货无忧安装平台
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

214 lines
4.0 KiB

<template>
<u-navbar title="工作台" placeholder border=true leftIcon=''></u-navbar>
<view class="mabox" v-for="item in tablist" :key="item.name">
<view class="boxtitl">
{{item.name}}
</view>
<view class="minboxlist">
<view @click="gopathpage(ite.router)" v-for="ite in item.minilist" :key="ite.name">
<image mode="widthFix" :src="ite.icon"></image>
<view>{{ite.name}}</view>
</view>
</view>
</view>
<tips ref="tip"></tips>
<!-- <Tabber checkstate='home'></Tabber> -->
</template>
<script lang="ts" setup>
import {
onLoad,
onShow,
onPullDownRefresh
} from '@dcloudio/uni-app'
import { getImageCache } from '@/utils/cacheimg.js'
import { listtype } from '@/interfaces/home/index'
import { reactive, toRefs, ref } from "vue";
// import { appMenuroutes } from '@/api/user.js';
const tip = ref(null)
let details = reactive<listtype>({
tablist: [
]
})
function gopathpage(path : string) {
uni.navigateTo({
url: path
})
}
onShow(() => {
// updateApp()
// print()
})
onLoad(() => {
init()
})
onPullDownRefresh(() => {
const timer = setTimeout(() => {
// 关闭刷新动画
uni.stopPullDownRefresh()
clearTimeout(timer)
}, 500)
})
async function init() {
let tabber = uni.getStorageSync('taskMenu')
console.log('tabber :>> ', tabber);
if (tabber) {
details.tablist = tabber
return
}
let res = {}
console.log(res, '-------------');
console.log('刷新后')
if (res.code == 200) {
//读取并处理缓存图标并把菜单写入缓存
getimgcache(res.data)
} else {
uni.showToast({
title: res.msg,
icon: 'none'
})
}
}
async function getimgcache(data) {
console.log('data :>> ', data);
let maxarr = []
// 首页菜单
if (!data[0]) return
for (let item of data[0].children) {
let arr = {
type: 1,
name: item.name,
minilist: []
}
for (let ite of item.children) {
let result = null;
if (ite.source != null) {
result = await getImageCache(ite.source)
}
let obj = {
icon: result,
name: ite.name,
router: ite.path
}
arr.minilist.push(obj)
}
maxarr.push(arr)
}
uni.setStorageSync('homerouter', maxarr)
const _taskArr = []
// 任务菜单
for (let item of data[1].children) {
let arr = {
type: 1,
name: item.name,
minilist: []
}
if (item.children) {
for (let ite of item.children) {
console.log('getImageCache(ite.source) :>> ', getImageCache(ite.source));
let result = null;
if (ite.source != null) {
result = await getImageCache(ite.source)
}
let obj = {
icon: result,
name: ite.name,
router: ite.path
}
arr.minilist.push(obj)
}
} else {
console.log('getImageCache(item.source) :>> ', getImageCache(item.source));
let result = null;
if (item.source != null) {
result = await getImageCache(item.source)
}
let obj = {
icon: result,
name: item.name,
router: item.path
}
arr.minilist.push(obj)
}
_taskArr.push(arr)
}
uni.setStorageSync('taskMenu', _taskArr)
details.tablist = _taskArr
console.log(details.tablist);
}
const { tablist } = toRefs(details)
</script>
<style lang="scss">
.mabox {
display: flex;
flex-direction: column;
// padding: 10upx 0;
box-sizing: border-box;
width: 686upx;
margin: auto;
background-color: #ffffff;
margin-bottom: 10upx;
margin-top: 10upx;
border-radius: 10upx;
box-shadow: 0rpx 2rpx 10rpx 0rpx #e2e2e380;
.boxtitl {
font-size: 30upx;
font-weight: 500;
margin-bottom: 10upx;
// margin-left: 10upx;
border-bottom: 2upx solid #EEEEEE;
padding: 20upx;
// padding-bottom: 0upx;
color: #092C4D;
}
.minboxlist {
display: flex;
flex-wrap: wrap;
align-items: center;
// justify-content: space-between;
padding: 10upx 0;
>view {
width: 25%;
display: flex;
flex-direction: column;
align-items: center;
margin-bottom: 15upx;
>image {
width: 100upx;
}
>view {
font-size: 26upx;
}
}
}
}
</style>