@bytebrand/fe-ui-core 4.0.261 → 4.0.263

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 (920) 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 +151 -151
  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 +10 -10
  25. package/media/svg/common/whyAutodeIconSet-F.svg +13 -13
  26. package/media/svg/common/whyAutodeIconSet-G.svg +10 -10
  27. package/media/svg/common/whyAutodeIconSet-Q.svg +16 -16
  28. package/media/svg/common/whyAutodeIconSet-R.svg +14 -14
  29. package/media/svg/infoBlocks/whyAutodeIconSet-F.svg +9 -9
  30. package/media/svg/infoBlocks/whyAutodeIconSet-G.svg +7 -7
  31. package/media/svg/infoBlocks/whyAutodeIconSet-Q.svg +12 -12
  32. package/media/svg/infoBlocks/whyAutodeIconSet-R.svg +10 -10
  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 +206 -206
  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 +96 -96
  49. package/source/components/Alternative/DealerInfo.tsx +125 -125
  50. package/source/components/Breadcrumbs/Breadcrumbs.story.js +40 -40
  51. package/source/components/Breadcrumbs/Breadcrumbs.styl +123 -123
  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 +61 -61
  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 +129 -129
  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 +58 -58
  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 +27 -27
  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 +148 -144
  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 +125 -124
  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 +51 -51
  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 +65 -65
  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 +165 -165
  210. package/source/components/SearchFilters/filters/Mileage.tsx +103 -103
  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 +73 -73
  215. package/source/components/SearchFilters/filters/Power.tsx +156 -156
  216. package/source/components/SearchFilters/filters/PriceDifference.tsx +68 -68
  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 +88 -88
  243. package/source/components/SearchPage/SearchTopBar/SearchTopBar.tsx +94 -94
  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 +75 -75
  250. package/source/components/SearchPageMobile/FiltersDetailed/Doors.styl +52 -52
  251. package/source/components/SearchPageMobile/FiltersDetailed/Doors.tsx +101 -101
  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 +172 -172
  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 +81 -81
  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 +84 -84
  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 +174 -174
  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 +58 -58
  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 +104 -104
  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 +49 -49
  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 +168 -168
  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 +142 -142
  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 +170 -170
  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 +112 -112
  365. package/source/components/VehicleDetailedSidebar/partials/PriceContent.tsx +124 -124
  366. package/source/components/VehicleDetailedSidebar/partials/Properties.styl +57 -57
  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 +133 -133
  394. package/source/components/VehicleSmallCard/VehicleData/VechiclePriceItem/VechiclePriceItem.tsx +153 -153
  395. package/source/components/VehicleSmallCard/VehicleData/VehicleInfo/VehicleInfo.styl +167 -167
  396. package/source/components/VehicleSmallCard/VehicleData/VehicleInfo/VehicleInfo.tsx +125 -125
  397. package/source/components/VehicleSmallCard/VehicleData/VehiclePrice/VehiclePrice.styl +51 -51
  398. package/source/components/VehicleSmallCard/VehicleData/VehiclePrice/VehiclePrice.tsx +230 -230
  399. package/source/components/VehicleSmallCard/VehicleData/VehicleProperty/VehicleProperty.styl +20 -20
  400. package/source/components/VehicleSmallCard/VehicleData/VehicleProperty/VehicleProperty.tsx +32 -32
  401. package/source/components/VehicleSmallCard/VehicleData/VehicleTitle/VehicleTitle.styl +108 -108
  402. package/source/components/VehicleSmallCard/VehicleData/VehicleTitle/VehicleTitle.tsx +85 -85
  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 +160 -159
  406. package/source/components/VehicleSmallCard/VehicleSmallCard.tsx +342 -342
  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 +35 -35
  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 +37 -37
  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 +207 -207
  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 +112 -112
  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 +34 -34
  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 +621 -621
  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/ArrowDetailedAccordionBlue.tsx +26 -26
  538. package/source/components/_common/IconSVG/SVG/common/ArrowDownBlue.tsx +21 -21
  539. package/source/components/_common/IconSVG/SVG/common/ArrowSelect.tsx +23 -23
  540. package/source/components/_common/IconSVG/SVG/common/ArrowStepDown.tsx +18 -18
  541. package/source/components/_common/IconSVG/SVG/common/Autocheck.tsx +19 -19
  542. package/source/components/_common/IconSVG/SVG/common/Avatar.tsx +17 -17
  543. package/source/components/_common/IconSVG/SVG/common/BellGray.tsx +19 -19
  544. package/source/components/_common/IconSVG/SVG/common/BigInfoTransparent.tsx +13 -13
  545. package/source/components/_common/IconSVG/SVG/common/Browse.tsx +20 -20
  546. package/source/components/_common/IconSVG/SVG/common/Calendar.tsx +24 -24
  547. package/source/components/_common/IconSVG/SVG/common/Camera.tsx +17 -17
  548. package/source/components/_common/IconSVG/SVG/common/Car.tsx +16 -16
  549. package/source/components/_common/IconSVG/SVG/common/CarBody.tsx +19 -19
  550. package/source/components/_common/IconSVG/SVG/common/CarFront.tsx +43 -43
  551. package/source/components/_common/IconSVG/SVG/common/CarInspectionCheck.tsx +21 -21
  552. package/source/components/_common/IconSVG/SVG/common/CarInspectionScheme0.tsx +32 -32
  553. package/source/components/_common/IconSVG/SVG/common/CarInspectionScheme1.tsx +53 -53
  554. package/source/components/_common/IconSVG/SVG/common/CarInspectionScheme2.tsx +52 -52
  555. package/source/components/_common/IconSVG/SVG/common/CarInspectionScheme3.tsx +32 -32
  556. package/source/components/_common/IconSVG/SVG/common/CarInspectionScheme4.tsx +32 -32
  557. package/source/components/_common/IconSVG/SVG/common/CarInspectionScheme5.tsx +32 -32
  558. package/source/components/_common/IconSVG/SVG/common/CarInspectionScheme6.tsx +32 -32
  559. package/source/components/_common/IconSVG/SVG/common/CarInspectionSchemeGeneral copy.tsx +24 -24
  560. package/source/components/_common/IconSVG/SVG/common/CarInspectionSchemeGeneral.tsx +24 -24
  561. package/source/components/_common/IconSVG/SVG/common/CheckBlue.tsx +18 -18
  562. package/source/components/_common/IconSVG/SVG/common/CheckMark.tsx +16 -16
  563. package/source/components/_common/IconSVG/SVG/common/CheckWhite.tsx +19 -19
  564. package/source/components/_common/IconSVG/SVG/common/Chevron.tsx +17 -17
  565. package/source/components/_common/IconSVG/SVG/common/CircledCheckmark.tsx +25 -25
  566. package/source/components/_common/IconSVG/SVG/common/Clock.tsx +18 -18
  567. package/source/components/_common/IconSVG/SVG/common/Close.tsx +19 -19
  568. package/source/components/_common/IconSVG/SVG/common/ContactEmail.tsx +21 -21
  569. package/source/components/_common/IconSVG/SVG/common/ContactPhone.tsx +28 -28
  570. package/source/components/_common/IconSVG/SVG/common/CopyIcon copy.tsx +22 -22
  571. package/source/components/_common/IconSVG/SVG/common/CopyIcon.tsx +22 -22
  572. package/source/components/_common/IconSVG/SVG/common/CopyIconForDealer.tsx +21 -21
  573. package/source/components/_common/IconSVG/SVG/common/DeleteCircle.tsx +31 -31
  574. package/source/components/_common/IconSVG/SVG/common/DeleteV1Icon.tsx +18 -18
  575. package/source/components/_common/IconSVG/SVG/common/DeliveryMail.tsx +24 -24
  576. package/source/components/_common/IconSVG/SVG/common/Discount100De.tsx +18 -18
  577. package/source/components/_common/IconSVG/SVG/common/Discount100En.tsx +19 -19
  578. package/source/components/_common/IconSVG/SVG/common/Discount66De.tsx +28 -28
  579. package/source/components/_common/IconSVG/SVG/common/Discount66En.tsx +20 -20
  580. package/source/components/_common/IconSVG/SVG/common/DoneIcon.tsx +18 -18
  581. package/source/components/_common/IconSVG/SVG/common/EditCircle.tsx +32 -32
  582. package/source/components/_common/IconSVG/SVG/common/EuroCurrency.tsx +18 -18
  583. package/source/components/_common/IconSVG/SVG/common/Export.tsx +20 -20
  584. package/source/components/_common/IconSVG/SVG/common/Eye.tsx +17 -17
  585. package/source/components/_common/IconSVG/SVG/common/EyeCatch.tsx +19 -19
  586. package/source/components/_common/IconSVG/SVG/common/FilterRange.tsx +16 -16
  587. package/source/components/_common/IconSVG/SVG/common/FilterToolBlack.tsx +23 -23
  588. package/source/components/_common/IconSVG/SVG/common/FlagDe.tsx +21 -21
  589. package/source/components/_common/IconSVG/SVG/common/FlagEn.tsx +43 -43
  590. package/source/components/_common/IconSVG/SVG/common/GrayEnvelopeIcon.tsx +19 -19
  591. package/source/components/_common/IconSVG/SVG/common/HamburgerMenuIcon.tsx +18 -18
  592. package/source/components/_common/IconSVG/SVG/common/Info.tsx +16 -16
  593. package/source/components/_common/IconSVG/SVG/common/InfoIcon.tsx +18 -18
  594. package/source/components/_common/IconSVG/SVG/common/InfoTransparent.tsx +18 -18
  595. package/source/components/_common/IconSVG/SVG/common/MagnifyingGlass.tsx +31 -31
  596. package/source/components/_common/IconSVG/SVG/common/MenuArrow.tsx +16 -16
  597. package/source/components/_common/IconSVG/SVG/common/MobileDeLogo.tsx +108 -108
  598. package/source/components/_common/IconSVG/SVG/common/Package.tsx +30 -30
  599. package/source/components/_common/IconSVG/SVG/common/Phone.tsx +18 -18
  600. package/source/components/_common/IconSVG/SVG/common/Picture.tsx +24 -24
  601. package/source/components/_common/IconSVG/SVG/common/Pictures.tsx +32 -32
  602. package/source/components/_common/IconSVG/SVG/common/Plus.tsx +16 -16
  603. package/source/components/_common/IconSVG/SVG/common/PlusNew.tsx +16 -16
  604. package/source/components/_common/IconSVG/SVG/common/ProfileIcon.tsx +17 -17
  605. package/source/components/_common/IconSVG/SVG/common/Question.tsx +19 -19
  606. package/source/components/_common/IconSVG/SVG/common/QuestionBold.tsx +25 -25
  607. package/source/components/_common/IconSVG/SVG/common/Search.tsx +19 -19
  608. package/source/components/_common/IconSVG/SVG/common/SettingPenIcon.tsx +20 -20
  609. package/source/components/_common/IconSVG/SVG/common/Share.tsx +16 -16
  610. package/source/components/_common/IconSVG/SVG/common/ShoppingCart.tsx +18 -18
  611. package/source/components/_common/IconSVG/SVG/common/SliderArrow.tsx +21 -21
  612. package/source/components/_common/IconSVG/SVG/common/SliderEye.tsx +18 -18
  613. package/source/components/_common/IconSVG/SVG/common/SortUpDownArrows.tsx +18 -18
  614. package/source/components/_common/IconSVG/SVG/common/Speedometer.tsx +23 -23
  615. package/source/components/_common/IconSVG/SVG/common/Star.tsx +20 -20
  616. package/source/components/_common/IconSVG/SVG/common/StarNew.tsx +16 -16
  617. package/source/components/_common/IconSVG/SVG/common/StarOutline.tsx +20 -20
  618. package/source/components/_common/IconSVG/SVG/common/StarRoundedCorners.tsx +18 -18
  619. package/source/components/_common/IconSVG/SVG/common/Stats.tsx +17 -17
  620. package/source/components/_common/IconSVG/SVG/common/Step1.tsx +21 -21
  621. package/source/components/_common/IconSVG/SVG/common/Step2.tsx +20 -20
  622. package/source/components/_common/IconSVG/SVG/common/Step3.tsx +21 -21
  623. package/source/components/_common/IconSVG/SVG/common/Telephone.tsx +22 -22
  624. package/source/components/_common/IconSVG/SVG/common/Time.tsx +17 -17
  625. package/source/components/_common/IconSVG/SVG/common/Timetable.tsx +18 -18
  626. package/source/components/_common/IconSVG/SVG/common/Trash.tsx +22 -22
  627. package/source/components/_common/IconSVG/SVG/common/Upload.tsx +17 -17
  628. package/source/components/_common/IconSVG/SVG/common/ValidateFailure.tsx +21 -21
  629. package/source/components/_common/IconSVG/SVG/common/ValidateSuccess.tsx +21 -21
  630. package/source/components/_common/IconSVG/SVG/common/WarningTriangle.tsx +20 -20
  631. package/source/components/_common/IconSVG/SVG/common/WhiteArrowUp.tsx +21 -21
  632. package/source/components/_common/IconSVG/SVG/common/WhiteKey.tsx +21 -21
  633. package/source/components/_common/IconSVG/SVG/common/WhitePeople.tsx +23 -23
  634. package/source/components/_common/IconSVG/SVG/common/WhiteTick.tsx +19 -19
  635. package/source/components/_common/IconSVG/SVG/infoBlocks/14DaysReturnPolicy.tsx +18 -18
  636. package/source/components/_common/IconSVG/SVG/infoBlocks/Autocheck.tsx +19 -19
  637. package/source/components/_common/IconSVG/SVG/infoBlocks/CheckTheStory.tsx +22 -22
  638. package/source/components/_common/IconSVG/SVG/infoBlocks/CustomerServiceWhite.tsx +16 -16
  639. package/source/components/_common/IconSVG/SVG/infoBlocks/Guarantee.tsx +16 -16
  640. package/source/components/_common/IconSVG/SVG/infoBlocks/OrderWhite.tsx +13 -13
  641. package/source/components/_common/IconSVG/SVG/infoBlocks/PriceGuarantee.tsx +19 -19
  642. package/source/components/_common/IconSVG/SVG/infoBlocks/PriceGuaranteeWhite.tsx +17 -17
  643. package/source/components/_common/IconSVG/SVG/infoBlocks/TransportAndDelivery.tsx +21 -21
  644. package/source/components/_common/IconSVG/SVG/infoBlocks/Warranty.tsx +23 -23
  645. package/source/components/_common/IconSVG/SVG/popower/Mail.tsx +18 -18
  646. package/source/components/_common/IconSVG/SVG/popower/Phone.tsx +19 -19
  647. package/source/components/_common/IconSVG/SVG/popower/Schedule.tsx +18 -18
  648. package/source/components/_common/IconSVG/SVG/searchWidgets/drive/AAllWheelDrive.tsx +26 -26
  649. package/source/components/_common/IconSVG/SVG/searchWidgets/drive/AllWheelDrive.tsx +24 -24
  650. package/source/components/_common/IconSVG/SVG/searchWidgets/drive/FrontWheelDrive.tsx +24 -24
  651. package/source/components/_common/IconSVG/SVG/searchWidgets/drive/OtherWheelDrive.tsx +26 -26
  652. package/source/components/_common/IconSVG/SVG/searchWidgets/drive/RearWheelDrive.tsx +24 -24
  653. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelDiesel.tsx +28 -28
  654. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelElectrical.tsx +23 -23
  655. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelElectricalDiesel.tsx +34 -34
  656. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelElectricalPetrol.tsx +46 -46
  657. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelEthanol.tsx +53 -53
  658. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelHydrogen.tsx +24 -24
  659. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelLpg.tsx +24 -24
  660. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelNaturalGas.tsx +23 -23
  661. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelOther.tsx +28 -28
  662. package/source/components/_common/IconSVG/SVG/searchWidgets/fuel/FuelPetrol.tsx +21 -21
  663. package/source/components/_common/IconSVG/SVG/settings/Account.tsx +15 -15
  664. package/source/components/_common/IconSVG/SVG/settings/DataUsage.tsx +15 -15
  665. package/source/components/_common/IconSVG/SVG/settings/Security.tsx +15 -15
  666. package/source/components/_common/IconSVG/SVG/slider/360.tsx +23 -23
  667. package/source/components/_common/IconSVG/SVG/slider/Checked.tsx +19 -19
  668. package/source/components/_common/IconSVG/SVG/slider/DiscountRibbon.tsx +51 -51
  669. package/source/components/_common/IconSVG/SVG/slider/DiscountRibbonMobile.tsx +47 -47
  670. package/source/components/_common/IconSVG/SVG/slider/DiscountRibbonNew.tsx +29 -29
  671. package/source/components/_common/IconSVG/SVG/slider/Easy.tsx +19 -19
  672. package/source/components/_common/IconSVG/SVG/slider/Fullscreen.tsx +16 -16
  673. package/source/components/_common/IconSVG/SVG/slider/FullscreenWindow.tsx +23 -23
  674. package/source/components/_common/IconSVG/SVG/slider/Safe.tsx +19 -19
  675. package/source/components/_common/IconSVG/SVG/slider/ToBuy.tsx +19 -19
  676. package/source/components/_common/IconSVG/SVG/slider/ZoomIn.tsx +21 -21
  677. package/source/components/_common/IconSVG/SVG/slider/ZoomOut.tsx +21 -21
  678. package/source/components/_common/IconSVG/SVG/social/AndroidLogo.tsx +18 -18
  679. package/source/components/_common/IconSVG/SVG/social/Apple.tsx +19 -19
  680. package/source/components/_common/IconSVG/SVG/social/FacebookF.tsx +19 -19
  681. package/source/components/_common/IconSVG/SVG/social/GooglePlusG.tsx +19 -19
  682. package/source/components/_common/IconSVG/SVG/social/Instagram.tsx +17 -17
  683. package/source/components/_common/IconSVG/SVG/social/Pinterest.tsx +19 -19
  684. package/source/components/_common/IconSVG/SVG/social/SharingInterface.tsx +21 -21
  685. package/source/components/_common/IconSVG/SVG/social/Twitter.tsx +19 -19
  686. package/source/components/_common/IconSVG/SVG/social/Youtube.tsx +19 -19
  687. package/source/components/_common/IconSVG/SVG/vehicle/AboIcon.tsx +11 -11
  688. package/source/components/_common/IconSVG/SVG/vehicle/Abs.tsx +24 -24
  689. package/source/components/_common/IconSVG/SVG/vehicle/AirCond.tsx +34 -34
  690. package/source/components/_common/IconSVG/SVG/vehicle/Airbag.tsx +21 -21
  691. package/source/components/_common/IconSVG/SVG/vehicle/AuxiliaryHeating.tsx +23 -23
  692. package/source/components/_common/IconSVG/SVG/vehicle/Bluetooth.tsx +22 -22
  693. package/source/components/_common/IconSVG/SVG/vehicle/BuyIcon.tsx +15 -15
  694. package/source/components/_common/IconSVG/SVG/vehicle/CarAvailability.tsx +21 -21
  695. package/source/components/_common/IconSVG/SVG/vehicle/CarInspectionCheck.tsx +21 -21
  696. package/source/components/_common/IconSVG/SVG/vehicle/CarInspectionCross.tsx +21 -21
  697. package/source/components/_common/IconSVG/SVG/vehicle/CheckoutChecked.tsx +15 -15
  698. package/source/components/_common/IconSVG/SVG/vehicle/Co2.tsx +24 -24
  699. package/source/components/_common/IconSVG/SVG/vehicle/CruiseControl.tsx +25 -25
  700. package/source/components/_common/IconSVG/SVG/vehicle/Date.tsx +24 -24
  701. package/source/components/_common/IconSVG/SVG/vehicle/Delivery.tsx +12 -12
  702. package/source/components/_common/IconSVG/SVG/vehicle/Diesel.tsx +28 -28
  703. package/source/components/_common/IconSVG/SVG/vehicle/Display.tsx +25 -25
  704. package/source/components/_common/IconSVG/SVG/vehicle/Done.tsx +11 -11
  705. package/source/components/_common/IconSVG/SVG/vehicle/Door.tsx +21 -21
  706. package/source/components/_common/IconSVG/SVG/vehicle/DoubleDone.tsx +18 -18
  707. package/source/components/_common/IconSVG/SVG/vehicle/EditIcon.tsx +11 -11
  708. package/source/components/_common/IconSVG/SVG/vehicle/EmergencyBrakeAssistant.tsx +27 -27
  709. package/source/components/_common/IconSVG/SVG/vehicle/Eps.tsx +24 -24
  710. package/source/components/_common/IconSVG/SVG/vehicle/Esp.tsx +24 -24
  711. package/source/components/_common/IconSVG/SVG/vehicle/FinancingIcon.tsx +20 -20
  712. package/source/components/_common/IconSVG/SVG/vehicle/FuelConsumption.tsx +24 -24
  713. package/source/components/_common/IconSVG/SVG/vehicle/Fueling.tsx +22 -22
  714. package/source/components/_common/IconSVG/SVG/vehicle/FullDrive.tsx +24 -24
  715. package/source/components/_common/IconSVG/SVG/vehicle/GasElectric.tsx +28 -28
  716. package/source/components/_common/IconSVG/SVG/vehicle/HandsFreePhoneSystem.tsx +24 -24
  717. package/source/components/_common/IconSVG/SVG/vehicle/Kw.tsx +23 -23
  718. package/source/components/_common/IconSVG/SVG/vehicle/LastCrawledAt.tsx +22 -22
  719. package/source/components/_common/IconSVG/SVG/vehicle/LeasingIcon.tsx +14 -14
  720. package/source/components/_common/IconSVG/SVG/vehicle/Led.tsx +24 -24
  721. package/source/components/_common/IconSVG/SVG/vehicle/LightSensor.tsx +22 -22
  722. package/source/components/_common/IconSVG/SVG/vehicle/LinkAlternative.tsx +15 -15
  723. package/source/components/_common/IconSVG/SVG/vehicle/Location.tsx +17 -17
  724. package/source/components/_common/IconSVG/SVG/vehicle/MinusIcon.tsx +11 -11
  725. package/source/components/_common/IconSVG/SVG/vehicle/Mirror.tsx +19 -19
  726. package/source/components/_common/IconSVG/SVG/vehicle/Navigation.tsx +27 -27
  727. package/source/components/_common/IconSVG/SVG/vehicle/NewCar.tsx +23 -23
  728. package/source/components/_common/IconSVG/SVG/vehicle/NoImage.tsx +17 -17
  729. package/source/components/_common/IconSVG/SVG/vehicle/Owner.tsx +21 -21
  730. package/source/components/_common/IconSVG/SVG/vehicle/PanoramicRoof.tsx +23 -23
  731. package/source/components/_common/IconSVG/SVG/vehicle/ParkingAssistants.tsx +24 -24
  732. package/source/components/_common/IconSVG/SVG/vehicle/PickYourself.tsx +18 -18
  733. package/source/components/_common/IconSVG/SVG/vehicle/PlusIcon.tsx +11 -11
  734. package/source/components/_common/IconSVG/SVG/vehicle/Power.tsx +21 -21
  735. package/source/components/_common/IconSVG/SVG/vehicle/Ps.tsx +19 -19
  736. package/source/components/_common/IconSVG/SVG/vehicle/Question.tsx +24 -24
  737. package/source/components/_common/IconSVG/SVG/vehicle/Seats.tsx +21 -21
  738. package/source/components/_common/IconSVG/SVG/vehicle/SeatsHeating.tsx +26 -26
  739. package/source/components/_common/IconSVG/SVG/vehicle/SelectorGearboxAutomatic.tsx +27 -27
  740. package/source/components/_common/IconSVG/SVG/vehicle/SelectorGearboxManualShift.tsx +24 -24
  741. package/source/components/_common/IconSVG/SVG/vehicle/SelectorGearboxOther.tsx +24 -24
  742. package/source/components/_common/IconSVG/SVG/vehicle/SelectorGearboxSemiAutomatic.tsx +30 -30
  743. package/source/components/_common/IconSVG/SVG/vehicle/SelectorInteriorTypeAlcantara.tsx +225 -225
  744. package/source/components/_common/IconSVG/SVG/vehicle/SelectorInteriorTypeFabric.tsx +29 -29
  745. package/source/components/_common/IconSVG/SVG/vehicle/SelectorInteriorTypeFullLeather.tsx +29 -29
  746. package/source/components/_common/IconSVG/SVG/vehicle/SelectorInteriorTypeOther.tsx +26 -26
  747. package/source/components/_common/IconSVG/SVG/vehicle/SelectorInteriorTypePartLeather.tsx +142 -142
  748. package/source/components/_common/IconSVG/SVG/vehicle/SelectorInteriorTypeSyntheticLeather.tsx +27 -27
  749. package/source/components/_common/IconSVG/SVG/vehicle/SelectorInteriorTypeVelours.tsx +39 -39
  750. package/source/components/_common/IconSVG/SVG/vehicle/Shield.tsx +39 -39
  751. package/source/components/_common/IconSVG/SVG/vehicle/Speedometer.tsx +23 -23
  752. package/source/components/_common/IconSVG/SVG/vehicle/StartStopSystem.tsx +30 -30
  753. package/source/components/_common/IconSVG/SVG/vehicle/Stop.tsx +25 -25
  754. package/source/components/_common/IconSVG/SVG/vehicle/TickMark.tsx +21 -21
  755. package/source/components/_common/IconSVG/SVG/vehicle/TrafficSignRecognition.tsx +29 -29
  756. package/source/components/_common/IconSVG/SVG/vehicle/TrailerCoupling.tsx +24 -24
  757. package/source/components/_common/IconSVG/SVG/vehicle/Transmission.tsx +27 -27
  758. package/source/components/_common/IconSVG/SVG/vehicle/Wheel.tsx +43 -43
  759. package/source/components/_common/IconSVG/SVG/vehicle/Wipers.tsx +22 -22
  760. package/source/components/_common/IconSVG/SVG/vehicle/Wrench.tsx +17 -17
  761. package/source/components/_common/Image/Image.story.js +142 -142
  762. package/source/components/_common/Image/Image.story.styl +18 -18
  763. package/source/components/_common/Image/Image.styl +109 -109
  764. package/source/components/_common/Image/Image.tsx +302 -302
  765. package/source/components/_common/ImagesSet/ImagesSet.story.js +34 -34
  766. package/source/components/_common/ImagesSet/ImagesSet.story.styl +3 -3
  767. package/source/components/_common/ImagesSet/ImagesSet.styl +27 -27
  768. package/source/components/_common/ImagesSet/ImagesSet.tsx +76 -76
  769. package/source/components/_common/Loader/Loader.story.js +21 -21
  770. package/source/components/_common/Loader/Loader.styl +39 -39
  771. package/source/components/_common/Loader/Loader.tsx +32 -32
  772. package/source/components/_common/MagnifyGlass/MagnifyGlass.styl +33 -33
  773. package/source/components/_common/MagnifyGlass/MagnifyGlass.tsx +213 -213
  774. package/source/components/_common/MaterialAccordion/MaterialAccordion.tsx +149 -149
  775. package/source/components/_common/MaterialAutocomplete/MaterialAutocomplete.styled.tsx +170 -170
  776. package/source/components/_common/MaterialAutocomplete/MaterialAutocomplete.tsx +219 -219
  777. package/source/components/_common/MaterialDatePicker/MaterialDatePicker.story.js +45 -45
  778. package/source/components/_common/MaterialDatePicker/MaterialDatePicker.story.styl +5 -5
  779. package/source/components/_common/MaterialDatePicker/MaterialDatePicker.styled.tsx +21 -21
  780. package/source/components/_common/MaterialDatePicker/MaterialDatePicker.tsx +112 -112
  781. package/source/components/_common/MaterialField/MaterialField.story.js +87 -87
  782. package/source/components/_common/MaterialField/MaterialField.story.styl +33 -33
  783. package/source/components/_common/MaterialField/MaterialField.styled.tsx +52 -52
  784. package/source/components/_common/MaterialField/MaterialField.tsx +91 -91
  785. package/source/components/_common/MaterialSelect/MaterialSelect.story.js +52 -52
  786. package/source/components/_common/MaterialSelect/MaterialSelect.story.styl +5 -5
  787. package/source/components/_common/MaterialSelect/MaterialSelect.styled.tsx +133 -133
  788. package/source/components/_common/MaterialSelect/MaterialSelect.tsx +211 -211
  789. package/source/components/_common/MaterialStepButton/MaterialStepButton.story.js +47 -47
  790. package/source/components/_common/MaterialStepButton/MaterialStepButton.story.styl +5 -5
  791. package/source/components/_common/MaterialStepButton/MaterialStepButton.styl +32 -32
  792. package/source/components/_common/MaterialStepButton/MaterialStepButton.tsx +61 -61
  793. package/source/components/_common/MuiDropDown/MuiDropDown.tsx +93 -93
  794. package/source/components/_common/MuiGroupedSelect/MuiGroupedSelect.story.js +21 -21
  795. package/source/components/_common/MuiGroupedSelect/MuiGroupedSelect.tsx +87 -87
  796. package/source/components/_common/OfferRequestButtonWrapper/OfferRequestButtonWrapper.styl +119 -119
  797. package/source/components/_common/OfferRequestButtonWrapper/OfferRequestButtonWrapper.styled.tsx +26 -26
  798. package/source/components/_common/OfferRequestButtonWrapper/OfferRequestButtonWrapper.tsx +119 -119
  799. package/source/components/_common/PropertySelector/FormPSGroup.story.js +36 -36
  800. package/source/components/_common/PropertySelector/FormPSGroup.story.styl +5 -5
  801. package/source/components/_common/PropertySelector/FormPSGroup.styl +22 -22
  802. package/source/components/_common/PropertySelector/FormPSGroup.tsx +54 -54
  803. package/source/components/_common/PropertySelector/PSGroup.story.js +93 -93
  804. package/source/components/_common/PropertySelector/PSGroup.story.styl +25 -25
  805. package/source/components/_common/PropertySelector/PSGroup.styl +5 -5
  806. package/source/components/_common/PropertySelector/PSGroup.tsx +98 -98
  807. package/source/components/_common/PropertySelector/PropertySelector.styl +139 -139
  808. package/source/components/_common/PropertySelector/PropertySelector.tsx +100 -100
  809. package/source/components/_common/PropertySelector/ProperySelector.story.js +83 -83
  810. package/source/components/_common/Radio/FormRadioGroup.story.js +28 -28
  811. package/source/components/_common/Radio/FormRadioGroup.story.styl +2 -2
  812. package/source/components/_common/Radio/FormRadioGroup.styl +22 -22
  813. package/source/components/_common/Radio/FormRadioGroup.tsx +52 -52
  814. package/source/components/_common/Radio/Radio.story.js +54 -54
  815. package/source/components/_common/Radio/Radio.styl +115 -115
  816. package/source/components/_common/Radio/Radio.tsx +141 -141
  817. package/source/components/_common/Radio/RadioGroup.story.js +90 -90
  818. package/source/components/_common/Radio/RadioGroup.story.styl +39 -39
  819. package/source/components/_common/Radio/RadioGroup.styl +5 -5
  820. package/source/components/_common/Radio/RadioGroup.tsx +65 -65
  821. package/source/components/_common/Range/Range.story.js +46 -46
  822. package/source/components/_common/Range/Range.story.styl +4 -4
  823. package/source/components/_common/Range/Range.styl +71 -71
  824. package/source/components/_common/Range/Range.tsx +69 -69
  825. package/source/components/_common/Skeleton/SkeletonItem.styl +80 -80
  826. package/source/components/_common/Skeleton/SkeletonItem.tsx +80 -80
  827. package/source/components/_common/Skeleton/SkeletonSearchItem.styl +123 -123
  828. package/source/components/_common/Skeleton/SkeletonSearchItem.tsx +92 -92
  829. package/source/components/_common/Slider/Slider.styl +2 -2
  830. package/source/components/_common/Slider/Slider.tsx +130 -130
  831. package/source/components/_common/SliderArrow/SliderArrow.story.js +18 -18
  832. package/source/components/_common/SliderArrow/SliderArrow.styl +32 -32
  833. package/source/components/_common/SliderArrow/SliderArrow.tsx +36 -36
  834. package/source/components/_common/StarButton/StarButton.styl +39 -39
  835. package/source/components/_common/StarButton/StarButton.tsx +31 -31
  836. package/source/components/_common/Tabs/TabPanel.tsx +28 -28
  837. package/source/components/_common/Tabs/Tabs.story.js +55 -55
  838. package/source/components/_common/Tabs/Tabs.styl +40 -40
  839. package/source/components/_common/Tabs/Tabs.tsx +44 -44
  840. package/source/components/_common/TextAreaField/TextAreaField.styl +47 -47
  841. package/source/components/_common/TextAreaField/TextAreaField.tsx +74 -74
  842. package/source/components/_common/TextField/FormTextField.story.js +21 -21
  843. package/source/components/_common/TextField/FormTextField.styl +35 -35
  844. package/source/components/_common/TextField/FormTextField.tsx +54 -54
  845. package/source/components/_common/TextField/TextField.styl +37 -37
  846. package/source/components/_common/TextField/TextField.tsx +77 -77
  847. package/source/components/_common/TimePicker/TimePicker.story.js +37 -37
  848. package/source/components/_common/TimePicker/TimePicker.styl +20 -20
  849. package/source/components/_common/TimePicker/TimePicker.tsx +138 -138
  850. package/source/components/_common/Tooltip/Tooltip.story.js +28 -28
  851. package/source/components/_common/Tooltip/Tooltip.styl +123 -123
  852. package/source/components/_common/Tooltip/Tooltip.tsx +62 -62
  853. package/source/components/_common/Usp/Usp.styl +78 -78
  854. package/source/components/_common/Usp/Usp.tsx +30 -30
  855. package/source/components/_common/VehicleSlider/VehicleSlider.story.js +99 -99
  856. package/source/components/_common/VehicleSlider/VehicleSlider.styl +62 -62
  857. package/source/components/_common/VehicleSlider/VehicleSlider.tsx +125 -125
  858. package/source/components/_common/VehicleSlider/VehicleSliderForSRL.tsx +170 -170
  859. package/source/components/_common/withLabel/withLabel.story.js +62 -62
  860. package/source/components/_common/withLabel/withLabel.styl +33 -33
  861. package/source/components/_common/withLabel/withLabel.tsx +44 -44
  862. package/source/components/_common/withPopover/withPopover.story.js +48 -48
  863. package/source/components/_common/withPopover/withPopover.story.styl +53 -53
  864. package/source/components/_common/withPopover/withPopover.styl +3 -3
  865. package/source/components/_common/withPopover/withPopover.tsx +88 -88
  866. package/source/components/_common/withStats/withStats.story.js +75 -75
  867. package/source/components/_common/withStats/withStats.styl +194 -194
  868. package/source/components/_common/withStats/withStats.tsx +176 -176
  869. package/source/components/containers/SearchPage/FiltersContainer/FiltersContainer.styl +50 -50
  870. package/source/components/containers/SearchPage/FiltersContainer/FiltersContainer.tsx +416 -416
  871. package/source/framework/DataTransformers.ts +80 -80
  872. package/source/framework/constants/RateSearchWidget.ts +15 -15
  873. package/source/framework/constants/Search.ts +290 -290
  874. package/source/framework/constants/SearchWidget.ts +108 -108
  875. package/source/framework/constants/app.ts +223 -223
  876. package/source/framework/constants/cars.ts +36 -36
  877. package/source/framework/constants/common.ts +9 -9
  878. package/source/framework/constants/data.ts +52 -52
  879. package/source/framework/constants/filters.ts +11 -11
  880. package/source/framework/constants/highlights.ts +165 -165
  881. package/source/framework/constants/price.ts +9 -9
  882. package/source/framework/constants/queryBuilder.ts +4 -4
  883. package/source/framework/constants/selectors.ts +38 -38
  884. package/source/framework/constants.ts +116 -116
  885. package/source/framework/data.ts +6 -6
  886. package/source/framework/factories/BreadcrumbsFactory.tsx +245 -245
  887. package/source/framework/factories/FactoryTypes.d.ts +29 -29
  888. package/source/framework/factories/FilterFactory.ts +364 -364
  889. package/source/framework/factories/ModalsFactory.tsx +11 -11
  890. package/source/framework/schemes/AggregationScheme.ts +73 -73
  891. package/source/framework/types/types.ts +323 -323
  892. package/source/framework/utils/CommonUtils.ts +519 -519
  893. package/source/framework/utils/CookieUtils.ts +61 -61
  894. package/source/framework/utils/DateUtils.ts +93 -93
  895. package/source/framework/utils/FiltersUtils.ts +234 -234
  896. package/source/framework/utils/RequestUtils.ts +20 -20
  897. package/source/framework/utils/StyledComponent.ts +2 -2
  898. package/source/framework/vehiclesProps/cbdSelectors.ts +117 -117
  899. package/source/framework/vehiclesProps/decoratedLightProps.tsx +300 -300
  900. package/source/framework/vehiclesProps/decoratedProps.tsx +1040 -1040
  901. package/source/framework/vehiclesProps/equipment.ts +128 -128
  902. package/source/framework/vehiclesProps/highlights.ts +54 -54
  903. package/source/framework/vehiclesProps/vehicleDetails.ts +309 -309
  904. package/source/globals.d.ts +18 -18
  905. package/source/locales/SearchDetailedPage.ts +205 -205
  906. package/source/locales/SearchPage.ts +224 -224
  907. package/source/locales/cbd.ts +719 -719
  908. package/source/locales/common.ts +109 -109
  909. package/source/locales/data.ts +1074 -1074
  910. package/source/locales/priceRating.ts +10 -10
  911. package/source/locales/sortingOptions.ts +21 -21
  912. package/source/theme/colors.styl +46 -46
  913. package/source/theme/mixins.styl +93 -93
  914. package/source/theme/priceReviewColors.styl +10 -10
  915. package/source/theme/selector_colors.styl +61 -61
  916. package/source/theme/slider.global.styl +3 -3
  917. package/source/theme/theme.styl +136 -136
  918. package/tsconfig.json +63 -63
  919. package/tslint.json +40 -40
  920. package/utils.ts +17 -17
@@ -1,520 +1,520 @@
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
- import { config } from '../constants/app';
14
-
15
- const PRICE_DEFAULT = DROP_DOWN_GROUP[PRICE].defaultValue;
16
-
17
- // const RANGE_FILTERS = [FIRST_REGISTRATION, MILEAGE, PRICE];
18
- // const ARRAY_RANGE_FILTERS = [FIRST_REGISTRATION, MILEAGE];
19
-
20
- export const formatMileage = (millage: number | string) => {
21
- return millage.toLocaleString('en-US').replace(/,/g, '.');
22
- };
23
-
24
- export const getFormattedNumber = (num: number) => Number.isFinite(num) ? num.toLocaleString('de-DE') : null;
25
-
26
- export const numberWithDot = (value: number | string) => {
27
- if (value === 'any' || value === 'beliebig') {
28
- return value;
29
- } else {
30
- return getFormattedNumber(+value);
31
- }
32
- }
33
-
34
- export const arrToObj = (arr: string[]): { [key: string]: boolean } => {
35
- if (!Array.isArray(arr)) return {};
36
- return arr.reduce(
37
- (obj: { [key: string]: boolean }, el: string) => { obj[el] = true; return obj; }, {}
38
- );
39
- };
40
-
41
- export const addPrefixToKeys = (obj: { [key: string]: any }, prefix: string) => {
42
- const result: { [key: string]: any } = {};
43
- Object.keys(obj).reduce((_, key) => {
44
- result[`${prefix}_${key}`] = obj[key];
45
- return result;
46
- }, result); // tslint:disable-line:align
47
- return result;
48
- };
49
-
50
- // function return list of filter for inject in title
51
- export const filtersInTitle = (filters: any) => {
52
- const result: any[] = [];
53
- const pushInResult = (value: any) => {
54
- if (result.length < MAX_FILTERS_IN_TITLE && value) {
55
- result.push(value);
56
- }
57
- };
58
-
59
- FILTERS_IN_TITLE.forEach((filter: string) => {
60
- if (filter === MMS_GROUPS_KEY) {
61
- filters.get(filter).forEach((MmsObject: any) => {
62
- pushInResult(MmsObject[MANUFACTURER_KEY].value);
63
- pushInResult(MmsObject[MODEL_KEY].value);
64
- });
65
- } else {
66
- filters.get(filter).value.forEach((value: string) => {
67
- pushInResult(value);
68
- });
69
- }
70
- });
71
- return result;
72
- };
73
-
74
- export const changeLocation = (path: string) =>
75
- window.location.href = `${window.location.origin}/${path}`;
76
-
77
- export const checkRangeValuesOnEqual = (defaultValues: any, filterValues: any) => {
78
- const keys = Object.keys(defaultValues);
79
- let valuesIsEqual = true;
80
- for (let i = 0; i < keys.length; i += 1) {
81
- const period = keys[i];
82
-
83
- if (filterValues[period] !== defaultValues[period]) {
84
- valuesIsEqual = false;
85
- break;
86
- }
87
- }
88
-
89
- return valuesIsEqual;
90
- };
91
-
92
- export interface ICarImage {
93
- url?: string;
94
- imageUrlSmall?: string;
95
- imageUrlMedium?: string;
96
- imageUrlLarge?: string;
97
- }
98
-
99
- export const preloadNearbyImages = (images: ICarImage[], activeIndex: number, imageUrlSize: 'imageUrlSmall' | 'imageUrlMedium' | 'imageUrlLarge') => {
100
- const imagesCount = Array.isArray(images) ? images.length : 0;
101
- const imageSize = imageUrlSize;
102
-
103
- const inMemoryPrevImage = new Image();
104
- const inMemoryNextImage = new Image();
105
-
106
- if (!!imagesCount) {
107
- const prevIndex = (activeIndex - 1 % imagesCount + imagesCount) % imagesCount;
108
- const nextIndex = (activeIndex + 1 % imagesCount + imagesCount) % imagesCount;
109
-
110
- inMemoryPrevImage.src = images[prevIndex][imageSize];
111
- inMemoryNextImage.src = images[nextIndex][imageSize];
112
- }
113
- };
114
-
115
- export const getGroupValuesForQuery = (groups: any) => {
116
- const arr: any = [];
117
- groups.map((group: any) => {
118
- const groupObj: any = {};
119
-
120
- Object.keys(group).forEach((key: string) => {
121
- const item = group[key];
122
- if (item.value) {
123
- groupObj[key] = item.value;
124
- }
125
- });
126
- if (Object.keys(groupObj).length) {
127
- arr.push(groupObj);
128
- }
129
- });
130
- return arr;
131
- };
132
-
133
- export const buildBodyForRequest = (state: any) => {
134
- const query: any = {
135
- filters: {
136
- absolutValues: {
137
- mmsGroup0: {}
138
- },
139
- noAbsolutValues: {},
140
- rangeValues: {}
141
- }
142
- };
143
-
144
- Object.keys(state).sort().forEach((key: string) => {
145
- const value = state[key];
146
-
147
- if (!value) return;
148
-
149
- if (key === MANUFACTURER && value.value) {
150
- query.filters.absolutValues.mmsGroup0.mainData_make = value.value;
151
- }
152
-
153
- if (key === MODEL && value.value) {
154
- if (value.isSeries) {
155
- query.filters.absolutValues.mmsGroup0.mainData_series = value.value;
156
- } else {
157
- query.filters.absolutValues.mmsGroup0.mainData_model = value.value;
158
- }
159
- }
160
-
161
- if (key === BODY_TYPE && value.length) {
162
- query.filters.noAbsolutValues[BODY_TYPE] = value;
163
- }
164
-
165
- if (key === FIRST_REGISTRATION && value.value) {
166
- query.filters.rangeValues['mainData_firstRegistrationYear'] = { from: value.value };
167
- }
168
-
169
- if (key === MILEAGE && value.value) {
170
- query.filters.rangeValues['mainData_mileage'] = { to: value.value };
171
- }
172
-
173
- if (key === PRICE) {
174
- const valueIsEqual = checkRangeValuesOnEqual(PRICE_DEFAULT, value);
175
-
176
- if (!valueIsEqual) {
177
- // check value in from / to. If we have - add it
178
- Object.keys(value).map((key: string) => {
179
- if (value[key]) {
180
- if (!query.filters.rangeValues['price_currentSalesPrice']) {
181
- query.filters.rangeValues['price_currentSalesPrice'] = {};
182
- }
183
-
184
- query.filters.rangeValues['price_currentSalesPrice'][key] = value[key];
185
- }
186
- });
187
- }
188
- }
189
-
190
- if (key === RATE) {
191
- const isRateDefault = checkRangeValuesOnEqual(RATE_DEFAULT, value);
192
-
193
- if (!isRateDefault) {
194
- query.filters.rangeValues['price_currentSalesPrice'] = { from: 1000, to: 2000 };
195
- }
196
- }
197
- });
198
-
199
- return query;
200
- };
201
-
202
- export const buildQueryForSearch = (filters: any) => {
203
- const query: { [key: string]: any } = {};
204
- const MMS_GROUP: any = {};
205
-
206
- Object.keys(filters).forEach((filter: string) => {
207
- const filterValue = filters[filter];
208
-
209
- if (filterValue && filterValue.value) {
210
- if (MMS_GROUP_FIELDS.indexOf(filter) !== -1) {
211
- MMS_GROUP[filter] = filterValue.value;
212
-
213
- if (filterValue.isSeries) {
214
- MMS_GROUP.SERIES = filterValue.value;
215
- }
216
- }
217
- }
218
-
219
- if (filterValue === PRICE) {
220
- const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
221
- const valueIsDefault = filter === PRICE ? checkRangeValuesOnEqual(defaultValue, filterValue) : filterValue === defaultValue;
222
-
223
- if (!valueIsDefault) {// check value in from / to. If we have - add it
224
- Object.keys(filterValue).map((key: string) => {
225
- if (filterValue[key]) {
226
- if (!query.filters.rangeValues['price_currentSalesPrice']) {
227
- query.filters.rangeValues['price_currentSalesPrice'] = {};
228
- }
229
-
230
- query.filters.rangeValues['price_currentSalesPrice'][key] = filterValue[key];
231
- }
232
- });
233
- }
234
- }
235
-
236
- if (filter === PRICE) {
237
- const valueIsDefault = checkRangeValuesOnEqual(PRICE_DEFAULT, filterValue);
238
-
239
- if (!valueIsDefault) {
240
- query[PRICE] = { from: '', to: '' };
241
- query[PRICE].from = _get(filterValue, 'from', '');
242
- query[PRICE].to = _get(filterValue, 'to', '');
243
- }
244
- }
245
-
246
- if (filter === RATE) {
247
- const isRateDefault = checkRangeValuesOnEqual(RATE_DEFAULT, filterValue);
248
-
249
- if (!isRateDefault) {
250
- query[RATE] = filterValue;
251
- }
252
- }
253
-
254
- if (filter === MILEAGE) {
255
- const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
256
- if (filterValue !== defaultValue) {
257
- query[MILEAGE] = { from: '', to: '' };
258
- query[MILEAGE].from = _get(filterValue, 'from', '');
259
- query[MILEAGE].to = _get(filterValue, 'to', '') || _get(filterValue, 'value', '');
260
- }
261
- }
262
-
263
- if (filter === FIRST_REGISTRATION) {
264
- const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
265
- if (filterValue !== defaultValue) {
266
- query[FIRST_REGISTRATION] = { from: '', to: '' };
267
- query[FIRST_REGISTRATION].from = _get(filterValue, 'from', '') || _get(filterValue, 'value', '');
268
- query[FIRST_REGISTRATION].to = _get(filterValue, 'to', '');
269
- }
270
- }
271
-
272
- if (filter === BODY_TYPE) {
273
- const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
274
-
275
- if (filterValue.length && filterValue !== defaultValue) {
276
- query[BODY_TYPE] = [];
277
-
278
- filterValue.map((bodyTypeSelector: string) => {
279
- query[BODY_TYPE].push(bodyTypeSelector);
280
- });
281
- }
282
- }
283
- });
284
-
285
- if (Object.keys(MMS_GROUP).length) {
286
- query[MMS_GROUPS_KEY] = [];
287
- query[MMS_GROUPS_KEY].push(MMS_GROUP);
288
- }
289
-
290
- return qs.stringify(query, { encode: false });
291
- };
292
-
293
- export const sliceLessThan = (array: number[], to: any): number[] => {
294
- const value = Number(to);
295
- return value && Number.isFinite(value)
296
- ? array.filter((val: number) => val <= value)
297
- : array;
298
- };
299
-
300
- export const sliceMoreThan = (array: number[], from: any): number[] => {
301
- const value = Number(from);
302
- return value && Number.isFinite(value)
303
- ? array.filter((val: number) => val >= value)
304
- : array;
305
- };
306
-
307
- export const getFormattedPrice = (price: any, format = '$,.0f', currency = ''): string => {
308
- if (!Number.isFinite(price)) return '-';
309
- const groupingNum = 3;
310
- return d3formatLocale({
311
- decimal: ',',
312
- thousands: '.',
313
- currency: ['', currency],
314
- grouping: [groupingNum]
315
- }).format(format)(price);
316
- };
317
-
318
- export const getPriceRating = (currentSalesPrice: number, predictablePrice: number) => {
319
- const isCorrectCurrentSalesPrice = Number.isFinite(Number.parseFloat(`${currentSalesPrice}`));
320
- const isCorrectPredictablePrice = Number.isFinite(Number.parseFloat(`${predictablePrice}`));
321
-
322
- if (!isCorrectCurrentSalesPrice || !isCorrectPredictablePrice) return 0;
323
-
324
- const ratingConfig = getPriceRatingConfig(currentSalesPrice, predictablePrice);
325
-
326
- for (const key of Object.keys(ratingConfig)) {
327
- const { min, max } = ratingConfig[key];
328
- const TOP_PRICE = 5;
329
- if (key === 'highPrice' && currentSalesPrice === max) return 1;
330
- if (key === 'topPrice' && currentSalesPrice <= min) return TOP_PRICE;
331
- if (currentSalesPrice >= min && currentSalesPrice < max) return priceRatings.indexOf(key);
332
- }
333
-
334
- return 0;
335
- };
336
-
337
- export const getPriceRatingConfig = (currentPrice: number, pricePredicted: number) => { // tslint:disable-line
338
- const round = (value: number) => {
339
- return Number.isFinite(pricePredicted)
340
- ? Math.round((pricePredicted * (1 + (value / 100))) / 100) * 100 // tslint:disable-line
341
- : '???';
342
- };
343
-
344
- if (currentPrice === 0) {
345
- console.log('Empty current price');
346
- }
347
-
348
- return Object.keys(priceRatingConfig).reduce((acc: any, key: any) => {
349
- const { min, max } = priceRatingConfig[key];
350
- return { ...acc, [key]: { min: round(min), max: round(max) } };
351
- }, {}); // tslint:disable-line
352
- };
353
-
354
- export const fixNumber = (num: number | string) => {
355
- const isNum = typeof num === 'number' ? num : parseFloat(num);
356
- return Math.round(isNum * HUNDRED) / HUNDRED;
357
- };
358
-
359
- export const getOfferSliders = (financingConfig: any, t: (key: string, options?: object) => string, priceTabIndex: null | number, componentType: string) => {
360
- const offerObj = offers[+priceTabIndex];
361
- const offerConfig = financingConfig[offerObj.name];
362
- const currentSalesPrice = financingConfig.common ? financingConfig.common.currentSalesPrice : financingConfig.currentSalesPrice; // TODO: fix deprecated. Correct is "financingConfig.common.currentSalesPrice"
363
- return offerObj.sliders
364
- .map((slider: any, index) => {
365
- if (componentType === 'checkout' && index === 1 && priceTabIndex === 0) return; // remove checkout annual mileage for financing
366
- if (slider.name === 'firstInstallment') slider.max = offerConfig.firstInstallmentMax || currentSalesPrice;
367
- slider.value = offerConfig[slider.name];
368
- slider.unitName = t(`modals:financing.${slider.unit}`);
369
- slider.caption = t(`modals:financing.${slider.name}`);
370
- return slider;
371
- }).filter(Boolean);
372
- };
373
-
374
- export const checkWebpFeature = async () => {
375
- // If the browser doesn't has the method createImageBitmap, you can't display webp format
376
- if (!self.createImageBitmap) return false;
377
-
378
- // Base64 representation of a white point image
379
- const webpData = 'data:image/webp;base64,UklGRiQAAABXRUJQVlA4IBgAAAAwAQCdASoCAAEAAQAcJaQAA3AA/v3AgAA=';
380
-
381
- // Retrieve the Image in Blob Format
382
- const blob = await fetch(webpData).then(r => r.blob());
383
-
384
- // If the createImageBitmap method succeeds, return true, otherwise false
385
- return createImageBitmap(blob).then(() => true, () => false);
386
- };
387
-
388
- export const getSupportedImageFormat = (IMAGE_URL: string, vehicleID: string, imageIdentifier: string, size: 'small' | 'medium' | 'large', webpFeature: boolean) => {
389
- if (!imageIdentifier) return null;
390
-
391
- const vehicleImageURL = `${IMAGE_URL}/${vehicleID}/${imageIdentifier}`;
392
-
393
- return webpFeature ? `${vehicleImageURL}/${size}-cached.webp` : `${vehicleImageURL}/${size}-cached.jpeg`;
394
- };
395
-
396
- export function getChipFilterValue (chip: any, t: (key: string, options?: object) => string, language: string = 'de') {
397
- let filterValue: string;
398
- let title: string;
399
- let from: string;
400
- let to: string;
401
- const chipFilterKey = chip.filterKey || chip.key; // we may have different key naming for landing or main
402
- const chipFilterValue = chip.filterValue || chip.value; // we may have different key naming for landing or main
403
- switch (chipFilterKey) {
404
- case 'MANUFACTURER':
405
- case 'MODEL':
406
- case 'SUB_MODEL':
407
- filterValue = chipFilterValue;
408
- break;
409
-
410
- case 'MANUFACTURER_EXCLUDE':
411
- case 'MODEL_EXCLUDE':
412
- title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
413
- filterValue = `${title} ${chipFilterValue}`;
414
- break;
415
-
416
- case 'FIRST_REGISTRATION':
417
- title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
418
- from = chipFilterValue.from ? `${t('SearchPage:filters.from')} ${chipFilterValue.from} ` : '';
419
- to = chipFilterValue.to ? `${t('SearchPage:filters.to')} ${chipFilterValue.to}` : '';
420
- filterValue = `${title} ${from} ${to}`;
421
- break;
422
-
423
- case 'PRICE':
424
- case 'PRICE_DIFFERENCE':
425
- case 'MILEAGE':
426
- case 'EMISSION_CO2':
427
- case 'POWER':
428
- case 'IMAGES_COUNT':
429
- title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
430
- from = chipFilterValue.from ? `${t('SearchPage:filters.from')} ${getFormattedPrice(+chipFilterValue.from)} ` : '';
431
- to = chipFilterValue.to ? `${t('SearchPage:filters.to')} ${getFormattedPrice(+chipFilterValue.to)}` : '';
432
- const type = chipFilterValue.type ? ` ${chipFilterValue.type}` : '';
433
- filterValue = `${title} ${from} ${to}${type}`;
434
- break;
435
-
436
- case 'DOORS':
437
- case 'OWNERS':
438
- filterValue = t(`SearchPage:filters.${chipFilterValue}`);
439
- break;
440
-
441
- case 'SEATS':
442
- case 'CUBIC_CAPACITY':
443
- title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
444
- const fromTo = `${chipFilterValue.from} - ${chipFilterValue.to}`;
445
- filterValue = `${title} ${fromTo}`;
446
- break;
447
-
448
- case 'CONSUMPTION':
449
- const fromValue = Number(chipFilterValue.from).toLocaleString(language);
450
- const toValue = Number(chipFilterValue.to).toLocaleString(language);
451
- const newFromValue: any = (fromValue === 'NaN') ? '1' : fromValue;
452
- const newToValue: any = (toValue === 'NaN') ? '18' : toValue;
453
- const fromToWithInfo = `${newFromValue} - ${newToValue}`;
454
- filterValue = t(`SearchPage:filtersChips.${chipFilterKey.toLocaleLowerCase()}`, { value: fromToWithInfo });
455
- break;
456
-
457
- case 'ONLINE_SINCE':
458
- filterValue = t(`SearchPage:filters.${chipFilterValue}`);
459
- break;
460
-
461
- case 'GENERAL_INSPECTION':
462
- filterValue = t(`SearchPage:filtersChips.generalInspection`, { month: t(`SearchPage:filters.${chipFilterValue}`) });
463
- break;
464
-
465
- case 'RATE':
466
- const { monthlyInstallmentFrom, monthlyInstallmentTo, firstInstallment, paybackPeriod } = chipFilterValue;
467
- const rowValues: any = { monthlyInstallmentFrom, monthlyInstallmentTo, firstInstallment, paybackPeriod };
468
- const values: string[][] = [
469
- ['monthlyInstallmentFrom', 'monthlyInstallmentTo'],
470
- ['firstInstallment', 'paybackPeriod']
471
- ].map((fields: string[]) => fields
472
- .map((field: string) => {
473
- const rowValue = rowValues[field];
474
- const value = Number.isFinite(+rowValue) ? getFormattedPrice(+rowValue) : rowValue;
475
- return +rowValue ? t(`SearchPage:filtersChips.${field}Chip`, { value }) : null;
476
- })
477
- .filter((item: any) => !!item)
478
- );
479
- const rateValue = `${t('SearchPage:filtersChips.rateChip')} ${values[0].length ? values[0].join(' ') : t('SearchPage:filtersChips.any')}`;
480
- filterValue = `${rateValue}, ${values[1].join(', ')}`;
481
- break;
482
-
483
- default:
484
- filterValue = t(`cbd:${chipFilterValue}`);
485
- }
486
- return filterValue;
487
- };
488
-
489
- function getUtmQueryParameter() {
490
- const query = window.location.search;
491
-
492
- if (!query) { return; }
493
-
494
- const queryString = /^[?]/.test(query) ? query.slice(1) : query;
495
-
496
- const result = queryString.split('&').reduce((params: any, param: string) => {
497
- const [key, value] = param.split('=');
498
-
499
- if (!/^source|^campaign|^medium|^content|^term|^reference|^gclid|^adgroupid|^keyword/.test(key)) { return params; }
500
-
501
- params[key] = value ? decodeURIComponent(value.replace(/\+/g, ' ')) : '';
502
-
503
- return params;
504
- }, {}); // eslint-disable-line indent,@typescript-eslint/indent
505
-
506
- return result;
507
- }
508
-
509
- export function setUtmParameters() {
510
- const marketing = getUtmQueryParameter();
511
-
512
- if (!marketing) return;
513
-
514
- if (!Object.keys(marketing).length) { return; }
515
-
516
- const expiresDate = new Date();
517
- expiresDate.setDate(expiresDate.getDate() + 1);
518
-
519
- document.cookie = `marketing=${JSON.stringify(marketing)};expires=${expiresDate};domain=.${config.DOMAIN};path=/`;
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
+ import { config } from '../constants/app';
14
+
15
+ const PRICE_DEFAULT = DROP_DOWN_GROUP[PRICE].defaultValue;
16
+
17
+ // const RANGE_FILTERS = [FIRST_REGISTRATION, MILEAGE, PRICE];
18
+ // const ARRAY_RANGE_FILTERS = [FIRST_REGISTRATION, MILEAGE];
19
+
20
+ export const formatMileage = (millage: number | string) => {
21
+ return millage.toLocaleString('en-US').replace(/,/g, '.');
22
+ };
23
+
24
+ export const getFormattedNumber = (num: number) => Number.isFinite(num) ? num.toLocaleString('de-DE') : null;
25
+
26
+ export const numberWithDot = (value: number | string) => {
27
+ if (value === 'any' || value === 'beliebig') {
28
+ return value;
29
+ } else {
30
+ return getFormattedNumber(+value);
31
+ }
32
+ }
33
+
34
+ export const arrToObj = (arr: string[]): { [key: string]: boolean } => {
35
+ if (!Array.isArray(arr)) return {};
36
+ return arr.reduce(
37
+ (obj: { [key: string]: boolean }, el: string) => { obj[el] = true; return obj; }, {}
38
+ );
39
+ };
40
+
41
+ export const addPrefixToKeys = (obj: { [key: string]: any }, prefix: string) => {
42
+ const result: { [key: string]: any } = {};
43
+ Object.keys(obj).reduce((_, key) => {
44
+ result[`${prefix}_${key}`] = obj[key];
45
+ return result;
46
+ }, result); // tslint:disable-line:align
47
+ return result;
48
+ };
49
+
50
+ // function return list of filter for inject in title
51
+ export const filtersInTitle = (filters: any) => {
52
+ const result: any[] = [];
53
+ const pushInResult = (value: any) => {
54
+ if (result.length < MAX_FILTERS_IN_TITLE && value) {
55
+ result.push(value);
56
+ }
57
+ };
58
+
59
+ FILTERS_IN_TITLE.forEach((filter: string) => {
60
+ if (filter === MMS_GROUPS_KEY) {
61
+ filters.get(filter).forEach((MmsObject: any) => {
62
+ pushInResult(MmsObject[MANUFACTURER_KEY].value);
63
+ pushInResult(MmsObject[MODEL_KEY].value);
64
+ });
65
+ } else {
66
+ filters.get(filter).value.forEach((value: string) => {
67
+ pushInResult(value);
68
+ });
69
+ }
70
+ });
71
+ return result;
72
+ };
73
+
74
+ export const changeLocation = (path: string) =>
75
+ window.location.href = `${window.location.origin}/${path}`;
76
+
77
+ export const checkRangeValuesOnEqual = (defaultValues: any, filterValues: any) => {
78
+ const keys = Object.keys(defaultValues);
79
+ let valuesIsEqual = true;
80
+ for (let i = 0; i < keys.length; i += 1) {
81
+ const period = keys[i];
82
+
83
+ if (filterValues[period] !== defaultValues[period]) {
84
+ valuesIsEqual = false;
85
+ break;
86
+ }
87
+ }
88
+
89
+ return valuesIsEqual;
90
+ };
91
+
92
+ export interface ICarImage {
93
+ url?: string;
94
+ imageUrlSmall?: string;
95
+ imageUrlMedium?: string;
96
+ imageUrlLarge?: string;
97
+ }
98
+
99
+ export const preloadNearbyImages = (images: ICarImage[], activeIndex: number, imageUrlSize: 'imageUrlSmall' | 'imageUrlMedium' | 'imageUrlLarge') => {
100
+ const imagesCount = Array.isArray(images) ? images.length : 0;
101
+ const imageSize = imageUrlSize;
102
+
103
+ const inMemoryPrevImage = new Image();
104
+ const inMemoryNextImage = new Image();
105
+
106
+ if (!!imagesCount) {
107
+ const prevIndex = (activeIndex - 1 % imagesCount + imagesCount) % imagesCount;
108
+ const nextIndex = (activeIndex + 1 % imagesCount + imagesCount) % imagesCount;
109
+
110
+ inMemoryPrevImage.src = images[prevIndex][imageSize];
111
+ inMemoryNextImage.src = images[nextIndex][imageSize];
112
+ }
113
+ };
114
+
115
+ export const getGroupValuesForQuery = (groups: any) => {
116
+ const arr: any = [];
117
+ groups.map((group: any) => {
118
+ const groupObj: any = {};
119
+
120
+ Object.keys(group).forEach((key: string) => {
121
+ const item = group[key];
122
+ if (item.value) {
123
+ groupObj[key] = item.value;
124
+ }
125
+ });
126
+ if (Object.keys(groupObj).length) {
127
+ arr.push(groupObj);
128
+ }
129
+ });
130
+ return arr;
131
+ };
132
+
133
+ export const buildBodyForRequest = (state: any) => {
134
+ const query: any = {
135
+ filters: {
136
+ absolutValues: {
137
+ mmsGroup0: {}
138
+ },
139
+ noAbsolutValues: {},
140
+ rangeValues: {}
141
+ }
142
+ };
143
+
144
+ Object.keys(state).sort().forEach((key: string) => {
145
+ const value = state[key];
146
+
147
+ if (!value) return;
148
+
149
+ if (key === MANUFACTURER && value.value) {
150
+ query.filters.absolutValues.mmsGroup0.mainData_make = value.value;
151
+ }
152
+
153
+ if (key === MODEL && value.value) {
154
+ if (value.isSeries) {
155
+ query.filters.absolutValues.mmsGroup0.mainData_series = value.value;
156
+ } else {
157
+ query.filters.absolutValues.mmsGroup0.mainData_model = value.value;
158
+ }
159
+ }
160
+
161
+ if (key === BODY_TYPE && value.length) {
162
+ query.filters.noAbsolutValues[BODY_TYPE] = value;
163
+ }
164
+
165
+ if (key === FIRST_REGISTRATION && value.value) {
166
+ query.filters.rangeValues['mainData_firstRegistrationYear'] = { from: value.value };
167
+ }
168
+
169
+ if (key === MILEAGE && value.value) {
170
+ query.filters.rangeValues['mainData_mileage'] = { to: value.value };
171
+ }
172
+
173
+ if (key === PRICE) {
174
+ const valueIsEqual = checkRangeValuesOnEqual(PRICE_DEFAULT, value);
175
+
176
+ if (!valueIsEqual) {
177
+ // check value in from / to. If we have - add it
178
+ Object.keys(value).map((key: string) => {
179
+ if (value[key]) {
180
+ if (!query.filters.rangeValues['price_currentSalesPrice']) {
181
+ query.filters.rangeValues['price_currentSalesPrice'] = {};
182
+ }
183
+
184
+ query.filters.rangeValues['price_currentSalesPrice'][key] = value[key];
185
+ }
186
+ });
187
+ }
188
+ }
189
+
190
+ if (key === RATE) {
191
+ const isRateDefault = checkRangeValuesOnEqual(RATE_DEFAULT, value);
192
+
193
+ if (!isRateDefault) {
194
+ query.filters.rangeValues['price_currentSalesPrice'] = { from: 1000, to: 2000 };
195
+ }
196
+ }
197
+ });
198
+
199
+ return query;
200
+ };
201
+
202
+ export const buildQueryForSearch = (filters: any) => {
203
+ const query: { [key: string]: any } = {};
204
+ const MMS_GROUP: any = {};
205
+
206
+ Object.keys(filters).forEach((filter: string) => {
207
+ const filterValue = filters[filter];
208
+
209
+ if (filterValue && filterValue.value) {
210
+ if (MMS_GROUP_FIELDS.indexOf(filter) !== -1) {
211
+ MMS_GROUP[filter] = filterValue.value;
212
+
213
+ if (filterValue.isSeries) {
214
+ MMS_GROUP.SERIES = filterValue.value;
215
+ }
216
+ }
217
+ }
218
+
219
+ if (filterValue === PRICE) {
220
+ const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
221
+ const valueIsDefault = filter === PRICE ? checkRangeValuesOnEqual(defaultValue, filterValue) : filterValue === defaultValue;
222
+
223
+ if (!valueIsDefault) {// check value in from / to. If we have - add it
224
+ Object.keys(filterValue).map((key: string) => {
225
+ if (filterValue[key]) {
226
+ if (!query.filters.rangeValues['price_currentSalesPrice']) {
227
+ query.filters.rangeValues['price_currentSalesPrice'] = {};
228
+ }
229
+
230
+ query.filters.rangeValues['price_currentSalesPrice'][key] = filterValue[key];
231
+ }
232
+ });
233
+ }
234
+ }
235
+
236
+ if (filter === PRICE) {
237
+ const valueIsDefault = checkRangeValuesOnEqual(PRICE_DEFAULT, filterValue);
238
+
239
+ if (!valueIsDefault) {
240
+ query[PRICE] = { from: '', to: '' };
241
+ query[PRICE].from = _get(filterValue, 'from', '');
242
+ query[PRICE].to = _get(filterValue, 'to', '');
243
+ }
244
+ }
245
+
246
+ if (filter === RATE) {
247
+ const isRateDefault = checkRangeValuesOnEqual(RATE_DEFAULT, filterValue);
248
+
249
+ if (!isRateDefault) {
250
+ query[RATE] = filterValue;
251
+ }
252
+ }
253
+
254
+ if (filter === MILEAGE) {
255
+ const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
256
+ if (filterValue !== defaultValue) {
257
+ query[MILEAGE] = { from: '', to: '' };
258
+ query[MILEAGE].from = _get(filterValue, 'from', '');
259
+ query[MILEAGE].to = _get(filterValue, 'to', '') || _get(filterValue, 'value', '');
260
+ }
261
+ }
262
+
263
+ if (filter === FIRST_REGISTRATION) {
264
+ const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
265
+ if (filterValue !== defaultValue) {
266
+ query[FIRST_REGISTRATION] = { from: '', to: '' };
267
+ query[FIRST_REGISTRATION].from = _get(filterValue, 'from', '') || _get(filterValue, 'value', '');
268
+ query[FIRST_REGISTRATION].to = _get(filterValue, 'to', '');
269
+ }
270
+ }
271
+
272
+ if (filter === BODY_TYPE) {
273
+ const defaultValue = DROP_DOWN_GROUP[filter].defaultValue;
274
+
275
+ if (filterValue.length && filterValue !== defaultValue) {
276
+ query[BODY_TYPE] = [];
277
+
278
+ filterValue.map((bodyTypeSelector: string) => {
279
+ query[BODY_TYPE].push(bodyTypeSelector);
280
+ });
281
+ }
282
+ }
283
+ });
284
+
285
+ if (Object.keys(MMS_GROUP).length) {
286
+ query[MMS_GROUPS_KEY] = [];
287
+ query[MMS_GROUPS_KEY].push(MMS_GROUP);
288
+ }
289
+
290
+ return qs.stringify(query, { encode: false });
291
+ };
292
+
293
+ export const sliceLessThan = (array: number[], to: any): number[] => {
294
+ const value = Number(to);
295
+ return value && Number.isFinite(value)
296
+ ? array.filter((val: number) => val <= value)
297
+ : array;
298
+ };
299
+
300
+ export const sliceMoreThan = (array: number[], from: any): number[] => {
301
+ const value = Number(from);
302
+ return value && Number.isFinite(value)
303
+ ? array.filter((val: number) => val >= value)
304
+ : array;
305
+ };
306
+
307
+ export const getFormattedPrice = (price: any, format = '$,.0f', currency = ''): string => {
308
+ if (!Number.isFinite(price)) return '-';
309
+ const groupingNum = 3;
310
+ return d3formatLocale({
311
+ decimal: ',',
312
+ thousands: '.',
313
+ currency: ['', currency],
314
+ grouping: [groupingNum]
315
+ }).format(format)(price);
316
+ };
317
+
318
+ export const getPriceRating = (currentSalesPrice: number, predictablePrice: number) => {
319
+ const isCorrectCurrentSalesPrice = Number.isFinite(Number.parseFloat(`${currentSalesPrice}`));
320
+ const isCorrectPredictablePrice = Number.isFinite(Number.parseFloat(`${predictablePrice}`));
321
+
322
+ if (!isCorrectCurrentSalesPrice || !isCorrectPredictablePrice) return 0;
323
+
324
+ const ratingConfig = getPriceRatingConfig(currentSalesPrice, predictablePrice);
325
+
326
+ for (const key of Object.keys(ratingConfig)) {
327
+ const { min, max } = ratingConfig[key];
328
+ const TOP_PRICE = 5;
329
+ if (key === 'highPrice' && currentSalesPrice === max) return 1;
330
+ if (key === 'topPrice' && currentSalesPrice <= min) return TOP_PRICE;
331
+ if (currentSalesPrice >= min && currentSalesPrice < max) return priceRatings.indexOf(key);
332
+ }
333
+
334
+ return 0;
335
+ };
336
+
337
+ export const getPriceRatingConfig = (currentPrice: number, pricePredicted: number) => { // tslint:disable-line
338
+ const round = (value: number) => {
339
+ return Number.isFinite(pricePredicted)
340
+ ? Math.round((pricePredicted * (1 + (value / 100))) / 100) * 100 // tslint:disable-line
341
+ : '???';
342
+ };
343
+
344
+ if (currentPrice === 0) {
345
+ console.log('Empty current price');
346
+ }
347
+
348
+ return Object.keys(priceRatingConfig).reduce((acc: any, key: any) => {
349
+ const { min, max } = priceRatingConfig[key];
350
+ return { ...acc, [key]: { min: round(min), max: round(max) } };
351
+ }, {}); // tslint:disable-line
352
+ };
353
+
354
+ export const fixNumber = (num: number | string) => {
355
+ const isNum = typeof num === 'number' ? num : parseFloat(num);
356
+ return Math.round(isNum * HUNDRED) / HUNDRED;
357
+ };
358
+
359
+ export const getOfferSliders = (financingConfig: any, t: (key: string, options?: object) => string, priceTabIndex: null | number, componentType: string) => {
360
+ const offerObj = offers[+priceTabIndex];
361
+ const offerConfig = financingConfig[offerObj.name];
362
+ const currentSalesPrice = financingConfig.common ? financingConfig.common.currentSalesPrice : financingConfig.currentSalesPrice; // TODO: fix deprecated. Correct is "financingConfig.common.currentSalesPrice"
363
+ return offerObj.sliders
364
+ .map((slider: any, index) => {
365
+ if (componentType === 'checkout' && index === 1 && priceTabIndex === 0) return; // remove checkout annual mileage for financing
366
+ if (slider.name === 'firstInstallment') slider.max = offerConfig.firstInstallmentMax || currentSalesPrice;
367
+ slider.value = offerConfig[slider.name];
368
+ slider.unitName = t(`modals:financing.${slider.unit}`);
369
+ slider.caption = t(`modals:financing.${slider.name}`);
370
+ return slider;
371
+ }).filter(Boolean);
372
+ };
373
+
374
+ export const checkWebpFeature = async () => {
375
+ // If the browser doesn't has the method createImageBitmap, you can't display webp format
376
+ if (!self.createImageBitmap) return false;
377
+
378
+ // Base64 representation of a white point image
379
+ const webpData = 'data:image/webp;base64,UklGRiQAAABXRUJQVlA4IBgAAAAwAQCdASoCAAEAAQAcJaQAA3AA/v3AgAA=';
380
+
381
+ // Retrieve the Image in Blob Format
382
+ const blob = await fetch(webpData).then(r => r.blob());
383
+
384
+ // If the createImageBitmap method succeeds, return true, otherwise false
385
+ return createImageBitmap(blob).then(() => true, () => false);
386
+ };
387
+
388
+ export const getSupportedImageFormat = (IMAGE_URL: string, vehicleID: string, imageIdentifier: string, size: 'small' | 'medium' | 'large', webpFeature: boolean) => {
389
+ if (!imageIdentifier) return null;
390
+
391
+ const vehicleImageURL = `${IMAGE_URL}/${vehicleID}/${imageIdentifier}`;
392
+
393
+ return webpFeature ? `${vehicleImageURL}/${size}-cached.webp` : `${vehicleImageURL}/${size}-cached.jpeg`;
394
+ };
395
+
396
+ export function getChipFilterValue (chip: any, t: (key: string, options?: object) => string, language: string = 'de') {
397
+ let filterValue: string;
398
+ let title: string;
399
+ let from: string;
400
+ let to: string;
401
+ const chipFilterKey = chip.filterKey || chip.key; // we may have different key naming for landing or main
402
+ const chipFilterValue = chip.filterValue || chip.value; // we may have different key naming for landing or main
403
+ switch (chipFilterKey) {
404
+ case 'MANUFACTURER':
405
+ case 'MODEL':
406
+ case 'SUB_MODEL':
407
+ filterValue = chipFilterValue;
408
+ break;
409
+
410
+ case 'MANUFACTURER_EXCLUDE':
411
+ case 'MODEL_EXCLUDE':
412
+ title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
413
+ filterValue = `${title} ${chipFilterValue}`;
414
+ break;
415
+
416
+ case 'FIRST_REGISTRATION':
417
+ title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
418
+ from = chipFilterValue.from ? `${t('SearchPage:filters.from')} ${chipFilterValue.from} ` : '';
419
+ to = chipFilterValue.to ? `${t('SearchPage:filters.to')} ${chipFilterValue.to}` : '';
420
+ filterValue = `${title} ${from} ${to}`;
421
+ break;
422
+
423
+ case 'PRICE':
424
+ case 'PRICE_DIFFERENCE':
425
+ case 'MILEAGE':
426
+ case 'EMISSION_CO2':
427
+ case 'POWER':
428
+ case 'IMAGES_COUNT':
429
+ title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
430
+ from = chipFilterValue.from ? `${t('SearchPage:filters.from')} ${getFormattedPrice(+chipFilterValue.from)} ` : '';
431
+ to = chipFilterValue.to ? `${t('SearchPage:filters.to')} ${getFormattedPrice(+chipFilterValue.to)}` : '';
432
+ const type = chipFilterValue.type ? ` ${chipFilterValue.type}` : '';
433
+ filterValue = `${title} ${from} ${to}${type}`;
434
+ break;
435
+
436
+ case 'DOORS':
437
+ case 'OWNERS':
438
+ filterValue = t(`SearchPage:filters.${chipFilterValue}`);
439
+ break;
440
+
441
+ case 'SEATS':
442
+ case 'CUBIC_CAPACITY':
443
+ title = t(`SearchPage:filters.${chipFilterKey.toLocaleLowerCase()}`);
444
+ const fromTo = `${chipFilterValue.from} - ${chipFilterValue.to}`;
445
+ filterValue = `${title} ${fromTo}`;
446
+ break;
447
+
448
+ case 'CONSUMPTION':
449
+ const fromValue = Number(chipFilterValue.from).toLocaleString(language);
450
+ const toValue = Number(chipFilterValue.to).toLocaleString(language);
451
+ const newFromValue: any = (fromValue === 'NaN') ? '1' : fromValue;
452
+ const newToValue: any = (toValue === 'NaN') ? '18' : toValue;
453
+ const fromToWithInfo = `${newFromValue} - ${newToValue}`;
454
+ filterValue = t(`SearchPage:filtersChips.${chipFilterKey.toLocaleLowerCase()}`, { value: fromToWithInfo });
455
+ break;
456
+
457
+ case 'ONLINE_SINCE':
458
+ filterValue = t(`SearchPage:filters.${chipFilterValue}`);
459
+ break;
460
+
461
+ case 'GENERAL_INSPECTION':
462
+ filterValue = t(`SearchPage:filtersChips.generalInspection`, { month: t(`SearchPage:filters.${chipFilterValue}`) });
463
+ break;
464
+
465
+ case 'RATE':
466
+ const { monthlyInstallmentFrom, monthlyInstallmentTo, firstInstallment, paybackPeriod } = chipFilterValue;
467
+ const rowValues: any = { monthlyInstallmentFrom, monthlyInstallmentTo, firstInstallment, paybackPeriod };
468
+ const values: string[][] = [
469
+ ['monthlyInstallmentFrom', 'monthlyInstallmentTo'],
470
+ ['firstInstallment', 'paybackPeriod']
471
+ ].map((fields: string[]) => fields
472
+ .map((field: string) => {
473
+ const rowValue = rowValues[field];
474
+ const value = Number.isFinite(+rowValue) ? getFormattedPrice(+rowValue) : rowValue;
475
+ return +rowValue ? t(`SearchPage:filtersChips.${field}Chip`, { value }) : null;
476
+ })
477
+ .filter((item: any) => !!item)
478
+ );
479
+ const rateValue = `${t('SearchPage:filtersChips.rateChip')} ${values[0].length ? values[0].join(' ') : t('SearchPage:filtersChips.any')}`;
480
+ filterValue = `${rateValue}, ${values[1].join(', ')}`;
481
+ break;
482
+
483
+ default:
484
+ filterValue = t(`cbd:${chipFilterValue}`);
485
+ }
486
+ return filterValue;
487
+ };
488
+
489
+ function getUtmQueryParameter() {
490
+ const query = window.location.search;
491
+
492
+ if (!query) { return; }
493
+
494
+ const queryString = /^[?]/.test(query) ? query.slice(1) : query;
495
+
496
+ const result = queryString.split('&').reduce((params: any, param: string) => {
497
+ const [key, value] = param.split('=');
498
+
499
+ if (!/^source|^campaign|^medium|^content|^term|^reference|^gclid|^adgroupid|^keyword/.test(key)) { return params; }
500
+
501
+ params[key] = value ? decodeURIComponent(value.replace(/\+/g, ' ')) : '';
502
+
503
+ return params;
504
+ }, {}); // eslint-disable-line indent,@typescript-eslint/indent
505
+
506
+ return result;
507
+ }
508
+
509
+ export function setUtmParameters() {
510
+ const marketing = getUtmQueryParameter();
511
+
512
+ if (!marketing) return;
513
+
514
+ if (!Object.keys(marketing).length) { return; }
515
+
516
+ const expiresDate = new Date();
517
+ expiresDate.setDate(expiresDate.getDate() + 1);
518
+
519
+ document.cookie = `marketing=${JSON.stringify(marketing)};expires=${expiresDate};domain=.${config.DOMAIN};path=/`;
520
520
  }