Вывод привет в диалоге чата vaadin (Spring boot и spring scheduler + vaadin 14) - PullRequest
0 голосов
/ 21 января 2020

Я создал чат на vaadine и весенней загрузке. Итак, у меня есть проблема с планировщиком, я хотел написать планировщик, который отображает «привет» каждую секунду, но как я могу написать так, чтобы он вызывал привет каждую секунду, только это было похоже на этот пример вывода -

hello 1 - (when 1 second has passed)
hello 2 - (after two seconds)
hello 3 - (after three seconds)
.
.
.
.
hello 45 - (after 45 seconds)
.
.
.
.
hello 100 - (after 100 seconds)

Пример изображения enter image description here

Мой код, Как я могу запустить планировщик чата при входе в систему

public class MainView extends VerticalLayout {

    private final MessagesInfoManager messagesInfoManager;
    private final RestService restService;
    private String username;



     private int count=0;

    @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.getFrom() + ": " + message.getMessage()));
        }

        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.getFrom().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);
        messagesInfoManager.updateMessageUIInfo(new MessageInfo(messageList, message, this));
        textField.clear();
        textField.focus();
    }






@Scheduled (fixedDelay = 1000)
public void test() {
    count++; 
    System.out.println("Hello"+count);

}
}

В отображении компилятора теперь мне нужно пообщаться enter image description here

Ответы [ 2 ]

0 голосов
/ 21 января 2020
@Scheduled(fixedDelay = 1000)
    public void test() {
        count++;
        System.out.println("Hello" + count);

        this.getUI().get().access(() -> {

            if (messageList != null) {
                messageList.add(new Paragraph("From me" + ": " + "Hello" + count));
            }

        });

    }
}
0 голосов
/ 21 января 2020

То, как вы устанавливаете планировщик в Java, само по себе мало связано с Ваадином. Вы можете использовать второй поток, который вы запускаете, или, как вам кажется, готовый инструмент для него. Похоже на функцию Spring, если я не ошибаюсь.

После этого вы обновляете компоненты Vaadin, чтобы они содержали новые сообщения. Например, вы можете превратить свой messageList в поле и в test() добавить новый абзац к нему. Или используйте бэкэнд-сервис, в который вам нужно отправить sh сообщений оттуда.

Когда вы обновляете пользовательский интерфейс из вторичного потока, помните, что вы можете столкнуться с условиями гонки. По этой причине вам следует заблокировать сеанс пользователя на время внесения изменений в пользовательский интерфейс .

...