@times-components/ts-components 1.146.2-a0ffbb6bc2acbec91d140a39f6be06256e702094.5 → 1.146.2-c12ed7999a41984c2ba8c437357e7a5df1914881.48

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 (137) hide show
  1. package/dist/components/carousel-component/CarouselComponent.stories.d.ts +1 -0
  2. package/dist/components/carousel-component/CarouselComponent.stories.js +146 -0
  3. package/dist/components/carousel-component/CarouselItem.d.ts +3 -0
  4. package/dist/components/carousel-component/CarouselItem.js +12 -0
  5. package/dist/components/carousel-component/DefaultNavigationArrow.d.ts +8 -0
  6. package/dist/components/carousel-component/DefaultNavigationArrow.js +6 -0
  7. package/dist/components/carousel-component/DefaultPageDot.d.ts +8 -0
  8. package/dist/components/carousel-component/DefaultPageDot.js +4 -0
  9. package/dist/components/carousel-component/__tests__/CarouselComponent.test.d.ts +1 -0
  10. package/dist/components/carousel-component/__tests__/CarouselComponent.test.js +163 -0
  11. package/dist/components/carousel-component/__tests__/CarouselItem.test.d.ts +1 -0
  12. package/dist/components/carousel-component/__tests__/CarouselItem.test.js +80 -0
  13. package/dist/components/carousel-component/__tests__/DefaultNavigationArrow.test.d.ts +1 -0
  14. package/dist/components/carousel-component/__tests__/DefaultNavigationArrow.test.js +62 -0
  15. package/dist/components/carousel-component/__tests__/DefaultPageDot.test.d.ts +1 -0
  16. package/dist/components/carousel-component/__tests__/DefaultPageDot.test.js +68 -0
  17. package/dist/components/carousel-component/hooks/__tests__/useCarousel.test.d.ts +1 -0
  18. package/dist/components/carousel-component/hooks/__tests__/useCarousel.test.js +459 -0
  19. package/dist/components/carousel-component/hooks/useCarousel.d.ts +2 -0
  20. package/dist/components/carousel-component/hooks/useCarousel.js +167 -0
  21. package/dist/components/carousel-component/index.d.ts +4 -0
  22. package/dist/components/carousel-component/index.js +20 -0
  23. package/dist/components/carousel-component/styles.d.ts +28 -0
  24. package/dist/components/carousel-component/styles.js +172 -0
  25. package/dist/components/carousel-component/types.d.ts +53 -0
  26. package/dist/components/carousel-component/types.js +2 -0
  27. package/dist/components/social-embed/SocialMediaEmbed.js +15 -122
  28. package/dist/components/social-embed/SocialVendor.d.ts +16 -1
  29. package/dist/components/social-embed/SocialVendor.js +2 -41
  30. package/dist/components/social-embed/__tests__/SocialVendor.test.js +1 -8
  31. package/dist/components/social-embed/constants.d.ts +0 -1
  32. package/dist/components/social-embed/constants.js +2 -3
  33. package/dist/components/social-embed/helpers/socialMediaVendors.js +1 -6
  34. package/dist/components/social-embed/styles.d.ts +0 -1
  35. package/dist/components/social-embed/styles.js +1 -28
  36. package/dist/components/trip-cards/SkeletonCard.d.ts +7 -0
  37. package/dist/components/trip-cards/SkeletonCard.js +22 -0
  38. package/dist/components/trip-cards/TripCard.d.ts +3 -0
  39. package/dist/components/trip-cards/TripCard.js +61 -0
  40. package/dist/components/trip-cards/TripCards.stories.d.ts +1 -0
  41. package/dist/components/trip-cards/TripCards.stories.js +159 -0
  42. package/dist/components/trip-cards/TripCardsLayout.d.ts +3 -0
  43. package/dist/components/trip-cards/TripCardsLayout.js +63 -0
  44. package/dist/components/trip-cards/__tests__/SkeletonCard.test.d.ts +1 -0
  45. package/dist/components/trip-cards/__tests__/SkeletonCard.test.js +139 -0
  46. package/dist/components/trip-cards/__tests__/TripCard.test.d.ts +1 -0
  47. package/dist/components/trip-cards/__tests__/TripCard.test.js +165 -0
  48. package/dist/components/trip-cards/__tests__/TripCardsLayout.test.d.ts +1 -0
  49. package/dist/components/trip-cards/__tests__/TripCardsLayout.test.js +353 -0
  50. package/dist/components/trip-cards/__tests__/assets.test.d.ts +1 -0
  51. package/dist/components/trip-cards/__tests__/assets.test.js +165 -0
  52. package/dist/components/trip-cards/__tests__/helpers.test.d.ts +1 -0
  53. package/dist/components/trip-cards/__tests__/helpers.test.js +221 -0
  54. package/dist/components/trip-cards/__tests__/index.test.d.ts +1 -0
  55. package/dist/components/trip-cards/__tests__/index.test.js +482 -0
  56. package/dist/components/trip-cards/__tests__/mockData.test.d.ts +1 -0
  57. package/dist/components/trip-cards/__tests__/mockData.test.js +57 -0
  58. package/dist/components/trip-cards/__tests__/skeletonStyles.test.d.ts +1 -0
  59. package/dist/components/trip-cards/__tests__/skeletonStyles.test.js +194 -0
  60. package/dist/components/trip-cards/assets/BoatIcon.d.ts +1 -0
  61. package/dist/components/trip-cards/assets/BoatIcon.js +4 -0
  62. package/dist/components/trip-cards/assets/CalendarIcon.d.ts +1 -0
  63. package/dist/components/trip-cards/assets/CalendarIcon.js +4 -0
  64. package/dist/components/trip-cards/assets/ChevronRightIcon.d.ts +1 -0
  65. package/dist/components/trip-cards/assets/ChevronRightIcon.js +4 -0
  66. package/dist/components/trip-cards/assets/LocationIcon.d.ts +1 -0
  67. package/dist/components/trip-cards/assets/LocationIcon.js +4 -0
  68. package/dist/components/trip-cards/assets/MoonIcon.d.ts +1 -0
  69. package/dist/components/trip-cards/assets/MoonIcon.js +4 -0
  70. package/dist/components/trip-cards/assets/index.d.ts +6 -0
  71. package/dist/components/trip-cards/assets/index.js +7 -0
  72. package/dist/components/trip-cards/helpers.d.ts +11 -0
  73. package/dist/components/trip-cards/helpers.js +144 -0
  74. package/dist/components/trip-cards/index.d.ts +4 -0
  75. package/dist/components/trip-cards/index.js +68 -0
  76. package/dist/components/trip-cards/mockData.d.ts +3 -0
  77. package/dist/components/trip-cards/mockData.js +317 -0
  78. package/dist/components/trip-cards/skeletonStyles.d.ts +9 -0
  79. package/dist/components/trip-cards/skeletonStyles.js +37 -0
  80. package/dist/components/trip-cards/styles.d.ts +43 -0
  81. package/dist/components/trip-cards/styles.js +404 -0
  82. package/dist/components/trip-cards/types.d.ts +121 -0
  83. package/dist/components/trip-cards/types.js +2 -0
  84. package/dist/index.d.ts +1 -0
  85. package/dist/index.js +2 -1
  86. package/dist/utils/cookie.d.ts +1 -0
  87. package/dist/utils/cookie.js +8 -1
  88. package/package.json +3 -3
  89. package/rnw.js +1 -1
  90. package/src/components/carousel-component/CarouselComponent.stories.tsx +220 -0
  91. package/src/components/carousel-component/CarouselItem.tsx +26 -0
  92. package/src/components/carousel-component/DefaultNavigationArrow.tsx +37 -0
  93. package/src/components/carousel-component/DefaultPageDot.tsx +20 -0
  94. package/src/components/carousel-component/__tests__/CarouselComponent.test.tsx +259 -0
  95. package/src/components/carousel-component/__tests__/CarouselItem.test.tsx +140 -0
  96. package/src/components/carousel-component/__tests__/DefaultNavigationArrow.test.tsx +153 -0
  97. package/src/components/carousel-component/__tests__/DefaultPageDot.test.tsx +105 -0
  98. package/src/components/carousel-component/hooks/__tests__/useCarousel.test.ts +625 -0
  99. package/src/components/carousel-component/hooks/useCarousel.ts +229 -0
  100. package/src/components/carousel-component/index.tsx +92 -0
  101. package/src/components/carousel-component/styles.ts +188 -0
  102. package/src/components/carousel-component/types.ts +62 -0
  103. package/src/components/social-embed/SocialMediaEmbed.tsx +1 -111
  104. package/src/components/social-embed/SocialVendor.tsx +1 -46
  105. package/src/components/social-embed/__tests__/SocialVendor.test.tsx +0 -11
  106. package/src/components/social-embed/constants.ts +1 -2
  107. package/src/components/social-embed/helpers/socialMediaVendors.ts +0 -5
  108. package/src/components/social-embed/styles.ts +0 -30
  109. package/src/components/trip-cards/SkeletonCard.tsx +64 -0
  110. package/src/components/trip-cards/TripCard.tsx +172 -0
  111. package/src/components/trip-cards/TripCards.stories.tsx +224 -0
  112. package/src/components/trip-cards/TripCardsLayout.tsx +162 -0
  113. package/src/components/trip-cards/__tests__/SkeletonCard.test.tsx +169 -0
  114. package/src/components/trip-cards/__tests__/TripCard.test.tsx +255 -0
  115. package/src/components/trip-cards/__tests__/TripCardsLayout.test.tsx +671 -0
  116. package/src/components/trip-cards/__tests__/assets.test.tsx +206 -0
  117. package/src/components/trip-cards/__tests__/helpers.test.ts +273 -0
  118. package/src/components/trip-cards/__tests__/index.test.tsx +554 -0
  119. package/src/components/trip-cards/__tests__/mockData.test.ts +67 -0
  120. package/src/components/trip-cards/__tests__/skeletonStyles.test.tsx +256 -0
  121. package/src/components/trip-cards/assets/BoatIcon.tsx +17 -0
  122. package/src/components/trip-cards/assets/CalendarIcon.tsx +17 -0
  123. package/src/components/trip-cards/assets/ChevronRightIcon.tsx +20 -0
  124. package/src/components/trip-cards/assets/LocationIcon.tsx +17 -0
  125. package/src/components/trip-cards/assets/MoonIcon.tsx +17 -0
  126. package/src/components/trip-cards/assets/index.ts +7 -0
  127. package/src/components/trip-cards/helpers.ts +181 -0
  128. package/src/components/trip-cards/index.tsx +120 -0
  129. package/src/components/trip-cards/mockData.ts +345 -0
  130. package/src/components/trip-cards/skeletonStyles.ts +46 -0
  131. package/src/components/trip-cards/styles.ts +450 -0
  132. package/src/components/trip-cards/types.ts +130 -0
  133. package/src/index.ts +2 -0
  134. package/src/utils/cookie.ts +8 -0
  135. package/dist/components/social-embed/components/FacebookComponent.d.ts +0 -6
  136. package/dist/components/social-embed/components/FacebookComponent.js +0 -74
  137. package/src/components/social-embed/components/FacebookComponent.tsx +0 -93
@@ -0,0 +1,167 @@
1
+ import { useState, useEffect, useRef, useCallback } from 'react';
2
+ const DRAG_THRESHOLD = 30;
3
+ export const useCarousel = (totalItems, options = {}) => {
4
+ const { itemsPerPage = 2, onPageChange } = options;
5
+ const [currentPage, setCurrentPage] = useState(0);
6
+ const carouselRef = useRef(null);
7
+ const isScrollingRef = useRef(false);
8
+ const isDraggingRef = useRef(false);
9
+ const startXRef = useRef(0);
10
+ const touchStartXRef = useRef(null);
11
+ const isSwipingRef = useRef(false);
12
+ const totalPages = Math.ceil(totalItems / itemsPerPage);
13
+ const scrollToPage = useCallback((page) => {
14
+ if (carouselRef.current) {
15
+ const cardElements = carouselRef.current.children;
16
+ if (cardElements.length > 0) {
17
+ isScrollingRef.current = true;
18
+ const container = carouselRef.current;
19
+ const targetCardIndex = page * itemsPerPage;
20
+ const targetCard = cardElements[targetCardIndex];
21
+ if (targetCard) {
22
+ const targetScroll = targetCard.offsetLeft;
23
+ container.scrollTo({
24
+ left: targetScroll,
25
+ behavior: 'smooth'
26
+ });
27
+ setCurrentPage(page);
28
+ if (onPageChange) {
29
+ onPageChange(page);
30
+ }
31
+ setTimeout(() => {
32
+ isScrollingRef.current = false;
33
+ }, 400);
34
+ }
35
+ }
36
+ }
37
+ }, [itemsPerPage, onPageChange]);
38
+ const handlePrevious = useCallback(() => {
39
+ const newPage = Math.max(0, currentPage - 1);
40
+ scrollToPage(newPage);
41
+ }, [currentPage, scrollToPage]);
42
+ const handleNext = useCallback(() => {
43
+ const newPage = Math.min(totalPages - 1, currentPage + 1);
44
+ scrollToPage(newPage);
45
+ }, [currentPage, totalPages, scrollToPage]);
46
+ const handleDragNavigation = useCallback((diff) => {
47
+ if (Math.abs(diff) > DRAG_THRESHOLD) {
48
+ if (diff > 0) {
49
+ handleNext();
50
+ }
51
+ else {
52
+ handlePrevious();
53
+ }
54
+ }
55
+ }, [handleNext, handlePrevious]);
56
+ const handleMouseDown = useCallback((e) => {
57
+ if (!carouselRef.current) {
58
+ return;
59
+ }
60
+ e.preventDefault();
61
+ isDraggingRef.current = true;
62
+ startXRef.current = e.pageX;
63
+ carouselRef.current.style.cursor = 'grabbing';
64
+ }, []);
65
+ const handleMouseUp = useCallback((e) => {
66
+ if (!isDraggingRef.current) {
67
+ return;
68
+ }
69
+ isDraggingRef.current = false;
70
+ if (carouselRef.current) {
71
+ carouselRef.current.style.cursor = 'grab';
72
+ const endX = e.pageX;
73
+ const diff = startXRef.current - endX;
74
+ handleDragNavigation(diff);
75
+ }
76
+ }, [handleDragNavigation]);
77
+ const handleMouseLeave = useCallback((e) => {
78
+ if (!isDraggingRef.current) {
79
+ return;
80
+ }
81
+ isDraggingRef.current = false;
82
+ if (carouselRef.current) {
83
+ carouselRef.current.style.cursor = 'grab';
84
+ const endX = e.pageX;
85
+ const diff = startXRef.current - endX;
86
+ handleDragNavigation(diff);
87
+ }
88
+ }, [handleDragNavigation]);
89
+ const handleTouchStart = (e) => {
90
+ if (!carouselRef.current) {
91
+ return;
92
+ }
93
+ touchStartXRef.current = e.touches[0].clientX;
94
+ isSwipingRef.current = false;
95
+ };
96
+ const handleTouchMove = (e) => {
97
+ if (touchStartXRef.current === null || isSwipingRef.current) {
98
+ return;
99
+ }
100
+ const currentX = e.touches[0].clientX;
101
+ const diff = touchStartXRef.current - currentX;
102
+ if (Math.abs(diff) > DRAG_THRESHOLD) {
103
+ isSwipingRef.current = true;
104
+ handleDragNavigation(diff);
105
+ }
106
+ };
107
+ const handleTouchEnd = () => {
108
+ touchStartXRef.current = null;
109
+ isSwipingRef.current = false;
110
+ };
111
+ const handleScroll = useCallback(() => {
112
+ if (isScrollingRef.current) {
113
+ return;
114
+ }
115
+ if (carouselRef.current) {
116
+ const container = carouselRef.current;
117
+ const children = container.children;
118
+ if (children.length === 0) {
119
+ return;
120
+ }
121
+ const scrollLeft = container.scrollLeft;
122
+ let closestPage = 0;
123
+ let closestDistance = Infinity;
124
+ for (let page = 0; page < totalPages; page++) {
125
+ const cardIndex = page * itemsPerPage;
126
+ if (cardIndex < children.length) {
127
+ const card = children[cardIndex];
128
+ const distance = Math.abs(card.offsetLeft - scrollLeft);
129
+ if (distance < closestDistance) {
130
+ closestDistance = distance;
131
+ closestPage = page;
132
+ }
133
+ }
134
+ }
135
+ if (closestPage !== currentPage) {
136
+ setCurrentPage(closestPage);
137
+ if (onPageChange) {
138
+ onPageChange(closestPage);
139
+ }
140
+ }
141
+ }
142
+ }, [totalPages, itemsPerPage, onPageChange]);
143
+ useEffect(() => {
144
+ const carousel = carouselRef.current;
145
+ if (carousel) {
146
+ carousel.addEventListener('scroll', handleScroll);
147
+ return () => carousel.removeEventListener('scroll', handleScroll);
148
+ }
149
+ return undefined;
150
+ }, [handleScroll]);
151
+ return {
152
+ currentPage,
153
+ totalPages,
154
+ carouselRef,
155
+ isScrolling: isScrollingRef.current,
156
+ handlePrevious,
157
+ handleNext,
158
+ scrollToPage,
159
+ handleMouseDown,
160
+ handleMouseUp,
161
+ handleMouseLeave,
162
+ handleTouchStart,
163
+ handleTouchMove,
164
+ handleTouchEnd
165
+ };
166
+ };
167
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlQ2Fyb3VzZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9jYXJvdXNlbC1jb21wb25lbnQvaG9va3MvdXNlQ2Fyb3VzZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBRSxNQUFNLE9BQU8sQ0FBQztBQUdqRSxNQUFNLGNBQWMsR0FBRyxFQUFFLENBQUM7QUFFMUIsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLENBQ3pCLFVBQWtCLEVBQ2xCLFVBQThCLEVBQUUsRUFDYixFQUFFO0lBQ3JCLE1BQU0sRUFBRSxZQUFZLEdBQUcsQ0FBQyxFQUFFLFlBQVksRUFBRSxHQUFHLE9BQU8sQ0FBQztJQUVuRCxNQUFNLENBQUMsV0FBVyxFQUFFLGNBQWMsQ0FBQyxHQUFHLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNsRCxNQUFNLFdBQVcsR0FBRyxNQUFNLENBQWlCLElBQUksQ0FBQyxDQUFDO0lBQ2pELE1BQU0sY0FBYyxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNyQyxNQUFNLGFBQWEsR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDcEMsTUFBTSxTQUFTLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQzVCLE1BQU0sY0FBYyxHQUFHLE1BQU0sQ0FBZ0IsSUFBSSxDQUFDLENBQUM7SUFDbkQsTUFBTSxZQUFZLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBRW5DLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxHQUFHLFlBQVksQ0FBQyxDQUFDO0lBRXhELE1BQU0sWUFBWSxHQUFHLFdBQVcsQ0FDOUIsQ0FBQyxJQUFZLEVBQUUsRUFBRTtRQUNmLElBQUksV0FBVyxDQUFDLE9BQU8sRUFBRTtZQUN2QixNQUFNLFlBQVksR0FB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
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import { CarouselComponentProps } from './types';
3
+ export declare const CarouselComponent: React.FC<CarouselComponentProps>;
4
+ export { CarouselItem } from './CarouselItem';
@@ -0,0 +1,20 @@
1
+ import React from 'react';
2
+ import { useCarousel } from './hooks/useCarousel';
3
+ import { CarouselContainer, CarouselWrapper, CarouselContent, CardsRow, PageControl } from './styles';
4
+ import { DefaultNavigationArrow } from './DefaultNavigationArrow';
5
+ import { DefaultPageDot } from './DefaultPageDot';
6
+ export const CarouselComponent = ({ items, options, showArrows = true, showDots = true, arrowComponent: CustomArrow, dotComponent: CustomDot, className }) => {
7
+ const { currentPage, totalPages, carouselRef, handlePrevious, handleNext, scrollToPage, handleMouseDown, handleMouseUp, handleMouseLeave, handleTouchStart, handleTouchMove, handleTouchEnd } = useCarousel(items.length, options);
8
+ const ArrowComponent = CustomArrow || DefaultNavigationArrow;
9
+ const DotComponent = CustomDot || DefaultPageDot;
10
+ return (React.createElement(CarouselContainer, { className: className },
11
+ React.createElement(CarouselWrapper, null,
12
+ showArrows && (React.createElement(ArrowComponent, { direction: "left", onClick: handlePrevious, disabled: currentPage === 0 })),
13
+ React.createElement(CarouselContent, null,
14
+ React.createElement(CardsRow, { ref: carouselRef, onMouseDown: handleMouseDown, onMouseUp: handleMouseUp, onMouseLeave: handleMouseLeave, onTouchStart: handleTouchStart, onTouchMove: handleTouchMove, onTouchEnd: handleTouchEnd }, items)),
15
+ showArrows && (React.createElement(ArrowComponent, { direction: "right", onClick: handleNext, disabled: currentPage >= totalPages - 1 }))),
16
+ showDots &&
17
+ totalPages > 1 && (React.createElement(PageControl, null, Array.from({ length: totalPages }).map((_, pageIndex) => (React.createElement(DotComponent, { key: pageIndex, active: pageIndex === currentPage, onClick: () => scrollToPage(pageIndex), index: pageIndex })))))));
18
+ };
19
+ export { CarouselItem } from './CarouselItem';
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9jYXJvdXNlbC1jb21wb25lbnQvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxNQUFNLE9BQU8sQ0FBQztBQUMxQixPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbEQsT0FBTyxFQUNMLGlCQUFpQixFQUNqQixlQUFlLEVBQ2YsZUFBZSxFQUNmLFFBQVEsRUFDUixXQUFXLEVBQ1osTUFBTSxVQUFVLENBQUM7QUFDbEIsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBR2xELE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFxQyxDQUFDLEVBQ2xFLEtBQUssRUFDTCxPQUFPLEVBQ1AsVUFBVSxHQUFHLElBQUksRUFDakIsUUFBUSxHQUFHLElBQUksRUFDZixjQUFjLEVBQUUsV0FBVyxFQUMzQixZQUFZLEVBQUUsU0FBUyxFQUN2QixTQUFTLEVBQ1YsRUFBRSxFQUFFO0lBQ0gsTUFBTSxFQUNKLFdBQVcsRUFDWCxVQUFVLEVBQ1YsV0FBVyxFQUNYLGNBQWMsRUFDZCxVQUFVLEVBQ1YsWUFBWSxFQUNaLGVBQWUsRUFDZixhQUFhLEVBQ2IsZ0JBQWdCLEVBQ2hCLGdCQUFnQixFQUNoQixlQUFlLEVBQ2YsY0FBYyxFQUNmLEdBQUcsV0FBVyxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFFdkMsTUFBTSxjQUFjLEdBQUcsV0FBVyxJQUFJLHNCQUFzQixDQUFDO0lBQzdELE1BQU0sWUFBWSxHQUFHLFNBQVMsSUFBSSxjQUFjLENBQUM7SUFFakQsT0FBTyxDQUNMLG9CQUFDLGlCQUFpQixJQUFDLFNBQVMsRUFBRSxTQUFTO1FBQ3JDLG9CQUFDLGVBQWU7WUFDYixVQUFVLElBQUksQ0FDYixvQkFBQyxjQUFjLElBQ2IsU0FBUyxFQUFDLE1BQU0sRUFDaEIsT0FBTyxFQUFFLGNBQWMsRUFDdkIsUUFBUSxFQUFFLFdBQVcsS0FBSyxDQUFDLEdBQzNCLENBQ0g7WUFFRCxvQkFBQyxlQUFlO2dCQUNkLG9CQUFDLFFBQVEsSUFDUCxHQUFHLEVBQUUsV0FBVyxFQUNoQixXQUFXLEVBQUUsZUFBZSxFQUM1QixTQUFTLEVBQUUsYUFBYSxFQUN4QixZQUFZLEVBQUUsZ0JBQWdCLEVBQzlCLFlBQVksRUFBRSxnQkFBZ0IsRUFDOUIsV0FBVyxFQUFFLGVBQWUsRUFDNUIsVUFBVSxFQUFFLGNBQWMsSUFFekIsS0FBSyxDQUNHLENBQ0s7WUFFakIsVUFBVSxJQUFJLENBQ2Isb0JBQUMsY0FBYyxJQUNiLFNBQVMsRUFBQyxPQUFPLEVBQ2pCLE9BQU8sRUFBRSxVQUFVLEVBQ25CLFFBQVEsRUFBRSxXQUFXLElBQUksVUFBVSxHQUFHLENBQUMsR0FDdkMsQ0FDSCxDQUNlO1FBRWpCLFFBQVE7WUFDUCxVQUFVLEdBQUcsQ0FBQyxJQUFJLENBQ2hCLG9CQUFDLFdBQVcsUUFDVCxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLFNBQVMsRUFBRSxFQUFFLENBQUMsQ0FDeEQsb0JBQUMsWUFBWSxJQUNYLEdBQUcsRUFBRSxTQUFTLEVBQ2QsTUFBTSxFQUFFLFNBQVMsS0FBSyxXQUFXLEVBQ2pDLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLEVBQ3RDLEtBQUssRUFBRSxTQUFTLEdBQ2hCLENBQ0gsQ0FBQyxDQUNVLENBQ2YsQ0FDZSxDQUNyQixDQUFDO0FBQ0osQ0FBQyxDQUFDO0FBRUYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGdCQUFnQixDQUFDIn0=
@@ -0,0 +1,28 @@
1
+ import { ResponsiveConfig } from './types';
2
+ export declare const breakpoints: {
3
+ xs: string;
4
+ sm: string;
5
+ md: string;
6
+ lg: string;
7
+ xl: string;
8
+ };
9
+ export declare const colors: {
10
+ primary: string;
11
+ white: string;
12
+ };
13
+ export declare const ItemContainer: import("styled-components").StyledComponent<"div", any, {
14
+ widthItemConfig?: ResponsiveConfig | undefined;
15
+ maxWidthItemConfig?: ResponsiveConfig | undefined;
16
+ }, never>;
17
+ export declare const CarouselContainer: import("styled-components").StyledComponent<"div", any, {}, never>;
18
+ export declare const CarouselWrapper: import("styled-components").StyledComponent<"div", any, {}, never>;
19
+ export declare const CarouselContent: import("styled-components").StyledComponent<"div", any, {}, never>;
20
+ export declare const CardsRow: import("styled-components").StyledComponent<"div", any, {}, never>;
21
+ export declare const PageControl: import("styled-components").StyledComponent<"div", any, {}, never>;
22
+ export declare const NavigationArrowButton: import("styled-components").StyledComponent<"button", any, {
23
+ direction: 'left' | 'right';
24
+ disabled?: boolean | undefined;
25
+ }, never>;
26
+ export declare const PageDotButton: import("styled-components").StyledComponent<"button", any, {
27
+ active: boolean;
28
+ }, never>;
@@ -0,0 +1,172 @@
1
+ import styled, { css } from 'styled-components';
2
+ export const breakpoints = {
3
+ xs: '0px',
4
+ sm: '520px',
5
+ md: '768px',
6
+ lg: '1024px',
7
+ xl: '1320px'
8
+ };
9
+ export const colors = {
10
+ primary: '#005C8A',
11
+ white: '#FFFFFF'
12
+ };
13
+ export const ItemContainer = styled.div `
14
+ scroll-snap-align: start;
15
+ display: flex;
16
+ flex-direction: column;
17
+ align-self: stretch;
18
+
19
+ ${props => {
20
+ if (!props.widthItemConfig) {
21
+ return '';
22
+ }
23
+ const { xs, mobile, tablet, desktop, xl } = props.widthItemConfig;
24
+ return css `
25
+ ${xs && `flex: 0 0 ${xs};`}
26
+ ${mobile &&
27
+ `
28
+ @media (min-width: ${breakpoints.sm}) {
29
+ flex: 0 0 ${mobile};
30
+ }
31
+ `}
32
+ ${tablet &&
33
+ `
34
+ @media (min-width: ${breakpoints.md}) {
35
+ flex: 0 0 ${tablet};
36
+ }
37
+ `}
38
+ ${desktop &&
39
+ `
40
+ @media (min-width: ${breakpoints.lg}) {
41
+ flex: 0 0 ${desktop};
42
+ }
43
+ `}
44
+ ${xl &&
45
+ `
46
+ @media (min-width: ${breakpoints.xl}) {
47
+ flex: 0 0 ${xl};
48
+ }
49
+ `}
50
+ `;
51
+ }} ${props => {
52
+ if (!props.maxWidthItemConfig) {
53
+ return '';
54
+ }
55
+ const { xs, mobile, tablet, desktop, xl } = props.maxWidthItemConfig;
56
+ return css `
57
+ ${xs && `max-width: ${xs};`}
58
+ ${mobile &&
59
+ `
60
+ @media (min-width: ${breakpoints.sm}) {
61
+ max-width: ${mobile};
62
+ }
63
+ `}
64
+ ${tablet &&
65
+ `
66
+ @media (min-width: ${breakpoints.md}) {
67
+ max-width: ${tablet};
68
+ }
69
+ `}
70
+ ${desktop &&
71
+ `
72
+ @media (min-width: ${breakpoints.lg}) {
73
+ max-width: ${desktop};
74
+ }
75
+ `}
76
+ ${xl &&
77
+ `
78
+ @media (min-width: ${breakpoints.xl}) {
79
+ max-width: ${xl};
80
+ }
81
+ `}
82
+ `;
83
+ }};
84
+ `;
85
+ export const CarouselContainer = styled.div `
86
+ width: 100%;
87
+ `;
88
+ export const CarouselWrapper = styled.div `
89
+ position: relative;
90
+ width: 100%;
91
+ `;
92
+ export const CarouselContent = styled.div `
93
+ overflow: hidden;
94
+ `;
95
+ export const CardsRow = styled.div `
96
+ display: flex;
97
+ gap: 20px;
98
+ overflow-x: hidden;
99
+ scroll-snap-type: x mandatory;
100
+ scrollbar-width: none;
101
+ -ms-overflow-style: none;
102
+ padding: 0;
103
+ scroll-behavior: smooth;
104
+ cursor: grab;
105
+ user-select: none;
106
+ align-items: stretch;
107
+
108
+ &::-webkit-scrollbar {
109
+ display: none;
110
+ }
111
+
112
+ &:active {
113
+ cursor: grabbing;
114
+ }
115
+ `;
116
+ export const PageControl = styled.div `
117
+ display: flex;
118
+ justify-content: center;
119
+ align-items: center;
120
+ gap: 10px;
121
+ padding: 12px;
122
+ background: ${colors.white};
123
+ `;
124
+ export const NavigationArrowButton = styled.button `
125
+ display: none;
126
+ position: absolute;
127
+ top: 50%;
128
+ transform: translateY(-50%);
129
+ ${({ direction }) => direction === 'left' ? 'left: -68px;' : 'right: -68px;'} z-index: 10;
130
+ width: 48px;
131
+ height: 48px;
132
+ border: none;
133
+ border-radius: 50%;
134
+ background: ${({ disabled }) => (disabled ? '#CCCCCC' : colors.primary)};
135
+ cursor: ${({ disabled }) => (disabled ? 'default' : 'pointer')};
136
+ align-items: center;
137
+ justify-content: center;
138
+ transition: background 0.2s ease;
139
+ pointer-events: ${({ disabled }) => (disabled ? 'none' : 'auto')};
140
+
141
+ svg {
142
+ width: 24px;
143
+ height: 24px;
144
+ }
145
+
146
+ svg path {
147
+ stroke: ${colors.white};
148
+ }
149
+
150
+ &:hover:not(:disabled) {
151
+ background: #004a6e;
152
+ }
153
+
154
+ @media (min-width: ${breakpoints.lg}) {
155
+ display: flex;
156
+ }
157
+ `;
158
+ export const PageDotButton = styled.button `
159
+ width: 8px;
160
+ height: 8px;
161
+ border-radius: 1000px;
162
+ border: none;
163
+ padding: 0;
164
+ background: ${({ active }) => (active ? '#01000D' : '#AAAAAA')};
165
+ cursor: pointer;
166
+ transition: background 0.2s ease;
167
+
168
+ &:hover {
169
+ background: #01000d;
170
+ }
171
+ `;
172
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3R5bGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvY2Fyb3VzZWwtY29tcG9uZW50L3N0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLE1BQU0sRUFBRSxFQUFFLEdBQUcsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRWhELE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRztJQUN6QixFQUFFLEVBQUUsS0FBSztJQUNULEVBQUUsRUFBRSxPQUFPO0lBQ1gsRUFBRSxFQUFFLE9BQU87SUFDWCxFQUFFLEVBQUUsUUFBUTtJQUNaLEVBQUUsRUFBRSxRQUFRO0NBQ2IsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FBRztJQUNwQixPQUFPLEVBQUUsU0FBUztJQUNsQixLQUFLLEVBQUUsU0FBUztDQUNqQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBR3JDOzs7Ozs7SUFNRSxLQUFLLENBQUMsRUFBRTtJQUNSLElBQUksQ0FBQyxLQUFLLENBQUMsZUFBZSxFQUFFO1FBQzFCLE9BQU8sRUFBRSxDQUFDO0tBQ1g7SUFDRCxNQUFNLEVBQUUsRUFBRSxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsT0FBTyxFQUFFLEVBQUUsRUFBRSxHQUFHLEtBQUssQ0FBQyxlQUFlLENBQUM7SUFDbEUsT0FBTyxHQUFHLENBQUE7UUFDTixFQUFFLElBQUksYUFBYSxFQUFFLEdBQUc7UUFDeEIsTUFBTTtRQUNOOzZCQUNxQixXQUFXLENBQUMsRUFBRTtzQkFDckIsTUFBTTs7T0FFckI7UUFDQyxNQUFNO1FBQ047NkJBQ3FCLFdBQVcsQ0FBQyxFQUFFO3NCQUNyQixNQUFNOztPQUVyQjtRQUNDLE9BQU87UUFDUDs2QkFDcUIsV0FBVyxDQUFDLEVBQUU7c0JBQ3JCLE9BQU87O09BRXRCO1FBQ0MsRUFBRTtRQUNGOzZCQUNxQixXQUFXLENBQUMsRUFBRTtz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
@@ -0,0 +1,53 @@
1
+ import { ReactNode } from 'react';
2
+ export interface ResponsiveConfig {
3
+ xs?: string;
4
+ mobile?: string;
5
+ tablet?: string;
6
+ desktop?: string;
7
+ xl?: string;
8
+ }
9
+ export declare type ResponsiveConfigNoXs = Omit<ResponsiveConfig, 'xs'>;
10
+ export interface ArrowComponentProps {
11
+ direction: 'left' | 'right';
12
+ onClick: () => void;
13
+ disabled: boolean;
14
+ }
15
+ export interface DotComponentProps {
16
+ active: boolean;
17
+ onClick: () => void;
18
+ index: number;
19
+ }
20
+ export interface CarouselComponentProps {
21
+ items: ReactNode[];
22
+ options?: UseCarouselOptions;
23
+ showArrows?: boolean;
24
+ showDots?: boolean;
25
+ arrowComponent?: React.ComponentType<ArrowComponentProps>;
26
+ dotComponent?: React.ComponentType<DotComponentProps>;
27
+ className?: string;
28
+ }
29
+ export interface CarouselItemProps {
30
+ children: ReactNode;
31
+ widthItemConfig?: ResponsiveConfig;
32
+ maxWidthItemConfig?: ResponsiveConfig;
33
+ className?: string;
34
+ }
35
+ export interface UseCarouselOptions {
36
+ itemsPerPage?: number;
37
+ onPageChange?: (page: number) => void;
38
+ }
39
+ export interface UseCarouselReturn {
40
+ currentPage: number;
41
+ totalPages: number;
42
+ carouselRef: React.RefObject<HTMLDivElement>;
43
+ isScrolling: boolean;
44
+ handlePrevious: () => void;
45
+ handleNext: () => void;
46
+ scrollToPage: (page: number) => void;
47
+ handleMouseDown: (e: React.MouseEvent) => void;
48
+ handleMouseUp: (e: React.MouseEvent) => void;
49
+ handleMouseLeave: (e: React.MouseEvent<Element, MouseEvent>) => void;
50
+ handleTouchStart: (e: React.TouchEvent) => void;
51
+ handleTouchMove: (e: React.TouchEvent) => void;
52
+ handleTouchEnd: () => void;
53
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9jYXJvdXNlbC1jb21wb25lbnQvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiJ9
@@ -1,80 +1,3 @@
1
- /* import React, { FC, useEffect } from 'react';
2
- import { BlockedEmbedMessage } from './BlockedEmbedMessage';
3
- import { checkVendorConsent } from './helpers/vendorConsent';
4
- import { eventStatus } from './constants';
5
- import { TcData, VendorName } from './types';
6
- import { useSocialEmbedsContext } from '../../contexts/SocialEmbedsProvider';
7
- import { Vendor } from './SocialVendor';
8
-
9
- declare global {
10
- interface Window {
11
- __tcfapi?: (
12
- command: string,
13
- version: number,
14
- callback: (data: TcData, success: boolean) => void,
15
- listenerId?: number
16
- ) => void;
17
- twttr?: {
18
- widgets: {
19
- load: (element?: HTMLElement) => void;
20
- };
21
- };
22
- instgrm?: {
23
- Embeds?: {
24
- process: () => void;
25
- };
26
- };
27
- }
28
- }
29
-
30
- export type SocialMediaEmbedProps = {
31
- element?: any;
32
- url: string;
33
- vendorName: VendorName;
34
- id: string;
35
- };
36
-
37
- export const SocialMediaEmbed: FC<SocialMediaEmbedProps> = ({
38
- id,
39
- url,
40
- vendorName
41
- }) => {
42
- const {
43
- setIsSocialEmbedAllowed,
44
- isAllowedOnce,
45
- isSocialEmbedAllowed
46
- } = useSocialEmbedsContext();
47
-
48
- useEffect(
49
- () => {
50
- if (window.__tcfapi) {
51
- window.__tcfapi('addEventListener', 2, (tcData, success) => {
52
- if (
53
- success &&
54
- (tcData.eventStatus === eventStatus.tcLoaded ||
55
- tcData.eventStatus === eventStatus.userActionComplete)
56
- ) {
57
- const consent = checkVendorConsent(vendorName);
58
- setIsSocialEmbedAllowed(prev => ({
59
- ...prev,
60
- [vendorName]: consent
61
- }));
62
- }
63
- });
64
- }
65
- },
66
- [vendorName, setIsSocialEmbedAllowed]
67
- );
68
-
69
- return isSocialEmbedAllowed[vendorName] || isAllowedOnce[vendorName] ? (
70
- <div id={id}>
71
- <Vendor vendorName={vendorName} url={url} />
72
- </div>
73
- ) : (
74
- <BlockedEmbedMessage vendorName={vendorName} />
75
- );
76
- };
77
- */
78
1
  import React, { useEffect } from 'react';
79
2
  import { BlockedEmbedMessage } from './BlockedEmbedMessage';
80
3
  import { checkVendorConsent } from './helpers/vendorConsent';
@@ -84,51 +7,21 @@ import { Vendor } from './SocialVendor';
84
7
  export const SocialMediaEmbed = ({ id, url, vendorName }) => {
85
8
  const { setIsSocialEmbedAllowed, isAllowedOnce, isSocialEmbedAllowed } = useSocialEmbedsContext();
86
9
  useEffect(() => {
87
- if (!window.__tcfapi)
88
- return;
89
- // 1. READ CURRENT CONSENT IMMEDIATELY
90
- const initialConsent = checkVendorConsent(vendorName);
91
- setIsSocialEmbedAllowed(prev => ({
92
- ...prev,
93
- [vendorName]: initialConsent
94
- }));
95
- // ✅ 2. LISTEN FOR FUTURE CHANGES
96
- window.__tcfapi('addEventListener', 2, (tcData, success) => {
97
- if (success &&
98
- (tcData.eventStatus === eventStatus.tcLoaded ||
99
- tcData.eventStatus === eventStatus.userActionComplete)) {
100
- const consent = checkVendorConsent(vendorName);
101
- setIsSocialEmbedAllowed(prev => ({
102
- ...prev,
103
- [vendorName]: consent
104
- }));
105
- }
106
- });
10
+ if (window.__tcfapi) {
11
+ window.__tcfapi('addEventListener', 2, (tcData, success) => {
12
+ if (success &&
13
+ (tcData.eventStatus === eventStatus.tcLoaded ||
14
+ tcData.eventStatus === eventStatus.userActionComplete)) {
15
+ const consent = checkVendorConsent(vendorName);
16
+ setIsSocialEmbedAllowed(prev => ({
17
+ ...prev,
18
+ [vendorName]: consent
19
+ }));
20
+ }
21
+ });
22
+ }
107
23
  }, [vendorName, setIsSocialEmbedAllowed]);
108
- /* useEffect(() => {
109
- if (!window.__tcfapi) return;
110
-
111
- // Listen to CMP consent updates
112
- window.__tcfapi('addEventListener', 2, (_tcData: TcData, success: boolean) => {
113
- if (
114
- !success ||
115
- _tcData.eventStatus === eventStatus.tcLoaded ||
116
- _tcData.eventStatus === eventStatus.userActionComplete
117
- ) {
118
- // Use old checkVendorConsent function
119
- const consent = checkVendorConsent(vendorName);
120
-
121
- setIsSocialEmbedAllowed(prev => ({
122
- ...prev,
123
- [vendorName]: consent
124
- }));
125
- }
126
- });
127
- }, [vendorName, setIsSocialEmbedAllowed]); */
128
- // Only render the social component if consent or allowed once
129
- const allowed = isSocialEmbedAllowed[vendorName] === true ||
130
- isAllowedOnce[vendorName] === true;
131
- return allowed ? (React.createElement("div", { id: id },
24
+ return isSocialEmbedAllowed[vendorName] || isAllowedOnce[vendorName] ? (React.createElement("div", { id: id },
132
25
  React.createElement(Vendor, { vendorName: vendorName, url: url }))) : (React.createElement(BlockedEmbedMessage, { vendorName: vendorName }));
133
26
  };
134
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU29jaWFsTWVkaWFFbWJlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3NvY2lhbC1lbWJlZC9Tb2NpYWxNZWRpYUVtYmVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQTRFRztBQUVILE9BQU8sS0FBSyxFQUFFLEVBQU0sU0FBUyxFQUFFLE1BQU0sT0FBTyxDQUFDO0FBQzdDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzVELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzdELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFMUMsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDN0UsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBOEJ4QyxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBOEIsQ0FBQyxFQUMxRCxFQUFFLEVBQ0YsR0FBRyxFQUNILFVBQVUsRUFDWCxFQUFFLEVBQUU7SUFDSCxNQUFNLEVBQ0osdUJBQXVCLEVBQ3ZCLGFBQWEsRUFDYixvQkFBb0IsRUFDckIsR0FBRyxzQkFBc0IsRUFBRSxDQUFDO0lBRTdCLFNBQVMsQ0FBQyxHQUFHLEVBQUU7UUFDZixJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVE7WUFBRSxPQUFPO1FBRTdCLHdDQUF3QztRQUN4QyxNQUFNLGNBQWMsR0FBRyxrQkFBa0IsQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUN0RCx1QkFBdUIsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDL0IsR0FBRyxJQUFJO1lBQ1AsQ0FBQyxVQUFVLENBQUMsRUFBRSxjQUFjO1NBQzdCLENBQUMsQ0FBQyxDQUFDO1FBRUosaUNBQWlDO1FBQ2pDLE1BQU0sQ0FBQyxRQUFRLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxFQUFFLENBQUMsTUFBTSxFQUFFLE9BQU8sRUFBRSxFQUFFO1lBQ3pELElBQ0UsT0FBTztnQkFDUCxDQUFDLE1BQU0sQ0FBQyxXQUFXLEtBQUssV0FBVyxDQUFDLFFBQVE7b0JBQzFDLE1BQU0sQ0FBQyxXQUFXLEtBQUssV0FBVyxDQUFDLGtCQUFrQixDQUFDLEVBQ3hEO2dCQUNBLE1BQU0sT0FBTyxHQUFHLGtCQUFrQixDQUFDLFVBQVUsQ0FBQyxDQUFDO2dCQUMvQyx1QkFBdUIsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7b0JBQy9CLEdBQUcsSUFBSTtvQkFDUCxDQUFDLFVBQVUsQ0FBQyxFQUFFLE9BQU87aUJBQ3RCLENBQUMsQ0FBQyxDQUFDO2FBQ0w7UUFDSCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUMsRUFBRSxDQUFDLFVBQVUsRUFBRSx1QkFBdUIsQ0FBQyxDQUFDLENBQUM7SUFHekM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7a0RBbUI4QztJQUU3Qyw4REFBOEQ7SUFDOUQsTUFBTSxPQUFPLEdBQ1gsb0JBQW9CLENBQUMsVUFBVSxDQUFDLEtBQUssSUFBSTtRQUN6QyxhQUFhLENBQUMsVUFBVSxDQUFDLEtBQUssSUFBSSxDQUFDO0lBRXJDLE9BQU8sT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUNmLDZCQUFLLEVBQUUsRUFBRSxFQUFFO1FBQ1Qsb0JBQUMsTUFBTSxJQUFDLFVBQVUsRUFBRSxVQUFVLEVBQUUsR0FBRyxFQUFFLEdBQUcsR0FBSSxDQUN4QyxDQUNQLENBQUMsQ0FBQyxDQUFDLENBQ0Ysb0JBQUMsbUJBQW1CLElBQUMsVUFBVSxFQUFFLFVBQVUsR0FBSSxDQUNoRCxDQUFDO0FBQ0osQ0FBQyxDQUFDIn0=
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU29jaWFsTWVkaWFFbWJlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3NvY2lhbC1lbWJlZC9Tb2NpYWxNZWRpYUVtYmVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxFQUFNLFNBQVMsRUFBRSxNQUFNLE9BQU8sQ0FBQztBQUM3QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRTFDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQThCeEMsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQThCLENBQUMsRUFDMUQsRUFBRSxFQUNGLEdBQUcsRUFDSCxVQUFVLEVBQ1gsRUFBRSxFQUFFO0lBQ0gsTUFBTSxFQUNKLHVCQUF1QixFQUN2QixhQUFhLEVBQ2Isb0JBQW9CLEVBQ3JCLEdBQUcsc0JBQXNCLEVBQUUsQ0FBQztJQUU3QixTQUFTLENBQ1AsR0FBRyxFQUFFO1FBQ0gsSUFBSSxNQUFNLENBQUMsUUFBUSxFQUFFO1lBQ25CLE1BQU0sQ0FBQyxRQUFRLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxFQUFFLENBQUMsTUFBTSxFQUFFLE9BQU8sRUFBRSxFQUFFO2dCQUN6RCxJQUNFLE9BQU87b0JBQ1AsQ0FBQyxNQUFNLENBQUMsV0FBVyxLQUFLLFdBQVcsQ0FBQyxRQUFRO3dCQUMxQyxNQUFNLENBQUMsV0FBVyxLQUFLLFdBQVcsQ0FBQyxrQkFBa0IsQ0FBQyxFQUN4RDtvQkFDQSxNQUFNLE9BQU8sR0FBRyxrQkFBa0IsQ0FBQyxVQUFVLENBQUMsQ0FBQztvQkFDL0MsdUJBQXVCLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO3dCQUMvQixHQUFHLElBQUk7d0JBQ1AsQ0FBQyxVQUFVLENBQUMsRUFBRSxPQUFPO3FCQUN0QixDQUFDLENBQUMsQ0FBQztpQkFDTDtZQUNILENBQUMsQ0FBQyxDQUFDO1NBQ0o7SUFDSCxDQUFDLEVBQ0QsQ0FBQyxVQUFVLEVBQUUsdUJBQXVCLENBQUMsQ0FDdEMsQ0FBQztJQUVGLE9BQU8sb0JBQW9CLENBQUMsVUFBVSxDQUFDLElBQUksYUFBYSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUNyRSw2QkFBSyxFQUFFLEVBQUUsRUFBRTtRQUNULG9CQUFDLE1BQU0sSUFBQyxVQUFVLEVBQUUsVUFBVSxFQUFFLEdBQUcsRUFBRSxHQUFHLEdBQUksQ0FDeEMsQ0FDUCxDQUFDLENBQUMsQ0FBQyxDQUNGLG9CQUFDLG1CQUFtQixJQUFDLFVBQVUsRUFBRSxVQUFVLEdBQUksQ0FDaEQsQ0FBQztBQUNKLENBQUMsQ0FBQyJ9
@@ -1,5 +1,20 @@
1
- import { VendorName } from './types';
1
+ declare const vendors: {
2
+ twitter: ({ url }: {
3
+ url: string;
4
+ }) => JSX.Element;
5
+ youtube: ({ url }: {
6
+ url: string;
7
+ }) => JSX.Element;
8
+ tiktok: ({ url }: {
9
+ url: string;
10
+ }) => JSX.Element;
11
+ instagram: ({ url }: {
12
+ url: string;
13
+ }) => JSX.Element;
14
+ };
15
+ export declare type VendorName = keyof typeof vendors;
2
16
  export declare const Vendor: ({ vendorName, url }: {
3
17
  vendorName: VendorName;
4
18
  url: string;
5
19
  }) => JSX.Element;
20
+ export {};