|
|
const e="0134f363-6673-4443-a165-53d5c6cbea75",a="custom-progress-node",t="进度条",n="
"nodes": [ { "id": "f0bb3636-d4a4-4437-a37d-b1eda804a5d9", "type": "custom-progress-node", "x": 200, "y": 200, "text": { "value": "", "x": 200, "y": 200 }, "properties": { "id": "f0bb3636-d4a4-4437-a37d-b1eda804a5d9", "width": 500, "height": 100, "x": 200, "y": 200, "rotation": 0, "opacity": 1, "showCategoryName": true, "showMaxValue": true, "showRectSplit": true, "splitMargin": 2, "showToolTip": true, "showToolTipBack": true, "xOffset": -35, "yOffset": -12, "codeConfig": "return option", "fontSize": 12, "showRightValue": true, "nodeAlias": "进度条", "showDefaultValue": false, "showUnit": false, "valueColor": "rgba(245, 166, 35, 1)", "categoryName": "A29", "categoryNameColor": "#03fcfe", "categoryFontSize": 12, "maxValue": 10000, "maxValueColor": "#0097ff", "maxValueFontSize": 12, "innerBarWidth": 18, "innerBarBack": [ { "offset": 0, "color": "#0097ff" }, { "offset": 0.4, "color": "#6dffe1" }, { "offset": 0.8, "color": "#9d6fff" } ], "outerBarWidth": 25, "outerBarBack": "#0e3c5e", "canvasBack": "rgb(24, 20, 50)", "tooltipBackUrl": "", "tooltipFontColor": "#ffffff", "tooltipFontSize": 12, "innerBarRadius": 0, "outerBarRadius": 0, "dynamic": { "normalData": { "dataPoint": "", "compareType": "", "conditionVariables": [], "defaultValue": "", "unit": "" } } } } ]}`,javascript:`const { createApp, createVNode, render } = Vue;const app = createApp({})const Progress = { template: '<div :id="chartId" style="width: 100%; height: 100%"></div>', props: { realValue: { type: String, default: '' }, unit: { type: String, default: '' }, chartId: { type: String, default: '' }, fontColor: { type: String, default: '#ffffff' }, fontSize: { type: Number, default: 14 }, fontFamily: { type: String, default: '宋体' }, fontStyle: { type: String, default: 'normal' }, width: { type: Number, default: 80 }, height: { type: Number, default: 35 }, showCategoryName: { type: Boolean, default: true }, showMaxValue: { type: Boolean, default: true }, showRectSplit: { type: Boolean, default: true }, splitMargin: { type: Number, default: 2, }, showToolTip: { type: Boolean, default: true }, showToolTipBack: { type: Boolean, default: true }, tooltipBackUrl: { type: String, default: '' }, xOffset: { type: Number, default: -35, }, yOffset: { type: Number, default: -12, }, categoryName: { type: String, default: "A29" }, categoryNameColor: { type: String, default: "#03fcfe" }, categoryFontSize: { type: Number, default: 12 }, tooltipFontColor:{ type: String, default: "#fff" }, tooltipFontSize:{ type: Number, default: 12 }, maxValue: { type: Number, default: 10000 }, maxValueColor: { type: String, default: "#0097ff" }, maxValueFontSize: { type: Number, default: 12 }, innerBarWidth: { type: Number, default: 18 }, innerBarBack: { type: Array, default: () => [ { "offset": 0, "color": "#0097ff" }, { "offset": 0.4, "color": "#6dffe1" }, { "offset": 0.8, "color": "#9d6fff" } ] }, outerBarWidth: { type: Number, default: 25 }, outerBarBack: { type: String, default: "#0e3c5e" }, canvasBack: { type: String, default: "rgb(24, 20, 50)" }, innerBarRadius: { type: Number, default: 0 }, outerBarRadius: { type: Number, default: 0 } }, setup(props) { const { watch, nextTick, toRefs } = Vue; const { canvasBack, tooltipBackUrl, showCategoryName, showMaxValue, showRectSplit, splitMargin, tooltipFontColor, tooltipFontSize, showToolTip, showToolTipBack, xOffset, yOffset, categoryName, categoryNameColor, categoryFontSize,innerBarRadius, outerBarRadius, unit, maxValue, maxValueColor, maxValueFontSize, innerBarWidth, innerBarBack, outerBarWidth, outerBarBack } = toRefs(props)
let myChart = null; const initChart = (val) => { // 基于准备好的dom,初始化echarts实例
const dom = document.getElementById(props.chartId); if (dom && !myChart) { if (!myChart) { myChart = echarts.init(dom); } if (val) { let category = [{ name: categoryName.value, value: Number(val) } ]; //类别
let total = maxValue.value; //数据总数
let datas = []; var rich = { white: { backgroundColor: { image: tooltipBackUrl.value }, padding: [5, 0, 5, 5], align: 'center', }, };
let rightValues = []
category.forEach(value => { datas.push(value.value); });
var option = { backgroundColor: canvasBack.value, xAxis: { max: total, splitLine: { show: false }, axisLine: { show: false }, axisLabel: { show: false }, axisTick: { show: false } }, grid: { left: 80, top: 20, //设置条形图的边距
right: 80, bottom: 20 }, yAxis: [{ type: 'category', inverse: true, axisLabel: { show: showCategoryName.value, textStyle: { fontSize: categoryFontSize.value, color: categoryNameColor.value, }, }, splitLine: { show: false, }, axisTick: { show: false, }, axisLine: { show: false, }, data: [categoryName.value], }], series: [{ //内
type: "bar", barWidth: innerBarWidth.value,
legendHoverLink: false, silent: true, itemStyle: { barBorderRadius: innerBarRadius.value, color: { type: "linear", x: 0, y: 0, x2: 1, y2: 0, colorStops: innerBarBack.value } }, label: { normal: { show: showToolTip.value, textStyle: { color: tooltipFontColor.value, fontSize: tooltipFontSize.value }, position: 'right', offset: [xOffset.value, yOffset.value], formatter: function (data) { const ratio = (data.value / total * 100).toFixed(2) return '{white|' + ratio + '%' + '}'; }, verticalAlign: 'bottom', rich: showToolTipBack.value ? rich : {} } }, data: category, z: 1, }, { //外边框
type: "pictorialBar", symbol: "rect", symbolBoundingData: total, itemStyle: { normal: { color: "none" } }, label: { normal: { show: showMaxValue.value, position: "right", offset: [0, 0], //设置右边数据位置
textStyle: { color: maxValueColor.value, fontSize: maxValueFontSize.value, fontWeight: 600 }, formatter(value) { const v = value.value >= 10000 ? value.value / 10000 + '万' + ' ' + unit.value : value.value + ' ' + unit.value; return v } } }, data: datas, z: 0, }, { name: "外框", type: "bar", barGap: "-120%", //设置外框粗细
data: [total, total, total], barWidth: outerBarWidth.value, itemStyle: { normal: { color: outerBarBack.value, //填充色
barBorderColor: outerBarBack.value, //边框色
barBorderWidth: 1, //边框宽度
barBorderRadius: outerBarRadius.value, //圆角半径
label: { //标签显示位置
show: false, position: "top" //insideTop 或者横向的 insideLeft
} } }, z: 0 } ] };
if (showRectSplit.value) { option.series.splice(1, 0, { //分隔
type: "pictorialBar", itemStyle: { color: "#000" }, symbolRepeat: "fixed", symbolMargin: splitMargin.value, symbol: "rect", symbolClip: true, symbolSize: [2, 21], symbolPosition: "start", symbolOffset: [0, 0], symbolBoundingData: total, data: category, z: 2, }) } // 使用刚指定的配置项和数据显示图表。
myChart.setOption(option); } } }
watch(() => props.realValue, (val) => { if (val) { console.log('val', val) nextTick(() => { initChart(val) }) } }, { immediate: true }) }}
class CustomProgressNode extends HtmlResize.view { setHtml(rootEl) { const { properties, width, height, } = this.props.model;
const { id, fontColor, fontSize, fontFamily, fontStyle, showCategoryName, showMaxValue, showRectSplit, splitMargin, tooltipFontColor, tooltipFontSize,innerBarRadius, outerBarRadius, showToolTip, showToolTipBack, xOffset, yOffset, categoryName, categoryNameColor, categoryFontSize, maxValue, maxValueColor, maxValueFontSize, innerBarWidth, innerBarBack, outerBarWidth, outerBarBack, canvasBack } = properties; const { model } = this.props;
const { normalData } = properties.dynamic || {}; let realValue = ""; let unit = ''; if (normalData) { realValue = window.resolveScadaNewValue(normalData.defaultValue); unit = normalData.unit; }
const el = document.createElement('div'); el.style.height = "100%"; rootEl.innerHTML = ''; const instance = createVNode(Progress, { realValue: realValue || '2500', unit, chartId: 'progress_' + id, fontColor, fontSize, fontFamily, fontStyle, width, height, showCategoryName, showMaxValue, showRectSplit, splitMargin, tooltipFontColor, tooltipFontSize,innerBarRadius, outerBarRadius, showToolTip, showToolTipBack, xOffset, yOffset, categoryName, categoryNameColor, categoryFontSize, maxValue, maxValueColor, maxValueFontSize, innerBarWidth, innerBarBack, outerBarWidth, outerBarBack, canvasBack }) instance.appContext = app._context render(instance, el) rootEl.appendChild(el); }
// 生命周期 支持重写内容, 但格式需一致
// shouldUpdate() {
// if (this.preProperties && this.preProperties === this.currentProperties) return;
// this.preProperties = this.currentProperties;
// return true;
// }
// componentDidMount() {
// if (this.shouldUpdate()) {
// this.setHtml(this.rootEl);
// }
// }
// componentDidUpdate() {
// if (this.shouldUpdate()) {
// this.setHtml(this.rootEl);
// }
// }
}
class CustomProgressModel extends HtmlResize.model { initNodeData(data) { // 自定义组件,需最开始重置一下text 。
data.text = { value: "", x: data.x, y: data.y, };
super.initNodeData(data); const { properties } = this; this.width = properties.width || 80; this.height = properties.height || 35; }
setAttributes() { // 自定义组件需重置 text
const { x, y, properties } = this; const { textHorizontalMove = 0, textVerticalMove = 0 } = properties; this.text = { ...this.text, x: x + textHorizontalMove, y: y + textVerticalMove, value: "", } }}
lf.register({ type: 'custom-progress-node', view: CustomProgressNode, model: CustomProgressModel,})
`,css:"",fakeData:""},c={id:e,name:a,aliasName:t,image:n,imageType:l,groupName:o,groupType:i,isRemote:!1,isDefault:!0,sectionType:A,config:r,files:s};export{t as aliasName,r as config,c as default,s as files,o as groupName,i as groupType,e as id,n as image,l as imageType,u as isDefault,d as isRemote,a as name,A as sectionType};
|