added main components for joining and leaving rooms
This commit is contained in:
@@ -3,8 +3,12 @@ package client;
|
|||||||
import javafx.application.Platform;
|
import javafx.application.Platform;
|
||||||
import javafx.fxml.FXML;
|
import javafx.fxml.FXML;
|
||||||
import javafx.scene.control.Alert;
|
import javafx.scene.control.Alert;
|
||||||
|
import javafx.scene.control.Button;
|
||||||
|
import javafx.scene.control.ButtonType;
|
||||||
|
import javafx.scene.control.TextField;
|
||||||
import javafx.scene.layout.Border;
|
import javafx.scene.layout.Border;
|
||||||
import javafx.scene.layout.BorderPane;
|
import javafx.scene.layout.BorderPane;
|
||||||
|
import javafx.scene.layout.VBox;
|
||||||
import javafx.stage.Stage;
|
import javafx.stage.Stage;
|
||||||
import network.protocol.packets.ServerResponsePacket;
|
import network.protocol.packets.ServerResponsePacket;
|
||||||
|
|
||||||
@@ -12,14 +16,23 @@ import java.net.InetSocketAddress;
|
|||||||
import java.net.SocketException;
|
import java.net.SocketException;
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
public class ClientGuiController implements ClientListener {
|
public class ClientGuiController implements ClientListener {
|
||||||
|
|
||||||
private Client client;
|
private Client client;
|
||||||
|
|
||||||
|
private boolean connected = true;
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
private BorderPane vueContainer;
|
private BorderPane vueContainer;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private VBox roomList;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private VBox chatList;
|
||||||
|
|
||||||
public void setClient(Client client) {
|
public void setClient(Client client) {
|
||||||
this.client = client;
|
this.client = client;
|
||||||
}
|
}
|
||||||
@@ -42,8 +55,15 @@ public void initialize() throws SocketException {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void handleConnexionError() {
|
public void handleConnexionError() {
|
||||||
System.out.println("Connection error");
|
Platform.runLater(() -> {
|
||||||
System.out.println(UsernameSingleton.getInstance().getUsername());
|
Alert alert = new Alert(Alert.AlertType.ERROR);
|
||||||
|
alert.setTitle("Connection");
|
||||||
|
alert.setHeaderText("Connection failed");
|
||||||
|
Optional<ButtonType> res = alert.showAndWait();
|
||||||
|
if (res.isPresent() && res.get() == ButtonType.OK) {
|
||||||
|
((Stage) vueContainer.getScene().getWindow()).close();
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -62,7 +82,44 @@ public void initialize() throws SocketException {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void handleRoomList(List<String> roomNames) {
|
public void handleRoomList(List<String> roomNames) {
|
||||||
|
Platform.runLater(() -> {
|
||||||
|
roomList.getChildren().clear();
|
||||||
|
for (String roomName : roomNames) {
|
||||||
|
Button button = new Button(roomName);
|
||||||
|
button.setOnAction(event -> {
|
||||||
|
client.SendJoinRoom(roomName);
|
||||||
|
createChatEnv(roomName);
|
||||||
|
});
|
||||||
|
roomList.getChildren().add(button);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void createChatEnv(String roomName) {
|
||||||
|
// <TextField fx:id="messageInput" promptText="Type a message..." styleClass="message-input"/>
|
||||||
|
// <Button fx:id="sendButton" text="Send" styleClass="send-button"/>
|
||||||
|
Platform.runLater(() -> {
|
||||||
|
chatList.getChildren().clear();
|
||||||
|
Button leaveButton = new Button("Leave room");
|
||||||
|
leaveButton.setOnAction(event -> {
|
||||||
|
client.SendLeaveRoom();
|
||||||
|
chatList.getChildren().clear();
|
||||||
|
});
|
||||||
|
chatList.getChildren().add(leaveButton);
|
||||||
|
|
||||||
|
TextField messageInput = new TextField();
|
||||||
|
messageInput.setPromptText("Type a message...");
|
||||||
|
messageInput.getStyleClass().add("message-input");
|
||||||
|
chatList.getChildren().add(messageInput);
|
||||||
|
|
||||||
|
Button sendButton = new Button("Send");
|
||||||
|
sendButton.getStyleClass().add("send-button");
|
||||||
|
sendButton.setOnAction(event -> {
|
||||||
|
client.SendChatMessage(messageInput.getText());
|
||||||
|
messageInput.clear();
|
||||||
|
});
|
||||||
|
chatList.getChildren().add(sendButton);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -37,6 +37,7 @@
|
|||||||
<VBox fx:id="chat" spacing="10.0">
|
<VBox fx:id="chat" spacing="10.0">
|
||||||
<Label text="Chat" style="-fx-font-size: 18px;"/>
|
<Label text="Chat" style="-fx-font-size: 18px;"/>
|
||||||
<VBox fx:id="chatList" styleClass="chat-list" spacing="5.0"/>
|
<VBox fx:id="chatList" styleClass="chat-list" spacing="5.0"/>
|
||||||
|
<HBox fx:id="chatInput" styleClass="chat-input" spacing="5.0" />
|
||||||
</VBox>
|
</VBox>
|
||||||
</ScrollPane>
|
</ScrollPane>
|
||||||
</center>
|
</center>
|
||||||
|
|||||||
Reference in New Issue
Block a user