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.
Files changed (45) hide show
  1. package/dist/-private/components/control/checkbox.d.ts.map +1 -1
  2. package/dist/-private/components/control/checkbox.js +18 -5
  3. package/dist/-private/components/control/checkbox.js.map +1 -1
  4. package/dist/-private/components/control/input.d.ts +2 -2
  5. package/dist/-private/components/control/input.js +20 -6
  6. package/dist/-private/components/control/input.js.map +1 -1
  7. package/dist/-private/components/control/radio-group/label.d.ts +15 -0
  8. package/dist/-private/components/control/radio-group/label.js +10 -0
  9. package/dist/-private/components/control/radio-group/label.js.map +1 -0
  10. package/dist/-private/components/control/radio-group/radio/input.d.ts +13 -0
  11. package/dist/-private/components/control/radio-group/radio/input.js +26 -0
  12. package/dist/-private/components/control/radio-group/radio/input.js.map +1 -0
  13. package/dist/-private/components/control/{radio.d.ts → radio-group/radio.d.ts} +4 -6
  14. package/dist/-private/components/control/radio-group/radio.js +41 -0
  15. package/dist/-private/components/control/radio-group/radio.js.map +1 -0
  16. package/dist/-private/components/control/radio-group.d.ts +27 -0
  17. package/dist/-private/components/control/radio-group.js +44 -0
  18. package/dist/-private/components/control/radio-group.js.map +1 -0
  19. package/dist/-private/components/control/select/option.js +15 -3
  20. package/dist/-private/components/control/select/option.js.map +1 -1
  21. package/dist/-private/components/control/select.d.ts +2 -3
  22. package/dist/-private/components/control/select.js +29 -10
  23. package/dist/-private/components/control/select.js.map +1 -1
  24. package/dist/-private/components/control/textarea.js +17 -5
  25. package/dist/-private/components/control/textarea.js.map +1 -1
  26. package/dist/-private/components/errors.js +15 -3
  27. package/dist/-private/components/errors.js.map +1 -1
  28. package/dist/-private/components/field.d.ts +8 -3
  29. package/dist/-private/components/field.js +96 -9
  30. package/dist/-private/components/field.js.map +1 -1
  31. package/dist/-private/components/label.d.ts +3 -2
  32. package/dist/-private/components/label.js +9 -5
  33. package/dist/-private/components/label.js.map +1 -1
  34. package/dist/-private/utils.d.ts +2 -1
  35. package/dist/-private/utils.js +10 -1
  36. package/dist/-private/utils.js.map +1 -1
  37. package/dist/components/headless-form.d.ts +14 -1
  38. package/dist/components/headless-form.js +48 -6
  39. package/dist/components/headless-form.js.map +1 -1
  40. package/package.json +11 -7
  41. package/dist/-private/components/control/radio/input.d.ts +0 -12
  42. package/dist/-private/components/control/radio/input.js +0 -10
  43. package/dist/-private/components/control/radio/input.js.map +0 -1
  44. package/dist/-private/components/control/radio.js +0 -23
  45. 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.hbs.js","../../../../../src/-private/components/control/select/option.ts"],"sourcesContent":["import { precompileTemplate } from \"@ember/template-compilation\";\nexport default precompileTemplate(\"{{!\\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}}\")","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"],"names":["precompileTemplate","HeadlessFormControlSelectOptionComponent","Component","isSelected","args","selected","value"],"mappings":";;;;AACA,eAAeA,kBAAkB,CAAC,ueAAue,CAAC;;ACqB3f,MAAMC,wCAAwC,SAASC,SAAS,CAAoD;AACjI,EAAA,IAAIC,UAAU,GAAY;IACxB,OAAO,IAAI,CAACC,IAAI,CAACC,QAAQ,KAAK,IAAI,CAACD,IAAI,CAACE,KAAK,CAAA;AAC/C,GAAA;AACF,CAAA;AAAC,oBAAA,CAAA,QAAA,EAJoBL,wCAAwC,CAAA;;;;"}
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 OptionComponent from "./select/option.js";
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 OptionComponent, 'selected'>;
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 = (_class = class HeadlessFormControlSelectComponent extends Component {
13
- constructor(...args) {
14
- super(...args);
15
- _defineProperty(this, "OptionComponent", HeadlessFormControlSelectOptionComponent);
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 = (_class = class HeadlessFormControlTextareaComponent extends Component {
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(TEMPLATE, HeadlessFormErrorsComponent);
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.hbs.js","../../../src/-private/components/errors.ts"],"sourcesContent":["import { precompileTemplate } from \"@ember/template-compilation\";\nexport default 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>\")","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"],"names":["precompileTemplate","HeadlessFormErrorsComponent","Component"],"mappings":";;;;AACA,eAAeA,kBAAkB,CAAC,uPAAuP,CAAC;;ACuB1R;AACe,MAAMC,2BAA2B,SAAgBC,SAAS,CAEvE,EAAA;AAAE,oBAAA,CAAA,QAAA,EAFiBD,2BAA2B,CAAA;;;;"}
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 RadioComponent from "./control/radio.js";
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
- Radio: WithBoundArgs<typeof RadioComponent, 'name' | 'selected' | 'setValue'>;
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
- RadioComponent: typeof RadioComponent;
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 HeadlessFormControlRadioComponent from './control/radio.js';
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 LabelComponent from './label.js';
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 = (_class = class HeadlessFormFieldComponent extends Component {
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", 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, "RadioComponent", HeadlessFormControlRadioComponent);
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
- setComponentTemplate(TEMPLATE, HeadlessFormFieldComponent);
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