UserLayout.vue 5.35 KB
<template>
  <div id="userLayout" :class="['user-layout-wrapper', device]">
    <div v-show="showContainer" class="container">
      <div class="top">
        <div class="header">
          <a href="/">
            <img src="~@/assets/huaheng.png" class="logo" alt="logo" />
          </a>
        </div>
        <div class="desc">华恒仓储管理系统</div>
      </div>
      <route-view></route-view>
      <div class="footer">
        <div class="copyright">
          Copyright &copy; 2023 华恒焊接股份有限公司
        </div>
      </div>
    </div>
  </div>
</template>

<script>
import { ACCESS_TOKEN, AZURE_AD_AUTH_REDIRECT } from '@/store/mutation-types'
import RouteView from '@/components/layouts/RouteView'
import { mixinDevice } from '@/utils/mixin.js'
import Vue from 'vue'
import { mapActions } from 'vuex'

export default {
  name: 'UserLayout',
  components: { RouteView },
  mixins: [mixinDevice],
  data() {
    return {
      showContainer: true
    }
  },
  created() {
    Vue.ls.remove(ACCESS_TOKEN)
    if (process.env.VUE_APP_OPEN_AZURE_AD_LOGIN === 'true') {
      this.showContainer = false
      this.handleLogin(true)
    }
  },
  methods: {
    ...mapActions(['AzureADLogin','AzureADAuthRedirect']),
    handleLogin(rememberMe) {
      let loginParams = {
        warehouseCode: 'CS0001',
        checkKey: this.currdatetime,
        remember_me: rememberMe
      }
      this.AzureADLogin(loginParams).then(res => {
        this.$emit('success', res.result)
        this.$router.push({ path: '/dashboard/analysis' })
      }).catch(err => {
        this.$emit('fail', err)
        if (err.code == 499) {
          this.$router.push({ path: '/user/systemTokenModal' })
        }
      })
      // console.info("AZURE_AD_AUTH_REDIRECT:" + Vue.ls.get(AZURE_AD_AUTH_REDIRECT));
      // if (!Vue.ls.get(AZURE_AD_AUTH_REDIRECT)) {
      //   this.AzureADAuthRedirect().then((res) => {
      //     Vue.ls.set(AZURE_AD_AUTH_REDIRECT, true, 120 * 1000);
      //     window.location.href = res.result;
      //   }).catch((err) => {
      //     this.$emit('fail', err)
      //     if (err.code == 499) {
      //       this.$router.push({path: "/user/systemTokenModal"})
      //     }
      //   })
      // } else {
      //   Vue.ls.set(AZURE_AD_AUTH_REDIRECT, false, 120 * 1000)
      //   var url = window.location.href //获取当前url
      //   var dz_url = url.split('#')[0];//获取#/之前的字符串
      //   var cs = dz_url.split('?')[1] //获取?之后的参数字符串
      //   let loginParams = {
      //     warehouseCode: 'CS0001',
      //     checkKey: this.currdatetime,
      //     remember_me: rememberMe,
      //     urlParameter : "?" + cs
      //   }
      //   this.AzureADLogin(loginParams).then(res => {
      //     this.$emit('success', res.result)
      //     this.$router.push({ path: '/dashboard/analysis' })
      //   }).catch(err => {
      //     this.$emit('fail', err)
      //     if (err.code == 499) {
      //       this.$router.push({ path: '/user/systemTokenModal' })
      //     }
      //   })
      // }
    }
  },
  mounted() {
    document.body.classList.add('userLayout')
  },
  beforeDestroy() {
    document.body.classList.remove('userLayout')
  }
}
</script>

<style lang="less" scoped>
#userLayout.user-layout-wrapper {
  height: 100%;

  &.mobile {
    .container {
      .main {
        max-width: 368px;
        width: 98%;
      }
    }
  }

  .container {
    width: 100%;
    min-height: 100%;
    background-color: 255, 255, 255;
    background-size: 100%;
    // padding: 110px 0 144px;
    position: relative;

    a {
      text-decoration: none;
    }

    .top {
      text-align: center;

      .header {
        height: 59px;
        line-height: 59px;
        background-color: #111;

        .badge {
          position: absolute;
          display: inline-block;
          line-height: 1;
          vertical-align: middle;
          margin-left: -12px;
          margin-top: -10px;
          opacity: 0.8;
        }

        .logo {
          height: 59px;
          line-height: 59px;
          padding: 19px;
          vertical-align: top;
          border-style: none;
        }

        .title {
          font-size: 33px;
          color: rgba(0, 0, 0, 0.85);
          font-family: 'Chinese Quote', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Hiragino Sans GB',
            'Microsoft YaHei', 'Helvetica Neue', Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji',
            'Segoe UI Symbol';
          font-weight: 600;
          position: relative;
          top: 2px;
        }
      }

      .desc {
        font-size: 24px;
        color: #111;
        margin-top: 10%;
        margin-bottom: 70px;
        font-weight: bolder;
      }
    }

    .main {
      min-width: 260px;
      width: 368px;
      margin: 0 auto;
      height: auto;
      position: relative;
      min-height: 400px;
    }

    .footer {
      position: absolute;
      width: 100%;
      bottom: 0;
      padding: 0 16px;
      margin: 48px 0 24px;
      text-align: center;

      .links {
        margin-bottom: 8px;
        font-size: 14px;

        a {
          color: rgba(0, 0, 0, 0.45);
          transition: all 0.3s;

          &:not(:last-child) {
            margin-right: 40px;
          }
        }
      }

      .copyright {
        color: rgba(0, 0, 0, 0.45);
        font-size: 14px;
      }
    }
  }
}
</style>