blob: 8e46bd035f5b3e41ebaaac69b3be5d9dc3fcc1fb [file] [log] [blame]
/**
* @license
* Copyright (C) 2023 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.
*/
import './gr-task-plugin.js';
import {htmlTemplate} from './gr-task-chip_html.js';
class GrTaskChip extends Polymer.Element {
static get is() {
return 'gr-task-chip';
}
static get template() {
return htmlTemplate;
}
static get properties() {
return {
chip_style: {
type: String,
notify: true,
value: 'ready',
},
};
}
_setTasksTabActive() {
// TODO: Identify a better way as current implementation is fragile
const endPointDecorators = document.querySelector('gr-app')
.shadowRoot.querySelector('gr-app-element')
.shadowRoot.querySelector('main')
.querySelector('gr-change-view')
.shadowRoot.querySelector('#mainContent')
.getElementsByTagName('gr-endpoint-decorator');
if (endPointDecorators) {
for (let i = 0; i <= endPointDecorators.length; i++) {
const el = endPointDecorators[i]
?.shadowRoot?.querySelector('gr-task-plugin');
if (el) {
el.shadowRoot.querySelector('paper-tabs')
.querySelector('paper-tab').scrollIntoView();
break;
}
}
}
}
_onChipClick() {
this._setTasksTabActive();
}
}
customElements.define(GrTaskChip.is, GrTaskChip);