1fb726d48Sopenharmony_ci/* 2fb726d48Sopenharmony_ci * Copyright (C) 2022 Huawei Device Co., Ltd. 3fb726d48Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4fb726d48Sopenharmony_ci * you may not use this file except in compliance with the License. 5fb726d48Sopenharmony_ci * You may obtain a copy of the License at 6fb726d48Sopenharmony_ci * 7fb726d48Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8fb726d48Sopenharmony_ci * 9fb726d48Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10fb726d48Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11fb726d48Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12fb726d48Sopenharmony_ci * See the License for the specific language governing permissions and 13fb726d48Sopenharmony_ci * limitations under the License. 14fb726d48Sopenharmony_ci */ 15fb726d48Sopenharmony_ci 16fb726d48Sopenharmony_ciimport { BaseElement, element } from '../../../base-ui/BaseElement'; 17fb726d48Sopenharmony_ciimport './TabCpuDetailsFrequency'; 18fb726d48Sopenharmony_ciimport './TabCpuDetailsIdle'; 19fb726d48Sopenharmony_ciimport './TabCpuDetailsIrq'; 20fb726d48Sopenharmony_ciimport { TabCpuDetailsFrequency } from './TabCpuDetailsFrequency'; 21fb726d48Sopenharmony_ciimport { TabCpuDetailsIdle } from './TabCpuDetailsIdle'; 22fb726d48Sopenharmony_ciimport { LitTabs } from '../../../base-ui/tabs/lit-tabs'; 23fb726d48Sopenharmony_ciimport { TabCpuDetailsIrq } from './TabCpuDetailsIrq'; 24fb726d48Sopenharmony_ci 25fb726d48Sopenharmony_ci@element('drawer-cpu-tabs') 26fb726d48Sopenharmony_ciexport class DrawerCpuTabs extends BaseElement { 27fb726d48Sopenharmony_ci private cpuNumber: number = 0; 28fb726d48Sopenharmony_ci private tabs: LitTabs | null | undefined; 29fb726d48Sopenharmony_ci private tabCpuDetailsFrequency: TabCpuDetailsFrequency | null | undefined; 30fb726d48Sopenharmony_ci private tabCpuDetailsIdle: TabCpuDetailsIdle | null | undefined; 31fb726d48Sopenharmony_ci private tabCpuDetailsIrq: TabCpuDetailsIrq | null | undefined; 32fb726d48Sopenharmony_ci 33fb726d48Sopenharmony_ci initElements(): void { 34fb726d48Sopenharmony_ci this.tabs = this.shadowRoot?.querySelector<LitTabs>('#tabs'); 35fb726d48Sopenharmony_ci this.tabCpuDetailsFrequency = this.shadowRoot?.querySelector<TabCpuDetailsFrequency>('#tab-cpu-details-frequency'); 36fb726d48Sopenharmony_ci this.tabCpuDetailsIdle = this.shadowRoot?.querySelector<TabCpuDetailsIdle>('#tab-cpu-details-idle'); 37fb726d48Sopenharmony_ci this.tabCpuDetailsIrq = this.shadowRoot?.querySelector<TabCpuDetailsIrq>('#tab-cpu-details-irq'); 38fb726d48Sopenharmony_ci 39fb726d48Sopenharmony_ci this.tabs!.onTabClick = (e: unknown): void => { 40fb726d48Sopenharmony_ci //@ts-ignore 41fb726d48Sopenharmony_ci if (e.detail.key === '1') { 42fb726d48Sopenharmony_ci //@ts-ignore 43fb726d48Sopenharmony_ci this.tabCpuDetailsIdle?.init(this.cpuNumber); //@ts-ignore 44fb726d48Sopenharmony_ci } else if (e.detail.key === '2') { 45fb726d48Sopenharmony_ci this.tabCpuDetailsFrequency?.init(this.cpuNumber); //@ts-ignore 46fb726d48Sopenharmony_ci } else if (e.detail.key === '3') { 47fb726d48Sopenharmony_ci this.tabCpuDetailsIrq?.init(this.cpuNumber); 48fb726d48Sopenharmony_ci } 49fb726d48Sopenharmony_ci }; 50fb726d48Sopenharmony_ci } 51fb726d48Sopenharmony_ci 52fb726d48Sopenharmony_ci init(cpu: number, value: string): void { 53fb726d48Sopenharmony_ci this.tabs!.activekey = value; 54fb726d48Sopenharmony_ci this.cpuNumber = cpu; 55fb726d48Sopenharmony_ci if (value === '1') { 56fb726d48Sopenharmony_ci this.tabCpuDetailsIdle?.init(this.cpuNumber); 57fb726d48Sopenharmony_ci } else if (value === '2') { 58fb726d48Sopenharmony_ci this.tabCpuDetailsFrequency?.init(this.cpuNumber); 59fb726d48Sopenharmony_ci } else if (value === '3') { 60fb726d48Sopenharmony_ci this.tabCpuDetailsIrq?.init(this.cpuNumber); 61fb726d48Sopenharmony_ci } 62fb726d48Sopenharmony_ci } 63fb726d48Sopenharmony_ci 64fb726d48Sopenharmony_ci clearData(): void { 65fb726d48Sopenharmony_ci this.tabCpuDetailsFrequency!.clearData(); 66fb726d48Sopenharmony_ci this.tabCpuDetailsIdle!.clearData(); 67fb726d48Sopenharmony_ci this.tabCpuDetailsIrq!.clearData(); 68fb726d48Sopenharmony_ci } 69fb726d48Sopenharmony_ci 70fb726d48Sopenharmony_ci initHtml(): string { 71fb726d48Sopenharmony_ci return ` 72fb726d48Sopenharmony_ci <style> 73fb726d48Sopenharmony_ci :host { 74fb726d48Sopenharmony_ci width: 100%; 75fb726d48Sopenharmony_ci height: 100%; 76fb726d48Sopenharmony_ci background: var(--dark-background5,#F6F6F6); 77fb726d48Sopenharmony_ci } 78fb726d48Sopenharmony_ci 79fb726d48Sopenharmony_ci #tabs{ 80fb726d48Sopenharmony_ci width: 100%; 81fb726d48Sopenharmony_ci height: calc(100% - 55px); 82fb726d48Sopenharmony_ci background-color: var(--dark-background5,#F6F6F6); 83fb726d48Sopenharmony_ci } 84fb726d48Sopenharmony_ci .tab-pane{ 85fb726d48Sopenharmony_ci background-color: var(--dark-background,#FFFFFF); 86fb726d48Sopenharmony_ci } 87fb726d48Sopenharmony_ci </style> 88fb726d48Sopenharmony_ci <div > 89fb726d48Sopenharmony_ci <lit-tabs id="tabs" position="top-left" activekey="1" mode="card" > 90fb726d48Sopenharmony_ci <lit-tabpane key="1" tab="CPU Idle" class="tab-pane"> 91fb726d48Sopenharmony_ci <tab-cpu-details-idle id="tab-cpu-details-idle"></tab-cpu-details-idle> 92fb726d48Sopenharmony_ci </lit-tabpane> 93fb726d48Sopenharmony_ci <lit-tabpane key="2" tab="CPU Frequency" class="tab-pane"> 94fb726d48Sopenharmony_ci <tab-cpu-details-frequency id="tab-cpu-details-frequency"></tab-cpu-details-frequency> 95fb726d48Sopenharmony_ci </lit-tabpane> 96fb726d48Sopenharmony_ci <lit-tabpane key="3" tab="CPU Irq" class="tab-pane"> 97fb726d48Sopenharmony_ci <tab-cpu-details-irq id="tab-cpu-details-irq"></tab-cpu-details-irq> 98fb726d48Sopenharmony_ci </lit-tabpane> 99fb726d48Sopenharmony_ci </lit-tabs> 100fb726d48Sopenharmony_ci </div> 101fb726d48Sopenharmony_ci `; 102fb726d48Sopenharmony_ci } 103fb726d48Sopenharmony_ci} 104