From 2a32e53e45eef72bb37409b0694e4b5c2b1587af Mon Sep 17 00:00:00 2001
From: MrShi <1878285526@qq.com>
Date: 星期四, 23 十月 2025 15:12:26 +0800
Subject: [PATCH] 页面
---
 admin/src/views/meeting/components/OperaBookingsWindow.vue |  179 ++++++++++++++++++++++++-----------------------------------
 1 files changed, 73 insertions(+), 106 deletions(-)
diff --git a/admin/src/views/meeting/components/OperaBookingsWindow.vue b/admin/src/views/meeting/components/OperaBookingsWindow.vue
index a98b285..70f7c03 100644
--- a/admin/src/views/meeting/components/OperaBookingsWindow.vue
+++ b/admin/src/views/meeting/components/OperaBookingsWindow.vue
@@ -1,85 +1,48 @@
 <template>
-  <GlobalAlertWindow
-    :title="title"
-    :visible.sync="visible"
-    :confirm-working="isWorking"
-    @confirm="confirm"
-  >
+  <GlobalAlertWindow :title="title" :visible.sync="visible" :confirm-working="isWorking" @confirm="confirm"
+    width="880px">
     <el-form :model="form" ref="form" :rules="rules" label-width="120px" label-suffix="锛�">
       <el-form-item label="鍏宠仈浼氳瀹�" prop="roomId">
-        <el-select
-          v-model="form.roomId"
-          filterable
-          clearable
-          placeholder="璇烽�夋嫨鍏宠仈浼氳瀹�"
-          @change="selectRoom"
+        <el-select v-model="form.roomId" @change="selectRoom" filterable clearable :disabled="isEdit" placeholder="璇烽�夋嫨鍏宠仈浼氳瀹�"
         >
           <el-option v-for="item in rooms()" :key="item.id" :value="item.id" :label="item.name" />
         </el-select>
       </el-form-item>
       <el-form-item label="棰勫畾鏃ユ湡" prop="date">
-        <el-date-picker
-          v-model="form.date"
-          value-format="yyyy-MM-dd"
-          placeholder="璇烽�夋嫨棰勫畾鏃ユ湡"
-          @change="selectDate"
-        ></el-date-picker>
+        <el-date-picker :disabled="isEdit" v-model="form.date" value-format="yyyy-MM-dd" placeholder="璇烽�夋嫨棰勫畾鏃ユ湡"
+          @change="selectDate"></el-date-picker>
       </el-form-item>
       <el-form-item label="棰勫畾鏃堕棿" prop="times">
         <div class="time-style">
-          <div
-            class="time-item"
-            v-for="(item, index) in timelist"
-            :key="item.id"
-            :class="{
-              'time-item-sel': form.times.indexOf(index)!=-1,
-              'time-item-disable': item.isUse,
-              'disable': item.bookingTimeId
-            }"
-            @click="selectTimes(index, item)"
-          >{{ `${item.startTime}-${item.endTime}` }}</div>
+          <div class="time-item" v-for="(item, index) in timelist" :key="item.id" :class="{
+            'time-item-sel': form.times.indexOf(index) != -1,
+            'time-item-disable': item.isUse,
+            'disable': item.bookingTimeId
+          }" @click="selectTimes(index, item)">{{ `${item.startTime}-${item.endTime}` }}</div>
         </div>
       </el-form-item>
       <el-form-item label="浼氳涓婚" prop="name">
-        <el-input v-model="form.name" placeholder="璇疯緭鍏ヤ細璁富棰�" :maxlength="30" v-trim/>
+        <el-input v-model="form.name" placeholder="璇疯緭鍏ヤ細璁富棰�" :maxlength="30" v-trim />
       </el-form-item>
-
-      <el-form-item label="鍙備細浜哄憳">
-        <!-- <el-input style="width:40%" disabled v-model="sysList" placeholder="閫夋嫨鍙備細浜哄憳" v-trim/> -->
-        <el-select
-          v-model="form.sysList"
-          filterable
-          clearable
-          multiple
-          placeholder="閫夋嫨閮ㄩ棬鎴愬憳"
-        >
-          <el-option
-            v-for="item in sysList"
-            :key="item.id"
-            :value="item.id"
-            :label="item.department?`${item.department.name}-${item.realname}`:item.realname"
-          ></el-option>
-          <!-- <el-option :key="1" :value="1" label="绂佺敤" /> -->
-        </el-select>
+        <el-form-item label="鍙備細浜哄憳">
+          <el-select style="width: 100%" v-model="form.sysList" filterable clearable multiple placeholder="閫夋嫨閮ㄩ棬鎴愬憳">
+            <el-option v-for="item in sysList" :key="item.id" :value="item.id"
+              :label="item.companyName ? `${item.realname}-${item.companyName}` : item.realname"></el-option>
+            <!-- <el-option :key="1" :value="1" label="绂佺敤" /> -->
+          </el-select>
+        </el-form-item>
+      <el-form-item   label-width="140px" label="鏄惁閫氱煡鍙備細浜哄憳">
+        <el-radio v-model="form.joinNotice" :label="1">涓嶉�氱煡</el-radio>
+        <el-radio v-model="form.joinNotice" :label="0">閫氱煡</el-radio>
       </el-form-item>
       <el-form-item label="浼氳鍐呭" prop="content">
-        <el-input
-          type="textarea"
-          v-model="form.content"
-          :maxlength="300"
-          show-word-limit
-          :autosize="{ minRows: 4, maxRows: 12}"
-          placeholder="璇疯緭鍏ヤ細璁唴瀹�"
-          v-trim
-        />
+        <el-input type="textarea" v-model="form.content" :maxlength="300" show-word-limit
+          :autosize="{ minRows: 4, maxRows: 12 }" placeholder="璇疯緭鍏ヤ細璁唴瀹�" v-trim />
       </el-form-item>
       <el-form-item v-if="projectList.length" label="閫夋嫨鏈嶅姟椤圭洰" prop="projectList">
         <el-checkbox-group v-model="form.projectList">
-          <el-checkbox
-            v-for="project in projectList"
-            :label="project.id"
-            :key="project.id"
-          >{{project.name}}</el-checkbox>
+          <el-checkbox v-for="project in projectList" :label="project.id"
+            :key="project.id">{{ project.name }}</el-checkbox>
         </el-checkbox-group>
       </el-form-item>
       <el-form-item label="浼氳闄勪欢" prop="fileList">
@@ -87,24 +50,16 @@
           <el-button type="primary" icon="el-icon-upload" @click="$refs.upFile.click()">浼氳闄勪欢</el-button>
         </div>
         <div class="data-list">
-          <FileLink
-            :links="form.fileList"
-            linkName="fileFullUrl"
-          />
+          <FileLink :links="form.fileList" linkName="fileFullUrl" />
         </div>
       </el-form-item>
-      <el-form-item label="浼氳澶囨敞" prop="remark">
-        <el-input type="textarea" v-model="form.remark" placeholder="璇疯緭鍏ヤ細璁娉�" v-trim/>
+      <el-form-item label="浼氳闇�姹�" prop="remark">
+        <el-input type="textarea" v-model="form.remark" placeholder="璇疯緭鍏ヤ細璁渶姹�" v-trim />
       </el-form-item>
       <input type="file" @change="upFiles" ref="upFile" style="display: none;" />
     </el-form>
 
-    <el-dialog
-      title="浼氳瀹ら绾︽儏鍐�"
-      :visible.sync="isShowDetail"
-      append-to-body
-      width="600px"
-    >
+    <el-dialog title="浼氳瀹ら绾︽儏鍐�" :visible.sync="isShowDetail" append-to-body width="600px">
       <div class="detail_modal">
         <div class="h1">{{ activeInfo.meetingName }}</div>
         <div class="line">
@@ -132,7 +87,7 @@
 import GlobalAlertWindow from '@/components/common/GlobalAlertWindow'
 import FileLink from '@/views/meeting/components/common/FileLink'
 import { upload } from '@/api/system/common'
-import { fetchList as userList } from '@/api/system/user'
+import { findAllList as userList } from '@/api/system/user'
 import { findListByObjId } from '@/api/meeting/projects'
 import { BookDetailById } from '@/api/meeting/bookings'
 import { findList } from '@/api/meeting/roomTime'
@@ -141,7 +96,7 @@
   name: 'OperaBookingsWindow',
   extends: BaseOpera,
   components: { GlobalAlertWindow, FileLink },
-  data () {
+  data() {
     return {
       // 琛ㄥ崟鏁版嵁
       form: {
@@ -155,6 +110,7 @@
         startTime: '',
         endTime: '',
         times: [],
+        joinNotice: 1,
         content: '',
         sysList: [],
         fileList: []
@@ -190,19 +146,15 @@
     }
   },
   inject: ['rooms'],
-  created () {
+  created() {
     this.config({
       api: '/meeting/bookings',
       'field.id': 'id'
     })
-    userList({
-      page: 1,
-      capacity: 9999,
-      model: { realname: this.filterText, memberType: 2, companyType: 1 }
-    })
+    userList({queryParam: this.filterText,querySpecial: 1, type: 2, companyType: 1,workStatus:0})
       .then(res => {
         console.log('userList', res)
-        this.sysList = res.records
+        this.sysList = res
       })
   },
   methods: {
@@ -211,7 +163,7 @@
      * @title 绐楀彛鏍囬
      * @target 缂栬緫鐨勫璞�
      */
-    open (title, target) {
+    open(title, target) {
       this.title = title
       this.visible = true
       this.timelist = []
@@ -239,7 +191,7 @@
         this.selectRoom(this.form.roomId)
       })
     },
-    selectRoom (objId) {
+    selectRoom(objId) {
       this.getTimes()
       findListByObjId({
         objId: objId,
@@ -249,11 +201,11 @@
           this.projectList = res
         })
     },
-    selectDate (v) {
+    selectDate(v) {
       // console.log(v);
       this.getTimes()
     },
-    getTimes (isInit = false) {
+    getTimes(isInit = false) {
       this.form.times = []
       this.timelist = []
 
@@ -290,7 +242,7 @@
           })
       }
     },
-    getDetail (id) {
+    getDetail(id) {
       BookDetailById({
         id
       }).then(res => {
@@ -298,7 +250,7 @@
         this.isShowDetail = true
       })
     },
-    selectTimes (index, item) {
+    selectTimes(index, item) {
       if (item.bookingTimeId) {
         this.getDetail(item.bookingTimeId)
         return
@@ -328,7 +280,7 @@
       }
       // console.log(this.form.times);
     },
-    upFiles (file) {
+    upFiles(file) {
       const formdate = new FormData()
       this.isUploading = true
       formdate.append('file', file.target.files[0])
@@ -349,7 +301,7 @@
       this.$refs.upFile.value = null
     },
     // 纭鏂板缓
-    __confirmCreate () {
+    __confirmCreate() {
       this.$refs.form.validate((valid) => {
         // debugger
         if (!valid) {
@@ -398,7 +350,7 @@
       })
     },
     // 纭淇敼
-    __confirmEdit () {
+    __confirmEdit() {
       this.$refs.form.validate((valid) => {
         if (!valid) {
           return
@@ -460,56 +412,71 @@
   display: flex;
   flex-wrap: wrap;
   cursor: pointer;
+
   .time-item {
     margin-right: 8px;
     margin-bottom: 8px;
-    border: #111 solid 1px;
     font-size: 14px;
+    font-weight: 400;
     line-height: 14px;
-    padding: 5px;
+    width: 124px;
+    height: 36px;
+    display: flex;
+    justify-content: center;
+    align-items: center;
     border-radius: 5px;
     color: #111;
+    border: #cccccc solid 1px;
+    cursor: pointer;
   }
+
   .time-item-sel {
     border-color: $primary-color;
-    background-color: $primary-color;
+    background-color: #f6f9fe;
+    color: $primary-color;
+  }
+
+  .time-item-disable {
+    color: #fff;
+    border-color: #cccccc;
+    background-color: #cccccc;
+  }
+
+  .disable {
+    border-color: #bed6f9;
+    background-color: #bed6f9;
     color: #fff;
   }
-  .time-item-disable {
-    color: #e4e4e4;
-    border-color: #999;
-    background-color: #999;
-  }
-  .disable{
-    border-color: #999;
-    background-color: #999;
-    color: #111;
-  }
 }
+
 .detail_modal {
   padding: 20px 16px;
+
   .title {
     text-align: center;
     font-weight: 600;
     font-size: 16px;
     margin-bottom: 20px;
   }
+
   .h1 {
     font-weight: 600;
     font-size: 16px;
     margin-bottom: 15px;
   }
+
   .line {
     display: flex;
     margin-bottom: 10px;
+
     .label {
       width: 70px;
       color: #888888;
     }
+
     .value {
       color: #333333;
     }
   }
 }
-
 </style>
--
Gitblit v1.9.3