/* * Copyright 2000-2021 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.ui; import org.jsoup.nodes.Element; import com.vaadin.shared.ui.textarea.TextAreaServerRpc; import com.vaadin.shared.ui.textarea.TextAreaState; import com.vaadin.ui.declarative.DesignContext; import com.vaadin.ui.declarative.DesignFormatter; /** * A text field that supports multi line editing. */ public class TextArea extends AbstractTextField { /** * Constructs an empty TextArea. */ public TextArea() { registerRpc(new TextAreaServerRpc() { @Override public void setHeight(String height) { TextArea.this.setHeight(height); } @Override public void setWidth(String width) { TextArea.this.setWidth(width); } }); clear(); } /** * Constructs an empty TextArea with given caption. * * @param caption * the caption for the field. */ public TextArea(String caption) { this(); setCaption(caption); } /** * Constructs a TextArea with given caption and value. * * @param caption * the caption for the field * @param value * the value for the field, not {@code null} */ public TextArea(String caption, String value) { this(caption); setValue(value); } /** * Constructs a new {@code TextArea} with a value change listener. *
* The listener is called when the value of this {@code TextArea} is changed
* either by the user or programmatically.
*
* @param valueChangeListener
* the value change listener, not {@code null}
* @since 8.0
*/
public TextArea(ValueChangeListener
* The listener is called when the value of this {@code TextArea} is changed
* either by the user or programmatically.
*
* @param caption
* the caption for the field
* @param valueChangeListener
* the value change listener, not {@code null}
* @since 8.0
*/
public TextArea(String caption,
ValueChangeListener
* The listener is called when the value of this {@code TextArea} is changed
* either by the user or programmatically.
*
* @param caption
* the caption for the field
* @param value
* the value for the field, not {@code null}
* @param valueChangeListener
* the value change listener, not {@code null}
* @since 8.0
*/
public TextArea(String caption, String value,
ValueChangeListener
* Note: it's not possible to display less than one row via this height
* setting method, so minimum number of rows has been set to 1.
*
* @param rows
* the number of rows for this text area.
*/
public void setRows(int rows) {
if (rows < 1) {
rows = 1;
}
getState().rows = rows;
}
/**
* Gets the number of rows in the text area.
*
* @return number of explicitly set rows.
*/
public int getRows() {
return getState(false).rows;
}
/**
* Sets the text area's word-wrap mode on or off.
*
* @param wordWrap
* true
to use word-wrap mode false
* otherwise.
*/
public void setWordWrap(boolean wordWrap) {
getState().wordWrap = wordWrap;
}
/**
* Tests if the text area is in word-wrap mode.
*
* @return true
if the component is in word-wrap mode,
* false
if not.
*/
public boolean isWordWrap() {
return getState(false).wordWrap;
}
@Override
public void readDesign(Element design, DesignContext designContext) {
super.readDesign(design, designContext);
doSetValue(DesignFormatter.decodeFromTextNode(design.html()));
}
@Override
public void writeDesign(Element design, DesignContext designContext) {
super.writeDesign(design, designContext);
design.html(DesignFormatter.encodeForTextNode(getValue()));
}
}