| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282 | 
(function ($) {    $(document).ready(function () {    lastObj = false;    thmrSpanified = false;    strs = Drupal.settings.thmrStrings;    $('body').addClass("thmr_call").attr("id", "thmr_" + Drupal.settings.page_id);    $('[thmr]')    .hover(      function () {        if (themerEnabled && this.parentNode.nodeName != 'BODY' && $(this).attr('thmr_curr') != 1) {          $(this).css('outline', 'red solid 1px');        }      },      function () {        if (themerEnabled && $(this).attr('thmr_curr') != 1) {          $(this).css('outline', 'none');        }      }    );    var themerEnabled = 0;    var themerToggle = function () {      themerEnabled = 1 - themerEnabled;      $('#themer-toggle :checkbox').attr('checked', themerEnabled ? 'checked' : '');      $('#themer-popup').css('display', themerEnabled ? 'block' : 'none');      if (themerEnabled) {        document.onclick = themerEvent;        if (lastObj != false) {          $(lastObj).css('outline', '3px solid #999');        }        if (!thmrSpanified) {          spanify();        }      }      else {        document.onclick = null;        if (lastObj != false) {          $(lastObj).css('outline', 'none');        }      }    };    $(Drupal.settings.thmr_popup)      .appendTo($('body'));    $('<div id="themer-toggle"><input type="checkbox" />'+ strs.themer_info +'</div>')      .appendTo($('body'))      .click(themerToggle);    $('#themer-popup').resizable();    $('#themer-popup')       .draggable({               opacity: .6,               handle: $('#themer-popup .topper')             })      .prepend(strs.toggle_throbber)    ;    // close box    $('#themer-popup .topper .close').click(function() {      themerToggle();    });  });    /**   * Known issue: IE does NOT support outline css property.   * Solution: use another browser   */  function themerHilight(obj) {    // hilight the current object (and un-highlight the last)    if (lastObj != false) {      $(lastObj).css('outline', 'none').attr('thmr_curr', 0);    }    $(obj).css('outline', '#999 solid 3px').attr('thmr_curr', 1);    lastObj = obj;  }  function themerDoIt(obj) {    if (thmrInPop(obj)) {      return true;    }    // start throbber    //$('#themer-popup img.throbber').show();    var objs = thmrFindParents(obj);    if (objs.length) {      themerHilight(objs[0]);      thmrRebuildPopup(objs);    }    return false;  }  function spanify() {    $('span[thmr]')      .each(function () {        // make spans around block elements into block elements themselves        var kids = $(this).children();        for(i=0;i<kids.length;i++) {          //console.log(kids[i].style.display);          if ($(kids[i]).css('display') != 'inline' && $(kids[i]).is('DIV, P, ADDRESS, BLOCKQUOTE, CENTER, DIR, DL, FIELDSET, FORM, H1, H2, H3, H4, H5, H6, HR, ISINDEX, MENU, NOFRAMES, NOSCRIPT, OL, PRE, TABLE, UL,  DD, DT, FRAMESET, LI, TBODY, TD, TFOOT, TH, THEAD, TR')) {            $(this).css('display', 'block');          }        }      });    thmrSpanified = true;    // turn off the throbber    //$('#themer-toggle img.throbber').hide();  }  function thmrInPop(obj) {    //is the element in either the popup box or the toggle div?    if (obj.id == "themer-popup" || obj.id == "themer-toggle") return true;    if (obj.parentNode) {      while (obj = obj.parentNode) {        if (obj.id=="themer-popup" || obj.id == "themer-toggle") return true;      }    }    return false;  }  function themerEvent(e) {    if (!e) {      var e = window.event;    };    if (e.target) var tg = e.target;    else if (e.srcElement) var tg = e.srcElement;    return themerDoIt(tg);  }  /**   * Find all parents with @thmr"   */  function thmrFindParents(obj) {    var parents = new Array();    if ($(obj).attr('thmr') != undefined) {      parents[parents.length] = obj;    }    if (obj && obj.parentNode) {      while ((obj = obj.parentNode) && (obj.nodeType != 9)) {        if ($(obj).attr('thmr') != undefined) {          parents[parents.length] = obj;        }      }    }    return parents;  }  /**   * Check to see if object is a block element   */  function thmrIsBlock(obj) {    if (obj.style.display == 'block') {      return true;    }    else if (obj.style.display == 'inline' || obj.style.display == 'none') {      return false;    }    if (obj.tagName != undefined) {      var i = blocks.length;      if (i > 0) {        do {          if (blocks[i] === obj.tagName) {            return true;          }        } while (i--);      }    }    return false;  }  function thmrRefreshCollapse() {    $('#themer-popup .devel-obj-output dt').each(function() {        $(this).toggle(function() {              $(this).parent().children('dd').show();            }, function() {              $(this).parent().children('dd').hide();            });      });  }  /**   * Rebuild the popup   *   * @param objs   *   The array of the current object and its parents. Current object is first element of the array   */  function thmrRebuildPopup(objs) {    // rebuild the popup box    var id = objs[0].getAttribute('thmr');    // vars is the settings array element for this theme item    var vars = Drupal.settings[id];    // strs is the translatable strings    var strs = Drupal.settings.thmrStrings;    var type = vars.type;    var key = vars.used;    // clear out the initial "click on any element" starter text    $('#themer-popup div.starter').empty();    if (type == 'func') {      // populate the function name      $('#themer-popup dd.key').empty().prepend('<a href="'+ strs.api_site +'api/search/'+ strs.drupal_version +'/'+ key +'" title="'+ strs.drupal_api_docs +'">'+ key +'()</a>');      $('#themer-popup dt.key-type').empty().prepend(strs.function_called);    }    else {      // populate the template name      $('#themer-popup dd.key').empty().prepend(key);      $('#themer-popup dt.key-type').empty().prepend(strs.template_called);    }    // parents    var parents = '';    parents = strs.parents +' <span class="parents">';    for(i=1;i<objs.length;i++) {      var thmrid = $(objs[i]).attr('thmr')      var pvars = Drupal.settings[thmrid];      parents += i!=1 ? '< ' : '';      // populate the parents      // each parent is wrapped with a span containing a 'trig' attribute with the id of the element it represents      parents += '<span class="parent" trig="'+ thmrid +'">'+ pvars.name +'</span> ';    }    parents += '</span>';    // stick the parents spans in the #parents div    $('#themer-popup #parents').empty().prepend(parents);    $('#themer-popup span.parent')      .click(function() {        var thmr_id = $(this).attr('trig');        var thmr_obj = $('[thmr = "' + thmr_id + '"]')[0];        themerDoIt(thmr_obj);      })      .hover(        function() {          // make them highlight their element on mouseover          $('#'+ $(this).attr('trig')).trigger('mouseover');        },        function() {          // and unhilight on mouseout          $('#'+ $(this).attr('trig')).trigger('mouseout');        }      );    if (vars == undefined) {      // if there's no item in the settings array for this element      $('#themer-popup dd.candidates').empty();      $('#themer-popup dd.preprocessors').empty();      $('#themer-popup div.attributes').empty();      $('#themer-popup div.used').empty();      $('#themer-popup div.duration').empty();    }    else {      $('#themer-popup div.duration').empty().prepend('<span class="dt">' + strs.duration + '</span>' + vars.duration + ' ms');      $('#themer-popup dd.candidates').empty().prepend(vars.candidates.join('<span class="delimiter"> < </span>'));      $('#themer-popup dd.preprocessors').empty().prepend(vars.preprocessors.join('<span class="delimiter"> + </span>'));      $('#themer-popup dt.preprocessors-type').empty().prepend(strs.preprocessors);      $('#themer-popup dd.processors').empty().prepend(vars.processors.join('<span class="delimiter"> + </span>'));      $('#themer-popup dt.processors-type').empty().prepend(strs.processors);      var uri = Drupal.settings.devel_themer_uri + '/' + id;      if (type == 'func') {          // populate the candidates          $('#themer-popup dt.candidates-type').empty().prepend(strs.candidate_functions);      }      else {        $('#themer-popup dt.candidates-type').empty().prepend(strs.candidate_files);      }      // Use drupal ajax to do what we need       vars_div_array = $('div.themer-variables');      vars_div = vars_div_array[0];            // Programatically using the drupal ajax things is tricky, so cheat.      dummy_link = $('<a href="'+uri+'" class="use-ajax">Loading Vars</a>');      $(vars_div).append(dummy_link);      Drupal.attachBehaviors(vars_div);      dummy_link.click();            thmrRefreshCollapse();    }    // stop throbber    //$('#themer-popup img.throbber').hide();  }})(jQuery);
 |