detail.vue 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. <template>
  2. <div class='app-container'>
  3. <el-form :model="form" :rules="rules" ref="form" label-width="100px" :disabled="disabled">
  4. <el-form-item label="活动名称:">
  5. <el-input v-model="form.name" placeholder="请输入活动名称" />
  6. </el-form-item>
  7. <el-form-item label="活动图片:" prop="pic">
  8. <Upload listType="picture-card" :url="form.pic" @upload="upload" />
  9. </el-form-item>
  10. <el-form-item label="有效时间:" prop="timeList">
  11. <el-date-picker type="datetimerange" v-model="form.timeList" start-placeholder="开始日期" end-placeholder="结束日期"
  12. value-format="yyyy-MM-dd HH:mm:ss" />
  13. </el-form-item>
  14. <el-form-item label="活动设备:" style="width: 1000px" prop="deviceRespList">
  15. <el-button type="primary" icon="el-icon-plus" @click="handlePush">添加</el-button>
  16. <el-table :data="form.deviceRespList">
  17. <el-table-column label="关联设备" align="center">
  18. <template slot-scope="scope">
  19. <el-form-item prop="deviceId">
  20. <el-select v-model="scope.row.deviceId" filterable placeholder="请选择关联设备" :disabled="disabledActivity">
  21. <el-option v-for="item in devOptions" :key="item.value" :value="item.value" :label="item.label"
  22. :disabled="item.disabled" />
  23. </el-select>
  24. </el-form-item>
  25. </template>
  26. </el-table-column>
  27. <el-table-column label="活动权益" align="center">
  28. <template slot-scope="scope">
  29. <el-form-item prop="indate">
  30. <el-select v-model="scope.row.indate" placeholder="请选择活动权益" :disabled="disabledActivity">
  31. <el-option v-for="item in serviceTimeOptions" :key="item.value" :value="item.value"
  32. :label="item.label" />
  33. </el-select>
  34. </el-form-item>
  35. </template>
  36. </el-table-column>
  37. <el-table-column label="领取数量" align="center">
  38. <template slot-scope="scope">
  39. <el-form-item prop="totalNum">
  40. <el-input-number v-model="scope.row.totalNum" :controls="false" :min="1" />
  41. </el-form-item>
  42. </template>
  43. </el-table-column>
  44. <el-table-column label="操作" align="center">
  45. <template slot-scope="scope">
  46. <el-button type="delete" @click="getDelete(scope.row.deviceId, scope.$index)"
  47. :disabled="disabledActivity">删除</el-button>
  48. </template>
  49. </el-table-column>
  50. </el-table>
  51. </el-form-item>
  52. </el-form>
  53. <div class="form-btn">
  54. <el-button @click="cancel">取消</el-button>
  55. <el-button v-if="!disabled" type="primary" @click="getSubmit">确定</el-button>
  56. </div>
  57. </div>
  58. </template>
  59. <script>
  60. import { detail, submit } from "@/api/operation/activity"
  61. import { serviceTimeMixin, devMixin } from '@/mixin/index'
  62. export default {
  63. mixins: [serviceTimeMixin, devMixin],
  64. data() {
  65. return {
  66. // 表单
  67. form: {
  68. deviceRespList: []
  69. },
  70. // 除蓝牙设备
  71. types: [2, 4],
  72. // 生效期内禁止修改活动设备
  73. disabledActivity: this.$route.query.activityState == 0 ? true : false,
  74. // 只读
  75. disabled: Boolean(this.$route.query.boolean),
  76. // 校验
  77. rules: {
  78. pic: [{
  79. required: true, message: '请上传活动图片', trigger: 'change'
  80. }],
  81. timeList: [{
  82. required: true, message: '请选择有效时间', trigger: 'change'
  83. }],
  84. deviceRespList: [{
  85. type: 'array', required: true, message: '请添加活动设备', trigger: 'change'
  86. }],
  87. deviceId: [{
  88. required: true, trigger: 'change'
  89. }],
  90. indate: [{
  91. required: true, trigger: 'change'
  92. }],
  93. totalNum: [{
  94. required: true, trigger: 'blur'
  95. }]
  96. }
  97. }
  98. },
  99. watch: {
  100. // 禁用已关联设备
  101. 'form.deviceRespList': {
  102. handler(val) {
  103. for (let i in this.devOptions) {
  104. this.devOptions[i].disabled = false
  105. }
  106. val.map(i => {
  107. if (i.deviceId) {
  108. let index = this.devOptions.findIndex(j => j.value === i.deviceId)
  109. this.devOptions[index].disabled = true
  110. }
  111. })
  112. },
  113. deep: true
  114. }
  115. },
  116. mounted() {
  117. if (this.$route.query.id) {
  118. this.getDetail()
  119. }
  120. },
  121. methods: {
  122. // 详情
  123. getDetail() {
  124. detail(this.$route.query.id).then(res => {
  125. if (res.code === 0) {
  126. this.form = res.data
  127. }
  128. })
  129. },
  130. // 上传图片
  131. upload(e) {
  132. this.form.pic = e.file
  133. },
  134. // 添加
  135. handlePush() {
  136. this.form.deviceRespList.push({})
  137. },
  138. // 删除
  139. getDelete(deviceId, index) {
  140. this.form.deviceRespList.splice(index, 1)
  141. this.devOptions.map(i => {
  142. if (i.value === deviceId) {
  143. i.disabled = false
  144. }
  145. })
  146. },
  147. // 取消
  148. cancel() {
  149. this.$tab.closeOpenPage('/operation/activity')
  150. },
  151. // 确定
  152. getSubmit() {
  153. this.$refs.form.validate((valid) => {
  154. if (valid) {
  155. submit(this.form).then(res => {
  156. if (res.code === 0) {
  157. this.$message.success('提交成功!')
  158. this.cancel()
  159. }
  160. })
  161. } else {
  162. return false
  163. }
  164. })
  165. }
  166. }
  167. }
  168. </script>
  169. <style lang="scss" scoped>
  170. .el-form-item {
  171. width: 500px;
  172. }
  173. .el-table__row {
  174. .el-form-item {
  175. width: 100%;
  176. }
  177. }
  178. </style>