pengyh 1 anno fa
parent
commit
0ba36d3ff7

+ 0 - 0
src/api/auxiliaryFittings/attachmentProfile.js


+ 46 - 0
src/api/auxiliaryFittings/supplier.js

@@ -0,0 +1,46 @@
+import request, { postBlob, getBlob, handleImport } from '@/utils/request'
+
+// 获取列表
+export function listPageV2(data) {
+  return request({
+    url: `/vender/list?moduleId=${data.moduleId}`,
+    method: 'post',
+    data
+  })
+}
+
+//导出
+export function pageExport(data, name) {
+  return postBlob({
+    url: '/vender/list/export',
+    data,
+    name
+  })
+}
+
+// 新增
+export function add(data) {
+  return request({
+    url: `/vender/add`,
+    method: 'post',
+    data
+  })
+}
+
+// 编辑
+export function edit(data) {
+  return request({
+    url: `/vender/edit`,
+    method: 'post',
+    data
+  })
+}
+
+// 详情
+export function getDetail(params) {
+  return request({
+    url: `/vender/detail`,
+    method: 'post',
+    params
+  })
+}

+ 5 - 4
src/components/file-upload/index.vue

@@ -59,10 +59,10 @@ export default {
       type: String,
       default: 'view'
     },
-    uid: {
-      type: String,
-      default: 'uidImgfile'
-    },
+    // uid: {
+    //   type: String,
+    //   default: 'uidImgfile'
+    // },
     // 最大上传数量
     limit: {
       type: Number,
@@ -112,6 +112,7 @@ export default {
   },
   data() {
     return {
+	  uid: "id_" + new Date().getTime(),
       myHeaders: { 'x-token': getToken() },
       baseURL: process.env.VUE_APP_BASE_API,
       imageURL: this.$imageUrl,

+ 38 - 0
src/components/template/rules_verify.js

@@ -27,3 +27,41 @@ export const mobile = [{
   trigger: 'blur'
 }]
 
+// 邮箱校验非必填
+export const email = [{
+  validator: (rule, value, callback) => {
+	var result = /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/.test(value);
+    if (value && !result) {
+      callback(new Error('请输入正确的邮箱'))
+    } else {
+      callback()
+    }
+  },
+  trigger: 'blur'
+}]
+
+// 身份证号码校验非必填
+export const idcard = [{
+  validator: (rule, value, callback) => {
+	var result = /^\d{6}(18|19|20)\d{2}(0\d|10|11|12)([0-2]\d|30|31)\d{3}[\dXx]$/g.test(value);
+    if (value && !result) {
+      callback(new Error('请输入正确的身份证号'))
+    } else {
+      callback()
+    }
+  },
+  trigger: 'blur'
+}]
+
+// 网址校验非必填
+export const httpUrl = [{
+  validator: (rule, value, callback) => {
+	var result = /^(?:http(s)?:\/\/)?[\w.-]+(?:\.[\w\.-]+)+[\w\-\._~:/?#[\]@!\$&'\*\+,;=.]+$/.test(value);
+    if (value && !result) {
+      callback(new Error('请输入正确的网址'))
+    } else {
+      callback()
+    }
+  },
+  trigger: 'blur'
+}]

+ 316 - 0
src/views/auxiliaryFittings/attachmentProfile/index.vue

@@ -0,0 +1,316 @@
+<template>
+	<template-page ref="pageRef" :get-list="getList" :table-attributes="tableAttributes" :table-events="tableEvents" :operationColumnWidth="200"
+	  :options-evens-group="optionsEvensGroup" :moreParameters="moreParameters" :column-parsing="columnParsing"
+	  :operation="operation" :exportList="exportList">
+	  <div slot="moreSearch">
+	    <el-radio-group v-model="examineStatus" size="mini" @change="changeType">
+	    	<el-radio-button label="">全部</el-radio-button>
+	    	<el-radio-button label="WAIT">待审核</el-radio-button>
+	    	<el-radio-button label="OK">审核通过</el-radio-button>
+	    	<el-radio-button label="FAIL">驳回</el-radio-button>
+	    </el-radio-group>
+	    <br><br>
+	  </div>
+	  <el-dialog title="" width="800px" custom-class="diy-dialog" append-to-body :modal="true" :visible.sync="formDialog"
+	    :show-close="true" :close-on-click-modal="false" :modal-append-to-body="false" :before-close="formCancel">
+	    <zj-form-container ref="formRef" :form-data="formData" :styleSwitch="false">
+	      <zj-form-module :title="formDialogTitles[formDialogType]" label-width="100px" :showPackUp="false"
+	        :form-data="formData" :form-items="formItems">
+	      </zj-form-module>
+	    </zj-form-container>
+	    <div slot="footer" class="dialog-footer">
+			<el-button v-if="formData.examineStatus == 'WAIT'" size="mini" type="primary" @click="audit('OK')">审核通过</el-button>
+			<el-button v-if="formData.examineStatus == 'WAIT'" size="mini" type="danger" @click="audit('FAIL')">审核驳回</el-button>
+			<el-button size="mini" @click="formCancel">取 消</el-button>
+	    </div>
+	  </el-dialog>
+	</template-page>
+</template>
+
+<script>
+import TemplatePage from '@/components/template/template-page-1.vue'
+import import_mixin from '@/components/template/import_mixin.js'
+import { required, mobileRequired, mobile } from '@/components/template/rules_verify.js'
+import { listPageV2,pageExport, getDetail, add, edit } from "@/api/auxiliaryFittings/supplier";
+export default {
+  components: { TemplatePage },
+  mixins: [import_mixin],
+  data() {
+    return {
+      // 事件组合
+      optionsEvensGroup: [],
+      // 表格属性
+      tableAttributes: {
+        // 启用勾选列
+        selectColumn: false
+      },
+      // 表格事件
+      tableEvents: {
+        'selection-change': this.selectionChange
+      },
+      // 勾选选中行
+      recordSelected: [],
+      /** 表单变量 */
+      formDialogType: 0,
+      formDialogTitles: ["审核", "详情"],
+      formDialog: false,
+      formData: {
+		type: '工程师',
+		examineRemark: ''
+      },
+	  examineStatus: ''
+    }
+  },
+  computed: {
+    // 更多参数
+    moreParameters() {
+      return []
+    },
+    formItems() {
+      return [{
+        md: 12,
+        isShow: true,
+        name: 'el-select',
+				options: [{label: '待审核', value: 'WAIT'},{label: '驳回', value: 'FAIL'},{label: '通过', value: 'OK'}],
+        attributes: { placeholder: '请输入', disabled: true },
+        formItemAttributes: {
+          label: '审核状态',
+          prop: 'examineStatus',
+          rules: []
+        },
+      }, {
+        md: 12,
+        isShow: true,
+        name: 'el-input',
+        attributes: { disabled: true },
+        formItemAttributes: {
+          label: '用户类型',
+          prop: 'type',
+          rules: []
+        }
+      }, {
+        md: 12,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入', disabled: true },
+        formItemAttributes: {
+          label: '用户名称',
+          prop: 'nickName',
+          rules: []
+        }
+      }, {
+        md: 12,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入', disabled: true },
+        formItemAttributes: {
+          label: '联系电话',
+          prop: 'mobile',
+          rules: []
+        }
+      }, {
+        md: 12,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入', disabled: true },
+        formItemAttributes: {
+          label: '身份证号码',
+          prop: 'idCard',
+          rules: []
+        }
+      }, {
+        md: 12,
+        isShow: true,
+        name: 'slot-component',
+        attributes: { },
+        formItemAttributes: {
+          label: '身份证',
+          prop: 'idCardImg',
+          rules: []
+        },
+				render: (h, { props, onInput }) => {
+					var { value } = props
+					return (
+						<el-image src={this.formData.idCardImg} style='width: 120px;height:120px' preview-src-list={[this.formData.idCardImg]} fit="fit"></el-image>
+					)
+				}
+      }, {
+        md: 12,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入', disabled: true },
+        formItemAttributes: {
+          label: '所属商户',
+          prop: 'companyName',
+          rules: []
+        }
+      }, {
+        md: 12,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入', disabled: true },
+        formItemAttributes: {
+          label: '入驻网点',
+          prop: 'websitName',
+          rules: []
+        }
+      }, {
+        md: 24,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入',type: "textarea", disabled: this.formData.examineStatus == 'WAIT' ? false:true },
+        formItemAttributes: {
+          label: '备注',
+          prop: 'examineRemark',
+          rules: []
+        }
+      }]
+    }
+  },
+  methods: {
+	// 切换状态
+	changeType(val) {
+	  this.$refs.pageRef.refreshList()
+	},
+    // 列表请求函数
+	getList(p) {
+	  try {
+	    var pam = JSON.parse(JSON.stringify(p))
+	    if (this.examineStatus) {
+	      pam.params.push({ "param": "b.examine_status", "compare": "=", "value": this.examineStatus })
+	    }
+	    return listPageV2(pam)
+	  } catch (error) {
+	    console.log(error)
+	  }
+	},
+    // 列表导出函数
+    exportList: pageExport,
+    // 表格列解析渲染数据更改
+    columnParsing(item, defaultData) {
+		if (item.jname === 'idCardImg') {
+		        defaultData.render = (h, { row, index, column }) => {
+		          return (
+		            <div style="padding:0 6px;cursor: pointer;">
+		              {row.idCardImg ? row.idCardImg.split(",").map(url => <el-image src={url} preview-src-list={[url]} fit="fit" style="width:80px;height:80px;" />) : null}
+		            </div>
+		          )
+		        }
+		      }
+      return defaultData
+    },
+    // 监听勾选变化
+    selectionChange(data) {
+      this.recordSelected = data
+    },
+    // 表格操作列
+    operation(h, { row, index, column }) {
+      return (
+        <div class='operation-btns'>
+          {row.examineStatus == 'WAIT' ? <el-button type="text" onClick={() => {
+            getMemberDetail({ id: row.id }).then(res => {
+              Object.assign(this.formData, res.data)
+              this.formDialogType = 0
+              this.openForm()
+            })
+          }}>审核</el-button> : null}
+          <el-button type="text" onClick={() => {
+            getMemberDetail({ id: row.id }).then(res => {
+              Object.assign(this.formData, res.data)
+              this.formDialogType = 1
+              this.openForm()
+            })
+          }}>详情</el-button>
+		  <el-button type="text" onClick={() => {
+			this.$confirm('请确认是否设为分销员, 是否继续?', '提示', {
+				confirmButtonText: '确定',
+				cancelButtonText: '取消',
+				type: 'warning'
+			}).then(() => {
+				memberInner({
+					type: 'SERVICE',
+					userIds: row.userId
+				}).then(res => {
+					if (res.code == 200) {
+						this.$message({ type: 'success', message: '设为分销员成功!' })
+						this.$refs.pageRef.refreshList()
+					} else {
+						this.$message.error(res.msg);
+					}
+				})
+			});
+		  }}>设为分销员</el-button>
+		  <el-button type="text" onClick={() => {
+			this.$confirm('请确认是否设为客户, 是否继续?', '提示', {
+				confirmButtonText: '确定',
+				cancelButtonText: '取消',
+				type: 'warning'
+			}).then(() => {
+				memberInner({
+					type: 'GENERAL',
+					userIds: row.userId
+				}).then(res => {
+					if (res.code == 200) {
+						this.$message({ type: 'success', message: '设为客户成功!' })
+						this.$refs.pageRef.refreshList()
+					} else {
+						this.$message.error(res.msg);
+					}
+				})
+			});
+		  }}>设为客户</el-button>
+        </div>
+      )
+    },
+    addData() {
+      this.formDialogType = 0
+      this.openForm()
+    },
+    openForm() {
+      this.formDialog = true;
+    },
+    formCancel() {
+      this.$refs.formRef.$refs.inlineForm.clearValidate()
+      this.$data.formData = this.$options.data().formData
+      this.formDialog = false
+    },
+	audit(examineStatusEnum){
+		memberAudit({ 
+			examineStatusEnum,
+			examineRemark: this.formData.examineRemark,
+			id: this.formData.id
+		}).then(res => {
+			this.$message({ type: 'success', message: '审核成功!' })
+			this.formCancel()
+			this.$refs.pageRef.refreshList()
+		})
+	},
+	memberInner(type){
+		memberInner({
+			type,
+			userIds: this.formData.userId
+		}).then(res => {
+			this.$message({ type: 'success', message: '设置成功!' })
+			this.$refs.pageRef.refreshList()
+		})
+	},
+    formConfirm() {
+      this.$refs.formRef.validate((valid, invalidFields, errLabels) => {
+        if (valid) {
+          ([memberAudit][this.formDialogType])(this.formData).then(res => {
+            this.$message({ type: 'success', message: `${this.formDialogTitles[this.formDialogType]}成功!` })
+            this.formCancel()
+            this.$refs.pageRef.refreshList()
+          })
+        }
+      })
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+	.tab{
+		padding: 20px 20px 0 20px;
+	}
+</style>

+ 395 - 0
src/views/auxiliaryFittings/supplier/index.vue

@@ -0,0 +1,395 @@
+<template>
+	<template-page ref="pageRef" :get-list="getList" :table-attributes="tableAttributes" :table-events="tableEvents"
+	  :options-evens-group="optionsEvensGroup" :moreParameters="moreParameters" :column-parsing="columnParsing"
+	  :operation="operation" :exportList="exportList">
+	  <el-dialog title="" width="1200px" custom-class="diy-dialog" append-to-body :modal="true" :visible.sync="formDialog"
+	    :show-close="true" :close-on-click-modal="false" :modal-append-to-body="false" :before-close="formCancel">
+	    <zj-form-container ref="formRef" :form-data="formData" :styleSwitch="false">
+	      <zj-form-module :title="formDialogTitles[formDialogType]" label-width="100px" :showPackUp="false"
+	        :form-data="formData" :form-items="formItems">
+	      </zj-form-module>
+	    </zj-form-container>
+	    <div slot="footer" class="dialog-footer">
+			<el-button size="mini" @click="formCancel">取 消</el-button>
+			<el-button size="mini" v-if="formDialogType !== 2" type="primary" @click="formConfirm()">确定</el-button>
+	    </div>
+	  </el-dialog>
+	</template-page>
+</template>
+
+<script>
+import TemplatePage from '@/components/template/template-page-1.vue'
+import import_mixin from '@/components/template/import_mixin.js'
+import ImageUpload from '@/components/file-upload'
+import { required, mobileRequired, mobile, httpUrl, email } from '@/components/template/rules_verify.js'
+import { listPageV2,pageExport, getDetail, add, edit } from "@/api/auxiliaryFittings/supplier";
+export default {
+  components: { TemplatePage, ImageUpload },
+  mixins: [import_mixin],
+  data() {
+    return {
+      // 事件组合
+      optionsEvensGroup: [
+	  	[
+	  		[
+	  			{
+	  				name: '新建',
+	  				click: this.addData
+	  			}
+	  		],
+	  	],
+	  ],
+      // 表格属性
+      tableAttributes: {
+        // 启用勾选列
+        selectColumn: false
+      },
+      // 表格事件
+      tableEvents: {
+        'selection-change': this.selectionChange
+      },
+      // 勾选选中行
+      recordSelected: [],
+      /** 表单变量 */
+      formDialogType: 0,
+      formDialogTitles: ["新增","编辑", "详情"],
+      formDialog: false,
+      formData: {
+		companyName: JSON.parse(localStorage.getItem('greemall_user')).companyName,
+		venderName: '',
+		linkName: '',
+		linkTel: '',
+		address: '',
+		zipNo: '',
+		email: '',
+		www: '',
+		telNO: '',
+		corporation: '',
+		faxNo: '',
+		licenseId: '',
+		khBank: '',
+		bankRow: '',
+		accNo: '',
+		remark: '',
+		status: 'ON',
+		venderType: 'M',
+		imageUrl: []
+      }
+    }
+  },
+  computed: {
+    // 更多参数
+    moreParameters() {
+      return []
+    },
+    formItems() {
+      return [{
+        md: 12,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入', disabled: true },
+        formItemAttributes: {
+          label: '所属商户',
+          prop: 'companyName',
+          rules: [...required]
+        },
+      }, {
+        md: 12,
+        isShow: true,
+        name: 'slot-component',
+        attributes: { },
+        formItemAttributes: {
+          label: '状态',
+          prop: 'status',
+          rules: [...required]
+        },
+		render: (h, { props, onInput }) => {
+			var { value } = props
+			return (
+				<el-radio-group v-model={this.formData.status}>
+				    <el-radio label="ON">启用</el-radio>
+				    <el-radio label="OFF">禁用</el-radio>
+				</el-radio-group>
+			)
+		}
+      }, {
+        md: 12,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入供应商名称', },
+        formItemAttributes: {
+          label: '供应商名称',
+          prop: 'venderName',
+          rules: [...required]
+        }
+      }, {
+        md: 6,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入联系人' },
+        formItemAttributes: {
+          label: '联系人',
+          prop: 'linkName',
+          rules: [...required]
+        }
+      }, {
+        md: 6,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入联系电话', maxlength: 11 },
+        formItemAttributes: {
+          label: '联系电话',
+          prop: 'linkTel',
+          rules: [...required,...mobile]
+        }
+      }, {
+        md: 12,
+        isShow: true,
+        name: 'slot-component',
+        attributes: { },
+        formItemAttributes: {
+          label: '供应类型',
+          prop: 'venderType',
+          rules: [...required]
+        },
+		render: (h, { props, onInput }) => {
+			var { value } = props
+			return (
+				<el-radio-group v-model={this.formData.venderType}>
+				    <el-radio label="M">辅材</el-radio>
+				    <el-radio label="P">配件</el-radio>
+					<el-radio label="A">辅材和配件</el-radio>
+				</el-radio-group>
+			)
+		}
+      }, {
+        md: 12,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入地址' },
+        formItemAttributes: {
+          label: '地址',
+          prop: 'address',
+          rules: []
+        }
+      }, {
+        md: 6,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入邮编' },
+        formItemAttributes: {
+          label: '邮编',
+          prop: 'zipNo',
+          rules: []
+        }
+      }, {
+        md: 6,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入网址' },
+        formItemAttributes: {
+          label: '网址',
+          prop: 'www',
+          rules: [...httpUrl]
+        }
+      }, {
+        md: 6,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入电子邮箱' },
+        formItemAttributes: {
+          label: '电子邮箱',
+          prop: 'email',
+          rules: [...email]
+        }
+      }, {
+        md: 6,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入固定电话' },
+        formItemAttributes: {
+          label: '固定电话',
+          prop: 'telNo',
+          rules: []
+        }
+      }, {
+        md: 6,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入传真' },
+        formItemAttributes: {
+          label: '传真',
+          prop: 'faxNo',
+          rules: []
+        }
+      }, {
+        md: 6,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入法人名称' },
+        formItemAttributes: {
+          label: '法人',
+          prop: 'corporation',
+          rules: []
+        }
+      }, {
+        md: 6,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入营业执照号' },
+        formItemAttributes: {
+          label: '营业执照号',
+          prop: 'licenseId',
+          rules: []
+        }
+      }, {
+        md: 8,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入开户银行' },
+        formItemAttributes: {
+          label: '开户银行',
+          prop: 'khBank',
+          rules: []
+        }
+      }, {
+        md: 8,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入开户行号' },
+        formItemAttributes: {
+          label: '开户行号',
+          prop: 'bankRow',
+          rules: []
+        }
+      }, {
+        md: 8,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入银行账号' },
+        formItemAttributes: {
+          label: '银行账号',
+          prop: 'accNo',
+          rules: []
+        }
+      }, {
+		md: 24,
+		isShow: true,
+		name: 'slot-component',
+		formItemAttributes: {
+			label: '营业执照',
+			prop: 'imageUrl',
+			rules: []
+		},
+		render: (h, { props, onInput }) => {
+			var { value } = props
+			return (
+				<ImageUpload fileList={this.formData.imageUrl} limit={1} isEdit={this.formDialogType !== 2} />
+			)
+		}
+	}, {
+        md: 24,
+        isShow: true,
+        name: 'el-input',
+        attributes: { placeholder: '请输入备注内容',type: "textarea", rows: 5 },
+        formItemAttributes: {
+          label: '备注',
+          prop: 'remark',
+          rules: []
+        }
+      }]
+    }
+  },
+  methods: {
+    // 列表请求函数
+	getList(p) {
+	  try {
+	    var pam = JSON.parse(JSON.stringify(p))
+	    if (this.examineStatus) {
+	      pam.params.push({ "param": "b.examine_status", "compare": "=", "value": this.examineStatus })
+	    }
+	    return listPageV2(pam)
+	  } catch (error) {
+	    console.log(error)
+	  }
+	},
+    // 列表导出函数
+    exportList: pageExport,
+    // 表格列解析渲染数据更改
+    columnParsing(item, defaultData) {
+		if (item.jname === 'idCardImg') {
+		        defaultData.render = (h, { row, index, column }) => {
+		          return (
+		            <div style="padding:0 6px;cursor: pointer;">
+		              {row.idCardImg ? row.idCardImg.split(",").map(url => <el-image src={url} preview-src-list={[url]} fit="fit" style="width:80px;height:80px;" />) : null}
+		            </div>
+		          )
+		        }
+		      }
+      return defaultData
+    },
+    // 监听勾选变化
+    selectionChange(data) {
+      this.recordSelected = data
+    },
+    // 表格操作列
+    operation(h, { row, index, column }) {
+      return (
+        <div class='operation-btns'>
+          <el-button type="text" onClick={() => {
+            getDetail({ id: row.venderId }).then(res => {
+              Object.assign(this.formData, res.data,{
+				  imageUrl:res.data?.imageUrl ? res.data?.imageUrl?.split(",").map(item=>({url:item})) : []
+			  })
+              this.formDialogType = 2
+              this.openForm()
+            })
+          }}>查看</el-button>
+		  <el-button type="text" onClick={() => {
+		    getDetail({ id: row.venderId }).then(res => {
+		      Object.assign(this.formData, res.data,{
+				  imageUrl:res.data?.imageUrl?  res.data?.imageUrl?.split(",").map(item=>({url:item})) : []
+			  })
+			   console.log(this.formData)
+		      this.formDialogType = 1
+		      this.openForm()
+		    })
+		  }}>编辑</el-button>
+        </div>
+      )
+    },
+    addData() {
+      this.formDialogType = 0
+      this.openForm()
+    },
+    openForm() {
+      this.formDialog = true;
+    },
+    formCancel() {
+      this.$refs.formRef.$refs.inlineForm.clearValidate()
+      this.$data.formData = this.$options.data().formData
+      this.formDialog = false
+    },
+    formConfirm() {
+      this.$refs.formRef.validate((valid, invalidFields, errLabels) => {
+        if (valid) {
+          ([add, edit][this.formDialogType])({
+			  ...this.formData,
+			  imageUrl:this.formData.imageUrl.map(item=>item.url).join(",")
+		  }).then(res => {
+            this.$message({ type: 'success', message: `${this.formDialogTitles[this.formDialogType]}成功!` })
+            this.formCancel()
+            this.$refs.pageRef.refreshList()
+          })
+        }
+      })
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+	.tab{
+		padding: 20px 20px 0 20px;
+	}
+</style>