form.vue 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. <template>
  2. <el-dialog :title="titleMap[mode]" v-model="visible" :width="500" destroy-on-close @closed="$emit('closed')" :close-on-click-modal="false" :close-on-press-escape="false">
  3. <el-form ref="dialogForm" :model="formData" :rules="rules" label-width="120px" label-position="top">
  4. <el-form-item label="打印类型" prop="type">
  5. <el-checkbox-group v-model="formData.type">
  6. <el-checkbox-button :label="item.key" v-for="(item,index) in typeData" :key="index">{{ item.name }}</el-checkbox-button>
  7. </el-checkbox-group>
  8. <div class="el-form-item-msg"></div>
  9. </el-form-item>
  10. <el-form-item label="支持纸型" prop="paper_size">
  11. <el-checkbox-group v-model="formData.paper_size">
  12. <el-checkbox-button :label="item" v-for="(item,index) in printType" :key="index">{{ item }}</el-checkbox-button>
  13. </el-checkbox-group>
  14. <div class="el-form-item-msg"></div>
  15. </el-form-item>
  16. <el-form-item label="打印机类型" prop="color">
  17. <el-checkbox-group v-model="formData.color">
  18. <el-checkbox-button :label="item.key" v-for="(item,index) in colorType" :key="index">{{ item.name }}</el-checkbox-button>
  19. </el-checkbox-group>
  20. <div class="el-form-item-msg"></div>
  21. </el-form-item>
  22. <el-form-item label="打印方向" prop="direction">
  23. <el-checkbox-group v-model="formData.direction">
  24. <el-checkbox-button :label="item.key" v-for="(item,index) in directionType" :key="index">{{ item.name }}</el-checkbox-button>
  25. </el-checkbox-group>
  26. <div class="el-form-item-msg"></div>
  27. </el-form-item>
  28. <el-form-item label="支持单双面" prop="duplex">
  29. <el-checkbox-group v-model="formData.duplex">
  30. <el-checkbox-button :label="item.key" v-for="(item,index) in duplexType" :key="index">{{ item.name }}</el-checkbox-button>
  31. </el-checkbox-group>
  32. <div class="el-form-item-msg"></div>
  33. </el-form-item>
  34. <el-form-item label="取件方式" prop="package">
  35. <el-checkbox-group v-model="formData.package">
  36. <el-checkbox-button :label="item.key" v-for="(item,index) in packageType" :key="index">{{ item.name }}</el-checkbox-button>
  37. </el-checkbox-group>
  38. <div class="el-form-item-msg"></div>
  39. </el-form-item>
  40. <el-form-item label="额外收费" prop="is_price">
  41. <el-radio-group v-model="formData.is_price">
  42. <el-radio-button :label="1">关闭</el-radio-button>
  43. <el-radio-button :label="2">启用</el-radio-button>
  44. </el-radio-group>
  45. <div class="el-form-item-msg">开启后该打印机可设置额外价格</div>
  46. </el-form-item>
  47. </el-form>
  48. <template #footer>
  49. <el-button @click="visible=false" >取 消</el-button>
  50. <el-button type="primary" :loading="isSaveing" @click="submit()">保存</el-button>
  51. </template>
  52. </el-dialog>
  53. </template>
  54. <script>
  55. export default {
  56. data(){
  57. return {
  58. loading: false,
  59. mode:"add",
  60. titleMap:{
  61. add:"更新地址",
  62. edit:"更新地址"
  63. },
  64. typeData:[{"name":"文档","key":1}],
  65. printType:['A3','A4','A5','A6','B4','B5'],
  66. colorType:[{"name":"彩色","key":1},{"name":"黑白","key":2}],
  67. directionType:[{"name":"自适应","key":1},{"name":"横向","key":2},{"name":"竖向","key":3}],
  68. duplexType:[{"name":"单面","key":1},{"name":"双面","key":2}],
  69. packageType:[{"name":"店内打印","key":1},{"name":"远程自取","key":2},{"name":"商家配送","key":3}],
  70. visible: false,
  71. isSaveing: false,
  72. formData:{
  73. is_price:1
  74. },
  75. disabled:false,
  76. rules:{
  77. type: [
  78. {required: true, message: '请选择'}
  79. ],
  80. paper_size: [
  81. {required: true, message: '请选择'}
  82. ],
  83. color: [
  84. {required: true, message: '请选择'}
  85. ],
  86. direction: [
  87. {required: true, message: '请选择'}
  88. ],
  89. duplex: [
  90. {required: true, message: '请选择'}
  91. ],
  92. package: [
  93. {required: true, message: '请选择'}
  94. ],
  95. is_price: [
  96. {required: true, message: '请选择'}
  97. ],
  98. }
  99. }
  100. },
  101. methods:{
  102. open(mode = 'add'){
  103. this.mode = mode;
  104. this.visible = true;
  105. return this
  106. },
  107. //表单注入数据
  108. setData(data){
  109. if (data.rule) {
  110. this.formData = data.rule;
  111. } else {
  112. this.formData = {}
  113. }
  114. this.formData.is_price = data.is_price;
  115. this.formData.id = data.id;
  116. this.titleMap.edit = "打印机【"+data.name + "】设置"
  117. },
  118. async submit(){
  119. var validate = await this.$refs.dialogForm.validate().catch(()=>{});
  120. if(!validate){ return false }
  121. this.isSaveing = true;
  122. let submitData = JSON.parse(JSON.stringify(this.formData));
  123. var resp = await this.$API.mPrint.save.post(submitData);
  124. this.isSaveing = false;
  125. if (resp.code !== 1) {
  126. return this.$message.error(resp.msg);
  127. }
  128. this.$message.success(resp.msg);
  129. this.visible = false;
  130. this.formData = {};
  131. this.submitState = false;
  132. this.$emit("success");
  133. }
  134. }
  135. }
  136. </script>
  137. <style>
  138. .mt20 {margin-top: 20px;}
  139. .login-msg-yzm {display: flex;width: 100%;}
  140. .login-msg-yzm .el-button {margin-left: 10px;--el-button-size:42px;}
  141. </style>