1
zhang
2025-10-03 232a3c6a9b65ee04e4ac73236a9d90076ee7a105
pages/home/home.vue
@@ -2,8 +2,9 @@
   <view>
      <scroll-view scroll-y class="page">
         <view class="nav-list">
            <navigator hover-class='none' :url="'/pages/component/' + item.name" class="nav-li" navigateTo :class="'bg-'+item.color"
             :style="[{animation: 'show ' + ((index+1)*0.2+1) + 's 1'}]" v-for="(item,index) in elements" :key="index">
            <navigator hover-class='none' :url="'/pages' + item.url" class="nav-li" navigateTo
               :class="'bg-'+item.color" :style="[{animation: 'show ' + ((index+1)*0.2+1) + 's 1'}]"
               v-for="(item,index) in elements2" :key="index">
               <view class="nav-title">{{item.title}}</view>
               <view class="nav-name">{{item.name}}</view>
               <text :class="'cuIcon-' + item.cuIcon"></text>
@@ -18,68 +19,280 @@
   export default {
      data() {
         return {
            elements: [{
                  title: '操作条',
                  name: 'bar',
                  color: 'purple',
                  cuIcon: 'vipcard'
               },
            baseUrl: '',
            token: '',
            icon: '',
            elements: [],
            elements2: [
               {
                  title: '导航栏 ',
                  name: 'nav',
                  color: 'mauve',
                  cuIcon: 'formfill'
               },
               {
                  title: '列表',
                  name: 'list',
                  color: 'pink',
                  cuIcon: 'list'
               },
               {
                  title: '卡片',
                  name: 'card',
                  color: 'brown',
                  cuIcon: 'newsfill'
               },
               {
                  title: '表单',
                  name: 'form',
                  color: 'red',
                  cuIcon: 'formfill'
               },
               {
                  title: '时间轴',
                  name: 'timeline',
                  color: 'orange',
                  cuIcon: 'timefill'
               },
               {
                  title: '聊天',
                  name: 'chat',
                  color: 'green',
                  cuIcon: 'messagefill'
               },
               {
                  title: '轮播',
                  name: 'swiper',
                  color: 'olive',
                  cuIcon: 'album'
               },
               {
                  title: '模态框',
                  name: 'modal',
                  color: 'grey',
                  cuIcon: 'squarecheckfill'
               },
               {
                  title: '步骤条',
                  name: 'steps',
                  title: '组托入库',
                  name: 'pakin',
                  color: 'cyan',
                  cuIcon: 'roundcheckfill'
               }
                  cuIcon: 'pullup',
                  url: '/pakin/pakin'
               },
               // {
               //    title: 'AGV组托入库',
               //    name: 'AGVPakin',
               //    color: 'cyan',
               //    cuIcon: 'pullup',
               //    url: '/AGV/AGVPakin'
               // },
               // {
               //    title: 'AGV验布入库',
               //    name: 'pakin',
               //    color: 'cyan',
               //    cuIcon: 'pullup',
               //    url: '/AGV/AGVYBPakin'
               // },
               // {
               //    title: 'AGV订单入库',
               //    name: 'pakin',
               //    color: 'cyan',
               //    cuIcon: 'pullup',
               //    url: '/order/orderPakin3'
               // },
               // {
               //    title: '补空托盘',
               //    name: 'AGVFillEmptyPallets',
               //    color: 'blue',
               //    cuIcon: 'order',
               //    url: '/AGV/AGVkongban'
               // },
               //{
               //    title: '出库确认--批号校验',
               //    name: 'outConfilm',
               //    color: 'red',
               //    cuIcon: 'pullup',
               //    url: '/pakin/outConfilm'
               // },{
               //    title: '出库确认',
               //    name: 'outConfilm',
               //    color: 'red',
               //    cuIcon: 'pullup',
               //    url: '/pakin/outConfilm1'
               // },{
               //    title: '空板回库或者拣料回库',
               //    name: 'AGVStart',
               //    color: 'yellow',
               //    cuIcon: 'order',
               //    url: '/AGV/AGVStart-return'
               // },
               // {
               //    title: '再次拣料',
               //    name: 'changePallet',
               //    color: 'green',
               //    cuIcon: 'order',
               //    url: '/pakin/pickAgain'
               // },
               {
                  title: '订单入库',
                  name: 'orderPakin',
                  color: 'red',
                  cuIcon: 'pullup',
                  url: '/pakin/pakin2'
               },
               // {
               //    title: 'AGV点到点移动任务',
               //    name: 'AGVStart',
               //    color: 'green',
               //    cuIcon: 'order',
               //    url: '/AGV/AGVStart'
               // },{
               //    title: 'AGV点到区域移动任务',
               //    name: 'AGVStart',
               //    color: 'green',
               //    cuIcon: 'order',
               //    url: '/AGV/AGVStartSITEZONE'
               // },{
               //    title: 'AGV区域到点移动任务',
               //    name: 'AGVStart',
               //    color: 'green',
               //    cuIcon: 'order',
               //    url: '/AGV/AGVStartZONESITE'
               // },
               // {
               //    title: '呼叫空托盘',
               //    name: 'AGVkongban',
               //    color: 'blue',
               //    cuIcon: 'pullup',
               //    url: '/AGV/AGVkongban'
               // },
               // {
               //    title: '组托上架',
               //    name: 'putOn',
               //    color: 'orange',
               //    cuIcon: 'pullup',
               //    url: '/pakin/putOn'
               // },
               // {
               //    title: '打印',
               //    name: 'print',
               //    color: 'purple',
               //    cuIcon: 'text',
               //    url: '/print/print'
               // },
               // {
               //    title: '订单上架',
               //    name: 'orderPutOn',
               //    color: 'yellow',
               //    cuIcon: 'pullup',
               //    url: '/order/orderPutOn'
               // },
               // {
               //    title: '订单下架',
               //    name: 'orderPutDown',
               //    color: 'olive',
               //    cuIcon: 'pulldown',
               //    url: '/order/orderPutDown'
               // },
               // {
               //    title: '库存查询',
               //    name: 'stockQuery',
               //    color: 'green',
               //    cuIcon: 'check',
               //    url: '/stock/stockQuery'
               // },
               // {
               //    title: '盘点',
               //    name: 'stockCheck',
               //    color: 'red',
               //    cuIcon: 'post',
               //    url: '/stock/stockCheck'
               // },
               // {
               //    title: '商品打印',
               //    name: 'matList',
               //    color: 'orange',
               //    cuIcon: 'post',
               //    url: '/mat/matList'
               // },
               // {
               //    title: '补货',
               //    name: 'restock',
               //    color: 'yellow',
               //    cuIcon: 'punch',
               //    url: '/stock/restock'
               // },
               // {
               //    title: '转全板',
               //    name: 'piking',
               //    color: 'olive',
               //    cuIcon: 'order',
               //    url: '/pakin/piking'
               // },
               // {
               //    title: '并板组托',
               //    name: 'mergeStore',
               //    color: 'olive',
               //    cuIcon: 'order',
               //    url: '/pakin/mergeStore'
               // },
               // {
               //    title: '换板绑定',
               //    name: 'changePallet',
               //    color: 'green',
               //    cuIcon: 'order',
               //    url: '/stock/changePallet'
               // },
               {
                  title: '退出登录',
                  name: 'logOut',
                  color: 'grey',
                  cuIcon: 'exit',
                  url: '/login/logOut'
               },
            ],
            colorList: ['cyan','blue','mauve','pink','brown','red','orange','yellow','olive','olive','green','grey' ]
         };
      },
      onShow() {
         this.baseUrl = uni.getStorageSync('baseUrl');
         this.token = uni.getStorageSync('token');
         this.getAuth()
      },
      methods: {
         getAuth() {
            let that = this
            uni.request({
               url: that.baseUrl + '/menu/pda/auth',
               data: {},
               header: { 'token': uni.getStorageSync('token') },
               method: 'POST',
               success(res) {
                  res = res.data
                  that.elements = [
                     // {
                     //    title: '组件入库',
                     //    name: 'modulePakin',
                     //    color: 'green',
                     //    cuIcon: 'order',
                     //    url: '/pakin/modulePakin'
                     // },
                  ]
                  if (res.code === 200) {
                     if (res.data == undefined || res.data == null || res.data == "") {
                        that.elements = that.elements2
                        return
                     }
                     for (var i = 0; i < res.data.length; i++) {
                        if (res.data.length < 0) {
                           break;
                        }
                        that.getIcon(res.data[i].title)
                        that.elements.push({
                           title: res.data[i].name,
                           name: res.data[i].title,
                           color: that.colorList[i],
                           cuIcon: that.icon,
                           url: res.data[i].action
                        })
                     }
                     that.elements.push({
                        title: '退出登录',
                        name: 'logOut',
                        color: 'grey',
                        cuIcon: 'exit',
                        url: '/login/logOut'
                     })
                  } else if (res.code === 403) {
                     uni.showToast({
                        title: res.msg,
                        icon: "none",
                        position: 'top'
                     })
                     setTimeout(() => {
                        uni.reLaunch({
                           url: '../login/login'
                        });
                     }, 1000);
                  } else if(res.status === 404) {
                     that.elements = that.elements2
                     // uni.showToast({
                     //    title: '默认主页',
                     //    icon: "none",
                     //    position: 'top'
                     // })
                  } else {
                     uni.showToast({
                        title: res.msg,
                        icon: "none",
                        position: 'top'
                     })
                  }
               },
               fail(err) {
                  console.log(err);
               }
            })
         },
         getIcon(e) {
            const ways = ['pakin','orderPakin','orderPutOn']
            if (ways.includes(e)) {
               this.icon = 'pullup'
            }
         }
      }
   }
</script>
@@ -88,76 +301,77 @@
   .page {
      height: 100vh;
   }
   .bg-red {
      background-color: #e54d42;
      color: #ffffff;
   }
   .bg-orange {
      background-color: #f37b1d;
      color: #ffffff;
   }
   .bg-yellow {
      background-color: #fbbd08;
      color: #333333;
   }
   .bg-olive {
      background-color: #8dc63f;
      color: #ffffff;
   }
   .bg-green {
      background-color: #39b54a;
      color: #ffffff;
   }
   .bg-cyan {
      background-color: #1cbbb4;
      color: #ffffff;
   }
   .bg-blue {
      background-color: #0081ff;
      color: #ffffff;
   }
   .bg-purple {
      background-color: #6739b6;
      color: #ffffff;
   }
   .bg-mauve {
      background-color: #9c26b0;
      color: #ffffff;
   }
   .bg-pink {
      background-color: #e03997;
      color: #ffffff;
   }
   .bg-brown {
      background-color: #a5673f;
      color: #ffffff;
   }
   .bg-grey {
      background-color: #8799a3;
      color: #ffffff;
   }
   .bg-gray {
      background-color: #f0f0f0;
      color: #333333;
   }
   .bg-black {
      background-color: #333333;
      color: #ffffff;
   }
   .bg-white {
      background-color: #ffffff;
      color: #666666;