@kre-form/ionic
Version:
220 lines • 19.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Input, ContentChild, Directive, Renderer2, ElementRef, } from "@angular/core";
import { Platform, IonText } from "@ionic/angular";
import * as _ from "lodash";
var IonKreFormFloat = /** @class */ (function () {
function IonKreFormFloat(el, renderer, plt) {
this.el = el;
this.plt = plt;
this.selectedColor = "";
this.decimalNumber = -1; // 保留小数位数,默认不限制
// 保留小数位数,默认不限制
this.max = 6;
this.floattype = "base"; // 固定整数取6位 base:兼容除流程外的数字精度显示,为base表示整数固定取6位
// 固定整数取6位 base:兼容除流程外的数字精度显示,为base表示整数固定取6位
this.allowminus = true; // 允许负数 -true 允许 -false 不允许
this.isblur = false;
}
/**
* @param {?} e
* @return {?}
*/
IonKreFormFloat.prototype.onfocus = /**
* @param {?} e
* @return {?}
*/
function (e) {
this.isblur = false;
};
/**
* @param {?} e
* @return {?}
*/
IonKreFormFloat.prototype.onBlur = /**
* @param {?} e
* @return {?}
*/
function (e) {
this.isblur = true;
if (e.currentTarget.value !== "" && !isNaN(e.currentTarget.value)) {
/** @type {?} */
var val = e.currentTarget.value;
if (this.decimalNumber > -1) {
val = Number(e.currentTarget.value).toFixed(this.decimalNumber);
}
e.currentTarget.value = val;
}
else {
e.currentTarget.value = "";
}
};
/**
* @param {?} event
* @return {?}
*/
IonKreFormFloat.prototype.onModelChange = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (this.isblur)
return;
var value = event.detail.value;
if (value === 0)
value = "";
if (!_.isNumber(value)) {
event.currentTarget.value = value;
}
else {
event.currentTarget.value = value = this.checkValue(value);
}
};
/**
* @param {?} event
* @return {?}
*/
IonKreFormFloat.prototype.checkValue = /**
* @param {?} event
* @return {?}
*/
function (event) {
/** @type {?} */
var oldValue = event;
/** @type {?} */
var mark = "";
if (this.allowminus) {
mark = event.charAt(0);
}
if (this.decimalNumber === 0) {
if (_.isNumber(oldValue)) {
oldValue = Number(oldValue).toFixed(0); // 保留整数
}
else {
// oldValue = oldValue;
}
}
else {
oldValue = oldValue.replace(/[^\d\.]/g, ""); // 清除"数字"和"."以外的字符
}
/** @type {?} */
var newValue = "";
if (oldValue === ".") {
newValue = "";
}
else if (oldValue.indexOf(".") >= 0) {
if (this.floattype !== "base") {
/** @type {?} */
var index = event.indexOf(".");
/** @type {?} */
var opintInLast = event.lastIndexOf(".") === event.length - 1;
/** @type {?} */
var totlaLength = index !== -1 && !opintInLast ? this.max + 1 : this.max;
event = totlaLength > 0 ? event.substr(0, totlaLength) : event;
oldValue = oldValue.split(".");
oldValue.length = 2;
/** @type {?} */
var floatLength = oldValue[1] ? oldValue[1].length : 0;
floatLength =
floatLength > this.decimalNumber ? this.decimalNumber : floatLength;
/** @type {?} */
var intPart = this.max > 0
? oldValue[0].substr(0, this.max - floatLength)
: oldValue[0];
if (this.decimalNumber === 0 || intPart.length >= this.max) {
newValue = String(Math.abs(Number(intPart)));
}
else {
/** @type {?} */
var floatPart = floatLength
? oldValue[1].substr(0, floatLength)
: oldValue[1].substr(0, 3);
newValue = String(Math.abs(Number(intPart)) + "." + floatPart);
}
}
else {
if (this.decimalNumber > 0) {
newValue =
oldValue.split(".")[0].substr(0, 6) +
"." +
oldValue.split(".")[1].substr(0, this.decimalNumber);
}
else {
newValue =
oldValue.split(".")[0].substr(0, 6) +
"." +
oldValue.split(".")[1].substr(0);
}
}
}
else {
if (this.floattype !== "base") {
newValue = oldValue.substr(0, this.max);
}
else {
newValue = oldValue.substr(0, 6);
}
}
if (String(newValue).substr(0, 1) === "0" &&
String(newValue).substr(1, 1) !== ".") {
newValue = "0";
}
if (this.allowminus && mark === "-") {
event = "" + mark + newValue;
newValue = "" + mark + newValue;
}
else {
event = newValue;
}
return event;
};
IonKreFormFloat.decorators = [
{ type: Directive, args: [{
selector: "[ionKreFormFloat]",
host: {
"(ionBlur)": "onBlur($event)",
"(ionChange)": "onModelChange($event)",
"(ionFocus)": "onfocus($event)",
},
},] }
];
/** @nocollapse */
IonKreFormFloat.ctorParameters = function () { return [
{ type: ElementRef },
{ type: Renderer2 },
{ type: Platform }
]; };
IonKreFormFloat.propDecorators = {
selectedColor: [{ type: Input }],
decimalNumber: [{ type: Input }],
max: [{ type: Input }],
floattype: [{ type: Input }],
allowminus: [{ type: Input }],
_ionInput: [{ type: ContentChild, args: [IonText, { static: false },] }]
};
return IonKreFormFloat;
}());
export { IonKreFormFloat };
if (false) {
/** @type {?} */
IonKreFormFloat.prototype.selectedColor;
/** @type {?} */
IonKreFormFloat.prototype.decimalNumber;
/** @type {?} */
IonKreFormFloat.prototype.max;
/** @type {?} */
IonKreFormFloat.prototype.floattype;
/** @type {?} */
IonKreFormFloat.prototype.allowminus;
/** @type {?} */
IonKreFormFloat.prototype._ionInput;
/** @type {?} */
IonKreFormFloat.prototype.isblur;
/** @type {?} */
IonKreFormFloat.prototype.el;
/** @type {?} */
IonKreFormFloat.prototype.plt;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kre-form.float.js","sourceRoot":"ng://@kre-form/ionic/","sources":["lib/kre-form.float.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Input,\n  ContentChild,\n  Directive,\n  Renderer2,\n  ElementRef,\n} from \"@angular/core\";\nimport { Platform, IonText } from \"@ionic/angular\";\nimport * as _ from \"lodash\";\n\n@Directive({\n  selector: \"[ionKreFormFloat]\",\n  host: {\n    \"(ionBlur)\": \"onBlur($event)\",\n    \"(ionChange)\": \"onModelChange($event)\",\n    \"(ionFocus)\": \"onfocus($event)\",\n  },\n})\nexport class IonKreFormFloat {\n  @Input() selectedColor = \"\";\n  @Input() decimalNumber = -1; // 保留小数位数,默认不限制\n  @Input() max = 6;\n  @Input() floattype = \"base\"; // 固定整数取6位 base:兼容除流程外的数字精度显示，为base表示整数固定取6位\n  @Input() allowminus = true; // 允许负数  -true 允许 -false 不允许\n  @ContentChild(IonText, { static: false }) _ionInput: IonText;\n  isblur = false;\n\n  constructor(\n    public el: ElementRef,\n    renderer: Renderer2,\n    public plt: Platform\n  ) {}\n  onfocus(e) {\n    this.isblur = false;\n  }\n  onBlur(e) {\n    this.isblur = true;\n\n    if (e.currentTarget.value !== \"\" && !isNaN(e.currentTarget.value)) {\n      let val: any = e.currentTarget.value;\n\n      if (this.decimalNumber > -1) {\n        val = Number(e.currentTarget.value).toFixed(this.decimalNumber);\n      }\n      e.currentTarget.value = val;\n    } else {\n      e.currentTarget.value = \"\";\n    }\n  }\n  onModelChange(event) {\n    if (this.isblur) return;\n    let { value } = event.detail;\n    if (value === 0) value = \"\";\n    if (!_.isNumber(value)) {\n      event.currentTarget.value = value;\n    } else {\n      event.currentTarget.value = value = this.checkValue(value);\n    }\n  }\n  checkValue(event) {\n    let oldValue = event;\n    let mark = \"\";\n    if (this.allowminus) {\n      mark = event.charAt(0);\n    }\n    if (this.decimalNumber === 0) {\n      if (_.isNumber(oldValue)) {\n        oldValue = Number(oldValue).toFixed(0); //  保留整数\n      } else {\n        // oldValue = oldValue;\n      }\n    } else {\n      oldValue = oldValue.replace(/[^\\d\\.]/g, \"\"); // 清除\"数字\"和\".\"以外的字符\n    }\n    let newValue: any = \"\";\n\n    if (oldValue === \".\") {\n      newValue = \"\";\n    } else if (oldValue.indexOf(\".\") >= 0) {\n      if (this.floattype !== \"base\") {\n        const index = event.indexOf(\".\");\n        const opintInLast = event.lastIndexOf(\".\") === event.length - 1;\n        const totlaLength =\n          index !== -1 && !opintInLast ? this.max + 1 : this.max;\n        event = totlaLength > 0 ? event.substr(0, totlaLength) : event;\n\n        oldValue = oldValue.split(\".\");\n        oldValue.length = 2;\n        let floatLength = oldValue[1] ? oldValue[1].length : 0;\n        floatLength =\n          floatLength > this.decimalNumber ? this.decimalNumber : floatLength;\n        const intPart =\n          this.max > 0\n            ? oldValue[0].substr(0, this.max - floatLength)\n            : oldValue[0];\n\n        if (this.decimalNumber === 0 || intPart.length >= this.max) {\n          newValue = String(Math.abs(Number(intPart)));\n        } else {\n          const floatPart = floatLength\n            ? oldValue[1].substr(0, floatLength)\n            : oldValue[1].substr(0, 3);\n          newValue = String(Math.abs(Number(intPart)) + \".\" + floatPart);\n        }\n      } else {\n        if (this.decimalNumber > 0) {\n          newValue =\n            oldValue.split(\".\")[0].substr(0, 6) +\n            \".\" +\n            oldValue.split(\".\")[1].substr(0, this.decimalNumber);\n        } else {\n          newValue =\n            oldValue.split(\".\")[0].substr(0, 6) +\n            \".\" +\n            oldValue.split(\".\")[1].substr(0);\n        }\n      }\n    } else {\n      if (this.floattype !== \"base\") {\n        newValue = oldValue.substr(0, this.max);\n      } else {\n        newValue = oldValue.substr(0, 6);\n      }\n    }\n    if (\n      String(newValue).substr(0, 1) === \"0\" &&\n      String(newValue).substr(1, 1) !== \".\"\n    ) {\n      newValue = \"0\";\n    }\n    if (this.allowminus && mark === \"-\") {\n      event = `${mark}${newValue}`;\n      newValue = `${mark}${newValue}`;\n    } else {\n      event = newValue;\n    }\n    return event;\n  }\n}\n"]}