UNPKG

@qn-pandora/pandora-visualization

Version:

Pandora 通用可视化库

88 lines (87 loc) 6.22 kB
var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; import React from 'react'; import { observer } from 'mobx-react'; import { legendPositions, legendValueDisplayOptions, switchOptions, sortOrders } from '../../../components/ChartStyleConfig/constants'; import Item from '../../../components/Common/Form/Item'; import Form from '../../Common/Form'; import { Selector } from '../../../components/Common'; import ValueDisplayItem from '../CheckboxGroupItem'; import SolidRadioItem from '../SolidRadioItem'; import errorBoundary from '../../../hocs/errorBoundary'; import { BaseLocale } from '../../../constants/language/base/type'; import bind from '../../../utils/bind'; import { formatString } from '../../../services/language'; import NumberItem from '../NumberItem'; var RowContainer = Form.RowContainer; var LegendPanel = /** @class */ (function (_super) { __extends(LegendPanel, _super); function LegendPanel() { return _super !== null && _super.apply(this, arguments) || this; } LegendPanel.prototype.handleSortFieldChange = function (field) { var _a = (this.props.sort || {}).order, order = _a === void 0 ? 'ascend' : _a; this.props.setSort({ field: field, order: order }); }; LegendPanel.prototype.handleSortOrderChange = function (order) { var _a = (this.props.sort || {}).field, field = _a === void 0 ? '' : _a; this.props.setSort({ field: field, order: order }); }; LegendPanel.prototype.render = function () { var _a = this.props, position = _a.position, setPosition = _a.setPosition, setLegendDisplayMode = _a.setLegendDisplayMode, legendDisplayMode = _a.legendDisplayMode, hideChartLegend = _a.hideChartLegend, setHideChartLegend = _a.setHideChartLegend, hideBaseLineLegend = _a.hideBaseLineLegend, setHideBaseLineLegend = _a.setHideBaseLineLegend, sort = _a.sort, width = _a.width, setWidth = _a.setWidth; return (React.createElement("div", null, React.createElement(SolidRadioItem, { label: BaseLocale.legend.position.title, options: legendPositions, value: position, onChange: setPosition }), (position === "left" /* Left */ || position === "right" /* Right */) && (React.createElement(NumberItem, { label: BaseLocale.legend.width, explain: formatString(BaseLocale.legend.width_tooltip), value: width, onChange: setWidth, min: 1, max: 60, placeholder: "Auto" })), !("none" /* None */ === position) && (React.createElement(React.Fragment, null, setHideChartLegend && (React.createElement(SolidRadioItem, { label: BaseLocale.legend.chart_legend, options: switchOptions, value: !hideChartLegend, onChange: function (value) { return setHideChartLegend(!value); } })), !hideChartLegend && (React.createElement(React.Fragment, null, React.createElement(ValueDisplayItem, { label: BaseLocale.legend.number.title, options: legendValueDisplayOptions, value: legendDisplayMode, onChange: setLegendDisplayMode, explain: BaseLocale.legend.explain }), React.createElement(Item, { label: BaseLocale.legend.sort }, React.createElement(RowContainer, { gutter: 8, sizes: [10, 10] }, React.createElement(Selector, { showSearch: true, allowClear: true, value: sort === null || sort === void 0 ? void 0 : sort.field, options: legendValueDisplayOptions.map(function (item) { return ({ text: item.label, value: item.value }); }), onChange: this.handleSortFieldChange, placeholder: formatString(BaseLocale.legend.sort_field_placeholder) }), React.createElement(Selector, { showSearch: true, allowClear: true, options: sortOrders, value: sort === null || sort === void 0 ? void 0 : sort.order, onChange: this.handleSortOrderChange, placeholder: formatString(BaseLocale.legend.sort_order_placeholder) }))))), setHideBaseLineLegend && (React.createElement(SolidRadioItem, { label: BaseLocale.legend.base_line_legend, options: switchOptions, value: !hideBaseLineLegend, onChange: function (value) { return setHideBaseLineLegend(!value); } })))))); }; __decorate([ bind, __metadata("design:type", Function), __metadata("design:paramtypes", [String]), __metadata("design:returntype", void 0) ], LegendPanel.prototype, "handleSortFieldChange", null); __decorate([ bind, __metadata("design:type", Function), __metadata("design:paramtypes", [String]), __metadata("design:returntype", void 0) ], LegendPanel.prototype, "handleSortOrderChange", null); LegendPanel = __decorate([ observer ], LegendPanel); return LegendPanel; }(React.Component)); export { LegendPanel }; export default errorBoundary(LegendPanel);