@recursyve/nice-ui-kit.v2 15.0.0-beta.131 → 16.0.0-beta.134

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 (400) hide show
  1. package/esm2022/lib/animations/defaults.mjs +32 -0
  2. package/{esm2020 → esm2022}/lib/api/interceptors/transform-response.interceptor.mjs +4 -4
  3. package/{esm2020 → esm2022}/lib/components/alert/alert.component.mjs +4 -4
  4. package/{esm2020 → esm2022}/lib/components/alert/alert.module.mjs +9 -9
  5. package/{esm2020 → esm2022}/lib/components/alert/alert.service.mjs +4 -4
  6. package/esm2022/lib/components/assets-carousel/assets-carousel.component.mjs +283 -0
  7. package/{esm2020 → esm2022}/lib/components/assets-carousel/assets-carousel.module.mjs +19 -19
  8. package/{esm2020 → esm2022}/lib/components/assets-carousel/directives/assets-carousel-active-content.directive.mjs +4 -4
  9. package/esm2022/lib/components/async-typeahead/async-typeahead.component.mjs +451 -0
  10. package/{esm2020 → esm2022}/lib/components/async-typeahead/async-typeahead.module.mjs +21 -21
  11. package/{esm2020 → esm2022}/lib/components/async-typeahead/providers/async-typeahead.service.mjs +4 -4
  12. package/{esm2020 → esm2022}/lib/components/base-form/base-form.component.mjs +4 -4
  13. package/{esm2020 → esm2022}/lib/components/base-form/base-form.module.mjs +5 -5
  14. package/{esm2020 → esm2022}/lib/components/base-form/form-submit.directive.mjs +4 -4
  15. package/{esm2020 → esm2022}/lib/components/card/card.component.mjs +4 -4
  16. package/{esm2020 → esm2022}/lib/components/card/card.module.mjs +5 -5
  17. package/{esm2020 → esm2022}/lib/components/carousel/carousel.component.mjs +4 -4
  18. package/esm2022/lib/components/carousel/carousel.module.mjs +40 -0
  19. package/{esm2020 → esm2022}/lib/components/carousel/picture-modal/picture-modal.component.mjs +4 -4
  20. package/{esm2020 → esm2022}/lib/components/carousel/picture-modal/picture-modal.service.mjs +4 -4
  21. package/{esm2020 → esm2022}/lib/components/carousel/pipe/carousel-layout.pipe.mjs +4 -4
  22. package/{esm2020 → esm2022}/lib/components/collapsable/collapsable.component.mjs +4 -4
  23. package/{esm2020 → esm2022}/lib/components/collapsable/collapsable.module.mjs +7 -7
  24. package/{esm2020 → esm2022}/lib/components/date-range-picker/components/header/header.component.mjs +4 -4
  25. package/{esm2020 → esm2022}/lib/components/date-range-picker/components/range-preset/range-preset.component.mjs +4 -4
  26. package/esm2022/lib/components/date-range-picker/date-range-picker.component.mjs +95 -0
  27. package/{esm2020 → esm2022}/lib/components/date-range-picker/date-range-picker.module.mjs +21 -21
  28. package/{esm2020 → esm2022}/lib/components/date-range-picker/providers/date-range-picker.service.mjs +4 -4
  29. package/{esm2020 → esm2022}/lib/components/drawer/drawer.component.mjs +4 -4
  30. package/{esm2020 → esm2022}/lib/components/drawer/drawer.module.mjs +7 -7
  31. package/{esm2020 → esm2022}/lib/components/drawer/drawer.service.mjs +4 -4
  32. package/{esm2020 → esm2022}/lib/components/export-bottom-sheet/export-bottom-sheet.component.mjs +4 -4
  33. package/esm2022/lib/components/export-bottom-sheet/export-bottom-sheet.module.mjs +45 -0
  34. package/{esm2020 → esm2022}/lib/components/export-bottom-sheet/providers/export-bottom-sheet.service.mjs +7 -7
  35. package/{esm2020 → esm2022}/lib/components/form-error/control-status.directive.mjs +4 -4
  36. package/esm2022/lib/components/form-error/form-error.component.mjs +53 -0
  37. package/{esm2020 → esm2022}/lib/components/form-error/form-error.module.mjs +5 -5
  38. package/esm2022/lib/components/horizontal-stepper/horizontal-stepper.component.mjs +34 -0
  39. package/{esm2020 → esm2022}/lib/components/horizontal-stepper/horizontal-stepper.module.mjs +9 -9
  40. package/{esm2020 → esm2022}/lib/components/horizontal-stepper/step.component.mjs +6 -6
  41. package/esm2022/lib/components/image-cropper/image-cropper.component.mjs +1269 -0
  42. package/{esm2020 → esm2022}/lib/components/image-cropper/image-cropper.module.mjs +5 -5
  43. package/{esm2020 → esm2022}/lib/components/layout/layout.component.mjs +4 -4
  44. package/{esm2020 → esm2022}/lib/components/layout/layout.module.mjs +5 -5
  45. package/{esm2020 → esm2022}/lib/components/loading-spinner/loading-spinner.component.mjs +4 -4
  46. package/{esm2020 → esm2022}/lib/components/loading-spinner/loading-spinner.module.mjs +9 -9
  47. package/{esm2020 → esm2022}/lib/components/loading-spinner/loading.directive.mjs +4 -4
  48. package/{esm2020 → esm2022}/lib/components/loading-toast/loading-toast.component.mjs +4 -4
  49. package/{esm2020 → esm2022}/lib/components/loading-toast/loading-toast.directive.mjs +4 -4
  50. package/{esm2020 → esm2022}/lib/components/loading-toast/loading-toast.module.mjs +5 -5
  51. package/{esm2020 → esm2022}/lib/components/loading-toast/loading-toast.service.mjs +4 -4
  52. package/{esm2020 → esm2022}/lib/components/lottie/lottie.component.mjs +4 -4
  53. package/{esm2020 → esm2022}/lib/components/lottie/lottie.module.mjs +5 -5
  54. package/{esm2020 → esm2022}/lib/components/navigation/components/hint-component-base.mjs +4 -4
  55. package/{esm2020 → esm2022}/lib/components/navigation/directives/show-hint.directive.mjs +4 -4
  56. package/esm2022/lib/components/navigation/horizontal/components/basic/basic.component.mjs +62 -0
  57. package/{esm2020 → esm2022}/lib/components/navigation/horizontal/components/branch/branch.component.mjs +7 -7
  58. package/{esm2020 → esm2022}/lib/components/navigation/horizontal/components/divider/divider.component.mjs +4 -4
  59. package/{esm2020 → esm2022}/lib/components/navigation/horizontal/components/spacer/spacer.component.mjs +4 -4
  60. package/esm2022/lib/components/navigation/horizontal/horizontal.component.mjs +50 -0
  61. package/esm2022/lib/components/navigation/navigation.component.mjs +83 -0
  62. package/esm2022/lib/components/navigation/navigation.module.mjs +108 -0
  63. package/{esm2020 → esm2022}/lib/components/navigation/navigation.service.mjs +4 -4
  64. package/{esm2020 → esm2022}/lib/components/navigation/pipes/should-hide.pipe.mjs +4 -4
  65. package/{esm2020 → esm2022}/lib/components/navigation/pipes/should-show-hint.pipe.mjs +4 -4
  66. package/esm2022/lib/components/navigation/pipes/translate-with-context.pipe.mjs +25 -0
  67. package/{esm2020 → esm2022}/lib/components/navigation/providers/hint.service.mjs +4 -4
  68. package/esm2022/lib/components/navigation/providers/translation-context.service.mjs +16 -0
  69. package/{esm2020 → esm2022}/lib/components/navigation/vertical/components/aside/aside.component.mjs +6 -6
  70. package/esm2022/lib/components/navigation/vertical/components/basic/basic.component.mjs +76 -0
  71. package/{esm2020 → esm2022}/lib/components/navigation/vertical/components/collapsable/collapsable.component.mjs +8 -8
  72. package/{esm2020 → esm2022}/lib/components/navigation/vertical/components/divider/divider.component.mjs +4 -4
  73. package/esm2022/lib/components/navigation/vertical/components/group/group.component.mjs +75 -0
  74. package/{esm2020 → esm2022}/lib/components/navigation/vertical/components/spacer/spacer.component.mjs +4 -4
  75. package/esm2022/lib/components/navigation/vertical/vertical.component.mjs +599 -0
  76. package/esm2022/lib/components/search-bar/search-bar.component.mjs +76 -0
  77. package/{esm2020 → esm2022}/lib/components/search-bar/search-bar.module.mjs +13 -13
  78. package/{esm2020 → esm2022}/lib/components/sweet-alert/sweet-alert.component.mjs +4 -4
  79. package/{esm2020 → esm2022}/lib/components/sweet-alert/sweet-alert.directive.mjs +4 -4
  80. package/{esm2020 → esm2022}/lib/components/sweet-alert/sweet-alert.module.mjs +5 -5
  81. package/{esm2020 → esm2022}/lib/components/sweet-alert/sweet-alert.service.mjs +4 -4
  82. package/{esm2020 → esm2022}/lib/components/toast/toast.component.mjs +4 -4
  83. package/{esm2020 → esm2022}/lib/components/toast/toast.module.mjs +5 -5
  84. package/{esm2020 → esm2022}/lib/components/toast/toast.service.mjs +4 -4
  85. package/esm2022/lib/components/toggle-button-group/toggle-button-group.component.mjs +134 -0
  86. package/{esm2020 → esm2022}/lib/components/toggle-button-group/toggle-button-group.module.mjs +7 -7
  87. package/{esm2020 → esm2022}/lib/components/toggle-button-group/toggle-button.component.mjs +4 -4
  88. package/esm2022/lib/components/translation-form/components/textarea/translation-form-textarea.component.mjs +38 -0
  89. package/esm2022/lib/components/translation-form/components/textfield/translation-form-textfield.component.mjs +26 -0
  90. package/{esm2020 → esm2022}/lib/components/translation-form/components/translation-form.component.mjs +4 -4
  91. package/{esm2020 → esm2022}/lib/components/translation-form/components/translation-form.module.mjs +19 -19
  92. package/{esm2020 → esm2022}/lib/components/translation-form/directives/translation-context.directive.mjs +4 -4
  93. package/{esm2020 → esm2022}/lib/components/translation-form/providers/nice-translation-form.service.mjs +4 -4
  94. package/{esm2020 → esm2022}/lib/components/translation-form/toggle/translation-toggle.component.mjs +4 -4
  95. package/{esm2020 → esm2022}/lib/components/translation-form/validators/require-for-languages.validator.mjs +4 -4
  96. package/{esm2020 → esm2022}/lib/components/typeahead/directives/options-scroll.directive.mjs +4 -4
  97. package/{esm2020 → esm2022}/lib/components/typeahead/directives/options-scroll.module.mjs +5 -5
  98. package/{esm2020 → esm2022}/lib/components/typeahead/typeahead.component.mjs +9 -9
  99. package/{esm2020 → esm2022}/lib/components/typeahead/typeahead.module.mjs +25 -25
  100. package/{esm2020 → esm2022}/lib/directives/autofocus/autofocus.directive.mjs +4 -4
  101. package/{esm2020 → esm2022}/lib/directives/autofocus/autofocus.module.mjs +5 -5
  102. package/{esm2020 → esm2022}/lib/directives/autogrow/autogrow.directive.mjs +4 -4
  103. package/{esm2020 → esm2022}/lib/directives/autogrow/autogrow.module.mjs +5 -5
  104. package/{esm2020 → esm2022}/lib/directives/chip-async-typeahead/chip-async-typeahead.directive.mjs +4 -4
  105. package/{esm2020 → esm2022}/lib/directives/chip-list/chip-list-items/chip-list-item-label.directive.mjs +4 -4
  106. package/{esm2020 → esm2022}/lib/directives/chip-list/chip-list-items/chip-list-items.component.mjs +4 -4
  107. package/{esm2020 → esm2022}/lib/directives/chip-list/chip-list.directive.mjs +4 -4
  108. package/{esm2020 → esm2022}/lib/directives/chip-list/chip-list.module.mjs +5 -5
  109. package/{esm2020 → esm2022}/lib/directives/draggable-list/draggable-list.directive.mjs +4 -4
  110. package/{esm2020 → esm2022}/lib/directives/draggable-list/draggable-list.module.mjs +5 -5
  111. package/{esm2020 → esm2022}/lib/directives/dropzone/dropzone.directive.mjs +4 -4
  112. package/{esm2020 → esm2022}/lib/directives/dropzone/dropzone.module.mjs +5 -5
  113. package/{esm2020 → esm2022}/lib/directives/image-error-placeholder/image-error-placeholder.directive.mjs +4 -4
  114. package/{esm2020 → esm2022}/lib/directives/image-error-placeholder/image-error-placeholder.module.mjs +5 -5
  115. package/{esm2020 → esm2022}/lib/directives/material/material.module.mjs +7 -7
  116. package/{esm2020 → esm2022}/lib/directives/material/nice-material-style.directive.mjs +4 -4
  117. package/{esm2020 → esm2022}/lib/directives/material/nice-rounded-style.directive.mjs +4 -4
  118. package/{esm2020 → esm2022}/lib/directives/modals/modal-on-click.directive.mjs +4 -4
  119. package/{esm2020 → esm2022}/lib/directives/modals/modal-opener.directive.mjs +4 -4
  120. package/{esm2020 → esm2022}/lib/directives/rerender/rerender.directive.mjs +4 -4
  121. package/{esm2020 → esm2022}/lib/directives/resolve/resolve.directive.mjs +4 -4
  122. package/{esm2020 → esm2022}/lib/directives/scroll-reset/scroll-reset.directive.mjs +4 -4
  123. package/{esm2020 → esm2022}/lib/directives/scroll-reset/scroll-reset.module.mjs +5 -5
  124. package/{esm2020 → esm2022}/lib/directives/scrollbar/scrollbar.directive.mjs +4 -4
  125. package/{esm2020 → esm2022}/lib/directives/scrollbar/scrollbar.module.mjs +5 -5
  126. package/{esm2020 → esm2022}/lib/directives/stop-propagation/click-stop-propagation.directive.mjs +4 -4
  127. package/{esm2020 → esm2022}/lib/directives/stop-propagation/stop-propagation.module.mjs +5 -5
  128. package/{esm2020 → esm2022}/lib/directives/window/prevent-close-window.directive.mjs +4 -4
  129. package/{esm2020 → esm2022}/lib/directives/window/window-directive.module.mjs +5 -5
  130. package/esm2022/lib/nice.module.mjs +124 -0
  131. package/{esm2020 → esm2022}/lib/pipes/boolean.pipe.mjs +4 -4
  132. package/{esm2020 → esm2022}/lib/pipes/capitalize-first-letter.pipe.mjs +4 -4
  133. package/{esm2020 → esm2022}/lib/pipes/ceil.pipe.mjs +4 -4
  134. package/{esm2020 → esm2022}/lib/pipes/entries.pipe.mjs +4 -4
  135. package/{esm2020 → esm2022}/lib/pipes/find-by-key.pipe.mjs +4 -4
  136. package/{esm2020 → esm2022}/lib/pipes/first-letter.pipe.mjs +4 -4
  137. package/{esm2020 → esm2022}/lib/pipes/floor.pipe.mjs +4 -4
  138. package/{esm2020 → esm2022}/lib/pipes/join-if-defined.pipe.mjs +4 -4
  139. package/{esm2020 → esm2022}/lib/pipes/link.pipe.mjs +4 -4
  140. package/{esm2020 → esm2022}/lib/pipes/localized-boolean.pipe.mjs +4 -4
  141. package/{esm2020 → esm2022}/lib/pipes/localized-currency.pipe.mjs +4 -4
  142. package/{esm2020 → esm2022}/lib/pipes/localized-date-only.pipe.mjs +4 -4
  143. package/{esm2020 → esm2022}/lib/pipes/localized-date.pipe.mjs +4 -4
  144. package/{esm2020 → esm2022}/lib/pipes/minutes-to-time.pipe.mjs +4 -4
  145. package/{esm2020 → esm2022}/lib/pipes/number-to-ordinal-indicator.pipe.mjs +4 -4
  146. package/{esm2020 → esm2022}/lib/pipes/pad.pipe.mjs +4 -4
  147. package/{esm2020 → esm2022}/lib/pipes/phone.pipe.mjs +4 -4
  148. package/{esm2020 → esm2022}/lib/pipes/pipes.module.mjs +72 -72
  149. package/{esm2020 → esm2022}/lib/pipes/postal-code.pipe.mjs +4 -4
  150. package/{esm2020 → esm2022}/lib/pipes/range.pipe.mjs +4 -4
  151. package/{esm2020 → esm2022}/lib/pipes/round.pipe.mjs +4 -4
  152. package/{esm2020 → esm2022}/lib/pipes/sanitize-bypass.pipe.mjs +4 -4
  153. package/{esm2020 → esm2022}/lib/pipes/seconds-to-time.pipe.mjs +4 -4
  154. package/{esm2020 → esm2022}/lib/pipes/track-by-prop.pipe.mjs +4 -4
  155. package/{esm2020 → esm2022}/lib/providers/config/config.module.mjs +5 -5
  156. package/{esm2020 → esm2022}/lib/providers/config/config.service.mjs +4 -4
  157. package/{esm2020 → esm2022}/lib/providers/media-watcher/media-watcher.module.mjs +7 -7
  158. package/{esm2020 → esm2022}/lib/providers/media-watcher/media-watcher.service.mjs +4 -4
  159. package/{esm2020 → esm2022}/lib/providers/overlay/dynamic-overlay-container.service.mjs +4 -4
  160. package/{esm2020 → esm2022}/lib/providers/overlay/dynamic-overlay.service.mjs +4 -4
  161. package/{esm2020 → esm2022}/lib/providers/splash-screen/splash-screen.module.mjs +7 -7
  162. package/{esm2020 → esm2022}/lib/providers/splash-screen/splash-screen.service.mjs +4 -4
  163. package/{esm2020 → esm2022}/lib/providers/utils/utils.module.mjs +5 -5
  164. package/{esm2020 → esm2022}/lib/providers/utils/utils.service.mjs +4 -4
  165. package/esm2022/lib/utils/regex.utils.mjs +11 -0
  166. package/{fesm2020 → fesm2022}/recursyve-nice-ui-kit.v2.mjs +948 -905
  167. package/fesm2022/recursyve-nice-ui-kit.v2.mjs.map +1 -0
  168. package/lib/components/alert/alert.component.d.ts +1 -1
  169. package/lib/components/assets-carousel/assets-carousel.component.d.ts +1 -1
  170. package/lib/components/async-typeahead/async-typeahead.component.d.ts +1 -1
  171. package/lib/components/base-form/base-form.component.d.ts +1 -1
  172. package/lib/components/base-form/form-submit.directive.d.ts +1 -1
  173. package/lib/components/card/card.component.d.ts +1 -1
  174. package/lib/components/carousel/carousel.component.d.ts +1 -1
  175. package/lib/components/collapsable/collapsable.component.d.ts +1 -1
  176. package/lib/components/date-range-picker/date-range-picker.component.d.ts +1 -1
  177. package/lib/components/drawer/drawer.component.d.ts +1 -1
  178. package/lib/components/form-error/form-error.component.d.ts +1 -1
  179. package/lib/components/image-cropper/image-cropper.component.d.ts +2 -2
  180. package/lib/components/loading-spinner/loading-spinner.component.d.ts +1 -1
  181. package/lib/components/loading-spinner/loading.directive.d.ts +1 -1
  182. package/lib/components/loading-toast/loading-toast.component.d.ts +1 -1
  183. package/lib/components/loading-toast/loading-toast.directive.d.ts +1 -1
  184. package/lib/components/lottie/lottie.component.d.ts +1 -1
  185. package/lib/components/navigation/directives/show-hint.directive.d.ts +1 -1
  186. package/lib/components/navigation/horizontal/components/basic/basic.component.d.ts +1 -1
  187. package/lib/components/navigation/horizontal/components/branch/branch.component.d.ts +1 -1
  188. package/lib/components/navigation/horizontal/components/divider/divider.component.d.ts +1 -1
  189. package/lib/components/navigation/horizontal/components/spacer/spacer.component.d.ts +1 -1
  190. package/lib/components/navigation/horizontal/horizontal.component.d.ts +4 -2
  191. package/lib/components/navigation/navigation.component.d.ts +3 -1
  192. package/lib/components/navigation/navigation.module.d.ts +12 -11
  193. package/lib/components/navigation/pipes/translate-with-context.pipe.d.ts +12 -0
  194. package/lib/components/navigation/providers/translation-context.service.d.ts +8 -0
  195. package/lib/components/navigation/vertical/components/aside/aside.component.d.ts +1 -1
  196. package/lib/components/navigation/vertical/components/basic/basic.component.d.ts +1 -1
  197. package/lib/components/navigation/vertical/components/collapsable/collapsable.component.d.ts +1 -1
  198. package/lib/components/navigation/vertical/components/divider/divider.component.d.ts +1 -1
  199. package/lib/components/navigation/vertical/components/group/group.component.d.ts +1 -1
  200. package/lib/components/navigation/vertical/components/spacer/spacer.component.d.ts +1 -1
  201. package/lib/components/navigation/vertical/vertical.component.d.ts +4 -2
  202. package/lib/components/search-bar/search-bar.component.d.ts +1 -1
  203. package/lib/components/sweet-alert/sweet-alert.directive.d.ts +1 -1
  204. package/lib/components/toggle-button-group/toggle-button-group.component.d.ts +1 -1
  205. package/lib/components/toggle-button-group/toggle-button.component.d.ts +1 -1
  206. package/lib/components/translation-form/components/textarea/translation-form-textarea.component.d.ts +1 -1
  207. package/lib/components/translation-form/components/translation-form.component.d.ts +1 -1
  208. package/lib/components/translation-form/validators/require-for-languages.validator.d.ts +1 -1
  209. package/lib/components/typeahead/directives/options-scroll.directive.d.ts +1 -1
  210. package/lib/components/typeahead/typeahead.component.d.ts +1 -1
  211. package/lib/directives/autogrow/autogrow.directive.d.ts +1 -1
  212. package/lib/directives/chip-list/chip-list-items/chip-list-items.component.d.ts +1 -1
  213. package/lib/directives/chip-list/chip-list.directive.d.ts +1 -1
  214. package/lib/directives/draggable-list/draggable-list.directive.d.ts +1 -1
  215. package/lib/directives/image-error-placeholder/image-error-placeholder.directive.d.ts +1 -1
  216. package/lib/directives/modals/modal-opener.directive.d.ts +1 -1
  217. package/lib/directives/rerender/rerender.directive.d.ts +1 -1
  218. package/lib/directives/resolve/resolve.directive.d.ts +1 -1
  219. package/lib/directives/scrollbar/scrollbar.directive.d.ts +1 -1
  220. package/package.json +12 -19
  221. package/esm2020/lib/animations/defaults.mjs +0 -32
  222. package/esm2020/lib/components/assets-carousel/assets-carousel.component.mjs +0 -283
  223. package/esm2020/lib/components/async-typeahead/async-typeahead.component.mjs +0 -451
  224. package/esm2020/lib/components/carousel/carousel.module.mjs +0 -41
  225. package/esm2020/lib/components/date-range-picker/date-range-picker.component.mjs +0 -95
  226. package/esm2020/lib/components/export-bottom-sheet/export-bottom-sheet.module.mjs +0 -45
  227. package/esm2020/lib/components/form-error/form-error.component.mjs +0 -53
  228. package/esm2020/lib/components/horizontal-stepper/horizontal-stepper.component.mjs +0 -34
  229. package/esm2020/lib/components/image-cropper/image-cropper.component.mjs +0 -1269
  230. package/esm2020/lib/components/navigation/horizontal/components/basic/basic.component.mjs +0 -62
  231. package/esm2020/lib/components/navigation/horizontal/horizontal.component.mjs +0 -46
  232. package/esm2020/lib/components/navigation/navigation.component.mjs +0 -76
  233. package/esm2020/lib/components/navigation/navigation.module.mjs +0 -105
  234. package/esm2020/lib/components/navigation/vertical/components/basic/basic.component.mjs +0 -76
  235. package/esm2020/lib/components/navigation/vertical/components/group/group.component.mjs +0 -75
  236. package/esm2020/lib/components/navigation/vertical/vertical.component.mjs +0 -595
  237. package/esm2020/lib/components/search-bar/search-bar.component.mjs +0 -76
  238. package/esm2020/lib/components/toggle-button-group/toggle-button-group.component.mjs +0 -134
  239. package/esm2020/lib/components/translation-form/components/textarea/translation-form-textarea.component.mjs +0 -38
  240. package/esm2020/lib/components/translation-form/components/textfield/translation-form-textfield.component.mjs +0 -26
  241. package/esm2020/lib/nice.module.mjs +0 -124
  242. package/esm2020/lib/utils/regex.utils.mjs +0 -11
  243. package/fesm2015/recursyve-nice-ui-kit.v2.mjs +0 -11867
  244. package/fesm2015/recursyve-nice-ui-kit.v2.mjs.map +0 -1
  245. package/fesm2020/recursyve-nice-ui-kit.v2.mjs.map +0 -1
  246. /package/{esm2020 → esm2022}/lib/animations/expand-collapse.mjs +0 -0
  247. /package/{esm2020 → esm2022}/lib/animations/fade.mjs +0 -0
  248. /package/{esm2020 → esm2022}/lib/animations/index.mjs +0 -0
  249. /package/{esm2020 → esm2022}/lib/animations/public-api.mjs +0 -0
  250. /package/{esm2020 → esm2022}/lib/animations/shake.mjs +0 -0
  251. /package/{esm2020 → esm2022}/lib/animations/slide.mjs +0 -0
  252. /package/{esm2020 → esm2022}/lib/animations/zoom.mjs +0 -0
  253. /package/{esm2020 → esm2022}/lib/api/exceptions/api.exception.mjs +0 -0
  254. /package/{esm2020 → esm2022}/lib/api/exceptions/exception.factory.mjs +0 -0
  255. /package/{esm2020 → esm2022}/lib/api/index.mjs +0 -0
  256. /package/{esm2020 → esm2022}/lib/api/nice.api.mjs +0 -0
  257. /package/{esm2020 → esm2022}/lib/api/public-api.mjs +0 -0
  258. /package/{esm2020 → esm2022}/lib/components/alert/alert.types.mjs +0 -0
  259. /package/{esm2020 → esm2022}/lib/components/alert/index.mjs +0 -0
  260. /package/{esm2020 → esm2022}/lib/components/alert/public-api.mjs +0 -0
  261. /package/{esm2020 → esm2022}/lib/components/assets-carousel/assets-carousel.constant.mjs +0 -0
  262. /package/{esm2020 → esm2022}/lib/components/assets-carousel/index.mjs +0 -0
  263. /package/{esm2020 → esm2022}/lib/components/assets-carousel/public-api.mjs +0 -0
  264. /package/{esm2020 → esm2022}/lib/components/async-typeahead/async-typeahead.constant.mjs +0 -0
  265. /package/{esm2020 → esm2022}/lib/components/async-typeahead/index.mjs +0 -0
  266. /package/{esm2020 → esm2022}/lib/components/async-typeahead/providers/async-typeahead.provider.mjs +0 -0
  267. /package/{esm2020 → esm2022}/lib/components/async-typeahead/public-api.mjs +0 -0
  268. /package/{esm2020 → esm2022}/lib/components/base-form/index.mjs +0 -0
  269. /package/{esm2020 → esm2022}/lib/components/base-form/nice-base.form.mjs +0 -0
  270. /package/{esm2020 → esm2022}/lib/components/base-form/public-api.mjs +0 -0
  271. /package/{esm2020 → esm2022}/lib/components/card/card.types.mjs +0 -0
  272. /package/{esm2020 → esm2022}/lib/components/card/index.mjs +0 -0
  273. /package/{esm2020 → esm2022}/lib/components/card/public-api.mjs +0 -0
  274. /package/{esm2020 → esm2022}/lib/components/carousel/index.mjs +0 -0
  275. /package/{esm2020 → esm2022}/lib/components/carousel/picture-modal/index.mjs +0 -0
  276. /package/{esm2020 → esm2022}/lib/components/carousel/picture-modal/public-api.mjs +0 -0
  277. /package/{esm2020 → esm2022}/lib/components/carousel/public-api.mjs +0 -0
  278. /package/{esm2020 → esm2022}/lib/components/collapsable/index.mjs +0 -0
  279. /package/{esm2020 → esm2022}/lib/components/collapsable/public-api.mjs +0 -0
  280. /package/{esm2020 → esm2022}/lib/components/date-range-picker/index.mjs +0 -0
  281. /package/{esm2020 → esm2022}/lib/components/date-range-picker/public-api.mjs +0 -0
  282. /package/{esm2020 → esm2022}/lib/components/drawer/drawer.types.mjs +0 -0
  283. /package/{esm2020 → esm2022}/lib/components/drawer/index.mjs +0 -0
  284. /package/{esm2020 → esm2022}/lib/components/drawer/public-api.mjs +0 -0
  285. /package/{esm2020 → esm2022}/lib/components/export-bottom-sheet/index.mjs +0 -0
  286. /package/{esm2020 → esm2022}/lib/components/export-bottom-sheet/models/export-strategy.model.mjs +0 -0
  287. /package/{esm2020 → esm2022}/lib/components/export-bottom-sheet/public-api.mjs +0 -0
  288. /package/{esm2020 → esm2022}/lib/components/form-error/index.mjs +0 -0
  289. /package/{esm2020 → esm2022}/lib/components/form-error/public-api.mjs +0 -0
  290. /package/{esm2020 → esm2022}/lib/components/horizontal-stepper/index.mjs +0 -0
  291. /package/{esm2020 → esm2022}/lib/components/horizontal-stepper/public-api.mjs +0 -0
  292. /package/{esm2020 → esm2022}/lib/components/image-cropper/index.mjs +0 -0
  293. /package/{esm2020 → esm2022}/lib/components/image-cropper/public-api.mjs +0 -0
  294. /package/{esm2020 → esm2022}/lib/components/image-cropper/resize-canvas.mjs +0 -0
  295. /package/{esm2020 → esm2022}/lib/components/index.mjs +0 -0
  296. /package/{esm2020 → esm2022}/lib/components/layout/index.mjs +0 -0
  297. /package/{esm2020 → esm2022}/lib/components/layout/public-api.mjs +0 -0
  298. /package/{esm2020 → esm2022}/lib/components/loading-spinner/index.mjs +0 -0
  299. /package/{esm2020 → esm2022}/lib/components/loading-spinner/loading.constant.mjs +0 -0
  300. /package/{esm2020 → esm2022}/lib/components/loading-spinner/public-api.mjs +0 -0
  301. /package/{esm2020 → esm2022}/lib/components/loading-toast/index.mjs +0 -0
  302. /package/{esm2020 → esm2022}/lib/components/loading-toast/loading-toast.constant.mjs +0 -0
  303. /package/{esm2020 → esm2022}/lib/components/loading-toast/public-api.mjs +0 -0
  304. /package/{esm2020 → esm2022}/lib/components/loading-toast/rxjs/show-loading-toast.operator.mjs +0 -0
  305. /package/{esm2020 → esm2022}/lib/components/lottie/index.mjs +0 -0
  306. /package/{esm2020 → esm2022}/lib/components/lottie/public-api.mjs +0 -0
  307. /package/{esm2020 → esm2022}/lib/components/navigation/index.mjs +0 -0
  308. /package/{esm2020 → esm2022}/lib/components/navigation/navigation.types.mjs +0 -0
  309. /package/{esm2020 → esm2022}/lib/components/navigation/providers/hide-item.resolver.mjs +0 -0
  310. /package/{esm2020 → esm2022}/lib/components/navigation/providers/hint.resolver.mjs +0 -0
  311. /package/{esm2020 → esm2022}/lib/components/navigation/public-api.mjs +0 -0
  312. /package/{esm2020 → esm2022}/lib/components/public-api.mjs +0 -0
  313. /package/{esm2020 → esm2022}/lib/components/search-bar/index.mjs +0 -0
  314. /package/{esm2020 → esm2022}/lib/components/search-bar/public-api.mjs +0 -0
  315. /package/{esm2020 → esm2022}/lib/components/sweet-alert/index.mjs +0 -0
  316. /package/{esm2020 → esm2022}/lib/components/sweet-alert/public-api.mjs +0 -0
  317. /package/{esm2020 → esm2022}/lib/components/sweet-alert/sweet-alert.constant.mjs +0 -0
  318. /package/{esm2020 → esm2022}/lib/components/toast/index.mjs +0 -0
  319. /package/{esm2020 → esm2022}/lib/components/toast/public-api.mjs +0 -0
  320. /package/{esm2020 → esm2022}/lib/components/toast/rxjs/show-success-or-error-toast.operator.mjs +0 -0
  321. /package/{esm2020 → esm2022}/lib/components/toast/rxjs/show-toast.operator.mjs +0 -0
  322. /package/{esm2020 → esm2022}/lib/components/toast/toast.constant.mjs +0 -0
  323. /package/{esm2020 → esm2022}/lib/components/toggle-button-group/index.mjs +0 -0
  324. /package/{esm2020 → esm2022}/lib/components/toggle-button-group/public-api.mjs +0 -0
  325. /package/{esm2020 → esm2022}/lib/components/translation-form/decorators/translation-form-group.decorator.mjs +0 -0
  326. /package/{esm2020 → esm2022}/lib/components/translation-form/index.mjs +0 -0
  327. /package/{esm2020 → esm2022}/lib/components/translation-form/public-api.mjs +0 -0
  328. /package/{esm2020 → esm2022}/lib/components/translation-form/translation.form.mjs +0 -0
  329. /package/{esm2020 → esm2022}/lib/components/typeahead/index.mjs +0 -0
  330. /package/{esm2020 → esm2022}/lib/components/typeahead/public-api.mjs +0 -0
  331. /package/{esm2020 → esm2022}/lib/directives/autofocus/index.mjs +0 -0
  332. /package/{esm2020 → esm2022}/lib/directives/autofocus/public-api.mjs +0 -0
  333. /package/{esm2020 → esm2022}/lib/directives/autogrow/index.mjs +0 -0
  334. /package/{esm2020 → esm2022}/lib/directives/autogrow/public-api.mjs +0 -0
  335. /package/{esm2020 → esm2022}/lib/directives/chip-async-typeahead/index.mjs +0 -0
  336. /package/{esm2020 → esm2022}/lib/directives/chip-async-typeahead/public-api.mjs +0 -0
  337. /package/{esm2020 → esm2022}/lib/directives/chip-list/chip-list.constant.mjs +0 -0
  338. /package/{esm2020 → esm2022}/lib/directives/chip-list/index.mjs +0 -0
  339. /package/{esm2020 → esm2022}/lib/directives/chip-list/public-api.mjs +0 -0
  340. /package/{esm2020 → esm2022}/lib/directives/draggable-list/index.mjs +0 -0
  341. /package/{esm2020 → esm2022}/lib/directives/draggable-list/public-api.mjs +0 -0
  342. /package/{esm2020 → esm2022}/lib/directives/dropzone/index.mjs +0 -0
  343. /package/{esm2020 → esm2022}/lib/directives/dropzone/public-api.mjs +0 -0
  344. /package/{esm2020 → esm2022}/lib/directives/image-error-placeholder/index.mjs +0 -0
  345. /package/{esm2020 → esm2022}/lib/directives/image-error-placeholder/public-api.mjs +0 -0
  346. /package/{esm2020 → esm2022}/lib/directives/index.mjs +0 -0
  347. /package/{esm2020 → esm2022}/lib/directives/material/index.mjs +0 -0
  348. /package/{esm2020 → esm2022}/lib/directives/material/public-api.mjs +0 -0
  349. /package/{esm2020 → esm2022}/lib/directives/modals/index.mjs +0 -0
  350. /package/{esm2020 → esm2022}/lib/directives/modals/public-api.mjs +0 -0
  351. /package/{esm2020 → esm2022}/lib/directives/public-api.mjs +0 -0
  352. /package/{esm2020 → esm2022}/lib/directives/rerender/index.mjs +0 -0
  353. /package/{esm2020 → esm2022}/lib/directives/rerender/public-api.mjs +0 -0
  354. /package/{esm2020 → esm2022}/lib/directives/resolve/index.mjs +0 -0
  355. /package/{esm2020 → esm2022}/lib/directives/resolve/public-api.mjs +0 -0
  356. /package/{esm2020 → esm2022}/lib/directives/scroll-reset/index.mjs +0 -0
  357. /package/{esm2020 → esm2022}/lib/directives/scroll-reset/public-api.mjs +0 -0
  358. /package/{esm2020 → esm2022}/lib/directives/scrollbar/index.mjs +0 -0
  359. /package/{esm2020 → esm2022}/lib/directives/scrollbar/public-api.mjs +0 -0
  360. /package/{esm2020 → esm2022}/lib/directives/scrollbar/scrollbar.types.mjs +0 -0
  361. /package/{esm2020 → esm2022}/lib/directives/stop-propagation/index.mjs +0 -0
  362. /package/{esm2020 → esm2022}/lib/directives/stop-propagation/public-api.mjs +0 -0
  363. /package/{esm2020 → esm2022}/lib/directives/window/index.mjs +0 -0
  364. /package/{esm2020 → esm2022}/lib/directives/window/public-api.mjs +0 -0
  365. /package/{esm2020 → esm2022}/lib/pipes/index.mjs +0 -0
  366. /package/{esm2020 → esm2022}/lib/pipes/public-api.mjs +0 -0
  367. /package/{esm2020 → esm2022}/lib/providers/config/config.constants.mjs +0 -0
  368. /package/{esm2020 → esm2022}/lib/providers/config/config.model.mjs +0 -0
  369. /package/{esm2020 → esm2022}/lib/providers/config/index.mjs +0 -0
  370. /package/{esm2020 → esm2022}/lib/providers/config/public-api.mjs +0 -0
  371. /package/{esm2020 → esm2022}/lib/providers/index.mjs +0 -0
  372. /package/{esm2020 → esm2022}/lib/providers/media-watcher/index.mjs +0 -0
  373. /package/{esm2020 → esm2022}/lib/providers/media-watcher/public-api.mjs +0 -0
  374. /package/{esm2020 → esm2022}/lib/providers/public-api.mjs +0 -0
  375. /package/{esm2020 → esm2022}/lib/providers/splash-screen/index.mjs +0 -0
  376. /package/{esm2020 → esm2022}/lib/providers/splash-screen/public-api.mjs +0 -0
  377. /package/{esm2020 → esm2022}/lib/providers/utils/index.mjs +0 -0
  378. /package/{esm2020 → esm2022}/lib/providers/utils/public-api.mjs +0 -0
  379. /package/{esm2020 → esm2022}/lib/types/constructor.mjs +0 -0
  380. /package/{esm2020 → esm2022}/lib/utils/array.utils.mjs +0 -0
  381. /package/{esm2020 → esm2022}/lib/utils/case.utils.mjs +0 -0
  382. /package/{esm2020 → esm2022}/lib/utils/colors.utils.mjs +0 -0
  383. /package/{esm2020 → esm2022}/lib/utils/date.utils.mjs +0 -0
  384. /package/{esm2020 → esm2022}/lib/utils/file.utils.mjs +0 -0
  385. /package/{esm2020 → esm2022}/lib/utils/font-awesome.utils.mjs +0 -0
  386. /package/{esm2020 → esm2022}/lib/utils/form-data.utils.mjs +0 -0
  387. /package/{esm2020 → esm2022}/lib/utils/http-status.utils.mjs +0 -0
  388. /package/{esm2020 → esm2022}/lib/utils/index.mjs +0 -0
  389. /package/{esm2020 → esm2022}/lib/utils/keyboard.utils.mjs +0 -0
  390. /package/{esm2020 → esm2022}/lib/utils/lexorank.utils.mjs +0 -0
  391. /package/{esm2020 → esm2022}/lib/utils/modal.utils.mjs +0 -0
  392. /package/{esm2020 → esm2022}/lib/utils/number.utils.mjs +0 -0
  393. /package/{esm2020 → esm2022}/lib/utils/object.utils.mjs +0 -0
  394. /package/{esm2020 → esm2022}/lib/utils/promise.utils.mjs +0 -0
  395. /package/{esm2020 → esm2022}/lib/utils/public-api.mjs +0 -0
  396. /package/{esm2020 → esm2022}/lib/utils/query-params.utils.mjs +0 -0
  397. /package/{esm2020 → esm2022}/lib/utils/type.utils.mjs +0 -0
  398. /package/{esm2020 → esm2022}/lib/utils/url.utils.mjs +0 -0
  399. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
  400. /package/{esm2020 → esm2022}/recursyve-nice-ui-kit.v2.mjs +0 -0
@@ -0,0 +1,599 @@
1
+ import { animate, AnimationBuilder, style } from "@angular/animations";
2
+ import { coerceBooleanProperty } from "@angular/cdk/coercion";
3
+ import { ScrollStrategyOptions } from "@angular/cdk/overlay";
4
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output, QueryList, Renderer2, ViewChild, ViewChildren, ViewEncapsulation } from "@angular/core";
5
+ import { NavigationEnd, Router } from "@angular/router";
6
+ import { merge, ReplaySubject } from "rxjs";
7
+ import { delay, filter, takeUntil } from "rxjs/operators";
8
+ import { niceAnimations } from "../../../animations";
9
+ import { NiceScrollbarDirective } from "../../../directives/scrollbar";
10
+ import { NiceUtilsService } from "../../../providers/utils";
11
+ import { NiceNavigationComponent } from "../navigation.component";
12
+ import { NiceNavigationService } from "../navigation.service";
13
+ import { NiceNavigationHintService } from "../providers/hint.service";
14
+ import { NiceTranslationContextService } from "../providers/translation-context.service";
15
+ import * as i0 from "@angular/core";
16
+ import * as i1 from "../navigation.service";
17
+ import * as i2 from "../../../providers/utils";
18
+ import * as i3 from "../providers/translation-context.service";
19
+ import * as i4 from "@angular/animations";
20
+ import * as i5 from "@angular/router";
21
+ import * as i6 from "@angular/cdk/overlay";
22
+ import * as i7 from "../providers/hint.service";
23
+ import * as i8 from "@angular/common";
24
+ import * as i9 from "../../../directives/scrollbar/scrollbar.directive";
25
+ import * as i10 from "./components/aside/aside.component";
26
+ import * as i11 from "./components/basic/basic.component";
27
+ import * as i12 from "./components/collapsable/collapsable.component";
28
+ import * as i13 from "./components/divider/divider.component";
29
+ import * as i14 from "./components/group/group.component";
30
+ import * as i15 from "./components/spacer/spacer.component";
31
+ import * as i16 from "../pipes/should-hide.pipe";
32
+ export class NiceVerticalNavigationComponent extends NiceNavigationComponent {
33
+ set navigation(navigation) {
34
+ this._navigation = navigation;
35
+ this._changeDetectorRef.markForCheck();
36
+ }
37
+ get navigation() {
38
+ return this._navigation;
39
+ }
40
+ set forceHovered(forceHovered) {
41
+ this._forceHovered = forceHovered;
42
+ this.hoveredChanged.next((this.hovered || this._forceHovered) || this.hasHint);
43
+ this._changeDetectorRef.markForCheck();
44
+ }
45
+ /**
46
+ * Constructor
47
+ */
48
+ constructor(_changeDetectorRef, _niceNavigationService, _niceUtilsService, _translationContextService, _animationBuilder, _elementRef, _renderer2, _router, _scrollStrategyOptions, _hintService) {
49
+ super(_changeDetectorRef, _niceNavigationService, _niceUtilsService, _translationContextService);
50
+ this._animationBuilder = _animationBuilder;
51
+ this._elementRef = _elementRef;
52
+ this._renderer2 = _renderer2;
53
+ this._router = _router;
54
+ this._scrollStrategyOptions = _scrollStrategyOptions;
55
+ this._hintService = _hintService;
56
+ this._forceHovered = false;
57
+ this._animationsEnabled = false;
58
+ this._scrollStrategy = this._scrollStrategyOptions.block();
59
+ this.name = this._niceUtilsService.randomId();
60
+ this.appearance = "default";
61
+ this.autoCollapse = true;
62
+ this.inner = false;
63
+ this.mode = "side";
64
+ this.opened = true;
65
+ this.hovered = false;
66
+ this.hasHint = false;
67
+ this.position = "left";
68
+ this.showTooltips = false;
69
+ this.transparentOverlay = false;
70
+ this.tooltipPosition = "after";
71
+ this.appearanceChanged = new EventEmitter();
72
+ this.modeChanged = new EventEmitter();
73
+ this.openedChanged = new EventEmitter();
74
+ this.hoveredChanged = new EventEmitter();
75
+ this.positionChanged = new EventEmitter();
76
+ this.activeAsideItemId = null;
77
+ this.onCollapsableItemCollapsed = new ReplaySubject(1);
78
+ this.onCollapsableItemExpanded = new ReplaySubject(1);
79
+ this._handleAsideOverlayClick = () => {
80
+ this.closeAside();
81
+ };
82
+ this._handleOverlayClick = () => {
83
+ this.close();
84
+ };
85
+ }
86
+ // -----------------------------------------------------------------------------------------------------
87
+ // @ Accessors
88
+ // -----------------------------------------------------------------------------------------------------
89
+ /**
90
+ * Host binding for component classes
91
+ */
92
+ get classList() {
93
+ return {
94
+ "nice-vertical-navigation-animations-enabled": this._animationsEnabled,
95
+ [`nice-vertical-navigation-appearance-${this.appearance}`]: true,
96
+ "nice-vertical-navigation-hover": this.hovered || this._forceHovered,
97
+ "nice-vertical-navigation-inner": this.inner,
98
+ "nice-vertical-navigation-mode-over": this.mode === "over",
99
+ "nice-vertical-navigation-mode-side": this.mode === "side",
100
+ "nice-vertical-navigation-opened": this.opened,
101
+ "nice-vertical-navigation-position-left": this.position === "left",
102
+ "nice-vertical-navigation-position-right": this.position === "right",
103
+ "nice-vertical-navigation-has-hint": this.hasHint
104
+ };
105
+ }
106
+ /**
107
+ * Host binding for component inline styles
108
+ */
109
+ get styleList() {
110
+ return {
111
+ "visibility": this.opened ? "visible" : "hidden"
112
+ };
113
+ }
114
+ /**
115
+ * Setter for niceScrollbarDirectives
116
+ */
117
+ set niceScrollbarDirectives(niceScrollbarDirectives) {
118
+ // Store the directives
119
+ this._niceScrollbarDirectives = niceScrollbarDirectives;
120
+ // Return if there are no directives
121
+ if (niceScrollbarDirectives.length === 0) {
122
+ return;
123
+ }
124
+ // Unsubscribe the previous subscriptions
125
+ if (this._niceScrollbarDirectivesSubscription) {
126
+ this._niceScrollbarDirectivesSubscription.unsubscribe();
127
+ }
128
+ // Update the scrollbars on collapsable items' collapse/expand
129
+ this._niceScrollbarDirectivesSubscription =
130
+ merge(this.onCollapsableItemCollapsed, this.onCollapsableItemExpanded)
131
+ .pipe(takeUntil(this._unsubscribeAll), delay(250))
132
+ .subscribe(() => {
133
+ // Loop through the scrollbars and update them
134
+ niceScrollbarDirectives.forEach((niceScrollbarDirective) => {
135
+ niceScrollbarDirective.update();
136
+ });
137
+ });
138
+ }
139
+ // -----------------------------------------------------------------------------------------------------
140
+ // @ Lifecycle hooks
141
+ // -----------------------------------------------------------------------------------------------------
142
+ /**
143
+ * On changes
144
+ *
145
+ * @param changes
146
+ */
147
+ ngOnChanges(changes) {
148
+ super.ngOnChanges(changes);
149
+ // Appearance
150
+ if ("appearance" in changes) {
151
+ // Execute the observable
152
+ this.appearanceChanged.next(changes.appearance.currentValue);
153
+ }
154
+ // Inner
155
+ if ("inner" in changes) {
156
+ // Coerce the value to a boolean
157
+ this.inner = coerceBooleanProperty(changes.inner.currentValue);
158
+ }
159
+ // Mode
160
+ if ("mode" in changes) {
161
+ // Get the previous and current values
162
+ const currentMode = changes.mode.currentValue;
163
+ const previousMode = changes.mode.previousValue;
164
+ // Disable the animations
165
+ this._disableAnimations();
166
+ // If the mode changes: 'over -> side'
167
+ if (previousMode === "over" && currentMode === "side") {
168
+ // Hide the overlay
169
+ this._hideOverlay();
170
+ }
171
+ // If the mode changes: 'side -> over'
172
+ if (previousMode === "side" && currentMode === "over") {
173
+ // Close the aside
174
+ this.closeAside();
175
+ // If the navigation is opened
176
+ if (this.opened) {
177
+ // Show the overlay
178
+ this._showOverlay();
179
+ }
180
+ }
181
+ // Execute the observable
182
+ this.modeChanged.next(currentMode);
183
+ // Enable the animations after a delay
184
+ // The delay must be bigger than the current transition-duration
185
+ // to make sure nothing will be animated while the mode changing
186
+ setTimeout(() => {
187
+ this._enableAnimations();
188
+ }, 500);
189
+ }
190
+ // Opened
191
+ if ("opened" in changes) {
192
+ // Coerce the value to a boolean
193
+ this.opened = coerceBooleanProperty(changes.opened.currentValue);
194
+ // Open/close the navigation
195
+ this._toggleOpened(this.opened);
196
+ }
197
+ // Position
198
+ if ("position" in changes) {
199
+ // Execute the observable
200
+ this.positionChanged.next(changes.position.currentValue);
201
+ }
202
+ // Transparent overlay
203
+ if ("transparentOverlay" in changes) {
204
+ // Coerce the value to a boolean
205
+ this.transparentOverlay = coerceBooleanProperty(changes.transparentOverlay.currentValue);
206
+ }
207
+ }
208
+ /**
209
+ * On init
210
+ */
211
+ ngOnInit() {
212
+ super.ngOnInit();
213
+ // Make sure the name input is not an empty string
214
+ if (this.name === "") {
215
+ this.name = this._niceUtilsService.randomId();
216
+ }
217
+ // Subscribe to the 'NavigationEnd' event
218
+ this._router.events
219
+ .pipe(filter(event => event instanceof NavigationEnd), takeUntil(this._unsubscribeAll))
220
+ .subscribe(() => {
221
+ // If the mode is 'over' and the navigation is opened...
222
+ if (this.mode === "over" && this.opened) {
223
+ // Close the navigation
224
+ this.close();
225
+ }
226
+ // If the mode is 'side' and the aside is active...
227
+ if (this.mode === "side" && this.activeAsideItemId) {
228
+ // Close the aside
229
+ this.closeAside();
230
+ }
231
+ });
232
+ this._hintService.hasActiveHint$.pipe(takeUntil(this._unsubscribeAll)).subscribe(hasHint => {
233
+ this.hasHint = hasHint;
234
+ this.hoveredChanged.next((this.hovered || this._forceHovered) || this.hasHint);
235
+ });
236
+ }
237
+ /**
238
+ * After view init
239
+ */
240
+ ngAfterViewInit() {
241
+ setTimeout(() => {
242
+ // Return if 'navigation content' element does not exist
243
+ if (!this._navigationContentEl) {
244
+ return;
245
+ }
246
+ // If 'navigation content' element doesn't have
247
+ // perfect scrollbar activated on it...
248
+ if (!this._navigationContentEl.nativeElement.classList.contains("ps")) {
249
+ // Find the active item
250
+ const activeItem = this._navigationContentEl.nativeElement.querySelector(".nice-vertical-navigation-item-active");
251
+ // If the active item exists, scroll it into view
252
+ if (activeItem) {
253
+ activeItem.scrollIntoView();
254
+ }
255
+ }
256
+ // Otherwise
257
+ else {
258
+ // Go through all the scrollbar directives
259
+ this._niceScrollbarDirectives.forEach((niceScrollbarDirective) => {
260
+ // Skip if not enabled
261
+ if (!niceScrollbarDirective.isEnabled()) {
262
+ return;
263
+ }
264
+ // Scroll to the active element
265
+ niceScrollbarDirective.scrollToElement(".nice-vertical-navigation-item-active", -120, true);
266
+ });
267
+ }
268
+ });
269
+ }
270
+ // -----------------------------------------------------------------------------------------------------
271
+ // @ Public methods
272
+ // -----------------------------------------------------------------------------------------------------
273
+ /**
274
+ * Open the navigation
275
+ */
276
+ open() {
277
+ // Return if the navigation is already open
278
+ if (this.opened) {
279
+ return;
280
+ }
281
+ // Set the opened
282
+ this._toggleOpened(true);
283
+ }
284
+ /**
285
+ * Close the navigation
286
+ */
287
+ close() {
288
+ // Return if the navigation is already closed
289
+ if (!this.opened) {
290
+ return;
291
+ }
292
+ // Close the aside
293
+ this.closeAside();
294
+ // Set the opened
295
+ this._toggleOpened(false);
296
+ }
297
+ /**
298
+ * Toggle the navigation
299
+ */
300
+ toggle() {
301
+ // Toggle
302
+ if (this.opened) {
303
+ this.close();
304
+ }
305
+ else {
306
+ this.open();
307
+ }
308
+ }
309
+ /**
310
+ * Open the aside
311
+ */
312
+ openAside(item) {
313
+ // Return if the item is disabled
314
+ if (item.disabled || !item.id) {
315
+ return;
316
+ }
317
+ // Open
318
+ this.activeAsideItemId = item.id;
319
+ // Show the aside overlay
320
+ this._showAsideOverlay();
321
+ // Mark for check
322
+ this._changeDetectorRef.markForCheck();
323
+ }
324
+ /**
325
+ * Close the aside
326
+ */
327
+ closeAside() {
328
+ // Close
329
+ this.activeAsideItemId = null;
330
+ // Hide the aside overlay
331
+ this._hideAsideOverlay();
332
+ // Mark for check
333
+ this._changeDetectorRef.markForCheck();
334
+ }
335
+ /**
336
+ * Toggle the aside
337
+ */
338
+ toggleAside(item) {
339
+ // Toggle
340
+ if (this.activeAsideItemId === item.id) {
341
+ this.closeAside();
342
+ }
343
+ else {
344
+ this.openAside(item);
345
+ }
346
+ }
347
+ // -----------------------------------------------------------------------------------------------------
348
+ // @ Private methods
349
+ // -----------------------------------------------------------------------------------------------------
350
+ /**
351
+ * Enable the animations
352
+ *
353
+ * @private
354
+ */
355
+ _enableAnimations() {
356
+ // Return if the animations are already enabled
357
+ if (this._animationsEnabled) {
358
+ return;
359
+ }
360
+ // Enable the animations
361
+ this._animationsEnabled = true;
362
+ }
363
+ /**
364
+ * Disable the animations
365
+ *
366
+ * @private
367
+ */
368
+ _disableAnimations() {
369
+ // Return if the animations are already disabled
370
+ if (!this._animationsEnabled) {
371
+ return;
372
+ }
373
+ // Disable the animations
374
+ this._animationsEnabled = false;
375
+ }
376
+ /**
377
+ * Show the overlay
378
+ *
379
+ * @private
380
+ */
381
+ _showOverlay() {
382
+ // Return if there is already an overlay
383
+ if (this._asideOverlay) {
384
+ return;
385
+ }
386
+ // Create the overlay element
387
+ this._overlay = this._renderer2.createElement("div");
388
+ // Add a class to the overlay element
389
+ this._overlay.classList.add("nice-vertical-navigation-overlay");
390
+ // Add a class depending on the transparentOverlay option
391
+ if (this.transparentOverlay) {
392
+ this._overlay.classList.add("nice-vertical-navigation-overlay-transparent");
393
+ }
394
+ // Append the overlay to the parent of the navigation
395
+ this._renderer2.appendChild(this._elementRef.nativeElement.parentElement, this._overlay);
396
+ // Enable block scroll strategy
397
+ this._scrollStrategy.enable();
398
+ // Create the enter animation and attach it to the player
399
+ this._player = this._animationBuilder.build([
400
+ animate("300ms cubic-bezier(0.25, 0.8, 0.25, 1)", style({ opacity: 1 }))
401
+ ]).create(this._overlay);
402
+ // Play the animation
403
+ this._player.play();
404
+ // Add an event listener to the overlay
405
+ this._overlay.addEventListener("click", this._handleOverlayClick);
406
+ }
407
+ /**
408
+ * Hide the overlay
409
+ *
410
+ * @private
411
+ */
412
+ _hideOverlay() {
413
+ if (!this._overlay) {
414
+ return;
415
+ }
416
+ // Create the leave animation and attach it to the player
417
+ this._player = this._animationBuilder.build([
418
+ animate("300ms cubic-bezier(0.25, 0.8, 0.25, 1)", style({ opacity: 0 }))
419
+ ]).create(this._overlay);
420
+ // Play the animation
421
+ this._player.play();
422
+ // Once the animation is done...
423
+ this._player.onDone(() => {
424
+ // If the overlay still exists...
425
+ if (this._overlay) {
426
+ // Remove the event listener
427
+ this._overlay.removeEventListener("click", this._handleOverlayClick);
428
+ // Remove the overlay
429
+ this._overlay.parentNode.removeChild(this._overlay);
430
+ this._overlay = null;
431
+ }
432
+ // Disable block scroll strategy
433
+ this._scrollStrategy.disable();
434
+ });
435
+ }
436
+ /**
437
+ * Show the aside overlay
438
+ *
439
+ * @private
440
+ */
441
+ _showAsideOverlay() {
442
+ // Return if there is already an overlay
443
+ if (this._asideOverlay) {
444
+ return;
445
+ }
446
+ // Create the aside overlay element
447
+ this._asideOverlay = this._renderer2.createElement("div");
448
+ // Add a class to the aside overlay element
449
+ this._asideOverlay.classList.add("nice-vertical-navigation-aside-overlay");
450
+ // Append the aside overlay to the parent of the navigation
451
+ this._renderer2.appendChild(this._elementRef.nativeElement.parentElement, this._asideOverlay);
452
+ // Create the enter animation and attach it to the player
453
+ this._player =
454
+ this._animationBuilder
455
+ .build([
456
+ animate("300ms cubic-bezier(0.25, 0.8, 0.25, 1)", style({ opacity: 1 }))
457
+ ]).create(this._asideOverlay);
458
+ // Play the animation
459
+ this._player.play();
460
+ // Add an event listener to the aside overlay
461
+ this._asideOverlay.addEventListener("click", this._handleAsideOverlayClick);
462
+ }
463
+ /**
464
+ * Hide the aside overlay
465
+ *
466
+ * @private
467
+ */
468
+ _hideAsideOverlay() {
469
+ if (!this._asideOverlay) {
470
+ return;
471
+ }
472
+ // Create the leave animation and attach it to the player
473
+ this._player =
474
+ this._animationBuilder
475
+ .build([
476
+ animate("300ms cubic-bezier(0.25, 0.8, 0.25, 1)", style({ opacity: 0 }))
477
+ ]).create(this._asideOverlay);
478
+ // Play the animation
479
+ this._player.play();
480
+ // Once the animation is done...
481
+ this._player.onDone(() => {
482
+ // If the aside overlay still exists...
483
+ if (this._asideOverlay) {
484
+ // Remove the event listener
485
+ this._asideOverlay.removeEventListener("click", this._handleAsideOverlayClick);
486
+ // Remove the aside overlay
487
+ this._asideOverlay.parentNode.removeChild(this._asideOverlay);
488
+ this._asideOverlay = null;
489
+ }
490
+ });
491
+ }
492
+ /**
493
+ * On mouseenter
494
+ */
495
+ _onMouseenter() {
496
+ // Enable the animations
497
+ this._enableAnimations();
498
+ // Set the hovered
499
+ this.hovered = true;
500
+ this.hoveredChanged.next(this.hovered || this._forceHovered);
501
+ }
502
+ /**
503
+ * On mouseleave
504
+ */
505
+ _onMouseleave() {
506
+ // Enable the animations
507
+ this._enableAnimations();
508
+ // Set the hovered
509
+ this.hovered = false;
510
+ this.hoveredChanged.next(this.hovered || this._forceHovered || this.hasHint);
511
+ }
512
+ /**
513
+ * Open/close the navigation
514
+ *
515
+ * @param open
516
+ * @private
517
+ */
518
+ _toggleOpened(open) {
519
+ // Set the opened
520
+ this.opened = open;
521
+ // Enable the animations
522
+ this._enableAnimations();
523
+ // If the navigation opened, and the mode
524
+ // is 'over', show the overlay
525
+ if (this.mode === "over") {
526
+ if (this.opened) {
527
+ this._showOverlay();
528
+ }
529
+ else {
530
+ this._hideOverlay();
531
+ }
532
+ }
533
+ // Execute the observable
534
+ this.openedChanged.next(open);
535
+ }
536
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.5", ngImport: i0, type: NiceVerticalNavigationComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.NiceNavigationService }, { token: i2.NiceUtilsService }, { token: i3.NiceTranslationContextService }, { token: i4.AnimationBuilder }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i5.Router }, { token: i6.ScrollStrategyOptions }, { token: i7.NiceNavigationHintService }], target: i0.ɵɵFactoryTarget.Component }); }
537
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.5", type: NiceVerticalNavigationComponent, selector: "nice-vertical-navigation", inputs: { name: "name", appearance: "appearance", autoCollapse: "autoCollapse", inner: "inner", mode: "mode", opened: "opened", hovered: "hovered", hasHint: "hasHint", position: "position", showTooltips: "showTooltips", transparentOverlay: "transparentOverlay", tooltipPosition: "tooltipPosition", translationContext: "translationContext", navigation: "navigation" }, outputs: { appearanceChanged: "appearanceChanged", modeChanged: "modeChanged", openedChanged: "openedChanged", hoveredChanged: "hoveredChanged", positionChanged: "positionChanged" }, host: { listeners: { "mouseenter": "_onMouseenter()", "mouseleave": "_onMouseleave()" }, properties: { "class": "this.classList", "style": "this.styleList" } }, providers: [NiceTranslationContextService], viewQueries: [{ propertyName: "_navigationContentEl", first: true, predicate: ["navigationContent"], descendants: true }, { propertyName: "niceScrollbarDirectives", predicate: NiceScrollbarDirective, descendants: true }], exportAs: ["niceVerticalNavigation"], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"nice-vertical-navigation-wrapper\">\n <!-- Header -->\n <div class=\"nice-vertical-navigation-header\">\n <ng-content select=\"[niceVerticalNavigationHeader]\"></ng-content>\n </div>\n\n <!-- Content -->\n <div\n class=\"nice-vertical-navigation-content\"\n niceScrollbar\n [niceScrollbarOptions]=\"{ wheelPropagation: inner, suppressScrollX: true }\"\n #navigationContent\n >\n <!-- Content header -->\n <div class=\"nice-vertical-navigation-content-header\">\n <ng-content select=\"[niceVerticalNavigationContentHeader]\"></ng-content>\n </div>\n\n <!-- Items -->\n <div *ngFor=\"let item of navigation; trackBy: trackByFn\" [@.disabled]=\"!animateNextNavChange\" @slideInRight>\n <!-- Skip the hidden items -->\n <ng-container *ngIf=\"!(item | niceShouldHide | async)\">\n <!-- Aside -->\n <nice-vertical-navigation-aside-item\n *ngIf=\"item.type === 'aside'\"\n [item]=\"item\"\n [name]=\"name\"\n [activeItemId]=\"activeAsideItemId\"\n [autoCollapse]=\"autoCollapse\"\n [skipChildren]=\"true\"\n [showTooltips]=\"showTooltips\"\n [tooltipPosition]=\"tooltipPosition\"\n (click)=\"toggleAside(item)\"\n ></nice-vertical-navigation-aside-item>\n\n <!-- Basic -->\n <nice-vertical-navigation-basic-item\n *ngIf=\"item.type === 'basic'\"\n [item]=\"item\"\n [name]=\"name\"\n [showTooltips]=\"showTooltips\"\n [tooltipPosition]=\"tooltipPosition\"\n ></nice-vertical-navigation-basic-item>\n\n <!-- Collapsable -->\n <nice-vertical-navigation-collapsable-item\n *ngIf=\"item.type === 'collapsable'\"\n [item]=\"item\"\n [name]=\"name\"\n [autoCollapse]=\"autoCollapse\"\n [showTooltips]=\"showTooltips\"\n [tooltipPosition]=\"tooltipPosition\"\n ></nice-vertical-navigation-collapsable-item>\n\n <!-- Divider -->\n <nice-vertical-navigation-divider-item\n *ngIf=\"item.type === 'divider'\"\n [item]=\"item\"\n [name]=\"name\"\n ></nice-vertical-navigation-divider-item>\n\n <!-- Group -->\n <nice-vertical-navigation-group-item\n *ngIf=\"item.type === 'group'\"\n [item]=\"item\"\n [name]=\"name\"\n [autoCollapse]=\"autoCollapse\"\n [showTooltips]=\"showTooltips\"\n [tooltipPosition]=\"tooltipPosition\"\n ></nice-vertical-navigation-group-item>\n\n <!-- Spacer -->\n <nice-vertical-navigation-spacer-item\n *ngIf=\"item.type === 'spacer'\"\n [item]=\"item\"\n [name]=\"name\"\n ></nice-vertical-navigation-spacer-item>\n </ng-container>\n </div>\n\n <!-- Content footer -->\n <div class=\"nice-vertical-navigation-content-footer\">\n <ng-content select=\"[niceVerticalNavigationContentFooter]\"></ng-content>\n </div>\n\n </div>\n\n <!-- Footer -->\n <div class=\"nice-vertical-navigation-footer\">\n <ng-content select=\"[niceVerticalNavigationFooter]\"></ng-content>\n </div>\n</div>\n\n<!-- Aside -->\n<div\n class=\"nice-vertical-navigation-aside-wrapper\"\n *ngIf=\"activeAsideItemId\"\n niceScrollbar\n [niceScrollbarOptions]=\"{ wheelPropagation: false, suppressScrollX: true }\"\n [@fadeInLeft]=\"position === 'left'\"\n [@fadeInRight]=\"position === 'right'\"\n [@fadeOutLeft]=\"position === 'left'\"\n [@fadeOutRight]=\"position === 'right'\"\n>\n\n <!-- Items -->\n <ng-container *ngFor=\"let item of navigation; trackBy: trackByFn\">\n <!-- Skip the hidden items -->\n <ng-container *ngIf=\"(item.hidden && !item.hidden(item)) || !item.hidden\">\n <!-- Aside -->\n <nice-vertical-navigation-aside-item\n *ngIf=\"item.type === 'aside' && item.id === activeAsideItemId\"\n [item]=\"item\"\n [name]=\"name\"\n [autoCollapse]=\"autoCollapse\"\n [showTooltips]=\"showTooltips\"\n [tooltipPosition]=\"tooltipPosition\"\n ></nice-vertical-navigation-aside-item>\n </ng-container>\n </ng-container>\n</div>\n", dependencies: [{ kind: "directive", type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i9.NiceScrollbarDirective, selector: "[niceScrollbar]", inputs: ["niceScrollbar", "niceScrollbarOptions"], exportAs: ["niceScrollbar"] }, { kind: "component", type: i10.NiceVerticalNavigationAsideItemComponent, selector: "nice-vertical-navigation-aside-item", inputs: ["activeItemId", "autoCollapse", "item", "name", "showTooltips", "skipChildren", "tooltipPosition"] }, { kind: "component", type: i11.NiceVerticalNavigationBasicItemComponent, selector: "nice-vertical-navigation-basic-item", inputs: ["item", "name", "showTooltips", "tooltipPosition"] }, { kind: "component", type: i12.NiceVerticalNavigationCollapsableItemComponent, selector: "nice-vertical-navigation-collapsable-item", inputs: ["autoCollapse", "item", "name", "showTooltips", "tooltipPosition"] }, { kind: "component", type: i13.NiceVerticalNavigationDividerItemComponent, selector: "nice-vertical-navigation-divider-item", inputs: ["item", "name"] }, { kind: "component", type: i14.NiceVerticalNavigationGroupItemComponent, selector: "nice-vertical-navigation-group-item", inputs: ["autoCollapse", "item", "name", "showTooltips", "tooltipPosition"] }, { kind: "component", type: i15.NiceVerticalNavigationSpacerItemComponent, selector: "nice-vertical-navigation-spacer-item", inputs: ["item", "name"] }, { kind: "pipe", type: i8.AsyncPipe, name: "async" }, { kind: "pipe", type: i16.NiceShouldHidePipe, name: "niceShouldHide" }], animations: niceAnimations, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
538
+ }
539
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.5", ngImport: i0, type: NiceVerticalNavigationComponent, decorators: [{
540
+ type: Component,
541
+ args: [{ selector: "nice-vertical-navigation", animations: niceAnimations, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [NiceTranslationContextService], exportAs: "niceVerticalNavigation", template: "<div class=\"nice-vertical-navigation-wrapper\">\n <!-- Header -->\n <div class=\"nice-vertical-navigation-header\">\n <ng-content select=\"[niceVerticalNavigationHeader]\"></ng-content>\n </div>\n\n <!-- Content -->\n <div\n class=\"nice-vertical-navigation-content\"\n niceScrollbar\n [niceScrollbarOptions]=\"{ wheelPropagation: inner, suppressScrollX: true }\"\n #navigationContent\n >\n <!-- Content header -->\n <div class=\"nice-vertical-navigation-content-header\">\n <ng-content select=\"[niceVerticalNavigationContentHeader]\"></ng-content>\n </div>\n\n <!-- Items -->\n <div *ngFor=\"let item of navigation; trackBy: trackByFn\" [@.disabled]=\"!animateNextNavChange\" @slideInRight>\n <!-- Skip the hidden items -->\n <ng-container *ngIf=\"!(item | niceShouldHide | async)\">\n <!-- Aside -->\n <nice-vertical-navigation-aside-item\n *ngIf=\"item.type === 'aside'\"\n [item]=\"item\"\n [name]=\"name\"\n [activeItemId]=\"activeAsideItemId\"\n [autoCollapse]=\"autoCollapse\"\n [skipChildren]=\"true\"\n [showTooltips]=\"showTooltips\"\n [tooltipPosition]=\"tooltipPosition\"\n (click)=\"toggleAside(item)\"\n ></nice-vertical-navigation-aside-item>\n\n <!-- Basic -->\n <nice-vertical-navigation-basic-item\n *ngIf=\"item.type === 'basic'\"\n [item]=\"item\"\n [name]=\"name\"\n [showTooltips]=\"showTooltips\"\n [tooltipPosition]=\"tooltipPosition\"\n ></nice-vertical-navigation-basic-item>\n\n <!-- Collapsable -->\n <nice-vertical-navigation-collapsable-item\n *ngIf=\"item.type === 'collapsable'\"\n [item]=\"item\"\n [name]=\"name\"\n [autoCollapse]=\"autoCollapse\"\n [showTooltips]=\"showTooltips\"\n [tooltipPosition]=\"tooltipPosition\"\n ></nice-vertical-navigation-collapsable-item>\n\n <!-- Divider -->\n <nice-vertical-navigation-divider-item\n *ngIf=\"item.type === 'divider'\"\n [item]=\"item\"\n [name]=\"name\"\n ></nice-vertical-navigation-divider-item>\n\n <!-- Group -->\n <nice-vertical-navigation-group-item\n *ngIf=\"item.type === 'group'\"\n [item]=\"item\"\n [name]=\"name\"\n [autoCollapse]=\"autoCollapse\"\n [showTooltips]=\"showTooltips\"\n [tooltipPosition]=\"tooltipPosition\"\n ></nice-vertical-navigation-group-item>\n\n <!-- Spacer -->\n <nice-vertical-navigation-spacer-item\n *ngIf=\"item.type === 'spacer'\"\n [item]=\"item\"\n [name]=\"name\"\n ></nice-vertical-navigation-spacer-item>\n </ng-container>\n </div>\n\n <!-- Content footer -->\n <div class=\"nice-vertical-navigation-content-footer\">\n <ng-content select=\"[niceVerticalNavigationContentFooter]\"></ng-content>\n </div>\n\n </div>\n\n <!-- Footer -->\n <div class=\"nice-vertical-navigation-footer\">\n <ng-content select=\"[niceVerticalNavigationFooter]\"></ng-content>\n </div>\n</div>\n\n<!-- Aside -->\n<div\n class=\"nice-vertical-navigation-aside-wrapper\"\n *ngIf=\"activeAsideItemId\"\n niceScrollbar\n [niceScrollbarOptions]=\"{ wheelPropagation: false, suppressScrollX: true }\"\n [@fadeInLeft]=\"position === 'left'\"\n [@fadeInRight]=\"position === 'right'\"\n [@fadeOutLeft]=\"position === 'left'\"\n [@fadeOutRight]=\"position === 'right'\"\n>\n\n <!-- Items -->\n <ng-container *ngFor=\"let item of navigation; trackBy: trackByFn\">\n <!-- Skip the hidden items -->\n <ng-container *ngIf=\"(item.hidden && !item.hidden(item)) || !item.hidden\">\n <!-- Aside -->\n <nice-vertical-navigation-aside-item\n *ngIf=\"item.type === 'aside' && item.id === activeAsideItemId\"\n [item]=\"item\"\n [name]=\"name\"\n [autoCollapse]=\"autoCollapse\"\n [showTooltips]=\"showTooltips\"\n [tooltipPosition]=\"tooltipPosition\"\n ></nice-vertical-navigation-aside-item>\n </ng-container>\n </ng-container>\n</div>\n" }]
542
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.NiceNavigationService }, { type: i2.NiceUtilsService }, { type: i3.NiceTranslationContextService }, { type: i4.AnimationBuilder }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i5.Router }, { type: i6.ScrollStrategyOptions }, { type: i7.NiceNavigationHintService }]; }, propDecorators: { name: [{
543
+ type: Input
544
+ }], appearance: [{
545
+ type: Input
546
+ }], autoCollapse: [{
547
+ type: Input
548
+ }], inner: [{
549
+ type: Input
550
+ }], mode: [{
551
+ type: Input
552
+ }], opened: [{
553
+ type: Input
554
+ }], hovered: [{
555
+ type: Input
556
+ }], hasHint: [{
557
+ type: Input
558
+ }], position: [{
559
+ type: Input
560
+ }], showTooltips: [{
561
+ type: Input
562
+ }], transparentOverlay: [{
563
+ type: Input
564
+ }], tooltipPosition: [{
565
+ type: Input
566
+ }], translationContext: [{
567
+ type: Input
568
+ }], appearanceChanged: [{
569
+ type: Output
570
+ }], modeChanged: [{
571
+ type: Output
572
+ }], openedChanged: [{
573
+ type: Output
574
+ }], hoveredChanged: [{
575
+ type: Output
576
+ }], positionChanged: [{
577
+ type: Output
578
+ }], _navigationContentEl: [{
579
+ type: ViewChild,
580
+ args: ["navigationContent"]
581
+ }], navigation: [{
582
+ type: Input
583
+ }], classList: [{
584
+ type: HostBinding,
585
+ args: ["class"]
586
+ }], styleList: [{
587
+ type: HostBinding,
588
+ args: ["style"]
589
+ }], niceScrollbarDirectives: [{
590
+ type: ViewChildren,
591
+ args: [NiceScrollbarDirective]
592
+ }], _onMouseenter: [{
593
+ type: HostListener,
594
+ args: ["mouseenter"]
595
+ }], _onMouseleave: [{
596
+ type: HostListener,
597
+ args: ["mouseleave"]
598
+ }] } });
599
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vertical.component.js","sourceRoot":"","sources":["../../../../../../../projects/nice-ui-kit-v2/src/lib/components/navigation/vertical/vertical.component.ts","../../../../../../../projects/nice-ui-kit-v2/src/lib/components/navigation/vertical/vertical.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, AnimationBuilder, AnimationPlayer, style } from \"@angular/animations\";\nimport { BooleanInput, coerceBooleanProperty } from \"@angular/cdk/coercion\";\nimport { ScrollStrategy, ScrollStrategyOptions } from \"@angular/cdk/overlay\";\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    QueryList,\n    Renderer2,\n    SimpleChanges,\n    ViewChild,\n    ViewChildren,\n    ViewEncapsulation\n} from \"@angular/core\";\nimport { TooltipPosition } from \"@angular/material/tooltip\";\nimport { NavigationEnd, Router } from \"@angular/router\";\nimport { merge, ReplaySubject, Subscription } from \"rxjs\";\nimport { delay, filter, takeUntil } from \"rxjs/operators\";\nimport { niceAnimations } from \"../../../animations\";\nimport { NiceScrollbarDirective } from \"../../../directives/scrollbar\";\nimport { NiceUtilsService } from \"../../../providers/utils\";\nimport { NiceNavigationComponent } from \"../navigation.component\";\nimport { NiceNavigationService } from \"../navigation.service\";\nimport {\n    NiceNavigationItem,\n    NiceVerticalNavigationAppearance,\n    NiceVerticalNavigationMode,\n    NiceVerticalNavigationPosition\n} from \"../navigation.types\";\nimport { NiceNavigationHintService } from \"../providers/hint.service\";\nimport { NiceTranslationContextService } from \"../providers/translation-context.service\";\n\n@Component({\n    selector: \"nice-vertical-navigation\",\n    templateUrl: \"./vertical.component.html\",\n    animations: niceAnimations,\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [NiceTranslationContextService],\n    exportAs: \"niceVerticalNavigation\"\n})\nexport class NiceVerticalNavigationComponent extends NiceNavigationComponent implements OnChanges, OnInit, AfterViewInit {\n    // tslint:disable-next-line:variable-name\n    public static ngAcceptInputType_inner: BooleanInput;\n    // tslint:disable-next-line:variable-name\n    public static ngAcceptInputType_opened: BooleanInput;\n    // tslint:disable-next-line:variable-name\n    public static ngAcceptInputType_transparentOverlay: BooleanInput;\n\n    private _forceHovered = false;\n    private _animationsEnabled = false;\n    private _asideOverlay: HTMLElement;\n    private readonly _handleAsideOverlayClick: any;\n    private readonly _handleOverlayClick: any;\n    private _overlay: HTMLElement;\n    private _player: AnimationPlayer;\n    private _scrollStrategy: ScrollStrategy = this._scrollStrategyOptions.block();\n    private _niceScrollbarDirectives!: QueryList<NiceScrollbarDirective>;\n    private _niceScrollbarDirectivesSubscription: Subscription;\n\n    @Input()\n    public name: string = this._niceUtilsService.randomId();\n\n    @Input()\n    public appearance: NiceVerticalNavigationAppearance = \"default\";\n\n    @Input()\n    public autoCollapse = true;\n\n    @Input()\n    public inner = false;\n\n    @Input()\n    public mode: NiceVerticalNavigationMode = \"side\";\n\n    @Input()\n    public opened = true;\n\n    @Input()\n    public hovered = false;\n\n    @Input()\n    public hasHint = false;\n\n    @Input()\n    public position: NiceVerticalNavigationPosition = \"left\";\n\n    @Input()\n    public showTooltips = false;\n\n    @Input()\n    public transparentOverlay = false;\n\n    @Input()\n    public tooltipPosition: TooltipPosition = \"after\";\n\n    @Input()\n    public translationContext: Record<string, any>;\n\n    @Output()\n    public readonly appearanceChanged = new EventEmitter<NiceVerticalNavigationAppearance>();\n\n    @Output()\n    public readonly modeChanged = new EventEmitter<NiceVerticalNavigationMode>();\n\n    @Output()\n    public readonly openedChanged = new EventEmitter<boolean>();\n\n    @Output()\n    public readonly hoveredChanged = new EventEmitter<boolean>();\n\n    @Output()\n    public readonly positionChanged = new EventEmitter<NiceVerticalNavigationPosition>();\n\n    @ViewChild(\"navigationContent\")\n    private _navigationContentEl: ElementRef;\n\n    @Input()\n    public set navigation(navigation: NiceNavigationItem[]) {\n        this._navigation = navigation;\n        this._changeDetectorRef.markForCheck();\n    }\n    public get navigation(): NiceNavigationItem[] {\n        return this._navigation;\n    }\n\n    public set forceHovered(forceHovered: boolean) {\n        this._forceHovered = forceHovered;\n        this.hoveredChanged.next((this.hovered || this._forceHovered) || this.hasHint);\n        this._changeDetectorRef.markForCheck();\n    }\n\n    public activeAsideItemId: string | null = null;\n    public onCollapsableItemCollapsed = new ReplaySubject<NiceNavigationItem>(1);\n    public onCollapsableItemExpanded = new ReplaySubject<NiceNavigationItem>(1);\n\n    /**\n     * Constructor\n     */\n    constructor(\n        _changeDetectorRef: ChangeDetectorRef,\n        _niceNavigationService: NiceNavigationService,\n        _niceUtilsService: NiceUtilsService,\n        _translationContextService: NiceTranslationContextService,\n        private _animationBuilder: AnimationBuilder,\n        private _elementRef: ElementRef,\n        private _renderer2: Renderer2,\n        private _router: Router,\n        private _scrollStrategyOptions: ScrollStrategyOptions,\n        private _hintService: NiceNavigationHintService\n    ) {\n        super(_changeDetectorRef, _niceNavigationService, _niceUtilsService, _translationContextService);\n\n        this._handleAsideOverlayClick = () => {\n            this.closeAside();\n        };\n        this._handleOverlayClick = () => {\n            this.close();\n        };\n    }\n\n    // -----------------------------------------------------------------------------------------------------\n    // @ Accessors\n    // -----------------------------------------------------------------------------------------------------\n\n    /**\n     * Host binding for component classes\n     */\n    @HostBinding(\"class\")\n    public get classList(): any {\n        return {\n            \"nice-vertical-navigation-animations-enabled\": this._animationsEnabled,\n            [`nice-vertical-navigation-appearance-${this.appearance}`]: true,\n            \"nice-vertical-navigation-hover\": this.hovered || this._forceHovered,\n            \"nice-vertical-navigation-inner\": this.inner,\n            \"nice-vertical-navigation-mode-over\": this.mode === \"over\",\n            \"nice-vertical-navigation-mode-side\": this.mode === \"side\",\n            \"nice-vertical-navigation-opened\": this.opened,\n            \"nice-vertical-navigation-position-left\": this.position === \"left\",\n            \"nice-vertical-navigation-position-right\": this.position === \"right\",\n            \"nice-vertical-navigation-has-hint\": this.hasHint\n        };\n    }\n\n    /**\n     * Host binding for component inline styles\n     */\n    @HostBinding(\"style\")\n    public get styleList(): any {\n        return {\n            \"visibility\": this.opened ? \"visible\" : \"hidden\"\n        };\n    }\n\n    /**\n     * Setter for niceScrollbarDirectives\n     */\n    @ViewChildren(NiceScrollbarDirective)\n    public set niceScrollbarDirectives(niceScrollbarDirectives: QueryList<NiceScrollbarDirective>) {\n        // Store the directives\n        this._niceScrollbarDirectives = niceScrollbarDirectives;\n\n        // Return if there are no directives\n        if (niceScrollbarDirectives.length === 0) {\n            return;\n        }\n\n        // Unsubscribe the previous subscriptions\n        if (this._niceScrollbarDirectivesSubscription) {\n            this._niceScrollbarDirectivesSubscription.unsubscribe();\n        }\n\n        // Update the scrollbars on collapsable items' collapse/expand\n        this._niceScrollbarDirectivesSubscription =\n            merge(\n                this.onCollapsableItemCollapsed,\n                this.onCollapsableItemExpanded\n            )\n                .pipe(\n                    takeUntil(this._unsubscribeAll),\n                    delay(250)\n                )\n                .subscribe(() => {\n\n                    // Loop through the scrollbars and update them\n                    niceScrollbarDirectives.forEach((niceScrollbarDirective) => {\n                        niceScrollbarDirective.update();\n                    });\n                });\n    }\n\n    // -----------------------------------------------------------------------------------------------------\n    // @ Lifecycle hooks\n    // -----------------------------------------------------------------------------------------------------\n\n    /**\n     * On changes\n     *\n     * @param changes\n     */\n    public ngOnChanges(changes: SimpleChanges): void {\n        super.ngOnChanges(changes);\n\n        // Appearance\n        if (\"appearance\" in changes) {\n            // Execute the observable\n            this.appearanceChanged.next(changes.appearance.currentValue);\n        }\n\n        // Inner\n        if (\"inner\" in changes) {\n            // Coerce the value to a boolean\n            this.inner = coerceBooleanProperty(changes.inner.currentValue);\n        }\n\n        // Mode\n        if (\"mode\" in changes) {\n            // Get the previous and current values\n            const currentMode = changes.mode.currentValue;\n            const previousMode = changes.mode.previousValue;\n\n            // Disable the animations\n            this._disableAnimations();\n\n            // If the mode changes: 'over -> side'\n            if (previousMode === \"over\" && currentMode === \"side\") {\n                // Hide the overlay\n                this._hideOverlay();\n            }\n\n            // If the mode changes: 'side -> over'\n            if (previousMode === \"side\" && currentMode === \"over\") {\n                // Close the aside\n                this.closeAside();\n\n                // If the navigation is opened\n                if (this.opened) {\n                    // Show the overlay\n                    this._showOverlay();\n                }\n            }\n\n            // Execute the observable\n            this.modeChanged.next(currentMode);\n\n            // Enable the animations after a delay\n            // The delay must be bigger than the current transition-duration\n            // to make sure nothing will be animated while the mode changing\n            setTimeout(() => {\n                this._enableAnimations();\n            }, 500);\n        }\n\n        // Opened\n        if (\"opened\" in changes) {\n            // Coerce the value to a boolean\n            this.opened = coerceBooleanProperty(changes.opened.currentValue);\n\n            // Open/close the navigation\n            this._toggleOpened(this.opened);\n        }\n\n        // Position\n        if (\"position\" in changes) {\n            // Execute the observable\n            this.positionChanged.next(changes.position.currentValue);\n        }\n\n        // Transparent overlay\n        if (\"transparentOverlay\" in changes) {\n            // Coerce the value to a boolean\n            this.transparentOverlay = coerceBooleanProperty(changes.transparentOverlay.currentValue);\n        }\n    }\n\n    /**\n     * On init\n     */\n    public ngOnInit(): void {\n        super.ngOnInit();\n\n        // Make sure the name input is not an empty string\n        if (this.name === \"\") {\n            this.name = this._niceUtilsService.randomId();\n        }\n\n        // Subscribe to the 'NavigationEnd' event\n        this._router.events\n            .pipe(\n                filter(event => event instanceof NavigationEnd),\n                takeUntil(this._unsubscribeAll)\n            )\n            .subscribe(() => {\n                // If the mode is 'over' and the navigation is opened...\n                if (this.mode === \"over\" && this.opened) {\n                    // Close the navigation\n                    this.close();\n                }\n\n                // If the mode is 'side' and the aside is active...\n                if (this.mode === \"side\" && this.activeAsideItemId) {\n                    // Close the aside\n                    this.closeAside();\n                }\n            });\n\n        this._hintService.hasActiveHint$.pipe(takeUntil(this._unsubscribeAll)).subscribe(hasHint => {\n            this.hasHint = hasHint;\n            this.hoveredChanged.next((this.hovered || this._forceHovered) || this.hasHint);\n        });\n    }\n\n    /**\n     * After view init\n     */\n    public ngAfterViewInit(): void {\n        setTimeout(() => {\n\n            // Return if 'navigation content' element does not exist\n            if (!this._navigationContentEl) {\n                return;\n            }\n\n            // If 'navigation content' element doesn't have\n            // perfect scrollbar activated on it...\n            if (!this._navigationContentEl.nativeElement.classList.contains(\"ps\")) {\n                // Find the active item\n                const activeItem = this._navigationContentEl.nativeElement.querySelector(\".nice-vertical-navigation-item-active\");\n\n                // If the active item exists, scroll it into view\n                if (activeItem) {\n                    activeItem.scrollIntoView();\n                }\n            }\n            // Otherwise\n            else {\n                // Go through all the scrollbar directives\n                this._niceScrollbarDirectives.forEach((niceScrollbarDirective) => {\n\n                    // Skip if not enabled\n                    if (!niceScrollbarDirective.isEnabled()) {\n                        return;\n                    }\n\n                    // Scroll to the active element\n                    niceScrollbarDirective.scrollToElement(\".nice-vertical-navigation-item-active\", -120, true);\n                });\n            }\n        });\n    }\n\n    // -----------------------------------------------------------------------------------------------------\n    // @ Public methods\n    // -----------------------------------------------------------------------------------------------------\n\n    /**\n     * Open the navigation\n     */\n    public open(): void {\n        // Return if the navigation is already open\n        if (this.opened) {\n            return;\n        }\n\n        // Set the opened\n        this._toggleOpened(true);\n    }\n\n    /**\n     * Close the navigation\n     */\n    public close(): void {\n        // Return if the navigation is already closed\n        if (!this.opened) {\n            return;\n        }\n\n        // Close the aside\n        this.closeAside();\n\n        // Set the opened\n        this._toggleOpened(false);\n    }\n\n    /**\n     * Toggle the navigation\n     */\n    public toggle(): void {\n        // Toggle\n        if (this.opened) {\n            this.close();\n        } else {\n            this.open();\n        }\n    }\n\n    /**\n     * Open the aside\n     */\n    public openAside(item: NiceNavigationItem): void {\n        // Return if the item is disabled\n        if (item.disabled || !item.id) {\n            return;\n        }\n\n        // Open\n        this.activeAsideItemId = item.id;\n\n        // Show the aside overlay\n        this._showAsideOverlay();\n\n        // Mark for check\n        this._changeDetectorRef.markForCheck();\n    }\n\n    /**\n     * Close the aside\n     */\n    public closeAside(): void {\n        // Close\n        this.activeAsideItemId = null;\n\n        // Hide the aside overlay\n        this._hideAsideOverlay();\n\n        // Mark for check\n        this._changeDetectorRef.markForCheck();\n    }\n\n    /**\n     * Toggle the aside\n     */\n    public toggleAside(item: NiceNavigationItem): void {\n        // Toggle\n        if (this.activeAsideItemId === item.id) {\n            this.closeAside();\n        } else {\n            this.openAside(item);\n        }\n    }\n\n    // -----------------------------------------------------------------------------------------------------\n    // @ Private methods\n    // -----------------------------------------------------------------------------------------------------\n\n    /**\n     * Enable the animations\n     *\n     * @private\n     */\n    private _enableAnimations(): void {\n        // Return if the animations are already enabled\n        if (this._animationsEnabled) {\n            return;\n        }\n\n        // Enable the animations\n        this._animationsEnabled = true;\n    }\n\n    /**\n     * Disable the animations\n     *\n     * @private\n     */\n    private _disableAnimations(): void {\n        // Return if the animations are already disabled\n        if (!this._animationsEnabled) {\n            return;\n        }\n\n        // Disable the animations\n        this._animationsEnabled = false;\n    }\n\n    /**\n     * Show the overlay\n     *\n     * @private\n     */\n    private _showOverlay(): void {\n        // Return if there is already an overlay\n        if (this._asideOverlay) {\n            return;\n        }\n\n        // Create the overlay element\n        this._overlay = this._renderer2.createElement(\"div\");\n\n        // Add a class to the overlay element\n        this._overlay.classList.add(\"nice-vertical-navigation-overlay\");\n\n        // Add a class depending on the transparentOverlay option\n        if (this.transparentOverlay) {\n            this._overlay.classList.add(\"nice-vertical-navigation-overlay-transparent\");\n        }\n\n        // Append the overlay to the parent of the navigation\n        this._renderer2.appendChild(this._elementRef.nativeElement.parentElement, this._overlay);\n\n        // Enable block scroll strategy\n        this._scrollStrategy.enable();\n\n        // Create the enter animation and attach it to the player\n        this._player = this._animationBuilder.build([\n            animate(\"300ms cubic-bezier(0.25, 0.8, 0.25, 1)\", style({opacity: 1}))\n        ]).create(this._overlay);\n\n        // Play the animation\n        this._player.play();\n\n        // Add an event listener to the overlay\n        this._overlay.addEventListener(\"click\", this._handleOverlayClick);\n    }\n\n    /**\n     * Hide the overlay\n     *\n     * @private\n     */\n    private _hideOverlay(): void {\n        if (!this._overlay) {\n            return;\n        }\n\n        // Create the leave animation and attach it to the player\n        this._player = this._animationBuilder.build([\n            animate(\"300ms cubic-bezier(0.25, 0.8, 0.25, 1)\", style({opacity: 0}))\n        ]).create(this._overlay);\n\n        // Play the animation\n        this._player.play();\n\n        // Once the animation is done...\n        this._player.onDone(() => {\n\n            // If the overlay still exists...\n            if (this._overlay) {\n                // Remove the event listener\n                this._overlay.removeEventListener(\"click\", this._handleOverlayClick);\n\n                // Remove the overlay\n                this._overlay.parentNode.removeChild(this._overlay);\n                this._overlay = null;\n            }\n\n            // Disable block scroll strategy\n            this._scrollStrategy.disable();\n        });\n    }\n\n    /**\n     * Show the aside overlay\n     *\n     * @private\n     */\n    private _showAsideOverlay(): void {\n        // Return if there is already an overlay\n        if (this._asideOverlay) {\n            return;\n        }\n\n        // Create the aside overlay element\n        this._asideOverlay = this._renderer2.createElement(\"div\");\n\n        // Add a class to the aside overlay element\n        this._asideOverlay.classList.add(\"nice-vertical-navigation-aside-overlay\");\n\n        // Append the aside overlay to the parent of the navigation\n        this._renderer2.appendChild(this._elementRef.nativeElement.parentElement, this._asideOverlay);\n\n        // Create the enter animation and attach it to the player\n        this._player =\n            this._animationBuilder\n                .build([\n                    animate(\"300ms cubic-bezier(0.25, 0.8, 0.25, 1)\", style({opacity: 1}))\n                ]).create(this._asideOverlay);\n\n        // Play the animation\n        this._player.play();\n\n        // Add an event listener to the aside overlay\n        this._asideOverlay.addEventListener(\"click\", this._handleAsideOverlayClick);\n    }\n\n    /**\n     * Hide the aside overlay\n     *\n     * @private\n     */\n    private _hideAsideOverlay(): void {\n        if (!this._asideOverlay) {\n            return;\n        }\n\n        // Create the leave animation and attach it to the player\n        this._player =\n            this._animationBuilder\n                .build([\n                    animate(\"300ms cubic-bezier(0.25, 0.8, 0.25, 1)\", style({opacity: 0}))\n                ]).create(this._asideOverlay);\n\n        // Play the animation\n        this._player.play();\n\n        // Once the animation is done...\n        this._player.onDone(() => {\n\n            // If the aside overlay still exists...\n            if (this._asideOverlay) {\n                // Remove the event listener\n                this._asideOverlay.removeEventListener(\"click\", this._handleAsideOverlayClick);\n\n                // Remove the aside overlay\n                this._asideOverlay.parentNode.removeChild(this._asideOverlay);\n                this._asideOverlay = null;\n            }\n        });\n    }\n\n    /**\n     * On mouseenter\n     */\n    @HostListener(\"mouseenter\")\n    public _onMouseenter(): void {\n        // Enable the animations\n        this._enableAnimations();\n\n        // Set the hovered\n        this.hovered = true;\n        this.hoveredChanged.next(this.hovered || this._forceHovered);\n    }\n\n    /**\n     * On mouseleave\n     */\n    @HostListener(\"mouseleave\")\n    public _onMouseleave(): void {\n        // Enable the animations\n        this._enableAnimations();\n\n        // Set the hovered\n        this.hovered = false;\n        this.hoveredChanged.next(this.hovered || this._forceHovered || this.hasHint);\n    }\n\n    /**\n     * Open/close the navigation\n     *\n     * @param open\n     * @private\n     */\n    private _toggleOpened(open: boolean): void {\n        // Set the opened\n        this.opened = open;\n\n        // Enable the animations\n        this._enableAnimations();\n\n        // If the navigation opened, and the mode\n        // is 'over', show the overlay\n        if (this.mode === \"over\") {\n            if (this.opened) {\n                this._showOverlay();\n            } else {\n                this._hideOverlay();\n            }\n        }\n\n        // Execute the observable\n        this.openedChanged.next(open);\n    }\n}\n","<div class=\"nice-vertical-navigation-wrapper\">\n    <!-- Header -->\n    <div class=\"nice-vertical-navigation-header\">\n        <ng-content select=\"[niceVerticalNavigationHeader]\"></ng-content>\n    </div>\n\n    <!-- Content -->\n    <div\n        class=\"nice-vertical-navigation-content\"\n        niceScrollbar\n        [niceScrollbarOptions]=\"{ wheelPropagation: inner, suppressScrollX: true }\"\n        #navigationContent\n    >\n        <!-- Content header -->\n        <div class=\"nice-vertical-navigation-content-header\">\n            <ng-content select=\"[niceVerticalNavigationContentHeader]\"></ng-content>\n        </div>\n\n        <!-- Items -->\n        <div *ngFor=\"let item of navigation; trackBy: trackByFn\" [@.disabled]=\"!animateNextNavChange\" @slideInRight>\n            <!-- Skip the hidden items -->\n            <ng-container *ngIf=\"!(item | niceShouldHide | async)\">\n                <!-- Aside -->\n                <nice-vertical-navigation-aside-item\n                    *ngIf=\"item.type === 'aside'\"\n                    [item]=\"item\"\n                    [name]=\"name\"\n                    [activeItemId]=\"activeAsideItemId\"\n                    [autoCollapse]=\"autoCollapse\"\n                    [skipChildren]=\"true\"\n                    [showTooltips]=\"showTooltips\"\n                    [tooltipPosition]=\"tooltipPosition\"\n                    (click)=\"toggleAside(item)\"\n                ></nice-vertical-navigation-aside-item>\n\n                <!-- Basic -->\n                <nice-vertical-navigation-basic-item\n                    *ngIf=\"item.type === 'basic'\"\n                    [item]=\"item\"\n                    [name]=\"name\"\n                    [showTooltips]=\"showTooltips\"\n                    [tooltipPosition]=\"tooltipPosition\"\n                ></nice-vertical-navigation-basic-item>\n\n                <!-- Collapsable -->\n                <nice-vertical-navigation-collapsable-item\n                    *ngIf=\"item.type === 'collapsable'\"\n                    [item]=\"item\"\n                    [name]=\"name\"\n                    [autoCollapse]=\"autoCollapse\"\n                    [showTooltips]=\"showTooltips\"\n                    [tooltipPosition]=\"tooltipPosition\"\n                ></nice-vertical-navigation-collapsable-item>\n\n                <!-- Divider -->\n                <nice-vertical-navigation-divider-item\n                    *ngIf=\"item.type === 'divider'\"\n                    [item]=\"item\"\n                    [name]=\"name\"\n                ></nice-vertical-navigation-divider-item>\n\n                <!-- Group -->\n                <nice-vertical-navigation-group-item\n                    *ngIf=\"item.type === 'group'\"\n                    [item]=\"item\"\n                    [name]=\"name\"\n                    [autoCollapse]=\"autoCollapse\"\n                    [showTooltips]=\"showTooltips\"\n                    [tooltipPosition]=\"tooltipPosition\"\n                ></nice-vertical-navigation-group-item>\n\n                <!-- Spacer -->\n                <nice-vertical-navigation-spacer-item\n                    *ngIf=\"item.type === 'spacer'\"\n                    [item]=\"item\"\n                    [name]=\"name\"\n                ></nice-vertical-navigation-spacer-item>\n            </ng-container>\n        </div>\n\n        <!-- Content footer -->\n        <div class=\"nice-vertical-navigation-content-footer\">\n            <ng-content select=\"[niceVerticalNavigationContentFooter]\"></ng-content>\n        </div>\n\n    </div>\n\n    <!-- Footer -->\n    <div class=\"nice-vertical-navigation-footer\">\n        <ng-content select=\"[niceVerticalNavigationFooter]\"></ng-content>\n    </div>\n</div>\n\n<!-- Aside -->\n<div\n    class=\"nice-vertical-navigation-aside-wrapper\"\n    *ngIf=\"activeAsideItemId\"\n    niceScrollbar\n    [niceScrollbarOptions]=\"{ wheelPropagation: false, suppressScrollX: true }\"\n    [@fadeInLeft]=\"position === 'left'\"\n    [@fadeInRight]=\"position === 'right'\"\n    [@fadeOutLeft]=\"position === 'left'\"\n    [@fadeOutRight]=\"position === 'right'\"\n>\n\n    <!-- Items -->\n    <ng-container *ngFor=\"let item of navigation; trackBy: trackByFn\">\n        <!-- Skip the hidden items -->\n        <ng-container *ngIf=\"(item.hidden && !item.hidden(item)) || !item.hidden\">\n            <!-- Aside -->\n            <nice-vertical-navigation-aside-item\n                *ngIf=\"item.type === 'aside' && item.id === activeAsideItemId\"\n                [item]=\"item\"\n                [name]=\"name\"\n                [autoCollapse]=\"autoCollapse\"\n                [showTooltips]=\"showTooltips\"\n                [tooltipPosition]=\"tooltipPosition\"\n            ></nice-vertical-navigation-aside-item>\n        </ng-container>\n    </ng-container>\n</div>\n"]}