PATH:
home
/
lab2454c
/
mact34.com
/
wp-content
/
plugins
/
tryo-toolkit
/
redux
/
ReduxCore
/
inc
/
fields
/
sorter
/*global redux, redux_opts*/ /* * 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"; redux.field_objects = redux.field_objects || {}; redux.field_objects.sorter = redux.field_objects.sorter || {}; var scroll = ''; $( document ).ready( function() { //redux.field_objects.sorter.init(); } ); redux.field_objects.sorter.init = function( selector ) { if ( !selector ) { selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-sorter:visible' ); } $( 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" ) ) { // Skip hidden fields 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' ); el.find( '#' + id ).find( 'ul' ).sortable( { items: 'li', placeholder: "placeholder", connectWith: '.sortlist_' + id, opacity: 0.8, scroll: false, out: function( event, ui ) { if ( !ui.helper ) return; if ( ui.offset.top > 0 ) { scroll = 'down'; } else { scroll = 'up'; } redux.field_objects.sorter.scrolling( $( this ).parents( '.redux-field-container:first' ) ); }, over: function( event, ui ) { scroll = ''; }, deactivate: function( event, ui ) { scroll = ''; }, stop: function( event, ui ) { var sorter = redux.sorter[$( this ).attr( 'data-id' )]; var id = $( this ).find( 'h3' ).text(); if ( 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 = redux.sorter[$( this ).attr( 'data-id' )]; var id = $( this ).find( 'h3' ).text(); if ( 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 listID = $( this ).parent().attr( 'id' ); var listID = $( this ).parent().attr( 'data-id' ); var parentID = $( this ).parent().parent().attr( 'data-group-id' ); redux_change( $( this ) ); var optionID = $( this ).parent().parent().parent().attr( 'id' ); $( this ).prop( "name", redux.args.opt_name + '[' + optionID + '][' + parentID + '][' + listID + ']' ); } ); } } ); el.find( ".redux-sorter" ).disableSelection(); } ); } ); }; redux.field_objects.sorter.scrolling = function( selector ) { if (selector === undefined) { return; } var scrollable = selector.find( ".redux-sorter" ); if ( scroll == 'up' ) { scrollable.scrollTop( scrollable.scrollTop() - 20 ); setTimeout( redux.field_objects.sorter.scrolling, 50 ); } else if ( scroll == 'down' ) { scrollable.scrollTop( scrollable.scrollTop() + 20 ); setTimeout( redux.field_objects.sorter.scrolling, 50 ); } }; })( jQuery );
[+]
..
[-] field_sorter.css.map
[edit]
[-] field_sorter.scss
[edit]
[-] field_sorter.js
[edit]
[-] field_sorter.css
[edit]
[-] field_sorter.min.js
[edit]
[-] field_sorter.php
[edit]