style:流程图
Showing
10 changed files
with
583 additions
and
68 deletions
| ... | @@ -21,7 +21,9 @@ | ... | @@ -21,7 +21,9 @@ |
| 21 | "vue-router": "3.0.2", | 21 | "vue-router": "3.0.2", |
| 22 | "vuex": "3.1.0", | 22 | "vuex": "3.1.0", |
| 23 | "bpmn-js": "^7.4.0", | 23 | "bpmn-js": "^7.4.0", |
| 24 | "diagram-js": "^6.8.2" | 24 | "diagram-js": "^6.8.2", |
| 25 | "bpmn-js-properties-panel": "^0.37.2", | ||
| 26 | "bpmn-js-token-simulation": "^0.10.0" | ||
| 25 | }, | 27 | }, |
| 26 | "devDependencies": { | 28 | "devDependencies": { |
| 27 | "@vue/cli-plugin-babel": "4.4.4", | 29 | "@vue/cli-plugin-babel": "4.4.4", |
| ... | @@ -74,4 +76,4 @@ | ... | @@ -74,4 +76,4 @@ |
| 74 | "type": "git", | 76 | "type": "git", |
| 75 | "url": "git+https://github.com/PanJiaChen/vue-element-admin.git" | 77 | "url": "git+https://github.com/PanJiaChen/vue-element-admin.git" |
| 76 | } | 78 | } |
| 77 | } | 79 | } |
| ... | \ No newline at end of file | ... | \ No newline at end of file | ... | ... |
| ... | @@ -47,13 +47,13 @@ export function logoutReg (data) { | ... | @@ -47,13 +47,13 @@ export function logoutReg (data) { |
| 47 | }) | 47 | }) |
| 48 | } | 48 | } |
| 49 | // 流程图 | 49 | // 流程图 |
| 50 | export function getWorkFlowImage (bsmSlsq) { | 50 | export function getWorkFlowImage (bsmSlsq, bestepid) { |
| 51 | return request({ | 51 | return request({ |
| 52 | url: '/business/workFlow/getWorkFlowImage', | 52 | url: '/business/workFlow/getWorkFlowImage', |
| 53 | method: 'get', | 53 | method: 'get', |
| 54 | responseType: 'blob', | ||
| 55 | params: { | 54 | params: { |
| 56 | bsmSlsq: bsmSlsq | 55 | bsmSlsq: bsmSlsq, |
| 56 | bestepid: bestepid | ||
| 57 | } | 57 | } |
| 58 | }) | 58 | }) |
| 59 | } | 59 | } | ... | ... |
| ... | @@ -55,21 +55,21 @@ export default { | ... | @@ -55,21 +55,21 @@ export default { |
| 55 | }, | 55 | }, |
| 56 | mounted () { | 56 | mounted () { |
| 57 | // 计算滚动条高度 | 57 | // 计算滚动条高度 |
| 58 | setTimeout(() => { | 58 | // setTimeout(() => { |
| 59 | if (this.btnShow) { //判断按钮的显影来决定是否需要计算高度 | 59 | // if (this.btnShow) { |
| 60 | if (this.height == 'auto') { | 60 | // if (this.height == 'auto') { |
| 61 | this.contentHeight = (this.$refs.contentRef.offsetHeight - 100) + 'px' | 61 | // this.contentHeight = (this.$refs.contentRef.offsetHeight - 200) + 'px' |
| 62 | } else { | 62 | // } else { |
| 63 | this.contentHeight = this.height | 63 | // this.contentHeight = this.height |
| 64 | } | 64 | // } |
| 65 | } else { | 65 | // } else { |
| 66 | if (this.height == 'auto') { | 66 | // if (this.height == 'auto') { |
| 67 | this.contentHeight = this.$refs.contentRef.offsetHeight | 67 | // this.contentHeight = this.$refs.contentRef.offsetHeight |
| 68 | } else { | 68 | // } else { |
| 69 | this.contentHeight = this.height | 69 | // this.contentHeight = this.height |
| 70 | } | 70 | // } |
| 71 | } | 71 | // } |
| 72 | }, 500) | 72 | // }, 500) |
| 73 | }, | 73 | }, |
| 74 | methods: { | 74 | methods: { |
| 75 | onCancel () { | 75 | onCancel () { | ... | ... |
| ... | @@ -22,7 +22,6 @@ router.beforeEach(async (to, from, next) => { | ... | @@ -22,7 +22,6 @@ router.beforeEach(async (to, from, next) => { |
| 22 | const { result: getMenuData } = await getMenuInfo() | 22 | const { result: getMenuData } = await getMenuInfo() |
| 23 | const accessRoutes = await store.dispatch('permission/generateRoutes', getMenuData) | 23 | const accessRoutes = await store.dispatch('permission/generateRoutes', getMenuData) |
| 24 | router.addRoutes(accessRoutes) | 24 | router.addRoutes(accessRoutes) |
| 25 | console.log(router); | ||
| 26 | next({ ...to, replace: true }) | 25 | next({ ...to, replace: true }) |
| 27 | } | 26 | } |
| 28 | NProgress.done() | 27 | NProgress.done() | ... | ... |
| 1 | /* 改变主题色变量 */ | ||
| 2 | // $--color-primary: #1890ff; | ||
| 3 | // $--color-danger: #ff4d4f; | ||
| 4 | |||
| 5 | /* 改变 icon 字体路径变量,必需 */ | ||
| 6 | |||
| 7 | .process-drawer .el-drawer__header { | ||
| 8 | padding: 16px 16px 8px 16px; | ||
| 9 | margin: 0; | ||
| 10 | line-height: 24px; | ||
| 11 | font-size: 18px; | ||
| 12 | color: #303133; | ||
| 13 | box-sizing: border-box; | ||
| 14 | border-bottom: 1px solid #e8e8e8; | ||
| 15 | } | ||
| 16 | |||
| 17 | div[class^="el-drawer"]:focus, | ||
| 18 | span:focus { | ||
| 19 | outline: none; | ||
| 20 | } | ||
| 21 | |||
| 22 | .process-drawer .el-drawer__body { | ||
| 23 | box-sizing: border-box; | ||
| 24 | padding: 16px; | ||
| 25 | width: 100%; | ||
| 26 | overflow-y: auto; | ||
| 27 | } | ||
| 28 | |||
| 29 | .process-design { | ||
| 30 | .el-table td, | ||
| 31 | .el-table th { | ||
| 32 | color: #333; | ||
| 33 | } | ||
| 34 | |||
| 35 | .el-dialog__header { | ||
| 36 | padding: 16px 16px 8px 16px; | ||
| 37 | box-sizing: border-box; | ||
| 38 | border-bottom: 1px solid #e8e8e8; | ||
| 39 | } | ||
| 40 | .el-dialog__body { | ||
| 41 | padding: 16px; | ||
| 42 | max-height: 80vh; | ||
| 43 | box-sizing: border-box; | ||
| 44 | overflow-y: auto; | ||
| 45 | } | ||
| 46 | .el-dialog__footer { | ||
| 47 | padding: 16px; | ||
| 48 | box-sizing: border-box; | ||
| 49 | border-top: 1px solid #e8e8e8; | ||
| 50 | } | ||
| 51 | .el-dialog__close { | ||
| 52 | font-weight: 600; | ||
| 53 | } | ||
| 54 | .el-select { | ||
| 55 | width: 100%; | ||
| 56 | } | ||
| 57 | .el-divider:not(.el-divider--horizontal) { | ||
| 58 | margin: 0 8px ; | ||
| 59 | } | ||
| 60 | .el-divider.el-divider--horizontal { | ||
| 61 | margin: 16px 0; | ||
| 62 | } | ||
| 63 | } |
src/styles/package/theme/index.scss
0 → 100644
| 1 | @import "./flow-element-variables.scss"; | ||
| 2 | @import "~bpmn-js-token-simulation/assets/css/bpmn-js-token-simulation.css"; | ||
| 3 | @import "~bpmn-js-token-simulation/assets/css/font-awesome.min.css"; | ||
| 4 | @import "~bpmn-js-token-simulation/assets/css/normalize.css"; | ||
| 5 | @import "~bpmn-js/dist/assets/diagram-js.css"; | ||
| 6 | @import "~bpmn-js/dist/assets/bpmn-font/css/bpmn.css"; | ||
| 7 | @import "~bpmn-js/dist/assets/bpmn-font/css/bpmn-codes.css"; | ||
| 8 | @import "./process-designer.scss"; | ||
| 9 | @import "./process-panel.scss"; | ||
| 10 | |||
| 11 | $success-color: #4eb819; | ||
| 12 | $primary-color: #409EFF; | ||
| 13 | $warning-color: #E6A23C; | ||
| 14 | $danger-color: #F56C6C; | ||
| 15 | $cancel-color: #909399; | ||
| 16 | |||
| 17 | .process-viewer { | ||
| 18 | position: relative; | ||
| 19 | border: 1px solid #EFEFEF; | ||
| 20 | background: url('') repeat!important; | ||
| 21 | |||
| 22 | .success-arrow { | ||
| 23 | fill: $success-color; | ||
| 24 | stroke: $success-color; | ||
| 25 | } | ||
| 26 | |||
| 27 | .success-conditional { | ||
| 28 | fill: white; | ||
| 29 | stroke: $success-color; | ||
| 30 | } | ||
| 31 | |||
| 32 | .fail-arrow { | ||
| 33 | fill: $warning-color; | ||
| 34 | stroke: $warning-color; | ||
| 35 | } | ||
| 36 | |||
| 37 | .fail-conditional { | ||
| 38 | fill: white; | ||
| 39 | stroke: $warning-color; | ||
| 40 | } | ||
| 41 | |||
| 42 | .success.djs-connection { | ||
| 43 | .djs-visual path { | ||
| 44 | stroke: $success-color!important; | ||
| 45 | marker-end: url(#sequenceflow-end-white-success)!important; | ||
| 46 | } | ||
| 47 | } | ||
| 48 | |||
| 49 | .success.djs-connection.condition-expression { | ||
| 50 | .djs-visual path { | ||
| 51 | marker-start: url(#conditional-flow-marker-white-success)!important; | ||
| 52 | } | ||
| 53 | } | ||
| 54 | |||
| 55 | .success.djs-shape { | ||
| 56 | .djs-visual rect { | ||
| 57 | stroke: $success-color!important; | ||
| 58 | fill: $success-color!important; | ||
| 59 | fill-opacity: 0.15!important; | ||
| 60 | } | ||
| 61 | |||
| 62 | .djs-visual polygon { | ||
| 63 | stroke: $success-color!important; | ||
| 64 | } | ||
| 65 | |||
| 66 | .djs-visual path:nth-child(2) { | ||
| 67 | stroke: $success-color!important; | ||
| 68 | fill: $success-color!important; | ||
| 69 | } | ||
| 70 | |||
| 71 | .djs-visual circle { | ||
| 72 | stroke: $success-color!important; | ||
| 73 | fill: $success-color!important; | ||
| 74 | fill-opacity: 0.15!important; | ||
| 75 | } | ||
| 76 | } | ||
| 77 | |||
| 78 | .primary.djs-shape { | ||
| 79 | .djs-visual rect { | ||
| 80 | stroke: $primary-color!important; | ||
| 81 | fill: $primary-color!important; | ||
| 82 | fill-opacity: 0.15!important; | ||
| 83 | } | ||
| 84 | |||
| 85 | .djs-visual polygon { | ||
| 86 | stroke: $primary-color!important; | ||
| 87 | } | ||
| 88 | |||
| 89 | .djs-visual circle { | ||
| 90 | stroke: $primary-color!important; | ||
| 91 | fill: $primary-color!important; | ||
| 92 | fill-opacity: 0.15!important; | ||
| 93 | } | ||
| 94 | } | ||
| 95 | |||
| 96 | .warning.djs-connection { | ||
| 97 | .djs-visual path { | ||
| 98 | stroke: $warning-color!important; | ||
| 99 | marker-end: url(#sequenceflow-end-white-fail)!important; | ||
| 100 | } | ||
| 101 | } | ||
| 102 | |||
| 103 | .warning.djs-connection.condition-expression { | ||
| 104 | .djs-visual path { | ||
| 105 | marker-start: url(#conditional-flow-marker-white-fail)!important; | ||
| 106 | } | ||
| 107 | } | ||
| 108 | |||
| 109 | .warning.djs-shape { | ||
| 110 | .djs-visual rect { | ||
| 111 | stroke: $warning-color!important; | ||
| 112 | fill: $warning-color!important; | ||
| 113 | fill-opacity: 0.15!important; | ||
| 114 | } | ||
| 115 | |||
| 116 | .djs-visual polygon { | ||
| 117 | stroke: $warning-color!important; | ||
| 118 | } | ||
| 119 | |||
| 120 | .djs-visual path:nth-child(2) { | ||
| 121 | stroke: $warning-color!important; | ||
| 122 | fill: $warning-color!important; | ||
| 123 | } | ||
| 124 | |||
| 125 | .djs-visual circle { | ||
| 126 | stroke: $warning-color!important; | ||
| 127 | fill: $warning-color!important; | ||
| 128 | fill-opacity: 0.15!important; | ||
| 129 | } | ||
| 130 | } | ||
| 131 | |||
| 132 | .danger.djs-shape { | ||
| 133 | .djs-visual rect { | ||
| 134 | stroke: $danger-color!important; | ||
| 135 | fill: $danger-color!important; | ||
| 136 | fill-opacity: 0.15!important; | ||
| 137 | } | ||
| 138 | |||
| 139 | .djs-visual polygon { | ||
| 140 | stroke: $danger-color!important; | ||
| 141 | } | ||
| 142 | |||
| 143 | .djs-visual circle { | ||
| 144 | stroke: $danger-color!important; | ||
| 145 | fill: $danger-color!important; | ||
| 146 | fill-opacity: 0.15!important; | ||
| 147 | } | ||
| 148 | } | ||
| 149 | |||
| 150 | .cancel.djs-shape { | ||
| 151 | .djs-visual rect { | ||
| 152 | stroke: $cancel-color!important; | ||
| 153 | fill: $cancel-color!important; | ||
| 154 | fill-opacity: 0.15!important; | ||
| 155 | } | ||
| 156 | |||
| 157 | .djs-visual polygon { | ||
| 158 | stroke: $cancel-color!important; | ||
| 159 | } | ||
| 160 | |||
| 161 | .djs-visual circle { | ||
| 162 | stroke: $cancel-color!important; | ||
| 163 | fill: $cancel-color!important; | ||
| 164 | fill-opacity: 0.15!important; | ||
| 165 | } | ||
| 166 | } | ||
| 167 | } | ||
| 168 | |||
| 169 | .process-viewer .djs-tooltip-container, .process-viewer .djs-overlay-container, .process-viewer .djs-palette { | ||
| 170 | display: none; | ||
| 171 | } |
| 1 | // 边框被 token-simulation 样式覆盖了 | ||
| 2 | .djs-palette { | ||
| 3 | background: var(--palette-background-color); | ||
| 4 | border: solid 1px var(--palette-border-color) !important; | ||
| 5 | border-radius: 2px; | ||
| 6 | } | ||
| 7 | |||
| 8 | .my-process-designer { | ||
| 9 | padding: 5px 0 10px 10px; | ||
| 10 | display: flex; | ||
| 11 | flex-direction: column; | ||
| 12 | width: 100%; | ||
| 13 | height: 100%; | ||
| 14 | box-sizing: border-box; | ||
| 15 | .my-process-designer__header { | ||
| 16 | width: 100%; | ||
| 17 | min-height: 36px; | ||
| 18 | .el-button { | ||
| 19 | text-align: center; | ||
| 20 | } | ||
| 21 | .el-button-group { | ||
| 22 | margin: 4px; | ||
| 23 | } | ||
| 24 | .el-tooltip__popper { | ||
| 25 | .el-button { | ||
| 26 | width: 100%; | ||
| 27 | text-align: left; | ||
| 28 | padding-left: 8px; | ||
| 29 | padding-right: 8px; | ||
| 30 | } | ||
| 31 | .el-button:hover { | ||
| 32 | background: rgba(64, 158, 255, 0.8); | ||
| 33 | color: #ffffff; | ||
| 34 | } | ||
| 35 | } | ||
| 36 | .align { | ||
| 37 | position: relative; | ||
| 38 | i { | ||
| 39 | &:after { | ||
| 40 | content: "|"; | ||
| 41 | position: absolute; | ||
| 42 | transform: rotate(90deg) translate(200%, 60%); | ||
| 43 | } | ||
| 44 | } | ||
| 45 | } | ||
| 46 | .align.align-left i { | ||
| 47 | transform: rotate(90deg); | ||
| 48 | } | ||
| 49 | .align.align-right i { | ||
| 50 | transform: rotate(-90deg); | ||
| 51 | } | ||
| 52 | .align.align-top i { | ||
| 53 | transform: rotate(180deg); | ||
| 54 | } | ||
| 55 | .align.align-bottom i { | ||
| 56 | transform: rotate(0deg); | ||
| 57 | } | ||
| 58 | .align.align-center i { | ||
| 59 | transform: rotate(90deg); | ||
| 60 | &:after { | ||
| 61 | transform: rotate(90deg) translate(0, 60%); | ||
| 62 | } | ||
| 63 | } | ||
| 64 | .align.align-middle i { | ||
| 65 | transform: rotate(0deg); | ||
| 66 | &:after { | ||
| 67 | transform: rotate(90deg) translate(0, 60%); | ||
| 68 | } | ||
| 69 | } | ||
| 70 | } | ||
| 71 | .my-process-designer__container { | ||
| 72 | display: inline-flex; | ||
| 73 | width: 100%; | ||
| 74 | flex: 1; | ||
| 75 | .my-process-designer__canvas { | ||
| 76 | flex: 1; | ||
| 77 | height: 100%; | ||
| 78 | position: relative; | ||
| 79 | background: url("") | ||
| 80 | repeat !important; | ||
| 81 | div.toggle-mode { | ||
| 82 | display: none; | ||
| 83 | } | ||
| 84 | } | ||
| 85 | .my-process-designer__property-panel { | ||
| 86 | height: 100%; | ||
| 87 | overflow: scroll; | ||
| 88 | overflow-y: auto; | ||
| 89 | z-index: 10; | ||
| 90 | * { | ||
| 91 | box-sizing: border-box; | ||
| 92 | } | ||
| 93 | } | ||
| 94 | svg { | ||
| 95 | width: 100%; | ||
| 96 | height: 100%; | ||
| 97 | min-height: 100%; | ||
| 98 | overflow: hidden; | ||
| 99 | } | ||
| 100 | } | ||
| 101 | } | ||
| 102 | |||
| 103 | //侧边栏配置 | ||
| 104 | .djs-palette.open { | ||
| 105 | .djs-palette-entries { | ||
| 106 | div[class^="bpmn-icon-"]:before, | ||
| 107 | div[class*="bpmn-icon-"]:before { | ||
| 108 | line-height: unset; | ||
| 109 | } | ||
| 110 | div.entry { | ||
| 111 | position: relative; | ||
| 112 | } | ||
| 113 | div.entry:hover { | ||
| 114 | &::after { | ||
| 115 | width: max-content; | ||
| 116 | content: attr(title); | ||
| 117 | vertical-align: text-bottom; | ||
| 118 | position: absolute; | ||
| 119 | right: -10px; | ||
| 120 | top: 0; | ||
| 121 | bottom: 0; | ||
| 122 | overflow: hidden; | ||
| 123 | transform: translateX(100%); | ||
| 124 | font-size: 0.5em; | ||
| 125 | display: inline-block; | ||
| 126 | text-decoration: inherit; | ||
| 127 | font-variant: normal; | ||
| 128 | text-transform: none; | ||
| 129 | background: #fafafa; | ||
| 130 | box-shadow: 0 0 6px #eeeeee; | ||
| 131 | border: 1px solid #cccccc; | ||
| 132 | box-sizing: border-box; | ||
| 133 | padding: 0 16px; | ||
| 134 | border-radius: 4px; | ||
| 135 | z-index: 100; | ||
| 136 | } | ||
| 137 | } | ||
| 138 | } | ||
| 139 | } | ||
| 140 | pre { | ||
| 141 | margin: 0; | ||
| 142 | height: 100%; | ||
| 143 | overflow: hidden; | ||
| 144 | max-height: calc(80vh - 32px); | ||
| 145 | overflow-y: auto; | ||
| 146 | } | ||
| 147 | .hljs { | ||
| 148 | word-break: break-word; | ||
| 149 | white-space: pre-wrap; | ||
| 150 | } | ||
| 151 | .hljs * { | ||
| 152 | font-family: Consolas, Monaco, monospace; | ||
| 153 | } |
src/styles/package/theme/process-panel.scss
0 → 100644
| 1 | .process-design { | ||
| 2 | .process-panel__container { | ||
| 3 | box-sizing: border-box; | ||
| 4 | padding: 0 8px; | ||
| 5 | border-left: 1px solid #eeeeee; | ||
| 6 | box-shadow: 0 0 8px #cccccc; | ||
| 7 | max-height: 100%; | ||
| 8 | overflow-y: scroll; | ||
| 9 | } | ||
| 10 | .panel-tab__title { | ||
| 11 | font-weight: 600; | ||
| 12 | padding: 0 8px; | ||
| 13 | font-size: 1.1em; | ||
| 14 | line-height: 1.2em; | ||
| 15 | i { | ||
| 16 | margin-right: 8px; | ||
| 17 | font-size: 1.2em; | ||
| 18 | } | ||
| 19 | } | ||
| 20 | .panel-tab__content { | ||
| 21 | width: 100%; | ||
| 22 | box-sizing: border-box; | ||
| 23 | border-top: 1px solid #eeeeee; | ||
| 24 | padding: 8px 16px; | ||
| 25 | .panel-tab__content--title { | ||
| 26 | display: flex; | ||
| 27 | justify-content: space-between; | ||
| 28 | padding-bottom: 8px; | ||
| 29 | span { | ||
| 30 | flex: 1; | ||
| 31 | text-align: left; | ||
| 32 | } | ||
| 33 | } | ||
| 34 | } | ||
| 35 | .element-property { | ||
| 36 | width: 100%; | ||
| 37 | display: flex; | ||
| 38 | align-items: flex-start; | ||
| 39 | margin: 8px 0; | ||
| 40 | .element-property__label { | ||
| 41 | display: block; | ||
| 42 | width: 90px; | ||
| 43 | text-align: right; | ||
| 44 | overflow: hidden; | ||
| 45 | padding-right: 12px; | ||
| 46 | line-height: 32px; | ||
| 47 | font-size: 14px; | ||
| 48 | box-sizing: border-box; | ||
| 49 | } | ||
| 50 | .element-property__value { | ||
| 51 | flex: 1; | ||
| 52 | line-height: 32px; | ||
| 53 | } | ||
| 54 | .el-form-item { | ||
| 55 | width: 100%; | ||
| 56 | margin-bottom: 0; | ||
| 57 | padding-bottom: 18px; | ||
| 58 | } | ||
| 59 | } | ||
| 60 | .list-property { | ||
| 61 | flex-direction: column; | ||
| 62 | .element-listener-item { | ||
| 63 | width: 100%; | ||
| 64 | display: inline-grid; | ||
| 65 | grid-template-columns: 16px auto 32px 32px; | ||
| 66 | grid-column-gap: 8px; | ||
| 67 | } | ||
| 68 | .element-listener-item + .element-listener-item { | ||
| 69 | margin-top: 8px; | ||
| 70 | } | ||
| 71 | } | ||
| 72 | .listener-filed__title { | ||
| 73 | display: inline-flex; | ||
| 74 | width: 100%; | ||
| 75 | justify-content: space-between; | ||
| 76 | align-items: center; | ||
| 77 | margin-top: 0; | ||
| 78 | span { | ||
| 79 | width: 200px; | ||
| 80 | text-align: left; | ||
| 81 | font-size: 14px; | ||
| 82 | } | ||
| 83 | i { | ||
| 84 | margin-right: 8px; | ||
| 85 | } | ||
| 86 | } | ||
| 87 | .element-drawer__button { | ||
| 88 | margin-top: 8px; | ||
| 89 | width: 100%; | ||
| 90 | display: inline-flex; | ||
| 91 | justify-content: space-around; | ||
| 92 | } | ||
| 93 | .element-drawer__button > .el-button { | ||
| 94 | width: 100%; | ||
| 95 | } | ||
| 96 | |||
| 97 | .el-collapse-item__content { | ||
| 98 | padding-bottom: 0; | ||
| 99 | } | ||
| 100 | .el-input.is-disabled .el-input__inner { | ||
| 101 | color: #999999; | ||
| 102 | } | ||
| 103 | .el-form-item.el-form-item--mini { | ||
| 104 | margin-bottom: 0; | ||
| 105 | & + .el-form-item { | ||
| 106 | margin-top: 16px; | ||
| 107 | } | ||
| 108 | } | ||
| 109 | } | ||
| 110 |
| 1 | <template> | 1 | <template> |
| 2 | <div class="process-viewer"> | 2 | <div class="process-viewer"> |
| 3 | <div v-show="!isLoading" ref="processCanvas" class="process-canvas" style="height: 100%;" /> | 3 | <div v-show="!isLoading" ref="processCanvas" class="process-canvas" style="height: 360px;" /> |
| 4 | <!-- 自定义箭头样式,用于成功状态下流程连线箭头 --> | 4 | <!-- 自定义箭头样式,用于成功状态下流程连线箭头 --> |
| 5 | <defs ref="customSuccessDefs"> | 5 | <defs ref="customSuccessDefs"> |
| 6 | <marker id="sequenceflow-end-white-success" view-box="0 0 20 20" ref-x="11" ref-y="10" marker-width="10" | 6 | <marker id="sequenceflow-end-white-success" view-box="0 0 20 20" ref-x="11" ref-y="10" marker-width="10" |
| ... | @@ -63,21 +63,18 @@ | ... | @@ -63,21 +63,18 @@ |
| 63 | </template> | 63 | </template> |
| 64 | 64 | ||
| 65 | <script> | 65 | <script> |
| 66 | import '@/styles/package/theme/index.scss' | ||
| 66 | import BpmnViewer from 'bpmn-js/lib/Viewer' | 67 | import BpmnViewer from 'bpmn-js/lib/Viewer' |
| 67 | import MoveCanvasModule from 'diagram-js/lib/navigation/movecanvas' | 68 | import MoveCanvasModule from 'diagram-js/lib/navigation/movecanvas' |
| 68 | |||
| 69 | export default { | 69 | export default { |
| 70 | props: { | 70 | props: { |
| 71 | // eslint-disable-next-line vue/require-default-prop | ||
| 72 | xml: { | 71 | xml: { |
| 73 | type: String | 72 | type: String |
| 74 | }, | 73 | }, |
| 75 | // eslint-disable-next-line vue/require-default-prop | ||
| 76 | finishedInfo: { | 74 | finishedInfo: { |
| 77 | type: Object | 75 | type: Object |
| 78 | }, | 76 | }, |
| 79 | // 所有节点审批记录 | 77 | // 所有节点审批记录 |
| 80 | // eslint-disable-next-line vue/require-default-prop | ||
| 81 | allCommentList: { | 78 | allCommentList: { |
| 82 | type: Array | 79 | type: Array |
| 83 | } | 80 | } |
| ... | @@ -88,7 +85,7 @@ export default { | ... | @@ -88,7 +85,7 @@ export default { |
| 88 | dlgTitle: undefined, | 85 | dlgTitle: undefined, |
| 89 | defaultZoom: 1, | 86 | defaultZoom: 1, |
| 90 | // 是否正在加载流程图 | 87 | // 是否正在加载流程图 |
| 91 | isLoading: false, | 88 | isLoading: true, |
| 92 | bpmnViewer: undefined, | 89 | bpmnViewer: undefined, |
| 93 | // 已完成流程元素 | 90 | // 已完成流程元素 |
| 94 | processNodeInfo: undefined, | 91 | processNodeInfo: undefined, |
| ... | @@ -100,24 +97,24 @@ export default { | ... | @@ -100,24 +97,24 @@ export default { |
| 100 | hoverTimer: null | 97 | hoverTimer: null |
| 101 | } | 98 | } |
| 102 | }, | 99 | }, |
| 103 | watch: { | 100 | // watch: { |
| 104 | xml: { | 101 | // xml: { |
| 105 | handler (newXml) { | 102 | // handler (newXml) { |
| 106 | this.importXML(newXml) | 103 | // this.importXML(newXml) |
| 107 | }, | 104 | // }, |
| 108 | immediate: true | 105 | // immediate: true |
| 109 | }, | 106 | // }, |
| 110 | finishedInfo: { | 107 | // finishedInfo: { |
| 111 | handler (newInfo) { | 108 | // handler (newInfo) { |
| 112 | this.setProcessStatus(newInfo) | 109 | // this.setProcessStatus(newInfo) |
| 113 | }, | 110 | // }, |
| 114 | immediate: true | 111 | // immediate: true |
| 115 | } | 112 | // } |
| 116 | }, | 113 | // }, |
| 117 | created () { | 114 | created () { |
| 118 | this.$nextTick(() => { | 115 | this.$nextTick(() => { |
| 119 | this.importXML(this.xml) | 116 | this.importXML(this.xml) |
| 120 | this.setProcessStatus(this.finishedInfo) | 117 | this.setProcessStatus(this.finishedInfo); |
| 121 | }) | 118 | }) |
| 122 | }, | 119 | }, |
| 123 | destroyed () { | 120 | destroyed () { |
| ... | @@ -146,19 +143,6 @@ export default { | ... | @@ -146,19 +143,6 @@ export default { |
| 146 | }, | 143 | }, |
| 147 | getOperationTagType (type) { | 144 | getOperationTagType (type) { |
| 148 | return 'success' | 145 | return 'success' |
| 149 | // switch (type) { | ||
| 150 | // case this.SysFlowTaskOperationType.AGREE: | ||
| 151 | // case this.SysFlowTaskOperationType.MULTI_AGREE: | ||
| 152 | // return 'success'; | ||
| 153 | // case this.SysFlowTaskOperationType.REFUSE: | ||
| 154 | // case this.SysFlowTaskOperationType.PARALLEL_REFUSE: | ||
| 155 | // case this.SysFlowTaskOperationType.MULTI_REFUSE: | ||
| 156 | // return 'warning'; | ||
| 157 | // case this.SysFlowTaskOperationType.STOP: | ||
| 158 | // return 'danger' | ||
| 159 | // default: | ||
| 160 | // return 'primary'; | ||
| 161 | // } | ||
| 162 | }, | 146 | }, |
| 163 | // 流程图预览清空 | 147 | // 流程图预览清空 |
| 164 | clearViewer (a) { | 148 | clearViewer (a) { |
| ... | @@ -214,9 +198,8 @@ export default { | ... | @@ -214,9 +198,8 @@ export default { |
| 214 | this.bpmnViewer.on('element.click', ({ element }) => { | 198 | this.bpmnViewer.on('element.click', ({ element }) => { |
| 215 | this.onSelectElement(element) | 199 | this.onSelectElement(element) |
| 216 | }) | 200 | }) |
| 217 | |||
| 218 | this.isLoading = true | ||
| 219 | const c = await this.bpmnViewer.importXML(xml) | 201 | const c = await this.bpmnViewer.importXML(xml) |
| 202 | this.isLoading = true | ||
| 220 | this.addCustomDefs() | 203 | this.addCustomDefs() |
| 221 | } catch (e) { | 204 | } catch (e) { |
| 222 | // this.clearViewer('b') | 205 | // this.clearViewer('b') | ... | ... |
| ... | @@ -63,6 +63,10 @@ | ... | @@ -63,6 +63,10 @@ |
| 63 | </div> | 63 | </div> |
| 64 | </div> | 64 | </div> |
| 65 | <fqsqDialog v-model="isDialog" :djywbm="$route.query.sqywbm" :isJump="true" @updateDialog="updateDialog" /> | 65 | <fqsqDialog v-model="isDialog" :djywbm="$route.query.sqywbm" :isJump="true" @updateDialog="updateDialog" /> |
| 66 | <dialogBox title="流程图" width="60%" v-model="myValue" @closeDialog="closeDialog"> | ||
| 67 | <process-viewer :key="`designer-${loadIndex}`" style="height:500px" :xml="xmlData" :finished-info="finishedInfo" | ||
| 68 | :all-comment-list="historyTaskList" @ch="changeLoadIndex" /> | ||
| 69 | </dialogBox> | ||
| 66 | </div> | 70 | </div> |
| 67 | </template> | 71 | </template> |
| 68 | 72 | ||
| ... | @@ -79,6 +83,7 @@ import { | ... | @@ -79,6 +83,7 @@ import { |
| 79 | completeTask, | 83 | completeTask, |
| 80 | } from "@/api/fqsq.js"; | 84 | } from "@/api/fqsq.js"; |
| 81 | import { deleteBdcdy } from "@/api/ywbl.js"; | 85 | import { deleteBdcdy } from "@/api/ywbl.js"; |
| 86 | import ProcessViewer from './components/processViewer.vue' | ||
| 82 | import { getWorkFlowImage } from "@/api/jsydsyqFlow.js"; | 87 | import { getWorkFlowImage } from "@/api/jsydsyqFlow.js"; |
| 83 | import { getForm } from "./flowform.js"; | 88 | import { getForm } from "./flowform.js"; |
| 84 | import fqsqDialog from "@/views/ywbl/ywsq/slectBdc.vue"; | 89 | import fqsqDialog from "@/views/ywbl/ywsq/slectBdc.vue"; |
| ... | @@ -86,12 +91,17 @@ import { queueDjywmc } from "@/views/ywbl/ywsq/slectBdcdata.js"; | ... | @@ -86,12 +91,17 @@ import { queueDjywmc } from "@/views/ywbl/ywsq/slectBdcdata.js"; |
| 86 | export default { | 91 | export default { |
| 87 | components: { | 92 | components: { |
| 88 | fqsqDialog, | 93 | fqsqDialog, |
| 94 | ProcessViewer | ||
| 89 | }, | 95 | }, |
| 90 | data () { | 96 | data () { |
| 91 | return { | 97 | return { |
| 92 | isDialog: false, | 98 | isDialog: false, |
| 93 | // 流程图 | 99 | // 流程图 |
| 94 | imgSrc: "", | 100 | myValue: false, |
| 101 | loadIndex: 0, | ||
| 102 | xmlData: '', | ||
| 103 | finishedInfo: {}, | ||
| 104 | historyTaskList: [], | ||
| 95 | // 折叠 | 105 | // 折叠 |
| 96 | isShowdrawer: true, | 106 | isShowdrawer: true, |
| 97 | // 默认选中 | 107 | // 默认选中 |
| ... | @@ -131,6 +141,12 @@ export default { | ... | @@ -131,6 +141,12 @@ export default { |
| 131 | this.flowInitParam(); | 141 | this.flowInitParam(); |
| 132 | }, | 142 | }, |
| 133 | methods: { | 143 | methods: { |
| 144 | changeLoadIndex () { | ||
| 145 | this.loadIndex++ | ||
| 146 | }, | ||
| 147 | closeDialog () { | ||
| 148 | this.myValue = false | ||
| 149 | }, | ||
| 134 | // 更新列表 | 150 | // 更新列表 |
| 135 | updateDialog () { | 151 | updateDialog () { |
| 136 | this.loadBdcdylist(); | 152 | this.loadBdcdylist(); |
| ... | @@ -216,16 +232,34 @@ export default { | ... | @@ -216,16 +232,34 @@ export default { |
| 216 | this.isDialog = true; | 232 | this.isDialog = true; |
| 217 | break; | 233 | break; |
| 218 | case "B1": | 234 | case "B1": |
| 219 | getWorkFlowImage(this.bsmSlsq).then((res) => { | 235 | getWorkFlowImage(this.bsmSlsq, this.$route.query.bestepid).then(res => { |
| 220 | this.imgSrc = URL.createObjectURL(res); | 236 | let { result } = res |
| 221 | this.$popup({ | 237 | this.myValue = true |
| 222 | title: "流程图", | 238 | this.loadIndex++ |
| 223 | btnShow: true, | 239 | this.xmlData = result.xml |
| 224 | height: '250px', | 240 | this.finishedInfo = { |
| 225 | editItem: "workflow/components/flowChart", | 241 | finishedTaskSet: result.finishedTaskSet, |
| 226 | formData: this.imgSrc, | 242 | unfinishedTaskSet: result.unfinishedTaskSet, |
| 227 | }); | 243 | rejectedTaskSet: result.rejectedTaskSet, |
| 228 | }); | 244 | finishedSequenceFlowSet: result.finishedSequenceFlowSet |
| 245 | } | ||
| 246 | this.allCommentList = result.historyTaskList | ||
| 247 | // this.$popup({ | ||
| 248 | // title: "流程图", | ||
| 249 | // height: '500px', | ||
| 250 | // editItem: "workflow/components/processViewer", | ||
| 251 | // formData: { | ||
| 252 | // xml: result.xml, | ||
| 253 | // finishedInfo: { | ||
| 254 | // finishedTaskSet: result.finishedTaskSet, | ||
| 255 | // unfinishedTaskSet: result.unfinishedTaskSet, | ||
| 256 | // rejectedTaskSet: result.rejectedTaskSet, | ||
| 257 | // finishedSequenceFlowSet: result.finishedSequenceFlowSet | ||
| 258 | // }, | ||
| 259 | // allCommentList: result.historyTaskList | ||
| 260 | // } | ||
| 261 | // }) | ||
| 262 | }) | ||
| 229 | break; | 263 | break; |
| 230 | case "B2": //材料分屏按钮 | 264 | case "B2": //材料分屏按钮 |
| 231 | this.splitScreen = this.splitScreen ? false : true; | 265 | this.splitScreen = this.splitScreen ? false : true; | ... | ... |
-
Please register or sign in to post a comment