doum
2025-09-11 7298d5354963a88643a543b51b90192dc9fc934c
h5/App.vue
@@ -1,279 +1,299 @@
<script>
import { wxAuthorize, refreshToken } from '@/api'
export default {
  onLaunch: function () {
    var that = this
    if (!that.$store.state.openid) {
      let url = window.location.href
      let code = ''
      let source = ''
      if (url.indexOf('code=') !== -1) {
        const query = url.split('?')
        console.log('app-app', url)
        for (const q of query) {
          if (q.indexOf('code=') !== -1) {
            code = q.substring(q.indexOf('code=') + 5, q.length)
          }
          if (q.indexOf('source=') !== -1) {
            source = q.substring(q.indexOf('source=') + 7,q.indexOf('source=') + 8 )
          }
        }
        wxAuthorize({
          code: code,
          source
        }).then(res => {
          console.log('app_ress', res)
          if (res.code === 200) {
            that.$store.commit('setOpenId', res.data.openid)
            if (res.data.member) {
              that.$store.commit('setMember', res.data.member)
            }
          }
        })
      } else {
        // const appID = 'wx4d7c10bdec51942b'
        // let uri = encodeURIComponent(url)
        // let authURL =
        //   `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${appID}&redirect_uri=${uri}&response_type=code&scope=snsapi_base&state=123#wechat_redirect`
        // window.location.href = authURL
      }
    }
    // 刷新token
    const token = uni.getStorageSync('token')
    // if (token) {
    //    refreshToken().then(res => {
    //       if(res.code && res.code === 200){
    //         this.$store.commit('setToken', res.data)
    //      }
    //   })
    // }
  },
  onShow: function () {
    console.log('App Show')
  },
  onHide: function () {
    console.log('App Hide')
  }
}
   import {
      wxAuthorize,
      refreshToken,
      app_url
   } from '@/api'
   export default {
      onLaunch: function() {
         window.addEventListener("popstate", (event) => {
            const path = this.$route.fullPath
            // console.log('path', path);
            if (path == '/pages/login/login' || path == '/') {
               window.location.href = app_url
            }
            if (path == '/pages/wdata/home') {
               window.location.href = 'https://atwl.ahzyssl.com/zhyq_h5/#/pages/wdata/home'
            }
            if (path == '/pages/waybill/home') {
               window.location.href = 'https://atwl.ahzyssl.com/zhyq_h5/#/pages/waybill/home'
            }
         })
         uni.setStorageSync('transportList', [])
         console.log('onLaunch')
      },
      onShow: function() {
         console.log('App Show')
      },
      onHide: function() {
         console.log('App Hide')
      }
   }
</script>
<style lang="scss">
/*每个页面公共css */
@import "uview-ui/index.scss";
   /*每个页面公共css */
   @import "uview-ui/index.scss";
.flex-cb {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
   html,
   body {
      height: auto;
      min-height: 100%;
      overflow: visible;
   }
.container {
  height: 100%;
  width: 100%;
  max-width: 800rpx;
  overflow-y: auto;
}
   .flex-cb {
      display: flex;
      justify-content: space-between;
      align-items: center;
   }
.doumee-container .ivu-tabs-nav {
  width: 100%;
}
   .container {
      height: 100%;
      width: 100%;
      max-width: 800rpx;
      overflow-y: auto;
   }
.doumee-container .ivu-tabs-nav .ivu-tabs-tab {
  width: calc(100% / 3);
}
   .empty_wrap {
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      color: #666666;
      min-height: 600rpx;
.doumee-container .ivu-tabs-nav .ivu-tabs-tab {
  margin-right: 0;
  text-align: center;
}
      image {
         width: 300rpx;
         height: 300rpx;
      }
   }
.cell {
  background-color: #fff;
  display: flex;
  justify-content: space-between;
  align-items: center;
  min-height: 100rpx;
  padding: 24rpx 30rpx;
  box-sizing: border-box;
  border-bottom: 1rpx solid #eee;
  font-size: 15rpx;
  position: relative;
}
   .doumee-container .ivu-tabs-nav {
      width: 100%;
   }
.cell .title {
  flex-shrink: 0;
  color: #222;
  line-height: 20rpx;
  height: 20rpx;
  width: 28%;
  margin-right: 5%;
}
   .doumee-container .ivu-tabs-nav .ivu-tabs-tab {
      width: calc(100% / 3);
   }
.cell .content {
  flex: 1;
  font-size: 28rpx;
  font-weight: 400;
  color: #999999;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
   .doumee-container .ivu-tabs-nav .ivu-tabs-tab {
      margin-right: 0;
      text-align: center;
   }
.cell .content .input {
  width: 100%;
  height: 100%;
  font-size: 28rpx;
  font-weight: 400;
  color: #333333;
  text-align: right;
}
   .cell {
      background-color: #fff;
      display: flex;
      justify-content: space-between;
      align-items: center;
      min-height: 100rpx;
      padding: 24rpx 30rpx;
      box-sizing: border-box;
      border-bottom: 1rpx solid #eee;
      font-size: 15rpx;
      position: relative;
   }
.cell.is-link::after {
  content: "";
  display: block;
  width: 8rpx;
  height: 8rpx;
  transform: rotate(-45deg);
  border-right: 1rpx solid #999999;
  border-bottom: 1rpx solid #999999;
  margin-left: 5rpx;
}
   .cell .title {
      flex-shrink: 0;
      color: #222;
      line-height: 20rpx;
      height: 20rpx;
      width: 28%;
      margin-right: 5%;
   }
.card {
  background-color: #fff;
  padding: 16rpx;
  position: relative;
}
   .cell .content {
      flex: 1;
      font-size: 28rpx;
      font-weight: 400;
      color: #999999;
      display: flex;
      align-items: center;
      justify-content: flex-end;
   }
.card::after {
  content: "";
  display: block;
  position: absolute;
  width: calc(100% - 32rpx);
  height: 0;
  bottom: 0;
  left: 16rpx;
  border-bottom: 1rpx solid #f7f7f7;
}
   .cell .content .input {
      width: 100%;
      height: 100%;
      font-size: 28rpx;
      font-weight: 400;
      color: #333333;
      text-align: right;
   }
.card .title {
  color: #777777;
  margin-bottom: 12rpx;
}
   .cell.is-link::after {
      content: "";
      display: block;
      width: 8rpx;
      height: 8rpx;
      transform: rotate(-45deg);
      border-right: 1rpx solid #999999;
      border-bottom: 1rpx solid #999999;
      margin-left: 5rpx;
   }
.card .content {
  color: #222;
}
   .card {
      background-color: #fff;
      padding: 16rpx;
      position: relative;
   }
.placeholder9 {
  color: #999999;
  font-size: 28rpx;
}
   .card::after {
      content: "";
      display: block;
      position: absolute;
      width: calc(100% - 32rpx);
      height: 0;
      bottom: 0;
      left: 16rpx;
      border-bottom: 1rpx solid #f7f7f7;
   }
//设置圆角
checkbox .uni-checkbox-input {
  border-radius: 50%;
}
   .card .title {
      color: #777777;
      margin-bottom: 12rpx;
   }
checkbox .uni-checkbox-input.uni-checkbox-input-checked {
  color: #fff !important;
  border: 1px solid #4d99a8 !important;
  background-color: #4d99a8 !important;
}
   .card .content {
      color: #222;
   }
checkbox .uni-checkbox-input.uni-checkbox-input-checked:before {
  /* color: #4d99a8 !important;  */
  /* border: 1px solid #4d99a8 !important; */
  /* font-size: 58rpx; */
  /* border-radius: 50%; */
}
   .placeholder9 {
      color: #999999 !important;
      font-size: 28rpx;
   }
//
   .placeholder3 {
      color: #333333 !important;
   }
view {
  box-sizing: border-box;
}
   .red {
      color: red !important;
   }
image {
  box-sizing: border-box;
  margin: 0;
  display: flex;
}
input {
  font-size: 30rpx;
}
textarea {
  box-sizing: border-box;
  // background-color: #f7f7f7;
  font-size: 30rpx !important;
  padding: 0;
  border-radius: 8rpx;
  color: #333333 !important;
}
.u-textarea {
  padding: 0 !important;
  color: #333333 !important;
}
   //设置圆角
   checkbox .uni-checkbox-input {
      border-radius: 50%;
   }
.df_ac {
  display: flex;
  align-items: center;
}
   checkbox .uni-checkbox-input.uni-checkbox-input-checked {
      color: #fff !important;
      border: 1px solid #4d99a8 !important;
      background-color: #4d99a8 !important;
   }
.main_app {
  padding: 0 30rpx 30rpx;
  font-size: 28rpx;
  color: #333333;
}
.popupShow {
   overflow: hidden;
   position: fixed;
  width: 100%;
}
.placeholder6 {
  color: #666666;
  font-size: 28rpx;
}
.primaryColor {
  color: $uni-color-primary;
}
.avatar {
  width: 64rpx;
  height: 64rpx;
  border-radius: 50%;
  overflow: hidden;
  margin-right: 20rpx;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: $uni-color-primary;
  color: #fff;
  font-size: 30rpx;
}
.placeholder9 {
  color: #999999;
  font-size: 28rpx;
}
.fs24 {
  font-size: 24rpx;
}
.mr24 {
  margin-right: 24rpx;
}
.mt24 {
  margin-top: 24rpx;
}
   checkbox .uni-checkbox-input.uni-checkbox-input-checked:before {
      /* color: #4d99a8 !important;  */
      /* border: 1px solid #4d99a8 !important; */
      /* font-size: 58rpx; */
      /* border-radius: 50%; */
   }
.mr12 {
  margin-right: 12rpx;
}
.ml12 {
  margin-left: 12rpx;
}
.mt6 {
  margin-top: 6rpx;
}
.mr6 {
  margin-right: 6rpx;
}
</style>
   //
   view {
      box-sizing: border-box;
   }
   image {
      box-sizing: border-box;
      margin: 0;
      display: flex;
   }
   input {
      font-size: 30rpx;
   }
   textarea {
      box-sizing: border-box;
      // background-color: #f7f7f7;
      font-size: 30rpx !important;
      padding: 0;
      border-radius: 8rpx;
      color: #333333 !important;
   }
   .u-textarea {
      padding: 0 !important;
      color: #333333 !important;
   }
   .df_ac {
      display: flex;
      align-items: center;
   }
   .main_app {
      padding: 10rpx 30rpx 0rpx;
      font-size: 28rpx;
      color: #333333;
   }
   .popupShow {
      overflow: hidden;
      position: fixed;
      width: 100%;
   }
   .placeholder6 {
      color: #666666;
      font-size: 28rpx;
   }
   .primaryColor {
      color: $uni-color-primary;
   }
   .avatar {
      width: 64rpx;
      height: 64rpx;
      border-radius: 50%;
      margin-right: 20rpx;
      display: flex;
      justify-content: center;
      align-items: center;
      background-color: $uni-color-primary;
      color: #fff;
      font-size: 30rpx;
   }
   .placeholder9 {
      color: #999999;
      font-size: 28rpx;
   }
   .fs24 {
      font-size: 24rpx;
   }
   .mr24 {
      margin-right: 24rpx;
   }
   .mt24 {
      margin-top: 24rpx;
   }
   .mr12 {
      margin-right: 12rpx;
   }
   .ml12 {
      margin-left: 12rpx;
   }
   .ml6 {
      margin-left: 6rpx;
   }
   .mt6 {
      margin-top: 6rpx;
   }
   .mr6 {
      margin-right: 6rpx;
   }
</style>