/* global confirm, redux, redux_change */
/*global redux_change, redux*/
(function( $ ) {
"use strict";
redux.field_objects = redux.field_objects || {};
redux.field_objects.image_select = redux.field_objects.image_select || {};
$( document ).ready(
function() {
//redux.field_objects.image_select.init();
}
);
redux.field_objects.image_select.init = function( selector ) {
if ( !selector ) {
selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-image_select: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;
}
// On label click, change the input and class
el.find( '.redux-image-select label img, .redux-image-select label .tiles' ).click(
function( e ) {
var id = $( this ).closest( 'label' ).attr( 'for' );
$( this ).parents( "fieldset:first" ).find( '.redux-image-select-selected' ).removeClass( 'redux-image-select-selected' ).find( "input[type='radio']" ).attr(
"checked", false
);
$( this ).closest( 'label' ).find( 'input[type="radio"]' ).prop( 'checked' );
if ( $( this ).closest( 'label' ).hasClass( 'redux-image-select-preset-' + id ) ) { // If they clicked on a preset, import!
e.preventDefault();
var presets = $( this ).closest( 'label' ).find( 'input' );
var data = presets.data( 'presets' );
var merge = presets.data( 'merge' );
if( merge !== undefined && merge !== null ) {
if( $.type( merge ) === 'string' ) {
merge = merge.split('|');
}
$.each(data, function( index, value ) {
if( ( merge === true || $.inArray( index, merge ) != -1 ) && $.type( redux.options[index] ) === 'object' ) {
data[index] = $.extend(redux.options[index], data[index]);
}
});
}
if ( presets !== undefined && presets !== null ) {
var answer = confirm( redux.args.preset_confirm );
if ( answer ) {
el.find( 'label[for="' + id + '"]' ).addClass( 'redux-image-select-selected' ).find( "input[type='radio']" ).attr(
"checked", true
);
window.onbeforeunload = null;
if ( $( '#import-code-value' ).length === 0 ) {
$( this ).append( '' );
} else {
$( '#import-code-value' ).val( JSON.stringify( data ) );
}
if ( $( '#publishing-action #publish' ).length !== 0 ) {
$( '#publish' ).click();
} else {
$( '#redux-import' ).click();
}
}
} else {
}
return false;
} else {
el.find( 'label[for="' + id + '"]' ).addClass( 'redux-image-select-selected' ).find( "input[type='radio']" ).attr(
"checked", true
).trigger('change');
redux_change( $( this ).closest( 'label' ).find( 'input[type="radio"]' ) );
}
}
);
// Used to display a full image preview of a tile/pattern
el.find( '.tiles' ).qtip(
{
content: {
text: function( event, api ) {
return "";
},
},
style: 'qtip-tipsy',
position: {
my: 'top center', // Position my top left...
at: 'bottom center', // at the bottom right of...
}
}
);
}
);
};
})( jQuery );