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 { SpSystemTrace } from '../SpSystemTrace'; 17fb726d48Sopenharmony_ciimport { TraceRow } from '../trace/base/TraceRow'; 18fb726d48Sopenharmony_ciimport { renders } from '../../database/ui-worker/ProcedureWorker'; 19fb726d48Sopenharmony_ciimport { LogRender, LogStruct } from '../../database/ui-worker/ProcedureWorkerLog'; 20fb726d48Sopenharmony_ciimport { LogDataSender } from '../../database/data-trafic/LogDataSender'; 21fb726d48Sopenharmony_ciimport { queryLogData } from '../../database/sql/SqlLite.sql'; 22fb726d48Sopenharmony_ciimport { SpStatisticsHttpUtil } from '../../../statistics/util/SpStatisticsHttpUtil'; 23fb726d48Sopenharmony_ci 24fb726d48Sopenharmony_ciexport class SpLogChart { 25fb726d48Sopenharmony_ci private trace: SpSystemTrace; 26fb726d48Sopenharmony_ci 27fb726d48Sopenharmony_ci constructor(trace: SpSystemTrace) { 28fb726d48Sopenharmony_ci this.trace = trace; 29fb726d48Sopenharmony_ci } 30fb726d48Sopenharmony_ci 31fb726d48Sopenharmony_ci async init(): Promise<void> { 32fb726d48Sopenharmony_ci let dataArray = await queryLogData(); 33fb726d48Sopenharmony_ci if (dataArray.length === 0) { 34fb726d48Sopenharmony_ci return; 35fb726d48Sopenharmony_ci } 36fb726d48Sopenharmony_ci let folder = await this.initFolder(); 37fb726d48Sopenharmony_ci this.trace.rowsEL?.appendChild(folder); 38fb726d48Sopenharmony_ci // 统计hilog插件 39fb726d48Sopenharmony_ci let requestBody = { 40fb726d48Sopenharmony_ci eventData:{ 41fb726d48Sopenharmony_ci plugin:['hilog-plugin'] 42fb726d48Sopenharmony_ci } 43fb726d48Sopenharmony_ci }; 44fb726d48Sopenharmony_ci SpStatisticsHttpUtil.recordPluginUsage(requestBody); 45fb726d48Sopenharmony_ci } 46fb726d48Sopenharmony_ci 47fb726d48Sopenharmony_ci async initFolder(): Promise<TraceRow<LogStruct>> { 48fb726d48Sopenharmony_ci let logsRow = TraceRow.skeleton<LogStruct>(); 49fb726d48Sopenharmony_ci logsRow.rowId = 'logs'; 50fb726d48Sopenharmony_ci logsRow.index = 0; 51fb726d48Sopenharmony_ci logsRow.rowType = TraceRow.ROW_TYPE_LOGS; 52fb726d48Sopenharmony_ci logsRow.rowParentId = ''; 53fb726d48Sopenharmony_ci logsRow.style.height = '42px'; 54fb726d48Sopenharmony_ci logsRow.folder = false; 55fb726d48Sopenharmony_ci logsRow.name = 'Logs'; 56fb726d48Sopenharmony_ci logsRow.favoriteChangeHandler = this.trace.favoriteChangeHandler; 57fb726d48Sopenharmony_ci logsRow.selectChangeHandler = this.trace.selectChangeHandler; 58fb726d48Sopenharmony_ci logsRow.supplierFrame = (): Promise<LogStruct[]> => { 59fb726d48Sopenharmony_ci return LogDataSender(logsRow).then((res) => { 60fb726d48Sopenharmony_ci return res; 61fb726d48Sopenharmony_ci }); 62fb726d48Sopenharmony_ci }; 63fb726d48Sopenharmony_ci logsRow.onThreadHandler = (useCache): void => { 64fb726d48Sopenharmony_ci let context: CanvasRenderingContext2D; 65fb726d48Sopenharmony_ci if (logsRow.currentContext) { 66fb726d48Sopenharmony_ci context = logsRow.currentContext; 67fb726d48Sopenharmony_ci } else { 68fb726d48Sopenharmony_ci context = logsRow.collect ? this.trace.canvasFavoritePanelCtx! : this.trace.canvasPanelCtx!; 69fb726d48Sopenharmony_ci } 70fb726d48Sopenharmony_ci logsRow.canvasSave(context); 71fb726d48Sopenharmony_ci (renders.logs as LogRender).renderMainThread( 72fb726d48Sopenharmony_ci { 73fb726d48Sopenharmony_ci context: context, 74fb726d48Sopenharmony_ci useCache: useCache, 75fb726d48Sopenharmony_ci type: 'logs', 76fb726d48Sopenharmony_ci }, 77fb726d48Sopenharmony_ci logsRow 78fb726d48Sopenharmony_ci ); 79fb726d48Sopenharmony_ci logsRow.canvasRestore(context, this.trace); 80fb726d48Sopenharmony_ci }; 81fb726d48Sopenharmony_ci return logsRow; 82fb726d48Sopenharmony_ci } 83fb726d48Sopenharmony_ci} 84