@abgov/angular-components
Version:
Government of Alberta - UI components for Angular
259 lines • 22.8 kB
JavaScript
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
[]="type"
[]="name"
[]="focused"
[]="value !== null ? value : ''"
[]="autoCapitalize"
[]="placeholder"
[]="leadingIcon"
[]="trailingIcon"
[]="variant"
[]="disabled"
[]="readonly"
[]="error"
[]="testId"
[]="width"
[]="ariaLabel"
[]="ariaLabelledBy"
[]="min"
[]="max"
[]="step"
[]="prefix"
[]="suffix"
[]="debounce"
[]="maxLength"
[]="id"
[]="mt"
[]="mr"
[]="mb"
[]="ml"
[]="handleTrailingIconClick"
[]="textAlign"
(_trailingIconClick)="_onTrailingIconClick($event)"
(_change)="_onChange($event)"
(_focus)="_onFocus($event)"
(_blur)="_onBlur($event)"
(_keypress)="_onKeyPress($event)"
[]="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
[]="type"
[]="name"
[]="focused"
[]="value !== null ? value : ''"
[]="autoCapitalize"
[]="placeholder"
[]="leadingIcon"
[]="trailingIcon"
[]="variant"
[]="disabled"
[]="readonly"
[]="error"
[]="testId"
[]="width"
[]="ariaLabel"
[]="ariaLabelledBy"
[]="min"
[]="max"
[]="step"
[]="prefix"
[]="suffix"
[]="debounce"
[]="maxLength"
[]="id"
[]="mt"
[]="mr"
[]="mb"
[]="ml"
[]="handleTrailingIconClick"
[]="textAlign"
(_trailingIconClick)="_onTrailingIconClick($event)"
(_change)="_onChange($event)"
(_focus)="_onFocus($event)"
(_blur)="_onBlur($event)"
(_keypress)="_onKeyPress($event)"
[]="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":"AAUA,OAAO,EACL,sBAAsB,EACtB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,UAAU,EAEV,gBAAgB,EAChB,eAAe,GAChB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;;AAyDzE,MAAM,OAAO,eAAe;IAvD5B;QAwDW,SAAI,GAAkB,QAAQ,CAAC;QA4B/B,cAAS,GAAsB,OAAO,CAAC,CAAC,+BAA+B;QAEvE,UAAK,GAAkB,IAAI,CAAC;QAE3B,wBAAmB,GAAG,IAAI,YAAY,EAAQ,CAAC,CAAC,iBAAiB;QACjE,YAAO,GAAG,IAAI,YAAY,EAA0B,CAAC;QACrD,WAAM,GAAG,IAAI,YAAY,EAAyB,CAAC;QACnD,eAAU,GAAG,IAAI,YAAY,EAA6B,CAAC;QAC3D,aAAQ,GAAG,IAAI,YAAY,EAA2B,CAAC;QAEjE,4BAAuB,GAAG,KAAK,CAAC;QAqDhC,YAAO,GAAG,KAAK,CAAC;KAwBjB;IA3EC,QAAQ;QACN,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC;IACnE,CAAC;IAED,oBAAoB,CAAC,CAAQ;QAC3B,IAAI,IAAI,CAAC,uBAAuB,EAAE,CAAC;YACjC,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC;QAClC,CAAC;IACH,CAAC;IAED,SAAS,CAAC,CAAQ;QAChB,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,MAAM,MAAM,GAAI,CAA0C,CAAC,MAAM,CAAC;QAElE,MAAM,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC;QACjC,IAAI,YAAY,GAAkB,IAAI,CAAC;QAEvC,IAAI,WAAW,KAAK,IAAI,IAAI,WAAW,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;YACtD,MAAM,MAAM,GAAG,UAAU,CAAC,WAAW,CAAC,CAAC;YACvC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC;gBACnB,YAAY,GAAG,MAAM,CAAC;YACxB,CAAC;QACH,CAAC;QAED,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC;QAE1B,IAAI,CAAC,QAAQ,EAAE,CAAC,YAAY,CAAC,CAAC;QAE9B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC7B,CAAC;IAED,WAAW,CAAC,CAAQ;QAClB,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,MAAM,MAAM,GAAI,CAA4C,CAAC,MAAM,CAAC;QACpE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC/B,CAAC;IAED,QAAQ,CAAC,CAAQ;QACf,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,MAAM,MAAM,GAAI,CAAyC,CAAC,MAAM,CAAC;QACjE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED,OAAO,CAAC,CAAQ;QACd,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,MAAM,MAAM,GAAI,CAAwC,CAAC,MAAM,CAAC;QAChE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC3B,CAAC;IAMD,aAAa;QACX,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;YACnB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACtB,CAAC;IACH,CAAC;IAED,UAAU,CAAC,KAAoB;QAC7B,IAAI,CAAC,KAAK,GAAG,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;IAClD,CAAC;IAED,gBAAgB,CAAC,EAAkC;QACjD,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,gBAAgB,CAAE,UAAmB;QACnC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;8GAnHU,eAAe;kGAAf,eAAe,wIAIN,eAAe,sCACf,gBAAgB,+KAMhB,gBAAgB,sCAChB,gBAAgB,6BAChB,gBAAgB,uIAMhB,eAAe,kDAGf,eAAe,iUA/BxB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,KAAK,EAAE,IAAI;gBACX,yCAAyC;gBACzC,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC;aAC/C;SACF,0BAlDS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyCT;;2FAWU,eAAe;kBAvD3B,SAAS;mBAAC;oBACT,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,mBAAmB;oBAC7B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyCT;oBACD,OAAO,EAAE,CAAC,sBAAsB,CAAC;oBACjC,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,KAAK,EAAE,IAAI;4BACX,yCAAyC;4BACzC,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,gBAAgB,CAAC;yBAC/C;qBACF;iBACF;8BAEU,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACiC,QAAQ;sBAA9C,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBACG,QAAQ;sBAA/C,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAC7B,cAAc;sBAAtB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACkC,OAAO;sBAA9C,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBACE,QAAQ;sBAA/C,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBACE,KAAK;sBAA5C,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAC7B,KAAK;sBAAb,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACiC,SAAS;sBAA/C,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAC5B,GAAG;sBAAX,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACiC,IAAI;sBAA1C,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAC5B,cAAc;sBAAtB,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAEG,KAAK;sBAAb,KAAK;gBAEI,mBAAmB;sBAA5B,MAAM;gBACG,OAAO;sBAAhB,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACG,QAAQ;sBAAjB,MAAM","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"]}