From f1a26e581a121af4b4dc85a8394193e1e978c1d6 Mon Sep 17 00:00:00 2001
From: MrShi <1878285526@qq.com>
Date: 星期六, 08 二月 2025 18:16:10 +0800
Subject: [PATCH] 改bug
---
 admin/src/views/project/components/OperaYwRoomWindow.vue |   75 ++++++++++++++++++++++++++++++++++---
 1 files changed, 69 insertions(+), 6 deletions(-)
diff --git a/admin/src/views/project/components/OperaYwRoomWindow.vue b/admin/src/views/project/components/OperaYwRoomWindow.vue
index d48a984..1ed0a57 100644
--- a/admin/src/views/project/components/OperaYwRoomWindow.vue
+++ b/admin/src/views/project/components/OperaYwRoomWindow.vue
@@ -1,5 +1,5 @@
 <template>
-  <GlobalWindow :title="title" :visible.sync="visible" :confirm-working="isWorking" @confirm="confirm">
+  <GlobalWindow width="720px" :title="title" :visible.sync="visible" :confirm-working="isWorking" @confirm="confirm">
     <el-form :model="form" ref="form" :rules="rules">
       <el-form-item label="鎵�灞為」鐩�" prop="projectId">
         <el-select v-model="form.projectId" @change="changeProject" placeholder="璇烽�夋嫨椤圭洰" clearable>
@@ -7,12 +7,14 @@
         </el-select>
       </el-form-item>
       <el-form-item label="鎵�灞炴ゼ瀹�" prop="buildingId">
-        <el-select v-model="form.buildingId" placeholder="璇烽�夋嫨妤煎畤" clearable>
+        <el-select v-model="form.buildingId" @change="changeBuild" placeholder="璇烽�夋嫨妤煎畤" clearable>
           <el-option v-for="item in buildList" :key="item.id" :label="item.name" :value="item.id"></el-option>
         </el-select>
       </el-form-item>
       <el-form-item label="妤煎眰" prop="floor">
-        <el-input v-model="form.floor" placeholder="璇疯緭鍏ユゼ灞�" v-trim />
+        <el-select v-model="form.floor" placeholder="璇烽�夋嫨妤煎眰" clearable>
+          <el-option v-for="item in floorList" :key="item.id" :label="item.name" :value="item.id"></el-option>
+        </el-select>
       </el-form-item>
       <el-form-item label="鎴垮彿" prop="roomNum">
         <el-input v-model="form.roomNum" placeholder="璇疯緭鍏ユ埧鍙�" v-trim />
@@ -21,7 +23,7 @@
         <el-input v-model="form.code" placeholder="璇疯緭鍏ユ埧闂寸紪鍙�" v-trim />
       </el-form-item>
       <el-form-item label="鏄惁鎷涘晢" prop="isInvestment">
-        <el-switch v-model="form.isInvestment" active-value="1" inactive-value="0">
+        <el-switch v-model="form.isInvestment" :active-value="1" :inactive-value="0">
         </el-switch>
       </el-form-item>
       <el-form-item label="寤虹瓚闈㈢Н(m虏)" prop="area">
@@ -42,6 +44,8 @@
 import GlobalWindow from '@/components/common/GlobalWindow'
 import { getProjectList } from '@/api/project/ywProject'
 import { getBuildList } from '@/api/project/ywBuilding'
+import { getFloorList } from '@/api/project/yeFloor'
+import { detailById } from '@/api/project/ywRoom'
 export default {
   name: 'OperaYwRoomWindow',
   extends: BaseOpera,
@@ -63,7 +67,7 @@
         imgurl: '',
         code: '',
         roomNum: '',
-        isInvestment: '0',
+        isInvestment: 0,
         area: '',
         feeArea: '',
         rentArea: '',
@@ -83,6 +87,7 @@
       },
       projectList: [],
       buildList: [],
+      floorList: [],
     }
   },
   created() {
@@ -92,16 +97,74 @@
     })
   },
   methods: {
+    open(title, target, type) {
+      this.title = title
+      this.visible = true
+      this.getProject()
+      this.buildList = []
+      this.floorList = []
+      // 鏂板缓缁勭粐
+      if (target == null) {
+        this.$nextTick(() => {
+          this.$refs.form.resetFields()
+          this.form[this.configData['field.id']] = null
+          this.form.type = type
+        })
+        return
+      }
+      // 缂栬緫
+      this.$nextTick(() => {
+        this.getDetail(target.id)
+      })
+    },
+    confirm() {
+      if (!this.form.feeArea) {
+        this.form.feeArea = this.form.rentArea
+      }
+      if (this.form.id == null || this.form.id === '') {
+        this.__confirmCreate()
+        return
+      }
+      this.__confirmEdit()
+    },
+    getDetail(id) {
+      detailById(id).then(res => {
+        this.form = res || {}
+        if (res.projectId) {
+          getBuildList({ projectId: res.projectId }).then(res => {
+            this.buildList = res || []
+          })
+        }
+        if (res.buildingId) {
+          getFloorList({ buildingId: res.buildingId }).then(res => {
+            this.floorList = res || []
+          })
+        }
+      })
+    },
     getProject() {
       getProjectList({}).then(res => {
         this.projectList = res || []
+        if (this.projectList.length > 0) {
+          this.$set(this.form, 'projectId', this.projectList[0].id)
+          this.changeProject(this.projectList[0].id)
+        }
       })
 
     },
     changeProject(e) {
       this.form.buildingId = ''
-      getBuildList({id: e}).then(res => {
+      getBuildList({ projectId: e }).then(res => {
         this.buildList = res || []
+        // if(this.buildList.length > 0){
+        //   this.form.buildingId = this.buildList[0].id
+        // }
+      })
+    },
+    changeBuild(e) {
+      this.form.floor = ''
+      getFloorList({ buildingId: e }).then(res => {
+        this.floorList = res || []
       })
     },
   }
--
Gitblit v1.9.3