@ng-atomic/components 17.9.0 → 17.11.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/components.module.mjs +3 -2
- package/esm2022/frames/app/app.frame.mjs +192 -16
- package/esm2022/frames/auto-layout/auto-layout.frame.mjs +2 -2
- package/esm2022/frames/columns/columns.frame.mjs +4 -4
- 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/frames.module.mjs +2 -1
- 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 +11 -4
- 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 +34 -28
- 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/checkbox-column/checkbox-column.molecule.mjs +48 -11
- 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 +11 -8
- 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 +4 -5
- package/esm2022/organisms/messages-section/messages-section.organism.mjs +2 -2
- package/esm2022/organisms/navigation-list/navigation-list.organism.mjs +51 -20
- package/esm2022/organisms/navigator/navigator.organism.mjs +3 -3
- 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 +4 -4
- package/esm2022/organisms/smart-list/smart-list.organism.mjs +11 -3
- package/esm2022/organisms/social-login-section/social-login-section.organism.mjs +2 -2
- package/esm2022/organisms/table/index.helpers.mjs +3 -1
- package/esm2022/organisms/table/table.organism.mjs +205 -101
- 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 +242 -50
- package/esm2022/pages/form/form.page.mjs +71 -46
- package/esm2022/pages/pages.module.mjs +3 -4
- package/esm2022/templates/_index/index.template.mjs +66 -28
- package/esm2022/templates/background/background.template.mjs +2 -2
- package/esm2022/templates/entrance/entrance.template.mjs +2 -2
- package/esm2022/templates/form/form.builder.mjs +12 -2
- package/esm2022/templates/form/form.template.mjs +2 -2
- package/esm2022/templates/icon-button-menu/icon-button-menu.template.mjs +2 -2
- package/esm2022/templates/menu/menu.template.mjs +3 -3
- 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 +191 -15
- 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 +3 -3
- package/fesm2022/ng-atomic-components-frames-columns.mjs.map +1 -1
- 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-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 +10 -3
- package/fesm2022/ng-atomic-components-frames-router-outlet.mjs.map +1 -1
- 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 +33 -27
- package/fesm2022/ng-atomic-components-frames-side-nav.mjs.map +1 -1
- 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-frames.mjs +1 -0
- package/fesm2022/ng-atomic-components-frames.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-molecules-checkbox-column.mjs +47 -10
- package/fesm2022/ng-atomic-components-molecules-checkbox-column.mjs.map +1 -1
- 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 +10 -7
- package/fesm2022/ng-atomic-components-molecules-navigation-list-item.mjs.map +1 -1
- 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 +3 -4
- package/fesm2022/ng-atomic-components-organisms-menu-header.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-organisms-messages-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-navigation-list.mjs +50 -19
- package/fesm2022/ng-atomic-components-organisms-navigation-list.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-organisms-navigator.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-navigator.mjs.map +1 -1
- 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 +3 -3
- package/fesm2022/ng-atomic-components-organisms-slider-input-section.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-organisms-smart-list.mjs +10 -2
- package/fesm2022/ng-atomic-components-organisms-smart-list.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-organisms-social-login-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-table.mjs +206 -100
- package/fesm2022/ng-atomic-components-organisms-table.mjs.map +1 -1
- 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 +242 -50
- package/fesm2022/ng-atomic-components-pages-_index.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-pages-form.mjs +71 -46
- package/fesm2022/ng-atomic-components-pages-form.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-pages.mjs +2 -3
- package/fesm2022/ng-atomic-components-pages.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-templates-_index.mjs +65 -27
- package/fesm2022/ng-atomic-components-templates-_index.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-templates-background.mjs +2 -2
- package/fesm2022/ng-atomic-components-templates-entrance.mjs +2 -2
- package/fesm2022/ng-atomic-components-templates-form.mjs +13 -3
- 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-menu.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-templates-selection.mjs +2 -2
- package/fesm2022/ng-atomic-components-templates-settings.mjs +2 -2
- package/fesm2022/ng-atomic-components.mjs +2 -1
- package/fesm2022/ng-atomic-components.mjs.map +1 -1
- package/frames/app/app.frame.d.ts +69 -52
- package/frames/columns/columns.frame.d.ts +3 -3
- package/frames/fab/fab.frame.d.ts +3 -3
- package/frames/router-outlet/router-outlet.frame.d.ts +4 -3
- package/frames/side-nav/side-nav.frame.d.ts +16 -12
- package/molecules/actions-column/actions-column.molecule.d.ts +3 -3
- package/molecules/checkbox-column/checkbox-column.molecule.d.ts +8 -2
- package/molecules/chips-input-field/chips-input-field.molecule.d.ts +3 -3
- package/molecules/loading-box/loading-box.molecule.d.ts +3 -3
- package/molecules/navigation-list-item/navigation-list-item.molecule.d.ts +3 -2
- package/organisms/menu-header/menu-header.organism.d.ts +10 -4
- package/organisms/navigation-list/navigation-list.organism.d.ts +2 -1
- package/organisms/navigator/navigator.organism.d.ts +3 -3
- package/organisms/slider-input-section/slider-input-section.organism.d.ts +3 -3
- package/organisms/smart-list/smart-list.organism.d.ts +14 -13
- package/organisms/stripe-input-section/stripe-input-section.organism.d.ts +3 -3
- package/organisms/table/index.helpers.d.ts +1 -0
- package/organisms/table/table.organism.d.ts +39 -9
- package/package.json +3 -3
- package/pages/_index/index.page.d.ts +123 -82
- package/pages/form/form.page.d.ts +69 -56
- package/pages/terms/terms.page.d.ts +3 -3
- package/templates/_index/index.template.d.ts +27 -15
- package/templates/form/form.template.d.ts +3 -3
|
@@ -63,7 +63,7 @@ export class ThreadMessagesSectionOrganism extends NgAtomicComponent {
|
|
|
63
63
|
</div>
|
|
64
64
|
<mat-divider />
|
|
65
65
|
}
|
|
66
|
-
`, isInline: true, styles: [":host{display:block;--primary-color: inherit;--primary-color-SCOPED-IN-%COMP%-
|
|
66
|
+
`, isInline: true, styles: [":host{display:block;--primary-color: inherit;--primary-color-SCOPED-IN-%COMP%-ADBN: var(--primary-color);--on-primary-color: inherit;--on-primary-color-SCOPED-IN-%COMP%-ADBN: var(--on-primary-color);--surface-color: inherit;--surface-color-SCOPED-IN-%COMP%-ADBN: var(--surface-color);--on-surface-color: inherit;--on-surface-color-SCOPED-IN-%COMP%-ADBN: var(--on-surface-color);--background-color: inherit;--background-color-SCOPED-IN-%COMP%-ADBN: var(--background-color);--on-background-color: inherit;--on-background-color-SCOPED-IN-%COMP%-ADBN: var(--on-background-color)}:host{display:flex;flex-direction:column;justify-content:flex-start;color:var(--on-surface-color-SCOPED-IN-%COMP%-ADBN)}:host .message{padding:8px 16px}:host .message .header{display:flex;justify-content:flex-start;align-items:center;padding:8px 0;box-sizing:border-box;gap:8px}:host .message .header .name{font-size:14px;font-weight:700}:host .message .header .description{display:flex;justify-content:flex-start;gap:4px;font-size:12px}:host .message .header img{width:40px;height:40px;border-radius:50%;background-color:var(--primary-color-SCOPED-IN-%COMP%-ADBN)}:host .message .content{font-size:14px;padding-bottom:24px;box-sizing:border-box}:host .message .bottom.actions{display:flex;justify-content:flex-end;align-items:center;gap:8px}:host .message .bottom.actions button{height:32px;padding:0 8px;--mdc-outlined-button-label-text-size: 12px}:host mat-divider{width:calc(100% - 16px);box-sizing:border-box;margin:0 8px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: ActionsPipe, name: "resolveActions" }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "pipe", type: DataAccessorPipe, name: "dataAccessor" }, { kind: "ngmodule", type: MatDividerModule }, { kind: "component", type: i2.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "directive", type: FallbackSrcDirective, selector: "[fallbackSrc]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
67
67
|
}
|
|
68
68
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ThreadMessagesSectionOrganism, decorators: [{
|
|
69
69
|
type: Component,
|
|
@@ -114,6 +114,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
114
114
|
directive: ThreadMessagesSectionOrganismStore,
|
|
115
115
|
inputs: ['comments', 'noCommentMessage', 'commentActions']
|
|
116
116
|
}
|
|
117
|
-
], styles: [":host{display:block;--primary-color: inherit;--primary-color-SCOPED-IN-%COMP%-
|
|
117
|
+
], styles: [":host{display:block;--primary-color: inherit;--primary-color-SCOPED-IN-%COMP%-ADBN: var(--primary-color);--on-primary-color: inherit;--on-primary-color-SCOPED-IN-%COMP%-ADBN: var(--on-primary-color);--surface-color: inherit;--surface-color-SCOPED-IN-%COMP%-ADBN: var(--surface-color);--on-surface-color: inherit;--on-surface-color-SCOPED-IN-%COMP%-ADBN: var(--on-surface-color);--background-color: inherit;--background-color-SCOPED-IN-%COMP%-ADBN: var(--background-color);--on-background-color: inherit;--on-background-color-SCOPED-IN-%COMP%-ADBN: var(--on-background-color)}:host{display:flex;flex-direction:column;justify-content:flex-start;color:var(--on-surface-color-SCOPED-IN-%COMP%-ADBN)}:host .message{padding:8px 16px}:host .message .header{display:flex;justify-content:flex-start;align-items:center;padding:8px 0;box-sizing:border-box;gap:8px}:host .message .header .name{font-size:14px;font-weight:700}:host .message .header .description{display:flex;justify-content:flex-start;gap:4px;font-size:12px}:host .message .header img{width:40px;height:40px;border-radius:50%;background-color:var(--primary-color-SCOPED-IN-%COMP%-ADBN)}:host .message .content{font-size:14px;padding-bottom:24px;box-sizing:border-box}:host .message .bottom.actions{display:flex;justify-content:flex-end;align-items:center;gap:8px}:host .message .bottom.actions button{height:32px;padding:0 8px;--mdc-outlined-button-label-text-size: 12px}:host mat-divider{width:calc(100% - 16px);box-sizing:border-box;margin:0 8px}\n"] }]
|
|
118
118
|
}] });
|
|
119
119
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhyZWFkLW1lc3NhZ2VzLXNlY3Rpb24ub3JnYW5pc20uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AbmctYXRvbWljL2NvbXBvbmVudHMvc3JjL2xpYi9vcmdhbmlzbXMvdGhyZWFkLW1lc3NhZ2VzLXNlY3Rpb24vdGhyZWFkLW1lc3NhZ2VzLXNlY3Rpb24ub3JnYW5pc20udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQVUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNyRyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFXLGlCQUFpQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDN0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDakYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDekUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQzs7OztBQUc5RCxNQUFNLE9BQU8sa0NBQWtDO0lBRC9DO1FBRVcsYUFBUSxHQUFHLEtBQUssQ0FBTSxFQUFFLENBQUMsQ0FBQztRQUMxQixxQkFBZ0IsR0FBRyxLQUFLLENBQUMsZUFBZSxDQUFDLENBQUM7UUFDMUMsbUJBQWMsR0FBRyxLQUFLLENBQVUsRUFBRSxDQUFDLENBQUM7S0FDOUM7OEdBSlksa0NBQWtDO2tHQUFsQyxrQ0FBa0M7OzJGQUFsQyxrQ0FBa0M7a0JBRDlDLFNBQVM7bUJBQUMsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFOztBQStEL0IsTUFBTSxPQUFPLDZCQUE4QixTQUFRLGlCQUFpQjtJQXhEcEU7O1FBeURZLFVBQUssR0FBRyxNQUFNLENBQUMsa0NBQWtDLENBQUMsQ0FBQztLQUM5RDs4R0FGWSw2QkFBNkI7a0dBQTdCLDZCQUE2QixpSEE5RDdCLGtDQUFrQywySUFpQm5DOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW1DVCx5aURBMUNDLFlBQVksMEJBQ1osV0FBVyxzREFDWCxlQUFlLHVOQUNmLGdCQUFnQixvREFDaEIsZ0JBQWdCLG1JQUNoQixvQkFBb0I7OzJGQStDWCw2QkFBNkI7a0JBeER6QyxTQUFTOytCQUNFLDBCQUEwQixjQUN4QixJQUFJLFdBQ1A7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLGVBQWU7d0JBQ2YsZ0JBQWdCO3dCQUNoQixnQkFBZ0I7d0JBQ2hCLG9CQUFvQjtxQkFDckIsWUFDUzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FtQ1QsbUJBRWdCLHVCQUF1QixDQUFDLE1BQU0sa0JBQy9CO3dCQUNkOzRCQUNFLFNBQVMsRUFBRSxrQ0FBa0M7NEJBQzdDLE1BQU0sRUFBRSxDQUFDLFVBQVUsRUFBRSxrQkFBa0IsRUFBRSxnQkFBZ0IsQ0FBQzt5QkFDM0Q7cUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBEaXJlY3RpdmUsIGVmZmVjdCwgaW5qZWN0LCBpbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEFjdGlvbnMsIE5nQXRvbWljQ29tcG9uZW50IH0gZnJvbSAnQG5nLWF0b21pYy9jb3JlJztcbmltcG9ydCB7IE1hdERpdmlkZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaXZpZGVyJztcbmltcG9ydCB7IEZhbGxiYWNrU3JjRGlyZWN0aXZlIH0gZnJvbSAnQG5nLWF0b21pYy9jb21tb24vZGlyZWN0aXZlcy9mYWxsYmFjay1zcmMnO1xuaW1wb3J0IHsgRGF0YUFjY2Vzc29yUGlwZSB9IGZyb20gJ0BuZy1hdG9taWMvY29tbW9uL3BpcGVzL2RhdGEtYWNjZXNzb3InO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7IEFjdGlvbnNQaXBlIH0gZnJvbSAnQG5nLWF0b21pYy9jb21tb24vcGlwZXMvYWN0aW9ucyc7XG5cbkBEaXJlY3RpdmUoeyBzdGFuZGFsb25lOiB0cnVlIH0pXG5leHBvcnQgY2xhc3MgVGhyZWFkTWVzc2FnZXNTZWN0aW9uT3JnYW5pc21TdG9yZTxUPiB7XG4gIHJlYWRvbmx5IGNvbW1lbnRzID0gaW5wdXQ8VFtdPihbXSk7XG4gIHJlYWRvbmx5IG5vQ29tbWVudE1lc3NhZ2UgPSBpbnB1dCgn44G+44Gg44Kz44Oh44Oz44OI44Gv44GC44KK44G+44Gb44KT44CCJyk7XG4gIHJlYWRvbmx5IGNvbW1lbnRBY3Rpb25zID0gaW5wdXQ8QWN0aW9ucz4oW10pO1xufVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdvcmdhbmlzbXMtdGhyZWFkLXNlY3Rpb24nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEFjdGlvbnNQaXBlLFxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICBEYXRhQWNjZXNzb3JQaXBlLFxuICAgIE1hdERpdmlkZXJNb2R1bGUsXG4gICAgRmFsbGJhY2tTcmNEaXJlY3RpdmUsXG4gIF0sXG4gIHRlbXBsYXRlOiBgXG4gIEBpZiAoc3RvcmUuY29tbWVudHMoKT8ubGVuZ3RoID09PSAwKSB7XG4gICAgPGRpdiBjbGFzcz1cIm1lc3NhZ2VcIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb250ZW50XCI+XG4gICAgICAgIDxzcGFuPnt7IHN0b3JlLm5vQ29tbWVudE1lc3NhZ2UoKSB9fTwvc3Bhbj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICB9XG5cbiAgQGZvciAoY29tbWVudCBvZiBzdG9yZS5jb21tZW50cygpID8/IFtdOyB0cmFjayBjb21tZW50KSB7XG4gICAgPGRpdiBjbGFzcz1cIm1lc3NhZ2VcIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJoZWFkZXJcIj5cbiAgICAgICAgPGltZyBbc3JjXT1cImNvbW1lbnQgfCBkYXRhQWNjZXNzb3I6J2ljb25VcmwnXCIgZmFsbGJhY2tTcmMgYWx0PVwiXCI+XG4gICAgICAgIDxkaXY+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJuYW1lXCI+e3sgY29tbWVudCB8IGRhdGFBY2Nlc3NvcjonYXV0aG9yTmFtZScgfX08L3NwYW4+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cImRlc2NyaXB0aW9uXCI+XG4gICAgICAgICAgICA8c3Bhbj57eyBjb21tZW50IHwgZGF0YUFjY2Vzc29yOidkZXNjcmlwdGlvbicgfX08L3NwYW4+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29udGVudFwiPlxuICAgICAgICA8c3Bhbj57eyBjb21tZW50IHwgZGF0YUFjY2Vzc29yOidjb250ZW50JyB9fTwvc3Bhbj5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImJvdHRvbSBhY3Rpb25zXCI+XG4gICAgICAgIEBmb3IgKGFjdGlvbiBvZiBzdG9yZS5jb21tZW50QWN0aW9ucygpIHwgcmVzb2x2ZUFjdGlvbnM6Y29tbWVudDsgdHJhY2sgYWN0aW9uLmlkKSB7XG4gICAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgbWF0LXN0cm9rZWQtYnV0dG9uXG4gICAgICAgICAgICBjb2xvcj1cInByaW1hcnlcIlxuICAgICAgICAgICAgKGNsaWNrKT1cImRpc3BhdGNoKGFjdGlvbilcIlxuICAgICAgICAgID57eyBhY3Rpb24ubmFtZSB9fTwvYnV0dG9uPlxuICAgICAgICB9XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8bWF0LWRpdmlkZXIgLz5cbiAgfVxuICBgLFxuICBzdHlsZVVybHM6IFsnLi90aHJlYWQtbWVzc2FnZXMtc2VjdGlvbi5vcmdhbmlzbS5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBob3N0RGlyZWN0aXZlczogW1xuICAgIHtcbiAgICAgIGRpcmVjdGl2ZTogVGhyZWFkTWVzc2FnZXNTZWN0aW9uT3JnYW5pc21TdG9yZSxcbiAgICAgIGlucHV0czogWydjb21tZW50cycsICdub0NvbW1lbnRNZXNzYWdlJywgJ2NvbW1lbnRBY3Rpb25zJ11cbiAgICB9XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgVGhyZWFkTWVzc2FnZXNTZWN0aW9uT3JnYW5pc20gZXh0ZW5kcyBOZ0F0b21pY0NvbXBvbmVudCB7XG4gIHByb3RlY3RlZCBzdG9yZSA9IGluamVjdChUaHJlYWRNZXNzYWdlc1NlY3Rpb25PcmdhbmlzbVN0b3JlKTtcbn1cbiJdfQ==
|
|
@@ -1,25 +1,41 @@
|
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
|
2
|
-
import { Component, Directive, computed, inject, input, signal } from '@angular/core';
|
|
2
|
+
import { Component, Directive, InjectionToken, Injector, computed, effect, inject, input, runInInjectionContext, signal } from '@angular/core';
|
|
3
|
+
import { ActivatedRoute, Router } from '@angular/router';
|
|
4
|
+
import { SelectionModel } from '@angular/cdk/collections';
|
|
3
5
|
import { RouterOutletFrame } from '@ng-atomic/components/frames/router-outlet';
|
|
4
6
|
import { getType, IndexTemplate } from '@ng-atomic/components/templates/_index';
|
|
5
7
|
import { injectAll } from '@ng-atomic/common/stores/entities';
|
|
6
8
|
import { injectModel, injectModelName } from '@ng-atomic/common/pipes/domain';
|
|
7
|
-
import { Effect, InjectableComponent, NgAtomicComponent, _computed } from '@ng-atomic/core';
|
|
8
|
-
import { ActivatedRoute, Router } from '@angular/router';
|
|
9
|
+
import { Effect, InjectableComponent, NgAtomicComponent, _computed, applyToInput, provideEffect } from '@ng-atomic/core';
|
|
9
10
|
import { buildColumns, injectIndexForm } from '@ng-atomic/components/organisms/table';
|
|
10
11
|
import { injectIsRootPage, injectNavStartActions, injectSideAppNavStartActions, makeConfig, NavActionId } from '@ng-atomic/common/services/ui';
|
|
11
|
-
import {
|
|
12
|
-
import {
|
|
13
|
-
import {
|
|
12
|
+
import { injectEntityIdName } from '@ng-atomic/components/pages/form';
|
|
13
|
+
import { computedRawValue, injectChildRouteParam, injectHasNext } from "@ng-atomic/common/utils";
|
|
14
|
+
import { AppService } from '@ng-atomic/common/services/app';
|
|
15
|
+
import { IndexPipe } from '@ng-atomic/common/pipes/index';
|
|
16
|
+
import { map } from 'rxjs';
|
|
17
|
+
import { computedAsync } from 'ngxtension/computed-async';
|
|
18
|
+
import { makeInitializerConfig } from '@ng-atomic/common/services/initializer';
|
|
19
|
+
import { FormGroup } from '@angular/forms';
|
|
20
|
+
import { IndexLengthPipe } from '@ng-atomic/common/pipes/index-length';
|
|
14
21
|
import * as i0 from "@angular/core";
|
|
15
22
|
export function injectHighlight(key) {
|
|
16
|
-
const
|
|
17
|
-
return computed(() => new SelectionModel(true, [
|
|
23
|
+
const itemId = injectChildRouteParam(key);
|
|
24
|
+
return computed(() => new SelectionModel(true, itemId() ? [itemId()] : []));
|
|
25
|
+
}
|
|
26
|
+
const FILTER_FUNC = new InjectionToken('FILTER_FUNC');
|
|
27
|
+
export function provideFilterFunc(useFactory) {
|
|
28
|
+
const wrapped = () => (injector = inject(Injector)) => runInInjectionContext(injector, useFactory);
|
|
29
|
+
return { provide: FILTER_FUNC, useFactory: wrapped };
|
|
30
|
+
}
|
|
31
|
+
export function injectFilterFunc() {
|
|
32
|
+
return (inject(FILTER_FUNC, { optional: true }) ?? (() => () => true))();
|
|
18
33
|
}
|
|
19
34
|
var ActionId;
|
|
20
35
|
(function (ActionId) {
|
|
21
|
-
ActionId["BACK"] = "[@ng-atomic/components/
|
|
36
|
+
ActionId["BACK"] = "[@ng-atomic/components:pages/index] Back";
|
|
22
37
|
ActionId["CHECKBOX_CLICK"] = "[@ng-atomic/components/pages] CheckboxClick";
|
|
38
|
+
ActionId["HEADER_CHECKBOX_CLICK"] = "[@ng-atomic/components/pages] HeaderCheckboxClick";
|
|
23
39
|
ActionId["ADD"] = "[@ng-atomic/components/pages] Add";
|
|
24
40
|
ActionId["DETAIL"] = "[@ng-atomic/components/pages] Detail";
|
|
25
41
|
ActionId["CLOSE"] = "[@ng-atomic/components/pages] Close";
|
|
@@ -30,45 +46,205 @@ export class IndexPageStore extends InjectableComponent {
|
|
|
30
46
|
const highlight = injectHighlight(injectEntityIdName());
|
|
31
47
|
const isRootPage = injectIsRootPage();
|
|
32
48
|
const navStartActions = injectNavStartActions(isRootPage);
|
|
33
|
-
|
|
49
|
+
const filterFunc = injectFilterFunc();
|
|
50
|
+
const modelName = injectModelName();
|
|
51
|
+
return () => ({
|
|
34
52
|
style: {
|
|
35
53
|
width: 'var(--page-width-lv3)',
|
|
36
54
|
},
|
|
37
55
|
items: [],
|
|
38
|
-
itemActions: () => [],
|
|
39
|
-
|
|
40
|
-
|
|
56
|
+
itemActions: (() => []),
|
|
57
|
+
itemsMapper: undefined,
|
|
58
|
+
itemsLength: 0,
|
|
59
|
+
filterFunc,
|
|
60
|
+
title: modelName() ? `${modelName()}一覧` : `取得中...`,
|
|
61
|
+
type: 'table',
|
|
41
62
|
selection: new SelectionModel(true, []),
|
|
42
63
|
highlight: highlight(),
|
|
43
|
-
form:
|
|
64
|
+
form: new FormGroup({}),
|
|
65
|
+
tableChildrenKey: null,
|
|
66
|
+
navStartActions: navStartActions(),
|
|
67
|
+
navEndActions: [],
|
|
68
|
+
});
|
|
69
|
+
}, ['components', 'pages', 'index']); }
|
|
70
|
+
static provideTypeConfig() {
|
|
71
|
+
return IndexPageStore.Config.provide(() => {
|
|
72
|
+
return (config, context) => ({ ...config, type: getType(context) });
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
static provideItemsFromRepository() {
|
|
76
|
+
return IndexPageStore.Config.provide(() => {
|
|
77
|
+
const Model = injectModel();
|
|
78
|
+
const items = Model ? injectAll(Model) : signal([]);
|
|
79
|
+
return (config) => ({ ...config, items: items() });
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
static provideSideAppNavStartActions() {
|
|
83
|
+
return IndexPageStore.Config.provide(() => {
|
|
84
|
+
const isRootPage = injectIsRootPage();
|
|
85
|
+
const navStartActions = injectSideAppNavStartActions(isRootPage);
|
|
86
|
+
return (config) => ({
|
|
87
|
+
...config,
|
|
88
|
+
navStartActions: navStartActions(),
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
static { this.Initializer = makeInitializerConfig(IndexPageStore); }
|
|
93
|
+
static provideFormInitializer() {
|
|
94
|
+
return IndexPageStore.Initializer.provide((store) => {
|
|
95
|
+
const form = injectIndexForm({
|
|
44
96
|
columns: buildColumns([
|
|
45
97
|
'id',
|
|
46
98
|
'createdAt',
|
|
47
99
|
'updatedAt',
|
|
48
100
|
(item) => [{ id: ActionId.DETAIL, icon: 'open_in_new', name: '詳細', payload: item }],
|
|
49
101
|
]),
|
|
102
|
+
});
|
|
103
|
+
applyToInput(store, 'form', form);
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
static provideFormValueStorageInitializer() {
|
|
107
|
+
return IndexPageStore.Initializer.provide((store) => {
|
|
108
|
+
let route = inject(ActivatedRoute);
|
|
109
|
+
const paths = route.pathFromRoot.map(r => r?.routeConfig?.path);
|
|
110
|
+
const key = `@ng-atomic/components/pages/index:${paths.filter((path) => !!path).join('/')}`;
|
|
111
|
+
store.form().patchValue(JSON.parse(localStorage.getItem(key) || '{}'));
|
|
112
|
+
store.form().valueChanges.subscribe(value => {
|
|
113
|
+
localStorage.setItem(key, JSON.stringify(value));
|
|
114
|
+
});
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
static provideItemsLengthInitializer() {
|
|
118
|
+
return [
|
|
119
|
+
IndexLengthPipe,
|
|
120
|
+
IndexPageStore.Initializer.provide((store) => {
|
|
121
|
+
const pipe = inject(IndexLengthPipe);
|
|
122
|
+
const formValue = computedRawValue(() => store.form());
|
|
123
|
+
effect(() => {
|
|
124
|
+
const itemsLength = pipe.transform(store.items(), formValue());
|
|
125
|
+
applyToInput(store, 'itemsLength', itemsLength);
|
|
126
|
+
}, { allowSignalWrites: true });
|
|
50
127
|
}),
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
128
|
+
];
|
|
129
|
+
}
|
|
130
|
+
static provideItemsMapperInitializer() {
|
|
131
|
+
return [
|
|
132
|
+
IndexPipe,
|
|
133
|
+
IndexPageStore.Initializer.provide((store) => {
|
|
134
|
+
const formValue = computedRawValue(() => store.form());
|
|
135
|
+
const indexPipe = inject(IndexPipe);
|
|
136
|
+
effect(() => {
|
|
137
|
+
const value = formValue();
|
|
138
|
+
const itemsMapper = (items) => {
|
|
139
|
+
// const filterFuncs = store.filterFuncs();
|
|
140
|
+
// console.debug('filterFuncs:', filterFuncs);
|
|
141
|
+
// for (const func of filterFuncs ?? []) {
|
|
142
|
+
// console.debug('items:', items);
|
|
143
|
+
// items = items.filter(func);
|
|
144
|
+
// console.debug('filteredItems:', items);
|
|
145
|
+
// }
|
|
146
|
+
return indexPipe.transform(items, value);
|
|
147
|
+
};
|
|
148
|
+
applyToInput(store, 'itemsMapper', itemsMapper);
|
|
149
|
+
}, { allowSignalWrites: true });
|
|
150
|
+
}),
|
|
151
|
+
];
|
|
152
|
+
}
|
|
153
|
+
static provideDefaultInitializer() {
|
|
154
|
+
return [
|
|
155
|
+
IndexPageStore.provideFormInitializer(),
|
|
156
|
+
IndexPageStore.provideFormValueStorageInitializer(),
|
|
157
|
+
IndexPageStore.provideItemsLengthInitializer(),
|
|
158
|
+
IndexPageStore.provideItemsMapperInitializer(),
|
|
159
|
+
];
|
|
160
|
+
}
|
|
161
|
+
static provideBackEffect() {
|
|
162
|
+
return provideEffect(IndexPageStore.ActionId.BACK, () => {
|
|
163
|
+
return () => history.back();
|
|
55
164
|
});
|
|
56
|
-
}
|
|
57
|
-
static
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
165
|
+
}
|
|
166
|
+
static provideDetailEffect() {
|
|
167
|
+
return provideEffect(IndexPageStore.ActionId.DETAIL, () => {
|
|
168
|
+
const app = inject(AppService);
|
|
169
|
+
const store = inject(IndexPageStore);
|
|
170
|
+
const hasNext = injectHasNext();
|
|
171
|
+
return (item) => {
|
|
172
|
+
app.router.navigate([item.id], {
|
|
173
|
+
relativeTo: store.route,
|
|
174
|
+
replaceUrl: hasNext(),
|
|
175
|
+
});
|
|
176
|
+
};
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
static provideAddEffect() {
|
|
180
|
+
return provideEffect(IndexPageStore.ActionId.ADD, () => {
|
|
181
|
+
const app = inject(AppService);
|
|
182
|
+
const hasNext = injectHasNext();
|
|
183
|
+
const route = inject(ActivatedRoute);
|
|
184
|
+
return () => {
|
|
185
|
+
app.router.navigate(['new'], {
|
|
186
|
+
relativeTo: route,
|
|
187
|
+
replaceUrl: !!hasNext(),
|
|
188
|
+
});
|
|
189
|
+
};
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
static provideCheckboxClickEffect() {
|
|
193
|
+
return provideEffect(IndexTemplate.ActionId.TABLE_CHECKBOX_CLICK, () => {
|
|
194
|
+
const store = inject(IndexPageStore);
|
|
195
|
+
return (item) => {
|
|
196
|
+
store.selection().toggle(item.id);
|
|
197
|
+
};
|
|
198
|
+
});
|
|
199
|
+
}
|
|
200
|
+
static provideTableHeaderClickEffect() {
|
|
201
|
+
return provideEffect(IndexTemplate.ActionId.TABLE_HEADER_CLICK, () => {
|
|
202
|
+
const store = inject(IndexPageStore);
|
|
203
|
+
return (key) => {
|
|
204
|
+
const sort = store.form().get(['sort']).value;
|
|
205
|
+
const order = key === sort.key && sort.order === 'asc' ? 'desc' : 'asc';
|
|
206
|
+
store.form().patchValue({ sort: { key, order } });
|
|
207
|
+
};
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
static provideSideNavEffects() {
|
|
211
|
+
return provideEffect(NavActionId.TOGGLE_SIDE_NAV, () => {
|
|
212
|
+
const app = inject(AppService);
|
|
213
|
+
return () => app.sideNav.toggle();
|
|
68
214
|
});
|
|
69
|
-
}
|
|
70
|
-
static
|
|
71
|
-
|
|
215
|
+
}
|
|
216
|
+
static provideHeaderCheckboxClickEffect() {
|
|
217
|
+
return provideEffect(IndexPageStore.ActionId.HEADER_CHECKBOX_CLICK, () => {
|
|
218
|
+
const store = inject(IndexPageStore);
|
|
219
|
+
return () => {
|
|
220
|
+
if (store.isAllSelected()) {
|
|
221
|
+
store.selection().clear();
|
|
222
|
+
}
|
|
223
|
+
else {
|
|
224
|
+
store.displayedItems().forEach(entry => store.selection().select(entry.id));
|
|
225
|
+
}
|
|
226
|
+
};
|
|
227
|
+
});
|
|
228
|
+
}
|
|
229
|
+
static provideDefaultEffects() {
|
|
230
|
+
return [
|
|
231
|
+
IndexPageStore.provideDetailEffect(),
|
|
232
|
+
IndexPageStore.provideAddEffect(),
|
|
233
|
+
IndexPageStore.provideBackEffect(),
|
|
234
|
+
IndexPageStore.provideHeaderCheckboxClickEffect(),
|
|
235
|
+
IndexPageStore.provideCheckboxClickEffect(),
|
|
236
|
+
IndexPageStore.provideTableHeaderClickEffect(),
|
|
237
|
+
IndexPageStore.provideSideNavEffects(),
|
|
238
|
+
];
|
|
239
|
+
}
|
|
240
|
+
static provideDefault() {
|
|
241
|
+
return [
|
|
242
|
+
IndexPageStore.Config.provide(),
|
|
243
|
+
IndexPageStore.provideTypeConfig(),
|
|
244
|
+
IndexPageStore.provideDefaultInitializer(),
|
|
245
|
+
IndexPageStore.provideDefaultEffects(),
|
|
246
|
+
];
|
|
247
|
+
}
|
|
72
248
|
constructor() {
|
|
73
249
|
super();
|
|
74
250
|
this.config = IndexPageStore.Config.inject();
|
|
@@ -83,12 +259,25 @@ export class IndexPageStore extends InjectableComponent {
|
|
|
83
259
|
this.navStartActions = input(_computed(() => this.config().navStartActions));
|
|
84
260
|
this.navEndActions = input(_computed(() => this.config().navEndActions));
|
|
85
261
|
this.filterFunc = input(_computed(() => this.config().filterFunc));
|
|
86
|
-
this.
|
|
262
|
+
this.itemsMapper = input(_computed(() => this.config().itemsMapper));
|
|
87
263
|
this.tableChildrenKey = input(_computed(() => this.config().tableChildrenKey));
|
|
88
|
-
|
|
264
|
+
this.itemsLength = input(_computed(() => this.config().itemsLength));
|
|
265
|
+
this.displayedItems = computed(() => {
|
|
266
|
+
let items = this.items() ?? [];
|
|
267
|
+
const filterFunc = this.filterFunc();
|
|
268
|
+
items = filterFunc ? items.filter(filterFunc) : items;
|
|
269
|
+
const itemsMapper = this.itemsMapper();
|
|
270
|
+
return itemsMapper ? itemsMapper(items) : items;
|
|
271
|
+
});
|
|
272
|
+
this.selectedIds = computedAsync(() => this.selection().changed.pipe(map(() => this.selection()?.selected ?? [])), { initialValue: [] });
|
|
273
|
+
this.selected = computed(() => this.items().filter(entry => this.selectedIds().includes(entry.id)));
|
|
274
|
+
this.isAllSelected = computed(() => {
|
|
275
|
+
return this.displayedItems().every(entry => this.selectedIds().includes(entry.id));
|
|
276
|
+
});
|
|
277
|
+
IndexPageStore.Initializer.initializeStore(this);
|
|
89
278
|
}
|
|
90
279
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: IndexPageStore, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
91
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.2.2", type: IndexPageStore, isStandalone: true, inputs: { type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, items: { classPropertyName: "items", publicName: "items", isSignal: true, isRequired: false, transformFunction: null }, itemActions: { classPropertyName: "itemActions", publicName: "itemActions", isSignal: true, isRequired: false, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, form: { classPropertyName: "form", publicName: "form", isSignal: true, isRequired: false, transformFunction: null }, selection: { classPropertyName: "selection", publicName: "selection", isSignal: true, isRequired: false, transformFunction: null }, highlight: { classPropertyName: "highlight", publicName: "highlight", isSignal: true, isRequired: false, transformFunction: null }, navStartActions: { classPropertyName: "navStartActions", publicName: "navStartActions", isSignal: true, isRequired: false, transformFunction: null }, navEndActions: { classPropertyName: "navEndActions", publicName: "navEndActions", isSignal: true, isRequired: false, transformFunction: null }, filterFunc: { classPropertyName: "filterFunc", publicName: "filterFunc", isSignal: true, isRequired: false, transformFunction: null }, tableChildrenKey: { classPropertyName: "tableChildrenKey", publicName: "tableChildrenKey", isSignal: true, isRequired: false, transformFunction: null } }, usesInheritance: true, ngImport: i0 }); }
|
|
280
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.2.2", type: IndexPageStore, isStandalone: true, inputs: { type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, items: { classPropertyName: "items", publicName: "items", isSignal: true, isRequired: false, transformFunction: null }, itemActions: { classPropertyName: "itemActions", publicName: "itemActions", isSignal: true, isRequired: false, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, form: { classPropertyName: "form", publicName: "form", isSignal: true, isRequired: false, transformFunction: null }, selection: { classPropertyName: "selection", publicName: "selection", isSignal: true, isRequired: false, transformFunction: null }, highlight: { classPropertyName: "highlight", publicName: "highlight", isSignal: true, isRequired: false, transformFunction: null }, navStartActions: { classPropertyName: "navStartActions", publicName: "navStartActions", isSignal: true, isRequired: false, transformFunction: null }, navEndActions: { classPropertyName: "navEndActions", publicName: "navEndActions", isSignal: true, isRequired: false, transformFunction: null }, filterFunc: { classPropertyName: "filterFunc", publicName: "filterFunc", isSignal: true, isRequired: false, transformFunction: null }, itemsMapper: { classPropertyName: "itemsMapper", publicName: "itemsMapper", isSignal: true, isRequired: false, transformFunction: null }, tableChildrenKey: { classPropertyName: "tableChildrenKey", publicName: "tableChildrenKey", isSignal: true, isRequired: false, transformFunction: null }, itemsLength: { classPropertyName: "itemsLength", publicName: "itemsLength", isSignal: true, isRequired: false, transformFunction: null } }, usesInheritance: true, ngImport: i0 }); }
|
|
92
281
|
}
|
|
93
282
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: IndexPageStore, decorators: [{
|
|
94
283
|
type: Directive,
|
|
@@ -101,17 +290,17 @@ export class IndexPage extends NgAtomicComponent {
|
|
|
101
290
|
this.router = inject(Router);
|
|
102
291
|
}
|
|
103
292
|
back() {
|
|
104
|
-
this.dispatch({ id: ActionId.BACK });
|
|
293
|
+
this.dispatch({ id: IndexPageStore.ActionId.BACK });
|
|
105
294
|
}
|
|
106
295
|
close() {
|
|
107
296
|
this.dispatch({ id: ActionId.CLOSE });
|
|
108
297
|
}
|
|
109
|
-
checkboxClick(item) {
|
|
110
|
-
this.store.selection().toggle(item.id);
|
|
111
|
-
}
|
|
112
298
|
itemClick(item) {
|
|
113
299
|
this.dispatch({ id: ActionId.DETAIL, payload: item });
|
|
114
300
|
}
|
|
301
|
+
onCheckboxClick(item) {
|
|
302
|
+
this.dispatch({ id: IndexPageStore.ActionId.HEADER_CHECKBOX_CLICK, payload: item });
|
|
303
|
+
}
|
|
115
304
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: IndexPage, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
116
305
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.2", type: IndexPage, isStandalone: true, selector: "pages-index", usesInheritance: true, hostDirectives: [{ directive: IndexPageStore, inputs: ["items", "items"] }], ngImport: i0, template: `
|
|
117
306
|
<frames-router-outlet>
|
|
@@ -120,7 +309,8 @@ export class IndexPage extends NgAtomicComponent {
|
|
|
120
309
|
[title]="store.title()"
|
|
121
310
|
[type]="store.type()"
|
|
122
311
|
[tableChildrenKey]="store.tableChildrenKey()"
|
|
123
|
-
[items]="store.
|
|
312
|
+
[items]="store.displayedItems()"
|
|
313
|
+
[itemsLength]="store.itemsLength()"
|
|
124
314
|
[itemActions]="store.itemActions()"
|
|
125
315
|
[form]="store.form()"
|
|
126
316
|
[selection]="store.selection()"
|
|
@@ -130,7 +320,7 @@ export class IndexPage extends NgAtomicComponent {
|
|
|
130
320
|
(action)="dispatch($event)"
|
|
131
321
|
/>
|
|
132
322
|
</frames-router-outlet>
|
|
133
|
-
`, isInline: true, styles: [":host{width:100%;height:100%;display:block;--page-width-lv3-SCOPED-IN-index-
|
|
323
|
+
`, isInline: true, styles: [":host{width:100%;height:100%;display:block;--page-width-lv3-SCOPED-IN-index-Zi6m: var(--page-width-lv3);--primary-color-SCOPED-IN-index-Zi6m: var(--primary-color);--on-primary-color-SCOPED-IN-index-Zi6m: var(--on-primary-color);--surface-color-SCOPED-IN-index-Zi6m: var(--surface-color);--on-surface-color-SCOPED-IN-index-Zi6m: var(--on-surface-color);--on-background-color-SCOPED-IN-index-Zi6m: var(--on-background-color);--background-color-SCOPED-IN-index-Zi6m: var(--background-color);--navigator-background-color-SCOPED-IN-index-Zi6m: var(--navigator-background-color);--navigator-on-background-color-SCOPED-IN-index-Zi6m: var(--navigator-on-background-color);--table-background-color-SCOPED-IN-index-Zi6m: var(--table-background-color);--table-on-background-color-SCOPED-IN-index-Zi6m: var(--table-on-background-color)}:host .template{width:var(--page-width-lv3-SCOPED-IN-index-Zi6m)}:host *{--primary-color: var(--primary-color-SCOPED-IN-index-Zi6m);--on-primary-color: var(--on-primary-color-SCOPED-IN-index-Zi6m);--surface-color: var(--surface-color-SCOPED-IN-index-Zi6m);--on-surface-color: var(--on-surface-color-SCOPED-IN-index-Zi6m);--background-color: var(--background-color-SCOPED-IN-index-Zi6m);--on-background-color: var(--on-background-color-SCOPED-IN-index-Zi6m);--navigator-background-color: var(--navigator-background-color-SCOPED-IN-index-Zi6m);--navigator-on-background-color: var(--navigator-on-background-color-SCOPED-IN-index-Zi6m);--table-background-color: var(--table-background-color-SCOPED-IN-index-Zi6m);--table-on-background-color: var(--table-on-background-color-SCOPED-IN-index-Zi6m)}\n"], dependencies: [{ kind: "component", type: RouterOutletFrame, selector: "frames-router-outlet" }, { kind: "component", type: IndexTemplate, selector: "templates-index" }] }); }
|
|
134
324
|
}
|
|
135
325
|
__decorate([
|
|
136
326
|
Effect(IndexTemplate.ActionId.BACK),
|
|
@@ -145,22 +335,23 @@ __decorate([
|
|
|
145
335
|
__metadata("design:returntype", void 0)
|
|
146
336
|
], IndexPage.prototype, "close", null);
|
|
147
337
|
__decorate([
|
|
148
|
-
Effect(IndexTemplate.ActionId.
|
|
338
|
+
Effect(IndexTemplate.ActionId.ITEM_CLICK),
|
|
149
339
|
__metadata("design:type", Function),
|
|
150
340
|
__metadata("design:paramtypes", [Object]),
|
|
151
341
|
__metadata("design:returntype", void 0)
|
|
152
|
-
], IndexPage.prototype, "
|
|
342
|
+
], IndexPage.prototype, "itemClick", null);
|
|
153
343
|
__decorate([
|
|
154
|
-
Effect(IndexTemplate.ActionId.
|
|
344
|
+
Effect(IndexTemplate.ActionId.TABLE_HEADER_CHECKBOX_CLICK),
|
|
155
345
|
__metadata("design:type", Function),
|
|
156
346
|
__metadata("design:paramtypes", [Object]),
|
|
157
347
|
__metadata("design:returntype", void 0)
|
|
158
|
-
], IndexPage.prototype, "
|
|
348
|
+
], IndexPage.prototype, "onCheckboxClick", null);
|
|
159
349
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: IndexPage, decorators: [{
|
|
160
350
|
type: Component,
|
|
161
351
|
args: [{ selector: 'pages-index', standalone: true, imports: [
|
|
162
352
|
RouterOutletFrame,
|
|
163
353
|
IndexTemplate,
|
|
354
|
+
IndexLengthPipe,
|
|
164
355
|
], template: `
|
|
165
356
|
<frames-router-outlet>
|
|
166
357
|
<templates-index
|
|
@@ -168,7 +359,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
168
359
|
[title]="store.title()"
|
|
169
360
|
[type]="store.type()"
|
|
170
361
|
[tableChildrenKey]="store.tableChildrenKey()"
|
|
171
|
-
[items]="store.
|
|
362
|
+
[items]="store.displayedItems()"
|
|
363
|
+
[itemsLength]="store.itemsLength()"
|
|
172
364
|
[itemActions]="store.itemActions()"
|
|
173
365
|
[form]="store.form()"
|
|
174
366
|
[selection]="store.selection()"
|
|
@@ -183,6 +375,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
183
375
|
directive: IndexPageStore,
|
|
184
376
|
inputs: ['items'],
|
|
185
377
|
},
|
|
186
|
-
], styles: [":host{width:100%;height:100%;display:block;--page-width-lv3-SCOPED-IN-index-
|
|
187
|
-
}], propDecorators: { back: [], close: [],
|
|
188
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.page.js","sourceRoot":"","sources":["../../../../../../../packages/@ng-atomic/components/src/lib/pages/_index/index.page.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Directive, Signal, computed, inject, input, signal } from '@angular/core';\nimport { RouterOutletFrame } from '@ng-atomic/components/frames/router-outlet';\nimport { getType, IndexTemplate } from '@ng-atomic/components/templates/_index';\nimport { injectAll } from '@ng-atomic/common/stores/entities';\nimport { injectModel, injectModelName } from '@ng-atomic/common/pipes/domain';\nimport { Actions, Effect, InjectableComponent, NgAtomicComponent, _computed } from '@ng-atomic/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { buildColumns, injectIndexForm } from '@ng-atomic/components/organisms/table';\nimport { injectIsRootPage, injectNavStartActions, injectSideAppNavStartActions, makeConfig, NavActionId } from '@ng-atomic/common/services/ui';\nimport { SelectionModel } from '@angular/cdk/collections';\nimport { initializeStore, injectEntityIdName, provideStoreInitializer } from '@ng-atomic/components/pages/form';\nimport { injectChildRouteParam } from \"@ng-atomic/common/utils\";\n\nexport function injectHighlight(key: string): Signal<SelectionModel<string>> {\n  const transferId = injectChildRouteParam(key);\n  return computed(() => new SelectionModel<string>(true, [transferId()]));\n}\n\nenum ActionId {\n  BACK = '[@ng-atomic/components/pages] Back',\n  CHECKBOX_CLICK = '[@ng-atomic/components/pages] CheckboxClick',\n  ADD = '[@ng-atomic/components/pages] Add',\n  DETAIL = '[@ng-atomic/components/pages] Detail',\n  CLOSE = '[@ng-atomic/components/pages] Close',\n}\n\n@Directive({ standalone: true })\nexport class IndexPageStore extends InjectableComponent {\n  static readonly ActionId = ActionId;\n  static readonly Config = makeConfig(() => {\n    const highlight = injectHighlight(injectEntityIdName());\n    const isRootPage = injectIsRootPage();\n    const navStartActions = injectNavStartActions(isRootPage);\n  \n    return (_, context) => ({\n      style: {\n        width: 'var(--page-width-lv3)',\n      },\n      items: [],\n      itemActions: <Actions>() => [],\n      title: `${injectModelName()()}一覧`,\n      type: getType(context),\n      selection: new SelectionModel<string>(true, []),\n      highlight: highlight(),\n      form: injectIndexForm({\n        columns: buildColumns([\n          'id', \n          'createdAt',\n          'updatedAt',\n          (item: {id: string}) => [{ id: ActionId.DETAIL, icon: 'open_in_new', name: '詳細', payload: item }],\n        ]),\n      }),\n      tableChildrenKey: null,\n      navStartActions: navStartActions(),\n      navEndActions: <Actions>[],\n      filterFunc: (item: any) => true,\n    });\n  }, ['components', 'pages', 'index']);\n  static provideItemsFromRepository = () => IndexPageStore.Config.provide(() => {\n    const Model = injectModel();\n    const items = Model ? injectAll(Model) : signal([]);\n    return (config) => ({...config, items: items()});\n  });\n  static provideSideAppNavStartActions = () => IndexPageStore.Config.provide(() => {\n    const isRootPage = injectIsRootPage();\n    const navStartActions = injectSideAppNavStartActions(isRootPage);\n    return (config) => ({\n      ...config,\n      navStartActions: navStartActions(),\n    });\n  });\n  static provideInitializer = provideStoreInitializer<IndexPageStore>;\n  static provideDefaultInitializer = () => provideStoreInitializer<IndexPageStore>(() => { });\n\n  readonly config = IndexPageStore.Config.inject();\n  readonly route = inject(ActivatedRoute);\n  readonly type = input(_computed(() => this.config().type));\n  readonly items = input(_computed(() => this.config().items));\n  readonly itemActions = input(_computed(() => this.config().itemActions));\n  readonly title = input(_computed(() => this.config().title));\n  readonly form = input(_computed(() => this.config().form));\n  readonly selection = input(_computed(() => this.config().selection));\n  readonly highlight = input(_computed(() => this.config().highlight));\n  readonly navStartActions = input(_computed(() => this.config().navStartActions));\n  readonly navEndActions = input(_computed(() => this.config().navEndActions));\n  readonly filterFunc = input(_computed(() => this.config().filterFunc));\n  readonly filteredItems = computed(() => (this.items() ?? []).filter(this.filterFunc()));\n  readonly tableChildrenKey = input(_computed(() => this.config().tableChildrenKey));\n\n  constructor() {\n    super();\n    initializeStore(this);\n  }\n}\n\n@Component({\n  selector: 'pages-index',\n  standalone: true,\n  imports: [\n    RouterOutletFrame,\n    IndexTemplate,\n  ],\n  template: `\n  <frames-router-outlet>\n    <templates-index\n      [style.width]=\"store.config().style.width\"\n      [title]=\"store.title()\"\n      [type]=\"store.type()\"\n      [tableChildrenKey]=\"store.tableChildrenKey()\"\n      [items]=\"store.filteredItems()\"\n      [itemActions]=\"store.itemActions()\"\n      [form]=\"store.form()\"\n      [selection]=\"store.selection()\"\n      [highlight]=\"store.highlight()\"\n      [navStartActions]=\"store.navStartActions()\"\n      [navEndActions]=\"store.navEndActions()\"\n      (action)=\"dispatch($event)\"\n    />\n  </frames-router-outlet>\n  `,\n  styleUrl: './index.page.scss',\n  hostDirectives: [\n    {\n      directive: IndexPageStore,\n      inputs: ['items'],\n    },\n  ],\n  // providers: [EffectReducer],\n})\nexport class IndexPage extends NgAtomicComponent {\n  protected store = inject(IndexPageStore);\n  protected router = inject(Router);\n\n  @Effect(IndexTemplate.ActionId.BACK)\n  protected back() {\n    this.dispatch({id: ActionId.BACK});\n  }\n\n  @Effect(NavActionId.CLOSE)\n  protected close() {\n    this.dispatch({id: ActionId.CLOSE});\n  }\n\n  @Effect(IndexTemplate.ActionId.CHECKBOX_CLICK)\n  protected checkboxClick(item: {id: string}) {\n    this.store.selection().toggle(item.id);\n  }\n\n  @Effect(IndexTemplate.ActionId.ITEM_CLICK)\n  protected itemClick(item: {id: string}) {\n    this.dispatch({id: ActionId.DETAIL, payload: item});\n  }\n\n  // @Effect(ActionId.DETAIL)\n  // protected detail(item: {id: string}) {\n  //   this.router.navigate([item?.id ?? 'new'], {relativeTo: this.store.route});\n  // }\n}\n"]}
|
|
378
|
+
], styles: [":host{width:100%;height:100%;display:block;--page-width-lv3-SCOPED-IN-index-Zi6m: var(--page-width-lv3);--primary-color-SCOPED-IN-index-Zi6m: var(--primary-color);--on-primary-color-SCOPED-IN-index-Zi6m: var(--on-primary-color);--surface-color-SCOPED-IN-index-Zi6m: var(--surface-color);--on-surface-color-SCOPED-IN-index-Zi6m: var(--on-surface-color);--on-background-color-SCOPED-IN-index-Zi6m: var(--on-background-color);--background-color-SCOPED-IN-index-Zi6m: var(--background-color);--navigator-background-color-SCOPED-IN-index-Zi6m: var(--navigator-background-color);--navigator-on-background-color-SCOPED-IN-index-Zi6m: var(--navigator-on-background-color);--table-background-color-SCOPED-IN-index-Zi6m: var(--table-background-color);--table-on-background-color-SCOPED-IN-index-Zi6m: var(--table-on-background-color)}:host .template{width:var(--page-width-lv3-SCOPED-IN-index-Zi6m)}:host *{--primary-color: var(--primary-color-SCOPED-IN-index-Zi6m);--on-primary-color: var(--on-primary-color-SCOPED-IN-index-Zi6m);--surface-color: var(--surface-color-SCOPED-IN-index-Zi6m);--on-surface-color: var(--on-surface-color-SCOPED-IN-index-Zi6m);--background-color: var(--background-color-SCOPED-IN-index-Zi6m);--on-background-color: var(--on-background-color-SCOPED-IN-index-Zi6m);--navigator-background-color: var(--navigator-background-color-SCOPED-IN-index-Zi6m);--navigator-on-background-color: var(--navigator-on-background-color-SCOPED-IN-index-Zi6m);--table-background-color: var(--table-background-color-SCOPED-IN-index-Zi6m);--table-on-background-color: var(--table-on-background-color-SCOPED-IN-index-Zi6m)}\n"] }]
|
|
379
|
+
}], propDecorators: { back: [], close: [], itemClick: [], onCheckboxClick: [] } });
|
|
380
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.page.js","sourceRoot":"","sources":["../../../../../../../packages/@ng-atomic/components/src/lib/pages/_index/index.page.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Directive, InjectionToken, Injector, Signal, computed, effect, inject, input, runInInjectionContext, signal } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { SelectionModel } from '@angular/cdk/collections';\nimport { RouterOutletFrame } from '@ng-atomic/components/frames/router-outlet';\nimport { getType, IndexTemplate } from '@ng-atomic/components/templates/_index';\nimport { injectAll } from '@ng-atomic/common/stores/entities';\nimport { injectModel, injectModelName } from '@ng-atomic/common/pipes/domain';\nimport { Actions, Effect, InjectableComponent, NgAtomicComponent, _computed, applyToInput, provideEffect } from '@ng-atomic/core';\nimport { buildColumns, injectIndexForm } from '@ng-atomic/components/organisms/table';\nimport { injectIsRootPage, injectNavStartActions, injectSideAppNavStartActions, makeConfig, NavActionId } from '@ng-atomic/common/services/ui';\nimport { injectEntityIdName } from '@ng-atomic/components/pages/form';\nimport { computedRawValue, injectChildRouteParam, injectHasNext } from \"@ng-atomic/common/utils\";\nimport { AppService } from '@ng-atomic/common/services/app';\nimport { IndexPipe } from '@ng-atomic/common/pipes/index';\nimport { map } from 'rxjs';\nimport { computedAsync } from 'ngxtension/computed-async';\nimport { makeInitializerConfig } from '@ng-atomic/common/services/initializer';\nimport { AbstractControl, FormGroup } from '@angular/forms';\nimport { IndexLengthPipe } from '@ng-atomic/common/pipes/index-length';\n\nexport function injectHighlight(key: string): Signal<SelectionModel<string>> {\n  const itemId = injectChildRouteParam(key);\n  return computed(() => new SelectionModel<string>(true, itemId() ? [itemId()] : []));\n}\n\ntype FilterFunc = (item: {id: string}) => boolean;\nconst FILTER_FUNC = new InjectionToken<(injector?: Injector) => FilterFunc>('FILTER_FUNC');\nexport function provideFilterFunc(useFactory: () => FilterFunc) {\n  const wrapped = () => (injector = inject(Injector)) => runInInjectionContext(injector, useFactory);\n\treturn { provide: FILTER_FUNC, useFactory: wrapped };\n}\nexport function injectFilterFunc() {\n  return (inject(FILTER_FUNC, {optional: true}) ?? (() => () => true))();\n}\n\nenum ActionId {\n  BACK = '[@ng-atomic/components:pages/index] Back',\n  CHECKBOX_CLICK = '[@ng-atomic/components/pages] CheckboxClick',\n  HEADER_CHECKBOX_CLICK = '[@ng-atomic/components/pages] HeaderCheckboxClick',\n  ADD = '[@ng-atomic/components/pages] Add',\n  DETAIL = '[@ng-atomic/components/pages] Detail',\n  CLOSE = '[@ng-atomic/components/pages] Close',\n}\n\n@Directive({ standalone: true })\nexport class IndexPageStore extends InjectableComponent {\n  static readonly ActionId = ActionId;\n  static readonly Config = makeConfig(() => {\n    const highlight = injectHighlight(injectEntityIdName());\n    const isRootPage = injectIsRootPage();\n    const navStartActions = injectNavStartActions(isRootPage);  \n    const filterFunc = injectFilterFunc();\n    const modelName = injectModelName();\n    return () => ({\n      style: {\n        width: 'var(--page-width-lv3)',\n      },\n      items: [],\n      itemActions: (() => []) as Actions,\n      itemsMapper: <(items: any[]) => any[]>undefined,\n      itemsLength: 0,\n      filterFunc,\n      title: modelName() ? `${modelName()}一覧` : `取得中...`,\n      type: 'table',\n      selection: new SelectionModel<string>(true, []),\n      highlight: highlight(),\n      form: new FormGroup({}) as AbstractControl,\n      tableChildrenKey: null,\n      navStartActions: navStartActions(),\n      navEndActions: <Actions>[],\n    });\n  }, ['components', 'pages', 'index']);\n\n  static provideTypeConfig() {\n    return IndexPageStore.Config.provide(() => {\n      return (config, context) => ({...config, type: getType(context)});\n    });\n  }\n\n  static provideItemsFromRepository() {\n    return IndexPageStore.Config.provide(() => {\n      const Model = injectModel();\n      const items = Model ? injectAll(Model) : signal([]);\n      return (config) => ({...config, items: items()});\n    });\n  }\n\n  static provideSideAppNavStartActions() {\n    return IndexPageStore.Config.provide(() => {\n      const isRootPage = injectIsRootPage();\n      const navStartActions = injectSideAppNavStartActions(isRootPage);\n      return (config) => ({\n        ...config,\n        navStartActions: navStartActions(),\n      });\n    });\n  }\n\n  static Initializer = makeInitializerConfig(IndexPageStore);\n  static provideFormInitializer() {\n    return IndexPageStore.Initializer.provide((store) => {\n      const form = injectIndexForm({\n        columns: buildColumns([\n          'id', \n          'createdAt',\n          'updatedAt',\n          (item: {id: string}) => [{ id: ActionId.DETAIL, icon: 'open_in_new', name: '詳細', payload: item }],\n        ]),\n      });\n      applyToInput(store, 'form', form);\n    });\n  }\n  static provideFormValueStorageInitializer() {\n    return IndexPageStore.Initializer.provide((store) => {\n      let route = inject(ActivatedRoute);\n      const paths = route.pathFromRoot.map(r => r?.routeConfig?.path);\n      const key = `@ng-atomic/components/pages/index:${paths.filter((path) => !!path).join('/')}`;\n      store.form().patchValue(JSON.parse(localStorage.getItem(key) || '{}'));\n      store.form().valueChanges.subscribe(value => {\n        localStorage.setItem(key, JSON.stringify(value));\n      });\n    });\n  }\n\n  static provideItemsLengthInitializer() {\n    return [\n      IndexLengthPipe,\n      IndexPageStore.Initializer.provide((store) => {\n        const pipe = inject(IndexLengthPipe);\n        const formValue = computedRawValue(() => store.form());\n        effect(() => {\n          const itemsLength = pipe.transform(store.items(), formValue());\n          applyToInput(store, 'itemsLength', itemsLength);\n        }, {allowSignalWrites: true});\n      }),\n    ];\n  }\n\n  static provideItemsMapperInitializer() {\n    return [\n      IndexPipe,\n\t\t\tIndexPageStore.Initializer.provide((store) => {\n\t\t\t\tconst formValue = computedRawValue(() => store.form());\n\t\t\t\tconst indexPipe = inject(IndexPipe);\n\t\t\t\teffect(() => {\n          const value = formValue() as any;\n\t\t\t\t  const itemsMapper = (items: any[]) => {\n            // const filterFuncs = store.filterFuncs();\n            // console.debug('filterFuncs:', filterFuncs);\n            // for (const func of filterFuncs ?? []) {\n            //   console.debug('items:', items);\n            //   items = items.filter(func);\n            //   console.debug('filteredItems:', items);\n            // }\n            return indexPipe.transform(items, value);\n          };\n\t\t\t\t\tapplyToInput(store, 'itemsMapper', itemsMapper);\n\t\t\t\t}, { allowSignalWrites: true });\n\t\t\t}),\n    ];\n  }\n\n  static provideDefaultInitializer() {\n    return [\n      IndexPageStore.provideFormInitializer(),\n      IndexPageStore.provideFormValueStorageInitializer(),\n      IndexPageStore.provideItemsLengthInitializer(),\n      IndexPageStore.provideItemsMapperInitializer(),\n    ];\n  }\n\n  static provideBackEffect() {\n    return provideEffect(IndexPageStore.ActionId.BACK, () => {\n      return () => history.back();\n    });\n  }\n\n  static provideDetailEffect() {\n    return provideEffect(IndexPageStore.ActionId.DETAIL, () => {\n      const app = inject(AppService);\n      const store = inject(IndexPageStore);\n      const hasNext = injectHasNext();\n      return (item: {id: string}) => {\n        app.router.navigate([item.id], {\n          relativeTo: store.route,\n          replaceUrl: hasNext(),\n        });\n      }\n    });\n  }\n\n  static provideAddEffect() {\n    return provideEffect(IndexPageStore.ActionId.ADD, () => {\n      const app = inject(AppService);\n      const hasNext = injectHasNext();\n      const route = inject(ActivatedRoute);\n      return () => {\n        app.router.navigate(['new'], {\n          relativeTo: route,\n          replaceUrl: !!hasNext(),\n        });\n      };\n    });\n  }\n\n  static provideCheckboxClickEffect() {\n    return provideEffect(IndexTemplate.ActionId.TABLE_CHECKBOX_CLICK, () => {\n      const store = inject(IndexPageStore);\n      return (item: {id: string}) => {\n        store.selection().toggle(item.id);\n      };\n    });\n  }\n\n  static provideTableHeaderClickEffect() {\n    return provideEffect(IndexTemplate.ActionId.TABLE_HEADER_CLICK, () => {\n      const store = inject(IndexPageStore);\n      return (key: string) => {\n        const sort = store.form().get(['sort']).value;\n        const order = key === sort.key && sort.order === 'asc' ? 'desc' : 'asc';\n        store.form().patchValue({sort: {key, order}});\n      };\n    });\n  }\n\n  static provideSideNavEffects() {\n    return provideEffect(NavActionId.TOGGLE_SIDE_NAV, () => {\n      const app = inject(AppService);\n      return () => app.sideNav.toggle();\n    });\n  }\n\n  static provideHeaderCheckboxClickEffect() {\n    return provideEffect(IndexPageStore.ActionId.HEADER_CHECKBOX_CLICK, () => {\n      const store = inject(IndexPageStore);\n      return () => {\n        if (store.isAllSelected()) {\n          store.selection().clear();\n        } else {\n          store.displayedItems().forEach(entry => store.selection().select(entry.id));\n        }\n      }\n    });\n  }\n\n  static provideDefaultEffects() {\n    return [\n      IndexPageStore.provideDetailEffect(),\n      IndexPageStore.provideAddEffect(),\n      IndexPageStore.provideBackEffect(),\n      IndexPageStore.provideHeaderCheckboxClickEffect(),\n      IndexPageStore.provideCheckboxClickEffect(),\n      IndexPageStore.provideTableHeaderClickEffect(),\n      IndexPageStore.provideSideNavEffects(),\n    ];\n  }\n\n  static provideDefault() {\n    return [\n      IndexPageStore.Config.provide(),\n      IndexPageStore.provideTypeConfig(),\n      IndexPageStore.provideDefaultInitializer(),\n      IndexPageStore.provideDefaultEffects(),\n    ];\n  }\n\n  readonly config = IndexPageStore.Config.inject();\n  readonly route = inject(ActivatedRoute);\n  readonly type = input(_computed(() => this.config().type));\n  readonly items = input(_computed(() => this.config().items));\n  readonly itemActions = input(_computed(() => this.config().itemActions));\n  readonly title = input(_computed(() => this.config().title));\n  readonly form = input(_computed(() => this.config().form));\n  readonly selection = input(_computed(() => this.config().selection));\n  readonly highlight = input(_computed(() => this.config().highlight));\n  readonly navStartActions = input(_computed(() => this.config().navStartActions));\n  readonly navEndActions = input(_computed(() => this.config().navEndActions));\n  readonly filterFunc = input(_computed(() => this.config().filterFunc));\n  readonly itemsMapper = input(_computed(() => this.config().itemsMapper));\n  readonly tableChildrenKey = input(_computed(() => this.config().tableChildrenKey));\n\n  readonly itemsLength = input(_computed(() => this.config().itemsLength));\n  readonly displayedItems = computed(() => {\n    let items = this.items() ?? [];\n    const filterFunc = this.filterFunc();\n    items = filterFunc ? items.filter(filterFunc) : items;\n    const itemsMapper = this.itemsMapper();\n    return itemsMapper ? itemsMapper(items) : items;\n  });\n  readonly selectedIds = computedAsync(() => this.selection().changed.pipe(\n    map(() => this.selection()?.selected ?? []),\n  ), {initialValue: []});\n  readonly selected = computed(() => this.items().filter(entry => this.selectedIds().includes(entry.id)));\n  readonly isAllSelected = computed(() => {\n    return this.displayedItems().every(entry => this.selectedIds().includes(entry.id));\n  });\n\n  constructor() {\n    super();\n    IndexPageStore.Initializer.initializeStore(this);\n  }\n}\n\n@Component({\n  selector: 'pages-index',\n  standalone: true,\n  imports: [\n    RouterOutletFrame,\n    IndexTemplate,\n    IndexLengthPipe,\n  ],\n  template: `\n  <frames-router-outlet>\n    <templates-index\n      [style.width]=\"store.config().style.width\"\n      [title]=\"store.title()\"\n      [type]=\"store.type()\"\n      [tableChildrenKey]=\"store.tableChildrenKey()\"\n      [items]=\"store.displayedItems()\"\n      [itemsLength]=\"store.itemsLength()\"\n      [itemActions]=\"store.itemActions()\"\n      [form]=\"store.form()\"\n      [selection]=\"store.selection()\"\n      [highlight]=\"store.highlight()\"\n      [navStartActions]=\"store.navStartActions()\"\n      [navEndActions]=\"store.navEndActions()\"\n      (action)=\"dispatch($event)\"\n    />\n  </frames-router-outlet>\n  `,\n  styleUrl: './index.page.scss',\n  hostDirectives: [\n    {\n      directive: IndexPageStore,\n      inputs: ['items'],\n    },\n  ],\n})\nexport class IndexPage extends NgAtomicComponent {\n  protected store = inject(IndexPageStore);\n  protected router = inject(Router);\n\n  @Effect(IndexTemplate.ActionId.BACK)\n  protected back() {\n    this.dispatch({id: IndexPageStore.ActionId.BACK});\n  }\n\n  @Effect(NavActionId.CLOSE)\n  protected close() {\n    this.dispatch({id: ActionId.CLOSE});\n  }\n\n  @Effect(IndexTemplate.ActionId.ITEM_CLICK)\n  protected itemClick(item: {id: string}) {\n    this.dispatch({id: ActionId.DETAIL, payload: item});\n  }\n\n  @Effect(IndexTemplate.ActionId.TABLE_HEADER_CHECKBOX_CLICK)\n  protected onCheckboxClick(item: {id: string}) {\n    this.dispatch({id: IndexPageStore.ActionId.HEADER_CHECKBOX_CLICK, payload: item});\n  }\n}\n"]}
|