@qn-pandora/pandora-visualization
Version:
Pandora 通用可视化库
94 lines (93 loc) • 5 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;
};
import React from 'react';
import { get, toString } from 'lodash';
import { observer } from 'mobx-react';
import { getPercent } from '../../../../utils/getPercent';
import errorBoundary from '../../../../hocs/errorBoundary';
import { formatString } from '../../../../services/language';
import { PieLocale } from '../../../../constants/language/pie/type';
import DoughnutInterval from './DoughnutInterval';
import HoverEvent from './HoverEvent';
import InnerTitle from './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 = get(center, 0);
var top = 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(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 = get(currentPlaySlice, 'name');
var _c = this.getTopLeft(normalPieCenter), normalLeft = _c.left, normalTop = _c.top;
return (React.createElement("div", null,
circularPlay === "on" /* On */ ? (React.createElement(DoughnutInterval, { store: this.props.store })) : (React.createElement(HoverEvent, { store: this.props.store })),
React.createElement(InnerTitle, { left: normalLeft, top: normalTop, subTitle: titleDataFormat === "hide" /* Hide */
? undefined
: currentPlaySlice
? __assign({ text: this.getValue(currentPlaySlice, totalOfCurrentData) }, titleDataFont) : __assign({ text: toString(this.getTotalValue(totalOfCurrentData)) }, titleDataFont), title: showTitleBucket
? currentPlaySlice
? __assign({ text: this.getTitle(toString(name)) }, titleFont) : __assign({ text: formatString(PieLocale.total) }, titleFont)
: undefined })));
};
InnerText = __decorate([
observer
], InnerText);
return InnerText;
}(React.Component));
export default errorBoundary(InnerText);