design-angular-kit 1.1.4 → 1.2.1

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 (546) hide show
  1. package/.eslintrc.json +31 -0
  2. package/karma.conf.js +38 -0
  3. package/ng-package.json +9 -0
  4. package/ng-package.prod.json +8 -0
  5. package/package.json +9 -14
  6. package/schematics/ng-add/index.spec.ts +45 -0
  7. package/schematics/ng-add/index.ts +36 -0
  8. package/schematics/ng-add/rules/setup-project/add-animations.ts +7 -0
  9. package/schematics/ng-add/rules/setup-project/add-assets.ts +45 -0
  10. package/schematics/ng-add/rules/setup-project/add-design-angular-kit.ts +40 -0
  11. package/schematics/ng-add/rules/setup-project/add-http-client.ts +7 -0
  12. package/schematics/ng-add/rules/setup-project/add-import-to-style-file.ts +120 -0
  13. package/schematics/ng-add/rules/setup-project/add-localisation.ts +45 -0
  14. package/schematics/ng-add/rules/setup-project/angular-json-helper.ts +11 -0
  15. package/schematics/ng-add/rules/setup-project/exceptions.ts +13 -0
  16. package/schematics/ng-add/{schema.d.ts → schema.ts} +1 -1
  17. package/schematics/ng-add/setup-project.spec.ts +166 -0
  18. package/schematics/ng-add/setup-project.ts +31 -0
  19. package/schematics/ng-add/utils.ts +71 -0
  20. package/schematics/ng-add/versions-helper.ts +41 -0
  21. package/src/lib/abstracts/abstract-form.component.ts +200 -0
  22. package/src/lib/abstracts/abstract.component.ts +63 -0
  23. package/src/lib/components/core/accordion/accordion.component.html +27 -0
  24. package/src/lib/components/core/accordion/accordion.component.spec.ts +21 -0
  25. package/src/lib/components/core/accordion/accordion.component.ts +40 -0
  26. package/src/lib/components/core/alert/alert.component.html +19 -0
  27. package/src/lib/components/core/alert/alert.component.scss +3 -0
  28. package/src/lib/components/core/alert/alert.component.spec.ts +62 -0
  29. package/src/lib/components/core/alert/alert.component.ts +75 -0
  30. package/src/lib/components/core/avatar/avatar-dropdown/avatar-dropdown.component.html +23 -0
  31. package/src/lib/components/core/avatar/avatar-dropdown/avatar-dropdown.component.scss +17 -0
  32. package/src/lib/components/core/avatar/avatar-dropdown/avatar-dropdown.component.spec.ts +21 -0
  33. package/src/lib/components/core/avatar/avatar-dropdown/avatar-dropdown.component.ts +50 -0
  34. package/src/lib/components/core/avatar/avatar-group/avatar-group.component.html +7 -0
  35. package/src/lib/components/core/avatar/avatar-group/avatar-group.component.spec.ts +38 -0
  36. package/src/lib/components/core/avatar/avatar-group/avatar-group.component.ts +25 -0
  37. package/src/lib/components/core/avatar/avatar.directive.ts +73 -0
  38. package/src/lib/components/core/avatar/avatar.module.ts +18 -0
  39. package/src/lib/components/core/badge/badge.directive.spec.ts +59 -0
  40. package/src/lib/components/core/badge/badge.directive.ts +39 -0
  41. package/src/lib/components/core/button/button.directive.spec.ts +96 -0
  42. package/src/lib/components/core/button/button.directive.ts +89 -0
  43. package/src/lib/components/core/callout/callout.component.html +25 -0
  44. package/src/lib/components/core/callout/callout.component.spec.ts +138 -0
  45. package/src/lib/components/core/callout/callout.component.ts +92 -0
  46. package/src/lib/components/core/card/card.component.html +35 -0
  47. package/src/lib/components/core/card/card.component.scss +30 -0
  48. package/src/lib/components/core/card/card.component.spec.ts +21 -0
  49. package/src/lib/components/core/card/card.component.ts +78 -0
  50. package/src/lib/components/core/carousel/carousel/carousel.component.html +29 -0
  51. package/src/lib/components/core/carousel/carousel/carousel.component.scss +1 -0
  52. package/src/lib/components/core/carousel/carousel/carousel.component.spec.ts +21 -0
  53. package/src/lib/components/core/carousel/carousel/carousel.component.ts +119 -0
  54. package/src/lib/components/core/carousel/carousel-item/carousel-item.component.html +3 -0
  55. package/src/lib/components/core/carousel/carousel-item/carousel-item.component.spec.ts +22 -0
  56. package/src/lib/components/core/carousel/carousel-item/carousel-item.component.ts +20 -0
  57. package/src/lib/components/core/carousel/carousel.module.ts +11 -0
  58. package/src/lib/components/core/chip/chip.component.html +26 -0
  59. package/src/lib/components/core/chip/chip.component.spec.ts +87 -0
  60. package/src/lib/components/core/chip/chip.component.ts +154 -0
  61. package/src/lib/components/core/collapse/collapse.component.html +3 -0
  62. package/src/lib/components/core/collapse/collapse.component.spec.ts +21 -0
  63. package/src/lib/components/core/collapse/collapse.component.ts +124 -0
  64. package/src/lib/components/core/dimmer/dimmer-buttons/dimmer-buttons.component.html +3 -0
  65. package/src/lib/components/core/dimmer/dimmer-buttons/dimmer-buttons.component.spec.ts +35 -0
  66. package/src/lib/components/core/dimmer/dimmer-buttons/dimmer-buttons.component.ts +23 -0
  67. package/src/lib/components/core/dimmer/dimmer-icon/dimmer-icon.component.html +3 -0
  68. package/src/lib/components/core/dimmer/dimmer-icon/dimmer-icon.component.spec.ts +22 -0
  69. package/src/lib/components/core/dimmer/dimmer-icon/dimmer-icon.component.ts +10 -0
  70. package/src/lib/components/core/dimmer/dimmer.component.html +7 -0
  71. package/src/lib/components/core/dimmer/dimmer.component.spec.ts +49 -0
  72. package/src/lib/components/core/dimmer/dimmer.component.ts +50 -0
  73. package/src/lib/components/core/dimmer/dimmer.module.ts +12 -0
  74. package/src/lib/components/core/dropdown/dropdown/dropdown.component.html +45 -0
  75. package/src/lib/components/core/dropdown/dropdown/dropdown.component.scss +3 -0
  76. package/src/lib/components/core/dropdown/dropdown/dropdown.component.spec.ts +21 -0
  77. package/src/lib/components/core/dropdown/dropdown/dropdown.component.ts +186 -0
  78. package/src/lib/components/core/dropdown/dropdown-item/dropdown-item.component.html +18 -0
  79. package/src/lib/components/core/dropdown/dropdown-item/dropdown-item.component.scss +4 -0
  80. package/src/lib/components/core/dropdown/dropdown-item/dropdown-item.component.spec.ts +21 -0
  81. package/src/lib/components/core/dropdown/dropdown-item/dropdown-item.component.ts +82 -0
  82. package/src/lib/components/core/dropdown/dropdown.module.ts +11 -0
  83. package/src/lib/components/core/forward/forward.directive.spec.ts +60 -0
  84. package/src/lib/components/core/forward/forward.directive.ts +43 -0
  85. package/src/lib/components/core/link/link.component.html +13 -0
  86. package/src/lib/components/core/link/link.component.spec.ts +21 -0
  87. package/src/lib/components/core/link/link.component.ts +54 -0
  88. package/src/lib/components/core/list/list/list.component.html +13 -0
  89. package/src/lib/components/core/list/list/list.component.spec.ts +21 -0
  90. package/src/lib/components/core/list/list/list.component.ts +30 -0
  91. package/src/lib/components/core/list/list-item/list-item.component.html +42 -0
  92. package/src/lib/components/core/list/list-item/list-item.component.scss +16 -0
  93. package/src/lib/components/core/list/list-item/list-item.component.spec.ts +21 -0
  94. package/src/lib/components/core/list/list-item/list-item.component.ts +75 -0
  95. package/src/lib/components/core/list/list.module.ts +11 -0
  96. package/src/lib/components/core/modal/modal.component.html +36 -0
  97. package/src/lib/components/core/modal/modal.component.scss +3 -0
  98. package/src/lib/components/core/modal/modal.component.spec.ts +21 -0
  99. package/src/lib/components/core/modal/modal.component.ts +218 -0
  100. package/src/lib/components/core/notifications/notifications.component.html +25 -0
  101. package/src/lib/components/core/notifications/notifications.component.scss +3 -0
  102. package/src/lib/components/core/notifications/notifications.component.spec.ts +21 -0
  103. package/src/lib/components/core/notifications/notifications.component.ts +123 -0
  104. package/src/lib/components/core/pagination/pagination.component.html +107 -0
  105. package/src/lib/components/core/pagination/pagination.component.spec.ts +21 -0
  106. package/src/lib/components/core/pagination/pagination.component.ts +157 -0
  107. package/src/lib/components/core/popover/popover.directive.spec.ts +21 -0
  108. package/src/lib/components/core/popover/popover.directive.ts +171 -0
  109. package/src/lib/components/core/progress-bar/progress-bar.component.html +20 -0
  110. package/src/lib/components/core/progress-bar/progress-bar.component.spec.ts +21 -0
  111. package/src/lib/components/core/progress-bar/progress-bar.component.ts +46 -0
  112. package/src/lib/components/core/progress-button/progress-button.component.html +5 -0
  113. package/src/lib/components/core/progress-button/progress-button.component.spec.ts +21 -0
  114. package/src/lib/components/core/progress-button/progress-button.component.ts +39 -0
  115. package/src/lib/components/core/spinner/spinner.component.html +7 -0
  116. package/src/lib/components/core/spinner/spinner.component.spec.ts +80 -0
  117. package/src/lib/components/core/spinner/spinner.component.ts +31 -0
  118. package/src/lib/components/core/steppers/steppers-container/steppers-container.component.html +126 -0
  119. package/src/lib/components/core/steppers/steppers-container/steppers-container.component.spec.ts +21 -0
  120. package/src/lib/components/core/steppers/steppers-container/steppers-container.component.ts +185 -0
  121. package/src/lib/components/core/steppers/steppers-item/steppers-item.component.html +3 -0
  122. package/src/lib/components/core/steppers/steppers-item/steppers-item.component.spec.ts +22 -0
  123. package/src/lib/components/core/steppers/steppers-item/steppers-item.component.ts +33 -0
  124. package/src/lib/components/core/steppers/steppers.module.ts +11 -0
  125. package/src/lib/components/core/tab/tab-container/tab-container.component.html +78 -0
  126. package/src/lib/components/core/tab/tab-container/tab-container.component.spec.ts +21 -0
  127. package/src/lib/components/core/tab/tab-container/tab-container.component.ts +137 -0
  128. package/src/lib/components/core/tab/tab-item/tab-item.component.html +3 -0
  129. package/src/lib/components/core/tab/tab-item/tab-item.component.spec.ts +22 -0
  130. package/src/lib/components/core/tab/tab-item/tab-item.component.ts +50 -0
  131. package/src/lib/components/core/tab/tab.module.ts +11 -0
  132. package/src/lib/components/core/table/sort/sort-header/sort-header.component.html +27 -0
  133. package/src/lib/components/core/table/sort/sort-header/sort-header.component.scss +65 -0
  134. package/src/lib/components/core/table/sort/sort-header/sort-header.component.spec.ts +25 -0
  135. package/src/lib/components/core/table/sort/sort-header/sort-header.component.ts +164 -0
  136. package/src/lib/components/core/table/sort/sort.directive.spec.ts +73 -0
  137. package/src/lib/components/core/table/sort/sort.directive.ts +142 -0
  138. package/src/lib/components/core/table/table.component.html +23 -0
  139. package/src/lib/components/core/table/table.component.scss +7 -0
  140. package/src/lib/components/core/table/table.component.spec.ts +21 -0
  141. package/src/lib/components/core/table/table.component.ts +70 -0
  142. package/src/lib/components/core/table/table.module.ts +12 -0
  143. package/src/lib/components/core/timeline/timeline-item/timeline-item.component.html +47 -0
  144. package/src/lib/components/core/timeline/timeline-item/timeline-item.component.spec.ts +24 -0
  145. package/src/lib/components/core/timeline/timeline-item/timeline-item.component.ts +102 -0
  146. package/src/lib/components/core/timeline/timeline.component.html +21 -0
  147. package/src/lib/components/core/timeline/timeline.component.spec.ts +21 -0
  148. package/src/lib/components/core/timeline/timeline.component.ts +31 -0
  149. package/src/lib/components/core/timeline/timeline.module.ts +11 -0
  150. package/src/lib/components/core/tooltip/tooltip.directive.spec.ts +20 -0
  151. package/src/lib/components/core/tooltip/tooltip.directive.ts +141 -0
  152. package/src/lib/components/form/autocomplete/autocomplete.component.html +58 -0
  153. package/src/lib/components/form/autocomplete/autocomplete.component.spec.ts +21 -0
  154. package/src/lib/components/form/autocomplete/autocomplete.component.ts +130 -0
  155. package/src/lib/components/form/checkbox/checkbox.component.html +67 -0
  156. package/src/lib/components/form/checkbox/checkbox.component.spec.ts +21 -0
  157. package/src/lib/components/form/checkbox/checkbox.component.ts +65 -0
  158. package/src/lib/components/form/form.module.ts +34 -0
  159. package/src/lib/components/form/input/input.component.html +92 -0
  160. package/src/lib/components/form/input/input.component.scss +29 -0
  161. package/src/lib/components/form/input/input.component.spec.ts +21 -0
  162. package/src/lib/components/form/input/input.component.ts +234 -0
  163. package/src/lib/components/form/password-input/password-input.component.html +65 -0
  164. package/src/lib/components/form/password-input/password-input.component.scss +9 -0
  165. package/src/lib/components/form/password-input/password-input.component.spec.ts +21 -0
  166. package/src/lib/components/form/password-input/password-input.component.ts +171 -0
  167. package/src/lib/components/form/radio-button/radio-button.component.html +50 -0
  168. package/src/lib/components/form/radio-button/radio-button.component.scss +14 -0
  169. package/src/lib/components/form/radio-button/radio-button.component.spec.ts +21 -0
  170. package/src/lib/components/form/radio-button/radio-button.component.ts +82 -0
  171. package/src/lib/components/form/range/range.component.html +17 -0
  172. package/src/lib/components/form/range/range.component.scss +17 -0
  173. package/src/lib/components/form/range/range.component.spec.ts +21 -0
  174. package/src/lib/components/form/range/range.component.ts +100 -0
  175. package/src/lib/components/form/rating/rating.component.html +24 -0
  176. package/src/lib/components/form/rating/rating.component.spec.ts +21 -0
  177. package/src/lib/components/form/rating/rating.component.ts +52 -0
  178. package/src/lib/components/form/select/select.component.html +54 -0
  179. package/src/lib/components/form/select/select.component.scss +3 -0
  180. package/src/lib/components/form/select/select.component.spec.ts +22 -0
  181. package/src/lib/components/form/select/select.component.ts +91 -0
  182. package/src/lib/components/form/textarea/textarea.component.html +28 -0
  183. package/src/lib/components/form/textarea/textarea.component.scss +12 -0
  184. package/src/lib/components/form/textarea/textarea.component.spec.ts +21 -0
  185. package/src/lib/components/form/textarea/textarea.component.ts +61 -0
  186. package/src/lib/components/form/transfer/store/transfer.reducers.ts +242 -0
  187. package/src/lib/components/form/transfer/store/transfer.state.ts +20 -0
  188. package/src/lib/components/form/transfer/store/transfer.store.ts +88 -0
  189. package/src/lib/components/form/transfer/transfer-list/transfer-list.component.html +42 -0
  190. package/src/lib/components/form/transfer/transfer-list/transfer-list.component.spec.ts +33 -0
  191. package/src/lib/components/form/transfer/transfer-list/transfer-list.component.ts +93 -0
  192. package/src/lib/components/form/transfer/transfer.component.html +52 -0
  193. package/src/lib/components/form/transfer/transfer.component.spec.ts +27 -0
  194. package/src/lib/components/form/transfer/transfer.component.ts +159 -0
  195. package/{lib/components/form/transfer/transfer.model.d.ts → src/lib/components/form/transfer/transfer.model.ts} +9 -2
  196. package/src/lib/components/form/upload-drag-drop/upload-drag-drop.component.html +36 -0
  197. package/src/lib/components/form/upload-drag-drop/upload-drag-drop.component.spec.ts +21 -0
  198. package/src/lib/components/form/upload-drag-drop/upload-drag-drop.component.ts +170 -0
  199. package/src/lib/components/form/upload-file-list/upload-file-list.component.html +46 -0
  200. package/src/lib/components/form/upload-file-list/upload-file-list.component.spec.ts +22 -0
  201. package/src/lib/components/form/upload-file-list/upload-file-list.component.ts +120 -0
  202. package/src/lib/components/navigation/back-button/back-button.component.html +25 -0
  203. package/src/lib/components/navigation/back-button/back-button.component.spec.ts +91 -0
  204. package/src/lib/components/navigation/back-button/back-button.component.ts +67 -0
  205. package/src/lib/components/navigation/back-to-top/back-to-top.component.html +11 -0
  206. package/src/lib/components/navigation/back-to-top/back-to-top.component.spec.ts +21 -0
  207. package/src/lib/components/navigation/back-to-top/back-to-top.component.ts +80 -0
  208. package/src/lib/components/navigation/breadcrumbs/breadcrumb/breadcrumb.component.html +23 -0
  209. package/src/lib/components/navigation/breadcrumbs/breadcrumb/breadcrumb.component.spec.ts +21 -0
  210. package/src/lib/components/navigation/breadcrumbs/breadcrumb/breadcrumb.component.ts +68 -0
  211. package/src/lib/components/navigation/breadcrumbs/breadcrumb-item/breadcrumb-item.component.html +3 -0
  212. package/src/lib/components/navigation/breadcrumbs/breadcrumb-item/breadcrumb-item.component.spec.ts +22 -0
  213. package/src/lib/components/navigation/breadcrumbs/breadcrumb-item/breadcrumb-item.component.ts +29 -0
  214. package/src/lib/components/navigation/breadcrumbs/breadcrumbs.module.ts +11 -0
  215. package/src/lib/components/navigation/header/header.component.html +102 -0
  216. package/src/lib/components/navigation/header/header.component.scss +3 -0
  217. package/src/lib/components/navigation/header/header.component.spec.ts +21 -0
  218. package/src/lib/components/navigation/header/header.component.ts +107 -0
  219. package/src/lib/components/navigation/megamenu/megamenu.component.html +34 -0
  220. package/src/lib/components/navigation/megamenu/megamenu.component.scss +5 -0
  221. package/src/lib/components/navigation/megamenu/megamenu.component.ts +30 -0
  222. package/src/lib/components/navigation/navbar/navbar/navbar.component.html +28 -0
  223. package/src/lib/components/navigation/navbar/navbar/navbar.component.ts +45 -0
  224. package/src/lib/components/navigation/navbar/navbar-item/navbar-item.component.html +3 -0
  225. package/src/lib/components/navigation/navbar/navbar-item/navbar-item.component.ts +10 -0
  226. package/src/lib/components/navigation/navbar/navbar.module.ts +11 -0
  227. package/src/lib/components/navigation/navscroll/navscroll-list-item.component.ts +95 -0
  228. package/src/lib/components/navigation/navscroll/navscroll-list-items.component.ts +27 -0
  229. package/src/lib/components/navigation/navscroll/navscroll.component.html +101 -0
  230. package/src/lib/components/navigation/navscroll/navscroll.component.scss +9 -0
  231. package/src/lib/components/navigation/navscroll/navscroll.component.ts +143 -0
  232. package/{lib/components/navigation/navscroll/navscroll.model.d.ts → src/lib/components/navigation/navscroll/navscroll.model.ts} +7 -5
  233. package/src/lib/components/navigation/navscroll/navscroll.store.ts +96 -0
  234. package/src/lib/components/navigation/navscroll/navscroll.utils.ts +28 -0
  235. package/src/lib/components/navigation/sidebar/sidebar.component.html +11 -0
  236. package/src/lib/components/navigation/sidebar/sidebar.component.spec.ts +21 -0
  237. package/src/lib/components/navigation/sidebar/sidebar.component.ts +39 -0
  238. package/src/lib/components/navigation/skiplink/skiplink/skiplink.component.html +15 -0
  239. package/src/lib/components/navigation/skiplink/skiplink/skiplink.component.ts +27 -0
  240. package/src/lib/components/navigation/skiplink/skiplink-item/skiplink-item.component.html +15 -0
  241. package/src/lib/components/navigation/skiplink/skiplink-item/skiplink-item.component.ts +38 -0
  242. package/src/lib/components/navigation/skiplink/skiplink.module.ts +11 -0
  243. package/src/lib/components/utils/error-page/error-page.component.html +33 -0
  244. package/src/lib/components/utils/error-page/error-page.component.spec.ts +21 -0
  245. package/src/lib/components/utils/error-page/error-page.component.ts +79 -0
  246. package/src/lib/components/utils/icon/icon.component.html +6 -0
  247. package/src/lib/components/utils/icon/icon.component.spec.ts +21 -0
  248. package/src/lib/components/utils/icon/icon.component.ts +95 -0
  249. package/src/lib/components/utils/language-switcher/language-switcher.component.html +21 -0
  250. package/src/lib/components/utils/language-switcher/language-switcher.component.spec.ts +21 -0
  251. package/src/lib/components/utils/language-switcher/language-switcher.component.ts +56 -0
  252. package/src/lib/design-angular-kit.module.ts +131 -0
  253. package/src/lib/enums/colors.enums.ts +10 -0
  254. package/src/lib/enums/sizes.enum.ts +7 -0
  255. package/{lib/interfaces/core.d.ts → src/lib/interfaces/core.ts} +95 -53
  256. package/src/lib/interfaces/design-angular-kit-config.ts +34 -0
  257. package/src/lib/interfaces/form.ts +78 -0
  258. package/src/lib/interfaces/icon.ts +176 -0
  259. package/src/lib/interfaces/sortable-table.ts +42 -0
  260. package/src/lib/interfaces/utils.ts +11 -0
  261. package/src/lib/pipes/date-ago.pipe.ts +57 -0
  262. package/src/lib/pipes/duration.pipe.ts +112 -0
  263. package/src/lib/pipes/mark-matching-text.pipe.ts +43 -0
  264. package/src/lib/provide-design-angular-kit.ts +73 -0
  265. package/src/lib/services/notification/notification.service.spec.ts +16 -0
  266. package/src/lib/services/notification/notification.service.ts +119 -0
  267. package/{lib/utils/coercion.d.ts → src/lib/utils/coercion.ts} +7 -1
  268. package/src/lib/utils/date-utils.ts +184 -0
  269. package/src/lib/utils/file-utils.ts +80 -0
  270. package/src/lib/utils/regex.ts +44 -0
  271. package/src/lib/validators/it-validators.ts +193 -0
  272. package/{public_api.d.ts → src/public_api.ts} +43 -0
  273. package/src/test.ts +26 -0
  274. package/tsconfig.lib.json +24 -0
  275. package/tsconfig.lib.prod.json +9 -0
  276. package/tsconfig.schematics.json +25 -0
  277. package/tsconfig.spec.json +9 -0
  278. package/README.md +0 -461
  279. package/esm2022/design-angular-kit.mjs +0 -5
  280. package/esm2022/lib/abstracts/abstract-form.component.mjs +0 -186
  281. package/esm2022/lib/abstracts/abstract.component.mjs +0 -46
  282. package/esm2022/lib/components/core/accordion/accordion.component.mjs +0 -39
  283. package/esm2022/lib/components/core/alert/alert.component.mjs +0 -71
  284. package/esm2022/lib/components/core/avatar/avatar-dropdown/avatar-dropdown.component.mjs +0 -43
  285. package/esm2022/lib/components/core/avatar/avatar-group/avatar-group.component.mjs +0 -40
  286. package/esm2022/lib/components/core/avatar/avatar.directive.mjs +0 -78
  287. package/esm2022/lib/components/core/avatar/avatar.module.mjs +0 -33
  288. package/esm2022/lib/components/core/badge/badge.directive.mjs +0 -39
  289. package/esm2022/lib/components/core/button/button.directive.mjs +0 -80
  290. package/esm2022/lib/components/core/callout/callout.component.mjs +0 -64
  291. package/esm2022/lib/components/core/card/card.component.mjs +0 -59
  292. package/esm2022/lib/components/core/carousel/carousel/carousel.component.mjs +0 -84
  293. package/esm2022/lib/components/core/carousel/carousel-item/carousel-item.component.mjs +0 -19
  294. package/esm2022/lib/components/core/carousel/carousel.module.mjs +0 -18
  295. package/esm2022/lib/components/core/chip/chip.component.mjs +0 -136
  296. package/esm2022/lib/components/core/collapse/collapse.component.mjs +0 -116
  297. package/esm2022/lib/components/core/dimmer/dimmer-buttons/dimmer-buttons.component.mjs +0 -27
  298. package/esm2022/lib/components/core/dimmer/dimmer-icon/dimmer-icon.component.mjs +0 -11
  299. package/esm2022/lib/components/core/dimmer/dimmer.component.mjs +0 -55
  300. package/esm2022/lib/components/core/dimmer/dimmer.module.mjs +0 -19
  301. package/esm2022/lib/components/core/dropdown/dropdown/dropdown.component.mjs +0 -144
  302. package/esm2022/lib/components/core/dropdown/dropdown-item/dropdown-item.component.mjs +0 -61
  303. package/esm2022/lib/components/core/dropdown/dropdown.module.mjs +0 -18
  304. package/esm2022/lib/components/core/forward/forward.directive.mjs +0 -57
  305. package/esm2022/lib/components/core/link/link.component.mjs +0 -42
  306. package/esm2022/lib/components/core/list/list/list.component.mjs +0 -22
  307. package/esm2022/lib/components/core/list/list-item/list-item.component.mjs +0 -56
  308. package/esm2022/lib/components/core/list/list.module.mjs +0 -18
  309. package/esm2022/lib/components/core/modal/modal.component.mjs +0 -194
  310. package/esm2022/lib/components/core/notifications/notifications.component.mjs +0 -111
  311. package/esm2022/lib/components/core/pagination/pagination.component.mjs +0 -130
  312. package/esm2022/lib/components/core/popover/popover.directive.mjs +0 -176
  313. package/esm2022/lib/components/core/progress-bar/progress-bar.component.mjs +0 -34
  314. package/esm2022/lib/components/core/progress-button/progress-button.component.mjs +0 -25
  315. package/esm2022/lib/components/core/spinner/spinner.component.mjs +0 -30
  316. package/esm2022/lib/components/core/steppers/steppers-container/steppers-container.component.mjs +0 -116
  317. package/esm2022/lib/components/core/steppers/steppers-item/steppers-item.component.mjs +0 -20
  318. package/esm2022/lib/components/core/steppers/steppers.module.mjs +0 -18
  319. package/esm2022/lib/components/core/tab/tab-container/tab-container.component.mjs +0 -72
  320. package/esm2022/lib/components/core/tab/tab-item/tab-item.component.mjs +0 -39
  321. package/esm2022/lib/components/core/tab/tab.module.mjs +0 -18
  322. package/esm2022/lib/components/core/table/sort/sort-header/sort-header.component.mjs +0 -134
  323. package/esm2022/lib/components/core/table/sort/sort.directive.mjs +0 -123
  324. package/esm2022/lib/components/core/table/table.component.mjs +0 -45
  325. package/esm2022/lib/components/core/table/table.module.mjs +0 -19
  326. package/esm2022/lib/components/core/timeline/timeline-item/timeline-item.component.mjs +0 -90
  327. package/esm2022/lib/components/core/timeline/timeline.component.mjs +0 -36
  328. package/esm2022/lib/components/core/timeline/timeline.module.mjs +0 -18
  329. package/esm2022/lib/components/core/tooltip/tooltip.directive.mjs +0 -143
  330. package/esm2022/lib/components/form/autocomplete/autocomplete.component.mjs +0 -112
  331. package/esm2022/lib/components/form/checkbox/checkbox.component.mjs +0 -48
  332. package/esm2022/lib/components/form/form.module.mjs +0 -63
  333. package/esm2022/lib/components/form/input/input.component.mjs +0 -190
  334. package/esm2022/lib/components/form/password-input/password-input.component.mjs +0 -149
  335. package/esm2022/lib/components/form/radio-button/radio-button.component.mjs +0 -60
  336. package/esm2022/lib/components/form/range/range.component.mjs +0 -64
  337. package/esm2022/lib/components/form/rating/rating.component.mjs +0 -50
  338. package/esm2022/lib/components/form/select/select.component.mjs +0 -70
  339. package/esm2022/lib/components/form/textarea/textarea.component.mjs +0 -55
  340. package/esm2022/lib/components/form/transfer/store/transfer.reducers.mjs +0 -191
  341. package/esm2022/lib/components/form/transfer/store/transfer.state.mjs +0 -2
  342. package/esm2022/lib/components/form/transfer/store/transfer.store.mjs +0 -70
  343. package/esm2022/lib/components/form/transfer/transfer-list/transfer-list.component.mjs +0 -72
  344. package/esm2022/lib/components/form/transfer/transfer.component.mjs +0 -149
  345. package/esm2022/lib/components/form/transfer/transfer.model.mjs +0 -6
  346. package/esm2022/lib/components/form/upload-drag-drop/upload-drag-drop.component.mjs +0 -142
  347. package/esm2022/lib/components/form/upload-file-list/upload-file-list.component.mjs +0 -107
  348. package/esm2022/lib/components/navigation/back-button/back-button.component.mjs +0 -67
  349. package/esm2022/lib/components/navigation/back-to-top/back-to-top.component.mjs +0 -68
  350. package/esm2022/lib/components/navigation/breadcrumbs/breadcrumb/breadcrumb.component.mjs +0 -51
  351. package/esm2022/lib/components/navigation/breadcrumbs/breadcrumb-item/breadcrumb-item.component.mjs +0 -21
  352. package/esm2022/lib/components/navigation/breadcrumbs/breadcrumbs.module.mjs +0 -18
  353. package/esm2022/lib/components/navigation/header/header.component.mjs +0 -97
  354. package/esm2022/lib/components/navigation/megamenu/megamenu.component.mjs +0 -27
  355. package/esm2022/lib/components/navigation/navbar/navbar/navbar.component.mjs +0 -40
  356. package/esm2022/lib/components/navigation/navbar/navbar-item/navbar-item.component.mjs +0 -11
  357. package/esm2022/lib/components/navigation/navbar/navbar.module.mjs +0 -18
  358. package/esm2022/lib/components/navigation/navscroll/navscroll-list-item.component.mjs +0 -98
  359. package/esm2022/lib/components/navigation/navscroll/navscroll-list-items.component.mjs +0 -44
  360. package/esm2022/lib/components/navigation/navscroll/navscroll.component.mjs +0 -116
  361. package/esm2022/lib/components/navigation/navscroll/navscroll.model.mjs +0 -2
  362. package/esm2022/lib/components/navigation/navscroll/navscroll.store.mjs +0 -65
  363. package/esm2022/lib/components/navigation/navscroll/navscroll.utils.mjs +0 -23
  364. package/esm2022/lib/components/navigation/sidebar/sidebar.component.mjs +0 -50
  365. package/esm2022/lib/components/navigation/skiplink/skiplink/skiplink.component.mjs +0 -27
  366. package/esm2022/lib/components/navigation/skiplink/skiplink-item/skiplink-item.component.mjs +0 -26
  367. package/esm2022/lib/components/navigation/skiplink/skiplink.module.mjs +0 -18
  368. package/esm2022/lib/components/utils/error-page/error-page.component.mjs +0 -74
  369. package/esm2022/lib/components/utils/icon/icon.component.mjs +0 -58
  370. package/esm2022/lib/components/utils/language-switcher/language-switcher.component.mjs +0 -50
  371. package/esm2022/lib/design-angular-kit.module.mjs +0 -233
  372. package/esm2022/lib/enums/colors.enums.mjs +0 -12
  373. package/esm2022/lib/enums/sizes.enum.mjs +0 -9
  374. package/esm2022/lib/interfaces/core.mjs +0 -16
  375. package/esm2022/lib/interfaces/design-angular-kit-config.mjs +0 -7
  376. package/esm2022/lib/interfaces/form.mjs +0 -2
  377. package/esm2022/lib/interfaces/icon.mjs +0 -168
  378. package/esm2022/lib/interfaces/sortable-table.mjs +0 -6
  379. package/esm2022/lib/interfaces/utils.mjs +0 -2
  380. package/esm2022/lib/pipes/date-ago.pipe.mjs +0 -56
  381. package/esm2022/lib/pipes/duration.pipe.mjs +0 -115
  382. package/esm2022/lib/pipes/mark-matching-text.pipe.mjs +0 -48
  383. package/esm2022/lib/provide-design-angular-kit.mjs +0 -64
  384. package/esm2022/lib/services/notification/notification.service.mjs +0 -120
  385. package/esm2022/lib/utils/coercion.mjs +0 -18
  386. package/esm2022/lib/utils/date-utils.mjs +0 -162
  387. package/esm2022/lib/utils/file-utils.mjs +0 -73
  388. package/esm2022/lib/utils/regex.mjs +0 -35
  389. package/esm2022/lib/validators/it-validators.mjs +0 -156
  390. package/esm2022/public_api.mjs +0 -110
  391. package/fesm2022/design-angular-kit.mjs +0 -6669
  392. package/fesm2022/design-angular-kit.mjs.map +0 -1
  393. package/index.d.ts +0 -5
  394. package/lib/abstracts/abstract-form.component.d.ts +0 -87
  395. package/lib/abstracts/abstract.component.d.ts +0 -30
  396. package/lib/components/core/accordion/accordion.component.d.ts +0 -18
  397. package/lib/components/core/alert/alert.component.d.ts +0 -44
  398. package/lib/components/core/avatar/avatar-dropdown/avatar-dropdown.component.d.ts +0 -29
  399. package/lib/components/core/avatar/avatar-group/avatar-group.component.d.ts +0 -15
  400. package/lib/components/core/avatar/avatar.directive.d.ts +0 -33
  401. package/lib/components/core/avatar/avatar.module.d.ts +0 -9
  402. package/lib/components/core/badge/badge.directive.d.ts +0 -23
  403. package/lib/components/core/button/button.directive.d.ts +0 -48
  404. package/lib/components/core/callout/callout.component.d.ts +0 -50
  405. package/lib/components/core/card/card.component.d.ts +0 -69
  406. package/lib/components/core/carousel/carousel/carousel.component.d.ts +0 -65
  407. package/lib/components/core/carousel/carousel-item/carousel-item.component.d.ts +0 -15
  408. package/lib/components/core/carousel/carousel.module.d.ts +0 -8
  409. package/lib/components/core/chip/chip.component.d.ts +0 -76
  410. package/lib/components/core/collapse/collapse.component.d.ts +0 -67
  411. package/lib/components/core/dimmer/dimmer-buttons/dimmer-buttons.component.d.ts +0 -12
  412. package/lib/components/core/dimmer/dimmer-icon/dimmer-icon.component.d.ts +0 -5
  413. package/lib/components/core/dimmer/dimmer.component.d.ts +0 -24
  414. package/lib/components/core/dimmer/dimmer.module.d.ts +0 -9
  415. package/lib/components/core/dropdown/dropdown/dropdown.component.d.ts +0 -94
  416. package/lib/components/core/dropdown/dropdown-item/dropdown-item.component.d.ts +0 -42
  417. package/lib/components/core/dropdown/dropdown.module.d.ts +0 -8
  418. package/lib/components/core/forward/forward.directive.d.ts +0 -14
  419. package/lib/components/core/link/link.component.d.ts +0 -35
  420. package/lib/components/core/list/list/list.component.d.ts +0 -24
  421. package/lib/components/core/list/list-item/list-item.component.d.ts +0 -41
  422. package/lib/components/core/list/list.module.d.ts +0 -8
  423. package/lib/components/core/modal/modal.component.d.ts +0 -135
  424. package/lib/components/core/notifications/notifications.component.d.ts +0 -45
  425. package/lib/components/core/pagination/pagination.component.d.ts +0 -92
  426. package/lib/components/core/popover/popover.directive.d.ts +0 -99
  427. package/lib/components/core/progress-bar/progress-bar.component.d.ts +0 -31
  428. package/lib/components/core/progress-button/progress-button.component.d.ts +0 -21
  429. package/lib/components/core/spinner/spinner.component.d.ts +0 -24
  430. package/lib/components/core/steppers/steppers-container/steppers-container.component.d.ts +0 -130
  431. package/lib/components/core/steppers/steppers-item/steppers-item.component.d.ts +0 -20
  432. package/lib/components/core/steppers/steppers.module.d.ts +0 -8
  433. package/lib/components/core/tab/tab-container/tab-container.component.d.ts +0 -36
  434. package/lib/components/core/tab/tab-item/tab-item.component.d.ts +0 -38
  435. package/lib/components/core/tab/tab.module.d.ts +0 -8
  436. package/lib/components/core/table/sort/sort-header/sort-header.component.d.ts +0 -72
  437. package/lib/components/core/table/sort/sort.directive.d.ts +0 -53
  438. package/lib/components/core/table/table.component.d.ts +0 -60
  439. package/lib/components/core/table/table.module.d.ts +0 -9
  440. package/lib/components/core/timeline/timeline-item/timeline-item.component.d.ts +0 -79
  441. package/lib/components/core/timeline/timeline.component.d.ts +0 -21
  442. package/lib/components/core/timeline/timeline.module.d.ts +0 -8
  443. package/lib/components/core/tooltip/tooltip.directive.d.ts +0 -82
  444. package/lib/components/form/autocomplete/autocomplete.component.d.ts +0 -59
  445. package/lib/components/form/checkbox/checkbox.component.d.ts +0 -41
  446. package/lib/components/form/form.module.d.ts +0 -18
  447. package/lib/components/form/input/input.component.d.ts +0 -95
  448. package/lib/components/form/password-input/password-input.component.d.ts +0 -80
  449. package/lib/components/form/radio-button/radio-button.component.d.ts +0 -38
  450. package/lib/components/form/range/range.component.d.ts +0 -42
  451. package/lib/components/form/rating/rating.component.d.ts +0 -24
  452. package/lib/components/form/select/select.component.d.ts +0 -36
  453. package/lib/components/form/textarea/textarea.component.d.ts +0 -34
  454. package/lib/components/form/transfer/store/transfer.reducers.d.ts +0 -103
  455. package/lib/components/form/transfer/store/transfer.state.d.ts +0 -18
  456. package/lib/components/form/transfer/store/transfer.store.d.ts +0 -23
  457. package/lib/components/form/transfer/transfer-list/transfer-list.component.d.ts +0 -48
  458. package/lib/components/form/transfer/transfer.component.d.ts +0 -75
  459. package/lib/components/form/upload-drag-drop/upload-drag-drop.component.d.ts +0 -60
  460. package/lib/components/form/upload-file-list/upload-file-list.component.d.ts +0 -62
  461. package/lib/components/navigation/back-button/back-button.component.d.ts +0 -47
  462. package/lib/components/navigation/back-to-top/back-to-top.component.d.ts +0 -50
  463. package/lib/components/navigation/breadcrumbs/breadcrumb/breadcrumb.component.d.ts +0 -28
  464. package/lib/components/navigation/breadcrumbs/breadcrumb-item/breadcrumb-item.component.d.ts +0 -23
  465. package/lib/components/navigation/breadcrumbs/breadcrumbs.module.d.ts +0 -8
  466. package/lib/components/navigation/header/header.component.d.ts +0 -36
  467. package/lib/components/navigation/megamenu/megamenu.component.d.ts +0 -22
  468. package/lib/components/navigation/navbar/navbar/navbar.component.d.ts +0 -16
  469. package/lib/components/navigation/navbar/navbar-item/navbar-item.component.d.ts +0 -5
  470. package/lib/components/navigation/navbar/navbar.module.d.ts +0 -8
  471. package/lib/components/navigation/navscroll/navscroll-list-item.component.d.ts +0 -16
  472. package/lib/components/navigation/navscroll/navscroll-list-items.component.d.ts +0 -7
  473. package/lib/components/navigation/navscroll/navscroll.component.d.ts +0 -47
  474. package/lib/components/navigation/navscroll/navscroll.store.d.ts +0 -16
  475. package/lib/components/navigation/navscroll/navscroll.utils.d.ts +0 -6
  476. package/lib/components/navigation/sidebar/sidebar.component.d.ts +0 -26
  477. package/lib/components/navigation/skiplink/skiplink/skiplink.component.d.ts +0 -17
  478. package/lib/components/navigation/skiplink/skiplink-item/skiplink-item.component.d.ts +0 -24
  479. package/lib/components/navigation/skiplink/skiplink.module.d.ts +0 -8
  480. package/lib/components/utils/error-page/error-page.component.d.ts +0 -44
  481. package/lib/components/utils/icon/icon.component.d.ts +0 -48
  482. package/lib/components/utils/language-switcher/language-switcher.component.d.ts +0 -27
  483. package/lib/design-angular-kit.module.d.ts +0 -53
  484. package/lib/enums/colors.enums.d.ts +0 -10
  485. package/lib/enums/sizes.enum.d.ts +0 -7
  486. package/lib/interfaces/design-angular-kit-config.d.ts +0 -30
  487. package/lib/interfaces/form.d.ts +0 -67
  488. package/lib/interfaces/icon.d.ts +0 -4
  489. package/lib/interfaces/sortable-table.d.ts +0 -33
  490. package/lib/interfaces/utils.d.ts +0 -10
  491. package/lib/pipes/date-ago.pipe.d.ts +0 -17
  492. package/lib/pipes/duration.pipe.d.ts +0 -35
  493. package/lib/pipes/mark-matching-text.pipe.d.ts +0 -18
  494. package/lib/provide-design-angular-kit.d.ts +0 -7
  495. package/lib/services/notification/notification.service.d.ts +0 -63
  496. package/lib/utils/date-utils.d.ts +0 -79
  497. package/lib/utils/file-utils.d.ts +0 -32
  498. package/lib/utils/regex.d.ts +0 -34
  499. package/lib/validators/it-validators.d.ts +0 -69
  500. package/schematics/ng-add/index.d.ts +0 -3
  501. package/schematics/ng-add/index.js +0 -29
  502. package/schematics/ng-add/index.js.map +0 -1
  503. package/schematics/ng-add/index.spec.d.ts +0 -1
  504. package/schematics/ng-add/index.spec.js +0 -43
  505. package/schematics/ng-add/index.spec.js.map +0 -1
  506. package/schematics/ng-add/rules/setup-project/add-animations.d.ts +0 -2
  507. package/schematics/ng-add/rules/setup-project/add-animations.js +0 -11
  508. package/schematics/ng-add/rules/setup-project/add-animations.js.map +0 -1
  509. package/schematics/ng-add/rules/setup-project/add-assets.d.ts +0 -3
  510. package/schematics/ng-add/rules/setup-project/add-assets.js +0 -50
  511. package/schematics/ng-add/rules/setup-project/add-assets.js.map +0 -1
  512. package/schematics/ng-add/rules/setup-project/add-design-angular-kit.d.ts +0 -3
  513. package/schematics/ng-add/rules/setup-project/add-design-angular-kit.js +0 -43
  514. package/schematics/ng-add/rules/setup-project/add-design-angular-kit.js.map +0 -1
  515. package/schematics/ng-add/rules/setup-project/add-http-client.d.ts +0 -2
  516. package/schematics/ng-add/rules/setup-project/add-http-client.js +0 -11
  517. package/schematics/ng-add/rules/setup-project/add-http-client.js.map +0 -1
  518. package/schematics/ng-add/rules/setup-project/add-import-to-style-file.d.ts +0 -11
  519. package/schematics/ng-add/rules/setup-project/add-import-to-style-file.js +0 -112
  520. package/schematics/ng-add/rules/setup-project/add-import-to-style-file.js.map +0 -1
  521. package/schematics/ng-add/rules/setup-project/add-localisation.d.ts +0 -3
  522. package/schematics/ng-add/rules/setup-project/add-localisation.js +0 -50
  523. package/schematics/ng-add/rules/setup-project/add-localisation.js.map +0 -1
  524. package/schematics/ng-add/rules/setup-project/angular-json-helper.d.ts +0 -2
  525. package/schematics/ng-add/rules/setup-project/angular-json-helper.js +0 -13
  526. package/schematics/ng-add/rules/setup-project/angular-json-helper.js.map +0 -1
  527. package/schematics/ng-add/rules/setup-project/exceptions.d.ts +0 -7
  528. package/schematics/ng-add/rules/setup-project/exceptions.js +0 -17
  529. package/schematics/ng-add/rules/setup-project/exceptions.js.map +0 -1
  530. package/schematics/ng-add/rules/setup-project/index.js +0 -23
  531. package/schematics/ng-add/rules/setup-project/index.js.map +0 -1
  532. package/schematics/ng-add/schema.js +0 -3
  533. package/schematics/ng-add/schema.js.map +0 -1
  534. package/schematics/ng-add/setup-project.d.ts +0 -3
  535. package/schematics/ng-add/setup-project.js +0 -37
  536. package/schematics/ng-add/setup-project.js.map +0 -1
  537. package/schematics/ng-add/setup-project.spec.d.ts +0 -1
  538. package/schematics/ng-add/setup-project.spec.js +0 -139
  539. package/schematics/ng-add/setup-project.spec.js.map +0 -1
  540. package/schematics/ng-add/utils.d.ts +0 -14
  541. package/schematics/ng-add/utils.js +0 -49
  542. package/schematics/ng-add/utils.js.map +0 -1
  543. package/schematics/ng-add/versions-helper.d.ts +0 -3
  544. package/schematics/ng-add/versions-helper.js +0 -40
  545. package/schematics/ng-add/versions-helper.js.map +0 -1
  546. /package/schematics/ng-add/rules/setup-project/{index.d.ts → index.ts} +0 -0
@@ -0,0 +1,159 @@
1
+ import { AsyncPipe, NgClass } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, DestroyRef, EventEmitter, inject, Input, OnInit, Optional, Output, Self } from '@angular/core';
3
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
+ import { FormControlName, NgControl, NgModel, ReactiveFormsModule } from '@angular/forms';
5
+ import { TranslateService } from '@ngx-translate/core';
6
+ import { tap } from 'rxjs';
7
+ import { ItAbstractFormComponent } from '../../../abstracts/abstract-form.component';
8
+ import { TransferStore } from './store/transfer.store';
9
+ import { ItTransferListComponent } from './transfer-list/transfer-list.component';
10
+ import { TransferItem } from './transfer.model';
11
+ import { TranslateModule } from '@ngx-translate/core';
12
+ import { ItIconComponent } from '../../utils/icon/icon.component';
13
+
14
+ /**
15
+ * Transfer
16
+ * @description Component that allows the creation of checkbox lists.
17
+ */
18
+ @Component({
19
+ selector: 'it-transfer',
20
+ standalone: true,
21
+ templateUrl: './transfer.component.html',
22
+ imports: [TranslateModule, ItIconComponent, ItTransferListComponent, NgClass, AsyncPipe, ReactiveFormsModule],
23
+ providers: [TransferStore],
24
+ changeDetection: ChangeDetectionStrategy.OnPush,
25
+ })
26
+ export class ItTransferComponent<T = any> extends ItAbstractFormComponent<T> implements OnInit {
27
+ /**
28
+ * The select options (left side)
29
+ */
30
+ @Input() options = [];
31
+ /**
32
+ * The selected options (right side)
33
+ */
34
+ @Input() selected = [];
35
+ /**
36
+ * Fired when there is a transfer, a backtransfer or a reset event
37
+ */
38
+ @Output() readonly transferChanges = new EventEmitter<TransferItem<T>[]>();
39
+
40
+ /**
41
+ * Enable transfer button
42
+ * @default false
43
+ */
44
+ readonly transferEnabled = this.store.transferEnabled;
45
+ /**
46
+ * Enable backtransfer button
47
+ * @default false
48
+ */
49
+ readonly backtransferEnabled = this.store.backtransferEnabled;
50
+ /**
51
+ * Enable reset button
52
+ * @default false
53
+ */
54
+ readonly resetEnabled = this.store.resetEnabled;
55
+
56
+ private readonly destroyRef = inject(DestroyRef);
57
+
58
+ constructor(
59
+ @Self()
60
+ @Optional()
61
+ override readonly _ngControl: NgControl,
62
+ override readonly _translateService: TranslateService,
63
+ private readonly store: TransferStore<T>
64
+ ) {
65
+ super(_translateService, _ngControl);
66
+ }
67
+
68
+ override ngOnInit() {
69
+ super.ngOnInit();
70
+ this.storeInit();
71
+ this.onStoreValueChanged();
72
+ }
73
+
74
+ /**
75
+ * Transfer button click handler
76
+ */
77
+ transferClickHandler(event: MouseEvent) {
78
+ this.buttonEventHandler(event, () => this.store.transfer());
79
+ }
80
+ /**
81
+ * Transfer button keypress handler
82
+ */
83
+ transferKeyPressHandler(event: KeyboardEvent) {
84
+ this.buttonEventHandler(event, () => this.store.transfer());
85
+ }
86
+ /**
87
+ * Backtransfer button click handler
88
+ */
89
+ backtransferClickHandler(event: MouseEvent) {
90
+ this.buttonEventHandler(event, () => this.store.backtransfer());
91
+ }
92
+ /**
93
+ * Backtransfer button keypress handler
94
+ */
95
+ backtransferKeyPressHandler(event: KeyboardEvent) {
96
+ this.buttonEventHandler(event, () => this.store.backtransfer());
97
+ }
98
+ /**
99
+ * Reset button click handler
100
+ */
101
+ resetClickHandler(event: MouseEvent) {
102
+ this.buttonEventHandler(event, () => this.store.reset());
103
+ }
104
+ /**
105
+ * Reset button keypress handler
106
+ */
107
+ resetKeyPressHandler(event: KeyboardEvent) {
108
+ this.buttonEventHandler(event, () => this.store.reset());
109
+ }
110
+
111
+ private buttonEventHandler(event: Event, updateStoreCb: () => void) {
112
+ event.preventDefault();
113
+ updateStoreCb();
114
+ }
115
+
116
+ private storeInit() {
117
+ let target = [];
118
+ const ngControl = this._ngControl;
119
+ const isNgControlDefined = Boolean(this._ngControl);
120
+
121
+ // if ngControl is defined, take values from it. Input() target will be ignored
122
+ if (isNgControlDefined) {
123
+ console.debug('ngControl instanceof NgModel:', ngControl instanceof NgModel);
124
+ console.debug('ngControl instanceof FormControlName:', ngControl instanceof FormControlName);
125
+
126
+ // if ngControl is an ngModel (template-driven form use case), take values from it
127
+ if (ngControl instanceof NgModel) {
128
+ console.debug('ngControl instanceof NgModel');
129
+ const model = (ngControl as NgModel).model;
130
+ target = Array.isArray(model) ? model : [];
131
+ }
132
+
133
+ // if ngControl is an FormControlName (reactive form use case), take values from it
134
+ if (ngControl instanceof FormControlName) {
135
+ console.debug('ngControl instanceof FormControlName');
136
+ const model = (ngControl as FormControlName).control.value;
137
+ target = Array.isArray(model) ? model : [];
138
+ }
139
+
140
+ console.debug('ngControl is defined. Input() target will be ignored');
141
+ } else if (this.selected && Array.isArray(this.selected)) {
142
+ target = [...this.selected];
143
+ }
144
+
145
+ console.debug('target:', this.selected, 'formControl:', this.control.value, 'ngModel:', this._ngControl);
146
+ this.store.init({ source: [...this.options], target });
147
+ }
148
+
149
+ private onStoreValueChanged() {
150
+ this.store.valueChanged
151
+ .pipe(
152
+ takeUntilDestroyed(this.destroyRef),
153
+ tap(value => this.writeValue(value as T)),
154
+ tap(value => this.onChange(value as T)),
155
+ tap(value => this.transferChanges.emit(value))
156
+ )
157
+ .subscribe();
158
+ }
159
+ }
@@ -1,6 +1,13 @@
1
+ //Qs
2
+ //Aria hidden?
3
+ //state management with service?
4
+ //interface?
5
+
1
6
  export interface TransferItem<ValueType> {
2
- text: string;
3
- value: ValueType;
7
+ text: string;
8
+ value: ValueType;
4
9
  }
10
+
5
11
  export type TransferItemSelection<ValueType> = Array<TransferItem<ValueType>>;
12
+
6
13
  export type SourceType = 'source' | 'target';
@@ -0,0 +1,36 @@
1
+ <div class="upload-dragdrop" [class.dragover]="isDragover" [class.loading]="isLoading" [class.success]="isSuccess">
2
+ <div class="upload-dragdrop-image">
3
+ <img
4
+ [ngSrc]="assetBasePath + '/dist/assets/upload-drag-drop-icon.svg'"
5
+ alt="drag-drop-icon"
6
+ aria-hidden="true"
7
+ [width]="180"
8
+ [height]="180" />
9
+ <div class="upload-dragdrop-loading">
10
+ <div class="progress-donut" #donutElement></div>
11
+ </div>
12
+ <div class="upload-dragdrop-success">
13
+ <it-icon name="check"></it-icon>
14
+ </div>
15
+ </div>
16
+ <div class="upload-dragdrop-text">
17
+ <p class="upload-dragdrop-weight">
18
+ <it-icon name="file" size="xs"></it-icon>
19
+ {{ extension }} ({{ fileSize }})
20
+ </p>
21
+ <h5>{{ filename || ('it.form.upload-drag-file' | translate) }}</h5>
22
+ @if (isLoading) {
23
+ <p>{{ 'it.form.upload-loading' | translate }}</p>
24
+ }
25
+ @if (isSuccess) {
26
+ <p>{{ 'it.form.upload-complete' | translate }}</p>
27
+ }
28
+ @if (!isLoading && !isSuccess) {
29
+ <p>
30
+ {{ 'it.form.upload-or' | translate }}
31
+ <input type="file" [id]="id" class="upload-dragdrop-input" [accept]="accept" (change)="onLoadFile($event)" />
32
+ <label [for]="id">{{ 'it.form.upload-select-device' | translate }}</label>
33
+ </p>
34
+ }
35
+ </div>
36
+ </div>
@@ -0,0 +1,21 @@
1
+ import { ComponentFixture, TestBed } from '@angular/core/testing';
2
+
3
+ import { ItUploadDragDropComponent } from './upload-drag-drop.component';
4
+ import { tb_base } from '../../../../test';
5
+
6
+ describe('ItUploadDragDropComponent', () => {
7
+ let component: ItUploadDragDropComponent;
8
+ let fixture: ComponentFixture<ItUploadDragDropComponent>;
9
+
10
+ beforeEach(async () => {
11
+ await TestBed.configureTestingModule(tb_base).compileComponents();
12
+
13
+ fixture = TestBed.createComponent(ItUploadDragDropComponent);
14
+ component = fixture.componentInstance;
15
+ fixture.detectChanges();
16
+ });
17
+
18
+ it('should create', () => {
19
+ expect(component).toBeTruthy();
20
+ });
21
+ });
@@ -0,0 +1,170 @@
1
+ import {
2
+ AfterViewInit,
3
+ ChangeDetectionStrategy,
4
+ Component,
5
+ ElementRef,
6
+ EventEmitter,
7
+ HostListener,
8
+ inject,
9
+ Input,
10
+ Output,
11
+ ViewChild,
12
+ } from '@angular/core';
13
+ import { ItAbstractComponent } from '../../../abstracts/abstract.component';
14
+ import { ItFileUtils } from '../../../utils/file-utils';
15
+ import { ProgressDonut } from 'bootstrap-italia';
16
+ import { ItIconComponent } from '../../utils/icon/icon.component';
17
+ import { NgOptimizedImage } from '@angular/common';
18
+ import { TranslateModule } from '@ngx-translate/core';
19
+ import { IT_ASSET_BASE_PATH } from '../../../interfaces/design-angular-kit-config';
20
+
21
+ @Component({
22
+ standalone: true,
23
+ selector: 'it-upload-drag-drop',
24
+ templateUrl: './upload-drag-drop.component.html',
25
+ exportAs: 'itUploadDragDrop',
26
+ changeDetection: ChangeDetectionStrategy.OnPush,
27
+ imports: [ItIconComponent, TranslateModule, NgOptimizedImage],
28
+ })
29
+ export class ItUploadDragDropComponent extends ItAbstractComponent implements AfterViewInit {
30
+ /**
31
+ * The accepted file type to upload <br>
32
+ * Possible values: <a href="https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/MIME_types/Common_types">MIME Types</a> separated by comma
33
+ * @example application/pdf,image/png
34
+ * @default *
35
+ */
36
+ @Input() accept: string = '*';
37
+
38
+ /**
39
+ * Fired when file start to upload
40
+ */
41
+ @Output() fileStartUpload = new EventEmitter<File>();
42
+
43
+ protected isDragover: boolean = false;
44
+ protected isLoading: boolean = false;
45
+ protected isSuccess: boolean = false;
46
+
47
+ protected donut?: ProgressDonut;
48
+
49
+ @ViewChild('donutElement') private donutElement?: ElementRef<HTMLDivElement>;
50
+
51
+ protected filename?: string;
52
+ protected extension?: string;
53
+ protected fileSize?: string;
54
+
55
+ /**
56
+ * The bootstrap-italia asset folder path
57
+ * @default ./bootstrap-italia
58
+ */
59
+ protected assetBasePath: string;
60
+
61
+ constructor() {
62
+ super();
63
+ this.assetBasePath = inject(IT_ASSET_BASE_PATH);
64
+ }
65
+
66
+ override ngAfterViewInit(): void {
67
+ super.ngAfterViewInit();
68
+ if (this.donutElement) {
69
+ this.donut = ProgressDonut.getOrCreateInstance(this.donutElement.nativeElement);
70
+ }
71
+ }
72
+
73
+ // Dragover listener
74
+ @HostListener('dragover', ['$event'])
75
+ public onDragOver(evt: DragEvent): void {
76
+ evt.preventDefault();
77
+ evt.stopPropagation();
78
+ this.isDragover = !this.isLoading;
79
+ }
80
+
81
+ // Dragleave listener
82
+ @HostListener('dragleave', ['$event'])
83
+ public onDragLeave(evt: DragEvent): void {
84
+ evt.preventDefault();
85
+ evt.stopPropagation();
86
+ this.isDragover = false;
87
+ }
88
+
89
+ // Drop leave listener
90
+ @HostListener('drop', ['$event'])
91
+ public onDrop(evt: DragEvent): void {
92
+ evt.preventDefault();
93
+ evt.stopPropagation();
94
+
95
+ this.isDragover = false;
96
+ const files = evt.dataTransfer?.files;
97
+ if (this.isLoading || !files?.length) {
98
+ return;
99
+ }
100
+ this.start(files[0]);
101
+ }
102
+
103
+ /**
104
+ * On load file from input
105
+ * @param event
106
+ */
107
+ onLoadFile(event: Event): void {
108
+ const files = (event.target as HTMLInputElement)?.files;
109
+ if (!files?.length) {
110
+ return;
111
+ }
112
+ this.start(files[0]);
113
+ }
114
+
115
+ /**
116
+ * Start the upload file
117
+ * @param file
118
+ */
119
+ public start(file: File): void {
120
+ if (this.accept !== '*' && !this.accept.includes(file.type)) {
121
+ return;
122
+ }
123
+
124
+ this.reset();
125
+ this.isLoading = true;
126
+
127
+ const splitName = file.name.split('.');
128
+ this.filename = splitName[0];
129
+ this.extension = splitName[1]?.toUpperCase();
130
+ this.fileSize = ItFileUtils.getFileSizeString(file);
131
+
132
+ this.fileStartUpload.emit(file);
133
+ }
134
+
135
+ /**
136
+ * Percentage of upload
137
+ * @param value the percentage [0 - 100]
138
+ */
139
+ public progress(value: number) {
140
+ if (!this.isLoading) {
141
+ return;
142
+ }
143
+
144
+ if (value >= 100) {
145
+ this.success();
146
+ } else {
147
+ this.donut?.set((value < 0 ? 0 : value) / 100);
148
+ }
149
+ }
150
+
151
+ /**
152
+ * Upload success
153
+ */
154
+ public success(): void {
155
+ this.isLoading = false;
156
+ this.isSuccess = true;
157
+ this._changeDetectorRef.detectChanges();
158
+ }
159
+
160
+ /**
161
+ * Reset file uploader
162
+ */
163
+ public reset(): void {
164
+ this.isLoading = false;
165
+ this.isSuccess = false;
166
+ this.filename = this.extension = this.fileSize = undefined;
167
+ this.donut?.set(0);
168
+ this._changeDetectorRef.detectChanges();
169
+ }
170
+ }
@@ -0,0 +1,46 @@
1
+ @if (!hideLoadButton) {
2
+ <input type="file" [id]="id" class="upload" [accept]="accept" [multiple]="multiple" (change)="onLoadFiles($event)" />
3
+ <label [for]="id">
4
+ <it-icon name="upload" size="sm"></it-icon>
5
+ <span>{{ 'it.form.upload' | translate }}</span>
6
+ </label>
7
+ }
8
+
9
+ @if (fileList.length) {
10
+ <ul class="upload-file-list" [class.upload-file-list-image]="images">
11
+ @for (item of fileList; track item.id) {
12
+ <li
13
+ class="upload-file"
14
+ [class.error]="item.error"
15
+ [class.uploading]="!item.error && item.progress !== undefined && item.progress > 0 && item.progress < 100"
16
+ [class.success]="!item.error && (!item.progress || item.progress >= 100)">
17
+ @if (images) {
18
+ <div class="upload-image">
19
+ <img [attr.src]="previewImages.get(item.id)" [alt]="item.file.name" />
20
+ </div>
21
+ } @else {
22
+ <it-icon name="file" size="sm" [color]="!item.error ? (item.progress ? 'secondary' : 'primary') : 'danger'"></it-icon>
23
+ }
24
+ <p [itTooltip]="item.tooltip">
25
+ <span class="visually-hidden">{{ 'it.form.uploaded-file' | translate: { name: item.file.name } }}</span>
26
+ {{ item.file.name }} <span class="upload-file-weight">{{ getFileSize(item.file) }}</span>
27
+ </p>
28
+ @if (item.removable && (!item.progress || item.progress < 100)) {
29
+ <button type="button" (click)="deleteItem.emit(item)">
30
+ <span class="visually-hidden">{{ 'it.form.delete-file' | translate: { name: item.file.name } }}</span>
31
+ <it-icon name="close"></it-icon>
32
+ </button>
33
+ }
34
+ @if ((!item.removable && !item.progress) || (item.progress !== undefined && item.progress >= 100)) {
35
+ <button type="button" disabled>
36
+ <span class="visually-hidden">{{ 'it.form.upload-complete' | translate }}</span>
37
+ <it-icon name="check"></it-icon>
38
+ </button>
39
+ }
40
+ @if (!item.error && item.progress !== undefined && item.progress > 0 && item.progress < 100) {
41
+ <it-progress-bar [value]="item.progress!"></it-progress-bar>
42
+ }
43
+ </li>
44
+ }
45
+ </ul>
46
+ }
@@ -0,0 +1,22 @@
1
+ import { ComponentFixture, TestBed } from '@angular/core/testing';
2
+
3
+ import { ItUploadFileListComponent } from './upload-file-list.component';
4
+ import { tb_base } from '../../../../test';
5
+
6
+ describe('ItUploadFileListComponent', () => {
7
+ let component: ItUploadFileListComponent;
8
+ let fixture: ComponentFixture<ItUploadFileListComponent>;
9
+
10
+ beforeEach(async () => {
11
+ await TestBed.configureTestingModule(tb_base).compileComponents();
12
+
13
+ fixture = TestBed.createComponent(ItUploadFileListComponent);
14
+ component = fixture.componentInstance;
15
+ component.fileList = [];
16
+ fixture.detectChanges();
17
+ });
18
+
19
+ it('should create', () => {
20
+ expect(component).toBeTruthy();
21
+ });
22
+ });
@@ -0,0 +1,120 @@
1
+ import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';
2
+ import { ItAbstractComponent } from '../../../abstracts/abstract.component';
3
+ import { UploadFileListItem } from '../../../interfaces/form';
4
+ import { ItFileUtils } from '../../../utils/file-utils';
5
+ import { forkJoin, take, tap } from 'rxjs';
6
+ import { ItIconComponent } from '../../utils/icon/icon.component';
7
+ import { TranslateModule } from '@ngx-translate/core';
8
+ import { ItTooltipDirective } from '../../core/tooltip/tooltip.directive';
9
+ import { ItProgressBarComponent } from '../../core/progress-bar/progress-bar.component';
10
+ import { inputToBoolean } from '../../../utils/coercion';
11
+
12
+ @Component({
13
+ standalone: true,
14
+ selector: 'it-upload-file-list',
15
+ templateUrl: './upload-file-list.component.html',
16
+ imports: [ItIconComponent, TranslateModule, ItTooltipDirective, ItProgressBarComponent],
17
+ })
18
+ export class ItUploadFileListComponent extends ItAbstractComponent implements OnInit, OnChanges {
19
+ /**
20
+ * The list of files to show in list
21
+ */
22
+ @Input({ required: true }) fileList!: Array<UploadFileListItem>;
23
+
24
+ /**
25
+ * The accepted file type to upload <br>
26
+ * Possible values: <a href="https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/MIME_types/Common_types">MIME Types</a> separated by comma
27
+ * @example application/pdf,image/png
28
+ * @default *
29
+ */
30
+ @Input() accept: string = '*';
31
+
32
+ /**
33
+ * If upload multiple files
34
+ * @default true
35
+ */
36
+ @Input({ transform: inputToBoolean }) multiple: boolean = true;
37
+
38
+ /**
39
+ * If is file list image
40
+ * @default false
41
+ */
42
+ @Input({ transform: inputToBoolean }) images?: boolean;
43
+
44
+ /**
45
+ * Hide the load button
46
+ * @default false
47
+ */
48
+ @Input({ transform: inputToBoolean }) hideLoadButton?: boolean;
49
+
50
+ /**
51
+ * Fired when upload new files
52
+ */
53
+ @Output() uploadFiles: EventEmitter<FileList> = new EventEmitter<FileList>();
54
+
55
+ /**
56
+ * Fired on delete item button click
57
+ */
58
+ @Output() deleteItem: EventEmitter<UploadFileListItem> = new EventEmitter<UploadFileListItem>();
59
+
60
+ /**
61
+ * Cache to preview image
62
+ */
63
+ previewImages: Map<number, string> = new Map<number, string>();
64
+
65
+ ngOnInit(): void {
66
+ if (!!this.images && this.accept === '*') {
67
+ this.accept = 'image/*';
68
+ }
69
+ }
70
+
71
+ override ngOnChanges(changes: SimpleChanges): void {
72
+ if (changes['fileList'] && !!this.images) {
73
+ const images$ = this.fileList.map(item =>
74
+ ItFileUtils.fileToBase64(item.file).pipe(
75
+ take(1),
76
+ tap(base64 => this.previewImages.set(item.id, base64))
77
+ )
78
+ );
79
+ forkJoin(images$).subscribe(() => {
80
+ this._changeDetectorRef.detectChanges();
81
+ super.ngOnChanges(changes);
82
+ });
83
+ } else {
84
+ super.ngOnChanges(changes);
85
+ }
86
+ }
87
+
88
+ /**
89
+ * On load file from input
90
+ * @param event
91
+ */
92
+ onLoadFiles(event: Event): void {
93
+ const input = event.target as HTMLInputElement;
94
+ const files = input?.files;
95
+ if (!files?.length) {
96
+ return;
97
+ }
98
+
99
+ const newFiles = Array.from(files).filter(
100
+ file =>
101
+ !this.fileList.some(item => {
102
+ return item.file.name === file.name && item.file.size === file.size && item.file.type === file.type;
103
+ })
104
+ );
105
+
106
+ const fileList = new DataTransfer();
107
+ newFiles.forEach(file => fileList.items.add(file));
108
+
109
+ this.uploadFiles.emit(fileList.files);
110
+ input.value = '';
111
+ }
112
+
113
+ /**
114
+ * Get the file size string
115
+ * @param file
116
+ */
117
+ getFileSize(file: File): string {
118
+ return ItFileUtils.getFileSizeString(file);
119
+ }
120
+ }
@@ -0,0 +1,25 @@
1
+ @if (buttonStyle === 'link') {
2
+ <a href="#" class="go-back" (click)="goBack($event)">
3
+ <ng-container *ngTemplateOutlet="content"></ng-container>
4
+ </a>
5
+ }
6
+
7
+ @if (buttonStyle === 'button') {
8
+ <button itButton="primary" class="go-back" (click)="goBack($event)">
9
+ <ng-container *ngTemplateOutlet="content"></ng-container>
10
+ </button>
11
+ }
12
+
13
+ <ng-template #content>
14
+ @if (showIcon) {
15
+ <it-icon
16
+ size="sm"
17
+ [name]="direction === 'left' ? 'arrow-left' : 'arrow-up'"
18
+ [color]="buttonStyle === 'link' ? 'primary' : 'white'"
19
+ [class.me-2]="showText"></it-icon>
20
+ }
21
+
22
+ <span [class.visually-hidden]="!showText">
23
+ {{ (direction === 'left' ? 'it.navigation.go-back' : 'it.navigation.upper-level') | translate }}
24
+ </span>
25
+ </ng-template>