| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- /**
- * Initialize the automatic DOM UI events
- *
- * @namespace LUNGO.Boot
- * @class Events
- *
- * @author Javier Jimenez Villar <javi@tapquo.com> || @soyjavi
- * @author Guillermo Pascual <pasku@tapquo.com> || @pasku1
- */
- LUNGO.Boot.Events = (function(lng, undefined) {
- /**
- * Initializes the automatic subscription events by markup of the project.
- *
- * @method init
- *
- */
- var start = function() {
- var touch_move_event = 'touchmove';
- var orientation_change = 'orientationchange';
- var target_selector = 'a[href][data-target]';
- var target_selector_from_aside = 'aside a[href][data-target]';
- lng.dom(document).on(touch_move_event, _iScroll);
- lng.dom(window).on(orientation_change, _changeOrientation);
- lng.dom(target_selector_from_aside).tap(_toggleAside);
- lng.dom(target_selector).tap(_loadTarget);
- _buttonsFeedbackInAndroid();
- };
- var _iScroll = function(event) {
- event.preventDefault();
- };
- var _changeOrientation = function(event) {
- lng.View.Resize.toolbars();
- };
- var _toggleAside = function(event) {
- var link = lng.dom(this);
- var section_id = _getParentIdOfElement(link);
- lng.View.Aside.toggle(section_id);
- event.preventDefault();
- };
- var _loadTarget = function(event) {
- var link = lng.dom(this);
- _selectTarget(link);
- event.preventDefault();
- };
- var _buttonsFeedbackInAndroid = function() {
- var environment = lng.Core.environment();
- if (environment.isMobile && environment.os.name === 'android') {
- lng.dom(document.body).on('touchstart', '.button', _addClassActiveToButton);
- lng.dom(document.body).on('touchend', '.button', _removeClassActiveToButton);
- }
- };
- var _addClassActiveToButton = function(element) {
- lng.dom(this).addClass('active');
- };
- var _removeClassActiveToButton = function(element) {
- lng.dom(this).removeClass('active');
- };
- var _selectTarget = function(link) {
- var target_type = link.data('target');
- switch(target_type) {
- case 'section':
- var target_id = link.attr('href');
- _goSection(target_id);
- break;
- case 'article':
- _goArticle(link);
- break;
- case 'aside':
- _goAside(link);
- break;
- }
- };
- var _goSection = function(id) {
- if (id === '#back') {
- lng.Router.back();
- } else {
- lng.Router.section(id);
- }
- };
- var _goArticle = function(element) {
- var section_id = _getParentIdOfElement(element);
- var article_id = element.attr('href');
- lng.Router.article(section_id, article_id);
- };
- var _goAside = function(element) {
- var section_id = _getParentIdOfElement(element);
- lng.View.Aside.toggle(section_id);
- };
- var _getParentIdOfElement = function(element) {
- var parent_id = '#' + element.parent('section').attr('id');
- return parent_id;
- };
- return {
- start: start
- };
- })(LUNGO);
|