2021-02-27 23:14:41 +01:00
|
|
|
$.fn.exponentialInput = function() {
|
2021-02-28 15:51:07 +01:00
|
|
|
var prefixes = {
|
|
|
|
'K': 3,
|
|
|
|
'M': 6,
|
|
|
|
'G': 9,
|
|
|
|
'T': 12
|
2021-02-27 22:30:48 +01:00
|
|
|
};
|
|
|
|
|
2021-02-27 22:15:19 +01:00
|
|
|
this.each(function(){
|
|
|
|
var $group = $(this);
|
|
|
|
var currentExponent = 0;
|
2021-02-27 23:14:41 +01:00
|
|
|
var $input = $group.find('input');
|
2021-02-27 22:15:19 +01:00
|
|
|
|
|
|
|
var setExponent = function() {
|
|
|
|
var newExponent = parseInt($exponent.val());
|
|
|
|
var delta = currentExponent - newExponent;
|
2021-02-27 23:21:14 +01:00
|
|
|
if (delta >= 0) {
|
|
|
|
$input.val(parseFloat($input.val()) * 10 ** delta);
|
|
|
|
} else {
|
|
|
|
// should not be necessary to handle this separately, but floating point precision in javascript
|
|
|
|
// does not handle this well otherwise
|
|
|
|
$input.val(parseFloat($input.val()) / 10 ** -delta);
|
|
|
|
}
|
2021-02-27 22:15:19 +01:00
|
|
|
currentExponent = newExponent;
|
|
|
|
};
|
|
|
|
|
2021-02-27 22:30:48 +01:00
|
|
|
$input.on('keydown', function(e) {
|
|
|
|
var c = String.fromCharCode(e.which);
|
2021-02-28 15:51:07 +01:00
|
|
|
if (c in prefixes) {
|
|
|
|
currentExponent = prefixes[c];
|
|
|
|
$exponent.val(prefixes[c]);
|
2021-02-27 22:30:48 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2021-02-27 23:14:41 +01:00
|
|
|
var $exponent = $group.find('select.exponent');
|
2021-02-27 22:15:19 +01:00
|
|
|
$exponent.on('change', setExponent);
|
|
|
|
|
|
|
|
// calculate initial exponent
|
2021-02-27 22:43:18 +01:00
|
|
|
var value = parseFloat($input.val());
|
|
|
|
if (!Number.isNaN(value)) {
|
2021-05-17 15:08:44 +02:00
|
|
|
$exponent.val(Math.floor(Math.log10(Math.abs(value)) / 3) * 3);
|
2021-02-27 22:43:18 +01:00
|
|
|
setExponent();
|
|
|
|
}
|
2021-02-27 22:15:19 +01:00
|
|
|
})
|
|
|
|
};
|