@eturnity/eturnity_reusable_components 8.10.0 → 8.10.1

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 (405) hide show
  1. package/README.md +29 -29
  2. package/package.json +85 -84
  3. package/src/App.vue +30 -30
  4. package/src/Test.vue +64 -128
  5. package/src/assets/icons/arrow_down.svg +3 -3
  6. package/src/assets/icons/arrow_up_red.svg +3 -3
  7. package/src/assets/icons/black_spinner.svg +35 -35
  8. package/src/assets/icons/delete_icon.svg +11 -11
  9. package/src/assets/icons/delete_icon_gray.svg +11 -11
  10. package/src/assets/icons/drag_icon.svg +8 -8
  11. package/src/assets/icons/external_icon.svg +6 -6
  12. package/src/assets/icons/language_icon.svg +6 -6
  13. package/src/assets/icons/pdf_icon.svg +6 -6
  14. package/src/assets/icons/plus_button.svg +4 -4
  15. package/src/assets/icons/search_icon_black.svg +3 -3
  16. package/src/assets/icons/subposition_icon.svg +3 -3
  17. package/src/assets/icons/subposition_marker.svg +3 -3
  18. package/src/assets/icons/warning_icon.svg +3 -3
  19. package/src/assets/svgIcons/2d_active.svg +7 -7
  20. package/src/assets/svgIcons/2d_inactive.svg +8 -8
  21. package/src/assets/svgIcons/3d_active.svg +7 -7
  22. package/src/assets/svgIcons/3d_inactive.svg +8 -8
  23. package/src/assets/svgIcons/_readme.md +7 -7
  24. package/src/assets/svgIcons/accept.svg +5 -5
  25. package/src/assets/svgIcons/activate_panels_active.svg +22 -22
  26. package/src/assets/svgIcons/activate_panels_inactive.svg +20 -20
  27. package/src/assets/svgIcons/add_icon-1.svg +3 -3
  28. package/src/assets/svgIcons/add_icon.svg +4 -4
  29. package/src/assets/svgIcons/address_book.svg +3 -3
  30. package/src/assets/svgIcons/adjust_roof.svg +6 -6
  31. package/src/assets/svgIcons/after_sale_as_a_service.svg +6 -6
  32. package/src/assets/svgIcons/all_good.svg +3 -3
  33. package/src/assets/svgIcons/angle_active.svg +5 -5
  34. package/src/assets/svgIcons/angle_inactive.svg +4 -4
  35. package/src/assets/svgIcons/area_active.svg +11 -11
  36. package/src/assets/svgIcons/area_inactive.svg +26 -26
  37. package/src/assets/svgIcons/areas_tool.svg +14 -14
  38. package/src/assets/svgIcons/arrow_down.svg +3 -3
  39. package/src/assets/svgIcons/arrow_left.svg +4 -4
  40. package/src/assets/svgIcons/arrow_right.svg +4 -4
  41. package/src/assets/svgIcons/arrow_up.svg +3 -3
  42. package/src/assets/svgIcons/attachment.svg +3 -3
  43. package/src/assets/svgIcons/base_layer.svg +3 -3
  44. package/src/assets/svgIcons/battery.svg +3 -3
  45. package/src/assets/svgIcons/bell.svg +3 -3
  46. package/src/assets/svgIcons/bell_alt.svg +5 -5
  47. package/src/assets/svgIcons/bexio.svg +4 -4
  48. package/src/assets/svgIcons/bold.svg +3 -3
  49. package/src/assets/svgIcons/bom.svg +3 -3
  50. package/src/assets/svgIcons/bom_generation.svg +10 -10
  51. package/src/assets/svgIcons/bookmaker.svg +3 -3
  52. package/src/assets/svgIcons/bubble.svg +3 -3
  53. package/src/assets/svgIcons/bug.svg +5 -5
  54. package/src/assets/svgIcons/buildings.svg +55 -55
  55. package/src/assets/svgIcons/bullet_list.svg +8 -8
  56. package/src/assets/svgIcons/calendar.svg +7 -7
  57. package/src/assets/svgIcons/calendar_icon.svg +7 -7
  58. package/src/assets/svgIcons/call.svg +3 -3
  59. package/src/assets/svgIcons/camera.svg +3 -3
  60. package/src/assets/svgIcons/car.svg +3 -3
  61. package/src/assets/svgIcons/cart.svg +3 -3
  62. package/src/assets/svgIcons/charger_icon_white.svg +44 -44
  63. package/src/assets/svgIcons/checkbox.svg +3 -3
  64. package/src/assets/svgIcons/checkmark.svg +3 -3
  65. package/src/assets/svgIcons/checkmark_white.svg +4 -0
  66. package/src/assets/svgIcons/clear_formatting.svg +7 -7
  67. package/src/assets/svgIcons/clenergy.svg +3 -3
  68. package/src/assets/svgIcons/clickable_info.svg +4 -4
  69. package/src/assets/svgIcons/clickable_info_white.svg +5 -0
  70. package/src/assets/svgIcons/clip.svg +3 -3
  71. package/src/assets/svgIcons/clock.svg +17 -17
  72. package/src/assets/svgIcons/clock_full.svg +3 -3
  73. package/src/assets/svgIcons/{close_for_modals,_tool_tips.svg → close.svg} +4 -4
  74. package/src/assets/svgIcons/co_branding.svg +5 -5
  75. package/src/assets/svgIcons/collapse.svg +4 -4
  76. package/src/assets/svgIcons/collapse_all.svg +3 -3
  77. package/src/assets/svgIcons/collections.svg +3 -3
  78. package/src/assets/svgIcons/component_library.svg +7 -7
  79. package/src/assets/svgIcons/consumption_tariffs.svg +43 -43
  80. package/src/assets/svgIcons/context_menu-1.svg +6 -6
  81. package/src/assets/svgIcons/context_menu-2.svg +5 -5
  82. package/src/assets/svgIcons/context_menu.svg +5 -5
  83. package/src/assets/svgIcons/context_menu_tabs.svg +5 -5
  84. package/src/assets/svgIcons/cross.svg +4 -4
  85. package/src/assets/svgIcons/current_variant.svg +4 -4
  86. package/src/assets/svgIcons/dashboard.svg +3 -3
  87. package/src/assets/svgIcons/data_transfer.svg +3 -3
  88. package/src/assets/svgIcons/deadline.svg +4 -4
  89. package/src/assets/svgIcons/deal_flow.svg +5 -5
  90. package/src/assets/svgIcons/delete.svg +4 -4
  91. package/src/assets/svgIcons/delete_area_active.svg +16 -16
  92. package/src/assets/svgIcons/delete_area_inactive.svg +15 -15
  93. package/src/assets/svgIcons/direction_active-1.svg +12 -12
  94. package/src/assets/svgIcons/direction_active.svg +5 -5
  95. package/src/assets/svgIcons/direction_arrow.svg +4 -4
  96. package/src/assets/svgIcons/direction_inactive.svg +4 -4
  97. package/src/assets/svgIcons/dislike.svg +3 -3
  98. package/src/assets/svgIcons/distance_tool.svg +8 -8
  99. package/src/assets/svgIcons/distances_active.svg +9 -9
  100. package/src/assets/svgIcons/distances_inactive.svg +8 -8
  101. package/src/assets/svgIcons/distort_tool.svg +10 -10
  102. package/src/assets/svgIcons/distort_tool2.svg +16 -16
  103. package/src/assets/svgIcons/document.svg +3 -3
  104. package/src/assets/svgIcons/documents.svg +4 -4
  105. package/src/assets/svgIcons/downarrow.svg +3 -3
  106. package/src/assets/svgIcons/download.svg +4 -4
  107. package/src/assets/svgIcons/drag_icon.svg +8 -8
  108. package/src/assets/svgIcons/draggable_corner.svg +5 -5
  109. package/src/assets/svgIcons/draw_tool.svg +3 -3
  110. package/src/assets/svgIcons/duplicate-1.svg +8 -8
  111. package/src/assets/svgIcons/duplicate-2.svg +5 -5
  112. package/src/assets/svgIcons/duplicate.svg +4 -4
  113. package/src/assets/svgIcons/e-mobility_configurator.svg +6 -6
  114. package/src/assets/svgIcons/e_signature.svg +5 -5
  115. package/src/assets/svgIcons/edit_button.svg +3 -3
  116. package/src/assets/svgIcons/electricity_tariff.svg +3 -3
  117. package/src/assets/svgIcons/email.svg +3 -3
  118. package/src/assets/svgIcons/ems-1.svg +3 -3
  119. package/src/assets/svgIcons/ems.svg +3 -3
  120. package/src/assets/svgIcons/end_of_the_list.svg +5 -5
  121. package/src/assets/svgIcons/erase.svg +4 -4
  122. package/src/assets/svgIcons/erase_white.svg +4 -0
  123. package/src/assets/svgIcons/expand_all.svg +4 -4
  124. package/src/assets/svgIcons/export_document.svg +3 -3
  125. package/src/assets/svgIcons/external_icon.svg +5 -5
  126. package/src/assets/svgIcons/fav_icon.svg +4 -4
  127. package/src/assets/svgIcons/finance.svg +3 -3
  128. package/src/assets/svgIcons/financing_for_pv-1.svg +5 -5
  129. package/src/assets/svgIcons/financing_for_pv-2.svg +3 -3
  130. package/src/assets/svgIcons/financing_for_pv.svg +6 -6
  131. package/src/assets/svgIcons/finish-1.svg +4 -4
  132. package/src/assets/svgIcons/finish.svg +3 -3
  133. package/src/assets/svgIcons/flatten.svg +11 -11
  134. package/src/assets/svgIcons/flatten_roof.svg +20 -20
  135. package/src/assets/svgIcons/folder.svg +3 -3
  136. package/src/assets/svgIcons/free_technology.svg +5 -5
  137. package/src/assets/svgIcons/handle.svg +5 -5
  138. package/src/assets/svgIcons/heat_calc.svg +7 -7
  139. package/src/assets/svgIcons/height_equalize.svg +3 -3
  140. package/src/assets/svgIcons/height_snap.svg +3 -3
  141. package/src/assets/svgIcons/house.svg +3 -3
  142. package/src/assets/svgIcons/house_3d-1.svg +7 -7
  143. package/src/assets/svgIcons/house_3d.svg +7 -7
  144. package/src/assets/svgIcons/hybrid.svg +4 -4
  145. package/src/assets/svgIcons/inclination.svg +2 -2
  146. package/src/assets/svgIcons/info.svg +3 -3
  147. package/src/assets/svgIcons/initial_situation.svg +3 -3
  148. package/src/assets/svgIcons/integrations.svg +3 -3
  149. package/src/assets/svgIcons/intro-tour-1.svg +3 -3
  150. package/src/assets/svgIcons/intro-tour.svg +3 -3
  151. package/src/assets/svgIcons/inverter-1.svg +5 -5
  152. package/src/assets/svgIcons/inverter.svg +3 -3
  153. package/src/assets/svgIcons/italic.svg +3 -3
  154. package/src/assets/svgIcons/key.svg +3 -3
  155. package/src/assets/svgIcons/lake.svg +29 -29
  156. package/src/assets/svgIcons/layers_close.svg +4 -4
  157. package/src/assets/svgIcons/layers_open.svg +4 -4
  158. package/src/assets/svgIcons/lead_marketplace.svg +6 -6
  159. package/src/assets/svgIcons/lead_provider.svg +4 -4
  160. package/src/assets/svgIcons/length_2d.svg +2 -2
  161. package/src/assets/svgIcons/length_3d.svg +4 -4
  162. package/src/assets/svgIcons/length_calculator.svg +2 -2
  163. package/src/assets/svgIcons/length_in_2d_active.svg +12 -12
  164. package/src/assets/svgIcons/length_in_2d_inctive.svg +13 -13
  165. package/src/assets/svgIcons/light_bulb.svg +3 -3
  166. package/src/assets/svgIcons/like.svg +3 -3
  167. package/src/assets/svgIcons/line_graph.svg +3 -3
  168. package/src/assets/svgIcons/local_subsidies.svg +18 -18
  169. package/src/assets/svgIcons/location.svg +3 -3
  170. package/src/assets/svgIcons/lock.svg +3 -3
  171. package/src/assets/svgIcons/logout.svg +3 -3
  172. package/src/assets/svgIcons/loop.svg +3 -3
  173. package/src/assets/svgIcons/low-vegetation.svg +37 -37
  174. package/src/assets/svgIcons/lunch.svg +4 -4
  175. package/src/assets/svgIcons/magic_tool.svg +6 -6
  176. package/src/assets/svgIcons/map_icon.svg +5 -5
  177. package/src/assets/svgIcons/map_settings.svg +3 -3
  178. package/src/assets/svgIcons/margin_tool.svg +4 -4
  179. package/src/assets/svgIcons/meeting.svg +6 -6
  180. package/src/assets/svgIcons/module.svg +3 -3
  181. package/src/assets/svgIcons/move_copy.svg +4 -4
  182. package/src/assets/svgIcons/move_down.svg +3 -3
  183. package/src/assets/svgIcons/move_up.svg +3 -3
  184. package/src/assets/svgIcons/new_area_inactive.svg +11 -11
  185. package/src/assets/svgIcons/next.svg +4 -4
  186. package/src/assets/svgIcons/normal-tg.svg +30 -30
  187. package/src/assets/svgIcons/normal-vegetation.svg +53 -53
  188. package/src/assets/svgIcons/not_equal_to.svg +3 -3
  189. package/src/assets/svgIcons/numbered_list.svg +6 -6
  190. package/src/assets/svgIcons/obstacle_tool.svg +8 -8
  191. package/src/assets/svgIcons/obstacle_tool_origin.svg +3 -3
  192. package/src/assets/svgIcons/offset_tool.svg +8 -8
  193. package/src/assets/svgIcons/open-tg.svg +21 -21
  194. package/src/assets/svgIcons/optimizer.svg +3 -6
  195. package/src/assets/svgIcons/outline_tool.svg +11 -11
  196. package/src/assets/svgIcons/pan_tool.svg +12 -12
  197. package/src/assets/svgIcons/panels_tool.svg +8 -8
  198. package/src/assets/svgIcons/pen_tool.svg +4 -4
  199. package/src/assets/svgIcons/picker_tool.svg +4 -4
  200. package/src/assets/svgIcons/picture.svg +3 -3
  201. package/src/assets/svgIcons/pin.svg +5 -5
  202. package/src/assets/svgIcons/plus_button.svg +4 -4
  203. package/src/assets/svgIcons/presentation.svg +3 -3
  204. package/src/assets/svgIcons/previous.svg +4 -4
  205. package/src/assets/svgIcons/profile-1.svg +4 -4
  206. package/src/assets/svgIcons/profile.svg +4 -4
  207. package/src/assets/svgIcons/profitability.svg +3 -3
  208. package/src/assets/svgIcons/project_analysis.svg +4 -4
  209. package/src/assets/svgIcons/project_settings.svg +4 -4
  210. package/src/assets/svgIcons/protected-tg.svg +47 -47
  211. package/src/assets/svgIcons/pv.svg +3 -3
  212. package/src/assets/svgIcons/question_mark.svg +3 -0
  213. package/src/assets/svgIcons/question_mark_white.svg +4 -0
  214. package/src/assets/svgIcons/quotations.svg +6 -6
  215. package/src/assets/svgIcons/redo.svg +6 -6
  216. package/src/assets/svgIcons/reorder_string.svg +3 -0
  217. package/src/assets/svgIcons/resizer.svg +5 -5
  218. package/src/assets/svgIcons/roof_layer.svg +3 -3
  219. package/src/assets/svgIcons/rotate_tool.svg +3 -3
  220. package/src/assets/svgIcons/rotate_view.svg +5 -5
  221. package/src/assets/svgIcons/ruler_tool.svg +3 -3
  222. package/src/assets/svgIcons/run_simulation.svg +3 -3
  223. package/src/assets/svgIcons/save.svg +3 -3
  224. package/src/assets/svgIcons/scaling_tool.svg +8 -8
  225. package/src/assets/svgIcons/sea.svg +34 -34
  226. package/src/assets/svgIcons/search.svg +3 -3
  227. package/src/assets/svgIcons/security.svg +3 -3
  228. package/src/assets/svgIcons/settings.svg +3 -3
  229. package/src/assets/svgIcons/show_in_a_new_tab.svg +12 -12
  230. package/src/assets/svgIcons/smartphone.svg +4 -4
  231. package/src/assets/svgIcons/solar_calc.svg +13 -13
  232. package/src/assets/svgIcons/solarmarkt.svg +3 -3
  233. package/src/assets/svgIcons/sorting.svg +4 -4
  234. package/src/assets/svgIcons/split.svg +12 -12
  235. package/src/assets/svgIcons/star.svg +3 -3
  236. package/src/assets/svgIcons/start_of_the_list.svg +5 -5
  237. package/src/assets/svgIcons/strikethrough.svg +4 -4
  238. package/src/assets/svgIcons/string_design.svg +5 -5
  239. package/src/assets/svgIcons/string_directions.svg +10 -10
  240. package/src/assets/svgIcons/subscriptions.svg +3 -3
  241. package/src/assets/svgIcons/subsidies-1.svg +5 -5
  242. package/src/assets/svgIcons/subsidies-2.svg +3 -3
  243. package/src/assets/svgIcons/subsidies.svg +3 -3
  244. package/src/assets/svgIcons/subtract_icon.svg +3 -3
  245. package/src/assets/svgIcons/suitcase.svg +3 -3
  246. package/src/assets/svgIcons/summer.svg +3 -3
  247. package/src/assets/svgIcons/switch_polarity.svg +5 -0
  248. package/src/assets/svgIcons/template_icon_not_clickable.svg +6 -6
  249. package/src/assets/svgIcons/transfer.svg +4 -4
  250. package/src/assets/svgIcons/transparent_warning.svg +4 -0
  251. package/src/assets/svgIcons/trim_tool.svg +4 -4
  252. package/src/assets/svgIcons/truck.svg +3 -3
  253. package/src/assets/svgIcons/underlined.svg +3 -3
  254. package/src/assets/svgIcons/undo.svg +6 -6
  255. package/src/assets/svgIcons/uparrow.svg +3 -3
  256. package/src/assets/svgIcons/update.svg +3 -3
  257. package/src/assets/svgIcons/upload_avatar-1.svg +12 -12
  258. package/src/assets/svgIcons/upload_avatar.svg +5 -5
  259. package/src/assets/svgIcons/upload_image.svg +8 -8
  260. package/src/assets/svgIcons/upload_image_tool.svg +7 -7
  261. package/src/assets/svgIcons/variants.svg +6 -6
  262. package/src/assets/svgIcons/vertical_tool.svg +3 -3
  263. package/src/assets/svgIcons/virtual_storage.svg +4 -4
  264. package/src/assets/svgIcons/warning.svg +4 -4
  265. package/src/assets/svgIcons/warning_triangle.svg +3 -0
  266. package/src/assets/svgIcons/warning_triangle_white.svg +5 -0
  267. package/src/assets/svgIcons/way.svg +5 -5
  268. package/src/assets/svgIcons/wifi.svg +3 -3
  269. package/src/assets/svgIcons/winter.svg +3 -3
  270. package/src/assets/svgIcons/workflow_template.svg +11 -11
  271. package/src/assets/tests/__mocks__/iconCache.js +1 -1
  272. package/src/assets/tests/__mocks__/svgMock.js +1 -1
  273. package/src/assets/tests/helpers.js +12 -12
  274. package/src/assets/theme.js +46 -46
  275. package/src/components/addNewButton/AddNewButton.stories.js +17 -17
  276. package/src/components/addNewButton/addNewButton.spec.js +23 -23
  277. package/src/components/addNewButton/index.vue +66 -66
  278. package/src/components/banner/actionBanner/ActionBanner.stories.js +45 -45
  279. package/src/components/banner/actionBanner/actionBanner.spec.js +76 -76
  280. package/src/components/banner/actionBanner/index.vue +86 -86
  281. package/src/components/banner/banner/Banner.stories.js +64 -64
  282. package/src/components/banner/banner/banner.spec.js +149 -149
  283. package/src/components/banner/banner/index.vue +205 -205
  284. package/src/components/banner/infoBanner/InfoBanner.spec.js +70 -70
  285. package/src/components/banner/infoBanner/InfoBanner.stories.js +42 -42
  286. package/src/components/banner/infoBanner/index.vue +97 -97
  287. package/src/components/banner/notificationBanner/index.vue +131 -131
  288. package/src/components/buttons/buttonIcon/index.vue +172 -147
  289. package/src/components/buttons/closeButton/CloseButton.stories.js +25 -25
  290. package/src/components/buttons/closeButton/index.vue +62 -62
  291. package/src/components/buttons/mainButton/MainButton.stories.js +51 -51
  292. package/src/components/buttons/mainButton/index.vue +174 -174
  293. package/src/components/buttons/mainButton/mainButton.spec.js +35 -35
  294. package/src/components/card/Card.stories.js +79 -79
  295. package/src/components/card/card.spec.js +135 -135
  296. package/src/components/card/index.vue +116 -116
  297. package/src/components/collapsableInfoText/index.vue +127 -127
  298. package/src/components/deleteIcon/DeleteIcon.stories.js +29 -29
  299. package/src/components/deleteIcon/index.vue +78 -78
  300. package/src/components/draggableInputHandle/index.vue +46 -46
  301. package/src/components/dropdown/Dropdown.stories.js +53 -53
  302. package/src/components/dropdown/index.vue +138 -138
  303. package/src/components/errorMessage/index.vue +64 -64
  304. package/src/components/filter/filterSettings.vue +669 -669
  305. package/src/components/filter/index.vue +154 -154
  306. package/src/components/filter/parentDropdown.vue +91 -91
  307. package/src/components/icon/Icons.stories.js +31 -31
  308. package/src/components/icon/icon.spec.js +66 -66
  309. package/src/components/icon/iconCache.mjs +23 -23
  310. package/src/components/icon/iconCollection.vue +83 -83
  311. package/src/components/icon/index.vue +177 -177
  312. package/src/components/iconWrapper/index.vue +184 -184
  313. package/src/components/infoCard/InfoCard.stories.js +170 -170
  314. package/src/components/infoCard/defaultProps.js +7 -7
  315. package/src/components/infoCard/index.vue +152 -152
  316. package/src/components/infoCard/infoCard.spec.js +64 -64
  317. package/src/components/infoLabel/index.vue +63 -0
  318. package/src/components/infoText/constants.js +4 -4
  319. package/src/components/infoText/index.vue +641 -511
  320. package/src/components/infoText/infoText.spec.js +62 -62
  321. package/src/components/infoText/infoText.stories.js +48 -48
  322. package/src/components/infoText/placeholder.vue +225 -225
  323. package/src/components/inputs/checkbox/Checkbox.stories.js +63 -63
  324. package/src/components/inputs/checkbox/checkbox.spec.js +109 -109
  325. package/src/components/inputs/checkbox/index.vue +250 -241
  326. package/src/components/inputs/inputNumber/InputNumber.stories.js +150 -150
  327. package/src/components/inputs/inputNumber/index.vue +985 -985
  328. package/src/components/inputs/inputNumberQuestion/index.vue +218 -218
  329. package/src/components/inputs/inputText/InputText.stories.js +70 -70
  330. package/src/components/inputs/inputText/index.vue +457 -457
  331. package/src/components/inputs/inputText/inputText.spec.js +588 -588
  332. package/src/components/inputs/radioButton/RadioButton.stories.js +77 -77
  333. package/src/components/inputs/radioButton/defaultProps.js +31 -31
  334. package/src/components/inputs/radioButton/index.vue +336 -336
  335. package/src/components/inputs/radioButton/radioButton.spec.js +306 -306
  336. package/src/components/inputs/searchInput/SearchInput.stories.js +66 -66
  337. package/src/components/inputs/searchInput/defaultProps.js +12 -12
  338. package/src/components/inputs/searchInput/index.vue +165 -165
  339. package/src/components/inputs/searchInput/searchInput.spec.js +64 -64
  340. package/src/components/inputs/select/index.vue +968 -968
  341. package/src/components/inputs/select/option/index.vue +164 -164
  342. package/src/components/inputs/select/select.stories.js +58 -58
  343. package/src/components/inputs/slider/index.vue +126 -126
  344. package/src/components/inputs/switchField/index.vue +254 -254
  345. package/src/components/inputs/textAreaInput/TextAreaInput.stories.js +127 -127
  346. package/src/components/inputs/textAreaInput/index.vue +204 -204
  347. package/src/components/inputs/toggle/Toggle.stories.js +77 -77
  348. package/src/components/inputs/toggle/index.vue +322 -322
  349. package/src/components/inputs/toggle/toggle.spec.js +102 -102
  350. package/src/components/label/index.vue +98 -98
  351. package/src/components/markerItem/index.vue +95 -95
  352. package/src/components/modals/actionModal/index.vue +64 -64
  353. package/src/components/modals/infoModal/index.vue +52 -52
  354. package/src/components/modals/modal/index.vue +186 -185
  355. package/src/components/modals/modal/modal.stories.js +31 -31
  356. package/src/components/navigationTabs/index.vue +114 -114
  357. package/src/components/pageSubtitle/PageSubtitle.stories.js +59 -59
  358. package/src/components/pageSubtitle/index.vue +78 -78
  359. package/src/components/pageSubtitle/pageSubtitle.spec.js +46 -46
  360. package/src/components/pageTitle/PageTitle.stories.js +95 -95
  361. package/src/components/pageTitle/index.vue +91 -91
  362. package/src/components/pageTitle/pageTitle.spec.js +46 -46
  363. package/src/components/pagination/index.vue +148 -148
  364. package/src/components/panelRangeInfo/index.vue +196 -0
  365. package/src/components/progressBar/index.vue +125 -125
  366. package/src/components/projectMarker/index.vue +300 -300
  367. package/src/components/rangeSlider/Slider.vue +578 -578
  368. package/src/components/rangeSlider/index.vue +517 -517
  369. package/src/components/rangeSlider/utils/dom.js +49 -49
  370. package/src/components/rangeSlider/utils/fns.js +26 -26
  371. package/src/components/roundTabs/index.vue +107 -107
  372. package/src/components/selectedOptions/index.vue +471 -471
  373. package/src/components/selectedOptions/selectedOptions.spec.js +176 -176
  374. package/src/components/selectedOptions/selectedOptions.stories.js +155 -155
  375. package/src/components/sideMenu/index.vue +281 -281
  376. package/src/components/spinner/Spinner.stories.js +34 -34
  377. package/src/components/spinner/index.vue +96 -96
  378. package/src/components/spinner/spinner.spec.js +69 -69
  379. package/src/components/spinnerGif/index.vue +98 -98
  380. package/src/components/tableDropdown/index.vue +685 -685
  381. package/src/components/tables/mainTable/exampleNested.vue +328 -328
  382. package/src/components/tables/mainTable/index.vue +518 -518
  383. package/src/components/tables/viewTable/index.vue +195 -195
  384. package/src/components/tabsHeader/index.vue +95 -83
  385. package/src/components/threeDots/index.vue +413 -413
  386. package/src/components/videoThumbnail/index.vue +103 -103
  387. package/src/components/videoThumbnail/videoThumbnail.stories.js +33 -33
  388. package/src/helpers/currencyMapping.js +28 -28
  389. package/src/helpers/numberConverter.js +103 -103
  390. package/src/helpers/translateLang.js +128 -128
  391. package/src/main.js +7 -7
  392. package/src/mixins/inputValidations.js +97 -97
  393. package/src/router/dynamicRoutes.js +23 -23
  394. package/src/stories/Button.stories.js +48 -48
  395. package/src/stories/Button.vue +52 -52
  396. package/src/stories/Configure.mdx +364 -364
  397. package/src/stories/Header.stories.js +41 -41
  398. package/src/stories/Header.vue +59 -59
  399. package/src/stories/Page.stories.js +30 -30
  400. package/src/stories/Page.vue +83 -83
  401. package/src/stories/button.css +30 -30
  402. package/src/stories/header.css +32 -32
  403. package/src/stories/page.css +69 -69
  404. package/src/utils/index.js +12 -12
  405. package/src/components/stringDesign/DropdownMenu/index.vue +0 -1009
@@ -1,511 +1,641 @@
1
- <template>
2
- <PageContainer ref="container" :type="type">
3
- <div
4
- ref="icon"
5
- data-test-id="infoText_trigger"
6
- @click=";(isMobile || openTrigger === 'onClick') && toggleInfo()"
7
- @mouseenter="!isMobile && openTrigger === 'onHover' && showInfo()"
8
- @mouseleave="!isMobile && openTrigger === 'onHover' && hideInfo()"
9
- >
10
- <Dot
11
- v-if="type === 'dot'"
12
- :color="dotColor"
13
- data-test-id="infoText_dot"
14
- />
15
- <IconComponent
16
- v-else
17
- :color="iconColor || computedIconColor"
18
- :cursor="isDisabled ? 'not-allowed' : 'pointer'"
19
- :disabled="isDisabled"
20
- :name="iconName"
21
- :size="size"
22
- />
23
- </div>
24
- <Teleport v-if="isVisible" to="body">
25
- <TextWrapper :style="wrapperStyle">
26
- <TextOverlay
27
- ref="infoBox"
28
- :image="image"
29
- :style="boxStyle"
30
- :width="infoBoxWidth"
31
- >
32
- <OverlayImage
33
- v-if="image"
34
- ref="infoImage"
35
- alt="Info Image"
36
- :src="image"
37
- @load="onImageLoad"
38
- />
39
- <span ref="textContent" :style="textStyle">
40
- <slot>
41
- <span v-html="text"></span>
42
- </slot>
43
- </span>
44
- </TextOverlay>
45
- <Arrow :image="image" :style="arrowStyle" />
46
- </TextWrapper>
47
- </Teleport>
48
- </PageContainer>
49
- </template>
50
-
51
- <script>
52
- // import InfoText from "@eturnity/eturnity_reusable_components/src/components/infoText"
53
- //To use:
54
- // <info-text
55
- // text="Veritatis et quasi architecto beatae vitae"
56
- // size="20px"
57
- // openTrigger="onClick"
58
- // buttonType="error"
59
- // image="path/to/image.jpg"
60
- // />
61
- import { ref, onMounted, onUnmounted, watch, nextTick, computed } from 'vue'
62
- import IconComponent from '../icon'
63
- import styled from 'vue3-styled-components'
64
- import theme from '../../assets/theme.js'
65
-
66
- const TextOverlay = styled('div')`
67
- background-color: ${(props) =>
68
- props.image ? props.theme.colors.white : props.theme.colors.black};
69
- color: ${(props) =>
70
- props.image ? props.theme.colors.grey1 : props.theme.colors.white};
71
- font-size: ${(props) => (props.image ? '12px' : '13px')};
72
- border-radius: 4px;
73
- padding: 10px;
74
- word-wrap: break-word;
75
- overflow-wrap: break-word;
76
- white-space: normal;
77
- width: ${(props) => (props.width ? `${props.width}px` : '100%')};
78
- box-shadow: ${(props) =>
79
- props.image ? '0 2px 10px rgba(0, 0, 0, 0.1)' : 'none'};
80
-
81
- a {
82
- color: ${(props) => props.theme.colors.blue};
83
- }
84
-
85
- img + span {
86
- margin-top: 10px;
87
- display: block;
88
- }
89
- `
90
-
91
- const Arrow = styled('div')`
92
- position: absolute;
93
- width: 0;
94
- height: 0;
95
- border: 8px solid transparent;
96
- border-top-color: ${(props) =>
97
- props.image ? props.theme.colors.white : props.theme.colors.black};
98
- filter: ${(props) =>
99
- props.image ? 'drop-shadow(0 2px 2px rgba(0, 0, 0, 0.1))' : 'none'};
100
- `
101
-
102
- const PageContainer = styled('div')`
103
- display: ${(props) => (props.type === 'dot' ? 'unset' : 'inline-block')};
104
- position: relative;
105
- `
106
-
107
- const TextWrapper = styled('div')`
108
- z-index: 99999;
109
- position: absolute;
110
- `
111
-
112
- const OverlayImage = styled('img')`
113
- width: 100%;
114
- height: auto;
115
- `
116
-
117
- const Dot = styled('div')`
118
- width: 5px;
119
- height: 5px;
120
- background-color: ${(props) => props.color};
121
- border-radius: 50%;
122
- `
123
-
124
- export default {
125
- name: 'InfoText',
126
- components: {
127
- IconComponent,
128
- TextOverlay,
129
- Arrow,
130
- Dot,
131
- PageContainer,
132
- TextWrapper,
133
- OverlayImage,
134
- },
135
- props: {
136
- text: {
137
- required: false,
138
- default: '',
139
- type: String,
140
- },
141
- size: {
142
- type: String,
143
- default: '14px',
144
- },
145
- infoPosition: {
146
- required: false,
147
- default: 'bottom',
148
- type: String,
149
- },
150
- maxWidth: {
151
- default: '400px',
152
- type: String,
153
- },
154
- openTrigger: {
155
- type: String,
156
- default: 'onHover',
157
- validator: (value) => ['onHover', 'onClick'].includes(value),
158
- },
159
- buttonType: {
160
- type: String,
161
- default: 'regular',
162
- validator: (value) => ['regular', 'error'].includes(value),
163
- },
164
- image: {
165
- type: String,
166
- default: '',
167
- },
168
- iconName: {
169
- type: String,
170
- default: 'info',
171
- },
172
- iconColor: {
173
- type: String,
174
- default: null,
175
- required: false,
176
- },
177
- isDisabled: {
178
- type: Boolean,
179
- default: false,
180
- required: false,
181
- },
182
- dotColor: {
183
- type: String,
184
- required: false,
185
- default: theme.colors.blue2,
186
- },
187
- type: {
188
- type: String,
189
- required: false,
190
- default: 'info', // info, dot
191
- },
192
- },
193
- setup(props) {
194
- const isVisible = ref(false)
195
- const container = ref(null)
196
- const icon = ref(null)
197
- const infoBox = ref(null)
198
- const textContent = ref(null)
199
- const infoImage = ref(null)
200
- const infoBoxWidth = ref(0)
201
- const infoBoxHeight = ref(0)
202
- const boxStyle = ref({})
203
- const arrowStyle = ref({})
204
- const wrapperStyle = ref({})
205
- const isMobile = ref(window.innerWidth <= 768)
206
-
207
- const textStyle = computed(() => ({
208
- fontSize: props.image ? '12px' : '13px',
209
- color: props.image ? theme.colors.grey1 : theme.colors.white,
210
- textAlign: props.image ? 'right' : 'left',
211
- }))
212
-
213
- const calculatePosition = (width) => {
214
- if (!icon.value || !width) return {}
215
-
216
- const iconRect = icon.value.getBoundingClientRect()
217
- const windowHeight = window.innerHeight
218
- const windowWidth = window.innerWidth
219
-
220
- // Calculate available space in all directions
221
- const spaceBelow = windowHeight - iconRect.bottom - 10
222
- const spaceAbove = iconRect.top - 10
223
- const spaceRight = windowWidth - iconRect.right - 10
224
- const spaceLeft = iconRect.left - 10
225
-
226
- // Determine the best position based on available space
227
- const positions = [
228
- { position: 'bottom', space: spaceBelow },
229
- { position: 'top', space: spaceAbove },
230
- { position: 'right', space: spaceRight },
231
- { position: 'left', space: spaceLeft },
232
- ].sort((a, b) => b.space - a.space)
233
-
234
- const bestPosition = positions[0].position
235
-
236
- let top, left, arrowPosition
237
-
238
- switch (bestPosition) {
239
- case 'bottom':
240
- top = Math.round(iconRect.bottom + 10)
241
- left = Math.round(Math.min(iconRect.left, windowWidth - width - 10))
242
- arrowPosition = {
243
- left: `${Math.round(
244
- Math.min(
245
- Math.max(iconRect.left - left + iconRect.width / 2 - 8, 2),
246
- width - 18
247
- )
248
- )}px`,
249
- top: '-7px',
250
- bottom: 'auto',
251
- transform: 'rotate(180deg)',
252
- }
253
- break
254
-
255
- case 'top':
256
- top = Math.round(iconRect.top - infoBoxHeight.value - 10)
257
- left = Math.round(Math.min(iconRect.left, windowWidth - width - 10))
258
- arrowPosition = {
259
- left: `${Math.round(
260
- Math.min(
261
- Math.max(iconRect.left - left + iconRect.width / 2 - 8, 2),
262
- width - 18
263
- )
264
- )}px`,
265
- top: 'auto',
266
- bottom: '-7px',
267
- transform: 'none',
268
- }
269
- break
270
-
271
- case 'right':
272
- top = Math.round(
273
- Math.max(
274
- Math.min(
275
- iconRect.top - (infoBoxHeight.value - iconRect.height) / 2,
276
- windowHeight - infoBoxHeight.value - 10
277
- ),
278
- 10
279
- )
280
- )
281
- left = Math.round(iconRect.right + 10)
282
- arrowPosition = {
283
- left: '-7px',
284
- top: `${Math.round(
285
- Math.min(
286
- Math.max(iconRect.top - top + iconRect.height / 2 - 8, 2),
287
- infoBoxHeight.value - 18
288
- )
289
- )}px`,
290
- bottom: 'auto',
291
- transform: 'rotate(90deg)',
292
- }
293
- break
294
-
295
- case 'left':
296
- top = Math.round(
297
- Math.max(
298
- Math.min(
299
- iconRect.top - (infoBoxHeight.value - iconRect.height) / 2,
300
- windowHeight - infoBoxHeight.value - 10
301
- ),
302
- 10
303
- )
304
- )
305
- left = Math.round(iconRect.left - width - 10)
306
- arrowPosition = {
307
- left: 'auto',
308
- right: '-7px',
309
- top: `${Math.round(
310
- Math.min(
311
- Math.max(iconRect.top - top + iconRect.height / 2 - 8, 2),
312
- infoBoxHeight.value - 18
313
- )
314
- )}px`,
315
- bottom: 'auto',
316
- transform: 'rotate(-90deg)',
317
- }
318
- break
319
- }
320
-
321
- // Set arrow styles
322
- arrowStyle.value = arrowPosition
323
-
324
- // Set wrapper styles
325
- wrapperStyle.value = {
326
- position: 'fixed',
327
- top: `${top}px`,
328
- left: `${left}px`,
329
- transform: 'none',
330
- width: `${width}px`,
331
- }
332
-
333
- return {
334
- width: '100%',
335
- maxWidth: props.maxWidth,
336
- overflowY: 'auto',
337
- backgroundColor: props.image
338
- ? theme.colors.white
339
- : theme.colors.black,
340
- }
341
- }
342
-
343
- const showInfo = async () => {
344
- isVisible.value = true
345
- // Wait for two render cycles to ensure content is stable
346
- await nextTick()
347
- await nextTick()
348
- await updatePosition()
349
- }
350
-
351
- const hideInfo = () => {
352
- isVisible.value = false
353
- infoBoxWidth.value = 0 // Reset width when hiding
354
- }
355
-
356
- const toggleInfo = () => {
357
- isVisible.value ? hideInfo() : showInfo()
358
- }
359
-
360
- const handleScroll = () => {
361
- if (isVisible.value) {
362
- hideInfo()
363
- }
364
- updatePosition()
365
- }
366
-
367
- const isIconInView = () => {
368
- if (!icon.value) return false
369
- const rect = icon.value.getBoundingClientRect()
370
- return (
371
- rect.top >= 0 &&
372
- rect.left >= 0 &&
373
- rect.bottom <=
374
- (window.innerHeight || document.documentElement.clientHeight) &&
375
- rect.right <=
376
- (window.innerWidth || document.documentElement.clientWidth)
377
- )
378
- }
379
-
380
- const updatePosition = async () => {
381
- if (!infoBox.value || !textContent.value) return
382
-
383
- // First make the content visible but hidden to get accurate measurements
384
- if (infoBox.value.$el) {
385
- infoBox.value.$el.style.visibility = 'hidden'
386
- infoBox.value.$el.style.display = 'block'
387
- }
388
-
389
- await nextTick()
390
-
391
- if (!isIconInView()) {
392
- if (isVisible.value) hideInfo()
393
- return
394
- }
395
-
396
- // Create a temporary clone to measure true width
397
- const clone = textContent.value.cloneNode(true)
398
- clone.style.position = 'absolute'
399
- clone.style.visibility = 'hidden'
400
- clone.style.width = 'auto'
401
- clone.style.maxWidth = 'none'
402
- clone.style.whiteSpace = 'nowrap' // Prevent text wrapping during measurement
403
- document.body.appendChild(clone)
404
-
405
- // Get fresh content width from clone
406
- const contentWidth = clone.offsetWidth
407
- document.body.removeChild(clone)
408
-
409
- // Calculate new width
410
- const calculatedWidth = Math.min(
411
- Math.max(contentWidth, 200),
412
- parseInt(props.maxWidth, 10)
413
- )
414
-
415
- // Set new dimensions
416
- infoBoxWidth.value = calculatedWidth
417
-
418
- // Wait for width to be applied
419
- await nextTick()
420
-
421
- infoBoxHeight.value = infoBox.value.$el.offsetHeight
422
-
423
- // Calculate and apply position
424
- boxStyle.value = calculatePosition(calculatedWidth)
425
-
426
- // Make visible after position is set
427
- if (isVisible.value && infoBox.value.$el) {
428
- infoBox.value.$el.style.visibility = 'visible'
429
- }
430
- }
431
-
432
- const onImageLoad = () => {
433
- if (infoImage.value) {
434
- infoBoxHeight.value = infoBox.value.$el.offsetHeight
435
- updatePosition()
436
- }
437
- }
438
-
439
- const handleClickOutside = (event) => {
440
- if (
441
- (props.openTrigger === 'onClick' || isMobile.value) &&
442
- isVisible.value
443
- ) {
444
- const clickedElement = event.target
445
- if (
446
- infoBox.value &&
447
- !infoBox.value.$el.contains(clickedElement) &&
448
- !icon.value.contains(clickedElement)
449
- ) {
450
- hideInfo()
451
- }
452
- }
453
- }
454
-
455
- const handleResize = () => {
456
- isMobile.value = window.innerWidth <= 768
457
- updatePosition()
458
- }
459
-
460
- onMounted(() => {
461
- window.addEventListener('scroll', handleScroll, { passive: true })
462
- window.addEventListener('resize', handleResize)
463
- document.addEventListener('scroll', handleScroll, {
464
- passive: true,
465
- capture: true,
466
- })
467
- document.addEventListener('click', handleClickOutside)
468
- })
469
-
470
- onUnmounted(() => {
471
- window.removeEventListener('scroll', handleScroll)
472
- window.removeEventListener('resize', handleResize)
473
- document.removeEventListener('scroll', handleScroll, { capture: true })
474
- document.removeEventListener('click', handleClickOutside)
475
- })
476
-
477
- watch(isVisible, (newValue) => {
478
- if (newValue) {
479
- updatePosition()
480
- }
481
- })
482
-
483
- return {
484
- isVisible,
485
- boxStyle,
486
- arrowStyle,
487
- showInfo,
488
- hideInfo,
489
- toggleInfo,
490
- container,
491
- icon,
492
- infoBox,
493
- textContent,
494
- infoImage,
495
- infoBoxWidth,
496
- infoBoxHeight,
497
- wrapperStyle,
498
- textStyle,
499
- onImageLoad,
500
- isMobile,
501
- }
502
- },
503
- computed: {
504
- computedIconColor() {
505
- return this.buttonType === 'error'
506
- ? theme.colors.red
507
- : theme.colors.mediumGray
508
- },
509
- },
510
- }
511
- </script>
1
+ <template>
2
+ <PageContainer
3
+ ref="container"
4
+ :type="type"
5
+ @click=";(isMobile || openTrigger === 'onClick') && toggleInfo()"
6
+ @mouseenter="!isMobile && openTrigger === 'onHover' && showInfo()"
7
+ @mouseleave="!isMobile && openTrigger === 'onHover' && hideInfo()"
8
+ >
9
+ <div ref="icon" data-test-id="infoText_trigger">
10
+ <IconWrapper
11
+ :background-color="backgroundColor"
12
+ :border-radius="borderRadius"
13
+ :hovered-icon="hoveredIcon"
14
+ :is-active="isActive"
15
+ :is-disabled="isDisabled"
16
+ :padding="padding"
17
+ >
18
+ <LabelWrapper
19
+ v-if="labelText && labelAlign === 'left'"
20
+ :color="iconColor || computedIconColor"
21
+ :size="labelSize"
22
+ >
23
+ {{ labelText }}
24
+ </LabelWrapper>
25
+ <Dot
26
+ v-if="type === 'dot'"
27
+ :color="dotColor"
28
+ data-test-id="infoText_dot"
29
+ />
30
+ <IconComponent
31
+ v-else-if="!noIcon"
32
+ :color="iconColor || computedIconColor"
33
+ :cursor="isDisabled ? 'not-allowed' : 'pointer'"
34
+ :disabled="isDisabled"
35
+ :name="iconName"
36
+ :size="size"
37
+ />
38
+ <LabelWrapper
39
+ v-if="labelText && labelAlign === 'right'"
40
+ :color="iconColor || computedIconColor"
41
+ :size="labelSize"
42
+ >
43
+ {{ labelText }}
44
+ </LabelWrapper>
45
+ </IconWrapper>
46
+ </div>
47
+ <Teleport v-if="isVisible" to="body">
48
+ <TextWrapper :style="wrapperStyle">
49
+ <TextOverlay
50
+ ref="infoBox"
51
+ :image="image"
52
+ :style="boxStyle"
53
+ :width="infoBoxWidth"
54
+ >
55
+ <OverlayImage
56
+ v-if="image"
57
+ ref="infoImage"
58
+ alt="Info Image"
59
+ :src="image"
60
+ @load="onImageLoad"
61
+ />
62
+ <span v-if="!hideInfoText" ref="textContent" :style="textStyle">
63
+ <slot>
64
+ <span v-html="text"></span>
65
+ </slot>
66
+ </span>
67
+ </TextOverlay>
68
+ <!-- <Arrow :image="image" :style="arrowStyle" /> -->
69
+ </TextWrapper>
70
+ </Teleport>
71
+ </PageContainer>
72
+ </template>
73
+
74
+ <script>
75
+ // import InfoText from "@eturnity/eturnity_reusable_components/src/components/infoText"
76
+ //To use:
77
+ // <info-text
78
+ // text="Veritatis et quasi architecto beatae vitae"
79
+ // size="20px"
80
+ // openTrigger="onClick"
81
+ // buttonType="error"
82
+ // image="path/to/image.jpg"
83
+ // />
84
+ import { ref, onMounted, onUnmounted, watch, nextTick, computed } from 'vue'
85
+ import IconComponent from '../icon'
86
+ import styled from 'vue3-styled-components'
87
+ import theme from '../../assets/theme.js'
88
+
89
+ const TextOverlayAttrs = {
90
+ appTheme: String,
91
+ image: Boolean,
92
+ width: Number,
93
+ }
94
+ const TextOverlay = styled('div', TextOverlayAttrs)`
95
+ background-color: ${(props) =>
96
+ props.image ? props.theme.colors.white : props.theme.colors.black};
97
+ color: ${(props) =>
98
+ props.image ? props.theme.colors.grey1 : props.theme.colors.white};
99
+ font-size: ${(props) => (props.image ? '12px' : '13px')};
100
+ border-radius: 4px;
101
+ padding: 10px;
102
+ word-wrap: break-word;
103
+ overflow-wrap: break-word;
104
+ white-space: normal;
105
+ width: ${(props) => (props.width ? `${props.width}px` : '100%')};
106
+ box-shadow: ${(props) =>
107
+ props.image ? '0 2px 10px rgba(0, 0, 0, 0.1)' : 'none'};
108
+
109
+ a {
110
+ color: ${(props) => props.theme.colors.blue};
111
+ }
112
+
113
+ img + span {
114
+ margin-top: 10px;
115
+ display: block;
116
+ }
117
+ `
118
+
119
+ // const Arrow = styled('div')`
120
+ // position: absolute;
121
+ // width: 0;
122
+ // height: 0;
123
+ // border: 8px solid transparent;
124
+ // border-top-color: ${(props) =>
125
+ // props.image ? props.theme.colors.white : props.theme.colors.black};
126
+ // filter: ${(props) =>
127
+ // props.image ? 'drop-shadow(0 2px 2px rgba(0, 0, 0, 0.1))' : 'none'};
128
+ // `
129
+
130
+ const PageContainer = styled('div')`
131
+ display: ${(props) => (props.type === 'dot' ? 'unset' : 'inline-block')};
132
+ position: relative;
133
+ `
134
+
135
+ const TextWrapper = styled('div')`
136
+ z-index: 99999;
137
+ position: absolute;
138
+ `
139
+
140
+ const OverlayImage = styled('img')`
141
+ width: 100%;
142
+ height: auto;
143
+ `
144
+
145
+ const Dot = styled('div')`
146
+ width: 5px;
147
+ height: 5px;
148
+ background-color: ${(props) => props.color};
149
+ border-radius: 50%;
150
+ `
151
+
152
+ const IconWrapperAttrs = {
153
+ backgroundColor: String,
154
+ borderRadius: String,
155
+ padding: String,
156
+ hoveredIcon: Boolean,
157
+ isActive: Boolean,
158
+ isDisabled: Boolean,
159
+ }
160
+ const IconWrapper = styled('div', IconWrapperAttrs)`
161
+ display: flex;
162
+ align-items: center;
163
+ justify-content: center;
164
+ gap: 6px;
165
+ white-space: nowrap;
166
+ background-color: ${(props) => props.backgroundColor};
167
+ border-radius: ${(props) =>
168
+ props.hoveredIcon ? '6px' : props.borderRadius};
169
+ padding: ${(props) => props.padding};
170
+ width: ${(props) => (props.hoveredIcon ? '32px' : '')};
171
+ height: ${(props) => (props.hoveredIcon ? '32px' : '')};
172
+ cursor: pointer;
173
+ background-color: ${(props) =>
174
+ props.isActive ? props.theme.colors.transparentWhite2 : ''};
175
+ cursor: ${(props) => (props.isDisabled ? 'not-allowed' : 'pointer')};
176
+ &:hover {
177
+ background-color: ${(props) =>
178
+ props.hoveredIcon ? props.theme.colors.transparentWhite2 : ''};
179
+ }
180
+ `
181
+
182
+ const LabelWrapperAttrs = {
183
+ size: String,
184
+ color: String,
185
+ }
186
+ const LabelWrapper = styled('div', LabelWrapperAttrs)`
187
+ font-size: ${(props) => props.size};
188
+ color: ${(props) => props.color};
189
+ `
190
+
191
+ export default {
192
+ name: 'InfoText',
193
+ components: {
194
+ IconComponent,
195
+ TextOverlay,
196
+ // Arrow,
197
+ Dot,
198
+ PageContainer,
199
+ TextWrapper,
200
+ OverlayImage,
201
+ IconWrapper,
202
+ LabelWrapper,
203
+ },
204
+ props: {
205
+ text: {
206
+ required: false,
207
+ default: '',
208
+ type: String,
209
+ },
210
+ isActive: {
211
+ required: false,
212
+ default: false,
213
+ type: Boolean,
214
+ },
215
+ labelText: {
216
+ required: false,
217
+ default: '',
218
+ type: String,
219
+ },
220
+ size: {
221
+ type: String,
222
+ default: '14px',
223
+ },
224
+ infoPosition: {
225
+ required: false,
226
+ default: 'bottom',
227
+ type: String,
228
+ },
229
+ maxWidth: {
230
+ default: '400px',
231
+ type: String,
232
+ },
233
+ openTrigger: {
234
+ type: String,
235
+ default: 'onHover',
236
+ validator: (value) => ['onHover', 'onClick'].includes(value),
237
+ },
238
+ buttonType: {
239
+ type: String,
240
+ default: 'regular',
241
+ validator: (value) => ['regular', 'error'].includes(value),
242
+ },
243
+ image: {
244
+ type: String,
245
+ default: '',
246
+ },
247
+ iconName: {
248
+ type: String,
249
+ default: 'info',
250
+ },
251
+ iconColor: {
252
+ type: String,
253
+ default: null,
254
+ required: false,
255
+ },
256
+ isDisabled: {
257
+ type: Boolean,
258
+ default: false,
259
+ required: false,
260
+ },
261
+ dotColor: {
262
+ type: String,
263
+ required: false,
264
+ default: theme.colors.blue2,
265
+ },
266
+ type: {
267
+ type: String,
268
+ required: false,
269
+ default: 'info', // info, dot
270
+ },
271
+ appTheme: {
272
+ type: String,
273
+ default: 'light', // light or dark
274
+ required: false,
275
+ },
276
+ labelAlign: {
277
+ type: String,
278
+ default: 'right',
279
+ required: false,
280
+ },
281
+ backgroundColor: {
282
+ type: String,
283
+ default: '',
284
+ required: false,
285
+ },
286
+ borderRadius: {
287
+ type: String,
288
+ default: '',
289
+ required: false,
290
+ },
291
+ padding: {
292
+ type: String,
293
+ default: '',
294
+ required: false,
295
+ },
296
+ labelSize: {
297
+ type: String,
298
+ default: '12px',
299
+ required: false,
300
+ },
301
+ noIcon: {
302
+ type: Boolean,
303
+ default: false,
304
+ required: false,
305
+ },
306
+ hoveredIcon: {
307
+ type: Boolean,
308
+ default: false,
309
+ required: false,
310
+ },
311
+ hideInfoText: {
312
+ type: Boolean,
313
+ default: false,
314
+ required: false,
315
+ },
316
+ },
317
+ setup(props) {
318
+ const isVisible = ref(false)
319
+ const container = ref(null)
320
+ const icon = ref(null)
321
+ const infoBox = ref(null)
322
+ const textContent = ref(null)
323
+ const infoImage = ref(null)
324
+ const infoBoxWidth = ref(0)
325
+ const infoBoxHeight = ref(0)
326
+ const boxStyle = ref({})
327
+ const arrowStyle = ref({})
328
+ const wrapperStyle = ref({})
329
+ const isMobile = ref(window.innerWidth <= 768)
330
+
331
+ const textStyle = computed(() => ({
332
+ fontSize: props.image ? '12px' : '13px',
333
+ color: props.image
334
+ ? theme.colors.grey1
335
+ : props.appTheme === 'dark'
336
+ ? theme.colors.black
337
+ : theme.colors.white,
338
+ textAlign: props.image ? 'right' : 'left',
339
+ }))
340
+
341
+ const calculatePosition = (width) => {
342
+ if (!icon.value || !width) return {}
343
+
344
+ const iconRect = icon.value.getBoundingClientRect()
345
+ const windowHeight = window.innerHeight
346
+ const windowWidth = window.innerWidth
347
+
348
+ // Calculate available space in all directions
349
+ const spaceBelow = windowHeight - iconRect.bottom - 10
350
+ const spaceAbove = iconRect.top - 10
351
+ const spaceRight = windowWidth - iconRect.right - 10
352
+ const spaceLeft = iconRect.left - 10
353
+
354
+ // Determine the best position based on available space
355
+ const positions = [
356
+ { position: 'bottom', space: spaceBelow },
357
+ { position: 'top', space: spaceAbove },
358
+ { position: 'right', space: spaceRight },
359
+ { position: 'left', space: spaceLeft },
360
+ ].sort((a, b) => b.space - a.space)
361
+
362
+ const bestPosition = positions[0].position
363
+
364
+ let top, left, arrowPosition
365
+
366
+ switch (bestPosition) {
367
+ case 'bottom':
368
+ top = Math.round(iconRect.bottom + 10)
369
+ left = Math.round(Math.min(iconRect.left, windowWidth - width - 10))
370
+ arrowPosition = {
371
+ left: `${Math.round(
372
+ Math.min(
373
+ Math.max(iconRect.left - left + iconRect.width / 2 - 8, 2),
374
+ width - 18
375
+ )
376
+ )}px`,
377
+ top: '-7px',
378
+ bottom: 'auto',
379
+ transform: 'rotate(180deg)',
380
+ }
381
+ break
382
+
383
+ case 'top':
384
+ top = Math.round(iconRect.top - infoBoxHeight.value - 10)
385
+ left = Math.round(Math.min(iconRect.left, windowWidth - width - 10))
386
+ arrowPosition = {
387
+ left: `${Math.round(
388
+ Math.min(
389
+ Math.max(iconRect.left - left + iconRect.width / 2 - 8, 2),
390
+ width - 18
391
+ )
392
+ )}px`,
393
+ top: 'auto',
394
+ bottom: '-7px',
395
+ transform: 'none',
396
+ }
397
+ break
398
+
399
+ case 'right':
400
+ top = Math.round(
401
+ Math.max(
402
+ Math.min(
403
+ iconRect.top - (infoBoxHeight.value - iconRect.height) / 2,
404
+ windowHeight - infoBoxHeight.value - 10
405
+ ),
406
+ 10
407
+ )
408
+ )
409
+ left = Math.round(iconRect.right + 10)
410
+ arrowPosition = {
411
+ left: '-7px',
412
+ top: `${Math.round(
413
+ Math.min(
414
+ Math.max(iconRect.top - top + iconRect.height / 2 - 8, 2),
415
+ infoBoxHeight.value - 18
416
+ )
417
+ )}px`,
418
+ bottom: 'auto',
419
+ transform: 'rotate(90deg)',
420
+ }
421
+ break
422
+
423
+ case 'left':
424
+ top = Math.round(
425
+ Math.max(
426
+ Math.min(
427
+ iconRect.top - (infoBoxHeight.value - iconRect.height) / 2,
428
+ windowHeight - infoBoxHeight.value - 10
429
+ ),
430
+ 10
431
+ )
432
+ )
433
+ left = Math.round(iconRect.left - width - 10)
434
+ arrowPosition = {
435
+ left: 'auto',
436
+ right: '-7px',
437
+ top: `${Math.round(
438
+ Math.min(
439
+ Math.max(iconRect.top - top + iconRect.height / 2 - 8, 2),
440
+ infoBoxHeight.value - 18
441
+ )
442
+ )}px`,
443
+ bottom: 'auto',
444
+ transform: 'rotate(-90deg)',
445
+ }
446
+ break
447
+ }
448
+
449
+ // Set arrow styles
450
+ arrowStyle.value = arrowPosition
451
+
452
+ // Set wrapper styles
453
+ wrapperStyle.value = {
454
+ position: 'fixed',
455
+ top: `${top}px`,
456
+ left: `${left}px`,
457
+ transform: 'none',
458
+ width: `${width}px`,
459
+ }
460
+
461
+ return {
462
+ width: '100%',
463
+ maxWidth: props.maxWidth,
464
+ overflowY: 'auto',
465
+ backgroundColor: props.image
466
+ ? theme.colors.white
467
+ : props.appTheme === 'light'
468
+ ? theme.colors.black
469
+ : theme.colors.grey5,
470
+ }
471
+ }
472
+
473
+ const showInfo = async () => {
474
+ isVisible.value = true
475
+ // Wait for two render cycles to ensure content is stable
476
+ await nextTick()
477
+ await nextTick()
478
+ await updatePosition()
479
+ }
480
+
481
+ const hideInfo = () => {
482
+ isVisible.value = false
483
+ infoBoxWidth.value = 0 // Reset width when hiding
484
+ }
485
+
486
+ const toggleInfo = () => {
487
+ isVisible.value ? hideInfo() : showInfo()
488
+ }
489
+
490
+ const handleScroll = () => {
491
+ if (isVisible.value) {
492
+ hideInfo()
493
+ }
494
+ updatePosition()
495
+ }
496
+
497
+ const isIconInView = () => {
498
+ if (!icon.value) return false
499
+ const rect = icon.value.getBoundingClientRect()
500
+ return (
501
+ rect.top >= 0 &&
502
+ rect.left >= 0 &&
503
+ rect.bottom <=
504
+ (window.innerHeight || document.documentElement.clientHeight) &&
505
+ rect.right <=
506
+ (window.innerWidth || document.documentElement.clientWidth)
507
+ )
508
+ }
509
+
510
+ const updatePosition = async () => {
511
+ if (!infoBox.value || !textContent.value) return
512
+
513
+ // First make the content visible but hidden to get accurate measurements
514
+ if (infoBox.value.$el) {
515
+ infoBox.value.$el.style.visibility = 'hidden'
516
+ infoBox.value.$el.style.display = 'block'
517
+ }
518
+
519
+ await nextTick()
520
+
521
+ if (!isIconInView()) {
522
+ if (isVisible.value) hideInfo()
523
+ return
524
+ }
525
+
526
+ // Create a temporary clone to measure true width
527
+ const clone = textContent.value.cloneNode(true)
528
+ clone.style.position = 'absolute'
529
+ clone.style.visibility = 'hidden'
530
+ clone.style.width = 'auto'
531
+ clone.style.maxWidth = 'none'
532
+ clone.style.whiteSpace = 'nowrap' // Prevent text wrapping during measurement
533
+ document.body.appendChild(clone)
534
+
535
+ // Get fresh content width from clone
536
+ const contentWidth = clone.offsetWidth
537
+ document.body.removeChild(clone)
538
+
539
+ // Calculate new width
540
+ const calculatedWidth = Math.min(
541
+ Math.max(contentWidth, 230),
542
+ parseInt(props.maxWidth, 10)
543
+ )
544
+
545
+ // Set new dimensions
546
+ infoBoxWidth.value = calculatedWidth
547
+
548
+ // Wait for width to be applied
549
+ await nextTick()
550
+
551
+ infoBoxHeight.value = infoBox.value.$el.offsetHeight
552
+
553
+ // Calculate and apply position
554
+ boxStyle.value = calculatePosition(calculatedWidth)
555
+
556
+ // Make visible after position is set
557
+ if (isVisible.value && infoBox.value.$el) {
558
+ infoBox.value.$el.style.visibility = 'visible'
559
+ }
560
+ }
561
+
562
+ const onImageLoad = () => {
563
+ if (infoImage.value) {
564
+ infoBoxHeight.value = infoBox.value.$el.offsetHeight
565
+ updatePosition()
566
+ }
567
+ }
568
+
569
+ const handleClickOutside = (event) => {
570
+ if (
571
+ (props.openTrigger === 'onClick' || isMobile.value) &&
572
+ isVisible.value
573
+ ) {
574
+ const clickedElement = event.target
575
+ if (
576
+ infoBox.value &&
577
+ !infoBox.value.$el.contains(clickedElement) &&
578
+ !icon.value.contains(clickedElement)
579
+ ) {
580
+ hideInfo()
581
+ }
582
+ }
583
+ }
584
+
585
+ const handleResize = () => {
586
+ isMobile.value = window.innerWidth <= 768
587
+ updatePosition()
588
+ }
589
+
590
+ onMounted(() => {
591
+ window.addEventListener('scroll', handleScroll, { passive: true })
592
+ window.addEventListener('resize', handleResize)
593
+ document.addEventListener('scroll', handleScroll, {
594
+ passive: true,
595
+ capture: true,
596
+ })
597
+ document.addEventListener('click', handleClickOutside)
598
+ })
599
+
600
+ onUnmounted(() => {
601
+ window.removeEventListener('scroll', handleScroll)
602
+ window.removeEventListener('resize', handleResize)
603
+ document.removeEventListener('scroll', handleScroll, { capture: true })
604
+ document.removeEventListener('click', handleClickOutside)
605
+ })
606
+
607
+ watch(isVisible, (newValue) => {
608
+ if (newValue) {
609
+ updatePosition()
610
+ }
611
+ })
612
+
613
+ return {
614
+ isVisible,
615
+ boxStyle,
616
+ arrowStyle,
617
+ showInfo,
618
+ hideInfo,
619
+ toggleInfo,
620
+ container,
621
+ icon,
622
+ infoBox,
623
+ textContent,
624
+ infoImage,
625
+ infoBoxWidth,
626
+ infoBoxHeight,
627
+ wrapperStyle,
628
+ textStyle,
629
+ onImageLoad,
630
+ isMobile,
631
+ }
632
+ },
633
+ computed: {
634
+ computedIconColor() {
635
+ return this.buttonType === 'error'
636
+ ? theme.colors.red
637
+ : theme.colors.mediumGray
638
+ },
639
+ },
640
+ }
641
+ </script>