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"> |
||||
var rootUrl = '<%= $self->get_url('/'); %>'; |
||||
</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> |
||||
<% } %> |
||||
|
Loading…
Reference in new issue