jellyfin-web/dashboard-ui/bower_components/paper-input/paper-input.html

159 lines
5.0 KiB
HTML
Raw Normal View History

2015-06-26 20:27:38 -07:00
<!--
@license
Copyright (c) 2015 The Polymer Project Authors. All rights reserved.
This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
Code distributed by Google as part of the polymer project is also
subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
-->
2015-12-14 08:43:03 -07:00
2015-06-26 20:27:38 -07:00
<link rel="import" href="../polymer/polymer.html">
<link rel="import" href="../iron-form-element-behavior/iron-form-element-behavior.html">
2015-12-14 08:43:03 -07:00
<link rel="import" href="../iron-input/iron-input.html">
2015-06-26 20:27:38 -07:00
<link rel="import" href="paper-input-behavior.html">
2015-12-14 08:43:03 -07:00
<link rel="import" href="paper-input-char-counter.html">
2015-06-26 20:27:38 -07:00
<link rel="import" href="paper-input-container.html">
<link rel="import" href="paper-input-error.html">
<!--
2015-12-14 08:43:03 -07:00
Material design: [Text fields](https://www.google.com/design/spec/components/text-fields.html)
2015-06-26 20:27:38 -07:00
`<paper-input>` is a single-line text field with Material Design styling.
<paper-input label="Input label"></paper-input>
It may include an optional error message or character counter.
<paper-input error-message="Invalid input!" label="Input label"></paper-input>
<paper-input char-counter label="Input label"></paper-input>
2015-08-04 07:26:36 -07:00
It can also include custom prefix or suffix elements, which are displayed
before or after the text input itself. In order for an element to be
considered as a prefix, it must have the `prefix` attribute (and similarly
for `suffix`).
<paper-input label="total">
<div prefix>$</div>
<paper-icon-button suffix icon="clear"></paper-icon-button>
</paper-input>
2015-12-14 08:43:03 -07:00
A `paper-input` can use the native `type=search` or `type=file` features.
2016-01-16 11:29:08 -07:00
However, since we can't control the native styling of the input (search icon,
file button, date placeholder, etc.), in these cases the label will be
automatically floated. The `placeholder` attribute can still be used for
additional informational text.
2015-09-29 21:10:14 -07:00
<paper-input label="search!" type="search"
placeholder="search for cats" autosave="test" results="5">
</paper-input>
2015-06-26 20:27:38 -07:00
See `Polymer.PaperInputBehavior` for more API docs.
2015-12-14 08:43:03 -07:00
### Focus
To focus a paper-input, you can call the native `focus()` method as long as the
paper input has a tab index.
2015-06-26 20:27:38 -07:00
### Styling
See `Polymer.PaperInputContainer` for a list of custom properties used to
style this element.
2015-12-14 08:43:03 -07:00
2015-06-26 20:27:38 -07:00
@group Paper Elements
@element paper-input
@hero hero.svg
@demo demo/index.html
-->
<dom-module id="paper-input">
2015-09-03 21:33:31 -07:00
<template>
<style>
:host {
display: block;
}
2015-06-26 20:27:38 -07:00
2015-09-03 21:33:31 -07:00
input::-webkit-input-placeholder {
color: var(--paper-input-container-color, --secondary-text-color);
}
2015-06-26 20:27:38 -07:00
2015-09-03 21:33:31 -07:00
input:-moz-placeholder {
color: var(--paper-input-container-color, --secondary-text-color);
}
2015-06-26 20:27:38 -07:00
2015-09-03 21:33:31 -07:00
input::-moz-placeholder {
color: var(--paper-input-container-color, --secondary-text-color);
}
2015-06-26 20:27:38 -07:00
2015-09-03 21:33:31 -07:00
input:-ms-input-placeholder {
color: var(--paper-input-container-color, --secondary-text-color);
}
</style>
2015-06-26 20:27:38 -07:00
<paper-input-container no-label-float="[[noLabelFloat]]" always-float-label="[[_computeAlwaysFloatLabel(alwaysFloatLabel,placeholder)]]" auto-validate$="[[autoValidate]]" disabled$="[[disabled]]" invalid="[[invalid]]">
2015-08-04 07:26:36 -07:00
<content select="[prefix]"></content>
2015-06-26 20:27:38 -07:00
<label hidden$="[[!label]]">[[label]]</label>
<input is="iron-input" id="input"
aria-labelledby$="[[_ariaLabelledBy]]"
aria-describedby$="[[_ariaDescribedBy]]"
disabled$="[[disabled]]"
2016-01-16 11:29:08 -07:00
title$="[[title]]"
2015-06-26 20:27:38 -07:00
bind-value="{{value}}"
invalid="{{invalid}}"
prevent-invalid-input="[[preventInvalidInput]]"
allowed-pattern="[[allowedPattern]]"
validator="[[validator]]"
type$="[[type]]"
pattern$="[[pattern]]"
required$="[[required]]"
autocomplete$="[[autocomplete]]"
autofocus$="[[autofocus]]"
inputmode$="[[inputmode]]"
minlength$="[[minlength]]"
2015-08-05 18:21:18 -07:00
maxlength$="[[maxlength]]"
min$="[[min]]"
max$="[[max]]"
step$="[[step]]"
2015-06-26 20:27:38 -07:00
name$="[[name]]"
placeholder$="[[placeholder]]"
readonly$="[[readonly]]"
list$="[[list]]"
2015-07-13 14:26:11 -07:00
size$="[[size]]"
autocapitalize$="[[autocapitalize]]"
2015-09-14 18:17:19 -07:00
autocorrect$="[[autocorrect]]"
2015-09-29 21:10:14 -07:00
on-change="_onChange"
2015-12-14 08:43:03 -07:00
tabindex$="[[tabindex]]"
autosave$="[[autosave]]"
results$="[[results]]"
accept$="[[accept]]"
multiple$="[[multiple]]">
2015-06-26 20:27:38 -07:00
2015-08-04 07:26:36 -07:00
<content select="[suffix]"></content>
2015-06-26 20:27:38 -07:00
<template is="dom-if" if="[[errorMessage]]">
<paper-input-error>[[errorMessage]]</paper-input-error>
</template>
<template is="dom-if" if="[[charCounter]]">
<paper-input-char-counter></paper-input-char-counter>
</template>
</paper-input-container>
</template>
</dom-module>
<script>
Polymer({
is: 'paper-input',
behaviors: [
2015-07-13 14:26:11 -07:00
Polymer.IronFormElementBehavior,
2015-12-14 08:43:03 -07:00
Polymer.PaperInputBehavior
2015-06-26 20:27:38 -07:00
]
2015-09-03 21:33:31 -07:00
});
2015-06-26 20:27:38 -07:00
</script>