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 { LitTable } from '../../../base-ui/table/lit-table'; 18fb726d48Sopenharmony_ciimport { procedurePool } from '../../database/Procedure'; 19fb726d48Sopenharmony_ciimport { info } from '../../../log/Log'; 20fb726d48Sopenharmony_ciimport '../../../base-ui/chart/pie/LitChartPie'; 21fb726d48Sopenharmony_ciimport { LitChartPie } from '../../../base-ui/chart/pie/LitChartPie'; 22fb726d48Sopenharmony_ciimport '../../../base-ui/progress-bar/LitProgressBar'; 23fb726d48Sopenharmony_ciimport { LitProgressBar } from '../../../base-ui/progress-bar/LitProgressBar'; 24fb726d48Sopenharmony_ciimport './TableNoData'; 25fb726d48Sopenharmony_ciimport { TableNoData } from './TableNoData'; 26fb726d48Sopenharmony_ci 27fb726d48Sopenharmony_ci@element('top20-process-thread-count') 28fb726d48Sopenharmony_ciexport class Top20ProcessThreadCount extends BaseElement { 29fb726d48Sopenharmony_ci traceChange: boolean = false; 30fb726d48Sopenharmony_ci private processThreadCountTbl: LitTable | null | undefined; 31fb726d48Sopenharmony_ci private processThreadCountPie: LitChartPie | null | undefined; 32fb726d48Sopenharmony_ci private processThreadCountProgress: LitProgressBar | null | undefined; 33fb726d48Sopenharmony_ci private nodata: TableNoData | null | undefined; 34fb726d48Sopenharmony_ci private processThreadCountData: Array<unknown> = []; 35fb726d48Sopenharmony_ci 36fb726d48Sopenharmony_ci initElements(): void { 37fb726d48Sopenharmony_ci this.nodata = this.shadowRoot!.querySelector<TableNoData>('#nodata'); 38fb726d48Sopenharmony_ci this.processThreadCountProgress = this.shadowRoot!.querySelector<LitProgressBar>('#loading'); 39fb726d48Sopenharmony_ci this.processThreadCountTbl = this.shadowRoot!.querySelector<LitTable>('#tb-process-thread-count'); 40fb726d48Sopenharmony_ci this.processThreadCountPie = this.shadowRoot!.querySelector<LitChartPie>('#pie'); 41fb726d48Sopenharmony_ci 42fb726d48Sopenharmony_ci this.processThreadCountTbl!.addEventListener('row-click', (evt: unknown): void => { 43fb726d48Sopenharmony_ci //@ts-ignore 44fb726d48Sopenharmony_ci let data = evt.detail.data; 45fb726d48Sopenharmony_ci data.isSelected = true; 46fb726d48Sopenharmony_ci // @ts-ignore 47fb726d48Sopenharmony_ci if ((evt.detail as unknown).callBack) { 48fb726d48Sopenharmony_ci // @ts-ignore 49fb726d48Sopenharmony_ci (evt.detail as unknown).callBack(true); 50fb726d48Sopenharmony_ci } 51fb726d48Sopenharmony_ci }); 52fb726d48Sopenharmony_ci 53fb726d48Sopenharmony_ci this.processThreadCountTbl!.addEventListener('column-click', (evt): void => { 54fb726d48Sopenharmony_ci // @ts-ignore 55fb726d48Sopenharmony_ci this.sortByColumn(evt.detail); 56fb726d48Sopenharmony_ci }); 57fb726d48Sopenharmony_ci this.processThreadCountTbl!.addEventListener('row-hover', (evt: unknown): void => { 58fb726d48Sopenharmony_ci //@ts-ignore 59fb726d48Sopenharmony_ci if (evt.detail.data) { 60fb726d48Sopenharmony_ci //@ts-ignore 61fb726d48Sopenharmony_ci let data = evt.detail.data; 62fb726d48Sopenharmony_ci data.isHover = true; 63fb726d48Sopenharmony_ci //@ts-ignore 64fb726d48Sopenharmony_ci if ((evt.detail as unknown).callBack) { 65fb726d48Sopenharmony_ci //@ts-ignore 66fb726d48Sopenharmony_ci (evt.detail as unknown).callBack(true); 67fb726d48Sopenharmony_ci } 68fb726d48Sopenharmony_ci } 69fb726d48Sopenharmony_ci this.processThreadCountPie?.showHover(); 70fb726d48Sopenharmony_ci }); 71fb726d48Sopenharmony_ci } 72fb726d48Sopenharmony_ci 73fb726d48Sopenharmony_ci init(): void { 74fb726d48Sopenharmony_ci if (!this.traceChange) { 75fb726d48Sopenharmony_ci if (this.processThreadCountTbl!.recycleDataSource.length > 0) { 76fb726d48Sopenharmony_ci this.processThreadCountTbl?.reMeauseHeight(); 77fb726d48Sopenharmony_ci } 78fb726d48Sopenharmony_ci return; 79fb726d48Sopenharmony_ci } 80fb726d48Sopenharmony_ci this.traceChange = false; 81fb726d48Sopenharmony_ci this.processThreadCountProgress!.loading = true; 82fb726d48Sopenharmony_ci this.queryLogicWorker( 83fb726d48Sopenharmony_ci 'scheduling-Process ThreadCount', 84fb726d48Sopenharmony_ci 'query Process Thread Count Analysis Time:', 85fb726d48Sopenharmony_ci (res): void => { 86fb726d48Sopenharmony_ci //@ts-ignore 87fb726d48Sopenharmony_ci this.nodata!.noData = res === undefined || res.length === 0; 88fb726d48Sopenharmony_ci //@ts-ignore 89fb726d48Sopenharmony_ci this.processThreadCountTbl!.recycleDataSource = res; 90fb726d48Sopenharmony_ci this.processThreadCountTbl!.reMeauseHeight(); 91fb726d48Sopenharmony_ci //@ts-ignore 92fb726d48Sopenharmony_ci this.processThreadCountData = res; 93fb726d48Sopenharmony_ci this.processThreadCountPie!.config = { 94fb726d48Sopenharmony_ci appendPadding: 10, 95fb726d48Sopenharmony_ci //@ts-ignore 96fb726d48Sopenharmony_ci data: res, 97fb726d48Sopenharmony_ci angleField: 'threadNumber', 98fb726d48Sopenharmony_ci colorField: 'pid', 99fb726d48Sopenharmony_ci radius: 0.8, 100fb726d48Sopenharmony_ci label: { 101fb726d48Sopenharmony_ci type: 'outer', 102fb726d48Sopenharmony_ci }, 103fb726d48Sopenharmony_ci hoverHandler: (data): void => { 104fb726d48Sopenharmony_ci if (data) { 105fb726d48Sopenharmony_ci this.processThreadCountTbl!.setCurrentHover(data); 106fb726d48Sopenharmony_ci } else { 107fb726d48Sopenharmony_ci this.processThreadCountTbl!.mouseOut(); 108fb726d48Sopenharmony_ci } 109fb726d48Sopenharmony_ci }, 110fb726d48Sopenharmony_ci tip: (obj): string => { 111fb726d48Sopenharmony_ci return `<div> 112fb726d48Sopenharmony_ci <div>pid:${ 113fb726d48Sopenharmony_ci // @ts-ignore 114fb726d48Sopenharmony_ci obj.obj.pid 115fb726d48Sopenharmony_ci }</div> 116fb726d48Sopenharmony_ci <div>p_name:${ 117fb726d48Sopenharmony_ci // @ts-ignore 118fb726d48Sopenharmony_ci obj.obj.pName 119fb726d48Sopenharmony_ci }</div> 120fb726d48Sopenharmony_ci <div>thread count:${ 121fb726d48Sopenharmony_ci // @ts-ignore 122fb726d48Sopenharmony_ci obj.obj.threadNumber 123fb726d48Sopenharmony_ci }</div> 124fb726d48Sopenharmony_ci </div> 125fb726d48Sopenharmony_ci `; 126fb726d48Sopenharmony_ci }, 127fb726d48Sopenharmony_ci interactions: [ 128fb726d48Sopenharmony_ci { 129fb726d48Sopenharmony_ci type: 'element-active', 130fb726d48Sopenharmony_ci }, 131fb726d48Sopenharmony_ci ], 132fb726d48Sopenharmony_ci }; 133fb726d48Sopenharmony_ci this.processThreadCountProgress!.loading = false; 134fb726d48Sopenharmony_ci } 135fb726d48Sopenharmony_ci ); 136fb726d48Sopenharmony_ci } 137fb726d48Sopenharmony_ci 138fb726d48Sopenharmony_ci clearData(): void { 139fb726d48Sopenharmony_ci this.traceChange = true; 140fb726d48Sopenharmony_ci this.processThreadCountPie!.dataSource = []; 141fb726d48Sopenharmony_ci this.processThreadCountTbl!.recycleDataSource = []; 142fb726d48Sopenharmony_ci } 143fb726d48Sopenharmony_ci 144fb726d48Sopenharmony_ci queryLogicWorker(option: string, log: string, handler: (res: unknown) => void): void { 145fb726d48Sopenharmony_ci let processThreadCountTime = new Date().getTime(); 146fb726d48Sopenharmony_ci procedurePool.submitWithName('logic0', option, {}, undefined, handler); 147fb726d48Sopenharmony_ci let durTime = new Date().getTime() - processThreadCountTime; 148fb726d48Sopenharmony_ci info(log, durTime); 149fb726d48Sopenharmony_ci } 150fb726d48Sopenharmony_ci 151fb726d48Sopenharmony_ci sortByColumn(detail: unknown): void { 152fb726d48Sopenharmony_ci // @ts-ignore 153fb726d48Sopenharmony_ci function compare(property, sort, type) { 154fb726d48Sopenharmony_ci return function (a: unknown, b: unknown) { 155fb726d48Sopenharmony_ci if (type === 'number') { 156fb726d48Sopenharmony_ci // @ts-ignore 157fb726d48Sopenharmony_ci return sort === 2 158fb726d48Sopenharmony_ci ? //@ts-ignore 159fb726d48Sopenharmony_ci parseFloat(b[property]) - parseFloat(a[property]) 160fb726d48Sopenharmony_ci : //@ts-ignore 161fb726d48Sopenharmony_ci parseFloat(a[property]) - parseFloat(b[property]); 162fb726d48Sopenharmony_ci } else { 163fb726d48Sopenharmony_ci if (sort === 2) { 164fb726d48Sopenharmony_ci //@ts-ignore 165fb726d48Sopenharmony_ci return b[property].toString().localeCompare(a[property].toString()); 166fb726d48Sopenharmony_ci } else { 167fb726d48Sopenharmony_ci //@ts-ignore 168fb726d48Sopenharmony_ci return a[property].toString().localeCompare(b[property].toString()); 169fb726d48Sopenharmony_ci } 170fb726d48Sopenharmony_ci } 171fb726d48Sopenharmony_ci }; 172fb726d48Sopenharmony_ci } 173fb726d48Sopenharmony_ci 174fb726d48Sopenharmony_ci //@ts-ignore 175fb726d48Sopenharmony_ci if (detail.key === 'NO' || detail.key === 'pid' || detail.key === 'threadNumber') { 176fb726d48Sopenharmony_ci //@ts-ignore 177fb726d48Sopenharmony_ci this.processThreadCountData.sort(compare(detail.key, detail.sort, 'number')); 178fb726d48Sopenharmony_ci } else { 179fb726d48Sopenharmony_ci //@ts-ignore 180fb726d48Sopenharmony_ci this.processThreadCountData.sort(compare(detail.key, detail.sort, 'string')); 181fb726d48Sopenharmony_ci } 182fb726d48Sopenharmony_ci this.processThreadCountTbl!.recycleDataSource = this.processThreadCountData; 183fb726d48Sopenharmony_ci } 184fb726d48Sopenharmony_ci 185fb726d48Sopenharmony_ci initHtml(): string { 186fb726d48Sopenharmony_ci return ` 187fb726d48Sopenharmony_ci <style> 188fb726d48Sopenharmony_ci :host { 189fb726d48Sopenharmony_ci width: 100%; 190fb726d48Sopenharmony_ci height: 100%; 191fb726d48Sopenharmony_ci background-color: var(--dark-background5,#F6F6F6); 192fb726d48Sopenharmony_ci } 193fb726d48Sopenharmony_ci .pie-chart{ 194fb726d48Sopenharmony_ci display: flex; 195fb726d48Sopenharmony_ci box-sizing: border-box; 196fb726d48Sopenharmony_ci width: 500px; 197fb726d48Sopenharmony_ci height: 500px; 198fb726d48Sopenharmony_ci } 199fb726d48Sopenharmony_ci .tb_thread_count{ 200fb726d48Sopenharmony_ci flex: 1; 201fb726d48Sopenharmony_ci overflow: auto ; 202fb726d48Sopenharmony_ci border-radius: 5px; 203fb726d48Sopenharmony_ci border: solid 1px var(--dark-border1,#e0e0e0); 204fb726d48Sopenharmony_ci margin: 15px; 205fb726d48Sopenharmony_ci padding: 5px 15px 206fb726d48Sopenharmony_ci } 207fb726d48Sopenharmony_ci .thread-root{ 208fb726d48Sopenharmony_ci width: 100%; 209fb726d48Sopenharmony_ci height: 100%; 210fb726d48Sopenharmony_ci box-sizing: border-box; 211fb726d48Sopenharmony_ci display: flex; 212fb726d48Sopenharmony_ci flex-direction: row; 213fb726d48Sopenharmony_ci } 214fb726d48Sopenharmony_ci </style> 215fb726d48Sopenharmony_ci <lit-progress-bar id="loading" style="height: 1px;width: 100%" loading></lit-progress-bar> 216fb726d48Sopenharmony_ci <table-no-data id="nodata" contentHeight="500px"> 217fb726d48Sopenharmony_ci <div class="thread-root"> 218fb726d48Sopenharmony_ci <div style="display: flex;flex-direction: column;align-items: center"> 219fb726d48Sopenharmony_ci <div>Statistics By Thread Count</div> 220fb726d48Sopenharmony_ci <lit-chart-pie id="pie" class="pie-chart"></lit-chart-pie> 221fb726d48Sopenharmony_ci </div> 222fb726d48Sopenharmony_ci <div class="tb_thread_count"> 223fb726d48Sopenharmony_ci <lit-table id="tb-process-thread-count" hideDownload style="height: auto"> 224fb726d48Sopenharmony_ci <lit-table-column width="1fr" title="NO" data-index="NO" key="NO" align="flex-start" order></lit-table-column> 225fb726d48Sopenharmony_ci <lit-table-column width="1fr" title="pid" data-index="pid" key="pid" align="flex-start" order></lit-table-column> 226fb726d48Sopenharmony_ci <lit-table-column width="1fr" title="p_name" data-index="pName" key="pName" align="flex-start" order></lit-table-column> 227fb726d48Sopenharmony_ci <lit-table-column width="1fr" title="thread count" data-index="threadNumber" key="threadNumber" align="flex-start" order></lit-table-column> 228fb726d48Sopenharmony_ci </lit-table> 229fb726d48Sopenharmony_ci </div> 230fb726d48Sopenharmony_ci </div> 231fb726d48Sopenharmony_ci </table-no-data> 232fb726d48Sopenharmony_ci `; 233fb726d48Sopenharmony_ci } 234fb726d48Sopenharmony_ci} 235