facilityDataDialog.vue 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  1. <template>
  2. <el-dialog
  3. :title="title"
  4. :visible.sync="dialogVisible"
  5. width="60%"
  6. append-to-body
  7. class="dialog"
  8. :close-on-click-modal="false"
  9. :close-on-press-escape="false"
  10. :show-close="false"
  11. >
  12. <div class="contain">
  13. <div class="form">
  14. <el-form ref="formRef" :model="form" label-width="120" :rules="rules">
  15. <el-row class="item">
  16. <el-col>
  17. <el-form-item label="监测周期:" prop="period">
  18. <el-select v-model="form.period" placeholder="请选择" size="mini" :clearable="true" style="width:100%" @change="periodChange()">
  19. <el-option
  20. v-for="item in periodList"
  21. :key="item.value"
  22. :label="item.label"
  23. :value="item.value"
  24. />
  25. </el-select>
  26. </el-form-item>
  27. </el-col>
  28. </el-row>
  29. <el-row v-if="form.period" class="item">
  30. <el-col>
  31. <el-form-item label="监测频率:" prop="date">
  32. <el-select
  33. v-if="form.period==='day' || form.period==='week'"
  34. v-model="form.date"
  35. :multiple="form.period==='day'"
  36. placeholder="请选择"
  37. size="mini"
  38. style="width:100%"
  39. >
  40. <el-option
  41. v-for="item in weekDays"
  42. :key="item.value"
  43. :label="item.label"
  44. :value="item.value"
  45. />
  46. </el-select>
  47. <el-select v-if="form.period==='month'" v-model="form.date" placeholder="请选择" size="mini" style="width:100%">
  48. <el-option
  49. v-for="item in 28"
  50. :key="item"
  51. :label="`第${item}天`"
  52. :value="item"
  53. />
  54. </el-select>
  55. <el-select v-if="form.period==='quarter'" v-model="form.date" placeholder="请选择" size="mini" style="width:100%">
  56. <el-option
  57. v-for="item in 3"
  58. :key="item"
  59. :label="`第${item}个月`"
  60. :value="item"
  61. />
  62. </el-select>
  63. <div v-if="form.period==='repeat'" style="display:flex;align-items: center;width:100%">
  64. <el-select v-model="form.date" placeholder="请选择" size="mini" style="width:100%">
  65. <el-option
  66. v-for="item in 30"
  67. :key="item"
  68. :label="`每隔${item}天`"
  69. :value="item"
  70. />
  71. </el-select>
  72. </div>
  73. </el-form-item>
  74. </el-col>
  75. </el-row>
  76. <el-row v-if="form.period==='repeat'" class="item">
  77. <el-col>
  78. <el-form-item label="开始时间:" prop="startTime">
  79. <el-date-picker
  80. v-model="form.startTime"
  81. :clearable="false"
  82. type="date"
  83. placeholder="选择监测开始时间"
  84. :picker-options="pickerOptions"
  85. value-format="yyyy-MM-dd"
  86. size="mini"
  87. style="width:100%"
  88. />
  89. </el-form-item>
  90. </el-col>
  91. </el-row>
  92. </el-form>
  93. </div>
  94. </div>
  95. <span slot="footer" class="dialog-footer">
  96. <el-button type="primary" size="mini" icon="ibps-icon-save" @click="handleConfirm">确 定</el-button>
  97. <el-button size="mini" icon="ibps-icon-close" @click="handleClose">取 消</el-button>
  98. </span>
  99. </el-dialog>
  100. </template>
  101. <script>
  102. import dayjs from 'dayjs'
  103. export default {
  104. props: {
  105. params: {
  106. type: Object,
  107. default: () => {}
  108. },
  109. dialogVisible: {
  110. type: Boolean,
  111. default: false
  112. }
  113. },
  114. data () {
  115. return {
  116. title: '',
  117. rules: {
  118. period: [
  119. { required: true, message: '请选择监测周期', trigger: 'blur' }
  120. ],
  121. date: [
  122. { required: true, message: '请选择查询的日期', trigger: 'blur' }
  123. ],
  124. startTime: [
  125. { required: true, message: '请选择开始时间', trigger: 'blur' }
  126. ]
  127. },
  128. pickerOptions: {
  129. disabledDate (time) {
  130. return time.getTime() < (Date.now() - (24 * 60 * 1000 * 60))
  131. }
  132. },
  133. form: {
  134. period: '',
  135. date: '',
  136. startTime: dayjs().format('YYYY-MM-DD')
  137. },
  138. periodList: [{ label: '日监测', value: 'day' }, { label: '周监测', value: 'week' }, { label: '月监测', value: 'month' }, { label: '季度监测', value: 'quarter' }, { label: '按时间间隔监测', value: 'repeat' }],
  139. weekDays: [{ label: '周一', value: 1 }, { label: '周二', value: 2 }, { label: '周三', value: 3 }, { label: '周四', value: 4 }, { label: '周五', value: 5 }, { label: '周六', value: 6 }, { label: '周日', value: 7 }]
  140. }
  141. },
  142. mounted () {
  143. this.form = this.params
  144. if (!this.params.rate) {
  145. this.title = '新增'
  146. } else {
  147. this.form = this.params
  148. this.title = '修改'
  149. }
  150. // this.form = this.params
  151. },
  152. methods: {
  153. handleClose () {
  154. this.$emit('update:dialogVisible', false)
  155. },
  156. async handleConfirm () {
  157. try {
  158. await this.$refs.formRef.validate()
  159. let rate = '每天'
  160. switch (this.form.period) {
  161. case 'day':
  162. if (this.form.date.length !== 7) {
  163. this.form.date.sort((a, b) => a - b)
  164. rate = '每周' + this.form.date.join(',')
  165. }
  166. break
  167. case 'week':
  168. rate = '每周' + this.form.date
  169. break
  170. case 'month':
  171. rate = '每个月第' + this.form.date + '天'
  172. break
  173. case 'quarter':
  174. rate = '每个季度第' + this.form.date + '个月'
  175. break
  176. case 'repeat':
  177. rate = this.form.startTime + '起每隔' + this.form.date + '天'
  178. break
  179. default:
  180. break
  181. }
  182. this.form.rate = rate
  183. this.$emit('submit', this.form, this.params.$index)
  184. this.handleClose()
  185. } catch (error) {
  186. console.log(error)
  187. }
  188. },
  189. periodChange () {
  190. if (this.form.period === 'day') {
  191. this.form.date = []
  192. } else {
  193. this.form.date = ''
  194. }
  195. }
  196. }
  197. }
  198. </script>
  199. <style lang="scss" scoped>
  200. .contain{
  201. padding: 20px;
  202. .form{
  203. .item{
  204. width: 600px;
  205. }
  206. }
  207. }
  208. ::v-deep{
  209. .el-form-item__content{
  210. display: flex;
  211. }
  212. }
  213. </style>