UserLayout.vue 3.88 KB
<template>
  <div id="userLayout" :class="['user-layout-wrapper', device]">
    <div 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 } 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 {}
  },
  created() {
    debugger
    Vue.ls.remove(ACCESS_TOKEN)
    this.handleLogin(true)
  },
  methods: {
    ...mapActions(['AzureADLogin']),
    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' })
          }
        })
    }
  },
  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>