75 lines
2.7 KiB
TypeScript
75 lines
2.7 KiB
TypeScript
/**
|
|
* 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 { Behavior, t } from '@superset-ui/core';
|
|
import buildQuery from './buildQuery';
|
|
import controlPanel from './controlPanel';
|
|
import transformProps from './transformProps';
|
|
import thumbnail from './images/thumbnail.png';
|
|
import example from './images/example.jpg';
|
|
import { EchartsFunnelChartProps, EchartsFunnelFormData } from './types';
|
|
import { EchartsChartPlugin } from '../types';
|
|
|
|
export default class EchartsFunnelChartPlugin extends EchartsChartPlugin<
|
|
EchartsFunnelFormData,
|
|
EchartsFunnelChartProps
|
|
> {
|
|
/**
|
|
* The constructor is used to pass relevant metadata and callbacks that get
|
|
* registered in respective registries that are used throughout the library
|
|
* and application. A more thorough description of each property is given in
|
|
* the respective imported file.
|
|
*
|
|
* It is worth noting that `buildQuery` and is optional, and only needed for
|
|
* advanced visualizations that require either post processing operations
|
|
* (pivoting, rolling aggregations, sorting etc) or submitting multiple queries.
|
|
*/
|
|
constructor() {
|
|
super({
|
|
buildQuery,
|
|
controlPanel,
|
|
loadChart: () => import('./EchartsFunnel'),
|
|
metadata: {
|
|
behaviors: [
|
|
Behavior.InteractiveChart,
|
|
Behavior.DrillToDetail,
|
|
Behavior.DrillBy,
|
|
],
|
|
category: t('KPI'),
|
|
credits: ['https://echarts.apache.org'],
|
|
description: t(
|
|
'Showcases how a metric changes as the funnel progresses. This classic chart is useful for visualizing drop-off between stages in a pipeline or lifecycle.',
|
|
),
|
|
exampleGallery: [{ url: example }],
|
|
name: t('Funnel Chart'),
|
|
tags: [
|
|
t('Business'),
|
|
t('ECharts'),
|
|
t('Progressive'),
|
|
t('Report'),
|
|
t('Sequential'),
|
|
t('Trend'),
|
|
t('Featured'),
|
|
],
|
|
thumbnail,
|
|
},
|
|
transformProps,
|
|
});
|
|
}
|
|
}
|