cranefly.js 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  1. $(function () {
  2. // Register tooltips
  3. $('.tooltip-top').tooltip({placement: 'top', container: 'body'})
  4. $('.tooltip-bottom').tooltip({placement: 'bottom', container: 'body'})
  5. $('.tooltip-left').tooltip({placement: 'left', container: 'body'})
  6. $('.tooltip-right').tooltip({placement: 'right', container: 'body'})
  7. // Register popovers
  8. $('.popover-top').popover({placement: 'top'})
  9. $('.popover-bottom').popover({placement: 'bottom'})
  10. $('.popover-left').popover({placement: 'left'})
  11. $('.popover-right').popover({placement: 'right'})
  12. // Dont fire popovers on touch devices
  13. $("[class^='tooltip-']").on('show', function (e) {
  14. if ('ontouchstart' in document.documentElement) {
  15. e.preventDefault();
  16. }
  17. });
  18. // Start all dropdowns
  19. $('.dropdown-toggle').dropdown()
  20. // Dont hide clickable dropdowns
  21. $('.dropdown-clickable').on('click', function (e) {
  22. e.stopPropagation()
  23. });
  24. // Fancy user nav activation
  25. $('#fancy-user-nav').show();
  26. // Search form extension
  27. var nav_search_form = $('#navbar-search');
  28. nav_search_form.click(function() {
  29. nav_search_form.addClass('open');
  30. });
  31. $('html').click(function() {
  32. nav_search_form.removeClass('open');
  33. });
  34. nav_search_form.click(function(event) {
  35. event.stopPropagation();
  36. });
  37. // Checkbox Group Master
  38. $('input.checkbox-master').live('click', function(){
  39. if($(this).is(':checked')){
  40. $('input.checkbox-member').attr("checked" ,"checked");
  41. }
  42. else
  43. {
  44. $('input.checkbox-member').removeAttr('checked');
  45. }
  46. });
  47. // Checkbox Group Member
  48. $('input.checkbox-member').live('click', function(){
  49. if(!$(this).is(':checked')){
  50. $('input.checkbox-master').removeAttr('checked');
  51. }
  52. });
  53. // Check Confirmation on links
  54. $('a.confirm').live('click', function(){
  55. var decision = confirm(jQuery.data(this, 'jsconfirm'));
  56. return decision
  57. });
  58. // Check Confirmation on forms
  59. $('form.confirm').live('submit', function(){
  60. data = $(this).data();
  61. var decision = confirm(data.jsconfirm);
  62. return decision
  63. });
  64. // Show go back link?
  65. if (document.referrer
  66. && document.referrer.indexOf(location.protocol + "//" + location.host) === 0
  67. && document.referrer != document.url) {
  68. $('.go-back').show();
  69. }
  70. // Go back one page
  71. $('.go-back').on('click', function (e) {
  72. history.go(-1)
  73. return false;
  74. })
  75. })
  76. function EnhancePostsMD() {
  77. $(function () {
  78. // Add labels to images
  79. $('.markdown.js-extra img').not('.emoji').each(function() {
  80. $(this).addClass('img-rounded');
  81. if ($(this).attr('alt').length > 0 && $(this).attr('alt') != $(this).attr('src')) {
  82. $(this).attr('title', $(this).attr('alt'));
  83. $(this).tooltip({placement: 'top', container: 'body'});
  84. }
  85. });
  86. // Automagically turn links into players
  87. var players = new Array();
  88. $('.markdown.js-extra').each(function() {
  89. $(this).find('a').each(function() {
  90. link2player(this, $.trim($(this).text()));
  91. });
  92. });
  93. });
  94. }
  95. // Turn link to player
  96. function link2player(element, link_href) {
  97. // Youtube link
  98. var re = /watch\?v=((\w|-)+)/;
  99. if (re.test(link_href)) {
  100. media_url = link_href.match(re);
  101. return youtube_player(element, media_url[1]);
  102. return '<iframe width="480" height="360" src="http://www.youtube.com/embed/' + media_url[1] + '" frameborder="0" allowfullscreen></iframe>';
  103. }
  104. // Youtube feature=embed
  105. var re = /watch\?feature=player_embedded&v=((\w|-)+)/;
  106. if (re.test(link_href)) {
  107. media_url = link_href.match(re);
  108. return youtube_player(element, media_url[1]);
  109. return '<iframe width="480" height="360" src="http://www.youtube.com/embed/' + media_url[1] + '" frameborder="0" allowfullscreen></iframe>';
  110. }
  111. // Youtube embed with start time
  112. var re = /youtu.be\/((\w|-)+)\?t=([A-Za-z0-9]+)/;
  113. if (re.test(link_href)) {
  114. media_url = link_href.match(re);
  115. media_minutes = media_url[2].match(/([0-9]+)m/);
  116. media_seconds = media_url[2].match(/([0-9]+)s/);
  117. media_url[2] = 0;
  118. if (media_minutes) { media_url[2] += (media_minutes[1] - 0) * 60; }
  119. if (media_seconds) { media_url[2] += (media_seconds[1] - 0); }
  120. return youtube_player(element, media_url[1], media_url[2]);
  121. return '<iframe width="480" height="360" src="http://www.youtube.com/embed/' + media_url[1] + '?start=' + media_url[2] + '" frameborder="0" allowfullscreen></iframe>';
  122. }
  123. // Youtube embed
  124. var re = /youtu.be\/(([A-Za-z0-9]|_|-)+)/;
  125. if (re.test(link_href)) {
  126. media_url = link_href.match(re);
  127. return youtube_player(element, media_url[1]);
  128. return '<iframe width="480" height="360" src="http://www.youtube.com/embed/' + media_url[1] + '" frameborder="0" allowfullscreen></iframe>';
  129. }
  130. // Vimeo link
  131. var re = /vimeo.com\/([0-9]+)/;
  132. if (re.test(link_href)) {
  133. media_url = link_href.match(re);
  134. return $(element).replaceWith('<iframe src="http://player.vimeo.com/video/' + media_url[1] + '?color=CF402E" width="500" height="281" frameborder="0" webkitAllowFullScreen mozallowfullscreen allowFullScreen></iframe>');
  135. }
  136. // No link
  137. return false;
  138. }
  139. // Youtube player
  140. function youtube_player(element, media_url, startfrom) {
  141. if (typeof startfrom != 'undefined') {
  142. player_url = 'http://www.youtube.com/embed/' + media_url + '?start=' + startfrom + '&amp;autoplay=1';
  143. } else {
  144. player_url = 'http://www.youtube.com/embed/' + media_url + '?autoplay=1';
  145. }
  146. var media_element = $('<div class="media-border"><div class="media-thumbnail" style="background: url(\'http://img.youtube.com/vi/' + media_url + '/0.jpg\');"><a href="' + $.trim($(element).text()) + '" data-playerurl="' + player_url + '"><i class="icon-youtube-sign"></i>' + l_play_media_msg + '</a></div></div>');
  147. $(media_element).find('.media-thumbnail a').click(function() {
  148. $(this).parent().replaceWith('<iframe width="480" height="360" src="' + $(this).data('playerurl') + '" frameborder="0" allowfullscreen></iframe>');
  149. return false;
  150. });
  151. $(element).replaceWith(media_element);
  152. return true;
  153. }
  154. // Ajax: Post votes
  155. $(function() {
  156. $('.post-rating-actions').each(function() {
  157. var action_parent = this;
  158. var csrf_token = $(this).find('input[name="_csrf_token"]').val();
  159. $(this).find('form').submit(function() {
  160. var form = this;
  161. $.post(this.action, {'_csrf_token': csrf_token}, "json").done(function(data, textStatus, jqXHR) {
  162. // Reset stuff and set classess
  163. $(action_parent).find('.post-score').removeClass('post-score-good post-score-bad');
  164. if (data.score_total > 0) {
  165. $(action_parent).find('.post-score-total').addClass('post-score-good');
  166. } else if (data.score_total < 0) {
  167. $(action_parent).find('.post-score-total').addClass('post-score-bad');
  168. }
  169. if (data.score_upvotes > 0) {
  170. $(action_parent).find('.post-score-upvotes').addClass('post-score-good');
  171. }
  172. if (data.score_downvotes > 0) {
  173. $(action_parent).find('.post-score-downvotes').addClass('post-score-bad');
  174. }
  175. // Set votes
  176. $(action_parent).find('.post-score-total').text(data.score_total);
  177. $(action_parent).find('.post-score-upvotes').text(data.score_upvotes);
  178. $(action_parent).find('.post-score-downvotes').text(data.score_downvotes);
  179. // Disable and enable forms
  180. if (data.user_vote == 1) {
  181. $(action_parent).find('.form-upvote button').attr("disabled", "disabled");
  182. $(action_parent).find('.form-downvote button').removeAttr("disabled");
  183. } else {
  184. $(action_parent).find('.form-upvote button').removeAttr("disabled");
  185. $(action_parent).find('.form-downvote button').attr("disabled", "disabled");
  186. }
  187. }).fail(function() {
  188. $(form).unbind();
  189. $(form).trigger('submit');
  190. });
  191. return false;
  192. });
  193. });
  194. });
  195. // Ajax: Post reports
  196. $(function() {
  197. $('.form-report').each(function() {
  198. var action_parent = this;
  199. var csrf_token = $(this).find('input[name="_csrf_token"]').val();
  200. var button = $(this).find('button');
  201. $(this).submit(function() {
  202. var form = this;
  203. $.post(form.action, {'_csrf_token': csrf_token}, "json").done(function(data, textStatus, jqXHR) {
  204. $(button).text(l_post_reported);
  205. $(button).tooltip('destroy');
  206. $(button).attr("title", data.message);
  207. $(button).tooltip({placement: 'top', container: 'body'});
  208. $(button).tooltip("show");
  209. $(button).attr("disabled", "disabled");
  210. setTimeout(function() {
  211. $(button).tooltip('hide');
  212. }, 2500);
  213. }).fail(function() {
  214. $(form).unbind();
  215. $(form).trigger('submit');
  216. });
  217. return false;
  218. });
  219. });
  220. });