Browse Source

2025.1.10

dzl 2 months ago
parent
commit
637992218e

BIN
src/assets/images/beijing.jpg


BIN
src/assets/images/dhk.png


BIN
src/assets/images/phone.png


BIN
src/assets/images/saoma.png


BIN
src/assets/images/weweima.png


BIN
src/assets/images/zc.png


+ 1 - 1
src/permission.js

@@ -8,7 +8,7 @@ import { isRelogin } from '@/utils/request'
 import Cookies from 'js-cookie'
 NProgress.configure({ showSpinner: false })
 
-const whiteList = ['/web/htm/systemmanage/login', '/register','/userIndex','/userIndex1','/zhengshuSearch','/mmzh']
+const whiteList = ['/web/htm/systemmanage/login', '/register','/userIndex','/userIndex1','/zhengshuSearch','/mmzh','/loginJly','/loginQy']
 
 router.beforeEach((to, from, next) => {
   NProgress.start()

+ 10 - 1
src/router/index.js

@@ -61,7 +61,16 @@ export const constantRoutes = [
     component: () => import("@/views/login"),
     hidden: true,
   },
-
+	{
+	  path: "/loginQy",
+	  component: () => import("@/views/loginQy"),
+	  hidden: true,
+	},
+	{
+	  path: "/loginJly",
+	  component: () => import("@/views/loginJly"),
+	  hidden: true,
+	},
   {
     path: "/register",
     component: () => import("@/views/register"),

+ 10 - 10
src/views/components/baoming/kaoshi.vue

@@ -176,13 +176,13 @@
 					<div class="m-t-10">
 						<el-form-item label="开票类型" prop="yjType">
 							<el-radio-group v-model="classForm.yjType" @change="changeType() ">
-								<el-radio :label="0">不开发票</el-radio>
-								<el-radio :label="1">个人</el-radio>
-								<el-radio :label="2">企业</el-radio>
+								<el-radio :label="2">不开发票</el-radio>
+								<el-radio :label="0">个人</el-radio>
+								<el-radio :label="1">企业</el-radio>
 							</el-radio-group>
 						</el-form-item>
 					</div>
-					<el-row :gutter="40" v-if="classForm.yjType == 1">
+					<el-row :gutter="40" v-if="classForm.yjType == 0">
 						<el-col :span="14">
 							<el-form-item label="个人姓名">
 								<el-input v-model="classForm.renCai.Name" readonly type="text" auto-complete="off"></el-input>
@@ -200,7 +200,7 @@
 							</el-form-item>
 						</el-col>
 					</el-row>
-					<el-row :gutter="40" v-if="classForm.yjType == 2"> 
+					<el-row :gutter="40" v-if="classForm.yjType == 1"> 
 						<el-col :span="12">
 							<el-form-item label="开票单位" prop="qiye.kpdw" :rules="{required: true,message: '请联系企业负责人先完善发票信息,再进行报名',trigger: ['blur', 'change']}">
 								<el-input v-model="classForm.qiye.kpdw" readonly type="text" auto-complete="off"></el-input>
@@ -299,7 +299,7 @@ import {
 					qiye:{
 						qyinfo:null,//所选企业索引
 					},//企业信息
-					yjType:null,//开票类型 0不开 1个人 2企业
+					yjType:null,//开票类型 2不开 0个人 1企业
 					byyx:null,//毕业院校
 					zcpzdw:null,//职称批准单位
 					jianli:[],//已有的简历列表
@@ -356,7 +356,7 @@ import {
 					],
 					yjType:{
 						required: true,
-						message: '请选择开票抬头',
+						message: '请选择开票类型',
 						trigger: ['blur', 'change']
 					},
 					'personcord.0.ZJImgUrl':{required: true,message: '请上传身份证',trigger: ['blur', 'change']},
@@ -397,7 +397,7 @@ import {
 					qiye:{
 						qyinfo:null,//所选企业索引
 					},//企业信息
-					yjType:null,//开票类型 0不开 1个人 2企业
+					yjType:null,//开票类型 
 					byyx:null,//毕业院校
 					zcpzdw:null,//职称批准单位
 					jianli:[],//已有的简历列表
@@ -546,14 +546,14 @@ import {
 			//选择开票类型
 			changeType(){ 
 				this.$refs.classForm.clearValidate(['renCai.Email','qiye.kplx','qiye.kpfs','qiye.kpdw','qiye.nsrsbh','qiye.dzfpyx'])
-				if(this.classForm.yjType == 0){
+				if(this.classForm.yjType == 2){
 					this.$alert('可由单位申请补开发票', '提示', {
 						confirmButtonText: '确定',
 						callback: action => {
 						
 						}
 					});
-				}else if(this.classForm.yjType == 1){
+				}else if(this.classForm.yjType == 0){
 					this.$alert('发票统一推送至单位邮箱,个人发票由单位转交。', '提示', {
 						confirmButtonText: '确定',
 						callback: action => {

+ 1 - 1
src/views/login.vue

@@ -6,7 +6,7 @@
 			</div>
 			<div class="login-box">
 				<el-form ref="loginForm" :model="loginForm" :rules="loginRules" class="login-form">
-					<h3 class="title">管理员登</h3>
+					<h3 class="title">管理员登</h3>
 					<el-form-item prop="username">
 						<el-input v-model="loginForm.username" type="text" auto-complete="off" placeholder="账号">
 							<svg-icon slot="prefix" icon-class="user" class="el-input__icon input-icon" />

+ 277 - 0
src/views/loginJly.vue

@@ -0,0 +1,277 @@
+<template>
+	<div class="login">
+		<div style="position: absolute;top: 50%;left: 50%;transform: translateX(-50%) translateY(-60%);">
+			<div class="login-box"> 
+				<img src="../assets/images/zc.png" style="width: 360px;" alt="" />
+				<div style="background-color: #fff;border-radius: 0 8px 8px 0;height:360px ;display: flex;flex-direction: column;justify-content: space-between;height: 418px;">
+					<div style="display: flex;justify-content: flex-end;align-items: center;">
+						<div class="dhk" style="font-size: 12px;">
+							{{type == 'zh'?'微信扫码登录':'账号密码登录'}}
+							<i class="el-icon-caret-right" style="position: absolute;right: -12px;font-size: 20px;color: #f0f6ff;top: 3px;z-index: 99;"></i>
+						</div>
+						<div class="saoma" style="padding: 6px;background-color: #f0f6ff;position: relative;cursor: pointer;" >
+							<img src="../assets/images/saoma.png" style="width: 34px;" alt="" v-if="type == 'zh'"  />
+							<img src="../assets/images/phone.png" style="width: 34px;" alt="" v-if="type == 'wx'"  />
+							<div style="width: 0;height: 0;border-bottom: 50px solid #fff;border-right: 47px solid transparent;position: absolute;bottom: 0;left: 0;" @click="type=='wx'?type='zh':type='wx'">
+								
+							</div>
+						</div>
+					</div>
+					<el-form ref="form" :model="form" :rules="userRules" class="login-form" v-if="type == 'zh'">
+						<h3 class="title"><span style="color: #2052f4;">账号密码</span>登录</h3>
+						<el-form-item prop="username">
+							<el-input v-model="form.username" type="text" auto-complete="off" placeholder="身份证号">
+								<svg-icon slot="prefix" icon-class="user" class="el-input__icon input-icon" />
+							</el-input>
+						</el-form-item>
+						<el-form-item prop="password">
+							<el-input v-model="form.password" type="password" auto-complete="off" placeholder="证书编号"
+								@keyup.enter.native="handleLogin">
+								<svg-icon slot="prefix" icon-class="password" class="el-input__icon input-icon" />
+							</el-input>
+						</el-form-item>
+						<el-form-item prop="code" v-if="captchaEnabled">
+							<el-input v-model="form.code" auto-complete="off" placeholder="验证码" style="width: 63%"
+								@keyup.enter.native="handleLogin">
+								<svg-icon slot="prefix" icon-class="validCode" class="el-input__icon input-icon" />
+							</el-input>
+							<div class="login-code">
+								<img :src="codeUrl" @click="getCode" class="login-code-img" />
+							</div>
+						</el-form-item>
+						<!-- <el-checkbox v-model="form.rememberMe" style="margin:0px 0px 25px 0px;">记住密码</el-checkbox> -->
+						<el-form-item style="width:100%;">
+							<el-button :loading="loading" size="medium" type="danger" style="width:100%;background-color: #2254f4;border-color: #2254f4;"
+								@click.native.prevent="handleLogin">
+								<span v-if="!loading">登 录</span>
+								<span v-else>登 录 中...</span>
+							</el-button>
+							<!-- <div style="float: right;">
+								<router-link class="link-type" :to="'/register'">立即注册</router-link>
+							</div> -->
+						</el-form-item>
+					</el-form>
+					<div v-else-if="type == 'wx'" class="login-form">
+							<h3 class="title"><span style="color: #2052f4;">微信扫码</span>登录</h3>
+							<div style="text-align: center;color:#aab0b5 ;font-size: 14px;">
+								未注册的微信号将自动创建稿定账号
+							</div>
+							<div style="text-align: center;">
+								<img src="../assets/images/weweima.png" style="width: 180px;margin-top: 10px;margin-bottom: 20px;" alt="" />
+							</div>
+					</div>
+					<div style="background-color: #f5f7fb; padding: 10px 0;text-align: center;color: #bbbcbe;font-size: 14px;font-weight: bold;">
+						主办单位:中国铁道工程建设协会建设监理专业委员会
+					</div>
+				</div>
+				
+			</div>
+			
+		</div>
+		
+		<!--  底部  -->
+		<div class="el-login-footer">
+			<!-- <span>Copyright © 2018-2023 ruoyi.vip All Rights Reserved.</span> -->
+		</div>
+	</div>
+</template>
+
+<script>
+	import {
+		getCodeImg
+	} from "@/api/login";
+	import Cookies from "js-cookie";
+	import {
+		encrypt,
+		decrypt
+	} from '@/utils/jsencrypt'
+
+	export default {
+		name: "LoginQy",
+		data() {
+			return {
+				type:'zh',
+				codeUrl: "",
+				form: {
+				  username: "",
+				  password: "",
+				  rememberMe: false,
+				  code: "",
+				  uuid: "",
+				  type: null,
+				},
+				userRules: {
+				  username: [
+				    {
+				      required: true,
+				      trigger: "blur",
+				      message: "请输入身份证号",
+				    },
+				  ],
+				  password: [
+				    {
+				      required: true,
+				      trigger: "blur",
+				      message: "请输入证书编号",
+				    },
+				  ],
+				  code: [
+				    {
+				      required: true,
+				      trigger: "change",
+				      message: "请输入验证码",
+				    },
+				  ],
+				},
+				loading: false,
+				// 验证码开关
+				captchaEnabled: true,
+				// 注册开关
+				register: false,
+				redirect: undefined
+			};
+		},
+		watch: {
+			$route: {
+				handler: function(route) {
+					this.redirect = route.query && route.query.redirect;
+				},
+				immediate: true
+			}
+		},
+		created() {
+			this.getCode();
+		},
+		methods: {
+			getCode() {
+				getCodeImg().then(res => {
+					this.captchaEnabled = res.captchaEnabled === undefined ? true : res.captchaEnabled;
+					if (this.captchaEnabled) {
+						this.codeUrl = "data:image/gif;base64," + res.img;
+						this.form.uuid = res.uuid;
+					}
+				});
+			},
+			handleLogin() {
+				this.$refs.form.validate((valid) => {
+				  if (valid) {
+				    this.loading = true;
+				    this.form.type = "1";
+				    this.$store.commit("setType", "1");
+				    this.$store
+				      .dispatch("Login", this.form)
+				      .then(() => {
+				        this.$router
+				          .push({
+				            path: this.redirect || "/index",
+				          })
+				          .catch(() => { });
+				      })
+				      .catch(() => {
+				        this.loading = false;
+				        if (this.captchaEnabled) {
+				          // this.$message({
+				          // 	type:"error",
+				          // 	message:error.msg
+				          // })
+				          this.getCode();
+				        }
+					  });
+					}
+				  });
+			}
+		}
+	};
+</script>
+
+<style rel="stylesheet/scss" lang="scss">
+	.login {
+		height: 100%;
+		position: relative;
+		background-image: url("../assets/images/beijing.jpg");
+		// background-size: cover;
+	}
+
+	.login-box {
+		// background: url("../assets/images/box.png") no-repeat;
+		display: flex;
+		justify-content: flex-end;
+		// background-color: #fff;
+		border-radius: 10px;
+		
+	}
+
+	.title {
+		margin: 0px auto 30px auto;
+		text-align: center;
+		// color: #F56C6C;
+		font-weight: bold;
+		font-size: 20px;
+		letter-spacing: 4px;
+	}
+
+	.login-form {
+		// height: 100%;
+		border-radius: 6px;
+		// background: #ffffff;
+		width: 480px;
+		padding: 25px 60px 5px 60px;
+
+		.el-input {
+			height: 38px;
+
+			input {
+				height: 38px;
+			}
+		}
+
+		.input-icon {
+			height: 39px;
+			width: 14px;
+			margin-left: 2px;
+		}
+	}
+
+	.login-tip {
+		font-size: 13px;
+		text-align: center;
+		color: #bfbfbf;
+	}
+
+	.login-code {
+		width: 33%;
+		height: 38px;
+		float: right;
+
+		img {
+			cursor: pointer;
+			vertical-align: middle;
+		}
+	}
+
+	.el-login-footer {
+		height: 40px;
+		line-height: 40px;
+		position: fixed;
+		bottom: 0;
+		width: 100%;
+		text-align: center;
+		color: #fff;
+		font-family: Arial;
+		font-size: 12px;
+		letter-spacing: 1px;
+	}
+
+	.login-code-img {
+		height: 38px;
+	}
+	.dhk{ 
+		padding: 5px 10px;
+		position: relative;
+		background-color: #f0f6ff;
+		color: #587df6;
+		border-radius: 4px;
+		// box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
+	}
+	
+</style>

+ 269 - 0
src/views/loginQy.vue

@@ -0,0 +1,269 @@
+<template>
+	<div class="login">
+		<div style="position: absolute;top: 50%;left: 50%;transform: translateX(-50%) translateY(-60%);">
+			<div class="login-box"> 
+				<img src="../assets/images/zc.png" style="width: 360px;" alt="" />
+				<div style="background-color: #fff;border-radius: 0 8px 8px 0;height:360px ;display: flex;flex-direction: column;justify-content: space-between;height: 418px;">
+					<div style="display: flex;justify-content: flex-end;align-items: center;">
+						<div class="dhk" style="font-size: 12px;">
+							{{type == 'zh'?'微信扫码登录':'账号密码登录'}}
+							<i class="el-icon-caret-right" style="position: absolute;right: -12px;font-size: 20px;color: #f0f6ff;top: 3px;z-index: 99;"></i>
+						</div>
+						<div class="saoma" style="padding: 6px;background-color: #f0f6ff;position: relative;cursor: pointer;" >
+							<img src="../assets/images/saoma.png" style="width: 34px;" alt="" v-if="type == 'zh'"  />
+							<img src="../assets/images/phone.png" style="width: 34px;" alt="" v-if="type == 'wx'"  />
+							<div style="width: 0;height: 0;border-bottom: 50px solid #fff;border-right: 47px solid transparent;position: absolute;bottom: 0;left: 0;" @click="type=='wx'?type='zh':type='wx'">
+								
+							</div>
+						</div>
+					</div>
+					<el-form ref="form" :model="form" :rules="loginRules" class="login-form" v-if="type == 'zh'">
+						<h3 class="title"><span style="color: #2052f4;">账号密码</span>登录</h3>
+						<el-form-item prop="username">
+							<el-input v-model="form.username" type="text" auto-complete="off" placeholder="账号">
+								<svg-icon slot="prefix" icon-class="user" class="el-input__icon input-icon" />
+							</el-input>
+						</el-form-item>
+						<el-form-item prop="password">
+							<el-input v-model="form.password" type="password" auto-complete="off" placeholder="密码"
+								@keyup.enter.native="handleLogin">
+								<svg-icon slot="prefix" icon-class="password" class="el-input__icon input-icon" />
+							</el-input>
+						</el-form-item>
+						<el-form-item prop="code" >
+							<el-input v-model="form.code" auto-complete="off" placeholder="验证码" style="width: 63%"
+								@keyup.enter.native="handleLogin">
+								<svg-icon slot="prefix" icon-class="validCode" class="el-input__icon input-icon" />
+							</el-input>
+							<div class="login-code">
+								<img :src="codeUrl" @click="getCode" class="login-code-img" />
+							</div>
+						</el-form-item>
+						<el-form-item style="width:100%;">
+							<el-button :loading="loading" size="medium" type="danger" style="width:100%;background-color: #2254f4;border-color: #2254f4;"
+								@click.native.prevent="handleLogin">
+								<span v-if="!loading">登 录</span>
+								<span v-else>登 录 中...</span>
+							</el-button>
+						</el-form-item>
+					</el-form>
+					<div v-else-if="type == 'wx'" class="login-form">
+							<h3 class="title"><span style="color: #2052f4;">微信扫码</span>登录</h3>
+							<div style="text-align: center;color:#aab0b5 ;font-size: 14px;">
+								未注册的微信号将自动创建稿定账号
+							</div>
+							<div style="text-align: center;">
+								<img src="../assets/images/weweima.png" style="width: 180px;margin-top: 10px;margin-bottom: 20px;" alt="" />
+							</div>
+					</div>
+					<div style="background-color: #f5f7fb; padding: 10px 0;text-align: center;color: #bbbcbe;font-size: 14px;font-weight: bold;">
+						主办单位:中国铁道工程建设协会建设监理专业委员会
+					</div>
+				</div>
+				
+			</div>
+			
+		</div>
+		
+		<!--  底部  -->
+		<div class="el-login-footer">
+			<!-- <span>Copyright © 2018-2023 ruoyi.vip All Rights Reserved.</span> -->
+		</div>
+	</div>
+</template>
+
+<script>
+	import {
+		getCodeImg
+	} from "@/api/login";
+	import Cookies from "js-cookie";
+	import {
+		encrypt,
+		decrypt
+	} from '@/utils/jsencrypt'
+
+	export default {
+		name: "LoginQy",
+		data() {
+			return {
+				type:'zh',
+				codeUrl: "",
+				form: {
+					username: "",
+					password: "",
+					rememberMe: false,
+					code: "",
+					uuid: "",
+					type: null,
+					cardName: "",
+					cardNo: "",
+				},
+				loginRules: {
+				  username: [
+				    {
+				      required: true,
+				      trigger: "blur",
+				      message: "请输入用户名",
+				    },
+				  ],
+				  password: [
+				    {
+				      required: true,
+				      trigger: "blur",
+				      message: "请输入密码",
+				    },
+				  ],
+				  code: [
+				    {
+				      required: true,
+				      trigger: "blur",
+				      message: "请输入验证码",
+				    },
+				  ],
+				},
+				loading: false,
+				// 注册开关
+				register: false,
+				redirect: undefined
+			};
+		},
+		watch: {
+			$route: {
+				handler: function(route) {
+					this.redirect = route.query && route.query.redirect;
+				},
+				immediate: true
+			}
+		},
+		created() {
+			this.getCode();
+		},
+		methods: {
+			getCode() {
+				getCodeImg().then(res => {
+					this.captchaEnabled = res.captchaEnabled === undefined ? true : res.captchaEnabled;
+					if (this.captchaEnabled) {
+						this.codeUrl = "data:image/gif;base64," + res.img;
+						this.form.uuid = res.uuid;
+					}
+				});
+			},
+			handleLogin() {
+				this.$refs.form.validate((valid) => {
+				  if (valid) {
+				    this.loading = true;
+				    this.form.type = "0";
+				    this.$store.commit("setType", "0");
+				    this.$store
+				      .dispatch("Login", this.form)
+				      .then(() => {
+				        this.$router
+				          .push({
+				            path: this.redirect || "/index",
+				          })
+				          .catch(() => { });
+				      })
+				      .catch((error) => {
+							this.loading = false;
+							if (this.captchaEnabled) {
+							  this.getCode();
+							}
+				      });
+				  }
+				});
+			}
+		}
+	};
+</script>
+
+<style rel="stylesheet/scss" lang="scss">
+	.login {
+		height: 100%;
+		position: relative;
+		background-image: url("../assets/images/beijing.jpg");
+		// background-size: cover;
+	}
+
+	.login-box {
+		// background: url("../assets/images/box.png") no-repeat;
+		display: flex;
+		justify-content: flex-end;
+		// background-color: #fff;
+		border-radius: 10px;
+		
+	}
+
+	.title {
+		margin: 0px auto 30px auto;
+		text-align: center;
+		// color: #F56C6C;
+		font-weight: bold;
+		font-size: 20px;
+		letter-spacing: 4px;
+	}
+
+	.login-form {
+		// height: 100%;
+		border-radius: 6px;
+		// background: #ffffff;
+		width: 480px;
+		padding: 25px 60px 5px 60px;
+
+		.el-input {
+			height: 38px;
+
+			input {
+				height: 38px;
+			}
+		}
+
+		.input-icon {
+			height: 39px;
+			width: 14px;
+			margin-left: 2px;
+		}
+	}
+
+	.login-tip {
+		font-size: 13px;
+		text-align: center;
+		color: #bfbfbf;
+	}
+
+	.login-code {
+		width: 33%;
+		height: 38px;
+		float: right;
+
+		img {
+			cursor: pointer;
+			vertical-align: middle;
+		}
+	}
+
+	.el-login-footer {
+		height: 40px;
+		line-height: 40px;
+		position: fixed;
+		bottom: 0;
+		width: 100%;
+		text-align: center;
+		color: #fff;
+		font-family: Arial;
+		font-size: 12px;
+		letter-spacing: 1px;
+	}
+
+	.login-code-img {
+		height: 38px;
+	}
+	.dhk{ 
+		padding: 5px 10px;
+		position: relative;
+		background-color: #f0f6ff;
+		color: #587df6;
+		border-radius: 4px;
+		// box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
+	}
+	
+</style>

+ 76 - 37
src/views/userIndex.vue

@@ -2,43 +2,49 @@
 	<div class="home" style="background-color:#edf6ff ;">
 		<div style="background-color:#1e62ec;color: #fff;padding: 10px 0;font-size: 15px;" >
 			<el-row>
-				<el-col :xl="{ span: 16, offset: 4 }" :lg="{ span: 16, offset: 4 }" :md="{ span: 18, offset: 2 }" :sm="{ span: 20, offset: 2 }" :xs="{ span: 24 }" class="flex-ac-jb">
+				<el-col :xl="{ span: 16, offset: 4 }" :lg="{ span: 16, offset: 4 }" :md="{ span: 18, offset: 3 }" :sm="{ span: 20, offset: 2 }" :xs="{ span: 24 }" class="flex-ac-jb">
 					<div >
 						中国铁道工程建设协会建设监理专业委员会
 					</div>
 					<div class="flex-ac">
-						<div>官方网站</div>
+						<div style="cursor: pointer;" @click="tiaozhuan('https://www.carec.org.cn/carec/committee')">官方网站</div>
 						<el-divider direction="vertical"></el-divider>
-						<div>注册监理工程师继续教育</div>
-						<el-divider direction="vertical"></el-divider>
-						<el-button size="mini" round style="background-color: #1e62ec;color: #fff;">登 录</el-button>
-						<el-button size="mini" round style="background-color: #1e62ec;color: #fff;">企业注册</el-button>
+						<div style="cursor: pointer;" @click="tiaozhuan('http://jxjy.jdkjxy.com/Web/index.html')">注册监理工程师继续教育</div>
+						<!-- <el-divider direction="vertical"></el-divider> -->
+						
 					</div>
 				</el-col>
 			</el-row>
 		</div>
 		<el-row style="background-color: #fff;height: 100px;box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.3);" class="flex-ac m-b-20" >
-			<el-col :xl="{ span: 16, offset: 4 }" :lg="{ span: 16, offset: 4 }" :md="{ span: 18, offset: 2 }" :sm="{ span: 20, offset: 2 }" :xs="{ span: 24 }" >
-				<img src="../assets/images/logoNew.png" style="width: 40%" alt="" />
+			<el-col :xl="{ span: 16, offset: 4 }" :lg="{ span: 16, offset: 4 }" :md="{ span: 18, offset: 3}" :sm="{ span: 20, offset: 2 }" :xs="{ span: 24 }" >
+				<div class="flex-ac-jb">
+					<img src="../assets/images/logoNew.png" style="width: 40%" alt="" />
+					<div>
+						<el-button type="success" @click="login(1)">监理企业登录入口</el-button>
+						<el-button type="primary" style="background-color: #1e62ec;border-color: #1e62ec;" @click="login(2)">网络教育登录入口</el-button>
+					</div>
+				</div>
+				
 			</el-col>
 		</el-row>
 		<el-row class="m-b-20">
-			<el-col :xl="{ span: 16, offset: 4 }" :lg="{ span: 16, offset: 4 }" :md="{ span: 18, offset: 2 }" :sm="{ span: 20, offset: 2 }" :xs="{ span: 24 }" >
-				<el-carousel height="400">
-				    <el-carousel-item v-for="(item,index) in lbList" :key="index">
+			<el-col :xl="{ span: 16, offset: 4 }" :lg="{ span: 16, offset: 4 }" :md="{ span: 18, offset: 3 }" :sm="{ span: 20, offset: 2 }" :xs="{ span: 24 }" >
+				<el-carousel :height="bannerHeight+'px'">
+				    <el-carousel-item v-for="(item,index) in lbList" :key="index" style="width: 100%;">
 				        <!-- <img :src="item" style="width: 100%;"  alt="" /> -->
-						<el-image style="height: 100%;" :src="item" fit="contain"></el-image>
+						<img ref="bannerHeight" style="width: 100%;" :src="item" fit="contain"></img>
 				    </el-carousel-item>
 				</el-carousel>
 			</el-col>
-			<el-col :xl="{ span: 16, offset: 4 }" :lg="{ span: 16, offset: 4 }" :md="{ span: 18, offset: 2 }" :sm="{ span: 20, offset: 2 }" :xs="{ span: 24 }" class="m-t-20">
+			<el-col :xl="{ span: 16, offset: 4 }" :lg="{ span: 16, offset: 4 }" :md="{ span: 18, offset: 3 }" :sm="{ span: 20, offset: 2 }" :xs="{ span: 24 }" class="m-t-20">
 				<div style="background-color: #fff;border-radius: 10px;box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);overflow: hidden;">
 					<div class="flex-ac">
-						<div class="flex-ac-jc" :style="{'background-color':bmType == 'jxjy'?'#1e62ec':'#f5f7fa'}" style="width: 50%;padding: 14px;" @click="changeBm('jxjy')">
+						<div class="flex-ac-jc" :style="{'background-color':bmType == 'jxjy'?'#1e62ec':'#f5f7fa'}" style="width: 50%;padding: 14px;" @mouseenter="changeBm('jxjy')">
 							<img :src="bmType=='jxjy'?require('../assets/images/btn11.png'):require('../assets/images/btn5.png')" style="width: 26px;" alt="" />
 							<span class="m-l-10" style="font-size: 18px;" :style="{color:bmType=='jxjy'?'#fff':'#666666'}">网络继续教育报名</span>
 						</div>
-						<div class="flex-ac-jc" :style="{'background-color':bmType == 'jxjy'?'#f5f7fa':'#1e62ec'}" style="width: 50%;padding: 14px;" @click="changeBm('zgks')">
+						<div class="flex-ac-jc" :style="{'background-color':bmType == 'jxjy'?'#f5f7fa':'#1e62ec'}" style="width: 50%;padding: 14px;" @mouseenter="changeBm('zgks')">
 							<img :src="bmType == 'jxjy'?require('../assets/images/btn4.png'):require('../assets/images/btn10.png')" style="width: 26px;" alt="" />
 								<span class="m-l-10" style="font-size: 18px;" :style="{color:bmType=='zgks'?'#fff':'#666666'}">资格考试报名</span>
 						</div>
@@ -163,9 +169,22 @@
 			</el-col>
 		</el-row>
 
-		<!-- <div style="width: 8vw;position: fixed;top: 20vh;right: 0;box-shadow: 0 2px 4px rgba(0, 0, 0, 0.12), 0 0 6px rgba(0, 0, 0, 0.04);border-radius: 6px 0 0 6px;overflow: hidden;" class="box-hover hidden-xs-only">
-			<img src="../assets/images/cx.jpg" style="width: 100%" @click="chaxun" />
-		</div> -->
+		<div style="width:80px;position: fixed;top: 60vh;right: 0;border-radius: 6px 0 0 6px;background-color: #1e62ec;display: flex;flex-direction: column;align-items: center;padding: 10px;color: #fff;" class="box-hover " >
+			<div style="display: flex;flex-direction: column;align-items: center;" @click="chaxun">
+				<img src="../assets/images/btn8.png" style="width: 30px;" alt="" />
+				<div style="font-size: 14px;margin-top: 10px;text-align: center;">证书有效期查询</div>
+			</div>
+			<el-divider></el-divider>
+			<div style="display: flex;flex-direction: column;align-items: center;">
+				<img src="../assets/images/btn1.png" style="width: 30px;" alt="" />
+				<div style="font-size: 14px;margin-top: 10px;">操作手册</div>
+			</div>
+			<el-divider></el-divider>
+			<div style="display: flex;flex-direction: column;align-items: center;">
+				<img src="../assets/images/btn2.png" style="width: 30px;" alt="" />
+				<div style="font-size: 14px;margin-top: 10px;">客服</div>
+			</div>
+		</div>
 		<!-- 继续教育报名 -->
 		<el-dialog title="监理工程师继续教育报名" :visible.sync="show" top="6vh" width="70%" :close-on-click-modal="false">
 			<div v-if="show" style="height: 74vh;overflow-y: auto;overflow-x: hidden;padding-top: 0;" class="pd-10">
@@ -237,7 +256,7 @@
 	import zj from "./components/baoming/zj.vue";
 	import jlgcs from "./components/baoming/jlgcs.vue";
 	import kaoshiH5 from "./components/baoming/H5.vue";
-
+	import loginQy from "./loginQy"
 	import {
 		getCodeImg
 	} from "@/api/login";
@@ -257,9 +276,12 @@
 			jly,
 			zj,
 			jlgcs,
+			loginQy
 		},
 		data() {
 			return {
+				loginShow:true,
+				bannerHeight:0,
 				bmType:'jxjy',
 				// 遮罩层
 				loading: true,
@@ -364,7 +386,21 @@
 			this.getCode();
 			this.getJxjyList();
 		},
+		mounted(){
+			this.imgLoad();
+			window.addEventListener('resize',() => {
+				this.bannerHeight=this.$refs.bannerHeight[0].height;
+				this.imgLoad()
+            },false)
+		},
 		methods: {
+			imgLoad(){
+				this.$nextTick(()=>{
+					setTimeout(()=>{
+						this.bannerHeight=this.$refs.bannerHeight[0].height;
+					},200)
+				})
+			},
 			viewFile(url) {
 				window.open(process.env.VUE_APP_BASE_API + url, '_blank'); // '_blank' 确保在新标签页中打开
 			},
@@ -387,7 +423,6 @@
 							UserName: this.form.cardName,
 							UserCord: this.form.cardNo
 						}).then((res) => {
-							console.log("🚀 ~ zigePersonQuery ~ res:", res)
 							let type = null
 							if (res.data.grshenhe == 0 || res.data.grshenhe == 2) {
 								type = true
@@ -399,11 +434,6 @@
 							} else {
 								this.xiugaiType = type
 							}
-							// this.xiugaiType = type == undefined ? true : false;
-							// this.loading = true;
-							// getZigePerson(res.data.zigeperson.PersonId).then((response) => {
-							console.log("🚀 ~ getZigePerson ~ response.data:", res.data)
-							// this.form = response.data;
 							if (res.data.ZcsZhuanYe == "8" || res.data.ZcsZhuanYe == "监理工程师") {
 								this.zgks = "jlgcs";
 							} else if (res.data.ZcsZhuanYe == "28" || res.data.ZcsZhuanYe == "监理员") {
@@ -412,13 +442,8 @@
 								this.zgks = "zj";
 							}
 							this.zgksInfo = res.data;
-							console.log("🚀 ~ getZigePerson ~ response.data:", res.data)
 							this.loading = false;
 							this.open = true;
-							// this.$modal.closeLoading();
-							// }).catch(() => {
-							//   this.$modal.closeLoading();
-							// })
 						})
 					} else {
 
@@ -446,7 +471,6 @@
 			},
 			//考试报名
 			kaoshiBm(row) {
-				console.log("5869", row);
 				if (row.address == null) {
 					this.$message({
 						type: "warning",
@@ -454,7 +478,6 @@
 					});
 				} else {
 					row.City = row.dishi.split("|")[row.address];
-					console.log("row.ZcsZhuanYe", row.ZcsZhuanYe);
 					if (row.ZcsZhuanYe == "8" || row.ZcsZhuanYe == "监理工程师") {
 						this.zgks = "jlgcs";
 						row.ZcsZhuanYe = "监理工程师";
@@ -484,7 +507,6 @@
 			//考试查询
 			search(row) {
 				this.searchRow = row
-				console.log("🚀 ~ 考试查询 ~ row:", row)
 				this.searchShow = true;
 			},
 			getCode() {
@@ -558,10 +580,6 @@
 								.catch((error) => {
 									this.loading = false;
 									if (this.captchaEnabled) {
-										// this.$message({
-										// 	type:"error",
-										// 	message:error.msg
-										// })
 										this.getCode();
 									}
 								});
@@ -639,6 +657,24 @@
 			},
 			changeBm(v){
 				this.bmType = v
+			},
+			tiaozhuan(v){
+				window.open(v)
+			},
+			login(v){
+				if(v == 1){
+					let url = '/loginQy'
+					const routePath = this.$router.resolve({
+						path: url
+					}).href
+					window.open(routePath, '_blank');
+				}else{
+					let url = '/loginJly'
+					const routePath = this.$router.resolve({
+						path: url
+					}).href
+					window.open(routePath, '_blank'); 
+				}
 			}
 		},
 	};
@@ -750,4 +786,7 @@
 		background-position: center;
 		background-repeat: no-repeat;
 	}
+	::v-deep .el-divider--horizontal{
+		margin: 15px 0 !important;
+	}
 </style>

+ 1 - 1
src/views/zhengshuSearch.vue

@@ -3,7 +3,7 @@
 		<div style="background-color: #eaeaea;height: 84px;box-shadow:0 4px 6px -1px rgba(0, 0, 0, 0.3) ;">
 			<el-row>
 				<el-col :xl="{ span: 20, offset: 2 }" :lg="{ span: 14, offset: 5 }" :md="{ span: 20, offset: 2 }" :sm="{ span: 20, offset: 2 }" :xs="{ span: 24 }">
-					<img src="../assets/images/logo.png" style="width: 500px;margin-top: 4px;"/>
+					<img src="../assets/images/logoNew.png" style="width: 500px;margin-top: 4px;"/>
 				</el-col>
 			</el-row>
 		</div>