我在Meteor应用程序中使用Braintree DropIn付款窗体。它工作正常创建窗体并能够创建一个事务。但是,当我提交表单时,它会显示新的屏幕,显示当前的付款方式以及更新它的链接。一旦服务器返回呼叫,我的自定义确认页面显示。Braintree DropIn窗体显示变化付款方式
所以工作流程顺序为:
1.脱入支付从(信用卡,EXP DT,CVV,..)
2.单击提交按钮
3. onPaymentMethodReceived:设置的部分称为
尽管尚未完成 4.将显示一个新的临时屏幕(选项更改pymt方法)
5. onPaymentMethodReceived:部分完成和自定义支付确认屏幕取代了以前的屏幕
我怎样才能摆脱此更新付款方式屏幕。
下面是代码:
`Template.billPay.onRendered(function() {
console.log('Satrt billPay Render');
Meteor.call('getClientToken', function(error, clientToken) {
if (error) {
console.log('Client Token Err');
console.log(error);
} else {
braintree.setup(clientToken, "dropin", {
container: "payment-form",
onPaymentMethodReceived: function (response) {
var nonce = response.nonce;
Session.set('pymtResponse',response.details);
Session.set('nonce',nonce);
$('.paySubmit').prop('disabled', true);
Meteor.call('btCreateCustomer', function(error, success) {
if (error) {
throw new Meteor.Error('customer-creation-failed');
} else {
Meteor.call('createTransaction', Session.get('nonce'), function(error, success) {
Session.set('pymtTxId', success.transaction.id);
Session.set('pymtTxId', success.transaction.id);
}
});
}
});
return false;
}
});
}
});
});`
您会添加生成客户端令牌的服务器端代码吗? – ThinkAboutIt
这里是生成服务器代码的令牌:
'Meteor.methods({ getClientToken:函数(的clientId){ VAR的generateToken = Meteor.wrapAsync(gateway.clientToken.generate,gateway.clientToken); VAR选项= { }; 变种BTID = Meteor.user()custBtId; 的console.log( 'genToken BTID' + BTID); // = options.customerId BTID; 尝试{ 变种响应=的generateToken(选项); // console.log('client token'+ response.clientToken); return response.clientToken; } catch(err){console.log(err.message); return err} } })' –