| 
									
										
										
										
											2024-12-27 21:08:26 +08:00
										 |  |  | <template> | 
					
						
							|  |  |  |   <div class="left"> | 
					
						
							| 
									
										
										
										
											2024-12-28 14:25:23 +08:00
										 |  |  |     <CCDock name="Hierarchy"> | 
					
						
							|  |  |  |       <CCInput style="flex: none" placeholder="enter keywords to filter" :data="filterText" v-if="false"> | 
					
						
							|  |  |  |         <slot> | 
					
						
							|  |  |  |           <i class="matchCase iconfont icon_font_size" @click.stop="onChangeCase" title="match case" :style="{ color: matchCase ? 'red' : '' }"></i> | 
					
						
							|  |  |  |         </slot> | 
					
						
							|  |  |  |       </CCInput> | 
					
						
							|  |  |  |       <CCTree style="flex: 1" ref="elTree" :expand-keys="expandedKeys" :default-expand-all="false" :value="treeData" @node-expand="onNodeExpand" @node-collapse="onNodeCollapse" @node-click="handleNodeClick" @node-unclick="handleNodeUnclick"></CCTree> | 
					
						
							|  |  |  |     </CCDock> | 
					
						
							| 
									
										
										
										
											2024-12-27 21:08:26 +08:00
										 |  |  |   </div> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | <script lang="ts"> | 
					
						
							|  |  |  | import ccui from "@xuyanfeng/cc-ui"; | 
					
						
							|  |  |  | import { storeToRefs } from "pinia"; | 
					
						
							| 
									
										
										
										
											2024-12-28 14:25:23 +08:00
										 |  |  | import { defineComponent, nextTick, onMounted, onUnmounted, ref, toRaw, watch } from "vue"; | 
					
						
							|  |  |  | import { Msg, PluginEvent, RequestNodeInfoData, RequestTreeInfoData, ResponseSetPropertyData } from "../../core/types"; | 
					
						
							| 
									
										
										
										
											2024-12-27 21:08:26 +08:00
										 |  |  | import { bridge } from "./bridge"; | 
					
						
							|  |  |  | import { Bus, BusMsg } from "./bus"; | 
					
						
							|  |  |  | import { EngineData, TreeData } from "./data"; | 
					
						
							| 
									
										
										
										
											2024-12-28 14:25:23 +08:00
										 |  |  | import { appStore } from "./store"; | 
					
						
							|  |  |  | import { Timer } from "./timer"; | 
					
						
							|  |  |  | const { CCTree, CCFootBar, CCDock, CCDialog, CCInput, CCButton, CCInputNumber, CCSelect, CCButtonGroup, CCCheckBox, CCColor, CCDivider } = ccui.components; | 
					
						
							| 
									
										
										
										
											2024-12-27 21:08:26 +08:00
										 |  |  | export default defineComponent({ | 
					
						
							|  |  |  |   name: "hierarchy", | 
					
						
							| 
									
										
										
										
											2024-12-28 14:25:23 +08:00
										 |  |  |   components: { CCButtonGroup, CCInput, CCTree, CCDock }, | 
					
						
							| 
									
										
										
										
											2024-12-27 21:08:26 +08:00
										 |  |  |   setup() { | 
					
						
							| 
									
										
										
										
											2024-12-28 14:25:23 +08:00
										 |  |  |     onMounted(() => {}); | 
					
						
							| 
									
										
										
										
											2024-12-27 21:08:26 +08:00
										 |  |  |     Bus.on(BusMsg.ShowPlace, (data: EngineData) => { | 
					
						
							|  |  |  |       console.log(toRaw(data)); | 
					
						
							|  |  |  |       _expand(data.engineUUID); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2024-12-28 14:25:23 +08:00
										 |  |  |     Bus.on(BusMsg.EnableSchedule, (b: boolean) => { | 
					
						
							|  |  |  |       if (b) { | 
					
						
							|  |  |  |         timer.create(); | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         timer.clean(); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-12-27 21:08:26 +08:00
										 |  |  |     }); | 
					
						
							| 
									
										
										
										
											2024-12-28 14:25:23 +08:00
										 |  |  |     const timer: Timer = new Timer(() => { | 
					
						
							|  |  |  |       updateTree(); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |     onMounted(() => { | 
					
						
							|  |  |  |       timer.create(); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |     onUnmounted(() => { | 
					
						
							|  |  |  |       timer.clean(); | 
					
						
							| 
									
										
										
										
											2024-12-27 21:08:26 +08:00
										 |  |  |     }); | 
					
						
							|  |  |  |     function _expand(uuid: string) { | 
					
						
							|  |  |  |       let expandKeys: Array<string> = []; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       function circle(array: any) { | 
					
						
							|  |  |  |         for (let i = 0; i < array.length; i++) { | 
					
						
							|  |  |  |           let item = array[i]; | 
					
						
							|  |  |  |           expandKeys.push(item.uuid); | 
					
						
							|  |  |  |           if (item.uuid === uuid) { | 
					
						
							|  |  |  |             return true; | 
					
						
							|  |  |  |           } else { | 
					
						
							|  |  |  |             let find = circle(item.children); | 
					
						
							|  |  |  |             if (find) { | 
					
						
							|  |  |  |               return true; | 
					
						
							|  |  |  |             } else { | 
					
						
							|  |  |  |               expandKeys.pop(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       circle(treeData); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expandKeys.forEach((key) => { | 
					
						
							|  |  |  |         if (!expandedKeys.value.find((el) => el === key)) { | 
					
						
							|  |  |  |           expandedKeys.value.push(key); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |       // 高亮uuid
 | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-12-28 14:25:23 +08:00
										 |  |  |     function updateTree() { | 
					
						
							|  |  |  |       console.log("update tree info"); | 
					
						
							| 
									
										
										
										
											2024-12-27 21:08:26 +08:00
										 |  |  |       const id = toRaw(frameID.value); | 
					
						
							|  |  |  |       bridge.send(Msg.RequstTreeInfo, { frameID: id } as RequestTreeInfoData); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-12-28 14:25:23 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-27 21:08:26 +08:00
										 |  |  |     function updateFilterText(val: any) { | 
					
						
							|  |  |  |       (elTree.value as any)?.filter(val); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     const filterText = ref<string>(""); | 
					
						
							|  |  |  |     watch(filterText, (val) => { | 
					
						
							|  |  |  |       // TODO: 过滤树
 | 
					
						
							|  |  |  |       updateFilterText(val); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |     const { config, frameID } = storeToRefs(appStore()); | 
					
						
							|  |  |  |     const matchCase = ref<boolean>(false); | 
					
						
							|  |  |  |     const elTree = ref<typeof CCTree>(); | 
					
						
							|  |  |  |     const treeData = ref<TreeData[]>([]); | 
					
						
							|  |  |  |     function updateNodeInfo() { | 
					
						
							|  |  |  |       if (selectedUUID) { | 
					
						
							|  |  |  |         bridge.send(Msg.RequestNodeInfo, { uuid: selectedUUID } as RequestNodeInfoData); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     let selectedUUID: string | null = null; | 
					
						
							| 
									
										
										
										
											2024-12-28 14:25:23 +08:00
										 |  |  |     bridge.on(Msg.ResponseTreeInfo, (event: PluginEvent) => { | 
					
						
							|  |  |  |       let data: Array<TreeData> = event.data; | 
					
						
							| 
									
										
										
										
											2024-12-27 21:08:26 +08:00
										 |  |  |       if (!Array.isArray(data)) { | 
					
						
							|  |  |  |         data = [data]; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       treeData.value = data; | 
					
						
							| 
									
										
										
										
											2024-12-28 14:25:23 +08:00
										 |  |  |       nextTick(() => { | 
					
						
							|  |  |  |         if (elTree.value) { | 
					
						
							|  |  |  |           elTree.value.handChoose(selectedUUID); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2024-12-27 21:08:26 +08:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-28 14:25:23 +08:00
										 |  |  |     bridge.on(Msg.ResponseSetProperty, (event: PluginEvent) => { | 
					
						
							|  |  |  |       let data: ResponseSetPropertyData = event.data; | 
					
						
							| 
									
										
										
										
											2024-12-27 21:08:26 +08:00
										 |  |  |       const uuid = data.path[0]; | 
					
						
							|  |  |  |       const key = data.path[1]; | 
					
						
							|  |  |  |       const value = data.data; | 
					
						
							|  |  |  |       let treeArray: Array<TreeData> = []; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       function circle(array: Array<TreeData>) { | 
					
						
							|  |  |  |         array.forEach((item) => { | 
					
						
							|  |  |  |           treeArray.push(item); | 
					
						
							|  |  |  |           circle(item.children); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // 更新指定uuid节点的tree的name
 | 
					
						
							|  |  |  |       circle(treeData.value); | 
					
						
							|  |  |  |       let ret = treeArray.find((el) => el.id === uuid); | 
					
						
							|  |  |  |       if (ret) { | 
					
						
							|  |  |  |         if (key === "name") { | 
					
						
							|  |  |  |           ret.text = value; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (key === "active") { | 
					
						
							|  |  |  |           ret.active = !!value; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |     const expandedKeys = ref<Array<string>>([]); | 
					
						
							|  |  |  |     return { | 
					
						
							|  |  |  |       expandedKeys, | 
					
						
							|  |  |  |       elTree, | 
					
						
							|  |  |  |       filterText, | 
					
						
							|  |  |  |       treeData, | 
					
						
							|  |  |  |       matchCase, | 
					
						
							|  |  |  |       frameID, | 
					
						
							| 
									
										
										
										
											2024-12-28 14:25:23 +08:00
										 |  |  |       handleNodeUnclick() { | 
					
						
							|  |  |  |         selectedUUID = null; | 
					
						
							|  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2024-12-27 21:08:26 +08:00
										 |  |  |       handleNodeClick(data: TreeData | null) { | 
					
						
							|  |  |  |         if (data) { | 
					
						
							|  |  |  |           selectedUUID = data.id; | 
					
						
							|  |  |  |           updateNodeInfo(); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |           selectedUUID = null; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       onNodeExpand(data: TreeData) { | 
					
						
							|  |  |  |         if (data.id) { | 
					
						
							|  |  |  |           expandedKeys.value.push(data.id); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       onNodeCollapse(data: TreeData) { | 
					
						
							|  |  |  |         if (data.id) { | 
					
						
							|  |  |  |           const keys = toRaw(expandedKeys.value); | 
					
						
							|  |  |  |           const index = keys.findIndex((el) => el === data.id); | 
					
						
							|  |  |  |           if (index !== -1) { | 
					
						
							|  |  |  |             keys.splice(index, 1); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           expandedKeys.value = keys; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       // TODO: 暂时这个版本先不实现
 | 
					
						
							|  |  |  |       filterNode(value: any, data: any) { | 
					
						
							|  |  |  |         if (!value) { | 
					
						
							|  |  |  |           return true; | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |           if (matchCase) { | 
					
						
							|  |  |  |             // 严格匹配大写
 | 
					
						
							|  |  |  |             return data?.name?.indexOf(value) !== -1; | 
					
						
							|  |  |  |           } else { | 
					
						
							|  |  |  |             return data?.name?.toLowerCase().indexOf(value.toLowerCase()) !== -1; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       onChangeCase() { | 
					
						
							|  |  |  |         matchCase.value = !matchCase.value; | 
					
						
							|  |  |  |         updateFilterText(filterText); | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | <style lang="less" scoped> | 
					
						
							|  |  |  | .left { | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  |   flex-direction: column; | 
					
						
							|  |  |  |   min-width: 200px; | 
					
						
							|  |  |  |   width: 300px; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .matchCase { | 
					
						
							|  |  |  |     width: 30px; | 
					
						
							|  |  |  |     height: 26px; | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     flex-direction: row; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							|  |  |  |     justify-content: center; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </style> |