MaterialCategoryModal.vue 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. <template>
  2. <div ref="container">
  3. <a-modal
  4. :title="title"
  5. :width="800"
  6. :ok="false"
  7. :visible="visible"
  8. :confirmLoading="confirmLoading"
  9. :okButtonProps="{ props: { disabled: disableSubmit } }"
  10. :getContainer="() => $refs.container"
  11. :maskStyle="{ top: '93px', left: '154px' }"
  12. :wrapClassName="wrapClassNameInfo()"
  13. :mask="isDesktop()"
  14. :maskClosable="false"
  15. @ok="handleOk"
  16. @cancel="handleCancel"
  17. style="top: 100px; height: 50%"
  18. cancelText="取消"
  19. okText="保存"
  20. >
  21. <a-spin :spinning="confirmLoading">
  22. <a-form :form="form">
  23. <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="名称">
  24. <a-input placeholder="请输入名称" v-decorator="['name', validatorRules.name]" />
  25. </a-form-item>
  26. <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="编号">
  27. <a-input disabled placeholder="请输入编号" v-decorator="['serialNo', validatorRules.serialNo]" />
  28. </a-form-item>
  29. <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="上级目录">
  30. <a-tree-select
  31. style="width: 100%"
  32. :dropdownStyle="{ maxHeight: '200px', overflow: 'auto' }"
  33. allow-clear
  34. :treeDefaultExpandAll="true"
  35. :treeData="categoryTree"
  36. v-decorator="['parentId']"
  37. placeholder="请选择上级目录"
  38. >
  39. </a-tree-select>
  40. </a-form-item>
  41. <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="排序">
  42. <a-input v-decorator="['sort']" />
  43. </a-form-item>
  44. <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="备注">
  45. <a-textarea placeholder="请输入备注" :rows="2" v-decorator.trim="['remark']" />
  46. </a-form-item>
  47. </a-form>
  48. </a-spin>
  49. </a-modal>
  50. </div>
  51. </template>
  52. <script>
  53. import { httpAction } from '@/api/manage'
  54. import { mixinDevice } from '@/utils/mixin'
  55. import { queryMaterialCategoryTreeList, checkMaterialCategory } from '@/api/api'
  56. import pick from 'lodash.pick'
  57. import ATextarea from 'ant-design-vue/es/input/TextArea'
  58. export default {
  59. name: 'MaterialCategoryModal',
  60. mixins: [mixinDevice],
  61. components: { ATextarea },
  62. data() {
  63. return {
  64. categoryTree: [],
  65. orgTypeData: [],
  66. phoneWarning: '',
  67. departName: '',
  68. title: '操作',
  69. visible: false,
  70. disableSubmit: false,
  71. model: {},
  72. menuhidden: false,
  73. menuusing: true,
  74. labelCol: {
  75. xs: { span: 24 },
  76. sm: { span: 5 },
  77. },
  78. wrapperCol: {
  79. xs: { span: 24 },
  80. sm: { span: 16 },
  81. },
  82. confirmLoading: false,
  83. form: this.$form.createForm(this),
  84. validatorRules: {
  85. name: {
  86. rules: [{ required: true, message: '请输入名称!' }, { validator: this.validateName }],
  87. },
  88. // serialNo: { rules: [{ required: true, message: '请输入编号!' }] },
  89. },
  90. url: {
  91. add: '/materialCategory/add',
  92. },
  93. }
  94. },
  95. created() {},
  96. methods: {
  97. loadTreeData() {
  98. var that = this
  99. let params = {}
  100. params.id = ''
  101. queryMaterialCategoryTreeList(params).then((res) => {
  102. if (res) {
  103. that.categoryTree = []
  104. for (let i = 0; i < res.length; i++) {
  105. let temp = res[i]
  106. that.categoryTree.push(temp)
  107. }
  108. }
  109. })
  110. },
  111. add() {
  112. this.edit()
  113. },
  114. edit(record) {
  115. this.form.resetFields()
  116. this.model = Object.assign({}, {})
  117. this.visible = true
  118. this.loadTreeData()
  119. this.$nextTick(() => {
  120. this.form.setFieldsValue(pick(record, 'name', 'serialNo', 'parentId', 'sort', 'remark'))
  121. })
  122. },
  123. close() {
  124. this.$emit('close')
  125. this.disableSubmit = false
  126. this.visible = false
  127. },
  128. handleOk() {
  129. const that = this
  130. // 触发表单验证
  131. this.form.validateFields((err, values) => {
  132. if (!err) {
  133. that.confirmLoading = true
  134. let formData = Object.assign(this.model, values)
  135. //时间格式化
  136. console.log(formData)
  137. httpAction(this.url.add, formData, 'post')
  138. .then((res) => {
  139. if (res.code == 200) {
  140. that.$message.success(res.data.message)
  141. that.loadTreeData()
  142. that.$emit('ok')
  143. } else {
  144. that.$message.warning(res.data.message)
  145. }
  146. })
  147. .finally(() => {
  148. that.confirmLoading = false
  149. that.close()
  150. })
  151. }
  152. })
  153. },
  154. handleCancel() {
  155. this.close()
  156. },
  157. validateName(rule, value, callback) {
  158. let params = {
  159. name: value,
  160. id: this.model.id ? this.model.id : 0,
  161. }
  162. checkMaterialCategory(params).then((res) => {
  163. if (res && res.code === 200) {
  164. if (!res.data.status) {
  165. callback()
  166. } else {
  167. callback('名称已经存在')
  168. }
  169. } else {
  170. callback(res.data)
  171. }
  172. })
  173. },
  174. },
  175. }
  176. </script>
  177. <style scoped></style>