From d539b7f289ba8887ccfdc11c06fe154ff5fb8974 Mon Sep 17 00:00:00 2001
From: feige <feige@qq.com>
Date: 星期二, 02 十二月 2025 15:47:59 +0800
Subject: [PATCH] 增加了代码

---
 ruoyi-ui/src/views/bignote/index.vue |  330 ++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 301 insertions(+), 29 deletions(-)

diff --git a/ruoyi-ui/src/views/bignote/index.vue b/ruoyi-ui/src/views/bignote/index.vue
index 926c621..fe3b5c0 100644
--- a/ruoyi-ui/src/views/bignote/index.vue
+++ b/ruoyi-ui/src/views/bignote/index.vue
@@ -1,5 +1,5 @@
 <template>
-  <div class="app-container" style="opacity: 1;">
+  <div class="app-container" style="opacity: 1;" >
     <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" >
 
       <el-form-item label="澶т簨鏍囬" prop="title">
@@ -146,14 +146,14 @@
       <template #dropdown>
         <el-dropdown-menu>
           <el-dropdown-item     :disabled="multiple" icon="el-icon-top" style="height: 32px;width:240px;color: #0099ff;" @click.native="handleShare">鍒嗕韩</el-dropdown-item>
-      
+
 		          <el-dropdown-item    icon="el-icon-top" @click.native="whoShare">鍒嗕韩缁欐垜鐨勬暟鎹�</el-dropdown-item>
 		      <el-dropdown-item    icon="el-icon-top" @click.native="handleWho">鍒嗕韩缁欒皝浜嗕粈涔堟暟鎹�</el-dropdown-item>
           <el-dropdown-item    icon="el-icon-top" @click.native="showData">灞曠ず涓嬭浇鐨勫垎浜暟鎹�</el-dropdown-item>
         </el-dropdown-menu>
       </template>
     </el-dropdown>
- 
+
 
       <right-toolbar :parentValue.sync="valueFromParent" :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
     </el-row>
@@ -200,7 +200,7 @@
             ></div>
         </template>
       </el-table-column>
-      <el-table-column label="鎿嶄綔" align="center" width="250" class-name="small-padding fixed-width" v-if="userId != 2">
+      <el-table-column  fixed="right" label="鎿嶄綔" align="center" width="250" class-name="small-padding fixed-width" v-if="userId != 2">
         <template slot-scope="scope" v-if="scope.row.roleId !== 1">
           <div class="button-container">
             <el-button
@@ -244,26 +244,48 @@
     />
 
     <!-- 娣诲姞鎴栦慨鏀硅祫浜т俊鎭厤缃璇濇 -->
-    <el-dialog :title="title" :visible.sync="open" width="800px" append-to-body>
+    <el-dialog :title="title"   @click.native="handleDialogClick" :visible.sync="open" width="800px" :append-to-body="true">
       <el-form ref="elForm" :model="formDat" :rules="rules" size="medium" label-width="100px">
 
 
         <el-form-item label="澶т簨鏍囬" prop="title">
           <el-input v-model="formDat.title" placeholder="璇疯緭鍏ュぇ浜嬫爣棰�" clearable :style="{width: '100%'}" ></el-input>
         </el-form-item>
-
-        <el-form-item label="浜虹墿" prop="people">
-          <el-input v-model="formDat.people" placeholder="璇疯緭鍏ヤ汉鐗�" clearable :style="{width: '100%'}" >
-          </el-input>
-        </el-form-item>
+     <!-- 瀹舵棌鎴愬憳閫夋嫨瀛楁 -->
+     <el-form-item label="瀹舵棌鎴愬憳" prop="selectedMemberIds">
+        <!-- 宸查�夋垚鍛樺洖鏄惧尯鍩� -->
+        <div v-if="selectedMemberNames.length > 0" class="selected-members">
+          <el-tag
+            v-for="(name, index) in selectedMemberNames"
+            :key="index"
+            closable
+            @close="handleTagClose(index)"
+          >
+            {{ name }}
+          </el-tag>
+        </div>
+        <!-- 瑙﹀彂寮圭獥鎸夐挳 -->
+        <el-button
+          type="primary"
+          icon="el-icon-user-plus"
+          @click="openMemberDialog"
+          :disabled="loading"
+        >
+          閫夋嫨瀹舵棌鎴愬憳
+        </el-button>
+      </el-form-item>
         <el-form-item label="鍦扮偣" prop="address">
           <el-input v-model="formDat.address" placeholder="璇疯緭鍏ュ湴鐐�" clearable :style="{width: '100%'}" >
           </el-input>
         </el-form-item>
 
         <el-form-item label="鍙戠敓鏃堕棿" prop="happenTime">
-          <el-date-picker v-model="formDat.happenTime" type="date" placeholder="璇烽�夋嫨鏃ユ湡"
-                          :editable="false" :clearable="false" :style="{width: '100%'}"  value-format="yyyy-MM-dd"
+          <el-date-picker  v-model="formDat.happenTime" type="date" placeholder="璇烽�夋嫨鏃ユ湡"
+                   @click.native.stop
+                   				      ref="datePicker"
+
+
+    :editable="false" :clearable="false" :style="{width: '100%'}"  value-format="yyyy-MM-dd"
           ></el-date-picker>
         </el-form-item>
         <el-form-item label="澶囨敞" prop="remark">
@@ -390,19 +412,67 @@
 
     </el-dialog>
 
+    <el-dialog
+      :visible.sync="memberDialogVisible"
+      title="閫夋嫨瀹舵棌鎴愬憳"
+      width="50%"
+      :close-on-click-modal="false"
+    >
+      <!-- 寮圭獥鍐呭鍖� -->
+      <div class="member-dialog-content">
+        <!-- 鎼滅储妗� -->
+        <el-input
+          v-model="memberSearch"
+          placeholder="鎼滅储鎴愬憳濮撳悕..."
+          prefix-icon="el-icon-search"
+          style="margin-bottom: 20px;"
+        ></el-input>
 
+
+
+        <!-- 鍔犺浇鐘舵�� -->
+       <div v-if="loading" class="loading-container">
+          <el-loading-spinner></el-loading-spinner>
+          <p>鍔犺浇瀹舵棌鎴愬憳涓�...</p>
+        </div>
+
+       <div v-else-if="familyMembers.length === 0" class="no-data">
+          <el-empty description="鏆傛棤瀹舵棌鎴愬憳鏁版嵁"></el-empty>
+        </div>
+<label v-for="item in familyMembers" :key="item.userId" class="signature-checkbox">
+     <input type="checkbox" v-model="selectedMemberIds" :value="item.userId">
+                                 <span>{{ item.oldName }}</span>
+                  </label>
+        <!-- 澶氶�夊垪琛紙鏈夋暟鎹級 -->
+<!--    <el-checkbox-group>
+         <el-checkbox
+
+
+          >
+          4545
+
+         </el-checkbox>
+        </el-checkbox-group> -->
+
+</div>
+      <!-- 寮圭獥搴曢儴鎸夐挳 -->
+      <div slot="footer" class="dialog-footer">
+        <el-button @click="memberDialogVisible = false">鍙栨秷</el-button>
+        <el-button type="primary" @click="confirmMemberSelection">纭閫夋嫨</el-button>
+      </div>
+    </el-dialog>
     <!-- 鍒嗕韩瀵硅瘽妗�1 -->
     <el-dialog :title="title1" :visible.sync="open1" width="500px" append-to-body @close="handleClose2">
 
     <el-table v-loading="loading1" :data="listRoot" :row-key="getRowId1" ref="table1"  @selection-change="handleSelectionChange1"  :row-class-name="tableRowClassName" style="background: #FFEFF2;  border-radius: 14px 14px 14px 14px;">
           <el-table-column type="selection" width="55"  align="center" />
           <el-table-column fixed label="搴忓彿" sortable type="index" :index="(queryParams1.pageNum-1)*queryParams1.pageSize+1" width="130"/>
-          <el-table-column label="韬唤" prop="identity" sortable width="130" >
+     <!--     <el-table-column label="韬唤" prop="identity" sortable width="130" >
             <template slot-scope="scope" >
               <span v-if="scope.row.isMyFamily==1">绗瑊{scope.row.identity}}浠�</span>
               <span v-else>鈥斺��</span>
             </template>
-          </el-table-column>
+          </el-table-column> -->
           <el-table-column label="濮撳悕" prop="nickName" sortable :show-overflow-tooltip="true" width="145" align="center"/>
         </el-table>
 
@@ -512,23 +582,38 @@
 
 
 <script>
-import { listRole, getRole, delRole, addRole, updateRole, dataScope, changeRoleStatus, deptTreeSelect } from "@/api/system/role";
+import { listRole, getRole, delRole, addRole,
+updateRole, dataScope, changeRoleStatus, deptTreeSelect } from "@/api/system/role";
 import { treeselect as menuTreeselect, roleMenuTreeselect } from "@/api/system/menu";
 
 
 import { Notification, MessageBox, Message, Loading } from 'element-ui'
+import {getAllInfo} from "@/api/system/user"
+import { getFamilyMembers } from '@/api/root'; // 鍋囪鑾峰彇瀹舵棌鎴愬憳鐨凙PI
 
 //鍦╯ystem/note/index.js涓鍏ユ帴鍙e嚱鏁�  --鎺ュソ浜�
 import {listFamilyevent,enload, delFamilyevent  , addFamilyevent , uploadPic,
-        share,shareToWho,getWhoShare,downShareData,deleteShareData,showShareData
+        share,shareToWho,getWhoShare,downShareData,deleteShareData,showShareData,showShareUser
         } from "@/api/bignote/index";
 import {listUserAll} from "@/api/root/index";
 import {getInfo} from "@/api/login";
 export default {
-  name: "Role",
+  name: "ZfEvent",
   dicts: ['sys_normal_disable'],
   data() {
     return {
+
+
+
+
+
+      // 鎴愬憳澶氶�夌浉鍏�
+      memberDialogVisible: false, // 寮圭獥鍙鎬�
+      familyMembers: [], // 瀹舵棌鎴愬憳鍒楄〃锛堝師濮嬫暟鎹級
+      selectedMemberIds: [], // 寮圭獥涓复鏃堕�変腑鐨勬垚鍛業D锛堢敤浜庡閫変氦浜掞級
+      memberSearch: '', // 鎴愬憳鎼滅储鍏抽敭璇�
+      loading: false, // 鍔犺浇鐘舵��
+		total1: 0,
       // 鍒嗕韩缁欒皝鐨刲ist
       listRoot: [],
       open1:false,
@@ -595,7 +680,7 @@
       dateRange: [],
       // 鏁版嵁鑼冨洿閫夐」
       fot:['.bmp','.jpg','.jpeg','.png','.tif','.gif','.pcx','.tga','.exif','.fpx',
-        '.svg','.psd','.cdr','.pcd','.dxf','.ufo','.eps','.ai','.aw','.WMF','.webp','.apng','.m4a'],
+        '.svg','.psd','.cdr','.pcd','.dxf','.ufo','.eps','.ai','.aw','.WMF','.webp','.apng','.m4a','.M4A'],
       fileList:[],
 	  fileList1:[],
 	  	  uploadFileList: [],
@@ -606,6 +691,7 @@
       uploading: false,
       formDat: {
         // type: undefined,
+        selectedMemberIds: [],
         title: undefined,
         location: undefined,
         holder: undefined,
@@ -637,6 +723,9 @@
       },
       // 琛ㄥ崟鏍¢獙
       rules: {
+        selectedMemberIds: [
+          { type: 'array', required: true, message: '璇疯嚦灏戦�夋嫨涓�鍚嶅鏃忔垚鍛�', trigger: 'change' }
+        ],
         title: [{
           required: true,
           message: '璇疯緭鍏ュぇ浜嬫爣棰�',
@@ -667,14 +756,43 @@
       typeOptions: [],
     };
   },
+
   created() {
     this.getList();
     //   this.getCateInfor()
     this.getInfo()
 
     this.getList1();
+
+
+  },
+  computed: {
+    // 宸查�夋垚鍛樺鍚嶏紙鐢ㄤ簬鍥炴樉锛�
+    selectedMemberNames() {
+      return this.familyMembers
+        .filter(member => this.selectedMemberIds.includes(member.userId))
+        .map(member => member.oldName);
+    },
+    // 杩囨护鍚庣殑鎴愬憳鍒楄〃锛堟悳绱㈠姛鑳斤級
+    filteredMembers() {
+      if (!this.memberSearch) return this.familyMembers;
+      console.log(this.familyMembers)
+      console.log("-sdf")
+      const keyword = this.memberSearch.toLowerCase();
+      return this.familyMembers;
+      //.filter(member =>
+     //   member.filteredMembers.toLowerCase().includes(keyword)
+        //||
+     //   member.role.toLowerCase().includes(keyword)
+    //  );
+    }
   },
   methods: {
+	  handleDialogClick()
+	  {
+	  	// 鍏抽棴鏃ユ湡閫夋嫨鍣�
+	  	      this.$refs.datePicker.handleClose();
+	  },
     // 鍒嗛〉
     fenYe(){
       // @pagination='ifNum === 1 ? selectValue : (ifNum === 2 ? whoShare : showData)'
@@ -806,21 +924,36 @@
     },
     getList1() {
           this.loading1 = true;
-          this.queryParams1.happenStartTime = this.dateRange1.length > 0 && this.dateRange1[0]
-          this.queryParams1.happenEndTime = this.dateRange1.length > 0 && this.dateRange1[1]
-          listUserAll(this.queryParams1).then(response => {
-              this.listRoot = response.data.data;
+		  let userId = this.$store.state.user.userId
+		//  alert(userId)
+		  this.userOptions = []
+		  showShareUser(userId, 2013).then(response=>{
+			  console.log("===========ddddddddddddd")
+			  console.log(response.data)
+			  console.log("--------------------")
+			  response.data.forEach(element =>{
+				   this.userOptions.push({label: element.oldName,value: element.userId})
+			  })
+		  })
+  //         this.queryParams1.happenStartTime = this.dateRange1.length > 0 && this.dateRange1[0]
+  //         this.queryParams1.happenEndTime = this.dateRange1.length > 0 && this.dateRange1[1]
+		// //  alert(this.$store.state.user.clanId)
+		//       this.listRoot = []
+		 let clanId = this.$store.state.user.clanId
+          getAllInfo(clanId).then(response => {
+              this.listRoot = response.data;
               const kon = {}
+			         console.log(response.data,'userListuserListuserList99999999999999')
               this.listRoot.forEach(element => {
                 kon[element['nickName']] = element['userId']
               })
-              for(let i in kon){
-                this.userOptions.push({label: i,value: kon[i]})
-              }
-              for(let i in this.userOptions){
-                this.userList.push(this.userOptions[i].value)
-              }
-              console.log(this.userList,'userListuserListuserList')
+              // for(let i in kon){
+              //   this.userOptions.push({label: i,value: kon[i]})
+              // }
+              // for(let i in this.userOptions){
+              //   this.userList.push(this.userOptions[i].value)
+              // }
+              // console.log(this.userList,'userListuserListuserList99999999999999')
               this.loading1 = false;
             }
           );
@@ -830,12 +963,22 @@
       const shareList = {}
       shareList.shareContents = this.id1 || this.ids;
       shareList.shareIds = this.ids1
+	  if(shareList.shareIds.length==0)
+	  {
+		  this.$modal.msgSuccess("璇烽�夋嫨鍒嗕韩瀵硅薄");
+		  return;
+	  }
       console.log(shareList,'sharelistsharelist')
+
+
+
+
       this.$modal.confirm('鏄惁纭鍒嗕韩锛�').then(function() {
         return share(shareList);
       }).then(() => {
 
         this.getList();
+		this.getList1();
         this.$modal.msgSuccess("鍒嗕韩鎴愬姛");
         this.id1 = undefined
         this.open1 = false;
@@ -860,8 +1003,16 @@
     isInFot(fileName) {
       return this.fot.includes(fileName);
     },
+
+	close(){
+		//alert(234)
+
+
+		this.open = false
+	},
     // 鍙栨秷鎸夐挳
     cancelData() {
+
       this.open = false;
       this.reset();
     },
@@ -969,6 +1120,7 @@
     /** 鏌ョ湅璇︾粏淇℃伅 */
     handleCheck(row){
       const id = row.id;
+	  this.open2 = false;
       this.$router.push("/familymodel/bignote/familyeventInfo/" + id);
     },
     /** 淇敼鎸夐挳鎿嶄綔 */
@@ -1030,6 +1182,10 @@
       // }).join(",")
       // this.formDat.url = ul+","+uls
 	//  alert(this.formDat.url)
+      //鎶婂悕瀛楄繛鍦ㄤ竴璧�
+      var pel = ""
+      pel = pel + this.selectedMemberNames.join(",")
+      this.formDat.people = pel;
       this.$refs["elForm"].validate(valid => {
         if (valid) {
 
@@ -1188,6 +1344,54 @@
         Message({ message: "瀵煎叆澶辫触", type: 'error' })
       }
 
+    },
+    // 鎵撳紑鎴愬憳澶氶�夊脊绐�
+    async openMemberDialog() {
+      this.memberDialogVisible = true;
+      this.memberSearch = ''; // 閲嶇疆鎼滅储
+      // 鍒濆鍖栧脊绐楅�変腑鐘舵�侊紙鍥炴樉宸查�夋垚鍛橈級
+  //    this.selectedMemberIds = [...this.familyForm.selectedMemberIds];
+      // 鍔犺浇瀹舵棌鎴愬憳鍒楄〃
+      await this.loadFamilyMembers();
+    },
+
+    // 鍔犺浇瀹舵棌鎴愬憳鍒楄〃
+    async loadFamilyMembers() {
+      this.loading = true;
+
+      let clanId = this.$store.state.user.clanId
+      try {
+        const res = await getFamilyMembers(clanId); // 鍋囪闇�瑕佸鏃廔D鍙傛暟
+
+
+    console.log(res)
+    console.log(res.data)
+       this.familyMembers = res.data;
+       // console.log(this.familyMembers.length)
+      //  console.log(this.familyMembers.length)
+       // console.log(this.familyMembers[0])
+        // for(let i=0; i < this.familyMembers.length; i++)
+        //   console.log(this.familyMembers[i])
+        // console.log("---999")
+        // 鏍煎紡锛歔{ id: 1, name: '寮犱笁', role: '瀹堕暱', relation: '鐖跺瓙', avatar: 'xxx' }, ...]
+      } catch (err) {
+        this.$message.error('鍔犺浇瀹舵棌鎴愬憳澶辫触锛岃閲嶈瘯');
+      } finally {
+        this.loading = false;
+      }
+    },
+
+    // 纭閫夋嫨鎴愬憳锛堜繚瀛樺埌琛ㄥ崟锛�
+    confirmMemberSelection() {
+      this.formDat.selectedMemberIds = [...this.selectedMemberIds]; // 灏嗗脊绐楅�変腑鐨処D鍚屾鍒拌〃鍗�
+      this.memberDialogVisible = false;
+      this.$modal.message(`宸查�夋嫨 ${this.selectedMemberNames.length} 鍚嶅鏃忔垚鍛榒);
+    },
+
+    // 绉婚櫎宸查�夋垚鍛樻爣绛�
+    handleTagClose(index) {
+      const removedId = this.familyForm.selectedMemberIds[index];
+      this.familyForm.selectedMemberIds = this.familyForm.selectedMemberIds.filter(id => id !== removedId);
     }
 
   }
@@ -1208,4 +1412,72 @@
 .button-container {
   display: inline-flex; /* 璁剧疆鎸夐挳瀹瑰櫒涓鸿鍐呭厓绱� */
 }
+
+
+/* 宸查�夋垚鍛樻爣绛炬牱寮� */
+.selected-members {
+  margin-bottom: 12px;
+  .el-tag {
+    margin-right: 8px;
+    margin-bottom: 8px;
+  }
+}
+
+/* 澶氶�夊脊绐楁牱寮� */
+.member-dialog-content {
+  max-height: 400px;
+  overflow-y: auto;
+  padding: 0 10px;
+}
+
+/* 鎴愬憳鍒楄〃鏍峰紡 */
+.member-checkbox-group {
+  .el-checkbox {
+    display: block;
+    padding: 12px;
+    border-bottom: 1px solid #f5f5f5;
+    &:last-child {
+      border-bottom: none;
+    }
+  }
+}
+
+/* 鎴愬憳椤规牱寮� */
+.member-item {
+  display: flex;
+  align-items: center;
+  .member-avatar {
+    width: 40px;
+    height: 40px;
+    border-radius: 50%;
+    margin-right: 12px;
+  }
+  .member-info {
+    .member-name {
+      font-weight: 500;
+      margin-bottom: 4px;
+    }
+    .member-role {
+      font-size: 12px;
+      color: #606266;
+    }
+  }
+}
+
+/* 鍔犺浇鐘舵�佹牱寮� */
+.loading-container {
+  text-align: center;
+  padding: 40px 0;
+  .el-loading-spinner {
+    margin-bottom: 16px;
+  }
+}
+.signature-checkbox
+{
+  margin-right: 15px;
+}
+/* 鏃犳暟鎹牱寮� */
+.no-data {
+  padding: 60px 0;
+}
 </style>

--
Gitblit v1.9.1