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 );