From ca017460fab82cf48fcccdc5baf4de13c156c956 Mon Sep 17 00:00:00 2001 From: Elijah Madden Date: Tue, 25 Oct 2016 15:14:22 +0900 Subject: [PATCH] Don't need a closure, jQuery ready function is enough. Use strict. --- administrator/templates/isis/js/template.js | 647 ++++++++++---------- 1 file changed, 328 insertions(+), 319 deletions(-) diff --git a/administrator/templates/isis/js/template.js b/administrator/templates/isis/js/template.js index 5eb58683c8620..618939433e7d9 100644 --- a/administrator/templates/isis/js/template.js +++ b/administrator/templates/isis/js/template.js @@ -6,410 +6,419 @@ * @since 3.0 */ -(function($) +jQuery(function($) { - $(document).ready(function() - { - var $w = $(window); + 'use strict'; - $('*[rel=tooltip]').tooltip(); + var $w = $(window); - // Turn radios into btn-group - $('.radio.btn-group label').addClass('btn'); + $('*[rel=tooltip]').tooltip(); - $('fieldset.btn-group').each(function() { - // Handle disabled, prevent clicks on the container, and add disabled style to each button - if ($(this).prop('disabled')) { - $(this).css('pointer-events', 'none').off('click'); - $(this).find('.btn').addClass('disabled'); - } - }); - - $('.btn-group label:not(.active)').click(function() - { - var label = $(this); - var input = $('#' + label.attr('for')); + // Turn radios into btn-group + $('.radio.btn-group label').addClass('btn'); - if (!input.prop('checked')) - { - label.closest('.btn-group').find('label').removeClass('active btn-success btn-danger btn-primary'); + $('fieldset.btn-group').each(function() { + // Handle disabled, prevent clicks on the container, and add disabled style to each button + if ($(this).prop('disabled')) { + $(this).css('pointer-events', 'none').off('click'); + $(this).find('.btn').addClass('disabled'); + } + }); - if (label.closest('.btn-group').hasClass('btn-group-reversed')) - { - if (input.val() == '') - { - label.addClass('active btn-primary'); - } - else if (input.val() == 0) - { - label.addClass('active btn-success'); - } - else - { - label.addClass('active btn-danger'); - } - } - else - { - if (input.val() == '') - { - label.addClass('active btn-primary'); - } - else if (input.val() == 0) - { - label.addClass('active btn-danger'); - } - else - { - label.addClass('active btn-success'); - } + $('.btn-group label:not(.active)').click(function() + { + var label = $(this); + var input = $('#' + label.attr('for')); - } - input.prop('checked', true); - input.trigger('change'); - } - }); - $('.btn-group input[checked=checked]').each(function() + if (!input.prop('checked')) { - var $self = $(this); - var attrId = $self.attr('id'); + label.closest('.btn-group').find('label').removeClass('active btn-success btn-danger btn-primary'); - if ($self.parent().hasClass('btn-group-reversed')) + if (label.closest('.btn-group').hasClass('btn-group-reversed')) { - if ($self.val() == '') + if (input.val() == '') { - $('label[for=' + attrId + ']').addClass('active btn-primary'); + label.addClass('active btn-primary'); } - else if ($self.val() == 0) + else if (input.val() == 0) { - $('label[for=' + attrId + ']').addClass('active btn-success'); + label.addClass('active btn-success'); } else { - $('label[for=' + attrId + ']').addClass('active btn-danger'); + label.addClass('active btn-danger'); } } else { - if ($self.val() == '') + if (input.val() == '') { - $('label[for=' + attrId + ']').addClass('active btn-primary'); + label.addClass('active btn-primary'); } - else if ($self.val() == 0) + else if (input.val() == 0) { - $('label[for=' + attrId + ']').addClass('active btn-danger'); + label.addClass('active btn-danger'); } else { - $('label[for=' + attrId + ']').addClass('active btn-success'); + label.addClass('active btn-success'); } + } + input.prop('checked', true); + input.trigger('change'); + } + }); + $('.btn-group input[checked=checked]').each(function() + { + var $self = $(this); + var attrId = $self.attr('id'); + + if ($self.parent().hasClass('btn-group-reversed')) + { + if ($self.val() == '') + { + $('label[for=' + attrId + ']').addClass('active btn-primary'); + } + else if ($self.val() == 0) + { + $('label[for=' + attrId + ']').addClass('active btn-success'); + } + else + { + $('label[for=' + attrId + ']').addClass('active btn-danger'); + } + } + else + { + if ($self.val() == '') + { + $('label[for=' + attrId + ']').addClass('active btn-primary'); + } + else if ($self.val() == 0) + { + $('label[for=' + attrId + ']').addClass('active btn-danger'); + } + else + { + $('label[for=' + attrId + ']').addClass('active btn-success'); + } + } + }); + $('.btn-group input[checked=checked]').each(function() + { + if ($(this).val() == '') { + $('label[for=' + $(this).attr('id') + ']').addClass('active btn-primary'); + } else if ($(this).val() == 0) { + $('label[for=' + $(this).attr('id') + ']').addClass('active btn-danger'); + } else { + $('label[for=' + $(this).attr('id') + ']').addClass('active btn-success'); + } + }); + // add color classes to chosen field based on value + $('select[class^="chzn-color"], select[class*=" chzn-color"]').on('liszt:ready', function(){ + var select = $(this); + var cls = this.className.replace(/^.(chzn-color[a-z0-9-_]*)$.*/, '\1'); + var container = select.next('.chzn-container').find('.chzn-single'); + container.addClass(cls).attr('rel', 'value_' + select.val()); + select.on('change click', function() + { + container.attr('rel', 'value_' + select.val()); }); - // add color classes to chosen field based on value - $('select[class^="chzn-color"], select[class*=" chzn-color"]').on('liszt:ready', function(){ - var select = $(this); - var cls = this.className.replace(/^.(chzn-color[a-z0-9-_]*)$.*/, '\1'); - var container = select.next('.chzn-container').find('.chzn-single'); - container.addClass(cls).attr('rel', 'value_' + select.val()); - select.on('change click', function() + + }); + + /** + * Append submenu items to empty UL on hover allowing a scrollable dropdown + */ + if ($w.width() > 767) + { + var menuScroll = $('#menu > li > ul'), + emptyMenu = $('#nav-empty'); + + $('#menu > li').on('click mouseenter', function() { + + // Set max-height (and width if scroll) for dropdown menu, depending of window height + var $dropdownMenu = $(this).children('ul'), + windowHeight = $w.height(), + linkHeight = $(this).outerHeight(true), + statusHeight = $('#status').outerHeight(true), + menuHeight = $dropdownMenu.height(), + menuOuterHeight = $dropdownMenu.outerHeight(true), + scrollMenuWidth = $dropdownMenu.width() + 15, + maxHeight = windowHeight - (linkHeight + statusHeight + (menuOuterHeight - menuHeight) + 20); + + if (maxHeight < menuHeight) { - container.attr('rel', 'value_' + select.val()); - }); + $dropdownMenu.css('width', scrollMenuWidth); + } + else if (maxHeight > menuHeight) + { + $dropdownMenu.css('width', 'auto'); + } + + $dropdownMenu.css('max-height', maxHeight); + + // Get the submenu position + linkWidth = $(this).outerWidth(true); + menuWidth = $dropdownMenu.width(); + linkPaddingLeft = $(this).children('a').css('padding-left'); + offsetLeft = Math.round($(this).offset().left) - parseInt(linkPaddingLeft); + + emptyMenu.empty().hide(); }); - /** - * Append submenu items to empty UL on hover allowing a scrollable dropdown - */ - if ($w.width() > 767) - { - var menuScroll = $('#menu > li > ul'), - emptyMenu = $('#nav-empty'); - - $('#menu > li').on('click mouseenter', function() { - - // Set max-height (and width if scroll) for dropdown menu, depending of window height - var $dropdownMenu = $(this).children('ul'), - windowHeight = $w.height(), - linkHeight = $(this).outerHeight(true), - statusHeight = $('#status').outerHeight(true), - menuHeight = $dropdownMenu.height(), - menuOuterHeight = $dropdownMenu.outerHeight(true), - scrollMenuWidth = $dropdownMenu.width() + 15, - maxHeight = windowHeight - (linkHeight + statusHeight + (menuOuterHeight - menuHeight) + 20); - - if (maxHeight < menuHeight) - { - $dropdownMenu.css('width', scrollMenuWidth); - } - else if (maxHeight > menuHeight) - { - $dropdownMenu.css('width', 'auto'); - } + menuScroll.find('.dropdown-submenu > a').on('mouseover', function() { + + var $self = $(this), + dropdown = $self.next('ul'), + submenuWidth = dropdown.outerWidth(), + offsetTop = $self.offset().top, + linkPaddingTop = parseInt(dropdown.css('padding-top')) + parseInt($(this).css('padding-top')), + scroll = $w.scrollTop() + linkPaddingTop; + + // Set the submenu position + if ($('html').attr('dir') == 'rtl') + { + emptyMenu.css({ + top : offsetTop - scroll, + left: offsetLeft - (menuWidth - linkWidth) - submenuWidth + }); + } + else + { + emptyMenu.css({ + top : offsetTop - scroll, + left: offsetLeft + menuWidth + }); + } - $dropdownMenu.css('max-height', maxHeight); + // Append items to empty