@milaboratories/uikit 2.11.6 → 2.11.8

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 (1119) hide show
  1. package/.turbo/turbo-build.log +634 -634
  2. package/.turbo/turbo-formatter$colon$check.log +2 -2
  3. package/.turbo/turbo-linter$colon$check.log +2 -2
  4. package/.turbo/turbo-types$colon$check.log +1 -1
  5. package/CHANGELOG.md +14 -0
  6. package/build.browser-lib.config.js +1 -1
  7. package/dist/_virtual/_plugin-vue_export-helper.js +2 -0
  8. package/dist/_virtual/_rolldown/runtime.js +2 -0
  9. package/dist/_virtual/_rolldown_dynamic_import_helper.js +2 -0
  10. package/dist/assets/icons/icon-assets-min/16_add.js +2 -0
  11. package/dist/assets/icons/icon-assets-min/16_add.js.map +1 -1
  12. package/dist/assets/icons/icon-assets-min/16_arrow-down.js +2 -0
  13. package/dist/assets/icons/icon-assets-min/16_arrow-down.js.map +1 -1
  14. package/dist/assets/icons/icon-assets-min/16_arrow-left.js +2 -0
  15. package/dist/assets/icons/icon-assets-min/16_arrow-left.js.map +1 -1
  16. package/dist/assets/icons/icon-assets-min/16_arrow-link.js +2 -0
  17. package/dist/assets/icons/icon-assets-min/16_arrow-link.js.map +1 -1
  18. package/dist/assets/icons/icon-assets-min/16_arrow-right.js +2 -0
  19. package/dist/assets/icons/icon-assets-min/16_arrow-right.js.map +1 -1
  20. package/dist/assets/icons/icon-assets-min/16_arrow-up.js +2 -0
  21. package/dist/assets/icons/icon-assets-min/16_arrow-up.js.map +1 -1
  22. package/dist/assets/icons/icon-assets-min/16_box.js +2 -0
  23. package/dist/assets/icons/icon-assets-min/16_box.js.map +1 -1
  24. package/dist/assets/icons/icon-assets-min/16_calendar.js +2 -0
  25. package/dist/assets/icons/icon-assets-min/16_calendar.js.map +1 -1
  26. package/dist/assets/icons/icon-assets-min/16_caret-down.js +2 -0
  27. package/dist/assets/icons/icon-assets-min/16_caret-down.js.map +1 -1
  28. package/dist/assets/icons/icon-assets-min/16_caret-left.js +2 -0
  29. package/dist/assets/icons/icon-assets-min/16_caret-left.js.map +1 -1
  30. package/dist/assets/icons/icon-assets-min/16_caret-right.js +2 -0
  31. package/dist/assets/icons/icon-assets-min/16_caret-right.js.map +1 -1
  32. package/dist/assets/icons/icon-assets-min/16_caret-up.js +2 -0
  33. package/dist/assets/icons/icon-assets-min/16_caret-up.js.map +1 -1
  34. package/dist/assets/icons/icon-assets-min/16_cell-type-num.js +2 -0
  35. package/dist/assets/icons/icon-assets-min/16_cell-type-num.js.map +1 -1
  36. package/dist/assets/icons/icon-assets-min/16_cell-type-subset.js +2 -0
  37. package/dist/assets/icons/icon-assets-min/16_cell-type-subset.js.map +1 -1
  38. package/dist/assets/icons/icon-assets-min/16_cell-type-txt.js +2 -0
  39. package/dist/assets/icons/icon-assets-min/16_cell-type-txt.js.map +1 -1
  40. package/dist/assets/icons/icon-assets-min/16_checkmark.js +2 -0
  41. package/dist/assets/icons/icon-assets-min/16_checkmark.js.map +1 -1
  42. package/dist/assets/icons/icon-assets-min/16_chevron-down.js +2 -0
  43. package/dist/assets/icons/icon-assets-min/16_chevron-down.js.map +1 -1
  44. package/dist/assets/icons/icon-assets-min/16_chevron-first.js +2 -0
  45. package/dist/assets/icons/icon-assets-min/16_chevron-first.js.map +1 -1
  46. package/dist/assets/icons/icon-assets-min/16_chevron-last.js +2 -0
  47. package/dist/assets/icons/icon-assets-min/16_chevron-last.js.map +1 -1
  48. package/dist/assets/icons/icon-assets-min/16_chevron-left.js +2 -0
  49. package/dist/assets/icons/icon-assets-min/16_chevron-left.js.map +1 -1
  50. package/dist/assets/icons/icon-assets-min/16_chevron-right.js +2 -0
  51. package/dist/assets/icons/icon-assets-min/16_chevron-right.js.map +1 -1
  52. package/dist/assets/icons/icon-assets-min/16_chevron-up.js +2 -0
  53. package/dist/assets/icons/icon-assets-min/16_chevron-up.js.map +1 -1
  54. package/dist/assets/icons/icon-assets-min/16_clear.js +2 -0
  55. package/dist/assets/icons/icon-assets-min/16_clear.js.map +1 -1
  56. package/dist/assets/icons/icon-assets-min/16_clipboard-copied.js +2 -0
  57. package/dist/assets/icons/icon-assets-min/16_clipboard-copied.js.map +1 -1
  58. package/dist/assets/icons/icon-assets-min/16_clipboard.js +2 -0
  59. package/dist/assets/icons/icon-assets-min/16_clipboard.js.map +1 -1
  60. package/dist/assets/icons/icon-assets-min/16_close.js +2 -0
  61. package/dist/assets/icons/icon-assets-min/16_close.js.map +1 -1
  62. package/dist/assets/icons/icon-assets-min/16_compare.js +2 -0
  63. package/dist/assets/icons/icon-assets-min/16_compare.js.map +1 -1
  64. package/dist/assets/icons/icon-assets-min/16_copy.js +2 -0
  65. package/dist/assets/icons/icon-assets-min/16_copy.js.map +1 -1
  66. package/dist/assets/icons/icon-assets-min/16_data-dimentions.js +2 -0
  67. package/dist/assets/icons/icon-assets-min/16_data-dimentions.js.map +1 -1
  68. package/dist/assets/icons/icon-assets-min/16_delete-bin.js +2 -0
  69. package/dist/assets/icons/icon-assets-min/16_delete-bin.js.map +1 -1
  70. package/dist/assets/icons/icon-assets-min/16_delete-circle.js +2 -0
  71. package/dist/assets/icons/icon-assets-min/16_delete-circle.js.map +1 -1
  72. package/dist/assets/icons/icon-assets-min/16_delete-clear.js +2 -0
  73. package/dist/assets/icons/icon-assets-min/16_delete-clear.js.map +1 -1
  74. package/dist/assets/icons/icon-assets-min/16_download.js +2 -0
  75. package/dist/assets/icons/icon-assets-min/16_download.js.map +1 -1
  76. package/dist/assets/icons/icon-assets-min/16_drag-dots.js +2 -0
  77. package/dist/assets/icons/icon-assets-min/16_drag-dots.js.map +1 -1
  78. package/dist/assets/icons/icon-assets-min/16_duplicate.js +2 -0
  79. package/dist/assets/icons/icon-assets-min/16_duplicate.js.map +1 -1
  80. package/dist/assets/icons/icon-assets-min/16_edit.js +2 -0
  81. package/dist/assets/icons/icon-assets-min/16_edit.js.map +1 -1
  82. package/dist/assets/icons/icon-assets-min/16_error.js +2 -0
  83. package/dist/assets/icons/icon-assets-min/16_error.js.map +1 -1
  84. package/dist/assets/icons/icon-assets-min/16_export.js +2 -0
  85. package/dist/assets/icons/icon-assets-min/16_export.js.map +1 -1
  86. package/dist/assets/icons/icon-assets-min/16_filter-on.js +2 -0
  87. package/dist/assets/icons/icon-assets-min/16_filter-on.js.map +1 -1
  88. package/dist/assets/icons/icon-assets-min/16_filter.js +2 -0
  89. package/dist/assets/icons/icon-assets-min/16_filter.js.map +1 -1
  90. package/dist/assets/icons/icon-assets-min/16_help-outline.js +2 -0
  91. package/dist/assets/icons/icon-assets-min/16_help-outline.js.map +1 -1
  92. package/dist/assets/icons/icon-assets-min/16_help.js +2 -0
  93. package/dist/assets/icons/icon-assets-min/16_help.js.map +1 -1
  94. package/dist/assets/icons/icon-assets-min/16_import.js +2 -0
  95. package/dist/assets/icons/icon-assets-min/16_import.js.map +1 -1
  96. package/dist/assets/icons/icon-assets-min/16_info-outline.js +2 -0
  97. package/dist/assets/icons/icon-assets-min/16_info-outline.js.map +1 -1
  98. package/dist/assets/icons/icon-assets-min/16_info.js +2 -0
  99. package/dist/assets/icons/icon-assets-min/16_info.js.map +1 -1
  100. package/dist/assets/icons/icon-assets-min/16_jump-link.js +2 -0
  101. package/dist/assets/icons/icon-assets-min/16_jump-link.js.map +1 -1
  102. package/dist/assets/icons/icon-assets-min/16_link-arrow.js +2 -0
  103. package/dist/assets/icons/icon-assets-min/16_link-arrow.js.map +1 -1
  104. package/dist/assets/icons/icon-assets-min/16_link.js +2 -0
  105. package/dist/assets/icons/icon-assets-min/16_link.js.map +1 -1
  106. package/dist/assets/icons/icon-assets-min/16_loading.js +2 -0
  107. package/dist/assets/icons/icon-assets-min/16_loading.js.map +1 -1
  108. package/dist/assets/icons/icon-assets-min/16_lock.js +2 -0
  109. package/dist/assets/icons/icon-assets-min/16_lock.js.map +1 -1
  110. package/dist/assets/icons/icon-assets-min/16_maximize.js +2 -0
  111. package/dist/assets/icons/icon-assets-min/16_maximize.js.map +1 -1
  112. package/dist/assets/icons/icon-assets-min/16_minimize.js +2 -0
  113. package/dist/assets/icons/icon-assets-min/16_minimize.js.map +1 -1
  114. package/dist/assets/icons/icon-assets-min/16_minus.js +2 -0
  115. package/dist/assets/icons/icon-assets-min/16_minus.js.map +1 -1
  116. package/dist/assets/icons/icon-assets-min/16_more.js +2 -0
  117. package/dist/assets/icons/icon-assets-min/16_more.js.map +1 -1
  118. package/dist/assets/icons/icon-assets-min/16_open.js +2 -0
  119. package/dist/assets/icons/icon-assets-min/16_open.js.map +1 -1
  120. package/dist/assets/icons/icon-assets-min/16_paper-clip.js +2 -0
  121. package/dist/assets/icons/icon-assets-min/16_paper-clip.js.map +1 -1
  122. package/dist/assets/icons/icon-assets-min/16_pause.js +2 -0
  123. package/dist/assets/icons/icon-assets-min/16_pause.js.map +1 -1
  124. package/dist/assets/icons/icon-assets-min/16_play.js +2 -0
  125. package/dist/assets/icons/icon-assets-min/16_play.js.map +1 -1
  126. package/dist/assets/icons/icon-assets-min/16_progress.js +2 -0
  127. package/dist/assets/icons/icon-assets-min/16_progress.js.map +1 -1
  128. package/dist/assets/icons/icon-assets-min/16_renew.js +2 -0
  129. package/dist/assets/icons/icon-assets-min/16_renew.js.map +1 -1
  130. package/dist/assets/icons/icon-assets-min/16_required.js +2 -0
  131. package/dist/assets/icons/icon-assets-min/16_required.js.map +1 -1
  132. package/dist/assets/icons/icon-assets-min/16_restart.js +2 -0
  133. package/dist/assets/icons/icon-assets-min/16_restart.js.map +1 -1
  134. package/dist/assets/icons/icon-assets-min/16_reverse.js +2 -0
  135. package/dist/assets/icons/icon-assets-min/16_reverse.js.map +1 -1
  136. package/dist/assets/icons/icon-assets-min/16_settings.js +2 -0
  137. package/dist/assets/icons/icon-assets-min/16_settings.js.map +1 -1
  138. package/dist/assets/icons/icon-assets-min/16_sort.js +2 -0
  139. package/dist/assets/icons/icon-assets-min/16_sort.js.map +1 -1
  140. package/dist/assets/icons/icon-assets-min/16_sorter.js +2 -0
  141. package/dist/assets/icons/icon-assets-min/16_sorter.js.map +1 -1
  142. package/dist/assets/icons/icon-assets-min/16_stop.js +2 -0
  143. package/dist/assets/icons/icon-assets-min/16_stop.js.map +1 -1
  144. package/dist/assets/icons/icon-assets-min/16_success.js +2 -0
  145. package/dist/assets/icons/icon-assets-min/16_success.js.map +1 -1
  146. package/dist/assets/icons/icon-assets-min/16_time.js +2 -0
  147. package/dist/assets/icons/icon-assets-min/16_time.js.map +1 -1
  148. package/dist/assets/icons/icon-assets-min/16_tune.js +2 -0
  149. package/dist/assets/icons/icon-assets-min/16_tune.js.map +1 -1
  150. package/dist/assets/icons/icon-assets-min/16_warning.js +2 -0
  151. package/dist/assets/icons/icon-assets-min/16_warning.js.map +1 -1
  152. package/dist/assets/icons/icon-assets-min/16_x-axis.js +2 -0
  153. package/dist/assets/icons/icon-assets-min/16_x-axis.js.map +1 -1
  154. package/dist/assets/icons/icon-assets-min/16_y-axis.js +2 -0
  155. package/dist/assets/icons/icon-assets-min/16_y-axis.js.map +1 -1
  156. package/dist/assets/icons/icon-assets-min/16_zip.js +2 -0
  157. package/dist/assets/icons/icon-assets-min/16_zip.js.map +1 -1
  158. package/dist/assets/icons/icon-assets-min/24_add-layer.js +2 -0
  159. package/dist/assets/icons/icon-assets-min/24_add-layer.js.map +1 -1
  160. package/dist/assets/icons/icon-assets-min/24_add.js +2 -0
  161. package/dist/assets/icons/icon-assets-min/24_add.js.map +1 -1
  162. package/dist/assets/icons/icon-assets-min/24_align-center.js +2 -0
  163. package/dist/assets/icons/icon-assets-min/24_align-center.js.map +1 -1
  164. package/dist/assets/icons/icon-assets-min/24_align-left.js +2 -0
  165. package/dist/assets/icons/icon-assets-min/24_align-left.js.map +1 -1
  166. package/dist/assets/icons/icon-assets-min/24_align-right.js +2 -0
  167. package/dist/assets/icons/icon-assets-min/24_align-right.js.map +1 -1
  168. package/dist/assets/icons/icon-assets-min/24_analytics-accent.js +2 -0
  169. package/dist/assets/icons/icon-assets-min/24_analytics-accent.js.map +1 -1
  170. package/dist/assets/icons/icon-assets-min/24_analytics.js +2 -0
  171. package/dist/assets/icons/icon-assets-min/24_analytics.js.map +1 -1
  172. package/dist/assets/icons/icon-assets-min/24_annotate.js +2 -0
  173. package/dist/assets/icons/icon-assets-min/24_annotate.js.map +1 -1
  174. package/dist/assets/icons/icon-assets-min/24_annotation.js +2 -0
  175. package/dist/assets/icons/icon-assets-min/24_annotation.js.map +1 -1
  176. package/dist/assets/icons/icon-assets-min/24_area.js +2 -0
  177. package/dist/assets/icons/icon-assets-min/24_area.js.map +1 -1
  178. package/dist/assets/icons/icon-assets-min/24_arrow-down.js +2 -0
  179. package/dist/assets/icons/icon-assets-min/24_arrow-down.js.map +1 -1
  180. package/dist/assets/icons/icon-assets-min/24_arrow-left-curved.js +2 -0
  181. package/dist/assets/icons/icon-assets-min/24_arrow-left-curved.js.map +1 -1
  182. package/dist/assets/icons/icon-assets-min/24_arrow-left.js +2 -0
  183. package/dist/assets/icons/icon-assets-min/24_arrow-left.js.map +1 -1
  184. package/dist/assets/icons/icon-assets-min/24_arrow-link.js +2 -0
  185. package/dist/assets/icons/icon-assets-min/24_arrow-link.js.map +1 -1
  186. package/dist/assets/icons/icon-assets-min/24_arrow-right.js +2 -0
  187. package/dist/assets/icons/icon-assets-min/24_arrow-right.js.map +1 -1
  188. package/dist/assets/icons/icon-assets-min/24_arrow-up.js +2 -0
  189. package/dist/assets/icons/icon-assets-min/24_arrow-up.js.map +1 -1
  190. package/dist/assets/icons/icon-assets-min/24_axes.js +2 -0
  191. package/dist/assets/icons/icon-assets-min/24_axes.js.map +1 -1
  192. package/dist/assets/icons/icon-assets-min/24_bar-cross.js +2 -0
  193. package/dist/assets/icons/icon-assets-min/24_bar-cross.js.map +1 -1
  194. package/dist/assets/icons/icon-assets-min/24_bar-error.js +2 -0
  195. package/dist/assets/icons/icon-assets-min/24_bar-error.js.map +1 -1
  196. package/dist/assets/icons/icon-assets-min/24_bar-stacked.js +2 -0
  197. package/dist/assets/icons/icon-assets-min/24_bar-stacked.js.map +1 -1
  198. package/dist/assets/icons/icon-assets-min/24_bar-trend.js +2 -0
  199. package/dist/assets/icons/icon-assets-min/24_bar-trend.js.map +1 -1
  200. package/dist/assets/icons/icon-assets-min/24_bar.js +2 -0
  201. package/dist/assets/icons/icon-assets-min/24_bar.js.map +1 -1
  202. package/dist/assets/icons/icon-assets-min/24_bindot.js +2 -0
  203. package/dist/assets/icons/icon-assets-min/24_bindot.js.map +1 -1
  204. package/dist/assets/icons/icon-assets-min/24_box.js +2 -0
  205. package/dist/assets/icons/icon-assets-min/24_box.js.map +1 -1
  206. package/dist/assets/icons/icon-assets-min/24_boxplot-binned.js +2 -0
  207. package/dist/assets/icons/icon-assets-min/24_boxplot-binned.js.map +1 -1
  208. package/dist/assets/icons/icon-assets-min/24_boxplot-jitter.js +2 -0
  209. package/dist/assets/icons/icon-assets-min/24_boxplot-jitter.js.map +1 -1
  210. package/dist/assets/icons/icon-assets-min/24_boxplot-notched.js +2 -0
  211. package/dist/assets/icons/icon-assets-min/24_boxplot-notched.js.map +1 -1
  212. package/dist/assets/icons/icon-assets-min/24_boxplot.js +2 -0
  213. package/dist/assets/icons/icon-assets-min/24_boxplot.js.map +1 -1
  214. package/dist/assets/icons/icon-assets-min/24_bubble.js +2 -0
  215. package/dist/assets/icons/icon-assets-min/24_bubble.js.map +1 -1
  216. package/dist/assets/icons/icon-assets-min/24_calendar.js +2 -0
  217. package/dist/assets/icons/icon-assets-min/24_calendar.js.map +1 -1
  218. package/dist/assets/icons/icon-assets-min/24_canvas.js +2 -0
  219. package/dist/assets/icons/icon-assets-min/24_canvas.js.map +1 -1
  220. package/dist/assets/icons/icon-assets-min/24_cell-type-num.js +2 -0
  221. package/dist/assets/icons/icon-assets-min/24_cell-type-num.js.map +1 -1
  222. package/dist/assets/icons/icon-assets-min/24_cell-type-subset.js +2 -0
  223. package/dist/assets/icons/icon-assets-min/24_cell-type-subset.js.map +1 -1
  224. package/dist/assets/icons/icon-assets-min/24_cell-type-txt.js +2 -0
  225. package/dist/assets/icons/icon-assets-min/24_cell-type-txt.js.map +1 -1
  226. package/dist/assets/icons/icon-assets-min/24_checkbox-checked.js +2 -0
  227. package/dist/assets/icons/icon-assets-min/24_checkbox-checked.js.map +1 -1
  228. package/dist/assets/icons/icon-assets-min/24_checkbox-intermediate.js +2 -0
  229. package/dist/assets/icons/icon-assets-min/24_checkbox-intermediate.js.map +1 -1
  230. package/dist/assets/icons/icon-assets-min/24_checkbox.js +2 -0
  231. package/dist/assets/icons/icon-assets-min/24_checkbox.js.map +1 -1
  232. package/dist/assets/icons/icon-assets-min/24_checkmark.js +2 -0
  233. package/dist/assets/icons/icon-assets-min/24_checkmark.js.map +1 -1
  234. package/dist/assets/icons/icon-assets-min/24_chevron-down.js +2 -0
  235. package/dist/assets/icons/icon-assets-min/24_chevron-down.js.map +1 -1
  236. package/dist/assets/icons/icon-assets-min/24_chevron-first.js +2 -0
  237. package/dist/assets/icons/icon-assets-min/24_chevron-first.js.map +1 -1
  238. package/dist/assets/icons/icon-assets-min/24_chevron-last.js +2 -0
  239. package/dist/assets/icons/icon-assets-min/24_chevron-last.js.map +1 -1
  240. package/dist/assets/icons/icon-assets-min/24_chevron-left.js +2 -0
  241. package/dist/assets/icons/icon-assets-min/24_chevron-left.js.map +1 -1
  242. package/dist/assets/icons/icon-assets-min/24_chevron-right.js +2 -0
  243. package/dist/assets/icons/icon-assets-min/24_chevron-right.js.map +1 -1
  244. package/dist/assets/icons/icon-assets-min/24_chevron-sort.js +2 -0
  245. package/dist/assets/icons/icon-assets-min/24_chevron-sort.js.map +1 -1
  246. package/dist/assets/icons/icon-assets-min/24_chevron-up.js +2 -0
  247. package/dist/assets/icons/icon-assets-min/24_chevron-up.js.map +1 -1
  248. package/dist/assets/icons/icon-assets-min/24_clipboard-copied.js +2 -0
  249. package/dist/assets/icons/icon-assets-min/24_clipboard-copied.js.map +1 -1
  250. package/dist/assets/icons/icon-assets-min/24_clipboard.js +2 -0
  251. package/dist/assets/icons/icon-assets-min/24_clipboard.js.map +1 -1
  252. package/dist/assets/icons/icon-assets-min/24_close.js +2 -0
  253. package/dist/assets/icons/icon-assets-min/24_close.js.map +1 -1
  254. package/dist/assets/icons/icon-assets-min/24_cloud-download.js +2 -0
  255. package/dist/assets/icons/icon-assets-min/24_cloud-download.js.map +1 -1
  256. package/dist/assets/icons/icon-assets-min/24_cloud-offline.js +2 -0
  257. package/dist/assets/icons/icon-assets-min/24_cloud-offline.js.map +1 -1
  258. package/dist/assets/icons/icon-assets-min/24_cloud-online.js +2 -0
  259. package/dist/assets/icons/icon-assets-min/24_cloud-online.js.map +1 -1
  260. package/dist/assets/icons/icon-assets-min/24_cloud-upload.js +2 -0
  261. package/dist/assets/icons/icon-assets-min/24_cloud-upload.js.map +1 -1
  262. package/dist/assets/icons/icon-assets-min/24_cluster.js +2 -0
  263. package/dist/assets/icons/icon-assets-min/24_cluster.js.map +1 -1
  264. package/dist/assets/icons/icon-assets-min/24_code.js +2 -0
  265. package/dist/assets/icons/icon-assets-min/24_code.js.map +1 -1
  266. package/dist/assets/icons/icon-assets-min/24_color-fill.js +2 -0
  267. package/dist/assets/icons/icon-assets-min/24_color-fill.js.map +1 -1
  268. package/dist/assets/icons/icon-assets-min/24_color-none.js +2 -0
  269. package/dist/assets/icons/icon-assets-min/24_color-none.js.map +1 -1
  270. package/dist/assets/icons/icon-assets-min/24_color-stroke.js +2 -0
  271. package/dist/assets/icons/icon-assets-min/24_color-stroke.js.map +1 -1
  272. package/dist/assets/icons/icon-assets-min/24_color.js +2 -0
  273. package/dist/assets/icons/icon-assets-min/24_color.js.map +1 -1
  274. package/dist/assets/icons/icon-assets-min/24_columns.js +2 -0
  275. package/dist/assets/icons/icon-assets-min/24_columns.js.map +1 -1
  276. package/dist/assets/icons/icon-assets-min/24_connected-points.js +2 -0
  277. package/dist/assets/icons/icon-assets-min/24_connected-points.js.map +1 -1
  278. package/dist/assets/icons/icon-assets-min/24_container.js +2 -0
  279. package/dist/assets/icons/icon-assets-min/24_container.js.map +1 -1
  280. package/dist/assets/icons/icon-assets-min/24_cookie.js +2 -0
  281. package/dist/assets/icons/icon-assets-min/24_cookie.js.map +1 -1
  282. package/dist/assets/icons/icon-assets-min/24_copy.js +2 -0
  283. package/dist/assets/icons/icon-assets-min/24_copy.js.map +1 -1
  284. package/dist/assets/icons/icon-assets-min/24_cpu.js +2 -0
  285. package/dist/assets/icons/icon-assets-min/24_cpu.js.map +1 -1
  286. package/dist/assets/icons/icon-assets-min/24_cursor-pointer.js +2 -0
  287. package/dist/assets/icons/icon-assets-min/24_cursor-pointer.js.map +1 -1
  288. package/dist/assets/icons/icon-assets-min/24_data-dimentions.js +2 -0
  289. package/dist/assets/icons/icon-assets-min/24_data-dimentions.js.map +1 -1
  290. package/dist/assets/icons/icon-assets-min/24_debug.js +2 -0
  291. package/dist/assets/icons/icon-assets-min/24_debug.js.map +1 -1
  292. package/dist/assets/icons/icon-assets-min/24_delete-bin.js +2 -0
  293. package/dist/assets/icons/icon-assets-min/24_delete-bin.js.map +1 -1
  294. package/dist/assets/icons/icon-assets-min/24_delete-circle.js +2 -0
  295. package/dist/assets/icons/icon-assets-min/24_delete-circle.js.map +1 -1
  296. package/dist/assets/icons/icon-assets-min/24_delete-clear.js +2 -0
  297. package/dist/assets/icons/icon-assets-min/24_delete-clear.js.map +1 -1
  298. package/dist/assets/icons/icon-assets-min/24_dendrogram-X-line.js +2 -0
  299. package/dist/assets/icons/icon-assets-min/24_dendrogram-X-line.js.map +1 -1
  300. package/dist/assets/icons/icon-assets-min/24_dendrogram-X.js +2 -0
  301. package/dist/assets/icons/icon-assets-min/24_dendrogram-X.js.map +1 -1
  302. package/dist/assets/icons/icon-assets-min/24_dendrogram-Y-line.js +2 -0
  303. package/dist/assets/icons/icon-assets-min/24_dendrogram-Y-line.js.map +1 -1
  304. package/dist/assets/icons/icon-assets-min/24_dendrogram-Y.js +2 -0
  305. package/dist/assets/icons/icon-assets-min/24_dendrogram-Y.js.map +1 -1
  306. package/dist/assets/icons/icon-assets-min/24_dna-add.js +2 -0
  307. package/dist/assets/icons/icon-assets-min/24_dna-add.js.map +1 -1
  308. package/dist/assets/icons/icon-assets-min/24_dna-import.js +2 -0
  309. package/dist/assets/icons/icon-assets-min/24_dna-import.js.map +1 -1
  310. package/dist/assets/icons/icon-assets-min/24_dna.js +2 -0
  311. package/dist/assets/icons/icon-assets-min/24_dna.js.map +1 -1
  312. package/dist/assets/icons/icon-assets-min/24_download.js +2 -0
  313. package/dist/assets/icons/icon-assets-min/24_download.js.map +1 -1
  314. package/dist/assets/icons/icon-assets-min/24_drag-dots.js +2 -0
  315. package/dist/assets/icons/icon-assets-min/24_drag-dots.js.map +1 -1
  316. package/dist/assets/icons/icon-assets-min/24_drag-horizontal.js +2 -0
  317. package/dist/assets/icons/icon-assets-min/24_drag-horizontal.js.map +1 -1
  318. package/dist/assets/icons/icon-assets-min/24_drag-vertical.js +2 -0
  319. package/dist/assets/icons/icon-assets-min/24_drag-vertical.js.map +1 -1
  320. package/dist/assets/icons/icon-assets-min/24_duplicate.js +2 -0
  321. package/dist/assets/icons/icon-assets-min/24_duplicate.js.map +1 -1
  322. package/dist/assets/icons/icon-assets-min/24_edit.js +2 -0
  323. package/dist/assets/icons/icon-assets-min/24_edit.js.map +1 -1
  324. package/dist/assets/icons/icon-assets-min/24_error-bar.js +2 -0
  325. package/dist/assets/icons/icon-assets-min/24_error-bar.js.map +1 -1
  326. package/dist/assets/icons/icon-assets-min/24_error.js +2 -0
  327. package/dist/assets/icons/icon-assets-min/24_error.js.map +1 -1
  328. package/dist/assets/icons/icon-assets-min/24_expand-left.js +2 -0
  329. package/dist/assets/icons/icon-assets-min/24_expand-left.js.map +1 -1
  330. package/dist/assets/icons/icon-assets-min/24_expand-right.js +2 -0
  331. package/dist/assets/icons/icon-assets-min/24_expand-right.js.map +1 -1
  332. package/dist/assets/icons/icon-assets-min/24_export-2.js +2 -0
  333. package/dist/assets/icons/icon-assets-min/24_export-2.js.map +1 -1
  334. package/dist/assets/icons/icon-assets-min/24_export.js +2 -0
  335. package/dist/assets/icons/icon-assets-min/24_export.js.map +1 -1
  336. package/dist/assets/icons/icon-assets-min/24_external-link.js +2 -0
  337. package/dist/assets/icons/icon-assets-min/24_external-link.js.map +1 -1
  338. package/dist/assets/icons/icon-assets-min/24_file-doc-add.js +2 -0
  339. package/dist/assets/icons/icon-assets-min/24_file-doc-add.js.map +1 -1
  340. package/dist/assets/icons/icon-assets-min/24_file-doc-download.js +2 -0
  341. package/dist/assets/icons/icon-assets-min/24_file-doc-download.js.map +1 -1
  342. package/dist/assets/icons/icon-assets-min/24_file-doc-import.js +2 -0
  343. package/dist/assets/icons/icon-assets-min/24_file-doc-import.js.map +1 -1
  344. package/dist/assets/icons/icon-assets-min/24_file-doc.js +2 -0
  345. package/dist/assets/icons/icon-assets-min/24_file-doc.js.map +1 -1
  346. package/dist/assets/icons/icon-assets-min/24_file-logs-accent.js +2 -0
  347. package/dist/assets/icons/icon-assets-min/24_file-logs-accent.js.map +1 -1
  348. package/dist/assets/icons/icon-assets-min/24_file-logs.js +2 -0
  349. package/dist/assets/icons/icon-assets-min/24_file-logs.js.map +1 -1
  350. package/dist/assets/icons/icon-assets-min/24_files-export.js +2 -0
  351. package/dist/assets/icons/icon-assets-min/24_files-export.js.map +1 -1
  352. package/dist/assets/icons/icon-assets-min/24_files-import.js +2 -0
  353. package/dist/assets/icons/icon-assets-min/24_files-import.js.map +1 -1
  354. package/dist/assets/icons/icon-assets-min/24_filter-on.js +2 -0
  355. package/dist/assets/icons/icon-assets-min/24_filter-on.js.map +1 -1
  356. package/dist/assets/icons/icon-assets-min/24_filter.js +2 -0
  357. package/dist/assets/icons/icon-assets-min/24_filter.js.map +1 -1
  358. package/dist/assets/icons/icon-assets-min/24_fire-tips.js +2 -0
  359. package/dist/assets/icons/icon-assets-min/24_fire-tips.js.map +1 -1
  360. package/dist/assets/icons/icon-assets-min/24_folder-parent.js +2 -0
  361. package/dist/assets/icons/icon-assets-min/24_folder-parent.js.map +1 -1
  362. package/dist/assets/icons/icon-assets-min/24_frame-type-all.js +2 -0
  363. package/dist/assets/icons/icon-assets-min/24_frame-type-all.js.map +1 -1
  364. package/dist/assets/icons/icon-assets-min/24_frame-type-bottom.js +2 -0
  365. package/dist/assets/icons/icon-assets-min/24_frame-type-bottom.js.map +1 -1
  366. package/dist/assets/icons/icon-assets-min/24_frame-type-left-bottom.js +2 -0
  367. package/dist/assets/icons/icon-assets-min/24_frame-type-left-bottom.js.map +1 -1
  368. package/dist/assets/icons/icon-assets-min/24_frame-type-left.js +2 -0
  369. package/dist/assets/icons/icon-assets-min/24_frame-type-left.js.map +1 -1
  370. package/dist/assets/icons/icon-assets-min/24_frame-type-none.js +2 -0
  371. package/dist/assets/icons/icon-assets-min/24_frame-type-none.js.map +1 -1
  372. package/dist/assets/icons/icon-assets-min/24_generate.js +2 -0
  373. package/dist/assets/icons/icon-assets-min/24_generate.js.map +1 -1
  374. package/dist/assets/icons/icon-assets-min/24_graph.js +2 -0
  375. package/dist/assets/icons/icon-assets-min/24_graph.js.map +1 -1
  376. package/dist/assets/icons/icon-assets-min/24_heatmap.js +2 -0
  377. package/dist/assets/icons/icon-assets-min/24_heatmap.js.map +1 -1
  378. package/dist/assets/icons/icon-assets-min/24_help-outline.js +2 -0
  379. package/dist/assets/icons/icon-assets-min/24_help-outline.js.map +1 -1
  380. package/dist/assets/icons/icon-assets-min/24_help.js +2 -0
  381. package/dist/assets/icons/icon-assets-min/24_help.js.map +1 -1
  382. package/dist/assets/icons/icon-assets-min/24_hide.js +2 -0
  383. package/dist/assets/icons/icon-assets-min/24_hide.js.map +1 -1
  384. package/dist/assets/icons/icon-assets-min/24_import.js +2 -0
  385. package/dist/assets/icons/icon-assets-min/24_import.js.map +1 -1
  386. package/dist/assets/icons/icon-assets-min/24_info-outline.js +2 -0
  387. package/dist/assets/icons/icon-assets-min/24_info-outline.js.map +1 -1
  388. package/dist/assets/icons/icon-assets-min/24_info.js +2 -0
  389. package/dist/assets/icons/icon-assets-min/24_info.js.map +1 -1
  390. package/dist/assets/icons/icon-assets-min/24_jitter.js +2 -0
  391. package/dist/assets/icons/icon-assets-min/24_jitter.js.map +1 -1
  392. package/dist/assets/icons/icon-assets-min/24_jump-link.js +2 -0
  393. package/dist/assets/icons/icon-assets-min/24_jump-link.js.map +1 -1
  394. package/dist/assets/icons/icon-assets-min/24_lasso.js +2 -0
  395. package/dist/assets/icons/icon-assets-min/24_lasso.js.map +1 -1
  396. package/dist/assets/icons/icon-assets-min/24_layers.js +2 -0
  397. package/dist/assets/icons/icon-assets-min/24_layers.js.map +1 -1
  398. package/dist/assets/icons/icon-assets-min/24_learn.js +2 -0
  399. package/dist/assets/icons/icon-assets-min/24_learn.js.map +1 -1
  400. package/dist/assets/icons/icon-assets-min/24_legend-box-dot.js +2 -0
  401. package/dist/assets/icons/icon-assets-min/24_legend-box-dot.js.map +1 -1
  402. package/dist/assets/icons/icon-assets-min/24_legend-box.js +2 -0
  403. package/dist/assets/icons/icon-assets-min/24_legend-box.js.map +1 -1
  404. package/dist/assets/icons/icon-assets-min/24_legend.js +2 -0
  405. package/dist/assets/icons/icon-assets-min/24_legend.js.map +1 -1
  406. package/dist/assets/icons/icon-assets-min/24_line-binned.js +2 -0
  407. package/dist/assets/icons/icon-assets-min/24_line-binned.js.map +1 -1
  408. package/dist/assets/icons/icon-assets-min/24_line-error.js +2 -0
  409. package/dist/assets/icons/icon-assets-min/24_line-error.js.map +1 -1
  410. package/dist/assets/icons/icon-assets-min/24_line-jitter.js +2 -0
  411. package/dist/assets/icons/icon-assets-min/24_line-jitter.js.map +1 -1
  412. package/dist/assets/icons/icon-assets-min/24_line.js +2 -0
  413. package/dist/assets/icons/icon-assets-min/24_line.js.map +1 -1
  414. package/dist/assets/icons/icon-assets-min/24_linetype-dashed.js +2 -0
  415. package/dist/assets/icons/icon-assets-min/24_linetype-dashed.js.map +1 -1
  416. package/dist/assets/icons/icon-assets-min/24_linetype-dotdash.js +2 -0
  417. package/dist/assets/icons/icon-assets-min/24_linetype-dotdash.js.map +1 -1
  418. package/dist/assets/icons/icon-assets-min/24_linetype-dotted.js +2 -0
  419. package/dist/assets/icons/icon-assets-min/24_linetype-dotted.js.map +1 -1
  420. package/dist/assets/icons/icon-assets-min/24_linetype-longdash.js +2 -0
  421. package/dist/assets/icons/icon-assets-min/24_linetype-longdash.js.map +1 -1
  422. package/dist/assets/icons/icon-assets-min/24_linetype-solid.js +2 -0
  423. package/dist/assets/icons/icon-assets-min/24_linetype-solid.js.map +1 -1
  424. package/dist/assets/icons/icon-assets-min/24_linetype-twodash.js +2 -0
  425. package/dist/assets/icons/icon-assets-min/24_linetype-twodash.js.map +1 -1
  426. package/dist/assets/icons/icon-assets-min/24_link-disabled.js +2 -0
  427. package/dist/assets/icons/icon-assets-min/24_link-disabled.js.map +1 -1
  428. package/dist/assets/icons/icon-assets-min/24_link.js +2 -0
  429. package/dist/assets/icons/icon-assets-min/24_link.js.map +1 -1
  430. package/dist/assets/icons/icon-assets-min/24_loading.js +2 -0
  431. package/dist/assets/icons/icon-assets-min/24_loading.js.map +1 -1
  432. package/dist/assets/icons/icon-assets-min/24_lock.js +2 -0
  433. package/dist/assets/icons/icon-assets-min/24_lock.js.map +1 -1
  434. package/dist/assets/icons/icon-assets-min/24_maximize.js +2 -0
  435. package/dist/assets/icons/icon-assets-min/24_maximize.js.map +1 -1
  436. package/dist/assets/icons/icon-assets-min/24_menu.js +2 -0
  437. package/dist/assets/icons/icon-assets-min/24_menu.js.map +1 -1
  438. package/dist/assets/icons/icon-assets-min/24_minimize.js +2 -0
  439. package/dist/assets/icons/icon-assets-min/24_minimize.js.map +1 -1
  440. package/dist/assets/icons/icon-assets-min/24_minus.js +2 -0
  441. package/dist/assets/icons/icon-assets-min/24_minus.js.map +1 -1
  442. package/dist/assets/icons/icon-assets-min/24_monetization-off.js +2 -0
  443. package/dist/assets/icons/icon-assets-min/24_monetization-off.js.map +1 -1
  444. package/dist/assets/icons/icon-assets-min/24_monetization-on.js +2 -0
  445. package/dist/assets/icons/icon-assets-min/24_monetization-on.js.map +1 -1
  446. package/dist/assets/icons/icon-assets-min/24_monetization.js +2 -0
  447. package/dist/assets/icons/icon-assets-min/24_monetization.js.map +1 -1
  448. package/dist/assets/icons/icon-assets-min/24_more.js +2 -0
  449. package/dist/assets/icons/icon-assets-min/24_more.js.map +1 -1
  450. package/dist/assets/icons/icon-assets-min/24_paper-clip.js +2 -0
  451. package/dist/assets/icons/icon-assets-min/24_paper-clip.js.map +1 -1
  452. package/dist/assets/icons/icon-assets-min/24_pause.js +2 -0
  453. package/dist/assets/icons/icon-assets-min/24_pause.js.map +1 -1
  454. package/dist/assets/icons/icon-assets-min/24_pen-tool.js +2 -0
  455. package/dist/assets/icons/icon-assets-min/24_pen-tool.js.map +1 -1
  456. package/dist/assets/icons/icon-assets-min/24_pin.js +2 -0
  457. package/dist/assets/icons/icon-assets-min/24_pin.js.map +1 -1
  458. package/dist/assets/icons/icon-assets-min/24_play.js +2 -0
  459. package/dist/assets/icons/icon-assets-min/24_play.js.map +1 -1
  460. package/dist/assets/icons/icon-assets-min/24_position-bottom-annotation.js +2 -0
  461. package/dist/assets/icons/icon-assets-min/24_position-bottom-annotation.js.map +1 -1
  462. package/dist/assets/icons/icon-assets-min/24_position-bottom.js +2 -0
  463. package/dist/assets/icons/icon-assets-min/24_position-bottom.js.map +1 -1
  464. package/dist/assets/icons/icon-assets-min/24_position-left-annotation.js +2 -0
  465. package/dist/assets/icons/icon-assets-min/24_position-left-annotation.js.map +1 -1
  466. package/dist/assets/icons/icon-assets-min/24_position-left.js +2 -0
  467. package/dist/assets/icons/icon-assets-min/24_position-left.js.map +1 -1
  468. package/dist/assets/icons/icon-assets-min/24_position-right-annotation.js +2 -0
  469. package/dist/assets/icons/icon-assets-min/24_position-right-annotation.js.map +1 -1
  470. package/dist/assets/icons/icon-assets-min/24_position-right.js +2 -0
  471. package/dist/assets/icons/icon-assets-min/24_position-right.js.map +1 -1
  472. package/dist/assets/icons/icon-assets-min/24_position-top-annotation.js +2 -0
  473. package/dist/assets/icons/icon-assets-min/24_position-top-annotation.js.map +1 -1
  474. package/dist/assets/icons/icon-assets-min/24_position-top.js +2 -0
  475. package/dist/assets/icons/icon-assets-min/24_position-top.js.map +1 -1
  476. package/dist/assets/icons/icon-assets-min/24_product.js +2 -0
  477. package/dist/assets/icons/icon-assets-min/24_product.js.map +1 -1
  478. package/dist/assets/icons/icon-assets-min/24_progress.js +2 -0
  479. package/dist/assets/icons/icon-assets-min/24_progress.js.map +1 -1
  480. package/dist/assets/icons/icon-assets-min/24_publications.js +2 -0
  481. package/dist/assets/icons/icon-assets-min/24_publications.js.map +1 -1
  482. package/dist/assets/icons/icon-assets-min/24_radio-button-checked.js +2 -0
  483. package/dist/assets/icons/icon-assets-min/24_radio-button-checked.js.map +1 -1
  484. package/dist/assets/icons/icon-assets-min/24_radio-button.js +2 -0
  485. package/dist/assets/icons/icon-assets-min/24_radio-button.js.map +1 -1
  486. package/dist/assets/icons/icon-assets-min/24_renew.js +2 -0
  487. package/dist/assets/icons/icon-assets-min/24_renew.js.map +1 -1
  488. package/dist/assets/icons/icon-assets-min/24_restart.js +2 -0
  489. package/dist/assets/icons/icon-assets-min/24_restart.js.map +1 -1
  490. package/dist/assets/icons/icon-assets-min/24_reverse.js +2 -0
  491. package/dist/assets/icons/icon-assets-min/24_reverse.js.map +1 -1
  492. package/dist/assets/icons/icon-assets-min/24_rotation-0.js +2 -0
  493. package/dist/assets/icons/icon-assets-min/24_rotation-0.js.map +1 -1
  494. package/dist/assets/icons/icon-assets-min/24_rotation-45.js +2 -0
  495. package/dist/assets/icons/icon-assets-min/24_rotation-45.js.map +1 -1
  496. package/dist/assets/icons/icon-assets-min/24_rotation-90.js +2 -0
  497. package/dist/assets/icons/icon-assets-min/24_rotation-90.js.map +1 -1
  498. package/dist/assets/icons/icon-assets-min/24_search.js +2 -0
  499. package/dist/assets/icons/icon-assets-min/24_search.js.map +1 -1
  500. package/dist/assets/icons/icon-assets-min/24_server-on.js +2 -0
  501. package/dist/assets/icons/icon-assets-min/24_server-on.js.map +1 -1
  502. package/dist/assets/icons/icon-assets-min/24_server.js +2 -0
  503. package/dist/assets/icons/icon-assets-min/24_server.js.map +1 -1
  504. package/dist/assets/icons/icon-assets-min/24_settings.js +2 -0
  505. package/dist/assets/icons/icon-assets-min/24_settings.js.map +1 -1
  506. package/dist/assets/icons/icon-assets-min/24_show.js +2 -0
  507. package/dist/assets/icons/icon-assets-min/24_show.js.map +1 -1
  508. package/dist/assets/icons/icon-assets-min/24_sina.js +2 -0
  509. package/dist/assets/icons/icon-assets-min/24_sina.js.map +1 -1
  510. package/dist/assets/icons/icon-assets-min/24_skatterplot.js +2 -0
  511. package/dist/assets/icons/icon-assets-min/24_skatterplot.js.map +1 -1
  512. package/dist/assets/icons/icon-assets-min/24_slice.js +2 -0
  513. package/dist/assets/icons/icon-assets-min/24_slice.js.map +1 -1
  514. package/dist/assets/icons/icon-assets-min/24_social-github.js +2 -0
  515. package/dist/assets/icons/icon-assets-min/24_social-github.js.map +1 -1
  516. package/dist/assets/icons/icon-assets-min/24_social-linkedin.js +2 -0
  517. package/dist/assets/icons/icon-assets-min/24_social-linkedin.js.map +1 -1
  518. package/dist/assets/icons/icon-assets-min/24_social-twitter-X.js +2 -0
  519. package/dist/assets/icons/icon-assets-min/24_social-twitter-X.js.map +1 -1
  520. package/dist/assets/icons/icon-assets-min/24_social-twitter-bird.js +2 -0
  521. package/dist/assets/icons/icon-assets-min/24_social-twitter-bird.js.map +1 -1
  522. package/dist/assets/icons/icon-assets-min/24_social-youtube.js +2 -0
  523. package/dist/assets/icons/icon-assets-min/24_social-youtube.js.map +1 -1
  524. package/dist/assets/icons/icon-assets-min/24_sort-list-down.js +2 -0
  525. package/dist/assets/icons/icon-assets-min/24_sort-list-down.js.map +1 -1
  526. package/dist/assets/icons/icon-assets-min/24_sort-list-up.js +2 -0
  527. package/dist/assets/icons/icon-assets-min/24_sort-list-up.js.map +1 -1
  528. package/dist/assets/icons/icon-assets-min/24_sort.js +2 -0
  529. package/dist/assets/icons/icon-assets-min/24_sort.js.map +1 -1
  530. package/dist/assets/icons/icon-assets-min/24_statistics.js +2 -0
  531. package/dist/assets/icons/icon-assets-min/24_statistics.js.map +1 -1
  532. package/dist/assets/icons/icon-assets-min/24_stop.js +2 -0
  533. package/dist/assets/icons/icon-assets-min/24_stop.js.map +1 -1
  534. package/dist/assets/icons/icon-assets-min/24_strip-plot.js +2 -0
  535. package/dist/assets/icons/icon-assets-min/24_strip-plot.js.map +1 -1
  536. package/dist/assets/icons/icon-assets-min/24_success.js +2 -0
  537. package/dist/assets/icons/icon-assets-min/24_success.js.map +1 -1
  538. package/dist/assets/icons/icon-assets-min/24_table-add.js +2 -0
  539. package/dist/assets/icons/icon-assets-min/24_table-add.js.map +1 -1
  540. package/dist/assets/icons/icon-assets-min/24_table-alias.js +2 -0
  541. package/dist/assets/icons/icon-assets-min/24_table-alias.js.map +1 -1
  542. package/dist/assets/icons/icon-assets-min/24_table-import.js +2 -0
  543. package/dist/assets/icons/icon-assets-min/24_table-import.js.map +1 -1
  544. package/dist/assets/icons/icon-assets-min/24_table-upload.js +2 -0
  545. package/dist/assets/icons/icon-assets-min/24_table-upload.js.map +1 -1
  546. package/dist/assets/icons/icon-assets-min/24_table.js +2 -0
  547. package/dist/assets/icons/icon-assets-min/24_table.js.map +1 -1
  548. package/dist/assets/icons/icon-assets-min/24_template.js +2 -0
  549. package/dist/assets/icons/icon-assets-min/24_template.js.map +1 -1
  550. package/dist/assets/icons/icon-assets-min/24_terminal.js +2 -0
  551. package/dist/assets/icons/icon-assets-min/24_terminal.js.map +1 -1
  552. package/dist/assets/icons/icon-assets-min/24_text-align-center.js +2 -0
  553. package/dist/assets/icons/icon-assets-min/24_text-align-center.js.map +1 -1
  554. package/dist/assets/icons/icon-assets-min/24_text-align-left.js +2 -0
  555. package/dist/assets/icons/icon-assets-min/24_text-align-left.js.map +1 -1
  556. package/dist/assets/icons/icon-assets-min/24_text-align-right.js +2 -0
  557. package/dist/assets/icons/icon-assets-min/24_text-align-right.js.map +1 -1
  558. package/dist/assets/icons/icon-assets-min/24_theme-dark.js +2 -0
  559. package/dist/assets/icons/icon-assets-min/24_theme-dark.js.map +1 -1
  560. package/dist/assets/icons/icon-assets-min/24_theme-light.js +2 -0
  561. package/dist/assets/icons/icon-assets-min/24_theme-light.js.map +1 -1
  562. package/dist/assets/icons/icon-assets-min/24_time.js +2 -0
  563. package/dist/assets/icons/icon-assets-min/24_time.js.map +1 -1
  564. package/dist/assets/icons/icon-assets-min/24_title-position.js +2 -0
  565. package/dist/assets/icons/icon-assets-min/24_title-position.js.map +1 -1
  566. package/dist/assets/icons/icon-assets-min/24_tune.js +2 -0
  567. package/dist/assets/icons/icon-assets-min/24_tune.js.map +1 -1
  568. package/dist/assets/icons/icon-assets-min/24_venn.js +2 -0
  569. package/dist/assets/icons/icon-assets-min/24_venn.js.map +1 -1
  570. package/dist/assets/icons/icon-assets-min/24_view-hide.js +2 -0
  571. package/dist/assets/icons/icon-assets-min/24_view-hide.js.map +1 -1
  572. package/dist/assets/icons/icon-assets-min/24_view-show.js +2 -0
  573. package/dist/assets/icons/icon-assets-min/24_view-show.js.map +1 -1
  574. package/dist/assets/icons/icon-assets-min/24_violin-binned.js +2 -0
  575. package/dist/assets/icons/icon-assets-min/24_violin-binned.js.map +1 -1
  576. package/dist/assets/icons/icon-assets-min/24_violin-jitter.js +2 -0
  577. package/dist/assets/icons/icon-assets-min/24_violin-jitter.js.map +1 -1
  578. package/dist/assets/icons/icon-assets-min/24_violin.js +2 -0
  579. package/dist/assets/icons/icon-assets-min/24_violin.js.map +1 -1
  580. package/dist/assets/icons/icon-assets-min/24_warning.js +2 -0
  581. package/dist/assets/icons/icon-assets-min/24_warning.js.map +1 -1
  582. package/dist/assets/icons/icon-assets-min/24_wetlab.js +2 -0
  583. package/dist/assets/icons/icon-assets-min/24_wetlab.js.map +1 -1
  584. package/dist/assets/icons/icon-assets-min/24_windows-collapse.js +2 -0
  585. package/dist/assets/icons/icon-assets-min/24_windows-collapse.js.map +1 -1
  586. package/dist/assets/icons/icon-assets-min/24_windows-expand.js +2 -0
  587. package/dist/assets/icons/icon-assets-min/24_windows-expand.js.map +1 -1
  588. package/dist/assets/icons/icon-assets-min/24_x-axis.js +2 -0
  589. package/dist/assets/icons/icon-assets-min/24_x-axis.js.map +1 -1
  590. package/dist/assets/icons/icon-assets-min/24_y-axis.js +2 -0
  591. package/dist/assets/icons/icon-assets-min/24_y-axis.js.map +1 -1
  592. package/dist/assets/icons/icon-assets-min/24_zip.js +2 -0
  593. package/dist/assets/icons/icon-assets-min/24_zip.js.map +1 -1
  594. package/dist/assets/icons/icon-assets-min/24_zoom-in.js +2 -0
  595. package/dist/assets/icons/icon-assets-min/24_zoom-in.js.map +1 -1
  596. package/dist/assets/icons/icon-assets-min/24_zoom-out.js +2 -0
  597. package/dist/assets/icons/icon-assets-min/24_zoom-out.js.map +1 -1
  598. package/dist/assets/images/24_checkbox-light-enabled-checked.js +2 -0
  599. package/dist/assets/images/24_checkbox-light-enabled-checked.js.map +1 -1
  600. package/dist/assets/images/24_checkbox-light-enabled-unchecked.js +2 -0
  601. package/dist/assets/images/24_checkbox-light-enabled-unchecked.js.map +1 -1
  602. package/dist/assets/images/required.js +2 -0
  603. package/dist/assets/images/required.js.map +1 -1
  604. package/dist/base/BtnBase.js +2 -0
  605. package/dist/base/BtnBase.vue2.js +2 -0
  606. package/dist/base/BtnBase.vue2.js.map +1 -1
  607. package/dist/colors/color.js +2 -9
  608. package/dist/colors/color.js.map +1 -1
  609. package/dist/colors/gradient.js +1 -34
  610. package/dist/colors/gradient.js.map +1 -1
  611. package/dist/colors/palette.js +3 -4
  612. package/dist/colors/palette.js.map +1 -1
  613. package/dist/components/ContextProvider.js +2 -0
  614. package/dist/components/ContextProvider.vue2.js +2 -0
  615. package/dist/components/ContextProvider.vue2.js.map +1 -1
  616. package/dist/components/DataTable/BaseCellComponent.js +2 -0
  617. package/dist/components/DataTable/BaseCellComponent.vue2.js +2 -0
  618. package/dist/components/DataTable/BaseCellComponent.vue2.js.map +1 -1
  619. package/dist/components/DataTable/ColumnCaret.js +2 -0
  620. package/dist/components/DataTable/ColumnCaret.vue2.js +2 -0
  621. package/dist/components/DataTable/ColumnCaret.vue2.js.map +1 -1
  622. package/dist/components/DataTable/ColumnsCommandMenu.js +2 -0
  623. package/dist/components/DataTable/ColumnsCommandMenu.vue2.js +2 -0
  624. package/dist/components/DataTable/ColumnsCommandMenu.vue2.js.map +1 -1
  625. package/dist/components/DataTable/RowsCommandMenu.js +2 -0
  626. package/dist/components/DataTable/RowsCommandMenu.vue2.js +2 -0
  627. package/dist/components/DataTable/RowsCommandMenu.vue2.js.map +1 -1
  628. package/dist/components/DataTable/TScroll.js +2 -0
  629. package/dist/components/DataTable/TScroll.vue2.js +2 -0
  630. package/dist/components/DataTable/TScroll.vue2.js.map +1 -1
  631. package/dist/components/DataTable/TableComponent.js +2 -0
  632. package/dist/components/DataTable/TableComponent.vue2.js +2 -0
  633. package/dist/components/DataTable/TableComponent.vue2.js.map +1 -1
  634. package/dist/components/DataTable/TdCell.js +2 -0
  635. package/dist/components/DataTable/TdCell.vue2.js +2 -0
  636. package/dist/components/DataTable/TdCell.vue2.js.map +1 -1
  637. package/dist/components/DataTable/ThCell.js +2 -0
  638. package/dist/components/DataTable/ThCell.vue2.js +2 -0
  639. package/dist/components/DataTable/ThCell.vue2.js.map +1 -1
  640. package/dist/components/DataTable/TrBody.js +2 -0
  641. package/dist/components/DataTable/TrBody.vue2.js +2 -0
  642. package/dist/components/DataTable/TrBody.vue2.js.map +1 -1
  643. package/dist/components/DataTable/TrHead.js +2 -0
  644. package/dist/components/DataTable/TrHead.vue2.js +2 -0
  645. package/dist/components/DataTable/TrHead.vue2.js.map +1 -1
  646. package/dist/components/DataTable/adapters/AsyncData.js +2 -0
  647. package/dist/components/DataTable/adapters/AsyncData.js.map +1 -1
  648. package/dist/components/DataTable/adapters/RawData.js +2 -0
  649. package/dist/components/DataTable/adapters/RawData.js.map +1 -1
  650. package/dist/components/DataTable/assets/TableIcon.js +2 -0
  651. package/dist/components/DataTable/assets/TableIcon.js.map +1 -1
  652. package/dist/components/DataTable/composition/useColumn.js +2 -0
  653. package/dist/components/DataTable/composition/useColumn.js.map +1 -1
  654. package/dist/components/DataTable/composition/useMouseUp.js +2 -0
  655. package/dist/components/DataTable/composition/useMouseUp.js.map +1 -1
  656. package/dist/components/DataTable/composition/useResize.js +2 -0
  657. package/dist/components/DataTable/composition/useResize.js.map +1 -1
  658. package/dist/components/DataTable/composition/useTableColumns.js +2 -0
  659. package/dist/components/DataTable/composition/useTableColumns.js.map +1 -1
  660. package/dist/components/DataTable/composition/useTableRows.js +2 -0
  661. package/dist/components/DataTable/composition/useTableRows.js.map +1 -1
  662. package/dist/components/DataTable/domain.js +2 -6
  663. package/dist/components/DataTable/domain.js.map +1 -1
  664. package/dist/components/DataTable/index.js +2 -7
  665. package/dist/components/DataTable/index.js.map +1 -1
  666. package/dist/components/DataTable/keys.js +3 -1
  667. package/dist/components/DataTable/keys.js.map +1 -1
  668. package/dist/components/DataTable/state.js +2 -0
  669. package/dist/components/DataTable/state.js.map +1 -1
  670. package/dist/components/DropdownListItem.js +2 -0
  671. package/dist/components/DropdownListItem.vue2.js +2 -0
  672. package/dist/components/DropdownListItem.vue2.js.map +1 -1
  673. package/dist/components/HScroll.js +2 -0
  674. package/dist/components/HScroll.vue2.js +2 -0
  675. package/dist/components/HScroll.vue2.js.map +1 -1
  676. package/dist/components/InputRange.js +2 -0
  677. package/dist/components/InputRange.vue2.js +2 -0
  678. package/dist/components/InputRange.vue2.js.map +1 -1
  679. package/dist/components/LongText.js +2 -0
  680. package/dist/components/LongText.vue2.js +2 -0
  681. package/dist/components/LongText.vue2.js.map +1 -1
  682. package/dist/components/PlAccordion/ExpandTransition.js +2 -0
  683. package/dist/components/PlAccordion/ExpandTransition.vue2.js +2 -0
  684. package/dist/components/PlAccordion/ExpandTransition.vue2.js.map +1 -1
  685. package/dist/components/PlAccordion/PlAccordion.js +2 -0
  686. package/dist/components/PlAccordion/PlAccordion.vue2.js +2 -0
  687. package/dist/components/PlAccordion/PlAccordion.vue2.js.map +1 -1
  688. package/dist/components/PlAccordion/PlAccordionSection.js +1 -0
  689. package/dist/components/PlAccordion/PlAccordionSection.style.js +1 -0
  690. package/dist/components/PlAccordion/PlAccordionSection.vue2.js +2 -0
  691. package/dist/components/PlAccordion/PlAccordionSection.vue2.js.map +1 -1
  692. package/dist/components/PlAlert/PlAlert.js +2 -0
  693. package/dist/components/PlAlert/PlAlert.vue2.js +2 -0
  694. package/dist/components/PlAlert/PlAlert.vue2.js.map +1 -1
  695. package/dist/components/PlAutocomplete/PlAutocomplete.js +2 -0
  696. package/dist/components/PlAutocomplete/PlAutocomplete.vue2.js +2 -0
  697. package/dist/components/PlAutocomplete/PlAutocomplete.vue2.js.map +1 -1
  698. package/dist/components/PlAutocompleteMulti/PlAutocompleteMulti.js +2 -0
  699. package/dist/components/PlAutocompleteMulti/PlAutocompleteMulti.vue2.js +2 -0
  700. package/dist/components/PlAutocompleteMulti/PlAutocompleteMulti.vue2.js.map +1 -1
  701. package/dist/components/PlBtnAccent/PlBtnAccent.js +2 -0
  702. package/dist/components/PlBtnAccent/PlBtnAccent.vue2.js +1 -0
  703. package/dist/components/PlBtnDanger/PlBtnDanger.js +2 -0
  704. package/dist/components/PlBtnDanger/PlBtnDanger.vue2.js +1 -0
  705. package/dist/components/PlBtnGhost/PlBtnGhost.js +2 -0
  706. package/dist/components/PlBtnGhost/PlBtnGhost.vue2.js +2 -0
  707. package/dist/components/PlBtnGhost/PlBtnGhost.vue2.js.map +1 -1
  708. package/dist/components/PlBtnGroup/PlBtnGroup.js +2 -0
  709. package/dist/components/PlBtnGroup/PlBtnGroup.vue2.js +2 -0
  710. package/dist/components/PlBtnGroup/PlBtnGroup.vue2.js.map +1 -1
  711. package/dist/components/PlBtnLink/PlBtnLink.js +2 -0
  712. package/dist/components/PlBtnLink/PlBtnLink.vue2.js +2 -0
  713. package/dist/components/PlBtnLink/PlBtnLink.vue2.js.map +1 -1
  714. package/dist/components/PlBtnPrimary/PlBtnPrimary.js +2 -0
  715. package/dist/components/PlBtnPrimary/PlBtnPrimary.vue2.js +1 -0
  716. package/dist/components/PlBtnSecondary/PlBtnSecondary.js +2 -0
  717. package/dist/components/PlBtnSecondary/PlBtnSecondary.vue2.js +1 -0
  718. package/dist/components/PlBtnSplit/PlBtnSplit.js +2 -0
  719. package/dist/components/PlBtnSplit/PlBtnSplit.vue2.js +2 -0
  720. package/dist/components/PlBtnSplit/PlBtnSplit.vue2.js.map +1 -1
  721. package/dist/components/PlChartHistogram/PlChartHistogram.js +1 -0
  722. package/dist/components/PlChartHistogram/PlChartHistogram.style.js +1 -0
  723. package/dist/components/PlChartHistogram/PlChartHistogram.vue2.js +2 -0
  724. package/dist/components/PlChartHistogram/PlChartHistogram.vue2.js.map +1 -1
  725. package/dist/components/PlChartHistogram/createGridlines.js +2 -0
  726. package/dist/components/PlChartHistogram/createGridlines.js.map +1 -1
  727. package/dist/components/PlChartHistogram/createLabels.js +2 -0
  728. package/dist/components/PlChartHistogram/createLabels.js.map +1 -1
  729. package/dist/components/PlChartHistogram/createSvgContainer.js +2 -0
  730. package/dist/components/PlChartHistogram/createSvgContainer.js.map +1 -1
  731. package/dist/components/PlChartHistogram/drawBins.js +2 -0
  732. package/dist/components/PlChartHistogram/drawBins.js.map +1 -1
  733. package/dist/components/PlChartHistogram/drawThreshold.js +2 -0
  734. package/dist/components/PlChartHistogram/drawThreshold.js.map +1 -1
  735. package/dist/components/PlChartHistogram/histogram.js +2 -0
  736. package/dist/components/PlChartHistogram/histogram.js.map +1 -1
  737. package/dist/components/PlChartHistogram/logspace.js +2 -0
  738. package/dist/components/PlChartHistogram/logspace.js.map +1 -1
  739. package/dist/components/PlChartHistogram/normalizeBins.js +2 -0
  740. package/dist/components/PlChartHistogram/normalizeBins.js.map +1 -1
  741. package/dist/components/PlChartStackedBar/Legends.js +1 -0
  742. package/dist/components/PlChartStackedBar/Legends.style.js +1 -0
  743. package/dist/components/PlChartStackedBar/Legends.vue2.js +2 -0
  744. package/dist/components/PlChartStackedBar/Legends.vue2.js.map +1 -1
  745. package/dist/components/PlChartStackedBar/PlChartStackedBar.js +1 -0
  746. package/dist/components/PlChartStackedBar/PlChartStackedBar.style.js +1 -0
  747. package/dist/components/PlChartStackedBar/PlChartStackedBar.vue2.js +2 -0
  748. package/dist/components/PlChartStackedBar/PlChartStackedBar.vue2.js.map +1 -1
  749. package/dist/components/PlChartStackedBar/PlChartStackedBarCompact.js +1 -0
  750. package/dist/components/PlChartStackedBar/PlChartStackedBarCompact.style.js +1 -0
  751. package/dist/components/PlChartStackedBar/PlChartStackedBarCompact.vue2.js +2 -0
  752. package/dist/components/PlChartStackedBar/PlChartStackedBarCompact.vue2.js.map +1 -1
  753. package/dist/components/PlChartStackedBar/StackedRow.js +1 -0
  754. package/dist/components/PlChartStackedBar/StackedRow.style.js +1 -0
  755. package/dist/components/PlChartStackedBar/StackedRow.vue2.js +2 -0
  756. package/dist/components/PlChartStackedBar/StackedRow.vue2.js.map +1 -1
  757. package/dist/components/PlChartStackedBar/StackedRowCompact.js +1 -0
  758. package/dist/components/PlChartStackedBar/StackedRowCompact.style.js +1 -0
  759. package/dist/components/PlChartStackedBar/StackedRowCompact.vue2.js +2 -0
  760. package/dist/components/PlChartStackedBar/StackedRowCompact.vue2.js.map +1 -1
  761. package/dist/components/PlCheckbox/PlCheckbox.js +2 -0
  762. package/dist/components/PlCheckbox/PlCheckbox.vue2.js +1 -0
  763. package/dist/components/PlCheckbox/PlCheckboxBase.js +2 -0
  764. package/dist/components/PlCheckbox/PlCheckboxBase.vue2.js +2 -0
  765. package/dist/components/PlCheckbox/PlCheckboxBase.vue2.js.map +1 -1
  766. package/dist/components/PlCheckboxGroup/PlCheckboxGroup.js +2 -0
  767. package/dist/components/PlCheckboxGroup/PlCheckboxGroup.vue2.js +2 -0
  768. package/dist/components/PlCheckboxGroup/PlCheckboxGroup.vue2.js.map +1 -1
  769. package/dist/components/PlChip/PlChip.js +2 -0
  770. package/dist/components/PlChip/PlChip.vue2.js +2 -0
  771. package/dist/components/PlChip/PlChip.vue2.js.map +1 -1
  772. package/dist/components/PlClipboard/PlClipboard.js +1 -0
  773. package/dist/components/PlClipboard/PlClipboard.style.js +1 -0
  774. package/dist/components/PlClipboard/PlClipboard.vue2.js +1 -0
  775. package/dist/components/PlConfirmDialog.js +2 -0
  776. package/dist/components/PlConfirmDialog.vue2.js +2 -0
  777. package/dist/components/PlConfirmDialog.vue2.js.map +1 -1
  778. package/dist/components/PlDialogModal/PlDialogModal.js +2 -0
  779. package/dist/components/PlDialogModal/PlDialogModal.js.map +1 -1
  780. package/dist/components/PlDialogModal/PlDialogModal.vue.d.ts +1 -0
  781. package/dist/components/PlDialogModal/PlDialogModal.vue.d.ts.map +1 -1
  782. package/dist/components/PlDialogModal/PlDialogModal.vue2.js +6 -1
  783. package/dist/components/PlDialogModal/PlDialogModal.vue2.js.map +1 -1
  784. package/dist/components/PlDropdown/OptionList.js +2 -0
  785. package/dist/components/PlDropdown/OptionList.vue2.js +2 -0
  786. package/dist/components/PlDropdown/OptionList.vue2.js.map +1 -1
  787. package/dist/components/PlDropdown/PlDropdown.js +2 -0
  788. package/dist/components/PlDropdown/PlDropdown.vue2.js +2 -0
  789. package/dist/components/PlDropdown/PlDropdown.vue2.js.map +1 -1
  790. package/dist/components/PlDropdown/useGroupBy.js +2 -0
  791. package/dist/components/PlDropdown/useGroupBy.js.map +1 -1
  792. package/dist/components/PlDropdownLegacy/PlDropdownLegacy.js +2 -0
  793. package/dist/components/PlDropdownLegacy/PlDropdownLegacy.vue2.js +2 -0
  794. package/dist/components/PlDropdownLegacy/PlDropdownLegacy.vue2.js.map +1 -1
  795. package/dist/components/PlDropdownLine/PlDropdownLine.js +2 -0
  796. package/dist/components/PlDropdownLine/PlDropdownLine.vue2.js +2 -0
  797. package/dist/components/PlDropdownLine/PlDropdownLine.vue2.js.map +1 -1
  798. package/dist/components/PlDropdownLine/ResizableInput.js +2 -0
  799. package/dist/components/PlDropdownLine/ResizableInput.vue2.js +2 -0
  800. package/dist/components/PlDropdownLine/ResizableInput.vue2.js.map +1 -1
  801. package/dist/components/PlDropdownMulti/PlDropdownMulti.js +2 -0
  802. package/dist/components/PlDropdownMulti/PlDropdownMulti.vue2.js +2 -0
  803. package/dist/components/PlDropdownMulti/PlDropdownMulti.vue2.js.map +1 -1
  804. package/dist/components/PlDropdownMultiRef/PlDropdownMultiRef.js +2 -0
  805. package/dist/components/PlDropdownMultiRef/PlDropdownMultiRef.vue2.js +2 -0
  806. package/dist/components/PlDropdownMultiRef/PlDropdownMultiRef.vue2.js.map +1 -1
  807. package/dist/components/PlDropdownRef/PlDropdownRef.js +2 -0
  808. package/dist/components/PlDropdownRef/PlDropdownRef.vue2.js +1 -0
  809. package/dist/components/PlEditableTitle/PlEditableTitle.js +2 -0
  810. package/dist/components/PlEditableTitle/PlEditableTitle.vue2.js +2 -0
  811. package/dist/components/PlEditableTitle/PlEditableTitle.vue2.js.map +1 -1
  812. package/dist/components/PlEditableTitle/pl-editable-title.module.js +1 -0
  813. package/dist/components/PlElementList/PlElementList.js +1 -0
  814. package/dist/components/PlElementList/PlElementList.style.js +1 -0
  815. package/dist/components/PlElementList/PlElementList.vue2.js +2 -0
  816. package/dist/components/PlElementList/PlElementList.vue2.js.map +1 -1
  817. package/dist/components/PlElementList/PlElementListItem.js +1 -0
  818. package/dist/components/PlElementList/PlElementListItem.style.js +1 -0
  819. package/dist/components/PlElementList/PlElementListItem.vue2.js +2 -0
  820. package/dist/components/PlElementList/PlElementListItem.vue2.js.map +1 -1
  821. package/dist/components/PlElementList/utils.js +3 -1
  822. package/dist/components/PlElementList/utils.js.map +1 -1
  823. package/dist/components/PlErrorAlert/PlErrorAlert.js +1 -0
  824. package/dist/components/PlErrorAlert/PlErrorAlert.style.js +1 -0
  825. package/dist/components/PlErrorAlert/PlErrorAlert.vue2.js +1 -0
  826. package/dist/components/PlErrorBoundary/PlErrorBoundary.js +2 -0
  827. package/dist/components/PlErrorBoundary/PlErrorBoundary.vue2.js +2 -0
  828. package/dist/components/PlErrorBoundary/PlErrorBoundary.vue2.js.map +1 -1
  829. package/dist/components/PlFileDialog/Local.js +2 -0
  830. package/dist/components/PlFileDialog/Local.vue2.js +2 -0
  831. package/dist/components/PlFileDialog/Local.vue2.js.map +1 -1
  832. package/dist/components/PlFileDialog/PlFileDialog.js +2 -0
  833. package/dist/components/PlFileDialog/PlFileDialog.vue2.js +2 -0
  834. package/dist/components/PlFileDialog/PlFileDialog.vue2.js.map +1 -1
  835. package/dist/components/PlFileDialog/Remote.js +2 -0
  836. package/dist/components/PlFileDialog/Remote.vue2.js +2 -0
  837. package/dist/components/PlFileDialog/Remote.vue2.js.map +1 -1
  838. package/dist/components/PlFileDialog/Shortcuts.js +1 -0
  839. package/dist/components/PlFileDialog/Shortcuts.style.js +1 -0
  840. package/dist/components/PlFileDialog/Shortcuts.vue2.js +2 -0
  841. package/dist/components/PlFileDialog/Shortcuts.vue2.js.map +1 -1
  842. package/dist/components/PlFileDialog/pl-file-dialog.module.js +1 -0
  843. package/dist/components/PlFileDialog/remote-helpers.js +4 -2
  844. package/dist/components/PlFileDialog/remote-helpers.js.map +1 -1
  845. package/dist/components/PlFileDialog/utils.js +2 -0
  846. package/dist/components/PlFileDialog/utils.js.map +1 -1
  847. package/dist/components/PlFileInput/PlFileInput.js +2 -0
  848. package/dist/components/PlFileInput/PlFileInput.vue2.js +2 -0
  849. package/dist/components/PlFileInput/PlFileInput.vue2.js.map +1 -1
  850. package/dist/components/PlIcon16/PlIcon16.js +1 -0
  851. package/dist/components/PlIcon16/PlIcon16.style.js +1 -0
  852. package/dist/components/PlIcon16/PlIcon16.vue2.js +2 -0
  853. package/dist/components/PlIcon16/PlIcon16.vue2.js.map +1 -1
  854. package/dist/components/PlIcon24/PlIcon24.js +1 -0
  855. package/dist/components/PlIcon24/PlIcon24.style.js +1 -0
  856. package/dist/components/PlIcon24/PlIcon24.vue2.js +2 -0
  857. package/dist/components/PlIcon24/PlIcon24.vue2.js.map +1 -1
  858. package/dist/components/PlLoaderCircular/PlLoaderCircular.js +2 -0
  859. package/dist/components/PlLoaderCircular/PlLoaderCircular.vue2.js +2 -0
  860. package/dist/components/PlLoaderCircular/PlLoaderCircular.vue2.js.map +1 -1
  861. package/dist/components/PlLoaderLogo.js +1 -0
  862. package/dist/components/PlLoaderLogo.style.js +1 -0
  863. package/dist/components/PlLoaderLogo.vue2.js +2 -0
  864. package/dist/components/PlLoaderLogo.vue2.js.map +1 -1
  865. package/dist/components/PlLogView/PlLogView.js +2 -0
  866. package/dist/components/PlLogView/PlLogView.vue2.js +2 -0
  867. package/dist/components/PlLogView/PlLogView.vue2.js.map +1 -1
  868. package/dist/components/PlLogView/useLogHandle.js +2 -0
  869. package/dist/components/PlLogView/useLogHandle.js.map +1 -1
  870. package/dist/components/PlNotificationAlert/PlNotificationAlert.js +2 -0
  871. package/dist/components/PlNotificationAlert/PlNotificationAlert.vue2.js +2 -0
  872. package/dist/components/PlNotificationAlert/PlNotificationAlert.vue2.js.map +1 -1
  873. package/dist/components/PlNumberField/PlNumberField.js +2 -0
  874. package/dist/components/PlNumberField/PlNumberField.js.map +1 -1
  875. package/dist/components/PlNumberField/PlNumberField.vue.d.ts +1 -1
  876. package/dist/components/PlNumberField/PlNumberField.vue.d.ts.map +1 -1
  877. package/dist/components/PlNumberField/PlNumberField.vue2.js +2 -0
  878. package/dist/components/PlNumberField/PlNumberField.vue2.js.map +1 -1
  879. package/dist/components/PlNumberField/parseNumber.js +2 -11
  880. package/dist/components/PlNumberField/parseNumber.js.map +1 -1
  881. package/dist/components/PlProgressBar/PlProgressBar.js +2 -0
  882. package/dist/components/PlProgressBar/PlProgressBar.vue2.js +2 -0
  883. package/dist/components/PlProgressBar/PlProgressBar.vue2.js.map +1 -1
  884. package/dist/components/PlProgressCell/PlProgressCell.js +2 -0
  885. package/dist/components/PlProgressCell/PlProgressCell.vue2.js +2 -0
  886. package/dist/components/PlProgressCell/PlProgressCell.vue2.js.map +1 -1
  887. package/dist/components/PlRadio/PlRadio.js +1 -0
  888. package/dist/components/PlRadio/PlRadio.style.js +1 -0
  889. package/dist/components/PlRadio/PlRadio.vue2.js +2 -0
  890. package/dist/components/PlRadio/PlRadio.vue2.js.map +1 -1
  891. package/dist/components/PlRadio/PlRadioGroup.js +1 -0
  892. package/dist/components/PlRadio/PlRadioGroup.style.js +1 -0
  893. package/dist/components/PlRadio/PlRadioGroup.vue2.js +2 -0
  894. package/dist/components/PlRadio/PlRadioGroup.vue2.js.map +1 -1
  895. package/dist/components/PlRadio/keys.js +3 -1
  896. package/dist/components/PlRadio/keys.js.map +1 -1
  897. package/dist/components/PlSearchField/PlSearchField.js +1 -0
  898. package/dist/components/PlSearchField/PlSearchField.style.js +1 -0
  899. package/dist/components/PlSearchField/PlSearchField.vue2.js +2 -0
  900. package/dist/components/PlSearchField/PlSearchField.vue2.js.map +1 -1
  901. package/dist/components/PlSectionSeparator/PlSectionSeparator.js +1 -0
  902. package/dist/components/PlSectionSeparator/PlSectionSeparator.style.js +1 -0
  903. package/dist/components/PlSectionSeparator/PlSectionSeparator.vue2.js +2 -0
  904. package/dist/components/PlSectionSeparator/PlSectionSeparator.vue2.js.map +1 -1
  905. package/dist/components/PlSidebar/PlSidebarGroup.js +1 -0
  906. package/dist/components/PlSidebar/PlSidebarGroup.style.js +1 -0
  907. package/dist/components/PlSidebar/PlSidebarGroup.vue2.js +2 -0
  908. package/dist/components/PlSidebar/PlSidebarGroup.vue2.js.map +1 -1
  909. package/dist/components/PlSidebar/PlSidebarItem.js +1 -0
  910. package/dist/components/PlSidebar/PlSidebarItem.style.js +1 -0
  911. package/dist/components/PlSidebar/PlSidebarItem.vue2.js +2 -0
  912. package/dist/components/PlSidebar/PlSidebarItem.vue2.js.map +1 -1
  913. package/dist/components/PlSlideModal/PlPureSlideModal.js +2 -0
  914. package/dist/components/PlSlideModal/PlPureSlideModal.vue2.js +1 -0
  915. package/dist/components/PlSlideModal/PlSlideModal.js +1 -0
  916. package/dist/components/PlSlideModal/PlSlideModal.style.js +1 -0
  917. package/dist/components/PlSlideModal/PlSlideModal.vue2.js +2 -0
  918. package/dist/components/PlSlideModal/PlSlideModal.vue2.js.map +1 -1
  919. package/dist/components/PlSlideModal/props.js +3 -1
  920. package/dist/components/PlSlideModal/props.js.map +1 -1
  921. package/dist/components/PlSplash/PlSplash.js +2 -0
  922. package/dist/components/PlSplash/PlSplash.vue2.js +2 -0
  923. package/dist/components/PlSplash/PlSplash.vue2.js.map +1 -1
  924. package/dist/components/PlSplash/pl-splash.module.js +1 -0
  925. package/dist/components/PlStatusTag/PlStatusTag.js +2 -0
  926. package/dist/components/PlStatusTag/PlStatusTag.vue2.js +2 -0
  927. package/dist/components/PlStatusTag/PlStatusTag.vue2.js.map +1 -1
  928. package/dist/components/PlSvg/PlSvg.js +1 -0
  929. package/dist/components/PlSvg/PlSvg.style.js +1 -0
  930. package/dist/components/PlSvg/PlSvg.vue2.js +2 -0
  931. package/dist/components/PlSvg/PlSvg.vue2.js.map +1 -1
  932. package/dist/components/PlSvg/registry.js +2 -0
  933. package/dist/components/PlSvg/registry.js.map +1 -1
  934. package/dist/components/PlTabs/PlTabs.js +2 -0
  935. package/dist/components/PlTabs/PlTabs.vue2.js +1 -0
  936. package/dist/components/PlTabs/Tab.js +2 -0
  937. package/dist/components/PlTabs/Tab.vue2.js +2 -0
  938. package/dist/components/PlTabs/Tab.vue2.js.map +1 -1
  939. package/dist/components/PlTabs/pl-tabs.module.js +1 -0
  940. package/dist/components/PlTextArea/PlTextArea.js +2 -0
  941. package/dist/components/PlTextArea/PlTextArea.vue2.js +2 -0
  942. package/dist/components/PlTextArea/PlTextArea.vue2.js.map +1 -1
  943. package/dist/components/PlTextField/PlTextField.js +2 -0
  944. package/dist/components/PlTextField/PlTextField.js.map +1 -1
  945. package/dist/components/PlTextField/PlTextField.vue.d.ts +8 -8
  946. package/dist/components/PlTextField/PlTextField.vue.d.ts.map +1 -1
  947. package/dist/components/PlTextField/PlTextField.vue2.js +4 -2
  948. package/dist/components/PlTextField/PlTextField.vue2.js.map +1 -1
  949. package/dist/components/PlToggleSwitch/PlToggleSwitch.js +2 -0
  950. package/dist/components/PlToggleSwitch/PlToggleSwitch.vue2.js +2 -0
  951. package/dist/components/PlToggleSwitch/PlToggleSwitch.vue2.js.map +1 -1
  952. package/dist/components/PlTooltip/PlTooltip.js +1 -0
  953. package/dist/components/PlTooltip/PlTooltip.style.js +1 -0
  954. package/dist/components/PlTooltip/PlTooltip.vue2.js +1 -0
  955. package/dist/components/PlTooltip/global.js +3 -1
  956. package/dist/components/PlTooltip/global.js.map +1 -1
  957. package/dist/components/Scrollable.js +2 -0
  958. package/dist/components/Scrollable.vue2.js +2 -0
  959. package/dist/components/Scrollable.vue2.js.map +1 -1
  960. package/dist/components/Slider.js +2 -0
  961. package/dist/components/Slider.vue2.js +2 -0
  962. package/dist/components/Slider.vue2.js.map +1 -1
  963. package/dist/components/SliderRange.js +2 -0
  964. package/dist/components/SliderRange.vue2.js +2 -0
  965. package/dist/components/SliderRange.vue2.js.map +1 -1
  966. package/dist/components/SliderRangeTriple.js +2 -0
  967. package/dist/components/SliderRangeTriple.vue2.js +2 -0
  968. package/dist/components/SliderRangeTriple.vue2.js.map +1 -1
  969. package/dist/components/TabItem.js +2 -0
  970. package/dist/components/TabItem.vue2.js +2 -0
  971. package/dist/components/TabItem.vue2.js.map +1 -1
  972. package/dist/components/ThemeSwitcher.js +2 -0
  973. package/dist/components/ThemeSwitcher.vue2.js +2 -0
  974. package/dist/components/ThemeSwitcher.vue2.js.map +1 -1
  975. package/dist/components/TransitionSlidePanel.js +2 -0
  976. package/dist/components/TransitionSlidePanel.vue2.js +2 -0
  977. package/dist/components/TransitionSlidePanel.vue2.js.map +1 -1
  978. package/dist/components/VScroll.js +2 -0
  979. package/dist/components/VScroll.vue2.js +2 -0
  980. package/dist/components/VScroll.vue2.js.map +1 -1
  981. package/dist/components/contextMenu/Menu.js +2 -0
  982. package/dist/components/contextMenu/Menu.vue2.js +2 -0
  983. package/dist/components/contextMenu/Menu.vue2.js.map +1 -1
  984. package/dist/components/contextMenu/index.js +2 -0
  985. package/dist/components/contextMenu/index.js.map +1 -1
  986. package/dist/composition/computedCached.js +2 -0
  987. package/dist/composition/computedCached.js.map +1 -1
  988. package/dist/composition/filters/metadata.js +3 -1
  989. package/dist/composition/filters/metadata.js.map +1 -1
  990. package/dist/composition/useClickOutside.js +2 -0
  991. package/dist/composition/useClickOutside.js.map +1 -1
  992. package/dist/composition/useComponentProp.js +2 -30
  993. package/dist/composition/useComponentProp.js.map +1 -1
  994. package/dist/composition/useConfirm.js +2 -0
  995. package/dist/composition/useConfirm.js.map +1 -1
  996. package/dist/composition/useDraggable.js +2 -0
  997. package/dist/composition/useDraggable.js.map +1 -1
  998. package/dist/composition/useEventListener.js +2 -0
  999. package/dist/composition/useEventListener.js.map +1 -1
  1000. package/dist/composition/useFilteredList.js +2 -0
  1001. package/dist/composition/useFilteredList.js.map +1 -1
  1002. package/dist/composition/useFormState.js +2 -0
  1003. package/dist/composition/useFormState.js.map +1 -1
  1004. package/dist/composition/useHover.js +2 -0
  1005. package/dist/composition/useHover.js.map +1 -1
  1006. package/dist/composition/useInterval.js +2 -0
  1007. package/dist/composition/useInterval.js.map +1 -1
  1008. package/dist/composition/useLocalStorage.js +2 -0
  1009. package/dist/composition/useLocalStorage.js.map +1 -1
  1010. package/dist/composition/useMouse.js +2 -0
  1011. package/dist/composition/useMouse.js.map +1 -1
  1012. package/dist/composition/useMouseCapture.js +2 -0
  1013. package/dist/composition/useMouseCapture.js.map +1 -1
  1014. package/dist/composition/usePollingQuery.js +11 -94
  1015. package/dist/composition/usePollingQuery.js.map +1 -1
  1016. package/dist/composition/usePosition.js +2 -0
  1017. package/dist/composition/usePosition.js.map +1 -1
  1018. package/dist/composition/useQuery.js +2 -0
  1019. package/dist/composition/useQuery.js.map +1 -1
  1020. package/dist/composition/useResizeObserver.js +2 -0
  1021. package/dist/composition/useResizeObserver.js.map +1 -1
  1022. package/dist/composition/useRipple.js +2 -0
  1023. package/dist/composition/useRipple.js.map +1 -1
  1024. package/dist/composition/useScroll.js +2 -0
  1025. package/dist/composition/useScroll.js.map +1 -1
  1026. package/dist/composition/useSliderBreakpoints.js +3 -1
  1027. package/dist/composition/useSliderBreakpoints.js.map +1 -1
  1028. package/dist/composition/useSortable.js +2 -0
  1029. package/dist/composition/useSortable.js.map +1 -1
  1030. package/dist/composition/useSortable2.js +2 -9
  1031. package/dist/composition/useSortable2.js.map +1 -1
  1032. package/dist/composition/useTheme.js +2 -0
  1033. package/dist/composition/useTheme.js.map +1 -1
  1034. package/dist/composition/useTransformedModel.js +2 -31
  1035. package/dist/composition/useTransformedModel.js.map +1 -1
  1036. package/dist/composition/useWatchFetch.js +2 -20
  1037. package/dist/composition/useWatchFetch.js.map +1 -1
  1038. package/dist/composition/utils.js +2 -0
  1039. package/dist/composition/utils.js.map +1 -1
  1040. package/dist/composition/watchCached.js +2 -1
  1041. package/dist/demo-site-data/all-css-variables.js +2 -0
  1042. package/dist/demo-site-data/all-css-variables.js.map +1 -1
  1043. package/dist/generated/icons-16.js +3 -1
  1044. package/dist/generated/icons-16.js.map +1 -1
  1045. package/dist/generated/icons-24.js +3 -1
  1046. package/dist/generated/icons-24.js.map +1 -1
  1047. package/dist/global/resizeObserver.js +2 -0
  1048. package/dist/global/resizeObserver.js.map +1 -1
  1049. package/dist/helpers/dom.js +2 -0
  1050. package/dist/helpers/dom.js.map +1 -1
  1051. package/dist/helpers/downloadContent.js +3 -1
  1052. package/dist/helpers/downloadContent.js.map +1 -1
  1053. package/dist/helpers/error.js +2 -0
  1054. package/dist/helpers/error.js.map +1 -1
  1055. package/dist/helpers/functions.js +2 -0
  1056. package/dist/helpers/functions.js.map +1 -1
  1057. package/dist/helpers/index.js +2 -0
  1058. package/dist/helpers/index.js.map +1 -1
  1059. package/dist/helpers/iterators.js +2 -0
  1060. package/dist/helpers/iterators.js.map +1 -1
  1061. package/dist/helpers/math.js +2 -0
  1062. package/dist/helpers/math.js.map +1 -1
  1063. package/dist/helpers/objects.js +2 -0
  1064. package/dist/helpers/objects.js.map +1 -1
  1065. package/dist/helpers/utils.js +2 -0
  1066. package/dist/helpers/utils.js.map +1 -1
  1067. package/dist/index.js +2 -0
  1068. package/dist/index.js.map +1 -1
  1069. package/dist/layout/PlBlockPage/PlBlockPage.js +1 -0
  1070. package/dist/layout/PlBlockPage/PlBlockPage.style.js +1 -0
  1071. package/dist/layout/PlBlockPage/PlBlockPage.vue2.js +2 -0
  1072. package/dist/layout/PlBlockPage/PlBlockPage.vue2.js.map +1 -1
  1073. package/dist/layout/PlBlockPage/PlBlockPageTitleTeleportTarget.js +3 -1
  1074. package/dist/layout/PlBlockPage/PlBlockPageTitleTeleportTarget.js.map +1 -1
  1075. package/dist/layout/PlBlockPage/usePlBlockPageTitleTeleportTarget.js +2 -0
  1076. package/dist/layout/PlBlockPage/usePlBlockPageTitleTeleportTarget.js.map +1 -1
  1077. package/dist/layout/PlContainer/PlContainer.js +2 -0
  1078. package/dist/layout/PlContainer/PlContainer.vue2.js +1 -0
  1079. package/dist/layout/PlGrid/PlGrid.js +2 -0
  1080. package/dist/layout/PlGrid/PlGrid.vue2.js +1 -0
  1081. package/dist/layout/PlPlaceholder/PlPlaceholder.js +1 -0
  1082. package/dist/layout/PlPlaceholder/PlPlaceholder.style.js +1 -0
  1083. package/dist/layout/PlPlaceholder/PlPlaceholder.vue2.js +2 -0
  1084. package/dist/layout/PlPlaceholder/PlPlaceholder.vue2.js.map +1 -1
  1085. package/dist/layout/PlPlaceholder/index.js +3 -1
  1086. package/dist/layout/PlPlaceholder/index.js.map +1 -1
  1087. package/dist/layout/PlPlaceholder/paint-worklet.js +2 -0
  1088. package/dist/layout/PlPlaceholder/paint-worklet.js.map +1 -1
  1089. package/dist/layout/PlRow/PlRow.js +2 -0
  1090. package/dist/layout/PlRow/PlRow.vue2.js +1 -0
  1091. package/dist/layout/PlSpacer/PlSpacer.js +2 -0
  1092. package/dist/layout/PlSpacer/PlSpacer.vue2.js +2 -0
  1093. package/dist/layout/PlSpacer/PlSpacer.vue2.js.map +1 -1
  1094. package/dist/utils/DoubleContour.js +2 -0
  1095. package/dist/utils/DoubleContour.js.map +1 -1
  1096. package/dist/utils/DoubleContour.vue2.js +3 -1
  1097. package/dist/utils/DoubleContour.vue2.js.map +1 -1
  1098. package/dist/utils/DropdownOverlay/DropdownOverlay.js +2 -0
  1099. package/dist/utils/DropdownOverlay/DropdownOverlay.vue2.js +2 -0
  1100. package/dist/utils/DropdownOverlay/DropdownOverlay.vue2.js.map +1 -1
  1101. package/dist/utils/InnerBorder.js +2 -0
  1102. package/dist/utils/InnerBorder.js.map +1 -1
  1103. package/dist/utils/InnerBorder.vue2.js +2 -0
  1104. package/dist/utils/InnerBorder.vue2.js.map +1 -1
  1105. package/dist/utils/PlCloseModalBtn.js +2 -0
  1106. package/dist/utils/PlCloseModalBtn.js.map +1 -1
  1107. package/dist/utils/PlCloseModalBtn.style.js +1 -0
  1108. package/dist/utils/TextLabel.js +2 -0
  1109. package/dist/utils/TextLabel.js.map +1 -1
  1110. package/dist/utils/TextLabel.style.js +1 -0
  1111. package/dist/utils/useLabelNotch.js +2 -3
  1112. package/dist/utils/useLabelNotch.js.map +1 -1
  1113. package/dist/utils/useValidation.js +2 -0
  1114. package/dist/utils/useValidation.js.map +1 -1
  1115. package/package.json +7 -7
  1116. package/src/components/PlDialogModal/PlDialogModal.vue +1 -0
  1117. package/src/components/PlNumberField/PlNumberField.vue +1 -1
  1118. package/src/components/PlTextField/PlTextField.vue +8 -8
  1119. package/src/utils/DoubleContour.vue +2 -2
@@ -1,5 +1,7 @@
1
1
  import e from "./PlAutocompleteMulti.vue2.js";
2
+ //#region src/components/PlAutocompleteMulti/PlAutocompleteMulti.vue
2
3
  var t = e;
4
+ //#endregion
3
5
  export { t as default };
4
6
 
5
7
  //# sourceMappingURL=PlAutocompleteMulti.js.map
@@ -17,6 +17,7 @@ import u from "../PlChip/PlChip.js";
17
17
  import "../PlChip/index.js";
18
18
  import { Fragment as d, computed as f, createBlock as p, createCommentVNode as m, createElementBlock as h, createElementVNode as g, createTextVNode as _, createVNode as ne, defineComponent as v, normalizeClass as re, openBlock as y, reactive as b, ref as x, renderList as S, renderSlot as C, toDisplayString as w, toRef as T, unref as E, useSlots as ie, useTemplateRef as ae, vModelText as D, watch as O, withCtx as k, withDirectives as oe, withModifiers as A } from "vue";
19
19
  import se from "canonicalize";
20
+ //#region src/components/PlAutocompleteMulti/PlAutocompleteMulti.vue?vue&type=script&setup=true&lang.ts
20
21
  var ce = ["tabindex"], le = { class: "pl-autocomplete-multi__container" }, ue = { class: "pl-autocomplete-multi__field" }, de = ["disabled", "placeholder"], fe = {
21
22
  key: 0,
22
23
  class: "chips-container"
@@ -229,6 +230,7 @@ var ce = ["tabindex"], le = { class: "pl-autocomplete-multi__container" }, ue =
229
230
  ])], 42, ce), $.value ? (y(), h("div", j, w($.value), 1)) : v.helper ? (y(), h("div", M, w(v.helper), 1)) : m("", !0)]));
230
231
  }
231
232
  });
233
+ //#endregion
232
234
  export { N as default };
233
235
 
234
236
  //# sourceMappingURL=PlAutocompleteMulti.vue2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PlAutocompleteMulti.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlAutocompleteMulti/PlAutocompleteMulti.vue"],"sourcesContent":["<script lang=\"ts\">\n/**\n * A multi-select autocomplete component that allows users to search and select multiple values from a list of options.\n * Supports async data fetching, keyboard navigation, and displays selected items as removable chips.\n *\n * @example\n * Basic usage:\n * <PlAutocompleteMulti\n * v-model=\"selectedUsers\"\n * :options-search=\"searchUsers\"\n * :model-search=\"getUsersByIds\"\n * label=\"Select Users\"\n * placeholder=\"Search for users...\"\n * required\n * :debounce=\"300\"\n * helper=\"Choose one or more users from the list\"\n * />\n *\n * With async functions:\n * const selectedUsers = ref([])\n *\n * const searchUsers = async (searchTerm) => {\n * const response = await fetch('/api/users/search?q=' + searchTerm)\n * const users = await response.json()\n * return users.map(user => ({ value: user.id, label: user.name }))\n * }\n *\n * const getUsersByIds = async (userIds) => {\n * if (!userIds.length) return []\n * const response = await fetch('/api/users?ids=' + userIds.join(','))\n * const users = await response.json()\n * return users.map(user => ({ value: user.id, label: user.name }))\n * }\n */\nexport default {\n name: \"PlAutocompleteMulti\",\n};\n\nexport interface OptionsSearch<T> {\n (s: string, type: \"label\"): Promise<Readonly<ListOptionBase<T>[]>>;\n (s: T[], type: \"value\"): Promise<Readonly<ListOptionBase<T>[]>>;\n}\n</script>\n\n<script lang=\"ts\" setup generic=\"M extends string | number = string\">\nimport \"./pl-autocomplete-multi.scss\";\n\nimport type { ListOptionBase } from \"@platforma-sdk/model\";\nimport canonicalize from \"canonicalize\";\nimport { computed, reactive, ref, toRef, unref, useSlots, useTemplateRef, watch } from \"vue\";\nimport { useWatchFetch } from \"../../composition/useWatchFetch.ts\";\nimport { getErrorMessage } from \"../../helpers/error.ts\";\nimport { deepEqual, deepIncludes } from \"../../helpers/objects\";\nimport DoubleContour from \"../../utils/DoubleContour.vue\";\nimport DropdownOverlay from \"../../utils/DropdownOverlay/DropdownOverlay.vue\";\nimport { useLabelNotch } from \"../../utils/useLabelNotch\";\nimport DropdownListItem from \"../DropdownListItem.vue\";\nimport { PlChip } from \"../PlChip\";\nimport { PlMaskIcon24 } from \"../PlMaskIcon24\";\nimport { PlTooltip } from \"../PlTooltip\";\n\nimport SvgRequired from \"../../assets/images/required.svg?raw\";\nimport { PlSvg } from \"../PlSvg\";\n\nconst emit = defineEmits<{\n (e: \"update:modelValue\", v: M[]): void;\n}>();\n\nconst emitModel = (v: M[]) => emit(\"update:modelValue\", v);\n\nconst slots = useSlots();\n\nconst props = withDefaults(\n defineProps<{\n /**\n * The current selected values.\n */\n modelValue: M[];\n /**\n * Lambda for requesting of available options for the dropdown by search string.\n */\n optionsSearch: OptionsSearch<M>;\n /**\n * Unique identifier for the source of the options, changing it will invalidate the options cache.\n */\n sourceId?: string;\n /**\n * The label text for the dropdown field (optional)\n */\n label?: string;\n /**\n * A helper text displayed below the dropdown when there are no errors (optional).\n */\n helper?: string;\n /**\n * Error message displayed below the dropdown (optional)\n */\n error?: unknown;\n /**\n * Placeholder text shown when no value is selected.\n */\n placeholder?: string;\n /**\n * If `true`, the dropdown component is marked as required.\n */\n required?: boolean;\n /**\n * If `true`, the dropdown component is disabled and cannot be interacted with.\n */\n disabled?: boolean;\n /**\n * Debounce time in ms for the options search.\n */\n debounce?: number;\n /**\n * If `true`, the search input is reset and focus is set on it when the new option is selected.\n */\n resetSearchOnSelect?: boolean;\n /**\n * The text to display when no options are found.\n */\n emptyOptionsText?: string;\n /**\n * Makes some of corners not rounded\n * */\n groupPosition?:\n | \"top\"\n | \"bottom\"\n | \"left\"\n | \"right\"\n | \"top-left\"\n | \"top-right\"\n | \"bottom-left\"\n | \"bottom-right\"\n | \"middle\";\n }>(),\n {\n modelValue: () => [],\n label: undefined,\n helper: undefined,\n error: undefined,\n placeholder: \"...\",\n required: false,\n disabled: false,\n debounce: 300,\n emptyOptionsText: \"Nothing found\",\n sourceId: undefined,\n groupPosition: undefined,\n },\n);\n\nconst rootRef = ref<HTMLElement | undefined>();\nconst inputRef = ref<HTMLInputElement | undefined>();\n\nconst overlay = useTemplateRef(\"overlay\");\n\nconst data = reactive({\n search: \"\",\n activeOption: -1,\n open: false,\n optionsHeight: 0,\n});\n\nwatch(\n () => data.open,\n (v) => {\n if (!v) {\n data.search = \"\";\n }\n },\n { flush: \"sync\" },\n);\n\nconst selectedValuesRef = computed(() => (Array.isArray(props.modelValue) ? props.modelValue : []));\n\nconst placeholderRef = computed(() => {\n if (data.open && props.modelValue.length > 0) {\n return props.placeholder;\n }\n\n return props.modelValue.length > 0 ? \"\" : props.placeholder;\n});\n\nconst debounce = toRef(props, \"debounce\");\n\nconst searchOptionsRef = useWatchFetch(\n () => [data.search, data.open, props.sourceId] as const,\n async ([search, _open]) => {\n return props.optionsSearch(search, \"label\");\n },\n {\n filterWatchResult: ([_search, open]) => open,\n debounce,\n },\n);\n\nconst modelOptionsRef = useWatchFetch(\n () => [props.modelValue, props.sourceId] as const,\n async ([v]) => {\n return props.optionsSearch(v, \"value\");\n },\n {\n debounce,\n },\n);\n\nconst allOptionsRef = computed(() => {\n const modelOptions = modelOptionsRef.value ?? [];\n const searchOptions = searchOptionsRef.value ?? [];\n\n const seenValues = new Set<string | undefined>();\n const result = [] as ListOptionBase<M>[];\n\n const addOptions = (options: Readonly<ListOptionBase<M>[]>) => {\n for (const option of options) {\n const canonicalValue = canonicalize(option.value);\n if (!seenValues.has(canonicalValue)) {\n seenValues.add(canonicalValue);\n result.push(option);\n }\n }\n };\n\n addOptions(modelOptions);\n addOptions(searchOptions);\n\n return result;\n});\n\nconst selectedOptionsRef = computed(() => {\n return selectedValuesRef.value\n .map((v) => allOptionsRef.value.find((opt) => deepEqual(opt.value, v)))\n .filter((v) => v !== undefined);\n});\n\nconst filteredOptionsRef = computed(() => {\n const selectedValues = unref(selectedValuesRef);\n\n const options = searchOptionsRef.value ?? [];\n\n return [...options].map((opt) => ({\n ...opt,\n selected: deepIncludes(selectedValues, opt.value),\n }));\n});\n\nconst isOptionsLoading = computed(() => searchOptionsRef.loading || modelOptionsRef.loading);\n\nconst isDisabled = computed(() => {\n if (modelOptionsRef.value === undefined) {\n return true;\n }\n\n return props.disabled;\n});\n\nconst tabindex = computed(() => (isDisabled.value ? undefined : \"0\"));\n\nconst updateActiveOption = () => {\n data.activeOption = 0;\n};\n\nconst selectOption = (v: M) => {\n const values = unref(selectedValuesRef);\n emitModel(deepIncludes(values, v) ? values.filter((it) => !deepEqual(it, v)) : [...values, v]);\n if (props.resetSearchOnSelect) {\n data.search = \"\";\n }\n inputRef.value?.focus();\n};\n\nconst unselectOption = (d: M) =>\n emitModel(unref(selectedValuesRef).filter((v) => !deepEqual(v, d)));\n\nconst setFocusOnInput = () => inputRef.value?.focus();\n\nconst toggleOpen = () => (data.open = !data.open);\n\nconst onFocusOut = (event: FocusEvent) => {\n const relatedTarget = event.relatedTarget as Node | null;\n\n if (!rootRef.value?.contains(relatedTarget) && !overlay.value?.listRef?.contains(relatedTarget)) {\n data.open = false;\n }\n};\n\nconst handleKeydown = (e: { code: string; preventDefault(): void }) => {\n const { open, activeOption } = data;\n\n if (!open) {\n if (e.code === \"Enter\") {\n data.open = true;\n }\n return;\n }\n\n if (e.code === \"Escape\") {\n data.open = false;\n inputRef.value?.focus();\n }\n\n const filteredOptions = unref(filteredOptionsRef);\n\n const { length } = filteredOptions;\n\n if (!length) {\n return;\n }\n\n if ([\"ArrowDown\", \"ArrowUp\", \"Enter\"].includes(e.code)) {\n e.preventDefault();\n }\n\n if (e.code === \"Enter\") {\n selectOption(filteredOptions[activeOption].value);\n }\n\n const d = e.code === \"ArrowDown\" ? 1 : e.code === \"ArrowUp\" ? -1 : 0;\n\n data.activeOption = Math.abs(activeOption + d + length) % length;\n\n requestAnimationFrame(() => overlay.value?.scrollIntoActive());\n};\n\nuseLabelNotch(rootRef);\n\nwatch(\n () => props.modelValue,\n () => updateActiveOption(),\n { immediate: true },\n);\n\nconst computedError = computed(() => {\n if (isOptionsLoading.value) {\n return undefined;\n }\n\n if (searchOptionsRef.error) {\n return getErrorMessage(searchOptionsRef.error);\n }\n\n if (modelOptionsRef.error) {\n return getErrorMessage(modelOptionsRef.error);\n }\n\n if (props.error) {\n return getErrorMessage(props.error);\n }\n\n if (props.modelValue.length && selectedOptionsRef.value.length !== props.modelValue.length) {\n return \"The selected values are not one of the options\";\n }\n\n return undefined;\n});\n</script>\n\n<template>\n <div class=\"pl-autocomplete-multi__envelope\" @click=\"setFocusOnInput\">\n <div\n ref=\"rootRef\"\n :tabindex=\"tabindex\"\n class=\"pl-autocomplete-multi\"\n :class=\"{ open: data.open, error: Boolean(computedError), disabled: isDisabled }\"\n @keydown=\"handleKeydown\"\n @focusout=\"onFocusOut\"\n >\n <div class=\"pl-autocomplete-multi__container\">\n <div class=\"pl-autocomplete-multi__field\">\n <input\n ref=\"inputRef\"\n v-model=\"data.search\"\n type=\"text\"\n tabindex=\"-1\"\n :disabled=\"isDisabled\"\n :placeholder=\"placeholderRef\"\n spellcheck=\"false\"\n autocomplete=\"chrome-off\"\n @focus=\"data.open = true\"\n />\n <div v-if=\"!data.open\" class=\"chips-container\">\n <PlChip\n v-for=\"(opt, i) in selectedOptionsRef\"\n :key=\"i\"\n closeable\n small\n @click.stop=\"data.open = true\"\n @close=\"unselectOption(opt.value)\"\n >\n {{ opt.label || opt.value }}\n </PlChip>\n </div>\n\n <div class=\"pl-autocomplete-multi__controls\">\n <PlMaskIcon24 v-if=\"isOptionsLoading\" name=\"loading\" />\n <slot name=\"append\" />\n <div class=\"pl-autocomplete-multi__arrow-wrapper\" @click.stop=\"toggleOpen\">\n <div class=\"arrow-icon arrow-icon-default\" />\n </div>\n </div>\n </div>\n <label v-if=\"label\">\n <PlSvg v-if=\"required\" :uri=\"SvgRequired\" />\n <span>{{ label }}</span>\n <PlTooltip v-if=\"slots.tooltip\" class=\"info\" position=\"top\">\n <template #tooltip>\n <slot name=\"tooltip\" />\n </template>\n </PlTooltip>\n </label>\n <DropdownOverlay\n v-if=\"data.open\"\n ref=\"overlay\"\n :root=\"rootRef\"\n class=\"pl-autocomplete-multi__options\"\n :gap=\"5\"\n tabindex=\"-1\"\n @focusout=\"onFocusOut\"\n >\n <div class=\"pl-autocomplete-multi__open-chips-container\">\n <PlChip\n v-for=\"(opt, i) in selectedOptionsRef\"\n :key=\"i\"\n closeable\n small\n @close=\"unselectOption(opt.value)\"\n >\n {{ opt.label || opt.value }}\n </PlChip>\n </div>\n <DropdownListItem\n v-for=\"(item, index) in filteredOptionsRef\"\n :key=\"index\"\n :option=\"item\"\n :text-item=\"'text'\"\n :is-selected=\"item.selected\"\n :is-hovered=\"data.activeOption == index\"\n size=\"medium\"\n use-checkbox\n @click.stop=\"selectOption(item.value)\"\n />\n <div v-if=\"!filteredOptionsRef.length && !isOptionsLoading\" class=\"nothing-found\">\n {{ emptyOptionsText }}\n </div>\n </DropdownOverlay>\n <DoubleContour class=\"pl-autocomplete-multi__contour\" :group-position=\"groupPosition\" />\n </div>\n </div>\n <div v-if=\"computedError\" class=\"pl-autocomplete-multi__error\">{{ computedError }}</div>\n <div v-else-if=\"helper\" class=\"pl-autocomplete-multi__helper\">{{ helper }}</div>\n </div>\n</template>\n"],"mappings":"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"}
1
+ {"version":3,"file":"PlAutocompleteMulti.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlAutocompleteMulti/PlAutocompleteMulti.vue"],"sourcesContent":["<script lang=\"ts\">\n/**\n * A multi-select autocomplete component that allows users to search and select multiple values from a list of options.\n * Supports async data fetching, keyboard navigation, and displays selected items as removable chips.\n *\n * @example\n * Basic usage:\n * <PlAutocompleteMulti\n * v-model=\"selectedUsers\"\n * :options-search=\"searchUsers\"\n * :model-search=\"getUsersByIds\"\n * label=\"Select Users\"\n * placeholder=\"Search for users...\"\n * required\n * :debounce=\"300\"\n * helper=\"Choose one or more users from the list\"\n * />\n *\n * With async functions:\n * const selectedUsers = ref([])\n *\n * const searchUsers = async (searchTerm) => {\n * const response = await fetch('/api/users/search?q=' + searchTerm)\n * const users = await response.json()\n * return users.map(user => ({ value: user.id, label: user.name }))\n * }\n *\n * const getUsersByIds = async (userIds) => {\n * if (!userIds.length) return []\n * const response = await fetch('/api/users?ids=' + userIds.join(','))\n * const users = await response.json()\n * return users.map(user => ({ value: user.id, label: user.name }))\n * }\n */\nexport default {\n name: \"PlAutocompleteMulti\",\n};\n\nexport interface OptionsSearch<T> {\n (s: string, type: \"label\"): Promise<Readonly<ListOptionBase<T>[]>>;\n (s: T[], type: \"value\"): Promise<Readonly<ListOptionBase<T>[]>>;\n}\n</script>\n\n<script lang=\"ts\" setup generic=\"M extends string | number = string\">\nimport \"./pl-autocomplete-multi.scss\";\n\nimport type { ListOptionBase } from \"@platforma-sdk/model\";\nimport canonicalize from \"canonicalize\";\nimport { computed, reactive, ref, toRef, unref, useSlots, useTemplateRef, watch } from \"vue\";\nimport { useWatchFetch } from \"../../composition/useWatchFetch.ts\";\nimport { getErrorMessage } from \"../../helpers/error.ts\";\nimport { deepEqual, deepIncludes } from \"../../helpers/objects\";\nimport DoubleContour from \"../../utils/DoubleContour.vue\";\nimport DropdownOverlay from \"../../utils/DropdownOverlay/DropdownOverlay.vue\";\nimport { useLabelNotch } from \"../../utils/useLabelNotch\";\nimport DropdownListItem from \"../DropdownListItem.vue\";\nimport { PlChip } from \"../PlChip\";\nimport { PlMaskIcon24 } from \"../PlMaskIcon24\";\nimport { PlTooltip } from \"../PlTooltip\";\n\nimport SvgRequired from \"../../assets/images/required.svg?raw\";\nimport { PlSvg } from \"../PlSvg\";\n\nconst emit = defineEmits<{\n (e: \"update:modelValue\", v: M[]): void;\n}>();\n\nconst emitModel = (v: M[]) => emit(\"update:modelValue\", v);\n\nconst slots = useSlots();\n\nconst props = withDefaults(\n defineProps<{\n /**\n * The current selected values.\n */\n modelValue: M[];\n /**\n * Lambda for requesting of available options for the dropdown by search string.\n */\n optionsSearch: OptionsSearch<M>;\n /**\n * Unique identifier for the source of the options, changing it will invalidate the options cache.\n */\n sourceId?: string;\n /**\n * The label text for the dropdown field (optional)\n */\n label?: string;\n /**\n * A helper text displayed below the dropdown when there are no errors (optional).\n */\n helper?: string;\n /**\n * Error message displayed below the dropdown (optional)\n */\n error?: unknown;\n /**\n * Placeholder text shown when no value is selected.\n */\n placeholder?: string;\n /**\n * If `true`, the dropdown component is marked as required.\n */\n required?: boolean;\n /**\n * If `true`, the dropdown component is disabled and cannot be interacted with.\n */\n disabled?: boolean;\n /**\n * Debounce time in ms for the options search.\n */\n debounce?: number;\n /**\n * If `true`, the search input is reset and focus is set on it when the new option is selected.\n */\n resetSearchOnSelect?: boolean;\n /**\n * The text to display when no options are found.\n */\n emptyOptionsText?: string;\n /**\n * Makes some of corners not rounded\n * */\n groupPosition?:\n | \"top\"\n | \"bottom\"\n | \"left\"\n | \"right\"\n | \"top-left\"\n | \"top-right\"\n | \"bottom-left\"\n | \"bottom-right\"\n | \"middle\";\n }>(),\n {\n modelValue: () => [],\n label: undefined,\n helper: undefined,\n error: undefined,\n placeholder: \"...\",\n required: false,\n disabled: false,\n debounce: 300,\n emptyOptionsText: \"Nothing found\",\n sourceId: undefined,\n groupPosition: undefined,\n },\n);\n\nconst rootRef = ref<HTMLElement | undefined>();\nconst inputRef = ref<HTMLInputElement | undefined>();\n\nconst overlay = useTemplateRef(\"overlay\");\n\nconst data = reactive({\n search: \"\",\n activeOption: -1,\n open: false,\n optionsHeight: 0,\n});\n\nwatch(\n () => data.open,\n (v) => {\n if (!v) {\n data.search = \"\";\n }\n },\n { flush: \"sync\" },\n);\n\nconst selectedValuesRef = computed(() => (Array.isArray(props.modelValue) ? props.modelValue : []));\n\nconst placeholderRef = computed(() => {\n if (data.open && props.modelValue.length > 0) {\n return props.placeholder;\n }\n\n return props.modelValue.length > 0 ? \"\" : props.placeholder;\n});\n\nconst debounce = toRef(props, \"debounce\");\n\nconst searchOptionsRef = useWatchFetch(\n () => [data.search, data.open, props.sourceId] as const,\n async ([search, _open]) => {\n return props.optionsSearch(search, \"label\");\n },\n {\n filterWatchResult: ([_search, open]) => open,\n debounce,\n },\n);\n\nconst modelOptionsRef = useWatchFetch(\n () => [props.modelValue, props.sourceId] as const,\n async ([v]) => {\n return props.optionsSearch(v, \"value\");\n },\n {\n debounce,\n },\n);\n\nconst allOptionsRef = computed(() => {\n const modelOptions = modelOptionsRef.value ?? [];\n const searchOptions = searchOptionsRef.value ?? [];\n\n const seenValues = new Set<string | undefined>();\n const result = [] as ListOptionBase<M>[];\n\n const addOptions = (options: Readonly<ListOptionBase<M>[]>) => {\n for (const option of options) {\n const canonicalValue = canonicalize(option.value);\n if (!seenValues.has(canonicalValue)) {\n seenValues.add(canonicalValue);\n result.push(option);\n }\n }\n };\n\n addOptions(modelOptions);\n addOptions(searchOptions);\n\n return result;\n});\n\nconst selectedOptionsRef = computed(() => {\n return selectedValuesRef.value\n .map((v) => allOptionsRef.value.find((opt) => deepEqual(opt.value, v)))\n .filter((v) => v !== undefined);\n});\n\nconst filteredOptionsRef = computed(() => {\n const selectedValues = unref(selectedValuesRef);\n\n const options = searchOptionsRef.value ?? [];\n\n return [...options].map((opt) => ({\n ...opt,\n selected: deepIncludes(selectedValues, opt.value),\n }));\n});\n\nconst isOptionsLoading = computed(() => searchOptionsRef.loading || modelOptionsRef.loading);\n\nconst isDisabled = computed(() => {\n if (modelOptionsRef.value === undefined) {\n return true;\n }\n\n return props.disabled;\n});\n\nconst tabindex = computed(() => (isDisabled.value ? undefined : \"0\"));\n\nconst updateActiveOption = () => {\n data.activeOption = 0;\n};\n\nconst selectOption = (v: M) => {\n const values = unref(selectedValuesRef);\n emitModel(deepIncludes(values, v) ? values.filter((it) => !deepEqual(it, v)) : [...values, v]);\n if (props.resetSearchOnSelect) {\n data.search = \"\";\n }\n inputRef.value?.focus();\n};\n\nconst unselectOption = (d: M) =>\n emitModel(unref(selectedValuesRef).filter((v) => !deepEqual(v, d)));\n\nconst setFocusOnInput = () => inputRef.value?.focus();\n\nconst toggleOpen = () => (data.open = !data.open);\n\nconst onFocusOut = (event: FocusEvent) => {\n const relatedTarget = event.relatedTarget as Node | null;\n\n if (!rootRef.value?.contains(relatedTarget) && !overlay.value?.listRef?.contains(relatedTarget)) {\n data.open = false;\n }\n};\n\nconst handleKeydown = (e: { code: string; preventDefault(): void }) => {\n const { open, activeOption } = data;\n\n if (!open) {\n if (e.code === \"Enter\") {\n data.open = true;\n }\n return;\n }\n\n if (e.code === \"Escape\") {\n data.open = false;\n inputRef.value?.focus();\n }\n\n const filteredOptions = unref(filteredOptionsRef);\n\n const { length } = filteredOptions;\n\n if (!length) {\n return;\n }\n\n if ([\"ArrowDown\", \"ArrowUp\", \"Enter\"].includes(e.code)) {\n e.preventDefault();\n }\n\n if (e.code === \"Enter\") {\n selectOption(filteredOptions[activeOption].value);\n }\n\n const d = e.code === \"ArrowDown\" ? 1 : e.code === \"ArrowUp\" ? -1 : 0;\n\n data.activeOption = Math.abs(activeOption + d + length) % length;\n\n requestAnimationFrame(() => overlay.value?.scrollIntoActive());\n};\n\nuseLabelNotch(rootRef);\n\nwatch(\n () => props.modelValue,\n () => updateActiveOption(),\n { immediate: true },\n);\n\nconst computedError = computed(() => {\n if (isOptionsLoading.value) {\n return undefined;\n }\n\n if (searchOptionsRef.error) {\n return getErrorMessage(searchOptionsRef.error);\n }\n\n if (modelOptionsRef.error) {\n return getErrorMessage(modelOptionsRef.error);\n }\n\n if (props.error) {\n return getErrorMessage(props.error);\n }\n\n if (props.modelValue.length && selectedOptionsRef.value.length !== props.modelValue.length) {\n return \"The selected values are not one of the options\";\n }\n\n return undefined;\n});\n</script>\n\n<template>\n <div class=\"pl-autocomplete-multi__envelope\" @click=\"setFocusOnInput\">\n <div\n ref=\"rootRef\"\n :tabindex=\"tabindex\"\n class=\"pl-autocomplete-multi\"\n :class=\"{ open: data.open, error: Boolean(computedError), disabled: isDisabled }\"\n @keydown=\"handleKeydown\"\n @focusout=\"onFocusOut\"\n >\n <div class=\"pl-autocomplete-multi__container\">\n <div class=\"pl-autocomplete-multi__field\">\n <input\n ref=\"inputRef\"\n v-model=\"data.search\"\n type=\"text\"\n tabindex=\"-1\"\n :disabled=\"isDisabled\"\n :placeholder=\"placeholderRef\"\n spellcheck=\"false\"\n autocomplete=\"chrome-off\"\n @focus=\"data.open = true\"\n />\n <div v-if=\"!data.open\" class=\"chips-container\">\n <PlChip\n v-for=\"(opt, i) in selectedOptionsRef\"\n :key=\"i\"\n closeable\n small\n @click.stop=\"data.open = true\"\n @close=\"unselectOption(opt.value)\"\n >\n {{ opt.label || opt.value }}\n </PlChip>\n </div>\n\n <div class=\"pl-autocomplete-multi__controls\">\n <PlMaskIcon24 v-if=\"isOptionsLoading\" name=\"loading\" />\n <slot name=\"append\" />\n <div class=\"pl-autocomplete-multi__arrow-wrapper\" @click.stop=\"toggleOpen\">\n <div class=\"arrow-icon arrow-icon-default\" />\n </div>\n </div>\n </div>\n <label v-if=\"label\">\n <PlSvg v-if=\"required\" :uri=\"SvgRequired\" />\n <span>{{ label }}</span>\n <PlTooltip v-if=\"slots.tooltip\" class=\"info\" position=\"top\">\n <template #tooltip>\n <slot name=\"tooltip\" />\n </template>\n </PlTooltip>\n </label>\n <DropdownOverlay\n v-if=\"data.open\"\n ref=\"overlay\"\n :root=\"rootRef\"\n class=\"pl-autocomplete-multi__options\"\n :gap=\"5\"\n tabindex=\"-1\"\n @focusout=\"onFocusOut\"\n >\n <div class=\"pl-autocomplete-multi__open-chips-container\">\n <PlChip\n v-for=\"(opt, i) in selectedOptionsRef\"\n :key=\"i\"\n closeable\n small\n @close=\"unselectOption(opt.value)\"\n >\n {{ opt.label || opt.value }}\n </PlChip>\n </div>\n <DropdownListItem\n v-for=\"(item, index) in filteredOptionsRef\"\n :key=\"index\"\n :option=\"item\"\n :text-item=\"'text'\"\n :is-selected=\"item.selected\"\n :is-hovered=\"data.activeOption == index\"\n size=\"medium\"\n use-checkbox\n @click.stop=\"selectOption(item.value)\"\n />\n <div v-if=\"!filteredOptionsRef.length && !isOptionsLoading\" class=\"nothing-found\">\n {{ emptyOptionsText }}\n </div>\n </DropdownOverlay>\n <DoubleContour class=\"pl-autocomplete-multi__contour\" :group-position=\"groupPosition\" />\n </div>\n </div>\n <div v-if=\"computedError\" class=\"pl-autocomplete-multi__error\">{{ computedError }}</div>\n <div v-else-if=\"helper\" class=\"pl-autocomplete-multi__helper\">{{ helper }}</div>\n </div>\n</template>\n"],"mappings":"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"}
@@ -1,5 +1,7 @@
1
1
  import e from "./PlBtnAccent.vue2.js";
2
+ //#region src/components/PlBtnAccent/PlBtnAccent.vue
2
3
  var t = e;
4
+ //#endregion
3
5
  export { t as default };
4
6
 
5
7
  //# sourceMappingURL=PlBtnAccent.js.map
@@ -19,6 +19,7 @@ var s = /* @__PURE__ */ n({
19
19
  }, 16));
20
20
  }
21
21
  });
22
+ //#endregion
22
23
  export { s as default };
23
24
 
24
25
  //# sourceMappingURL=PlBtnAccent.vue2.js.map
@@ -1,5 +1,7 @@
1
1
  import e from "./PlBtnDanger.vue2.js";
2
+ //#region src/components/PlBtnDanger/PlBtnDanger.vue
2
3
  var t = e;
4
+ //#endregion
3
5
  export { t as default };
4
6
 
5
7
  //# sourceMappingURL=PlBtnDanger.js.map
@@ -19,6 +19,7 @@ var s = /* @__PURE__ */ n({
19
19
  }, 16));
20
20
  }
21
21
  });
22
+ //#endregion
22
23
  export { s as default };
23
24
 
24
25
  //# sourceMappingURL=PlBtnDanger.vue2.js.map
@@ -1,5 +1,7 @@
1
1
  import e from "./PlBtnGhost.vue2.js";
2
+ //#region src/components/PlBtnGhost/PlBtnGhost.vue
2
3
  var t = e;
4
+ //#endregion
3
5
  export { t as default };
4
6
 
5
7
  //# sourceMappingURL=PlBtnGhost.js.map
@@ -3,6 +3,7 @@ import "../PlMaskIcon24/index.js";
3
3
  import { useRipple as t } from "../../composition/useRipple.js";
4
4
  import './pl-btn-ghost.css';/* empty css */
5
5
  import { computed as n, createBlock as r, createCommentVNode as i, createElementBlock as a, defineComponent as o, mergeProps as s, openBlock as c, ref as l, renderSlot as u, unref as d, useSlots as f } from "vue";
6
+ //#region src/components/PlBtnGhost/PlBtnGhost.vue?vue&type=script&setup=true&lang.ts
6
7
  var p = { key: 0 }, m = /* @__PURE__ */ o({
7
8
  name: "PlBtnGhost",
8
9
  props: {
@@ -49,6 +50,7 @@ var p = { key: 0 }, m = /* @__PURE__ */ o({
49
50
  ], 16));
50
51
  }
51
52
  });
53
+ //#endregion
52
54
  export { m as default };
53
55
 
54
56
  //# sourceMappingURL=PlBtnGhost.vue2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PlBtnGhost.vue_vue_type_script_setup_true_lang.js","names":["$attrs"],"sources":["../../../src/components/PlBtnGhost/PlBtnGhost.vue"],"sourcesContent":["<script lang=\"ts\">\n/**\n * Ghost button\n */\nexport default {\n name: \"PlBtnGhost\",\n};\n</script>\n\n<script lang=\"ts\" setup>\nimport \"./pl-btn-ghost.scss\";\nimport type { MaskIconName24, Size } from \"../../types\";\nimport { PlMaskIcon24 } from \"../PlMaskIcon24\";\nimport { computed, ref, useSlots } from \"vue\";\nimport { useRipple } from \"../../composition/useRipple\";\n\nconst props = withDefaults(\n defineProps<{\n /**\n * If `true,` the button is disabled, cannot be interacted with, and shows a special 'loading' icon.\n */\n loading?: boolean;\n /**\n * Size of the button, the default value is 'medium'\n */\n size?: Size;\n /**\n * If `true` the shape is round.\n */\n round?: boolean;\n /**\n * Icon to display\n */\n icon?: MaskIconName24;\n /**\n * If `true`, an icon is displayed before the text.\n */\n reverse?: boolean;\n /**\n * Justify text at the center (is `false` by default)\n */\n justifyCenter?: boolean;\n }>(),\n {\n size: undefined,\n icon: undefined,\n justifyCenter: false,\n },\n);\n\nconst small = computed(() => props.size === \"small\");\nconst large = computed(() => props.size === \"large\");\n\nconst btnRef = ref();\n\nconst slots = useSlots();\n\nuseRipple(btnRef);\n</script>\n\n<template>\n <button\n ref=\"btnRef\"\n tabindex=\"0\"\n class=\"pl-btn-ghost\"\n :class=\"{ loading, small, large, round, reverse, justifyCenter, [$attrs.class + '']: true }\"\n v-bind=\"{ ...$attrs, disabled: Boolean($attrs.disabled) || loading }\"\n >\n <span v-if=\"slots.default && !round\">\n <slot />\n </span>\n <slot name=\"icon\">\n <PlMaskIcon24 v-if=\"loading\" name=\"loading\" :size=\"size\" />\n <PlMaskIcon24 v-else-if=\"icon\" :name=\"icon\" :size=\"size\" />\n </slot>\n <slot name=\"append\" />\n </button>\n</template>\n"],"mappings":";;;;;;CAKE,MAAM;;;;;;;;;;;;;EAWR,IAAM,IAAQ,GAkCR,IAAQ,QAAe,EAAM,SAAS,QAAQ,EAC9C,IAAQ,QAAe,EAAM,SAAS,QAAQ,EAE9C,IAAS,GAAK,EAEd,IAAQ,GAAU;SAExB,EAAU,EAAO,kBAIf,EAeS,UAfT,EAeS;YAdH;GAAJ,KAAI;GACJ,UAAS;GACT,OAAK,CAAC,gBAAc;IAAA,SACV,EAAA;IAAO,OAAE,EAAA;IAAK,OAAE,EAAA;IAAK,OAAE,EAAA;IAAK,SAAE,EAAA;IAAO,eAAE,EAAA;KAAgBA,EAAAA,OAAO,QAAK,KAAA;IAAA,CAAA;;MAChEA,EAAAA;GAAM,UAAY,EAAQA,EAAAA,OAAO,YAAa,EAAA;GAAO,CAAA,EAAA;GAEtD,EAAA,EAAK,CAAC,WAAO,CAAK,EAAA,SAAA,GAAA,EAA9B,EAEO,QAAA,GAAA,CADL,EAAQ,EAAA,QAAA,UAAA,CAAA,CAAA,IAAA,EAAA,IAAA,GAAA;GAEV,EAGO,EAAA,QAAA,QAAA,EAAA,QAAA,CAFe,EAAA,WAAA,GAAA,EAApB,EAA2D,EAAA,EAAA,EAAA;;IAA9B,MAAK;IAAW,MAAM,EAAA;4BAC1B,EAAA,QAAA,GAAA,EAAzB,EAA2D,EAAA,EAAA,EAAA;;IAA3B,MAAM,EAAA;IAAO,MAAM,EAAA;;GAErD,EAAsB,EAAA,QAAA,SAAA"}
1
+ {"version":3,"file":"PlBtnGhost.vue_vue_type_script_setup_true_lang.js","names":["$attrs"],"sources":["../../../src/components/PlBtnGhost/PlBtnGhost.vue"],"sourcesContent":["<script lang=\"ts\">\n/**\n * Ghost button\n */\nexport default {\n name: \"PlBtnGhost\",\n};\n</script>\n\n<script lang=\"ts\" setup>\nimport \"./pl-btn-ghost.scss\";\nimport type { MaskIconName24, Size } from \"../../types\";\nimport { PlMaskIcon24 } from \"../PlMaskIcon24\";\nimport { computed, ref, useSlots } from \"vue\";\nimport { useRipple } from \"../../composition/useRipple\";\n\nconst props = withDefaults(\n defineProps<{\n /**\n * If `true,` the button is disabled, cannot be interacted with, and shows a special 'loading' icon.\n */\n loading?: boolean;\n /**\n * Size of the button, the default value is 'medium'\n */\n size?: Size;\n /**\n * If `true` the shape is round.\n */\n round?: boolean;\n /**\n * Icon to display\n */\n icon?: MaskIconName24;\n /**\n * If `true`, an icon is displayed before the text.\n */\n reverse?: boolean;\n /**\n * Justify text at the center (is `false` by default)\n */\n justifyCenter?: boolean;\n }>(),\n {\n size: undefined,\n icon: undefined,\n justifyCenter: false,\n },\n);\n\nconst small = computed(() => props.size === \"small\");\nconst large = computed(() => props.size === \"large\");\n\nconst btnRef = ref();\n\nconst slots = useSlots();\n\nuseRipple(btnRef);\n</script>\n\n<template>\n <button\n ref=\"btnRef\"\n tabindex=\"0\"\n class=\"pl-btn-ghost\"\n :class=\"{ loading, small, large, round, reverse, justifyCenter, [$attrs.class + '']: true }\"\n v-bind=\"{ ...$attrs, disabled: Boolean($attrs.disabled) || loading }\"\n >\n <span v-if=\"slots.default && !round\">\n <slot />\n </span>\n <slot name=\"icon\">\n <PlMaskIcon24 v-if=\"loading\" name=\"loading\" :size=\"size\" />\n <PlMaskIcon24 v-else-if=\"icon\" :name=\"icon\" :size=\"size\" />\n </slot>\n <slot name=\"append\" />\n </button>\n</template>\n"],"mappings":";;;;;;;CAKE,MAAM;;;;;;;;;;;;;EAWR,IAAM,IAAQ,GAkCR,IAAQ,QAAe,EAAM,SAAS,QAAQ,EAC9C,IAAQ,QAAe,EAAM,SAAS,QAAQ,EAE9C,IAAS,GAAK,EAEd,IAAQ,GAAU;SAExB,EAAU,EAAO,kBAIf,EAeS,UAfT,EAeS;YAdH;GAAJ,KAAI;GACJ,UAAS;GACT,OAAK,CAAC,gBAAc;IAAA,SACV,EAAA;IAAO,OAAE,EAAA;IAAK,OAAE,EAAA;IAAK,OAAE,EAAA;IAAK,SAAE,EAAA;IAAO,eAAE,EAAA;KAAgBA,EAAAA,OAAO,QAAK,KAAA;IAAA,CAAA;;MAChEA,EAAAA;GAAM,UAAY,EAAQA,EAAAA,OAAO,YAAa,EAAA;GAAO,CAAA,EAAA;GAEtD,EAAA,EAAK,CAAC,WAAO,CAAK,EAAA,SAAA,GAAA,EAA9B,EAEO,QAAA,GAAA,CADL,EAAQ,EAAA,QAAA,UAAA,CAAA,CAAA,IAAA,EAAA,IAAA,GAAA;GAEV,EAGO,EAAA,QAAA,QAAA,EAAA,QAAA,CAFe,EAAA,WAAA,GAAA,EAApB,EAA2D,EAAA,EAAA,EAAA;;IAA9B,MAAK;IAAW,MAAM,EAAA;4BAC1B,EAAA,QAAA,GAAA,EAAzB,EAA2D,EAAA,EAAA,EAAA;;IAA3B,MAAM,EAAA;IAAO,MAAM,EAAA;;GAErD,EAAsB,EAAA,QAAA,SAAA"}
@@ -1,5 +1,7 @@
1
1
  import e from "./PlBtnGroup.vue2.js";
2
+ //#region src/components/PlBtnGroup/PlBtnGroup.vue
2
3
  var t = e;
4
+ //#endregion
3
5
  export { t as default };
4
6
 
5
7
  //# sourceMappingURL=PlBtnGroup.js.map
@@ -4,6 +4,7 @@ import { getErrorMessage as t } from "../../helpers/error.js";
4
4
  import './pl-btn-group.css';/* empty css */
5
5
  import n from "../../utils/InnerBorder.js";
6
6
  import { Fragment as r, computed as i, createBlock as a, createCommentVNode as o, createElementBlock as s, createElementVNode as c, createVNode as l, defineComponent as u, normalizeClass as d, openBlock as f, renderList as p, renderSlot as m, toDisplayString as h, unref as g, useSlots as _, withCtx as v, withKeys as y } from "vue";
7
+ //#region src/components/PlBtnGroup/PlBtnGroup.vue?vue&type=script&setup=true&lang.ts
7
8
  var b = { key: 0 }, x = [
8
9
  "tabindex",
9
10
  "onKeydown",
@@ -57,6 +58,7 @@ var b = { key: 0 }, x = [
57
58
  ], 2));
58
59
  }
59
60
  });
61
+ //#endregion
60
62
  export { w as default };
61
63
 
62
64
  //# sourceMappingURL=PlBtnGroup.vue2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PlBtnGroup.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlBtnGroup/PlBtnGroup.vue"],"sourcesContent":["<script lang=\"ts\">\n/**\n * A component for selecting one value from a list of options\n */\nexport default {\n name: \"PlBtnGroup\",\n};\n</script>\n\n<script lang=\"ts\" setup generic=\"M = unknown\">\nimport \"./pl-btn-group.scss\";\nimport { computed, useSlots } from \"vue\";\nimport { PlTooltip } from \"../PlTooltip\";\nimport InnerBorder from \"../../utils/InnerBorder.vue\";\nimport type { SimpleOption } from \"../../types\";\nimport { getErrorMessage } from \"../../helpers/error.ts\";\n\nconst slots = useSlots();\n\nconst emit = defineEmits<{\n /**\n * Emitted when the model value is updated.\n */\n (e: \"update:modelValue\", value: M): void;\n}>();\n\nconst emitModel = (v: M) => emit(\"update:modelValue\", v);\n\nconst props = defineProps<{\n /**\n * The current selected value.\n */\n modelValue?: M;\n /**\n * The label text for the component (optional)\n */\n label?: string;\n /**\n * List of available options for the component\n */\n options: Readonly<SimpleOption<M>[]>;\n /**\n * If `true`, the component is disabled and cannot be interacted with.\n */\n disabled?: boolean;\n /**\n * If `true`, the height of the component is 32px\n */\n compact?: boolean;\n /**\n * A helper text displayed below the component when there are no errors (optional).\n */\n helper?: string;\n /**\n * Error message displayed below the component (optional)\n */\n error?: unknown;\n}>();\n\nconst normalizedOptions = computed(() =>\n props.options.map((it) => ({\n label: \"label\" in it ? it.label : it.text,\n value: it.value,\n })),\n);\n</script>\n\n<template>\n <div class=\"pl-btn-group\" :class=\"{ disabled, compact }\">\n <label v-if=\"label\">\n <span>{{ label }}</span>\n <PlTooltip v-if=\"slots.tooltip\" class=\"info\" position=\"top\">\n <template #tooltip>\n <slot name=\"tooltip\" />\n </template>\n </PlTooltip>\n </label>\n <InnerBorder class=\"pl-btn-group__container\">\n <div\n v-for=\"(opt, i) in normalizedOptions\"\n :key=\"i\"\n class=\"pl-btn-group__option text-s\"\n :tabindex=\"modelValue === opt.value || disabled ? undefined : 0\"\n :class=\"{ active: modelValue === opt.value }\"\n @keydown.enter=\"emitModel(opt.value)\"\n @click=\"emitModel(opt.value)\"\n >\n {{ opt.label }}\n </div>\n </InnerBorder>\n <div v-if=\"helper\" class=\"pl-btn-group__helper\">{{ helper }}</div>\n <div v-else-if=\"error\" class=\"pl-btn-group__error\">{{ getErrorMessage(error) }}</div>\n </div>\n</template>\n"],"mappings":";;;;;;;;;;;;;;;;;CAKE,MAAM;;;;;;;;;;;;EAYR,IAAM,IAAQ,GAAU,EAElB,IAAO,GAOP,KAAa,MAAS,EAAK,qBAAqB,EAAE,EAElD,IAAQ,GA+BR,IAAoB,QACxB,EAAM,QAAQ,KAAK,OAAQ;GACzB,OAAO,WAAW,IAAK,EAAG,QAAQ,EAAG;GACrC,OAAO,EAAG;GACX,EAAE,CACJ;yBAIC,EAwBM,OAAA,EAxBD,OAAK,EAAA,CAAC,gBAAc;GAAA,UAAW,EAAA;GAAQ,SAAE,EAAA;GAAO,CAAA,CAAA,EAAA,EAAA;GACtC,EAAA,SAAA,GAAA,EAAb,EAOQ,SAAA,GAAA,CANN,EAAwB,QAAA,MAAA,EAAf,EAAA,MAAK,EAAA,EAAA,EACG,EAAA,EAAK,CAAC,WAAA,GAAA,EAAvB,EAIY,EAAA,EAAA,EAAA;;IAJoB,OAAM;IAAO,UAAS;;IACzC,SAAO,QACO,CAAvB,EAAuB,EAAA,QAAA,UAAA,CAAA,CAAA;;;GAI7B,EAYc,GAAA,EAZD,OAAM,2BAAyB,EAAA;qBAEH,EAAA,EAAA,GAAA,EADvC,EAUM,GAAA,MAAA,EATe,EAAA,QAAX,GAAK,YADf,EAUM,OAAA;KARH,KAAK;KACN,OAAK,EAAA,CAAC,+BAA6B,EAAA,QAEjB,EAAA,eAAe,EAAI,OAAK,CAAA,CAAA;KADzC,UAAU,EAAA,eAAe,EAAI,SAAS,EAAA,WAAW,KAAA,IAAS;KAE1D,WAAO,GAAA,MAAQ,EAAU,EAAI,MAAK,EAAA,CAAA,QAAA,CAAA;KAClC,UAAK,MAAE,EAAU,EAAI,MAAK;SAExB,EAAI,MAAK,EAAA,IAAA,EAAA;;;GAGL,EAAA,UAAA,GAAA,EAAX,EAAkE,OAAlE,GAAkE,EAAf,EAAA,OAAM,EAAA,EAAA,IACzC,EAAA,SAAA,GAAA,EAAhB,EAAqF,OAArF,GAAqF,EAA/B,EAAA,EAAe,CAAC,EAAA,MAAK,CAAA,EAAA,EAAA,IAAA,EAAA,IAAA,GAAA"}
1
+ {"version":3,"file":"PlBtnGroup.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlBtnGroup/PlBtnGroup.vue"],"sourcesContent":["<script lang=\"ts\">\n/**\n * A component for selecting one value from a list of options\n */\nexport default {\n name: \"PlBtnGroup\",\n};\n</script>\n\n<script lang=\"ts\" setup generic=\"M = unknown\">\nimport \"./pl-btn-group.scss\";\nimport { computed, useSlots } from \"vue\";\nimport { PlTooltip } from \"../PlTooltip\";\nimport InnerBorder from \"../../utils/InnerBorder.vue\";\nimport type { SimpleOption } from \"../../types\";\nimport { getErrorMessage } from \"../../helpers/error.ts\";\n\nconst slots = useSlots();\n\nconst emit = defineEmits<{\n /**\n * Emitted when the model value is updated.\n */\n (e: \"update:modelValue\", value: M): void;\n}>();\n\nconst emitModel = (v: M) => emit(\"update:modelValue\", v);\n\nconst props = defineProps<{\n /**\n * The current selected value.\n */\n modelValue?: M;\n /**\n * The label text for the component (optional)\n */\n label?: string;\n /**\n * List of available options for the component\n */\n options: Readonly<SimpleOption<M>[]>;\n /**\n * If `true`, the component is disabled and cannot be interacted with.\n */\n disabled?: boolean;\n /**\n * If `true`, the height of the component is 32px\n */\n compact?: boolean;\n /**\n * A helper text displayed below the component when there are no errors (optional).\n */\n helper?: string;\n /**\n * Error message displayed below the component (optional)\n */\n error?: unknown;\n}>();\n\nconst normalizedOptions = computed(() =>\n props.options.map((it) => ({\n label: \"label\" in it ? it.label : it.text,\n value: it.value,\n })),\n);\n</script>\n\n<template>\n <div class=\"pl-btn-group\" :class=\"{ disabled, compact }\">\n <label v-if=\"label\">\n <span>{{ label }}</span>\n <PlTooltip v-if=\"slots.tooltip\" class=\"info\" position=\"top\">\n <template #tooltip>\n <slot name=\"tooltip\" />\n </template>\n </PlTooltip>\n </label>\n <InnerBorder class=\"pl-btn-group__container\">\n <div\n v-for=\"(opt, i) in normalizedOptions\"\n :key=\"i\"\n class=\"pl-btn-group__option text-s\"\n :tabindex=\"modelValue === opt.value || disabled ? undefined : 0\"\n :class=\"{ active: modelValue === opt.value }\"\n @keydown.enter=\"emitModel(opt.value)\"\n @click=\"emitModel(opt.value)\"\n >\n {{ opt.label }}\n </div>\n </InnerBorder>\n <div v-if=\"helper\" class=\"pl-btn-group__helper\">{{ helper }}</div>\n <div v-else-if=\"error\" class=\"pl-btn-group__error\">{{ getErrorMessage(error) }}</div>\n </div>\n</template>\n"],"mappings":";;;;;;;;;;;;;;;;;;CAKE,MAAM;;;;;;;;;;;;EAYR,IAAM,IAAQ,GAAU,EAElB,IAAO,GAOP,KAAa,MAAS,EAAK,qBAAqB,EAAE,EAElD,IAAQ,GA+BR,IAAoB,QACxB,EAAM,QAAQ,KAAK,OAAQ;GACzB,OAAO,WAAW,IAAK,EAAG,QAAQ,EAAG;GACrC,OAAO,EAAG;GACX,EAAE,CACJ;yBAIC,EAwBM,OAAA,EAxBD,OAAK,EAAA,CAAC,gBAAc;GAAA,UAAW,EAAA;GAAQ,SAAE,EAAA;GAAO,CAAA,CAAA,EAAA,EAAA;GACtC,EAAA,SAAA,GAAA,EAAb,EAOQ,SAAA,GAAA,CANN,EAAwB,QAAA,MAAA,EAAf,EAAA,MAAK,EAAA,EAAA,EACG,EAAA,EAAK,CAAC,WAAA,GAAA,EAAvB,EAIY,EAAA,EAAA,EAAA;;IAJoB,OAAM;IAAO,UAAS;;IACzC,SAAO,QACO,CAAvB,EAAuB,EAAA,QAAA,UAAA,CAAA,CAAA;;;GAI7B,EAYc,GAAA,EAZD,OAAM,2BAAyB,EAAA;qBAEH,EAAA,EAAA,GAAA,EADvC,EAUM,GAAA,MAAA,EATe,EAAA,QAAX,GAAK,YADf,EAUM,OAAA;KARH,KAAK;KACN,OAAK,EAAA,CAAC,+BAA6B,EAAA,QAEjB,EAAA,eAAe,EAAI,OAAK,CAAA,CAAA;KADzC,UAAU,EAAA,eAAe,EAAI,SAAS,EAAA,WAAW,KAAA,IAAS;KAE1D,WAAO,GAAA,MAAQ,EAAU,EAAI,MAAK,EAAA,CAAA,QAAA,CAAA;KAClC,UAAK,MAAE,EAAU,EAAI,MAAK;SAExB,EAAI,MAAK,EAAA,IAAA,EAAA;;;GAGL,EAAA,UAAA,GAAA,EAAX,EAAkE,OAAlE,GAAkE,EAAf,EAAA,OAAM,EAAA,EAAA,IACzC,EAAA,SAAA,GAAA,EAAhB,EAAqF,OAArF,GAAqF,EAA/B,EAAA,EAAe,CAAC,EAAA,MAAK,CAAA,EAAA,EAAA,IAAA,EAAA,IAAA,GAAA"}
@@ -1,5 +1,7 @@
1
1
  import e from "./PlBtnLink.vue2.js";
2
+ //#region src/components/PlBtnLink/PlBtnLink.vue
2
3
  var t = e;
4
+ //#endregion
3
5
  export { t as default };
4
6
 
5
7
  //# sourceMappingURL=PlBtnLink.js.map
@@ -1,6 +1,7 @@
1
1
  import './pl-btn-link.css';/* empty css */
2
2
  import e from "../PlBtnSecondary/PlBtnSecondary.js";
3
3
  import { createElementBlock as t, createVNode as n, defineComponent as r, mergeProps as i, normalizeClass as a, openBlock as o, ref as s, renderSlot as c } from "vue";
4
+ //#region src/components/PlBtnLink/PlBtnLink.vue?vue&type=script&setup=true&lang.ts
4
5
  var l = /* @__PURE__ */ r({
5
6
  __name: "PlBtnLink",
6
7
  props: {
@@ -27,6 +28,7 @@ var l = /* @__PURE__ */ r({
27
28
  }, l), null, 16, ["hover"]), c(s.$slots, "default")], 34));
28
29
  }
29
30
  });
31
+ //#endregion
30
32
  export { l as default };
31
33
 
32
34
  //# sourceMappingURL=PlBtnLink.vue2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PlBtnLink.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlBtnLink/PlBtnLink.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport \"./pl-btn-link.scss\";\nimport type { MaskIconName16, Size } from \"../../types\";\nimport BtnSecondary from \"../PlBtnSecondary/PlBtnSecondary.vue\";\nimport { ref } from \"vue\";\n\nconst props = defineProps<{\n /**\n * If `true,` the button is disabled, cannot be interacted with, and shows a special 'loading' icon.\n */\n loading?: boolean;\n /**\n * Size of the button, the default value is 'medium'\n */\n size?: Size;\n /**\n * Icon to display\n */\n icon?: MaskIconName16;\n /**\n * If `true`, an icon is displayed before the text.\n */\n reverse?: boolean;\n /**\n * Justify text at the center (is `true` by default)\n */\n justifyCenter?: boolean;\n /**\n * If `true`, the button is disabled and cannot be interacted with.\n */\n disabled?: boolean;\n}>();\n\nconst hover = ref(false);\n</script>\n\n<template>\n <div\n class=\"ui-btn-link\"\n :class=\"{ disabled, loading, hover }\"\n @mouseover=\"hover = true\"\n @mouseleave=\"hover = false\"\n >\n <BtnSecondary round :hover=\"hover\" v-bind=\"props\" />\n <slot />\n </div>\n</template>\n"],"mappings":";;;;;;;;;;;;;;EAMA,IAAM,IAAQ,GA2BR,IAAQ,EAAI,GAAM;yBAItB,EAQM,OAAA;GAPJ,OAAK,EAAA,CAAC,eAAa;IAAA,UACT,EAAA;IAAQ,SAAE,EAAA;IAAO,OAAE,EAAA;IAAK,CAAA,CAAA;GACjC,aAAS,AAAA,EAAA,QAAA,MAAE,EAAA,QAAK;GAChB,cAAU,AAAA,EAAA,QAAA,MAAE,EAAA,QAAK;MAElB,EAAoD,GAApD,EAAoD;GAAtC,OAAA;GAAO,OAAO,EAAA;KAAe,EAAK,EAAA,MAAA,IAAA,CAAA,QAAA,CAAA,EAChD,EAAQ,EAAA,QAAA,UAAA,CAAA,EAAA,GAAA"}
1
+ {"version":3,"file":"PlBtnLink.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlBtnLink/PlBtnLink.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport \"./pl-btn-link.scss\";\nimport type { MaskIconName16, Size } from \"../../types\";\nimport BtnSecondary from \"../PlBtnSecondary/PlBtnSecondary.vue\";\nimport { ref } from \"vue\";\n\nconst props = defineProps<{\n /**\n * If `true,` the button is disabled, cannot be interacted with, and shows a special 'loading' icon.\n */\n loading?: boolean;\n /**\n * Size of the button, the default value is 'medium'\n */\n size?: Size;\n /**\n * Icon to display\n */\n icon?: MaskIconName16;\n /**\n * If `true`, an icon is displayed before the text.\n */\n reverse?: boolean;\n /**\n * Justify text at the center (is `true` by default)\n */\n justifyCenter?: boolean;\n /**\n * If `true`, the button is disabled and cannot be interacted with.\n */\n disabled?: boolean;\n}>();\n\nconst hover = ref(false);\n</script>\n\n<template>\n <div\n class=\"ui-btn-link\"\n :class=\"{ disabled, loading, hover }\"\n @mouseover=\"hover = true\"\n @mouseleave=\"hover = false\"\n >\n <BtnSecondary round :hover=\"hover\" v-bind=\"props\" />\n <slot />\n </div>\n</template>\n"],"mappings":";;;;;;;;;;;;;;;EAMA,IAAM,IAAQ,GA2BR,IAAQ,EAAI,GAAM;yBAItB,EAQM,OAAA;GAPJ,OAAK,EAAA,CAAC,eAAa;IAAA,UACT,EAAA;IAAQ,SAAE,EAAA;IAAO,OAAE,EAAA;IAAK,CAAA,CAAA;GACjC,aAAS,AAAA,EAAA,QAAA,MAAE,EAAA,QAAK;GAChB,cAAU,AAAA,EAAA,QAAA,MAAE,EAAA,QAAK;MAElB,EAAoD,GAApD,EAAoD;GAAtC,OAAA;GAAO,OAAO,EAAA;KAAe,EAAK,EAAA,MAAA,IAAA,CAAA,QAAA,CAAA,EAChD,EAAQ,EAAA,QAAA,UAAA,CAAA,EAAA,GAAA"}
@@ -1,5 +1,7 @@
1
1
  import e from "./PlBtnPrimary.vue2.js";
2
+ //#region src/components/PlBtnPrimary/PlBtnPrimary.vue
2
3
  var t = e;
4
+ //#endregion
3
5
  export { t as default };
4
6
 
5
7
  //# sourceMappingURL=PlBtnPrimary.js.map
@@ -19,6 +19,7 @@ var s = /* @__PURE__ */ n({
19
19
  }, 16));
20
20
  }
21
21
  });
22
+ //#endregion
22
23
  export { s as default };
23
24
 
24
25
  //# sourceMappingURL=PlBtnPrimary.vue2.js.map
@@ -1,5 +1,7 @@
1
1
  import e from "./PlBtnSecondary.vue2.js";
2
+ //#region src/components/PlBtnSecondary/PlBtnSecondary.vue
2
3
  var t = e;
4
+ //#endregion
3
5
  export { t as default };
4
6
 
5
7
  //# sourceMappingURL=PlBtnSecondary.js.map
@@ -19,6 +19,7 @@ var s = /* @__PURE__ */ n({
19
19
  }, 16));
20
20
  }
21
21
  });
22
+ //#endregion
22
23
  export { s as default };
23
24
 
24
25
  //# sourceMappingURL=PlBtnSecondary.vue2.js.map
@@ -1,5 +1,7 @@
1
1
  import e from "./PlBtnSplit.vue2.js";
2
+ //#region src/components/PlBtnSplit/PlBtnSplit.vue
2
3
  var t = e;
4
+ //#endregion
3
5
  export { t as default };
4
6
 
5
7
  //# sourceMappingURL=PlBtnSplit.js.map
@@ -6,6 +6,7 @@ import { useElementPosition as r } from "../../composition/usePosition.js";
6
6
  import './pl-btn-split.css';/* empty css */
7
7
  import { Fragment as i, Teleport as a, computed as o, createBlock as s, createCommentVNode as c, createElementBlock as l, createElementVNode as u, defineComponent as d, mergeModels as f, normalizeClass as p, normalizeStyle as m, openBlock as h, reactive as g, ref as _, renderList as v, toDisplayString as y, unref as b, useModel as x, watch as S, withKeys as C, withModifiers as w } from "vue";
8
8
  import { deepEqual as T } from "@milaboratories/helpers";
9
+ //#region src/components/PlBtnSplit/PlBtnSplit.vue?vue&type=script&setup=true&lang.ts
9
10
  var E = ["onKeyup"], D = /* @__PURE__ */ d({
10
11
  __name: "PlBtnSplit",
11
12
  props: /* @__PURE__ */ f({
@@ -132,6 +133,7 @@ var E = ["onKeyup"], D = /* @__PURE__ */ d({
132
133
  ], 34));
133
134
  }
134
135
  });
136
+ //#endregion
135
137
  export { D as default };
136
138
 
137
139
  //# sourceMappingURL=PlBtnSplit.vue2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PlBtnSplit.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlBtnSplit/PlBtnSplit.vue"],"sourcesContent":["<script setup lang=\"ts\" generic=\"M = unknown\">\nimport { deepEqual } from \"@milaboratories/helpers\";\nimport { computed, reactive, ref, unref, watch } from \"vue\";\nimport { useElementPosition } from \"../../composition/usePosition\";\nimport { normalizeListOptions } from \"../../helpers/utils\";\nimport type { ListOption } from \"../../types\";\nimport DropdownListItem from \"../DropdownListItem.vue\";\nimport { PlIcon16 } from \"../PlIcon16\";\n\nimport \"./pl-btn-split.scss\";\n\nconst props = defineProps<{\n /**\n * List of available options for the dropdown menu\n */\n options?: Readonly<ListOption<M>[]>;\n\n /**\n * If `true`, the dropdown component is disabled and cannot be interacted with.\n */\n disabled?: boolean;\n\n /**\n * If `true,` the button is disabled, cannot be interacted with, and shows a special 'loading' icon.\n */\n loading?: boolean;\n}>();\n\nconst emits = defineEmits([\"click\"]);\n\nconst model = defineModel<M>({ required: true });\n\nconst root = ref<HTMLElement | undefined>();\nconst list = ref<HTMLElement | undefined>();\nconst menuActivator = ref<HTMLElement | undefined>();\nconst buttonAction = ref<HTMLElement | undefined>();\n\nconst data = reactive({\n open: false,\n optionsHeight: 0,\n activeIndex: -1,\n});\n\ndefineExpose({\n data,\n});\n\nconst optionsStyle = reactive({\n top: \"0px\",\n left: \"0px\",\n width: \"0px\",\n});\n\nwatch(\n list,\n (el) => {\n if (el) {\n const rect = el.getBoundingClientRect();\n data.optionsHeight = rect.height;\n window.dispatchEvent(new CustomEvent(\"adjust\"));\n }\n },\n { immediate: true },\n);\n\nconst iconName = computed(() => (data.open ? \"chevron-up\" : \"chevron-down\"));\n\nconst selectedIndex = computed(() => {\n return (props.options ?? []).findIndex((o) => deepEqual(o.value, model.value));\n});\n\nconst items = computed(() =>\n normalizeListOptions(props.options ?? []).map((opt, index) => ({\n ...opt,\n index,\n isSelected: index === selectedIndex.value,\n isActive: index === data.activeIndex,\n })),\n);\n\nconst isLoadingOptions = computed(() => props.loading || props.options === undefined);\n\nconst actionName = computed(\n () =>\n items.value.find((o) => deepEqual(o.value, model.value))?.label ??\n (props.options === undefined ? \"...\" : \"\"),\n);\n\nuseElementPosition(root, (pos) => {\n const focusWidth = 3;\n\n const downTopOffset = pos.top + pos.height + focusWidth;\n\n if (downTopOffset + data.optionsHeight > pos.clientHeight) {\n optionsStyle.top = pos.top - data.optionsHeight - focusWidth + \"px\";\n } else {\n optionsStyle.top = downTopOffset + \"px\";\n }\n\n optionsStyle.left = pos.left + \"px\";\n optionsStyle.width = pos.width + \"px\";\n});\n\nconst selectOption = (v: M | undefined) => {\n model.value = v!;\n data.open = false;\n root?.value?.focus();\n};\n\nfunction emitEnter() {\n emits(\"click\");\n}\n\nconst handleKeydown = (e: {\n code: string;\n preventDefault(): void;\n stopPropagation(): void;\n target: EventTarget | null;\n}) => {\n if (![\"ArrowDown\", \"ArrowUp\", \"Enter\", \"Escape\"].includes(e.code)) {\n return;\n } else {\n e.preventDefault();\n }\n\n if (e.target === buttonAction.value && e.code === \"Enter\") {\n emitEnter();\n return;\n }\n\n const { open, activeIndex } = data;\n\n if (!open && e.target === menuActivator.value) {\n if (e.code === \"Enter\") {\n data.open = true;\n }\n return;\n }\n\n if (e.code === \"Escape\") {\n data.open = false;\n root.value?.focus();\n }\n\n const filtered = unref(items);\n\n const { length } = filtered;\n\n if (!length) {\n return;\n }\n\n if (e.code === \"Enter\") {\n selectOption(filtered.find((it) => it.index === activeIndex)?.value);\n }\n\n const localIndex = filtered.findIndex((it) => it.index === activeIndex) ?? -1;\n\n const delta = e.code === \"ArrowDown\" ? 1 : e.code === \"ArrowUp\" ? -1 : 0;\n\n const newIndex = Math.abs(localIndex + delta + length) % length;\n\n data.activeIndex = items.value[newIndex].index ?? -1;\n};\n\nconst onFocusOut = (event: FocusEvent) => {\n const relatedTarget = event.relatedTarget as Node | null;\n\n if (!root.value?.contains(relatedTarget) && !list.value?.contains(relatedTarget)) {\n data.open = false;\n }\n};\n</script>\n<template>\n <div\n ref=\"root\"\n :class=\"{ disabled: disabled || isLoadingOptions, loading: isLoadingOptions }\"\n class=\"pl-btn-split d-flex\"\n @focusout=\"onFocusOut\"\n @keydown=\"handleKeydown\"\n >\n <div\n ref=\"buttonAction\"\n class=\"pl-btn-split__title flex-grow-1 d-flex align-center text-s-btn\"\n tabindex=\"0\"\n @click=\"emitEnter\"\n @keyup.stop.enter=\"emitEnter\"\n >\n {{ actionName }}\n </div>\n <div\n ref=\"menuActivator\"\n class=\"pl-btn-split__icon-container d-flex align-center justify-center\"\n tabindex=\"0\"\n @click=\"data.open = !data.open\"\n >\n <PlIcon16 v-if=\"isLoadingOptions\" name=\"loading\" />\n <PlIcon16 v-else :name=\"iconName\" class=\"pl-btn-split__icon\" />\n </div>\n\n <Teleport v-if=\"data.open\" to=\"body\">\n <div ref=\"list\" class=\"pl-dropdown__options\" :style=\"optionsStyle\" tabindex=\"-1\">\n <DropdownListItem\n v-for=\"(item, index) in items\"\n :key=\"index\"\n :option=\"item\"\n :is-selected=\"item.isSelected\"\n :is-hovered=\"item.isActive\"\n :size=\"'medium'\"\n @click.stop=\"selectOption(item.value)\"\n />\n </div>\n </Teleport>\n </div>\n</template>\n"],"mappings":";;;;;;;;;;;;;;;;;;;;EAWA,IAAM,IAAQ,GAiBR,IAAQ,GAER,IAAQ,EAAc,GAAA,aAAoB,EAE1C,IAAO,GAA8B,EACrC,IAAO,GAA8B,EACrC,IAAgB,GAA8B,EAC9C,IAAe,GAA8B,EAE7C,IAAO,EAAS;GACpB,MAAM;GACN,eAAe;GACf,aAAa;GACd,CAAC;AAEF,IAAa,EACX,SACD,CAAC;EAEF,IAAM,IAAe,EAAS;GAC5B,KAAK;GACL,MAAM;GACN,OAAO;GACR,CAAC;AAEF,IACE,IACC,MAAO;AACN,GAAI,MAEF,EAAK,gBADQ,EAAG,uBAAuB,CACb,QAC1B,OAAO,cAAc,IAAI,YAAY,SAAS,CAAC;KAGnD,EAAE,WAAW,IAAM,CACpB;EAED,IAAM,IAAW,QAAgB,EAAK,OAAO,eAAe,eAAgB,EAEtE,IAAgB,SACZ,EAAM,WAAW,EAAE,EAAE,WAAW,MAAM,EAAU,EAAE,OAAO,EAAM,MAAM,CAAC,CAC9E,EAEI,IAAQ,QACZ,EAAqB,EAAM,WAAW,EAAE,CAAC,CAAC,KAAK,GAAK,OAAW;GAC7D,GAAG;GACH;GACA,YAAY,MAAU,EAAc;GACpC,UAAU,MAAU,EAAK;GAC1B,EAAE,CACJ,EAEK,IAAmB,QAAe,EAAM,WAAW,EAAM,YAAY,KAAA,EAAU,EAE/E,IAAa,QAEf,EAAM,MAAM,MAAM,MAAM,EAAU,EAAE,OAAO,EAAM,MAAM,CAAC,EAAE,UACzD,EAAM,YAAY,KAAA,IAAY,QAAQ,IAC1C;AAED,IAAmB,IAAO,MAAQ;GAChC,IAEM,IAAgB,EAAI,MAAM,EAAI,SAAS;AAS7C,GAPI,IAAgB,EAAK,gBAAgB,EAAI,eAC3C,EAAa,MAAM,EAAI,MAAM,EAAK,gBAAgB,IAAa,OAE/D,EAAa,MAAM,IAAgB,MAGrC,EAAa,OAAO,EAAI,OAAO,MAC/B,EAAa,QAAQ,EAAI,QAAQ;IACjC;EAEF,IAAM,KAAgB,MAAqB;AAGzC,GAFA,EAAM,QAAQ,GACd,EAAK,OAAO,IACZ,GAAM,OAAO,OAAO;;EAGtB,SAAS,IAAY;AACnB,KAAM,QAAQ;;EAGhB,IAAM,KAAiB,MAKjB;AACJ,OAAK;IAAC;IAAa;IAAW;IAAS;IAAS,CAAC,SAAS,EAAE,KAAK,CAG/D,GAAE,gBAAgB;OAFlB;AAKF,OAAI,EAAE,WAAW,EAAa,SAAS,EAAE,SAAS,SAAS;AACzD,OAAW;AACX;;GAGF,IAAM,EAAE,SAAM,mBAAgB;AAE9B,OAAI,CAAC,KAAQ,EAAE,WAAW,EAAc,OAAO;AAC7C,IAAI,EAAE,SAAS,YACb,EAAK,OAAO;AAEd;;AAGF,GAAI,EAAE,SAAS,aACb,EAAK,OAAO,IACZ,EAAK,OAAO,OAAO;GAGrB,IAAM,IAAW,EAAM,EAAM,EAEvB,EAAE,cAAW;AAEnB,OAAI,CAAC,EACH;AAGF,GAAI,EAAE,SAAS,WACb,EAAa,EAAS,MAAM,MAAO,EAAG,UAAU,EAAY,EAAE,MAAM;GAGtE,IAAM,IAAa,EAAS,WAAW,MAAO,EAAG,UAAU,EAAY,IAAI,IAErE,IAAQ,EAAE,SAAS,cAAc,IAAI,EAAE,SAAS,YAAY,KAAK,GAEjE,IAAW,KAAK,IAAI,IAAa,IAAQ,EAAO,GAAG;AAEzD,KAAK,cAAc,EAAM,MAAM,GAAU,SAAS;KAG9C,KAAc,MAAsB;GACxC,IAAM,IAAgB,EAAM;AAE5B,GAAI,CAAC,EAAK,OAAO,SAAS,EAAc,IAAI,CAAC,EAAK,OAAO,SAAS,EAAc,KAC9E,EAAK,OAAO;;yBAKd,EAuCM,OAAA;YAtCA;GAAJ,KAAI;GACH,OAAK,EAAA,CAAA;IAAA,UAAc,EAAA,YAAY,EAAA;IAAgB,SAAW,EAAA;IAAgB,EACrE,sBAAqB,CAAA;GAC1B,YAAU;GACV,WAAS;;GAEV,EAQM,OAAA;aAPA;IAAJ,KAAI;IACJ,OAAM;IACN,UAAS;IACR,SAAO;IACP,SAAK,EAAA,EAAa,GAAS,CAAA,OAAA,CAAA,EAAA,CAAA,QAAA,CAAA;QAEzB,EAAA,MAAU,EAAA,IAAA,EAAA;GAEf,EAQM,OAAA;aAPA;IAAJ,KAAI;IACJ,OAAM;IACN,UAAS;IACR,SAAK,AAAA,EAAA,QAAA,MAAE,EAAK,OAAI,CAAI,EAAK;OAEV,EAAA,SAAA,GAAA,EAAhB,EAAmD,EAAA,EAAA,EAAA;;IAAjB,MAAK;eACvC,EAA+D,EAAA,EAAA,EAAA;;IAA7C,MAAM,EAAA;IAAU,OAAM;;GAG1B,EAAK,QAAA,GAAA,EAArB,EAYW,GAAA;;IAZgB,IAAG;OAC5B,EAUM,OAAA;aAVG;IAAJ,KAAI;IAAO,OAAM;IAAwB,OAAK,EAAE,EAAY;IAAE,UAAS;eAC1E,EAQE,GAAA,MAAA,EAPwB,EAAA,QAAhB,GAAM,YADhB,EAQE,GAAA;IANC,KAAK;IACL,QAAQ;IACR,eAAa,EAAK;IAClB,cAAY,EAAK;IACjB,MAAM;IACN,SAAK,GAAA,MAAO,EAAa,EAAK,MAAK,EAAA,CAAA,OAAA,CAAA"}
1
+ {"version":3,"file":"PlBtnSplit.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlBtnSplit/PlBtnSplit.vue"],"sourcesContent":["<script setup lang=\"ts\" generic=\"M = unknown\">\nimport { deepEqual } from \"@milaboratories/helpers\";\nimport { computed, reactive, ref, unref, watch } from \"vue\";\nimport { useElementPosition } from \"../../composition/usePosition\";\nimport { normalizeListOptions } from \"../../helpers/utils\";\nimport type { ListOption } from \"../../types\";\nimport DropdownListItem from \"../DropdownListItem.vue\";\nimport { PlIcon16 } from \"../PlIcon16\";\n\nimport \"./pl-btn-split.scss\";\n\nconst props = defineProps<{\n /**\n * List of available options for the dropdown menu\n */\n options?: Readonly<ListOption<M>[]>;\n\n /**\n * If `true`, the dropdown component is disabled and cannot be interacted with.\n */\n disabled?: boolean;\n\n /**\n * If `true,` the button is disabled, cannot be interacted with, and shows a special 'loading' icon.\n */\n loading?: boolean;\n}>();\n\nconst emits = defineEmits([\"click\"]);\n\nconst model = defineModel<M>({ required: true });\n\nconst root = ref<HTMLElement | undefined>();\nconst list = ref<HTMLElement | undefined>();\nconst menuActivator = ref<HTMLElement | undefined>();\nconst buttonAction = ref<HTMLElement | undefined>();\n\nconst data = reactive({\n open: false,\n optionsHeight: 0,\n activeIndex: -1,\n});\n\ndefineExpose({\n data,\n});\n\nconst optionsStyle = reactive({\n top: \"0px\",\n left: \"0px\",\n width: \"0px\",\n});\n\nwatch(\n list,\n (el) => {\n if (el) {\n const rect = el.getBoundingClientRect();\n data.optionsHeight = rect.height;\n window.dispatchEvent(new CustomEvent(\"adjust\"));\n }\n },\n { immediate: true },\n);\n\nconst iconName = computed(() => (data.open ? \"chevron-up\" : \"chevron-down\"));\n\nconst selectedIndex = computed(() => {\n return (props.options ?? []).findIndex((o) => deepEqual(o.value, model.value));\n});\n\nconst items = computed(() =>\n normalizeListOptions(props.options ?? []).map((opt, index) => ({\n ...opt,\n index,\n isSelected: index === selectedIndex.value,\n isActive: index === data.activeIndex,\n })),\n);\n\nconst isLoadingOptions = computed(() => props.loading || props.options === undefined);\n\nconst actionName = computed(\n () =>\n items.value.find((o) => deepEqual(o.value, model.value))?.label ??\n (props.options === undefined ? \"...\" : \"\"),\n);\n\nuseElementPosition(root, (pos) => {\n const focusWidth = 3;\n\n const downTopOffset = pos.top + pos.height + focusWidth;\n\n if (downTopOffset + data.optionsHeight > pos.clientHeight) {\n optionsStyle.top = pos.top - data.optionsHeight - focusWidth + \"px\";\n } else {\n optionsStyle.top = downTopOffset + \"px\";\n }\n\n optionsStyle.left = pos.left + \"px\";\n optionsStyle.width = pos.width + \"px\";\n});\n\nconst selectOption = (v: M | undefined) => {\n model.value = v!;\n data.open = false;\n root?.value?.focus();\n};\n\nfunction emitEnter() {\n emits(\"click\");\n}\n\nconst handleKeydown = (e: {\n code: string;\n preventDefault(): void;\n stopPropagation(): void;\n target: EventTarget | null;\n}) => {\n if (![\"ArrowDown\", \"ArrowUp\", \"Enter\", \"Escape\"].includes(e.code)) {\n return;\n } else {\n e.preventDefault();\n }\n\n if (e.target === buttonAction.value && e.code === \"Enter\") {\n emitEnter();\n return;\n }\n\n const { open, activeIndex } = data;\n\n if (!open && e.target === menuActivator.value) {\n if (e.code === \"Enter\") {\n data.open = true;\n }\n return;\n }\n\n if (e.code === \"Escape\") {\n data.open = false;\n root.value?.focus();\n }\n\n const filtered = unref(items);\n\n const { length } = filtered;\n\n if (!length) {\n return;\n }\n\n if (e.code === \"Enter\") {\n selectOption(filtered.find((it) => it.index === activeIndex)?.value);\n }\n\n const localIndex = filtered.findIndex((it) => it.index === activeIndex) ?? -1;\n\n const delta = e.code === \"ArrowDown\" ? 1 : e.code === \"ArrowUp\" ? -1 : 0;\n\n const newIndex = Math.abs(localIndex + delta + length) % length;\n\n data.activeIndex = items.value[newIndex].index ?? -1;\n};\n\nconst onFocusOut = (event: FocusEvent) => {\n const relatedTarget = event.relatedTarget as Node | null;\n\n if (!root.value?.contains(relatedTarget) && !list.value?.contains(relatedTarget)) {\n data.open = false;\n }\n};\n</script>\n<template>\n <div\n ref=\"root\"\n :class=\"{ disabled: disabled || isLoadingOptions, loading: isLoadingOptions }\"\n class=\"pl-btn-split d-flex\"\n @focusout=\"onFocusOut\"\n @keydown=\"handleKeydown\"\n >\n <div\n ref=\"buttonAction\"\n class=\"pl-btn-split__title flex-grow-1 d-flex align-center text-s-btn\"\n tabindex=\"0\"\n @click=\"emitEnter\"\n @keyup.stop.enter=\"emitEnter\"\n >\n {{ actionName }}\n </div>\n <div\n ref=\"menuActivator\"\n class=\"pl-btn-split__icon-container d-flex align-center justify-center\"\n tabindex=\"0\"\n @click=\"data.open = !data.open\"\n >\n <PlIcon16 v-if=\"isLoadingOptions\" name=\"loading\" />\n <PlIcon16 v-else :name=\"iconName\" class=\"pl-btn-split__icon\" />\n </div>\n\n <Teleport v-if=\"data.open\" to=\"body\">\n <div ref=\"list\" class=\"pl-dropdown__options\" :style=\"optionsStyle\" tabindex=\"-1\">\n <DropdownListItem\n v-for=\"(item, index) in items\"\n :key=\"index\"\n :option=\"item\"\n :is-selected=\"item.isSelected\"\n :is-hovered=\"item.isActive\"\n :size=\"'medium'\"\n @click.stop=\"selectOption(item.value)\"\n />\n </div>\n </Teleport>\n </div>\n</template>\n"],"mappings":"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"}
@@ -2,6 +2,7 @@ import e from "../../_virtual/_plugin-vue_export-helper.js";
2
2
  import t from "./PlChartHistogram.vue2.js";
3
3
  import n from "./PlChartHistogram.style.js";
4
4
  var r = /* @__PURE__ */ e(t, [["__cssModules", { $style: n }]]);
5
+ //#endregion
5
6
  export { r as default };
6
7
 
7
8
  //# sourceMappingURL=PlChartHistogram.js.map
@@ -2,6 +2,7 @@ import './PlChartHistogram.vue.css';var e = {
2
2
  component: "_component_12ebd_2",
3
3
  title: "_title_12ebd_11"
4
4
  };
5
+ //#endregion
5
6
  export { e as default };
6
7
 
7
8
  //# sourceMappingURL=PlChartHistogram.style.js.map
@@ -1,5 +1,6 @@
1
1
  import { createHistogramFromBins as e, createHistogramLinear as t, createHistogramLog as n } from "./histogram.js";
2
2
  import { computed as r, createCommentVNode as i, createElementBlock as a, createElementVNode as o, defineComponent as s, normalizeClass as c, onMounted as l, openBlock as u, ref as d, toDisplayString as f, watch as p } from "vue";
3
+ //#region src/components/PlChartHistogram/PlChartHistogram.vue?vue&type=script&setup=true&lang.ts
3
4
  var m = /* @__PURE__ */ s({
4
5
  __name: "PlChartHistogram",
5
6
  props: { settings: {} },
@@ -43,6 +44,7 @@ var m = /* @__PURE__ */ s({
43
44
  }, null, 512)], 2));
44
45
  }
45
46
  });
47
+ //#endregion
46
48
  export { m as default };
47
49
 
48
50
  //# sourceMappingURL=PlChartHistogram.vue2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PlChartHistogram.vue_vue_type_script_setup_true_lang.js","names":["$style"],"sources":["../../../src/components/PlChartHistogram/PlChartHistogram.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { computed, onMounted, ref, watch } from \"vue\";\nimport { createHistogramFromBins, createHistogramLinear, createHistogramLog } from \"./histogram\";\nimport type { ChartOptions, PlChartHistogramSettings } from \"./types\";\n\nconst props = defineProps<{\n settings: PlChartHistogramSettings;\n}>();\n\nconst chart = ref<HTMLElement>();\n\nconst options = computed<ChartOptions>(() => {\n const {\n xAxisLabel,\n yAxisLabel,\n threshold,\n compact,\n totalWidth = 674,\n totalHeight = 252,\n } = props.settings;\n\n const margin = compact\n ? { top: 0, right: 0, bottom: 0, left: 0 }\n : { top: 0, right: 30, bottom: 40, left: 85 };\n const width = totalWidth - margin.left - margin.right;\n const height = totalHeight - margin.top - margin.bottom;\n\n return {\n width,\n height,\n margin,\n compact,\n nBins: \"nBins\" in props.settings ? props.settings.nBins : 10,\n xAxisLabel: xAxisLabel,\n yAxisLabel: yAxisLabel,\n threshold: threshold,\n };\n});\n\nconst createHistogram = () => {\n const settings = props.settings;\n\n if (settings.type === \"log-bins\") {\n createHistogramFromBins(chart.value!, options.value, settings.bins);\n return;\n }\n\n if (settings.log) {\n createHistogramLog(chart.value!, options.value, settings.numbers);\n } else {\n createHistogramLinear(chart.value!, options.value, settings.numbers);\n }\n};\n\nwatch(props, createHistogram);\n\nonMounted(createHistogram);\n</script>\n\n<template>\n <div :class=\"$style.component\">\n <div v-if=\"settings.title && !settings.compact\" :class=\"$style.title\">{{ settings.title }}</div>\n <div ref=\"chart\" />\n </div>\n</template>\n\n<style module>\n.component {\n display: flex;\n flex-direction: column;\n gap: 24px;\n svg {\n font-family: var(--font-family-base);\n }\n}\n\n.title {\n font-size: 20px;\n font-weight: 500;\n line-height: 24px; /* 120% */\n letter-spacing: -0.2px;\n}\n\n:global(.svg-tooltip) {\n font-family: var(--font-family-base);\n background: rgba(69, 77, 93, 0.9);\n border-radius: 0.1rem;\n color: #fff;\n display: block;\n font-size: 14px;\n max-width: 320px;\n padding: 0.2rem 0.4rem;\n position: absolute;\n text-overflow: ellipsis;\n white-space: pre;\n z-index: 300;\n visibility: hidden;\n}\n</style>\n"],"mappings":";;;;;;EAKA,IAAM,IAAQ,GAIR,IAAQ,GAAkB,EAE1B,IAAU,QAA6B;GAC3C,IAAM,EACJ,eACA,eACA,cACA,YACA,gBAAa,KACb,iBAAc,QACZ,EAAM,UAEJ,IAAS,IACX;IAAE,KAAK;IAAG,OAAO;IAAG,QAAQ;IAAG,MAAM;IAAE,GACvC;IAAE,KAAK;IAAG,OAAO;IAAI,QAAQ;IAAI,MAAM;IAAI;AAI/C,UAAO;IACL,OAJY,IAAa,EAAO,OAAO,EAAO;IAK9C,QAJa,IAAc,EAAO,MAAM,EAAO;IAK/C;IACA;IACA,OAAO,WAAW,EAAM,WAAW,EAAM,SAAS,QAAQ;IAC9C;IACA;IACD;IACZ;IACD,EAEI,UAAwB;GAC5B,IAAM,IAAW,EAAM;AAEvB,OAAI,EAAS,SAAS,YAAY;AAChC,MAAwB,EAAM,OAAQ,EAAQ,OAAO,EAAS,KAAK;AACnE;;AAGF,GAAI,EAAS,MACX,EAAmB,EAAM,OAAQ,EAAQ,OAAO,EAAS,QAAQ,GAEjE,EAAsB,EAAM,OAAQ,EAAQ,OAAO,EAAS,QAAQ;;SAIxE,EAAM,GAAO,EAAgB,EAE7B,EAAU,EAAgB,kBAIxB,EAGM,OAAA,EAHA,OAAK,EAAEA,EAAAA,OAAO,UAAS,EAAA,EAAA,CAChB,EAAA,SAAS,SAAK,CAAK,EAAA,SAAS,WAAA,GAAA,EAAvC,EAAgG,OAAA;;GAA/C,OAAK,EAAEA,EAAAA,OAAO,MAAK;OAAK,EAAA,SAAS,MAAK,EAAA,EAAA,IAAA,EAAA,IAAA,GAAA,EACvF,EAAmB,OAAA;YAAV;GAAJ,KAAI"}
1
+ {"version":3,"file":"PlChartHistogram.vue_vue_type_script_setup_true_lang.js","names":["$style"],"sources":["../../../src/components/PlChartHistogram/PlChartHistogram.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { computed, onMounted, ref, watch } from \"vue\";\nimport { createHistogramFromBins, createHistogramLinear, createHistogramLog } from \"./histogram\";\nimport type { ChartOptions, PlChartHistogramSettings } from \"./types\";\n\nconst props = defineProps<{\n settings: PlChartHistogramSettings;\n}>();\n\nconst chart = ref<HTMLElement>();\n\nconst options = computed<ChartOptions>(() => {\n const {\n xAxisLabel,\n yAxisLabel,\n threshold,\n compact,\n totalWidth = 674,\n totalHeight = 252,\n } = props.settings;\n\n const margin = compact\n ? { top: 0, right: 0, bottom: 0, left: 0 }\n : { top: 0, right: 30, bottom: 40, left: 85 };\n const width = totalWidth - margin.left - margin.right;\n const height = totalHeight - margin.top - margin.bottom;\n\n return {\n width,\n height,\n margin,\n compact,\n nBins: \"nBins\" in props.settings ? props.settings.nBins : 10,\n xAxisLabel: xAxisLabel,\n yAxisLabel: yAxisLabel,\n threshold: threshold,\n };\n});\n\nconst createHistogram = () => {\n const settings = props.settings;\n\n if (settings.type === \"log-bins\") {\n createHistogramFromBins(chart.value!, options.value, settings.bins);\n return;\n }\n\n if (settings.log) {\n createHistogramLog(chart.value!, options.value, settings.numbers);\n } else {\n createHistogramLinear(chart.value!, options.value, settings.numbers);\n }\n};\n\nwatch(props, createHistogram);\n\nonMounted(createHistogram);\n</script>\n\n<template>\n <div :class=\"$style.component\">\n <div v-if=\"settings.title && !settings.compact\" :class=\"$style.title\">{{ settings.title }}</div>\n <div ref=\"chart\" />\n </div>\n</template>\n\n<style module>\n.component {\n display: flex;\n flex-direction: column;\n gap: 24px;\n svg {\n font-family: var(--font-family-base);\n }\n}\n\n.title {\n font-size: 20px;\n font-weight: 500;\n line-height: 24px; /* 120% */\n letter-spacing: -0.2px;\n}\n\n:global(.svg-tooltip) {\n font-family: var(--font-family-base);\n background: rgba(69, 77, 93, 0.9);\n border-radius: 0.1rem;\n color: #fff;\n display: block;\n font-size: 14px;\n max-width: 320px;\n padding: 0.2rem 0.4rem;\n position: absolute;\n text-overflow: ellipsis;\n white-space: pre;\n z-index: 300;\n visibility: hidden;\n}\n</style>\n"],"mappings":";;;;;;;EAKA,IAAM,IAAQ,GAIR,IAAQ,GAAkB,EAE1B,IAAU,QAA6B;GAC3C,IAAM,EACJ,eACA,eACA,cACA,YACA,gBAAa,KACb,iBAAc,QACZ,EAAM,UAEJ,IAAS,IACX;IAAE,KAAK;IAAG,OAAO;IAAG,QAAQ;IAAG,MAAM;IAAE,GACvC;IAAE,KAAK;IAAG,OAAO;IAAI,QAAQ;IAAI,MAAM;IAAI;AAI/C,UAAO;IACL,OAJY,IAAa,EAAO,OAAO,EAAO;IAK9C,QAJa,IAAc,EAAO,MAAM,EAAO;IAK/C;IACA;IACA,OAAO,WAAW,EAAM,WAAW,EAAM,SAAS,QAAQ;IAC9C;IACA;IACD;IACZ;IACD,EAEI,UAAwB;GAC5B,IAAM,IAAW,EAAM;AAEvB,OAAI,EAAS,SAAS,YAAY;AAChC,MAAwB,EAAM,OAAQ,EAAQ,OAAO,EAAS,KAAK;AACnE;;AAGF,GAAI,EAAS,MACX,EAAmB,EAAM,OAAQ,EAAQ,OAAO,EAAS,QAAQ,GAEjE,EAAsB,EAAM,OAAQ,EAAQ,OAAO,EAAS,QAAQ;;SAIxE,EAAM,GAAO,EAAgB,EAE7B,EAAU,EAAgB,kBAIxB,EAGM,OAAA,EAHA,OAAK,EAAEA,EAAAA,OAAO,UAAS,EAAA,EAAA,CAChB,EAAA,SAAS,SAAK,CAAK,EAAA,SAAS,WAAA,GAAA,EAAvC,EAAgG,OAAA;;GAA/C,OAAK,EAAEA,EAAAA,OAAO,MAAK;OAAK,EAAA,SAAS,MAAK,EAAA,EAAA,IAAA,EAAA,IAAA,GAAA,EACvF,EAAmB,OAAA;YAAV;GAAJ,KAAI"}
@@ -1,5 +1,6 @@
1
1
  import { selectAll as e } from "d3-selection";
2
2
  import { axisBottom as t, axisLeft as n } from "d3-axis";
3
+ //#region src/components/PlChartHistogram/createGridlines.ts
3
4
  function r(r, i, a, o) {
4
5
  let { width: s, height: c } = i;
5
6
  function l() {
@@ -10,6 +11,7 @@ function r(r, i, a, o) {
10
11
  }
11
12
  r.append("g").attr("class", "grid").attr("font-family", "'Manrope', sans-serif").call(l().tickSize(-s).tickFormat(() => "")), r.append("g").attr("class", "grid").attr("font-family", "'Manrope', sans-serif").attr("transform", `translate(0,${c})`).call(u().tickSize(-c).tickFormat(() => "")), e(".grid line").style("stroke", "#E1E3EB").style("opacity", .7);
12
13
  }
14
+ //#endregion
13
15
  export { r as createGridlines };
14
16
 
15
17
  //# sourceMappingURL=createGridlines.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"createGridlines.js","names":[],"sources":["../../../src/components/PlChartHistogram/createGridlines.ts"],"sourcesContent":["import type { ChartOptions, Scales } from \"./types\";\nimport type { Selection } from \"d3-selection\";\nimport type { Axis } from \"d3-axis\";\nimport type { NumberValue } from \"d3-scale\";\nimport { selectAll } from \"d3-selection\";\nimport { axisBottom, axisLeft } from \"d3-axis\";\n\nexport function createGridlines(\n svg: Selection<SVGGElement, unknown, null, undefined>,\n options: ChartOptions,\n scales: Scales,\n xTicks: (d: Axis<NumberValue>) => Axis<NumberValue>,\n) {\n const { width, height } = options;\n\n function makeYGridlines() {\n return axisLeft(scales.y) // Use the y-scale for horizontal gridlines\n .ticks(6); // Adjust the number of gridlines\n }\n\n function makeXGridlines() {\n return xTicks(axisBottom(scales.x));\n }\n // Append horizontal gridlines\n svg\n .append(\"g\")\n .attr(\"class\", \"grid\") // Add a class for styling\n .attr(\"font-family\", \"'Manrope', sans-serif\") // Doesn't work\n .call(\n makeYGridlines()\n .tickSize(-width) // Extend gridlines across the chart width\n .tickFormat(() => \"\"),\n ); // Remove tick labels\n\n // Append vertical gridlines\n svg\n .append(\"g\")\n .attr(\"class\", \"grid\") // Add a class for styling\n .attr(\"font-family\", \"'Manrope', sans-serif\")\n .attr(\"transform\", `translate(0,${height})`) // Position at the bottom of the chart\n .call(\n makeXGridlines()\n .tickSize(-height) // Extend gridlines across the chart height\n .tickFormat(() => \"\"),\n ); // Remove tick labels\n\n // Style the gridlines using CSS (or inline styles)\n selectAll(\".grid line\")\n .style(\"stroke\", \"#E1E3EB\") // Light gray gridlines\n // .style('stroke-dasharray', '2,2') // Dashed gridlines\n .style(\"opacity\", 0.7); // Slightly transparent\n}\n"],"mappings":";;AAOA,SAAgB,EACd,GACA,GACA,GACA,GACA;CACA,IAAM,EAAE,UAAO,cAAW;CAE1B,SAAS,IAAiB;AACxB,SAAO,EAAS,EAAO,EAAE,CACtB,MAAM,EAAE;;CAGb,SAAS,IAAiB;AACxB,SAAO,EAAO,EAAW,EAAO,EAAE,CAAC;;AA0BrC,CAvBA,EACG,OAAO,IAAI,CACX,KAAK,SAAS,OAAO,CACrB,KAAK,eAAe,wBAAwB,CAC5C,KACC,GAAgB,CACb,SAAS,CAAC,EAAM,CAChB,iBAAiB,GAAG,CACxB,EAGH,EACG,OAAO,IAAI,CACX,KAAK,SAAS,OAAO,CACrB,KAAK,eAAe,wBAAwB,CAC5C,KAAK,aAAa,eAAe,EAAO,GAAG,CAC3C,KACC,GAAgB,CACb,SAAS,CAAC,EAAO,CACjB,iBAAiB,GAAG,CACxB,EAGH,EAAU,aAAa,CACpB,MAAM,UAAU,UAAU,CAE1B,MAAM,WAAW,GAAI"}
1
+ {"version":3,"file":"createGridlines.js","names":[],"sources":["../../../src/components/PlChartHistogram/createGridlines.ts"],"sourcesContent":["import type { ChartOptions, Scales } from \"./types\";\nimport type { Selection } from \"d3-selection\";\nimport type { Axis } from \"d3-axis\";\nimport type { NumberValue } from \"d3-scale\";\nimport { selectAll } from \"d3-selection\";\nimport { axisBottom, axisLeft } from \"d3-axis\";\n\nexport function createGridlines(\n svg: Selection<SVGGElement, unknown, null, undefined>,\n options: ChartOptions,\n scales: Scales,\n xTicks: (d: Axis<NumberValue>) => Axis<NumberValue>,\n) {\n const { width, height } = options;\n\n function makeYGridlines() {\n return axisLeft(scales.y) // Use the y-scale for horizontal gridlines\n .ticks(6); // Adjust the number of gridlines\n }\n\n function makeXGridlines() {\n return xTicks(axisBottom(scales.x));\n }\n // Append horizontal gridlines\n svg\n .append(\"g\")\n .attr(\"class\", \"grid\") // Add a class for styling\n .attr(\"font-family\", \"'Manrope', sans-serif\") // Doesn't work\n .call(\n makeYGridlines()\n .tickSize(-width) // Extend gridlines across the chart width\n .tickFormat(() => \"\"),\n ); // Remove tick labels\n\n // Append vertical gridlines\n svg\n .append(\"g\")\n .attr(\"class\", \"grid\") // Add a class for styling\n .attr(\"font-family\", \"'Manrope', sans-serif\")\n .attr(\"transform\", `translate(0,${height})`) // Position at the bottom of the chart\n .call(\n makeXGridlines()\n .tickSize(-height) // Extend gridlines across the chart height\n .tickFormat(() => \"\"),\n ); // Remove tick labels\n\n // Style the gridlines using CSS (or inline styles)\n selectAll(\".grid line\")\n .style(\"stroke\", \"#E1E3EB\") // Light gray gridlines\n // .style('stroke-dasharray', '2,2') // Dashed gridlines\n .style(\"opacity\", 0.7); // Slightly transparent\n}\n"],"mappings":";;;AAOA,SAAgB,EACd,GACA,GACA,GACA,GACA;CACA,IAAM,EAAE,UAAO,cAAW;CAE1B,SAAS,IAAiB;AACxB,SAAO,EAAS,EAAO,EAAE,CACtB,MAAM,EAAE;;CAGb,SAAS,IAAiB;AACxB,SAAO,EAAO,EAAW,EAAO,EAAE,CAAC;;AA0BrC,CAvBA,EACG,OAAO,IAAI,CACX,KAAK,SAAS,OAAO,CACrB,KAAK,eAAe,wBAAwB,CAC5C,KACC,GAAgB,CACb,SAAS,CAAC,EAAM,CAChB,iBAAiB,GAAG,CACxB,EAGH,EACG,OAAO,IAAI,CACX,KAAK,SAAS,OAAO,CACrB,KAAK,eAAe,wBAAwB,CAC5C,KAAK,aAAa,eAAe,EAAO,GAAG,CAC3C,KACC,GAAgB,CACb,SAAS,CAAC,EAAO,CACjB,iBAAiB,GAAG,CACxB,EAGH,EAAU,aAAa,CACpB,MAAM,UAAU,UAAU,CAE1B,MAAM,WAAW,GAAI"}
@@ -1,7 +1,9 @@
1
+ //#region src/components/PlChartHistogram/createLabels.ts
1
2
  function e(e, t) {
2
3
  let { height: n, width: r, margin: i, xAxisLabel: a, yAxisLabel: o, compact: s } = t;
3
4
  s || (e.append("text").attr("class", "x-axis-label").attr("font-weight", 500).attr("text-anchor", "middle").attr("x", r / 2).attr("y", n + i.bottom - 5).text(a ?? "Value Range"), e.append("text").attr("class", "y-axis-label").attr("font-weight", 500).attr("text-anchor", "middle").attr("x", -n / 2).attr("y", -i.left + 15).attr("transform", "rotate(-90)").text(o ?? "Frequency"));
4
5
  }
6
+ //#endregion
5
7
  export { e as createLabels };
6
8
 
7
9
  //# sourceMappingURL=createLabels.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"createLabels.js","names":[],"sources":["../../../src/components/PlChartHistogram/createLabels.ts"],"sourcesContent":["import type { Selection } from \"d3-selection\";\nimport type { ChartOptions } from \"./types\";\n\nexport function createLabels(\n svg: Selection<SVGGElement, unknown, null, undefined>,\n options: ChartOptions,\n) {\n const { height, width, margin, xAxisLabel, yAxisLabel, compact } = options;\n\n if (compact) {\n return;\n }\n\n // X-axis label\n svg\n .append(\"text\")\n .attr(\"class\", \"x-axis-label\")\n .attr(\"font-weight\", 500)\n .attr(\"text-anchor\", \"middle\") // Center the text\n .attr(\"x\", width / 2) // Center horizontally\n .attr(\"y\", height + margin.bottom - 5) // Position below the X-axis\n .text(xAxisLabel ?? \"Value Range\"); // Set your custom label text\n\n // Y-axis label\n svg\n .append(\"text\")\n .attr(\"class\", \"y-axis-label\")\n .attr(\"font-weight\", 500)\n .attr(\"text-anchor\", \"middle\") // Center the text\n .attr(\"x\", -height / 2) // Center vertically (rotated axis)\n .attr(\"y\", -margin.left + 15) // Position to the left of the Y-axis\n .attr(\"transform\", \"rotate(-90)\") // Rotate text 90 degrees counter-clockwise\n .text(yAxisLabel ?? \"Frequency\"); // Set your custom label text\n}\n"],"mappings":"AAGA,SAAgB,EACd,GACA,GACA;CACA,IAAM,EAAE,WAAQ,UAAO,WAAQ,eAAY,eAAY,eAAY;AAE/D,OAKJ,EACG,OAAO,OAAO,CACd,KAAK,SAAS,eAAe,CAC7B,KAAK,eAAe,IAAI,CACxB,KAAK,eAAe,SAAS,CAC7B,KAAK,KAAK,IAAQ,EAAE,CACpB,KAAK,KAAK,IAAS,EAAO,SAAS,EAAE,CACrC,KAAK,KAAc,cAAc,EAGpC,EACG,OAAO,OAAO,CACd,KAAK,SAAS,eAAe,CAC7B,KAAK,eAAe,IAAI,CACxB,KAAK,eAAe,SAAS,CAC7B,KAAK,KAAK,CAAC,IAAS,EAAE,CACtB,KAAK,KAAK,CAAC,EAAO,OAAO,GAAG,CAC5B,KAAK,aAAa,cAAc,CAChC,KAAK,KAAc,YAAY"}
1
+ {"version":3,"file":"createLabels.js","names":[],"sources":["../../../src/components/PlChartHistogram/createLabels.ts"],"sourcesContent":["import type { Selection } from \"d3-selection\";\nimport type { ChartOptions } from \"./types\";\n\nexport function createLabels(\n svg: Selection<SVGGElement, unknown, null, undefined>,\n options: ChartOptions,\n) {\n const { height, width, margin, xAxisLabel, yAxisLabel, compact } = options;\n\n if (compact) {\n return;\n }\n\n // X-axis label\n svg\n .append(\"text\")\n .attr(\"class\", \"x-axis-label\")\n .attr(\"font-weight\", 500)\n .attr(\"text-anchor\", \"middle\") // Center the text\n .attr(\"x\", width / 2) // Center horizontally\n .attr(\"y\", height + margin.bottom - 5) // Position below the X-axis\n .text(xAxisLabel ?? \"Value Range\"); // Set your custom label text\n\n // Y-axis label\n svg\n .append(\"text\")\n .attr(\"class\", \"y-axis-label\")\n .attr(\"font-weight\", 500)\n .attr(\"text-anchor\", \"middle\") // Center the text\n .attr(\"x\", -height / 2) // Center vertically (rotated axis)\n .attr(\"y\", -margin.left + 15) // Position to the left of the Y-axis\n .attr(\"transform\", \"rotate(-90)\") // Rotate text 90 degrees counter-clockwise\n .text(yAxisLabel ?? \"Frequency\"); // Set your custom label text\n}\n"],"mappings":";AAGA,SAAgB,EACd,GACA,GACA;CACA,IAAM,EAAE,WAAQ,UAAO,WAAQ,eAAY,eAAY,eAAY;AAE/D,OAKJ,EACG,OAAO,OAAO,CACd,KAAK,SAAS,eAAe,CAC7B,KAAK,eAAe,IAAI,CACxB,KAAK,eAAe,SAAS,CAC7B,KAAK,KAAK,IAAQ,EAAE,CACpB,KAAK,KAAK,IAAS,EAAO,SAAS,EAAE,CACrC,KAAK,KAAc,cAAc,EAGpC,EACG,OAAO,OAAO,CACd,KAAK,SAAS,eAAe,CAC7B,KAAK,eAAe,IAAI,CACxB,KAAK,eAAe,SAAS,CAC7B,KAAK,KAAK,CAAC,IAAS,EAAE,CACtB,KAAK,KAAK,CAAC,EAAO,OAAO,GAAG,CAC5B,KAAK,aAAa,cAAc,CAChC,KAAK,KAAc,YAAY"}
@@ -1,8 +1,10 @@
1
1
  import { select as e } from "d3-selection";
2
+ //#region src/components/PlChartHistogram/createSvgContainer.ts
2
3
  function t(t, n) {
3
4
  let { width: r, height: i, margin: a, compact: o } = n;
4
5
  return t.replaceChildren(), o && (t.style.height = i + "px", t.style.lineHeight = i + "px"), e(t).append("svg").attr("width", r + a.left + a.right).attr("height", i + a.top + a.bottom).append("g").attr("transform", `translate(${a.left},${a.top})`);
5
6
  }
7
+ //#endregion
6
8
  export { t as createSvgContainer };
7
9
 
8
10
  //# sourceMappingURL=createSvgContainer.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"createSvgContainer.js","names":[],"sources":["../../../src/components/PlChartHistogram/createSvgContainer.ts"],"sourcesContent":["import type { ChartOptions } from \"./types\";\nimport { select } from \"d3-selection\";\n\nexport function createSvgContainer(el: HTMLElement, options: ChartOptions) {\n const { width, height, margin, compact } = options;\n\n el.replaceChildren();\n\n if (compact) {\n el.style.height = height + \"px\";\n el.style.lineHeight = height + \"px\";\n }\n\n const svg = select(el) // Append the SVG element to the body\n .append(\"svg\")\n .attr(\"width\", width + margin.left + margin.right) // Set the total width\n .attr(\"height\", height + margin.top + margin.bottom) // Set the total height\n .append(\"g\") // Append a group to handle margins\n .attr(\"transform\", `translate(${margin.left},${margin.top})`);\n\n return svg;\n}\n"],"mappings":";AAGA,SAAgB,EAAmB,GAAiB,GAAuB;CACzE,IAAM,EAAE,UAAO,WAAQ,WAAQ,eAAY;AAgB3C,QAdA,EAAG,iBAAiB,EAEhB,MACF,EAAG,MAAM,SAAS,IAAS,MAC3B,EAAG,MAAM,aAAa,IAAS,OAGrB,EAAO,EAAG,CACnB,OAAO,MAAM,CACb,KAAK,SAAS,IAAQ,EAAO,OAAO,EAAO,MAAM,CACjD,KAAK,UAAU,IAAS,EAAO,MAAM,EAAO,OAAO,CACnD,OAAO,IAAI,CACX,KAAK,aAAa,aAAa,EAAO,KAAK,GAAG,EAAO,IAAI,GAAG"}
1
+ {"version":3,"file":"createSvgContainer.js","names":[],"sources":["../../../src/components/PlChartHistogram/createSvgContainer.ts"],"sourcesContent":["import type { ChartOptions } from \"./types\";\nimport { select } from \"d3-selection\";\n\nexport function createSvgContainer(el: HTMLElement, options: ChartOptions) {\n const { width, height, margin, compact } = options;\n\n el.replaceChildren();\n\n if (compact) {\n el.style.height = height + \"px\";\n el.style.lineHeight = height + \"px\";\n }\n\n const svg = select(el) // Append the SVG element to the body\n .append(\"svg\")\n .attr(\"width\", width + margin.left + margin.right) // Set the total width\n .attr(\"height\", height + margin.top + margin.bottom) // Set the total height\n .append(\"g\") // Append a group to handle margins\n .attr(\"transform\", `translate(${margin.left},${margin.top})`);\n\n return svg;\n}\n"],"mappings":";;AAGA,SAAgB,EAAmB,GAAiB,GAAuB;CACzE,IAAM,EAAE,UAAO,WAAQ,WAAQ,eAAY;AAgB3C,QAdA,EAAG,iBAAiB,EAEhB,MACF,EAAG,MAAM,SAAS,IAAS,MAC3B,EAAG,MAAM,aAAa,IAAS,OAGrB,EAAO,EAAG,CACnB,OAAO,MAAM,CACb,KAAK,SAAS,IAAQ,EAAO,OAAO,EAAO,MAAM,CACjD,KAAK,UAAU,IAAS,EAAO,MAAM,EAAO,OAAO,CACnD,OAAO,IAAI,CACX,KAAK,aAAa,aAAa,EAAO,KAAK,GAAG,EAAO,IAAI,GAAG"}
@@ -1,4 +1,5 @@
1
1
  import { select as e } from "d3-selection";
2
+ //#region src/components/PlChartHistogram/drawBins.ts
2
3
  function t(t, n, r, i) {
3
4
  let { height: a } = r, { x: o, y: s } = i, c = e("body").append("div").attr("class", "svg-tooltip").style("position", "absolute").style("visibility", "hidden");
4
5
  t.selectAll("rect").data(n).enter().append("rect").attr("x", (e) => o(e.x0)).attr("y", (e) => s(e.length)).attr("width", (e) => o(e.x1) - o(e.x0)).attr("height", (e) => a - s(e.length)).style("fill", "#929BAD").attr("stroke", "#fff").attr("stroke-opacity", .2).attr("stroke-width", .5).on("mouseover", function(e, t) {
@@ -9,6 +10,7 @@ function t(t, n, r, i) {
9
10
  c.style("visibility", "hidden");
10
11
  }).append("title").text((e) => `[${e.x0}, ${e.x1}]\n` + e.length + "\n");
11
12
  }
13
+ //#endregion
12
14
  export { t as drawBins };
13
15
 
14
16
  //# sourceMappingURL=drawBins.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"drawBins.js","names":[],"sources":["../../../src/components/PlChartHistogram/drawBins.ts"],"sourcesContent":["import type { BinLike, ChartOptions, Scales, SVG } from \"./types\";\nimport { select } from \"d3-selection\";\n\nexport function drawBins(svg: SVG, bins: BinLike[], dimension: ChartOptions, scales: Scales) {\n const { height } = dimension;\n\n const { x, y } = scales;\n\n const tooltip = select(\"body\")\n .append(\"div\")\n .attr(\"class\", \"svg-tooltip\")\n .style(\"position\", \"absolute\")\n .style(\"visibility\", \"hidden\");\n\n // Three function that change the tooltip when user hover / move / leave a cell\n const mouseover = function (_event: MouseEvent, d: BinLike) {\n tooltip.style(\"visibility\", \"visible\").text(`count: ${d.length}\\nx0: ${d.x0}\\nx1: ${d.x1}`);\n };\n\n const mousemove = function (event: MouseEvent) {\n tooltip.style(\"top\", event.pageY - 10 + \"px\").style(\"left\", event.pageX + 10 + \"px\");\n };\n\n const mouseout = function () {\n tooltip.style(\"visibility\", \"hidden\");\n };\n\n // Add rectangles for the histogram bars\n svg\n .selectAll(\"rect\")\n .data(bins)\n .enter()\n .append(\"rect\")\n .attr(\"x\", (d) => x(d.x0!)) // Position the bar based on the bin start\n .attr(\"y\", (d) => y(d.length)) // Height based on bin count\n .attr(\"width\", (d) => x(d.x1!) - x(d.x0!)) // Bar width based on logarithmic intervals\n .attr(\"height\", (d) => height - y(d.length)) // Invert height to fit SVG coordinate system\n .style(\"fill\", \"#929BAD\")\n .attr(\"stroke\", \"#fff\") // Border color\n .attr(\"stroke-opacity\", 0.2)\n .attr(\"stroke-width\", 0.5)\n .on(\"mouseover\", mouseover)\n .on(\"mousemove\", mousemove)\n .on(\"mouseout\", mouseout)\n .append(\"title\")\n .text((d) => `[${d.x0}, ${d.x1}]\\n` + d.length + \"\\n\"); // Set bar color\n}\n"],"mappings":";AAGA,SAAgB,EAAS,GAAU,GAAiB,GAAyB,GAAgB;CAC3F,IAAM,EAAE,cAAW,GAEb,EAAE,MAAG,SAAM,GAEX,IAAU,EAAO,OAAO,CAC3B,OAAO,MAAM,CACb,KAAK,SAAS,cAAc,CAC5B,MAAM,YAAY,WAAW,CAC7B,MAAM,cAAc,SAAS;AAgBhC,GACG,UAAU,OAAO,CACjB,KAAK,EAAK,CACV,OAAO,CACP,OAAO,OAAO,CACd,KAAK,MAAM,MAAM,EAAE,EAAE,GAAI,CAAC,CAC1B,KAAK,MAAM,MAAM,EAAE,EAAE,OAAO,CAAC,CAC7B,KAAK,UAAU,MAAM,EAAE,EAAE,GAAI,GAAG,EAAE,EAAE,GAAI,CAAC,CACzC,KAAK,WAAW,MAAM,IAAS,EAAE,EAAE,OAAO,CAAC,CAC3C,MAAM,QAAQ,UAAU,CACxB,KAAK,UAAU,OAAO,CACtB,KAAK,kBAAkB,GAAI,CAC3B,KAAK,gBAAgB,GAAI,CACzB,GAAG,aA1BY,SAAU,GAAoB,GAAY;AAC1D,IAAQ,MAAM,cAAc,UAAU,CAAC,KAAK,UAAU,EAAE,OAAO,QAAQ,EAAE,GAAG,QAAQ,EAAE,KAAK;GAyBhE,CAC1B,GAAG,aAvBY,SAAU,GAAmB;AAC7C,IAAQ,MAAM,OAAO,EAAM,QAAQ,KAAK,KAAK,CAAC,MAAM,QAAQ,EAAM,QAAQ,KAAK,KAAK;GAsBzD,CAC1B,GAAG,YApBW,WAAY;AAC3B,IAAQ,MAAM,cAAc,SAAS;GAmBZ,CACxB,OAAO,QAAQ,CACf,MAAM,MAAM,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,OAAO,EAAE,SAAS,KAAK"}
1
+ {"version":3,"file":"drawBins.js","names":[],"sources":["../../../src/components/PlChartHistogram/drawBins.ts"],"sourcesContent":["import type { BinLike, ChartOptions, Scales, SVG } from \"./types\";\nimport { select } from \"d3-selection\";\n\nexport function drawBins(svg: SVG, bins: BinLike[], dimension: ChartOptions, scales: Scales) {\n const { height } = dimension;\n\n const { x, y } = scales;\n\n const tooltip = select(\"body\")\n .append(\"div\")\n .attr(\"class\", \"svg-tooltip\")\n .style(\"position\", \"absolute\")\n .style(\"visibility\", \"hidden\");\n\n // Three function that change the tooltip when user hover / move / leave a cell\n const mouseover = function (_event: MouseEvent, d: BinLike) {\n tooltip.style(\"visibility\", \"visible\").text(`count: ${d.length}\\nx0: ${d.x0}\\nx1: ${d.x1}`);\n };\n\n const mousemove = function (event: MouseEvent) {\n tooltip.style(\"top\", event.pageY - 10 + \"px\").style(\"left\", event.pageX + 10 + \"px\");\n };\n\n const mouseout = function () {\n tooltip.style(\"visibility\", \"hidden\");\n };\n\n // Add rectangles for the histogram bars\n svg\n .selectAll(\"rect\")\n .data(bins)\n .enter()\n .append(\"rect\")\n .attr(\"x\", (d) => x(d.x0!)) // Position the bar based on the bin start\n .attr(\"y\", (d) => y(d.length)) // Height based on bin count\n .attr(\"width\", (d) => x(d.x1!) - x(d.x0!)) // Bar width based on logarithmic intervals\n .attr(\"height\", (d) => height - y(d.length)) // Invert height to fit SVG coordinate system\n .style(\"fill\", \"#929BAD\")\n .attr(\"stroke\", \"#fff\") // Border color\n .attr(\"stroke-opacity\", 0.2)\n .attr(\"stroke-width\", 0.5)\n .on(\"mouseover\", mouseover)\n .on(\"mousemove\", mousemove)\n .on(\"mouseout\", mouseout)\n .append(\"title\")\n .text((d) => `[${d.x0}, ${d.x1}]\\n` + d.length + \"\\n\"); // Set bar color\n}\n"],"mappings":";;AAGA,SAAgB,EAAS,GAAU,GAAiB,GAAyB,GAAgB;CAC3F,IAAM,EAAE,cAAW,GAEb,EAAE,MAAG,SAAM,GAEX,IAAU,EAAO,OAAO,CAC3B,OAAO,MAAM,CACb,KAAK,SAAS,cAAc,CAC5B,MAAM,YAAY,WAAW,CAC7B,MAAM,cAAc,SAAS;AAgBhC,GACG,UAAU,OAAO,CACjB,KAAK,EAAK,CACV,OAAO,CACP,OAAO,OAAO,CACd,KAAK,MAAM,MAAM,EAAE,EAAE,GAAI,CAAC,CAC1B,KAAK,MAAM,MAAM,EAAE,EAAE,OAAO,CAAC,CAC7B,KAAK,UAAU,MAAM,EAAE,EAAE,GAAI,GAAG,EAAE,EAAE,GAAI,CAAC,CACzC,KAAK,WAAW,MAAM,IAAS,EAAE,EAAE,OAAO,CAAC,CAC3C,MAAM,QAAQ,UAAU,CACxB,KAAK,UAAU,OAAO,CACtB,KAAK,kBAAkB,GAAI,CAC3B,KAAK,gBAAgB,GAAI,CACzB,GAAG,aA1BY,SAAU,GAAoB,GAAY;AAC1D,IAAQ,MAAM,cAAc,UAAU,CAAC,KAAK,UAAU,EAAE,OAAO,QAAQ,EAAE,GAAG,QAAQ,EAAE,KAAK;GAyBhE,CAC1B,GAAG,aAvBY,SAAU,GAAmB;AAC7C,IAAQ,MAAM,OAAO,EAAM,QAAQ,KAAK,KAAK,CAAC,MAAM,QAAQ,EAAM,QAAQ,KAAK,KAAK;GAsBzD,CAC1B,GAAG,YApBW,WAAY;AAC3B,IAAQ,MAAM,cAAc,SAAS;GAmBZ,CACxB,OAAO,QAAQ,CACf,MAAM,MAAM,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,OAAO,EAAE,SAAS,KAAK"}
@@ -1,7 +1,9 @@
1
+ //#region src/components/PlChartHistogram/drawThreshold.ts
1
2
  function e(e, t, n) {
2
3
  let { threshold: r } = n;
3
4
  r && e.append("line").attr("x1", t.x(r)).attr("x2", t.x(r)).attr("y1", 0).attr("y2", n.height).style("stroke", "#F05670").style("stroke-width", "1").style("stroke-dasharray", "7.4 3.2");
4
5
  }
6
+ //#endregion
5
7
  export { e as drawThreshold };
6
8
 
7
9
  //# sourceMappingURL=drawThreshold.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"drawThreshold.js","names":[],"sources":["../../../src/components/PlChartHistogram/drawThreshold.ts"],"sourcesContent":["import type { ChartOptions, Scales, SVG } from \"./types\";\n\nexport function drawThreshold(svg: SVG, scales: Scales, options: ChartOptions) {\n const { threshold } = options;\n\n if (!threshold) {\n return;\n }\n\n svg\n .append(\"line\")\n .attr(\"x1\", scales.x(threshold))\n .attr(\"x2\", scales.x(threshold))\n .attr(\"y1\", 0)\n .attr(\"y2\", options.height)\n .style(\"stroke\", \"#F05670\")\n .style(\"stroke-width\", \"1\")\n .style(\"stroke-dasharray\", \"7.4 3.2\");\n}\n"],"mappings":"AAEA,SAAgB,EAAc,GAAU,GAAgB,GAAuB;CAC7E,IAAM,EAAE,iBAAc;AAEjB,MAIL,EACG,OAAO,OAAO,CACd,KAAK,MAAM,EAAO,EAAE,EAAU,CAAC,CAC/B,KAAK,MAAM,EAAO,EAAE,EAAU,CAAC,CAC/B,KAAK,MAAM,EAAE,CACb,KAAK,MAAM,EAAQ,OAAO,CAC1B,MAAM,UAAU,UAAU,CAC1B,MAAM,gBAAgB,IAAI,CAC1B,MAAM,oBAAoB,UAAU"}
1
+ {"version":3,"file":"drawThreshold.js","names":[],"sources":["../../../src/components/PlChartHistogram/drawThreshold.ts"],"sourcesContent":["import type { ChartOptions, Scales, SVG } from \"./types\";\n\nexport function drawThreshold(svg: SVG, scales: Scales, options: ChartOptions) {\n const { threshold } = options;\n\n if (!threshold) {\n return;\n }\n\n svg\n .append(\"line\")\n .attr(\"x1\", scales.x(threshold))\n .attr(\"x2\", scales.x(threshold))\n .attr(\"y1\", 0)\n .attr(\"y2\", options.height)\n .style(\"stroke\", \"#F05670\")\n .style(\"stroke-width\", \"1\")\n .style(\"stroke-dasharray\", \"7.4 3.2\");\n}\n"],"mappings":";AAEA,SAAgB,EAAc,GAAU,GAAgB,GAAuB;CAC7E,IAAM,EAAE,iBAAc;AAEjB,MAIL,EACG,OAAO,OAAO,CACd,KAAK,MAAM,EAAO,EAAE,EAAU,CAAC,CAC/B,KAAK,MAAM,EAAO,EAAE,EAAU,CAAC,CAC/B,KAAK,MAAM,EAAE,CACb,KAAK,MAAM,EAAQ,OAAO,CAC1B,MAAM,UAAU,UAAU,CAC1B,MAAM,gBAAgB,IAAI,CAC1B,MAAM,oBAAoB,UAAU"}