Wrapped text in userList
(as suggested by @CyB3RC0nN0R) It is nice to see that JavaFX is less prone to shittyness than Swing is.
This commit is contained in:
parent
e6ac95ac14
commit
18819a873f
@ -2,6 +2,7 @@ package envoy.client.ui;
|
|||||||
|
|
||||||
import javafx.scene.control.Label;
|
import javafx.scene.control.Label;
|
||||||
import javafx.scene.control.ListCell;
|
import javafx.scene.control.ListCell;
|
||||||
|
import javafx.scene.control.ListView;
|
||||||
import javafx.scene.layout.VBox;
|
import javafx.scene.layout.VBox;
|
||||||
|
|
||||||
import envoy.data.Contact;
|
import envoy.data.Contact;
|
||||||
@ -18,6 +19,14 @@ import envoy.data.User;
|
|||||||
*/
|
*/
|
||||||
public class ContactListCell extends ListCell<Contact> {
|
public class ContactListCell extends ListCell<Contact> {
|
||||||
|
|
||||||
|
private final ListView<Contact> listView;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param listView the list view inside which this cell is contained
|
||||||
|
* @since Envoy Client v0.1-beta
|
||||||
|
*/
|
||||||
|
public ContactListCell(ListView<Contact> listView) { this.listView = listView; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Displays the name of a contact. If the contact is a user, their online status
|
* Displays the name of a contact. If the contact is a user, their online status
|
||||||
* is displayed as well.
|
* is displayed as well.
|
||||||
@ -32,17 +41,18 @@ public class ContactListCell extends ListCell<Contact> {
|
|||||||
setGraphic(null);
|
setGraphic(null);
|
||||||
} else {
|
} else {
|
||||||
// Container with contact name
|
// Container with contact name
|
||||||
final var vbox = new VBox(new Label(contact.getName()));
|
final var nameLabel = new Label(contact.getName());
|
||||||
|
nameLabel.setWrapText(true);
|
||||||
|
final var vbox = new VBox(nameLabel);
|
||||||
if (contact instanceof User) {
|
if (contact instanceof User) {
|
||||||
// Online status
|
// Online status
|
||||||
final var user = (User) contact;
|
final var user = (User) contact;
|
||||||
final var statusLabel = new Label(user.getStatus().toString());
|
final var statusLabel = new Label(user.getStatus().toString());
|
||||||
statusLabel.getStyleClass().add(user.getStatus().toString().toLowerCase());
|
statusLabel.getStyleClass().add(user.getStatus().toString().toLowerCase());
|
||||||
vbox.getChildren().add(statusLabel);
|
vbox.getChildren().add(statusLabel);
|
||||||
} else {
|
} else // Member count
|
||||||
// Member count
|
|
||||||
vbox.getChildren().add(new Label(((Group) contact).getContacts().size() + " members"));
|
vbox.getChildren().add(new Label(((Group) contact).getContacts().size() + " members"));
|
||||||
}
|
prefWidthProperty().bind(listView.widthProperty().subtract(40));
|
||||||
setGraphic(vbox);
|
setGraphic(vbox);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -92,8 +92,8 @@ public final class ChatScene {
|
|||||||
private void initialize() {
|
private void initialize() {
|
||||||
|
|
||||||
// Initialize message and user rendering
|
// Initialize message and user rendering
|
||||||
messageList.setCellFactory(listView -> new MessageListCell(listView));
|
messageList.setCellFactory(MessageListCell::new);
|
||||||
userList.setCellFactory(listView -> new ContactListCell());
|
userList.setCellFactory(ContactListCell::new);
|
||||||
|
|
||||||
settingsButton.setGraphic(new ImageView(IconUtil.load("/icons/settings.png", 16)));
|
settingsButton.setGraphic(new ImageView(IconUtil.load("/icons/settings.png", 16)));
|
||||||
|
|
||||||
|
@ -67,7 +67,7 @@ public class ContactSearchScene {
|
|||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
private void initialize() {
|
private void initialize() {
|
||||||
contactList.setCellFactory(e -> new ContactListCell());
|
contactList.setCellFactory(ContactListCell::new);
|
||||||
eventBus.register(ContactSearchResult.class,
|
eventBus.register(ContactSearchResult.class,
|
||||||
response -> Platform.runLater(() -> { contactList.getItems().clear(); contactList.getItems().addAll(response.get()); }));
|
response -> Platform.runLater(() -> { contactList.getItems().clear(); contactList.getItems().addAll(response.get()); }));
|
||||||
}
|
}
|
||||||
|
@ -41,7 +41,7 @@ public class GroupCreationScene {
|
|||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
private void initialize() {
|
private void initialize() {
|
||||||
contactList.setCellFactory(e -> new ContactListCell());
|
contactList.setCellFactory(ContactListCell::new);
|
||||||
contactList.getSelectionModel().setSelectionMode(SelectionMode.MULTIPLE);
|
contactList.getSelectionModel().setSelectionMode(SelectionMode.MULTIPLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user