You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Works great but only with int on step value, if you want to use float values can us this:
/* ========================================================================
* bootstrap-spin - v1.0
* https://github.com/wpic/bootstrap-spin
* ========================================================================
* Copyright 2014 WPIC, Hamed Abdollahpour
*
* ========================================================================
* 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 ( $ ) {
$.fn.bootstrapNumber = function( options ) {
var settings = $.extend({
upClass: 'default',
downClass: 'default',
upText: '+',
downText: '-',
center: true
}, options );
return this.each(function(e) {
var self = $(this);
var clone = self.clone();
var min = self.attr('min');
var max = self.attr('max');
var step = parseFloat(self.attr('step')) || 1;
var dec = decimalPlaces(step);
function setText(n) {
if (isNaN(n) || (min && n < min) || (max && n > max)) {
return false;
}
if($.isNumeric(n)){ // it is a number
n = +n.toFixed(dec);
} else{
// not a number
return false;
}
clone.focus().val(n);
clone.trigger('change');
return true;
}
var group = $("<div class='input-group'></div>");
var down = $("<button type='button'>" + settings.downText + "</button>").attr('class', 'btn btn-' + settings.downClass).click(function() {
setText(parseFloat((clone.val() || clone.attr('min'))) - step);
});
var up = $("<button type='button'>" + settings.upText + "</button>").attr('class', 'btn btn-' + settings.upClass).click(function() {
setText(parseFloat((clone.val() || clone.attr('min'))) + step);
});
$("<span class='input-group-btn'></span>").append(down).appendTo(group);
clone.appendTo(group);
if(clone && settings.center) {
clone.css('text-align', 'center');
}
$("<span class='input-group-btn'></span>").append(up).appendTo(group);
// remove spins from original
clone.prop('type', 'text').keydown(function(e) {
if ($.inArray(e.keyCode, [46, 8, 9, 27, 13, 110, 190]) !== -1 ||
(e.keyCode == 65 && e.ctrlKey === true) ||
(e.keyCode >= 35 && e.keyCode <= 39)) {
return;
}
if ((e.shiftKey || (e.keyCode < 48 || e.keyCode > 57)) && (e.keyCode < 96 || e.keyCode > 105)) {
e.preventDefault();
}
var c = String.fromCharCode(e.which);
var n = parseInt(clone.val() + c);
if ((min && n < min) || (max && n > max)) {
e.preventDefault();
}
});
self.replaceWith(group);
});
};
decimalPlaces = function(num) {
var match = (''+num).match(/(?:\.(\d+))?(?:[eE]([+-]?\d+))?$/);
if (!match) { return 0; }
return Math.max(
0,
// Number of digits right of decimal point.
(match[1] ? match[1].length : 0)
// Adjust for scientific notation.
- (match[2] ? +match[2] : 0));
};
} ( jQuery ));
I use min value when is no value, because if you take value att this can be out of range.
Thanks!
The text was updated successfully, but these errors were encountered:
Is there another problem... when you write directly a value out of range. buttons not work again. Could you please explain me, how can I use change event to call setText function?
Works great but only with int on step value, if you want to use float values can us this:
I use min value when is no value, because if you take value att this can be out of range.
Thanks!
The text was updated successfully, but these errors were encountered: