| <template> | 
|   <div class="container"> | 
|     <authheader :items="menuTips"></authheader> | 
|   | 
|     <a-row :gutter="20"> | 
|       <a-col :span="8"> | 
|         <a-card :title="$t('menu.organization.title')" :bordered="false" :style="{ width: '100%',height: '900px', 'overflow-y': 'auto' }"> | 
|           <a-tree | 
|             class="tree-demo" | 
|             draggable | 
|             blockNode | 
|             :data="treeData" | 
|             :show-line="showLine" | 
|             :fieldNames="{ | 
|               key:'deptId', | 
|               title:'deptName', | 
|               children:'children', | 
|             }" | 
|             @drop="onDrop" | 
|             @select="showDetail" | 
|           > | 
|             <template #extra="nodeData"> | 
|               <IconPlus | 
|                 style="position: absolute; right: 60px; font-size: 12px; top: 10px; color: #3370ff;" | 
|                 @click="() => onIconClick(nodeData)" | 
|               /> | 
|               <IconDelete style="position: absolute; right: 40px; font-size: 12px; top: 10px; color: #3370ff;" | 
|                           @click="() => onIconClickDelete(nodeData)" /> | 
|             </template> | 
|           </a-tree> | 
|   | 
|         </a-card> | 
|       </a-col> | 
|       <a-col :span="16"> | 
|         <a-card :title="$t('menu.organization.detail')" :bordered="false" :style="{ width: '100%' }"> | 
|           <a-form :model="deptform" layout="horizontal"> | 
|             <a-form-item field="parentName" label="上级机构"> | 
|               <a-input v-model="deptform.parentId" /> | 
|             </a-form-item> | 
|             <a-form-item field="status" label="机构状态"> | 
|               <a-switch checked-value="0" unchecked-value="1" v-model="deptform.status"></a-switch> | 
|             </a-form-item> | 
|             <a-form-item field="deptName" label="机构名称"> | 
|               <a-input v-model="deptform.deptName" /> | 
|             </a-form-item> | 
|             <a-form-item field="leader" label="联系人"> | 
|               <a-input v-model="deptform.leader" /> | 
|             </a-form-item> | 
|             <a-form-item field="phone" label="联系电话"> | 
|               <a-input v-model="deptform.phone" /> | 
|             </a-form-item> | 
|             <a-form-item field="address" label="机构地址" style="align: start"> | 
|               <a-input v-model="deptform.address" /> | 
|             </a-form-item> | 
|             <a-form-item> | 
|               <a-space> | 
|                 <a-button  @click="editdept">保存</a-button> | 
|                 <a-button @click="reset(deptform.deptId)">重置</a-button> | 
|               </a-space> | 
|             </a-form-item> | 
|           </a-form> | 
|         </a-card> | 
|       </a-col> | 
|     </a-row> | 
|     <a-modal width="50%" v-model:visible="visible" title="新增" @cancel="handleCancel" @ok="addDept"> | 
|       <a-form :model="deptform" layout="horizontal"> | 
|         <a-form-item field="parentName" label="上级机构"> | 
|           <a-input v-model="deptform.parentName" /> | 
|         </a-form-item> | 
|         <a-form-item field="status" label="机构状态"> | 
|           <a-switch checked-value="0" unchecked-value="1" v-model="deptform.status"></a-switch> | 
|         </a-form-item> | 
|         <a-form-item field="deptName" label="机构名称"> | 
|           <a-input v-model="deptform.deptName" /> | 
|         </a-form-item> | 
|         <a-form-item field="leader" label="联系人"> | 
|           <a-input v-model="deptform.leader" /> | 
|         </a-form-item> | 
|         <a-form-item field="phone" label="联系电话"> | 
|           <a-input v-model="deptform.phone" /> | 
|         </a-form-item> | 
|         <a-form-item field="address" label="机构地址" style="align: start"> | 
|           <a-input v-model="deptform.address" /> | 
|         </a-form-item> | 
|       </a-form> | 
|     </a-modal> | 
|   </div> | 
| </template> | 
|   | 
| <script lang="ts" setup> | 
| import { ref } from "vue"; | 
| import { IconPlus } from "@arco-design/web-vue/es/icon"; | 
| import { | 
|   Organization, | 
|   OrganizationAdd, | 
|   OrganizationById, | 
|   OrganizationDelete, | 
|   OrganizationList, | 
|   OrganizationUpdate | 
| } from "@/api/authority"; | 
| import Authheader from "@/views/authority/components/authheader.vue"; | 
| import { Modal } from "@arco-design/web-vue"; | 
|   | 
| let visible = ref(false); | 
| let treeData = ref([]); | 
| let showLine = ref(true); | 
| let menuTips = ref(["权限管理", "机构"]); | 
| let deptform = ref<Organization>({ | 
|   deptName: "", | 
|   email: "", | 
|   leader: "", | 
|   orderNum: "0", | 
|   parentId: "", | 
|   parentName: "", | 
|   phone: "", | 
|   status: "", | 
|   address: "", | 
|   deptId: "" | 
| }); | 
|   | 
| const onIconClick = (nodeData) => { | 
|   deptform.value.parentName = nodeData.deptName; | 
|   deptform.value.parentId = nodeData.deptId; | 
|   visible.value = true; | 
| }; | 
|   | 
| const addDept = async () => { | 
|   await OrganizationAdd({ | 
|     ...deptform.value | 
|   } as unknown as Organization).then((res) => { | 
|     OrganizationData(""); | 
|   }); | 
| }; | 
|   | 
| const onIconClickDelete = (nodeData) => { | 
|   OrganizationDelete(nodeData.deptId).then(() => { | 
|     OrganizationData(""); | 
|   }); | 
| }; | 
|   | 
| const showDetail = (id) => { | 
|   OrganizationById(id).then((res) => { | 
|     deptform.value = {...res.data}; | 
|   }); | 
| }; | 
| const editdept=()=>{ | 
|    OrganizationUpdate({ | 
|     ...deptform.value | 
|   } as unknown as Organization).then((res) => { | 
|     OrganizationData(""); | 
|      Modal.success({ | 
|        title: "保存成功", | 
|        content: "保存成功" | 
|      }); | 
|   }); | 
| } | 
| const reset=(id)=>{ | 
|   OrganizationById(id).then((res) => { | 
|     deptform.value = {...res.data}; | 
|   }); | 
| } | 
|   | 
| const onDrop = ({ dragNode, dropNode, dropPosition }) => { | 
|   const data = treeData.value; | 
|   OrganizationUpdate({ | 
|     orderNum: "0", parentId: dropNode.deptId, deptId: dragNode.deptId | 
|   }); | 
|   const loop = (data, key, callback) => { | 
|     data.some((item, index, arr) => { | 
|       if (item.deptId === key) { | 
|         callback(item, index, arr); | 
|         return true; | 
|       } | 
|       if (item.children) { | 
|         return loop(item.children, key, callback); | 
|       } | 
|       return false; | 
|     }); | 
|   }; | 
|   | 
|   loop(data, dragNode.deptId, (_, index, arr) => { | 
|     arr.splice(index, 1); | 
|   }); | 
|   | 
|   if (dropPosition === 0) { | 
|     loop(data, dropNode.deptId, (item) => { | 
|       item.children = item.children || []; | 
|       item.children.push(dragNode); | 
|     }); | 
|   } else { | 
|     loop(data, dropNode.deptId, (_, index, arr) => { | 
|       arr.splice(dropPosition < 0 ? index : index + 1, 0, dragNode); | 
|     }); | 
|   } | 
| }; | 
|   | 
| const handleCancel = (type) => { | 
|   if (type == 1) { | 
|     visible.value = false; | 
|   } | 
| }; | 
|   | 
| const OrganizationData = async (key) => { | 
|   await OrganizationList(key).then((res) => { | 
|     treeData.value = [...res.rows]; | 
|   }); | 
| }; | 
|   | 
| OrganizationData(""); | 
| </script> | 
|   | 
|   | 
| <style scoped> | 
| .tree-demo :deep(.tree-node-dropover) > :deep(.arco-tree-node-title), | 
| .tree-demo :deep(.tree-node-dropover) > :deep(.arco-tree-node-title):hover { | 
|   animation: blinkBg 0.4s 2; | 
| } | 
|   | 
| @keyframes blinkBg { | 
|   0% { | 
|     background-color: transparent; | 
|   } | 
|   | 
|   100% { | 
|     background-color: var(--color-primary-light-1); | 
|   } | 
| } | 
| </style> |