diff --git a/ignite-html-input.js b/ignite-html-input.js index 3d3ed70..b1ce5ee 100644 --- a/ignite-html-input.js +++ b/ignite-html-input.js @@ -29,6 +29,35 @@ import { IgniteTemplate } from "../ignite-html/ignite-template.js"; return this; } +/** + * Forces an input to only allow digits and periods for an input. + * @param {Number} max Max number of digits allowed to be inputed. Default is -1 which disables this feature. + * @returns {IgniteTemplate} This ignite template. + */ +IgniteTemplate.prototype.inputNumber = function(max = -1) { + this.on("keydown", e => { + //If the input key isn't a digit, and it's not a backspace or escape or tab, ignore it. + if ((e.key < '0' || e.key > '9') && e.key != 'Backspace' && e.key != 'Escape' && e.key != 'Tab' && e.key != 'Control' && e.ctrlKey == false && e.key != '.') { + e.preventDefault(); + return false; + } else { + //If we reached the max and the key isn't a special one then block this. + if (max != -1 && e.target.value.length >= max && e.key != 'Backspace' && e.key != 'Escape' && e.key != 'Tab' && e.key != 'Control' && e.ctrlKey == false) { + e.preventDefault(); + return false; + } + //If the control key is down, and it's not ctrl-a or ctrl-c or ctrl-v or ctrl-r then prevent + else if (e.ctrlKey && e.key != 'a' && e.key != 'c' && e.key != 'v' && e.key != 'R' && e.key != 'r') + { + e.preventDefault(); + return false; + } + } + }); + + return this; +} + /** * Forces an input to only allow letters for input. * @param {Number} max Max number of letters allow to be inputed. Default is -1 which disables this feature.