You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

498 lines
15 KiB

<template>
<el-dialog :visible.sync="showBusiness" style="width: 100%" @close="closeData" :close-on-click-modal="false" :show-close="false" custom-class="data-dia">
<div slot="title" class="dia-header2">
<div class="data-title2">请选择业务</div>
<div class="close"><img v-lazy="closeImg" alt="" @click="showBusinessSelect(false)" /></div>
</div>
<p class="tips2">请选择您要办理的业务</p>
<ul class="take-list2">
<li v-for="(item) in businessArr" :class="{checked: takeCheck == item.myKey}" :key="item.myKey" @click="checkTake(item.myKey)">
<img v-lazy="businessImg" alt="">
<p>{{ item.myKey + item.text}}</p>
</li>
<li v-for="(item) in (3 - businessArr.length%3)" class="sitting" :key="item"></li>
</ul>
<div class="dia-footer2">
<div class='busyButtonBox'>
<el-button @click="showBusinessSelect(false)">取消</el-button>
<el-button type="primary" @click="selectBusiness()">确定</el-button>
</div>
</div>
</el-dialog>
</template>
<script>
import { mapState, mapMutations } from 'vuex';
export default {
props: {
// showBusiness: {
// type: Boolean,
// default: false
// }
// default: '本业务需要授权'
},
created() {
if(this.businessKey) {
// 如果上次保存有 那么直接赋值
this.takeCheck = this.businessKey
}
},
data() {
return {
checkList: [],
takeCheck: '',
businessImg: require('@/assets/img/业务列表2.png'),
closeImg: require('@/assets/svg/close.svg'),
// 选择业务逻辑
businessArr: [
{
myKey: '项目一',
text: ': 个人活期开户、存款'
},
{
myKey: '项目二',
text: ': 个人活期转账、取款、销户'
},
{
myKey: '项目三',
text: ': 整存整取开户存款'
},
{
myKey: '项目四',
text: ': 整存整取部分提前支取'
},
{
myKey: '项目五',
text: ': 整存整取全部提前支取'
},
{
myKey: '项目六',
text: ': 零存整取开户'
},
{
myKey: '项目七',
text: ': 零存整取续存'
},
{
myKey: '项目八',
text: ': 零存整取销户'
},
{
myKey: '项目九',
text: ': 通知存款开户'
},
{
myKey: '项目十',
text: ': 通知存款销户'
},
{
myKey: '项目十一',
text: ': 公司基本户和开立'
},
{
myKey: '项目十二',
text: ': 公司存款'
},
{
myKey: '项目十三',
text: ': 公司现金支票取款'
},
{
myKey: '项目十四',
text: ': 公司现金支票转账'
},
{
myKey: '项目十五',
text: ': 密码修改'
},
{
myKey: '项目十六',
text: ': 密码挂失'
},
{
myKey: '项目十七',
text: ': 挂失解挂'
},
{
myKey: '项目十八',
text: ': 现金领用'
},
{
myKey: '项目十九',
text: ': 现金上缴'
},
{
myKey: '项目二十',
text: ': 现金调入'
},
{
myKey: '项目二十一',
text: ': 现金调出'
},
{
myKey: '项目二十二',
text: ': 凭证领用'
},
{
myKey: '项目二十三',
text: ': 凭证上缴'
},
{
myKey: '项目二十四',
text: ': 凭证调入'
},
{
myKey: '项目二十五',
text: ': 凭证调出'
},
{
myKey: '项目二十六',
text: ': 支票出售'
},
{
myKey: '项目二十七',
text: ': 柜员日中轧账'
},
{
myKey: '项目二十八',
text: ': 网点日中轧账'
}
],
}
},
methods: {
...mapMutations({
setBusinessKey: 'system/setBusinessKey',
setShowBusiness: 'system/setShowBusiness'
}),
closeData() {
this.checkList = [];
},
showBusinessSelect (judge) {
if(!judge && !this.businessKey) {
// this.$confirm('由于您未选择一个业务,系统将返回主界面, 是否继续?', '提示', {
// confirmButtonText: '确定',
// cancelButtonText: '取消',
// type: 'warning',
// center: true
// }).then(() => {
// this.$router.push('/index')
// }).catch(() => {
// this.$message({
// type: 'info',
// message: '请选择一个业务'
// });
// });
this.$message({
type: 'info',
message: '请选择一个业务'
});
return
}
this.setShowBusiness(judge)
},
checkTake(myKey){
if(this.takeCheck === myKey) {
this.takeCheck = ''
}else {
this.takeCheck = myKey
}
},
selectBusiness() {
if(!this.takeCheck) {
this.$message({
type: 'info',
message: '请选择一个业务'
});
return
}
this.setBusinessKey(this.takeCheck)
if(!this.$store.state.system.businessSelect[this.$store.state.system.businessKey].id) {
this.$message({
type: 'info',
message: '业务开发中,尽请期待!'
});
return
}
this.setShowBusiness(false)
sessionStorage.setItem('businessKey', this.$store.state.system.businessKey)
},
},
computed: {
...mapState({
showBusiness: state => state.system.showBusiness,
businessKey: state => state.system.businessKey
})
},
watch: {
showBusiness(newVal) {
if(!newVal) {
this.takeCheck = this.businessKey
}
}
},
}
</script>
<style lang="scss" scoped>
.data-dia {
border-radius: 16px;
margin-top: 4vh !important;
background: #fff;
position: fixed;
top: 7%;
left: 50%;
transform: translate(-50%, 0);
padding: 0 15px 15px;
z-index: 997;
border: 1px solid #e6e6e6;
max-height: 600px;
overflow: auto;
.dia-header {
position: relative;
.data-title {
height:70px;
width: 300px;
margin: 0 auto;
line-height: 70px;
text-align: center;
color: #fff;
font-size: 24px;
background: url('../../assets/img/dia-title.png') 0 0 / cover no-repeat;
}
.close {
position: absolute;
top: 15px;
right: 15px;
cursor: pointer;
}
}
// 业务选择中的
.take-list2{
width: 100%;
display: flex;
justify-content: space-around;
flex-direction: row;
flex-wrap: wrap;
height: 40vh;
overflow: auto;
li{
display: inline-flex;
align-items: center;
width: 30%;
height: 10vh;
margin: 1vh 0;
border: 4px solid #DBDBDB;
border-radius: 20px;
cursor: pointer;
background-color: rgba(216,216,216,0.10);
// &:first-child{
// margin: 0 0px 50px 0;
// }
// &:last-child{
// margin-left: 50px;
// }
img{
width: 15%;
margin: 0;
//height: 154px;
//margin: 0 45px;
}
p{
font-size: 14px;
color: #000;
text-align: center;
padding: 0 20px;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
&.checked{
background: rgba(97,145,255,0.10) url('../../assets/svg/checked.svg') 96% 7%/auto no-repeat;
border-color: #6191FF;
}
}
}
.dia-header2 {
position: relative;height: 50px;
line-height: 50px;
background-color: rgb(98, 149, 243) ;
border-top-left-radius:14px;
border-top-right-radius:14px;
.data-title2 {
position: absolute;
left: 15px;
height: 50px;
line-height: 50px;
color:#fff;
}
.close {
height: 50px;
position: absolute;
right: 15px;
cursor: pointer;
display: flex;
flex-direction: column;
justify-content: center;
img {
vertical-align: center;
}
}
}
.tips2 {
margin: 1vh 0 2vh 0;
text-align: left;
font-size: 20px;
color: #000;
}
.list {
width: 940px;
min-height: 204px;
max-height: 360px;
overflow: auto;
margin: 0 auto;
display: flex;
align-items: center;
.img-wrap{
background: url('../../assets/img/data-frame.png') 0 0 / cover no-repeat;
width: 180px;
height: 180px;
display: flex;
justify-content: center;
margin: 5px 10px;
position: relative;
cursor: pointer;
.file {
position: relative;
max-width: 180px;
max-height: 130px;
text-align: center;
margin: 10px 10px ;
img {
margin-top: 45px;
}
p {
position: absolute;
bottom: 0;
width: 100%;
line-height: 54px;
text-align: center;
font-size: 18px;
color: #000;
}
}
.text{
font-size: 18px;
white-space:nowrap;
position: absolute;
bottom: 15px;
left: 50%;
transform: translate(-50%,0);
}
&.checked {
background: url('../../assets/img/data-frame-checked.png') 0 0 / cover no-repeat,
url('../../assets/svg/checked.svg') 165px 7% / auto no-repeat;
p {
color: #fff;
}
}
}
}
.seal{
width: 1100px;
padding: 0 5%;
display: flex;
justify-content: space-between;
.box{
border: 2px solid #e6e6e6;
width: 45%;
min-height: 300px;
border-radius: 10px;
padding: 10px;
}
.left{
display: flex;
width: 50%;
flex-wrap: wrap;
.file {
position: relative;
width: 140px;
height: 140px;
text-align: center;
background: url('../../assets/img/data-frame.png') 0 0 / cover no-repeat;
cursor: pointer;
margin: 5px 7px;
img{
width: 130px;
max-height: 90px;
}
&:last-child {
margin-right: 0;
}
&:nth-child(n>1){
margin-top: 0;
}
img {
width: 130px;
max-height: 108px;
margin: 10px auto 0;
z-index: 9;
}
p {
position: absolute;
bottom: 0;
width: 100%;
line-height: 54px;
text-align: center;
font-size: 18px;
color: #000;
}
&.checked {
background: url('../../assets/img/data-frame-checked.png') 0 0 / cover no-repeat,
url('../../assets/svg/checked.svg') 163px 7% / auto no-repeat;
p {
color: #fff;
}
}
}
&.active {
left: 0;
z-index: 9999;
}
img {
cursor: pointer;
&:last-child {
margin-right: 0;
}
}
}
.right{
margin-left: 5%;
}
.else{
width: 100%;
}
}
.dia-footer2 {
height: 70px;
line-height: 70px;
display: flex;
justify-content: flex-end;
align-items: center;
.busyButtonBox {
display: flex;
justify-content: space-between;
}
}
}
.sitting {
opacity: 0;
cursor: default!important;
}
</style>