@updevs/components 1.0.0-alpha.8 → 1.0.0-alpha.81

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 (687) hide show
  1. package/README.md +1 -11
  2. package/assets/styles/_bootstrap-components.scss +18 -1
  3. package/assets/styles/_core.scss +9 -0
  4. package/assets/styles/_debug.scss +49 -0
  5. package/assets/styles/_props.scss +91 -0
  6. package/assets/styles/_seven-columns.scss +73 -0
  7. package/assets/styles/_updevs.scss +16 -0
  8. package/assets/styles/_utilities-marketing.scss +209 -0
  9. package/assets/styles/_utilities.scss +127 -92
  10. package/assets/styles/_variables-dark.scss +8 -6
  11. package/assets/styles/_variables.scss +325 -256
  12. package/assets/styles/helpers/_index.scss +143 -0
  13. package/assets/styles/layout/_core.scss +3 -2
  14. package/assets/styles/layout/_dark.scss +40 -35
  15. package/assets/styles/layout/_footer.scss +1 -1
  16. package/assets/styles/layout/_navbar.scss +31 -19
  17. package/assets/styles/layout/_page.scss +6 -5
  18. package/assets/styles/layout/_root.scss +26 -34
  19. package/assets/styles/marketing/_browser.scss +67 -0
  20. package/assets/styles/marketing/_core.scss +8 -0
  21. package/assets/styles/marketing/_filters.scss +0 -0
  22. package/assets/styles/marketing/_hero.scss +70 -0
  23. package/assets/styles/marketing/_pricing.scss +111 -0
  24. package/assets/styles/marketing/_sections.scss +124 -0
  25. package/assets/styles/marketing/_shape.scss +31 -0
  26. package/assets/styles/mixins/_functions.scss +53 -0
  27. package/assets/styles/mixins/_mixins.scss +9 -9
  28. package/assets/styles/ui/_accordion.scss +165 -11
  29. package/assets/styles/ui/_alerts.scss +80 -38
  30. package/assets/styles/ui/_avatars.scss +36 -9
  31. package/assets/styles/ui/_badges.scss +47 -13
  32. package/assets/styles/ui/_button-group.scss +1 -1
  33. package/assets/styles/ui/_buttons.scss +33 -37
  34. package/assets/styles/ui/_calendars.scss +2 -2
  35. package/assets/styles/ui/_cards.scss +9 -0
  36. package/assets/styles/ui/_carousel.scss +1 -1
  37. package/assets/styles/ui/_charts.scss +1 -1
  38. package/assets/styles/ui/_chat.scss +38 -0
  39. package/assets/styles/ui/_close.scss +54 -1
  40. package/assets/styles/ui/_datagrid.scss +1 -1
  41. package/assets/styles/ui/_dropdowns.scss +3 -0
  42. package/assets/styles/ui/_empty.scss +0 -5
  43. package/assets/styles/ui/_flags.scss +2 -2
  44. package/assets/styles/ui/_forms.scss +33 -7
  45. package/assets/styles/ui/_grid.scss +1 -1
  46. package/assets/styles/ui/_icons.scss +1 -1
  47. package/assets/styles/ui/_images.scss +4 -0
  48. package/assets/styles/ui/_lists.scss +12 -16
  49. package/assets/styles/ui/_loaders.scss +1 -1
  50. package/assets/styles/ui/_markdown.scss +15 -4
  51. package/assets/styles/ui/_modals.scss +2 -2
  52. package/assets/styles/ui/_nav.scss +17 -3
  53. package/assets/styles/ui/_offcanvas.scss +2 -2
  54. package/assets/styles/ui/_pagination.scss +2 -0
  55. package/assets/styles/ui/_payments.scss +1 -1
  56. package/assets/styles/ui/_placeholder.scss +1 -1
  57. package/assets/styles/ui/_progress.scss +1 -1
  58. package/assets/styles/ui/_ribbons.scss +1 -0
  59. package/assets/styles/ui/_segmented.scss +101 -0
  60. package/assets/styles/ui/_signature.scss +15 -0
  61. package/assets/styles/ui/_social.scss +52 -0
  62. package/assets/styles/ui/_status.scss +1 -1
  63. package/assets/styles/ui/_steps.scss +5 -1
  64. package/assets/styles/ui/_switch-icon.scss +1 -1
  65. package/assets/styles/ui/_tables.scss +27 -1
  66. package/assets/styles/ui/_tags.scss +1 -1
  67. package/assets/styles/ui/_timeline.scss +1 -1
  68. package/assets/styles/ui/_toasts.scss +0 -1
  69. package/assets/styles/ui/_tracking.scss +1 -1
  70. package/assets/styles/ui/_type.scss +169 -8
  71. package/assets/styles/ui/forms/_form-check.scss +1 -1
  72. package/assets/styles/ui/forms/_form-colorinput.scss +1 -1
  73. package/assets/styles/ui/forms/_form-custom.scss +1 -1
  74. package/assets/styles/ui/forms/_form-imagecheck.scss +6 -5
  75. package/assets/styles/ui/forms/_form-selectgroup.scss +2 -2
  76. package/assets/styles/ui/typo/_hr.scss +4 -2
  77. package/assets/styles/utils/_colors.scss +72 -11
  78. package/assets/styles/utils/_opacity.scss +1 -1
  79. package/assets/styles/utils/_scroll.scss +0 -2
  80. package/assets/styles/utils/_sizing.scss +1 -1
  81. package/assets/styles/utils/_text.scss +1 -2
  82. package/assets/styles/vendor/_apexcharts.scss +52 -0
  83. package/assets/styles/vendor/_coloris.scss +72 -0
  84. package/assets/styles/vendor/_dropzone.scss +27 -0
  85. package/assets/styles/vendor/_fslightbox.scss +13 -0
  86. package/assets/styles/vendor/_jsvectormap.scss +47 -0
  87. package/assets/styles/vendor/_litepicker.scss +69 -0
  88. package/assets/styles/vendor/_nouislider.scss +49 -0
  89. package/assets/styles/vendor/_plyr.scss +3 -0
  90. package/assets/styles/vendor/_stars-rating.scss +22 -0
  91. package/assets/styles/vendor/_tom-select.scss +81 -0
  92. package/assets/styles/vendor/_turbo.scss +3 -0
  93. package/assets/styles/vendor/_typed.scss +4 -0
  94. package/assets/styles/vendor/_wysiwyg.scss +46 -0
  95. package/badge/badge-config.model.d.ts +14 -0
  96. package/badge/badge.component.d.ts +23 -0
  97. package/badge/badge.config.d.ts +12 -0
  98. package/badge/index.d.ts +1 -0
  99. package/badge/public-api.d.ts +3 -0
  100. package/badge/upd-badge.module.d.ts +8 -0
  101. package/button/button.component.d.ts +51 -33
  102. package/button/upd-button.module.d.ts +3 -1
  103. package/calendar/calendar.component.d.ts +63 -0
  104. package/calendar/index.d.ts +1 -0
  105. package/calendar/models/calendar-date.model.d.ts +10 -0
  106. package/calendar/models/calendar-month.model.d.ts +7 -0
  107. package/calendar/models/calendar-selected.model.d.ts +5 -0
  108. package/calendar/models/calendar-user-event.model.d.ts +4 -0
  109. package/calendar/models/calendar-year.model.d.ts +6 -0
  110. package/calendar/models/date-range.model.d.ts +22 -0
  111. package/calendar/models/enums/calendar-view.enum.d.ts +5 -0
  112. package/calendar/models/public-api.d.ts +7 -0
  113. package/calendar/public-api.d.ts +5 -0
  114. package/calendar/services/calendar-range-strategy.service.d.ts +35 -0
  115. package/calendar/services/calendar-signals.service.d.ts +24 -0
  116. package/calendar/services/public-api.d.ts +1 -0
  117. package/calendar/types/calendar-view.type.d.ts +1 -0
  118. package/calendar/types/public-api.d.ts +1 -0
  119. package/calendar/upd-calendar.module.d.ts +13 -0
  120. package/card/card.component.d.ts +2 -2
  121. package/card/public-api.d.ts +1 -0
  122. package/card/types/public-api.d.ts +5 -0
  123. package/drag-and-drop/drag-and-drop.component.d.ts +26 -0
  124. package/drag-and-drop/index.d.ts +1 -0
  125. package/drag-and-drop/models/drag-and-drop-column.config.d.ts +8 -0
  126. package/drag-and-drop/models/drag-and-drop-column.model.d.ts +10 -0
  127. package/drag-and-drop/models/drag-and-drop-item.d.ts +7 -0
  128. package/drag-and-drop/models/drag-and-drop-item.model.d.ts +13 -0
  129. package/drag-and-drop/models/drag-and-drop.config.d.ts +6 -0
  130. package/drag-and-drop/models/public-api.d.ts +4 -0
  131. package/drag-and-drop/public-api.d.ts +3 -0
  132. package/drag-and-drop/upd-drag-and-drop.module.d.ts +9 -0
  133. package/dropdown/dropdown.component.d.ts +23 -6
  134. package/dropdown/models/dropdown-action-clicked.model.d.ts +6 -0
  135. package/dropdown/models/dropdown-item.d.ts +7 -2
  136. package/dropdown/models/dropdown-item.type.d.ts +1 -1
  137. package/dropdown/models/public-api.d.ts +2 -0
  138. package/dropdown/models/toolbar.type.d.ts +1 -0
  139. package/esm2022/badge/badge-config.model.mjs +14 -0
  140. package/esm2022/badge/badge.component.mjs +48 -0
  141. package/esm2022/badge/badge.config.mjs +2 -0
  142. package/esm2022/badge/index.mjs +2 -0
  143. package/esm2022/badge/public-api.mjs +4 -0
  144. package/esm2022/badge/upd-badge.module.mjs +24 -0
  145. package/esm2022/badge/updevs-components-badge.mjs +5 -0
  146. package/esm2022/button/button.component.mjs +126 -132
  147. package/esm2022/button/index.mjs +1 -1
  148. package/esm2022/button/public-api.mjs +1 -1
  149. package/esm2022/button/upd-button.module.mjs +14 -6
  150. package/esm2022/button/updevs-components-button.mjs +1 -1
  151. package/esm2022/calendar/assets/i18n/en.json +16 -0
  152. package/esm2022/calendar/assets/i18n/pt.json +16 -0
  153. package/esm2022/calendar/calendar.component.mjs +318 -0
  154. package/esm2022/calendar/index.mjs +2 -0
  155. package/esm2022/calendar/models/calendar-date.model.mjs +2 -0
  156. package/esm2022/calendar/models/calendar-month.model.mjs +2 -0
  157. package/esm2022/calendar/models/calendar-selected.model.mjs +2 -0
  158. package/esm2022/calendar/models/calendar-user-event.model.mjs +2 -0
  159. package/esm2022/calendar/models/calendar-year.model.mjs +2 -0
  160. package/esm2022/calendar/models/date-range.model.mjs +18 -0
  161. package/esm2022/calendar/models/enums/calendar-view.enum.mjs +7 -0
  162. package/esm2022/calendar/models/public-api.mjs +8 -0
  163. package/esm2022/calendar/public-api.mjs +6 -0
  164. package/esm2022/calendar/services/calendar-range-strategy.service.mjs +99 -0
  165. package/esm2022/calendar/services/calendar-signals.service.mjs +47 -0
  166. package/esm2022/calendar/services/public-api.mjs +2 -0
  167. package/esm2022/calendar/types/calendar-view.type.mjs +2 -0
  168. package/esm2022/calendar/types/public-api.mjs +2 -0
  169. package/esm2022/calendar/upd-calendar.module.mjs +52 -0
  170. package/esm2022/calendar/updevs-components-calendar.mjs +5 -0
  171. package/esm2022/card/card.component.mjs +4 -4
  172. package/esm2022/card/directives/card-actions.directive.mjs +4 -4
  173. package/esm2022/card/directives/card-footer.directive.mjs +4 -4
  174. package/esm2022/card/directives/card-header.directive.mjs +4 -4
  175. package/esm2022/card/directives/card-image.directive.mjs +4 -4
  176. package/esm2022/card/directives/public-api.mjs +1 -1
  177. package/esm2022/card/index.mjs +1 -1
  178. package/esm2022/card/public-api.mjs +2 -1
  179. package/esm2022/card/types/card-state.type.mjs +1 -1
  180. package/esm2022/card/types/card-style.type.mjs +1 -1
  181. package/esm2022/card/types/hover-effect.type.mjs +1 -1
  182. package/esm2022/card/types/public-api.mjs +6 -0
  183. package/esm2022/card/types/ribbon-style.type.mjs +1 -1
  184. package/esm2022/card/types/status-position.type.mjs +1 -1
  185. package/esm2022/card/upd-card.module.mjs +5 -5
  186. package/esm2022/card/updevs-components-card.mjs +1 -1
  187. package/esm2022/drag-and-drop/drag-and-drop.component.mjs +134 -0
  188. package/esm2022/drag-and-drop/index.mjs +2 -0
  189. package/esm2022/drag-and-drop/models/drag-and-drop-column.config.mjs +2 -0
  190. package/esm2022/drag-and-drop/models/drag-and-drop-column.model.mjs +9 -0
  191. package/esm2022/drag-and-drop/models/drag-and-drop-item.mjs +2 -0
  192. package/esm2022/drag-and-drop/models/drag-and-drop-item.model.mjs +14 -0
  193. package/esm2022/drag-and-drop/models/drag-and-drop.config.mjs +2 -0
  194. package/esm2022/drag-and-drop/models/public-api.mjs +5 -0
  195. package/esm2022/drag-and-drop/public-api.mjs +4 -0
  196. package/esm2022/drag-and-drop/upd-drag-and-drop.module.mjs +28 -0
  197. package/esm2022/drag-and-drop/updevs-components-drag-and-drop.mjs +5 -0
  198. package/esm2022/dropdown/dropdown.component.mjs +79 -21
  199. package/esm2022/dropdown/index.mjs +1 -1
  200. package/esm2022/dropdown/models/dropdown-action-clicked.model.mjs +2 -0
  201. package/esm2022/dropdown/models/dropdown-item.mjs +1 -1
  202. package/esm2022/dropdown/models/dropdown-item.type.mjs +1 -1
  203. package/esm2022/dropdown/models/public-api.mjs +3 -1
  204. package/esm2022/dropdown/models/toolbar.type.mjs +2 -0
  205. package/esm2022/dropdown/public-api.mjs +1 -1
  206. package/esm2022/dropdown/upd-dropdown.module.mjs +5 -5
  207. package/esm2022/dropdown/updevs-components-dropdown.mjs +1 -1
  208. package/esm2022/form/assets/i18n/en.json +17 -0
  209. package/esm2022/form/assets/i18n/pt.json +17 -0
  210. package/esm2022/form/components/dynamic-field/dynamic-field.component.mjs +166 -0
  211. package/esm2022/form/form.component.mjs +180 -0
  212. package/esm2022/form/index.mjs +1 -1
  213. package/esm2022/form/models/attachment-rule.model.mjs +2 -0
  214. package/esm2022/form/models/button-field.model.mjs +2 -0
  215. package/esm2022/form/models/button-group-field.model.mjs +2 -0
  216. package/esm2022/form/models/checkbox-field.model.mjs +2 -0
  217. package/esm2022/form/models/checkbox-group-field.model.mjs +2 -0
  218. package/esm2022/form/models/dynamic-field.model.mjs +2 -0
  219. package/esm2022/form/models/enums/attachment-type.enum.mjs +15 -0
  220. package/esm2022/form/models/enums/dynamic-field.type.mjs +17 -0
  221. package/esm2022/form/models/enums/public-api.mjs +3 -0
  222. package/esm2022/form/models/file-upload-field.model.mjs +2 -0
  223. package/esm2022/form/models/form-config.mjs +2 -0
  224. package/esm2022/form/models/form-row.model.mjs +2 -0
  225. package/esm2022/form/models/form-update-on.type.mjs +2 -0
  226. package/esm2022/form/models/input-field.model.mjs +2 -0
  227. package/esm2022/form/models/masked-input-field.model.mjs +2 -0
  228. package/esm2022/form/models/public-api.mjs +19 -0
  229. package/esm2022/form/models/radio-field.model.mjs +2 -0
  230. package/esm2022/form/models/radio-group-field.model.mjs +2 -0
  231. package/esm2022/form/models/select-field.model.mjs +2 -0
  232. package/esm2022/form/models/single-select-field.model.mjs +2 -0
  233. package/esm2022/form/models/textarea-field.model.mjs +2 -0
  234. package/esm2022/form/models/validator-config.mjs +2 -0
  235. package/esm2022/form/public-api.mjs +4 -2
  236. package/esm2022/form/tools/errors-helper.mjs +54 -0
  237. package/esm2022/form/upd-form.module.mjs +84 -0
  238. package/esm2022/form/updevs-components-form.mjs +1 -1
  239. package/esm2022/form-controls/abstractions/base-control.mjs +46 -0
  240. package/esm2022/form-controls/abstractions/index.mjs +2 -0
  241. package/esm2022/form-controls/abstractions/public-api.mjs +2 -0
  242. package/esm2022/form-controls/abstractions/updevs-components-form-controls-abstractions.mjs +5 -0
  243. package/esm2022/form-controls/checkbox/checkbox.component.mjs +37 -51
  244. package/esm2022/form-controls/checkbox/index.mjs +1 -1
  245. package/esm2022/form-controls/checkbox/public-api.mjs +1 -1
  246. package/esm2022/form-controls/checkbox/upd-checkbox.module.mjs +12 -8
  247. package/esm2022/form-controls/checkbox/updevs-components-form-controls-checkbox.mjs +1 -1
  248. package/esm2022/form-controls/date-picker/date-picker.component.mjs +132 -0
  249. package/esm2022/form-controls/date-picker/index.mjs +2 -0
  250. package/esm2022/form-controls/date-picker/public-api.mjs +3 -0
  251. package/esm2022/form-controls/date-picker/upd-date-picker.module.mjs +40 -0
  252. package/esm2022/form-controls/date-picker/updevs-components-form-controls-date-picker.mjs +5 -0
  253. package/esm2022/form-controls/file-upload/assets/i18n/en.json +15 -0
  254. package/esm2022/form-controls/file-upload/assets/i18n/pt.json +15 -0
  255. package/esm2022/form-controls/file-upload/file-upload-changed.event.mjs +2 -0
  256. package/esm2022/form-controls/file-upload/file-upload.component.mjs +169 -0
  257. package/esm2022/form-controls/file-upload/index.mjs +2 -0
  258. package/esm2022/form-controls/file-upload/public-api.mjs +4 -0
  259. package/esm2022/form-controls/file-upload/upd-file-upload.module.mjs +48 -0
  260. package/esm2022/form-controls/file-upload/updevs-components-form-controls-file-upload.mjs +5 -0
  261. package/esm2022/form-controls/input/directives/input-append.directive.mjs +4 -4
  262. package/esm2022/form-controls/input/directives/input-prepend.directive.mjs +4 -4
  263. package/esm2022/form-controls/input/directives/public-api.mjs +1 -1
  264. package/esm2022/form-controls/input/index.mjs +1 -1
  265. package/esm2022/form-controls/input/input.component.mjs +75 -35
  266. package/esm2022/form-controls/input/public-api.mjs +1 -1
  267. package/esm2022/form-controls/input/types/input.type.mjs +1 -1
  268. package/esm2022/form-controls/input/types/loader-position.type.mjs +1 -1
  269. package/esm2022/form-controls/input/types/public-api.mjs +1 -1
  270. package/esm2022/form-controls/input/upd-input.module.mjs +5 -5
  271. package/esm2022/form-controls/input/updevs-components-form-controls-input.mjs +1 -1
  272. package/esm2022/form-controls/radio/index.mjs +1 -1
  273. package/esm2022/form-controls/radio/public-api.mjs +1 -1
  274. package/esm2022/form-controls/radio/radio.component.mjs +12 -25
  275. package/esm2022/form-controls/radio/upd-radio.module.mjs +14 -6
  276. package/esm2022/form-controls/radio/updevs-components-form-controls-radio.mjs +1 -1
  277. package/esm2022/form-controls/select/components/multiple/select-multiple.component.mjs +38 -14
  278. package/esm2022/form-controls/select/components/single/select.component.mjs +45 -21
  279. package/esm2022/form-controls/select/index.mjs +1 -1
  280. package/esm2022/form-controls/select/models/abstractions/base-select.component.mjs +129 -106
  281. package/esm2022/form-controls/select/models/defaults.mjs +8 -0
  282. package/esm2022/form-controls/select/models/public-api.mjs +2 -1
  283. package/esm2022/form-controls/select/models/select-item.mjs +1 -1
  284. package/esm2022/form-controls/select/public-api.mjs +1 -1
  285. package/esm2022/form-controls/select/upd-select.module.mjs +10 -6
  286. package/esm2022/form-controls/select/updevs-components-form-controls-select.mjs +1 -1
  287. package/esm2022/form-controls/textarea/index.mjs +1 -1
  288. package/esm2022/form-controls/textarea/public-api.mjs +1 -1
  289. package/esm2022/form-controls/textarea/textarea.component.mjs +18 -36
  290. package/esm2022/form-controls/textarea/upd-textarea.module.mjs +5 -5
  291. package/esm2022/form-controls/textarea/updevs-components-form-controls-textarea.mjs +1 -1
  292. package/esm2022/form-controls/time-picker/index.mjs +1 -1
  293. package/esm2022/form-controls/time-picker/public-api.mjs +1 -1
  294. package/esm2022/form-controls/time-picker/time-picker.component.mjs +4 -4
  295. package/esm2022/form-controls/time-picker/time-selector/time-selector.component.mjs +5 -5
  296. package/esm2022/form-controls/time-picker/upd-time-picker.module.mjs +8 -7
  297. package/esm2022/form-controls/time-picker/updevs-components-form-controls-time-picker.mjs +1 -1
  298. package/esm2022/index.mjs +2 -0
  299. package/esm2022/layout/abstractions/base-page.component.mjs +6 -7
  300. package/esm2022/layout/abstractions/base.layout.mjs +31 -0
  301. package/esm2022/layout/abstractions/public-api.mjs +1 -1
  302. package/esm2022/layout/assets/i18n/en.json +24 -2
  303. package/esm2022/layout/assets/i18n/pt.json +24 -2
  304. package/esm2022/layout/index.mjs +1 -1
  305. package/esm2022/layout/layouts/blank-layout/blank-layout.component.mjs +18 -7
  306. package/esm2022/layout/layouts/blank-layout/blank-layout.module.mjs +32 -6
  307. package/esm2022/layout/layouts/public-api.mjs +1 -1
  308. package/esm2022/layout/layouts/vertical-sidebar-layout/vertical-sidebar-layout.component.mjs +8 -22
  309. package/esm2022/layout/layouts/vertical-sidebar-layout/vertical-sidebar-layout.module.mjs +24 -27
  310. package/esm2022/layout/models/login-page-config.model.mjs +20 -0
  311. package/esm2022/layout/models/login-page.config.mjs +2 -0
  312. package/esm2022/layout/models/public-api.mjs +2 -1
  313. package/esm2022/layout/models/security-layout-config.model.mjs +10 -0
  314. package/esm2022/layout/models/security-layout.config.mjs +2 -0
  315. package/esm2022/layout/models/upd-layout-config.model.mjs +11 -17
  316. package/esm2022/layout/models/upd-layout.config.mjs +1 -1
  317. package/esm2022/layout/pages/auth-flow/auth-flow-routing.module.mjs +5 -5
  318. package/esm2022/layout/pages/auth-flow/auth-flow.module.mjs +36 -9
  319. package/esm2022/layout/pages/auth-flow/logged-out/logged-out.component.mjs +4 -4
  320. package/esm2022/layout/pages/auth-flow/login/login.component.mjs +95 -12
  321. package/esm2022/layout/pages/auth-flow/oauth-callback/oauth-callback.component.mjs +4 -4
  322. package/esm2022/layout/pages/auth-flow/public-api.mjs +1 -1
  323. package/esm2022/layout/pages/public-api.mjs +1 -1
  324. package/esm2022/layout/partials/footer/footer.component.mjs +9 -24
  325. package/esm2022/layout/partials/footer/footer.module.mjs +28 -0
  326. package/esm2022/layout/partials/footer/public-api.mjs +2 -2
  327. package/esm2022/layout/partials/header/header-style.type.mjs +1 -1
  328. package/esm2022/layout/partials/header/header.component.mjs +115 -52
  329. package/esm2022/layout/partials/header/header.module.mjs +40 -0
  330. package/esm2022/layout/partials/header/public-api.mjs +2 -1
  331. package/esm2022/layout/partials/page-header/page-header.component.mjs +10 -9
  332. package/esm2022/layout/partials/page-header/public-api.mjs +1 -1
  333. package/esm2022/layout/partials/public-api.mjs +1 -1
  334. package/esm2022/layout/partials/sidebar/public-api.mjs +1 -1
  335. package/esm2022/layout/partials/sidebar/sidebar.component.mjs +177 -86
  336. package/esm2022/layout/public-api.mjs +1 -1
  337. package/esm2022/layout/services/public-api.mjs +1 -1
  338. package/esm2022/layout/services/upd-layout-config.service.mjs +4 -4
  339. package/esm2022/layout/tools/layout.constants.mjs +1 -1
  340. package/esm2022/layout/upd-layout.module.mjs +12 -8
  341. package/esm2022/layout/updevs-components-layout.mjs +1 -1
  342. package/esm2022/lib/index.mjs +1 -1
  343. package/esm2022/lib/models/public-api.mjs +2 -0
  344. package/esm2022/lib/models/row-column-size.mjs +2 -0
  345. package/esm2022/lib/public-api.mjs +3 -1
  346. package/esm2022/lib/tools/column-size.helper.mjs +12 -0
  347. package/esm2022/lib/tools/public-api.mjs +2 -0
  348. package/esm2022/lib/types/component-size.type.mjs +1 -1
  349. package/esm2022/lib/types/horizontal-vertical.type.mjs +2 -0
  350. package/esm2022/lib/types/public-api.mjs +2 -1
  351. package/esm2022/lib/types/validation-status.type.mjs +1 -1
  352. package/esm2022/lib/upd-components.module.mjs +5 -5
  353. package/esm2022/link/index.mjs +1 -1
  354. package/esm2022/link/link.component.mjs +4 -4
  355. package/esm2022/link/public-api.mjs +1 -1
  356. package/esm2022/link/target.type.mjs +1 -1
  357. package/esm2022/link/upd-link.module.mjs +5 -5
  358. package/esm2022/link/updevs-components-link.mjs +1 -1
  359. package/esm2022/list/assets/i18n/en.json +7 -3
  360. package/esm2022/list/assets/i18n/pt.json +7 -3
  361. package/esm2022/list/index.mjs +1 -1
  362. package/esm2022/list/list.component.mjs +9 -29
  363. package/esm2022/list/models/badge-position.type.mjs +1 -1
  364. package/esm2022/list/models/list-item.mjs +1 -1
  365. package/esm2022/list/models/list-item.model.mjs +7 -2
  366. package/esm2022/list/models/public-api.mjs +1 -1
  367. package/esm2022/list/public-api.mjs +1 -1
  368. package/esm2022/list/upd-list.module.mjs +8 -7
  369. package/esm2022/list/updevs-components-list.mjs +1 -1
  370. package/esm2022/modal/assets/i18n/en.json +17 -0
  371. package/esm2022/modal/assets/i18n/pt.json +17 -0
  372. package/esm2022/modal/components/modal-container/modal-container.component.mjs +216 -0
  373. package/esm2022/modal/index.mjs +2 -0
  374. package/esm2022/modal/models/base.modal.mjs +14 -0
  375. package/esm2022/modal/models/modal-config.model.mjs +20 -0
  376. package/esm2022/modal/models/modal-ref.mjs +2 -0
  377. package/esm2022/modal/models/modal.config.mjs +2 -0
  378. package/esm2022/modal/models/public-api.mjs +4 -0
  379. package/esm2022/modal/public-api.mjs +4 -0
  380. package/esm2022/modal/services/modal-alert.service.mjs +99 -0
  381. package/esm2022/modal/services/modal.service.mjs +30 -0
  382. package/esm2022/modal/services/public-api.mjs +3 -0
  383. package/esm2022/modal/types/modal-footer-style.type.mjs +2 -0
  384. package/esm2022/modal/types/modal-size.type.mjs +2 -0
  385. package/esm2022/modal/upd-modal.module.mjs +90 -0
  386. package/esm2022/modal/updevs-components-modal.mjs +5 -0
  387. package/esm2022/paginator/assets/i18n/en.json +15 -0
  388. package/esm2022/paginator/assets/i18n/pt.json +15 -0
  389. package/esm2022/paginator/index.mjs +2 -0
  390. package/esm2022/paginator/paginator.component.mjs +66 -0
  391. package/esm2022/paginator/public-api.mjs +3 -0
  392. package/esm2022/paginator/upd-paginator.module.mjs +47 -0
  393. package/esm2022/paginator/updevs-components-paginator.mjs +5 -0
  394. package/esm2022/popover/index.mjs +1 -1
  395. package/esm2022/popover/popover.component.mjs +6 -6
  396. package/esm2022/popover/popover.directive.mjs +23 -32
  397. package/esm2022/popover/public-api.mjs +1 -1
  398. package/esm2022/popover/upd-popover.module.mjs +5 -5
  399. package/esm2022/popover/updevs-components-popover.mjs +1 -1
  400. package/esm2022/pricing/index.mjs +2 -0
  401. package/esm2022/pricing/models/price-item-feature.model.mjs +2 -0
  402. package/esm2022/pricing/models/price-item-features-group.model.mjs +2 -0
  403. package/esm2022/pricing/models/price-item-tag.model.mjs +2 -0
  404. package/esm2022/pricing/models/price-item.model.mjs +2 -0
  405. package/esm2022/pricing/models/public-api.mjs +5 -0
  406. package/esm2022/pricing/pricing-cards/pricing-cards.component.mjs +27 -0
  407. package/esm2022/pricing/pricing-table/pricing-table.component.mjs +57 -0
  408. package/esm2022/pricing/public-api.mjs +5 -0
  409. package/esm2022/pricing/upd-pricing.module.mjs +49 -0
  410. package/esm2022/pricing/updevs-components-pricing.mjs +5 -0
  411. package/esm2022/public-api.mjs +1 -1
  412. package/esm2022/table/abstractions/base-column.model.mjs +52 -0
  413. package/esm2022/table/abstractions/base.column.mjs +84 -0
  414. package/esm2022/table/abstractions/filters-operands.service.mjs +3 -0
  415. package/esm2022/table/abstractions/public-api.mjs +3 -0
  416. package/esm2022/table/assets/i18n/en.json +74 -0
  417. package/esm2022/table/assets/i18n/pt.json +74 -0
  418. package/esm2022/table/components/columns/boolean-column/boolean-column.component.mjs +26 -0
  419. package/esm2022/table/components/columns/date-time-column/date-time-column.component.mjs +13 -0
  420. package/esm2022/table/components/columns/number-column/number-column.component.mjs +13 -0
  421. package/esm2022/table/components/columns/text-column/text-column.component.mjs +31 -0
  422. package/esm2022/table/components/columns-manager/columns-manager.component.mjs +36 -0
  423. package/esm2022/table/components/filter-row/filter-row.component.mjs +114 -0
  424. package/esm2022/table/components/save-search/save-search.component.mjs +72 -0
  425. package/esm2022/table/components/search-section/search-section.component.mjs +93 -0
  426. package/esm2022/table/directives/public-api.mjs +2 -0
  427. package/esm2022/table/directives/table-column.directive.mjs +52 -0
  428. package/esm2022/table/index.mjs +2 -0
  429. package/esm2022/table/models/columns/boolean-column.model.mjs +22 -0
  430. package/esm2022/table/models/columns/date-time-column.model.mjs +16 -0
  431. package/esm2022/table/models/columns/guid-column.model.mjs +13 -0
  432. package/esm2022/table/models/columns/image-column.model.mjs +11 -0
  433. package/esm2022/table/models/columns/number-column.model.mjs +17 -0
  434. package/esm2022/table/models/columns/public-api.mjs +7 -0
  435. package/esm2022/table/models/columns/text-column.model.mjs +11 -0
  436. package/esm2022/table/models/enums/column-type.enum.mjs +15 -0
  437. package/esm2022/table/models/enums/public-api.mjs +2 -0
  438. package/esm2022/table/models/filter-item.model.mjs +2 -0
  439. package/esm2022/table/models/filter-operand.config.mjs +2 -0
  440. package/esm2022/table/models/operands-lists/boolean-filter-operands-list.model.mjs +25 -0
  441. package/esm2022/table/models/operands-lists/date-filter-operands-list.model.mjs +25 -0
  442. package/esm2022/table/models/operands-lists/date-or-number-operands-list.config.mjs +31 -0
  443. package/esm2022/table/models/operands-lists/filter-operands-list.config.mjs +31 -0
  444. package/esm2022/table/models/operands-lists/guid-filter-operands-list.model.mjs +16 -0
  445. package/esm2022/table/models/operands-lists/number-filter-operands-list.model.mjs +25 -0
  446. package/esm2022/table/models/operands-lists/string-filter-operands-list.model.mjs +45 -0
  447. package/esm2022/table/models/public-api.mjs +5 -0
  448. package/esm2022/table/models/saved-view.model.mjs +2 -0
  449. package/esm2022/table/models/table-config.model.mjs +29 -0
  450. package/esm2022/table/models/table.config.mjs +2 -0
  451. package/esm2022/table/models/upd-table-config.model.mjs +9 -0
  452. package/esm2022/table/models/upd-table.config.mjs +2 -0
  453. package/esm2022/table/public-api.mjs +6 -0
  454. package/esm2022/table/services/default-filters-operands.service.mjs +60 -0
  455. package/esm2022/table/services/storages/saved-views.storage.mjs +56 -0
  456. package/esm2022/table/services/stores/filters-operands.store.mjs +19 -0
  457. package/esm2022/table/services/upd-table-config.service.mjs +18 -0
  458. package/esm2022/table/table.component.mjs +439 -0
  459. package/esm2022/table/tools/filters.tools.mjs +48 -0
  460. package/esm2022/table/tools/table.constants.mjs +15 -0
  461. package/esm2022/table/upd-table.module.mjs +150 -0
  462. package/esm2022/table/updevs-components-table.mjs +5 -0
  463. package/esm2022/updevs-components.mjs +2 -2
  464. package/fesm2022/updevs-components-badge.mjs +89 -0
  465. package/fesm2022/updevs-components-badge.mjs.map +1 -0
  466. package/fesm2022/updevs-components-button.mjs +138 -136
  467. package/fesm2022/updevs-components-button.mjs.map +1 -1
  468. package/fesm2022/updevs-components-calendar.mjs +582 -0
  469. package/fesm2022/updevs-components-calendar.mjs.map +1 -0
  470. package/fesm2022/updevs-components-card.mjs +20 -20
  471. package/fesm2022/updevs-components-card.mjs.map +1 -1
  472. package/fesm2022/updevs-components-drag-and-drop.mjs +185 -0
  473. package/fesm2022/updevs-components-drag-and-drop.mjs.map +1 -0
  474. package/fesm2022/updevs-components-dropdown.mjs +83 -25
  475. package/fesm2022/updevs-components-dropdown.mjs.map +1 -1
  476. package/fesm2022/updevs-components-form-controls-abstractions.mjs +53 -0
  477. package/fesm2022/updevs-components-form-controls-abstractions.mjs.map +1 -0
  478. package/fesm2022/updevs-components-form-controls-checkbox.mjs +47 -57
  479. package/fesm2022/updevs-components-form-controls-checkbox.mjs.map +1 -1
  480. package/fesm2022/updevs-components-form-controls-date-picker.mjs +175 -0
  481. package/fesm2022/updevs-components-form-controls-date-picker.mjs.map +1 -0
  482. package/fesm2022/updevs-components-form-controls-file-upload.mjs +264 -0
  483. package/fesm2022/updevs-components-form-controls-file-upload.mjs.map +1 -0
  484. package/fesm2022/updevs-components-form-controls-input.mjs +84 -44
  485. package/fesm2022/updevs-components-form-controls-input.mjs.map +1 -1
  486. package/fesm2022/updevs-components-form-controls-radio.mjs +25 -30
  487. package/fesm2022/updevs-components-form-controls-radio.mjs.map +1 -1
  488. package/fesm2022/updevs-components-form-controls-select.mjs +219 -139
  489. package/fesm2022/updevs-components-form-controls-select.mjs.map +1 -1
  490. package/fesm2022/updevs-components-form-controls-textarea.mjs +21 -39
  491. package/fesm2022/updevs-components-form-controls-textarea.mjs.map +1 -1
  492. package/fesm2022/updevs-components-form-controls-time-picker.mjs +14 -13
  493. package/fesm2022/updevs-components-form-controls-time-picker.mjs.map +1 -1
  494. package/fesm2022/updevs-components-form.mjs +533 -10
  495. package/fesm2022/updevs-components-form.mjs.map +1 -1
  496. package/fesm2022/updevs-components-layout.mjs +757 -375
  497. package/fesm2022/updevs-components-layout.mjs.map +1 -1
  498. package/fesm2022/updevs-components-link.mjs +8 -8
  499. package/fesm2022/updevs-components-link.mjs.map +1 -1
  500. package/fesm2022/updevs-components-list.mjs +39 -53
  501. package/fesm2022/updevs-components-list.mjs.map +1 -1
  502. package/fesm2022/updevs-components-modal.mjs +504 -0
  503. package/fesm2022/updevs-components-modal.mjs.map +1 -0
  504. package/fesm2022/updevs-components-paginator.mjs +160 -0
  505. package/fesm2022/updevs-components-paginator.mjs.map +1 -0
  506. package/fesm2022/updevs-components-popover.mjs +30 -39
  507. package/fesm2022/updevs-components-popover.mjs.map +1 -1
  508. package/fesm2022/updevs-components-pricing.mjs +130 -0
  509. package/fesm2022/updevs-components-pricing.mjs.map +1 -0
  510. package/fesm2022/updevs-components-table.mjs +1754 -0
  511. package/fesm2022/updevs-components-table.mjs.map +1 -0
  512. package/fesm2022/updevs-components.mjs +17 -5
  513. package/fesm2022/updevs-components.mjs.map +1 -1
  514. package/form/components/dynamic-field/dynamic-field.component.d.ts +63 -0
  515. package/form/form.component.d.ts +64 -0
  516. package/form/models/attachment-rule.model.d.ts +35 -0
  517. package/form/models/button-field.model.d.ts +5 -0
  518. package/form/models/button-group-field.model.d.ts +5 -0
  519. package/form/models/checkbox-field.model.d.ts +4 -0
  520. package/form/models/checkbox-group-field.model.d.ts +6 -0
  521. package/form/models/dynamic-field.model.d.ts +49 -0
  522. package/form/models/enums/attachment-type.enum.d.ts +13 -0
  523. package/form/models/enums/dynamic-field.type.d.ts +15 -0
  524. package/form/models/enums/public-api.d.ts +2 -0
  525. package/form/models/file-upload-field.model.d.ts +16 -0
  526. package/form/models/form-config.d.ts +2 -0
  527. package/form/models/form-row.model.d.ts +10 -0
  528. package/form/models/form-update-on.type.d.ts +1 -0
  529. package/form/models/input-field.model.d.ts +9 -0
  530. package/form/models/masked-input-field.model.d.ts +6 -0
  531. package/form/models/public-api.d.ts +18 -0
  532. package/form/models/radio-field.model.d.ts +4 -0
  533. package/form/models/radio-group-field.model.d.ts +6 -0
  534. package/form/models/select-field.model.d.ts +29 -0
  535. package/form/models/single-select-field.model.d.ts +4 -0
  536. package/form/models/textarea-field.model.d.ts +10 -0
  537. package/form/models/validator-config.d.ts +5 -0
  538. package/form/public-api.d.ts +3 -1
  539. package/form/tools/errors-helper.d.ts +11 -0
  540. package/form/upd-form.module.d.ts +22 -0
  541. package/form-controls/abstractions/base-control.d.ts +29 -0
  542. package/form-controls/abstractions/index.d.ts +2 -0
  543. package/form-controls/abstractions/public-api.d.ts +2 -0
  544. package/form-controls/checkbox/checkbox.component.d.ts +14 -20
  545. package/form-controls/checkbox/upd-checkbox.module.d.ts +2 -1
  546. package/form-controls/date-picker/date-picker.component.d.ts +66 -0
  547. package/form-controls/date-picker/index.d.ts +1 -0
  548. package/form-controls/date-picker/public-api.d.ts +2 -0
  549. package/form-controls/date-picker/upd-date-picker.module.d.ts +12 -0
  550. package/form-controls/file-upload/file-upload-changed.event.d.ts +4 -0
  551. package/form-controls/file-upload/file-upload.component.d.ts +46 -0
  552. package/form-controls/file-upload/index.d.ts +1 -0
  553. package/form-controls/file-upload/public-api.d.ts +3 -0
  554. package/form-controls/file-upload/upd-file-upload.module.d.ts +14 -0
  555. package/form-controls/input/input.component.d.ts +27 -14
  556. package/form-controls/radio/radio.component.d.ts +5 -12
  557. package/form-controls/radio/upd-radio.module.d.ts +3 -1
  558. package/form-controls/select/components/multiple/select-multiple.component.d.ts +13 -2
  559. package/form-controls/select/components/single/select.component.d.ts +12 -4
  560. package/form-controls/select/models/abstractions/base-select.component.d.ts +36 -32
  561. package/form-controls/select/models/defaults.d.ts +8 -0
  562. package/form-controls/select/models/public-api.d.ts +1 -0
  563. package/form-controls/select/upd-select.module.d.ts +3 -2
  564. package/form-controls/textarea/textarea.component.d.ts +11 -15
  565. package/form-controls/time-picker/upd-time-picker.module.d.ts +2 -2
  566. package/index.d.ts +1 -4
  567. package/layout/abstractions/base.layout.d.ts +15 -0
  568. package/layout/layouts/blank-layout/blank-layout.component.d.ts +5 -1
  569. package/layout/layouts/blank-layout/blank-layout.module.d.ts +8 -1
  570. package/layout/layouts/vertical-sidebar-layout/vertical-sidebar-layout.component.d.ts +2 -8
  571. package/layout/layouts/vertical-sidebar-layout/vertical-sidebar-layout.module.d.ts +14 -13
  572. package/layout/models/login-page-config.model.d.ts +46 -0
  573. package/layout/models/login-page.config.d.ts +44 -0
  574. package/layout/models/public-api.d.ts +1 -0
  575. package/layout/models/security-layout-config.model.d.ts +12 -0
  576. package/layout/models/security-layout.config.d.ts +10 -0
  577. package/layout/models/upd-layout-config.model.d.ts +9 -0
  578. package/layout/models/upd-layout.config.d.ts +9 -0
  579. package/layout/pages/auth-flow/auth-flow.module.d.ts +9 -2
  580. package/layout/pages/auth-flow/login/login.component.d.ts +20 -6
  581. package/layout/partials/footer/footer.component.d.ts +4 -13
  582. package/layout/partials/footer/footer.module.d.ts +9 -0
  583. package/layout/partials/footer/public-api.d.ts +1 -1
  584. package/layout/partials/header/header.component.d.ts +41 -21
  585. package/layout/partials/header/header.module.d.ts +12 -0
  586. package/layout/partials/header/public-api.d.ts +1 -0
  587. package/layout/partials/page-header/page-header.component.d.ts +2 -2
  588. package/layout/partials/sidebar/sidebar.component.d.ts +28 -1
  589. package/layout/upd-layout.module.d.ts +2 -1
  590. package/lib/index.d.ts +1 -0
  591. package/lib/models/public-api.d.ts +2 -0
  592. package/lib/models/row-column-size.d.ts +23 -0
  593. package/lib/public-api.d.ts +3 -0
  594. package/lib/tools/column-size.helper.d.ts +6 -0
  595. package/lib/tools/public-api.d.ts +2 -0
  596. package/lib/types/component-size.type.d.ts +1 -0
  597. package/lib/types/horizontal-vertical.type.d.ts +2 -0
  598. package/lib/types/public-api.d.ts +2 -0
  599. package/lib/types/validation-status.type.d.ts +1 -0
  600. package/lib/upd-components.module.d.ts +1 -0
  601. package/list/list.component.d.ts +1 -16
  602. package/list/models/list-item.d.ts +4 -2
  603. package/list/models/list-item.model.d.ts +4 -2
  604. package/list/upd-list.module.d.ts +2 -2
  605. package/modal/components/modal-container/modal-container.component.d.ts +74 -0
  606. package/modal/index.d.ts +1 -0
  607. package/modal/models/base.modal.d.ts +8 -0
  608. package/modal/models/modal-config.model.d.ts +32 -0
  609. package/modal/models/modal-ref.d.ts +6 -0
  610. package/modal/models/modal.config.d.ts +30 -0
  611. package/modal/models/public-api.d.ts +3 -0
  612. package/modal/public-api.d.ts +3 -0
  613. package/modal/services/modal-alert.service.d.ts +22 -0
  614. package/modal/services/modal.service.d.ts +12 -0
  615. package/modal/services/public-api.d.ts +2 -0
  616. package/modal/types/modal-footer-style.type.d.ts +1 -0
  617. package/modal/types/modal-size.type.d.ts +1 -0
  618. package/modal/upd-modal.module.d.ts +18 -0
  619. package/package.json +67 -6
  620. package/paginator/index.d.ts +1 -0
  621. package/paginator/paginator.component.d.ts +42 -0
  622. package/paginator/public-api.d.ts +2 -0
  623. package/paginator/upd-paginator.module.d.ts +14 -0
  624. package/popover/popover.component.d.ts +2 -2
  625. package/pricing/index.d.ts +1 -0
  626. package/pricing/models/price-item-feature.model.d.ts +7 -0
  627. package/pricing/models/price-item-features-group.model.d.ts +5 -0
  628. package/pricing/models/price-item-tag.model.d.ts +6 -0
  629. package/pricing/models/price-item.model.d.ts +22 -0
  630. package/pricing/models/public-api.d.ts +4 -0
  631. package/pricing/pricing-cards/pricing-cards.component.d.ts +12 -0
  632. package/pricing/pricing-table/pricing-table.component.d.ts +30 -0
  633. package/pricing/public-api.d.ts +4 -0
  634. package/pricing/upd-pricing.module.d.ts +14 -0
  635. package/public-api.d.ts +1 -0
  636. package/table/abstractions/base-column.model.d.ts +31 -0
  637. package/table/abstractions/base.column.d.ts +26 -0
  638. package/table/abstractions/filters-operands.service.d.ts +8 -0
  639. package/table/abstractions/public-api.d.ts +2 -0
  640. package/table/components/columns/boolean-column/boolean-column.component.d.ts +9 -0
  641. package/table/components/columns/date-time-column/date-time-column.component.d.ts +7 -0
  642. package/table/components/columns/number-column/number-column.component.d.ts +7 -0
  643. package/table/components/columns/text-column/text-column.component.d.ts +9 -0
  644. package/table/components/columns-manager/columns-manager.component.d.ts +15 -0
  645. package/table/components/filter-row/filter-row.component.d.ts +40 -0
  646. package/table/components/save-search/save-search.component.d.ts +17 -0
  647. package/table/components/search-section/search-section.component.d.ts +36 -0
  648. package/table/directives/public-api.d.ts +1 -0
  649. package/table/directives/table-column.directive.d.ts +14 -0
  650. package/table/index.d.ts +1 -0
  651. package/table/models/columns/boolean-column.model.d.ts +15 -0
  652. package/table/models/columns/date-time-column.model.d.ts +8 -0
  653. package/table/models/columns/guid-column.model.d.ts +4 -0
  654. package/table/models/columns/image-column.model.d.ts +6 -0
  655. package/table/models/columns/number-column.model.d.ts +8 -0
  656. package/table/models/columns/public-api.d.ts +6 -0
  657. package/table/models/columns/text-column.model.d.ts +6 -0
  658. package/table/models/enums/column-type.enum.d.ts +13 -0
  659. package/table/models/enums/public-api.d.ts +1 -0
  660. package/table/models/filter-item.model.d.ts +6 -0
  661. package/table/models/filter-operand.config.d.ts +9 -0
  662. package/table/models/operands-lists/boolean-filter-operands-list.model.d.ts +6 -0
  663. package/table/models/operands-lists/date-filter-operands-list.model.d.ts +6 -0
  664. package/table/models/operands-lists/date-or-number-operands-list.config.d.ts +5 -0
  665. package/table/models/operands-lists/filter-operands-list.config.d.ts +5 -0
  666. package/table/models/operands-lists/guid-filter-operands-list.model.d.ts +6 -0
  667. package/table/models/operands-lists/number-filter-operands-list.model.d.ts +6 -0
  668. package/table/models/operands-lists/string-filter-operands-list.model.d.ts +6 -0
  669. package/table/models/public-api.d.ts +4 -0
  670. package/table/models/saved-view.model.d.ts +11 -0
  671. package/table/models/table-config.model.d.ts +33 -0
  672. package/table/models/table.config.d.ts +31 -0
  673. package/table/models/upd-table-config.model.d.ts +6 -0
  674. package/table/models/upd-table.config.d.ts +6 -0
  675. package/table/public-api.d.ts +5 -0
  676. package/table/services/default-filters-operands.service.d.ts +17 -0
  677. package/table/services/storages/saved-views.storage.d.ts +19 -0
  678. package/table/services/stores/filters-operands.store.d.ts +11 -0
  679. package/table/services/upd-table-config.service.d.ts +12 -0
  680. package/table/table.component.d.ts +81 -0
  681. package/table/tools/filters.tools.d.ts +9 -0
  682. package/table/tools/table.constants.d.ts +15 -0
  683. package/table/upd-table.module.d.ts +40 -0
  684. package/esm2022/form/form.module.mjs +0 -18
  685. package/esm2022/layout/partials/footer/footer-copyright.directive.mjs +0 -13
  686. package/form/form.module.d.ts +0 -7
  687. package/layout/partials/footer/footer-copyright.directive.d.ts +0 -5
@@ -1,25 +1,548 @@
1
1
  import * as i0 from '@angular/core';
2
- import { NgModule } from '@angular/core';
2
+ import { inject, Injectable, EventEmitter, input, computed, effect, Output, HostBinding, Component, model, NgModule } from '@angular/core';
3
+ import * as i1$1 from '@angular/forms';
4
+ import { Validators, FormGroup, FormControl, ReactiveFormsModule } from '@angular/forms';
5
+ import { TextService, UpdSdkModule } from '@updevs/sdk';
6
+ import { BaseComponent } from '@updevs/sdk/layout';
7
+ import { startWith } from 'rxjs';
8
+ import * as i1 from '@updevs/components/button';
9
+ import { UpdButtonModule } from '@updevs/components/button';
10
+ import * as i1$2 from '@jsverse/transloco';
11
+ import { TranslocoDirective } from '@jsverse/transloco';
12
+ import { ColumnSizeHelper } from '@updevs/components';
13
+ import * as i5 from '@updevs/components/form-controls/select';
14
+ import { Defaults, UpdSelectModule } from '@updevs/components/form-controls/select';
15
+ import * as i2 from '@updevs/components/form-controls/input';
16
+ import { UpdInputModule } from '@updevs/components/form-controls/input';
17
+ import * as i3 from '@updevs/components/form-controls/checkbox';
18
+ import { UpdCheckboxModule } from '@updevs/components/form-controls/checkbox';
19
+ import * as i4 from '@updevs/components/form-controls/radio';
20
+ import { UpdRadioModule } from '@updevs/components/form-controls/radio';
21
+ import * as i6 from '@updevs/components/form-controls/textarea';
22
+ import { UpdTextareaModule } from '@updevs/components/form-controls/textarea';
23
+ import * as i7 from '@updevs/components/form-controls/file-upload';
24
+ import { UpdFileUploadModule } from '@updevs/components/form-controls/file-upload';
3
25
  import { CommonModule } from '@angular/common';
26
+ import { UpdDatePickerModule } from '@updevs/components/form-controls/date-picker';
4
27
 
5
- class FormModule {
6
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: FormModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.1", ngImport: i0, type: FormModule, imports: [CommonModule] }); }
8
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: FormModule, imports: [CommonModule] }); }
28
+ /**
29
+ * How a parent field influences its child.
30
+ **/
31
+ var AttachmentTypeEnum;
32
+ (function (AttachmentTypeEnum) {
33
+ /**
34
+ * Enable / disable behaviour (default).
35
+ **/
36
+ AttachmentTypeEnum["Disabled"] = "disabled";
37
+ /**
38
+ * Child waits for the parent to have a value and (re)loads afterwards.
39
+ **/
40
+ AttachmentTypeEnum["ParentLoad"] = "parentLoad";
41
+ })(AttachmentTypeEnum || (AttachmentTypeEnum = {}));
42
+
43
+ var DynamicFieldType;
44
+ (function (DynamicFieldType) {
45
+ DynamicFieldType[DynamicFieldType["Input"] = 1] = "Input";
46
+ DynamicFieldType[DynamicFieldType["Select"] = 2] = "Select";
47
+ DynamicFieldType[DynamicFieldType["SelectMultiple"] = 3] = "SelectMultiple";
48
+ DynamicFieldType[DynamicFieldType["Label"] = 4] = "Label";
49
+ DynamicFieldType[DynamicFieldType["Checkbox"] = 5] = "Checkbox";
50
+ DynamicFieldType[DynamicFieldType["CheckboxGroup"] = 6] = "CheckboxGroup";
51
+ DynamicFieldType[DynamicFieldType["Radio"] = 7] = "Radio";
52
+ DynamicFieldType[DynamicFieldType["RadioGroup"] = 8] = "RadioGroup";
53
+ DynamicFieldType[DynamicFieldType["TextArea"] = 9] = "TextArea";
54
+ DynamicFieldType[DynamicFieldType["FileUpload"] = 10] = "FileUpload";
55
+ DynamicFieldType[DynamicFieldType["MaskedInput"] = 11] = "MaskedInput";
56
+ DynamicFieldType[DynamicFieldType["Button"] = 12] = "Button";
57
+ DynamicFieldType[DynamicFieldType["ButtonGroup"] = 13] = "ButtonGroup";
58
+ })(DynamicFieldType || (DynamicFieldType = {}));
59
+
60
+ class ErrorsHelper {
61
+ constructor() {
62
+ this.errors = {
63
+ 'required': { text: 'UpDevs.Form.ErrorMessages.Required' },
64
+ 'requiredTrue': { text: 'UpDevs.Form.ErrorMessages.RequiredTrue' },
65
+ 'generic': { text: 'UpDevs.Form.ErrorMessages.Generic' },
66
+ 'email': { text: 'UpDevs.Form.ErrorMessages.Email' },
67
+ 'max': { text: 'UpDevs.Form.ErrorMessages.Max', defaultErrorParamToShow: 'max' },
68
+ 'min': { text: 'UpDevs.Form.ErrorMessages.Min', defaultErrorParamToShow: 'min' },
69
+ 'maxlength': { text: 'UpDevs.Form.ErrorMessages.MaxLength', defaultErrorParamToShow: 'requiredLength' },
70
+ 'minlength': { text: 'UpDevs.Form.ErrorMessages.MinLength', defaultErrorParamToShow: 'requiredLength' }
71
+ };
72
+ this.textService = inject(TextService);
73
+ }
74
+ getMessages(control, customConfig) {
75
+ if (!control.errors) {
76
+ return [];
77
+ }
78
+ const errorMessages = [];
79
+ const genericText = this.textService.getText({ text: this.errors['generic'].text, isTranslated: false });
80
+ const combinedErrorMessagesList = Object.assign({}, this.errors, customConfig || {});
81
+ const controlErrorKeys = Object.keys(control.errors);
82
+ controlErrorKeys.forEach(key => {
83
+ const customError = !!control.errors ? control.errors[key] : undefined;
84
+ if (!!customError?.errorText) {
85
+ errorMessages.push(this.textService.getText(customError.errorText));
86
+ }
87
+ else if (key in combinedErrorMessagesList) {
88
+ const config = combinedErrorMessagesList[key];
89
+ let params;
90
+ if (config.showLength) {
91
+ params = { value: control.value?.length || 0 };
92
+ }
93
+ if (!!config.defaultErrorParamToShow) {
94
+ params = { value: control.errors[key][config.defaultErrorParamToShow] };
95
+ }
96
+ errorMessages.push(this.textService.getText({ text: config.text, isTranslated: false }, params));
97
+ }
98
+ });
99
+ if (controlErrorKeys.length > 0 && errorMessages.length < 1) {
100
+ errorMessages.push(genericText);
101
+ }
102
+ return errorMessages;
103
+ }
104
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: ErrorsHelper, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
105
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: ErrorsHelper }); }
106
+ }
107
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: ErrorsHelper, decorators: [{
108
+ type: Injectable
109
+ }] });
110
+
111
+ class DynamicFieldComponent extends BaseComponent {
112
+ get hostClasses() {
113
+ return this.wrapperClasses();
114
+ }
115
+ get formControl() {
116
+ return this.formGroup().controls[this.field().name];
117
+ }
118
+ get inputField() {
119
+ return this.field();
120
+ }
121
+ get checkboxField() {
122
+ return this.field();
123
+ }
124
+ get checkboxGroupField() {
125
+ return this.field();
126
+ }
127
+ get radioField() {
128
+ return this.field();
129
+ }
130
+ get radioGroupField() {
131
+ return this.field();
132
+ }
133
+ get selectField() {
134
+ return this.field();
135
+ }
136
+ get singleSelectField() {
137
+ return this.field();
138
+ }
139
+ get textareaField() {
140
+ return this.field();
141
+ }
142
+ get fileUploadField() {
143
+ return this.field();
144
+ }
145
+ get maskedField() {
146
+ return this.field();
147
+ }
148
+ get buttonField() {
149
+ return this.field();
150
+ }
151
+ get buttonGroupField() {
152
+ return this.field();
153
+ }
154
+ get checkboxGroupOptionsKeys() {
155
+ return Object.keys(this.checkboxGroupField.options);
156
+ }
157
+ get radioGroupOptionsKeys() {
158
+ return Object.keys(this.radioGroupField.options);
159
+ }
160
+ get fileNameControl() {
161
+ return !!this.fileUploadField.fileNameFormProperty
162
+ ? this.formGroup().controls[this.fileUploadField.fileNameFormProperty]
163
+ : undefined;
164
+ }
165
+ constructor() {
166
+ super();
167
+ this.submitForm = new EventEmitter();
168
+ this.DynamicFieldType = DynamicFieldType;
169
+ this.SelectDefaults = Defaults;
170
+ this.formGroup = input.required();
171
+ this.field = input.required();
172
+ this.layout = input.required();
173
+ this.validationStatusDescriptions = [];
174
+ this.textService = inject(TextService);
175
+ this.wrapperClasses = computed(() => {
176
+ const isVisible = this.field().isVisible?.() ?? true;
177
+ const columnClasses = ColumnSizeHelper.getSizeClasses(this.field().colSize);
178
+ return `${columnClasses} ${isVisible ? '' : 'd-none'}`;
179
+ });
180
+ this.errorsHelper = inject(ErrorsHelper);
181
+ effect(() => {
182
+ const control = this.formControl;
183
+ const isVisible = this.field().isVisible?.() ?? true;
184
+ // If a field is not visible, we should remove its validators and restore if it becomes visible again.
185
+ if (!!control) {
186
+ if (isVisible) {
187
+ const fieldConfig = this.field();
188
+ const originalValidators = fieldConfig.validators || [];
189
+ const finalValidators = [...originalValidators];
190
+ if (fieldConfig.isRequired && !originalValidators.includes(Validators.required)) {
191
+ finalValidators.push(Validators.required);
192
+ }
193
+ control.setValidators(finalValidators);
194
+ }
195
+ else {
196
+ control.clearValidators();
197
+ }
198
+ control.updateValueAndValidity({ emitEvent: false });
199
+ }
200
+ });
201
+ }
202
+ ngOnInit() {
203
+ if (!!this.formControl) {
204
+ const statusSub = this.formControl.statusChanges.subscribe(() => this.updateValidationDisplay());
205
+ this.addSubscriptions(statusSub);
206
+ }
207
+ }
208
+ onBlur() {
209
+ if (!!this.formControl) {
210
+ this.formControl.markAsTouched();
211
+ this.updateValidationDisplay();
212
+ }
213
+ }
214
+ setControlValue(value) {
215
+ this.formControl.setValue(value);
216
+ this.formControl.markAsDirty();
217
+ }
218
+ getText(textModel) {
219
+ return this.textService.getText(textModel);
220
+ }
221
+ getOptionDescription(key, type) {
222
+ return type === 'checkbox' ?
223
+ this.checkboxGroupField.options[key] : this.radioGroupField.options[key];
224
+ }
225
+ handleFileSelected(event) {
226
+ this.formControl.setValue(!!this.fileUploadField.saveAsDataUrl ? event?.dataUrl : event?.file);
227
+ this.formControl.markAsDirty();
228
+ if (!!this.fileUploadField.fileNameFormProperty) {
229
+ this.fileNameControl.setValue(event?.file.name);
230
+ }
231
+ }
232
+ onInputEnter() {
233
+ if (!!this.inputField.shouldSubmitOnEnter) {
234
+ this.submitForm.next();
235
+ }
236
+ }
237
+ updateValidationDisplay() {
238
+ if (this.formControl && this.formControl.invalid && this.formControl.touched) {
239
+ this.validationStatusDescriptions = this.errorsHelper.getMessages(this.formControl)
240
+ .map(t => ({ text: t, isTranslated: true }));
241
+ this.validationStatus = 'invalid';
242
+ }
243
+ else {
244
+ this.validationStatusDescriptions = [];
245
+ this.validationStatus = this.field().showValidStatus && this.formControl?.touched ? 'valid' : undefined;
246
+ }
247
+ }
248
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: DynamicFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
249
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: DynamicFieldComponent, selector: "upd-dynamic-field", inputs: { formGroup: { classPropertyName: "formGroup", publicName: "formGroup", isSignal: true, isRequired: true, transformFunction: null }, field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null }, layout: { classPropertyName: "layout", publicName: "layout", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { submitForm: "submitForm" }, host: { properties: { "class": "this.hostClasses" } }, usesInheritance: true, ngImport: i0, template: "@switch (field().type) {\n @case (DynamicFieldType.Input) {\n <upd-input [name]=\"field().name\" [label]=\"field().label\" [placeholder]=\"field().placeholder\" [hint]=\"field().hint\"\n [hintAsTooltip]=\"field().hintAsTooltip || false\" [validationStatus]=\"validationStatus\"\n [validationStatusDescriptions]=\"validationStatusDescriptions\" [layout]=\"layout()\" [isDisabled]=\"field().isDisabled || false\"\n [type]=\"inputField.inputType || 'text'\" [labelColSize]=\"field().labelColSize\" [value]=\"formControl.value\"\n (valueChange)=\"setControlValue($event)\" (blurred)=\"onBlur()\" (keyUpEnter)=\"onInputEnter()\">\n @if (!!inputField.prefix) {\n <ng-template updInputPrepend>\n {{ textService.getText(inputField.prefix) }}\n </ng-template>\n }\n\n @if (!!inputField.suffix) {\n <ng-template updInputAppend>\n {{ textService.getText(inputField.suffix) }}\n </ng-template>\n }\n </upd-input>\n }\n @case (DynamicFieldType.Checkbox) {\n <upd-checkbox [name]=\"field().name\" [label]=\"field().label\" [hint]=\"field().hint\" [hintAsTooltip]=\"field().hintAsTooltip || false\"\n [validationStatus]=\"validationStatus\" [validationStatusDescriptions]=\"validationStatusDescriptions\" [value]=\"true\"\n [isDisabled]=\"field().isDisabled || false\" [isChecked]=\"formControl.value\" [isInline]=\"checkboxField.isInline || false\"\n [isSwitch]=\"checkboxField.isSwitch || false\" (changed)=\"setControlValue($event)\"></upd-checkbox>\n }\n @case (DynamicFieldType.CheckboxGroup) {\n @if (!!field().label) {\n <label class=\"form-label\">{{ getText(field().label) }}</label>\n }\n\n @for (option of checkboxGroupOptionsKeys; track option) {\n <upd-checkbox [name]=\"field().name\" [label]=\"getOptionDescription(option, 'checkbox')\" [hint]=\"field().hint\"\n [hintAsTooltip]=\"field().hintAsTooltip || false\" [validationStatus]=\"validationStatus\"\n [validationStatusDescriptions]=\"validationStatusDescriptions\" [value]=\"option\" [isDisabled]=\"field().isDisabled || false\"\n [isChecked]=\"formControl.value\" [isInline]=\"checkboxField.isInline || false\" [isSwitch]=\"checkboxField.isSwitch || false\"\n (changed)=\"setControlValue(option)\"></upd-checkbox>\n }\n }\n @case (DynamicFieldType.Radio) {\n <upd-radio [name]=\"field().name\" [label]=\"field().label\" [hint]=\"field().hint\" [hintAsTooltip]=\"field().hintAsTooltip || false\"\n [validationStatus]=\"validationStatus\" [validationStatusDescriptions]=\"validationStatusDescriptions\" [value]=\"true\"\n [isChecked]=\"formControl.value\" [isDisabled]=\"field().isDisabled || false\" [isInline]=\"radioField.isInline || false\"\n (selected)=\"setControlValue($event)\">\n </upd-radio>\n }\n @case (DynamicFieldType.RadioGroup) {\n @if (!!field().label) {\n <label class=\"form-label\">{{ getText(field().label) }}</label>\n }\n\n @for (option of radioGroupOptionsKeys; track option) {\n <upd-radio [name]=\"field().name\" [label]=\"getOptionDescription(option, 'radio')\" [hint]=\"field().hint\"\n [hintAsTooltip]=\"field().hintAsTooltip || false\" [validationStatus]=\"validationStatus\"\n [validationStatusDescriptions]=\"validationStatusDescriptions\" [value]=\"option\" [isDisabled]=\"field().isDisabled || false\"\n [isChecked]=\"formControl.value\" [isInline]=\"checkboxField.isInline || false\"\n (selected)=\"setControlValue(option)\"></upd-radio>\n }\n }\n @case (DynamicFieldType.Select) {\n <upd-select [name]=\"field().name\" [label]=\"field().label\" [hint]=\"field().hint\" [hintAsTooltip]=\"field().hintAsTooltip || false\"\n [validationStatus]=\"validationStatus\" [validationStatusDescriptions]=\"validationStatusDescriptions\"\n [useSystemStyle]=\"singleSelectField.useSystemStyle || false\" [isDisabled]=\"field().isDisabled || false\"\n [items]=\"selectField.items\" [layout]=\"layout()\" [labelColSize]=\"field().labelColSize\" [store]=\"selectField.store!\"\n [observable]=\"selectField.observable\" [itemKey]=\"selectField.itemKey\" [itemValue]=\"selectField.itemValue\"\n [dropdownMaxHeight]=\"selectField.dropdownMaxHeight || SelectDefaults.dropdownMaxHeight\"\n [typeaheadDebounce]=\"selectField.typeaheadDebounce || SelectDefaults.typeaheadDebounce\"\n [shouldAutoSearch]=\"selectField.shouldAutoSearch || SelectDefaults.shouldAutoSearch\"\n [shouldCloseOnOutsideClick]=\"selectField.shouldCloseOnOutsideClick || SelectDefaults.shouldCloseOnOutsideClick\"\n [shouldTruncateSelectedText]=\"selectField.shouldTruncateSelectedText\" [parentValue]=\"selectField.parentValue\"\n [value]=\"formControl.value\" (selectedItem)=\"setControlValue($event?.value)\"></upd-select>\n }\n @case (DynamicFieldType.SelectMultiple) {\n <upd-select-multiple [name]=\"field().name\" [label]=\"field().label\" [hint]=\"field().hint\"\n [hintAsTooltip]=\"field().hintAsTooltip || false\" [validationStatus]=\"validationStatus\"\n [validationStatusDescriptions]=\"validationStatusDescriptions\" [isDisabled]=\"field().isDisabled || false\"\n [items]=\"selectField.items\" [layout]=\"layout()\" [labelColSize]=\"field().labelColSize\" [store]=\"selectField.store!\"\n [observable]=\"selectField.observable\" [itemKey]=\"selectField.itemKey\" [itemValue]=\"selectField.itemValue\"\n [dropdownMaxHeight]=\"selectField.dropdownMaxHeight || SelectDefaults.dropdownMaxHeight\"\n [typeaheadDebounce]=\"selectField.typeaheadDebounce || SelectDefaults.typeaheadDebounce\"\n [shouldAutoSearch]=\"selectField.shouldAutoSearch || SelectDefaults.shouldAutoSearch\" [parentValue]=\"selectField.parentValue\"\n [shouldCloseOnOutsideClick]=\"selectField.shouldCloseOnOutsideClick || SelectDefaults.shouldCloseOnOutsideClick\"\n [selectedValues]=\"formControl.value\" (selectedIds)=\"setControlValue($event)\"></upd-select-multiple>\n }\n @case (DynamicFieldType.Label) {\n <label class=\"form-label\">{{ getText(field().label) }}</label>\n }\n @case (DynamicFieldType.TextArea) {\n <upd-textarea [name]=\"field().name\" [label]=\"field().label\" [placeholder]=\"field().placeholder\" [hint]=\"field().hint\"\n [hintAsTooltip]=\"field().hintAsTooltip || false\" [validationStatus]=\"validationStatus\"\n [validationStatusDescriptions]=\"validationStatusDescriptions\" [isDisabled]=\"field().isDisabled || false\"\n [value]=\"formControl.value\" [customClasses]=\"textareaField.customClasses\" [wrapperClasses]=\"textareaField.wrapperClasses\"\n [maxLength]=\"textareaField.maxLength\" [rows]=\"textareaField.rows\"\n [displayCharactersCount]=\"textareaField.displayCharactersCount || false\" (valueChange)=\"setControlValue($event)\">\n </upd-textarea>\n }\n @case (DynamicFieldType.FileUpload) {\n <upd-file-upload [name]=\"field().name\" [label]=\"field().label\" [hint]=\"field().hint\" [isDisabled]=\"field().isDisabled || false\"\n [hintAsTooltip]=\"field().hintAsTooltip || false\" [validationStatus]=\"validationStatus\" [fileName]=\"fileNameControl?.value\"\n [validationStatusDescriptions]=\"validationStatusDescriptions\" [allowFilesDrop]=\"fileUploadField.allowFilesDrop || false\"\n [title]=\"fileUploadField.title\" [labelColSize]=\"field().labelColSize\" [minFileSize]=\"fileUploadField.minFileSize\"\n [isMultiple]=\"fileUploadField.isMultiple || false\" [allowedExtensions]=\"fileUploadField.allowedExtensions || '*'\"\n [maxFileSize]=\"fileUploadField.maxFileSize\" [layout]=\"layout()\" (fileChanged)=\"handleFileSelected($event)\"></upd-file-upload>\n }\n @case (DynamicFieldType.MaskedInput) {\n <upd-input [name]=\"field().name\" [label]=\"field().label\" [placeholder]=\"field().placeholder\" [hint]=\"field().hint\"\n [hintAsTooltip]=\"field().hintAsTooltip || false\" [validationStatus]=\"validationStatus\" [mask]=\"maskedField.mask\"\n [maskConfig]=\"maskedField.maskConfig\" [validationStatusDescriptions]=\"validationStatusDescriptions\" [layout]=\"layout()\"\n [isDisabled]=\"field().isDisabled || false\" [type]=\"inputField.inputType || 'text'\" [labelColSize]=\"field().labelColSize\"\n [value]=\"formControl.value\" (valueChange)=\"setControlValue($event)\" (blurred)=\"onBlur()\" (keyUpEnter)=\"onInputEnter()\">\n @if (!!inputField.prefix) {\n <ng-template updInputPrepend>\n {{ textService.getText(inputField.prefix) }}\n </ng-template>\n }\n\n @if (!!inputField.suffix) {\n <ng-template updInputAppend>\n {{ textService.getText(inputField.suffix) }}\n </ng-template>\n }\n </upd-input>\n }\n @case(DynamicFieldType.Button) {\n <upd-button [text]=\"field().label\" [isDisabled]=\"field().isDisabled || false\" [model]=\"buttonField.model\" />\n }\n @case(DynamicFieldType.ButtonGroup) {\n @if(!!field().label) {\n <label class=\"form-label\">{{ getText(field().label) }}</label>\n }\n\n <div class=\"btn-group\" role=\"group\">\n @for (btn of buttonGroupField.buttons; track btn) {\n <upd-button [model]=\"btn\" [isDisabled]=\"field().isDisabled || false\" />\n }\n </div>\n }\n}", styles: [""], dependencies: [{ kind: "component", type: i1.ButtonComponent, selector: "upd-button", inputs: ["model", "text", "brandColorStyle", "customClasses", "isOutline", "isGhost", "isSquare", "isPill", "isIcon", "isLoading", "isList", "isFloating", "isAction", "isNavigationLink", "isLink", "shouldIgnoreBtnClass", "iconModel", "iconPosition", "isDisabled", "isActive", "badgeConfig", "colorStyle", "size", "title"], outputs: ["clicked"] }, { kind: "component", type: i2.InputComponent, selector: "upd-input", inputs: ["type", "mask", "maskConfig", "value", "size", "customClasses", "wrapperClasses", "maxLength", "isPlainText", "isReadOnly", "isLoading", "isRound", "isFlush", "isInputGroupFlat", "isPrependButton", "isAppendButton", "isFloating", "loaderPosition", "prependIconModel", "appendIconModel", "isValidationStatusLight", "layout"], outputs: ["valueChange", "blurred", "keyDown", "keyDownEsc", "keyUpEnter"] }, { kind: "directive", type: i2.InputAppendDirective, selector: "ng-template[updInputAppend]" }, { kind: "directive", type: i2.InputPrependDirective, selector: "ng-template[updInputPrepend]" }, { kind: "component", type: i3.CheckboxComponent, selector: "upd-checkbox", inputs: ["wrapperClasses", "value", "customClasses", "isChecked", "isInline", "isSwitch", "isIndeterminate"], outputs: ["changed", "isCheckedChange", "isIndeterminateChange"] }, { kind: "component", type: i4.RadioComponent, selector: "upd-radio", inputs: ["wrapperClasses", "value", "customClasses", "isChecked", "isInline"], outputs: ["selected"] }, { kind: "component", type: i5.SelectComponent, selector: "upd-select", inputs: ["useSystemStyle", "shouldShowClearButton", "shouldTruncateSelectedText", "isCompact", "value"], outputs: ["selectedItem"] }, { kind: "component", type: i5.SelectMultipleComponent, selector: "upd-select-multiple", inputs: ["selectedValues"], outputs: ["selectedItems", "selectedIds"] }, { kind: "component", type: i6.TextareaComponent, selector: "upd-textarea", inputs: ["value", "customClasses", "wrapperClasses", "maxLength", "rows", "displayCharactersCount"], outputs: ["valueChange"] }, { kind: "component", type: i7.FileUploadComponent, selector: "upd-file-upload", inputs: ["fileName", "title", "allowFilesDrop", "isMultiple", "allowedExtensions", "minFileSize", "maxFileSize", "layout"], outputs: ["fileChanged"] }] }); }
250
+ }
251
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: DynamicFieldComponent, decorators: [{
252
+ type: Component,
253
+ args: [{ selector: 'upd-dynamic-field', template: "@switch (field().type) {\n @case (DynamicFieldType.Input) {\n <upd-input [name]=\"field().name\" [label]=\"field().label\" [placeholder]=\"field().placeholder\" [hint]=\"field().hint\"\n [hintAsTooltip]=\"field().hintAsTooltip || false\" [validationStatus]=\"validationStatus\"\n [validationStatusDescriptions]=\"validationStatusDescriptions\" [layout]=\"layout()\" [isDisabled]=\"field().isDisabled || false\"\n [type]=\"inputField.inputType || 'text'\" [labelColSize]=\"field().labelColSize\" [value]=\"formControl.value\"\n (valueChange)=\"setControlValue($event)\" (blurred)=\"onBlur()\" (keyUpEnter)=\"onInputEnter()\">\n @if (!!inputField.prefix) {\n <ng-template updInputPrepend>\n {{ textService.getText(inputField.prefix) }}\n </ng-template>\n }\n\n @if (!!inputField.suffix) {\n <ng-template updInputAppend>\n {{ textService.getText(inputField.suffix) }}\n </ng-template>\n }\n </upd-input>\n }\n @case (DynamicFieldType.Checkbox) {\n <upd-checkbox [name]=\"field().name\" [label]=\"field().label\" [hint]=\"field().hint\" [hintAsTooltip]=\"field().hintAsTooltip || false\"\n [validationStatus]=\"validationStatus\" [validationStatusDescriptions]=\"validationStatusDescriptions\" [value]=\"true\"\n [isDisabled]=\"field().isDisabled || false\" [isChecked]=\"formControl.value\" [isInline]=\"checkboxField.isInline || false\"\n [isSwitch]=\"checkboxField.isSwitch || false\" (changed)=\"setControlValue($event)\"></upd-checkbox>\n }\n @case (DynamicFieldType.CheckboxGroup) {\n @if (!!field().label) {\n <label class=\"form-label\">{{ getText(field().label) }}</label>\n }\n\n @for (option of checkboxGroupOptionsKeys; track option) {\n <upd-checkbox [name]=\"field().name\" [label]=\"getOptionDescription(option, 'checkbox')\" [hint]=\"field().hint\"\n [hintAsTooltip]=\"field().hintAsTooltip || false\" [validationStatus]=\"validationStatus\"\n [validationStatusDescriptions]=\"validationStatusDescriptions\" [value]=\"option\" [isDisabled]=\"field().isDisabled || false\"\n [isChecked]=\"formControl.value\" [isInline]=\"checkboxField.isInline || false\" [isSwitch]=\"checkboxField.isSwitch || false\"\n (changed)=\"setControlValue(option)\"></upd-checkbox>\n }\n }\n @case (DynamicFieldType.Radio) {\n <upd-radio [name]=\"field().name\" [label]=\"field().label\" [hint]=\"field().hint\" [hintAsTooltip]=\"field().hintAsTooltip || false\"\n [validationStatus]=\"validationStatus\" [validationStatusDescriptions]=\"validationStatusDescriptions\" [value]=\"true\"\n [isChecked]=\"formControl.value\" [isDisabled]=\"field().isDisabled || false\" [isInline]=\"radioField.isInline || false\"\n (selected)=\"setControlValue($event)\">\n </upd-radio>\n }\n @case (DynamicFieldType.RadioGroup) {\n @if (!!field().label) {\n <label class=\"form-label\">{{ getText(field().label) }}</label>\n }\n\n @for (option of radioGroupOptionsKeys; track option) {\n <upd-radio [name]=\"field().name\" [label]=\"getOptionDescription(option, 'radio')\" [hint]=\"field().hint\"\n [hintAsTooltip]=\"field().hintAsTooltip || false\" [validationStatus]=\"validationStatus\"\n [validationStatusDescriptions]=\"validationStatusDescriptions\" [value]=\"option\" [isDisabled]=\"field().isDisabled || false\"\n [isChecked]=\"formControl.value\" [isInline]=\"checkboxField.isInline || false\"\n (selected)=\"setControlValue(option)\"></upd-radio>\n }\n }\n @case (DynamicFieldType.Select) {\n <upd-select [name]=\"field().name\" [label]=\"field().label\" [hint]=\"field().hint\" [hintAsTooltip]=\"field().hintAsTooltip || false\"\n [validationStatus]=\"validationStatus\" [validationStatusDescriptions]=\"validationStatusDescriptions\"\n [useSystemStyle]=\"singleSelectField.useSystemStyle || false\" [isDisabled]=\"field().isDisabled || false\"\n [items]=\"selectField.items\" [layout]=\"layout()\" [labelColSize]=\"field().labelColSize\" [store]=\"selectField.store!\"\n [observable]=\"selectField.observable\" [itemKey]=\"selectField.itemKey\" [itemValue]=\"selectField.itemValue\"\n [dropdownMaxHeight]=\"selectField.dropdownMaxHeight || SelectDefaults.dropdownMaxHeight\"\n [typeaheadDebounce]=\"selectField.typeaheadDebounce || SelectDefaults.typeaheadDebounce\"\n [shouldAutoSearch]=\"selectField.shouldAutoSearch || SelectDefaults.shouldAutoSearch\"\n [shouldCloseOnOutsideClick]=\"selectField.shouldCloseOnOutsideClick || SelectDefaults.shouldCloseOnOutsideClick\"\n [shouldTruncateSelectedText]=\"selectField.shouldTruncateSelectedText\" [parentValue]=\"selectField.parentValue\"\n [value]=\"formControl.value\" (selectedItem)=\"setControlValue($event?.value)\"></upd-select>\n }\n @case (DynamicFieldType.SelectMultiple) {\n <upd-select-multiple [name]=\"field().name\" [label]=\"field().label\" [hint]=\"field().hint\"\n [hintAsTooltip]=\"field().hintAsTooltip || false\" [validationStatus]=\"validationStatus\"\n [validationStatusDescriptions]=\"validationStatusDescriptions\" [isDisabled]=\"field().isDisabled || false\"\n [items]=\"selectField.items\" [layout]=\"layout()\" [labelColSize]=\"field().labelColSize\" [store]=\"selectField.store!\"\n [observable]=\"selectField.observable\" [itemKey]=\"selectField.itemKey\" [itemValue]=\"selectField.itemValue\"\n [dropdownMaxHeight]=\"selectField.dropdownMaxHeight || SelectDefaults.dropdownMaxHeight\"\n [typeaheadDebounce]=\"selectField.typeaheadDebounce || SelectDefaults.typeaheadDebounce\"\n [shouldAutoSearch]=\"selectField.shouldAutoSearch || SelectDefaults.shouldAutoSearch\" [parentValue]=\"selectField.parentValue\"\n [shouldCloseOnOutsideClick]=\"selectField.shouldCloseOnOutsideClick || SelectDefaults.shouldCloseOnOutsideClick\"\n [selectedValues]=\"formControl.value\" (selectedIds)=\"setControlValue($event)\"></upd-select-multiple>\n }\n @case (DynamicFieldType.Label) {\n <label class=\"form-label\">{{ getText(field().label) }}</label>\n }\n @case (DynamicFieldType.TextArea) {\n <upd-textarea [name]=\"field().name\" [label]=\"field().label\" [placeholder]=\"field().placeholder\" [hint]=\"field().hint\"\n [hintAsTooltip]=\"field().hintAsTooltip || false\" [validationStatus]=\"validationStatus\"\n [validationStatusDescriptions]=\"validationStatusDescriptions\" [isDisabled]=\"field().isDisabled || false\"\n [value]=\"formControl.value\" [customClasses]=\"textareaField.customClasses\" [wrapperClasses]=\"textareaField.wrapperClasses\"\n [maxLength]=\"textareaField.maxLength\" [rows]=\"textareaField.rows\"\n [displayCharactersCount]=\"textareaField.displayCharactersCount || false\" (valueChange)=\"setControlValue($event)\">\n </upd-textarea>\n }\n @case (DynamicFieldType.FileUpload) {\n <upd-file-upload [name]=\"field().name\" [label]=\"field().label\" [hint]=\"field().hint\" [isDisabled]=\"field().isDisabled || false\"\n [hintAsTooltip]=\"field().hintAsTooltip || false\" [validationStatus]=\"validationStatus\" [fileName]=\"fileNameControl?.value\"\n [validationStatusDescriptions]=\"validationStatusDescriptions\" [allowFilesDrop]=\"fileUploadField.allowFilesDrop || false\"\n [title]=\"fileUploadField.title\" [labelColSize]=\"field().labelColSize\" [minFileSize]=\"fileUploadField.minFileSize\"\n [isMultiple]=\"fileUploadField.isMultiple || false\" [allowedExtensions]=\"fileUploadField.allowedExtensions || '*'\"\n [maxFileSize]=\"fileUploadField.maxFileSize\" [layout]=\"layout()\" (fileChanged)=\"handleFileSelected($event)\"></upd-file-upload>\n }\n @case (DynamicFieldType.MaskedInput) {\n <upd-input [name]=\"field().name\" [label]=\"field().label\" [placeholder]=\"field().placeholder\" [hint]=\"field().hint\"\n [hintAsTooltip]=\"field().hintAsTooltip || false\" [validationStatus]=\"validationStatus\" [mask]=\"maskedField.mask\"\n [maskConfig]=\"maskedField.maskConfig\" [validationStatusDescriptions]=\"validationStatusDescriptions\" [layout]=\"layout()\"\n [isDisabled]=\"field().isDisabled || false\" [type]=\"inputField.inputType || 'text'\" [labelColSize]=\"field().labelColSize\"\n [value]=\"formControl.value\" (valueChange)=\"setControlValue($event)\" (blurred)=\"onBlur()\" (keyUpEnter)=\"onInputEnter()\">\n @if (!!inputField.prefix) {\n <ng-template updInputPrepend>\n {{ textService.getText(inputField.prefix) }}\n </ng-template>\n }\n\n @if (!!inputField.suffix) {\n <ng-template updInputAppend>\n {{ textService.getText(inputField.suffix) }}\n </ng-template>\n }\n </upd-input>\n }\n @case(DynamicFieldType.Button) {\n <upd-button [text]=\"field().label\" [isDisabled]=\"field().isDisabled || false\" [model]=\"buttonField.model\" />\n }\n @case(DynamicFieldType.ButtonGroup) {\n @if(!!field().label) {\n <label class=\"form-label\">{{ getText(field().label) }}</label>\n }\n\n <div class=\"btn-group\" role=\"group\">\n @for (btn of buttonGroupField.buttons; track btn) {\n <upd-button [model]=\"btn\" [isDisabled]=\"field().isDisabled || false\" />\n }\n </div>\n }\n}" }]
254
+ }], ctorParameters: () => [], propDecorators: { hostClasses: [{
255
+ type: HostBinding,
256
+ args: ['class']
257
+ }], submitForm: [{
258
+ type: Output
259
+ }] } });
260
+
261
+ class FormComponent extends BaseComponent {
262
+ get titleText() {
263
+ return this.textService.getText(this.title());
264
+ }
265
+ constructor() {
266
+ super();
267
+ this.initialized = new EventEmitter();
268
+ this.dataLoaded = new EventEmitter(); // TODO: implementar
269
+ this.submitted = new EventEmitter();
270
+ /**
271
+ * Rows to generate the form.
272
+ */
273
+ this.rows = input.required();
274
+ /**
275
+ * Form's layout.
276
+ */
277
+ this.layout = input('vertical');
278
+ /**
279
+ * Title of the form.
280
+ * Optional.
281
+ */
282
+ this.title = input(undefined);
283
+ /**
284
+ * Whether the actions section will be displayed.
285
+ */
286
+ this.hasActionsSection = input(true);
287
+ /**
288
+ * Whether the form is contained in a card.
289
+ * If true, it'll display a card as a form wrapper.
290
+ */
291
+ this.isCard = input(false);
292
+ /**
293
+ * Whether the form is in read only mode, which means no fields can be edited.
294
+ */
295
+ this.isDisabled = input(false, { transform: (val) => typeof val === 'string' ? val === '' : val });
296
+ /**
297
+ * Whether the form is loading.
298
+ */
299
+ this.isLoading = input(false); // TODO: implementar
300
+ /**
301
+ * Whether the form is saving.
302
+ */
303
+ this.isSaving = input(false); // TODO: implementar
304
+ /**
305
+ * Current form data.
306
+ */
307
+ this.formData = model({});
308
+ this.formGroup = model(new FormGroup({}));
309
+ this.textService = inject(TextService);
310
+ effect(() => {
311
+ this.rows();
312
+ this.setupFormGroup();
313
+ });
314
+ }
315
+ ngOnInit() {
316
+ this.setupFormGroup();
317
+ this.initialized.emit();
318
+ const valueChangesSub = this.formGroup().valueChanges.subscribe(() => this.formData.set(this.formGroup().getRawValue()));
319
+ this.addSubscriptions(valueChangesSub);
320
+ }
321
+ submit() {
322
+ this.formGroup().markAllAsTouched();
323
+ this.formGroup().updateValueAndValidity();
324
+ Object.values(this.formGroup().controls).forEach(control => control.updateValueAndValidity());
325
+ if (this.formGroup().valid) {
326
+ this.submitted.emit(this.formGroup().value);
327
+ }
328
+ }
329
+ setupFormGroup() {
330
+ const allFields = this.rows().map(r => r.fields).reduce((acc, fields) => acc.concat(fields), []);
331
+ allFields.forEach(field => {
332
+ const validators = field.validators || [];
333
+ if (field.isRequired && !validators.includes(Validators.required)) {
334
+ validators.push(Validators.required);
335
+ }
336
+ // TODO: handle extra cases, when ready. DateRange, DateTimeRange, TimeRange, etc.
337
+ switch (field.type) {
338
+ case DynamicFieldType.FileUpload:
339
+ this.formGroup().addControl(field.name, new FormControl({
340
+ value: field.initValue,
341
+ disabled: field.isDisabled || this.isDisabled()
342
+ }, { validators: validators }));
343
+ const fileNameFormProp = field.fileNameFormProperty;
344
+ if (!!fileNameFormProp) {
345
+ this.formGroup().addControl(fileNameFormProp, new FormControl({
346
+ value: field.initValue,
347
+ disabled: field.isDisabled || this.isDisabled()
348
+ }, { validators: validators }));
349
+ }
350
+ break;
351
+ // Buttons don't generate values, so they don't need to have a control.
352
+ case DynamicFieldType.Button:
353
+ case DynamicFieldType.ButtonGroup:
354
+ break;
355
+ default:
356
+ this.formGroup().addControl(field.name, new FormControl({
357
+ value: field.initValue,
358
+ disabled: field.isDisabled || this.isDisabled()
359
+ }, { validators: validators, updateOn: field.updateOn || 'blur' }));
360
+ }
361
+ });
362
+ this.bindAttachments(allFields);
363
+ }
364
+ /**
365
+ * Glue the declarative AttachmentRule array to actual FormControls.
366
+ **/
367
+ bindAttachments(fields) {
368
+ fields.forEach(childField => {
369
+ if (!childField.attachments?.length) {
370
+ return;
371
+ }
372
+ const childCtrl = this.formGroup().get(childField.name);
373
+ childField.attachments.forEach((rule) => {
374
+ const parentCtrl = this.formGroup().get(rule.name);
375
+ if (!parentCtrl) {
376
+ console.warn(`[FormComponent] attachment parent '${rule.name}' not found`);
377
+ return;
378
+ }
379
+ const sub = parentCtrl.valueChanges
380
+ .pipe(startWith(parentCtrl.value))
381
+ .subscribe(parentVal => {
382
+ const childVal = childCtrl.value;
383
+ let shouldDisable = false;
384
+ if (rule.type === AttachmentTypeEnum.ParentLoad || rule.disableIfEmpty) {
385
+ shouldDisable = parentVal === null || parentVal === undefined || parentVal === '';
386
+ }
387
+ if (!!rule.disableIf) {
388
+ shouldDisable = rule.disableIf(childVal, parentVal);
389
+ }
390
+ if (shouldDisable) {
391
+ if (rule.clearValueIfDisabled && childCtrl.enabled) {
392
+ childCtrl.setValue(null, { emitEvent: false });
393
+ }
394
+ childField.parentValue = undefined;
395
+ childCtrl.disable({ emitEvent: false });
396
+ }
397
+ else {
398
+ childField.parentValue = parentVal;
399
+ if (childCtrl.disabled) {
400
+ childCtrl.enable({ emitEvent: false });
401
+ }
402
+ if (rule.clearValueIfEmpty && !parentVal) {
403
+ childCtrl.setValue(null, { emitEvent: false });
404
+ }
405
+ }
406
+ if (rule.visibleIf) {
407
+ const visible = rule.visibleIf(childVal, parentVal);
408
+ childField.isHidden = !visible;
409
+ }
410
+ });
411
+ this.addSubscriptions(sub);
412
+ });
413
+ });
414
+ }
415
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: FormComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
416
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: FormComponent, selector: "upd-form", inputs: { rows: { classPropertyName: "rows", publicName: "rows", isSignal: true, isRequired: true, transformFunction: null }, layout: { classPropertyName: "layout", publicName: "layout", isSignal: true, isRequired: false, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, hasActionsSection: { classPropertyName: "hasActionsSection", publicName: "hasActionsSection", isSignal: true, isRequired: false, transformFunction: null }, isCard: { classPropertyName: "isCard", publicName: "isCard", isSignal: true, isRequired: false, transformFunction: null }, isDisabled: { classPropertyName: "isDisabled", publicName: "isDisabled", isSignal: true, isRequired: false, transformFunction: null }, isLoading: { classPropertyName: "isLoading", publicName: "isLoading", isSignal: true, isRequired: false, transformFunction: null }, isSaving: { classPropertyName: "isSaving", publicName: "isSaving", isSignal: true, isRequired: false, transformFunction: null }, formData: { classPropertyName: "formData", publicName: "formData", isSignal: true, isRequired: false, transformFunction: null }, formGroup: { classPropertyName: "formGroup", publicName: "formGroup", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { initialized: "initialized", dataLoaded: "dataLoaded", submitted: "submitted", formData: "formDataChange", formGroup: "formGroupChange" }, usesInheritance: true, ngImport: i0, template: "<ng-container *transloco=\"let t; prefix: 'UpDevs.Form'\">\n <div [class.card]=\"isCard()\">\n @if (!!titleText) {\n <div [class.card-header]=\"isCard()\">\n <h3 [class.card-title]=\"isCard()\">{{ titleText }}</h3>\n </div>\n }\n <div [class.card-body]=\"isCard()\">\n @for (row of rows(); track row; let isFirst = $first) {\n <div class=\"row\" [class.mt-4]=\"!isFirst\">\n @if (!!row.title) {\n <div class=\"card-title col-12\">{{ textService.getText(row.title) }}</div>\n }\n\n @for (field of row.fields; track field.name) {\n @if (!field.isHidden) {\n <upd-dynamic-field [layout]=\"layout()\" [field]=\"field\" [formGroup]=\"formGroup()\" (submitForm)=\"submit()\">\n </upd-dynamic-field>\n }\n }\n </div>\n }\n </div>\n\n @if (hasActionsSection()) {\n <div [class.card-footer]=\"isCard()\" [class.mt-4]=\"!isCard()\">\n <upd-button colorStyle=\"primary\" (clicked)=\"submit()\">\n {{ t('Submit') }}\n </upd-button>\n </div>\n }\n </div>\n</ng-container>", styles: [""], dependencies: [{ kind: "directive", type: i1$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i1.ButtonComponent, selector: "upd-button", inputs: ["model", "text", "brandColorStyle", "customClasses", "isOutline", "isGhost", "isSquare", "isPill", "isIcon", "isLoading", "isList", "isFloating", "isAction", "isNavigationLink", "isLink", "shouldIgnoreBtnClass", "iconModel", "iconPosition", "isDisabled", "isActive", "badgeConfig", "colorStyle", "size", "title"], outputs: ["clicked"] }, { kind: "directive", type: i1$2.TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "component", type: DynamicFieldComponent, selector: "upd-dynamic-field", inputs: ["formGroup", "field", "layout"], outputs: ["submitForm"] }] }); }
9
417
  }
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: FormModule, decorators: [{
418
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: FormComponent, decorators: [{
419
+ type: Component,
420
+ args: [{ selector: 'upd-form', template: "<ng-container *transloco=\"let t; prefix: 'UpDevs.Form'\">\n <div [class.card]=\"isCard()\">\n @if (!!titleText) {\n <div [class.card-header]=\"isCard()\">\n <h3 [class.card-title]=\"isCard()\">{{ titleText }}</h3>\n </div>\n }\n <div [class.card-body]=\"isCard()\">\n @for (row of rows(); track row; let isFirst = $first) {\n <div class=\"row\" [class.mt-4]=\"!isFirst\">\n @if (!!row.title) {\n <div class=\"card-title col-12\">{{ textService.getText(row.title) }}</div>\n }\n\n @for (field of row.fields; track field.name) {\n @if (!field.isHidden) {\n <upd-dynamic-field [layout]=\"layout()\" [field]=\"field\" [formGroup]=\"formGroup()\" (submitForm)=\"submit()\">\n </upd-dynamic-field>\n }\n }\n </div>\n }\n </div>\n\n @if (hasActionsSection()) {\n <div [class.card-footer]=\"isCard()\" [class.mt-4]=\"!isCard()\">\n <upd-button colorStyle=\"primary\" (clicked)=\"submit()\">\n {{ t('Submit') }}\n </upd-button>\n </div>\n }\n </div>\n</ng-container>" }]
421
+ }], ctorParameters: () => [], propDecorators: { initialized: [{
422
+ type: Output
423
+ }], dataLoaded: [{
424
+ type: Output
425
+ }], submitted: [{
426
+ type: Output
427
+ }] } });
428
+
429
+ var UpDevs$1 = {
430
+ Form: {
431
+ Submit: "Submit",
432
+ ErrorMessages: {
433
+ Generic: "Error",
434
+ Email: "Invalid email",
435
+ Max: "Value should not be greater than {{value}}",
436
+ Min: "Value should not be lower than {{value}}",
437
+ MaxLength: "Maximum length: {{value}}",
438
+ MinLength: "Minimum length: {{value}}",
439
+ Required: "Required field",
440
+ RequiredTrue: "This field must be selected"
441
+ }
442
+ }
443
+ };
444
+ var en = {
445
+ UpDevs: UpDevs$1
446
+ };
447
+
448
+ var en$1 = /*#__PURE__*/Object.freeze({
449
+ __proto__: null,
450
+ UpDevs: UpDevs$1,
451
+ default: en
452
+ });
453
+
454
+ var UpDevs = {
455
+ Form: {
456
+ Submit: "Enviar",
457
+ ErrorMessages: {
458
+ Generic: "Erro",
459
+ Email: "E-mail inválido",
460
+ Max: "O valor não pode ser maior do que {{value}}",
461
+ Min: "O valor não pode ser menor do que {{value}}",
462
+ MaxLength: "Tamanho máximo permitido: {{value}}",
463
+ MinLength: "Tamanho mínimo permitido: {{value}}",
464
+ Required: "Campo obrigatório",
465
+ RequiredTrue: "Este campo deve ser selecionado"
466
+ }
467
+ }
468
+ };
469
+ var pt = {
470
+ UpDevs: UpDevs
471
+ };
472
+
473
+ var pt$1 = /*#__PURE__*/Object.freeze({
474
+ __proto__: null,
475
+ UpDevs: UpDevs,
476
+ default: pt
477
+ });
478
+
479
+ class UpdFormModule {
480
+ constructor(translocoService) {
481
+ translocoService.setFallbackLangForMissingTranslation({ fallbackLang: 'en' });
482
+ translocoService.setTranslation(en$1, 'en');
483
+ translocoService.setTranslation(pt$1, 'pt');
484
+ }
485
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: UpdFormModule, deps: [{ token: i1$2.TranslocoService }], target: i0.ɵɵFactoryTarget.NgModule }); }
486
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.1.0", ngImport: i0, type: UpdFormModule, declarations: [FormComponent,
487
+ DynamicFieldComponent], imports: [CommonModule,
488
+ ReactiveFormsModule,
489
+ UpdButtonModule,
490
+ TranslocoDirective,
491
+ UpdInputModule,
492
+ UpdCheckboxModule,
493
+ UpdRadioModule,
494
+ UpdDatePickerModule,
495
+ UpdSelectModule,
496
+ UpdTextareaModule,
497
+ UpdFileUploadModule,
498
+ UpdSdkModule], exports: [FormComponent] }); }
499
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: UpdFormModule, providers: [
500
+ ErrorsHelper
501
+ ], imports: [CommonModule,
502
+ ReactiveFormsModule,
503
+ UpdButtonModule,
504
+ UpdInputModule,
505
+ UpdCheckboxModule,
506
+ UpdRadioModule,
507
+ UpdDatePickerModule,
508
+ UpdSelectModule,
509
+ UpdTextareaModule,
510
+ UpdFileUploadModule,
511
+ UpdSdkModule] }); }
512
+ }
513
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: UpdFormModule, decorators: [{
11
514
  type: NgModule,
12
515
  args: [{
13
- declarations: [],
14
516
  imports: [
15
- CommonModule
517
+ CommonModule,
518
+ ReactiveFormsModule,
519
+ UpdButtonModule,
520
+ TranslocoDirective,
521
+ UpdInputModule,
522
+ UpdCheckboxModule,
523
+ UpdRadioModule,
524
+ UpdDatePickerModule,
525
+ UpdSelectModule,
526
+ UpdTextareaModule,
527
+ UpdFileUploadModule,
528
+ UpdSdkModule
529
+ ],
530
+ declarations: [
531
+ FormComponent,
532
+ DynamicFieldComponent
533
+ ],
534
+ exports: [
535
+ FormComponent
536
+ ],
537
+ providers: [
538
+ ErrorsHelper
16
539
  ]
17
540
  }]
18
- }] });
541
+ }], ctorParameters: () => [{ type: i1$2.TranslocoService }] });
19
542
 
20
543
  /**
21
544
  * Generated bundle index. Do not edit.
22
545
  */
23
546
 
24
- export { FormModule };
547
+ export { AttachmentTypeEnum, DynamicFieldType, FormComponent, UpdFormModule };
25
548
  //# sourceMappingURL=updevs-components-form.mjs.map