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
|
|
|
|
-->
|
|
|
|
|
|
|
|
<link rel="import" href="../polymer/polymer.html">
|
2015-12-14 08:43:03 -07:00
|
|
|
<link rel="import" href="../paper-styles/typography.html">
|
2015-06-26 20:27:38 -07:00
|
|
|
<link rel="import" href="paper-input-addon-behavior.html">
|
|
|
|
|
|
|
|
<!--
|
|
|
|
`<paper-input-char-counter>` is a character counter for use with `<paper-input-container>`. It
|
|
|
|
shows the number of characters entered in the input and the max length if it is specified.
|
|
|
|
|
|
|
|
<paper-input-container>
|
|
|
|
<input is="iron-input" maxlength="20">
|
|
|
|
<paper-input-char-counter></paper-input-char-counter>
|
|
|
|
</paper-input-container>
|
|
|
|
|
|
|
|
### Styling
|
|
|
|
|
|
|
|
The following mixin is available for styling:
|
|
|
|
|
|
|
|
Custom property | Description | Default
|
|
|
|
----------------|-------------|----------
|
|
|
|
`--paper-input-char-counter` | Mixin applied to the element | `{}`
|
|
|
|
-->
|
2015-12-14 08:43:03 -07:00
|
|
|
|
2015-06-26 20:27:38 -07:00
|
|
|
<dom-module id="paper-input-char-counter">
|
2015-09-03 21:33:31 -07:00
|
|
|
<template>
|
|
|
|
<style>
|
|
|
|
:host {
|
|
|
|
display: inline-block;
|
|
|
|
float: right;
|
2015-06-26 20:27:38 -07:00
|
|
|
|
2015-09-03 21:33:31 -07:00
|
|
|
@apply(--paper-font-caption);
|
|
|
|
@apply(--paper-input-char-counter);
|
|
|
|
}
|
2015-12-14 08:43:03 -07:00
|
|
|
|
|
|
|
:host-context([dir="rtl"]) {
|
|
|
|
float: left;
|
|
|
|
}
|
2015-09-03 21:33:31 -07:00
|
|
|
</style>
|
2015-06-26 20:27:38 -07:00
|
|
|
|
|
|
|
<span>[[_charCounterStr]]</span>
|
|
|
|
</template>
|
|
|
|
</dom-module>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
Polymer({
|
|
|
|
is: 'paper-input-char-counter',
|
|
|
|
|
|
|
|
behaviors: [
|
|
|
|
Polymer.PaperInputAddonBehavior
|
|
|
|
],
|
|
|
|
|
|
|
|
properties: {
|
|
|
|
_charCounterStr: {
|
|
|
|
type: String,
|
|
|
|
value: '0'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
update: function(state) {
|
|
|
|
if (!state.inputElement) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
state.value = state.value || '';
|
|
|
|
|
2016-02-18 11:20:10 -07:00
|
|
|
var counter = state.value.length;
|
2015-06-26 20:27:38 -07:00
|
|
|
|
|
|
|
if (state.inputElement.hasAttribute('maxlength')) {
|
2016-02-18 11:20:10 -07:00
|
|
|
counter += '/' + state.inputElement.getAttribute('maxlength');
|
2015-06-26 20:27:38 -07:00
|
|
|
}
|
2016-02-18 11:20:10 -07:00
|
|
|
|
|
|
|
this._charCounterStr = counter;
|
2015-06-26 20:27:38 -07:00
|
|
|
}
|
|
|
|
});
|
|
|
|
</script>
|