|
@@ -1,6 +1,7 @@
|
|
|
<template>
|
|
|
<div class="elements">
|
|
|
<div class="title" style="margin: 8px 0 0 12px">视图结构</div>
|
|
|
+
|
|
|
<t-tree
|
|
|
class="flex-grow"
|
|
|
ref="tree"
|
|
@@ -142,7 +143,7 @@ import { onBeforeMount, onBeforeUnmount, reactive, ref } from 'vue';
|
|
|
import { MessagePlugin } from 'tdesign-vue-next';
|
|
|
|
|
|
import { LockState, Pen } from '@meta2d/core';
|
|
|
-import { getPenTree, setChildrenVisible } from '@/services/common';
|
|
|
+import { getPenTree, inTreePanel, setChildrenVisible } from '@/services/common';
|
|
|
|
|
|
const tree = ref<any>(null);
|
|
|
const data = reactive<any>({
|
|
@@ -158,8 +159,16 @@ onBeforeMount(() => {
|
|
|
meta2d.on('redo', getTree);
|
|
|
meta2d.on('delete', getTree);
|
|
|
meta2d.on('combine', getTree);
|
|
|
+ meta2d.on('click', getActived);
|
|
|
+
|
|
|
+ if (inTreePanel.timer) {
|
|
|
+ clearTimeout(inTreePanel.timer);
|
|
|
+ inTreePanel.timer = undefined;
|
|
|
+ }
|
|
|
+ inTreePanel.value = true;
|
|
|
|
|
|
getTree();
|
|
|
+ getActived();
|
|
|
|
|
|
const d = meta2d.store.data as any;
|
|
|
if (!d.groups) {
|
|
@@ -172,6 +181,15 @@ const getTree = () => {
|
|
|
data.tree = getPenTree();
|
|
|
};
|
|
|
|
|
|
+const getActived = () => {
|
|
|
+ data.actived = [];
|
|
|
+ if (meta2d.store.active) {
|
|
|
+ for (const pen of meta2d.store.active) {
|
|
|
+ data.actived.push(pen.id);
|
|
|
+ }
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
const calcElem = (node: Pen) => {
|
|
|
if (!node) {
|
|
|
return;
|
|
@@ -300,6 +318,11 @@ onBeforeUnmount(() => {
|
|
|
meta2d.off('redo', getTree);
|
|
|
meta2d.off('delete', getTree);
|
|
|
meta2d.off('combine', getTree);
|
|
|
+ meta2d.on('click', getActived);
|
|
|
+
|
|
|
+ inTreePanel.timer = setTimeout(() => {
|
|
|
+ inTreePanel.value = false;
|
|
|
+ }, 1000);
|
|
|
});
|
|
|
</script>
|
|
|
<style lang="postcss" scoped>
|