Lungo.Boot.Events.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  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. HREF_TARGET: 'a[href][data-target]',
  16. HREF_TARGET_FROM_ASIDE: 'aside a[href][data-target]'
  17. };
  18. /**
  19. * Initializes the automatic subscription events by markup of the project.
  20. *
  21. * @method init
  22. *
  23. */
  24. var start = function() {
  25. var touch_move_event = 'touchmove';
  26. var resize = 'resize';
  27. console.error(SELECTORS);
  28. //@ToDo: Error with input type="range"
  29. //lng.dom(document).on(touch_move_event, _iScroll);
  30. lng.dom(window).on(resize, _changeOrientation);
  31. lng.dom(SELECTORS.HREF_TARGET_FROM_ASIDE).tap(_loadTargetFromAside);
  32. lng.dom(SELECTORS.HREF_TARGET).tap(_loadTarget);
  33. lng.Fallback.androidButtons();
  34. };
  35. var _iScroll = function(event) {
  36. event.preventDefault();
  37. };
  38. var _changeOrientation = function(event) {
  39. lng.View.Resize.toolbars();
  40. };
  41. var _loadTargetFromAside = function(event) {
  42. var link = lng.dom(this);
  43. var aside_id = '#' + link.parent(ELEMENT.ASIDE).attr(ATTRIBUTE.ID);
  44. var section_id = '#' + lng.dom('section.aside, section.current').first().attr(ATTRIBUTE.ID);
  45. if (link.data(ATTRIBUTE.TARGET) === ELEMENT.ARTICLE) {
  46. lng.dom(ELEMENT.ASIDE + aside_id + ' ' + SELECTORS.HREF_TARGET).removeClass(CLASS.CURRENT);
  47. link.addClass(CLASS.CURRENT);
  48. }
  49. _hideAsideIfNecesary(section_id, aside_id);
  50. };
  51. var _loadTarget = function(event) {
  52. var link = lng.dom(this);
  53. _selectTarget(link);
  54. event.preventDefault();
  55. };
  56. var _selectTarget = function(link) {
  57. var target_type = link.data(ATTRIBUTE.TARGET);
  58. console.error(ELEMENT, target_type);
  59. switch(target_type) {
  60. case ELEMENT.SECTION:
  61. var target_id = link.attr(ATTRIBUTE.HREF);
  62. _goSection(target_id);
  63. break;
  64. case ELEMENT.ARTICLE:
  65. _goArticle(link);
  66. break;
  67. case ELEMENT.ASIDE:
  68. _goAside(link);
  69. break;
  70. }
  71. };
  72. var _goSection = function(id) {
  73. id = lng.Core.parseUrl(id);
  74. if (id === '#back') {
  75. lng.Router.back();
  76. } else {
  77. lng.Router.section(id);
  78. }
  79. };
  80. var _goArticle = function(element) {
  81. var section_id = lng.Router.History.current();
  82. var article_id = element.attr(ATTRIBUTE.HREF);
  83. lng.Router.article(section_id, article_id);
  84. };
  85. var _goAside = function(element) {
  86. var section_id = lng.Router.History.current();
  87. var aside_id = element.attr(ATTRIBUTE.HREF);
  88. lng.Router.aside(section_id, aside_id);
  89. };
  90. var _hideAsideIfNecesary = function(section_id, aside_id) {
  91. if (window.innerWidth < 768) {
  92. lng.View.Aside.hide(section_id, aside_id);
  93. }
  94. };
  95. return {
  96. start: start
  97. };
  98. })(LUNGO);