@abgov/angular-components 4.7.0-alpha.3 → 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.
- package/esm2022/lib/components/input/input.mjs +70 -4
- package/esm2022/lib/components/input-number/input-number.mjs +70 -4
- package/fesm2022/abgov-angular-components.mjs +134 -4
- package/fesm2022/abgov-angular-components.mjs.map +1 -1
- package/lib/components/input/input.d.ts +8 -2
- package/lib/components/input-number/input-number.d.ts +8 -2
- package/package.json +1 -1
|
@@ -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":"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","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":"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","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 {
|
|
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":"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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 { 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: [{
|