Я создал чат vaadin, и мне нужно, чтобы, когда любой пользователь заходил в чат, он видел только последние 10 сообщений из базы данных MySQL. Я думаю, что мой код реализован неправильно. Потому что он показывает мне первые 10 сообщений, хотя программа должна показывать последние 10 сообщений.
Мой код Класс MainView -
public class MainView extends VerticalLayout {
private final MessagesInfoManager messagesInfoManager;
private final RestService restService;
private String username;
private TextField textField;
private Message messageLast;
@Autowired
public MainView(RestService restService) {
this.messagesInfoManager = MessageConfigurator.getInstance().getChatMessagesInfoManager();
addClassName("main-view");
setSizeFull();
setDefaultHorizontalComponentAlignment(Alignment.CENTER);
H1 header = new H1("Vaadin Chat");
header.getElement().getThemeList().add("dark");
add(header);
askUsername();
this.restService = restService;
}
private void askUsername() {
HorizontalLayout layout = new HorizontalLayout();
TextField usernameField = new TextField();
Button startButton = new Button("Start chat");
layout.add(usernameField, startButton);
startButton.addClickListener(click -> {
username = usernameField.getValue();
remove(layout);
showChat(username);
});
add(layout);
}
private void showChat(String username) {
MessageList messageList = new MessageList();
List<Message> lasts = restService.getLast();
for (Message message : lasts) {
messageList.add(new Paragraph(message.getFromV() + ": " + message.getMessageV()));
}
messageLast = lasts.get(lasts.size() - 1);
add(messageList, createInputLayout(username, messageList));
expand(messageList);
}
private Component createInputLayout(String username, MessageList messageList) {
HorizontalLayout layout = new HorizontalLayout();
layout.setWidth("100%");
TextField messageField = new TextField();
messageField.addKeyDownListener(Key.ENTER, keyDownEvent -> sender(messageField, messageList));
Button sendButton = new Button("Send");
sendButton.addThemeVariants(ButtonVariant.LUMO_PRIMARY);
layout.add(messageField, sendButton);
layout.expand(messageField);
messageField.addFocusListener(event -> {
for (Message message : messagesInfoManager.getMessagesByUI(getUI())) {
if (!message.getFromV().equals(username)) {
message.setUnread(false);
this.restService.updateMessage(message.getId(), message);
}
}
});
sendButton.addClickListener(click -> sender(messageField, messageList));
messageField.focus();
return layout;
}
private void sender(TextField textField, MessageList messageList) {
Message message = new Message(username, textField.getValue());
message = restService.saveMessage(message);
messageLast = message;
this.textField = textField;
messagesInfoManager.updateMessageUIInfo(new MessageInfo(messageList, message, this));
textField.clear();
textField.focus();
}
@Scheduled(fixedDelay = 5000)
public void scheduleFixedDelayTask() {
MessageList messageList = new MessageList();
List<LinkedHashMap> lasts = restService.getUnreadMessages(messageLast.getId());
for (LinkedHashMap message : lasts) {
messageList.add(new Paragraph(message.get("fromV") + ": " + message.get("messageV")));
}
messagesInfoManager.updateMessageUIInfo(new MessageInfo(messageList, messageLast, this));
}
}
У меня есть api / last - который должен отображать последние 10 сообщений
@GetMapping("/api/last")
public List<Message> getLasts() {
return (messageService.getLast());
}
MessageRepository У меня есть SQL запрос на последние 10 сообщений
@Query(value = "SELECT * FROM chatMessages LIMIT 10", nativeQuery = true)
List<Message> getLastMessages();
My Github https://github.com/adk96/vaadin-chat