Lungo.Boot.Events.js 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  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.Dom.Event.listener(document, touch_move_event, _iScroll);
  25. lng.Dom.Event.listener(window, orientation_change, _changeOrientation);
  26. lng.Dom.Event.live(target_selector_from_aside, touch_start_event, _toggleAside);
  27. lng.Dom.Event.live(target_selector, tap, _loadTarget);
  28. };
  29. var _iScroll = function(event) {
  30. event.preventDefault();
  31. };
  32. var _changeOrientation = function(event) {
  33. lng.View.Resize.toolbars();
  34. };
  35. var _toggleAside = function(event) {
  36. var link = lng.Dom.query(this);
  37. var section_id = _getParentIdOfElement(link);
  38. lng.View.Aside.toggle(section_id);
  39. event.preventDefault();
  40. };
  41. var _loadTarget = function(event) {
  42. var link = lng.Dom.query(this);
  43. _selectTarget(link);
  44. event.preventDefault();
  45. };
  46. var _selectTarget = function(link) {
  47. var target_type = link.data('target');
  48. switch(target_type) {
  49. case 'section':
  50. var target_id = link.attr('href');
  51. _goSection(target_id);
  52. break;
  53. case 'article':
  54. _goArticle(link);
  55. break;
  56. case 'aside':
  57. _goAside(link);
  58. break;
  59. }
  60. };
  61. var _goSection = function(id) {
  62. if (id === '#back') {
  63. lng.Router.back();
  64. } else {
  65. lng.Router.section(id);
  66. }
  67. };
  68. var _goArticle = function(element) {
  69. var section_id = _getParentIdOfElement(element);
  70. var article_id = element.attr('href');
  71. lng.Router.article(section_id, article_id);
  72. };
  73. var _goAside = function(element) {
  74. var section_id = _getParentIdOfElement(element);
  75. lng.View.Aside.toggle(section_id);
  76. };
  77. var _getParentIdOfElement = function(element) {
  78. var parent_id = '#' + element.parents('section').attr('id');
  79. return parent_id;
  80. };
  81. return {
  82. start: start
  83. };
  84. })(LUNGO);