2017-02-21 18:21:42 -05:00
|
|
|
import { ajax } from 'discourse/lib/ajax';
|
2017-02-27 20:39:07 -05:00
|
|
|
import { getRegister } from 'discourse-common/lib/get-owner';
|
2017-02-21 18:21:42 -05:00
|
|
|
|
2017-02-20 18:25:31 -05:00
|
|
|
export default Ember.Component.extend({
|
2017-02-27 20:39:07 -05:00
|
|
|
donateAmounts: [1, 5, 10, 25],
|
2017-02-22 17:30:40 -05:00
|
|
|
result: null,
|
2017-02-22 20:48:06 -05:00
|
|
|
amount: null,
|
2017-02-27 20:39:07 -05:00
|
|
|
stripe: null,
|
2017-03-05 19:12:22 -05:00
|
|
|
transactionInProgress: null,
|
2017-02-26 22:22:52 -05:00
|
|
|
|
2017-02-27 20:39:07 -05:00
|
|
|
init() {
|
|
|
|
this._super();
|
|
|
|
var public_key = getRegister(this).lookup('site-settings:main').discourse_donations_public_key
|
|
|
|
this.set('stripe', Stripe(public_key));
|
|
|
|
},
|
2017-02-21 18:21:42 -05:00
|
|
|
|
2017-02-20 18:25:31 -05:00
|
|
|
card: function() {
|
|
|
|
var elements = this.get('stripe').elements();
|
|
|
|
return elements.create('card', { hidePostalCode: true });
|
|
|
|
}.property('stripe'),
|
|
|
|
|
|
|
|
didInsertElement() {
|
2017-02-22 17:30:40 -05:00
|
|
|
this._super();
|
2017-02-21 18:21:42 -05:00
|
|
|
this.get('card').mount('#card-element');
|
2017-02-20 18:25:31 -05:00
|
|
|
},
|
|
|
|
|
|
|
|
actions: {
|
|
|
|
submitStripeCard() {
|
2017-02-22 17:30:40 -05:00
|
|
|
var self = this;
|
|
|
|
|
2017-03-05 20:34:03 -05:00
|
|
|
this.get('stripe').createToken(this.get('card')).then(data => {
|
2017-02-22 17:30:40 -05:00
|
|
|
|
|
|
|
self.set('result', null);
|
|
|
|
|
2017-03-05 20:34:03 -05:00
|
|
|
if (data.error) {
|
|
|
|
self.set('result', data.error.message);
|
2017-02-20 18:25:31 -05:00
|
|
|
}
|
|
|
|
else {
|
2017-03-05 19:12:22 -05:00
|
|
|
self.set('transactionInProgress', true);
|
|
|
|
|
2017-02-22 17:30:40 -05:00
|
|
|
var params = {
|
2017-03-05 20:34:03 -05:00
|
|
|
stripeToken: data.token.id,
|
2017-02-22 20:48:06 -05:00
|
|
|
amount: self.get('amount') * 100
|
2017-02-21 18:21:42 -05:00
|
|
|
};
|
|
|
|
|
2017-02-22 17:30:40 -05:00
|
|
|
ajax('/charges', { data: params, method: 'post' }).then(data => {
|
2017-03-05 19:12:22 -05:00
|
|
|
self.set('transactionInProgress', false);
|
2017-03-05 20:34:03 -05:00
|
|
|
self.set('result', data.outcome.seller_message);
|
2017-02-21 18:21:42 -05:00
|
|
|
});
|
2017-02-20 18:25:31 -05:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|