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.

1586 lines
61 KiB

<template>
<div class="wrap">
<!-- <img class="sth bg" src="" alt="" />-->
<!-- <img class="sth guide" src="@/assets/img/guide.png" alt="" /> -->
<img class="sth man cp" src="@/assets/img/man.png" alt="" @click="showData('客户签字',0)"/>
4 years ago
<img class="sth counter" src="@/assets/img/counter.png" alt="" />
<img class="sth glass" src="@/assets/img/glass.png" alt="" />
<!-- 系统录入 -->
<el-tooltip placement="top" popper-class="sth-popper">
<div slot="content">
<img style="height: 178px;position:relative;top:-450px;right:20px" src="@/assets/img/tooltip/system.png" alt="" />
</div>
4 years ago
<img @click="showManage" class="sth computer cp" src="@/assets/img/computer.png" alt="" />
</el-tooltip>
4 years ago
<el-tooltip placement="top" popper-class="sth-popper" offset="50">
<div slot="content">
4 years ago
<img src="@/assets/img/tooltip/cpl.png" alt="" />
</div>
<img class="sth summons cp" src="@/assets/img/summons.png" alt="" @click="showData('传票箱',1)" />
</el-tooltip>
4 years ago
<el-tooltip placement="top-start" popper-class="sth-popper" offset="250">
<div slot="content">
4 years ago
<img src="@/assets/img/tooltip/ptpzx.png" alt="" />
</div>
<img class="sth voucher-box cp" src="@/assets/img/voucher-box.png" alt="" @click="showData('普通凭证箱',2)" />
</el-tooltip>
4 years ago
<el-tooltip placement="top-start" popper-class="sth-popper" offset="250">
<div slot="content">
4 years ago
<img src="@/assets/img/tooltip/zk.png" alt="" />
</div>
<img class="sth important cp" src="@/assets/img/important.png" alt="" @click="showData('重要空白凭证箱',3)" />
</el-tooltip>
<el-tooltip placement="left-start" popper-class="sth-popper">
<div slot="content">
4 years ago
<img src="@/assets/img/tooltip/qx.png" alt="" />
</div>
<img class="sth money-box cp" src="@/assets/img/money-box.png" alt="" @click="showData('钱箱',4)" />
</el-tooltip>
4 years ago
<el-tooltip placement="top" popper-class="sth-popper" offset="-100">
<div slot="content">
4 years ago
<img src="@/assets/img/tooltip/yzh.png" alt="" />
</div>
<img class="sth seal-box cp" src="@/assets/img/seal-box.png" @click="showData('印章盒',5)" alt="" />
</el-tooltip>
4 years ago
<el-tooltip placement="top" popper-class="sth-popper" offset="-100">
<div slot="content">
4 years ago
<img src="@/assets/img/tooltip/ycj.png" alt="" />
</div>
<img class="sth currency-detector cp" src="@/assets/img/currency-detector.png" @click="showData('验钞机',6)" alt="" />
</el-tooltip>
4 years ago
<el-tooltip placement="top" popper-class="sth-popper" offset="-400">
<div slot="content">
4 years ago
<img src="@/assets/img/tooltip/dyj.png" alt="" />
</div>
<img class="sth printer cp" src="@/assets/img/printer.png" alt="" @click="showData('打印机',7)" />
</el-tooltip>
4 years ago
<el-tooltip placement="top" popper-class="sth-popper" offset="50">
<div slot="content">
4 years ago
<img src="@/assets/img/tooltip/mmq.png" alt="" />
</div>
<img class="sth cipher-machine cp" src="@/assets/img/cipher-machine.png" @click="showData('密码器',8)" alt="" />
</el-tooltip>
4 years ago
<img class="sth employee" src="@/assets/img/employee.png" alt="" />
<el-tooltip placement="top" popper-class="sth-popper" offset="-50">
<div slot="content">
<img src="@/assets/img/tooltip/data.png" alt="" />
</div>
<p class="employeeText" @click="showData('资料',9)">资料</p>
</el-tooltip>
4 years ago
<el-tooltip placement="top" popper-class="sth-popper" offset="00">
<div slot="content">
4 years ago
<img src="@/assets/img/tooltip/skj.png" alt="" />
</div>
<img class="sth card-machine cp" src="@/assets/img/card-machine.png" alt="" @click="showData('刷卡器',10)" />
</el-tooltip>
<el-tooltip placement="top" popper-class="sth-popper" offset="-100">
<div slot="content">
4 years ago
<img src="@/assets/img/tooltip/sfz.png" alt="" />
</div>
<img class="sth idCard-scanner cp" src="@/assets/img/idCard-scanner.png" @click="showData('身份证扫描仪',11)" alt="" />
</el-tooltip>
<!-- 物品栏 -->
<div ref="goods" class="goods-dia" :class="{ active: showGoods }">
<div :id="item.name" v-for="(item, index) in goodsShelfTotalData" :key="index" class=" justify-center" :class="{ checked: checkList.includes(item.id),file:true }" @click="dblClickFn(item,'goods')">
<img :style="item.name==='开户申请书'?'margin-top:10px;':''" :src="item.src" alt="" />
<p>{{item.name}}</p>
</div>
</div>
4 years ago
<div class="goods" :class="{ active: showGoods }" @click="toggleGoods">
<span>物品栏</span>
4 years ago
<img class="icon" src="@/assets/svg/arrow-right.svg" alt="" />
</div>
<!-- 硬件交互--弹框 -->
<div v-show="showPop" width="1120px" class="data-dia">
<div class="dia-header">
<div class="data-title">{{ popText }}</div>
<img class="close" src="@/assets/svg/close.svg" alt="" @click="closePop" />
</div>
<p v-if="popText=='密码器'" class="tips"></p>
<p v-else-if="popText=='重要空白凭证箱'||popText=='普通凭证箱'" class="tips">- 请从以下物品中选取所需材料 -</p>
<p v-else class="tips">- 请从物品栏选中或拖拽所需材料 -</p>
<div v-if="popText==='密码器'" style="width:800px;padding-right:150px;padding-top:80px">
<el-form :model="passwordForm" :rules="passwordRules" ref="form" label-width="180px">
<el-form-item label="密码" prop="password">
<el-input v-focus show-password v-model="passwordForm.password" maxlength="6" onkeyup="{this.value=this.value.replace(/\D/g,'')}" autocomplete="off"></el-input>
</el-form-item>
<el-form-item label="确认密码" prop="passwordAgain">
3 years ago
<el-input show-password v-model="passwordForm.passwordAgain" maxlength="6" onkeyup="this.value=this.value.replace(/\D/g,'')" autocomplete="off"></el-input>
</el-form-item>
</el-form>
</div>
<div v-else-if="popText==='印章盒'" class="seal" style="width:1200px;">
<div class="left">
<div v-for="(item, index) in sealArr" :key="index" :class="{ checked: sealChecked.includes(item.id),file:true }" @click="dblClickFn(item)">
<img :src="item.src" alt="" />
<p>{{item.name}}</p>
</div>
</div>
<div class="box right" ref="goods">
<!-- <div v-for="(item, index) in goods" :key="index" :class="{ checked: checkList.includes(item.id),file:true }" @click="dblClickFn(item)">-->
<!-- <img :src="item.src" alt="" />-->
<!-- <p>{{item.name}}</p>-->
<!-- </div>-->
</div>
</div>
<div v-else-if="popText==='重要空白凭证箱'" class="seal" style="width:1200px;">
<div class="left else">
<div v-for="(item, index) in importanceArr" :key="index" :class="{ checked: importantChecked.includes(item.id),file:true }" @click="dblClickFn(item)">
<img :src="item.src" alt="" />
<p>{{item.name}}</p>
</div>
</div>
</div>
<div v-else-if="popText==='普通凭证箱'" class="seal" style="width:1200px;">
<div class="left else">
<div v-for="(item, index) in commonArr" :key="index" :class="{ checked: commonChecked.includes(item.id),file:true }" @click="dblClickFn(item)">
<img :src="item.src" alt="" />
<p>{{item.name}}</p>
</div>
</div>
</div>
<!-- 暂时未确定是否公共使用一个弹框 -->
<div v-else class="list" ref="popUp"><!-- 钱箱 / 传票栏 ... 一系列可存物品弹框 -->
3 years ago
<div class="img-wrap" :class="{ checked: commonChecked.includes(item.id),'img-wrap':true }" @click='dislodgeItem(index)' v-for="(item, index) in receptionList" :key="index" v-if="receptionList.length" >
<img :src="item.src" class="file" alt="" />
<p class="text">{{item.name}}</p>
</div>
</div>
<div class="dia-footer">
<button v-throttle @click="popSure" type="button">确定</button>
</div>
</div>
<!-- 蒙版 -->
<div v-show="showPop" class="masking"></div>
<!-- 商业银行系统的全屏功能实现 -->
4 years ago
<div :class="full ? 'fullScreenSystem' : 'system'" v-if="manageVisible">
<router-view></router-view>
</div>
<el-dialog
custom-class="data-dia"
:visible.sync="showImg"
width="45%"
>
<img :src="imgSrc" class="imgPop" alt="">
</el-dialog>
</div>
</template>
<script>
4 years ago
import { mapState } from 'vuex';
import Sortable from 'sortablejs'
4 years ago
import manage from '../../manage/index';
import { addOperation, getOperation } from '@/api/http';
3 years ago
import { EventBus } from "@/utils/event-bus.js";
export default {
name: 'index',
4 years ago
components: {
manage: manage
},
data() {
var validatePass = (rule, value, callback) => {
if (value === '') {
callback(new Error('请输入密码'));
} else {
if (this.passwordForm.password&&/^[0-9]*$/.test(this.passwordForm.password)&&this.passwordForm.password.length===6) {
// this.$refs.passwordForm.validateField('password');
callback();
}else{
callback(new Error('请注意密码格式以及密码长度'))
}
}
};
var validatePass2 = (rule, value, callback) => {
if (value === '') {
callback(new Error('请再次输入密码'));
3 years ago
} else if (value.length < 6) {
callback(new Error('两次输入密码不一致!'));
} else if(value !== this.passwordForm.password){
callback(new Error('两次输入密码不一致!'));
}else{
callback();
}
};
return {
showGoods: false,
4 years ago
manageVisible: false, // 显示系统录入
checkList: [],// 物品栏选中
elseBoxCheck:[],/* 所有其他可从物品栏拖拽物品进入的弹框 */
//身份证扫描仪//审核资料//验钞机//选择重要空白凭证
auditGoodsShelf:[
{name:'身份证', src:require('@/assets/img/goods/idcard.png'), id:13},
{name:'开户申请书', src:require('@/assets/img/goods/khsqs.png'), id:14},
{name:'现金', src:require('@/assets/img/goods/cash-sm.png'), id:15},
{name:'身份证复印件', src:require('@/assets/img/idCard-copy-sm.png'), id:23},
],
//系统录入 //选择普通空白凭证
systemInputGoodsShelf:[
{name:'身份证', src:require('@/assets/img/goods/idcard.png'), id:13},
{name:'开户申请书', src:require('@/assets/img/goods/khsqs.png'), id:14},
{name:'现金', src:require('@/assets/img/goods/cash-sm.png'), id:15},
{name:'银行卡', src:require('@/assets/img/goods/bankCard.png'), id:16},
{name:'身份证复印件', src:require('@/assets/img/idCard-copy-sm.png'), id:23},
],
//打印资料 //客户签字 //印章盒
printoutGoodsShelf:[
{name:'身份证', src:require('@/assets/img/goods/idcard.png'), id:13},
{name:'开户申请书', src:require('@/assets/img/goods/khsqs.png'), id:14},
{name:'现金', src:require('@/assets/img/goods/cash-sm.png'), id:15},
{name:'银行卡', src:require('@/assets/img/goods/bankCard.png'), id:16},
{name:'存款凭条', src:require('@/assets/img/goods/ckpt.png'), id:17},
{name:'身份证复印件', src:require('@/assets/img/idCard-copy-sm.png'), id:23},
],
//钱箱
cashboxGoodsShelf:[
{name:'身份证', src:require('@/assets/img/goods/idcard.png'), id:13},
{name:'现金', src:require('@/assets/img/goods/cash-sm.png'), id:15},
{name:'身份证复印件', src:require('@/assets/img/idCard-copy-sm.png'), id:23},
],
// 总盒子里面的东西
goodsShelfTotalData:[
{name:'身份证', src:require('@/assets/img/goods/idcard.png'), id:13},
{name:'开户申请书', src:require('@/assets/img/goods/khsqs.png'), id:14},
{name:'现金', src:require('@/assets/img/goods/cash-sm.png'), id:15},
{name:'身份证复印件', src:require('@/assets/img/idCard-copy-sm.png'), id:23},
],
// goods:[/* 物品栏物品 */
// ],
popArr:[/* 弹窗展示的物品 */
{name:'银行卡',src:require('@/assets/img/goods/bankCard.png'),id:16},
{name:'定期存单',src:require('@/assets/img/seal/paid.png'),id:19},
{name:'预留印签卡',src:require('@/assets/img/seal/paid.png'),id:'预留印签卡'},
{name:'转账支票',src:require('@/assets/img/goods/xd-zzzp.png'),id:'转账支票'},
{name:'银行承兑汇票',src:require('@/assets/img/seal/paid.png'),id:30},
{name:'现金支票',src:require('@/assets/img/goods/xjzp.png'),id:'现金支票'},
// {name:'存款凭条',src:require('@/assets/img/seal/paid.png'),id:'存款凭条'},
{name:'取款凭条',src:require('@/assets/img/goods/qkpt.png'),id:'取款凭条'},
{name:'转账凭条',src:require('@/assets/img/goods/zzpt.png'),id:'转账凭条'},
{name:'业务收费凭证',src:require('@/assets/img/goods/ywsfpz.png'),id:'业务收费凭证'},
{name:'利息清单',src:require('@/assets/img/goods/lxqd.png'),id:'利息清单'},
{name:'普通空白凭证',src:require('@/assets/img/goods/ptkbpz.png'),id:'普通空白凭证'},
{name:'身份证',src:require('@/assets/img/goods/idcard.png'),id:13},
{name:'身份证复印件',src:require('@/assets/img/idCard-copy-sm.png'),id:23},
{name:'开户申请书',src:require('@/assets/img/goods/khsqs.png'),id:14},
{name:'现金',src:require('@/assets/img/goods/cash-sm.png'),id:15},
{name:'存款凭条',src:require('@/assets/img/goods/ckpt.png'),id:17},
],
receptionList:[
],
sealArr:[/* 印章盒物品 */
{name:'收讫章',src:require('@/assets/img/seal/paid.png'),id:'收讫章'},
{name:'销户章',src:require('@/assets/img/seal/closing.png'),id:'销户章'},
{name:'私章',src:require('@/assets/img/seal/personal.png'),id:'私章'},
{name:'附件章',src:require('@/assets/img/seal/accessory.png'),id:'附件章'},
{name:'付讫章',src:require('@/assets/img/seal/paid.png'),id:'付讫章'},
{name:'业务专用章',src:require('@/assets/img/seal/business.png'),id:'业务专用章'},
{name:'转讫章',src:require('@/assets/img/seal/Transfer.png'),id:'转讫章'},
],
importanceArr:[/* 重要空白凭证 */
{name:'银行卡',src:require('@/assets/img/goods/bankCard.png'),id:16},
{name:'定期存单',src:require('@/assets/img/seal/paid.png'),id:19},
{name:'预留印签卡',src:require('@/assets/img/seal/paid.png'),id:'预留印签卡'},
{name:'转账支票',src:require('@/assets/img/goods/xd-zzzp.png'),id:'转账支票'},
{name:'银行承兑汇票',src:require('@/assets/img/seal/paid.png'),id:30},
{name:'现金支票',src:require('@/assets/img/goods/xjzp.png'),id:'现金支票'},
],
commonArr:[/* 普通凭证箱 */
{name:'存款凭条',src:require('@/assets/img/seal/paid.png'),id:17},
{name:'取款凭条',src:require('@/assets/img/goods/qkpt.png'),id:'取款凭条'},
{name:'转账凭条',src:require('@/assets/img/goods/zzpt.png'),id:'转账凭条'},
{name:'业务收费凭证',src:require('@/assets/img/goods/ywsfpz.png'),id:'业务收费凭证'},
{name:'利息清单',src:require('@/assets/img/goods/lxqd.png'),id:'利息清单'},
{name:'普通空白凭证',src:require('@/assets/img/goods/ptkbpz.png'),id:'普通空白凭证'},
],
sealChecked:[],/* 印章盒选中 */
importantChecked:[],// 重要凭证选中
commonChecked:[],// 普通凭证选中
passwordForm:{
password:'',
},
passwordRules:{
password:[
{ validator: validatePass, trigger: 'blur' },
],
passwordAgain:[
{ validator: validatePass2, trigger: 'blur' },
]
},
clickNum:0,
showImg:false,
imgSrc:'',
nbm:0,
4 years ago
};
},
computed: {
full: function () {// 全屏
return this.$store.state.system.fullScreen;
},
showPop:function(){/* 展示弹框 */
this.receptionList = []
if(this.$store.state.system.popText == '刷卡器'){
3 years ago
if (this.$store.state.system.id == '62,1'){
this.nbm = 62
let param= {
parentId: '0,5,26,57,62,75'
}
getOperation(param).then((data)=> {
if (data.data.status == 200) {
var list = data.data.judgmentRuleReqs
for(var j=0;j<list.length;j++){
for(var i=0;i<this.goodsShelfTotalData.length;i++){
if(list[j].answerId == this.goodsShelfTotalData[i].id){
this.receptionList.push(this.goodsShelfTotalData[i])
}
}
}
}else{
let accountVoucher = sessionStorage.getItem('accountVoucher')
this.receptionList = JSON.parse(accountVoucher);
if(this.receptionList == null){
this.receptionList = []
}
}
}).catch((error)=>{
})
3 years ago
}else{
let dataList = JSON.parse(sessionStorage.getItem('dataList'));
if (dataList){
this.receptionList = []
for(var j=0;j<dataList.length;j++){
for(var i=0;i<this.goodsShelfTotalData.length;i++){
if(dataList[j].answerId == this.goodsShelfTotalData[i].id){
this.receptionList.push(this.goodsShelfTotalData[i])
}
}
}
}
}
}
if(this.$store.state.system.popText == '密码器'){
let accountPasswordAll = sessionStorage.getItem('accountPasswordAll');
3 years ago
if(accountPasswordAll){
this.passwordForm.password = accountPasswordAll
this.passwordForm.passwordAgain = accountPasswordAll
}
}
3 years ago
// if(!this.showGoods) this.showGoods = this.$store.state.system.showPop
// this.showGoods = this.$store.state.system.showPop
if(!this.showGoods) this.checkList = []
return this.$store.state.system.showPop;
},
popText:function(){/* 文字 */
return this.$store.state.system.popText;
},
id:function(){/* 文字 */
return this.$store.state.system.id;
},
goods:function () {/* 物品栏的物品 */
return this.$store.state.system.goods
}
},
watch: {
4 years ago
'$route.path': function (val) {
// 控制弹框显隐
let arr = val.split('/').slice(-2);
if (arr.pop() === 'manage' || arr[0] === 'manage') {
this.manageVisible = true;
} else {
this.manageVisible = false;
}
3 years ago
},
manageVisible(newVal) {
if(newVal === false) {
this.showGoods = false
}
}
},
4 years ago
created() {
let arr = this.$route.path.split('/').slice(-2);
if (arr.pop() === 'manage' || arr[0] === 'manage') {
this.manageVisible = true;
} else {
this.manageVisible = false;
}
},
mounted(){
3 years ago
// 监听EventBus事件
EventBus.$on("changeShowGoods", (judge) => {
this.showGoods = judge
});
let that = this
// 拖拽-物品栏
new Sortable(this.$refs.goods, {
animation: 150,
group: {
name:'shared',
pull:'clone',// 是否可以被移出或克隆
put:false// 禁止拖入
},
sort: false,// 禁止排序
onEnd: function (/**Event*/evt) { // 结束拖拽
// 判断拖拽的地址
if(!that.$refs.popUp) return that.$message.warning('非可拖拽的交互!')
let targetDom = that.$refs.popUp.getBoundingClientRect()
if(evt.originalEvent.pageX<targetDom.right&&evt.originalEvent.pageX>targetDom.left){
if(evt.originalEvent.pageY<targetDom.bottom&&evt.originalEvent.pageY>targetDom.top){
/* oldindex识别是拖拽了哪个文件 */
console.log(that.goodsShelfTotalData[evt.oldIndex].name,'执行拖拽2');
that.checkList.push(that.goodsShelfTotalData[evt.oldIndex].name)
let ifElse = 0;
for(var i=0;i<that.popArr.length;i++){
if (that.goodsShelfTotalData[evt.oldIndex].name == that.popArr[i].name){
if (that.receptionList == null){
that.receptionList = []
}
if (that.receptionList.length){
for(var j=0;j< that.receptionList.length;j++){
if (that.receptionList[j].name == that.goodsShelfTotalData[evt.oldIndex].name){
ifElse = ifElse+1
}
}
if(ifElse > 0){
}else{
that.receptionList.push(that.popArr[i])
}
}else{
that.receptionList.push(that.popArr[i])
}
}
}
}
}
},
});
// 拖拽-弹框
new Sortable(this.$refs.popUp, {
animation: 150,
group: {
name:'shared',
pull:'clone',// 是否可以被移出或克隆
put:false
},
sort: false,// 禁止排序
// 结束拖拽
onEnd: function (/**Event*/evt) {
// console.log(refParamBox,'目标dom',refParamBox.getBoundingClientRect());
// 判断拖拽的地址
let targetDom = that.$refs.goods.getBoundingClientRect()
if(evt.originalEvent.pageX<targetDom.right&&evt.originalEvent.pageX>targetDom.left){
if(evt.originalEvent.pageY<targetDom.bottom&&evt.originalEvent.pageY>targetDom.top){
3 years ago
console.log(evt)
// this.importanceArr[evt.oldIndex]
// this.importanceArr
alert('拉入到弹框')
}
}
},
});
},
methods: {
3 years ago
dislodgeItem(index){
this.receptionList.splice(index,1);
},
4 years ago
toggleGoods() {
this.showGoods = !this.showGoods;
},
showData(type,nbm) {/* 展示弹窗-type为弹窗标题文字 */
this.nbm = nbm
if(type == '普通凭证箱' || type == '系统'){
this.goodsShelfTotalData = this.systemInputGoodsShelf
let parentId = ''
if(type == '普通凭证箱'){
parentId = '0,3'
}
if(type == '系统'){
parentId = '0,5'
}
}else if(type == '身份证扫描仪' || type == '验钞机' || type == '资料' || type == '重要空白凭证箱'){
this.goodsShelfTotalData = this.auditGoodsShelf
let parentId = ''
if(type == '重要空白凭证箱'){
parentId = '0,2'
}
if(type == '资料'){
parentId = '0,11'
}
if(type == '验钞机'){
parentId = '0,9'
}
if(type == '身份证扫描仪'){
parentId = '0,7'
}
let param= {
parentId: parentId
}
}else if(type == '打印机' || type == '客户签字' || type == '印章盒'){
this.goodsShelfTotalData = this.printoutGoodsShelf
let parentId = ''
if(type == '打印机'){
parentId = '0,10'
}
if(type == '客户签字'){
parentId = '0,12'
}
if(type == '印章盒'){
parentId = '0,8'
}
}else if(type == '钱箱'){
this.goodsShelfTotalData = this.cashboxGoodsShelf;
let param= {
parentId: '0,1'
}
getOperation(param).then((data)=> {
if (data.data.status == 200) {
var list = data.data.judgmentRuleReqs
for(var j=0;j<list.length;j++){
for(var i=0;i<this.goodsShelfTotalData.length;i++){
if(list[j].answerId == this.goodsShelfTotalData[i].id){
this.receptionList.push(this.goodsShelfTotalData[i])
}
}
}
}else{
this.receptionList = []
}
}).catch((error)=>{
})
}
3 years ago
this.showGoods = true
this.$store.commit('system/changePop',{show:true,text:type})
},
checkData(item) {/* 选中物品 */
let _this = this
_this.clickNum++;
if (_this.clickNum === 2) {
_this.clickNum = 0;
// 处理双击事件...
_this.showImg = true
_this.imgSrc = item.src
}
setTimeout(function () {
if (_this.clickNum === 1) {
_this.clickNum = 0;
// 处理单击事件...
console.log('单击事件');
_this.checkList.includes(item.id) ? _this.checkList.splice(_this.checkList.indexOf(item.id), 1) : _this.checkList.push(item.id);
}
}, 200)
},
dblClickFn(item,val){/* 选中/预览 单/双击函数 */
console.log(item)
let that = this
this.clickNum++
if (this.clickNum === 2) { // 处理双击事件
this.clickNum = 0;
this.showImg = true
this.imgSrc = item.src
}
setTimeout(function () {
let arr
switch (that.popText) {
case '普通凭证箱': arr = that.commonChecked
break;
case '印章盒':arr = that.sealChecked
break;
case '重要空白凭证箱':arr = that.importantChecked
break;
default:
break;
}
if(val==='goods') arr = that.checkList
if (that.clickNum === 1) {// 处理单击事件
that.clickNum = 0;
if(that.popText==='印章盒'){
arr.splice(0,1,item.id)
}else if(val==='goods'&&that.popText==='印章盒'){
that.checkList.length=0
that.checkList.push(item.id)
}else{
arr.includes(item.id) ? arr.splice(arr.indexOf(item.id), 1) : arr.push(item.id);
}
}
}, 200)
},
checkSeal(id) {/* 选中印章 */
this.sealChecked.includes(id) ? this.sealChecked.splice(this.sealChecked.indexOf(id), 1) : this.sealChecked.push(id);
},
checkImportant(id){/* 选中重空凭证 */
this.importantChecked.includes(id) ? this.importantChecked.splice(this.importantChecked.indexOf(id), 1) : this.importantChecked.push(id);
},
checkCommon(item){/* 选中普通凭证 */
this.commonChecked.includes(id) ? this.commonChecked.splice(this.commonChecked.indexOf(id), 1) : this.commonChecked.push(id);
},
closePop() {// 关闭弹窗
this.receptionList = [];
3 years ago
this.showGoods = false
this.$store.commit('system/changePop',{show:false,text:''})
},
4 years ago
closeData() {
this.checkList = [];
},
showManage() {// 展示系统管理
3 years ago
this.showGoods = true
4 years ago
this.manageVisible = true;
this.$router.push('/counter/list/manage/consumerClient');
},
popSure(){/* 弹框-确定 */
/*
添加文件处理选中的文件commit到stor里提示
印章添加一个字段判断已盖章的图表
其他直接展示已处理或已完成且添加处理过的文件到物品栏
*/
let arr = []
if(this.popText==='重要空白凭证箱'||this.popText==='普通凭证箱'){
let goods,clickList
this.popText==='重要空白凭证箱'?(goods=this.importanceArr,clickList=this.importantChecked):(goods=this.commonArr ,clickList = this.commonChecked)
if(clickList.length===0) return this.$message.warning(`请选择物品后再确定!`)
// 把确定的数据传输进物品栏
goods.map(e=>{
clickList.map(el=>{
if(el===e.id){
arr.push(e)
}
})
})
this.$store.commit('system/changeGoods',{push:arr})
clickList.length = 0
}else{
if (this.$store.state.system.id == '62,1'){
this.nbm = 62
this.goodsShelfTotalData = this.auditGoodsShelf
if (this.receptionList.length >0){
sessionStorage.setItem('accountVoucher', JSON.stringify(this.receptionList))
}
3 years ago
if (this.passwordForm.passwordAgain){
let accountPassword = '';
accountPassword = this.passwordForm.passwordAgain
sessionStorage.setItem('accountPassword', accountPassword)
}
}
if (this.$store.state.system.id == '62,2'){
this.nbm = 62
this.goodsShelfTotalData = this.auditGoodsShelf
if (this.receptionList.length >0){
sessionStorage.setItem('accountVoucherTwo', JSON.stringify(this.receptionList))
}
if (this.passwordForm.passwordAgain){
let accountPasswordTwo = ''
accountPasswordTwo = this.passwordForm.passwordAgain
sessionStorage.setItem('accountPasswordTwo', accountPasswordTwo)
}
}
if (this.$store.state.system.id == '62,3'){
this.nbm = 62
this.goodsShelfTotalData = this.auditGoodsShelf
if (this.receptionList.length >0){
sessionStorage.setItem('accountVoucherThree', JSON.stringify(this.receptionList))
}
if (this.passwordForm.passwordAgain){
let accountPasswordThree = ''
accountPasswordThree = this.passwordForm.passwordAgain
sessionStorage.setItem('accountPasswordThree', accountPasswordThree)
}
}
}
this.toggleGoods()
if(this.popText == '密码器'){
if (this.nbm == 8){
let formList = []
let ruleReqs = sessionStorage.getItem('ruleReqs')
if (ruleReqs){formList = JSON.parse(ruleReqs);}else{formList = []}
for (var i=0;i<this.receptionList.length;i++){formList.push({"emptyOne": "18", "emptyTwo": this.passwordForm.passwordAgain, "operationIds": "0,282,"+this.receptionList[i].id,"type": "3"})}
sessionStorage.setItem('ruleReqs', JSON.stringify(formList))
}
if(this.passwordForm.password && this.passwordForm.passwordAgain){
if(this.passwordForm.password.length >=6 && this.passwordForm.passwordAgain.length >=6){
if(this.passwordForm.password == this.passwordForm.passwordAgain) {
this.$store.commit('system/changePop', {show: false, text: ''})
this.$message.success(`${this.popText}操作成功!`)
}
}
}else{
this.$message.error('请输入密码和确认密码');
}
}else{
if (this.receptionList.length >0){
3 years ago
let formList = []
this.$message.success(`${this.popText}操作成功!`)
if (this.nbm == 0){ //用户
}else if (this.nbm == 1){ //传票箱
let projectId = sessionStorage.getItem('projectId')
let startTime = sessionStorage.getItem('startTime')
for (var i=0;i<this.receptionList.length;i++){formList.push({"answerId":this.receptionList[i].id,"emptyOne": "", "emptyTwo": "", "operationIds": "0,4,"+this.receptionList[i].id,"type": ""})}
let params= {
parentId:'0,4',
lcJudgmentRuleReq:formList,
projectId:+projectId,
startTime:startTime,
}
addOperation(params).then((data)=>{
this.$message({
message: '提交成功',
type: 'success'
});
}).catch((error)=>{
})
}else if (this.nbm == 2){ //普通凭证箱
let projectId = sessionStorage.getItem('projectId')
let startTime = sessionStorage.getItem('startTime')
for (var i=0;i<this.receptionList.length;i++){formList.push({ "answerId":this.receptionList[i].id, "emptyOne": "", "emptyTwo": "", "operationIds": "0,3,"+this.receptionList[i].id, "type": "" })}
let params= {
parentId:'0,3',
lcJudgmentRuleReq:formList,
projectId:+projectId,
startTime:startTime,
}
addOperation(params).then((data)=>{
this.$message({
message: '提交成功',
type: 'success'
});
}).catch((error)=>{
})
}else if (this.nbm == 3){ //重要空白凭证箱
let projectId = sessionStorage.getItem('projectId')
let startTime = sessionStorage.getItem('startTime')
for (var i=0;i<this.receptionList.length;i++){formList.push({ "answerId":this.receptionList[i].id, "emptyOne": "", "emptyTwo": "", "operationIds": "0,2,"+this.receptionList[i].id, "type": "" })}
let params= {
parentId:'0,2',
lcJudgmentRuleReq:formList,
projectId:+projectId,
startTime:startTime,
}
addOperation(params).then((data)=>{
this.$message({
message: '提交成功',
type: 'success'
});
}).catch((error)=>{
})
}else if (this.nbm == 4){ //钱箱
let projectId = sessionStorage.getItem('projectId')
let startTime = sessionStorage.getItem('startTime')
let formList = [];
for (var i=0;i<this.receptionList.length;i++){formList.push({ "answerId":this.receptionList[i].id, "emptyOne": "", "emptyTwo": "", "operationIds": "0,1,"+this.receptionList[i].id, "type": "" })}
let params= {
parentId:'0,1',
lcJudgmentRuleReq:formList,
projectId:+projectId,
startTime:startTime,
}
addOperation(params).then((data)=>{
this.$message({
message: '提交成功',
type: 'success'
});
}).catch((error)=>{
})
}else if (this.nbm == 5){ //印章盒
let projectId = sessionStorage.getItem('projectId')
let startTime = sessionStorage.getItem('startTime')
for (var i=0;i<this.receptionList.length;i++){formList.push({"answerId":this.receptionList[i].id, "emptyOne": "", "emptyTwo": "", "operationIds": "0,8,"+this.receptionList[i].id,"type": ""})}
let params= {
parentId:'0,8',
lcJudgmentRuleReq:formList,
projectId:+projectId,
startTime:startTime,
}
addOperation(params).then((data)=>{
this.$message({
message: '提交成功',
type: 'success'
});
}).catch((error)=>{
})
}else if (this.nbm == 6){ //验钞机
let projectId = sessionStorage.getItem('projectId')
let startTime = sessionStorage.getItem('startTime')
for (var i=0;i<this.receptionList.length;i++){formList.push({"answerId":this.receptionList[i].id, "emptyOne": "", "emptyTwo": "", "operationIds": "0,9,"+this.receptionList[i].id,"type": ""})}
let params= {
parentId:'0,9',
lcJudgmentRuleReq:formList,
projectId:+projectId,
startTime:startTime,
}
addOperation(params).then((data)=>{
this.$message({
message: '提交成功',
type: 'success'
});
}).catch((error)=>{
})
}else if (this.nbm == 7){ //打印机
let projectId = sessionStorage.getItem('projectId')
let startTime = sessionStorage.getItem('startTime')
for (var i=0;i<this.receptionList.length;i++){formList.push({"answerId":this.receptionList[i].id, "emptyOne": "", "emptyTwo": "", "operationIds": "0,10,"+this.receptionList[i].id,"type": ""})}
let params= {
parentId:'0,10',
lcJudgmentRuleReq:formList,
projectId:+projectId,
startTime:startTime,
}
addOperation(params).then((data)=>{
this.$message({
message: '提交成功',
type: 'success'
});
}).catch((error)=>{
})
}else if (this.nbm == 9){//资料
let projectId = sessionStorage.getItem('projectId')
let startTime = sessionStorage.getItem('startTime')
for (var i=0;i<this.receptionList.length;i++){formList.push({"answerId":this.receptionList[i].id, "emptyOne": "", "emptyTwo": "", "operationIds": "0,11,"+this.receptionList[i].id,"type": ""})}
let params= {
parentId:'0,11',
lcJudgmentRuleReq:formList,
projectId:+projectId,
startTime:startTime,
}
addOperation(params).then((data)=>{
this.$message({
message: '提交成功',
type: 'success'
});
}).catch((error)=>{
})
}else if (this.nbm == 10){ //刷卡器
let projectId = sessionStorage.getItem('projectId')
let startTime = sessionStorage.getItem('startTime')
for (var i=0;i<this.receptionList.length;i++){formList.push({"answerId":this.receptionList[i].id, "emptyOne": "", "emptyTwo": "", "operationIds": "0,6,"+this.receptionList[i].id,"type": ""})}
let params= {
parentId:'0,6',
lcJudgmentRuleReq:formList,
projectId:+projectId,
startTime:startTime,
}
addOperation(params).then((data)=>{
this.$message({
message: '提交成功',
type: 'success'
});
}).catch((error)=>{
})
}else if (this.nbm == 11){ //身份证扫描仪
let projectId = sessionStorage.getItem('projectId')
let startTime = sessionStorage.getItem('startTime')
for (var i=0;i<this.receptionList.length;i++){formList.push({"answerId":this.receptionList[i].id, "emptyOne": "", "emptyTwo": "", "operationIds": "0,7,"+this.receptionList[i].id,"type": ""})}
let params= {
parentId:'0,7',
lcJudgmentRuleReq:formList,
projectId:+projectId,
startTime:startTime,
}
addOperation(params).then((data)=>{
this.$message({
message: '提交成功',
type: 'success'
});
}).catch((error)=>{
})
}else{
}
this.$store.commit('system/changePop',{show:false,text:''})
this.receptionList = [];
}else{
this.$message.error('请从物品栏中拖拽所需资料');
}
}
}
3 years ago
},
beforeDestroy() {
EventBus.$off('changeShowGoods')
}
};
</script>
<style lang="scss" scoped>
4 years ago
.wrap {
.sth {
position: absolute;
&.cp {
cursor: pointer;
}
4 years ago
}
.guide {
top: 90px;
left: 0;
width: 222px;
cursor: pointer;
&:hover {
opacity: 0.9;
}
4 years ago
}
.bg {
top: 0;
left: 0;
// width: 100%;
height: calc(100vh - 60px);
}
// 1920
@media screen and (min-width: 1920px) {
.wrap {
width: 100%;
position: relative;
//width: 100%;
height: calc(100vh - 68px);
overflow: hidden;
background:url("../../../assets/img/integrated-counter-bg.png");
}
4 years ago
.counter {
top: 116px;
left: 357px;
width: 1555px;
}
4 years ago
.glass {
top: -145px;
left: 964px;
width: 855px;
}
4 years ago
.employee {
top: 371px;
left: 920px;
width: 388px;
}
4 years ago
.employeeText {
position: absolute;
top: 503px;
left: 1229px;
color: #000;
transform: rotateZ(38deg) scale3d(1, 1, 1) skew(-19deg, -9deg);
font-size: 18px;
width: 100px;
height: 100px;
text-align: center;
line-height: 100px;
cursor: pointer;
}
4 years ago
.man {
top: 82px;
right: 150px;
width: 262px;
}
4 years ago
.money-box {
top: 406px;
left: 445px;
width: 197px;
}
4 years ago
.important {
top: 372px;
left: 582px;
width: 175px;
}
4 years ago
.voucher-box {
top: 216px;
left: 718px;
width: 160px;
}
4 years ago
.summons {
top: 250px;
left: 844px;
width: 139px;
}
4 years ago
.computer {
top: 120px;
left: 955px;
width: 219px;
}
4 years ago
.card-machine {
top: 377px;
left: 1147px;
width: 110px;
}
4 years ago
.idCard-scanner {
top: 443px;
left: 1229px;
width: 82px;
}
4 years ago
.seal-box {
top: 486px;
left: 1340px;
width: 97px;
}
4 years ago
.currency-detector {
top: 492px;
left: 1421px;
width: 151px;
}
4 years ago
.printer {
top: 550px;
left: 1531px;
width: 205px;
}
4 years ago
.cipher-machine {
top: 324px;
left: 1298px;
width: 100px;
}
4 years ago
.el-tooltip__popper.sth-popper {
padding: 0;
// background-color: transparent;
background-color: #fff;
img {
height: 78px;
}
4 years ago
.popper__arrow {
display: none;
}
}
4 years ago
}
// 1440-1550
@media screen and (max-width: 1550px) {
.wrap {
width: 1550px;
position: relative;
//width: 100%;
height: calc(100vh - 68px);
overflow: hidden;
background:url("../../../assets/img/integrated-counter-bg.png");
}
4 years ago
.counter {
top: 35%;
left: 10%;
height: 61vh;
}
.glass {
// 玻璃窗
top: 185px;
left: 716px;
width: 690px;
}
.employee {
// 柜员
// top: 57%;
// left: 42%;
// width: 23%;
top: 617px;
left: 610px;
width: 333px;
position: relative;
}
.employeeText {
// 资料文字
position: absolute;
top: 746px;
left: 925px;
color: #000;
transform: rotateZ(38deg) scale3d(1, 1, 1) skew(-19deg, -9deg);
font-size: 18px;
width: 100px;
height: 100px;
cursor: pointer
4 years ago
}
.man {
// 人
top: 278px;
left: 1075px;
width: 267px;
}
.money-box {
// 钱箱
top: 637px;
left: 195px;
width: 164px;
}
.important {
// 重空箱
top: 621px;
left: 314px;
width: 149px;
}
.voucher-box {
// 普通箱
top: 482px;
left: 434px;
width: 134px;
}
.summons {
// 传票栏
top: 500px;
left: 548px;
width: 112px;
}
.computer {
top: 395px;
left: 652px;
width: 170px;
}
.card-machine {
top: 596px;
left: 800px;
width: 100px;
}
.idCard-scanner {
top: 656px;
left: 861px;
width: 100px;
}
.seal-box {
top: 680px;
left: 966px;
width: 86px;
}
.currency-detector {
top: 693px;
left: 1035px;
width: 142px;
}
.printer {
top: 758px;
left: 1162px;
width: 187px;
}
.cipher-machine {
top: 551px;
left: 977px;
width: 122px;
}
}
4 years ago
// 1550-1919
@media screen and (min-width: 1550px) and (max-width: 1919px) {
.wrap{
width: 1550px;
position: relative;
//width: 100%;
height: calc(100vh - 68px);
overflow: hidden;
background:url("../../../assets/img/integrated-counter-bg.png");
}
4 years ago
.counter {
top: 30%;
4 years ago
left: 8%;
height: 63vh;
}
4 years ago
.glass {
// 玻璃窗
top: 135px;
left: 514px;
width: 507px;
4 years ago
}
.employee {
// 柜员
// top: 57%;
// left: 42%;
// width: 23%;
top: 374px;
left: 400px;
width: 283px;
4 years ago
position: relative;
}
.employeeText {
// 资料文字
position: absolute;
top: 482px;
left: 655px;
color: #000;
4 years ago
transform: rotateZ(38deg) scale3d(1, 1, 1) skew(-19deg, -9deg);
font-size: 18px;
width: 100px;
text-align: center;
height: 100px;
line-height: 100px;
cursor: pointer
}
4 years ago
.man {
// 人
top: 191px;
left: 846px;
width: 199px;
4 years ago
}
.money-box {
// 钱箱
top: 436px;
left: 170px;
width: 129px;
4 years ago
}
.important {
// 重空箱
top: 434px;
left: 241px;
width: 118px;
4 years ago
}
.voucher-box {
// 普通箱
top: 327px;
left: 327px;
width: 112px;
4 years ago
}
.summons {
// 传票栏
top: 341px;
left: 389px;
4 years ago
width: 112px;
}
.computer {
top: 257px;
left: 504px;
width: 148px;
4 years ago
}
.card-machine {
top: 434px;
left: 624px;
width: 66px;
}
4 years ago
.idCard-scanner {
top: 472px;
left: 666px;
width: 46px;
4 years ago
}
.seal-box {
top: 500px;
left: 742px;
width: 50px;
4 years ago
}
.currency-detector {
top: 478px;
left: 772px;
width: 117px;
4 years ago
}
.printer {
top: 519px;
left: 844px;
width: 149px;
4 years ago
}
.cipher-machine {
top: 391px;
left: 711px;
width: 79px;
4 years ago
}
}
.goods {
position: fixed;
bottom: 0;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
width: 94px;
height: 200px;
cursor: pointer;
z-index: 998;
4 years ago
background: url(../../../assets/img/sth-bg.png) 0 0 / cover no-repeat;
span {
width: 30px;
margin-bottom: 10px;
color: #fff;
font-size: 30px;
text-align: center;
4 years ago
}
.icon {
width: 30px;
transition: all 0.5s;
}
&:hover {
opacity: 0.9;
}
&.active {
3 years ago
4 years ago
.icon {
transform: rotate(180deg);
3 years ago
4 years ago
}
}
}
.goods-dia {
display: flex;
justify-content: center;
width: 100%;
white-space: nowrap;
overflow-x: auto;
4 years ago
position: fixed;
bottom: 0;
left: -100%;
padding: 20px 300px 20px 300px;
4 years ago
transition: all 0.5s;
background-color: rgba(255, 255, 255, 0.7);
.file {
position: relative;
min-width: 160px;
height: 160px;
text-align: center;
background: url(../../../assets/img/data-frame.png) 0 0 / cover no-repeat;
cursor: pointer;
margin: 0 10px;
img {
width: 99px;
max-height: 105px;
4 years ago
margin: auto;
margin-top: 40px;
}
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) 165px 7% / auto no-repeat;
p {
color: #fff;
}
}
}
4 years ago
&.active {
left: 0;
z-index: 998;
4 years ago
}
img {
cursor: pointer;
4 years ago
&:last-child {
margin-right: 0;
}
}
}
}
.imgPop{
width: 100%;
}
.masking{
position: fixed;
top: 0;
left: 0;
bottom: 0;
right: 0;
opacity: .5;
background: #e6e6e6;
z-index: 99;
4 years ago
}
.data-dia {
4 years ago
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: 72px;
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;
}
}
4 years ago
.tips {
margin: 20px 0 50px;
4 years ago
text-align: center;
font-size: 20px;
color: #000;
}
4 years ago
.list {
width: 940px;
min-height: 204px;
max-height: 360px;
overflow: auto;
4 years ago
margin: 0 auto;
display: flex;
align-items: center;
.img-wrap{
4 years ago
background: url(../../../assets/img/data-frame.png) 0 0 / cover no-repeat;
width: 200px;
height: 200px;
display: flex;
justify-content: center;
margin: 5px 10px;
position: relative;
4 years ago
cursor: pointer;
.file {
position: relative;
max-width: 180px;
max-height: 140px;
4 years ago
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{
4 years ago
font-size: 18px;
white-space:nowrap;
position: absolute;
bottom: 15px;
left: 50%;
transform: translate(-50%,0);
4 years ago
}
&.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: 164px;
height: 164px;
text-align: center;
background: url(../../../assets/img/data-frame.png) 0 0 / cover no-repeat;
cursor: pointer;
margin: 5px 7px;
&: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%;
}
}
4 years ago
.dia-footer {
margin-top: 140px;
text-align: center;
button {
width: 300px;
line-height: 60px;
color: #fff;
font-size: 24px;
background-color: rgb(81, 147, 255);
border: 0;
border-radius: 20px;
cursor: pointer;
&:hover {
opacity: 0.9;
}
}
}
4 years ago
}
.system {
margin-top: -8vh;
position: absolute;
top: 12%;
left: 50%;
z-index: 9;
transform: translate(-50%, 0);
width: 1280px;
}
.fullScreenSystem {
width: 100vw;
margin-top: 0;
position: absolute;
top: 0%;
left: 50%;
z-index: 9;
transform: translate(-50%, 0);
}
/deep/ .view .el-dialog__body {
padding: 0 !important;
}
</style>