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.
189 lines
6.9 KiB
189 lines
6.9 KiB
5 years ago
|
<!DOCTYPE html>
|
||
|
<html>
|
||
|
|
||
|
<head>
|
||
|
<meta charset="utf-8">
|
||
|
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
|
||
|
<title>银行卡设置</title>
|
||
|
<!--REM自适应布局JS-->
|
||
|
<script src="../../../js/base/rem-layout.js"></script>
|
||
|
<link rel="stylesheet" type="text/css" href="../../../../lib/css/mui.min.css">
|
||
|
<link href="../../../../lib/css/basic.css" rel="stylesheet" />
|
||
|
<link rel="stylesheet" type="text/css" href="../../../css/base.css" />
|
||
|
<link rel="stylesheet" type="text/css" href="../../../css/dom-flex.css" />
|
||
|
<link rel="stylesheet" type="text/css" href="../../../css/user_pay_base.css" />
|
||
|
<script src="../../../../lib/js/mui.min.js"></script>
|
||
|
<script src="../../../../lib/js/vue.js"></script>
|
||
|
<script src="../../../../lib/js/app.js"></script>
|
||
|
<script src="../../../../lib/js/jsencrypt.min.js"></script>
|
||
|
<script src="../../../js/my/my_ajax.js"></script>
|
||
|
<script src="../../../js/user/user_language.js"></script>
|
||
|
<script src="../../../js/user/user_ajax.js"></script>
|
||
|
<script src="../../../../html/wakuang/js/eth/ajax/eth.ajaxApi.js"></script>
|
||
|
</head>
|
||
|
|
||
|
<body>
|
||
|
<div id="data-info">
|
||
|
<header class="mui-bar mui-bar-nav app-header">
|
||
|
<a class="mui-action-back mui-icon mui-icon-left-nav mui-pull-left"></a>
|
||
|
<h1 class="mui-title">{{dataBase.c2cSaveUserPayYHKTitle}}</h1>
|
||
|
</header>
|
||
|
<div class="mui-content" >
|
||
|
<div id="contents">
|
||
|
<div class="app-input-group app-input-group-darkly">
|
||
|
<div class="app-input-row-list">
|
||
|
<label class="mui-text-center">{{dataBase.c2cSaveUserPayYHKbankCardNameText}}</label>
|
||
|
<input class="app-input" type="text" :placeholder="dataBase.c2cSaveUserPayYHKbankCardNamePlaceholder" v-model.trim="data.bankCardName" onkeyup="this.value = this.value.replace(/^ +| +$/g, '')">
|
||
|
</div>
|
||
|
<div class="app-input-row-list">
|
||
|
<label class="mui-text-center">{{dataBase.c2cSaveUserPayYHKbankTypeText}}</label>
|
||
|
<input class="app-input" type="text" :placeholder="dataBase.c2cSaveUserPayYHKbankTypePlaceholder" v-model.trim="data.bankType" onkeyup="this.value = this.value.replace(/^ +| +$/g, '')">
|
||
|
</div>
|
||
|
<div class="app-input-row-list">
|
||
|
<label class="mui-text-center">{{dataBase.c2cSaveUserPayYHKbankNumberText}}</label>
|
||
|
<input class="app-input" type="text" :placeholder="dataBase.c2cSaveUserPayYHKbankNumberPlaceholder" v-model.trim="data.bankNumber" onkeyup="this.value = this.value.replace(/^ +| +$/g, '')">
|
||
|
</div>
|
||
|
</div>
|
||
|
<button id="save" class="app-btn-darkly" style="margin-top: 0.6rem;">{{dataBase.c2cBtnSaveText}}</button>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div id="backdrop" class="transfer-backdrop mui-backdrop mui-active"></div>
|
||
|
<div id="footer-div-bottom" class="footer-div-bottom">
|
||
|
<div class="transfer-footer-header">
|
||
|
<a id="transfer-cancel" class="transfer-footer-left mui-icon mui-icon-closeempty mui-pull-left"></a>
|
||
|
<h1 class="transfer-footer-title">确认</h1>
|
||
|
</div>
|
||
|
<div class="transfer-password-group transfer-input-group mui-input-group">
|
||
|
<div class="transfer-password-row transfer-input-row mui-input-row">
|
||
|
<label>请输入密码</label>
|
||
|
<input value="" type="password" id="password" onkeyup="this.value = this.value.replace(/^ +| +$/g, '')">
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="transfer-next-group">
|
||
|
<input id="order_submit" type="button" value="确认">
|
||
|
</div>
|
||
|
</div>
|
||
|
</body>
|
||
|
|
||
|
</html>
|
||
|
<script type="text/javascript">
|
||
|
//数据验证
|
||
|
function verifyData() {
|
||
|
if(bodyData.data.bankCardName == "") {
|
||
|
mui.alert(dataBase.c2cSaveUserPayYHKbankCardNamePlaceholder)
|
||
|
} else if(bodyData.data.bankType == "") {
|
||
|
mui.alert(dataBase.c2cSaveUserPayYHKbankTypePlaceholder);
|
||
|
} else if(bodyData.data.bankNumber == "") {
|
||
|
mui.alert(dataBase.c2cSaveUserPayYHKbankNumberPlaceholder)
|
||
|
} else if(bodyData.data.bankNumber.length < 15 || bodyData.data.bankNumber.length > 19) {
|
||
|
mui.alert(dataBase.c2cSaveUserPayYHKbankNumberFormatError);
|
||
|
} else if(bodyData.oldData == null ||
|
||
|
bodyData.data.bankCardName != bodyData.oldData.bankCardName ||
|
||
|
bodyData.data.bankType != bodyData.oldData.bankType ||
|
||
|
bodyData.data.bankNumber != bodyData.oldData.bankNumber) {
|
||
|
return true;
|
||
|
} else {
|
||
|
mui.alert(dataBase.c2cSaveUserPayYHKError);
|
||
|
}
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 对象克隆
|
||
|
*
|
||
|
* @param {Object} obj
|
||
|
*/
|
||
|
var cloneObj = function(obj) {
|
||
|
var newObj = {};
|
||
|
if(obj instanceof Array) {
|
||
|
newObj = [];
|
||
|
}
|
||
|
for(var key in obj) {
|
||
|
var val = obj[key];
|
||
|
//newObj[key] = typeof val === 'object' ? arguments.callee(val) : val; //arguments.callee 在哪一个函数中运行,它就代表哪个函数, 一般用在匿名函数中。
|
||
|
newObj[key] = typeof val === 'object' ? cloneObj(val) : val;
|
||
|
}
|
||
|
return newObj;
|
||
|
};
|
||
|
|
||
|
var bodyData = new Vue({
|
||
|
el: '#data-info',
|
||
|
data: {
|
||
|
dataBase: dataBase, // 页面文字渲染
|
||
|
data: {
|
||
|
bankCardName: "",
|
||
|
bankType: "",
|
||
|
bankNumber: ""
|
||
|
}
|
||
|
},
|
||
|
computed: {},
|
||
|
methods: {}
|
||
|
})
|
||
|
|
||
|
// 数据请求
|
||
|
ajaxJs.ajaxUtil({
|
||
|
obj: ajaxJs.AJAX_SELECT_USERLPAY,
|
||
|
isNotMsg: true,
|
||
|
data: {
|
||
|
payType: 2
|
||
|
},
|
||
|
end: function(data) {
|
||
|
bodyData.data = data.data;
|
||
|
bodyData.oldData = cloneObj(data.data);
|
||
|
}
|
||
|
})
|
||
|
|
||
|
// 保存
|
||
|
document.getElementById("save").addEventListener("tap", function() {
|
||
|
if(verifyData()) {
|
||
|
//弹出交易密码
|
||
|
document.getElementById("backdrop").style.display = "block";
|
||
|
document.getElementById("footer-div-bottom").style.display = "block";
|
||
|
document.activeElement.blur();
|
||
|
}
|
||
|
|
||
|
});
|
||
|
</script>
|
||
|
<script type="text/javascript">
|
||
|
//交易密码,底部遮罩
|
||
|
document.getElementById("backdrop").addEventListener("tap", function() {
|
||
|
document.getElementById("backdrop").style.display = "none";
|
||
|
document.getElementById("footer-div-bottom").style.display = "none";
|
||
|
});
|
||
|
document.getElementById("transfer-cancel").addEventListener("tap", function() {
|
||
|
document.getElementById("backdrop").style.display = "none";
|
||
|
document.getElementById("footer-div-bottom").style.display = "none";
|
||
|
});
|
||
|
|
||
|
document.getElementById('order_submit').addEventListener('tap', function() {
|
||
|
plus.nativeUI.showWaiting("等待中...");
|
||
|
var _pass = document.getElementById("password").value;
|
||
|
if(_pass == "" || _pass == null) {
|
||
|
mui.alert("密码不能为空!");
|
||
|
} else {
|
||
|
ethCommonFun.getPublicKey(_pass, function(data) { // 获取公钥加密密码,生成秘钥
|
||
|
if(data.code == "200") {
|
||
|
var ajaxObj = bodyData.oldData == null ? ajaxJs.AJAX_INSERT_USERPAYYHK : ajaxJs.AJAX_UPDATE_USERPAYYHK;
|
||
|
bodyData.data.password = data.data;
|
||
|
ajaxJs.ajaxUtil({
|
||
|
obj: ajaxObj,
|
||
|
data: bodyData.data,
|
||
|
end: function(data) {
|
||
|
plus.nativeUI.closeWaiting();
|
||
|
//更新父窗口数据
|
||
|
var userPayView = plus.webview.getWebviewById("mine/html/user/pay/user_pay.html");
|
||
|
userPayView.evalJS("saveUserPayData();");
|
||
|
|
||
|
app.toast(dataBase.c2cMsgSuccess);
|
||
|
mui.back();
|
||
|
}
|
||
|
});
|
||
|
} else {
|
||
|
mui.toast(data.msg);
|
||
|
}
|
||
|
plus.nativeUI.closeWaiting();
|
||
|
})
|
||
|
}
|
||
|
})
|
||
|
</script>
|