mirror of https://github.com/dani/vroom.git
parent
9f9b4cc8b5
commit
34d8649e3e
8 changed files with 789 additions and 2 deletions
@ -0,0 +1,206 @@ |
|||||||
|
/* ======================================================================== |
||||||
|
* bootstrap-switch - v3.0.2 |
||||||
|
* http://www.bootstrap-switch.org |
||||||
|
* ======================================================================== |
||||||
|
* Copyright 2012-2013 Mattia Larentis |
||||||
|
* |
||||||
|
* ======================================================================== |
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||||
|
* you may not use this file except in compliance with the License. |
||||||
|
* You may obtain a copy of the License at |
||||||
|
* |
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0 |
||||||
|
* |
||||||
|
* Unless required by applicable law or agreed to in writing, software |
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, |
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||||
|
* See the License for the specific language governing permissions and |
||||||
|
* limitations under the License. |
||||||
|
* ======================================================================== |
||||||
|
*/ |
||||||
|
|
||||||
|
.bootstrap-switch { |
||||||
|
display: inline-block; |
||||||
|
cursor: pointer; |
||||||
|
border-radius: 4px; |
||||||
|
border: 1px solid; |
||||||
|
border-color: #cccccc; |
||||||
|
position: relative; |
||||||
|
text-align: left; |
||||||
|
overflow: hidden; |
||||||
|
line-height: 8px; |
||||||
|
-webkit-user-select: none; |
||||||
|
-moz-user-select: none; |
||||||
|
-ms-user-select: none; |
||||||
|
user-select: none; |
||||||
|
vertical-align: middle; |
||||||
|
min-width: 100px; |
||||||
|
-webkit-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s; |
||||||
|
transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s; |
||||||
|
} |
||||||
|
.bootstrap-switch.bootstrap-switch-mini { |
||||||
|
min-width: 71px; |
||||||
|
} |
||||||
|
.bootstrap-switch.bootstrap-switch-mini .bootstrap-switch-handle-on, |
||||||
|
.bootstrap-switch.bootstrap-switch-mini .bootstrap-switch-handle-off, |
||||||
|
.bootstrap-switch.bootstrap-switch-mini .bootstrap-switch-label { |
||||||
|
padding-bottom: 4px; |
||||||
|
padding-top: 4px; |
||||||
|
font-size: 10px; |
||||||
|
line-height: 9px; |
||||||
|
} |
||||||
|
.bootstrap-switch.bootstrap-switch-small { |
||||||
|
min-width: 79px; |
||||||
|
} |
||||||
|
.bootstrap-switch.bootstrap-switch-small .bootstrap-switch-handle-on, |
||||||
|
.bootstrap-switch.bootstrap-switch-small .bootstrap-switch-handle-off, |
||||||
|
.bootstrap-switch.bootstrap-switch-small .bootstrap-switch-label { |
||||||
|
padding-bottom: 3px; |
||||||
|
padding-top: 3px; |
||||||
|
font-size: 12px; |
||||||
|
line-height: 18px; |
||||||
|
} |
||||||
|
.bootstrap-switch.bootstrap-switch-large { |
||||||
|
min-width: 120px; |
||||||
|
} |
||||||
|
.bootstrap-switch.bootstrap-switch-large .bootstrap-switch-handle-on, |
||||||
|
.bootstrap-switch.bootstrap-switch-large .bootstrap-switch-handle-off, |
||||||
|
.bootstrap-switch.bootstrap-switch-large .bootstrap-switch-label { |
||||||
|
padding-bottom: 9px; |
||||||
|
padding-top: 9px; |
||||||
|
font-size: 16px; |
||||||
|
line-height: normal; |
||||||
|
} |
||||||
|
.bootstrap-switch.bootstrap-switch-animate .bootstrap-switch-container { |
||||||
|
-webkit-transition: margin-left 0.5s; |
||||||
|
transition: margin-left 0.5s; |
||||||
|
} |
||||||
|
.bootstrap-switch.bootstrap-switch-on .bootstrap-switch-container { |
||||||
|
margin-left: 0%; |
||||||
|
} |
||||||
|
.bootstrap-switch.bootstrap-switch-on .bootstrap-switch-label { |
||||||
|
border-bottom-right-radius: 3px; |
||||||
|
border-top-right-radius: 3px; |
||||||
|
} |
||||||
|
.bootstrap-switch.bootstrap-switch-off .bootstrap-switch-container { |
||||||
|
margin-left: -50%; |
||||||
|
} |
||||||
|
.bootstrap-switch.bootstrap-switch-off .bootstrap-switch-label { |
||||||
|
border-bottom-left-radius: 3px; |
||||||
|
border-top-left-radius: 3px; |
||||||
|
} |
||||||
|
.bootstrap-switch.bootstrap-switch-indeterminate .bootstrap-switch-container { |
||||||
|
margin-left: -25%; |
||||||
|
} |
||||||
|
.bootstrap-switch.bootstrap-switch-disabled, |
||||||
|
.bootstrap-switch.bootstrap-switch-readonly, |
||||||
|
.bootstrap-switch.bootstrap-switch-indeterminate { |
||||||
|
opacity: 0.5; |
||||||
|
filter: alpha(opacity=50); |
||||||
|
cursor: default !important; |
||||||
|
} |
||||||
|
.bootstrap-switch.bootstrap-switch-disabled .bootstrap-switch-handle-on, |
||||||
|
.bootstrap-switch.bootstrap-switch-readonly .bootstrap-switch-handle-on, |
||||||
|
.bootstrap-switch.bootstrap-switch-indeterminate .bootstrap-switch-handle-on, |
||||||
|
.bootstrap-switch.bootstrap-switch-disabled .bootstrap-switch-handle-off, |
||||||
|
.bootstrap-switch.bootstrap-switch-readonly .bootstrap-switch-handle-off, |
||||||
|
.bootstrap-switch.bootstrap-switch-indeterminate .bootstrap-switch-handle-off, |
||||||
|
.bootstrap-switch.bootstrap-switch-disabled .bootstrap-switch-label, |
||||||
|
.bootstrap-switch.bootstrap-switch-readonly .bootstrap-switch-label, |
||||||
|
.bootstrap-switch.bootstrap-switch-indeterminate .bootstrap-switch-label { |
||||||
|
cursor: default !important; |
||||||
|
} |
||||||
|
.bootstrap-switch.bootstrap-switch-focused { |
||||||
|
border-color: #66afe9; |
||||||
|
outline: 0; |
||||||
|
-webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, 0.6); |
||||||
|
box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, 0.6); |
||||||
|
} |
||||||
|
.bootstrap-switch .bootstrap-switch-container { |
||||||
|
display: inline-block; |
||||||
|
width: 150%; |
||||||
|
top: 0; |
||||||
|
border-radius: 4px; |
||||||
|
-webkit-transform: translate3d(0, 0, 0); |
||||||
|
transform: translate3d(0, 0, 0); |
||||||
|
} |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-on, |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-off, |
||||||
|
.bootstrap-switch .bootstrap-switch-label { |
||||||
|
-webkit-box-sizing: border-box; |
||||||
|
-moz-box-sizing: border-box; |
||||||
|
box-sizing: border-box; |
||||||
|
cursor: pointer; |
||||||
|
display: inline-block !important; |
||||||
|
height: 100%; |
||||||
|
padding-bottom: 4px; |
||||||
|
padding-top: 4px; |
||||||
|
font-size: 14px; |
||||||
|
line-height: 20px; |
||||||
|
} |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-on, |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-off { |
||||||
|
text-align: center; |
||||||
|
z-index: 1; |
||||||
|
width: 33.333333333%; |
||||||
|
} |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-primary, |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-primary { |
||||||
|
color: #fff; |
||||||
|
background: #428bca; |
||||||
|
} |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-info, |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-info { |
||||||
|
color: #fff; |
||||||
|
background: #5bc0de; |
||||||
|
} |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-success, |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-success { |
||||||
|
color: #fff; |
||||||
|
background: #5cb85c; |
||||||
|
} |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-warning, |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-warning { |
||||||
|
background: #f0ad4e; |
||||||
|
color: #fff; |
||||||
|
} |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-danger, |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-danger { |
||||||
|
color: #fff; |
||||||
|
background: #d9534f; |
||||||
|
} |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-default, |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-default { |
||||||
|
color: #000; |
||||||
|
background: #eeeeee; |
||||||
|
} |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-on { |
||||||
|
border-bottom-left-radius: 3px; |
||||||
|
border-top-left-radius: 3px; |
||||||
|
} |
||||||
|
.bootstrap-switch .bootstrap-switch-handle-off { |
||||||
|
border-bottom-right-radius: 3px; |
||||||
|
border-top-right-radius: 3px; |
||||||
|
} |
||||||
|
.bootstrap-switch .bootstrap-switch-label { |
||||||
|
text-align: center; |
||||||
|
margin-top: -1px; |
||||||
|
margin-bottom: -1px; |
||||||
|
z-index: 100; |
||||||
|
width: 33.333333333%; |
||||||
|
color: #333333; |
||||||
|
background: #ffffff; |
||||||
|
} |
||||||
|
.bootstrap-switch input[type='radio'], |
||||||
|
.bootstrap-switch input[type='checkbox'] { |
||||||
|
position: absolute !important; |
||||||
|
top: 0; |
||||||
|
left: 0; |
||||||
|
opacity: 0; |
||||||
|
filter: alpha(opacity=0); |
||||||
|
z-index: -1; |
||||||
|
} |
||||||
|
.bootstrap-switch input[type='radio'].form-control, |
||||||
|
.bootstrap-switch input[type='checkbox'].form-control { |
||||||
|
height: auto; |
||||||
|
} |
File diff suppressed because one or more lines are too long
@ -0,0 +1,532 @@ |
|||||||
|
/* ======================================================================== |
||||||
|
* bootstrap-switch - v3.0.2 |
||||||
|
* http://www.bootstrap-switch.org
|
||||||
|
* ======================================================================== |
||||||
|
* Copyright 2012-2013 Mattia Larentis |
||||||
|
* |
||||||
|
* ======================================================================== |
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||||
|
* you may not use this file except in compliance with the License. |
||||||
|
* You may obtain a copy of the License at |
||||||
|
* |
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
* |
||||||
|
* Unless required by applicable law or agreed to in writing, software |
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, |
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||||
|
* See the License for the specific language governing permissions and |
||||||
|
* limitations under the License. |
||||||
|
* ======================================================================== |
||||||
|
*/ |
||||||
|
|
||||||
|
(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) { |
||||||
|
return; |
||||||
|
} |
||||||
|
_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) { |
||||||
|
return; |
||||||
|
} |
||||||
|
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) { |
||||||
|
return; |
||||||
|
} |
||||||
|
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) { |
||||||
|
return; |
||||||
|
} |
||||||
|
e.preventDefault(); |
||||||
|
_this.isLabelDragging = true; |
||||||
|
return _this.$element.trigger("focus.bootstrapSwitch"); |
||||||
|
}; |
||||||
|
})(this), |
||||||
|
"mouseup.bootstrapSwitch touchend.bootstrapSwitch": (function(_this) { |
||||||
|
return function(e) { |
||||||
|
if (!_this.isLabelDragging) { |
||||||
|
return; |
||||||
|
} |
||||||
|
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; |
||||||
|
} |
||||||
|
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: true, |
||||||
|
disabled: false, |
||||||
|
readonly: false, |
||||||
|
indeterminate: false, |
||||||
|
onColor: "primary", |
||||||
|
offColor: "default", |
||||||
|
onText: "ON", |
||||||
|
offText: "OFF", |
||||||
|
labelText: " ", |
||||||
|
baseClass: "bootstrap-switch", |
||||||
|
wrapperClass: "wrapper", |
||||||
|
radioAllOff: false, |
||||||
|
onInit: function() {}, |
||||||
|
onSwitchChange: function() {} |
||||||
|
}; |
||||||
|
})(window.jQuery, window); |
||||||
|
|
||||||
|
}).call(this); |
File diff suppressed because one or more lines are too long
@ -1,7 +1,7 @@ |
|||||||
<script type="text/javascript"> |
<script type="text/javascript"> |
||||||
var rootUrl = '<%= $self->get_url('/'); %>'; |
var rootUrl = '<%= $self->get_url('/'); %>'; |
||||||
</script> |
</script> |
||||||
<% foreach my $js (qw(jquery-1.11.1.min.js bootstrap.min.js notify-combined.min.js vroom.js)){ |
<% foreach my $js (qw(jquery-1.11.1.min.js bootstrap.min.js notify-combined.min.js bootstrap-switch.min.js vroom.js)){ |
||||||
%> |
%> |
||||||
<script type="text/javascript" src="<%= $self->get_url('/') %><%= $self->get_mtime("js/$js") %>/js/<%= $js %>"></script> |
<script type="text/javascript" src="<%= $self->get_url('/') %><%= $self->get_mtime("js/$js") %>/js/<%= $js %>"></script> |
||||||
<% } %> |
<% } %> |
||||||
|
Loading…
Reference in new issue