All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.vaadin.ui.TextField Maven / Gradle / Ivy

There is a newer version: 8.27.3
Show newest version
/*
 * Copyright (C) 2000-2024 Vaadin Ltd
 *
 * This program is available under Vaadin Commercial License and Service Terms.
 *
 * See  for the full
 * license.
 */

package com.vaadin.ui;

import org.jsoup.nodes.Attributes;
import org.jsoup.nodes.Element;

import com.vaadin.shared.ui.textfield.TextFieldState;
import com.vaadin.ui.declarative.DesignAttributeHandler;
import com.vaadin.ui.declarative.DesignContext;

/**
 * A component for editing textual data that fits on a single line. For a
 * multi-line textarea, see the {@link TextArea} component.
 *
 * @author Vaadin Ltd.
 */
@SuppressWarnings("serial")
public class TextField extends AbstractTextField {

    /**
     * Constructs an empty TextField with no caption.
     */
    public TextField() {
        clear();
    }

    /**
     * Constructs an empty TextField with given caption.
     *
     * @param caption
     *            the caption String for the editor.
     */
    public TextField(String caption) {
        this();
        setCaption(caption);
    }

    /**
     * Constructs a new TextField with the given caption and
     * initial text contents.
     *
     * @param caption
     *            the caption String for the editor.
     * @param value
     *            the initial text content of the editor, not {@code null}
     */
    public TextField(String caption, String value) {
        setValue(value);
        setCaption(caption);
    }

    /**
     * Constructs a new {@code TextField} with a value change listener. The
     * listener is called when the value of this {@code TextField} is changed
     * either by the user or programmatically.
     *
     * @param valueChangeListener
     *            the value change listener, not {@code null}
     */
    public TextField(ValueChangeListener valueChangeListener) {
        addValueChangeListener(valueChangeListener);
    }

    /**
     * Constructs a new {@code TextField} with the given caption and a value
     * change listener.
     * 

* The listener is called when the value of this {@code TextField} is * changed either by the user or programmatically. * * @param caption * the caption {@code String} for the editor. * @param valueChangeListener * the value change listener, not {@code null} */ public TextField(String caption, ValueChangeListener valueChangeListener) { this(valueChangeListener); setCaption(caption); } /** * Constructs a new {@code TextField} with the given caption, initial text * contents and a value change listener. *

* The listener is called when the value of this {@code TextField} is * changed either by the user or programmatically. * * @param caption * the caption {@code String} for the editor. * @param value * the initial text content of the editor, not {@code null} * @param valueChangeListener * the value change listener, not {@code null} */ public TextField(String caption, String value, ValueChangeListener valueChangeListener) { this(caption, value); addValueChangeListener(valueChangeListener); } @Override protected TextFieldState getState() { return (TextFieldState) super.getState(); } @Override protected TextFieldState getState(boolean markAsDirty) { return (TextFieldState) super.getState(markAsDirty); } @Override public void readDesign(Element design, DesignContext designContext) { super.readDesign(design, designContext); Attributes attr = design.attributes(); if (attr.hasKey("value")) { String text = DesignAttributeHandler.readAttribute("value", attr, String.class); doSetValue(text); } } @Override public void writeDesign(Element design, DesignContext designContext) { super.writeDesign(design, designContext); AbstractTextField def = designContext.getDefaultInstance(this); Attributes attr = design.attributes(); DesignAttributeHandler.writeAttribute("value", attr, getValue(), def.getValue(), String.class, designContext); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy