Browse Source

优化

master
陈裕财 4 years ago
parent
commit
64b8e38241
  1. 4
      src/router/index.js
  2. 541
      src/views/login/index.vue
  3. 62
      src/views/login/index2.vue
  4. 378
      src/views/login/register.vue
  5. 1434
      src/views/xm/XmOverview.vue
  6. 1163
      src/views/xm/XmOverview2.vue

4
src/router/index.js

@ -38,7 +38,7 @@ export { Layout }
}
**/
export const constantRouterMap = [
{ path: '/login', component: _import('login/index2'), hidden: true },
{ path: '/login', component: _import('login/index'), hidden: true },
{ path: '/404', component: _import('errorPage/404'), hidden: true },
{ path: '/401', component: _import('errorPage/401'), hidden: true },
{
@ -49,7 +49,7 @@ export const constantRouterMap = [
children: [
{
path: 'dashboard',
component: _import('xm/XmOverview2'),
component: _import('xm/XmOverview'),
name: '首页',
meta: { title: '首页', icon: 'home-page', noCache: true }
},

541
src/views/login/index.vue

@ -1,511 +1,62 @@
<template>
<div class="login-container">
<el-form class="login-form" autoComplete="on" :model="loginForm" :rules="loginRules" ref="loginForm">
<div class="title-container">
<div class="logo">
<img src="../../assets/image/logo1.png" alt="" />
<div class="logo-text">
<div class="main-title">{{$t('login.title')}}</div>
</div>
</div>
<lang-select class="set-language"></lang-select>
</div>
<el-form-item prop="authType">
<el-radio-group v-model="loginForm.authType">
<el-radio label="password_display_userid">账户密码</el-radio>
<el-radio label="sms">短信验证码快速登录</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item prop="userloginid" v-show="loginForm.authType=='password_display_userid'">
<el-input title="登陆账号" name="userloginid" type="text" v-model="loginForm.userloginid" autoComplete="on" placeholder="用户编号" >
<template slot="prepend">账号</template>
</el-input>
</el-form-item>
<el-form-item prop="password" v-show="loginForm.authType=='password_display_userid'">
<el-input name="password" :type="passwordType" @keyup.enter.native="handleLogin" v-model="loginForm.password" autoComplete="on" placeholder="password">
<template slot="prepend">密码</template>
<span slot="append" class="show-pwd" @click="showPwd">
<svg-icon icon-class="eye" />
</span>
</el-input>
</el-form-item>
<el-form-item prop="phoneno" v-show="loginForm.authType=='sms'">
<el-input name="phoneno" type="text" v-model="loginForm.phoneno" autoComplete="on" placeholder="手机号码">
<template slot="prepend">手机号码&nbsp;&nbsp;&nbsp;</template>
<el-button slot="append" @click.prevent="sendPhonenoSmsCode" v-loading="load.sendSmsCode">发送验证码</el-button>
</el-input>
<span v-if="users!=null && users.length>0"> 该手机号有{{users.length}}个账户,请选择需要登录的账户<font color="blue"></font>
<br>
<el-tag v-if="selectUser && selectUser.userid">已选择:{{selectUser.username}}</el-tag> <el-button type="text" @click="phonenoUsersVisible=true">选择账户</el-button>
</span>
</el-form-item>
<el-form-item prop="smsCode" v-show="loginForm.authType=='sms'">
<el-input name="smsCode" type="text" v-model="loginForm.smsCode" autoComplete="on" placeholder="短信验证码">
<template slot="prepend">短信验证码</template>
<template slot="append">六位验证码</template>
</el-input>
</el-form-item>
<el-button type="primary" style="width:100%;margin-bottom:30px;" :loading="loading" @click.native.prevent="handleLogin">{{$t('login.logIn')}}</el-button>
<el-row>
<el-button type="success" plain round @click="showRegisterDialog=true">新用户注册</el-button>
<el-button type="warning" plain round @click="showResetPasswordDialog=true">忘记密码</el-button>
<el-button type="primary" plain round @click="showTpLoginDialog=true">{{$t('login.thirdparty')}}</el-button>
</el-row>
</el-form>
<el-dialog
title="请选择一个部门进行登陆"
:visible.sync="deptSelectVisible"
width="screenWidth<500?'90%':'500px" append-to-body>
<el-row class="app-container">
<el-col :span=20 v-for="(d,index) in myDepts" :key="index">
<el-col :span=20><el-radio v-model="userDeptid" :label="d.deptid">{{d.deptName}}({{d.branchName}}) </el-radio> </el-col>
</el-col>
</el-row >
<el-row class="app-container" style="text-align:right;">
<el-col :span=20 >
<el-button @click="deptSelectVisible = false"> </el-button>
<el-button type="primary" @click="deptChecked"> </el-button>
</el-col>
</el-row >
</el-dialog>
<!-- 第三方登陆窗口 -->
<el-dialog :title="$t('login.thirdparty')" :visible.sync="showTpLoginDialog" append-to-body>
{{$t('login.thirdpartyTips')}}
<br/>
<br/>
<br/>
<social-sign />
</el-dialog>
<!-- 注册窗口 -->
<el-dialog title="新用户注册" :visible.sync="showRegisterDialog" append-to-body>
<register />
</el-dialog>
<!-- 重置密码窗口 -->
<el-dialog title="重置密码" :visible.sync="showResetPasswordDialog" append-to-body>
<reset-password />
</el-dialog>
<!--新增 Branch 管理端机构表机构下面若干部门界面-->
<el-dialog title="新增机构" :visible.sync="addBranchFormVisible" width="50%" :close-on-click-modal="false" append-to-body>
<branch-add :visible="addBranchFormVisible" @cancel="addBranchFormVisible=false" @submit="afterAddBranchSubmit"></branch-add>
</el-dialog>
<el-dialog
title="查看已有账户"
:visible.sync="phonenoUsersVisible"
width="600" append-to-body>
<el-table :data="users">
<el-table-column prop="userid" label="编号">
</el-table-column>
<el-table-column prop="displayUserid" label="登录账号">
</el-table-column>
<el-table-column prop="username" label="姓名">
</el-table-column>
<el-table-column prop="branchName" label="企业">
</el-table-column>
<el-table-column label="操作">
<template slot-scope="scope">
<el-button type="primary" @click="onUserSelect(scope.row)">选中</el-button>
</template>
</el-table-column>
</el-table>
</el-dialog>
</div>
<div class="login_container">
<div class="login_content">
<div class="left">
</div>
<div class="right">
<div class="logo">
<img src="@/assets/image/logo1.png">
<span>唛盟</span>
</div>
<div class="login_box">
<div class="login_box_content">
<div class="top">
<h2>平台{{status == 'register' ? '注册' : '登录' }}</h2>
<span v-if="status == 'login'" >没有账号?<a style="color:#409EFF;" @click="status = 'register' ">点此注册</a> </span>
<span v-else>已有账号<a style="color:#409EFF;" @click="status = 'login' ">点此登录</a> </span>
</div>
<login-form v-if="status == 'login'"></login-form>
<register-form v-else></register-form>
</div>
</div>
</div>
</div>
</div>
</template>
<script>
import { sendSmsCode } from '@/api/sms/sms';
import LangSelect from '@/components/LangSelect';
import SocialSign from './socialsignin';
import Register from './register';
import ResetPassword from './resetPassword';
import { queryByUserloginid } from '@/api/login';
import BranchAdd from './BranchAdd';
import { mapGetters } from 'vuex';
import md5 from 'js-md5';
<script>
import loginForm from './components/login';
import registerForm from './components/register';
export default {
components: { LangSelect, SocialSign, BranchAdd, Register,ResetPassword},
name: 'login',
data() {
const validateDisplayUserid = (rule, value, callback) => {
if (this.loginForm.authType=='password_display_userid') {
if(value.length<=6){
callback(new Error('请输入6位以上用户账号'))
}else{
callback()
}
} else {
callback()
}
}
const validatePassword = (rule, value, callback) => {
if (this.loginForm.authType=='password_display_userid') {
if(value.length<6){
callback(new Error('密码最少为六位'))
}else{
callback()
}
} else {
callback()
}
}
const validatePhoneno = (rule, value, callback) => {
if (this.loginForm.authType=='sms') {
if(value.length !=11 ){
callback(new Error('手机号码必须为11位号码'))
}else{
callback()
}
} else {
callback()
}
}
const validateSmsCode = (rule, value, callback) => {
if (this.loginForm.authType=='sms') {
if(value.length !=6 ){
callback(new Error('请输入6位短信验证码'))
}else{
callback()
}
} else {
callback()
}
}
return {
loginForm: {
userloginid: '',
password: '',
authType:'password_display_userid',//password/sms/password_display_userid
phoneno:'',//
smsCode:'',//
},
loginRules: {
userloginid: [{ required: true, trigger: 'blur', validator: validateDisplayUserid }],
password: [{ required: true, trigger: 'blur', validator: validatePassword }],
phoneno: [{ required: true, trigger: 'blur', validator: validatePhoneno }],
smsCode: [{ required: true, trigger: 'blur', validator: validateSmsCode }],
},
passwordType: 'password',
loading: false,
load:{sendSmsCode:false,},
showResetPasswordDialog:false,//
showTpLoginDialog: false, //
showRegisterDialog: false,//
deptSelectVisible:false,//
userDeptid:'',//
addBranchFormVisible:false, //
users:[],
phonenoUsersVisible:false,
selectUser:null,
}
},
methods: {
showPwd() {
if (this.passwordType === 'password') {
this.passwordType = ''
} else {
this.passwordType = 'password'
}
},
sendPhonenoSmsCode(){
this.load.sendSmsCode=true;
this.$refs.loginForm.validateField("phoneno",(err)=>{
if(err){
this.$message.error(err);
this.load.sendSmsCode=false;
return;
}else{
var params={
phoneno:this.loginForm.phoneno,
scene:"login"
}
sendSmsCode(params).then(res=>{
this.load.sendSmsCode=false;
if(res.data.tips.isOk){
this.$message.success(res.data.tips.msg);
this.queryByUserloginid();
}else{
this.$message.error(res.data.tips.msg);
}
}).catch(()=>this.load.sendSmsCode=false)
name: 'login',
components: {loginForm, registerForm},
data() {
return {
status: "login",
}
});
},
handleLogin() {
this.$refs.loginForm.validate(valid => {
if (valid) {
this.loading = true
let params={
userloginid:this.loginForm.userloginid,
password:md5(this.loginForm.password),
deptid:this.userDeptid,
authType:this.loginForm.authType,
phoneno:this.loginForm.phoneno,
smsCode:this.loginForm.smsCode
}
var loginParams={ }
if(params.authType=='password_display_userid'){
loginParams.userloginid=params.userloginid
loginParams.password=params.password
loginParams.grantType="password"
loginParams.authType='password_display_userid'
loginParams.deptid=params.deptid
}else if(params.authType=='sms'){
loginParams.userloginid=params.phoneno
loginParams.password=params.smsCode
loginParams.grantType="password"
loginParams.authType="sms"
loginParams.deptid=params.deptid
}
if(this.selectUser){
loginParams.userid=this.selectUser.userid
}
this.$store.dispatch("LoginByUserloginid",loginParams).then(res => {
this.loading = false
debugger;
if(res.data.tips.isOk==true){
console.log(this.$store);
this.loading = true;
this.$store.dispatch('GetUserInfo').then((res2)=>{
//this.userDeptid=res2.data.userInfo.deptid
debugger;
this.loading = false
if(res2.data.tips.isOk==true){
if(this.$store.state.user.myDepts.length>1 ){
//this.$message.info("");
if( !this.userDeptid ){
this.userDeptid=res2.data.userInfo.deptid
this.deptSelectVisible=true;
}else{
this.rolesChecked();
}
//this.$router.push({ path: 'mdp/sys/branch/BranchAdd' })
}else if(this.$store.state.user.myDepts.length==1){
//
this.userDeptid=res2.data.userInfo.deptid
this.rolesChecked();
}else{
this.rolesChecked();
}
}else{
this.$message.error(res2.data.tips.msg);
}
}).catch(err=>{
console.log(err);
this.loading = false
});
}else{
this.$message.error(res.data.tips.msg);
}
}).catch((e) => {
console.log(e);
this.loading = false
})
} else {
console.log('error submit!!')
return false
}
})
methods: {
},
deptChecked() {
if( !this.userDeptid){
this.$message.error("请选择登陆的部门")
return
}
let depts=this.myDepts.filter(d=>d.deptid==this.userDeptid)
if(this.$store.state.user.userInfo.deptid!=this.userDeptid){
this.handleLogin();
return;
}else{
this.rolesChecked();
}
created() {
},
//
rolesChecked(){
if(this.userInfo.isSuperAdmin){
this.$router.push({ path: '/' });
this.$message.info("欢迎登陆,超级管理员");
}else if(this.userInfo.isPlatformAdmin){
this.$router.push({ path: '/' });
this.$message.info("欢迎登陆,平台管理员");
}else{
this.$router.push({ path: '/' });
this.$message.info("欢迎登陆");
}
},
afterAddBranchSubmit(branch){
this.addBranchFormVisible=false;
this.handleLogin();
},
afterQRScan() {
// const hash = window.location.hash.slice(1)
// const hashObj = getQueryObject(hash)
// const originUrl = window.location.origin
// history.replaceState({}, '', originUrl)
// const codeMap = {
// wechat: 'code',
// tencent: 'code'
// }
// const codeName = hashObj[codeMap[this.auth_type]]
// if (!codeName) {
// alert('')
// } else {
// this.$store.dispatch('LoginByThirdparty', codeName).then(() => {
// this.$router.push({ path: '/' })
// })
// }
},
queryByUserloginid(){
var params={userloginid:this.loginForm.userloginid}
if(this.loginForm.authType=='sms'){
params.idType="phoneno"
}else{
params.idType='all'
}
queryByUserloginid(params).then(res=>{
var tips = res.data.tips;
if(tips.isOk){
this.users=res.data.data
}
})
destroyed() {
},
onUserSelect(user){
this.selectUser=user
this.phonenoUsersVisible=false;
}
},
created() {
// window.addEventListener('hashchange', this.afterQRScan)
},
destroyed() {
// window.removeEventListener('hashchange', this.afterQRScan)
},
computed: {
...mapGetters([
'myBranchs','myDepts','userInfo','roles'
]),
screenWidth:function(){
return screen.width;
},
}
}
</script>
<style rel="stylesheet/scss" lang="scss" scoped>
$bg:#2d3a4b;
$dark_gray:#889aa4;
$light_gray:#ef1010;
<style lang="scss" scoped>
@import './index.scss';
</style>
.login-container {
position:absolute;
height: 100%;
width: 100%;
background-color: $bg;
background-size: 100%;
background:url(../../assets/image/yxin_login_backgroup_pc.png) center center;
.login-form {
position: absolute;
left: 0;
right: 0;
max-width: 520px;
padding: 35px 35px 15px 35px;
margin: 180px auto;
border-radius: 20px;
background-color:#f5f7faee;
}
.tips {
font-size: 14px;
color: #fff;
margin-bottom: 10px;
span {
&:first-of-type {
margin-right: 16px;
}
}
}
.svg-container {
padding: 6px 5px 6px 15px;
color: $dark_gray;
vertical-align: middle;
width: 30px;
display: inline-block;
&_login {
font-size: 20px;
}
}
.title-container {
position: relative;
.title {
font-size: 26px;
font-weight: 400;
color: $light_gray;
margin: 0px auto 40px auto;
text-align: center;
font-weight: bold;
}
.set-language {
color: rgb(95, 41, 221);
position: absolute;
top: 5px;
right: 0px;
}
}
.show-pwd {
position: absolute;
right: 10px;
top: 7px;
font-size: 16px;
color: $dark_gray;
cursor: pointer;
user-select: none;
}
.thirdparty-button {
position: absolute;
right: 35px;
bottom: 28px;
}
.register-button {
position: absolute;
bottom: 28px;
}
}
.logo {
height: 100px;
width: 100%;
// padding: 0 20px;
display: flex;
align-items: left;
justify-content: center;
img {
height: 100%;
}
.logo-text {
display: flex;
align-items: center;
justify-content: center;
color: $light_gray;
.main-title {
font-size: 35px;
font-weight: 400;
color: $light_gray;
text-align: center;
font-weight: bold;
}
}
}
</style>

62
src/views/login/index2.vue

@ -1,62 +0,0 @@
<template>
<div class="login_container">
<div class="login_content">
<div class="left">
</div>
<div class="right">
<div class="logo">
<img src="@/assets/image/logo1.png">
<span>唛盟</span>
</div>
<div class="login_box">
<div class="login_box_content">
<div class="top">
<h2>平台{{status == 'register' ? '注册' : '登录' }}</h2>
<span v-if="status == 'login'" >没有账号?<a style="color:#409EFF;" @click="status = 'register' ">点此注册</a> </span>
<span v-else>已有账号<a style="color:#409EFF;" @click="status = 'login' ">点此登录</a> </span>
</div>
<login-form v-if="status == 'login'"></login-form>
<register-form v-else></register-form>
</div>
</div>
</div>
</div>
</div>
</template>
<script>
import loginForm from './components/login';
import registerForm from './components/register';
export default {
name: 'login',
components: {loginForm, registerForm},
data() {
return {
status: "login",
}
},
methods: {
},
created() {
},
destroyed() {
},
}
</script>
<style lang="scss" scoped>
@import './index.scss';
</style>

378
src/views/login/register.vue

@ -1,378 +0,0 @@
<template>
<div>
<el-form autoComplete="on" label-width="120px" :model="loginForm" :rules="loginRules" ref="loginForm">
<div>
<div class="logo">
<img src="../../assets/image/logo1.png" alt="" />
<div class="logo-text">
<div class="systemName">{{$t('login.title')}}</div>
</div>
</div>
</div>
<el-form-item prop="phoneno" label="手机号码">
<el-input name="phoneno" type="text" v-model="loginForm.phoneno" autoComplete="on" placeholder="手机号码">
<span slot="append"> <el-button @click.prevent="sendPhonenoSmsCode" v-loading="load.sendSmsCode">发送验证码</el-button> </span>
</el-input>
<span v-if="phonenoUsers!=null && phonenoUsers.length>0"> 该手机号已注册有{{phonenoUsers.length}}个账户<font color="blue"></font>
<el-button type="text" @click="phonenoUsersVisible=true">查看明细</el-button>
</span>
</el-form-item>
<el-form-item prop="smsCode" label="短信验证码">
<el-input name="smsCode" type="text" v-model="loginForm.smsCode" autoComplete="on" placeholder="短信验证码">
<template slot="append">六位验证码</template>
</el-input>
</el-form-item>
<el-form-item prop="username" label="用户名称">
<el-input name="username" type="text" v-model="loginForm.username" autoComplete="on" placeholder="用户名称" >
</el-input>
</el-form-item>
<el-form-item prop="displayUserid" label="账号">
<el-input name="displayUserid" type="text" v-model="loginForm.displayUserid" autoComplete="on" placeholder="用户编号" >
<el-button slot="append" @click.prevent="checkDisplayUserid">检测是否已注册</el-button>
</el-input>
</el-form-item>
<el-form-item prop="password" label="密码">
<el-input name="password" :type="passwordType" @keyup.enter.native="handleLogin" v-model="loginForm.password" autoComplete="on" placeholder="password">
<span slot="append" class="show-pwd" @click="showPwd">
<svg-icon icon-class="eye" />
</span>
</el-input>
</el-form-item>
<el-button type="primary" style="width:100%;margin-bottom:30px;" :loading="loading" @click.native.prevent="handleRegister">注册</el-button>
</el-form>
<el-dialog
title="请选择一个部门进行登陆"
:visible.sync="deptSelectVisible"
width="screenWidth<500?'90%':'500px" append-to-body>
<el-row class="app-container">
<el-col :span=20 v-for="(d,index) in myDepts" :key="index">
<el-col :span=20><el-radio v-model="userDeptid" :label="d.deptid">{{d.deptName}}({{d.branchName}}) </el-radio> </el-col>
</el-col>
</el-row >
<el-row class="app-container" style="text-align:right;">
<el-col :span=20 >
<el-button @click="deptSelectVisible = false"> </el-button>
<el-button type="primary" @click="deptChecked"> </el-button>
</el-col>
</el-row >
</el-dialog>
<el-dialog
title="查看已有账户"
:visible.sync="phonenoUsersVisible"
width="600" append-to-body>
<el-table :data="phonenoUsers">
<el-table-column prop="userid" label="编号">
</el-table-column>
<el-table-column prop="displayUserid" label="登录账号">
</el-table-column>
<el-table-column prop="username" label="姓名">
</el-table-column>
<el-table-column prop="branchName" label="企业">
</el-table-column>
</el-table>
</el-dialog>
<!-- 第三方登陆窗口 -->
<el-dialog :title="$t('login.thirdparty')" :visible.sync="showTpLoginDialog" append-to-body>
{{$t('login.thirdpartyTips')}}
<br/>
<br/>
<br/>
<social-sign />
</el-dialog>
<!--新增 Branch 管理端机构表机构下面若干部门界面-->
<el-dialog title="新增机构" :visible.sync="addBranchFormVisible" width="50%" :close-on-click-modal="false" append-to-body>
<branch-add :visible="addBranchFormVisible" @cancel="addBranchFormVisible=false" @submit="afterAddBranchSubmit"></branch-add>
</el-dialog>
</div>
</template>
<script>
import { sendSmsCode } from '@/api/sms/sms';
import { checkPhoneno,checkDisplayUserid,doRegister,queryByUserloginid } from '@/api/login';
import LangSelect from '@/components/LangSelect';
import SocialSign from './socialsignin';
import BranchAdd from './BranchAdd';
import { mapGetters } from 'vuex';
import md5 from 'js-md5';
export default {
components: { LangSelect, SocialSign, BranchAdd },
name: 'login',
data() {
const validateDisplayUserid = (rule, value, callback) => {
if( !value || value.length<=6){
callback(new Error('请输入6位以上用户账号'))
}else{
callback()
}
}
const validatePassword = (rule, value, callback) => {
if( !value || value.length<6){
callback(new Error('密码最少为六位'))
}else{
callback()
}
}
const validatePhoneno = (rule, value, callback) => {
if( !value || value.length !=11 ){
callback(new Error('手机号码必须为11位号码'))
}else{
callback()
}
}
const validateSmsCode = (rule, value, callback) => {
if( !value || value.length !=6 ){
callback(new Error('请输入6位短信验证码'))
}else{
callback()
}
}
const validateUsername = (rule, value, callback) => {
if( !value || value.length <2 ){
callback(new Error('请输入用户名称'))
}else{
callback()
}
}
return {
loginForm: {
username:'',
displayUserid: '',
password: '',
authType:'password_display_userid',//password/sms/password_display_userid
phoneno:'',//
smsCode:'',//
},
loginRules: {
username: [{ required: true, trigger: 'blur', validator: validateUsername }],
displayUserid: [{ required: true, trigger: 'blur', validator: validateDisplayUserid }],
password: [{ required: true, trigger: 'blur', validator: validatePassword }],
phoneno: [{ required: true, trigger: 'blur', validator: validatePhoneno }],
smsCode: [{ required: true, trigger: 'blur', validator: validateSmsCode }],
},
passwordType: 'password',
loading: false,
load:{sendSmsCode:false,},
showTpLoginDialog: false, //
deptSelectVisible:false,//
userDeptid:'',//
addBranchFormVisible:false, //
phonenoUsers:[],//
phonenoUsersVisible:false,
}
},
methods: {
showPwd() {
if (this.passwordType === 'password') {
this.passwordType = ''
} else {
this.passwordType = 'password'
}
},
sendPhonenoSmsCode(){
this.load.sendSmsCode=true;
if(!this.loginForm.phoneno){
this.$message.error("手机号码不能为空");
this.load.sendSmsCode=false;
return;
}
if(this.loginForm.phoneno.length !=11 ){
this.$message.error("手机号码必须为11位");
this.load.sendSmsCode=false;
return;
}
var params={
phoneno:this.loginForm.phoneno,
scene:"register"
}
queryByUserloginid({userloginid:this.loginForm.phoneno,idType:"phoneno"}).then(res0=>{
this.load.sendSmsCode=false;
if(res0.data.tips.isOk){
this.phonenoUsers=res0.data.data;
sendSmsCode(params).then(res=>{
if(res.data.tips.isOk){
this.$message.success(res.data.tips.msg);
}else{
this.$message.error(res.data.tips.msg);
}
})
}
}).catch(err=> this.load.sendSmsCode=false)
/**
checkPhoneno(this.loginForm.phoneno).then(res0=>{
if(res0.data.tips.isOk){
sendSmsCode(params).then(res=>{
if(res.data.tips.isOk){
this.$message.success(res.data.tips.msg);
}else{
this.$message.error(res.data.tips.msg);
}
})
}else{
this.$message.error("手机号码已存在,不允许注册,请直接登录");
}
})
*/
},
checkPhonenoUsers(){
queryByUserloginid({userloginid:this.loginForm.phoneno,idType:"phoneno",atype:'1'}).then(res0=>{
if(res0.data.tips.isOk){
this.phonenoUsers=res0.data.data;
}
})
},
checkDisplayUserid(){
if(!this.loginForm.displayUserid){
this.$message.error("账号不能为空");
return;
}
checkDisplayUserid(this.loginForm.displayUserid).then(res0=>{
if(res0.data.tips.isOk){
this.$message.success("该账户可以注册");
}else{
this.$message.error("该账户已存在,不允许再注册!");
}
})
},
handleRegister() {
this.loading = true
this.$refs.loginForm.validate(valid => {
if (valid) {
let params={
displayUserid:this.loginForm.displayUserid,
password:md5(this.loginForm.password),
deptid:this.userDeptid,
phoneno:this.loginForm.phoneno,
smsCode:this.loginForm.smsCode,
username:this.loginForm.username,
}
doRegister(params).then(res=>{
this.loading = false
if(res.data.tips.isOk){
this.$message.success(res.data.tips.msg);
}else{
this.$message.error(res.data.tips.msg);
}
})
} else {
this.loading = false
return false
}
})
},
deptChecked() {
if( !this.userDeptid){
this.$message.error("请选择登陆的部门")
return
}
let depts=this.myDepts.filter(d=>d.deptid==this.userDeptid)
if(this.$store.state.user.userInfo.deptid!=this.userDeptid){
this.handleLogin();
return;
}else{
this.rolesChecked();
}
},
//
rolesChecked(){
if(this.userInfo.isSuperAdmin){
this.$router.push({ path: '/' });
this.$message.info("欢迎登陆,超级管理员");
}else if(this.userInfo.isPlatformAdmin){
this.$router.push({ path: '/' });
this.$message.info("欢迎登陆,平台管理员");
}else{
this.$router.push({ path: '/' });
this.$message.info("欢迎登陆");
}
},
afterAddBranchSubmit(branch){
this.addBranchFormVisible=false;
this.loading=true
this.$store.dispatch('GetUserInfo').then((res)=>{
this.userDeptid=res.data.userInfo.deptid
this.loading = false;
//
this.rolesChecked();
});
},
afterQRScan() {
// const hash = window.location.hash.slice(1)
// const hashObj = getQueryObject(hash)
// const originUrl = window.location.origin
// history.replaceState({}, '', originUrl)
// const codeMap = {
// wechat: 'code',
// tencent: 'code'
// }
// const codeName = hashObj[codeMap[this.auth_type]]
// if (!codeName) {
// alert('')
// } else {
// this.$store.dispatch('LoginByThirdparty', codeName).then(() => {
// this.$router.push({ path: '/' })
// })
// }
}
},
created() {
// window.addEventListener('hashchange', this.afterQRScan)
},
destroyed() {
// window.removeEventListener('hashchange', this.afterQRScan)
},
computed: {
...mapGetters([
'myBranchs','myDepts','userInfo','roles'
]),
screenWidth:function(){
return screen.width;
},
}
}
</script>
<style rel="stylesheet/scss" lang="scss" scoped>
$bg:#2d3a4b;
$dark_gray:#889aa4;
$light_gray:#ef1010;
.logo {
height: 100px;
width: 100%;
// padding: 0 20px;
display: flex;
align-items: left;
justify-content: center;
img {
height: 100%;
}
.logo-text {
display: flex;
align-items: center;
justify-content: center;
color: $light_gray;
.systemName {
font-size: 35px;
font-weight: 400;
color: $light_gray;
text-align: center;
font-weight: bold;
}
}
}
</style>

1434
src/views/xm/XmOverview.vue
File diff suppressed because it is too large
View File

1163
src/views/xm/XmOverview2.vue
File diff suppressed because it is too large
View File

Loading…
Cancel
Save