@alauda/ui 6.4.8-beta.22 → 6.4.8-beta.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/input/number-input/number-input.component.mjs +5 -3
- package/fesm2015/alauda-ui.mjs +4 -2
- package/fesm2015/alauda-ui.mjs.map +1 -1
- package/fesm2020/alauda-ui.mjs +4 -2
- package/fesm2020/alauda-ui.mjs.map +1 -1
- package/input/number-input/number-input.component.d.ts +3 -2
- package/package.json +1 -1
|
@@ -23,11 +23,13 @@ export class NumberInputComponent extends CommonFormControl {
|
|
|
23
23
|
this.angleControls = false;
|
|
24
24
|
this.isFocus = false;
|
|
25
25
|
}
|
|
26
|
-
|
|
27
|
-
this.inputRef.nativeElement.value = (this.model ?? '') + '';
|
|
26
|
+
ngAfterContentInit() {
|
|
28
27
|
this.hasAddonBefore$ = watchContentExist(this.addonBeforeRefs);
|
|
29
28
|
this.hasAddonAfter$ = watchContentExist(this.addonAfterRefs);
|
|
30
29
|
}
|
|
30
|
+
ngAfterViewInit() {
|
|
31
|
+
this.inputRef.nativeElement.value = (this.model ?? '') + '';
|
|
32
|
+
}
|
|
31
33
|
valueIn(v) {
|
|
32
34
|
if (this.inputRef) {
|
|
33
35
|
this.inputRef.nativeElement.value = (v ?? '') + '';
|
|
@@ -103,4 +105,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
103
105
|
type: ContentChildren,
|
|
104
106
|
args: [InputAddonAfterDirective]
|
|
105
107
|
}] } });
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-input.component.js","sourceRoot":"","sources":["../../../../src/input/number-input/number-input.component.ts","../../../../src/input/number-input/number-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,KAAK,EACL,SAAS,EACT,iBAAiB,EACjB,UAAU,EACV,eAAe,GAEhB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAGnD,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAO,QAAQ,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAC7E,OAAO,EACL,wBAAwB,EACxB,yBAAyB,GAC1B,MAAM,sBAAsB,CAAC;;;;;;AAiB9B,MAAM,OAAO,oBACX,SAAQ,iBAAyB;IAhBnC;;QAmBE,QAAG,GAAQ,QAAQ,CAAC,kBAAkB,CAAC,CAAC;QAGxC,SAAI,GAAkB,aAAa,CAAC,MAAM,CAAC;QAG3C,QAAG,GAAoB,MAAM,CAAC,gBAAgB,CAAC;QAG/C,QAAG,GAAoB,MAAM,CAAC,gBAAgB,CAAC;QAG/C,SAAI,GAAG,CAAC,CAAC;QAMT,aAAQ,GAAG,IAAI,CAAC;QAGhB,gBAAW,GAAG,EAAE,CAAC;QAGjB,qBAAgB,GAAG,EAAE,CAAC;QAGtB,kBAAa,GAAG,KAAK,CAAC;QAWtB,YAAO,GAAG,KAAK,CAAC;KAkDjB;IA7CC,eAAe;QACb,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE,CAAC,GAAG,EAAE,CAAC;QAC5D,IAAI,CAAC,eAAe,GAAG,iBAAiB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAC/D,IAAI,CAAC,cAAc,GAAG,iBAAiB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAC/D,CAAC;IAEQ,OAAO,CAAC,CAAS;QACxB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,EAAE,CAAC;SACpD;QACD,OAAO,CAAC,CAAC;IACX,CAAC;IAEQ,QAAQ,CAAC,KAAa;QAC7B,OAAO,IAAI,CAAC,GAAG,CACb,YAAY,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,CAAC,gBAAgB,CAAC,EAC/C,IAAI,CAAC,GAAG,CACN,YAAY,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,CAAC,gBAAgB,CAAC,EAC/C,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAC3B,CACF,CAAC;IACJ,CAAC;IAED,YAAY,CAAC,KAAa;QACxB,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IAClD,CAAC;IAED,WAAW,CAAC,QAAiB;QAC3B,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;SAC/C;aAAM;YACL,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;SAC/C;IACH,CAAC;IAEO,cAAc,CAAC,KAAa;QAClC,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC5D,OAAO,UAAU,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC;IAC9C,CAAC;IAEO,gBAAgB;QACtB,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QAC5B,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAChC,OAAO,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC;IACtD,CAAC;;iHA3FU,oBAAoB;qGAApB,oBAAoB,2PARpB;QACT;YACE,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,oBAAoB,CAAC;YACnD,KAAK,EAAE,IAAI;SACZ;KACF,0DAsCgB,yBAAyB,iDAGzB,wBAAwB,8GANV,UAAU,oDCvE3C,85EAmFA;2FD7Ca,oBAAoB;kBAfhC,SAAS;+BACE,kBAAkB,mBAGX,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,uBAChB,KAAK,aACf;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,qBAAqB,CAAC;4BACnD,KAAK,EAAE,IAAI;yBACZ;qBACF;8BASD,IAAI;sBADH,KAAK;gBAIN,GAAG;sBADF,KAAK;gBAIN,GAAG;sBADF,KAAK;gBAIN,IAAI;sBADH,KAAK;gBAIN,SAAS;sBADR,KAAK;gBAIN,QAAQ;sBADP,KAAK;gBAIN,WAAW;sBADV,KAAK;gBAIN,gBAAgB;sBADf,KAAK;gBAIN,aAAa;sBADZ,KAAK;gBAIN,QAAQ;sBADP,SAAS;uBAAC,UAAU,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBAI1B,eAAe;sBAD/B,eAAe;uBAAC,yBAAyB;gBAIzB,cAAc;sBAD9B,eAAe;uBAAC,wBAAwB","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n  ContentChildren,\n  QueryList,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Observable } from 'rxjs';\n\nimport { CommonFormControl } from '../../form';\nimport { ComponentSize } from '../../types';\nimport { Bem, buildBem, coerceNumber, watchContentExist } from '../../utils';\nimport {\n  InputAddonAfterDirective,\n  InputAddonBeforeDirective,\n} from '../helper-directives';\n\n@Component({\n  selector: 'aui-number-input',\n  templateUrl: './number-input.component.html',\n  styleUrls: ['./number-input.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => NumberInputComponent),\n      multi: true,\n    },\n  ],\n})\nexport class NumberInputComponent\n  extends CommonFormControl<number>\n  implements AfterViewInit\n{\n  bem: Bem = buildBem('aui-number-input');\n\n  @Input()\n  size: ComponentSize = ComponentSize.Medium;\n\n  @Input()\n  min: string | number = Number.MIN_SAFE_INTEGER;\n\n  @Input()\n  max: string | number = Number.MAX_SAFE_INTEGER;\n\n  @Input()\n  step = 1;\n\n  @Input()\n  precision: number;\n\n  @Input()\n  controls = true;\n\n  @Input()\n  placeholder = '';\n\n  @Input()\n  controlsPosition = '';\n\n  @Input()\n  angleControls = false;\n\n  @ViewChild('inputRef', { read: ElementRef })\n  inputRef: ElementRef<HTMLInputElement>;\n\n  @ContentChildren(InputAddonBeforeDirective)\n  private readonly addonBeforeRefs: QueryList<InputAddonBeforeDirective>;\n\n  @ContentChildren(InputAddonAfterDirective)\n  private readonly addonAfterRefs: QueryList<InputAddonAfterDirective>;\n\n  isFocus = false;\n\n  hasAddonBefore$: Observable<boolean>;\n  hasAddonAfter$: Observable<boolean>;\n\n  ngAfterViewInit() {\n    this.inputRef.nativeElement.value = (this.model ?? '') + '';\n    this.hasAddonBefore$ = watchContentExist(this.addonBeforeRefs);\n    this.hasAddonAfter$ = watchContentExist(this.addonAfterRefs);\n  }\n\n  override valueIn(v: number) {\n    if (this.inputRef) {\n      this.inputRef.nativeElement.value = (v ?? '') + '';\n    }\n    return v;\n  }\n\n  override modelOut(value: number) {\n    return Math.max(\n      coerceNumber(this.min, Number.MIN_SAFE_INTEGER),\n      Math.min(\n        coerceNumber(this.max, Number.MAX_SAFE_INTEGER),\n        this.parsePrecision(value),\n      ),\n    );\n  }\n\n  inputChanged(value: string) {\n    this.emitModel(coerceNumber(value, this.model));\n  }\n\n  takeOneStep(positive: boolean) {\n    if (positive) {\n      this.emitModel((this.model ?? 0) + this.step);\n    } else {\n      this.emitModel((this.model ?? 0) - this.step);\n    }\n  }\n\n  private parsePrecision(value: number) {\n    const precision = this.precision ?? this.getStepPrecision();\n    return parseFloat(value.toFixed(precision));\n  }\n\n  private getStepPrecision() {\n    const step = this.step + '';\n    const index = step.indexOf('.');\n    return index < 0 ? 0 : step.slice(index + 1).length;\n  }\n}\n","<div [class]=\"bem.element('inner-wrapper')\">\n  <div\n    *ngIf=\"hasAddonBefore$ | async\"\n    [class]=\"bem.element('addon', 'before')\"\n  >\n    <ng-content select=\"[auiInputAddonBefore]\"></ng-content>\n  </div>\n  <div\n    [class]=\"bem.block(size)\"\n    [ngClass]=\"{\n      isFocus: isFocus,\n      isDisabled: disabled,\n      hasBefore: hasAddonBefore$ | async,\n      hasAfter: hasAddonAfter$ | async\n    }\"\n    auiClickOutside\n    (auiClickOutside)=\"isFocus = false\"\n  >\n    <button\n      *ngIf=\"controls && !angleControls\"\n      aui-button\n      type=\"button\"\n      [ngClass]=\"bem.element('decrease')\"\n      [disabled]=\"disabled || model <= min\"\n      (click)=\"takeOneStep(false); isFocus = true\"\n    >\n      <aui-icon icon=\"minus\"></aui-icon>\n    </button>\n    <input\n      #inputRef\n      autocomplete=\"off\"\n      (change)=\"inputChanged($any($event).target.value)\"\n      [disabled]=\"disabled\"\n      [ngClass]=\"bem.element('input')\"\n      [placeholder]=\"placeholder\"\n      (focus)=\"isFocus = true\"\n      (blur)=\"isFocus = false\"\n      [ngStyle]=\"{ 'text-align': angleControls ? 'left' : 'center' }\"\n    />\n    <button\n      *ngIf=\"controls && !angleControls\"\n      aui-button\n      type=\"button\"\n      [ngClass]=\"bem.element('increase')\"\n      [disabled]=\"disabled || model >= max\"\n      (click)=\"takeOneStep(true); isFocus = true\"\n    >\n      <aui-icon icon=\"plus\"></aui-icon>\n    </button>\n    <div\n      *ngIf=\"controls && angleControls\"\n      class=\"aui-angle-container\"\n    >\n      <button\n        aui-button\n        type=\"button\"\n        size=\"mini\"\n        [ngClass]=\"bem.element('angleIncrease')\"\n        [disabled]=\"disabled || model >= max\"\n        (click)=\"takeOneStep(true); isFocus = true\"\n      >\n        <aui-icon icon=\"angle_up\"></aui-icon>\n      </button>\n      <div class=\"separation\"></div>\n      <button\n        aui-button\n        type=\"button\"\n        size=\"mini\"\n        [ngClass]=\"bem.element('angleDecrease')\"\n        [disabled]=\"disabled || model <= min\"\n        (click)=\"takeOneStep(false); isFocus = true\"\n      >\n        <aui-icon icon=\"angle_down\"></aui-icon>\n      </button>\n    </div>\n  </div>\n  <div\n    *ngIf=\"hasAddonAfter$ | async\"\n    [class]=\"bem.element('addon', 'after')\"\n  >\n    <ng-content select=\"[auiInputAddonAfter]\"></ng-content>\n  </div>\n</div>\n"]}
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-input.component.js","sourceRoot":"","sources":["../../../../src/input/number-input/number-input.component.ts","../../../../src/input/number-input/number-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n  ContentChildren,\n  QueryList,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Observable } from 'rxjs';\n\nimport { CommonFormControl } from '../../form';\nimport { ComponentSize } from '../../types';\nimport { Bem, buildBem, coerceNumber, watchContentExist } from '../../utils';\nimport {\n  InputAddonAfterDirective,\n  InputAddonBeforeDirective,\n} from '../helper-directives';\n\n@Component({\n  selector: 'aui-number-input',\n  templateUrl: './number-input.component.html',\n  styleUrls: ['./number-input.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => NumberInputComponent),\n      multi: true,\n    },\n  ],\n})\nexport class NumberInputComponent\n  extends CommonFormControl<number>\n  implements AfterContentInit, AfterViewInit\n{\n  bem: Bem = buildBem('aui-number-input');\n\n  @Input()\n  size: ComponentSize = ComponentSize.Medium;\n\n  @Input()\n  min: string | number = Number.MIN_SAFE_INTEGER;\n\n  @Input()\n  max: string | number = Number.MAX_SAFE_INTEGER;\n\n  @Input()\n  step = 1;\n\n  @Input()\n  precision: number;\n\n  @Input()\n  controls = true;\n\n  @Input()\n  placeholder = '';\n\n  @Input()\n  controlsPosition = '';\n\n  @Input()\n  angleControls = false;\n\n  @ViewChild('inputRef', { read: ElementRef })\n  inputRef: ElementRef<HTMLInputElement>;\n\n  @ContentChildren(InputAddonBeforeDirective)\n  private readonly addonBeforeRefs: QueryList<InputAddonBeforeDirective>;\n\n  @ContentChildren(InputAddonAfterDirective)\n  private readonly addonAfterRefs: QueryList<InputAddonAfterDirective>;\n\n  isFocus = false;\n\n  hasAddonBefore$: Observable<boolean>;\n  hasAddonAfter$: Observable<boolean>;\n\n  ngAfterContentInit() {\n    this.hasAddonBefore$ = watchContentExist(this.addonBeforeRefs);\n    this.hasAddonAfter$ = watchContentExist(this.addonAfterRefs);\n  }\n\n  ngAfterViewInit() {\n    this.inputRef.nativeElement.value = (this.model ?? '') + '';\n  }\n\n  override valueIn(v: number) {\n    if (this.inputRef) {\n      this.inputRef.nativeElement.value = (v ?? '') + '';\n    }\n    return v;\n  }\n\n  override modelOut(value: number) {\n    return Math.max(\n      coerceNumber(this.min, Number.MIN_SAFE_INTEGER),\n      Math.min(\n        coerceNumber(this.max, Number.MAX_SAFE_INTEGER),\n        this.parsePrecision(value),\n      ),\n    );\n  }\n\n  inputChanged(value: string) {\n    this.emitModel(coerceNumber(value, this.model));\n  }\n\n  takeOneStep(positive: boolean) {\n    if (positive) {\n      this.emitModel((this.model ?? 0) + this.step);\n    } else {\n      this.emitModel((this.model ?? 0) - this.step);\n    }\n  }\n\n  private parsePrecision(value: number) {\n    const precision = this.precision ?? this.getStepPrecision();\n    return parseFloat(value.toFixed(precision));\n  }\n\n  private getStepPrecision() {\n    const step = this.step + '';\n    const index = step.indexOf('.');\n    return index < 0 ? 0 : step.slice(index + 1).length;\n  }\n}\n","<div [class]=\"bem.element('inner-wrapper')\">\n  <div\n    *ngIf=\"hasAddonBefore$ | async\"\n    [class]=\"bem.element('addon', 'before')\"\n  >\n    <ng-content select=\"[auiInputAddonBefore]\"></ng-content>\n  </div>\n  <div\n    [class]=\"bem.block(size)\"\n    [ngClass]=\"{\n      isFocus: isFocus,\n      isDisabled: disabled,\n      hasBefore: hasAddonBefore$ | async,\n      hasAfter: hasAddonAfter$ | async\n    }\"\n    auiClickOutside\n    (auiClickOutside)=\"isFocus = false\"\n  >\n    <button\n      *ngIf=\"controls && !angleControls\"\n      aui-button\n      type=\"button\"\n      [ngClass]=\"bem.element('decrease')\"\n      [disabled]=\"disabled || model <= min\"\n      (click)=\"takeOneStep(false); isFocus = true\"\n    >\n      <aui-icon icon=\"minus\"></aui-icon>\n    </button>\n    <input\n      #inputRef\n      autocomplete=\"off\"\n      (change)=\"inputChanged($any($event).target.value)\"\n      [disabled]=\"disabled\"\n      [ngClass]=\"bem.element('input')\"\n      [placeholder]=\"placeholder\"\n      (focus)=\"isFocus = true\"\n      (blur)=\"isFocus = false\"\n      [ngStyle]=\"{ 'text-align': angleControls ? 'left' : 'center' }\"\n    />\n    <button\n      *ngIf=\"controls && !angleControls\"\n      aui-button\n      type=\"button\"\n      [ngClass]=\"bem.element('increase')\"\n      [disabled]=\"disabled || model >= max\"\n      (click)=\"takeOneStep(true); isFocus = true\"\n    >\n      <aui-icon icon=\"plus\"></aui-icon>\n    </button>\n    <div\n      *ngIf=\"controls && angleControls\"\n      class=\"aui-angle-container\"\n    >\n      <button\n        aui-button\n        type=\"button\"\n        size=\"mini\"\n        [ngClass]=\"bem.element('angleIncrease')\"\n        [disabled]=\"disabled || model >= max\"\n        (click)=\"takeOneStep(true); isFocus = true\"\n      >\n        <aui-icon icon=\"angle_up\"></aui-icon>\n      </button>\n      <div class=\"separation\"></div>\n      <button\n        aui-button\n        type=\"button\"\n        size=\"mini\"\n        [ngClass]=\"bem.element('angleDecrease')\"\n        [disabled]=\"disabled || model <= min\"\n        (click)=\"takeOneStep(false); isFocus = true\"\n      >\n        <aui-icon icon=\"angle_down\"></aui-icon>\n      </button>\n    </div>\n  </div>\n  <div\n    *ngIf=\"hasAddonAfter$ | async\"\n    [class]=\"bem.element('addon', 'after')\"\n  >\n    <ng-content select=\"[auiInputAddonAfter]\"></ng-content>\n  </div>\n</div>\n"]}
|
package/fesm2015/alauda-ui.mjs
CHANGED
|
@@ -4711,11 +4711,13 @@ class NumberInputComponent extends CommonFormControl {
|
|
|
4711
4711
|
this.angleControls = false;
|
|
4712
4712
|
this.isFocus = false;
|
|
4713
4713
|
}
|
|
4714
|
+
ngAfterContentInit() {
|
|
4715
|
+
this.hasAddonBefore$ = watchContentExist(this.addonBeforeRefs);
|
|
4716
|
+
this.hasAddonAfter$ = watchContentExist(this.addonAfterRefs);
|
|
4717
|
+
}
|
|
4714
4718
|
ngAfterViewInit() {
|
|
4715
4719
|
var _a;
|
|
4716
4720
|
this.inputRef.nativeElement.value = ((_a = this.model) !== null && _a !== void 0 ? _a : '') + '';
|
|
4717
|
-
this.hasAddonBefore$ = watchContentExist(this.addonBeforeRefs);
|
|
4718
|
-
this.hasAddonAfter$ = watchContentExist(this.addonAfterRefs);
|
|
4719
4721
|
}
|
|
4720
4722
|
valueIn(v) {
|
|
4721
4723
|
if (this.inputRef) {
|