|
@@ -11,9 +11,13 @@
|
|
|
<el-button v-show="isEdit" size="small" style="float:right">保存</el-button>
|
|
|
<el-button v-show="isEdit" size="small" @click="isEdit = false" style="float:right">取消</el-button>
|
|
|
</div>
|
|
|
- <addSpaceDialog :dialogVisible.sync="dialogVisible" ref="addSpaceDialog" @refresh="refresh" :params="cenoteObj" :spaceType="spaceType" :floorType="floorType"></addSpaceDialog>
|
|
|
+ <addSpaceDialog :dialogVisible.sync="dialogVisible" ref="addSpaceDialog" @refresh="refresh" :params="cenoteObj" :spaceType="spaceType"
|
|
|
+ :floorType="floorType"></addSpaceDialog>
|
|
|
</div>
|
|
|
- <space-select @change="changeSpace"></space-select>
|
|
|
+ <el-select v-model="space" placeholder="请选择业务空间" @change="changeSpace" style="margin-left:15px;">
|
|
|
+ <el-option v-for="item in spaceList" :key="item.Code" :label="item.Name" :value="item.Code">
|
|
|
+ </el-option>
|
|
|
+ </el-select>
|
|
|
</div>
|
|
|
<div class="saga-build-tab">
|
|
|
<el-radio-group v-model="isMyTab" @change="changeRadio" style="width: 136px;">
|
|
@@ -21,23 +25,29 @@
|
|
|
<el-radio-button label="2" class="space-own-radio" style="width: 68px;">列表</el-radio-button>
|
|
|
</el-radio-group>
|
|
|
</div>
|
|
|
- <div v-show="isMyTab == 1" class="data-item">
|
|
|
- <el-select v-model="building" placeholder="请选择建筑" @change="changeBuilding">
|
|
|
+ <div v-if="isMyTab == 1" class="data-item">
|
|
|
+ <el-select v-model="building" placeholder="请选择建筑" @change="changeBuilding" v-loading="buildingLoading">
|
|
|
<el-option v-for="item in buildingList" :key="item.value" :label="item.BuildLocalName" :value="item.BuildID"></el-option>
|
|
|
</el-select>
|
|
|
<div style="height:calc(100% - 42px);margin:10px 0 0 0;width:100%;position:relative;">
|
|
|
- <el-scrollbar style="height:100%;width:149px;border-right:1px solid;margin:0px;">
|
|
|
- <div class="floor" style="width:149px;height:100%;">
|
|
|
- <span class="floor-item">楼 层</span>
|
|
|
- <div v-if="building">
|
|
|
- <span class="floor-item" @click="changeFloor(item.FloorID)" :class="{floorItemChoose:(item.FloorID == floor)}" v-for="item in buildingObj.Floor" :key="item.FloorID">{{ item.FloorLocalName }}</span>
|
|
|
+ <el-scrollbar style="height:100%;width:149px;border-right:1px solid;margin:0px;float:left;">
|
|
|
+ <div class="floor" style="width:149px;height:100%;">
|
|
|
+ <span class="floor-item">楼 层</span>
|
|
|
+ <div v-if="building" v-loading="buildingLoading">
|
|
|
+ <span class="floor-item" @click="changeFloor(item.FloorID)" :class="{floorItemChoose:(item.FloorID == floor)}"
|
|
|
+ v-for="item in buildingObj.Floor" :key="item.FloorID">{{ item.FloorLocalName }}</span>
|
|
|
+ </div>
|
|
|
</div>
|
|
|
- </div>
|
|
|
</el-scrollbar>
|
|
|
+ <div style="float:right;height:100%;width:calc(100% - 150px);">
|
|
|
+ <cenote-graphy></cenote-graphy>
|
|
|
+ </div>
|
|
|
</div>
|
|
|
+
|
|
|
</div>
|
|
|
- <div v-show="isMyTab == 2" class="data-item">
|
|
|
- <related-spaceList :space="space" ref="spacelist"></related-spaceList>
|
|
|
+ <div v-else class="data-item">
|
|
|
+ <related-spaceList :space="space" :buildingList="buildingList" :spaceType="spaceType" :floorType="floorType" ref="relatedSpacelist">
|
|
|
+ </related-spaceList>
|
|
|
</div>
|
|
|
</div>
|
|
|
</div>
|
|
@@ -47,20 +57,23 @@
|
|
|
import spaceSelect from "@/components/ledger/lib/spaceSelect";
|
|
|
import relatedSpaceList from "@/views/ledger/cenotelist/relatedSpaceList";
|
|
|
import addSpaceDialog from '@/components/ledger/cenote/dialog/addSpaceDialog';
|
|
|
-import { queryDictionaryHead, buildingQuery } from '@/api/scan/request'
|
|
|
+import { queryDictionaryHead, buildingQuery, shaftSpaceTypeQuery, shaftSpaceBuildingQuery } from '@/api/scan/request';
|
|
|
+import cenoteGraphy from '@/components/ledger/lib/cenoteGraphy'
|
|
|
export default {
|
|
|
data() {
|
|
|
return {
|
|
|
isMyTab: 1,//默认平面图
|
|
|
isEdit: false,//是否正在编辑
|
|
|
building: '',//当前建筑id
|
|
|
- buildingObj:{},//当前建筑obj
|
|
|
+ buildingObj: {},//当前建筑obj
|
|
|
buildingList: [],
|
|
|
space: '',//当前业务空间
|
|
|
+ spaceList: [],//空间list
|
|
|
floor: '',//当前楼层
|
|
|
dialogVisible: false,//添加空间弹窗
|
|
|
spaceType: {},//空间种类
|
|
|
floorType: {},//子组件楼层信息
|
|
|
+ buildingLoading:false,//左侧列表加载
|
|
|
}
|
|
|
},
|
|
|
computed: {
|
|
@@ -74,36 +87,105 @@ export default {
|
|
|
components: {
|
|
|
spaceSelect,
|
|
|
relatedSpaceList,
|
|
|
- addSpaceDialog
|
|
|
+ addSpaceDialog,
|
|
|
+ cenoteGraphy
|
|
|
},
|
|
|
created() {
|
|
|
this.load();
|
|
|
- let pa = {
|
|
|
- Filters: `parentId='Space'`
|
|
|
- }
|
|
|
- queryDictionaryHead(pa, res => {
|
|
|
- res.Content.map(t => {
|
|
|
- if (t.Name != "元空间") {
|
|
|
- this.spaceType[t.Code] = t.Name;
|
|
|
+ this.getSpaceData();
|
|
|
+ },
|
|
|
+ methods: {
|
|
|
+ //获取空间信息
|
|
|
+ getSpaceData() {
|
|
|
+ if (this.cenoteObj.onlyRead) {
|
|
|
+ let pa = {
|
|
|
+ shaftId: this.$route.query.ShaftId
|
|
|
}
|
|
|
- })
|
|
|
- });
|
|
|
-
|
|
|
- let param = {
|
|
|
- Cascade: [
|
|
|
- { Name: "floor" }
|
|
|
- ]
|
|
|
- };
|
|
|
- buildingQuery(param, res => {
|
|
|
- this.buildingList = res.Content;
|
|
|
- if(this.buildingList.length > 0){
|
|
|
+ shaftSpaceTypeQuery(pa, res => {
|
|
|
+ this.spaceList = res.Content.map(item => {
|
|
|
+ return { Code: item.ObjectType, Name: item.ObjectTypeName };
|
|
|
+ });
|
|
|
+ this.showDefaultSpace();
|
|
|
+ });
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ let pa = {
|
|
|
+ Filters: `parentId='Space'`
|
|
|
+ }
|
|
|
+ queryDictionaryHead(pa, res => {
|
|
|
+ this.spaceList = res.Content.map(t => {
|
|
|
+ if (t.Name != "元空间") {
|
|
|
+ this.spaceType[t.Code] = t.Name;
|
|
|
+ }
|
|
|
+ return t;
|
|
|
+ });
|
|
|
+ this.showDefaultSpace();
|
|
|
+ });
|
|
|
+ }
|
|
|
+ },
|
|
|
+ //默认显示第一个空间
|
|
|
+ showDefaultSpace() {
|
|
|
+ if (this.spaceList.length) {
|
|
|
+ this.space = this.spaceList[0].Code;
|
|
|
+ }
|
|
|
+ //处理空间类型
|
|
|
+ this.spaceList.map(item => {
|
|
|
+ if (item.Name != "元空间") {
|
|
|
+ this.spaceType[item.Code] = item.Name;
|
|
|
+ }
|
|
|
+ });
|
|
|
+ //加载楼层信息
|
|
|
+ this.loadBuildingData();
|
|
|
+ },
|
|
|
+ //获取楼层信息
|
|
|
+ loadBuildingData() {
|
|
|
+ if (this.cenoteObj.onlyRead) {
|
|
|
+ let param = {
|
|
|
+ ShaftId: this.$route.query.ShaftId,
|
|
|
+ ObjectType: this.space
|
|
|
+ };
|
|
|
+ this.buildingLoading = true;
|
|
|
+ shaftSpaceBuildingQuery(param, res => {
|
|
|
+ this.buildingLoading = false;
|
|
|
+ this.buildingList = res.Content;
|
|
|
+ this.buildingList = this.buildingList.map(item => {
|
|
|
+ item.Floor = item.FloorList;
|
|
|
+ item.BuildID = item.BuildingId;
|
|
|
+ item.BuildLocalName = item.BuildingName;
|
|
|
+ if (item.Floor) {
|
|
|
+ item.Floor = item.Floor.map(item => {
|
|
|
+ item.FloorID = item.FloorId;
|
|
|
+ item.FloorLocalName = item.FloorName;
|
|
|
+ return item;
|
|
|
+ })
|
|
|
+ }
|
|
|
+ return item;
|
|
|
+ })
|
|
|
+ this.handleBuildingData();
|
|
|
+ });
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ let param = {
|
|
|
+ Cascade: [
|
|
|
+ { Name: "floor" }
|
|
|
+ ]
|
|
|
+ };
|
|
|
+ buildingQuery(param, res => {
|
|
|
+ this.buildingList = res.Content;
|
|
|
+ this.handleBuildingData();
|
|
|
+ });
|
|
|
+ }
|
|
|
+ },
|
|
|
+ //处理建筑楼层数据
|
|
|
+ handleBuildingData() {
|
|
|
+ if (this.buildingList.length) {
|
|
|
this.building = this.buildingList[0].BuildID;
|
|
|
this.buildingObj = this.buildingList[0];
|
|
|
- if(this.buildingObj.Floor.length > 0){
|
|
|
+ if (this.buildingObj.Floor && this.buildingObj.Floor.length) {
|
|
|
this.floor = this.buildingObj.Floor[0].FloorID;
|
|
|
}
|
|
|
}
|
|
|
- res.Content.map(item => {
|
|
|
+ this.buildingList.map(item => {
|
|
|
if (item.BuildID && item.BuildLocalName) {
|
|
|
this.floorType[item.BuildID] = item.BuildLocalName;
|
|
|
if (item.Floor instanceof Array) {
|
|
@@ -115,39 +197,46 @@ export default {
|
|
|
}
|
|
|
}
|
|
|
});
|
|
|
- });
|
|
|
- },
|
|
|
- methods: {
|
|
|
+ },
|
|
|
//更改业务空间类型
|
|
|
changeSpace(val) {
|
|
|
this.space = val;
|
|
|
- this.load();
|
|
|
+ this.loadBuildingData();
|
|
|
},
|
|
|
//加载数据
|
|
|
load() {
|
|
|
- if (this.isMyTab == 1) {
|
|
|
-
|
|
|
- }
|
|
|
- else {
|
|
|
- this.$refs.spacelist.getSpaceList();
|
|
|
- }
|
|
|
+
|
|
|
},
|
|
|
//更换建筑
|
|
|
- changeBuilding(bid){
|
|
|
+ changeBuilding(bid) {
|
|
|
this.buildingList.map(item => {
|
|
|
- if(item.BuildID == bid){
|
|
|
+ if (item.BuildID == bid) {
|
|
|
this.buildingObj = item;
|
|
|
+ if(item.Floor && item.Floor.length){
|
|
|
+ this.floor = item.Floor[0].FloorID
|
|
|
+ }
|
|
|
}
|
|
|
})
|
|
|
this.load();
|
|
|
},
|
|
|
//更换楼层
|
|
|
- changeFloor(fid){
|
|
|
+ changeFloor(fid) {
|
|
|
this.floor = fid;
|
|
|
this.load();
|
|
|
},
|
|
|
//更换列表或平面图
|
|
|
changeRadio(val) {
|
|
|
+ if (val == 2) {
|
|
|
+ this.spaceList.unshift({ Code: '', Name: '全部' });
|
|
|
+ }
|
|
|
+ if (val == 1) {
|
|
|
+ if (this.spaceList.length > 0) {
|
|
|
+ this.spaceList.shift();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if(this.spaceList.length){
|
|
|
+ this.changeSpace(this.spaceList[0].Code);
|
|
|
+ }
|
|
|
this.isMyTab = val;
|
|
|
this.load();
|
|
|
},
|
|
@@ -159,7 +248,8 @@ export default {
|
|
|
},
|
|
|
//更新
|
|
|
refresh() {
|
|
|
- this.load();
|
|
|
+ this.$refs.relatedSpacelist.getSpaceList();
|
|
|
+ this.dialogVisible = false;
|
|
|
}
|
|
|
},
|
|
|
watch: {
|
|
@@ -252,9 +342,9 @@ export default {
|
|
|
cursor: pointer;
|
|
|
}
|
|
|
.floorItemChoose {
|
|
|
- background: rgba(0,0,0,0.2);
|
|
|
+ background: rgba(0, 0, 0, 0.2);
|
|
|
}
|
|
|
/deep/ .el-scrollbar__wrap {
|
|
|
- overflow-x: hidden;
|
|
|
- }
|
|
|
+ overflow-x: hidden;
|
|
|
+}
|
|
|
</style>
|