You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
332 lines
10 KiB
332 lines
10 KiB
<template>
|
|
<div class="app-container">
|
|
<el-header>
|
|
<i class="el-icon-back" @click="goBack"></i>
|
|
资源目录管理
|
|
<span>/详情</span>
|
|
</el-header>
|
|
<el-container>
|
|
<div class="top">
|
|
<span class="title">图层资源目录详情</span>
|
|
<div class="directoryInfo">
|
|
<span> 图层资源目录名称:{{ directoryInfo.name }}</span>
|
|
<span> 图层资源目录编号: {{ directoryInfo.id }}</span>
|
|
<span> 图层数量: {{ pageOptions.total }}</span>
|
|
<span> 创建时间: {{ directoryInfo.pubDate }}</span>
|
|
<span> 创建人:{{ directoryInfo.createUser }} </span>
|
|
</div>
|
|
</div>
|
|
<div class="middle">
|
|
<el-button type="primary" plain @click="dialogFormVisible = true">添加图层</el-button>
|
|
<el-dialog :title="dialogTitle" :visible.sync="dialogFormVisible">
|
|
<el-form :model="editDataInfoForm">
|
|
<el-form-item label="服务类型" style="font-size: 1rem" :label-width="'120px'">
|
|
<el-select style="width: 80%" v-model="editDataInfoForm.serviceType" placeholder="请选择">
|
|
<el-option
|
|
v-for="item in serviceTypeOptions"
|
|
:key="item.value"
|
|
:label="item.label"
|
|
:value="item.value"
|
|
/>
|
|
</el-select>
|
|
</el-form-item>
|
|
|
|
<el-form-item label="服务名称" prop="serviceName" style="font-size: 1rem" :label-width="'120px'">
|
|
<el-input v-model.trim="editDataInfoForm.serviceName" style="width: 80%"></el-input>
|
|
</el-form-item>
|
|
<el-form-item label="服务别名" prop="serviceNameAlias" style="font-size: 1rem" :label-width="'120px'">
|
|
<el-input v-model.trim="editDataInfoForm.serviceNameAlias" style="width: 80%"></el-input>
|
|
</el-form-item>
|
|
<el-form-item label="服务地址" prop="serviceUrl" style="font-size: 1rem" :label-width="'120px'">
|
|
<el-input v-model.trim="editDataInfoForm.serviceUrl" style="width: 80%"></el-input>
|
|
</el-form-item>
|
|
<el-form-item
|
|
v-if="editDataInfoForm.serviceType === '030300'"
|
|
label="服务索引"
|
|
prop="serviceIndex"
|
|
style="font-size: 1rem"
|
|
:label-width="'120px'"
|
|
>
|
|
<el-input v-model="editDataInfoForm.serviceIndex" style="width: 80%"></el-input>
|
|
</el-form-item>
|
|
</el-form>
|
|
<div slot="footer" class="dialog-footer">
|
|
<el-button @click="dialogFormVisible = false">取 消</el-button>
|
|
<el-button type="primary" @click="saveOrUpdateLayer">确 定</el-button>
|
|
</div>
|
|
</el-dialog>
|
|
<div class="keyword-filter">
|
|
<el-input class="keyword-input" placeholder="请输入内容" v-model="keyword" clearable> </el-input>
|
|
<el-button class="search-btn">搜索</el-button>
|
|
</div>
|
|
</div>
|
|
<div class="content">
|
|
<el-table :data="tableData" stripe style="width: 100%">
|
|
<el-table-column
|
|
type="index"
|
|
:index="(index) => index + (pageOptions.pageNum - 1) * pageOptions.pageSize + 1"
|
|
label="序号"
|
|
width="50"
|
|
header-align="center"
|
|
></el-table-column>
|
|
<el-table-column prop="id" label="图层资源目录编号" width="350"> </el-table-column>
|
|
<el-table-column prop="serviceName" label="图层资源目录名称"> </el-table-column>
|
|
<el-table-column prop="pubDate" label="创建时间"> </el-table-column>
|
|
<el-table-column prop="createUser" label="创建人"> </el-table-column>
|
|
<el-table-column label="操作">
|
|
<template slot-scope="scope">
|
|
<el-button size="mini" @click="handleEdit(scope.$index, scope.row)">编辑</el-button>
|
|
<el-button size="mini" type="danger" @click="handleDelete(scope.row)">删除</el-button>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
<el-pagination
|
|
background
|
|
layout="prev, pager, next"
|
|
:current-page.sync="pageOptions.pageNum"
|
|
:total="pageOptions.total"
|
|
:page-size="pageOptions.pageSize"
|
|
@current-change="getLayerList"
|
|
>
|
|
</el-pagination>
|
|
</div>
|
|
</el-container>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import debounce from 'lodash/debounce';
|
|
import { saveOrUpdateLayerApi, getLayerListApi, deleteLayerApi } from '@/api/aiSupervision/layerConfigApi.js';
|
|
export default {
|
|
props: ['directoryInfo'],
|
|
data() {
|
|
return {
|
|
tableData: [],
|
|
editDataInfoForm: {
|
|
serviceType: '', //服务类型,wms/wmts/wfs/3d tiles/terrain
|
|
serviceUrl: '', //服务地址
|
|
serviceName: '', //服务名称
|
|
serviceNameAlias: '', //服务别名
|
|
serviceIndex: '', //服务索引
|
|
dirId: '',
|
|
dirNames: '',
|
|
tileSize: '256'
|
|
},
|
|
dialogTitle: '添加图层',
|
|
serviceTypeOptions: [
|
|
{
|
|
value: '021102',
|
|
label: 'ArcGISRest图层'
|
|
},
|
|
{
|
|
value: '030300',
|
|
label: 'WFS200'
|
|
},
|
|
{
|
|
value: '113200',
|
|
label: 'S3M图层'
|
|
},
|
|
{
|
|
value: '',
|
|
label: 'XYZ底图'
|
|
}
|
|
],
|
|
pageOptions: {
|
|
pageNum: 1,
|
|
pageSize: 8,
|
|
total: 0
|
|
},
|
|
dialogFormVisible: false, //是否显示对话框
|
|
keyword: ''
|
|
};
|
|
},
|
|
mounted() {
|
|
this.initData();
|
|
this.getLayerList();
|
|
},
|
|
methods: {
|
|
goBack() {
|
|
this.$emit('goback');
|
|
},
|
|
handleEdit(index, row) {
|
|
this.editDataInfoForm.id = row.id;
|
|
this.editDataInfoForm.serviceType = row.serviceType;
|
|
this.editDataInfoForm.serviceName = row.serviceName;
|
|
this.editDataInfoForm.serviceNameAlias = row.serviceNameAlias;
|
|
this.editDataInfoForm.serviceUrl = row.serviceUrl;
|
|
this.editDataInfoForm.serviceIndex = row.serviceIndex;
|
|
this.dialogTitle = '编辑图层';
|
|
this.dialogFormVisible = true;
|
|
},
|
|
|
|
handleDelete(row) {
|
|
this.$confirm('删除图层将同时删除该图层资源以及关联的图层数据,删除后将不可恢复,是否继续删除?', '提示', {
|
|
confirmButtonText: '确定',
|
|
cancelButtonText: '取消',
|
|
type: 'warning'
|
|
})
|
|
.then(async () => {
|
|
const res = await deleteLayerApi(row.id);
|
|
if (res.success) {
|
|
this.getLayerList();
|
|
this.$message({
|
|
type: 'success',
|
|
message: '删除成功!'
|
|
});
|
|
}
|
|
})
|
|
.catch(() => {
|
|
this.$message({
|
|
type: 'info',
|
|
message: '已取消删除'
|
|
});
|
|
});
|
|
},
|
|
// 获取图层列表
|
|
getLayerList() {
|
|
const params = {
|
|
pageNum: this.pageOptions.pageNum,
|
|
pageSize: this.pageOptions.pageSize,
|
|
data: {
|
|
serviceName: this.keyword,
|
|
dirId: this.directoryInfo.id
|
|
},
|
|
params: {
|
|
orderBy: 'pub_date',
|
|
sortBy: 'asc'
|
|
}
|
|
};
|
|
getLayerListApi(params).then((res) => {
|
|
this.pageOptions.total = res.total;
|
|
this.tableData = res.records;
|
|
});
|
|
},
|
|
async saveOrUpdateLayer() {
|
|
const reg = /^(\w|[\u4e00-\u9fa5]){3,30}$/g;
|
|
if (!reg.test(this.editDataInfoForm.serviceName)) {
|
|
this.$message({
|
|
type: 'info',
|
|
message: '格式有误,目录名称仅支持中文、数字、字母、下划线,最大长度不超过30'
|
|
});
|
|
return;
|
|
}
|
|
await saveOrUpdateLayerApi(this.editDataInfoForm);
|
|
this.getLayerList();
|
|
this.dialogFormVisible = false;
|
|
},
|
|
initData() {
|
|
this.editDataInfoForm.serviceUrl = '';
|
|
this.editDataInfoForm.serviceName = '';
|
|
this.editDataInfoForm.serviceNameAlias = '';
|
|
this.editDataInfoForm.serviceIndex = '';
|
|
|
|
this.editDataInfoForm.serviceType = this.serviceTypeOptions[0].value;
|
|
this.editDataInfoForm.dirId = this.directoryInfo.id;
|
|
this.editDataInfoForm.dirNames = this.directoryInfo.name;
|
|
this.editDataInfoForm.tileSize = '256';
|
|
this.dialogTitle = '添加图层';
|
|
}
|
|
},
|
|
created() {
|
|
// 使用 lodash 的 debounce 函数创建防抖版本
|
|
this.debouncedGetLayerList = debounce(this.getLayerList, 500);
|
|
},
|
|
watch: {
|
|
keyword() {
|
|
this.debouncedGetLayerList();
|
|
},
|
|
dialogFormVisible(val) {
|
|
if (val === false) {
|
|
this.initData();
|
|
}
|
|
}
|
|
}
|
|
};
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
.app-container {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 15px;
|
|
}
|
|
header,
|
|
.el-container,
|
|
aside {
|
|
background-color: #fff;
|
|
}
|
|
header {
|
|
display: flex;
|
|
align-items: center;
|
|
border-radius: 10px;
|
|
gap: 10px;
|
|
box-shadow: rgba(17, 12, 46, 0.15) 0px 48px 100px 0px;
|
|
.el-icon-back {
|
|
cursor: pointer;
|
|
&:hover {
|
|
color: rgb(135, 231, 140);
|
|
}
|
|
}
|
|
span {
|
|
color: #999;
|
|
font-style: italic;
|
|
font-size: 14px;
|
|
}
|
|
}
|
|
.el-container {
|
|
flex: 1;
|
|
overflow-y: auto;
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 10px;
|
|
padding: 20px;
|
|
padding-top: 5px;
|
|
border-radius: 3px;
|
|
box-shadow: rgba(17, 12, 46, 0.15) 0px 48px 100px 0px;
|
|
.top {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 15px;
|
|
padding: 20px 40px;
|
|
width: 100%;
|
|
border-bottom: 2px solid #d9d9d9;
|
|
.title {
|
|
font-weight: bold;
|
|
font-size: 16px;
|
|
}
|
|
.directoryInfo {
|
|
display: grid;
|
|
grid-template-columns: 1fr 1fr 1fr;
|
|
grid-gap: 5px 10px;
|
|
}
|
|
}
|
|
.middle {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
.keyword-filter {
|
|
display: flex;
|
|
border-radius: 4px;
|
|
border: 1px solid #d9d9d9;
|
|
|
|
::v-deep .el-input__inner {
|
|
border: none;
|
|
}
|
|
.search-btn {
|
|
border: none;
|
|
border-radius: 0px;
|
|
border-left: 1px solid #d9d9d9;
|
|
}
|
|
}
|
|
}
|
|
.content {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 10px;
|
|
justify-content: space-between;
|
|
flex: 1;
|
|
.el-pagination {
|
|
text-align: center;
|
|
}
|
|
}
|
|
}
|
|
</style>
|
|
|