ember-headless-form 1.0.0-beta.0 → 1.0.0-beta.2
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/dist/-private/components/control/checkbox.d.ts.map +1 -1
- package/dist/-private/components/control/checkbox.js +18 -5
- package/dist/-private/components/control/checkbox.js.map +1 -1
- package/dist/-private/components/control/input.d.ts +2 -2
- package/dist/-private/components/control/input.js +20 -6
- package/dist/-private/components/control/input.js.map +1 -1
- package/dist/-private/components/control/radio-group/label.d.ts +15 -0
- package/dist/-private/components/control/radio-group/label.js +10 -0
- package/dist/-private/components/control/radio-group/label.js.map +1 -0
- package/dist/-private/components/control/radio-group/radio/input.d.ts +13 -0
- package/dist/-private/components/control/radio-group/radio/input.js +26 -0
- package/dist/-private/components/control/radio-group/radio/input.js.map +1 -0
- package/dist/-private/components/control/{radio.d.ts → radio-group/radio.d.ts} +4 -6
- package/dist/-private/components/control/radio-group/radio.js +41 -0
- package/dist/-private/components/control/radio-group/radio.js.map +1 -0
- package/dist/-private/components/control/radio-group.d.ts +27 -0
- package/dist/-private/components/control/radio-group.js +44 -0
- package/dist/-private/components/control/radio-group.js.map +1 -0
- package/dist/-private/components/control/select/option.js +15 -3
- package/dist/-private/components/control/select/option.js.map +1 -1
- package/dist/-private/components/control/select.d.ts +2 -3
- package/dist/-private/components/control/select.js +29 -10
- package/dist/-private/components/control/select.js.map +1 -1
- package/dist/-private/components/control/textarea.js +17 -5
- package/dist/-private/components/control/textarea.js.map +1 -1
- package/dist/-private/components/errors.js +15 -3
- package/dist/-private/components/errors.js.map +1 -1
- package/dist/-private/components/field.d.ts +8 -3
- package/dist/-private/components/field.js +96 -9
- package/dist/-private/components/field.js.map +1 -1
- package/dist/-private/components/label.d.ts +3 -2
- package/dist/-private/components/label.js +9 -5
- package/dist/-private/components/label.js.map +1 -1
- package/dist/-private/utils.d.ts +2 -1
- package/dist/-private/utils.js +10 -1
- package/dist/-private/utils.js.map +1 -1
- package/dist/components/headless-form.d.ts +14 -1
- package/dist/components/headless-form.js +48 -6
- package/dist/components/headless-form.js.map +1 -1
- package/package.json +11 -7
- package/dist/-private/components/control/radio/input.d.ts +0 -12
- package/dist/-private/components/control/radio/input.js +0 -10
- package/dist/-private/components/control/radio/input.js.map +0 -1
- package/dist/-private/components/control/radio.js +0 -23
- package/dist/-private/components/control/radio.js.map +0 -1
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"option.js","sources":["../../../../../src/-private/components/control/select/option.
|
1
|
+
{"version":3,"file":"option.js","sources":["../../../../../src/-private/components/control/select/option.ts"],"sourcesContent":["import Component from '@glimmer/component';\n\nexport interface HeadlessFormControlSelectOptionComponentSignature {\n Element: HTMLOptionElement;\n Args: {\n /**\n * The select's value when this option is selected\n */\n value: string;\n\n // the following are private arguments curried by the component helper, so users will never have to use those\n\n /*\n * @internal\n */\n selected: string;\n };\n Blocks: {\n default: [];\n };\n}\n\nexport default class HeadlessFormControlSelectOptionComponent extends Component<HeadlessFormControlSelectOptionComponentSignature> {\n get isSelected(): boolean {\n return this.args.selected === this.args.value;\n }\n\n [__GLIMMER_TEMPLATE(`\n {{!\nEmber seems to insist to set \\`selected\\` as a property instead of an attribute.\nBut an attribute is needed if you want to use this with SSR/FastBoot, so the selected option is preselected before JS has loaded.\nUsing this wonky workaround for now.\nSee https://github.com/emberjs/ember.js/issues/19115\n}}\n {{#if this.isSelected}}\n <option value={{@value}} selected ...attributes>{{yield}}</option>\n {{else}}\n <option value={{@value}} ...attributes>{{yield}}</option>\n {{/if}}\n `, { strictMode: true })]\n}\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9uLmpzIiwic291cmNlcyI6WyJvcHRpb24uZ3RzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBDb21wb25lbnQgZnJvbSAnQGdsaW1tZXIvY29tcG9uZW50JztcblxuZXhwb3J0IGludGVyZmFjZSBIZWFkbGVzc0Zvcm1Db250cm9sU2VsZWN0T3B0aW9uQ29tcG9uZW50U2lnbmF0dXJlIHtcbiAgRWxlbWVudDogSFRNTE9wdGlvbkVsZW1lbnQ7XG4gIEFyZ3M6IHtcbiAgICAvKipcbiAgICAgKiBUaGUgc2VsZWN0J3MgdmFsdWUgd2hlbiB0aGlzIG9wdGlvbiBpcyBzZWxlY3RlZFxuICAgICAqL1xuICAgIHZhbHVlOiBzdHJpbmc7XG5cbiAgICAvLyB0aGUgZm9sbG93aW5nIGFyZSBwcml2YXRlIGFyZ3VtZW50cyBjdXJyaWVkIGJ5IHRoZSBjb21wb25lbnQgaGVscGVyLCBzbyB1c2VycyB3aWxsIG5ldmVyIGhhdmUgdG8gdXNlIHRob3NlXG5cbiAgICAvKlxuICAgICAqIEBpbnRlcm5hbFxuICAgICAqL1xuICAgIHNlbGVjdGVkOiBzdHJpbmc7XG4gIH07XG4gIEJsb2Nrczoge1xuICAgIGRlZmF1bHQ6IFtdO1xuICB9O1xufVxuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBIZWFkbGVzc0Zvcm1Db250cm9sU2VsZWN0T3B0aW9uQ29tcG9uZW50IGV4dGVuZHMgQ29tcG9uZW50PEhlYWRsZXNzRm9ybUNvbnRyb2xTZWxlY3RPcHRpb25Db21wb25lbnRTaWduYXR1cmU+IHtcbiAgZ2V0IGlzU2VsZWN0ZWQoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuYXJncy5zZWxlY3RlZCA9PT0gdGhpcy5hcmdzLnZhbHVlO1xuICB9XG5cbiAgPHRlbXBsYXRlPlxuICAgIHt7IVxuRW1iZXIgc2VlbXMgdG8gaW5zaXN0IHRvIHNldCBcXGBzZWxlY3RlZFxcYCBhcyBhIHByb3BlcnR5IGluc3RlYWQgb2YgYW4gYXR0cmlidXRlLlxuQnV0IGFuIGF0dHJpYnV0ZSBpcyBuZWVkZWQgaWYgeW91IHdhbnQgdG8gdXNlIHRoaXMgd2l0aCBTU1IvRmFzdEJvb3QsIHNvIHRoZSBzZWxlY3RlZCBvcHRpb24gaXMgcHJlc2VsZWN0ZWQgYmVmb3JlIEpTIGhhcyBsb2FkZWQuXG5Vc2luZyB0aGlzIHdvbmt5IHdvcmthcm91bmQgZm9yIG5vdy5cblNlZSBodHRwczovL2dpdGh1Yi5jb20vZW1iZXJqcy9lbWJlci5qcy9pc3N1ZXMvMTkxMTVcbn19XG4gICAge3sjaWYgdGhpcy5pc1NlbGVjdGVkfX1cbiAgICAgIDxvcHRpb24gdmFsdWU9e3tAdmFsdWV9fSBzZWxlY3RlZCAuLi5hdHRyaWJ1dGVzPnt7eWllbGR9fTwvb3B0aW9uPlxuICAgIHt7ZWxzZX19XG4gICAgICA8b3B0aW9uIHZhbHVlPXt7QHZhbHVlfX0gLi4uYXR0cmlidXRlcz57e3lpZWxkfX08L29wdGlvbj5cbiAgICB7ey9pZn19XG4gIDwvdGVtcGxhdGU+XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUMzQztBQUNBLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNwRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDN0IsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDVCxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ1AsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDdEQsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNQLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ2xCO0FBQ0EsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ2pIO0FBQ0EsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDTixDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ2hCLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNyQixDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ0osQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ1gsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNoQixDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ0osQ0FBQztBQUNEO0FBQ0EsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDcEksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQzdCLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNsRCxDQUFDLENBQUMsQ0FBQztBQUNIO0FBQ0EsQ0FBQyxDQUFDLHFCQUFVO0FBQ1o7Ozs7Ozs7Ozs7O0NBV0MsQ0FBQyx5QkFBVztBQUNiLENBQUM7In0="],"names":["HeadlessFormControlSelectOptionComponent","Component","isSelected","args","selected","value","setComponentTemplate","precompileTemplate","strictMode"],"mappings":";;;;AAsBe,MAAMA,wCAAwC,SAASC,SAAS,CAAoD;EACjI,IAAIC,UAAUA,GAAY;IACxB,OAAO,IAAI,CAACC,IAAI,CAACC,QAAQ,KAAK,IAAI,CAACD,IAAI,CAACE,KAAK,CAAA;AAC/C,GAAA;AAeF,CAAA;AAACC,oBAAA,CAAAC,kBAAA,CAbW,CAAA;AACZ;;;;;;;;;;;AAWE,EAAA,CAAA,EAAA;EAAAC,UAAA,EAAA,IAAA;AAAA,CAAA,CAAA,EAjBmBR,wCAAwC,CAAA;;;;"}
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import Component from '@glimmer/component';
|
2
|
-
import
|
2
|
+
import HeadlessFormControlSelectOptionComponent from "./select/option.js";
|
3
3
|
import { WithBoundArgs } from '@glint/template';
|
4
4
|
interface HeadlessFormControlSelectComponentSignature {
|
5
5
|
Element: HTMLSelectElement;
|
@@ -14,13 +14,12 @@ interface HeadlessFormControlSelectComponentSignature {
|
|
14
14
|
Blocks: {
|
15
15
|
default: [
|
16
16
|
{
|
17
|
-
Option: WithBoundArgs<typeof
|
17
|
+
Option: WithBoundArgs<typeof HeadlessFormControlSelectOptionComponent, 'selected'>;
|
18
18
|
}
|
19
19
|
];
|
20
20
|
};
|
21
21
|
}
|
22
22
|
declare class HeadlessFormControlSelectComponent extends Component<HeadlessFormControlSelectComponentSignature> {
|
23
|
-
OptionComponent: typeof OptionComponent;
|
24
23
|
handleInput(e: Event | InputEvent): void;
|
25
24
|
}
|
26
25
|
export { HeadlessFormControlSelectComponentSignature, HeadlessFormControlSelectComponent as default };
|
@@ -1,24 +1,43 @@
|
|
1
|
-
import _defineProperty from '@babel/runtime/helpers/esm/defineProperty';
|
2
1
|
import _applyDecoratedDescriptor from '@babel/runtime/helpers/esm/applyDecoratedDescriptor';
|
3
2
|
import { setComponentTemplate } from '@ember/component';
|
4
3
|
import { precompileTemplate } from '@ember/template-compilation';
|
5
4
|
import Component from '@glimmer/component';
|
5
|
+
import { hash } from '@ember/helper';
|
6
|
+
import { on } from '@ember/modifier';
|
6
7
|
import { action } from '@ember/object';
|
7
8
|
import HeadlessFormControlSelectOptionComponent from './select/option.js';
|
8
9
|
|
9
|
-
var TEMPLATE = precompileTemplate("<select\n name={{@name}}\n value={{@value}}\n id={{@fieldId}}\n aria-invalid={{if @invalid \'true\'}}\n aria-errormessage={{if @invalid @errorId}}\n ...attributes\n {{on \'input\' this.handleInput}}\n>\n {{yield\n (hash\n Option=(component\n (ensure-safe-component this.OptionComponent) selected=@value\n )\n )\n }}\n</select>");
|
10
|
-
|
11
10
|
var _class;
|
12
|
-
let HeadlessFormControlSelectComponent = (
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
11
|
+
let HeadlessFormControlSelectComponent = setComponentTemplate(precompileTemplate(`
|
12
|
+
<select
|
13
|
+
name={{@name}}
|
14
|
+
value={{@value}}
|
15
|
+
id={{@fieldId}}
|
16
|
+
aria-invalid={{if @invalid "true"}}
|
17
|
+
aria-describedby={{if @invalid @errorId}}
|
18
|
+
...attributes
|
19
|
+
{{on "input" this.handleInput}}
|
20
|
+
>
|
21
|
+
{{yield
|
22
|
+
(hash
|
23
|
+
Option=(component
|
24
|
+
HeadlessFormControlSelectOptionComponent selected=@value
|
25
|
+
)
|
26
|
+
)
|
27
|
+
}}
|
28
|
+
</select>
|
29
|
+
`, {
|
30
|
+
strictMode: true,
|
31
|
+
scope: () => ({
|
32
|
+
on,
|
33
|
+
hash,
|
34
|
+
HeadlessFormControlSelectOptionComponent
|
35
|
+
})
|
36
|
+
}), (_class = class HeadlessFormControlSelectComponent extends Component {
|
17
37
|
handleInput(e) {
|
18
38
|
this.args.setValue(e.target.value);
|
19
39
|
}
|
20
|
-
}, (_applyDecoratedDescriptor(_class.prototype, "handleInput", [action], Object.getOwnPropertyDescriptor(_class.prototype, "handleInput"), _class.prototype)), _class);
|
21
|
-
setComponentTemplate(TEMPLATE, HeadlessFormControlSelectComponent);
|
40
|
+
}, (_applyDecoratedDescriptor(_class.prototype, "handleInput", [action], Object.getOwnPropertyDescriptor(_class.prototype, "handleInput"), _class.prototype)), _class));
|
22
41
|
|
23
42
|
export { HeadlessFormControlSelectComponent as default };
|
24
43
|
//# sourceMappingURL=select.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"select.js","sources":["../../../../src/-private/components/control/select.hbs.js","../../../../src/-private/components/control/select.ts"],"sourcesContent":["import { precompileTemplate } from \"@ember/template-compilation\";\nexport default precompileTemplate(\"<select\\n name={{@name}}\\n value={{@value}}\\n id={{@fieldId}}\\n aria-invalid={{if @invalid \\'true\\'}}\\n aria-errormessage={{if @invalid @errorId}}\\n ...attributes\\n {{on \\'input\\' this.handleInput}}\\n>\\n {{yield\\n (hash\\n Option=(component\\n (ensure-safe-component this.OptionComponent) selected=@value\\n )\\n )\\n }}\\n</select>\")","import Component from '@glimmer/component';\nimport { action } from '@ember/object';\n\nimport OptionComponent from './select/option';\n\nimport type { WithBoundArgs } from '@glint/template';\n\nexport interface HeadlessFormControlSelectComponentSignature {\n Element: HTMLSelectElement;\n Args: {\n // the following are private arguments curried by the component helper, so users will never have to use those\n\n /*\n * @internal\n */\n value: string;\n\n /*\n * @internal\n */\n name: string;\n\n /*\n * @internal\n */\n fieldId: string;\n\n /*\n * @internal\n */\n setValue: (value: string) => void;\n\n /*\n * @internal\n */\n invalid: boolean;\n\n /*\n * @internal\n */\n errorId: string;\n };\n Blocks: {\n default: [\n {\n Option: WithBoundArgs<typeof OptionComponent, 'selected'>;\n }\n ];\n };\n}\n\nexport default class HeadlessFormControlSelectComponent extends Component<HeadlessFormControlSelectComponentSignature> {\n OptionComponent = OptionComponent;\n\n @action\n handleInput(e: Event | InputEvent): void {\n this.args.setValue((e.target as HTMLSelectElement).value);\n }\n}\n"],"names":["precompileTemplate","HeadlessFormControlSelectComponent","Component","OptionComponent","handleInput","e","args","setValue","target","value","action"],"mappings":";;;;;;;;AACA,eAAeA,kBAAkB,CAAC,wWAAwW,CAAC;;;ACE7V,IAgDzBC,kCAAkC,IAAxC,MAAA,GAAA,MAAMA,kCAAkC,SAASC,SAAS,CAA8C;AAAA,EAAA,WAAA,CAAA,GAAA,IAAA,EAAA;AAAA,IAAA,KAAA,CAAA,GAAA,IAAA,CAAA,CAAA;AAAA,IAAA,eAAA,CAAA,IAAA,EAAA,iBAAA,EACnGC,wCAAe,CAAA,CAAA;AAAA,GAAA;EAGjCC,WAAW,CAACC,CAAqB,EAAQ;IACvC,IAAI,CAACC,IAAI,CAACC,QAAQ,CAAEF,CAAC,CAACG,MAAM,CAAuBC,KAAK,CAAC,CAAA;AAC3D,GAAA;AACF,CAAC,+DAJEC,MAAM,CAAA,EAAA,MAAA,CAAA,wBAAA,CAAA,MAAA,CAAA,SAAA,EAAA,aAAA,CAAA,EAAA,MAAA,CAAA,SAAA,CAAA,GAAA,MAAA,EAAA;AAH8C,oBAAA,CAAA,QAAA,EAAA,kCAAA,CAAA;;;;"}
|
1
|
+
{"version":3,"file":"select.js","sources":["../../../../src/-private/components/control/select.ts"],"sourcesContent":["import Component from '@glimmer/component';\nimport { hash } from '@ember/helper';\nimport { on } from '@ember/modifier';\nimport { action } from '@ember/object';\n\nimport HeadlessFormControlSelectOptionComponent from './select/option';\n\nimport type { WithBoundArgs } from '@glint/template';\n\nexport interface HeadlessFormControlSelectComponentSignature {\n Element: HTMLSelectElement;\n Args: {\n // the following are private arguments curried by the component helper, so users will never have to use those\n\n /*\n * @internal\n */\n value: string;\n\n /*\n * @internal\n */\n name: string;\n\n /*\n * @internal\n */\n fieldId: string;\n\n /*\n * @internal\n */\n setValue: (value: string) => void;\n\n /*\n * @internal\n */\n invalid: boolean;\n\n /*\n * @internal\n */\n errorId: string;\n };\n Blocks: {\n default: [\n {\n Option: WithBoundArgs<\n typeof HeadlessFormControlSelectOptionComponent,\n 'selected'\n >;\n }\n ];\n };\n}\n\nexport default class HeadlessFormControlSelectComponent extends Component<HeadlessFormControlSelectComponentSignature> {\n @action\n handleInput(e: Event | InputEvent): void {\n this.args.setValue((e.target as HTMLSelectElement).value);\n }\n\n [__GLIMMER_TEMPLATE(`\n <select\n name={{@name}}\n value={{@value}}\n id={{@fieldId}}\n aria-invalid={{if @invalid \"true\"}}\n aria-describedby={{if @invalid @errorId}}\n ...attributes\n {{on \"input\" this.handleInput}}\n >\n {{yield\n (hash\n Option=(component\n HeadlessFormControlSelectOptionComponent selected=@value\n )\n )\n }}\n </select>\n `, { strictMode: true, scope: () => ({on,hash,HeadlessFormControlSelectOptionComponent}) })]\n}\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"select.js","sources":["select.gts"],"sourcesContent":["import Component from '@glimmer/component';\nimport { hash } from '@ember/helper';\nimport { on } from '@ember/modifier';\nimport { action } from '@ember/object';\n\nimport HeadlessFormControlSelectOptionComponent from './select/option';\n\nimport type { WithBoundArgs } from '@glint/template';\n\nexport interface HeadlessFormControlSelectComponentSignature {\n  Element: HTMLSelectElement;\n  Args: {\n    // the following are private arguments curried by the component helper, so users will never have to use those\n\n    /*\n     * @internal\n     */\n    value: string;\n\n    /*\n     * @internal\n     */\n    name: string;\n\n    /*\n     * @internal\n     */\n    fieldId: string;\n\n    /*\n     * @internal\n     */\n    setValue: (value: string) => void;\n\n    /*\n     * @internal\n     */\n    invalid: boolean;\n\n    /*\n     * @internal\n     */\n    errorId: string;\n  };\n  Blocks: {\n    default: [\n      {\n        Option: WithBoundArgs<\n          typeof HeadlessFormControlSelectOptionComponent,\n          'selected'\n        >;\n      }\n    ];\n  };\n}\n\nexport default class HeadlessFormControlSelectComponent extends Component<HeadlessFormControlSelectComponentSignature> {\n  @action\n  handleInput(e: Event | InputEvent): void {\n    this.args.setValue((e.target as HTMLSelectElement).value);\n  }\n\n  <template>\n    <select\n      name={{@name}}\n      value={{@value}}\n      id={{@fieldId}}\n      aria-invalid={{if @invalid \"true\"}}\n      aria-describedby={{if @invalid @errorId}}\n      ...attributes\n      {{on \"input\" this.handleInput}}\n    >\n      {{yield\n        (hash\n          Option=(component\n            HeadlessFormControlSelectOptionComponent selected=@value\n          )\n        )\n      }}\n    </select>\n  </template>\n}\n"],"names":[],"mappings":"AAAA,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAC3C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACrC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACrC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACvC;AACA,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACvE;AACA,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACrD;AACA,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAC9D,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAC7B,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACT,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACjH;AACA,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACN,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAChB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAClB;AACA,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACN,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAChB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACjB;AACA,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACN,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAChB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACpB;AACA,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACN,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAChB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC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"}"],"names":["HeadlessFormControlSelectComponent","setComponentTemplate","precompileTemplate","strictMode","scope","on","hash","HeadlessFormControlSelectOptionComponent","_class","Component","handleInput","e","args","setValue","target","value","_applyDecoratedDescriptor","prototype","action","Object","getOwnPropertyDescriptor"],"mappings":";;;;;;;;;;AAKuE,IAmDlDA,kCAAkC,GAAAC,oBAAA,CAAAC,kBAAA,CAM3C,CAAA;AACZ;;;;;;;;;;;;;;;;;AAiBE,EAAA,CAAA,EAAA;EAAAC,UAAA,EAAA,IAAA;AAAAC,EAAAA,KAAA,EAAAA,OAAA;IAAAC,EAAA;IAAAC,IAAA;AAAAC,IAAAA,wCAAAA;AAAA,GAAA,CAAA;AAAA,CAAA,CAAA,GAAAC,MAAA,GAxBa,MAAMR,kCAAkC,SAASS,SAAS,CAA8C;EAErHC,WAAWA,CAACC,CAAqB,EAAQ;IACvC,IAAI,CAACC,IAAI,CAACC,QAAQ,CAAEF,CAAC,CAACG,MAAM,CAAuBC,KAAK,CAAC,CAAA;AAC3D,GAAA;AAqBF,CAAC,GAAAC,yBAAA,CAAAR,MAAA,CAAAS,SAAA,EAAA,aAAA,EAAA,CAxBEC,MAAM,CAAAC,EAAAA,MAAA,CAAAC,wBAAA,CAAAZ,MAAA,CAAAS,SAAA,kBAAAT,MAAA,CAAAS,SAAA,CAAA,GAAAT,MAAA;;;;"}
|
@@ -2,17 +2,29 @@ import _applyDecoratedDescriptor from '@babel/runtime/helpers/esm/applyDecorated
|
|
2
2
|
import { setComponentTemplate } from '@ember/component';
|
3
3
|
import { precompileTemplate } from '@ember/template-compilation';
|
4
4
|
import Component from '@glimmer/component';
|
5
|
+
import { on } from '@ember/modifier';
|
5
6
|
import { action } from '@ember/object';
|
6
7
|
|
7
|
-
var TEMPLATE = precompileTemplate("<textarea\n name={{@name}}\n id={{@fieldId}}\n aria-invalid={{if @invalid \'true\'}}\n aria-errormessage={{if @invalid @errorId}}\n ...attributes\n {{on \'input\' this.handleInput}}\n>{{@value}}</textarea>");
|
8
|
-
|
9
8
|
var _class;
|
10
|
-
let HeadlessFormControlTextareaComponent = (
|
9
|
+
let HeadlessFormControlTextareaComponent = setComponentTemplate(precompileTemplate(`
|
10
|
+
<textarea
|
11
|
+
name={{@name}}
|
12
|
+
id={{@fieldId}}
|
13
|
+
aria-invalid={{if @invalid "true"}}
|
14
|
+
aria-describedby={{if @invalid @errorId}}
|
15
|
+
...attributes
|
16
|
+
{{on "input" this.handleInput}}
|
17
|
+
>{{@value}}</textarea>
|
18
|
+
`, {
|
19
|
+
strictMode: true,
|
20
|
+
scope: () => ({
|
21
|
+
on
|
22
|
+
})
|
23
|
+
}), (_class = class HeadlessFormControlTextareaComponent extends Component {
|
11
24
|
handleInput(e) {
|
12
25
|
this.args.setValue(e.target.value);
|
13
26
|
}
|
14
|
-
}, (_applyDecoratedDescriptor(_class.prototype, "handleInput", [action], Object.getOwnPropertyDescriptor(_class.prototype, "handleInput"), _class.prototype)), _class);
|
15
|
-
setComponentTemplate(TEMPLATE, HeadlessFormControlTextareaComponent);
|
27
|
+
}, (_applyDecoratedDescriptor(_class.prototype, "handleInput", [action], Object.getOwnPropertyDescriptor(_class.prototype, "handleInput"), _class.prototype)), _class));
|
16
28
|
|
17
29
|
export { HeadlessFormControlTextareaComponent as default };
|
18
30
|
//# sourceMappingURL=textarea.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"textarea.js","sources":["../../../../src/-private/components/control/textarea.hbs.js","../../../../src/-private/components/control/textarea.ts"],"sourcesContent":["import { precompileTemplate } from \"@ember/template-compilation\";\nexport default precompileTemplate(\"<textarea\\n name={{@name}}\\n id={{@fieldId}}\\n aria-invalid={{if @invalid \\'true\\'}}\\n aria-errormessage={{if @invalid @errorId}}\\n ...attributes\\n {{on \\'input\\' this.handleInput}}\\n>{{@value}}</textarea>\")","import Component from '@glimmer/component';\nimport { action } from '@ember/object';\n\nexport interface HeadlessFormControlTextareaComponentSignature {\n Element: HTMLTextAreaElement;\n Args: {\n // the following are private arguments curried by the component helper, so users will never have to use those\n\n /*\n * @internal\n */\n value: string;\n\n /*\n * @internal\n */\n name: string;\n\n /*\n * @internal\n */\n fieldId: string;\n\n /*\n * @internal\n */\n setValue: (value: string) => void;\n\n /*\n * @internal\n */\n invalid: boolean;\n\n /*\n * @internal\n */\n errorId: string;\n };\n}\n\nexport default class HeadlessFormControlTextareaComponent extends Component<HeadlessFormControlTextareaComponentSignature> {\n @action\n handleInput(e: Event | InputEvent): void {\n this.args.setValue((e.target as HTMLTextAreaElement).value);\n }\n}\n"],"names":["precompileTemplate","HeadlessFormControlTextareaComponent","Component","handleInput","e","args","setValue","target","value","action"],"mappings":";;;;;;AACA,eAAeA,kBAAkB,CAAC,qNAAqN,CAAC;;;ACAjN,IAuClBC,oCAAoC,IAA1C,MAAA,GAAA,MAAMA,oCAAoC,SAASC,SAAS,CAAgD;EAEzHC,WAAW,CAACC,CAAqB,EAAQ;IACvC,IAAI,CAACC,IAAI,CAACC,QAAQ,CAAEF,CAAC,CAACG,MAAM,CAAyBC,KAAK,CAAC,CAAA;AAC7D,GAAA;AACF,CAAC,+DAJEC,MAAM,CAAA,EAAA,MAAA,CAAA,wBAAA,CAAA,MAAA,CAAA,SAAA,EAAA,aAAA,CAAA,EAAA,MAAA,CAAA,SAAA,CAAA,GAAA,MAAA,EAAA;AADgD,oBAAA,CAAA,QAAA,EAAA,oCAAA,CAAA;;;;"}
|
1
|
+
{"version":3,"file":"textarea.js","sources":["../../../../src/-private/components/control/textarea.ts"],"sourcesContent":["import Component from '@glimmer/component';\nimport { on } from '@ember/modifier';\nimport { action } from '@ember/object';\n\nexport interface HeadlessFormControlTextareaComponentSignature {\n Element: HTMLTextAreaElement;\n Args: {\n // the following are private arguments curried by the component helper, so users will never have to use those\n\n /*\n * @internal\n */\n value: string;\n\n /*\n * @internal\n */\n name: string;\n\n /*\n * @internal\n */\n fieldId: string;\n\n /*\n * @internal\n */\n setValue: (value: string) => void;\n\n /*\n * @internal\n */\n invalid: boolean;\n\n /*\n * @internal\n */\n errorId: string;\n };\n}\n\nexport default class HeadlessFormControlTextareaComponent extends Component<HeadlessFormControlTextareaComponentSignature> {\n @action\n handleInput(e: Event | InputEvent): void {\n this.args.setValue((e.target as HTMLTextAreaElement).value);\n }\n\n [__GLIMMER_TEMPLATE(`\n <textarea\n name={{@name}}\n id={{@fieldId}}\n aria-invalid={{if @invalid \"true\"}}\n aria-describedby={{if @invalid @errorId}}\n ...attributes\n {{on \"input\" this.handleInput}}\n >{{@value}}</textarea>\n `, { strictMode: true, scope: () => ({on}) })]\n}\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"textarea.js","sources":["textarea.gts"],"sourcesContent":["import Component from '@glimmer/component';\nimport { on } from '@ember/modifier';\nimport { action } from '@ember/object';\n\nexport interface HeadlessFormControlTextareaComponentSignature {\n  Element: HTMLTextAreaElement;\n  Args: {\n    // the following are private arguments curried by the component helper, so users will never have to use those\n\n    /*\n     * @internal\n     */\n    value: string;\n\n    /*\n     * @internal\n     */\n    name: string;\n\n    /*\n     * @internal\n     */\n    fieldId: string;\n\n    /*\n     * @internal\n     */\n    setValue: (value: string) => void;\n\n    /*\n     * @internal\n     */\n    invalid: boolean;\n\n    /*\n     * @internal\n     */\n    errorId: string;\n  };\n}\n\nexport default class HeadlessFormControlTextareaComponent extends Component<HeadlessFormControlTextareaComponentSignature> {\n  @action\n  handleInput(e: Event | InputEvent): void {\n    this.args.setValue((e.target as HTMLTextAreaElement).value);\n  }\n\n  <template>\n    <textarea\n      name={{@name}}\n      id={{@fieldId}}\n      aria-invalid={{if @invalid \"true\"}}\n      aria-describedby={{if @invalid @errorId}}\n      ...attributes\n      {{on \"input\" this.handleInput}}\n    >{{@value}}</textarea>\n  </template>\n}\n"],"names":[],"mappings":"AAAA,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAC3C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACrC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACvC;AACA,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAChE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAC/B,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACT,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACjH;AACA,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACN,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAChB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAClB;AACA,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACN,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAChB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACjB;AACA,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACN,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAChB,CAAC,CAAC,CAAC,CAAC,CAAC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"}"],"names":["HeadlessFormControlTextareaComponent","setComponentTemplate","precompileTemplate","strictMode","scope","on","_class","Component","handleInput","e","args","setValue","target","value","_applyDecoratedDescriptor","prototype","action","Object","getOwnPropertyDescriptor"],"mappings":";;;;;;;;AAEuC,IAuClBA,oCAAoC,GAAAC,oBAAA,CAAAC,kBAAA,CAM7C,CAAA;AACZ;;;;;;;;AAQE,EAAA,CAAA,EAAA;EAAAC,UAAA,EAAA,IAAA;AAAAC,EAAAA,KAAA,EAAAA,OAAA;AAAAC,IAAAA,EAAAA;AAAA,GAAA,CAAA;AAAA,CAAA,CAAA,GAAAC,MAAA,GAfa,MAAMN,oCAAoC,SAASO,SAAS,CAAgD;EAEzHC,WAAWA,CAACC,CAAqB,EAAQ;IACvC,IAAI,CAACC,IAAI,CAACC,QAAQ,CAAEF,CAAC,CAACG,MAAM,CAAyBC,KAAK,CAAC,CAAA;AAC7D,GAAA;AAYF,CAAC,GAAAC,yBAAA,CAAAR,MAAA,CAAAS,SAAA,EAAA,aAAA,EAAA,CAfEC,MAAM,CAAAC,EAAAA,MAAA,CAAAC,wBAAA,CAAAZ,MAAA,CAAAS,SAAA,kBAAAT,MAAA,CAAAS,SAAA,CAAA,GAAAT,MAAA;;;;"}
|
@@ -2,11 +2,23 @@ import { setComponentTemplate } from '@ember/component';
|
|
2
2
|
import { precompileTemplate } from '@ember/template-compilation';
|
3
3
|
import Component from '@glimmer/component';
|
4
4
|
|
5
|
-
var TEMPLATE = precompileTemplate("<div id={{@id}} aria-live=\'assertive\' ...attributes>\n {{#if (has-block)}}\n {{yield @errors}}\n {{else}}\n {{#each @errors as |e|}}\n {{#if e.message}}\n {{e.message}}<br />\n {{/if}}\n {{/each}}\n {{/if}}\n</div>");
|
6
|
-
|
7
5
|
// eslint-disable-next-line ember/no-empty-glimmer-component-classes -- unfortunately we cannot use templateOnlyComponent() here, as it is not possible to type that as a generic type, like templateOnlyComponent<HeadlessFormErrorsComponentSignature<VALUE>>
|
8
6
|
class HeadlessFormErrorsComponent extends Component {}
|
9
|
-
setComponentTemplate(
|
7
|
+
setComponentTemplate(precompileTemplate(`
|
8
|
+
<div id={{@id}} aria-live="assertive" ...attributes>
|
9
|
+
{{#if (has-block)}}
|
10
|
+
{{yield @errors}}
|
11
|
+
{{else}}
|
12
|
+
{{#each @errors as |e|}}
|
13
|
+
{{#if e.message}}
|
14
|
+
{{e.message}}<br />
|
15
|
+
{{/if}}
|
16
|
+
{{/each}}
|
17
|
+
{{/if}}
|
18
|
+
</div>
|
19
|
+
`, {
|
20
|
+
strictMode: true
|
21
|
+
}), HeadlessFormErrorsComponent);
|
10
22
|
|
11
23
|
export { HeadlessFormErrorsComponent as default };
|
12
24
|
//# sourceMappingURL=errors.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"errors.js","sources":["../../../src/-private/components/errors.
|
1
|
+
{"version":3,"file":"errors.js","sources":["../../../src/-private/components/errors.ts"],"sourcesContent":["import Component from '@glimmer/component';\n\nimport type { ValidationError } from '../types';\n\nexport interface HeadlessFormErrorsComponentSignature<VALUE> {\n Element: HTMLDivElement;\n Args: {\n // the following are private arguments curried by the component helper, so users will never have to use those\n\n /*\n * @internal\n */\n errors: ValidationError<VALUE>[];\n\n /*\n * @internal\n */\n id: string;\n };\n Blocks: {\n default?: [ValidationError<VALUE>[]];\n };\n}\n\n// eslint-disable-next-line ember/no-empty-glimmer-component-classes -- unfortunately we cannot use templateOnlyComponent() here, as it is not possible to type that as a generic type, like templateOnlyComponent<HeadlessFormErrorsComponentSignature<VALUE>>\nexport default class HeadlessFormErrorsComponent<VALUE> extends Component<\n HeadlessFormErrorsComponentSignature<VALUE>\n> {\n [__GLIMMER_TEMPLATE(`\n <div id={{@id}} aria-live=\"assertive\" ...attributes>\n {{#if (has-block)}}\n {{yield @errors}}\n {{else}}\n {{#each @errors as |e|}}\n {{#if e.message}}\n {{e.message}}<br />\n {{/if}}\n {{/each}}\n {{/if}}\n </div>\n `, { strictMode: true })]\n}\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlcyI6WyJlcnJvcnMuZ3RzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBDb21wb25lbnQgZnJvbSAnQGdsaW1tZXIvY29tcG9uZW50JztcblxuaW1wb3J0IHR5cGUgeyBWYWxpZGF0aW9uRXJyb3IgfSBmcm9tICcuLi90eXBlcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSGVhZGxlc3NGb3JtRXJyb3JzQ29tcG9uZW50U2lnbmF0dXJlPFZBTFVFPiB7XG4gIEVsZW1lbnQ6IEhUTUxEaXZFbGVtZW50O1xuICBBcmdzOiB7XG4gICAgLy8gdGhlIGZvbGxvd2luZyBhcmUgcHJpdmF0ZSBhcmd1bWVudHMgY3VycmllZCBieSB0aGUgY29tcG9uZW50IGhlbHBlciwgc28gdXNlcnMgd2lsbCBuZXZlciBoYXZlIHRvIHVzZSB0aG9zZVxuXG4gICAgLypcbiAgICAgKiBAaW50ZXJuYWxcbiAgICAgKi9cbiAgICBlcnJvcnM6IFZhbGlkYXRpb25FcnJvcjxWQUxVRT5bXTtcblxuICAgIC8qXG4gICAgICogQGludGVybmFsXG4gICAgICovXG4gICAgaWQ6IHN0cmluZztcbiAgfTtcbiAgQmxvY2tzOiB7XG4gICAgZGVmYXVsdD86IFtWYWxpZGF0aW9uRXJyb3I8VkFMVUU+W11dO1xuICB9O1xufVxuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgZW1iZXIvbm8tZW1wdHktZ2xpbW1lci1jb21wb25lbnQtY2xhc3NlcyAtLSB1bmZvcnR1bmF0ZWx5IHdlIGNhbm5vdCB1c2UgdGVtcGxhdGVPbmx5Q29tcG9uZW50KCkgaGVyZSwgYXMgaXQgaXMgbm90IHBvc3NpYmxlIHRvIHR5cGUgdGhhdCBhcyBhIGdlbmVyaWMgdHlwZSwgbGlrZSB0ZW1wbGF0ZU9ubHlDb21wb25lbnQ8SGVhZGxlc3NGb3JtRXJyb3JzQ29tcG9uZW50U2lnbmF0dXJlPFZBTFVFPj5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEhlYWRsZXNzRm9ybUVycm9yc0NvbXBvbmVudDxWQUxVRT4gZXh0ZW5kcyBDb21wb25lbnQ8XG4gIEhlYWRsZXNzRm9ybUVycm9yc0NvbXBvbmVudFNpZ25hdHVyZTxWQUxVRT5cbj4ge1xuICA8dGVtcGxhdGU+XG4gICAgPGRpdiBpZD17e0BpZH19IGFyaWEtbGl2ZT1cImFzc2VydGl2ZVwiIC4uLmF0dHJpYnV0ZXM+XG4gICAgICB7eyNpZiAoaGFzLWJsb2NrKX19XG4gICAgICAgIHt7eWllbGQgQGVycm9yc319XG4gICAgICB7e2Vsc2V9fVxuICAgICAgICB7eyNlYWNoIEBlcnJvcnMgYXMgfGV8fX1cbiAgICAgICAgICB7eyNpZiBlLm1lc3NhZ2V9fVxuICAgICAgICAgICAge3tlLm1lc3NhZ2V9fTxiciAvPlxuICAgICAgICAgIHt7L2lmfX1cbiAgICAgICAge3svZWFjaH19XG4gICAgICB7ey9pZn19XG4gICAgPC9kaXY+XG4gIDwvdGVtcGxhdGU+XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUMzQztBQUNBLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ2hEO0FBQ0EsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQzlELENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUMxQixDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNULENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNqSDtBQUNBLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ04sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNoQixDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ1AsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNyQztBQUNBLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ04sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNoQixDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ1AsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDZixDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ0osQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ1gsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ3pDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDSixDQUFDO0FBQ0Q7QUFDQSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUMvUCxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDMUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDN0MsQ0FBQyxDQUFDLENBQUM7QUFDSCxDQUFDLENBQUMscUJBQVU7QUFDWjs7Ozs7Ozs7Ozs7Q0FXQyxDQUFDLHlCQUFXO0FBQ2IsQ0FBQzsifQ=="],"names":["HeadlessFormErrorsComponent","Component","setComponentTemplate","precompileTemplate","strictMode"],"mappings":";;;;AAwBA;AACe,MAAMA,2BAA2B,SAAgBC,SAAS,CAEvE,EAAA;AAcDC,oBAAA,CAAAC,kBAAA,CAbW,CAAA;AACZ;;;;;;;;;;;AAWE,EAAA,CAAA,EAAA;EAAAC,UAAA,EAAA,IAAA;AAAA,CAAA,CAAA,EAfmBJ,2BAA2B,CAAA;;;;"}
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import Component from '@glimmer/component';
|
2
2
|
import CheckboxComponent from "./control/checkbox.js";
|
3
3
|
import InputComponent from "./control/input.js";
|
4
|
-
import
|
4
|
+
import RadioGroupComponent from "./control/radio-group.js";
|
5
5
|
import SelectComponent from "./control/select.js";
|
6
6
|
import TextareaComponent from "./control/textarea.js";
|
7
7
|
import ErrorsComponent from "./errors.js";
|
@@ -50,7 +50,7 @@ interface HeadlessFormFieldComponentSignature<DATA extends UserData, KEY extends
|
|
50
50
|
*
|
51
51
|
* Use multiple to define a radio group. It further yields components to render `Input` and `Label`.
|
52
52
|
*/
|
53
|
-
|
53
|
+
RadioGroup: WithBoundArgs<typeof RadioGroupComponent, 'name' | 'selected' | 'setValue' | 'invalid' | 'errorId'>;
|
54
54
|
/**
|
55
55
|
* Yielded control component that renders a `<select>` element.
|
56
56
|
*/
|
@@ -95,6 +95,10 @@ interface HeadlessFormFieldComponentSignature<DATA extends UserData, KEY extends
|
|
95
95
|
* You can use this to customize your markup, e.g. apply HTML classes for error styling.
|
96
96
|
*/
|
97
97
|
isInvalid: boolean;
|
98
|
+
/**
|
99
|
+
* An array of raw ValidationError objects, for custom rendering of error output
|
100
|
+
*/
|
101
|
+
rawErrors?: ValidationError<DATA[KEY]>[];
|
98
102
|
/**
|
99
103
|
* When calling this action, validation will be triggered.
|
100
104
|
*
|
@@ -123,7 +127,7 @@ declare class HeadlessFormFieldComponent<DATA extends FormData, KEY extends Form
|
|
123
127
|
};
|
124
128
|
SelectComponent: typeof SelectComponent;
|
125
129
|
TextareaComponent: typeof TextareaComponent;
|
126
|
-
|
130
|
+
RadioGroupComponent: import("@ember/component/template-only").TemplateOnlyComponent<import("./control/radio-group.js").HeadlessFormControlRadioGroupComponentSignature>;
|
127
131
|
CaptureEventsModifier: import("ember-modifier").FunctionBasedModifier<{
|
128
132
|
Element: HTMLElement;
|
129
133
|
Args: {
|
@@ -140,6 +144,7 @@ declare class HeadlessFormFieldComponent<DATA extends FormData, KEY extends Form
|
|
140
144
|
get errors(): ValidationError<DATA[KEY]>[] | undefined;
|
141
145
|
get hasErrors(): boolean;
|
142
146
|
get valueAsString(): string | undefined;
|
147
|
+
get valueAsStringOrNumber(): string | number | undefined;
|
143
148
|
get valueAsBoolean(): boolean | undefined;
|
144
149
|
setValue(value: unknown): void;
|
145
150
|
}
|
@@ -4,29 +4,112 @@ import { setComponentTemplate } from '@ember/component';
|
|
4
4
|
import { precompileTemplate } from '@ember/template-compilation';
|
5
5
|
import Component from '@glimmer/component';
|
6
6
|
import { assert } from '@ember/debug';
|
7
|
+
import { fn, hash } from '@ember/helper';
|
7
8
|
import { action, get } from '@ember/object';
|
8
9
|
import CaptureEventsModifier from '../modifiers/capture-events.js';
|
10
|
+
import { uniqueId } from '../utils.js';
|
9
11
|
import HeadlessFormControlCheckboxComponent from './control/checkbox.js';
|
10
12
|
import HeadlessFormControlInputComponent from './control/input.js';
|
11
|
-
import
|
13
|
+
import HeadlessFormControlRadioGroupComponent from './control/radio-group.js';
|
12
14
|
import HeadlessFormControlSelectComponent from './control/select.js';
|
13
15
|
import HeadlessFormControlTextareaComponent from './control/textarea.js';
|
14
16
|
import HeadlessFormErrorsComponent from './errors.js';
|
15
|
-
import
|
16
|
-
|
17
|
-
var TEMPLATE = precompileTemplate("{{#let\n (unique-id)\n (unique-id)\n (fn @set @name)\n (fn @triggerValidationFor @name)\n as |fieldId errorId setValue triggerValidation|\n}}\n {{yield\n (hash\n Label=(component\n (ensure-safe-component this.LabelComponent) fieldId=fieldId\n )\n Input=(component\n (ensure-safe-component this.InputComponent)\n name=@name\n fieldId=fieldId\n errorId=errorId\n value=this.valueAsString\n setValue=this.setValue\n invalid=this.hasErrors\n )\n Checkbox=(component\n (ensure-safe-component this.CheckboxComponent)\n name=@name\n fieldId=fieldId\n errorId=errorId\n value=this.valueAsBoolean\n setValue=this.setValue\n invalid=this.hasErrors\n )\n Select=(component\n (ensure-safe-component this.SelectComponent)\n name=@name\n fieldId=fieldId\n errorId=errorId\n value=this.valueAsString\n setValue=this.setValue\n invalid=this.hasErrors\n )\n Textarea=(component\n (ensure-safe-component this.TextareaComponent)\n name=@name\n fieldId=fieldId\n errorId=errorId\n value=this.valueAsString\n setValue=this.setValue\n invalid=this.hasErrors\n )\n Radio=(component\n (ensure-safe-component this.RadioComponent)\n name=@name\n selected=this.valueAsString\n setValue=this.setValue\n )\n value=this.value\n setValue=setValue\n id=fieldId\n errorId=errorId\n Errors=(if\n this.errors\n (component\n (ensure-safe-component this.ErrorsComponent)\n errors=this.errors\n id=errorId\n )\n )\n isInvalid=this.hasErrors\n triggerValidation=triggerValidation\n captureEvents=(modifier\n this.CaptureEventsModifier\n event=(if this.hasErrors @fieldRevalidationEvent @fieldValidationEvent)\n triggerValidation=triggerValidation\n )\n )\n }}\n{{/let}}");
|
17
|
+
import HeadlessFormLabelComponent from './label.js';
|
18
18
|
|
19
19
|
var _class;
|
20
|
-
let HeadlessFormFieldComponent = (
|
20
|
+
let HeadlessFormFieldComponent = setComponentTemplate(precompileTemplate(`
|
21
|
+
{{#let
|
22
|
+
(uniqueId)
|
23
|
+
(uniqueId)
|
24
|
+
(fn @set @name)
|
25
|
+
(fn @triggerValidationFor @name)
|
26
|
+
as |fieldId errorId setValue triggerValidation|
|
27
|
+
}}
|
28
|
+
{{yield
|
29
|
+
(hash
|
30
|
+
Label=(component this.LabelComponent fieldId=fieldId)
|
31
|
+
Input=(component
|
32
|
+
this.InputComponent
|
33
|
+
name=@name
|
34
|
+
fieldId=fieldId
|
35
|
+
errorId=errorId
|
36
|
+
value=this.valueAsStringOrNumber
|
37
|
+
setValue=this.setValue
|
38
|
+
invalid=this.hasErrors
|
39
|
+
)
|
40
|
+
Checkbox=(component
|
41
|
+
this.CheckboxComponent
|
42
|
+
name=@name
|
43
|
+
fieldId=fieldId
|
44
|
+
errorId=errorId
|
45
|
+
value=this.valueAsBoolean
|
46
|
+
setValue=this.setValue
|
47
|
+
invalid=this.hasErrors
|
48
|
+
)
|
49
|
+
Select=(component
|
50
|
+
this.SelectComponent
|
51
|
+
name=@name
|
52
|
+
fieldId=fieldId
|
53
|
+
errorId=errorId
|
54
|
+
value=this.valueAsString
|
55
|
+
setValue=this.setValue
|
56
|
+
invalid=this.hasErrors
|
57
|
+
)
|
58
|
+
Textarea=(component
|
59
|
+
this.TextareaComponent
|
60
|
+
name=@name
|
61
|
+
fieldId=fieldId
|
62
|
+
errorId=errorId
|
63
|
+
value=this.valueAsString
|
64
|
+
setValue=this.setValue
|
65
|
+
invalid=this.hasErrors
|
66
|
+
)
|
67
|
+
RadioGroup=(component
|
68
|
+
this.RadioGroupComponent
|
69
|
+
name=@name
|
70
|
+
errorId=errorId
|
71
|
+
selected=this.valueAsString
|
72
|
+
setValue=this.setValue
|
73
|
+
invalid=this.hasErrors
|
74
|
+
)
|
75
|
+
value=this.value
|
76
|
+
setValue=setValue
|
77
|
+
id=fieldId
|
78
|
+
errorId=errorId
|
79
|
+
Errors=(if
|
80
|
+
this.errors
|
81
|
+
(component this.ErrorsComponent errors=this.errors id=errorId)
|
82
|
+
)
|
83
|
+
isInvalid=this.hasErrors
|
84
|
+
rawErrors=this.errors
|
85
|
+
triggerValidation=triggerValidation
|
86
|
+
captureEvents=(modifier
|
87
|
+
this.CaptureEventsModifier
|
88
|
+
event=(if
|
89
|
+
this.hasErrors @fieldRevalidationEvent @fieldValidationEvent
|
90
|
+
)
|
91
|
+
triggerValidation=triggerValidation
|
92
|
+
)
|
93
|
+
)
|
94
|
+
}}
|
95
|
+
{{/let}}
|
96
|
+
`, {
|
97
|
+
strictMode: true,
|
98
|
+
scope: () => ({
|
99
|
+
uniqueId,
|
100
|
+
fn,
|
101
|
+
hash
|
102
|
+
})
|
103
|
+
}), (_class = class HeadlessFormFieldComponent extends Component {
|
21
104
|
constructor(owner, args) {
|
22
105
|
super(owner, args);
|
23
|
-
_defineProperty(this, "LabelComponent",
|
106
|
+
_defineProperty(this, "LabelComponent", HeadlessFormLabelComponent);
|
24
107
|
_defineProperty(this, "InputComponent", HeadlessFormControlInputComponent);
|
25
108
|
_defineProperty(this, "CheckboxComponent", HeadlessFormControlCheckboxComponent);
|
26
109
|
_defineProperty(this, "ErrorsComponent", HeadlessFormErrorsComponent);
|
27
110
|
_defineProperty(this, "SelectComponent", HeadlessFormControlSelectComponent);
|
28
111
|
_defineProperty(this, "TextareaComponent", HeadlessFormControlTextareaComponent);
|
29
|
-
_defineProperty(this, "
|
112
|
+
_defineProperty(this, "RadioGroupComponent", HeadlessFormControlRadioGroupComponent);
|
30
113
|
_defineProperty(this, "CaptureEventsModifier", CaptureEventsModifier);
|
31
114
|
assert('Nested property paths in @name are not supported.', typeof this.args.name !== 'string' || !this.args.name.includes('.'));
|
32
115
|
this.args.registerField(this.args.name, {
|
@@ -52,6 +135,10 @@ let HeadlessFormFieldComponent = (_class = class HeadlessFormFieldComponent exte
|
|
52
135
|
assert(`Only string values are expected for ${String(this.args.name)}, but you passed ${typeof this.value}`, typeof this.value === 'undefined' || typeof this.value === 'string');
|
53
136
|
return this.value;
|
54
137
|
}
|
138
|
+
get valueAsStringOrNumber() {
|
139
|
+
assert(`Only string or number values are expected for ${String(this.args.name)}, but you passed ${typeof this.value}`, typeof this.value === 'undefined' || typeof this.value === 'string' || typeof this.value === 'number');
|
140
|
+
return this.value;
|
141
|
+
}
|
55
142
|
get valueAsBoolean() {
|
56
143
|
assert(`Only boolean values are expected for ${String(this.args.name)}, but you passed ${typeof this.value}`, typeof this.value === 'undefined' || typeof this.value === 'boolean');
|
57
144
|
return this.value;
|
@@ -59,8 +146,8 @@ let HeadlessFormFieldComponent = (_class = class HeadlessFormFieldComponent exte
|
|
59
146
|
setValue(value) {
|
60
147
|
this.args.set(this.args.name, value);
|
61
148
|
}
|
62
|
-
}, (_applyDecoratedDescriptor(_class.prototype, "setValue", [action], Object.getOwnPropertyDescriptor(_class.prototype, "setValue"), _class.prototype)), _class);
|
63
|
-
|
149
|
+
}, (_applyDecoratedDescriptor(_class.prototype, "setValue", [action], Object.getOwnPropertyDescriptor(_class.prototype, "setValue"), _class.prototype)), _class));
|
150
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars -- workaround for unknown modifier helper: https://github.com/typed-ember/glint/issues/410
|
64
151
|
|
65
152
|
export { HeadlessFormFieldComponent as default };
|
66
153
|
//# sourceMappingURL=field.js.map
|