UNPKG

@kre-form/ionic

Version:

207 lines 19.1 kB
/** * @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"; export class IonKreFormFloat { /** * @param {?} el * @param {?} renderer * @param {?} plt */ constructor(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 {?} */ onfocus(e) { this.isblur = false; } /** * @param {?} e * @return {?} */ onBlur(e) { this.isblur = true; if (e.currentTarget.value !== "" && !isNaN(e.currentTarget.value)) { /** @type {?} */ let 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 {?} */ onModelChange(event) { if (this.isblur) return; let { value } = event.detail; if (value === 0) value = ""; if (!_.isNumber(value)) { event.currentTarget.value = value; } else { event.currentTarget.value = value = this.checkValue(value); } } /** * @param {?} event * @return {?} */ checkValue(event) { /** @type {?} */ let oldValue = event; /** @type {?} */ let 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 {?} */ let newValue = ""; if (oldValue === ".") { newValue = ""; } else if (oldValue.indexOf(".") >= 0) { if (this.floattype !== "base") { /** @type {?} */ const index = event.indexOf("."); /** @type {?} */ const opintInLast = event.lastIndexOf(".") === event.length - 1; /** @type {?} */ const totlaLength = index !== -1 && !opintInLast ? this.max + 1 : this.max; event = totlaLength > 0 ? event.substr(0, totlaLength) : event; oldValue = oldValue.split("."); oldValue.length = 2; /** @type {?} */ let floatLength = oldValue[1] ? oldValue[1].length : 0; floatLength = floatLength > this.decimalNumber ? this.decimalNumber : floatLength; /** @type {?} */ const 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 {?} */ const 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 = () => [ { 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 },] }] }; 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"]}