@ng-atomic/components 17.9.0 → 17.11.0

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