@ng-atomic/components 17.6.0 → 17.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/atoms/icon/icon.atom.mjs +2 -2
- package/esm2022/frames/app/app.frame.mjs +12 -9
- package/esm2022/frames/auto-layout/auto-layout.frame.mjs +2 -2
- package/esm2022/frames/columns/columns.frame.mjs +2 -2
- package/esm2022/frames/divider/divider.frame.mjs +2 -2
- package/esm2022/frames/drawer/drawer.frame.mjs +2 -2
- package/esm2022/frames/entrance/entrance.frame.mjs +2 -2
- package/esm2022/frames/fab/fab.frame.mjs +2 -2
- package/esm2022/frames/line-up/line-up.frame.mjs +2 -2
- package/esm2022/frames/loading/loading.frame.mjs +2 -2
- package/esm2022/frames/router-outlet/router-outlet.frame.mjs +2 -2
- package/esm2022/frames/scroll/scroll.frame.mjs +2 -2
- package/esm2022/frames/scroll-v2/scroll.frame.mjs +2 -2
- package/esm2022/frames/side-nav/side-nav.frame.mjs +2 -2
- package/esm2022/frames/smart-menu/smart-menu.frame.mjs +2 -2
- package/esm2022/frames/vertical-hide/vertical-hide.frame.mjs +2 -2
- package/esm2022/molecules/date-input-field/date-input-field.molecule.mjs +2 -2
- package/esm2022/molecules/date-range-input-field/date-range-input-field.molecule.mjs +2 -2
- package/esm2022/molecules/grid-item/grid-item.molecule.mjs +2 -2
- package/esm2022/molecules/loading-box/loading-box.molecule.mjs +2 -2
- package/esm2022/molecules/navigation-list-item/navigation-list-item.molecule.mjs +2 -2
- package/esm2022/molecules/select-input-field/select-input-field.molecule.mjs +2 -2
- package/esm2022/organisms/action-buttons-section/action-buttons-section.organism.mjs +2 -2
- package/esm2022/organisms/action-input-section/action-input-section.organism.mjs +2 -2
- package/esm2022/organisms/card-input-section/card-input-section.organism.mjs +2 -2
- package/esm2022/organisms/cvc-and-exp-input-section/cvc-and-exp-input-section.organism.mjs +2 -2
- package/esm2022/organisms/date-input-section/date-input-section.organism.mjs +2 -2
- package/esm2022/organisms/date-range-input-section/date-range-input-section.organism.mjs +2 -2
- package/esm2022/organisms/definition-list/definition-list.organism.mjs +2 -2
- package/esm2022/organisms/file-input-section/file-input-section.organism.mjs +2 -2
- package/esm2022/organisms/grid-cards-section/grid-cards-section.organism.mjs +2 -2
- package/esm2022/organisms/heading/heading.organism.mjs +2 -2
- package/esm2022/organisms/menu-footer/menu-footer.organism.mjs +2 -2
- package/esm2022/organisms/menu-header/menu-header.organism.mjs +2 -2
- package/esm2022/organisms/messages-section/messages-section.organism.mjs +2 -2
- package/esm2022/organisms/navigation-list/navigation-list.organism.mjs +2 -2
- package/esm2022/organisms/navigator/navigator.organism.mjs +2 -2
- package/esm2022/organisms/number-input-section/number-input-section.organism.mjs +2 -2
- package/esm2022/organisms/paginator/paginator.organism.mjs +2 -2
- package/esm2022/organisms/password-input-section/password-input-section.organism.mjs +2 -2
- package/esm2022/organisms/select-input-section/select-input-section.organism.mjs +2 -2
- package/esm2022/organisms/slider-input-section/slider-input-section.organism.mjs +2 -2
- package/esm2022/organisms/social-login-section/social-login-section.organism.mjs +2 -2
- package/esm2022/organisms/table/table.organism.mjs +2 -2
- package/esm2022/organisms/text-input-section/text-input-section.organism.mjs +2 -2
- package/esm2022/organisms/textarea-section/textarea-section.organism.mjs +2 -2
- package/esm2022/organisms/thread-messages-section/thread-messages-section.organism.mjs +2 -2
- package/esm2022/pages/_index/index.page.mjs +24 -6
- package/esm2022/pages/form/form.page.mjs +23 -5
- package/esm2022/templates/_index/index.template.mjs +2 -2
- package/esm2022/templates/background/background.template.mjs +2 -2
- package/esm2022/templates/entrance/entrance.template.mjs +22 -36
- package/esm2022/templates/form/form.builder.mjs +415 -0
- package/esm2022/templates/form/form.template.mjs +24 -364
- package/esm2022/templates/form/index.mjs +2 -1
- package/esm2022/templates/icon-button-menu/icon-button-menu.template.mjs +2 -2
- package/esm2022/templates/menu/menu.template.mjs +2 -2
- package/esm2022/templates/selection/selection.template.mjs +2 -2
- package/esm2022/templates/settings/settings.template.mjs +2 -2
- package/fesm2022/ng-atomic-components-atoms-icon.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-app.mjs +11 -8
- package/fesm2022/ng-atomic-components-frames-app.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-frames-auto-layout.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-columns.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-divider.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-drawer.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-entrance.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-entrance.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-frames-fab.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-line-up.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-loading.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-router-outlet.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-scroll-v2.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-scroll.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-side-nav.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-smart-menu.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-vertical-hide.mjs +2 -2
- package/fesm2022/ng-atomic-components-molecules-date-input-field.mjs +2 -2
- package/fesm2022/ng-atomic-components-molecules-date-range-input-field.mjs +2 -2
- package/fesm2022/ng-atomic-components-molecules-grid-item.mjs +2 -2
- package/fesm2022/ng-atomic-components-molecules-loading-box.mjs +2 -2
- package/fesm2022/ng-atomic-components-molecules-navigation-list-item.mjs +2 -2
- package/fesm2022/ng-atomic-components-molecules-select-input-field.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-action-buttons-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-action-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-card-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-cvc-and-exp-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-date-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-date-range-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-definition-list.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-file-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-grid-cards-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-heading.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-menu-footer.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-menu-header.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-messages-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-navigation-list.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-navigator.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-number-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-paginator.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-password-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-select-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-slider-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-social-login-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-table.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-text-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-textarea-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-thread-messages-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-pages-_index.mjs +23 -5
- package/fesm2022/ng-atomic-components-pages-_index.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-pages-form.mjs +22 -4
- package/fesm2022/ng-atomic-components-pages-form.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-templates-_index.mjs +2 -2
- package/fesm2022/ng-atomic-components-templates-background.mjs +2 -2
- package/fesm2022/ng-atomic-components-templates-entrance.mjs +21 -35
- package/fesm2022/ng-atomic-components-templates-entrance.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-templates-form.mjs +408 -337
- package/fesm2022/ng-atomic-components-templates-form.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-templates-icon-button-menu.mjs +2 -2
- package/fesm2022/ng-atomic-components-templates-menu.mjs +2 -2
- package/fesm2022/ng-atomic-components-templates-selection.mjs +2 -2
- package/fesm2022/ng-atomic-components-templates-settings.mjs +2 -2
- package/frames/app/app.frame.d.ts +7 -4
- package/package.json +3 -3
- package/pages/_index/index.page.d.ts +5 -2
- package/pages/form/form.page.d.ts +3 -0
- package/templates/entrance/entrance.template.d.ts +3 -1
- package/templates/form/form.builder.d.ts +33 -0
- package/templates/form/form.template.d.ts +7 -13
- 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
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
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-
|
|
81
|
+
`, isInline: true, styles: [":host{--horizontal-padding: 64px;--horizontal-padding-SCOPED-IN-entrance-olss: var(--horizontal-padding);--background-color: #eee;--background-color-SCOPED-IN-entrance-olss: var(--background-color);--on-background-color: #333;--on-background-color-SCOPED-IN-entrance-olss: var(--on-background-color);--page-width-lv1-SCOPED-IN-entrance-olss: var(--page-width-lv1)}:host{display:flex;justify-content:center;align-items:center;background-color:var(--background-color-SCOPED-IN-entrance-olss);color:var(--on-background-color-SCOPED-IN-entrance-olss);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-olss)}:host frames-card ng-atomic-form-section-builder{max-width:calc(100% - 32px);--horizontal-padding: var(--horizontal-padding-SCOPED-IN-entrance-olss)}\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
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
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-
|
|
119
|
+
], styles: [":host{--horizontal-padding: 64px;--horizontal-padding-SCOPED-IN-entrance-olss: var(--horizontal-padding);--background-color: #eee;--background-color-SCOPED-IN-entrance-olss: var(--background-color);--on-background-color: #333;--on-background-color-SCOPED-IN-entrance-olss: var(--on-background-color);--page-width-lv1-SCOPED-IN-entrance-olss: var(--page-width-lv1)}:host{display:flex;justify-content:center;align-items:center;background-color:var(--background-color-SCOPED-IN-entrance-olss);color:var(--on-background-color-SCOPED-IN-entrance-olss);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-olss)}:host frames-card ng-atomic-form-section-builder{max-width:calc(100% - 32px);--horizontal-padding: var(--horizontal-padding-SCOPED-IN-entrance-olss)}\n"] }]
|
|
134
120
|
}] });
|
|
135
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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"]}
|