| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325 | (function($, Drupal, drupalSettings) {  EdlpTheme = function(){    var _origin = window.location.origin;    var _base_url = drupalSettings.path.baseUrl;    var _ajax_settings = drupalSettings.edlp_ajax;    var _$body = $('body');    // var _is_front = drupalSettings.path.isFront;    var _corpus_ready = false;    var _$corpus_canvas;    var _$row = $('main[role="main"]>.layout-content>.row');    var _$ajaxLinks;    var _audioPlayer;    var _randomPlayer;    var _compoPlayer;    var _ajax_timing = {      start:0,      end:0    };    var _corpus_promise;    var _is_mobile =  edlp_mobile.device_is_mobile;    var _is_loggedin = drupalSettings.user.uid === 0 ? false : true;    var _$log_form;    var _user_tokens;    var _states_history = [];    var _is_expo = $('body').hasClass('domain-expo-encyclopediedelaparole-org');    //  ___      _ _    // |_ _|_ _ (_) |_    //  | || ' \| |  _|    // |___|_||_|_|\__|    function init(){      console.log("EdlpTheme init()");      if (!_is_loggedin) {        initLogForm();      }      if(_is_mobile){        initMobile();      }      initEvents();      _audioPlayer = new AudioPlayer();      _compoPlayer = new CompoPlayer();      initAjaxLinks();      initHistory();      if(!_is_mobile){        checkLayout();        initAudioLinksHover();      }      if(_is_mobile){        if(drupalSettings.path.isFront){          initHomeMobile();        }        _$body.attr('booted', 'booted');      }    };    //  _                ___    // | |   ___  __ _  | __|__ _ _ _ __    // | |__/ _ \/ _` | | _/ _ \ '_| '  \    // |____\___/\__, | |_|\___/_| |_|_|_|    //           |___/    function initLogForm(){      console.log('initLogForm');      _$log_form = $('#user-login-form:not(ajax-enebled)')        .on('submit', onSubmitLogForm)        .addClass('ajax-enabled');    };    function onSubmitLogForm(e){      e.preventDefault();      // console.log('onSubmitLogForm', e);      var args = {        name : $('input#edit-name[type="text"]', this).val(),        pass : $('input#edit-pass[type="password"]', this).val()      };      // console.log(args);      logIn(args).then(logedin);      return false;    };    function logIn(args){      console.log('logIn', args);      _$log_form.addClass('ajax-loading');      _$body.addClass('ajax-loading');      return $.ajax({        type: 'POST',        headers: {'Content-Type': 'application/json'},        xhrFields: {          withCredentials: true        },        // accessToken : 'tokenvaluehere',        url: _origin+_base_url+"user/login?_format=json",        data: JSON.stringify(args),        // name: args.mail,        // pass: args.pass,        success: function(response){          // console.log('sucess', response);          _user_tokens = response;        },        error: function (xhr, ajaxOptions, thrownError){          console.log(xhr.status);          console.log(thrownError);        }      });    };    function logedin(){      $('body').addClass('user-logged-in');      getStudioLinkBlock();    };    function getStudioLinkBlock(){      var path = _origin+_base_url+'edlp/ajax/blocks/json/';      $.getJSON(path+"studiolinkblock", {})        .done(onStudioLinkBlockLoaded)        .fail(function(jqxhr, textStatus, error){          console.warn('Studio ink block load failed', jqxhr.responseText);        });    };    function onStudioLinkBlockLoaded(data){      console.log('onStudioLinkBlockLoaded', data);      $('#block-studiouserlogin').replaceWith(data.blocks.studiolinkblock.rendered);      initAjaxLinks();      refreshFavoritesLinks();      _$log_form.removeClass('ajax-loading');      _$body.removeClass('ajax-loading');    }    //  __  __     _    _ _    // |  \/  |___| |__(_) |___    // | |\/| / _ \ '_ \ | / -_)    // |_|  |_\___/_.__/_|_\___|    function initMobile(){      // $('[data-drupal-link-system-path="<front>"]','#block-mainnavigation')      //   .removeClass('is-active')      //   .attr('href', '#collection');      // edlp_mobile.mobile_home_path.replace(/^\//, '')      // TODO: remove collection from mobile home      // TODO: replace ajax link to only collection for mobile      $('h2, a', '#block-mainnavigation')        .add('h2, a', '#block-mainnavigation-2')        .on('click', onclickHomeMobileMenu);    }    function onclickHomeMobileMenu(e){      // $('#block-mainnavigation').toggleClass('opened');      $('#block-mainnavigation-2').toggleClass('opened');    };    function initHomeMobile(){      // taxonomy-term.vocabulary-entrees.home_mobile      // $('.field--name-field-notice, .index', '.entrees .taxonomy-term.vocabulary-entrees')      //   .addClass('closed');      // $('.field--name-field-notice>.field__label', '.entrees .taxonomy-term.vocabulary-entrees')      //   .on('click', onClickHomeMobileNotice);      // $('.index>.field__label', '.entrees .taxonomy-term.vocabulary-entrees')      //   .on('click', onClickHomeMobileIndex);    };    // function onClickHomeMobileNotice(e){    //   // console.log('onClickHomeMobileNotice');    //   // var $part = $(this).parent();//parents('.taxonomy-term');    //   toggleEntreeOpening($(this).parent(), 'notice');    // };    // function onClickHomeMobileIndex(e){    //   // console.log('onClickHomeMobileIndex');    //   // var $part = $(this).parent();//parents('.taxonomy-term');    //   toggleEntreeOpening($(this).parent(), 'index');    // };    // function toggleEntreeOpening($e, part){    //   $e.toggleClass('closed')    //     .parents('.taxonomy-term.vocabulary-entrees.home_mobile').toggleClass(part+'-opened');    // }    //  ___             _    // | __|_ _____ _ _| |_ ___    // | _|\ V / -_) ' \  _(_-<    // |___|\_/\___|_||_\__/__/    function initEvents(){      // https://www.html5rocks.com/en/tutorials/async/deferred/      var $corpus_df = $.Deferred();      _corpus_promise = $corpus_df.promise();      _$body        .on('corpus-map-ready', function(e){          onCorpusMapReady(e);          $corpus_df.resolve();        })        .on('on-studio-chutier-updated', initAjaxLinks)        .on('studio-initialized', function(e){          _compoPlayer.newCompo();        })        .on('studio-not-active', function(e){          _compoPlayer.deactivate();        })        .on('on-studio-compo-updated', function(e){          initAjaxLinks();          _compoPlayer.refresh();        })        .on('on-studio-compo-opened', function(e){          initAjaxLinks();          _compoPlayer.newCompo();        })        .on('search-results-loaded', function(e){          initAjaxLinks();          initAudioLinksHover();          checkVisibleCorpusMapSpace();        })        // do not close index or notice modale on entree click        .on('open_entree', function(e){          console.log('on_open_entree : e', e);          closeAllModals();          checkLayout();          // add body class for currently loaded content          // var body_classes = [          //   'path-'+sys_path.replace(/\//g, '-'),          //   'entity-type-'+data.entity_type,          //   'bundle-'+data.bundle,          //   'view-mode-'+data.view_mode          // ];          _$body.removeClass();//.addClass(body_classes.join(' '));          // record new history state          if(typeof e.url != 'undefined'){            var state = getSysPathState(e.sys_path);            history.pushState(state, null, e.url);            // piwik            if(typeof _paq !== 'undefined'){              // page tracking              // https://matomo.org/blog/2017/02/how-to-track-single-page-websites-using-piwik-analytics/              _paq.push(['setCustomUrl', e.url]);              _paq.push(['setDocumentTitle', e.title]);              _paq.push(['trackPageView']);            }          }        })        .on('close_entree', function(e){          backToFrontPage();          checkLayout();        });      window.addEventListener('resize', checkLayout, false);    }    // __      ___         _              ___        _    // \ \    / (_)_ _  __| |_____ __ __ | _ \___ __(_)______    //  \ \/\/ /| | ' \/ _` / _ \ V  V / |   / -_|_-< |_ / -_)    //   \_/\_/ |_|_||_\__,_\___/\_/\_/  |_|_\___/__/_/__\___|    function checkLayout(){      var $audioplayer = $("#audio-player");      if($audioplayer.length){        var navpos = $('#block-mainnavigation').position();        // console.log('navpos', navpos);        if(typeof navpos != 'undefined'){          $audioplayer.css({            'width':navpos.left+'px'          });        }      }      checkGridBlockHeight();      checkGridBlockVisible();      // entrees      // TODO: center the entrees menu    };    //  ___             _ _ ___    // / __| __ _ _ ___| | | _ ) __ _ _ _ ___    // \__ \/ _| '_/ _ \ | | _ \/ _` | '_(_-<    // |___/\__|_| \___/_|_|___/\__,_|_| /__/    function initScrollbars(){      // console.log("initScrollbars");      // TODO: find a better js scroll than overlayScrollbars which does not handle well max-height + overflow-y:auto;      // $('.os-scroll').overlayScrollbars({      //   overflowBehavior:{      //     x:'h',      //     y:'scroll',      //     clipAlways:false      //   }      // });    };    //    _    _    //   /_\  (_)__ ___ __    //  / _ \ | / _` \ \ /    // /_/ \_\/ \__,_/_\_\    //      |__/    function getSysPathState(sys_path, view_mode){      // console.log('Theme : getSysPathState', sys_path);      var state = {        'sys_path':sys_path,        'ajax_path': sys_path      };      // convert node link to edlp_ajax_node module links      var node_match = state.ajax_path.match(/^\/?(node\/(\d+))$/i);      console.log('node_match', node_match);      var term_match = state.ajax_path.match(/^\/?(taxonomy\/term\/(\d+))$/i);      console.log('term_match', term_match);      if(node_match){        // TODO: detect audio links which will open audioplayer and wont load any ajax content unless view_mode "article" or "transcript"        state.ajax_path = _ajax_settings.entityjson_path+'/'+node_match[1];        state.node_nid = node_match[2];        // check for viewmode attribute        if(view_mode){          state.ajax_path += '/'+view_mode;          state.view_mode = view_mode;        }      }else if(term_match){        // terms are always entrees, there's no other vocabulary links in front        state.ajax_path = _ajax_settings.entityjson_path+'/'+term_match[1];        state.ajax_path = state.ajax_path.replace(/taxonomy\/term/, 'taxonomy_term');        state.entree_tid = term_match[2];        // check for viewmode attribute        if(view_mode){          state.ajax_path += '/'+view_mode;          state.view_mode = view_mode;        }else{          state.ajax_path = null;        }      }else{        // convert other link to ajax        // TODO: we assume that other links (no node, no term) are all from own modules (e.g. productions) !! may not be true !!        state.ajax_path += '/ajax'      }      return state;    };    function ajaxLoadContent(state){      console.log('ajaxLoadContent : state', state);      _$body.addClass('ajax-loading');      _ajax_timing.start = performance.now();      var path = _origin + Drupal.url(state.ajax_path);      $.getJSON(path, {})        .done(function(data){          onAjaxLoaded(data, state);        })        .fail(function(jqxhr, textStatus, error){          onAjaxLoadError(jqxhr, textStatus, error, state.sys_path);        });    };    function onAjaxLoadError(jqxhr, textStatus, error, sys_path){      console.warn('ajaxlink load failed for '+sys_path+' : '+error, jqxhr.responseText);      $('.ajax-loading').removeClass('ajax-loading');      _$body.removeClass('ajax-loading');    };    function onAjaxLoaded(data, state){      console.log('ajax loaded', state, data);      var $rendered = $(data.rendered);      $rendered.attr({        'sys_path':state.sys_path,        'view_mode': state.view_mode      });      // console.log(data);      // reset all style may been added by other pages (like masonry for productions)      // and replace all content with newly loaded      // TODO: build a system to replace or append contents (like studio + search)      if(data.entity_type == "node" && data.bundle == "evenement"){        if(_$row.find('.col.event').length){          _$row.find('.col.event').replaceWith($rendered);        }else if(_$row.find('.col.aside').length){          _$row.find('.col.aside').replaceWith($rendered);        }else{          _$row.append($rendered);        }      }      else if(        (state.context == 'document-transcript' || state.context == 'document-artcile')        && state.caller == "search"      ){        _$row.append($rendered);      }      else{        _$row.removeAttr('style').html($rendered);      }      // remove article is-active class is static content loaded      if ((data.entity_type == "node" && data.bundle == "static")          || state.sys_path == "docsindex") {        $('.ajax-link.is-active.articles-link').removeClass('is-active');      }      // add body class for currently loaded content      var body_classes = [        'path-'+state.sys_path.replace(/\//g, '-'),        'entity-type-'+data.entity_type,        'bundle-'+data.bundle,        'view-mode-'+data.view_mode      ];      _$body.removeClass().addClass(body_classes.join(' '));      // id node add a generic path-node class to body      // m = state.sys_path.match(/^\/?(node\/\d+)$/g);      // if(m)      if(state.node_nid)        _$body.addClass('path-edlp-node');      // handle clicked link classes      $('.ajax-loading').removeClass('ajax-loading');      $('.ajax-link.is-active:not(.articles-link)').removeClass('is-active');      $('.is-active-trail').removeClass('is-active-trail');      if(typeof state.selector != 'undefined'){        // in case of entree link (actualy, selector is used only for entries links)        // TODO:  unfortunatly on initFirstLoad there is no selector property        console.log('selector', state.selector);        $('a[selector="'+state.selector+'"]').addClass('is-active');        initAudioLinksHover();      }else{        if(typeof state.view_mode != 'undefined'){          $('a[viewmode="'+state.view_mode+'"][data-drupal-link-system-path="'+state.sys_path+'"]').addClass('is-active');        }else{          // wait for corpus map beeing ready (e.g. for articles link)          _corpus_promise.done(function(){            $('a[data-drupal-link-system-path="'+state.sys_path+'"]').addClass('is-active');          });        }        // as new content is not related to entree, we trigger close entree        _$body.trigger({'type':'new-content-not-entree-ajax-loaded'});      }      // if bundle page (productions) activate production links      if (typeof data.bundle != 'undefined' && data.bundle == "page") {        $('a[data-drupal-link-system-path="productions"]').addClass('is-active-trail');      }      // if node is in production menu tree, set first level of tree active, e.g. pieces sonores      if (typeof data.menu_parents != 'undefined') {        for (var i = 0; i < data.menu_parents.length; i++) {          var menu_sys_path = data.menu_parents[i];          $('a[data-drupal-link-system-path="'+menu_sys_path+'"]').addClass('is-active-trail');        }      }      // if entity has corpus-map's linked document call a filter to corpus map      if(typeof data.documents_lies != 'undefined'){        if(_corpus_ready){          _$body.trigger({            type:'ajax-node-loaded-linked-documents',            nids:data.documents_lies          });        }else{          _corpus_promise.done(function(){            _$body.trigger({              type:'ajax-node-loaded-linked-documents',              nids:data.documents_lies            });          });        }      }      // if block attached (eg : from edlp_productions module)      // not used anymore as production block is always present (but not visible)      if(typeof data.block != 'undefined'){        // if block not already added        if(!$('#'+data.block.id, '.region-'+data.block.region).length){          $('.region-'+data.block.region).append(data.block.rendered);        }      }      // initScrollbars();      if(state.sys_path == "productions"){        // initProductions();        initGrid();      }else{        addCloseModalBtnToCols();      }      if(state.sys_path == "collection"){        // only for mobile version of collection        initCollectionNav();      }      // enregistrement transcription      if(data.entity_type == "node" && data.bundle == "enregistrement" && data.view_mode == "transcript"){        // window.requestAnimationFrame(initEnregistrementTranscript);        initEnregistrementTranscript();      }      if(state.sys_path == "search"){        initSearch();      }      // update the language switcher block if it comes in the response      if(typeof data.translations_links != 'undefined'){        console.log('state',state);        var lang_code = drupalSettings.path.currentLanguage;        var $links = $(data.translations_links);        // set active link        $links.find('li[hreflang="'+lang_code+'"]').addClass('is-active').find('a').addClass('is-active');        if(state.view_mode){          $links.find('a').each(function(i,e){            var $a = $(this);            $a.attr('href', $a.attr('href')+'#'+state.view_mode);          });        }        // if(state.selector){        //   $links.find('a').attr('selector', state.selector);        // }        $('ul','.block.language-switcher-language-url').replaceWith($links);      }      initAjaxLinks();      initAudioLinksHover();      checkVisibleCorpusMapSpace();      // trigger other modules behaviours      _$body.trigger({'type':'new-content-ajax-loaded'});      // and call drupal behaviours      Drupal.attachBehaviors(_$row[0]);      _$body.attr('booted', 'booted');      _$body.removeClass('ajax-loading');      // record the states history as we can't get them from history api      _states_history.unshift(state);      // url is null means that we are loading content on popState event      // so we don't record the state again      if(state.url){        // /!\ we can not pushestate with absolute url /!\        history.pushState(state, null, state.url);        // piwik        if(typeof _paq !== 'undefined'){          // page tracking          // https://matomo.org/blog/2017/02/how-to-track-single-page-websites-using-piwik-analytics/          _paq.push(['setCustomUrl', state.url]);          _paq.push(['setDocumentTitle', data.title]);          // TODO: piwik track load time          _ajax_timing.end = performance.now();          _paq.push(['setGenerationTimeMs', _ajax_timing.end-_ajax_timing.start]);          _paq.push(['trackPageView']);          // js event          // trackEvent(category, action, [name], [value])          // _paq.push(['trackEvent', 'AjaxNav', 'loaded', state.url]);        }      }    };    function initAudioLinksHover(){      console.log("initAudioLinksHover()");      _$row.find('a.audio-link')        .not('article.node--view-mode-docsindex a.audio-link')        .on('mouseover', function(event) {          event.preventDefault();          if(_corpus_ready){            _$corpus_canvas.trigger({              type:'mouseover-audio-link',              nid:$(this).attr('nid')            });          }        })        .on('mouseout', function(event) {          event.preventDefault();          if(_corpus_ready){            _$corpus_canvas.trigger({              type:'mouseout-audio-link',              nid:$(this).attr('nid')            });          }        });    };    function addCloseModalBtnToCols(){      if(_is_mobile) return;      $('.col', _$row).each(function(index, el) {        if($('span.close-col-btn', this).length)          return true;        $(this).children('.wrapper').prepend($('<span>')          .addClass('close-col-btn')          .on('click', onCloseModal)        );      });    };    function onCloseModal(e){      console.log("onCloseModal");      // check from production to audio text back to production      console.log("onCloseModal _states_history",_states_history);      if(['document-transcript', 'document-article'].indexOf(_states_history[0].context) != -1)      {        if (_states_history[0].caller == "production") {          for (var i = 0; i < _states_history.length; i++) {            if (_states_history[i].context == "production") {              // history.go(i*-1-1);              console.log("onCloseModal return to production", _states_history[i]);              ajaxLoadContent(_states_history[i]);              return;            }          }        }        if (_states_history[0].caller == "entree-index") {          for (var i = 0; i < _states_history.length; i++) {            if (_states_history[i].context == "entree-index") {              console.log("onCloseModal return to entree-index", _states_history[i]);              ajaxLoadContent(_states_history[i]);              return;            }          }        }        if (_states_history[0].caller == "entree-notice") {          for (var i = 0; i < _states_history.length; i++) {            if (_states_history[i].context == "entree-notice") {              console.log("onCloseModal return to entree-notice", _states_history[i]);              ajaxLoadContent(_states_history[i]);              return;            }          }        }      }      // return to productions home when closing a prod      // if(['production'].indexOf(_states_history[0].context) != -1)      // {      //   var i = 0;      //   while (_states_history[i].caller == "production-home") {      //     if (_states_history[i].context == "production-home") {      //       // history.go(i*-1-1);      //       console.log("onCloseModal return to productions home", _states_history[i]);      //       ajaxLoadContent(_states_history[i]);      //       return;      //     }      //     i++;      //   }      // }      // check for theme attribute and emmit event      var $col = $(this).parents('.col');      var theme = $col.attr('theme');      if(theme != ''){        _$body.trigger({'type':theme+'-col-closed'});      }      if(_$body.is('.entity-type-node.bundle-page') && $(this).next().is('.node--type-page')){        // remove all the col (prod page and agenda in case) only if closing the main page col        // if closing the aside col (agenda) leave the main col in place        $col.add($col.siblings('.col')).remove();      }else{        // remove the col        $col.remove();      }      checkRowEmpty();      checkVisibleCorpusMapSpace();      // set links to this modal to not active (tested on articles from audio cartel)      if( $col.attr('view_mode') && $col.attr('sys_path')){        $('a[data-drupal-link-system-path="'+$col.attr('sys_path')+'"][viewmode="'+$col.attr('view_mode')+'"]').removeClass('is-active');      }    };    //    _    _            ___ _         _    //   /_\  (_)__ ___ __ | _ ) |___  __| |__ ___    //  / _ \ | / _` \ \ / | _ \ / _ \/ _| / /(_-<    // /_/ \_\/ \__,_/_\_\ |___/_\___/\__|_\_\/__/    //      |__/    // NOT USED (YET)    // function refreshAllBlocks(){    //   var path = _origin + Drupal.url(_ajax_settings.blocksjson_path);    //   $.getJSON(path, {})    //     .done(function(data){    //       onAjaxBlockLoaded(data);    //     })    //     .fail(function(jqxhr, textStatus, error){    //       onAjaxBlockLoadError(jqxhr, textStatus, error);    //     });    // };    // function onAjaxBlockLoadError(jqxhr, textStatus, error){    //   console.warn('ajax block load failed: '+error, jqxhr.responseText);    // };    // function onAjaxBlockLoaded(data){    //   console.log('onAjaxBlockLoaded', data);    //   // TODO: update each blocks (exepted language switcher)    //   for (var blockname in data.blocks) {    //     var block = data.blocks[blockname];    //     console.log(blockname, block);    //     $(block.id).replaceWith(block.rendered);    //   }    // };    //  _  _ _    _    // | || (_)__| |_ ___ _ _ _  _    // | __ | (_-<  _/ _ \ '_| || |    // |_||_|_/__/\__\___/_|  \_, |    //                        |__/    function initHistory(){      initFirstLoad();      window.addEventListener('popstate', onHistoryPopState);    };    function initFirstLoad(){      console.log('theme : initFirstLoad()');      console.log('window.location', window.location);      // var origin_sys_path = window.localStorage.getItem('edlp_origin_path');      var edlp_origin = JSON.parse(window.localStorage.getItem('edlp_origin'));      console.log('edlp_origin', edlp_origin);      if(edlp_origin != null && edlp_origin.sys_path){        // hash is used as viewmode for taxonomy term entrees load (index or notice)        // and for audio contents (article|transcript)        var hash = edlp_origin.hash.replace('#', '');        // create history state        var state = getSysPathState(edlp_origin.sys_path, hash);        // open entree tray in case of entree index|notice        // (index or notice will be opened with ajaxLoadContent)        // refactorized with new infos from edlp_origin        // if(hash){        if(edlp_origin.entity_type == "taxonomy_term"            && edlp_origin.entity_bundle == "entrees"            && hash){          // var $link = $('[href="'+edlp_origin.url+'"][viewmode="'+hash+'"]');          // var selector = $link.attr('selector') || null;          // record the selector in the state for actions after ajaxContentLoaded          state.selector = 'entree-'+hash+'-link-'+edlp_origin.entity_id; // entree-index-link-125          // if(selector){            // in case of entree link (actualy, selector is used only for entries links)            // TODO: use a promise            // TODO: but what if corpus ready before onAjaxLoaded >> use a promise !!            if(_corpus_ready){              _$corpus_canvas.trigger({                type:'open-entree',                // tid:$link.attr('tid')                tid:edlp_origin.entity_id              });            }else{              // else : EdlpCorpus will check when ready if entry item (notice or index) is already .is-active              // .is-active class is added by onAjaxLoaded() (when content is loaded)              // $('li.entree[tid="'+$link.attr('tid')+'"] a.term-link').addClass('is-active');              $('li.entree[tid="'+edlp_origin.entity_id+'"] a.term-link').addClass('is-active');            }          // }        }        // check if audio link        // only if not random link        if(edlp_origin.audio_url){          var node = {            nid:edlp_origin.entity_id,            audio_url:edlp_origin.audio_url          };          _audioPlayer.openDocument(node, 'history_first_load');          // close home          closeAllModals();          if(hash == "" || hash == 'random'){            // if hash is random, RandomPlayer will be started when playlist sent by corpus.js            // if audio only record in state            state.audio = true;            state.node = node;            // we don't laod ajax content so we boot the home            _$body.attr('booted', 'booted');          }else{            // ajax load content for audio only if article or transcript            ajaxLoadContent(state);          }        }        // only if not entree path        // only if not audio (without article or transcript) path        else if(state.ajax_path){          // load content through ajax          // ajaxLoadContent(null, state.sys_path, state.ajax_path, selector);          ajaxLoadContent(state);        }        if(state.entree_tid){          openEntree(state.entree_tid);        }        // record history state        history.replaceState(state, null, edlp_origin.url+edlp_origin.hash);        // reset the storage        window.localStorage.removeItem("edlp_origin");        // window.localStorage.removeItem("edlp_origin_url");      }else{        // if(window.location.hash == "#random"){        //        // }        history.replaceState({home:true}, null, window.location.pathname+window.location.hash);        // initHome();        initGrid();        _$body.attr('booted', 'booted');      }    };    function onHistoryPopState(e){      console.log('onPopState',e.state);      if(e.state.home){        backToFrontPage(true);      }      else if (e.state.audio) {          _audioPlayer.openDocument(e.state.node, 'popstate', e.state.historic_index);      }      else{        if(e.state.entree_tid){          openEntree(e.state.entree_tid);        }        if(e.state.ajax_path){          e.state.url = null;          // ajaxLoadContent(null, e.state.sys_path, e.state.ajax_path)          ajaxLoadContent(e.state);        }      }    };    //    _    _          _    _      _    //   /_\  (_)__ ___ _| |  (_)_ _ | |__ ___    //  / _ \ | / _` \ \ / |__| | ' \| / /(_-<    // /_/ \_\/ \__,_/_\_\____|_|_||_|_\_\/__/    //      |__/    function initAjaxLinks(){      // console.log('initAjaxLinks');      $('a', '#block-mainnavigation')        .add('a', '#block-mainnavigation-2')        // .add('a', '.block.language-switcher-language-url')        .add('a', '#block-footer.menu--footer')        .add('a', '#block-productions')        .add('a', 'article.node:not(.node--type-enregistrement) h2.node-title')        // .add('a', 'article.node--type-evenement.node--view-mode-teaser .field--name-field-page-liee')        .add('a', '.productions-subtree')        .add('a', '.productions-parent')        // .add('a.index-link, a.notice-link', '#block-edlpentreesblock')        .add('a', '.field--name-field-son')        .addClass('ajax-link');      if(!_is_mobile){        $('a.site-name', '#block-edlptheme-branding').addClass('ajax-link');      }      _$ajaxLinks = $('.ajax-link');      activateAjaxLinks();    };    function activateAjaxLinks(){      // $('.ajax-link:not(.ajax-enabled)')      _$ajaxLinks.each(function(i,e){          var $this = $(this);          // avoid already ajaxified links          if($this.is('.ajax-enable')) return;          if($this.attr('data-drupal-link-system-path') || $this.is('[type^="audio"]')){            $this.on('click', onClickAjaxLink).addClass('ajax-enable');          }        });    };    function onClickAjaxLink(e){      e.preventDefault();      var $link = $(this);      // let the site-name link going through as it will shuffle the map if already active      if($link.is('.is-active') && !$link.is('.site-name'))        return false;      // Audio links      // launch audio player and stop here      if($link.is('.audio-link')){        // check if caller is lastdocs block        caller = $link.parents('.lastdocs, .lastdocs-home').length ? 'lastdocs' : null;        // check if caller is studio composition        if(!caller){          caller = $link.parents('.composition_ui').length ? 'studio-compo' : null;        }        // open audio player        if(caller == 'studio-compo'){          var index = $link.parents('.field__item').index();          console.log('audio link caller', caller, index);          // _compoPlayer.setIndex(index);          _compoPlayer.start(index);        }else{          _audioPlayer            .emmit('stop-shuffle')            .openDocument({              nid:$link.attr('nid'),              audio_url:$link.attr('audio_url'),              title:$link.find('.field--name-title').html()            },            caller);        }        return false;      }      // other sounds playing      if($link.is('[type^="audio"]')){        _audioPlayer          .emmit('stop-shuffle')          .openSound($link.attr('href'), $link.html());        return false;      }      // NOT USED ( YET ? )      // if($link.is('.language-link')){        // TODO: change global site current language        // load all blocks translated (exepted language switcher) ... :/        // refreshAllBlocks();        // TODO: use a promise to initAjaxLinks again after blocks updated        // then let load the content      // }      // other links      var sys_path = $(this).attr('data-drupal-link-system-path');      // front page      // just remove contents and stop here      if(sys_path == '<front>'){        if(!_is_mobile){          if($link.is('.is-active') && _corpus_ready){            _$corpus_canvas.trigger({'type':'shuffle-collection'});          }else{            backToFrontPage();          }          return false;        }        // else{        //   sys_path = edlp_mobile.mobile_home_path.replace(/^\//, '');        // }      }      var view_mode = $link.attr('viewmode');      var state = getSysPathState(sys_path, view_mode);      state.url = $(this).attr('href');      if(view_mode){        state.url += "#"+view_mode;      }      // get context for navigation purpose      // var contexts = state.url.match(/^.*\/(productions)\/.*/g);      var contexts = /^.*\/(productions|documents|entrees|search)(\/.*)?/g.exec(state.url);      console.log("onClickAjaxLink contexts", contexts);      if(contexts){        switch (contexts[1]) {          case 'productions':            // console.log("onClickAjaxLink is production");            // if (typeof contexts[2] !== 'undefined') {              state.context = "production"            // }else{            //   state.context = "production-home"            // }            break;          case 'entrees':            switch(view_mode) {              case 'index':                state.context = "entree-index";                break;              case 'notice':                state.context = "entree-notice";                break;            }            break;          case 'search':            state.context = "search";            break;          case 'documents':            // console.log("onClickAjaxLink is production");            switch (view_mode) {              case 'transcript':                state.context = "document-transcript";                break;              case 'article':                state.context = "document-article";                break;              default:                state.context = "document";            }            // get the caller from pecedent context            if(typeof _states_history[0] != "undefined"){              if(_states_history[0].caller){                state.caller = _states_history[0].caller              }else{                state.caller = _states_history[0].context              }            }else{              state.caller = null;            }            break;        }      }else{        state.context = null;        // state.context = caller;      }      if($link.is('[selector]')){        state.selector = $link.attr('selector');      }      $link.addClass('ajax-loading');      // ajaxLoadContent(url, sys_path, state.ajax_path, selector);      ajaxLoadContent(state);      return false;    };    function refreshFavoritesLinks(){      console.log("refreshFavoritesLinks", _states_history);      // reload the active audioPlayer cartel      _audioPlayer.reloadNode();      // current content (index)      if(_states_history[0].view_mode == 'index' || _states_history[0].sys_path == "docsindex"){        ajaxLoadContent(_states_history[0]);      }    }    //   ___    //  / __|___ _ _ _ __ _  _ ___    // | (__/ _ \ '_| '_ \ || (_-<    //  \___\___/_| | .__/\_,_/__/    //              |_|    function onCorpusMapReady(e){      //console.log('theme : onCorpusReady', e);      _corpus_ready = true;      _$corpus_canvas = $('canvas#corpus-map');      _$corpus_canvas        .on('corpus-cliked-on-map', function(e) {          //console.log('theme : corpus-cliked-on-map');          backToFrontPage();        })        .on('corpus-cliked-on-node', function(e) {          //console.log('theme : corpus-cliked-on-node', e);          _audioPlayer            .emmit('stop-shuffle')            // .setAutoOpenArticle(e.article)            .openDocument(e.target_node);        });      _randomPlayer = new RandomPlayer(e.playlist);      if (_is_expo) {        initExpo();      }      // mainly for articles link      initAjaxLinks();      _$body.attr('corpus-map', 'ready');    }    function openEntree(tid){      if(tid){        closeAllModals();        _$body.removeClass();//.addClass(body_classes.join(' '));        // open entree        if(_corpus_ready){          _$corpus_canvas.trigger({            type:'open-entree',            tid:tid          });        }else{          // else : EdlpCorpus will check when ready if entry item (notice or index) is already .is-active          $('li.entree[tid="'+tid+'"] a.term-link').addClass('is-active');        }      }    };    function checkVisibleCorpusMapSpace(){      var left_limit = 0, right_limit = 0;      _$row.find('.col').each(function(i,e){        var $col = $(this);        var offset = $col.offset();        console.log('$col', $col);        switch(true){          case $col.is('.float-right'):            right_limit = Math.max(right_limit, Math.abs(offset.left-15-window.innerWidth));            break;          default:            left_limit = Math.max(left_limit, offset.left+$col.width()+15);            break;        }      });      console.log('checkVisibleCorpusMapSpace left_limit:'+left_limit+" right_limit:"+right_limit);      if(_corpus_ready){        _$body.trigger({          type:'visible-space-changed',          left_limit:left_limit,          right_limit:right_limit        });      }else{        _corpus_promise.done(function(){          _$body.trigger({            type:'visible-space-changed',            left_limit:left_limit,            right_limit:right_limit          });        });      }    };    //    _          _ _    //   /_\ _  _ __| (_)___    //  / _ \ || / _` | / _ \    // /_/ \_\_,_\__,_|_\___/    //    // https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement    // https://docs.microsoft.com/en-us/previous-versions/windows/internet-explorer/ie-developer/samples/gg589528%28v%3dvs.85%29    // https://www.binarytides.com/using-html5-audio-element-javascript/    function AudioPlayer(){      var that = this;      this.fid;      this.audio = new Audio();      // audio events      this.audio_events = ["loadedmetadata","playing","pause","timeupdate","ended","error"]; // ,"canplay"      // UI dom objects      this.$container   = $('<div id="audio-player">');      // btns      this.$btns        = $('<div>').addClass('btns').appendTo(this.$container);      this.$previous    = $('<div>').addClass('previous').appendTo(this.$btns);      this.$playpause   = $('<div>').addClass('play-pause').appendTo(this.$btns);      this.$next        = $('<div>').addClass('next').appendTo(this.$btns);      // timeline      this.$timelinecont= $('<div>').addClass('time-line-container').appendTo(this.$container);      this.$timeline    = $('<div>').addClass('time-line').appendTo(this.$timelinecont);      this.$loader      = $('<div>').addClass('loader').appendTo(this.$timeline);      this.$cursor      = $('<div>').addClass('cursor').appendTo(this.$timeline);      // time      this.$time        = $('<div>').addClass('time').appendTo(this.$container);      this.$currentTime = $('<div>').addClass('current-time').html('00:00').appendTo(this.$time);      this.$duration    = $('<div>').addClass('duration').html('00:00').appendTo(this.$time);      // favoris      this.$fav       = $('<div>').addClass('favoris').appendTo(this.$container);      // cartel      this.$cartel       = $('<div>').addClass('cartel').appendTo(this.$container);      this.scndCartel_visible = 0;      this.cartelSwitchIntervalMS = 7000;      this.cartelSwitchInterval = false;      // hiding      this.visible = false;      this.hideTimer = false;      this.hideTimeMS = 15000;      // history      this.currentHistoricIndex = null;      this.historic = [];      this.shuffle_is_active = false;      // artciles      this.auto_open_article = false;      // object events      this.event_handlers = {        'audio-open-document':[],        'audio-play':[],        'audio-pause':[],        'audio-play-next':[],        'audio-ended':[],        'stop-shuffle':[]      };      this.init();    };    AudioPlayer.prototype = {      init(){        if(!_is_expo){          this.$container_parent = $('header[role="banner"] .region-header');        }else{          this.$container_parent = $('main[role="main"]');        }        // append ui to document        this.$container.appendTo(this.$container_parent);        // record timeline width        this.timeline_w = parseInt(this.$timeline.width());        // init seeking        this.$loader.on('click', this.seek.bind(this));        // init audio events        var fn = '';        for (var i = 0; i < this.audio_events.length; i++) {          fn = this.audio_events[i];          // capitalize first letter of event (only cosmetic :p )          fn = 'on'+fn.charAt(0).toUpperCase()+fn.slice(1);          this.audio.addEventListener(            this.audio_events[i],            this[fn].bind(this),            true);        }        // init btns events        this.$previous.on('click', this.playPrevious.bind(this));        this.$playpause.on('click', this.togglePlayPause.bind(this));        this.$next.on('click', this.playNext.bind(this));      },      openDocument(node, caller, historic_index){        console.log('AudioPlayer openDocument', node, caller);        if(typeof node == 'undefined'          || typeof node.nid ==  'undefined'          || typeof node.audio_url == 'undefined'){          console.warn('AudioPlayer openDocument() node is malformed', node);          return false;        }        // if we don't come from history popstate        if(typeof caller == 'undefined' || caller != 'popstate'){          console.log('');          this.historic.push(node);          this.currentHistoricIndex = this.historic.length-1;          // this.shuffle_mode = shuffle_mode || false;          // add the document opening to history to be able to share and play audio from any where          if(caller != "history_first_load"){            if(typeof node.document_url == 'undefined'){              console.warn("AudioPlayer openDocument missing document_url, can't push state to history", caller, node);            }else{              var state = {                audio:true,                node:{                  nid:node.nid,                  audio_url:node.audio_url,                  document_url:node.document_url,                  title:node.title || null,                },                historic_index : this.currentHistoricIndex,              };              // console.log('AudioPlayer pushstate', state);              var url = node.document_url + (caller == 'random' ? '#random' : '');              history.pushState(state, null, url);            }          }        }else{          // if the call commes from popstate, we update the current position of index          this.currentHistoricIndex = historic_index;        }        if(_$body.is('.path-frontpage') && caller !== 'lastdocs' && !_is_mobile){          closeAllModals();        }        // TODO: update language switcher for document url        // TODO: stop random player if playing from studio        this.emmit('audio-open-document', {caller:caller});        // piwik        // debugger;        if(typeof _paq !== 'undefined'){          // page tracking          // https://matomo.org/blog/2017/02/how-to-track-single-page-websites-using-piwik-analytics/          // _paq.push(['setCustomUrl', state.url]);          // _paq.push(['setDocumentTitle', data.title]);          // _paq.push(['trackPageView']);          // js event          // trackEvent(category, action, [name], [value])          if(typeof node.title != 'undefined'){            _paq.push(['trackEvent', 'Audio', 'play', node.title]);          }        }        this.launch();      },      launch(){        this.clearTimeOutToHide();        this.clearIntervalAutoCartelSwitch();        this.setSRC(this.historic[this.currentHistoricIndex].audio_url);        if(!_is_mobile){          this.loadNode(this.historic[this.currentHistoricIndex].nid);        }        // emmit new playing doc (e.g.: corpus map nowing that audio played from RandomPlayer)        try {          _$corpus_canvas.trigger({            'type':'audio-node-opened',            'nid':this.historic[this.currentHistoricIndex].nid          });        } catch (e) {          console.info('AudioPlayer : _$corpus_canvas does not exists, testing promise');          var that = this;          _corpus_promise.done(function(){            _$corpus_canvas.trigger({              'type':'audio-node-opened',              'nid':that.historic[that.currentHistoricIndex].nid            });          });        }        this.showHidePreviousBtn();        this.showHideNextBtn();        this.show();      },      openSound(url, title){        this.hide();        this.clearTimeOutToHide();        this.$cartel.html("");        this.setSRC(url);        this.show();        if(typeof _paq !== 'undefined'){          _paq.push(['trackEvent', 'Audio', 'play', url]);        }      },      // audio functions      setSRC(url){        console.log('AudioPlayer setSRC : url', url);        this.audio.src = url;        // need to trigger play right now to prevent safari blocking auto-play        this.play();      },      // audio is ready to play      onLoadedmetadata(){        var rem = parseInt(this.audio.duration, 10),            mins = Math.floor(rem/60,10),            secs = rem - mins*60;        this.$duration.html('<span>'+(mins<10 ? '0':'')+mins+':'+(secs<10 ? '0':'')+secs+'</span>');        this.updateLoadingBar();      },      updateLoadingBar(){        console.log("updateLoadingBar");        // var that = this;        // if (this.audio.readyState === 4){        if(this.audio.buffered.length>0){          // debugger;          this.$loader.css({            'width':parseInt((100 * this.audio.buffered.end(0) / this.audio.duration), 10)+'%'          });          if( this.audio.buffered.end(0) < this.audio.duration ){            // loop through this function until file is fully loaded            window.requestAnimationFrame(this.updateLoadingBar.bind(this));          }else{            console.log('Audio fully loaded');          }        }else{          // as audio buffer is not ready, recall updateLoadingBar in next frame          window.requestAnimationFrame(this.updateLoadingBar.bind(this));        }      },      // onCanplay(){      //   // this.play();      // },      onError(){        console.warn("Audio Error " + this.audio.error.code + "; details: " + this.audio.error.message);      },      play(){        this.clearTimeOutToHide();        // this.audio.play();        // making sound shorter for debuging purpose        // if(_is_expo){        //   setTimeout(this.seekToEnd.bind(this), 20000);        // }        // Not really needed has we trigger play right after setting the source https://stackoverflow.com/questions/47431439/mp4-video-safari-showing-unhandled-promise-rejection-object-domerror-in-c        var promise = this.audio.play();        // console.log('promise', promise);        if (promise !== undefined) {          promise.catch(function(error){              // Auto-play was prevented              // Show a UI element to let the user manually start playback              console.warn('autoplay failed, ask for playing', error);          }).then(function(){              // Auto-play started              console.log('autoplay succeed');          });        }      },      playPrevious(){        if(this.currentHistoricIndex > 0){          this.currentHistoricIndex -= 1;          this.launch();          // TODO: update history state        }      },      playNext(){        if(this.currentHistoricIndex < this.historic.length-1){          this.currentHistoricIndex += 1;          this.launch();          // TODO: update history state        }else{          this.emmit('audio-play-next');        }      },      togglePlayPause(e){        if(this.audio.paused){          // this.audio.play();          this.play();        }else{          // this.audio.pause();          this.stop();        }      },      stop(){        // console.log('AudioPlayer stop()');        // debugger;        this.audio.pause();        // don't close player if article or transcript is open        if(!(_$body.is('.path-node-'+this.historic[this.currentHistoricIndex].nid)          && (_$body.is('.view-mode-article') || _$body.is('.view-mode-transcript')))){          this.timeOutToHide();        }      },      seek(e){        var seek = e.originalEvent.layerX / this.timeline_w * this.audio.duration        console.log("Audio seeking : seek", seek);        this.audio.currentTime = seek;      },      seekToEnd(){        if (this.audio.duration > 40) {          console.log("seekToEnd", this.audio.duration);          this.audio.currentTime = this.audio.duration - 20;        }      },      // audio events      onPlaying(){        this.$btns.addClass('is-playing');        this.emmit('audio-play');      },      onPause(){        this.$btns.removeClass('is-playing');        this.emmit('audio-pause');      },      onTimeupdate(){        // move cursor        this.$cursor.css({          'left':(this.audio.currentTime/this.audio.duration * this.timeline_w)+"px"        });        // update time text display        var rem = parseInt(this.audio.currentTime, 10),            mins = Math.floor(rem/60,10),            secs = rem - mins*60;        this.$currentTime.html('<span>'+(mins<10 ? '0':'')+mins+':'+(secs<10 ? '0':'')+secs+'</span>');      },      onEnded(){        console.log('AudioPlayer onEnded()');        this.stop();        this.emmit('audio-ended');      },      // cartel functions      reloadNode(){        if(this.visible){          if(!_is_mobile){            console.log('reloadNode (cartel)');            this.loadNode(this.historic[this.currentHistoricIndex].nid);          }        }      },      loadNode(nid){        this.$cartel.addClass('loading');        var vm = 'player_cartel';        var ajax_path = _ajax_settings.entityjson_path+'/node/'+nid+'/'+vm;        var path = _origin + Drupal.url(ajax_path);        $.getJSON(path, {})          .done(this.onNodeLoaded.bind(this))          .fail(this.onNodeLoadFail.bind(this));      },      onNodeLoaded(data){        console.log('AudioPlayer node loaded');//, data);        this.$cartel.html(data.rendered).removeClass('loading');        _$body.trigger({'type':'new-audio-cartel-loaded'});        initAjaxLinks();        // cartel autoswitch        this.scndCartel_visible = 0;        this.$cartel.removeClass('second-visible');        if(!_is_expo){          // if second cartel has special info ?          if (this.$cartel.find('.second-cartel .col-left').children().length > 1              || this.$cartel.find('.second-cartel').children('.col-right').length){            // init cartel auto switch            this.cartelSwitchInterval = setInterval(this.switchCartel.bind(this), this.cartelSwitchIntervalMS);          }          // call drupal behaviours (for addtoany)          Drupal.attachBehaviors(this.$cartel);        }        // open automaticly tha article if needed        this.setAutoOpenArticle();        if(this.auto_open_article){          this.$cartel.find('a.link-article').trigger('click');          this.auto_open_article = false;        }      },      onNodeLoadFail(jqxhr, textStatus, error){        console.warn('AudioPlayer node load failed', jqxhr.responseText);        this.$cartel.removeClass('loading').html('');      },      setAutoOpenArticle(art){        this.auto_open_article = $('a.articles-link').is('.is-active');        return this;      },      // global      show(){        this.visible = true;        this.$container_parent.addClass('audio-player-visible');        this.$container.addClass('visible');      },      showHidePreviousBtn(){        if(this.historic.length > 1 && this.currentHistoricIndex > 0){          this.$previous.addClass('is-active');        }else{          this.$previous.removeClass('is-active');        }      },      showHideNextBtn(){        if(this.currentHistoricIndex < this.historic.length-1 || this.shuffle_is_active){          this.$next.addClass('is-active');        }else{          this.$next.removeClass('is-active');        }      },      timeOutToHide(){        // console.log('AudioPlayer timeOutToHide()');        this.clearTimeOutToHide();        this.hideTimer = setTimeout(this.hide.bind(this), this.hideTimeMS);      },      clearTimeOutToHide(){        // console.log('AudioPlayer clearTimeOutToHide()',this.hideTimer);        if(this.hideTimer){          clearTimeout(this.hideTimer);          this.hideTimer = false;        }      },      // cartel      switchCartel(){        // console.log("switchCartel", this.scndCartel_visible);        if (this.scndCartel_visible) {          // return to first cartel          this.$cartel.removeClass('second-visible');          this.scndCartel_visible = 0;          // kill the auto switch after one rotation          this.clearIntervalAutoCartelSwitch();        }else{          // switch to 2nd cartel          this.$cartel.addClass('second-visible');          this.scndCartel_visible = 1;        }      },      clearIntervalAutoCartelSwitch(){        if(this.cartelSwitchInterval){          clearInterval(this.cartelSwitchInterval);          this.cartelSwitchInterval = false;        }      },      hide(){        // console.log('AudioPlayer hide()');        this.visible = false;        this.$container_parent.removeClass('audio-player-visible');        this.$container.removeClass('visible');        // trigger highlighted node remove on corpus map        try {          _$corpus_canvas.trigger('audio-node-closed');        } catch (e) {          console.info('AudioPlayer hide() : _$corpus_canvas does not exists');        }      },      deActivateRandom(){        this.shuffle_is_active = false;        this.showHideNextBtn();      },      // object events      on(event_name, handler){        if(typeof this.event_handlers[event_name] == 'undefined'){          console.warn('AudioPlayer : event '+event_name+' does not exists');        }        this.event_handlers[event_name].push(handler);        return this;      },      emmit(event_name, args){        console.log('AudioPlayer emmit()', event_name, args, this.event_handlers[event_name]);        // console.log('AudioPlayer emmit() handlers', this.event_handlers[event_name]);        var handler;        var args  = args || {};        for (var i = this.event_handlers[event_name].length-1; i >= 0 ; i--) {          handler = this.event_handlers[event_name][i];          // console.log('AudioPlayer emmit() loop handler', handler);          (function(handler, args){            setTimeout(function(){              // console.log('AudioPlayer emmit() timeout handler', handler);              handler(args);            }, 0);          }(handler, args));        }        return this;      },    }    //  ___              _           ___ _    // | _ \__ _ _ _  __| |___ _ __ | _ \ |__ _ _  _ ___ _ _    // |   / _` | ' \/ _` / _ \ '  \|  _/ / _` | || / -_) '_|    // |_|_\__,_|_||_\__,_\___/_|_|_|_| |_\__,_|\_, \___|_|    //                                          |__/    function RandomPlayer(playlist){      this.active = false;      this.playlist = playlist;      this.path =  _base_url+drupalSettings.path.pathPrefix+'#random'      this.$btn = $('<a>')        .html('Shuffle')        .attr('href',this.path)        .attr('alt', drupalSettings.edlp_corpus.random_link_title)        .addClass('random-player-btn');      this.init();    };    RandomPlayer.prototype = {      init(){        // this.shuffle();        $('<div>')          .addClass('block random-player')          .append(this.$btn)          // .insertAfter('#block-userlogin, #block-studiolinkblock');          .prependTo('.region-footer-right');        // events        this.$btn.on('click', this.toggleActive.bind(this));        // attach an event on AudioPlayer        _audioPlayer          .on('audio-play-next', this.onAudioPlayNext.bind(this))          .on('audio-ended', this.onAudioPlayerEnded.bind(this))          .on('stop-shuffle', this.stop.bind(this));        _$corpus_canvas          .on('update-random-playlist', this.updatePlaylist.bind(this));        // provide a link to auto start random player        if(window.location.hash == '#random'){          this.start();        }      },      updatePlaylist(e){        if (!_is_expo) {          this.playlist = e.playlist;          this.shuffle();        }      },      shuffle(){        var tempPLaylist = [];        for (var i = this.playlist.length-1; i >= 0 ; i--) {          tempPLaylist.push(this.playlist[i]);        }        this.shuffledPlaylist = [];        while(tempPLaylist.length > 0){          var r = Math.floor(Math.random() * tempPLaylist.length);          this.shuffledPlaylist.push(tempPLaylist.splice(r,1)[0]);        }        //console.log('RandomPlayer, this.shuffledPlaylist', this.shuffledPlaylist);      },      toggleActive(e){        e.preventDefault();        if (this.active) {          this.stop();        }else{          this.start();        }        return false;      },      start(){        this.active = _audioPlayer.shuffle_is_active = true;        this.$btn.addClass('is-active');        this.shuffle();        this.next();        // piwik        if(typeof _paq !== 'undefined'){          // trackEvent(category, action, [name], [value])          _paq.push(['trackEvent', 'RandomPlayer', 'start']);        }      },      stop(){        this.active = false;        this.$btn.removeClass('is-active');        // stop audio player        // _audioPlayer.stop();        // remove hash        history.replaceState(history.state, null, window.location.pathname);        // tell to AudioPlayer to deactivate netx btn        _audioPlayer.deActivateRandom();        if(typeof _paq !== 'undefined'){          // trackEvent(category, action, [name], [value])          _paq.push(['trackEvent', 'RandomPlayer', 'stop']);        }      },      next(){        console.log('RandomPlayer next', this.active, this.shuffledPlaylist.length);        if(this.active){          if (this.shuffledPlaylist.length == 0) {            this.shuffle();          }          _audioPlayer.openDocument(this.shuffledPlaylist.splice(0,1)[0], 'random');        }      },      onAudioPlayNext(){        console.log('RandomPlayer : onAudioPlayNext()');        if(this.active){          this.next();        }      },      onAudioPlayerEnded(){        console.log('RandomPlayer : onAudioPlayerEnded()');        if(this.active){          this.next();          if(_is_expo){            _$corpus_canvas.trigger({'type':'scramble-collection'}); //shuffle-collection scramble-collection          }        }      }    };    //   ___                     ___ _    //  / __|___ _ __  _ __  ___| _ \ |__ _ _  _ ___ _ _    // | (__/ _ \ '  \| '_ \/ _ \  _/ / _` | || / -_) '_|    //  \___\___/_|_|_| .__/\___/_| |_\__,_|\_, \___|_|    //                |_|                   |__/    function CompoPlayer(){      this.active = false;      this.playing = false;      this.paused = false;      this.playlist = [];      this.current_index = 0;      this.$composer = null;      this.$compo = null;      this.$controls = null;      this.init();    };    CompoPlayer.prototype = {      init(){        // console.log('CompoPlayer init()');        // attach an event on AudioPlayer        _audioPlayer          .on('audio-open-document', this.onAudioOpenDocument.bind(this))          .on('audio-play', this.onAudioPlayerPlay.bind(this))          .on('audio-pause', this.onAudioPlayerPause.bind(this))          .on('audio-ended', this.onAudioPlayerEnded.bind(this));          // .on('audio-play-next', this.onAudioPlayNext.bind(this));        // this.newCompo();      },      newCompo(){        console.log('CompoPlayer newCompo()');        // this.$compo = $('.composition_ui .composer .composition');        this.initControls();      },      initControls(){        //console.log('CompoPlayer initControls()');        this.$composer = $('.composition_ui .composer');        this.$compo = $('.composition_ui .composer .composition');        this.$controls = $('.composition_ui .composer .compo-player-controls');        if(!this.$controls.is('.ready') && this.$compo){          this.$previous = $('<div>').addClass('previous')            .on('click', this.prev.bind(this))            .appendTo(this.$controls);          this.$playpause = $('<div>').addClass('play-pause')            .on('click', this.togglePlayPause.bind(this))            .appendTo(this.$controls);          this.$next = $('<div>').addClass('next')            .on('click', this.next.bind(this))            .appendTo(this.$controls);          this.$controls.addClass('ready');          this.active = true;          // this.newCompo();        }        this.refresh();      },      refresh(){        // console.log('CompoPlayer refresh(), this', this);        this.stop();        // load new playlist        this.playlist = [];        var that = this;        $('.field--name-documents .field__item',this.$compo).each(function(i,el){          var $link = $('a.audio-link',this);          that.playlist.push({            item:$(this),            audio_url:$link.attr("audio_url"),            nid:$link.attr("nid"),          });        });        this.showHideControls();      },      togglePlayPause(){        // console.log('CompoPlayer togglePlayPause');        if (this.playing && !this.paused) {          this.pause();        }else{          if(this.playing && this.paused){            this.play();          }else{            this.start();          }        }      },      start(i){        //console.log('start');        // console.log('CompoPlayer start()');        this.current_index = i || 0;        this.playing = true;        this.play();      },      play(){        console.log('CompoPlayer play()', this.playlist[this.current_index]);        if(this.paused){          this.paused = false;          _audioPlayer.play();        }else{          console.log('CompoPlayer opendoc with audio player');          // _audioPlayer;          _audioPlayer.emmit('stop-shuffle').openDocument(this.playlist[this.current_index], this);        }        this.setActiveItem().showHideControls();      },      pause(){        //console.log('pause');        this.paused = true;        this.showHideControls();        _audioPlayer.stop();      },      next(){        console.log('CompoPlayer next()',this.playing);        if(this.playing){          this.current_index += 1;          if(this.current_index < this.playlist.length){            this.play();          }else{            this.stop();          }        }      },      prev(){        // console.log('CompoPlayer prev()');        if(this.playing){          this.current_index -= 1;          if(this.current_index >= 0){            this.play();          }else{            this.stop();          }        }      },      stop(){        if(this.playing){          _audioPlayer.stop();        }        this.reset();      },      reset(){        this.playing = false;        this.paused = false;        this.resetIndex();      },      resetIndex(){        this.current_index = 0;        this.showHideControls().resetActiveItems();      },      setActiveItem(){        this.resetActiveItems();        if(this.playing && this.current_index >= 0){          this.playlist[this.current_index].item.addClass('is-active');        }        // this call shoud not be here        this.showHideControls();        return this;      },      resetActiveItems(){        for (var n = 0; n < this.playlist.length; n++) {          // console.log('node',node);          this.playlist[n].item.removeClass('is-active');        }        return this;      },      showHideControls(){        // console.log('CompoPlayer showHideNextBtn(), playing:'+this.playing+', paused:'+this.paused);        // global playing        if(this.$controls){          if(this.playing && !this.paused){            this.$controls.addClass('is-playing');          }else{            this.$controls.removeClass('is-playing');          }        }        // playpause        if(this.$playpause){          if(this.playlist.length > 0){            this.$playpause.addClass('is-active');          }else{            this.$playpause.removeClass('is-active');          }        }        // next        if(this.$next){          if(this.playing && this.playlist.length > 1 && this.current_index < this.playlist.length -1){            this.$next.addClass('is-active');          }else{            this.$next.removeClass('is-active');          }        }        // previous        if(this.$previous){          if(this.playing && this.playlist.length > 1 && this.current_index > 0){            this.$previous.addClass('is-active');          }else{            this.$previous.removeClass('is-active');          }        }        return this;      },      deactivate(){        this.stop();        this.active = false;      },      // _audioPlayer events      onAudioOpenDocument(args){        console.log('Compo player onAudioOpenDocument', args);        if(args.caller !== this){          // console.log('CompoPlayer onAudioOpenDocument() called by other');          this.reset();        }        // else{        //   // console.log('CompoPlayer onAudioOpenDocument() self calling');        // }      },      onAudioPlayerPlay(){        if(this.playing && this.paused){          this.paused = false;          this.showHideControls();        }      },      onAudioPlayerPause(){        if(this.playing && !this.paused){          this.paused = true;          this.showHideControls();        }      },      onAudioPlayerEnded(){        console.log('onAudioPlayerEnded');        if(this.playing){          // this paused shoudn't be true but i'm lazzy to find why it is ...          this.paused = false;          this.next();        }      },      // onAudioPlayNext(){      //   this.next();      // }    };    //  ___    // | __|_ ___ __  ___    // | _|\ \ / '_ \/ _ \    // |___/_\_\ .__/\___/    //         |_|    function initExpo(){      console.log('initExpo', window.location.hash);      if(window.location.hash == '#black'){        $('body').addClass('expo-black');      }      _$body.on('map-node-opened', checkExpoPlayerPositionning);      _randomPlayer.start();    }    function checkExpoPlayerPositionning(e){      console.log('checkExpoPlayerPositionning', e.node);      switch(true){        case e.node.x > window.innerWidth-800 && e.node.y < 200:          _audioPlayer.$container.attr('pos', 'bottom-left');          break;        case e.node.x > window.innerWidth-800:          _audioPlayer.$container.attr('pos', 'top-left');          break;        case e.node.y < 200:          _audioPlayer.$container.attr('pos', 'bottom-right');          break;        default:          _audioPlayer.$container.attr('pos', 'top-right');      }      _audioPlayer.$container.css({        'display':"block",        'left':e.node.x+"px",        'top':e.node.y+"px",      });    }    //   ___     _    _    //  / __|_ _(_)__| |    // | (_ | '_| / _` |    //  \___|_| |_\__,_|    function initGrid(){      console.log('theme : initGrid');      if(!_is_mobile){        checkGridBlockHeight();        _$row.find('.col').addClass('offfield');      }      if(false){        var $grid = $('.grid',_$row).masonry({          itemSelector:'.col',          columnWidth:'.col-2',          containerStyle: null,          resizeContainer:false,          // horizontalOrder: true,          transitionDuration:0,//'0.2s',          // stagger:30,          // disable initial layout          // initLayout: false,        });        // layout Masonry after each image loads        $grid.imagesLoaded().progress( function() {          $grid.masonry('layout');        });        $grid.imagesLoaded(function(){          $grid.masonry('layout');          // checkProductionBlockVisible();        });        // bind event        // $grid.masonry( 'on', 'layoutComplete', function() {        //   console.log('layout is complete');        // });        $grid.on('layoutComplete', checkGridBlockVisible);      }else{        // setTimeout(checkGridBlockVisible, 100);        if(!_is_mobile){          checkGridBlockVisible();        }      }    };    function checkGridBlockHeight(){      // console.log('checkGridBlockHeight');      // if(_is_mobile) return;      var $r_h = _$row.height();      var $this;      // console.log($r_h);      $('.grid .col', _$row).each(function(i,e){        $this = $(this);        if(!$this.is('[init-height]')){          $this.attr('init-height', $this.outerHeight())        }        // console.log($(this).height(), $(this).innerHeight(), $(this).outerHeight());        // if($this.height() > $r_h){        //   $this.height($r_h);        // }else{        //   $this.height('auto');        // }        $this.height(Math.min($this.attr('init-height'), _$row.height()));      });    };    function checkGridBlockVisible(){      // console.log('checkGridBlockVisible');      // if(_is_mobile) return;      var $r_h = _$row.height();      var $this,pos;      $('.grid .col', _$row).each(function(i,e){        // $(this).on('load',function(event){          $this = $(this);          pos = $this.position();          // console.log(pos.top, $this.height(), pos.top+$this.height(), $r_h, $this);          if(pos.top+$this.height() <= $r_h){            $this.removeClass('offfield');          }else{            $this.addClass('offfield');          }        // });      });      // for (var i in items) {      //   if(!items[i].isTransitioning){      //     console.log('y+outerHeight', items[i].position.y+items[i].size.outerHeight);      //     console.log('_$row.height()', _$row.height());      //     if(items[i].position.y+items[i].size.outerHeight < _$row.height()){      //       $(items[i].element).removeClass('offfield');      //     }else{      //       // $(items[i].element).addClass('offfield');      //     }      //   }      // }    }    //  ___             _         _   _    // | _ \_ _ ___  __| |_  _ __| |_(_)___ _ _  ___    // |  _/ '_/ _ \/ _` | || / _|  _| / _ \ ' \(_-<    // |_| |_| \___/\__,_|\_,_\__|\__|_\___/_||_/__/    // function initProductions(){    //   console.log('theme : initProductions');    //    //   // _$row.find('.col').addClass('offfield');    //   var $grid = $('.grid',_$row).masonry({    //     itemSelector:'.col',    //     columnWidth:'.col-2',    //     containerStyle: null,    //     resizeContainer:false,    //     // horizontalOrder: true,    //     transitionDuration:0,//'0.2s',    //     // stagger:30,    //     // disable initial layout    //     // initLayout: false,    //   });    //    //   // layout Masonry after each image loads    //   $grid.imagesLoaded().progress( function() {    //     $grid.masonry('layout');    //   });    //    //   $grid.imagesLoaded(function(){    //     $grid.masonry('layout');    //     // checkProductionBlockVisible();    //   });    //    //   // bind event    //   // $grid.masonry( 'on', 'layoutComplete', function() {    //   //   console.log('layout is complete');    //   // });    //   // $grid.on('layoutComplete', checkProductionBlockVisible);    // };    //   ___     _ _        _   _    //  / __|___| | |___ __| |_(_)___ _ _    // | (__/ _ \ | / -_) _|  _| / _ \ ' \    //  \___\___/_|_\___\__|\__|_\___/_||_|    // mobile version of collection    function initCollectionNav(){      console.log('initCollectionNav');      // taxonomy-term.vocabulary-entrees.home_mobile      $('.field--name-field-notice, .index', '.taxonomy-term.vocabulary-entrees.home_mobile')        .addClass('closed');      $('.field--name-field-notice>.field__label', '.taxonomy-term.vocabulary-entrees.home_mobile')        .on('click', onClickCollectionNotice);      $('.index>.field__label', '.taxonomy-term.vocabulary-entrees.home_mobile')        .on('click', onClickCollectionIndex);    };    function onClickCollectionNotice(e){      // console.log('onClickCollectionNotice');      // var $part = $(this).parent();//parents('.taxonomy-term');      toggleEntreeOpening($(this).parent(), 'notice');    };    function onClickCollectionIndex(e){      // console.log('onClickCollectionIndex');      // var $part = $(this).parent();//parents('.taxonomy-term');      toggleEntreeOpening($(this).parent(), 'index');    };    function toggleEntreeOpening($e, part){      $e.toggleClass('closed')        .parents('.taxonomy-term.vocabulary-entrees.home_mobile').toggleClass(part+'-opened');    }    //  ___                  _    // / __| ___ __ _ _ _ __| |_    // \__ \/ -_) _` | '_/ _| ' \    // |___/\___\__,_|_| \__|_||_|    function initSearch(){      // if($('#edit-entries input:checked', '#edlp-search-form').length){      //   $('#edit-entries--wrapper', '#edlp-search-form').toggleClass('opened');      // }      $('#edit-entries--wrapper legend', '#edlp-search-form').on('click', function(){        $(this).parent().toggleClass('opened');      });    };    //  ___                   _    _                         _    // | __|_ _  _ _ ___ __ _(_)__| |_ _ _ ___ _ __  ___ _ _| |_    // | _|| ' \| '_/ -_) _` | (_-<  _| '_/ -_) '  \/ -_) ' \  _|    // |___|_||_|_| \___\__, |_/__/\__|_| \___|_|_|_\___|_||_\__|    //                  |___/    function initEnregistrementTranscript(){      console.log('initEnregistrementTranscript');      var $node = _$row.find('article.node--type-enregistrement.node--view-mode-transcript');      var $nav = $('<nav>').prependTo($node);      $node.find('.field--name-field-transcript-vo').addClass('visible').find('.field__label')        .clone().appendTo($nav).addClass('is-active')        .attr('field_target', '.field--name-field-transcript-vo');      $node.find('.field--name-field-transcript-trad').find('.field__label')        .clone().appendTo($nav)        .attr('field_target', '.field--name-field-transcript-trad');      $nav.find('.field__label').on('click', function(){        var $this = $(this).addClass('is-active');        $this.siblings('.is-active').removeClass('is-active');        $this.parents('article.node').find('.field.visible').removeClass('visible');        $this.parents('article.node').find($this.attr('field_target')).addClass('visible');      });    };    //  ___            _   ___    // | __| _ ___ _ _| |_| _ \__ _ __ _ ___    // | _| '_/ _ \ ' \  _|  _/ _` / _` / -_)    // |_||_| \___/_||_\__|_| \__,_\__, \___|    //                             |___/    function backToFrontPage(pop_state){      console.log('backToFrontPage', pop_state);      closeAllModals();      // assume we are going back to front page      $('body').removeClass().addClass('path-frontpage');      $('a[data-drupal-link-system-path="<front>"]').addClass('is-active');      // close entrees      if(_corpus_ready){        _$corpus_canvas.trigger({'type':'close-all-entree'});        _$corpus_canvas.trigger({'type':'scramble-collection'});      }      if(typeof pop_state == "undefined" || !pop_state){        console.log('backToFrontPage push state');        state = {          home:true,          context:"home",          caller:null        }        _states_history.unshift(state);        history.pushState(state, null, _base_url+drupalSettings.path.currentLanguage);      }    }    // function initHome(){    //   addCloseModalBtnToCols();      // return;      // console.log('theme : initHome');      // var $grid = $('.grid',_$row).masonry({      //   itemSelector:'.col',      //   columnWidth:'.col-2',      //   horizontalOrder: true,      //   containerStyle: null,      //   // disable initial layout      //   // initLayout: false,      // });      // // bind event      // // $grid.masonry( 'on', 'layoutComplete', function() {      // //   console.log('layout is complete');      // // });      //      // // layout Masonry after each image loads      // $grid.imagesLoaded().progress( function() {      //   $grid.masonry('layout');      // });      //      // $grid.imagesLoaded(function(){      //   $grid.masonry('layout');      // });    // }    //  __  __         _      _    // |  \/  |___  __| |__ _| |___    // | |\/| / _ \/ _` / _` | (_-<    // |_|  |_\___/\__,_\__,_|_/__/    function closeAllModals(){      //console.log('theme : closeAllModals');      // TODO: animate the remove      _$row.html('');      _$ajaxLinks.removeClass('is-active');      _$body.trigger({'type':'all-modal-closed'});      // checkRowEmpty();      checkVisibleCorpusMapSpace();    };    function checkRowEmpty(){      console.log('checkRowEmpty');      // if row is empty and we are not in productions or entree notice|index call closeAllModals()      if(!$('.col', _$row).length){        if(!_$body.is('.entity-type-taxonomy_term.bundle-entrees')){          if(!_$body.is('.entity-type-node.bundle-page')){            // we weren't on production or entree, so go back to front page            // debugger;            if(_$body.is('.bundle-enregistrement.view-mode-article')              && $('a.articles-link').is('.is-active')){                console.log('Closing article while article index is active');                // if node article and articles is active, reload index                $('a.articles-link').removeClass('is-active').trigger('click');            }else{              backToFrontPage();            }            // if(!$('a.articles-link').is('.is-active')){            //   // don't go back to front page if articles filter is on              // backToFrontPage();            // }else{            // }          }else{            // if we were on production page just scramble collection in case of map was filtered            if(_corpus_ready){              _$corpus_canvas.trigger({'type':'scramble-collection'});            }            // reload production home            $('a[data-drupal-link-system-path="productions"]', '#block-mainnavigation')              .removeClass('is-active').trigger('click');          }        }else{          // remove is-active class from index or notice entree links          $('.entree-content a.is-active').removeClass('is-active');          // TODO: remove the hash index or notice        }      }    };    init();  } // end EdlpTheme()  $(document).ready(function($) {    if(drupalSettings.path.isFront){      var edlptheme = new EdlpTheme();    }else{      $('body').attr('booted', 'booted');    }  });})(jQuery, Drupal, drupalSettings);
 |