@zanichelli/albe-web-components 4.0.4 → 4.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (303) hide show
  1. package/CHANGELOG.md +66 -0
  2. package/dist/cjs/{index-6b6a3299.js → index-0e75c8cc.js} +16 -45
  3. package/dist/cjs/index.cjs.js +2 -2
  4. package/dist/cjs/loader.cjs.js +1 -1
  5. package/dist/cjs/utils-155eec04.js +2706 -0
  6. package/dist/cjs/{utils-8cc414c9.js → utils-97262bbd.js} +1 -1
  7. package/dist/cjs/web-components-library.cjs.js +1 -1
  8. package/dist/cjs/z-app-switcher_9.cjs.entry.js +736 -0
  9. package/dist/cjs/z-aria-alert.cjs.entry.js +1 -1
  10. package/dist/cjs/z-avatar.cjs.entry.js +1 -1
  11. package/dist/cjs/z-button-deprecated.cjs.entry.js +1 -1
  12. package/dist/cjs/z-button.cjs.entry.js +44 -0
  13. package/dist/cjs/z-card.cjs.entry.js +69 -0
  14. package/dist/cjs/z-carousel.cjs.entry.js +24 -0
  15. package/dist/cjs/z-chip.cjs.entry.js +2 -2
  16. package/dist/cjs/z-combobox.cjs.entry.js +2 -2
  17. package/dist/cjs/z-contextual-menu.cjs.entry.js +18 -7
  18. package/dist/cjs/z-cookiebar.cjs.entry.js +1 -1
  19. package/dist/cjs/z-date-picker.cjs.entry.js +10 -2701
  20. package/dist/cjs/z-file-upload.cjs.entry.js +2 -2
  21. package/dist/cjs/z-file.cjs.entry.js +10 -9
  22. package/dist/cjs/z-footer.cjs.entry.js +1 -1
  23. package/dist/cjs/z-ghost-loading.cjs.entry.js +19 -0
  24. package/dist/cjs/z-input-deprecated.cjs.entry.js +2 -2
  25. package/dist/cjs/z-input-label_2.cjs.entry.js +2 -2
  26. package/dist/cjs/z-list-group.cjs.entry.js +1 -1
  27. package/dist/cjs/z-list_2.cjs.entry.js +1 -1
  28. package/dist/cjs/z-menu-dropdown_2.cjs.entry.js +2 -2
  29. package/dist/cjs/z-messages-pocket.cjs.entry.js +1 -1
  30. package/dist/cjs/z-modal-login.cjs.entry.js +1 -1
  31. package/dist/cjs/z-myz-card-alert.cjs.entry.js +1 -1
  32. package/dist/cjs/z-myz-card-dictionary.cjs.entry.js +1 -1
  33. package/dist/cjs/z-myz-card-footer.cjs.entry.js +1 -1
  34. package/dist/cjs/z-myz-card-info.cjs.entry.js +4 -4
  35. package/dist/cjs/z-myz-card_4.cjs.entry.js +1 -1
  36. package/dist/cjs/z-myz-list-item.cjs.entry.js +2 -2
  37. package/dist/cjs/z-myz-topbar.cjs.entry.js +1 -1
  38. package/dist/cjs/z-navigation-tab-link.cjs.entry.js +1 -1
  39. package/dist/cjs/z-navigation-tab.cjs.entry.js +1 -1
  40. package/dist/cjs/z-navigation-tabs.cjs.entry.js +1 -1
  41. package/dist/cjs/z-offcanvas.cjs.entry.js +63 -0
  42. package/dist/cjs/z-otp.cjs.entry.js +1 -1
  43. package/dist/cjs/z-pagination-bar.cjs.entry.js +2 -2
  44. package/dist/cjs/z-pocket_3.cjs.entry.js +2 -2
  45. package/dist/cjs/z-popover-deprecated.cjs.entry.js +338 -0
  46. package/dist/cjs/z-popover.cjs.entry.js +304 -97
  47. package/dist/cjs/z-section-title.cjs.entry.js +1 -1
  48. package/dist/cjs/z-skip-to-content.cjs.entry.js +2 -2
  49. package/dist/cjs/z-slideshow.cjs.entry.js +2 -2
  50. package/dist/cjs/z-status-tag.cjs.entry.js +1 -1
  51. package/dist/cjs/z-table-cell.cjs.entry.js +1 -1
  52. package/dist/cjs/z-table-header.cjs.entry.js +8 -11
  53. package/dist/cjs/z-table-row.cjs.entry.js +1 -1
  54. package/dist/cjs/z-table.cjs.entry.js +1 -1
  55. package/dist/cjs/z-toast-notification-list.cjs.entry.js +1 -1
  56. package/dist/cjs/z-toast-notification.cjs.entry.js +1 -1
  57. package/dist/cjs/z-toggle-switch.cjs.entry.js +2 -2
  58. package/dist/cjs/z-tooltip-deprecated.cjs.entry.js +274 -0
  59. package/dist/cjs/z-tooltip.cjs.entry.js +8 -251
  60. package/dist/collection/beans/index.js +16 -45
  61. package/dist/collection/collection-manifest.json +4 -1
  62. package/dist/collection/components/{z-date-picker → date-picker}/styles.css +69 -17
  63. package/dist/collection/components/date-picker/utils.js +76 -0
  64. package/dist/collection/components/{z-date-picker → date-picker/z-date-picker}/index.js +13 -84
  65. package/dist/collection/components/date-picker/z-range-picker/index.js +483 -0
  66. package/dist/collection/components/file-upload/z-file/index.js +13 -13
  67. package/dist/collection/components/file-upload/z-file/styles.css +2 -2
  68. package/dist/collection/components/inputs/z-input/styles.css +2 -0
  69. package/dist/collection/components/notification/z-tooltip/index.js +45 -298
  70. package/dist/collection/components/notification/z-tooltip/styles.css +8 -120
  71. package/dist/collection/components/z-contextual-menu/index.js +26 -16
  72. package/dist/collection/components/z-contextual-menu/styles.css +16 -5
  73. package/dist/collection/components/z-popover/index.js +381 -166
  74. package/dist/collection/components/z-popover/styles.css +91 -180
  75. package/dist/collection/components/z-table/z-table-header/index.js +10 -16
  76. package/dist/collection/components/z-table/z-table-header/styles.css +7 -1
  77. package/dist/collection/deprecated/z-popover-deprecated/index.js +489 -0
  78. package/dist/collection/deprecated/z-popover-deprecated/styles.css +134 -0
  79. package/dist/collection/deprecated/z-tooltip-deprecated/index.js +379 -0
  80. package/dist/collection/deprecated/z-tooltip-deprecated/styles.css +128 -0
  81. package/dist/collection/snowflakes/myz/card/z-myz-card-info/index.js +2 -2
  82. package/dist/collection/snowflakes/myz/card/z-myz-card-info/styles.css +1 -1
  83. package/dist/esm/{index-46ca649a.js → index-c1ce8cab.js} +17 -46
  84. package/dist/esm/index.js +2 -2
  85. package/dist/esm/loader.js +1 -1
  86. package/dist/esm/{utils-5d5963ef.js → utils-99c70c57.js} +2 -2
  87. package/dist/esm/utils-fa9f38ec.js +2701 -0
  88. package/dist/esm/web-components-library.js +1 -1
  89. package/dist/esm/z-app-switcher_9.entry.js +724 -0
  90. package/dist/esm/z-aria-alert.entry.js +1 -1
  91. package/dist/esm/z-avatar.entry.js +1 -1
  92. package/dist/esm/z-button-deprecated.entry.js +1 -1
  93. package/dist/esm/z-button.entry.js +40 -0
  94. package/dist/esm/z-card.entry.js +65 -0
  95. package/dist/esm/z-carousel.entry.js +20 -0
  96. package/dist/esm/z-chip.entry.js +2 -2
  97. package/dist/esm/z-combobox.entry.js +2 -2
  98. package/dist/esm/z-contextual-menu.entry.js +19 -8
  99. package/dist/esm/z-cookiebar.entry.js +1 -1
  100. package/dist/esm/z-date-picker.entry.js +9 -2700
  101. package/dist/esm/z-file-upload.entry.js +2 -2
  102. package/dist/esm/z-file.entry.js +10 -9
  103. package/dist/esm/z-footer.entry.js +1 -1
  104. package/dist/esm/z-ghost-loading.entry.js +15 -0
  105. package/dist/esm/z-input-deprecated.entry.js +2 -2
  106. package/dist/esm/z-input-label_2.entry.js +2 -2
  107. package/dist/esm/z-list-group.entry.js +1 -1
  108. package/dist/esm/z-list_2.entry.js +1 -1
  109. package/dist/esm/z-menu-dropdown_2.entry.js +2 -2
  110. package/dist/esm/z-messages-pocket.entry.js +1 -1
  111. package/dist/esm/z-modal-login.entry.js +1 -1
  112. package/dist/esm/z-myz-card-alert.entry.js +1 -1
  113. package/dist/esm/z-myz-card-dictionary.entry.js +1 -1
  114. package/dist/esm/z-myz-card-footer.entry.js +1 -1
  115. package/dist/esm/z-myz-card-info.entry.js +4 -4
  116. package/dist/esm/z-myz-card_4.entry.js +1 -1
  117. package/dist/esm/z-myz-list-item.entry.js +2 -2
  118. package/dist/esm/z-myz-topbar.entry.js +1 -1
  119. package/dist/esm/z-navigation-tab-link.entry.js +1 -1
  120. package/dist/esm/z-navigation-tab.entry.js +1 -1
  121. package/dist/esm/z-navigation-tabs.entry.js +1 -1
  122. package/dist/esm/z-offcanvas.entry.js +59 -0
  123. package/dist/esm/z-otp.entry.js +1 -1
  124. package/dist/esm/z-pagination-bar.entry.js +2 -2
  125. package/dist/esm/z-pocket_3.entry.js +2 -2
  126. package/dist/esm/z-popover-deprecated.entry.js +334 -0
  127. package/dist/esm/z-popover.entry.js +305 -98
  128. package/dist/esm/z-section-title.entry.js +1 -1
  129. package/dist/esm/z-skip-to-content.entry.js +2 -2
  130. package/dist/esm/z-slideshow.entry.js +2 -2
  131. package/dist/esm/z-status-tag.entry.js +1 -1
  132. package/dist/esm/z-table-cell.entry.js +1 -1
  133. package/dist/esm/z-table-header.entry.js +8 -11
  134. package/dist/esm/z-table-row.entry.js +1 -1
  135. package/dist/esm/z-table.entry.js +1 -1
  136. package/dist/esm/z-toast-notification-list.entry.js +1 -1
  137. package/dist/esm/z-toast-notification.entry.js +1 -1
  138. package/dist/esm/z-toggle-switch.entry.js +2 -2
  139. package/dist/esm/z-tooltip-deprecated.entry.js +270 -0
  140. package/dist/esm/z-tooltip.entry.js +9 -252
  141. package/dist/types/beans/index.d.ts +7 -33
  142. package/dist/types/components/date-picker/utils.d.ts +3 -0
  143. package/dist/types/components/{z-date-picker → date-picker/z-date-picker}/index.d.ts +3 -8
  144. package/dist/types/components/date-picker/z-range-picker/index.d.ts +43 -0
  145. package/dist/types/components/file-upload/z-file/index.d.ts +3 -3
  146. package/dist/types/components/notification/z-tooltip/index.d.ts +14 -29
  147. package/dist/types/components/z-contextual-menu/index.d.ts +8 -4
  148. package/dist/types/components/z-popover/index.d.ts +57 -28
  149. package/dist/types/components/z-table/z-table-header/index.d.ts +2 -1
  150. package/dist/types/components.d.ts +210 -35
  151. package/dist/types/deprecated/z-popover-deprecated/index.d.ts +57 -0
  152. package/dist/types/deprecated/z-tooltip-deprecated/index.d.ts +41 -0
  153. package/dist/web-components-library/index.esm.js +1 -1
  154. package/dist/web-components-library/{p-4af112a7.entry.js → p-053846df.entry.js} +1 -1
  155. package/dist/web-components-library/{p-e2102da3.entry.js → p-0f6edb58.entry.js} +1 -1
  156. package/dist/web-components-library/p-10be0462.entry.js +1 -0
  157. package/dist/web-components-library/{p-b15efba3.entry.js → p-15fa8ca4.entry.js} +1 -1
  158. package/dist/web-components-library/{p-02ea7e49.entry.js → p-1a76a57d.entry.js} +1 -1
  159. package/{www/build/p-1f73a6d8.entry.js → dist/web-components-library/p-1b1717c9.entry.js} +1 -1
  160. package/{www/build/p-3edbd35c.entry.js → dist/web-components-library/p-1d5aa37b.entry.js} +1 -1
  161. package/dist/web-components-library/{p-9074e1a5.entry.js → p-1eb357e8.entry.js} +1 -1
  162. package/dist/web-components-library/{p-57d1acdc.entry.js → p-28e4abc4.entry.js} +1 -1
  163. package/dist/web-components-library/p-41f33f7b.entry.js +1 -0
  164. package/dist/web-components-library/{p-d33fea26.entry.js → p-46aecb12.entry.js} +1 -1
  165. package/dist/web-components-library/{p-63ccb013.entry.js → p-4be52491.entry.js} +1 -1
  166. package/{www/build/p-55ddbfe9.entry.js → dist/web-components-library/p-4d6f2f01.entry.js} +1 -1
  167. package/dist/web-components-library/p-514719d2.entry.js +1 -0
  168. package/dist/web-components-library/p-53dade4b.entry.js +16 -0
  169. package/{www/build/p-df4e963b.entry.js → dist/web-components-library/p-55f09348.entry.js} +1 -1
  170. package/dist/web-components-library/p-5789bbe7.entry.js +1 -0
  171. package/dist/web-components-library/{p-de25c7f0.entry.js → p-5dcbba4e.entry.js} +1 -1
  172. package/dist/web-components-library/{p-9f9e4266.entry.js → p-659fc25e.entry.js} +1 -1
  173. package/dist/web-components-library/{p-8fbc2ce9.entry.js → p-6bbd53ec.entry.js} +1 -1
  174. package/dist/web-components-library/{p-5be162d5.entry.js → p-6c52ed1b.entry.js} +1 -1
  175. package/dist/web-components-library/p-78df5dbf.entry.js +1 -0
  176. package/dist/web-components-library/{p-b9da171f.js → p-7f1cc90f.js} +1 -1
  177. package/dist/web-components-library/{p-0f17db30.entry.js → p-805af37b.entry.js} +1 -1
  178. package/dist/web-components-library/p-870dabdc.entry.js +1 -0
  179. package/dist/web-components-library/{p-43329b81.entry.js → p-897f9491.entry.js} +1 -1
  180. package/dist/web-components-library/{p-3c111c2a.entry.js → p-8ce4b2c4.entry.js} +1 -1
  181. package/dist/web-components-library/p-8cf3798f.entry.js +1 -0
  182. package/dist/web-components-library/p-8ddbbe24.entry.js +1 -0
  183. package/{www/build/p-dffdf60a.entry.js → dist/web-components-library/p-91ec5eb4.entry.js} +1 -1
  184. package/dist/web-components-library/{p-292bc0c4.entry.js → p-92895bce.entry.js} +1 -1
  185. package/dist/web-components-library/p-970bd07c.entry.js +1 -0
  186. package/dist/web-components-library/{p-6c6b4e80.entry.js → p-990b8236.entry.js} +1 -1
  187. package/dist/web-components-library/{p-51cdabeb.entry.js → p-99a562cb.entry.js} +1 -1
  188. package/dist/web-components-library/p-b359a3b4.entry.js +1 -0
  189. package/dist/web-components-library/p-b6cd034b.js +1 -0
  190. package/dist/web-components-library/{p-edb8d2ab.entry.js → p-b9cc2dfc.entry.js} +1 -1
  191. package/dist/web-components-library/p-bfc78a89.entry.js +1 -0
  192. package/dist/web-components-library/{p-d995d9dc.entry.js → p-c042e745.entry.js} +1 -1
  193. package/dist/web-components-library/{p-ccdebe3f.entry.js → p-c8383456.entry.js} +1 -1
  194. package/dist/web-components-library/{p-0e256fdc.entry.js → p-caa21a6f.entry.js} +1 -1
  195. package/{www/build/p-bfe5693d.entry.js → dist/web-components-library/p-cd88cead.entry.js} +1 -1
  196. package/dist/web-components-library/p-d04f3cb6.entry.js +1 -0
  197. package/{www/build/p-9a5ee6c2.entry.js → dist/web-components-library/p-d6361790.entry.js} +1 -1
  198. package/dist/web-components-library/{p-69ef6ddc.entry.js → p-dd0efdbf.entry.js} +1 -1
  199. package/dist/web-components-library/p-e007cd0b.entry.js +1 -0
  200. package/dist/web-components-library/{p-0a0aee35.entry.js → p-e74b3fd9.entry.js} +1 -1
  201. package/{www/build/p-d97a2db9.entry.js → dist/web-components-library/p-eca4cb15.entry.js} +1 -1
  202. package/dist/web-components-library/p-ed1cd6b1.js +1 -0
  203. package/dist/web-components-library/p-f26251dd.entry.js +1 -0
  204. package/dist/web-components-library/p-f61fd81e.entry.js +1 -0
  205. package/dist/web-components-library/{p-1727c1c8.entry.js → p-f78d6123.entry.js} +1 -1
  206. package/dist/web-components-library/p-fbfaa699.entry.js +1 -0
  207. package/dist/web-components-library/{p-ba29bc12.entry.js → p-fdd91263.entry.js} +1 -1
  208. package/dist/web-components-library/{p-fe927bf4.entry.js → p-ff4a0f6f.entry.js} +1 -1
  209. package/dist/web-components-library/web-components-library.esm.js +1 -1
  210. package/package.json +1 -1
  211. package/react/components.d.ts +3 -0
  212. package/react/components.js +5 -2
  213. package/react/components.js.map +1 -1
  214. package/www/build/index.esm.js +1 -1
  215. package/www/build/{p-4af112a7.entry.js → p-053846df.entry.js} +1 -1
  216. package/www/build/{p-e2102da3.entry.js → p-0f6edb58.entry.js} +1 -1
  217. package/www/build/p-10be0462.entry.js +1 -0
  218. package/www/build/{p-b15efba3.entry.js → p-15fa8ca4.entry.js} +1 -1
  219. package/www/build/{p-02ea7e49.entry.js → p-1a76a57d.entry.js} +1 -1
  220. package/{dist/web-components-library/p-1f73a6d8.entry.js → www/build/p-1b1717c9.entry.js} +1 -1
  221. package/{dist/web-components-library/p-3edbd35c.entry.js → www/build/p-1d5aa37b.entry.js} +1 -1
  222. package/www/build/{p-9074e1a5.entry.js → p-1eb357e8.entry.js} +1 -1
  223. package/www/build/{p-57d1acdc.entry.js → p-28e4abc4.entry.js} +1 -1
  224. package/www/build/p-41f33f7b.entry.js +1 -0
  225. package/www/build/{p-d33fea26.entry.js → p-46aecb12.entry.js} +1 -1
  226. package/www/build/{p-63ccb013.entry.js → p-4be52491.entry.js} +1 -1
  227. package/{dist/web-components-library/p-55ddbfe9.entry.js → www/build/p-4d6f2f01.entry.js} +1 -1
  228. package/www/build/p-514719d2.entry.js +1 -0
  229. package/www/build/p-53dade4b.entry.js +16 -0
  230. package/{dist/web-components-library/p-df4e963b.entry.js → www/build/p-55f09348.entry.js} +1 -1
  231. package/www/build/p-5789bbe7.entry.js +1 -0
  232. package/www/build/{p-de25c7f0.entry.js → p-5dcbba4e.entry.js} +1 -1
  233. package/www/build/{p-9f9e4266.entry.js → p-659fc25e.entry.js} +1 -1
  234. package/www/build/{p-8fbc2ce9.entry.js → p-6bbd53ec.entry.js} +1 -1
  235. package/www/build/{p-5be162d5.entry.js → p-6c52ed1b.entry.js} +1 -1
  236. package/www/build/p-78df5dbf.entry.js +1 -0
  237. package/www/build/{p-b9da171f.js → p-7f1cc90f.js} +1 -1
  238. package/www/build/{p-0f17db30.entry.js → p-805af37b.entry.js} +1 -1
  239. package/www/build/p-870dabdc.entry.js +1 -0
  240. package/www/build/{p-43329b81.entry.js → p-897f9491.entry.js} +1 -1
  241. package/www/build/{p-3c111c2a.entry.js → p-8ce4b2c4.entry.js} +1 -1
  242. package/www/build/p-8cf3798f.entry.js +1 -0
  243. package/www/build/p-8ddbbe24.entry.js +1 -0
  244. package/{dist/web-components-library/p-dffdf60a.entry.js → www/build/p-91ec5eb4.entry.js} +1 -1
  245. package/www/build/{p-292bc0c4.entry.js → p-92895bce.entry.js} +1 -1
  246. package/www/build/p-970bd07c.entry.js +1 -0
  247. package/www/build/p-975e9d42.js +129 -0
  248. package/www/build/{p-6c6b4e80.entry.js → p-990b8236.entry.js} +1 -1
  249. package/www/build/{p-51cdabeb.entry.js → p-99a562cb.entry.js} +1 -1
  250. package/www/build/p-b359a3b4.entry.js +1 -0
  251. package/www/build/p-b6cd034b.js +1 -0
  252. package/www/build/{p-edb8d2ab.entry.js → p-b9cc2dfc.entry.js} +1 -1
  253. package/www/build/p-bfc78a89.entry.js +1 -0
  254. package/www/build/{p-d995d9dc.entry.js → p-c042e745.entry.js} +1 -1
  255. package/www/build/{p-ccdebe3f.entry.js → p-c8383456.entry.js} +1 -1
  256. package/www/build/{p-0e256fdc.entry.js → p-caa21a6f.entry.js} +1 -1
  257. package/{dist/web-components-library/p-bfe5693d.entry.js → www/build/p-cd88cead.entry.js} +1 -1
  258. package/www/build/p-d04f3cb6.entry.js +1 -0
  259. package/{dist/web-components-library/p-9a5ee6c2.entry.js → www/build/p-d6361790.entry.js} +1 -1
  260. package/www/build/{p-69ef6ddc.entry.js → p-dd0efdbf.entry.js} +1 -1
  261. package/www/build/p-e007cd0b.entry.js +1 -0
  262. package/www/build/{p-0a0aee35.entry.js → p-e74b3fd9.entry.js} +1 -1
  263. package/{dist/web-components-library/p-d97a2db9.entry.js → www/build/p-eca4cb15.entry.js} +1 -1
  264. package/www/build/p-ed1cd6b1.js +1 -0
  265. package/www/build/p-f26251dd.entry.js +1 -0
  266. package/www/build/p-f61fd81e.entry.js +1 -0
  267. package/www/build/{p-1727c1c8.entry.js → p-f78d6123.entry.js} +1 -1
  268. package/www/build/p-fbfaa699.entry.js +1 -0
  269. package/www/build/p-fcff1237.css +812 -0
  270. package/www/build/{p-ba29bc12.entry.js → p-fdd91263.entry.js} +1 -1
  271. package/www/build/{p-fe927bf4.entry.js → p-ff4a0f6f.entry.js} +1 -1
  272. package/www/build/web-components-library.esm.js +1 -1
  273. package/www/index.html +6 -70
  274. package/dist/cjs/z-app-switcher_11.cjs.entry.js +0 -377
  275. package/dist/cjs/z-input_2.cjs.entry.js +0 -228
  276. package/dist/esm/z-app-switcher_11.entry.js +0 -363
  277. package/dist/esm/z-input_2.entry.js +0 -223
  278. package/dist/web-components-library/p-0d29d851.entry.js +0 -1
  279. package/dist/web-components-library/p-0e408871.entry.js +0 -1
  280. package/dist/web-components-library/p-0ef6c549.entry.js +0 -1
  281. package/dist/web-components-library/p-20d62443.entry.js +0 -1
  282. package/dist/web-components-library/p-562e2d52.entry.js +0 -1
  283. package/dist/web-components-library/p-5eacbfc7.entry.js +0 -1
  284. package/dist/web-components-library/p-6218514a.entry.js +0 -1
  285. package/dist/web-components-library/p-71accd8e.entry.js +0 -1
  286. package/dist/web-components-library/p-7c6d4440.entry.js +0 -1
  287. package/dist/web-components-library/p-9f5d707a.js +0 -1
  288. package/dist/web-components-library/p-a8875b97.entry.js +0 -16
  289. package/dist/web-components-library/p-e2431b92.entry.js +0 -1
  290. package/www/build/p-0d29d851.entry.js +0 -1
  291. package/www/build/p-0e408871.entry.js +0 -1
  292. package/www/build/p-0ef6c549.entry.js +0 -1
  293. package/www/build/p-20d62443.entry.js +0 -1
  294. package/www/build/p-562e2d52.entry.js +0 -1
  295. package/www/build/p-5eacbfc7.entry.js +0 -1
  296. package/www/build/p-6218514a.entry.js +0 -1
  297. package/www/build/p-71accd8e.entry.js +0 -1
  298. package/www/build/p-7614383b.js +0 -1
  299. package/www/build/p-7c6d4440.entry.js +0 -1
  300. package/www/build/p-88b56b6e.css +0 -1
  301. package/www/build/p-9f5d707a.js +0 -1
  302. package/www/build/p-a8875b97.entry.js +0 -16
  303. package/www/build/p-e2431b92.entry.js +0 -1
@@ -0,0 +1,483 @@
1
+ import { Component, Prop, Element, h, Listen, Event, State, } from "@stencil/core";
2
+ import flatpickr from "flatpickr";
3
+ import { Italian } from "flatpickr/dist/l10n/it.js";
4
+ import { ZDatePickerMode, ZDatePickerPosition, InputTypeEnum, } from "../../../beans";
5
+ import { setAriaOptions, setFlatpickrPosition } from "../utils";
6
+ export class ZRangePicker {
7
+ constructor() {
8
+ /** [Optional] datepicker mode: date, datetime, only months */
9
+ this.mode = ZDatePickerMode.date;
10
+ this.flatpickrPosition = ZDatePickerPosition.bottom;
11
+ this.activeInput = "start-input";
12
+ this.flatpickrInstance = null;
13
+ this.flatpickrInstance2 = null;
14
+ }
15
+ handleClick() {
16
+ this.getFocusedInput();
17
+ }
18
+ handleKeyDown(ev) {
19
+ let currentInputState = this.activeInput === "start-input"
20
+ ? { picker: this.flatpickrInstance, index: 0 }
21
+ : { picker: this.flatpickrInstance2, index: 1 };
22
+ let isCalendarOpened = document.activeElement.closest(".flatpickr-calendar");
23
+ this.getFocusedInput();
24
+ if (ev.key === "Enter" || ev.key === " ") {
25
+ if (document.activeElement.classList.contains(`${this.rangePickerId}`) ||
26
+ document.activeElement.classList.contains(`${this.rangePickerId}-2`)) {
27
+ !isCalendarOpened && currentInputState.picker.open();
28
+ }
29
+ let isPrevArrowEntered = document.activeElement.classList.contains("flatpickr-prev-month");
30
+ let isNextArrowEntered = document.activeElement.classList.contains("flatpickr-next-month");
31
+ let arrowPressed = isPrevArrowEntered || isNextArrowEntered;
32
+ arrowPressed && ev.key === " " && ev.preventDefault();
33
+ isPrevArrowEntered && currentInputState.picker.changeMonth(-1);
34
+ isNextArrowEntered && currentInputState.picker.changeMonth(1);
35
+ }
36
+ }
37
+ /** Set background color before or after first selected date, before selecting the second one */
38
+ onMouseOver(e) {
39
+ let currentInputState = this.activeInput === "start-input"
40
+ ? { picker: this.flatpickrInstance, index: 0 }
41
+ : { picker: this.flatpickrInstance2, index: 1 };
42
+ this.setRangeHoverStyle(e, currentInputState.picker, this.element.getElementsByClassName("flatpickr-calendar")[currentInputState.index]);
43
+ }
44
+ componentDidLoad() {
45
+ let config = {
46
+ enableTime: this.mode === ZDatePickerMode.dateTime,
47
+ locale: Italian,
48
+ allowInput: true,
49
+ dateFormat: this.mode === ZDatePickerMode.dateTime ? "d-m-Y - H:i" : "d-m-Y",
50
+ ariaDateFormat: "d F Y",
51
+ minuteIncrement: 1,
52
+ time_24hr: true,
53
+ onChange: (selectedDates, _dateStr, instance) => {
54
+ this.onDateSelect(selectedDates, instance);
55
+ },
56
+ onOpen: () => {
57
+ setAriaOptions(this.element, this.mode);
58
+ this.flatpickrPosition = setFlatpickrPosition(this.element, this.mode);
59
+ this.setRangeStyle();
60
+ this.getFocusedInput();
61
+ this.getCurrentMonth();
62
+ },
63
+ onYearChange: () => {
64
+ this.setRangeStyle();
65
+ },
66
+ onMonthChange: () => {
67
+ this.setRangeStyle();
68
+ },
69
+ onKeyDown: () => {
70
+ setAriaOptions(this.element, this.mode);
71
+ },
72
+ wrap: true,
73
+ };
74
+ this.flatpickrInstance = flatpickr(`.${this.rangePickerId}-container`, Object.assign(Object.assign({}, config), { mode: "multiple", appendTo: this.element.querySelector(`.${this.rangePickerId}-container`) }));
75
+ this.flatpickrInstance2 = flatpickr(`.${this.rangePickerId}-container-2`, Object.assign(Object.assign({}, config), { mode: "multiple", appendTo: this.element.querySelector(`.${this.rangePickerId}-container-2`) }));
76
+ this.element.querySelectorAll(".flatpickr-weekday").forEach((element) => {
77
+ element.innerHTML = element.innerHTML.trim().charAt(0);
78
+ });
79
+ }
80
+ onDateSelect(selectedDates, instance) {
81
+ const firstInputElement = this.element.querySelectorAll("z-input")[0];
82
+ const secondInputElement = this.element.querySelectorAll("z-input")[1];
83
+ let firstInputActive = this.activeInput === "start-input";
84
+ /** If range is already set, clicking another date it will update it */
85
+ if (selectedDates.length === 3) {
86
+ instance.setDate([selectedDates[0], selectedDates[2]]);
87
+ }
88
+ /** Order the selected dates ASC and update the two flatpickers */
89
+ if (instance.selectedDates.length > 1) {
90
+ if (firstInputActive) {
91
+ /** First Flatpickr selection */
92
+ let orderedDates = instance.selectedDates.sort((a, b) => b - a);
93
+ instance.setDate([...orderedDates]);
94
+ this.flatpickrInstance2.setDate([
95
+ instance.selectedDates[1],
96
+ instance.selectedDates[0],
97
+ ]);
98
+ }
99
+ else {
100
+ /** Second Flatpickr selection */
101
+ let orderedDates = instance.selectedDates.sort((a, b) => a - b);
102
+ instance.setDate([...orderedDates]);
103
+ this.flatpickrInstance.setDate([
104
+ instance.selectedDates[1],
105
+ instance.selectedDates[0],
106
+ ]);
107
+ this.flatpickrInstance.setDate(this.flatpickrInstance.selectedDates.sort((a, b) => b - a));
108
+ }
109
+ this.printDate(instance.selectedDates[0], instance.selectedDates[1]);
110
+ }
111
+ let index = instance.selectedDates.length - 1;
112
+ /** If exists, set second date value into first input */
113
+ if (instance.selectedDates[0]) {
114
+ firstInputElement.value = this.getDate(instance.selectedDates[firstInputActive ? index : 0]);
115
+ }
116
+ /** If exists, set second date value into second input */
117
+ if (instance.selectedDates[1]) {
118
+ secondInputElement.value = this.getDate(instance.selectedDates[firstInputActive ? 0 : index]);
119
+ }
120
+ }
121
+ getDate(date) {
122
+ if (this.mode === ZDatePickerMode.date) {
123
+ return `${flatpickr.formatDate(date, "d-m-Y")}`;
124
+ }
125
+ else {
126
+ return `${flatpickr.formatDate(date, "d-m-Y - H:i")}`;
127
+ }
128
+ }
129
+ printDate(firstDate, lastDate) {
130
+ let orderedDates = [firstDate, lastDate].sort((a, b) => a - b);
131
+ this.dateSelect.emit([
132
+ this.getDate(orderedDates[0]),
133
+ this.getDate(orderedDates[1]),
134
+ ]);
135
+ }
136
+ /** Replace month word to month number */
137
+ parseDate(date) {
138
+ const month = date.split(" ")[1];
139
+ const months = {
140
+ Gennaio: "01",
141
+ Febbraio: "02",
142
+ Marzo: "03",
143
+ Aprile: "04",
144
+ Maggio: "05",
145
+ Giugno: "06",
146
+ Luglio: "07",
147
+ Agosto: "08",
148
+ Settembre: "09",
149
+ Ottobre: "10",
150
+ Novembre: "11",
151
+ Dicembre: "12",
152
+ };
153
+ const pieces = date.replace(month, months[month]).split(" ");
154
+ return new Date(parseInt(pieces[2]), parseInt(pieces[1]) - 1, parseInt(pieces[0]));
155
+ }
156
+ /** Get the current focused input, first or last */
157
+ getFocusedInput() {
158
+ const focusedZInput = document.activeElement.closest("z-input");
159
+ if (!focusedZInput) {
160
+ return;
161
+ }
162
+ if (focusedZInput === null || focusedZInput === void 0 ? void 0 : focusedZInput.classList.contains("start-input")) {
163
+ this.activeInput = "start-input";
164
+ }
165
+ else if (focusedZInput.classList.contains("end-input")) {
166
+ this.activeInput = "end-input";
167
+ }
168
+ }
169
+ /** Set current month after flatpickr opened */
170
+ getCurrentMonth() {
171
+ let currentInputState = this.activeInput === "start-input"
172
+ ? { picker: this.flatpickrInstance, index: 0 }
173
+ : { picker: this.flatpickrInstance2, index: 1 };
174
+ let length = currentInputState.picker.selectedDates.length;
175
+ if (length > 0) {
176
+ let dateMonth = currentInputState.picker.selectedDates[length - 1].getMonth();
177
+ let dateYear = currentInputState.picker.selectedDates[length - 1].getFullYear();
178
+ currentInputState.picker.changeMonth(dateMonth, false);
179
+ currentInputState.picker.changeYear(dateYear, false);
180
+ }
181
+ }
182
+ /** Set style of the days between the two selected dates */
183
+ setRangeStyle() {
184
+ let currentInputState = this.activeInput === "start-input"
185
+ ? { picker: this.flatpickrInstance, index: 0 }
186
+ : { picker: this.flatpickrInstance2, index: 1 };
187
+ let calendar = this.element.getElementsByClassName("flatpickr-calendar")[currentInputState.index];
188
+ Array.from(calendar.getElementsByClassName("flatpickr-day")).forEach((element) => {
189
+ let selectedDatesCount = this.flatpickrInstance.selectedDates.length;
190
+ if (selectedDatesCount === 2) {
191
+ let date = this.parseDate(element.ariaLabel);
192
+ let firstDate = this.flatpickrInstance.selectedDates[1];
193
+ let secondDate = this.flatpickrInstance.selectedDates[0];
194
+ let selected = element.className.includes("selected");
195
+ if (date > firstDate && date < secondDate && !selected) {
196
+ element.classList.toggle("inRange", true);
197
+ }
198
+ }
199
+ });
200
+ }
201
+ /** Set style of the days between first selected date and hovered date */
202
+ setRangeHoverStyle(e, flatpickr, calendar) {
203
+ const isDay = e.target.classList.contains("flatpickr-day");
204
+ if (isDay) {
205
+ let calendarDate = e.target.ariaLabel;
206
+ let hoveredDate = this.parseDate(calendarDate);
207
+ Array.from(calendar.getElementsByClassName("flatpickr-day")).forEach((element) => {
208
+ let date = this.parseDate(element.ariaLabel);
209
+ let selectedDatesCount = flatpickr.selectedDates.length;
210
+ let firstDate = selectedDatesCount === 1 ? flatpickr.selectedDates[0] : null;
211
+ let before = firstDate && hoveredDate < firstDate;
212
+ let after = firstDate && hoveredDate > firstDate;
213
+ let selected = element.className.includes("selected");
214
+ if (firstDate &&
215
+ ((before && date > hoveredDate && date < firstDate && !selected) ||
216
+ (after && date < hoveredDate && date > firstDate && !selected))) {
217
+ element.classList.toggle("inRange", true);
218
+ }
219
+ else {
220
+ element.classList.remove("inRange");
221
+ }
222
+ this.setRangeStyle();
223
+ });
224
+ }
225
+ }
226
+ onStopTyping(value) {
227
+ let text = value.detail.value;
228
+ let englishData = text.split("-");
229
+ let time = this.mode === ZDatePickerMode.dateTime ? `${englishData[3]}:00` : "";
230
+ let englishParsedData = `${englishData[2]}-${englishData[1]}-${englishData[0]}T${time}`
231
+ .split(" ")
232
+ .join("");
233
+ let isDate = Date.parse(englishParsedData);
234
+ if (this.activeInput === "start-input") {
235
+ /** Remove second value from either the flatpickers if input is cleared */
236
+ if (text === "") {
237
+ if (this.flatpickrInstance.selectedDates.length === 1) {
238
+ this.flatpickrInstance.setDate([]);
239
+ this.flatpickrInstance2.setDate([]);
240
+ }
241
+ else {
242
+ this.flatpickrInstance.setDate([
243
+ this.flatpickrInstance.selectedDates[0],
244
+ ]);
245
+ this.flatpickrInstance2.setDate([
246
+ this.flatpickrInstance2.selectedDates[1],
247
+ ]);
248
+ }
249
+ }
250
+ else {
251
+ /** If the value inserted is a correct date, update the first input value */
252
+ if (!Number.isNaN(isDate)) {
253
+ this.flatpickrInstance.setDate([
254
+ this.flatpickrInstance.selectedDates[0],
255
+ text,
256
+ ]);
257
+ this.flatpickrInstance2.setDate([
258
+ text,
259
+ this.flatpickrInstance2.selectedDates[1],
260
+ ]);
261
+ if (this.flatpickrInstance.selectedDates.length > 1) {
262
+ this.printDate(new Date(englishParsedData), this.flatpickrInstance.selectedDates[0]);
263
+ }
264
+ this.setRangeStyle();
265
+ }
266
+ }
267
+ }
268
+ else {
269
+ /** Remove second value from either the flatpickers if input is cleared */
270
+ if (text === "") {
271
+ if (this.flatpickrInstance2.selectedDates.length === 1) {
272
+ this.flatpickrInstance.setDate([]);
273
+ this.flatpickrInstance2.setDate([]);
274
+ }
275
+ else {
276
+ this.flatpickrInstance.setDate([
277
+ this.flatpickrInstance.selectedDates[1],
278
+ ]);
279
+ this.flatpickrInstance2.setDate([
280
+ this.flatpickrInstance2.selectedDates[0],
281
+ ]);
282
+ }
283
+ }
284
+ else {
285
+ /** If the value inserted is a correct date, update the second input value */
286
+ if (!Number.isNaN(isDate)) {
287
+ this.flatpickrInstance.setDate([
288
+ text,
289
+ this.flatpickrInstance.selectedDates[1],
290
+ ]);
291
+ this.flatpickrInstance2.setDate([
292
+ this.flatpickrInstance2.selectedDates[0],
293
+ text,
294
+ ]);
295
+ if (this.flatpickrInstance2.selectedDates.length > 1) {
296
+ this.printDate(new Date(englishParsedData), this.flatpickrInstance2.selectedDates[0]);
297
+ }
298
+ this.setRangeStyle();
299
+ }
300
+ }
301
+ }
302
+ }
303
+ render() {
304
+ const zInputProps = {
305
+ type: InputTypeEnum.text,
306
+ icon: "event",
307
+ tabindex: "0",
308
+ message: false,
309
+ onStopTyping: (value) => {
310
+ this.onStopTyping(value);
311
+ },
312
+ };
313
+ return (h("div", { class: {
314
+ ["range-picker-container"]: true,
315
+ [this.mode]: true,
316
+ [this.activeInput]: true,
317
+ [this.flatpickrPosition]: true,
318
+ } },
319
+ h("div", { class: `${this.rangePickerId}-container` },
320
+ h("input", { class: "hidden-input", "data-input": true }),
321
+ h("z-input", Object.assign({}, zInputProps, { class: `start-input ${this.rangePickerId}`, ariaLabel: this.firstAriaLabel, label: this.firstLabel, "data-toggle": true }))),
322
+ h("div", { class: `${this.rangePickerId}-container-2` },
323
+ h("input", { class: "hidden-input", "data-input": true }),
324
+ h("z-input", Object.assign({}, zInputProps, { class: `end-input ${this.rangePickerId}-2`, ariaLabel: this.secondAriaLabel, label: this.secondLabel, "data-toggle": true })))));
325
+ }
326
+ static get is() { return "z-range-picker"; }
327
+ static get originalStyleUrls() { return {
328
+ "$": ["../styles.css"]
329
+ }; }
330
+ static get styleUrls() { return {
331
+ "$": ["../styles.css"]
332
+ }; }
333
+ static get properties() { return {
334
+ "rangePickerId": {
335
+ "type": "string",
336
+ "mutable": false,
337
+ "complexType": {
338
+ "original": "string",
339
+ "resolved": "string",
340
+ "references": {}
341
+ },
342
+ "required": false,
343
+ "optional": false,
344
+ "docs": {
345
+ "tags": [],
346
+ "text": "unique id"
347
+ },
348
+ "attribute": "range-picker-id",
349
+ "reflect": false
350
+ },
351
+ "firstAriaLabel": {
352
+ "type": "string",
353
+ "mutable": false,
354
+ "complexType": {
355
+ "original": "string",
356
+ "resolved": "string",
357
+ "references": {}
358
+ },
359
+ "required": false,
360
+ "optional": true,
361
+ "docs": {
362
+ "tags": [],
363
+ "text": "first z-input aria label"
364
+ },
365
+ "attribute": "first-aria-label",
366
+ "reflect": false
367
+ },
368
+ "firstLabel": {
369
+ "type": "string",
370
+ "mutable": false,
371
+ "complexType": {
372
+ "original": "string",
373
+ "resolved": "string",
374
+ "references": {}
375
+ },
376
+ "required": false,
377
+ "optional": true,
378
+ "docs": {
379
+ "tags": [],
380
+ "text": "first z-input label"
381
+ },
382
+ "attribute": "first-label",
383
+ "reflect": false
384
+ },
385
+ "secondAriaLabel": {
386
+ "type": "string",
387
+ "mutable": false,
388
+ "complexType": {
389
+ "original": "string",
390
+ "resolved": "string",
391
+ "references": {}
392
+ },
393
+ "required": false,
394
+ "optional": true,
395
+ "docs": {
396
+ "tags": [],
397
+ "text": "second z-input aria label"
398
+ },
399
+ "attribute": "second-aria-label",
400
+ "reflect": false
401
+ },
402
+ "secondLabel": {
403
+ "type": "string",
404
+ "mutable": false,
405
+ "complexType": {
406
+ "original": "string",
407
+ "resolved": "string",
408
+ "references": {}
409
+ },
410
+ "required": false,
411
+ "optional": true,
412
+ "docs": {
413
+ "tags": [],
414
+ "text": "second z-input label"
415
+ },
416
+ "attribute": "second-label",
417
+ "reflect": false
418
+ },
419
+ "mode": {
420
+ "type": "string",
421
+ "mutable": false,
422
+ "complexType": {
423
+ "original": "ZDatePickerMode",
424
+ "resolved": "ZDatePickerMode.date | ZDatePickerMode.dateTime | ZDatePickerMode.months",
425
+ "references": {
426
+ "ZDatePickerMode": {
427
+ "location": "import",
428
+ "path": "../../../beans"
429
+ }
430
+ }
431
+ },
432
+ "required": false,
433
+ "optional": false,
434
+ "docs": {
435
+ "tags": [],
436
+ "text": "[Optional] datepicker mode: date, datetime, only months"
437
+ },
438
+ "attribute": "mode",
439
+ "reflect": false,
440
+ "defaultValue": "ZDatePickerMode.date"
441
+ }
442
+ }; }
443
+ static get states() { return {
444
+ "flatpickrPosition": {},
445
+ "activeInput": {}
446
+ }; }
447
+ static get events() { return [{
448
+ "method": "dateSelect",
449
+ "name": "dateSelect",
450
+ "bubbles": true,
451
+ "cancelable": true,
452
+ "composed": true,
453
+ "docs": {
454
+ "tags": [],
455
+ "text": "emitted when date changes, returns an array with the two selected dates"
456
+ },
457
+ "complexType": {
458
+ "original": "any",
459
+ "resolved": "any",
460
+ "references": {}
461
+ }
462
+ }]; }
463
+ static get elementRef() { return "element"; }
464
+ static get listeners() { return [{
465
+ "name": "click",
466
+ "method": "handleClick",
467
+ "target": "body",
468
+ "capture": true,
469
+ "passive": false
470
+ }, {
471
+ "name": "keydown",
472
+ "method": "handleKeyDown",
473
+ "target": "body",
474
+ "capture": true,
475
+ "passive": false
476
+ }, {
477
+ "name": "mouseover",
478
+ "method": "onMouseOver",
479
+ "target": undefined,
480
+ "capture": false,
481
+ "passive": true
482
+ }]; }
483
+ }
@@ -1,29 +1,29 @@
1
1
  import { Component, h, Event, Element, Host, State, Listen, Prop, } from "@stencil/core";
2
- import { TooltipPosition, ZChipType } from "../../../beans";
2
+ import { PopoverPositions, ZChipType } from "../../../beans";
3
3
  import { tabletBreakpoint } from "../../../constants/breakpoints";
4
- import "./index";
5
4
  export class ZFile {
6
5
  constructor() {
7
- this.allowTooltip = false;
8
- this.tooltipVisible = false;
6
+ this.allowPopover = false;
7
+ this.popoverVisible = false;
9
8
  }
10
9
  removeFileHandler() {
11
10
  this.removeFile.emit();
12
11
  this.el.remove();
13
12
  }
14
13
  onMouseOver() {
15
- this.tooltipVisible = true;
14
+ this.popoverVisible = true;
16
15
  }
17
16
  onMouseLeave() {
18
- this.tooltipVisible = false;
17
+ this.popoverVisible = false;
19
18
  }
20
19
  onInteractiveIconClick() {
21
20
  this.removeFileHandler();
22
21
  }
23
22
  componentDidLoad() {
24
23
  var _a, _b;
25
- if (this.elementHasEllipsis() && window.innerWidth > tabletBreakpoint)
26
- this.allowTooltip = true;
24
+ if (this.elementHasEllipsis() && window.innerWidth > tabletBreakpoint) {
25
+ this.allowPopover = true;
26
+ }
27
27
  (_b = (_a = this.icon) === null || _a === void 0 ? void 0 : _a.focus) === null || _b === void 0 ? void 0 : _b.call(_a);
28
28
  }
29
29
  elementHasEllipsis() {
@@ -31,9 +31,9 @@ export class ZFile {
31
31
  }
32
32
  render() {
33
33
  return (h(Host, null,
34
- this.allowTooltip && (h("z-tooltip", { open: this.tooltipVisible, type: TooltipPosition.AUTO, "bind-to": `#chip-${this.fileNumber}` },
35
- h("span", { class: "body-5 tootip-content" }, this.ellipsis.innerText))),
36
- h("z-chip", { id: `chip-${this.fileNumber}`, interactiveIcon: "multiply-circled", type: ZChipType.default },
34
+ this.allowPopover && (h("z-popover", { open: this.popoverVisible, position: PopoverPositions.AUTO, bindTo: this.chip },
35
+ h("span", { class: "body-5 tooltip-content" }, this.ellipsis.innerText))),
36
+ h("z-chip", { ref: (el) => (this.chip = el), id: `chip-${this.fileNumber}`, interactiveIcon: "multiply-circled", type: ZChipType.default },
37
37
  h("span", { ref: (el) => (this.ellipsis = el), tabIndex: -1 },
38
38
  h("slot", null)))));
39
39
  }
@@ -65,8 +65,8 @@ export class ZFile {
65
65
  }
66
66
  }; }
67
67
  static get states() { return {
68
- "allowTooltip": {},
69
- "tooltipVisible": {}
68
+ "allowPopover": {},
69
+ "popoverVisible": {}
70
70
  }; }
71
71
  static get events() { return [{
72
72
  "method": "removeFile",
@@ -4,11 +4,11 @@
4
4
  position: relative;
5
5
  }
6
6
 
7
- :host > z-tooltip {
7
+ :host > z-popover {
8
8
  z-index: 10;
9
9
  }
10
10
 
11
- :host > z-tooltip > .tootip-content {
11
+ :host > z-popover > .tooltip-content {
12
12
  white-space: nowrap;
13
13
  }
14
14
 
@@ -123,6 +123,8 @@ label.inputLabel {
123
123
  margin-bottom: var(--space-unit);
124
124
  color: var(--color-text02);
125
125
  font-family: var(--font-family-sans);
126
+ font-size: var(--font-size-1);
127
+ font-weight: var(--font-sb);
126
128
  text-transform: uppercase;
127
129
  text-align: left;
128
130
  }