Merge pull request #6 from chrisbeach/post_donate_button_fix

Move script to jquery insertion on render
This commit is contained in:
Chris Beach 2017-11-27 08:15:44 +00:00 committed by GitHub
commit a16fdf57ef
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 45 additions and 20 deletions

View File

@ -0,0 +1,29 @@
import { withPluginApi } from 'discourse/lib/plugin-api';
export default {
name: 'donations-edits',
initialize() {
withPluginApi('0.8.12', api => {
api.decorateCooked($post => {
const $form = $post.find('.stripe-checkout');
if ($form.length) {
const $input = $form.find('input');
const settings = Discourse.SiteSettings;
var s = document.createElement('script');
s.src = 'https://checkout.stripe.com/checkout.js';
s.setAttribute('class', 'stripe-button');
s.setAttribute('data-key', settings.discourse_donations_public_key);
s.setAttribute('data-amount', $input.attr('amount'));
s.setAttribute('data-name', settings.discourse_donations_shop_name);
s.setAttribute('data-description', $form.attr('content'));
s.setAttribute('data-image', $form.attr('image') || '');
s.setAttribute('data-locale', 'auto');
s.setAttribute('data-zip-code', settings.discourse_donations_zip_code);
s.setAttribute('data-billing-address', settings.discourse_donations_billing_address);
s.setAttribute('data-currency', settings.discourse_donations_currency);
$form.append(s);
}
});
});
}
};

View File

@ -16,7 +16,7 @@ function replaceWithStripeOrError(siteSettings) {
if (errors.length) { if (errors.length) {
displayErrors(state, errors); displayErrors(state, errors);
} else { } else {
insertCheckout(state, tagInfo, content, siteSettings); insertCheckout(state, tagInfo, content);
} }
return true; return true;
}; };
@ -30,29 +30,22 @@ function displayErrors(state, errors) {
state.push('div-close', 'div', -1); state.push('div-close', 'div', -1);
} }
function insertCheckout(state, tagInfo, content, siteSettings) { function insertCheckout(state, tagInfo, content) {
let token = state.push('stripe-checkout-form-open', 'form', 1); let token = state.push('stripe-checkout-form-open', 'form', 1);
token.attrs = [['method', 'POST'], ['action', '/checkout']];
token = state.push('stripe-checkout-form-amount', 'input', 0);
token.attrs = [['type', 'hidden'], ['name', 'amount'], ['value', tagInfo.attrs['amount']]];
token = state.push('stripe-checkout-script-open', 'script', 0);
token.attrs = [ token.attrs = [
['src', 'https://checkout.stripe.com/checkout.js'], ['method', 'POST'],
['class', 'stripe-button'], ['action', '/checkout'],
['data-key', siteSettings.discourse_donations_public_key], ['content', content],
['data-amount', tagInfo.attrs['amount']], ['image', tagInfo.attrs['image']],
['data-name', siteSettings.discourse_donations_shop_name], ['class', 'stripe-checkout']
['data-description', content],
['data-image', tagInfo.attrs['image'] || ''],
['data-locale', 'auto'],
['data-zip-code', siteSettings.discourse_donations_zip_code],
['data-billing-address', siteSettings.discourse_donations_billing_address],
['data-currency', siteSettings.discourse_donations_currency]
]; ];
state.push('stripe-checkout-script-close', 'script', -1); token = state.push('stripe-checkout-form-amount', 'input', 0);
token.attrs = [
['type', 'hidden'],
['name', 'amount'],
['value', tagInfo.attrs['amount']]
];
state.push('stripe-checkout-form-close', 'form', -1); state.push('stripe-checkout-form-close', 'form', -1);
} }
@ -72,6 +65,9 @@ export function setup(helper) {
'div[class]', 'div[class]',
'form[method]', 'form[method]',
'form[action]', 'form[action]',
'form[class]',
'form[content]',
'form[image]',
'input[type]', 'input[type]',
'input[name]', 'input[name]',
'input[value]', 'input[value]',