Отображает сообщение в неправильном порядке - PullRequest
0 голосов
/ 29 января 2020

Я создал чат 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

Ответы [ 2 ]

6 голосов
/ 29 января 2020

SQL запросы сортируются по возрастанию по умолчанию. Вам нужно настроить свой запрос на сортировку в порядке убывания.

@Query(value = "SELECT * FROM chatMessages ORDER BY <yourFieldName> DESC LIMIT 10", nativeQuery = true)
    List<Message> getLastMessages();
2 голосов
/ 29 января 2020

Чтобы вернуть последние 10 записей, вы можете использовать что-то вроде этого:

В Репозиторий сообщений изменить:

@Query(value = "SELECT * FROM chatMessages LIMIT 10", nativeQuery = true)
List<Message> getLastMessages();

На

Page<Message> findAll(Pageable pageable);

В MessageServiceImpl изменить:

@Override
public List<Message> getLast() {
    return repository.getLastMessages();
}

К

@Override
public List<Message> getLast() {
    Pageable pageable = new PageRequest(0, 10, Sort.Direction.DESC, "time");
    Page<Message> bottomPage = repository.findAll(pageable);
    return bottomPage.getContent();
}
...