1053 lines
30 KiB
JavaScript
Raw Permalink Normal View History

2022-04-13 13:51:55 +07:00
"use strict";
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
/*!
* jQuery SmartWizard v5.1.1
* The awesome jQuery step wizard plugin
* http://www.techlaboratory.net/jquery-smartwizard
*
* Created by Dipu Raj
* http://dipu.me
*
* @license Licensed under the terms of the MIT License
* https://github.com/techlab/jquery-smartwizard/blob/master/LICENSE
*/
(function (factory) {
if (typeof define === 'function' && define.amd) {
// AMD. Register as an anonymous module.
define(['jquery'], factory);
} else if ((typeof module === "undefined" ? "undefined" : _typeof(module)) === 'object' && module.exports) {
// Node/CommonJS
module.exports = function (root, jQuery) {
if (jQuery === undefined) {
// require('jQuery') returns a factory that requires window to
// build a jQuery instance, we normalize how we use modules
// that require this pattern but the window provided is a noop
// if it's defined (how jquery works)
if (typeof window !== 'undefined') {
jQuery = require('jquery');
} else {
jQuery = require('jquery')(root);
}
}
factory(jQuery);
return jQuery;
};
} else {
// Browser globals
factory(jQuery);
}
})(function ($) {
"use strict"; // Default options
var defaults = {
selected: 0,
// Initial selected step, 0 = first step
theme: 'default',
// theme for the wizard, related css need to include for other than default theme
justified: true,
// Nav menu justification. true/false
darkMode: false,
// Enable/disable Dark Mode if the theme supports. true/false
autoAdjustHeight: true,
// Automatically adjust content height
cycleSteps: false,
// Allows to cycle the navigation of steps
backButtonSupport: true,
// Enable the back button support
enableURLhash: true,
// Enable selection of the step based on url hash
transition: {
animation: 'none',
// Effect on navigation, none/fade/slide-horizontal/slide-vertical/slide-swing
speed: '400',
// Transion animation speed
easing: '' // Transition animation easing. Not supported without a jQuery easing plugin
},
toolbarSettings: {
toolbarPosition: 'bottom',
// none, top, bottom, both
toolbarButtonPosition: 'right',
// left, right, center
showNextButton: true,
// show/hide a Next button
showPreviousButton: true,
// show/hide a Previous button
toolbarExtraButtons: [] // Extra buttons to show on toolbar, array of jQuery input/buttons elements
},
anchorSettings: {
anchorClickable: true,
// Enable/Disable anchor navigation
enableAllAnchors: false,
// Activates all anchors clickable all times
markDoneStep: true,
// Add done state on navigation
markAllPreviousStepsAsDone: true,
// When a step selected by url hash, all previous steps are marked done
removeDoneStepOnNavigateBack: false,
// While navigate back done step after active step will be cleared
enableAnchorOnDoneStep: true // Enable/Disable the done steps navigation
},
keyboardSettings: {
keyNavigation: true,
// Enable/Disable keyboard navigation(left and right keys are used if enabled)
keyLeft: [37],
// Left key code
keyRight: [39] // Right key code
},
lang: {
// Language variables for button
next: 'Next',
previous: 'Previous'
},
disabledSteps: [],
// Array Steps disabled
errorSteps: [],
// Highlight step with errors
hiddenSteps: [] // Hidden steps
};
var SmartWizard = /*#__PURE__*/function () {
function SmartWizard(element, options) {
_classCallCheck(this, SmartWizard);
// Merge user settings with default
this.options = $.extend(true, {}, defaults, options); // Main container element
this.main = $(element); // Navigation bar element
this.nav = this._getFirstDescendant('.nav'); // Step anchor elements
this.steps = this.nav.find('.nav-link'); // Content container
this.container = this._getFirstDescendant('.tab-content'); // Content pages
this.pages = this.container.children('.tab-pane'); // Assign options
this._initOptions(); // Initial load
this._initLoad();
} // Initial Load Method
_createClass(SmartWizard, [{
key: "_initLoad",
value: function _initLoad() {
// Clean the elements
this.pages.hide();
this.steps.removeClass('done active'); // Active step index
this.current_index = null; // Get the initial step index
var idx = this._getStepIndex(); // Mark any previous steps done
this._setPreviousStepsDone(idx); // Show the initial step
this._showStep(idx);
} // Initialize options
}, {
key: "_initOptions",
value: function _initOptions() {
// Set the elements
this._setElements(); // Add toolbar
this._setToolbar(); // Assign plugin events
this._setEvents();
}
}, {
key: "_getFirstDescendant",
value: function _getFirstDescendant(selector) {
// Check for first level element
var elm = this.main.children(selector);
if (elm.length > 0) {
return elm;
} // Check for second level element
this.main.children().each(function (i, n) {
var tmp = $(n).children(selector);
if (tmp.length > 0) {
elm = tmp;
return false;
}
});
if (elm.length > 0) {
return elm;
} // Element not found
this._showError("Element not found " + selector);
return false;
}
}, {
key: "_setElements",
value: function _setElements() {
// Set the main element
this.main.addClass('sw');
this._setTheme(this.options.theme);
this._setJustify(this.options.justified);
this._setDarkMode(this.options.darkMode); // Set the anchor default style
if (this.options.anchorSettings.enableAllAnchors !== true || this.options.anchorSettings.anchorClickable !== true) {
this.steps.addClass('inactive');
} // Disabled steps
this._setCSSClass(this.options.disabledSteps, "disabled"); // Error steps
this._setCSSClass(this.options.errorSteps, "danger"); // Hidden steps
this._setCSSClass(this.options.hiddenSteps, "hidden");
}
}, {
key: "_setEvents",
value: function _setEvents() {
var _this = this;
// Check if event handler already exists
if (this.main.data('click-init')) {
return true;
} // Flag item to prevent attaching handler again
this.main.data('click-init', true); // Anchor click event
$(this.steps).on("click", function (e) {
e.preventDefault();
if (_this.options.anchorSettings.anchorClickable === false) {
return true;
} // Get the step index
var idx = _this.steps.index(e.currentTarget);
if (idx === _this.current_index) {
return true;
}
if (_this.options.anchorSettings.enableAnchorOnDoneStep === false && _this._isDone(idx)) {
return true;
}
if (_this.options.anchorSettings.enableAllAnchors !== false || _this._isDone(idx)) {
_this._showStep(idx);
}
}); // Next button event
this.main.find('.sw-btn-next').on("click", function (e) {
e.preventDefault();
_this._showNext();
}); // Previous button event
this.main.find('.sw-btn-prev').on("click", function (e) {
e.preventDefault();
_this._showPrevious();
}); // Keyboard navigation event
if (this.options.keyboardSettings.keyNavigation) {
$(document).keyup(function (e) {
_this._keyNav(e);
});
} // Back/forward browser button event
if (this.options.backButtonSupport) {
$(window).on('hashchange', function (e) {
var idx = _this._getURLHashIndex();
if (idx !== false) {
e.preventDefault();
_this._showStep(idx);
}
});
}
}
}, {
key: "_setToolbar",
value: function _setToolbar() {
// Skip right away if the toolbar is not enabled
if (this.options.toolbarSettings.toolbarPosition === 'none') {
return true;
} // Append toolbar based on the position
switch (this.options.toolbarSettings.toolbarPosition) {
case 'top':
this.container.before(this._createToolbar('top'));
break;
case 'bottom':
this.container.after(this._createToolbar('bottom'));
break;
case 'both':
this.container.before(this._createToolbar('top'));
this.container.after(this._createToolbar('bottom'));
break;
default:
this.container.after(this._createToolbar('bottom'));
break;
}
}
}, {
key: "_createToolbar",
value: function _createToolbar(position) {
// Skip if the toolbar is already created
if (this.main.find('.toolbar-' + position).length > 0) {
return null;
}
var toolbar = $('<div></div>').addClass('toolbar toolbar-' + position).attr('role', 'toolbar'); // Create the toolbar buttons
var btnNext = this.options.toolbarSettings.showNextButton !== false ? $('<button></button>').text(this.options.lang.next).addClass('btn btn-primary sw-btn-next').attr('type', 'button') : null;
var btnPrevious = this.options.toolbarSettings.showPreviousButton !== false ? $('<button></button>').text(this.options.lang.previous).addClass('btn btn-primary sw-btn-prev').attr('type', 'button') : null;
toolbar.append(btnPrevious, btnNext); // Add extra toolbar buttons
if (this.options.toolbarSettings.toolbarExtraButtons && this.options.toolbarSettings.toolbarExtraButtons.length > 0) {
$.each(this.options.toolbarSettings.toolbarExtraButtons, function (_i, n) {
toolbar.append(n.clone(true));
});
}
toolbar.css('text-align', this.options.toolbarSettings.toolbarButtonPosition);
return toolbar;
}
}, {
key: "_showNext",
value: function _showNext() {
var si = this._getNextShowable(this.current_index);
if (si === false) {
return false;
}
this._showStep(si);
}
}, {
key: "_showPrevious",
value: function _showPrevious() {
var si = this._getPreviousShowable(this.current_index);
if (si === false) {
return false;
}
this._showStep(si);
}
}, {
key: "_showStep",
value: function _showStep(idx) {
// If current step is requested again, skip
if (idx == this.current_index) {
return false;
} // If step not found, skip
if (!this.steps.eq(idx)) {
return false;
} // If it is a disabled step, skip
if (!this._isShowable(idx)) {
return false;
} // Load step content
this._loadStep(idx);
}
}, {
key: "_getNextShowable",
value: function _getNextShowable(idx) {
var si = false; // Find the next showable step
for (var i = idx + 1; i < this.steps.length; i++) {
if (this._isShowable(i)) {
si = i;
break;
}
}
if (si !== false && this.steps.length <= si) {
if (!this.options.cycleSteps) {
return false;
}
si = 0;
}
return si;
}
}, {
key: "_getPreviousShowable",
value: function _getPreviousShowable(idx) {
var si = false; // Find the previous showable step
for (var i = idx - 1; i >= 0; i--) {
if (this._isShowable(i)) {
si = i;
break;
}
}
if (si !== false && 0 > si) {
if (!this.options.cycleSteps) {
return false;
}
si = this.steps.length - 1;
}
return si;
}
}, {
key: "_isShowable",
value: function _isShowable(idx) {
var elm = this.steps.eq(idx);
if (elm.hasClass('disabled') || elm.hasClass('hidden')) {
return false;
}
return true;
}
}, {
key: "_isDone",
value: function _isDone(idx) {
var elm = this.steps.eq(idx);
if (elm.hasClass('done')) {
return true;
}
return false;
}
}, {
key: "_setPreviousStepsDone",
value: function _setPreviousStepsDone(idx) {
if (idx > 0 && this.options.anchorSettings.markDoneStep && this.options.anchorSettings.markAllPreviousStepsAsDone) {
// Mark previous steps of the active step as done
for (var i = idx; i >= 0; i--) {
this._setCSSClass(i, "done");
}
}
}
}, {
key: "_setCSSClass",
value: function _setCSSClass(idx, cls) {
var _this2 = this;
if (idx === null) {
return false;
}
var idxs = $.isArray(idx) ? idx : [idx];
idxs.map(function (i) {
_this2.steps.eq(i).addClass(cls);
});
}
}, {
key: "_resetCSSClass",
value: function _resetCSSClass(idx, cls) {
var _this3 = this;
var idxs = $.isArray(idx) ? idx : [idx];
idxs.map(function (i) {
_this3.steps.eq(i).removeClass(cls);
});
}
}, {
key: "_getStepDirection",
value: function _getStepDirection(idx) {
if (this.current_index == null) {
return '';
}
return this.current_index < idx ? "forward" : "backward";
}
}, {
key: "_getStepPosition",
value: function _getStepPosition(idx) {
var stepPosition = 'middle';
if (idx === 0) {
stepPosition = 'first';
} else if (idx === this.steps.length - 1) {
stepPosition = 'last';
}
return stepPosition;
}
}, {
key: "_getStepAnchor",
value: function _getStepAnchor(idx) {
if (idx == null) {
return null;
}
return this.steps.eq(idx);
}
}, {
key: "_getStepPage",
value: function _getStepPage(idx) {
if (idx == null) {
return null;
}
var anchor = this._getStepAnchor(idx);
return anchor.length > 0 ? this.main.find(anchor.attr("href")) : null;
}
}, {
key: "_setStepContent",
value: function _setStepContent(idx, html) {
var page = this._getStepPage(idx);
if (page) {
page.html(html);
}
}
}, {
key: "_loadStep",
value: function _loadStep(idx) {
var _this4 = this;
// Get current step element
var curStep = this._getStepAnchor(this.current_index); // Get step direction
var stepDirection = this._getStepDirection(idx); // Get the direction of step navigation
if (this.current_index !== null) {
// Trigger "leaveStep" event
if (this._triggerEvent("leaveStep", [curStep, this.current_index, idx, stepDirection]) === false) {
return false;
}
} // Get next step element
var selStep = this._getStepAnchor(idx); // Get the content if used
var getStepContent = this._triggerEvent("stepContent", [selStep, idx, stepDirection]);
if (getStepContent) {
if (_typeof(getStepContent) == "object") {
getStepContent.then(function (res) {
_this4._setStepContent(idx, res);
_this4._transitStep(idx);
})["catch"](function (err) {
console.error(err);
_this4._setStepContent(idx, err);
_this4._transitStep(idx);
});
} else if (typeof getStepContent == "string") {
this._setStepContent(idx, getStepContent);
this._transitStep(idx);
} else {
this._transitStep(idx);
}
} else {
this._transitStep(idx);
}
}
}, {
key: "_transitStep",
value: function _transitStep(idx) {
var _this5 = this;
// Get step to show element
var selStep = this._getStepAnchor(idx); // Change the url hash to new step
this._setURLHash(selStep.attr("href")); // Update controls
this._setAnchor(idx); // Get the direction of step navigation
var stepDirection = this._getStepDirection(idx); // Get the position of step
var stepPosition = this._getStepPosition(idx); // Animate the step
this._doStepAnimation(idx, function () {
// Fix height with content
_this5._fixHeight(idx); // Trigger "showStep" event
_this5._triggerEvent("showStep", [selStep, _this5.current_index, stepDirection, stepPosition]);
}); // Update the current index
this.current_index = idx; // Set the buttons based on the step
this._setButtons(idx);
}
}, {
key: "_doStepAnimation",
value: function _doStepAnimation(idx, callback) {
var _this6 = this;
// Get current step element
var curPage = this._getStepPage(this.current_index); // Get next step element
var selPage = this._getStepPage(idx); // Get the animation
var animation = this.options.transition.animation.toLowerCase(); // Complete any ongoing animations
this._stopAnimations();
switch (animation) {
case 'slide-horizontal':
case 'slide-h':
// horizontal slide
var containerWidth = this.container.width();
var curLastLeft = containerWidth;
var nextFirstLeft = containerWidth * -2; // Forward direction
if (idx > this.current_index) {
curLastLeft = containerWidth * -1;
nextFirstLeft = containerWidth;
} // First load set the container width
if (this.current_index == null) {
this.container.height(selPage.outerHeight());
}
var css_pos, css_left;
if (curPage) {
css_pos = curPage.css("position");
css_left = curPage.css("left");
curPage.css("position", 'absolute').css("left", 0).animate({
left: curLastLeft
}, this.options.transition.speed, this.options.transition.easing, function () {
$(this).hide();
curPage.css("position", css_pos).css("left", css_left);
});
}
css_pos = selPage.css("position");
css_left = selPage.css("left");
selPage.css("position", 'absolute').css("left", nextFirstLeft).outerWidth(containerWidth).show().animate({
left: 0
}, this.options.transition.speed, this.options.transition.easing, function () {
selPage.css("position", css_pos).css("left", css_left);
callback();
});
break;
case 'slide-vertical':
case 'slide-v':
// vertical slide
var containerHeight = this.container.height();
var curLastTop = containerHeight;
var nextFirstTop = containerHeight * -2; // Forward direction
if (idx > this.current_index) {
curLastTop = containerHeight * -1;
nextFirstTop = containerHeight;
}
var css_vpos, css_vtop;
if (curPage) {
css_vpos = curPage.css("position");
css_vtop = curPage.css("top");
curPage.css("position", 'absolute').css("top", 0).animate({
top: curLastTop
}, this.options.transition.speed, this.options.transition.easing, function () {
$(this).hide();
curPage.css("position", css_vpos).css("top", css_vtop);
});
}
css_vpos = selPage.css("position");
css_vtop = selPage.css("top");
selPage.css("position", 'absolute').css("top", nextFirstTop).show().animate({
top: 0
}, this.options.transition.speed, this.options.transition.easing, function () {
selPage.css("position", css_vpos).css("top", css_vtop);
callback();
});
break;
case 'slide-swing':
case 'slide-s':
// normal slide
if (curPage) {
curPage.slideUp('fast', this.options.transition.easing, function () {
selPage.slideDown(_this6.options.transition.speed, _this6.options.transition.easing, function () {
callback();
});
});
} else {
selPage.slideDown(this.options.transition.speed, this.options.transition.easing, function () {
callback();
});
}
break;
case 'fade':
// normal fade
if (curPage) {
curPage.fadeOut('fast', this.options.transition.easing, function () {
selPage.fadeIn('fast', _this6.options.transition.easing, function () {
callback();
});
});
} else {
selPage.fadeIn(this.options.transition.speed, this.options.transition.easing, function () {
callback();
});
}
break;
default:
if (curPage) {
curPage.hide();
}
selPage.show();
callback();
break;
}
}
}, {
key: "_stopAnimations",
value: function _stopAnimations() {
this.pages.finish();
this.container.finish();
}
}, {
key: "_setAnchor",
value: function _setAnchor(idx) {
// Current step anchor > Remove other classes and add done class
this._resetCSSClass(this.current_index, "active");
if (this.options.anchorSettings.markDoneStep !== false && this.current_index !== null) {
this._setCSSClass(this.current_index, "done");
if (this.options.anchorSettings.removeDoneStepOnNavigateBack !== false && this._getStepDirection(idx) === 'backward') {
this._resetCSSClass(this.current_index, "done");
}
} // Next step anchor > Remove other classes and add active class
this._resetCSSClass(idx, "done");
this._setCSSClass(idx, "active");
}
}, {
key: "_setButtons",
value: function _setButtons(idx) {
// Previous/Next Button enable/disable based on step
if (!this.options.cycleSteps) {
this.main.find('.sw-btn-prev').removeClass("disabled");
this.main.find('.sw-btn-next').removeClass("disabled");
switch (this._getStepPosition(idx)) {
case 'first':
this.main.find('.sw-btn-prev').addClass("disabled");
break;
case 'last':
this.main.find('.sw-btn-next').addClass("disabled");
break;
default:
if (this._getNextShowable(idx) === false) {
this.main.find('.sw-btn-next').addClass("disabled");
}
if (this._getPreviousShowable(idx) === false) {
this.main.find('.sw-btn-prev').addClass("disabled");
}
break;
}
}
}
}, {
key: "_getStepIndex",
value: function _getStepIndex() {
// Get selected step from the url
var idx = this._getURLHashIndex();
return idx === false ? this.options.selected : idx;
}
}, {
key: "_setTheme",
value: function _setTheme(theme) {
this.main.removeClass(function (index, className) {
return (className.match(/(^|\s)sw-theme-\S+/g) || []).join(' ');
}).addClass('sw-theme-' + theme);
}
}, {
key: "_setJustify",
value: function _setJustify(justified) {
if (justified === true) {
this.main.addClass('sw-justified');
} else {
this.main.removeClass('sw-justified');
}
}
}, {
key: "_setDarkMode",
value: function _setDarkMode(darkMode) {
if (darkMode === true) {
this.main.addClass('sw-dark');
} else {
this.main.removeClass('sw-dark');
}
} // HELPER FUNCTIONS
}, {
key: "_keyNav",
value: function _keyNav(e) {
// Keyboard navigation
if ($.inArray(e.which, this.options.keyboardSettings.keyLeft) > -1) {
// left
this._showPrevious();
e.preventDefault();
} else if ($.inArray(e.which, this.options.keyboardSettings.keyRight) > -1) {
// right
this._showNext();
e.preventDefault();
} else {
return; // exit this handler for other keys
}
}
}, {
key: "_fixHeight",
value: function _fixHeight(idx) {
// Auto adjust height of the container
if (this.options.autoAdjustHeight) {
var selPage = this._getStepPage(idx);
this.container.finish().animate({
height: selPage.outerHeight()
}, this.options.transition.speed);
}
}
}, {
key: "_triggerEvent",
value: function _triggerEvent(name, params) {
// Trigger an event
var e = $.Event(name);
this.main.trigger(e, params);
if (e.isDefaultPrevented()) {
return false;
}
return e.result;
}
}, {
key: "_setURLHash",
value: function _setURLHash(hash) {
if (this.options.enableURLhash && window.location.hash !== hash) {
history.pushState(null, null, hash);
}
}
}, {
key: "_getURLHashIndex",
value: function _getURLHashIndex() {
if (this.options.enableURLhash) {
// Get step number from url hash if available
var hash = window.location.hash;
if (hash.length > 0) {
var elm = this.nav.find("a[href*='" + hash + "']");
if (elm.length > 0) {
return this.steps.index(elm);
}
}
}
return false;
}
}, {
key: "_loader",
value: function _loader(action) {
switch (action) {
case 'show':
this.main.addClass('sw-loading');
break;
case 'hide':
this.main.removeClass('sw-loading');
break;
default:
this.main.toggleClass('sw-loading');
}
}
}, {
key: "_showError",
value: function _showError(msg) {
console.error(msg);
} // PUBLIC FUNCTIONS
}, {
key: "goToStep",
value: function goToStep(stepIndex) {
this._showStep(stepIndex);
}
}, {
key: "next",
value: function next() {
this._showNext();
}
}, {
key: "prev",
value: function prev() {
this._showPrevious();
}
}, {
key: "reset",
value: function reset() {
// Reset all
this._setURLHash('#');
this._initOptions();
this._initLoad();
}
}, {
key: "stepState",
value: function stepState(stepArray, state) {
if (!stepArray) {
return false;
}
switch (state) {
case 'disable':
this._setCSSClass(stepArray, 'disabled');
break;
case 'enable':
this._resetCSSClass(stepArray, 'disabled');
break;
case 'hide':
this._setCSSClass(stepArray, 'hidden');
break;
case 'show':
this._resetCSSClass(stepArray, 'hidden');
break;
case 'error-on':
this._setCSSClass(stepArray, 'danger');
break;
case 'error-off':
this._resetCSSClass(stepArray, 'danger');
break;
}
}
}, {
key: "setOptions",
value: function setOptions(options) {
this.options = $.extend(true, {}, this.options, options);
this._initOptions();
}
}, {
key: "getStepIndex",
value: function getStepIndex() {
return this.current_index;
}
}, {
key: "loader",
value: function loader(state) {
if (state === "show") {
this.main.addClass('sw-loading');
} else {
this.main.removeClass('sw-loading');
}
}
}]);
return SmartWizard;
}(); // Wrapper for the plugin
$.fn.smartWizard = function (options) {
if (options === undefined || _typeof(options) === 'object') {
return this.each(function () {
if (!$.data(this, "smartWizard")) {
$.data(this, "smartWizard", new SmartWizard(this, options));
}
});
} else if (typeof options === 'string' && options[0] !== '_' && options !== 'init') {
var instance = $.data(this[0], 'smartWizard');
if (options === 'destroy') {
$.data(this, 'smartWizard', null);
}
if (instance instanceof SmartWizard && typeof instance[options] === 'function') {
return instance[options].apply(instance, Array.prototype.slice.call(arguments, 1));
} else {
return this;
}
}
};
});