// 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, }, hostAttributes: { tabindex: '0', }, _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); }, }); })();