@zanichelli/albe-web-components 17.0.6 → 17.0.7-RC1

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 (385) hide show
  1. package/dist/cjs/{index-aa56c709.js → index-117cd3b0.js} +4 -4
  2. package/dist/cjs/{index-aa56c709.js.map → index-117cd3b0.js.map} +1 -1
  3. package/dist/cjs/{index-2a9a328d.js → index-9b8b105e.js} +2 -2
  4. package/dist/cjs/{index-2a9a328d.js.map → index-9b8b105e.js.map} +1 -1
  5. package/dist/cjs/{index-f5ebcaa2.js → index-a465bca8.js} +2 -1
  6. package/dist/cjs/index-a465bca8.js.map +1 -0
  7. package/dist/cjs/{index-b2f35532.js → index-d6c4fda2.js} +2 -2
  8. package/dist/cjs/{index-b2f35532.js.map → index-d6c4fda2.js.map} +1 -1
  9. package/dist/cjs/index.cjs.js +2 -2
  10. package/dist/cjs/loader.cjs.js +1 -1
  11. package/dist/cjs/{utils-d08d4b80.js → utils-873dd0ae.js} +2 -2
  12. package/dist/cjs/{utils-d08d4b80.js.map → utils-873dd0ae.js.map} +1 -1
  13. package/dist/cjs/{utils-c95c97b8.js → utils-ee8e5b38.js} +2 -2
  14. package/dist/cjs/{utils-c95c97b8.js.map → utils-ee8e5b38.js.map} +1 -1
  15. package/dist/cjs/web-components-library.cjs.js +1 -1
  16. package/dist/cjs/z-accordion.cjs.entry.js +1 -1
  17. package/dist/cjs/z-anchor-navigation.cjs.entry.js +1 -1
  18. package/dist/cjs/z-app-header-deprecated.cjs.entry.js +1 -1
  19. package/dist/cjs/z-app-header_12.cjs.entry.js +10 -7
  20. package/dist/cjs/z-app-header_12.cjs.entry.js.map +1 -1
  21. package/dist/cjs/z-aria-alert.cjs.entry.js +1 -1
  22. package/dist/cjs/z-avatar.cjs.entry.js +1 -1
  23. package/dist/cjs/z-book-card-app.cjs.entry.js +1 -1
  24. package/dist/cjs/z-book-card-deprecated.cjs.entry.js +2 -2
  25. package/dist/cjs/z-book-card.cjs.entry.js +1 -1
  26. package/dist/cjs/z-breadcrumb.cjs.entry.js +2 -2
  27. package/dist/cjs/z-card.cjs.entry.js +1 -1
  28. package/dist/cjs/z-carousel.cjs.entry.js +1 -1
  29. package/dist/cjs/z-chip.cjs.entry.js +1 -1
  30. package/dist/cjs/z-combobox.cjs.entry.js +2 -2
  31. package/dist/cjs/z-cover-hero.cjs.entry.js +1 -1
  32. package/dist/cjs/z-date-picker.cjs.entry.js +2 -2
  33. package/dist/cjs/z-dragdrop-area_2.cjs.entry.js +1 -1
  34. package/dist/cjs/z-file-upload.cjs.entry.js +1 -1
  35. package/dist/cjs/z-file.cjs.entry.js +1 -1
  36. package/dist/cjs/z-info-reveal.cjs.entry.js +1 -1
  37. package/dist/cjs/z-menu-section.cjs.entry.js +1 -1
  38. package/dist/cjs/z-menu.cjs.entry.js +2 -2
  39. package/dist/cjs/z-myz-card-alert.cjs.entry.js +1 -1
  40. package/dist/cjs/z-myz-card-dictionary.cjs.entry.js +1 -1
  41. package/dist/cjs/z-myz-card-footer.cjs.entry.js +1 -1
  42. package/dist/cjs/z-myz-card-info.cjs.entry.js +2 -2
  43. package/dist/cjs/z-myz-card_4.cjs.entry.js +1 -1
  44. package/dist/cjs/z-myz-list-item.cjs.entry.js +2 -2
  45. package/dist/cjs/z-navigation-tabs.cjs.entry.js +1 -1
  46. package/dist/cjs/z-otp.cjs.entry.js +1 -1
  47. package/dist/cjs/z-pagination.cjs.entry.js +1 -1
  48. package/dist/cjs/z-popover.cjs.entry.js +1 -1
  49. package/dist/cjs/z-range-picker.cjs.entry.js +2 -2
  50. package/dist/cjs/z-section-title.cjs.entry.js +1 -1
  51. package/dist/cjs/z-select.cjs.entry.js +187 -54
  52. package/dist/cjs/z-select.cjs.entry.js.map +1 -1
  53. package/dist/cjs/z-skip-to-content.cjs.entry.js +2 -2
  54. package/dist/cjs/z-slideshow.cjs.entry.js +2 -2
  55. package/dist/cjs/z-table.cjs.entry.js +5 -5
  56. package/dist/cjs/z-td.cjs.entry.js +2 -2
  57. package/dist/cjs/z-th.cjs.entry.js +2 -2
  58. package/dist/cjs/z-toast-notification-list.cjs.entry.js +1 -1
  59. package/dist/cjs/z-toast-notification.cjs.entry.js +1 -1
  60. package/dist/cjs/z-toggle-switch.cjs.entry.js +2 -2
  61. package/dist/cjs/z-tooltip.cjs.entry.js +1 -1
  62. package/dist/cjs/z-tr.cjs.entry.js +5 -5
  63. package/dist/collection/beans/index.js +1 -0
  64. package/dist/collection/beans/index.js.map +1 -1
  65. package/dist/collection/components/list/z-list/index.js +1 -1
  66. package/dist/collection/components/list/z-list-element/index.js +20 -2
  67. package/dist/collection/components/list/z-list-element/index.js.map +1 -1
  68. package/dist/collection/components/list/z-list-group/index.js +23 -4
  69. package/dist/collection/components/list/z-list-group/index.js.map +1 -1
  70. package/dist/collection/components/list/z-list-group/styles.css +5 -0
  71. package/dist/collection/components/z-select/index.js +203 -57
  72. package/dist/collection/components/z-select/index.js.map +1 -1
  73. package/dist/collection/components/z-select/index.stories.js +138 -0
  74. package/dist/collection/components/z-select/index.stories.js.map +1 -1
  75. package/dist/collection/components/z-select/styles.css +155 -0
  76. package/dist/components/index14.js +3 -1
  77. package/dist/components/index14.js.map +1 -1
  78. package/dist/components/index15.js +8 -5
  79. package/dist/components/index15.js.map +1 -1
  80. package/dist/components/index2.js +1 -0
  81. package/dist/components/index2.js.map +1 -1
  82. package/dist/components/z-select.js +187 -52
  83. package/dist/components/z-select.js.map +1 -1
  84. package/dist/esm/{index-735d4f23.js → index-5c567adb.js} +2 -2
  85. package/dist/esm/{index-735d4f23.js.map → index-5c567adb.js.map} +1 -1
  86. package/dist/esm/{index-ee40e66b.js → index-c9fd4a10.js} +2 -1
  87. package/dist/esm/index-c9fd4a10.js.map +1 -0
  88. package/dist/esm/{index-90f624c1.js → index-dac83244.js} +2 -2
  89. package/dist/esm/{index-90f624c1.js.map → index-dac83244.js.map} +1 -1
  90. package/dist/esm/{index-092fc7cc.js → index-f36946b3.js} +4 -4
  91. package/dist/esm/{index-092fc7cc.js.map → index-f36946b3.js.map} +1 -1
  92. package/dist/esm/index.js +2 -2
  93. package/dist/esm/loader.js +1 -1
  94. package/dist/esm/{utils-a31c16d9.js → utils-1a6a53d2.js} +2 -2
  95. package/dist/esm/{utils-a31c16d9.js.map → utils-1a6a53d2.js.map} +1 -1
  96. package/dist/esm/{utils-b924649f.js → utils-7774201b.js} +2 -2
  97. package/dist/esm/{utils-b924649f.js.map → utils-7774201b.js.map} +1 -1
  98. package/dist/esm/web-components-library.js +1 -1
  99. package/dist/esm/z-accordion.entry.js +1 -1
  100. package/dist/esm/z-anchor-navigation.entry.js +1 -1
  101. package/dist/esm/z-app-header-deprecated.entry.js +1 -1
  102. package/dist/esm/z-app-header_12.entry.js +10 -7
  103. package/dist/esm/z-app-header_12.entry.js.map +1 -1
  104. package/dist/esm/z-aria-alert.entry.js +1 -1
  105. package/dist/esm/z-avatar.entry.js +1 -1
  106. package/dist/esm/z-book-card-app.entry.js +1 -1
  107. package/dist/esm/z-book-card-deprecated.entry.js +2 -2
  108. package/dist/esm/z-book-card.entry.js +1 -1
  109. package/dist/esm/z-breadcrumb.entry.js +2 -2
  110. package/dist/esm/z-card.entry.js +1 -1
  111. package/dist/esm/z-carousel.entry.js +1 -1
  112. package/dist/esm/z-chip.entry.js +1 -1
  113. package/dist/esm/z-combobox.entry.js +2 -2
  114. package/dist/esm/z-cover-hero.entry.js +1 -1
  115. package/dist/esm/z-date-picker.entry.js +2 -2
  116. package/dist/esm/z-dragdrop-area_2.entry.js +1 -1
  117. package/dist/esm/z-file-upload.entry.js +1 -1
  118. package/dist/esm/z-file.entry.js +1 -1
  119. package/dist/esm/z-info-reveal.entry.js +1 -1
  120. package/dist/esm/z-menu-section.entry.js +1 -1
  121. package/dist/esm/z-menu.entry.js +2 -2
  122. package/dist/esm/z-myz-card-alert.entry.js +1 -1
  123. package/dist/esm/z-myz-card-dictionary.entry.js +1 -1
  124. package/dist/esm/z-myz-card-footer.entry.js +1 -1
  125. package/dist/esm/z-myz-card-info.entry.js +2 -2
  126. package/dist/esm/z-myz-card_4.entry.js +1 -1
  127. package/dist/esm/z-myz-list-item.entry.js +2 -2
  128. package/dist/esm/z-navigation-tabs.entry.js +1 -1
  129. package/dist/esm/z-otp.entry.js +1 -1
  130. package/dist/esm/z-pagination.entry.js +1 -1
  131. package/dist/esm/z-popover.entry.js +1 -1
  132. package/dist/esm/z-range-picker.entry.js +2 -2
  133. package/dist/esm/z-section-title.entry.js +1 -1
  134. package/dist/esm/z-select.entry.js +187 -54
  135. package/dist/esm/z-select.entry.js.map +1 -1
  136. package/dist/esm/z-skip-to-content.entry.js +2 -2
  137. package/dist/esm/z-slideshow.entry.js +2 -2
  138. package/dist/esm/z-table.entry.js +5 -5
  139. package/dist/esm/z-td.entry.js +2 -2
  140. package/dist/esm/z-th.entry.js +2 -2
  141. package/dist/esm/z-toast-notification-list.entry.js +1 -1
  142. package/dist/esm/z-toast-notification.entry.js +1 -1
  143. package/dist/esm/z-toggle-switch.entry.js +2 -2
  144. package/dist/esm/z-tooltip.entry.js +1 -1
  145. package/dist/esm/z-tr.entry.js +5 -5
  146. package/dist/types/beans/index.d.ts +3 -1
  147. package/dist/types/components/list/z-list-element/index.d.ts +4 -0
  148. package/dist/types/components/list/z-list-group/index.d.ts +4 -0
  149. package/dist/types/components/z-select/index.d.ts +12 -0
  150. package/dist/types/components/z-select/index.stories.d.ts +17 -0
  151. package/dist/types/components.d.ts +18 -0
  152. package/dist/web-components-library/index.esm.js +1 -1
  153. package/dist/web-components-library/{p-e691c0b8.js → p-010b6146.js} +2 -2
  154. package/{www/build/p-f06bd257.entry.js → dist/web-components-library/p-011fa0c8.entry.js} +2 -2
  155. package/dist/web-components-library/{p-2c450113.entry.js → p-0a149188.entry.js} +2 -2
  156. package/dist/web-components-library/{p-e5b1c34a.entry.js → p-0b8a7949.entry.js} +2 -2
  157. package/dist/web-components-library/p-0b8a7949.entry.js.map +1 -0
  158. package/dist/web-components-library/{p-f075ec62.entry.js → p-0d60cc5e.entry.js} +2 -2
  159. package/{www/build/p-bba6129f.js → dist/web-components-library/p-15aac7aa.js} +2 -2
  160. package/dist/web-components-library/{p-d6a2b1c6.entry.js → p-20e4a601.entry.js} +2 -2
  161. package/{www/build/p-1630e240.entry.js → dist/web-components-library/p-29a297ed.entry.js} +2 -2
  162. package/dist/web-components-library/p-2b309f57.js +2 -0
  163. package/dist/web-components-library/p-2b309f57.js.map +1 -0
  164. package/dist/web-components-library/{p-2a0d8ebe.entry.js → p-31c5b39d.entry.js} +2 -2
  165. package/dist/web-components-library/p-3243015c.entry.js +2 -0
  166. package/dist/web-components-library/{p-0df6b405.entry.js → p-475a2ba2.entry.js} +2 -2
  167. package/dist/web-components-library/p-4b29336e.entry.js +2 -0
  168. package/{www/build/p-bd571858.entry.js → dist/web-components-library/p-4c287a21.entry.js} +2 -2
  169. package/{www/build/p-18d63f0c.entry.js → dist/web-components-library/p-5b6dd467.entry.js} +2 -2
  170. package/dist/web-components-library/{p-e78353d6.entry.js → p-5bac684a.entry.js} +2 -2
  171. package/dist/web-components-library/{p-758333dc.entry.js → p-6279b3fc.entry.js} +2 -2
  172. package/{www/build/p-aa0b3e7a.entry.js → dist/web-components-library/p-6337614a.entry.js} +2 -2
  173. package/dist/web-components-library/{p-115fab3e.entry.js → p-6f5f2d56.entry.js} +2 -2
  174. package/{www/build/p-0d3f0534.entry.js → dist/web-components-library/p-7057d71f.entry.js} +2 -2
  175. package/dist/web-components-library/{p-395b261e.entry.js → p-7091a1fc.entry.js} +2 -2
  176. package/dist/web-components-library/{p-7f370d17.entry.js → p-71e2a48b.entry.js} +2 -2
  177. package/dist/web-components-library/{p-9e6d080f.entry.js → p-78626225.entry.js} +2 -2
  178. package/{www/build/p-14e61df6.js → dist/web-components-library/p-7b375bca.js} +2 -2
  179. package/dist/web-components-library/{p-7af33b00.entry.js → p-7cfe50d0.entry.js} +2 -2
  180. package/{www/build/p-4374d3f3.entry.js → dist/web-components-library/p-7ef2c4ce.entry.js} +2 -2
  181. package/dist/web-components-library/{p-9218da42.entry.js → p-7f0cbe57.entry.js} +2 -2
  182. package/dist/web-components-library/p-7fa29563.entry.js +2 -0
  183. package/dist/web-components-library/p-7fa29563.entry.js.map +1 -0
  184. package/{www/build/p-ed091723.entry.js → dist/web-components-library/p-898fcd66.entry.js} +2 -2
  185. package/{www/build/p-9c4b7a51.entry.js → dist/web-components-library/p-8adf58c8.entry.js} +2 -2
  186. package/dist/web-components-library/{p-c29a520b.entry.js → p-8ca50c86.entry.js} +2 -2
  187. package/dist/web-components-library/{p-11216ee8.entry.js → p-8e544914.entry.js} +2 -2
  188. package/dist/web-components-library/{p-50bf57b4.entry.js → p-8e6760d9.entry.js} +2 -2
  189. package/{www/build/p-75808b47.entry.js → dist/web-components-library/p-96be6eae.entry.js} +2 -2
  190. package/{www/build/p-aa42f01d.entry.js → dist/web-components-library/p-9ec778dc.entry.js} +2 -2
  191. package/dist/web-components-library/p-a4ddeb5f.entry.js +2 -0
  192. package/dist/web-components-library/{p-05f6053f.js → p-b22d3c7d.js} +2 -2
  193. package/dist/web-components-library/p-b539c9be.entry.js +2 -0
  194. package/{www/build/p-d1cca5ea.entry.js → dist/web-components-library/p-b7cf2442.entry.js} +2 -2
  195. package/dist/web-components-library/{p-11629dd3.entry.js → p-bbdb67db.entry.js} +2 -2
  196. package/dist/web-components-library/{p-5387e6f3.entry.js → p-c29bd399.entry.js} +2 -2
  197. package/{www/build/p-123739cb.js → dist/web-components-library/p-c3c99202.js} +2 -2
  198. package/dist/web-components-library/{p-8c952964.entry.js → p-c7f8b628.entry.js} +2 -2
  199. package/dist/web-components-library/{p-d28b352f.entry.js → p-cb34ca26.entry.js} +2 -2
  200. package/{www/build/p-52be7378.entry.js → dist/web-components-library/p-cc775eee.entry.js} +2 -2
  201. package/dist/web-components-library/{p-22e32e11.entry.js → p-cdc51108.entry.js} +2 -2
  202. package/{www/build/p-73d686e0.entry.js → dist/web-components-library/p-d29f9574.entry.js} +2 -2
  203. package/dist/web-components-library/{p-cf7b7e73.entry.js → p-f444b5bd.entry.js} +2 -2
  204. package/dist/web-components-library/{p-1e3ff105.entry.js → p-f49171aa.entry.js} +2 -2
  205. package/dist/web-components-library/{p-72dae90b.entry.js → p-f9fb6005.entry.js} +2 -2
  206. package/dist/web-components-library/{p-f8915e2e.entry.js → p-fc2b2a96.entry.js} +2 -2
  207. package/dist/web-components-library/web-components-library.esm.js +1 -1
  208. package/dist/web-components-library/web-components-library.esm.js.map +1 -1
  209. package/package.json +1 -1
  210. package/www/build/index.esm.js +1 -1
  211. package/www/build/{p-e691c0b8.js → p-010b6146.js} +2 -2
  212. package/{dist/web-components-library/p-f06bd257.entry.js → www/build/p-011fa0c8.entry.js} +2 -2
  213. package/www/build/{p-2c450113.entry.js → p-0a149188.entry.js} +2 -2
  214. package/www/build/{p-e5b1c34a.entry.js → p-0b8a7949.entry.js} +2 -2
  215. package/www/build/p-0b8a7949.entry.js.map +1 -0
  216. package/www/build/{p-f075ec62.entry.js → p-0d60cc5e.entry.js} +2 -2
  217. package/{dist/web-components-library/p-bba6129f.js → www/build/p-15aac7aa.js} +2 -2
  218. package/www/build/{p-d6a2b1c6.entry.js → p-20e4a601.entry.js} +2 -2
  219. package/{dist/web-components-library/p-1630e240.entry.js → www/build/p-29a297ed.entry.js} +2 -2
  220. package/www/build/p-2b309f57.js +2 -0
  221. package/www/build/p-2b309f57.js.map +1 -0
  222. package/www/build/{p-2a0d8ebe.entry.js → p-31c5b39d.entry.js} +2 -2
  223. package/www/build/p-3243015c.entry.js +2 -0
  224. package/www/build/{p-0df6b405.entry.js → p-475a2ba2.entry.js} +2 -2
  225. package/www/build/p-4b29336e.entry.js +2 -0
  226. package/{dist/web-components-library/p-bd571858.entry.js → www/build/p-4c287a21.entry.js} +2 -2
  227. package/www/build/p-549543a7.js +2 -0
  228. package/{dist/web-components-library/p-18d63f0c.entry.js → www/build/p-5b6dd467.entry.js} +2 -2
  229. package/www/build/{p-e78353d6.entry.js → p-5bac684a.entry.js} +2 -2
  230. package/www/build/{p-758333dc.entry.js → p-6279b3fc.entry.js} +2 -2
  231. package/{dist/web-components-library/p-aa0b3e7a.entry.js → www/build/p-6337614a.entry.js} +2 -2
  232. package/www/build/{p-115fab3e.entry.js → p-6f5f2d56.entry.js} +2 -2
  233. package/{dist/web-components-library/p-0d3f0534.entry.js → www/build/p-7057d71f.entry.js} +2 -2
  234. package/www/build/{p-395b261e.entry.js → p-7091a1fc.entry.js} +2 -2
  235. package/www/build/{p-7f370d17.entry.js → p-71e2a48b.entry.js} +2 -2
  236. package/www/build/{p-9e6d080f.entry.js → p-78626225.entry.js} +2 -2
  237. package/{dist/web-components-library/p-14e61df6.js → www/build/p-7b375bca.js} +2 -2
  238. package/www/build/{p-7af33b00.entry.js → p-7cfe50d0.entry.js} +2 -2
  239. package/{dist/web-components-library/p-4374d3f3.entry.js → www/build/p-7ef2c4ce.entry.js} +2 -2
  240. package/www/build/{p-9218da42.entry.js → p-7f0cbe57.entry.js} +2 -2
  241. package/www/build/p-7fa29563.entry.js +2 -0
  242. package/www/build/p-7fa29563.entry.js.map +1 -0
  243. package/{dist/web-components-library/p-ed091723.entry.js → www/build/p-898fcd66.entry.js} +2 -2
  244. package/{dist/web-components-library/p-9c4b7a51.entry.js → www/build/p-8adf58c8.entry.js} +2 -2
  245. package/www/build/{p-c29a520b.entry.js → p-8ca50c86.entry.js} +2 -2
  246. package/www/build/{p-11216ee8.entry.js → p-8e544914.entry.js} +2 -2
  247. package/www/build/{p-50bf57b4.entry.js → p-8e6760d9.entry.js} +2 -2
  248. package/{dist/web-components-library/p-75808b47.entry.js → www/build/p-96be6eae.entry.js} +2 -2
  249. package/{dist/web-components-library/p-aa42f01d.entry.js → www/build/p-9ec778dc.entry.js} +2 -2
  250. package/www/build/p-a4ddeb5f.entry.js +2 -0
  251. package/www/build/{p-05f6053f.js → p-b22d3c7d.js} +2 -2
  252. package/www/build/p-b539c9be.entry.js +2 -0
  253. package/{dist/web-components-library/p-d1cca5ea.entry.js → www/build/p-b7cf2442.entry.js} +2 -2
  254. package/www/build/{p-11629dd3.entry.js → p-bbdb67db.entry.js} +2 -2
  255. package/www/build/{p-5387e6f3.entry.js → p-c29bd399.entry.js} +2 -2
  256. package/{dist/web-components-library/p-123739cb.js → www/build/p-c3c99202.js} +2 -2
  257. package/www/build/{p-8c952964.entry.js → p-c7f8b628.entry.js} +2 -2
  258. package/www/build/{p-d28b352f.entry.js → p-cb34ca26.entry.js} +2 -2
  259. package/{dist/web-components-library/p-52be7378.entry.js → www/build/p-cc775eee.entry.js} +2 -2
  260. package/www/build/{p-22e32e11.entry.js → p-cdc51108.entry.js} +2 -2
  261. package/{dist/web-components-library/p-73d686e0.entry.js → www/build/p-d29f9574.entry.js} +2 -2
  262. package/www/build/{p-cf7b7e73.entry.js → p-f444b5bd.entry.js} +2 -2
  263. package/www/build/{p-1e3ff105.entry.js → p-f49171aa.entry.js} +2 -2
  264. package/www/build/{p-72dae90b.entry.js → p-f9fb6005.entry.js} +2 -2
  265. package/www/build/{p-f8915e2e.entry.js → p-fc2b2a96.entry.js} +2 -2
  266. package/www/build/web-components-library.esm.js +1 -1
  267. package/www/build/web-components-library.esm.js.map +1 -1
  268. package/www/index.html +1 -1
  269. package/dist/cjs/index-f5ebcaa2.js.map +0 -1
  270. package/dist/esm/index-ee40e66b.js.map +0 -1
  271. package/dist/web-components-library/p-2798c0b2.entry.js +0 -2
  272. package/dist/web-components-library/p-ad825740.entry.js +0 -2
  273. package/dist/web-components-library/p-b34993de.js +0 -2
  274. package/dist/web-components-library/p-b34993de.js.map +0 -1
  275. package/dist/web-components-library/p-d65aba93.entry.js +0 -2
  276. package/dist/web-components-library/p-e185545c.entry.js +0 -2
  277. package/dist/web-components-library/p-e256027a.entry.js +0 -2
  278. package/dist/web-components-library/p-e256027a.entry.js.map +0 -1
  279. package/dist/web-components-library/p-e5b1c34a.entry.js.map +0 -1
  280. package/www/build/p-2798c0b2.entry.js +0 -2
  281. package/www/build/p-ad825740.entry.js +0 -2
  282. package/www/build/p-b34993de.js +0 -2
  283. package/www/build/p-b34993de.js.map +0 -1
  284. package/www/build/p-bac5085b.js +0 -2
  285. package/www/build/p-d65aba93.entry.js +0 -2
  286. package/www/build/p-e185545c.entry.js +0 -2
  287. package/www/build/p-e256027a.entry.js +0 -2
  288. package/www/build/p-e256027a.entry.js.map +0 -1
  289. package/www/build/p-e5b1c34a.entry.js.map +0 -1
  290. /package/dist/web-components-library/{p-e691c0b8.js.map → p-010b6146.js.map} +0 -0
  291. /package/dist/web-components-library/{p-f06bd257.entry.js.map → p-011fa0c8.entry.js.map} +0 -0
  292. /package/dist/web-components-library/{p-2c450113.entry.js.map → p-0a149188.entry.js.map} +0 -0
  293. /package/dist/web-components-library/{p-f075ec62.entry.js.map → p-0d60cc5e.entry.js.map} +0 -0
  294. /package/dist/web-components-library/{p-bba6129f.js.map → p-15aac7aa.js.map} +0 -0
  295. /package/dist/web-components-library/{p-d6a2b1c6.entry.js.map → p-20e4a601.entry.js.map} +0 -0
  296. /package/dist/web-components-library/{p-1630e240.entry.js.map → p-29a297ed.entry.js.map} +0 -0
  297. /package/dist/web-components-library/{p-2a0d8ebe.entry.js.map → p-31c5b39d.entry.js.map} +0 -0
  298. /package/dist/web-components-library/{p-d65aba93.entry.js.map → p-3243015c.entry.js.map} +0 -0
  299. /package/dist/web-components-library/{p-0df6b405.entry.js.map → p-475a2ba2.entry.js.map} +0 -0
  300. /package/dist/web-components-library/{p-2798c0b2.entry.js.map → p-4b29336e.entry.js.map} +0 -0
  301. /package/dist/web-components-library/{p-bd571858.entry.js.map → p-4c287a21.entry.js.map} +0 -0
  302. /package/dist/web-components-library/{p-18d63f0c.entry.js.map → p-5b6dd467.entry.js.map} +0 -0
  303. /package/dist/web-components-library/{p-e78353d6.entry.js.map → p-5bac684a.entry.js.map} +0 -0
  304. /package/dist/web-components-library/{p-758333dc.entry.js.map → p-6279b3fc.entry.js.map} +0 -0
  305. /package/dist/web-components-library/{p-aa0b3e7a.entry.js.map → p-6337614a.entry.js.map} +0 -0
  306. /package/dist/web-components-library/{p-115fab3e.entry.js.map → p-6f5f2d56.entry.js.map} +0 -0
  307. /package/dist/web-components-library/{p-0d3f0534.entry.js.map → p-7057d71f.entry.js.map} +0 -0
  308. /package/dist/web-components-library/{p-395b261e.entry.js.map → p-7091a1fc.entry.js.map} +0 -0
  309. /package/dist/web-components-library/{p-7f370d17.entry.js.map → p-71e2a48b.entry.js.map} +0 -0
  310. /package/dist/web-components-library/{p-9e6d080f.entry.js.map → p-78626225.entry.js.map} +0 -0
  311. /package/dist/web-components-library/{p-14e61df6.js.map → p-7b375bca.js.map} +0 -0
  312. /package/dist/web-components-library/{p-7af33b00.entry.js.map → p-7cfe50d0.entry.js.map} +0 -0
  313. /package/dist/web-components-library/{p-4374d3f3.entry.js.map → p-7ef2c4ce.entry.js.map} +0 -0
  314. /package/dist/web-components-library/{p-9218da42.entry.js.map → p-7f0cbe57.entry.js.map} +0 -0
  315. /package/dist/web-components-library/{p-ed091723.entry.js.map → p-898fcd66.entry.js.map} +0 -0
  316. /package/dist/web-components-library/{p-9c4b7a51.entry.js.map → p-8adf58c8.entry.js.map} +0 -0
  317. /package/dist/web-components-library/{p-c29a520b.entry.js.map → p-8ca50c86.entry.js.map} +0 -0
  318. /package/dist/web-components-library/{p-11216ee8.entry.js.map → p-8e544914.entry.js.map} +0 -0
  319. /package/dist/web-components-library/{p-50bf57b4.entry.js.map → p-8e6760d9.entry.js.map} +0 -0
  320. /package/dist/web-components-library/{p-75808b47.entry.js.map → p-96be6eae.entry.js.map} +0 -0
  321. /package/dist/web-components-library/{p-aa42f01d.entry.js.map → p-9ec778dc.entry.js.map} +0 -0
  322. /package/dist/web-components-library/{p-ad825740.entry.js.map → p-a4ddeb5f.entry.js.map} +0 -0
  323. /package/dist/web-components-library/{p-05f6053f.js.map → p-b22d3c7d.js.map} +0 -0
  324. /package/dist/web-components-library/{p-e185545c.entry.js.map → p-b539c9be.entry.js.map} +0 -0
  325. /package/dist/web-components-library/{p-d1cca5ea.entry.js.map → p-b7cf2442.entry.js.map} +0 -0
  326. /package/dist/web-components-library/{p-11629dd3.entry.js.map → p-bbdb67db.entry.js.map} +0 -0
  327. /package/dist/web-components-library/{p-5387e6f3.entry.js.map → p-c29bd399.entry.js.map} +0 -0
  328. /package/dist/web-components-library/{p-123739cb.js.map → p-c3c99202.js.map} +0 -0
  329. /package/dist/web-components-library/{p-8c952964.entry.js.map → p-c7f8b628.entry.js.map} +0 -0
  330. /package/dist/web-components-library/{p-d28b352f.entry.js.map → p-cb34ca26.entry.js.map} +0 -0
  331. /package/dist/web-components-library/{p-52be7378.entry.js.map → p-cc775eee.entry.js.map} +0 -0
  332. /package/dist/web-components-library/{p-22e32e11.entry.js.map → p-cdc51108.entry.js.map} +0 -0
  333. /package/dist/web-components-library/{p-73d686e0.entry.js.map → p-d29f9574.entry.js.map} +0 -0
  334. /package/dist/web-components-library/{p-cf7b7e73.entry.js.map → p-f444b5bd.entry.js.map} +0 -0
  335. /package/dist/web-components-library/{p-1e3ff105.entry.js.map → p-f49171aa.entry.js.map} +0 -0
  336. /package/dist/web-components-library/{p-72dae90b.entry.js.map → p-f9fb6005.entry.js.map} +0 -0
  337. /package/dist/web-components-library/{p-f8915e2e.entry.js.map → p-fc2b2a96.entry.js.map} +0 -0
  338. /package/www/build/{p-e691c0b8.js.map → p-010b6146.js.map} +0 -0
  339. /package/www/build/{p-f06bd257.entry.js.map → p-011fa0c8.entry.js.map} +0 -0
  340. /package/www/build/{p-2c450113.entry.js.map → p-0a149188.entry.js.map} +0 -0
  341. /package/www/build/{p-f075ec62.entry.js.map → p-0d60cc5e.entry.js.map} +0 -0
  342. /package/www/build/{p-bba6129f.js.map → p-15aac7aa.js.map} +0 -0
  343. /package/www/build/{p-d6a2b1c6.entry.js.map → p-20e4a601.entry.js.map} +0 -0
  344. /package/www/build/{p-1630e240.entry.js.map → p-29a297ed.entry.js.map} +0 -0
  345. /package/www/build/{p-2a0d8ebe.entry.js.map → p-31c5b39d.entry.js.map} +0 -0
  346. /package/www/build/{p-d65aba93.entry.js.map → p-3243015c.entry.js.map} +0 -0
  347. /package/www/build/{p-0df6b405.entry.js.map → p-475a2ba2.entry.js.map} +0 -0
  348. /package/www/build/{p-2798c0b2.entry.js.map → p-4b29336e.entry.js.map} +0 -0
  349. /package/www/build/{p-bd571858.entry.js.map → p-4c287a21.entry.js.map} +0 -0
  350. /package/www/build/{p-18d63f0c.entry.js.map → p-5b6dd467.entry.js.map} +0 -0
  351. /package/www/build/{p-e78353d6.entry.js.map → p-5bac684a.entry.js.map} +0 -0
  352. /package/www/build/{p-758333dc.entry.js.map → p-6279b3fc.entry.js.map} +0 -0
  353. /package/www/build/{p-aa0b3e7a.entry.js.map → p-6337614a.entry.js.map} +0 -0
  354. /package/www/build/{p-115fab3e.entry.js.map → p-6f5f2d56.entry.js.map} +0 -0
  355. /package/www/build/{p-0d3f0534.entry.js.map → p-7057d71f.entry.js.map} +0 -0
  356. /package/www/build/{p-395b261e.entry.js.map → p-7091a1fc.entry.js.map} +0 -0
  357. /package/www/build/{p-7f370d17.entry.js.map → p-71e2a48b.entry.js.map} +0 -0
  358. /package/www/build/{p-9e6d080f.entry.js.map → p-78626225.entry.js.map} +0 -0
  359. /package/www/build/{p-14e61df6.js.map → p-7b375bca.js.map} +0 -0
  360. /package/www/build/{p-7af33b00.entry.js.map → p-7cfe50d0.entry.js.map} +0 -0
  361. /package/www/build/{p-4374d3f3.entry.js.map → p-7ef2c4ce.entry.js.map} +0 -0
  362. /package/www/build/{p-9218da42.entry.js.map → p-7f0cbe57.entry.js.map} +0 -0
  363. /package/www/build/{p-ed091723.entry.js.map → p-898fcd66.entry.js.map} +0 -0
  364. /package/www/build/{p-9c4b7a51.entry.js.map → p-8adf58c8.entry.js.map} +0 -0
  365. /package/www/build/{p-c29a520b.entry.js.map → p-8ca50c86.entry.js.map} +0 -0
  366. /package/www/build/{p-11216ee8.entry.js.map → p-8e544914.entry.js.map} +0 -0
  367. /package/www/build/{p-50bf57b4.entry.js.map → p-8e6760d9.entry.js.map} +0 -0
  368. /package/www/build/{p-75808b47.entry.js.map → p-96be6eae.entry.js.map} +0 -0
  369. /package/www/build/{p-aa42f01d.entry.js.map → p-9ec778dc.entry.js.map} +0 -0
  370. /package/www/build/{p-ad825740.entry.js.map → p-a4ddeb5f.entry.js.map} +0 -0
  371. /package/www/build/{p-05f6053f.js.map → p-b22d3c7d.js.map} +0 -0
  372. /package/www/build/{p-e185545c.entry.js.map → p-b539c9be.entry.js.map} +0 -0
  373. /package/www/build/{p-d1cca5ea.entry.js.map → p-b7cf2442.entry.js.map} +0 -0
  374. /package/www/build/{p-11629dd3.entry.js.map → p-bbdb67db.entry.js.map} +0 -0
  375. /package/www/build/{p-5387e6f3.entry.js.map → p-c29bd399.entry.js.map} +0 -0
  376. /package/www/build/{p-123739cb.js.map → p-c3c99202.js.map} +0 -0
  377. /package/www/build/{p-8c952964.entry.js.map → p-c7f8b628.entry.js.map} +0 -0
  378. /package/www/build/{p-d28b352f.entry.js.map → p-cb34ca26.entry.js.map} +0 -0
  379. /package/www/build/{p-52be7378.entry.js.map → p-cc775eee.entry.js.map} +0 -0
  380. /package/www/build/{p-22e32e11.entry.js.map → p-cdc51108.entry.js.map} +0 -0
  381. /package/www/build/{p-73d686e0.entry.js.map → p-d29f9574.entry.js.map} +0 -0
  382. /package/www/build/{p-cf7b7e73.entry.js.map → p-f444b5bd.entry.js.map} +0 -0
  383. /package/www/build/{p-1e3ff105.entry.js.map → p-f49171aa.entry.js.map} +0 -0
  384. /package/www/build/{p-72dae90b.entry.js.map → p-f9fb6005.entry.js.map} +0 -0
  385. /package/www/build/{p-f8915e2e.entry.js.map → p-fc2b2a96.entry.js.map} +0 -0
@@ -4,6 +4,8 @@ import { boolean, containsElement, getClickedElement, handleKeyboardSubmit, rand
4
4
  export class ZSelect {
5
5
  constructor() {
6
6
  this.itemsList = [];
7
+ this.itemIdKeyMap = {};
8
+ this.resetKey = -1;
7
9
  this.htmlid = `id-${randomId()}`;
8
10
  this.items = undefined;
9
11
  this.name = undefined;
@@ -18,6 +20,7 @@ export class ZSelect {
18
20
  this.autocomplete = false;
19
21
  this.noresultslabel = "Nessun risultato";
20
22
  this.hasGroupItems = undefined;
23
+ this.hasTreeItems = undefined;
21
24
  this.isfixed = false;
22
25
  this.resetItem = undefined;
23
26
  this.size = ControlSize.BIG;
@@ -25,12 +28,18 @@ export class ZSelect {
25
28
  this.selectedItem = null;
26
29
  this.focusedItemId = undefined;
27
30
  this.searchString = undefined;
31
+ this.flattenedList = [];
28
32
  this.toggleSelectUl = this.toggleSelectUl.bind(this);
29
33
  this.handleSelectFocus = this.handleSelectFocus.bind(this);
30
34
  }
31
35
  watchItems() {
32
36
  this.itemsList = this.getInitialItemsArray();
33
- this.selectedItem = this.itemsList.find((item) => item.selected);
37
+ this.selectedItem = this.findSelectedItem(this.itemsList);
38
+ this.flattenedList = this.flattenTreeItems(this.itemsList);
39
+ this.itemIdKeyMap = {};
40
+ this.flattenedList.forEach(({ item, key }) => {
41
+ this.itemIdKeyMap[item.id] = key;
42
+ });
34
43
  }
35
44
  getFocusedItemHandler(e) {
36
45
  this.focusedItemId = e.target.id;
@@ -52,7 +61,11 @@ export class ZSelect {
52
61
  else {
53
62
  values = value;
54
63
  }
55
- this.selectedItem = this.itemsList.find((item) => values.includes(item.id));
64
+ this.itemsList = this.getInitialItemsArray();
65
+ if (values.length) {
66
+ this.updateSelection(this.itemsList, values[0]);
67
+ }
68
+ this.selectedItem = this.findSelectedItem(this.itemsList);
56
69
  }
57
70
  emitOptionSelect() {
58
71
  this.optionSelect.emit({
@@ -90,23 +103,48 @@ export class ZSelect {
90
103
  const prevList = this.mapSelectedItemToItemsArray();
91
104
  if (!(searchString === null || searchString === void 0 ? void 0 : searchString.length)) {
92
105
  this.itemsList = prevList;
106
+ return;
107
+ }
108
+ if (this.hasTreeItems) {
109
+ this.itemsList = this.filterTree(prevList, searchString);
93
110
  }
94
111
  else {
95
112
  this.itemsList = prevList
96
- .filter((item) => {
97
- return item.name.toUpperCase().includes(searchString.toUpperCase());
98
- })
113
+ .filter((item) => item.name.toUpperCase().includes(searchString.toUpperCase()))
99
114
  .map((item) => {
100
- const start = item.name.toUpperCase().indexOf(searchString.toUpperCase());
101
- const end = start + searchString.length;
102
- const newName = item.name.substring(0, start) +
103
- `<strong>${item.name.substring(start, end)}</strong>` +
104
- item.name.substring(end, item.name.length);
105
- item.name = newName;
115
+ item.name = this.getHighlightedText(item.name, searchString);
106
116
  return item;
107
117
  });
108
118
  }
109
119
  }
120
+ filterTree(items, searchString) {
121
+ return items
122
+ .map((item) => {
123
+ const match = item.name.toUpperCase().includes(searchString.toUpperCase());
124
+ const newItem = Object.assign({}, item);
125
+ if (newItem.children && newItem.children.length > 0) {
126
+ newItem.children = this.filterTree(newItem.children, searchString);
127
+ }
128
+ if (match) {
129
+ newItem.name = this.getHighlightedText(newItem.name, searchString);
130
+ }
131
+ if (match || (newItem.children && newItem.children.length > 0)) {
132
+ return newItem;
133
+ }
134
+ return null;
135
+ })
136
+ .filter((item) => item !== null);
137
+ }
138
+ getHighlightedText(text, search) {
139
+ const upperText = text.toUpperCase();
140
+ const upperSearch = search.toUpperCase();
141
+ const start = upperText.indexOf(upperSearch);
142
+ if (start === -1) {
143
+ return text;
144
+ }
145
+ const end = start + search.length;
146
+ return text.substring(0, start) + `<strong>${text.substring(start, end)}</strong>` + text.substring(end);
147
+ }
110
148
  hasAutocomplete() {
111
149
  return boolean(this.autocomplete) === true;
112
150
  }
@@ -116,23 +154,58 @@ export class ZSelect {
116
154
  this.toggleSelectUl();
117
155
  }
118
156
  }
157
+ updateSelection(items, selectedId) {
158
+ items.forEach((item) => {
159
+ item.selected = item.id === selectedId;
160
+ if (item.children && item.children.length > 0) {
161
+ this.updateSelection(item.children, selectedId);
162
+ }
163
+ });
164
+ }
165
+ findSelectedItem(items) {
166
+ for (const item of items) {
167
+ if (item.selected) {
168
+ return item;
169
+ }
170
+ if (item.children && item.children.length > 0) {
171
+ const found = this.findSelectedItem(item.children);
172
+ if (found) {
173
+ return found;
174
+ }
175
+ }
176
+ }
177
+ return null;
178
+ }
119
179
  selectItem(selected) {
120
180
  if (selected === null || selected === void 0 ? void 0 : selected.disabled) {
121
181
  return;
122
182
  }
123
- this.itemsList = this.mapSelectedItemToItemsArray();
124
- this.itemsList.forEach((i) => {
125
- i.selected = i.id === (selected === null || selected === void 0 ? void 0 : selected.id);
126
- return i;
127
- });
128
- this.selectedItem = this.itemsList.find((item) => item.selected);
183
+ this.itemsList = this.getInitialItemsArray();
184
+ if (selected) {
185
+ this.updateSelection(this.itemsList, selected.id);
186
+ }
187
+ this.selectedItem = this.findSelectedItem(this.itemsList);
129
188
  this.emitOptionSelect();
130
189
  this.toggleSelectUl(true);
131
190
  if (this.searchString) {
132
191
  this.searchString = null;
133
192
  }
134
193
  }
135
- arrowsSelectNav(e, key) {
194
+ flattenTreeItems(items) {
195
+ const flatItems = [];
196
+ let index = 0;
197
+ function flatten(subItems) {
198
+ subItems.forEach((itm) => {
199
+ flatItems.push({ item: itm, key: index++ });
200
+ if (itm.children && itm.children.length > 0) {
201
+ flatten(itm.children);
202
+ }
203
+ });
204
+ }
205
+ flatten(items);
206
+ return flatItems;
207
+ }
208
+ arrowsSelectNav(e, idOrReset) {
136
209
  const showResetIcon = this.resetItem && !!this.selectedItem;
137
210
  const arrows = [KeyboardCode.ARROW_DOWN, KeyboardCode.ARROW_UP];
138
211
  if (!arrows.includes(e.key)) {
@@ -140,33 +213,43 @@ export class ZSelect {
140
213
  }
141
214
  e.preventDefault();
142
215
  e.stopPropagation();
216
+ const flatItems = [...this.flattenedList];
217
+ if (this.resetItem && showResetIcon) {
218
+ flatItems.unshift({
219
+ item: { id: "__RESET_ITEM__" },
220
+ key: this.resetKey,
221
+ });
222
+ }
223
+ let currentIndex;
224
+ if (typeof idOrReset === "number") {
225
+ currentIndex = flatItems.findIndex((f) => f.key === idOrReset);
226
+ }
227
+ else {
228
+ const k = this.itemIdKeyMap[idOrReset];
229
+ currentIndex = flatItems.findIndex((f) => f.key === k);
230
+ }
143
231
  if (!this.isOpen) {
144
232
  this.toggleSelectUl();
145
- }
146
- let index;
147
- if (this.resetItem) {
148
- if (e.key === KeyboardCode.ARROW_DOWN) {
149
- index = key + 1 === this.itemsList.length + 1 ? +!showResetIcon : key + 1;
150
- }
151
- else if (e.key === KeyboardCode.ARROW_UP) {
152
- index = key <= +!showResetIcon ? this.itemsList.length : key - 1;
233
+ if (currentIndex === -1) {
234
+ currentIndex = -1;
153
235
  }
154
236
  }
155
- if (!this.resetItem) {
156
- if (e.key === KeyboardCode.ARROW_DOWN) {
157
- index = key + 1 === this.itemsList.length ? 0 : key + 1;
158
- }
159
- else if (e.key === KeyboardCode.ARROW_UP) {
160
- index = key <= 0 ? this.itemsList.length - 1 : key - 1;
161
- }
237
+ const lastIndex = flatItems.length - 1;
238
+ let newIndex = currentIndex;
239
+ if (e.key === KeyboardCode.ARROW_DOWN) {
240
+ newIndex = currentIndex === lastIndex ? 0 : currentIndex + 1;
241
+ }
242
+ else {
243
+ newIndex = currentIndex <= 0 ? lastIndex : currentIndex - 1;
162
244
  }
163
- this.focusSelectItem(index);
245
+ this.focusSelectItem(flatItems[newIndex].key);
164
246
  }
165
- focusSelectItem(index) {
247
+ focusSelectItem(key) {
166
248
  var _a;
167
- (_a = this.host.querySelector(`#${this.htmlid}_${index}`)) === null || _a === void 0 ? void 0 : _a.focus();
249
+ (_a = this.host.querySelector(`#${this.htmlid}_key_${key}`)) === null || _a === void 0 ? void 0 : _a.focus();
168
250
  }
169
251
  toggleSelectUl(selfFocusOnClose = false) {
252
+ var _a;
170
253
  if (this.disabled || this.readonly) {
171
254
  return;
172
255
  }
@@ -178,7 +261,7 @@ export class ZSelect {
178
261
  document.removeEventListener("click", this.handleSelectFocus);
179
262
  document.removeEventListener("keyup", this.handleSelectFocus);
180
263
  if (selfFocusOnClose) {
181
- this.host.querySelector(`#${this.htmlid}_input`).focus();
264
+ (_a = this.host.querySelector(`#${this.htmlid}_input`)) === null || _a === void 0 ? void 0 : _a.focus();
182
265
  }
183
266
  }
184
267
  this.focusedItemId = "";
@@ -210,7 +293,7 @@ export class ZSelect {
210
293
  scrollToLetter(letter) {
211
294
  const foundItem = this.itemsList.findIndex((item) => item.name.charAt(0) === letter);
212
295
  if (foundItem > -1) {
213
- this.focusSelectItem(foundItem);
296
+ this.focusSelectItem(this.itemIdKeyMap[this.itemsList[foundItem].id]);
214
297
  }
215
298
  }
216
299
  renderInput() {
@@ -225,7 +308,12 @@ export class ZSelect {
225
308
  }
226
309
  handleKeyboardSubmit(e, this.toggleSelectUl);
227
310
  }, onKeyDown: (e) => {
228
- return this.arrowsSelectNav(e, this.selectedItem ? this.itemsList.indexOf(this.selectedItem) : this.resetItem ? 0 : -1);
311
+ const current = this.selectedItem
312
+ ? this.itemIdKeyMap[this.selectedItem.id]
313
+ : this.resetItem
314
+ ? this.resetKey
315
+ : "";
316
+ return this.arrowsSelectNav(e, current);
229
317
  }, onInputChange: (e) => {
230
318
  this.handleInputChange(e);
231
319
  }, onKeyPress: (e) => {
@@ -251,35 +339,81 @@ export class ZSelect {
251
339
  "hide": !this.selectedItem || !this.resetItem,
252
340
  "reset-item": true,
253
341
  "reset-item-margin": !this.hasGroupItems,
254
- }, clickable: true, disabled: false, dividerType: ListDividerType.ELEMENT, role: "option", tabindex: "0", "aria-selected": "false", id: `${this.htmlid}_${this.resetItem ? "0" : "none"}`, size: this.listSizeType(), onClickItem: () => {
342
+ }, clickable: true, disabled: false, dividerType: ListDividerType.ELEMENT, role: "option", tabindex: "0", "aria-selected": "false", id: `${this.htmlid}_key_${this.resetKey}`, size: this.hasTreeItems ? ListSize.MEDIUM : this.listSizeType(), onClickItem: () => {
255
343
  this.selectedItem = null;
256
344
  this.searchString = null;
257
345
  this.emitResetSelect();
258
- }, onKeyDown: (e) => this.arrowsSelectNav(e, 0) }, h("div", { class: "reset-item-content" }, h("z-icon", { name: "multiply-circled" }), h("span", null, this.resetItem))));
259
- }
260
- renderItem(item, key, lastItem) {
261
- return (h("z-list-element", { clickable: !item.disabled, disabled: item.disabled, dividerType: lastItem ? ListDividerType.HEADER : ListDividerType.ELEMENT, role: "option", tabindex: item.disabled || !this.isOpen ? -1 : 0, "aria-selected": item.selected ? "true" : "false", id: `${this.htmlid}_${key}`, size: this.listSizeType(), onClickItem: () => this.selectItem(item), onKeyDown: (e) => this.arrowsSelectNav(e, key) }, h("div", { class: "list-element-container" }, h("div", { class: {
346
+ }, onKeyDown: (e) => this.arrowsSelectNav(e, this.resetKey) }, h("div", { class: {
347
+ "reset-item-content": true,
348
+ "tree-list-reset-item": this.hasTreeItems,
349
+ } }, h("z-icon", { name: "multiply-circled" }), h("span", null, this.resetItem))));
350
+ }
351
+ renderItem(item, lastItem) {
352
+ const thisItemKey = this.itemIdKeyMap[item.id];
353
+ return (h("z-list-element", { clickable: !item.disabled, disabled: item.disabled, dividerType: lastItem ? ListDividerType.HEADER : ListDividerType.ELEMENT, role: "option", tabindex: item.disabled || !this.isOpen ? -1 : 0, "aria-selected": item.selected ? "true" : "false", id: `${this.htmlid}_key_${thisItemKey}`, size: this.listSizeType(), onClickItem: () => this.selectItem(item), onKeyDown: (e) => this.arrowsSelectNav(e, thisItemKey) }, h("div", { class: "list-element-container" }, h("div", { class: {
262
354
  "selected": !!item.selected,
263
355
  "list-element-content": true,
264
356
  }, innerHTML: item.name }), item.icon && h("z-tag", { icon: item.icon }))));
265
357
  }
266
358
  listSizeType() {
359
+ if (this.hasTreeItems) {
360
+ return ListSize.NONE;
361
+ }
267
362
  if (this.size === ControlSize.SMALL || this.size === ControlSize.X_SMALL) {
268
363
  return ListSize.SMALL;
269
364
  }
270
365
  return ListSize.MEDIUM;
271
366
  }
367
+ //eslint-disable-next-line
272
368
  renderSelectUlItems() {
273
369
  if (!this.itemsList.length) {
274
370
  return this.renderNoSearchResults();
275
371
  }
276
- if (this.hasGroupItems) {
372
+ if (this.hasGroupItems && !this.hasTreeItems) {
277
373
  return this.renderSelectGroupItems();
278
374
  }
375
+ else if (this.hasGroupItems && this.hasTreeItems) {
376
+ return this.renderGroupedTree();
377
+ }
279
378
  return this.itemsList.map((item, key, array) => {
280
379
  const lastItem = array.length === key + 1;
281
- const itemKey = this.resetItem ? key + 1 : key;
282
- return this.renderItem(item, itemKey, lastItem);
380
+ if (this.hasTreeItems) {
381
+ return this.renderTreeItems(item, lastItem);
382
+ }
383
+ return this.renderItem(item, lastItem);
384
+ });
385
+ }
386
+ renderTreeItems(item, divider) {
387
+ var _a, _b;
388
+ const hasDivider = divider && !((_a = item.children) === null || _a === void 0 ? void 0 : _a.length);
389
+ const thisItemKey = this.itemIdKeyMap[item.id];
390
+ return (h("z-list-element", { class: {
391
+ "grouped-tree-parent-node": this.hasGroupItems && !!((_b = item.children) === null || _b === void 0 ? void 0 : _b.length),
392
+ }, size: this.listSizeType(), dividerType: hasDivider ? ListDividerType.ELEMENT : undefined, hasTreeItems: this.hasTreeItems }, h("div", { id: `${this.htmlid}_key_${thisItemKey}`, role: "option", class: "list-element", tabIndex: 0, onClick: () => this.selectItem(item), onKeyDown: (e) => {
393
+ this.arrowsSelectNav(e, thisItemKey);
394
+ if (e.key === KeyboardCode.ENTER) {
395
+ this.selectItem(item);
396
+ }
397
+ }, onMouseEnter: (e) => {
398
+ const currentElement = e.target;
399
+ currentElement.classList.add("hovered");
400
+ }, onMouseLeave: (e) => {
401
+ const currentElement = e.target;
402
+ currentElement.classList.contains("hovered") && currentElement.classList.remove("hovered");
403
+ } }, h("span", { class: "item ellipsis" }, (item === null || item === void 0 ? void 0 : item.icon) && (h("z-icon", { class: "item-icon", name: item.icon })), h("span", { class: {
404
+ "item-label": true,
405
+ "selected": !!item.selected,
406
+ }, title: item.name, innerHTML: item.name })), item.icon && h("z-tag", { icon: item.icon })), item.children && item.children.length > 0 ? (h("z-list", null, h("div", { class: "children-node" }, item.children.map((child, index, arr) => this.renderTreeItems(child, index === arr.length - 1))))) : null));
407
+ }
408
+ renderGroupedTree() {
409
+ const grouped = this.itemsList.reduce((acc, item) => {
410
+ const category = item.category || "Altra categoria";
411
+ acc[category] = acc[category] || [];
412
+ acc[category].push(item);
413
+ return acc;
414
+ }, {});
415
+ return Object.entries(grouped).map(([category, items]) => {
416
+ return (h("z-list-group", { "divider-type": ListDividerType.ELEMENT, hasTreeItems: true }, h("span", { class: "body-3-sb z-list-group-title", slot: "header-title" }, category), h("z-list", null, items.map((item, i, arr) => this.renderTreeItems(item, i === arr.length - 1)))));
283
417
  });
284
418
  }
285
419
  renderSelectGroupItems() {
@@ -287,8 +421,7 @@ export class ZSelect {
287
421
  var _a;
288
422
  const { category } = item;
289
423
  const lastItem = array.length === index + 1;
290
- const itemKey = this.resetItem ? index + 1 : index;
291
- const zListItem = this.renderItem(item, itemKey, lastItem);
424
+ const zListItem = this.renderItem(item, lastItem);
292
425
  group[category] = (_a = group[category]) !== null && _a !== void 0 ? _a : [];
293
426
  group[category].push(zListItem);
294
427
  return group;
@@ -298,7 +431,7 @@ export class ZSelect {
298
431
  });
299
432
  }
300
433
  renderNoSearchResults() {
301
- return (h("z-list-element", { color: "color-primary01", class: "no-results", size: this.listSizeType() }, h("z-icon", { name: "multiply-circle", fill: "color-primary01-icon" }), this.noresultslabel));
434
+ return (h("z-list-element", { color: "color-primary01", class: "no-results", size: this.hasTreeItems ? ListSize.MEDIUM : this.listSizeType() }, h("z-icon", { name: "multiply-circle", fill: "color-primary01-icon" }), this.noresultslabel));
302
435
  }
303
436
  renderMessage() {
304
437
  if (boolean(this.message) === false) {
@@ -307,7 +440,7 @@ export class ZSelect {
307
440
  return (h("z-input-message", { message: boolean(this.message) === true ? undefined : this.message, status: this.status, class: this.size, disabled: this.disabled }));
308
441
  }
309
442
  render() {
310
- return (h("div", { key: '3fc3a44d3a8e78034ac8b0ccd76b90c427312a7c', class: "select-wrapper" }, this.renderInput(), this.renderSelectUl(), this.renderMessage()));
443
+ return (h("div", { key: 'b57864d8d6005f5239c76da17bd6d2a5631efd59', class: "select-wrapper" }, this.renderInput(), this.renderSelectUl(), this.renderMessage()));
311
444
  }
312
445
  static get is() { return "z-select"; }
313
446
  static get encapsulation() { return "scoped"; }
@@ -580,6 +713,23 @@ export class ZSelect {
580
713
  "attribute": "has-group-items",
581
714
  "reflect": false
582
715
  },
716
+ "hasTreeItems": {
717
+ "type": "boolean",
718
+ "mutable": false,
719
+ "complexType": {
720
+ "original": "boolean",
721
+ "resolved": "boolean",
722
+ "references": {}
723
+ },
724
+ "required": false,
725
+ "optional": true,
726
+ "docs": {
727
+ "tags": [],
728
+ "text": ""
729
+ },
730
+ "attribute": "has-tree-items",
731
+ "reflect": false
732
+ },
583
733
  "isfixed": {
584
734
  "type": "boolean",
585
735
  "mutable": false,
@@ -646,7 +796,8 @@ export class ZSelect {
646
796
  "isOpen": {},
647
797
  "selectedItem": {},
648
798
  "focusedItemId": {},
649
- "searchString": {}
799
+ "searchString": {},
800
+ "flattenedList": {}
650
801
  };
651
802
  }
652
803
  static get events() {
@@ -735,11 +886,6 @@ export class ZSelect {
735
886
  "Promise": {
736
887
  "location": "global",
737
888
  "id": "global::Promise"
738
- },
739
- "SelectItem": {
740
- "location": "import",
741
- "path": "../../beans",
742
- "id": "src/beans/index.tsx::SelectItem"
743
889
  }
744
890
  },
745
891
  "return": "Promise<void>"
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/z-select/index.tsx"],"names":[],"mappings":"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","sourcesContent":["import {Component, Element, Event, EventEmitter, Listen, Method, Prop, State, Watch, h} from \"@stencil/core\";\nimport {ControlSize, InputStatus, KeyboardCode, ListDividerType, ListSize, SelectItem} from \"../../beans\";\nimport {boolean, containsElement, getClickedElement, handleKeyboardSubmit, randomId} from \"../../utils/utils\";\n\n@Component({\n tag: \"z-select\",\n styleUrl: \"styles.css\",\n shadow: false,\n scoped: true,\n})\nexport class ZSelect {\n @Element() host: HTMLZSelectElement;\n\n /** the id of the input element */\n @Prop()\n htmlid = `id-${randomId()}`;\n\n /** the input select options */\n @Prop()\n items: SelectItem[] | string;\n\n /** the input name */\n @Prop()\n name?: string;\n\n /** the input label */\n @Prop()\n label?: string;\n\n /** the input aria-label */\n @Prop()\n ariaLabel = \"\";\n\n /** the input is disabled */\n @Prop()\n disabled?: boolean = false;\n\n /** the input is readonly */\n @Prop()\n readonly?: boolean = false;\n\n /** the input placeholder (optional) */\n @Prop()\n placeholder?: string;\n\n /** the input html title (optional) */\n @Prop()\n htmltitle?: string;\n\n /** the input status (optional) */\n @Prop()\n status?: InputStatus;\n\n /** input helper message (optional) - if set to `false` message won't be displayed */\n @Prop()\n message?: string | boolean = true;\n\n /** the input has autocomplete option */\n @Prop()\n autocomplete?: boolean = false;\n\n /** no result text message */\n @Prop()\n noresultslabel?: string = \"Nessun risultato\";\n\n /** */\n @Prop()\n hasGroupItems?: boolean;\n\n /** When fixed, it occupies space and pushes down next elements. */\n @Prop()\n isfixed?: boolean = false;\n\n /** */\n @Prop()\n resetItem?: string;\n\n /** Available sizes: `big`, `small` and `x-small`. Defaults to `big`. */\n @Prop()\n size?: ControlSize = ControlSize.BIG;\n\n @State()\n isOpen = false;\n\n @State()\n selectedItem: null | SelectItem = null;\n\n @State()\n focusedItemId: string;\n\n @State()\n searchString: null | string;\n\n private itemsList: SelectItem[] = [];\n\n constructor() {\n this.toggleSelectUl = this.toggleSelectUl.bind(this);\n this.handleSelectFocus = this.handleSelectFocus.bind(this);\n }\n\n @Watch(\"items\")\n watchItems(): void {\n this.itemsList = this.getInitialItemsArray();\n this.selectedItem = this.itemsList.find((item: SelectItem) => item.selected);\n }\n\n @Listen(\"ariaDescendantFocus\")\n getFocusedItemHandler(e: CustomEvent): void {\n this.focusedItemId = (e.target as Element).id;\n }\n\n /** get the input selected options */\n @Method()\n async getSelectedItem(): Promise<SelectItem> {\n return this.selectedItem;\n }\n\n /** get the input value */\n @Method()\n async getValue(): Promise<string> {\n return this.getSelectedValue();\n }\n\n /** set the input value */\n @Method()\n async setValue(value: string | string[]): Promise<void> {\n let values: string[] = [];\n if (typeof value === \"string\") {\n values.push(value);\n } else {\n values = value;\n }\n\n this.selectedItem = this.itemsList.find((item: SelectItem) => values.includes(item.id));\n }\n\n /** Emitted on select option selection, returns select id, selected item id */\n @Event()\n optionSelect: EventEmitter;\n\n private emitOptionSelect(): void {\n this.optionSelect.emit({\n id: this.htmlid,\n selected: this.getSelectedValue(),\n });\n }\n\n /** Emitted on reset selected item, returns select id, selected item id */\n @Event()\n resetSelect: EventEmitter;\n\n private emitResetSelect(): void {\n this.resetSelect.emit({\n id: this.htmlid,\n });\n }\n\n componentWillLoad(): void {\n this.watchItems();\n }\n\n componentWillRender(): void {\n this.filterItems(this.searchString);\n }\n\n private getInitialItemsArray(): SelectItem[] {\n return typeof this.items === \"string\" ? JSON.parse(this.items) : this.items;\n }\n\n private mapSelectedItemToItemsArray(): SelectItem[] {\n const initialItemsList = this.getInitialItemsArray();\n\n return initialItemsList.map((item: SelectItem) => {\n item.selected = item.id === this.selectedItem?.id;\n\n return item;\n });\n }\n\n private getSelectedValue(): string {\n return this.selectedItem?.id;\n }\n\n private filterItems(searchString: string): void {\n const prevList = this.mapSelectedItemToItemsArray();\n if (!searchString?.length) {\n this.itemsList = prevList;\n } else {\n this.itemsList = prevList\n .filter((item: SelectItem) => {\n return item.name.toUpperCase().includes(searchString.toUpperCase());\n })\n .map((item: SelectItem) => {\n const start = item.name.toUpperCase().indexOf(searchString.toUpperCase());\n const end = start + searchString.length;\n const newName =\n item.name.substring(0, start) +\n `<strong>${item.name.substring(start, end)}</strong>` +\n item.name.substring(end, item.name.length);\n item.name = newName;\n\n return item;\n });\n }\n }\n\n private hasAutocomplete(): boolean {\n return boolean(this.autocomplete) === true;\n }\n\n private handleInputChange(e: CustomEvent): void {\n this.searchString = e.detail.value;\n if (!this.isOpen) {\n this.toggleSelectUl();\n }\n }\n\n private selectItem(selected: null | SelectItem): void {\n if (selected?.disabled) {\n return;\n }\n\n this.itemsList = this.mapSelectedItemToItemsArray();\n this.itemsList.forEach((i: SelectItem) => {\n i.selected = i.id === selected?.id;\n\n return i;\n });\n\n this.selectedItem = this.itemsList.find((item: SelectItem) => item.selected);\n\n this.emitOptionSelect();\n this.toggleSelectUl(true);\n\n if (this.searchString) {\n this.searchString = null;\n }\n }\n\n private arrowsSelectNav(e: KeyboardEvent, key: number): void {\n const showResetIcon = this.resetItem && !!this.selectedItem;\n const arrows = [KeyboardCode.ARROW_DOWN, KeyboardCode.ARROW_UP];\n if (!arrows.includes(e.key as KeyboardCode)) {\n return;\n }\n\n e.preventDefault();\n e.stopPropagation();\n\n if (!this.isOpen) {\n this.toggleSelectUl();\n }\n\n let index: number;\n\n if (this.resetItem) {\n if (e.key === KeyboardCode.ARROW_DOWN) {\n index = key + 1 === this.itemsList.length + 1 ? +!showResetIcon : key + 1;\n } else if (e.key === KeyboardCode.ARROW_UP) {\n index = key <= +!showResetIcon ? this.itemsList.length : key - 1;\n }\n }\n\n if (!this.resetItem) {\n if (e.key === KeyboardCode.ARROW_DOWN) {\n index = key + 1 === this.itemsList.length ? 0 : key + 1;\n } else if (e.key === KeyboardCode.ARROW_UP) {\n index = key <= 0 ? this.itemsList.length - 1 : key - 1;\n }\n }\n\n this.focusSelectItem(index);\n }\n\n private focusSelectItem(index: number): void {\n this.host.querySelector<HTMLLIElement>(`#${this.htmlid}_${index}`)?.focus();\n }\n\n private toggleSelectUl(selfFocusOnClose = false): void {\n if (this.disabled || this.readonly) {\n return;\n }\n\n if (!this.isOpen) {\n document.addEventListener(\"click\", this.handleSelectFocus);\n document.addEventListener(\"keyup\", this.handleSelectFocus);\n } else {\n document.removeEventListener(\"click\", this.handleSelectFocus);\n document.removeEventListener(\"keyup\", this.handleSelectFocus);\n if (selfFocusOnClose) {\n (this.host.querySelector(`#${this.htmlid}_input`) as HTMLInputElement).focus();\n }\n }\n\n this.focusedItemId = \"\";\n this.isOpen = !this.isOpen;\n }\n\n private handleInputClick(e: MouseEvent | KeyboardEvent): void {\n if ((e.target as HTMLElement).closest(\".reset-icon\")) {\n e.stopPropagation();\n\n return;\n }\n\n this.toggleSelectUl();\n }\n\n private handleSelectFocus(e: MouseEvent | KeyboardEvent): void {\n const clickedElement = getClickedElement();\n if (clickedElement?.hasAttribute(\"disabled\")) {\n return;\n }\n\n if (e instanceof KeyboardEvent && e.key === KeyboardCode.ESC) {\n e.stopPropagation();\n\n return this.toggleSelectUl(true);\n }\n\n if (e instanceof KeyboardEvent && e.key !== KeyboardCode.TAB && e.key !== KeyboardCode.ENTER) {\n return;\n }\n\n if (!containsElement(this.host, clickedElement)) {\n this.toggleSelectUl(e instanceof MouseEvent);\n }\n }\n\n private scrollToLetter(letter: string): void {\n const foundItem = this.itemsList.findIndex((item: SelectItem) => item.name.charAt(0) === letter);\n if (foundItem > -1) {\n this.focusSelectItem(foundItem);\n }\n }\n\n private renderInput(): HTMLZInputElement {\n return (\n <z-input\n class={{\n \"active-select\": this.isOpen,\n \"cursor-select\": !this.autocomplete,\n }}\n id={`${this.htmlid}_input`}\n htmlid={`${this.htmlid}_select_input`}\n placeholder={this.placeholder}\n value={!this.isOpen && this.selectedItem ? this.selectedItem.name.replace(/<[^>]+>/g, \"\") : null}\n label={this.label}\n aria-expanded={this.isOpen ? \"true\" : \"false\"}\n aria-label={this.ariaLabel}\n aria-controls={`${this.htmlid}_list`}\n aria-autocomplete={this.hasAutocomplete() ? \"list\" : \"none\"}\n aria-activedescendant={this.isOpen ? this.focusedItemId : \"\"}\n icon={this.isOpen ? \"caret-up\" : \"caret-down\"}\n hasclearicon={this.hasAutocomplete()}\n message={false}\n disabled={this.disabled}\n readonly={this.readonly || (!this.hasAutocomplete() && this.isOpen)}\n status={this.isOpen ? undefined : this.status}\n role=\"combobox\"\n size={this.size}\n onClick={(e: MouseEvent) => {\n this.handleInputClick(e);\n }}\n onKeyUp={(e: KeyboardEvent) => {\n if (e.key !== KeyboardCode.ENTER) {\n e.preventDefault();\n }\n handleKeyboardSubmit(e, this.toggleSelectUl);\n }}\n onKeyDown={(e: KeyboardEvent) => {\n return this.arrowsSelectNav(\n e,\n this.selectedItem ? this.itemsList.indexOf(this.selectedItem) : this.resetItem ? 0 : -1\n );\n }}\n onInputChange={(e: CustomEvent) => {\n this.handleInputChange(e);\n }}\n onKeyPress={(e: KeyboardEvent) => {\n if (!this.hasAutocomplete()) {\n e.preventDefault();\n this.scrollToLetter(String.fromCharCode(e.keyCode));\n }\n }}\n />\n );\n }\n\n private renderSelectUl(): HTMLDivElement {\n return (\n <div class={this.isOpen ? \"open\" : \"closed\"}>\n <div\n class={{\n \"ul-scroll-wrapper\": true,\n \"fixed\": this.isfixed,\n }}\n >\n <z-list\n role=\"listbox\"\n aria-label={this.ariaLabel || this.label}\n tabindex={this.disabled || this.readonly || !this.isOpen ? -1 : 0}\n id={`${this.htmlid}_list`}\n aria-multiselectable={false}\n size={this.listSizeType()}\n class={{\n \"disabled\": this.disabled,\n \"readonly\": this.readonly,\n [`input-${this.status}`]: !this.isOpen && !!this.status,\n \"z-scrollbar\": true,\n }}\n >\n {this.resetItem && this.renderResetItem()}\n {this.renderSelectUlItems()}\n </z-list>\n </div>\n </div>\n );\n }\n\n private renderResetItem(): HTMLZListElementElement {\n return (\n <z-list-element\n class={{\n \"hide\": !this.selectedItem || !this.resetItem,\n \"reset-item\": true,\n \"reset-item-margin\": !this.hasGroupItems,\n }}\n clickable={true}\n disabled={false}\n dividerType={ListDividerType.ELEMENT}\n role=\"option\"\n tabindex=\"0\"\n aria-selected=\"false\"\n id={`${this.htmlid}_${this.resetItem ? \"0\" : \"none\"}`}\n size={this.listSizeType()}\n onClickItem={() => {\n this.selectedItem = null;\n this.searchString = null;\n this.emitResetSelect();\n }}\n onKeyDown={(e: KeyboardEvent) => this.arrowsSelectNav(e, 0)}\n >\n <div class=\"reset-item-content\">\n <z-icon name=\"multiply-circled\" />\n <span>{this.resetItem}</span>\n </div>\n </z-list-element>\n );\n }\n\n private renderItem(item: SelectItem, key: number, lastItem: boolean): HTMLZListElementElement {\n return (\n <z-list-element\n clickable={!item.disabled}\n disabled={item.disabled}\n dividerType={lastItem ? ListDividerType.HEADER : ListDividerType.ELEMENT}\n role=\"option\"\n tabindex={item.disabled || !this.isOpen ? -1 : 0}\n aria-selected={item.selected ? \"true\" : \"false\"}\n id={`${this.htmlid}_${key}`}\n size={this.listSizeType()}\n onClickItem={() => this.selectItem(item)}\n onKeyDown={(e: KeyboardEvent) => this.arrowsSelectNav(e, key)}\n >\n <div class=\"list-element-container\">\n <div\n class={{\n \"selected\": !!item.selected,\n \"list-element-content\": true,\n }}\n innerHTML={item.name}\n />\n\n {item.icon && <z-tag icon={item.icon}></z-tag>}\n </div>\n </z-list-element>\n );\n }\n\n private listSizeType(): ListSize {\n if (this.size === ControlSize.SMALL || this.size === ControlSize.X_SMALL) {\n return ListSize.SMALL;\n }\n\n return ListSize.MEDIUM;\n }\n\n private renderSelectUlItems(): HTMLZListElementElement | HTMLZListElementElement[] {\n if (!this.itemsList.length) {\n return this.renderNoSearchResults();\n }\n\n if (this.hasGroupItems) {\n return this.renderSelectGroupItems();\n }\n\n return this.itemsList.map((item: SelectItem, key, array) => {\n const lastItem = array.length === key + 1;\n const itemKey = this.resetItem ? key + 1 : key;\n\n return this.renderItem(item, itemKey, lastItem);\n });\n }\n\n private renderSelectGroupItems(): HTMLZListElementElement | HTMLZListElementElement[] {\n const newData = this.itemsList.reduce((group, item, index, array) => {\n const {category} = item;\n const lastItem = array.length === index + 1;\n const itemKey = this.resetItem ? index + 1 : index;\n const zListItem = this.renderItem(item, itemKey, lastItem);\n\n group[category] = group[category] ?? [];\n group[category].push(zListItem);\n\n return group;\n }, {});\n\n return Object.entries(newData as {[key: string]: HTMLZListElementElement[]}).map(([key, value]) => {\n return (\n <z-list-group divider-type={ListDividerType.ELEMENT}>\n <span\n class=\"body-3-sb z-list-group-title\"\n slot=\"header-title\"\n >\n {key}\n </span>\n {value.map((item) => item)}\n </z-list-group>\n );\n });\n }\n\n private renderNoSearchResults(): HTMLZListElementElement {\n return (\n <z-list-element\n color=\"color-primary01\"\n class=\"no-results\"\n size={this.listSizeType()}\n >\n <z-icon\n name=\"multiply-circle\"\n fill=\"color-primary01-icon\"\n />\n {this.noresultslabel}\n </z-list-element>\n );\n }\n\n private renderMessage(): HTMLZInputMessageElement {\n if (boolean(this.message) === false) {\n return;\n }\n\n return (\n <z-input-message\n message={boolean(this.message) === true ? undefined : (this.message as string)}\n status={this.status}\n class={this.size}\n disabled={this.disabled}\n />\n );\n }\n\n render(): HTMLDivElement {\n return (\n <div class=\"select-wrapper\">\n {this.renderInput()}\n {this.renderSelectUl()}\n {this.renderMessage()}\n </div>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/z-select/index.tsx"],"names":[],"mappings":"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","sourcesContent":["import {Component, Element, Event, EventEmitter, Listen, Method, Prop, State, Watch, h} from \"@stencil/core\";\nimport {ControlSize, InputStatus, KeyboardCode, ListDividerType, ListSize, SelectItem} from \"../../beans\";\nimport {boolean, containsElement, getClickedElement, handleKeyboardSubmit, randomId} from \"../../utils/utils\";\n\n@Component({\n tag: \"z-select\",\n styleUrl: \"styles.css\",\n shadow: false,\n scoped: true,\n})\nexport class ZSelect {\n @Element() host: HTMLZSelectElement;\n\n /** the id of the input element */\n @Prop()\n htmlid = `id-${randomId()}`;\n\n /** the input select options */\n @Prop()\n items: SelectItem[] | string;\n\n /** the input name */\n @Prop()\n name?: string;\n\n /** the input label */\n @Prop()\n label?: string;\n\n /** the input aria-label */\n @Prop()\n ariaLabel = \"\";\n\n /** the input is disabled */\n @Prop()\n disabled?: boolean = false;\n\n /** the input is readonly */\n @Prop()\n readonly?: boolean = false;\n\n /** the input placeholder (optional) */\n @Prop()\n placeholder?: string;\n\n /** the input html title (optional) */\n @Prop()\n htmltitle?: string;\n\n /** the input status (optional) */\n @Prop()\n status?: InputStatus;\n\n /** input helper message (optional) - if set to `false` message won't be displayed */\n @Prop()\n message?: string | boolean = true;\n\n /** the input has autocomplete option */\n @Prop()\n autocomplete?: boolean = false;\n\n /** no result text message */\n @Prop()\n noresultslabel?: string = \"Nessun risultato\";\n\n /** */\n @Prop()\n hasGroupItems?: boolean;\n\n /** */\n @Prop()\n hasTreeItems?: boolean;\n\n /** When fixed, it occupies space and pushes down next elements. */\n @Prop()\n isfixed?: boolean = false;\n\n /** */\n @Prop()\n resetItem?: string;\n\n /** Available sizes: `big`, `small` and `x-small`. Defaults to `big`. */\n @Prop()\n size?: ControlSize = ControlSize.BIG;\n\n @State()\n isOpen = false;\n\n @State()\n selectedItem: null | SelectItem = null;\n\n @State()\n focusedItemId: string;\n\n @State()\n searchString: null | string;\n\n @State()\n private flattenedList: {item: SelectItem; key: number}[] = [];\n\n private itemsList: SelectItem[] = [];\n\n private itemIdKeyMap: Record<string, number> = {};\n\n private readonly resetKey = -1;\n\n constructor() {\n this.toggleSelectUl = this.toggleSelectUl.bind(this);\n this.handleSelectFocus = this.handleSelectFocus.bind(this);\n }\n\n @Watch(\"items\")\n watchItems(): void {\n this.itemsList = this.getInitialItemsArray();\n\n this.selectedItem = this.findSelectedItem(this.itemsList);\n\n this.flattenedList = this.flattenTreeItems(this.itemsList);\n this.itemIdKeyMap = {};\n this.flattenedList.forEach(({item, key}) => {\n this.itemIdKeyMap[item.id] = key;\n });\n }\n\n @Listen(\"ariaDescendantFocus\")\n getFocusedItemHandler(e: CustomEvent): void {\n this.focusedItemId = (e.target as Element).id;\n }\n\n /** get the input selected options */\n @Method()\n async getSelectedItem(): Promise<SelectItem> {\n return this.selectedItem;\n }\n\n /** get the input value */\n @Method()\n async getValue(): Promise<string> {\n return this.getSelectedValue();\n }\n\n /** set the input value */\n @Method()\n async setValue(value: string | string[]): Promise<void> {\n let values: string[] = [];\n if (typeof value === \"string\") {\n values.push(value);\n } else {\n values = value;\n }\n\n this.itemsList = this.getInitialItemsArray();\n if (values.length) {\n this.updateSelection(this.itemsList, values[0]);\n }\n this.selectedItem = this.findSelectedItem(this.itemsList);\n }\n\n /** Emitted on select option selection, returns select id, selected item id */\n @Event()\n optionSelect: EventEmitter;\n\n private emitOptionSelect(): void {\n this.optionSelect.emit({\n id: this.htmlid,\n selected: this.getSelectedValue(),\n });\n }\n\n /** Emitted on reset selected item, returns select id, selected item id */\n @Event()\n resetSelect: EventEmitter;\n\n private emitResetSelect(): void {\n this.resetSelect.emit({\n id: this.htmlid,\n });\n }\n\n componentWillLoad(): void {\n this.watchItems();\n }\n\n componentWillRender(): void {\n this.filterItems(this.searchString);\n }\n\n private getInitialItemsArray(): SelectItem[] {\n return typeof this.items === \"string\" ? JSON.parse(this.items) : this.items;\n }\n\n private mapSelectedItemToItemsArray(): SelectItem[] {\n const initialItemsList = this.getInitialItemsArray();\n\n return initialItemsList.map((item: SelectItem) => {\n item.selected = item.id === this.selectedItem?.id;\n\n return item;\n });\n }\n\n private getSelectedValue(): string {\n return this.selectedItem?.id;\n }\n\n private filterItems(searchString: string): void {\n const prevList = this.mapSelectedItemToItemsArray();\n\n if (!searchString?.length) {\n this.itemsList = prevList;\n\n return;\n }\n\n if (this.hasTreeItems) {\n this.itemsList = this.filterTree(prevList, searchString);\n } else {\n this.itemsList = prevList\n .filter((item: SelectItem) => item.name.toUpperCase().includes(searchString.toUpperCase()))\n .map((item: SelectItem) => {\n item.name = this.getHighlightedText(item.name, searchString);\n\n return item;\n });\n }\n }\n\n private filterTree(items: SelectItem[], searchString: string): SelectItem[] {\n return items\n .map((item) => {\n const match = item.name.toUpperCase().includes(searchString.toUpperCase());\n\n const newItem: SelectItem = {...item};\n\n if (newItem.children && newItem.children.length > 0) {\n newItem.children = this.filterTree(newItem.children, searchString);\n }\n\n if (match) {\n newItem.name = this.getHighlightedText(newItem.name, searchString);\n }\n\n if (match || (newItem.children && newItem.children.length > 0)) {\n return newItem;\n }\n\n return null;\n })\n .filter((item) => item !== null) as SelectItem[];\n }\n\n private getHighlightedText(text: string, search: string): string {\n const upperText = text.toUpperCase();\n const upperSearch = search.toUpperCase();\n const start = upperText.indexOf(upperSearch);\n\n if (start === -1) {\n return text;\n }\n\n const end = start + search.length;\n\n return text.substring(0, start) + `<strong>${text.substring(start, end)}</strong>` + text.substring(end);\n }\n\n private hasAutocomplete(): boolean {\n return boolean(this.autocomplete) === true;\n }\n\n private handleInputChange(e: CustomEvent): void {\n this.searchString = e.detail.value;\n if (!this.isOpen) {\n this.toggleSelectUl();\n }\n }\n\n private updateSelection(items: SelectItem[], selectedId: string): void {\n items.forEach((item) => {\n item.selected = item.id === selectedId;\n if (item.children && item.children.length > 0) {\n this.updateSelection(item.children, selectedId);\n }\n });\n }\n\n private findSelectedItem(items: SelectItem[]): SelectItem | null {\n for (const item of items) {\n if (item.selected) {\n return item;\n }\n if (item.children && item.children.length > 0) {\n const found = this.findSelectedItem(item.children);\n if (found) {\n return found;\n }\n }\n }\n\n return null;\n }\n\n private selectItem(selected: null | SelectItem): void {\n if (selected?.disabled) {\n return;\n }\n\n this.itemsList = this.getInitialItemsArray();\n\n if (selected) {\n this.updateSelection(this.itemsList, selected.id);\n }\n\n this.selectedItem = this.findSelectedItem(this.itemsList);\n this.emitOptionSelect();\n this.toggleSelectUl(true);\n\n if (this.searchString) {\n this.searchString = null;\n }\n }\n\n private flattenTreeItems(items: SelectItem[]): {item: SelectItem; key: number}[] {\n const flatItems: {item: SelectItem; key: number}[] = [];\n let index = 0;\n\n function flatten(subItems: SelectItem[]): void {\n subItems.forEach((itm) => {\n flatItems.push({item: itm, key: index++});\n if (itm.children && itm.children.length > 0) {\n flatten(itm.children);\n }\n });\n }\n\n flatten(items);\n\n return flatItems;\n }\n\n private arrowsSelectNav(e: KeyboardEvent, idOrReset: string | number): void {\n const showResetIcon = this.resetItem && !!this.selectedItem;\n const arrows = [KeyboardCode.ARROW_DOWN, KeyboardCode.ARROW_UP];\n\n if (!arrows.includes(e.key as KeyboardCode)) {\n return;\n }\n\n e.preventDefault();\n e.stopPropagation();\n\n const flatItems = [...this.flattenedList];\n\n if (this.resetItem && showResetIcon) {\n flatItems.unshift({\n item: {id: \"__RESET_ITEM__\"} as SelectItem,\n key: this.resetKey,\n });\n }\n\n let currentIndex: number;\n if (typeof idOrReset === \"number\") {\n currentIndex = flatItems.findIndex((f) => f.key === idOrReset);\n } else {\n const k = this.itemIdKeyMap[idOrReset];\n currentIndex = flatItems.findIndex((f) => f.key === k);\n }\n\n if (!this.isOpen) {\n this.toggleSelectUl();\n\n if (currentIndex === -1) {\n currentIndex = -1;\n }\n }\n\n const lastIndex = flatItems.length - 1;\n\n let newIndex = currentIndex;\n\n if (e.key === KeyboardCode.ARROW_DOWN) {\n newIndex = currentIndex === lastIndex ? 0 : currentIndex + 1;\n } else {\n newIndex = currentIndex <= 0 ? lastIndex : currentIndex - 1;\n }\n\n this.focusSelectItem(flatItems[newIndex].key);\n }\n\n private focusSelectItem(key: number): void {\n this.host.querySelector<HTMLDivElement>(`#${this.htmlid}_key_${key}`)?.focus();\n }\n\n private toggleSelectUl(selfFocusOnClose = false): void {\n if (this.disabled || this.readonly) {\n return;\n }\n\n if (!this.isOpen) {\n document.addEventListener(\"click\", this.handleSelectFocus);\n document.addEventListener(\"keyup\", this.handleSelectFocus);\n } else {\n document.removeEventListener(\"click\", this.handleSelectFocus);\n document.removeEventListener(\"keyup\", this.handleSelectFocus);\n if (selfFocusOnClose) {\n (this.host.querySelector(`#${this.htmlid}_input`) as HTMLInputElement)?.focus();\n }\n }\n\n this.focusedItemId = \"\";\n this.isOpen = !this.isOpen;\n }\n\n private handleInputClick(e: MouseEvent | KeyboardEvent): void {\n if ((e.target as HTMLElement).closest(\".reset-icon\")) {\n e.stopPropagation();\n\n return;\n }\n\n this.toggleSelectUl();\n }\n\n private handleSelectFocus(e: MouseEvent | KeyboardEvent): void {\n const clickedElement = getClickedElement();\n if (clickedElement?.hasAttribute(\"disabled\")) {\n return;\n }\n\n if (e instanceof KeyboardEvent && e.key === KeyboardCode.ESC) {\n e.stopPropagation();\n\n return this.toggleSelectUl(true);\n }\n\n if (e instanceof KeyboardEvent && e.key !== KeyboardCode.TAB && e.key !== KeyboardCode.ENTER) {\n return;\n }\n\n if (!containsElement(this.host, clickedElement)) {\n this.toggleSelectUl(e instanceof MouseEvent);\n }\n }\n\n private scrollToLetter(letter: string): void {\n const foundItem = this.itemsList.findIndex((item: SelectItem) => item.name.charAt(0) === letter);\n if (foundItem > -1) {\n this.focusSelectItem(this.itemIdKeyMap[this.itemsList[foundItem].id]);\n }\n }\n\n private renderInput(): HTMLZInputElement {\n return (\n <z-input\n class={{\n \"active-select\": this.isOpen,\n \"cursor-select\": !this.autocomplete,\n }}\n id={`${this.htmlid}_input`}\n htmlid={`${this.htmlid}_select_input`}\n placeholder={this.placeholder}\n value={!this.isOpen && this.selectedItem ? this.selectedItem.name.replace(/<[^>]+>/g, \"\") : null}\n label={this.label}\n aria-expanded={this.isOpen ? \"true\" : \"false\"}\n aria-label={this.ariaLabel}\n aria-controls={`${this.htmlid}_list`}\n aria-autocomplete={this.hasAutocomplete() ? \"list\" : \"none\"}\n aria-activedescendant={this.isOpen ? this.focusedItemId : \"\"}\n icon={this.isOpen ? \"caret-up\" : \"caret-down\"}\n hasclearicon={this.hasAutocomplete()}\n message={false}\n disabled={this.disabled}\n readonly={this.readonly || (!this.hasAutocomplete() && this.isOpen)}\n status={this.isOpen ? undefined : this.status}\n role=\"combobox\"\n size={this.size}\n onClick={(e: MouseEvent) => {\n this.handleInputClick(e);\n }}\n onKeyUp={(e: KeyboardEvent) => {\n if (e.key !== KeyboardCode.ENTER) {\n e.preventDefault();\n }\n handleKeyboardSubmit(e, this.toggleSelectUl);\n }}\n onKeyDown={(e: KeyboardEvent) => {\n const current = this.selectedItem\n ? this.itemIdKeyMap[this.selectedItem.id]\n : this.resetItem\n ? this.resetKey\n : \"\";\n\n return this.arrowsSelectNav(e, current);\n }}\n onInputChange={(e: CustomEvent) => {\n this.handleInputChange(e);\n }}\n onKeyPress={(e: KeyboardEvent) => {\n if (!this.hasAutocomplete()) {\n e.preventDefault();\n this.scrollToLetter(String.fromCharCode(e.keyCode));\n }\n }}\n />\n );\n }\n\n private renderSelectUl(): HTMLDivElement {\n return (\n <div class={this.isOpen ? \"open\" : \"closed\"}>\n <div\n class={{\n \"ul-scroll-wrapper\": true,\n \"fixed\": this.isfixed,\n }}\n >\n <z-list\n role=\"listbox\"\n aria-label={this.ariaLabel || this.label}\n tabindex={this.disabled || this.readonly || !this.isOpen ? -1 : 0}\n id={`${this.htmlid}_list`}\n aria-multiselectable={false}\n size={this.listSizeType()}\n class={{\n \"disabled\": this.disabled,\n \"readonly\": this.readonly,\n [`input-${this.status}`]: !this.isOpen && !!this.status,\n \"z-scrollbar\": true,\n }}\n >\n {this.resetItem && this.renderResetItem()}\n {this.renderSelectUlItems()}\n </z-list>\n </div>\n </div>\n );\n }\n\n private renderResetItem(): HTMLZListElementElement {\n return (\n <z-list-element\n class={{\n \"hide\": !this.selectedItem || !this.resetItem,\n \"reset-item\": true,\n \"reset-item-margin\": !this.hasGroupItems,\n }}\n clickable={true}\n disabled={false}\n dividerType={ListDividerType.ELEMENT}\n role=\"option\"\n tabindex=\"0\"\n aria-selected=\"false\"\n id={`${this.htmlid}_key_${this.resetKey}`}\n size={this.hasTreeItems ? ListSize.MEDIUM : this.listSizeType()}\n onClickItem={() => {\n this.selectedItem = null;\n this.searchString = null;\n this.emitResetSelect();\n }}\n onKeyDown={(e: KeyboardEvent) => this.arrowsSelectNav(e, this.resetKey)}\n >\n <div\n class={{\n \"reset-item-content\": true,\n \"tree-list-reset-item\": this.hasTreeItems,\n }}\n >\n <z-icon name=\"multiply-circled\" />\n <span>{this.resetItem}</span>\n </div>\n </z-list-element>\n );\n }\n\n private renderItem(item: SelectItem, lastItem: boolean): HTMLZListElementElement {\n const thisItemKey = this.itemIdKeyMap[item.id];\n\n return (\n <z-list-element\n clickable={!item.disabled}\n disabled={item.disabled}\n dividerType={lastItem ? ListDividerType.HEADER : ListDividerType.ELEMENT}\n role=\"option\"\n tabindex={item.disabled || !this.isOpen ? -1 : 0}\n aria-selected={item.selected ? \"true\" : \"false\"}\n id={`${this.htmlid}_key_${thisItemKey}`}\n size={this.listSizeType()}\n onClickItem={() => this.selectItem(item)}\n onKeyDown={(e: KeyboardEvent) => this.arrowsSelectNav(e, thisItemKey)}\n >\n <div class=\"list-element-container\">\n <div\n class={{\n \"selected\": !!item.selected,\n \"list-element-content\": true,\n }}\n innerHTML={item.name}\n />\n {item.icon && <z-tag icon={item.icon}></z-tag>}\n </div>\n </z-list-element>\n );\n }\n\n private listSizeType(): ListSize {\n if (this.hasTreeItems) {\n return ListSize.NONE;\n }\n\n if (this.size === ControlSize.SMALL || this.size === ControlSize.X_SMALL) {\n return ListSize.SMALL;\n }\n\n return ListSize.MEDIUM;\n }\n\n //eslint-disable-next-line\n private renderSelectUlItems(): any {\n if (!this.itemsList.length) {\n return this.renderNoSearchResults();\n }\n\n if (this.hasGroupItems && !this.hasTreeItems) {\n return this.renderSelectGroupItems();\n } else if (this.hasGroupItems && this.hasTreeItems) {\n return this.renderGroupedTree();\n }\n\n return this.itemsList.map((item: SelectItem, key, array) => {\n const lastItem = array.length === key + 1;\n\n if (this.hasTreeItems) {\n return this.renderTreeItems(item, lastItem);\n }\n\n return this.renderItem(item, lastItem);\n });\n }\n\n private renderTreeItems(item: SelectItem, divider?: boolean): HTMLZListElementElement[] {\n const hasDivider = divider && !item.children?.length;\n const thisItemKey = this.itemIdKeyMap[item.id];\n\n return (\n <z-list-element\n class={{\n \"grouped-tree-parent-node\": this.hasGroupItems && !!item.children?.length,\n }}\n size={this.listSizeType()}\n dividerType={hasDivider ? ListDividerType.ELEMENT : undefined}\n hasTreeItems={this.hasTreeItems}\n >\n <div\n id={`${this.htmlid}_key_${thisItemKey}`}\n role=\"option\"\n class=\"list-element\"\n tabIndex={0}\n onClick={() => this.selectItem(item)}\n onKeyDown={(e: KeyboardEvent) => {\n this.arrowsSelectNav(e, thisItemKey);\n if (e.key === KeyboardCode.ENTER) {\n this.selectItem(item);\n }\n }}\n onMouseEnter={(e: MouseEvent) => {\n const currentElement = e.target as HTMLElement;\n currentElement.classList.add(\"hovered\");\n }}\n onMouseLeave={(e: MouseEvent) => {\n const currentElement = e.target as HTMLElement;\n currentElement.classList.contains(\"hovered\") && currentElement.classList.remove(\"hovered\");\n }}\n >\n <span class=\"item ellipsis\">\n {item?.icon && (\n <z-icon\n class=\"item-icon\"\n name={item.icon}\n />\n )}\n <span\n class={{\n \"item-label\": true,\n \"selected\": !!item.selected,\n }}\n title={item.name}\n innerHTML={item.name}\n />\n </span>\n {item.icon && <z-tag icon={item.icon}></z-tag>}\n </div>\n {item.children && item.children.length > 0 ? (\n <z-list>\n <div class=\"children-node\">\n {item.children.map((child, index, arr) => this.renderTreeItems(child, index === arr.length - 1))}\n </div>\n </z-list>\n ) : null}\n </z-list-element>\n );\n }\n\n private renderGroupedTree(): HTMLZListGroupElement[] {\n const grouped = this.itemsList.reduce(\n (acc, item) => {\n const category = item.category || \"Altra categoria\";\n acc[category] = acc[category] || [];\n acc[category].push(item);\n\n return acc;\n },\n {} as Record<string, SelectItem[]>\n );\n\n return Object.entries(grouped).map(([category, items]) => {\n return (\n <z-list-group\n divider-type={ListDividerType.ELEMENT}\n hasTreeItems={true}\n >\n <span\n class=\"body-3-sb z-list-group-title\"\n slot=\"header-title\"\n >\n {category}\n </span>\n <z-list>{items.map((item, i, arr) => this.renderTreeItems(item, i === arr.length - 1))}</z-list>\n </z-list-group>\n );\n });\n }\n\n private renderSelectGroupItems(): HTMLZListElementElement[] {\n const newData = this.itemsList.reduce(\n (group, item, index, array) => {\n const {category} = item;\n const lastItem = array.length === index + 1;\n const zListItem = this.renderItem(item, lastItem);\n\n group[category] = group[category] ?? [];\n group[category].push(zListItem);\n\n return group;\n },\n {} as Record<string, HTMLZListElementElement[]>\n );\n\n return Object.entries(newData).map(([key, value]) => {\n return (\n <z-list-group divider-type={ListDividerType.ELEMENT}>\n <span\n class=\"body-3-sb z-list-group-title\"\n slot=\"header-title\"\n >\n {key}\n </span>\n {value.map((item) => item)}\n </z-list-group>\n );\n });\n }\n\n private renderNoSearchResults(): HTMLZListElementElement {\n return (\n <z-list-element\n color=\"color-primary01\"\n class=\"no-results\"\n size={this.hasTreeItems ? ListSize.MEDIUM : this.listSizeType()}\n >\n <z-icon\n name=\"multiply-circle\"\n fill=\"color-primary01-icon\"\n />\n {this.noresultslabel}\n </z-list-element>\n );\n }\n\n private renderMessage(): HTMLZInputMessageElement {\n if (boolean(this.message) === false) {\n return;\n }\n\n return (\n <z-input-message\n message={boolean(this.message) === true ? undefined : (this.message as string)}\n status={this.status}\n class={this.size}\n disabled={this.disabled}\n />\n );\n }\n\n render(): HTMLDivElement {\n return (\n <div class=\"select-wrapper\">\n {this.renderInput()}\n {this.renderSelectUl()}\n {this.renderMessage()}\n </div>\n );\n }\n}\n"]}