Skip to content
Snippets Groups Projects
index.vue 6.3 KiB
Newer Older
  • Learn to ignore specific revisions
  • Pan's avatar
    Pan committed
    <template>
    
    Pan's avatar
    Pan committed
      <div class="login-container">
    
    Maxim Filippov's avatar
    Maxim Filippov committed
        <el-form ref="loginForm" :model="loginForm" class="login-form" auto-complete="on" label-position="left">
    
    Pan's avatar
    Pan committed
          <div class="title-container">
    
            <h3 class="title">
              {{ $t('login.title') }}
            </h3>
    
    Pan's avatar
    Pan committed
          </div>
    
    Pan's avatar
    Pan committed
          <el-form-item prop="username">
    
    花裤衩's avatar
    花裤衩 committed
            <span class="svg-container">
    
              <svg-icon icon-class="user" />
    
    Pan's avatar
    Pan committed
            </span>
    
            <el-input
              v-model="loginForm.username"
              :placeholder="$t('login.username')"
              name="username"
              type="text"
              auto-complete="on"
    
    Pan's avatar
    Pan committed
          </el-form-item>
    
    Maxim Filippov's avatar
    Maxim Filippov committed
          <div class="omit-host-note">{{ $t('login.omitHostname') }}</div>
    
    Pan's avatar
    Pan committed
    
    
    Pan's avatar
    Pan committed
          <el-form-item prop="password">
    
    Pan's avatar
    Pan committed
            <span class="svg-container">
    
              <svg-icon icon-class="password" />
    
    Pan's avatar
    Pan committed
            </span>
    
            <el-input
              v-model="loginForm.password"
    
              :type="passwordType"
    
              :placeholder="$t('login.password')"
              name="password"
              auto-complete="on"
    
              @keyup.enter.native="handleLogin"
            />
    
    Pan's avatar
    Pan committed
            <span class="show-pwd" @click="showPwd">
    
              <svg-icon :icon-class="passwordType === 'password' ? 'eye' : 'eye-open'" />
    
    Pan's avatar
    Pan committed
            </span>
    
    Pan's avatar
    Pan committed
          </el-form-item>
    
    Pan's avatar
    Pan committed
    
    
    Maxim Filippov's avatar
    Maxim Filippov committed
          <el-button :loading="loading" class="login-button" type="primary" @click.native.prevent="handleLogin">
    
            {{ $t('login.logIn') }}
          </el-button>
    
    Maxim Filippov's avatar
    Maxim Filippov committed
          <el-button v-if="pleromaFEToken" :loading="loadingPleromaFE" class="login-button" type="primary" @click.native.prevent="handlePleromaFELogin">
            {{ $t('login.logInViaPleromaFE') }}
          </el-button>
    
    Pan's avatar
    Pan committed
        </el-form>
      </div>
    
    Pan's avatar
    Pan committed
    </template>
    
    <script>
    
    import SvgIcon from '@/components/SvgIcon'
    
    Maxim Filippov's avatar
    Maxim Filippov committed
    import localforage from 'localforage'
    import _ from 'lodash'
    import i18n from '@/lang'
    
    import { authenticateWithPleromaFE } from '@/services/pleromaAuth'
    
    Pan's avatar
    Pan committed
    export default {
    
      components: { 'svg-icon': SvgIcon },
    
    Maxim Filippov's avatar
    Maxim Filippov committed
      data: function() {
    
    Pan's avatar
    Pan committed
        return {
          loginForm: {
    
    Maxim Filippov's avatar
    Maxim Filippov committed
            username: '',
            password: ''
    
    Pan's avatar
    Pan committed
          },
    
    花裤衩's avatar
    花裤衩 committed
          passwordType: 'password',
    
    Pan's avatar
    Pan committed
          loading: false,
    
    Maxim Filippov's avatar
    Maxim Filippov committed
          loadingPleromaFE: false,
    
    Maxim Filippov's avatar
    Maxim Filippov committed
          redirect: undefined,
          pleromaFEToken: false,
          pleromaFEStateKey: 'vuex-lz',
          pleromaFEState: {}
    
    Pan's avatar
    Pan committed
        }
      },
    
      watch: {
        $route: {
          handler: function(route) {
            this.redirect = route.query && route.query.redirect
          },
          immediate: true
        }
      },
    
    Maxim Filippov's avatar
    Maxim Filippov committed
      async mounted() {
        const pleromaFEState = await localforage.getItem(this.pleromaFEStateKey)
        this.pleromaFEState = pleromaFEState
    
        if (_.get(pleromaFEState, 'oauth.userToken') === undefined) {
          return
        }
    
        this.pleromaFEToken = true
      },
    
    Pan's avatar
    Pan committed
      methods: {
        showPwd() {
    
    花裤衩's avatar
    花裤衩 committed
          if (this.passwordType === 'password') {
            this.passwordType = ''
    
    Pan's avatar
    Pan committed
          } else {
    
    花裤衩's avatar
    花裤衩 committed
            this.passwordType = 'password'
    
    Pan's avatar
    Pan committed
          }
        },
    
    Pan's avatar
    Pan committed
        handleLogin() {
    
    Maxim Filippov's avatar
    Maxim Filippov committed
          this.loading = true
    
          const loginData = this.getLoginData()
          this.$store.dispatch('LoginByUsername', loginData).then(() => {
    
    Maxim Filippov's avatar
    Maxim Filippov committed
            this.loading = false
    
            this.$router.push({ path: this.redirect || '/users/index' })
          }).catch(() => {
            this.loading = false
          })
    
    Maxim Filippov's avatar
    Maxim Filippov committed
        async handlePleromaFELogin() {
          this.loadingPleromaFE = true
          try {
    
            await authenticateWithPleromaFE(this.$store)
    
    Maxim Filippov's avatar
    Maxim Filippov committed
          } catch (error) {
            this.loadingPleromaFE = false
            this.$message.error(i18n.t('login.pleromaFELoginFailed'))
          }
    
          this.loadingPleromaFE = false
    
          this.$message.success(i18n.t('login.pleromaFELoginSucceed'))
    
          this.$router.push({ path: this.redirect || '/users/index' })
    
    Maxim Filippov's avatar
    Maxim Filippov committed
        },
    
        getLoginData() {
          const [username, authHost] = this.loginForm.username.split('@')
    
          return {
            username: username.trim(),
    
            authHost: authHost ? authHost.trim() : window.location.host,
    
            password: this.loginForm.password
          }
    
    Pan's avatar
    Pan committed
        }
    
    Pan's avatar
    Pan committed
      }
    
    Pan's avatar
    Pan committed
    }
    
    Pan's avatar
    Pan committed
    </script>
    
    
    Pan's avatar
    Pan committed
    <style rel="stylesheet/scss" lang="scss">
    
      $bg:#283443;
      $light_gray:#eee;
      $cursor: #fff;
    
    Pan's avatar
    Pan committed
    
    
      @supports (-webkit-mask: none) and (not (cater-color: $cursor)) {
        .login-container .el-input input{
          color: $cursor;
          &::first-line {
            color: $light_gray;
    
    Pan's avatar
    Pan committed
        }
    
    
      /* reset element-ui css */
      .login-container {
        .el-input {
          display: inline-block;
          height: 47px;
          width: 85%;
          input {
            background: transparent;
            border: 0px;
            -webkit-appearance: none;
            border-radius: 0px;
            padding: 12px 5px 12px 15px;
            color: $light_gray;
            height: 47px;
            caret-color: $cursor;
            &:-webkit-autofill {
              -webkit-box-shadow: 0 0 0px 1000px $bg inset !important;
              -webkit-text-fill-color: $cursor !important;
            }
          }
        }
        .el-form-item {
          border: 1px solid rgba(255, 255, 255, 0.1);
          background: rgba(0, 0, 0, 0.1);
          border-radius: 5px;
          color: #454545;
        }
    
    Maxim Filippov's avatar
    Maxim Filippov committed
        .login-button {
          width: 100%;
          margin: 0 0 10px 0;
        }
        .omit-host-note {
          color: #596f8c;
          font-size: 0.8em;
          font-style: italic;
          margin: -20px 0 15px 0;
          padding: 3px 0 0 15px;
        }
    
    Pan's avatar
    Pan committed
      }
    </style>
    
    <style rel="stylesheet/scss" lang="scss" scoped>
    $bg:#2d3a4b;
    $dark_gray:#889aa4;
    $light_gray:#eee;
    
    .login-container {
    
      min-height: 100%;
    
      width: 100%;
    
    Pan's avatar
    Pan committed
      background-color: $bg;
    
      overflow: hidden;
    
    Pan's avatar
    Pan committed
      .login-form {
    
        position: relative;
    
    Pan's avatar
    Pan committed
        width: 520px;
    
        max-width: 100%;
    
        padding: 160px 35px 0;
        margin: 0 auto;
        overflow: hidden;
    
    Pan's avatar
    Pan committed
      }
      .tips {
        font-size: 14px;
        color: #fff;
        margin-bottom: 10px;
        span {
          &:first-of-type {
            margin-right: 16px;
    
    Pan's avatar
    Pan committed
          }
    
    Pan's avatar
    Pan committed
        }
    
    Pan's avatar
    Pan committed
      }
      .svg-container {
        padding: 6px 5px 6px 15px;
        color: $dark_gray;
        vertical-align: middle;
        width: 30px;
        display: inline-block;
      }
      .title-container {
        position: relative;
    
    Pan's avatar
    Pan committed
        .title {
          font-size: 26px;
    
    Pan's avatar
    Pan committed
          color: $light_gray;
    
    Pan's avatar
    Pan committed
          margin: 0px auto 40px auto;
          text-align: center;
          font-weight: bold;
        }
    
    Pan's avatar
    Pan committed
        .set-language {
          color: #fff;
    
    Pan's avatar
    Pan committed
          position: absolute;
    
    Pan's avatar
    Pan committed
          top: 3px;
          font-size:18px;
    
    Pan's avatar
    Pan committed
          right: 0px;
    
    Pan's avatar
    Pan committed
          cursor: pointer;
    
    Pan's avatar
    Pan committed
        }
      }
    
    Pan's avatar
    Pan committed
      .show-pwd {
        position: absolute;
        right: 10px;
        top: 7px;
        font-size: 16px;
        color: $dark_gray;
        cursor: pointer;
        user-select: none;
      }
      .thirdparty-button {
        position: absolute;
    
        right: 0;
        bottom: 6px;
    
    Pan's avatar
    Pan committed
    </style>