Angularjs Директива для форматирования номера
Мне нужна директива angularjs для привязки к полю ввода, которое имеет следующие особенности:
- Формат десятичный в виде #, ###
- Ограничить десятичные цифры
- Ограничьте введенные цифры
Если я хочу ограничить десятичные цифры до 2, а введенные цифры - до 8, то выходные данные должны иметь вид: 45 345 345,34
Директива:
App.directive('amountInput',function($filter) {
return {
restrict : 'AE',
scope : {
ngModel : '=ngModel',
limit:'=limit',
declimit:'=declimit',
},
link : function(scope, elem, attr, ctrl) {
scope.validateamount = function(e) {
var theEvent = e || window.event;
var key = theEvent.keyCode || theEvent.which;
if (theEvent.altKey || theEvent.ctrlKey ){
return;
}
if(theEvent.ctrlKey && key == 65 ){
return ;
}
if(key == 16 || key == 36 || key == 37 || key == 38 || key == 39 || key == 40 ) { // Left / Up / Right / Down Arrow, Backspace, Delete keys
return;
}
// Regular
var acceptChar = /^[|m|k|M|K|0-9,.]+$/gi;
var acceptNumDotComma = /^[0-9.,]+$/
var isCharHaveMnK = /\m|k/gi;
var enteredString = $("#"+scope.amountId).val();
var decimalString ;
var preCommaCount = enteredString.substring(0,cursorPostion).split(",").length-1;
enteredString = enteredString.replace(/,/g,"");
var lastChar = enteredString.charAt(enteredString.length-1);
if(lastChar.match(acceptChar)==null){
enteredString = enteredString.slice(0,-1)
}
if(enteredString.match(new RegExp('\\.','g'))!=null &&
enteredString.match(new RegExp('\\.','g')).length > 1){
var temp = enteredString;
enteredString = temp.substring(0, temp.indexOf("."));
decimalString = temp.substring(temp.indexOf(".")+1,temp.length);;
var Re = new RegExp("\\.","g");
decimalString = decimalString.replace(Re," ");
enteredString = enteredString+'.'+decimalString.trim();
}
if(enteredString.match(isCharHaveMnK) != null){
enteredString = enteredString.substring(0,enteredString.length-1);
var amount ;
if (lastChar == "m" || lastChar == "M") {
amount = (enteredString * 1000000);
} else if (lastChar == "k" || lastChar == "K") {
amount = (enteredString * 1000);
}
amount = Math.round(amount)
amount = amount+"";
cursorPostion = amount.length;
if(amount.length > scope.limit){
enteredString = enteredString.substring(0,scope.limit);
}else{
enteredString = amount;
}
}
//Dont accept char above the limit
decimalString = "";
if(enteredString.indexOf(".")!=-1){
var temp = enteredString;
enteredString = temp.substring(0, temp.indexOf("."));
decimalString = temp.substring(temp.indexOf("."),temp.length);;
}
if(enteredString.length > scope.limit){
enteredString = enteredString.substring(0,scope.limit);
}
//Remove Spl char from Decimal point
var res = decimalString.split("");
decimalString = "";
for(var i = 0 ; i < res.length;i++){
if(res[i] == "."){
decimalString = decimalString+res[i];
}else if(!isNaN(res[i]) && res[i]!=' ' ){
decimalString = decimalString+res[i];
}
}
if(scope.declimit==0){
decimalString="";
}else if(decimalString.length-1 > scope.declimit){
decimalString = decimalString.substring(0,parseInt(scope.declimit)+1);
}
res = enteredString.split("");
enteredString = "";
for(var i = 0 ; i < res.length;i++){
if(!isNaN(res[i]) && res[i]!=' '){
enteredString = enteredString+res[i];
}
}
var temp1 = scope.numberformatter(enteredString) +decimalString;
var prefixCommaCount = temp1.substring(0,cursorPostion).split(",").length-1;
var count= prefixCommaCount-preCommaCount ;
var suffixChar = temp1.substring(parseInt(cursorPostion)-count,temp1.length);
scope.numberformatter = function(obj){
if(obj!='0'){
return $.formatNumber(obj, {format:"#,###", locale:"us"});
}
return obj;
};
},
};
});