/* * Copyright (C) 2022 Huawei Device Co., Ltd. * 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 { BaseElement, element } from '../../../base-ui/BaseElement.js'; import './TabCpuDetailsFrequency.js'; import './TabCpuDetailsIdle.js'; import './TabCpuDetailsIrq.js'; import { TabCpuDetailsFrequency } from './TabCpuDetailsFrequency.js'; import { TabCpuDetailsIdle } from './TabCpuDetailsIdle.js'; import { LitTabs } from '../../../base-ui/tabs/lit-tabs.js'; import { TabCpuDetailsIrq } from './TabCpuDetailsIrq.js'; @element('drawer-cpu-tabs') export class DrawerCpuTabs extends BaseElement { private cpuNumber: number = 0; private tabs: LitTabs | null | undefined; private tabCpuDetailsFrequency: TabCpuDetailsFrequency | null | undefined; private tabCpuDetailsIdle: TabCpuDetailsIdle | null | undefined; private tabCpuDetailsIrq: TabCpuDetailsIrq | null | undefined; initElements(): void { this.tabs = this.shadowRoot?.querySelector('#tabs'); this.tabCpuDetailsFrequency = this.shadowRoot?.querySelector('#tab-cpu-details-frequency'); this.tabCpuDetailsIdle = this.shadowRoot?.querySelector('#tab-cpu-details-idle'); this.tabCpuDetailsIrq = this.shadowRoot?.querySelector('#tab-cpu-details-irq'); this.tabs!.onTabClick = (e: any) => { if (e.detail.key == '1') { this.tabCpuDetailsIdle?.init(this.cpuNumber); } else if (e.detail.key == '2') { this.tabCpuDetailsFrequency?.init(this.cpuNumber); } else if (e.detail.key == '3') { this.tabCpuDetailsIrq?.init(this.cpuNumber); } }; } init(cpu: number, value: string) { this.tabs!.activekey = value; this.cpuNumber = cpu; if (value == '1') { this.tabCpuDetailsIdle?.init(this.cpuNumber); } else if (value == '2') { this.tabCpuDetailsFrequency?.init(this.cpuNumber); } else if (value == '3') { this.tabCpuDetailsIrq?.init(this.cpuNumber); } } clearData() { this.tabCpuDetailsFrequency!.clearData(); this.tabCpuDetailsIdle!.clearData(); this.tabCpuDetailsIrq!.clearData(); } initHtml(): string { return `
`; } }