Lungo.Boot.Events.js 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. /**
  2. * Initialize the automatic DOM UI events
  3. *
  4. * @namespace Lungo.Boot
  5. * @class Events
  6. *
  7. * @author Javier Jimenez Villar <javi@tapquo.com> || @soyjavi
  8. * @author Guillermo Pascual <pasku@tapquo.com> || @pasku1
  9. */
  10. Lungo.Boot.Events = (function(lng, undefined) {
  11. var ATTRIBUTE = lng.Constants.ATTRIBUTE;
  12. var CLASS = lng.Constants.CLASS;
  13. var ELEMENT = lng.Constants.ELEMENT;
  14. var SELECTORS = {
  15. DOCUMENT: document,
  16. WINDOW: window,
  17. HREF_TARGET: 'a[href][data-router]',
  18. HREF_TARGET_FROM_ASIDE: 'aside a[href][data-router]',
  19. CURRENT_SECTION: 'section.aside, section.current'
  20. };
  21. /**
  22. * Initializes the automatic subscription events by markup of the project.
  23. *
  24. * @method init
  25. *
  26. */
  27. var init = function() {
  28. var touch_move_event = 'touchmove';
  29. var resize = 'resize';
  30. lng.dom(SELECTORS.WINDOW).on(resize, _changeOrientation);
  31. lng.dom(SELECTORS.HREF_TARGET).tap(_loadTarget);
  32. lng.dom(SELECTORS.HREF_TARGET_FROM_ASIDE).tap(_hideAsideIfNecesary);
  33. };
  34. var _changeOrientation = function(event) {
  35. event.preventDefault();
  36. lng.View.Resize.toolbars();
  37. };
  38. var _loadTarget = function(event) {
  39. event.preventDefault();
  40. var link = lng.dom(this);
  41. _selectTarget(link);
  42. };
  43. var _hideAsideIfNecesary = function(event) {
  44. //@TODO: refactor
  45. if (window.innerWidth < 768) lng.View.Aside.hide();
  46. if (event) event.preventDefault();
  47. };
  48. var _selectTarget = function(link) {
  49. var target_type = link.data(ATTRIBUTE.ROUTER);
  50. switch(target_type) {
  51. case ELEMENT.SECTION:
  52. var target_id = link.attr(ATTRIBUTE.HREF);
  53. _goSection(target_id);
  54. break;
  55. case ELEMENT.ARTICLE:
  56. _goArticle(link);
  57. break;
  58. case ELEMENT.ASIDE:
  59. _goAside(link);
  60. break;
  61. }
  62. };
  63. var _goSection = function(id) {
  64. _hideAsideIfNecesary();
  65. id = lng.Core.parseUrl(id);
  66. if (id === '#back') {
  67. lng.Router.back();
  68. } else {
  69. var aside = lng.Element.Current.aside;
  70. if (aside && aside.hasClass(CLASS.SHOW)) {
  71. setTimeout(function(){
  72. lng.Router.section(id);
  73. }, 250);
  74. } else {
  75. lng.Router.section(id);
  76. }
  77. }
  78. };
  79. var _goArticle = function(element) {
  80. var section_id = lng.Router.History.current();
  81. var article_id = element.attr(ATTRIBUTE.HREF);
  82. lng.Router.article(section_id, article_id, element);
  83. };
  84. var _goAside = function(element) {
  85. var section_id = lng.Router.History.current();
  86. var aside_id = element.attr(ATTRIBUTE.HREF);
  87. lng.Router.aside(section_id, aside_id);
  88. };
  89. return {
  90. init: init
  91. };
  92. })(Lungo);