GenerateDialog.vue 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569
  1. <template>
  2. <el-dialog
  3. :visible.sync="visible"
  4. :title="element.options.title"
  5. :width="element.options.width || '50%'"
  6. :top="element.options.top || '15vh'"
  7. :close-on-click-modal='false'
  8. :show-close="element.options.showClose"
  9. :center="element.options.center"
  10. destroy-on-close
  11. :ref="`generate-dialog-${element.model}`"
  12. :custom-class="`fm-generate-dialog fm-form ${element.options && element.options.customClass ? element.options && element.options.customClass : ''}`"
  13. append-to-body
  14. @open="handleOpen"
  15. @close="handleClose"
  16. >
  17. <div v-if="visible">
  18. <template v-for="item in element.list">
  19. <generate-col-item
  20. v-if="item.type == 'grid'"
  21. :key="item.key"
  22. :model="dialogModel"
  23. :rules="rules"
  24. :element="item"
  25. :remote="remote"
  26. :blanks="blanks"
  27. :display="displayFields"
  28. :edit="edit"
  29. :remote-option="remoteOption"
  30. :platform="platform"
  31. :preview="preview"
  32. :container-key="containerKey"
  33. :data-source-value="dataSourceValue"
  34. :event-function="eventFunction"
  35. :print-read="printRead"
  36. :is-dialog="true"
  37. :dialog-name="element.model"
  38. :group="element.model"
  39. :field-node="element.model"
  40. >
  41. <template v-slot:[blank.name]="scope" v-for="blank in blanks">
  42. <slot :name="blank.name" :model="scope.model"></slot>
  43. </template>
  44. </generate-col-item>
  45. <generate-tab-item
  46. v-else-if="item.type == 'tabs'"
  47. :key="item.key"
  48. :model="dialogModel"
  49. :rules="rules"
  50. :element="item"
  51. :remote="remote"
  52. :blanks="blanks"
  53. :display="displayFields"
  54. :edit="edit"
  55. :remote-option="remoteOption"
  56. :platform="platform"
  57. :preview="preview"
  58. :container-key="containerKey"
  59. :data-source-value="dataSourceValue"
  60. :event-function="eventFunction"
  61. :print-read="printRead"
  62. :is-dialog="true"
  63. :dialog-name="element.model"
  64. :group="element.model"
  65. :field-node="element.model"
  66. >
  67. <template v-slot:[blank.name]="scope" v-for="blank in blanks">
  68. <slot :name="blank.name" :model="scope.model"></slot>
  69. </template>
  70. </generate-tab-item>
  71. <generate-collapse
  72. v-else-if="item.type == 'collapse'"
  73. :key="item.key"
  74. :model="dialogModel"
  75. :rules="rules"
  76. :element="item"
  77. :remote="remote"
  78. :blanks="blanks"
  79. :display="displayFields"
  80. :edit="edit"
  81. :remote-option="remoteOption"
  82. :platform="platform"
  83. :preview="preview"
  84. :container-key="containerKey"
  85. :data-source-value="dataSourceValue"
  86. :event-function="eventFunction"
  87. :print-read="printRead"
  88. :is-dialog="true"
  89. :dialog-name="element.model"
  90. :group="element.model"
  91. :field-node="element.model"
  92. >
  93. <template v-slot:[blank.name]="scope" v-for="blank in blanks">
  94. <slot :name="blank.name" :model="scope.model"></slot>
  95. </template>
  96. </generate-collapse>
  97. <generate-report
  98. v-else-if="item.type == 'report'"
  99. :key="item.key"
  100. :model="dialogModel"
  101. :rules="rules"
  102. :element="item"
  103. :remote="remote"
  104. :blanks="blanks"
  105. :display="displayFields"
  106. :edit="edit"
  107. :remote-option="remoteOption"
  108. :platform="platform"
  109. :preview="preview"
  110. :container-key="containerKey"
  111. :data-source-value="dataSourceValue"
  112. :event-function="eventFunction"
  113. :print-read="printRead"
  114. :is-dialog="true"
  115. :dialog-name="element.model"
  116. :group="element.model"
  117. :field-node="element.model"
  118. >
  119. <template v-slot:[blank.name]="scope" v-for="blank in blanks">
  120. <slot :name="blank.name" :model="scope.model"></slot>
  121. </template>
  122. </generate-report>
  123. <generate-card
  124. v-else-if="item.type == 'card'"
  125. :key="item.key"
  126. :model="dialogModel"
  127. :rules="rules"
  128. :element="item"
  129. :remote="remote"
  130. :blanks="blanks"
  131. :display="displayFields"
  132. :edit="edit"
  133. :remote-option="remoteOption"
  134. :platform="platform"
  135. :preview="preview"
  136. :container-key="containerKey"
  137. :data-source-value="dataSourceValue"
  138. :event-function="eventFunction"
  139. :print-read="printRead"
  140. :is-dialog="true"
  141. :dialog-name="element.model"
  142. :group="element.model"
  143. :field-node="element.model"
  144. >
  145. <template v-slot:[blank.name]="scope" v-for="blank in blanks">
  146. <slot :name="blank.name" :model="scope.model"></slot>
  147. </template>
  148. </generate-card>
  149. <generate-inline
  150. v-else-if="item.type == 'inline'"
  151. :key="item.key"
  152. :model="dialogModel"
  153. :rules="rules"
  154. :element="item"
  155. :remote="remote"
  156. :blanks="blanks"
  157. :display="displayFields"
  158. :edit="edit"
  159. :remote-option="remoteOption"
  160. :platform="platform"
  161. :preview="preview"
  162. :container-key="containerKey"
  163. :data-source-value="dataSourceValue"
  164. :event-function="eventFunction"
  165. :print-read="printRead"
  166. :is-dialog="true"
  167. :dialog-name="element.model"
  168. :group="element.model"
  169. :field-node="element.model"
  170. >
  171. <template v-slot:[blank.name]="scope" v-for="blank in blanks">
  172. <slot :name="blank.name" :model="scope.model"></slot>
  173. </template>
  174. </generate-inline>
  175. <generate-form-item
  176. v-else
  177. :key="item.key"
  178. :models="dialogModel"
  179. :rules="rules"
  180. :widget="item"
  181. :remote="remote"
  182. :blanks="blanks"
  183. :display="displayFields"
  184. :edit="edit"
  185. :remote-option="remoteOption"
  186. :platform="platform"
  187. :preview="preview"
  188. :container-key="containerKey"
  189. :data-source-value="dataSourceValue"
  190. :event-function="eventFunction"
  191. :print-read="printRead"
  192. :is-dialog="true"
  193. :dialog-name="element.model"
  194. :group="element.model"
  195. :field-node="element.model"
  196. >
  197. <template v-slot:[blank.name]="scope" v-for="blank in blanks">
  198. <slot :name="blank.name" :model="scope.model"></slot>
  199. </template>
  200. </generate-form-item>
  201. </template>
  202. </div>
  203. <template #footer v-if="element.options.showCancel || element.options.showOk">
  204. <div>
  205. <el-button v-if="element.options.showCancel" @click="handleCancel">{{element.options.cancelText}}</el-button>
  206. <el-button type="primary" v-if="element.options.showOk" :loading="element.options.confirmLoading" @click="handleConfirm">{{element.options.okText}}</el-button>
  207. </div>
  208. </template>
  209. </el-dialog>
  210. </template>
  211. <script>
  212. import GenerateFormItem from './GenerateFormItem.vue'
  213. import GenerateColItem from './GenerateColItem.vue'
  214. import GenerateTabItem from './GenerateTabItem.vue'
  215. import GenerateReport from './GenerateReport.vue'
  216. import GenerateInline from './GenerateInline.vue'
  217. import GenerateCollapse from './GenerateCollapse.vue'
  218. import GenerateCard from './GenerateCard.vue'
  219. import { updateClassName } from '../util/reuse-methods'
  220. import _ from 'lodash'
  221. export default {
  222. name: 'generate-dialog',
  223. components: {
  224. GenerateColItem,
  225. GenerateFormItem,
  226. GenerateInline,
  227. GenerateReport,
  228. GenerateTabItem,
  229. GenerateCollapse,
  230. GenerateCard
  231. },
  232. props: ['models', 'rules', 'element', 'remote', 'blanks', 'edit', 'remoteOption', 'platform', 'preview', 'containerKey', 'dataSourceValue', 'eventFunction', 'printRead', 'componentInstance', 'group', 'fieldNode'],
  233. data () {
  234. return {
  235. visible: this.element.options.visible,
  236. displayFields: {},
  237. dialogModel: this.models[this.element.model] || {},
  238. dialogDisabled: {}
  239. }
  240. },
  241. inject: ['generateComponentInstance', 'deleteComponentInstance', 'getFormComponent', 'onFormHide', 'onFormDisplay'],
  242. created () {
  243. this._generateModel(this.element.list)
  244. },
  245. mounted () {
  246. this.generateComponentInstance && this.generateComponentInstance(this.element.model, this.$refs[`generate-dialog-${this.element.model}`].$parent)
  247. },
  248. beforeDestroy () {
  249. this.deleteComponentInstance && this.deleteComponentInstance(this.element.model)
  250. },
  251. provide () {
  252. return {
  253. 'setDialogData': this.setDialogData
  254. }
  255. },
  256. methods: {
  257. setDialogData (value, field) {
  258. this.$set(this.dialogModel, field, value)
  259. },
  260. _generateModel (genList) {
  261. for (let i = 0; i < genList.length; i++) {
  262. if (genList[i].type == 'grid') {
  263. this.displayFields[genList[i].model] = !genList[i].options.hidden
  264. genList[i].columns.forEach(item => {
  265. this._generateModel(item.list)
  266. })
  267. } else if (genList[i].type === 'tabs') {
  268. genList[i].tabs.forEach(item => {
  269. this._generateModel(item.list)
  270. })
  271. this.displayFields[genList[i].model] = !genList[i].options.hidden
  272. } else if (genList[i].type === 'collapse') {
  273. genList[i].tabs.forEach(item => {
  274. this._generateModel(item.list)
  275. })
  276. this.displayFields[genList[i].model] = !genList[i].options.hidden
  277. } else if (genList[i].type === 'report') {
  278. genList[i].rows.forEach(row => {
  279. row.columns.forEach(column => {
  280. this._generateModel(column.list)
  281. })
  282. })
  283. this.displayFields[genList[i].model] = !genList[i].options.hidden
  284. } else if (genList[i].type === 'inline') {
  285. this._generateModel(genList[i].list)
  286. this.displayFields[genList[i].model] = !genList[i].options.hidden
  287. } else if (genList[i].type === 'card') {
  288. this._generateModel(genList[i].list)
  289. this.displayFields[genList[i].model] = !genList[i].options.hidden
  290. } else {
  291. if (genList[i].type == 'blank') {
  292. this.$set(this.dialogModel, genList[i].model, genList[i].options.defaultType === 'String' ? '' : (genList[i].options.defaultType === 'Object' ? {} : []))
  293. } else {
  294. this.$set(this.dialogModel, genList[i].model, this.models[this.element.model][genList[i].model] || _.cloneDeep(genList[i].options.defaultValue))
  295. }
  296. this.displayFields[genList[i].model] = !genList[i].options.hidden
  297. this.dialogDisabled[genList[i].model] = !genList[i].options.disabled
  298. }
  299. }
  300. },
  301. open () {
  302. this.visible = true
  303. },
  304. close () {
  305. this.visible = false
  306. },
  307. hide (fields) {
  308. if (typeof fields === 'string') {
  309. fields = [fields]
  310. }
  311. fields.forEach(field => {
  312. this.onFormHide(`${this.fieldNode}.${field}`)
  313. })
  314. },
  315. display (fields) {
  316. if (typeof fields === 'string') {
  317. fields = [fields]
  318. }
  319. fields.forEach(field => {
  320. this.onFormDisplay(`${this.fieldNode}.${field}`)
  321. })
  322. },
  323. disabled (fields, disabled) {
  324. if (typeof fields === 'string') {
  325. fields = [fields]
  326. }
  327. this._setDisabled(this.element.list, fields, disabled)
  328. },
  329. validate () {
  330. return new Promise((resolve, reject) => {
  331. let realFields = this._getAllRuleFields()
  332. Promise.all(realFields.map(fieldItem => {
  333. return new Promise((resolve2) => {
  334. this.getFormComponent().validateField(fieldItem, (error) => {
  335. resolve2(error)
  336. })
  337. })
  338. })).then((values) => {
  339. console.log('promise all success', values)
  340. if (values.findIndex(v => v) >= 0) {
  341. reject()
  342. } else {
  343. resolve()
  344. }
  345. })
  346. })
  347. },
  348. clearValidate () {
  349. let realFields = this._getAllRuleFields()
  350. this.getFormComponent()?.clearValidate(realFields)
  351. },
  352. handleOpen () {
  353. if (this.element && this.element.events && this.element.events.onOpen) {
  354. let funcKey = this.element.events.onOpen
  355. this.$nextTick(() => {
  356. this.eventFunction[funcKey]({
  357. field: this.element.model,
  358. currentRef: this
  359. })
  360. })
  361. }
  362. },
  363. handleClose () {
  364. if (this.element && this.element.events && this.element.events.onClose) {
  365. let funcKey = this.element.events.onClose
  366. this.eventFunction[funcKey]({
  367. field: this.element.model,
  368. currentRef: this
  369. })
  370. }
  371. },
  372. handleCancel () {
  373. if (this.element && this.element.events && this.element.events.onCancel) {
  374. let funcKey = this.element.events.onCancel
  375. this.eventFunction[funcKey]({
  376. field: this.element.model,
  377. currentRef: this
  378. })
  379. }
  380. },
  381. handleConfirm () {
  382. if (this.element && this.element.events && this.element.events.onConfirm) {
  383. let funcKey = this.element.events.onConfirm
  384. this.eventFunction[funcKey]({
  385. field: this.element.model,
  386. currentRef: this
  387. })
  388. }
  389. },
  390. confirmLoading (status) {
  391. this.element.options.confirmLoading = status
  392. },
  393. setOptions (fields, options) {
  394. if (typeof fields === 'string') {
  395. fields = [fields]
  396. }
  397. this._setOptions(this.element.list, fields, options)
  398. },
  399. setData (value) {
  400. return new Promise((resolve) => {
  401. this.$nextTick(() => {
  402. Object.keys(value).forEach(item => {
  403. this.$set(this.dialogModel, item, value[item])
  404. })
  405. resolve()
  406. })
  407. })
  408. },
  409. getValues () {
  410. return this.dialogModel
  411. },
  412. getValue (fieldName) {
  413. return this.dialogModel[fieldName]
  414. },
  415. addClassName (fields, className) {
  416. if (typeof fields === 'string') {
  417. fields = [fields]
  418. }
  419. fields.forEach(item => {
  420. updateClassName(this.element.list, item.split('.'), className, 'add')
  421. })
  422. },
  423. removeClassName (fields, className) {
  424. if (typeof fields === 'string') {
  425. fields = [fields]
  426. }
  427. fields.forEach(item => {
  428. updateClassName(this.element.list, item.split('.'), className, 'remove')
  429. })
  430. },
  431. _setDisabled (genList, fields, disabled) {
  432. for (let i = 0; i < genList.length; i++) {
  433. if (genList[i].type === 'grid') {
  434. genList[i].columns.forEach(item => {
  435. this._setDisabled(item.list, fields, disabled)
  436. })
  437. } else if (genList[i].type === 'tabs') {
  438. genList[i].tabs.forEach(item => {
  439. this._setDisabled(item.list, fields, disabled)
  440. })
  441. } else if (genList[i].type === 'collapse') {
  442. genList[i].tabs.forEach(item => {
  443. this._setDisabled(item.list, fields, disabled)
  444. })
  445. } else if (genList[i].type === 'report') {
  446. genList[i].rows.forEach(row => {
  447. row.columns.forEach(column => {
  448. this._setDisabled(column.list, fields, disabled)
  449. })
  450. })
  451. } else if (genList[i].type === 'inline') {
  452. this._setDisabled(genList[i].list, fields, disabled)
  453. } else if (genList[i].type === 'card') {
  454. this._setDisabled(genList[i].list, fields, disabled)
  455. } else {
  456. if (fields.indexOf(genList[i].model) >= 0) {
  457. genList[i].options.disabled = disabled
  458. }
  459. }
  460. }
  461. },
  462. _setOptions (genList, fields, opts) {
  463. for (let i = 0; i < genList.length; i++) {
  464. if (genList[i].type === 'grid') {
  465. genList[i].columns.forEach(item => {
  466. this._setOptions(item.list, fields, opts)
  467. })
  468. } else if (genList[i].type === 'tabs') {
  469. genList[i].tabs.forEach(item => {
  470. this._setOptions(item.list, fields, opts)
  471. })
  472. } else if (genList[i].type === 'collapse') {
  473. genList[i].tabs.forEach(item => {
  474. this._setOptions(item.list, fields, opts)
  475. })
  476. } else if (genList[i].type === 'report') {
  477. genList[i].rows.forEach(row => {
  478. row.columns.forEach(column => {
  479. this._setOptions(column.list, fields, opts)
  480. })
  481. })
  482. } else if (genList[i].type === 'inline') {
  483. this._setOptions(genList[i].list, fields, opts)
  484. } else if (genList[i].type === 'card') {
  485. this._setOptions(genList[i].list, fields, opts)
  486. }
  487. if (fields.indexOf(genList[i].model) >= 0) {
  488. Object.keys(opts).forEach(key => {
  489. genList[i].options[key] = opts[key]
  490. })
  491. }
  492. }
  493. },
  494. _getAllRuleFields () {
  495. let realFields = []
  496. Object.keys(this.dialogModel).forEach((v) => {
  497. if (Array.isArray(this.dialogModel[v])) {
  498. const currentArray = this.dialogModel[v]
  499. currentArray.forEach((o, i) => {
  500. Object.keys(o).forEach((key) => {
  501. this.componentInstance[`${this.element.model}.${v}.${i}.${key}`] && realFields.push(`${this.element.model}.${v}.${i}.${key}`)
  502. })
  503. })
  504. } else {
  505. this.componentInstance[`${this.element.model}.${v}`] && realFields.push(`${this.element.model}.${v}`)
  506. }
  507. })
  508. return realFields
  509. }
  510. },
  511. watch: {
  512. dialogModel: {
  513. deep: true,
  514. handler (val) {
  515. this.$emit('update:models', {
  516. ...this.models,
  517. [this.element.model]: val
  518. })
  519. }
  520. },
  521. models: {
  522. deep: true,
  523. handler (val) {
  524. this.dialogModel = this.models[this.element.model]
  525. }
  526. },
  527. }
  528. }
  529. </script>
  530. <style lang="scss">
  531. .fm-generate-dialog{
  532. .el-dialog__footer{
  533. text-align: right;
  534. }
  535. &.el-dialog--center{
  536. .el-dialog__footer{
  537. text-align: center;
  538. }
  539. }
  540. }
  541. </style>