@qn-pandora/pandora-visualization
Version:
Pandora 通用可视化库
88 lines (87 loc) • 6.22 kB
JavaScript
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);