km-approval-process.vue 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. <template>
  2. <div :class="$style.wrapHeight">
  3. <a-row :class="$style.rowHeight">
  4. <a-col :span="5" :class="$style.treeWrap">
  5. <a-card>
  6. <a-spin :spinning="spinning" :class="$style.spin" />
  7. <a-input-search v-if="treeData.length > 0" placeholder="请输入" @change="onChange" />
  8. <a-empty v-if="empty" />
  9. <a-tree
  10. :expanded-keys="expandedKeys"
  11. :auto-expand-parent="autoExpandParent"
  12. :tree-data="treeData"
  13. :replace-fields="replaceFields"
  14. :selected-keys="selectedkey"
  15. @expand="onExpand"
  16. @select="onSelect"
  17. >
  18. <template slot="title" slot-scope="{ text, props }">
  19. <span v-if="text.indexOf(searchValue) > -1">
  20. {{ text.substr(0, text.indexOf(searchValue))
  21. }}<span :class="$style.searchColor">{{ searchValue }}</span
  22. >{{ text.substr(text.indexOf(searchValue) + searchValue.length) }}</span
  23. ><span v-else>{{ text }}</span
  24. ><a-badge
  25. v-if="props.flowId !== null && props.flowId !== undefined"
  26. :class="$style.badge"
  27. status="error"
  28. />
  29. </template>
  30. </a-tree>
  31. </a-card>
  32. </a-col>
  33. <a-col :class="$style.formHeight" :span="19">
  34. <a-card :class="$style.form">
  35. <sd-detail-form
  36. v-if="showForm"
  37. ref="docform"
  38. :record-id="fwId"
  39. page-id="km/admin/kmApprovalFlow"
  40. @saved="fwSaved"
  41. >
  42. <template v-slot="{ model }">
  43. <sd-form-item name="name"></sd-form-item>
  44. <sd-form-item name="categoryName" :input-props="{ defaultValue: categoryName }">
  45. <a-input v-model="model.categoryName" :disabled="!disabled" />
  46. </sd-form-item>
  47. <sd-form-item
  48. :hidden="true"
  49. name="categoryId"
  50. :input-props="{ defaultValue: categoryId }"
  51. />
  52. <sd-form-item name="flowField">
  53. <sd-business-type-picker
  54. v-model="model.flowField"
  55. parent-code="PROJECT_ZSGL"
  56. :single="true"
  57. />
  58. </sd-form-item>
  59. <sd-form-item name="status" />
  60. </template>
  61. </sd-detail-form>
  62. </a-card>
  63. </a-col>
  64. </a-row>
  65. </div>
  66. </template>
  67. <script>
  68. import { Message } from 'ant-design-vue'
  69. import KmKnowledageService from '../km-knowledage-service'
  70. import components from './_import-components/km-approval-process-import'
  71. const getParentKey = (key, tree) => {
  72. let parentKey
  73. for (let i = 0; i < tree.length; i++) {
  74. const node = tree[i]
  75. if (node.children) {
  76. if (node.children.some((item) => item.id === key)) {
  77. parentKey = node.id
  78. } else if (getParentKey(key, node.children)) {
  79. parentKey = getParentKey(key, node.children)
  80. }
  81. }
  82. }
  83. return parentKey
  84. }
  85. // 给树的所有对象增加scopedSlots属性
  86. const addSlot = (obj) => {
  87. for (let i = 0; i < obj.length; i++) {
  88. Object.assign(obj[i], { scopedSlots: { title: 'title' } })
  89. if (obj[i].children) {
  90. addSlot(obj[i].children)
  91. }
  92. }
  93. }
  94. export default {
  95. name: 'KmApprovalProcess',
  96. metaInfo: {
  97. title: '审批流程维护',
  98. },
  99. components,
  100. data() {
  101. return {
  102. spinning: true,
  103. empty: false,
  104. expandedKeys: [],
  105. searchValue: '',
  106. autoExpandParent: true,
  107. treeData: [],
  108. dataList: [],
  109. fwId: null,
  110. replaceFields: {
  111. title: 'text',
  112. key: 'id',
  113. },
  114. selectedkey: [], // 选中的节点
  115. categoryName: '',
  116. categoryId: '',
  117. showForm: false,
  118. disabled: false,
  119. }
  120. },
  121. created() {
  122. this.queryKnowledageTree()
  123. },
  124. methods: {
  125. // 获取树数据
  126. queryKnowledageTree(selectdId) {
  127. KmKnowledageService.getKnowledgeTree({ pageId: 'KmApprovalFlow' }).then((res) => {
  128. this.spinning = false
  129. if (res.data) {
  130. const newArr = res.data
  131. addSlot(newArr)
  132. this.treeData = newArr
  133. this.generateList(this.treeData)
  134. // 默认展开
  135. if (selectdId === null || selectdId === undefined) {
  136. this.expandedKeys = [res.data[0].id]
  137. // 没选择节点的时候默认选中根节点
  138. this.selectedkey = [res.data[0].id]
  139. if (res.data[0].props.flowId) {
  140. this.fwId = parseInt(res.data[0].props.flowId)
  141. this.showForm = true
  142. } else {
  143. this.categoryName = res.data[0].text
  144. this.categoryId = res.data[0].id
  145. this.fwId = undefined
  146. this.showForm = true
  147. }
  148. }
  149. } else {
  150. this.treeData = []
  151. this.empty = true
  152. }
  153. })
  154. },
  155. onExpand(expandedKeys) {
  156. this.expandedKeys = expandedKeys
  157. this.autoExpandParent = false
  158. },
  159. onChange(e) {
  160. const value = e.target.value
  161. const expandedKeys = this.dataList
  162. .map((item) => {
  163. if (item.title.indexOf(value) > -1) {
  164. return getParentKey(item.key, this.treeData)
  165. }
  166. return null
  167. })
  168. .filter((item, i, self) => item && self.indexOf(item) === i)
  169. Object.assign(this, {
  170. expandedKeys,
  171. searchValue: value,
  172. autoExpandParent: true,
  173. })
  174. },
  175. generateList(data) {
  176. for (let i = 0; i < data.length; i++) {
  177. const node = data[i]
  178. const key = node.id
  179. const title = node.text
  180. this.dataList.push({ key, title: title })
  181. if (node.children) {
  182. this.generateList(node.children)
  183. }
  184. }
  185. },
  186. onSelect(selectedKeys, info) {
  187. this.selectedkey = selectedKeys
  188. this.categoryName = info.node.dataRef.text
  189. this.categoryId = info.node.dataRef.id
  190. if (this.$refs.docform) {
  191. this.$refs.docform.setFieldValue('categoryName', info.node.dataRef.text)
  192. this.$refs.docform.setFieldValue('categoryId', info.node.dataRef.id)
  193. }
  194. this.fwId =
  195. info.node.dataRef.props.flowId !== null && info.node.dataRef.props.flowId !== undefined
  196. ? parseInt(info.node.dataRef.props.flowId)
  197. : undefined
  198. this.showForm = true
  199. },
  200. fwSaved() {
  201. Message.success('保存成功')
  202. this.treeData = []
  203. this.queryKnowledageTree(this.selectedkey)
  204. },
  205. },
  206. }
  207. </script>
  208. <style module lang="scss">
  209. @use '@/common/design' as *;
  210. .spin {
  211. width: 100%;
  212. line-height: 30;
  213. }
  214. .search-color {
  215. color: $orange-6;
  216. }
  217. .badge {
  218. margin-left: 5px;
  219. }
  220. .wrap-height {
  221. height: 100%;
  222. .row-height {
  223. height: 100%;
  224. .tree-wrap {
  225. height: 100%;
  226. padding-right: $padding-lg;
  227. :global(.ant-card) {
  228. height: 100%;
  229. overflow: auto;
  230. }
  231. }
  232. }
  233. }
  234. // 隐藏退出按钮
  235. .form-height {
  236. height: 100%;
  237. .form {
  238. height: 100%;
  239. overflow: auto;
  240. :global(.sd-form-btns-close) {
  241. display: none;
  242. }
  243. }
  244. }
  245. </style>