Sidebar-Charts.js 8.23 KB
(function () {
	// Adds Atlassian shapes
	// 图表
	Sidebar.prototype.addChartsPalette = function () {

		const generatorId = () => `echarts__instance__${ Date.now() }`

		const addClickHandler = Sidebar.prototype.addClickHandler
		Sidebar.prototype.addClickHandler = function (elt, ds, cells) {
			var graph = this.editorUi.editor.graph;
			var tol = graph.tolerance;
			const cell = cells[0]
			const cellValue = cell.value
			const validate = cellValue && cellValue.nodeName === 'UserObject' && cellValue.getAttribute('componentsType') === 'charts'
			const mouseDown = ds.mouseDown

			ds.mouseDown = function (evt) {
				if (validate) {
					cell.value.setAttribute('id', generatorId())
					graph.setAttributeForCell(cell, 'label', `<div class="echarts__instance" id="${ generatorId() }">${ generatorId() }</div>`)
				}
				mouseDown.apply(this, arguments)
			};

			const mouseUp = ds.mouseUp
			ds.mouseUp = function () {
				try {
					mouseUp.apply(this, arguments)
				} finally {
					if (validate) {
						const id = cell.value.id
						const chartDom = document.getElementById(id);
						chartDom.style.width = '400px'
						chartDom.style.height = '400px'
						const myChart = echarts.init(chartDom);
						const option = {
							xAxis: {
								type: 'category',
								data: [ 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun' ],
							},
							yAxis: {
								type: 'value',
							},
							series: [
								{
									data: [ 150, 230, 224, 218, 135, 147, 260 ],
									type: 'line',
								},
							],
						};

						option && myChart.setOption(option);
					}
				}
				// const dom = document.getElementById()
			}
			addClickHandler.apply(this, arguments)
		}

		const convertValueToString = this.graph.convertValueToString
		this.graph.convertValueToString = function (cell) {
			const cellValue = cell.value
			const validate = cellValue && cellValue.nodeName === 'UserObject' && cellValue.getAttribute('componentsType') === 'charts'
			if (validate) {
				setTimeout(() => {
					const id = cell.value.id
					console.log(id)
					const chartDom = document.getElementById(id);
					chartDom.style.width = '400px'
					chartDom.style.height = '400px'
					const myChart = echarts.init(chartDom);
					const option = {
						xAxis: {
							type: 'category',
							data: [ 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun' ],
						},
						yAxis: {
							type: 'value',
						},
						series: [
							{
								data: [ 150, 230, 224, 218, 135, 147, 260 ],
								type: 'line',
							},
						],
					};

					option && myChart.setOption(option);
				})
			}

			return convertValueToString.apply(this, arguments)
		}

		var s = 'html=1;shadow=0;dashed=0;shape=mxgraph.atlassian.';
		var s2 = 'html=1;shadow=0;dashed=0;fillColor=none;strokeColor=none;shape=mxgraph.bootstrap.rect;';
		var s3 = mxConstants.STYLE_STROKEWIDTH + '=1;shadow=0;dashed=0;align=center;html=1;' + mxConstants.STYLE_SHAPE + "=mxgraph.mockup.";
		var gn = 'mxgraph.charts';
		var dt = 'charts ';
		var sb = this;
		this.setCurrentSearchEntryLibrary('charts');

		const now = Date.now
		var fns = [
			this.addEntry('charts', mxUtils.bind(this, function () {
				const id = generatorId()
				var cell = new mxCell(`<div  id="${ id }" class="echarts__instance"></div>`, new mxGeometry(0, 0, 400, 400), 'text;html=1;strokeColor=none;fillColor=none;align=center;verticalAlign=middle;whiteSpace=wrap;overflow=hidden;');
				cell.setVertex(true)
				this.graph.setAttributeForCell(cell, 'placeholders', '1');
				this.graph.setAttributeForCell(cell, 'componentsType', 'charts');
				cell.value.setAttribute('id', id)
				return this.createVertexTemplateFromCells([ cell ], cell.geometry.width, cell.geometry.height, 'charts');
			})),
		];

		this.addPaletteFunctions('charts', '图表', false, fns);

		this.setCurrentSearchEntryLibrary();
	};
})();

function testChartImg() {
	return ''
}