| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145 |
- import { changeTypeByTaskShape, typeConfig } from '../../config';
- import { append as svgAppend, create as svgCreate } from 'tiny-svg';
- import {
- bpmnEnd,
- bpmnExecute,
- bpmnGroup,
- bpmnLabel,
- bpmnOutside,
- bpmnProcessing,
- bpmnStart,
- bpmnSubFlow,
- bpmnTask,
- bpmnTrigger,
- typeExecute,
- typeOutside,
- typeProcessing,
- typeSubFlow,
- typeTrigger,
- } from '../../config/variableName';
- /**
- * svg重画bpmn节点
- */
- export default (parentNode: any, element: any, jnpfFlowInfo: any, injector: any) => {
- let data = jnpfFlowInfo?.flowNodes[element.id];
- let nodeMap = jnpfFlowInfo?.nodeList;
- let isPreview = jnpfFlowInfo?.isPreview;
- let type = element.type; // 获取到类型
- if (typeConfig && typeConfig[type]) {
- if (type === bpmnGroup) return null;
- if (data?.type === typeSubFlow || element.wnType === typeSubFlow) type = bpmnSubFlow;
- if (data?.type === typeProcessing || element.wnType === typeProcessing) type = bpmnProcessing;
- if (data?.type === typeTrigger || element.wnType === typeTrigger) type = bpmnTrigger;
- if (data?.type === typeExecute || element.wnType === typeExecute) type = bpmnExecute;
- if (data?.type === typeOutside || element.wnType === typeOutside) type = bpmnOutside;
- if (changeTypeByTaskShape[data?.type] || changeTypeByTaskShape[element?.wnType]) type = changeTypeByTaskShape[element?.wnType || data?.type];
- let { renderer } = typeConfig[type];
- let { icon, iconColor, rendererName, background, titleColor, attr, bodyDefaultText } = renderer;
- // 直接修改元素的宽高
- element['width'] = type === bpmnLabel ? 128 : attr.width;
- element['height'] = type === bpmnLabel ? 28 : attr.height;
- let nodeName = element.nodeName != null ? element.nodeName : data?.nodeName != null ? data.nodeName : rendererName;
- let nodeContent = element.elementBodyName || nodeMap.get(element.id)?.userName || data?.content || bodyDefaultText;
- if (isPreview) {
- if (nodeMap.get(element.id)?.type) {
- if (nodeMap.get(element.id)?.type === '0') {
- titleColor = 'linear-gradient(90deg, #AEEFC2 0%, #4ED587 100%)';
- iconColor = '#25a210';
- }
- if (nodeMap.get(element.id)?.type === '1') {
- titleColor = 'linear-gradient(90deg, #C0EDF8 0%, #A6DEF8 100%)';
- iconColor = '#1eaceb';
- }
- if (nodeMap.get(element.id)?.type === '3') {
- titleColor = 'linear-gradient(90deg, #FDC9D1 0%,#E03845 100%)';
- iconColor = '#E03845';
- }
- } else {
- titleColor = 'linear-gradient(90deg, #CED1D5 0%, #CBCBCC 100%);';
- iconColor = '#4c4c58';
- }
- }
- let foreignObject: any = svgCreate('foreignObject', {
- width: type === bpmnLabel ? 128 : attr.width,
- height: type === bpmnLabel ? 28 : attr.height,
- class: type === bpmnStart || type === bpmnEnd ? 'begin-or-end-node' : 'task-node',
- });
- // 开始节点
- if (type === bpmnStart) {
- foreignObject.innerHTML = `
- <div class="node-container start-node-container" style="background:${background}" >
- <div class='node-top-container'>
- <i class="${icon}" style="color:${iconColor}"></i>
- <span>${nodeName}</span>
- </div>
- </div>`;
- svgAppend(parentNode, foreignObject);
- return parentNode;
- }
- // 审批节点
- if (type === bpmnTask) {
- foreignObject.innerHTML = `
- <div class="node-container" style="background:${background}" >
- <div class='node-top-container' style="background:${titleColor};">
- <i class="${icon}" style="color:${iconColor}"></i>
- <span>${nodeName}</span>
- </div>
- <div class='node-bottom-container'>
- <span>${nodeContent}</span>
- </div>
- </div>`;
- svgAppend(parentNode, foreignObject);
- return parentNode;
- }
- // 子流程节点
- if (type === bpmnSubFlow || type === bpmnProcessing || type === bpmnTrigger || changeTypeByTaskShape[element?.wnType || data?.type]) {
- foreignObject.innerHTML = `
- <div class="node-container" style="background:${background}" >
- <div class='node-top-container' style="background:${titleColor}">
- <i class="${icon}" style="color:${iconColor}"></i>
- <span>${nodeName}</span>
- </div>
- <div class='node-bottom-container'>
- <span>${nodeContent}</span>
- </div>
- </div>`;
- svgAppend(parentNode, foreignObject);
- return parentNode;
- }
- // 结束节点
- if (type === bpmnEnd) {
- foreignObject.innerHTML = `
- <div class="node-container end-node-container" style="background:${background}" >
- <div class='node-top-container'>
- <i class="${icon}" style="color:${iconColor}"></i>
- <span>${nodeName}</span>
- </div>
- </div>`;
- svgAppend(parentNode, foreignObject);
- return parentNode;
- }
- // label渲染
- if (type === bpmnLabel) {
- let jnpfData = injector?.get('jnpfData');
- let data = jnpfData.getValue('global');
- let connectName = jnpfData.getValue(element.id.replace('_label', ''))?.nodeName || '连接线';
- if (data.isShowConditions) {
- let foreignObject: any = svgCreate('foreignObject', {
- width: 128,
- height: 28,
- class: 'label-node',
- });
- foreignObject.innerHTML = `
- <div class="node-container-label" >
- <div class='node-top-container'>
- <span> ${data.showNameType === 1 ? element.text : connectName}</span>
- </div>
- </div>`;
- element.text && svgAppend(parentNode, foreignObject);
- return parentNode;
- }
- return null;
- }
- }
- };
|