+++ /dev/null
-/*
- * Fuel UX Wizard
- * https://github.com/ExactTarget/fuelux
- *
- * Copyright (c) 2012 ExactTarget
- * Licensed under the MIT license.
- */
-
-define(['require','jquery'],function (require) {
-
- var $ = require('jquery');
-
-
- // WIZARD CONSTRUCTOR AND PROTOTYPE
-
- var Wizard = function (element, options) {
- var kids;
-
- this.$element = $(element);
- this.options = $.extend({}, $.fn.wizard.defaults, options);
- this.currentStep = 1;
- this.numSteps = this.$element.find('li').length;
- this.$prevBtn = this.$element.find('button.btn-prev');
- this.$nextBtn = this.$element.find('button.btn-next');
-
- kids = this.$nextBtn.children().detach();
- this.nextText = $.trim(this.$nextBtn.text());
- this.$nextBtn.append(kids);
-
- // handle events
- this.$prevBtn.on('click', $.proxy(this.previous, this));
- this.$nextBtn.on('click', $.proxy(this.next, this));
- this.$element.on('click', 'li.complete', $.proxy(this.stepclicked, this));
- };
-
- Wizard.prototype = {
-
- constructor: Wizard,
-
- setState: function () {
- var canMovePrev = (this.currentStep > 1);
- var firstStep = (this.currentStep === 1);
- var lastStep = (this.currentStep === this.numSteps);
-
- // disable buttons based on current step
- this.$prevBtn.attr('disabled', (firstStep === true || canMovePrev === false));
-
- // change button text of last step, if specified
- var data = this.$nextBtn.data();
- if (data && data.last) {
- this.lastText = data.last;
- if (typeof this.lastText !== 'undefined') {
- // replace text
- var text = (lastStep !== true) ? this.nextText : this.lastText;
- var kids = this.$nextBtn.children().detach();
- this.$nextBtn.text(text).append(kids);
- }
- }
-
- // reset classes for all steps
- var $steps = this.$element.find('li');
- $steps.removeClass('active').removeClass('complete');
- $steps.find('span.badge').removeClass('badge-info').removeClass('badge-success');
-
- // set class for all previous steps
- var prevSelector = 'li:lt(' + (this.currentStep - 1) + ')';
- var $prevSteps = this.$element.find(prevSelector);
- $prevSteps.addClass('complete');
- $prevSteps.find('span.badge').addClass('badge-success');
-
- // set class for current step
- var currentSelector = 'li:eq(' + (this.currentStep - 1) + ')';
- var $currentStep = this.$element.find(currentSelector);
- $currentStep.addClass('active');
- $currentStep.find('span.badge').addClass('badge-info');
-
- // set display of target element
- var target = $currentStep.data().target;
- $('.step-pane').removeClass('active');
- $(target).addClass('active');
-
- this.$element.trigger('changed');
- },
-
- stepclicked: function (e) {
- var li = $(e.currentTarget);
-
- var index = $('.steps li').index(li);
-
- var evt = $.Event('stepclick');
- this.$element.trigger(evt, {step: index + 1});
- if (evt.isDefaultPrevented()) return;
-
- this.currentStep = (index + 1);
- this.setState();
- },
-
- previous: function () {
- var canMovePrev = (this.currentStep > 1);
- if (canMovePrev) {
- var e = $.Event('change');
- this.$element.trigger(e, {step: this.currentStep, direction: 'previous'});
- if (e.isDefaultPrevented()) return;
-
- this.currentStep -= 1;
- this.setState();
- }
- },
-
- next: function () {
- var canMoveNext = (this.currentStep + 1 <= this.numSteps);
- var lastStep = (this.currentStep === this.numSteps);
-
- if (canMoveNext) {
- var e = $.Event('change');
- this.$element.trigger(e, {step: this.currentStep, direction: 'next'});
-
- if (e.isDefaultPrevented()) return;
-
- this.currentStep += 1;
- this.setState();
- }
- else if (lastStep) {
- this.$element.trigger('finished');
- }
- },
-
- selectedItem: function (val) {
- return {
- step: this.currentStep
- };
- }
- };
-
-
- // WIZARD PLUGIN DEFINITION
-
- $.fn.wizard = function (option, value) {
- var methodReturn;
-
- var $set = this.each(function () {
- var $this = $(this);
- var data = $this.data('wizard');
- var options = typeof option === 'object' && option;
-
- if (!data) $this.data('wizard', (data = new Wizard(this, options)));
- if (typeof option === 'string') methodReturn = data[option](value);
- });
-
- return (methodReturn === undefined) ? $set : methodReturn;
- };
-
- $.fn.wizard.defaults = {};
-
- $.fn.wizard.Constructor = Wizard;
-
-
- // WIZARD DATA-API
-
- $(function () {
- $('body').on('mousedown.wizard.data-api', '.wizard', function () {
- var $this = $(this);
- if ($this.data('wizard')) return;
- $this.wizard($this.data());
- });
- });
-
-});