@sebgroup/green-angular 3.8.0 → 4.1.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 (247) hide show
  1. package/{esm2020 → esm2022}/lib/accordion/accordion-list-item.component.mjs +4 -4
  2. package/{esm2020 → esm2022}/lib/accordion/accordion.component.mjs +4 -4
  3. package/{esm2020 → esm2022}/lib/accordion/accordion.module.mjs +5 -5
  4. package/esm2022/lib/badge/badge.component.mjs +80 -0
  5. package/{esm2020 → esm2022}/lib/badge/badge.module.mjs +5 -5
  6. package/{esm2020 → esm2022}/lib/button/button.component.mjs +4 -4
  7. package/{esm2020 → esm2022}/lib/button/button.module.mjs +5 -5
  8. package/{esm2020 → esm2022}/lib/cell-table/cell-table-item.component.mjs +6 -6
  9. package/{esm2020 → esm2022}/lib/cell-table/cell-table.component.mjs +4 -4
  10. package/{esm2020 → esm2022}/lib/cell-table/cell-table.module.mjs +7 -7
  11. package/{esm2020 → esm2022}/lib/cell-table/cell-underline.directive.mjs +4 -4
  12. package/{esm2020 → esm2022}/lib/context-menu/context-menu.component.mjs +4 -4
  13. package/{esm2020 → esm2022}/lib/context-menu/context-menu.module.mjs +5 -5
  14. package/esm2022/lib/datepicker/datepicker.component.mjs +138 -0
  15. package/{esm2020 → esm2022}/lib/datepicker/datepicker.module.mjs +5 -5
  16. package/{esm2020 → esm2022}/lib/dropdown/dropdown-button.directive.mjs +4 -4
  17. package/{esm2020 → esm2022}/lib/dropdown/dropdown-option.directive.mjs +4 -4
  18. package/esm2022/lib/dropdown/dropdown.component.mjs +212 -0
  19. package/{esm2020 → esm2022}/lib/dropdown/dropdown.module.mjs +9 -9
  20. package/{esm2020 → esm2022}/lib/green-angular.module.mjs +31 -31
  21. package/{esm2020 → esm2022}/lib/in-page-wizard/in-page-wizard-step-card.component.mjs +4 -4
  22. package/{esm2020 → esm2022}/lib/in-page-wizard/in-page-wizard.module.mjs +5 -5
  23. package/{esm2020 → esm2022}/lib/modal/modal-footer.directive.mjs +4 -4
  24. package/{esm2020 → esm2022}/lib/modal/modal-header.directive.mjs +4 -4
  25. package/esm2022/lib/modal/modal.component.mjs +307 -0
  26. package/{esm2020 → esm2022}/lib/modal/modal.module.mjs +12 -12
  27. package/{esm2020 → esm2022}/lib/pagination/pagination.component.mjs +4 -4
  28. package/{esm2020 → esm2022}/lib/pagination/pagination.module.mjs +5 -5
  29. package/{esm2020 → esm2022}/lib/progress-circle/progress-circle.component.mjs +4 -4
  30. package/{esm2020 → esm2022}/lib/progress-circle/progress-circle.module.mjs +5 -5
  31. package/{esm2020 → esm2022}/lib/segmented-control/segmented-control.component.mjs +6 -6
  32. package/{esm2020 → esm2022}/lib/segmented-control/segmented-control.module.mjs +5 -5
  33. package/{esm2020 → esm2022}/lib/shared/core-element/core-element.directive.mjs +4 -4
  34. package/{esm2020 → esm2022}/lib/shared/core-element/core-element.module.mjs +5 -5
  35. package/{esm2020/src → esm2022}/lib/shared/on-scroll.directive.mjs +10 -10
  36. package/{esm2020 → esm2022}/lib/shared/shared.module.mjs +5 -5
  37. package/esm2022/lib/slider/slider.component.mjs +113 -0
  38. package/{esm2020 → esm2022}/lib/slider/slider.module.mjs +5 -5
  39. package/{esm2020 → esm2022}/lib/sortable-list/sortable-list.component.mjs +4 -4
  40. package/{esm2020 → esm2022}/lib/sortable-list/sortable-list.module.mjs +5 -5
  41. package/{esm2020 → esm2022}/src/lib/accordion/accordion-list-item.component.mjs +4 -4
  42. package/{esm2020 → esm2022}/src/lib/accordion/accordion.component.mjs +4 -4
  43. package/{esm2020 → esm2022}/src/lib/accordion/accordion.module.mjs +5 -5
  44. package/esm2022/src/lib/badge/badge.component.mjs +80 -0
  45. package/{esm2020 → esm2022}/src/lib/badge/badge.module.mjs +5 -5
  46. package/{esm2020 → esm2022}/src/lib/button/button.component.mjs +4 -4
  47. package/{esm2020 → esm2022}/src/lib/button/button.module.mjs +5 -5
  48. package/{esm2020 → esm2022}/src/lib/cell-table/cell-table-item.component.mjs +6 -6
  49. package/{esm2020 → esm2022}/src/lib/cell-table/cell-table.component.mjs +4 -4
  50. package/{esm2020 → esm2022}/src/lib/cell-table/cell-table.module.mjs +7 -7
  51. package/{esm2020 → esm2022}/src/lib/cell-table/cell-underline.directive.mjs +4 -4
  52. package/{esm2020 → esm2022}/src/lib/context-menu/context-menu.component.mjs +4 -4
  53. package/{esm2020 → esm2022}/src/lib/context-menu/context-menu.module.mjs +5 -5
  54. package/esm2022/src/lib/datepicker/datepicker.component.mjs +138 -0
  55. package/{esm2020 → esm2022}/src/lib/datepicker/datepicker.module.mjs +5 -5
  56. package/{esm2020 → esm2022}/src/lib/dropdown/dropdown-button.directive.mjs +4 -4
  57. package/{esm2020 → esm2022}/src/lib/dropdown/dropdown-option.directive.mjs +4 -4
  58. package/esm2022/src/lib/dropdown/dropdown.component.mjs +212 -0
  59. package/{esm2020 → esm2022}/src/lib/dropdown/dropdown.module.mjs +9 -9
  60. package/{esm2020 → esm2022}/src/lib/in-page-wizard/in-page-wizard-step-card.component.mjs +4 -4
  61. package/{esm2020 → esm2022}/src/lib/in-page-wizard/in-page-wizard.module.mjs +5 -5
  62. package/{esm2020 → esm2022}/src/lib/modal/modal-footer.directive.mjs +4 -4
  63. package/{esm2020 → esm2022}/src/lib/modal/modal-header.directive.mjs +4 -4
  64. package/esm2022/src/lib/modal/modal.component.mjs +307 -0
  65. package/{esm2020 → esm2022}/src/lib/modal/modal.module.mjs +12 -12
  66. package/{esm2020 → esm2022}/src/lib/pagination/pagination.component.mjs +4 -4
  67. package/{esm2020 → esm2022}/src/lib/pagination/pagination.module.mjs +5 -5
  68. package/{esm2020 → esm2022}/src/lib/progress-circle/progress-circle.component.mjs +4 -4
  69. package/{esm2020 → esm2022}/src/lib/progress-circle/progress-circle.module.mjs +5 -5
  70. package/{esm2020 → esm2022}/src/lib/segmented-control/segmented-control.component.mjs +6 -6
  71. package/{esm2020 → esm2022}/src/lib/segmented-control/segmented-control.module.mjs +5 -5
  72. package/{esm2020 → esm2022}/src/lib/shared/core-element/core-element.directive.mjs +4 -4
  73. package/{esm2020 → esm2022}/src/lib/shared/core-element/core-element.module.mjs +5 -5
  74. package/esm2022/src/lib/shared/on-scroll.directive.mjs +47 -0
  75. package/{esm2020 → esm2022}/src/lib/shared/shared.module.mjs +5 -5
  76. package/esm2022/src/lib/slider/slider.component.mjs +113 -0
  77. package/{esm2020 → esm2022}/src/lib/slider/slider.module.mjs +5 -5
  78. package/{esm2020 → esm2022}/src/lib/sortable-list/sortable-list.component.mjs +4 -4
  79. package/{esm2020 → esm2022}/src/lib/sortable-list/sortable-list.module.mjs +5 -5
  80. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-accordion.mjs +10 -10
  81. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-accordion.mjs.map +1 -1
  82. package/{fesm2015 → fesm2022}/sebgroup-green-angular-src-lib-badge.mjs +16 -16
  83. package/fesm2022/sebgroup-green-angular-src-lib-badge.mjs.map +1 -0
  84. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-button.mjs +7 -7
  85. package/{fesm2015 → fesm2022}/sebgroup-green-angular-src-lib-button.mjs.map +1 -1
  86. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-cell-table.mjs +17 -17
  87. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-cell-table.mjs.map +1 -1
  88. package/{fesm2015 → fesm2022}/sebgroup-green-angular-src-lib-context-menu.mjs +7 -7
  89. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-context-menu.mjs.map +1 -1
  90. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-datepicker.mjs +20 -20
  91. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-datepicker.mjs.map +1 -1
  92. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-dropdown.mjs +69 -69
  93. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-dropdown.mjs.map +1 -1
  94. package/{fesm2015 → fesm2022}/sebgroup-green-angular-src-lib-in-page-wizard.mjs +7 -7
  95. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-in-page-wizard.mjs.map +1 -1
  96. package/fesm2022/sebgroup-green-angular-src-lib-modal.mjs +375 -0
  97. package/fesm2022/sebgroup-green-angular-src-lib-modal.mjs.map +1 -0
  98. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-pagination.mjs +7 -7
  99. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-pagination.mjs.map +1 -1
  100. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-progress-circle.mjs +7 -7
  101. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-progress-circle.mjs.map +1 -1
  102. package/{fesm2015 → fesm2022}/sebgroup-green-angular-src-lib-segmented-control.mjs +9 -9
  103. package/fesm2022/sebgroup-green-angular-src-lib-segmented-control.mjs.map +1 -0
  104. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-shared.mjs +20 -20
  105. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-shared.mjs.map +1 -1
  106. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-slider.mjs +13 -13
  107. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-slider.mjs.map +1 -1
  108. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-sortable-list.mjs +7 -7
  109. package/{fesm2020 → fesm2022}/sebgroup-green-angular-src-lib-sortable-list.mjs.map +1 -1
  110. package/{fesm2020 → fesm2022}/sebgroup-green-angular.mjs +339 -290
  111. package/fesm2022/sebgroup-green-angular.mjs.map +1 -0
  112. package/lib/accordion/accordion-list-item.component.d.ts +1 -1
  113. package/lib/accordion/accordion.component.d.ts +1 -1
  114. package/lib/badge/badge.component.d.ts +1 -1
  115. package/lib/button/button.component.d.ts +1 -1
  116. package/lib/cell-table/cell-table-item.component.d.ts +1 -1
  117. package/lib/cell-table/cell-table.component.d.ts +1 -1
  118. package/lib/cell-table/cell-table.types.d.ts +1 -1
  119. package/lib/cell-table/cell-underline.directive.d.ts +1 -1
  120. package/lib/context-menu/context-menu.component.d.ts +1 -1
  121. package/lib/datepicker/datepicker.component.d.ts +1 -1
  122. package/lib/dropdown/dropdown.component.d.ts +4 -4
  123. package/lib/in-page-wizard/in-page-wizard-step-card.component.d.ts +1 -1
  124. package/lib/modal/modal.component.d.ts +3 -3
  125. package/lib/pagination/pagination.component.d.ts +1 -1
  126. package/lib/progress-circle/progress-circle.component.d.ts +1 -1
  127. package/lib/segmented-control/segmented-control.component.d.ts +1 -1
  128. package/lib/slider/slider.component.d.ts +1 -1
  129. package/lib/sortable-list/sortable-list.component.d.ts +1 -1
  130. package/package.json +58 -94
  131. package/src/lib/accordion/accordion-list-item.component.d.ts +1 -1
  132. package/src/lib/accordion/accordion.component.d.ts +1 -1
  133. package/src/lib/badge/badge.component.d.ts +1 -1
  134. package/src/lib/button/button.component.d.ts +1 -1
  135. package/src/lib/cell-table/cell-table-item.component.d.ts +1 -1
  136. package/src/lib/cell-table/cell-table.component.d.ts +1 -1
  137. package/src/lib/cell-table/cell-table.types.d.ts +1 -1
  138. package/src/lib/cell-table/cell-underline.directive.d.ts +1 -1
  139. package/src/lib/context-menu/context-menu.component.d.ts +1 -1
  140. package/src/lib/datepicker/datepicker.component.d.ts +1 -1
  141. package/src/lib/dropdown/dropdown.component.d.ts +4 -4
  142. package/src/lib/in-page-wizard/in-page-wizard-step-card.component.d.ts +1 -1
  143. package/src/lib/modal/modal.component.d.ts +3 -3
  144. package/src/lib/pagination/pagination.component.d.ts +1 -1
  145. package/src/lib/progress-circle/progress-circle.component.d.ts +1 -1
  146. package/src/lib/segmented-control/segmented-control.component.d.ts +1 -1
  147. package/src/lib/slider/slider.component.d.ts +1 -1
  148. package/src/lib/sortable-list/sortable-list.component.d.ts +1 -1
  149. package/esm2020/lib/badge/badge.component.mjs +0 -80
  150. package/esm2020/lib/datepicker/datepicker.component.mjs +0 -138
  151. package/esm2020/lib/dropdown/dropdown.component.mjs +0 -212
  152. package/esm2020/lib/modal/modal.component.mjs +0 -258
  153. package/esm2020/lib/shared/on-scroll.directive.mjs +0 -47
  154. package/esm2020/lib/slider/slider.component.mjs +0 -113
  155. package/esm2020/src/lib/badge/badge.component.mjs +0 -80
  156. package/esm2020/src/lib/datepicker/datepicker.component.mjs +0 -138
  157. package/esm2020/src/lib/dropdown/dropdown.component.mjs +0 -212
  158. package/esm2020/src/lib/modal/modal.component.mjs +0 -258
  159. package/esm2020/src/lib/slider/slider.component.mjs +0 -113
  160. package/fesm2015/sebgroup-green-angular-src-lib-accordion.mjs +0 -140
  161. package/fesm2015/sebgroup-green-angular-src-lib-accordion.mjs.map +0 -1
  162. package/fesm2015/sebgroup-green-angular-src-lib-badge.mjs.map +0 -1
  163. package/fesm2015/sebgroup-green-angular-src-lib-button.mjs +0 -50
  164. package/fesm2015/sebgroup-green-angular-src-lib-cell-table.mjs +0 -272
  165. package/fesm2015/sebgroup-green-angular-src-lib-cell-table.mjs.map +0 -1
  166. package/fesm2015/sebgroup-green-angular-src-lib-context-menu.mjs.map +0 -1
  167. package/fesm2015/sebgroup-green-angular-src-lib-datepicker.mjs +0 -166
  168. package/fesm2015/sebgroup-green-angular-src-lib-datepicker.mjs.map +0 -1
  169. package/fesm2015/sebgroup-green-angular-src-lib-dropdown.mjs +0 -266
  170. package/fesm2015/sebgroup-green-angular-src-lib-dropdown.mjs.map +0 -1
  171. package/fesm2015/sebgroup-green-angular-src-lib-in-page-wizard.mjs.map +0 -1
  172. package/fesm2015/sebgroup-green-angular-src-lib-modal.mjs +0 -328
  173. package/fesm2015/sebgroup-green-angular-src-lib-modal.mjs.map +0 -1
  174. package/fesm2015/sebgroup-green-angular-src-lib-pagination.mjs +0 -197
  175. package/fesm2015/sebgroup-green-angular-src-lib-pagination.mjs.map +0 -1
  176. package/fesm2015/sebgroup-green-angular-src-lib-progress-circle.mjs +0 -63
  177. package/fesm2015/sebgroup-green-angular-src-lib-progress-circle.mjs.map +0 -1
  178. package/fesm2015/sebgroup-green-angular-src-lib-segmented-control.mjs.map +0 -1
  179. package/fesm2015/sebgroup-green-angular-src-lib-shared.mjs +0 -114
  180. package/fesm2015/sebgroup-green-angular-src-lib-shared.mjs.map +0 -1
  181. package/fesm2015/sebgroup-green-angular-src-lib-slider.mjs +0 -136
  182. package/fesm2015/sebgroup-green-angular-src-lib-slider.mjs.map +0 -1
  183. package/fesm2015/sebgroup-green-angular-src-lib-sortable-list.mjs +0 -204
  184. package/fesm2015/sebgroup-green-angular-src-lib-sortable-list.mjs.map +0 -1
  185. package/fesm2015/sebgroup-green-angular.mjs +0 -2165
  186. package/fesm2015/sebgroup-green-angular.mjs.map +0 -1
  187. package/fesm2020/sebgroup-green-angular-src-lib-badge.mjs +0 -102
  188. package/fesm2020/sebgroup-green-angular-src-lib-badge.mjs.map +0 -1
  189. package/fesm2020/sebgroup-green-angular-src-lib-button.mjs.map +0 -1
  190. package/fesm2020/sebgroup-green-angular-src-lib-context-menu.mjs +0 -104
  191. package/fesm2020/sebgroup-green-angular-src-lib-in-page-wizard.mjs +0 -72
  192. package/fesm2020/sebgroup-green-angular-src-lib-modal.mjs +0 -326
  193. package/fesm2020/sebgroup-green-angular-src-lib-modal.mjs.map +0 -1
  194. package/fesm2020/sebgroup-green-angular-src-lib-segmented-control.mjs +0 -58
  195. package/fesm2020/sebgroup-green-angular-src-lib-segmented-control.mjs.map +0 -1
  196. package/fesm2020/sebgroup-green-angular.mjs.map +0 -1
  197. /package/{esm2020 → esm2022}/index.mjs +0 -0
  198. /package/{esm2020 → esm2022}/lib/accordion/index.mjs +0 -0
  199. /package/{esm2020 → esm2022}/lib/badge/index.mjs +0 -0
  200. /package/{esm2020 → esm2022}/lib/button/index.mjs +0 -0
  201. /package/{esm2020 → esm2022}/lib/cell-table/cell-table.types.mjs +0 -0
  202. /package/{esm2020 → esm2022}/lib/cell-table/index.mjs +0 -0
  203. /package/{esm2020 → esm2022}/lib/context-menu/index.mjs +0 -0
  204. /package/{esm2020 → esm2022}/lib/datepicker/index.mjs +0 -0
  205. /package/{esm2020 → esm2022}/lib/dropdown/index.mjs +0 -0
  206. /package/{esm2020 → esm2022}/lib/in-page-wizard/index.mjs +0 -0
  207. /package/{esm2020 → esm2022}/lib/modal/index.mjs +0 -0
  208. /package/{esm2020 → esm2022}/lib/pagination/index.mjs +0 -0
  209. /package/{esm2020 → esm2022}/lib/progress-circle/index.mjs +0 -0
  210. /package/{esm2020 → esm2022}/lib/segmented-control/index.mjs +0 -0
  211. /package/{esm2020 → esm2022}/lib/shared/core-element/index.mjs +0 -0
  212. /package/{esm2020 → esm2022}/lib/shared/index.mjs +0 -0
  213. /package/{esm2020 → esm2022}/lib/slider/index.mjs +0 -0
  214. /package/{esm2020 → esm2022}/lib/sortable-list/index.mjs +0 -0
  215. /package/{esm2020 → esm2022}/sebgroup-green-angular.mjs +0 -0
  216. /package/{esm2020 → esm2022}/src/lib/accordion/index.mjs +0 -0
  217. /package/{esm2020 → esm2022}/src/lib/accordion/sebgroup-green-angular-src-lib-accordion.mjs +0 -0
  218. /package/{esm2020 → esm2022}/src/lib/badge/index.mjs +0 -0
  219. /package/{esm2020 → esm2022}/src/lib/badge/sebgroup-green-angular-src-lib-badge.mjs +0 -0
  220. /package/{esm2020 → esm2022}/src/lib/button/index.mjs +0 -0
  221. /package/{esm2020 → esm2022}/src/lib/button/sebgroup-green-angular-src-lib-button.mjs +0 -0
  222. /package/{esm2020 → esm2022}/src/lib/cell-table/cell-table.types.mjs +0 -0
  223. /package/{esm2020 → esm2022}/src/lib/cell-table/index.mjs +0 -0
  224. /package/{esm2020 → esm2022}/src/lib/cell-table/sebgroup-green-angular-src-lib-cell-table.mjs +0 -0
  225. /package/{esm2020 → esm2022}/src/lib/context-menu/index.mjs +0 -0
  226. /package/{esm2020 → esm2022}/src/lib/context-menu/sebgroup-green-angular-src-lib-context-menu.mjs +0 -0
  227. /package/{esm2020 → esm2022}/src/lib/datepicker/index.mjs +0 -0
  228. /package/{esm2020 → esm2022}/src/lib/datepicker/sebgroup-green-angular-src-lib-datepicker.mjs +0 -0
  229. /package/{esm2020 → esm2022}/src/lib/dropdown/index.mjs +0 -0
  230. /package/{esm2020 → esm2022}/src/lib/dropdown/sebgroup-green-angular-src-lib-dropdown.mjs +0 -0
  231. /package/{esm2020 → esm2022}/src/lib/in-page-wizard/index.mjs +0 -0
  232. /package/{esm2020 → esm2022}/src/lib/in-page-wizard/sebgroup-green-angular-src-lib-in-page-wizard.mjs +0 -0
  233. /package/{esm2020 → esm2022}/src/lib/modal/index.mjs +0 -0
  234. /package/{esm2020 → esm2022}/src/lib/modal/sebgroup-green-angular-src-lib-modal.mjs +0 -0
  235. /package/{esm2020 → esm2022}/src/lib/pagination/index.mjs +0 -0
  236. /package/{esm2020 → esm2022}/src/lib/pagination/sebgroup-green-angular-src-lib-pagination.mjs +0 -0
  237. /package/{esm2020 → esm2022}/src/lib/progress-circle/index.mjs +0 -0
  238. /package/{esm2020 → esm2022}/src/lib/progress-circle/sebgroup-green-angular-src-lib-progress-circle.mjs +0 -0
  239. /package/{esm2020 → esm2022}/src/lib/segmented-control/index.mjs +0 -0
  240. /package/{esm2020 → esm2022}/src/lib/segmented-control/sebgroup-green-angular-src-lib-segmented-control.mjs +0 -0
  241. /package/{esm2020 → esm2022}/src/lib/shared/core-element/index.mjs +0 -0
  242. /package/{esm2020 → esm2022}/src/lib/shared/index.mjs +0 -0
  243. /package/{esm2020 → esm2022}/src/lib/shared/sebgroup-green-angular-src-lib-shared.mjs +0 -0
  244. /package/{esm2020 → esm2022}/src/lib/slider/index.mjs +0 -0
  245. /package/{esm2020 → esm2022}/src/lib/slider/sebgroup-green-angular-src-lib-slider.mjs +0 -0
  246. /package/{esm2020 → esm2022}/src/lib/sortable-list/index.mjs +0 -0
  247. /package/{esm2020 → esm2022}/src/lib/sortable-list/sebgroup-green-angular-src-lib-sortable-list.mjs +0 -0
@@ -0,0 +1,307 @@
1
+ import { ChangeDetectionStrategy, Component, ContentChild, ElementRef, EventEmitter, HostBinding, Input, Output, ViewChild, } from '@angular/core';
2
+ import { trigger, query, style, animate, transition, group, } from '@angular/animations';
3
+ import { ConfigurableFocusTrapFactory, } from '@angular/cdk/a11y';
4
+ import { disableBodyScroll, enableBodyScroll } from 'body-scroll-lock';
5
+ import { NggModalHeaderDirective } from './modal-header.directive';
6
+ import { NggModalFooterDirective } from './modal-footer.directive';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/cdk/a11y";
9
+ import * as i2 from "@angular/common";
10
+ export class NggModalComponent {
11
+ get trapFocus() {
12
+ return this._trapFocus;
13
+ }
14
+ set trapFocus(value) {
15
+ this._trapFocus = value;
16
+ if (value) {
17
+ if (this._isOpen) {
18
+ this.enableFocusTrap();
19
+ }
20
+ }
21
+ else {
22
+ this.disableFocusTrap();
23
+ }
24
+ }
25
+ get isOpen() {
26
+ return this._isOpen;
27
+ }
28
+ set isOpen(value) {
29
+ this._isOpen = value;
30
+ if (value) {
31
+ if (this.trapFocus) {
32
+ this.enableFocusTrap();
33
+ }
34
+ if (this.disableBodyScroll) {
35
+ disableBodyScroll(this.ref.nativeElement, {
36
+ allowTouchMove: (el) => {
37
+ // Allow touchmove for elements inside modal, its required for scroll to work on iOS devices
38
+ return this.ref.nativeElement.contains(el);
39
+ },
40
+ });
41
+ }
42
+ }
43
+ else {
44
+ this.disableFocusTrap();
45
+ if (this.disableBodyScroll) {
46
+ enableBodyScroll(this.ref.nativeElement);
47
+ }
48
+ }
49
+ }
50
+ get open() {
51
+ return this.isOpen;
52
+ }
53
+ constructor(ref, configurableFocusTrapFactory) {
54
+ this.ref = ref;
55
+ this.configurableFocusTrapFactory = configurableFocusTrapFactory;
56
+ this.disableBodyScroll = true;
57
+ this.isOpenChange = new EventEmitter();
58
+ this.closed = new EventEmitter();
59
+ this.confirm = new EventEmitter();
60
+ this.dismiss = new EventEmitter();
61
+ this.configurableFocusTrap = this.configurableFocusTrapFactory.create(this.ref.nativeElement);
62
+ }
63
+ ngOnInit() {
64
+ if (this._isOpen && this.trapFocus)
65
+ this.enableFocusTrap();
66
+ else
67
+ this.disableFocusTrap();
68
+ }
69
+ handleCloseClick(event) {
70
+ this.closeModal(event);
71
+ }
72
+ handleBackdropClick(event) {
73
+ if (event.target == this.backdropRef?.nativeElement)
74
+ this.closeModal(event);
75
+ }
76
+ handleDismiss(event) {
77
+ this.dismiss.emit(event);
78
+ }
79
+ handleConfirm(event) {
80
+ this.confirm.emit(event);
81
+ }
82
+ closeModal(event) {
83
+ if (this.closed.observers.length > 0) {
84
+ this.closed.emit(event);
85
+ }
86
+ else {
87
+ this.isOpen = false;
88
+ this.isOpenChange.emit(this.isOpen);
89
+ }
90
+ }
91
+ enableFocusTrap() {
92
+ if (this.configurableFocusTrap) {
93
+ this.configurableFocusTrap.enabled = true;
94
+ this.configurableFocusTrap.focusInitialElementWhenReady();
95
+ }
96
+ }
97
+ disableFocusTrap() {
98
+ if (this.configurableFocusTrap) {
99
+ this.configurableFocusTrap.enabled = false;
100
+ }
101
+ }
102
+ ngOnDestroy() {
103
+ this.configurableFocusTrap?.destroy();
104
+ enableBodyScroll(this.ref.nativeElement);
105
+ }
106
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggModalComponent, deps: [{ token: i0.ElementRef }, { token: i1.ConfigurableFocusTrapFactory }], target: i0.ɵɵFactoryTarget.Component }); }
107
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NggModalComponent, selector: "ngg-modal", inputs: { modalType: "modalType", header: "header", confirmLabel: "confirmLabel", dismissLabel: "dismissLabel", size: "size", hideHeader: "hideHeader", hideFooter: "hideFooter", disableBodyScroll: "disableBodyScroll", trapFocus: "trapFocus", isOpen: "isOpen" }, outputs: { isOpenChange: "isOpenChange", closed: "closed", confirm: "confirm", dismiss: "dismiss" }, host: { properties: { "class.open": "this.open" } }, queries: [{ propertyName: "modalHeaderContent", first: true, predicate: NggModalHeaderDirective, descendants: true }, { propertyName: "modalFooterContent", first: true, predicate: NggModalFooterDirective, descendants: true }], viewQueries: [{ propertyName: "backdropRef", first: true, predicate: ["backdrop"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"isOpen\" [ngSwitch]=\"modalType\">\n <div class=\"gds-dialog-wrapper\" [@modalAnimation]>\n <aside\n data-testid=\"modal\"\n *ngSwitchCase=\"'slideout'\"\n role=\"dialog\"\n aria-modal=\"true\"\n [class.small]=\"size === 'sm'\"\n [class.medium]=\"size === 'md'\"\n [class.large]=\"size === 'lg'\"\n [class.entered]=\"isOpen\"\n >\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </aside>\n <main\n data-testid=\"modal\"\n *ngSwitchCase=\"'takeover'\"\n role=\"dialog\"\n aria-modal=\"true\"\n [class.entered]=\"isOpen\"\n >\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </main>\n <section\n data-testid=\"modal\"\n *ngSwitchDefault\n role=\"dialog\"\n aria-modal=\"true\"\n [class.small]=\"size === 'sm'\"\n [class.medium]=\"size === 'md'\"\n [class.large]=\"size === 'lg'\"\n [class.entered]=\"isOpen\"\n >\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </section>\n <ng-template #contentTemplate>\n <ng-container *ngIf=\"!hideHeader\">\n <header\n *ngIf=\"!modalHeaderContent; else headerContentTemplate\"\n ngg-modal-header\n data-testid=\"modal-header\"\n [header]=\"header\"\n (closed)=\"this.handleCloseClick($event)\"\n ></header>\n </ng-container>\n <div ngg-modal-body data-testid=\"modal-body\" class=\"body\">\n <ng-container *ngTemplateOutlet=\"bodyContentTemplate\"></ng-container>\n </div>\n <ng-container *ngIf=\"!hideFooter && (dismissLabel || confirmLabel)\">\n <footer\n *ngIf=\"!modalFooterContent; else footerContentTemplate\"\n ngg-modal-footer\n data-testid=\"modal-footer\"\n [dismissLabel]=\"dismissLabel\"\n [confirmLabel]=\"confirmLabel\"\n (dismiss)=\"this.handleDismiss($event)\"\n (confirm)=\"this.handleConfirm($event)\"\n ></footer>\n </ng-container>\n </ng-template>\n <ng-template #headerContentTemplate>\n <header data-testid=\"modal-header\">\n <ng-content select=\"[nggModalHeader]\"></ng-content>\n </header>\n </ng-template>\n <ng-template #bodyContentTemplate>\n <ng-content></ng-content>\n </ng-template>\n <ng-template #footerContentTemplate>\n <footer data-testid=\"modal-footer\">\n <ng-content select=\"[nggModalFooter]\"></ng-content>\n </footer>\n </ng-template>\n <div\n #backdrop\n data-testid=\"modal-backdrop\"\n class=\"backdrop entered\"\n (click)=\"this.handleBackdropClick($event)\"\n [attr.aria-hidden]=\"true\"\n ></div>\n </div>\n</ng-container>\n", styles: [":host.open{height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100%;z-index:var(--sg-z-index-modal)}:host.open>section[role=dialog]{left:50%;top:50%;transform:translate(-50%,-50%)}.body::-webkit-scrollbar{background-color:#f8f8f8;height:10px;width:10px}.body::-webkit-scrollbar-thumb{background-color:#cecece}.body::-webkit-scrollbar-track{background-color:#f8f8f8;box-shadow:inset 0 0 10px #00000040}\n"], dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i2.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgTemplateOutlet; }), selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgSwitch; }), selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgSwitchCase; }), selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgSwitchDefault; }), selector: "[ngSwitchDefault]" }, { kind: "component", type: i0.forwardRef(function () { return NggModalHeaderComponent; }), selector: "[ngg-modal-header]", inputs: ["header"], outputs: ["closed"] }, { kind: "component", type: i0.forwardRef(function () { return NggModalBodyComponent; }), selector: "[ngg-modal-body]" }, { kind: "component", type: i0.forwardRef(function () { return NggModalFooterComponent; }), selector: "[ngg-modal-footer]", inputs: ["dismissLabel", "confirmLabel"], outputs: ["dismiss", "confirm"] }], animations: [
108
+ trigger('modalAnimation', [
109
+ transition(':enter', [
110
+ query('aside', style({ transform: 'translateX(100%)' }), {
111
+ optional: true,
112
+ }),
113
+ query('.backdrop, [role=dialog]', style({ opacity: '0' }), {
114
+ optional: true,
115
+ }),
116
+ group([
117
+ query('aside', animate('350ms cubic-bezier(0.33, 1, 0.68, 1)', style({ transform: 'translateX(0)' })), { optional: true }),
118
+ query('.backdrop, [role=dialog]', animate('350ms cubic-bezier(0.33, 1, 0.68, 1)', style({ opacity: '1' })), { optional: true }),
119
+ ]),
120
+ ]),
121
+ transition(':leave', [
122
+ query('aside', style({ transform: 'translateX(0)' }), {
123
+ optional: true,
124
+ }),
125
+ group([
126
+ query('aside', animate('350ms cubic-bezier(0.33, 1, 0.68, 1)', style({ transform: 'translateX(100%)' })), { optional: true }),
127
+ query('.backdrop, [role=dialog]', animate('350ms cubic-bezier(0.33, 1, 0.68, 1)', style({ opacity: '0' })), { optional: true }),
128
+ ]),
129
+ ]),
130
+ ]),
131
+ ], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
132
+ }
133
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggModalComponent, decorators: [{
134
+ type: Component,
135
+ args: [{ selector: 'ngg-modal', changeDetection: ChangeDetectionStrategy.OnPush, animations: [
136
+ trigger('modalAnimation', [
137
+ transition(':enter', [
138
+ query('aside', style({ transform: 'translateX(100%)' }), {
139
+ optional: true,
140
+ }),
141
+ query('.backdrop, [role=dialog]', style({ opacity: '0' }), {
142
+ optional: true,
143
+ }),
144
+ group([
145
+ query('aside', animate('350ms cubic-bezier(0.33, 1, 0.68, 1)', style({ transform: 'translateX(0)' })), { optional: true }),
146
+ query('.backdrop, [role=dialog]', animate('350ms cubic-bezier(0.33, 1, 0.68, 1)', style({ opacity: '1' })), { optional: true }),
147
+ ]),
148
+ ]),
149
+ transition(':leave', [
150
+ query('aside', style({ transform: 'translateX(0)' }), {
151
+ optional: true,
152
+ }),
153
+ group([
154
+ query('aside', animate('350ms cubic-bezier(0.33, 1, 0.68, 1)', style({ transform: 'translateX(100%)' })), { optional: true }),
155
+ query('.backdrop, [role=dialog]', animate('350ms cubic-bezier(0.33, 1, 0.68, 1)', style({ opacity: '0' })), { optional: true }),
156
+ ]),
157
+ ]),
158
+ ]),
159
+ ], template: "<ng-container *ngIf=\"isOpen\" [ngSwitch]=\"modalType\">\n <div class=\"gds-dialog-wrapper\" [@modalAnimation]>\n <aside\n data-testid=\"modal\"\n *ngSwitchCase=\"'slideout'\"\n role=\"dialog\"\n aria-modal=\"true\"\n [class.small]=\"size === 'sm'\"\n [class.medium]=\"size === 'md'\"\n [class.large]=\"size === 'lg'\"\n [class.entered]=\"isOpen\"\n >\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </aside>\n <main\n data-testid=\"modal\"\n *ngSwitchCase=\"'takeover'\"\n role=\"dialog\"\n aria-modal=\"true\"\n [class.entered]=\"isOpen\"\n >\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </main>\n <section\n data-testid=\"modal\"\n *ngSwitchDefault\n role=\"dialog\"\n aria-modal=\"true\"\n [class.small]=\"size === 'sm'\"\n [class.medium]=\"size === 'md'\"\n [class.large]=\"size === 'lg'\"\n [class.entered]=\"isOpen\"\n >\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </section>\n <ng-template #contentTemplate>\n <ng-container *ngIf=\"!hideHeader\">\n <header\n *ngIf=\"!modalHeaderContent; else headerContentTemplate\"\n ngg-modal-header\n data-testid=\"modal-header\"\n [header]=\"header\"\n (closed)=\"this.handleCloseClick($event)\"\n ></header>\n </ng-container>\n <div ngg-modal-body data-testid=\"modal-body\" class=\"body\">\n <ng-container *ngTemplateOutlet=\"bodyContentTemplate\"></ng-container>\n </div>\n <ng-container *ngIf=\"!hideFooter && (dismissLabel || confirmLabel)\">\n <footer\n *ngIf=\"!modalFooterContent; else footerContentTemplate\"\n ngg-modal-footer\n data-testid=\"modal-footer\"\n [dismissLabel]=\"dismissLabel\"\n [confirmLabel]=\"confirmLabel\"\n (dismiss)=\"this.handleDismiss($event)\"\n (confirm)=\"this.handleConfirm($event)\"\n ></footer>\n </ng-container>\n </ng-template>\n <ng-template #headerContentTemplate>\n <header data-testid=\"modal-header\">\n <ng-content select=\"[nggModalHeader]\"></ng-content>\n </header>\n </ng-template>\n <ng-template #bodyContentTemplate>\n <ng-content></ng-content>\n </ng-template>\n <ng-template #footerContentTemplate>\n <footer data-testid=\"modal-footer\">\n <ng-content select=\"[nggModalFooter]\"></ng-content>\n </footer>\n </ng-template>\n <div\n #backdrop\n data-testid=\"modal-backdrop\"\n class=\"backdrop entered\"\n (click)=\"this.handleBackdropClick($event)\"\n [attr.aria-hidden]=\"true\"\n ></div>\n </div>\n</ng-container>\n", styles: [":host.open{height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100%;z-index:var(--sg-z-index-modal)}:host.open>section[role=dialog]{left:50%;top:50%;transform:translate(-50%,-50%)}.body::-webkit-scrollbar{background-color:#f8f8f8;height:10px;width:10px}.body::-webkit-scrollbar-thumb{background-color:#cecece}.body::-webkit-scrollbar-track{background-color:#f8f8f8;box-shadow:inset 0 0 10px #00000040}\n"] }]
160
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.ConfigurableFocusTrapFactory }]; }, propDecorators: { modalType: [{
161
+ type: Input
162
+ }], header: [{
163
+ type: Input
164
+ }], confirmLabel: [{
165
+ type: Input
166
+ }], dismissLabel: [{
167
+ type: Input
168
+ }], size: [{
169
+ type: Input
170
+ }], hideHeader: [{
171
+ type: Input
172
+ }], hideFooter: [{
173
+ type: Input
174
+ }], disableBodyScroll: [{
175
+ type: Input
176
+ }], trapFocus: [{
177
+ type: Input
178
+ }], isOpen: [{
179
+ type: Input
180
+ }], isOpenChange: [{
181
+ type: Output
182
+ }], closed: [{
183
+ type: Output
184
+ }], confirm: [{
185
+ type: Output
186
+ }], dismiss: [{
187
+ type: Output
188
+ }], open: [{
189
+ type: HostBinding,
190
+ args: ['class.open']
191
+ }], backdropRef: [{
192
+ type: ViewChild,
193
+ args: ['backdrop']
194
+ }], modalHeaderContent: [{
195
+ type: ContentChild,
196
+ args: [NggModalHeaderDirective]
197
+ }], modalFooterContent: [{
198
+ type: ContentChild,
199
+ args: [NggModalFooterDirective]
200
+ }] } });
201
+ export class NggModalHeaderComponent {
202
+ constructor() {
203
+ this.closed = new EventEmitter();
204
+ }
205
+ handleClose(event) {
206
+ this.closed.emit(event);
207
+ }
208
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggModalHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
209
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NggModalHeaderComponent, selector: "[ngg-modal-header]", inputs: { header: "header" }, outputs: { closed: "closed" }, ngImport: i0, template: `
210
+ <h3 data-testid="modal-header-text">{{ header }}</h3>
211
+ <button
212
+ data-testid="modal-close-button"
213
+ class="close"
214
+ (click)="this.handleClose($event)"
215
+ >
216
+ <span className="sr-only">Close</span>
217
+ <i></i>
218
+ </button>
219
+ `, isInline: true, styles: [":host.open{height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100%;z-index:var(--sg-z-index-modal)}:host.open>section[role=dialog]{left:50%;top:50%;transform:translate(-50%,-50%)}.body::-webkit-scrollbar{background-color:#f8f8f8;height:10px;width:10px}.body::-webkit-scrollbar-thumb{background-color:#cecece}.body::-webkit-scrollbar-track{background-color:#f8f8f8;box-shadow:inset 0 0 10px #00000040}\n"] }); }
220
+ }
221
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggModalHeaderComponent, decorators: [{
222
+ type: Component,
223
+ args: [{ selector: '[ngg-modal-header]', template: `
224
+ <h3 data-testid="modal-header-text">{{ header }}</h3>
225
+ <button
226
+ data-testid="modal-close-button"
227
+ class="close"
228
+ (click)="this.handleClose($event)"
229
+ >
230
+ <span className="sr-only">Close</span>
231
+ <i></i>
232
+ </button>
233
+ `, styles: [":host.open{height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100%;z-index:var(--sg-z-index-modal)}:host.open>section[role=dialog]{left:50%;top:50%;transform:translate(-50%,-50%)}.body::-webkit-scrollbar{background-color:#f8f8f8;height:10px;width:10px}.body::-webkit-scrollbar-thumb{background-color:#cecece}.body::-webkit-scrollbar-track{background-color:#f8f8f8;box-shadow:inset 0 0 10px #00000040}\n"] }]
234
+ }], propDecorators: { header: [{
235
+ type: Input
236
+ }], closed: [{
237
+ type: Output
238
+ }] } });
239
+ export class NggModalBodyComponent {
240
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggModalBodyComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
241
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NggModalBodyComponent, selector: "[ngg-modal-body]", ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, styles: [":host.open{height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100%;z-index:var(--sg-z-index-modal)}:host.open>section[role=dialog]{left:50%;top:50%;transform:translate(-50%,-50%)}.body::-webkit-scrollbar{background-color:#f8f8f8;height:10px;width:10px}.body::-webkit-scrollbar-thumb{background-color:#cecece}.body::-webkit-scrollbar-track{background-color:#f8f8f8;box-shadow:inset 0 0 10px #00000040}\n"] }); }
242
+ }
243
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggModalBodyComponent, decorators: [{
244
+ type: Component,
245
+ args: [{ selector: '[ngg-modal-body]', template: `<ng-content></ng-content>`, styles: [":host.open{height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100%;z-index:var(--sg-z-index-modal)}:host.open>section[role=dialog]{left:50%;top:50%;transform:translate(-50%,-50%)}.body::-webkit-scrollbar{background-color:#f8f8f8;height:10px;width:10px}.body::-webkit-scrollbar-thumb{background-color:#cecece}.body::-webkit-scrollbar-track{background-color:#f8f8f8;box-shadow:inset 0 0 10px #00000040}\n"] }]
246
+ }] });
247
+ export class NggModalFooterComponent {
248
+ constructor() {
249
+ this.dismiss = new EventEmitter();
250
+ this.confirm = new EventEmitter();
251
+ }
252
+ handleDismiss(event) {
253
+ this.dismiss.emit(event);
254
+ }
255
+ handleConfirm(event) {
256
+ this.confirm.emit(event);
257
+ }
258
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggModalFooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
259
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NggModalFooterComponent, selector: "[ngg-modal-footer]", inputs: { dismissLabel: "dismissLabel", confirmLabel: "confirmLabel" }, outputs: { dismiss: "dismiss", confirm: "confirm" }, ngImport: i0, template: `
260
+ <button
261
+ data-testid="modal-dismiss-button"
262
+ *ngIf="dismissLabel"
263
+ class="secondary"
264
+ (click)="this.handleDismiss($event)"
265
+ >
266
+ {{ dismissLabel }}
267
+ </button>
268
+ <button
269
+ data-testid="modal-confirm-button"
270
+ *ngIf="confirmLabel"
271
+ class="primary"
272
+ (click)="this.handleConfirm($event)"
273
+ >
274
+ {{ confirmLabel }}
275
+ </button>
276
+ `, isInline: true, styles: [":host.open{height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100%;z-index:var(--sg-z-index-modal)}:host.open>section[role=dialog]{left:50%;top:50%;transform:translate(-50%,-50%)}.body::-webkit-scrollbar{background-color:#f8f8f8;height:10px;width:10px}.body::-webkit-scrollbar-thumb{background-color:#cecece}.body::-webkit-scrollbar-track{background-color:#f8f8f8;box-shadow:inset 0 0 10px #00000040}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
277
+ }
278
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggModalFooterComponent, decorators: [{
279
+ type: Component,
280
+ args: [{ selector: '[ngg-modal-footer]', template: `
281
+ <button
282
+ data-testid="modal-dismiss-button"
283
+ *ngIf="dismissLabel"
284
+ class="secondary"
285
+ (click)="this.handleDismiss($event)"
286
+ >
287
+ {{ dismissLabel }}
288
+ </button>
289
+ <button
290
+ data-testid="modal-confirm-button"
291
+ *ngIf="confirmLabel"
292
+ class="primary"
293
+ (click)="this.handleConfirm($event)"
294
+ >
295
+ {{ confirmLabel }}
296
+ </button>
297
+ `, styles: [":host.open{height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100%;z-index:var(--sg-z-index-modal)}:host.open>section[role=dialog]{left:50%;top:50%;transform:translate(-50%,-50%)}.body::-webkit-scrollbar{background-color:#f8f8f8;height:10px;width:10px}.body::-webkit-scrollbar-thumb{background-color:#cecece}.body::-webkit-scrollbar-track{background-color:#f8f8f8;box-shadow:inset 0 0 10px #00000040}\n"] }]
298
+ }], propDecorators: { dismissLabel: [{
299
+ type: Input
300
+ }], confirmLabel: [{
301
+ type: Input
302
+ }], dismiss: [{
303
+ type: Output
304
+ }], confirm: [{
305
+ type: Output
306
+ }] } });
307
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/lib/modal/modal.component.ts","../../../../../../libs/angular/src/lib/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core'\nimport {\n  trigger,\n  query,\n  style,\n  animate,\n  transition,\n  group,\n} from '@angular/animations'\nimport { ModalType, Size } from '@sebgroup/extract'\nimport {\n  ConfigurableFocusTrap,\n  ConfigurableFocusTrapFactory,\n} from '@angular/cdk/a11y'\nimport { disableBodyScroll, enableBodyScroll } from 'body-scroll-lock'\nimport { NggModalHeaderDirective } from './modal-header.directive'\nimport { NggModalFooterDirective } from './modal-footer.directive'\n\n@Component({\n  selector: 'ngg-modal',\n  styleUrls: ['./modal.component.scss'],\n  templateUrl: './modal.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  animations: [\n    trigger('modalAnimation', [\n      transition(':enter', [\n        query('aside', style({ transform: 'translateX(100%)' }), {\n          optional: true,\n        }),\n        query('.backdrop, [role=dialog]', style({ opacity: '0' }), {\n          optional: true,\n        }),\n        group([\n          query(\n            'aside',\n            animate(\n              '350ms cubic-bezier(0.33, 1, 0.68, 1)',\n              style({ transform: 'translateX(0)' }),\n            ),\n            { optional: true },\n          ),\n          query(\n            '.backdrop, [role=dialog]',\n            animate(\n              '350ms cubic-bezier(0.33, 1, 0.68, 1)',\n              style({ opacity: '1' }),\n            ),\n            { optional: true },\n          ),\n        ]),\n      ]),\n      transition(':leave', [\n        query('aside', style({ transform: 'translateX(0)' }), {\n          optional: true,\n        }),\n        group([\n          query(\n            'aside',\n            animate(\n              '350ms cubic-bezier(0.33, 1, 0.68, 1)',\n              style({ transform: 'translateX(100%)' }),\n            ),\n            { optional: true },\n          ),\n          query(\n            '.backdrop, [role=dialog]',\n            animate(\n              '350ms cubic-bezier(0.33, 1, 0.68, 1)',\n              style({ opacity: '0' }),\n            ),\n            { optional: true },\n          ),\n        ]),\n      ]),\n    ]),\n  ],\n})\nexport class NggModalComponent implements OnDestroy, OnInit {\n  @Input() public modalType?: ModalType\n  @Input() public header?: string\n  @Input() public confirmLabel?: string\n  @Input() public dismissLabel?: string\n  @Input() public size?: Size\n  @Input() public hideHeader?: boolean\n  @Input() public hideFooter?: boolean\n  @Input() public disableBodyScroll?: boolean = true\n  @Input() public get trapFocus(): boolean | undefined {\n    return this._trapFocus\n  }\n  public set trapFocus(value: boolean | undefined) {\n    this._trapFocus = value\n\n    if (value) {\n      if (this._isOpen) {\n        this.enableFocusTrap()\n      }\n    } else {\n      this.disableFocusTrap()\n    }\n  }\n\n  @Input()\n  public get isOpen(): boolean | undefined {\n    return this._isOpen\n  }\n  public set isOpen(value: boolean | undefined) {\n    this._isOpen = value\n\n    if (value) {\n      if (this.trapFocus) {\n        this.enableFocusTrap()\n      }\n\n      if (this.disableBodyScroll) {\n        disableBodyScroll(this.ref.nativeElement, {\n          allowTouchMove: (el) => {\n            // Allow touchmove for elements inside modal, its required for scroll to work on iOS devices\n            return this.ref.nativeElement.contains(el)\n          },\n        })\n      }\n    } else {\n      this.disableFocusTrap()\n      if (this.disableBodyScroll) {\n        enableBodyScroll(this.ref.nativeElement)\n      }\n    }\n  }\n\n  @Output() public isOpenChange: EventEmitter<boolean> =\n    new EventEmitter<boolean>()\n  @Output() public closed: EventEmitter<MouseEvent> =\n    new EventEmitter<MouseEvent>()\n  @Output() public confirm: EventEmitter<MouseEvent> =\n    new EventEmitter<MouseEvent>()\n  @Output() public dismiss: EventEmitter<MouseEvent> =\n    new EventEmitter<MouseEvent>()\n\n  @HostBinding('class.open') get open() {\n    return this.isOpen\n  }\n  @ViewChild('backdrop') private backdropRef?: ElementRef<HTMLInputElement>\n  @ContentChild(NggModalHeaderDirective)\n  public modalHeaderContent?: NggModalHeaderDirective\n  @ContentChild(NggModalFooterDirective)\n  public modalFooterContent?: NggModalFooterDirective\n  private _isOpen?: boolean\n  private _trapFocus?: boolean\n  private configurableFocusTrap: ConfigurableFocusTrap\n\n  constructor(\n    private ref: ElementRef<HTMLElement>,\n    private configurableFocusTrapFactory: ConfigurableFocusTrapFactory,\n  ) {\n    this.configurableFocusTrap = this.configurableFocusTrapFactory.create(\n      this.ref.nativeElement,\n    )\n  }\n\n  ngOnInit(): void {\n    if (this._isOpen && this.trapFocus) this.enableFocusTrap()\n    else this.disableFocusTrap()\n  }\n\n  public handleCloseClick(event: MouseEvent) {\n    this.closeModal(event)\n  }\n\n  public handleBackdropClick(event: MouseEvent) {\n    if (event.target == this.backdropRef?.nativeElement) this.closeModal(event)\n  }\n\n  public handleDismiss(event: MouseEvent) {\n    this.dismiss.emit(event)\n  }\n\n  public handleConfirm(event: MouseEvent) {\n    this.confirm.emit(event)\n  }\n\n  private closeModal(event: MouseEvent) {\n    if (this.closed.observers.length > 0) {\n      this.closed.emit(event)\n    } else {\n      this.isOpen = false\n      this.isOpenChange.emit(this.isOpen)\n    }\n  }\n\n  private enableFocusTrap() {\n    if (this.configurableFocusTrap) {\n      this.configurableFocusTrap.enabled = true\n      this.configurableFocusTrap.focusInitialElementWhenReady()\n    }\n  }\n\n  private disableFocusTrap() {\n    if (this.configurableFocusTrap) {\n      this.configurableFocusTrap.enabled = false\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.configurableFocusTrap?.destroy()\n    enableBodyScroll(this.ref.nativeElement)\n  }\n}\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: '[ngg-modal-header]',\n  styleUrls: ['./modal.component.scss'],\n  template: `\n    <h3 data-testid=\"modal-header-text\">{{ header }}</h3>\n    <button\n      data-testid=\"modal-close-button\"\n      class=\"close\"\n      (click)=\"this.handleClose($event)\"\n    >\n      <span className=\"sr-only\">Close</span>\n      <i></i>\n    </button>\n  `,\n})\nexport class NggModalHeaderComponent {\n  @Input() header?: string\n  @Output() closed: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>()\n\n  handleClose(event: MouseEvent) {\n    this.closed.emit(event)\n  }\n}\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: '[ngg-modal-body]',\n  styleUrls: ['./modal.component.scss'],\n  template: `<ng-content></ng-content>`,\n})\nexport class NggModalBodyComponent {}\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: '[ngg-modal-footer]',\n  styleUrls: ['./modal.component.scss'],\n  template: `\n    <button\n      data-testid=\"modal-dismiss-button\"\n      *ngIf=\"dismissLabel\"\n      class=\"secondary\"\n      (click)=\"this.handleDismiss($event)\"\n    >\n      {{ dismissLabel }}\n    </button>\n    <button\n      data-testid=\"modal-confirm-button\"\n      *ngIf=\"confirmLabel\"\n      class=\"primary\"\n      (click)=\"this.handleConfirm($event)\"\n    >\n      {{ confirmLabel }}\n    </button>\n  `,\n})\nexport class NggModalFooterComponent {\n  @Input() dismissLabel?: string\n  @Input() confirmLabel?: string\n  @Output() dismiss: EventEmitter<MouseEvent> = new EventEmitter()\n  @Output() confirm: EventEmitter<MouseEvent> = new EventEmitter()\n\n  handleDismiss(event: MouseEvent) {\n    this.dismiss.emit(event)\n  }\n\n  handleConfirm(event: MouseEvent) {\n    this.confirm.emit(event)\n  }\n}\n","<ng-container *ngIf=\"isOpen\" [ngSwitch]=\"modalType\">\n  <div class=\"gds-dialog-wrapper\" [@modalAnimation]>\n    <aside\n      data-testid=\"modal\"\n      *ngSwitchCase=\"'slideout'\"\n      role=\"dialog\"\n      aria-modal=\"true\"\n      [class.small]=\"size === 'sm'\"\n      [class.medium]=\"size === 'md'\"\n      [class.large]=\"size === 'lg'\"\n      [class.entered]=\"isOpen\"\n    >\n      <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n    </aside>\n    <main\n      data-testid=\"modal\"\n      *ngSwitchCase=\"'takeover'\"\n      role=\"dialog\"\n      aria-modal=\"true\"\n      [class.entered]=\"isOpen\"\n    >\n      <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n    </main>\n    <section\n      data-testid=\"modal\"\n      *ngSwitchDefault\n      role=\"dialog\"\n      aria-modal=\"true\"\n      [class.small]=\"size === 'sm'\"\n      [class.medium]=\"size === 'md'\"\n      [class.large]=\"size === 'lg'\"\n      [class.entered]=\"isOpen\"\n    >\n      <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n    </section>\n    <ng-template #contentTemplate>\n      <ng-container *ngIf=\"!hideHeader\">\n        <header\n          *ngIf=\"!modalHeaderContent; else headerContentTemplate\"\n          ngg-modal-header\n          data-testid=\"modal-header\"\n          [header]=\"header\"\n          (closed)=\"this.handleCloseClick($event)\"\n        ></header>\n      </ng-container>\n      <div ngg-modal-body data-testid=\"modal-body\" class=\"body\">\n        <ng-container *ngTemplateOutlet=\"bodyContentTemplate\"></ng-container>\n      </div>\n      <ng-container *ngIf=\"!hideFooter && (dismissLabel || confirmLabel)\">\n        <footer\n          *ngIf=\"!modalFooterContent; else footerContentTemplate\"\n          ngg-modal-footer\n          data-testid=\"modal-footer\"\n          [dismissLabel]=\"dismissLabel\"\n          [confirmLabel]=\"confirmLabel\"\n          (dismiss)=\"this.handleDismiss($event)\"\n          (confirm)=\"this.handleConfirm($event)\"\n        ></footer>\n      </ng-container>\n    </ng-template>\n    <ng-template #headerContentTemplate>\n      <header data-testid=\"modal-header\">\n        <ng-content select=\"[nggModalHeader]\"></ng-content>\n      </header>\n    </ng-template>\n    <ng-template #bodyContentTemplate>\n      <ng-content></ng-content>\n    </ng-template>\n    <ng-template #footerContentTemplate>\n      <footer data-testid=\"modal-footer\">\n        <ng-content select=\"[nggModalFooter]\"></ng-content>\n      </footer>\n    </ng-template>\n    <div\n      #backdrop\n      data-testid=\"modal-backdrop\"\n      class=\"backdrop entered\"\n      (click)=\"this.handleBackdropClick($event)\"\n      [attr.aria-hidden]=\"true\"\n    ></div>\n  </div>\n</ng-container>\n"]}
@@ -19,18 +19,18 @@ const EXPORTS = [
19
19
  NggModalFooterDirective,
20
20
  ];
21
21
  export class NggModalModule {
22
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggModalModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
23
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: NggModalModule, declarations: [NggModalComponent,
24
+ NggModalHeaderComponent,
25
+ NggModalBodyComponent,
26
+ NggModalFooterComponent,
27
+ NggModalHeaderDirective,
28
+ NggModalFooterDirective], imports: [A11yModule, CommonModule], exports: [NggModalComponent,
29
+ NggModalHeaderDirective,
30
+ NggModalFooterDirective] }); }
31
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggModalModule, imports: [A11yModule, CommonModule] }); }
22
32
  }
23
- NggModalModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggModalModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
24
- NggModalModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: NggModalModule, declarations: [NggModalComponent,
25
- NggModalHeaderComponent,
26
- NggModalBodyComponent,
27
- NggModalFooterComponent,
28
- NggModalHeaderDirective,
29
- NggModalFooterDirective], imports: [A11yModule, CommonModule], exports: [NggModalComponent,
30
- NggModalHeaderDirective,
31
- NggModalFooterDirective] });
32
- NggModalModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggModalModule, imports: [A11yModule, CommonModule] });
33
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggModalModule, decorators: [{
33
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggModalModule, decorators: [{
34
34
  type: NgModule,
35
35
  args: [{
36
36
  imports: [A11yModule, CommonModule],
@@ -38,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
38
38
  declarations: DECLARATIONS,
39
39
  }]
40
40
  }] });
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL3NyYy9saWIvbW9kYWwvbW9kYWwubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUM5QyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ3hDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQTtBQUM5QyxPQUFPLEVBQ0wscUJBQXFCLEVBQ3JCLGlCQUFpQixFQUNqQix1QkFBdUIsRUFDdkIsdUJBQXVCLEdBQ3hCLE1BQU0sbUJBQW1CLENBQUE7QUFDMUIsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sMEJBQTBCLENBQUE7QUFDbEUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sMEJBQTBCLENBQUE7O0FBRWxFLE1BQU0sWUFBWSxHQUFHO0lBQ25CLGlCQUFpQjtJQUNqQix1QkFBdUI7SUFDdkIscUJBQXFCO0lBQ3JCLHVCQUF1QjtJQUN2Qix1QkFBdUI7SUFDdkIsdUJBQXVCO0NBQ3hCLENBQUE7QUFFRCxNQUFNLE9BQU8sR0FBRztJQUNkLGlCQUFpQjtJQUNqQix1QkFBdUI7SUFDdkIsdUJBQXVCO0NBQ3hCLENBQUE7QUFPRCxNQUFNLE9BQU8sY0FBYzs7MkdBQWQsY0FBYzs0R0FBZCxjQUFjLGlCQW5CekIsaUJBQWlCO1FBQ2pCLHVCQUF1QjtRQUN2QixxQkFBcUI7UUFDckIsdUJBQXVCO1FBQ3ZCLHVCQUF1QjtRQUN2Qix1QkFBdUIsYUFVYixVQUFVLEVBQUUsWUFBWSxhQU5sQyxpQkFBaUI7UUFDakIsdUJBQXVCO1FBQ3ZCLHVCQUF1Qjs0R0FRWixjQUFjLFlBSmYsVUFBVSxFQUFFLFlBQVk7MkZBSXZCLGNBQWM7a0JBTDFCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsVUFBVSxFQUFFLFlBQVksQ0FBQztvQkFDbkMsT0FBTyxFQUFFLE9BQU87b0JBQ2hCLFlBQVksRUFBRSxZQUFZO2lCQUMzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbidcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IEExMXlNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvYTExeSdcbmltcG9ydCB7XG4gIE5nZ01vZGFsQm9keUNvbXBvbmVudCxcbiAgTmdnTW9kYWxDb21wb25lbnQsXG4gIE5nZ01vZGFsRm9vdGVyQ29tcG9uZW50LFxuICBOZ2dNb2RhbEhlYWRlckNvbXBvbmVudCxcbn0gZnJvbSAnLi9tb2RhbC5jb21wb25lbnQnXG5pbXBvcnQgeyBOZ2dNb2RhbEhlYWRlckRpcmVjdGl2ZSB9IGZyb20gJy4vbW9kYWwtaGVhZGVyLmRpcmVjdGl2ZSdcbmltcG9ydCB7IE5nZ01vZGFsRm9vdGVyRGlyZWN0aXZlIH0gZnJvbSAnLi9tb2RhbC1mb290ZXIuZGlyZWN0aXZlJ1xuXG5jb25zdCBERUNMQVJBVElPTlMgPSBbXG4gIE5nZ01vZGFsQ29tcG9uZW50LFxuICBOZ2dNb2RhbEhlYWRlckNvbXBvbmVudCxcbiAgTmdnTW9kYWxCb2R5Q29tcG9uZW50LFxuICBOZ2dNb2RhbEZvb3RlckNvbXBvbmVudCxcbiAgTmdnTW9kYWxIZWFkZXJEaXJlY3RpdmUsXG4gIE5nZ01vZGFsRm9vdGVyRGlyZWN0aXZlLFxuXVxuXG5jb25zdCBFWFBPUlRTID0gW1xuICBOZ2dNb2RhbENvbXBvbmVudCxcbiAgTmdnTW9kYWxIZWFkZXJEaXJlY3RpdmUsXG4gIE5nZ01vZGFsRm9vdGVyRGlyZWN0aXZlLFxuXVxuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQTExeU1vZHVsZSwgQ29tbW9uTW9kdWxlXSxcbiAgZXhwb3J0czogRVhQT1JUUyxcbiAgZGVjbGFyYXRpb25zOiBERUNMQVJBVElPTlMsXG59KVxuZXhwb3J0IGNsYXNzIE5nZ01vZGFsTW9kdWxlIHt9XG4iXX0=
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL3NyYy9saWIvbW9kYWwvbW9kYWwubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUM5QyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ3hDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQTtBQUM5QyxPQUFPLEVBQ0wscUJBQXFCLEVBQ3JCLGlCQUFpQixFQUNqQix1QkFBdUIsRUFDdkIsdUJBQXVCLEdBQ3hCLE1BQU0sbUJBQW1CLENBQUE7QUFDMUIsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sMEJBQTBCLENBQUE7QUFDbEUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sMEJBQTBCLENBQUE7O0FBRWxFLE1BQU0sWUFBWSxHQUFHO0lBQ25CLGlCQUFpQjtJQUNqQix1QkFBdUI7SUFDdkIscUJBQXFCO0lBQ3JCLHVCQUF1QjtJQUN2Qix1QkFBdUI7SUFDdkIsdUJBQXVCO0NBQ3hCLENBQUE7QUFFRCxNQUFNLE9BQU8sR0FBRztJQUNkLGlCQUFpQjtJQUNqQix1QkFBdUI7SUFDdkIsdUJBQXVCO0NBQ3hCLENBQUE7QUFPRCxNQUFNLE9BQU8sY0FBYzsrR0FBZCxjQUFjO2dIQUFkLGNBQWMsaUJBbkJ6QixpQkFBaUI7WUFDakIsdUJBQXVCO1lBQ3ZCLHFCQUFxQjtZQUNyQix1QkFBdUI7WUFDdkIsdUJBQXVCO1lBQ3ZCLHVCQUF1QixhQVViLFVBQVUsRUFBRSxZQUFZLGFBTmxDLGlCQUFpQjtZQUNqQix1QkFBdUI7WUFDdkIsdUJBQXVCO2dIQVFaLGNBQWMsWUFKZixVQUFVLEVBQUUsWUFBWTs7NEZBSXZCLGNBQWM7a0JBTDFCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsVUFBVSxFQUFFLFlBQVksQ0FBQztvQkFDbkMsT0FBTyxFQUFFLE9BQU87b0JBQ2hCLFlBQVksRUFBRSxZQUFZO2lCQUMzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbidcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IEExMXlNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvYTExeSdcbmltcG9ydCB7XG4gIE5nZ01vZGFsQm9keUNvbXBvbmVudCxcbiAgTmdnTW9kYWxDb21wb25lbnQsXG4gIE5nZ01vZGFsRm9vdGVyQ29tcG9uZW50LFxuICBOZ2dNb2RhbEhlYWRlckNvbXBvbmVudCxcbn0gZnJvbSAnLi9tb2RhbC5jb21wb25lbnQnXG5pbXBvcnQgeyBOZ2dNb2RhbEhlYWRlckRpcmVjdGl2ZSB9IGZyb20gJy4vbW9kYWwtaGVhZGVyLmRpcmVjdGl2ZSdcbmltcG9ydCB7IE5nZ01vZGFsRm9vdGVyRGlyZWN0aXZlIH0gZnJvbSAnLi9tb2RhbC1mb290ZXIuZGlyZWN0aXZlJ1xuXG5jb25zdCBERUNMQVJBVElPTlMgPSBbXG4gIE5nZ01vZGFsQ29tcG9uZW50LFxuICBOZ2dNb2RhbEhlYWRlckNvbXBvbmVudCxcbiAgTmdnTW9kYWxCb2R5Q29tcG9uZW50LFxuICBOZ2dNb2RhbEZvb3RlckNvbXBvbmVudCxcbiAgTmdnTW9kYWxIZWFkZXJEaXJlY3RpdmUsXG4gIE5nZ01vZGFsRm9vdGVyRGlyZWN0aXZlLFxuXVxuXG5jb25zdCBFWFBPUlRTID0gW1xuICBOZ2dNb2RhbENvbXBvbmVudCxcbiAgTmdnTW9kYWxIZWFkZXJEaXJlY3RpdmUsXG4gIE5nZ01vZGFsRm9vdGVyRGlyZWN0aXZlLFxuXVxuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQTExeU1vZHVsZSwgQ29tbW9uTW9kdWxlXSxcbiAgZXhwb3J0czogRVhQT1JUUyxcbiAgZGVjbGFyYXRpb25zOiBERUNMQVJBVElPTlMsXG59KVxuZXhwb3J0IGNsYXNzIE5nZ01vZGFsTW9kdWxlIHt9XG4iXX0=
@@ -151,10 +151,10 @@ export class NggPaginationComponent {
151
151
  }
152
152
  return pages;
153
153
  }
154
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggPaginationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
155
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NggPaginationComponent, selector: "ngg-pagination", inputs: { i18n: "i18n", size: "size", displayPages: "displayPages", length: "length", pageSize: "pageSize", pageIndex: "pageIndex" }, outputs: { page: "page" }, usesOnChanges: true, ngImport: i0, template: "<nav\n [class]=\"'pagination ' + size\"\n role=\"navigation\"\n [attr.aria-label]=\"i18n.paginationLabel\"\n *ngIf=\"totalPages > 1\"\n>\n <ul class=\"gds-reset\">\n <li *ngIf=\"hasPrevious()\">\n <a\n class=\"gds-reset\"\n tabindex=\"0\"\n (click)=\"gotoPrevious()\"\n (keydown.enter)=\"gotoPrevious()\"\n [attr.aria-label]=\"i18n.previousPageLabel\"\n role=\"button\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 320 512\">\n <path\n d=\"M9.4 233.4c-12.5 12.5-12.5 32.8 0 45.3l192 192c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L77.3 256 246.6 86.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-192 192z\"\n />\n </svg>\n </a>\n </li>\n\n <li>\n <a\n class=\"gds-reset\"\n tabindex=\"0\"\n (click)=\"gotoFirst()\"\n (keydown.enter)=\"gotoFirst()\"\n [attr.aria-current]=\"pageIndex === 0 ? 'page' : null\"\n [attr.aria-label]=\"i18n.firstPageLabel\"\n role=\"button\"\n >\n 1\n </a>\n </li>\n <li *ngIf=\"pageIndicies[0] > 1\" aria-hidden=\"true\">...</li>\n\n <li *ngFor=\"let index of pageIndicies\">\n <a\n class=\"gds-reset\"\n tabindex=\"0\"\n (click)=\"goto(index)\"\n (keydown.enter)=\"goto(index)\"\n [attr.aria-current]=\"pageIndex === index ? 'page' : null\"\n [attr.aria-label]=\"i18n.getPageLabel(index)\"\n role=\"button\"\n >\n {{ index + 1 }}\n </a>\n </li>\n\n <li\n *ngIf=\"pageIndicies[pageIndicies.length - 1] < totalPages - 2\"\n aria-hidden=\"true\"\n >\n ...\n </li>\n\n <li>\n <a\n class=\"gds-reset\"\n tabindex=\"0\"\n (click)=\"gotoLast()\"\n (keydown.enter)=\"gotoLast()\"\n [attr.aria-current]=\"pageIndex === totalPages - 1 ? 'page' : null\"\n [attr.aria-label]=\"i18n.lastPageLabel\"\n role=\"button\"\n >\n {{ totalPages }}\n </a>\n </li>\n <li *ngIf=\"hasNext()\">\n <a\n class=\"gds-reset\"\n tabindex=\"0\"\n (click)=\"gotoNext()\"\n (keydown.enter)=\"gotoNext()\"\n [attr.aria-label]=\"i18n.nextPageLabel\"\n role=\"button\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 320 512\">\n <path\n d=\"M310.6 233.4c12.5 12.5 12.5 32.8 0 45.3l-192 192c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L242.7 256 73.4 86.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l192 192z\"\n />\n </svg>\n </a>\n </li>\n </ul>\n</nav>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
154
156
  }
155
- NggPaginationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggPaginationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
156
- NggPaginationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: NggPaginationComponent, selector: "ngg-pagination", inputs: { i18n: "i18n", size: "size", displayPages: "displayPages", length: "length", pageSize: "pageSize", pageIndex: "pageIndex" }, outputs: { page: "page" }, usesOnChanges: true, ngImport: i0, template: "<nav\n [class]=\"'pagination ' + size\"\n role=\"navigation\"\n [attr.aria-label]=\"i18n.paginationLabel\"\n *ngIf=\"totalPages > 1\"\n>\n <ul class=\"gds-reset\">\n <li *ngIf=\"hasPrevious()\">\n <a\n class=\"gds-reset\"\n tabindex=\"0\"\n (click)=\"gotoPrevious()\"\n (keydown.enter)=\"gotoPrevious()\"\n [attr.aria-label]=\"i18n.previousPageLabel\"\n role=\"button\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 320 512\">\n <path\n d=\"M9.4 233.4c-12.5 12.5-12.5 32.8 0 45.3l192 192c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L77.3 256 246.6 86.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-192 192z\"\n />\n </svg>\n </a>\n </li>\n\n <li>\n <a\n class=\"gds-reset\"\n tabindex=\"0\"\n (click)=\"gotoFirst()\"\n (keydown.enter)=\"gotoFirst()\"\n [attr.aria-current]=\"pageIndex === 0 ? 'page' : null\"\n [attr.aria-label]=\"i18n.firstPageLabel\"\n role=\"button\"\n >\n 1\n </a>\n </li>\n <li *ngIf=\"pageIndicies[0] > 1\" aria-hidden=\"true\">...</li>\n\n <li *ngFor=\"let index of pageIndicies\">\n <a\n class=\"gds-reset\"\n tabindex=\"0\"\n (click)=\"goto(index)\"\n (keydown.enter)=\"goto(index)\"\n [attr.aria-current]=\"pageIndex === index ? 'page' : null\"\n [attr.aria-label]=\"i18n.getPageLabel(index)\"\n role=\"button\"\n >\n {{ index + 1 }}\n </a>\n </li>\n\n <li\n *ngIf=\"pageIndicies[pageIndicies.length - 1] < totalPages - 2\"\n aria-hidden=\"true\"\n >\n ...\n </li>\n\n <li>\n <a\n class=\"gds-reset\"\n tabindex=\"0\"\n (click)=\"gotoLast()\"\n (keydown.enter)=\"gotoLast()\"\n [attr.aria-current]=\"pageIndex === totalPages - 1 ? 'page' : null\"\n [attr.aria-label]=\"i18n.lastPageLabel\"\n role=\"button\"\n >\n {{ totalPages }}\n </a>\n </li>\n <li *ngIf=\"hasNext()\">\n <a\n class=\"gds-reset\"\n tabindex=\"0\"\n (click)=\"gotoNext()\"\n (keydown.enter)=\"gotoNext()\"\n [attr.aria-label]=\"i18n.nextPageLabel\"\n role=\"button\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 320 512\">\n <path\n d=\"M310.6 233.4c12.5 12.5 12.5 32.8 0 45.3l-192 192c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L242.7 256 73.4 86.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l192 192z\"\n />\n </svg>\n </a>\n </li>\n </ul>\n</nav>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
157
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggPaginationComponent, decorators: [{
157
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggPaginationComponent, decorators: [{
158
158
  type: Component,
159
159
  args: [{ selector: 'ngg-pagination', changeDetection: ChangeDetectionStrategy.OnPush, template: "<nav\n [class]=\"'pagination ' + size\"\n role=\"navigation\"\n [attr.aria-label]=\"i18n.paginationLabel\"\n *ngIf=\"totalPages > 1\"\n>\n <ul class=\"gds-reset\">\n <li *ngIf=\"hasPrevious()\">\n <a\n class=\"gds-reset\"\n tabindex=\"0\"\n (click)=\"gotoPrevious()\"\n (keydown.enter)=\"gotoPrevious()\"\n [attr.aria-label]=\"i18n.previousPageLabel\"\n role=\"button\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 320 512\">\n <path\n d=\"M9.4 233.4c-12.5 12.5-12.5 32.8 0 45.3l192 192c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L77.3 256 246.6 86.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-192 192z\"\n />\n </svg>\n </a>\n </li>\n\n <li>\n <a\n class=\"gds-reset\"\n tabindex=\"0\"\n (click)=\"gotoFirst()\"\n (keydown.enter)=\"gotoFirst()\"\n [attr.aria-current]=\"pageIndex === 0 ? 'page' : null\"\n [attr.aria-label]=\"i18n.firstPageLabel\"\n role=\"button\"\n >\n 1\n </a>\n </li>\n <li *ngIf=\"pageIndicies[0] > 1\" aria-hidden=\"true\">...</li>\n\n <li *ngFor=\"let index of pageIndicies\">\n <a\n class=\"gds-reset\"\n tabindex=\"0\"\n (click)=\"goto(index)\"\n (keydown.enter)=\"goto(index)\"\n [attr.aria-current]=\"pageIndex === index ? 'page' : null\"\n [attr.aria-label]=\"i18n.getPageLabel(index)\"\n role=\"button\"\n >\n {{ index + 1 }}\n </a>\n </li>\n\n <li\n *ngIf=\"pageIndicies[pageIndicies.length - 1] < totalPages - 2\"\n aria-hidden=\"true\"\n >\n ...\n </li>\n\n <li>\n <a\n class=\"gds-reset\"\n tabindex=\"0\"\n (click)=\"gotoLast()\"\n (keydown.enter)=\"gotoLast()\"\n [attr.aria-current]=\"pageIndex === totalPages - 1 ? 'page' : null\"\n [attr.aria-label]=\"i18n.lastPageLabel\"\n role=\"button\"\n >\n {{ totalPages }}\n </a>\n </li>\n <li *ngIf=\"hasNext()\">\n <a\n class=\"gds-reset\"\n tabindex=\"0\"\n (click)=\"gotoNext()\"\n (keydown.enter)=\"gotoNext()\"\n [attr.aria-label]=\"i18n.nextPageLabel\"\n role=\"button\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 320 512\">\n <path\n d=\"M310.6 233.4c12.5 12.5 12.5 32.8 0 45.3l-192 192c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L242.7 256 73.4 86.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l192 192z\"\n />\n </svg>\n </a>\n </li>\n </ul>\n</nav>\n" }]
160
160
  }], propDecorators: { i18n: [{
@@ -172,4 +172,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
172
172
  }], page: [{
173
173
  type: Output
174
174
  }] } });
175
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/lib/pagination/pagination.component.ts","../../../../../../libs/angular/src/lib/pagination/pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ChangeDetectionStrategy,\n  OnChanges,\n  SimpleChanges,\n} from '@angular/core'\nimport {\n  IPaginationEvent,\n  IPaginationI18n,\n  PaginationI18n,\n  PaginationSize,\n} from '@sebgroup/extract'\n\n@Component({\n  selector: 'ngg-pagination',\n  templateUrl: './pagination.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NggPaginationComponent implements OnChanges {\n  /** Internationalization labels */\n  @Input() i18n: IPaginationI18n = PaginationI18n\n\n  /** Rendered size */\n  @Input() size: PaginationSize = 'small'\n\n  /** Amount of pages to be displayed between the first and last  */\n  @Input() displayPages = 5\n\n  /** Total amount of items to be paginated */\n  @Input() length = 0\n\n  /** Displayed items per page */\n  @Input() pageSize = 10\n\n  /** The zero-based page index of the displayed list of pages. Defaulted to 0. */\n  @Input()\n  get pageIndex(): number {\n    return this._pageIndex\n  }\n  set pageIndex(value: number) {\n    this._pageIndex = Math.max(value, 0)\n  }\n  private _pageIndex = 0\n\n  /** All centric page indicies to be displayed. */\n  get pageIndicies(): number[] {\n    return this._pageIndicies\n  }\n  private _pageIndicies: number[] = []\n\n  get totalPages(): number {\n    if (!this.pageSize) {\n      return 0\n    }\n\n    return Math.ceil(this.length / this.pageSize)\n  }\n\n  /** Event emitted when a new page index is selected */\n  @Output() page = new EventEmitter<IPaginationEvent>()\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (\n      changes.displayPages ||\n      changes.pageIndex ||\n      changes.pageSize ||\n      changes.length\n    ) {\n      this._pageIndicies = this.getDisplayedPageIndicies()\n    }\n  }\n\n  hasPrevious(): boolean {\n    return this.pageIndex >= 1\n  }\n\n  hasNext(): boolean {\n    return this.pageIndex < this.totalPages - 1\n  }\n\n  gotoFirst(): void {\n    if (!this.hasPrevious()) {\n      return\n    }\n    const previous = this.pageIndex\n    this.pageIndex = 0\n    this.emit(previous)\n  }\n\n  gotoLast(): void {\n    if (!this.hasNext()) {\n      return\n    }\n    const previous = this.pageIndex\n    this.pageIndex = this.totalPages - 1\n    this.emit(previous)\n  }\n\n  gotoPrevious(): void {\n    if (!this.hasPrevious()) {\n      return\n    }\n    const previous = this.pageIndex\n    this.pageIndex = previous - 1\n    this.emit(previous)\n  }\n\n  gotoNext(): void {\n    if (!this.hasNext()) {\n      return\n    }\n    const previous = this.pageIndex\n    this.pageIndex = previous + 1\n    this.emit(previous)\n  }\n\n  goto(index: number): void {\n    if (index === this.pageIndex || index < 0 || index >= this.totalPages) {\n      return\n    }\n    const previous = this.pageIndex\n    this.pageIndex = index\n    this.emit(previous)\n  }\n\n  private emit(previous: number) {\n    this._pageIndicies = this.getDisplayedPageIndicies()\n    this.page.emit({ pageIndex: this.pageIndex, previousPageIndex: previous })\n  }\n\n  private getDisplayedPageIndicies(): number[] {\n    // Do not render\n    if (this.totalPages <= 1) {\n      return []\n    }\n\n    // All pages can fit\n    if (this.totalPages <= this.displayPages)\n      return [...Array(this.totalPages - 2).keys()].map((index) => index + 1)\n\n    // Only first & last\n    if (this.totalPages === 2) return []\n\n    return this.getCenteredPageIndicies()\n  }\n\n  /**\n   * Find X (displayPages) amount of page indicies that are centered from the currently selected page index,\n   * but exclude the first and last indicies if they are within the range.\n   */\n  private getCenteredPageIndicies(): number[] {\n    const pages: number[] = []\n\n    if (this.pageIndex === 0) {\n      pages.push(this.pageIndex + 1)\n    } else if (this.pageIndex === this.totalPages - 1) {\n      pages.push(this.pageIndex - 1)\n    } else {\n      pages.push(this.pageIndex)\n    }\n\n    const addAfter = () => {\n      const next = pages[pages.length - 1] + 1\n      if (next < this.totalPages - 1 && counter > 0) {\n        pages.push(next)\n        return true\n      }\n      return false\n    }\n    const addBefore = () => {\n      const previous = pages[0] - 1\n      if (previous > 0 && counter > 0) {\n        pages.unshift(previous)\n        return true\n      }\n      return false\n    }\n\n    let counter = this.displayPages - 1\n    while (counter > 0) {\n      const addedAfter = addAfter()\n      if (addedAfter) counter--\n\n      const addedBefore = addBefore()\n      if (addedBefore) counter--\n\n      if (!addedAfter && !addedBefore) break\n    }\n\n    return pages\n  }\n}\n","<nav\n  [class]=\"'pagination ' + size\"\n  role=\"navigation\"\n  [attr.aria-label]=\"i18n.paginationLabel\"\n  *ngIf=\"totalPages > 1\"\n>\n  <ul class=\"gds-reset\">\n    <li *ngIf=\"hasPrevious()\">\n      <a\n        class=\"gds-reset\"\n        tabindex=\"0\"\n        (click)=\"gotoPrevious()\"\n        (keydown.enter)=\"gotoPrevious()\"\n        [attr.aria-label]=\"i18n.previousPageLabel\"\n        role=\"button\"\n      >\n        <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 320 512\">\n          <path\n            d=\"M9.4 233.4c-12.5 12.5-12.5 32.8 0 45.3l192 192c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L77.3 256 246.6 86.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-192 192z\"\n          />\n        </svg>\n      </a>\n    </li>\n\n    <li>\n      <a\n        class=\"gds-reset\"\n        tabindex=\"0\"\n        (click)=\"gotoFirst()\"\n        (keydown.enter)=\"gotoFirst()\"\n        [attr.aria-current]=\"pageIndex === 0 ? 'page' : null\"\n        [attr.aria-label]=\"i18n.firstPageLabel\"\n        role=\"button\"\n      >\n        1\n      </a>\n    </li>\n    <li *ngIf=\"pageIndicies[0] > 1\" aria-hidden=\"true\">...</li>\n\n    <li *ngFor=\"let index of pageIndicies\">\n      <a\n        class=\"gds-reset\"\n        tabindex=\"0\"\n        (click)=\"goto(index)\"\n        (keydown.enter)=\"goto(index)\"\n        [attr.aria-current]=\"pageIndex === index ? 'page' : null\"\n        [attr.aria-label]=\"i18n.getPageLabel(index)\"\n        role=\"button\"\n      >\n        {{ index + 1 }}\n      </a>\n    </li>\n\n    <li\n      *ngIf=\"pageIndicies[pageIndicies.length - 1] < totalPages - 2\"\n      aria-hidden=\"true\"\n    >\n      ...\n    </li>\n\n    <li>\n      <a\n        class=\"gds-reset\"\n        tabindex=\"0\"\n        (click)=\"gotoLast()\"\n        (keydown.enter)=\"gotoLast()\"\n        [attr.aria-current]=\"pageIndex === totalPages - 1 ? 'page' : null\"\n        [attr.aria-label]=\"i18n.lastPageLabel\"\n        role=\"button\"\n      >\n        {{ totalPages }}\n      </a>\n    </li>\n    <li *ngIf=\"hasNext()\">\n      <a\n        class=\"gds-reset\"\n        tabindex=\"0\"\n        (click)=\"gotoNext()\"\n        (keydown.enter)=\"gotoNext()\"\n        [attr.aria-label]=\"i18n.nextPageLabel\"\n        role=\"button\"\n      >\n        <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 320 512\">\n          <path\n            d=\"M310.6 233.4c12.5 12.5 12.5 32.8 0 45.3l-192 192c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L242.7 256 73.4 86.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l192 192z\"\n          />\n        </svg>\n      </a>\n    </li>\n  </ul>\n</nav>\n"]}
175
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/lib/pagination/pagination.component.ts","../../../../../../libs/angular/src/lib/pagination/pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ChangeDetectionStrategy,\n  OnChanges,\n  SimpleChanges,\n} from '@angular/core'\nimport {\n  IPaginationEvent,\n  IPaginationI18n,\n  PaginationI18n,\n  PaginationSize,\n} from '@sebgroup/extract'\n\n@Component({\n  selector: 'ngg-pagination',\n  templateUrl: './pagination.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NggPaginationComponent implements OnChanges {\n  /** Internationalization labels */\n  @Input() i18n: IPaginationI18n = PaginationI18n\n\n  /** Rendered size */\n  @Input() size: PaginationSize = 'small'\n\n  /** Amount of pages to be displayed between the first and last  */\n  @Input() displayPages = 5\n\n  /** Total amount of items to be paginated */\n  @Input() length = 0\n\n  /** Displayed items per page */\n  @Input() pageSize = 10\n\n  /** The zero-based page index of the displayed list of pages. Defaulted to 0. */\n  @Input()\n  get pageIndex(): number {\n    return this._pageIndex\n  }\n  set pageIndex(value: number) {\n    this._pageIndex = Math.max(value, 0)\n  }\n  private _pageIndex = 0\n\n  /** All centric page indicies to be displayed. */\n  get pageIndicies(): number[] {\n    return this._pageIndicies\n  }\n  private _pageIndicies: number[] = []\n\n  get totalPages(): number {\n    if (!this.pageSize) {\n      return 0\n    }\n\n    return Math.ceil(this.length / this.pageSize)\n  }\n\n  /** Event emitted when a new page index is selected */\n  @Output() page = new EventEmitter<IPaginationEvent>()\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (\n      changes.displayPages ||\n      changes.pageIndex ||\n      changes.pageSize ||\n      changes.length\n    ) {\n      this._pageIndicies = this.getDisplayedPageIndicies()\n    }\n  }\n\n  hasPrevious(): boolean {\n    return this.pageIndex >= 1\n  }\n\n  hasNext(): boolean {\n    return this.pageIndex < this.totalPages - 1\n  }\n\n  gotoFirst(): void {\n    if (!this.hasPrevious()) {\n      return\n    }\n    const previous = this.pageIndex\n    this.pageIndex = 0\n    this.emit(previous)\n  }\n\n  gotoLast(): void {\n    if (!this.hasNext()) {\n      return\n    }\n    const previous = this.pageIndex\n    this.pageIndex = this.totalPages - 1\n    this.emit(previous)\n  }\n\n  gotoPrevious(): void {\n    if (!this.hasPrevious()) {\n      return\n    }\n    const previous = this.pageIndex\n    this.pageIndex = previous - 1\n    this.emit(previous)\n  }\n\n  gotoNext(): void {\n    if (!this.hasNext()) {\n      return\n    }\n    const previous = this.pageIndex\n    this.pageIndex = previous + 1\n    this.emit(previous)\n  }\n\n  goto(index: number): void {\n    if (index === this.pageIndex || index < 0 || index >= this.totalPages) {\n      return\n    }\n    const previous = this.pageIndex\n    this.pageIndex = index\n    this.emit(previous)\n  }\n\n  private emit(previous: number) {\n    this._pageIndicies = this.getDisplayedPageIndicies()\n    this.page.emit({ pageIndex: this.pageIndex, previousPageIndex: previous })\n  }\n\n  private getDisplayedPageIndicies(): number[] {\n    // Do not render\n    if (this.totalPages <= 1) {\n      return []\n    }\n\n    // All pages can fit\n    if (this.totalPages <= this.displayPages)\n      return [...Array(this.totalPages - 2).keys()].map((index) => index + 1)\n\n    // Only first & last\n    if (this.totalPages === 2) return []\n\n    return this.getCenteredPageIndicies()\n  }\n\n  /**\n   * Find X (displayPages) amount of page indicies that are centered from the currently selected page index,\n   * but exclude the first and last indicies if they are within the range.\n   */\n  private getCenteredPageIndicies(): number[] {\n    const pages: number[] = []\n\n    if (this.pageIndex === 0) {\n      pages.push(this.pageIndex + 1)\n    } else if (this.pageIndex === this.totalPages - 1) {\n      pages.push(this.pageIndex - 1)\n    } else {\n      pages.push(this.pageIndex)\n    }\n\n    const addAfter = () => {\n      const next = pages[pages.length - 1] + 1\n      if (next < this.totalPages - 1 && counter > 0) {\n        pages.push(next)\n        return true\n      }\n      return false\n    }\n    const addBefore = () => {\n      const previous = pages[0] - 1\n      if (previous > 0 && counter > 0) {\n        pages.unshift(previous)\n        return true\n      }\n      return false\n    }\n\n    let counter = this.displayPages - 1\n    while (counter > 0) {\n      const addedAfter = addAfter()\n      if (addedAfter) counter--\n\n      const addedBefore = addBefore()\n      if (addedBefore) counter--\n\n      if (!addedAfter && !addedBefore) break\n    }\n\n    return pages\n  }\n}\n","<nav\n  [class]=\"'pagination ' + size\"\n  role=\"navigation\"\n  [attr.aria-label]=\"i18n.paginationLabel\"\n  *ngIf=\"totalPages > 1\"\n>\n  <ul class=\"gds-reset\">\n    <li *ngIf=\"hasPrevious()\">\n      <a\n        class=\"gds-reset\"\n        tabindex=\"0\"\n        (click)=\"gotoPrevious()\"\n        (keydown.enter)=\"gotoPrevious()\"\n        [attr.aria-label]=\"i18n.previousPageLabel\"\n        role=\"button\"\n      >\n        <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 320 512\">\n          <path\n            d=\"M9.4 233.4c-12.5 12.5-12.5 32.8 0 45.3l192 192c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L77.3 256 246.6 86.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-192 192z\"\n          />\n        </svg>\n      </a>\n    </li>\n\n    <li>\n      <a\n        class=\"gds-reset\"\n        tabindex=\"0\"\n        (click)=\"gotoFirst()\"\n        (keydown.enter)=\"gotoFirst()\"\n        [attr.aria-current]=\"pageIndex === 0 ? 'page' : null\"\n        [attr.aria-label]=\"i18n.firstPageLabel\"\n        role=\"button\"\n      >\n        1\n      </a>\n    </li>\n    <li *ngIf=\"pageIndicies[0] > 1\" aria-hidden=\"true\">...</li>\n\n    <li *ngFor=\"let index of pageIndicies\">\n      <a\n        class=\"gds-reset\"\n        tabindex=\"0\"\n        (click)=\"goto(index)\"\n        (keydown.enter)=\"goto(index)\"\n        [attr.aria-current]=\"pageIndex === index ? 'page' : null\"\n        [attr.aria-label]=\"i18n.getPageLabel(index)\"\n        role=\"button\"\n      >\n        {{ index + 1 }}\n      </a>\n    </li>\n\n    <li\n      *ngIf=\"pageIndicies[pageIndicies.length - 1] < totalPages - 2\"\n      aria-hidden=\"true\"\n    >\n      ...\n    </li>\n\n    <li>\n      <a\n        class=\"gds-reset\"\n        tabindex=\"0\"\n        (click)=\"gotoLast()\"\n        (keydown.enter)=\"gotoLast()\"\n        [attr.aria-current]=\"pageIndex === totalPages - 1 ? 'page' : null\"\n        [attr.aria-label]=\"i18n.lastPageLabel\"\n        role=\"button\"\n      >\n        {{ totalPages }}\n      </a>\n    </li>\n    <li *ngIf=\"hasNext()\">\n      <a\n        class=\"gds-reset\"\n        tabindex=\"0\"\n        (click)=\"gotoNext()\"\n        (keydown.enter)=\"gotoNext()\"\n        [attr.aria-label]=\"i18n.nextPageLabel\"\n        role=\"button\"\n      >\n        <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 320 512\">\n          <path\n            d=\"M310.6 233.4c12.5 12.5 12.5 32.8 0 45.3l-192 192c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L242.7 256 73.4 86.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l192 192z\"\n          />\n        </svg>\n      </a>\n    </li>\n  </ul>\n</nav>\n"]}
@@ -3,11 +3,11 @@ import { CommonModule } from '@angular/common';
3
3
  import { NggPaginationComponent } from './pagination.component';
4
4
  import * as i0 from "@angular/core";
5
5
  export class NggPaginationModule {
6
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggPaginationModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: NggPaginationModule, declarations: [NggPaginationComponent], imports: [CommonModule], exports: [NggPaginationComponent] }); }
8
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggPaginationModule, imports: [CommonModule] }); }
6
9
  }
7
- NggPaginationModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggPaginationModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
8
- NggPaginationModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: NggPaginationModule, declarations: [NggPaginationComponent], imports: [CommonModule], exports: [NggPaginationComponent] });
9
- NggPaginationModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggPaginationModule, imports: [CommonModule] });
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggPaginationModule, decorators: [{
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggPaginationModule, decorators: [{
11
11
  type: NgModule,
12
12
  args: [{
13
13
  declarations: [NggPaginationComponent],
@@ -15,4 +15,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
15
15
  exports: [NggPaginationComponent],
16
16
  }]
17
17
  }] });
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdGlvbi5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL2xpYi9wYWdpbmF0aW9uL3BhZ2luYXRpb24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDeEMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBRTlDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHdCQUF3QixDQUFBOztBQU8vRCxNQUFNLE9BQU8sbUJBQW1COztnSEFBbkIsbUJBQW1CO2lIQUFuQixtQkFBbUIsaUJBSmYsc0JBQXNCLGFBQzNCLFlBQVksYUFDWixzQkFBc0I7aUhBRXJCLG1CQUFtQixZQUhwQixZQUFZOzJGQUdYLG1CQUFtQjtrQkFML0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztvQkFDdEMsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztpQkFDbEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nXG5cbmltcG9ydCB7IE5nZ1BhZ2luYXRpb25Db21wb25lbnQgfSBmcm9tICcuL3BhZ2luYXRpb24uY29tcG9uZW50J1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtOZ2dQYWdpbmF0aW9uQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGV4cG9ydHM6IFtOZ2dQYWdpbmF0aW9uQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgTmdnUGFnaW5hdGlvbk1vZHVsZSB7fVxuIl19
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdGlvbi5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL2xpYi9wYWdpbmF0aW9uL3BhZ2luYXRpb24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDeEMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBRTlDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHdCQUF3QixDQUFBOztBQU8vRCxNQUFNLE9BQU8sbUJBQW1COytHQUFuQixtQkFBbUI7Z0hBQW5CLG1CQUFtQixpQkFKZixzQkFBc0IsYUFDM0IsWUFBWSxhQUNaLHNCQUFzQjtnSEFFckIsbUJBQW1CLFlBSHBCLFlBQVk7OzRGQUdYLG1CQUFtQjtrQkFML0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztvQkFDdEMsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztpQkFDbEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nXG5cbmltcG9ydCB7IE5nZ1BhZ2luYXRpb25Db21wb25lbnQgfSBmcm9tICcuL3BhZ2luYXRpb24uY29tcG9uZW50J1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtOZ2dQYWdpbmF0aW9uQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGV4cG9ydHM6IFtOZ2dQYWdpbmF0aW9uQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgTmdnUGFnaW5hdGlvbk1vZHVsZSB7fVxuIl19
@@ -19,10 +19,10 @@ export class NggProgressCircleComponent {
19
19
  this._startValue = degrees;
20
20
  }
21
21
  }
22
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggProgressCircleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
23
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NggProgressCircleComponent, selector: "ngg-progress-circle", inputs: { id: "id", theme: "theme", value: "value" }, host: { properties: { "style.--start-value": "this._startValue", "style.--end-value": "this._endValue" } }, ngImport: i0, template: "<div\n class=\"gds-progress-circle\"\n role=\"progressbar\"\n [attr.aria-valuenow]=\"value\"\n [attr.aria-valuemin]=\"0\"\n [attr.aria-valuemax]=\"100\"\n [attr.aria-label]=\"id\"\n>\n <div class=\"ring full-ring\">\n <div class=\"ring-progress\" [ngClass]=\"theme\"></div>\n </div>\n <div class=\"ring\">\n <div class=\"ring-progress\" [ngClass]=\"theme\"></div>\n </div>\n <div class=\"inner-circle\">\n <ng-content></ng-content>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
22
24
  }
23
- NggProgressCircleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggProgressCircleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
24
- NggProgressCircleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: NggProgressCircleComponent, selector: "ngg-progress-circle", inputs: { id: "id", theme: "theme", value: "value" }, host: { properties: { "style.--start-value": "this._startValue", "style.--end-value": "this._endValue" } }, ngImport: i0, template: "<div\n class=\"gds-progress-circle\"\n role=\"progressbar\"\n [attr.aria-valuenow]=\"value\"\n [attr.aria-valuemin]=\"0\"\n [attr.aria-valuemax]=\"100\"\n [attr.aria-label]=\"id\"\n>\n <div class=\"ring full-ring\">\n <div class=\"ring-progress\" [ngClass]=\"theme\"></div>\n </div>\n <div class=\"ring\">\n <div class=\"ring-progress\" [ngClass]=\"theme\"></div>\n </div>\n <div class=\"inner-circle\">\n <ng-content></ng-content>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
25
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggProgressCircleComponent, decorators: [{
25
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggProgressCircleComponent, decorators: [{
26
26
  type: Component,
27
27
  args: [{ selector: 'ngg-progress-circle', template: "<div\n class=\"gds-progress-circle\"\n role=\"progressbar\"\n [attr.aria-valuenow]=\"value\"\n [attr.aria-valuemin]=\"0\"\n [attr.aria-valuemax]=\"100\"\n [attr.aria-label]=\"id\"\n>\n <div class=\"ring full-ring\">\n <div class=\"ring-progress\" [ngClass]=\"theme\"></div>\n </div>\n <div class=\"ring\">\n <div class=\"ring-progress\" [ngClass]=\"theme\"></div>\n </div>\n <div class=\"inner-circle\">\n <ng-content></ng-content>\n </div>\n</div>\n" }]
28
28
  }], propDecorators: { _startValue: [{
@@ -38,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
38
38
  }], value: [{
39
39
  type: Input
40
40
  }] } });
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3MtY2lyY2xlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvbGliL3Byb2dyZXNzLWNpcmNsZS9wcm9ncmVzcy1jaXJjbGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL3NyYy9saWIvcHJvZ3Jlc3MtY2lyY2xlL3Byb2dyZXNzLWNpcmNsZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDN0QsT0FBTyxFQUNMLGdCQUFnQixFQUVoQixRQUFRLEdBQ1QsTUFBTSxtQkFBbUIsQ0FBQTs7O0FBTTFCLE1BQU0sT0FBTywwQkFBMEI7SUFKdkM7UUFLOEMsZ0JBQVcsR0FBRyxNQUFNLENBQUE7UUFDdEIsY0FBUyxHQUFHLE1BQU0sQ0FBQTtRQUU1RCxnQ0FBZ0M7UUFDdkIsT0FBRSxHQUFZLEdBQUcsUUFBUSxFQUFFLGtCQUFrQixDQUFBO1FBQ3RELG1DQUFtQztRQUMxQixVQUFLLEdBQXlCLFNBQVMsQ0FBQTtLQVNqRDtJQVJDLDBDQUEwQztJQUMxQyxJQUFhLEtBQUssQ0FBQyxHQUFXO1FBQzVCLE1BQU0sT0FBTyxHQUFHLEdBQUcsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQTtRQUM3QyxJQUFJLENBQUMsU0FBUyxHQUFHLE9BQU8sQ0FBQTtRQUN4QixJQUFJLElBQUksQ0FBQyxLQUFLLEtBQUssVUFBVSxFQUFFO1lBQzdCLElBQUksQ0FBQyxXQUFXLEdBQUcsT0FBTyxDQUFBO1NBQzNCO0lBQ0gsQ0FBQzs7dUhBZlUsMEJBQTBCOzJHQUExQiwwQkFBMEIsNk5DWHZDLHlkQWtCQTsyRkRQYSwwQkFBMEI7a0JBSnRDLFNBQVM7K0JBQ0UscUJBQXFCOzhCQUlhLFdBQVc7c0JBQXRELFdBQVc7dUJBQUMscUJBQXFCO2dCQUNRLFNBQVM7c0JBQWxELFdBQVc7dUJBQUMsbUJBQW1CO2dCQUd2QixFQUFFO3NCQUFWLEtBQUs7Z0JBRUcsS0FBSztzQkFBYixLQUFLO2dCQUVPLEtBQUs7c0JBQWpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQge1xuICBjYWxjdWxhdGVEZWdyZWVzLFxuICBQcm9ncmVzc0NpcmNsZVRoZW1lcyxcbiAgcmFuZG9tSWQsXG59IGZyb20gJ0BzZWJncm91cC9leHRyYWN0J1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICduZ2ctcHJvZ3Jlc3MtY2lyY2xlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3Byb2dyZXNzLWNpcmNsZS5jb21wb25lbnQuaHRtbCcsXG59KVxuZXhwb3J0IGNsYXNzIE5nZ1Byb2dyZXNzQ2lyY2xlQ29tcG9uZW50IHtcbiAgQEhvc3RCaW5kaW5nKCdzdHlsZS4tLXN0YXJ0LXZhbHVlJykgcHJpdmF0ZSBfc3RhcnRWYWx1ZSA9ICcwZGVnJ1xuICBASG9zdEJpbmRpbmcoJ3N0eWxlLi0tZW5kLXZhbHVlJykgcHJpdmF0ZSBfZW5kVmFsdWUgPSAnMGRlZydcblxuICAvKiogaWQgb2YgdGhlIHByb2dyZXNzIGNpcmNsZSAqL1xuICBASW5wdXQoKSBpZD86IHN0cmluZyA9IGAke3JhbmRvbUlkKCl9LXByb2dyZXNzLWNpcmNsZWBcbiAgLyoqIHRoZW1lIG9mIHRoZSBwcm9ncmVzcyBjaXJjbGUgKi9cbiAgQElucHV0KCkgdGhlbWU6IFByb2dyZXNzQ2lyY2xlVGhlbWVzID0gJ3dhcm5pbmcnXG4gIC8qKiBwcm9ncmVzcyBjaXJjbGUgdmFsdWUgaW4gcGVyY2VudGFnZSAqL1xuICBASW5wdXQoKSBzZXQgdmFsdWUodmFsOiBudW1iZXIpIHtcbiAgICBjb25zdCBkZWdyZWVzID0gYCR7Y2FsY3VsYXRlRGVncmVlcyh2YWwpfWRlZ2BcbiAgICB0aGlzLl9lbmRWYWx1ZSA9IGRlZ3JlZXNcbiAgICBpZiAodGhpcy50aGVtZSA9PT0gJ2Rpc2FibGVkJykge1xuICAgICAgdGhpcy5fc3RhcnRWYWx1ZSA9IGRlZ3JlZXNcbiAgICB9XG4gIH1cbn1cbiIsIjxkaXZcbiAgY2xhc3M9XCJnZHMtcHJvZ3Jlc3MtY2lyY2xlXCJcbiAgcm9sZT1cInByb2dyZXNzYmFyXCJcbiAgW2F0dHIuYXJpYS12YWx1ZW5vd109XCJ2YWx1ZVwiXG4gIFthdHRyLmFyaWEtdmFsdWVtaW5dPVwiMFwiXG4gIFthdHRyLmFyaWEtdmFsdWVtYXhdPVwiMTAwXCJcbiAgW2F0dHIuYXJpYS1sYWJlbF09XCJpZFwiXG4+XG4gIDxkaXYgY2xhc3M9XCJyaW5nIGZ1bGwtcmluZ1wiPlxuICAgIDxkaXYgY2xhc3M9XCJyaW5nLXByb2dyZXNzXCIgW25nQ2xhc3NdPVwidGhlbWVcIj48L2Rpdj5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJyaW5nXCI+XG4gICAgPGRpdiBjbGFzcz1cInJpbmctcHJvZ3Jlc3NcIiBbbmdDbGFzc109XCJ0aGVtZVwiPjwvZGl2PlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cImlubmVyLWNpcmNsZVwiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3MtY2lyY2xlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvbGliL3Byb2dyZXNzLWNpcmNsZS9wcm9ncmVzcy1jaXJjbGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL3NyYy9saWIvcHJvZ3Jlc3MtY2lyY2xlL3Byb2dyZXNzLWNpcmNsZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDN0QsT0FBTyxFQUNMLGdCQUFnQixFQUVoQixRQUFRLEdBQ1QsTUFBTSxtQkFBbUIsQ0FBQTs7O0FBTTFCLE1BQU0sT0FBTywwQkFBMEI7SUFKdkM7UUFLOEMsZ0JBQVcsR0FBRyxNQUFNLENBQUE7UUFDdEIsY0FBUyxHQUFHLE1BQU0sQ0FBQTtRQUU1RCxnQ0FBZ0M7UUFDdkIsT0FBRSxHQUFZLEdBQUcsUUFBUSxFQUFFLGtCQUFrQixDQUFBO1FBQ3RELG1DQUFtQztRQUMxQixVQUFLLEdBQXlCLFNBQVMsQ0FBQTtLQVNqRDtJQVJDLDBDQUEwQztJQUMxQyxJQUFhLEtBQUssQ0FBQyxHQUFXO1FBQzVCLE1BQU0sT0FBTyxHQUFHLEdBQUcsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQTtRQUM3QyxJQUFJLENBQUMsU0FBUyxHQUFHLE9BQU8sQ0FBQTtRQUN4QixJQUFJLElBQUksQ0FBQyxLQUFLLEtBQUssVUFBVSxFQUFFO1lBQzdCLElBQUksQ0FBQyxXQUFXLEdBQUcsT0FBTyxDQUFBO1NBQzNCO0lBQ0gsQ0FBQzsrR0FmVSwwQkFBMEI7bUdBQTFCLDBCQUEwQiw2TkNYdkMseWRBa0JBOzs0RkRQYSwwQkFBMEI7a0JBSnRDLFNBQVM7K0JBQ0UscUJBQXFCOzhCQUlhLFdBQVc7c0JBQXRELFdBQVc7dUJBQUMscUJBQXFCO2dCQUNRLFNBQVM7c0JBQWxELFdBQVc7dUJBQUMsbUJBQW1CO2dCQUd2QixFQUFFO3NCQUFWLEtBQUs7Z0JBRUcsS0FBSztzQkFBYixLQUFLO2dCQUVPLEtBQUs7c0JBQWpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQge1xuICBjYWxjdWxhdGVEZWdyZWVzLFxuICBQcm9ncmVzc0NpcmNsZVRoZW1lcyxcbiAgcmFuZG9tSWQsXG59IGZyb20gJ0BzZWJncm91cC9leHRyYWN0J1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICduZ2ctcHJvZ3Jlc3MtY2lyY2xlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3Byb2dyZXNzLWNpcmNsZS5jb21wb25lbnQuaHRtbCcsXG59KVxuZXhwb3J0IGNsYXNzIE5nZ1Byb2dyZXNzQ2lyY2xlQ29tcG9uZW50IHtcbiAgQEhvc3RCaW5kaW5nKCdzdHlsZS4tLXN0YXJ0LXZhbHVlJykgcHJpdmF0ZSBfc3RhcnRWYWx1ZSA9ICcwZGVnJ1xuICBASG9zdEJpbmRpbmcoJ3N0eWxlLi0tZW5kLXZhbHVlJykgcHJpdmF0ZSBfZW5kVmFsdWUgPSAnMGRlZydcblxuICAvKiogaWQgb2YgdGhlIHByb2dyZXNzIGNpcmNsZSAqL1xuICBASW5wdXQoKSBpZD86IHN0cmluZyA9IGAke3JhbmRvbUlkKCl9LXByb2dyZXNzLWNpcmNsZWBcbiAgLyoqIHRoZW1lIG9mIHRoZSBwcm9ncmVzcyBjaXJjbGUgKi9cbiAgQElucHV0KCkgdGhlbWU6IFByb2dyZXNzQ2lyY2xlVGhlbWVzID0gJ3dhcm5pbmcnXG4gIC8qKiBwcm9ncmVzcyBjaXJjbGUgdmFsdWUgaW4gcGVyY2VudGFnZSAqL1xuICBASW5wdXQoKSBzZXQgdmFsdWUodmFsOiBudW1iZXIpIHtcbiAgICBjb25zdCBkZWdyZWVzID0gYCR7Y2FsY3VsYXRlRGVncmVlcyh2YWwpfWRlZ2BcbiAgICB0aGlzLl9lbmRWYWx1ZSA9IGRlZ3JlZXNcbiAgICBpZiAodGhpcy50aGVtZSA9PT0gJ2Rpc2FibGVkJykge1xuICAgICAgdGhpcy5fc3RhcnRWYWx1ZSA9IGRlZ3JlZXNcbiAgICB9XG4gIH1cbn1cbiIsIjxkaXZcbiAgY2xhc3M9XCJnZHMtcHJvZ3Jlc3MtY2lyY2xlXCJcbiAgcm9sZT1cInByb2dyZXNzYmFyXCJcbiAgW2F0dHIuYXJpYS12YWx1ZW5vd109XCJ2YWx1ZVwiXG4gIFthdHRyLmFyaWEtdmFsdWVtaW5dPVwiMFwiXG4gIFthdHRyLmFyaWEtdmFsdWVtYXhdPVwiMTAwXCJcbiAgW2F0dHIuYXJpYS1sYWJlbF09XCJpZFwiXG4+XG4gIDxkaXYgY2xhc3M9XCJyaW5nIGZ1bGwtcmluZ1wiPlxuICAgIDxkaXYgY2xhc3M9XCJyaW5nLXByb2dyZXNzXCIgW25nQ2xhc3NdPVwidGhlbWVcIj48L2Rpdj5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJyaW5nXCI+XG4gICAgPGRpdiBjbGFzcz1cInJpbmctcHJvZ3Jlc3NcIiBbbmdDbGFzc109XCJ0aGVtZVwiPjwvZGl2PlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cImlubmVyLWNpcmNsZVwiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==