@qn-pandora/pandora-visualization
Version:
Pandora 通用可视化库
120 lines (119 loc) • 8.14 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 __assign = (this && this.__assign) || function () {
__assign = Object.assign || function(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
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);
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.StyleElement = void 0;
var react_1 = __importDefault(require("react"));
var mobx_react_1 = require("mobx-react");
var mobx_1 = require("mobx");
var lodash_1 = require("lodash");
var pandora_component_1 = require("@qn-pandora/pandora-component");
var errorBoundary_1 = __importDefault(require("../../../../hocs/errorBoundary"));
var BasicComponent_1 = __importDefault(require("../../../Base/BasicComponent"));
var Common_1 = require("../../../Common");
var Base_1 = require("../../../Base");
var type_1 = require("../../../../constants/language/other/type");
var type_2 = require("../../../../constants/language/single/type");
var bind_1 = __importDefault(require("../../../../utils/bind"));
var services_1 = require("../../../../services");
var SwitchNumberEditor_1 = __importDefault(require("../../Metrics/component/SwitchNumberEditor"));
var MetricStyle_1 = __importDefault(require("../../Metrics/component/MetricStyle"));
var constants_1 = require("../../constants");
var conatsnts_1 = require("./conatsnts");
var TitleIcon_1 = __importDefault(require("./TitleIcon"));
var Item = Common_1.Form.Item, Field = Common_1.Form.Field;
var StyleElement = /** @class */ (function (_super) {
__extends(StyleElement, _super);
function StyleElement() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(StyleElement.prototype, "titleFontStyle", {
get: function () {
var _a = this.props, themeOption = _a.themeOption, chartStyleService = _a.chartStyleService;
var titleFontSize = chartStyleService.titleFontSize, titleFontColor = chartStyleService.titleFontColor;
var statusPanel = lodash_1.get(themeOption, 'statusPanel');
var color = titleFontColor || lodash_1.get(statusPanel, ['itemStyle', 'fontColor']);
var fontSize = titleFontSize || lodash_1.get(statusPanel, ['itemStyle', 'fontSize']);
return { color: color, fontSize: fontSize };
},
enumerable: false,
configurable: true
});
StyleElement.prototype.handleChange = function (font) {
var _a = this.props.chartStyleService, setTitleFontSize = _a.setTitleFontSize, setTitleFontColor = _a.setTitleFontColor;
setTitleFontSize(font.fontSize);
setTitleFontColor(font.color);
};
StyleElement.prototype.render = function () {
var _a = this.props, themeOption = _a.themeOption, chartStyleService = _a.chartStyleService, dataset = _a.dataset, getPopupContainer = _a.getPopupContainer;
var metricStyles = chartStyleService.metricStyles, setMetricStyles = chartStyleService.setMetricStyles, pageSize = chartStyleService.pageSize, autoplaySpeed = chartStyleService.autoplaySpeed;
return (react_1.default.createElement(react_1.default.Fragment, null,
react_1.default.createElement(Base_1.SolidRadioItem, __assign({ options: constants_1.singleColorModeOptions, label: type_2.SingleLocale.color, field: "colorMode" }, conatsnts_1.formItemLayout)),
react_1.default.createElement(Item, __assign({ label: type_1.OtherLocale.status.panel_width, field: "width" }, conatsnts_1.formItemLayout),
react_1.default.createElement(pandora_component_1.InputNumber, { addonAfter: "px" })),
react_1.default.createElement(Item, __assign({ label: type_1.OtherLocale.status.panel_height, field: "height" }, conatsnts_1.formItemLayout),
react_1.default.createElement(pandora_component_1.InputNumber, { addonAfter: "px" })),
react_1.default.createElement(Base_1.TitleItem, __assign({ label: type_1.OtherLocale.metric.title, value: this.titleFontStyle, onChange: this.handleChange }, conatsnts_1.formItemLayout)),
react_1.default.createElement(Base_1.SolidRadioItem, __assign({ options: conatsnts_1.Arrangements, field: "arrangement", label: type_1.OtherLocale.status.arrangement }, conatsnts_1.formItemLayout)),
react_1.default.createElement(TitleIcon_1.default, { getPopupContainer: getPopupContainer, chartStyleService: chartStyleService, dataset: dataset }),
react_1.default.createElement(Field, { field: "pageSize" },
react_1.default.createElement(SwitchNumberEditor_1.default, __assign({ switchLabel: type_1.OtherLocale.status.page_size, inputLabel: type_1.OtherLocale.status.page_number, value: pageSize, switchEnableValue: 20, switchDisableValue: 0, inputUnit: services_1.formatString(type_1.OtherLocale.status.unit) }, conatsnts_1.formItemLayout))),
pageSize > 0 && (react_1.default.createElement(Field, { field: "autoplaySpeed" },
react_1.default.createElement(SwitchNumberEditor_1.default, __assign({ switchLabel: type_1.OtherLocale.status.autoplay, inputLabel: type_1.OtherLocale.status.speed, value: autoplaySpeed, switchEnableValue: 3, switchDisableValue: 0, inputUnit: services_1.formatString(type_1.OtherLocale.status.s) }, conatsnts_1.formItemLayout)))),
metricStyles && metricStyles.length > 0 && (react_1.default.createElement(react_1.default.Fragment, null,
react_1.default.createElement(Item, __assign({ label: type_1.OtherLocale.metric.metric_style }, conatsnts_1.formItemLayout)),
react_1.default.createElement(Item, { wrapperCol: { span: 24 } },
react_1.default.createElement(MetricStyle_1.default, { getPopupContainer: getPopupContainer, styles: metricStyles, themeOption: themeOption, onChange: setMetricStyles }))))));
};
__decorate([
mobx_1.computed,
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], StyleElement.prototype, "titleFontStyle", null);
__decorate([
bind_1.default,
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", void 0)
], StyleElement.prototype, "handleChange", null);
StyleElement = __decorate([
mobx_react_1.observer
], StyleElement);
return StyleElement;
}(BasicComponent_1.default));
exports.StyleElement = StyleElement;
exports.default = errorBoundary_1.default(StyleElement);