mirror of
https://github.com/e107inc/e107.git
synced 2025-01-18 05:09:05 +01:00
1079 lines
27 KiB
JavaScript
1079 lines
27 KiB
JavaScript
var e107 = e107 || {'settings': {}, 'behaviors': {}};
|
|
|
|
(function ($)
|
|
{
|
|
|
|
/**
|
|
* Initializes click event on '.e-modal' elements.
|
|
*
|
|
* @type {{attach: e107.behaviors.eModalAdmin.attach}}
|
|
*/
|
|
e107.behaviors.eModalAdmin = {
|
|
attach: function (context, settings)
|
|
{
|
|
$(context).find('.e-modal').once('e-modal-admin').each(function ()
|
|
{
|
|
var $that = $(this);
|
|
|
|
$that.on('click', function ()
|
|
{
|
|
var $this = $(this);
|
|
|
|
if($this.attr('data-cache') === 'false')
|
|
{
|
|
$('#uiModal').on('shown.bs.modal', function ()
|
|
{
|
|
$(this).removeData('bs.modal');
|
|
});
|
|
}
|
|
|
|
var url = $this.attr('href');
|
|
var caption = $this.attr('data-modal-caption');
|
|
var height = ($(window).height() * 0.7) - 120;
|
|
|
|
|
|
if(caption === undefined)
|
|
{
|
|
caption = '';
|
|
}
|
|
|
|
$('.modal-body').html('<div class="well"><iframe id="e-modal-iframe" width="100%" height="' + height + 'px" frameborder="0" scrolling="auto" style="display:block;background-color:transparent" allowtransparency="true" src="' + url + '"></iframe></div>');
|
|
$('.modal-caption').html(caption + ' <i id="e-modal-loading" class="fa fa-spin fa-spinner"></i>');
|
|
$('.modal').modal('show');
|
|
|
|
$("#e-modal-iframe").on("load", function ()
|
|
{
|
|
$('#e-modal-loading').hide();
|
|
|
|
if($this.attr('data-modal-submit'))
|
|
{
|
|
var buttonCaption = $('#e-modal-iframe').contents().find('#etrigger-submit').text(); // copy submit button caption from iframe form.
|
|
$('#e-modal-submit').text(buttonCaption).fadeIn(); // display the button in the modal footer.
|
|
$('#e-modal-iframe').contents().find('.buttons-bar').hide(); // hide buttons in the iframe's form.
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
return false;
|
|
});
|
|
});
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Run tips on .field-help.
|
|
*
|
|
* @type {{attach: e107.behaviors.fieldHelpTooltip.attach}}
|
|
*/
|
|
e107.behaviors.fieldHelpTooltip = {
|
|
attach: function (context, settings)
|
|
{
|
|
var selector = 'div.tbox,div.checkboxes,input,textarea,select,label,.e-tip,div.form-control';
|
|
|
|
$(context).find(selector).once('field-help-tooltip').each(function ()
|
|
{
|
|
var $this = $(this);
|
|
var $fieldHelp = $this.nextAll(".field-help");
|
|
var placement = 'bottom';
|
|
|
|
if($this.is("textarea"))
|
|
{
|
|
placement = 'top';
|
|
}
|
|
|
|
var custPlace = $fieldHelp.attr('data-placement'); // ie top|left|bottom|right
|
|
|
|
if(custPlace !== undefined)
|
|
{
|
|
placement = custPlace;
|
|
}
|
|
|
|
$fieldHelp.hide();
|
|
|
|
$this.tooltip({
|
|
title: function ()
|
|
{
|
|
return $fieldHelp.html();
|
|
},
|
|
fade: true,
|
|
html: true,
|
|
opacity: 1.0,
|
|
placement: placement,
|
|
container: 'body',
|
|
delay: {
|
|
show: 300,
|
|
hide: 600
|
|
}
|
|
});
|
|
});
|
|
}
|
|
};
|
|
|
|
})(jQuery);
|
|
|
|
(function (jQuery)
|
|
{
|
|
|
|
/**
|
|
* jQuery extension to make admin tab 'fadeIn' with 'display: inline-block'.
|
|
*
|
|
* @param displayMode
|
|
* A string determining display mode for element after the animation.
|
|
* Default: 'inline-block'.
|
|
* @param duration
|
|
* A string or number determining how long the animation will run.
|
|
* Default: 400.
|
|
*/
|
|
jQuery.fn.fadeInAdminTab = function (displayMode, duration)
|
|
{
|
|
var $this = $(this);
|
|
|
|
if($this.css('display') !== 'none')
|
|
{
|
|
return;
|
|
}
|
|
|
|
displayMode = displayMode || 'inline-block';
|
|
duration = duration || 400;
|
|
|
|
$this.fadeIn(duration, function ()
|
|
{
|
|
$this.css('display', displayMode);
|
|
});
|
|
};
|
|
|
|
})(jQuery);
|
|
|
|
|
|
$(document).ready(function()
|
|
{
|
|
|
|
$('#e-modal-submit').click(function () {
|
|
$('#e-modal-iframe').contents().find('#etrigger-submit').trigger('click');
|
|
|
|
var type = $(this).data('loading-icon');
|
|
var orig = $(this).text();
|
|
|
|
var caption = "<i class='fa fa-spin " + type + " fa-fw'></i>";
|
|
caption += "<span>" + orig + "</span>";
|
|
|
|
$(this).html(caption);
|
|
|
|
$('#e-modal-iframe').on('load', function(){
|
|
|
|
var buttonFound = $('#e-modal-iframe').contents().find('#etrigger-submit');
|
|
|
|
if(buttonFound.length === 0) // disable resubmitting if not button found after submit.
|
|
{
|
|
$('#e-modal-submit').fadeOut(1000);
|
|
}
|
|
|
|
$('#e-modal-submit').text(orig); // remove spinner.
|
|
|
|
});
|
|
|
|
});
|
|
|
|
$('[data-dismiss="modal"]').click(function(){ // hide button for next modal popup usage.
|
|
|
|
$('#e-modal-submit').hide(1000);
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$('form').h5Validate(
|
|
{ errorClass: 'has-error' }
|
|
); // allow older browsers to use html5 validation.
|
|
|
|
// Change hash when a tab changes
|
|
$('.nav-tabs a').on('shown', function (event) {
|
|
var hash = event.target.href.toString().split('#')[1], form = $(event.target).parents('form')[0];
|
|
window.location.hash = '/' + hash;
|
|
if(form) {
|
|
$(form).attr('action', $(form).attr('action').split('#')[0] + '#/' + hash);
|
|
}
|
|
});
|
|
|
|
// tabs hash
|
|
if(/^#\/\w+/.test(window.location.hash)) {
|
|
var hash = window.location.hash.substr(2);
|
|
if(hash.match('^tab')){ $('.nav-tabs a[href=#' + hash + ']').tab('show'); }
|
|
}
|
|
|
|
$('.e-typeahead').each( function(){
|
|
|
|
var id = $(this).attr("id");
|
|
var name = '#' + id.replace('-usersearch', '');
|
|
var newval = $(this).attr("data-value");
|
|
|
|
$(this).typeahead({
|
|
source: $(this).attr("data-source"),
|
|
updater: function(text, type){
|
|
if(type === 'value')
|
|
{
|
|
$(name).val(text);
|
|
}
|
|
return text;
|
|
}
|
|
});
|
|
});
|
|
|
|
/* Switch to Tab containing invalid form field. */
|
|
$('input[type=submit],button[type=submit]').on('click', function() {
|
|
|
|
var id = $(this).closest('form').attr('id');
|
|
var found = false;
|
|
|
|
$('#'+id).find('input:invalid,select:invalid,textarea:invalid').each(function(index, node) {
|
|
|
|
var tab = $('#'+node.id).closest('.tab-pane').attr('id');
|
|
|
|
if(tab && (found === false))
|
|
{
|
|
$('a[href="#'+tab+'"]').tab('show');
|
|
found = true;
|
|
// alert(node.id+' : '+tab + ' '.index);
|
|
}
|
|
// var label = $('label[for=' + node.id + ']');
|
|
});
|
|
|
|
return true;
|
|
});
|
|
|
|
|
|
|
|
// run tips on title attribute.
|
|
$(".e-tip").each(function() {
|
|
|
|
|
|
var tip = $(this).attr('title');
|
|
if(!tip)
|
|
{
|
|
return;
|
|
}
|
|
|
|
var pos = $(this).attr('data-placement');
|
|
if(!pos)
|
|
{
|
|
pos = 'top';
|
|
}
|
|
|
|
$(this).tooltip({opacity:1.0,fade:true, placement: pos});
|
|
// $(this).css( 'cursor', 'pointer' )
|
|
});
|
|
|
|
|
|
$("#uiModal").draggable({
|
|
handle: ".modal-header"
|
|
});
|
|
|
|
|
|
$('div.e-container').editable({
|
|
selector: '.e-editable',
|
|
display: function (value, sourceData)
|
|
{
|
|
// HTML entities decoding... fix for:
|
|
// @see https://github.com/e107inc/e107/issues/2351
|
|
$.each(sourceData, function (index, element)
|
|
{
|
|
element.text = $("<div/>").html(element.text).text();
|
|
sourceData[index] = element;
|
|
});
|
|
|
|
// Display checklist as comma-separated values.
|
|
var html = [];
|
|
var checked = $.fn.editableutils.itemsByValue(value, sourceData);
|
|
|
|
if(checked.length)
|
|
{
|
|
$.each(checked, function (i, v)
|
|
{
|
|
html.push($.fn.editableutils.escape(v.text));
|
|
});
|
|
|
|
$(this).html(html.join(', '));
|
|
}
|
|
else
|
|
{
|
|
$(this).text(value);
|
|
}
|
|
}
|
|
});
|
|
|
|
// $('.e-editable').editable();
|
|
|
|
// Fix for boostrap modal cache.
|
|
|
|
// $('.modal').on('hidden',function(){
|
|
// $(this).removeData('.modal');
|
|
// $('#uiModal .modal-label').text('Loading');
|
|
// $('#uiModal .modal-body').html('default_body');
|
|
// });
|
|
|
|
$('body').on('hidden', '.modal', function () {
|
|
$(this).removeData('modal');
|
|
$('#uiModal .modal-label').text('Loading...');
|
|
$('#uiModal .modal-body').html(' ');
|
|
});
|
|
|
|
|
|
|
|
|
|
$('a[data-toggle="modal"]').on('click', function()
|
|
{
|
|
var link = $(this).attr('href');
|
|
var caption = $(this).attr('data-modal-caption');
|
|
var height = ($(window).height() * 0.9) - 50;
|
|
|
|
$('#uiModal .modal-caption').text(caption);
|
|
$('.modal').height(height);
|
|
// $('#uiModal .modal-label').text('Loading...');
|
|
// $('#uiModal .modal-body').html(link);
|
|
// alert(caption);
|
|
}
|
|
);
|
|
|
|
|
|
$('button[data-loading-text],a[data-loading-text]').on('click', function()
|
|
{
|
|
var caption = $(this).attr('data-loading-text');
|
|
$(this).removeClass('btn-success');
|
|
$(this).removeClass('btn-primary');
|
|
$(this).html(caption);
|
|
if($(this).attr('data-disable') == 'true')
|
|
{
|
|
$(this).attr('disabled', 'disabled');
|
|
}
|
|
return true;
|
|
}
|
|
);
|
|
|
|
$('input[data-loading-text]').on('click', function()
|
|
{
|
|
var caption = $(this).attr('data-loading-text');
|
|
$(this).val(caption);
|
|
$(this).removeClass('btn-success');
|
|
$(this).removeClass('btn-primary');
|
|
//$(this).attr('disabled', 'disabled').val(caption);
|
|
return true;
|
|
}
|
|
);
|
|
|
|
|
|
$('a[data-toggle-sidebar]').on('click', function(e)
|
|
{
|
|
e.preventDefault();
|
|
|
|
var $leftPanel = $(".admin-left-panel");
|
|
var $rightPanel = $(".admin-right-panel");
|
|
|
|
if ($rightPanel.hasClass('col-md-12'))
|
|
{
|
|
$rightPanel.toggleClass("col-md-9 col-md-12");
|
|
$rightPanel.toggleClass("col-lg-10 col-lg-12");
|
|
$leftPanel.toggle(1000);
|
|
}
|
|
else
|
|
{
|
|
$leftPanel.toggle(1000, function() {
|
|
$rightPanel.toggleClass("col-md-9 col-md-12");
|
|
$rightPanel.toggleClass("col-lg-10 col-lg-12");
|
|
});
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
/* InfoPanel Comment approval and deletion */
|
|
$(document).on("click", "button[data-comment-action]", function(){
|
|
|
|
var url = $(this).attr("data-target");
|
|
var action = $(this).attr('data-comment-action');
|
|
var id = $(this).attr("data-comment-id");
|
|
var next = $('#comment-'+ id).nextAll('.hide').attr("id");
|
|
|
|
$.ajax({
|
|
type: 'POST',
|
|
url: url + '?ajax_used=1&mode='+action,
|
|
data: { itemid: id },
|
|
success: function(data) {
|
|
var a = $.parseJSON(data);
|
|
// alert(data);
|
|
if(!a.error)
|
|
{
|
|
$('#comment-'+ id).hide(800, function () {
|
|
$('#'+next).show('slow');
|
|
$('#'+next).removeClass('hide');
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
});
|
|
|
|
return false;
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
var progresspump = null;
|
|
|
|
$('.e-progress-cancel').on('click', function(e)
|
|
{
|
|
clearInterval(progresspump);
|
|
var target = $(this).attr('data-progress-target');
|
|
$("#"+target).closest('.progress').removeClass("active");
|
|
progresspump = null;
|
|
alert('stopped');
|
|
});
|
|
|
|
$('.e-progress').on('click', function(e)
|
|
{
|
|
// alert('Process Started');
|
|
|
|
var target = $(this).attr('data-progress-target');
|
|
var script = $(this).attr('data-progress');
|
|
var show = $(this).attr('data-progress-show');
|
|
var hide = $(this).attr('data-progress-hide');
|
|
var mode = $(this).attr('data-progress-mode');
|
|
var interval = $(this).attr('data-progress-interval');
|
|
|
|
if(interval === undefined)
|
|
{
|
|
interval = 1000;
|
|
}
|
|
|
|
$("#"+target).css('width','1%'); // so we know it's running.
|
|
|
|
progresspump = setInterval(function(){
|
|
|
|
$.get(script, { mode: mode }).done( function(data){
|
|
|
|
// alert(data);
|
|
$("#"+target).css('width', data+'%'); // update the progress bar width */
|
|
$("#"+target).html(data+'%'); // display the numeric value */
|
|
|
|
|
|
data = parseInt(data);
|
|
|
|
if(data > 99.999) {
|
|
|
|
clearInterval(progresspump);
|
|
$("#"+target).closest('.progress').removeClass("active");
|
|
|
|
$("#"+target).html("Done");
|
|
|
|
if(hide !== 'undefined')
|
|
{
|
|
$('#'+hide).hide();
|
|
}
|
|
|
|
if(show !== 'undefined')
|
|
{
|
|
$('#'+show).show('slow');
|
|
}
|
|
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}, interval);
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
$('a[data-toggle="modal"]').on('click', function()
|
|
{
|
|
$(this).removeData('modal');
|
|
$('#uiModal .modal-header').text($(this).attr('title'));
|
|
var link = $(this).attr('href');
|
|
alert(link);
|
|
$('#uiModal .modal-body').html( 'table' );
|
|
//return false;
|
|
|
|
return this;
|
|
|
|
$('#uiModal .modal-body').load(link, function(response, status, xhr)
|
|
{
|
|
if (status === 'error')
|
|
{
|
|
//console.log('got here');
|
|
$('#uiModal .modal-body').html('<h2>Oh boy</h2><p>Sorry, but there was an error:' + xhr.status + ' ' + xhr.statusText+ '</p>');
|
|
}
|
|
return false;
|
|
return this;
|
|
}
|
|
)
|
|
|
|
});
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$('.e-noclick').click(function(e) {
|
|
e.stopPropagation();
|
|
});
|
|
|
|
|
|
// BC Compatible
|
|
$("select.tbox").each(function() {
|
|
|
|
var multi = $(this).attr('multiple');
|
|
|
|
if(multi === undefined)
|
|
{
|
|
// $(this).selectpicker(); // causes HTML5 validation alert to be hidden.
|
|
return;
|
|
}
|
|
else
|
|
{
|
|
$(this).multiselect({ buttonClass: 'btn btn-default'} );
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// $(".e-spinner").spinner(); //FIXME breaks tooltips etc.
|
|
|
|
|
|
$(document).on("click", ".e-alert", function(){
|
|
|
|
var message = $(this).html();
|
|
alert(message);
|
|
$("#uiAlert").val(message);
|
|
$("#uiAlert").alert();
|
|
$("#uiAlert").fadeIn('slow');
|
|
window.setTimeout(function() { $("#uiAlert").alert('close'); }, 4000);
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
$(".e-radio-multi").each(function() {
|
|
// $(this).nextAll(".field-help").hide();
|
|
// $(this).nextAll(":input").tipsy({title: 'hello'});
|
|
|
|
});
|
|
|
|
// $(".e-tags").tag();
|
|
|
|
|
|
|
|
// Decorate
|
|
$(".adminlist tr:even").addClass("even");
|
|
$(".adminlist tr:odd").addClass("odd");
|
|
$(".adminlist tr:first").addClass("first");
|
|
$(".adminlist tr:last").addClass("last");
|
|
|
|
|
|
|
|
// Admin Prefs Navigation
|
|
|
|
$(".plugin-navigation a").click(function () {
|
|
$(".plugin-navigation a").each(function(index) {
|
|
var ot = $(this).attr("href");
|
|
$(ot).hide().removeClass('e-hideme');
|
|
$(this).closest("li").removeClass("active");
|
|
$(this).switchClass( "link-active", "link", 0 );
|
|
});
|
|
var id = $(this).attr("href"), hash = id.split('#')[1], form = $('.admin-menu')[0]; // FIXME - a better way to detect the page form
|
|
|
|
$(this).switchClass( "link", "link-active", 30 );
|
|
$(this).closest("li").addClass("active");
|
|
|
|
$(id).removeClass('e-hideme').show({
|
|
effect: "slide"
|
|
});
|
|
// 'remember' the active navigation pane
|
|
if(hash) {
|
|
window.location.hash = 'nav-' + hash;
|
|
if(form) {
|
|
|
|
// $(form).attr('action', $(form).attr('action').split('#')[0] + '#nav-' + hash); // breaks menu-manager nav.
|
|
}
|
|
return false;
|
|
}
|
|
});
|
|
|
|
// plugin navigation hash
|
|
if(/^#nav-+/.test(window.location.hash)) {
|
|
$("a[href='" + window.location.hash.replace('nav-', '') + "']").click();
|
|
}
|
|
|
|
// backend
|
|
/*
|
|
$(".e-password").pwdMeter({
|
|
minLength: 6,
|
|
displayGeneratePassword: true,
|
|
generatePassText: "Generate",
|
|
randomPassLength: 12
|
|
});*/
|
|
|
|
|
|
|
|
// Sorting
|
|
var fixHelper = function(e, ui) {
|
|
ui.closest("tr").switchClass( "odd", "highlight-odd e-sort", 0 );
|
|
ui.closest("tr").switchClass( "even", "highlight-even e-sort", 0 );
|
|
ui.children().each(function() {
|
|
$(this).width($(this).width());
|
|
// $(this).closest("tr").switchClass( "odd", "highlight-odd", 0 );
|
|
// $(this).closest("tr").switchClass( "even", "highlight-even", 0 );
|
|
});
|
|
return ui;
|
|
};
|
|
|
|
$("#e-sort").sortable({
|
|
helper: fixHelper,
|
|
cursor: "move",
|
|
opacity: 0.9,
|
|
handle: ".e-sort",
|
|
distance: 20,
|
|
containment: "parent",
|
|
stop: function(e,ui) {
|
|
var allItems = $(this).sortable("toArray");
|
|
var newSortValue = allItems.indexOf( $(ui.item).attr("id") );
|
|
// alert($(ui.item).attr("id") + " was moved to index " + newSortValue);
|
|
$(".highlight-even").switchClass( "highlight-even", "even", 600 );
|
|
$(".highlight-odd").switchClass( "highlight-odd", "odd", 600 );
|
|
$("tr.e-sort").removeClass( "e-sort");
|
|
|
|
},
|
|
|
|
update: function(event, ui) {
|
|
var allItems = $(this).sortable("toArray");
|
|
// console.log(allItems);
|
|
var neworder = allItems.indexOf( $(ui.item).attr("id") );
|
|
var linkid = $(ui.item).attr("id");
|
|
// $("td").removeClass("e-moving","slow");
|
|
|
|
var script = $(".sort-trigger:first").attr("data-target");
|
|
|
|
$.ajax({
|
|
type: "POST",
|
|
url: script,
|
|
data: { all: allItems, linkid: linkid, neworder: neworder }
|
|
// data: { linkid: linkid, neworder: neworder }
|
|
}).done(function( msg ) {
|
|
|
|
// alert("Posted: "+allItems+" Updated: "+ msg );
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
// }).disableSelection(); // causes issue with admin->users drop-down selection.
|
|
|
|
|
|
// Check ALl Button
|
|
$("#e-check-all").click(function(){
|
|
$('input[type="checkbox"]').attr("checked", "checked");
|
|
});
|
|
|
|
// Uncheck all button.
|
|
$("#e-uncheck-all").click(function(){
|
|
$('input[type="checkbox"]').removeAttr("checked");
|
|
});
|
|
|
|
|
|
|
|
// Check-All checkbox toggle
|
|
$("input.toggle-all").click(function(evt) {
|
|
var selector = 'input[type="checkbox"].checkbox';
|
|
|
|
if($(this).val().indexOf('jstarget:') === 0) {
|
|
selector = 'input[type="checkbox"][name^="' + $(this).val().split(/jstarget\:/)[1] + '"]';
|
|
}
|
|
|
|
if($(this).is(":checked")){
|
|
//$(selector).attr("checked", "checked");
|
|
$(selector).prop('checked', true);
|
|
}
|
|
else{
|
|
$(selector).prop('checked',false);
|
|
// $(selector).removeAttr("checked");
|
|
}
|
|
});
|
|
|
|
// highlight checked row
|
|
$(".adminlist input[type='checkbox']").click(function(evt){
|
|
|
|
if(this.checked)
|
|
{
|
|
$(this).closest("tr.odd").switchClass( "odd", "highlight-odd", 50 );
|
|
$(this).closest("tr.even").switchClass( "even", "highlight-even", 50 );
|
|
}
|
|
else
|
|
{
|
|
$(this).closest("tr.highlight-odd").switchClass( "highlight-odd", "odd", 300 );
|
|
$(this).closest("tr.highlight-even").switchClass( "highlight-even", "even", 300 );
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// Basic Delete Confirmation
|
|
$('input.delete,button.delete,a[data-confirm]').click(function(){
|
|
answer = confirm($(this).attr("data-confirm"));
|
|
return answer; // answer is a boolean
|
|
});
|
|
|
|
$(".e-confirm").click(function(){
|
|
answer = confirm($(this).attr("title"));
|
|
return answer; // answer is a boolean
|
|
});
|
|
|
|
|
|
// see boot.php for main processing. (works only in admin)
|
|
$(".e-sef-generate").click(function(){
|
|
|
|
src = $(this).attr("data-src");
|
|
target = $(this).attr("data-target");
|
|
toconvert = $('#'+src).val();
|
|
script = window.location;
|
|
|
|
$.ajax({
|
|
type: "POST",
|
|
url: script,
|
|
data: { source: toconvert, mode: 'sef' }
|
|
|
|
}).done(function( data ) {
|
|
|
|
var a = $.parseJSON(data);
|
|
// alert(a.converted);
|
|
if(a.converted)
|
|
{
|
|
$('#'+target).val(a.converted);
|
|
|
|
// $('#uiAlert').notify({
|
|
// type: 'success',
|
|
// message: { text: 'Completed' },
|
|
// fadeOut: { enabled: true, delay: 2000 }
|
|
// }).show();
|
|
|
|
}
|
|
});
|
|
|
|
});
|
|
|
|
|
|
$('body').on('slid.bs.carousel', '.carousel', function(){
|
|
var currentIndex = $(this).find('.active').index();
|
|
var text = (currentIndex + 1);
|
|
var id = $(this).attr('id') + '-index'; // admin-ui-carousel-index etc.
|
|
$('#'+id).text(text);
|
|
|
|
// this takes commented content for each carousel slide and enables it, one slide at a time as we scroll.
|
|
|
|
$(this).find('.item').each(function(index, node)
|
|
{
|
|
var content = $(this).contents();
|
|
|
|
var item = content[0];
|
|
|
|
if(item.nodeType === 8) // commented code @see e_media::browserCarousel() using '<!--'
|
|
{
|
|
$(item).replaceWith(item.nodeValue);
|
|
return false;
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
$(window).load(function() {
|
|
|
|
$('.carousel').each(function(){
|
|
|
|
$(this).carouselHeights();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
// Normalize Bootstrap Carousel Heights
|
|
|
|
$.fn.carouselHeights = function() {
|
|
|
|
var items = $(this).find('.item'), // grab all slides
|
|
|
|
heights = [], // create empty array to store height values
|
|
|
|
tallest, // create variable to make note of the tallest slide
|
|
|
|
call;
|
|
|
|
var normalizeHeights = function() {
|
|
|
|
items.each(function() { // add heights to array
|
|
|
|
heights.push($(this).outerHeight());
|
|
|
|
});
|
|
|
|
tallest = Math.max.apply(null, heights); // cache largest value
|
|
|
|
items.css('height', tallest);
|
|
|
|
};
|
|
|
|
normalizeHeights();
|
|
|
|
$(window).on('resize orientationchange', function() {
|
|
|
|
// reset vars
|
|
|
|
tallest = 0;
|
|
|
|
heights.length = 0;
|
|
|
|
items.css('height', ''); // reset height
|
|
|
|
if(call){
|
|
|
|
clearTimeout(call);
|
|
|
|
};
|
|
|
|
call = setTimeout(normalizeHeights, 100); // run it again
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
$("a.menuManagerSelect").click(function(e){
|
|
|
|
|
|
var link = $(this).attr('data-url');
|
|
var layout= $(this).attr('data-layout');
|
|
|
|
$('#curLayout').val(layout);
|
|
$('ul.e-mm-selector').hide();
|
|
$('form#e-mm-selector').attr('action',link);
|
|
|
|
var text = $(this).text();
|
|
$(this).html(text + ' <i class="e-mm-select-loading fa fa-spin fa-spinner"></i>');
|
|
|
|
$("#menu_iframe").attr("src",link);
|
|
|
|
$("#menu_iframe").on("load", function () {
|
|
$('.e-mm-select-loading').hide();
|
|
});
|
|
|
|
|
|
return false;
|
|
});
|
|
|
|
|
|
// Menu Manager Layout drop-down options
|
|
$("#menuManagerSelect").change(function(){
|
|
var link = $(this).val();
|
|
$("#menu_iframe").attr("src",link);
|
|
return false;
|
|
});
|
|
|
|
|
|
|
|
$("a.e-mm-selector").click(function(e){
|
|
|
|
var hash = $('#curLayout').val();
|
|
// alert(hash);
|
|
|
|
var selector = 'ul.dropdown-menu.e-mm-selector.' + hash;
|
|
|
|
$(selector).toggle();
|
|
|
|
// $('.menu-selector input[type="checkbox"]').removeAttr("checked");
|
|
|
|
return false;
|
|
});
|
|
|
|
|
|
|
|
|
|
$(".e-mm-selector li input").click(function(e){
|
|
|
|
$("ul.dropdown-menu.e-mm-selector").css('display','none');
|
|
|
|
});
|
|
|
|
|
|
$(".e-shake" ).effect("shake",{times: 10, distance: 2},20);
|
|
|
|
|
|
$("select.filter").change(function() {
|
|
$(this).closest("form").submit();
|
|
});
|
|
|
|
|
|
$("div.e-autocomplete").keyup(function() { //TODO.
|
|
|
|
|
|
});
|
|
|
|
|
|
$(function() {
|
|
|
|
//$(".e-menumanager-delete").live("click", function(e){
|
|
|
|
|
|
$( ".column" ).sortable({
|
|
connectWith: ".column",
|
|
constain: 'table',
|
|
// stop: function(e,ui) {
|
|
// var allItems = $(this).sortable("toArray");
|
|
// var newSortValue = allItems.indexOf( $(ui.item).attr("id") );
|
|
// // alert($(ui.item).attr("id") + " was moved to index " + newSortValue);
|
|
|
|
// },
|
|
cursor: "move",
|
|
opacity: 0.9,
|
|
handle: ".portlet-header",
|
|
distance: 20,
|
|
remove: function(event, ui) {
|
|
// ui.item.clone().appendTo(this);
|
|
// $(this).sortable('cancel');
|
|
},
|
|
stop: function(event, ui) {
|
|
|
|
var linkid = $(ui.item).attr("id");
|
|
var area = $('#'+linkid).closest('.column').attr('id');
|
|
var areaList = $('#'+linkid).closest('.column').sortable("toArray");
|
|
// alert(areaList);
|
|
|
|
$(ui.item).attr("id")
|
|
|
|
var layout = $('#dbLayout').attr("value");
|
|
// alert(layout);
|
|
|
|
var opt = linkid.split('-');
|
|
|
|
if(area == 'remove')
|
|
{ // alert(area);
|
|
var remove = linkid;
|
|
areaList = '';
|
|
$('#check-' + opt[1]).show('fast');
|
|
$('#option-' + opt[1]).hide('fast');
|
|
$('#status-' + opt[1]).text('remove');
|
|
}
|
|
else
|
|
{
|
|
if($('#status-' + opt[1]).text() == 'insert' || $('#status-' + opt[1]).text() == 'update')
|
|
{
|
|
var stat = 'update';
|
|
}
|
|
else
|
|
{
|
|
var stat = 'insert';
|
|
|
|
}
|
|
var aId = area.split('-');
|
|
var newId = linkid + '-' + aId[1];
|
|
|
|
var remId = $('#'+linkid).find(".delete").attr('id') + aId[1];
|
|
$('#'+linkid).find(".delete").attr('id',remId);
|
|
var hidem = "block-" + opt[1] +'-' + aId[1];
|
|
$('#'+linkid).attr('id',hidem);
|
|
|
|
$('#check-' + opt[1]).hide('fast');
|
|
$('#option-' + opt[1]).show('fast');
|
|
$('#status-' + opt[1]).text(stat);
|
|
}
|
|
|
|
$.ajax({
|
|
type: "POST",
|
|
url: "menus.php?ajax_used=1",
|
|
data: { removeid: remove, insert:linkid, mode: stat, list: areaList, area: area, layout: layout }
|
|
// data: { linkid: linkid, neworder: neworder }
|
|
}).done(function( msg ) {
|
|
|
|
// alert(" Updated: "+ msg );
|
|
});
|
|
|
|
}
|
|
});
|
|
|
|
$( ".portlet" ).addClass( "ui-widget ui-widget-content ui-helper-clearfix ui-corner-all" )
|
|
// $( ".portlet" ).addClass( "ui-widget ui-widget-content ui-helper-clearfix ui-corner-all" )
|
|
.find( ".portlet-header" )
|
|
.addClass( "ui-widget-header ui-corner-all" )
|
|
.prepend( "<span class='ui-icon ui-icon-minusthick'></span>")
|
|
.end()
|
|
.find( ".portlet-content" );
|
|
|
|
$( ".portlet-header .ui-icon" ).click(function() {
|
|
$( this ).toggleClass( "ui-icon-minusthick" ).toggleClass( "ui-icon-plusthick" );
|
|
$( this ).parents( ".portlet:first" ).find( ".portlet-content" ).toggle();
|
|
});
|
|
|
|
$( ".column" ).disableSelection();
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$.fn.extend({
|
|
insertAtCaret: function(myValue) {
|
|
if (document.selection) {
|
|
this.focus();
|
|
sel = document.selection.createRange();
|
|
sel.text = myValue;
|
|
this.focus();
|
|
}
|
|
else if (this.selectionStart || this.selectionStart == '0') {
|
|
var startPos = this.selectionStart;
|
|
var endPos = this.selectionEnd;
|
|
var scrollTop = this.scrollTop;
|
|
this.value = this.value.substring(0, startPos)+myValue+this.value.substring(endPos,this.value.length);
|
|
this.focus();
|
|
this.selectionStart = startPos + myValue.length;
|
|
this.selectionEnd = startPos + myValue.length;
|
|
this.scrollTop = scrollTop;
|
|
} else {
|
|
this.value += myValue;
|
|
this.focus();
|
|
}
|
|
}
|
|
|
|
|
|
|
|
})
|
|
|
|
// Text-area AutoGrow
|
|
// $("textarea.e-autoheight").elastic();
|
|
});
|
|
|
|
|
|
|