123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130 |
- /**
- * Implementation of Drupal behavior.
- */
- (function($) {
- Drupal.behaviors.rubik = {};
- Drupal.behaviors.rubik.attach = function(context, settings) {
- // If there are both main column and side column buttons, only show the main
- // column buttons if the user scrolls past the ones to the side.
- $('div.form:has(div.column-main div.form-actions):not(.rubik-processed)', context).each(function() {
- var form = $(this);
- var offset = $('div.column-side div.form-actions', form).height() + $('div.column-side div.form-actions', form).offset().top;
- $(window).scroll(function() {
- if ($(this).scrollTop() > offset) {
- $('div.column-main .column-wrapper > div.form-actions#edit-actions', form).show();
- }
- else {
- $('div.column-main .column-wrapper > div.form-actions#edit-actions', form).hide();
- }
- });
- form.addClass('rubik-processed');
- });
- $('a.toggler:not(.rubik-processed)', context).each(function() {
- var id = $(this).attr('href').split('#')[1];
- // Target exists, add click handler.
- if ($('#' + id).size() > 0) {
- $(this).click(function() {
- var toggleable = $('#' + id);
- toggleable.toggle();
- $(this).toggleClass('toggler-active');
- return false;
- });
- }
- // Target does not exist, remove click handler.
- else {
- $(this).addClass('toggler-disabled');
- $(this).click(function() { return false; });
- }
- // Mark as processed.
- $(this).addClass('rubik-processed');
- });
- // If there's no active secondary tab, make the first one show.
- var activeli = $('.primary-tabs li.active .secondary-tabs li.active');
- if (activeli.length === 0) {
- $('.primary-tabs li.active .secondary-tabs li:first-child a').css('display', 'block');
- }
-
- $('.secondary-tabs li a, .secondary-tabs', context).bind('focus blur', function(){
- $(this).parents('.secondary-tabs').toggleClass('focused');
- });
- // Sticky sidebar functionality.
- var disableSticky = (settings.rubik !== undefined) ? settings.rubik.disable_sticky : false;
- if ($('#content .column-side .column-wrapper').length !== 0 ) {
- // Move fields to sidebar if it exists.
- $('.rubik_sidebar_field', context).once('rubik', function() {
- $('.column-side .column-wrapper').append($(this));
- });
- // Check if the sidebar should be made sticky.
- if (!disableSticky) {
- var rubikColumn = $('#content .column-side .column-wrapper', context);
- if (rubikColumn && rubikColumn.offset()) {
- var rubikStickySidebar = rubikColumn.offset().top;
- $(window).scroll(function() {
- if ($(window).scrollTop() > rubikStickySidebar) {
- rubikColumn.each(function() {
- $(this).addClass("fixed");
- $(this).width($(this).parent().width());
- });
- }
- else {
- rubikColumn.each(function() {
- $(this).removeClass("fixed");
- $(this).width($(this).parent().width());
- });
- }
- });
- }
- }
- }
-
- // Cache the primary tabs.
- var $primaryTabsWrap = $('.primary-tabs');
- if ($primaryTabsWrap.length) {
- var $primaryTabs = $primaryTabsWrap.find('> li');
- // Trigger adjusting function upon first page load.
- adjustPrimaryTabs();
- // Trigger adjusting function upon any screen resizing.
- $(window).resize(function() {
- adjustPrimaryTabs();
- });
- }
- function adjustPrimaryTabs() {
- // Get the position of whole element.
- var parentPosition = $primaryTabs.offset().top;
- // Complicated count.
- var count = [];
- var rowNumber = 1;
- // Remove remainings of other classes we attached.
- $primaryTabs.removeClass('last-row-link');
- $primaryTabs.removeClass('first-row-link');
- // Loop through and compare the position of each tab.
- $primaryTabs.each(function(index) {
- var $this = $(this);
- // New row.
- if (count[rowNumber] != $this.offset().top) {
- // Increase the count for this row.
- rowNumber++;
- count[rowNumber] = $this.offset().top;
- // Add "first" class to this element.
- $this.addClass('first-row-link');
- // Add "last" class to the previous element, if there is one.
- if ($this.prev('li').length) {
- $this.prev('li').addClass('last-row-link');
- }
- }
- // Add "last" class if this is the last element.
- if (index === ($primaryTabs.length - 1)) {
- $this.addClass('last-row-link');
- }
- });
- }
- };
- })(jQuery);
|