Changed message list to use JLabels as elements
* Using JLabel as message list element * Managing sender and recipient in Client * Reduced amount of ReST requests
This commit is contained in:
parent
4022e227ca
commit
8751bd8781
@ -1,40 +1,20 @@
|
||||
package envoy.client;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import javax.swing.DefaultListModel;
|
||||
|
||||
import envoy.schema.Message;
|
||||
import envoy.schema.User;
|
||||
|
||||
public class Chat {
|
||||
|
||||
public long chatPartnerID;
|
||||
public List<Message> messageList;
|
||||
DefaultListModel chatModel;
|
||||
public Chat() {
|
||||
chatPartnerID = 0;
|
||||
chatModel = new DefaultListModel();
|
||||
messageList = new ArrayList<Message>();
|
||||
}
|
||||
|
||||
public void setUserID(long givenUserID) { chatPartnerID = givenUserID;}
|
||||
|
||||
public long getUserID() { return chatPartnerID;}
|
||||
|
||||
public int getSize() { return chatModel.getSize();}
|
||||
|
||||
public void addMessage(String message) { chatModel.addElement(message);}
|
||||
|
||||
public String getMessageAt(int index) { return (String) chatModel.getElementAt(index);}
|
||||
|
||||
@SuppressWarnings("unchecked")
|
||||
public DefaultListModel<String> getModel() { return chatModel;}
|
||||
|
||||
public int getListSize() { return messageList.size();}
|
||||
|
||||
public void addMessageElement(Message message) { messageList.add(message);}
|
||||
|
||||
public Message getMessageElement(int index) { return messageList.get(index);}
|
||||
|
||||
}
|
||||
private User recipient;
|
||||
private DefaultListModel<Message> model = new DefaultListModel<>();
|
||||
|
||||
public Chat(User recipient) { this.recipient = recipient; }
|
||||
|
||||
public User getRecipient() { return recipient; }
|
||||
|
||||
public void appendMessage(Message message) { model.addElement(message); }
|
||||
|
||||
public DefaultListModel<Message> getModel() { return model; }
|
||||
}
|
@ -36,7 +36,7 @@ public class Client {
|
||||
private ObjectFactory objectFactory = new ObjectFactory();
|
||||
private DatatypeFactory datatypeFactory;
|
||||
private Config config;
|
||||
private User user;
|
||||
private User sender, recipient;
|
||||
|
||||
public Client(Config config, String username) {
|
||||
this.config = config;
|
||||
@ -45,8 +45,7 @@ public class Client {
|
||||
} catch (DatatypeConfigurationException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
user = getUser(username);
|
||||
System.out.printf("Mein Name ist %s und ich habe die ID %d%n", user.getName(), user.getID());
|
||||
sender = getUser(username);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -89,15 +88,13 @@ public class Client {
|
||||
/**
|
||||
* Creates a {@link Message} object serializable to XML.
|
||||
*
|
||||
* @param senderID The ID of the sender
|
||||
* @param recipientID The ID of the recipient
|
||||
* @param textContent The content (text) of the message
|
||||
* @return prepared {@link Message} object
|
||||
*/
|
||||
public Message createMessage(long senderID, long recipientID, String textContent) {
|
||||
public Message createMessage(String textContent) {
|
||||
Message.MetaData metaData = objectFactory.createMessageMetaData();
|
||||
metaData.setSender(senderID);
|
||||
metaData.setRecipient(recipientID);
|
||||
metaData.setSender(sender.getID());
|
||||
metaData.setRecipient(recipient.getID());
|
||||
metaData.setState(MessageState.WAITING);
|
||||
metaData.setDate(datatypeFactory.newXMLGregorianCalendar(Instant.now().toString()));
|
||||
|
||||
@ -150,10 +147,14 @@ public class Client {
|
||||
}
|
||||
|
||||
/**
|
||||
* @return the user id of this client
|
||||
* @return the sender object that represents this client
|
||||
* @since Envoy 0.1
|
||||
*/
|
||||
public long getSenderID() { return user.getID(); }
|
||||
|
||||
public User getClientUser() { return user;}
|
||||
public User getSender() { return sender; }
|
||||
|
||||
public User getRecipient() { return recipient; }
|
||||
|
||||
public void setRecipient(User recipient) { this.recipient = recipient; }
|
||||
|
||||
public boolean hasRecipient() { return recipient != null; }
|
||||
}
|
@ -42,25 +42,21 @@ public class ChatWindow extends JFrame {
|
||||
|
||||
private static final long serialVersionUID = 6865098428255463649L;
|
||||
|
||||
private long recipientID = 0;
|
||||
private JPanel contentPane = new JPanel();
|
||||
private JPanel contentPane = new JPanel();
|
||||
|
||||
private Client client;
|
||||
|
||||
private DefaultListModel<String> messageListModel = new DefaultListModel<>();
|
||||
private DefaultListModel<Message> messageListModel = new DefaultListModel<>();
|
||||
private List<Chat> partnerChatList = new ArrayList<Chat>();
|
||||
private Chat currentChat;
|
||||
|
||||
@SuppressWarnings("null")
|
||||
public ChatWindow(Client client) {
|
||||
this.client = client;
|
||||
|
||||
// Initialize chat list and current chat
|
||||
Users chatUsers = client.getUsersListXml();
|
||||
|
||||
for (int i = 0; i < chatUsers.getUser().size(); i++) {
|
||||
Chat userChat = new Chat();
|
||||
userChat.setUserID(chatUsers.getUser().get(i).getID());
|
||||
partnerChatList.add(userChat);
|
||||
}
|
||||
chatUsers.getUser().forEach(user -> partnerChatList.add(new Chat(user)));
|
||||
if (partnerChatList.size() > 0) currentChat = partnerChatList.get(0);
|
||||
|
||||
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
|
||||
setBounds(100, 100, 600, 800);
|
||||
@ -78,24 +74,25 @@ public class ChatWindow extends JFrame {
|
||||
gbl_contentPane.rowWeights = new double[] { 0.05, 1, 0.07 };
|
||||
contentPane.setLayout(gbl_contentPane);
|
||||
|
||||
JList<String> elementList = new JList<>();
|
||||
elementList.setFocusTraversalKeysEnabled(false);
|
||||
JList<Message> messageList = new JList<>();
|
||||
messageList.setCellRenderer(new MessageListRenderer());
|
||||
|
||||
elementList.setSelectionForeground(new Color(255, 255, 255));
|
||||
elementList.setSelectionBackground(new Color(102, 0, 153));
|
||||
elementList.setComponentOrientation(ComponentOrientation.LEFT_TO_RIGHT);
|
||||
elementList.setForeground(new Color(255, 255, 255));
|
||||
elementList.setBackground(new Color(51, 51, 51));
|
||||
messageList.setFocusTraversalKeysEnabled(false);
|
||||
messageList.setSelectionForeground(new Color(255, 255, 255));
|
||||
messageList.setSelectionBackground(new Color(102, 0, 153));
|
||||
messageList.setComponentOrientation(ComponentOrientation.LEFT_TO_RIGHT);
|
||||
messageList.setForeground(new Color(255, 255, 255));
|
||||
messageList.setBackground(new Color(51, 51, 51));
|
||||
|
||||
elementList.setModel(messageListModel);
|
||||
elementList.setFont(new Font("Arial", Font.PLAIN, 17));
|
||||
elementList.setFixedCellHeight(60);
|
||||
elementList.setBorder(new EmptyBorder(5, 5, 5, 5));
|
||||
messageList.setModel(messageListModel);
|
||||
messageList.setFont(new Font("Arial", Font.PLAIN, 17));
|
||||
messageList.setFixedCellHeight(60);
|
||||
messageList.setBorder(new EmptyBorder(5, 5, 5, 5));
|
||||
|
||||
JScrollPane scrollPane = new JScrollPane();
|
||||
scrollPane.setForeground(new Color(0, 0, 0));
|
||||
scrollPane.setBackground(new Color(51, 51, 51));
|
||||
scrollPane.setViewportView(elementList);
|
||||
scrollPane.setViewportView(messageList);
|
||||
scrollPane.setBorder(null);
|
||||
|
||||
GridBagConstraints gbc_scrollPane = new GridBagConstraints();
|
||||
@ -141,27 +138,27 @@ public class ChatWindow extends JFrame {
|
||||
|
||||
gbc_moveSelectionPostButton.insets = new Insets(10, 10, 10, 10);
|
||||
|
||||
contentPane.add(postButton, gbc_moveSelectionPostButton);
|
||||
|
||||
postButton.addActionListener((evt) -> {
|
||||
if (recipientID == 0) System.out.println("Please select recipient");
|
||||
if (!client.hasRecipient()) {
|
||||
JOptionPane.showMessageDialog(this,
|
||||
"Please select a recipient!",
|
||||
"Cannot send message",
|
||||
JOptionPane.INFORMATION_MESSAGE);
|
||||
return;
|
||||
}
|
||||
|
||||
// TODO: Acquire proper sender id
|
||||
if (!messageEnterTextfield.getText().isEmpty() && recipientID != 0) try {
|
||||
final Message message = client
|
||||
.createMessage(client.getSenderID(), recipientID, messageEnterTextfield.getText());
|
||||
if (!messageEnterTextfield.getText().isEmpty()) try {
|
||||
|
||||
// Create and send message object
|
||||
final Message message = client.createMessage(messageEnterTextfield.getText());
|
||||
client.sendMessage(message);
|
||||
Chat partnerChat = null;
|
||||
for (int i = 0; i < partnerChatList.size(); i++) {
|
||||
if (recipientID == partnerChatList.get(i).getUserID()) {
|
||||
partnerChat = partnerChatList.get(i);
|
||||
// System.out.println("partnerChatID: " + partnerChatList.get(i).getUserID());
|
||||
|
||||
}
|
||||
}
|
||||
appendMessageToChat(message, partnerChat);
|
||||
// Append message object to chat
|
||||
currentChat.appendMessage(message);
|
||||
messageList.setModel(currentChat.getModel());
|
||||
|
||||
// Clear text field
|
||||
messageEnterTextfield.setText("");
|
||||
elementList.setModel(partnerChat.getModel());
|
||||
contentPane.revalidate();
|
||||
} catch (Exception e) {
|
||||
JOptionPane.showMessageDialog(this,
|
||||
@ -172,6 +169,8 @@ public class ChatWindow extends JFrame {
|
||||
}
|
||||
});
|
||||
|
||||
contentPane.add(postButton, gbc_moveSelectionPostButton);
|
||||
|
||||
// Partner name display
|
||||
JTextPane textPane = new JTextPane();
|
||||
textPane.setBackground(new Color(0, 0, 0));
|
||||
@ -194,22 +193,20 @@ public class ChatWindow extends JFrame {
|
||||
userList.addListSelectionListener((listSelectionEvent) -> {
|
||||
if (!listSelectionEvent.getValueIsAdjusting()) {
|
||||
@SuppressWarnings("unchecked")
|
||||
JList<User> selectedUserList = (JList<User>) listSelectionEvent.getSource();
|
||||
recipientID = selectedUserList.getModel().getElementAt(selectedUserList.getSelectedIndex()).getID();
|
||||
Chat selectedChat = null;
|
||||
final JList<User> selectedUserList = (JList<User>) listSelectionEvent.getSource();
|
||||
final User user = selectedUserList.getSelectedValue();
|
||||
client.setRecipient(user);
|
||||
|
||||
for (int i = 0; i < partnerChatList.size(); i++) {
|
||||
if (selectedUserList.getSelectedIndex() == partnerChatList.get(i).getUserID() - 1) {
|
||||
selectedChat = partnerChatList.get(i);
|
||||
currentChat = partnerChatList.stream()
|
||||
.filter(chat -> chat.getRecipient().getID() == user.getID())
|
||||
.findFirst()
|
||||
.get();
|
||||
|
||||
}
|
||||
}
|
||||
User partner = getPartner();
|
||||
System.out.println(partner.getName());
|
||||
textPane.setText(partner.getName());
|
||||
elementList.setModel(selectedChat.getModel());
|
||||
client.setRecipient(user);
|
||||
|
||||
textPane.setText(currentChat.getRecipient().getName());
|
||||
messageList.setModel(currentChat.getModel());
|
||||
contentPane.revalidate();
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
@ -221,7 +218,7 @@ public class ChatWindow extends JFrame {
|
||||
userList.setBorder(new EmptyBorder(5, 5, 5, 5));
|
||||
|
||||
GridBagConstraints gbc_userList = new GridBagConstraints();
|
||||
gbc_userList.fill = GridBagConstraints.VERTICAL;
|
||||
gbc_userList.fill = GridBagConstraints.VERTICAL;
|
||||
gbc_userList.gridx = 0;
|
||||
gbc_userList.gridy = 1;
|
||||
gbc_userList.anchor = GridBagConstraints.PAGE_START;
|
||||
@ -247,39 +244,4 @@ public class ChatWindow extends JFrame {
|
||||
SwingUtilities.invokeLater(() -> userList.setModel(userListModel));
|
||||
}).start();
|
||||
}
|
||||
|
||||
/**
|
||||
* Extracts the first text content from a message.
|
||||
*
|
||||
* @param message The message from which to return the text content
|
||||
* @return The first content of type 'text'
|
||||
*/
|
||||
private String getFirstTextContent(Message message) { return message.getContent().get(0).getText(); }
|
||||
|
||||
/**
|
||||
* Appends a message with sender and message content to the message list.
|
||||
*
|
||||
* @param message The message to append
|
||||
*/
|
||||
private void appendMessageToChat(Message message, Chat partnerChat) {
|
||||
partnerChat.addMessage("<html>"
|
||||
+ "<p style=\"color:#d2d235\"> <b> <small>"
|
||||
+ client.getClientUser().getName() + " "
|
||||
+ (message.getMetaData().getDate().getHour() + 2) + ":" //Dont know why this parameter 2 hours back.
|
||||
+ message.getMetaData().getDate().getMinute() + ":"
|
||||
+ message.getMetaData().getDate().getSecond()
|
||||
//Dont know
|
||||
+ "</b> </small>" + "<br>" + "<p style=\"color:white\">" + getFirstTextContent(message)
|
||||
+ "</span></html>");
|
||||
partnerChat.addMessageElement(message);
|
||||
}
|
||||
|
||||
public User getPartner() {
|
||||
Users users = client.getUsersListXml();
|
||||
User partner = null;
|
||||
for (int i = 0; i < users.getUser().size(); i++) {
|
||||
if (users.getUser().get(i).getID() == recipientID) { partner = users.getUser().get(i); }
|
||||
}
|
||||
return partner;
|
||||
}
|
||||
}
|
42
src/main/java/envoy/client/ui/MessageListRenderer.java
Normal file
42
src/main/java/envoy/client/ui/MessageListRenderer.java
Normal file
@ -0,0 +1,42 @@
|
||||
package envoy.client.ui;
|
||||
|
||||
import java.awt.Component;
|
||||
|
||||
import javax.swing.JLabel;
|
||||
import javax.swing.JList;
|
||||
import javax.swing.ListCellRenderer;
|
||||
|
||||
import envoy.schema.Message;
|
||||
|
||||
/**
|
||||
* Project: <strong>envoy-client</strong><br>
|
||||
* File: <strong>UserListRenderer.java</strong><br>
|
||||
* Created: <strong>19 Oct 2019</strong><br>
|
||||
*
|
||||
* @author Kai S. K. Engelbart
|
||||
*/
|
||||
public class MessageListRenderer extends JLabel implements ListCellRenderer<Message> {
|
||||
|
||||
private static final long serialVersionUID = 5164417379767181198L;
|
||||
|
||||
@Override
|
||||
public Component getListCellRendererComponent(JList<? extends Message> list, Message value, int index,
|
||||
boolean isSelected,
|
||||
boolean cellHasFocus) {
|
||||
if (isSelected) {
|
||||
setBackground(list.getSelectionBackground());
|
||||
setForeground(list.getSelectionForeground());
|
||||
} else {
|
||||
setBackground(list.getBackground());
|
||||
setForeground(list.getForeground());
|
||||
}
|
||||
|
||||
// Enable background rendering
|
||||
setOpaque(true);
|
||||
|
||||
setText(value.getContent().get(0).getText());
|
||||
setFont(list.getFont());
|
||||
|
||||
return this;
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user