From da47a3349dcfd87db23ab8e64fbf35fe1aea5685 Mon Sep 17 00:00:00 2001
From: 潘志宝 <979469083@qq.com>
Date: 星期四, 14 十一月 2024 16:52:21 +0800
Subject: [PATCH] 预测项数据

---
 src/views/Home/Index.vue |   86 ++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 85 insertions(+), 1 deletions(-)

diff --git a/src/views/Home/Index.vue b/src/views/Home/Index.vue
index b824385..aa64a85 100644
--- a/src/views/Home/Index.vue
+++ b/src/views/Home/Index.vue
@@ -1,12 +1,96 @@
 <template>
   <div>
-    <h1>这里是应用首页</h1>
+    <h1>IAILAB 平台主页</h1>
   </div>
+  <el-skeleton :loading="loading" animated>
+    <div id="app" v-for="(item, index) in appList" :key="`dynamics-${index}`">
+      <div class="card" @click="gotoApp(item)">
+        <img :src="item.icon" style="width: 100px; height: 100px" />
+        <div>
+          {{item.appName}}
+        </div>
+      </div>
+    </div>
+  </el-skeleton>
+
 </template>
 <script lang="ts" setup>
+
+import * as AppApi from '@/api/system/app'
+import {Apps} from "@/views/Home/types";
+import {CACHE_KEY, useCache} from "@/hooks/web/useCache";
+import * as authUtil from "@/utils/auth";
 
 
 defineOptions({ name: 'Home' })
 
+const { wsCache } = useCache()
+
+const loading = ref(true)
+
+let appList = reactive<Apps[]>([])
+
+const getAppList = async () => {
+  const data = await AppApi.getAppList()
+  appList = Object.assign(appList, data)
+}
+
+const getAppMenuList = async (id) => {
+  const data = await AppApi.getAppMenuList(id)
+  let userInfo = wsCache.get(CACHE_KEY.USER)
+  userInfo.menus = data
+  wsCache.set(CACHE_KEY.USER, userInfo)
+  wsCache.set(CACHE_KEY.ROLE_ROUTERS, data)
+  window.location.href = '/plat/index'
+}
+
+const getAllApi = async () => {
+  await Promise.all([
+    getAppList()
+  ])
+  loading.value = false
+}
+
+getAllApi()
+
+// 进入应用
+const gotoApp = async (item) => {
+  let id = item.id
+  let type = item.type
+  if(type === 0) {
+    getAppMenuList(id)
+  } else {
+    const data = await AppApi.getAppMenuList(id)
+    let userInfo = wsCache.get(CACHE_KEY.USER)
+    userInfo.menus = data
+    wsCache.set(CACHE_KEY.USER, userInfo)
+    wsCache.set(CACHE_KEY.ROLE_ROUTERS, data)
+    // await OAuth2Login(formData.value)
+    // window.open(item.appDomain + '/login?appid=' + item.id + "&username=" + authUtil.getLoginForm().username, '_blank')
+    window.open(item.appDomain + '/index', '_blank')
+  }
+}
 
 </script>
+
+<style lang="scss" scoped>
+#app{
+  width: 300px;
+  height: 200px;
+  display: inline-block;
+  background: transparent;
+}
+.card{
+  border: thin dashed gainsboro;
+  width: 150px;
+  height: 120px;
+  padding: 30px;
+  text-align: center;
+  justify-content: center;
+  font-size: 15px;
+  font-weight: bolder;
+  color: blue;
+  background: aliceblue;
+  border-radius: 10px;
+}
+</style>

--
Gitblit v1.9.3