Lungo.Boot.Events.js 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  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-router]',
  16. HREF_TARGET_FROM_ASIDE: 'aside a[href][data-router]',
  17. INPUT_CHECKBOX: 'input[type=range].checkbox'
  18. };
  19. /**
  20. * Initializes the automatic subscription events by markup of the project.
  21. *
  22. * @method init
  23. *
  24. */
  25. var init = function() {
  26. lng.dom(SELECTORS.HREF_TARGET_FROM_ASIDE).tap(_hideAsideIfNecesary);
  27. lng.dom(SELECTORS.HREF_TARGET).tap(_loadTarget);
  28. lng.dom(SELECTORS.INPUT_CHECKBOX).touch(_changeCheckboxValue);
  29. };
  30. var _loadTarget = function(event) {
  31. event.preventDefault();
  32. var link = lng.dom(this);
  33. if (link.data("async")) {
  34. _loadAsyncTarget(link);
  35. } else {
  36. _selectTarget(link);
  37. }
  38. };
  39. var _hideAsideIfNecesary = function(event) {
  40. event.preventDefault();
  41. lng.View.Aside.hide();
  42. };
  43. var _changeCheckboxValue = function(event) {
  44. event.preventDefault();
  45. var el = lng.dom(this);
  46. var current_value = el.val() > 0 ? 0 : 1;
  47. el.toggleClass("active").attr('value', current_value);
  48. };
  49. var _selectTarget = function(link) {
  50. var target_type = link.data(ATTRIBUTE.ROUTER);
  51. switch(target_type) {
  52. case ELEMENT.SECTION:
  53. var target_id = link.attr(ATTRIBUTE.HREF);
  54. _goSection(target_id);
  55. break;
  56. case ELEMENT.ARTICLE:
  57. _goArticle(link);
  58. break;
  59. case ELEMENT.ASIDE:
  60. _goAside(link);
  61. break;
  62. }
  63. };
  64. var _loadAsyncTarget = function(link) {
  65. lng.Notification.show();
  66. lng.Boot.Resources.load(link.data("async"));
  67. link[0].removeAttribute("data-async");
  68. lng.Boot.Data.init( link.attr(ATTRIBUTE.HREF) );
  69. setTimeout(function() {
  70. _selectTarget(link);
  71. lng.Notification.hide();
  72. }, lng.Constants.TRANSITION.DURATION * 2);
  73. };
  74. var _goSection = function(id) {
  75. id = lng.Core.parseUrl(id);
  76. if (id === '#back') {
  77. lng.Router.back();
  78. } else {
  79. lng.Router.section(id);
  80. }
  81. };
  82. var _goArticle = function(element) {
  83. var section_id = lng.Router.History.current();
  84. var article_id = element.attr(ATTRIBUTE.HREF);
  85. lng.Router.article(section_id, article_id, element);
  86. };
  87. var _goAside = function(element) {
  88. var section_id = lng.Router.History.current();
  89. var aside_id = element.attr(ATTRIBUTE.HREF);
  90. lng.Router.aside(section_id, aside_id);
  91. };
  92. return {
  93. init: init
  94. };
  95. })(Lungo);