Files
gerrit/polygerrit-ui/app/elements/settings/gr-change-table-editor/gr-change-table-editor.js
Dave Borowitz 8cdc76ba4c Add @license tags to PG HTML and JS assets
These tags are preserved by the Closure compiler and vulcanize in order
to serve the license notices embedded in the outputs. In a standalone
Gerrit server, these license are also covered in the LICENSES.txt served
with the documentation. When serving PG assets from a CDN, it's less
obvious what the corresponding LICENSES.txt file is, since the CDN is
not directly linked to a running Gerrit server. Safer to embed the
licenses in the assets themselves.

Change-Id: Id1add1451fad1baa7916882a6bda02c326ccc988
2018-03-26 10:47:55 -04:00

75 lines
1.9 KiB
JavaScript

/**
* @license
* 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-change-table-editor',
properties: {
displayedColumns: {
type: Array,
notify: true,
},
showNumber: {
type: Boolean,
notify: true,
},
},
behaviors: [
Gerrit.ChangeTableBehavior,
],
_getButtonText(isShown) {
return isShown ? 'Hide' : 'Show';
},
_updateDisplayedColumns(displayedColumns, name, checked) {
if (!checked) {
return displayedColumns.filter(column => {
return name.toLowerCase() !== column.toLowerCase();
});
} else {
return displayedColumns.concat([name]);
}
},
/**
* Handles tap on either the checkbox itself or the surrounding table cell.
*/
_handleTargetTap(e) {
let checkbox = Polymer.dom(e.target).querySelector('input');
if (checkbox) {
checkbox.click();
} else {
// The target is the checkbox itself.
checkbox = Polymer.dom(e).rootTarget;
}
if (checkbox.name === 'number') {
this.showNumber = checkbox.checked;
return;
}
this.set('displayedColumns',
this._updateDisplayedColumns(
this.displayedColumns, checkbox.name, checkbox.checked));
},
});
})();