mc.js 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. var findEventHandlers = function (eventType, jqSelector) {
  2. var results = [];
  3. var $ = jQuery;// to avoid conflict between others frameworks like Mootools
  4. var arrayIntersection = function (array1, array2) {
  5. return $(array1).filter(function (index, element) {
  6. return $.inArray(element, $(array2)) !== -1;
  7. });
  8. };
  9. var haveCommonElements = function (array1, array2) {
  10. return arrayIntersection(array1, array2).length !== 0;
  11. };
  12. var addEventHandlerInfo = function (element, event, $elementsCovered) {
  13. var extendedEvent = event;
  14. if ($elementsCovered !== void 0 && $elementsCovered !== null) {
  15. $.extend(extendedEvent, { targets: $elementsCovered.toArray() });
  16. }
  17. var eventInfo;
  18. var eventsInfo = $.grep(results, function (evInfo, index) {
  19. return element === evInfo.element;
  20. });
  21. if (eventsInfo.length === 0) {
  22. eventInfo = {
  23. element: element,
  24. events: [extendedEvent]
  25. };
  26. results.push(eventInfo);
  27. } else {
  28. eventInfo = eventsInfo[0];
  29. eventInfo.events.push(extendedEvent);
  30. }
  31. };
  32. var $elementsToWatch = $(jqSelector);
  33. if (jqSelector === "*")//* does not include document and we might be interested in handlers registered there
  34. $elementsToWatch = $elementsToWatch.add(document);
  35. var $allElements = $("*").add(document);
  36. $.each($allElements, function (elementIndex, element) {
  37. var allElementEvents = $._data(element, "events");
  38. if (allElementEvents !== void 0 && allElementEvents[eventType] !== void 0) {
  39. var eventContainer = allElementEvents[eventType];
  40. $.each(eventContainer, function(eventIndex, event){
  41. var isDelegateEvent = event.selector !== void 0 && event.selector !== null;
  42. var $elementsCovered;
  43. if (isDelegateEvent) {
  44. $elementsCovered = $(event.selector, element); //only look at children of the element, since those are the only ones the handler covers
  45. } else {
  46. $elementsCovered = $(element); //just itself
  47. }
  48. if (haveCommonElements($elementsCovered, $elementsToWatch)) {
  49. addEventHandlerInfo(element, event, $elementsCovered);
  50. }
  51. });
  52. }
  53. });
  54. return results;
  55. };
  56. window.top.addEventListener('popstate', function(event) {
  57. if(!!event.state) window.location = event.state;
  58. });
  59. $(document).ready(function() {
  60. window.top.history.replaceState(window.location.pathname, null, '/mc' + window.location.pathname);
  61. $(document).on('click', '.stag_rhs_toggle', function() {
  62. var state = window.top.toggleRHS(), icon = $(this).find('i');
  63. if(state === 'collapsed') {
  64. icon.removeClass().addClass('fa fa-arrow-left');
  65. }
  66. else {
  67. icon.removeClass().addClass('fa fa-arrow-right');
  68. }
  69. });
  70. var body = $(window.top.document.body), icon = $('.stag_rhs_toggle i');
  71. if(body.is('.stag_rhs_collapsed')) {
  72. icon.removeClass().addClass('fa fa-arrow-left');
  73. }
  74. initFastLoad();
  75. });
  76. function initFastLoad(_parent = false) {
  77. var allAs = $('a:not([onclick]):not([href="#"]):visible');
  78. if(_parent) {
  79. allAs = _parent.find('a:not([onclick]):not([href="#"]):visible');
  80. }
  81. // find links without event handlers
  82. allAs.each(function() {
  83. if(!$(this).closest('[moe]').length) {
  84. var handlers = findEventHandlers('click', this);
  85. if(!handlers || !handlers.length) {
  86. enableFastLoad(this);
  87. }
  88. }
  89. });
  90. function enableFastLoad(_a) {
  91. var targetParent = $('.stag-content');
  92. $(_a).on('click', function() {
  93. $.get(_a.href, function(_data) {
  94. _data = '<div>' + _data + '</div>';
  95. var content = $(_data).find('.stag-content');
  96. if(content) {
  97. content = content.html();
  98. content += '<script src="/js/yemi.js"></script>';
  99. targetParent.html(content);
  100. initFastLoad(targetParent);
  101. // push state
  102. var target = _a.href;
  103. if(target.indexOf('//') !== -1) {
  104. target = target.split('//')[1];
  105. if(target.indexOf('/') !== -1) {
  106. target = target.substr(target.indexOf('/') + 1);
  107. }
  108. }
  109. window.top.history.pushState(target, null, '/mc/' + target);
  110. }
  111. else {
  112. console.warn('Target page not found: ' + this.href);
  113. }
  114. });
  115. return false;
  116. });
  117. console.info('FastLoad enabled for ' + _a.innerText + ' [' + _a.href + ']');
  118. }
  119. }
  120. function openInRHS(_url) {
  121. window.top.showRHS();
  122. var icon = $('.stag_rhs_toggle i');
  123. icon.removeClass().addClass('fa fa-arrow-right');
  124. window.top.openInRHS(_url);
  125. return false;
  126. }