@nova-design-system/nova-webcomponents 3.0.0-beta.41 → 3.0.0-beta.42

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 (526) hide show
  1. package/dist/blazor-docs.json +16850 -0
  2. package/dist/cjs/_commonjsHelpers-b3309d7b.js +12 -0
  3. package/dist/cjs/_commonjsHelpers-b3309d7b.js.map +1 -0
  4. package/dist/cjs/{constants-79d2cdfc.js → constants-bcd6b2e2.js} +100 -2
  5. package/dist/cjs/constants-bcd6b2e2.js.map +1 -0
  6. package/dist/cjs/{index-5910ba06.js → index-9bda5507.js} +1364 -1182
  7. package/dist/cjs/index-9bda5507.js.map +1 -0
  8. package/dist/cjs/index.cjs.js +1 -1
  9. package/dist/cjs/inputmask-76b7b93f.js +3763 -0
  10. package/dist/cjs/inputmask-76b7b93f.js.map +1 -0
  11. package/dist/cjs/loader.cjs.js +2 -2
  12. package/dist/cjs/native.cjs.js +3 -3
  13. package/dist/cjs/native.cjs.js.map +1 -1
  14. package/dist/cjs/nv-alert.cjs.entry.js +3 -3
  15. package/dist/cjs/nv-alert.cjs.entry.js.map +1 -1
  16. package/dist/cjs/nv-avatar.cjs.entry.js +3 -3
  17. package/dist/cjs/nv-avatar.cjs.entry.js.map +1 -1
  18. package/dist/cjs/nv-badge_2.cjs.entry.js +16 -5
  19. package/dist/cjs/nv-badge_2.cjs.entry.js.map +1 -1
  20. package/dist/cjs/nv-base.cjs.entry.js +2 -2
  21. package/dist/cjs/nv-breadcrumb.cjs.entry.js +2 -2
  22. package/dist/cjs/nv-breadcrumbs.cjs.entry.js +2 -2
  23. package/dist/cjs/nv-button.cjs.entry.js +3 -3
  24. package/dist/cjs/nv-calendar.cjs.entry.js +77 -22
  25. package/dist/cjs/nv-calendar.cjs.entry.js.map +1 -1
  26. package/dist/cjs/nv-col.cjs.entry.js +2 -2
  27. package/dist/cjs/nv-datagrid.cjs.entry.js +267 -5
  28. package/dist/cjs/nv-datagrid.cjs.entry.js.map +1 -1
  29. package/dist/cjs/nv-datagridcolumn.cjs.entry.js +2 -2
  30. package/dist/cjs/nv-dialog.cjs.entry.js +15 -10
  31. package/dist/cjs/nv-dialog.cjs.entry.js.map +1 -1
  32. package/dist/cjs/nv-dialogfooter_2.cjs.entry.js +4 -4
  33. package/dist/cjs/nv-fieldcheckbox.cjs.entry.js +6 -6
  34. package/dist/cjs/nv-fieldcheckbox.cjs.entry.js.map +1 -1
  35. package/dist/cjs/nv-fielddate.cjs.entry.js +281 -0
  36. package/dist/cjs/nv-fielddate.cjs.entry.js.map +1 -0
  37. package/dist/cjs/nv-fielddaterange.cjs.entry.js +358 -0
  38. package/dist/cjs/nv-fielddaterange.cjs.entry.js.map +1 -0
  39. package/dist/cjs/nv-fielddropdown.cjs.entry.js +13 -24
  40. package/dist/cjs/nv-fielddropdown.cjs.entry.js.map +1 -1
  41. package/dist/cjs/nv-fielddropdownitem.cjs.entry.js +2 -2
  42. package/dist/cjs/nv-fieldmultiselect.cjs.entry.js +22 -30
  43. package/dist/cjs/nv-fieldmultiselect.cjs.entry.js.map +1 -1
  44. package/dist/cjs/nv-fieldnumber.cjs.entry.js +9 -6
  45. package/dist/cjs/nv-fieldnumber.cjs.entry.js.map +1 -1
  46. package/dist/cjs/nv-fieldpassword.cjs.entry.js +5 -13
  47. package/dist/cjs/nv-fieldpassword.cjs.entry.js.map +1 -1
  48. package/dist/cjs/nv-fieldradio.cjs.entry.js +4 -4
  49. package/dist/cjs/nv-fieldradio.cjs.entry.js.map +1 -1
  50. package/dist/cjs/nv-fieldselect.cjs.entry.js +7 -7
  51. package/dist/cjs/nv-fieldselect.cjs.entry.js.map +1 -1
  52. package/dist/cjs/nv-fieldtext.cjs.entry.js +5 -5
  53. package/dist/cjs/nv-fieldtext.cjs.entry.js.map +1 -1
  54. package/dist/cjs/nv-fieldtextarea.cjs.entry.js +4 -4
  55. package/dist/cjs/nv-fieldtextarea.cjs.entry.js.map +1 -1
  56. package/dist/cjs/nv-fieldtime.cjs.entry.js +12 -12
  57. package/dist/cjs/nv-fieldtime.cjs.entry.js.map +1 -1
  58. package/dist/cjs/nv-icon.cjs.entry.js +4 -4
  59. package/dist/cjs/nv-icon.cjs.entry.js.map +1 -1
  60. package/dist/cjs/{nv-iconbutton.cjs.entry.js → nv-iconbutton_2.cjs.entry.js} +44 -3
  61. package/dist/cjs/nv-iconbutton_2.cjs.entry.js.map +1 -0
  62. package/dist/cjs/nv-menu.cjs.entry.js +5 -5
  63. package/dist/cjs/nv-menu.cjs.entry.js.map +1 -1
  64. package/dist/cjs/nv-menuitem.cjs.entry.js +5 -5
  65. package/dist/cjs/nv-menuitem.cjs.entry.js.map +1 -1
  66. package/dist/cjs/nv-popover.cjs.entry.js +31 -18
  67. package/dist/cjs/nv-popover.cjs.entry.js.map +1 -1
  68. package/dist/cjs/nv-row.cjs.entry.js +2 -2
  69. package/dist/cjs/nv-stack.cjs.entry.js +2 -2
  70. package/dist/cjs/nv-table.cjs.entry.js +3 -3
  71. package/dist/cjs/nv-tablecolumn.cjs.entry.js +1 -1
  72. package/dist/cjs/nv-toggle.cjs.entry.js +3 -3
  73. package/dist/cjs/nv-toggle.cjs.entry.js.map +1 -1
  74. package/dist/cjs/nv-tooltip.cjs.entry.js +3 -3
  75. package/dist/cjs/nv-tooltip.cjs.entry.js.map +1 -1
  76. package/dist/collection/collection-manifest.json +4 -2
  77. package/dist/collection/components/nv-alert/nv-alert.js +2 -2
  78. package/dist/collection/components/nv-alert/nv-alert.js.map +1 -1
  79. package/dist/collection/components/nv-avatar/nv-avatar.js +8 -8
  80. package/dist/collection/components/nv-avatar/nv-avatar.js.map +1 -1
  81. package/dist/collection/components/nv-badge/nv-badge.js +4 -4
  82. package/dist/collection/components/nv-badge/nv-badge.js.map +1 -1
  83. package/dist/collection/components/nv-base/nv-base.js +1 -1
  84. package/dist/collection/components/nv-breadcrumb/nv-breadcrumb.js +1 -1
  85. package/dist/collection/components/nv-breadcrumbs/nv-breadcrumbs.js +1 -1
  86. package/dist/collection/components/nv-button/nv-button.js +1 -1
  87. package/dist/collection/components/nv-calendar/nv-calendar.css +13 -8
  88. package/dist/collection/components/nv-calendar/nv-calendar.js +82 -24
  89. package/dist/collection/components/nv-calendar/nv-calendar.js.map +1 -1
  90. package/dist/collection/components/nv-col/nv-col.js +1 -1
  91. package/dist/collection/components/nv-datagrid/nv-datagrid.docs.js +24 -0
  92. package/dist/collection/components/nv-datagrid/nv-datagrid.docs.js.map +1 -1
  93. package/dist/collection/components/nv-datagrid/nv-datagrid.js +89 -6
  94. package/dist/collection/components/nv-datagrid/nv-datagrid.js.map +1 -1
  95. package/dist/collection/components/nv-datagridcolumn/nv-datagridcolumn.js +1 -1
  96. package/dist/collection/components/nv-dialog/nv-dialog.js +13 -8
  97. package/dist/collection/components/nv-dialog/nv-dialog.js.map +1 -1
  98. package/dist/collection/components/nv-dialogfooter/nv-dialogfooter.js +1 -1
  99. package/dist/collection/components/nv-dialogheader/nv-dialogheader.js +1 -1
  100. package/dist/collection/components/nv-fieldcheckbox/nv-fieldcheckbox.css +56 -40
  101. package/dist/collection/components/nv-fieldcheckbox/nv-fieldcheckbox.js +7 -7
  102. package/dist/collection/components/nv-fieldcheckbox/nv-fieldcheckbox.js.map +1 -1
  103. package/dist/collection/components/nv-fielddate/nv-fielddate.docs.js +335 -0
  104. package/dist/collection/components/nv-fielddate/nv-fielddate.docs.js.map +1 -0
  105. package/dist/collection/components/nv-fielddate/nv-fielddate.js +845 -0
  106. package/dist/collection/components/nv-fielddate/nv-fielddate.js.map +1 -0
  107. package/dist/collection/components/nv-fielddate/styles/nv-fielddate.css +165 -0
  108. package/dist/collection/components/nv-fielddaterange/nv-fielddaterange.docs.js +284 -0
  109. package/dist/collection/components/nv-fielddaterange/nv-fielddaterange.docs.js.map +1 -0
  110. package/dist/collection/components/nv-fielddaterange/nv-fielddaterange.js +988 -0
  111. package/dist/collection/components/nv-fielddaterange/nv-fielddaterange.js.map +1 -0
  112. package/dist/collection/components/nv-fielddaterange/styles/nv-fielddaterange.css +192 -0
  113. package/dist/collection/components/nv-fielddropdown/nv-fielddropdown.js +11 -22
  114. package/dist/collection/components/nv-fielddropdown/nv-fielddropdown.js.map +1 -1
  115. package/dist/collection/components/nv-fielddropdown/styles/nv-fielddropdown.css +14 -16
  116. package/dist/collection/components/nv-fielddropdownitem/nv-fielddropdownitem.js +1 -1
  117. package/dist/collection/components/nv-fielddropdownitemcheck/nv-fielddropdownitemcheck.css +1 -0
  118. package/dist/collection/components/nv-fielddropdownitemcheck/nv-fielddropdownitemcheck.js +12 -1
  119. package/dist/collection/components/nv-fielddropdownitemcheck/nv-fielddropdownitemcheck.js.map +1 -1
  120. package/dist/collection/components/nv-fieldmultiselect/nv-fieldmultiselect.css +22 -24
  121. package/dist/collection/components/nv-fieldmultiselect/nv-fieldmultiselect.docs.js +1 -4
  122. package/dist/collection/components/nv-fieldmultiselect/nv-fieldmultiselect.docs.js.map +1 -1
  123. package/dist/collection/components/nv-fieldmultiselect/nv-fieldmultiselect.js +19 -48
  124. package/dist/collection/components/nv-fieldmultiselect/nv-fieldmultiselect.js.map +1 -1
  125. package/dist/collection/components/nv-fieldnumber/nv-fieldnumber.css +17 -21
  126. package/dist/collection/components/nv-fieldnumber/nv-fieldnumber.docs.js +1 -1
  127. package/dist/collection/components/nv-fieldnumber/nv-fieldnumber.docs.js.map +1 -1
  128. package/dist/collection/components/nv-fieldnumber/nv-fieldnumber.js +9 -6
  129. package/dist/collection/components/nv-fieldnumber/nv-fieldnumber.js.map +1 -1
  130. package/dist/collection/components/nv-fieldpassword/nv-fieldpassword.css +9 -10
  131. package/dist/collection/components/nv-fieldpassword/nv-fieldpassword.docs.js +1 -1
  132. package/dist/collection/components/nv-fieldpassword/nv-fieldpassword.docs.js.map +1 -1
  133. package/dist/collection/components/nv-fieldpassword/nv-fieldpassword.js +3 -11
  134. package/dist/collection/components/nv-fieldpassword/nv-fieldpassword.js.map +1 -1
  135. package/dist/collection/components/nv-fieldradio/nv-fieldradio.js +5 -5
  136. package/dist/collection/components/nv-fieldradio/nv-fieldradio.js.map +1 -1
  137. package/dist/collection/components/nv-fieldselect/nv-fieldselect.css +30 -15
  138. package/dist/collection/components/nv-fieldselect/nv-fieldselect.js +8 -8
  139. package/dist/collection/components/nv-fieldselect/nv-fieldselect.js.map +1 -1
  140. package/dist/collection/components/nv-fieldtext/nv-fieldtext.css +15 -16
  141. package/dist/collection/components/nv-fieldtext/nv-fieldtext.docs.js +1 -1
  142. package/dist/collection/components/nv-fieldtext/nv-fieldtext.docs.js.map +1 -1
  143. package/dist/collection/components/nv-fieldtext/nv-fieldtext.js +6 -6
  144. package/dist/collection/components/nv-fieldtext/nv-fieldtext.js.map +1 -1
  145. package/dist/collection/components/nv-fieldtextarea/nv-fieldtextarea.js +5 -5
  146. package/dist/collection/components/nv-fieldtextarea/nv-fieldtextarea.js.map +1 -1
  147. package/dist/collection/components/nv-fieldtime/nv-fieldtime.js +11 -11
  148. package/dist/collection/components/nv-fieldtime/nv-fieldtime.js.map +1 -1
  149. package/dist/collection/components/nv-fieldtime/{nv-fieldtime.css → styles/nv-fieldtime.css} +20 -32
  150. package/dist/collection/components/nv-icon/nv-icon.js +8 -8
  151. package/dist/collection/components/nv-icon/nv-icon.js.map +1 -1
  152. package/dist/collection/components/nv-iconbutton/nv-iconbutton.js +31 -1
  153. package/dist/collection/components/nv-iconbutton/nv-iconbutton.js.map +1 -1
  154. package/dist/collection/components/nv-loader/nv-loader.js +1 -1
  155. package/dist/collection/components/nv-menu/nv-menu.css +3 -0
  156. package/dist/collection/components/nv-menu/nv-menu.docs.js +6 -6
  157. package/dist/collection/components/nv-menu/nv-menu.docs.js.map +1 -1
  158. package/dist/collection/components/nv-menu/nv-menu.js +11 -12
  159. package/dist/collection/components/nv-menu/nv-menu.js.map +1 -1
  160. package/dist/collection/components/nv-menuitem/nv-menuitem.css +3 -0
  161. package/dist/collection/components/nv-menuitem/nv-menuitem.js +27 -9
  162. package/dist/collection/components/nv-menuitem/nv-menuitem.js.map +1 -1
  163. package/dist/collection/components/nv-popover/nv-popover.css +5 -5
  164. package/dist/collection/components/nv-popover/nv-popover.docs.js +3 -3
  165. package/dist/collection/components/nv-popover/nv-popover.docs.js.map +1 -1
  166. package/dist/collection/components/nv-popover/nv-popover.js +38 -37
  167. package/dist/collection/components/nv-popover/nv-popover.js.map +1 -1
  168. package/dist/collection/components/nv-row/nv-row.js +1 -1
  169. package/dist/collection/components/nv-stack/nv-stack.js +1 -1
  170. package/dist/collection/components/nv-table/nv-table.js +2 -2
  171. package/dist/collection/components/nv-toggle/nv-toggle.js +9 -9
  172. package/dist/collection/components/nv-toggle/nv-toggle.js.map +1 -1
  173. package/dist/collection/components/nv-tooltip/nv-tooltip.css +1 -1
  174. package/dist/collection/components/nv-tooltip/nv-tooltip.js +4 -4
  175. package/dist/collection/components/nv-tooltip/nv-tooltip.js.map +1 -1
  176. package/dist/collection/utils/constants.js +94 -0
  177. package/dist/collection/utils/constants.js.map +1 -1
  178. package/dist/collection/utils/input.utils.js +20 -0
  179. package/dist/collection/utils/input.utils.js.map +1 -0
  180. package/dist/collection/utils/test/input.utils.test.js +42 -0
  181. package/dist/collection/utils/test/input.utils.test.js.map +1 -0
  182. package/dist/components/index.js +2 -2
  183. package/dist/components/nv-alert.js +5 -5
  184. package/dist/components/nv-alert.js.map +1 -1
  185. package/dist/components/nv-avatar.js +11 -11
  186. package/dist/components/nv-avatar.js.map +1 -1
  187. package/dist/components/nv-badge.js +1 -1
  188. package/dist/components/nv-base.js +2 -2
  189. package/dist/components/nv-breadcrumb.js +4 -4
  190. package/dist/components/nv-breadcrumbs.js +2 -2
  191. package/dist/components/nv-button.js +1 -1
  192. package/dist/components/nv-calendar.js +1 -1039
  193. package/dist/components/nv-calendar.js.map +1 -1
  194. package/dist/components/nv-col.js +2 -2
  195. package/dist/components/nv-datagrid.js +272 -7
  196. package/dist/components/nv-datagrid.js.map +1 -1
  197. package/dist/components/nv-datagridcolumn.js +2 -2
  198. package/dist/components/nv-dialog.js +20 -15
  199. package/dist/components/nv-dialog.js.map +1 -1
  200. package/dist/components/nv-dialogfooter.js +1 -1
  201. package/dist/components/nv-dialogheader.js +1 -1
  202. package/dist/components/nv-fieldcheckbox.js +1 -1
  203. package/dist/components/nv-fielddate.d.ts +11 -0
  204. package/dist/components/nv-fielddate.js +359 -0
  205. package/dist/components/nv-fielddate.js.map +1 -0
  206. package/dist/components/nv-fielddaterange.d.ts +11 -0
  207. package/dist/components/nv-fielddaterange.js +440 -0
  208. package/dist/components/nv-fielddaterange.js.map +1 -0
  209. package/dist/components/nv-fielddropdown.js +18 -29
  210. package/dist/components/nv-fielddropdown.js.map +1 -1
  211. package/dist/components/nv-fielddropdownitem.js +1 -1
  212. package/dist/components/nv-fielddropdownitemcheck.js +1 -1
  213. package/dist/components/nv-fieldmultiselect.js +30 -40
  214. package/dist/components/nv-fieldmultiselect.js.map +1 -1
  215. package/dist/components/nv-fieldnumber.js +25 -10
  216. package/dist/components/nv-fieldnumber.js.map +1 -1
  217. package/dist/components/nv-fieldpassword.js +8 -16
  218. package/dist/components/nv-fieldpassword.js.map +1 -1
  219. package/dist/components/nv-fieldradio.js +6 -6
  220. package/dist/components/nv-fieldradio.js.map +1 -1
  221. package/dist/components/nv-fieldselect.js +24 -12
  222. package/dist/components/nv-fieldselect.js.map +1 -1
  223. package/dist/components/nv-fieldtext.js +9 -9
  224. package/dist/components/nv-fieldtext.js.map +1 -1
  225. package/dist/components/nv-fieldtextarea.js +6 -6
  226. package/dist/components/nv-fieldtextarea.js.map +1 -1
  227. package/dist/components/nv-fieldtime.js +16 -16
  228. package/dist/components/nv-fieldtime.js.map +1 -1
  229. package/dist/components/nv-icon.js +1 -1
  230. package/dist/components/nv-iconbutton.js +1 -1
  231. package/dist/components/nv-loader.js +1 -1
  232. package/dist/components/nv-menu.js +12 -12
  233. package/dist/components/nv-menu.js.map +1 -1
  234. package/dist/components/nv-menuitem.js +1 -1
  235. package/dist/components/nv-popover.js +1 -1
  236. package/dist/components/nv-row.js +2 -2
  237. package/dist/components/nv-stack.js +2 -2
  238. package/dist/components/nv-table.js +3 -3
  239. package/dist/components/nv-tablecolumn.js +1 -1
  240. package/dist/components/nv-toggle.js +10 -10
  241. package/dist/components/nv-toggle.js.map +1 -1
  242. package/dist/components/nv-tooltip.js +1 -1
  243. package/dist/components/{p-d17558a8.js → p-057ae4f2.js} +41 -1201
  244. package/dist/components/p-057ae4f2.js.map +1 -0
  245. package/dist/components/{p-ba145f46.js → p-1a4f9c97.js} +5 -5
  246. package/dist/components/{p-ba145f46.js.map → p-1a4f9c97.js.map} +1 -1
  247. package/dist/components/{p-77d0fedc.js → p-1c45c0f2.js} +1283 -1208
  248. package/dist/components/p-1c45c0f2.js.map +1 -0
  249. package/dist/components/{p-11cc38e0.js → p-1e095bba.js} +21 -6
  250. package/dist/components/p-1e095bba.js.map +1 -0
  251. package/dist/components/{p-4bb5eb79.js → p-1fad2529.js} +16 -5
  252. package/dist/components/p-1fad2529.js.map +1 -0
  253. package/dist/components/{p-f201db34.js → p-3a3ba5b1.js} +3 -3
  254. package/dist/components/{p-f201db34.js.map → p-3a3ba5b1.js.map} +1 -1
  255. package/dist/components/p-3aa6f6dc.js +1104 -0
  256. package/dist/components/p-3aa6f6dc.js.map +1 -0
  257. package/dist/components/{p-69543282.js → p-4c6ba63c.js} +8 -7
  258. package/dist/components/p-4c6ba63c.js.map +1 -0
  259. package/dist/components/{p-a633892a.js → p-4c6d8df7.js} +3 -3
  260. package/dist/components/{p-a633892a.js.map → p-4c6d8df7.js.map} +1 -1
  261. package/dist/components/p-55202370.js +172 -0
  262. package/dist/components/p-55202370.js.map +1 -0
  263. package/dist/components/{p-1657eba4.js → p-56716b97.js} +7 -7
  264. package/dist/components/{p-1657eba4.js.map → p-56716b97.js.map} +1 -1
  265. package/dist/components/{p-33f9bdb1.js → p-7f142767.js} +7 -7
  266. package/dist/components/{p-33f9bdb1.js.map → p-7f142767.js.map} +1 -1
  267. package/dist/components/{p-b316c35d.js → p-8348db09.js} +99 -3
  268. package/dist/components/p-8348db09.js.map +1 -0
  269. package/dist/components/p-89fb308b.js +3761 -0
  270. package/dist/components/p-89fb308b.js.map +1 -0
  271. package/dist/components/{p-4b184820.js → p-9476354d.js} +4 -4
  272. package/dist/components/{p-4b184820.js.map → p-9476354d.js.map} +1 -1
  273. package/dist/components/{p-fad78896.js → p-a8b5969f.js} +8 -8
  274. package/dist/components/p-a8b5969f.js.map +1 -0
  275. package/dist/components/{p-f77c3072.js → p-ebf24fd0.js} +11 -11
  276. package/dist/components/p-ebf24fd0.js.map +1 -0
  277. package/dist/docs.json +1822 -151
  278. package/dist/esm/_commonjsHelpers-1789f0cf.js +9 -0
  279. package/dist/esm/_commonjsHelpers-1789f0cf.js.map +1 -0
  280. package/dist/esm/{constants-75e6d7f0.js → constants-98e2dcc2.js} +99 -3
  281. package/dist/esm/constants-98e2dcc2.js.map +1 -0
  282. package/dist/esm/{index-fac2d5d2.js → index-1fb7a9a6.js} +1364 -1182
  283. package/dist/esm/index-1fb7a9a6.js.map +1 -0
  284. package/dist/esm/index.js +1 -1
  285. package/dist/esm/inputmask-edcad3c1.js +3761 -0
  286. package/dist/esm/inputmask-edcad3c1.js.map +1 -0
  287. package/dist/esm/loader.js +3 -3
  288. package/dist/esm/native.js +4 -4
  289. package/dist/esm/native.js.map +1 -1
  290. package/dist/esm/nv-alert.entry.js +3 -3
  291. package/dist/esm/nv-alert.entry.js.map +1 -1
  292. package/dist/esm/nv-avatar.entry.js +3 -3
  293. package/dist/esm/nv-avatar.entry.js.map +1 -1
  294. package/dist/esm/nv-badge_2.entry.js +16 -5
  295. package/dist/esm/nv-badge_2.entry.js.map +1 -1
  296. package/dist/esm/nv-base.entry.js +2 -2
  297. package/dist/esm/nv-breadcrumb.entry.js +2 -2
  298. package/dist/esm/nv-breadcrumbs.entry.js +2 -2
  299. package/dist/esm/nv-button.entry.js +3 -3
  300. package/dist/esm/nv-calendar.entry.js +73 -18
  301. package/dist/esm/nv-calendar.entry.js.map +1 -1
  302. package/dist/esm/nv-col.entry.js +2 -2
  303. package/dist/esm/nv-datagrid.entry.js +267 -5
  304. package/dist/esm/nv-datagrid.entry.js.map +1 -1
  305. package/dist/esm/nv-datagridcolumn.entry.js +2 -2
  306. package/dist/esm/nv-dialog.entry.js +15 -10
  307. package/dist/esm/nv-dialog.entry.js.map +1 -1
  308. package/dist/esm/nv-dialogfooter_2.entry.js +4 -4
  309. package/dist/esm/nv-fieldcheckbox.entry.js +6 -6
  310. package/dist/esm/nv-fieldcheckbox.entry.js.map +1 -1
  311. package/dist/esm/nv-fielddate.entry.js +277 -0
  312. package/dist/esm/nv-fielddate.entry.js.map +1 -0
  313. package/dist/esm/nv-fielddaterange.entry.js +354 -0
  314. package/dist/esm/nv-fielddaterange.entry.js.map +1 -0
  315. package/dist/esm/nv-fielddropdown.entry.js +13 -24
  316. package/dist/esm/nv-fielddropdown.entry.js.map +1 -1
  317. package/dist/esm/nv-fielddropdownitem.entry.js +2 -2
  318. package/dist/esm/nv-fieldmultiselect.entry.js +22 -30
  319. package/dist/esm/nv-fieldmultiselect.entry.js.map +1 -1
  320. package/dist/esm/nv-fieldnumber.entry.js +9 -6
  321. package/dist/esm/nv-fieldnumber.entry.js.map +1 -1
  322. package/dist/esm/nv-fieldpassword.entry.js +5 -13
  323. package/dist/esm/nv-fieldpassword.entry.js.map +1 -1
  324. package/dist/esm/nv-fieldradio.entry.js +4 -4
  325. package/dist/esm/nv-fieldradio.entry.js.map +1 -1
  326. package/dist/esm/nv-fieldselect.entry.js +7 -7
  327. package/dist/esm/nv-fieldselect.entry.js.map +1 -1
  328. package/dist/esm/nv-fieldtext.entry.js +5 -5
  329. package/dist/esm/nv-fieldtext.entry.js.map +1 -1
  330. package/dist/esm/nv-fieldtextarea.entry.js +4 -4
  331. package/dist/esm/nv-fieldtextarea.entry.js.map +1 -1
  332. package/dist/esm/nv-fieldtime.entry.js +12 -12
  333. package/dist/esm/nv-fieldtime.entry.js.map +1 -1
  334. package/dist/esm/nv-icon.entry.js +4 -4
  335. package/dist/esm/nv-icon.entry.js.map +1 -1
  336. package/dist/esm/{nv-iconbutton.entry.js → nv-iconbutton_2.entry.js} +44 -4
  337. package/dist/esm/nv-iconbutton_2.entry.js.map +1 -0
  338. package/dist/esm/nv-menu.entry.js +5 -5
  339. package/dist/esm/nv-menu.entry.js.map +1 -1
  340. package/dist/esm/nv-menuitem.entry.js +5 -5
  341. package/dist/esm/nv-menuitem.entry.js.map +1 -1
  342. package/dist/esm/nv-popover.entry.js +31 -18
  343. package/dist/esm/nv-popover.entry.js.map +1 -1
  344. package/dist/esm/nv-row.entry.js +2 -2
  345. package/dist/esm/nv-stack.entry.js +2 -2
  346. package/dist/esm/nv-table.entry.js +3 -3
  347. package/dist/esm/nv-tablecolumn.entry.js +1 -1
  348. package/dist/esm/nv-toggle.entry.js +3 -3
  349. package/dist/esm/nv-toggle.entry.js.map +1 -1
  350. package/dist/esm/nv-tooltip.entry.js +3 -3
  351. package/dist/esm/nv-tooltip.entry.js.map +1 -1
  352. package/dist/native/index.esm.js +1 -1
  353. package/dist/native/native.esm.js +1 -1
  354. package/dist/native/native.esm.js.map +1 -1
  355. package/dist/native/p-0462f723.js +2 -0
  356. package/dist/native/p-0462f723.js.map +1 -0
  357. package/dist/native/{p-8664ab16.entry.js → p-048486e0.entry.js} +3 -3
  358. package/dist/native/p-048486e0.entry.js.map +1 -0
  359. package/dist/native/{p-fca807b4.entry.js → p-04c6048a.entry.js} +3 -3
  360. package/dist/native/{p-fca807b4.entry.js.map → p-04c6048a.entry.js.map} +1 -1
  361. package/dist/native/p-1a46cb52.entry.js +2 -0
  362. package/dist/native/p-2281d5ef.entry.js +2 -0
  363. package/dist/native/p-2281d5ef.entry.js.map +1 -0
  364. package/dist/native/p-22a45102.entry.js +2 -0
  365. package/dist/native/p-22a45102.entry.js.map +1 -0
  366. package/dist/native/p-2ed540e3.entry.js +2 -0
  367. package/dist/native/p-2ed540e3.entry.js.map +1 -0
  368. package/dist/native/p-31184fdd.entry.js +2 -0
  369. package/dist/native/p-31184fdd.entry.js.map +1 -0
  370. package/dist/native/p-314d2b34.entry.js +2 -0
  371. package/dist/native/p-314d2b34.entry.js.map +1 -0
  372. package/dist/native/p-332c5d6c.entry.js +2 -0
  373. package/dist/native/p-332c5d6c.entry.js.map +1 -0
  374. package/dist/native/p-3af5bcc1.entry.js +2 -0
  375. package/dist/native/p-3af5bcc1.entry.js.map +1 -0
  376. package/dist/native/{p-e36e956b.entry.js → p-442f04f9.entry.js} +2 -2
  377. package/dist/native/{p-af60740c.entry.js → p-45577c7f.entry.js} +2 -2
  378. package/dist/native/p-45577c7f.entry.js.map +1 -0
  379. package/dist/native/p-464ef88f.entry.js +2 -0
  380. package/dist/native/p-464ef88f.entry.js.map +1 -0
  381. package/dist/native/p-46aa1136.entry.js +2 -0
  382. package/dist/native/{p-27ad7af2.entry.js → p-4a440970.entry.js} +2 -2
  383. package/dist/native/p-4a440970.entry.js.map +1 -0
  384. package/dist/native/p-4dc1d036.entry.js +2 -0
  385. package/dist/native/{p-e9e77494.entry.js → p-514101d6.entry.js} +2 -2
  386. package/dist/native/p-514101d6.entry.js.map +1 -0
  387. package/dist/native/p-53aa81dd.js +10 -0
  388. package/dist/native/p-53aa81dd.js.map +1 -0
  389. package/dist/native/{p-1a3d2a74.entry.js → p-56e98443.entry.js} +2 -2
  390. package/dist/native/p-56e98443.entry.js.map +1 -0
  391. package/dist/native/{p-b316c35d.js → p-59768ee5.js} +2 -2
  392. package/dist/native/p-59768ee5.js.map +1 -0
  393. package/dist/native/{p-edee1c1f.entry.js → p-62df7dd4.entry.js} +2 -2
  394. package/dist/native/p-665db087.entry.js +2 -0
  395. package/dist/native/p-68b5a92c.entry.js +2 -0
  396. package/dist/native/{p-b58c661b.entry.js → p-6a629671.entry.js} +2 -2
  397. package/dist/native/p-7fade532.entry.js +2 -0
  398. package/dist/native/p-7fade532.entry.js.map +1 -0
  399. package/dist/native/p-913907fb.entry.js +2 -0
  400. package/dist/native/p-913907fb.entry.js.map +1 -0
  401. package/dist/native/p-942f8e92.entry.js +2 -0
  402. package/dist/native/p-942f8e92.entry.js.map +1 -0
  403. package/dist/native/p-9f5e4dfc.entry.js +2 -0
  404. package/dist/native/p-9f5e4dfc.entry.js.map +1 -0
  405. package/dist/native/p-ab002252.js +3 -0
  406. package/dist/native/p-ab002252.js.map +1 -0
  407. package/dist/native/{p-fde56f9c.entry.js → p-ab84ff42.entry.js} +2 -2
  408. package/dist/native/{p-fde56f9c.entry.js.map → p-ab84ff42.entry.js.map} +1 -1
  409. package/dist/native/{p-487b81bd.entry.js → p-b052f1cb.entry.js} +2 -2
  410. package/dist/native/{p-9795090f.entry.js → p-bdabd495.entry.js} +2 -2
  411. package/dist/native/p-bdabd495.entry.js.map +1 -0
  412. package/dist/native/p-be4fc827.entry.js +2 -0
  413. package/dist/native/p-be4fc827.entry.js.map +1 -0
  414. package/dist/native/{p-184cd119.entry.js → p-c10e5113.entry.js} +2 -2
  415. package/dist/native/{p-491f4605.entry.js → p-d5cbf5c8.entry.js} +2 -2
  416. package/dist/native/{p-491f4605.entry.js.map → p-d5cbf5c8.entry.js.map} +1 -1
  417. package/dist/native/{p-69fb1c9d.entry.js → p-db2902d6.entry.js} +2 -2
  418. package/dist/native/p-ecc28398.entry.js +2 -0
  419. package/dist/native/p-ecc28398.entry.js.map +1 -0
  420. package/dist/native/p-ed595c96.entry.js +2 -0
  421. package/dist/native/p-ed595c96.entry.js.map +1 -0
  422. package/dist/native/p-f5e0d5c5.entry.js +2 -0
  423. package/dist/native/p-f5e0d5c5.entry.js.map +1 -0
  424. package/dist/native/p-f89b7d06.entry.js +2 -0
  425. package/dist/types/components/nv-calendar/nv-calendar.d.ts +7 -0
  426. package/dist/types/components/nv-datagrid/nv-datagrid.d.ts +21 -0
  427. package/dist/types/components/nv-dialog/nv-dialog.d.ts +1 -0
  428. package/dist/types/components/nv-fielddate/nv-fielddate.d.ts +192 -0
  429. package/dist/types/components/nv-fielddate/nv-fielddate.docs.d.ts +4 -0
  430. package/dist/types/components/nv-fielddaterange/nv-fielddaterange.d.ts +206 -0
  431. package/dist/types/components/nv-fielddaterange/nv-fielddaterange.docs.d.ts +4 -0
  432. package/dist/types/components/nv-fielddropdown/nv-fielddropdown.d.ts +1 -3
  433. package/dist/types/components/nv-fielddropdownitemcheck/nv-fielddropdownitemcheck.d.ts +2 -0
  434. package/dist/types/components/nv-fieldmultiselect/nv-fieldmultiselect.d.ts +1 -11
  435. package/dist/types/components/nv-fieldnumber/nv-fieldnumber.d.ts +1 -0
  436. package/dist/types/components/nv-fieldpassword/nv-fieldpassword.d.ts +0 -1
  437. package/dist/types/components/nv-iconbutton/nv-iconbutton.d.ts +3 -0
  438. package/dist/types/components/nv-menu/nv-menu.d.ts +2 -3
  439. package/dist/types/components/nv-menuitem/nv-menuitem.d.ts +20 -16
  440. package/dist/types/components/nv-popover/nv-popover.d.ts +7 -4
  441. package/dist/types/components.d.ts +2344 -974
  442. package/dist/types/utils/constants.d.ts +6 -0
  443. package/dist/types/utils/input.utils.d.ts +8 -0
  444. package/dist/types/utils/test/input.utils.test.d.ts +1 -0
  445. package/dist/vscode-data.json +4570 -0
  446. package/hydrate/index.d.ts +22 -5
  447. package/hydrate/index.js +6403 -1242
  448. package/hydrate/index.mjs +6403 -1242
  449. package/package.json +5 -1
  450. package/dist/cjs/constants-79d2cdfc.js.map +0 -1
  451. package/dist/cjs/index-5910ba06.js.map +0 -1
  452. package/dist/cjs/nv-iconbutton.cjs.entry.js.map +0 -1
  453. package/dist/cjs/nv-loader.cjs.entry.js +0 -35
  454. package/dist/cjs/nv-loader.cjs.entry.js.map +0 -1
  455. package/dist/components/p-11cc38e0.js.map +0 -1
  456. package/dist/components/p-4bb5eb79.js.map +0 -1
  457. package/dist/components/p-69543282.js.map +0 -1
  458. package/dist/components/p-77d0fedc.js.map +0 -1
  459. package/dist/components/p-96605453.js +0 -172
  460. package/dist/components/p-96605453.js.map +0 -1
  461. package/dist/components/p-b316c35d.js.map +0 -1
  462. package/dist/components/p-d17558a8.js.map +0 -1
  463. package/dist/components/p-f77c3072.js.map +0 -1
  464. package/dist/components/p-fad78896.js.map +0 -1
  465. package/dist/esm/constants-75e6d7f0.js.map +0 -1
  466. package/dist/esm/index-fac2d5d2.js.map +0 -1
  467. package/dist/esm/nv-iconbutton.entry.js.map +0 -1
  468. package/dist/esm/nv-loader.entry.js +0 -31
  469. package/dist/esm/nv-loader.entry.js.map +0 -1
  470. package/dist/native/p-0a2a9f8b.entry.js +0 -2
  471. package/dist/native/p-0a2a9f8b.entry.js.map +0 -1
  472. package/dist/native/p-12d08abc.entry.js +0 -2
  473. package/dist/native/p-12d08abc.entry.js.map +0 -1
  474. package/dist/native/p-15be3d96.entry.js +0 -2
  475. package/dist/native/p-15be3d96.entry.js.map +0 -1
  476. package/dist/native/p-1a3d2a74.entry.js.map +0 -1
  477. package/dist/native/p-27ad7af2.entry.js.map +0 -1
  478. package/dist/native/p-2b2a10f9.entry.js +0 -2
  479. package/dist/native/p-2b2a10f9.entry.js.map +0 -1
  480. package/dist/native/p-359f0f53.entry.js +0 -2
  481. package/dist/native/p-359f0f53.entry.js.map +0 -1
  482. package/dist/native/p-3b65037c.entry.js +0 -2
  483. package/dist/native/p-3be2c9a1.entry.js +0 -2
  484. package/dist/native/p-4283f375.entry.js +0 -2
  485. package/dist/native/p-5439afb8.js +0 -3
  486. package/dist/native/p-5439afb8.js.map +0 -1
  487. package/dist/native/p-554f7b44.entry.js +0 -2
  488. package/dist/native/p-554f7b44.entry.js.map +0 -1
  489. package/dist/native/p-729c9d45.entry.js +0 -2
  490. package/dist/native/p-729c9d45.entry.js.map +0 -1
  491. package/dist/native/p-78f08578.entry.js +0 -2
  492. package/dist/native/p-78f08578.entry.js.map +0 -1
  493. package/dist/native/p-8664ab16.entry.js.map +0 -1
  494. package/dist/native/p-87bd53df.entry.js +0 -2
  495. package/dist/native/p-87bd53df.entry.js.map +0 -1
  496. package/dist/native/p-8d6516a3.entry.js +0 -2
  497. package/dist/native/p-8d6516a3.entry.js.map +0 -1
  498. package/dist/native/p-951baf95.entry.js +0 -2
  499. package/dist/native/p-9795090f.entry.js.map +0 -1
  500. package/dist/native/p-af60740c.entry.js.map +0 -1
  501. package/dist/native/p-b316c35d.js.map +0 -1
  502. package/dist/native/p-b7bc918b.entry.js +0 -2
  503. package/dist/native/p-cda56476.entry.js +0 -2
  504. package/dist/native/p-cda56476.entry.js.map +0 -1
  505. package/dist/native/p-d1bf4d77.entry.js +0 -2
  506. package/dist/native/p-d7665a07.entry.js +0 -2
  507. package/dist/native/p-d7665a07.entry.js.map +0 -1
  508. package/dist/native/p-daeb7e22.entry.js +0 -2
  509. package/dist/native/p-daeb7e22.entry.js.map +0 -1
  510. package/dist/native/p-e9e77494.entry.js.map +0 -1
  511. package/dist/native/p-f1585fc2.entry.js +0 -2
  512. package/dist/native/p-f1585fc2.entry.js.map +0 -1
  513. package/dist/native/p-f3579407.entry.js +0 -2
  514. package/dist/native/p-f3579407.entry.js.map +0 -1
  515. /package/dist/native/{p-3be2c9a1.entry.js.map → p-1a46cb52.entry.js.map} +0 -0
  516. /package/dist/native/{p-e36e956b.entry.js.map → p-442f04f9.entry.js.map} +0 -0
  517. /package/dist/native/{p-d1bf4d77.entry.js.map → p-46aa1136.entry.js.map} +0 -0
  518. /package/dist/native/{p-4283f375.entry.js.map → p-4dc1d036.entry.js.map} +0 -0
  519. /package/dist/native/{p-edee1c1f.entry.js.map → p-62df7dd4.entry.js.map} +0 -0
  520. /package/dist/native/{p-951baf95.entry.js.map → p-665db087.entry.js.map} +0 -0
  521. /package/dist/native/{p-b7bc918b.entry.js.map → p-68b5a92c.entry.js.map} +0 -0
  522. /package/dist/native/{p-b58c661b.entry.js.map → p-6a629671.entry.js.map} +0 -0
  523. /package/dist/native/{p-487b81bd.entry.js.map → p-b052f1cb.entry.js.map} +0 -0
  524. /package/dist/native/{p-184cd119.entry.js.map → p-c10e5113.entry.js.map} +0 -0
  525. /package/dist/native/{p-69fb1c9d.entry.js.map → p-db2902d6.entry.js.map} +0 -0
  526. /package/dist/native/{p-3b65037c.entry.js.map → p-f89b7d06.entry.js.map} +0 -0
@@ -0,0 +1,359 @@
1
+ import { p as proxyCustomElement, H, c as createEvent, h, d as Host } from './p-1c45c0f2.js';
2
+ import { I as Inputmask } from './p-89fb308b.js';
3
+ import { d as defineCustomElement$7 } from './p-1a4f9c97.js';
4
+ import { d as defineCustomElement$6 } from './p-3aa6f6dc.js';
5
+ import { d as defineCustomElement$5 } from './p-ebf24fd0.js';
6
+ import { d as defineCustomElement$4 } from './p-1e095bba.js';
7
+ import { d as defineCustomElement$3 } from './p-3a3ba5b1.js';
8
+ import { d as defineCustomElement$2 } from './p-057ae4f2.js';
9
+ import { v as v4 } from './p-f5ff676c.js';
10
+
11
+ const nvFielddateCss = "nv-fielddate{--nv-field-border-default:var(--components-form-field-border-default);--nv-field-border-hover:var(--components-form-field-border-hover);--nv-field-border-focus:var(--components-form-field-border-focus);--nv-field-border-disabled:var(--components-form-field-border-default);--nv-field-border-readonly:var(--components-form-field-border-default);--nv-field-focus-box-shadow:var(--color-focus-brand);--nv-field-background:var(--components-form-field-background-default);display:flex;flex-direction:column;align-items:flex-start;gap:var(--form-gap-y);box-sizing:border-box}nv-fielddate[readonly]:not([readonly=false]){--nv-field-border-default:var(--components-form-field-border-readonly);--nv-field-border-hover:var(--nv-field-border-default);--nv-field-border-focus:var(--components-form-field-border-focus);--nv-field-border-disabled:var(--nv-field-border-default);--nv-field-border-readonly:var(--nv-field-border-default);--nv-field-background:var(--components-form-field-background-readonly)}nv-fielddate[error]:not([error=false]){--nv-field-border-default:var(--components-form-field-border-error);--nv-field-border-hover:var(--nv-field-border-default);--nv-field-border-focus:var(--nv-field-border-default);--nv-field-border-disabled:var(--nv-field-border-default);--nv-field-border-readonly:var(--nv-field-border-default);--nv-field-focus-box-shadow:var(--color-focus-destructive)}nv-fielddate[success]:not([success=false]){--nv-field-border-default:var(--components-form-field-border-success);--nv-field-border-hover:var(--nv-field-border-default);--nv-field-border-focus:var(--nv-field-border-default);--nv-field-border-disabled:var(--nv-field-border-default);--nv-field-border-readonly:var(--nv-field-border-default);--nv-field-focus-box-shadow:var(--color-focus-success)}nv-fielddate[required]:not([required=false]) label::after{content:\"*\";color:var(--components-form-text-required);font-weight:700}nv-fielddate label{display:flex;align-items:center;gap:var(--form-label-gap);align-self:stretch;color:var(--components-form-text-label-default);font-family:\"TT Norms Pro\", sans-serif;font-size:var(--form-label-font-size);font-style:normal;font-weight:500;line-height:var(--form-label-line-height)}nv-fielddate nv-popover{width:100%;display:block}nv-fielddate nv-popover [data-scope=popover]{padding:0;background-color:var(--components-list-dropdown-background);border:1px solid var(--components-list-dropdown-border);width:auto}nv-fielddate nv-popover [slot=content]{display:block;width:100%}nv-fielddate .input-wrapper{display:flex;flex-wrap:wrap;gap:var(--form-gap-x);align-items:stretch;align-self:stretch;display:flex;align-items:center;gap:8px}nv-fielddate .input-wrapper .input-container{display:flex;flex-grow:1;justify-content:center;align-items:center;align-self:stretch;border-radius:var(--form-field-radius);border-width:1px;border-style:solid;border-color:var(--nv-field-border-default);opacity:var(--components-form-opacity-default, 1);background:var(--nv-field-background);transition:all 150ms ease-out}nv-fielddate .input-wrapper .input-container:hover{border-color:var(--nv-field-border-hover)}nv-fielddate .input-wrapper .input-container:focus-within,nv-fielddate .input-wrapper .input-container:focus-within:hover,nv-fielddate .input-wrapper .input-container:focus,nv-fielddate .input-wrapper .input-container:focus:hover{border-color:var(--nv-field-border-focus);box-shadow:0px 0px 0px var(--focus-field-stroke) var(--nv-field-focus-box-shadow)}nv-fielddate .input-wrapper .input-container:has(input:read-only){opacity:0.5;background-color:var(--components-form-field-background-readonly);border-color:var(--nv-field-border-readonly)}nv-fielddate .input-wrapper .input-container:has(input:disabled){opacity:0.5;background-color:var(--components-form-field-background-disabled);border-color:var(--nv-field-border-disabled)}nv-fielddate .input-wrapper .input-container input{display:flex;align-items:center;flex:1 0 0;overflow:hidden;background-color:transparent;color:var(--components-form-field-content-text);padding:var(--form-field-padding-y) var(--form-field-padding-x);font-size:var(--form-field-font-size);font-style:normal;font-weight:500;line-height:var(--form-field-line-height);width:100%}nv-fielddate .input-wrapper .input-container input:focus{outline:none}nv-fielddate .input-wrapper .input-container input::placeholder{overflow:hidden;color:var(--components-form-field-content-placeholder);text-overflow:ellipsis;font-family:\"TT Norms Pro\", sans-serif;font-size:var(--form-field-font-size);font-style:normal;font-weight:400;line-height:var(--form-field-line-height)}nv-fielddate .input-wrapper .input-container>nv-iconbutton{border:0px;border-radius:0px}nv-fielddate .input-wrapper .input-container>nv-iconbutton:focus-visible{border-radius:var(--button-md-border-radius);outline-offset:-3px}nv-fielddate .input-wrapper .input-container nv-icon.validation{color:var(--nv-field-border-default)}nv-fielddate .description{align-self:stretch;color:var(--components-form-text-description-default);font-family:\"TT Norms Pro\", sans-serif;font-size:var(--form-description-font-size);font-style:normal;line-height:var(--form-description-line-height)}nv-fielddate .error-description{align-self:stretch;color:var(--components-form-text-description-default);font-family:\"TT Norms Pro\", sans-serif;font-size:var(--form-description-font-size);font-style:normal;line-height:var(--form-description-line-height);color:var(--components-form-text-description-error)}";
12
+ const NvFielddateStyle0 = nvFielddateCss;
13
+
14
+ const NvFielddate$1 = /*@__PURE__*/ proxyCustomElement(class NvFielddate extends H {
15
+ constructor() {
16
+ super();
17
+ this.__registerHost();
18
+ this.dateChange = createEvent(this, "dateChange", 7);
19
+ this.popoverId = v4();
20
+ /****************************************************************************/
21
+ //#region PROPERTIES
22
+ /**
23
+ * Sets the ID for the input element and the for attribute of the associated
24
+ * label. If no ID is provided, a random one will be automatically generated.
25
+ */
26
+ this.inputId = v4();
27
+ /**
28
+ * Disables the input field.
29
+ */
30
+ this.disabled = false;
31
+ /**
32
+ * Sets the input field as read-only.
33
+ */
34
+ this.readonly = false;
35
+ /**
36
+ * Marks the input field as required.
37
+ */
38
+ this.required = false;
39
+ /**
40
+ * Indicates an error state.
41
+ */
42
+ this.error = false;
43
+ /**
44
+ * Indicates a success state.
45
+ */
46
+ this.success = false;
47
+ /**
48
+ * Autofocus the input when the component is mounted.
49
+ */
50
+ this.autofocus = false;
51
+ /**
52
+ * The initial value of the input (date in string format).
53
+ */
54
+ this.value = '';
55
+ /**
56
+ * The current value of the input date in string format.
57
+ */
58
+ this.singleValue = '';
59
+ /**
60
+ * Controls the opening of the popover.
61
+ */
62
+ this.open = false;
63
+ /**
64
+ * First day of the week 0 = Sunday, 1 = Monday, etc.
65
+ * @default 1
66
+ */
67
+ this.firstDayOfWeek = 1;
68
+ /**
69
+ * Number of calendars to display
70
+ * @default 1
71
+ */
72
+ this.numberOfCalendars = 1;
73
+ /**
74
+ * Minimum date for selection ISO string format, ex: 2025-01-01
75
+ */
76
+ this.min = '';
77
+ /**
78
+ * Maximum date for selection ISO string format, ex: 2025-12-31
79
+ */
80
+ this.max = '';
81
+ /** Locale for date formatting
82
+ * @default 'en-BE'
83
+ */
84
+ this.locale = 'en-BE';
85
+ /** Date format ex: YYYY-MM-DD, DD-MM-YYYY, etc.
86
+ * @default 'YYYY-MM-DD'
87
+ * @note If the date format is in UTC mode, the date will be displayed in UTC time.
88
+ * @note If the date format is not in UTC mode, the date will be displayed in the local time.
89
+ */
90
+ this.dateFormat = 'YYYY-MM-DD';
91
+ /**
92
+ * Footer placement
93
+ * @default 'bottom'
94
+ */
95
+ this.shortcutsPlacement = 'bottom';
96
+ /**
97
+ * Show action buttons
98
+ * @default false
99
+ */
100
+ this.showActions = false;
101
+ /**
102
+ * Custom actions to display in the footer
103
+ * JSON array of objects with the following properties:
104
+ * - label: string
105
+ * - onClick: function
106
+ * @default '[]'
107
+ */
108
+ this.shortcuts = '[]';
109
+ /**
110
+ * Disabled dates ISO string array
111
+ * @default '[]'
112
+ */
113
+ this.disabledDates = '[]';
114
+ /**
115
+ * Closes the popover when a click is detected outside the component.
116
+ * @param {MouseEvent} event - The click event.
117
+ */
118
+ this.handleClickOutside = (event) => {
119
+ if (this.open && this.el && !this.el.contains(event.target)) {
120
+ this.open = false;
121
+ }
122
+ };
123
+ /**
124
+ * Focuses the input when the input container is clicked.
125
+ * @param {MouseEvent} event - The click event.
126
+ */
127
+ this.handleInputContainerClick = (event) => {
128
+ if (this.readonly || this.disabled) {
129
+ event.preventDefault();
130
+ event.stopPropagation();
131
+ return;
132
+ }
133
+ this.inputElement.focus();
134
+ // Select the first characters based on the date format
135
+ const format = this.dateFormat;
136
+ if (format.startsWith('DD')) {
137
+ this.inputElement.setSelectionRange(0, 2);
138
+ }
139
+ else if (format.startsWith('MM')) {
140
+ this.inputElement.setSelectionRange(0, 2);
141
+ }
142
+ else if (format.startsWith('YYYY')) {
143
+ this.inputElement.setSelectionRange(0, 4);
144
+ }
145
+ };
146
+ /**
147
+ * Handles the input event on the input element.
148
+ * Updates the singleValue and emits the dateChange event.
149
+ * @param {Event} event - The input event.
150
+ */
151
+ this.handleInput = (event) => {
152
+ if (this.readonly || this.disabled) {
153
+ event.preventDefault();
154
+ return;
155
+ }
156
+ const input = event.target;
157
+ this.singleValue = input.value;
158
+ this.dateChange.emit({ value: input.value });
159
+ };
160
+ /**
161
+ * Toggles the opening/closing of the popover.
162
+ */
163
+ this.toggleCalendar = () => {
164
+ if (this.readonly || this.disabled) {
165
+ return;
166
+ }
167
+ this.open = !this.open;
168
+ };
169
+ /**
170
+ * Handles focus events on the input element.
171
+ * @param {FocusEvent} event - The focus event.
172
+ */
173
+ this.handleFocus = (event) => {
174
+ if (this.readonly || this.disabled) {
175
+ event.preventDefault();
176
+ event.target.blur();
177
+ return;
178
+ }
179
+ };
180
+ }
181
+ //#endregion PROPERTIES
182
+ /****************************************************************************/
183
+ //#region METHODS
184
+ /**
185
+ * Converts the nv-calendar date format to the format expected by Inputmask.
186
+ * @param {string} format - The date format.
187
+ * @returns {string} Format adapted for Inputmask.
188
+ */
189
+ convertToInputmaskFormat(format) {
190
+ switch (format) {
191
+ case 'DD/MM/YYYY':
192
+ return 'dd/mm/yyyy';
193
+ case 'MM/DD/YYYY':
194
+ return 'mm/dd/yyyy';
195
+ case 'YYYY-MM-DD':
196
+ return 'yyyy-mm-dd';
197
+ case 'DD.MM.YYYY':
198
+ return 'dd.mm.yyyy';
199
+ case 'YYYYMMDD':
200
+ return 'yyyymmdd';
201
+ default:
202
+ return format;
203
+ }
204
+ }
205
+ //#endregion METHODS
206
+ /****************************************************************************/
207
+ //#region LIFECYCLE
208
+ connectedCallback() {
209
+ document.addEventListener('click', this.handleClickOutside);
210
+ }
211
+ componentWillLoad() {
212
+ if (this.value) {
213
+ this.singleValue = this.value;
214
+ }
215
+ }
216
+ componentDidLoad() {
217
+ const inputs = this.el.querySelectorAll('.input-wrapper input');
218
+ inputs.forEach((input) => {
219
+ Inputmask({
220
+ alias: 'datetime',
221
+ inputFormat: this.convertToInputmaskFormat(this.dateFormat),
222
+ placeholder: '_'.repeat(this.dateFormat.length),
223
+ }).mask(input);
224
+ });
225
+ }
226
+ disconnectedCallback() {
227
+ document.removeEventListener('click', this.handleClickOutside);
228
+ }
229
+ /**
230
+ * Handles the single date selection event from nv-calendar.
231
+ * Updates the input value and closes the popover.
232
+ * @param {CustomEvent} event - The event from nv-calendar.
233
+ */
234
+ handleSingleDateChange(event) {
235
+ const value = event.detail;
236
+ this.singleValue = value;
237
+ this.dateChange.emit({ value });
238
+ if (!this.showActions) {
239
+ this.open = false;
240
+ }
241
+ }
242
+ handleClosePopover() {
243
+ this.open = false;
244
+ }
245
+ handleKeyDown(event) {
246
+ if (!this.open) {
247
+ if (event.key === 'ArrowDown') {
248
+ this.open = true;
249
+ event.preventDefault();
250
+ return;
251
+ }
252
+ return;
253
+ }
254
+ // Verify if the popover element is defined
255
+ if (!this.popoverElement) {
256
+ console.warn('nv-fielddate -> Popover element is not defined');
257
+ return;
258
+ }
259
+ }
260
+ handleValueChange(newValue) {
261
+ this.singleValue = newValue;
262
+ }
263
+ //#endregion EVENTS
264
+ /****************************************************************************/
265
+ //#region RENDER
266
+ render() {
267
+ return (h(Host, { key: 'df11f4f395a48f6288b20a242cccdacc9d7b397c' }, ((this.label && this.label.length > 0) ||
268
+ this.el.querySelector('[slot="label"]')) && (h("label", { key: 'bebb3787dcef1ea73bada36586bdd678f0ce0556', htmlFor: this.inputId }, h("slot", { key: '52be6fb452bcd9471708376e708e9a8126af73c2', name: "label" }, this.label))), h("nv-popover", { key: '6e1cc0a602641ec43be99ca990d64f175ff7bac8', ref: el => (this.popoverElement = el), id: this.popoverId, triggerMode: "controlled", placement: "bottom-start", open: this.open }, h("div", { key: '7cc0bcc9df49252d209caa22b61358c230d2f0dd', slot: "trigger", class: "input-wrapper" }, h("slot", { key: '13037bdfe258561afd35c23fd1cb94ed96bbba9d', name: "before-input" }), h("div", { key: '5a0c1bce690feb834f6183c57772d7b2eed0a8a6', class: "input-container", onClick: this.handleInputContainerClick }, h("slot", { key: '73842b222ba5059f1f09a4ce57b662710a1e341a', name: "leading-input" }), h("input", { key: '2e4de521b0d1d735fd4170eefacfe4e8f5bbcf33', id: this.inputId, ref: e => (this.inputElement = e), placeholder: this.placeholder, name: this.name, disabled: this.disabled, readOnly: this.readonly, required: this.required, autofocus: this.autofocus, value: this.singleValue, onInput: this.handleInput, onFocus: this.handleFocus }), h("nv-iconbutton", { key: 'dff7fe7f4a49a3da8ed44235ef719e726a40db87', class: "toggle-calendar-icon", name: "calendar" //{this.open ? 'chevron-top' : 'chevron-down'}
269
+ ,
270
+ size: "md", emphasis: "lower", "aria-label": this.open ? 'Hide calendar' : 'Show calendar', "aria-pressed": this.open.toString(), onClick: this.toggleCalendar, tabIndex: this.disabled ? -1 : 0 })), h("slot", { key: 'aafa39739ae3f907cef45d95094ef643833d50ad', name: "after-input" })), h("div", { key: '38cbef48ee7b053ad7c277e8125fcbf6d11c636c', slot: "content" }, h("nv-calendar", { key: 'dd5f1b3f1d7fcb17a47d90be58949fffe89e3ad4', dateFormat: this.dateFormat, singleValue: this.singleValue, firstDayOfWeek: this.firstDayOfWeek, numberOfCalendars: this.numberOfCalendars, min: this.min, max: this.max, locale: this.locale, shortcutsPlacement: this.shortcutsPlacement, showActions: this.showActions, shortcuts: this.shortcuts, showWeekNumbers: this.showWeekNumbers, disabledDates: this.disabledDates }))), ((this.description && this.description.length > 0) ||
271
+ this.el.querySelector('[slot="description"]')) && (h("div", { key: '92526d3d8ed3bce713a5b30097df182b0ea22d4f', class: "description" }, h("slot", { key: 'd2a3a35577c08e3dd21c1c48eb6c6e3959abb7da', name: "description" }, this.description))), (this.errorDescription ||
272
+ this.el.querySelector('[slot="error-description"]')) && (h("div", { key: 'd4ba884604a01e2376691d382fb530576c02f029', hidden: !this.error, class: "error-description" }, this.el.querySelector('[slot="error-description"]') ? (h("slot", { name: "error-description" })) : (this.errorDescription))), h("slot", { key: '443c990302fa9aaef0e6fe732738d4f8e4570717' })));
273
+ }
274
+ get el() { return this; }
275
+ static get watchers() { return {
276
+ "value": ["handleValueChange"]
277
+ }; }
278
+ static get style() { return NvFielddateStyle0; }
279
+ }, [4, "nv-fielddate", {
280
+ "inputId": [513, "input-id"],
281
+ "label": [513],
282
+ "description": [513],
283
+ "placeholder": [513],
284
+ "name": [513],
285
+ "disabled": [516],
286
+ "readonly": [516],
287
+ "required": [516],
288
+ "error": [516],
289
+ "errorDescription": [513, "error-description"],
290
+ "success": [516],
291
+ "autofocus": [516],
292
+ "value": [513],
293
+ "firstDayOfWeek": [514, "first-day-of-week"],
294
+ "numberOfCalendars": [514, "number-of-calendars"],
295
+ "min": [513],
296
+ "max": [513],
297
+ "locale": [513],
298
+ "dateFormat": [513, "date-format"],
299
+ "shortcutsPlacement": [513, "shortcuts-placement"],
300
+ "showActions": [516, "show-actions"],
301
+ "shortcuts": [513],
302
+ "showWeekNumbers": [516, "show-week-numbers"],
303
+ "disabledDates": [513, "disabled-dates"],
304
+ "singleValue": [32],
305
+ "open": [32]
306
+ }, [[0, "singleDateChange", "handleSingleDateChange"], [0, "closePopover", "handleClosePopover"], [0, "keydown", "handleKeyDown"]], {
307
+ "value": ["handleValueChange"]
308
+ }]);
309
+ function defineCustomElement$1() {
310
+ if (typeof customElements === "undefined") {
311
+ return;
312
+ }
313
+ const components = ["nv-fielddate", "nv-button", "nv-calendar", "nv-icon", "nv-iconbutton", "nv-loader", "nv-popover"];
314
+ components.forEach(tagName => { switch (tagName) {
315
+ case "nv-fielddate":
316
+ if (!customElements.get(tagName)) {
317
+ customElements.define(tagName, NvFielddate$1);
318
+ }
319
+ break;
320
+ case "nv-button":
321
+ if (!customElements.get(tagName)) {
322
+ defineCustomElement$7();
323
+ }
324
+ break;
325
+ case "nv-calendar":
326
+ if (!customElements.get(tagName)) {
327
+ defineCustomElement$6();
328
+ }
329
+ break;
330
+ case "nv-icon":
331
+ if (!customElements.get(tagName)) {
332
+ defineCustomElement$5();
333
+ }
334
+ break;
335
+ case "nv-iconbutton":
336
+ if (!customElements.get(tagName)) {
337
+ defineCustomElement$4();
338
+ }
339
+ break;
340
+ case "nv-loader":
341
+ if (!customElements.get(tagName)) {
342
+ defineCustomElement$3();
343
+ }
344
+ break;
345
+ case "nv-popover":
346
+ if (!customElements.get(tagName)) {
347
+ defineCustomElement$2();
348
+ }
349
+ break;
350
+ } });
351
+ }
352
+ defineCustomElement$1();
353
+
354
+ const NvFielddate = NvFielddate$1;
355
+ const defineCustomElement = defineCustomElement$1;
356
+
357
+ export { NvFielddate, defineCustomElement };
358
+
359
+ //# sourceMappingURL=nv-fielddate.js.map
@@ -0,0 +1 @@
1
+ {"file":"nv-fielddate.js","mappings":"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","names":["NvFielddate","uuidv4"],"sources":["src/components/nv-fielddate/styles/nv-fielddate.scss?tag=nv-fielddate","src/components/nv-fielddate/nv-fielddate.tsx"],"sourcesContent":["@import '../../../styles/form-field';\n\nnv-fielddate {\n @include form-field-variables();\n @include form-field-root();\n\n &[readonly]:not([readonly='false']) {\n @include form-field-readonly-variables();\n }\n\n &[error]:not([error='false']) {\n @include form-field-error-variables();\n }\n\n &[success]:not([success='false']) {\n @include form-field-success-variables();\n }\n\n &[required]:not([required='false']) label {\n @include form-field-label-required();\n }\n\n label {\n @include form-field-label();\n }\n\n nv-popover {\n width: 100%;\n display: block;\n\n [data-scope='popover'] {\n padding: 0;\n background-color: var(--components-list-dropdown-background);\n border: 1px solid var(--components-list-dropdown-border);\n width: auto;\n }\n\n [slot='content'] {\n display: block;\n width: 100%;\n }\n }\n\n .input-wrapper {\n @include form-field-input-wrapper();\n display: flex;\n align-items: center;\n gap: 8px;\n\n .input-container {\n @include form-field-input-container();\n\n input {\n @include form-field-input();\n width: 100%;\n }\n\n > nv-iconbutton {\n @include form-field-action();\n }\n\n nv-icon.validation {\n @include form-field-icon();\n }\n }\n }\n\n .description {\n @include form-field-description();\n }\n\n .error-description {\n @include form-field-error-description();\n }\n}\n","import {\n Component,\n h,\n Prop,\n State,\n Element,\n Event,\n EventEmitter,\n Listen,\n Host,\n Watch,\n} from '@stencil/core';\nimport Inputmask from 'inputmask';\nimport { v4 as uuidv4 } from 'uuid';\n\n/**\n * @slot default - Child content of the component.\n * @slot leading-input - Content to be placed before the input text, within the input container.\n * @slot before-input - Content to be placed before the input text, outside the input container.\n * @slot after-input - Content to be placed after the input text, outside the input container.\n * @slot label - Content to be placed as the label, will override the label prop.\n * @slot description - Content to be placed as the description, will override the description prop.\n * @slot error-description - Content to be placed as the error description, will override the errorDescription prop.\n */\n@Component({\n tag: 'nv-fielddate',\n styleUrl: 'styles/nv-fielddate.scss',\n shadow: false,\n})\nexport class NvFielddate {\n @Element() el: HTMLNvFielddateElement;\n private inputElement!: HTMLInputElement;\n\n private popoverElement!: HTMLNvPopoverElement;\n private popoverId: string = uuidv4();\n\n /****************************************************************************/\n //#region PROPERTIES\n\n /**\n * Sets the ID for the input element and the for attribute of the associated\n * label. If no ID is provided, a random one will be automatically generated.\n */\n @Prop({ reflect: true })\n readonly inputId: string = uuidv4();\n\n /**\n * Text displayed as label. A slot label can override this prop.\n */\n @Prop({ reflect: true })\n readonly label: string;\n\n /**\n * Description displayed below the input. A slot description can override this prop.\n */\n @Prop({ reflect: true })\n readonly description: string;\n\n /**\n * Placeholder for the input field.\n */\n @Prop({ reflect: true })\n readonly placeholder: string;\n\n /**\n * Name attribute for the input.\n */\n @Prop({ reflect: true })\n readonly name: string;\n\n /**\n * Disables the input field.\n */\n @Prop({ reflect: true })\n readonly disabled: boolean = false;\n\n /**\n * Sets the input field as read-only.\n */\n @Prop({ reflect: true })\n readonly readonly: boolean = false;\n\n /**\n * Marks the input field as required.\n */\n @Prop({ reflect: true })\n readonly required: boolean = false;\n\n /**\n * Indicates an error state.\n */\n @Prop({ reflect: true })\n readonly error: boolean = false;\n\n /**\n * Error description. A slot error-description can override this prop.\n */\n @Prop({ reflect: true })\n readonly errorDescription?: string;\n\n /**\n * Indicates a success state.\n */\n @Prop({ reflect: true })\n readonly success: boolean = false;\n\n /**\n * Autofocus the input when the component is mounted.\n */\n @Prop({ reflect: true })\n // eslint-disable-next-line @stencil-community/reserved-member-names\n readonly autofocus: boolean = false;\n\n /**\n * The initial value of the input (date in string format).\n */\n @Prop({ reflect: true })\n readonly value: string = '';\n\n /**\n * The current value of the input date in string format.\n */\n @State()\n singleValue: string = '';\n\n /**\n * Controls the opening of the popover.\n */\n @State()\n open: boolean = false;\n\n /**\n * First day of the week 0 = Sunday, 1 = Monday, etc.\n * @default 1\n */\n @Prop({ reflect: true })\n readonly firstDayOfWeek: number = 1;\n\n /**\n * Number of calendars to display\n * @default 1\n */\n @Prop({ reflect: true })\n readonly numberOfCalendars: number = 1;\n\n /**\n * Minimum date for selection ISO string format, ex: 2025-01-01\n */\n @Prop({ reflect: true })\n readonly min?: string = '';\n\n /**\n * Maximum date for selection ISO string format, ex: 2025-12-31\n */\n @Prop({ reflect: true })\n readonly max?: string = '';\n\n /** Locale for date formatting\n * @default 'en-BE'\n */\n @Prop({ reflect: true })\n readonly locale: string = 'en-BE';\n\n /** Date format ex: YYYY-MM-DD, DD-MM-YYYY, etc.\n * @default 'YYYY-MM-DD'\n * @note If the date format is in UTC mode, the date will be displayed in UTC time.\n * @note If the date format is not in UTC mode, the date will be displayed in the local time.\n */\n @Prop({ reflect: true })\n readonly dateFormat: string = 'YYYY-MM-DD';\n\n /**\n * Footer placement\n * @default 'bottom'\n */\n @Prop({ reflect: true })\n readonly shortcutsPlacement: 'bottom' | 'left' | 'right' = 'bottom';\n\n /**\n * Show action buttons\n * @default false\n */\n @Prop({ reflect: true })\n readonly showActions: boolean = false;\n\n /**\n * Custom actions to display in the footer\n * JSON array of objects with the following properties:\n * - label: string\n * - onClick: function\n * @default '[]'\n */\n @Prop({ reflect: true })\n readonly shortcuts: string = '[]';\n\n /**\n * Show week numbers\n * @default true\n */\n @Prop({ reflect: true })\n readonly showWeekNumbers: boolean;\n\n /**\n * Disabled dates ISO string array\n * @default '[]'\n */\n @Prop({ reflect: true })\n readonly disabledDates: string = '[]';\n\n //#endregion PROPERTIES\n /****************************************************************************/\n //#region METHODS\n\n /**\n * Converts the nv-calendar date format to the format expected by Inputmask.\n * @param {string} format - The date format.\n * @returns {string} Format adapted for Inputmask.\n */\n private convertToInputmaskFormat(format: string): string {\n switch (format) {\n case 'DD/MM/YYYY':\n return 'dd/mm/yyyy';\n case 'MM/DD/YYYY':\n return 'mm/dd/yyyy';\n case 'YYYY-MM-DD':\n return 'yyyy-mm-dd';\n case 'DD.MM.YYYY':\n return 'dd.mm.yyyy';\n case 'YYYYMMDD':\n return 'yyyymmdd';\n default:\n return format;\n }\n }\n\n /**\n * Closes the popover when a click is detected outside the component.\n * @param {MouseEvent} event - The click event.\n */\n private handleClickOutside = (event: MouseEvent) => {\n if (this.open && this.el && !this.el.contains(event.target as Node)) {\n this.open = false;\n }\n };\n\n /**\n * Focuses the input when the input container is clicked.\n * @param {MouseEvent} event - The click event.\n */\n private handleInputContainerClick = (event: MouseEvent) => {\n if (this.readonly || this.disabled) {\n event.preventDefault();\n event.stopPropagation();\n return;\n }\n this.inputElement.focus();\n // Select the first characters based on the date format\n const format = this.dateFormat;\n if (format.startsWith('DD')) {\n this.inputElement.setSelectionRange(0, 2);\n } else if (format.startsWith('MM')) {\n this.inputElement.setSelectionRange(0, 2);\n } else if (format.startsWith('YYYY')) {\n this.inputElement.setSelectionRange(0, 4);\n }\n };\n\n /**\n * Handles the input event on the input element.\n * Updates the singleValue and emits the dateChange event.\n * @param {Event} event - The input event.\n */\n private handleInput = (event: Event) => {\n if (this.readonly || this.disabled) {\n event.preventDefault();\n return;\n }\n const input = event.target as HTMLInputElement;\n this.singleValue = input.value;\n this.dateChange.emit({ value: input.value });\n };\n\n /**\n * Toggles the opening/closing of the popover.\n */\n private toggleCalendar = () => {\n if (this.readonly || this.disabled) {\n return;\n }\n this.open = !this.open;\n };\n\n /**\n * Handles focus events on the input element.\n * @param {FocusEvent} event - The focus event.\n */\n private handleFocus = (event: FocusEvent) => {\n if (this.readonly || this.disabled) {\n event.preventDefault();\n (event.target as HTMLElement).blur();\n return;\n }\n };\n\n //#endregion METHODS\n /****************************************************************************/\n //#region LIFECYCLE\n\n connectedCallback() {\n document.addEventListener('click', this.handleClickOutside);\n }\n\n componentWillLoad() {\n if (this.value) {\n this.singleValue = this.value;\n }\n }\n\n componentDidLoad() {\n const inputs = this.el.querySelectorAll('.input-wrapper input');\n inputs.forEach((input: HTMLInputElement) => {\n Inputmask({\n alias: 'datetime',\n inputFormat: this.convertToInputmaskFormat(this.dateFormat),\n placeholder: '_'.repeat(this.dateFormat.length),\n }).mask(input);\n });\n }\n\n disconnectedCallback() {\n document.removeEventListener('click', this.handleClickOutside);\n }\n\n //#endregion LIFECYCLE\n /****************************************************************************/\n //#region EVENTS\n\n /**\n * Emits an event when the date changes.\n */\n @Event()\n dateChange: EventEmitter<{\n /**\n * The date value.\n */\n value: string;\n }>;\n\n /**\n * Handles the single date selection event from nv-calendar.\n * Updates the input value and closes the popover.\n * @param {CustomEvent} event - The event from nv-calendar.\n */\n @Listen('singleDateChange')\n handleSingleDateChange(event: CustomEvent) {\n const value: string = event.detail;\n this.singleValue = value;\n this.dateChange.emit({ value });\n if (!this.showActions) {\n this.open = false;\n }\n }\n\n @Listen('closePopover')\n handleClosePopover() {\n this.open = false;\n }\n\n @Listen('keydown', { passive: false })\n handleKeyDown(event: KeyboardEvent) {\n if (!this.open) {\n if (event.key === 'ArrowDown') {\n this.open = true;\n\n event.preventDefault();\n return;\n }\n return;\n }\n\n // Verify if the popover element is defined\n if (!this.popoverElement) {\n console.warn('nv-fielddate -> Popover element is not defined');\n return;\n }\n }\n\n @Watch('value')\n handleValueChange(newValue: string) {\n this.singleValue = newValue;\n }\n\n //#endregion EVENTS\n /****************************************************************************/\n //#region RENDER\n render() {\n return (\n <Host>\n {((this.label && this.label.length > 0) ||\n this.el.querySelector('[slot=\"label\"]')) && (\n <label htmlFor={this.inputId}>\n <slot name=\"label\">{this.label}</slot>\n </label>\n )}\n\n <nv-popover\n ref={el => (this.popoverElement = el as HTMLNvPopoverElement)}\n id={this.popoverId}\n triggerMode=\"controlled\"\n placement=\"bottom-start\"\n open={this.open}\n >\n <div slot=\"trigger\" class=\"input-wrapper\">\n <slot name=\"before-input\"></slot>\n\n <div\n class=\"input-container\"\n onClick={this.handleInputContainerClick}\n >\n <slot name=\"leading-input\"></slot>\n\n <input\n id={this.inputId}\n ref={e => (this.inputElement = e)}\n placeholder={this.placeholder}\n name={this.name}\n disabled={this.disabled}\n readOnly={this.readonly}\n required={this.required}\n autofocus={this.autofocus}\n value={this.singleValue}\n onInput={this.handleInput}\n onFocus={this.handleFocus}\n />\n\n <nv-iconbutton\n class=\"toggle-calendar-icon\"\n name=\"calendar\" //{this.open ? 'chevron-top' : 'chevron-down'}\n size=\"md\"\n emphasis=\"lower\"\n aria-label={this.open ? 'Hide calendar' : 'Show calendar'}\n aria-pressed={this.open.toString()}\n onClick={this.toggleCalendar}\n tabIndex={this.disabled ? -1 : 0}\n />\n </div>\n\n <slot name=\"after-input\"></slot>\n </div>\n\n <div slot=\"content\">\n <nv-calendar\n dateFormat={this.dateFormat}\n singleValue={this.singleValue}\n firstDayOfWeek={this.firstDayOfWeek}\n numberOfCalendars={this.numberOfCalendars}\n min={this.min}\n max={this.max}\n locale={this.locale}\n shortcutsPlacement={this.shortcutsPlacement}\n showActions={this.showActions}\n shortcuts={this.shortcuts}\n showWeekNumbers={this.showWeekNumbers}\n disabledDates={this.disabledDates}\n ></nv-calendar>\n </div>\n </nv-popover>\n\n {((this.description && this.description.length > 0) ||\n this.el.querySelector('[slot=\"description\"]')) && (\n <div class=\"description\">\n <slot name=\"description\">{this.description}</slot>\n </div>\n )}\n\n {(this.errorDescription ||\n this.el.querySelector('[slot=\"error-description\"]')) && (\n <div hidden={!this.error} class=\"error-description\">\n {this.el.querySelector('[slot=\"error-description\"]') ? (\n <slot name=\"error-description\"></slot>\n ) : (\n this.errorDescription\n )}\n </div>\n )}\n\n <slot></slot>\n </Host>\n );\n }\n //#endregion RENDER\n}\n"],"version":3}
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface NvFielddaterange extends Components.NvFielddaterange, HTMLElement {}
4
+ export const NvFielddaterange: {
5
+ prototype: NvFielddaterange;
6
+ new (): NvFielddaterange;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;