UNPKG

@qn-pandora/pandora-visualization

Version:

Pandora 通用可视化库

99 lines (98 loc) 5.5 kB
"use strict"; 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 __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); var react_1 = __importDefault(require("react")); var lodash_1 = require("lodash"); var mobx_react_1 = require("mobx-react"); var getPercent_1 = require("../../../../utils/getPercent"); var errorBoundary_1 = __importDefault(require("../../../../hocs/errorBoundary")); var language_1 = require("../../../../services/language"); var type_1 = require("../../../../constants/language/pie/type"); var DoughnutInterval_1 = __importDefault(require("./DoughnutInterval")); var HoverEvent_1 = __importDefault(require("./HoverEvent")); var InnerTitle_1 = __importDefault(require("./InnerTitle")); var InnerText = /** @class */ (function (_super) { __extends(InnerText, _super); function InnerText() { var _this = _super !== null && _super.apply(this, arguments) || this; _this.chartStyleService = _this.props.store .chartStyleService; _this.getTopLeft = function (center) { var left = lodash_1.get(center, 0); var top = lodash_1.get(center, 1); return { top: top, left: left }; }; _this.getValue = function (series, total) { return _this.formatValue(series.value, total); }; _this.getTitle = function (name) { var transformSeriesTooltipName = _this.props.store.transformSeriesTooltipName; return transformSeriesTooltipName(name); }; return _this; } InnerText.prototype.formatValue = function (value, total) { var _a = this.chartStyleService, titleDataFormat = _a.titleDataFormat, unitTransformer = _a.unitTransformer, titleDataPercentDecimals = _a.titleDataPercentDecimals; return titleDataFormat === "value" /* Value */ ? unitTransformer(value) : getPercent_1.getPercent(value, total, titleDataPercentDecimals); }; InnerText.prototype.getTotalValue = function (total) { return this.formatValue(total, total); }; InnerText.prototype.render = function () { var _a = this.props.store, normalPieCenter = _a.normalPieCenter, currentPlaySlice = _a.currentPlaySlice, totalOfCurrentData = _a.totalOfCurrentData; var _b = this.chartStyleService, titleDataFont = _b.titleDataFont, titleDataFormat = _b.titleDataFormat, titleFont = _b.titleFont, showTitleBucket = _b.showTitleBucket, circularPlay = _b.circularPlay; var name = lodash_1.get(currentPlaySlice, 'name'); var _c = this.getTopLeft(normalPieCenter), normalLeft = _c.left, normalTop = _c.top; return (react_1.default.createElement("div", null, circularPlay === "on" /* On */ ? (react_1.default.createElement(DoughnutInterval_1.default, { store: this.props.store })) : (react_1.default.createElement(HoverEvent_1.default, { store: this.props.store })), react_1.default.createElement(InnerTitle_1.default, { left: normalLeft, top: normalTop, subTitle: titleDataFormat === "hide" /* Hide */ ? undefined : currentPlaySlice ? __assign({ text: this.getValue(currentPlaySlice, totalOfCurrentData) }, titleDataFont) : __assign({ text: lodash_1.toString(this.getTotalValue(totalOfCurrentData)) }, titleDataFont), title: showTitleBucket ? currentPlaySlice ? __assign({ text: this.getTitle(lodash_1.toString(name)) }, titleFont) : __assign({ text: language_1.formatString(type_1.PieLocale.total) }, titleFont) : undefined }))); }; InnerText = __decorate([ mobx_react_1.observer ], InnerText); return InnerText; }(react_1.default.Component)); exports.default = errorBoundary_1.default(InnerText);