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