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