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