@ng-atomic/components 17.6.1 → 17.7.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (130) hide show
  1. package/esm2022/atoms/icon/icon.atom.mjs +2 -2
  2. package/esm2022/frames/app/app.frame.mjs +12 -9
  3. package/esm2022/frames/auto-layout/auto-layout.frame.mjs +2 -2
  4. package/esm2022/frames/columns/columns.frame.mjs +2 -2
  5. package/esm2022/frames/divider/divider.frame.mjs +2 -2
  6. package/esm2022/frames/drawer/drawer.frame.mjs +2 -2
  7. package/esm2022/frames/entrance/entrance.frame.mjs +2 -2
  8. package/esm2022/frames/fab/fab.frame.mjs +2 -2
  9. package/esm2022/frames/line-up/line-up.frame.mjs +2 -2
  10. package/esm2022/frames/loading/loading.frame.mjs +2 -2
  11. package/esm2022/frames/router-outlet/router-outlet.frame.mjs +2 -2
  12. package/esm2022/frames/scroll/scroll.frame.mjs +2 -2
  13. package/esm2022/frames/scroll-v2/scroll.frame.mjs +2 -2
  14. package/esm2022/frames/side-nav/side-nav.frame.mjs +2 -2
  15. package/esm2022/frames/smart-menu/smart-menu.frame.mjs +2 -2
  16. package/esm2022/frames/vertical-hide/vertical-hide.frame.mjs +2 -2
  17. package/esm2022/molecules/date-input-field/date-input-field.molecule.mjs +2 -2
  18. package/esm2022/molecules/date-range-input-field/date-range-input-field.molecule.mjs +2 -2
  19. package/esm2022/molecules/grid-item/grid-item.molecule.mjs +2 -2
  20. package/esm2022/molecules/loading-box/loading-box.molecule.mjs +2 -2
  21. package/esm2022/molecules/navigation-list-item/navigation-list-item.molecule.mjs +2 -2
  22. package/esm2022/molecules/select-input-field/select-input-field.molecule.mjs +2 -2
  23. package/esm2022/organisms/action-buttons-section/action-buttons-section.organism.mjs +2 -2
  24. package/esm2022/organisms/action-input-section/action-input-section.organism.mjs +2 -2
  25. package/esm2022/organisms/card-input-section/card-input-section.organism.mjs +2 -2
  26. package/esm2022/organisms/cvc-and-exp-input-section/cvc-and-exp-input-section.organism.mjs +2 -2
  27. package/esm2022/organisms/date-input-section/date-input-section.organism.mjs +2 -2
  28. package/esm2022/organisms/date-range-input-section/date-range-input-section.organism.mjs +2 -2
  29. package/esm2022/organisms/definition-list/definition-list.organism.mjs +2 -2
  30. package/esm2022/organisms/file-input-section/file-input-section.organism.mjs +2 -2
  31. package/esm2022/organisms/grid-cards-section/grid-cards-section.organism.mjs +2 -2
  32. package/esm2022/organisms/heading/heading.organism.mjs +2 -2
  33. package/esm2022/organisms/menu-footer/menu-footer.organism.mjs +2 -2
  34. package/esm2022/organisms/menu-header/menu-header.organism.mjs +2 -2
  35. package/esm2022/organisms/messages-section/messages-section.organism.mjs +2 -2
  36. package/esm2022/organisms/navigation-list/navigation-list.organism.mjs +2 -2
  37. package/esm2022/organisms/navigator/navigator.organism.mjs +2 -2
  38. package/esm2022/organisms/number-input-section/number-input-section.organism.mjs +2 -2
  39. package/esm2022/organisms/paginator/paginator.organism.mjs +2 -2
  40. package/esm2022/organisms/password-input-section/password-input-section.organism.mjs +2 -2
  41. package/esm2022/organisms/select-input-section/select-input-section.organism.mjs +2 -2
  42. package/esm2022/organisms/slider-input-section/slider-input-section.organism.mjs +2 -2
  43. package/esm2022/organisms/social-login-section/social-login-section.organism.mjs +2 -2
  44. package/esm2022/organisms/table/table.organism.mjs +2 -2
  45. package/esm2022/organisms/text-input-section/text-input-section.organism.mjs +2 -2
  46. package/esm2022/organisms/textarea-section/textarea-section.organism.mjs +2 -2
  47. package/esm2022/organisms/thread-messages-section/thread-messages-section.organism.mjs +2 -2
  48. package/esm2022/pages/_index/index.page.mjs +24 -6
  49. package/esm2022/pages/form/form.page.mjs +23 -5
  50. package/esm2022/templates/_index/index.template.mjs +2 -2
  51. package/esm2022/templates/background/background.template.mjs +2 -2
  52. package/esm2022/templates/entrance/entrance.template.mjs +22 -36
  53. package/esm2022/templates/form/form.builder.mjs +415 -0
  54. package/esm2022/templates/form/form.template.mjs +24 -364
  55. package/esm2022/templates/form/index.mjs +2 -1
  56. package/esm2022/templates/icon-button-menu/icon-button-menu.template.mjs +2 -2
  57. package/esm2022/templates/menu/menu.template.mjs +2 -2
  58. package/esm2022/templates/selection/selection.template.mjs +2 -2
  59. package/esm2022/templates/settings/settings.template.mjs +2 -2
  60. package/fesm2022/ng-atomic-components-atoms-icon.mjs +2 -2
  61. package/fesm2022/ng-atomic-components-frames-app.mjs +11 -8
  62. package/fesm2022/ng-atomic-components-frames-app.mjs.map +1 -1
  63. package/fesm2022/ng-atomic-components-frames-auto-layout.mjs +2 -2
  64. package/fesm2022/ng-atomic-components-frames-columns.mjs +2 -2
  65. package/fesm2022/ng-atomic-components-frames-divider.mjs +2 -2
  66. package/fesm2022/ng-atomic-components-frames-drawer.mjs +2 -2
  67. package/fesm2022/ng-atomic-components-frames-entrance.mjs +2 -2
  68. package/fesm2022/ng-atomic-components-frames-entrance.mjs.map +1 -1
  69. package/fesm2022/ng-atomic-components-frames-fab.mjs +2 -2
  70. package/fesm2022/ng-atomic-components-frames-line-up.mjs +2 -2
  71. package/fesm2022/ng-atomic-components-frames-loading.mjs +2 -2
  72. package/fesm2022/ng-atomic-components-frames-router-outlet.mjs +2 -2
  73. package/fesm2022/ng-atomic-components-frames-scroll-v2.mjs +2 -2
  74. package/fesm2022/ng-atomic-components-frames-scroll.mjs +2 -2
  75. package/fesm2022/ng-atomic-components-frames-side-nav.mjs +2 -2
  76. package/fesm2022/ng-atomic-components-frames-smart-menu.mjs +2 -2
  77. package/fesm2022/ng-atomic-components-frames-vertical-hide.mjs +2 -2
  78. package/fesm2022/ng-atomic-components-molecules-date-input-field.mjs +2 -2
  79. package/fesm2022/ng-atomic-components-molecules-date-range-input-field.mjs +2 -2
  80. package/fesm2022/ng-atomic-components-molecules-grid-item.mjs +2 -2
  81. package/fesm2022/ng-atomic-components-molecules-loading-box.mjs +2 -2
  82. package/fesm2022/ng-atomic-components-molecules-navigation-list-item.mjs +2 -2
  83. package/fesm2022/ng-atomic-components-molecules-select-input-field.mjs +2 -2
  84. package/fesm2022/ng-atomic-components-organisms-action-buttons-section.mjs +2 -2
  85. package/fesm2022/ng-atomic-components-organisms-action-input-section.mjs +2 -2
  86. package/fesm2022/ng-atomic-components-organisms-card-input-section.mjs +2 -2
  87. package/fesm2022/ng-atomic-components-organisms-cvc-and-exp-input-section.mjs +2 -2
  88. package/fesm2022/ng-atomic-components-organisms-date-input-section.mjs +2 -2
  89. package/fesm2022/ng-atomic-components-organisms-date-range-input-section.mjs +2 -2
  90. package/fesm2022/ng-atomic-components-organisms-definition-list.mjs +2 -2
  91. package/fesm2022/ng-atomic-components-organisms-file-input-section.mjs +2 -2
  92. package/fesm2022/ng-atomic-components-organisms-grid-cards-section.mjs +2 -2
  93. package/fesm2022/ng-atomic-components-organisms-heading.mjs +2 -2
  94. package/fesm2022/ng-atomic-components-organisms-menu-footer.mjs +2 -2
  95. package/fesm2022/ng-atomic-components-organisms-menu-header.mjs +2 -2
  96. package/fesm2022/ng-atomic-components-organisms-messages-section.mjs +2 -2
  97. package/fesm2022/ng-atomic-components-organisms-navigation-list.mjs +2 -2
  98. package/fesm2022/ng-atomic-components-organisms-navigator.mjs +2 -2
  99. package/fesm2022/ng-atomic-components-organisms-number-input-section.mjs +2 -2
  100. package/fesm2022/ng-atomic-components-organisms-paginator.mjs +2 -2
  101. package/fesm2022/ng-atomic-components-organisms-password-input-section.mjs +2 -2
  102. package/fesm2022/ng-atomic-components-organisms-select-input-section.mjs +2 -2
  103. package/fesm2022/ng-atomic-components-organisms-slider-input-section.mjs +2 -2
  104. package/fesm2022/ng-atomic-components-organisms-social-login-section.mjs +2 -2
  105. package/fesm2022/ng-atomic-components-organisms-table.mjs +2 -2
  106. package/fesm2022/ng-atomic-components-organisms-text-input-section.mjs +2 -2
  107. package/fesm2022/ng-atomic-components-organisms-textarea-section.mjs +2 -2
  108. package/fesm2022/ng-atomic-components-organisms-thread-messages-section.mjs +2 -2
  109. package/fesm2022/ng-atomic-components-pages-_index.mjs +23 -5
  110. package/fesm2022/ng-atomic-components-pages-_index.mjs.map +1 -1
  111. package/fesm2022/ng-atomic-components-pages-form.mjs +22 -4
  112. package/fesm2022/ng-atomic-components-pages-form.mjs.map +1 -1
  113. package/fesm2022/ng-atomic-components-templates-_index.mjs +2 -2
  114. package/fesm2022/ng-atomic-components-templates-background.mjs +2 -2
  115. package/fesm2022/ng-atomic-components-templates-entrance.mjs +21 -35
  116. package/fesm2022/ng-atomic-components-templates-entrance.mjs.map +1 -1
  117. package/fesm2022/ng-atomic-components-templates-form.mjs +408 -337
  118. package/fesm2022/ng-atomic-components-templates-form.mjs.map +1 -1
  119. package/fesm2022/ng-atomic-components-templates-icon-button-menu.mjs +2 -2
  120. package/fesm2022/ng-atomic-components-templates-menu.mjs +2 -2
  121. package/fesm2022/ng-atomic-components-templates-selection.mjs +2 -2
  122. package/fesm2022/ng-atomic-components-templates-settings.mjs +2 -2
  123. package/frames/app/app.frame.d.ts +7 -4
  124. package/package.json +3 -3
  125. package/pages/_index/index.page.d.ts +5 -2
  126. package/pages/form/form.page.d.ts +3 -0
  127. package/templates/entrance/entrance.template.d.ts +3 -1
  128. package/templates/form/form.builder.d.ts +33 -0
  129. package/templates/form/form.template.d.ts +7 -13
  130. package/templates/form/index.d.ts +1 -0
@@ -8,6 +8,7 @@ import { ActionButtonsSectionOrganism } from '@ng-atomic/components/organisms/ac
8
8
  import { HeadingOrganism } from '@ng-atomic/components/organisms/heading';
9
9
  import { SocialLoginSectionOrganism } from '@ng-atomic/components/organisms/social-login-section';
10
10
  import { TextInputSectionOrganismStore } from '@ng-atomic/components/organisms/text-input-section';
11
+ import { NgAtomicFormSectionBuilder } from '@ng-atomic/components/templates/form';
11
12
  import * as i0 from "@angular/core";
12
13
  var ActionId;
13
14
  (function (ActionId) {
@@ -27,11 +28,15 @@ let EntranceTemplateStore = class EntranceTemplateStore extends InjectableCompon
27
28
  { id: ActionId.SIGN_IN_WITH_GOOGLE, name: 'Sign In With Google', icon: 'google' },
28
29
  { id: ActionId.SIGN_IN_WITH_TWITTER, name: 'Sign In With Twitter', icon: 'twitter' },
29
30
  ]);
31
+ this.fieldMap = input({
32
+ email: { type: 'text' },
33
+ password: { type: 'password' },
34
+ });
30
35
  this.title = input('ログイン');
31
36
  }
32
37
  static { this.ActionId = ActionId; }
33
38
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: EntranceTemplateStore, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
34
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.2.2", type: EntranceTemplateStore, isStandalone: true, selector: "templates-entrance", inputs: { form: { classPropertyName: "form", publicName: "form", isSignal: true, isRequired: false, transformFunction: null }, actions: { classPropertyName: "actions", publicName: "actions", isSignal: true, isRequired: false, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null } }, usesInheritance: true, ngImport: i0 }); }
39
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.2.2", type: EntranceTemplateStore, isStandalone: true, selector: "templates-entrance", inputs: { form: { classPropertyName: "form", publicName: "form", isSignal: true, isRequired: false, transformFunction: null }, actions: { classPropertyName: "actions", publicName: "actions", isSignal: true, isRequired: false, transformFunction: null }, fieldMap: { classPropertyName: "fieldMap", publicName: "fieldMap", isSignal: true, isRequired: false, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null } }, usesInheritance: true, ngImport: i0 }); }
35
40
  };
36
41
  EntranceTemplateStore = __decorate([
37
42
  TokenizedType()
@@ -57,22 +62,12 @@ export class EntranceTemplate extends NgAtomicComponent {
57
62
  <frames-auto-layout vertical>
58
63
  <organisms-heading>{{ store.title() }}</organisms-heading>
59
64
  @if (store.form()) {
60
- @if (store.form().get('email')) {
61
- @defer {
62
- <organisms-text-input-section injectable
63
- label="メールアドレス"
64
- [control]="store.form().get('email')"
65
- />
66
- }
67
- }
68
- @if (store.form().get('password')) {
69
- @defer {
70
- <organisms-text-input-section injectable
71
- label="パスワード"
72
- [control]="store.form().get('password')"
73
- />
74
- }
75
- }
65
+ <ng-atomic-form-section-builder
66
+ [form]="store.form()"
67
+ [formFlatExcludes]="[]"
68
+ [fieldMap]="store.fieldMap()"
69
+ (action)="dispatch($event)"
70
+ />
76
71
  @for (action of store.actions(); track action.id;) {
77
72
  @defer {
78
73
  <organisms-action-buttons-section
@@ -83,7 +78,7 @@ export class EntranceTemplate extends NgAtomicComponent {
83
78
  }
84
79
  </frames-auto-layout>
85
80
  </frames-card>
86
- `, isInline: true, styles: [":host{--horizontal-padding: 64px;--horizontal-padding-SCOPED-IN-entrance-zujh: var(--horizontal-padding);--background-color: #eee;--background-color-SCOPED-IN-entrance-zujh: var(--background-color);--on-background-color: #333;--on-background-color-SCOPED-IN-entrance-zujh: var(--on-background-color);--page-width-lv1-SCOPED-IN-entrance-zujh: var(--page-width-lv1)}:host{display:flex;justify-content:center;align-items:center;background-color:var(--background-color-SCOPED-IN-entrance-zujh);color:var(--on-background-color-SCOPED-IN-entrance-zujh);width:100%;height:100%}:host frames-card{display:flex;flex-direction:column;width:600px;max-width:calc(100% - 32px);height:-moz-fit-content;height:fit-content}:host frames-card *{max-width:calc(100% - 32px);--horizontal-padding: var(--horizontal-padding-SCOPED-IN-entrance-zujh)}\n"], dependencies: [{ kind: "component", type: AutoLayoutFrame, selector: "frames-auto-layout" }, { kind: "component", type: CardFrame, selector: "frames-card" }, { kind: "component", type: HeadingOrganism, selector: "organisms-heading", inputs: ["level"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
81
+ `, isInline: true, styles: [":host{--horizontal-padding: 64px;--horizontal-padding-SCOPED-IN-entrance-Nwdh: var(--horizontal-padding);--background-color: #eee;--background-color-SCOPED-IN-entrance-Nwdh: var(--background-color);--on-background-color: #333;--on-background-color-SCOPED-IN-entrance-Nwdh: var(--on-background-color);--page-width-lv1-SCOPED-IN-entrance-Nwdh: var(--page-width-lv1)}:host{display:flex;justify-content:center;align-items:center;background-color:var(--background-color-SCOPED-IN-entrance-Nwdh);color:var(--on-background-color-SCOPED-IN-entrance-Nwdh);width:100%;height:100%}:host frames-card{display:flex;flex-direction:column;width:600px;max-width:calc(100% - 32px);height:-moz-fit-content;height:fit-content}:host frames-card *{max-width:calc(100% - 32px);--horizontal-padding: var(--horizontal-padding-SCOPED-IN-entrance-Nwdh)}:host frames-card ng-atomic-form-section-builder{max-width:calc(100% - 32px);--horizontal-padding: var(--horizontal-padding-SCOPED-IN-entrance-Nwdh)}\n"], dependencies: [{ kind: "component", type: AutoLayoutFrame, selector: "frames-auto-layout" }, { kind: "component", type: CardFrame, selector: "frames-card" }, { kind: "component", type: HeadingOrganism, selector: "organisms-heading", inputs: ["level"] }, { kind: "component", type: NgAtomicFormSectionBuilder, selector: "ng-atomic-form-section-builder", inputs: ["form", "formFlatExcludes", "fieldMap"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
87
82
  }
88
83
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: EntranceTemplate, decorators: [{
89
84
  type: Component,
@@ -94,27 +89,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
94
89
  HeadingOrganism,
95
90
  SocialLoginSectionOrganism,
96
91
  TextInputSectionOrganismStore,
92
+ NgAtomicFormSectionBuilder,
97
93
  ], template: `
98
94
  <frames-card>
99
95
  <frames-auto-layout vertical>
100
96
  <organisms-heading>{{ store.title() }}</organisms-heading>
101
97
  @if (store.form()) {
102
- @if (store.form().get('email')) {
103
- @defer {
104
- <organisms-text-input-section injectable
105
- label="メールアドレス"
106
- [control]="store.form().get('email')"
107
- />
108
- }
109
- }
110
- @if (store.form().get('password')) {
111
- @defer {
112
- <organisms-text-input-section injectable
113
- label="パスワード"
114
- [control]="store.form().get('password')"
115
- />
116
- }
117
- }
98
+ <ng-atomic-form-section-builder
99
+ [form]="store.form()"
100
+ [formFlatExcludes]="[]"
101
+ [fieldMap]="store.fieldMap()"
102
+ (action)="dispatch($event)"
103
+ />
118
104
  @for (action of store.actions(); track action.id;) {
119
105
  @defer {
120
106
  <organisms-action-buttons-section
@@ -130,6 +116,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
130
116
  directive: EntranceTemplateStore,
131
117
  inputs: ['form', 'actions', 'title'],
132
118
  },
133
- ], styles: [":host{--horizontal-padding: 64px;--horizontal-padding-SCOPED-IN-entrance-zujh: var(--horizontal-padding);--background-color: #eee;--background-color-SCOPED-IN-entrance-zujh: var(--background-color);--on-background-color: #333;--on-background-color-SCOPED-IN-entrance-zujh: var(--on-background-color);--page-width-lv1-SCOPED-IN-entrance-zujh: var(--page-width-lv1)}:host{display:flex;justify-content:center;align-items:center;background-color:var(--background-color-SCOPED-IN-entrance-zujh);color:var(--on-background-color-SCOPED-IN-entrance-zujh);width:100%;height:100%}:host frames-card{display:flex;flex-direction:column;width:600px;max-width:calc(100% - 32px);height:-moz-fit-content;height:fit-content}:host frames-card *{max-width:calc(100% - 32px);--horizontal-padding: var(--horizontal-padding-SCOPED-IN-entrance-zujh)}\n"] }]
119
+ ], styles: [":host{--horizontal-padding: 64px;--horizontal-padding-SCOPED-IN-entrance-Nwdh: var(--horizontal-padding);--background-color: #eee;--background-color-SCOPED-IN-entrance-Nwdh: var(--background-color);--on-background-color: #333;--on-background-color-SCOPED-IN-entrance-Nwdh: var(--on-background-color);--page-width-lv1-SCOPED-IN-entrance-Nwdh: var(--page-width-lv1)}:host{display:flex;justify-content:center;align-items:center;background-color:var(--background-color-SCOPED-IN-entrance-Nwdh);color:var(--on-background-color-SCOPED-IN-entrance-Nwdh);width:100%;height:100%}:host frames-card{display:flex;flex-direction:column;width:600px;max-width:calc(100% - 32px);height:-moz-fit-content;height:fit-content}:host frames-card *{max-width:calc(100% - 32px);--horizontal-padding: var(--horizontal-padding-SCOPED-IN-entrance-Nwdh)}:host frames-card ng-atomic-form-section-builder{max-width:calc(100% - 32px);--horizontal-padding: var(--horizontal-padding-SCOPED-IN-entrance-Nwdh)}\n"] }]
134
120
  }] });
135
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50cmFuY2UudGVtcGxhdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AbmctYXRvbWljL2NvbXBvbmVudHMvc3JjL2xpYi90ZW1wbGF0ZXMvZW50cmFuY2UvZW50cmFuY2UudGVtcGxhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDN0YsT0FBTyxFQUFFLG1CQUFtQixFQUFFLGlCQUFpQixFQUFFLGFBQWEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3hGLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQzNFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUM5RCxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSx3REFBd0QsQ0FBQztBQUN0RyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDMUUsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sc0RBQXNELENBQUM7QUFDbEcsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sb0RBQW9ELENBQUM7O0FBRW5HLElBQUssUUFJSjtBQUpELFdBQUssUUFBUTtJQUNYLHVEQUEyQyxDQUFBO0lBQzNDLCtFQUFtRSxDQUFBO0lBQ25FLGlGQUFxRSxDQUFBO0FBQ3ZFLENBQUMsRUFKSSxRQUFRLEtBQVIsUUFBUSxRQUlaO0FBT00sSUFBTSxxQkFBcUIsR0FBM0IsTUFBTSxxQkFBc0IsU0FBUSxtQkFBbUI7SUFBdkQ7O1FBRUksU0FBSSxHQUFHLEtBQUssQ0FBQyxJQUFJLFNBQVMsQ0FBQztZQUNsQyxLQUFLLEVBQUUsSUFBSSxXQUFXLENBQUMsRUFBRSxDQUFDO1lBQzFCLFFBQVEsRUFBRSxJQUFJLFdBQVcsQ0FBQyxFQUFFLENBQUM7U0FDOUIsQ0FBQyxDQUFDLENBQUM7UUFDSyxZQUFPLEdBQUcsS0FBSyxDQUFDO1lBQ3ZCLEVBQUUsRUFBRSxFQUFFLFFBQVEsQ0FBQyxPQUFPLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFO1lBQ3hELEVBQUUsRUFBRSxFQUFFLFFBQVEsQ0FBQyxtQkFBbUIsRUFBRSxJQUFJLEVBQUUscUJBQXFCLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRTtZQUNqRixFQUFFLEVBQUUsRUFBRSxRQUFRLENBQUMsb0JBQW9CLEVBQUUsSUFBSSxFQUFFLHNCQUFzQixFQUFFLElBQUksRUFBRSxTQUFTLEVBQUU7U0FDckYsQ0FBQyxDQUFDO1FBRU0sVUFBSyxHQUFHLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztLQUNoQzthQVppQixhQUFRLEdBQUcsUUFBUSxBQUFYLENBQVk7OEdBRHpCLHFCQUFxQjtrR0FBckIscUJBQXFCOztBQUFyQixxQkFBcUI7SUFMakMsYUFBYSxFQUFFO0dBS0gscUJBQXFCLENBYWpDOzsyRkFiWSxxQkFBcUI7a0JBSmpDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG9CQUFvQjtvQkFDOUIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOztBQXFFRCxNQUFNLE9BQU8sZ0JBQWlCLFNBQVEsaUJBQWlCO0lBckR2RDs7UUF1RFksYUFBUSxHQUFHLFFBQVEsQ0FBQztRQUNwQixVQUFLLEdBQUcsTUFBTSxDQUFDLHFCQUFxQixDQUFDLENBQUM7S0FDakQ7YUFIUSxhQUFRLEdBQUcsUUFBUSxBQUFYLENBQVk7OEdBRGhCLGdCQUFnQjtrR0FBaEIsZ0JBQWdCLGlKQXBFaEIscUJBQXFCLCtGQTBCdEI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0ErQlQsczRCQXRDQyxlQUFlLCtEQUNmLFNBQVMsd0RBRVQsZUFBZTs7MkZBOENOLGdCQUFnQjtrQkFyRDVCLFNBQVM7K0JBQ0Usb0JBQW9CLGNBQ2xCLElBQUksV0FDUDt3QkFDUCxlQUFlO3dCQUNmLFNBQVM7d0JBQ1QsNEJBQTRCO3dCQUM1QixlQUFlO3dCQUNmLDBCQUEwQjt3QkFDMUIsNkJBQTZCO3FCQUM5QixZQUNTOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBK0JULFFBRUssRUFBQyxLQUFLLEVBQUUsVUFBVSxFQUFDLG1CQUNSLHVCQUF1QixDQUFDLE1BQU0sa0JBQy9CO3dCQUNkOzRCQUNFLFNBQVMsRUFBRSxxQkFBcUI7NEJBQ2hDLE1BQU0sRUFBRSxDQUFDLE1BQU0sRUFBRSxTQUFTLEVBQUUsT0FBTyxDQUFDO3lCQUNyQztxQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIERpcmVjdGl2ZSwgaW5qZWN0LCBpbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSW5qZWN0YWJsZUNvbXBvbmVudCwgTmdBdG9taWNDb21wb25lbnQsIFRva2VuaXplZFR5cGUgfSBmcm9tICdAbmctYXRvbWljL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUdyb3VwLCBGb3JtQ29udHJvbH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQXV0b0xheW91dEZyYW1lIH0gZnJvbSAnQG5nLWF0b21pYy9jb21wb25lbnRzL2ZyYW1lcy9hdXRvLWxheW91dCc7XG5pbXBvcnQgeyBDYXJkRnJhbWUgfSBmcm9tICdAbmctYXRvbWljL2NvbXBvbmVudHMvZnJhbWVzL2NhcmQnO1xuaW1wb3J0IHsgQWN0aW9uQnV0dG9uc1NlY3Rpb25PcmdhbmlzbSB9IGZyb20gJ0BuZy1hdG9taWMvY29tcG9uZW50cy9vcmdhbmlzbXMvYWN0aW9uLWJ1dHRvbnMtc2VjdGlvbic7XG5pbXBvcnQgeyBIZWFkaW5nT3JnYW5pc20gfSBmcm9tICdAbmctYXRvbWljL2NvbXBvbmVudHMvb3JnYW5pc21zL2hlYWRpbmcnO1xuaW1wb3J0IHsgU29jaWFsTG9naW5TZWN0aW9uT3JnYW5pc20gfSBmcm9tICdAbmctYXRvbWljL2NvbXBvbmVudHMvb3JnYW5pc21zL3NvY2lhbC1sb2dpbi1zZWN0aW9uJztcbmltcG9ydCB7IFRleHRJbnB1dFNlY3Rpb25PcmdhbmlzbVN0b3JlIH0gZnJvbSAnQG5nLWF0b21pYy9jb21wb25lbnRzL29yZ2FuaXNtcy90ZXh0LWlucHV0LXNlY3Rpb24nO1xuXG5lbnVtIEFjdGlvbklkIHtcbiAgU0lHTl9JTiA9ICdbQG5nLWF0b21pYy9jb21wb25lbnRzXSBTaWduIEluJyxcbiAgU0lHTl9JTl9XSVRIX0dPT0dMRSA9ICdbQG5nLWF0b21pYy9jb21wb25lbnRzXSBTaWduIEluIFdpdGggR29vZ2xlJyxcbiAgU0lHTl9JTl9XSVRIX1RXSVRURVIgPSAnW0BuZy1hdG9taWMvY29tcG9uZW50c10gU2lnbiBJbiBXaXRoIFR3aXR0ZXInLFxufVxuXG5AVG9rZW5pemVkVHlwZSgpXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICd0ZW1wbGF0ZXMtZW50cmFuY2UnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBFbnRyYW5jZVRlbXBsYXRlU3RvcmUgZXh0ZW5kcyBJbmplY3RhYmxlQ29tcG9uZW50IHtcbiAgc3RhdGljIHJlYWRvbmx5IEFjdGlvbklkID0gQWN0aW9uSWQ7XG4gIHJlYWRvbmx5IGZvcm0gPSBpbnB1dChuZXcgRm9ybUdyb3VwKHtcbiAgICBlbWFpbDogbmV3IEZvcm1Db250cm9sKCcnKSxcbiAgICBwYXNzd29yZDogbmV3IEZvcm1Db250cm9sKCcnKSxcbiAgfSkpO1xuICByZWFkb25seSBhY3Rpb25zID0gaW5wdXQoW1xuICAgIHsgaWQ6IEFjdGlvbklkLlNJR05fSU4sIG5hbWU6ICdTaWduIEluJywgaWNvbjogJ2xvZ2luJyB9LFxuICAgIHsgaWQ6IEFjdGlvbklkLlNJR05fSU5fV0lUSF9HT09HTEUsIG5hbWU6ICdTaWduIEluIFdpdGggR29vZ2xlJywgaWNvbjogJ2dvb2dsZScgfSxcbiAgICB7IGlkOiBBY3Rpb25JZC5TSUdOX0lOX1dJVEhfVFdJVFRFUiwgbmFtZTogJ1NpZ24gSW4gV2l0aCBUd2l0dGVyJywgaWNvbjogJ3R3aXR0ZXInIH0sXG4gIF0pO1xuXG4gIHJlYWRvbmx5IHRpdGxlID0gaW5wdXQoJ+ODreOCsOOCpOODsycpO1xufVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd0ZW1wbGF0ZXMtZW50cmFuY2UnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXG4gICAgQXV0b0xheW91dEZyYW1lLFxuICAgIENhcmRGcmFtZSxcbiAgICBBY3Rpb25CdXR0b25zU2VjdGlvbk9yZ2FuaXNtLFxuICAgIEhlYWRpbmdPcmdhbmlzbSxcbiAgICBTb2NpYWxMb2dpblNlY3Rpb25PcmdhbmlzbSxcbiAgICBUZXh0SW5wdXRTZWN0aW9uT3JnYW5pc21TdG9yZSxcbiAgXSxcbiAgdGVtcGxhdGU6IGBcbiAgPGZyYW1lcy1jYXJkPlxuICAgIDxmcmFtZXMtYXV0by1sYXlvdXQgdmVydGljYWw+XG4gICAgICA8b3JnYW5pc21zLWhlYWRpbmc+e3sgc3RvcmUudGl0bGUoKSB9fTwvb3JnYW5pc21zLWhlYWRpbmc+XG4gICAgICBAaWYgKHN0b3JlLmZvcm0oKSkge1xuICAgICAgICBAaWYgKHN0b3JlLmZvcm0oKS5nZXQoJ2VtYWlsJykpIHtcbiAgICAgICAgICBAZGVmZXIge1xuICAgICAgICAgICAgPG9yZ2FuaXNtcy10ZXh0LWlucHV0LXNlY3Rpb24gaW5qZWN0YWJsZVxuICAgICAgICAgICAgICBsYWJlbD1cIuODoeODvOODq+OCouODieODrOOCuVwiXG4gICAgICAgICAgICAgIFtjb250cm9sXT1cInN0b3JlLmZvcm0oKS5nZXQoJ2VtYWlsJylcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgQGlmIChzdG9yZS5mb3JtKCkuZ2V0KCdwYXNzd29yZCcpKSB7XG4gICAgICAgICAgQGRlZmVyIHtcbiAgICAgICAgICAgIDxvcmdhbmlzbXMtdGV4dC1pbnB1dC1zZWN0aW9uIGluamVjdGFibGVcbiAgICAgICAgICAgICAgbGFiZWw9XCLjg5Hjgrnjg6/jg7zjg4lcIlxuICAgICAgICAgICAgICBbY29udHJvbF09XCJzdG9yZS5mb3JtKCkuZ2V0KCdwYXNzd29yZCcpXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIEBmb3IgKGFjdGlvbiBvZiBzdG9yZS5hY3Rpb25zKCk7IHRyYWNrIGFjdGlvbi5pZDspIHtcbiAgICAgICAgICBAZGVmZXIge1xuICAgICAgICAgICAgPG9yZ2FuaXNtcy1hY3Rpb24tYnV0dG9ucy1zZWN0aW9uXG4gICAgICAgICAgICAgIFthY3Rpb25zXT1cIlthY3Rpb25dXCJcbiAgICAgICAgICAgICAgKGFjdGlvbik9XCJkaXNwYXRjaCgkZXZlbnQpXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgfSBAZXJyb3IgeyBlcnJvciB9IH1cbiAgICAgIH1cbiAgICA8L2ZyYW1lcy1hdXRvLWxheW91dD5cbiAgPC9mcmFtZXMtY2FyZD5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vZW50cmFuY2UudGVtcGxhdGUuc2NzcyddLFxuICBob3N0OiB7Y2xhc3M6ICd0ZW1wbGF0ZSd9LFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgaG9zdERpcmVjdGl2ZXM6IFtcbiAgICB7XG4gICAgICBkaXJlY3RpdmU6IEVudHJhbmNlVGVtcGxhdGVTdG9yZSxcbiAgICAgIGlucHV0czogWydmb3JtJywgJ2FjdGlvbnMnLCAndGl0bGUnXSxcbiAgICB9LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBFbnRyYW5jZVRlbXBsYXRlIGV4dGVuZHMgTmdBdG9taWNDb21wb25lbnQge1xuICBzdGF0aWMgQWN0aW9uSWQgPSBBY3Rpb25JZDtcbiAgcHJvdGVjdGVkIEFjdGlvbklkID0gQWN0aW9uSWQ7XG4gIHByb3RlY3RlZCBzdG9yZSA9IGluamVjdChFbnRyYW5jZVRlbXBsYXRlU3RvcmUpO1xufVxuIl19
121
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50cmFuY2UudGVtcGxhdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AbmctYXRvbWljL2NvbXBvbmVudHMvc3JjL2xpYi90ZW1wbGF0ZXMvZW50cmFuY2UvZW50cmFuY2UudGVtcGxhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDN0YsT0FBTyxFQUFFLG1CQUFtQixFQUFFLGlCQUFpQixFQUFFLGFBQWEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3hGLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQzNFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUM5RCxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSx3REFBd0QsQ0FBQztBQUN0RyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDMUUsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sc0RBQXNELENBQUM7QUFDbEcsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sb0RBQW9ELENBQUM7QUFDbkcsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7O0FBR2xGLElBQUssUUFJSjtBQUpELFdBQUssUUFBUTtJQUNYLHVEQUEyQyxDQUFBO0lBQzNDLCtFQUFtRSxDQUFBO0lBQ25FLGlGQUFxRSxDQUFBO0FBQ3ZFLENBQUMsRUFKSSxRQUFRLEtBQVIsUUFBUSxRQUlaO0FBT00sSUFBTSxxQkFBcUIsR0FBM0IsTUFBTSxxQkFBc0IsU0FBUSxtQkFBbUI7SUFBdkQ7O1FBRUksU0FBSSxHQUFHLEtBQUssQ0FBQyxJQUFJLFNBQVMsQ0FBQztZQUNsQyxLQUFLLEVBQUUsSUFBSSxXQUFXLENBQUMsRUFBRSxDQUFDO1lBQzFCLFFBQVEsRUFBRSxJQUFJLFdBQVcsQ0FBQyxFQUFFLENBQUM7U0FDOUIsQ0FBQyxDQUFDLENBQUM7UUFDSyxZQUFPLEdBQUcsS0FBSyxDQUFDO1lBQ3ZCLEVBQUUsRUFBRSxFQUFFLFFBQVEsQ0FBQyxPQUFPLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFO1lBQ3hELEVBQUUsRUFBRSxFQUFFLFFBQVEsQ0FBQyxtQkFBbUIsRUFBRSxJQUFJLEVBQUUscUJBQXFCLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRTtZQUNqRixFQUFFLEVBQUUsRUFBRSxRQUFRLENBQUMsb0JBQW9CLEVBQUUsSUFBSSxFQUFFLHNCQUFzQixFQUFFLElBQUksRUFBRSxTQUFTLEVBQUU7U0FDckYsQ0FBQyxDQUFDO1FBRU0sYUFBUSxHQUFHLEtBQUssQ0FBZTtZQUN0QyxLQUFLLEVBQUUsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFO1lBQ3ZCLFFBQVEsRUFBRSxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUU7U0FDL0IsQ0FBQyxDQUFDO1FBRU0sVUFBSyxHQUFHLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztLQUNoQzthQWpCaUIsYUFBUSxHQUFHLFFBQVEsQUFBWCxDQUFZOzhHQUR6QixxQkFBcUI7a0dBQXJCLHFCQUFxQjs7QUFBckIscUJBQXFCO0lBTGpDLGFBQWEsRUFBRTtHQUtILHFCQUFxQixDQWtCakM7OzJGQWxCWSxxQkFBcUI7a0JBSmpDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG9CQUFvQjtvQkFDOUIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOztBQWtFRCxNQUFNLE9BQU8sZ0JBQWlCLFNBQVEsaUJBQWlCO0lBN0N2RDs7UUErQ1ksYUFBUSxHQUFHLFFBQVEsQ0FBQztRQUNwQixVQUFLLEdBQUcsTUFBTSxDQUFDLHFCQUFxQixDQUFDLENBQUM7S0FDakQ7YUFIUSxhQUFRLEdBQUcsUUFBUSxBQUFYLENBQVk7OEdBRGhCLGdCQUFnQjtrR0FBaEIsZ0JBQWdCLGlKQWpFaEIscUJBQXFCLCtGQWlDdEI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXFCVCwyaENBOUJDLGVBQWUsK0RBQ2YsU0FBUyx3REFFVCxlQUFlLGlGQUdmLDBCQUEwQjs7MkZBbUNqQixnQkFBZ0I7a0JBN0M1QixTQUFTOytCQUNFLG9CQUFvQixjQUNsQixJQUFJLFdBQ1A7d0JBQ1AsZUFBZTt3QkFDZixTQUFTO3dCQUNULDRCQUE0Qjt3QkFDNUIsZUFBZTt3QkFDZiwwQkFBMEI7d0JBQzFCLDZCQUE2Qjt3QkFDN0IsMEJBQTBCO3FCQUUzQixZQUNTOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FxQlQsUUFFSyxFQUFDLEtBQUssRUFBRSxVQUFVLEVBQUMsbUJBQ1IsdUJBQXVCLENBQUMsTUFBTSxrQkFDL0I7d0JBQ2Q7NEJBQ0UsU0FBUyxFQUFFLHFCQUFxQjs0QkFDaEMsTUFBTSxFQUFFLENBQUMsTUFBTSxFQUFFLFNBQVMsRUFBRSxPQUFPLENBQUM7eUJBQ3JDO3FCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRGlyZWN0aXZlLCBpbmplY3QsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJbmplY3RhYmxlQ29tcG9uZW50LCBOZ0F0b21pY0NvbXBvbmVudCwgVG9rZW5pemVkVHlwZSB9IGZyb20gJ0BuZy1hdG9taWMvY29yZSc7XG5pbXBvcnQgeyBGb3JtR3JvdXAsIEZvcm1Db250cm9sfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBBdXRvTGF5b3V0RnJhbWUgfSBmcm9tICdAbmctYXRvbWljL2NvbXBvbmVudHMvZnJhbWVzL2F1dG8tbGF5b3V0JztcbmltcG9ydCB7IENhcmRGcmFtZSB9IGZyb20gJ0BuZy1hdG9taWMvY29tcG9uZW50cy9mcmFtZXMvY2FyZCc7XG5pbXBvcnQgeyBBY3Rpb25CdXR0b25zU2VjdGlvbk9yZ2FuaXNtIH0gZnJvbSAnQG5nLWF0b21pYy9jb21wb25lbnRzL29yZ2FuaXNtcy9hY3Rpb24tYnV0dG9ucy1zZWN0aW9uJztcbmltcG9ydCB7IEhlYWRpbmdPcmdhbmlzbSB9IGZyb20gJ0BuZy1hdG9taWMvY29tcG9uZW50cy9vcmdhbmlzbXMvaGVhZGluZyc7XG5pbXBvcnQgeyBTb2NpYWxMb2dpblNlY3Rpb25PcmdhbmlzbSB9IGZyb20gJ0BuZy1hdG9taWMvY29tcG9uZW50cy9vcmdhbmlzbXMvc29jaWFsLWxvZ2luLXNlY3Rpb24nO1xuaW1wb3J0IHsgVGV4dElucHV0U2VjdGlvbk9yZ2FuaXNtU3RvcmUgfSBmcm9tICdAbmctYXRvbWljL2NvbXBvbmVudHMvb3JnYW5pc21zL3RleHQtaW5wdXQtc2VjdGlvbic7XG5pbXBvcnQgeyBOZ0F0b21pY0Zvcm1TZWN0aW9uQnVpbGRlciB9IGZyb20gJ0BuZy1hdG9taWMvY29tcG9uZW50cy90ZW1wbGF0ZXMvZm9ybSc7XG5pbXBvcnQgeyBGb3JtRmllbGRNYXAgfSBmcm9tICdAbmctYXRvbWljL2NvbW1vbi9waXBlcy9zbWFydC1maWVsZCc7XG5cbmVudW0gQWN0aW9uSWQge1xuICBTSUdOX0lOID0gJ1tAbmctYXRvbWljL2NvbXBvbmVudHNdIFNpZ24gSW4nLFxuICBTSUdOX0lOX1dJVEhfR09PR0xFID0gJ1tAbmctYXRvbWljL2NvbXBvbmVudHNdIFNpZ24gSW4gV2l0aCBHb29nbGUnLFxuICBTSUdOX0lOX1dJVEhfVFdJVFRFUiA9ICdbQG5nLWF0b21pYy9jb21wb25lbnRzXSBTaWduIEluIFdpdGggVHdpdHRlcicsXG59XG5cbkBUb2tlbml6ZWRUeXBlKClcbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ3RlbXBsYXRlcy1lbnRyYW5jZScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIEVudHJhbmNlVGVtcGxhdGVTdG9yZSBleHRlbmRzIEluamVjdGFibGVDb21wb25lbnQge1xuICBzdGF0aWMgcmVhZG9ubHkgQWN0aW9uSWQgPSBBY3Rpb25JZDtcbiAgcmVhZG9ubHkgZm9ybSA9IGlucHV0KG5ldyBGb3JtR3JvdXAoe1xuICAgIGVtYWlsOiBuZXcgRm9ybUNvbnRyb2woJycpLFxuICAgIHBhc3N3b3JkOiBuZXcgRm9ybUNvbnRyb2woJycpLFxuICB9KSk7XG4gIHJlYWRvbmx5IGFjdGlvbnMgPSBpbnB1dChbXG4gICAgeyBpZDogQWN0aW9uSWQuU0lHTl9JTiwgbmFtZTogJ1NpZ24gSW4nLCBpY29uOiAnbG9naW4nIH0sXG4gICAgeyBpZDogQWN0aW9uSWQuU0lHTl9JTl9XSVRIX0dPT0dMRSwgbmFtZTogJ1NpZ24gSW4gV2l0aCBHb29nbGUnLCBpY29uOiAnZ29vZ2xlJyB9LFxuICAgIHsgaWQ6IEFjdGlvbklkLlNJR05fSU5fV0lUSF9UV0lUVEVSLCBuYW1lOiAnU2lnbiBJbiBXaXRoIFR3aXR0ZXInLCBpY29uOiAndHdpdHRlcicgfSxcbiAgXSk7XG5cbiAgcmVhZG9ubHkgZmllbGRNYXAgPSBpbnB1dDxGb3JtRmllbGRNYXA+KHtcbiAgICBlbWFpbDogeyB0eXBlOiAndGV4dCcgfSxcbiAgICBwYXNzd29yZDogeyB0eXBlOiAncGFzc3dvcmQnIH0sXG4gIH0pO1xuXG4gIHJlYWRvbmx5IHRpdGxlID0gaW5wdXQoJ+ODreOCsOOCpOODsycpO1xufVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd0ZW1wbGF0ZXMtZW50cmFuY2UnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXG4gICAgQXV0b0xheW91dEZyYW1lLFxuICAgIENhcmRGcmFtZSxcbiAgICBBY3Rpb25CdXR0b25zU2VjdGlvbk9yZ2FuaXNtLFxuICAgIEhlYWRpbmdPcmdhbmlzbSxcbiAgICBTb2NpYWxMb2dpblNlY3Rpb25PcmdhbmlzbSxcbiAgICBUZXh0SW5wdXRTZWN0aW9uT3JnYW5pc21TdG9yZSxcbiAgICBOZ0F0b21pY0Zvcm1TZWN0aW9uQnVpbGRlcixcbiAgICBcbiAgXSxcbiAgdGVtcGxhdGU6IGBcbiAgPGZyYW1lcy1jYXJkPlxuICAgIDxmcmFtZXMtYXV0by1sYXlvdXQgdmVydGljYWw+XG4gICAgICA8b3JnYW5pc21zLWhlYWRpbmc+e3sgc3RvcmUudGl0bGUoKSB9fTwvb3JnYW5pc21zLWhlYWRpbmc+XG4gICAgICBAaWYgKHN0b3JlLmZvcm0oKSkge1xuICAgICAgICA8bmctYXRvbWljLWZvcm0tc2VjdGlvbi1idWlsZGVyXG4gICAgICAgICAgW2Zvcm1dPVwic3RvcmUuZm9ybSgpXCJcbiAgICAgICAgICBbZm9ybUZsYXRFeGNsdWRlc109XCJbXVwiXG4gICAgICAgICAgW2ZpZWxkTWFwXT1cInN0b3JlLmZpZWxkTWFwKClcIlxuICAgICAgICAgIChhY3Rpb24pPVwiZGlzcGF0Y2goJGV2ZW50KVwiXG4gICAgICAgIC8+XG4gICAgICAgIEBmb3IgKGFjdGlvbiBvZiBzdG9yZS5hY3Rpb25zKCk7IHRyYWNrIGFjdGlvbi5pZDspIHtcbiAgICAgICAgICBAZGVmZXIge1xuICAgICAgICAgICAgPG9yZ2FuaXNtcy1hY3Rpb24tYnV0dG9ucy1zZWN0aW9uXG4gICAgICAgICAgICAgIFthY3Rpb25zXT1cIlthY3Rpb25dXCJcbiAgICAgICAgICAgICAgKGFjdGlvbik9XCJkaXNwYXRjaCgkZXZlbnQpXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgfSBAZXJyb3IgeyBlcnJvciB9IH1cbiAgICAgIH1cbiAgICA8L2ZyYW1lcy1hdXRvLWxheW91dD5cbiAgPC9mcmFtZXMtY2FyZD5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vZW50cmFuY2UudGVtcGxhdGUuc2NzcyddLFxuICBob3N0OiB7Y2xhc3M6ICd0ZW1wbGF0ZSd9LFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgaG9zdERpcmVjdGl2ZXM6IFtcbiAgICB7XG4gICAgICBkaXJlY3RpdmU6IEVudHJhbmNlVGVtcGxhdGVTdG9yZSxcbiAgICAgIGlucHV0czogWydmb3JtJywgJ2FjdGlvbnMnLCAndGl0bGUnXSxcbiAgICB9LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBFbnRyYW5jZVRlbXBsYXRlIGV4dGVuZHMgTmdBdG9taWNDb21wb25lbnQge1xuICBzdGF0aWMgQWN0aW9uSWQgPSBBY3Rpb25JZDtcbiAgcHJvdGVjdGVkIEFjdGlvbklkID0gQWN0aW9uSWQ7XG4gIHByb3RlY3RlZCBzdG9yZSA9IGluamVjdChFbnRyYW5jZVRlbXBsYXRlU3RvcmUpO1xufVxuIl19
@@ -0,0 +1,415 @@
1
+ import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
2
+ import { TextareaSectionOrganismStore } from '@ng-atomic/components/organisms/textarea-section';
3
+ import { TextInputSectionOrganismStore } from '@ng-atomic/components/organisms/text-input-section';
4
+ import { DateInputSectionOrganism } from '@ng-atomic/components/organisms/date-input-section';
5
+ import { SelectInputSectionOrganismStore } from '@ng-atomic/components/organisms/select-input-section';
6
+ import { DomainPipe } from '@ng-atomic/common/pipes/domain';
7
+ import { ActionInputSectionOrganismStore } from '@ng-atomic/components/organisms/action-input-section';
8
+ import { NgAtomicComponent } from '@ng-atomic/core';
9
+ import { FileInputSectionOrganism, FileInputSectionOrganismStore } from '@ng-atomic/components/organisms/file-input-section';
10
+ import { AgreementInputSectionOrganism } from '@ng-atomic/components/organisms/agreement-input-section';
11
+ import { VideoSectionOrganism } from '@ng-atomic/components/organisms/video-section';
12
+ import { NumberInputSectionOrganismStore } from '@ng-atomic/components/organisms/number-input-section';
13
+ import { ImagePreviewSectionOrganism } from '@ng-atomic/components/organisms/image-preview-section';
14
+ import { PasswordInputSectionOrganismStore } from '@ng-atomic/components/organisms/password-input-section';
15
+ import { DateRangeInputSectionOrganism } from '@ng-atomic/components/organisms/date-range-input-section';
16
+ import { SliderInputSectionOrganismStore } from '@ng-atomic/components/organisms/slider-input-section';
17
+ import { get } from 'lodash-es';
18
+ import * as i0 from "@angular/core";
19
+ function walkControls(controls, cb, excludes = [], name = '') {
20
+ Object.entries(controls).forEach(([key, control]) => {
21
+ const path = name === '' ? key : `${name}.${key}`;
22
+ if (excludes.includes(path)) {
23
+ cb(path, control);
24
+ }
25
+ else if (control.controls) {
26
+ walkControls(control.controls, cb, excludes, path);
27
+ }
28
+ else {
29
+ cb(path, control);
30
+ }
31
+ });
32
+ }
33
+ function flatControls(form, excludes) {
34
+ const controlMap = new Map();
35
+ walkControls(form?.controls, (name, control) => controlMap.set(name, control), [
36
+ ...excludes,
37
+ ]);
38
+ return [...controlMap.entries()];
39
+ }
40
+ var ActionId;
41
+ (function (ActionId) {
42
+ ActionId["FILE_SELECTED"] = "[@ng-atomic/components:templates/form/ng-atomic-form-section-switcher] File selected";
43
+ ActionId["CANCEL"] = "[@ng-atomic/components:templates/form/ng-atomic-form-section-switcher] Cancel";
44
+ })(ActionId || (ActionId = {}));
45
+ export class NgAtomicFormSectionSwitcher extends NgAtomicComponent {
46
+ constructor() {
47
+ super(...arguments);
48
+ this.name = input.required();
49
+ this.control = input.required();
50
+ this.field = input.required();
51
+ }
52
+ static { this.ActionId = ActionId; }
53
+ dispatchFileInputAction(action, name) {
54
+ switch (action.id) {
55
+ case FileInputSectionOrganism.ActionId.FILE_SELECTED: {
56
+ return this.dispatch({ id: ActionId.FILE_SELECTED, payload: { scope: name, files: action.payload } });
57
+ }
58
+ case FileInputSectionOrganism.ActionId.CANCEL: {
59
+ return this.dispatch({ id: ActionId.CANCEL, payload: { scope: name } });
60
+ }
61
+ }
62
+ }
63
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: NgAtomicFormSectionSwitcher, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
64
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.2", type: NgAtomicFormSectionSwitcher, isStandalone: true, selector: "ng-atomic-form-section-switcher", inputs: { name: { classPropertyName: "name", publicName: "name", isSignal: true, isRequired: true, transformFunction: null }, control: { classPropertyName: "control", publicName: "control", isSignal: true, isRequired: true, transformFunction: null }, field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null } }, usesInheritance: true, ngImport: i0, template: `
65
+ @if (field(); as field) {
66
+ @switch (field.type) {
67
+ @case ('select') {
68
+ @defer {
69
+ <organisms-select-input-section injectable
70
+ [label]="name() | domain"
71
+ [control]="control()"
72
+ [hint]="field.hint"
73
+ [options]="field.options"
74
+ [placeholder]="field.placeholder"
75
+ [actions]="field.actions"
76
+ [multiple]="field?.multiple"
77
+ (action)="dispatch($event)"
78
+ />
79
+ }
80
+ }
81
+ @case ('date') {
82
+ <organisms-date-input-section
83
+ [label]="name() | domain"
84
+ [hint]="field.hint"
85
+ [control]="control()"
86
+ [actions]="field.actions"
87
+ (action)="dispatch($event)"
88
+ />
89
+ }
90
+ @case ('date-range') {
91
+ <organisms-date-range-input-section
92
+ [label]="name() | domain"
93
+ [hint]="field.hint"
94
+ [control]="control()"
95
+ [actions]="field.actions"
96
+ (action)="dispatch($event)"
97
+ />
98
+ }
99
+ @case ('text') {
100
+ @defer {
101
+ <organisms-text-input-section injectable
102
+ [label]="name() | domain"
103
+ [control]="control()"
104
+ [actions]="field.actions"
105
+ [hint]="field.hint"
106
+ [placeholder]="field.placeholder"
107
+ [autoComplete]="field.autoComplete"
108
+ (action)="dispatch($event)"
109
+ />
110
+ }
111
+ }
112
+ @case ('number') {
113
+ @defer {
114
+ <organisms-number-input-section injectable
115
+ [label]="name() | domain"
116
+ [control]="control()"
117
+ [actions]="field.actions"
118
+ [hint]="field.hint"
119
+ [placeholder]="field.placeholder"
120
+ (action)="dispatch($event)"
121
+ />
122
+ }
123
+ }
124
+ @case ('textarea') {
125
+ @defer {
126
+ <organisms-textarea-section injectable
127
+ [label]="name() | domain"
128
+ [control]="control()"
129
+ [hint]="field.hint"
130
+ [rows]="field.rows"
131
+ [placeholder]="field.placeholder"
132
+ (action)="dispatch($event)"
133
+ />
134
+ }
135
+ }
136
+ @case ('password') {
137
+ @defer {
138
+ <organisms-password-input-section injectable
139
+ [label]="name() | domain"
140
+ [control]="control()"
141
+ [hint]="field.hint"
142
+ [placeholder]="field.placeholder"
143
+ [actions]="field.actions"
144
+ (action)="dispatch($event)"
145
+ />
146
+ }
147
+ }
148
+ @case ('action') {
149
+ @defer {
150
+ <organisms-action-input-section injectable
151
+ [label]="name() | domain"
152
+ [control]="control()"
153
+ [hint]="field.hint"
154
+ [actions]="field.actions"
155
+ (action)="dispatch($event)"
156
+ />
157
+ }
158
+ }
159
+ @case ('file') {
160
+ @defer {
161
+ <organisms-file-input-section injectable
162
+ [label]="name() | domain"
163
+ [control]="control()"
164
+ [hint]="field.hint"
165
+ [progress]="field?.progress"
166
+ (action)="dispatchFileInputAction($event, name())"
167
+ />
168
+ }
169
+ }
170
+ @case ('slider') {
171
+ @defer {
172
+ <organisms-slider-input-section injectable
173
+ [label]="name() | domain"
174
+ [control]="control()"
175
+ [max]="field?.slider?.max"
176
+ [min]="field?.slider?.min"
177
+ [step]="field?.slider?.step"
178
+ (action)="dispatch($event)"
179
+ />
180
+ }
181
+ }
182
+ @case ('agreement') {
183
+ @defer {
184
+ <organisms-agreement-input-section injectable
185
+ [control]="control()"
186
+ [labelTemp]="field?.labelTemp"
187
+ />
188
+ }
189
+ }
190
+ @case ('preview') {
191
+ @defer {
192
+ <organisms-video-section injectable
193
+ [src]="control().value"
194
+ [autoplay]="false"
195
+ />
196
+ }
197
+ }
198
+ @case ('preview:image') {
199
+ @defer {
200
+ <organisms-image-preview-section
201
+ [src]="control().value"
202
+ />
203
+ }
204
+ }
205
+ @case ('hidden') { }
206
+ }
207
+ }
208
+ `, isInline: true, styles: [":host{display:contents}\n"], dependencies: [{ kind: "pipe", type: DomainPipe, name: "domain" }, { kind: "component", type: DateInputSectionOrganism, selector: "organisms-date-input-section" }, { kind: "component", type: DateRangeInputSectionOrganism, selector: "organisms-date-range-input-section" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
209
+ }
210
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: NgAtomicFormSectionSwitcher, decorators: [{
211
+ type: Component,
212
+ args: [{ selector: 'ng-atomic-form-section-switcher', standalone: true, imports: [
213
+ DomainPipe,
214
+ AgreementInputSectionOrganism,
215
+ ActionInputSectionOrganismStore,
216
+ FileInputSectionOrganismStore,
217
+ DateInputSectionOrganism,
218
+ DateRangeInputSectionOrganism,
219
+ TextInputSectionOrganismStore,
220
+ NumberInputSectionOrganismStore,
221
+ TextareaSectionOrganismStore,
222
+ SelectInputSectionOrganismStore,
223
+ SliderInputSectionOrganismStore,
224
+ VideoSectionOrganism,
225
+ ImagePreviewSectionOrganism,
226
+ PasswordInputSectionOrganismStore,
227
+ ], template: `
228
+ @if (field(); as field) {
229
+ @switch (field.type) {
230
+ @case ('select') {
231
+ @defer {
232
+ <organisms-select-input-section injectable
233
+ [label]="name() | domain"
234
+ [control]="control()"
235
+ [hint]="field.hint"
236
+ [options]="field.options"
237
+ [placeholder]="field.placeholder"
238
+ [actions]="field.actions"
239
+ [multiple]="field?.multiple"
240
+ (action)="dispatch($event)"
241
+ />
242
+ }
243
+ }
244
+ @case ('date') {
245
+ <organisms-date-input-section
246
+ [label]="name() | domain"
247
+ [hint]="field.hint"
248
+ [control]="control()"
249
+ [actions]="field.actions"
250
+ (action)="dispatch($event)"
251
+ />
252
+ }
253
+ @case ('date-range') {
254
+ <organisms-date-range-input-section
255
+ [label]="name() | domain"
256
+ [hint]="field.hint"
257
+ [control]="control()"
258
+ [actions]="field.actions"
259
+ (action)="dispatch($event)"
260
+ />
261
+ }
262
+ @case ('text') {
263
+ @defer {
264
+ <organisms-text-input-section injectable
265
+ [label]="name() | domain"
266
+ [control]="control()"
267
+ [actions]="field.actions"
268
+ [hint]="field.hint"
269
+ [placeholder]="field.placeholder"
270
+ [autoComplete]="field.autoComplete"
271
+ (action)="dispatch($event)"
272
+ />
273
+ }
274
+ }
275
+ @case ('number') {
276
+ @defer {
277
+ <organisms-number-input-section injectable
278
+ [label]="name() | domain"
279
+ [control]="control()"
280
+ [actions]="field.actions"
281
+ [hint]="field.hint"
282
+ [placeholder]="field.placeholder"
283
+ (action)="dispatch($event)"
284
+ />
285
+ }
286
+ }
287
+ @case ('textarea') {
288
+ @defer {
289
+ <organisms-textarea-section injectable
290
+ [label]="name() | domain"
291
+ [control]="control()"
292
+ [hint]="field.hint"
293
+ [rows]="field.rows"
294
+ [placeholder]="field.placeholder"
295
+ (action)="dispatch($event)"
296
+ />
297
+ }
298
+ }
299
+ @case ('password') {
300
+ @defer {
301
+ <organisms-password-input-section injectable
302
+ [label]="name() | domain"
303
+ [control]="control()"
304
+ [hint]="field.hint"
305
+ [placeholder]="field.placeholder"
306
+ [actions]="field.actions"
307
+ (action)="dispatch($event)"
308
+ />
309
+ }
310
+ }
311
+ @case ('action') {
312
+ @defer {
313
+ <organisms-action-input-section injectable
314
+ [label]="name() | domain"
315
+ [control]="control()"
316
+ [hint]="field.hint"
317
+ [actions]="field.actions"
318
+ (action)="dispatch($event)"
319
+ />
320
+ }
321
+ }
322
+ @case ('file') {
323
+ @defer {
324
+ <organisms-file-input-section injectable
325
+ [label]="name() | domain"
326
+ [control]="control()"
327
+ [hint]="field.hint"
328
+ [progress]="field?.progress"
329
+ (action)="dispatchFileInputAction($event, name())"
330
+ />
331
+ }
332
+ }
333
+ @case ('slider') {
334
+ @defer {
335
+ <organisms-slider-input-section injectable
336
+ [label]="name() | domain"
337
+ [control]="control()"
338
+ [max]="field?.slider?.max"
339
+ [min]="field?.slider?.min"
340
+ [step]="field?.slider?.step"
341
+ (action)="dispatch($event)"
342
+ />
343
+ }
344
+ }
345
+ @case ('agreement') {
346
+ @defer {
347
+ <organisms-agreement-input-section injectable
348
+ [control]="control()"
349
+ [labelTemp]="field?.labelTemp"
350
+ />
351
+ }
352
+ }
353
+ @case ('preview') {
354
+ @defer {
355
+ <organisms-video-section injectable
356
+ [src]="control().value"
357
+ [autoplay]="false"
358
+ />
359
+ }
360
+ }
361
+ @case ('preview:image') {
362
+ @defer {
363
+ <organisms-image-preview-section
364
+ [src]="control().value"
365
+ />
366
+ }
367
+ }
368
+ @case ('hidden') { }
369
+ }
370
+ }
371
+ `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:contents}\n"] }]
372
+ }] });
373
+ export class NgAtomicFormSectionBuilder extends NgAtomicComponent {
374
+ constructor() {
375
+ super(...arguments);
376
+ this.form = input.required();
377
+ this.formFlatExcludes = input([]);
378
+ this.fieldMap = input.required();
379
+ this.controlEntries = computed(() => {
380
+ return flatControls(this.form(), this.formFlatExcludes()).map(([name, control]) => ({
381
+ name,
382
+ control,
383
+ field: get(this.fieldMap(), name) ?? { type: 'text' },
384
+ }));
385
+ });
386
+ }
387
+ static { this.ActionId = ActionId; }
388
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: NgAtomicFormSectionBuilder, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
389
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.2", type: NgAtomicFormSectionBuilder, isStandalone: true, selector: "ng-atomic-form-section-builder", inputs: { form: { classPropertyName: "form", publicName: "form", isSignal: true, isRequired: true, transformFunction: null }, formFlatExcludes: { classPropertyName: "formFlatExcludes", publicName: "formFlatExcludes", isSignal: true, isRequired: false, transformFunction: null }, fieldMap: { classPropertyName: "fieldMap", publicName: "fieldMap", isSignal: true, isRequired: true, transformFunction: null } }, usesInheritance: true, ngImport: i0, template: `
390
+ @for (entry of controlEntries(); track entry.name;) {
391
+ <ng-atomic-form-section-switcher
392
+ [name]="entry.name"
393
+ [control]="entry.control"
394
+ [field]="entry.field"
395
+ (action)="dispatch($event)"
396
+ />
397
+ }
398
+ `, isInline: true, styles: [":host{display:contents}\n"], dependencies: [{ kind: "component", type: NgAtomicFormSectionSwitcher, selector: "ng-atomic-form-section-switcher", inputs: ["name", "control", "field"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
399
+ }
400
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: NgAtomicFormSectionBuilder, decorators: [{
401
+ type: Component,
402
+ args: [{ standalone: true, selector: 'ng-atomic-form-section-builder', imports: [
403
+ NgAtomicFormSectionSwitcher,
404
+ ], template: `
405
+ @for (entry of controlEntries(); track entry.name;) {
406
+ <ng-atomic-form-section-switcher
407
+ [name]="entry.name"
408
+ [control]="entry.control"
409
+ [field]="entry.field"
410
+ (action)="dispatch($event)"
411
+ />
412
+ }
413
+ `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:contents}\n"] }]
414
+ }] });
415
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.builder.js","sourceRoot":"","sources":["../../../../../../../packages/@ng-atomic/components/src/lib/templates/form/form.builder.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { TextareaSectionOrganismStore } from '@ng-atomic/components/organisms/textarea-section';\nimport { TextInputSectionOrganismStore } from '@ng-atomic/components/organisms/text-input-section';\nimport { DateInputSectionOrganism } from '@ng-atomic/components/organisms/date-input-section';\nimport { SelectInputSectionOrganismStore } from '@ng-atomic/components/organisms/select-input-section';\nimport { FormField, FormFieldMap } from '@ng-atomic/common/pipes/smart-field';\nimport { DomainPipe } from '@ng-atomic/common/pipes/domain';\nimport { AbstractControl } from '@angular/forms';\nimport { _computed, Action } from '@ng-atomic/core';\nimport { ActionInputSectionOrganismStore } from '@ng-atomic/components/organisms/action-input-section';\nimport { NgAtomicComponent } from '@ng-atomic/core';\nimport { FileInputSectionOrganism, FileInputSectionOrganismStore } from '@ng-atomic/components/organisms/file-input-section';\nimport { AgreementInputSectionOrganism } from '@ng-atomic/components/organisms/agreement-input-section';\nimport { VideoSectionOrganism } from '@ng-atomic/components/organisms/video-section';\nimport { NumberInputSectionOrganismStore } from '@ng-atomic/components/organisms/number-input-section';\nimport { ImagePreviewSectionOrganism } from '@ng-atomic/components/organisms/image-preview-section';\nimport { PasswordInputSectionOrganismStore } from '@ng-atomic/components/organisms/password-input-section';\nimport { DateRangeInputSectionOrganism } from '@ng-atomic/components/organisms/date-range-input-section';\nimport { SliderInputSectionOrganismStore } from '@ng-atomic/components/organisms/slider-input-section';\nimport { get } from 'lodash-es';\n\nfunction walkControls(controls: any, cb: (name: string, control: any) => void, excludes: string[] = [], name = '') {\n  Object.entries(controls).forEach(([key, control]: any) => {\n    const path = name === '' ? key : `${name}.${key}`;\n    if (excludes.includes(path)) {\n      cb(path, control);\n    } else if (control.controls) {\n      walkControls(control.controls, cb, excludes, path);\n    } else {\n      cb(path, control);\n    }\n  });\n}\n\nfunction flatControls(form: FormGroup, excludes: string[]): [string, AbstractControl][] {\n  const controlMap = new Map<string, AbstractControl>();\n  walkControls(form?.controls, (name, control: AbstractControl) => controlMap.set(name, control), [\n    ...excludes,\n  ]);\n  return [...controlMap.entries()];\n}\n\n\nenum ActionId {\n  FILE_SELECTED = '[@ng-atomic/components:templates/form/ng-atomic-form-section-switcher] File selected',\n  CANCEL = '[@ng-atomic/components:templates/form/ng-atomic-form-section-switcher] Cancel',\n}\n\n@Component({\n  selector: 'ng-atomic-form-section-switcher',\n  standalone: true,\n  imports: [\n    DomainPipe,\n    AgreementInputSectionOrganism,\n    ActionInputSectionOrganismStore,\n    FileInputSectionOrganismStore,\n    DateInputSectionOrganism,\n    DateRangeInputSectionOrganism,\n    TextInputSectionOrganismStore,\n    NumberInputSectionOrganismStore,\n    TextareaSectionOrganismStore,\n    SelectInputSectionOrganismStore,\n    SliderInputSectionOrganismStore,\n    VideoSectionOrganism,\n    ImagePreviewSectionOrganism,\n    PasswordInputSectionOrganismStore,\n  ],\n  template: `\n    @if (field(); as field) {\n      @switch (field.type) {\n        @case ('select') {\n          @defer {\n            <organisms-select-input-section injectable\n              [label]=\"name() | domain\"\n              [control]=\"control()\"\n              [hint]=\"field.hint\"\n              [options]=\"field.options\"\n              [placeholder]=\"field.placeholder\"\n              [actions]=\"field.actions\"\n              [multiple]=\"field?.multiple\"\n              (action)=\"dispatch($event)\"\n            />\n          }\n        }\n        @case ('date') {\n            <organisms-date-input-section\n              [label]=\"name() | domain\"\n              [hint]=\"field.hint\"\n              [control]=\"control()\"\n              [actions]=\"field.actions\"\n              (action)=\"dispatch($event)\"\n            />\n        }\n        @case ('date-range') {\n          <organisms-date-range-input-section\n            [label]=\"name() | domain\"\n            [hint]=\"field.hint\"\n            [control]=\"control()\"\n            [actions]=\"field.actions\"\n            (action)=\"dispatch($event)\"\n          />\n        }\n        @case ('text') {\n          @defer {\n            <organisms-text-input-section injectable\n              [label]=\"name() | domain\"\n              [control]=\"control()\"\n              [actions]=\"field.actions\"\n              [hint]=\"field.hint\"\n              [placeholder]=\"field.placeholder\"\n              [autoComplete]=\"field.autoComplete\"\n              (action)=\"dispatch($event)\"\n            />\n          }\n        }\n        @case ('number') {\n          @defer {\n            <organisms-number-input-section injectable\n              [label]=\"name() | domain\"\n              [control]=\"control()\"\n              [actions]=\"field.actions\"\n              [hint]=\"field.hint\"\n              [placeholder]=\"field.placeholder\"\n              (action)=\"dispatch($event)\"\n            />\n          }\n        }\n        @case ('textarea') {\n          @defer {\n            <organisms-textarea-section injectable\n              [label]=\"name() | domain\"\n              [control]=\"control()\"\n              [hint]=\"field.hint\"\n              [rows]=\"field.rows\"\n              [placeholder]=\"field.placeholder\"\n              (action)=\"dispatch($event)\"\n            />\n          }\n        }\n        @case ('password') {\n          @defer {\n            <organisms-password-input-section injectable\n              [label]=\"name() | domain\"\n              [control]=\"control()\"\n              [hint]=\"field.hint\"\n              [placeholder]=\"field.placeholder\"\n              [actions]=\"field.actions\"\n              (action)=\"dispatch($event)\"\n            />\n          }\n        }\n        @case ('action') {\n          @defer {\n            <organisms-action-input-section injectable\n              [label]=\"name() | domain\"\n              [control]=\"control()\"\n              [hint]=\"field.hint\"\n              [actions]=\"field.actions\"\n              (action)=\"dispatch($event)\"\n            />\n          }\n        }\n        @case ('file') {\n          @defer {\n            <organisms-file-input-section injectable\n              [label]=\"name() | domain\"\n              [control]=\"control()\"\n              [hint]=\"field.hint\"\n              [progress]=\"field?.progress\"\n              (action)=\"dispatchFileInputAction($event, name())\"\n            />\n          }\n        }\n        @case ('slider') {\n          @defer {\n            <organisms-slider-input-section injectable\n              [label]=\"name() | domain\"\n              [control]=\"control()\"\n              [max]=\"field?.slider?.max\"\n              [min]=\"field?.slider?.min\"\n              [step]=\"field?.slider?.step\"\n              (action)=\"dispatch($event)\"\n            />\n          }\n        }\n        @case ('agreement') {\n          @defer {\n            <organisms-agreement-input-section injectable\n              [control]=\"control()\"\n              [labelTemp]=\"field?.labelTemp\"\n            />\n          }\n        }\n        @case ('preview') {\n          @defer {\n            <organisms-video-section injectable\n              [src]=\"control().value\"\n              [autoplay]=\"false\"\n            />\n          }\n        }\n        @case ('preview:image') {\n          @defer {\n            <organisms-image-preview-section\n              [src]=\"control().value\"\n            />\n          }\n        }\n        @case ('hidden') { }\n      }\n    }\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  styles: [`:host { display: contents; }`]\n})\nexport class NgAtomicFormSectionSwitcher extends NgAtomicComponent {\n  static readonly ActionId = ActionId;\n  readonly name = input.required<string>();\n  readonly control = input.required<AbstractControl>();\n  readonly field = input.required<FormFieldMap | FormField>();\n\n  protected dispatchFileInputAction(action: Action, name: string) {\n    switch (action.id) {\n      case FileInputSectionOrganism.ActionId.FILE_SELECTED: {\n        return this.dispatch({id: ActionId.FILE_SELECTED, payload: {scope: name, files: action.payload}});\n      }\n      case FileInputSectionOrganism.ActionId.CANCEL: {\n        return this.dispatch({id: ActionId.CANCEL, payload: {scope: name}});\n      }\n    }\n  }\n}\n\n@Component({\n  standalone: true,\n  selector: 'ng-atomic-form-section-builder',\n  imports: [\n    NgAtomicFormSectionSwitcher,\n  ],\n  template: `\n    @for (entry of controlEntries(); track entry.name;) {\n      <ng-atomic-form-section-switcher\n        [name]=\"entry.name\"\n        [control]=\"entry.control\"\n        [field]=\"entry.field\"\n        (action)=\"dispatch($event)\"\n      />\n    }\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  styles: `:host { display: contents; }`,\n})\nexport class NgAtomicFormSectionBuilder extends NgAtomicComponent {\n  static readonly ActionId = ActionId;\n\n  readonly form = input.required<FormGroup>();\n  readonly formFlatExcludes = input<string[]>([]);\n  readonly fieldMap = input.required<FormFieldMap>();\n\n  readonly controlEntries = computed(() => {\n    return flatControls(this.form(), this.formFlatExcludes()).map(([name, control]) => ({\n      name,\n      control,\n      field: get(this.fieldMap(), name) ?? {type: 'text'},\n    }));\n  });\n}\n"]}