MMCT TEAM
Server IP : 2a02:4780:11:1359:0:1d43:a566:2  /  Your IP : 216.73.216.199
Web Server : LiteSpeed
System : Linux in-mum-web1259.main-hosting.eu 4.18.0-553.37.1.lve.el8.x86_64 #1 SMP Mon Feb 10 22:45:17 UTC 2025 x86_64
User : u490972518 ( 490972518)
PHP Version : 5.6.40
Disable Function : system, exec, shell_exec, passthru, mysql_list_dbs, ini_alter, dl, symlink, link, chgrp, leak, popen, apache_child_terminate, virtual, mb_send_mail
MySQL : ON  |  cURL : ON  |  WGET : ON  |  Perl : OFF  |  Python : OFF
Directory (0755) :  /home/u490972518/domains/ppschool.org.in/public_html/gsmps/js/

[  Home  ][  C0mmand  ][  Upload File  ]

Current File : /home/u490972518/domains/ppschool.org.in/public_html/gsmps/js/mislider.js

//  miSlider 

//  Copyright 2014 John Bowyer-Smyth

//  This file is part of miSlider.

//  miSlider is free software: you can redistribute it and/or modify
//  it under the terms of the GNU General Public License as published by
//  the Free Software Foundation, either version 3 of the License, or
//  (at your option) any later version.

//  miSlider is distributed in the hope that it will be useful,
//  but WITHOUT ANY WARRANTY; without even the implied warranty of
//  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
//  GNU General Public License for more details.

//  You should have received a copy of the GNU General Public License
//  along with this program.  If not, see http://www.gnu.org/licenses/

; (function ($, window, document, Math, undefined) {

	var miSlider = function (stageEl, options) {
		
		//  Clone miSlider object
		var o = this;

		//  Initialize option defaults ------------------------------------------------------------------------
		o.optionsInit = {
			//  The speed of the slide transition in milliseconds. Options: positive integer.
			speed: 700,
			//  slide pause time between transitions in milliseconds. Options: false, positive integer. false = Autoplay off.
			pause: 4000,
			//  The number of slides to increment with Autoplay and Nav Buttons. Options: positive or negative integer. Positive integer = Slide left. Negative integer = Slide right.
			increment: 1,
			//  The height of the stage in px. Options: false or positive integer. false = height is calculated using maximum slide heights.
			stageHeight: false,
			//  Number of slides visible at one time. Options: false or positive integer. false = Fit as many as possible.
			slidesOnStage: 1,
			//  Continuous motion - Boolean. true = slides loop in one direction if possible.
			slidesContinuous: true,
			//  The location of the current slide on the stage. Options: 'left', 'right', 'center'.
			slidePosition: 'left',
			//  The slide to start on. Options: 'beg', 'mid', 'end' or slide number starting at 1 - '1','2','3', etc.
			slideStart: 'beg',
			//  The width of the current slide in px. Options: false or positive integer. false = width is the maximum of the existing slide widths.
			slideWidth: false,
			//  The relative percentage scaling factor of the current slide - other slides are scaled down. Options: positive number 100 or higher. 100 = No scaling.
			slideScaling: 100,
		    //  The vertical offset of the slide center as a percentage of slide height. Options:  positive or negative number. Neg value = up. Pos value = down. 0 = No offset.
			offsetV: 0,
			//  Center slide contents vertically - Boolean.
			centerV: false,
		    //  Enable numbered list navigation - Boolean.
			navList: true,
			//  Enable prev and next button navigation - Boolean.
			navButtons: true,
			//  Always show prev and next button navigation except when transitioning - Boolean.
			navButtonsShow: false,
			//  Opacity of the prev and next button navigation when not transitioning. Options: Number between 0 and 1. 0 (transparent) - 1 (opaque).
			navButtonsOpacity: 0.5,
			//  Randomize the order of the slides - Boolean.
			randomize: false,
			//  The slides loaded call back function - called when slides have loaded.
			slidesLoaded: false,
			//  The slide transition before call back function - called before the slide transition.
			beforeTrans: false,
			//  The slide transition complete call back function - called at the end of a slide transition.
			afterTrans: false,
			//  The CSS class that will be applied to the stage element.
			classStage: 'mis-stage',
		    //  The CSS class that will be applied to the slider element.
			classSlider: 'mis-slider',
		    //  The CSS class that will be applied to each slide element.
			classSlide: 'mis-slide',
		    //  The CSS class that will be applied to the parent of the prev and next button navigation elements.
			classNavButtons: 'mis-nav-buttons',
		    //  The CSS class that will be applied to the parent of the numbered list navigation elements
			classNavList: 'mis-nav-list',
			//  The selector used to select the slider element - Descendant of the stage
			selectorSlider: 'ol',
			//  The selector used to select each slide element - Descendant of the slider
			selectorSlide: 'li',
		    //  Use Modernizr to test feature support - csstransforms
			modernizrBool: false,

		};

		//  Define objects and vars ------------------------------------------------------------------------------

		//  Objects
		o.options = {};                                 //  Merged options
		o.stage = false;                                //  slider container element
		o.slider = false;                               //  slider element - container for slides
		o.slides = false;                               //  The collection of slides
		o.navButtons = false;                           //  The nav buttons element
		o.prev = false;                                 //  The 'previous' nav button
		o.next = false;                                 //  The 'next' nav button
		o.navList = false;                              //  The nav list element
		o.navListItems = false;                         //  The nav list items collection
		o.slideCurrent = false;                         //  Current slide
		o.animatedElements = $();                       //  A collection of all the elements that animate 

		//   Calculated Widths and Heights
		o.stageWidth = 0;                               //  The existing width of the stage
		o.stageHeight = 0;                              //  The calculated height of stage
		o.sliderWidth = 0;                              //  The calculated width of slider                              
		o.slideWidth = 0;                               //  Slide calculated width of non-current slides
		o.slideWidthCurrent = 0;                        //  Slide calculated width of current slide

		//  Calculated Scaling vars
		o.slideScaling = o.optionsInit.slideScaling;    //  The calculated relative percentage scaling factor of the current slide
		o.scalingWidth = 0;                             //  The calculated scaling width
		o.scalingMargin = 0;                            //  The calculated scaling margin
		o.offsetV = o.optionsInit.offsetV;              //  The vertical offset of the slide center

		//  Slide counts
		o.slidesLengthOrig = 0;                         //  The original number of slides in collection
		o.slidesLength = 0;                             //  The number of slides in collection including cloned slides
		o.indexCurrent = 0;                             //  Current slide index 
		o.indexFirst = 0;                               //  The index of the first unique slide
		o.indexLast = 0;                                //  The index of the last unique slide
		o.increment = o.optionsInit.increment;          //  The calculated number of slides to increment with Autoplay and Nav Buttons
		o.slidesOnStage = o.optionsInit.slidesOnStage;  //  The calculated number of slides on stage
		
		//  Slider settings
		o.speed = o.optionsInit.speed;                          //  The calculated speed
		o.navButtonsOpacity = o.optionsInit.navButtonsOpacity;  //  The calculted Nav Buttons opacity
		o.navButtonsFade = false;                               //  The calculated prev and next button navigation fade boolean
		o.slidesContinuous = o.optionsInit.slidesContinuous;    //  The calculated continuous motion Boolean.
		o.pause = o.optionsInit.pause;                          //  The normalized pause value
		
		//  Functions
		o.timer = false;                                //  Interval timer function
		o.resizeTimer = false;                          //  Window resize timer function
		o.after = false;                                //  Temporary after transition callback function

		//  Classes
		o.classSlideClone = 'mis-clone';                //  Class applied to the cloned slides
		o.classSlideContainer = 'mis-container';        //  Class of slide container - inserted around the contents of each slide
		o.classCurrent = 'mis-current';                 //  Class applied to the the current slides and current nav list item
		o.classPrev = 'mis-prev';                       //  Class applied to the the 'previous' button
		o.classNext = 'mis-next';                       //  Class applied to the the 'next' button

		//  Initiate slider ==================================================================================
		o.init = function (stageEl, options) {   //  Must only be called once
			
			//  Set options
			o.options = $.extend({}, o.optionsInit, options);
			
			//  Initiate elements
			o.stage = $(stageEl);
			o.stage.fadeTo(0, 0);   //  Hide everything while we get setup
			o.slider = o.stage.children(o.options.selectorSlider).first();  //  Only one slider per stage
			o.slides = o.slider.children(o.options.selectorSlide);
			o.slidesLengthOrig = o.slides.length;
			o.animatedElements = o.animatedElements.add(o.slider);

		    //  Initiate current index
			if (String(o.options.slideStart) === 'beg') {
			    o.indexCurrent = 0;
			} else if (String(o.options.slideStart) === 'mid') {
			    o.indexCurrent = Math.ceil(o.slidesLengthOrig / 2) - 1;
			} else if (String(o.options.slideStart) === 'end') {
			    o.indexCurrent = o.slidesLengthOrig - 1;
			} else if ($.isNumeric(o.options.slideStart) && parseInt(o.options.slideStart) <= o.slidesLengthOrig && parseInt(o.options.slideStart) > 0) {
			    o.indexCurrent = parseInt(o.options.slideStart) - 1;
			} else {
			    o.indexCurrent = 0;
			}

		    //  Randomize slides
			if (o.options.randomize) {
			    o.randomize();
			}

			//  Add classes to stage and slider
			if (!o.stage.hasClass(o.options.classStage)) {
				o.stage.addClass(o.options.classStage);
			}
			if (!o.slider.hasClass(o.options.classSlider)) {
				o.slider.addClass(o.options.classSlider);
			}

			//  Normalize static options
			if (o.options.speed && $.isNumeric(o.options.speed)) {
				o.speed = Math.abs(parseInt(o.options.speed));
			}
			if (o.options.pause === false) {    //  Note: 0 must return true
			    o.pause = false;
			} else if ($.isNumeric(o.options.pause)) {
			    o.pause = Math.abs(parseInt(o.options.pause));
			}
			if ($.isNumeric(o.options.offsetV)) {
				o.offsetV = Number(o.options.offsetV);
			}
			if ($.isNumeric(o.options.navButtonsOpacity) && Number(o.options.navButtonsOpacity) >= 0 && Number(o.options.navButtonsOpacity) <= 1) {
				o.navButtonsOpacity = Number(o.options.navButtonsOpacity);
			}

		    //  Initiate calculated scaling factor
			if ($.isNumeric(o.options.slideScaling) && Number(o.options.slideScaling) >= 100) {
			    o.slideScaling = Number(o.options.slideScaling);
			}
			if (!o.supportTransform(o.options.modernizrBool, stageEl)) { //  CSS transforms are not supported
			    o.slideScaling = 100;
			}
			o.optionsInit.slideScaling = o.slideScaling;

		    //  Initiate the calculated increment
			if ($.isNumeric(o.options.increment) && parseInt(o.options.increment) !== 0) {
			    o.increment = parseInt(o.options.increment);
			    o.optionsInit.increment = o.increment;
			}

			
		    //  Add previous and next nav buttons
			if (o.options.navButtons) {
			    o.addNavButtons(o.stage);
			    o.animatedElements = o.animatedElements.add(o.navButtons);
			    if (!o.options.navButtonsShow) {
			        o.navButtonsFade = true;
			    }
			}

		    //  Add numbered list navigation 
			if (o.options.navList) {
			    o.addNavList();
			}
			
			//  Set up the slider
			o.setup();

            //  Add event handlers ----------------------------------------------------------------------------

		    //  Add click events to slides
			if (o.slidesOnStage > 1) {
			    o.slider.on('click', o.options.selectorSlide, function (e) {
			        if ($(this).index() !== o.indexCurrent) {
			            e.preventDefault();
			            o.autoplayOff();
			            o.transition($(this).index(), false, o.autoplayOn(o.increment));
			        }
			    });
			}

		    //  Add hover events for controling Autoplay and Nav Button opacity
			if (o.pause !== false || o.navButtonsFade) {    //  Note: 0 must return true for o.pause
			    o.stage.on({
			        'mouseenter': function () {
			            if (o.pause !== false) {
                            o.autoplayOff();
			            }
			            if (o.navButtonsFade) {
			                if (!o.animatedElements.is(':animated')) {
			                    o.navButtons.fadeTo(400, o.navButtonsOpacity);
			                } else {
			                    if ($.isFunction(o.after)) {
			                        var after = o.after;
			                        o.after = function () {
			                            after();
			                            o.navButtons.fadeTo(400, o.navButtonsOpacity);
			                        };
			                    } else {
			                        o.after = function () {
			                            o.navButtons.fadeTo(400, o.navButtonsOpacity);
			                        };
			                    }
			                }
			            }
			        },
			        'mouseleave': function () {
			            if (o.pause !== false) {
			                o.autoplayOn(o.increment);
			            }
			            if (o.navButtonsFade) {
			                o.navButtons.fadeTo(100, 0);
			            }
			        }
			    });
			}
		    
			//  Window events
			$(window).on({

			    //  Wait for slides to load before setting up slides and nav buttons
                'load': function () {

			        //  Setup slides and nav buttons
			        o.slideSetup();
			        o.updateNavButtons();

			        //  Fade in everything
			        o.stage.fadeTo(600, 1);

			        //  Autoplay slides if enabled
			        o.autoplayOn(o.increment);

			        //  Slides loaded callBack
			        if ($.isFunction(o.options.slidesLoaded)) {
			            o.options.slidesLoaded();
			        }
                },

			    //  Reset Slider on screen resize
                'resize': function () {
                    o.autoplayOff();
                    clearTimeout(o.resizeTimer);
                    o.resizeTimer = setTimeout(function () {
                        o.resetSlider();
                    }, 500);
                }
		    });
			
			return this;
		};
		
		//  Setup slider ======================================================================================
		o.setup = function () {

			//  Set Slides length
		    o.slidesLength = o.slidesLengthOrig;
		    o.indexLast = o.slidesLength - 1;

			//  Get widths, heights, add slide class and container
			o.slides.each(function () {
			    var slide = $(this);

                //  Add slide class to slide
			    if (!slide.hasClass(o.options.classSlide)) {
			        slide.addClass(o.options.classSlide);
			    }

			    //  Add slide container to slide
			    if (!slide.children().hasClass(o.classSlideContainer)) {
			        slide.wrapInner('<div class="' + o.classSlideContainer + '"></div>');
			    }

                //  Get widths and heights
				var width = slide.outerWidth();
				var height = slide.outerHeight();

				if (width > o.slideWidthCurrent) {
					o.slideWidthCurrent = width;
				}
				if (height > o.stageHeight) {
					o.stageHeight = height;
				}

			});

			//  Apply presets if they exist
			if ($.isNumeric(o.options.slideWidth) && parseInt(o.options.slideWidth) > 0) {
				o.slideWidthCurrent = parseInt(o.options.slideWidth);
			}
			if ($.isNumeric(o.options.stageHeight) && parseInt(o.options.stageHeight) > 0) {
				o.stageHeight = parseInt(o.options.stageHeight);
			}

		    //  Use modulus hack to ensure current index is within range
			o.indexCurrent = o.normalizeIndex(o.indexCurrent);

			//  Set the stage ----------------------------------------------------------------------------------

			//  Set CSS
			o.stage.css({
			    'height': o.stageHeight,
			});

			//  Get Stage width - must do this after setting height
			o.stageWidth = o.stage.outerWidth();

			//  Calculate slide scaling, widths, increment and slides on and off stage  ------------------

			//  Determine the maximum number of slides that fit on the stage
			var slidesMaxNum = Math.floor((o.stageWidth - o.slideWidthCurrent) / (o.slideWidthCurrent * 100 / o.slideScaling)) + 1;
			slidesMaxNum = (slidesMaxNum < 1) ? 1 : slidesMaxNum;   //  Must have at least 1

			//  Calculate the number of slides visible on the stage
			o.slidesOnStage = slidesMaxNum;  //  Fit as many as possible
			if ($.isNumeric(o.options.slidesOnStage) && parseInt(o.options.slidesOnStage) >= 1 && parseInt(o.options.slidesOnStage) <= slidesMaxNum) {
			    o.slidesOnStage = parseInt(o.options.slidesOnStage); //  use existing options value
			}
			if (o.options.slidePosition === 'center') { //  need odd number for centered layout
				o.slidesOnStage = (Math.ceil(o.slidesOnStage / 2) * 2) - 1;
			}

			//  The absolute increment number should not be greater than slides on stage
			var x = (o.increment + o.slidesOnStage) / 2;
			if (x > o.slidesOnStage) {  //  increment is positive and more than slides on stage
				o.increment = o.slidesOnStage;
			} else if (x < 0) {     //  increment is negative and more than slides on stage
				o.increment = -o.slidesOnStage;
			}

			//  Calculate the current and non-current slide widths
			if (o.slidesOnStage > 1) {     // modify non-current slide width to accommodate correct number of slides on the stage
				o.slideWidth = (o.stageWidth - o.slideWidthCurrent) / (o.slidesOnStage - 1);
				if (o.slideWidthCurrent < o.slideWidth && !o.options.slideWidth) {  //  Set slideWidth and slideWidthCurrent to be the same
					o.slideWidth = o.stageWidth / o.slidesOnStage;
					o.slideWidthCurrent = o.slideWidth;
				}
			} else {    //  Make slide widths full width of stage
				o.slideWidth = o.stageWidth;
				o.slideWidthCurrent = o.slideWidth;
				o.slideScaling = 100;
			}

			//  Set scaling width and margin
			o.scalingWidth = o.slideWidth * o.slideScaling / 100;
			o.scalingMargin = (o.slideWidth - o.scalingWidth) / 2;
			
			//  Determine the number of slides off stage
			var slidesOffStage = o.slidesLengthOrig - o.slidesOnStage;

		    //  Clone last slidesToClone slides to beginning and first slidesToClone slides to end ---------------
			if ((slidesOffStage >= 0) && (o.options.slidesContinuous)) {

			    //  Set calculated continuous motion boolean to true
			    o.slidesContinuous = true;

			    //  Determine the number of slides to clone
			    o.slidesToClone = o.slidesOnStage + Math.abs(o.increment) - 1;

			    // Prepend last slidesToClone slides
			    o.slides.slice(o.slidesLength - o.slidesToClone)
                    .clone()
                    .addClass(o.classSlideClone)
                    .removeAttr('id')
                    .prependTo(o.slider)
                    .find('*').removeAttr('id');

			    // Append first slidesToClone slides
			    o.slides.slice(0, o.slidesToClone)
                    .clone()
                    .addClass(o.classSlideClone)
                    .removeAttr('id')
                    .appendTo(o.slider)
                    .find('*').removeAttr('id');

			    // Adjust indexes
			    o.indexFirst = o.slidesToClone;
			    o.indexLast = o.slidesLength + o.slidesToClone - 1;
			    o.indexCurrent = o.indexCurrent + o.slidesToClone;

			    // Refresh slides
			    o.slides = o.slider.children(o.options.selectorSlide);
			    o.slidesLength = o.slides.length;

			} else {
			    o.slidesContinuous = false;
			}

			//  Update current slide
			o.slideCurrent = o.slides.eq(o.indexCurrent);
			o.animatedElements = o.animatedElements.add(o.slides);

			//  Set the horizontal position, width and other CSS of the slider ---------------------------------

			//  Calculate the width of the slider
			o.sliderWidth = o.slideWidthCurrent + (o.slideWidth * (o.slidesLength - 1)) + 1;
			
			//  Set CSS of slider
			o.slider
				.css({
					'left': o.leftOffset(o.indexCurrent),
					'width': o.sliderWidth,   
				})
			;

		    //  update navList
			o.updateNavList(o.indexCurrent);

			return this;
		};

		//  Transition control function =========================================================================
		o.transition = function (indexTo, beforeTrans, afterTrans, navButtonsFadeIn) {

		    //  If slider is not animated and indexTo != current index - continue 
		    if (!o.animatedElements.is(':animated') && indexTo !== o.indexCurrent) {

		        //  Define indexes that might be adjusted
		        var indexToAdjusted = indexTo;
		        var indexCurrentAdjusted = o.indexCurrent;

		        //  Update indexes and slides if continuous and slides are out of bounds ------------------------
		        if (o.slidesContinuous) {

		            //  Get adjusted indexTo if slides are out of bounds
		            if (indexTo < o.indexFirst) {
		                indexToAdjusted = indexTo + o.slidesLengthOrig;
		            } else if (indexTo > o.indexLast) {
		                indexToAdjusted = indexTo - o.slidesLengthOrig;
		            }

		            if (indexToAdjusted !== indexTo) {  //  indexTo is out of bounds

		                //  Adjust current index
		                indexCurrentAdjusted = o.indexCurrent + o.slidesLengthOrig;
		                if (indexToAdjusted < indexTo) {
		                    indexCurrentAdjusted = o.indexCurrent - o.slidesLengthOrig;
		                }
		            }
		        } else {
		            //  Use modulus hack to ensure adjusted index is within range
		            indexToAdjusted = o.normalizeIndex(indexTo);
		        }

		        //  Get the normalized difference between indexes
		        var indexDiff = o.normalizeIndex(indexToAdjusted) - o.normalizeIndex(indexCurrentAdjusted);

		        //  If adjusted indexTo != adjusted current index - do move --------------------------------------
		        if (indexDiff) {

		            //  Call 'before transition' functions
		            if ($.isFunction(beforeTrans)) {
		                beforeTrans();
		            }
		            if ($.isFunction(o.options.beforeTrans)) {
		                o.options.beforeTrans();
		            }

		            //  Construct after transition function
		            var after = function () {

		                //  Call afterTrans local function
		                if ($.isFunction(afterTrans)) {
		                    afterTrans();
		                }

		                //  Call afterTrans pre-defined function
		                if ($.isFunction(o.options.afterTrans)) {
		                    o.options.afterTrans();
		                }

		                //  Call temporary callback function
		                if ($.isFunction(o.after)) {
		                    o.after();
		                    o.after = false;
		                }

		            };

		            //  Swap current slide if continuous and current index needs to be adjusted --------------------
		            if (o.slidesContinuous && indexCurrentAdjusted !== o.indexCurrent) {

		                var slideCurrentAdjusted = o.slides.eq(indexCurrentAdjusted);

		                //  Prepare Current slide's clone
		                if (o.slideScaling !== 100) {
		                    
                            //  Scale slide
		                    slideCurrentAdjusted.css({
		                        'transform': 'scale(1)',
		                        'width': o.slideWidthCurrent,
		                        'marginLeft': '0',
		                        'marginRight': '0',
		                        'borderSpacing': '100px', // value placeholder used with step function to animate tranform
		                    });

		                    //  Vertically center slide if enabled
		                    if (o.options.centerV) {
		                        slideCurrentAdjusted.children().first().css('marginTop', slideCurrentAdjusted.data('slideMarginTopCurrent'));
		                    }
		                }

		                //  Add current class to current slide
		                slideCurrentAdjusted
                            .addClass(o.classCurrent)
                        .siblings()
                            .removeClass(o.classCurrent)
                        ;

		                //  Jump to Clone
		                o.slider.css('left', o.leftOffset(indexCurrentAdjusted));

		                //  Reset original
		                if (o.slideScaling !== 100) {

		                    //  Scale slide
		                    o.slideCurrent.css({
		                        'transform': 'scale(' + (100 / o.slideScaling) + ')',
		                        'width': o.scalingWidth,
		                        'marginLeft': o.scalingMargin,
		                        'marginRight': o.scalingMargin,
		                        'borderSpacing': o.slideScaling, // value placeholder used with step function to animate tranform
		                    });

		                    //  Vertically center slide if enabled
		                    if (o.options.centerV) {
		                        o.slideCurrent.children().first().css('marginTop', o.slideCurrent.data('slideMarginTop'));
		                    }
		                }

		                //  Update current index and slide
		                o.indexCurrent = indexCurrentAdjusted;
		                o.slideCurrent = o.slides.eq(o.indexCurrent);

		            }

                    //  Transition ----------------------------------------------------------------------------
		            if (o.navButtons) {
		                //  FadeIn Nav Buttons before move if fadeIn bool true
		                o.navButtons.fadeTo(100, (navButtonsFadeIn) ? o.navButtonsOpacity : 0, 
                            function () {
                                //  FadeOut Nav Buttons before move
                                o.navButtons.fadeTo(100, 0, //  FadeOut Nav Buttons before move
                                    function () {
                                        //  Do transition
                                        o.animateSlides(indexToAdjusted,
                                            function () {
                                                if (o.stage.find(':hover').length || o.options.navButtonsShow) { //  FadeIn Nav Buttons after move
                                                    o.navButtons.fadeTo(400, o.navButtonsOpacity, after);
                                                } else {
                                                    after();
                                                }
                                            }
                                        );
                                    }
                                );
                            }
                        );
		            } else {
		                //  Do transition
		                o.animateSlides(indexToAdjusted, after);
		            }
		        }
		    }
			return this;
		};

	    //  Animate slide transition ==========================================================================
		o.animateSlides = function (indexTo, afterTrans) {

		    //  Remove current class from current slide
		    o.slideCurrent.removeClass(o.classCurrent);

            //  Define the slide to move to
		    var slideTo = o.slides.eq(indexTo);

		    if (o.slideScaling !== 100) { // only scale if needed

		        //  Scale New Slide ---------------------------------------------------------------------------
		        slideTo
					.animate({
					    'marginLeft': '0',
					    'marginRight': '0',
					    'width': o.slideWidthCurrent
					}, {
					    duration: o.speed,
					    queue: false,
					})
					.animate({
					    'borderSpacing': '100px'
					}, {    //  Must use step function to animate scaling
					    step: function (now) {
					        $(this).css({
					            'transform': 'scale(' + 100 / now + ')',
					        });
					    },
					    duration: o.speed,
					    queue: false,
					})
		        ;

		        //  Scale Current slide ---------------------------------------------------------------------
		        o.slideCurrent
					.animate({
					    'marginLeft': o.scalingMargin,
					    'marginRight': o.scalingMargin,
					    'width': o.scalingWidth
					}, {
					    duration: o.speed,
					    queue: false,
					})
					.animate({
					    'borderSpacing': o.slideScaling
					}, {    //  Must use step function to animate scaling
					    step: function (now) {
					        $(this).css({
					            'transform': 'scale(' + 100 / now + ')',
					        });
					    },
					    duration: o.speed,
					    queue: false,
					})
		        ;

		        //  Animate slide contents margin if vertically center slide is enabled ---------------------
		        if (o.options.centerV) {

		            //  Animate New Slide content
		            slideTo.children().first()
                        .animate({
                            'marginTop': slideTo.data('slideMarginTopCurrent'),
                        }, {
                            duration: o.speed,
                            queue: false,
                        })
		            ;
		            //  Animate Current Slide content
		            o.slideCurrent.children().first()
                        .animate({
                            'marginTop': o.slideCurrent.data('slideMarginTop'),
                        }, {
                            duration: o.speed,
                            queue: false,
                        })
		            ;
		        }
		    }

		    //  Move to new slide ---------------------------------------------------------------------------
		    o.slider.animate({
		        'left': o.leftOffset(indexTo)
		    }, {
		        duration: o.speed,
		        queue: false,
		        complete: function () { //  transition complete

		            //  Update current index and slide
		            o.indexCurrent = indexTo;
		            o.slideCurrent = slideTo;

		            //  update navList
		            o.updateNavList(indexTo);

		            //  Add current class to current slide
		            o.slideCurrent
                        .addClass(o.classCurrent)
                    .siblings()
                        .removeClass(o.classCurrent)
		            ;

                    //  Execute callbacks
		            if ($.isFunction(afterTrans)) {
		                afterTrans();
		            }
		        }
		    });

		    return this;
		};
		
	    //  Playback control functions ======================================================================

	    //  Autoplay on -------------------------------------------------------------------------------------
		o.autoplayOn = function (incr) {
		    if (o.pause !== false) { //  autoplay is enabled

                //  Reset timer
		        o.timer = clearInterval(o.timer);
		        if (!o.stage.find(':hover').length) {   // slider is not in hover state
		            o.timer = setInterval(function () {
                        //  if not transitioning do transition
		                if (!o.animatedElements.is(':animated')) {
		                    o.transition(o.indexCurrent + incr);
		                }
		            }, o.pause);
		        }
		    }
		    return this;
		};

	    //  Autoplay off ------------------------------------------------------------------------------------
		o.autoplayOff = function () {
		    o.timer = clearInterval(o.timer);
		    return this;
		};

		// Add navButtons ------------------------------------------------------------------------------------
		o.addNavButtons = function (element) {

            //  Parent element to append nav buttons to
			var $el = $(element); 

			//  Construct HTML
			var navButtons = $('<div class="' + o.options.classNavButtons + '"><a href="#" class="' + o.classPrev + '">Prev</a><a href="#" class="' + o.classNext + '">Next</a></div>');

			//  Apply CSS and click events to buttons
			navButtons
				.css({
					'opacity': ((o.options.navButtonsShow) ? o.navButtonsOpacity : 0),
				})
				.children('a')
					.on('click', function (e) {
						e.preventDefault();
						if (this.className === o.classPrev) {
							o.autoplayOff();
							o.transition(o.indexCurrent - Math.abs(o.increment), false, o.autoplayOn(o.increment), true);
						} else if (this.className === o.classNext) {
							o.autoplayOff();
							o.transition(o.indexCurrent + Math.abs(o.increment), false, o.autoplayOn(o.increment), true);
						}
					})
			;

			//  Append buttons to stage
			$el.append(navButtons);

			//  Define cached objects
			o.navButtons = $el.find('.' + o.options.classNavButtons);
			o.prev = o.navButtons.find('.' + o.classPrev);
			o.next = o.navButtons.find('.' + o.classNext);

			return this;
		};

		//  Update Nav Buttons --------------------------------------------------------------------------------
		o.updateNavButtons = function () {
		    if (o.navButtons) {
		        //  Apply CSS to buttons
		        o.navButtons
                    .css({
                        'width': o.slideWidthCurrent,
                        'left': (o.slideCurrent.offset().left - o.stage.offset().left),
                    })
                    .children('a')
                        .css({
                            'height': o.stageHeight,
                            'paddingTop': (50 + o.offsetV) * o.stageHeight / 100,
                        })
		        ;
		    }
		};

		// Add navList --------------------------------------------------------------------------------------
		o.addNavList = function () {

		    //  Define List
			var listHtml = '<ol class="' + o.options.classNavList + '">';

		    //  Create each List item
			o.slides.each(function (index) {

				//  Define the text for the list item
				var itemText = index + 1;

				// Use header, figcaption, or img title as list item text instead
				var caption = $(this).find(':header').sort(function (a,b) {
					var aTag = $(a).prop('tagName'),
						bTag = $(b).prop('tagName');
					return parseInt(aTag.match(/\d+/), 10) - parseInt(bTag.match(/\d+/), 10);
				}).eq(0).html();
				if (caption) {
					itemText = caption;
				} else {
					caption = $(this).find('figcaption').eq(0).html();
					if (caption) {
						itemText = caption;
					} else {
						caption = $(this).find('img').eq(0).attr('title');
						if (caption) {
							itemText = caption;
						}
					}
				}

				//  Add list item to list
				listHtml += '<li><a href="#" title="' + itemText + '">' + itemText + '</a></li>';
			  
			});

			//  Close list
			listHtml += '</ol>';

			//  Create temporary list object and add click events
			var navList = $(listHtml)
					.on('click', 'li', function (e) {
						e.preventDefault();
						if ($(this).index() !== (o.indexCurrent - o.indexFirst)) {
						    o.autoplayOff();
						    o.transition($(this).index() + o.indexFirst, false, o.autoplayOn(o.increment));
						}
					})
				;

			//  Prepend list to slider and update cached objects
			o.stage.prepend(navList);
			o.navList = o.stage.children().first();
			o.navListItems = o.navList.children('li');
			
			return this;
		};

	    // Update navList ------------------------------------------------------------------------------------
		o.updateNavList = function (index) {
		    if (o.navListItems.length) {
		        o.navListItems
                    .eq(index - o.indexFirst)
                        .addClass(o.classCurrent)
                    .siblings()
                        .removeClass(o.classCurrent)
		        ;
		    }
		};

		//  Assorted functions ==============================================================================

		//  Randomizer --------------------------------------------------------------------------------------
		o.randomize = function () {
			
			//  Randomize cached slides
			o.slides.sort(function () {
				return (0.5 - Math.random());
			});

			//  Apply randomized slides to page
			o.slides.detach().appendTo(o.slider);

			return this;
		};
		
		//  Slider left offset calculator ------------------------------------------------------------------
		o.leftOffset = function (index) {

			var indexOffset = o.slideWidth * index * -1;
			var leftOffset = indexOffset;   //  Slide position = Left

			if (o.options.slidePosition === 'center') {
			    leftOffset = (indexOffset + (Math.floor(o.slidesOnStage / 2) * o.slideWidth));
			} else if (o.options.slidePosition === 'right') {
				leftOffset = (indexOffset + ((o.slidesOnStage - 1) * o.slideWidth));
			}

			return leftOffset;
		};
		
		//  Reset Slider ----------------------------------------------------------------------------------
		o.resetSlider = function () {
		    if (o.animatedElements.is(':animated')) {

		        //  Reset slider after transition has finished
		        if ($.isFunction(o.after)) {
		            var after = o.after;
		            o.after = function () {
		                after();
		                o.resetSlider;
		            };
		        } else {
		            o.after = o.resetSlider;
		        }   

			} else {

                //  Resets
				o.autoplayOff();
				o.stage.removeAttr('style');
				o.slider.removeAttr('style');
				o.slides.removeAttr('style');
				o.slides.filter('.' + o.classSlideClone).remove();
				o.slides = o.slider.children(o.options.selectorSlide);
				o.stageHeight = 0;
				o.slideWidthCurrent = 0;
				o.slideScaling = o.optionsInit.slideScaling;
				o.indexCurrent -= o.slidesToClone;
				o.indexFirst = 0;
				o.increment = o.optionsInit.increment;
				o.after = false;

                //  Setup
				o.setup();
				o.slideSetup();
				o.updateNavButtons();
				o.autoplayOn(o.increment);
			}
			
			return this;
		};

		//  Use modulus hack to make sure index is within range -----------------------------------------------------
		o.normalizeIndex = function (index) {
			index = ((index % o.slidesLengthOrig) + o.slidesLengthOrig) % o.slidesLengthOrig;
			return index;
		};

	    //  Setup slides function -----------------------------------------------------------------------------------
		o.slideSetup = function () {
		    o.slides.each(function (i) {

		        var slide = $(this);

		        //  Set transform origin and current width
		        slide.css({
		            'transform-origin': '50% ' + String(50 + o.offsetV) + '%',
		            'width': o.slideWidthCurrent,
		        });

		        //  Get vertical slide offset if enabled
		        if (o.options.centerV) {
		            o.getMarginTop(slide, 'slideMarginTopCurrent');
		        }

		        //  Set non-current slides
		        slide.css({
		            'width': o.scalingWidth,
		        });
		        if (o.slideScaling !== 100) {
		            slide.css({
		                'marginLeft': o.scalingMargin, // compensation for scaling transform
		                'marginRight': o.scalingMargin, // compensation for scaling transform
		                'transform': 'scale(' + (100 / o.slideScaling) + ')',
		                'borderSpacing': o.slideScaling // value placeholder used with step function to animate tranform
		            });
		        }

		        //  Vertically center slide if enabled
		        if (o.options.centerV) {
		            slide.children().first().css('marginTop', o.getMarginTop(slide, 'slideMarginTop'));
		        }

		        //  Set current slides
		        if (i === o.indexCurrent) {
		            slide
                        .css({
                            'borderSpacing': '100px', // value placeholder used with step function to animate tranform
                            'width': o.slideWidthCurrent,
                            'marginLeft': 0, // compensation for scaling transform
                            'marginRight': 0, // compensation for scaling transform
                            'transform': 'scale(1)',
                        })
                        .addClass(o.classCurrent)
                    .siblings()
                        .removeClass(o.classCurrent)
		            ;

		            //  Vertically center slide if enabled
		            if (o.options.centerV) {
		                slide.children().first().css('marginTop', o.getMarginTop(slide, 'slideMarginTopCurrent'));
		            }
		        }
		    });
		};

	    //  Get offset for centering slide contents vertically within stage
        //  Must be called after contents (images) have loaded to get correct height
		o.getMarginTop = function (slide, dataKey) {

		    var slideMarginTop = 0;

            //  Get height of slide container
		    var height = slide.children().first().outerHeight();

            //  Add negative top margin if slide height is bigger than stage height
		    if (height > o.stageHeight) {
		        slideMarginTop = (o.stageHeight - height) / 2;
		    }

            //  Store slide's top margin value for re-use
		    slide.data(dataKey, slideMarginTop);

		    return slideMarginTop;
		};

	    //  Test transform feature support
		o.supportTransform = function (modernizrBool, element) {
		    var test = false;
            //  User Modernizr if it exists
		    if (modernizrBool && Modernizr) {
		        if (Modernizr.csstransforms) {
		            test = true;
		        }
		    } else {
		        var style = element.style;
		        if (typeof style.transform !== "undefined" || typeof style.WebkitTransform !== "undefined" || typeof style.msTransform !== "undefined") {
		            test = true;
		        }
		    }
		    return test;
		};

		// initialize ------------------------------------------------------------------------------------
		o.init(stageEl, options);
		
		return this;
	};

	//  Create a jQuery plugin ==========================================================================
	$.fn.miSlider = function (options) {
		
		//  Enable multiple-slider support
		return this.each(function () {
			var stage = $(this);
			if (!stage.data('miSlider')) {
				stage.data('miSlider', new miSlider(this, options));
			}
		});
	};
})(jQuery, window, document, Math);

MMCT - 2023