Guest User

Untitled

a guest
Jun 18th, 2018
89
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 3.54 KB | None | 0 0
  1. (function() {
  2.  
  3. // Define widget css
  4. if (!document.getElementById('speakerrate-css')) {
  5. var speakerrateCSS = document.createElement('link');
  6. speakerrateCSS.setAttribute('rel', 'stylesheet');
  7. speakerrateCSS.setAttribute('href', '<%= root_url %>stylesheets/widget.css');
  8. speakerrateCSS.setAttribute('type', 'text/css');
  9. speakerrateCSS.setAttribute('media', 'screen');
  10. speakerrateCSS.setAttribute('id', 'speakerrate-css');
  11. document.getElementsByTagName('head')[0].appendChild(speakerrateCSS);
  12. }
  13.  
  14. // Define content for embedded widget
  15. var scriptTag = document.getElementById("speakerrate-widget-<%= @talk.id %>");
  16. var container = document.createElement("div");
  17. container.setAttribute('id', 'speakerrate-embed-<%= @talk.id %>');
  18. container.innerHTML = "<a href='javascript:void(0)' id='speakerrate-launcher-<%= @talk.id %>' class='speakerrate-launcher'>Rate Talk</a><br /><p class='speakerrate-current-rating'>Rated <% if @talk.average_rating %><%= @talk.average_rating.round(1) %><% else %>--<% end %> / 5.0 <span class='speakerrate-ratings-count'>(<%= pluralize(@talk.total_ratings, 'rating') %>)</span></p>";
  19.  
  20. // Define widget lightbox
  21. var lightBox = document.createElement('div');
  22. lightBox.setAttribute('id', 'speakerrate-lightbox-<%= @talk.id %>');
  23. lightBox.setAttribute('class', 'speakerrate-lightbox')
  24. lightBox.innerHTML = '<div id="speakerrate-wrapper-<%= @talk.id %>" class="speakerrate-wrapper"><a href="javascript:void(0)" id="speakerrate-close-<%= @talk.id %>" class="speakerrate-close"></a><iframe src="" id="speakerrate-iframe-<%= @talk.id %>" class="speakerrate-iframe" allowTransparency="true" scrolling="vertical" frameborder="0"></iframe></div><div id="speakerrate-screen-<%= @talk.id %>" class="speakerrate-screen"></div>';
  25.  
  26. // Insert loaded content
  27. container = scriptTag.parentNode.insertBefore(container, scriptTag);
  28. lightBox = scriptTag.parentNode.insertBefore(lightBox, scriptTag);
  29.  
  30. var widget = {
  31. modal: document.getElementById('speakerrate-lightbox-<%= @talk.id %>'),
  32. frame: document.getElementById('speakerrate-iframe-<%= @talk.id %>'),
  33. launcher: document.getElementById('speakerrate-launcher-<%= @talk.id %>'),
  34. container: document.getElementById('speakerrate-wrapper-<%= @talk.id %>')
  35. };
  36.  
  37. // Widget close button click
  38. document.getElementById('speakerrate-close-<%= @talk.id %>').onclick = function() {
  39. document.getElementById('speakerrate-lightbox-<%= @talk.id %>').style.display = 'none';
  40. return false;
  41. };
  42.  
  43. // Widget Launcher click
  44. widget.launcher.onclick = function() {
  45. if (widget.modal.parentNode != document.body) {
  46. widget.modal.parentNode.removeChild(widget.modal);
  47. document.body.appendChild(widget.modal);
  48. }
  49.  
  50. <% if params[:preview] %>
  51. widget.frame.setAttribute("src", "/images/widget_screenshot.png");
  52. <% else %>
  53. widget.frame.setAttribute("src", "<%= new_talk_review_url(@talk.id) %>");
  54. <% end %>
  55.  
  56. widget.container.style.top = (document.documentElement.scrollTop || document.body.scrollTop) + (150) + "px";
  57. widget.modal.style.display = "block";
  58. widget.modal.style.height = math.max(window.innerHieght, widget.modal.parentNode.offsetHeight)+'px';
  59.  
  60.  
  61. return false;
  62. };
  63.  
  64. // Monitors location of user mouse clicks
  65. document.onclick = function(e) {
  66. e = e || event;
  67. var target = e.target || e.srcElement;
  68.  
  69. do {
  70. if (widget.frame == target || widget.launcher == target) {
  71. return;
  72. }
  73. target = target.parentNode;
  74. } while(target)
  75.  
  76. widget.modal.style.display = 'none';
  77. };
  78. })();
Add Comment
Please, Sign In to add comment