131 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			131 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * 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);
 | 
