Lungo.Boot.Events.js 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  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. /**
  12. * Initializes the automatic subscription events by markup of the project.
  13. *
  14. * @method init
  15. *
  16. */
  17. var start = function() {
  18. var touch_move_event = 'TOUCH_MOVE';
  19. var touch_start_event = 'TOUCH_START';
  20. var tap = 'TAP';
  21. var orientation_change = 'ORIENTATION_CHANGE';
  22. var target_selector = 'a[href][data-target]';
  23. var target_selector_from_aside = 'aside a[href][data-target]';
  24. lng.Events.init();
  25. lng.Dom.Event.listener(document, touch_move_event, _iScroll);
  26. lng.Dom.Event.listener(window, orientation_change, _changeOrientation);
  27. lng.Dom.Event.live(target_selector_from_aside, touch_start_event, _toggleAside);
  28. lng.Dom.Event.live(target_selector, tap, _loadTarget);
  29. };
  30. var _iScroll = function(event) {
  31. event.preventDefault();
  32. };
  33. var _changeOrientation = function(event) {
  34. lng.View.Resize.toolbars();
  35. };
  36. var _toggleAside = function(event) {
  37. var link = lng.Dom.query(this);
  38. var section_id = _getParentIdOfElement(link);
  39. lng.View.Aside.toggle(section_id);
  40. event.preventDefault();
  41. };
  42. var _loadTarget = function(event) {
  43. var link = lng.Dom.query(this);
  44. _selectTarget(link);
  45. event.preventDefault();
  46. };
  47. var _selectTarget = function(link) {
  48. var target_type = link.data('target');
  49. switch(target_type) {
  50. case 'section':
  51. var target_id = link.attr('href');
  52. _goSection(target_id);
  53. break;
  54. case 'article':
  55. _goArticle(link);
  56. break;
  57. case 'aside':
  58. _goAside(link);
  59. break;
  60. }
  61. };
  62. var _goSection = function(id) {
  63. if (id === '#back') {
  64. lng.Router.back();
  65. } else {
  66. lng.Router.section(id);
  67. }
  68. };
  69. var _goArticle = function(element) {
  70. var section_id = _getParentIdOfElement(element);
  71. var article_id = element.attr('href');
  72. lng.Router.article(section_id, article_id);
  73. };
  74. var _goAside = function(element) {
  75. var section_id = _getParentIdOfElement(element);
  76. lng.View.Aside.toggle(section_id);
  77. };
  78. var _getParentIdOfElement = function(element) {
  79. var parent_id = '#' + element.parents('section').attr('id');
  80. return parent_id;
  81. };
  82. return {
  83. start: start
  84. };
  85. })(LUNGO);