LoginPage.vue 9.38 KB
<template>
  <div class="login-container">
    <!-- 左侧 - 品牌展示区 -->
    <div class="login-left hidden-lg-only">
      <div class="login-bg">
        <img 
          src="https://images.unsplash.com/photo-1681321570365-df53da7dbaa2?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&ixid=M3w3Nzg4Nzd8MHwxfHNlYXJjaHwxfHxidXNpbmVzcyUyMHRlY2hub2xvZ3klMjBuZXR3b3JrfGVufDF8fHx8MTc2MTIxMTIyMXww&ixlib=rb-4.1.0&q=80&w=1080" 
          alt="背景" 
          class="login-bg-image"
        >
      </div>
      
      <div class="login-content">
        <div class="login-brand-info">
          <h2 class="login-title">
            智能商机管理<br>助力业务增长
          </h2>
          <p class="login-desc">
            装维师傅上门服务时发现商机,系统自动分配给营销人员跟进,实现业务闭环管理
          </p>
        </div>

        <!-- 特性卡片 -->
        <div class="login-features">
          <div class="login-feature-item">
            <div class="login-feature-icon">
              <i class="el-icon-mobile"></i>
            </div>
            <div class="login-feature-text">
              <h3 class="login-feature-title">移动端采集</h3>
              <p class="login-feature-desc">装维师傅随时随地记录商机信息</p>
            </div>
          </div>

          <div class="login-feature-item">
            <div class="login-feature-icon">
              <i class="el-icon-user"></i>
            </div>
            <div class="login-feature-text">
              <h3 class="login-feature-title">智能分配</h3>
              <p class="login-feature-desc">基于网格自动分配给合适的营销人员</p>
            </div>
          </div>

          <div class="login-feature-item">
            <div class="login-feature-icon">
              <i class="el-icon-data-analysis"></i>
            </div>
            <div class="login-feature-text">
              <h3 class="login-feature-title">数据驱动</h3>
              <p class="login-feature-desc">实时统计分析,洞察业务趋势</p>
            </div>
          </div>
        </div>
      </div>

      <!-- 装饰元素 -->
      <div class="login-decor-1"></div>
      <div class="login-decor-2"></div>
    </div>

    <!-- 右侧 - 登录表单 -->
    <div class="login-right">
      <div class="login-form-wrapper">
        <div class="login-header">
          <img 
            src="../assets/icons/a74fada241bbe2bf828e041e685f9486904a94e9.png" 
            alt="中国移动 Logo" 
            class="login-logo"
          >
          <h1 class="login-app-title">上门随销商机管理平台</h1>
        </div>

        <el-form :model="loginForm" :rules="loginRules" ref="loginForm" class="login-form">
          <el-form-item prop="username">
            <el-input 
              v-model="loginForm.username" 
              placeholder="请输入用户名" 
              prefix-icon="el-icon-user"
              size="medium"
              @keyup.enter.native="handleLogin"
            />
          </el-form-item>
          
          <el-form-item prop="password">
            <el-input 
              v-model="loginForm.password" 
              type="password" 
              placeholder="请输入密码" 
              prefix-icon="el-icon-lock"
              size="medium"
              @keyup.enter.native="handleLogin"
            />
          </el-form-item>

          <el-button 
            type="primary" 
            @click="handleLogin" 
            :loading="loading" 
            class="login-btn"
            size="medium"
            style="width: 100%;"
          >
            <i v-if="!loading" class="el-icon-right"></i>
            {{ loading ? '登录中...' : '登录' }}
          </el-button>
        </el-form>

        <div class="login-demo-info">
          <p class="login-demo-title">测试账号:</p>
          <div class="login-demo-accounts">
            <p>网格管理员: grid001 / 123456</p>
            <p>区县管理员: county001 / 123456</p>
            <p>地市管理员: city001 / 123456</p>
            <p>省级管理员: province001 / 123456</p>
          </div>
        </div>
      </div>
    </div>
  </div>
</template>

<script>
import { mapActions } from 'vuex'

export default {
  name: 'LoginPage',
  data() {
    return {
      loginForm: {
        username: '',
        password: ''
      },
      loginRules: {
        username: [
          { required: true, message: '请输入用户名', trigger: 'blur' }
        ],
        password: [
          { required: true, message: '请输入密码', trigger: 'blur' },
          { min: 6, message: '密码长度不能少于6位', trigger: 'blur' }
        ]
      },
      loading: false
    }
  },
  methods: {
    ...mapActions(['login']),
    async handleLogin() {
      try {
        await this.$refs.loginForm.validate()
        this.loading = true
        
        await this.login({
          username: this.loginForm.username,
          password: this.loginForm.password
        })
        
        this.$message.success('登录成功')
        this.$router.push('/')
      } catch (error) {
        console.error('Login error:', error)
        this.$message.error(error.message || '登录失败,请稍后重试')
      } finally {
        this.loading = false
      }
    }
  }
}
</script>

<style lang="scss" scoped>
.login-container {
  min-height: 100vh;
  display: flex;
  background: #fff;

  .login-left {
    flex: 1;
    background: linear-gradient(135deg, #3b82f6 0%, #6366f1 50%, #8b5cf6 100%);
    position: relative;
    overflow: hidden;

    .login-bg {
      position: absolute;
      inset: 0;
      opacity: 0.2;

      .login-bg-image {
        width: 100%;
        height: 100%;
        object-fit: cover;
      }
    }

    .login-content {
      position: relative;
      z-index: 10;
      display: flex;
      flex-direction: column;
      justify-content: center;
      padding: 100px 80px 100px 80px;
      color: white;

      .login-brand-info {
        margin-bottom: 60px;

        .login-title {
          font-size: 42px;
          margin: 0 0 20px 0;
          line-height: 1.2;
          font-weight: bold;
        }

        .login-desc {
          font-size: 16px;
          color: rgba(255, 255, 255, 0.8);
          max-width: 420px;
        }
      }

      .login-features {
        .login-feature-item {
          display: flex;
          align-items: flex-start;
          gap: 20px;
          padding: 20px;
          background: rgba(255, 255, 255, 0.1);
          backdrop-filter: blur(10px);
          border-radius: 12px;
          margin-bottom: 20px;

          &:last-child {
            margin-bottom: 0;
          }

          .login-feature-icon {
            flex-shrink: 0;
            width: 48px;
            height: 48px;
            background: rgba(255, 255, 255, 0.2);
            border-radius: 12px;
            display: flex;
            align-items: center;
            justify-content: center;

            i {
              font-size: 24px;
              color: white;
            }
          }

          .login-feature-text {
            .login-feature-title {
              font-size: 18px;
              margin: 0 0 5px 0;
              font-weight: 600;
            }

            .login-feature-desc {
              font-size: 14px;
              color: rgba(255, 255, 255, 0.8);
              margin: 0;
            }
          }
        }
      }
    }

    .login-decor-1 {
      position: absolute;
      top: 80px;
      right: 80px;
      width: 288px;
      height: 288px;
      background: rgba(255, 255, 255, 0.05);
      border-radius: 50%;
      filter: blur(60px);
    }

    .login-decor-2 {
      position: absolute;
      bottom: 80px;
      left: 80px;
      width: 384px;
      height: 384px;
      background: rgba(139, 92, 246, 0.1);
      border-radius: 50%;
      filter: blur(60px);
    }
  }

  .login-right {
    width: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px;

    .login-form-wrapper {
      width: 100%;
      max-width: 420px;

      .login-header {
        margin-bottom: 40px;
        text-align: center;

        .login-logo {
          height: 64px;
          width: 64px;
          margin-bottom: 16px;
        }

        .login-app-title {
          font-size: 28px;
          font-weight: bold;
          margin: 0;
        }
      }

      .login-form {
        margin-bottom: 32px;
      }

      .login-btn {
        height: 44px;
        font-size: 16px;
        font-weight: 500;
      }

      .login-demo-info {
        padding: 20px;
        background-color: #f5f7fa;
        border-radius: 8px;

        .login-demo-title {
          font-size: 14px;
          margin: 0 0 10px 0;
          color: #606266;
        }

        .login-demo-accounts {
          font-size: 12px;
          color: #909399;
          line-height: 1.8;

          p {
            margin: 0 0 5px 0;
          }
        }
      }
    }
  }
}

// 响应式设计
@media (max-width: 992px) {
  .login-container {
    .login-left {
      display: none;
    }

    .login-right {
      width: 100%;
    }
  }
}
</style>