From 5e26f4e419440a810d66d2f3a5c978da5581f56f Mon Sep 17 00:00:00 2001 From: 潘志宝 <979469083@qq.com> Date: 星期一, 06 一月 2025 13:30:00 +0800 Subject: [PATCH] pyFile可编辑 --- src/views/Home/Index2.vue | 367 ++++++++++------------------------------------------ 1 files changed, 71 insertions(+), 296 deletions(-) diff --git a/src/views/Home/Index2.vue b/src/views/Home/Index2.vue index c9429ab..69f23ad 100644 --- a/src/views/Home/Index2.vue +++ b/src/views/Home/Index2.vue @@ -1,319 +1,94 @@ <template> - <el-row :class="prefixCls" :gutter="20" justify="space-between"> - <el-col :lg="6" :md="12" :sm="12" :xl="6" :xs="24"> - <el-card class="mb-20px" shadow="hover"> - <el-skeleton :loading="loading" :rows="2" animated> - <template #default> - <div :class="`${prefixCls}__item flex justify-between`"> - <div> - <div - :class="`${prefixCls}__item--icon ${prefixCls}__item--peoples p-16px inline-block rounded-6px`" - > - <Icon :size="40" icon="svg-icon:peoples" /> - </div> - </div> - <div class="flex flex-col justify-between"> - <div :class="`${prefixCls}__item--text text-16px text-gray-500 text-right`" - >{{ t('analysis.newUser') }} - </div> - <CountTo - :duration="2600" - :end-val="102400" - :start-val="0" - class="text-right text-20px font-700" - /> - </div> - </div> - </template> - </el-skeleton> - </el-card> - </el-col> + <ToolHeader ref="toolHeader" /> + <div> + <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)"> + {{item.appName}} + </div> + </div> + </el-skeleton> - <el-col :lg="6" :md="12" :sm="12" :xl="6" :xs="24"> - <el-card class="mb-20px" shadow="hover"> - <el-skeleton :loading="loading" :rows="2" animated> - <template #default> - <div :class="`${prefixCls}__item flex justify-between`"> - <div> - <div - :class="`${prefixCls}__item--icon ${prefixCls}__item--message p-16px inline-block rounded-6px`" - > - <Icon :size="40" icon="svg-icon:message" /> - </div> - </div> - <div class="flex flex-col justify-between"> - <div :class="`${prefixCls}__item--text text-16px text-gray-500 text-right`" - >{{ t('analysis.unreadInformation') }} - </div> - <CountTo - :duration="2600" - :end-val="81212" - :start-val="0" - class="text-right text-20px font-700" - /> - </div> - </div> - </template> - </el-skeleton> - </el-card> - </el-col> - - <el-col :lg="6" :md="12" :sm="12" :xl="6" :xs="24"> - <el-card class="mb-20px" shadow="hover"> - <el-skeleton :loading="loading" :rows="2" animated> - <template #default> - <div :class="`${prefixCls}__item flex justify-between`"> - <div> - <div - :class="`${prefixCls}__item--icon ${prefixCls}__item--money p-16px inline-block rounded-6px`" - > - <Icon :size="40" icon="svg-icon:money" /> - </div> - </div> - <div class="flex flex-col justify-between"> - <div :class="`${prefixCls}__item--text text-16px text-gray-500 text-right`" - >{{ t('analysis.transactionAmount') }} - </div> - <CountTo - :duration="2600" - :end-val="9280" - :start-val="0" - class="text-right text-20px font-700" - /> - </div> - </div> - </template> - </el-skeleton> - </el-card> - </el-col> - - <el-col :lg="6" :md="12" :sm="12" :xl="6" :xs="24"> - <el-card class="mb-20px" shadow="hover"> - <el-skeleton :loading="loading" :rows="2" animated> - <template #default> - <div :class="`${prefixCls}__item flex justify-between`"> - <div> - <div - :class="`${prefixCls}__item--icon ${prefixCls}__item--shopping p-16px inline-block rounded-6px`" - > - <Icon :size="40" icon="svg-icon:shopping" /> - </div> - </div> - <div class="flex flex-col justify-between"> - <div :class="`${prefixCls}__item--text text-16px text-gray-500 text-right`" - >{{ t('analysis.totalShopping') }} - </div> - <CountTo - :duration="2600" - :end-val="13600" - :start-val="0" - class="text-right text-20px font-700" - /> - </div> - </div> - </template> - </el-skeleton> - </el-card> - </el-col> - </el-row> - <el-row :gutter="20" justify="space-between"> - <el-col :lg="10" :md="24" :sm="24" :xl="10" :xs="24"> - <el-card class="mb-20px" shadow="hover"> - <el-skeleton :loading="loading" animated> - <Echart :height="300" :options="pieOptionsData" /> - </el-skeleton> - </el-card> - </el-col> - <el-col :lg="14" :md="24" :sm="24" :xl="14" :xs="24"> - <el-card class="mb-20px" shadow="hover"> - <el-skeleton :loading="loading" animated> - <Echart :height="300" :options="barOptionsData" /> - </el-skeleton> - </el-card> - </el-col> - <el-col :span="24"> - <el-card class="mb-20px" shadow="hover"> - <el-skeleton :loading="loading" :rows="4" animated> - <Echart :height="350" :options="lineOptionsData" /> - </el-skeleton> - </el-card> - </el-col> - </el-row> </template> <script lang="ts" setup> -import { set } from 'lodash-es' -import { EChartsOption } from 'echarts' -import { useDesign } from '@/hooks/web/useDesign' -import type { AnalysisTotalTypes } from './types' -import { barOptions, lineOptions, pieOptions } from './echarts-data' +import * as AppApi from '@/api/system/app' +import * as LoginApi from '@/api/login' +import ToolHeader from '@/layout/components/ToolHeader.vue' +import {Apps} from "@/views/Home/types"; +import {CACHE_KEY, useCache} from "@/hooks/web/useCache"; +import {usePermissionStore} from "@/store/modules/permission"; +import {OAuth2Login, OAuth2TokenVO} from "@/api/system/oauth2/token"; +import * as authUtil from "@/utils/auth"; +import {CommonStatusEnum} from "@/utils/constants"; +import * as UserApi from "@/api/system/user"; +const permissionStore = usePermissionStore() +const { push } = useRouter() + +const formData = ref({ + grantType: 'password', + scope: 'user.read user.write', + refreshToken: authUtil.getRefreshToken(), + username: authUtil.getLoginForm().username, + password: authUtil.getLoginForm().password, + redirectUri: 'http://localhost:90', +}) defineOptions({ name: 'Home2' }) -const { t } = useI18n() +const { wsCache } = useCache() + const loading = ref(true) -const { getPrefixCls } = useDesign() -const prefixCls = getPrefixCls('panel') -const pieOptionsData = reactive<EChartsOption>(pieOptions) as EChartsOption -let totalState = reactive<AnalysisTotalTypes>({ - users: 0, - messages: 0, - moneys: 0, - shoppings: 0 -}) +let appList = reactive<Apps[]>([]) -const getCount = async () => { - const data = { - users: 102400, - messages: 81212, - moneys: 9280, - shoppings: 13600 - } - totalState = Object.assign(totalState, data) -} - -// 用户来源 -const getUserAccessSource = async () => { - const data = [ - { value: 335, name: 'analysis.directAccess' }, - { value: 310, name: 'analysis.mailMarketing' }, - { value: 234, name: 'analysis.allianceAdvertising' }, - { value: 135, name: 'analysis.videoAdvertising' }, - { value: 1548, name: 'analysis.searchEngines' } - ] - set( - pieOptionsData, - 'legend.data', - data.map((v) => t(v.name)) - ) - set(pieOptionsData, 'series.data', data) -} -const barOptionsData = reactive<EChartsOption>(barOptions) as EChartsOption - -// 周活跃量 -const getWeeklyUserActivity = async () => { - const data = [ - { value: 13253, name: 'analysis.monday' }, - { value: 34235, name: 'analysis.tuesday' }, - { value: 26321, name: 'analysis.wednesday' }, - { value: 12340, name: 'analysis.thursday' }, - { value: 24643, name: 'analysis.friday' }, - { value: 1322, name: 'analysis.saturday' }, - { value: 1324, name: 'analysis.sunday' } - ] - set( - barOptionsData, - 'xAxis.data', - data.map((v) => t(v.name)) - ) - set(barOptionsData, 'series', [ - { - name: t('analysis.activeQuantity'), - data: data.map((v) => v.value), - type: 'bar' - } - ]) -} - -const lineOptionsData = reactive<EChartsOption>(lineOptions) as EChartsOption - -// 每月销售总额 -const getMonthlySales = async () => { - const data = [ - { estimate: 100, actual: 120, name: 'analysis.january' }, - { estimate: 120, actual: 82, name: 'analysis.february' }, - { estimate: 161, actual: 91, name: 'analysis.march' }, - { estimate: 134, actual: 154, name: 'analysis.april' }, - { estimate: 105, actual: 162, name: 'analysis.may' }, - { estimate: 160, actual: 140, name: 'analysis.june' }, - { estimate: 165, actual: 145, name: 'analysis.july' }, - { estimate: 114, actual: 250, name: 'analysis.august' }, - { estimate: 163, actual: 134, name: 'analysis.september' }, - { estimate: 185, actual: 56, name: 'analysis.october' }, - { estimate: 118, actual: 99, name: 'analysis.november' }, - { estimate: 123, actual: 123, name: 'analysis.december' } - ] - set( - lineOptionsData, - 'xAxis.data', - data.map((v) => t(v.name)) - ) - set(lineOptionsData, 'series', [ - { - name: t('analysis.estimate'), - smooth: true, - type: 'line', - data: data.map((v) => v.estimate), - animationDuration: 2800, - animationEasing: 'cubicInOut' - }, - { - name: t('analysis.actual'), - smooth: true, - type: 'line', - itemStyle: {}, - data: data.map((v) => v.actual), - animationDuration: 2800, - animationEasing: 'quadraticOut' - } - ]) +const getAppList = async () => { + const data = await AppApi.getAppList() + appList = Object.assign(appList, data) } const getAllApi = async () => { - await Promise.all([getCount(), getUserAccessSource(), getWeeklyUserActivity(), getMonthlySales()]) + await Promise.all([ + getAppList() + ]) loading.value = false } getAllApi() + +// 进入应用 +const gotoApp = async (item) => { + let appType = item.appType + console.log(appType) + if(appType === 1) { + window.location.href = '/index' + } else { + // await OAuth2Login(formData.value) + window.open('http://localhost:90/login?appid=' + item.appMenuId + "&username=" + authUtil.getLoginForm().username, '_blank') + } +} + </script> <style lang="scss" scoped> -$prefix-cls: #{$namespace}-panel; - -.#{$prefix-cls} { - &__item { - &--peoples { - color: #40c9c6; - } - - &--message { - color: #36a3f7; - } - - &--money { - color: #f4516c; - } - - &--shopping { - color: #34bfa3; - } - - &:hover { - :deep(.#{$namespace}-icon) { - color: #fff !important; - } - - .#{$prefix-cls}__item--icon { - transition: all 0.38s ease-out; - } - - .#{$prefix-cls}__item--peoples { - background: #40c9c6; - } - - .#{$prefix-cls}__item--message { - background: #36a3f7; - } - - .#{$prefix-cls}__item--money { - background: #f4516c; - } - - .#{$prefix-cls}__item--shopping { - background: #34bfa3; - } - } - } +#app{ + width: 300px; + height: 140px; + display: inline-block; + background: transparent; +} +.card{ + width: 300px; + height: 100px; + padding: 30px; + text-align: center; + justify-content: center; + font-size: 30px; + font-weight: bolder; + color: blue; + background: aliceblue; + border-radius: 10px; } </style> -- Gitblit v1.9.3