From 962f4ba1ac745ed4f7170bffc51d3386f48907a8 Mon Sep 17 00:00:00 2001 From: luoxiao Date: Fri, 6 Sep 2024 09:28:43 +0800 Subject: [PATCH] =?UTF-8?q?=E5=9B=BE=E5=B1=82=E5=88=97=E8=A1=A8ui=E8=B0=83?= =?UTF-8?q?=E6=95=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/common/_lang/en.js | 5 +- src/common/_lang/zh.js | 5 +- src/mapboxgl/web-map/LayerGroup.vue | 231 ++++++++++++++---- .../control/layer-list/style/layer-list.scss | 32 ++- 4 files changed, 219 insertions(+), 54 deletions(-) diff --git a/src/common/_lang/en.js b/src/common/_lang/en.js index b21f965f..6915e290 100644 --- a/src/common/_lang/en.js +++ b/src/common/_lang/en.js @@ -81,7 +81,10 @@ export default { unSupportedData: 'The current data does not support linkage with the map' }, layerList: { - title: 'Layer' + title: 'Layer', + layerStyle: "layerStyle", + attributes: "Attributes", + zoomToMap: "zoomToMap" }, slideshow: { title: 'Slideshow' diff --git a/src/common/_lang/zh.js b/src/common/_lang/zh.js index a7d7baf5..87e13804 100644 --- a/src/common/_lang/zh.js +++ b/src/common/_lang/zh.js @@ -82,7 +82,10 @@ export default { unSupportedData: '当前数据不支持与地图联动' }, layerList: { - title: '图层' + title: '图层', + layerStyle: "图层样式", + attributes: "属性表", + zoomToMap: "缩放至地图" }, slideshow: { title: '幻灯片' diff --git a/src/mapboxgl/web-map/LayerGroup.vue b/src/mapboxgl/web-map/LayerGroup.vue index 6ded08fa..879de0a7 100644 --- a/src/mapboxgl/web-map/LayerGroup.vue +++ b/src/mapboxgl/web-map/LayerGroup.vue @@ -1,57 +1,59 @@ @@ -59,13 +61,15 @@ import Theme from 'vue-iclient/src/common/_mixin/Theme'; import SmCollapse from 'vue-iclient/src/common/collapse/Collapse.vue'; import SmCollapsePanel from 'vue-iclient/src/common/collapse/Panel.vue'; +import SmTree from 'vue-iclient/src/common/tree/Tree.vue'; export default { name: 'LayerGroup', mixins: [Theme], components: { SmCollapse, - SmCollapsePanel + SmCollapsePanel, + SmTree }, props: { layerCatalog: { @@ -74,11 +78,28 @@ export default { return []; } }, + zoomToMap: { + type: Object, + default() { + return { + enabled: true + }; + } + }, attributes: { type: Object, default() { return {}; } + }, + layerStyle: { + type: Object, + default() { + return { + enabled: true, + opacity: 1 + }; + } } }, computed: { @@ -86,23 +107,131 @@ export default { return (this.attributes && this.attributes.iconClass) || 'sm-components-icon-attribute'; }, attributesEnabled() { - return (item) => { + return item => { const isGeojson = item.renderSource.type === 'geojson'; const isStructureData = item.dataSource.type === 'STRUCTURE_DATA'; return this.attributes.enabled && (isGeojson || isStructureData); }; + }, + treeData() { + const data = this.getTreeData(this.layerCatalog); + console.log(data); + return data; } }, + data() { + return { + showIcons: true, + showOpacity: false + }; + }, + mounted() { + // this.promise(); + }, methods: { + promise() { + // this.a = 2; + Promise.resolve().then(() => { + console.log('promise1'); + }); + this.$nextTick(() => { + console.log('nextTick1'); + }); + Promise.resolve().then(() => { + console.log('promise2'); + }); + this.$nextTick(() => { + console.log('nextTick2'); + }); + }, + getTreeData(data) { + const treeData = []; + data.map(item => { + const data = { ...item, scopedSlots: { title: 'custom' } }; + if (data.children) { + const children = this.getTreeData(data.children); + data.children = children; + } + console.log(item, data); + treeData.push(data); + }); + return treeData; + }, + sliderChange(val) {}, toggleItemVisibility(item) { + this.promise(); this.$emit('toggleItemVisibility', item, !item.visible); }, toggleAttributesVisibility(e, item) { this.$emit('toggleAttributesVisibility', e, item); + }, + toggleLayerStyleVisibility(e, item) { + this.promise(); + this.showOpacity = item.id; + }, + onDragEnter(info) { + console.log(info); + // expandedKeys 需要受控时设置 + // this.expandedKeys = info.expandedKeys + }, + onDrop(info) { + console.log(info); + const dropKey = info.node.eventKey; + const dragKey = info.dragNode.eventKey; + const dropPos = info.node.pos.split('-'); + const dropPosition = info.dropPosition - Number(dropPos[dropPos.length - 1]); + const loop = (data, key, callback) => { + data.forEach((item, index, arr) => { + if (item.key === key) { + return callback(item, index, arr); + } + if (item.children) { + return loop(item.children, key, callback); + } + }); + }; + const data = [...this.treeData]; + + // Find dragObject + let dragObj; + loop(data, dragKey, (item, index, arr) => { + arr.splice(index, 1); + dragObj = item; + }); + if (!info.dropToGap) { + // Drop on the content + loop(data, dropKey, item => { + item.children = item.children || []; + // where to insert 示例添加到尾部,可以是随意位置 + item.children.push(dragObj); + }); + } else if ( + (info.node.children || []).length > 0 && // Has children + info.node.expanded && // Is expanded + dropPosition === 1 // On the bottom gap + ) { + loop(data, dropKey, item => { + item.children = item.children || []; + // where to insert 示例添加到尾部,可以是随意位置 + item.children.unshift(dragObj); + }); + } else { + let ar; + let i; + loop(data, dropKey, (item, index, arr) => { + ar = arr; + i = index; + }); + if (dropPosition === -1) { + ar.splice(i, 0, dragObj); + } else { + ar.splice(i + 1, 0, dragObj); + } + } + this.treeData = data; } } }; - + diff --git a/src/mapboxgl/web-map/control/layer-list/style/layer-list.scss b/src/mapboxgl/web-map/control/layer-list/style/layer-list.scss index ac568571..14b08e64 100644 --- a/src/mapboxgl/web-map/control/layer-list/style/layer-list.scss +++ b/src/mapboxgl/web-map/control/layer-list/style/layer-list.scss @@ -18,6 +18,35 @@ border-radius: 0; color: inherit; } + & .sm-component-tree li span.sm-component-tree-switcher { + position: absolute; + right: 0; + top: 4px; + } + & .sm-component-tree > li { + position: relative; + } + & .sm-component-tree li span.sm-component-tree-switcher.sm-component-tree-switcher-noop { + display: none; + } + & .sm-component-tree-child-tree-open { + display: list-item; + } + & .sm-component-tree li .sm-component-tree-node-content-wrapper { + display: block; + width: 95%; + height: auto; + } + & .sm-component-tree-title { + display: block; + } + & .sm-component-tree-title .header-text { + display: inline-flex; + justify-content: space-between; + } + & .opacity-style { + width: 100%; + } } @include e(a-card) { padding-top: 4px; @@ -108,7 +137,8 @@ .header-wrap { justify-content: space-between; .header-text { - font-size: 0; + display: inline-flex; + justify-content: space-between; & > i, & > span { vertical-align: middle;