@qn-pandora/pandora-visualization
Version:
Pandora 通用可视化库
142 lines (141 loc) • 6.7 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 });
var mobx_1 = require("mobx");
var lodash_1 = require("lodash");
var bind_1 = __importDefault(require("../../../../utils/bind"));
var single_chart_1 = require("../../transforms/single-chart");
var constant_1 = require("../constant");
var constant_2 = require("./constant");
var language_1 = require("../../../../services/language");
var store_1 = __importDefault(require("../SingleCircleChart/store"));
var SingleGaugeStore = /** @class */ (function (_super) {
__extends(SingleGaugeStore, _super);
function SingleGaugeStore() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(SingleGaugeStore.prototype, "gaugeAxisLineRadius", {
// 刻度环的半径
get: function () {
var gaugeAxisLineRadius = '50%';
if (this.chartHeight && this.chartWidth) {
// 刻度环的半径 = 仪表盘半径 - 外环与刻度环的间距
gaugeAxisLineRadius = this.innerRadius - constant_2.GaugeAxisLineGap;
}
return gaugeAxisLineRadius;
},
enumerable: false,
configurable: true
});
Object.defineProperty(SingleGaugeStore.prototype, "series", {
get: function () {
return this.toGaugeSeries();
},
enumerable: false,
configurable: true
});
Object.defineProperty(SingleGaugeStore.prototype, "options", {
get: function () {
return lodash_1.merge({}, constant_1.defaultConfig, {
series: this.series
});
},
enumerable: false,
configurable: true
});
Object.defineProperty(SingleGaugeStore.prototype, "gaugeAxisSeries", {
// 仪表盘的刻度盘series配置
get: function () {
var _a = this.chartStyleService, gaugeMin = _a.gaugeMin, gaugeMax = _a.gaugeMax, unitTransformer = _a.unitTransformer, showAxisLabel = _a.showAxisLabel, splitNumber = _a.splitNumber;
return __assign(__assign({}, constant_2.gaugeAxisLineSeries), { radius: this.gaugeAxisLineRadius, min: gaugeMin, max: gaugeMax, splitNumber: splitNumber, name: language_1.formatString(constant_2.gaugeAxisLineSeries.name), axisLine: {
show: false,
lineStyle: {
width: 0,
color: [[1, 'rgba(0,0,0,0)']]
}
}, axisTick: {
show: showAxisLabel
}, axisLabel: {
show: showAxisLabel,
formatter: function (value) { return unitTransformer(value); }
}, splitLine: {
show: showAxisLabel
} });
},
enumerable: false,
configurable: true
});
SingleGaugeStore.prototype.toGaugeSeries = function () {
var detail = this.gaugeCircleSeries.detail;
var _a = this.chartStyleService, showAxisLabel = _a.showAxisLabel, gaugeTitlePosition = _a.gaugeTitlePosition;
var offcenter = lodash_1.get(this.themeOption, ['gauge', 'detail', 'offsetCenter']);
var gaugeCircleSeries = __assign(__assign({}, this.gaugeCircleSeries), { startAngle: 210, endAngle: -30, axisLine: {
show: true,
lineStyle: __assign(__assign({}, (this.gaugeLineWidth ? { width: this.gaugeLineWidth } : {})), { color: this.getGaugeColors(single_chart_1.getGaugeColorRange) })
}, detail: __assign(__assign({}, detail), { offsetCenter: showAxisLabel || gaugeTitlePosition === 'center' ? offcenter : [0, 0] }) });
return [this.gaugeAxisSeries, gaugeCircleSeries];
};
__decorate([
mobx_1.computed,
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], SingleGaugeStore.prototype, "gaugeAxisLineRadius", null);
__decorate([
mobx_1.computed,
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], SingleGaugeStore.prototype, "series", null);
__decorate([
mobx_1.computed,
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], SingleGaugeStore.prototype, "options", null);
__decorate([
mobx_1.computed,
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], SingleGaugeStore.prototype, "gaugeAxisSeries", null);
__decorate([
bind_1.default,
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", void 0)
], SingleGaugeStore.prototype, "toGaugeSeries", null);
return SingleGaugeStore;
}(store_1.default));
exports.default = SingleGaugeStore;