UNPKG

@mcdevsl/superset-ui

Version:
112 lines (107 loc) 3.35 kB
/** * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ import { buildQueryContext, getMetricLabel, QueryFormData, QueryObject, normalizeOrderBy, } from '@superset-ui/core'; export default function buildQuery(formData: QueryFormData) { const { adhoc_filters, adhoc_filters_b, groupby, groupby_b, limit, limit_b, timeseries_limit_metric, timeseries_limit_metric_b, metrics, metrics_b, order_desc, order_desc_b, ...baseFormData } = formData; baseFormData.is_timeseries = true; const formData1 = { ...baseFormData, adhoc_filters, columns: groupby, limit, timeseries_limit_metric, metrics, order_desc, }; const formData2 = { ...baseFormData, adhoc_filters: adhoc_filters_b, columns: groupby_b, limit: limit_b, timeseries_limit_metric: timeseries_limit_metric_b, metrics: metrics_b, order_desc: order_desc_b, }; const queryContextA = buildQueryContext(formData1, baseQueryObject => { const metricLabels = (baseQueryObject.metrics || []).map(getMetricLabel); const queryObjectA = { ...baseQueryObject, is_timeseries: true, post_processing: [ { operation: 'pivot', options: { index: ['__timestamp'], columns: formData1.columns || [], // Create 'dummy' sum aggregates to assign cell values in pivot table aggregates: Object.fromEntries( metricLabels.map(metric => [metric, { operator: 'sum' }]), ), }, }, ], } as QueryObject; return [normalizeOrderBy(queryObjectA)]; }); const queryContextB = buildQueryContext(formData2, baseQueryObject => { const metricLabels = (baseQueryObject.metrics || []).map(getMetricLabel); const queryObjectB = { ...baseQueryObject, is_timeseries: true, post_processing: [ { operation: 'pivot', options: { index: ['__timestamp'], columns: formData2.columns || [], // Create 'dummy' sum aggregates to assign cell values in pivot table aggregates: Object.fromEntries( metricLabels.map(metric => [metric, { operator: 'sum' }]), ), }, }, ], } as QueryObject; return [normalizeOrderBy(queryObjectB)]; }); return { ...queryContextA, queries: [...queryContextA.queries, ...queryContextB.queries], }; }