@ng-atomic/components 18.2.0 → 18.4.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/atoms/smart-menu-button/smart-menu-button.atom.d.ts +3 -3
- package/components.module.d.ts +6 -1
- package/esm2022/atoms/icon/icon.atom.mjs +2 -2
- package/esm2022/atoms/smart-menu-button/smart-menu-button.atom.mjs +77 -114
- package/esm2022/components.module.mjs +7 -3
- package/esm2022/extras/editor/editor.component.mjs +78 -46
- package/esm2022/frames/app/app.frame.mjs +130 -70
- package/esm2022/frames/auto-layout/auto-layout.frame.mjs +29 -7
- 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/frames.module.mjs +3 -3
- package/esm2022/frames/line-up/line-up.animations.mjs +3 -7
- package/esm2022/frames/line-up/line-up.frame.mjs +2 -2
- package/esm2022/frames/loading/loading.frame.mjs +2 -2
- package/esm2022/frames/progress-bar/index.mjs +2 -0
- package/esm2022/frames/progress-bar/ng-atomic-components-frames-progress-bar.mjs +5 -0
- package/esm2022/frames/progress-bar/progress-bar.frame.mjs +53 -0
- package/esm2022/frames/router-outlet/router-outlet.frame.mjs +96 -41
- package/esm2022/frames/scroll/scroll.frame.mjs +32 -14
- package/esm2022/frames/scroll-v2/index.mjs +2 -2
- package/esm2022/frames/side-app/index.mjs +2 -0
- package/esm2022/frames/side-app/ng-atomic-components-frames-side-app.mjs +5 -0
- package/esm2022/frames/side-app/side-app.frame.mjs +74 -0
- package/esm2022/frames/side-nav/side-nav.frame.mjs +27 -21
- package/esm2022/frames/smart-menu/smart-menu.frame.mjs +2 -2
- package/esm2022/frames/tabs/tabs.frame.mjs +13 -7
- package/esm2022/frames/vertical-hide/vertical-hide.frame.mjs +11 -18
- package/esm2022/molecules/action-input-field/action-input-field.molecule.mjs +2 -2
- package/esm2022/molecules/actions-column/actions-column.molecule.mjs +13 -7
- package/esm2022/molecules/checkbox-column/checkbox-column.molecule.mjs +48 -21
- 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/file-input-field/file-input-field.molecule.mjs +2 -2
- package/esm2022/molecules/grid-item/grid-item.molecule.mjs +2 -2
- package/esm2022/molecules/list-item/index.mjs +2 -0
- package/esm2022/molecules/list-item/list-item.molecule.mjs +198 -0
- package/esm2022/molecules/list-item/ng-atomic-components-molecules-list-item.mjs +5 -0
- package/esm2022/molecules/loading-box/loading-box.molecule.mjs +2 -2
- package/esm2022/molecules/molecules.module.mjs +4 -1
- package/esm2022/molecules/navigation-list-item/navigation-list-item.molecule.mjs +2 -2
- package/esm2022/molecules/select-input-field/select-input-field.molecule.mjs +9 -5
- package/esm2022/molecules/smart-column/smart-column.molecule.mjs +129 -43
- package/esm2022/molecules/tree-column/tree-column.molecule.mjs +37 -25
- 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/agreement-input-section/agreement-input-section.organism.mjs +3 -3
- 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 +4 -4
- package/esm2022/organisms/date-range-input-section/date-range-input-section.organism.mjs +4 -4
- 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/filters-section/filters-section.organism.mjs +5 -5
- package/esm2022/organisms/graphql-editor/graphql-editor.organism.mjs +1 -1
- package/esm2022/organisms/grid-cards-section/grid-cards-section.organism.mjs +2 -2
- package/esm2022/organisms/heading/heading.organism.mjs +2 -2
- package/esm2022/{sheets/actions → organisms/list}/index.mjs +2 -2
- package/esm2022/organisms/list/list.organism.mjs +161 -0
- package/esm2022/{sheets/actions/ng-atomic-components-sheets-actions.mjs → organisms/list/ng-atomic-components-organisms-list.mjs} +1 -1
- 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/mermaid-section/mermaid-section.organism.mjs +39 -33
- 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 +49 -19
- package/esm2022/organisms/number-input-section/number-input-section.organism.mjs +2 -2
- package/esm2022/organisms/organisms.module.mjs +5 -5
- 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 +4 -4
- package/esm2022/organisms/selection-list/selection-list.organism.mjs +1 -1
- package/esm2022/organisms/slider-input-section/slider-input-section.organism.mjs +4 -4
- package/esm2022/organisms/social-login-section/social-login-section.organism.mjs +2 -2
- package/esm2022/organisms/table/index.mjs +2 -1
- package/esm2022/organisms/table/table.helpers.mjs +4 -4
- package/esm2022/organisms/table/table.organism.mjs +152 -141
- package/esm2022/organisms/text-input-section/text-input-section.organism.mjs +4 -4
- 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/organisms/tree-list/index.mjs +2 -0
- package/esm2022/organisms/tree-list/ng-atomic-components-organisms-tree-list.mjs +5 -0
- package/esm2022/organisms/tree-list/tree-list.organism.mjs +125 -0
- package/esm2022/pages/_index/index.page.mjs +169 -62
- package/esm2022/pages/columns/columns.page.mjs +10 -9
- package/esm2022/pages/form/form.page.mjs +27 -12
- package/esm2022/pages/terms/terms.page.mjs +2 -2
- package/esm2022/templates/_index/index.template.mjs +276 -155
- package/esm2022/templates/background/background.template.mjs +2 -2
- package/esm2022/templates/code-editor/code-editor.template.mjs +52 -15
- package/esm2022/templates/columns/columns.template.mjs +6 -4
- package/esm2022/templates/entrance/entrance.template.mjs +12 -11
- package/esm2022/templates/form/form.builder.mjs +93 -71
- package/esm2022/templates/form/form.template.mjs +47 -28
- package/esm2022/templates/icon-button-menu/icon-button-menu.template.mjs +69 -16
- package/esm2022/templates/menu/menu.template.mjs +2 -2
- package/esm2022/templates/messages/messages.template.mjs +71 -65
- package/esm2022/templates/selection/selection.template.mjs +2 -2
- package/esm2022/templates/settings/settings.template.mjs +2 -2
- package/extras/editor/editor.component.d.ts +19 -10
- package/fesm2022/ng-atomic-components-atoms-icon.mjs +2 -2
- package/fesm2022/ng-atomic-components-atoms-smart-menu-button.mjs +76 -113
- package/fesm2022/ng-atomic-components-atoms-smart-menu-button.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-extras-editor.mjs +79 -47
- package/fesm2022/ng-atomic-components-extras-editor.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-frames-app.mjs +129 -69
- package/fesm2022/ng-atomic-components-frames-app.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-frames-auto-layout.mjs +29 -7
- package/fesm2022/ng-atomic-components-frames-auto-layout.mjs.map +1 -1
- 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-fab.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-line-up.mjs +4 -8
- package/fesm2022/ng-atomic-components-frames-line-up.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-frames-loading.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames-progress-bar.mjs +60 -0
- package/fesm2022/ng-atomic-components-frames-progress-bar.mjs.map +1 -0
- package/fesm2022/ng-atomic-components-frames-router-outlet.mjs +96 -41
- package/fesm2022/ng-atomic-components-frames-router-outlet.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-frames-scroll-v2.mjs +1 -48
- package/fesm2022/ng-atomic-components-frames-scroll-v2.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-frames-scroll.mjs +31 -13
- package/fesm2022/ng-atomic-components-frames-scroll.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-frames-side-app.mjs +81 -0
- package/fesm2022/ng-atomic-components-frames-side-app.mjs.map +1 -0
- package/fesm2022/ng-atomic-components-frames-side-nav.mjs +26 -20
- 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-tabs.mjs +12 -6
- package/fesm2022/ng-atomic-components-frames-tabs.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-frames-vertical-hide.mjs +10 -17
- package/fesm2022/ng-atomic-components-frames-vertical-hide.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-frames.mjs +2 -2
- package/fesm2022/ng-atomic-components-frames.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-molecules-action-input-field.mjs +1 -1
- package/fesm2022/ng-atomic-components-molecules-action-input-field.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-molecules-actions-column.mjs +12 -6
- package/fesm2022/ng-atomic-components-molecules-actions-column.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-molecules-checkbox-column.mjs +47 -21
- 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-file-input-field.mjs +1 -1
- package/fesm2022/ng-atomic-components-molecules-file-input-field.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-molecules-grid-item.mjs +2 -2
- package/fesm2022/ng-atomic-components-molecules-list-item.mjs +203 -0
- package/fesm2022/ng-atomic-components-molecules-list-item.mjs.map +1 -0
- 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 +8 -4
- package/fesm2022/ng-atomic-components-molecules-select-input-field.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-molecules-smart-column.mjs +128 -43
- package/fesm2022/ng-atomic-components-molecules-smart-column.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-molecules-tree-column.mjs +36 -24
- package/fesm2022/ng-atomic-components-molecules-tree-column.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-molecules.mjs +3 -0
- package/fesm2022/ng-atomic-components-molecules.mjs.map +1 -1
- 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-agreement-input-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-agreement-input-section.mjs.map +1 -1
- 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 +3 -3
- package/fesm2022/ng-atomic-components-organisms-date-input-section.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-organisms-date-range-input-section.mjs +3 -3
- package/fesm2022/ng-atomic-components-organisms-date-range-input-section.mjs.map +1 -1
- 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-filters-section.mjs +4 -4
- package/fesm2022/ng-atomic-components-organisms-filters-section.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-organisms-graphql-editor.mjs +1 -1
- package/fesm2022/ng-atomic-components-organisms-graphql-editor.mjs.map +1 -1
- 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-list.mjs +166 -0
- package/fesm2022/ng-atomic-components-organisms-list.mjs.map +1 -0
- 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-mermaid-section.mjs +38 -32
- package/fesm2022/ng-atomic-components-organisms-mermaid-section.mjs.map +1 -1
- 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 +48 -18
- 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-number-input-section.mjs.map +1 -1
- 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-password-input-section.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-organisms-select-input-section.mjs +3 -3
- package/fesm2022/ng-atomic-components-organisms-select-input-section.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-organisms-selection-list.mjs +1 -1
- package/fesm2022/ng-atomic-components-organisms-selection-list.mjs.map +1 -1
- 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-social-login-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-table.mjs +156 -145
- package/fesm2022/ng-atomic-components-organisms-table.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-organisms-text-input-section.mjs +3 -3
- package/fesm2022/ng-atomic-components-organisms-text-input-section.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-organisms-textarea-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-textarea-section.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-organisms-thread-messages-section.mjs +2 -2
- package/fesm2022/ng-atomic-components-organisms-tree-list.mjs +132 -0
- package/fesm2022/ng-atomic-components-organisms-tree-list.mjs.map +1 -0
- package/fesm2022/ng-atomic-components-organisms.mjs +4 -4
- package/fesm2022/ng-atomic-components-organisms.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-pages-_index.mjs +168 -62
- package/fesm2022/ng-atomic-components-pages-_index.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-pages-columns.mjs +9 -8
- package/fesm2022/ng-atomic-components-pages-columns.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-pages-form.mjs +26 -11
- package/fesm2022/ng-atomic-components-pages-form.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-pages-terms.mjs +1 -1
- package/fesm2022/ng-atomic-components-pages-terms.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-templates-_index.mjs +276 -155
- 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-code-editor.mjs +51 -14
- package/fesm2022/ng-atomic-components-templates-code-editor.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-templates-columns.mjs +5 -3
- package/fesm2022/ng-atomic-components-templates-columns.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-templates-entrance.mjs +11 -10
- package/fesm2022/ng-atomic-components-templates-entrance.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-templates-form.mjs +139 -99
- package/fesm2022/ng-atomic-components-templates-form.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-templates-icon-button-menu.mjs +68 -15
- package/fesm2022/ng-atomic-components-templates-icon-button-menu.mjs.map +1 -1
- package/fesm2022/ng-atomic-components-templates-menu.mjs +2 -2
- package/fesm2022/ng-atomic-components-templates-messages.mjs +71 -65
- package/fesm2022/ng-atomic-components-templates-messages.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 +7 -3
- package/fesm2022/ng-atomic-components.mjs.map +1 -1
- package/frames/app/app.frame.d.ts +13 -1
- package/frames/auto-layout/auto-layout.frame.d.ts +7 -1
- package/frames/progress-bar/index.d.ts +1 -0
- package/frames/progress-bar/progress-bar.frame.d.ts +14 -0
- package/frames/router-outlet/router-outlet.frame.d.ts +20 -9
- package/frames/scroll/scroll.frame.d.ts +5 -1
- package/frames/scroll-v2/index.d.ts +1 -1
- package/frames/side-app/index.d.ts +1 -0
- package/frames/side-app/side-app.frame.d.ts +20 -0
- package/frames/side-nav/side-nav.frame.d.ts +6 -2
- package/frames/tabs/tabs.frame.d.ts +2 -1
- package/frames/vertical-hide/vertical-hide.frame.d.ts +2 -2
- package/molecules/actions-column/actions-column.molecule.d.ts +3 -2
- package/molecules/checkbox-column/checkbox-column.molecule.d.ts +12 -4
- package/molecules/list-item/index.d.ts +1 -0
- package/molecules/list-item/list-item.molecule.d.ts +50 -0
- package/molecules/molecules.module.d.ts +3 -0
- package/molecules/smart-column/smart-column.molecule.d.ts +34 -9
- package/molecules/tree-column/tree-column.molecule.d.ts +6 -2
- package/organisms/list/index.d.ts +1 -0
- package/organisms/{smart-list/smart-list.organism.d.ts → list/list.organism.d.ts} +11 -11
- package/organisms/mermaid-section/mermaid-section.organism.d.ts +10 -10
- package/organisms/navigator/navigator.organism.d.ts +8 -6
- package/organisms/organisms.module.d.ts +1 -1
- package/organisms/table/index.d.ts +1 -0
- package/organisms/table/table.helpers.d.ts +1 -1
- package/organisms/table/table.organism.d.ts +32 -1
- package/organisms/tree-list/index.d.ts +1 -0
- package/organisms/tree-list/tree-list.organism.d.ts +33 -0
- package/package.json +37 -25
- package/pages/_index/index.page.d.ts +72 -43
- package/pages/columns/columns.page.d.ts +5 -2
- package/pages/form/form.page.d.ts +11 -2
- package/templates/_index/index.template.d.ts +40 -11
- package/templates/code-editor/code-editor.template.d.ts +6 -3
- package/templates/entrance/entrance.template.d.ts +1 -1
- package/templates/form/form.builder.d.ts +10 -3
- package/templates/form/form.template.d.ts +2 -1
- package/templates/icon-button-menu/icon-button-menu.template.d.ts +3 -2
- package/templates/messages/messages.template.d.ts +21 -17
- package/esm2022/frames/scroll-v2/scroll.frame.mjs +0 -46
- package/esm2022/organisms/smart-list/index.mjs +0 -2
- package/esm2022/organisms/smart-list/ng-atomic-components-organisms-smart-list.mjs +0 -5
- package/esm2022/organisms/smart-list/smart-list.organism.mjs +0 -218
- package/esm2022/sheets/actions/actions.sheet.mjs +0 -45
- package/esm2022/sheets/index.mjs +0 -3
- package/esm2022/sheets/ng-atomic-components-sheets.mjs +0 -5
- package/esm2022/sheets/sheets.module.mjs +0 -25
- package/esm2022/sheets/sheets.service.mjs +0 -20
- package/fesm2022/ng-atomic-components-organisms-smart-list.mjs +0 -223
- package/fesm2022/ng-atomic-components-organisms-smart-list.mjs.map +0 -1
- package/fesm2022/ng-atomic-components-sheets-actions.mjs +0 -52
- package/fesm2022/ng-atomic-components-sheets-actions.mjs.map +0 -1
- package/fesm2022/ng-atomic-components-sheets.mjs +0 -48
- package/fesm2022/ng-atomic-components-sheets.mjs.map +0 -1
- package/frames/scroll-v2/scroll.frame.d.ts +0 -9
- package/organisms/smart-list/index.d.ts +0 -1
- package/sheets/actions/actions.sheet.d.ts +0 -9
- package/sheets/actions/index.d.ts +0 -1
- package/sheets/index.d.ts +0 -2
- package/sheets/sheets.module.d.ts +0 -11
- package/sheets/sheets.service.d.ts +0 -10
|
@@ -1,16 +1,17 @@
|
|
|
1
|
+
var IndexPageStore_1;
|
|
1
2
|
import { __decorate, __metadata } from "tslib";
|
|
2
3
|
import { Component, Directive, InjectionToken, Injector, computed, effect, inject, input, runInInjectionContext, signal } from '@angular/core';
|
|
3
4
|
import { ActivatedRoute, Router } from '@angular/router';
|
|
4
5
|
import { SelectionModel } from '@angular/cdk/collections';
|
|
5
6
|
import { RouterOutletFrame } from '@ng-atomic/components/frames/router-outlet';
|
|
6
|
-
import { getType, IndexTemplate } from '@ng-atomic/components/templates/_index';
|
|
7
|
+
import { convertToItemsMap, getType, IndexTemplate } from '@ng-atomic/components/templates/_index';
|
|
7
8
|
import { injectAll } from '@ng-atomic/common/stores/entities';
|
|
8
9
|
import { injectModel, injectModelName } from '@ng-atomic/common/pipes/domain';
|
|
9
|
-
import { Effect, InjectableComponent, NgAtomicComponent, _computed, applyToInput, provideEffect } from '@ng-atomic/core';
|
|
10
|
+
import { Effect, InjectableComponent, NgAtomicComponent, TokenizedType, _computed, applyToInput, provideEffect, resolveActions } from '@ng-atomic/core';
|
|
10
11
|
import { buildColumns, injectIndexForm } from '@ng-atomic/components/organisms/table';
|
|
11
12
|
import { injectIsRootPage, injectNavStartActions, injectSideAppNavStartActions, makeConfig, NavActionId } from '@ng-atomic/common/services/ui';
|
|
12
13
|
import { injectEntityIdName } from '@ng-atomic/components/pages/form';
|
|
13
|
-
import { computedRawValue, injectChildRouteParam, injectHasNext } from "@ng-atomic/common/utils";
|
|
14
|
+
import { computedRawValue, injectChildRouteParam, injectHasNext, injectRouteSkip } from "@ng-atomic/common/utils";
|
|
14
15
|
import { AppService } from '@ng-atomic/common/services/app';
|
|
15
16
|
import { IndexPipe } from '@ng-atomic/common/pipes/index';
|
|
16
17
|
import { map } from 'rxjs';
|
|
@@ -18,6 +19,7 @@ import { computedAsync } from 'ngxtension/computed-async';
|
|
|
18
19
|
import { makeInitializerConfig } from '@ng-atomic/common/services/initializer';
|
|
19
20
|
import { FormGroup } from '@angular/forms';
|
|
20
21
|
import { IndexLengthPipe } from '@ng-atomic/common/pipes/index-length';
|
|
22
|
+
import { SheetService } from '@ng-atomic/common/services/sheets';
|
|
21
23
|
import * as i0 from "@angular/core";
|
|
22
24
|
export function injectHighlight(key) {
|
|
23
25
|
const itemId = injectChildRouteParam(key);
|
|
@@ -39,8 +41,44 @@ var ActionId;
|
|
|
39
41
|
ActionId["ADD"] = "[@ng-atomic/components/pages/index] Add";
|
|
40
42
|
ActionId["DETAIL"] = "[@ng-atomic/components/pages/index] Detail";
|
|
41
43
|
ActionId["CLOSE"] = "[@ng-atomic/components/pages/index] Close";
|
|
44
|
+
ActionId["LIST_ITEM_BUTTON_CLICKED"] = "[@ng-atomic/components/pages/index] ListItemButtonClick";
|
|
42
45
|
})(ActionId || (ActionId = {}));
|
|
43
|
-
export
|
|
46
|
+
export function toggleAllSelection(selection, items) {
|
|
47
|
+
if (selection.selected.length === items.length) {
|
|
48
|
+
return new SelectionModel(true, []);
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
return new SelectionModel(true, items.map(entry => entry.id));
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
function tryJsonParse(value) {
|
|
55
|
+
try {
|
|
56
|
+
return JSON.parse(value);
|
|
57
|
+
}
|
|
58
|
+
catch {
|
|
59
|
+
return {};
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
export function recoveryFormValue(form, key = 'default') {
|
|
63
|
+
// FormControlの場合とFormGroupの場合で処理を分ける
|
|
64
|
+
if (form instanceof FormGroup) {
|
|
65
|
+
form.patchValue(tryJsonParse(localStorage.getItem(key)));
|
|
66
|
+
form.valueChanges.subscribe(value => {
|
|
67
|
+
localStorage.setItem(key, JSON.stringify(value));
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
const value = localStorage.getItem(key);
|
|
72
|
+
console.debug('loaded:', value);
|
|
73
|
+
form.setValue(value);
|
|
74
|
+
form.valueChanges.subscribe(value => {
|
|
75
|
+
console.debug('value:', value);
|
|
76
|
+
localStorage.setItem(key, value);
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
let IndexPageStore = class IndexPageStore extends InjectableComponent {
|
|
81
|
+
static { IndexPageStore_1 = this; }
|
|
44
82
|
static { this.ActionId = ActionId; }
|
|
45
83
|
static { this.Config = makeConfig(() => {
|
|
46
84
|
const highlight = injectHighlight(injectEntityIdName());
|
|
@@ -52,7 +90,10 @@ export class IndexPageStore extends InjectableComponent {
|
|
|
52
90
|
style: {
|
|
53
91
|
width: 'var(--page-width-lv3)',
|
|
54
92
|
},
|
|
93
|
+
groupedBy: null,
|
|
94
|
+
groupKeys: [],
|
|
55
95
|
items: [],
|
|
96
|
+
itemsMap: undefined,
|
|
56
97
|
itemActions: (() => []),
|
|
57
98
|
itemsMapper: undefined,
|
|
58
99
|
itemsLength: 0,
|
|
@@ -68,20 +109,30 @@ export class IndexPageStore extends InjectableComponent {
|
|
|
68
109
|
});
|
|
69
110
|
}, ['components', 'pages', 'index']); }
|
|
70
111
|
static provideTypeConfig() {
|
|
71
|
-
return
|
|
112
|
+
return IndexPageStore_1.Config.provide(() => {
|
|
72
113
|
return (config, context) => ({ ...config, type: getType(context) });
|
|
73
114
|
});
|
|
74
115
|
}
|
|
75
116
|
static provideItemsFromRepository() {
|
|
76
|
-
return
|
|
117
|
+
return IndexPageStore_1.Config.provide(() => {
|
|
77
118
|
const Model = injectModel();
|
|
78
119
|
const items = Model ? injectAll(Model) : signal([]);
|
|
79
120
|
return (config) => ({ ...config, items: items() });
|
|
80
121
|
});
|
|
81
122
|
}
|
|
123
|
+
static provideItemActionsConfig() {
|
|
124
|
+
return IndexPageStore_1.Config.provide(() => {
|
|
125
|
+
return (config) => ({
|
|
126
|
+
...config,
|
|
127
|
+
itemActions: (item) => [
|
|
128
|
+
{ id: ActionId.DETAIL, icon: 'open_in_new', name: '詳細', payload: item },
|
|
129
|
+
],
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
}
|
|
82
133
|
static provideSideAppNavStartActions() {
|
|
83
|
-
return
|
|
84
|
-
const isRootPage = injectIsRootPage();
|
|
134
|
+
return IndexPageStore_1.Config.provide(() => {
|
|
135
|
+
const isRootPage = injectIsRootPage('side');
|
|
85
136
|
const navStartActions = injectSideAppNavStartActions(isRootPage);
|
|
86
137
|
return (config) => ({
|
|
87
138
|
...config,
|
|
@@ -89,9 +140,9 @@ export class IndexPageStore extends InjectableComponent {
|
|
|
89
140
|
});
|
|
90
141
|
});
|
|
91
142
|
}
|
|
92
|
-
static { this.Initializer = makeInitializerConfig(
|
|
143
|
+
static { this.Initializer = makeInitializerConfig(IndexPageStore_1); }
|
|
93
144
|
static provideFormInitializer() {
|
|
94
|
-
return
|
|
145
|
+
return IndexPageStore_1.Initializer.provide((store) => {
|
|
95
146
|
const form = injectIndexForm({
|
|
96
147
|
columns: buildColumns([
|
|
97
148
|
'id',
|
|
@@ -104,20 +155,17 @@ export class IndexPageStore extends InjectableComponent {
|
|
|
104
155
|
});
|
|
105
156
|
}
|
|
106
157
|
static provideFormValueStorageInitializer() {
|
|
107
|
-
return
|
|
158
|
+
return IndexPageStore_1.Initializer.provide((store) => {
|
|
108
159
|
const route = inject(ActivatedRoute);
|
|
109
160
|
const paths = route.pathFromRoot.map(r => r?.routeConfig?.path);
|
|
110
161
|
const key = `@ng-atomic/components/pages/index:${paths.filter((path) => !!path).join('/')}`;
|
|
111
|
-
store.form()
|
|
112
|
-
store.form().valueChanges.subscribe(value => {
|
|
113
|
-
localStorage.setItem(key, JSON.stringify(value));
|
|
114
|
-
});
|
|
162
|
+
recoveryFormValue(store.form(), key);
|
|
115
163
|
});
|
|
116
164
|
}
|
|
117
165
|
static provideItemsLengthInitializer() {
|
|
118
166
|
return [
|
|
119
167
|
IndexLengthPipe,
|
|
120
|
-
|
|
168
|
+
IndexPageStore_1.Initializer.provide((store) => {
|
|
121
169
|
const pipe = inject(IndexLengthPipe);
|
|
122
170
|
const formValue = computedRawValue(() => store.form());
|
|
123
171
|
effect(() => {
|
|
@@ -130,7 +178,7 @@ export class IndexPageStore extends InjectableComponent {
|
|
|
130
178
|
static provideItemsMapperInitializer() {
|
|
131
179
|
return [
|
|
132
180
|
IndexPipe,
|
|
133
|
-
|
|
181
|
+
IndexPageStore_1.Initializer.provide((store) => {
|
|
134
182
|
const formValue = computedRawValue(() => store.form());
|
|
135
183
|
const indexPipe = inject(IndexPipe);
|
|
136
184
|
effect(() => {
|
|
@@ -150,23 +198,42 @@ export class IndexPageStore extends InjectableComponent {
|
|
|
150
198
|
}),
|
|
151
199
|
];
|
|
152
200
|
}
|
|
201
|
+
static provideColumnsInitializer(useFactory) {
|
|
202
|
+
return [
|
|
203
|
+
IndexPageStore_1.Initializer.provide((store) => {
|
|
204
|
+
const columns = useFactory();
|
|
205
|
+
const form = injectIndexForm({ columns: buildColumns(columns) });
|
|
206
|
+
applyToInput(store, 'form', form);
|
|
207
|
+
}),
|
|
208
|
+
];
|
|
209
|
+
}
|
|
210
|
+
static provideItemsInitializer(itemsFactory) {
|
|
211
|
+
return [
|
|
212
|
+
IndexPageStore_1.Initializer.provide((store) => {
|
|
213
|
+
const items = itemsFactory();
|
|
214
|
+
effect(() => {
|
|
215
|
+
applyToInput(store, 'items', items);
|
|
216
|
+
}, { allowSignalWrites: true });
|
|
217
|
+
}),
|
|
218
|
+
];
|
|
219
|
+
}
|
|
153
220
|
static provideDefaultInitializer() {
|
|
154
221
|
return [
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
222
|
+
IndexPageStore_1.provideFormInitializer(),
|
|
223
|
+
IndexPageStore_1.provideFormValueStorageInitializer(),
|
|
224
|
+
IndexPageStore_1.provideItemsLengthInitializer(),
|
|
225
|
+
IndexPageStore_1.provideItemsMapperInitializer(),
|
|
159
226
|
];
|
|
160
227
|
}
|
|
161
228
|
static provideBackEffect() {
|
|
162
|
-
return provideEffect(
|
|
229
|
+
return provideEffect(IndexPageStore_1.ActionId.BACK, () => {
|
|
163
230
|
return () => history.back();
|
|
164
231
|
});
|
|
165
232
|
}
|
|
166
233
|
static provideDetailEffect() {
|
|
167
|
-
return provideEffect(
|
|
234
|
+
return provideEffect(IndexPageStore_1.ActionId.DETAIL, () => {
|
|
168
235
|
const app = inject(AppService);
|
|
169
|
-
const store = inject(
|
|
236
|
+
const store = inject(IndexPageStore_1);
|
|
170
237
|
const hasNext = injectHasNext();
|
|
171
238
|
return (item) => {
|
|
172
239
|
app.router.navigate([item.id], {
|
|
@@ -177,7 +244,7 @@ export class IndexPageStore extends InjectableComponent {
|
|
|
177
244
|
});
|
|
178
245
|
}
|
|
179
246
|
static provideAddEffect() {
|
|
180
|
-
return provideEffect(
|
|
247
|
+
return provideEffect(IndexPageStore_1.ActionId.ADD, () => {
|
|
181
248
|
const app = inject(AppService);
|
|
182
249
|
const hasNext = injectHasNext();
|
|
183
250
|
const route = inject(ActivatedRoute);
|
|
@@ -191,7 +258,7 @@ export class IndexPageStore extends InjectableComponent {
|
|
|
191
258
|
}
|
|
192
259
|
static provideCheckboxClickEffect() {
|
|
193
260
|
return provideEffect(IndexTemplate.ActionId.TABLE_CHECKBOX_CLICK, () => {
|
|
194
|
-
const store = inject(
|
|
261
|
+
const store = inject(IndexPageStore_1);
|
|
195
262
|
return (item) => {
|
|
196
263
|
store.selection().toggle(item.id);
|
|
197
264
|
};
|
|
@@ -199,7 +266,7 @@ export class IndexPageStore extends InjectableComponent {
|
|
|
199
266
|
}
|
|
200
267
|
static provideTableHeaderClickEffect() {
|
|
201
268
|
return provideEffect(IndexTemplate.ActionId.TABLE_HEADER_CLICK, () => {
|
|
202
|
-
const store = inject(
|
|
269
|
+
const store = inject(IndexPageStore_1);
|
|
203
270
|
return (key) => {
|
|
204
271
|
const sort = store.form().get(['sort']).value;
|
|
205
272
|
const order = key === sort.key && sort.order === 'asc' ? 'desc' : 'asc';
|
|
@@ -214,43 +281,49 @@ export class IndexPageStore extends InjectableComponent {
|
|
|
214
281
|
});
|
|
215
282
|
}
|
|
216
283
|
static provideHeaderCheckboxClickEffect() {
|
|
217
|
-
return provideEffect(
|
|
218
|
-
const store = inject(
|
|
284
|
+
return provideEffect(IndexPageStore_1.ActionId.HEADER_CHECKBOX_CLICK, () => {
|
|
285
|
+
const store = inject(IndexPageStore_1);
|
|
219
286
|
return () => {
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
}
|
|
223
|
-
else {
|
|
224
|
-
store.displayedItems().forEach(entry => store.selection().select(entry.id));
|
|
225
|
-
}
|
|
287
|
+
const selection = toggleAllSelection(store.selection(), store.displayedItems());
|
|
288
|
+
applyToInput(store, 'selection', selection);
|
|
226
289
|
};
|
|
227
290
|
});
|
|
228
291
|
}
|
|
229
292
|
static provideDefaultEffects() {
|
|
230
293
|
return [
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
294
|
+
IndexPageStore_1.provideDetailEffect(),
|
|
295
|
+
IndexPageStore_1.provideAddEffect(),
|
|
296
|
+
IndexPageStore_1.provideBackEffect(),
|
|
297
|
+
IndexPageStore_1.provideHeaderCheckboxClickEffect(),
|
|
298
|
+
IndexPageStore_1.provideCheckboxClickEffect(),
|
|
299
|
+
IndexPageStore_1.provideTableHeaderClickEffect(),
|
|
300
|
+
IndexPageStore_1.provideSideNavEffects(),
|
|
301
|
+
];
|
|
302
|
+
}
|
|
303
|
+
static provideDefaultConfig() {
|
|
304
|
+
return [
|
|
305
|
+
IndexPageStore_1.Config.provide(),
|
|
306
|
+
IndexPageStore_1.provideItemActionsConfig(),
|
|
307
|
+
IndexPageStore_1.provideTypeConfig(),
|
|
238
308
|
];
|
|
239
309
|
}
|
|
240
310
|
static provideDefault() {
|
|
241
311
|
return [
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
IndexPageStore.provideDefaultEffects(),
|
|
312
|
+
IndexPageStore_1.provideDefaultConfig(),
|
|
313
|
+
IndexPageStore_1.provideDefaultInitializer(),
|
|
314
|
+
IndexPageStore_1.provideDefaultEffects(),
|
|
246
315
|
];
|
|
247
316
|
}
|
|
248
317
|
constructor() {
|
|
249
318
|
super();
|
|
250
|
-
this.config =
|
|
319
|
+
this.config = IndexPageStore_1.Config.inject();
|
|
320
|
+
this.style = input(_computed(() => this.config().style));
|
|
251
321
|
this.route = inject(ActivatedRoute);
|
|
322
|
+
this.groupedBy = input(_computed(() => this.config().groupedBy));
|
|
323
|
+
this.groupKeys = input(_computed(() => this.config().groupKeys));
|
|
252
324
|
this.type = input(_computed(() => this.config().type));
|
|
253
325
|
this.items = input(_computed(() => this.config().items));
|
|
326
|
+
this.itemsMap = input(_computed(() => convertToItemsMap(this.items())));
|
|
254
327
|
this.itemActions = input(_computed(() => this.config().itemActions));
|
|
255
328
|
this.title = input(_computed(() => this.config().title));
|
|
256
329
|
this.form = input(_computed(() => this.config().form));
|
|
@@ -270,15 +343,24 @@ export class IndexPageStore extends InjectableComponent {
|
|
|
270
343
|
return itemsMapper ? itemsMapper(items) : items;
|
|
271
344
|
});
|
|
272
345
|
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)));
|
|
346
|
+
this.selected = computed(() => (this.items() ?? []).filter(entry => this.selectedIds().includes(entry.id)));
|
|
274
347
|
this.isAllSelected = computed(() => {
|
|
275
348
|
return this.displayedItems().every(entry => this.selectedIds().includes(entry.id));
|
|
276
349
|
});
|
|
277
|
-
|
|
350
|
+
this.skip = injectRouteSkip();
|
|
351
|
+
IndexPageStore_1.Initializer.initializeStore(this);
|
|
352
|
+
effect(() => {
|
|
353
|
+
console.debug('itemsMap:', this.itemsMap());
|
|
354
|
+
});
|
|
278
355
|
}
|
|
279
356
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: IndexPageStore, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
280
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.1.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 }); }
|
|
281
|
-
}
|
|
357
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.1.2", type: IndexPageStore, isStandalone: true, inputs: { style: { classPropertyName: "style", publicName: "style", isSignal: true, isRequired: false, transformFunction: null }, groupedBy: { classPropertyName: "groupedBy", publicName: "groupedBy", isSignal: true, isRequired: false, transformFunction: null }, groupKeys: { classPropertyName: "groupKeys", publicName: "groupKeys", isSignal: true, isRequired: false, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, items: { classPropertyName: "items", publicName: "items", isSignal: true, isRequired: false, transformFunction: null }, itemsMap: { classPropertyName: "itemsMap", publicName: "itemsMap", 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 }); }
|
|
358
|
+
};
|
|
359
|
+
IndexPageStore = IndexPageStore_1 = __decorate([
|
|
360
|
+
TokenizedType(),
|
|
361
|
+
__metadata("design:paramtypes", [])
|
|
362
|
+
], IndexPageStore);
|
|
363
|
+
export { IndexPageStore };
|
|
282
364
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: IndexPageStore, decorators: [{
|
|
283
365
|
type: Directive,
|
|
284
366
|
args: [{ standalone: true }]
|
|
@@ -288,6 +370,7 @@ export class IndexPage extends NgAtomicComponent {
|
|
|
288
370
|
super(...arguments);
|
|
289
371
|
this.store = inject(IndexPageStore);
|
|
290
372
|
this.router = inject(Router);
|
|
373
|
+
this.sheet = inject(SheetService);
|
|
291
374
|
}
|
|
292
375
|
back() {
|
|
293
376
|
this.dispatch({ id: IndexPageStore.ActionId.BACK });
|
|
@@ -301,17 +384,30 @@ export class IndexPage extends NgAtomicComponent {
|
|
|
301
384
|
onCheckboxClick(item) {
|
|
302
385
|
this.dispatch({ id: IndexPageStore.ActionId.HEADER_CHECKBOX_CLICK, payload: item });
|
|
303
386
|
}
|
|
387
|
+
// MEMO(@nontangent): シートのアクションをページに持たせるべきかは要検討。
|
|
388
|
+
onItemButtonClicked(item) {
|
|
389
|
+
const actions = resolveActions(this.store.itemActions(), item);
|
|
390
|
+
this.sheet.openActions(actions).then((action) => {
|
|
391
|
+
this.dispatch({
|
|
392
|
+
id: action.id,
|
|
393
|
+
payload: action.payload,
|
|
394
|
+
});
|
|
395
|
+
});
|
|
396
|
+
}
|
|
304
397
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: IndexPage, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
305
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.2", type: IndexPage, isStandalone: true, selector: "pages-index", usesInheritance: true, hostDirectives: [{ directive: IndexPageStore, inputs: ["items", "items"] }], ngImport: i0, template: `
|
|
306
|
-
<frames-router-outlet>
|
|
398
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.2", type: IndexPage, isStandalone: true, selector: "pages-index", usesInheritance: true, hostDirectives: [{ directive: IndexPageStore, inputs: ["items", "items", "itemsMap", "itemsMap"] }], ngImport: i0, template: `
|
|
399
|
+
<frames-router-outlet [skip]="store.skip()">
|
|
307
400
|
<templates-index
|
|
308
|
-
[style
|
|
401
|
+
[style]="store.style()"
|
|
309
402
|
[title]="store.title()"
|
|
310
403
|
[type]="store.type()"
|
|
311
404
|
[tableChildrenKey]="store.tableChildrenKey()"
|
|
312
405
|
[items]="store.displayedItems()"
|
|
406
|
+
[itemsMap]="store.itemsMap()"
|
|
313
407
|
[itemsLength]="store.itemsLength()"
|
|
314
408
|
[itemActions]="store.itemActions()"
|
|
409
|
+
[groupedBy]="store.groupedBy()"
|
|
410
|
+
[groupKeys]="store.groupKeys()"
|
|
315
411
|
[form]="store.form()"
|
|
316
412
|
[selection]="store.selection()"
|
|
317
413
|
[highlight]="store.highlight()"
|
|
@@ -320,7 +416,7 @@ export class IndexPage extends NgAtomicComponent {
|
|
|
320
416
|
(action)="dispatch($event)"
|
|
321
417
|
/>
|
|
322
418
|
</frames-router-outlet>
|
|
323
|
-
`, isInline: true, styles: [":host{width:100%;height:100%;display:block;--page-width-lv3-SCOPED-IN-index-
|
|
419
|
+
`, isInline: true, styles: [":host{width:100%;height:100%;display:block;--page-width-lv3-SCOPED-IN-index-Xw2p: var(--page-width-lv3);--primary-color-SCOPED-IN-index-Xw2p: var(--primary-color);--on-primary-color-SCOPED-IN-index-Xw2p: var(--on-primary-color);--surface-color-SCOPED-IN-index-Xw2p: var(--surface-color);--on-surface-color-SCOPED-IN-index-Xw2p: var(--on-surface-color);--on-background-color-SCOPED-IN-index-Xw2p: var(--on-background-color);--background-color-SCOPED-IN-index-Xw2p: var(--background-color);--navigator-background-color-SCOPED-IN-index-Xw2p: var(--navigator-background-color);--navigator-on-background-color-SCOPED-IN-index-Xw2p: var(--navigator-on-background-color);--table-background-color-SCOPED-IN-index-Xw2p: var(--table-background-color);--table-on-background-color-SCOPED-IN-index-Xw2p: var(--table-on-background-color)}:host .template{width:var(--page-width-lv3-SCOPED-IN-index-Xw2p)}:host *{--primary-color: var(--primary-color-SCOPED-IN-index-Xw2p);--on-primary-color: var(--on-primary-color-SCOPED-IN-index-Xw2p);--surface-color: var(--surface-color-SCOPED-IN-index-Xw2p);--on-surface-color: var(--on-surface-color-SCOPED-IN-index-Xw2p);--background-color: var(--background-color-SCOPED-IN-index-Xw2p);--on-background-color: var(--on-background-color-SCOPED-IN-index-Xw2p);--navigator-background-color: var(--navigator-background-color-SCOPED-IN-index-Xw2p);--navigator-on-background-color: var(--navigator-on-background-color-SCOPED-IN-index-Xw2p);--table-background-color: var(--table-background-color-SCOPED-IN-index-Xw2p);--table-on-background-color: var(--table-on-background-color-SCOPED-IN-index-Xw2p)}\n"], dependencies: [{ kind: "component", type: RouterOutletFrame, selector: "frames-router-outlet", outputs: ["events"] }, { kind: "component", type: IndexTemplate, selector: "templates-index" }] }); }
|
|
324
420
|
}
|
|
325
421
|
__decorate([
|
|
326
422
|
Effect(IndexTemplate.ActionId.BACK),
|
|
@@ -346,22 +442,30 @@ __decorate([
|
|
|
346
442
|
__metadata("design:paramtypes", [Object]),
|
|
347
443
|
__metadata("design:returntype", void 0)
|
|
348
444
|
], IndexPage.prototype, "onCheckboxClick", null);
|
|
445
|
+
__decorate([
|
|
446
|
+
Effect(IndexTemplate.ActionId.LIST_ITEM_BUTTON_CLICKED),
|
|
447
|
+
__metadata("design:type", Function),
|
|
448
|
+
__metadata("design:paramtypes", [Object]),
|
|
449
|
+
__metadata("design:returntype", void 0)
|
|
450
|
+
], IndexPage.prototype, "onItemButtonClicked", null);
|
|
349
451
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: IndexPage, decorators: [{
|
|
350
452
|
type: Component,
|
|
351
453
|
args: [{ selector: 'pages-index', standalone: true, imports: [
|
|
352
454
|
RouterOutletFrame,
|
|
353
455
|
IndexTemplate,
|
|
354
|
-
IndexLengthPipe,
|
|
355
456
|
], template: `
|
|
356
|
-
<frames-router-outlet>
|
|
457
|
+
<frames-router-outlet [skip]="store.skip()">
|
|
357
458
|
<templates-index
|
|
358
|
-
[style
|
|
459
|
+
[style]="store.style()"
|
|
359
460
|
[title]="store.title()"
|
|
360
461
|
[type]="store.type()"
|
|
361
462
|
[tableChildrenKey]="store.tableChildrenKey()"
|
|
362
463
|
[items]="store.displayedItems()"
|
|
464
|
+
[itemsMap]="store.itemsMap()"
|
|
363
465
|
[itemsLength]="store.itemsLength()"
|
|
364
466
|
[itemActions]="store.itemActions()"
|
|
467
|
+
[groupedBy]="store.groupedBy()"
|
|
468
|
+
[groupKeys]="store.groupKeys()"
|
|
365
469
|
[form]="store.form()"
|
|
366
470
|
[selection]="store.selection()"
|
|
367
471
|
[highlight]="store.highlight()"
|
|
@@ -373,8 +477,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
|
|
|
373
477
|
`, hostDirectives: [
|
|
374
478
|
{
|
|
375
479
|
directive: IndexPageStore,
|
|
376
|
-
inputs: [
|
|
480
|
+
inputs: [
|
|
481
|
+
'items',
|
|
482
|
+
'itemsMap',
|
|
483
|
+
],
|
|
377
484
|
},
|
|
378
|
-
], styles: [":host{width:100%;height:100%;display:block;--page-width-lv3-SCOPED-IN-index-
|
|
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/index] CheckboxClick',\n  HEADER_CHECKBOX_CLICK = '[@ng-atomic/components/pages/index] HeaderCheckboxClick',\n  ADD = '[@ng-atomic/components/pages/index] Add',\n  DETAIL = '[@ng-atomic/components/pages/index] Detail',\n  CLOSE = '[@ng-atomic/components/pages/index] 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      const 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"]}
|
|
485
|
+
], styles: [":host{width:100%;height:100%;display:block;--page-width-lv3-SCOPED-IN-index-Xw2p: var(--page-width-lv3);--primary-color-SCOPED-IN-index-Xw2p: var(--primary-color);--on-primary-color-SCOPED-IN-index-Xw2p: var(--on-primary-color);--surface-color-SCOPED-IN-index-Xw2p: var(--surface-color);--on-surface-color-SCOPED-IN-index-Xw2p: var(--on-surface-color);--on-background-color-SCOPED-IN-index-Xw2p: var(--on-background-color);--background-color-SCOPED-IN-index-Xw2p: var(--background-color);--navigator-background-color-SCOPED-IN-index-Xw2p: var(--navigator-background-color);--navigator-on-background-color-SCOPED-IN-index-Xw2p: var(--navigator-on-background-color);--table-background-color-SCOPED-IN-index-Xw2p: var(--table-background-color);--table-on-background-color-SCOPED-IN-index-Xw2p: var(--table-on-background-color)}:host .template{width:var(--page-width-lv3-SCOPED-IN-index-Xw2p)}:host *{--primary-color: var(--primary-color-SCOPED-IN-index-Xw2p);--on-primary-color: var(--on-primary-color-SCOPED-IN-index-Xw2p);--surface-color: var(--surface-color-SCOPED-IN-index-Xw2p);--on-surface-color: var(--on-surface-color-SCOPED-IN-index-Xw2p);--background-color: var(--background-color-SCOPED-IN-index-Xw2p);--on-background-color: var(--on-background-color-SCOPED-IN-index-Xw2p);--navigator-background-color: var(--navigator-background-color-SCOPED-IN-index-Xw2p);--navigator-on-background-color: var(--navigator-on-background-color-SCOPED-IN-index-Xw2p);--table-background-color: var(--table-background-color-SCOPED-IN-index-Xw2p);--table-on-background-color: var(--table-on-background-color-SCOPED-IN-index-Xw2p)}\n"] }]
|
|
486
|
+
}], propDecorators: { back: [], close: [], itemClick: [], onCheckboxClick: [], onItemButtonClicked: [] } });
|
|
487
|
+
//# 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":";;AAAA,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,cAAc,EAAE,QAAQ,EAAoB,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,qBAAqB,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACjK,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,iBAAiB,EAAE,MAAM,4CAA4C,CAAC;AAC/E,OAAO,EAAE,iBAAiB,EAAE,OAAO,EAAE,aAAa,EAAY,MAAM,wCAAwC,CAAC;AAC7G,OAAO,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;AAC9D,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AAC9E,OAAO,EAAW,MAAM,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,aAAa,EAAE,SAAS,EAAE,YAAY,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjK,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,uCAAuC,CAAC;AACtF,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,4BAA4B,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC/I,OAAO,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AACtE,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,aAAa,EAAoB,eAAe,EAAE,MAAM,yBAAyB,CAAC;AACpI,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAC5D,OAAO,EAAE,SAAS,EAAE,MAAM,+BAA+B,CAAC;AAC1D,OAAO,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAC3B,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,wCAAwC,CAAC;AAC/E,OAAO,EAAmB,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAC;;AAEjE,MAAM,UAAU,eAAe,CAAC,GAAW;IACzC,MAAM,MAAM,GAAG,qBAAqB,CAAC,GAAG,CAAC,CAAC;IAC1C,OAAO,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,cAAc,CAAS,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AACtF,CAAC;AAGD,MAAM,WAAW,GAAG,IAAI,cAAc,CAAsC,aAAa,CAAC,CAAC;AAC3F,MAAM,UAAU,iBAAiB,CAAC,UAA4B;IAC5D,MAAM,OAAO,GAAG,GAAG,EAAE,CAAC,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC,qBAAqB,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;IACpG,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC;AACtD,CAAC;AACD,MAAM,UAAU,gBAAgB;IAC9B,OAAO,CAAC,MAAM,CAAC,WAAW,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;AACzE,CAAC;AAED,IAAK,QAQJ;AARD,WAAK,QAAQ;IACX,6DAAiD,CAAA;IACjD,gFAAoE,CAAA;IACpE,6FAAiF,CAAA;IACjF,2DAA+C,CAAA;IAC/C,iEAAqD,CAAA;IACrD,+DAAmD,CAAA;IACnD,gGAAoF,CAAA;AACtF,CAAC,EARI,QAAQ,KAAR,QAAQ,QAQZ;AAED,MAAM,UAAU,kBAAkB,CAAC,SAAiC,EAAE,KAAqB;IACzF,IAAI,SAAS,CAAC,QAAQ,CAAC,MAAM,KAAK,KAAK,CAAC,MAAM,EAAE,CAAC;QAC/C,OAAO,IAAI,cAAc,CAAS,IAAI,EAAE,EAAE,CAAC,CAAC;IAC9C,CAAC;SAAM,CAAC;QACN,OAAO,IAAI,cAAc,CAAS,IAAI,EAAE,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;IACxE,CAAC;AACH,CAAC;AAED,SAAS,YAAY,CAAC,KAAa;IACjC,IAAI,CAAC;QACH,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,IAAqB,EAAE,MAAc,SAAS;IAC9E,qCAAqC;IACrC,IAAI,IAAI,YAAY,SAAS,EAAE,CAAC;QAC9B,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAClC,YAAY,CAAC,OAAO,CAAC,GAAG,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;QACnD,CAAC,CAAC,CAAC;IACL,CAAC;SAAM,CAAC;QACN,MAAM,KAAK,GAAG,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QACxC,OAAO,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QAChC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAClC,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;YAC/B,YAAY,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QACnC,CAAC,CAAC,CAAC;IACL,CAAC;AACH,CAAC;AAIM,IAAM,cAAc,GAApB,MAAM,cAAkB,SAAQ,mBAAmB;;aACxC,aAAQ,GAAG,QAAQ,AAAX,CAAY;aACpB,WAAM,GAAG,UAAU,CAAC,GAAG,EAAE;QACvC,MAAM,SAAS,GAAG,eAAe,CAAC,kBAAkB,EAAE,CAAC,CAAC;QACxD,MAAM,UAAU,GAAG,gBAAgB,EAAE,CAAC;QACtC,MAAM,eAAe,GAAG,qBAAqB,CAAC,UAAU,CAAC,CAAC;QAC1D,MAAM,UAAU,GAAG,gBAAgB,EAAE,CAAC;QACtC,MAAM,SAAS,GAAG,eAAe,EAAE,CAAC;QACpC,OAAO,GAAG,EAAE,CAAC,CAAC;YACZ,KAAK,EAAE;gBACL,KAAK,EAAE,uBAAuB;aAC/B;YACD,SAAS,EAAU,IAAI;YACvB,SAAS,EAAE,EAAE;YACb,KAAK,EAAE,EAAE;YACT,QAAQ,EAAiB,SAAS;YAClC,WAAW,EAAE,CAAC,GAAG,EAAE,CAAC,EAAE,CAAY;YAClC,WAAW,EAA2B,SAAS;YAC/C,WAAW,EAAE,CAAC;YACd,UAAU;YACV,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,GAAG,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,QAAQ;YAClD,IAAI,EAA6B,OAAO;YACxC,SAAS,EAAE,IAAI,cAAc,CAAS,IAAI,EAAE,EAAE,CAAC;YAC/C,SAAS,EAAE,SAAS,EAAE;YACtB,IAAI,EAAE,IAAI,SAAS,CAAC,EAAE,CAAoB;YAC1C,gBAAgB,EAAE,IAAI;YACtB,eAAe,EAAE,eAAe,EAAE;YAClC,aAAa,EAAW,EAAE;SAC3B,CAAC,CAAC;IACL,CAAC,EAAE,CAAC,YAAY,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,AA3Bd,CA2Be;IAErC,MAAM,CAAC,iBAAiB;QACtB,OAAO,gBAAc,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,EAAE;YACxC,OAAO,CAAC,MAAM,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC,EAAC,GAAG,MAAM,EAAE,IAAI,EAAE,OAAO,CAAC,OAAO,CAAC,EAAC,CAAC,CAAC;QACpE,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,0BAA0B;QAC/B,OAAO,gBAAc,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,EAAE;YACxC,MAAM,KAAK,GAAG,WAAW,EAAE,CAAC;YAC5B,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;YACpD,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,EAAC,GAAG,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,EAAC,CAAC,CAAC;QACnD,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,wBAAwB;QAC7B,OAAO,gBAAc,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,EAAE;YACxC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;gBAClB,GAAG,MAAM;gBACT,WAAW,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC;oBACrB,EAAE,EAAE,EAAE,QAAQ,CAAC,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE;iBACxE;aACF,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,6BAA6B;QAClC,OAAO,gBAAc,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,EAAE;YACxC,MAAM,UAAU,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;YAC5C,MAAM,eAAe,GAAG,4BAA4B,CAAC,UAAU,CAAC,CAAC;YACjE,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;gBAClB,GAAG,MAAM;gBACT,eAAe,EAAE,eAAe,EAAE;aACnC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;aAEM,gBAAW,GAAG,qBAAqB,CAAC,gBAAc,CAAC,AAAxC,CAAyC;IAC3D,MAAM,CAAC,sBAAsB;QAC3B,OAAO,gBAAc,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YAClD,MAAM,IAAI,GAAG,eAAe,CAAC;gBAC3B,OAAO,EAAE,YAAY,CAAC;oBACpB,IAAI;oBACJ,WAAW;oBACX,WAAW;oBACX,CAAC,IAAkB,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,QAAQ,CAAC,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;iBAClG,CAAC;aACH,CAAC,CAAC;YACH,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;IACL,CAAC;IACD,MAAM,CAAC,kCAAkC;QACvC,OAAO,gBAAc,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YAClD,MAAM,KAAK,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;YACrC,MAAM,KAAK,GAAG,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,WAAW,EAAE,IAAI,CAAC,CAAC;YAChE,MAAM,GAAG,GAAG,qCAAqC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;YAC5F,iBAAiB,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,GAAG,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,6BAA6B;QAClC,OAAO;YACL,eAAe;YACf,gBAAc,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;gBAC3C,MAAM,IAAI,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;gBACrC,MAAM,SAAS,GAAG,gBAAgB,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;gBACvD,MAAM,CAAC,GAAG,EAAE;oBACV,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC;oBAC/D,YAAY,CAAC,KAAK,EAAE,aAAa,EAAE,WAAW,CAAC,CAAC;gBAClD,CAAC,EAAE,EAAC,iBAAiB,EAAE,IAAI,EAAC,CAAC,CAAC;YAChC,CAAC,CAAC;SACH,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,6BAA6B;QAClC,OAAO;YACL,SAAS;YACZ,gBAAc,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;gBAC5C,MAAM,SAAS,GAAG,gBAAgB,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;gBACvD,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;gBACpC,MAAM,CAAC,GAAG,EAAE;oBACN,MAAM,KAAK,GAAG,SAAS,EAAS,CAAC;oBACrC,MAAM,WAAW,GAAG,CAAC,KAAY,EAAE,EAAE;wBAC/B,2CAA2C;wBAC3C,8CAA8C;wBAC9C,0CAA0C;wBAC1C,oCAAoC;wBACpC,gCAAgC;wBAChC,4CAA4C;wBAC5C,IAAI;wBACJ,OAAO,SAAS,CAAC,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;oBAC3C,CAAC,CAAC;oBACP,YAAY,CAAC,KAAK,EAAE,aAAa,EAAE,WAAW,CAAC,CAAC;gBACjD,CAAC,EAAE,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAAC,CAAC;YACjC,CAAC,CAAC;SACA,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,yBAAyB,CAAC,UAA0B;QACzD,OAAO;YACL,gBAAc,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;gBAC3C,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;gBAC7B,MAAM,IAAI,GAAG,eAAe,CAAC,EAAE,OAAO,EAAE,YAAY,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;gBACjE,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC;YACpC,CAAC,CAAC;SACH,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,uBAAuB,CAAC,YAAyB;QACtD,OAAO;YACL,gBAAc,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;gBAC3C,MAAM,KAAK,GAAG,YAAY,EAAE,CAAC;gBACjC,MAAM,CAAC,GAAG,EAAE;oBACX,YAAY,CAAC,KAAK,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;gBACrC,CAAC,EAAE,EAAC,iBAAiB,EAAE,IAAI,EAAC,CAAC,CAAC;YAC/B,CAAC,CAAC;SACA,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,yBAAyB;QAC9B,OAAO;YACL,gBAAc,CAAC,sBAAsB,EAAE;YACvC,gBAAc,CAAC,kCAAkC,EAAE;YACnD,gBAAc,CAAC,6BAA6B,EAAE;YAC9C,gBAAc,CAAC,6BAA6B,EAAE;SAC/C,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,iBAAiB;QACtB,OAAO,aAAa,CAAC,gBAAc,CAAC,QAAQ,CAAC,IAAI,EAAE,GAAG,EAAE;YACtD,OAAO,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;QAC9B,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,mBAAmB;QACxB,OAAO,aAAa,CAAC,gBAAc,CAAC,QAAQ,CAAC,MAAM,EAAE,GAAG,EAAE;YACxD,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;YAC/B,MAAM,KAAK,GAAG,MAAM,CAAC,gBAAc,CAAC,CAAC;YACrC,MAAM,OAAO,GAAG,aAAa,EAAE,CAAC;YAChC,OAAO,CAAC,IAAkB,EAAE,EAAE;gBAC5B,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE;oBAC7B,UAAU,EAAE,KAAK,CAAC,KAAK;oBACvB,UAAU,EAAE,OAAO,EAAE;iBACtB,CAAC,CAAC;YACL,CAAC,CAAA;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,gBAAgB;QACrB,OAAO,aAAa,CAAC,gBAAc,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,EAAE;YACrD,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;YAC/B,MAAM,OAAO,GAAG,aAAa,EAAE,CAAC;YAChC,MAAM,KAAK,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;YACrC,OAAO,GAAG,EAAE;gBACV,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE;oBAC3B,UAAU,EAAE,KAAK;oBACjB,UAAU,EAAE,CAAC,CAAC,OAAO,EAAE;iBACxB,CAAC,CAAC;YACL,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,0BAA0B;QAC/B,OAAO,aAAa,CAAC,aAAa,CAAC,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;YACrE,MAAM,KAAK,GAAG,MAAM,CAAC,gBAAc,CAAC,CAAC;YACrC,OAAO,CAAC,IAAkB,EAAE,EAAE;gBAC5B,KAAK,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACpC,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,6BAA6B;QAClC,OAAO,aAAa,CAAC,aAAa,CAAC,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;YACnE,MAAM,KAAK,GAAG,MAAM,CAAC,gBAAc,CAAC,CAAC;YACrC,OAAO,CAAC,GAAW,EAAE,EAAE;gBACrB,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC;gBAC9C,MAAM,KAAK,GAAG,GAAG,KAAK,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC;gBACxE,KAAK,CAAC,IAAI,EAAE,CAAC,UAAU,CAAC,EAAC,IAAI,EAAE,EAAC,GAAG,EAAE,KAAK,EAAC,EAAC,CAAC,CAAC;YAChD,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,qBAAqB;QAC1B,OAAO,aAAa,CAAC,WAAW,CAAC,eAAe,EAAE,GAAG,EAAE;YACrD,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;YAC/B,OAAO,GAAG,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;QACpC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,gCAAgC;QACrC,OAAO,aAAa,CAAC,gBAAc,CAAC,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;YACvE,MAAM,KAAK,GAAG,MAAM,CAAC,gBAAc,CAAC,CAAC;YACrC,OAAO,GAAG,EAAE;gBACV,MAAM,SAAS,GAAG,kBAAkB,CAAC,KAAK,CAAC,SAAS,EAAE,EAAE,KAAK,CAAC,cAAc,EAAE,CAAC,CAAC;gBAChF,YAAY,CAAC,KAAK,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC;YAC9C,CAAC,CAAA;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,qBAAqB;QAC1B,OAAO;YACL,gBAAc,CAAC,mBAAmB,EAAE;YACpC,gBAAc,CAAC,gBAAgB,EAAE;YACjC,gBAAc,CAAC,iBAAiB,EAAE;YAClC,gBAAc,CAAC,gCAAgC,EAAE;YACjD,gBAAc,CAAC,0BAA0B,EAAE;YAC3C,gBAAc,CAAC,6BAA6B,EAAE;YAC9C,gBAAc,CAAC,qBAAqB,EAAE;SACvC,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,oBAAoB;QACzB,OAAO;YACL,gBAAc,CAAC,MAAM,CAAC,OAAO,EAAE;YAC/B,gBAAc,CAAC,wBAAwB,EAAE;YACzC,gBAAc,CAAC,iBAAiB,EAAE;SACnC,CAAA;IACH,CAAC;IAED,MAAM,CAAC,cAAc;QACnB,OAAO;YACL,gBAAc,CAAC,oBAAoB,EAAE;YACrC,gBAAc,CAAC,yBAAyB,EAAE;YAC1C,gBAAc,CAAC,qBAAqB,EAAE;SACvC,CAAC;IACJ,CAAC;IAsCD;QACE,KAAK,EAAE,CAAC;QArCD,WAAM,GAAG,gBAAc,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;QACxC,UAAK,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;QACpD,UAAK,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QAC/B,cAAS,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;QAC5D,cAAS,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;QAC5D,SAAI,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;QAClD,UAAK,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;QACpD,aAAQ,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;QACnE,gBAAW,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC;QAChE,UAAK,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;QACpD,SAAI,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;QAClD,cAAS,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;QAC5D,cAAS,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;QAC5D,oBAAe,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,eAAe,CAAC,CAAC,CAAC;QACxE,kBAAa,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,aAAa,CAAC,CAAC,CAAC;QACpE,eAAU,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;QAC9D,gBAAW,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC;QAChE,qBAAgB,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC;QAE1E,gBAAW,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC;QAChE,mBAAc,GAAG,QAAQ,CAAC,GAAG,EAAE;YACtC,IAAI,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC;YAC/B,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YACrC,KAAK,GAAG,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YACtD,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;YACvC,OAAO,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QAClD,CAAC,CAAC,CAAC;QACM,gBAAW,GAAG,aAAa,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,OAAO,CAAC,IAAI,CACtE,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE,QAAQ,IAAI,EAAE,CAAC,CAC5C,EAAE,EAAC,YAAY,EAAE,EAAE,EAAC,CAAC,CAAC;QACd,aAAQ,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACvG,kBAAa,GAAG,QAAQ,CAAC,GAAG,EAAE;YACrC,OAAO,IAAI,CAAC,cAAc,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;QACrF,CAAC,CAAC,CAAC;QACM,SAAI,GAAG,eAAe,EAAE,CAAC;QAIhC,gBAAc,CAAC,WAAW,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QAEjD,MAAM,CAAC,GAAG,EAAE;YACV,OAAO,CAAC,KAAK,CAAC,WAAW,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAA;IACJ,CAAC;8GA5SU,cAAc;kGAAd,cAAc;;AAAd,cAAc;IAF1B,aAAa,EAAE;;GAEH,cAAc,CA6S1B;;2FA7SY,cAAc;kBAD1B,SAAS;mBAAC,EAAE,UAAU,EAAE,IAAI,EAAE;;AAwV/B,MAAM,OAAO,SAAU,SAAQ,iBAAiB;IAxChD;;QAyCY,UAAK,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QAC/B,WAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QACxB,UAAK,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC;KAiCxC;IA9BW,IAAI;QACZ,IAAI,CAAC,QAAQ,CAAC,EAAC,EAAE,EAAE,cAAc,CAAC,QAAQ,CAAC,IAAI,EAAC,CAAC,CAAC;IACpD,CAAC;IAGS,KAAK;QACb,IAAI,CAAC,QAAQ,CAAC,EAAC,EAAE,EAAE,QAAQ,CAAC,KAAK,EAAC,CAAC,CAAC;IACtC,CAAC;IAGS,SAAS,CAAC,IAAkB;QACpC,IAAI,CAAC,QAAQ,CAAC,EAAC,EAAE,EAAE,QAAQ,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,EAAC,CAAC,CAAC;IACtD,CAAC;IAGS,eAAe,CAAC,IAAkB;QAC1C,IAAI,CAAC,QAAQ,CAAC,EAAC,EAAE,EAAE,cAAc,CAAC,QAAQ,CAAC,qBAAqB,EAAE,OAAO,EAAE,IAAI,EAAC,CAAC,CAAC;IACpF,CAAC;IAED,gDAAgD;IAEtC,mBAAmB,CAAC,IAAS;QACrC,MAAM,OAAO,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,CAAC;QAC/D,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;YAC9C,IAAI,CAAC,QAAQ,CAAC;gBACZ,EAAE,EAAE,MAAM,CAAC,EAAE;gBACb,OAAO,EAAE,MAAM,CAAC,OAAO;aACxB,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;8GAnCU,SAAS;kGAAT,SAAS,oGAvVT,cAAc,iFAsTf;;;;;;;;;;;;;;;;;;;;;GAqBT,6pDAxBC,iBAAiB,sFACjB,aAAa;;AAyCL;IADT,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC;;;;qCAGnC;AAGS;IADT,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC;;;;sCAGzB;AAGS;IADT,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,UAAU,CAAC;;;;0CAGzC;AAGS;IADT,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,2BAA2B,CAAC;;;;gDAG1D;AAIS;IADT,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,wBAAwB,CAAC;;;;oDASvD;2FAnCU,SAAS;kBAxCrB,SAAS;+BACE,aAAa,cACX,IAAI,WACP;wBACP,iBAAiB;wBACjB,aAAa;qBACd,YACS;;;;;;;;;;;;;;;;;;;;;GAqBT,kBAEe;wBACd;4BACE,SAAS,EAAE,cAAc;4BACzB,MAAM,EAAE;gCACN,OAAO;gCACP,UAAU;6BACX;yBACF;qBACF;8BAQS,IAAI,MAKJ,KAAK,MAKL,SAAS,MAKT,eAAe,MAMf,mBAAmB","sourcesContent":["import { Component, Directive, InjectionToken, Injector, Provider, 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 { convertToItemsMap, getType, IndexTemplate, ItemsMap } 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, TokenizedType, _computed, applyToInput, provideEffect, resolveActions } 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, injectRouteParam, injectRouteSkip } 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';\nimport { SheetService } from '@ng-atomic/common/services/sheets';\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/index] CheckboxClick',\n  HEADER_CHECKBOX_CLICK = '[@ng-atomic/components/pages/index] HeaderCheckboxClick',\n  ADD = '[@ng-atomic/components/pages/index] Add',\n  DETAIL = '[@ng-atomic/components/pages/index] Detail',\n  CLOSE = '[@ng-atomic/components/pages/index] Close',\n  LIST_ITEM_BUTTON_CLICKED = '[@ng-atomic/components/pages/index] ListItemButtonClick',\n}\n\nexport function toggleAllSelection(selection: SelectionModel<string>, items: {id: string}[]) {\n  if (selection.selected.length === items.length) {\n    return new SelectionModel<string>(true, []);\n  } else {\n    return new SelectionModel<string>(true, items.map(entry => entry.id));\n  }\n}\n\nfunction tryJsonParse(value: string) {\n  try {\n    return JSON.parse(value);\n  } catch {\n    return {};\n  }\n}\n\nexport function recoveryFormValue(form: AbstractControl, key: string = 'default') {\n  // FormControlの場合とFormGroupの場合で処理を分ける\n  if (form instanceof FormGroup) {\n    form.patchValue(tryJsonParse(localStorage.getItem(key)));\n    form.valueChanges.subscribe(value => {\n      localStorage.setItem(key, JSON.stringify(value));\n    });\n  } else {\n    const value = localStorage.getItem(key);\n    console.debug('loaded:', value);\n    form.setValue(value);\n    form.valueChanges.subscribe(value => {\n      console.debug('value:', value);\n      localStorage.setItem(key, value);\n    });\n  }\n}\n\n@TokenizedType()\n@Directive({ standalone: true })\nexport class IndexPageStore<T> 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      groupedBy: <string>null,\n      groupKeys: [],\n      items: [],\n      itemsMap: <ItemsMap<any>>undefined,\n      itemActions: (() => []) as Actions,\n      itemsMapper: <(items: any[]) => any[]>undefined,\n      itemsLength: 0,\n      filterFunc,\n      title: modelName() ? `${modelName()}一覧` : `取得中...`,\n      type: <'list' | 'table' | 'grid'>'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 provideItemActionsConfig() {\n    return IndexPageStore.Config.provide(() => {\n      return (config) => ({\n        ...config,\n        itemActions: (item) => [\n          { id: ActionId.DETAIL, icon: 'open_in_new', name: '詳細', payload: item },\n        ],\n      });\n    });\n  }\n\n  static provideSideAppNavStartActions() {\n    return IndexPageStore.Config.provide(() => {\n      const isRootPage = injectIsRootPage('side');\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      const 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      recoveryFormValue(store.form(), key);\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 provideColumnsInitializer(useFactory: () => string[]): Provider[] {\n    return [\n      IndexPageStore.Initializer.provide((store) => {\n        const columns = useFactory();\n        const form = injectIndexForm({ columns: buildColumns(columns) });\n        applyToInput(store, 'form', form);\n      }),\n    ];\n  }\n\n  static provideItemsInitializer(itemsFactory: () => any[]): Provider[] {\n    return [\n      IndexPageStore.Initializer.provide((store) => {\n        const items = itemsFactory();\n\t\t\t\teffect(() => {\n\t\t\t\t\tapplyToInput(store, 'items', items);\t\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        const selection = toggleAllSelection(store.selection(), store.displayedItems());\n        applyToInput(store, 'selection', selection);\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 provideDefaultConfig() {\n    return [\n      IndexPageStore.Config.provide(),\n      IndexPageStore.provideItemActionsConfig(),\n      IndexPageStore.provideTypeConfig(),\n    ]\n  }\n\n  static provideDefault() {\n    return [\n      IndexPageStore.provideDefaultConfig(),\n      IndexPageStore.provideDefaultInitializer(),\n      IndexPageStore.provideDefaultEffects(),\n    ];\n  }\n\n  readonly config = IndexPageStore.Config.inject();\n  readonly style = input(_computed(() => this.config().style));\n  readonly route = inject(ActivatedRoute);\n  readonly groupedBy = input(_computed(() => this.config().groupedBy));\n  readonly groupKeys = input(_computed(() => this.config().groupKeys));\n  readonly type = input(_computed(() => this.config().type));\n  readonly items = input(_computed(() => this.config().items));\n  readonly itemsMap = input(_computed(() => convertToItemsMap(this.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  readonly skip = injectRouteSkip();\n\n  constructor() {\n    super();\n    IndexPageStore.Initializer.initializeStore(this);\n\n    effect(() => {\n      console.debug('itemsMap:', this.itemsMap());\n    })\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 [skip]=\"store.skip()\">\n    <templates-index\n      [style]=\"store.style()\"\n      [title]=\"store.title()\"\n      [type]=\"store.type()\"\n      [tableChildrenKey]=\"store.tableChildrenKey()\"\n      [items]=\"store.displayedItems()\"\n      [itemsMap]=\"store.itemsMap()\"\n      [itemsLength]=\"store.itemsLength()\"\n      [itemActions]=\"store.itemActions()\"\n      [groupedBy]=\"store.groupedBy()\"\n      [groupKeys]=\"store.groupKeys()\"\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: [\n        'items',\n        'itemsMap',\n      ],\n    },\n  ],\n})\nexport class IndexPage extends NgAtomicComponent {\n  protected store = inject(IndexPageStore);\n  protected router = inject(Router);\n  protected sheet = inject(SheetService);\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  // MEMO(@nontangent): シートのアクションをページに持たせるべきかは要検討。\n  @Effect(IndexTemplate.ActionId.LIST_ITEM_BUTTON_CLICKED)\n  protected onItemButtonClicked(item: any) {\n    const actions = resolveActions(this.store.itemActions(), item);\n    this.sheet.openActions(actions).then((action) => {\n      this.dispatch({\n        id: action.id,\n        payload: action.payload,\n      });\n    });\n  }\n}\n"]}
|