File "redux-sorter.js"

Full Path: /home/elegucvf/public_html/video/wp-content/plugins/atlas-core/framework/redux-core/inc/fields/sorter/redux-sorter.js
File size: 4.68 KB
MIME-type: text/plain
Charset: utf-8

/*global redux, redux_change */
/*
 * Field Sorter jquery function
 * Based on
 * [SMOF - Slightly Modded Options Framework](http://aquagraphite.com/2011/09/slightly-modded-options-framework/)
 * Version 1.4.2
 */

(function( $ ) {
	'use strict';

	var scrollDir = '';

	redux.field_objects        = redux.field_objects || {};
	redux.field_objects.sorter = redux.field_objects.sorter || {};

	redux.field_objects.sorter.init = function( selector ) {
		selector = $.redux.getSelector( selector, 'sorter' );

		$( selector ).each(
			function() {
				var el     = $( this );
				var parent = el;

				if ( ! el.hasClass( 'redux-field-container' ) ) {
					parent = el.parents( '.redux-field-container:first' );
				}

				if ( parent.is( ':hidden' ) ) {
					return;
				}

				if ( parent.hasClass( 'redux-field-init' ) ) {
					parent.removeClass( 'redux-field-init' );
				} else {
					return;
				}

				/**    Sorter (Layout Manager) */
				el.find( '.redux-sorter' ).each(
					function() {
						var id         = $( this ).attr( 'id' );
						var inRepeater = $( this ).hasClass( 'in-repeater' );

						el.find( '#' + id ).find( 'ul' ).sortable(
							{
								items: 'li',
								placeholder: 'placeholder',
								connectWith: '.sortlist_' + id,
								opacity: 0.8,
								scroll: false,
								out: function( event, ui ) {
									event = null;

									if ( ! ui.helper ) {
										return;
									}

									if ( ui.offset.top > 0 ) {
										scrollDir = 'down';
									} else {
										scrollDir = 'up';
									}

									redux.field_objects.sorter.scrolling( $( this ).parents( '.redux-field-container:first' ) );
								},
								over: function() {
									scrollDir = '';
								},
								deactivate: function() {
									scrollDir = '';
								},
								stop: function( event, ui ) {
									var sorter;
									var id;
									var index;

									event = null;

									if ( inRepeater ) {
										index = $( this ).attr( 'data-repeater-id' );
									} else {
										index = $( this ).attr( 'data-id' );
									}

									sorter = redux.optName.sorter[index];
									id     = $( this ).find( 'h3' ).text();

									if ( undefined !== sorter.limits && sorter.limits && id && sorter.limits[id] ) {
										if ( $( this ).children( 'li' ).length >= sorter.limits[id] ) {
											$( this ).addClass( 'filled' );
											if ( $( this ).children( 'li' ).length > sorter.limits[id] ) {
												$( ui.sender ).sortable( 'cancel' );
											}
										} else {
											$( this ).removeClass( 'filled' );
										}
									}
								},
								update: function( event, ui ) {
									var sorter;
									var id;
									var index;

									event = null;

									if ( inRepeater ) {
										index = $( this ).attr( 'data-repeater-id' );
									} else {
										index = $( this ).attr( 'data-id' );
									}

									sorter = redux.optName.sorter[index];
									id     = $( this ).find( 'h3' ).text();

									if ( undefined !== sorter.limits && sorter.limits && id && sorter.limits[id] ) {
										if ( $( this ).children( 'li' ).length >= sorter.limits[id] ) {
											$( this ).addClass( 'filled' );
											if ( $( this ).children( 'li' ).length > sorter.limits[id] ) {
												$( ui.sender ).sortable( 'cancel' );
											}
										} else {
											$( this ).removeClass( 'filled' );
										}
									}

									$( this ).find( '.position' ).each(
										function() {
											var optionID;
											var suffix;

											var listID   = $( this ).parent().attr( 'data-id' );
											var parentID = $( this ).parent().parent().attr( 'data-group-id' );

											redux_change( $( this ) );

											suffix = $( this ).parent().parent().attr( 'data-suffix' );

											if ( inRepeater ) {
												optionID = $( this ).parent().parent().attr( 'data-repeater-id' );
											} else {
												optionID = $( this ).parent().parent().attr( 'data-id' );
											}

											$( this ).prop( 'name', redux.optName.args.opt_name + '[' + optionID + ']' + suffix + '[' + parentID + '][' + listID + ']' );
										}
									);
								}
							}
						);

						el.find( '.redux-sorter' ).disableSelection();
					}
				);
			}
		);
	};

	redux.field_objects.sorter.scrolling = function( selector ) {
		var scrollable;

		if ( undefined === selector ) {
			return;
		}

		scrollable = selector.find( '.redux-sorter' );

		if ( 'up' === scrollDir ) {
			scrollable.scrollTop( scrollable.scrollTop() - 20 );
			setTimeout( redux.field_objects.sorter.scrolling, 50 );
		} else if ( 'down' === scrollDir ) {
			scrollable.scrollTop( scrollable.scrollTop() + 20 );
			setTimeout( redux.field_objects.sorter.scrolling, 50 );
		}
	};
})( jQuery );