From f4e6a890da2884777281031a9c736c7659c2a74a Mon Sep 17 00:00:00 2001
From: dongyukun <1208714201@qq.com>
Date: 星期四, 02 一月 2025 14:20:04 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 src/views/Home/Index.vue |  146 +++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 143 insertions(+), 3 deletions(-)

diff --git a/src/views/Home/Index.vue b/src/views/Home/Index.vue
index b824385..1558788 100644
--- a/src/views/Home/Index.vue
+++ b/src/views/Home/Index.vue
@@ -1,12 +1,152 @@
 <template>
-  <div>
-    <h1>这里是应用首页</h1>
+  <div id="title">
+    <span>工业互联网平台</span>
   </div>
+  <el-skeleton :loading="loading" animated>
+    <div id="app">
+      <div class="card" v-for="(item, index) in appList" :key="`dynamics-${index}`">
+        <div>
+          <img class="card-left" :src="item.icon"/>
+          <div class="card-right">
+            <div class="app-title">
+              {{ item.appName }}
+            </div>
+            <div class="goto-app" @click="gotoApp(item)">
+              <div>进入应用</div>
+            </div>
+          </div>
+        </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, useSessionCache} from "@/hooks/web/useCache";
 
-defineOptions({ name: 'Home' })
 
+defineOptions({name: 'Home'})
+
+const {wsCache} = useCache()
+const {wsSessionCache} = useSessionCache()
+
+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, appCode) => {
+  const data = await AppApi.getAppMenuList(id)
+  let userInfo = wsCache.get(CACHE_KEY.USER)
+  // userInfo.menus = data
+  wsCache.set(CACHE_KEY.USER, userInfo)
+  wsSessionCache.set(CACHE_KEY.ROLE_ROUTERS, data)
+  window.location.href = import.meta.env.VITE_BASE_PATH + 'index'
+}
+
+const getAllApi = async () => {
+  await Promise.all([
+    getAppList()
+  ])
+  loading.value = false
+}
+
+getAllApi()
+
+// 进入应用
+const gotoApp = async (item) => {
+  let path = window.location.pathname
+  let appName = path.split("/")[0]
+  let id = item.id
+  let type = item.type
+  let appCode = item.appCode
+  if (type === 0) {
+    await getAppMenuList(id, appCode)
+  } else {
+    // const data = await AppApi.getAppMenuList(id)
+    // let userInfo = wsCache.get(CACHE_KEY.USER)
+    // userInfo.menus = data
+    // wsCache.set(CACHE_KEY.USER, userInfo)
+    // wsSessionCache.set(CACHE_KEY.ROLE_ROUTERS, data)
+    localStorage.setItem(appCode, id)
+    window.open(item.appDomain + '/index', '_blank')
+    // window.open('/plat/shasteel', '_blank')
+    // window.location.href = '/plat/shasteel'
+    // window.location.href = `/plat/shasteel?key=energy&url=http://localhost:9000&energy=/energy/demo`
+  }
+}
 
 </script>
+
+<style lang="scss" scoped>
+#title {
+  width: 280px;
+  height: 51px;
+  margin: 30px auto;
+  font-family: Microsoft YaHei UI, Microsoft YaHei UI;
+  font-weight: bold;
+  font-size: 40px;
+  color: #282F3D;
+}
+
+#app {
+  margin: 0 96px;
+  width: 100%;
+}
+
+.card {
+  width: 354px;
+  height: 200px;
+  margin: 0 24px 24px 0;
+  background: linear-gradient(180deg, #E9F0FA 0%, #FFFFFF 100%);
+  border-radius: 12px 12px 12px 12px;
+  border: 2px solid;
+  border-image: linear-gradient(180deg, rgba(255, 255, 255, 1), rgba(255, 255, 255, 1)) 2 2;
+  display: inline-block;
+}
+
+.card-left {
+  height: 100px;
+  width: 100px;
+  float: left;
+  margin: 50px 30px;
+}
+
+.card-right {
+  float: right;
+  margin: 61px 10px;
+}
+
+.app-title {
+  width: 162px;
+  font-family: Microsoft YaHei, Microsoft YaHei;
+  font-weight: bold;
+  font-size: 24px;
+  color: #282F3D;
+}
+
+.goto-app {
+  width: 96px;
+  height: 35px;
+  margin-top: 5px;
+  background: #3A99FD;
+  border-radius: 80px 80px 80px 80px;
+  cursor: pointer;
+}
+
+.goto-app > div {
+  padding: 6px;
+  margin-left: 5px;
+  font-family: Microsoft YaHei UI, Microsoft YaHei UI;
+  font-weight: 400;
+  font-size: 18px;
+  color: #FFFFFF;
+}
+</style>

--
Gitblit v1.9.3