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 { query } from '../SqlLite';
17fb726d48Sopenharmony_ci// import { XpowerStruct } from '../ui-worker/ProcedureWorkerXpower';
18fb726d48Sopenharmony_ciexport const queryXpowerMeasureData = (traceId?: string): Promise<
19fb726d48Sopenharmony_ci  Array<{
20fb726d48Sopenharmony_ci    filter_id: number;
21fb726d48Sopenharmony_ci  }>
22fb726d48Sopenharmony_ci> =>
23fb726d48Sopenharmony_ci  query(
24fb726d48Sopenharmony_ci    'queryXpowerMeasureData',
25fb726d48Sopenharmony_ci    `
26fb726d48Sopenharmony_ci    select 
27fb726d48Sopenharmony_ci        name 
28fb726d48Sopenharmony_ci    from     
29fb726d48Sopenharmony_ci        measure_filter mf
30fb726d48Sopenharmony_ci    where
31fb726d48Sopenharmony_ci        mf.type = 'xpower_filter'
32fb726d48Sopenharmony_ci;
33fb726d48Sopenharmony_ci`, {}, {traceId: traceId}
34fb726d48Sopenharmony_ci  );
35fb726d48Sopenharmony_ciexport const queryXpowerData = (traceId?: string): Promise<
36fb726d48Sopenharmony_ci  Array<{
37fb726d48Sopenharmony_ci    name: string;
38fb726d48Sopenharmony_ci    num: number;
39fb726d48Sopenharmony_ci    maxValue?: number;
40fb726d48Sopenharmony_ci  }>
41fb726d48Sopenharmony_ci> =>
42fb726d48Sopenharmony_ci  query(
43fb726d48Sopenharmony_ci    'queryXpowerData',
44fb726d48Sopenharmony_ci    `
45fb726d48Sopenharmony_ci    select 
46fb726d48Sopenharmony_ci        name,
47fb726d48Sopenharmony_ci        COUNT(*) num 
48fb726d48Sopenharmony_ci    from     
49fb726d48Sopenharmony_ci        measure_filter mf
50fb726d48Sopenharmony_ci    left join
51fb726d48Sopenharmony_ci        xpower_measure xm
52fb726d48Sopenharmony_ci    on
53fb726d48Sopenharmony_ci        mf.id = xm.filter_id
54fb726d48Sopenharmony_ci    where 
55fb726d48Sopenharmony_ci        mf.type = 'xpower_filter'
56fb726d48Sopenharmony_ci    group by name
57fb726d48Sopenharmony_ci;
58fb726d48Sopenharmony_ci`, {}, {traceId: traceId}
59fb726d48Sopenharmony_ci  );
60fb726d48Sopenharmony_ci
61fb726d48Sopenharmony_ci
62fb726d48Sopenharmony_ci
63