Showing
5 changed files
with
236 additions
and
86 deletions
No preview for this file type
No preview for this file type
src/main/webapp/images/thingskit/charts.png
0 → 100644
224 Bytes
| @@ -1109,7 +1109,7 @@ | @@ -1109,7 +1109,7 @@ | ||
| 1109 | // 阀门 | 1109 | // 阀门 |
| 1110 | this.addValvePalette(); | 1110 | this.addValvePalette(); |
| 1111 | // 图表 | 1111 | // 图表 |
| 1112 | - // this.addChartsPalette(); | 1112 | + this.addChartsPalette(); |
| 1113 | // 风机 | 1113 | // 风机 |
| 1114 | this.addFanPalette(); | 1114 | this.addFanPalette(); |
| 1115 | // 污水处理 | 1115 | // 污水处理 |
| 1 | (function () { | 1 | (function () { |
| 2 | + | ||
| 3 | + const enumConst = { | ||
| 4 | + | ||
| 5 | + /** | ||
| 6 | + * @description 图表cell 默认宽度 | ||
| 7 | + */ | ||
| 8 | + CHART_CELL_DEFAULT_WIDTH: 400, | ||
| 9 | + | ||
| 10 | + /** | ||
| 11 | + * @description 图表cell 默认高度 | ||
| 12 | + */ | ||
| 13 | + CHART_CELL_DEFAULT_HEIGHT: 400, | ||
| 14 | + | ||
| 15 | + /** | ||
| 16 | + * @description 图表cell的 width attribute | ||
| 17 | + */ | ||
| 18 | + CHART_CELL_WIDTH: 'width', | ||
| 19 | + | ||
| 20 | + /** | ||
| 21 | + * @description 图表cell的 height attribute | ||
| 22 | + */ | ||
| 23 | + CHART_CELL_HEIGHT: 'height', | ||
| 24 | + | ||
| 25 | + /** | ||
| 26 | + * @description cell 类型是否为 charts | ||
| 27 | + */ | ||
| 28 | + IS_CHART_COMP: 'charts', | ||
| 29 | + | ||
| 30 | + /** | ||
| 31 | + * @description cell id key | ||
| 32 | + */ | ||
| 33 | + CHART_CELL_ID: 'chartInstanceId', | ||
| 34 | + | ||
| 35 | + /** | ||
| 36 | + * @description 图表类型key | ||
| 37 | + */ | ||
| 38 | + CHART_CELL_TYPE: 'componentsType', | ||
| 39 | + | ||
| 40 | + /** | ||
| 41 | + * @description 图表容器 class name | ||
| 42 | + */ | ||
| 43 | + CHART_CONTAINER_CLS: 'echarts__instance', | ||
| 44 | + | ||
| 45 | + /** | ||
| 46 | + * @description 图表容器 id 前缀 | ||
| 47 | + */ | ||
| 48 | + CHART_CONTAINER_ID_PREFIX: 'echarts__instance__', | ||
| 49 | + | ||
| 50 | + /** | ||
| 51 | + * @description 图表图片占位符大小 | ||
| 52 | + */ | ||
| 53 | + CHART_IMG_PLACEHOLDER_SIZE: 30, | ||
| 54 | + } | ||
| 55 | + | ||
| 2 | // Adds Atlassian shapes | 56 | // Adds Atlassian shapes |
| 3 | // 图表 | 57 | // 图表 |
| 4 | Sidebar.prototype.addChartsPalette = function () { | 58 | Sidebar.prototype.addChartsPalette = function () { |
| 59 | + const graph = this.graph | ||
| 60 | + chartsComponentInit(graph) | ||
| 5 | 61 | ||
| 6 | - const generatorId = () => `echarts__instance__${ Date.now() }` | 62 | + const s = 'html=1;shadow=0;dashed=0;shape=mxgraph.atlassian.'; |
| 63 | + const s2 = 'html=1;shadow=0;dashed=0;fillColor=none;strokeColor=none;shape=mxgraph.bootstrap.rect;'; | ||
| 64 | + const s3 = mxConstants.STYLE_STROKEWIDTH + '=1;shadow=0;dashed=0;align=center;html=1;' + mxConstants.STYLE_SHAPE + "=mxgraph.mockup."; | ||
| 65 | + const gn = 'mxgraph.charts'; | ||
| 66 | + const dt = 'charts '; | ||
| 67 | + const sb = this; | ||
| 68 | + this.setCurrentSearchEntryLibrary('charts'); | ||
| 69 | + | ||
| 70 | + const fns = [ | ||
| 71 | + this.addEntry('charts', mxUtils.bind(this, function () { | ||
| 72 | + const id = generatorChartsId() | ||
| 73 | + const cell = generatorCell(id, enumConst.CHART_IMG_PLACEHOLDER_SIZE, enumConst.CHART_IMG_PLACEHOLDER_SIZE, graph) | ||
| 74 | + return this.createVertexTemplateFromCells([ cell ], cell.geometry.width, cell.geometry.height, 'charts'); | ||
| 75 | + })), | ||
| 76 | + ]; | ||
| 77 | + | ||
| 78 | + this.addPaletteFunctions('charts', '图表', false, fns); | ||
| 79 | + | ||
| 80 | + this.setCurrentSearchEntryLibrary(); | ||
| 81 | + }; | ||
| 82 | + | ||
| 83 | + /** | ||
| 84 | + * @description 创建cell | ||
| 85 | + * @param id | ||
| 86 | + * @param width | ||
| 87 | + * @param height | ||
| 88 | + * @returns {*} | ||
| 89 | + */ | ||
| 90 | + function generatorCell(id, width, height, graph) { | ||
| 91 | + const cell = new mxCell(createChartsNode(id, width, height), new mxGeometry(0, 0, width, height), 'text;html=1;strokeColor=none;fillColor=none;align=center;verticalAlign=middle;whiteSpace=wrap;overflow=hidden;'); | ||
| 92 | + cell.setVertex(true) | ||
| 93 | + graph.setAttributeForCell(cell, enumConst.CHART_CELL_TYPE, 'charts'); | ||
| 94 | + graph.setAttributeForCell(cell, enumConst.CHART_CELL_ID, id); | ||
| 95 | + graph.setAttributeForCell(cell, enumConst.CHART_CELL_WIDTH, width) | ||
| 96 | + graph.setAttributeForCell(cell, enumConst.CHART_CELL_HEIGHT, height) | ||
| 97 | + return cell | ||
| 98 | + } | ||
| 99 | + | ||
| 100 | + function generatorChartsId() { | ||
| 101 | + return `${ enumConst.CHART_CONTAINER_ID_PREFIX }${ Date.now() }` | ||
| 102 | + } | ||
| 103 | + | ||
| 104 | + | ||
| 105 | + function createChartsNode(id, width = 400, height = 400) { | ||
| 106 | + const chartImg = '' | ||
| 107 | + return `<div class="echarts__instance" style="width: ${ width }px; height: ${ height }px" id="${ id }"><img src="${ chartImg }" alt=""></div>` | ||
| 108 | + } | ||
| 109 | + | ||
| 110 | + /** | ||
| 111 | + * @description 折线图配置 | ||
| 112 | + * @returns {{yAxis: {type: string}, xAxis: {data: string[], type: string}, series: [{data: number[], type: string}]}} | ||
| 113 | + */ | ||
| 114 | + function chartsLineChartsConfig() { | ||
| 115 | + return { | ||
| 116 | + xAxis: { | ||
| 117 | + type: 'category', | ||
| 118 | + data: [ 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun' ], | ||
| 119 | + }, | ||
| 120 | + yAxis: { | ||
| 121 | + type: 'value', | ||
| 122 | + }, | ||
| 123 | + series: [ | ||
| 124 | + { | ||
| 125 | + data: [ 150, 230, 224, 218, 135, 147, 260 ], | ||
| 126 | + type: 'line', | ||
| 127 | + }, | ||
| 128 | + ], | ||
| 129 | + } | ||
| 130 | + } | ||
| 7 | 131 | ||
| 132 | + function chartsComponentInit(graph) { | ||
| 133 | + const chartsInstanceMapping = new Map() | ||
| 134 | + | ||
| 135 | + /** | ||
| 136 | + * @description 拓展添加charts 实例方法 | ||
| 137 | + */ | ||
| 8 | const addClickHandler = Sidebar.prototype.addClickHandler | 138 | const addClickHandler = Sidebar.prototype.addClickHandler |
| 9 | Sidebar.prototype.addClickHandler = function (elt, ds, cells) { | 139 | Sidebar.prototype.addClickHandler = function (elt, ds, cells) { |
| 10 | - var graph = this.editorUi.editor.graph; | ||
| 11 | - var tol = graph.tolerance; | ||
| 12 | const cell = cells[0] | 140 | const cell = cells[0] |
| 13 | const cellValue = cell.value | 141 | const cellValue = cell.value |
| 14 | - const validate = cellValue && cellValue.nodeName === 'UserObject' && cellValue.getAttribute('componentsType') === 'charts' | ||
| 15 | - const mouseDown = ds.mouseDown | 142 | + const validate = cellValue && cellValue.nodeName === 'UserObject' && isChartCell(cell) |
| 16 | 143 | ||
| 144 | + const mouseDown = ds.mouseDown | ||
| 17 | ds.mouseDown = function (evt) { | 145 | ds.mouseDown = function (evt) { |
| 18 | if (validate) { | 146 | if (validate) { |
| 19 | - cell.value.setAttribute('id', generatorId()) | ||
| 20 | - graph.setAttributeForCell(cell, 'label', `<div class="echarts__instance" id="${ generatorId() }">${ generatorId() }</div>`) | 147 | + const id = generatorChartsId() |
| 148 | + const geo = Object.assign(graph.model.getGeometry(cell), { width: 400, height: 400 }) | ||
| 149 | + cell.setGeometry(geo) | ||
| 150 | + graph.setAttributeForCell(cell, enumConst.CHART_CELL_ID, id); | ||
| 151 | + graph.setAttributeForCell(cell, 'label', createChartsNode(id)) | ||
| 21 | } | 152 | } |
| 22 | mouseDown.apply(this, arguments) | 153 | mouseDown.apply(this, arguments) |
| 23 | }; | 154 | }; |
| @@ -28,97 +159,116 @@ | @@ -28,97 +159,116 @@ | ||
| 28 | mouseUp.apply(this, arguments) | 159 | mouseUp.apply(this, arguments) |
| 29 | } finally { | 160 | } finally { |
| 30 | if (validate) { | 161 | if (validate) { |
| 31 | - const id = cell.value.id | 162 | + const id = getCellId(cell) |
| 32 | const chartDom = document.getElementById(id); | 163 | const chartDom = document.getElementById(id); |
| 33 | - chartDom.style.width = '400px' | ||
| 34 | - chartDom.style.height = '400px' | ||
| 35 | const myChart = echarts.init(chartDom); | 164 | const myChart = echarts.init(chartDom); |
| 36 | - const option = { | ||
| 37 | - xAxis: { | ||
| 38 | - type: 'category', | ||
| 39 | - data: [ 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun' ], | ||
| 40 | - }, | ||
| 41 | - yAxis: { | ||
| 42 | - type: 'value', | ||
| 43 | - }, | ||
| 44 | - series: [ | ||
| 45 | - { | ||
| 46 | - data: [ 150, 230, 224, 218, 135, 147, 260 ], | ||
| 47 | - type: 'line', | ||
| 48 | - }, | ||
| 49 | - ], | ||
| 50 | - }; | ||
| 51 | - | 165 | + const option = chartsLineChartsConfig() |
| 52 | option && myChart.setOption(option); | 166 | option && myChart.setOption(option); |
| 167 | + chartsInstanceMapping.set(id, myChart) | ||
| 53 | } | 168 | } |
| 54 | } | 169 | } |
| 55 | - // const dom = document.getElementById() | ||
| 56 | } | 170 | } |
| 57 | addClickHandler.apply(this, arguments) | 171 | addClickHandler.apply(this, arguments) |
| 58 | } | 172 | } |
| 59 | 173 | ||
| 60 | - const convertValueToString = this.graph.convertValueToString | ||
| 61 | - this.graph.convertValueToString = function (cell) { | ||
| 62 | - const cellValue = cell.value | ||
| 63 | - const validate = cellValue && cellValue.nodeName === 'UserObject' && cellValue.getAttribute('componentsType') === 'charts' | ||
| 64 | - if (validate) { | ||
| 65 | - setTimeout(() => { | ||
| 66 | - const id = cell.value.id | ||
| 67 | - console.log(id) | ||
| 68 | - const chartDom = document.getElementById(id); | ||
| 69 | - chartDom.style.width = '400px' | ||
| 70 | - chartDom.style.height = '400px' | ||
| 71 | - const myChart = echarts.init(chartDom); | ||
| 72 | - const option = { | ||
| 73 | - xAxis: { | ||
| 74 | - type: 'category', | ||
| 75 | - data: [ 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun' ], | ||
| 76 | - }, | ||
| 77 | - yAxis: { | ||
| 78 | - type: 'value', | ||
| 79 | - }, | ||
| 80 | - series: [ | ||
| 81 | - { | ||
| 82 | - data: [ 150, 230, 224, 218, 135, 147, 260 ], | ||
| 83 | - type: 'line', | ||
| 84 | - }, | ||
| 85 | - ], | ||
| 86 | - }; | ||
| 87 | - | ||
| 88 | - option && myChart.setOption(option); | ||
| 89 | - }) | ||
| 90 | - } | 174 | + /** |
| 175 | + * @description charts cell发生resize时改变charts size | ||
| 176 | + * @type {mxGraph.cellResized} | ||
| 177 | + */ | ||
| 178 | + const cellResized = mxGraph.prototype.cellResized | ||
| 179 | + mxGraph.prototype.cellResized = function (cell, rect) { | ||
| 180 | + const { width, height } = rect | ||
| 181 | + const id = getCellId(cell) | ||
| 182 | + const chartDom = document.getElementById(id) | ||
| 183 | + chartDom.style.width = `${ width }px` | ||
| 184 | + chartDom.style.height = `${ height }px` | ||
| 185 | + graph.setAttributeForCell(cell, enumConst.CHART_CELL_WIDTH, width) | ||
| 186 | + graph.setAttributeForCell(cell, enumConst.CHART_CELL_HEIGHT, height) | ||
| 187 | + const instance = chartsInstanceMapping.get(id) | ||
| 188 | + instance.resize() | ||
| 189 | + cellResized.apply(this, arguments) | ||
| 190 | + } | ||
| 91 | 191 | ||
| 92 | - return convertValueToString.apply(this, arguments) | 192 | + /** |
| 193 | + * @description 删除charts cell 时 删除保存的charts 实例 | ||
| 194 | + */ | ||
| 195 | + const deleteCells = Graph.prototype.deleteCells | ||
| 196 | + Graph.prototype.deleteCells = function (cell) { | ||
| 197 | + const id = getCellId(cell) | ||
| 198 | + chartsInstanceMapping.delete(id) | ||
| 199 | + return deleteCells.apply(this, arguments) | ||
| 93 | } | 200 | } |
| 94 | 201 | ||
| 95 | - var s = 'html=1;shadow=0;dashed=0;shape=mxgraph.atlassian.'; | ||
| 96 | - var s2 = 'html=1;shadow=0;dashed=0;fillColor=none;strokeColor=none;shape=mxgraph.bootstrap.rect;'; | ||
| 97 | - var s3 = mxConstants.STYLE_STROKEWIDTH + '=1;shadow=0;dashed=0;align=center;html=1;' + mxConstants.STYLE_SHAPE + "=mxgraph.mockup."; | ||
| 98 | - var gn = 'mxgraph.charts'; | ||
| 99 | - var dt = 'charts '; | ||
| 100 | - var sb = this; | ||
| 101 | - this.setCurrentSearchEntryLibrary('charts'); | 202 | + /** |
| 203 | + * @description 获取charts cell 的id | ||
| 204 | + * @param cell | ||
| 205 | + * @returns {*} | ||
| 206 | + */ | ||
| 207 | + function getCellId(cell) { | ||
| 208 | + return graph.getAttributeForCell(cell, enumConst.CHART_CELL_ID) | ||
| 209 | + } | ||
| 102 | 210 | ||
| 103 | - const now = Date.now | ||
| 104 | - var fns = [ | ||
| 105 | - this.addEntry('charts', mxUtils.bind(this, function () { | ||
| 106 | - const id = generatorId() | ||
| 107 | - 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;'); | ||
| 108 | - cell.setVertex(true) | ||
| 109 | - this.graph.setAttributeForCell(cell, 'placeholders', '1'); | ||
| 110 | - this.graph.setAttributeForCell(cell, 'componentsType', 'charts'); | ||
| 111 | - cell.value.setAttribute('id', id) | ||
| 112 | - return this.createVertexTemplateFromCells([ cell ], cell.geometry.width, cell.geometry.height, 'charts'); | ||
| 113 | - })), | ||
| 114 | - ]; | 211 | + function generatorEChartInstance(id, width, height) { |
| 212 | + const chartDom = document.getElementById(id); | ||
| 213 | + chartDom.style.width = `${ width }px` | ||
| 214 | + chartDom.style.height = `${ height }px` | ||
| 215 | + const myChart = echarts.init(chartDom); | ||
| 216 | + const option = chartsLineChartsConfig() | ||
| 217 | + option && myChart.setOption(option); | ||
| 218 | + chartsInstanceMapping.set(id, myChart) | ||
| 219 | + } | ||
| 115 | 220 | ||
| 116 | - this.addPaletteFunctions('charts', '图表', false, fns); | 221 | + // 初始化图表 |
| 222 | + const openFileHandle = EditorUi.prototype.openFileHandle | ||
| 223 | + EditorUi.prototype.openFileHandle = function () { | ||
| 224 | + try { | ||
| 225 | + openFileHandle.apply(this, arguments) | ||
| 226 | + } finally { | ||
| 227 | + const allCell = this.editor.graph.getDefaultParent().children | ||
| 228 | + const domIdMapping = new Map() | ||
| 229 | + for (const cell of allCell) { | ||
| 230 | + const chartInstanceId = graph.getAttributeForCell(cell, enumConst.CHART_CELL_ID) | ||
| 231 | + if (isChartCell(cell) && chartInstanceId) { | ||
| 232 | + const width = graph.getAttributeForCell(cell, enumConst.CHART_CELL_WIDTH) | ||
| 233 | + const height = graph.getAttributeForCell(cell, enumConst.CHART_CELL_HEIGHT) | ||
| 234 | + domIdMapping.set(chartInstanceId, { width, height }) | ||
| 235 | + } | ||
| 236 | + } | ||
| 237 | + const chartsDomList = document.querySelectorAll(`.${ enumConst.CHART_CONTAINER_CLS }`) | ||
| 238 | + for (const chartDom of chartsDomList) { | ||
| 239 | + const id = chartDom.getAttribute('id') | ||
| 240 | + const { width, height } = domIdMapping.get(id) | ||
| 241 | + generatorEChartInstance(id, width, height) | ||
| 242 | + } | ||
| 243 | + } | ||
| 244 | + } | ||
| 117 | 245 | ||
| 118 | - this.setCurrentSearchEntryLibrary(); | ||
| 119 | - }; | ||
| 120 | -})(); | 246 | + /** |
| 247 | + * @description 是否是图表cell | ||
| 248 | + * @param cell | ||
| 249 | + * @returns {boolean} | ||
| 250 | + */ | ||
| 251 | + function isChartCell(cell) { | ||
| 252 | + const componentsType = graph.getAttributeForCell(cell, enumConst.CHART_CELL_TYPE) | ||
| 253 | + return !!(componentsType && componentsType === enumConst.IS_CHART_COMP) | ||
| 254 | + } | ||
| 121 | 255 | ||
| 122 | -function testChartImg() { | ||
| 123 | - return '' | ||
| 124 | -} | ||
| 256 | + const createTooltip = Sidebar.prototype.createTooltip | ||
| 257 | + Sidebar.prototype.createTooltip = function (elt, cells) { | ||
| 258 | + const id = generatorChartsId() | ||
| 259 | + const validateFlag = isChartCell(cells[0]) | ||
| 260 | + try { | ||
| 261 | + if (validateFlag) { | ||
| 262 | + const cell = generatorCell(id, enumConst.CHART_CELL_DEFAULT_WIDTH, enumConst.CHART_CELL_DEFAULT_HEIGHT, graph) | ||
| 263 | + const _arguments = Array.prototype.slice.call(arguments, 0) | ||
| 264 | + _arguments.splice(1, 1, [ cell ]) | ||
| 265 | + createTooltip.apply(this, _arguments) | ||
| 266 | + } else { | ||
| 267 | + createTooltip.apply(this, arguments) | ||
| 268 | + } | ||
| 269 | + } finally { | ||
| 270 | + if (validateFlag) generatorEChartInstance(id, enumConst.CHART_CELL_DEFAULT_WIDTH, enumConst.CHART_CELL_DEFAULT_HEIGHT) | ||
| 271 | + } | ||
| 272 | + } | ||
| 273 | + } | ||
| 274 | +})(); |