From db96301a4715b1c4f1180095441963ed6f430797 Mon Sep 17 00:00:00 2001
From: MrShi <1878285526@qq.com>
Date: 星期五, 17 一月 2025 11:02:41 +0800
Subject: [PATCH] 开发功能

---
 admin/src/views/Inspection/components/OperaYwPatrolSchemeWindow.vue |  246 ++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 220 insertions(+), 26 deletions(-)

diff --git a/admin/src/views/Inspection/components/OperaYwPatrolSchemeWindow.vue b/admin/src/views/Inspection/components/OperaYwPatrolSchemeWindow.vue
index 0f933b6..343b02b 100644
--- a/admin/src/views/Inspection/components/OperaYwPatrolSchemeWindow.vue
+++ b/admin/src/views/Inspection/components/OperaYwPatrolSchemeWindow.vue
@@ -1,38 +1,52 @@
 <template>
-  <GlobalWindow width="520px" :title="title" :visible.sync="visible" :confirm-working="isWorking" @confirm="confirm">
+  <GlobalWindow width="520px" :title="title" @close="close" :visible.sync="visible" :confirm-working="isWorking"
+    @confirm="confirm">
+    <div class="warnning">
+      {{ form.id ? '缂栬緫璁″垝瀵瑰凡鐢熸垚鐨勪换鍔℃棤鏁堬紝浼氬湪涓嬫鐢熸垚浠诲姟鏃剁敓鏁堬紝涓斿綋澶╀笉浼氱敓鎴愪袱涓换鍔�' : '鏂板缓宸℃璁″垝浼氫粠褰撳ぉ寮�濮嬶紝鎸夌収閰嶇疆瑙勫垯浜х敓瀵瑰簲鐨勫贰妫�浠诲姟' }}
+    </div>
     <el-form :model="form" ref="form" :rules="rules">
       <el-form-item label="璁″垝鍚嶇О" prop="title">
         <el-input v-model="form.title" placeholder="璇疯緭鍏ユ爣棰�" v-trim />
       </el-form-item>
-      <el-form-item label="宸℃绾胯矾">
-        <el-select v-model="form.status" filterable clearable>
-          <el-option value="0" label="姣忓ぉ"></el-option>
-          <el-option value="1" label="姣忓懆"></el-option>
-          <el-option value="2" label="姣忔湀"></el-option>
+      <el-form-item label="宸℃绾胯矾" prop="lineId">
+        <el-select v-model="form.lineId" filterable clearable>
+          <el-option v-for="item in lineList" :value="item.id" :label="item.name"></el-option>
         </el-select>
       </el-form-item>
-      <el-form-item label="宸℃璐熻矗浜�">
-        <el-select v-model="form.userIds" filterable clearable>
-          <el-option value="0" label="姣忓ぉ"></el-option>
-          <el-option value="1" label="姣忓懆"></el-option>
-          <el-option value="2" label="姣忔湀"></el-option>
+      <el-form-item label="宸℃璐熻矗浜�" prop="userIds">
+        <el-select v-model="form.userIds" multiple filterable clearable>
+          <el-option v-for="item in staffList" :value="item.id" :label="item.realname"></el-option>
         </el-select>
       </el-form-item>
-      <el-form-item label="璁″垝寮�濮嬫棩鏈�-缁撴潫鏃ユ湡">
-        <el-date-picker v-model="form.selDate" is-range range-separator="-" value-format="yyyy-MM-dd" type="daterange"
-          start-placeholder="寮�濮嬫棩鏈�" end-placeholder="缁撴潫鏃ユ湡" class="w400" />
+      <el-form-item label="璁″垝寮�濮嬫棩鏈�-缁撴潫鏃ユ湡" prop="selDate">
+        <el-date-picker v-model="form.selDate" @change="changeDate" is-range range-separator="-"
+          value-format="yyyy-MM-dd" type="daterange" start-placeholder="寮�濮嬫棩鏈�" end-placeholder="缁撴潫鏃ユ湡" />
       </el-form-item>
       <el-form-item label="璁″垝鎵ц鏃堕棿">
-        <el-time-picker v-model="form.selTime" is-range range-separator="-" format="HH:mm" value-format="HH:mm:ss"
-          start-placeholder="寮�濮嬫椂闂�" end-placeholder="缁撴潫鏃堕棿" placeholder="閫夋嫨鏃堕棿鑼冨洿" class="w400" />
+        <el-time-picker v-model="form.selTime" @change="changeTime" is-range range-separator="-" format="HH:mm"
+          value-format="HH:mm:ss" start-placeholder="寮�濮嬫椂闂�" end-placeholder="缁撴潫鏃堕棿" placeholder="閫夋嫨鏃堕棿鑼冨洿" />
       </el-form-item>
-      <el-form-item label="寰幆鍛ㄦ湡">
-        <el-select v-model="form.circleType" filterable clearable>
-          <el-option value="0" label="姣忓ぉ"></el-option>
-          <el-option value="1" label="姣忓懆"></el-option>
-          <el-option value="2" label="姣忔湀"></el-option>
+      <el-form-item label="閲嶅棰戠巼">
+        <el-select v-model="form.circleType" @change="changeType" filterable>
+          <el-option :value="0" label="姣忓ぉ"></el-option>
+          <el-option :value="1" label="姣忓懆"></el-option>
+          <el-option :value="2" label="姣忔湀"></el-option>
         </el-select>
       </el-form-item>
+      <el-form-item v-if="form.circleType == 1" prop="circleDays" label="閲嶅瑙勫垯">
+        <div class="weeks">
+          <div class="week" @click="weekClick(i)" :class="{ active: item.sel }" v-for="item, i in weeks">{{ item.la }}
+          </div>
+        </div>
+      </el-form-item>
+      <el-form-item v-if="form.circleType == 2" prop="circleDays" label="閲嶅瑙勫垯">
+        <div class="weeks">
+          <div class="week" @click="monthClick(i)" :class="{ active: item.sel }" v-for="item, i in monthsList">{{
+            item.la
+            }}</div>
+        </div>
+      </el-form-item>
+
     </el-form>
   </GlobalWindow>
 </template>
@@ -40,6 +54,9 @@
 <script>
 import BaseOpera from '@/components/base/BaseOpera'
 import GlobalWindow from '@/components/common/GlobalWindow'
+import { fetchList as getLineList } from '@/api/Inspection/ywPatrolLine'
+import { detailById } from '@/api/Inspection/ywPatrolScheme'
+import { getUserList } from '@/api/system/user'
 export default {
   name: 'OperaYwPatrolSchemeWindow',
   extends: BaseOpera,
@@ -59,11 +76,11 @@
         status: '',
         sortnum: '',
         lineId: '',
-        userIds: '',
+        userIds: [],
         dealUserId: '',
         dealDate: '',
         dealInfo: '',
-        circleType: '',
+        circleType: 0,
         circleDays: '',
         startDate: '',
         endDate: '',
@@ -71,10 +88,26 @@
         endTime: '',
         processStatus: '',
         selDate: [],
-        selTime: [],
       },
-      // 楠岃瘉瑙勫垯
+      lineList: [],
+      staffList: [],
+      weeks: [
+        { la: '鍛ㄤ竴', va: 1, sel: false },
+        { la: '鍛ㄤ簩', va: 2, sel: false },
+        { la: '鍛ㄤ笁', va: 3, sel: false },
+        { la: '鍛ㄥ洓', va: 4, sel: false },
+        { la: '鍛ㄤ簲', va: 5, sel: false },
+        { la: '鍛ㄥ叚', va: 6, sel: false },
+        { la: '鍛ㄦ棩', va: 7, sel: false },
+      ],
+      monthsList: [],
+      selCircleDays: [],
       rules: {
+        title: [{ required: true, message: '璇疯緭鍏�' }],
+        lineId: [{ required: true, message: '璇烽�夋嫨' }],
+        userIds: [{ required: true, message: '璇烽�夋嫨' }],
+        selDate: [{ type: 'array', required: true, message: '璇烽�夋嫨' }],
+        circleDays: [{ required: true, message: '璇烽�夋嫨' }],
       }
     }
   },
@@ -85,10 +118,171 @@
     })
   },
   methods: {
+    __confirmCreate () {
+      this.$refs.form.validate((valid) => {
+        if (!valid) {
+          return
+        }
+        let obj = JSON.parse(JSON.stringify(this.form))
+        obj.userIds = obj.userIds.join(',')
+        // 璋冪敤鏂板缓鎺ュ彛
+        this.isWorking = true
+        this.api.create(obj)
+          .then(() => {
+            this.visible = false
+            this.$tip.apiSuccess('鏂板缓鎴愬姛')
+            this.$emit('success')
+          })
+          .catch(e => {
+            // this.$tip.apiFailed(e)
+          })
+          .finally(() => {
+            this.isWorking = false
+          })
+      })
+    },
+    __confirmEdit () {
+      this.$refs.form.validate((valid) => {
+        if (!valid) {
+          return
+        }
+        let obj = JSON.parse(JSON.stringify(this.form))
+        obj.userIds = obj.userIds.join(',')
+        // 璋冪敤鏂板缓鎺ュ彛
+        this.isWorking = true
+        this.api.updateById(obj)
+          .then(() => {
+            this.visible = false
+            this.$tip.apiSuccess('淇敼鎴愬姛')
+            this.$emit('success')
+          })
+          .catch(e => {
+            // this.$tip.apiFailed(e)
+          })
+          .finally(() => {
+            this.isWorking = false
+          })
+      })
+    },
+    weekClick(i) {
+      this.weeks.forEach((item, index) => {
+        if (i == index) { item.sel = !item.sel }
+      })
+      this.$set(this.form, 'circleDays', this.weeks.filter(j => j.sel).map(a => a.va).join(','))
+    },
+    monthClick(i) {
+      this.monthsList.forEach((item, index) => {
+        if (i == index) { item.sel = !item.sel }
+      })
+      this.$set(this.form, 'circleDays', this.monthsList.filter(j => j.sel).map(a => a.va).join(','))
+    },
+    changeTime(e) {
+      if (e && e.length > 0) {
+        this.$set(this.form, 'startTime', e[0])
+        this.$set(this.form, 'endTime', e[1])
+      } else {
+        this.$set(this.form, 'startTime', '')
+        this.$set(this.form, 'endTime', '')
+      }
+    },
+    changeDate(e) {
+      if (e && e.length > 0) {
+        this.$set(this.form, 'startDate', e[0])
+        this.$set(this.form, 'endDate', e[1])
+      } else {
+        this.$set(this.form, 'startDate', '')
+        this.$set(this.form, 'endDate', '')
+      }
+    },
+    changeType() {
+      this.$set(this.form, 'circleDays', '')
+    },
+    getDetail(id) {
+      detailById(id).then(res => {
+        this.form = res
+        if (res.userIds) {
+          this.$set(this.form, 'userIds', Number(res.userIds))
+        }
+        if (res.startTime) {
+          this.$set(this.form, 'selTime', [res.startTime, res.endTime])
+        }
+        if (res.circleDays) {
+          const circleDays = res.circleDays.split(',')
+          if (res.circleType == 1) {
+            circleDays.forEach(i => {
+              this.weeks.forEach(j => {
+                if (i == j.va) {
+                  j.sel = true
+                }
+              })
+            })
+          } else {
+            setTimeout(() => {
+              circleDays.forEach(i => {
+                this.monthsList.forEach(j => {
+                  if (i == j.va) {
+                    j.sel = true
+                  }
+                })
+              })
+            }, 500)
+          }
+        }
+        this.$set(this.form, 'selDate', [res.startDate, res.endDate])
+      })
+    },
     initData() {
-
+      getLineList({
+        model: {},
+        capacity: 9999,
+        page: 1,
+      }).then(res => {
+        this.lineList = res.records
+      })
+      getUserList({}).then(res => {
+        this.staffList = res
+      })
+      this.monthsList = []
+      for (let i = 1; i < 32; i++) {
+        this.monthsList.push({ la: i, va: i, sel: false })
+      }
+    },
+    close() {
+      this.$refs.form.resetFields()
+      this.visible = false
     }
   }
 
 }
 </script>
+<style lang="scss" scoped>
+@import '@/assets/style/variables.scss';
+.warnning{
+  padding: 6px 10px;
+  background-color: #fcf3e6;
+  font-size: 12px;
+  color: #333333;
+}
+.weeks {
+  display: flex;
+  align-items: center;
+  flex-wrap: wrap;
+
+  .week {
+    border: 1px solid #999999;
+    width: 40px;
+    height: 18px;
+    text-align: center;
+    line-height: 18px;
+    font-size: 12px;
+    margin-right: 8px;
+    cursor: pointer;
+    margin-bottom: 6px;
+  }
+
+  .active {
+    color: $primary-color;
+    border: 1px solid $primary-color;
+  }
+}
+</style>

--
Gitblit v1.9.3