mirror of
https://github.com/apache/superset.git
synced 2026-05-11 02:45:46 +00:00
92 lines
3.5 KiB
TypeScript
92 lines
3.5 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 { t } from '@apache-superset/core/translation';
|
|
import { Behavior } from '@superset-ui/core';
|
|
import buildQuery from './buildQuery';
|
|
import controlPanel from './controlPanel';
|
|
import transformProps from './transformProps';
|
|
import thumbnail from './images/thumbnail.png';
|
|
import thumbnailDark from './images/thumbnail-dark.png';
|
|
import example1 from './images/Pie1.jpg';
|
|
import example1Dark from './images/Pie1-dark.jpg';
|
|
import example2 from './images/Pie2.jpg';
|
|
import example2Dark from './images/Pie2-dark.jpg';
|
|
import example3 from './images/Pie3.jpg';
|
|
import example3Dark from './images/Pie3-dark.jpg';
|
|
import example4 from './images/Pie4.jpg';
|
|
import example4Dark from './images/Pie4-dark.jpg';
|
|
import { EchartsPieChartProps, EchartsPieFormData } from './types';
|
|
import { EchartsChartPlugin } from '../types';
|
|
|
|
export default class EchartsPieChartPlugin extends EchartsChartPlugin<
|
|
EchartsPieFormData,
|
|
EchartsPieChartProps
|
|
> {
|
|
/**
|
|
* 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('./EchartsPie'),
|
|
metadata: {
|
|
behaviors: [
|
|
Behavior.InteractiveChart,
|
|
Behavior.DrillToDetail,
|
|
Behavior.DrillBy,
|
|
],
|
|
category: t('Part of a Whole'),
|
|
credits: ['https://echarts.apache.org'],
|
|
description:
|
|
t(`The classic. Great for showing how much of a company each investor gets, what demographics follow your blog, or what portion of the budget goes to the military industrial complex.
|
|
|
|
Pie charts can be difficult to interpret precisely. If clarity of relative proportion is important, consider using a bar or other chart type instead.`),
|
|
exampleGallery: [
|
|
{ url: example1, urlDark: example1Dark },
|
|
{ url: example2, urlDark: example2Dark },
|
|
{ url: example3, urlDark: example3Dark },
|
|
{ url: example4, urlDark: example4Dark },
|
|
],
|
|
name: t('Pie Chart'),
|
|
tags: [
|
|
t('Categorical'),
|
|
t('Circular'),
|
|
t('Comparison'),
|
|
t('Percentages'),
|
|
t('Featured'),
|
|
t('Proportional'),
|
|
t('ECharts'),
|
|
t('Nightingale'),
|
|
],
|
|
thumbnail,
|
|
thumbnailDark,
|
|
},
|
|
transformProps,
|
|
});
|
|
}
|
|
}
|