@abgov/angular-components 4.7.0 → 4.7.1-alpha.1

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.
@@ -1,6 +1,7 @@
1
- import { CUSTOM_ELEMENTS_SCHEMA, Component, EventEmitter, Input, Output, forwardRef, booleanAttribute, numberAttribute, } from "@angular/core";
1
+ import { CUSTOM_ELEMENTS_SCHEMA, Component, EventEmitter, Input, Output, forwardRef, booleanAttribute, numberAttribute, TemplateRef, } from "@angular/core";
2
2
  import { NG_VALUE_ACCESSOR } from "@angular/forms";
3
3
  import { GoabControlValueAccessor } from "../base.component";
4
+ import { NgIf, NgTemplateOutlet } from "@angular/common";
4
5
  import * as i0 from "@angular/core";
5
6
  export class GoabInput extends GoabControlValueAccessor {
6
7
  constructor() {
@@ -46,8 +47,24 @@ export class GoabInput extends GoabControlValueAccessor {
46
47
  const detail = e.detail;
47
48
  this.onBlur.emit(detail);
48
49
  }
50
+ getLeadingContentAsString() {
51
+ return this.leadingContent instanceof TemplateRef ? "" : this.leadingContent;
52
+ }
53
+ getLeadingContentAsTemplate() {
54
+ if (!this.leadingContent)
55
+ return null;
56
+ return this.leadingContent instanceof TemplateRef ? this.leadingContent : null;
57
+ }
58
+ getTrailingContentAsString() {
59
+ return this.trailingContent instanceof TemplateRef ? "" : this.trailingContent;
60
+ }
61
+ getTrailingContentAsTemplate() {
62
+ if (!this.trailingContent)
63
+ return null;
64
+ return this.trailingContent instanceof TemplateRef ? this.trailingContent : null;
65
+ }
49
66
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: GoabInput, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
50
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.3", type: GoabInput, isStandalone: true, selector: "goab-input", inputs: { type: "type", name: "name", debounce: ["debounce", "debounce", numberAttribute], autoCapitalize: "autoCapitalize", autoComplete: "autoComplete", placeholder: "placeholder", leadingIcon: "leadingIcon", trailingIcon: "trailingIcon", variant: "variant", focused: ["focused", "focused", booleanAttribute], readonly: ["readonly", "readonly", booleanAttribute], width: "width", prefix: "prefix", suffix: "suffix", ariaLabel: "ariaLabel", maxLength: ["maxLength", "maxLength", numberAttribute], min: "min", max: "max", step: ["step", "step", numberAttribute], ariaLabelledBy: "ariaLabelledBy", trailingIconAriaLabel: "trailingIconAriaLabel", textAlign: "textAlign" }, outputs: { onTrailingIconClick: "onTrailingIconClick", onFocus: "onFocus", onBlur: "onBlur", onKeyPress: "onKeyPress", onChange: "onChange" }, providers: [
67
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.3", type: GoabInput, isStandalone: true, selector: "goab-input", inputs: { type: "type", name: "name", debounce: ["debounce", "debounce", numberAttribute], autoCapitalize: "autoCapitalize", autoComplete: "autoComplete", placeholder: "placeholder", leadingIcon: "leadingIcon", trailingIcon: "trailingIcon", variant: "variant", focused: ["focused", "focused", booleanAttribute], readonly: ["readonly", "readonly", booleanAttribute], width: "width", prefix: "prefix", suffix: "suffix", ariaLabel: "ariaLabel", maxLength: ["maxLength", "maxLength", numberAttribute], min: "min", max: "max", step: ["step", "step", numberAttribute], ariaLabelledBy: "ariaLabelledBy", trailingIconAriaLabel: "trailingIconAriaLabel", textAlign: "textAlign", leadingContent: "leadingContent", trailingContent: "trailingContent" }, outputs: { onTrailingIconClick: "onTrailingIconClick", onFocus: "onFocus", onBlur: "onBlur", onKeyPress: "onKeyPress", onChange: "onChange" }, providers: [
51
68
  {
52
69
  provide: NG_VALUE_ACCESSOR,
53
70
  multi: true,
@@ -93,15 +110,38 @@ export class GoabInput extends GoabControlValueAccessor {
93
110
  (_keyPress)="_onKeyPress($event)"
94
111
  [attr.trailingiconarialabel]="trailingIconAriaLabel"
95
112
  >
113
+ <div slot="leadingContent">
114
+ <ng-container *ngIf="leadingContent">
115
+ <ng-container *ngIf="getLeadingContentAsTemplate(); else stringLeading">
116
+ <ng-container
117
+ [ngTemplateOutlet]="getLeadingContentAsTemplate()"
118
+ ></ng-container>
119
+ </ng-container>
120
+ <ng-template #stringLeading>{{ getLeadingContentAsString() }}</ng-template>
121
+ </ng-container>
122
+ </div>
123
+
96
124
  <ng-content />
125
+
126
+ <div slot="trailingContent">
127
+ <ng-container *ngIf="trailingContent">
128
+ <ng-container *ngIf="getTrailingContentAsTemplate(); else stringTrailing">
129
+ <ng-container
130
+ [ngTemplateOutlet]="getTrailingContentAsTemplate()"
131
+ ></ng-container>
132
+ </ng-container>
133
+ <ng-template #stringTrailing>{{ getTrailingContentAsString() }}</ng-template>
134
+ </ng-container>
135
+ </div>
97
136
  </goa-input>
98
- `, isInline: true }); }
137
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
99
138
  }
100
139
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: GoabInput, decorators: [{
101
140
  type: Component,
102
141
  args: [{
103
142
  standalone: true,
104
143
  selector: "goab-input",
144
+ imports: [NgIf, NgTemplateOutlet],
105
145
  template: `
106
146
  <goa-input
107
147
  [attr.type]="type"
@@ -142,7 +182,29 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
142
182
  (_keyPress)="_onKeyPress($event)"
143
183
  [attr.trailingiconarialabel]="trailingIconAriaLabel"
144
184
  >
185
+ <div slot="leadingContent">
186
+ <ng-container *ngIf="leadingContent">
187
+ <ng-container *ngIf="getLeadingContentAsTemplate(); else stringLeading">
188
+ <ng-container
189
+ [ngTemplateOutlet]="getLeadingContentAsTemplate()"
190
+ ></ng-container>
191
+ </ng-container>
192
+ <ng-template #stringLeading>{{ getLeadingContentAsString() }}</ng-template>
193
+ </ng-container>
194
+ </div>
195
+
145
196
  <ng-content />
197
+
198
+ <div slot="trailingContent">
199
+ <ng-container *ngIf="trailingContent">
200
+ <ng-container *ngIf="getTrailingContentAsTemplate(); else stringTrailing">
201
+ <ng-container
202
+ [ngTemplateOutlet]="getTrailingContentAsTemplate()"
203
+ ></ng-container>
204
+ </ng-container>
205
+ <ng-template #stringTrailing>{{ getTrailingContentAsString() }}</ng-template>
206
+ </ng-container>
207
+ </div>
146
208
  </goa-input>
147
209
  `,
148
210
  schemas: [CUSTOM_ELEMENTS_SCHEMA],
@@ -203,6 +265,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
203
265
  type: Input
204
266
  }], textAlign: [{
205
267
  type: Input
268
+ }], leadingContent: [{
269
+ type: Input
270
+ }], trailingContent: [{
271
+ type: Input
206
272
  }], onTrailingIconClick: [{
207
273
  type: Output
208
274
  }], onFocus: [{
@@ -214,4 +280,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
214
280
  }], onChange: [{
215
281
  type: Output
216
282
  }] } });
217
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.js","sourceRoot":"","sources":["../../../../../../../libs/angular-components/src/lib/components/input/input.ts"],"names":[],"mappings":"AASA,OAAO,EACL,sBAAsB,EACtB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,UAAU,EAEV,gBAAgB,EAChB,eAAe,GAChB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,wBAAwB,EAAE,MAAM,mBAAmB,CAAC;;AA6D7D,MAAM,OAAO,SAAU,SAAQ,wBAAwB;IAvDvD;;QAwDW,SAAI,GAAmB,MAAM,CAAC;QAqB9B,cAAS,GAAsB,MAAM,CAAC;QAErC,wBAAmB,GAAG,IAAI,YAAY,EAAE,CAAC;QACzC,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;KAyCjC;IAvCC,QAAQ;QACN,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC;QACjE,IAAI,OAAO,IAAI,CAAC,KAAK,KAAK,QAAQ,EAAE,CAAC;YACnC,OAAO,CAAC,IAAI,CAAC,2CAA2C,CAAC,CAAC;QAC5D,CAAC;IACH,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;QAClE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAE3B,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAChC,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;QAE7B,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;IACrB,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,MAAM,MAAM,GAAI,CAAwC,CAAC,MAAM,CAAC;QAChE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC3B,CAAC;8GAtEU,SAAS;kGAAT,SAAS,uHAGA,eAAe,6MAOf,gBAAgB,sCAChB,gBAAgB,qHAKhB,eAAe,kDAGf,eAAe,yQA3BxB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,KAAK,EAAE,IAAI;gBACX,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC;aACzC;SACF,iDAlDS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0CT;;2FAUU,SAAS;kBAvDrB,SAAS;mBAAC;oBACT,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,YAAY;oBACtB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0CT;oBACD,OAAO,EAAE,CAAC,sBAAsB,CAAC;oBACjC,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,KAAK,EAAE,IAAI;4BACX,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,UAAU,CAAC;yBACzC;qBACF;iBACF;8BAEU,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACiC,QAAQ;sBAA9C,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAC5B,cAAc;sBAAtB,KAAK;gBACG,YAAY;sBAApB,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;gBAC7B,KAAK;sBAAb,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,qBAAqB;sBAA7B,KAAK;gBACG,SAAS;sBAAjB,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} 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 { NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { GoabControlValueAccessor } from \"../base.component\";\n\nexport interface IgnoreMe {\n  ignore: string;\n}\n\n@Component({\n  standalone: true,\n  selector: \"goab-input\",\n  template: `\n    <goa-input\n      [attr.type]=\"type\"\n      [attr.name]=\"name\"\n      [attr.focused]=\"focused\"\n      [attr.value]=\"value\"\n      [attr.autocapitalize]=\"autoCapitalize\"\n      [attr.autocomplete]=\"autoComplete\"\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      useExisting: forwardRef(() => GoabInput),\n    },\n  ],\n})\nexport class GoabInput extends GoabControlValueAccessor implements OnInit {\n  @Input() type?: GoabInputType = \"text\";\n  @Input() name?: string;\n  @Input({ transform: numberAttribute }) debounce?: number;\n  @Input() autoCapitalize?: GoabInputAutoCapitalize;\n  @Input() autoComplete?: string;\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() width?: string;\n  @Input() prefix?: string;\n  @Input() suffix?: 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() trailingIconAriaLabel?: string;\n  @Input() textAlign?: \"left\" | \"right\" = \"left\";\n\n  @Output() onTrailingIconClick = new EventEmitter();\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    if (typeof this.value === \"number\") {\n      console.warn(\"For numeric values use goab-input-number.\");\n    }\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    this.onChange.emit(detail);\n\n    this.fcChange?.(detail.value);\n  }\n\n  _onKeyPress(e: Event) {\n    this.markAsTouched();\n    const detail = (e as CustomEvent<GoabInputOnKeyPressDetail>).detail;\n    this.onKeyPress.emit(detail);\n\n    this.fcTouched?.();\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    const detail = (e as CustomEvent<GoabInputOnBlurDetail>).detail;\n    this.onBlur.emit(detail);\n  }\n}\n"]}
283
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.js","sourceRoot":"","sources":["../../../../../../../libs/angular-components/src/lib/components/input/input.ts"],"names":[],"mappings":"AASA,OAAO,EACL,sBAAsB,EACtB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,UAAU,EAEV,gBAAgB,EAChB,eAAe,EACf,WAAW,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,wBAAwB,EAAE,MAAM,mBAAmB,CAAC;AAC7D,OAAO,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;;AAoFzD,MAAM,OAAO,SAAU,SAAQ,wBAAwB;IA9EvD;;QA+EW,SAAI,GAAmB,MAAM,CAAC;QAqB9B,cAAS,GAAsB,MAAM,CAAC;QAIrC,wBAAmB,GAAG,IAAI,YAAY,EAAE,CAAC;QACzC,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;KA2DjC;IAzDC,QAAQ;QACN,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC;QACjE,IAAI,OAAO,IAAI,CAAC,KAAK,KAAK,QAAQ,EAAE,CAAC;YACnC,OAAO,CAAC,IAAI,CAAC,2CAA2C,CAAC,CAAC;QAC5D,CAAC;IACH,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;QAClE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAE3B,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAChC,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;QAE7B,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;IACrB,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,MAAM,MAAM,GAAI,CAAwC,CAAC,MAAM,CAAC;QAChE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC3B,CAAC;IAED,yBAAyB;QACvB,OAAO,IAAI,CAAC,cAAc,YAAY,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC;IAC/E,CAAC;IAED,2BAA2B;QACzB,IAAI,CAAC,IAAI,CAAC,cAAc;YAAE,OAAO,IAAI,CAAC;QACtC,OAAO,IAAI,CAAC,cAAc,YAAY,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC;IACjF,CAAC;IAED,0BAA0B;QACxB,OAAO,IAAI,CAAC,eAAe,YAAY,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC;IACjF,CAAC;IAED,4BAA4B;QAC1B,IAAI,CAAC,IAAI,CAAC,eAAe;YAAE,OAAO,IAAI,CAAC;QACvC,OAAO,IAAI,CAAC,eAAe,YAAY,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC;IACnF,CAAC;8GA1FU,SAAS;kGAAT,SAAS,uHAGA,eAAe,6MAOf,gBAAgB,sCAChB,gBAAgB,qHAKhB,eAAe,kDAGf,eAAe,+UA3BxB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,KAAK,EAAE,IAAI;gBACX,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC;aACzC;SACF,iDAxES;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgET,4DAjES,IAAI,6FAAE,gBAAgB;;2FA2ErB,SAAS;kBA9ErB,SAAS;mBAAC;oBACT,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,YAAY;oBACtB,OAAO,EAAE,CAAC,IAAI,EAAE,gBAAgB,CAAC;oBACjC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgET;oBACD,OAAO,EAAE,CAAC,sBAAsB,CAAC;oBACjC,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,KAAK,EAAE,IAAI;4BACX,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,UAAU,CAAC;yBACzC;qBACF;iBACF;8BAEU,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACiC,QAAQ;sBAA9C,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAC5B,cAAc;sBAAtB,KAAK;gBACG,YAAY;sBAApB,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;gBAC7B,KAAK;sBAAb,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,qBAAqB;sBAA7B,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,eAAe;sBAAvB,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} 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  TemplateRef,\n} from \"@angular/core\";\nimport { NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { GoabControlValueAccessor } from \"../base.component\";\nimport { NgIf, NgTemplateOutlet } from \"@angular/common\";\n\nexport interface IgnoreMe {\n  ignore: string;\n}\n\n@Component({\n  standalone: true,\n  selector: \"goab-input\",\n  imports: [NgIf, NgTemplateOutlet],\n  template: `\n    <goa-input\n      [attr.type]=\"type\"\n      [attr.name]=\"name\"\n      [attr.focused]=\"focused\"\n      [attr.value]=\"value\"\n      [attr.autocapitalize]=\"autoCapitalize\"\n      [attr.autocomplete]=\"autoComplete\"\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      <div slot=\"leadingContent\">\n        <ng-container *ngIf=\"leadingContent\">\n          <ng-container *ngIf=\"getLeadingContentAsTemplate(); else stringLeading\">\n            <ng-container\n              [ngTemplateOutlet]=\"getLeadingContentAsTemplate()\"\n            ></ng-container>\n          </ng-container>\n          <ng-template #stringLeading>{{ getLeadingContentAsString() }}</ng-template>\n        </ng-container>\n      </div>\n\n      <ng-content />\n\n      <div slot=\"trailingContent\">\n        <ng-container *ngIf=\"trailingContent\">\n          <ng-container *ngIf=\"getTrailingContentAsTemplate(); else stringTrailing\">\n            <ng-container\n              [ngTemplateOutlet]=\"getTrailingContentAsTemplate()\"\n            ></ng-container>\n          </ng-container>\n          <ng-template #stringTrailing>{{ getTrailingContentAsString() }}</ng-template>\n        </ng-container>\n      </div>\n    </goa-input>\n  `,\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      multi: true,\n      useExisting: forwardRef(() => GoabInput),\n    },\n  ],\n})\nexport class GoabInput extends GoabControlValueAccessor implements OnInit {\n  @Input() type?: GoabInputType = \"text\";\n  @Input() name?: string;\n  @Input({ transform: numberAttribute }) debounce?: number;\n  @Input() autoCapitalize?: GoabInputAutoCapitalize;\n  @Input() autoComplete?: string;\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() width?: string;\n  @Input() prefix?: string;\n  @Input() suffix?: 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() trailingIconAriaLabel?: string;\n  @Input() textAlign?: \"left\" | \"right\" = \"left\";\n  @Input() leadingContent!: string | TemplateRef<any>;\n  @Input() trailingContent!: string | TemplateRef<any>;\n\n  @Output() onTrailingIconClick = new EventEmitter();\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    if (typeof this.value === \"number\") {\n      console.warn(\"For numeric values use goab-input-number.\");\n    }\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    this.onChange.emit(detail);\n\n    this.fcChange?.(detail.value);\n  }\n\n  _onKeyPress(e: Event) {\n    this.markAsTouched();\n    const detail = (e as CustomEvent<GoabInputOnKeyPressDetail>).detail;\n    this.onKeyPress.emit(detail);\n\n    this.fcTouched?.();\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    const detail = (e as CustomEvent<GoabInputOnBlurDetail>).detail;\n    this.onBlur.emit(detail);\n  }\n\n  getLeadingContentAsString(): string {\n    return this.leadingContent instanceof TemplateRef ? \"\" : this.leadingContent;\n  }\n\n  getLeadingContentAsTemplate(): TemplateRef<any> | null {\n    if (!this.leadingContent) return null;\n    return this.leadingContent instanceof TemplateRef ? this.leadingContent : null;\n  }\n\n  getTrailingContentAsString(): string {\n    return this.trailingContent instanceof TemplateRef ? \"\" : this.trailingContent;\n  }\n\n  getTrailingContentAsTemplate(): TemplateRef<any> | null {\n    if (!this.trailingContent) return null;\n    return this.trailingContent instanceof TemplateRef ? this.trailingContent : null;\n  }\n}\n"]}
@@ -1,4 +1,5 @@
1
- import { CUSTOM_ELEMENTS_SCHEMA, Component, EventEmitter, Input, Output, forwardRef, booleanAttribute, numberAttribute, } from "@angular/core";
1
+ import { NgIf, NgTemplateOutlet } from "@angular/common";
2
+ import { CUSTOM_ELEMENTS_SCHEMA, Component, EventEmitter, Input, Output, forwardRef, booleanAttribute, numberAttribute, TemplateRef, } from "@angular/core";
2
3
  import { NG_VALUE_ACCESSOR } from "@angular/forms";
3
4
  import * as i0 from "@angular/core";
4
5
  export class GoabInputNumber {
@@ -70,8 +71,24 @@ export class GoabInputNumber {
70
71
  setDisabledState(isDisabled) {
71
72
  this.disabled = isDisabled;
72
73
  }
74
+ getLeadingContentAsString() {
75
+ return this.leadingContent instanceof TemplateRef ? "" : this.leadingContent;
76
+ }
77
+ getLeadingContentAsTemplate() {
78
+ if (!this.leadingContent)
79
+ return null;
80
+ return this.leadingContent instanceof TemplateRef ? this.leadingContent : null;
81
+ }
82
+ getTrailingContentAsString() {
83
+ return this.trailingContent instanceof TemplateRef ? "" : this.trailingContent;
84
+ }
85
+ getTrailingContentAsTemplate() {
86
+ if (!this.trailingContent)
87
+ return null;
88
+ return this.trailingContent instanceof TemplateRef ? this.trailingContent : null;
89
+ }
73
90
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: GoabInputNumber, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
74
- 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: [
91
+ 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", leadingContent: "leadingContent", trailingContent: "trailingContent" }, outputs: { onTrailingIconClick: "onTrailingIconClick", onFocus: "onFocus", onBlur: "onBlur", onKeyPress: "onKeyPress", onChange: "onChange" }, providers: [
75
92
  {
76
93
  provide: NG_VALUE_ACCESSOR,
77
94
  multi: true,
@@ -117,15 +134,38 @@ export class GoabInputNumber {
117
134
  (_keypress)="_onKeyPress($event)"
118
135
  [attr.trailingiconarialabel]="trailingIconAriaLabel"
119
136
  >
137
+ <div slot="leadingContent">
138
+ <ng-container *ngIf="leadingContent">
139
+ <ng-container *ngIf="getLeadingContentAsTemplate(); else stringLeading">
140
+ <ng-container
141
+ [ngTemplateOutlet]="getLeadingContentAsTemplate()"
142
+ ></ng-container>
143
+ </ng-container>
144
+ <ng-template #stringLeading>{{ getLeadingContentAsString() }}</ng-template>
145
+ </ng-container>
146
+ </div>
147
+
120
148
  <ng-content />
149
+
150
+ <div slot="trailingContent">
151
+ <ng-container *ngIf="trailingContent">
152
+ <ng-container *ngIf="getTrailingContentAsTemplate(); else stringTrailing">
153
+ <ng-container
154
+ [ngTemplateOutlet]="getTrailingContentAsTemplate()"
155
+ ></ng-container>
156
+ </ng-container>
157
+ <ng-template #stringTrailing>{{ getTrailingContentAsString() }}</ng-template>
158
+ </ng-container>
159
+ </div>
121
160
  </goa-input>
122
- `, isInline: true }); }
161
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
123
162
  }
124
163
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: GoabInputNumber, decorators: [{
125
164
  type: Component,
126
165
  args: [{
127
166
  standalone: true,
128
167
  selector: "goab-input-number",
168
+ imports: [NgIf, NgTemplateOutlet],
129
169
  template: `
130
170
  <goa-input
131
171
  [attr.type]="type"
@@ -165,7 +205,29 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
165
205
  (_keypress)="_onKeyPress($event)"
166
206
  [attr.trailingiconarialabel]="trailingIconAriaLabel"
167
207
  >
208
+ <div slot="leadingContent">
209
+ <ng-container *ngIf="leadingContent">
210
+ <ng-container *ngIf="getLeadingContentAsTemplate(); else stringLeading">
211
+ <ng-container
212
+ [ngTemplateOutlet]="getLeadingContentAsTemplate()"
213
+ ></ng-container>
214
+ </ng-container>
215
+ <ng-template #stringLeading>{{ getLeadingContentAsString() }}</ng-template>
216
+ </ng-container>
217
+ </div>
218
+
168
219
  <ng-content />
220
+
221
+ <div slot="trailingContent">
222
+ <ng-container *ngIf="trailingContent">
223
+ <ng-container *ngIf="getTrailingContentAsTemplate(); else stringTrailing">
224
+ <ng-container
225
+ [ngTemplateOutlet]="getTrailingContentAsTemplate()"
226
+ ></ng-container>
227
+ </ng-container>
228
+ <ng-template #stringTrailing>{{ getTrailingContentAsString() }}</ng-template>
229
+ </ng-container>
230
+ </div>
169
231
  </goa-input>
170
232
  `,
171
233
  schemas: [CUSTOM_ELEMENTS_SCHEMA],
@@ -245,6 +307,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
245
307
  type: Input
246
308
  }], value: [{
247
309
  type: Input
310
+ }], leadingContent: [{
311
+ type: Input
312
+ }], trailingContent: [{
313
+ type: Input
248
314
  }], onTrailingIconClick: [{
249
315
  type: Output
250
316
  }], onFocus: [{
@@ -256,4 +322,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
256
322
  }], onChange: [{
257
323
  type: Output
258
324
  }] } });
259
- //# 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"]}
325
+ //# 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,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,EACL,sBAAsB,EACtB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,UAAU,EAEV,gBAAgB,EAChB,eAAe,EACf,WAAW,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;;AAgFzE,MAAM,OAAO,eAAe;IA9E5B;QA+EW,SAAI,GAAkB,QAAQ,CAAC;QA4B/B,cAAS,GAAsB,OAAO,CAAC,CAAC,+BAA+B;QAEvE,UAAK,GAAkB,IAAI,CAAC;QAI3B,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;KA0CjB;IA7FC,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;IAED,yBAAyB;QACvB,OAAO,IAAI,CAAC,cAAc,YAAY,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC;IAC/E,CAAC;IAED,2BAA2B;QACzB,IAAI,CAAC,IAAI,CAAC,cAAc;YAAE,OAAO,IAAI,CAAC;QACtC,OAAO,IAAI,CAAC,cAAc,YAAY,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC;IACjF,CAAC;IAED,0BAA0B;QACxB,OAAO,IAAI,CAAC,eAAe,YAAY,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC;IACjF,CAAC;IAED,4BAA4B;QAC1B,IAAI,CAAC,IAAI,CAAC,eAAe;YAAE,OAAO,IAAI,CAAC;QACvC,OAAO,IAAI,CAAC,eAAe,YAAY,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC;IACnF,CAAC;8GAvIU,eAAe;kGAAf,eAAe,wIAIN,eAAe,sCACf,gBAAgB,+KAMhB,gBAAgB,sCAChB,gBAAgB,6BAChB,gBAAgB,uIAMhB,eAAe,kDAGf,eAAe,uYA/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,0BAxES;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+DT,4DAhES,IAAI,6FAAE,gBAAgB;;2FA2ErB,eAAe;kBA9E3B,SAAS;mBAAC;oBACT,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,mBAAmB;oBAC7B,OAAO,EAAE,CAAC,IAAI,EAAE,gBAAgB,CAAC;oBACjC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+DT;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;gBACG,cAAc;sBAAtB,KAAK;gBACG,eAAe;sBAAvB,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 { NgIf, NgTemplateOutlet } from \"@angular/common\";\nimport {\n  CUSTOM_ELEMENTS_SCHEMA,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  forwardRef,\n  OnInit,\n  booleanAttribute,\n  numberAttribute,\n  TemplateRef,\n} from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\n@Component({\n  standalone: true,\n  selector: \"goab-input-number\",\n  imports: [NgIf, NgTemplateOutlet],\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      <div slot=\"leadingContent\">\n        <ng-container *ngIf=\"leadingContent\">\n          <ng-container *ngIf=\"getLeadingContentAsTemplate(); else stringLeading\">\n            <ng-container\n              [ngTemplateOutlet]=\"getLeadingContentAsTemplate()\"\n            ></ng-container>\n          </ng-container>\n          <ng-template #stringLeading>{{ getLeadingContentAsString() }}</ng-template>\n        </ng-container>\n      </div>\n\n      <ng-content />\n\n      <div slot=\"trailingContent\">\n        <ng-container *ngIf=\"trailingContent\">\n          <ng-container *ngIf=\"getTrailingContentAsTemplate(); else stringTrailing\">\n            <ng-container\n              [ngTemplateOutlet]=\"getTrailingContentAsTemplate()\"\n            ></ng-container>\n          </ng-container>\n          <ng-template #stringTrailing>{{ getTrailingContentAsString() }}</ng-template>\n        </ng-container>\n      </div>\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  @Input() leadingContent!: string | TemplateRef<any>;\n  @Input() trailingContent!: string | TemplateRef<any>;\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  getLeadingContentAsString(): string {\n    return this.leadingContent instanceof TemplateRef ? \"\" : this.leadingContent;\n  }\n\n  getLeadingContentAsTemplate(): TemplateRef<any> | null {\n    if (!this.leadingContent) return null;\n    return this.leadingContent instanceof TemplateRef ? this.leadingContent : null;\n  }\n\n  getTrailingContentAsString(): string {\n    return this.trailingContent instanceof TemplateRef ? \"\" : this.trailingContent;\n  }\n\n  getTrailingContentAsTemplate(): TemplateRef<any> | null {\n    if (!this.trailingContent) return null;\n    return this.trailingContent instanceof TemplateRef ? this.trailingContent : null;\n  }\n}\n"]}
@@ -2828,8 +2828,24 @@ class GoabInput extends GoabControlValueAccessor {
2828
2828
  const detail = e.detail;
2829
2829
  this.onBlur.emit(detail);
2830
2830
  }
2831
+ getLeadingContentAsString() {
2832
+ return this.leadingContent instanceof TemplateRef ? "" : this.leadingContent;
2833
+ }
2834
+ getLeadingContentAsTemplate() {
2835
+ if (!this.leadingContent)
2836
+ return null;
2837
+ return this.leadingContent instanceof TemplateRef ? this.leadingContent : null;
2838
+ }
2839
+ getTrailingContentAsString() {
2840
+ return this.trailingContent instanceof TemplateRef ? "" : this.trailingContent;
2841
+ }
2842
+ getTrailingContentAsTemplate() {
2843
+ if (!this.trailingContent)
2844
+ return null;
2845
+ return this.trailingContent instanceof TemplateRef ? this.trailingContent : null;
2846
+ }
2831
2847
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: GoabInput, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
2832
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.3", type: GoabInput, isStandalone: true, selector: "goab-input", inputs: { type: "type", name: "name", debounce: ["debounce", "debounce", numberAttribute], autoCapitalize: "autoCapitalize", autoComplete: "autoComplete", placeholder: "placeholder", leadingIcon: "leadingIcon", trailingIcon: "trailingIcon", variant: "variant", focused: ["focused", "focused", booleanAttribute], readonly: ["readonly", "readonly", booleanAttribute], width: "width", prefix: "prefix", suffix: "suffix", ariaLabel: "ariaLabel", maxLength: ["maxLength", "maxLength", numberAttribute], min: "min", max: "max", step: ["step", "step", numberAttribute], ariaLabelledBy: "ariaLabelledBy", trailingIconAriaLabel: "trailingIconAriaLabel", textAlign: "textAlign" }, outputs: { onTrailingIconClick: "onTrailingIconClick", onFocus: "onFocus", onBlur: "onBlur", onKeyPress: "onKeyPress", onChange: "onChange" }, providers: [
2848
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.3", type: GoabInput, isStandalone: true, selector: "goab-input", inputs: { type: "type", name: "name", debounce: ["debounce", "debounce", numberAttribute], autoCapitalize: "autoCapitalize", autoComplete: "autoComplete", placeholder: "placeholder", leadingIcon: "leadingIcon", trailingIcon: "trailingIcon", variant: "variant", focused: ["focused", "focused", booleanAttribute], readonly: ["readonly", "readonly", booleanAttribute], width: "width", prefix: "prefix", suffix: "suffix", ariaLabel: "ariaLabel", maxLength: ["maxLength", "maxLength", numberAttribute], min: "min", max: "max", step: ["step", "step", numberAttribute], ariaLabelledBy: "ariaLabelledBy", trailingIconAriaLabel: "trailingIconAriaLabel", textAlign: "textAlign", leadingContent: "leadingContent", trailingContent: "trailingContent" }, outputs: { onTrailingIconClick: "onTrailingIconClick", onFocus: "onFocus", onBlur: "onBlur", onKeyPress: "onKeyPress", onChange: "onChange" }, providers: [
2833
2849
  {
2834
2850
  provide: NG_VALUE_ACCESSOR,
2835
2851
  multi: true,
@@ -2875,15 +2891,38 @@ class GoabInput extends GoabControlValueAccessor {
2875
2891
  (_keyPress)="_onKeyPress($event)"
2876
2892
  [attr.trailingiconarialabel]="trailingIconAriaLabel"
2877
2893
  >
2894
+ <div slot="leadingContent">
2895
+ <ng-container *ngIf="leadingContent">
2896
+ <ng-container *ngIf="getLeadingContentAsTemplate(); else stringLeading">
2897
+ <ng-container
2898
+ [ngTemplateOutlet]="getLeadingContentAsTemplate()"
2899
+ ></ng-container>
2900
+ </ng-container>
2901
+ <ng-template #stringLeading>{{ getLeadingContentAsString() }}</ng-template>
2902
+ </ng-container>
2903
+ </div>
2904
+
2878
2905
  <ng-content />
2906
+
2907
+ <div slot="trailingContent">
2908
+ <ng-container *ngIf="trailingContent">
2909
+ <ng-container *ngIf="getTrailingContentAsTemplate(); else stringTrailing">
2910
+ <ng-container
2911
+ [ngTemplateOutlet]="getTrailingContentAsTemplate()"
2912
+ ></ng-container>
2913
+ </ng-container>
2914
+ <ng-template #stringTrailing>{{ getTrailingContentAsString() }}</ng-template>
2915
+ </ng-container>
2916
+ </div>
2879
2917
  </goa-input>
2880
- `, isInline: true }); }
2918
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
2881
2919
  }
2882
2920
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: GoabInput, decorators: [{
2883
2921
  type: Component,
2884
2922
  args: [{
2885
2923
  standalone: true,
2886
2924
  selector: "goab-input",
2925
+ imports: [NgIf, NgTemplateOutlet],
2887
2926
  template: `
2888
2927
  <goa-input
2889
2928
  [attr.type]="type"
@@ -2924,7 +2963,29 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
2924
2963
  (_keyPress)="_onKeyPress($event)"
2925
2964
  [attr.trailingiconarialabel]="trailingIconAriaLabel"
2926
2965
  >
2966
+ <div slot="leadingContent">
2967
+ <ng-container *ngIf="leadingContent">
2968
+ <ng-container *ngIf="getLeadingContentAsTemplate(); else stringLeading">
2969
+ <ng-container
2970
+ [ngTemplateOutlet]="getLeadingContentAsTemplate()"
2971
+ ></ng-container>
2972
+ </ng-container>
2973
+ <ng-template #stringLeading>{{ getLeadingContentAsString() }}</ng-template>
2974
+ </ng-container>
2975
+ </div>
2976
+
2927
2977
  <ng-content />
2978
+
2979
+ <div slot="trailingContent">
2980
+ <ng-container *ngIf="trailingContent">
2981
+ <ng-container *ngIf="getTrailingContentAsTemplate(); else stringTrailing">
2982
+ <ng-container
2983
+ [ngTemplateOutlet]="getTrailingContentAsTemplate()"
2984
+ ></ng-container>
2985
+ </ng-container>
2986
+ <ng-template #stringTrailing>{{ getTrailingContentAsString() }}</ng-template>
2987
+ </ng-container>
2988
+ </div>
2928
2989
  </goa-input>
2929
2990
  `,
2930
2991
  schemas: [CUSTOM_ELEMENTS_SCHEMA],
@@ -2985,6 +3046,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
2985
3046
  type: Input
2986
3047
  }], textAlign: [{
2987
3048
  type: Input
3049
+ }], leadingContent: [{
3050
+ type: Input
3051
+ }], trailingContent: [{
3052
+ type: Input
2988
3053
  }], onTrailingIconClick: [{
2989
3054
  type: Output
2990
3055
  }], onFocus: [{
@@ -3066,8 +3131,24 @@ class GoabInputNumber {
3066
3131
  setDisabledState(isDisabled) {
3067
3132
  this.disabled = isDisabled;
3068
3133
  }
3134
+ getLeadingContentAsString() {
3135
+ return this.leadingContent instanceof TemplateRef ? "" : this.leadingContent;
3136
+ }
3137
+ getLeadingContentAsTemplate() {
3138
+ if (!this.leadingContent)
3139
+ return null;
3140
+ return this.leadingContent instanceof TemplateRef ? this.leadingContent : null;
3141
+ }
3142
+ getTrailingContentAsString() {
3143
+ return this.trailingContent instanceof TemplateRef ? "" : this.trailingContent;
3144
+ }
3145
+ getTrailingContentAsTemplate() {
3146
+ if (!this.trailingContent)
3147
+ return null;
3148
+ return this.trailingContent instanceof TemplateRef ? this.trailingContent : null;
3149
+ }
3069
3150
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: GoabInputNumber, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
3070
- 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: [
3151
+ 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", leadingContent: "leadingContent", trailingContent: "trailingContent" }, outputs: { onTrailingIconClick: "onTrailingIconClick", onFocus: "onFocus", onBlur: "onBlur", onKeyPress: "onKeyPress", onChange: "onChange" }, providers: [
3071
3152
  {
3072
3153
  provide: NG_VALUE_ACCESSOR,
3073
3154
  multi: true,
@@ -3113,15 +3194,38 @@ class GoabInputNumber {
3113
3194
  (_keypress)="_onKeyPress($event)"
3114
3195
  [attr.trailingiconarialabel]="trailingIconAriaLabel"
3115
3196
  >
3197
+ <div slot="leadingContent">
3198
+ <ng-container *ngIf="leadingContent">
3199
+ <ng-container *ngIf="getLeadingContentAsTemplate(); else stringLeading">
3200
+ <ng-container
3201
+ [ngTemplateOutlet]="getLeadingContentAsTemplate()"
3202
+ ></ng-container>
3203
+ </ng-container>
3204
+ <ng-template #stringLeading>{{ getLeadingContentAsString() }}</ng-template>
3205
+ </ng-container>
3206
+ </div>
3207
+
3116
3208
  <ng-content />
3209
+
3210
+ <div slot="trailingContent">
3211
+ <ng-container *ngIf="trailingContent">
3212
+ <ng-container *ngIf="getTrailingContentAsTemplate(); else stringTrailing">
3213
+ <ng-container
3214
+ [ngTemplateOutlet]="getTrailingContentAsTemplate()"
3215
+ ></ng-container>
3216
+ </ng-container>
3217
+ <ng-template #stringTrailing>{{ getTrailingContentAsString() }}</ng-template>
3218
+ </ng-container>
3219
+ </div>
3117
3220
  </goa-input>
3118
- `, isInline: true }); }
3221
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
3119
3222
  }
3120
3223
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: GoabInputNumber, decorators: [{
3121
3224
  type: Component,
3122
3225
  args: [{
3123
3226
  standalone: true,
3124
3227
  selector: "goab-input-number",
3228
+ imports: [NgIf, NgTemplateOutlet],
3125
3229
  template: `
3126
3230
  <goa-input
3127
3231
  [attr.type]="type"
@@ -3161,7 +3265,29 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
3161
3265
  (_keypress)="_onKeyPress($event)"
3162
3266
  [attr.trailingiconarialabel]="trailingIconAriaLabel"
3163
3267
  >
3268
+ <div slot="leadingContent">
3269
+ <ng-container *ngIf="leadingContent">
3270
+ <ng-container *ngIf="getLeadingContentAsTemplate(); else stringLeading">
3271
+ <ng-container
3272
+ [ngTemplateOutlet]="getLeadingContentAsTemplate()"
3273
+ ></ng-container>
3274
+ </ng-container>
3275
+ <ng-template #stringLeading>{{ getLeadingContentAsString() }}</ng-template>
3276
+ </ng-container>
3277
+ </div>
3278
+
3164
3279
  <ng-content />
3280
+
3281
+ <div slot="trailingContent">
3282
+ <ng-container *ngIf="trailingContent">
3283
+ <ng-container *ngIf="getTrailingContentAsTemplate(); else stringTrailing">
3284
+ <ng-container
3285
+ [ngTemplateOutlet]="getTrailingContentAsTemplate()"
3286
+ ></ng-container>
3287
+ </ng-container>
3288
+ <ng-template #stringTrailing>{{ getTrailingContentAsString() }}</ng-template>
3289
+ </ng-container>
3290
+ </div>
3165
3291
  </goa-input>
3166
3292
  `,
3167
3293
  schemas: [CUSTOM_ELEMENTS_SCHEMA],
@@ -3241,6 +3367,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
3241
3367
  type: Input
3242
3368
  }], value: [{
3243
3369
  type: Input
3370
+ }], leadingContent: [{
3371
+ type: Input
3372
+ }], trailingContent: [{
3373
+ type: Input
3244
3374
  }], onTrailingIconClick: [{
3245
3375
  type: Output
3246
3376
  }], onFocus: [{