| // Copyright (C) 2016 The Android Open Source Project |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| (function() { |
| 'use strict'; |
| |
| Polymer({ |
| is: 'gr-editable-label', |
| |
| /** |
| * Fired when the value is changed. |
| * |
| * @event changed |
| */ |
| |
| properties: { |
| editing: { |
| type: Boolean, |
| value: false, |
| }, |
| value: { |
| type: String, |
| notify: true, |
| value: null, |
| observer: '_updateTitle', |
| }, |
| placeholder: { |
| type: String, |
| value: null, |
| }, |
| readOnly: { |
| type: Boolean, |
| value: false, |
| }, |
| _inputText: String, |
| }, |
| |
| _usePlaceholder: function(value, placeholder) { |
| return (!value || !value.length) && placeholder; |
| }, |
| |
| _computeLabel: function(value, placeholder) { |
| if (this._usePlaceholder(value, placeholder)) { |
| return placeholder; |
| } |
| return value; |
| }, |
| |
| _open: function() { |
| if (this.readOnly || this.editing) { return; } |
| |
| this._inputText = this.value; |
| this.editing = true; |
| |
| this.async(function() { |
| this.$.input.focus(); |
| this.$.input.setSelectionRange(0, this.$.input.value.length); |
| }); |
| }, |
| |
| _save: function() { |
| if (!this.editing) { return; } |
| |
| this.value = this._inputText; |
| this.editing = false; |
| this.fire('changed', this.value); |
| }, |
| |
| _cancel: function() { |
| if (!this.editing) { return; } |
| |
| this.editing = false; |
| this._inputText = this.value; |
| }, |
| |
| _handleInputKeydown: function(e) { |
| if (e.keyCode === 13) { // Enter key |
| e.preventDefault(); |
| this._save(); |
| } else if (e.keyCode === 27) { // Escape key |
| e.preventDefault(); |
| this._cancel(); |
| } |
| }, |
| |
| _computeLabelClass: function(readOnly, value, placeholder) { |
| var classes = []; |
| if (!readOnly) { classes.push('editable'); } |
| if (this._usePlaceholder(value, placeholder)) { |
| classes.push('placeholder'); |
| } |
| return classes.join(' '); |
| }, |
| |
| _updateTitle: function(value) { |
| this.setAttribute('title', (value && value.length) ? value : null); |
| }, |
| }); |
| })(); |