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

com.vaadin.polymer.paper.widget.PaperInputContainer Maven / Gradle / Ivy

There is a newer version: 1.9.3.1
Show newest version
/*
 * This code was generated with Vaadin Web Component GWT API Generator, 
 * from paper-input project by The Polymer Authors
 * that is licensed with http://polymer.github.io/LICENSE.txt license.
 */
package com.vaadin.polymer.paper.widget;

import com.vaadin.polymer.paper.element.*;

import com.vaadin.polymer.PolymerWidget;
import com.vaadin.polymer.elemental.*;
import com.google.gwt.core.client.JsArray;
import com.google.gwt.event.shared.HandlerRegistration;
import com.google.gwt.core.client.JavaScriptObject;

/**
 * 

<paper-input-container> is a container for a <label>, an <input is="iron-input"> or
<iron-autogrow-textarea> and optional add-on elements such as an error message or character
counter, used to implement Material Design text fields.

*

For example:

*
<paper-input-container>
 *   <label>Your name</label>
 *   <input is="iron-input">
 * </paper-input-container>
 * 
 * 
 * 

Listening for input changes

*

By default, it listens for changes on the bind-value attribute on its children nodes and perform
tasks such as auto-validating and label styling when the bind-value changes. You can configure
the attribute it listens to with the attr-for-value attribute.

*

Using a custom input element

*

You can use a custom input element in a <paper-input-container>, for example to implement a
compound input field like a social security number input. The custom input element should have the
paper-input-input class, have a notify:true value property and optionally implements
Polymer.IronValidatableBehavior if it is validatble.

*
<paper-input-container attr-for-value="ssn-value">
 *   <label>Social security number</label>
 *   <ssn-input class="paper-input-input"></ssn-input>
 * </paper-input-container>
 * 
 * 
 * 

Validation

*

If the auto-validate attribute is set, the input container will validate the input and update
the container styling when the input value changes.

*

Add-ons

*

Add-ons are child elements of a <paper-input-container> with the add-on attribute and
implements the Polymer.PaperInputAddonBehavior behavior. They are notified when the input value
or validity changes, and may implement functionality such as error messages or character counters.
They appear at the bottom of the input.

*

Styling

*

The following custom properties and mixins are available for styling:

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
Custom propertyDescriptionDefault
--paper-input-container-colorLabel and underline color when the input is not focused--secondary-text-color
--paper-input-container-focus-colorLabel and underline color when the input is focused--default-primary-color
--paper-input-container-invalid-colorLabel and underline color when the input is focused--google-red-500
--paper-input-container-input-colorInput foreground color--primary-text-color
--paper-input-containerMixin applied to the container{}
--paper-input-container-labelMixin applied to the label{}
--paper-input-container-inputMixin applied to the input{}
*

This element is display:block by default, but you can set the inline attribute to make it
display:inline-block.

*/ public class PaperInputContainer extends PolymerWidget { /** * Default Constructor. */ public PaperInputContainer() { this(""); } /** * Constructor used by UIBinder to create widgets with content. */ public PaperInputContainer(String html) { super(PaperInputContainerElement.TAG, PaperInputContainerElement.SRC, html); } /** * Gets a handle to the Polymer object's underlying DOM element. */ public PaperInputContainerElement getPolymerElement() { return (PaperInputContainerElement) getElement(); } /** *

Set to true to always float the floating label.

* * JavaScript Info: * @property alwaysFloatLabel * @type Boolean * */ public boolean getAlwaysFloatLabel(){ return getPolymerElement().getAlwaysFloatLabel(); } /** *

Set to true to always float the floating label.

* * JavaScript Info: * @property alwaysFloatLabel * @type Boolean * */ public void setAlwaysFloatLabel(boolean value) { getPolymerElement().setAlwaysFloatLabel(value); } /** *

The attribute to listen for value changes on.

* * JavaScript Info: * @property attrForValue * @type String * */ public String getAttrForValue(){ return getPolymerElement().getAttrForValue(); } /** *

The attribute to listen for value changes on.

* * JavaScript Info: * @property attrForValue * @type String * */ public void setAttrForValue(String value) { getPolymerElement().setAttrForValue(value); } /** *

Set to true to auto-validate the input value when it changes.

* * JavaScript Info: * @property autoValidate * @type Boolean * */ public boolean getAutoValidate(){ return getPolymerElement().getAutoValidate(); } /** *

Set to true to auto-validate the input value when it changes.

* * JavaScript Info: * @property autoValidate * @type Boolean * */ public void setAutoValidate(boolean value) { getPolymerElement().setAutoValidate(value); } /** *

True if the input has focus.

* * JavaScript Info: * @property focused * @type Boolean * */ public boolean getFocused(){ return getPolymerElement().getFocused(); } /** *

True if the input has focus.

* * JavaScript Info: * @property focused * @type Boolean * */ public void setFocused(boolean value) { getPolymerElement().setFocused(value); } /** *

True if the input is invalid. This property is set automatically when the input value
changes if auto-validating, or when the iron-input-valid event is heard from a child.

* * JavaScript Info: * @property invalid * @type Boolean * */ public boolean getInvalid(){ return getPolymerElement().getInvalid(); } /** *

True if the input is invalid. This property is set automatically when the input value
changes if auto-validating, or when the iron-input-valid event is heard from a child.

* * JavaScript Info: * @property invalid * @type Boolean * */ public void setInvalid(boolean value) { getPolymerElement().setInvalid(value); } /** *

Set to true to disable the floating label. The label disappears when the input value is
not null.

* * JavaScript Info: * @property noLabelFloat * @type Boolean * */ public boolean getNoLabelFloat(){ return getPolymerElement().getNoLabelFloat(); } /** *

Set to true to disable the floating label. The label disappears when the input value is
not null.

* * JavaScript Info: * @property noLabelFloat * @type Boolean * */ public void setNoLabelFloat(boolean value) { getPolymerElement().setNoLabelFloat(value); } /** *

Call this to update the state of add-ons.

* * JavaScript Info: * @method updateAddons * @param {Object} state * */ public void updateAddons(JavaScriptObject state) { getPolymerElement().updateAddons(state); } /** * * * JavaScript Info: * @method attached * */ public void attached() { getPolymerElement().attached(); } /** * * * JavaScript Info: * @property listeners * @type Object * */ public JavaScriptObject getListeners(){ return getPolymerElement().getListeners(); } /** * * * JavaScript Info: * @property listeners * @type Object * */ public void setListeners(JavaScriptObject value) { getPolymerElement().setListeners(value); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy