初始化项目

This commit is contained in:
18500206848
2024-02-02 14:51:50 +08:00
parent dc7051417b
commit 12664d0204
681 changed files with 1 additions and 142886 deletions

View File

@@ -1,198 +0,0 @@
<template>
<div class="avue-contail" :class="{ 'avue--collapse': isCollapse }" v-if="isRouterAlive">
<div class="avue-header">
<!-- 顶部导航栏 -->
<top ref="top" />
<div class="avue-helpText" v-if="helpShow" :class="{'avue-helpText-active':helpTag}" @click="jlHelpChange">
<div class="text">
<img src="../../../public/img/help/icon.png" height="20" width="20"/>
<span>帮助中心</span>
</div>
<img v-if="!helpTag" src="../../../public/img/help/zuo_jiantou.png" height="16" width="16"/>
<img v-else src="../../../public/img/help/right_jiantou.png" height="16" width="16"/>
</div>
</div>
<div class="avue-layout">
<div class="avue-left">
<!-- 左侧导航栏 -->
<sidebar />
</div>
<div class="avue-main" :class="{'avue-main-active':helpTag}">
<!-- 顶部标签卡 -->
<tags />
<transition name="fade-scale">
<search class="avue-view" v-show="isSearch"></search>
</transition>
<!-- 主体视图层 -->
<div style="height: 100%; overflow-y: auto; overflow-x: hidden" id="avue-view" v-show="!isSearch">
<keep-alive :include="include" max="10">
<router-view class="avue-view" v-if="$route.meta.$keepAlive" />
</keep-alive>
<router-view class="avue-view" v-if="!$route.meta.$keepAlive" />
</div>
</div>
<!-- 侧边栏 -->
<jl-help></jl-help>
</div>
<div class="avue-shade" @click="showCollapse"></div>
<set-sign-pwd ref="setSignPwd"></set-sign-pwd>
</div>
</template>
<script>
import {mapGetters, mapState} from "vuex";
import tags from "./tags";
import search from "./search";
import top from "./top/";
import sidebar from "./sidebar/";
import admin from "@/util/admin";
import { validatenull } from "@/util/validate";
import { calcDate } from "@/util/date.js";
import { getStore } from "@/util/store.js";
import { resetRouter } from "@/router/router";
import {whetherSetSignPwd } from '@/api/manage/econtract';
import setSignPwd from './setSignPwd'
import jlHelp from '@/components/jl-help'
export default {
components: {
top,
tags,
search,
sidebar,
setSignPwd,
jlHelp
},
name: "index",
provide() {
return {
index: this,
};
},
data() {
return {
//搜索控制
isSearch: false,
//刷新token锁
refreshLock: false,
//刷新token的时间
refreshTime: "",
isRouterAlive: true,
hasPass:'',
};
},
created() {
//实时检测刷新token
this.refreshToken();
},
mounted() {
this.init();
this.getSignatureStatus();//获取企业是否设置了签章密码
},
activated() { },
computed: {
...mapGetters([
"isMenu",
"isLock",
"isCollapse",
"website",
"menu",
"trial",
"tagList",
]),
...mapState({
helpTag: state => state.common.helpTag,
helpShow: state => state.common.helpShow
}),
include() {
const arr = [];
Array.prototype.forEach.call(this.tagList, (item) => {
arr.push(item.code);
});
return arr;
},
},
props: [],
methods: {
jlHelpChange () {
this.$store.dispatch('jlHelpTag', !this.helpTag)
},
showCollapse() {
this.$store.commit("SET_COLLAPSE");
},
// 初始化
init() {
this.$store.commit("SET_SCREEN", admin.getScreen());
window.onresize = () => {
setTimeout(() => {
this.$store.commit("SET_SCREEN", admin.getScreen());
}, 0);
};
this.$store.dispatch("FlowRoutes").then(() => { });
this.$store.dispatch("InitArea");
},
getSignatureStatus() {
whetherSetSignPwd().then(res => {
this.hasPass=res.data.data;
if(!this.hasPass){
this.$refs.setSignPwd.open();
}
})
},
//打开菜单
openMenu(item = {}) {
if (this.$store.state.user.auth === "2") {
this.$store.dispatch("GetMenu", item.id).then((data) => {
resetRouter();
this.$router.$avueRouter.formatRoutes(data, true);
});
}
},
// 定时检测token
refreshToken() {
this.refreshTime = setInterval(() => {
const token =
getStore({
name: "token",
debug: true,
}) || {};
const date = calcDate(token.datetime, new Date().getTime());
if (validatenull(date)) return;
if (date.seconds >= this.website.tokenTime && !this.refreshLock) {
this.refreshLock = true;
this.$store
.dispatch("refreshToken")
.then(() => {
this.refreshLock = false;
})
.catch(() => {
this.refreshLock = false;
});
}
}, 10000);
},
},
watch: {
trial() {
this.$jlEvent("trialCheck").then(
() => { },
() => { }
);
},
isSearch(val) {
if (!val) {
this.isRouterAlive = false;
this.$nextTick(() => {
this.isRouterAlive = true;
});
}
},
},
};
</script>

View File

@@ -1,8 +0,0 @@
<template>
<div>
<keep-alive>
<router-view class="avue-view" v-if="$route.meta.$keepAlive" />
</keep-alive>
<router-view class="avue-view" v-if="!$route.meta.$keepAlive" />
</div>
</template>

View File

@@ -1,87 +0,0 @@
<template>
<div class="avue-logo">
<transition name="fade">
<span v-if="keyCollapse" class="avue-logo_subtitle" key="0">{{website.logo}}</span>
</transition>
<transition-group name="fade">
<template v-if="!keyCollapse">
<span v-if="loginType !== 'Type-S'" class="avue-logo_title" style=" display: flex !important;
align-items: center !important;" key="1">
<!-- <img height="26px" width="140px" src="/manage/svg/logo_dark2.png" alt /> -->
德阳市智慧就业服务平台
</span>
<span v-if="loginType === 'Type-S'" class="avue-logo_title" key="1">
德阳市智慧就业服务平台
<!-- <img height="26px" width="140px" src="/manage/svg/logo_dark2.png" alt /> -->
</span>
</template>
</transition-group>
</div>
</template>
<script>
import { mapGetters, mapState } from "vuex";
export default {
name: "logo",
data () {
return {};
},
created () { },
computed: {
...mapState({
loginType: (state) => state.user.userInfo.login_type,
}),
...mapGetters(["website", "keyCollapse"])
},
methods: {}
};
</script>
<style lang="scss">
.avue-logo_title {
height: 100% !important;
/*display: flex !important;*/
/*align-items: center !important;*/
img {
margin-left: 20px;
}
}
.fade-leave-active {
transition: opacity 0.2s;
}
.fade-enter-active {
transition: opacity 2.5s;
}
.fade-enter,
.fade-leave-to {
opacity: 0;
}
.avue-logo {
position: fixed;
top: 0;
left: 0;
width: 240px;
height: 64px;
line-height: 64px;
background-color: #20222a;
font-size: 20px;
overflow: hidden;
box-sizing: border-box;
box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.15);
color: rgba(255, 255, 255, 0.8);
z-index: 1024;
&_title {
display: block;
text-align: center;
font-weight: 300;
font-size: 20px;
}
&_subtitle {
display: block;
text-align: center;
font-size: 18px;
font-weight: bold;
color: #fff;
}
}
</style>

View File

@@ -1,197 +0,0 @@
<template>
<div class="avue-searchs">
<i class="avue-searchs__closeBtn el-icon-close" @click="handleEsc"></i>
<div class="avue-searchs__title">菜单搜索</div>
<div class="avue-searchs__content">
<div class="avue-searchs__form">
<el-input :placeholder="$t('search')"
v-model="value"
@keydown.esc.native="handleEsc">
<el-button slot="append"
icon="el-icon-search"></el-button>
</el-input>
<p>
<el-tag>你可以使用快捷键esc 关闭</el-tag>
</p>
</div>
<div class="avue-searchs__list">
<el-scrollbar class="avue-searchs__scrollbar">
<div class="avue-searchs__item"
v-for="(item,index) in menus"
:key="index"
@click="handleSelect(item)">
<i :class="[item[iconKey],'avue-searchs__item-icon']"></i>
<span class="avue-searchs__item-title">{{item[labelKey]}}</span>
<div class="avue-searchs__item-path">
{{item[pathKey]}}
</div>
</div>
</el-scrollbar>
</div>
</div>
</div>
</template>
<script>
import config from './sidebar/config.js'
import {mapGetters} from "vuex";
export default {
data() {
return {
config: config,
value: "",
menus: [],
menuList: []
}
},
created() {
this.getMenuList();
},
watch: {
value() {
this.querySearch();
},
menu() {
this.getMenuList();
}
},
computed: {
labelKey() {
return this.website.menu.props.label || this.config.propsDefault.label;
},
pathKey() {
return this.website.menu.props.path || this.config.propsDefault.path;
},
iconKey() {
return this.website.menu.props.icon || this.config.propsDefault.icon;
},
childrenKey() {
return (
this.website.menu.props.children || this.config.propsDefault.children
);
},
...mapGetters(["menu", "website"])
},
methods: {
handleEsc() {
this.$parent.isSearch = false;
},
getMenuList() {
const findMenu = list => {
for (let i = 0; i < list.length; i++) {
const ele = Object.assign({}, list[i]);
if (this.validatenull(ele[this.childrenKey])) {
this.menuList.push(ele);
} else {
findMenu(ele[this.childrenKey]);
}
}
};
this.menuList = [];
findMenu(this.menu);
this.menus = this.menuList;
},
querySearch() {
var restaurants = this.menuList;
var queryString = this.value
this.menus = queryString
? this.menuList.filter(this.createFilter(queryString))
: restaurants;
},
createFilter(queryString) {
return restaurant => {
return (
restaurant.name.toLowerCase().indexOf(queryString.toLowerCase()) ===
0
);
};
},
handleSelect(item) {
this.handleEsc();
this.value = "";
this.$router.push({
path: this.$router.$avueRouter.getPath({
name: item[this.labelKey],
src: item[this.pathKey]
}, item.meta),
query: item.query
});
}
}
}
</script>
<style lang="scss" scoped>
.avue-searchs {
padding-top: 50px;
width: 100%;
height: 100%;
background-color: #fff;
z-index: 1024;
&__title {
margin-bottom: 60px;
text-align: center;
font-size: 42px;
font-weight: bold;
letter-spacing: 2px;
text-indent: 2px;
}
&__closeBtn{
float: right;
font-size: 30px;
cursor: pointer;
margin-top: 20px;
}
&__form {
margin: 0 auto 50px auto;
width: 50%;
text-align: center;
p {
margin-top: 20px;
}
}
&__scrollbar {
height: 400px;
}
&__list {
box-sizing: border-box;
padding: 20px 30px;
margin: 0 auto;
width: 70%;
border-radius: 4px;
border: 1px solid #ebeef5;
background-color: #fff;
overflow: hidden;
color: #303133;
transition: 0.3s;
box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
}
&__item {
padding: 5px 0;
border-bottom: 1px dashed #eee;
&-icon {
margin-right: 5px;
font-size: 18px;
}
&-title {
font-size: 20px;
font-weight: 500;
color: #333;
}
&-path {
line-height: 30px;
color: #666;
}
}
}
</style>

View File

@@ -1,141 +0,0 @@
<template>
<!--重置密码dialog-->
<el-dialog title="设置签章密码" :visible.sync="dialogFormVisible" :close-on-click-modal="false" :show-close="false"
:close-on-press-escape="false" width="30%">
<el-form :model="form" :rules="rules" ref="resetPwdForm" class="resetPwd-form">
<el-form-item label="手机号码:" :label-width="formLabelWidth" prop="account">
<span>{{phone}}</span>
</el-form-item>
<el-form-item label="请输入验证码:" :label-width="formLabelWidth" prop="code">
<el-input v-model="form.code" autocomplete="off" style="width: 50%;"></el-input>
<el-button :disabled="msgKey" type="primary" @click="getCode">{{msgText}}</el-button>
</el-form-item>
<el-form-item label="请设置新密码:" :label-width="formLabelWidth" prop="pwd">
<el-input type="number" maxlength="6" onKeypress="return(/^[0-9]*$/.test(String.fromCharCode(event.keyCode)))" v-model="form.pwd" autocomplete="off" show-password placeholder="请输入六位数字密码"></el-input>
</el-form-item>
<el-form-item label="请再次输入新密码:" :label-width="formLabelWidth" prop="pwd2">
<el-input type="number" maxlength="6" onKeypress="return(/^[0-9]*$/.test(String.fromCharCode(event.keyCode)))" v-model="form.pwd2" autocomplete="off" show-password placeholder="请再次输入六位数字密码"></el-input>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitResetPwd"> </el-button>
</div>
</el-dialog>
</template>
<script>
import { mapGetters } from 'vuex'
import {getCode,resetPwd} from '@/api/manage/econtract'
export default {
data() {
const validatePwd = (rule, value, callback) => {
if (value != this.form.pwd) {
callback(new Error('两次输入密码不一致'));
}
else {
callback();
}
};
const validPwdNums = (rule, value, callback) => {
if (value.length != 6 || isNaN(Number(value))) {
callback(new Error('请输入6位数的数字密码'));
}
else {
callback();
}
}
return {
form: {
name: '',
region: '',
code: '',
pwd: '',
pwd2: '',
},
formLabelWidth: '150px',
dialogFormVisible: false,
msgKey: false,
msgText: '获取验证码',
msgTime: 120,
phone: '',
rules: {
code: [
{
required: true, message: '请输入验证码', trigger: 'blur'
}
],
pwd: [
{
required: true, message: '请输入密码', trigger: 'blur'
},
{
validator: validPwdNums, trigger: 'blur'
}
],
pwd2: [
{
required: true, message: '请输入确认密码', trigger: 'blur'
},
{
validator: validatePwd, trigger: 'blur'
}
]
}
}
},
methods: {
open() {
this.phone = this.userInfo.account;
var pat = /(\d{3})\d*(\d{4})/;
this.phone = this.phone.replace(pat, '$1****$2');
this.dialogFormVisible = true;
},
/*获取验证码*/
getCode() {
this.msgKey = true;
this.msgText = "发送中...";
getCode(this.userInfo.account)
.then(() => {
this.msgText = "剩余" + 120 + "s";
this.msgKey = true;
const time = setInterval(() => {
this.msgTime--;
this.msgText = "剩余" + this.msgTime + "s";
if (this.msgTime <= 0) {
this.msgTime = 120;
this.msgText = "重新获取";
this.msgKey = false;
clearInterval(time);
}
}, 1000);
})
.catch(() => {
this.msgText = "重新获取";
this.msgKey = false;
});
},
/*设置签章密码*/
submitResetPwd() {
this.$refs.resetPwdForm.validate(valid => {
if (valid) {
resetPwd(this.userInfo.account, this.form.pwd, this.form.code).then(() => {
this.$message.success('签章密码设置成功');
this.dialogFormVisible = false;
})
.catch((err) => {
this.$message.error(err);
})
}
})
},
},
computed: {
...mapGetters(['userInfo'])
}
}
</script>
<style>
.resetPwd-form .el-form-item {
margin-bottom: 30px!important;
}
</style>

View File

@@ -1,8 +0,0 @@
export default {
propsDefault: {
label: 'label',
path: 'path',
icon: 'icon',
children: 'children'
}
}

View File

@@ -1,60 +0,0 @@
<template>
<div class="avue-sidebar">
<logo></logo>
<el-scrollbar style="height:100%">
<div v-if="validatenull(menu)" class="avue-sidebar--tip">{{$t('menuTip')}}</div>
<el-menu
unique-opened
:default-active="nowTagValue"
mode="vertical"
:show-timeout="200"
:collapse="keyCollapse"
>
<sidebar-item
:menu="menu"
:screen="screen"
first
:props="website.menu.props"
:collapse="keyCollapse"
></sidebar-item>
</el-menu>
</el-scrollbar>
</div>
</template>
<script>
import { mapGetters } from "vuex";
import logo from "../logo";
import sidebarItem from "./sidebarItem";
export default {
name: "sidebar",
components: { sidebarItem, logo },
inject: ["index"],
data() {
return {};
},
created() {
this.index.openMenu(this.menuId);
},
computed: {
...mapGetters([
"website",
"menu",
"tag",
"keyCollapse",
"screen",
"menuId",
]),
nowTagValue: function () {
return this.$router.$avueRouter.getValue(this.$route);
},
},
mounted() {},
methods: {},
watch: {},
};
</script>
<style lang="scss" scoped>
</style>

View File

@@ -1,146 +0,0 @@
<template>
<div class="menu-wrapper">
<template v-for="item in menu">
<el-menu-item v-if="validatenull(item[childrenKey]) && vaildRoles(item)"
:index="item[pathKey]"
@click="open(item)"
:key="item[labelKey]"
:class="{'is-active':vaildAvtive(item)}">
<i :class="item[iconKey]"></i>
<span slot="title"
:alt="item[pathKey]">{{generateTitle(item)}}</span>
</el-menu-item>
<el-submenu v-else-if="!validatenull(item[childrenKey])&&vaildRoles(item)"
:index="item[pathKey]"
:key="item[labelKey]">
<template slot="title">
<i :class="item[iconKey]"></i>
<span slot="title"
:class="{'el-menu--display':collapse && first}">{{generateTitle(item)}}</span>
</template>
<template v-for="(child,cindex) in item[childrenKey]">
<el-menu-item :index="child[pathKey],cindex"
@click="open(child)"
:class="{'is-active':vaildAvtive(child)}"
v-if="validatenull(child[childrenKey])"
:key="child[labelKey]">
<i :class="child[iconKey]"></i>
<span slot="title">{{generateTitle(child)}}</span>
</el-menu-item>
<sidebar-item v-else
:menu="[child]"
:key="cindex"
:props="props"
:screen="screen"
:collapse="collapse"></sidebar-item>
</template>
</el-submenu>
</template>
</div>
</template>
<script>
import {mapGetters} from "vuex";
import {validatenull} from "@/util/validate";
import config from "./config.js";
export default {
name: "sidebarItem",
data() {
return {
config: config
};
},
props: {
menu: {
type: Array
},
screen: {
type: Number
},
first: {
type: Boolean,
default: false
},
props: {
type: Object,
default: () => {
return {};
}
},
collapse: {
type: Boolean
}
},
created() {
},
mounted() {
},
computed: {
...mapGetters(["roles"]),
labelKey() {
return this.props.label || this.config.propsDefault.label;
},
pathKey() {
return this.props.path || this.config.propsDefault.path;
},
iconKey() {
return this.props.icon || this.config.propsDefault.icon;
},
childrenKey() {
return this.props.children || this.config.propsDefault.children;
},
nowTagValue() {
return this.$router.$avueRouter.getValue(this.$route);
}
},
methods: {
generateTitle(item) {
return this.$router.$avueRouter.generateTitle(
item[this.labelKey],
(item.meta || {}).i18n
);
},
vaildAvtive(item) {
const groupFlag = (item["group"] || []).some(ele =>
this.$route.path.includes(ele)
);
return this.nowTagValue === item[this.pathKey] || groupFlag;
},
vaildRoles(item) {
item.meta = item.meta || {};
return item.meta.roles ? item.meta.roles.includes(this.roles) : true;
},
validatenull(val) {
return validatenull(val);
},
open (item) {
if (this.screen <= 1) this.$store.commit("SET_COLLAPSE");
this.$router.$avueRouter.group = item.group;
this.$router.$avueRouter.meta = item.meta;
var query = {}
if (item.isShow === 1) {
var obj = {
isShow: item.isShow,
id: item.id,
}
query = {
obj: JSON.stringify(obj),
...item.query
}
} else {
query = {
...item.query
}
}
this.$router.push({
path: this.$router.$avueRouter.getPath({
name: item[this.labelKey],
src: item[this.pathKey],
}, item.meta),
query: query,
});
}
}
};
</script>

View File

@@ -1,188 +0,0 @@
<template>
<div class="avue-tags" v-if="showTag">
<!-- tag盒子 -->
<div
v-if="contextmenuFlag"
class="avue-tags__contentmenu"
:style="{left:contentmenuX+'px',top:contentmenuY+'px'}"
>
<!-- <div class="item" @click="clearCacheTags">{{$t('tagsView.clearCache')}}</div>
<div class="item" @click="closeOthersTags">{{$t('tagsView.closeOthers')}}</div>
<div class="item" @click="closeAllTags">{{$t('tagsView.closeAll')}}</div> -->
</div>
<div class="avue-tags__box" :class="{'avue-tags__box--close':!website.isFirstPage}">
<el-tabs
v-model="active"
type="card"
@contextmenu.native="handleContextmenu"
:closable="tagLen!==1"
@tab-click="openTag"
@edit="menuTag"
>
<el-tab-pane
:key="item.value"
v-for="item in tagList"
:label="generateTitle(item)"
:name="item.value"
></el-tab-pane>
</el-tabs>
<el-dropdown class="avue-tags__menu">
<el-button type="text" size="mini">
{{$t('tagsView.menu')}}
<i class="el-icon-arrow-down el-icon--right"></i>
</el-button>
<el-dropdown-menu slot="dropdown">
<el-dropdown-item @click.native="$parent.isSearch=true">{{$t('tagsView.search')}}</el-dropdown-item>
<el-dropdown-item @click.native="closeOthersTags">{{$t('tagsView.closeOthers')}}</el-dropdown-item>
<el-dropdown-item @click.native="closeAllTags">{{$t('tagsView.closeAll')}}</el-dropdown-item>
<el-dropdown-item @click.native="clearCacheTags">{{$t('tagsView.clearCache')}}</el-dropdown-item>
</el-dropdown-menu>
</el-dropdown>
</div>
</div>
</template>
<script>
import { mapGetters, mapState } from "vuex";
import { clearCache } from "@/api/user";
import {removeStore} from '@/util/store'
export default {
name: "tags",
data () {
return {
active: "",
contentmenuX: "",
contentmenuY: "",
contextmenuFlag: false
};
},
created () {
},
mounted () {
this.setActive();
},
watch: {
tag () {
this.setActive();
},
contextmenuFlag () {
window.addEventListener("mousedown", this.watchContextmenu);
}
},
computed: {
...mapGetters(["tagWel", "tagList", "tag", "website"]),
...mapState({
showTag: state => state.common.showTag
}),
tagLen () {
return this.tagList.length || 0;
}
},
methods: {
generateTitle (item) {
return this.$router.$avueRouter.generateTitle(
item.label,
(item.meta || {}).i18n
);
},
watchContextmenu (event) {
if (!this.$el.contains(event.target) || event.button !== 0) {
this.contextmenuFlag = false;
}
window.removeEventListener("mousedown", this.watchContextmenu);
},
handleContextmenu (event) {
let target = event.target;
// 解决 https://github.com/d2-projects/d2-admin/issues/54
let flag = false;
if (target.className.indexOf("el-tabs__item") > -1) flag = true;
else if (target.parentNode.className.indexOf("el-tabs__item") > -1) {
target = target.parentNode;
flag = true;
}
if (flag) {
event.preventDefault();
event.stopPropagation();
this.contentmenuX = event.clientX;
this.contentmenuY = event.clientY;
this.tagName = target.getAttribute("aria-controls").slice(5);
this.contextmenuFlag = true;
}
},
//激活当前选项
setActive () {
this.active = this.tag.value;
},
menuTag (value, action) {
if (action === "remove") {
let { tag, key } = this.findTag(value);
if (value === '/workstation/task/index') {
removeStore({name: 'taskStatus', type: 'session'})
}
if (value === '/workstation/enterprise/index') {
removeStore({name: 'enterpriseStatus', type: 'session'})
}
this.$store.commit("DEL_TAG", tag);
if (tag.value === this.tag.value) {
tag = this.tagList[key === 0 ? key : key - 1]; //如果关闭本标签让前推一个
this.openTag(tag);
}
}
},
openTag (item) {
let tag;
if (item.name) {
tag = this.findTag(item.name).tag;
} else {
tag = item;
}
this.$router.push({
path: this.$router.$avueRouter.getPath({
name: tag.label,
src: tag.value
}, tag.meta),
query: tag.query
});
},
closeOthersTags () {
this.contextmenuFlag = false;
this.$store.commit("DEL_TAG_OTHER");
},
findTag (value) {
let tag, key;
this.tagList.map((item, index) => {
if (item.value === value) {
tag = item;
key = index;
}
});
return { tag: tag, key: key };
},
closeAllTags () {
this.contextmenuFlag = false;
this.$store.commit("DEL_ALL_TAG");
removeStore({name: 'taskStatus', type: 'session'})
removeStore({name: 'enterpriseStatus', type: 'session'})
this.$router.push({
path: this.$router.$avueRouter.getPath({
src: this.tagWel.value
}),
query: this.tagWel.query
});
},
clearCacheTags () {
this.$confirm("是否需要清除缓存?", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
}).then(() => {
clearCache().then(() => {
this.$message.success('清除完毕');
})
});
}
}
};
</script>

View File

@@ -1,167 +0,0 @@
<template>
<div class="avue-top">
<div class="top-bar__left">
<div
class="avue-breadcrumb"
:class="[{ 'avue-breadcrumb--active': isCollapse }]"
v-if="showCollapse"
>
<i v-if="showNavIcon" class="icon-navicon" @click="setCollapse"></i>
</div>
</div>
<div class="top-bar__title">
<div class="top-bar__item top-bar__item--show" v-if="showMenu">
<top-menu ref="topMenu"></top-menu>
</div>
</div>
<div class="top-bar__right">
<top-theme></top-theme>
<router-link to="/tenant/news/index" v-if="$store.state.user.auth === '2'">
<div class="top-bar__item top-bar__item--show">
<el-button type="text" style="padding:0;color:#fff;font-weight: 400;">
<i v-if="notice.count > 0" class="el-icon-bell" style="color:red"></i>
<i v-else class="el-icon-bell"></i>
<span>客户消息&nbsp;</span>
<span v-if="notice.count > 0">({{notice.count}})</span>
<span v-else-if="notice.count > 10">(99+)</span>
</el-button>
</div>
</router-link>
<div style="margin-top:2px">
<img class="top-bar__img" src="/manage/img/head.png" />
<span class="top-bar__name">{{userInfo.real_name}}</span>
<el-dropdown>
<span class="el-dropdown-link">
<i class="el-icon-arrow-down el-icon--right"></i>
</span>
<el-dropdown-menu slot="dropdown" style="margin-top:-5px">
<!-- <el-dropdown-item>
<router-link to="/">{{$t('navbar.dashboard')}}</router-link>
</el-dropdown-item>-->
<!-- <el-dropdown-item>
<router-link to="/info/index">{{$t('navbar.userinfo')}}</router-link>
</el-dropdown-item>-->
<el-dropdown-item>
<router-link to="/tenant/account/index">{{$t('navbar.accountsafe')}}</router-link>
</el-dropdown-item>
<el-dropdown-item v-if="auth === '2' && loginType === 'Type-S'" divided>
<a href="http://www.jlhrms.com/#/" target="_blank">{{$t('navbar.experienceEntrance')}}</a>
</el-dropdown-item>
<!-- <el-dropdown-item>
<router-link to="/tenant/set/index">{{$t('navbar.set')}}</router-link>
</el-dropdown-item>-->
<!-- <el-dropdown-item>
<router-link to="/tenant/company/index">{{$t('navbar.companyindex')}}</router-link>
</el-dropdown-item>-->
<el-dropdown-item @click.native="logout" divided>{{$t('navbar.logOut')}}</el-dropdown-item>
</el-dropdown-menu>
</el-dropdown>
</div>
</div>
</div>
</template>
<script>
import { resetRouter } from "@/router/router";
import { mapGetters, mapState } from "vuex";
import { fullscreenToggel, listenfullscreen } from "@/util/util";
import topLock from "./top-lock";
import topMenu from "./top-menu";
import topSearch from "./top-search";
import topTheme from "./top-theme";
import topLogs from "./top-logs";
import topColor from "./top-color";
import topNotice from "./top-notice";
import topLang from "./top-lang";
let interval;
export default {
components: {
topLock,
topMenu,
topSearch,
topTheme,
topLogs,
topColor,
topNotice,
topLang,
},
name: "top",
data() {
return {};
},
filters: {},
created() {},
mounted() {
listenfullscreen(this.setScreen);
if (this.loginType === 'Type-S') {
this.$store.dispatch("workGetUnreadCount");
} else {
this.$store.dispatch("getUnreadCount");
}
interval = setInterval(() => {
if (this.loginType === 'Type-S') {
this.$store.dispatch("workGetUnreadCount");
} else {
this.$store.dispatch("getUnreadCount");
}
}, 60000);
},
computed: {
...mapState({
showDebug: (state) => state.common.showDebug,
showTheme: (state) => state.common.showTheme,
showLock: (state) => state.common.showLock,
showFullScren: (state) => state.common.showFullScren,
showCollapse: (state) => state.common.showCollapse,
showSearch: (state) => state.common.showSearch,
showMenu: (state) => state.common.showMenu,
showColor: (state) => state.common.showColor,
showNavIcon: (state) => state.user.auth === "2" || !state.notPc,
auth: (state) => state.user.auth,
loginType: (state) => state.user.userInfo.login_type,
}),
...mapGetters([
"userInfo",
"isFullScren",
"tagWel",
"tagList",
"isCollapse",
"tag",
"logsLen",
"logsFlag",
"notice",
]),
},
methods: {
handleScreen() {
fullscreenToggel();
},
setCollapse() {
this.$store.commit("SET_COLLAPSE");
},
setScreen() {
this.$store.commit("SET_FULLSCREN");
},
logout() {
this.$confirm(this.$t("logoutTip"), this.$t("tip"), {
confirmButtonText: this.$t("submitText"),
cancelButtonText: this.$t("cancelText"),
type: "warning",
}).then(() => {
this.$store.dispatch("LogOut").then(() => {
resetRouter();
this.$store.dispatch('jlHelpShow', false)
this.$router.push({ path: "/login" });
});
});
},
},
destroyed() {
clearInterval(interval);
},
};
</script>
<style lang="scss" scoped>
</style>

View File

@@ -1,30 +0,0 @@
<template>
<el-color-picker size="mini"
style="padding-top:18px;"
class="theme-picker"
popper-class="theme-picker-dropdown"
v-model="themeVal"></el-color-picker>
</template>
<script>
import color from "@/mixins/color";
export default {
name: "topColor",
mixins: [color()],
data() {
return {
chalk: ""
};
}
};
</script>
<style>
.theme-picker .el-color-picker__trigger {
vertical-align: middle;
}
.theme-picker-dropdown .el-color-dropdown__link-btn {
display: none;
}
</style>

View File

@@ -1,49 +0,0 @@
<template>
<el-dropdown trigger="click"
@command="handleSetLanguage">
<i class="icon-zhongyingwen"></i>
<el-dropdown-menu slot="dropdown">
<el-dropdown-item :disabled="language==='zh'"
command="zh">中文
</el-dropdown-item>
<el-dropdown-item :disabled="language==='en'"
command="en">English
</el-dropdown-item>
</el-dropdown-menu>
</el-dropdown>
</template>
<script>
import {mapGetters} from "vuex";
export default {
name: "top-lang",
data() {
return {};
},
created() {
},
mounted() {
},
computed: {
...mapGetters(["language", "tag"])
},
props: [],
methods: {
handleSetLanguage(lang) {
this.$i18n.locale = lang;
this.$store.commit("SET_LANGUAGE", lang);
let tag = this.tag;
let title = this.$router.$avueRouter.generateTitle(
tag.label,
(tag.meta || {}).i18n
);
//根据当前的标签也获取label的值动态设置浏览器标题
this.$router.$avueRouter.setTitle(title);
}
}
};
</script>
<style lang="scss" scoped>
</style>

View File

@@ -1,72 +0,0 @@
<template>
<span>
<i class="icon-suoping"
@click="handleLock"></i>
<el-dialog title="设置锁屏密码"
:visible.sync="box"
width="30%"
append-to-body>
<el-form :model="form"
ref="form"
label-width="80px">
<el-form-item label="锁屏密码"
prop="passwd"
:rules="[{ required: true, message: '锁屏密码不能为空'}]">
<el-input v-model="form.passwd"
placeholder="请输入锁屏密码" />
</el-form-item>
</el-form>
<span slot="footer"
class="dialog-footer">
<el-button type="primary"
@click="handleSetLock"> </el-button>
</span>
</el-dialog>
</span>
</template>
<script>
import { validatenull } from "@/util/validate";
import { mapGetters } from "vuex";
export default {
name: "top-lock",
data() {
return {
box: false,
form: {
passwd: ""
}
};
},
created() {},
mounted() {},
computed: {
...mapGetters(["lockPasswd"])
},
props: [],
methods: {
handleSetLock() {
this.$refs["form"].validate(valid => {
if (valid) {
this.$store.commit("SET_LOCK_PASSWD", this.form.passwd);
this.handleLock();
}
});
},
handleLock() {
if (validatenull(this.lockPasswd)) {
this.box = true;
return;
}
this.$store.commit("SET_LOCK");
setTimeout(() => {
this.$router.push({ path: "/lock" });
}, 100);
}
},
components: {}
};
</script>
<style lang="scss" scoped>
</style>

View File

@@ -1,43 +0,0 @@
<template>
<span @click="logsFlag?'':handleOpen()">
<el-badge :value="logsFlag?'':logsLen"
:max="99">
<i class="icon-rizhi1"></i>
</el-badge>
<el-dialog title="日志"
fullscreen
:visible.sync="box"
width="100%"
append-to-body>
<logs></logs>
</el-dialog>
</span>
</template>
<script>
import { mapGetters } from "vuex";
import logs from "@/page/logs/index";
export default {
name: "top-logs",
components: { logs },
data() {
return {
box: false
};
},
created() {},
mounted() {},
computed: {
...mapGetters(["logsFlag", "logsLen"])
},
props: [],
methods: {
handleOpen() {
this.box = true;
}
}
};
</script>
<style lang="scss" scoped>
</style>

View File

@@ -1,93 +0,0 @@
<template>
<div class="top-menu">
<el-menu :default-active="activeIndex" mode="horizontal" text-color="#333">
<el-menu-item index="0" @click.native="openHome(itemHome)" key="0">
<template slot="title" v-if="loginType !== 'Type-S'">
<span>{{generateTitle(itemHome)}}</span>
</template>
<template slot="title" v-if="loginType === 'Type-S'">
<span class="workTitle">{{nickName}}</span>
</template>
</el-menu-item>
<template v-for="(item,index) in items">
<el-menu-item :index="item.id+''" @click.native="openMenu(item)" :key="index">
<template slot="title">
<i :class="item.source" style="padding-right: 5px;"></i>
<span>{{generateTitle(item)}}</span>
</template>
</el-menu-item>
</template>
</el-menu>
</div>
</template>
<script>
import { mapGetters, mapState } from "vuex";
export default {
name: "top-menu",
data () {
return {
itemHome: {
code: "wel",
name: '欢迎进入德阳市智慧就业服务平台(零工市场服务系统)',
source: 'iconfont iconhome',
},
activeIndex: "0",
items: [],
};
},
inject: ["index"],
created () {
this.getMenu();
},
computed: {
...mapState({
nickName: (state) => state.user.userInfo.nick_name,
loginType: (state) => state.user.userInfo.login_type,
}),
...mapGetters(["tagCurrent", "menu"])
},
methods: {
openHome (itemHome) {
this.index.openMenu(itemHome);
this.$router.push({
path: this.$router.$avueRouter.getPath({ name: itemHome.name, src: '' }, {})
});
},
openMenu (item) {
this.index.openMenu(item)
},
getMenu () {
this.$store.dispatch("GetTopMenu").then(res => {
this.items = res;
});
},
generateTitle (item) {
return this.$router.$avueRouter.generateTitle(
item.name,
(item.meta || {}).i18n
);
},
}
};
</script>
<style scoped>
.el-menu-item [class^="iconfont"] {
margin-right: 5px;
width: 24px;
font-weight: 400;
text-align: center;
font-size: 14px;
vertical-align: middle;
color: rgb(51, 51, 51);
}
.workTitle{
width: 217px;
height: 30px;
font-size: 22px;
font-weight: bold;
color: #333333;
line-height: 30px;
}
</style>

View File

@@ -1,87 +0,0 @@
<template>
<el-popover placement="bottom"
width="350"
trigger="click">
<el-tabs v-model="activeName">
<el-tab-pane label="邮件(1)"
name="first"></el-tab-pane>
<el-tab-pane label="消息(2)"
name="second"></el-tab-pane>
<el-tab-pane label="通知"
name="third"></el-tab-pane>
</el-tabs>
<el-scrollbar style="height:300px">
<avue-notice :data="data"
:option="option"
@page-change="pageChange"></avue-notice>
</el-scrollbar>
<div slot="reference">
<el-badge is-dot>
<i class="el-icon-bell"></i>
</el-badge>
</div>
</el-popover>
</template>
<script>
let list = [{
img: 'https://avue.jobslinkX.vip/images/logo-bg.jpg',
title: '史蒂夫·乔布斯 关注了你',
subtitle: '05-08 15:08',
tag: '已经开始',
status: 0
}, {
img: 'https://avue.jobslinkX.vip/images/logo-bg.jpg',
title: '斯蒂夫·沃兹尼亚克 关注了你',
subtitle: '05-08 15:08',
tag: '未开始',
status: 1
}, {
img: 'https://avue.jobslinkX.vip/images/logo-bg.jpg',
title: '蒂姆·库克 关注了你',
subtitle: '05-08 15:08',
status: 3,
tag: '有错误'
}, {
img: 'https://avue.jobslinkX.vip/images/logo-bg.jpg',
title: '比尔·费尔南德斯 关注了你',
subtitle: '05-08 15:08',
status: 4,
tag: '已完成'
}];
export default {
name: "top-notice",
data () {
return {
activeName: 'first',
option: {
props: {
img: 'img',
title: 'title',
subtitle: 'subtitle',
tag: 'tag',
status: 'status'
},
},
data: list,
}
},
created () {
},
methods: {
pageChange (page, done) {
setTimeout(() => {
this.$message.success('页码' + page)
this.data = this.data.concat(list);
done();
}, 1000)
},
}
};
</script>
<style lang="scss" scoped>
</style>

View File

@@ -1,131 +0,0 @@
<template>
<el-autocomplete class="top-search"
popper-class="my-autocomplete"
v-model="value"
:fetch-suggestions="querySearch"
:placeholder="$t('search')"
@select="handleSelect">
<template slot-scope="{ item }">
<i :class="[item[iconKey],'icon']"></i>
<div class="name">{{ item[labelKey] }}</div>
<div class="addr">{{ item[pathKey] }}</div>
</template>
</el-autocomplete>
</template>
<script>
import config from "../sidebar/config.js";
import {mapGetters} from "vuex";
export default {
data() {
return {
config: config,
value: "",
menuList: []
};
},
created() {
this.getMenuList();
},
watch: {
menu() {
this.getMenuList();
}
},
computed: {
labelKey() {
return this.website.menu.props.label || this.config.propsDefault.label;
},
pathKey() {
return this.website.menu.props.path || this.config.propsDefault.path;
},
iconKey() {
return this.website.menu.props.icon || this.config.propsDefault.icon;
},
childrenKey() {
return (
this.website.menu.props.children || this.config.propsDefault.children
);
},
...mapGetters(["menu", "website"])
},
methods: {
getMenuList() {
const findMenu = list => {
for (let i = 0; i < list.length; i++) {
const ele = Object.assign({}, list[i]);
if (this.validatenull(ele[this.childrenKey])) {
this.menuList.push(ele);
} else {
findMenu(ele[this.childrenKey]);
}
}
};
this.menuList = [];
findMenu(this.menu);
},
querySearch(queryString, cb) {
var restaurants = this.menuList;
var results = queryString
? restaurants.filter(this.createFilter(queryString))
: restaurants;
// 调用 callback 返回建议列表的数据
cb(results);
},
createFilter(queryString) {
return restaurant => {
return (
restaurant.name.toLowerCase().indexOf(queryString.toLowerCase()) ===
0
);
};
},
handleSelect(item) {
this.value = "";
this.$router.push({
path: this.$router.$avueRouter.getPath({
name: item[this.labelKey],
src: item[this.pathKey]
}, item.meta),
query: item.query
});
}
}
};
</script>
<style lang="scss">
.my-autocomplete {
li {
line-height: normal;
padding: 7px;
.icon {
margin-right: 5px;
display: inline-block;
vertical-align: middle;
}
.name {
display: inline-block;
text-overflow: ellipsis;
overflow: hidden;
vertical-align: middle;
}
.addr {
padding-top: 5px;
width: 100%;
font-size: 12px;
color: #b4b4b4;
}
.highlighted .addr {
color: #ddd;
}
}
}
</style>

View File

@@ -1,72 +0,0 @@
<template>
<div>
<el-dialog title="选择"
append-to-body
:visible.sync="box"
width="50%">
<el-radio-group v-model="text"
class="list">
<el-row :span="24">
<el-col v-for="(item,index) in list"
:key="index"
:md="4"
:xs="12"
:sm="4">
<el-radio :label="item.value">{{item.name}}</el-radio>
</el-col>
</el-row>
</el-radio-group>
</el-dialog>
</div>
</template>
<script>
import { setTheme } from "@/util/util";
import { mapGetters } from "vuex";
export default {
data () {
return {
box: false,
text: "",
list: [
{
name: "默认主题",
value: "default"
},
{
name: "白色主题",
value: "theme-white"
}
]
};
},
watch: {
text: function (val) {
val = "theme-white";
this.$store.commit("SET_THEME_NAME", val);
setTheme(val);
}
},
computed: {
...mapGetters(["themeName"])
},
mounted () {
this.text = this.themeName;
if (!this.text) {
this.text = "";
}
},
methods: {
open () {
this.box = true;
}
}
};
</script>
<style lang="scss" scoped>
.list {
width: 100%;
}
</style>

View File

@@ -1,108 +0,0 @@
<template>
<div class="lock-container">
<div class="lock-form animated bounceInDown">
<div class="animated"
:class="{'shake':passwdError,'bounceOut':pass}">
<h3 class="title">{{userInfo.username}}</h3>
<el-input placeholder="请输入登录密码"
type="password"
class="input-with-select animated"
v-model="passwd"
@keyup.enter.native="handleLogin">
<el-button slot="append"
icon="icon-bofangqi-suoping"
@click="handleLogin"></el-button>
<el-button slot="append"
icon="icon-tuichu"
@click="handleLogout"></el-button>
</el-input>
</div>
</div>
</div>
</template>
<script>
import { mapGetters, mapState } from "vuex";
export default {
name: "lock",
data() {
return {
passwd: "",
passwdError: false,
pass: false
};
},
created() {},
mounted() {},
computed: {
...mapState({
userInfo: state => state.user.userInfo
}),
...mapGetters(["tag", "lockPasswd"])
},
props: [],
methods: {
handleLogout() {
this.$confirm("是否退出系统, 是否继续?", "提示", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
}).then(() => {
this.$store.dispatch("LogOut").then(() => {
this.$router.push({ path: "/login" });
});
});
},
handleLogin() {
if (this.passwd !== this.lockPasswd) {
this.passwd = "";
this.$message({
message: "解锁密码错误,请重新输入",
type: "error"
});
this.passwdError = true;
setTimeout(() => {
this.passwdError = false;
}, 1000);
return;
}
this.pass = true;
setTimeout(() => {
this.$store.commit("CLEAR_LOCK");
this.$router.push({
path: this.$router.$avueRouter.getPath({ src: this.tag.value })
});
}, 1000);
}
},
components: {}
};
</script>
<style lang="scss">
.lock-container {
height: 100%;
display: flex;
align-items: center;
justify-content: center;
position: relative;
.title {
margin-bottom: 8px;
color: #333;
}
}
.lock-container::before {
z-index: -999;
content: "";
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
background-image: url("/img/bg/login.png");
background-size: cover;
}
.lock-form {
width: 300px;
}
</style>

View File

@@ -1,99 +0,0 @@
<template>
<div class="layoutBottomBox">
<div class="footerPrepare">
<p>
Copyright © 2021 企嘉云人力
<a href="//beian.miit.gov.cn" target="blank">京ICP备16004663号-10</a>
经营许可证编号京B2-20130104
<a href="/home/img/license/YYZZ.jpg" target="blank"
><img
height="16"
src="/manage/img/icon-badge-1.png"
/>电子营业执照</a
>&nbsp;
<a href="/home/img/license/RLZYXKZ.jpg" target="blank"
>人力资源服务许可证</a
>
</p>
</div>
</div>
</div>
</template>
<script>
let config;
if (process.env.VUE_APP_SITE === "default") {
config = {
phone: "185-0020-68488:30-17:30 周一到周五)",
email: "tousu@jilianjituan.com",
address: "通州区和平西路486号",
gongzhonghao: "/manage/img/cmanage/wx/gzh/default.jpeg",
xiaochengxu: "/manage/img/cmanage/wx/xcx/default.jpeg",
};
} else if (process.env.VUE_APP_SITE === "hengshui") {
config = {
phone: "0318-88888108:30-17:30 周一到周五)",
email: "tousu@jilianjituan.com",
address: "衡水市桃城区人民西路818号易得电子广场5层",
gongzhonghao: "",
xiaochengxu: "/manage/img/cmanage/wx/xcx/hengshui.jpg",
};
}
export default {
name: "layoutBottom",
data() {
return { config };
},
};
</script>
<style scoped>
* {
margin: 0;
padding: 0;
}
.layoutBottomBox {
background: #ffffff;
}
.footerTop {
width: 100%;
display: flex;
justify-content: space-between;
}
h4 {
font-size: 18px;
color: #666666;
margin-top: 40px;
}
.contactUs p {
line-height: 40px;
font-size: 14px;
color: #666666;
}
.footerPrepare {
width: 100%;
text-align: center;
border-top: 1px solid #dddddd;
padding: 31px 0;
margin-top: 40px;
font-size: 14px;
color: #999999;
}
.footerPrepare a,
.footerPrepare a:hover,
.footerPrepare a:visited {
color: inherit;
}
.footerCode {
display: flex;
margin-top: 30px;
}
.footerCode div {
text-align: center;
font-size: 14px;
color: #666666;
letter-spacing: 0;
line-height: 20px;
}
</style>

View File

@@ -1,282 +0,0 @@
<template>
<div class="layoutTopBox">
<div class="layoutBox">
<div class="layoutTopBoxLeft">
<img
:src="config.logo"
height="30"
width="140"
class="logo hand"
@click="logoUrl"
/>
</div>
<div class="layoutTopBoxRight">
<div class="topBtn hand" @click="changeManageWork('workstation')" :class="{ isSelect: workStationStatus === 'workstation' }">
<span>代理商</span>
</div>
<div class="topBtn hand qrCodeBox">
<img
class="Code"
src="/img/cmanage/qrcode.svg"
height="14"
width="14"
/>
<img
class="CodeBlue"
src="/img/cmanage/code_blue.svg"
height="14"
width="14"
/>
<span>{{config.wxTitle}}</span>
<div class="qrCode">
<img
:src="config.wxImg"
height="130"
width="130"
/>
</div>
</div>
</div>
</div>
</div>
</template>
<script>
import { mapGetters } from "vuex";
import {setStore, getStore} from '@/util/store'
let config;
if (process.env.VUE_APP_SITE === "default") {
config = {
logo: "/manage/img/cmanage/logo/default.pn",
wxTitle: "企嘉云小程序",
wxImg: "/manage/img/cmanage/wx/xcx/default.jpeg",
zixun: "企嘉云资讯",
guanyu: "关于企嘉云",
};
} else if (process.env.VUE_APP_SITE === "hengshui") {
config = {
logo: "/manage/img/cmanage/logo/hengshui.svg",
wxTitle: "小程序",
wxImg: "/manage/img/cmanage/wx/xcx/hengshui.jpg",
zixun: "平台资讯",
guanyu: "关于平台",
};
}
export default {
name: "layoutTop",
data() {
return {
layoutInput: getStore({ name: "searchInput" }) || "",
workStationStatus: 'manageInfo',
titleList: [
{
name: "首页",
url: "/#/",
},
{
name: "我要招聘",
url: "/#/recruit/index",
},
{
name: "企业服务",
url: "",
select: true
},
{
name: config.zixun,
url: "/#/news",
},
{
name: config.guanyu,
url: "/#/aboutJL",
},
],
config,
};
},
methods: {
changeManageWork (str) {
setStore({name: 'workStationStatus', content: str, type: 'session'})
this.workStationStatus = str
if (str === 'manageInfo') {
this.$emit('change','login')
} else if (str === 'workstation') {
this.$emit('change','workstation')
}
},
enterKey(e) {
if (!this.layoutInput.trim()) return;
var evt = window.event || e;
if (evt.keyCode == 13) {
this.layoutIsSearchInput(this.layoutInput);
window.open("/#/searchJob?id=" + this.layoutInput, "_blank");
// window.open('http://192.168.88.123:8081/#/searchJob?id='+this.layoutInput, '_blank');
}
},
isSearchSelect(type) {
this.$store.dispatch("layoutIsSearch", type);
this.$store.dispatch("layoutIsSearchInput", "");
this.layoutInput = "";
if (!type) return;
this.$nextTick(() => {
this.$refs.search.focus();
});
},
layoutIsSearchInput(str) {
this.$store.dispatch("layoutIsSearchInput", str);
},
logoUrl() {
window.open("/#/", "_self");
},
},
computed: {
...mapGetters(["isSearch", "searchInput"])
},
};
</script>
<style scoped>
.hand {
cursor: pointer;
}
.logo {
margin-right: 46px;
}
ul {
overflow: hidden;
}
ul li {
list-style: none;
}
.layoutTopBox {
background: #ffffff;
}
.layoutBox {
display: flex;
justify-content: space-between;
width: 1000px;
margin: 0 auto;
padding: 20px 0;
}
.layoutTopBoxLeft,
.layoutTopBoxRight {
display: flex;
align-items: center;
}
.layoutTopUl,
a {
display: flex;
font-size: 18px;
color: #333333;
margin: 0 !important;
padding: 0 !important;
}
.layoutTopUl li {
margin: 0 10px;
}
.layoutTopUl li a:hover {
color: #5aa0fa;
}
.isSelect {
color: #5aa0fa !important;
}
.layoutInputBox {
display: flex;
align-content: center;
width: 440px;
padding-bottom: 6px;
border-bottom: 1px solid #5aa0fa;
}
.layoutInputBox .searchIcon {
margin-right: 2px;
}
.layoutInputBox img {
margin-top: 2px;
}
.layoutInputBox input {
width: 400px;
height: 20px;
border: none;
font-size: 16px;
color: #333333;
}
.layoutInputBox input:focus {
outline: none;
border: none;
}
.topBtn {
display: flex;
align-items: center;
font-size: 16px;
color: #333333;
}
.topBtn:hover {
color: #5aa0fa;
}
.topBtn:hover .search {
display: none;
}
.topBtn:hover .searchBlue {
display: block;
}
.topBtn .searchBlue {
display: none;
}
.topBtn img {
margin: 2px 5px 0 0;
}
.topBtn:first-of-type + div {
margin: 0 16px;
}
.qrCodeBox {
position: relative;
}
.qrCodeBox:hover {
color: #5aa0fa;
}
.qrCodeBox:hover .qrCode {
display: block;
}
.qrCodeBox:hover .Code {
display: none;
}
.qrCodeBox:hover .CodeBlue {
display: block;
}
.qrCodeBox .CodeBlue {
display: none;
}
.qrCode {
position: absolute;
top: 45px;
left: -51px;
width: 130px;
height: 130px;
background-color: #ffffff;
padding: 10px;
z-index: 999;
display: none;
box-shadow: 0 2px 12px 0 rgba(0,0,0,.06);
border-radius: 4px;
}
.qrCode img {
margin: 0;
}
</style>

View File

@@ -1,20 +0,0 @@
<template>
<div></div>
</template>
<script>
export default {
name: 'authredirect',
created () {
window.close()
const params = this.$route.query
const state = params.state
const code = params.code
window.opener.location.href = `${window.location.origin}/#/login?state=${state}&code=${code}`
}
}
</script>
<style>
</style>

View File

@@ -1,133 +0,0 @@
<template>
<el-form class="login-form"
status-icon
:rules="loginRules"
ref="loginForm"
:model="loginForm"
label-width="0">
<el-form-item prop="phone">
<el-input size="small"
@keyup.enter.native="handleLogin"
v-model="loginForm.phone"
auto-complete="off"
:placeholder="$t('login.phone')">
<i slot="prefix"
class="icon-shouji"/>
</el-input>
</el-form-item>
<el-form-item prop="code">
<el-input size="small"
@keyup.enter.native="handleLogin"
v-model="loginForm.code"
auto-complete="off"
:placeholder="$t('login.code')">
<i slot="prefix"
class="icon-yanzhengma"
style="margin-top:6px;"/>
<template slot="append">
<span @click="handleSend"
class="msg-text"
:class="[{display:msgKey}]">{{msgText}}</span>
</template>
</el-input>
</el-form-item>
<el-form-item>
<el-button size="small"
type="primary"
@click.native.prevent="handleLogin"
class="login-submit">{{$t('login.submit')}}</el-button>
</el-form-item>
</el-form>
</template>
<script>
import { isvalidatemobile } from "@/util/validate";
import { mapGetters } from "vuex";
export default {
name: "codelogin",
data() {
const validatePhone = (rule, value, callback) => {
if (isvalidatemobile(value)[0]) {
callback(new Error(isvalidatemobile(value)[1]));
} else {
callback();
}
};
const validateCode = (rule, value, callback) => {
if (value.length !== 4) {
callback(new Error("请输入4位数的验证码"));
} else {
callback();
}
};
return {
msgText: "",
msgTime: "",
msgKey: false,
loginForm: {
phone: "",
code: ""
},
loginRules: {
phone: [{ required: true, trigger: "blur", validator: validatePhone }],
code: [{ required: true, trigger: "blur", validator: validateCode }]
}
};
},
created() {
this.msgText = this.config.MSGINIT;
this.msgTime = this.config.MSGTIME;
},
mounted() {},
computed: {
...mapGetters(["tagWel"]),
config() {
return {
MSGINIT: this.$t("login.msgText"),
MSGSCUCCESS: this.$t("login.msgSuccess"),
MSGTIME: 60
};
}
},
props: [],
methods: {
handleSend() {
if (this.msgKey) return;
this.msgText = this.msgTime + this.config.MSGSCUCCESS;
this.msgKey = true;
const time = setInterval(() => {
this.msgTime--;
this.msgText = this.msgTime + this.config.MSGSCUCCESS;
if (this.msgTime === 0) {
this.msgTime = this.config.MSGTIME;
this.msgText = this.config.MSGINIT;
this.msgKey = false;
clearInterval(time);
}
}, 1000);
},
handleLogin() {
this.$refs.loginForm.validate(valid => {
if (valid) {
this.$store.dispatch("LoginByPhone", this.loginForm).then(() => {
this.$router.push({ path: this.tagWel.value });
});
}
});
}
}
};
</script>
<style>
.msg-text {
display: block;
width: 60px;
font-size: 12px;
text-align: center;
cursor: pointer;
}
.msg-text.display {
color: #ccc;
}
</style>

View File

@@ -1,208 +0,0 @@
<template>
<div>
<el-form :model="pwdForm" :rules="pwdRules" ref="pwdForm" class="login-form">
<el-form-item prop="phone">
<el-input
@keyup.enter.native="submit"
v-model="pwdForm.phone"
auto-complete="off"
placeholder="请输入您的手机号"
></el-input>
</el-form-item>
<el-form-item v-if="this.website.captchaMode" prop="imgCode">
<el-input
@keyup.enter.native="handleLogin"
v-model="pwdForm.imgCode"
auto-complete="off"
placeholder="请输入图形验证码"
class="code-input"
></el-input>
<div class="login-code">
<img :src="pwdForm.image" class="login-code-img" @click="refreshCode" />
</div>
</el-form-item>
<el-form-item prop="code">
<el-input
@keyup.enter.native="submit"
v-model="pwdForm.code"
auto-complete="off"
placeholder="请输入短信验证码"
class="code-input"
></el-input>
<div class="login-code">
<el-button type="text" @click="handleSend" class="msg-text">{{msgText}}</el-button>
</div>
</el-form-item>
<el-form-item prop="password">
<el-input
@keyup.enter.native="submit"
v-model="pwdForm.password"
type="password"
auto-complete="off"
placeholder="请输入6-20位包含数字和字母的密码"
></el-input>
</el-form-item>
<div>
<el-button
size="small"
type="primary"
@click.native.prevent="submit"
class="login-submit"
style="margin-top: 30px;"
>确定</el-button>
</div>
<div class="forget-pwd">
<el-button size="small" type="text" @click="backLogin">返回登录</el-button>
</div>
</el-form>
</div>
</template>
<script>
import { isvalidatemobile, password } from "@/util/validate";
import { mapGetters } from "vuex";
import { getCaptcha, sendCodeFgt, forgetPwd } from "@/api/tenant/account";
import md5 from 'js-md5'
import { getStore } from '@/util/store'
const validatePassDef = (rule, value, callback) => {
if (password(value)) {
callback(new Error("密码需要包含数字和字母并且长度为6-20位"));
} else {
callback();
}
};
export default {
name: "codelogin",
data () {
const validatePhone = (rule, value, callback) => {
if (isvalidatemobile(value)[0]) {
callback(new Error(isvalidatemobile(value)[1]));
} else {
callback();
}
};
const validateCode = (rule, value, callback) => {
if (value.length !== 4) {
callback(new Error("验证码不正确"));
} else {
callback();
}
};
return {
msgText: "获取验证码",
msgTime: 120,
msgKey: false,
pwdForm: {
phone: "",
password: '',
code: "",
imgCode: '',
key: "",
//预加载白色背景
image: "",
},
pwdRules: {
phone: [{ required: true, trigger: "blur", validator: validatePhone }],
imgCode: [{ required: true, message: '请输入图形验证码', trigger: "blur" }],
code: [{ required: true, trigger: "blur", validator: validateCode }],
password: [{ required: true, message: '请输入您的密码', trigger: "blur" },
{
validator: validatePassDef,
trigger: "blur",
}],
}
};
},
created () {
this.refreshCode();
},
mounted () { },
computed: {
...mapGetters(["website", "tagWel"])
},
props: [],
methods: {
backLogin(){
var status = getStore({name: 'workStationStatus'})
if (status && status === 'workstation') {
this.$emit('change', 'workstation')
} else {
this.$emit('change','login')
}
},
refreshCode () {
getCaptcha().then(res => {
const data = res.data;
this.pwdForm.key = data.key;
this.pwdForm.image = data.image;
})
},
/*发送短信验证码 */
handleSend () {
if (this.msgKey) return;
this.$refs.pwdForm.validateField('phone', (error) => {
if (!error) {
this.$refs.pwdForm.validateField('imgCode', (error) => {
if (!error) {
sendCodeFgt(this.pwdForm).then(() => {
this.msgText = '剩余' + 120 + 's';
this.msgKey = true;
const time = setInterval(() => {
this.msgTime--;
this.msgText = '剩余' + this.msgTime + 's';
if (this.msgTime === 0) {
this.msgTime = 120;
this.msgText = '重新获取';
this.msgKey = false;
clearInterval(time);
}
}, 1000);
}, error => {
window.console.log(error);
this.$message.error('发送失败!')
});
}
})
}
})
},
submit () {
this.$refs.pwdForm.validate(valid => {
if (valid) {
var status = getStore({name: 'workStationStatus'})
var authType = 0
if (status && status === 'workstation') {
authType = 2
}
forgetPwd(this.pwdForm.phone, this.pwdForm.code, md5(this.pwdForm.password), authType).then(() => {
this.$message({
message: '修改密码成功',
type: 'success'
});
setTimeout(() => {
this.$emit('change', 'login')
}, 1000);
}, error => {
window.console.log(error);
});
}
});
}
}
};
</script>
<style scoped>
.login-form {
margin-top: -30px !important;
}
.forget-pwd {
text-align: center !important;
margin-top: 30px !important;
}
</style>
<style lang="scss">
@import "@/styles/login.scss";
</style>

View File

@@ -1,97 +0,0 @@
<template>
<div class="login-container" ref="login" @keyup.enter.native="handleLogin">
<!-- <cmanage-title @change="changeActive"></cmanage-title> -->
<div class="login-weaper animated bounceInDown">
<div style="height: 50px;"></div>
<div class="login-content">
<!-- <div class="login-left">
<img class="img" src="/manage/img/logobg.png" alt />
</div> -->
<div class="login-border">
<user-login v-if="activeName==='login'" @change="changeActive" />
<forget-pwd v-else-if="activeName==='pwd'" @change="changeActive" />
<user-register v-else-if="activeName==='register'" @change="changeActive" />
<work-station-login v-else-if="activeName==='workstation'" @change="changeActive"></work-station-login>
</div>
</div>
<div data-v-3c692830="" style="text-align: center; margin-top: 20px; padding-bottom: 30px;"><div data-v-3c692830="" style="font-size: 12px; color: #40a9ff;">Copyright @ 德阳市智慧就业服务中心</div></div>
</div>
</div>
</template>
<script>
import userLogin from "./userlogin";
import forgetPwd from "./forgetPwd";
import userRegister from "./userRegister";
import workStationLogin from "./workStationLogin";
import topLang from "@/page/index/top/top-lang";
import CmanageFooter from './CmanageFooter'
import CmanageTitle from './CmanageTitle'
import jlTab from "@/components/jl-tab/main";
export default {
name: "login",
components: {
topLang,
forgetPwd,
userLogin,
userRegister,
workStationLogin,
CmanageFooter,
CmanageTitle,
jlTab
},
data() {
return {
activeName: "login",
fixed: 0,
homeList: [],
fixedShow:false,
maxFixed: 2000
};
},
watch: {},
created() {
},
mounted() {
this.$refs.login.addEventListener('scroll',this.scroll)
this.maxFixed = this.$refs.login.scrollHeight
},
computed: {},
props: [],
methods: {
introduce (item) {
const arr = {"企业招聘":0,"一键录用":1,"电子合同":2,"职业伤害":3,"工资结算":4,"信用评价":5}
this.$refs.intro[arr[item]].scrollIntoView()
},
changeActive(name) {
this.activeName = name;
},
handleSelect(index) {
if (index == 1) {
this.$router.push({ path: "/login" });
} else if (index == 2) {
window.location.href = "http://crm.jobslink.cn/crm";
}
},
scroll(){
const tab = this.$refs.tab.$el
const login = this.$refs.login
this.fixedShow =
login.scrollTop > tab.offsetTop &&
login.scrollTop < this.maxFixed - tab.clientHeight;
if (this.fixedShow) {
const number = login.scrollTop - tab.offsetTop
const index = Math.floor(number / 410)
const tabData = this.$refs.tab._data
if(tabData.active === 4 && tabData.activeStatus)return
this.$refs.tab.tabNum(index)
}
}
},
};
</script>
<style lang="scss">
@import "@/styles/login.scss";
</style>

View File

@@ -1,84 +0,0 @@
<template>
<div class="social-container">
<div class="box"
@click="handleClick('wechat')">
<span class="container"
:style="{backgroundColor:'#6ba2d6'}">
<i icon-class="wechat"
class="iconfont icon-weixin"/>
</span>
<p class="title">{{$t('login.wechat')}}</p>
</div>
<div class="box"
@click="handleClick('tencent')">
<span class="container"
:style="{backgroundColor:'#8dc349'}">
<i icon-class="qq"
class="iconfont icon-qq"/>
</span>
<p class="title">{{$t('login.qq')}}</p>
</div>
</div>
</template>
<script>
import { openWindow } from "@/util/util";
export default {
name: "thirdLogin",
methods: {
handleClick(thirdpart) {
let appid, client_id, redirect_uri, url;
redirect_uri = encodeURIComponent(
window.location.origin + "/#/authredirect"
);
if (thirdpart === "wechat") {
appid = "xxxx";
url =
"https://open.weixin.qq.com/connect/qrconnect?appid=" +
appid +
"&redirect_uri=" +
redirect_uri +
"&state=WX&response_type=code&scope=snsapi_login#wechat_redirect";
} else if (thirdpart === "tencent") {
client_id = "xxxx";
url =
"https://graph.qq.com/oauth2.0/authorize?response_type=code&state=QQ&client_id=" +
client_id +
"&redirect_uri=" +
redirect_uri;
}
openWindow(url, thirdpart, 540, 540);
}
}
};
</script>
<style rel="stylesheet/scss" lang="scss" scoped>
.social-container {
margin: 20px 0;
display: flex;
align-items: center;
justify-content: space-around;
.box {
cursor: pointer;
}
.iconfont {
color: #fff;
font-size: 30px;
}
.container {
$height: 50px;
display: inline-block;
width: $height;
height: $height;
line-height: $height;
text-align: center;
border-radius: 4px;
margin-bottom: 10px;
}
.title {
text-align: center;
}
}
</style>

View File

@@ -1,295 +0,0 @@
<template>
<div class="registerContainer">
<div class="login-title">{{ $t('login.userRegister') }}</div>
<el-form :model="registerForm" :rules="rules" ref="registerForm" class="login-form">
<el-form-item prop="inviteCode">
<el-input
@keyup.enter.native="handleRegister"
v-model="registerForm.inviteCode"
:auto-complete="off"
placeholder="请输入邀请码JL10000000"
></el-input>
</el-form-item>
<el-form-item prop="companyName">
<el-input
@keyup.enter.native="handleRegister"
v-model="registerForm.companyName"
:auto-complete="off"
placeholder="请输入您的企业名"
></el-input>
</el-form-item>
<el-form-item prop="companyTid">
<el-input
@keyup.enter.native="handleRegister"
v-model="registerForm.companyTid"
:auto-complete="off"
placeholder="统一社会信用代码"
></el-input>
</el-form-item>
<el-form-item prop="account">
<el-input
@keyup.enter.native="handleRegister"
v-model.trim="registerForm.account"
:auto-complete="off"
placeholder="请输入您的手机号"
></el-input>
</el-form-item>
<el-form-item prop="code">
<el-input
@keyup.enter.native="handleRegister"
v-model.trim="registerForm.code"
auto-complete="off"
placeholder="请输入验证码"
class="code-input"
></el-input>
<div class="login-code">
<el-button :disabled="msgKey" type="text" @click="handleSend" class="msg-text">{{msgText}}</el-button>
</div>
</el-form-item>
<el-form-item prop="password">
<el-input
type="password"
@keyup.enter.native="handleRegister"
v-model.trim="registerForm.password"
:auto-complete="off"
placeholder="请输入6-20位包含数字和字母的新密码"
></el-input>
</el-form-item>
<div>
<el-button
size="small"
type="primary"
@click="handleRegister"
class="register-submit"
>{{$t('login.registerSubmit')}}</el-button>
</div>
</el-form>
<div class="reg-bottom">
<div>
<el-checkbox v-model="checked"></el-checkbox>
<span @click="checked = !checked" class="reg-agreement">
同意企嘉云用工
<a
@click.stop
href="/blackboard/account/companyagreement.html"
target="blank"
>用户协议及隐私政策</a>
</span>
</div>
<div>
<a @click="$emit('change','login')">{{$t('login.directLogin')}}</a>
</div>
</div>
</div>
</template>
<script>
import { mapGetters } from "vuex";
import topLang from "@/page/index/top/top-lang";
import { isvalidatemobile } from "@/util/validate";
import { reg, sendValidate,regCheckIdentity } from "@/api/tenant/reg";
import md5 from "js-md5";
export default {
name: "login",
components: {
topLang,
},
data () {
const validatePhone = (rule, value, callback) => {
if (isvalidatemobile(value)[0]) {
callback(new Error(isvalidatemobile(value)[1]));
} else {
callback();
}
};
const validatePwd = (rule, value, callback) => {
var re = /^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{6,20}$/;
var match = value.match(re);
if (value.length < 6 || value.length > 20 || !match) {
callback(new Error("密码格式不正确"));
} else {
callback();
}
};
const validateTcode = (rule, value, callback) => {
if(value){
regCheckIdentity(value).then(()=>{
callback();
})
.catch((err)=>{
callback(err);
})
}
else{
callback(new Error('请输入社会统一信用代码'))
}
}
const validateChecked = (rule, value, callback) => {
if (!value) {
callback(new Error('请阅读并同意《服务及隐私协议》'));
}
else {
callback();
}
}
return {
msgText: "获取验证码",
msgTime: 120,
msgKey: false,
checked: false,
registerForm: {
inviteCode: "",
account: "",
password: "",
code: "",
checked: false,
},
rules: {
companyName: [
{ required: true, trigger: "blur", message: "请输入企业名称" },
],
companyTid: [
{
required: true,
whitespace: true,
message: "请输入统一社会信用代码",
trigger: "blur",
},
{ validator: validateTcode, trigger: "blur" },
],
account: [
{ required: true, trigger: "blur", validator: validatePhone },
],
inviteCode: [
{ required: true, message: "请输入邀请码", trigger: "blur" },
{ min: 10, message: "长度不少于10个字符", trigger: "blur" },
],
code: [
{ required: true, message: "请输入短信验证码", trigger: "blur" },
],
password: [
{ required: true, message: "请输入密码" },
{ trigger: "blur", validator: validatePwd },
],
checked: [
{
validator: validateChecked, trigger: 'blur'
}
]
},
passwordType: "password",
};
},
watch: {},
mounted () { },
computed: {
...mapGetters(["website", "tagWel"]),
},
props: [],
methods: {
showPassword () {
this.passwordType === ""
? (this.passwordType = "password")
: (this.passwordType = "");
},
/*发送短信验证码 */
handleSend () {
const inviteCode = new Promise((resolve) => {
this.$refs.registerForm.validateField("inviteCode", resolve);
});
const account = new Promise((resolve) => {
this.$refs.registerForm.validateField("account", resolve);
});
Promise.all([inviteCode, account]).then((err) => {
if (err[0] || err[1]) {
return;
}
this.msgKey = true;
this.msgText = "发送中...";
sendValidate(this.registerForm.account, 0)
.then(() => {
this.msgText = "剩余" + 120 + "s";
this.msgKey = true;
const time = setInterval(() => {
this.msgTime--;
this.msgText = "剩余" + this.msgTime + "s";
if (this.msgTime === 0) {
this.msgTime = 120;
this.msgText = "重新获取";
this.msgKey = false;
clearInterval(time);
}
}, 1000);
})
.catch(() => {
this.msgText = "重新获取";
this.msgKey = false;
});
});
},
handleRegister () {
this.$refs.registerForm.validate((valid) => {
if (valid) {
if (this.checked) {
const loading = this.$loading({
lock: true,
text: "注册中,请稍后。。。",
spinner: "el-icon-loading",
});
reg(
this.registerForm.inviteCode,
this.registerForm.companyName,
this.registerForm.companyTid,
this.registerForm.code,
this.registerForm.account,
md5(this.registerForm.password)
).then(
() => {
this.$message({
message: "注册成功",
type: "success",
});
loading.close();
setTimeout(() => {
this.$emit("change", "login");
}, 1000);
},
() => {
loading.close();
}
);
} else {
this.$message.error("请阅读并同意企嘉云用工用户协议及隐私政策");
}
}
});
},
},
};
</script>
<style lang="scss">
@import "@/styles/login.scss";
.reg-bottom {
margin: 0 30px 0 30px;
display: flex;
font-family: PingFangSC-Regular;
font-size: 14px;
color: #999999;
letter-spacing: 0;
text-align: left;
line-height: 14px;
justify-content: space-between;
flex-wrap: wrap;
cursor: pointer;
}
.reg-bottom > div {
padding-top: 9px;
}
.reg-bottom a {
color: #5aa0fa;
}
</style>

View File

@@ -1,159 +0,0 @@
<template>
<div>
<div class="login-title">{{ $t('login.phoneLogin') }}</div>
<el-form :model="loginForm" :rules="loginRules" ref="loginForm" class="login-form">
<el-form-item prop="username">
<el-input size="small" style="margin-top: 20px; margin-bottom:10px;"
@keyup.enter.native="handleLogin"
v-model="loginForm.username"
:auto-complete="off"
placeholder="请输入您的账号">
<i slot="prefix" class="icon-yonghu" />
</el-input>
</el-form-item>
<el-form-item prop="password">
<el-input size="small" style="margin-top: 20px; margin-bottom:10px;"
type="password"
@keyup.enter.native="handleLogin"
v-model="loginForm.password"
:auto-complete="off"
placeholder="请输入您的密码">
<i slot="prefix" class="icon-mima"/>
</el-input>
</el-form-item>
<el-form-item v-if="this.website.captchaMode" prop="code">
<el-input size="small" style="margin-top: 20px; margin-bottom:10px;"
@keyup.enter.native="handleLogin"
v-model="loginForm.code"
auto-complete="off"
placeholder="请输入图形验证码"
class="code-input">
<i slot="prefix" class="icon-yanzhengma"/>
</el-input>
<div class="login-code" >
<img :src="loginForm.image" class="login-code-img" @click="refreshCode" />
</div>
</el-form-item>
<div>
<el-button
size="small"
type="primary"
@click.native.prevent="handleLogin"
class="login-submit"
>{{$t('login.submit')}}</el-button>
</div>
</el-form>
</div>
</template>
<script>
import { mapGetters } from "vuex";
import topLang from "@/page/index/top/top-lang";
// import { info } from "@/api/system/tenant";
import { getCaptcha } from "@/api/user";
export default {
name: "login",
components: {
topLang,
},
data () {
return {
loginForm: {
//租户ID
tenantId: "000000",
//用户名
username: "",
//密码
password: "",
//账户类型
type: "account",
//验证码的值
code: "",
//验证码的索引
key: "",
//预加载白色背景
image: "",
//工作站loginTpye值为2
loginType:'Type-T'
},
loginRules: {
username: [
{ required: true, message: "请输入用户名", trigger: "blur" }
],
password: [
{ required: true, message: "请输入密码", trigger: "blur" },
{ min: 1, message: "密码长度最少为6位", trigger: "blur" }
]
},
passwordType: "password"
};
},
watch: {
},
created () {
// this.getTenant();
this.refreshCode();
},
mounted () {
},
computed: {
...mapGetters(["website", "tagWel"])
},
props: [],
methods: {
handelGoReg(){
this.$router.push({ path: "/reg" });
},
refreshCode () {
getCaptcha().then(res => {
const data = res.data;
this.loginForm.key = data.key;
this.loginForm.image = data.image;
})
},
showPassword () {
this.passwordType === ""
? (this.passwordType = "password")
: (this.passwordType = "");
},
handleLogin () {
this.$refs.loginForm.validate(valid => {
if (valid) {
const loading = this.$loading({
lock: true,
text: '登录中,请稍后。。。',
spinner: "el-icon-loading"
});
this.$store.dispatch("LoginByUsername", this.loginForm).then(() => {
this.$store.dispatch('jlHelpShow', false)
this.$router.push({ path: this.tagWel.value });
loading.close();
}).catch(() => {
loading.close();
this.refreshCode();
});
}
});
},
// getTenant () {
// let domain = window.location.href.split("/#/")[0];
// // 临时指定域名,方便测试
// info(domain).then(res => {
// const data = res.data;
// if (data.success && data.data.tenantId) {
// this.tenantMode = false;
// this.loginForm.tenantId = data.data.tenantId;
// this.$parent.$refs.login.style.backgroundImage = `url(${data.data.backgroundUrl})`;
// }
// })
// }
}
};
</script>
<style lang="scss">
@import "@/styles/login.scss";
</style>

View File

@@ -1,139 +0,0 @@
<template>
<div>
<div class="login-title">代理商登录</div>
<el-form :model="loginForm" :rules="loginRules" ref="loginForm" class="login-form" label-width="100">
<el-form-item prop="username">
<el-input
@keyup.enter.native="handleLogin"
v-model="loginForm.username"
:auto-complete="off"
placeholder="请输入您的手机号"
></el-input>
</el-form-item>
<el-form-item prop="password">
<el-input
type="password"
@keyup.enter.native="handleLogin"
v-model="loginForm.password"
:auto-complete="off"
placeholder="请输入您的密码"
></el-input>
</el-form-item>
<el-form-item prop="code">
<el-input
@keyup.enter.native="handleLogin"
v-model="loginForm.code"
auto-complete="off"
placeholder="请输入图形验证码"
class="code-input"
></el-input>
<div class="login-code">
<img :src="loginForm.image" class="login-code-img" @click="refreshCode" />
</div>
</el-form-item>
<div>
<el-button
size="small"
type="primary"
@click.native.prevent="handleLogin"
class="login-submit"
>{{$t('login.submit')}}</el-button>
</div>
</el-form>
</div>
</template>
<script>
import { mapGetters } from "vuex";
import { getCaptcha } from "@/api/user";
export default {
name: "workStationLogin",
data () {
return {
loginForm: {
//租户ID
tenantId: "000000",
//用户名
username: "",
//密码
password: "",
//账户类型
type: "account",
//验证码的值
code: "",
//验证码的索引
key: "",
//预加载白色背景
image: "",
//工作站loginTpye值为2
loginType:'Type-S'
},
loginRules: {
username: [
{ required: true, message: "请输入您的手机号", trigger: "blur" }
],
password: [
{ required: true, message: "请输入密码", trigger: "blur" },
{ min: 1, message: "密码长度最少为6位", trigger: "blur" }
]
},
passwordType: "password"
};
},
created() {
this.refreshCode();
},
computed: {
...mapGetters(["website", "tagWel"])
},
methods: {
refreshCode () {
getCaptcha().then(res => {
const data = res.data;
this.loginForm.key = data.key;
this.loginForm.image = data.image;
})
},
handleLogin () {
this.$refs.loginForm.validate(valid => {
if (valid) {
const loading = this.$loading({
lock: true,
text: '登录中,请稍后。。。',
spinner: "el-icon-loading"
});
this.$store.dispatch("LoginByUsername", this.loginForm).then(() => {
this.$router.push({ path: this.tagWel.value });
loading.close();
}).catch(() => {
loading.close();
this.refreshCode();
});
}
});
// this.$refs.loginForm.validate(valid => {
// console.log(this.loginForm);
// if (valid) {
// const loading = this.$loading({
// lock: true,
// text: '登录中,请稍后。。。',
// spinner: "el-icon-loading"
// });
// this.$store.dispatch("loginByUsername", this.loginForm).then(() => {
// this.$router.push({ path: this.tagWel.value });
// loading.close();
// }).catch(() => {
// loading.close();
// this.refreshCode();
// });
// }
// });
},
}
}
</script>
<style lang="scss">
@import "@/styles/login.scss";
</style>

View File

@@ -1,135 +0,0 @@
<template>
<avue-crud :data="logsList"
:option="option">
<template slot="menuLeft">
<el-button type="primary"
size="small"
icon="el-icon-upload"
@click="send">上传服务器</el-button>
<el-button type="danger"
size="small"
icon="el-icon-delete"
@click="clear">清空本地日志</el-button>
</template>
<template slot-scope="scope"
slot="type">
<el-tag type="danger"
size="small">{{scope.label}}</el-tag>
</template>
<template slot-scope="props"
slot="expand">
<pre class="code">
{{props.row.stack}}
</pre>
</template>
</avue-crud>
</template>
<script>
import { mapGetters } from "vuex";
export default {
name: "errLogs",
data() {
return {
option: {
menu: false,
addBtn: false,
page: false,
border: true,
expand: true,
refreshBtn: false,
headerAlign: "center",
column: [
{
label: "类型",
prop: "type",
width: 80,
align: "center",
slot: true,
dicData: [
{
label: "bug",
value: "error"
}
]
},
{
label: "地址",
width: 200,
prop: "url",
overHidden: true
},
{
label: "内容",
prop: "message",
overHidden: true
},
{
label: "错误堆栈",
prop: "stack",
hide: true
},
{
label: "时间",
align: "center",
prop: "time",
width: 200
}
]
}
};
},
created() {},
mounted() {},
computed: {
...mapGetters(["logsList"])
},
props: [],
methods: {
send() {
this.$confirm("确定上传本地日志到服务器?", "提示", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
})
.then(() => {
this.$store.dispatch("SendLogs").then(() => {
this.$parent.$parent.box = false;
this.$message({
type: "success",
message: "发送成功!"
});
});
})
.catch(() => {});
},
clear() {
this.$confirm("确定清空本地日志记录?", "提示", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
})
.then(() => {
this.$store.commit("CLEAR_LOGS");
window.console.log(this);
this.$parent.$parent.box = false;
this.$message({
type: "success",
message: "清空成功!"
});
})
.catch(() => {});
}
}
};
</script>
<style lang="scss" scoped>
.code {
font-size: 12px;
display: block;
font-family: monospace;
white-space: pre;
margin: 1em 0px;
}
</style>