com.vaadin.flow.component.messages.MessageInput Maven / Gradle / Ivy
/*
* Copyright 2000-2024 Vaadin Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package com.vaadin.flow.component.messages;
import java.util.Objects;
import com.vaadin.flow.component.Component;
import com.vaadin.flow.component.ComponentEvent;
import com.vaadin.flow.component.ComponentEventListener;
import com.vaadin.flow.component.DomEvent;
import com.vaadin.flow.component.EventData;
import com.vaadin.flow.component.Focusable;
import com.vaadin.flow.component.HasEnabled;
import com.vaadin.flow.component.HasSize;
import com.vaadin.flow.component.HasStyle;
import com.vaadin.flow.component.Tag;
import com.vaadin.flow.component.dependency.JsModule;
import com.vaadin.flow.component.dependency.NpmPackage;
import com.vaadin.flow.component.shared.HasTooltip;
import com.vaadin.flow.internal.JsonUtils;
import com.vaadin.flow.shared.Registration;
/**
* Message Input allows users to author and send messages. The component
* displays a text-area to input a message and a button to send it. The user can
* send the message with one of the following actions:
*
* - by pressing Enter (use Shift + Enter to add a new line)
* - by clicking the “send” button.
*
* Use the {@link MessageList} component to show messages that users have sent.
*
* @author Vaadin Ltd.
*/
@Tag("vaadin-message-input")
@NpmPackage(value = "@vaadin/polymer-legacy-adapter", version = "24.6.0")
@JsModule("@vaadin/polymer-legacy-adapter/style-modules.js")
@JsModule("@vaadin/message-input/src/vaadin-message-input.js")
@NpmPackage(value = "@vaadin/message-input", version = "24.6.0")
public class MessageInput extends Component implements Focusable,
HasSize, HasStyle, HasEnabled, HasTooltip {
private MessageInputI18n i18n;
/**
* The {@code submit} event which is fired by {@link MessageInput}
* component.
*/
@DomEvent("submit")
public static class SubmitEvent extends ComponentEvent {
private final String value;
/**
* Creates the event.
*
* @param source
* the source component
* @param fromClient
* true if the event comes from the client
* @param value
* the value of the input
*/
public SubmitEvent(MessageInput source, boolean fromClient,
@EventData("event.detail.value") String value) {
super(source, fromClient);
this.value = value;
}
/**
* Gets the submitted value.
*
* @return the submitted value
*/
public String getValue() {
return value;
}
}
/**
* Creates a new message input component.
*/
public MessageInput() {
}
/**
* Creates a new message input component with the provided listener that
* gets invoked when the user submits a new message.
*
* @param listener
* the submit event listener
* @see #addSubmitListener(ComponentEventListener)
*/
public MessageInput(ComponentEventListener listener) {
addSubmitListener(listener);
}
/**
* Adds a listener that is called when the user submits the value of the
* input field, which can be obtained with {@link SubmitEvent#getValue()}.
*
* The event is fired when clicking the Send button or pressing the Enter
* key.
*
* @param listener
* the listener
* @return registration for removal of the listener
*/
public Registration addSubmitListener(
ComponentEventListener listener) {
return addListener(SubmitEvent.class, listener);
}
/**
* Gets the internationalization object previously set for this component.
*
* NOTE: Updating the instance that is returned from this method will not
* update the component if not set again using
* {@link #setI18n(MessageInputI18n)}.
*
* @return the i18n object or {@code null} if no i18n object has been set
*/
public MessageInputI18n getI18n() {
return i18n;
}
/**
* Sets the internationalization object for this component. It enabled you
* to customize and translate the language used in the message input.
*
* Note: updating the object properties after setting the i18n will not
* update the component. To make the changes effective, you need to set the
* updated object again.
*
* @param i18n
* the i18n object, not {@code null}
*/
public void setI18n(MessageInputI18n i18n) {
Objects.requireNonNull(i18n, "The i18n object should not be null");
this.i18n = i18n;
getElement().setPropertyJson("i18n", JsonUtils.beanToJson(i18n));
}
}