Current File : /home/inlingua/public_html/bestbuyind/wp-content/plugins/crelly-slider/wordpress/js/admin.js
/************************/
/** EXTERNAL RESOURCES **/
/************************/

// An improved jQuery clone function that fixes some jQuery issues. https://github.com/spencertipping/jquery.fix.clone
// The function has been renamed and modified a bit to prevent compatibility issues
(function (original) {
  jQuery.fn.crellyslider_betterClone = function () {
    var result           = original.apply(this, arguments),
        my_textareas     = this.find('textarea').add(this.filter('textarea')),
        result_textareas = result.find('textarea').add(result.filter('textarea')),
        my_selects       = this.find('select').add(this.filter('select')),
        result_selects   = result.find('select').add(result.filter('select'));

    for (var i = 0, l = my_textareas.length; i < l; ++i) jQuery(result_textareas[i]).val(jQuery(my_textareas[i]).val());
    for (var i = 0, l = my_selects.length;   i < l; ++i) {
      for (var j = 0, m = my_selects[i].options.length; j < m; ++j) {
        if (my_selects[i].options[j].selected === true) {
          result_selects[i].options[j].selected = true;
        }
      }
    }
    return result;
  };
}) (jQuery.fn.clone);

/*************/
/** BACKEND **/
/*************/

(function($) {
	$(window).on('load', function() {

		// Simulate keyup. Useful when textboxes change value
		function crellyslider_keyup(element) {
			$(element).trigger('keyup');
		}

		// Slider settings and slide tabs
		$('#cs-show-slider-settings').on('click', function() {
			$('#cs-slider-settings').fadeIn();
			$('#cs-slides').hide();
		});
		$('#cs-show-slides').on('click', function() {
			$('#cs-slides').fadeIn();
			$('#cs-slider-settings').hide();
		});

		// Run draggables
		crellyslider_draggableElements();

		function crellyslider_showSuccess() {
			$('.cs-admin .cs-message').css('display', 'none');

			var target = $('.cs-admin .cs-message.cs-message-ok');
			target.css({
				'display' : 'block',
				'opacity' : 0,
			});
			target.animate({
				'opacity' : 1,
			}, 300)
			.delay(2000)
			.animate({
				'opacity' : 0,
			}, 300, function() {
				target.css('display', 'none');
			});
		}

		function crellyslider_showError() {
			$('.cs-admin .cs-message').css('display', 'none');

			var target = $('.cs-admin .cs-message.cs-message-error');
			target.css({
				'display' : 'block',
				'opacity' : 0,
			});
			target.animate({
				'opacity' : 1,
			}, 300)
			.delay(2000)
			.animate({
				'opacity' : 0,
			}, 300, function() {
				target.css('display', 'none');
			});
		}

		function crellyslider_showWait() {
			$('.cs-admin .cs-message').css('display', 'none');

			var target = $('.cs-admin .cs-message.cs-message-wait');

			var untouchedMessage = target.text().split('.').join('');
			target.text(untouchedMessage);

			target.css({
				'display' : 'block',
				'opacity' : 1,
			});

			if(typeof crellyslider_showWait.dotsTimer != 'undefined' ) {
				clearInterval(crellyslider_showWait.dotsTimer);
			}
			var dots = 0;
			crellyslider_showWait.dotsTimer = setInterval(function() {
				if(dots == 3) {
					dots = 0;
					target.text(untouchedMessage);
					return;
				}
				target.text(target.text() + '.');
				dots++;
			}, 300);
		}

		/*************/
		/** SLIDERS **/
		/*************/

		// Set Alias
		$('.cs-slider').find('#cs-slider-name').keyup(function() {
			var alias = crellyslider_getAlias();
			$('.cs-slider').find('#cs-slider-alias').text(alias);
		});

		// Set shortcode
		$('.cs-slider').find('#cs-slider-name').keyup(function() {
			var alias = crellyslider_getAlias();
			var shortcode = '';
			shortcode += '[crellyslider alias="';
			shortcode += alias;
			shortcode += '"]';
			if(alias != '') {
				$('.cs-slider').find('#cs-slider-shortcode').text(shortcode);
			}
			else {
				$('.cs-slider').find('#cs-slider-shortcode').text('');
			}
		});

		// Set the new sizes of the editing area and of the slider if changing values
		$('.cs-admin #cs-slider-settings .cs-slider-settings-list #cs-slider-startWidth').keyup(function() {
			crellyslider_setSlidesEditingAreaSizes();
		});
		$('.cs-admin #cs-slider-settings .cs-slider-settings-list #cs-slider-startHeight').keyup(function() {
			crellyslider_setSlidesEditingAreaSizes();
		});

		// Get the alias starting form the name
		function crellyslider_getAlias() {
			var slider_name = $('.cs-slider').find('#cs-slider-name').val();
			var slider_alias = slider_name.toLowerCase();
			slider_alias = slider_alias.replace(/ /g, '_');
			return slider_alias;
		}

		// Init from/to datepickers
		jQuery.datetimepicker.setLocale(crellyslider_locale.substring(0, crellyslider_locale.indexOf('_'))); // If locale does not exists, datetimepicker defaults to English
		$('.cs-slider-datepicker').datetimepicker({
			format:'Y-m-d H:i',
		});

		$('#cs-slider-displayImmediately').on('change', function() {
			if(this.checked) {
				$('#cs-slider-displayFromWrapper').hide();
			}
			else{
				$('#cs-slider-displayFromWrapper').show();
			}
		});
		$('#cs-slider-displayForever').on('change', function() {
			if(this.checked) {
				$('#cs-slider-displayToWrapper').hide();
			}
			else{
				$('#cs-slider-displayToWrapper').show();
			}
		});

		/************/
		/** SLIDES **/
		/************/

		var slides_number = $('.cs-admin #cs-slides .cs-slide-tabs > ul > li').length - 1;

		// Run sortable
		var slide_before; // Contains the index before the sorting
		var slide_after; // Contains the index after the sorting
		$('.cs-slide-tabs .cs-sortable').sortable({
			items: 'li:not(.ui-state-disabled)',
			cancel: '.ui-state-disabled',
			connectWith: '.cs-slide-tabs .cs-sortable',
			containment: 'parent',
			placeholder: 'sortable-placeholder',

			start: function(event, ui) {
				// Store the current index
				slide_before = $(ui.item).index();

				ui.placeholder.height(ui.helper.height() - 1);
				ui.placeholder.width(ui.helper.width() - 1);
			},

			// Change the .cs-slide order based on the new index and rename the tabs
			update: function(event, ui) {
				// Store the new index
				slide_after = $(ui.item).index();

				// Change the slide position
				var slide = $('.cs-admin #cs-slides .cs-slides-list .cs-slide:eq(' + slide_before + ')');
				var after = $('.cs-admin #cs-slides .cs-slides-list .cs-slide:eq(' + slide_after + ')');
				if(slide_before < slide_after) {
					slide.insertAfter(after);
				}
				else {
					slide.insertBefore(after);
				}

				// Rename all the tabs
				$('.cs-admin #cs-slides .cs-slide-tabs > ul > li').each(function() {
					var temp = $(this);
					if(!temp.find('a').hasClass('cs-add-new')) {
						temp.find('a').html('<span class="cs-slide-name-text">' + crellyslider_translations.slide + ' <span class="cs-slide-index">' + (temp.index() + 1) + '</span></span>');
					}
				});
			}
		});
		$('.cs-slide-tabs .cs-sortable li').disableSelection();

		// Show the slide when clicking on the link
		$('.cs-admin #cs-slides').on('click', '.cs-slide-tabs > ul > li > a', function() {
      crellyslider_deselectElements();

      // Do only if is not click add new
			if($(this).parent().index() != slides_number) {
				// Stop previews
				$('.cs-admin #cs-slides .cs-slide .cs-elements .cs-elements-actions .cs-live-preview').each(function() {
					var btn = $(this);
					var slide_parent = btn.closest('.cs-slide');

					if(btn.hasClass('cs-live-preview-running')) {
						btn.removeClass('cs-live-preview-running');
						btn.text(crellyslider_translations.slide_live_preview);
						crellyslider_stopLivePreview(slide_parent);
					}
				});

				// Hide all tabs
				$('.cs-admin #cs-slides .cs-slides-list .cs-slide').css('display', 'none');
				var tab = $(this).parent().index();
				$('.cs-admin #cs-slides .cs-slides-list .cs-slide:eq(' + tab + ')').css('display', 'block');

				// Active class
				$('.cs-admin #cs-slides .cs-slide-tabs > ul > li').removeClass('active');
				$(this).parent().addClass('active');
			}
		});

		// Add new
		function crellyslider_addSlide() {
			var add_btn = $('.cs-admin #cs-slides .cs-add-new');

			var void_slide = $('.cs-admin #cs-slides .cs-void-slide').html();
			// Insert the link at the end of the list
			add_btn.parent().before('<li class="ui-state-default"><a><span class="cs-slide-name-text">' + crellyslider_translations.slide + ' <span class="cs-slide-index">' + (slides_number + 1) + '</span></span></a><span title="' + crellyslider_translations.duplicate_slide + '" class="cs-duplicate"></span><span title="' + crellyslider_translations.remove_slide + '" class="cs-close"></span></li>');
			// jQuery UI tabs are not working here. For now, just use a manual created tab
			$('.cs-admin #cs-slides .cs-slide-tab').tabs('refresh');
			// Create the slide
			$('.cs-admin #cs-slides .cs-slides-list').append('<div class="cs-slide">' + void_slide + '</div>');
			slides_number++;

			// Open the tab just created
			var tab_index = add_btn.parent().index() - 1;
			$('.cs-admin #cs-slides .cs-slide-tabs > ul > li').eq(tab_index).find('a').trigger('click');

			// Active class
			$('.cs-admin #cs-slides .cs-slide-tabs > ul > li').removeClass('active');
			$('.cs-admin #cs-slides .cs-slide-tabs > ul > li').eq(tab_index).addClass('active');

			// Set editing area sizes
			crellyslider_setSlidesEditingAreaSizes();

			crellyslider_slidesColorPicker();

      		// Update "start from slide" in the slider settings
			$('.cs-admin #cs-slider-settings .cs-slider-settings-list #cs-slider-startFromSlide').append('<option value="' + (slides_number - 1) + '">' + crellyslider_translations.slide + ' ' + slides_number + '</option>');
		}

		// Add new on click
		$('.cs-admin #cs-slides .cs-add-new').on('click', function() {
			crellyslider_addSlide();
		});
		// Also add a new slide if slides_number == 0
		if(slides_number == 0) {
			crellyslider_addSlide();
			// Start from first slide by default, unless the user specifically picked random order
			if(!$('.cs-admin #cs-slider-settings .cs-slider-settings-list #cs-slider-startFromSlide option[value=-1]').is('[selected]')) {
				$('.cs-admin #cs-slider-settings .cs-slider-settings-list #cs-slider-startFromSlide').val('0');
				$('.cs-admin #cs-slider-settings .cs-slider-settings-list #cs-slider-startFromSlide option[value=0]').attr('selected', 'selected');
			}
		}
		else {
			$('.cs-admin #cs-slides .cs-slide-tabs > ul > li').eq(0).find('a').trigger('click');
		}

		// Delete
		$('.cs-admin #cs-slides').on('click', '.cs-slide-tabs > ul > li .cs-close', function() {
			if($('.cs-admin #cs-slides .cs-slide-tabs > ul > li').length <= 2) {
				alert(crellyslider_translations.slide_delete_just_one);
				return;
			}

			var confirm = window.confirm(crellyslider_translations.slide_delete_confirm);
			if(!confirm) {
				return;
			}

			slides_number--;

			var slide_index = $(this).parent().index();

			// If is deleting the current viewing slide, set the first as active
			if($('.cs-admin #cs-slides .cs-slide-tabs > ul > li').eq(slide_index).hasClass('active') && slides_number != 0) {
				$('.cs-admin #cs-slides .cs-slide-tabs > ul > li').eq(0).addClass('active');
				$('.cs-admin #cs-slides .cs-slides-list .cs-slide').css('display', 'none');
				$('.cs-admin #cs-slides .cs-slides-list .cs-slide').eq(0).css('display', 'block');
			}

			// Remove the anchor
			$(this).parent().remove();
			// Remove the slide itself
			$('.cs-admin #cs-slides .cs-slides-list .cs-slide').eq(slide_index).remove();

			// Scale back all the slides text
			for(var i = slide_index; i < slides_number; i++) {
				var slide = $('.cs-admin #cs-slides .cs-slide-tabs > ul > li').eq(i);
				var indx = parseInt(slide.find('.cs-slide-index').text());
				slide.find('.cs-slide-index').text(indx - 1);
			}

			// Update "start from slide" in the slider settings
			if($('.cs-admin #cs-slider-settings .cs-slider-settings-list #cs-slider-startFromSlide').find('option:selected').val() >= slides_number) { console.log("sdfsd")
				$('.cs-admin #cs-slider-settings .cs-slider-settings-list #cs-slider-startFromSlide').val('0');
				$('.cs-admin #cs-slider-settings .cs-slider-settings-list #cs-slider-startFromSlide option[value=0]').attr('selected', 'selected');
			}
			$('.cs-admin #cs-slider-settings .cs-slider-settings-list #cs-slider-startFromSlide').children().last().remove();
		});

    // Duplicate
    $('.cs-admin #cs-slides').on('click', '.cs-slide-tabs > ul > li .cs-duplicate', function() {
    	var slide_index = $(this).parent().index();
      var slide = $('.cs-admin #cs-slides .cs-slides-list .cs-slide').eq(slide_index);

      // Clone the slide settings table
    	slide.crellyslider_betterClone(true, false).appendTo(slide.parent()).css('display', 'none');

      // Fix TinyMCE
      slide.parent().last().find('.cs-elements-list .cs-text-element-settings:not(.cs-void-text-element-settings)').each(function() {
        var cloned_options = $(this);

        cloned_options.find('.cs-switch-editor, .mce-tinymce').remove();
        cloned_options.find('.cs-element-inner_html').removeAttr('id').removeAttr('aria-hidden').removeAttr('style');
        crellyslider_convertToWPEditor(cloned_options.find('.cs-element-inner_html'));
      });

      // Add a new color picker, then remove the old one
      crellyslider_slidesColorPicker();
      $('.cs-admin #cs-slides .cs-slides-list .cs-slide').eq(slides_number).find('.wp-picker-container > .wp-color-result').eq(0).remove();

      // Insert the link at the end of the list
      $(this).parent().parent().find('.cs-add-new').parent().before('<li class="ui-state-default"><a><span class="cs-slide-name-text">' + crellyslider_translations.slide + ' <span class="cs-slide-index">' + (slides_number + 1) + '</span></span></a><span title="' + crellyslider_translations.duplicate_slide + '" class="cs-duplicate"></span><span title="' + crellyslider_translations.remove_slide + '" class="cs-close"></span></li>');
      $('.cs-admin #cs-slides .cs-slide-tab').tabs('refresh');

      crellyslider_draggableElements();

      slides_number++;

      // Update "start from slide" in the slider settings
      $('.cs-admin #cs-slider-settings .cs-slider-settings-list #cs-slider-startFromSlide').append('<option value="' + (slides_number - 1) + '">' + crellyslider_translations.slide + ' ' + slides_number + '</option>');
    });

		// Set correct size for the editing area
		function crellyslider_setSlidesEditingAreaSizes() {
			var width = parseInt($('.cs-admin #cs-slider-settings .cs-slider-settings-list #cs-slider-startWidth').val());
			var height = parseInt($('.cs-admin #cs-slider-settings .cs-slider-settings-list #cs-slider-startHeight').val());

			$('.cs-admin #cs-slides .cs-slide .cs-slide-editing-area').css({
				'width' : width,
				'height' : height,
			});

			$('.cs-admin').css({
				'width' : width,
			});
		}

		crellyslider_slidesColorPicker();

		// Run background color picker
		function crellyslider_slidesColorPicker() {
			$('.cs-admin #cs-slides .cs-slides-list .cs-slide-settings-list .cs-slide-background_type_color-picker-input').wpColorPicker({
				// a callback to fire whenever the color changes to a valid color
				change: function(event, ui){
					var btn = $(this);
					if(btn.closest('.cs-content').find('input[name="cs-slide-background_type_color"]:checked').val() != '1') {
						btn.closest('.cs-content').find('input[name="cs-slide-background_type_color"][value="1"]:radio').prop('checked', true);
					}
					var area = btn.closest('.cs-slide').find('.cs-elements .cs-slide-editing-area');
					area.css('background-color', ui.color.toString());
				},
				// a callback to fire when the input is emptied or an invalid color
				clear: function() {},
				// hide the color picker controls on load
				hide: true,
				// show a group of common colors beneath the square
				// or, supply an array of colors to customize further
				palettes: true
			});
		}

		// Set background color (transparent == 0, color-picker == 1 or manual == 2). For backward compatiblity, a "-1" is used to indicate that there were no way to set the bg color manually
		$('.cs-admin #cs-slides').on('change', '.cs-slides-list .cs-slide-settings-list input[name="cs-slide-background_type_color"]:radio', function() {
			var btn = $(this);
			var btn_val = btn.val();
			var area = btn.closest('.cs-slide').find('.cs-elements .cs-slide-editing-area');

			if(btn_val == '0') {
				area.css('background-color', '#fff');
			}
			else if(btn_val == '1') {
				var color_picker_value = btn.closest('.cs-content').find('.wp-color-result').css('background-color');
				area.css('background-color', color_picker_value);
			}
			else {
				area.css('background-color', btn.closest('.cs-content').find('.cs-slide-background_type_color-manual').val());
			}
		});

		$('.cs-admin #cs-slides').on('keyup', '.cs-slides-list .cs-slide-settings-list .cs-slide-background_type_color-manual', function() {
			var text = $(this);
			var val = text.val();
			var area = text.closest('.cs-slide').find('.cs-elements .cs-slide-editing-area');

			text.closest('.cs-slide').find('input[name="cs-slide-background_type_color"][value="2"]:radio').prop('checked', true);
			area.css('background-color', val);
		});

		// Set background image (none or image)
		$('.cs-admin #cs-slides').on('change', '.cs-slides-list .cs-slide-settings-list input[name="cs-slide-background_type_image"]:radio', function() {
			var btn = $(this);
			var area = btn.closest('.cs-slide').find('.cs-elements .cs-slide-editing-area');

			if(btn.val() == '0') {
				area.css('background-image', 'none');
			}
			else {
				var slide_parent = $(this).closest('.cs-slide');
				crellyslider_addSlideImageBackground(slide_parent);
			}
		});

		// Set Background image (the upload function)
		$('.cs-admin #cs-slides').on('click', '.cs-slides-list .cs-slide-settings-list .cs-slide-background_type_image-upload-button', function() {
			var btn = $(this);
			if(btn.closest('.cs-content').find('input[name="cs-slide-background_type_image"]:checked').val() == '1') {
				var slide_parent = $(this).closest('.cs-slide');
				crellyslider_addSlideImageBackground(slide_parent);
			}
			else {
				btn.closest('.cs-content').find('input[name="cs-slide-background_type_image"]').prop('checked', true);
				var slide_parent = $(this).closest('.cs-slide');
				crellyslider_addSlideImageBackground(slide_parent);
			}
		});
		function crellyslider_addSlideImageBackground(slide_parent) {
			var area = slide_parent.find('.cs-slide-editing-area');

			// Upload
			var file_frame;

			// If the media frame already exists, reopen it.
			if ( file_frame ) {
			  file_frame.open();
			  return;
			}

			// Create the media frame.
			file_frame = wp.media.frames.file_frame = wp.media({
			  title: jQuery( this ).data( 'uploader_title' ),
			  button: {
				text: jQuery( this ).data( 'uploader_button_text' ),
			  },
			  multiple: false  // Set to true to allow multiple files to be selected
			});

			// When an image is selected, run a callback.
			file_frame.on( 'select', function() {
			  // We set multiple to false so only get one image from the uploader
			  attachment = file_frame.state().get('selection').first().toJSON();

			  // Do something with attachment.id and/or attachment.url here
			  var image_src = attachment.url;
			  var image_alt = attachment.alt;
        var image_id = attachment.id;

			  // Set background
			  area.css('background-image', 'url("' + image_src + '")');

        // Data that we'll store into the database
        area.data('background-image-src', image_id);
			});

			// Finally, open the modal
			file_frame.open();
		}

		// Background propriety: repeat or no-repeat
		$('.cs-admin #cs-slides').on('change', '.cs-slides-list .cs-slide-settings-list input[name="cs-slide-background_repeat"]:radio', function() {
			var btn = $(this);
			var area = btn.closest('.cs-slide').find('.cs-elements .cs-slide-editing-area');

			if(btn.val() == '0') {
				area.css('background-repeat', 'no-repeat');
			}
			else {
				area.css('background-repeat', 'repeat');
			}
		});

		// Background propriety: positions x and y
		$('.cs-admin #cs-slides').on('keyup', '.cs-slides-list .cs-slide-settings-list .cs-slide-background_propriety_position_x', function() {
			var text = $(this);
			var area = text.closest('.cs-slide').find('.cs-elements .cs-slide-editing-area');

			var x = text.val();
			var y = text.parent().find('.cs-slide-background_propriety_position_y').val();

			area.css('background-position', x + ' ' + y);
		});
		$('.cs-admin #cs-slides').on('keyup', '.cs-slides-list .cs-slide-settings-list .cs-slide-background_propriety_position_y', function() {
			var text = $(this);
			var area = text.closest('.cs-slide').find('.cs-elements .cs-slide-editing-area');

			var x = text.parent().find('.cs-slide-background_propriety_position_x').val();
			var y = text.val();

			area.css('background-position', x + ' ' + y);
		});

		// Background propriety: size
		$('.cs-admin #cs-slides').on('keyup', '.cs-slides-list .cs-slide-settings-list .cs-slide-background_propriety_size', function() {
			var text = $(this);
			var val = text.val();
			var area = text.closest('.cs-slide').find('.cs-elements .cs-slide-editing-area');

			area.css('background-size', val);
		});

		// Background presets
		$('.cs-admin').on('click', '.cs-slide-background-image-fullwidth-preset', function() {
			var text = $(this);
			var area = text.closest('.cs-slide').find('.cs-elements .cs-slide-editing-area');
			var settings = text.closest('.cs-slide');

			settings.find('.cs-slide-background_propriety_position_x').val('center');
			crellyslider_keyup(settings.find('.cs-slide-background_propriety_position_x'));

			settings.find('.cs-slide-background_propriety_position_y').val('center');
			crellyslider_keyup(settings.find('.cs-slide-background_propriety_position_y'));

			settings.find('input[name="cs-slide-background_repeat"][value="0"]').prop('checked', true);
			area.css('background-repeat', 'no-repeat');

			settings.find('.cs-slide-background_propriety_size').val('cover');
			crellyslider_keyup(settings.find('.cs-slide-background_propriety_size'));
		});

		$('.cs-admin').on('click', '.cs-slide-background-image-pattern-preset', function() {
			var text = $(this);
			var area = text.closest('.cs-slide').find('.cs-elements .cs-slide-editing-area');
			var settings = text.closest('.cs-slide');

			settings.find('.cs-slide-background_propriety_position_x').val(0);
			crellyslider_keyup(settings.find('.cs-slide-background_propriety_position_x'));

			settings.find('.cs-slide-background_propriety_position_y').val(0);
			crellyslider_keyup(settings.find('.cs-slide-background_propriety_position_y'));

			settings.find('input[name="cs-slide-background_repeat"][value="1"]').prop('checked', true);
			area.css('background-repeat', 'repeat');

			settings.find('.cs-slide-background_propriety_size').val('auto');
			crellyslider_keyup(settings.find('.cs-slide-background_propriety_size'));
		});

		// Apply custom CSS
		$('.cs-admin #cs-slides').on('keyup', '.cs-slides-list .cs-slide-settings-list .cs-slide-custom_css', function() {
			var text = $(this);
			var area = text.closest('.cs-slide').find('.cs-elements .cs-slide-editing-area');
			var css = text.val();

			// Save current styles
			var width = area.css('width');
			var height = area.css('height');
			var background_image = area.css('background-image');
			var background_color = area.css('background-color');
			var background_position = area.css('background-position');
			var background_repeat = area.css('background-repeat');
			var background_size = area.css('background-size');

			// Apply CSS
			area.attr('style', css);
			area.css({
				'width' : width,
				'height' : height,
				'background-image' : background_image,
				'background-color' : background_color,
				'background-position' : background_position,
				'background-repeat' : background_repeat,
				'background-size' : background_size
			});
		});

		/**************/
		/** ELEMENTS **/
		/**************/

		// GENERAL

		// Make draggable
		function crellyslider_draggableElements() {
      $('.cs-admin .cs-elements .cs-element').draggable({
				'containment' : 'parent',

				start: function() {
					// Select when dragging
          crellyslider_selectElement($(this));
				},

				drag: function(){
					// Set left and top positions on drag to the textbox
					var position = $(this).position();
					var left = position.left;
					var top = position.top;
					var index = $(this).index();

					$(this).closest('.cs-elements').find('.cs-elements-list .cs-element-settings:eq(' + index + ') .cs-element-data_left').val(left);
					$(this).closest('.cs-elements').find('.cs-elements-list .cs-element-settings:eq(' + index + ') .cs-element-data_top').val(top);
				},
			});
		}

		// Selects an element, shows its options and makes the delete element button available
		$('.cs-admin #cs-slides').on('click', '.cs-slide .cs-elements .cs-slide-editing-area .cs-element', function(e) {
			// Do not click the editing-area
			e.stopPropagation();

			// Do not open links
			e.preventDefault();

			crellyslider_selectElement($(this));
		});
		function crellyslider_selectElement(element) {
			var index = element.index();
			var slide = element.closest('.cs-slide');
			var options = slide.find('.cs-elements .cs-elements-list');

			// Hide all options - .active class
			options.find('.cs-element-settings').css('display', 'none');
			options.find('.cs-element-settings').removeClass('active');

			// Show the correct options + .active class
			options.find('.cs-element-settings:eq(' + index + ')').css('display', 'block');
			options.find('.cs-element-settings:eq(' + index + ')').addClass('active');

			// Add .active class to the element in the editing area
			element.parent().children().removeClass('active');
			element.addClass('active');

			// Make the delete and the duplicate buttons working
			slide.find('.cs-elements-actions .cs-delete-element').removeClass('cs-is-disabled');
			slide.find('.cs-elements-actions .cs-duplicate-element').removeClass('cs-is-disabled');
		}

		// Deselect elements
		$('.cs-admin').on('click', '.cs-slide .cs-elements .cs-slide-editing-area', function() {
			crellyslider_deselectElements();
		});
		function crellyslider_deselectElements() {
			$('.cs-admin .cs-slide .cs-elements .cs-slide-editing-area .cs-element').removeClass('active');
			$('.cs-admin .cs-slide .cs-elements .cs-elements-list .cs-element-settings').removeClass('active');
			$('.cs-admin .cs-slide .cs-elements .cs-elements-list .cs-element-settings').css('display', 'none');

			// Hide delete and duplicate element btns
			$('.cs-admin .cs-slide .cs-elements-actions .cs-delete-element').addClass('cs-is-disabled');
			$('.cs-admin .cs-slide .cs-elements-actions .cs-duplicate-element').addClass('cs-is-disabled');
		}

		// Delete element. Remember that the button should be enabled / disabled somewhere else
		function crellyslider_deleteElement(element) {
			var index = element.index();
			var slide_parent = element.closest('.cs-slide');

			element.remove();
			var element_options = slide_parent.find('.cs-elements-list .cs-element-settings:eq(' + index + ')');
			element_options.remove();
			crellyslider_deselectElements();
		}
		$('.cs-admin #cs-slides').on('click', '.cs-slide .cs-elements .cs-elements-actions .cs-delete-element', function() {
			// Click only if an element is selected
			if($(this).hasClass('.cs-is-disabled')) {
				return;
			}

			var slide_parent = $(this).closest('.cs-slide');
			var element = slide_parent.find('.cs-elements .cs-slide-editing-area .cs-element.active');
			crellyslider_deleteElement(element);
		});

		function crellyslider_duplicateElement(element) {
			var index = element.index();
			var slide_parent = element.closest('.cs-slide');

			element.clone().appendTo(element.parent()).css({
				'left' : '+=10',
				'top' : '+=10',
			});
			var element_options = slide_parent.find('.cs-elements-list .cs-element-settings').eq(index);
			element_options.crellyslider_betterClone(true).insertBefore(element_options.parent().find('.cs-void-text-element-settings'));

			crellyslider_deselectElements();
			crellyslider_selectElement(element.parent().find('.cs-element').last());

			var cloned_options = element.parent().find('.cs-element').last().closest('.cs-slide').find('.cs-elements-list .cs-element-settings.active');

			// Move the element 10 pixels away
			cloned_options.find('.cs-element-data_left').val(parseInt(element_options.find('.cs-element-data_left').val()) + 10);
			cloned_options.find('.cs-element-data_top').val(parseInt(element_options.find('.cs-element-data_top').val()) + 10);

      // If it's a text, fix TinyMCE
      if(cloned_options.hasClass('cs-text-element-settings')) {
        cloned_options.find('.cs-switch-editor, .mce-tinymce').remove();
        cloned_options.find('.cs-element-inner_html').removeAttr('id').removeAttr('aria-hidden').removeAttr('style');
        crellyslider_convertToWPEditor(cloned_options.find('.cs-element-inner_html'));
      }

			// Make draggable
			crellyslider_draggableElements();
		}
		$('.cs-admin #cs-slides').on('click', '.cs-slide .cs-elements .cs-elements-actions .cs-duplicate-element', function() {
			// Click only if an element is selected
			if($(this).hasClass('.cs-is-disabled')) {
				return;
			}

			var slide_parent = $(this).closest('.cs-slide');
			var element = slide_parent.find('.cs-elements .cs-slide-editing-area .cs-element.active');
			crellyslider_duplicateElement(element);
		});

		// Modify left position
		$('.cs-admin').on('keyup', '.cs-elements .cs-elements-list .cs-element-settings .cs-element-data_left', function() {
			var index = $(this).closest('.cs-element-settings').index();
			$(this).closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').css('left', parseFloat($(this).val()));
		});

		// Center horizontally
		$('.cs-admin').on('click', '.cs-elements .cs-elements-list .cs-element-settings .cs-element-center-x', function() {
			var index = $(this).closest('.cs-element-settings').index();
			var left = parseInt(($('.cs-admin #cs-slider-settings .cs-slider-settings-list #cs-slider-startWidth').val() / 2) - (parseFloat($(this).closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').width()) / 2));
			$(this).closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').css('left', left);
			$(this).closest('.cs-elements').find('.cs-elements-list .cs-element-settings:eq(' + index + ') .cs-element-data_left').val(left);
		});

		// Modify top position
		$('.cs-admin').on('keyup', '.cs-elements .cs-elements-list .cs-element-settings .cs-element-data_top', function() {
			var index = $(this).closest('.cs-element-settings').index();
			$(this).closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').css('top', parseFloat($(this).val()));
		});

		// Center vertically
		$('.cs-admin').on('click', '.cs-elements .cs-elements-list .cs-element-settings .cs-element-center-y', function() {
			var index = $(this).closest('.cs-element-settings').index();
			var top = parseInt(($('.cs-admin #cs-slider-settings .cs-slider-settings-list #cs-slider-startHeight').val() / 2) - (parseFloat($(this).closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').height()) / 2));
			$(this).closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').css('top', top);
			$(this).closest('.cs-elements').find('.cs-elements-list .cs-element-settings:eq(' + index + ') .cs-element-data_top').val(top);
		});

		// Modify z-index
		$('.cs-admin').on('keyup', '.cs-elements .cs-elements-list .cs-element-settings .cs-element-z_index', function() {
			var index = $(this).closest('.cs-element-settings').index();
			$(this).closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').css('z-index', parseFloat($(this).val()));
		});

		// Add / remove link wrapper (fire on textbox edit or on checkbox _target:"blank" edit)
		$('.cs-admin').on('keyup', '.cs-elements .cs-elements-list .cs-element-settings .cs-element-link', function() {
			crellyslider_editElementsLink($(this));
		});
		$('.cs-admin').on('change', '.cs-elements .cs-elements-list .cs-element-settings .cs-element-link_new_tab', function() {
			var textbox = $(this).parent().find('.cs-element-link');
			crellyslider_editElementsLink(textbox);
		});

		// Wrap - unwrap elements with an <a href="" target="">
		function crellyslider_editElementsLink(textbox_link) {
			var index = textbox_link.closest('.cs-element-settings').index();
			var copy_attributes = false;
			var reapply_css = false;

			if(textbox_link.val() != '' && !textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').parent('a').hasClass('cs-element')) {
				// Remove custom css classes
				textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').removeClass(textbox_link.closest('.cs-element-settings').find('.cs-element-custom_css_classes').val());
				textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').removeClass(textbox_link.closest('.cs-element-settings').find('.cs-element-custom_css_classes').val());

				var link_new_tab = textbox_link.parent().find('.cs-element-link_new_tab').prop('checked') ? 'target="_blank"' : '';
				textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').wrap('<a href="' + textbox_link.val() + '"' + link_new_tab + ' />');
				copy_attributes = true;
				reapply_css = true;
			}
			else if(textbox_link.val() != '' && textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').parent('a').hasClass('cs-element')) {
				var link_new_tab = textbox_link.parent().find('.cs-element-link_new_tab').prop('checked') ? true : false;

				textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').parent('a').attr('href', textbox_link.val());

				if(link_new_tab) {
					textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').parent('a').attr('target', '_blank');
				}
				else {
					textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').parent('a').removeAttr('target');
				}

				copy_attributes = false;
			}
			else if(textbox_link.val() == '' && textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').parent('a').hasClass('cs-element')) {
				textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').attr('class', textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').parent('a').attr('class')).removeClass('ui-draggable');

				// Reapply CSS and custom CSS
				applyCustomCss(textbox_link.closest('.cs-element-settings').find('.cs-element-custom_css'));
				textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').css('top', textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').parent('a').css('top'));
				textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').css('left', textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').parent('a').css('left'));
				textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').css('z-index', textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').parent('a').css('z-index'));

				// Reapply custom css classes
				crellyslider_applyCustomCssClasses(textbox_link.closest('.cs-element-settings').find('.cs-element-custom_css_classes'));

				textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').unwrap();
				textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').parent('a').draggable('destroy');
				copy_attributes = false;
			}

			if(copy_attributes) {
				textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').parent().attr('style', textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').attr('style'));
				textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').parent().attr('class', textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').attr('class')).removeClass('ui-draggable');

				textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').removeAttr('style');
				textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').removeAttr('class');
				textbox_link.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').draggable('destroy');
			}

			crellyslider_draggableElements();

			if(reapply_css) {
				applyCustomCss(textbox_link.closest('.cs-element-settings').find('.cs-element-custom_css'));
				crellyslider_applyCustomCssClasses(textbox_link.closest('.cs-element-settings').find('.cs-element-custom_css_classes'));
			}
		}

		// Apply custom CSS
		$('.cs-admin').on('keyup', '.cs-elements .cs-elements-list .cs-element-settings .cs-element-custom_css', function() {
			applyCustomCss($(this));
		});

		function applyCustomCss(textarea) {
			var index = textarea.closest('.cs-element-settings').index();
			// Save current positions
			var left = textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').css('left');
			var top = textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').css('top');
			var z_index = textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').css('z-index');

			// Apply CSS
			if(! textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').is('a') && ! textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').hasClass('cs-video-element')) {
				textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').attr('style', textarea.val());
			}
			else {
				textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').attr('style', textarea.val());
				textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > .cs-avoid-interaction').removeAttr('style');
				textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').removeAttr('style');
			}
			textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').css('top', top);
			textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').css('left', left);
			textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').css('z-index', z_index);
		}

		// Add custom CSS classes
		$('.cs-admin').on('keydown', '.cs-elements .cs-elements-list .cs-element-settings .cs-element-custom_css_classes', function() {
			var textarea = $(this);
			var index = textarea.closest('.cs-element-settings').index();

			if(! textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').is('a') && ! textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').hasClass('cs-video-element')) {
				textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').removeClass(textarea.val());
			}
			else {
				textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').removeClass(textarea.val());
				var avoid_interaction = textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > .cs-avoid-interaction');
				avoid_interaction.removeAttr('class');
				avoid_interaction.addClass('cs-avoid-interaction');
			}
		});
		$('.cs-admin').on('keyup', '.cs-elements .cs-elements-list .cs-element-settings .cs-element-custom_css_classes', function() {
			crellyslider_applyCustomCssClasses($(this));
		});
		function crellyslider_applyCustomCssClasses(textarea) {
			var index = textarea.closest('.cs-element-settings').index();

			if(! textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').is('a') && ! textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').hasClass('cs-video-element')) {
				textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')').addClass(textarea.val());
			}
			else {
				textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > *').addClass(textarea.val());
				var avoid_interaction = textarea.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ') > .cs-avoid-interaction');
				avoid_interaction.removeAttr('class');
				avoid_interaction.addClass('cs-avoid-interaction');
			}
		}

		// TEXT ELEMENTS

    // Convert textareas to WP editors
    $('.cs-admin .cs-slide .cs-elements .cs-text-element-settings .cs-element-inner_html').each(function() {
      var textarea = $(this);

      if(textarea.closest('.cs-text-element-settings').hasClass('cs-void-text-element-settings')) {
        return; // It means "continue;"
      }

      crellyslider_convertToWPEditor(textarea);
    });

    // Converts a textarea to something similar to wp_editor()
    function crellyslider_convertToWPEditor(textarea) {
      // Static counter: generates a new ID for each editor
      if(crellyslider_convertToWPEditor.static_counter == undefined) {
        crellyslider_convertToWPEditor.static_counter = 0;
      }
      else {
        crellyslider_convertToWPEditor.static_counter++;
      }

      textarea.attr('id', 'cs-element-editor-' + crellyslider_convertToWPEditor.static_counter);

		var settings = crellyslider_tinyMCEInit;

		settings.selector = '#cs-element-editor-' + (crellyslider_convertToWPEditor.static_counter);
		settings.body_class = ('cs-element-editor-' + (crellyslider_convertToWPEditor.static_counter) + ' locale-' + crellyslider_locale).toLowerCase();
		settings.setup = function(editor) {
			editor.on("KeyUp ExecCommand ContextMenu Change", function(e) {
				editor.save();
				crellyslider_triggerTinyMCE(editor.id);
			});

			editor.on("init", function() {
				// Set default CSS
				this.getDoc().body.style.fontSize = "14px";
				this.getDoc().body.style.fontFamily = "Verdana";

				// Insert switch button
				textarea.parent().prepend('<div class="cs-switch-editor"><div onclick="tinyMCE.execCommand(\'mceToggleEditor\', false, \'' + editor.id + '\')" class="cs-button cs-is-default cs-tinymce">' + crellyslider_translations.switch_editor + '</div></div>');
			});
		};

      if(typeof tinyMCE != 'undefined') {
        tinyMCE.init(settings);
      }
    }

    // When the user modifies the text in the TinyMCE editor, apply the changes to the preview area
    function crellyslider_triggerTinyMCE(editor_id) {
      crellyslider_changeText(jQuery('#' + editor_id));
    }

    // Add text click
		$('.cs-admin #cs-slides').on('click', '.cs-slide .cs-elements .cs-elements-actions .cs-add-text-element', function() {
			var slide_parent = $(this).closest('.cs-slide');
			crellyslider_addTextElement(slide_parent);
		});

		// Add text. Receives the slide as object
		function crellyslider_addTextElement(slide_parent) {
			var area = slide_parent.find('.cs-slide-editing-area');
			var settings_div = slide_parent.find('.cs-elements .cs-elements-list .cs-void-text-element-settings');
			var settings = '<div class="cs-element-settings cs-text-element-settings">' + $('.cs-admin .cs-slide .cs-elements .cs-void-text-element-settings').html() + '</div>';

			// Insert in editing area
			area.append('<div class="cs-element cs-text-element" style="z-index: 1;">' + crellyslider_translations.text_element_default_html + '</div>');

			// Insert the options
			settings_div.before(settings);

			// Make draggable
			crellyslider_draggableElements();

      // Convert textarea to WP editor
      crellyslider_convertToWPEditor(slide_parent.find('.cs-elements .cs-elements-list .cs-text-element-settings:not(.cs-void-text-element-settings)').last().find('.cs-element-inner_html'));

			// Display settings
			crellyslider_selectElement(area.find('.cs-element').last());
		}

    // Modify text
		$('.cs-admin').on('keyup', '.cs-elements .cs-elements-list .cs-element-settings .cs-element-inner_html', function() {
			crellyslider_changeText($(this));
		});
    crellyslider_changeText = function crellyslider_changeText(element) {
      var index = element.closest('.cs-element-settings').index();
			var text_element = element.closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')');

			if(! text_element.is('a')) {
				text_element.html(element.val());

        text_element.css('width', '');
        text_element.css('height', '');
			}
			else {
				text_element.find('> div').html(element.val());

        text_element.find('> div').css('width', '');
        text_element.find('> div').css('height', '');
			}
    }

		// IMAGE ELEMENTS

		// Add images click
		$('.cs-admin #cs-slides').on('click', '.cs-slide .cs-elements .cs-elements-actions .cs-add-image-element', function() {
			var slide_parent = $(this).closest('.cs-slide');
			crellyslider_addImageElement(slide_parent);
		});

		// Upload click
		$('.cs-admin').on('click', '.cs-elements .cs-elements-list .cs-image-element-settings .cs-image-element-upload-button', function() {
			var slide_parent = $(this).closest('.cs-slide');
			crellySliderUploadImageElement(slide_parent);
		});

		// Add image. Receives the slide as object
		function crellyslider_addImageElement(slide_parent) {
			var area = slide_parent.find('.cs-slide-editing-area');
			var settings_div = slide_parent.find('.cs-elements .cs-elements-list .cs-void-text-element-settings');
			var settings = '<div class="cs-element-settings cs-image-element-settings">' + $('.cs-admin .cs-slide .cs-elements .cs-void-image-element-settings').html() + '</div>';

			// Temporarily insert an element with no src and alt
			// Add the image into the editing area.
			  area.append('<img class="cs-element cs-image-element" src="nothing_now.jpg" style="z-index: 1;" />');

			// Insert the options
			settings_div.before(settings);

			// Make draggable
			crellyslider_draggableElements();

			// Display settings
			crellyslider_selectElement(area.find('.cs-element').last());

			// Upload
			crellySliderUploadImageElement(slide_parent);
		}

		function crellySliderUploadImageElement(slide_parent) {
			var area = slide_parent.find('.cs-slide-editing-area');
			var settings_div = slide_parent.find('.cs-elements .cs-elements-list .cs-void-text-element-settings');
			var settings = '<div class="cs-element-settings cs-image-element-settings">' + $('.cs-admin .cs-slide .cs-elements .cs-void-image-element-settings').html() + '</div>';

			var file_frame;

			// If the media frame already exists, reopen it.
			if ( file_frame ) {
			  file_frame.open();
			  return;
			}

			// Create the media frame.
			file_frame = wp.media.frames.file_frame = wp.media({
			  title: jQuery( this ).data( 'uploader_title' ),
			  button: {
				text: jQuery( this ).data( 'uploader_button_text' ),
			  },
			  multiple: false  // Set to true to allow multiple files to be selected
			});

			// When an image is selected, run a callback.
			file_frame.on( 'select', function() {
			  // We set multiple to false so only get one image from the uploader
			  attachment = file_frame.state().get('selection').first().toJSON();

			  // Do something with attachment.id and/or attachment.url here
			  var image_src = attachment.url;
			  var image_alt = attachment.alt;
        var attachment_id = attachment.id;

			  // Set attributes. If is a link, do the right thing
			  var image = area.find('.cs-image-element.active').last();

			  if(! image.is('a')) {
				  image.attr('src', image_src);
				  image.attr('alt', image_alt);
			  }
			  else {
  				image.find('> img').attr('src', image_src);
          image.find('> img').attr('alt', image_alt);
			  }

			  // Set data (will be used in the ajax call)
			  settings_div.parent().find('.cs-element-settings.active .cs-image-element-upload-button').data('src', attachment_id);
			  settings_div.parent().find('.cs-element-settings.active .cs-image-element-upload-button').data('alt', image_alt);
			});

			// Finally, open the modal
			file_frame.open();
		}

		// VIDEO ELEMENTS

		// Add video click
		$('.cs-admin #cs-slides').on('click', '.cs-slide .cs-elements .cs-elements-actions .cs-add-video-element', function() {
			var slide_parent = $(this).closest('.cs-slide');
			crellyslider_addVideoElement(slide_parent);
		});

		// Adds a video container. Receives the slide as object
		function crellyslider_addVideoElement(slide_parent) {
			var area = slide_parent.find('.cs-slide-editing-area');
			var settings_div = slide_parent.find('.cs-elements .cs-elements-list .cs-void-text-element-settings');
			var settings = '<div class="cs-element-settings cs-video-element-settings">' + $('.cs-admin .cs-slide .cs-elements .cs-void-video-element-settings').html() + '</div>';

			// Insert in editing area
			area.append('<div class="cs-element cs-video-element" style="z-index: 1;"></div>');

			// Insert the options
			settings_div.before(settings);

			// Make draggable
			crellyslider_draggableElements();

			// Display settings
			crellyslider_selectElement(area.find('.cs-element').last());

			// Select youtube video as default
			area.find('.cs-element').last().closest('.cs-slide').find('.cs-elements .cs-elements-list .cs-element-video_src').trigger('change');
		}

		// Change video id
		$('.cs-admin').on('change keyup input', '.cs-elements .cs-elements-list .cs-element-settings .cs-element-video_id', function() {
			var index = $(this).closest('.cs-element-settings').index();
			var element = $(this).closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')');

			crellyslider_changeVideo($(this), element, $(this).parent().find('.cs-element-video_src').val(), $(this).val());
		});
		// Change video source
		$('.cs-admin').on('change', '.cs-elements .cs-elements-list .cs-element-settings .cs-element-video_src', function() {
			var index = $(this).closest('.cs-element-settings').index();
			var element = $(this).closest('.cs-elements').find('.cs-slide-editing-area .cs-element:eq(' + index + ')');

			crellyslider_changeVideo($(this), element, $(this).val(), $(this).parent().find('.cs-element-video_id').val());
		});
		function crellyslider_changeVideo(input, element, source, video_id) {
			if(source == 'youtube') {
				element.html('<div class="cs-avoid-interaction"></div><iframe class="cs-yt-iframe" type="text/html" width="560" height="315" src="https://www.youtube.com/embed/' + video_id + '?enablejsapi=1" frameborder="0"></iframe>');
			}
			else {
				element.html('<div class="cs-avoid-interaction"></div><iframe class="cs-vimeo-iframe" src="https://player.vimeo.com/video/' + video_id + '?api=1" width="560" height="315" frameborder="0" ></iframe>');
			}

			// Re-apply custom CSS and custom CSS classes
			crellyslider_keyup(input.closest('.cs-element-settings').find('.cs-element-custom_css'));
			crellyslider_keyup(input.closest('.cs-element-settings').find('.cs-element-custom_css_classes'));
		}

		/******************/
		/** LIVE PREVIEW **/
		/******************/

		// Live preview click
		$('.cs-admin #cs-slides').on('click', '.cs-slide .cs-elements .cs-elements-actions .cs-live-preview', function() {
			var btn = $(this);
			var slide_parent = btn.closest('.cs-slide');

			if(! btn.hasClass('cs-live-preview-running')) {
				btn.addClass('cs-live-preview-running');
				btn.text(crellyslider_translations.slide_stop_preview);
				crellyslider_startLivePreview(slide_parent);
			}
			else {
				btn.removeClass('cs-live-preview-running');
				btn.text(crellyslider_translations.slide_live_preview);
				crellyslider_stopLivePreview(slide_parent);
			}
		});

		function crellyslider_startLivePreview(slide_parent) {
			crellyslider_deselectElements();

			var area = slide_parent.find('.cs-slide-editing-area');

			area.clone().addClass('cs-slide-live-preview-area').insertAfter(area);
			var prev = slide_parent.find('.cs-slide-live-preview-area');

			area.css('display', 'none');

			// Set elements data and styles
			var elements = prev.find('.cs-element');
			var original_elements = area.closest('.cs-slide').find('.cs-elements .cs-element-settings');
			var i = 0;
			elements.each(function() {
				var element = $(this);

        // Video elements settings only
        var html_class = false;
				if(element.find('.cs-yt-iframe').length > 0) {
					element.find('.cs-avoid-interaction').remove();
					element = element.find('.cs-yt-iframe');
					element.unwrap();
					element.attr({
						'data-autoplay' : parseInt(original_elements.eq(i).find('.cs-element-video_autoplay').val()),
						'data-loop' : parseInt(original_elements.eq(i).find('.cs-element-video_loop').val()),
						'data-start-mute' : parseInt(original_elements.eq(i).find('.cs-element-video_start_mute').val()),
						'data-pause-while-watching' : parseInt(original_elements.eq(i).find('.cs-element-video_pause_while_watching').val()),
					});
					html_class = 'cs-yt-iframe';
				}
				else if(element.find('.cs-vimeo-iframe').length > 0) {
					element.find('.cs-avoid-interaction').remove();
					element = element.find('.cs-vimeo-iframe');
					element.unwrap();
					element.attr({
						'data-autoplay' : parseInt(original_elements.eq(i).find('.cs-element-video_autoplay').val()),
						'data-loop' : parseInt(original_elements.eq(i).find('.cs-element-video_loop').val()),
						'data-start-mute' : parseInt(original_elements.eq(i).find('.cs-element-video_start_mute').val()),
						'data-pause-while-watching' : parseInt(original_elements.eq(i).find('.cs-element-video_pause_while_watching').val()),
					});
					html_class = 'cs-vimeo-iframe';
				}

				element.removeAttr('style');
				element.attr('style', original_elements.eq(i).find('.cs-element-custom_css').val());
				element.css({
					'z-index' : parseInt(original_elements.eq(i).find('.cs-element-z_index').val()),
					'display' : 'none',
				});

				element.removeAttr('class');
				element.addClass(original_elements.eq(i).find('.cs-element-custom_css_classes').val());
        if(html_class) {
          element.addClass(html_class);
        }

				element.attr({
					'data-left' : parseInt(original_elements.eq(i).find('.cs-element-data_left').val()),
					'data-top' : parseInt(original_elements.eq(i).find('.cs-element-data_top').val()),
					'data-delay' : parseInt(original_elements.eq(i).find('.cs-element-data_delay').val()),
					'data-time' : original_elements.eq(i).find('.cs-element-data_time').val(),
					'data-in' : original_elements.eq(i).find('.cs-element-data_in').val(),
					'data-out' : original_elements.eq(i).find('.cs-element-data_out').val(),
					'data-ignore-ease-out' : original_elements.eq(i).find('.cs-element-data_out').prop('checked') ? 1 : 0,
					'data-ease-in' : parseInt(original_elements.eq(i).find('.cs-element-data_easeIn').val()),
					'data-ease-out' : parseInt(original_elements.eq(i).find('.cs-element-data_easeOut').val()),
				});

				i++;
			});

			// Prepare HTML structure
			prev.wrapInner('<li />');
			prev.wrapInner('<ul />');


			var slide = prev.find('ul > li');
			var original_slide = area.closest('.cs-slide');
			var content = original_slide.find('.cs-slide-settings-list');

			// Set slide link
			if(content.find('.cs-background-link').val() != '') {
				if(! content.find('.cs-background-link_new_tab').prop('checked')) {
					slide.prepend('<a class="cs-background-link" href="' + content.find('.cs-background-link').val() + '"></a>');
				}
				else {
					slide.prepend('<a class="cs-background-link" target="_blank" href="' + content.find('.cs-background-link').val() + '"></a>');
				}
			}

			// Set slide data and styles
			slide.attr({
				'data-in' : content.find('.cs-slide-data_in').val(),
				'data-out' : content.find('.cs-slide-data_out').val(),
				'data-time' : parseInt(content.find('.cs-slide-data_time').val()),
				'data-ease-in' : parseInt(content.find('.cs-slide-data_easeIn').val()),
				'data-ease-out' : parseInt(content.find('.cs-slide-data_easeOut').val()),
			});

			slide.attr('style', content.find('.cs-slide-custom_css').val());
			slide.css({
				'background-image' : area.css('background-image') ,
				'background-color' : area.css('background-color') + "",
				'background-position' : content.find('.cs-slide-background_propriety_position_x').val() + ' ' + content.find('.cs-slide-background_propriety_position_y').val(),
				'background-repeat' : content.find('input[name="cs-slide-background_repeat"]:checked').val() == '0' ? 'no-repeat' : 'repeat',
				'background-size' : content.find('.cs-slide-background_propriety_size').val(),
			});

			var slider = $('.cs-admin .cs-slider #cs-slider-settings');

			// Run Crelly Slider
			prev.crellySlider({
				'layout' : 'fixed',
				'responsive' : false,
				'startWidth' : parseInt(slider.find('#cs-slider-startWidth').val()),
				'startHeight' : parseInt(slider.find('#cs-slider-startHeight').val()),

				'automaticSlide' : true,
				'showControls' : false,
				'showNavigation' : false,
				'enableSwipe' : false,
				'showProgressBar' : false,
				'pauseOnHover' : false,
			});

			// Warning: click on background links
			$('.cs-slide-live-preview-area a').on('click', function(event) {
				if($(this).prop('target') != '_blank') {
					var confirm = window.confirm(crellyslider_translations.exit_without_saving);
					if(! confirm) {
						event.preventDefault();
					}
				}
			});
		}

		function crellyslider_stopLivePreview(slide_parent) {
			var area = slide_parent.find('.cs-slide-editing-area');
			var prev = slide_parent.find('.cs-slide-live-preview-area');

			prev.remove();
			area.css('display', 'block');
		}

		/****************/
		/** AJAX CALLS **/
		/****************/

		// Save or update the new slider in the database
		$('.cs-admin .cs-slider .cs-save-settings').on('click', function() {
			$('.cs-admin #cs-slides .cs-live-preview').each(function() {
				var btn = $(this);
				var slide_parent = btn.closest('.cs-slide');

				if(btn.hasClass('cs-live-preview-running')) {
					btn.removeClass('cs-live-preview-running');
					btn.text(crellyslider_translations.slide_live_preview);
					crellyslider_stopLivePreview(slide_parent);
				}
			});

			crellyslider_saveSlider();
		});

		// Delete slider
		$('.cs-admin .cs-home').on('click', '.cs-sliders-list .cs-delete-slider', function() {
			var confirm = window.confirm(crellyslider_translations.slider_delete_confirm);
			if(!confirm) {
				return;
			}

			crellyslider_deleteSlider($(this));
		});

		// Duplicate slider
		$('.cs-admin .cs-home').on('click', '.cs-sliders-list .cs-duplicate-slider', function() {
			crellyslider_duplicateSlider($(this));
		});

		// Export slider
		$('.cs-admin .cs-home').on('click', '.cs-sliders-list .cs-export-slider', function() {
			crellyslider_exportSlider($(this));
		});

		// Import slider
		$('.cs-admin .cs-home').on('click', '.cs-import-slider', function() {
			$('#cs-import-file').trigger('click');
		});
		$('.cs-admin .cs-home').on('change', '#cs-import-file', function() {
			crellyslider_importSlider();
		});

		// Sends an array with the new or current slider options
		function crellyslider_saveSlider() {
			crellyslider_showWait();

			var content = $('.cs-admin .cs-slider #cs-slider-settings');
			var options = {
				id : parseInt($('.cs-admin .cs-slider .cs-save-settings').data('id')),
				name : content.find('#cs-slider-name').val(),
				alias : content.find('#cs-slider-alias').text(),
				layout : content.find('#cs-slider-layout').val(),
				responsive : parseInt(content.find('#cs-slider-responsive').val()),
				startWidth : parseInt(content.find('#cs-slider-startWidth').val()),
				startHeight : parseInt(content.find('#cs-slider-startHeight').val()),
				automaticSlide : parseInt(content.find('#cs-slider-automaticSlide').val()),
				showControls : parseInt(content.find('#cs-slider-showControls').val()),
				showNavigation : parseInt(content.find('#cs-slider-showNavigation').val()),
				enableSwipe : parseInt(content.find('#cs-slider-enableSwipe').val()),
				showProgressBar : parseInt(content.find('#cs-slider-showProgressBar').val()),
				pauseOnHover : parseInt(content.find('#cs-slider-pauseOnHover').val()),
				randomOrder : parseInt(content.find('#cs-slider-randomOrder').val()),
				startFromSlide : parseInt(content.find('#cs-slider-startFromSlide').val()),
				fromDate : content.find('#cs-slider-displayImmediately').prop('checked') || content.find('#cs-slider-fromDate').val() == '' ? '1000-01-01 00:00:00' : content.find('#cs-slider-fromDate').val(),
				toDate : content.find('#cs-slider-displayForever').prop('checked') || content.find('#cs-slider-toDate').val() == '' ? '9999-12-31 23:59:59' : content.find('#cs-slider-toDate').val(),
				callbacks : content.find('#cs-slider-callbacks').val(),
			};

			var sliderNonce;
			if(typeof(crellyslider_currentSliderNonce) != "undefined") {
				sliderNonce = crellyslider_currentSliderNonce;
			}
			else {
				sliderNonce = crellyslider_nonces.addSlider;
			}

			// Do the ajax call
			jQuery.ajax({
				type : 'POST',
				dataType : 'json',
				url : ajaxurl,
				data : {
					// Is it saving or updating?
					action: $('.cs-admin .cs-slider').hasClass('cs-add-slider') ? 'crellyslider_addSlider' : 'crellyslider_editSlider',
					security: sliderNonce,
					datas : options,
				},
				success: function(response) {
					//alert('Save slider response: ' + response);
					// If adding a new slider, response will be the generated id, else will be the number of rows modified
					if(response !== false) {
						// If is adding a slider, redirect
						if($('.cs-admin .cs-slider').hasClass('cs-add-slider')) {
							window.location.href = '?page=crellyslider&view=edit&id=' + response;
							return;
						}

						crellyslider_saveSlides();
					}
					else {
						crellyslider_showError();
					}
				},

				error: function(XMLHttpRequest, textStatus, errorThrown) {
					alert('Error saving slider');
					console.log(XMLHttpRequest.responseText);
					crellyslider_showError();
				}
			});
		}

		// Sends an array with all the slides options
		function crellyslider_saveSlides() {
			var slides = $('.cs-admin .cs-slider #cs-slides .cs-slide');
			var i = 0;
			var final_options = {};

			final_options['options'] = new Array();
			slides.each(function() {
				var slide = $(this);
				var content = slide.find('.cs-slide-settings-list');

				var background_type_color;
				if(content.find('input[name="cs-slide-background_type_color"]:checked').val() == '0') {
					background_type_color = 'transparent';
				}
				else if(content.find('input[name="cs-slide-background_type_color"]:checked').val() == '1') {
					background_type_color = slide.find('.cs-slide-editing-area').css('background-color') + "";
				}
				else {
					background_type_color = content.find('.cs-slide-background_type_color-manual').val();
				}

				var options = {
					slider_parent : parseInt($('.cs-admin .cs-save-settings').data('id')),
					position : i,

          draft : parseInt(content.find('.cs-slide-draft').val()),
          background_type_image : slide.find('.cs-slide-editing-area').css('background-image') == 'none' ? 'none' : slide.find('.cs-slide-editing-area').data('background-image-src') + "",
					background_type_color : background_type_color,
					background_type_color_input : content.find('input[name="cs-slide-background_type_color"]:checked').val(),
					background_propriety_position_x : content.find('.cs-slide-background_propriety_position_x').val(),
					background_propriety_position_y : content.find('.cs-slide-background_propriety_position_y').val(),
					background_repeat : content.find('input[name="cs-slide-background_repeat"]:checked').val() == '0' ? 'no-repeat' : 'repeat',
					background_propriety_size : content.find('.cs-slide-background_propriety_size').val(),
					data_in : content.find('.cs-slide-data_in').val(),
					data_out : content.find('.cs-slide-data_out').val(),
					data_time : parseInt(content.find('.cs-slide-data_time').val()),
					data_easeIn : parseInt(content.find('.cs-slide-data_easeIn').val()),
					data_easeOut : parseInt(content.find('.cs-slide-data_easeOut').val()),
					link : slide.find('.cs-background-link').val(),
					link_new_tab : slide.find('.cs-background-link_new_tab').prop('checked') ? 1 : 0,
					custom_css : content.find('.cs-slide-custom_css').val(),
				};

				final_options['options'][i] = options;

				i++;
			});

			final_options['slider_parent'] = parseInt($('.cs-admin .cs-save-settings').data('id')),

			// Do the ajax call
			jQuery.ajax({
				type : 'POST',
				dataType : 'json',
				url : ajaxurl,
				data : {
					action: 'crellyslider_editSlides',
					security: crellyslider_currentSliderNonce,
					datas : final_options,
				},
				success: function(response) {
					//console.log('Save slides response: ' + response);
					if(response !== false) {
						crellyslider_saveElements();
					}
					else {
						crellyslider_showError();
					}
				},

				error: function(XMLHttpRequest, textStatus, errorThrown) {
					alert('Error saving slides');
					console.log(XMLHttpRequest.responseText);
					crellyslider_showError();
				}
			});
		}

		// Sends an array with all the elements options of each slide
		function crellyslider_saveElements() {
			var slides = $('.cs-admin .cs-slider #cs-slides .cs-slide');
			var i = 0, j = 0;
			var final_options = {};

			final_options['options'] = new Array();
			slides.each(function() {
				var slide = $(this);
				var elements = slide.find('.cs-elements .cs-element-settings');

				elements.each(function() {
					var element = $(this);

					// Stop each loop when reach the void element
					if(element.hasClass('cs-void-element-settings')) {
						return;
					}

					// Get the type of the element
					var type;
					if(element.hasClass('cs-text-element-settings')) {
						type = 'text';
					}
					else if(element.hasClass('cs-image-element-settings')) {
						type = 'image';
					}
					else if(element.hasClass('cs-video-element-settings')) {
						if(element.find('.cs-element-video_src').val() == 'youtube') {
							type = 'youtube_video';
						}
						else {
							type = 'vimeo_video';
						}
					}
					else {
						type = 'undefined';
					}

					var options = {
						slider_parent : parseInt($('.cs-admin .cs-save-settings').data('id')),
						slide_parent : i,
						position : element.index(),
						type : type,

						inner_html : element.hasClass('cs-text-element-settings') ? element.find('.cs-element-inner_html').val() : '',
						image_src : element.hasClass('cs-image-element-settings') ? element.find('.cs-image-element-upload-button').data('src') : '',
						image_alt : element.hasClass('cs-image-element-settings') ? element.find('.cs-image-element-upload-button').data('alt') : '',
						data_left : parseInt(element.find('.cs-element-data_left').val()),
						data_top : parseInt(element.find('.cs-element-data_top').val()),
						z_index : parseInt(element.find('.cs-element-z_index').val()),
						data_delay : parseInt(element.find('.cs-element-data_delay').val()),
						data_time : element.find('.cs-element-data_time').val(),
						data_in : element.find('.cs-element-data_in').val(),
						data_out : element.find('.cs-element-data_out').val(),
						data_ignoreEaseOut : element.find('.cs-element-data_ignoreEaseOut').prop('checked') ? 1 : 0,
						data_easeIn : parseInt(element.find('.cs-element-data_easeIn').val()),
						data_easeOut : parseInt(element.find('.cs-element-data_easeOut').val()),
						custom_css : element.find('.cs-element-custom_css').val(),
						custom_css_classes : element.find('.cs-element-custom_css_classes').val(),
						link : element.hasClass('cs-video-element-settings') ? '' : element.find('.cs-element-link').val(),
						link_new_tab : element.find('.cs-element-link_new_tab').prop('checked') ? 1 : 0,
						video_id : element.hasClass('cs-video-element-settings') ? element.find('.cs-element-video_id').val() : '',
						video_loop : element.hasClass('cs-video-element-settings') ? parseInt(element.find('.cs-element-video_loop').val()) : -1,
						video_autoplay : element.hasClass('cs-video-element-settings') ? parseInt(element.find('.cs-element-video_autoplay').val()) : -1,
						video_start_mute : element.hasClass('cs-video-element-settings') ? parseInt(element.find('.cs-element-video_start_mute').val()) : -1,
						video_pause_while_watching : element.hasClass('cs-video-element-settings') ? parseInt(element.find('.cs-element-video_pause_while_watching').val()) : -1,
					};

					final_options['options'][j] = options;

					j++;
				});

				i++;
			});

			// Proceed?
			final_options['elements'] = 1;
			if(final_options['options'].length == 0) {
				final_options['elements'] = 0;
			}

			final_options['slider_parent'] = parseInt($('.cs-admin .cs-save-settings').data('id'));

			final_options['options'] = JSON.stringify(final_options['options']);

			// Do the ajax call
			jQuery.ajax({
				type : 'POST',
				dataType : 'json',
				url : ajaxurl,
				data : {
					action: 'crellyslider_editElements',
					security: crellyslider_currentSliderNonce,
					datas : final_options,
				},
				success: function(response) {
					//console.log(response);
					if(response !== false) {
						crellyslider_currentSliderNonce = response;
						crellyslider_showSuccess();
					}
					else {
						crellyslider_showError();
					}
				},

				error: function(XMLHttpRequest, textStatus, errorThrown) {
					alert('Error saving elements');
					console.log(XMLHttpRequest.responseText);
					crellyslider_showError();
				}
			});
		}

		function crellyslider_deleteSlider(content) {
			crellyslider_showWait();

			// Get options
			var options = {
				id : parseInt(content.data('delete')),
			};

			// Do the ajax call
			jQuery.ajax({
				type : 'POST',
				dataType : 'json',
				url : ajaxurl,
				data : {
					action: 'crellyslider_deleteSlider',
					security: crellyslider_nonces.deleteSlider,
					datas : options,
				},
				success: function(response) {
					//alert('Delete slider response: ' + response);
					if(response !== false) {
						if($('.cs-sliders-list .cs-delete-slider').length > 1) {
							content.parent().parent().remove();
						}
						else {
							location.reload();
						}
						crellyslider_showSuccess();
					}
					else {
						crellyslider_showError();
					}
				},

				error: function(XMLHttpRequest, textStatus, errorThrown) {
					alert('Error deleting slider');
					console.log(XMLHttpRequest.responseText);
					crellyslider_showError();
				},
			});
		}

		function crellyslider_duplicateSlider(content) {
			crellyslider_showWait();

			// Get options
			var options = {
				id : parseInt(content.data('duplicate')),
			};

			// Do the ajax call
			jQuery.ajax({
				type : 'POST',
				dataType : 'json',
				url : ajaxurl,
				data : {
					action: 'crellyslider_duplicateSlider',
					security: crellyslider_nonces.duplicateSlider,
					datas : options,
				},
				success: function(response) {
					//console.log(response);
					if(response['response'] !== false) {
						var cloned_slider = content.parent().parent().clone().appendTo(content.parent().parent().parent());
						cloned_slider.find('.cs-slider-id').html(response['cloned_slider_id']);
						cloned_slider.find('.cs-slider-name a').html(response['cloned_slider_name']);
						cloned_slider.find('.cs-slider-name a').attr('href', '?page=crellyslider&view=edit&id=' + response['cloned_slider_id']);
						cloned_slider.find('.cs-slider-alias').html(response['cloned_slider_alias']);
						cloned_slider.find('.cs-slider-shortcode').html('[crellyslider alias="' + response['cloned_slider_alias'] + '"]');
						cloned_slider.find('.cs-edit-slider').attr('href', '?page=crellyslider&view=edit&id=' + response['cloned_slider_id']);
						cloned_slider.find('.cs-duplicate-slider').data('duplicate', response['cloned_slider_id']);
						cloned_slider.find('.cs-delete-slider').data('delete', response['cloned_slider_id']);
						cloned_slider.find('.cs-export-slider').data('export', response['cloned_slider_id']);

						crellyslider_showSuccess();
					}
					else {
						crellyslider_showError();
					}
				},

				error: function(XMLHttpRequest, textStatus, errorThrown) {
					alert('Error duplicating slider');
					console.log(XMLHttpRequest.responseText);
					crellyslider_showError();
				},
			});
		}

		function crellyslider_exportSlider(content) {
			crellyslider_showWait();

			// Get options
			var options = {
				id : parseInt(content.data('export')),
			};

			// Do the ajax call
			jQuery.ajax({
				type : 'POST',
				dataType : 'json',
				url : ajaxurl,
				data : {
					action: 'crellyslider_exportSlider',
					security: crellyslider_nonces.exportSlider,
					datas : options,
				},
				success: function(response) {
					if(response['response'] !== false) {
						window.location.href = response['url'];
						crellyslider_showSuccess();
					}
					else {
						crellyslider_showError();
					}
				},

				error: function(XMLHttpRequest, textStatus, errorThrown) {
					alert('Error while exporting the slider');
					console.log(XMLHttpRequest.responseText);
					crellyslider_showError();
				},
			});
		}

		function crellyslider_importSlider() {
			var file = $('#cs-import-file')[0].files[0];

			if(! file) {
				return;
			}

			// Reset input file. Prevents conflicts
			$('#cs-import-file').val('');

			crellyslider_showWait();

			// Form data (for file uploads)
			var fd = new FormData();
			fd.append('file', file);
			fd.append('action', 'crellyslider_importSlider');
			fd.append('security', crellyslider_nonces.importSlider);

			// Do the ajax call
			jQuery.ajax({
				type : 'POST',
				url : ajaxurl,
				contentType: false,
				processData : false,
				data : fd,
				success: function(response) {
          response = JSON.parse(response);
          //console.log(response);
					if(response['response'] !== false) {
						var content = $('.cs-sliders-list .cs-duplicate-slider:eq(0)');
						if(content.length > 0) {
							var imported_slider = content.parent().parent().clone().appendTo(content.parent().parent().parent());
							imported_slider.find('.cs-slider-id').html(response['imported_slider_id']);
							imported_slider.find('.cs-slider-name a').html(response['imported_slider_name']);
							imported_slider.find('.cs-slider-name a').attr('href', '?page=crellyslider&view=edit&id=' + response['imported_slider_id']);
							imported_slider.find('.cs-slider-alias').html(response['imported_slider_alias']);
							imported_slider.find('.cs-slider-shortcode').html('[crellyslider alias="' + response['imported_slider_alias'] + '"]');
							imported_slider.find('.cs-edit-slider').attr('href', '?page=crellyslider&view=edit&id=' + response['imported_slider_id']);
							imported_slider.find('.cs-duplicate-slider').data('duplicate', response['imported_slider_id']);
							imported_slider.find('.cs-delete-slider').data('delete', response['imported_slider_id']);
							imported_slider.find('.cs-delete-slider').data('export', response['imported_slider_id']);
						}
						else {
							location.reload();
						}

						crellyslider_showSuccess();
					}
					else {
						crellyslider_showError();
					}
				},

				error: function(XMLHttpRequest, textStatus, errorThrown) {
					alert('Error while importing the slider');
					console.log(XMLHttpRequest.responseText);
					crellyslider_showError();
				},
			});
		}

	});
})(jQuery);