@bytebrand/fe-ui-core 4.1.129 → 4.1.131

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 (980) hide show
  1. package/.editorconfig +10 -10
  2. package/.storybook/addons.js +4 -4
  3. package/.storybook/config.js +64 -64
  4. package/.storybook/postcss.config.js +6 -6
  5. package/.storybook/preview-head.html +9 -9
  6. package/.storybook/webpack.config.js +130 -130
  7. package/common.ts +154 -154
  8. package/feWpComponents.ts +25 -25
  9. package/index.ts +4 -4
  10. package/landing.ts +38 -38
  11. package/media/images/advantages/advantage_cart.svg +4 -4
  12. package/media/images/advantages/advantage_check.svg +4 -4
  13. package/media/images/advantages/advantage_like.svg +10 -10
  14. package/media/images/advantages/advantage_secure.svg +6 -6
  15. package/media/images/check-blue.svg +40 -40
  16. package/media/images/raiting-star.svg +3 -3
  17. package/media/images/raiting-stars-min.svg +7 -7
  18. package/media/images/refresh-button.svg +49 -49
  19. package/media/images/slider-arrow-big.svg +11 -11
  20. package/media/images/user-icon.svg +16 -16
  21. package/media/locales/de/promoSlider.json +25 -25
  22. package/media/locales/en/promoSlider.json +25 -25
  23. package/media/svg/common/arrow_breadcrumps.svg +3 -3
  24. package/media/svg/common/home.svg +8 -8
  25. package/media/svg/common/whyAutodeIconSet-F.svg +9 -9
  26. package/media/svg/common/whyAutodeIconSet-G.svg +8 -8
  27. package/media/svg/common/whyAutodeIconSet-Q.svg +6 -6
  28. package/media/svg/common/whyAutodeIconSet-R.svg +9 -9
  29. package/media/svg/infoBlocks/whyAutodeIconSet-F.svg +9 -9
  30. package/media/svg/infoBlocks/whyAutodeIconSet-G.svg +8 -8
  31. package/media/svg/infoBlocks/whyAutodeIconSet-Q.svg +6 -6
  32. package/media/svg/infoBlocks/whyAutodeIconSet-R.svg +9 -9
  33. package/media/svg/usp/icon1.svg +16 -16
  34. package/media/svg/usp/icon2.svg +13 -13
  35. package/media/svg/usp/icon3.svg +10 -10
  36. package/media/svg/usp/icon4.svg +14 -14
  37. package/package.json +106 -106
  38. package/profile.ts +1 -1
  39. package/source/components/AccardionSection/AccardionSection.styl +45 -45
  40. package/source/components/AccardionSection/AccardionSection.tsx +47 -47
  41. package/source/components/AccordionWidget/AccordionWidget.styl +203 -203
  42. package/source/components/AccordionWidget/AccordionWidget.tsx +227 -227
  43. package/source/components/AdvantageItem/AdvantageItem.story.js +23 -23
  44. package/source/components/AdvantageItem/AdvantageItem.styl +47 -47
  45. package/source/components/AdvantageItem/AdvantageItem.tsx +26 -26
  46. package/source/components/Alternative/Dealer.story.js +31 -31
  47. package/source/components/Alternative/Dealer.story.styl +2 -2
  48. package/source/components/Alternative/DealerInfo.styl +109 -109
  49. package/source/components/Alternative/DealerInfo.tsx +145 -145
  50. package/source/components/Breadcrumbs/Breadcrumbs.story.js +40 -40
  51. package/source/components/Breadcrumbs/Breadcrumbs.styl +135 -135
  52. package/source/components/Breadcrumbs/Breadcrumbs.tsx +87 -87
  53. package/source/components/Breadcrumbs/FirstInfoBlock/FirstInfoBlock.story.js +45 -45
  54. package/source/components/Breadcrumbs/FirstInfoBlock/FirstInfoBlock.styl +54 -54
  55. package/source/components/Breadcrumbs/FirstInfoBlock/FirstInfoBlock.tsx +17 -17
  56. package/source/components/Checkout/CheckoutStepper/CheckoutStepper.styl +221 -221
  57. package/source/components/Checkout/CheckoutStepper/CheckoutStepper.tsx +70 -70
  58. package/source/components/Checkout/CheckoutStepper/CheckoutStepperClasses.js +173 -173
  59. package/source/components/Checkout/OrderOverviewItem/OrderOverviewItem.story.js +243 -243
  60. package/source/components/Checkout/OrderOverviewItem/OrderOverviewItem.story.styl +20 -20
  61. package/source/components/Checkout/OrderOverviewItem/OrderOverviewItem.styl +36 -36
  62. package/source/components/Checkout/OrderOverviewItem/OrderOverviewItem.tsx +53 -53
  63. package/source/components/Checkout/RadioCards/AdditionalServiceCard/ServiceCardWrapper.styl +200 -200
  64. package/source/components/Checkout/RadioCards/AdditionalServiceCard/ServiceCardWrapper.tsx +212 -212
  65. package/source/components/Checkout/RadioCards/ContentCard/AdditionalServiceContent.styl +30 -30
  66. package/source/components/Checkout/RadioCards/ContentCard/AdditionalServiceContent.tsx +62 -62
  67. package/source/components/Checkout/RadioCards/ContentCard/VehicleDeliveryContent.styl +73 -73
  68. package/source/components/Checkout/RadioCards/ContentCard/VehicleDeliveryContent.tsx +61 -61
  69. package/source/components/Checkout/RadioCards/PaymentTypeCard/PaymentTypeCard.styl +199 -199
  70. package/source/components/Checkout/RadioCards/PaymentTypeCard/PaymentTypeCard.tsx +195 -195
  71. package/source/components/Checkout/RadioCards/RadioCheckout.styl +158 -158
  72. package/source/components/Checkout/RadioCards/RadioCheckout.tsx +178 -178
  73. package/source/components/Checkout/RadioCards/RadioGroupCheckout.story.js +105 -105
  74. package/source/components/Checkout/RadioCards/RadioGroupCheckout.story.styl +37 -37
  75. package/source/components/Checkout/Switcher/Switcher.story.js +51 -51
  76. package/source/components/Checkout/Switcher/Switcher.story.styl +1 -1
  77. package/source/components/Checkout/Switcher/Switcher.styl +93 -93
  78. package/source/components/Checkout/Switcher/Switcher.tsx +104 -104
  79. package/source/components/CompactSearchWidget/CompactSearchFields/CompactSearchFields.styl +176 -176
  80. package/source/components/CompactSearchWidget/CompactSearchFields/CompactSearchFields.tsx +477 -477
  81. package/source/components/CompactSearchWidget/CompactSearchWidget.story.js +187 -187
  82. package/source/components/CompactSearchWidget/CompactSearchWidget.styl +43 -43
  83. package/source/components/CompactSearchWidget/CompactSearchWidget.tsx +165 -165
  84. package/source/components/ContactForm/ContactForm.story.js +93 -93
  85. package/source/components/ContactForm/ContactForm.styl +260 -260
  86. package/source/components/ContactForm/ContactForm.tsx +588 -588
  87. package/source/components/ContactForm/WpContactForm.tsx +287 -287
  88. package/source/components/ContactInfo/ContactInfo.story.js +58 -58
  89. package/source/components/ContactInfo/ContactInfo.styl +22 -22
  90. package/source/components/ContactInfo/ContactInfo.tsx +161 -161
  91. package/source/components/ContactInfo/TemporaryTranslation.ts +11 -11
  92. package/source/components/CustomerQuote/CustomerQuote.story.js +41 -41
  93. package/source/components/CustomerQuote/CustomerQuote.styl +79 -79
  94. package/source/components/CustomerQuote/CustomerQuote.tsx +68 -68
  95. package/source/components/CustomerQuotesSlider/CustomerQuotesSlider.story.js +73 -73
  96. package/source/components/CustomerQuotesSlider/CustomerQuotesSlider.story.styl +4 -4
  97. package/source/components/CustomerQuotesSlider/CustomerQuotesSlider.styl +46 -46
  98. package/source/components/CustomerQuotesSlider/CustomerQuotesSlider.tsx +79 -79
  99. package/source/components/CustomerQuotesSlider/SliderArrow.tsx +20 -20
  100. package/source/components/FormattedNumber/FormattedNumber.story.js +114 -114
  101. package/source/components/FormattedNumber/FormattedNumber.styl +1 -1
  102. package/source/components/FormattedNumber/FormattedNumber.tsx +91 -91
  103. package/source/components/ImageSettings/EditableOptionsTable/CustomCheckbox/CustomCheckbox.styl +7 -7
  104. package/source/components/ImageSettings/EditableOptionsTable/CustomCheckbox/CustomCheckbox.tsx +30 -30
  105. package/source/components/ImageSettings/EditableOptionsTable/EditableOptionsTable.styl +122 -122
  106. package/source/components/ImageSettings/EditableOptionsTable/EditableOptionsTable.tsx +199 -199
  107. package/source/components/ImageSettings/EditableOptionsTable/ImageIcon/ImageIcon.styl +3 -3
  108. package/source/components/ImageSettings/EditableOptionsTable/ImageIcon/ImageIcon.tsx +15 -15
  109. package/source/components/ImageSettings/OptionsTable/OptionsTable.styl +47 -47
  110. package/source/components/ImageSettings/OptionsTable/OptionsTable.tsx +122 -122
  111. package/source/components/ImageSettings/PricePlan/PricePlan.styl +63 -63
  112. package/source/components/ImageSettings/PricePlan/PricePlan.tsx +32 -32
  113. package/source/components/ImageSettings/index.ts +42 -42
  114. package/source/components/ImageSettings/story.js +1212 -1212
  115. package/source/components/InfoBlocks/FirstInfoBlock/FirstInfoBlock.styl +33 -33
  116. package/source/components/InfoBlocks/FirstInfoBlock/FirstInfoBlock.tsx +48 -48
  117. package/source/components/InfoBlocks/FirstInfoBlock/FirstInfoBlockItem/FirstInfoBlockItem.styl +68 -68
  118. package/source/components/InfoBlocks/FirstInfoBlock/FirstInfoBlockItem/FirstInfoBlockItem.tsx +21 -21
  119. package/source/components/InfoBlocks/InfoBlockWrapper/InfoBlockWrapper.styl +41 -41
  120. package/source/components/InfoBlocks/InfoBlockWrapper/InfoBlockWrapper.tsx +45 -45
  121. package/source/components/InfoBlocks/InfoBlockWrapper.story.js +101 -101
  122. package/source/components/InfoBlocks/InfoBlockWrapper.story.styl +45 -45
  123. package/source/components/InfoBlocks/PricingToolBlock/PricingTool.styl +6 -6
  124. package/source/components/InfoBlocks/PricingToolBlock/PricingTool.tsx +29 -29
  125. package/source/components/InfoBlocks/PricingToolBlock/PricingToolBlock.styl +45 -45
  126. package/source/components/InfoBlocks/PricingToolBlock/PricingToolBlock.tsx +81 -81
  127. package/source/components/InfoBlocks/ServicesBlock/ServiceBlockItem.styl +47 -47
  128. package/source/components/InfoBlocks/ServicesBlock/ServiceBlockItem.tsx +25 -25
  129. package/source/components/OfferDetailedSection/OfferDetailedSection.styl +31 -31
  130. package/source/components/OfferDetailedSection/OfferDetailedSection.tsx +100 -100
  131. package/source/components/OfferDetailedSection/partials/PanelConfig.styl +127 -127
  132. package/source/components/OfferDetailedSection/partials/PanelConfig.tsx +124 -124
  133. package/source/components/OfferPanel/AboAccordion/AboAccordion.styl +24 -24
  134. package/source/components/OfferPanel/AboAccordion/AboAccordion.tsx +128 -128
  135. package/source/components/OfferPanel/AboAccordion/AboColorOptions/AboColorOptions.styl +11 -11
  136. package/source/components/OfferPanel/AboAccordion/AboColorOptions/AboColorOptions.tsx +35 -35
  137. package/source/components/OfferPanel/AboAccordion/AboFaq/AboFaq.story.js +97 -97
  138. package/source/components/OfferPanel/AboAccordion/AboFaq/AboFaq.styl +20 -20
  139. package/source/components/OfferPanel/AboAccordion/AboFaq/AboFaq.tsx +25 -25
  140. package/source/components/OfferPanel/AboAccordion/AboIncludedServices/AboIncludedServices.styl +13 -13
  141. package/source/components/OfferPanel/AboAccordion/AboIncludedServices/AboIncludedServices.tsx +39 -39
  142. package/source/components/OfferPanel/MuiOfferPeriod/MuiOfferPeriod.theme.js +29 -29
  143. package/source/components/OfferPanel/MuiOfferPeriod/MuiOfferPeriod.tsx +49 -49
  144. package/source/components/OfferPanel/OfferCheckboxGroup/CheckboxContainer.tsx +145 -145
  145. package/source/components/OfferPanel/OfferCheckboxGroup/OfferCheckboxGroup.styl +118 -118
  146. package/source/components/OfferPanel/OfferCheckboxGroup/OfferCheckboxGroup.tsx +24 -24
  147. package/source/components/OfferPanel/OfferPanel.story.js +139 -139
  148. package/source/components/OfferPanel/OfferPanel.styl +189 -189
  149. package/source/components/OfferPanel/OfferPanel.tsx +81 -81
  150. package/source/components/OfferPanel/OfferPeriod/OfferPeriod.styl +24 -24
  151. package/source/components/OfferPanel/OfferPeriod/OfferPeriod.tsx +49 -49
  152. package/source/components/OfferPanel/RangeGroup/RangeGroup.story.js +35 -35
  153. package/source/components/OfferPanel/RangeGroup/RangeGroup.story.styl +2 -2
  154. package/source/components/OfferPanel/RangeGroup/RangeGroup.tsx +37 -37
  155. package/source/components/PriceRating/PriceRating.story.js +39 -39
  156. package/source/components/PriceRating/PriceRating.story.styl +1 -1
  157. package/source/components/PriceRating/PriceRating.styl +47 -47
  158. package/source/components/PriceRating/PriceRating.tsx +64 -64
  159. package/source/components/PriceRatingDetailed/PriceRatingDetailed.story.js +78 -78
  160. package/source/components/PriceRatingDetailed/PriceRatingDetailed.story.styl +11 -11
  161. package/source/components/PriceRatingDetailed/PriceRatingDetailed.styl +120 -120
  162. package/source/components/PriceRatingDetailed/PriceRatingDetailed.tsx +187 -187
  163. package/source/components/RateSearchValue/RateSearchValue.story.js +78 -78
  164. package/source/components/RateSearchValue/RateSearchValue.story.styl +1 -1
  165. package/source/components/RateSearchValue/RateSearchValue.styl +22 -22
  166. package/source/components/RateSearchValue/RateSearchValue.tsx +55 -55
  167. package/source/components/RateSearchWidget/RateSearchWidget.story.js +57 -57
  168. package/source/components/RateSearchWidget/RateSearchWidget.story.styl +12 -12
  169. package/source/components/RateSearchWidget/RateSearchWidget.styl +106 -106
  170. package/source/components/RateSearchWidget/RateSearchWidget.tsx +163 -163
  171. package/source/components/SearchFilters/FiltersFactory.story.js +273 -273
  172. package/source/components/SearchFilters/FiltersFactory.tsx +85 -85
  173. package/source/components/SearchFilters/Slider.styl +66 -66
  174. package/source/components/SearchFilters/common/Color/Color.styl +29 -29
  175. package/source/components/SearchFilters/common/Color/Color.tsx +60 -60
  176. package/source/components/SearchFilters/common/FilterBlock/FilterBlock.styl +39 -39
  177. package/source/components/SearchFilters/common/FilterBlock/FilterBlock.styled.tsx +28 -28
  178. package/source/components/SearchFilters/common/FilterBlock/FilterBlock.tsx +54 -54
  179. package/source/components/SearchFilters/common/FilterBlock/FilterBlockFactory.tsx +151 -151
  180. package/source/components/SearchFilters/common/RangeControlled/RangeControlled.tsx +149 -149
  181. package/source/components/SearchFilters/filters/AlternativeID.styl +98 -98
  182. package/source/components/SearchFilters/filters/AlternativeID.tsx +77 -77
  183. package/source/components/SearchFilters/filters/Consumption.styl +41 -41
  184. package/source/components/SearchFilters/filters/Consumption.tsx +52 -52
  185. package/source/components/SearchFilters/filters/Cost.styl +43 -43
  186. package/source/components/SearchFilters/filters/Cost.tsx +112 -112
  187. package/source/components/SearchFilters/filters/CubicCapacity.styl +30 -30
  188. package/source/components/SearchFilters/filters/CubicCapacity.tsx +134 -134
  189. package/source/components/SearchFilters/filters/Damaged.styl +1 -1
  190. package/source/components/SearchFilters/filters/Damaged.tsx +40 -40
  191. package/source/components/SearchFilters/filters/Doors.styl +18 -18
  192. package/source/components/SearchFilters/filters/Doors.tsx +113 -113
  193. package/source/components/SearchFilters/filters/DriveType.styl +22 -22
  194. package/source/components/SearchFilters/filters/DriveType.tsx +72 -72
  195. package/source/components/SearchFilters/filters/EmissionClass.tsx +35 -35
  196. package/source/components/SearchFilters/filters/EmissionSticker.styl +46 -46
  197. package/source/components/SearchFilters/filters/EmissionSticker.tsx +52 -52
  198. package/source/components/SearchFilters/filters/FirstRegistration.tsx +97 -97
  199. package/source/components/SearchFilters/filters/Fuel.styl +27 -27
  200. package/source/components/SearchFilters/filters/Fuel.tsx +73 -73
  201. package/source/components/SearchFilters/filters/Highlights.styl +38 -38
  202. package/source/components/SearchFilters/filters/Highlights.tsx +69 -69
  203. package/source/components/SearchFilters/filters/ImagesCount.tsx +66 -66
  204. package/source/components/SearchFilters/filters/InteriorColor.styl +29 -29
  205. package/source/components/SearchFilters/filters/InteriorColor.tsx +71 -71
  206. package/source/components/SearchFilters/filters/InteriorMaterial.styl +28 -28
  207. package/source/components/SearchFilters/filters/InteriorMaterial.tsx +71 -71
  208. package/source/components/SearchFilters/filters/MakeModel.styl +106 -106
  209. package/source/components/SearchFilters/filters/MakeModel.tsx +164 -164
  210. package/source/components/SearchFilters/filters/Mileage.tsx +105 -105
  211. package/source/components/SearchFilters/filters/OwnerID.styl +14 -14
  212. package/source/components/SearchFilters/filters/OwnerID.tsx +65 -65
  213. package/source/components/SearchFilters/filters/Owners.styl +23 -23
  214. package/source/components/SearchFilters/filters/Owners.tsx +72 -72
  215. package/source/components/SearchFilters/filters/Power.tsx +154 -154
  216. package/source/components/SearchFilters/filters/PriceDifference.tsx +67 -67
  217. package/source/components/SearchFilters/filters/Rate.styl +34 -34
  218. package/source/components/SearchFilters/filters/Rate.tsx +53 -53
  219. package/source/components/SearchFilters/filters/Seats.styl +31 -31
  220. package/source/components/SearchFilters/filters/Seats.tsx +53 -53
  221. package/source/components/SearchFilters/filters/StateOptions.styl +16 -16
  222. package/source/components/SearchFilters/filters/StateOptions.tsx +58 -58
  223. package/source/components/SearchFilters/filters/StateOptionsNew.styl +23 -23
  224. package/source/components/SearchFilters/filters/StateOptionsNew.tsx +72 -72
  225. package/source/components/SearchFilters/filters/Transmission.styl +20 -20
  226. package/source/components/SearchFilters/filters/Transmission.tsx +71 -71
  227. package/source/components/SearchFilters/filters/commonFilters.styl +93 -93
  228. package/source/components/SearchPage/ChipFilter/ChipFilter.styl +45 -45
  229. package/source/components/SearchPage/ChipFilter/ChipFilter.tsx +21 -21
  230. package/source/components/SearchPage/DropDown/DropDown.styl +99 -99
  231. package/source/components/SearchPage/DropDown/DropDown.tsx +52 -52
  232. package/source/components/SearchPage/DropDown/MultiDropDown.tsx +84 -84
  233. package/source/components/SearchPage/DropDown/index.ts +8 -8
  234. package/source/components/SearchPage/Filters/HistogramSlider.styl +77 -77
  235. package/source/components/SearchPage/Filters/MakeModel/MakeModel.story.js +11 -11
  236. package/source/components/SearchPage/Filters/MakeModel/MakeModel.styl +95 -95
  237. package/source/components/SearchPage/Filters/MakeModel/MakeModel.tsx +142 -142
  238. package/source/components/SearchPage/Pagination/Pagination.styl +95 -95
  239. package/source/components/SearchPage/Pagination/Pagination.tsx +89 -89
  240. package/source/components/SearchPage/SearchChips/SearchChips.styl +51 -51
  241. package/source/components/SearchPage/SearchChips/SearchChips.tsx +76 -76
  242. package/source/components/SearchPage/SearchTopBar/SearchTopBar.styl +108 -108
  243. package/source/components/SearchPage/SearchTopBar/SearchTopBar.tsx +116 -116
  244. package/source/components/SearchPageMobile/FiltersContainer/FiltersContainer.styl +44 -44
  245. package/source/components/SearchPageMobile/FiltersContainer/FiltersContainer.tsx +162 -162
  246. package/source/components/SearchPageMobile/FiltersDetailed/BodyType.styl +47 -47
  247. package/source/components/SearchPageMobile/FiltersDetailed/BodyType.tsx +84 -84
  248. package/source/components/SearchPageMobile/FiltersDetailed/Consumption.styl +48 -48
  249. package/source/components/SearchPageMobile/FiltersDetailed/Consumption.tsx +76 -76
  250. package/source/components/SearchPageMobile/FiltersDetailed/Doors.styl +52 -52
  251. package/source/components/SearchPageMobile/FiltersDetailed/Doors.tsx +102 -102
  252. package/source/components/SearchPageMobile/FiltersDetailed/FirstRegistration.tsx +69 -69
  253. package/source/components/SearchPageMobile/FiltersDetailed/Fuel.styl +31 -31
  254. package/source/components/SearchPageMobile/FiltersDetailed/Fuel.tsx +81 -81
  255. package/source/components/SearchPageMobile/FiltersDetailed/HistogramSlider.styl +100 -100
  256. package/source/components/SearchPageMobile/FiltersDetailed/MakeModel.styl +95 -95
  257. package/source/components/SearchPageMobile/FiltersDetailed/MakeModel.tsx +171 -171
  258. package/source/components/SearchPageMobile/FiltersDetailed/MakeModelExclude.styl +112 -112
  259. package/source/components/SearchPageMobile/FiltersDetailed/MakeModelExclude.tsx +122 -122
  260. package/source/components/SearchPageMobile/FiltersDetailed/Mileage.tsx +80 -80
  261. package/source/components/SearchPageMobile/FiltersDetailed/Power.tsx +116 -116
  262. package/source/components/SearchPageMobile/FiltersDetailed/Price.tsx +129 -129
  263. package/source/components/SearchPageMobile/FiltersDetailed/Rate.tsx +252 -252
  264. package/source/components/SearchPageMobile/FiltersDetailed/Seats.styl +41 -41
  265. package/source/components/SearchPageMobile/FiltersDetailed/Seats.tsx +85 -85
  266. package/source/components/SearchWidget/BasicDataWidget/BasicDataWidget.story.js +834 -834
  267. package/source/components/SearchWidget/BasicDataWidget/BasicDataWidget.story.styl +40 -40
  268. package/source/components/SearchWidget/BasicDataWidget/BasicDataWidget.styl +37 -37
  269. package/source/components/SearchWidget/BasicDataWidget/BasicDataWidget.tsx +127 -127
  270. package/source/components/SearchWidget/ColorWidget/BodyColorWidget.styl +54 -54
  271. package/source/components/SearchWidget/ColorWidget/BodyColorWidget.tsx +122 -122
  272. package/source/components/SearchWidget/DriveTransmissionWidget/DriveTransmissionWidget.styl +17 -17
  273. package/source/components/SearchWidget/DriveTransmissionWidget/DriveTransmissionWidget.tsx +36 -36
  274. package/source/components/SearchWidget/EnvironmentWidget/DetailedEnvironmentWidget.styl +25 -25
  275. package/source/components/SearchWidget/EnvironmentWidget/DetailedEnvironmentWidget.tsx +126 -126
  276. package/source/components/SearchWidget/EnvironmentWidget/EnvironmentWidget.styl +54 -54
  277. package/source/components/SearchWidget/EnvironmentWidget/EnvironmentWidget.tsx +173 -173
  278. package/source/components/SearchWidget/HighlightsWidget/HighlightsWidget.styl +39 -39
  279. package/source/components/SearchWidget/HighlightsWidget/HighlightsWidget.tsx +99 -99
  280. package/source/components/SearchWidget/InteriorWidget/DetailedInteriorWidget.tsx +44 -44
  281. package/source/components/SearchWidget/InteriorWidget/InteriorWidget.styl +28 -28
  282. package/source/components/SearchWidget/InteriorWidget/InteriorWidget.tsx +42 -42
  283. package/source/components/SearchWidget/OfferDetalisWidget/OfferDetailsWidgetMobile.tsx +59 -59
  284. package/source/components/SearchWidget/SearchWidget.story.js +191 -191
  285. package/source/components/SearchWidget/SearchWidget.story.styl +5 -5
  286. package/source/components/SearchWidget/SearchWidget.styl +196 -196
  287. package/source/components/SearchWidget/SearchWidget.tsx +208 -208
  288. package/source/components/SearchWidget/StateWidget/StateWidget.styl +57 -57
  289. package/source/components/SearchWidget/StateWidget/StateWidget.tsx +107 -107
  290. package/source/components/SearchWidget/SuperAdminWidget/SuperAdminWidget.styl +10 -10
  291. package/source/components/SearchWidget/SuperAdminWidget/SuperAdminWidget.tsx +64 -64
  292. package/source/components/SearchWidget/partials/BuyCar/BuyCar.styl +19 -19
  293. package/source/components/SearchWidget/partials/BuyCar/BuyCar.tsx +162 -162
  294. package/source/components/SearchWidget/partials/DropDown/DropDown.styl +70 -70
  295. package/source/components/SearchWidget/partials/DropDown/DropDown.tsx +36 -36
  296. package/source/components/SearchWidget/partials/DropDown/MultiDropDown.tsx +76 -76
  297. package/source/components/SearchWidget/partials/DropDown/index.ts +7 -7
  298. package/source/components/SearchWidget/partials/DropDownGroup/DropDownGroup.styl +48 -48
  299. package/source/components/SearchWidget/partials/DropDownGroup/DropDownGroup.tsx +101 -101
  300. package/source/components/SearchWidget/partials/FastSearch/FastSearch.tsx +55 -55
  301. package/source/components/SearchWidget/partials/MakerFilter/MakerFilter.styl +8 -8
  302. package/source/components/SearchWidget/partials/MakerFilter/MakerFilter.tsx +69 -69
  303. package/source/components/SearchWidget/partials/PanelFilter/Item.tsx +43 -43
  304. package/source/components/SearchWidget/partials/PanelFilter/PanelFilter.styl +32 -32
  305. package/source/components/SearchWidget/partials/PanelFilter/PanelFilter.tsx +53 -53
  306. package/source/components/SearchWidget/partials/TabPanel/TabPanel.tsx +29 -29
  307. package/source/components/SearchWidget/partials/Tabs/Tab.tsx +20 -20
  308. package/source/components/SearchWidget/partials/Tabs/Tabs.styl +27 -27
  309. package/source/components/SearchWidget/partials/Tabs/Tabs.tsx +69 -69
  310. package/source/components/SearchWidget/partials/Tabs/index.ts +7 -7
  311. package/source/components/SearchWidgetsMobile/BasicDataWidgetMobile/BasicDataWidgetMobile.styl +91 -91
  312. package/source/components/SearchWidgetsMobile/BasicDataWidgetMobile/BasicDataWidgetMobile.tsx +216 -216
  313. package/source/components/SearchWidgetsMobile/EngineTransDriveWidget/EngineTransDriveWidget.styl +47 -47
  314. package/source/components/SearchWidgetsMobile/EngineTransDriveWidget/EngineTransDriveWidget.tsx +125 -125
  315. package/source/components/SearchWidgetsMobile/EquipmentsWidget/EquipmentsWidget.styl +62 -62
  316. package/source/components/SearchWidgetsMobile/EquipmentsWidget/EquipmentsWidget.styled.tsx +38 -38
  317. package/source/components/SearchWidgetsMobile/EquipmentsWidget/EquipmentsWidget.tsx +293 -293
  318. package/source/components/SearchWidgetsMobile/EquipmentsWidget/EquipmentsWidgetCategory.tsx +50 -50
  319. package/source/components/SearchWidgetsMobile/HighlightsWidgetMobile/HighlightsWidgetMobile.styl +50 -50
  320. package/source/components/SearchWidgetsMobile/HighlightsWidgetMobile/HighlightsWidgetMobile.tsx +96 -96
  321. package/source/components/SearchWidgetsMobile/InteriorWidget/InteriorWidget.styl +30 -30
  322. package/source/components/SearchWidgetsMobile/InteriorWidget/InteriorWidget.tsx +33 -33
  323. package/source/components/SearchWidgetsMobile/InteriorWidget/InteriorWidgetMobile.tsx +44 -44
  324. package/source/components/SearchWidgetsMobile/SafetyWidget/SafetyWidget.styl +45 -45
  325. package/source/components/SearchWidgetsMobile/SafetyWidget/SafetyWidget.tsx +149 -149
  326. package/source/components/SearchWidgetsMobile/StateWidget/StateWidget.styl +59 -59
  327. package/source/components/SearchWidgetsMobile/StateWidget/StateWidget.tsx +172 -172
  328. package/source/components/SearchWidgetsMobile/index.ts +18 -18
  329. package/source/components/Stepper/Step/Step.styl +46 -46
  330. package/source/components/Stepper/Step/Step.tsx +44 -44
  331. package/source/components/Stepper/Stepper.story.js +119 -119
  332. package/source/components/Stepper/Stepper.story.styl +41 -41
  333. package/source/components/Stepper/Stepper.styl +10 -10
  334. package/source/components/Stepper/Stepper.tsx +67 -67
  335. package/source/components/Stepper/StepsDivider/StepsDivider.styl +15 -15
  336. package/source/components/Stepper/StepsDivider/StepsDivider.tsx +23 -23
  337. package/source/components/Theme.story.js +36 -36
  338. package/source/components/Theme.story.styl +85 -85
  339. package/source/components/TickerText/TickerText.story.js +17 -17
  340. package/source/components/TickerText/TickerText.styl +43 -43
  341. package/source/components/TickerText/TickerText.tsx +24 -24
  342. package/source/components/Vehicle/VehicleConsumption/VehicleConsumption.styl +10 -10
  343. package/source/components/Vehicle/VehicleConsumption/VehicleConsumption.tsx +44 -44
  344. package/source/components/Vehicle/VehicleFormattedPrice/VehicleFormattedPrice.story.js +247 -247
  345. package/source/components/Vehicle/VehicleFormattedPrice/VehicleFormattedPrice.styl +148 -148
  346. package/source/components/Vehicle/VehicleFormattedPrice/VehicleFormattedPrice.tsx +137 -137
  347. package/source/components/Vehicle/VehicleTitle/VehicleTitle.story.js +27 -27
  348. package/source/components/Vehicle/VehicleTitle/VehicleTitle.styl +48 -48
  349. package/source/components/Vehicle/VehicleTitle/VehicleTitle.tsx +44 -44
  350. package/source/components/VehicleCompared/CompareGeneral/CompareGeneral.story.js +30 -30
  351. package/source/components/VehicleCompared/CompareGeneral/CompareGeneral.styl +49 -49
  352. package/source/components/VehicleCompared/CompareGeneral/CompareGeneral.tsx +55 -55
  353. package/source/components/VehicleCompared/ComparePrice/ComparePrice.story.js +18 -18
  354. package/source/components/VehicleCompared/ComparePrice/ComparePrice.styl +17 -17
  355. package/source/components/VehicleCompared/ComparePrice/ComparePrice.tsx +33 -33
  356. package/source/components/VehicleCompared/CompareTitle/CompareTitle.story.js +19 -19
  357. package/source/components/VehicleCompared/CompareTitle/CompareTitle.styl +38 -38
  358. package/source/components/VehicleCompared/CompareTitle/CompareTitle.tsx +32 -32
  359. package/source/components/VehicleDetailedSidebar/VehicleDetailedSidebar.story.js +44 -44
  360. package/source/components/VehicleDetailedSidebar/VehicleDetailedSidebar.styl +28 -28
  361. package/source/components/VehicleDetailedSidebar/VehicleDetailedSidebar.tsx +168 -168
  362. package/source/components/VehicleDetailedSidebar/partials/Price.styl +22 -22
  363. package/source/components/VehicleDetailedSidebar/partials/Price.tsx +40 -40
  364. package/source/components/VehicleDetailedSidebar/partials/PriceContent.styl +107 -107
  365. package/source/components/VehicleDetailedSidebar/partials/PriceContent.tsx +124 -124
  366. package/source/components/VehicleDetailedSidebar/partials/Properties.styl +53 -53
  367. package/source/components/VehicleDetailedSidebar/partials/Properties.tsx +117 -117
  368. package/source/components/VehicleDetailedSidebar/partials/Title.styl +35 -35
  369. package/source/components/VehicleDetailedSidebar/partials/Title.tsx +33 -33
  370. package/source/components/VehicleDetailedSlider/VehicleDetailedSlider.story.js +120 -120
  371. package/source/components/VehicleDetailedSlider/VehicleDetailedSlider.styl +102 -102
  372. package/source/components/VehicleDetailedSlider/VehicleDetailedSlider.tsx +285 -285
  373. package/source/components/VehicleDetailedSlider/partials/MobileStast.tsx +61 -61
  374. package/source/components/VehicleDetailedSlider/partials/MobileStats.styl +71 -71
  375. package/source/components/VehicleDetailedSlider/partials/PriceData.styl +71 -71
  376. package/source/components/VehicleDetailedSlider/partials/PriceData.tsx +39 -39
  377. package/source/components/VehicleDetailedSlider/partials/Stats.styl +80 -80
  378. package/source/components/VehicleDetailedSlider/partials/Stats.tsx +62 -62
  379. package/source/components/VehicleDetailedSlider/partials/Title.styl +37 -37
  380. package/source/components/VehicleDetailedSlider/partials/Title.tsx +36 -36
  381. package/source/components/VehiclePromoSlider/VehiclePromoInfo/VehiclePromoInfo.story.js +42 -42
  382. package/source/components/VehiclePromoSlider/VehiclePromoInfo/VehiclePromoInfo.styl +298 -298
  383. package/source/components/VehiclePromoSlider/VehiclePromoInfo/VehiclePromoInfo.tsx +201 -201
  384. package/source/components/VehiclePromoSlider/VehiclePromoSlide/VehiclePromoSlide.story.js +62 -62
  385. package/source/components/VehiclePromoSlider/VehiclePromoSlide/VehiclePromoSlide.styl +263 -263
  386. package/source/components/VehiclePromoSlider/VehiclePromoSlide/VehiclePromoSlide.tsx +141 -141
  387. package/source/components/VehiclePromoSlider/VehiclePromoSlider.story.js +42 -42
  388. package/source/components/VehiclePromoSlider/VehiclePromoSlider.styl +122 -122
  389. package/source/components/VehiclePromoSlider/VehiclePromoSlider.tsx +111 -111
  390. package/source/components/VehiclePromoSlider/cars.js +220 -220
  391. package/source/components/VehicleSmallCard/SeoText/SeoText.styl +8 -8
  392. package/source/components/VehicleSmallCard/SeoText/SeoText.tsx +16 -16
  393. package/source/components/VehicleSmallCard/VehicleData/VechiclePriceItem/VechiclePriceItem.styl +141 -141
  394. package/source/components/VehicleSmallCard/VehicleData/VechiclePriceItem/VechiclePriceItem.tsx +174 -174
  395. package/source/components/VehicleSmallCard/VehicleData/VehicleInfo/VehicleInfo.styl +232 -232
  396. package/source/components/VehicleSmallCard/VehicleData/VehicleInfo/VehicleInfo.tsx +151 -151
  397. package/source/components/VehicleSmallCard/VehicleData/VehiclePrice/VehiclePrice.styl +124 -124
  398. package/source/components/VehicleSmallCard/VehicleData/VehiclePrice/VehiclePrice.tsx +286 -286
  399. package/source/components/VehicleSmallCard/VehicleData/VehicleProperty/VehicleProperty.styl +18 -18
  400. package/source/components/VehicleSmallCard/VehicleData/VehicleProperty/VehicleProperty.tsx +32 -32
  401. package/source/components/VehicleSmallCard/VehicleData/VehicleTitle/VehicleTitle.styl +124 -124
  402. package/source/components/VehicleSmallCard/VehicleData/VehicleTitle/VehicleTitle.tsx +90 -90
  403. package/source/components/VehicleSmallCard/VehicleSmallCard.story.js +412 -412
  404. package/source/components/VehicleSmallCard/VehicleSmallCard.story.styl +55 -55
  405. package/source/components/VehicleSmallCard/VehicleSmallCard.styl +379 -379
  406. package/source/components/VehicleSmallCard/VehicleSmallCard.tsx +391 -391
  407. package/source/components/VehicleSmallCardForDealerships/VehicleSmallCardForDealerships.story.js +199 -199
  408. package/source/components/VehicleSmallCardForDealerships/VehicleSmallCardForDealerships.story.styl +40 -40
  409. package/source/components/VehicleSmallCardForDealerships/VehicleSmallCardForDealerships.styl +150 -150
  410. package/source/components/VehicleSmallCardForDealerships/VehicleSmallCardForDealerships.tsx +184 -184
  411. package/source/components/_common/Accordion/Accordion.story.js +36 -36
  412. package/source/components/_common/Accordion/Accordion.styl +2 -2
  413. package/source/components/_common/Accordion/Accordion.tsx +132 -132
  414. package/source/components/_common/Accordion/AccordionTitle/AccordionTitle.styl +49 -49
  415. package/source/components/_common/Accordion/AccordionTitle/AccordionTitle.tsx +33 -33
  416. package/source/components/_common/AccordionWrapper/AccordionItem/AccordionItem.styl +34 -34
  417. package/source/components/_common/AccordionWrapper/AccordionItem/AccordionItem.tsx +64 -64
  418. package/source/components/_common/AccordionWrapper/AccordionWrapper.tsx +34 -34
  419. package/source/components/_common/Badge/Badge.story.js +27 -27
  420. package/source/components/_common/Badge/Badge.story.styl +5 -5
  421. package/source/components/_common/Badge/Badge.styl +41 -41
  422. package/source/components/_common/Badge/Badge.tsx +25 -25
  423. package/source/components/_common/BodyTypeIcons/Audi.tsx +9 -9
  424. package/source/components/_common/BodyTypeIcons/Bmw.tsx +860 -860
  425. package/source/components/_common/BodyTypeIcons/Ford.tsx +31 -31
  426. package/source/components/_common/BodyTypeIcons/IconsConfig.tsx +44 -44
  427. package/source/components/_common/BodyTypeIcons/IconsConfigCompact.tsx +30 -30
  428. package/source/components/_common/BodyTypeIcons/Mazda.tsx +44 -44
  429. package/source/components/_common/BodyTypeIcons/MercedesBenz.tsx +38 -38
  430. package/source/components/_common/BodyTypeIcons/Opel.tsx +19 -19
  431. package/source/components/_common/BodyTypeIcons/Search.tsx +19 -19
  432. package/source/components/_common/BodyTypeIcons/SelectorCategoryCombi.tsx +68 -68
  433. package/source/components/_common/BodyTypeIcons/SelectorCategoryCompact.tsx +20 -20
  434. package/source/components/_common/BodyTypeIcons/SelectorCategoryConvertible.tsx +68 -68
  435. package/source/components/_common/BodyTypeIcons/SelectorCategoryCoupe.tsx +60 -60
  436. package/source/components/_common/BodyTypeIcons/SelectorCategoryMinibus.tsx +64 -64
  437. package/source/components/_common/BodyTypeIcons/SelectorCategorySedan.tsx +69 -69
  438. package/source/components/_common/BodyTypeIcons/SelectorCategorySuv.tsx +77 -77
  439. package/source/components/_common/BodyTypeIcons/SelectorCategoryTransporter.tsx +68 -68
  440. package/source/components/_common/BodyTypeIcons/SelectorCategoryVan.tsx +72 -72
  441. package/source/components/_common/BodyTypeIcons/Volkswagen.tsx +330 -330
  442. package/source/components/_common/BodyTypeIcons/index.ts +17 -17
  443. package/source/components/_common/Bubble/Bubble.story.js +52 -52
  444. package/source/components/_common/Bubble/Bubble.styl +53 -53
  445. package/source/components/_common/Bubble/Bubble.tsx +37 -37
  446. package/source/components/_common/Button/Button.story.js +52 -52
  447. package/source/components/_common/Button/Button.story.styl +5 -5
  448. package/source/components/_common/Button/Button.styl +12 -12
  449. package/source/components/_common/Button/Button.styled.tsx +50 -50
  450. package/source/components/_common/Button/Button.tsx +78 -78
  451. package/source/components/_common/ButtonOld/Button.story.js +54 -54
  452. package/source/components/_common/ButtonOld/Button.story.styl +5 -5
  453. package/source/components/_common/ButtonOld/Button.styl +65 -65
  454. package/source/components/_common/ButtonOld/Button.tsx +84 -84
  455. package/source/components/_common/Checkbox/Checkbox.story.js +85 -85
  456. package/source/components/_common/Checkbox/Checkbox.story.styl +14 -14
  457. package/source/components/_common/Checkbox/Checkbox.styl +119 -119
  458. package/source/components/_common/Checkbox/Checkbox.tsx +151 -151
  459. package/source/components/_common/Checkbox/FormCheckbox.styl +22 -22
  460. package/source/components/_common/Checkbox/FormCheckbox.tsx +54 -54
  461. package/source/components/_common/Checkbox/index.js +4 -4
  462. package/source/components/_common/CheckboxMaterial/CheckboxMaterial.story.js +136 -136
  463. package/source/components/_common/CheckboxMaterial/CheckboxMaterial.story.styl +14 -14
  464. package/source/components/_common/CheckboxMaterial/CheckboxMaterial.styl +155 -155
  465. package/source/components/_common/CheckboxMaterial/CheckboxMaterial.tsx +210 -210
  466. package/source/components/_common/CheckboxMaterial/FormCheckboxMaterial.styl +22 -22
  467. package/source/components/_common/CheckboxMaterial/FormCheckboxMaterial.tsx +50 -50
  468. package/source/components/_common/Chip/Chip.story.js +43 -43
  469. package/source/components/_common/Chip/Chip.styl +69 -69
  470. package/source/components/_common/Chip/Chip.tsx +40 -40
  471. package/source/components/_common/ChipList/ChipList.story.js +36 -36
  472. package/source/components/_common/ChipList/ChipList.styl +80 -80
  473. package/source/components/_common/ChipList/ChipList.tsx +58 -58
  474. package/source/components/_common/Co2Widget/CO2Efficiency.styl +114 -114
  475. package/source/components/_common/Co2Widget/CO2Efficiency.tsx +49 -49
  476. package/source/components/_common/Divider/Divider.styl +8 -8
  477. package/source/components/_common/Divider/Divider.tsx +16 -16
  478. package/source/components/_common/DoorSelector/DoorSelector.styl +35 -35
  479. package/source/components/_common/DoorSelector/DoorSelector.tsx +39 -39
  480. package/source/components/_common/DropDown/DropDown.story.js +35 -35
  481. package/source/components/_common/DropDown/DropDown.styl +129 -129
  482. package/source/components/_common/DropDown/DropDown.tsx +111 -111
  483. package/source/components/_common/DropDown/DropDownComponents.tsx +53 -53
  484. package/source/components/_common/DropDown/DropDownGroup.styl +20 -20
  485. package/source/components/_common/DropDown/DropDownGroup.tsx +136 -136
  486. package/source/components/_common/DropDown/FormDropDown.styl +35 -35
  487. package/source/components/_common/DropDown/FormDropDown.tsx +52 -52
  488. package/source/components/_common/DropDown/MultiDropDown.tsx +84 -84
  489. package/source/components/_common/DropDown/index.ts +7 -7
  490. package/source/components/_common/ExpandablePanel/ExpandablePanel.story.js +41 -41
  491. package/source/components/_common/ExpandablePanel/ExpandablePanel.styl +19 -19
  492. package/source/components/_common/ExpandablePanel/ExpandablePanel.tsx +88 -88
  493. package/source/components/_common/ExpansionPanel/ExpansionPanel.styl +36 -36
  494. package/source/components/_common/ExpansionPanel/ExpansionPanel.styled.tsx +28 -28
  495. package/source/components/_common/ExpansionPanel/ExpansionPanel.tsx +89 -89
  496. package/source/components/_common/FilterLabel/FilterLabel.styl +24 -24
  497. package/source/components/_common/FilterLabel/FilterLabel.tsx +23 -23
  498. package/source/components/_common/Histogram/Histogram.story.js +51 -51
  499. package/source/components/_common/IconContainer/IconContainer.styl +23 -23
  500. package/source/components/_common/IconContainer/IconContainer.tsx +34 -34
  501. package/source/components/_common/IconSVG/IconSVG.story.js +21 -21
  502. package/source/components/_common/IconSVG/IconSVG.story.styl +25 -25
  503. package/source/components/_common/IconSVG/IconSVG.tsx +30 -30
  504. package/source/components/_common/IconSVG/IconSVGConfig.tsx +708 -708
  505. package/source/components/_common/IconSVG/SVG/AboPartner.tsx +16 -16
  506. package/source/components/_common/IconSVG/SVG/ArrowQuotes.tsx +22 -22
  507. package/source/components/_common/IconSVG/SVG/CloseIcon.tsx +17 -17
  508. package/source/components/_common/IconSVG/SVG/CloseIconSelect.tsx +18 -18
  509. package/source/components/_common/IconSVG/SVG/ClosedLockIcon.tsx +18 -18
  510. package/source/components/_common/IconSVG/SVG/DealerCheckIcon.tsx +18 -18
  511. package/source/components/_common/IconSVG/SVG/DealerPopoverMail.tsx +21 -21
  512. package/source/components/_common/IconSVG/SVG/DealerPopoverPhone.tsx +21 -21
  513. package/source/components/_common/IconSVG/SVG/GrayPhoneIcon.tsx +22 -22
  514. package/source/components/_common/IconSVG/SVG/InternetIcon.tsx +18 -18
  515. package/source/components/_common/IconSVG/SVG/WhiteEnvelopeIcon.tsx +21 -21
  516. package/source/components/_common/IconSVG/SVG/bodyType/Cabrio.tsx +23 -23
  517. package/source/components/_common/IconSVG/SVG/bodyType/Coupe.tsx +22 -22
  518. package/source/components/_common/IconSVG/SVG/bodyType/Minibus.tsx +22 -22
  519. package/source/components/_common/IconSVG/SVG/bodyType/Other.tsx +25 -25
  520. package/source/components/_common/IconSVG/SVG/bodyType/Sedan.tsx +22 -22
  521. package/source/components/_common/IconSVG/SVG/bodyType/SelectorCategoryCombi.tsx +68 -68
  522. package/source/components/_common/IconSVG/SVG/bodyType/SelectorCategoryCompact.tsx +20 -20
  523. package/source/components/_common/IconSVG/SVG/bodyType/SelectorCategoryConvertible.tsx +68 -68
  524. package/source/components/_common/IconSVG/SVG/bodyType/SelectorCategoryCoupe.tsx +60 -60
  525. package/source/components/_common/IconSVG/SVG/bodyType/SelectorCategoryMinibus.tsx +64 -64
  526. package/source/components/_common/IconSVG/SVG/bodyType/SelectorCategoryOther.tsx +60 -60
  527. package/source/components/_common/IconSVG/SVG/bodyType/SelectorCategorySedan.tsx +69 -69
  528. package/source/components/_common/IconSVG/SVG/bodyType/SelectorCategorySuv.tsx +77 -77
  529. package/source/components/_common/IconSVG/SVG/bodyType/SelectorCategoryTransporter.tsx +68 -68
  530. package/source/components/_common/IconSVG/SVG/bodyType/SelectorCategoryVan.tsx +72 -72
  531. package/source/components/_common/IconSVG/SVG/bodyType/Small.tsx +23 -23
  532. package/source/components/_common/IconSVG/SVG/bodyType/Suv.tsx +23 -23
  533. package/source/components/_common/IconSVG/SVG/bodyType/Van.tsx +23 -23
  534. package/source/components/_common/IconSVG/SVG/bodyType/Wagon.tsx +23 -23
  535. package/source/components/_common/IconSVG/SVG/common/AddIcon.tsx +16 -16
  536. package/source/components/_common/IconSVG/SVG/common/AddPlus.tsx +16 -16
  537. package/source/components/_common/IconSVG/SVG/common/AddressDashboard.tsx +29 -29
  538. package/source/components/_common/IconSVG/SVG/common/AddressIcon.tsx +20 -20
  539. package/source/components/_common/IconSVG/SVG/common/ArrowDetailedAccordionBlue.tsx +26 -26
  540. package/source/components/_common/IconSVG/SVG/common/ArrowDownBlue.tsx +21 -21
  541. package/source/components/_common/IconSVG/SVG/common/ArrowSelect.tsx +23 -23
  542. package/source/components/_common/IconSVG/SVG/common/ArrowStepDown.tsx +18 -18
  543. package/source/components/_common/IconSVG/SVG/common/Autocheck.tsx +19 -19
  544. package/source/components/_common/IconSVG/SVG/common/AutodeLogo.tsx +36 -36
  545. package/source/components/_common/IconSVG/SVG/common/Avatar.tsx +17 -17
  546. package/source/components/_common/IconSVG/SVG/common/BellGray.tsx +19 -19
  547. package/source/components/_common/IconSVG/SVG/common/BigInfoTransparent.tsx +13 -13
  548. package/source/components/_common/IconSVG/SVG/common/Browse.tsx +20 -20
  549. package/source/components/_common/IconSVG/SVG/common/Calendar.tsx +24 -24
  550. package/source/components/_common/IconSVG/SVG/common/CallbackDashboard.tsx +30 -30
  551. package/source/components/_common/IconSVG/SVG/common/Camera.tsx +17 -17
  552. package/source/components/_common/IconSVG/SVG/common/Car.tsx +16 -16
  553. package/source/components/_common/IconSVG/SVG/common/CarBody.tsx +19 -19
  554. package/source/components/_common/IconSVG/SVG/common/CarFront.tsx +43 -43
  555. package/source/components/_common/IconSVG/SVG/common/CarInspectionCheck.tsx +21 -21
  556. package/source/components/_common/IconSVG/SVG/common/CarInspectionScheme0.tsx +32 -32
  557. package/source/components/_common/IconSVG/SVG/common/CarInspectionScheme1.tsx +53 -53
  558. package/source/components/_common/IconSVG/SVG/common/CarInspectionScheme2.tsx +52 -52
  559. package/source/components/_common/IconSVG/SVG/common/CarInspectionScheme3.tsx +32 -32
  560. package/source/components/_common/IconSVG/SVG/common/CarInspectionScheme4.tsx +32 -32
  561. package/source/components/_common/IconSVG/SVG/common/CarInspectionScheme5.tsx +32 -32
  562. package/source/components/_common/IconSVG/SVG/common/CarInspectionScheme6.tsx +32 -32
  563. package/source/components/_common/IconSVG/SVG/common/CarInspectionSchemeGeneral copy.tsx +24 -24
  564. package/source/components/_common/IconSVG/SVG/common/CarInspectionSchemeGeneral.tsx +24 -24
  565. package/source/components/_common/IconSVG/SVG/common/CheckBlue.tsx +18 -18
  566. package/source/components/_common/IconSVG/SVG/common/CheckGreen.tsx +22 -22
  567. package/source/components/_common/IconSVG/SVG/common/CheckMark.tsx +16 -16
  568. package/source/components/_common/IconSVG/SVG/common/CheckWhite.tsx +19 -19
  569. package/source/components/_common/IconSVG/SVG/common/Chevron.tsx +17 -17
  570. package/source/components/_common/IconSVG/SVG/common/CircledCheckmark.tsx +25 -25
  571. package/source/components/_common/IconSVG/SVG/common/Clock.tsx +18 -18
  572. package/source/components/_common/IconSVG/SVG/common/Close.tsx +19 -19
  573. package/source/components/_common/IconSVG/SVG/common/CloseGrey.tsx +22 -22
  574. package/source/components/_common/IconSVG/SVG/common/ContactEmail.tsx +21 -21
  575. package/source/components/_common/IconSVG/SVG/common/ContactPhone.tsx +28 -28
  576. package/source/components/_common/IconSVG/SVG/common/CopyIcon copy.tsx +22 -22
  577. package/source/components/_common/IconSVG/SVG/common/CopyIcon.tsx +22 -22
  578. package/source/components/_common/IconSVG/SVG/common/CopyIconForDealer.tsx +21 -21
  579. package/source/components/_common/IconSVG/SVG/common/DashboardIcon.tsx +20 -20
  580. package/source/components/_common/IconSVG/SVG/common/DashboardQuestionMark.tsx +20 -20
  581. package/source/components/_common/IconSVG/SVG/common/DealersIcon.tsx +20 -20
  582. package/source/components/_common/IconSVG/SVG/common/DeleteCircle.tsx +31 -31
  583. package/source/components/_common/IconSVG/SVG/common/DeleteV1Icon.tsx +18 -18
  584. package/source/components/_common/IconSVG/SVG/common/DeliveryDashboard.tsx +24 -24
  585. package/source/components/_common/IconSVG/SVG/common/DeliveryMail.tsx +24 -24
  586. package/source/components/_common/IconSVG/SVG/common/Discount100De.tsx +18 -18
  587. package/source/components/_common/IconSVG/SVG/common/Discount100En.tsx +19 -19
  588. package/source/components/_common/IconSVG/SVG/common/Discount66De.tsx +28 -28
  589. package/source/components/_common/IconSVG/SVG/common/Discount66En.tsx +20 -20
  590. package/source/components/_common/IconSVG/SVG/common/DoneIcon.tsx +18 -18
  591. package/source/components/_common/IconSVG/SVG/common/EditCircle.tsx +32 -32
  592. package/source/components/_common/IconSVG/SVG/common/EuroCurrency.tsx +18 -18
  593. package/source/components/_common/IconSVG/SVG/common/Export.tsx +20 -20
  594. package/source/components/_common/IconSVG/SVG/common/Eye.tsx +17 -17
  595. package/source/components/_common/IconSVG/SVG/common/EyeCatch.tsx +19 -19
  596. package/source/components/_common/IconSVG/SVG/common/FavoritesIcon.tsx +20 -20
  597. package/source/components/_common/IconSVG/SVG/common/FilterRange.tsx +16 -16
  598. package/source/components/_common/IconSVG/SVG/common/FilterToolBlack.tsx +23 -23
  599. package/source/components/_common/IconSVG/SVG/common/FlagDe.tsx +21 -21
  600. package/source/components/_common/IconSVG/SVG/common/FlagEn.tsx +43 -43
  601. package/source/components/_common/IconSVG/SVG/common/GrayEnvelopeIcon.tsx +19 -19
  602. package/source/components/_common/IconSVG/SVG/common/HamburgerMenuIcon.tsx +18 -18
  603. package/source/components/_common/IconSVG/SVG/common/HandingOverDashboard.tsx +32 -32
  604. package/source/components/_common/IconSVG/SVG/common/ImageSettingsIcon.tsx +20 -20
  605. package/source/components/_common/IconSVG/SVG/common/Info.tsx +16 -16
  606. package/source/components/_common/IconSVG/SVG/common/InfoIcon.tsx +18 -18
  607. package/source/components/_common/IconSVG/SVG/common/InfoTransparent.tsx +18 -18
  608. package/source/components/_common/IconSVG/SVG/common/LogoutIcon.tsx +20 -20
  609. package/source/components/_common/IconSVG/SVG/common/MagnifyingGlass.tsx +31 -31
  610. package/source/components/_common/IconSVG/SVG/common/MenuArrow.tsx +16 -16
  611. package/source/components/_common/IconSVG/SVG/common/MenuGrey.tsx +22 -22
  612. package/source/components/_common/IconSVG/SVG/common/MobileDeLogo.tsx +108 -108
  613. package/source/components/_common/IconSVG/SVG/common/MyOrderIcon.tsx +28 -28
  614. package/source/components/_common/IconSVG/SVG/common/MyVehiclesIcon.tsx +20 -20
  615. package/source/components/_common/IconSVG/SVG/common/NewFlagDe.tsx +25 -25
  616. package/source/components/_common/IconSVG/SVG/common/NewFlagEn.tsx +34 -34
  617. package/source/components/_common/IconSVG/SVG/common/OrderReceivedDashboard.tsx +27 -27
  618. package/source/components/_common/IconSVG/SVG/common/Package.tsx +30 -30
  619. package/source/components/_common/IconSVG/SVG/common/Phone.tsx +18 -18
  620. package/source/components/_common/IconSVG/SVG/common/PhoneGrey.tsx +22 -22
  621. package/source/components/_common/IconSVG/SVG/common/PickupDashboard.tsx +30 -30
  622. package/source/components/_common/IconSVG/SVG/common/Picture.tsx +24 -24
  623. package/source/components/_common/IconSVG/SVG/common/Pictures.tsx +32 -32
  624. package/source/components/_common/IconSVG/SVG/common/Plus.tsx +16 -16
  625. package/source/components/_common/IconSVG/SVG/common/PlusNew.tsx +16 -16
  626. package/source/components/_common/IconSVG/SVG/common/PreparationDashboard.tsx +29 -29
  627. package/source/components/_common/IconSVG/SVG/common/ProfileDashboard.tsx +24 -24
  628. package/source/components/_common/IconSVG/SVG/common/ProfileIcon.tsx +17 -17
  629. package/source/components/_common/IconSVG/SVG/common/Question.tsx +19 -19
  630. package/source/components/_common/IconSVG/SVG/common/QuestionBold.tsx +25 -25
  631. package/source/components/_common/IconSVG/SVG/common/RegistrationDashboard.tsx +31 -31
  632. package/source/components/_common/IconSVG/SVG/common/SavedSearchsIcon.tsx +20 -20
  633. package/source/components/_common/IconSVG/SVG/common/Search.tsx +19 -19
  634. package/source/components/_common/IconSVG/SVG/common/SearchGrey.tsx +22 -22
  635. package/source/components/_common/IconSVG/SVG/common/SettingPenIcon.tsx +20 -20
  636. package/source/components/_common/IconSVG/SVG/common/Share.tsx +16 -16
  637. package/source/components/_common/IconSVG/SVG/common/ShoppingCart.tsx +18 -18
  638. package/source/components/_common/IconSVG/SVG/common/SliderArrow.tsx +21 -21
  639. package/source/components/_common/IconSVG/SVG/common/SliderEye.tsx +17 -17
  640. package/source/components/_common/IconSVG/SVG/common/SortUpDownArrows.tsx +18 -18
  641. package/source/components/_common/IconSVG/SVG/common/Speedometer.tsx +23 -23
  642. package/source/components/_common/IconSVG/SVG/common/Star.tsx +20 -20
  643. package/source/components/_common/IconSVG/SVG/common/StarNew.tsx +16 -16
  644. package/source/components/_common/IconSVG/SVG/common/StarOutline.tsx +20 -20
  645. package/source/components/_common/IconSVG/SVG/common/StarRoundedCorners.tsx +18 -18
  646. package/source/components/_common/IconSVG/SVG/common/Stats.tsx +17 -17
  647. package/source/components/_common/IconSVG/SVG/common/Step1.tsx +21 -21
  648. package/source/components/_common/IconSVG/SVG/common/Step2.tsx +20 -20
  649. package/source/components/_common/IconSVG/SVG/common/Step3.tsx +21 -21
  650. package/source/components/_common/IconSVG/SVG/common/SupportCallbackIcon.tsx +20 -20
  651. package/source/components/_common/IconSVG/SVG/common/Telephone.tsx +22 -22
  652. package/source/components/_common/IconSVG/SVG/common/Time.tsx +17 -17
  653. package/source/components/_common/IconSVG/SVG/common/Timetable.tsx +18 -18
  654. package/source/components/_common/IconSVG/SVG/common/Trash.tsx +22 -22
  655. package/source/components/_common/IconSVG/SVG/common/TrashRed.tsx +23 -23
  656. package/source/components/_common/IconSVG/SVG/common/Upload.tsx +17 -17
  657. package/source/components/_common/IconSVG/SVG/common/UserGrey.tsx +22 -22
  658. package/source/components/_common/IconSVG/SVG/common/UserProfileIcon.tsx +20 -20
  659. package/source/components/_common/IconSVG/SVG/common/ValidateFailure.tsx +21 -21
  660. package/source/components/_common/IconSVG/SVG/common/ValidateSuccess.tsx +21 -21
  661. package/source/components/_common/IconSVG/SVG/common/WarningTriangle.tsx +20 -20
  662. package/source/components/_common/IconSVG/SVG/common/WhiteArrowUp.tsx +21 -21
  663. package/source/components/_common/IconSVG/SVG/common/WhiteKey.tsx +21 -21
  664. package/source/components/_common/IconSVG/SVG/common/WhitePeople.tsx +23 -23
  665. package/source/components/_common/IconSVG/SVG/common/WhiteTick.tsx +19 -19
  666. package/source/components/_common/IconSVG/SVG/infoBlocks/14DaysReturnPolicy.tsx +18 -18
  667. package/source/components/_common/IconSVG/SVG/infoBlocks/Autocheck.tsx +19 -19
  668. package/source/components/_common/IconSVG/SVG/infoBlocks/CheckTheStory.tsx +22 -22
  669. package/source/components/_common/IconSVG/SVG/infoBlocks/CustomerServiceWhite.tsx +16 -16
  670. package/source/components/_common/IconSVG/SVG/infoBlocks/Guarantee.tsx +16 -16
  671. package/source/components/_common/IconSVG/SVG/infoBlocks/OrderWhite.tsx +13 -13
  672. package/source/components/_common/IconSVG/SVG/infoBlocks/PriceGuarantee.tsx +19 -19
  673. package/source/components/_common/IconSVG/SVG/infoBlocks/PriceGuaranteeWhite.tsx +17 -17
  674. package/source/components/_common/IconSVG/SVG/infoBlocks/TransportAndDelivery.tsx +21 -21
  675. package/source/components/_common/IconSVG/SVG/infoBlocks/Warranty.tsx +23 -23
  676. package/source/components/_common/IconSVG/SVG/popower/Mail.tsx +18 -18
  677. package/source/components/_common/IconSVG/SVG/popower/Phone.tsx +19 -19
  678. package/source/components/_common/IconSVG/SVG/popower/Schedule.tsx +18 -18
  679. package/source/components/_common/IconSVG/SVG/searchWidgets/drive/AAllWheelDrive.tsx +26 -26
  680. package/source/components/_common/IconSVG/SVG/searchWidgets/drive/AllWheelDrive.tsx +26 -26
  681. package/source/components/_common/IconSVG/SVG/searchWidgets/drive/FrontWheelDrive.tsx +25 -25
  682. package/source/components/_common/IconSVG/SVG/searchWidgets/drive/OtherWheelDrive.tsx +26 -26
  683. package/source/components/_common/IconSVG/SVG/searchWidgets/drive/RearWheelDrive.tsx +25 -25
  684. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelDiesel.tsx +18 -18
  685. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelElectrical.tsx +19 -19
  686. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelElectricalDiesel.tsx +34 -34
  687. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelElectricalPetrol.tsx +20 -20
  688. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelEthanol.tsx +53 -53
  689. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelHydrogen.tsx +24 -24
  690. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelLpg.tsx +24 -24
  691. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelNaturalGas.tsx +23 -23
  692. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelOther.tsx +28 -28
  693. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelPetrol.tsx +18 -18
  694. package/source/components/_common/IconSVG/SVG/settings/Account.tsx +17 -17
  695. package/source/components/_common/IconSVG/SVG/settings/DataUsage.tsx +17 -17
  696. package/source/components/_common/IconSVG/SVG/settings/MarketResearch.tsx +17 -17
  697. package/source/components/_common/IconSVG/SVG/settings/Newsletter.tsx +17 -17
  698. package/source/components/_common/IconSVG/SVG/settings/RemoveEye.tsx +17 -17
  699. package/source/components/_common/IconSVG/SVG/settings/RemoveEyeOff.tsx +17 -17
  700. package/source/components/_common/IconSVG/SVG/settings/Security.tsx +17 -17
  701. package/source/components/_common/IconSVG/SVG/settings/Warning.tsx +17 -17
  702. package/source/components/_common/IconSVG/SVG/slider/360.tsx +23 -23
  703. package/source/components/_common/IconSVG/SVG/slider/360New.tsx +20 -20
  704. package/source/components/_common/IconSVG/SVG/slider/Checked.tsx +19 -19
  705. package/source/components/_common/IconSVG/SVG/slider/DiscountRibbon.tsx +51 -51
  706. package/source/components/_common/IconSVG/SVG/slider/DiscountRibbonMobile.tsx +47 -47
  707. package/source/components/_common/IconSVG/SVG/slider/DiscountRibbonNew.tsx +29 -29
  708. package/source/components/_common/IconSVG/SVG/slider/Easy.tsx +19 -19
  709. package/source/components/_common/IconSVG/SVG/slider/Fullscreen.tsx +16 -16
  710. package/source/components/_common/IconSVG/SVG/slider/FullscreenWindow.tsx +23 -23
  711. package/source/components/_common/IconSVG/SVG/slider/Safe.tsx +19 -19
  712. package/source/components/_common/IconSVG/SVG/slider/ToBuy.tsx +19 -19
  713. package/source/components/_common/IconSVG/SVG/slider/ZoomIn.tsx +21 -21
  714. package/source/components/_common/IconSVG/SVG/slider/ZoomOut.tsx +21 -21
  715. package/source/components/_common/IconSVG/SVG/social/AndroidLogo.tsx +18 -18
  716. package/source/components/_common/IconSVG/SVG/social/Apple.tsx +19 -19
  717. package/source/components/_common/IconSVG/SVG/social/FacebookF.tsx +19 -19
  718. package/source/components/_common/IconSVG/SVG/social/GooglePlusG.tsx +19 -19
  719. package/source/components/_common/IconSVG/SVG/social/Instagram.tsx +17 -17
  720. package/source/components/_common/IconSVG/SVG/social/Pinterest.tsx +19 -19
  721. package/source/components/_common/IconSVG/SVG/social/SharingInterface.tsx +21 -21
  722. package/source/components/_common/IconSVG/SVG/social/Twitter.tsx +19 -19
  723. package/source/components/_common/IconSVG/SVG/social/Youtube.tsx +19 -19
  724. package/source/components/_common/IconSVG/SVG/vehicle/AboIcon.tsx +11 -11
  725. package/source/components/_common/IconSVG/SVG/vehicle/Abs.tsx +24 -24
  726. package/source/components/_common/IconSVG/SVG/vehicle/AirCond.tsx +34 -34
  727. package/source/components/_common/IconSVG/SVG/vehicle/Airbag.tsx +21 -21
  728. package/source/components/_common/IconSVG/SVG/vehicle/AuxiliaryHeating.tsx +23 -23
  729. package/source/components/_common/IconSVG/SVG/vehicle/Bluetooth.tsx +22 -22
  730. package/source/components/_common/IconSVG/SVG/vehicle/BuyIcon.tsx +15 -15
  731. package/source/components/_common/IconSVG/SVG/vehicle/CarAvailability.tsx +22 -22
  732. package/source/components/_common/IconSVG/SVG/vehicle/CarInspectionCheck.tsx +21 -21
  733. package/source/components/_common/IconSVG/SVG/vehicle/CarInspectionCross.tsx +21 -21
  734. package/source/components/_common/IconSVG/SVG/vehicle/CheckoutChecked.tsx +15 -15
  735. package/source/components/_common/IconSVG/SVG/vehicle/Co2.tsx +24 -24
  736. package/source/components/_common/IconSVG/SVG/vehicle/CruiseControl.tsx +25 -25
  737. package/source/components/_common/IconSVG/SVG/vehicle/Date.tsx +21 -21
  738. package/source/components/_common/IconSVG/SVG/vehicle/Delivery.tsx +12 -12
  739. package/source/components/_common/IconSVG/SVG/vehicle/Diesel.tsx +28 -28
  740. package/source/components/_common/IconSVG/SVG/vehicle/Display.tsx +25 -25
  741. package/source/components/_common/IconSVG/SVG/vehicle/Done.tsx +11 -11
  742. package/source/components/_common/IconSVG/SVG/vehicle/Door.tsx +19 -19
  743. package/source/components/_common/IconSVG/SVG/vehicle/DoubleDone.tsx +18 -18
  744. package/source/components/_common/IconSVG/SVG/vehicle/EditIcon.tsx +11 -11
  745. package/source/components/_common/IconSVG/SVG/vehicle/EmergencyBrakeAssistant.tsx +27 -27
  746. package/source/components/_common/IconSVG/SVG/vehicle/Eps.tsx +24 -24
  747. package/source/components/_common/IconSVG/SVG/vehicle/Esp.tsx +24 -24
  748. package/source/components/_common/IconSVG/SVG/vehicle/FinancingIcon.tsx +20 -20
  749. package/source/components/_common/IconSVG/SVG/vehicle/FuelConsumption.tsx +20 -20
  750. package/source/components/_common/IconSVG/SVG/vehicle/Fueling.tsx +22 -22
  751. package/source/components/_common/IconSVG/SVG/vehicle/FullDrive.tsx +24 -24
  752. package/source/components/_common/IconSVG/SVG/vehicle/GasElectric.tsx +28 -28
  753. package/source/components/_common/IconSVG/SVG/vehicle/HandsFreePhoneSystem.tsx +24 -24
  754. package/source/components/_common/IconSVG/SVG/vehicle/Kw.tsx +23 -23
  755. package/source/components/_common/IconSVG/SVG/vehicle/LastCrawledAt.tsx +22 -22
  756. package/source/components/_common/IconSVG/SVG/vehicle/LeasingIcon.tsx +14 -14
  757. package/source/components/_common/IconSVG/SVG/vehicle/Led.tsx +24 -24
  758. package/source/components/_common/IconSVG/SVG/vehicle/LightSensor.tsx +22 -22
  759. package/source/components/_common/IconSVG/SVG/vehicle/LinkAlternative.tsx +15 -15
  760. package/source/components/_common/IconSVG/SVG/vehicle/Location.tsx +17 -17
  761. package/source/components/_common/IconSVG/SVG/vehicle/MinusIcon.tsx +11 -11
  762. package/source/components/_common/IconSVG/SVG/vehicle/Mirror.tsx +19 -19
  763. package/source/components/_common/IconSVG/SVG/vehicle/Navigation.tsx +27 -27
  764. package/source/components/_common/IconSVG/SVG/vehicle/NewCar.tsx +21 -21
  765. package/source/components/_common/IconSVG/SVG/vehicle/NoImage.tsx +17 -17
  766. package/source/components/_common/IconSVG/SVG/vehicle/Owner.tsx +18 -18
  767. package/source/components/_common/IconSVG/SVG/vehicle/PanoramicRoof.tsx +23 -23
  768. package/source/components/_common/IconSVG/SVG/vehicle/ParkingAssistants.tsx +24 -24
  769. package/source/components/_common/IconSVG/SVG/vehicle/PickYourself.tsx +18 -18
  770. package/source/components/_common/IconSVG/SVG/vehicle/PlusIcon.tsx +11 -11
  771. package/source/components/_common/IconSVG/SVG/vehicle/Power.tsx +21 -21
  772. package/source/components/_common/IconSVG/SVG/vehicle/Ps.tsx +19 -19
  773. package/source/components/_common/IconSVG/SVG/vehicle/Question.tsx +24 -24
  774. package/source/components/_common/IconSVG/SVG/vehicle/Seats.tsx +21 -21
  775. package/source/components/_common/IconSVG/SVG/vehicle/SeatsHeating.tsx +26 -26
  776. package/source/components/_common/IconSVG/SVG/vehicle/SelectorGearboxAutomatic.tsx +24 -24
  777. package/source/components/_common/IconSVG/SVG/vehicle/SelectorGearboxManualShift.tsx +19 -19
  778. package/source/components/_common/IconSVG/SVG/vehicle/SelectorGearboxOther.tsx +24 -24
  779. package/source/components/_common/IconSVG/SVG/vehicle/SelectorGearboxSemiAutomatic.tsx +30 -30
  780. package/source/components/_common/IconSVG/SVG/vehicle/SelectorInteriorTypeAlcantara.tsx +225 -225
  781. package/source/components/_common/IconSVG/SVG/vehicle/SelectorInteriorTypeFabric.tsx +29 -29
  782. package/source/components/_common/IconSVG/SVG/vehicle/SelectorInteriorTypeFullLeather.tsx +29 -29
  783. package/source/components/_common/IconSVG/SVG/vehicle/SelectorInteriorTypeOther.tsx +26 -26
  784. package/source/components/_common/IconSVG/SVG/vehicle/SelectorInteriorTypePartLeather.tsx +142 -142
  785. package/source/components/_common/IconSVG/SVG/vehicle/SelectorInteriorTypeSyntheticLeather.tsx +27 -27
  786. package/source/components/_common/IconSVG/SVG/vehicle/SelectorInteriorTypeVelours.tsx +39 -39
  787. package/source/components/_common/IconSVG/SVG/vehicle/Shield.tsx +39 -39
  788. package/source/components/_common/IconSVG/SVG/vehicle/Speedometer.tsx +17 -17
  789. package/source/components/_common/IconSVG/SVG/vehicle/StartStopSystem.tsx +30 -30
  790. package/source/components/_common/IconSVG/SVG/vehicle/Stop.tsx +25 -25
  791. package/source/components/_common/IconSVG/SVG/vehicle/TickMark.tsx +21 -21
  792. package/source/components/_common/IconSVG/SVG/vehicle/TrafficSignRecognition.tsx +29 -29
  793. package/source/components/_common/IconSVG/SVG/vehicle/TrailerCoupling.tsx +24 -24
  794. package/source/components/_common/IconSVG/SVG/vehicle/Transmission.tsx +27 -27
  795. package/source/components/_common/IconSVG/SVG/vehicle/Wheel.tsx +43 -43
  796. package/source/components/_common/IconSVG/SVG/vehicle/Wipers.tsx +22 -22
  797. package/source/components/_common/IconSVG/SVG/vehicle/Wrench.tsx +17 -17
  798. package/source/components/_common/Image/Image.story.js +142 -142
  799. package/source/components/_common/Image/Image.story.styl +18 -18
  800. package/source/components/_common/Image/Image.styl +109 -109
  801. package/source/components/_common/Image/Image.tsx +302 -302
  802. package/source/components/_common/ImagesSet/ImagesSet.story.js +34 -34
  803. package/source/components/_common/ImagesSet/ImagesSet.story.styl +3 -3
  804. package/source/components/_common/ImagesSet/ImagesSet.styl +27 -27
  805. package/source/components/_common/ImagesSet/ImagesSet.tsx +76 -76
  806. package/source/components/_common/Loader/Loader.story.js +21 -21
  807. package/source/components/_common/Loader/Loader.styl +39 -39
  808. package/source/components/_common/Loader/Loader.tsx +32 -32
  809. package/source/components/_common/MagnifyGlass/MagnifyGlass.styl +33 -33
  810. package/source/components/_common/MagnifyGlass/MagnifyGlass.tsx +213 -213
  811. package/source/components/_common/MaterialAccordion/MaterialAccordion.tsx +149 -149
  812. package/source/components/_common/MaterialAccordionGroup/MaterialAccordionGroup.story.js +49 -49
  813. package/source/components/_common/MaterialAccordionGroup/MaterialAccordionGroup.styled.tsx +71 -71
  814. package/source/components/_common/MaterialAccordionGroup/MaterialAccordionGroup.tsx +40 -40
  815. package/source/components/_common/MaterialAutocomplete/MaterialAutocomplete.styled.tsx +204 -204
  816. package/source/components/_common/MaterialAutocomplete/MaterialAutocomplete.tsx +225 -225
  817. package/source/components/_common/MaterialDatePicker/MaterialDatePicker.story.js +45 -45
  818. package/source/components/_common/MaterialDatePicker/MaterialDatePicker.story.styl +5 -5
  819. package/source/components/_common/MaterialDatePicker/MaterialDatePicker.styled.tsx +21 -21
  820. package/source/components/_common/MaterialDatePicker/MaterialDatePicker.tsx +112 -112
  821. package/source/components/_common/MaterialField/MaterialField.story.js +87 -87
  822. package/source/components/_common/MaterialField/MaterialField.story.styl +33 -33
  823. package/source/components/_common/MaterialField/MaterialField.styled.tsx +52 -52
  824. package/source/components/_common/MaterialField/MaterialField.tsx +120 -120
  825. package/source/components/_common/MaterialSelect/MaterialSelect.story.js +52 -52
  826. package/source/components/_common/MaterialSelect/MaterialSelect.story.styl +5 -5
  827. package/source/components/_common/MaterialSelect/MaterialSelect.styled.tsx +126 -126
  828. package/source/components/_common/MaterialSelect/MaterialSelect.tsx +218 -218
  829. package/source/components/_common/MaterialStepButton/MaterialStepButton.story.js +47 -47
  830. package/source/components/_common/MaterialStepButton/MaterialStepButton.story.styl +5 -5
  831. package/source/components/_common/MaterialStepButton/MaterialStepButton.styl +32 -32
  832. package/source/components/_common/MaterialStepButton/MaterialStepButton.tsx +61 -61
  833. package/source/components/_common/MaterialSwitch/MaterialSwitch.story.js +17 -17
  834. package/source/components/_common/MaterialSwitch/MaterialSwitch.styled.tsx +5 -5
  835. package/source/components/_common/MaterialSwitch/MaterialSwitch.tsx +35 -35
  836. package/source/components/_common/MaterialTooltip/MaterialTooltip.story.js +10 -10
  837. package/source/components/_common/MaterialTooltip/MaterialTooltip.tsx +21 -21
  838. package/source/components/_common/Modal/CookieModal.tsx +40 -40
  839. package/source/components/_common/Modal/Modal.story.js +37 -37
  840. package/source/components/_common/Modal/Modal.styled.tsx +13 -13
  841. package/source/components/_common/Modal/Modal.tsx +27 -27
  842. package/source/components/_common/Modal/ModalsConfig.tsx +19 -19
  843. package/source/components/_common/Modal/modals/ManageCookieModal/ManageCookieModal.styl +67 -67
  844. package/source/components/_common/Modal/modals/ManageCookieModal/ManageCookieModal.tsx +147 -147
  845. package/source/components/_common/Modal/modals/PreviewCookieModal/PreviewCookieModal.styl +44 -44
  846. package/source/components/_common/Modal/modals/PreviewCookieModal/PreviewCookieModal.tsx +33 -33
  847. package/source/components/_common/Modal/modals/TestModal.tsx +7 -7
  848. package/source/components/_common/MuiDropDown/MuiDropDown.tsx +93 -93
  849. package/source/components/_common/MuiGroupedSelect/MuiGroupedSelect.story.js +21 -21
  850. package/source/components/_common/MuiGroupedSelect/MuiGroupedSelect.tsx +87 -87
  851. package/source/components/_common/OfferRequestButtonWrapper/OfferRequestButtonWrapper.styl +119 -119
  852. package/source/components/_common/OfferRequestButtonWrapper/OfferRequestButtonWrapper.styled.tsx +23 -23
  853. package/source/components/_common/OfferRequestButtonWrapper/OfferRequestButtonWrapper.tsx +118 -118
  854. package/source/components/_common/PropertySelector/FormPSGroup.story.js +36 -36
  855. package/source/components/_common/PropertySelector/FormPSGroup.story.styl +5 -5
  856. package/source/components/_common/PropertySelector/FormPSGroup.styl +22 -22
  857. package/source/components/_common/PropertySelector/FormPSGroup.tsx +54 -54
  858. package/source/components/_common/PropertySelector/PSGroup.story.js +93 -93
  859. package/source/components/_common/PropertySelector/PSGroup.story.styl +25 -25
  860. package/source/components/_common/PropertySelector/PSGroup.styl +5 -5
  861. package/source/components/_common/PropertySelector/PSGroup.tsx +98 -98
  862. package/source/components/_common/PropertySelector/PropertySelector.styl +139 -139
  863. package/source/components/_common/PropertySelector/PropertySelector.tsx +100 -100
  864. package/source/components/_common/PropertySelector/ProperySelector.story.js +83 -83
  865. package/source/components/_common/Radio/FormRadioGroup.story.js +28 -28
  866. package/source/components/_common/Radio/FormRadioGroup.story.styl +2 -2
  867. package/source/components/_common/Radio/FormRadioGroup.styl +22 -22
  868. package/source/components/_common/Radio/FormRadioGroup.tsx +52 -52
  869. package/source/components/_common/Radio/Radio.story.js +54 -54
  870. package/source/components/_common/Radio/Radio.styl +115 -115
  871. package/source/components/_common/Radio/Radio.tsx +141 -141
  872. package/source/components/_common/Radio/RadioGroup.story.js +90 -90
  873. package/source/components/_common/Radio/RadioGroup.story.styl +39 -39
  874. package/source/components/_common/Radio/RadioGroup.styl +5 -5
  875. package/source/components/_common/Radio/RadioGroup.tsx +65 -65
  876. package/source/components/_common/Range/Range.story.js +46 -46
  877. package/source/components/_common/Range/Range.story.styl +4 -4
  878. package/source/components/_common/Range/Range.styl +71 -71
  879. package/source/components/_common/Range/Range.tsx +69 -69
  880. package/source/components/_common/Skeleton/SkeletonItem.styl +80 -80
  881. package/source/components/_common/Skeleton/SkeletonItem.tsx +80 -80
  882. package/source/components/_common/Skeleton/SkeletonSearchItem.styl +123 -123
  883. package/source/components/_common/Skeleton/SkeletonSearchItem.tsx +92 -92
  884. package/source/components/_common/Slider/Slider.styl +2 -2
  885. package/source/components/_common/Slider/Slider.tsx +130 -130
  886. package/source/components/_common/SliderArrow/SliderArrow.story.js +18 -18
  887. package/source/components/_common/SliderArrow/SliderArrow.styl +32 -32
  888. package/source/components/_common/SliderArrow/SliderArrow.tsx +36 -36
  889. package/source/components/_common/StarButton/StarButton.styl +39 -39
  890. package/source/components/_common/StarButton/StarButton.tsx +31 -31
  891. package/source/components/_common/Tabs/TabPanel.tsx +28 -28
  892. package/source/components/_common/Tabs/Tabs.story.js +55 -55
  893. package/source/components/_common/Tabs/Tabs.styl +40 -40
  894. package/source/components/_common/Tabs/Tabs.tsx +44 -44
  895. package/source/components/_common/TextAreaField/TextAreaField.styl +47 -47
  896. package/source/components/_common/TextAreaField/TextAreaField.tsx +74 -74
  897. package/source/components/_common/TextField/FormTextField.story.js +21 -21
  898. package/source/components/_common/TextField/FormTextField.styl +35 -35
  899. package/source/components/_common/TextField/FormTextField.tsx +54 -54
  900. package/source/components/_common/TextField/TextField.styl +37 -37
  901. package/source/components/_common/TextField/TextField.tsx +77 -77
  902. package/source/components/_common/TimePicker/TimePicker.story.js +37 -37
  903. package/source/components/_common/TimePicker/TimePicker.styl +20 -20
  904. package/source/components/_common/TimePicker/TimePicker.tsx +144 -144
  905. package/source/components/_common/Tooltip/Tooltip.story.js +28 -28
  906. package/source/components/_common/Tooltip/Tooltip.styl +123 -123
  907. package/source/components/_common/Tooltip/Tooltip.tsx +62 -62
  908. package/source/components/_common/UserMenu/MaterialMenu.story.js +56 -56
  909. package/source/components/_common/UserMenu/MaterialMenu.styled.tsx +73 -73
  910. package/source/components/_common/UserMenu/MaterialMenu.tsx +95 -95
  911. package/source/components/_common/UserMenu/MaterialMenuItem.tsx +54 -54
  912. package/source/components/_common/Usp/Usp.styl +78 -78
  913. package/source/components/_common/Usp/Usp.tsx +30 -30
  914. package/source/components/_common/VehicleSlider/VehicleSlider.story.js +99 -99
  915. package/source/components/_common/VehicleSlider/VehicleSlider.styl +62 -62
  916. package/source/components/_common/VehicleSlider/VehicleSlider.tsx +125 -125
  917. package/source/components/_common/VehicleSlider/VehicleSliderForSRL.tsx +170 -170
  918. package/source/components/_common/withLabel/withLabel.story.js +62 -62
  919. package/source/components/_common/withLabel/withLabel.styl +33 -33
  920. package/source/components/_common/withLabel/withLabel.tsx +44 -44
  921. package/source/components/_common/withPopover/withPopover.story.js +48 -48
  922. package/source/components/_common/withPopover/withPopover.story.styl +53 -53
  923. package/source/components/_common/withPopover/withPopover.styl +3 -3
  924. package/source/components/_common/withPopover/withPopover.tsx +88 -88
  925. package/source/components/_common/withStats/withStats.story.js +75 -75
  926. package/source/components/_common/withStats/withStats.styl +147 -147
  927. package/source/components/_common/withStats/withStats.tsx +185 -185
  928. package/source/components/containers/SearchPage/FiltersContainer/FiltersContainer.styl +50 -50
  929. package/source/components/containers/SearchPage/FiltersContainer/FiltersContainer.tsx +422 -422
  930. package/source/framework/DataTransformers.ts +80 -80
  931. package/source/framework/constants/RateSearchWidget.ts +15 -15
  932. package/source/framework/constants/Search.ts +290 -290
  933. package/source/framework/constants/SearchWidget.ts +108 -108
  934. package/source/framework/constants/app.ts +223 -223
  935. package/source/framework/constants/cars.ts +36 -36
  936. package/source/framework/constants/common.ts +28 -19
  937. package/source/framework/constants/data.ts +52 -52
  938. package/source/framework/constants/filters.ts +11 -11
  939. package/source/framework/constants/highlights.ts +165 -165
  940. package/source/framework/constants/price.ts +9 -9
  941. package/source/framework/constants/queryBuilder.ts +4 -4
  942. package/source/framework/constants/selectors.ts +38 -38
  943. package/source/framework/constants.ts +116 -116
  944. package/source/framework/data.ts +6 -6
  945. package/source/framework/factories/BreadcrumbsFactory.tsx +271 -271
  946. package/source/framework/factories/FactoryTypes.d.ts +30 -30
  947. package/source/framework/factories/FilterFactory.ts +364 -364
  948. package/source/framework/factories/ModalsFactory.tsx +11 -11
  949. package/source/framework/hooks/useModal.ts +13 -13
  950. package/source/framework/schemes/AggregationScheme.ts +73 -73
  951. package/source/framework/types/types.ts +334 -334
  952. package/source/framework/utils/CommonUtils.ts +553 -545
  953. package/source/framework/utils/CookieUtils.ts +61 -61
  954. package/source/framework/utils/DateUtils.ts +93 -93
  955. package/source/framework/utils/FiltersUtils.ts +234 -234
  956. package/source/framework/utils/RequestUtils.ts +20 -20
  957. package/source/framework/utils/StyledComponent.ts +2 -2
  958. package/source/framework/vehiclesProps/cbdSelectors.ts +117 -117
  959. package/source/framework/vehiclesProps/decoratedLightProps.tsx +345 -345
  960. package/source/framework/vehiclesProps/decoratedProps.tsx +1040 -1040
  961. package/source/framework/vehiclesProps/equipment.ts +128 -128
  962. package/source/framework/vehiclesProps/highlights.ts +54 -54
  963. package/source/framework/vehiclesProps/vehicleDetails.ts +329 -329
  964. package/source/globals.d.ts +18 -18
  965. package/source/locales/SearchDetailedPage.ts +205 -205
  966. package/source/locales/SearchPage.ts +224 -224
  967. package/source/locales/cbd.ts +719 -719
  968. package/source/locales/common.ts +109 -109
  969. package/source/locales/data.ts +1075 -1075
  970. package/source/locales/priceRating.ts +10 -10
  971. package/source/locales/sortingOptions.ts +21 -21
  972. package/source/theme/colors.styl +46 -46
  973. package/source/theme/mixins.styl +93 -93
  974. package/source/theme/priceReviewColors.styl +12 -12
  975. package/source/theme/selector_colors.styl +61 -61
  976. package/source/theme/slider.global.styl +3 -3
  977. package/source/theme/theme.styl +136 -136
  978. package/tsconfig.json +63 -63
  979. package/tslint.json +40 -40
  980. package/utils.ts +17 -17
@@ -1,545 +1,553 @@
1
- import qs from 'qs';
2
- import _get from 'lodash/get';
3
- import { formatLocale as d3formatLocale } from 'd3-format';
4
- import Cookies from 'js-cookie';
5
- import {
6
- FIRST_REGISTRATION, MANUFACTURER, MILEAGE, MODEL, BODY_TYPE, PRICE, RATE,
7
- DROP_DOWN_GROUP, RATE_DEFAULT, MMS_GROUPS_KEY, MMS_GROUP_FIELDS
8
- } from '../constants/SearchWidget';
9
- import { priceRatings, priceRatingConfig } from '../constants/price';
10
- import { HUNDRED } from '../constants/common';
11
- import { offers } from '../constants';
12
- import { FILTERS_IN_TITLE, MANUFACTURER_KEY, MAX_FILTERS_IN_TITLE, MODEL_KEY } from '../constants/Search';
13
-
14
- const PRICE_DEFAULT = DROP_DOWN_GROUP[PRICE].defaultValue;
15
-
16
- export const formatMileage = (millage: number | string) => {
17
- return millage.toLocaleString('en-US').replace(/,/g, '.');
18
- };
19
-
20
- export const getFormattedNumber = (num: number) => Number.isFinite(num) ? num.toLocaleString('de-DE') : null;
21
-
22
- export const numberWithDot = (value: number | string) => {
23
- switch (value) {
24
- case 'any':
25
- return value;
26
- case 'beliebig':
27
- return value;
28
- default: return getFormattedNumber(+value);
29
- }
30
- // if (value === 'any' || value === 'beliebig') {
31
- // return value;
32
- // }
33
- return getFormattedNumber(+value);
34
- };
35
-
36
- export const arrToObj = (arr: string[]): { [key: string]: boolean } => {
37
- if (!Array.isArray(arr)) return {};
38
- return arr.reduce(
39
- (obj: { [key: string]: boolean }, el: string) => { obj[el] = true; return obj; }, {}
40
- );
41
- };
42
-
43
- export const addPrefixToKeys = (obj: { [key: string]: any }, prefix: string) => {
44
- const result: { [key: string]: any } = {};
45
- Object.keys(obj).reduce((_, key) => {
46
- result[`${prefix}_${key}`] = obj[key];
47
- return result;
48
- }, result); // tslint:disable-line:align
49
- return result;
50
- };
51
-
52
- // function return list of filter for inject in title
53
- export const filtersInTitle = (filters: any) => {
54
- const result: any[] = [];
55
- const pushInResult = (value: any) => {
56
- if (result.length < MAX_FILTERS_IN_TITLE && value) {
57
- result.push(value);
58
- }
59
- };
60
-
61
- FILTERS_IN_TITLE.forEach((filter: string) => {
62
- if (filter === MMS_GROUPS_KEY) {
63
- filters.get(filter).forEach((MmsObject: any) => {
64
- pushInResult(MmsObject[MANUFACTURER_KEY].value);
65
- pushInResult(MmsObject[MODEL_KEY].value);
66
- });
67
- } else {
68
- filters.get(filter).value.forEach((value: string) => {
69
- pushInResult(value);
70
- });
71
- }
72
- });
73
- return result;
74
- };
75
-
76
- export const changeLocation = (path: string) =>
77
- window.location.href = `${window.location.origin}/${path}`;
78
-
79
- export const checkRangeValuesOnEqual = (defaultValues: any, filterValues: any) => {
80
- const keys = Object.keys(defaultValues);
81
- let valuesIsEqual = true;
82
- for (let i = 0; i < keys.length; i += 1) {
83
- const period = keys[i];
84
-
85
- if (filterValues[period] !== defaultValues[period]) {
86
- valuesIsEqual = false;
87
- break;
88
- }
89
- }
90
-
91
- return valuesIsEqual;
92
- };
93
-
94
- export interface ICarImage {
95
- url?: string;
96
- imageUrlSmall?: string;
97
- imageUrlMedium?: string;
98
- imageUrlLarge?: string;
99
- }
100
-
101
- export const preloadNearbyImages = (images: ICarImage[], activeIndex: number, imageUrlSize: 'imageUrlSmall' | 'imageUrlMedium' | 'imageUrlLarge') => {
102
- const imagesCount = Array.isArray(images) ? images.length : 0;
103
- const imageSize = imageUrlSize;
104
-
105
- const inMemoryPrevImage = new Image();
106
- const inMemoryNextImage = new Image();
107
-
108
- if (!!imagesCount) {
109
- const prevIndex = (activeIndex - 1 % imagesCount + imagesCount) % imagesCount;
110
- const nextIndex = (activeIndex + 1 % imagesCount + imagesCount) % imagesCount;
111
-
112
- inMemoryPrevImage.src = images[prevIndex][imageSize];
113
- inMemoryNextImage.src = images[nextIndex][imageSize];
114
- }
115
- };
116
-
117
- export const getGroupValuesForQuery = (groups: any) => {
118
- const arr: any = [];
119
- groups.map((group: any) => {
120
- const groupObj: any = {};
121
-
122
- Object.keys(group).forEach((key: string) => {
123
- const item = group[key];
124
- if (item.value) {
125
- groupObj[key] = item.value;
126
- }
127
- });
128
- if (Object.keys(groupObj).length) {
129
- arr.push(groupObj);
130
- }
131
- });
132
- return arr;
133
- };
134
-
135
- export const buildBodyForRequest = (state: any) => {
136
- const query: any = {
137
- filters: {
138
- absolutValues: {
139
- mmsGroup0: {}
140
- },
141
- noAbsolutValues: {},
142
- rangeValues: {}
143
- }
144
- };
145
-
146
- Object.keys(state).sort().forEach((key: string) => {
147
- const value = state[key];
148
-
149
- if (!value) return;
150
-
151
- if (key === MANUFACTURER && value.value) {
152
- query.filters.absolutValues.mmsGroup0.mainData_make = value.value;
153
- }
154
-
155
- if (key === MODEL && value.value) {
156
- if (value.isSeries) {
157
- query.filters.absolutValues.mmsGroup0.mainData_series = value.value;
158
- } else {
159
- query.filters.absolutValues.mmsGroup0.mainData_model = value.value;
160
- }
161
- }
162
-
163
- if (key === BODY_TYPE && value.length) {
164
- query.filters.noAbsolutValues[BODY_TYPE] = value;
165
- }
166
-
167
- if (key === FIRST_REGISTRATION && value.value) {
168
- query.filters.rangeValues['mainData_firstRegistrationYear'] = { from: value.value };
169
- }
170
-
171
- if (key === MILEAGE && value.value) {
172
- query.filters.rangeValues['mainData_mileage'] = { to: value.value };
173
- }
174
-
175
- if (key === PRICE) {
176
- const valueIsEqual = checkRangeValuesOnEqual(PRICE_DEFAULT, value);
177
-
178
- if (!valueIsEqual) {
179
- // check value in from / to. If we have - add it
180
- Object.keys(value).map((key: string) => {
181
- if (value[key]) {
182
- if (!query.filters.rangeValues['price_currentSalesPrice']) {
183
- query.filters.rangeValues['price_currentSalesPrice'] = {};
184
- }
185
-
186
- query.filters.rangeValues['price_currentSalesPrice'][key] = value[key];
187
- }
188
- });
189
- }
190
- }
191
-
192
- if (key === RATE) {
193
- const isRateDefault = checkRangeValuesOnEqual(RATE_DEFAULT, value);
194
-
195
- if (!isRateDefault) {
196
- query.filters.rangeValues['price_currentSalesPrice'] = { from: 1000, to: 2000 };
197
- }
198
- }
199
- });
200
-
201
- return query;
202
- };
203
-
204
- export const buildQueryForSearch = (filters: any) => {
205
- const query: { [key: string]: any } = {};
206
- const MMS_GROUP: any = {};
207
-
208
- Object.keys(filters).forEach((filter: string) => {
209
- const filterValue = filters[filter];
210
-
211
- if (filterValue && filterValue.value) {
212
- if (MMS_GROUP_FIELDS.indexOf(filter) !== -1) {
213
- MMS_GROUP[filter] = filterValue.value;
214
-
215
- if (filterValue.isSeries) {
216
- MMS_GROUP.SERIES = filterValue.value;
217
- }
218
- }
219
- }
220
-
221
- if (filterValue === PRICE) {
222
- const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
223
- const valueIsDefault = filter === PRICE ? checkRangeValuesOnEqual(defaultValue, filterValue) : filterValue === defaultValue;
224
-
225
- if (!valueIsDefault) {// check value in from / to. If we have - add it
226
- Object.keys(filterValue).map((key: string) => {
227
- if (filterValue[key]) {
228
- if (!query.filters.rangeValues['price_currentSalesPrice']) {
229
- query.filters.rangeValues['price_currentSalesPrice'] = {};
230
- }
231
-
232
- query.filters.rangeValues['price_currentSalesPrice'][key] = filterValue[key];
233
- }
234
- });
235
- }
236
- }
237
-
238
- if (filter === PRICE) {
239
- const valueIsDefault = checkRangeValuesOnEqual(PRICE_DEFAULT, filterValue);
240
-
241
- if (!valueIsDefault) {
242
- query[PRICE] = { from: '', to: '' };
243
- query[PRICE].from = _get(filterValue, 'from', '');
244
- query[PRICE].to = _get(filterValue, 'to', '');
245
- }
246
- }
247
-
248
- if (filter === RATE) {
249
- const isRateDefault = checkRangeValuesOnEqual(RATE_DEFAULT, filterValue);
250
-
251
- if (!isRateDefault) {
252
- query[RATE] = filterValue;
253
- }
254
- }
255
-
256
- if (filter === MILEAGE) {
257
- const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
258
- if (filterValue !== defaultValue) {
259
- query[MILEAGE] = { from: '', to: '' };
260
- query[MILEAGE].from = _get(filterValue, 'from', '');
261
- query[MILEAGE].to = _get(filterValue, 'to', '') || _get(filterValue, 'value', '');
262
- }
263
- }
264
-
265
- if (filter === FIRST_REGISTRATION) {
266
- const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
267
- if (filterValue !== defaultValue) {
268
- query[FIRST_REGISTRATION] = { from: '', to: '' };
269
- query[FIRST_REGISTRATION].from = _get(filterValue, 'from', '') || _get(filterValue, 'value', '');
270
- query[FIRST_REGISTRATION].to = _get(filterValue, 'to', '');
271
- }
272
- }
273
-
274
- if (filter === BODY_TYPE) {
275
- const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
276
-
277
- if (filterValue.length && filterValue !== defaultValue) {
278
- query[BODY_TYPE] = [];
279
-
280
- filterValue.map((bodyTypeSelector: string) => {
281
- query[BODY_TYPE].push(bodyTypeSelector);
282
- });
283
- }
284
- }
285
- });
286
-
287
- if (Object.keys(MMS_GROUP).length) {
288
- query[MMS_GROUPS_KEY] = [];
289
- query[MMS_GROUPS_KEY].push(MMS_GROUP);
290
- }
291
-
292
- return qs.stringify(query, { encode: false });
293
- };
294
-
295
- export const sliceLessThan = (array: number[], to: any): number[] => {
296
- const value = Number(to);
297
- return value && Number.isFinite(value)
298
- ? array.filter((val: number) => val <= value)
299
- : array;
300
- };
301
-
302
- export const sliceMoreThan = (array: number[], from: any): number[] => {
303
- const value = Number(from);
304
- return value && Number.isFinite(value)
305
- ? array.filter((val: number) => val >= value)
306
- : array;
307
- };
308
-
309
- export const getFormattedPrice = (price: any, format = '$,.0f', currency = ''): string => {
310
- if (!Number.isFinite(price)) return '-';
311
- const groupingNum = 3;
312
- return d3formatLocale({
313
- decimal: ',',
314
- thousands: '.',
315
- currency: ['', currency],
316
- grouping: [groupingNum]
317
- }).format(format)(price);
318
- };
319
-
320
- export const getPriceRating = (currentSalesPrice: number, predictablePrice: number) => {
321
- const isCorrectCurrentSalesPrice = Number.isFinite(Number.parseFloat(`${currentSalesPrice}`));
322
- const isCorrectPredictablePrice = Number.isFinite(Number.parseFloat(`${predictablePrice}`));
323
-
324
- if (!isCorrectCurrentSalesPrice || !isCorrectPredictablePrice) return 0;
325
-
326
- const ratingConfig = getPriceRatingConfig(currentSalesPrice, predictablePrice);
327
-
328
- for (const key of Object.keys(ratingConfig)) {
329
- const { min, max } = ratingConfig[key];
330
- const TOP_PRICE = 5;
331
- if (key === 'highPrice' && currentSalesPrice === max) return 1;
332
- if (key === 'topPrice' && currentSalesPrice <= min) return TOP_PRICE;
333
- if (currentSalesPrice >= min && currentSalesPrice < max) return priceRatings.indexOf(key);
334
- }
335
-
336
- return 0;
337
- };
338
-
339
- export const getPriceRatingConfig = (currentPrice: number, pricePredicted: number) => { // tslint:disable-line
340
- const round = (value: number) => {
341
- return Number.isFinite(pricePredicted)
342
- ? Math.round((pricePredicted * (1 + (value / 100))) / 100) * 100 // tslint:disable-line
343
- : '???';
344
- };
345
-
346
- if (currentPrice === 0) {
347
- console.log('Empty current price');
348
- }
349
-
350
- return Object.keys(priceRatingConfig).reduce((acc: any, key: any) => {
351
- const { min, max } = priceRatingConfig[key];
352
- return { ...acc, [key]: { min: round(min), max: round(max) } };
353
- }, {}); // tslint:disable-line
354
- };
355
-
356
- export const fixNumber = (num: number | string) => {
357
- const isNum = typeof num === 'number' ? num : parseFloat(num);
358
- return Math.round(isNum * HUNDRED) / HUNDRED;
359
- };
360
-
361
- export const getOfferSliders = (financingConfig: any, t: (key: string, options?: object) => string, priceTabIndex: null | number, componentType: string) => {
362
- const offerObj = offers[+priceTabIndex];
363
- const offerConfig = financingConfig[offerObj.name];
364
- const currentSalesPrice =
365
- financingConfig.common ?
366
- financingConfig.common.currentSalesPrice :
367
- financingConfig.currentSalesPrice; // TODO: fix deprecated. Correct is "financingConfig.common.currentSalesPrice"
368
- return offerObj.sliders
369
- .map((slider: any, index) => {
370
- if (componentType === 'checkout' && index === 1 && priceTabIndex === 0) return; // remove checkout annual mileage for financing
371
- if (slider.name === 'firstInstallment') slider.max = offerConfig.firstInstallmentMax || currentSalesPrice;
372
- slider.value = offerConfig[slider.name];
373
- slider.unitName = t(`modals:financing.${slider.unit}`);
374
- slider.caption = t(`modals:financing.${slider.name}`);
375
- return slider;
376
- }).filter(Boolean);
377
- };
378
-
379
- export const checkWebpFeature = async () => {
380
- // If the browser doesn't has the method createImageBitmap, you can't display webp format
381
- if (!self.createImageBitmap) return false;
382
-
383
- // Base64 representation of a white point image
384
- const webpData = 'data:image/webp;base64,UklGRiQAAABXRUJQVlA4IBgAAAAwAQCdASoCAAEAAQAcJaQAA3AA/v3AgAA=';
385
-
386
- // Retrieve the Image in Blob Format
387
- const blob = await fetch(webpData).then(r => r.blob());
388
-
389
- // If the createImageBitmap method succeeds, return true, otherwise false
390
- return createImageBitmap(blob).then(() => true, () => false);
391
- };
392
-
393
- export const getSupportedImageFormat = (IMAGE_URL: string, vehicleID: string, imageIdentifier: string, size: 'small' | 'medium' | 'large', webpFeature: boolean) => {
394
- if (!imageIdentifier) return null;
395
-
396
- const vehicleImageURL = `${IMAGE_URL}/${vehicleID}/${imageIdentifier}`;
397
-
398
- return webpFeature ? `${vehicleImageURL}/${size}-cached.webp` : `${vehicleImageURL}/${size}-cached.jpeg`;
399
- };
400
-
401
- export function getChipFilterValue(chip: any, t: (key: string, options?: object) => string, language: string = 'de') {
402
- let filterValue: string;
403
- let title: string;
404
- let from: string;
405
- let to: string;
406
- const chipFilterKey = chip.filterKey || chip.key; // we may have different key naming for landing or main
407
- const chipFilterValue = chip.filterValue || chip.value; // we may have different key naming for landing or main
408
- switch (chipFilterKey) {
409
- case 'MANUFACTURER':
410
- case 'MODEL':
411
- case 'SUB_MODEL':
412
- filterValue = chipFilterValue;
413
- break;
414
-
415
- case 'MANUFACTURER_EXCLUDE':
416
- case 'MODEL_EXCLUDE':
417
- title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
418
- filterValue = `${title} ${chipFilterValue}`;
419
- break;
420
-
421
- case 'FIRST_REGISTRATION':
422
- title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
423
- from = chipFilterValue.from ? `${t('SearchPage:filters.from')} ${chipFilterValue.from} ` : '';
424
- to = chipFilterValue.to ? `${t('SearchPage:filters.to')} ${chipFilterValue.to}` : '';
425
- filterValue = `${title} ${from} ${to}`;
426
- break;
427
-
428
- case 'PRICE':
429
- case 'PRICE_DIFFERENCE':
430
- case 'MILEAGE':
431
- case 'EMISSION_CO2':
432
- case 'POWER':
433
- case 'IMAGES_COUNT':
434
- title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
435
- from = chipFilterValue.from ? `${t('SearchPage:filters.from')} ${getFormattedPrice(+chipFilterValue.from)} ` : '';
436
- to = chipFilterValue.to ? `${t('SearchPage:filters.to')} ${getFormattedPrice(+chipFilterValue.to)}` : '';
437
- const type = chipFilterValue.type ? ` ${chipFilterValue.type}` : '';
438
- filterValue = `${title} ${from} ${to}${type}`;
439
- break;
440
-
441
- case 'DOORS':
442
- case 'OWNERS':
443
- filterValue = t(`SearchPage:filters.${chipFilterValue}`);
444
- break;
445
-
446
- case 'SEATS':
447
- case 'CUBIC_CAPACITY':
448
- title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
449
- const fromTo = `${chipFilterValue.from} - ${chipFilterValue.to}`;
450
- filterValue = `${title} ${fromTo}`;
451
- break;
452
-
453
- case 'CONSUMPTION':
454
- const fromValue = Number(chipFilterValue.from).toLocaleString(language);
455
- const toValue = Number(chipFilterValue.to).toLocaleString(language);
456
- const newFromValue: any = (fromValue === 'NaN') ? '1' : fromValue;
457
- const newToValue: any = (toValue === 'NaN') ? '18' : toValue;
458
- const fromToWithInfo = `${newFromValue} - ${newToValue}`;
459
- filterValue = t(`SearchPage:filtersChips.${chipFilterKey.toLocaleLowerCase()}`, { value: fromToWithInfo });
460
- break;
461
-
462
- case 'ONLINE_SINCE':
463
- filterValue = t(`SearchPage:filters.${chipFilterValue}`);
464
- break;
465
-
466
- case 'GENERAL_INSPECTION':
467
- filterValue = t(`SearchPage:filtersChips.generalInspection`, { month: t(`SearchPage:filters.${chipFilterValue}`) });
468
- break;
469
-
470
- case 'RATE':
471
- const { monthlyInstallmentFrom, monthlyInstallmentTo, firstInstallment, paybackPeriod } = chipFilterValue;
472
- const rowValues: any = { monthlyInstallmentFrom, monthlyInstallmentTo, firstInstallment, paybackPeriod };
473
- const values: string[][] = [
474
- ['monthlyInstallmentFrom', 'monthlyInstallmentTo'],
475
- ['firstInstallment', 'paybackPeriod']
476
- ].map((fields: string[]) => fields
477
- .map((field: string) => {
478
- const rowValue = rowValues[field];
479
- const value = Number.isFinite(+rowValue) ? getFormattedPrice(+rowValue) : rowValue;
480
- return +rowValue ? t(`SearchPage:filtersChips.${field}Chip`, { value }) : null;
481
- })
482
- .filter((item: any) => !!item)
483
- );
484
- const rateValue = `${t('SearchPage:filtersChips.rateChip')} ${values[0].length ? values[0].join(' ') : t('SearchPage:filtersChips.any')}`;
485
- filterValue = `${rateValue}, ${values[1].join(', ')}`;
486
- break;
487
-
488
- default:
489
- filterValue = t(`cbd:${chipFilterValue}`);
490
- }
491
- return filterValue;
492
- }
493
-
494
- function getUtmQueryParameter() {
495
- const query = window.location.search;
496
-
497
- if (!query) { return; }
498
-
499
- const queryString = /^[?]/.test(query) ? query.slice(1) : query;
500
-
501
- const result = queryString.split('&').reduce(
502
- (params: any, param: string) => {
503
- const [key, value] = param.split('=');
504
-
505
- if (!/^source|^campaign|^medium|^content|^term|^reference|^gclid|^adgroupid|^keyword/.test(key)) { return params; }
506
-
507
- params[key] = value ? decodeURIComponent(value.replace(/\+/g, ' ')) : '';
508
-
509
- return params;
510
- },
511
- {}
512
- ); // eslint-disable-line indent,@typescript-eslint/indent
513
-
514
- return result;
515
- }
516
-
517
- export function setUtmParameters() {
518
- const marketing = getUtmQueryParameter();
519
-
520
- if (!marketing) return;
521
-
522
- if (!Object.keys(marketing).length) { return; }
523
-
524
- const expiresDate = new Date();
525
- expiresDate.setDate(expiresDate.getDate() + 1);
526
-
527
- const parsedUrl = new URL(window.location.href);
528
- const domain = parsedUrl.hostname.split('.').slice(-2).join('.');
529
-
530
- document.cookie = `marketing=${JSON.stringify(marketing)};expires=${expiresDate};domain=.${domain};path=/`;
531
- }
532
-
533
- export const updateCookieList = () => {
534
- let isGoogleConsentGranted = true;
535
- const cookieConfig = JSON.parse(localStorage.getItem('cookieConfig')) || {};
536
- const parsedUrl = new URL(window.location.href);
537
- const domain = parsedUrl.hostname.split('.').slice(-2).join('.');
538
- Object.keys(cookieConfig).forEach((group: string) => {
539
- cookieConfig[group].forEach((cookie: string) => {
540
- Cookies.remove(cookie, { domain, path: '/' }); // manually remove selected cookies
541
- if (isGoogleConsentGranted && cookie.includes('_g')) isGoogleConsentGranted = false; // deny google cookie consent for _gcl_au, _ga, _gid, _gat_UA-31842-13, etc
542
- });
543
- });
544
- window.grantCookieConsent(isGoogleConsentGranted); // grant consent for setting google cookies
545
- };
1
+ import qs from 'qs';
2
+ import _get from 'lodash/get';
3
+ import { formatLocale as d3formatLocale } from 'd3-format';
4
+ import Cookies from 'js-cookie';
5
+ import {
6
+ FIRST_REGISTRATION, MANUFACTURER, MILEAGE, MODEL, BODY_TYPE, PRICE, RATE,
7
+ DROP_DOWN_GROUP, RATE_DEFAULT, MMS_GROUPS_KEY, MMS_GROUP_FIELDS
8
+ } from '../constants/SearchWidget';
9
+ import { priceRatings, priceRatingConfig } from '../constants/price';
10
+ import { GOOGLE_BUNDLE_COOKIES, HUNDRED } from '../constants/common';
11
+ import { offers } from '../constants';
12
+ import { FILTERS_IN_TITLE, MANUFACTURER_KEY, MAX_FILTERS_IN_TITLE, MODEL_KEY } from '../constants/Search';
13
+
14
+ const PRICE_DEFAULT = DROP_DOWN_GROUP[PRICE].defaultValue;
15
+
16
+ export const formatMileage = (millage: number | string) => {
17
+ return millage.toLocaleString('en-US').replace(/,/g, '.');
18
+ };
19
+
20
+ export const getFormattedNumber = (num: number) => Number.isFinite(num) ? num.toLocaleString('de-DE') : null;
21
+
22
+ export const numberWithDot = (value: number | string) => {
23
+ switch (value) {
24
+ case 'any':
25
+ return value;
26
+ case 'beliebig':
27
+ return value;
28
+ default: return getFormattedNumber(+value);
29
+ }
30
+ // if (value === 'any' || value === 'beliebig') {
31
+ // return value;
32
+ // }
33
+ return getFormattedNumber(+value);
34
+ };
35
+
36
+ export const arrToObj = (arr: string[]): { [key: string]: boolean } => {
37
+ if (!Array.isArray(arr)) return {};
38
+ return arr.reduce(
39
+ (obj: { [key: string]: boolean }, el: string) => { obj[el] = true; return obj; }, {}
40
+ );
41
+ };
42
+
43
+ export const addPrefixToKeys = (obj: { [key: string]: any }, prefix: string) => {
44
+ const result: { [key: string]: any } = {};
45
+ Object.keys(obj).reduce((_, key) => {
46
+ result[`${prefix}_${key}`] = obj[key];
47
+ return result;
48
+ }, result); // tslint:disable-line:align
49
+ return result;
50
+ };
51
+
52
+ // function return list of filter for inject in title
53
+ export const filtersInTitle = (filters: any) => {
54
+ const result: any[] = [];
55
+ const pushInResult = (value: any) => {
56
+ if (result.length < MAX_FILTERS_IN_TITLE && value) {
57
+ result.push(value);
58
+ }
59
+ };
60
+
61
+ FILTERS_IN_TITLE.forEach((filter: string) => {
62
+ if (filter === MMS_GROUPS_KEY) {
63
+ filters.get(filter).forEach((MmsObject: any) => {
64
+ pushInResult(MmsObject[MANUFACTURER_KEY].value);
65
+ pushInResult(MmsObject[MODEL_KEY].value);
66
+ });
67
+ } else {
68
+ filters.get(filter).value.forEach((value: string) => {
69
+ pushInResult(value);
70
+ });
71
+ }
72
+ });
73
+ return result;
74
+ };
75
+
76
+ export const changeLocation = (path: string) =>
77
+ window.location.href = `${window.location.origin}/${path}`;
78
+
79
+ export const checkRangeValuesOnEqual = (defaultValues: any, filterValues: any) => {
80
+ const keys = Object.keys(defaultValues);
81
+ let valuesIsEqual = true;
82
+ for (let i = 0; i < keys.length; i += 1) {
83
+ const period = keys[i];
84
+
85
+ if (filterValues[period] !== defaultValues[period]) {
86
+ valuesIsEqual = false;
87
+ break;
88
+ }
89
+ }
90
+
91
+ return valuesIsEqual;
92
+ };
93
+
94
+ export interface ICarImage {
95
+ url?: string;
96
+ imageUrlSmall?: string;
97
+ imageUrlMedium?: string;
98
+ imageUrlLarge?: string;
99
+ }
100
+
101
+ export const preloadNearbyImages = (images: ICarImage[], activeIndex: number, imageUrlSize: 'imageUrlSmall' | 'imageUrlMedium' | 'imageUrlLarge') => {
102
+ const imagesCount = Array.isArray(images) ? images.length : 0;
103
+ const imageSize = imageUrlSize;
104
+
105
+ const inMemoryPrevImage = new Image();
106
+ const inMemoryNextImage = new Image();
107
+
108
+ if (!!imagesCount) {
109
+ const prevIndex = (activeIndex - 1 % imagesCount + imagesCount) % imagesCount;
110
+ const nextIndex = (activeIndex + 1 % imagesCount + imagesCount) % imagesCount;
111
+
112
+ inMemoryPrevImage.src = images[prevIndex][imageSize];
113
+ inMemoryNextImage.src = images[nextIndex][imageSize];
114
+ }
115
+ };
116
+
117
+ export const getGroupValuesForQuery = (groups: any) => {
118
+ const arr: any = [];
119
+ groups.map((group: any) => {
120
+ const groupObj: any = {};
121
+
122
+ Object.keys(group).forEach((key: string) => {
123
+ const item = group[key];
124
+ if (item.value) {
125
+ groupObj[key] = item.value;
126
+ }
127
+ });
128
+ if (Object.keys(groupObj).length) {
129
+ arr.push(groupObj);
130
+ }
131
+ });
132
+ return arr;
133
+ };
134
+
135
+ export const buildBodyForRequest = (state: any) => {
136
+ const query: any = {
137
+ filters: {
138
+ absolutValues: {
139
+ mmsGroup0: {}
140
+ },
141
+ noAbsolutValues: {},
142
+ rangeValues: {}
143
+ }
144
+ };
145
+
146
+ Object.keys(state).sort().forEach((key: string) => {
147
+ const value = state[key];
148
+
149
+ if (!value) return;
150
+
151
+ if (key === MANUFACTURER && value.value) {
152
+ query.filters.absolutValues.mmsGroup0.mainData_make = value.value;
153
+ }
154
+
155
+ if (key === MODEL && value.value) {
156
+ if (value.isSeries) {
157
+ query.filters.absolutValues.mmsGroup0.mainData_series = value.value;
158
+ } else {
159
+ query.filters.absolutValues.mmsGroup0.mainData_model = value.value;
160
+ }
161
+ }
162
+
163
+ if (key === BODY_TYPE && value.length) {
164
+ query.filters.noAbsolutValues[BODY_TYPE] = value;
165
+ }
166
+
167
+ if (key === FIRST_REGISTRATION && value.value) {
168
+ query.filters.rangeValues['mainData_firstRegistrationYear'] = { from: value.value };
169
+ }
170
+
171
+ if (key === MILEAGE && value.value) {
172
+ query.filters.rangeValues['mainData_mileage'] = { to: value.value };
173
+ }
174
+
175
+ if (key === PRICE) {
176
+ const valueIsEqual = checkRangeValuesOnEqual(PRICE_DEFAULT, value);
177
+
178
+ if (!valueIsEqual) {
179
+ // check value in from / to. If we have - add it
180
+ Object.keys(value).map((key: string) => {
181
+ if (value[key]) {
182
+ if (!query.filters.rangeValues['price_currentSalesPrice']) {
183
+ query.filters.rangeValues['price_currentSalesPrice'] = {};
184
+ }
185
+
186
+ query.filters.rangeValues['price_currentSalesPrice'][key] = value[key];
187
+ }
188
+ });
189
+ }
190
+ }
191
+
192
+ if (key === RATE) {
193
+ const isRateDefault = checkRangeValuesOnEqual(RATE_DEFAULT, value);
194
+
195
+ if (!isRateDefault) {
196
+ query.filters.rangeValues['price_currentSalesPrice'] = { from: 1000, to: 2000 };
197
+ }
198
+ }
199
+ });
200
+
201
+ return query;
202
+ };
203
+
204
+ export const buildQueryForSearch = (filters: any) => {
205
+ const query: { [key: string]: any } = {};
206
+ const MMS_GROUP: any = {};
207
+
208
+ Object.keys(filters).forEach((filter: string) => {
209
+ const filterValue = filters[filter];
210
+
211
+ if (filterValue && filterValue.value) {
212
+ if (MMS_GROUP_FIELDS.indexOf(filter) !== -1) {
213
+ MMS_GROUP[filter] = filterValue.value;
214
+
215
+ if (filterValue.isSeries) {
216
+ MMS_GROUP.SERIES = filterValue.value;
217
+ }
218
+ }
219
+ }
220
+
221
+ if (filterValue === PRICE) {
222
+ const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
223
+ const valueIsDefault = filter === PRICE ? checkRangeValuesOnEqual(defaultValue, filterValue) : filterValue === defaultValue;
224
+
225
+ if (!valueIsDefault) {// check value in from / to. If we have - add it
226
+ Object.keys(filterValue).map((key: string) => {
227
+ if (filterValue[key]) {
228
+ if (!query.filters.rangeValues['price_currentSalesPrice']) {
229
+ query.filters.rangeValues['price_currentSalesPrice'] = {};
230
+ }
231
+
232
+ query.filters.rangeValues['price_currentSalesPrice'][key] = filterValue[key];
233
+ }
234
+ });
235
+ }
236
+ }
237
+
238
+ if (filter === PRICE) {
239
+ const valueIsDefault = checkRangeValuesOnEqual(PRICE_DEFAULT, filterValue);
240
+
241
+ if (!valueIsDefault) {
242
+ query[PRICE] = { from: '', to: '' };
243
+ query[PRICE].from = _get(filterValue, 'from', '');
244
+ query[PRICE].to = _get(filterValue, 'to', '');
245
+ }
246
+ }
247
+
248
+ if (filter === RATE) {
249
+ const isRateDefault = checkRangeValuesOnEqual(RATE_DEFAULT, filterValue);
250
+
251
+ if (!isRateDefault) {
252
+ query[RATE] = filterValue;
253
+ }
254
+ }
255
+
256
+ if (filter === MILEAGE) {
257
+ const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
258
+ if (filterValue !== defaultValue) {
259
+ query[MILEAGE] = { from: '', to: '' };
260
+ query[MILEAGE].from = _get(filterValue, 'from', '');
261
+ query[MILEAGE].to = _get(filterValue, 'to', '') || _get(filterValue, 'value', '');
262
+ }
263
+ }
264
+
265
+ if (filter === FIRST_REGISTRATION) {
266
+ const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
267
+ if (filterValue !== defaultValue) {
268
+ query[FIRST_REGISTRATION] = { from: '', to: '' };
269
+ query[FIRST_REGISTRATION].from = _get(filterValue, 'from', '') || _get(filterValue, 'value', '');
270
+ query[FIRST_REGISTRATION].to = _get(filterValue, 'to', '');
271
+ }
272
+ }
273
+
274
+ if (filter === BODY_TYPE) {
275
+ const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
276
+
277
+ if (filterValue.length && filterValue !== defaultValue) {
278
+ query[BODY_TYPE] = [];
279
+
280
+ filterValue.map((bodyTypeSelector: string) => {
281
+ query[BODY_TYPE].push(bodyTypeSelector);
282
+ });
283
+ }
284
+ }
285
+ });
286
+
287
+ if (Object.keys(MMS_GROUP).length) {
288
+ query[MMS_GROUPS_KEY] = [];
289
+ query[MMS_GROUPS_KEY].push(MMS_GROUP);
290
+ }
291
+
292
+ return qs.stringify(query, { encode: false });
293
+ };
294
+
295
+ export const sliceLessThan = (array: number[], to: any): number[] => {
296
+ const value = Number(to);
297
+ return value && Number.isFinite(value)
298
+ ? array.filter((val: number) => val <= value)
299
+ : array;
300
+ };
301
+
302
+ export const sliceMoreThan = (array: number[], from: any): number[] => {
303
+ const value = Number(from);
304
+ return value && Number.isFinite(value)
305
+ ? array.filter((val: number) => val >= value)
306
+ : array;
307
+ };
308
+
309
+ export const getFormattedPrice = (price: any, format = '$,.0f', currency = ''): string => {
310
+ if (!Number.isFinite(price)) return '-';
311
+ const groupingNum = 3;
312
+ return d3formatLocale({
313
+ decimal: ',',
314
+ thousands: '.',
315
+ currency: ['', currency],
316
+ grouping: [groupingNum]
317
+ }).format(format)(price);
318
+ };
319
+
320
+ export const getPriceRating = (currentSalesPrice: number, predictablePrice: number) => {
321
+ const isCorrectCurrentSalesPrice = Number.isFinite(Number.parseFloat(`${currentSalesPrice}`));
322
+ const isCorrectPredictablePrice = Number.isFinite(Number.parseFloat(`${predictablePrice}`));
323
+
324
+ if (!isCorrectCurrentSalesPrice || !isCorrectPredictablePrice) return 0;
325
+
326
+ const ratingConfig = getPriceRatingConfig(currentSalesPrice, predictablePrice);
327
+
328
+ for (const key of Object.keys(ratingConfig)) {
329
+ const { min, max } = ratingConfig[key];
330
+ const TOP_PRICE = 5;
331
+ if (key === 'highPrice' && currentSalesPrice === max) return 1;
332
+ if (key === 'topPrice' && currentSalesPrice <= min) return TOP_PRICE;
333
+ if (currentSalesPrice >= min && currentSalesPrice < max) return priceRatings.indexOf(key);
334
+ }
335
+
336
+ return 0;
337
+ };
338
+
339
+ export const getPriceRatingConfig = (currentPrice: number, pricePredicted: number) => { // tslint:disable-line
340
+ const round = (value: number) => {
341
+ return Number.isFinite(pricePredicted)
342
+ ? Math.round((pricePredicted * (1 + (value / 100))) / 100) * 100 // tslint:disable-line
343
+ : '???';
344
+ };
345
+
346
+ if (currentPrice === 0) {
347
+ console.log('Empty current price');
348
+ }
349
+
350
+ return Object.keys(priceRatingConfig).reduce((acc: any, key: any) => {
351
+ const { min, max } = priceRatingConfig[key];
352
+ return { ...acc, [key]: { min: round(min), max: round(max) } };
353
+ }, {}); // tslint:disable-line
354
+ };
355
+
356
+ export const fixNumber = (num: number | string) => {
357
+ const isNum = typeof num === 'number' ? num : parseFloat(num);
358
+ return Math.round(isNum * HUNDRED) / HUNDRED;
359
+ };
360
+
361
+ export const getOfferSliders = (financingConfig: any, t: (key: string, options?: object) => string, priceTabIndex: null | number, componentType: string) => {
362
+ const offerObj = offers[+priceTabIndex];
363
+ const offerConfig = financingConfig[offerObj.name];
364
+ const currentSalesPrice =
365
+ financingConfig.common ?
366
+ financingConfig.common.currentSalesPrice :
367
+ financingConfig.currentSalesPrice; // TODO: fix deprecated. Correct is "financingConfig.common.currentSalesPrice"
368
+ return offerObj.sliders
369
+ .map((slider: any, index) => {
370
+ if (componentType === 'checkout' && index === 1 && priceTabIndex === 0) return; // remove checkout annual mileage for financing
371
+ if (slider.name === 'firstInstallment') slider.max = offerConfig.firstInstallmentMax || currentSalesPrice;
372
+ slider.value = offerConfig[slider.name];
373
+ slider.unitName = t(`modals:financing.${slider.unit}`);
374
+ slider.caption = t(`modals:financing.${slider.name}`);
375
+ return slider;
376
+ }).filter(Boolean);
377
+ };
378
+
379
+ export const checkWebpFeature = async () => {
380
+ // If the browser doesn't has the method createImageBitmap, you can't display webp format
381
+ if (!self.createImageBitmap) return false;
382
+
383
+ // Base64 representation of a white point image
384
+ const webpData = 'data:image/webp;base64,UklGRiQAAABXRUJQVlA4IBgAAAAwAQCdASoCAAEAAQAcJaQAA3AA/v3AgAA=';
385
+
386
+ // Retrieve the Image in Blob Format
387
+ const blob = await fetch(webpData).then(r => r.blob());
388
+
389
+ // If the createImageBitmap method succeeds, return true, otherwise false
390
+ return createImageBitmap(blob).then(() => true, () => false);
391
+ };
392
+
393
+ export const getSupportedImageFormat = (IMAGE_URL: string, vehicleID: string, imageIdentifier: string, size: 'small' | 'medium' | 'large', webpFeature: boolean) => {
394
+ if (!imageIdentifier) return null;
395
+
396
+ const vehicleImageURL = `${IMAGE_URL}/${vehicleID}/${imageIdentifier}`;
397
+
398
+ return webpFeature ? `${vehicleImageURL}/${size}-cached.webp` : `${vehicleImageURL}/${size}-cached.jpeg`;
399
+ };
400
+
401
+ export function getChipFilterValue(chip: any, t: (key: string, options?: object) => string, language: string = 'de') {
402
+ let filterValue: string;
403
+ let title: string;
404
+ let from: string;
405
+ let to: string;
406
+ const chipFilterKey = chip.filterKey || chip.key; // we may have different key naming for landing or main
407
+ const chipFilterValue = chip.filterValue || chip.value; // we may have different key naming for landing or main
408
+ switch (chipFilterKey) {
409
+ case 'MANUFACTURER':
410
+ case 'MODEL':
411
+ case 'SUB_MODEL':
412
+ filterValue = chipFilterValue;
413
+ break;
414
+
415
+ case 'MANUFACTURER_EXCLUDE':
416
+ case 'MODEL_EXCLUDE':
417
+ title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
418
+ filterValue = `${title} ${chipFilterValue}`;
419
+ break;
420
+
421
+ case 'FIRST_REGISTRATION':
422
+ title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
423
+ from = chipFilterValue.from ? `${t('SearchPage:filters.from')} ${chipFilterValue.from} ` : '';
424
+ to = chipFilterValue.to ? `${t('SearchPage:filters.to')} ${chipFilterValue.to}` : '';
425
+ filterValue = `${title} ${from} ${to}`;
426
+ break;
427
+
428
+ case 'PRICE':
429
+ case 'PRICE_DIFFERENCE':
430
+ case 'MILEAGE':
431
+ case 'EMISSION_CO2':
432
+ case 'POWER':
433
+ case 'IMAGES_COUNT':
434
+ title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
435
+ from = chipFilterValue.from ? `${t('SearchPage:filters.from')} ${getFormattedPrice(+chipFilterValue.from)} ` : '';
436
+ to = chipFilterValue.to ? `${t('SearchPage:filters.to')} ${getFormattedPrice(+chipFilterValue.to)}` : '';
437
+ const type = chipFilterValue.type ? ` ${chipFilterValue.type}` : '';
438
+ filterValue = `${title} ${from} ${to}${type}`;
439
+ break;
440
+
441
+ case 'DOORS':
442
+ case 'OWNERS':
443
+ filterValue = t(`SearchPage:filters.${chipFilterValue}`);
444
+ break;
445
+
446
+ case 'SEATS':
447
+ case 'CUBIC_CAPACITY':
448
+ title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
449
+ const fromTo = `${chipFilterValue.from} - ${chipFilterValue.to}`;
450
+ filterValue = `${title} ${fromTo}`;
451
+ break;
452
+
453
+ case 'CONSUMPTION':
454
+ const fromValue = Number(chipFilterValue.from).toLocaleString(language);
455
+ const toValue = Number(chipFilterValue.to).toLocaleString(language);
456
+ const newFromValue: any = (fromValue === 'NaN') ? '1' : fromValue;
457
+ const newToValue: any = (toValue === 'NaN') ? '18' : toValue;
458
+ const fromToWithInfo = `${newFromValue} - ${newToValue}`;
459
+ filterValue = t(`SearchPage:filtersChips.${chipFilterKey.toLocaleLowerCase()}`, { value: fromToWithInfo });
460
+ break;
461
+
462
+ case 'ONLINE_SINCE':
463
+ filterValue = t(`SearchPage:filters.${chipFilterValue}`);
464
+ break;
465
+
466
+ case 'GENERAL_INSPECTION':
467
+ filterValue = t(`SearchPage:filtersChips.generalInspection`, { month: t(`SearchPage:filters.${chipFilterValue}`) });
468
+ break;
469
+
470
+ case 'RATE':
471
+ const { monthlyInstallmentFrom, monthlyInstallmentTo, firstInstallment, paybackPeriod } = chipFilterValue;
472
+ const rowValues: any = { monthlyInstallmentFrom, monthlyInstallmentTo, firstInstallment, paybackPeriod };
473
+ const values: string[][] = [
474
+ ['monthlyInstallmentFrom', 'monthlyInstallmentTo'],
475
+ ['firstInstallment', 'paybackPeriod']
476
+ ].map((fields: string[]) => fields
477
+ .map((field: string) => {
478
+ const rowValue = rowValues[field];
479
+ const value = Number.isFinite(+rowValue) ? getFormattedPrice(+rowValue) : rowValue;
480
+ return +rowValue ? t(`SearchPage:filtersChips.${field}Chip`, { value }) : null;
481
+ })
482
+ .filter((item: any) => !!item)
483
+ );
484
+ const rateValue = `${t('SearchPage:filtersChips.rateChip')} ${values[0].length ? values[0].join(' ') : t('SearchPage:filtersChips.any')}`;
485
+ filterValue = `${rateValue}, ${values[1].join(', ')}`;
486
+ break;
487
+
488
+ default:
489
+ filterValue = t(`cbd:${chipFilterValue}`);
490
+ }
491
+ return filterValue;
492
+ }
493
+
494
+ function getUtmQueryParameter() {
495
+ const query = window.location.search;
496
+
497
+ if (!query) { return; }
498
+
499
+ const queryString = /^[?]/.test(query) ? query.slice(1) : query;
500
+
501
+ const result = queryString.split('&').reduce(
502
+ (params: any, param: string) => {
503
+ const [key, value] = param.split('=');
504
+
505
+ if (!/^source|^campaign|^medium|^content|^term|^reference|^gclid|^adgroupid|^keyword/.test(key)) { return params; }
506
+
507
+ params[key] = value ? decodeURIComponent(value.replace(/\+/g, ' ')) : '';
508
+
509
+ return params;
510
+ },
511
+ {}
512
+ ); // eslint-disable-line indent,@typescript-eslint/indent
513
+
514
+ return result;
515
+ }
516
+
517
+ export function setUtmParameters() {
518
+ const marketing = getUtmQueryParameter();
519
+
520
+ if (!marketing) return;
521
+
522
+ if (!Object.keys(marketing).length) { return; }
523
+
524
+ const expiresDate = new Date();
525
+ expiresDate.setDate(expiresDate.getDate() + 1);
526
+
527
+ const parsedUrl = new URL(window.location.href);
528
+ const domain = parsedUrl.hostname.split('.').slice(-2).join('.');
529
+
530
+ document.cookie = `marketing=${JSON.stringify(marketing)};expires=${expiresDate};domain=.${domain};path=/`;
531
+ }
532
+
533
+ export const updateCookieList = () => {
534
+ let cookieConsentList = Object.keys(GOOGLE_BUNDLE_COOKIES);
535
+ let isFBGranted = true;
536
+ const cookieConfig = JSON.parse(localStorage.getItem('cookieConfig')) || {};
537
+
538
+ const parsedUrl = new URL(window.location.href);
539
+ const domain = parsedUrl.hostname.split('.').slice(-2).join('.');
540
+ Object.keys(cookieConfig).forEach((group: string) => {
541
+ cookieConfig[group].forEach((cookie: string) => {
542
+ Cookies.remove(cookie, { domain, path: '/' }); // manually remove selected cookies
543
+ // google
544
+ if (cookieConsentList.includes(cookie)) cookieConsentList = cookieConsentList.filter(i => i !== cookie); // deny google cookie consent for _gcl_au, _ga, _gid, _gat_UA-31842-13, etc
545
+ // fb
546
+ else if (cookie === '_fbp') isFBGranted = false;
547
+ });
548
+ });
549
+ // grant google cookies
550
+ window.grantCookieConsent(cookieConsentList);
551
+ // grant FB cookies
552
+ if (isFBGranted) window.fbq('consent', 'grant');
553
+ };