提交
This commit is contained in:
		| @ -210,16 +210,21 @@ function createWindow(): void { | |||||||
|     } |     } | ||||||
|     * */ |     * */ | ||||||
|  |  | ||||||
|     console.log('GetHomeDir()', GetHomeDir()) |     // console.log('GetHomeDir()', GetHomeDir()) | ||||||
|  |     let prefix = | ||||||
|  |     process.env.NODE_ENV === "development" | ||||||
|  |       ? "src/renderer/public" | ||||||
|  |       : "resources/app.asar/out/renderer"; | ||||||
|     let data = {}; |     let data = {}; | ||||||
|     for (const objKey in obj) { |     for (const objKey in obj) { | ||||||
|       let files = fs.readdirSync( |       let files = fs.readdirSync( | ||||||
|         path.join( |         path.join( | ||||||
|           global.__static ? global.__static : GetHomeDir() + "/src/renderer/public", |           GetHomeDir(), | ||||||
|  |           prefix, | ||||||
|           obj[objKey] |           obj[objKey] | ||||||
|         ) |         ) | ||||||
|       ); |       ); | ||||||
|       console.log(files); |       // console.log(files); | ||||||
|       for (let i = 0; i < files.length; i++) { |       for (let i = 0; i < files.length; i++) { | ||||||
|         files[i] = obj[objKey] + "/" + files[i]; |         files[i] = obj[objKey] + "/" + files[i]; | ||||||
|       } |       } | ||||||
|  | |||||||
							
								
								
									
										1
									
								
								src/renderer/components.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								src/renderer/components.d.ts
									
									
									
									
										vendored
									
									
								
							| @ -9,7 +9,6 @@ export {} | |||||||
| declare module 'vue' { | declare module 'vue' { | ||||||
|   export interface GlobalComponents { |   export interface GlobalComponents { | ||||||
|     BaseDialog: typeof import('./src/components/dialog/baseDialog.vue')['default'] |     BaseDialog: typeof import('./src/components/dialog/baseDialog.vue')['default'] | ||||||
|     copy: typeof import('./src/components/dialog/directory copy.vue')['default'] |  | ||||||
|     Directory: typeof import('./src/components/dialog/directory.vue')['default'] |     Directory: typeof import('./src/components/dialog/directory.vue')['default'] | ||||||
|     DirectoryEdit: typeof import('./src/components/dialog/directoryEdit.vue')['default'] |     DirectoryEdit: typeof import('./src/components/dialog/directoryEdit.vue')['default'] | ||||||
|     ElButton: typeof import('element-plus/es')['ElButton'] |     ElButton: typeof import('element-plus/es')['ElButton'] | ||||||
|  | |||||||
| @ -106,7 +106,7 @@ export const initMapData = async (type, data, cd) => { | |||||||
|       entityObject = new YJ.Obj.RadarScanStereoscopic(window.earth, data) |       entityObject = new YJ.Obj.RadarScanStereoscopic(window.earth, data) | ||||||
|       break |       break | ||||||
|     case 'textBox': |     case 'textBox': | ||||||
|       entityObject = new YJ.Obj.TextBox(window.earth, data, ()=>{}) |       entityObject = new YJ.Obj.TextBox(window.earth, data, () => { }) | ||||||
|       break |       break | ||||||
|     case 'polyhedronObject': |     case 'polyhedronObject': | ||||||
|       entityObject = new YJ.Obj.PolyhedronObject(window.earth, data) |       entityObject = new YJ.Obj.PolyhedronObject(window.earth, data) | ||||||
| @ -129,7 +129,7 @@ export const initMapData = async (type, data, cd) => { | |||||||
|     case 'flyLine': |     case 'flyLine': | ||||||
|       entityObject = new YJ.Obj.FlowLine(window.earth, data) |       entityObject = new YJ.Obj.FlowLine(window.earth, data) | ||||||
|       break |       break | ||||||
|       case 'explosion': |     case 'explosion': | ||||||
|       entityObject = new YJ.Obj.Explosion(window.earth, data) |       entityObject = new YJ.Obj.Explosion(window.earth, data) | ||||||
|       break |       break | ||||||
|     default: |     default: | ||||||
| @ -137,31 +137,37 @@ export const initMapData = async (type, data, cd) => { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   if (entityObject) { |   if (entityObject) { | ||||||
|     options = structuredClone(entityObject.options) |     function getOptions() { | ||||||
|     delete options.host |       let opt = structuredClone(entityObject.options) | ||||||
|     switch (type) { |       delete opt.host | ||||||
|       case 'textBox': |       switch (type) { | ||||||
|         delete options.name |         case 'textBox': | ||||||
|         break |           delete opt.name | ||||||
|       case 'fountain': |           break | ||||||
|       case 'fire': |         case 'fountain': | ||||||
|       case 'smoke': |         case 'fire': | ||||||
|       case 'waterL': |         case 'smoke': | ||||||
|         delete options.url |         case 'waterL': | ||||||
|         break |           delete opt.url | ||||||
|       default: |           break | ||||||
|         break |         default: | ||||||
|  |           break | ||||||
|  |       } | ||||||
|  |       return opt | ||||||
|     } |     } | ||||||
|  |     options = getOptions() | ||||||
|     console.log('--------------------onClick') |     console.log('--------------------onClick') | ||||||
|     //鼠标左键点击事件 |     //鼠标左键点击事件 | ||||||
|     entityObject.onClick = () => { |     entityObject.onClick = () => { | ||||||
|       // console.log('onClick') |       // console.log('onClick') | ||||||
|       leftClick(options); |       leftClick(getOptions()); | ||||||
|     }; |     }; | ||||||
|     //鼠标右键点击事件 |     //鼠标右键点击事件 | ||||||
|     entityObject.onRightClick = () => { |     entityObject.onRightClick = () => { | ||||||
|       rightClick(options); |       rightClick(getOptions()); | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|  |      | ||||||
|   } |   } | ||||||
|   // options = entityObject |   // options = entityObject | ||||||
|   return options |   return options | ||||||
|  | |||||||
| @ -1,5 +1,5 @@ | |||||||
| <template> | <template> | ||||||
|   <div class="adddirectory"> |   <div class="editdirectoryBox"> | ||||||
|     <div class="box"> |     <div class="box"> | ||||||
|       <div class="boxHeader nav"> |       <div class="boxHeader nav"> | ||||||
|         <!-- <span></span> --> |         <!-- <span></span> --> | ||||||
| @ -19,7 +19,7 @@ | |||||||
|           <el-form-item> |           <el-form-item> | ||||||
|             <div class="btnOption"> |             <div class="btnOption"> | ||||||
|               <el-button type="primary" @click="submitForm(ruleForm)">确定</el-button> |               <el-button type="primary" @click="submitForm(ruleForm)">确定</el-button> | ||||||
|               <el-button @click="cancel">取消</el-button> |               <el-button @click="close">取消</el-button> | ||||||
|             </div> |             </div> | ||||||
|           </el-form-item> |           </el-form-item> | ||||||
|         </el-form> |         </el-form> | ||||||
| @ -34,10 +34,11 @@ import { throttle } from '@/utils/index' | |||||||
| import { ElMessage, FormInstance } from 'element-plus' | import { ElMessage, FormInstance } from 'element-plus' | ||||||
| import { TreeApi } from '@/api/tree' | import { TreeApi } from '@/api/tree' | ||||||
| import { useTreeNode } from '@/views/components/tree/hooks/treeNode' | import { useTreeNode } from '@/views/components/tree/hooks/treeNode' | ||||||
| const { getKeyOfSelectedNode, getSelectedNode, cusAddNodes, getSameLevel } = useTreeNode() | const { getKeyOfSelectedNode, getSelectedNode, cusUpdateNode, getSameLevel, getSelectedNodes } = useTreeNode() | ||||||
| const title = ref('编辑节点') | const title = ref('编辑节点') | ||||||
|  | const sourceId = ref('') | ||||||
| let form: any = reactive({ | let form: any = reactive({ | ||||||
|   sourceName: '图层' |   sourceName: '' | ||||||
| }) | }) | ||||||
| const ruleForm = ref() | const ruleForm = ref() | ||||||
| const rules = reactive({ | const rules = reactive({ | ||||||
| @ -47,7 +48,10 @@ const removeSpaces = (value: string) => { | |||||||
|   form.sourceName = value.replace(/\s/g, '') |   form.sourceName = value.replace(/\s/g, '') | ||||||
| } | } | ||||||
| const close = () => { | const close = () => { | ||||||
|   $changeComponentPop('.adddirectory', false) |   $changeComponentPop('.editdirectoryBox', false) | ||||||
|  |   sourceId.value = '' | ||||||
|  |   form.sourceName = '' | ||||||
|  |   ruleForm.value?.resetFields() | ||||||
| } | } | ||||||
| const submitForm = async (formEl: FormInstance | undefined) => { | const submitForm = async (formEl: FormInstance | undefined) => { | ||||||
|   if (!formEl) return |   if (!formEl) return | ||||||
| @ -60,41 +64,11 @@ const submitForm = async (formEl: FormInstance | undefined) => { | |||||||
|   }) |   }) | ||||||
| } | } | ||||||
| const add = throttle(async () => { | const add = throttle(async () => { | ||||||
|   let parentId = getKeyOfSelectedNode(window.treeObj, 'id') |   const res: any = await TreeApi.updateDirectoryInfo({ | ||||||
|   let fnone = getSelectedNode(window.treeObj) |     id: sourceId.value, | ||||||
|   const res: any = await TreeApi.addDirectory({ |     sourceName: form.sourceName | ||||||
|     id: new YJ.Tools().randomString(), |  | ||||||
|     sourceName: form.sourceName, |  | ||||||
|     parentId: parentId || undefined |  | ||||||
|   }) |   }) | ||||||
|   console.log(res) |   cusUpdateNode({ id: sourceId.value, sourceName: form.sourceName, params: undefined }) | ||||||
|   if (res.code == 0 || res.code == 200) { |  | ||||||
|     const node = { |  | ||||||
|       ...res.data |  | ||||||
|     } |  | ||||||
|     let addNode = await cusAddNodes(window.treeObj, getSelectedNode(window.treeObj), [node], true) //添加节点 |  | ||||||
|     //获取该节点下的同级节点 |  | ||||||
|     const someNode: any = getSameLevel(window.treeObj, addNode[0]) |  | ||||||
|     console.log('someNode', someNode) |  | ||||||
|     const newNode = someNode.map((item: any) => { |  | ||||||
|       let index = item.getIndex() |  | ||||||
|       item.treeIndex = index+1 |  | ||||||
|       return { |  | ||||||
|         ...item, |  | ||||||
|         treeIndex: item.getIndex() |  | ||||||
|       } |  | ||||||
|     }) |  | ||||||
|     ElMessage({ |  | ||||||
|       message: '添加成功', |  | ||||||
|       type: 'success' |  | ||||||
|     }) |  | ||||||
|     cancel() |  | ||||||
|   } else { |  | ||||||
|     ElMessage({ |  | ||||||
|       message: '添加失败', |  | ||||||
|       type: 'error' |  | ||||||
|     }) |  | ||||||
|   } |  | ||||||
|   //   console.log(res) |   //   console.log(res) | ||||||
| }, 3000) | }, 3000) | ||||||
| // //上传或修改树的层级 | // //上传或修改树的层级 | ||||||
| @ -123,15 +97,23 @@ const add = throttle(async () => { | |||||||
| //   } | //   } | ||||||
| // } | // } | ||||||
|  |  | ||||||
| const cancel = () => { | const open = () => { | ||||||
|   $changeComponentPop('.adddirectory', false) |   let selectNodes = getSelectedNodes(window.treeObj); | ||||||
|   form.sourceName = '图层' |   if (selectNodes && selectNodes[selectNodes.length - 1]) { | ||||||
|   ruleForm.value?.resetFields() |     sourceId.value = selectNodes[selectNodes.length - 1].id | ||||||
|  |     form.sourceName = selectNodes[selectNodes.length - 1].sourceName | ||||||
|  |     $changeComponentPop('.editdirectoryBox', true) | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | defineExpose({ | ||||||
|  |   open, | ||||||
|  |   close | ||||||
|  | }) | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="scss"> | <style lang="scss"> | ||||||
| .adddirectory { | .editdirectoryBox { | ||||||
|   user-select: none; |   user-select: none; | ||||||
|   width: 100vw; |   width: 100vw; | ||||||
|   height: 100vh; |   height: 100vh; | ||||||
|  | |||||||
							
								
								
									
										1
									
								
								src/renderer/src/icons/svg/weather.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								src/renderer/src/icons/svg/weather.svg
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| After Width: | Height: | Size: 32 KiB | 
| @ -97,7 +97,7 @@ | |||||||
|                   ref="imageRef" |                   ref="imageRef" | ||||||
|                   fit="contain" |                   fit="contain" | ||||||
|                   :preview-teleported="true" |                   :preview-teleported="true" | ||||||
|                   :preview-src-list="modelList.map((item) => 'http://127.0.0.1:8848' + item.data)" |                   :preview-src-list="modelList.map((item:any) => 'http://127.0.0.1:8848' + item.data)" | ||||||
|                   style="width: 80px; height: 60px" |                   style="width: 80px; height: 60px" | ||||||
|                   :src="'http://127.0.0.1:8848' + row.data" |                   :src="'http://127.0.0.1:8848' + row.data" | ||||||
|                   :initial-index="currentIndex" |                   :initial-index="currentIndex" | ||||||
| @ -109,7 +109,7 @@ | |||||||
|                   ref="imageRef" |                   ref="imageRef" | ||||||
|                   fit="contain" |                   fit="contain" | ||||||
|                   :preview-teleported="true" |                   :preview-teleported="true" | ||||||
|                   :preview-src-list="modelList.map((item) => 'http://localhost:55110/' + item.data)" |                   :preview-src-list="modelList.map((item:any) => 'http://localhost:55110/' + item.data)" | ||||||
|                   style="width: 80px; height: 60px" |                   style="width: 80px; height: 60px" | ||||||
|                   :src="'http://localhost:55110/' + row.data" |                   :src="'http://localhost:55110/' + row.data" | ||||||
|                   :initial-index="currentIndex" |                   :initial-index="currentIndex" | ||||||
| @ -772,6 +772,7 @@ const setPhotoList = () => { | |||||||
|     dirName1s: 'GEMarker1s' |     dirName1s: 'GEMarker1s' | ||||||
|   }) |   }) | ||||||
|   $recvElectronChanel('dirFiles', (e, res) => { |   $recvElectronChanel('dirFiles', (e, res) => { | ||||||
|  |     console.log('dirFiles', res) | ||||||
|     res.GEMarker1s.forEach((item) => { |     res.GEMarker1s.forEach((item) => { | ||||||
|       let name = item.split('.')[0] |       let name = item.split('.')[0] | ||||||
|       name = name.split('/')[1] |       name = name.split('/')[1] | ||||||
|  | |||||||
| @ -110,7 +110,7 @@ const setList = ref([ | |||||||
|   width: 15vw; |   width: 15vw; | ||||||
|   position: absolute; |   position: absolute; | ||||||
|   right: 1vw; |   right: 1vw; | ||||||
|   top: 7%; |   top: 0; | ||||||
|   border-radius: 5px; |   border-radius: 5px; | ||||||
|   //   background: var(--svg-headColorbg); |   //   background: var(--svg-headColorbg); | ||||||
|   display: flex; |   display: flex; | ||||||
|  | |||||||
| @ -10,6 +10,9 @@ | |||||||
|         <span>{{ date.ymd }}</span> |         <span>{{ date.ymd }}</span> | ||||||
|         <span>{{ t(`week.${date.week}`) }}</span> |         <span>{{ t(`week.${date.week}`) }}</span> | ||||||
|       </div> |       </div> | ||||||
|  |       <div class="weather"> | ||||||
|  |         <svg-icon name="weather" :size="40"></svg-icon> | ||||||
|  |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <setTool ref="setToolRef"></setTool> |     <setTool ref="setToolRef"></setTool> | ||||||
|  |  | ||||||
| @ -101,7 +104,7 @@ onUnmounted(() => { | |||||||
|     position: absolute; |     position: absolute; | ||||||
|     left: 20px; |     left: 20px; | ||||||
|     //top: 15px; |     //top: 15px; | ||||||
|     top: 0.35vw; |     top: 0.55vw; | ||||||
|     height: 50px; |     height: 50px; | ||||||
|     //border: 1px solid red; |     //border: 1px solid red; | ||||||
|     //width: 200px; |     //width: 200px; | ||||||
| @ -133,6 +136,14 @@ onUnmounted(() => { | |||||||
|         font-size: 0.8rem; |         font-size: 0.8rem; | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     .weather { | ||||||
|  |       margin-left: 15px; | ||||||
|  |       svg { | ||||||
|  |         fill: rgba(0, 255, 255, 1) !important; | ||||||
|  |         cursor: pointer; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   .headButton { |   .headButton { | ||||||
|  | |||||||
| @ -762,10 +762,14 @@ const close = () => { | |||||||
| } | } | ||||||
|  |  | ||||||
| const clickChangeImage = () => { | const clickChangeImage = () => { | ||||||
|   eventBus?.emit('openSelectImg', entityOptions.value.billboardImage, entityOptions.value) |   eventBus?.emit('openPhoto', (img)=>{ | ||||||
|  |     entityOptions.value.billboardImage = img | ||||||
|  |   }) | ||||||
| } | } | ||||||
| const clickChangeDefaultImage = () => { | const clickChangeDefaultImage = () => { | ||||||
|   eventBus?.emit('openSelectImg', entityOptions.value.billboardDefaultImage, entityOptions.value) |   eventBus?.emit('openPhoto', (img)=>{ | ||||||
|  |     entityOptions.value.billboardDefaultImage = img | ||||||
|  |   }) | ||||||
| } | } | ||||||
| const fontChange = (val) => { | const fontChange = (val) => { | ||||||
|   entityOptions.value.labelFontFamily = val |   entityOptions.value.labelFontFamily = val | ||||||
|  | |||||||
| @ -11,55 +11,29 @@ | |||||||
|       <div class="set_detail"> |       <div class="set_detail"> | ||||||
|         <div class="top"> |         <div class="top"> | ||||||
|           <div> |           <div> | ||||||
|             <el-input |             <el-input v-model="modelName" class="w-50 m-2" placeholder="请输入图标类型进行搜索" :suffix-icon="Search" /> | ||||||
|               v-model="modelName" |  | ||||||
|               class="w-50 m-2" |  | ||||||
|               placeholder="请输入图标名称进行搜索" |  | ||||||
|               :suffix-icon="Search" |  | ||||||
|             /> |  | ||||||
|           </div> |           </div> | ||||||
|           <div class="typeBut"> |           <div class="typeBut"> | ||||||
|             <span |             <span v-for="(item, index) in butList" :key="index" :class="{ clickButClass: butActiveIndex === index }" | ||||||
|               v-for="(item, index) in butList" |               @click="typeClick(index)">{{ item }}</span> | ||||||
|               :key="index" |  | ||||||
|               :class="{ clickButClass: butActiveIndex === index }" |  | ||||||
|               @click="typeClick(index)" |  | ||||||
|               >{{ item }}</span |  | ||||||
|             > |  | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div class="content"> |         <div class="content"> | ||||||
|           <!-- 左侧Tab导航 --> |           <!-- 左侧Tab导航 --> | ||||||
|           <div class="treeCon"> |           <div class="treeCon"> | ||||||
|             <el-tree |             <el-tree style="max-width: 600px" :data="typeTreeData" ref="treeRef" node-key="id" | ||||||
|               style="max-width: 600px" |               @node-click="handleTypeClick" :filter-node-method="filterNode"> | ||||||
|               :data="typeTreeData" |  | ||||||
|               ref="treeRef" |  | ||||||
|               node-key="id" |  | ||||||
|               @node-click="handleTypeClick" |  | ||||||
|               :filter-node-method="filterNode" |  | ||||||
|             > |  | ||||||
|               <template #default="{ node, data }"> |               <template #default="{ node, data }"> | ||||||
|                 <!-- <span> {{ node.label }}</span> --> |                 <!-- <span> {{ node.label }}</span> --> | ||||||
|  |  | ||||||
|                 <span |                 <span :class="{ | ||||||
|                   :class="{ |       'primary-type': !(node.childNodes.length != 0), | ||||||
|                     'primary-type': !(node.childNodes.length != 0), |       'selected-text': node.id === currentTypeId | ||||||
|                     'selected-text': node.id === currentTypeId |     }" @click.stop="toggleExpand(node)" class="allowDrag"> | ||||||
|                   }" |                   <svg-icon :name="node.expanded ? 'arrow' : 'more'" :size="12" color="rgba(0, 255, 255, 1)" | ||||||
|                   @click.stop="toggleExpand(node)" |                     style="margin-right: 5px; margin-left: 5px" v-if="node.childNodes.length != 0" | ||||||
|                   class="allowDrag" |                     @click.stop="toggleExpand(node)"></svg-icon> | ||||||
|                 > |                   {{ node.label }}</span> | ||||||
|                   <svg-icon |  | ||||||
|                     :name="node.expanded ? 'arrow' : 'more'" |  | ||||||
|                     :size="12" |  | ||||||
|                     color="rgba(0, 255, 255, 1)" |  | ||||||
|                     style="margin-right: 5px; margin-left: 5px" |  | ||||||
|                     v-if="node.childNodes.length != 0" |  | ||||||
|                     @click.stop="toggleExpand(node)" |  | ||||||
|                   ></svg-icon> |  | ||||||
|                   {{ node.label }}</span |  | ||||||
|                 > |  | ||||||
|               </template> |               </template> | ||||||
|             </el-tree> |             </el-tree> | ||||||
|           </div> |           </div> | ||||||
| @ -68,29 +42,17 @@ | |||||||
|             <div class="model-section" v-if="butActiveIndex === 2"> |             <div class="model-section" v-if="butActiveIndex === 2"> | ||||||
|               <!-- <h2 class="section-title">{{ categories[Number(currentTypeId)].name }}</h2> --> |               <!-- <h2 class="section-title">{{ categories[Number(currentTypeId)].name }}</h2> --> | ||||||
|               <div class="model-grid"> |               <div class="model-grid"> | ||||||
|                 <div |                 <div v-for="(model, mIndex) in categories" :key="mIndex" class="model-item" | ||||||
|                   v-for="(model, mIndex) in categories" |                   @click="modelClick(mIndex, model)"> | ||||||
|                   :key="mIndex" |  | ||||||
|                   class="model-item" |  | ||||||
|                   @click="modelClick(mIndex, model)" |  | ||||||
|                 > |  | ||||||
|                   <div class="imgbg"> |                   <div class="imgbg"> | ||||||
|                     <el-image |                     <el-image :src="service + model.data" fit="contain" class="thumbnail"> | ||||||
|                       :src="'http://127.0.0.1:8848' + model.data" |  | ||||||
|                       fit="contain" |  | ||||||
|                       class="thumbnail" |  | ||||||
|                     > |  | ||||||
|                       <template #error> |                       <template #error> | ||||||
|                         <div class="image-error">加载失败</div> |                         <div class="image-error">加载失败</div> | ||||||
|                       </template> |                       </template> | ||||||
|                     </el-image> |                     </el-image> | ||||||
|                   </div> |                   </div> | ||||||
|  |  | ||||||
|                   <div |                   <div class="model-name" :class="{ isactive: activeIndex == mIndex }" :title="model.iconName"> | ||||||
|                     class="model-name" |  | ||||||
|                     :class="{ isactive: activeIndex == mIndex }" |  | ||||||
|                     :title="model.iconName" |  | ||||||
|                   > |  | ||||||
|                     {{ model.iconName }} |                     {{ model.iconName }} | ||||||
|                   </div> |                   </div> | ||||||
|                 </div> |                 </div> | ||||||
| @ -101,38 +63,21 @@ | |||||||
|             <div class="model-section2" v-else> |             <div class="model-section2" v-else> | ||||||
|               <!-- <h2 class="section-title">{{ categories[Number(currentTypeId)].name }}</h2> --> |               <!-- <h2 class="section-title">{{ categories[Number(currentTypeId)].name }}</h2> --> | ||||||
|               <div class="typeTitltName" v-if="categories.length"> |               <div class="typeTitltName" v-if="categories.length"> | ||||||
|                 <svg-icon |                 <svg-icon name="fk" :size="16" color="rgba(0, 255, 255, 1)" style="margin-right: 5px"></svg-icon>基本类型 | ||||||
|                   name="fk" |  | ||||||
|                   :size="16" |  | ||||||
|                   color="rgba(0, 255, 255, 1)" |  | ||||||
|                   style="margin-right: 5px" |  | ||||||
|                 ></svg-icon |  | ||||||
|                 >基本类型 |  | ||||||
|               </div> |               </div> | ||||||
|               <div class="model-grid"> |               <div class="model-grid"> | ||||||
|                 <div |                 <div v-for="(model, mIndex) in categories" :key="mIndex" class="model-item" | ||||||
|                   v-for="(model, mIndex) in categories" |                   @click="modelClick(mIndex, model)"> | ||||||
|                   :key="mIndex" |  | ||||||
|                   class="model-item" |  | ||||||
|                   @click="modelClick(mIndex, model)" |  | ||||||
|                 > |  | ||||||
|                   <div class="imgbg"> |                   <div class="imgbg"> | ||||||
|                     <el-image |                     <el-image :src="'http://localhost:' + availablePort + '/' + model.data" fit="contain" | ||||||
|                       :src="'http://localhost:55110/' + model.data" |                       class="thumbnail"> | ||||||
|                       fit="contain" |  | ||||||
|                       class="thumbnail" |  | ||||||
|                     > |  | ||||||
|                       <template #error> |                       <template #error> | ||||||
|                         <div class="image-error">加载失败</div> |                         <div class="image-error">加载失败</div> | ||||||
|                       </template> |                       </template> | ||||||
|                     </el-image> |                     </el-image> | ||||||
|                   </div> |                   </div> | ||||||
|  |  | ||||||
|                   <div |                   <div class="model-name" :class="{ isactive: activeIndex == mIndex }" :title="model.iconName"> | ||||||
|                     class="model-name" |  | ||||||
|                     :class="{ isactive: activeIndex == mIndex }" |  | ||||||
|                     :title="model.iconName" |  | ||||||
|                   > |  | ||||||
|                     {{ model.iconName }} |                     {{ model.iconName }} | ||||||
|                   </div> |                   </div> | ||||||
|                 </div> |                 </div> | ||||||
| @ -159,6 +104,8 @@ import { | |||||||
|   $recvElectronChanel, |   $recvElectronChanel, | ||||||
|   $changeComponentShow |   $changeComponentShow | ||||||
| } from '@/utils/communication' | } from '@/utils/communication' | ||||||
|  |  | ||||||
|  | const { ipcRenderer } = require('electron') | ||||||
| const { t } = useI18n() | const { t } = useI18n() | ||||||
| const { findParentId, findTreeIndex, cusAddNodes } = useTreeNode() | const { findParentId, findTreeIndex, cusAddNodes } = useTreeNode() | ||||||
| const isShowPup = ref(false) | const isShowPup = ref(false) | ||||||
| @ -166,6 +113,15 @@ const eventBus: any = inject('bus') | |||||||
| const { cusUpdateNode } = useTreeNode() | const { cusUpdateNode } = useTreeNode() | ||||||
| var modelName = ref('') | var modelName = ref('') | ||||||
|  |  | ||||||
|  | const availablePort = ref(55110) | ||||||
|  | const service = ref(localStorage.getItem("service")) | ||||||
|  |  | ||||||
|  | ipcRenderer.invoke('get-available-port').then((port) => { | ||||||
|  |   availablePort.value = port | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | let selectCallback | ||||||
|  |  | ||||||
| //tab | //tab | ||||||
| interface Model { | interface Model { | ||||||
|   id: string |   id: string | ||||||
| @ -290,6 +246,10 @@ const handleScroll = () => { | |||||||
| const currentTypeId = ref<string>('') | const currentTypeId = ref<string>('') | ||||||
| var activeIndex: any = ref(null) | var activeIndex: any = ref(null) | ||||||
|  |  | ||||||
|  | //立体图标、普通图标 | ||||||
|  | let threePhoto: any = [] | ||||||
|  | let ordinaryPhoto: any = [] | ||||||
|  |  | ||||||
| interface TypeNode { | interface TypeNode { | ||||||
|   id: string |   id: string | ||||||
|   label: string |   label: string | ||||||
| @ -330,14 +290,30 @@ let typeArr = { | |||||||
| const modelClick = (index, row) => { | const modelClick = (index, row) => { | ||||||
|   activeIndex.value = index |   activeIndex.value = index | ||||||
|   isShowPup.value = false |   isShowPup.value = false | ||||||
|   console.log(row, '点中了') |   console.log(index, row) | ||||||
|  |   let selectedImg | ||||||
|  |   if(selectCallback) { | ||||||
|  |     if(butActiveIndex.value === 0) | ||||||
|  |     { | ||||||
|  |       selectedImg = 'http://localhost:' + availablePort.value + '/' + (row.data.indexOf("1s/") > -1 ? row.data.replace(/1s/g, "1") : row.data) | ||||||
|  |     } | ||||||
|  |     else if(butActiveIndex.value === 1) | ||||||
|  |     { | ||||||
|  |       selectedImg = 'http://localhost:' + availablePort.value + '/' + row.data | ||||||
|  |     } | ||||||
|  |     else if(butActiveIndex.value === 2) | ||||||
|  |     { | ||||||
|  |       selectedImg = service.value + row.data | ||||||
|  |     } | ||||||
|  |     selectCallback(selectedImg) | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| const getModelListByType = (id) => { | const getModelListByType = (id) => { | ||||||
|   if (butActiveIndex.value === 0) { |   if (butActiveIndex.value === 0) { | ||||||
|     categories.value = threePhoto |     categories.value = [...threePhoto] | ||||||
|   } else if (butActiveIndex.value === 1) { |   } else if (butActiveIndex.value === 1) { | ||||||
|     categories.value = ordinaryPhoto |     categories.value = [...ordinaryPhoto] | ||||||
|   } else { |   } else { | ||||||
|     let formData = new FormData() |     let formData = new FormData() | ||||||
|     formData.append('iconTypeId', id) |     formData.append('iconTypeId', id) | ||||||
| @ -356,11 +332,20 @@ const getModelList = async () => { | |||||||
|         parentId: null |         parentId: null | ||||||
|       } |       } | ||||||
|     ] |     ] | ||||||
|  |     if(butActiveIndex.value==0) { | ||||||
|  |       categories.value = [...threePhoto] | ||||||
|  |     } | ||||||
|  |     if(butActiveIndex.value==1) { | ||||||
|  |       categories.value = [...ordinaryPhoto] | ||||||
|  |     } | ||||||
|   } else { |   } else { | ||||||
|     const res: any = await PhotoApi.modelTypeList() |     const res: any = await PhotoApi.modelTypeList() | ||||||
|     if (res.code == 0 || res.code == 200) { |     if (res.code == 0 || res.code == 200) { | ||||||
|       let data = transformNestedJson(res.data, 'name', 'label') |       let data = transformNestedJson(res.data, 'name', 'label') | ||||||
|       typeTreeData.value = data |       typeTreeData.value = data | ||||||
|  |       if(typeTreeData.value.length>0) { | ||||||
|  |         getModelListByType(typeTreeData.value[0].id) | ||||||
|  |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @ -389,26 +374,18 @@ onBeforeUnmount(() => { | |||||||
|   observer?.disconnect() |   observer?.disconnect() | ||||||
| }) | }) | ||||||
| //end | //end | ||||||
|  | eventBus.on('openPhoto', async(cb) => { | ||||||
| eventBus.on('openPhoto', (data) => { |   isShowPup.value = true | ||||||
|   isShowPup.value = data |   selectCallback = cb | ||||||
|   if (data) { |   getModelList() | ||||||
|     getModelList() |   getSetting() | ||||||
|     getSetting() |   setPhotoList() | ||||||
|     setPhotoList() |  | ||||||
|   } |  | ||||||
| }) | }) | ||||||
| eventBus.on('closeModelSet', (data) => { | eventBus.on('closePhoto', () => { | ||||||
|   isShowPup.value = data |   isShowPup.value = false | ||||||
|   if (data) { |   getSetting() | ||||||
|     getSetting() |  | ||||||
|   } |  | ||||||
| }) | }) | ||||||
|  |  | ||||||
| //立体图标、普通图标 |  | ||||||
| let threePhoto: any = [] |  | ||||||
| let ordinaryPhoto: any = [] |  | ||||||
|  |  | ||||||
| const setPhotoList = () => { | const setPhotoList = () => { | ||||||
|   $sendElectronChanel('requireGEMarkerName', { |   $sendElectronChanel('requireGEMarkerName', { | ||||||
|     dirName: 'GEMarker', |     dirName: 'GEMarker', | ||||||
| @ -431,6 +408,7 @@ const setPhotoList = () => { | |||||||
|         data: item |         data: item | ||||||
|       }) |       }) | ||||||
|     }) |     }) | ||||||
|  |     categories.value = [...threePhoto] | ||||||
|   }) |   }) | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -465,6 +443,7 @@ defineExpose({ | |||||||
| .set_pup { | .set_pup { | ||||||
|   width: 40vw; |   width: 40vw; | ||||||
|   height: 50vh; |   height: 50vh; | ||||||
|  |  | ||||||
|   :deep(.el-dialog) { |   :deep(.el-dialog) { | ||||||
|     background: |     background: | ||||||
|       linear-gradient(180deg, rgba(0, 255, 255, 0.2) 0%, rgba(0, 255, 255, 0) 100%), |       linear-gradient(180deg, rgba(0, 255, 255, 0.2) 0%, rgba(0, 255, 255, 0) 100%), | ||||||
| @ -472,24 +451,30 @@ defineExpose({ | |||||||
|     border: 1px solid #00c9ff; |     border: 1px solid #00c9ff; | ||||||
|     padding-left: 0 !important; |     padding-left: 0 !important; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   :deep(.el-dialog__body) { |   :deep(.el-dialog__body) { | ||||||
|     padding: 0 !important; |     padding: 0 !important; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   :deep(.el-dialog__headerbtn) { |   :deep(.el-dialog__headerbtn) { | ||||||
|     height: 30px; |     height: 30px; | ||||||
|     width: 30px; |     width: 30px; | ||||||
|     border-bottom-left-radius: 80%; |     border-bottom-left-radius: 80%; | ||||||
|     background-color: #008989; |     background-color: #008989; | ||||||
|  |  | ||||||
|     &:hover { |     &:hover { | ||||||
|       background-color: #00ffff; |       background-color: #00ffff; | ||||||
|  |  | ||||||
|       .el-dialog__close { |       .el-dialog__close { | ||||||
|         color: rgba(0, 66, 66, 1); // 悬停时改变关闭图标为红色 |         color: rgba(0, 66, 66, 1); // 悬停时改变关闭图标为红色 | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   :deep(.el-dialog__headerbtn .el-dialog__close) { |   :deep(.el-dialog__headerbtn .el-dialog__close) { | ||||||
|     color: #fff; |     color: #fff; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   .set_pup_header { |   .set_pup_header { | ||||||
|     width: 100%; |     width: 100%; | ||||||
|     height: 100%; |     height: 100%; | ||||||
| @ -498,6 +483,7 @@ defineExpose({ | |||||||
|     justify-content: center; |     justify-content: center; | ||||||
|     align-items: center; |     align-items: center; | ||||||
|     padding-bottom: 20px; |     padding-bottom: 20px; | ||||||
|  |  | ||||||
|     .system_title { |     .system_title { | ||||||
|       background: url('@/assets/images/titlebg.png') no-repeat; |       background: url('@/assets/images/titlebg.png') no-repeat; | ||||||
|       background-size: 100% 100%; |       background-size: 100% 100%; | ||||||
| @ -511,26 +497,24 @@ defineExpose({ | |||||||
|       font-weight: 700; |       font-weight: 700; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   .set_detail { |   .set_detail { | ||||||
|     box-sizing: border-box; |     box-sizing: border-box; | ||||||
|  |  | ||||||
|     // height: 50vh; |     // height: 50vh; | ||||||
|     :deep( |     :deep(.el-tabs--left .el-tabs__active-bar.is-left, | ||||||
|       .el-tabs--left .el-tabs__active-bar.is-left, |  | ||||||
|       .el-tabs--left .el-tabs__active-bar.is-right, |       .el-tabs--left .el-tabs__active-bar.is-right, | ||||||
|       .el-tabs--right .el-tabs__active-bar.is-left, |       .el-tabs--right .el-tabs__active-bar.is-left, | ||||||
|       .el-tabs--right .el-tabs__active-bar.is-right |       .el-tabs--right .el-tabs__active-bar.is-right) { | ||||||
|     ) { |  | ||||||
|       width: 3px; |       width: 3px; | ||||||
|       background: rgba(0, 255, 255, 1); |       background: rgba(0, 255, 255, 1); | ||||||
|       height: 40px !important; |       height: 40px !important; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     :deep( |     :deep(.el-tabs--left .el-tabs__nav-wrap.is-left::after, | ||||||
|       .el-tabs--left .el-tabs__nav-wrap.is-left::after, |  | ||||||
|       .el-tabs--left .el-tabs__nav-wrap.is-right::after, |       .el-tabs--left .el-tabs__nav-wrap.is-right::after, | ||||||
|       .el-tabs--right .el-tabs__nav-wrap.is-left::after, |       .el-tabs--right .el-tabs__nav-wrap.is-left::after, | ||||||
|       .el-tabs--right .el-tabs__nav-wrap.is-right::after |       .el-tabs--right .el-tabs__nav-wrap.is-right::after) { | ||||||
|     ) { |  | ||||||
|       width: 3px; |       width: 3px; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -563,13 +547,16 @@ defineExpose({ | |||||||
|       width: 5px; |       width: 5px; | ||||||
|       height: 5px; |       height: 5px; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     :deep(.el-tabs__content::-webkit-scrollbar-thumb) { |     :deep(.el-tabs__content::-webkit-scrollbar-thumb) { | ||||||
|       background-color: #0ff; |       background-color: #0ff; | ||||||
|       border-radius: 5px; |       border-radius: 5px; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     :deep(.el-tabs__content::-webkit-scrollbar-track) { |     :deep(.el-tabs__content::-webkit-scrollbar-track) { | ||||||
|       background-color: rgba(0, 255, 255, 0.2); |       background-color: rgba(0, 255, 255, 0.2); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     :deep(.el-tabs__item) { |     :deep(.el-tabs__item) { | ||||||
|       width: 8vw; |       width: 8vw; | ||||||
|       color: #fff !important; |       color: #fff !important; | ||||||
| @ -582,50 +569,45 @@ defineExpose({ | |||||||
|       margin-bottom: 3px; |       margin-bottom: 3px; | ||||||
|       box-sizing: border-box; |       box-sizing: border-box; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     :deep(.el-tabs__item:hover) { |     :deep(.el-tabs__item:hover) { | ||||||
|       background: linear-gradient( |       background: linear-gradient(90deg, | ||||||
|         90deg, |           rgba(0, 255, 255, 0) 0%, | ||||||
|         rgba(0, 255, 255, 0) 0%, |           rgba(0, 255, 255, 0.5) 48.91%, | ||||||
|         rgba(0, 255, 255, 0.5) 48.91%, |           rgba(0, 255, 255, 0) 100%); | ||||||
|         rgba(0, 255, 255, 0) 100% |  | ||||||
|       ); |  | ||||||
|       border: 1px solid; |       border: 1px solid; | ||||||
|       box-sizing: border-box; |       box-sizing: border-box; | ||||||
|       border-image: linear-gradient( |       border-image: linear-gradient(90deg, | ||||||
|           90deg, |  | ||||||
|           rgba(0, 255, 255, 0) 0%, |           rgba(0, 255, 255, 0) 0%, | ||||||
|           rgba(0, 255, 255, 1) 55.55%, |           rgba(0, 255, 255, 1) 55.55%, | ||||||
|           rgba(0, 255, 255, 0) 100% |           rgba(0, 255, 255, 0) 100%) 1; | ||||||
|         ) |  | ||||||
|         1; |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     :deep(.el-tabs__item.is-active) { |     :deep(.el-tabs__item.is-active) { | ||||||
|       background: linear-gradient( |       background: linear-gradient(90deg, | ||||||
|         90deg, |           rgba(0, 255, 255, 0) 0%, | ||||||
|         rgba(0, 255, 255, 0) 0%, |           rgba(0, 255, 255, 0.5) 48.91%, | ||||||
|         rgba(0, 255, 255, 0.5) 48.91%, |           rgba(0, 255, 255, 0) 100%) !important; | ||||||
|         rgba(0, 255, 255, 0) 100% |  | ||||||
|       ) !important; |  | ||||||
|       border: 0.1px solid; |       border: 0.1px solid; | ||||||
|       // box-sizing: border-box; |       // box-sizing: border-box; | ||||||
|       border-image: linear-gradient( |       border-image: linear-gradient(90deg, | ||||||
|           90deg, |  | ||||||
|           rgba(0, 255, 255, 0) 0%, |           rgba(0, 255, 255, 0) 0%, | ||||||
|           rgba(0, 255, 255, 1) 55.55%, |           rgba(0, 255, 255, 1) 55.55%, | ||||||
|           rgba(0, 255, 255, 0) 100% |           rgba(0, 255, 255, 0) 100%) 1 !important; | ||||||
|         ) |  | ||||||
|         1 !important; |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     :deep(.el-tabs__header) { |     :deep(.el-tabs__header) { | ||||||
|       height: 50vh !important; |       height: 50vh !important; | ||||||
|       width: 8vw; |       width: 8vw; | ||||||
|       overflow-y: auto; |       overflow-y: auto; | ||||||
|       overflow-x: hidden; |       overflow-x: hidden; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     :deep(.el-tabs__nav-next, .el-tabs__nav-prev) { |     :deep(.el-tabs__nav-next, .el-tabs__nav-prev) { | ||||||
|       color: #fff; |       color: #fff; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   .el-input { |   .el-input { | ||||||
|     width: 300px; |     width: 300px; | ||||||
|     margin-left: 30px; |     margin-left: 30px; | ||||||
| @ -637,9 +619,11 @@ defineExpose({ | |||||||
|     --el-input-hover-border-color: rgba(var(--color-sdk-base-rgb), 0.5) !important; |     --el-input-hover-border-color: rgba(var(--color-sdk-base-rgb), 0.5) !important; | ||||||
|     --el-input-focus-border-color: rgba(var(--color-sdk-base-rgb), 0.5) !important; |     --el-input-focus-border-color: rgba(var(--color-sdk-base-rgb), 0.5) !important; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   ::v-deep .el-input__wrapper { |   ::v-deep .el-input__wrapper { | ||||||
|     background-color: rgba(0, 0, 0, 0.5) !important; |     background-color: rgba(0, 0, 0, 0.5) !important; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   .btn { |   .btn { | ||||||
|     float: right; |     float: right; | ||||||
|     height: 32px; |     height: 32px; | ||||||
| @ -650,9 +634,11 @@ defineExpose({ | |||||||
|     color: #fff !important; |     color: #fff !important; | ||||||
|     padding: 0 15px; |     padding: 0 15px; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   .btn:hover { |   .btn:hover { | ||||||
|     color: rgba(var(--color-sdk-base-rgb), 1) !important; |     color: rgba(var(--color-sdk-base-rgb), 1) !important; | ||||||
|     border: 1px solid rgba(var(--color-sdk-base-rgb), 1) !important; |     border: 1px solid rgba(var(--color-sdk-base-rgb), 1) !important; | ||||||
|  |  | ||||||
|     .setIcon { |     .setIcon { | ||||||
|       color: rgba(var(--color-sdk-base-rgb), 1) !important; |       color: rgba(var(--color-sdk-base-rgb), 1) !important; | ||||||
|     } |     } | ||||||
| @ -670,17 +656,20 @@ defineExpose({ | |||||||
|   display: flex; |   display: flex; | ||||||
|   height: 100vh; |   height: 100vh; | ||||||
| } | } | ||||||
|  |  | ||||||
| .model-tabs { | .model-tabs { | ||||||
|   width: 130px; |   width: 130px; | ||||||
|   height: 100%; |   height: 100%; | ||||||
|   float: left; |   float: left; | ||||||
| } | } | ||||||
|  |  | ||||||
| .treeCon { | .treeCon { | ||||||
|   width: 140px; |   width: 140px; | ||||||
|   height: 100%; |   height: 100%; | ||||||
|   float: left; |   float: left; | ||||||
|   border-right: 1px solid rgba(204, 204, 204, 0.2); |   border-right: 1px solid rgba(204, 204, 204, 0.2); | ||||||
| } | } | ||||||
|  |  | ||||||
| .model-gallery { | .model-gallery { | ||||||
|   flex: 1; |   flex: 1; | ||||||
|   /* padding: 20px; */ |   /* padding: 20px; */ | ||||||
| @ -690,16 +679,19 @@ defineExpose({ | |||||||
|   float: left; |   float: left; | ||||||
|   margin-left: 10px; |   margin-left: 10px; | ||||||
| } | } | ||||||
|  |  | ||||||
| .model-section { | .model-section { | ||||||
|   min-height: 10vh; |   min-height: 10vh; | ||||||
|   margin-bottom: 40px; |   margin-bottom: 40px; | ||||||
| } | } | ||||||
|  |  | ||||||
| .model-grid { | .model-grid { | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex-wrap: wrap; |   flex-wrap: wrap; | ||||||
|   /* justify-content: space-around; */ |   /* justify-content: space-around; */ | ||||||
|   gap: 20px; |   gap: 20px; | ||||||
| } | } | ||||||
|  |  | ||||||
| .model-name { | .model-name { | ||||||
|   width: 100%; |   width: 100%; | ||||||
|   height: 30px; |   height: 30px; | ||||||
| @ -711,18 +703,22 @@ defineExpose({ | |||||||
|  |  | ||||||
|   color: rgba(255, 255, 255, 1); |   color: rgba(255, 255, 255, 1); | ||||||
| } | } | ||||||
|  |  | ||||||
| .isactive { | .isactive { | ||||||
|   color: rgba(var(--color-sdk-base-rgb), 1) !important; |   color: rgba(var(--color-sdk-base-rgb), 1) !important; | ||||||
| } | } | ||||||
|  |  | ||||||
| .model-item { | .model-item { | ||||||
|   border-radius: 8px; |   border-radius: 8px; | ||||||
|   overflow: hidden; |   overflow: hidden; | ||||||
|   width: 70px; |   width: 70px; | ||||||
|   /* box-shadow: 0 2px 12px rgba(0, 0, 0, 0.1); */ |   /* box-shadow: 0 2px 12px rgba(0, 0, 0, 0.1); */ | ||||||
| } | } | ||||||
|  |  | ||||||
| .model-item:hover { | .model-item:hover { | ||||||
|   cursor: pointer !important; |   cursor: pointer !important; | ||||||
|   color: rgba(var(--color-sdk-base-rgb), 1) !important; |   color: rgba(var(--color-sdk-base-rgb), 1) !important; | ||||||
|  |  | ||||||
|   .model-name { |   .model-name { | ||||||
|     color: rgba(var(--color-sdk-base-rgb), 1) !important; |     color: rgba(var(--color-sdk-base-rgb), 1) !important; | ||||||
|   } |   } | ||||||
| @ -734,17 +730,20 @@ defineExpose({ | |||||||
|   background: url('@/assets/images/model-bg.png') no-repeat; |   background: url('@/assets/images/model-bg.png') no-repeat; | ||||||
|   background-size: 100% 100%; |   background-size: 100% 100%; | ||||||
| } | } | ||||||
|  |  | ||||||
| .model-section2 { | .model-section2 { | ||||||
|   .imgbg { |   .imgbg { | ||||||
|     background: unset; |     background: unset; | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| .thumbnail { | .thumbnail { | ||||||
|   width: 64px; |   width: 64px; | ||||||
|   height: 64px; |   height: 64px; | ||||||
|   margin-left: 3px; |   margin-left: 3px; | ||||||
|   margin-top: 3px; |   margin-top: 3px; | ||||||
| } | } | ||||||
|  |  | ||||||
| .loading-more { | .loading-more { | ||||||
|   text-align: center; |   text-align: center; | ||||||
|   padding: 20px; |   padding: 20px; | ||||||
| @ -753,10 +752,12 @@ defineExpose({ | |||||||
| ::v-deep .el-tabs__content { | ::v-deep .el-tabs__content { | ||||||
|   display: none !important; |   display: none !important; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* 修改滚动条轨道的颜色 */ | /* 修改滚动条轨道的颜色 */ | ||||||
| ::v-deep ::-webkit-scrollbar-track { | ::v-deep ::-webkit-scrollbar-track { | ||||||
|   background: rgba(var(--color-sdk-base-rgb), 0.1) !important; |   background: rgba(var(--color-sdk-base-rgb), 0.1) !important; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* 修改滚动条滑块的样式 */ | /* 修改滚动条滑块的样式 */ | ||||||
| ::v-deep ::-webkit-scrollbar-thumb { | ::v-deep ::-webkit-scrollbar-thumb { | ||||||
|   background: rgba(var(--color-sdk-base-rgb), 1) !important; |   background: rgba(var(--color-sdk-base-rgb), 1) !important; | ||||||
| @ -773,11 +774,13 @@ defineExpose({ | |||||||
|   width: 5px; |   width: 5px; | ||||||
|   height: 5px; |   height: 5px; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* 定义背景颜色和圆角 */ | /* 定义背景颜色和圆角 */ | ||||||
| ::-webkit-scrollbar-thumb { | ::-webkit-scrollbar-thumb { | ||||||
|   border-radius: 1em; |   border-radius: 1em; | ||||||
|   background-color: rgba(50, 50, 50, 0.3); |   background-color: rgba(50, 50, 50, 0.3); | ||||||
| } | } | ||||||
|  |  | ||||||
| /* //定义滚动条轨道 内阴影+圆角 */ | /* //定义滚动条轨道 内阴影+圆角 */ | ||||||
| ::-webkit-scrollbar-track { | ::-webkit-scrollbar-track { | ||||||
|   border-radius: 1em; |   border-radius: 1em; | ||||||
| @ -785,9 +788,10 @@ defineExpose({ | |||||||
| } | } | ||||||
|  |  | ||||||
| /* tree */ | /* tree */ | ||||||
| .el-tree-node__content > .el-tree-node__expand-icon { | .el-tree-node__content>.el-tree-node__expand-icon { | ||||||
|   display: none !important; |   display: none !important; | ||||||
| } | } | ||||||
|  |  | ||||||
| .el-tree { | .el-tree { | ||||||
|   background: transparent !important; |   background: transparent !important; | ||||||
|   --el-tree-node-hover-bg-color: rgba(var(--color-sdk-base-rgb), 0.2) !important; |   --el-tree-node-hover-bg-color: rgba(var(--color-sdk-base-rgb), 0.2) !important; | ||||||
| @ -797,16 +801,21 @@ defineExpose({ | |||||||
|   float: left; |   float: left; | ||||||
|   margin-left: 10px; |   margin-left: 10px; | ||||||
| } | } | ||||||
|  |  | ||||||
| ::v-deep .el-text { | ::v-deep .el-text { | ||||||
|   color: rgba(255, 255, 255, 1) !important; |   color: rgba(255, 255, 255, 1) !important; | ||||||
|   font-size: 12px !important; |   font-size: 12px !important; | ||||||
| } | } | ||||||
|  |  | ||||||
| .selected-text { | .selected-text { | ||||||
|   color: rgba(var(--color-sdk-base-rgb), 1) !important; /* Element UI主色,可自定义 */ |   color: rgba(var(--color-sdk-base-rgb), 1) !important; | ||||||
|  |   /* Element UI主色,可自定义 */ | ||||||
| } | } | ||||||
| ::v-deep .el-tree--highlight-current .el-tree-node.is-current > .el-tree-node__content { |  | ||||||
|  | ::v-deep .el-tree--highlight-current .el-tree-node.is-current>.el-tree-node__content { | ||||||
|   border-right: 1px solid rgba(var(--color-sdk-base-rgb), 0.2) !important; |   border-right: 1px solid rgba(var(--color-sdk-base-rgb), 0.2) !important; | ||||||
| } | } | ||||||
|  |  | ||||||
| .typeBut { | .typeBut { | ||||||
|   left: 527px; |   left: 527px; | ||||||
|   top: 3764px; |   top: 3764px; | ||||||
| @ -816,6 +825,7 @@ defineExpose({ | |||||||
|   display: flex; |   display: flex; | ||||||
|   justify-content: flex-start; |   justify-content: flex-start; | ||||||
|   align-items: flex-start; |   align-items: flex-start; | ||||||
|  |  | ||||||
|   span { |   span { | ||||||
|     display: block; |     display: block; | ||||||
|     width: 90px; |     width: 90px; | ||||||
| @ -835,21 +845,25 @@ defineExpose({ | |||||||
|     cursor: pointer; |     cursor: pointer; | ||||||
|     color: #fff; |     color: #fff; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   span:hover { |   span:hover { | ||||||
|     color: rgba(var(--color-sdk-base-rgb), 1); |     color: rgba(var(--color-sdk-base-rgb), 1); | ||||||
|     border: 1px solid rgba(var(--color-sdk-base-rgb), 1); |     border: 1px solid rgba(var(--color-sdk-base-rgb), 1); | ||||||
|     border-radius: 4px; |     border-radius: 4px; | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| .clickButClass { | .clickButClass { | ||||||
|   color: rgba(var(--color-sdk-base-rgb), 1); |   color: rgba(var(--color-sdk-base-rgb), 1); | ||||||
|   border: 1px solid rgba(var(--color-sdk-base-rgb), 1) !important; |   border: 1px solid rgba(var(--color-sdk-base-rgb), 1) !important; | ||||||
|   border-radius: 4px; |   border-radius: 4px; | ||||||
| } | } | ||||||
|  |  | ||||||
| .top { | .top { | ||||||
|   display: flex; |   display: flex; | ||||||
|   justify-content: space-between; |   justify-content: space-between; | ||||||
| } | } | ||||||
|  |  | ||||||
| .typeTitltName { | .typeTitltName { | ||||||
|   font-size: 16px; |   font-size: 16px; | ||||||
|   font-weight: 400; |   font-weight: 400; | ||||||
|  | |||||||
| @ -6,7 +6,7 @@ import { initMapData } from '../../../../common/initMapData' | |||||||
| export const useTree = () => { | export const useTree = () => { | ||||||
|   const rightMenuRef: any = ref() //右键菜单的实例 |   const rightMenuRef: any = ref() //右键菜单的实例 | ||||||
|   const treeObj = ref() //树形的实例 |   const treeObj = ref() //树形的实例 | ||||||
|   const { getSelectedNodes, showRightMenu, cusSelectNode, getSameLevel, cusNodeIcon } = useTreeNode() //树上一系列的方法hooks |   const { getSelectedNodes, showRightMenu, cusSelectNode, getSameLevel, cusNodeIcon, nodeType } = useTreeNode() //树上一系列的方法hooks | ||||||
|   const nodes: any = ref([]) |   const nodes: any = ref([]) | ||||||
|   /** |   /** | ||||||
|    * 用于捕获zTree上鼠标按键按下后的事件回调函数 |    * 用于捕获zTree上鼠标按键按下后的事件回调函数 | ||||||
| @ -100,14 +100,14 @@ export const useTree = () => { | |||||||
|       item.treeIndex = index |       item.treeIndex = index | ||||||
|       return { |       return { | ||||||
|         ...item, |         ...item, | ||||||
|         treeIndex: item.getIndex()+1 |         treeIndex: item.getIndex() + 1 | ||||||
|       } |       } | ||||||
|     }) |     }) | ||||||
|     const list = newNode.map((item: any) => { |     const list = newNode.map((item: any) => { | ||||||
|       return { |       return { | ||||||
|         id: item.id, |         id: item.id, | ||||||
|         treeIndex: item.treeIndex, |         treeIndex: item.treeIndex, | ||||||
|         parentId: item.parentId |         parentId: item.parentId || '' | ||||||
|       } |       } | ||||||
|     }) |     }) | ||||||
|     const res = await TreeApi.updateTreeIndex(list) |     const res = await TreeApi.updateTreeIndex(list) | ||||||
| @ -190,29 +190,26 @@ export const useTree = () => { | |||||||
|    * @returns {boolean} 返回 false,zTree 将恢复被拖拽的节点,也无法触发 onDrop 事件回调函数 |    * @returns {boolean} 返回 false,zTree 将恢复被拖拽的节点,也无法触发 onDrop 事件回调函数 | ||||||
|    */ |    */ | ||||||
|   const beforeDrop = ( |   const beforeDrop = ( | ||||||
|     event: DragEvent, |  | ||||||
|     treeId: any, |     treeId: any, | ||||||
|     treeNodes: any, |     treeNodes: any, | ||||||
|     targetNode: any, |     targetNode: any, | ||||||
|     moveType: any |     moveType: any | ||||||
|   ) => { |   ) => { | ||||||
|     console.log('开始拖拽之前') |     if ( | ||||||
|  |       ['prev', 'next', 'inner'].includes(moveType) && | ||||||
|     // if ( |       ['pressModel', 'terrainDig'].includes(treeNodes[0].sourceType) | ||||||
|     //   ['prev', 'next', 'inner'].includes(moveType) && |     ) { | ||||||
|     //   ['pressModel', 'terrainDig'].includes(treeNodes[0].sourceType) |       return false | ||||||
|     // ) { |     } | ||||||
|     //   return false |     if (['prev', 'next'].includes(moveType)) { | ||||||
|     // } |       let parent = treeObj.value.getNodeByParam('id', targetNode.parentId, null) | ||||||
|     // if (['prev', 'next'].includes(moveType)) { |       if (parent && !nodeType[parent.sourceType].allowChildren) return false | ||||||
|     //   let parent = this.treeObj.getNodeByParam('id', targetNode.parentId, null) |     } | ||||||
|     //   if (parent && !treeNodeOption.nodeType[parent.sourceType].allowChildren) return false |     if (targetNode) { | ||||||
|     // } |       if (moveType == 'inner' && !nodeType[targetNode.sourceType].allowChildren) { | ||||||
|     // if (targetNode) { |         return false | ||||||
|     //   if (moveType == 'inner' && !treeNodeOption.nodeType[targetNode.sourceType].allowChildren) { |       } | ||||||
|     //     return false |     } | ||||||
|     //   } |  | ||||||
|     // } |  | ||||||
|   } |   } | ||||||
|   /** |   /** | ||||||
|    * 捕获 checkbox / radio 被勾选 或 取消勾选的事件回调函数 |    * 捕获 checkbox / radio 被勾选 或 取消勾选的事件回调函数 | ||||||
| @ -544,7 +541,7 @@ export const useTree = () => { | |||||||
|       "GDSLImagery", |       "GDSLImagery", | ||||||
|       "layer", |       "layer", | ||||||
|     ]; |     ]; | ||||||
|     let layers:any = [] |     let layers: any = [] | ||||||
|     if (window.earth) { |     if (window.earth) { | ||||||
|       for (let i = 0; i < zNodes.value.length; i++) { |       for (let i = 0; i < zNodes.value.length; i++) { | ||||||
|         if (zNodes.value[i].sourceType === 'directory') { |         if (zNodes.value[i].sourceType === 'directory') { | ||||||
| @ -560,7 +557,7 @@ export const useTree = () => { | |||||||
|         if (!params.name) { |         if (!params.name) { | ||||||
|           params.name = zNodes.value[i].sourceName |           params.name = zNodes.value[i].sourceName | ||||||
|         } |         } | ||||||
|         if(arr.includes(zNodes.value[i].sourceType)) { |         if (arr.includes(zNodes.value[i].sourceType)) { | ||||||
|           layers.push( |           layers.push( | ||||||
|             { |             { | ||||||
|               sourceType: zNodes.value[i].sourceType, |               sourceType: zNodes.value[i].sourceType, | ||||||
| @ -575,7 +572,7 @@ export const useTree = () => { | |||||||
|       layers.sort((obj1, obj2) => { |       layers.sort((obj1, obj2) => { | ||||||
|         return obj1.params.layerIndex - obj2.params.layerIndex; |         return obj1.params.layerIndex - obj2.params.layerIndex; | ||||||
|       }); |       }); | ||||||
|       for(let i = 0; i < layers.length; i++) { |       for (let i = 0; i < layers.length; i++) { | ||||||
|         initMapData(layers[i].sourceType, layers[i].params, null) |         initMapData(layers[i].sourceType, layers[i].params, null) | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -661,6 +661,7 @@ export const useTreeNode = () => { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   return { |   return { | ||||||
|  |     nodeType, | ||||||
|     showRightMenu, |     showRightMenu, | ||||||
|     cusNodeIcon, |     cusNodeIcon, | ||||||
|     getSelectedNodes, |     getSelectedNodes, | ||||||
|  | |||||||
| @ -11,14 +11,8 @@ | |||||||
|   <firstMenu class="absolute zIndex9" ref="firstMenuRef"></firstMenu> |   <firstMenu class="absolute zIndex9" ref="firstMenuRef"></firstMenu> | ||||||
|   <!--底部菜单--> |   <!--底部菜单--> | ||||||
|   <bottomMenu class="absolute zIndex9" ref="bottomMenuRef"></bottomMenu> |   <bottomMenu class="absolute zIndex9" ref="bottomMenuRef"></bottomMenu> | ||||||
|   <input |   <input type="file" id="fileInputlink" style="display: none" multiple accept=".jpeg,.png,.jpg,.mp4,.pdf" | ||||||
|     type="file" |     @input="uploadFile" /> | ||||||
|     id="fileInputlink" |  | ||||||
|     style="display: none" |  | ||||||
|     multiple |  | ||||||
|     accept=".jpeg,.png,.jpg,.mp4,.pdf" |  | ||||||
|     @input="uploadFile" |  | ||||||
|   /> |  | ||||||
|  |  | ||||||
|   <!-- 多点视线分析 --> |   <!-- 多点视线分析 --> | ||||||
|   <Visibility ref="visibility"></Visibility> |   <Visibility ref="visibility"></Visibility> | ||||||
| @ -135,6 +129,7 @@ let dynamicComponentRef = ref() | |||||||
| let addStandTextRef = ref() | let addStandTextRef = ref() | ||||||
| let tree = ref() | let tree = ref() | ||||||
| let selectImgRef = ref() | let selectImgRef = ref() | ||||||
|  | let editdirectoryBox = ref() | ||||||
| eventBus.on('openDialog', async (sourceType: any, id: any) => { | eventBus.on('openDialog', async (sourceType: any, id: any) => { | ||||||
|   console.log(sourceType, id) |   console.log(sourceType, id) | ||||||
|   if (dynamicComponentRef.value && dynamicComponentRef.value.close) { |   if (dynamicComponentRef.value && dynamicComponentRef.value.close) { | ||||||
| @ -142,7 +137,7 @@ eventBus.on('openDialog', async (sourceType: any, id: any) => { | |||||||
|   } |   } | ||||||
|   switch (sourceType) { |   switch (sourceType) { | ||||||
|     case 'directory': |     case 'directory': | ||||||
|     $changeComponentPop('.editdirectoryBox', true) |       editdirectoryBox.value.open() | ||||||
|       // currentComponent.value = addDirectory |       // currentComponent.value = addDirectory | ||||||
|       // await nextTick() |       // await nextTick() | ||||||
|       // dynamicComponentRef.value?.open() |       // dynamicComponentRef.value?.open() | ||||||
| @ -422,9 +417,9 @@ const getStatus = (time) => { | |||||||
|   const currentTimestamp = Date.now() |   const currentTimestamp = Date.now() | ||||||
|  |  | ||||||
|   if (timestamp > currentTimestamp) { |   if (timestamp > currentTimestamp) { | ||||||
|     ;(window as any).checkAuthIsValid = true |     ; (window as any).checkAuthIsValid = true | ||||||
|   } else { |   } else { | ||||||
|     ;(window as any).checkAuthIsValid = false |     ; (window as any).checkAuthIsValid = false | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -441,7 +436,8 @@ onMounted(async () => { | |||||||
|   height: 100%; |   height: 100%; | ||||||
| } | } | ||||||
|  |  | ||||||
| .adddirectoryBox, .editdirectoryBox { | .adddirectoryBox, | ||||||
|  | .editdirectoryBox { | ||||||
|   display: none; |   display: none; | ||||||
| } | } | ||||||
| </style> | </style> | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user