com.vaadin.polymer.paper.widget.PaperInputContainer Maven / Gradle / Ivy
/*
* 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 validatable.
* <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.
* Prefixes and suffixes
* These are child elements of a <paper-input-container>
with the prefix
or suffix
attribute, and are displayed inline with the input, before or after.
* <paper-input-container>
* <div prefix>$</div>
* <label>Total</label>
* <input is="iron-input">
* <paper-icon-button suffix icon="clear"></paper-icon-button>
* </paper-input-container>
*
*
*
Styling
* The following custom properties and mixins are available for styling:
*
*
*
* Custom property
* Description
* Default
*
*
*
*
* --paper-input-container-color
* Label and underline color when the input is not focused
* --secondary-text-color
*
*
* --paper-input-container-focus-color
* Label and underline color when the input is focused
* --default-primary-color
*
*
* --paper-input-container-invalid-color
* Label and underline color when the input is is invalid
* --google-red-500
*
*
* --paper-input-container-input-color
* Input foreground color
* --primary-text-color
*
*
* --paper-input-container
* Mixin applied to the container
* {}
*
*
* --paper-input-container-label
* Mixin applied to the label
* {}
*
*
* --paper-input-container-label-focus
* Mixin applied to the label when the input is focused
* {}
*
*
* --paper-input-container-input
* Mixin applied to the input
* {}
*
*
* --paper-input-container-input-disabled
* Mixin applied to the input when it’s disabled
* {}
*
*
* --paper-input-container-prefix
* Mixin applied to the input prefix
* {}
*
*
* --paper-input-container-suffix
* Mixin applied to the input suffix
* {}
*
*
* --paper-input-container-underline
* Mixin applied to the underline
* {}
*
*
* --paper-input-container-underline-focus
* Mixin applied to the underline when the input is focued
* {}
*
*
* --paper-input-container-underline-disabled
* Mixin applied to the underline when the input is disabled
* {}
*
*
*
* 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() {
try {
return (PaperInputContainerElement) getElement();
} catch (ClassCastException e) {
jsinteropError();
return null;
}
}
/**
* 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);
}
}