UNPKG

zoomla

Version:

16年专业研发|中文alexa排名第一的CMS品牌-基于dotNET core、功能强大,集成站群、微信开发、小程序与ERP及OA办公系统,支持国际语言和多民族语言,世界五百强与大型门户专用高端网站内核CMS系统

734 lines (660 loc) 28.5 kB
/* ======================================================================== * bootstrap-switch - v3.0.2 * http://www.bootstrap-switch.org * ======================================================================== */ (function() { var __slice = [].slice; (function($, window) { "use strict"; var BootstrapSwitch; BootstrapSwitch = (function() { function BootstrapSwitch(element, options) { if (options == null) { options = {}; } this.$element = $(element); this.options = $.extend({}, $.fn.bootstrapSwitch.defaults, { state: this.$element.is(":checked"), size: this.$element.data("size"), animate: this.$element.data("animate"), disabled: this.$element.is(":disabled"), readonly: this.$element.is("[readonly]"), indeterminate: this.$element.data("indeterminate"), onColor: this.$element.data("on-color"), offColor: this.$element.data("off-color"), onText: this.$element.data("on-text"), offText: this.$element.data("off-text"), labelText: this.$element.data("label-text"), baseClass: this.$element.data("base-class"), wrapperClass: this.$element.data("wrapper-class"), radioAllOff: this.$element.data("radio-all-off") }, options); this.$wrapper = $("<div>", { "class": (function(_this) { return function() { var classes; classes = ["" + _this.options.baseClass].concat(_this._getClasses(_this.options.wrapperClass)); classes.push(_this.options.state ? "" + _this.options.baseClass + "-on" : "" + _this.options.baseClass + "-off"); if (_this.options.size != null) { classes.push("" + _this.options.baseClass + "-" + _this.options.size); } if (_this.options.animate) { classes.push("" + _this.options.baseClass + "-animate"); } if (_this.options.disabled) { classes.push("" + _this.options.baseClass + "-disabled"); } if (_this.options.readonly) { classes.push("" + _this.options.baseClass + "-readonly"); } if (_this.options.indeterminate) { classes.push("" + _this.options.baseClass + "-indeterminate"); } if (_this.$element.attr("id")) { classes.push("" + _this.options.baseClass + "-id-" + (_this.$element.attr("id"))); } return classes.join(" "); }; })(this)() }); this.$container = $("<div>", { "class": "" + this.options.baseClass + "-container" }); this.$on = $("<span>", { html: this.options.onText, "class": "" + this.options.baseClass + "-handle-on " + this.options.baseClass + "-" + this.options.onColor }); this.$off = $("<span>", { html: this.options.offText, "class": "" + this.options.baseClass + "-handle-off " + this.options.baseClass + "-" + this.options.offColor }); this.$label = $("<label>", { html: this.options.labelText, "class": "" + this.options.baseClass + "-label" }); if (this.options.indeterminate) { this.$element.prop("indeterminate", true); } this.$element.on("init.bootstrapSwitch", (function(_this) { return function() { return _this.options.onInit.apply(element, arguments); }; })(this)); this.$element.on("switchChange.bootstrapSwitch", (function(_this) { return function() { return _this.options.onSwitchChange.apply(element, arguments); }; })(this)); this.$container = this.$element.wrap(this.$container).parent(); this.$wrapper = this.$container.wrap(this.$wrapper).parent(); this.$element.before(this.$on).before(this.$label).before(this.$off).trigger("init.bootstrapSwitch"); this._elementHandlers(); this._handleHandlers(); this._labelHandlers(); this._formHandler(); } BootstrapSwitch.prototype._constructor = BootstrapSwitch; BootstrapSwitch.prototype.state = function(value, skip) { if (typeof value === "undefined") { return this.options.state; } if (this.options.disabled || this.options.readonly || this.options.indeterminate) { return this.$element; } if (this.options.state && !this.options.radioAllOff && this.$element.is(':radio')) { return this.$element; } value = !!value; this.$element.prop("checked", value).trigger("change.bootstrapSwitch", skip); return this.$element; }; BootstrapSwitch.prototype.toggleState = function(skip) { if (this.options.disabled || this.options.readonly || this.options.indeterminate) { return this.$element; } return this.$element.prop("checked", !this.options.state).trigger("change.bootstrapSwitch", skip); }; BootstrapSwitch.prototype.size = function(value) { if (typeof value === "undefined") { return this.options.size; } if (this.options.size != null) { this.$wrapper.removeClass("" + this.options.baseClass + "-" + this.options.size); } if (value) { this.$wrapper.addClass("" + this.options.baseClass + "-" + value); } this.options.size = value; return this.$element; }; BootstrapSwitch.prototype.animate = function(value) { if (typeof value === "undefined") { return this.options.animate; } value = !!value; this.$wrapper[value ? "addClass" : "removeClass"]("" + this.options.baseClass + "-animate"); this.options.animate = value; return this.$element; }; BootstrapSwitch.prototype.disabled = function(value) { if (typeof value === "undefined") { return this.options.disabled; } value = !!value; this.$wrapper[value ? "addClass" : "removeClass"]("" + this.options.baseClass + "-disabled"); this.$element.prop("disabled", value); this.options.disabled = value; return this.$element; }; BootstrapSwitch.prototype.toggleDisabled = function() { this.$element.prop("disabled", !this.options.disabled); this.$wrapper.toggleClass("" + this.options.baseClass + "-disabled"); this.options.disabled = !this.options.disabled; return this.$element; }; BootstrapSwitch.prototype.readonly = function(value) { if (typeof value === "undefined") { return this.options.readonly; } value = !!value; this.$wrapper[value ? "addClass" : "removeClass"]("" + this.options.baseClass + "-readonly"); this.$element.prop("readonly", value); this.options.readonly = value; return this.$element; }; BootstrapSwitch.prototype.toggleReadonly = function() { this.$element.prop("readonly", !this.options.readonly); this.$wrapper.toggleClass("" + this.options.baseClass + "-readonly"); this.options.readonly = !this.options.readonly; return this.$element; }; BootstrapSwitch.prototype.indeterminate = function(value) { if (typeof value === "undefined") { return this.options.indeterminate; } value = !!value; this.$wrapper[value ? "addClass" : "removeClass"]("" + this.options.baseClass + "-indeterminate"); this.$element.prop("indeterminate", value); this.options.indeterminate = value; return this.$element; }; BootstrapSwitch.prototype.toggleIndeterminate = function() { this.$element.prop("indeterminate", !this.options.indeterminate); this.$wrapper.toggleClass("" + this.options.baseClass + "-indeterminate"); this.options.indeterminate = !this.options.indeterminate; return this.$element; }; BootstrapSwitch.prototype.onColor = function(value) { var color; color = this.options.onColor; if (typeof value === "undefined") { return color; } if (color != null) { this.$on.removeClass("" + this.options.baseClass + "-" + color); } this.$on.addClass("" + this.options.baseClass + "-" + value); this.options.onColor = value; return this.$element; }; BootstrapSwitch.prototype.offColor = function(value) { var color; color = this.options.offColor; if (typeof value === "undefined") { return color; } if (color != null) { this.$off.removeClass("" + this.options.baseClass + "-" + color); } this.$off.addClass("" + this.options.baseClass + "-" + value); this.options.offColor = value; return this.$element; }; BootstrapSwitch.prototype.onText = function(value) { if (typeof value === "undefined") { return this.options.onText; } this.$on.html(value); this.options.onText = value; return this.$element; }; BootstrapSwitch.prototype.offText = function(value) { if (typeof value === "undefined") { return this.options.offText; } this.$off.html(value); this.options.offText = value; return this.$element; }; BootstrapSwitch.prototype.labelText = function(value) { if (typeof value === "undefined") { return this.options.labelText; } this.$label.html(value); this.options.labelText = value; return this.$element; }; BootstrapSwitch.prototype.baseClass = function(value) { return this.options.baseClass; }; BootstrapSwitch.prototype.wrapperClass = function(value) { if (typeof value === "undefined") { return this.options.wrapperClass; } if (!value) { value = $.fn.bootstrapSwitch.defaults.wrapperClass; } this.$wrapper.removeClass(this._getClasses(this.options.wrapperClass).join(" ")); this.$wrapper.addClass(this._getClasses(value).join(" ")); this.options.wrapperClass = value; return this.$element; }; BootstrapSwitch.prototype.radioAllOff = function(value) { if (typeof value === "undefined") { return this.options.radioAllOff; } this.options.radioAllOff = value; return this.$element; }; BootstrapSwitch.prototype.onInit = function(value) { if (typeof value === "undefined") { return this.options.onInit; } if (!value) { value = $.fn.bootstrapSwitch.defaults.onInit; } this.options.onInit = value; return this.$element; }; BootstrapSwitch.prototype.onSwitchChange = function(value) { if (typeof value === "undefined") { return this.options.onSwitchChange; } if (!value) { value = $.fn.bootstrapSwitch.defaults.onSwitchChange; } this.options.onSwitchChange = value; return this.$element; }; BootstrapSwitch.prototype.destroy = function() { var $form; $form = this.$element.closest("form"); if ($form.length) { $form.off("reset.bootstrapSwitch").removeData("bootstrap-switch"); } this.$container.children().not(this.$element).remove(); this.$element.unwrap().unwrap().off(".bootstrapSwitch").removeData("bootstrap-switch"); return this.$element; }; BootstrapSwitch.prototype._elementHandlers = function() { return this.$element.on({ "change.bootstrapSwitch": (function(_this) { return function(e, skip) { var checked; e.preventDefault(); e.stopImmediatePropagation(); checked = _this.$element.is(":checked"); if (checked === _this.options.state) { } _this.options.state = checked; _this.$wrapper.removeClass(checked ? "" + _this.options.baseClass + "-off" : "" + _this.options.baseClass + "-on").addClass(checked ? "" + _this.options.baseClass + "-on" : "" + _this.options.baseClass + "-off"); if (!skip) { if (_this.$element.is(":radio")) { $("[name='" + (_this.$element.attr('name')) + "']").not(_this.$element).prop("checked", false).trigger("change.bootstrapSwitch", true); } return _this.$element.trigger("switchChange.bootstrapSwitch", [checked]); } }; })(this), "focus.bootstrapSwitch": (function(_this) { return function(e) { e.preventDefault(); return _this.$wrapper.addClass("" + _this.options.baseClass + "-focused"); }; })(this), "blur.bootstrapSwitch": (function(_this) { return function(e) { e.preventDefault(); return _this.$wrapper.removeClass("" + _this.options.baseClass + "-focused"); }; })(this), "keydown.bootstrapSwitch": (function(_this) { return function(e) { if (!e.which || _this.options.disabled || _this.options.readonly || _this.options.indeterminate) { } switch (e.which) { case 37: e.preventDefault(); e.stopImmediatePropagation(); return _this.state(false); case 39: e.preventDefault(); e.stopImmediatePropagation(); return _this.state(true); } }; })(this) }); }; BootstrapSwitch.prototype._handleHandlers = function() { this.$on.on("click.bootstrapSwitch", (function(_this) { return function(e) { _this.state(false); return _this.$element.trigger("focus.bootstrapSwitch"); }; })(this)); return this.$off.on("click.bootstrapSwitch", (function(_this) { return function(e) { _this.state(true); return _this.$element.trigger("focus.bootstrapSwitch"); }; })(this)); }; BootstrapSwitch.prototype._labelHandlers = function() { return this.$label.on({ "mousemove.bootstrapSwitch touchmove.bootstrapSwitch": (function(_this) { return function(e) { var left, pageX, percent, right; if (!_this.isLabelDragging) { } e.preventDefault(); _this.isLabelDragged = true; pageX = e.pageX || e.originalEvent.touches[0].pageX; percent = ((pageX - _this.$wrapper.offset().left) / _this.$wrapper.width()) * 100; left = 25; right = 75; if (_this.options.animate) { _this.$wrapper.removeClass("" + _this.options.baseClass + "-animate"); } if (percent < left) { percent = left; } else if (percent > right) { percent = right; } _this.$container.css("margin-left", "" + (percent - right) + "%"); return _this.$element.trigger("focus.bootstrapSwitch"); }; })(this), "mousedown.bootstrapSwitch touchstart.bootstrapSwitch": (function(_this) { return function(e) { if (_this.isLabelDragging || _this.options.disabled || _this.options.readonly || _this.options.indeterminate) { } e.preventDefault(); _this.isLabelDragging = true; return _this.$element.trigger("focus.bootstrapSwitch"); }; })(this), "mouseup.bootstrapSwitch touchend.bootstrapSwitch": (function(_this) { return function(e) { if (!_this.isLabelDragging) { } e.preventDefault(); if (_this.isLabelDragged) { _this.isLabelDragged = false; _this.state(parseInt(_this.$container.css("margin-left"), 10) > -(_this.$container.width() / 6)); if (_this.options.animate) { _this.$wrapper.addClass("" + _this.options.baseClass + "-animate"); } _this.$container.css("margin-left", ""); } else { _this.state(!_this.options.state); } return _this.isLabelDragging = false; }; })(this), "mouseleave.bootstrapSwitch": (function(_this) { return function(e) { return _this.$label.trigger("mouseup.bootstrapSwitch"); }; })(this) }); }; BootstrapSwitch.prototype._formHandler = function() { var $form; $form = this.$element.closest("form"); if ($form.data("bootstrap-switch")) { } return $form.on("reset.bootstrapSwitch", function() { return window.setTimeout(function() { return $form.find("input").filter(function() { return $(this).data("bootstrap-switch"); }).each(function() { return $(this).bootstrapSwitch("state", this.checked); }); }, 1); }).data("bootstrap-switch", true); }; BootstrapSwitch.prototype._getClasses = function(classes) { var c, cls, _i, _len; if (!$.isArray(classes)) { return ["" + this.options.baseClass + "-" + classes]; } cls = []; for (_i = 0, _len = classes.length; _i < _len; _i++) { c = classes[_i]; cls.push("" + this.options.baseClass + "-" + c); } return cls; }; return BootstrapSwitch; })(); $.fn.bootstrapSwitch = function() { var args, option, ret; option = arguments[0], args = 2 <= arguments.length ? __slice.call(arguments, 1) : []; ret = this; this.each(function() { var $this, data; $this = $(this); data = $this.data("bootstrap-switch"); if (!data) { $this.data("bootstrap-switch", data = new BootstrapSwitch(this, option)); } if (typeof option === "string") { return ret = data[option].apply(data, args); } }); return ret; }; $.fn.bootstrapSwitch.Constructor = BootstrapSwitch; return $.fn.bootstrapSwitch.defaults = { state: true, size: null, animate: false, disabled: false, readonly: false, indeterminate: false, onColor: "primary", offColor: "default", onText: "是", offText: "否", labelText: "&nbsp;", baseClass: "bootstrap-switch", wrapperClass: "wrapper", radioAllOff: false, onInit: function() {}, onSwitchChange: function() {} }; })(window.jQuery, window); }).call(this); //-------------- (function ($) { $.fn.labelauty = function (options) { /* * Our default settings * Hope you don't need to change anything, with these settings */ var settings = $.extend( { // Development Mode // This will activate console debug messages development: false, // Trigger Class // This class will be used to apply styles class: "labelauty", // Use text label ? // If false, then only an icon represents the input label: true, // Separator between labels' messages // If you use this separator for anything, choose a new one separator: "|", // Default Checked Message // This message will be visible when input is checked checked_label: "Checked", // Default UnChecked Message // This message will be visible when input is unchecked unchecked_label: "Unchecked", // Minimum Label Width // This value will be used to apply a minimum width to the text labels minimum_width: false, // Use the greatest width between two text labels ? // If this has a true value, then label width will be the greatest between labels same_width: true }, options); /* * Let's create the core function * It will try to cover all settings and mistakes of using */ return this.each(function () { var $object = $(this); var use_labels = true; var labels; var labels_object; var input_id; // Test if object is a check input // Don't mess me up, come on if ($object.is(":checkbox") === false && $object.is(":radio") === false) return this; // Add "labelauty" class to all checkboxes // So you can apply some custom styles $object.addClass(settings.class); // Get the value of "data-labelauty" attribute // Then, we have the labels for each case (or not, as we will see) labels = $object.attr("data-labelauty"); use_labels = settings.label; // It's time to check if it's going to the right way // Null values, more labels than expected or no labels will be handled here if (use_labels === true) { if (labels == null || labels.length === 0) { // If attribute has no label and we want to use, then use the default labels labels_object = new Array(); labels_object[0] = settings.unchecked_label; labels_object[1] = settings.checked_label; } else { // Ok, ok, it's time to split Checked and Unchecked labels // We split, by the "settings.separator" option labels_object = labels.split(settings.separator); // Now, let's check if exist _only_ two labels // If there's more than two, then we do not use labels :( // Else, do some additional tests if (labels_object.length > 2) { use_labels = false; debug(settings.development, "There's more than two labels. LABELAUTY will not use labels."); } else { // If there's just one label (no split by "settings.separator"), it will be used for both cases // Here, we have the possibility of use the same label for both cases if (labels_object.length === 1) debug(settings.development, "There's just one label. LABELAUTY will use this one for both cases."); } } } /* * Let's begin the beauty */ // Start hiding ugly checkboxes // Obviously, we don't need native checkboxes :O $object.css({ display: "none" }); // We don't need more data-labelauty attributes! // Ok, ok, it's just for beauty improvement $object.removeAttr("data-labelauty"); // Now, grab checkbox ID Attribute for "label" tag use // If there's no ID Attribute, then generate a new one input_id = $object.attr("id"); if (input_id == null) { var input_id_number = 1 + Math.floor(Math.random() * 1024000); input_id = "labelauty-" + input_id_number; // Is there any element with this random ID ? // If exists, then increment until get an unused ID while ($(input_id).length !== 0) { input_id_number++; input_id = "labelauty-" + input_id_number; debug(settings.development, "Holy crap, between 1024 thousand numbers, one raised a conflict. Trying again."); } $object.attr("id", input_id); } // Now, add necessary tags to make this work // Here, we're going to test some control variables and act properly $object.after(create(input_id, labels_object, use_labels)); // Now, add "min-width" to label // Let's say the truth, a fixed width is more beautiful than a variable width if (settings.minimum_width !== false) $object.next("label[for=" + input_id + "]").css({ "min-width": settings.minimum_width }); // Now, add "min-width" to label // Let's say the truth, a fixed width is more beautiful than a variable width if (settings.same_width != false && settings.label == true) { var label_object = $object.next("label[for=" + input_id + "]"); var unchecked_width = getRealWidth(label_object.find("span.labelauty-unchecked")); var checked_width = getRealWidth(label_object.find("span.labelauty-checked")); if (unchecked_width > checked_width) label_object.find("span.labelauty-checked").width(unchecked_width); else label_object.find("span.labelauty-unchecked").width(checked_width); } }); }; /* * Tricky code to work with hidden elements, like tabs. * Note: This code is based on jquery.actual plugin. * https://github.com/dreamerslab/jquery.actual */ function getRealWidth(element) { var width = 0; var $target = element; var style = 'position: absolute !important; top: -1000 !important; '; $target = $target.clone().attr('style', style).appendTo('body'); width = $target.width(true); $target.remove(); return width; } function debug(debug, message) { if (debug && window.console && window.console.log) window.console.log("jQuery-LABELAUTY: " + message); }; function create(input_id, messages_object, label) { var block; var unchecked_message; var checked_message; if (messages_object == null) unchecked_message = checked_message = ""; else { unchecked_message = messages_object[0]; // If checked message is null, then put the same text of unchecked message if (messages_object[1] == null) checked_message = unchecked_message; else checked_message = messages_object[1]; } if (label == true) { block = '<label for="' + input_id + '">' + '<span class="labelauty-unchecked-image"></span>' + '<span class="labelauty-unchecked">' + unchecked_message + '</span>' + '<span class="labelauty-checked-image"></span>' + '<span class="labelauty-checked">' + checked_message + '</span>' + '</label>'; } else { block = '<label for="' + input_id + '">' + '<span class="labelauty-unchecked-image"></span>' + '<span class="labelauty-checked-image"></span>' + '</label>'; } return block; }; }(jQuery)); //-------------- $(function () { $('.switchChk').not('#create-switch').not('#events-switch').bootstrapSwitch(); $(".goodradio").labelauty(); });