UNPKG

@abgov/angular-components

Version:

Government of Alberta - UI components for Angular

259 lines 22.8 kB
import { CUSTOM_ELEMENTS_SCHEMA, Component, EventEmitter, Input, Output, forwardRef, booleanAttribute, numberAttribute, } from "@angular/core"; import { NG_VALUE_ACCESSOR } from "@angular/forms"; import * as i0 from "@angular/core"; export class GoabInputNumber { constructor() { this.type = "number"; this.textAlign = "right"; // Default to right for numbers this.value = null; this.onTrailingIconClick = new EventEmitter(); // Keep void type this.onFocus = new EventEmitter(); this.onBlur = new EventEmitter(); this.onKeyPress = new EventEmitter(); this.onChange = new EventEmitter(); this.handleTrailingIconClick = false; this.touched = false; } ngOnInit() { this.handleTrailingIconClick = this.onTrailingIconClick.observed; } _onTrailingIconClick(_) { if (this.handleTrailingIconClick) { this.onTrailingIconClick.emit(); } } _onChange(e) { this.markAsTouched(); const detail = e.detail; const stringValue = detail.value; let numericValue = null; if (stringValue !== null && stringValue.trim() !== "") { const parsed = parseFloat(stringValue); if (!isNaN(parsed)) { numericValue = parsed; } } this.value = numericValue; this.fcChange?.(numericValue); this.onChange.emit(detail); } _onKeyPress(e) { this.markAsTouched(); const detail = e.detail; this.onKeyPress.emit(detail); } _onFocus(e) { this.markAsTouched(); const detail = e.detail; this.onFocus.emit(detail); } _onBlur(e) { this.markAsTouched(); const detail = e.detail; this.onBlur.emit(detail); } markAsTouched() { if (!this.touched) { this.fcTouched?.(); this.touched = true; } } writeValue(value) { this.value = value === undefined ? null : value; } registerOnChange(fn) { this.fcChange = fn; } registerOnTouched(fn) { this.fcTouched = fn; } setDisabledState(isDisabled) { this.disabled = isDisabled; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: GoabInputNumber, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.3", type: GoabInputNumber, isStandalone: true, selector: "goab-input-number", inputs: { type: "type", name: "name", id: "id", debounce: ["debounce", "debounce", numberAttribute], disabled: ["disabled", "disabled", booleanAttribute], autoCapitalize: "autoCapitalize", placeholder: "placeholder", leadingIcon: "leadingIcon", trailingIcon: "trailingIcon", variant: "variant", focused: ["focused", "focused", booleanAttribute], readonly: ["readonly", "readonly", booleanAttribute], error: ["error", "error", booleanAttribute], width: "width", prefix: "prefix", suffix: "suffix", testId: "testId", ariaLabel: "ariaLabel", maxLength: ["maxLength", "maxLength", numberAttribute], min: "min", max: "max", step: ["step", "step", numberAttribute], ariaLabelledBy: "ariaLabelledBy", mt: "mt", mr: "mr", mb: "mb", ml: "ml", trailingIconAriaLabel: "trailingIconAriaLabel", textAlign: "textAlign", value: "value" }, outputs: { onTrailingIconClick: "onTrailingIconClick", onFocus: "onFocus", onBlur: "onBlur", onKeyPress: "onKeyPress", onChange: "onChange" }, providers: [ { provide: NG_VALUE_ACCESSOR, multi: true, // Use forwardRef with the new class name useExisting: forwardRef(() => GoabInputNumber), }, ], ngImport: i0, template: ` <goa-input [attr.type]="type" [attr.name]="name" [attr.focused]="focused" [attr.value]="value !== null ? value : ''" [attr.autocapitalize]="autoCapitalize" [attr.placeholder]="placeholder" [attr.leadingicon]="leadingIcon" [attr.trailingicon]="trailingIcon" [attr.variant]="variant" [disabled]="disabled" [attr.readonly]="readonly" [attr.error]="error" [attr.data-testid]="testId" [attr.width]="width" [attr.arialabel]="ariaLabel" [attr.arialabelledby]="ariaLabelledBy" [attr.min]="min" [attr.max]="max" [attr.step]="step" [attr.prefix]="prefix" [attr.suffix]="suffix" [attr.debounce]="debounce" [attr.maxlength]="maxLength" [attr.id]="id" [attr.mt]="mt" [attr.mr]="mr" [attr.mb]="mb" [attr.ml]="ml" [attr.handletrailingiconclick]="handleTrailingIconClick" [attr.textalign]="textAlign" (_trailingIconClick)="_onTrailingIconClick($event)" (_change)="_onChange($event)" (_focus)="_onFocus($event)" (_blur)="_onBlur($event)" (_keypress)="_onKeyPress($event)" [attr.trailingiconarialabel]="trailingIconAriaLabel" > <ng-content /> </goa-input> `, isInline: true }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: GoabInputNumber, decorators: [{ type: Component, args: [{ standalone: true, selector: "goab-input-number", template: ` <goa-input [attr.type]="type" [attr.name]="name" [attr.focused]="focused" [attr.value]="value !== null ? value : ''" [attr.autocapitalize]="autoCapitalize" [attr.placeholder]="placeholder" [attr.leadingicon]="leadingIcon" [attr.trailingicon]="trailingIcon" [attr.variant]="variant" [disabled]="disabled" [attr.readonly]="readonly" [attr.error]="error" [attr.data-testid]="testId" [attr.width]="width" [attr.arialabel]="ariaLabel" [attr.arialabelledby]="ariaLabelledBy" [attr.min]="min" [attr.max]="max" [attr.step]="step" [attr.prefix]="prefix" [attr.suffix]="suffix" [attr.debounce]="debounce" [attr.maxlength]="maxLength" [attr.id]="id" [attr.mt]="mt" [attr.mr]="mr" [attr.mb]="mb" [attr.ml]="ml" [attr.handletrailingiconclick]="handleTrailingIconClick" [attr.textalign]="textAlign" (_trailingIconClick)="_onTrailingIconClick($event)" (_change)="_onChange($event)" (_focus)="_onFocus($event)" (_blur)="_onBlur($event)" (_keypress)="_onKeyPress($event)" [attr.trailingiconarialabel]="trailingIconAriaLabel" > <ng-content /> </goa-input> `, schemas: [CUSTOM_ELEMENTS_SCHEMA], providers: [ { provide: NG_VALUE_ACCESSOR, multi: true, // Use forwardRef with the new class name useExisting: forwardRef(() => GoabInputNumber), }, ], }] }], propDecorators: { type: [{ type: Input }], name: [{ type: Input }], id: [{ type: Input }], debounce: [{ type: Input, args: [{ transform: numberAttribute }] }], disabled: [{ type: Input, args: [{ transform: booleanAttribute }] }], autoCapitalize: [{ type: Input }], placeholder: [{ type: Input }], leadingIcon: [{ type: Input }], trailingIcon: [{ type: Input }], variant: [{ type: Input }], focused: [{ type: Input, args: [{ transform: booleanAttribute }] }], readonly: [{ type: Input, args: [{ transform: booleanAttribute }] }], error: [{ type: Input, args: [{ transform: booleanAttribute }] }], width: [{ type: Input }], prefix: [{ type: Input }], suffix: [{ type: Input }], testId: [{ type: Input }], ariaLabel: [{ type: Input }], maxLength: [{ type: Input, args: [{ transform: numberAttribute }] }], min: [{ type: Input }], max: [{ type: Input }], step: [{ type: Input, args: [{ transform: numberAttribute }] }], ariaLabelledBy: [{ type: Input }], mt: [{ type: Input }], mr: [{ type: Input }], mb: [{ type: Input }], ml: [{ type: Input }], trailingIconAriaLabel: [{ type: Input }], textAlign: [{ type: Input }], value: [{ type: Input }], onTrailingIconClick: [{ type: Output }], onFocus: [{ type: Output }], onBlur: [{ type: Output }], onKeyPress: [{ type: Output }], onChange: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.js","sourceRoot":"","sources":["../../../../../../../libs/angular-components/src/lib/components/input-number/input-number.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  GoabIconType,\n  GoabInputAutoCapitalize,\n  GoabInputOnBlurDetail,\n  GoabInputOnChangeDetail,\n  GoabInputOnFocusDetail,\n  GoabInputOnKeyPressDetail,\n  GoabInputType,\n  Spacing,\n} from \"@abgov/ui-components-common\";\nimport {\n  CUSTOM_ELEMENTS_SCHEMA,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  forwardRef,\n  OnInit,\n  booleanAttribute,\n  numberAttribute,\n} from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\n@Component({\n  standalone: true,\n  selector: \"goab-input-number\",\n  template: `\n    <goa-input\n      [attr.type]=\"type\"\n      [attr.name]=\"name\"\n      [attr.focused]=\"focused\"\n      [attr.value]=\"value !== null ? value : ''\"\n      [attr.autocapitalize]=\"autoCapitalize\"\n      [attr.placeholder]=\"placeholder\"\n      [attr.leadingicon]=\"leadingIcon\"\n      [attr.trailingicon]=\"trailingIcon\"\n      [attr.variant]=\"variant\"\n      [disabled]=\"disabled\"\n      [attr.readonly]=\"readonly\"\n      [attr.error]=\"error\"\n      [attr.data-testid]=\"testId\"\n      [attr.width]=\"width\"\n      [attr.arialabel]=\"ariaLabel\"\n      [attr.arialabelledby]=\"ariaLabelledBy\"\n      [attr.min]=\"min\"\n      [attr.max]=\"max\"\n      [attr.step]=\"step\"\n      [attr.prefix]=\"prefix\"\n      [attr.suffix]=\"suffix\"\n      [attr.debounce]=\"debounce\"\n      [attr.maxlength]=\"maxLength\"\n      [attr.id]=\"id\"\n      [attr.mt]=\"mt\"\n      [attr.mr]=\"mr\"\n      [attr.mb]=\"mb\"\n      [attr.ml]=\"ml\"\n      [attr.handletrailingiconclick]=\"handleTrailingIconClick\"\n      [attr.textalign]=\"textAlign\"\n      (_trailingIconClick)=\"_onTrailingIconClick($event)\"\n      (_change)=\"_onChange($event)\"\n      (_focus)=\"_onFocus($event)\"\n      (_blur)=\"_onBlur($event)\"\n      (_keypress)=\"_onKeyPress($event)\"\n      [attr.trailingiconarialabel]=\"trailingIconAriaLabel\"\n    >\n      <ng-content />\n    </goa-input>\n  `,\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      multi: true,\n      // Use forwardRef with the new class name\n      useExisting: forwardRef(() => GoabInputNumber),\n    },\n  ],\n})\nexport class GoabInputNumber implements ControlValueAccessor, OnInit {\n  @Input() type: GoabInputType = \"number\";\n  @Input() name?: string;\n  @Input() id?: string;\n  @Input({ transform: numberAttribute }) debounce?: number;\n  @Input({ transform: booleanAttribute }) disabled?: boolean;\n  @Input() autoCapitalize?: GoabInputAutoCapitalize;\n  @Input() placeholder?: string;\n  @Input() leadingIcon?: GoabIconType;\n  @Input() trailingIcon?: GoabIconType;\n  @Input() variant?: string;\n  @Input({ transform: booleanAttribute }) focused?: boolean;\n  @Input({ transform: booleanAttribute }) readonly?: boolean;\n  @Input({ transform: booleanAttribute }) error?: boolean;\n  @Input() width?: string;\n  @Input() prefix?: string;\n  @Input() suffix?: string;\n  @Input() testId?: string;\n  @Input() ariaLabel?: string;\n  @Input({ transform: numberAttribute }) maxLength?: number;\n  @Input() min?: string | number;\n  @Input() max?: string | number;\n  @Input({ transform: numberAttribute }) step?: number;\n  @Input() ariaLabelledBy?: string;\n  @Input() mt?: Spacing;\n  @Input() mr?: Spacing;\n  @Input() mb?: Spacing;\n  @Input() ml?: Spacing;\n  @Input() trailingIconAriaLabel?: string;\n  @Input() textAlign?: \"left\" | \"right\" = \"right\"; // Default to right for numbers\n\n  @Input() value: number | null = null;\n\n  @Output() onTrailingIconClick = new EventEmitter<void>(); // Keep void type\n  @Output() onFocus = new EventEmitter<GoabInputOnFocusDetail>();\n  @Output() onBlur = new EventEmitter<GoabInputOnBlurDetail>();\n  @Output() onKeyPress = new EventEmitter<GoabInputOnKeyPressDetail>();\n  @Output() onChange = new EventEmitter<GoabInputOnChangeDetail>();\n\n  handleTrailingIconClick = false;\n\n  ngOnInit() {\n    this.handleTrailingIconClick = this.onTrailingIconClick.observed;\n  }\n\n  _onTrailingIconClick(_: Event) {\n    if (this.handleTrailingIconClick) {\n      this.onTrailingIconClick.emit();\n    }\n  }\n\n  _onChange(e: Event) {\n    this.markAsTouched();\n    const detail = (e as CustomEvent<GoabInputOnChangeDetail>).detail;\n\n    const stringValue = detail.value;\n    let numericValue: number | null = null;\n\n    if (stringValue !== null && stringValue.trim() !== \"\") {\n      const parsed = parseFloat(stringValue);\n      if (!isNaN(parsed)) {\n        numericValue = parsed;\n      }\n    }\n\n    this.value = numericValue;\n\n    this.fcChange?.(numericValue);\n\n    this.onChange.emit(detail);\n  }\n\n  _onKeyPress(e: Event) {\n    this.markAsTouched();\n    const detail = (e as CustomEvent<GoabInputOnKeyPressDetail>).detail;\n    this.onKeyPress.emit(detail);\n  }\n\n  _onFocus(e: Event) {\n    this.markAsTouched();\n    const detail = (e as CustomEvent<GoabInputOnFocusDetail>).detail;\n    this.onFocus.emit(detail);\n  }\n\n  _onBlur(e: Event) {\n    this.markAsTouched();\n    const detail = (e as CustomEvent<GoabInputOnBlurDetail>).detail;\n    this.onBlur.emit(detail);\n  }\n\n  private fcChange?: (value: number | null) => void;\n  private fcTouched?: () => void; // Changed type to void for consistency\n  touched = false;\n\n  markAsTouched() {\n    if (!this.touched) {\n      this.fcTouched?.();\n      this.touched = true;\n    }\n  }\n\n  writeValue(value: number | null): void {\n    this.value = value === undefined ? null : value;\n  }\n\n  registerOnChange(fn: (value: number | null) => void): void {\n    this.fcChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.fcTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n}\n"]}