subscribe_widget.js 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. 'use strict';
  2. var subscribe_data = JSON.parse(document.getElementById('subscribe_data').textContent);
  3. var payload = 'csrf_token=' + subscribe_data.csrf_token;
  4. var subscribe_button = document.getElementById('subscribe');
  5. subscribe_button.parentNode.action = 'javascript:void(0)';
  6. if (subscribe_button.getAttribute('data-type') === 'subscribe') {
  7. subscribe_button.onclick = subscribe;
  8. } else {
  9. subscribe_button.onclick = unsubscribe;
  10. }
  11. function subscribe() {
  12. var fallback = subscribe_button.innerHTML;
  13. subscribe_button.onclick = unsubscribe;
  14. subscribe_button.innerHTML = '<b>' + subscribe_data.unsubscribe_text + ' | ' + subscribe_data.sub_count_text + '</b>';
  15. var url = '/subscription_ajax?action=create_subscription_to_channel&redirect=false' +
  16. '&c=' + subscribe_data.ucid;
  17. helpers.xhr('POST', url, {payload: payload, retries: 5, entity_name: 'subscribe request'}, {
  18. onNon200: function (xhr) {
  19. subscribe_button.onclick = subscribe;
  20. subscribe_button.innerHTML = fallback;
  21. }
  22. });
  23. }
  24. function unsubscribe() {
  25. var fallback = subscribe_button.innerHTML;
  26. subscribe_button.onclick = subscribe;
  27. subscribe_button.innerHTML = '<b>' + subscribe_data.subscribe_text + ' | ' + subscribe_data.sub_count_text + '</b>';
  28. var url = '/subscription_ajax?action=remove_subscriptions&redirect=false' +
  29. '&c=' + subscribe_data.ucid;
  30. helpers.xhr('POST', url, {payload: payload, retries: 5, entity_name: 'unsubscribe request'}, {
  31. onNon200: function (xhr) {
  32. subscribe_button.onclick = unsubscribe;
  33. subscribe_button.innerHTML = fallback;
  34. }
  35. });
  36. }