@milaboratories/uikit 2.11.6 → 2.11.7

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 (1115) hide show
  1. package/.turbo/turbo-build.log +636 -636
  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 +8 -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.vue2.js +2 -0
  780. package/dist/components/PlDialogModal/PlDialogModal.vue2.js.map +1 -1
  781. package/dist/components/PlDropdown/OptionList.js +2 -0
  782. package/dist/components/PlDropdown/OptionList.vue2.js +2 -0
  783. package/dist/components/PlDropdown/OptionList.vue2.js.map +1 -1
  784. package/dist/components/PlDropdown/PlDropdown.js +2 -0
  785. package/dist/components/PlDropdown/PlDropdown.vue2.js +2 -0
  786. package/dist/components/PlDropdown/PlDropdown.vue2.js.map +1 -1
  787. package/dist/components/PlDropdown/useGroupBy.js +2 -0
  788. package/dist/components/PlDropdown/useGroupBy.js.map +1 -1
  789. package/dist/components/PlDropdownLegacy/PlDropdownLegacy.js +2 -0
  790. package/dist/components/PlDropdownLegacy/PlDropdownLegacy.vue2.js +2 -0
  791. package/dist/components/PlDropdownLegacy/PlDropdownLegacy.vue2.js.map +1 -1
  792. package/dist/components/PlDropdownLine/PlDropdownLine.js +2 -0
  793. package/dist/components/PlDropdownLine/PlDropdownLine.vue2.js +2 -0
  794. package/dist/components/PlDropdownLine/PlDropdownLine.vue2.js.map +1 -1
  795. package/dist/components/PlDropdownLine/ResizableInput.js +2 -0
  796. package/dist/components/PlDropdownLine/ResizableInput.vue2.js +2 -0
  797. package/dist/components/PlDropdownLine/ResizableInput.vue2.js.map +1 -1
  798. package/dist/components/PlDropdownMulti/PlDropdownMulti.js +2 -0
  799. package/dist/components/PlDropdownMulti/PlDropdownMulti.vue2.js +2 -0
  800. package/dist/components/PlDropdownMulti/PlDropdownMulti.vue2.js.map +1 -1
  801. package/dist/components/PlDropdownMultiRef/PlDropdownMultiRef.js +2 -0
  802. package/dist/components/PlDropdownMultiRef/PlDropdownMultiRef.vue2.js +2 -0
  803. package/dist/components/PlDropdownMultiRef/PlDropdownMultiRef.vue2.js.map +1 -1
  804. package/dist/components/PlDropdownRef/PlDropdownRef.js +2 -0
  805. package/dist/components/PlDropdownRef/PlDropdownRef.vue2.js +1 -0
  806. package/dist/components/PlEditableTitle/PlEditableTitle.js +2 -0
  807. package/dist/components/PlEditableTitle/PlEditableTitle.vue2.js +2 -0
  808. package/dist/components/PlEditableTitle/PlEditableTitle.vue2.js.map +1 -1
  809. package/dist/components/PlEditableTitle/pl-editable-title.module.js +1 -0
  810. package/dist/components/PlElementList/PlElementList.js +1 -0
  811. package/dist/components/PlElementList/PlElementList.style.js +1 -0
  812. package/dist/components/PlElementList/PlElementList.vue2.js +2 -0
  813. package/dist/components/PlElementList/PlElementList.vue2.js.map +1 -1
  814. package/dist/components/PlElementList/PlElementListItem.js +1 -0
  815. package/dist/components/PlElementList/PlElementListItem.style.js +1 -0
  816. package/dist/components/PlElementList/PlElementListItem.vue2.js +2 -0
  817. package/dist/components/PlElementList/PlElementListItem.vue2.js.map +1 -1
  818. package/dist/components/PlElementList/utils.js +3 -1
  819. package/dist/components/PlElementList/utils.js.map +1 -1
  820. package/dist/components/PlErrorAlert/PlErrorAlert.js +1 -0
  821. package/dist/components/PlErrorAlert/PlErrorAlert.style.js +1 -0
  822. package/dist/components/PlErrorAlert/PlErrorAlert.vue2.js +1 -0
  823. package/dist/components/PlErrorBoundary/PlErrorBoundary.js +2 -0
  824. package/dist/components/PlErrorBoundary/PlErrorBoundary.vue2.js +2 -0
  825. package/dist/components/PlErrorBoundary/PlErrorBoundary.vue2.js.map +1 -1
  826. package/dist/components/PlFileDialog/Local.js +2 -0
  827. package/dist/components/PlFileDialog/Local.vue2.js +2 -0
  828. package/dist/components/PlFileDialog/Local.vue2.js.map +1 -1
  829. package/dist/components/PlFileDialog/PlFileDialog.js +2 -0
  830. package/dist/components/PlFileDialog/PlFileDialog.vue2.js +2 -0
  831. package/dist/components/PlFileDialog/PlFileDialog.vue2.js.map +1 -1
  832. package/dist/components/PlFileDialog/Remote.js +2 -0
  833. package/dist/components/PlFileDialog/Remote.vue2.js +2 -0
  834. package/dist/components/PlFileDialog/Remote.vue2.js.map +1 -1
  835. package/dist/components/PlFileDialog/Shortcuts.js +1 -0
  836. package/dist/components/PlFileDialog/Shortcuts.style.js +1 -0
  837. package/dist/components/PlFileDialog/Shortcuts.vue2.js +2 -0
  838. package/dist/components/PlFileDialog/Shortcuts.vue2.js.map +1 -1
  839. package/dist/components/PlFileDialog/pl-file-dialog.module.js +1 -0
  840. package/dist/components/PlFileDialog/remote-helpers.js +4 -2
  841. package/dist/components/PlFileDialog/remote-helpers.js.map +1 -1
  842. package/dist/components/PlFileDialog/utils.js +2 -0
  843. package/dist/components/PlFileDialog/utils.js.map +1 -1
  844. package/dist/components/PlFileInput/PlFileInput.js +2 -0
  845. package/dist/components/PlFileInput/PlFileInput.vue2.js +2 -0
  846. package/dist/components/PlFileInput/PlFileInput.vue2.js.map +1 -1
  847. package/dist/components/PlIcon16/PlIcon16.js +1 -0
  848. package/dist/components/PlIcon16/PlIcon16.style.js +1 -0
  849. package/dist/components/PlIcon16/PlIcon16.vue2.js +2 -0
  850. package/dist/components/PlIcon16/PlIcon16.vue2.js.map +1 -1
  851. package/dist/components/PlIcon24/PlIcon24.js +1 -0
  852. package/dist/components/PlIcon24/PlIcon24.style.js +1 -0
  853. package/dist/components/PlIcon24/PlIcon24.vue2.js +2 -0
  854. package/dist/components/PlIcon24/PlIcon24.vue2.js.map +1 -1
  855. package/dist/components/PlLoaderCircular/PlLoaderCircular.js +2 -0
  856. package/dist/components/PlLoaderCircular/PlLoaderCircular.vue2.js +2 -0
  857. package/dist/components/PlLoaderCircular/PlLoaderCircular.vue2.js.map +1 -1
  858. package/dist/components/PlLoaderLogo.js +1 -0
  859. package/dist/components/PlLoaderLogo.style.js +1 -0
  860. package/dist/components/PlLoaderLogo.vue2.js +2 -0
  861. package/dist/components/PlLoaderLogo.vue2.js.map +1 -1
  862. package/dist/components/PlLogView/PlLogView.js +2 -0
  863. package/dist/components/PlLogView/PlLogView.vue2.js +2 -0
  864. package/dist/components/PlLogView/PlLogView.vue2.js.map +1 -1
  865. package/dist/components/PlLogView/useLogHandle.js +2 -0
  866. package/dist/components/PlLogView/useLogHandle.js.map +1 -1
  867. package/dist/components/PlNotificationAlert/PlNotificationAlert.js +2 -0
  868. package/dist/components/PlNotificationAlert/PlNotificationAlert.vue2.js +2 -0
  869. package/dist/components/PlNotificationAlert/PlNotificationAlert.vue2.js.map +1 -1
  870. package/dist/components/PlNumberField/PlNumberField.js +2 -0
  871. package/dist/components/PlNumberField/PlNumberField.js.map +1 -1
  872. package/dist/components/PlNumberField/PlNumberField.vue.d.ts +1 -1
  873. package/dist/components/PlNumberField/PlNumberField.vue.d.ts.map +1 -1
  874. package/dist/components/PlNumberField/PlNumberField.vue2.js +2 -0
  875. package/dist/components/PlNumberField/PlNumberField.vue2.js.map +1 -1
  876. package/dist/components/PlNumberField/parseNumber.js +2 -11
  877. package/dist/components/PlNumberField/parseNumber.js.map +1 -1
  878. package/dist/components/PlProgressBar/PlProgressBar.js +2 -0
  879. package/dist/components/PlProgressBar/PlProgressBar.vue2.js +2 -0
  880. package/dist/components/PlProgressBar/PlProgressBar.vue2.js.map +1 -1
  881. package/dist/components/PlProgressCell/PlProgressCell.js +2 -0
  882. package/dist/components/PlProgressCell/PlProgressCell.vue2.js +2 -0
  883. package/dist/components/PlProgressCell/PlProgressCell.vue2.js.map +1 -1
  884. package/dist/components/PlRadio/PlRadio.js +1 -0
  885. package/dist/components/PlRadio/PlRadio.style.js +1 -0
  886. package/dist/components/PlRadio/PlRadio.vue2.js +2 -0
  887. package/dist/components/PlRadio/PlRadio.vue2.js.map +1 -1
  888. package/dist/components/PlRadio/PlRadioGroup.js +1 -0
  889. package/dist/components/PlRadio/PlRadioGroup.style.js +1 -0
  890. package/dist/components/PlRadio/PlRadioGroup.vue2.js +2 -0
  891. package/dist/components/PlRadio/PlRadioGroup.vue2.js.map +1 -1
  892. package/dist/components/PlRadio/keys.js +3 -1
  893. package/dist/components/PlRadio/keys.js.map +1 -1
  894. package/dist/components/PlSearchField/PlSearchField.js +1 -0
  895. package/dist/components/PlSearchField/PlSearchField.style.js +1 -0
  896. package/dist/components/PlSearchField/PlSearchField.vue2.js +2 -0
  897. package/dist/components/PlSearchField/PlSearchField.vue2.js.map +1 -1
  898. package/dist/components/PlSectionSeparator/PlSectionSeparator.js +1 -0
  899. package/dist/components/PlSectionSeparator/PlSectionSeparator.style.js +1 -0
  900. package/dist/components/PlSectionSeparator/PlSectionSeparator.vue2.js +2 -0
  901. package/dist/components/PlSectionSeparator/PlSectionSeparator.vue2.js.map +1 -1
  902. package/dist/components/PlSidebar/PlSidebarGroup.js +1 -0
  903. package/dist/components/PlSidebar/PlSidebarGroup.style.js +1 -0
  904. package/dist/components/PlSidebar/PlSidebarGroup.vue2.js +2 -0
  905. package/dist/components/PlSidebar/PlSidebarGroup.vue2.js.map +1 -1
  906. package/dist/components/PlSidebar/PlSidebarItem.js +1 -0
  907. package/dist/components/PlSidebar/PlSidebarItem.style.js +1 -0
  908. package/dist/components/PlSidebar/PlSidebarItem.vue2.js +2 -0
  909. package/dist/components/PlSidebar/PlSidebarItem.vue2.js.map +1 -1
  910. package/dist/components/PlSlideModal/PlPureSlideModal.js +2 -0
  911. package/dist/components/PlSlideModal/PlPureSlideModal.vue2.js +1 -0
  912. package/dist/components/PlSlideModal/PlSlideModal.js +1 -0
  913. package/dist/components/PlSlideModal/PlSlideModal.style.js +1 -0
  914. package/dist/components/PlSlideModal/PlSlideModal.vue2.js +2 -0
  915. package/dist/components/PlSlideModal/PlSlideModal.vue2.js.map +1 -1
  916. package/dist/components/PlSlideModal/props.js +3 -1
  917. package/dist/components/PlSlideModal/props.js.map +1 -1
  918. package/dist/components/PlSplash/PlSplash.js +2 -0
  919. package/dist/components/PlSplash/PlSplash.vue2.js +2 -0
  920. package/dist/components/PlSplash/PlSplash.vue2.js.map +1 -1
  921. package/dist/components/PlSplash/pl-splash.module.js +1 -0
  922. package/dist/components/PlStatusTag/PlStatusTag.js +2 -0
  923. package/dist/components/PlStatusTag/PlStatusTag.vue2.js +2 -0
  924. package/dist/components/PlStatusTag/PlStatusTag.vue2.js.map +1 -1
  925. package/dist/components/PlSvg/PlSvg.js +1 -0
  926. package/dist/components/PlSvg/PlSvg.style.js +1 -0
  927. package/dist/components/PlSvg/PlSvg.vue2.js +2 -0
  928. package/dist/components/PlSvg/PlSvg.vue2.js.map +1 -1
  929. package/dist/components/PlSvg/registry.js +2 -0
  930. package/dist/components/PlSvg/registry.js.map +1 -1
  931. package/dist/components/PlTabs/PlTabs.js +2 -0
  932. package/dist/components/PlTabs/PlTabs.vue2.js +1 -0
  933. package/dist/components/PlTabs/Tab.js +2 -0
  934. package/dist/components/PlTabs/Tab.vue2.js +2 -0
  935. package/dist/components/PlTabs/Tab.vue2.js.map +1 -1
  936. package/dist/components/PlTabs/pl-tabs.module.js +1 -0
  937. package/dist/components/PlTextArea/PlTextArea.js +2 -0
  938. package/dist/components/PlTextArea/PlTextArea.vue2.js +2 -0
  939. package/dist/components/PlTextArea/PlTextArea.vue2.js.map +1 -1
  940. package/dist/components/PlTextField/PlTextField.js +2 -0
  941. package/dist/components/PlTextField/PlTextField.js.map +1 -1
  942. package/dist/components/PlTextField/PlTextField.vue.d.ts +8 -8
  943. package/dist/components/PlTextField/PlTextField.vue.d.ts.map +1 -1
  944. package/dist/components/PlTextField/PlTextField.vue2.js +4 -2
  945. package/dist/components/PlTextField/PlTextField.vue2.js.map +1 -1
  946. package/dist/components/PlToggleSwitch/PlToggleSwitch.js +2 -0
  947. package/dist/components/PlToggleSwitch/PlToggleSwitch.vue2.js +2 -0
  948. package/dist/components/PlToggleSwitch/PlToggleSwitch.vue2.js.map +1 -1
  949. package/dist/components/PlTooltip/PlTooltip.js +1 -0
  950. package/dist/components/PlTooltip/PlTooltip.style.js +1 -0
  951. package/dist/components/PlTooltip/PlTooltip.vue2.js +1 -0
  952. package/dist/components/PlTooltip/global.js +3 -1
  953. package/dist/components/PlTooltip/global.js.map +1 -1
  954. package/dist/components/Scrollable.js +2 -0
  955. package/dist/components/Scrollable.vue2.js +2 -0
  956. package/dist/components/Scrollable.vue2.js.map +1 -1
  957. package/dist/components/Slider.js +2 -0
  958. package/dist/components/Slider.vue2.js +2 -0
  959. package/dist/components/Slider.vue2.js.map +1 -1
  960. package/dist/components/SliderRange.js +2 -0
  961. package/dist/components/SliderRange.vue2.js +2 -0
  962. package/dist/components/SliderRange.vue2.js.map +1 -1
  963. package/dist/components/SliderRangeTriple.js +2 -0
  964. package/dist/components/SliderRangeTriple.vue2.js +2 -0
  965. package/dist/components/SliderRangeTriple.vue2.js.map +1 -1
  966. package/dist/components/TabItem.js +2 -0
  967. package/dist/components/TabItem.vue2.js +2 -0
  968. package/dist/components/TabItem.vue2.js.map +1 -1
  969. package/dist/components/ThemeSwitcher.js +2 -0
  970. package/dist/components/ThemeSwitcher.vue2.js +2 -0
  971. package/dist/components/ThemeSwitcher.vue2.js.map +1 -1
  972. package/dist/components/TransitionSlidePanel.js +2 -0
  973. package/dist/components/TransitionSlidePanel.vue2.js +2 -0
  974. package/dist/components/TransitionSlidePanel.vue2.js.map +1 -1
  975. package/dist/components/VScroll.js +2 -0
  976. package/dist/components/VScroll.vue2.js +2 -0
  977. package/dist/components/VScroll.vue2.js.map +1 -1
  978. package/dist/components/contextMenu/Menu.js +2 -0
  979. package/dist/components/contextMenu/Menu.vue2.js +2 -0
  980. package/dist/components/contextMenu/Menu.vue2.js.map +1 -1
  981. package/dist/components/contextMenu/index.js +2 -0
  982. package/dist/components/contextMenu/index.js.map +1 -1
  983. package/dist/composition/computedCached.js +2 -0
  984. package/dist/composition/computedCached.js.map +1 -1
  985. package/dist/composition/filters/metadata.js +3 -1
  986. package/dist/composition/filters/metadata.js.map +1 -1
  987. package/dist/composition/useClickOutside.js +2 -0
  988. package/dist/composition/useClickOutside.js.map +1 -1
  989. package/dist/composition/useComponentProp.js +2 -30
  990. package/dist/composition/useComponentProp.js.map +1 -1
  991. package/dist/composition/useConfirm.js +2 -0
  992. package/dist/composition/useConfirm.js.map +1 -1
  993. package/dist/composition/useDraggable.js +2 -0
  994. package/dist/composition/useDraggable.js.map +1 -1
  995. package/dist/composition/useEventListener.js +2 -0
  996. package/dist/composition/useEventListener.js.map +1 -1
  997. package/dist/composition/useFilteredList.js +2 -0
  998. package/dist/composition/useFilteredList.js.map +1 -1
  999. package/dist/composition/useFormState.js +2 -0
  1000. package/dist/composition/useFormState.js.map +1 -1
  1001. package/dist/composition/useHover.js +2 -0
  1002. package/dist/composition/useHover.js.map +1 -1
  1003. package/dist/composition/useInterval.js +2 -0
  1004. package/dist/composition/useInterval.js.map +1 -1
  1005. package/dist/composition/useLocalStorage.js +2 -0
  1006. package/dist/composition/useLocalStorage.js.map +1 -1
  1007. package/dist/composition/useMouse.js +2 -0
  1008. package/dist/composition/useMouse.js.map +1 -1
  1009. package/dist/composition/useMouseCapture.js +2 -0
  1010. package/dist/composition/useMouseCapture.js.map +1 -1
  1011. package/dist/composition/usePollingQuery.js +11 -94
  1012. package/dist/composition/usePollingQuery.js.map +1 -1
  1013. package/dist/composition/usePosition.js +2 -0
  1014. package/dist/composition/usePosition.js.map +1 -1
  1015. package/dist/composition/useQuery.js +2 -0
  1016. package/dist/composition/useQuery.js.map +1 -1
  1017. package/dist/composition/useResizeObserver.js +2 -0
  1018. package/dist/composition/useResizeObserver.js.map +1 -1
  1019. package/dist/composition/useRipple.js +2 -0
  1020. package/dist/composition/useRipple.js.map +1 -1
  1021. package/dist/composition/useScroll.js +2 -0
  1022. package/dist/composition/useScroll.js.map +1 -1
  1023. package/dist/composition/useSliderBreakpoints.js +3 -1
  1024. package/dist/composition/useSliderBreakpoints.js.map +1 -1
  1025. package/dist/composition/useSortable.js +2 -0
  1026. package/dist/composition/useSortable.js.map +1 -1
  1027. package/dist/composition/useSortable2.js +2 -9
  1028. package/dist/composition/useSortable2.js.map +1 -1
  1029. package/dist/composition/useTheme.js +2 -0
  1030. package/dist/composition/useTheme.js.map +1 -1
  1031. package/dist/composition/useTransformedModel.js +2 -31
  1032. package/dist/composition/useTransformedModel.js.map +1 -1
  1033. package/dist/composition/useWatchFetch.js +2 -20
  1034. package/dist/composition/useWatchFetch.js.map +1 -1
  1035. package/dist/composition/utils.js +2 -0
  1036. package/dist/composition/utils.js.map +1 -1
  1037. package/dist/composition/watchCached.js +2 -1
  1038. package/dist/demo-site-data/all-css-variables.js +2 -0
  1039. package/dist/demo-site-data/all-css-variables.js.map +1 -1
  1040. package/dist/generated/icons-16.js +3 -1
  1041. package/dist/generated/icons-16.js.map +1 -1
  1042. package/dist/generated/icons-24.js +3 -1
  1043. package/dist/generated/icons-24.js.map +1 -1
  1044. package/dist/global/resizeObserver.js +2 -0
  1045. package/dist/global/resizeObserver.js.map +1 -1
  1046. package/dist/helpers/dom.js +2 -0
  1047. package/dist/helpers/dom.js.map +1 -1
  1048. package/dist/helpers/downloadContent.js +3 -1
  1049. package/dist/helpers/downloadContent.js.map +1 -1
  1050. package/dist/helpers/error.js +2 -0
  1051. package/dist/helpers/error.js.map +1 -1
  1052. package/dist/helpers/functions.js +2 -0
  1053. package/dist/helpers/functions.js.map +1 -1
  1054. package/dist/helpers/index.js +2 -0
  1055. package/dist/helpers/index.js.map +1 -1
  1056. package/dist/helpers/iterators.js +2 -0
  1057. package/dist/helpers/iterators.js.map +1 -1
  1058. package/dist/helpers/math.js +2 -0
  1059. package/dist/helpers/math.js.map +1 -1
  1060. package/dist/helpers/objects.js +2 -0
  1061. package/dist/helpers/objects.js.map +1 -1
  1062. package/dist/helpers/utils.js +2 -0
  1063. package/dist/helpers/utils.js.map +1 -1
  1064. package/dist/index.js +2 -0
  1065. package/dist/index.js.map +1 -1
  1066. package/dist/layout/PlBlockPage/PlBlockPage.js +1 -0
  1067. package/dist/layout/PlBlockPage/PlBlockPage.style.js +1 -0
  1068. package/dist/layout/PlBlockPage/PlBlockPage.vue2.js +2 -0
  1069. package/dist/layout/PlBlockPage/PlBlockPage.vue2.js.map +1 -1
  1070. package/dist/layout/PlBlockPage/PlBlockPageTitleTeleportTarget.js +3 -1
  1071. package/dist/layout/PlBlockPage/PlBlockPageTitleTeleportTarget.js.map +1 -1
  1072. package/dist/layout/PlBlockPage/usePlBlockPageTitleTeleportTarget.js +2 -0
  1073. package/dist/layout/PlBlockPage/usePlBlockPageTitleTeleportTarget.js.map +1 -1
  1074. package/dist/layout/PlContainer/PlContainer.js +2 -0
  1075. package/dist/layout/PlContainer/PlContainer.vue2.js +1 -0
  1076. package/dist/layout/PlGrid/PlGrid.js +2 -0
  1077. package/dist/layout/PlGrid/PlGrid.vue2.js +1 -0
  1078. package/dist/layout/PlPlaceholder/PlPlaceholder.js +1 -0
  1079. package/dist/layout/PlPlaceholder/PlPlaceholder.style.js +1 -0
  1080. package/dist/layout/PlPlaceholder/PlPlaceholder.vue2.js +2 -0
  1081. package/dist/layout/PlPlaceholder/PlPlaceholder.vue2.js.map +1 -1
  1082. package/dist/layout/PlPlaceholder/index.js +3 -1
  1083. package/dist/layout/PlPlaceholder/index.js.map +1 -1
  1084. package/dist/layout/PlPlaceholder/paint-worklet.js +2 -0
  1085. package/dist/layout/PlPlaceholder/paint-worklet.js.map +1 -1
  1086. package/dist/layout/PlRow/PlRow.js +2 -0
  1087. package/dist/layout/PlRow/PlRow.vue2.js +1 -0
  1088. package/dist/layout/PlSpacer/PlSpacer.js +2 -0
  1089. package/dist/layout/PlSpacer/PlSpacer.vue2.js +2 -0
  1090. package/dist/layout/PlSpacer/PlSpacer.vue2.js.map +1 -1
  1091. package/dist/utils/DoubleContour.js +2 -0
  1092. package/dist/utils/DoubleContour.js.map +1 -1
  1093. package/dist/utils/DoubleContour.vue2.js +3 -1
  1094. package/dist/utils/DoubleContour.vue2.js.map +1 -1
  1095. package/dist/utils/DropdownOverlay/DropdownOverlay.js +2 -0
  1096. package/dist/utils/DropdownOverlay/DropdownOverlay.vue2.js +2 -0
  1097. package/dist/utils/DropdownOverlay/DropdownOverlay.vue2.js.map +1 -1
  1098. package/dist/utils/InnerBorder.js +2 -0
  1099. package/dist/utils/InnerBorder.js.map +1 -1
  1100. package/dist/utils/InnerBorder.vue2.js +2 -0
  1101. package/dist/utils/InnerBorder.vue2.js.map +1 -1
  1102. package/dist/utils/PlCloseModalBtn.js +2 -0
  1103. package/dist/utils/PlCloseModalBtn.js.map +1 -1
  1104. package/dist/utils/PlCloseModalBtn.style.js +1 -0
  1105. package/dist/utils/TextLabel.js +2 -0
  1106. package/dist/utils/TextLabel.js.map +1 -1
  1107. package/dist/utils/TextLabel.style.js +1 -0
  1108. package/dist/utils/useLabelNotch.js +2 -3
  1109. package/dist/utils/useLabelNotch.js.map +1 -1
  1110. package/dist/utils/useValidation.js +2 -0
  1111. package/dist/utils/useValidation.js.map +1 -1
  1112. package/package.json +6 -6
  1113. package/src/components/PlNumberField/PlNumberField.vue +1 -1
  1114. package/src/components/PlTextField/PlTextField.vue +8 -8
  1115. package/src/utils/DoubleContour.vue +2 -2
@@ -1 +1 @@
1
- {"version":3,"file":"Remote.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlFileDialog/Remote.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { useEventListener } from \"../../composition/useEventListener\";\nimport type { ImportedFiles } from \"../../types\";\nimport { between, notEmpty, tapIf } from \"@milaboratories/helpers\";\nimport { getRawPlatformaInstance, type StorageHandle } from \"@platforma-sdk/model\";\nimport { computed, onMounted, reactive, ref, toRef, watch } from \"vue\";\nimport { PlDropdown } from \"../PlDropdown\";\nimport { PlIcon16 } from \"../PlIcon16\";\nimport Shortcuts from \"./Shortcuts.vue\";\nimport { PlMaskIcon16 } from \"../PlMaskIcon16\";\nimport { PlSearchField } from \"../PlSearchField\";\nimport style from \"./pl-file-dialog.module.scss\";\nimport { defaultData, useVisibleItems, vTextOverflown } from \"./remote-helpers\";\nimport { getFilePathBreadcrumbs, normalizeExtensions, type FileDialogItem } from \"./utils\";\n\n// note that on a Mac, a click combined with the control key is intercepted by the operating system and used to open a context menu, so ctrlKey is not detectable on click events.\nconst isCtrlOrMeta = (ev: KeyboardEvent | MouseEvent) => ev.ctrlKey || ev.metaKey;\n\ndefineEmits<{\n (e: \"update:modelValue\", value: boolean): void;\n (e: \"import:files\", value: ImportedFiles): void;\n}>();\n\nconst props = withDefaults(\n defineProps<{\n modelValue: boolean;\n extensions?: string[]; // with dot, like ['.fastq.gz', '.fastq']\n multi?: boolean;\n title?: string;\n autoSelectStorage?: boolean;\n submit: () => void;\n }>(),\n {\n extensions: undefined,\n title: undefined,\n autoSelectStorage: true,\n },\n);\n\nconst data = reactive(defaultData());\n\nconst resetData = () => {\n data.search = \"\";\n data.error = \"\";\n data.lastSelected = undefined;\n};\n\nconst extensions = computed(() => normalizeExtensions(props.extensions));\n\nconst visibleItems = useVisibleItems(data);\n\nconst lookup = computed(() => {\n return {\n modelValue: props.modelValue,\n dirPath: data.dirPath,\n storageHandle: data.storageEntry?.handle,\n };\n});\n\nconst query = (storageHandle: StorageHandle, dirPath: string) => {\n if (!getRawPlatformaInstance()) {\n return;\n }\n\n if (data.currentLoadingPath === dirPath) {\n return;\n }\n\n data.currentLoadingPath = dirPath;\n\n getRawPlatformaInstance()\n .lsDriver.listFiles(storageHandle, dirPath)\n .then((res) => {\n if (dirPath !== data.dirPath) {\n return;\n }\n\n data.items = notEmpty(res)\n .entries.map((item) => ({\n path: item.fullPath,\n name: item.name,\n isDir: item.type === \"dir\",\n canBeSelected:\n item.type === \"file\" &&\n (!extensions.value || extensions.value.some((ext) => item.fullPath.endsWith(ext))),\n handle: item.type === \"file\" ? item.handle : undefined,\n selected: false,\n }))\n .sort((a, b) => {\n if (a.isDir && !b.isDir) return -1;\n if (!a.isDir && b.isDir) return 1;\n // localeCompare for unicode alphabets\n return a.name.localeCompare(b.name);\n })\n .map((it, id) => ({ id, ...it }));\n\n data.lastSelected = undefined;\n })\n .catch((err) => (data.error = String(err)))\n .finally(() => {\n data.currentLoadingPath = undefined;\n });\n};\n\nconst load = () => {\n resetData();\n const { storageHandle, dirPath, modelValue } = lookup.value;\n if (storageHandle && modelValue) {\n query(storageHandle, dirPath);\n }\n};\n\nconst breadcrumbs = computed(() => getFilePathBreadcrumbs(data.dirPath));\n\nconst selectedFiles = computed(() =>\n data.items.filter((f) => f.canBeSelected && f.selected && !f.isDir),\n);\n\nconst isReady = computed(() => selectedFiles.value.length > 0 && data.storageEntry?.handle);\n\nconst getFilesToImport = () => ({\n storageHandle: notEmpty(data.storageEntry?.handle),\n files: selectedFiles.value.map((f) => f.handle!),\n});\n\nconst setDirPath = (dirPath: string) => {\n data.dirPath = dirPath;\n};\n\nconst selectFile = (ev: MouseEvent, file: FileDialogItem) => {\n const { shiftKey } = ev;\n\n const ctrlOrMetaKey = isCtrlOrMeta(ev);\n\n const { lastSelected } = data;\n\n ev.preventDefault();\n\n const items = visibleItems.value;\n\n if (file.canBeSelected) {\n if (!props.multi) {\n items.forEach((f) => (f.selected = false));\n }\n\n file.selected = !file.selected;\n\n if (!props.multi) {\n return;\n }\n\n if (!ctrlOrMetaKey && !shiftKey) {\n items.forEach((f) => {\n if (f.id !== file.id) {\n f.selected = false;\n }\n });\n }\n\n if (shiftKey && lastSelected !== undefined) {\n items.forEach((f) => {\n if (between(f.id, lastSelected, file.id)) {\n f.selected = true;\n }\n });\n }\n\n if (file.selected) {\n data.lastSelected = file.id;\n }\n }\n};\n\nconst changeAll = (selected: boolean) => {\n if (selected && !props.multi) {\n return;\n }\n\n visibleItems.value\n .filter((f) => f.canBeSelected)\n .forEach((file) => {\n file.selected = selected;\n });\n};\n\nconst selectAll = () => changeAll(true);\n\nconst deselectAll = () => changeAll(false);\n\nconst loadAvailableStorages = () => {\n resetData();\n deselectAll();\n if (!getRawPlatformaInstance()) {\n console.warn(\"platforma API is not found\");\n return;\n }\n getRawPlatformaInstance()\n .lsDriver.getStorageList()\n .then((storageEntries) => {\n // local storage is always returned by the ML, so we need to remove it from remote dialog manually\n storageEntries = storageEntries.filter(\n (it) => it.name !== \"local\" && !it.name.startsWith(\"local_disk_\"),\n );\n\n data.storageOptions = storageEntries.map((it) => ({\n text: it.name,\n value: it,\n }));\n\n if (props.autoSelectStorage) {\n tapIf(storageEntries[0], (entry) => {\n data.storageEntry = entry;\n });\n }\n })\n .catch((err) => (data.error = String(err)));\n};\n\nwatch(\n toRef(data, \"storageEntry\"),\n (entry) => {\n resetData();\n data.dirPath = entry?.initialFullPath ?? \"\";\n },\n { immediate: true },\n);\n\nwatch([() => data.dirPath, () => data.storageEntry], () => {\n load();\n});\n\nwatch(\n () => props.modelValue,\n (isOpen) => {\n if (isOpen) {\n loadAvailableStorages();\n } else {\n Object.assign(data, defaultData());\n }\n },\n { immediate: true },\n);\n\nuseEventListener(document, \"keydown\", (ev: KeyboardEvent) => {\n if (!props.modelValue) {\n return;\n }\n\n if (ev.target !== document.body) {\n return;\n }\n\n const ctrlOrMetaKey = isCtrlOrMeta(ev);\n\n if (ctrlOrMetaKey && ev.code === \"KeyA\") {\n ev.preventDefault();\n selectAll();\n }\n\n if (ctrlOrMetaKey && ev.shiftKey && ev.code === \"Period\") {\n ev.preventDefault();\n data.showHiddenItems = !data.showHiddenItems;\n }\n\n if (ev.code === \"Enter\") {\n props.submit();\n }\n});\n\ndefineExpose({\n isReady,\n getFilesToImport,\n});\n\nonMounted(loadAvailableStorages);\n\nconst lsContainerRef = ref<HTMLElement | undefined>();\n</script>\n\n<template>\n <div :class=\"style.remote\" @click.stop=\"deselectAll\">\n <div :class=\"style.search\">\n <div>\n <PlDropdown\n v-model=\"data.storageEntry\"\n label=\"Select storage\"\n :options=\"data.storageOptions\"\n />\n </div>\n <div>\n <PlSearchField v-model=\"data.search\" label=\"Search in folder\" clearable />\n </div>\n </div>\n <div :class=\"style['ls-container']\" ref=\"lsContainerRef\">\n <div :class=\"style['ls-head']\">\n <div :class=\"style['breadcrumbs']\">\n <template v-for=\"(s, i) in breadcrumbs\" :key=\"i\">\n <div :title=\"s.path\" @click=\"setDirPath(s.path)\">{{ s.name }}</div>\n <PlIcon16 v-if=\"s.index !== breadcrumbs.length - 1\" name=\"chevron-right\" />\n </template>\n </div>\n <div :class=\"style.selected\">\n <span>Selected: {{ selectedFiles.length }}</span>\n <Shortcuts :container=\"lsContainerRef\" />\n </div>\n </div>\n <div v-if=\"data.currentLoadingPath !== undefined\" class=\"ls-loader\">\n <i class=\"mask-24 mask-loading loader-icon\" />\n </div>\n <div v-else-if=\"!data.storageEntry\" :class=\"style['ls-empty']\">\n <div :class=\"style.cat\" />\n <div :class=\"style.message\">Select storage to preview</div>\n </div>\n <div v-else-if=\"data.error\" :class=\"style['ls-error']\">\n <div :class=\"style.cat\" />\n <div :class=\"style.message\">{{ data.error }}</div>\n </div>\n <div v-else :class=\"style['ls-body']\">\n <template v-for=\"file in visibleItems\" :key=\"file.id\">\n <div v-if=\"file.isDir\" :class=\"style.isDir\" @click=\"setDirPath(file.path)\">\n <PlIcon16 name=\"chevron-right\" />\n <span v-text-overflown :title=\"file.name\">{{ file.name }}</span>\n </div>\n <div\n v-else\n :class=\"{ [style.canBeSelected]: file.canBeSelected, [style.selected]: file.selected }\"\n @click.stop=\"(ev) => selectFile(ev, file)\"\n >\n <PlMaskIcon16 name=\"box\" :class=\"style.isFile\" />\n <span v-text-overflown :title=\"file.name\">{{ file.name }}</span>\n </div>\n </template>\n </div>\n </div>\n </div>\n</template>\n"],"mappings":"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"}
1
+ {"version":3,"file":"Remote.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlFileDialog/Remote.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { useEventListener } from \"../../composition/useEventListener\";\nimport type { ImportedFiles } from \"../../types\";\nimport { between, notEmpty, tapIf } from \"@milaboratories/helpers\";\nimport { getRawPlatformaInstance, type StorageHandle } from \"@platforma-sdk/model\";\nimport { computed, onMounted, reactive, ref, toRef, watch } from \"vue\";\nimport { PlDropdown } from \"../PlDropdown\";\nimport { PlIcon16 } from \"../PlIcon16\";\nimport Shortcuts from \"./Shortcuts.vue\";\nimport { PlMaskIcon16 } from \"../PlMaskIcon16\";\nimport { PlSearchField } from \"../PlSearchField\";\nimport style from \"./pl-file-dialog.module.scss\";\nimport { defaultData, useVisibleItems, vTextOverflown } from \"./remote-helpers\";\nimport { getFilePathBreadcrumbs, normalizeExtensions, type FileDialogItem } from \"./utils\";\n\n// note that on a Mac, a click combined with the control key is intercepted by the operating system and used to open a context menu, so ctrlKey is not detectable on click events.\nconst isCtrlOrMeta = (ev: KeyboardEvent | MouseEvent) => ev.ctrlKey || ev.metaKey;\n\ndefineEmits<{\n (e: \"update:modelValue\", value: boolean): void;\n (e: \"import:files\", value: ImportedFiles): void;\n}>();\n\nconst props = withDefaults(\n defineProps<{\n modelValue: boolean;\n extensions?: string[]; // with dot, like ['.fastq.gz', '.fastq']\n multi?: boolean;\n title?: string;\n autoSelectStorage?: boolean;\n submit: () => void;\n }>(),\n {\n extensions: undefined,\n title: undefined,\n autoSelectStorage: true,\n },\n);\n\nconst data = reactive(defaultData());\n\nconst resetData = () => {\n data.search = \"\";\n data.error = \"\";\n data.lastSelected = undefined;\n};\n\nconst extensions = computed(() => normalizeExtensions(props.extensions));\n\nconst visibleItems = useVisibleItems(data);\n\nconst lookup = computed(() => {\n return {\n modelValue: props.modelValue,\n dirPath: data.dirPath,\n storageHandle: data.storageEntry?.handle,\n };\n});\n\nconst query = (storageHandle: StorageHandle, dirPath: string) => {\n if (!getRawPlatformaInstance()) {\n return;\n }\n\n if (data.currentLoadingPath === dirPath) {\n return;\n }\n\n data.currentLoadingPath = dirPath;\n\n getRawPlatformaInstance()\n .lsDriver.listFiles(storageHandle, dirPath)\n .then((res) => {\n if (dirPath !== data.dirPath) {\n return;\n }\n\n data.items = notEmpty(res)\n .entries.map((item) => ({\n path: item.fullPath,\n name: item.name,\n isDir: item.type === \"dir\",\n canBeSelected:\n item.type === \"file\" &&\n (!extensions.value || extensions.value.some((ext) => item.fullPath.endsWith(ext))),\n handle: item.type === \"file\" ? item.handle : undefined,\n selected: false,\n }))\n .sort((a, b) => {\n if (a.isDir && !b.isDir) return -1;\n if (!a.isDir && b.isDir) return 1;\n // localeCompare for unicode alphabets\n return a.name.localeCompare(b.name);\n })\n .map((it, id) => ({ id, ...it }));\n\n data.lastSelected = undefined;\n })\n .catch((err) => (data.error = String(err)))\n .finally(() => {\n data.currentLoadingPath = undefined;\n });\n};\n\nconst load = () => {\n resetData();\n const { storageHandle, dirPath, modelValue } = lookup.value;\n if (storageHandle && modelValue) {\n query(storageHandle, dirPath);\n }\n};\n\nconst breadcrumbs = computed(() => getFilePathBreadcrumbs(data.dirPath));\n\nconst selectedFiles = computed(() =>\n data.items.filter((f) => f.canBeSelected && f.selected && !f.isDir),\n);\n\nconst isReady = computed(() => selectedFiles.value.length > 0 && data.storageEntry?.handle);\n\nconst getFilesToImport = () => ({\n storageHandle: notEmpty(data.storageEntry?.handle),\n files: selectedFiles.value.map((f) => f.handle!),\n});\n\nconst setDirPath = (dirPath: string) => {\n data.dirPath = dirPath;\n};\n\nconst selectFile = (ev: MouseEvent, file: FileDialogItem) => {\n const { shiftKey } = ev;\n\n const ctrlOrMetaKey = isCtrlOrMeta(ev);\n\n const { lastSelected } = data;\n\n ev.preventDefault();\n\n const items = visibleItems.value;\n\n if (file.canBeSelected) {\n if (!props.multi) {\n items.forEach((f) => (f.selected = false));\n }\n\n file.selected = !file.selected;\n\n if (!props.multi) {\n return;\n }\n\n if (!ctrlOrMetaKey && !shiftKey) {\n items.forEach((f) => {\n if (f.id !== file.id) {\n f.selected = false;\n }\n });\n }\n\n if (shiftKey && lastSelected !== undefined) {\n items.forEach((f) => {\n if (between(f.id, lastSelected, file.id)) {\n f.selected = true;\n }\n });\n }\n\n if (file.selected) {\n data.lastSelected = file.id;\n }\n }\n};\n\nconst changeAll = (selected: boolean) => {\n if (selected && !props.multi) {\n return;\n }\n\n visibleItems.value\n .filter((f) => f.canBeSelected)\n .forEach((file) => {\n file.selected = selected;\n });\n};\n\nconst selectAll = () => changeAll(true);\n\nconst deselectAll = () => changeAll(false);\n\nconst loadAvailableStorages = () => {\n resetData();\n deselectAll();\n if (!getRawPlatformaInstance()) {\n console.warn(\"platforma API is not found\");\n return;\n }\n getRawPlatformaInstance()\n .lsDriver.getStorageList()\n .then((storageEntries) => {\n // local storage is always returned by the ML, so we need to remove it from remote dialog manually\n storageEntries = storageEntries.filter(\n (it) => it.name !== \"local\" && !it.name.startsWith(\"local_disk_\"),\n );\n\n data.storageOptions = storageEntries.map((it) => ({\n text: it.name,\n value: it,\n }));\n\n if (props.autoSelectStorage) {\n tapIf(storageEntries[0], (entry) => {\n data.storageEntry = entry;\n });\n }\n })\n .catch((err) => (data.error = String(err)));\n};\n\nwatch(\n toRef(data, \"storageEntry\"),\n (entry) => {\n resetData();\n data.dirPath = entry?.initialFullPath ?? \"\";\n },\n { immediate: true },\n);\n\nwatch([() => data.dirPath, () => data.storageEntry], () => {\n load();\n});\n\nwatch(\n () => props.modelValue,\n (isOpen) => {\n if (isOpen) {\n loadAvailableStorages();\n } else {\n Object.assign(data, defaultData());\n }\n },\n { immediate: true },\n);\n\nuseEventListener(document, \"keydown\", (ev: KeyboardEvent) => {\n if (!props.modelValue) {\n return;\n }\n\n if (ev.target !== document.body) {\n return;\n }\n\n const ctrlOrMetaKey = isCtrlOrMeta(ev);\n\n if (ctrlOrMetaKey && ev.code === \"KeyA\") {\n ev.preventDefault();\n selectAll();\n }\n\n if (ctrlOrMetaKey && ev.shiftKey && ev.code === \"Period\") {\n ev.preventDefault();\n data.showHiddenItems = !data.showHiddenItems;\n }\n\n if (ev.code === \"Enter\") {\n props.submit();\n }\n});\n\ndefineExpose({\n isReady,\n getFilesToImport,\n});\n\nonMounted(loadAvailableStorages);\n\nconst lsContainerRef = ref<HTMLElement | undefined>();\n</script>\n\n<template>\n <div :class=\"style.remote\" @click.stop=\"deselectAll\">\n <div :class=\"style.search\">\n <div>\n <PlDropdown\n v-model=\"data.storageEntry\"\n label=\"Select storage\"\n :options=\"data.storageOptions\"\n />\n </div>\n <div>\n <PlSearchField v-model=\"data.search\" label=\"Search in folder\" clearable />\n </div>\n </div>\n <div :class=\"style['ls-container']\" ref=\"lsContainerRef\">\n <div :class=\"style['ls-head']\">\n <div :class=\"style['breadcrumbs']\">\n <template v-for=\"(s, i) in breadcrumbs\" :key=\"i\">\n <div :title=\"s.path\" @click=\"setDirPath(s.path)\">{{ s.name }}</div>\n <PlIcon16 v-if=\"s.index !== breadcrumbs.length - 1\" name=\"chevron-right\" />\n </template>\n </div>\n <div :class=\"style.selected\">\n <span>Selected: {{ selectedFiles.length }}</span>\n <Shortcuts :container=\"lsContainerRef\" />\n </div>\n </div>\n <div v-if=\"data.currentLoadingPath !== undefined\" class=\"ls-loader\">\n <i class=\"mask-24 mask-loading loader-icon\" />\n </div>\n <div v-else-if=\"!data.storageEntry\" :class=\"style['ls-empty']\">\n <div :class=\"style.cat\" />\n <div :class=\"style.message\">Select storage to preview</div>\n </div>\n <div v-else-if=\"data.error\" :class=\"style['ls-error']\">\n <div :class=\"style.cat\" />\n <div :class=\"style.message\">{{ data.error }}</div>\n </div>\n <div v-else :class=\"style['ls-body']\">\n <template v-for=\"file in visibleItems\" :key=\"file.id\">\n <div v-if=\"file.isDir\" :class=\"style.isDir\" @click=\"setDirPath(file.path)\">\n <PlIcon16 name=\"chevron-right\" />\n <span v-text-overflown :title=\"file.name\">{{ file.name }}</span>\n </div>\n <div\n v-else\n :class=\"{ [style.canBeSelected]: file.canBeSelected, [style.selected]: file.selected }\"\n @click.stop=\"(ev) => selectFile(ev, file)\"\n >\n <PlMaskIcon16 name=\"box\" :class=\"style.isFile\" />\n <span v-text-overflown :title=\"file.name\">{{ file.name }}</span>\n </div>\n </template>\n </div>\n </div>\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 "./Shortcuts.vue2.js";
3
3
  import n from "./Shortcuts.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=Shortcuts.js.map
@@ -4,6 +4,7 @@ import './Shortcuts.vue.css';var e = {
4
4
  head: "_head_11ml3_30",
5
5
  body: "_body_11ml3_58"
6
6
  };
7
+ //#endregion
7
8
  export { e as default };
8
9
 
9
10
  //# sourceMappingURL=Shortcuts.style.js.map
@@ -1,6 +1,7 @@
1
1
  import e from "../PlTooltip/PlTooltip.js";
2
2
  import "../PlTooltip/index.js";
3
3
  import { createBlock as t, createElementVNode as n, defineComponent as r, normalizeClass as i, openBlock as a, unref as o, withCtx as s } from "vue";
4
+ //#region src/components/PlFileDialog/Shortcuts.vue?vue&type=script&setup=true&lang.ts
4
5
  var c = /* @__PURE__ */ r({
5
6
  __name: "Shortcuts",
6
7
  props: { container: {} },
@@ -37,6 +38,7 @@ var c = /* @__PURE__ */ r({
37
38
  }, 8, ["container"]));
38
39
  }
39
40
  });
41
+ //#endregion
40
42
  export { c as default };
41
43
 
42
44
  //# sourceMappingURL=Shortcuts.vue2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Shortcuts.vue_vue_type_script_setup_true_lang.js","names":["$style"],"sources":["../../../src/components/PlFileDialog/Shortcuts.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { PlTooltip } from \"../PlTooltip\";\n\ndefineProps<{\n container?: \"body\" | HTMLElement;\n}>();\n</script>\n\n<template>\n <PlTooltip class=\"info\" position=\"bottom\" max-width=\"420px\" :container=\"container\">\n <template #tooltip>\n <span :class=\"$style.title\">Shortcuts</span>\n\n <div :class=\"[$style.row, $style.head]\">\n <div />\n <div>MacOS</div>\n <div>Windows/Linux</div>\n </div>\n\n <div :class=\"[$style.row, $style.body]\">\n <div>Single File</div>\n <div>Click the file</div>\n <div>Click the file</div>\n\n <div>Adjacent multiple files</div>\n <div>Hold Shift, click first and last files</div>\n <div>Hold Shift, click first and last files</div>\n\n <div>Non-adjacent multiple files</div>\n <div>Hold Command (⌘), click each file</div>\n <div>Hold Ctrl, click each file</div>\n\n <div>All files</div>\n <div>Press Command (⌘) + A</div>\n <div>Press Ctrl + A</div>\n </div>\n </template>\n </PlTooltip>\n</template>\n\n<style lang=\"css\" module>\n.title {\n display: inline-block;\n font-size: 14px;\n font-weight: 600;\n line-height: 20px;\n margin-bottom: 10px;\n}\n\n.row {\n display: grid;\n grid-template-columns: repeat(3, 1fr);\n width: 100%;\n color: #fff;\n column-gap: 1px;\n\n font-size: 14px;\n font-weight: 500;\n line-height: 20px;\n}\n\n.row > div:nth-child(3n + 1) {\n padding-left: 4px;\n}\n\n.row > div:nth-child(3n) {\n padding-right: 4px;\n}\n\n.head {\n background-color: #110529;\n position: relative;\n}\n\n.head:before {\n position: absolute;\n content: \"\";\n background-color: #231842;\n width: 12px;\n left: -12px;\n height: 100%;\n}\n\n.head:after {\n position: absolute;\n content: \"\";\n background-color: #231842;\n width: 12px;\n right: -12px;\n height: 100%;\n}\n\n.head > div {\n padding: 6px 12px;\n background-color: #231842;\n}\n\n.body {\n background-color: #231842;\n}\n\n.body > div {\n padding: 6px 12px;\n background: #110529;\n}\n</style>\n"],"mappings":";;;;;;;yBASE,EA4BY,EAAA,EAAA,EAAA;GA5BD,OAAM;GAAO,UAAS;GAAS,aAAU;GAAS,WAAW,EAAA;;GAC3D,SAAO,QAC4B;IAA5C,EAA4C,QAAA,EAArC,OAAK,EAAEA,EAAAA,OAAO,MAAK,EAAA,EAAE,aAAS,EAAA;IAErC,EAIM,OAAA,EAJA,OAAK,EAAA,CAAGA,EAAAA,OAAO,KAAKA,EAAAA,OAAO,KAAI,CAAA,EAAA,EAAA,CAAA,GAAA,AAAA,EAAA,OAAA;KACnC,EAAO,OAAA,MAAA,MAAA,GAAA;KACP,EAAgB,OAAA,MAAX,SAAK,GAAA;KACV,EAAwB,OAAA,MAAnB,iBAAa,GAAA;;IAGpB,EAgBM,OAAA,EAhBA,OAAK,EAAA,CAAGA,EAAAA,OAAO,KAAKA,EAAAA,OAAO,KAAI,CAAA,EAAA,EAAA,CAAA,GAAA,AAAA,EAAA,OAAA;KACnC,EAAsB,OAAA,MAAjB,eAAW,GAAA;KAChB,EAAyB,OAAA,MAApB,kBAAc,GAAA;KACnB,EAAyB,OAAA,MAApB,kBAAc,GAAA;KAEnB,EAAkC,OAAA,MAA7B,2BAAuB,GAAA;KAC5B,EAAiD,OAAA,MAA5C,0CAAsC,GAAA;KAC3C,EAAiD,OAAA,MAA5C,0CAAsC,GAAA;KAE3C,EAAsC,OAAA,MAAjC,+BAA2B,GAAA;KAChC,EAA4C,OAAA,MAAvC,qCAAiC,GAAA;KACtC,EAAqC,OAAA,MAAhC,8BAA0B,GAAA;KAE/B,EAAoB,OAAA,MAAf,aAAS,GAAA;KACd,EAAgC,OAAA,MAA3B,yBAAqB,GAAA;KAC1B,EAAyB,OAAA,MAApB,kBAAc,GAAA"}
1
+ {"version":3,"file":"Shortcuts.vue_vue_type_script_setup_true_lang.js","names":["$style"],"sources":["../../../src/components/PlFileDialog/Shortcuts.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { PlTooltip } from \"../PlTooltip\";\n\ndefineProps<{\n container?: \"body\" | HTMLElement;\n}>();\n</script>\n\n<template>\n <PlTooltip class=\"info\" position=\"bottom\" max-width=\"420px\" :container=\"container\">\n <template #tooltip>\n <span :class=\"$style.title\">Shortcuts</span>\n\n <div :class=\"[$style.row, $style.head]\">\n <div />\n <div>MacOS</div>\n <div>Windows/Linux</div>\n </div>\n\n <div :class=\"[$style.row, $style.body]\">\n <div>Single File</div>\n <div>Click the file</div>\n <div>Click the file</div>\n\n <div>Adjacent multiple files</div>\n <div>Hold Shift, click first and last files</div>\n <div>Hold Shift, click first and last files</div>\n\n <div>Non-adjacent multiple files</div>\n <div>Hold Command (⌘), click each file</div>\n <div>Hold Ctrl, click each file</div>\n\n <div>All files</div>\n <div>Press Command (⌘) + A</div>\n <div>Press Ctrl + A</div>\n </div>\n </template>\n </PlTooltip>\n</template>\n\n<style lang=\"css\" module>\n.title {\n display: inline-block;\n font-size: 14px;\n font-weight: 600;\n line-height: 20px;\n margin-bottom: 10px;\n}\n\n.row {\n display: grid;\n grid-template-columns: repeat(3, 1fr);\n width: 100%;\n color: #fff;\n column-gap: 1px;\n\n font-size: 14px;\n font-weight: 500;\n line-height: 20px;\n}\n\n.row > div:nth-child(3n + 1) {\n padding-left: 4px;\n}\n\n.row > div:nth-child(3n) {\n padding-right: 4px;\n}\n\n.head {\n background-color: #110529;\n position: relative;\n}\n\n.head:before {\n position: absolute;\n content: \"\";\n background-color: #231842;\n width: 12px;\n left: -12px;\n height: 100%;\n}\n\n.head:after {\n position: absolute;\n content: \"\";\n background-color: #231842;\n width: 12px;\n right: -12px;\n height: 100%;\n}\n\n.head > div {\n padding: 6px 12px;\n background-color: #231842;\n}\n\n.body {\n background-color: #231842;\n}\n\n.body > div {\n padding: 6px 12px;\n background: #110529;\n}\n</style>\n"],"mappings":";;;;;;;;yBASE,EA4BY,EAAA,EAAA,EAAA;GA5BD,OAAM;GAAO,UAAS;GAAS,aAAU;GAAS,WAAW,EAAA;;GAC3D,SAAO,QAC4B;IAA5C,EAA4C,QAAA,EAArC,OAAK,EAAEA,EAAAA,OAAO,MAAK,EAAA,EAAE,aAAS,EAAA;IAErC,EAIM,OAAA,EAJA,OAAK,EAAA,CAAGA,EAAAA,OAAO,KAAKA,EAAAA,OAAO,KAAI,CAAA,EAAA,EAAA,CAAA,GAAA,AAAA,EAAA,OAAA;KACnC,EAAO,OAAA,MAAA,MAAA,GAAA;KACP,EAAgB,OAAA,MAAX,SAAK,GAAA;KACV,EAAwB,OAAA,MAAnB,iBAAa,GAAA;;IAGpB,EAgBM,OAAA,EAhBA,OAAK,EAAA,CAAGA,EAAAA,OAAO,KAAKA,EAAAA,OAAO,KAAI,CAAA,EAAA,EAAA,CAAA,GAAA,AAAA,EAAA,OAAA;KACnC,EAAsB,OAAA,MAAjB,eAAW,GAAA;KAChB,EAAyB,OAAA,MAApB,kBAAc,GAAA;KACnB,EAAyB,OAAA,MAApB,kBAAc,GAAA;KAEnB,EAAkC,OAAA,MAA7B,2BAAuB,GAAA;KAC5B,EAAiD,OAAA,MAA5C,0CAAsC,GAAA;KAC3C,EAAiD,OAAA,MAA5C,0CAAsC,GAAA;KAE3C,EAAsC,OAAA,MAAjC,+BAA2B,GAAA;KAChC,EAA4C,OAAA,MAAvC,qCAAiC,GAAA;KACtC,EAAqC,OAAA,MAAhC,8BAA0B,GAAA;KAE/B,EAAoB,OAAA,MAAf,aAAS,GAAA;KACd,EAAgC,OAAA,MAA3B,yBAAqB,GAAA;KAC1B,EAAyB,OAAA,MAApB,kBAAc,GAAA"}
@@ -20,6 +20,7 @@ import './pl-file-dialog.css';var e = {
20
20
  "loader-icon": "_loader-icon_1jvlg_220",
21
21
  spin: "_spin_1jvlg_1"
22
22
  };
23
+ //#endregion
23
24
  export { e as default };
24
25
 
25
26
  //# sourceMappingURL=pl-file-dialog.module.js.map
@@ -1,5 +1,6 @@
1
1
  import { computed as e } from "vue";
2
- const t = () => ({
2
+ //#region src/components/PlFileDialog/remote-helpers.ts
3
+ var t = () => ({
3
4
  dirPath: "",
4
5
  search: "",
5
6
  storageEntry: void 0,
@@ -21,12 +22,13 @@ function n(t) {
21
22
  return e;
22
23
  });
23
24
  }
24
- const r = { mounted: (e) => {
25
+ var r = { mounted: (e) => {
25
26
  if (e.clientWidth < e.scrollWidth) {
26
27
  let t = e.innerText;
27
28
  e.innerText = t.substring(0, 57) + "..." + t.substring(t.length - 10);
28
29
  }
29
30
  } };
31
+ //#endregion
30
32
  export { t as defaultData, n as useVisibleItems, r as vTextOverflown };
31
33
 
32
34
  //# sourceMappingURL=remote-helpers.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"remote-helpers.js","names":[],"sources":["../../../src/components/PlFileDialog/remote-helpers.ts"],"sourcesContent":["import type { Option } from \"@milaboratories/helpers\";\nimport type { StorageEntry } from \"@platforma-sdk/model\";\nimport type { FileDialogItem } from \"./utils\";\nimport { computed } from \"vue\";\n\nexport const defaultData = () => ({\n dirPath: \"\" as string,\n search: \"\",\n storageEntry: undefined as StorageEntry | undefined,\n items: [] as FileDialogItem[],\n error: \"\",\n storageOptions: [] as Option<StorageEntry>[],\n selected: [],\n lastSelected: undefined as number | undefined,\n currentLoadingPath: undefined as string | undefined,\n showHiddenItems: false,\n});\n\nexport type Data = ReturnType<typeof defaultData>;\n\nexport function useVisibleItems(data: Data) {\n return computed(() => {\n let items = data.items;\n\n if (!data.showHiddenItems) {\n items = items.filter((it) => !it.name.startsWith(\".\"));\n }\n\n if (data.search) {\n const search = data.search.toLocaleLowerCase();\n items = items.filter((it) => it.name.toLocaleLowerCase().includes(search));\n }\n\n return items;\n });\n}\n\nexport const vTextOverflown = {\n mounted: (el: HTMLElement) => {\n if (el.clientWidth < el.scrollWidth) {\n const s = el.innerText;\n el.innerText = s.substring(0, 57) + \"...\" + s.substring(s.length - 10);\n }\n },\n};\n"],"mappings":";AAKA,MAAa,WAAqB;CAChC,SAAS;CACT,QAAQ;CACR,cAAc,KAAA;CACd,OAAO,EAAE;CACT,OAAO;CACP,gBAAgB,EAAE;CAClB,UAAU,EAAE;CACZ,cAAc,KAAA;CACd,oBAAoB,KAAA;CACpB,iBAAiB;CAClB;AAID,SAAgB,EAAgB,GAAY;AAC1C,QAAO,QAAe;EACpB,IAAI,IAAQ,EAAK;AAMjB,MAJK,EAAK,oBACR,IAAQ,EAAM,QAAQ,MAAO,CAAC,EAAG,KAAK,WAAW,IAAI,CAAC,GAGpD,EAAK,QAAQ;GACf,IAAM,IAAS,EAAK,OAAO,mBAAmB;AAC9C,OAAQ,EAAM,QAAQ,MAAO,EAAG,KAAK,mBAAmB,CAAC,SAAS,EAAO,CAAC;;AAG5E,SAAO;GACP;;AAGJ,MAAa,IAAiB,EAC5B,UAAU,MAAoB;AAC5B,KAAI,EAAG,cAAc,EAAG,aAAa;EACnC,IAAM,IAAI,EAAG;AACb,IAAG,YAAY,EAAE,UAAU,GAAG,GAAG,GAAG,QAAQ,EAAE,UAAU,EAAE,SAAS,GAAG;;GAG3E"}
1
+ {"version":3,"file":"remote-helpers.js","names":[],"sources":["../../../src/components/PlFileDialog/remote-helpers.ts"],"sourcesContent":["import type { Option } from \"@milaboratories/helpers\";\nimport type { StorageEntry } from \"@platforma-sdk/model\";\nimport type { FileDialogItem } from \"./utils\";\nimport { computed } from \"vue\";\n\nexport const defaultData = () => ({\n dirPath: \"\" as string,\n search: \"\",\n storageEntry: undefined as StorageEntry | undefined,\n items: [] as FileDialogItem[],\n error: \"\",\n storageOptions: [] as Option<StorageEntry>[],\n selected: [],\n lastSelected: undefined as number | undefined,\n currentLoadingPath: undefined as string | undefined,\n showHiddenItems: false,\n});\n\nexport type Data = ReturnType<typeof defaultData>;\n\nexport function useVisibleItems(data: Data) {\n return computed(() => {\n let items = data.items;\n\n if (!data.showHiddenItems) {\n items = items.filter((it) => !it.name.startsWith(\".\"));\n }\n\n if (data.search) {\n const search = data.search.toLocaleLowerCase();\n items = items.filter((it) => it.name.toLocaleLowerCase().includes(search));\n }\n\n return items;\n });\n}\n\nexport const vTextOverflown = {\n mounted: (el: HTMLElement) => {\n if (el.clientWidth < el.scrollWidth) {\n const s = el.innerText;\n el.innerText = s.substring(0, 57) + \"...\" + s.substring(s.length - 10);\n }\n },\n};\n"],"mappings":";;AAKA,IAAa,WAAqB;CAChC,SAAS;CACT,QAAQ;CACR,cAAc,KAAA;CACd,OAAO,EAAE;CACT,OAAO;CACP,gBAAgB,EAAE;CAClB,UAAU,EAAE;CACZ,cAAc,KAAA;CACd,oBAAoB,KAAA;CACpB,iBAAiB;CAClB;AAID,SAAgB,EAAgB,GAAY;AAC1C,QAAO,QAAe;EACpB,IAAI,IAAQ,EAAK;AAMjB,MAJK,EAAK,oBACR,IAAQ,EAAM,QAAQ,MAAO,CAAC,EAAG,KAAK,WAAW,IAAI,CAAC,GAGpD,EAAK,QAAQ;GACf,IAAM,IAAS,EAAK,OAAO,mBAAmB;AAC9C,OAAQ,EAAM,QAAQ,MAAO,EAAG,KAAK,mBAAmB,CAAC,SAAS,EAAO,CAAC;;AAG5E,SAAO;GACP;;AAGJ,IAAa,IAAiB,EAC5B,UAAU,MAAoB;AAC5B,KAAI,EAAG,cAAc,EAAG,aAAa;EACnC,IAAM,IAAI,EAAG;AACb,IAAG,YAAY,EAAE,UAAU,GAAG,GAAG,GAAG,QAAQ,EAAE,UAAU,EAAE,SAAS,GAAG;;GAG3E"}
@@ -1,4 +1,5 @@
1
1
  import { trimChars as e, trimCharsLeft as t } from "@milaboratories/helpers";
2
+ //#region src/components/PlFileDialog/utils.ts
2
3
  function n(e) {
3
4
  return e ? e.map((e) => "." + t(e, ["."])) : void 0;
4
5
  }
@@ -19,6 +20,7 @@ function r(t) {
19
20
  }
20
21
  return i;
21
22
  }
23
+ //#endregion
22
24
  export { r as getFilePathBreadcrumbs, n as normalizeExtensions };
23
25
 
24
26
  //# sourceMappingURL=utils.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","names":[],"sources":["../../../src/components/PlFileDialog/utils.ts"],"sourcesContent":["import { trimChars, trimCharsLeft } from \"@milaboratories/helpers\";\nimport type { ImportFileHandle } from \"@platforma-sdk/model\";\n\nexport function normalizeExtensions(extensions: string[] | undefined) {\n return extensions ? extensions.map((it) => \".\" + trimCharsLeft(it, [\".\"])) : undefined;\n}\n\n// NOTE: works only with '/' separator on *nix systems.\nexport function getFilePathBreadcrumbs(filePath: string) {\n // FIXME: separator probably should be got from ls driver from backend.\n // or else this component won't work with remote storages on Windows.\n const sep = \"/\";\n\n // If file path starts with '/',\n // the storage was set up with absolute paths,\n // and we need to add the separator to the results.\n const isAbsolute = filePath.startsWith(sep);\n const chunks = trimChars(filePath, [sep]).split(sep);\n\n const stack: { index: number; path: string; name: string }[] = [\n {\n index: 0,\n name: \"Root\",\n path: \"\",\n },\n ];\n\n if (chunks.length === 1 && chunks[0] === \"\") {\n return stack;\n }\n\n for (let i = 0; i < chunks.length; i++) {\n const pathPrefix = isAbsolute ? sep : \"\";\n const p = pathPrefix + chunks.slice(0, i + 1).join(sep);\n\n stack.push({\n index: i + 1,\n name: chunks[i],\n path: p,\n });\n }\n\n return stack;\n}\n\nexport type FileDialogItem = {\n id: number;\n path: string;\n name: string;\n canBeSelected: boolean;\n isDir: boolean;\n selected: boolean;\n handle: ImportFileHandle | undefined;\n};\n"],"mappings":";AAGA,SAAgB,EAAoB,GAAkC;AACpE,QAAO,IAAa,EAAW,KAAK,MAAO,MAAM,EAAc,GAAI,CAAC,IAAI,CAAC,CAAC,GAAG,KAAA;;AAI/E,SAAgB,EAAuB,GAAkB;CAGvD,IAKM,IAAa,EAAS,WAAW,IAAI,EACrC,IAAS,EAAU,GAAU,CAAC,IAAI,CAAC,CAAC,MAAM,IAAI,EAE9C,IAAyD,CAC7D;EACE,OAAO;EACP,MAAM;EACN,MAAM;EACP,CACF;AAED,KAAI,EAAO,WAAW,KAAK,EAAO,OAAO,GACvC,QAAO;AAGT,MAAK,IAAI,IAAI,GAAG,IAAI,EAAO,QAAQ,KAAK;EAEtC,IAAM,KADa,IAAa,MAAM,MACf,EAAO,MAAM,GAAG,IAAI,EAAE,CAAC,KAAK,IAAI;AAEvD,IAAM,KAAK;GACT,OAAO,IAAI;GACX,MAAM,EAAO;GACb,MAAM;GACP,CAAC;;AAGJ,QAAO"}
1
+ {"version":3,"file":"utils.js","names":[],"sources":["../../../src/components/PlFileDialog/utils.ts"],"sourcesContent":["import { trimChars, trimCharsLeft } from \"@milaboratories/helpers\";\nimport type { ImportFileHandle } from \"@platforma-sdk/model\";\n\nexport function normalizeExtensions(extensions: string[] | undefined) {\n return extensions ? extensions.map((it) => \".\" + trimCharsLeft(it, [\".\"])) : undefined;\n}\n\n// NOTE: works only with '/' separator on *nix systems.\nexport function getFilePathBreadcrumbs(filePath: string) {\n // FIXME: separator probably should be got from ls driver from backend.\n // or else this component won't work with remote storages on Windows.\n const sep = \"/\";\n\n // If file path starts with '/',\n // the storage was set up with absolute paths,\n // and we need to add the separator to the results.\n const isAbsolute = filePath.startsWith(sep);\n const chunks = trimChars(filePath, [sep]).split(sep);\n\n const stack: { index: number; path: string; name: string }[] = [\n {\n index: 0,\n name: \"Root\",\n path: \"\",\n },\n ];\n\n if (chunks.length === 1 && chunks[0] === \"\") {\n return stack;\n }\n\n for (let i = 0; i < chunks.length; i++) {\n const pathPrefix = isAbsolute ? sep : \"\";\n const p = pathPrefix + chunks.slice(0, i + 1).join(sep);\n\n stack.push({\n index: i + 1,\n name: chunks[i],\n path: p,\n });\n }\n\n return stack;\n}\n\nexport type FileDialogItem = {\n id: number;\n path: string;\n name: string;\n canBeSelected: boolean;\n isDir: boolean;\n selected: boolean;\n handle: ImportFileHandle | undefined;\n};\n"],"mappings":";;AAGA,SAAgB,EAAoB,GAAkC;AACpE,QAAO,IAAa,EAAW,KAAK,MAAO,MAAM,EAAc,GAAI,CAAC,IAAI,CAAC,CAAC,GAAG,KAAA;;AAI/E,SAAgB,EAAuB,GAAkB;CAGvD,IAKM,IAAa,EAAS,WAAW,IAAI,EACrC,IAAS,EAAU,GAAU,CAAC,IAAI,CAAC,CAAC,MAAM,IAAI,EAE9C,IAAyD,CAC7D;EACE,OAAO;EACP,MAAM;EACN,MAAM;EACP,CACF;AAED,KAAI,EAAO,WAAW,KAAK,EAAO,OAAO,GACvC,QAAO;AAGT,MAAK,IAAI,IAAI,GAAG,IAAI,EAAO,QAAQ,KAAK;EAEtC,IAAM,KADa,IAAa,MAAM,MACf,EAAO,MAAM,GAAG,IAAI,EAAE,CAAC,KAAK,IAAI;AAEvD,IAAM,KAAK;GACT,OAAO,IAAI;GACX,MAAM,EAAO;GACb,MAAM;GACP,CAAC;;AAGJ,QAAO"}
@@ -1,5 +1,7 @@
1
1
  import e from "./PlFileInput.vue2.js";
2
+ //#region src/components/PlFileInput/PlFileInput.vue
2
3
  var t = e;
4
+ //#endregion
3
5
  export { t as default };
4
6
 
5
7
  //# sourceMappingURL=PlFileInput.js.map
@@ -14,6 +14,7 @@ import './pl-file-input.css';/* empty css */
14
14
  import { Fragment as c, computed as l, createBlock as u, createCommentVNode as d, createElementBlock as f, createElementVNode as p, createTextVNode as m, createVNode as h, defineComponent as g, normalizeClass as _, normalizeStyle as v, openBlock as y, reactive as b, ref as x, renderSlot as S, toDisplayString as C, unref as w, useSlots as T, watch as E, withCtx as D, withKeys as O, withModifiers as k } from "vue";
15
15
  import { prettyBytes as A } from "@milaboratories/helpers";
16
16
  import { getFileNameFromHandle as ee, getFilePathFromHandle as j } from "@platforma-sdk/model";
17
+ //#region src/components/PlFileInput/PlFileInput.vue?vue&type=script&setup=true&lang.ts
17
18
  var M = {
18
19
  key: 0,
19
20
  ref: "label"
@@ -145,6 +146,7 @@ var M = {
145
146
  ])], 64));
146
147
  }
147
148
  });
149
+ //#endregion
148
150
  export { L as default };
149
151
 
150
152
  //# sourceMappingURL=PlFileInput.vue2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PlFileInput.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlFileInput/PlFileInput.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport \"./pl-file-input.scss\";\n\nimport { prettyBytes } from \"@milaboratories/helpers\";\nimport type { ImportFileHandle, ImportProgress } from \"@platforma-sdk/model\";\nimport { getFileNameFromHandle, getFilePathFromHandle } from \"@platforma-sdk/model\";\nimport { computed, reactive, ref, useSlots, watch } from \"vue\";\nimport { getErrorMessage } from \"../../helpers/error.ts\";\nimport type { ImportedFiles } from \"../../types\";\nimport DoubleContour from \"../../utils/DoubleContour.vue\";\nimport { useLabelNotch } from \"../../utils/useLabelNotch\";\nimport { PlFileDialog } from \"../PlFileDialog\";\nimport { PlMaskIcon24 } from \"../PlMaskIcon24\";\nimport { PlTooltip } from \"../PlTooltip\";\n\nimport SvgRequired from \"../../assets/images/required.svg?raw\";\nimport { PlSvg } from \"../PlSvg\";\n\nconst data = reactive({\n fileDialogOpen: false,\n error: undefined as undefined | string,\n});\n\nconst slots = useSlots();\n\nconst emit = defineEmits<{\n (e: \"update:modelValue\", value: ImportFileHandle | undefined): void;\n}>();\n\nconst props = withDefaults(\n defineProps<{\n /**\n * The current import file handle.\n */\n modelValue: ImportFileHandle | undefined;\n /**\n * The label to display above the input field.\n */\n label?: string;\n /**\n * If `true`, the input field is marked as required.\n */\n required?: boolean;\n /**\n * If `true`, the component border is dashed.\n */\n dashed?: boolean;\n /**\n * Allowed file extensions (should start with `.`)\n */\n extensions?: string[];\n /**\n * Placeholder text\n */\n placeholder?: string;\n /**\n * Import/Upload progress\n */\n progress?: ImportProgress;\n /**\n * An error message to display below the input field.\n */\n error?: unknown;\n /**\n * A helper text to display below the input field when there are no errors.\n */\n helper?: string;\n /**\n * Remove rounded border and change styles\n */\n cellStyle?: boolean;\n /**\n * File dialog title\n */\n fileDialogTitle?: string;\n /**\n * If `true`, the file dialog window closes when clicking outside the modal area (default: `true`)\n */\n fileDialogCloseOnOutsideClick?: boolean;\n }>(),\n {\n label: undefined,\n extensions: undefined,\n fileDialogTitle: undefined,\n placeholder: undefined,\n progress: undefined,\n error: undefined,\n helper: undefined,\n cellStyle: false,\n fileDialogCloseOnOutsideClick: true,\n },\n);\n\nconst tryValue = <T extends ImportFileHandle>(\n v: T | undefined,\n cb: (v: T) => string | undefined,\n) => {\n if (!v) {\n return undefined;\n }\n\n try {\n return cb(v);\n } catch (err) {\n data.error = err instanceof Error ? err.message : String(err);\n return v;\n }\n};\n\nconst fileName = computed(() => tryValue(props.modelValue, getFileNameFromHandle));\n\nconst filePath = computed(() => tryValue(props.modelValue, getFilePathFromHandle));\n\nconst isUploading = computed(() => props.progress && !props.progress.done);\n\nconst isUploaded = computed(() => props.progress && props.progress.done);\n\nconst computedErrorMessage = computed(() => getErrorMessage(data.error, props.error));\n\nconst hasErrors = computed(() => typeof computedErrorMessage.value === \"string\");\n\nconst uploadStats = computed(() => {\n const { status, done } = props.progress ?? {};\n\n if (!status || !status.bytesTotal) {\n return \"\";\n }\n\n if (status.bytesProcessed && !done) {\n return prettyBytes(status.bytesProcessed, {}) + \" / \" + prettyBytes(status.bytesTotal, {});\n }\n\n return prettyBytes(status.bytesTotal, {});\n});\n\nconst progressStyle = computed(() => {\n const { progress } = props;\n\n if (!progress) {\n return {};\n }\n\n return {\n width: progress.done ? \"100%\" : Math.round((progress.status?.progress ?? 0) * 100) + \"%\",\n };\n});\n\nconst openFileDialog = () => {\n data.fileDialogOpen = true;\n};\n\nconst onImport = (v: ImportedFiles) => {\n if (v.files.length) {\n emit(\"update:modelValue\", v.files[0]);\n }\n};\n\nconst clear = () => emit(\"update:modelValue\", undefined);\n\nwatch(\n () => props.modelValue,\n () => (data.error = undefined),\n { immediate: true },\n);\n\nconst rootRef = ref();\n\nif (!props.cellStyle) {\n useLabelNotch(rootRef);\n}\n</script>\n\n<template>\n <div\n :class=\"{ 'pl-file-input__cell-style': !!cellStyle, 'has-file': !!fileName }\"\n class=\"pl-file-input__envelope\"\n >\n <div\n ref=\"rootRef\"\n :class=\"{ dashed, error: hasErrors }\"\n class=\"pl-file-input\"\n tabindex=\"0\"\n @keyup.enter=\"openFileDialog\"\n @click.stop=\"openFileDialog\"\n >\n <div :style=\"progressStyle\" class=\"pl-file-input__progress\" />\n <label v-if=\"!cellStyle && label\" ref=\"label\">\n <PlSvg v-if=\"required\" :uri=\"SvgRequired\" />\n <span>{{ label }}</span>\n <PlTooltip v-if=\"slots.tooltip || filePath\" class=\"info\" position=\"top\">\n <template #tooltip>\n <slot v-if=\"slots.tooltip\" name=\"tooltip\" />\n <template v-else>{{ filePath }}</template>\n </template>\n </PlTooltip>\n </label>\n <PlMaskIcon24 v-if=\"hasErrors\" name=\"restart\" />\n <PlMaskIcon24 v-else-if=\"isUploading\" name=\"cloud-upload\" />\n <PlMaskIcon24 v-else-if=\"isUploaded\" name=\"success\" />\n <PlMaskIcon24 v-else name=\"paper-clip\" />\n <div :data-placeholder=\"placeholder ?? 'Choose file'\" class=\"pl-file-input__filename\">\n {{ fileName }}\n </div>\n <div v-if=\"uploadStats\" class=\"pl-file-input__stats\">{{ uploadStats }}</div>\n <PlMaskIcon24\n v-if=\"modelValue\"\n class=\"pl-file-input__clear\"\n name=\"close\"\n @click.stop=\"clear\"\n />\n <DoubleContour class=\"pl-file-input__contour\" />\n </div>\n <div v-if=\"hasErrors\" class=\"pl-file-input__error\">\n {{ computedErrorMessage }}\n </div>\n <div v-else-if=\"helper\" class=\"pl-file-input__helper\">{{ helper }}</div>\n </div>\n <PlFileDialog\n v-model=\"data.fileDialogOpen\"\n :close-on-outside-click=\"fileDialogCloseOnOutsideClick\"\n :extensions=\"extensions\"\n :title=\"fileDialogTitle\"\n @import:files=\"onImport\"\n />\n</template>\n"],"mappings":"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"}
1
+ {"version":3,"file":"PlFileInput.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlFileInput/PlFileInput.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport \"./pl-file-input.scss\";\n\nimport { prettyBytes } from \"@milaboratories/helpers\";\nimport type { ImportFileHandle, ImportProgress } from \"@platforma-sdk/model\";\nimport { getFileNameFromHandle, getFilePathFromHandle } from \"@platforma-sdk/model\";\nimport { computed, reactive, ref, useSlots, watch } from \"vue\";\nimport { getErrorMessage } from \"../../helpers/error.ts\";\nimport type { ImportedFiles } from \"../../types\";\nimport DoubleContour from \"../../utils/DoubleContour.vue\";\nimport { useLabelNotch } from \"../../utils/useLabelNotch\";\nimport { PlFileDialog } from \"../PlFileDialog\";\nimport { PlMaskIcon24 } from \"../PlMaskIcon24\";\nimport { PlTooltip } from \"../PlTooltip\";\n\nimport SvgRequired from \"../../assets/images/required.svg?raw\";\nimport { PlSvg } from \"../PlSvg\";\n\nconst data = reactive({\n fileDialogOpen: false,\n error: undefined as undefined | string,\n});\n\nconst slots = useSlots();\n\nconst emit = defineEmits<{\n (e: \"update:modelValue\", value: ImportFileHandle | undefined): void;\n}>();\n\nconst props = withDefaults(\n defineProps<{\n /**\n * The current import file handle.\n */\n modelValue: ImportFileHandle | undefined;\n /**\n * The label to display above the input field.\n */\n label?: string;\n /**\n * If `true`, the input field is marked as required.\n */\n required?: boolean;\n /**\n * If `true`, the component border is dashed.\n */\n dashed?: boolean;\n /**\n * Allowed file extensions (should start with `.`)\n */\n extensions?: string[];\n /**\n * Placeholder text\n */\n placeholder?: string;\n /**\n * Import/Upload progress\n */\n progress?: ImportProgress;\n /**\n * An error message to display below the input field.\n */\n error?: unknown;\n /**\n * A helper text to display below the input field when there are no errors.\n */\n helper?: string;\n /**\n * Remove rounded border and change styles\n */\n cellStyle?: boolean;\n /**\n * File dialog title\n */\n fileDialogTitle?: string;\n /**\n * If `true`, the file dialog window closes when clicking outside the modal area (default: `true`)\n */\n fileDialogCloseOnOutsideClick?: boolean;\n }>(),\n {\n label: undefined,\n extensions: undefined,\n fileDialogTitle: undefined,\n placeholder: undefined,\n progress: undefined,\n error: undefined,\n helper: undefined,\n cellStyle: false,\n fileDialogCloseOnOutsideClick: true,\n },\n);\n\nconst tryValue = <T extends ImportFileHandle>(\n v: T | undefined,\n cb: (v: T) => string | undefined,\n) => {\n if (!v) {\n return undefined;\n }\n\n try {\n return cb(v);\n } catch (err) {\n data.error = err instanceof Error ? err.message : String(err);\n return v;\n }\n};\n\nconst fileName = computed(() => tryValue(props.modelValue, getFileNameFromHandle));\n\nconst filePath = computed(() => tryValue(props.modelValue, getFilePathFromHandle));\n\nconst isUploading = computed(() => props.progress && !props.progress.done);\n\nconst isUploaded = computed(() => props.progress && props.progress.done);\n\nconst computedErrorMessage = computed(() => getErrorMessage(data.error, props.error));\n\nconst hasErrors = computed(() => typeof computedErrorMessage.value === \"string\");\n\nconst uploadStats = computed(() => {\n const { status, done } = props.progress ?? {};\n\n if (!status || !status.bytesTotal) {\n return \"\";\n }\n\n if (status.bytesProcessed && !done) {\n return prettyBytes(status.bytesProcessed, {}) + \" / \" + prettyBytes(status.bytesTotal, {});\n }\n\n return prettyBytes(status.bytesTotal, {});\n});\n\nconst progressStyle = computed(() => {\n const { progress } = props;\n\n if (!progress) {\n return {};\n }\n\n return {\n width: progress.done ? \"100%\" : Math.round((progress.status?.progress ?? 0) * 100) + \"%\",\n };\n});\n\nconst openFileDialog = () => {\n data.fileDialogOpen = true;\n};\n\nconst onImport = (v: ImportedFiles) => {\n if (v.files.length) {\n emit(\"update:modelValue\", v.files[0]);\n }\n};\n\nconst clear = () => emit(\"update:modelValue\", undefined);\n\nwatch(\n () => props.modelValue,\n () => (data.error = undefined),\n { immediate: true },\n);\n\nconst rootRef = ref();\n\nif (!props.cellStyle) {\n useLabelNotch(rootRef);\n}\n</script>\n\n<template>\n <div\n :class=\"{ 'pl-file-input__cell-style': !!cellStyle, 'has-file': !!fileName }\"\n class=\"pl-file-input__envelope\"\n >\n <div\n ref=\"rootRef\"\n :class=\"{ dashed, error: hasErrors }\"\n class=\"pl-file-input\"\n tabindex=\"0\"\n @keyup.enter=\"openFileDialog\"\n @click.stop=\"openFileDialog\"\n >\n <div :style=\"progressStyle\" class=\"pl-file-input__progress\" />\n <label v-if=\"!cellStyle && label\" ref=\"label\">\n <PlSvg v-if=\"required\" :uri=\"SvgRequired\" />\n <span>{{ label }}</span>\n <PlTooltip v-if=\"slots.tooltip || filePath\" class=\"info\" position=\"top\">\n <template #tooltip>\n <slot v-if=\"slots.tooltip\" name=\"tooltip\" />\n <template v-else>{{ filePath }}</template>\n </template>\n </PlTooltip>\n </label>\n <PlMaskIcon24 v-if=\"hasErrors\" name=\"restart\" />\n <PlMaskIcon24 v-else-if=\"isUploading\" name=\"cloud-upload\" />\n <PlMaskIcon24 v-else-if=\"isUploaded\" name=\"success\" />\n <PlMaskIcon24 v-else name=\"paper-clip\" />\n <div :data-placeholder=\"placeholder ?? 'Choose file'\" class=\"pl-file-input__filename\">\n {{ fileName }}\n </div>\n <div v-if=\"uploadStats\" class=\"pl-file-input__stats\">{{ uploadStats }}</div>\n <PlMaskIcon24\n v-if=\"modelValue\"\n class=\"pl-file-input__clear\"\n name=\"close\"\n @click.stop=\"clear\"\n />\n <DoubleContour class=\"pl-file-input__contour\" />\n </div>\n <div v-if=\"hasErrors\" class=\"pl-file-input__error\">\n {{ computedErrorMessage }}\n </div>\n <div v-else-if=\"helper\" class=\"pl-file-input__helper\">{{ helper }}</div>\n </div>\n <PlFileDialog\n v-model=\"data.fileDialogOpen\"\n :close-on-outside-click=\"fileDialogCloseOnOutsideClick\"\n :extensions=\"extensions\"\n :title=\"fileDialogTitle\"\n @import:files=\"onImport\"\n />\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 "./PlIcon16.vue2.js";
3
3
  import n from "./PlIcon16.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=PlIcon16.js.map
@@ -1,4 +1,5 @@
1
1
  import './PlIcon16.vue.css';var e = { icon: "_icon_d0ctm_2" };
2
+ //#endregion
2
3
  export { e as default };
3
4
 
4
5
  //# sourceMappingURL=PlIcon16.style.js.map
@@ -1,6 +1,7 @@
1
1
  import e from "../PlSvg/PlSvg.js";
2
2
  import "../PlSvg/index.js";
3
3
  import { computed as t, createBlock as n, defineComponent as r, normalizeClass as i, openBlock as a, unref as o } from "vue";
4
+ //#region src/components/PlIcon16/PlIcon16.vue?vue&type=script&setup=true&lang.ts
4
5
  var s = /* @__PURE__ */ r({
5
6
  __name: "PlIcon16",
6
7
  props: {
@@ -41,6 +42,7 @@ var s = /* @__PURE__ */ r({
41
42
  ]));
42
43
  }
43
44
  });
45
+ //#endregion
44
46
  export { s as default };
45
47
 
46
48
  //# sourceMappingURL=PlIcon16.vue2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PlIcon16.vue_vue_type_script_setup_true_lang.js","names":["$style"],"sources":["../../../src/components/PlIcon16/PlIcon16.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport type { MaskIconName16, Size } from \"../../types\";\nimport { PlSvg } from \"../PlSvg\";\nimport { computed } from \"vue\";\n\nconst props = defineProps<{\n name: MaskIconName16;\n size?: number | string | Size;\n color?: string | string[];\n stroke?: string | string[];\n}>();\n\nconst size = computed(() => {\n if (typeof props.size === \"string\") {\n if (props.size === \"small\") return 12;\n if (props.size === \"medium\") return 16;\n if (props.size === \"large\") return 24;\n }\n return props.size ?? 16;\n});\n</script>\n\n<template>\n <PlSvg\n :name=\"`16_${props.name}`\"\n :class=\"[$style.icon, 'icon-16', 'mask-16', `icon-${props.name}`, `mask-${props.name}`]\"\n :width=\"size\"\n :height=\"size\"\n :color=\"props.color\"\n :stroke=\"props.stroke\"\n />\n</template>\n\n<style module>\n.icon {\n /* pass color to svg variable */\n --svg-fill-0: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-1: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-2: var(--icon-color, var(--mask-icon-bg-color));\n display: inline-block;\n}\n</style>\n"],"mappings":";;;;;;;;;;;;EAKA,IAAM,IAAQ,GAOR,IAAO,QAAe;AAC1B,OAAI,OAAO,EAAM,QAAS,UAAU;AAClC,QAAI,EAAM,SAAS,QAAS,QAAO;AACnC,QAAI,EAAM,SAAS,SAAU,QAAO;AACpC,QAAI,EAAM,SAAS,QAAS,QAAO;;AAErC,UAAO,EAAM,QAAQ;IACrB;yBAIA,EAOE,EAAA,EAAA,EAAA;GANC,MAAI,MAAQ,EAAM;GAClB,OAAK,EAAA;IAAGA,EAAAA,OAAO;IAAI;IAAA;IAAA,QAAgC,EAAM;IAAI,QAAY,EAAM;IAAI,CAAA;GACnF,OAAO,EAAA;GACP,QAAQ,EAAA;GACR,OAAO,EAAM;GACb,QAAQ,EAAM"}
1
+ {"version":3,"file":"PlIcon16.vue_vue_type_script_setup_true_lang.js","names":["$style"],"sources":["../../../src/components/PlIcon16/PlIcon16.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport type { MaskIconName16, Size } from \"../../types\";\nimport { PlSvg } from \"../PlSvg\";\nimport { computed } from \"vue\";\n\nconst props = defineProps<{\n name: MaskIconName16;\n size?: number | string | Size;\n color?: string | string[];\n stroke?: string | string[];\n}>();\n\nconst size = computed(() => {\n if (typeof props.size === \"string\") {\n if (props.size === \"small\") return 12;\n if (props.size === \"medium\") return 16;\n if (props.size === \"large\") return 24;\n }\n return props.size ?? 16;\n});\n</script>\n\n<template>\n <PlSvg\n :name=\"`16_${props.name}`\"\n :class=\"[$style.icon, 'icon-16', 'mask-16', `icon-${props.name}`, `mask-${props.name}`]\"\n :width=\"size\"\n :height=\"size\"\n :color=\"props.color\"\n :stroke=\"props.stroke\"\n />\n</template>\n\n<style module>\n.icon {\n /* pass color to svg variable */\n --svg-fill-0: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-1: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-2: var(--icon-color, var(--mask-icon-bg-color));\n display: inline-block;\n}\n</style>\n"],"mappings":";;;;;;;;;;;;;EAKA,IAAM,IAAQ,GAOR,IAAO,QAAe;AAC1B,OAAI,OAAO,EAAM,QAAS,UAAU;AAClC,QAAI,EAAM,SAAS,QAAS,QAAO;AACnC,QAAI,EAAM,SAAS,SAAU,QAAO;AACpC,QAAI,EAAM,SAAS,QAAS,QAAO;;AAErC,UAAO,EAAM,QAAQ;IACrB;yBAIA,EAOE,EAAA,EAAA,EAAA;GANC,MAAI,MAAQ,EAAM;GAClB,OAAK,EAAA;IAAGA,EAAAA,OAAO;IAAI;IAAA;IAAA,QAAgC,EAAM;IAAI,QAAY,EAAM;IAAI,CAAA;GACnF,OAAO,EAAA;GACP,QAAQ,EAAA;GACR,OAAO,EAAM;GACb,QAAQ,EAAM"}
@@ -2,6 +2,7 @@ import e from "../../_virtual/_plugin-vue_export-helper.js";
2
2
  import t from "./PlIcon24.vue2.js";
3
3
  import n from "./PlIcon24.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=PlIcon24.js.map
@@ -1,4 +1,5 @@
1
1
  import './PlIcon24.vue.css';var e = { icon: "_icon_6q2ws_2" };
2
+ //#endregion
2
3
  export { e as default };
3
4
 
4
5
  //# sourceMappingURL=PlIcon24.style.js.map
@@ -1,6 +1,7 @@
1
1
  import e from "../PlSvg/PlSvg.js";
2
2
  import "../PlSvg/index.js";
3
3
  import { computed as t, createBlock as n, defineComponent as r, normalizeClass as i, openBlock as a, unref as o } from "vue";
4
+ //#region src/components/PlIcon24/PlIcon24.vue?vue&type=script&setup=true&lang.ts
4
5
  var s = /* @__PURE__ */ r({
5
6
  __name: "PlIcon24",
6
7
  props: {
@@ -41,6 +42,7 @@ var s = /* @__PURE__ */ r({
41
42
  ]));
42
43
  }
43
44
  });
45
+ //#endregion
44
46
  export { s as default };
45
47
 
46
48
  //# sourceMappingURL=PlIcon24.vue2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PlIcon24.vue_vue_type_script_setup_true_lang.js","names":["$style"],"sources":["../../../src/components/PlIcon24/PlIcon24.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport type { MaskIconName24, Size } from \"../../types\";\nimport { PlSvg } from \"../PlSvg\";\nimport { computed } from \"vue\";\n\nconst props = defineProps<{\n name: MaskIconName24;\n size?: number | string | Size;\n color?: string | string[];\n stroke?: string | string[];\n}>();\n\nconst size = computed(() => {\n if (typeof props.size === \"string\") {\n if (props.size === \"small\") return 16;\n if (props.size === \"medium\") return 24;\n if (props.size === \"large\") return 32;\n }\n return props.size ?? 24;\n});\n</script>\n\n<template>\n <PlSvg\n :name=\"`24_${props.name}`\"\n :class=\"['icon-24', 'mask-24', `icon-${props.name}`, `mask-${props.name}`, $style.icon]\"\n :width=\"size\"\n :height=\"size\"\n :color=\"props.color\"\n :stroke=\"props.stroke\"\n />\n</template>\n\n<style module>\n.icon {\n /* pass color to svg variable */\n --svg-fill-0: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-1: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-2: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-3: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-4: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-5: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-6: var(--icon-color, var(--mask-icon-bg-color));\n --svg-stroke-0: var(--icon-color, var(--mask-icon-bg-color));\n --svg-stroke-1: var(--icon-color, var(--mask-icon-bg-color));\n --svg-stroke-2: var(--icon-color, var(--mask-icon-bg-color));\n --svg-stroke-3: var(--icon-color, var(--mask-icon-bg-color));\n --svg-stroke-4: var(--icon-color, var(--mask-icon-bg-color));\n --svg-stroke-5: var(--icon-color, var(--mask-icon-bg-color));\n --svg-stroke-6: var(--icon-color, var(--mask-icon-bg-color));\n display: inline-block;\n}\n</style>\n"],"mappings":";;;;;;;;;;;;EAKA,IAAM,IAAQ,GAOR,IAAO,QAAe;AAC1B,OAAI,OAAO,EAAM,QAAS,UAAU;AAClC,QAAI,EAAM,SAAS,QAAS,QAAO;AACnC,QAAI,EAAM,SAAS,SAAU,QAAO;AACpC,QAAI,EAAM,SAAS,QAAS,QAAO;;AAErC,UAAO,EAAM,QAAQ;IACrB;yBAIA,EAOE,EAAA,EAAA,EAAA;GANC,MAAI,MAAQ,EAAM;GAClB,OAAK,EAAA;IAAA;IAAA;IAAA,QAAiC,EAAM;IAAI,QAAY,EAAM;IAAQA,EAAAA,OAAO;IAAI,CAAA;GACrF,OAAO,EAAA;GACP,QAAQ,EAAA;GACR,OAAO,EAAM;GACb,QAAQ,EAAM"}
1
+ {"version":3,"file":"PlIcon24.vue_vue_type_script_setup_true_lang.js","names":["$style"],"sources":["../../../src/components/PlIcon24/PlIcon24.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport type { MaskIconName24, Size } from \"../../types\";\nimport { PlSvg } from \"../PlSvg\";\nimport { computed } from \"vue\";\n\nconst props = defineProps<{\n name: MaskIconName24;\n size?: number | string | Size;\n color?: string | string[];\n stroke?: string | string[];\n}>();\n\nconst size = computed(() => {\n if (typeof props.size === \"string\") {\n if (props.size === \"small\") return 16;\n if (props.size === \"medium\") return 24;\n if (props.size === \"large\") return 32;\n }\n return props.size ?? 24;\n});\n</script>\n\n<template>\n <PlSvg\n :name=\"`24_${props.name}`\"\n :class=\"['icon-24', 'mask-24', `icon-${props.name}`, `mask-${props.name}`, $style.icon]\"\n :width=\"size\"\n :height=\"size\"\n :color=\"props.color\"\n :stroke=\"props.stroke\"\n />\n</template>\n\n<style module>\n.icon {\n /* pass color to svg variable */\n --svg-fill-0: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-1: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-2: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-3: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-4: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-5: var(--icon-color, var(--mask-icon-bg-color));\n --svg-fill-6: var(--icon-color, var(--mask-icon-bg-color));\n --svg-stroke-0: var(--icon-color, var(--mask-icon-bg-color));\n --svg-stroke-1: var(--icon-color, var(--mask-icon-bg-color));\n --svg-stroke-2: var(--icon-color, var(--mask-icon-bg-color));\n --svg-stroke-3: var(--icon-color, var(--mask-icon-bg-color));\n --svg-stroke-4: var(--icon-color, var(--mask-icon-bg-color));\n --svg-stroke-5: var(--icon-color, var(--mask-icon-bg-color));\n --svg-stroke-6: var(--icon-color, var(--mask-icon-bg-color));\n display: inline-block;\n}\n</style>\n"],"mappings":";;;;;;;;;;;;;EAKA,IAAM,IAAQ,GAOR,IAAO,QAAe;AAC1B,OAAI,OAAO,EAAM,QAAS,UAAU;AAClC,QAAI,EAAM,SAAS,QAAS,QAAO;AACnC,QAAI,EAAM,SAAS,SAAU,QAAO;AACpC,QAAI,EAAM,SAAS,QAAS,QAAO;;AAErC,UAAO,EAAM,QAAQ;IACrB;yBAIA,EAOE,EAAA,EAAA,EAAA;GANC,MAAI,MAAQ,EAAM;GAClB,OAAK,EAAA;IAAA;IAAA;IAAA,QAAiC,EAAM;IAAI,QAAY,EAAM;IAAQA,EAAAA,OAAO;IAAI,CAAA;GACrF,OAAO,EAAA;GACP,QAAQ,EAAA;GACR,OAAO,EAAM;GACb,QAAQ,EAAM"}
@@ -1,5 +1,7 @@
1
1
  import e from "./PlLoaderCircular.vue2.js";
2
+ //#region src/components/PlLoaderCircular/PlLoaderCircular.vue
2
3
  var t = e;
4
+ //#endregion
3
5
  export { t as default };
4
6
 
5
7
  //# sourceMappingURL=PlLoaderCircular.js.map
@@ -1,5 +1,6 @@
1
1
  import './pl-loader-circular.css';/* empty css */
2
2
  import { createElementBlock as e, createElementVNode as t, defineComponent as n, normalizeStyle as r, openBlock as i } from "vue";
3
+ //#region src/components/PlLoaderCircular/PlLoaderCircular.vue?vue&type=script&setup=true&lang.ts
3
4
  var a = { class: "pl-loader-circular" }, o = {
4
5
  class: "pl-loader-circular__svg",
5
6
  viewBox: "25 25 50 50"
@@ -25,6 +26,7 @@ var a = { class: "pl-loader-circular" }, o = {
25
26
  }, null, 8, s)]))], 4)]));
26
27
  }
27
28
  });
29
+ //#endregion
28
30
  export { c as default };
29
31
 
30
32
  //# sourceMappingURL=PlLoaderCircular.vue2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PlLoaderCircular.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlLoaderCircular/PlLoaderCircular.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport \"./pl-loader-circular.scss\";\n\nwithDefaults(\n defineProps<{\n size?: \"16\" | \"24\" | \"48\" | string;\n }>(),\n { size: \"16\" },\n);\n</script>\n<template>\n <div class=\"pl-loader-circular\">\n <div\n :style=\"{\n height: `${size}px`,\n width: `${size}px`,\n '--main-color': `${+size < 48 ? 'var(--ic-01)' : 'var(--ic-02)'}`,\n }\"\n class=\"pl-circle-loader__wrapper\"\n >\n <svg class=\"pl-loader-circular__svg\" viewBox=\"25 25 50 50\">\n <circle\n class=\"pl-loader-circular__svg-circle\"\n cx=\"50\"\n cy=\"50\"\n r=\"20\"\n fill=\"none\"\n :stroke=\"`${+size < 48 ? 'var(--ic-01)' : 'var(--ic-02)'}`\"\n stroke-width=\"2\"\n />\n </svg>\n </div>\n </div>\n</template>\n"],"mappings":";;;;;;;;;yBAWE,EAqBM,OArBN,GAqBM,CApBJ,EAmBM,OAAA;GAlBH,OAAK,EAAA;eAAuB,EAAA,KAAI;cAAwB,EAAA,KAAI;wBAAkC,EAAA,OAAI,KAAA,iBAAA;;GAKnG,OAAM;YAEN,EAUM,OAVN,GAUM,CATJ,EAQE,UAAA;GAPA,OAAM;GACN,IAAG;GACH,IAAG;GACH,GAAE;GACF,MAAK;GACJ,QAAM,GAAA,CAAM,EAAA,OAAI,KAAA,iBAAA;GACjB,gBAAa"}
1
+ {"version":3,"file":"PlLoaderCircular.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlLoaderCircular/PlLoaderCircular.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport \"./pl-loader-circular.scss\";\n\nwithDefaults(\n defineProps<{\n size?: \"16\" | \"24\" | \"48\" | string;\n }>(),\n { size: \"16\" },\n);\n</script>\n<template>\n <div class=\"pl-loader-circular\">\n <div\n :style=\"{\n height: `${size}px`,\n width: `${size}px`,\n '--main-color': `${+size < 48 ? 'var(--ic-01)' : 'var(--ic-02)'}`,\n }\"\n class=\"pl-circle-loader__wrapper\"\n >\n <svg class=\"pl-loader-circular__svg\" viewBox=\"25 25 50 50\">\n <circle\n class=\"pl-loader-circular__svg-circle\"\n cx=\"50\"\n cy=\"50\"\n r=\"20\"\n fill=\"none\"\n :stroke=\"`${+size < 48 ? 'var(--ic-01)' : 'var(--ic-02)'}`\"\n stroke-width=\"2\"\n />\n </svg>\n </div>\n </div>\n</template>\n"],"mappings":";;;;;;;;;;yBAWE,EAqBM,OArBN,GAqBM,CApBJ,EAmBM,OAAA;GAlBH,OAAK,EAAA;eAAuB,EAAA,KAAI;cAAwB,EAAA,KAAI;wBAAkC,EAAA,OAAI,KAAA,iBAAA;;GAKnG,OAAM;YAEN,EAUM,OAVN,GAUM,CATJ,EAQE,UAAA;GAPA,OAAM;GACN,IAAG;GACH,IAAG;GACH,GAAE;GACF,MAAK;GACJ,QAAM,GAAA,CAAM,EAAA,OAAI,KAAA,iBAAA;GACjB,gBAAa"}
@@ -2,6 +2,7 @@ import e from "../_virtual/_plugin-vue_export-helper.js";
2
2
  import t from "./PlLoaderLogo.vue2.js";
3
3
  import n from "./PlLoaderLogo.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=PlLoaderLogo.js.map
@@ -2,6 +2,7 @@ import './PlLoaderLogo.vue.css';var e = {
2
2
  root: "_root_1hwch_2",
3
3
  flash: "_flash_1hwch_1"
4
4
  };
5
+ //#endregion
5
6
  export { e as default };
6
7
 
7
8
  //# sourceMappingURL=PlLoaderLogo.style.js.map
@@ -1,4 +1,5 @@
1
1
  import { computed as e, createElementBlock as t, createStaticVNode as n, defineComponent as r, normalizeClass as i, openBlock as a, unref as o, useCssModule as s, useCssVars as c } from "vue";
2
+ //#region src/components/PlLoaderLogo.vue?vue&type=script&setup=true&lang.ts
2
3
  var l = /* @__PURE__ */ r({
3
4
  __name: "PlLoaderLogo",
4
5
  props: {
@@ -20,6 +21,7 @@ var l = /* @__PURE__ */ r({
20
21
  }, [...r[0] ||= [n("<path d=\"m32 3 26 15H6z\"></path><path d=\"M32 18h26v28H32z\"></path><path d=\"M32 45.5h26L32 61z\"></path><path d=\"M6 39h26v22L6 46z\"></path><path d=\"M6 30h26v8H6z\"></path><path d=\"M6 18h26v12H6z\"></path><path d=\"M28.816 1.834c.788-.423 1.357-.671 1.947-.796a6 6 0 0 1 2.474 0c.59.125 1.159.373 1.947.796.578.295 1.26.685 2.141 1.189l17.411 9.956a67 67 0 0 1 1.88 1.098c.853.511 1.397.896 1.83 1.375a6 6 0 0 1 1.258 2.167c.296.907.296 1.922.296 3.951v20.858c0 2.029 0 3.043-.296 3.95a6 6 0 0 1-1.258 2.168c-.433.479-.977.864-1.83 1.376-.504.31-1.116.66-1.88 1.097l-17.41 9.956c-.882.504-1.563.893-2.14 1.188-.79.424-1.358.672-1.949.796a6 6 0 0 1-2.474 0c-.59-.124-1.16-.372-1.948-.796-.578-.295-1.259-.684-2.14-1.188l-17.41-9.956a69 69 0 0 1-1.88-1.097c-.853-.512-1.397-.897-1.831-1.376a6 6 0 0 1-1.258-2.167C4 45.47 4 44.457 4 42.428V21.57c0-2.03 0-3.044.296-3.95a6 6 0 0 1 1.258-2.168c.434-.479.977-.864 1.83-1.375a68 68 0 0 1 1.88-1.098l17.411-9.956c.882-.504 1.563-.894 2.14-1.19M8 27.997V19.99h21.964v8.006zm0 8.005v-4.003h21.964v4.003zM29.964 58.33 8 45.722v-5.718h21.964zm22.051-10.32L34.037 58.33V48.01zM56 19.99v24.016H34.037V19.99zm-44.016-4L32 4.499l20.016 11.49z\"></path>", 7)]], 2));
21
22
  }
22
23
  });
24
+ //#endregion
23
25
  export { l as default };
24
26
 
25
27
  //# sourceMappingURL=PlLoaderLogo.vue2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PlLoaderLogo.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../src/components/PlLoaderLogo.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, useCssModule } from \"vue\";\n\nconst props = defineProps<{\n size?: number | string;\n color?: string;\n backgroundColor?: string;\n}>();\n\nconst styles = useCssModule();\n\nconst size = computed(() =>\n typeof props.size === \"number\" ? CSS.px(props.size).toString() : props.size,\n);\n\nconst color = props.color ?? \"currentColor\";\nconst backgroundColor = props.backgroundColor ?? \"var(--color-div-bw)\";\n</script>\n\n<template>\n <svg viewBox=\"0 0 64 64\" xmlns=\"http://www.w3.org/2000/svg\" :class=\"styles.root\">\n <path d=\"m32 3 26 15H6z\" />\n <path d=\"M32 18h26v28H32z\" />\n <path d=\"M32 45.5h26L32 61z\" />\n <path d=\"M6 39h26v22L6 46z\" />\n <path d=\"M6 30h26v8H6z\" />\n <path d=\"M6 18h26v12H6z\" />\n <path\n d=\"M28.816 1.834c.788-.423 1.357-.671 1.947-.796a6 6 0 0 1 2.474 0c.59.125 1.159.373 1.947.796.578.295 1.26.685 2.141 1.189l17.411 9.956a67 67 0 0 1 1.88 1.098c.853.511 1.397.896 1.83 1.375a6 6 0 0 1 1.258 2.167c.296.907.296 1.922.296 3.951v20.858c0 2.029 0 3.043-.296 3.95a6 6 0 0 1-1.258 2.168c-.433.479-.977.864-1.83 1.376-.504.31-1.116.66-1.88 1.097l-17.41 9.956c-.882.504-1.563.893-2.14 1.188-.79.424-1.358.672-1.949.796a6 6 0 0 1-2.474 0c-.59-.124-1.16-.372-1.948-.796-.578-.295-1.259-.684-2.14-1.188l-17.41-9.956a69 69 0 0 1-1.88-1.097c-.853-.512-1.397-.897-1.831-1.376a6 6 0 0 1-1.258-2.167C4 45.47 4 44.457 4 42.428V21.57c0-2.03 0-3.044.296-3.95a6 6 0 0 1 1.258-2.168c.434-.479.977-.864 1.83-1.375a68 68 0 0 1 1.88-1.098l17.411-9.956c.882-.504 1.563-.894 2.14-1.19M8 27.997V19.99h21.964v8.006zm0 8.005v-4.003h21.964v4.003zM29.964 58.33 8 45.722v-5.718h21.964zm22.051-10.32L34.037 58.33V48.01zM56 19.99v24.016H34.037V19.99zm-44.016-4L32 4.499l20.016 11.49z\"\n />\n </svg>\n</template>\n\n<style module>\n.root {\n min-block-size: v-bind(size);\n max-block-size: v-bind(size);\n min-inline-size: v-bind(size);\n max-inline-size: v-bind(size);\n fill-rule: evenodd;\n path {\n &:not(:last-of-type) {\n fill: v-bind(backgroundColor);\n animation-duration: 1s;\n animation-delay: calc(1s / 6 * (sibling-index() - 1));\n animation-iteration-count: infinite;\n animation-name: flash;\n }\n &:last-of-type {\n fill: v-bind(color);\n }\n }\n}\n\n@keyframes flash {\n from {\n fill: v-bind(color);\n }\n}\n</style>\n"],"mappings":";;;;;;;;;;;;;;EAGA,IAAM,IAAQ,GAMR,IAAS,GAAc,EAEvB,IAAO,QACX,OAAO,EAAM,QAAS,WAAW,IAAI,GAAG,EAAM,KAAK,CAAC,UAAU,GAAG,EAAM,KACxE,EAEK,IAAQ,EAAM,SAAS,gBACvB,IAAkB,EAAM,mBAAmB;yBAI/C,EAUM,OAAA;GAVD,SAAQ;GAAY,OAAM;GAA8B,OAAK,EAAE,EAAA,EAAM,CAAC,KAAI"}
1
+ {"version":3,"file":"PlLoaderLogo.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../src/components/PlLoaderLogo.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, useCssModule } from \"vue\";\n\nconst props = defineProps<{\n size?: number | string;\n color?: string;\n backgroundColor?: string;\n}>();\n\nconst styles = useCssModule();\n\nconst size = computed(() =>\n typeof props.size === \"number\" ? CSS.px(props.size).toString() : props.size,\n);\n\nconst color = props.color ?? \"currentColor\";\nconst backgroundColor = props.backgroundColor ?? \"var(--color-div-bw)\";\n</script>\n\n<template>\n <svg viewBox=\"0 0 64 64\" xmlns=\"http://www.w3.org/2000/svg\" :class=\"styles.root\">\n <path d=\"m32 3 26 15H6z\" />\n <path d=\"M32 18h26v28H32z\" />\n <path d=\"M32 45.5h26L32 61z\" />\n <path d=\"M6 39h26v22L6 46z\" />\n <path d=\"M6 30h26v8H6z\" />\n <path d=\"M6 18h26v12H6z\" />\n <path\n d=\"M28.816 1.834c.788-.423 1.357-.671 1.947-.796a6 6 0 0 1 2.474 0c.59.125 1.159.373 1.947.796.578.295 1.26.685 2.141 1.189l17.411 9.956a67 67 0 0 1 1.88 1.098c.853.511 1.397.896 1.83 1.375a6 6 0 0 1 1.258 2.167c.296.907.296 1.922.296 3.951v20.858c0 2.029 0 3.043-.296 3.95a6 6 0 0 1-1.258 2.168c-.433.479-.977.864-1.83 1.376-.504.31-1.116.66-1.88 1.097l-17.41 9.956c-.882.504-1.563.893-2.14 1.188-.79.424-1.358.672-1.949.796a6 6 0 0 1-2.474 0c-.59-.124-1.16-.372-1.948-.796-.578-.295-1.259-.684-2.14-1.188l-17.41-9.956a69 69 0 0 1-1.88-1.097c-.853-.512-1.397-.897-1.831-1.376a6 6 0 0 1-1.258-2.167C4 45.47 4 44.457 4 42.428V21.57c0-2.03 0-3.044.296-3.95a6 6 0 0 1 1.258-2.168c.434-.479.977-.864 1.83-1.375a68 68 0 0 1 1.88-1.098l17.411-9.956c.882-.504 1.563-.894 2.14-1.19M8 27.997V19.99h21.964v8.006zm0 8.005v-4.003h21.964v4.003zM29.964 58.33 8 45.722v-5.718h21.964zm22.051-10.32L34.037 58.33V48.01zM56 19.99v24.016H34.037V19.99zm-44.016-4L32 4.499l20.016 11.49z\"\n />\n </svg>\n</template>\n\n<style module>\n.root {\n min-block-size: v-bind(size);\n max-block-size: v-bind(size);\n min-inline-size: v-bind(size);\n max-inline-size: v-bind(size);\n fill-rule: evenodd;\n path {\n &:not(:last-of-type) {\n fill: v-bind(backgroundColor);\n animation-duration: 1s;\n animation-delay: calc(1s / 6 * (sibling-index() - 1));\n animation-iteration-count: infinite;\n animation-name: flash;\n }\n &:last-of-type {\n fill: v-bind(color);\n }\n }\n}\n\n@keyframes flash {\n from {\n fill: v-bind(color);\n }\n}\n</style>\n"],"mappings":";;;;;;;;;;;;;;;EAGA,IAAM,IAAQ,GAMR,IAAS,GAAc,EAEvB,IAAO,QACX,OAAO,EAAM,QAAS,WAAW,IAAI,GAAG,EAAM,KAAK,CAAC,UAAU,GAAG,EAAM,KACxE,EAEK,IAAQ,EAAM,SAAS,gBACvB,IAAkB,EAAM,mBAAmB;yBAI/C,EAUM,OAAA;GAVD,SAAQ;GAAY,OAAM;GAA8B,OAAK,EAAE,EAAA,EAAM,CAAC,KAAI"}
@@ -1,5 +1,7 @@
1
1
  import e from "./PlLogView.vue2.js";
2
+ //#region src/components/PlLogView/PlLogView.vue
2
3
  var t = e;
4
+ //#endregion
3
5
  export { t as default };
4
6
 
5
7
  //# sourceMappingURL=PlLogView.js.map
@@ -10,6 +10,7 @@ import './pl-log-view.css';/* empty css */
10
10
  import { useLogHandle as a } from "./useLogHandle.js";
11
11
  import { computed as o, createBlock as s, createCommentVNode as c, createElementBlock as l, createElementVNode as u, createTextVNode as d, createVNode as f, defineComponent as p, normalizeClass as m, openBlock as h, ref as g, renderSlot as _, toDisplayString as v, unref as y, useSlots as b, watch as x, withCtx as S } from "vue";
12
12
  import { okOptional as C, tapIf as w } from "@milaboratories/helpers";
13
+ //#region src/components/PlLogView/PlLogView.vue?vue&type=script&setup=true&lang.ts
13
14
  var T = { key: 0 }, E = { class: "pl-log-view__copy" }, D = {
14
15
  key: 1,
15
16
  class: "pl-log-view__error"
@@ -106,6 +107,7 @@ var T = { key: 0 }, E = { class: "pl-log-view__copy" }, D = {
106
107
  ], 2));
107
108
  }
108
109
  });
110
+ //#endregion
109
111
  export { O as default };
110
112
 
111
113
  //# sourceMappingURL=PlLogView.vue2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PlLogView.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlLogView/PlLogView.vue"],"sourcesContent":["<script lang=\"ts\">\n/**\n * Log Viewer Component\n */\nexport default {\n name: \"PlLogView\",\n};\n</script>\n\n<script lang=\"ts\" setup>\nimport { computed, ref, useSlots, watch } from \"vue\";\nimport { PlMaskIcon24 } from \"../PlMaskIcon24\";\nimport \"./pl-log-view.scss\";\nimport { okOptional, tapIf } from \"@milaboratories/helpers\";\nimport type { AnyLogHandle, OutputWithStatus, Platforma } from \"@platforma-sdk/model\";\nimport { useLogHandle } from \"./useLogHandle\";\nimport { useLabelNotch } from \"../../utils/useLabelNotch\";\nimport DoubleContour from \"../../utils/DoubleContour.vue\";\nimport { PlTooltip } from \"../PlTooltip\";\nimport { PlIcon24 } from \"../PlIcon24\";\nimport { downloadContent } from \"../../helpers/dom\";\n\nconst getOutputError = <T,>(o?: OutputWithStatus<T>) => {\n if (o && o.ok === false) {\n return o.errors.join(\"\\n\");\n }\n};\n\nconst slots = useSlots();\n\nconst props = defineProps<{\n /**\n * String contents\n */\n value?: string;\n /**\n * The content to copy (Note: it takes precedence over value property)\n */\n valueToCopy?: string;\n /**\n * AnyLogHandle\n */\n logHandle?: AnyLogHandle;\n /**\n * Custom progress prefix (to filter logHandle results)\n */\n progressPrefix?: string;\n /**\n * String contents\n */\n error?: unknown;\n /**\n * Block output (Note: error and value take precedence over output property)\n */\n output?: OutputWithStatus<unknown>;\n /**\n * Max retries for AnyLogHandle fetch (with the same parameters)\n */\n maxRetries?: number;\n /**\n * @TODO\n */\n mockPlatforma?: Platforma;\n /**\n * The label to display above the texarea.\n */\n label?: string;\n /**\n * Do not scroll to bottom on content change. Default is false (scroll to bottom).\n */\n disableAutoScroll?: boolean;\n /**\n * If provided, a download icon will be shown and the content will be downloaded when clicked.\n */\n downloadFilename?: string;\n}>();\n\nconst logState = useLogHandle(props);\n\nconst isAnchored = ref<boolean>(true);\n\nconst contentRef = ref<HTMLElement>();\n\nconst root = ref<HTMLInputElement>();\n\nconst computedError = computed(\n () => logState.value?.error ?? props.error ?? getOutputError(props.output),\n);\n\nconst computedValue = computed(\n () => logState.value?.lines ?? props.value ?? okOptional(props.output),\n);\n\nconst computedValueToCopy = computed(() => {\n if (props.valueToCopy) {\n return props.valueToCopy;\n }\n if (computedValue.value && typeof computedValue.value === \"string\") {\n return computedValue.value;\n }\n return undefined;\n});\n\nconst copyActive = ref(false);\n\nuseLabelNotch(root);\n\nconst iconName = computed(() => (copyActive.value ? \"clipboard-copied\" : \"clipboard\"));\n\nconst onClickCopy = () => {\n copyActive.value = true;\n setTimeout(() => {\n copyActive.value = false;\n }, 1200);\n\n const toCopy = computedValueToCopy.value;\n\n if (toCopy !== undefined) {\n navigator.clipboard.writeText(toCopy);\n }\n};\n\nconst onClickDownload = (filename: string) => {\n const toDownload = computedValueToCopy.value;\n\n if (toDownload !== undefined) {\n downloadContent([toDownload, \"text/plain\"], filename);\n }\n};\n\nconst optionallyScrollDown = () => {\n if (props.disableAutoScroll) {\n return;\n }\n\n tapIf(contentRef.value, (el) => {\n if (isAnchored.value) {\n el.scrollTo(el.scrollLeft, el.scrollHeight);\n }\n });\n};\n\nwatch(\n computedValue,\n () => {\n requestAnimationFrame(() => {\n optionallyScrollDown();\n });\n },\n { immediate: true },\n);\n\nconst onContentScroll = (ev: Event) => {\n const el = ev.target as HTMLElement;\n isAnchored.value = el.scrollTop + 20 /* ~ 1 line height */ >= el.scrollHeight - el.offsetHeight;\n};\n</script>\n\n<template>\n <div ref=\"root\" class=\"pl-log-view\" :class=\"{ 'has-error': computedError }\">\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 <DoubleContour class=\"pl-log-view__contour\" />\n <div class=\"pl-log-view__copy\">\n <PlTooltip :close-delay=\"800\" position=\"top\">\n <PlMaskIcon24 title=\"Copy content\" :name=\"iconName\" @click=\"onClickCopy\" />\n <template #tooltip>{{ copyActive ? \"copied\" : \"copy\" }}</template>\n </PlTooltip>\n <PlTooltip v-if=\"downloadFilename\" :close-delay=\"800\" position=\"top\">\n <PlIcon24 name=\"download\" @click=\"() => onClickDownload(downloadFilename!)\" />\n <template #tooltip>download</template>\n </PlTooltip>\n </div>\n <div v-if=\"computedError\" class=\"pl-log-view__error\">{{ computedError }}</div>\n <div v-else ref=\"contentRef\" class=\"pl-log-view__content\" @scroll=\"onContentScroll\">\n {{ computedValue }}\n </div>\n </div>\n</template>\n"],"mappings":";;;;;;;;;;;;;;;;CAKE,MAAM;;;;;;;;;;;;;;;EAiBR,IAAM,KAAsB,MAA4B;AACtD,OAAI,KAAK,EAAE,OAAO,GAChB,QAAO,EAAE,OAAO,KAAK,KAAK;KAIxB,IAAQ,GAAU,EAElB,IAAQ,GA+CR,IAAW,EAAa,EAAM,EAE9B,IAAa,EAAa,GAAK,EAE/B,IAAa,GAAkB,EAE/B,IAAO,GAAuB,EAE9B,IAAgB,QACd,EAAS,OAAO,SAAS,EAAM,SAAS,EAAe,EAAM,OAAO,CAC3E,EAEK,IAAgB,QACd,EAAS,OAAO,SAAS,EAAM,SAAS,EAAW,EAAM,OAAO,CACvE,EAEK,IAAsB,QAAe;AACzC,OAAI,EAAM,YACR,QAAO,EAAM;AAEf,OAAI,EAAc,SAAS,OAAO,EAAc,SAAU,SACxD,QAAO,EAAc;IAGvB,EAEI,IAAa,EAAI,GAAM;AAE7B,IAAc,EAAK;EAEnB,IAAM,IAAW,QAAgB,EAAW,QAAQ,qBAAqB,YAAa,EAEhF,UAAoB;AAExB,GADA,EAAW,QAAQ,IACnB,iBAAiB;AACf,MAAW,QAAQ;MAClB,KAAK;GAER,IAAM,IAAS,EAAoB;AAEnC,GAAI,MAAW,KAAA,KACb,UAAU,UAAU,UAAU,EAAO;KAInC,KAAmB,MAAqB;GAC5C,IAAM,IAAa,EAAoB;AAEvC,GAAI,MAAe,KAAA,KACjB,EAAgB,CAAC,GAAY,aAAa,EAAE,EAAS;KAInD,UAA6B;AAC7B,KAAM,qBAIV,EAAM,EAAW,QAAQ,MAAO;AAC9B,IAAI,EAAW,SACb,EAAG,SAAS,EAAG,YAAY,EAAG,aAAa;KAE7C;;AAGJ,IACE,SACM;AACJ,+BAA4B;AAC1B,OAAsB;KACtB;KAEJ,EAAE,WAAW,IAAM,CACpB;EAED,IAAM,KAAmB,MAAc;GACrC,IAAM,IAAK,EAAG;AACd,KAAW,QAAQ,EAAG,YAAY,MAA4B,EAAG,eAAe,EAAG;;yBAKnF,EAwBM,OAAA;YAxBG;GAAJ,KAAI;GAAO,OAAK,EAAA,CAAC,eAAa,EAAA,aAAwB,EAAA,OAAa,CAAA,CAAA;;GACzD,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,EAA8C,GAAA,EAA/B,OAAM,wBAAsB,CAAA;GAC3C,EASM,OATN,GASM,CARJ,EAGY,EAAA,EAAA,EAAA;IAHA,eAAa;IAAK,UAAS;;IAE1B,SAAO,QAAqC,CAAA,EAAA,EAAjC,EAAA,QAAU,WAAA,OAAA,EAAA,EAAA,CAAA,CAAA;qBAD2C,CAA3E,EAA2E,EAAA,EAAA,EAAA;KAA7D,OAAM;KAAgB,MAAM,EAAA;KAAW,SAAO;;;OAG7C,EAAA,oBAAA,GAAA,EAAjB,EAGY,EAAA,EAAA,EAAA;;IAHwB,eAAa;IAAK,UAAS;;IAElD,SAAO,QAAS,CAAA,GAAA,AAAA,EAAA,OAAA,CAAA,EAAR,YAAQ,GAAA,CAAA,CAAA,CAAA;qBADmD,CAA9E,EAA8E,EAAA,EAAA,EAAA;KAApE,MAAK;KAAY,SAAK,AAAA,EAAA,aAAQ,EAAgB,EAAA,iBAAgB;;;;GAIjE,EAAA,SAAA,GAAA,EAAX,EAA8E,OAA9E,GAA8E,EAAtB,EAAA,MAAa,EAAA,EAAA,KAAA,GAAA,EACrE,EAEM,OAAA;;aAFU;IAAJ,KAAI;IAAa,OAAM;IAAwB,UAAQ;QAC9D,EAAA,MAAa,EAAA,IAAA"}
1
+ {"version":3,"file":"PlLogView.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/PlLogView/PlLogView.vue"],"sourcesContent":["<script lang=\"ts\">\n/**\n * Log Viewer Component\n */\nexport default {\n name: \"PlLogView\",\n};\n</script>\n\n<script lang=\"ts\" setup>\nimport { computed, ref, useSlots, watch } from \"vue\";\nimport { PlMaskIcon24 } from \"../PlMaskIcon24\";\nimport \"./pl-log-view.scss\";\nimport { okOptional, tapIf } from \"@milaboratories/helpers\";\nimport type { AnyLogHandle, OutputWithStatus, Platforma } from \"@platforma-sdk/model\";\nimport { useLogHandle } from \"./useLogHandle\";\nimport { useLabelNotch } from \"../../utils/useLabelNotch\";\nimport DoubleContour from \"../../utils/DoubleContour.vue\";\nimport { PlTooltip } from \"../PlTooltip\";\nimport { PlIcon24 } from \"../PlIcon24\";\nimport { downloadContent } from \"../../helpers/dom\";\n\nconst getOutputError = <T,>(o?: OutputWithStatus<T>) => {\n if (o && o.ok === false) {\n return o.errors.join(\"\\n\");\n }\n};\n\nconst slots = useSlots();\n\nconst props = defineProps<{\n /**\n * String contents\n */\n value?: string;\n /**\n * The content to copy (Note: it takes precedence over value property)\n */\n valueToCopy?: string;\n /**\n * AnyLogHandle\n */\n logHandle?: AnyLogHandle;\n /**\n * Custom progress prefix (to filter logHandle results)\n */\n progressPrefix?: string;\n /**\n * String contents\n */\n error?: unknown;\n /**\n * Block output (Note: error and value take precedence over output property)\n */\n output?: OutputWithStatus<unknown>;\n /**\n * Max retries for AnyLogHandle fetch (with the same parameters)\n */\n maxRetries?: number;\n /**\n * @TODO\n */\n mockPlatforma?: Platforma;\n /**\n * The label to display above the texarea.\n */\n label?: string;\n /**\n * Do not scroll to bottom on content change. Default is false (scroll to bottom).\n */\n disableAutoScroll?: boolean;\n /**\n * If provided, a download icon will be shown and the content will be downloaded when clicked.\n */\n downloadFilename?: string;\n}>();\n\nconst logState = useLogHandle(props);\n\nconst isAnchored = ref<boolean>(true);\n\nconst contentRef = ref<HTMLElement>();\n\nconst root = ref<HTMLInputElement>();\n\nconst computedError = computed(\n () => logState.value?.error ?? props.error ?? getOutputError(props.output),\n);\n\nconst computedValue = computed(\n () => logState.value?.lines ?? props.value ?? okOptional(props.output),\n);\n\nconst computedValueToCopy = computed(() => {\n if (props.valueToCopy) {\n return props.valueToCopy;\n }\n if (computedValue.value && typeof computedValue.value === \"string\") {\n return computedValue.value;\n }\n return undefined;\n});\n\nconst copyActive = ref(false);\n\nuseLabelNotch(root);\n\nconst iconName = computed(() => (copyActive.value ? \"clipboard-copied\" : \"clipboard\"));\n\nconst onClickCopy = () => {\n copyActive.value = true;\n setTimeout(() => {\n copyActive.value = false;\n }, 1200);\n\n const toCopy = computedValueToCopy.value;\n\n if (toCopy !== undefined) {\n navigator.clipboard.writeText(toCopy);\n }\n};\n\nconst onClickDownload = (filename: string) => {\n const toDownload = computedValueToCopy.value;\n\n if (toDownload !== undefined) {\n downloadContent([toDownload, \"text/plain\"], filename);\n }\n};\n\nconst optionallyScrollDown = () => {\n if (props.disableAutoScroll) {\n return;\n }\n\n tapIf(contentRef.value, (el) => {\n if (isAnchored.value) {\n el.scrollTo(el.scrollLeft, el.scrollHeight);\n }\n });\n};\n\nwatch(\n computedValue,\n () => {\n requestAnimationFrame(() => {\n optionallyScrollDown();\n });\n },\n { immediate: true },\n);\n\nconst onContentScroll = (ev: Event) => {\n const el = ev.target as HTMLElement;\n isAnchored.value = el.scrollTop + 20 /* ~ 1 line height */ >= el.scrollHeight - el.offsetHeight;\n};\n</script>\n\n<template>\n <div ref=\"root\" class=\"pl-log-view\" :class=\"{ 'has-error': computedError }\">\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 <DoubleContour class=\"pl-log-view__contour\" />\n <div class=\"pl-log-view__copy\">\n <PlTooltip :close-delay=\"800\" position=\"top\">\n <PlMaskIcon24 title=\"Copy content\" :name=\"iconName\" @click=\"onClickCopy\" />\n <template #tooltip>{{ copyActive ? \"copied\" : \"copy\" }}</template>\n </PlTooltip>\n <PlTooltip v-if=\"downloadFilename\" :close-delay=\"800\" position=\"top\">\n <PlIcon24 name=\"download\" @click=\"() => onClickDownload(downloadFilename!)\" />\n <template #tooltip>download</template>\n </PlTooltip>\n </div>\n <div v-if=\"computedError\" class=\"pl-log-view__error\">{{ computedError }}</div>\n <div v-else ref=\"contentRef\" class=\"pl-log-view__content\" @scroll=\"onContentScroll\">\n {{ computedValue }}\n </div>\n </div>\n</template>\n"],"mappings":";;;;;;;;;;;;;;;;;CAKE,MAAM;;;;;;;;;;;;;;;EAiBR,IAAM,KAAsB,MAA4B;AACtD,OAAI,KAAK,EAAE,OAAO,GAChB,QAAO,EAAE,OAAO,KAAK,KAAK;KAIxB,IAAQ,GAAU,EAElB,IAAQ,GA+CR,IAAW,EAAa,EAAM,EAE9B,IAAa,EAAa,GAAK,EAE/B,IAAa,GAAkB,EAE/B,IAAO,GAAuB,EAE9B,IAAgB,QACd,EAAS,OAAO,SAAS,EAAM,SAAS,EAAe,EAAM,OAAO,CAC3E,EAEK,IAAgB,QACd,EAAS,OAAO,SAAS,EAAM,SAAS,EAAW,EAAM,OAAO,CACvE,EAEK,IAAsB,QAAe;AACzC,OAAI,EAAM,YACR,QAAO,EAAM;AAEf,OAAI,EAAc,SAAS,OAAO,EAAc,SAAU,SACxD,QAAO,EAAc;IAGvB,EAEI,IAAa,EAAI,GAAM;AAE7B,IAAc,EAAK;EAEnB,IAAM,IAAW,QAAgB,EAAW,QAAQ,qBAAqB,YAAa,EAEhF,UAAoB;AAExB,GADA,EAAW,QAAQ,IACnB,iBAAiB;AACf,MAAW,QAAQ;MAClB,KAAK;GAER,IAAM,IAAS,EAAoB;AAEnC,GAAI,MAAW,KAAA,KACb,UAAU,UAAU,UAAU,EAAO;KAInC,KAAmB,MAAqB;GAC5C,IAAM,IAAa,EAAoB;AAEvC,GAAI,MAAe,KAAA,KACjB,EAAgB,CAAC,GAAY,aAAa,EAAE,EAAS;KAInD,UAA6B;AAC7B,KAAM,qBAIV,EAAM,EAAW,QAAQ,MAAO;AAC9B,IAAI,EAAW,SACb,EAAG,SAAS,EAAG,YAAY,EAAG,aAAa;KAE7C;;AAGJ,IACE,SACM;AACJ,+BAA4B;AAC1B,OAAsB;KACtB;KAEJ,EAAE,WAAW,IAAM,CACpB;EAED,IAAM,KAAmB,MAAc;GACrC,IAAM,IAAK,EAAG;AACd,KAAW,QAAQ,EAAG,YAAY,MAA4B,EAAG,eAAe,EAAG;;yBAKnF,EAwBM,OAAA;YAxBG;GAAJ,KAAI;GAAO,OAAK,EAAA,CAAC,eAAa,EAAA,aAAwB,EAAA,OAAa,CAAA,CAAA;;GACzD,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,EAA8C,GAAA,EAA/B,OAAM,wBAAsB,CAAA;GAC3C,EASM,OATN,GASM,CARJ,EAGY,EAAA,EAAA,EAAA;IAHA,eAAa;IAAK,UAAS;;IAE1B,SAAO,QAAqC,CAAA,EAAA,EAAjC,EAAA,QAAU,WAAA,OAAA,EAAA,EAAA,CAAA,CAAA;qBAD2C,CAA3E,EAA2E,EAAA,EAAA,EAAA;KAA7D,OAAM;KAAgB,MAAM,EAAA;KAAW,SAAO;;;OAG7C,EAAA,oBAAA,GAAA,EAAjB,EAGY,EAAA,EAAA,EAAA;;IAHwB,eAAa;IAAK,UAAS;;IAElD,SAAO,QAAS,CAAA,GAAA,AAAA,EAAA,OAAA,CAAA,EAAR,YAAQ,GAAA,CAAA,CAAA,CAAA;qBADmD,CAA9E,EAA8E,EAAA,EAAA,EAAA;KAApE,MAAK;KAAY,SAAK,AAAA,EAAA,aAAQ,EAAgB,EAAA,iBAAgB;;;;GAIjE,EAAA,SAAA,GAAA,EAAX,EAA8E,OAA9E,GAA8E,EAAtB,EAAA,MAAa,EAAA,EAAA,KAAA,GAAA,EACrE,EAEM,OAAA;;aAFU;IAAJ,KAAI;IAAa,OAAM;IAAwB,UAAQ;QAC9D,EAAA,MAAa,EAAA,IAAA"}
@@ -1,6 +1,7 @@
1
1
  import { reactive as e, ref as t, watch as n } from "vue";
2
2
  import { useTimeoutPoll as r, whenever as i } from "@vueuse/core";
3
3
  import { getRawPlatformaInstance as a } from "@platforma-sdk/model";
4
+ //#region src/components/PlLogView/useLogHandle.ts
4
5
  var o = "[==PROGRESS==]";
5
6
  function s(e) {
6
7
  return e.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
@@ -42,6 +43,7 @@ function c(c) {
42
43
  }, u.errorCount = 0, f.resume());
43
44
  }, { immediate: !0 }), l;
44
45
  }
46
+ //#endregion
45
47
  export { c as useLogHandle };
46
48
 
47
49
  //# sourceMappingURL=useLogHandle.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useLogHandle.js","names":[],"sources":["../../../src/components/PlLogView/useLogHandle.ts"],"sourcesContent":["import { reactive, type Reactive, ref, watch } from \"vue\";\nimport { useTimeoutPoll, whenever } from \"@vueuse/core\";\nimport { getRawPlatformaInstance, type AnyLogHandle, type Platforma } from \"@platforma-sdk/model\";\n\ntype LogState = {\n logHandle: AnyLogHandle;\n lines: string;\n lastOffset: number;\n finished: boolean;\n error: unknown;\n};\n\nconst ProgressPrefixDefault = \"[==PROGRESS==]\"; // @TODO ?\n\n// from here https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_expressions#escaping\nfunction escapeRegExp(str: string) {\n return str.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n}\n\nexport function useLogHandle(\n props: Reactive<{\n logHandle: AnyLogHandle | undefined;\n maxRetries?: number;\n mockPlatforma?: Platforma;\n progressPrefix?: string;\n }>,\n) {\n const logState = ref<LogState>();\n\n const data = reactive({\n errorCount: 0,\n });\n\n async function fetchLogs() {\n // making a snapshot of the ref\n let currentLogState: LogState | undefined = logState.value;\n\n if (currentLogState === undefined) return;\n\n const platforma = props.mockPlatforma ?? getRawPlatformaInstance();\n\n if (!platforma) {\n console.warn(\"Platforma API is not available\");\n return;\n }\n\n while (true) {\n const result = await platforma.logDriver.readText(\n currentLogState.logHandle,\n 100,\n currentLogState.lastOffset,\n );\n\n currentLogState.error = undefined;\n\n data.errorCount = 0;\n\n if (result.shouldUpdateHandle) return;\n\n // somebody changed target log while we were fetching log data\n // @TODO There may be a situation where the new descriptor points to the same file and we don't need to reread it\n if (currentLogState.logHandle !== logState.value?.logHandle) return;\n\n const progressPrefix = props.progressPrefix ?? ProgressPrefixDefault;\n\n const newLines = new TextDecoder()\n .decode(result.data)\n .replace(new RegExp(`${escapeRegExp(progressPrefix)}`, \"g\"), \"\");\n\n // We simply change it in a mutable way: if logHandle has been changed, it points to the new object\n currentLogState = Object.assign(currentLogState, {\n lines: currentLogState.lines + newLines,\n lastOffset: result.newOffset,\n finished: !result.live,\n });\n\n if (result.newOffset >= result.size) break;\n }\n }\n\n const fetchAndCatch = () =>\n fetchLogs().catch((err) => {\n if (logState.value) {\n data.errorCount++;\n if (data.errorCount > (props.maxRetries ?? 3)) {\n logState.value.error = err;\n } else {\n console.warn(\"skip error:\", err, \"retry...\");\n }\n }\n });\n\n // Only trigger after last fetch is done\n const timeoutPoll = useTimeoutPoll(fetchAndCatch, 1500, {\n immediate: false,\n immediateCallback: true,\n });\n\n whenever(\n () => logState?.value?.finished,\n () => timeoutPoll.pause(),\n );\n\n watch(\n () => props.logHandle,\n (lh) => {\n if (lh === undefined) {\n logState.value = undefined;\n timeoutPoll.pause();\n } else if (lh !== logState.value?.logHandle) {\n logState.value = {\n logHandle: lh,\n lastOffset: 0,\n lines: \"\",\n finished: false,\n error: undefined,\n };\n data.errorCount = 0;\n timeoutPoll.resume();\n }\n },\n { immediate: true },\n );\n\n return logState;\n}\n"],"mappings":";;;AAYA,IAAM,IAAwB;AAG9B,SAAS,EAAa,GAAa;AACjC,QAAO,EAAI,QAAQ,uBAAuB,OAAO;;AAGnD,SAAgB,EACd,GAMA;CACA,IAAM,IAAW,GAAe,EAE1B,IAAO,EAAS,EACpB,YAAY,GACb,CAAC;CAEF,eAAe,IAAY;EAEzB,IAAI,IAAwC,EAAS;AAErD,MAAI,MAAoB,KAAA,EAAW;EAEnC,IAAM,IAAY,EAAM,iBAAiB,GAAyB;AAElE,MAAI,CAAC,GAAW;AACd,WAAQ,KAAK,iCAAiC;AAC9C;;AAGF,WAAa;GACX,IAAM,IAAS,MAAM,EAAU,UAAU,SACvC,EAAgB,WAChB,KACA,EAAgB,WACjB;AAUD,OARA,EAAgB,QAAQ,KAAA,GAExB,EAAK,aAAa,GAEd,EAAO,sBAIP,EAAgB,cAAc,EAAS,OAAO,UAAW;GAE7D,IAAM,IAAiB,EAAM,kBAAkB,GAEzC,IAAW,IAAI,aAAa,CAC/B,OAAO,EAAO,KAAK,CACnB,QAAY,OAAO,GAAG,EAAa,EAAe,IAAI,IAAI,EAAE,GAAG;AASlE,OANA,IAAkB,OAAO,OAAO,GAAiB;IAC/C,OAAO,EAAgB,QAAQ;IAC/B,YAAY,EAAO;IACnB,UAAU,CAAC,EAAO;IACnB,CAAC,EAEE,EAAO,aAAa,EAAO,KAAM;;;CAiBzC,IAAM,IAAc,QAZlB,GAAW,CAAC,OAAO,MAAQ;AACzB,EAAI,EAAS,UACX,EAAK,cACD,EAAK,cAAc,EAAM,cAAc,KACzC,EAAS,MAAM,QAAQ,IAEvB,QAAQ,KAAK,eAAe,GAAK,WAAW;GAGhD,EAG8C,MAAM;EACtD,WAAW;EACX,mBAAmB;EACpB,CAAC;AA4BF,QA1BA,QACQ,GAAU,OAAO,gBACjB,EAAY,OAAO,CAC1B,EAED,QACQ,EAAM,YACX,MAAO;AACN,EAAI,MAAO,KAAA,KACT,EAAS,QAAQ,KAAA,GACjB,EAAY,OAAO,IACV,MAAO,EAAS,OAAO,cAChC,EAAS,QAAQ;GACf,WAAW;GACX,YAAY;GACZ,OAAO;GACP,UAAU;GACV,OAAO,KAAA;GACR,EACD,EAAK,aAAa,GAClB,EAAY,QAAQ;IAGxB,EAAE,WAAW,IAAM,CACpB,EAEM"}
1
+ {"version":3,"file":"useLogHandle.js","names":[],"sources":["../../../src/components/PlLogView/useLogHandle.ts"],"sourcesContent":["import { reactive, type Reactive, ref, watch } from \"vue\";\nimport { useTimeoutPoll, whenever } from \"@vueuse/core\";\nimport { getRawPlatformaInstance, type AnyLogHandle, type Platforma } from \"@platforma-sdk/model\";\n\ntype LogState = {\n logHandle: AnyLogHandle;\n lines: string;\n lastOffset: number;\n finished: boolean;\n error: unknown;\n};\n\nconst ProgressPrefixDefault = \"[==PROGRESS==]\"; // @TODO ?\n\n// from here https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_expressions#escaping\nfunction escapeRegExp(str: string) {\n return str.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n}\n\nexport function useLogHandle(\n props: Reactive<{\n logHandle: AnyLogHandle | undefined;\n maxRetries?: number;\n mockPlatforma?: Platforma;\n progressPrefix?: string;\n }>,\n) {\n const logState = ref<LogState>();\n\n const data = reactive({\n errorCount: 0,\n });\n\n async function fetchLogs() {\n // making a snapshot of the ref\n let currentLogState: LogState | undefined = logState.value;\n\n if (currentLogState === undefined) return;\n\n const platforma = props.mockPlatforma ?? getRawPlatformaInstance();\n\n if (!platforma) {\n console.warn(\"Platforma API is not available\");\n return;\n }\n\n while (true) {\n const result = await platforma.logDriver.readText(\n currentLogState.logHandle,\n 100,\n currentLogState.lastOffset,\n );\n\n currentLogState.error = undefined;\n\n data.errorCount = 0;\n\n if (result.shouldUpdateHandle) return;\n\n // somebody changed target log while we were fetching log data\n // @TODO There may be a situation where the new descriptor points to the same file and we don't need to reread it\n if (currentLogState.logHandle !== logState.value?.logHandle) return;\n\n const progressPrefix = props.progressPrefix ?? ProgressPrefixDefault;\n\n const newLines = new TextDecoder()\n .decode(result.data)\n .replace(new RegExp(`${escapeRegExp(progressPrefix)}`, \"g\"), \"\");\n\n // We simply change it in a mutable way: if logHandle has been changed, it points to the new object\n currentLogState = Object.assign(currentLogState, {\n lines: currentLogState.lines + newLines,\n lastOffset: result.newOffset,\n finished: !result.live,\n });\n\n if (result.newOffset >= result.size) break;\n }\n }\n\n const fetchAndCatch = () =>\n fetchLogs().catch((err) => {\n if (logState.value) {\n data.errorCount++;\n if (data.errorCount > (props.maxRetries ?? 3)) {\n logState.value.error = err;\n } else {\n console.warn(\"skip error:\", err, \"retry...\");\n }\n }\n });\n\n // Only trigger after last fetch is done\n const timeoutPoll = useTimeoutPoll(fetchAndCatch, 1500, {\n immediate: false,\n immediateCallback: true,\n });\n\n whenever(\n () => logState?.value?.finished,\n () => timeoutPoll.pause(),\n );\n\n watch(\n () => props.logHandle,\n (lh) => {\n if (lh === undefined) {\n logState.value = undefined;\n timeoutPoll.pause();\n } else if (lh !== logState.value?.logHandle) {\n logState.value = {\n logHandle: lh,\n lastOffset: 0,\n lines: \"\",\n finished: false,\n error: undefined,\n };\n data.errorCount = 0;\n timeoutPoll.resume();\n }\n },\n { immediate: true },\n );\n\n return logState;\n}\n"],"mappings":";;;;AAYA,IAAM,IAAwB;AAG9B,SAAS,EAAa,GAAa;AACjC,QAAO,EAAI,QAAQ,uBAAuB,OAAO;;AAGnD,SAAgB,EACd,GAMA;CACA,IAAM,IAAW,GAAe,EAE1B,IAAO,EAAS,EACpB,YAAY,GACb,CAAC;CAEF,eAAe,IAAY;EAEzB,IAAI,IAAwC,EAAS;AAErD,MAAI,MAAoB,KAAA,EAAW;EAEnC,IAAM,IAAY,EAAM,iBAAiB,GAAyB;AAElE,MAAI,CAAC,GAAW;AACd,WAAQ,KAAK,iCAAiC;AAC9C;;AAGF,WAAa;GACX,IAAM,IAAS,MAAM,EAAU,UAAU,SACvC,EAAgB,WAChB,KACA,EAAgB,WACjB;AAUD,OARA,EAAgB,QAAQ,KAAA,GAExB,EAAK,aAAa,GAEd,EAAO,sBAIP,EAAgB,cAAc,EAAS,OAAO,UAAW;GAE7D,IAAM,IAAiB,EAAM,kBAAkB,GAEzC,IAAW,IAAI,aAAa,CAC/B,OAAO,EAAO,KAAK,CACnB,QAAY,OAAO,GAAG,EAAa,EAAe,IAAI,IAAI,EAAE,GAAG;AASlE,OANA,IAAkB,OAAO,OAAO,GAAiB;IAC/C,OAAO,EAAgB,QAAQ;IAC/B,YAAY,EAAO;IACnB,UAAU,CAAC,EAAO;IACnB,CAAC,EAEE,EAAO,aAAa,EAAO,KAAM;;;CAiBzC,IAAM,IAAc,QAZlB,GAAW,CAAC,OAAO,MAAQ;AACzB,EAAI,EAAS,UACX,EAAK,cACD,EAAK,cAAc,EAAM,cAAc,KACzC,EAAS,MAAM,QAAQ,IAEvB,QAAQ,KAAK,eAAe,GAAK,WAAW;GAGhD,EAG8C,MAAM;EACtD,WAAW;EACX,mBAAmB;EACpB,CAAC;AA4BF,QA1BA,QACQ,GAAU,OAAO,gBACjB,EAAY,OAAO,CAC1B,EAED,QACQ,EAAM,YACX,MAAO;AACN,EAAI,MAAO,KAAA,KACT,EAAS,QAAQ,KAAA,GACjB,EAAY,OAAO,IACV,MAAO,EAAS,OAAO,cAChC,EAAS,QAAQ;GACf,WAAW;GACX,YAAY;GACZ,OAAO;GACP,UAAU;GACV,OAAO,KAAA;GACR,EACD,EAAK,aAAa,GAClB,EAAY,QAAQ;IAGxB,EAAE,WAAW,IAAM,CACpB,EAEM"}
@@ -1,5 +1,7 @@
1
1
  import e from "./PlNotificationAlert.vue2.js";
2
+ //#region src/components/PlNotificationAlert/PlNotificationAlert.vue
2
3
  var t = e;
4
+ //#endregion
3
5
  export { t as default };
4
6
 
5
7
  //# sourceMappingURL=PlNotificationAlert.js.map