Files
gerrit/polygerrit-ui/app/elements/admin/gr-admin-group-list/gr-admin-group-list.js
Becky Siegel 07156c5b36 Fix URL computation bug introduced by behavior
https://gerrit-review.googlesource.com/c/109492/

The element attemted to call a behavior function in the template which
does not work. Instead, add a private function that calls the
behavior function.

Change-Id: I8c2e52a5ff4770059336f6814d47a56dac805480
2017-06-13 16:46:36 -07:00

105 lines
2.5 KiB
JavaScript

// Copyright (C) 2017 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-admin-group-list',
properties: {
/**
* URL params passed from the router.
*/
params: {
type: Object,
observer: '_paramsChanged',
},
/**
* Offset of currently visible query results.
*/
_offset: Number,
_path: {
type: String,
readOnly: true,
value: '/admin/groups/',
},
_groups: Array,
/**
* Because we request one more than the groupsPerPage, _shownGroups
* may be one less than _groups.
* */
_shownGroups: {
type: Array,
computed: 'computeShownItems(_groups)',
},
_groupsPerPage: {
type: Number,
value: 25,
},
_loading: {
type: Boolean,
value: true,
},
_filter: String,
},
behaviors: [
Gerrit.ListViewBehavior,
],
listeners: {
'next-page': '_handleNextPage',
'previous-page': '_handlePreviousPage',
},
_paramsChanged(params) {
this._loading = true;
this._filter = this.getFilterValue(params);
this._offset = this.getOffsetValue(params);
return this._getGroups(this._filter, this._groupsPerPage,
this._offset);
},
_computeGroupUrl(id) {
return this.getUrl(this._path, id);
},
_getGroups(filter, groupsPerPage, offset) {
this._groups = [];
return this.$.restAPI.getGroups(filter, groupsPerPage, offset)
.then(groups => {
if (!groups) {
return;
}
this._groups = Object.keys(groups)
.map(key => {
const group = groups[key];
group.name = key;
return group;
});
this._loading = false;
});
},
_visibleToAll(item) {
return item.options.visible_to_all === true ? 'Y' : 'N';
},
});
})();