@eturnity/eturnity_reusable_components 8.13.13-EPDM-9631.0 → 8.13.13-EPDM-12459.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (412) hide show
  1. package/README.md +29 -29
  2. package/package.json +85 -85
  3. package/src/App.vue +30 -30
  4. package/src/Test.vue +64 -64
  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_down_unfilled.svg +4 -4
  40. package/src/assets/svgIcons/arrow_left.svg +4 -4
  41. package/src/assets/svgIcons/arrow_right.svg +4 -4
  42. package/src/assets/svgIcons/arrow_up.svg +3 -3
  43. package/src/assets/svgIcons/arrow_up_unfilled.svg +4 -4
  44. package/src/assets/svgIcons/attachment.svg +3 -3
  45. package/src/assets/svgIcons/base_layer.svg +3 -3
  46. package/src/assets/svgIcons/battery.svg +3 -3
  47. package/src/assets/svgIcons/bell.svg +3 -3
  48. package/src/assets/svgIcons/bell_alt.svg +3 -3
  49. package/src/assets/svgIcons/bexio.svg +4 -4
  50. package/src/assets/svgIcons/bold.svg +3 -3
  51. package/src/assets/svgIcons/bom.svg +3 -3
  52. package/src/assets/svgIcons/bom_generation.svg +10 -10
  53. package/src/assets/svgIcons/bookmaker.svg +3 -3
  54. package/src/assets/svgIcons/bubble.svg +3 -3
  55. package/src/assets/svgIcons/bug.svg +5 -5
  56. package/src/assets/svgIcons/buildings.svg +55 -55
  57. package/src/assets/svgIcons/bullet_list.svg +8 -8
  58. package/src/assets/svgIcons/calendar.svg +7 -7
  59. package/src/assets/svgIcons/calendar_icon.svg +7 -7
  60. package/src/assets/svgIcons/call.svg +3 -3
  61. package/src/assets/svgIcons/camera.svg +3 -3
  62. package/src/assets/svgIcons/car.svg +3 -3
  63. package/src/assets/svgIcons/cart.svg +3 -3
  64. package/src/assets/svgIcons/charger_icon_white.svg +44 -44
  65. package/src/assets/svgIcons/checkbox.svg +3 -3
  66. package/src/assets/svgIcons/checkmark.svg +3 -3
  67. package/src/assets/svgIcons/checkmark_white.svg +4 -4
  68. package/src/assets/svgIcons/clear_formatting.svg +7 -7
  69. package/src/assets/svgIcons/clenergy.svg +3 -3
  70. package/src/assets/svgIcons/clickable_info.svg +4 -4
  71. package/src/assets/svgIcons/clickable_info_white.svg +5 -5
  72. package/src/assets/svgIcons/clip.svg +3 -3
  73. package/src/assets/svgIcons/clock.svg +17 -17
  74. package/src/assets/svgIcons/clock_full.svg +3 -3
  75. package/src/assets/svgIcons/close.svg +4 -4
  76. package/src/assets/svgIcons/co_branding.svg +5 -5
  77. package/src/assets/svgIcons/collapse.svg +4 -4
  78. package/src/assets/svgIcons/collapse_all.svg +3 -3
  79. package/src/assets/svgIcons/collections.svg +3 -3
  80. package/src/assets/svgIcons/component_library.svg +7 -7
  81. package/src/assets/svgIcons/consumption_tariffs.svg +43 -43
  82. package/src/assets/svgIcons/context_menu-1.svg +6 -6
  83. package/src/assets/svgIcons/context_menu-2.svg +5 -5
  84. package/src/assets/svgIcons/context_menu.svg +5 -5
  85. package/src/assets/svgIcons/context_menu_tabs.svg +5 -5
  86. package/src/assets/svgIcons/cross.svg +4 -4
  87. package/src/assets/svgIcons/current_variant.svg +4 -4
  88. package/src/assets/svgIcons/customer.svg +3 -3
  89. package/src/assets/svgIcons/dashboard.svg +3 -3
  90. package/src/assets/svgIcons/data_transfer.svg +3 -3
  91. package/src/assets/svgIcons/deadline.svg +4 -4
  92. package/src/assets/svgIcons/deal_flow.svg +3 -3
  93. package/src/assets/svgIcons/delete.svg +4 -4
  94. package/src/assets/svgIcons/delete_area_active.svg +16 -16
  95. package/src/assets/svgIcons/delete_area_inactive.svg +15 -15
  96. package/src/assets/svgIcons/direction_active-1.svg +12 -12
  97. package/src/assets/svgIcons/direction_active.svg +5 -5
  98. package/src/assets/svgIcons/direction_arrow.svg +4 -4
  99. package/src/assets/svgIcons/direction_inactive.svg +4 -4
  100. package/src/assets/svgIcons/dislike.svg +3 -3
  101. package/src/assets/svgIcons/distance_tool.svg +8 -8
  102. package/src/assets/svgIcons/distances_active.svg +9 -9
  103. package/src/assets/svgIcons/distances_inactive.svg +8 -8
  104. package/src/assets/svgIcons/distort_tool.svg +10 -10
  105. package/src/assets/svgIcons/distort_tool2.svg +16 -16
  106. package/src/assets/svgIcons/document.svg +3 -3
  107. package/src/assets/svgIcons/documents.svg +3 -3
  108. package/src/assets/svgIcons/downarrow.svg +3 -3
  109. package/src/assets/svgIcons/download.svg +4 -4
  110. package/src/assets/svgIcons/drag_icon.svg +8 -8
  111. package/src/assets/svgIcons/draggable_corner.svg +5 -5
  112. package/src/assets/svgIcons/draw_tool.svg +3 -3
  113. package/src/assets/svgIcons/duplicate-1.svg +8 -8
  114. package/src/assets/svgIcons/duplicate-2.svg +5 -5
  115. package/src/assets/svgIcons/duplicate.svg +4 -4
  116. package/src/assets/svgIcons/e-mobility_configurator.svg +6 -6
  117. package/src/assets/svgIcons/e_signature.svg +5 -5
  118. package/src/assets/svgIcons/edit_button.svg +3 -3
  119. package/src/assets/svgIcons/efs.svg +5 -5
  120. package/src/assets/svgIcons/electricity_tariff.svg +3 -3
  121. package/src/assets/svgIcons/email.svg +3 -3
  122. package/src/assets/svgIcons/ems-1.svg +3 -3
  123. package/src/assets/svgIcons/ems.svg +3 -3
  124. package/src/assets/svgIcons/end_of_the_list.svg +5 -5
  125. package/src/assets/svgIcons/energy_meter.svg +3 -3
  126. package/src/assets/svgIcons/erase.svg +4 -4
  127. package/src/assets/svgIcons/erase_white.svg +4 -4
  128. package/src/assets/svgIcons/expand_all.svg +4 -4
  129. package/src/assets/svgIcons/export_document.svg +3 -3
  130. package/src/assets/svgIcons/external_icon.svg +5 -5
  131. package/src/assets/svgIcons/fav_icon.svg +4 -4
  132. package/src/assets/svgIcons/finance.svg +3 -3
  133. package/src/assets/svgIcons/financing_for_pv-1.svg +5 -5
  134. package/src/assets/svgIcons/financing_for_pv-2.svg +3 -3
  135. package/src/assets/svgIcons/financing_for_pv.svg +3 -3
  136. package/src/assets/svgIcons/finish-1.svg +4 -4
  137. package/src/assets/svgIcons/finish.svg +3 -3
  138. package/src/assets/svgIcons/flatten.svg +11 -11
  139. package/src/assets/svgIcons/flatten_roof.svg +20 -20
  140. package/src/assets/svgIcons/folder.svg +3 -3
  141. package/src/assets/svgIcons/free_technology.svg +3 -3
  142. package/src/assets/svgIcons/handle.svg +5 -5
  143. package/src/assets/svgIcons/heat_calc.svg +7 -7
  144. package/src/assets/svgIcons/heat_pump.svg +5 -5
  145. package/src/assets/svgIcons/heating_system.svg +3 -3
  146. package/src/assets/svgIcons/height_equalize.svg +3 -3
  147. package/src/assets/svgIcons/height_snap.svg +3 -3
  148. package/src/assets/svgIcons/house.svg +3 -3
  149. package/src/assets/svgIcons/house_3d-1.svg +7 -7
  150. package/src/assets/svgIcons/house_3d.svg +7 -7
  151. package/src/assets/svgIcons/hybrid.svg +4 -4
  152. package/src/assets/svgIcons/inclination.svg +2 -2
  153. package/src/assets/svgIcons/info.svg +3 -3
  154. package/src/assets/svgIcons/initial_situation.svg +3 -3
  155. package/src/assets/svgIcons/integrations.svg +3 -3
  156. package/src/assets/svgIcons/intro-tour-1.svg +3 -3
  157. package/src/assets/svgIcons/intro-tour.svg +3 -3
  158. package/src/assets/svgIcons/inverter.svg +3 -3
  159. package/src/assets/svgIcons/italic.svg +3 -3
  160. package/src/assets/svgIcons/k2.svg +4 -4
  161. package/src/assets/svgIcons/key.svg +3 -3
  162. package/src/assets/svgIcons/lake.svg +29 -29
  163. package/src/assets/svgIcons/layers_close.svg +4 -4
  164. package/src/assets/svgIcons/layers_open.svg +4 -4
  165. package/src/assets/svgIcons/lead_marketplace.svg +6 -6
  166. package/src/assets/svgIcons/lead_provider.svg +4 -4
  167. package/src/assets/svgIcons/length_2d.svg +2 -2
  168. package/src/assets/svgIcons/length_3d.svg +4 -4
  169. package/src/assets/svgIcons/length_calculator.svg +2 -2
  170. package/src/assets/svgIcons/length_in_2d_active.svg +12 -12
  171. package/src/assets/svgIcons/length_in_2d_inctive.svg +13 -13
  172. package/src/assets/svgIcons/light_bulb.svg +3 -3
  173. package/src/assets/svgIcons/like.svg +3 -3
  174. package/src/assets/svgIcons/line_graph.svg +3 -3
  175. package/src/assets/svgIcons/local_subsidies.svg +18 -18
  176. package/src/assets/svgIcons/location.svg +3 -3
  177. package/src/assets/svgIcons/lock.svg +3 -3
  178. package/src/assets/svgIcons/logout.svg +3 -3
  179. package/src/assets/svgIcons/loop.svg +3 -3
  180. package/src/assets/svgIcons/low-vegetation.svg +37 -37
  181. package/src/assets/svgIcons/lunch.svg +4 -4
  182. package/src/assets/svgIcons/magic_tool.svg +6 -6
  183. package/src/assets/svgIcons/map_icon.svg +5 -5
  184. package/src/assets/svgIcons/map_settings.svg +3 -3
  185. package/src/assets/svgIcons/margin_tool.svg +4 -4
  186. package/src/assets/svgIcons/meeting.svg +6 -6
  187. package/src/assets/svgIcons/module.svg +3 -3
  188. package/src/assets/svgIcons/move_copy.svg +4 -4
  189. package/src/assets/svgIcons/move_down.svg +3 -3
  190. package/src/assets/svgIcons/move_up.svg +3 -3
  191. package/src/assets/svgIcons/new_area_inactive.svg +11 -11
  192. package/src/assets/svgIcons/next.svg +4 -4
  193. package/src/assets/svgIcons/normal-tg.svg +30 -30
  194. package/src/assets/svgIcons/normal-vegetation.svg +53 -53
  195. package/src/assets/svgIcons/not_equal_to.svg +3 -3
  196. package/src/assets/svgIcons/numbered_list.svg +6 -6
  197. package/src/assets/svgIcons/obstacle_tool.svg +8 -8
  198. package/src/assets/svgIcons/obstacle_tool_origin.svg +3 -3
  199. package/src/assets/svgIcons/offset_tool.svg +8 -8
  200. package/src/assets/svgIcons/open-tg.svg +21 -21
  201. package/src/assets/svgIcons/optimizer.svg +3 -3
  202. package/src/assets/svgIcons/outline_tool.svg +11 -11
  203. package/src/assets/svgIcons/pan_tool.svg +12 -12
  204. package/src/assets/svgIcons/panels_tool.svg +8 -8
  205. package/src/assets/svgIcons/pen_tool.svg +4 -4
  206. package/src/assets/svgIcons/picker_tool.svg +4 -4
  207. package/src/assets/svgIcons/picture.svg +3 -3
  208. package/src/assets/svgIcons/pin.svg +5 -5
  209. package/src/assets/svgIcons/plus_button.svg +4 -4
  210. package/src/assets/svgIcons/presentation.svg +3 -3
  211. package/src/assets/svgIcons/previous.svg +4 -4
  212. package/src/assets/svgIcons/profile-1.svg +4 -4
  213. package/src/assets/svgIcons/profile.svg +3 -3
  214. package/src/assets/svgIcons/profitability.svg +3 -3
  215. package/src/assets/svgIcons/project_analysis.svg +3 -3
  216. package/src/assets/svgIcons/project_settings.svg +3 -3
  217. package/src/assets/svgIcons/protected-tg.svg +47 -47
  218. package/src/assets/svgIcons/pv.svg +3 -3
  219. package/src/assets/svgIcons/question_mark.svg +3 -3
  220. package/src/assets/svgIcons/question_mark_white.svg +4 -4
  221. package/src/assets/svgIcons/quotations.svg +6 -6
  222. package/src/assets/svgIcons/redo.svg +6 -6
  223. package/src/assets/svgIcons/reorder_string.svg +3 -3
  224. package/src/assets/svgIcons/resizer.svg +5 -5
  225. package/src/assets/svgIcons/roof_layer.svg +3 -3
  226. package/src/assets/svgIcons/rotate_tool.svg +3 -3
  227. package/src/assets/svgIcons/rotate_view.svg +5 -5
  228. package/src/assets/svgIcons/ruler_tool.svg +3 -3
  229. package/src/assets/svgIcons/run_simulation.svg +3 -3
  230. package/src/assets/svgIcons/save.svg +3 -3
  231. package/src/assets/svgIcons/scaling_tool.svg +8 -8
  232. package/src/assets/svgIcons/sea.svg +34 -34
  233. package/src/assets/svgIcons/search.svg +3 -3
  234. package/src/assets/svgIcons/security.svg +3 -3
  235. package/src/assets/svgIcons/settings.svg +3 -3
  236. package/src/assets/svgIcons/show_in_a_new_tab.svg +12 -12
  237. package/src/assets/svgIcons/smartphone.svg +4 -4
  238. package/src/assets/svgIcons/solar_calc.svg +13 -13
  239. package/src/assets/svgIcons/solarmarkt.svg +3 -3
  240. package/src/assets/svgIcons/sorting.svg +4 -4
  241. package/src/assets/svgIcons/split.svg +12 -12
  242. package/src/assets/svgIcons/star.svg +3 -3
  243. package/src/assets/svgIcons/start_of_the_list.svg +5 -5
  244. package/src/assets/svgIcons/strikethrough.svg +4 -4
  245. package/src/assets/svgIcons/string_design.svg +5 -5
  246. package/src/assets/svgIcons/string_directions.svg +10 -10
  247. package/src/assets/svgIcons/subscriptions.svg +3 -3
  248. package/src/assets/svgIcons/subsidies-2.svg +3 -3
  249. package/src/assets/svgIcons/subsidies.svg +3 -3
  250. package/src/assets/svgIcons/subtract_icon.svg +3 -3
  251. package/src/assets/svgIcons/suitcase.svg +3 -3
  252. package/src/assets/svgIcons/summer.svg +3 -3
  253. package/src/assets/svgIcons/switch_polarity.svg +5 -5
  254. package/src/assets/svgIcons/template_icon_not_clickable.svg +6 -6
  255. package/src/assets/svgIcons/transfer.svg +4 -4
  256. package/src/assets/svgIcons/transparent_warning.svg +4 -4
  257. package/src/assets/svgIcons/trim_tool.svg +4 -4
  258. package/src/assets/svgIcons/truck.svg +3 -3
  259. package/src/assets/svgIcons/underlined.svg +3 -3
  260. package/src/assets/svgIcons/undo.svg +6 -6
  261. package/src/assets/svgIcons/uparrow.svg +3 -3
  262. package/src/assets/svgIcons/update.svg +3 -3
  263. package/src/assets/svgIcons/upload_avatar-1.svg +12 -12
  264. package/src/assets/svgIcons/upload_avatar.svg +5 -5
  265. package/src/assets/svgIcons/upload_image.svg +8 -8
  266. package/src/assets/svgIcons/upload_image_tool.svg +7 -7
  267. package/src/assets/svgIcons/variants.svg +3 -3
  268. package/src/assets/svgIcons/vdv.svg +5 -5
  269. package/src/assets/svgIcons/vertical_tool.svg +3 -3
  270. package/src/assets/svgIcons/virtual_storage.svg +3 -3
  271. package/src/assets/svgIcons/warning.svg +4 -4
  272. package/src/assets/svgIcons/warning_triangle.svg +3 -3
  273. package/src/assets/svgIcons/warning_triangle_white.svg +5 -5
  274. package/src/assets/svgIcons/way.svg +5 -5
  275. package/src/assets/svgIcons/wifi.svg +3 -3
  276. package/src/assets/svgIcons/winter.svg +3 -3
  277. package/src/assets/svgIcons/workflow_template.svg +11 -11
  278. package/src/assets/tests/__mocks__/iconCache.js +1 -1
  279. package/src/assets/tests/__mocks__/svgMock.js +1 -1
  280. package/src/assets/tests/helpers.js +12 -12
  281. package/src/assets/theme.js +623 -623
  282. package/src/components/addNewButton/AddNewButton.stories.js +17 -17
  283. package/src/components/addNewButton/addNewButton.spec.js +23 -23
  284. package/src/components/addNewButton/index.vue +66 -66
  285. package/src/components/banner/actionBanner/ActionBanner.stories.js +45 -45
  286. package/src/components/banner/actionBanner/actionBanner.spec.js +76 -76
  287. package/src/components/banner/actionBanner/index.vue +86 -86
  288. package/src/components/banner/banner/Banner.stories.js +64 -64
  289. package/src/components/banner/banner/banner.spec.js +149 -149
  290. package/src/components/banner/banner/index.vue +205 -205
  291. package/src/components/banner/infoBanner/InfoBanner.spec.js +70 -70
  292. package/src/components/banner/infoBanner/InfoBanner.stories.js +42 -42
  293. package/src/components/banner/infoBanner/index.vue +97 -97
  294. package/src/components/banner/notificationBanner/index.vue +131 -131
  295. package/src/components/buttons/buttonIcon/index.vue +250 -250
  296. package/src/components/buttons/closeButton/CloseButton.stories.js +25 -25
  297. package/src/components/buttons/closeButton/index.vue +62 -62
  298. package/src/components/buttons/mainButton/MainButton.stories.js +51 -51
  299. package/src/components/buttons/mainButton/index.vue +213 -213
  300. package/src/components/buttons/mainButton/mainButton.spec.js +35 -35
  301. package/src/components/card/Card.stories.js +79 -79
  302. package/src/components/card/card.spec.js +135 -135
  303. package/src/components/card/index.vue +116 -116
  304. package/src/components/collapsableInfoText/index.vue +127 -127
  305. package/src/components/deleteIcon/DeleteIcon.stories.js +29 -29
  306. package/src/components/deleteIcon/index.vue +78 -78
  307. package/src/components/draggableInputHandle/index.vue +46 -46
  308. package/src/components/dropdown/Dropdown.stories.js +53 -53
  309. package/src/components/dropdown/index.vue +138 -138
  310. package/src/components/errorMessage/index.vue +64 -64
  311. package/src/components/filter/filterSettings.vue +670 -670
  312. package/src/components/filter/index.vue +154 -154
  313. package/src/components/filter/parentDropdown.vue +91 -91
  314. package/src/components/icon/Icons.stories.js +31 -31
  315. package/src/components/icon/icon.spec.js +66 -66
  316. package/src/components/icon/iconCache.mjs +23 -23
  317. package/src/components/icon/iconCollection.vue +83 -83
  318. package/src/components/icon/index.vue +197 -197
  319. package/src/components/iconWrapper/index.vue +184 -184
  320. package/src/components/infoCard/InfoCard.stories.js +170 -170
  321. package/src/components/infoCard/defaultProps.js +7 -7
  322. package/src/components/infoCard/index.vue +156 -156
  323. package/src/components/infoCard/infoCard.spec.js +64 -64
  324. package/src/components/infoLabel/index.vue +63 -63
  325. package/src/components/infoText/constants.js +4 -4
  326. package/src/components/infoText/index.vue +645 -645
  327. package/src/components/infoText/infoText.spec.js +62 -62
  328. package/src/components/infoText/infoText.stories.js +48 -48
  329. package/src/components/infoText/placeholder.vue +225 -225
  330. package/src/components/inputs/checkbox/Checkbox.stories.js +63 -63
  331. package/src/components/inputs/checkbox/checkbox.spec.js +109 -109
  332. package/src/components/inputs/checkbox/index.vue +250 -250
  333. package/src/components/inputs/inputNumber/InputNumber.stories.js +150 -150
  334. package/src/components/inputs/inputNumber/index.vue +990 -990
  335. package/src/components/inputs/inputNumberQuestion/index.vue +218 -218
  336. package/src/components/inputs/inputText/InputText.stories.js +70 -70
  337. package/src/components/inputs/inputText/index.vue +463 -463
  338. package/src/components/inputs/inputText/inputText.spec.js +588 -588
  339. package/src/components/inputs/radioButton/RadioButton.stories.js +77 -77
  340. package/src/components/inputs/radioButton/defaultProps.js +31 -31
  341. package/src/components/inputs/radioButton/index.vue +336 -336
  342. package/src/components/inputs/radioButton/radioButton.spec.js +306 -306
  343. package/src/components/inputs/searchInput/SearchInput.stories.js +66 -66
  344. package/src/components/inputs/searchInput/defaultProps.js +12 -12
  345. package/src/components/inputs/searchInput/index.vue +165 -165
  346. package/src/components/inputs/searchInput/searchInput.spec.js +64 -64
  347. package/src/components/inputs/select/index.vue +1041 -968
  348. package/src/components/inputs/select/option/index.vue +164 -164
  349. package/src/components/inputs/select/select.stories.js +58 -58
  350. package/src/components/inputs/slider/index.vue +126 -126
  351. package/src/components/inputs/switchField/index.vue +254 -254
  352. package/src/components/inputs/textAreaInput/TextAreaInput.stories.js +127 -127
  353. package/src/components/inputs/textAreaInput/index.vue +204 -204
  354. package/src/components/inputs/toggle/Toggle.stories.js +77 -77
  355. package/src/components/inputs/toggle/index.vue +322 -322
  356. package/src/components/inputs/toggle/toggle.spec.js +102 -102
  357. package/src/components/label/index.vue +98 -98
  358. package/src/components/markerItem/index.vue +95 -95
  359. package/src/components/modals/actionModal/index.vue +64 -64
  360. package/src/components/modals/infoModal/index.vue +52 -52
  361. package/src/components/modals/modal/index.vue +213 -200
  362. package/src/components/modals/modal/modal.stories.js +31 -31
  363. package/src/components/navigationTabs/index.vue +114 -114
  364. package/src/components/pageSubtitle/PageSubtitle.stories.js +59 -59
  365. package/src/components/pageSubtitle/index.vue +78 -78
  366. package/src/components/pageSubtitle/pageSubtitle.spec.js +46 -46
  367. package/src/components/pageTitle/PageTitle.stories.js +95 -95
  368. package/src/components/pageTitle/index.vue +91 -91
  369. package/src/components/pageTitle/pageTitle.spec.js +46 -46
  370. package/src/components/pagination/index.vue +148 -148
  371. package/src/components/panelRangeInfo/index.vue +196 -196
  372. package/src/components/progressBar/index.vue +125 -125
  373. package/src/components/projectMarker/index.vue +301 -301
  374. package/src/components/rangeSlider/Slider.vue +578 -578
  375. package/src/components/rangeSlider/index.vue +517 -517
  376. package/src/components/rangeSlider/utils/dom.js +49 -49
  377. package/src/components/rangeSlider/utils/fns.js +26 -26
  378. package/src/components/roundTabs/index.vue +107 -107
  379. package/src/components/selectedOptions/index.vue +462 -462
  380. package/src/components/selectedOptions/selectedOptions.spec.js +176 -176
  381. package/src/components/selectedOptions/selectedOptions.stories.js +155 -155
  382. package/src/components/sideMenu/index.vue +325 -325
  383. package/src/components/spinner/Spinner.stories.js +34 -34
  384. package/src/components/spinner/index.vue +129 -129
  385. package/src/components/spinner/spinner.spec.js +69 -69
  386. package/src/components/spinnerGif/index.vue +98 -98
  387. package/src/components/tableDropdown/index.vue +692 -692
  388. package/src/components/tables/mainTable/exampleNested.vue +328 -328
  389. package/src/components/tables/mainTable/index.vue +523 -523
  390. package/src/components/tables/viewTable/index.vue +195 -195
  391. package/src/components/tabsHeader/index.vue +95 -95
  392. package/src/components/threeDots/index.vue +413 -413
  393. package/src/components/videoThumbnail/index.vue +103 -103
  394. package/src/components/videoThumbnail/videoThumbnail.stories.js +33 -33
  395. package/src/helpers/currencyMapping.js +28 -28
  396. package/src/helpers/numberConverter.js +103 -103
  397. package/src/helpers/translateLang.js +128 -128
  398. package/src/main.js +7 -7
  399. package/src/mixins/inputValidations.js +97 -97
  400. package/src/router/dynamicRoutes.js +23 -23
  401. package/src/stories/Button.stories.js +48 -48
  402. package/src/stories/Button.vue +52 -52
  403. package/src/stories/Configure.mdx +364 -364
  404. package/src/stories/Header.stories.js +41 -41
  405. package/src/stories/Header.vue +59 -59
  406. package/src/stories/Page.stories.js +30 -30
  407. package/src/stories/Page.vue +83 -83
  408. package/src/stories/button.css +30 -30
  409. package/src/stories/header.css +32 -32
  410. package/src/stories/page.css +69 -69
  411. package/src/utils/index.js +12 -12
  412. package/src/helpers/dateTimeFormatting.js +0 -51
@@ -1,968 +1,1041 @@
1
- <template>
2
- <Container
3
- :no-relative="noRelative"
4
- :select-width="selectWidth"
5
- @mouseenter="mouseEnterHandler"
6
- @mouseleave="mouseLeaveHandler"
7
- >
8
- <InputWrapper
9
- :align-items="alignItems"
10
- :has-label="!!label && label.length > 0"
11
- :no-relative="noRelative"
12
- >
13
- <LabelWrapper
14
- v-if="label"
15
- :data-id="labelDataId"
16
- :data-qa-id="dataQaId + '_label'"
17
- :info-text-message="!!infoTextMessage || !!$slots.infoText"
18
- >
19
- <InputLabel
20
- :font-color="
21
- labelFontColor || colorMode == 'dark' || colorMode == 'transparent'
22
- ? 'white'
23
- : 'eturnityGrey'
24
- "
25
- :font-size="fontSize"
26
- >{{ label }}
27
- <OptionalLabel v-if="labelOptional">
28
- ({{ $gettext('Optional') }})</OptionalLabel
29
- >
30
- </InputLabel>
31
- <InfoText
32
- v-if="infoTextMessage || !!$slots.infoText"
33
- :align-arrow="infoTextAlignArrow"
34
- :max-width="infoTextWidth"
35
- :size="infoTextSize"
36
- :text="infoTextMessage"
37
- :width="infoTextWidth"
38
- >
39
- <slot name="infoText"></slot>
40
- </InfoText>
41
- </LabelWrapper>
42
- <SelectButtonWrapper :disabled="disabled">
43
- <SelectButton
44
- ref="select"
45
- :bg-color="
46
- buttonBgColor || colorMode == 'dark'
47
- ? 'transparentBlack1'
48
- : colorMode == 'transparent'
49
- ? 'transparent'
50
- : 'white'
51
- "
52
- class="select-button"
53
- :color-mode="colorMode"
54
- :data-id="dataId"
55
- :data-qa-id="dataQaId"
56
- :disabled="disabled"
57
- :font-color="
58
- buttonFontColor || colorMode == 'dark' || colorMode == 'transparent'
59
- ? 'white'
60
- : 'black'
61
- "
62
- :font-size="fontSize"
63
- :has-error="hasError"
64
- :has-no-padding="isSearchBarVisible || !hasSelectButtonPadding"
65
- :height="height"
66
- :is-search-bar-visible="isSearchBarVisible"
67
- :no-relative="noRelative"
68
- :padding-left="paddingLeft"
69
- :select-height="selectHeight"
70
- :select-min-height="selectMinHeight"
71
- :select-width="selectWidth"
72
- :show-border="showBorder"
73
- :show-disabled-background="showDisabledBackground"
74
- :table-padding-left="tablePaddingLeft"
75
- @click="toggleDropdown"
76
- @keydown="onKeyDown"
77
- >
78
- <DraggableInputHandle
79
- v-if="isDraggable && !isSearchBarVisible"
80
- :height="selectHeight"
81
- />
82
- <InputText
83
- v-if="isSearchBarVisible"
84
- ref="searchInput"
85
- background-color="transparent"
86
- :font-color="
87
- buttonFontColor ||
88
- colorMode == 'dark' ||
89
- colorMode == 'transparent'
90
- ? 'white'
91
- : 'black'
92
- "
93
- :font-size="fontSize"
94
- input-height="34px"
95
- :input-width="computedWidth"
96
- :no-border="true"
97
- tabindex="0"
98
- :value="textSearch"
99
- @click.stop
100
- @input-change="searchChange"
101
- @keydown.stop="onKeyDown"
102
- />
103
- <Selector
104
- v-else
105
- :disabled="disabled"
106
- :padding-left="paddingLeft"
107
- :select-width="selectWidth"
108
- :show-border="showBorder"
109
- >
110
- <slot name="selector" :selected-value="selectedValue"></slot>
111
- </Selector>
112
- <Caret
113
- class="caret_dropdown"
114
- :color-mode="colorMode"
115
- @click.stop="toggleCaretDropdown"
116
- >
117
- <Icon
118
- v-if="isDropdownOpen"
119
- :color="
120
- caretColor || colorMode == 'dark' || colorMode == 'transparent'
121
- ? 'white'
122
- : 'transparentBlack1'
123
- "
124
- name="arrow_up"
125
- :size="colorMode === 'transparent' ? '8px' : '12px'"
126
- />
127
- <Icon
128
- v-else
129
- :color="
130
- caretColor || colorMode == 'dark' || colorMode == 'transparent'
131
- ? 'white'
132
- : 'transparentBlack1'
133
- "
134
- name="arrow_down"
135
- :size="colorMode === 'transparent' ? '8px' : '12px'"
136
- />
137
- </Caret>
138
- </SelectButton>
139
- <DropdownWrapper ref="dropdownWrapperRef" :no-relative="noRelative">
140
- <Teleport to="body">
141
- <SelectDropdown
142
- v-show="isSelectDropdownShown"
143
- ref="dropdown"
144
- :bg-color="
145
- dropdownBgColor ||
146
- colorMode == 'dark' ||
147
- colorMode == 'transparent'
148
- ? 'black'
149
- : 'white'
150
- "
151
- :dropdown-position="dropdownPosition"
152
- :font-color="
153
- dropdownFontColor ||
154
- colorMode == 'dark' ||
155
- colorMode == 'transparent'
156
- ? 'white'
157
- : 'black'
158
- "
159
- :font-size="fontSize"
160
- :hovered-bg-color="
161
- colorMode == 'dark'
162
- ? '#000000'
163
- : colorMode == 'transparent'
164
- ? 'grey6'
165
- : dropdownBgColor
166
- "
167
- :hovered-index="hoveredIndex"
168
- :hovered-value="hoveredValue"
169
- :is-active="isActive"
170
- :min-width="minWidth"
171
- :no-relative="noRelative"
172
- :option-width="getOptionWidth"
173
- :selected-value="selectedValue"
174
- @mouseleave="optionLeave"
175
- @option-hovered="optionHovered"
176
- @option-selected="optionSelected"
177
- >
178
- <slot name="dropdown"></slot>
179
- </SelectDropdown>
180
- </Teleport>
181
- </DropdownWrapper>
182
- </SelectButtonWrapper>
183
- </InputWrapper>
184
- </Container>
185
- </template>
186
-
187
- <script>
188
- //How to use it
189
- // <Select
190
- // hoverDropdown="true"
191
- // selectWidth="100%"
192
- // minWidth="220px"
193
- // optionWidth="50%"
194
- // label="that is a label"
195
- // alignItems="vertical"
196
- // label-data-id="test-label-data-id"
197
- // data-id="test-data-id"
198
- // :hasSelectButtonPadding="false"
199
- // >
200
- // <template #selector="{selectedValue}">
201
- // value selected: {{selectedValue}}
202
- // </template>
203
- // <template #dropdown>
204
- // <Option value="1">value one</Option>
205
- // <Option value="2">value two</Option>
206
- // <Option value="3">value three</Option>
207
- // <Option value="4">value four</Option>
208
- // </template>
209
- // </Select>
210
-
211
- import { Teleport } from 'vue'
212
- import styled from 'vue3-styled-components'
213
- import InfoText from '../../infoText'
214
- import Icon from '../../icon'
215
- import InputText from '../inputText'
216
- import DraggableInputHandle from '../../draggableInputHandle'
217
- import { debounce } from '../../../utils'
218
-
219
- const CARET_WIDTH = '30px'
220
- const BORDER_WIDTH = '1px'
221
-
222
- const CaretAttrs = { colorMode: String }
223
- const Caret = styled('div', CaretAttrs)`
224
- display: flex;
225
- align-items: center;
226
- justify-content: center;
227
- width: ${(props) =>
228
- props.colorMode === 'transparent' ? '15px' : CARET_WIDTH};
229
- min-width: ${(props) =>
230
- props.colorMode === 'transparent' ? '15px' : CARET_WIDTH};
231
- height: 100%;
232
- align-items: center;
233
- cursor: pointer;
234
- margin-left: auto;
235
- `
236
-
237
- const selectorProps = {
238
- disabled: Boolean,
239
- selectWidth: String,
240
- paddingLeft: String,
241
- showBorder: Boolean,
242
- }
243
- const Selector = styled('div', selectorProps)`
244
- color: ${(props) => (props.disabled ? props.theme.colors.grey2 : '')};
245
- ${(props) =>
246
- props.selectWidth === '100%'
247
- ? 'width: 100%;'
248
- : `width: calc(${props.selectWidth} -
249
- (
250
- ${CARET_WIDTH} +
251
- ${props.paddingLeft}
252
- ${props.showBorder ? `+ (${BORDER_WIDTH} * 2)` : ''}
253
- )
254
- );
255
- white-space: nowrap;
256
- text-overflow: ellipsis;
257
- overflow: hidden;`}
258
- `
259
-
260
- const labelAttrs = { fontSize: String, fontColor: String }
261
- const InputLabel = styled('div', labelAttrs)`
262
- color: ${(props) =>
263
- props.theme.colors[props.fontColor]
264
- ? props.theme.colors[props.fontColor]
265
- : props.fontColor};
266
- font-size: ${(props) => props.fontSize};
267
- font-weight: 700;
268
- `
269
- const OptionalLabel = styled.span`
270
- font-weight: 300;
271
- text-transform: lowercase;
272
- `
273
- const inputProps = {
274
- selectWidth: String,
275
- optionWidth: String,
276
- noRelative: Boolean,
277
- }
278
- const Container = styled('div', inputProps)`
279
- width: ${(props) => props.selectWidth};
280
- position: ${(props) => (props.noRelative ? 'static' : 'relative')};
281
- display: inline-block;
282
- `
283
-
284
- const LabelWrapperAttrs = { infoTextMessage: Boolean }
285
- const LabelWrapper = styled('div', LabelWrapperAttrs)`
286
- display: inline-grid;
287
- grid-template-columns: ${(props) =>
288
- props.infoTextMessage ? 'auto auto' : 'auto'};
289
- grid-gap: 12px;
290
- align-items: center;
291
- justify-content: start;
292
- `
293
-
294
- const SelectButtonWrapperAttrs = {
295
- disabled: Boolean,
296
- }
297
- const SelectButtonWrapper = styled('div', SelectButtonWrapperAttrs)`
298
- ${(props) => (props.disabled ? 'cursor: not-allowed' : 'cursor: pointer')};
299
- `
300
-
301
- const selectButtonAttrs = {
302
- bgColor: String,
303
- fontColor: String,
304
- hasError: Boolean,
305
- disabled: Boolean,
306
- selectHeight: String,
307
- selectWidth: String,
308
- height: String,
309
- selectMinHeight: String,
310
- hasNoPadding: Boolean,
311
- showBorder: Boolean,
312
- paddingLeft: String,
313
- noRelative: Boolean,
314
- tablePaddingLeft: String,
315
- showDisabledBackground: Boolean,
316
- colorMode: String,
317
- isSearchBarVisible: Boolean,
318
- }
319
- const SelectButton = styled('div', selectButtonAttrs)`
320
- position: ${(props) => (props.noRelative ? 'static' : 'relative')};
321
- box-sizing: border-box;
322
- border-radius: 4px;
323
- max-width: ${(props) => (props.selectWidth ? props.selectWidth : '100%')};
324
- ${(props) =>
325
- props.colorMode === 'transparent'
326
- ? props.isSearchBarVisible
327
- ? 'padding: 10px 15px 10px 5px;'
328
- : 'padding: 10px 15px;'
329
- : props.isSearchBarVisible
330
- ? ''
331
- : `padding-left: ${
332
- props.hasNoPadding
333
- ? '0'
334
- : props.tablePaddingLeft
335
- ? props.tablePaddingLeft
336
- : props.paddingLeft
337
- }`};
338
- text-align: left;
339
- min-height: ${(props) =>
340
- props.selectHeight
341
- ? props.selectHeight
342
- : props.selectMinHeight
343
- ? props.selectMinHeight
344
- : props.height
345
- ? props.height
346
- : '36px'};
347
- display: flex;
348
- align-items: center;
349
- height: ${(props) => props.selectHeight};
350
- ${({ showBorder, theme, hasError }) =>
351
- showBorder &&
352
- `
353
- border: ${BORDER_WIDTH} solid ${
354
- hasError ? theme.colors.red : theme.colors.grey4
355
- }
356
- `}
357
- opacity: ${(props) =>
358
- props.colorMode === 'transparent' && props.disabled ? '0.4' : '1'};
359
- background-color: ${(props) =>
360
- props.colorMode === 'transparent'
361
- ? 'transparent'
362
- : props.disabled && props.showDisabledBackground
363
- ? props.theme.colors.grey5
364
- : props.theme.colors[props.bgColor]
365
- ? props.theme.colors[props.bgColor]
366
- : props.bgColor};
367
- color: ${(props) =>
368
- props.colorMode === 'transparent'
369
- ? props.theme.colors.white
370
- : props.disabled && props.showDisabledBackground
371
- ? props.theme.colors.black
372
- : props.theme.colors[props.fontColor]
373
- ? props.theme.colors[props.fontColor]
374
- : props.fontColor};
375
- ${(props) => (props.disabled ? 'pointer-events: none' : '')};
376
- overflow: hidden;
377
- & > .handle {
378
- border-right: ${(props) =>
379
- props.hasError ? props.theme.colors.red : props.theme.colors.grey4}
380
- 1px solid;
381
- }
382
- `
383
- const selectDropdownAttrs = {
384
- hoveredBgColor: String,
385
- bgColor: String,
386
- fontColor: String,
387
- optionWidth: String,
388
- hoveredIndex: Number,
389
- fontSize: String,
390
- dropdownPosition: Object,
391
- hoveredValue: Number | String,
392
- selectedValue: Number | String,
393
- noRelative: Boolean,
394
- minWidth: String,
395
- }
396
- const SelectDropdown = styled('div', selectDropdownAttrs)`
397
- box-sizing: border-box;
398
- z-index: ${(props) => (props.isActive ? '2' : '99999')};
399
- position: absolute;
400
- top: ${(props) =>
401
- props.noRelative ? 'auto' : props.dropdownPosition?.top + 'px'};
402
- left: ${(props) => props.dropdownPosition?.left}px;
403
- border: ${BORDER_WIDTH} solid ${(props) => props.theme.colors.grey4};
404
- border-radius: 4px;
405
- display: flex;
406
- flex-direction: column;
407
- align-items: flex-start;
408
- padding: 0px;
409
- box-shadow: 0px 8px 16px 0px rgba(0, 0, 0, 0.2);
410
- width: ${(props) => (props.optionWidth ? props.optionWidth : '100%')};
411
- min-width: ${(props) =>
412
- props.minWidth
413
- ? props.minWidth
414
- : props.optionWidth
415
- ? props.optionWidth
416
- : '100%'};
417
- background-color: ${(props) =>
418
- props.theme.colors[props.bgColor]
419
- ? props.theme.colors[props.bgColor]
420
- : props.bgColor};
421
- color: ${(props) =>
422
- props.theme.colors[props.fontColor]
423
- ? props.theme.colors[props.fontColor]
424
- : props.fontColor};
425
- max-height: 300px;
426
- overflow-y: auto;
427
- & > div[data-value='${(props) => props.hoveredValue}'] {
428
- background-color: ${(props) =>
429
- props.theme.colors[props.hoveredBgColor]
430
- ? props.theme.colors[props.hoveredBgColor]
431
- : props.hoveredBgColor};
432
- }
433
- font-size: ${(props) => props.fontSize};
434
- `
435
- SelectDropdown.emits = ['option-hovered', 'option-selected']
436
- const DropdownAttrs = { noRelative: Boolean }
437
- const DropdownWrapper = styled('div', DropdownAttrs)`
438
- position: ${(props) => (props.noRelative ? 'static' : 'relative')};
439
- `
440
- const inputAttrs = {
441
- alignItems: String,
442
- hasLabel: Boolean,
443
- noRelative: Boolean,
444
- }
445
- const InputWrapper = styled('div', inputAttrs)`
446
- position: ${(props) => (props.noRelative ? 'static' : 'relative')};
447
- display: grid;
448
- width: 100%;
449
- min-width: ${(props) => (props.minWidth ? props.minWidth : '150px')};
450
- align-items: center;
451
- gap: 8px;
452
- grid-template-columns: ${(props) =>
453
- props.alignItems === 'vertical' || !props.hasLabel ? '1fr' : 'auto 1fr'};
454
- `
455
-
456
- const DROPDOWN_HEIGHT_OFFSET = 4
457
- const DROPDOWN_TOP_OFFSET = 21
458
- const MIN_OPTION_LENGTH = 5
459
-
460
- const DROPDOWN_MENU_POSITIONS = {
461
- Automatic: 'automatic',
462
- Bottom: 'bottom',
463
- }
464
-
465
- export default {
466
- name: 'RCselect',
467
-
468
- components: {
469
- SelectButton,
470
- SelectButtonWrapper,
471
- SelectDropdown,
472
- Container,
473
- InputLabel,
474
- LabelWrapper,
475
- OptionalLabel,
476
- InfoText,
477
- InputWrapper,
478
- DropdownWrapper,
479
- Icon,
480
- Caret,
481
- Selector,
482
- InputText,
483
- Teleport,
484
- DraggableInputHandle,
485
- },
486
-
487
- props: {
488
- value: {
489
- required: false,
490
- default: null,
491
- },
492
- fontSize: {
493
- required: false,
494
- default: '13px',
495
- },
496
- noRelative: {
497
- required: false,
498
- default: false,
499
- },
500
- label: {
501
- required: false,
502
- },
503
- labelOptional: {
504
- required: false,
505
- default: false,
506
- },
507
- labelDataId: {
508
- required: false,
509
- default: '',
510
- },
511
- infoTextMessage: {
512
- required: false,
513
- },
514
- selectWidth: {
515
- type: String,
516
- required: false,
517
- default: '100%',
518
- },
519
- minWidth: {
520
- required: false,
521
- },
522
- maxWidth: {
523
- required: false,
524
- },
525
- selectHeight: {
526
- type: String,
527
- required: false,
528
- default: null,
529
- },
530
- height: {
531
- required: false,
532
- default: null,
533
- },
534
- selectMinHeight: {
535
- required: false,
536
- default: '36px',
537
- },
538
- optionWidth: {
539
- required: false,
540
- default: null,
541
- },
542
- hoverDropdown: {
543
- required: false,
544
- default: false,
545
- },
546
- dropdownAutoClose: {
547
- required: false,
548
- default: false,
549
- },
550
- alignItems: {
551
- required: false,
552
- default: 'horizontal',
553
- },
554
- buttonBgColor: {
555
- required: false,
556
- },
557
- buttonFontColor: {
558
- required: false,
559
- },
560
- dropdownBgColor: {
561
- required: false,
562
- default: 'grey5',
563
- },
564
- dropdownFontColor: {
565
- required: false,
566
- },
567
- dropDownArrowVisible: {
568
- required: false,
569
- default: true,
570
- },
571
- caretColor: {
572
- required: false,
573
- },
574
- labelFontColor: {
575
- required: false,
576
- },
577
- colorMode: {
578
- required: false,
579
- default: 'light',
580
- },
581
- isSearchable: {
582
- required: false,
583
- default: true,
584
- },
585
- hasError: {
586
- required: false,
587
- default: false,
588
- },
589
- disabled: {
590
- required: false,
591
- type: Boolean,
592
- default: false,
593
- },
594
- isAutoSearch: {
595
- required: false,
596
- default: true,
597
- },
598
- showBorder: {
599
- required: false,
600
- default: true,
601
- },
602
- infoTextSize: {
603
- required: false,
604
- default: '14px',
605
- },
606
- dataId: {
607
- type: String,
608
- default: '',
609
- },
610
- dataQaId: {
611
- type: String,
612
- default: '',
613
- },
614
- hasSelectButtonPadding: {
615
- required: false,
616
- type: Boolean,
617
- default: true,
618
- },
619
- isDraggable: {
620
- type: Boolean,
621
- default: false,
622
- },
623
- leftPadding: {
624
- type: String,
625
- default: '15px',
626
- },
627
- tablePaddingLeft: {
628
- required: false,
629
- },
630
- showDisabledBackground: {
631
- required: false,
632
- default: true,
633
- },
634
- minOptionLength: {
635
- type: Number,
636
- default: MIN_OPTION_LENGTH,
637
- },
638
- dropdownMenuPosition: {
639
- type: String,
640
- default: DROPDOWN_MENU_POSITIONS.Automatic, // options: ['automatic', bottom]
641
- },
642
- infoTextWidth: {
643
- type: String,
644
- required: false,
645
- },
646
- infoTextAlignArrow: {
647
- type: String,
648
- required: false,
649
- },
650
- },
651
-
652
- data() {
653
- return {
654
- selectedValue: null,
655
- paddingLeft: this.isDraggable ? '30px' : this.leftPadding,
656
- isDropdownOpen: false,
657
- isActive: false,
658
- textSearch: '',
659
- hoveredIndex: 0,
660
- isClickOutsideActive: false,
661
- dropdownPosition: {
662
- left: null,
663
- top: null,
664
- },
665
- dropdownWidth: null,
666
- hoveredValue: null,
667
- }
668
- },
669
- computed: {
670
- optionLength() {
671
- if (this.isDropdownOpen) {
672
- return this.$refs.dropdown.$el.childElementCount > 1
673
- ? this.$refs.dropdown.$el.childElementCount
674
- : this.$refs.dropdown.$el.children[0]
675
- ? this.$refs.dropdown.$el.children[0].childElementCount
676
- : 0
677
- }
678
-
679
- return 0
680
- },
681
- isSearchBarVisible() {
682
- return (
683
- this.isSearchable &&
684
- this.optionLength >= this.minOptionLength &&
685
- this.isDropdownOpen
686
- )
687
- },
688
- computedWidth() {
689
- function removePX(item) {
690
- return Number(item.replace('px', ''))
691
- }
692
-
693
- return this.selectWidth === '100%'
694
- ? '100%'
695
- : removePX(this.selectWidth) - removePX(CARET_WIDTH) + 'px'
696
- },
697
- getOptionWidth() {
698
- if (this.optionWidth) return this.optionWidth
699
-
700
- return this.dropdownWidth
701
- },
702
- isSelectDropdownShown() {
703
- return (
704
- this.isDropdownOpen &&
705
- this.dropdownPosition.left !== null &&
706
- (!this.isSearchable || this.isSearchable)
707
- )
708
- },
709
- isMobileDevice() {
710
- const userAgent =
711
- navigator.userAgent || navigator.vendor || window.opera
712
- const touchCapable =
713
- 'ontouchstart' in window ||
714
- navigator.maxTouchPoints > 0 ||
715
- navigator.msMaxTouchPoints > 0
716
-
717
- return (
718
- /Android/i.test(userAgent) ||
719
- /iPad|iPhone|iPod/.test(userAgent) ||
720
- (/Macintosh/.test(userAgent) && touchCapable) ||
721
- /windows phone/i.test(userAgent)
722
- )
723
- },
724
- },
725
- watch: {
726
- value(val) {
727
- this.selectedValue = val
728
- },
729
- async isDropdownOpen(val) {
730
- if (val) {
731
- this.$emit('on-dropdown-open')
732
- setTimeout(() => {
733
- this.isClickOutsideActive = true
734
- }, 10)
735
- await this.$nextTick()
736
- this.handleSetDropdownOffet()
737
- } else {
738
- this.dropdownPosition.left = null
739
- setTimeout(() => {
740
- this.isClickOutsideActive = false
741
- }, 10)
742
- }
743
- if (val && this.isSearchable) {
744
- this.$nextTick(() => {
745
- if (this.$refs.searchInput && !this.isMobileDevice) {
746
- this.$refs.searchInput.$el.querySelector('input').focus()
747
- }
748
- })
749
- }
750
- },
751
- },
752
- mounted() {
753
- this.observeDropdownHeight()
754
- this.observeSelectWidth()
755
- window.addEventListener('resize', this.handleSetDropdownOffet)
756
- },
757
- beforeMount() {
758
- this.selectedValue = this.value
759
- document.addEventListener('click', this.clickOutside)
760
- this.getDropdownPosition()
761
- window.removeEventListener('resize', this.handleSetDropdownOffet)
762
- if (this.dropdownResizeObserver) this.dropdownResizeObserver.disconnect()
763
- if (this.selectResizeObserver) this.selectResizeObserver.disconnect()
764
- },
765
- unmounted() {
766
- document.removeEventListener('click', this.clickOutside)
767
- },
768
- methods: {
769
- focus() {
770
- this.isActive = true
771
- },
772
- blur(e) {
773
- this.isActive = false
774
- this.$emit('blur', e)
775
- },
776
- toggleDropdown() {
777
- this.isDropdownOpen = !this.isDropdownOpen
778
- },
779
- toggleCaretDropdown() {
780
- this.isDropdownOpen = !this.isDropdownOpen
781
- },
782
- closeDropdown() {
783
- this.blur()
784
- this.clearSearch()
785
- this.isDropdownOpen = false
786
- },
787
- clearSearch() {
788
- this.textSearch = ''
789
- this.searchChange('')
790
- },
791
- optionSelected(e) {
792
- this.selectedValue = e
793
- this.closeDropdown()
794
- this.blur()
795
- this.$emit('input-change', e)
796
- },
797
- optionHovered: debounce(function (e) {
798
- this.hoveredValue = e
799
- }, 300),
800
- mouseEnterHandler() {
801
- if (this.hoverDropdown) {
802
- this.focus()
803
- this.isDropdownOpen = true
804
- }
805
- },
806
- mouseLeaveHandler() {
807
- if (this.hoverDropdown) {
808
- this.blur()
809
- }
810
- },
811
- optionLeave() {
812
- if (this.dropdownAutoClose) {
813
- this.isDropdownOpen = false
814
- }
815
- },
816
- searchChange(value) {
817
- this.textSearch = value
818
- this.$emit('search-change', value)
819
- const dropdownChildren = [...this.$refs.dropdown.$el.children]
820
- dropdownChildren.forEach((el) => {
821
- if (!el.textContent.toLowerCase().includes(value.toLowerCase())) {
822
- el.style.display = 'none'
823
-
824
- return
825
- }
826
-
827
- el.style.display = 'inherit'
828
- })
829
- },
830
- clickOutside(event) {
831
- const dropdownRef = this.$refs.dropdown
832
- // we need to prevent closing on selecting an option, because in the case of
833
- // a disabled option, we don't want to close the dropdown
834
- if (!this.isClickOutsideActive) return
835
- if (
836
- this.$refs.select.$el == event.target ||
837
- this.$refs.select.$el.contains(event.target) ||
838
- event.target.id === 'more-button' ||
839
- event.target.parentNode === dropdownRef.$el
840
- ) {
841
- return
842
- } else {
843
- this.closeDropdown()
844
- }
845
- },
846
- onKeyDown(e) {
847
- if (e.key == 'ArrowDown') {
848
- this.onArrowPress(1)
849
- } else if (e.key == 'ArrowUp') {
850
- this.onArrowPress(-1)
851
- } else if (e.key == 'Enter') {
852
- const optionHoveredComponent = [...this.$refs.dropdown.$el.children][
853
- (this.hoveredIndex - 1 + this.optionLength) % this.optionLength
854
- ]
855
- this.optionSelected(optionHoveredComponent.$el.dataset.value)
856
- }
857
- },
858
- // If some part of the dropdown menu is outside viewport of the bottom of the screen,
859
- // we need to offset it and display it at the top of the select dropdown instead
860
- async getDropdownPosition() {
861
- if (
862
- !this.$refs.dropdownWrapperRef ||
863
- !this.$refs.select ||
864
- !this.$refs.dropdown
865
- ) {
866
- return
867
- }
868
- await this.$nextTick()
869
- const isDisplayedAtBottom = await this.generateDropdownPosition()
870
- // If the dropdown menu is going to be displayed at the bottom,
871
- // we need reverify its position after a dom update (nextTick)
872
- await this.$nextTick()
873
- if (isDisplayedAtBottom) this.generateDropdownPosition()
874
- },
875
- async generateDropdownPosition() {
876
- const isDropdownNotCompletelyVisible =
877
- await this.isBottomOfDropdownOutOfViewport()
878
- const dropdownWrapperEl = this.$refs.dropdownWrapperRef.$el
879
- const selectButtonHeight = this.$refs.select.$el.clientHeight
880
- const dropdownHeight = this.$refs.dropdown.$el.clientHeight
881
- const dropdownWrapperRelativeHeight =
882
- dropdownWrapperEl.getBoundingClientRect().top +
883
- window.scrollY +
884
- DROPDOWN_HEIGHT_OFFSET
885
-
886
- const top =
887
- isDropdownNotCompletelyVisible ||
888
- (!isDropdownNotCompletelyVisible &&
889
- this.dropdownMenuPosition === DROPDOWN_MENU_POSITIONS.Bottom)
890
- ? dropdownWrapperRelativeHeight
891
- : dropdownWrapperRelativeHeight -
892
- dropdownHeight -
893
- selectButtonHeight -
894
- DROPDOWN_TOP_OFFSET
895
- const left = this.dropdownPosition.left
896
- ? this.dropdownPosition.left
897
- : dropdownWrapperEl.getBoundingClientRect().left + window.scrollX
898
-
899
- this.dropdownPosition = { left: Math.floor(left), top: Math.floor(top) }
900
-
901
- return isDropdownNotCompletelyVisible
902
- },
903
- async isBottomOfDropdownOutOfViewport() {
904
- if (
905
- !this.$refs.dropdown ||
906
- this.dropdownMenuPosition === DROPDOWN_MENU_POSITIONS.Bottom
907
- ) {
908
- return false
909
- }
910
-
911
- await this.$nextTick()
912
- const rect = this.$refs.dropdown.$el.getBoundingClientRect()
913
- const windowHeight =
914
- window.innerHeight || document.documentElement.clientHeight
915
-
916
- if (windowHeight <= 650) return true
917
-
918
- // using Math.floor because the offsets may contain decimals we are not going to consider here
919
- return Math.floor(rect.top) + Math.floor(rect.height) <= windowHeight
920
- },
921
- observeDropdownHeight() {
922
- if (!this.$refs.dropdown) return
923
- this.dropdownResizeObserver = new ResizeObserver(() => {
924
- this.$nextTick(() => this.getDropdownPosition())
925
- })
926
- this.dropdownResizeObserver.observe(this.$refs.dropdown.$el)
927
- },
928
- handleSetDropdownOffet() {
929
- if (!this.$refs.select) return
930
- this.dropdownPosition.left = Math.floor(
931
- this.$refs.select.$el.getBoundingClientRect().left
932
- )
933
- this.getDropdownWidth()
934
- },
935
- observeSelectWidth() {
936
- if (!this.$refs.select) return
937
- this.selectResizeObserver = new ResizeObserver(() =>
938
- // eslint-disable-next-line vue/valid-next-tick
939
- this.$nextTick(() => this.getDropdownWidth())
940
- )
941
- this.selectResizeObserver.observe(this.$refs.dropdown.$el)
942
- },
943
- async getDropdownWidth() {
944
- if (!this.$refs.select) return
945
- await this.$nextTick()
946
- this.dropdownWidth = `${this.$refs.select.$el.clientWidth}px`
947
- },
948
- onArrowPress(dir) {
949
- let newHoveredElem
950
- const currentHoveredElem = this.$refs.dropdown.$el.querySelector(
951
- `[data-value="${this.hoveredValue}"]`
952
- )
953
- if (currentHoveredElem) {
954
- if (dir > 0) {
955
- newHoveredElem = currentHoveredElem.nextElementSibling
956
- } else {
957
- newHoveredElem = currentHoveredElem.previousElementSibling
958
- }
959
- if (newHoveredElem) {
960
- this.hoveredValue = newHoveredElem.getAttribute('data-value')
961
- const topPos = newHoveredElem.offsetTop
962
- this.$refs.dropdown.$el.scrollTop = topPos
963
- }
964
- }
965
- },
966
- },
967
- }
968
- </script>
1
+ <template>
2
+ <Container
3
+ :no-relative="noRelative"
4
+ :select-width="selectWidth"
5
+ @mouseenter="mouseEnterHandler"
6
+ @mouseleave="mouseLeaveHandler"
7
+ >
8
+ <InputWrapper
9
+ :align-items="alignItems"
10
+ :has-label="!!label && label.length > 0"
11
+ :no-relative="noRelative"
12
+ >
13
+ <LabelWrapper
14
+ v-if="label"
15
+ :data-id="labelDataId"
16
+ :data-qa-id="dataQaId + '_label'"
17
+ :info-text-message="!!infoTextMessage || !!$slots.infoText"
18
+ >
19
+ <InputLabel
20
+ :font-color="
21
+ labelFontColor || colorMode == 'dark' || colorMode == 'transparent'
22
+ ? 'white'
23
+ : 'eturnityGrey'
24
+ "
25
+ :font-size="fontSize"
26
+ >{{ label }}
27
+ <OptionalLabel v-if="labelOptional">
28
+ ({{ $gettext('Optional') }})</OptionalLabel
29
+ >
30
+ </InputLabel>
31
+ <InfoText
32
+ v-if="infoTextMessage || !!$slots.infoText"
33
+ :align-arrow="infoTextAlignArrow"
34
+ :max-width="infoTextWidth"
35
+ :size="infoTextSize"
36
+ :text="infoTextMessage"
37
+ :width="infoTextWidth"
38
+ >
39
+ <slot name="infoText"></slot>
40
+ </InfoText>
41
+ </LabelWrapper>
42
+ <SelectButtonWrapper :disabled="disabled">
43
+ <SelectButton
44
+ ref="select"
45
+ :bg-color="
46
+ buttonBgColor || colorMode == 'dark'
47
+ ? 'transparentBlack1'
48
+ : colorMode == 'transparent'
49
+ ? 'transparent'
50
+ : 'white'
51
+ "
52
+ class="select-button"
53
+ :color-mode="colorMode"
54
+ :data-id="dataId"
55
+ :data-qa-id="dataQaId"
56
+ :disabled="disabled"
57
+ :font-color="
58
+ buttonFontColor || colorMode == 'dark' || colorMode == 'transparent'
59
+ ? 'white'
60
+ : 'black'
61
+ "
62
+ :font-size="fontSize"
63
+ :has-error="hasError"
64
+ :has-no-padding="isSearchBarVisible || !hasSelectButtonPadding"
65
+ :height="height"
66
+ :is-search-bar-visible="isSearchBarVisible"
67
+ :no-relative="noRelative"
68
+ :padding-left="paddingLeft"
69
+ :select-height="selectHeight"
70
+ :select-min-height="selectMinHeight"
71
+ :select-width="selectWidth"
72
+ :show-border="showBorder"
73
+ :show-disabled-background="showDisabledBackground"
74
+ :table-padding-left="tablePaddingLeft"
75
+ @click="toggleDropdown"
76
+ @keydown="onKeyDown"
77
+ >
78
+ <DraggableInputHandle
79
+ v-if="isDraggable && !isSearchBarVisible"
80
+ :height="selectHeight"
81
+ />
82
+ <InputText
83
+ v-if="isSearchBarVisible"
84
+ ref="searchInput"
85
+ background-color="transparent"
86
+ :font-color="
87
+ buttonFontColor ||
88
+ colorMode == 'dark' ||
89
+ colorMode == 'transparent'
90
+ ? 'white'
91
+ : 'black'
92
+ "
93
+ :font-size="fontSize"
94
+ input-height="34px"
95
+ :input-width="computedWidth"
96
+ :no-border="true"
97
+ tabindex="0"
98
+ :value="textSearch"
99
+ @click.stop
100
+ @input-change="searchChange"
101
+ @keydown.stop="onKeyDown"
102
+ />
103
+ <Selector
104
+ v-else
105
+ :disabled="disabled"
106
+ :padding-left="paddingLeft"
107
+ :select-width="selectWidth"
108
+ :show-border="showBorder"
109
+ >
110
+ <slot name="selector" :selected-value="selectedValue"></slot>
111
+ </Selector>
112
+ <Caret class="caret_dropdown" :color-mode="colorMode">
113
+ <Icon
114
+ v-if="isDropdownOpen"
115
+ :color="
116
+ caretColor || colorMode == 'dark' || colorMode == 'transparent'
117
+ ? 'white'
118
+ : 'transparentBlack1'
119
+ "
120
+ name="arrow_up"
121
+ :size="colorMode === 'transparent' ? '8px' : '12px'"
122
+ />
123
+ <Icon
124
+ v-else
125
+ :color="
126
+ caretColor || colorMode == 'dark' || colorMode == 'transparent'
127
+ ? 'white'
128
+ : 'transparentBlack1'
129
+ "
130
+ name="arrow_down"
131
+ :size="colorMode === 'transparent' ? '8px' : '12px'"
132
+ />
133
+ </Caret>
134
+ </SelectButton>
135
+ <DropdownWrapper ref="dropdownWrapperRef" :no-relative="noRelative">
136
+ <Teleport to="body">
137
+ <SelectDropdown
138
+ v-show="isSelectDropdownShown"
139
+ ref="dropdown"
140
+ :bg-color="
141
+ colorMode == 'dark' || colorMode == 'transparent'
142
+ ? 'black'
143
+ : 'white'
144
+ "
145
+ class="rc-select-dropdown"
146
+ :dropdown-position="dropdownPosition"
147
+ :font-color="
148
+ dropdownFontColor ||
149
+ colorMode == 'dark' ||
150
+ colorMode == 'transparent'
151
+ ? 'white'
152
+ : 'black'
153
+ "
154
+ :font-size="fontSize"
155
+ :hovered-bg-color="
156
+ colorMode == 'dark'
157
+ ? '#000000'
158
+ : colorMode == 'transparent'
159
+ ? 'grey6'
160
+ : dropdownBgColor
161
+ "
162
+ :hovered-index="hoveredIndex"
163
+ :hovered-value="hoveredValue"
164
+ :is-active="isActive"
165
+ :is-fixed-dropdown-position="isFixedDropdownPosition"
166
+ :is-parent-modal="isParentModal"
167
+ :min-width="minWidth"
168
+ :no-relative="noRelative"
169
+ :option-width="getOptionWidth"
170
+ :selected-value="selectedValue"
171
+ :style="{
172
+ transform: `translate(${dropdownPosition?.left}px, ${
173
+ noRelative ? 'auto' : `${dropdownPosition?.top}px`
174
+ })`,
175
+ }"
176
+ @mouseleave="optionLeave"
177
+ @option-hovered="optionHovered"
178
+ @option-selected="optionSelected"
179
+ >
180
+ <slot name="dropdown"></slot>
181
+ </SelectDropdown>
182
+ </Teleport>
183
+ </DropdownWrapper>
184
+ </SelectButtonWrapper>
185
+ </InputWrapper>
186
+ </Container>
187
+ </template>
188
+
189
+ <script>
190
+ //How to use it
191
+ // <Select
192
+ // hoverDropdown="true"
193
+ // selectWidth="100%"
194
+ // minWidth="220px"
195
+ // optionWidth="50%"
196
+ // label="that is a label"
197
+ // alignItems="vertical"
198
+ // label-data-id="test-label-data-id"
199
+ // data-id="test-data-id"
200
+ // :hasSelectButtonPadding="false"
201
+ // >
202
+ // <template #selector="{selectedValue}">
203
+ // value selected: {{selectedValue}}
204
+ // </template>
205
+ // <template #dropdown>
206
+ // <Option value="1">value one</Option>
207
+ // <Option value="2">value two</Option>
208
+ // <Option value="3">value three</Option>
209
+ // <Option value="4">value four</Option>
210
+ // </template>
211
+ // </Select>
212
+
213
+ import { Teleport, inject } from 'vue'
214
+ import styled from 'vue3-styled-components'
215
+ import InfoText from '../../infoText'
216
+ import Icon from '../../icon'
217
+ import InputText from '../inputText'
218
+ import DraggableInputHandle from '../../draggableInputHandle'
219
+ import { debounce } from '../../../utils'
220
+
221
+ const CARET_WIDTH = '30px'
222
+ const BORDER_WIDTH = '1px'
223
+
224
+ const CaretAttrs = { colorMode: String }
225
+ const Caret = styled('div', CaretAttrs)`
226
+ display: flex;
227
+ align-items: center;
228
+ justify-content: center;
229
+ width: ${(props) =>
230
+ props.colorMode === 'transparent' ? '15px' : CARET_WIDTH};
231
+ min-width: ${(props) =>
232
+ props.colorMode === 'transparent' ? '15px' : CARET_WIDTH};
233
+ height: 100%;
234
+ align-items: center;
235
+ cursor: pointer;
236
+ margin-left: auto;
237
+ `
238
+
239
+ const selectorProps = {
240
+ disabled: Boolean,
241
+ selectWidth: String,
242
+ paddingLeft: String,
243
+ showBorder: Boolean,
244
+ }
245
+ const Selector = styled('div', selectorProps)`
246
+ color: ${(props) => (props.disabled ? props.theme.colors.grey2 : '')};
247
+ ${(props) =>
248
+ props.selectWidth === '100%'
249
+ ? 'width: 100%;'
250
+ : `width: calc(${props.selectWidth} -
251
+ (
252
+ ${CARET_WIDTH} +
253
+ ${props.paddingLeft}
254
+ ${props.showBorder ? `+ (${BORDER_WIDTH} * 2)` : ''}
255
+ )
256
+ );
257
+ white-space: nowrap;
258
+ text-overflow: ellipsis;
259
+ overflow: hidden;`}
260
+ `
261
+
262
+ const labelAttrs = { fontSize: String, fontColor: String }
263
+ const InputLabel = styled('div', labelAttrs)`
264
+ color: ${(props) =>
265
+ props.theme.colors[props.fontColor]
266
+ ? props.theme.colors[props.fontColor]
267
+ : props.fontColor};
268
+ font-size: ${(props) => props.fontSize};
269
+ font-weight: 700;
270
+ `
271
+ const OptionalLabel = styled.span`
272
+ font-weight: 300;
273
+ text-transform: lowercase;
274
+ `
275
+ const inputProps = {
276
+ selectWidth: String,
277
+ optionWidth: String,
278
+ noRelative: Boolean,
279
+ }
280
+ const Container = styled('div', inputProps)`
281
+ width: ${(props) => props.selectWidth};
282
+ position: ${(props) => (props.noRelative ? 'static' : 'relative')};
283
+ display: inline-block;
284
+ `
285
+
286
+ const LabelWrapperAttrs = { infoTextMessage: Boolean }
287
+ const LabelWrapper = styled('div', LabelWrapperAttrs)`
288
+ display: inline-grid;
289
+ grid-template-columns: ${(props) =>
290
+ props.infoTextMessage ? 'auto auto' : 'auto'};
291
+ grid-gap: 12px;
292
+ align-items: center;
293
+ justify-content: start;
294
+ `
295
+
296
+ const SelectButtonWrapperAttrs = {
297
+ disabled: Boolean,
298
+ }
299
+ const SelectButtonWrapper = styled('div', SelectButtonWrapperAttrs)`
300
+ ${(props) => (props.disabled ? 'cursor: not-allowed' : 'cursor: pointer')};
301
+ `
302
+
303
+ const selectButtonAttrs = {
304
+ bgColor: String,
305
+ fontColor: String,
306
+ hasError: Boolean,
307
+ disabled: Boolean,
308
+ selectHeight: String,
309
+ selectWidth: String,
310
+ height: String,
311
+ selectMinHeight: String,
312
+ hasNoPadding: Boolean,
313
+ showBorder: Boolean,
314
+ paddingLeft: String,
315
+ noRelative: Boolean,
316
+ tablePaddingLeft: String,
317
+ showDisabledBackground: Boolean,
318
+ colorMode: String,
319
+ isSearchBarVisible: Boolean,
320
+ }
321
+ const SelectButton = styled('div', selectButtonAttrs)`
322
+ position: ${(props) => (props.noRelative ? 'static' : 'relative')};
323
+ box-sizing: border-box;
324
+ border-radius: 4px;
325
+ max-width: ${(props) => (props.selectWidth ? props.selectWidth : '100%')};
326
+ ${(props) =>
327
+ props.colorMode === 'transparent'
328
+ ? props.isSearchBarVisible
329
+ ? 'padding: 10px 15px 10px 5px;'
330
+ : 'padding: 10px 15px;'
331
+ : props.isSearchBarVisible
332
+ ? ''
333
+ : `padding-left: ${
334
+ props.hasNoPadding
335
+ ? '0'
336
+ : props.tablePaddingLeft
337
+ ? props.tablePaddingLeft
338
+ : props.paddingLeft
339
+ }`};
340
+ text-align: left;
341
+ min-height: ${(props) =>
342
+ props.selectHeight
343
+ ? props.selectHeight
344
+ : props.selectMinHeight
345
+ ? props.selectMinHeight
346
+ : props.height
347
+ ? props.height
348
+ : '36px'};
349
+ display: flex;
350
+ align-items: center;
351
+ height: ${(props) => props.selectHeight};
352
+ ${({ showBorder, theme, hasError }) =>
353
+ showBorder &&
354
+ `
355
+ border: ${BORDER_WIDTH} solid ${
356
+ hasError ? theme.colors.red : theme.colors.grey4
357
+ }
358
+ `}
359
+ opacity: ${(props) =>
360
+ props.colorMode === 'transparent' && props.disabled ? '0.4' : '1'};
361
+ background-color: ${(props) =>
362
+ props.colorMode === 'transparent'
363
+ ? 'transparent'
364
+ : props.disabled && props.showDisabledBackground
365
+ ? props.theme.colors.grey5
366
+ : props.theme.colors[props.bgColor]
367
+ ? props.theme.colors[props.bgColor]
368
+ : props.bgColor};
369
+ color: ${(props) =>
370
+ props.colorMode === 'transparent'
371
+ ? props.theme.colors.white
372
+ : props.disabled && props.showDisabledBackground
373
+ ? props.theme.colors.black
374
+ : props.theme.colors[props.fontColor]
375
+ ? props.theme.colors[props.fontColor]
376
+ : props.fontColor};
377
+ ${(props) => (props.disabled ? 'pointer-events: none' : '')};
378
+ overflow: hidden;
379
+ & > .handle {
380
+ border-right: ${(props) =>
381
+ props.hasError ? props.theme.colors.red : props.theme.colors.grey4}
382
+ 1px solid;
383
+ }
384
+ `
385
+ const selectDropdownAttrs = {
386
+ hoveredBgColor: String,
387
+ bgColor: String,
388
+ fontColor: String,
389
+ optionWidth: String,
390
+ hoveredIndex: Number,
391
+ fontSize: String,
392
+ dropdownPosition: Object,
393
+ hoveredValue: Number | String,
394
+ selectedValue: Number | String,
395
+ noRelative: Boolean,
396
+ minWidth: String,
397
+ isParentModal: Boolean,
398
+ isFixedDropdownPosition: Boolean,
399
+ }
400
+ const SelectDropdown = styled('div', selectDropdownAttrs)`
401
+ box-sizing: border-box;
402
+ z-index: ${(props) =>
403
+ props.isActive ? '2' : props.isParentModal ? '9999999' : '99999'};
404
+ position: ${(props) =>
405
+ props.isFixedDropdownPosition ? 'fixed' : 'absolute'};
406
+ top: 0px;
407
+ left: 0px;
408
+ border: ${BORDER_WIDTH} solid ${(props) => props.theme.colors.grey4};
409
+ border-radius: 4px;
410
+ display: flex;
411
+ flex-direction: column;
412
+ align-items: flex-start;
413
+ padding: 0px;
414
+ box-shadow: 0px 8px 16px 0px rgba(0, 0, 0, 0.2);
415
+ width: ${(props) => (props.optionWidth ? props.optionWidth : '100%')};
416
+ min-width: ${(props) =>
417
+ props.minWidth
418
+ ? props.minWidth
419
+ : props.optionWidth
420
+ ? props.optionWidth
421
+ : '100%'};
422
+ background-color: ${(props) =>
423
+ props.theme.colors[props.bgColor]
424
+ ? props.theme.colors[props.bgColor]
425
+ : props.bgColor};
426
+ color: ${(props) =>
427
+ props.theme.colors[props.fontColor]
428
+ ? props.theme.colors[props.fontColor]
429
+ : props.fontColor};
430
+ max-height: 300px;
431
+ overflow-y: auto;
432
+ & > div[data-value='${(props) => props.hoveredValue}'] {
433
+ background-color: ${(props) =>
434
+ props.theme.colors[props.hoveredBgColor]
435
+ ? props.theme.colors[props.hoveredBgColor]
436
+ : props.hoveredBgColor};
437
+ }
438
+ font-size: ${(props) => props.fontSize};
439
+ `
440
+ SelectDropdown.emits = ['option-hovered', 'option-selected']
441
+ const DropdownAttrs = { noRelative: Boolean }
442
+ const DropdownWrapper = styled('div', DropdownAttrs)`
443
+ position: ${(props) => (props.noRelative ? 'static' : 'relative')};
444
+ `
445
+ const inputAttrs = {
446
+ alignItems: String,
447
+ hasLabel: Boolean,
448
+ noRelative: Boolean,
449
+ }
450
+ const InputWrapper = styled('div', inputAttrs)`
451
+ position: ${(props) => (props.noRelative ? 'static' : 'relative')};
452
+ display: grid;
453
+ width: 100%;
454
+ min-width: ${(props) => (props.minWidth ? props.minWidth : '150px')};
455
+ align-items: center;
456
+ gap: 8px;
457
+ grid-template-columns: ${(props) =>
458
+ props.alignItems === 'vertical' || !props.hasLabel ? '1fr' : 'auto 1fr'};
459
+ `
460
+
461
+ const DROPDOWN_HEIGHT_OFFSET = 4
462
+ const DROPDOWN_TOP_OFFSET = 21
463
+ const MIN_OPTION_LENGTH = 5
464
+
465
+ const DROPDOWN_MENU_POSITIONS = {
466
+ Automatic: 'automatic',
467
+ Bottom: 'bottom',
468
+ }
469
+
470
+ export default {
471
+ name: 'RCselect',
472
+
473
+ components: {
474
+ SelectButton,
475
+ SelectButtonWrapper,
476
+ SelectDropdown,
477
+ Container,
478
+ InputLabel,
479
+ LabelWrapper,
480
+ OptionalLabel,
481
+ InfoText,
482
+ InputWrapper,
483
+ DropdownWrapper,
484
+ Icon,
485
+ Caret,
486
+ Selector,
487
+ InputText,
488
+ Teleport,
489
+ DraggableInputHandle,
490
+ },
491
+
492
+ props: {
493
+ value: {
494
+ required: false,
495
+ default: null,
496
+ },
497
+ fontSize: {
498
+ required: false,
499
+ default: '13px',
500
+ },
501
+ noRelative: {
502
+ required: false,
503
+ default: false,
504
+ },
505
+ label: {
506
+ required: false,
507
+ },
508
+ labelOptional: {
509
+ required: false,
510
+ default: false,
511
+ },
512
+ labelDataId: {
513
+ required: false,
514
+ default: '',
515
+ },
516
+ infoTextMessage: {
517
+ required: false,
518
+ },
519
+ selectWidth: {
520
+ type: String,
521
+ required: false,
522
+ default: '100%',
523
+ },
524
+ minWidth: {
525
+ required: false,
526
+ },
527
+ maxWidth: {
528
+ required: false,
529
+ },
530
+ selectHeight: {
531
+ type: String,
532
+ required: false,
533
+ default: null,
534
+ },
535
+ height: {
536
+ required: false,
537
+ default: null,
538
+ },
539
+ selectMinHeight: {
540
+ required: false,
541
+ default: '36px',
542
+ },
543
+ optionWidth: {
544
+ required: false,
545
+ default: null,
546
+ },
547
+ hoverDropdown: {
548
+ required: false,
549
+ default: false,
550
+ },
551
+ dropdownAutoClose: {
552
+ required: false,
553
+ default: false,
554
+ },
555
+ alignItems: {
556
+ required: false,
557
+ default: 'horizontal',
558
+ },
559
+ buttonBgColor: {
560
+ required: false,
561
+ },
562
+ buttonFontColor: {
563
+ required: false,
564
+ },
565
+ dropdownBgColor: {
566
+ required: false,
567
+ default: 'grey5',
568
+ },
569
+ dropdownFontColor: {
570
+ required: false,
571
+ },
572
+ dropDownArrowVisible: {
573
+ required: false,
574
+ default: true,
575
+ },
576
+ caretColor: {
577
+ required: false,
578
+ },
579
+ labelFontColor: {
580
+ required: false,
581
+ },
582
+ colorMode: {
583
+ required: false,
584
+ default: 'light',
585
+ },
586
+ isSearchable: {
587
+ required: false,
588
+ default: true,
589
+ },
590
+ hasError: {
591
+ required: false,
592
+ default: false,
593
+ },
594
+ disabled: {
595
+ required: false,
596
+ type: Boolean,
597
+ default: false,
598
+ },
599
+ isAutoSearch: {
600
+ required: false,
601
+ default: true,
602
+ },
603
+ showBorder: {
604
+ required: false,
605
+ default: true,
606
+ },
607
+ infoTextSize: {
608
+ required: false,
609
+ default: '14px',
610
+ },
611
+ dataId: {
612
+ type: String,
613
+ default: '',
614
+ },
615
+ dataQaId: {
616
+ type: String,
617
+ default: '',
618
+ },
619
+ hasSelectButtonPadding: {
620
+ required: false,
621
+ type: Boolean,
622
+ default: true,
623
+ },
624
+ isDraggable: {
625
+ type: Boolean,
626
+ default: false,
627
+ },
628
+ leftPadding: {
629
+ type: String,
630
+ default: '15px',
631
+ },
632
+ tablePaddingLeft: {
633
+ required: false,
634
+ },
635
+ showDisabledBackground: {
636
+ required: false,
637
+ default: true,
638
+ },
639
+ minOptionLength: {
640
+ type: Number,
641
+ default: MIN_OPTION_LENGTH,
642
+ },
643
+ dropdownMenuPosition: {
644
+ type: String,
645
+ default: DROPDOWN_MENU_POSITIONS.Automatic, // options: ['automatic', bottom]
646
+ },
647
+ infoTextWidth: {
648
+ type: String,
649
+ required: false,
650
+ },
651
+ infoTextAlignArrow: {
652
+ type: String,
653
+ required: false,
654
+ },
655
+ isFixedDropdownPosition: {
656
+ type: Boolean,
657
+ required: false,
658
+ default: false,
659
+ },
660
+ },
661
+
662
+ data() {
663
+ return {
664
+ selectedValue: null,
665
+ paddingLeft: this.isDraggable ? '30px' : this.leftPadding,
666
+ isDropdownOpen: false,
667
+ isActive: false,
668
+ textSearch: '',
669
+ hoveredIndex: 0,
670
+ isClickOutsideActive: false,
671
+ dropdownPosition: {
672
+ left: null,
673
+ top: null,
674
+ },
675
+ dropdownWidth: null,
676
+ hoveredValue: null,
677
+ isDisplayedAtBottom: true,
678
+ selectTopPosition: 0,
679
+ selectAndDropdownDistance: 0,
680
+ animationFrameId: null,
681
+ }
682
+ },
683
+ setup() {
684
+ const modalRef = inject('modalRef')
685
+
686
+ return {
687
+ modalRef,
688
+ }
689
+ },
690
+ computed: {
691
+ optionLength() {
692
+ if (this.isDropdownOpen) {
693
+ return this.$refs.dropdown.$el.childElementCount > 1
694
+ ? this.$refs.dropdown.$el.childElementCount
695
+ : this.$refs.dropdown.$el.children[0]
696
+ ? this.$refs.dropdown.$el.children[0].childElementCount
697
+ : 0
698
+ }
699
+
700
+ return 0
701
+ },
702
+ isSearchBarVisible() {
703
+ return (
704
+ this.isSearchable &&
705
+ this.optionLength >= this.minOptionLength &&
706
+ this.isDropdownOpen
707
+ )
708
+ },
709
+ computedWidth() {
710
+ function removePX(item) {
711
+ return Number(item.replace('px', ''))
712
+ }
713
+
714
+ return this.selectWidth === '100%'
715
+ ? '100%'
716
+ : removePX(this.selectWidth) - removePX(CARET_WIDTH) + 'px'
717
+ },
718
+ getOptionWidth() {
719
+ if (this.optionWidth) return this.optionWidth
720
+
721
+ return this.dropdownWidth
722
+ },
723
+ isSelectDropdownShown() {
724
+ return (
725
+ this.isDropdownOpen &&
726
+ this.dropdownPosition.left !== null &&
727
+ (!this.isSearchable || this.isSearchable)
728
+ )
729
+ },
730
+ isMobileDevice() {
731
+ const userAgent =
732
+ navigator.userAgent || navigator.vendor || window.opera
733
+ const touchCapable =
734
+ 'ontouchstart' in window ||
735
+ navigator.maxTouchPoints > 0 ||
736
+ navigator.msMaxTouchPoints > 0
737
+
738
+ return (
739
+ /Android/i.test(userAgent) ||
740
+ /iPad|iPhone|iPod/.test(userAgent) ||
741
+ (/Macintosh/.test(userAgent) && touchCapable) ||
742
+ /windows phone/i.test(userAgent)
743
+ )
744
+ },
745
+ isParentModal() {
746
+ return !!this.modalRef
747
+ },
748
+ },
749
+ watch: {
750
+ value(val) {
751
+ this.selectedValue = val
752
+ },
753
+ async isDropdownOpen(val) {
754
+ if (val) {
755
+ this.$emit('on-dropdown-open')
756
+ setTimeout(() => {
757
+ this.isClickOutsideActive = true
758
+ }, 10)
759
+ await this.$nextTick()
760
+ this.handleSetDropdownOffet()
761
+ if (!this.isFixedDropdownPosition) this.calculateSelectTopPosition()
762
+ } else {
763
+ this.dropdownPosition.left = null
764
+ if (this.animationFrameId) {
765
+ cancelAnimationFrame(this.animationFrameId)
766
+ this.animationFrameId = null
767
+ }
768
+ setTimeout(() => {
769
+ this.isClickOutsideActive = false
770
+ }, 10)
771
+ }
772
+ if (val && this.isSearchable) {
773
+ this.$nextTick(() => {
774
+ if (this.$refs.searchInput && !this.isMobileDevice) {
775
+ this.$refs.searchInput.$el.querySelector('input').focus()
776
+ }
777
+ })
778
+ }
779
+ },
780
+ isSelectDropdownShown(isShown) {
781
+ if (!isShown) return
782
+ // Need to wait for 1ms to make sure the dropdown menu is shown in the DOM
783
+ // before getting the distance between the select and the dropdown menu
784
+ setTimeout(() => {
785
+ this.getDistanceBetweenSelectAndDropdownMenu()
786
+ }, 100)
787
+ },
788
+ selectTopPosition() {
789
+ this.dropdownPosition.top =
790
+ this.selectTopPosition +
791
+ this.$refs.select.$el.clientHeight +
792
+ this.selectAndDropdownDistance
793
+ },
794
+ },
795
+ mounted() {
796
+ this.observeDropdownHeight()
797
+ this.observeSelectWidth()
798
+ window.addEventListener('resize', this.handleSetDropdownOffet)
799
+ if (!this.isFixedDropdownPosition)
800
+ document.body.addEventListener(
801
+ 'scroll',
802
+ this.calculateSelectTopPosition
803
+ )
804
+ },
805
+ beforeMount() {
806
+ this.selectedValue = this.value
807
+ document.addEventListener('click', this.clickOutside)
808
+ this.getDropdownPosition()
809
+ window.removeEventListener('resize', this.handleSetDropdownOffet)
810
+ if (this.dropdownResizeObserver) this.dropdownResizeObserver.disconnect()
811
+ if (this.selectResizeObserver) this.selectResizeObserver.disconnect()
812
+ if (!this.isFixedDropdownPosition) {
813
+ document.body.removeEventListener(
814
+ 'scroll',
815
+ this.calculateSelectTopPosition
816
+ )
817
+ }
818
+ },
819
+ unmounted() {
820
+ document.removeEventListener('click', this.clickOutside)
821
+ },
822
+ methods: {
823
+ focus() {
824
+ this.isActive = true
825
+ },
826
+ blur(e) {
827
+ this.isActive = false
828
+ this.$emit('blur', e)
829
+ },
830
+ toggleDropdown() {
831
+ this.isDropdownOpen = !this.isDropdownOpen
832
+ },
833
+ toggleCaretDropdown() {
834
+ this.isDropdownOpen = !this.isDropdownOpen
835
+ },
836
+ closeDropdown() {
837
+ this.blur()
838
+ this.clearSearch()
839
+ this.isDropdownOpen = false
840
+ },
841
+ clearSearch() {
842
+ this.textSearch = ''
843
+ this.searchChange('')
844
+ },
845
+ optionSelected(e) {
846
+ this.selectedValue = e
847
+ this.closeDropdown()
848
+ this.blur()
849
+ this.$emit('input-change', e)
850
+ },
851
+ optionHovered: debounce(function (e) {
852
+ this.hoveredValue = e
853
+ }, 300),
854
+ mouseEnterHandler() {
855
+ if (this.hoverDropdown) {
856
+ this.focus()
857
+ this.isDropdownOpen = true
858
+ }
859
+ },
860
+ mouseLeaveHandler() {
861
+ if (this.hoverDropdown) {
862
+ this.blur()
863
+ }
864
+ },
865
+ optionLeave() {
866
+ if (this.dropdownAutoClose) {
867
+ this.isDropdownOpen = false
868
+ }
869
+ },
870
+ searchChange(value) {
871
+ this.textSearch = value
872
+ this.$emit('search-change', value)
873
+ const dropdownChildren = [...this.$refs.dropdown.$el.children]
874
+ dropdownChildren.forEach((el) => {
875
+ if (!el.textContent.toLowerCase().includes(value.toLowerCase())) {
876
+ el.style.display = 'none'
877
+
878
+ return
879
+ }
880
+
881
+ el.style.display = 'inherit'
882
+ })
883
+ },
884
+ clickOutside(event) {
885
+ const dropdownRef = this.$refs.dropdown
886
+ // we need to prevent closing on selecting an option, because in the case of
887
+ // a disabled option, we don't want to close the dropdown
888
+ if (!this.isClickOutsideActive) return
889
+ if (
890
+ this.$refs.select.$el == event.target ||
891
+ this.$refs.select.$el.contains(event.target) ||
892
+ event.target.id === 'more-button' ||
893
+ event.target.parentNode === dropdownRef.$el
894
+ ) {
895
+ return
896
+ } else {
897
+ this.closeDropdown()
898
+ }
899
+ },
900
+ onKeyDown(e) {
901
+ if (e.key == 'ArrowDown') {
902
+ this.onArrowPress(1)
903
+ } else if (e.key == 'ArrowUp') {
904
+ this.onArrowPress(-1)
905
+ } else if (e.key == 'Enter') {
906
+ const optionHoveredComponent = [...this.$refs.dropdown.$el.children][
907
+ (this.hoveredIndex - 1 + this.optionLength) % this.optionLength
908
+ ]
909
+ this.optionSelected(optionHoveredComponent.$el.dataset.value)
910
+ }
911
+ },
912
+ // If some part of the dropdown menu is outside viewport of the bottom of the screen,
913
+ // we need to offset it and display it at the top of the select dropdown instead
914
+ async getDropdownPosition() {
915
+ if (
916
+ !this.$refs.dropdownWrapperRef ||
917
+ !this.$refs.select ||
918
+ !this.$refs.dropdown
919
+ ) {
920
+ return
921
+ }
922
+ await this.$nextTick()
923
+ this.isDisplayedAtBottom = await this.generateDropdownPosition()
924
+ // If the dropdown menu is going to be displayed at the bottom,
925
+ // we need reverify its position after a dom update (nextTick)
926
+ await this.$nextTick()
927
+ if (this.isDisplayedAtBottom) this.generateDropdownPosition()
928
+ },
929
+ async generateDropdownPosition() {
930
+ const isDropdownNotCompletelyVisible =
931
+ await this.isBottomOfDropdownOutOfViewport()
932
+ const dropdownWrapperEl = this.$refs.dropdownWrapperRef.$el
933
+ const selectButtonHeight = this.$refs.select.$el.clientHeight
934
+ const dropdownHeight = this.$refs.dropdown.$el.clientHeight
935
+ const dropdownWrapperRelativeHeight =
936
+ dropdownWrapperEl.getBoundingClientRect().top +
937
+ window.scrollY +
938
+ DROPDOWN_HEIGHT_OFFSET
939
+
940
+ const top =
941
+ isDropdownNotCompletelyVisible ||
942
+ (!isDropdownNotCompletelyVisible &&
943
+ this.dropdownMenuPosition === DROPDOWN_MENU_POSITIONS.Bottom)
944
+ ? dropdownWrapperRelativeHeight
945
+ : dropdownWrapperRelativeHeight -
946
+ dropdownHeight -
947
+ selectButtonHeight -
948
+ DROPDOWN_TOP_OFFSET
949
+ const left = this.dropdownPosition.left
950
+ ? this.dropdownPosition.left
951
+ : dropdownWrapperEl.getBoundingClientRect().left + window.scrollX
952
+
953
+ this.dropdownPosition = { left: Math.floor(left), top: Math.floor(top) }
954
+
955
+ return isDropdownNotCompletelyVisible
956
+ },
957
+ async isBottomOfDropdownOutOfViewport() {
958
+ if (
959
+ !this.$refs.dropdown ||
960
+ this.dropdownMenuPosition === DROPDOWN_MENU_POSITIONS.Bottom
961
+ ) {
962
+ return false
963
+ }
964
+
965
+ await this.$nextTick()
966
+ const rect = this.$refs.dropdown.$el.getBoundingClientRect()
967
+ const windowHeight =
968
+ window.innerHeight || document.documentElement.clientHeight
969
+
970
+ if (windowHeight <= 650) return true
971
+
972
+ // using Math.floor because the offsets may contain decimals we are not going to consider here
973
+ return Math.floor(rect.top) + Math.floor(rect.height) <= windowHeight
974
+ },
975
+ observeDropdownHeight() {
976
+ if (!this.$refs.dropdown) return
977
+ this.dropdownResizeObserver = new ResizeObserver(() => {
978
+ this.$nextTick(() => this.getDropdownPosition())
979
+ })
980
+ this.dropdownResizeObserver.observe(this.$refs.dropdown.$el)
981
+ },
982
+ handleSetDropdownOffet() {
983
+ if (!this.$refs.select) return
984
+ this.dropdownPosition.left = Math.floor(
985
+ this.$refs.select.$el.getBoundingClientRect().left
986
+ )
987
+ this.getDropdownWidth()
988
+ },
989
+ observeSelectWidth() {
990
+ if (!this.$refs.select) return
991
+ this.selectResizeObserver = new ResizeObserver(() =>
992
+ // eslint-disable-next-line vue/valid-next-tick
993
+ this.$nextTick(() => this.getDropdownWidth())
994
+ )
995
+ this.selectResizeObserver.observe(this.$refs.dropdown.$el)
996
+ },
997
+ async getDropdownWidth() {
998
+ if (!this.$refs.select) return
999
+ await this.$nextTick()
1000
+ this.dropdownWidth = `${this.$refs.select.$el.clientWidth}px`
1001
+ },
1002
+ onArrowPress(dir) {
1003
+ let newHoveredElem
1004
+ const currentHoveredElem = this.$refs.dropdown.$el.querySelector(
1005
+ `[data-value="${this.hoveredValue}"]`
1006
+ )
1007
+ if (currentHoveredElem) {
1008
+ if (dir > 0) {
1009
+ newHoveredElem = currentHoveredElem.nextElementSibling
1010
+ } else {
1011
+ newHoveredElem = currentHoveredElem.previousElementSibling
1012
+ }
1013
+ if (newHoveredElem) {
1014
+ this.hoveredValue = newHoveredElem.getAttribute('data-value')
1015
+ const topPos = newHoveredElem.offsetTop
1016
+ this.$refs.dropdown.$el.scrollTop = topPos
1017
+ }
1018
+ }
1019
+ },
1020
+ getDistanceBetweenSelectAndDropdownMenu() {
1021
+ const wholeSelectTopPosition =
1022
+ this.selectTopPosition + this.$refs.select.$el.clientHeight
1023
+ this.selectAndDropdownDistance =
1024
+ this.dropdownPosition.top - wholeSelectTopPosition
1025
+ },
1026
+ calculateSelectTopPosition() {
1027
+ const selectRef = this.$refs.select
1028
+ if (selectRef) {
1029
+ const currentTopPosition =
1030
+ selectRef.$el.getBoundingClientRect().top + window.scrollY
1031
+ if (this.selectTopPosition !== currentTopPosition) {
1032
+ this.selectTopPosition = currentTopPosition
1033
+ }
1034
+ }
1035
+ this.animationFrameId = requestAnimationFrame(
1036
+ this.calculateSelectTopPosition
1037
+ )
1038
+ },
1039
+ },
1040
+ }
1041
+ </script>