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