cranefly.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354
  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. $('body').tooltip({placement: 'top', container: 'body', selector: '.tooltip-top'})
  8. $('body').tooltip({placement: 'bottom', container: 'body', selector: '.tooltip-bottom'})
  9. $('body').tooltip({placement: 'left', container: 'body', selector: '.tooltip-left'})
  10. $('body').tooltip({placement: 'right', container: 'body', selector: '.tooltip-right'})
  11. // Register popovers
  12. $('.popover-top').popover({placement: 'top'})
  13. $('.popover-bottom').popover({placement: 'bottom'})
  14. $('.popover-left').popover({placement: 'left'})
  15. $('.popover-right').popover({placement: 'right'})
  16. // Dont fire popovers on touch devices
  17. $("[class^='tooltip-']").on('show', function (e) {
  18. if ('ontouchstart' in document.documentElement) {
  19. e.preventDefault();
  20. }
  21. });
  22. // Start all dropdowns
  23. $('.dropdown-toggle').dropdown()
  24. // Dont hide clickable dropdowns
  25. $('.dropdown-clickable').on('click', function (e) {
  26. e.stopPropagation()
  27. });
  28. // Ajax Loader
  29. var ajax_loader = $('#ajax-loader');
  30. $("body").on({
  31. ajaxStart: function() {
  32. ajax_loader.fadeIn();
  33. },
  34. ajaxStop: function() {
  35. ajax_loader.fadeOut();
  36. }
  37. });
  38. // Fancy user nav activation
  39. $('#fancy-user-nav').show();
  40. // Search form extension
  41. var nav_search_form = $('#navbar-search');
  42. nav_search_form.click(function() {
  43. nav_search_form.addClass('open');
  44. });
  45. $('html').click(function() {
  46. nav_search_form.removeClass('open');
  47. });
  48. nav_search_form.click(function(event) {
  49. event.stopPropagation();
  50. });
  51. // Checkbox Group Master
  52. $('input.checkbox-master').live('click', function(){
  53. if($(this).is(':checked')){
  54. $('input.checkbox-member').attr("checked" ,"checked");
  55. }
  56. else
  57. {
  58. $('input.checkbox-member').removeAttr('checked');
  59. }
  60. });
  61. // Checkbox Group Member
  62. $('input.checkbox-member').live('click', function(){
  63. if(!$(this).is(':checked')){
  64. $('input.checkbox-master').removeAttr('checked');
  65. }
  66. });
  67. // Check Confirmation on links
  68. $('a.confirm').live('click', function(){
  69. var decision = confirm(jQuery.data(this, 'jsconfirm'));
  70. return decision
  71. });
  72. // Check Confirmation on forms
  73. $('form.confirm').live('submit', function(){
  74. data = $(this).data();
  75. var decision = confirm(data.jsconfirm);
  76. return decision
  77. });
  78. // Show go back link?
  79. if (document.referrer
  80. && document.referrer.indexOf(location.protocol + "//" + location.host) === 0
  81. && document.referrer != document.url) {
  82. $('.go-back').show();
  83. }
  84. // Go back one page
  85. $('.go-back').on('click', function (e) {
  86. history.go(-1)
  87. return false;
  88. })
  89. })
  90. function EnhancePostsMD() {
  91. $(function () {
  92. // Add labels to images
  93. $('.markdown.js-extra img').not('.emoji').each(function() {
  94. $(this).addClass('img-rounded');
  95. if ($(this).attr('alt').length > 0 && $(this).attr('alt') != $(this).attr('src')) {
  96. $(this).attr('title', $(this).attr('alt'));
  97. $(this).tooltip({placement: 'top', container: 'body'});
  98. }
  99. });
  100. // Automagically turn links into players
  101. var players = new Array();
  102. $('.markdown.js-extra').each(function() {
  103. $(this).find('a').each(function() {
  104. link2player(this, $.trim($(this).text()));
  105. });
  106. });
  107. });
  108. }
  109. // Turn link to player
  110. function link2player(element, link_href) {
  111. // Youtube link
  112. var re = /watch\?v=((\w|-)+)/;
  113. if (re.test(link_href)) {
  114. media_url = link_href.match(re);
  115. return youtube_player(element, media_url[1]);
  116. }
  117. // Youtube feature=embed
  118. var re = /watch\?feature=player_embedded&v=((\w|-)+)/;
  119. if (re.test(link_href)) {
  120. media_url = link_href.match(re);
  121. return youtube_player(element, media_url[1]);
  122. }
  123. // Youtube embed with start time
  124. var re = /youtu.be\/((\w|-)+)\?t=([A-Za-z0-9]+)/;
  125. if (re.test(link_href)) {
  126. media_url = link_href.match(re);
  127. media_minutes = media_url[2].match(/([0-9]+)m/);
  128. media_seconds = media_url[2].match(/([0-9]+)s/);
  129. media_url[2] = 0;
  130. if (media_minutes) { media_url[2] += (media_minutes[1] - 0) * 60; }
  131. if (media_seconds) { media_url[2] += (media_seconds[1] - 0); }
  132. return youtube_player(element, media_url[1], media_url[2]);
  133. }
  134. // Youtube embed
  135. var re = /youtu.be\/(([A-Za-z0-9]|_|-)+)/;
  136. if (re.test(link_href)) {
  137. media_url = link_href.match(re);
  138. return youtube_player(element, media_url[1]);
  139. }
  140. // Vimeo link
  141. var re = /vimeo.com\/([0-9]+)/;
  142. if (re.test(link_href)) {
  143. media_url = link_href.match(re);
  144. return $(element).replaceWith('<iframe src="//player.vimeo.com/video/' + media_url[1] + '?color=CF402E" width="500" height="281" frameborder="0" webkitAllowFullScreen mozallowfullscreen allowFullScreen></iframe>');
  145. }
  146. // No link
  147. return false;
  148. }
  149. // Youtube player
  150. function youtube_player(element, movie_id, startfrom) {
  151. if (typeof startfrom != 'undefined') {
  152. player_url = '//www.youtube.com/embed/' + movie_id + '?start=' + startfrom + '&amp;autoplay=1';
  153. } else {
  154. player_url = '//www.youtube.com/embed/' + movie_id + '?autoplay=1';
  155. }
  156. // Replace link with fancy image
  157. var media_element = $('<div><div class="media-border youtube-player" data-movieid="' + movie_id + '"><div class="media-thumbnail" style="background-image: url(\'//img.youtube.com/vi/' + movie_id + '/0.jpg\');"><a href="' + $.trim($(element).text()) + '" class="play-link" data-playerurl="' + player_url + '"><i class="icon-youtube-sign"></i><strong>' + l_play_media_msg + '</strong></a></div></div></div>');
  158. $(media_element).find('.play-link').click(function() {
  159. $(this).parent().replaceWith('<iframe width="853" height="480" src="' + $(this).data('playerurl') + '" frameborder="0" allowfullscreen></iframe>');
  160. return false;
  161. });
  162. $(element).replaceWith(media_element);
  163. // Fetch title, author name and thumbnail
  164. $.getJSON("//gdata.youtube.com/feeds/api/videos/" + movie_id + "?v=2&alt=json",
  165. function(data, textStatus, jqXHR) {
  166. // Movie details
  167. var movie_title = data.entry.title.$t;
  168. var movie_author = data.entry.author['0'].name.$t
  169. $(media_element).find('.play-link').addClass('movie-title');
  170. $(media_element).find('.play-link strong').text(movie_title);
  171. $(media_element).find('.play-link').append(l_play_media_author.replace('{author}', movie_author));
  172. // Movie thumbnail
  173. var thumb = {height: 90, url: '//img.youtube.com/vi/' + movie_id + '/0.jpg'};
  174. console.log(data.entry['media$group']['media$thumbnail']);
  175. $(data.entry['media$group']['media$thumbnail']).each(function(key, yt_image) {
  176. if (thumb.height < yt_image.height) {
  177. thumb = yt_image;
  178. }
  179. });
  180. $(media_element).find('.media-thumbnail').css('background-image', "url('" + thumb.url + "')");
  181. });
  182. return true;
  183. }
  184. // Ajax: Reports and Alerts
  185. $(function() {
  186. var midman = $('.midman');
  187. var animation_speed = 0;
  188. var midman_arrow = midman.find('.midman-arrow');
  189. var midman_error = midman.find('.ajax-error');
  190. var midman_content = midman.find('.loaded-content');
  191. var midman_content_id = false;
  192. var midman_cache = new Array();
  193. var midman_request = false;
  194. function midman_open(content_id) {
  195. midman_error.hide();
  196. if (midman_content_id != false) {
  197. midman_close();
  198. if (midman_request != false) {
  199. midman_request.abort();
  200. }
  201. }
  202. midman_content_id = content_id;
  203. $(midman_content_id).parent().addClass('active');
  204. var button_offset = $(midman_content_id).parent().offset();
  205. $(midman_arrow).css('left', button_offset.left + ($(midman_content_id).parent().width() / 2) - 10);
  206. if (midman_content_id in midman_cache) {
  207. midman_content.html(midman_cache[midman_content_id]);
  208. midman.show(animation_speed);
  209. return;
  210. }
  211. midman_request = $.ajax({
  212. url: $(midman_content_id).attr('href')
  213. }).done(function(data) {
  214. midman_cache[midman_content_id] = data.html;
  215. midman_content.html(data.html);
  216. midman.show(animation_speed);
  217. });
  218. }
  219. function midman_close() {
  220. if (midman_content_id != false) {
  221. $(midman_content_id).parent().removeClass('active');
  222. midman_content_id = false;
  223. midman.hide(animation_speed);
  224. }
  225. }
  226. $('.midman-close').live('click', function() {
  227. midman_close()
  228. });
  229. $('.midman form').live('submit', function() {
  230. var csrf_token = $(this).find('input[name="_csrf_token"]').val();
  231. $.post(this.action, {'_csrf_token': csrf_token}, "json").done(function(data, textStatus, jqXHR) {
  232. midman_cache[midman_content_id] = data.html;
  233. midman_content.html(data.html);
  234. });
  235. return false;
  236. });
  237. $('.nav-alerts').click(function() {
  238. this_content_id = '.nav-alerts';
  239. if (midman_content_id == this_content_id) {
  240. midman_close(this_content_id)
  241. } else {
  242. midman_open(this_content_id)
  243. }
  244. return false;
  245. });
  246. });
  247. // Ajax: Post votes
  248. $(function() {
  249. $('.post-rating-actions').each(function() {
  250. var action_parent = this;
  251. var csrf_token = $(this).find('input[name="_csrf_token"]').val();
  252. $(this).find('form').submit(function() {
  253. var form = this;
  254. $.post(this.action, {'_csrf_token': csrf_token}, "json").done(function(data, textStatus, jqXHR) {
  255. // Reset stuff and set classess
  256. $(action_parent).find('.post-score').removeClass('post-score-good post-score-bad');
  257. if (data.score_total > 0) {
  258. $(action_parent).find('.post-score-total').addClass('post-score-good');
  259. } else if (data.score_total < 0) {
  260. $(action_parent).find('.post-score-total').addClass('post-score-bad');
  261. }
  262. if (data.score_upvotes > 0) {
  263. $(action_parent).find('.post-score-upvotes').addClass('post-score-good');
  264. }
  265. if (data.score_downvotes > 0) {
  266. $(action_parent).find('.post-score-downvotes').addClass('post-score-bad');
  267. }
  268. // Set votes
  269. $(action_parent).find('.post-score-total').text(data.score_total);
  270. $(action_parent).find('.post-score-upvotes').text(data.score_upvotes);
  271. $(action_parent).find('.post-score-downvotes').text(data.score_downvotes);
  272. // Disable and enable forms
  273. if (data.user_vote == 1) {
  274. $(action_parent).find('.form-upvote button').attr("disabled", "disabled");
  275. $(action_parent).find('.form-downvote button').removeAttr("disabled");
  276. } else {
  277. $(action_parent).find('.form-upvote button').removeAttr("disabled");
  278. $(action_parent).find('.form-downvote button').attr("disabled", "disabled");
  279. }
  280. }).fail(function() {
  281. $(form).unbind();
  282. $(form).trigger('submit');
  283. });
  284. return false;
  285. });
  286. });
  287. });
  288. // Ajax: Post reports
  289. $(function() {
  290. $('.form-report').each(function() {
  291. var action_parent = this;
  292. var csrf_token = $(this).find('input[name="_csrf_token"]').val();
  293. var button = $(this).find('button');
  294. $(this).submit(function() {
  295. var form = this;
  296. $.post(form.action, {'_csrf_token': csrf_token}, "json").done(function(data, textStatus, jqXHR) {
  297. $(button).text(l_post_reported);
  298. $(button).tooltip('destroy');
  299. $(button).attr("title", data.message);
  300. $(button).tooltip({placement: 'top', container: 'body'});
  301. $(button).tooltip("show");
  302. $(button).attr("disabled", "disabled");
  303. setTimeout(function() {
  304. $(button).tooltip('hide');
  305. }, 2500);
  306. }).fail(function() {
  307. $(form).unbind();
  308. $(form).trigger('submit');
  309. });
  310. return false;
  311. });
  312. });
  313. });