@xsolla/xui-game-card 0.158.0 → 0.160.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +69 -48
- package/native/index.d.mts +2 -0
- package/native/index.d.ts +2 -0
- package/native/index.js +5 -1
- package/native/index.js.map +1 -1
- package/native/index.mjs +5 -1
- package/native/index.mjs.map +1 -1
- package/package.json +3 -3
- package/web/index.d.mts +2 -0
- package/web/index.d.ts +2 -0
- package/web/index.js +8 -2
- package/web/index.js.map +1 -1
- package/web/index.mjs +8 -2
- package/web/index.mjs.map +1 -1
package/README.md
CHANGED
|
@@ -13,8 +13,8 @@ npm install @xsolla/xui-game-card
|
|
|
13
13
|
### Basic GameCard
|
|
14
14
|
|
|
15
15
|
```tsx
|
|
16
|
-
import * as React from
|
|
17
|
-
import { GameCard } from
|
|
16
|
+
import * as React from "react";
|
|
17
|
+
import { GameCard } from "@xsolla/xui-game-card";
|
|
18
18
|
|
|
19
19
|
export default function BasicGameCard() {
|
|
20
20
|
return (
|
|
@@ -31,10 +31,10 @@ export default function BasicGameCard() {
|
|
|
31
31
|
### GameCard with Tags
|
|
32
32
|
|
|
33
33
|
```tsx
|
|
34
|
-
import * as React from
|
|
35
|
-
import { GameCard } from
|
|
36
|
-
import { Tag } from
|
|
37
|
-
import { XsollaTicket, XsollaPoint } from
|
|
34
|
+
import * as React from "react";
|
|
35
|
+
import { GameCard } from "@xsolla/xui-game-card";
|
|
36
|
+
import { Tag } from "@xsolla/xui-tag";
|
|
37
|
+
import { XsollaTicket, XsollaPoint } from "@xsolla/xui-icons-currency";
|
|
38
38
|
|
|
39
39
|
export default function GameCardWithTags() {
|
|
40
40
|
return (
|
|
@@ -44,11 +44,19 @@ export default function GameCardWithTags() {
|
|
|
44
44
|
subtitle="Strategy • Puzzle • Building"
|
|
45
45
|
tagsTopLeft={
|
|
46
46
|
<>
|
|
47
|
-
<Tag size="sm" tone="brand" icon={<XsollaPoint />}>
|
|
48
|
-
|
|
47
|
+
<Tag size="sm" tone="brand" icon={<XsollaPoint />}>
|
|
48
|
+
250
|
|
49
|
+
</Tag>
|
|
50
|
+
<Tag size="sm" tone="secondary" icon={<XsollaTicket />}>
|
|
51
|
+
5x
|
|
52
|
+
</Tag>
|
|
49
53
|
</>
|
|
50
54
|
}
|
|
51
|
-
tagsTopRight={
|
|
55
|
+
tagsTopRight={
|
|
56
|
+
<Tag size="sm" tone="secondary">
|
|
57
|
+
10h left
|
|
58
|
+
</Tag>
|
|
59
|
+
}
|
|
52
60
|
buttonText="Activate"
|
|
53
61
|
/>
|
|
54
62
|
);
|
|
@@ -58,14 +66,14 @@ export default function GameCardWithTags() {
|
|
|
58
66
|
### GameCard with Custom Trailing
|
|
59
67
|
|
|
60
68
|
```tsx
|
|
61
|
-
import * as React from
|
|
62
|
-
import { GameCard } from
|
|
63
|
-
import { Button } from
|
|
64
|
-
import { Badge } from
|
|
69
|
+
import * as React from "react";
|
|
70
|
+
import { GameCard } from "@xsolla/xui-game-card";
|
|
71
|
+
import { Button } from "@xsolla/xui-button";
|
|
72
|
+
import { Badge } from "@xsolla/xui-badge";
|
|
65
73
|
|
|
66
74
|
export default function GameCardCustomTrailing() {
|
|
67
75
|
return (
|
|
68
|
-
<div style={{ display:
|
|
76
|
+
<div style={{ display: "flex", flexDirection: "column", gap: 16 }}>
|
|
69
77
|
{/* Custom Button */}
|
|
70
78
|
<GameCard
|
|
71
79
|
image="https://example.com/game.jpg"
|
|
@@ -84,9 +92,17 @@ export default function GameCardCustomTrailing() {
|
|
|
84
92
|
title="Premium Bundle"
|
|
85
93
|
subtitle="Action • Adventure"
|
|
86
94
|
trailing={
|
|
87
|
-
<div style={{ textAlign:
|
|
95
|
+
<div style={{ textAlign: "right" }}>
|
|
88
96
|
<div style={{ fontSize: 14, fontWeight: 600 }}>$29.99</div>
|
|
89
|
-
<div
|
|
97
|
+
<div
|
|
98
|
+
style={{
|
|
99
|
+
fontSize: 11,
|
|
100
|
+
textDecoration: "line-through",
|
|
101
|
+
opacity: 0.6,
|
|
102
|
+
}}
|
|
103
|
+
>
|
|
104
|
+
$49.99
|
|
105
|
+
</div>
|
|
90
106
|
</div>
|
|
91
107
|
}
|
|
92
108
|
/>
|
|
@@ -96,7 +112,11 @@ export default function GameCardCustomTrailing() {
|
|
|
96
112
|
image="https://example.com/game.jpg"
|
|
97
113
|
title="Free to Play"
|
|
98
114
|
subtitle="Casual • Puzzle"
|
|
99
|
-
trailing={
|
|
115
|
+
trailing={
|
|
116
|
+
<Badge size="xl" tone="success">
|
|
117
|
+
FREE
|
|
118
|
+
</Badge>
|
|
119
|
+
}
|
|
100
120
|
/>
|
|
101
121
|
</div>
|
|
102
122
|
);
|
|
@@ -106,12 +126,12 @@ export default function GameCardCustomTrailing() {
|
|
|
106
126
|
### GameCard Sizes
|
|
107
127
|
|
|
108
128
|
```tsx
|
|
109
|
-
import * as React from
|
|
110
|
-
import { GameCard } from
|
|
129
|
+
import * as React from "react";
|
|
130
|
+
import { GameCard } from "@xsolla/xui-game-card";
|
|
111
131
|
|
|
112
132
|
export default function GameCardSizes() {
|
|
113
133
|
return (
|
|
114
|
-
<div style={{ display:
|
|
134
|
+
<div style={{ display: "flex", flexDirection: "column", gap: 24 }}>
|
|
115
135
|
<div style={{ maxWidth: 366 }}>
|
|
116
136
|
<p>Large (lg)</p>
|
|
117
137
|
<GameCard
|
|
@@ -152,20 +172,20 @@ export default function GameCardSizes() {
|
|
|
152
172
|
Import the component and use it directly:
|
|
153
173
|
|
|
154
174
|
```jsx
|
|
155
|
-
import { GameCard } from
|
|
175
|
+
import { GameCard } from "@xsolla/xui-game-card";
|
|
156
176
|
|
|
157
177
|
<GameCard
|
|
158
|
-
image="..."
|
|
159
|
-
title="Game Title"
|
|
160
|
-
subtitle="Genre"
|
|
161
|
-
size="lg"
|
|
162
|
-
tagsTopLeft={<Tag />}
|
|
163
|
-
tagsTopRight={<Tag />}
|
|
164
|
-
trailing={<Button />}
|
|
165
|
-
buttonText="Play"
|
|
178
|
+
image="..." // Required: Game artwork URL
|
|
179
|
+
title="Game Title" // Required: Game name
|
|
180
|
+
subtitle="Genre" // Optional: Categories/genre
|
|
181
|
+
size="lg" // Size variant
|
|
182
|
+
tagsTopLeft={<Tag />} // Custom top-left content
|
|
183
|
+
tagsTopRight={<Tag />} // Custom top-right content
|
|
184
|
+
trailing={<Button />} // Custom trailing content
|
|
185
|
+
buttonText="Play" // Default button text (if no trailing)
|
|
166
186
|
onButtonClick={() => {}} // Default button handler
|
|
167
|
-
onPress={() => {}}
|
|
168
|
-
|
|
187
|
+
onPress={() => {}} // Card press handler
|
|
188
|
+
/>;
|
|
169
189
|
```
|
|
170
190
|
|
|
171
191
|
## API Reference
|
|
@@ -176,28 +196,29 @@ A card component for displaying game promotions.
|
|
|
176
196
|
|
|
177
197
|
**GameCard Props:**
|
|
178
198
|
|
|
179
|
-
| Prop
|
|
180
|
-
|
|
|
181
|
-
|
|
|
182
|
-
|
|
|
183
|
-
|
|
|
184
|
-
|
|
|
185
|
-
|
|
|
186
|
-
|
|
|
187
|
-
|
|
|
188
|
-
|
|
|
189
|
-
|
|
|
190
|
-
|
|
|
191
|
-
|
|
|
192
|
-
|
|
|
199
|
+
| Prop | Type | Default | Description |
|
|
200
|
+
| :------------ | :--------------------- | :------- | :------------------------------------------------------------------------------------------------------------ |
|
|
201
|
+
| `testID` | `string` | — | Test ID for testing frameworks. On web this renders as `data-testid`; on React Native it renders as `testID`. |
|
|
202
|
+
| image | `string` | required | Game artwork image URL. |
|
|
203
|
+
| title | `string` | required | Game title. |
|
|
204
|
+
| subtitle | `string` | - | Game subtitle (e.g., genre tags). |
|
|
205
|
+
| size | `"lg" \| "md" \| "sm"` | `"lg"` | Size variant of the card. |
|
|
206
|
+
| tagsTopLeft | `ReactNode` | - | Custom content for top-left corner. |
|
|
207
|
+
| tagsTopRight | `ReactNode` | - | Custom content for top-right corner. |
|
|
208
|
+
| trailing | `ReactNode` | - | Custom trailing content (button, price, etc.). |
|
|
209
|
+
| buttonText | `string` | - | Button label text (if trailing not provided). |
|
|
210
|
+
| onButtonClick | `() => void` | - | Button click handler (if trailing not provided). |
|
|
211
|
+
| onPress | `() => void` | - | Card click handler. |
|
|
212
|
+
| imageAlt | `string` | - | Alt text for game image. |
|
|
213
|
+
| className | `string` | - | Custom className for the container. |
|
|
193
214
|
|
|
194
215
|
**Size Dimensions:**
|
|
195
216
|
|
|
196
217
|
| Size | Image Aspect Ratio | Reference Width |
|
|
197
218
|
| :--- | :----------------- | :-------------- |
|
|
198
|
-
| lg
|
|
199
|
-
| md
|
|
200
|
-
| sm
|
|
219
|
+
| lg | 366:206 (~16:9) | 366px |
|
|
220
|
+
| md | 280:158 (~16:9) | 280px |
|
|
221
|
+
| sm | 200:113 (~16:9) | 200px |
|
|
201
222
|
|
|
202
223
|
## Accessibility
|
|
203
224
|
|
package/native/index.d.mts
CHANGED
|
@@ -52,6 +52,8 @@ interface GameCardProps extends ThemeOverrideProps {
|
|
|
52
52
|
imageAlt?: string;
|
|
53
53
|
/** Custom className for the container */
|
|
54
54
|
className?: string;
|
|
55
|
+
/** Test ID for testing frameworks */
|
|
56
|
+
testID?: string;
|
|
55
57
|
}
|
|
56
58
|
|
|
57
59
|
declare const GameCard: React.FC<GameCardProps>;
|
package/native/index.d.ts
CHANGED
|
@@ -52,6 +52,8 @@ interface GameCardProps extends ThemeOverrideProps {
|
|
|
52
52
|
imageAlt?: string;
|
|
53
53
|
/** Custom className for the container */
|
|
54
54
|
className?: string;
|
|
55
|
+
/** Test ID for testing frameworks */
|
|
56
|
+
testID?: string;
|
|
55
57
|
}
|
|
56
58
|
|
|
57
59
|
declare const GameCard: React.FC<GameCardProps>;
|
package/native/index.js
CHANGED
|
@@ -238,6 +238,8 @@ var Text = ({
|
|
|
238
238
|
numberOfLines,
|
|
239
239
|
id,
|
|
240
240
|
role,
|
|
241
|
+
testID,
|
|
242
|
+
"data-testid": dataTestId,
|
|
241
243
|
style: styleProp,
|
|
242
244
|
...props
|
|
243
245
|
}) => {
|
|
@@ -267,7 +269,7 @@ var Text = ({
|
|
|
267
269
|
{
|
|
268
270
|
style: baseStyle,
|
|
269
271
|
numberOfLines,
|
|
270
|
-
testID: id,
|
|
272
|
+
testID: dataTestId || testID || id,
|
|
271
273
|
accessibilityRole,
|
|
272
274
|
children
|
|
273
275
|
}
|
|
@@ -458,6 +460,7 @@ var GameCard = ({
|
|
|
458
460
|
onPress,
|
|
459
461
|
imageAlt,
|
|
460
462
|
className,
|
|
463
|
+
testID,
|
|
461
464
|
themeMode,
|
|
462
465
|
themeProductContext
|
|
463
466
|
}) => {
|
|
@@ -706,6 +709,7 @@ var GameCard = ({
|
|
|
706
709
|
return /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
|
|
707
710
|
Box,
|
|
708
711
|
{
|
|
712
|
+
testID,
|
|
709
713
|
className,
|
|
710
714
|
flexDirection: "column",
|
|
711
715
|
width: "100%",
|
package/native/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.tsx","../../src/GameCard.tsx","../../../../foundation/primitives-native/src/Box.tsx","../../../../foundation/primitives-native/src/Text.tsx","../../../../foundation/primitives-native/src/LinearGradient.tsx","../../../../foundation/primitives-native/src/index.tsx"],"sourcesContent":["export * from \"./GameCard\";\nexport * from \"./types\";\n","import React, { useState } from \"react\";\n// @ts-expect-error - this will be resolved at build time\nimport { Box, Text, LinearGradient, isWeb } from \"@xsolla/xui-primitives\";\nimport { useResolvedTheme } from \"@xsolla/xui-core\";\nimport type {\n GameCardProps,\n GameCardSize,\n GameCardImageRatio,\n GameCardPlatform,\n GameCardLayout,\n} from \"./types\";\n\nconst IMAGE_RATIOS: Record<Exclude<GameCardImageRatio, \"custom\">, number> = {\n \"16:9\": 240 / 135,\n \"1:1\": 1,\n \"2:3\": 240 / 360,\n \"3:2\": 240 / 160,\n \"4:3\": 360 / 270,\n \"9:16\": 135 / 240,\n};\n\nconst BORDER_RADIUS = 8;\nconst TAG_INSET = 8;\nconst TAG_GAP = 4;\n\ninterface SizeConfig {\n titleFontSize: number;\n titleLineHeight: number;\n subtitleFontSize: number;\n subtitleLineHeight: number;\n}\n\nconst getSizeConfig = (\n size: GameCardSize,\n platform: GameCardPlatform\n): SizeConfig => {\n const isDesktop = platform === \"desktop\";\n switch (size) {\n case \"lg\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"md\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"sm\":\n return {\n titleFontSize: 12,\n titleLineHeight: 16,\n subtitleFontSize: 10,\n subtitleLineHeight: 14,\n };\n }\n};\n\nconst getFooterPadding = (platform: GameCardPlatform): number =>\n platform === \"desktop\" ? 16 : 12;\n\nconst getFooterGap = (): number => 12;\n\nconst resolveAspectRatio = (\n imageRatio: GameCardImageRatio,\n customWidth?: number,\n customHeight?: number\n): number => {\n if (imageRatio === \"custom\" && customWidth && customHeight) {\n return customWidth / customHeight;\n }\n return (\n IMAGE_RATIOS[imageRatio as Exclude<GameCardImageRatio, \"custom\">] ??\n IMAGE_RATIOS[\"16:9\"]\n );\n};\n\nconst ellipsisStyle = isWeb\n ? {\n overflow: \"hidden\" as const,\n textOverflow: \"ellipsis\" as const,\n whiteSpace: \"nowrap\" as const,\n }\n : undefined;\n\nexport const GameCard: React.FC<GameCardProps> = ({\n image,\n title,\n subtitle,\n size = \"lg\",\n imageRatio = \"16:9\",\n customImageWidth,\n customImageHeight,\n badge,\n tagsTopLeft,\n tagsTopRight,\n tagsBottomLeft,\n tagsBottomRight,\n trailing,\n buttonText,\n onButtonClick,\n buttonDisabled,\n layout = \"horizontal\",\n platform = \"mobile\",\n hideFooter = false,\n hoverContent,\n onPress,\n imageAlt,\n className,\n themeMode,\n themeProductContext,\n}) => {\n const { theme } = useResolvedTheme({ themeMode, themeProductContext });\n const config = getSizeConfig(size, platform);\n const footerPadding = getFooterPadding(platform);\n const footerGap = getFooterGap();\n const aspectRatio = resolveAspectRatio(\n imageRatio,\n customImageWidth,\n customImageHeight\n );\n\n const [isHovered, setIsHovered] = useState(false);\n\n const wrapperProps = onPress ? { onPress } : {};\n const hoverHandlers =\n isWeb && hoverContent\n ? {\n onMouseEnter: () => setIsHovered(true),\n onMouseLeave: () => setIsHovered(false),\n }\n : {};\n\n const isHorizontal = layout === \"horizontal\";\n\n const renderPlaceholder = () => (\n <Box\n width=\"100%\"\n height=\"100%\"\n backgroundColor={theme.colors.background.secondary}\n alignItems=\"center\"\n justifyContent=\"center\"\n >\n <Box\n width={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n height={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n alignItems=\"center\"\n justifyContent=\"center\"\n style={{ opacity: 0.4 }}\n >\n <Text\n color={theme.colors.content.tertiary}\n fontSize={24}\n style={{ textAlign: \"center\" as const }}\n >\n {\"\\u{1F5BC}\"}\n </Text>\n </Box>\n </Box>\n );\n\n const renderImage = () => (\n <Box\n position=\"relative\"\n width=\"100%\"\n overflow=\"hidden\"\n style={{ aspectRatio }}\n {...hoverHandlers}\n >\n {image ? (\n <>\n <Box\n as=\"img\"\n src={image}\n alt={imageAlt || title}\n position=\"absolute\"\n top={0}\n left={0}\n width=\"100%\"\n height=\"100%\"\n style={\n isWeb\n ? {\n objectFit: \"cover\" as const,\n pointerEvents: \"none\" as const,\n }\n : undefined\n }\n />\n <LinearGradient\n colors={[\"transparent\", \"rgba(0, 0, 0, 0.48)\"]}\n start={{ x: 0, y: 0 }}\n end={{ x: 0, y: 1 }}\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height=\"100%\"\n style={{ maxHeight: 206 }}\n />\n </>\n ) : (\n renderPlaceholder()\n )}\n\n {/* Tag zones */}\n {(badge || tagsTopLeft) && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {badge}\n {tagsTopLeft}\n </Box>\n )}\n\n {tagsTopRight && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsTopRight}\n </Box>\n )}\n\n {tagsBottomLeft && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {tagsBottomLeft}\n </Box>\n )}\n\n {tagsBottomRight && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsBottomRight}\n </Box>\n )}\n\n {/* Hover overlay */}\n {isWeb && hoverContent && isHovered && (\n <Box\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height={72}\n flexDirection=\"row\"\n alignItems=\"center\"\n gap={8}\n padding={16}\n borderRadius={4}\n overflow=\"hidden\"\n style={{\n backdropFilter: \"blur(15px)\",\n WebkitBackdropFilter: \"blur(15px)\",\n backgroundColor: theme.colors.layer.float,\n }}\n >\n {hoverContent}\n </Box>\n )}\n </Box>\n );\n\n const renderFooter = () => (\n <Box\n backgroundColor={theme.colors.overlay.mono}\n padding={footerPadding}\n flexDirection={isHorizontal ? \"row\" : \"column\"}\n alignItems={isHorizontal ? \"center\" : \"flex-start\"}\n justifyContent={isHorizontal ? undefined : \"center\"}\n gap={footerGap}\n >\n <Box\n flex={isHorizontal ? 1 : undefined}\n width={isHorizontal ? undefined : \"100%\"}\n flexDirection=\"column\"\n style={{ minWidth: 0 }}\n >\n <Text\n color={theme.colors.content.primary}\n fontSize={config.titleFontSize}\n lineHeight={config.titleLineHeight}\n fontWeight=\"500\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {title}\n </Text>\n {subtitle && (\n <Text\n color={theme.colors.content.tertiary}\n fontSize={config.subtitleFontSize}\n lineHeight={config.subtitleLineHeight}\n fontWeight=\"400\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {subtitle}\n </Text>\n )}\n </Box>\n\n {trailing}\n {!trailing && buttonText && (\n <Box\n onPress={buttonDisabled ? undefined : onButtonClick}\n backgroundColor={theme.colors.control.mono.secondary.bg}\n borderRadius={BORDER_RADIUS}\n height={40}\n paddingHorizontal={20}\n alignItems=\"center\"\n justifyContent=\"center\"\n style={\n isWeb\n ? {\n opacity: buttonDisabled ? 0.4 : 1,\n backdropFilter: \"blur(30px)\",\n WebkitBackdropFilter: \"blur(30px)\",\n border: `1px solid ${theme.colors.control.mono.secondary.border}`,\n cursor: buttonDisabled\n ? \"not-allowed\"\n : onButtonClick\n ? \"pointer\"\n : \"default\",\n }\n : { opacity: buttonDisabled ? 0.4 : 1 }\n }\n >\n <Text\n color={theme.colors.control.mono.text.secondary}\n fontSize={14}\n lineHeight={18}\n fontWeight=\"500\"\n style={{ letterSpacing: 0.4 }}\n >\n {buttonText}\n </Text>\n </Box>\n )}\n </Box>\n );\n\n return (\n <Box\n className={className}\n flexDirection=\"column\"\n width=\"100%\"\n {...wrapperProps}\n >\n <Box\n borderRadius={BORDER_RADIUS}\n overflow=\"hidden\"\n flexDirection=\"column\"\n style={\n isWeb\n ? {\n borderRadius: `${BORDER_RADIUS}px`,\n overflow: \"hidden\",\n border: `1px solid ${theme.colors.border.secondary}`,\n }\n : {\n borderRadius: BORDER_RADIUS,\n overflow: \"hidden\",\n borderWidth: 1,\n borderColor: theme.colors.border.secondary,\n }\n }\n >\n {renderImage()}\n {!hideFooter && renderFooter()}\n </Box>\n </Box>\n );\n};\n","import React from \"react\";\nimport {\n View,\n Pressable,\n Image,\n ViewStyle,\n ImageStyle,\n DimensionValue,\n AnimatableNumericValue,\n} from \"react-native\";\nimport { BoxProps } from \"@xsolla/xui-primitives-core\";\n\nexport const Box: React.FC<BoxProps> = ({\n children,\n onPress,\n onLayout,\n onMoveShouldSetResponder,\n onResponderGrant,\n onResponderMove,\n onResponderRelease,\n onResponderTerminate,\n backgroundColor,\n borderColor,\n borderWidth,\n borderBottomWidth,\n borderBottomColor,\n borderTopWidth,\n borderTopColor,\n borderLeftWidth,\n borderLeftColor,\n borderRightWidth,\n borderRightColor,\n borderRadius,\n borderStyle,\n height,\n padding,\n paddingHorizontal,\n paddingVertical,\n margin,\n marginTop,\n marginBottom,\n marginLeft,\n marginRight,\n flexDirection,\n alignItems,\n justifyContent,\n position,\n top,\n bottom,\n left,\n right,\n width,\n minWidth,\n minHeight,\n maxWidth,\n maxHeight,\n flex,\n overflow,\n zIndex,\n hoverStyle,\n pressStyle,\n style,\n \"data-testid\": dataTestId,\n testID,\n as,\n src,\n alt,\n ...rest\n}) => {\n const getContainerStyle = (pressed?: boolean): ViewStyle => ({\n backgroundColor:\n pressed && pressStyle?.backgroundColor\n ? pressStyle.backgroundColor\n : backgroundColor,\n borderColor,\n borderWidth,\n borderBottomWidth,\n borderBottomColor,\n borderTopWidth,\n borderTopColor,\n borderLeftWidth,\n borderLeftColor,\n borderRightWidth,\n borderRightColor,\n borderRadius: borderRadius as AnimatableNumericValue,\n borderStyle: borderStyle as ViewStyle[\"borderStyle\"],\n overflow,\n zIndex,\n height: height as DimensionValue,\n width: width as DimensionValue,\n minWidth: minWidth as DimensionValue,\n minHeight: minHeight as DimensionValue,\n maxWidth: maxWidth as DimensionValue,\n maxHeight: maxHeight as DimensionValue,\n padding: padding as DimensionValue,\n paddingHorizontal: paddingHorizontal as DimensionValue,\n paddingVertical: paddingVertical as DimensionValue,\n margin: margin as DimensionValue,\n marginTop: marginTop as DimensionValue,\n marginBottom: marginBottom as DimensionValue,\n marginLeft: marginLeft as DimensionValue,\n marginRight: marginRight as DimensionValue,\n flexDirection,\n alignItems,\n justifyContent,\n position: position as ViewStyle[\"position\"],\n top: top as DimensionValue,\n bottom: bottom as DimensionValue,\n left: left as DimensionValue,\n right: right as DimensionValue,\n flex,\n ...(style as ViewStyle),\n });\n\n const finalTestID = dataTestId || testID;\n\n // Destructure and drop web-only props from rest before passing to RN components\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const {\n role,\n tabIndex,\n onKeyDown,\n onKeyUp,\n \"aria-label\": _ariaLabel,\n \"aria-labelledby\": _ariaLabelledBy,\n \"aria-current\": _ariaCurrent,\n \"aria-disabled\": _ariaDisabled,\n \"aria-live\": _ariaLive,\n className,\n \"data-testid\": _dataTestId,\n ...nativeRest\n } = rest as Record<string, unknown>;\n\n // Handle as=\"img\" for React Native\n if (as === \"img\" && src) {\n const imageStyle: ImageStyle = {\n width: width as DimensionValue,\n height: height as DimensionValue,\n borderRadius: borderRadius as number,\n position: position as ImageStyle[\"position\"],\n top: top as DimensionValue,\n bottom: bottom as DimensionValue,\n left: left as DimensionValue,\n right: right as DimensionValue,\n ...(style as ImageStyle),\n };\n\n return (\n <Image\n source={{ uri: src }}\n style={imageStyle}\n testID={finalTestID}\n resizeMode=\"cover\"\n {...nativeRest}\n />\n );\n }\n\n if (onPress) {\n return (\n <Pressable\n onPress={onPress}\n onLayout={onLayout}\n onMoveShouldSetResponder={onMoveShouldSetResponder}\n onResponderGrant={onResponderGrant}\n onResponderMove={onResponderMove}\n onResponderRelease={onResponderRelease}\n onResponderTerminate={onResponderTerminate}\n style={({ pressed }) => getContainerStyle(pressed)}\n testID={finalTestID}\n {...nativeRest}\n >\n {children}\n </Pressable>\n );\n }\n\n return (\n <View\n style={getContainerStyle()}\n testID={finalTestID}\n onLayout={onLayout}\n onMoveShouldSetResponder={onMoveShouldSetResponder}\n onResponderGrant={onResponderGrant}\n onResponderMove={onResponderMove}\n onResponderRelease={onResponderRelease}\n onResponderTerminate={onResponderTerminate}\n {...nativeRest}\n >\n {children}\n </View>\n );\n};\n","import React from \"react\";\nimport {\n Text as RNText,\n TextStyle,\n AccessibilityRole,\n StyleSheet,\n} from \"react-native\";\nimport { TextProps } from \"@xsolla/xui-primitives-core\";\n\nconst roleMap: Record<string, AccessibilityRole> = {\n alert: \"alert\",\n heading: \"header\",\n button: \"button\",\n link: \"link\",\n text: \"text\",\n};\n\nconst parseNumericValue = (\n value: string | number | undefined\n): number | undefined => {\n if (value === undefined) return undefined;\n if (typeof value === \"number\") return value;\n const parsed = parseFloat(value);\n return isNaN(parsed) ? undefined : parsed;\n};\n\nexport const Text: React.FC<TextProps> = ({\n children,\n color,\n fontSize,\n fontWeight,\n fontFamily,\n textAlign,\n lineHeight,\n numberOfLines,\n id,\n role,\n style: styleProp,\n ...props\n}) => {\n let resolvedFontFamily = fontFamily\n ? fontFamily.split(\",\")[0].replace(/['\"]/g, \"\").trim()\n : undefined;\n\n if (\n resolvedFontFamily === \"Pilat Wide\" ||\n resolvedFontFamily === \"Pilat Wide Bold\" ||\n resolvedFontFamily === \"Aktiv Grotesk\"\n ) {\n resolvedFontFamily = undefined;\n }\n\n const incomingStyle = StyleSheet.flatten(styleProp) as TextStyle | undefined;\n\n const baseStyle: TextStyle = {\n color: color ?? incomingStyle?.color,\n fontSize: typeof fontSize === \"number\" ? fontSize : undefined,\n fontWeight: fontWeight as TextStyle[\"fontWeight\"],\n fontFamily: resolvedFontFamily,\n textDecorationLine: props.textDecoration as TextStyle[\"textDecorationLine\"],\n textAlign: textAlign ?? incomingStyle?.textAlign,\n lineHeight: parseNumericValue(lineHeight ?? incomingStyle?.lineHeight),\n marginTop: parseNumericValue(\n incomingStyle?.marginTop as number | string | undefined\n ),\n marginBottom: parseNumericValue(\n incomingStyle?.marginBottom as number | string | undefined\n ),\n };\n\n const accessibilityRole = role ? roleMap[role] : undefined;\n\n return (\n <RNText\n style={baseStyle}\n numberOfLines={numberOfLines}\n testID={id}\n accessibilityRole={accessibilityRole}\n >\n {children}\n </RNText>\n );\n};\n","import React, { useRef } from \"react\";\nimport { View, ViewStyle, DimensionValue } from \"react-native\";\nimport Svg, {\n Defs,\n LinearGradient as SvgLinearGradient,\n Stop,\n Rect,\n} from \"react-native-svg\";\nimport { LinearGradientProps } from \"@xsolla/xui-primitives-core\";\n\nlet gradientIdCounter = 0;\n\nfunction parseColor(color: string): { stopColor: string; stopOpacity: number } {\n if (color === \"transparent\") {\n return { stopColor: \"#000000\", stopOpacity: 0 };\n }\n\n const rgbaMatch = color.match(\n /^rgba?\\(\\s*([\\d.]+%?)\\s*,\\s*([\\d.]+%?)\\s*,\\s*([\\d.]+%?)\\s*,\\s*([\\d.]+)\\s*\\)$/i\n );\n if (rgbaMatch) {\n return {\n stopColor: `rgb(${rgbaMatch[1]}, ${rgbaMatch[2]}, ${rgbaMatch[3]})`,\n stopOpacity: parseFloat(rgbaMatch[4]),\n };\n }\n\n return { stopColor: color, stopOpacity: 1 };\n}\n\nexport const LinearGradient: React.FC<LinearGradientProps> = ({\n colors,\n start = { x: 0, y: 0 },\n end = { x: 0, y: 1 },\n locations,\n children,\n position,\n top,\n bottom,\n left,\n right,\n width,\n height,\n borderRadius,\n overflow,\n zIndex,\n style,\n testID,\n \"data-testid\": dataTestId,\n}) => {\n const containerStyle: ViewStyle = {\n position: position as ViewStyle[\"position\"],\n top: top as DimensionValue,\n bottom: bottom as DimensionValue,\n left: left as DimensionValue,\n right: right as DimensionValue,\n width: width as DimensionValue,\n height: height as DimensionValue,\n borderRadius: typeof borderRadius === \"number\" ? borderRadius : undefined,\n overflow,\n zIndex,\n ...(style as ViewStyle),\n };\n\n const gradientId = useRef(`xui-lg-${++gradientIdCounter}`).current;\n\n const stops = colors.map((color, index) => {\n const offset = locations ? locations[index] : index / (colors.length - 1);\n const { stopColor, stopOpacity } = parseColor(color);\n return (\n <Stop\n key={index}\n offset={offset}\n stopColor={stopColor}\n stopOpacity={stopOpacity}\n />\n );\n });\n\n return (\n <View style={containerStyle} testID={dataTestId || testID}>\n <Svg\n style={{ position: \"absolute\", top: 0, left: 0, right: 0, bottom: 0 }}\n width=\"100%\"\n height=\"100%\"\n >\n <Defs>\n <SvgLinearGradient\n id={gradientId}\n x1={`${start.x * 100}%`}\n y1={`${start.y * 100}%`}\n x2={`${end.x * 100}%`}\n y2={`${end.y * 100}%`}\n >\n {stops}\n </SvgLinearGradient>\n </Defs>\n <Rect\n x=\"0\"\n y=\"0\"\n width=\"100%\"\n height=\"100%\"\n fill={`url(#${gradientId})`}\n />\n </Svg>\n {children}\n </View>\n );\n};\n","export * from \"./Box\";\nexport * from \"./Text\";\nexport * from \"./Spinner\";\nexport * from \"./Icon\";\nexport * from \"./Divider\";\nexport * from \"./Input\";\nexport * from \"./TextArea\";\nexport * from \"./LinearGradient\";\n\nexport const isWeb = false;\nexport const isNative = true;\n"],"mappings":"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","names":["import_react","import_react_native","import_jsx_runtime","RNText","import_react_native","import_jsx_runtime","Svg","SvgLinearGradient","import_jsx_runtime"]}
|
|
1
|
+
{"version":3,"sources":["../../src/index.tsx","../../src/GameCard.tsx","../../../../foundation/primitives-native/src/Box.tsx","../../../../foundation/primitives-native/src/Text.tsx","../../../../foundation/primitives-native/src/LinearGradient.tsx","../../../../foundation/primitives-native/src/index.tsx"],"sourcesContent":["export * from \"./GameCard\";\nexport * from \"./types\";\n","import React, { useState } from \"react\";\n// @ts-expect-error - this will be resolved at build time\nimport { Box, Text, LinearGradient, isWeb } from \"@xsolla/xui-primitives\";\nimport { useResolvedTheme } from \"@xsolla/xui-core\";\nimport type {\n GameCardProps,\n GameCardSize,\n GameCardImageRatio,\n GameCardPlatform,\n GameCardLayout,\n} from \"./types\";\n\nconst IMAGE_RATIOS: Record<Exclude<GameCardImageRatio, \"custom\">, number> = {\n \"16:9\": 240 / 135,\n \"1:1\": 1,\n \"2:3\": 240 / 360,\n \"3:2\": 240 / 160,\n \"4:3\": 360 / 270,\n \"9:16\": 135 / 240,\n};\n\nconst BORDER_RADIUS = 8;\nconst TAG_INSET = 8;\nconst TAG_GAP = 4;\n\ninterface SizeConfig {\n titleFontSize: number;\n titleLineHeight: number;\n subtitleFontSize: number;\n subtitleLineHeight: number;\n}\n\nconst getSizeConfig = (\n size: GameCardSize,\n platform: GameCardPlatform\n): SizeConfig => {\n const isDesktop = platform === \"desktop\";\n switch (size) {\n case \"lg\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"md\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"sm\":\n return {\n titleFontSize: 12,\n titleLineHeight: 16,\n subtitleFontSize: 10,\n subtitleLineHeight: 14,\n };\n }\n};\n\nconst getFooterPadding = (platform: GameCardPlatform): number =>\n platform === \"desktop\" ? 16 : 12;\n\nconst getFooterGap = (): number => 12;\n\nconst resolveAspectRatio = (\n imageRatio: GameCardImageRatio,\n customWidth?: number,\n customHeight?: number\n): number => {\n if (imageRatio === \"custom\" && customWidth && customHeight) {\n return customWidth / customHeight;\n }\n return (\n IMAGE_RATIOS[imageRatio as Exclude<GameCardImageRatio, \"custom\">] ??\n IMAGE_RATIOS[\"16:9\"]\n );\n};\n\nconst ellipsisStyle = isWeb\n ? {\n overflow: \"hidden\" as const,\n textOverflow: \"ellipsis\" as const,\n whiteSpace: \"nowrap\" as const,\n }\n : undefined;\n\nexport const GameCard: React.FC<GameCardProps> = ({\n image,\n title,\n subtitle,\n size = \"lg\",\n imageRatio = \"16:9\",\n customImageWidth,\n customImageHeight,\n badge,\n tagsTopLeft,\n tagsTopRight,\n tagsBottomLeft,\n tagsBottomRight,\n trailing,\n buttonText,\n onButtonClick,\n buttonDisabled,\n layout = \"horizontal\",\n platform = \"mobile\",\n hideFooter = false,\n hoverContent,\n onPress,\n imageAlt,\n className,\n testID,\n themeMode,\n themeProductContext,\n}) => {\n const { theme } = useResolvedTheme({ themeMode, themeProductContext });\n const config = getSizeConfig(size, platform);\n const footerPadding = getFooterPadding(platform);\n const footerGap = getFooterGap();\n const aspectRatio = resolveAspectRatio(\n imageRatio,\n customImageWidth,\n customImageHeight\n );\n\n const [isHovered, setIsHovered] = useState(false);\n\n const wrapperProps = onPress ? { onPress } : {};\n const hoverHandlers =\n isWeb && hoverContent\n ? {\n onMouseEnter: () => setIsHovered(true),\n onMouseLeave: () => setIsHovered(false),\n }\n : {};\n\n const isHorizontal = layout === \"horizontal\";\n\n const renderPlaceholder = () => (\n <Box\n width=\"100%\"\n height=\"100%\"\n backgroundColor={theme.colors.background.secondary}\n alignItems=\"center\"\n justifyContent=\"center\"\n >\n <Box\n width={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n height={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n alignItems=\"center\"\n justifyContent=\"center\"\n style={{ opacity: 0.4 }}\n >\n <Text\n color={theme.colors.content.tertiary}\n fontSize={24}\n style={{ textAlign: \"center\" as const }}\n >\n {\"\\u{1F5BC}\"}\n </Text>\n </Box>\n </Box>\n );\n\n const renderImage = () => (\n <Box\n position=\"relative\"\n width=\"100%\"\n overflow=\"hidden\"\n style={{ aspectRatio }}\n {...hoverHandlers}\n >\n {image ? (\n <>\n <Box\n as=\"img\"\n src={image}\n alt={imageAlt || title}\n position=\"absolute\"\n top={0}\n left={0}\n width=\"100%\"\n height=\"100%\"\n style={\n isWeb\n ? {\n objectFit: \"cover\" as const,\n pointerEvents: \"none\" as const,\n }\n : undefined\n }\n />\n <LinearGradient\n colors={[\"transparent\", \"rgba(0, 0, 0, 0.48)\"]}\n start={{ x: 0, y: 0 }}\n end={{ x: 0, y: 1 }}\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height=\"100%\"\n style={{ maxHeight: 206 }}\n />\n </>\n ) : (\n renderPlaceholder()\n )}\n\n {/* Tag zones */}\n {(badge || tagsTopLeft) && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {badge}\n {tagsTopLeft}\n </Box>\n )}\n\n {tagsTopRight && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsTopRight}\n </Box>\n )}\n\n {tagsBottomLeft && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {tagsBottomLeft}\n </Box>\n )}\n\n {tagsBottomRight && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsBottomRight}\n </Box>\n )}\n\n {/* Hover overlay */}\n {isWeb && hoverContent && isHovered && (\n <Box\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height={72}\n flexDirection=\"row\"\n alignItems=\"center\"\n gap={8}\n padding={16}\n borderRadius={4}\n overflow=\"hidden\"\n style={{\n backdropFilter: \"blur(15px)\",\n WebkitBackdropFilter: \"blur(15px)\",\n backgroundColor: theme.colors.layer.float,\n }}\n >\n {hoverContent}\n </Box>\n )}\n </Box>\n );\n\n const renderFooter = () => (\n <Box\n backgroundColor={theme.colors.overlay.mono}\n padding={footerPadding}\n flexDirection={isHorizontal ? \"row\" : \"column\"}\n alignItems={isHorizontal ? \"center\" : \"flex-start\"}\n justifyContent={isHorizontal ? undefined : \"center\"}\n gap={footerGap}\n >\n <Box\n flex={isHorizontal ? 1 : undefined}\n width={isHorizontal ? undefined : \"100%\"}\n flexDirection=\"column\"\n style={{ minWidth: 0 }}\n >\n <Text\n color={theme.colors.content.primary}\n fontSize={config.titleFontSize}\n lineHeight={config.titleLineHeight}\n fontWeight=\"500\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {title}\n </Text>\n {subtitle && (\n <Text\n color={theme.colors.content.tertiary}\n fontSize={config.subtitleFontSize}\n lineHeight={config.subtitleLineHeight}\n fontWeight=\"400\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {subtitle}\n </Text>\n )}\n </Box>\n\n {trailing}\n {!trailing && buttonText && (\n <Box\n onPress={buttonDisabled ? undefined : onButtonClick}\n backgroundColor={theme.colors.control.mono.secondary.bg}\n borderRadius={BORDER_RADIUS}\n height={40}\n paddingHorizontal={20}\n alignItems=\"center\"\n justifyContent=\"center\"\n style={\n isWeb\n ? {\n opacity: buttonDisabled ? 0.4 : 1,\n backdropFilter: \"blur(30px)\",\n WebkitBackdropFilter: \"blur(30px)\",\n border: `1px solid ${theme.colors.control.mono.secondary.border}`,\n cursor: buttonDisabled\n ? \"not-allowed\"\n : onButtonClick\n ? \"pointer\"\n : \"default\",\n }\n : { opacity: buttonDisabled ? 0.4 : 1 }\n }\n >\n <Text\n color={theme.colors.control.mono.text.secondary}\n fontSize={14}\n lineHeight={18}\n fontWeight=\"500\"\n style={{ letterSpacing: 0.4 }}\n >\n {buttonText}\n </Text>\n </Box>\n )}\n </Box>\n );\n\n return (\n <Box\n testID={testID}\n className={className}\n flexDirection=\"column\"\n width=\"100%\"\n {...wrapperProps}\n >\n <Box\n borderRadius={BORDER_RADIUS}\n overflow=\"hidden\"\n flexDirection=\"column\"\n style={\n isWeb\n ? {\n borderRadius: `${BORDER_RADIUS}px`,\n overflow: \"hidden\",\n border: `1px solid ${theme.colors.border.secondary}`,\n }\n : {\n borderRadius: BORDER_RADIUS,\n overflow: \"hidden\",\n borderWidth: 1,\n borderColor: theme.colors.border.secondary,\n }\n }\n >\n {renderImage()}\n {!hideFooter && renderFooter()}\n </Box>\n </Box>\n );\n};\n","import React from \"react\";\nimport {\n View,\n Pressable,\n Image,\n ViewStyle,\n ImageStyle,\n DimensionValue,\n AnimatableNumericValue,\n} from \"react-native\";\nimport { BoxProps } from \"@xsolla/xui-primitives-core\";\n\nexport const Box: React.FC<BoxProps> = ({\n children,\n onPress,\n onLayout,\n onMoveShouldSetResponder,\n onResponderGrant,\n onResponderMove,\n onResponderRelease,\n onResponderTerminate,\n backgroundColor,\n borderColor,\n borderWidth,\n borderBottomWidth,\n borderBottomColor,\n borderTopWidth,\n borderTopColor,\n borderLeftWidth,\n borderLeftColor,\n borderRightWidth,\n borderRightColor,\n borderRadius,\n borderStyle,\n height,\n padding,\n paddingHorizontal,\n paddingVertical,\n margin,\n marginTop,\n marginBottom,\n marginLeft,\n marginRight,\n flexDirection,\n alignItems,\n justifyContent,\n position,\n top,\n bottom,\n left,\n right,\n width,\n minWidth,\n minHeight,\n maxWidth,\n maxHeight,\n flex,\n overflow,\n zIndex,\n hoverStyle,\n pressStyle,\n style,\n \"data-testid\": dataTestId,\n testID,\n as,\n src,\n alt,\n ...rest\n}) => {\n const getContainerStyle = (pressed?: boolean): ViewStyle => ({\n backgroundColor:\n pressed && pressStyle?.backgroundColor\n ? pressStyle.backgroundColor\n : backgroundColor,\n borderColor,\n borderWidth,\n borderBottomWidth,\n borderBottomColor,\n borderTopWidth,\n borderTopColor,\n borderLeftWidth,\n borderLeftColor,\n borderRightWidth,\n borderRightColor,\n borderRadius: borderRadius as AnimatableNumericValue,\n borderStyle: borderStyle as ViewStyle[\"borderStyle\"],\n overflow,\n zIndex,\n height: height as DimensionValue,\n width: width as DimensionValue,\n minWidth: minWidth as DimensionValue,\n minHeight: minHeight as DimensionValue,\n maxWidth: maxWidth as DimensionValue,\n maxHeight: maxHeight as DimensionValue,\n padding: padding as DimensionValue,\n paddingHorizontal: paddingHorizontal as DimensionValue,\n paddingVertical: paddingVertical as DimensionValue,\n margin: margin as DimensionValue,\n marginTop: marginTop as DimensionValue,\n marginBottom: marginBottom as DimensionValue,\n marginLeft: marginLeft as DimensionValue,\n marginRight: marginRight as DimensionValue,\n flexDirection,\n alignItems,\n justifyContent,\n position: position as ViewStyle[\"position\"],\n top: top as DimensionValue,\n bottom: bottom as DimensionValue,\n left: left as DimensionValue,\n right: right as DimensionValue,\n flex,\n ...(style as ViewStyle),\n });\n\n const finalTestID = dataTestId || testID;\n\n // Destructure and drop web-only props from rest before passing to RN components\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const {\n role,\n tabIndex,\n onKeyDown,\n onKeyUp,\n \"aria-label\": _ariaLabel,\n \"aria-labelledby\": _ariaLabelledBy,\n \"aria-current\": _ariaCurrent,\n \"aria-disabled\": _ariaDisabled,\n \"aria-live\": _ariaLive,\n className,\n \"data-testid\": _dataTestId,\n ...nativeRest\n } = rest as Record<string, unknown>;\n\n // Handle as=\"img\" for React Native\n if (as === \"img\" && src) {\n const imageStyle: ImageStyle = {\n width: width as DimensionValue,\n height: height as DimensionValue,\n borderRadius: borderRadius as number,\n position: position as ImageStyle[\"position\"],\n top: top as DimensionValue,\n bottom: bottom as DimensionValue,\n left: left as DimensionValue,\n right: right as DimensionValue,\n ...(style as ImageStyle),\n };\n\n return (\n <Image\n source={{ uri: src }}\n style={imageStyle}\n testID={finalTestID}\n resizeMode=\"cover\"\n {...nativeRest}\n />\n );\n }\n\n if (onPress) {\n return (\n <Pressable\n onPress={onPress}\n onLayout={onLayout}\n onMoveShouldSetResponder={onMoveShouldSetResponder}\n onResponderGrant={onResponderGrant}\n onResponderMove={onResponderMove}\n onResponderRelease={onResponderRelease}\n onResponderTerminate={onResponderTerminate}\n style={({ pressed }) => getContainerStyle(pressed)}\n testID={finalTestID}\n {...nativeRest}\n >\n {children}\n </Pressable>\n );\n }\n\n return (\n <View\n style={getContainerStyle()}\n testID={finalTestID}\n onLayout={onLayout}\n onMoveShouldSetResponder={onMoveShouldSetResponder}\n onResponderGrant={onResponderGrant}\n onResponderMove={onResponderMove}\n onResponderRelease={onResponderRelease}\n onResponderTerminate={onResponderTerminate}\n {...nativeRest}\n >\n {children}\n </View>\n );\n};\n","import React from \"react\";\nimport {\n Text as RNText,\n TextStyle,\n AccessibilityRole,\n StyleSheet,\n} from \"react-native\";\nimport { TextProps } from \"@xsolla/xui-primitives-core\";\n\nconst roleMap: Record<string, AccessibilityRole> = {\n alert: \"alert\",\n heading: \"header\",\n button: \"button\",\n link: \"link\",\n text: \"text\",\n};\n\nconst parseNumericValue = (\n value: string | number | undefined\n): number | undefined => {\n if (value === undefined) return undefined;\n if (typeof value === \"number\") return value;\n const parsed = parseFloat(value);\n return isNaN(parsed) ? undefined : parsed;\n};\n\nexport const Text: React.FC<TextProps> = ({\n children,\n color,\n fontSize,\n fontWeight,\n fontFamily,\n textAlign,\n lineHeight,\n numberOfLines,\n id,\n role,\n testID,\n \"data-testid\": dataTestId,\n style: styleProp,\n ...props\n}) => {\n let resolvedFontFamily = fontFamily\n ? fontFamily.split(\",\")[0].replace(/['\"]/g, \"\").trim()\n : undefined;\n\n if (\n resolvedFontFamily === \"Pilat Wide\" ||\n resolvedFontFamily === \"Pilat Wide Bold\" ||\n resolvedFontFamily === \"Aktiv Grotesk\"\n ) {\n resolvedFontFamily = undefined;\n }\n\n const incomingStyle = StyleSheet.flatten(styleProp) as TextStyle | undefined;\n\n const baseStyle: TextStyle = {\n color: color ?? incomingStyle?.color,\n fontSize: typeof fontSize === \"number\" ? fontSize : undefined,\n fontWeight: fontWeight as TextStyle[\"fontWeight\"],\n fontFamily: resolvedFontFamily,\n textDecorationLine: props.textDecoration as TextStyle[\"textDecorationLine\"],\n textAlign: textAlign ?? incomingStyle?.textAlign,\n lineHeight: parseNumericValue(lineHeight ?? incomingStyle?.lineHeight),\n marginTop: parseNumericValue(\n incomingStyle?.marginTop as number | string | undefined\n ),\n marginBottom: parseNumericValue(\n incomingStyle?.marginBottom as number | string | undefined\n ),\n };\n\n const accessibilityRole = role ? roleMap[role] : undefined;\n\n return (\n <RNText\n style={baseStyle}\n numberOfLines={numberOfLines}\n testID={dataTestId || testID || id}\n accessibilityRole={accessibilityRole}\n >\n {children}\n </RNText>\n );\n};\n","import React, { useRef } from \"react\";\nimport { View, ViewStyle, DimensionValue } from \"react-native\";\nimport Svg, {\n Defs,\n LinearGradient as SvgLinearGradient,\n Stop,\n Rect,\n} from \"react-native-svg\";\nimport { LinearGradientProps } from \"@xsolla/xui-primitives-core\";\n\nlet gradientIdCounter = 0;\n\nfunction parseColor(color: string): { stopColor: string; stopOpacity: number } {\n if (color === \"transparent\") {\n return { stopColor: \"#000000\", stopOpacity: 0 };\n }\n\n const rgbaMatch = color.match(\n /^rgba?\\(\\s*([\\d.]+%?)\\s*,\\s*([\\d.]+%?)\\s*,\\s*([\\d.]+%?)\\s*,\\s*([\\d.]+)\\s*\\)$/i\n );\n if (rgbaMatch) {\n return {\n stopColor: `rgb(${rgbaMatch[1]}, ${rgbaMatch[2]}, ${rgbaMatch[3]})`,\n stopOpacity: parseFloat(rgbaMatch[4]),\n };\n }\n\n return { stopColor: color, stopOpacity: 1 };\n}\n\nexport const LinearGradient: React.FC<LinearGradientProps> = ({\n colors,\n start = { x: 0, y: 0 },\n end = { x: 0, y: 1 },\n locations,\n children,\n position,\n top,\n bottom,\n left,\n right,\n width,\n height,\n borderRadius,\n overflow,\n zIndex,\n style,\n testID,\n \"data-testid\": dataTestId,\n}) => {\n const containerStyle: ViewStyle = {\n position: position as ViewStyle[\"position\"],\n top: top as DimensionValue,\n bottom: bottom as DimensionValue,\n left: left as DimensionValue,\n right: right as DimensionValue,\n width: width as DimensionValue,\n height: height as DimensionValue,\n borderRadius: typeof borderRadius === \"number\" ? borderRadius : undefined,\n overflow,\n zIndex,\n ...(style as ViewStyle),\n };\n\n const gradientId = useRef(`xui-lg-${++gradientIdCounter}`).current;\n\n const stops = colors.map((color, index) => {\n const offset = locations ? locations[index] : index / (colors.length - 1);\n const { stopColor, stopOpacity } = parseColor(color);\n return (\n <Stop\n key={index}\n offset={offset}\n stopColor={stopColor}\n stopOpacity={stopOpacity}\n />\n );\n });\n\n return (\n <View style={containerStyle} testID={dataTestId || testID}>\n <Svg\n style={{ position: \"absolute\", top: 0, left: 0, right: 0, bottom: 0 }}\n width=\"100%\"\n height=\"100%\"\n >\n <Defs>\n <SvgLinearGradient\n id={gradientId}\n x1={`${start.x * 100}%`}\n y1={`${start.y * 100}%`}\n x2={`${end.x * 100}%`}\n y2={`${end.y * 100}%`}\n >\n {stops}\n </SvgLinearGradient>\n </Defs>\n <Rect\n x=\"0\"\n y=\"0\"\n width=\"100%\"\n height=\"100%\"\n fill={`url(#${gradientId})`}\n />\n </Svg>\n {children}\n </View>\n );\n};\n","export * from \"./Box\";\nexport * from \"./Text\";\nexport * from \"./Spinner\";\nexport * from \"./Icon\";\nexport * from \"./Divider\";\nexport * from \"./Input\";\nexport * from \"./TextArea\";\nexport * from \"./LinearGradient\";\n\nexport const isWeb = false;\nexport const isNative = true;\n"],"mappings":"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","names":["import_react","import_react_native","import_jsx_runtime","RNText","import_react_native","import_jsx_runtime","Svg","SvgLinearGradient","import_jsx_runtime"]}
|
package/native/index.mjs
CHANGED
|
@@ -209,6 +209,8 @@ var Text = ({
|
|
|
209
209
|
numberOfLines,
|
|
210
210
|
id,
|
|
211
211
|
role,
|
|
212
|
+
testID,
|
|
213
|
+
"data-testid": dataTestId,
|
|
212
214
|
style: styleProp,
|
|
213
215
|
...props
|
|
214
216
|
}) => {
|
|
@@ -238,7 +240,7 @@ var Text = ({
|
|
|
238
240
|
{
|
|
239
241
|
style: baseStyle,
|
|
240
242
|
numberOfLines,
|
|
241
|
-
testID: id,
|
|
243
|
+
testID: dataTestId || testID || id,
|
|
242
244
|
accessibilityRole,
|
|
243
245
|
children
|
|
244
246
|
}
|
|
@@ -434,6 +436,7 @@ var GameCard = ({
|
|
|
434
436
|
onPress,
|
|
435
437
|
imageAlt,
|
|
436
438
|
className,
|
|
439
|
+
testID,
|
|
437
440
|
themeMode,
|
|
438
441
|
themeProductContext
|
|
439
442
|
}) => {
|
|
@@ -682,6 +685,7 @@ var GameCard = ({
|
|
|
682
685
|
return /* @__PURE__ */ jsx4(
|
|
683
686
|
Box,
|
|
684
687
|
{
|
|
688
|
+
testID,
|
|
685
689
|
className,
|
|
686
690
|
flexDirection: "column",
|
|
687
691
|
width: "100%",
|
package/native/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/GameCard.tsx","../../../../foundation/primitives-native/src/Box.tsx","../../../../foundation/primitives-native/src/Text.tsx","../../../../foundation/primitives-native/src/LinearGradient.tsx","../../../../foundation/primitives-native/src/index.tsx"],"sourcesContent":["import React, { useState } from \"react\";\n// @ts-expect-error - this will be resolved at build time\nimport { Box, Text, LinearGradient, isWeb } from \"@xsolla/xui-primitives\";\nimport { useResolvedTheme } from \"@xsolla/xui-core\";\nimport type {\n GameCardProps,\n GameCardSize,\n GameCardImageRatio,\n GameCardPlatform,\n GameCardLayout,\n} from \"./types\";\n\nconst IMAGE_RATIOS: Record<Exclude<GameCardImageRatio, \"custom\">, number> = {\n \"16:9\": 240 / 135,\n \"1:1\": 1,\n \"2:3\": 240 / 360,\n \"3:2\": 240 / 160,\n \"4:3\": 360 / 270,\n \"9:16\": 135 / 240,\n};\n\nconst BORDER_RADIUS = 8;\nconst TAG_INSET = 8;\nconst TAG_GAP = 4;\n\ninterface SizeConfig {\n titleFontSize: number;\n titleLineHeight: number;\n subtitleFontSize: number;\n subtitleLineHeight: number;\n}\n\nconst getSizeConfig = (\n size: GameCardSize,\n platform: GameCardPlatform\n): SizeConfig => {\n const isDesktop = platform === \"desktop\";\n switch (size) {\n case \"lg\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"md\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"sm\":\n return {\n titleFontSize: 12,\n titleLineHeight: 16,\n subtitleFontSize: 10,\n subtitleLineHeight: 14,\n };\n }\n};\n\nconst getFooterPadding = (platform: GameCardPlatform): number =>\n platform === \"desktop\" ? 16 : 12;\n\nconst getFooterGap = (): number => 12;\n\nconst resolveAspectRatio = (\n imageRatio: GameCardImageRatio,\n customWidth?: number,\n customHeight?: number\n): number => {\n if (imageRatio === \"custom\" && customWidth && customHeight) {\n return customWidth / customHeight;\n }\n return (\n IMAGE_RATIOS[imageRatio as Exclude<GameCardImageRatio, \"custom\">] ??\n IMAGE_RATIOS[\"16:9\"]\n );\n};\n\nconst ellipsisStyle = isWeb\n ? {\n overflow: \"hidden\" as const,\n textOverflow: \"ellipsis\" as const,\n whiteSpace: \"nowrap\" as const,\n }\n : undefined;\n\nexport const GameCard: React.FC<GameCardProps> = ({\n image,\n title,\n subtitle,\n size = \"lg\",\n imageRatio = \"16:9\",\n customImageWidth,\n customImageHeight,\n badge,\n tagsTopLeft,\n tagsTopRight,\n tagsBottomLeft,\n tagsBottomRight,\n trailing,\n buttonText,\n onButtonClick,\n buttonDisabled,\n layout = \"horizontal\",\n platform = \"mobile\",\n hideFooter = false,\n hoverContent,\n onPress,\n imageAlt,\n className,\n themeMode,\n themeProductContext,\n}) => {\n const { theme } = useResolvedTheme({ themeMode, themeProductContext });\n const config = getSizeConfig(size, platform);\n const footerPadding = getFooterPadding(platform);\n const footerGap = getFooterGap();\n const aspectRatio = resolveAspectRatio(\n imageRatio,\n customImageWidth,\n customImageHeight\n );\n\n const [isHovered, setIsHovered] = useState(false);\n\n const wrapperProps = onPress ? { onPress } : {};\n const hoverHandlers =\n isWeb && hoverContent\n ? {\n onMouseEnter: () => setIsHovered(true),\n onMouseLeave: () => setIsHovered(false),\n }\n : {};\n\n const isHorizontal = layout === \"horizontal\";\n\n const renderPlaceholder = () => (\n <Box\n width=\"100%\"\n height=\"100%\"\n backgroundColor={theme.colors.background.secondary}\n alignItems=\"center\"\n justifyContent=\"center\"\n >\n <Box\n width={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n height={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n alignItems=\"center\"\n justifyContent=\"center\"\n style={{ opacity: 0.4 }}\n >\n <Text\n color={theme.colors.content.tertiary}\n fontSize={24}\n style={{ textAlign: \"center\" as const }}\n >\n {\"\\u{1F5BC}\"}\n </Text>\n </Box>\n </Box>\n );\n\n const renderImage = () => (\n <Box\n position=\"relative\"\n width=\"100%\"\n overflow=\"hidden\"\n style={{ aspectRatio }}\n {...hoverHandlers}\n >\n {image ? (\n <>\n <Box\n as=\"img\"\n src={image}\n alt={imageAlt || title}\n position=\"absolute\"\n top={0}\n left={0}\n width=\"100%\"\n height=\"100%\"\n style={\n isWeb\n ? {\n objectFit: \"cover\" as const,\n pointerEvents: \"none\" as const,\n }\n : undefined\n }\n />\n <LinearGradient\n colors={[\"transparent\", \"rgba(0, 0, 0, 0.48)\"]}\n start={{ x: 0, y: 0 }}\n end={{ x: 0, y: 1 }}\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height=\"100%\"\n style={{ maxHeight: 206 }}\n />\n </>\n ) : (\n renderPlaceholder()\n )}\n\n {/* Tag zones */}\n {(badge || tagsTopLeft) && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {badge}\n {tagsTopLeft}\n </Box>\n )}\n\n {tagsTopRight && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsTopRight}\n </Box>\n )}\n\n {tagsBottomLeft && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {tagsBottomLeft}\n </Box>\n )}\n\n {tagsBottomRight && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsBottomRight}\n </Box>\n )}\n\n {/* Hover overlay */}\n {isWeb && hoverContent && isHovered && (\n <Box\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height={72}\n flexDirection=\"row\"\n alignItems=\"center\"\n gap={8}\n padding={16}\n borderRadius={4}\n overflow=\"hidden\"\n style={{\n backdropFilter: \"blur(15px)\",\n WebkitBackdropFilter: \"blur(15px)\",\n backgroundColor: theme.colors.layer.float,\n }}\n >\n {hoverContent}\n </Box>\n )}\n </Box>\n );\n\n const renderFooter = () => (\n <Box\n backgroundColor={theme.colors.overlay.mono}\n padding={footerPadding}\n flexDirection={isHorizontal ? \"row\" : \"column\"}\n alignItems={isHorizontal ? \"center\" : \"flex-start\"}\n justifyContent={isHorizontal ? undefined : \"center\"}\n gap={footerGap}\n >\n <Box\n flex={isHorizontal ? 1 : undefined}\n width={isHorizontal ? undefined : \"100%\"}\n flexDirection=\"column\"\n style={{ minWidth: 0 }}\n >\n <Text\n color={theme.colors.content.primary}\n fontSize={config.titleFontSize}\n lineHeight={config.titleLineHeight}\n fontWeight=\"500\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {title}\n </Text>\n {subtitle && (\n <Text\n color={theme.colors.content.tertiary}\n fontSize={config.subtitleFontSize}\n lineHeight={config.subtitleLineHeight}\n fontWeight=\"400\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {subtitle}\n </Text>\n )}\n </Box>\n\n {trailing}\n {!trailing && buttonText && (\n <Box\n onPress={buttonDisabled ? undefined : onButtonClick}\n backgroundColor={theme.colors.control.mono.secondary.bg}\n borderRadius={BORDER_RADIUS}\n height={40}\n paddingHorizontal={20}\n alignItems=\"center\"\n justifyContent=\"center\"\n style={\n isWeb\n ? {\n opacity: buttonDisabled ? 0.4 : 1,\n backdropFilter: \"blur(30px)\",\n WebkitBackdropFilter: \"blur(30px)\",\n border: `1px solid ${theme.colors.control.mono.secondary.border}`,\n cursor: buttonDisabled\n ? \"not-allowed\"\n : onButtonClick\n ? \"pointer\"\n : \"default\",\n }\n : { opacity: buttonDisabled ? 0.4 : 1 }\n }\n >\n <Text\n color={theme.colors.control.mono.text.secondary}\n fontSize={14}\n lineHeight={18}\n fontWeight=\"500\"\n style={{ letterSpacing: 0.4 }}\n >\n {buttonText}\n </Text>\n </Box>\n )}\n </Box>\n );\n\n return (\n <Box\n className={className}\n flexDirection=\"column\"\n width=\"100%\"\n {...wrapperProps}\n >\n <Box\n borderRadius={BORDER_RADIUS}\n overflow=\"hidden\"\n flexDirection=\"column\"\n style={\n isWeb\n ? {\n borderRadius: `${BORDER_RADIUS}px`,\n overflow: \"hidden\",\n border: `1px solid ${theme.colors.border.secondary}`,\n }\n : {\n borderRadius: BORDER_RADIUS,\n overflow: \"hidden\",\n borderWidth: 1,\n borderColor: theme.colors.border.secondary,\n }\n }\n >\n {renderImage()}\n {!hideFooter && renderFooter()}\n </Box>\n </Box>\n );\n};\n","import React from \"react\";\nimport {\n View,\n Pressable,\n Image,\n ViewStyle,\n ImageStyle,\n DimensionValue,\n AnimatableNumericValue,\n} from \"react-native\";\nimport { BoxProps } from \"@xsolla/xui-primitives-core\";\n\nexport const Box: React.FC<BoxProps> = ({\n children,\n onPress,\n onLayout,\n onMoveShouldSetResponder,\n onResponderGrant,\n onResponderMove,\n onResponderRelease,\n onResponderTerminate,\n backgroundColor,\n borderColor,\n borderWidth,\n borderBottomWidth,\n borderBottomColor,\n borderTopWidth,\n borderTopColor,\n borderLeftWidth,\n borderLeftColor,\n borderRightWidth,\n borderRightColor,\n borderRadius,\n borderStyle,\n height,\n padding,\n paddingHorizontal,\n paddingVertical,\n margin,\n marginTop,\n marginBottom,\n marginLeft,\n marginRight,\n flexDirection,\n alignItems,\n justifyContent,\n position,\n top,\n bottom,\n left,\n right,\n width,\n minWidth,\n minHeight,\n maxWidth,\n maxHeight,\n flex,\n overflow,\n zIndex,\n hoverStyle,\n pressStyle,\n style,\n \"data-testid\": dataTestId,\n testID,\n as,\n src,\n alt,\n ...rest\n}) => {\n const getContainerStyle = (pressed?: boolean): ViewStyle => ({\n backgroundColor:\n pressed && pressStyle?.backgroundColor\n ? pressStyle.backgroundColor\n : backgroundColor,\n borderColor,\n borderWidth,\n borderBottomWidth,\n borderBottomColor,\n borderTopWidth,\n borderTopColor,\n borderLeftWidth,\n borderLeftColor,\n borderRightWidth,\n borderRightColor,\n borderRadius: borderRadius as AnimatableNumericValue,\n borderStyle: borderStyle as ViewStyle[\"borderStyle\"],\n overflow,\n zIndex,\n height: height as DimensionValue,\n width: width as DimensionValue,\n minWidth: minWidth as DimensionValue,\n minHeight: minHeight as DimensionValue,\n maxWidth: maxWidth as DimensionValue,\n maxHeight: maxHeight as DimensionValue,\n padding: padding as DimensionValue,\n paddingHorizontal: paddingHorizontal as DimensionValue,\n paddingVertical: paddingVertical as DimensionValue,\n margin: margin as DimensionValue,\n marginTop: marginTop as DimensionValue,\n marginBottom: marginBottom as DimensionValue,\n marginLeft: marginLeft as DimensionValue,\n marginRight: marginRight as DimensionValue,\n flexDirection,\n alignItems,\n justifyContent,\n position: position as ViewStyle[\"position\"],\n top: top as DimensionValue,\n bottom: bottom as DimensionValue,\n left: left as DimensionValue,\n right: right as DimensionValue,\n flex,\n ...(style as ViewStyle),\n });\n\n const finalTestID = dataTestId || testID;\n\n // Destructure and drop web-only props from rest before passing to RN components\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const {\n role,\n tabIndex,\n onKeyDown,\n onKeyUp,\n \"aria-label\": _ariaLabel,\n \"aria-labelledby\": _ariaLabelledBy,\n \"aria-current\": _ariaCurrent,\n \"aria-disabled\": _ariaDisabled,\n \"aria-live\": _ariaLive,\n className,\n \"data-testid\": _dataTestId,\n ...nativeRest\n } = rest as Record<string, unknown>;\n\n // Handle as=\"img\" for React Native\n if (as === \"img\" && src) {\n const imageStyle: ImageStyle = {\n width: width as DimensionValue,\n height: height as DimensionValue,\n borderRadius: borderRadius as number,\n position: position as ImageStyle[\"position\"],\n top: top as DimensionValue,\n bottom: bottom as DimensionValue,\n left: left as DimensionValue,\n right: right as DimensionValue,\n ...(style as ImageStyle),\n };\n\n return (\n <Image\n source={{ uri: src }}\n style={imageStyle}\n testID={finalTestID}\n resizeMode=\"cover\"\n {...nativeRest}\n />\n );\n }\n\n if (onPress) {\n return (\n <Pressable\n onPress={onPress}\n onLayout={onLayout}\n onMoveShouldSetResponder={onMoveShouldSetResponder}\n onResponderGrant={onResponderGrant}\n onResponderMove={onResponderMove}\n onResponderRelease={onResponderRelease}\n onResponderTerminate={onResponderTerminate}\n style={({ pressed }) => getContainerStyle(pressed)}\n testID={finalTestID}\n {...nativeRest}\n >\n {children}\n </Pressable>\n );\n }\n\n return (\n <View\n style={getContainerStyle()}\n testID={finalTestID}\n onLayout={onLayout}\n onMoveShouldSetResponder={onMoveShouldSetResponder}\n onResponderGrant={onResponderGrant}\n onResponderMove={onResponderMove}\n onResponderRelease={onResponderRelease}\n onResponderTerminate={onResponderTerminate}\n {...nativeRest}\n >\n {children}\n </View>\n );\n};\n","import React from \"react\";\nimport {\n Text as RNText,\n TextStyle,\n AccessibilityRole,\n StyleSheet,\n} from \"react-native\";\nimport { TextProps } from \"@xsolla/xui-primitives-core\";\n\nconst roleMap: Record<string, AccessibilityRole> = {\n alert: \"alert\",\n heading: \"header\",\n button: \"button\",\n link: \"link\",\n text: \"text\",\n};\n\nconst parseNumericValue = (\n value: string | number | undefined\n): number | undefined => {\n if (value === undefined) return undefined;\n if (typeof value === \"number\") return value;\n const parsed = parseFloat(value);\n return isNaN(parsed) ? undefined : parsed;\n};\n\nexport const Text: React.FC<TextProps> = ({\n children,\n color,\n fontSize,\n fontWeight,\n fontFamily,\n textAlign,\n lineHeight,\n numberOfLines,\n id,\n role,\n style: styleProp,\n ...props\n}) => {\n let resolvedFontFamily = fontFamily\n ? fontFamily.split(\",\")[0].replace(/['\"]/g, \"\").trim()\n : undefined;\n\n if (\n resolvedFontFamily === \"Pilat Wide\" ||\n resolvedFontFamily === \"Pilat Wide Bold\" ||\n resolvedFontFamily === \"Aktiv Grotesk\"\n ) {\n resolvedFontFamily = undefined;\n }\n\n const incomingStyle = StyleSheet.flatten(styleProp) as TextStyle | undefined;\n\n const baseStyle: TextStyle = {\n color: color ?? incomingStyle?.color,\n fontSize: typeof fontSize === \"number\" ? fontSize : undefined,\n fontWeight: fontWeight as TextStyle[\"fontWeight\"],\n fontFamily: resolvedFontFamily,\n textDecorationLine: props.textDecoration as TextStyle[\"textDecorationLine\"],\n textAlign: textAlign ?? incomingStyle?.textAlign,\n lineHeight: parseNumericValue(lineHeight ?? incomingStyle?.lineHeight),\n marginTop: parseNumericValue(\n incomingStyle?.marginTop as number | string | undefined\n ),\n marginBottom: parseNumericValue(\n incomingStyle?.marginBottom as number | string | undefined\n ),\n };\n\n const accessibilityRole = role ? roleMap[role] : undefined;\n\n return (\n <RNText\n style={baseStyle}\n numberOfLines={numberOfLines}\n testID={id}\n accessibilityRole={accessibilityRole}\n >\n {children}\n </RNText>\n );\n};\n","import React, { useRef } from \"react\";\nimport { View, ViewStyle, DimensionValue } from \"react-native\";\nimport Svg, {\n Defs,\n LinearGradient as SvgLinearGradient,\n Stop,\n Rect,\n} from \"react-native-svg\";\nimport { LinearGradientProps } from \"@xsolla/xui-primitives-core\";\n\nlet gradientIdCounter = 0;\n\nfunction parseColor(color: string): { stopColor: string; stopOpacity: number } {\n if (color === \"transparent\") {\n return { stopColor: \"#000000\", stopOpacity: 0 };\n }\n\n const rgbaMatch = color.match(\n /^rgba?\\(\\s*([\\d.]+%?)\\s*,\\s*([\\d.]+%?)\\s*,\\s*([\\d.]+%?)\\s*,\\s*([\\d.]+)\\s*\\)$/i\n );\n if (rgbaMatch) {\n return {\n stopColor: `rgb(${rgbaMatch[1]}, ${rgbaMatch[2]}, ${rgbaMatch[3]})`,\n stopOpacity: parseFloat(rgbaMatch[4]),\n };\n }\n\n return { stopColor: color, stopOpacity: 1 };\n}\n\nexport const LinearGradient: React.FC<LinearGradientProps> = ({\n colors,\n start = { x: 0, y: 0 },\n end = { x: 0, y: 1 },\n locations,\n children,\n position,\n top,\n bottom,\n left,\n right,\n width,\n height,\n borderRadius,\n overflow,\n zIndex,\n style,\n testID,\n \"data-testid\": dataTestId,\n}) => {\n const containerStyle: ViewStyle = {\n position: position as ViewStyle[\"position\"],\n top: top as DimensionValue,\n bottom: bottom as DimensionValue,\n left: left as DimensionValue,\n right: right as DimensionValue,\n width: width as DimensionValue,\n height: height as DimensionValue,\n borderRadius: typeof borderRadius === \"number\" ? borderRadius : undefined,\n overflow,\n zIndex,\n ...(style as ViewStyle),\n };\n\n const gradientId = useRef(`xui-lg-${++gradientIdCounter}`).current;\n\n const stops = colors.map((color, index) => {\n const offset = locations ? locations[index] : index / (colors.length - 1);\n const { stopColor, stopOpacity } = parseColor(color);\n return (\n <Stop\n key={index}\n offset={offset}\n stopColor={stopColor}\n stopOpacity={stopOpacity}\n />\n );\n });\n\n return (\n <View style={containerStyle} testID={dataTestId || testID}>\n <Svg\n style={{ position: \"absolute\", top: 0, left: 0, right: 0, bottom: 0 }}\n width=\"100%\"\n height=\"100%\"\n >\n <Defs>\n <SvgLinearGradient\n id={gradientId}\n x1={`${start.x * 100}%`}\n y1={`${start.y * 100}%`}\n x2={`${end.x * 100}%`}\n y2={`${end.y * 100}%`}\n >\n {stops}\n </SvgLinearGradient>\n </Defs>\n <Rect\n x=\"0\"\n y=\"0\"\n width=\"100%\"\n height=\"100%\"\n fill={`url(#${gradientId})`}\n />\n </Svg>\n {children}\n </View>\n );\n};\n","export * from \"./Box\";\nexport * from \"./Text\";\nexport * from \"./Spinner\";\nexport * from \"./Icon\";\nexport * from \"./Divider\";\nexport * from \"./Input\";\nexport * from \"./TextArea\";\nexport * from \"./LinearGradient\";\n\nexport const isWeb = false;\nexport const isNative = true;\n"],"mappings":"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","names":["jsx","View","jsx","jsx","jsxs"]}
|
|
1
|
+
{"version":3,"sources":["../../src/GameCard.tsx","../../../../foundation/primitives-native/src/Box.tsx","../../../../foundation/primitives-native/src/Text.tsx","../../../../foundation/primitives-native/src/LinearGradient.tsx","../../../../foundation/primitives-native/src/index.tsx"],"sourcesContent":["import React, { useState } from \"react\";\n// @ts-expect-error - this will be resolved at build time\nimport { Box, Text, LinearGradient, isWeb } from \"@xsolla/xui-primitives\";\nimport { useResolvedTheme } from \"@xsolla/xui-core\";\nimport type {\n GameCardProps,\n GameCardSize,\n GameCardImageRatio,\n GameCardPlatform,\n GameCardLayout,\n} from \"./types\";\n\nconst IMAGE_RATIOS: Record<Exclude<GameCardImageRatio, \"custom\">, number> = {\n \"16:9\": 240 / 135,\n \"1:1\": 1,\n \"2:3\": 240 / 360,\n \"3:2\": 240 / 160,\n \"4:3\": 360 / 270,\n \"9:16\": 135 / 240,\n};\n\nconst BORDER_RADIUS = 8;\nconst TAG_INSET = 8;\nconst TAG_GAP = 4;\n\ninterface SizeConfig {\n titleFontSize: number;\n titleLineHeight: number;\n subtitleFontSize: number;\n subtitleLineHeight: number;\n}\n\nconst getSizeConfig = (\n size: GameCardSize,\n platform: GameCardPlatform\n): SizeConfig => {\n const isDesktop = platform === \"desktop\";\n switch (size) {\n case \"lg\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"md\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"sm\":\n return {\n titleFontSize: 12,\n titleLineHeight: 16,\n subtitleFontSize: 10,\n subtitleLineHeight: 14,\n };\n }\n};\n\nconst getFooterPadding = (platform: GameCardPlatform): number =>\n platform === \"desktop\" ? 16 : 12;\n\nconst getFooterGap = (): number => 12;\n\nconst resolveAspectRatio = (\n imageRatio: GameCardImageRatio,\n customWidth?: number,\n customHeight?: number\n): number => {\n if (imageRatio === \"custom\" && customWidth && customHeight) {\n return customWidth / customHeight;\n }\n return (\n IMAGE_RATIOS[imageRatio as Exclude<GameCardImageRatio, \"custom\">] ??\n IMAGE_RATIOS[\"16:9\"]\n );\n};\n\nconst ellipsisStyle = isWeb\n ? {\n overflow: \"hidden\" as const,\n textOverflow: \"ellipsis\" as const,\n whiteSpace: \"nowrap\" as const,\n }\n : undefined;\n\nexport const GameCard: React.FC<GameCardProps> = ({\n image,\n title,\n subtitle,\n size = \"lg\",\n imageRatio = \"16:9\",\n customImageWidth,\n customImageHeight,\n badge,\n tagsTopLeft,\n tagsTopRight,\n tagsBottomLeft,\n tagsBottomRight,\n trailing,\n buttonText,\n onButtonClick,\n buttonDisabled,\n layout = \"horizontal\",\n platform = \"mobile\",\n hideFooter = false,\n hoverContent,\n onPress,\n imageAlt,\n className,\n testID,\n themeMode,\n themeProductContext,\n}) => {\n const { theme } = useResolvedTheme({ themeMode, themeProductContext });\n const config = getSizeConfig(size, platform);\n const footerPadding = getFooterPadding(platform);\n const footerGap = getFooterGap();\n const aspectRatio = resolveAspectRatio(\n imageRatio,\n customImageWidth,\n customImageHeight\n );\n\n const [isHovered, setIsHovered] = useState(false);\n\n const wrapperProps = onPress ? { onPress } : {};\n const hoverHandlers =\n isWeb && hoverContent\n ? {\n onMouseEnter: () => setIsHovered(true),\n onMouseLeave: () => setIsHovered(false),\n }\n : {};\n\n const isHorizontal = layout === \"horizontal\";\n\n const renderPlaceholder = () => (\n <Box\n width=\"100%\"\n height=\"100%\"\n backgroundColor={theme.colors.background.secondary}\n alignItems=\"center\"\n justifyContent=\"center\"\n >\n <Box\n width={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n height={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n alignItems=\"center\"\n justifyContent=\"center\"\n style={{ opacity: 0.4 }}\n >\n <Text\n color={theme.colors.content.tertiary}\n fontSize={24}\n style={{ textAlign: \"center\" as const }}\n >\n {\"\\u{1F5BC}\"}\n </Text>\n </Box>\n </Box>\n );\n\n const renderImage = () => (\n <Box\n position=\"relative\"\n width=\"100%\"\n overflow=\"hidden\"\n style={{ aspectRatio }}\n {...hoverHandlers}\n >\n {image ? (\n <>\n <Box\n as=\"img\"\n src={image}\n alt={imageAlt || title}\n position=\"absolute\"\n top={0}\n left={0}\n width=\"100%\"\n height=\"100%\"\n style={\n isWeb\n ? {\n objectFit: \"cover\" as const,\n pointerEvents: \"none\" as const,\n }\n : undefined\n }\n />\n <LinearGradient\n colors={[\"transparent\", \"rgba(0, 0, 0, 0.48)\"]}\n start={{ x: 0, y: 0 }}\n end={{ x: 0, y: 1 }}\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height=\"100%\"\n style={{ maxHeight: 206 }}\n />\n </>\n ) : (\n renderPlaceholder()\n )}\n\n {/* Tag zones */}\n {(badge || tagsTopLeft) && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {badge}\n {tagsTopLeft}\n </Box>\n )}\n\n {tagsTopRight && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsTopRight}\n </Box>\n )}\n\n {tagsBottomLeft && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {tagsBottomLeft}\n </Box>\n )}\n\n {tagsBottomRight && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsBottomRight}\n </Box>\n )}\n\n {/* Hover overlay */}\n {isWeb && hoverContent && isHovered && (\n <Box\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height={72}\n flexDirection=\"row\"\n alignItems=\"center\"\n gap={8}\n padding={16}\n borderRadius={4}\n overflow=\"hidden\"\n style={{\n backdropFilter: \"blur(15px)\",\n WebkitBackdropFilter: \"blur(15px)\",\n backgroundColor: theme.colors.layer.float,\n }}\n >\n {hoverContent}\n </Box>\n )}\n </Box>\n );\n\n const renderFooter = () => (\n <Box\n backgroundColor={theme.colors.overlay.mono}\n padding={footerPadding}\n flexDirection={isHorizontal ? \"row\" : \"column\"}\n alignItems={isHorizontal ? \"center\" : \"flex-start\"}\n justifyContent={isHorizontal ? undefined : \"center\"}\n gap={footerGap}\n >\n <Box\n flex={isHorizontal ? 1 : undefined}\n width={isHorizontal ? undefined : \"100%\"}\n flexDirection=\"column\"\n style={{ minWidth: 0 }}\n >\n <Text\n color={theme.colors.content.primary}\n fontSize={config.titleFontSize}\n lineHeight={config.titleLineHeight}\n fontWeight=\"500\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {title}\n </Text>\n {subtitle && (\n <Text\n color={theme.colors.content.tertiary}\n fontSize={config.subtitleFontSize}\n lineHeight={config.subtitleLineHeight}\n fontWeight=\"400\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {subtitle}\n </Text>\n )}\n </Box>\n\n {trailing}\n {!trailing && buttonText && (\n <Box\n onPress={buttonDisabled ? undefined : onButtonClick}\n backgroundColor={theme.colors.control.mono.secondary.bg}\n borderRadius={BORDER_RADIUS}\n height={40}\n paddingHorizontal={20}\n alignItems=\"center\"\n justifyContent=\"center\"\n style={\n isWeb\n ? {\n opacity: buttonDisabled ? 0.4 : 1,\n backdropFilter: \"blur(30px)\",\n WebkitBackdropFilter: \"blur(30px)\",\n border: `1px solid ${theme.colors.control.mono.secondary.border}`,\n cursor: buttonDisabled\n ? \"not-allowed\"\n : onButtonClick\n ? \"pointer\"\n : \"default\",\n }\n : { opacity: buttonDisabled ? 0.4 : 1 }\n }\n >\n <Text\n color={theme.colors.control.mono.text.secondary}\n fontSize={14}\n lineHeight={18}\n fontWeight=\"500\"\n style={{ letterSpacing: 0.4 }}\n >\n {buttonText}\n </Text>\n </Box>\n )}\n </Box>\n );\n\n return (\n <Box\n testID={testID}\n className={className}\n flexDirection=\"column\"\n width=\"100%\"\n {...wrapperProps}\n >\n <Box\n borderRadius={BORDER_RADIUS}\n overflow=\"hidden\"\n flexDirection=\"column\"\n style={\n isWeb\n ? {\n borderRadius: `${BORDER_RADIUS}px`,\n overflow: \"hidden\",\n border: `1px solid ${theme.colors.border.secondary}`,\n }\n : {\n borderRadius: BORDER_RADIUS,\n overflow: \"hidden\",\n borderWidth: 1,\n borderColor: theme.colors.border.secondary,\n }\n }\n >\n {renderImage()}\n {!hideFooter && renderFooter()}\n </Box>\n </Box>\n );\n};\n","import React from \"react\";\nimport {\n View,\n Pressable,\n Image,\n ViewStyle,\n ImageStyle,\n DimensionValue,\n AnimatableNumericValue,\n} from \"react-native\";\nimport { BoxProps } from \"@xsolla/xui-primitives-core\";\n\nexport const Box: React.FC<BoxProps> = ({\n children,\n onPress,\n onLayout,\n onMoveShouldSetResponder,\n onResponderGrant,\n onResponderMove,\n onResponderRelease,\n onResponderTerminate,\n backgroundColor,\n borderColor,\n borderWidth,\n borderBottomWidth,\n borderBottomColor,\n borderTopWidth,\n borderTopColor,\n borderLeftWidth,\n borderLeftColor,\n borderRightWidth,\n borderRightColor,\n borderRadius,\n borderStyle,\n height,\n padding,\n paddingHorizontal,\n paddingVertical,\n margin,\n marginTop,\n marginBottom,\n marginLeft,\n marginRight,\n flexDirection,\n alignItems,\n justifyContent,\n position,\n top,\n bottom,\n left,\n right,\n width,\n minWidth,\n minHeight,\n maxWidth,\n maxHeight,\n flex,\n overflow,\n zIndex,\n hoverStyle,\n pressStyle,\n style,\n \"data-testid\": dataTestId,\n testID,\n as,\n src,\n alt,\n ...rest\n}) => {\n const getContainerStyle = (pressed?: boolean): ViewStyle => ({\n backgroundColor:\n pressed && pressStyle?.backgroundColor\n ? pressStyle.backgroundColor\n : backgroundColor,\n borderColor,\n borderWidth,\n borderBottomWidth,\n borderBottomColor,\n borderTopWidth,\n borderTopColor,\n borderLeftWidth,\n borderLeftColor,\n borderRightWidth,\n borderRightColor,\n borderRadius: borderRadius as AnimatableNumericValue,\n borderStyle: borderStyle as ViewStyle[\"borderStyle\"],\n overflow,\n zIndex,\n height: height as DimensionValue,\n width: width as DimensionValue,\n minWidth: minWidth as DimensionValue,\n minHeight: minHeight as DimensionValue,\n maxWidth: maxWidth as DimensionValue,\n maxHeight: maxHeight as DimensionValue,\n padding: padding as DimensionValue,\n paddingHorizontal: paddingHorizontal as DimensionValue,\n paddingVertical: paddingVertical as DimensionValue,\n margin: margin as DimensionValue,\n marginTop: marginTop as DimensionValue,\n marginBottom: marginBottom as DimensionValue,\n marginLeft: marginLeft as DimensionValue,\n marginRight: marginRight as DimensionValue,\n flexDirection,\n alignItems,\n justifyContent,\n position: position as ViewStyle[\"position\"],\n top: top as DimensionValue,\n bottom: bottom as DimensionValue,\n left: left as DimensionValue,\n right: right as DimensionValue,\n flex,\n ...(style as ViewStyle),\n });\n\n const finalTestID = dataTestId || testID;\n\n // Destructure and drop web-only props from rest before passing to RN components\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const {\n role,\n tabIndex,\n onKeyDown,\n onKeyUp,\n \"aria-label\": _ariaLabel,\n \"aria-labelledby\": _ariaLabelledBy,\n \"aria-current\": _ariaCurrent,\n \"aria-disabled\": _ariaDisabled,\n \"aria-live\": _ariaLive,\n className,\n \"data-testid\": _dataTestId,\n ...nativeRest\n } = rest as Record<string, unknown>;\n\n // Handle as=\"img\" for React Native\n if (as === \"img\" && src) {\n const imageStyle: ImageStyle = {\n width: width as DimensionValue,\n height: height as DimensionValue,\n borderRadius: borderRadius as number,\n position: position as ImageStyle[\"position\"],\n top: top as DimensionValue,\n bottom: bottom as DimensionValue,\n left: left as DimensionValue,\n right: right as DimensionValue,\n ...(style as ImageStyle),\n };\n\n return (\n <Image\n source={{ uri: src }}\n style={imageStyle}\n testID={finalTestID}\n resizeMode=\"cover\"\n {...nativeRest}\n />\n );\n }\n\n if (onPress) {\n return (\n <Pressable\n onPress={onPress}\n onLayout={onLayout}\n onMoveShouldSetResponder={onMoveShouldSetResponder}\n onResponderGrant={onResponderGrant}\n onResponderMove={onResponderMove}\n onResponderRelease={onResponderRelease}\n onResponderTerminate={onResponderTerminate}\n style={({ pressed }) => getContainerStyle(pressed)}\n testID={finalTestID}\n {...nativeRest}\n >\n {children}\n </Pressable>\n );\n }\n\n return (\n <View\n style={getContainerStyle()}\n testID={finalTestID}\n onLayout={onLayout}\n onMoveShouldSetResponder={onMoveShouldSetResponder}\n onResponderGrant={onResponderGrant}\n onResponderMove={onResponderMove}\n onResponderRelease={onResponderRelease}\n onResponderTerminate={onResponderTerminate}\n {...nativeRest}\n >\n {children}\n </View>\n );\n};\n","import React from \"react\";\nimport {\n Text as RNText,\n TextStyle,\n AccessibilityRole,\n StyleSheet,\n} from \"react-native\";\nimport { TextProps } from \"@xsolla/xui-primitives-core\";\n\nconst roleMap: Record<string, AccessibilityRole> = {\n alert: \"alert\",\n heading: \"header\",\n button: \"button\",\n link: \"link\",\n text: \"text\",\n};\n\nconst parseNumericValue = (\n value: string | number | undefined\n): number | undefined => {\n if (value === undefined) return undefined;\n if (typeof value === \"number\") return value;\n const parsed = parseFloat(value);\n return isNaN(parsed) ? undefined : parsed;\n};\n\nexport const Text: React.FC<TextProps> = ({\n children,\n color,\n fontSize,\n fontWeight,\n fontFamily,\n textAlign,\n lineHeight,\n numberOfLines,\n id,\n role,\n testID,\n \"data-testid\": dataTestId,\n style: styleProp,\n ...props\n}) => {\n let resolvedFontFamily = fontFamily\n ? fontFamily.split(\",\")[0].replace(/['\"]/g, \"\").trim()\n : undefined;\n\n if (\n resolvedFontFamily === \"Pilat Wide\" ||\n resolvedFontFamily === \"Pilat Wide Bold\" ||\n resolvedFontFamily === \"Aktiv Grotesk\"\n ) {\n resolvedFontFamily = undefined;\n }\n\n const incomingStyle = StyleSheet.flatten(styleProp) as TextStyle | undefined;\n\n const baseStyle: TextStyle = {\n color: color ?? incomingStyle?.color,\n fontSize: typeof fontSize === \"number\" ? fontSize : undefined,\n fontWeight: fontWeight as TextStyle[\"fontWeight\"],\n fontFamily: resolvedFontFamily,\n textDecorationLine: props.textDecoration as TextStyle[\"textDecorationLine\"],\n textAlign: textAlign ?? incomingStyle?.textAlign,\n lineHeight: parseNumericValue(lineHeight ?? incomingStyle?.lineHeight),\n marginTop: parseNumericValue(\n incomingStyle?.marginTop as number | string | undefined\n ),\n marginBottom: parseNumericValue(\n incomingStyle?.marginBottom as number | string | undefined\n ),\n };\n\n const accessibilityRole = role ? roleMap[role] : undefined;\n\n return (\n <RNText\n style={baseStyle}\n numberOfLines={numberOfLines}\n testID={dataTestId || testID || id}\n accessibilityRole={accessibilityRole}\n >\n {children}\n </RNText>\n );\n};\n","import React, { useRef } from \"react\";\nimport { View, ViewStyle, DimensionValue } from \"react-native\";\nimport Svg, {\n Defs,\n LinearGradient as SvgLinearGradient,\n Stop,\n Rect,\n} from \"react-native-svg\";\nimport { LinearGradientProps } from \"@xsolla/xui-primitives-core\";\n\nlet gradientIdCounter = 0;\n\nfunction parseColor(color: string): { stopColor: string; stopOpacity: number } {\n if (color === \"transparent\") {\n return { stopColor: \"#000000\", stopOpacity: 0 };\n }\n\n const rgbaMatch = color.match(\n /^rgba?\\(\\s*([\\d.]+%?)\\s*,\\s*([\\d.]+%?)\\s*,\\s*([\\d.]+%?)\\s*,\\s*([\\d.]+)\\s*\\)$/i\n );\n if (rgbaMatch) {\n return {\n stopColor: `rgb(${rgbaMatch[1]}, ${rgbaMatch[2]}, ${rgbaMatch[3]})`,\n stopOpacity: parseFloat(rgbaMatch[4]),\n };\n }\n\n return { stopColor: color, stopOpacity: 1 };\n}\n\nexport const LinearGradient: React.FC<LinearGradientProps> = ({\n colors,\n start = { x: 0, y: 0 },\n end = { x: 0, y: 1 },\n locations,\n children,\n position,\n top,\n bottom,\n left,\n right,\n width,\n height,\n borderRadius,\n overflow,\n zIndex,\n style,\n testID,\n \"data-testid\": dataTestId,\n}) => {\n const containerStyle: ViewStyle = {\n position: position as ViewStyle[\"position\"],\n top: top as DimensionValue,\n bottom: bottom as DimensionValue,\n left: left as DimensionValue,\n right: right as DimensionValue,\n width: width as DimensionValue,\n height: height as DimensionValue,\n borderRadius: typeof borderRadius === \"number\" ? borderRadius : undefined,\n overflow,\n zIndex,\n ...(style as ViewStyle),\n };\n\n const gradientId = useRef(`xui-lg-${++gradientIdCounter}`).current;\n\n const stops = colors.map((color, index) => {\n const offset = locations ? locations[index] : index / (colors.length - 1);\n const { stopColor, stopOpacity } = parseColor(color);\n return (\n <Stop\n key={index}\n offset={offset}\n stopColor={stopColor}\n stopOpacity={stopOpacity}\n />\n );\n });\n\n return (\n <View style={containerStyle} testID={dataTestId || testID}>\n <Svg\n style={{ position: \"absolute\", top: 0, left: 0, right: 0, bottom: 0 }}\n width=\"100%\"\n height=\"100%\"\n >\n <Defs>\n <SvgLinearGradient\n id={gradientId}\n x1={`${start.x * 100}%`}\n y1={`${start.y * 100}%`}\n x2={`${end.x * 100}%`}\n y2={`${end.y * 100}%`}\n >\n {stops}\n </SvgLinearGradient>\n </Defs>\n <Rect\n x=\"0\"\n y=\"0\"\n width=\"100%\"\n height=\"100%\"\n fill={`url(#${gradientId})`}\n />\n </Svg>\n {children}\n </View>\n );\n};\n","export * from \"./Box\";\nexport * from \"./Text\";\nexport * from \"./Spinner\";\nexport * from \"./Icon\";\nexport * from \"./Divider\";\nexport * from \"./Input\";\nexport * from \"./TextArea\";\nexport * from \"./LinearGradient\";\n\nexport const isWeb = false;\nexport const isNative = true;\n"],"mappings":"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","names":["jsx","View","jsx","jsx","jsxs"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@xsolla/xui-game-card",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.160.0",
|
|
4
4
|
"main": "./web/index.js",
|
|
5
5
|
"module": "./web/index.mjs",
|
|
6
6
|
"types": "./web/index.d.ts",
|
|
@@ -14,8 +14,8 @@
|
|
|
14
14
|
"test:coverage": "vitest run --coverage"
|
|
15
15
|
},
|
|
16
16
|
"dependencies": {
|
|
17
|
-
"@xsolla/xui-core": "0.
|
|
18
|
-
"@xsolla/xui-primitives-core": "0.
|
|
17
|
+
"@xsolla/xui-core": "0.160.0",
|
|
18
|
+
"@xsolla/xui-primitives-core": "0.160.0"
|
|
19
19
|
},
|
|
20
20
|
"peerDependencies": {
|
|
21
21
|
"react": ">=16.8.0",
|
package/web/index.d.mts
CHANGED
|
@@ -52,6 +52,8 @@ interface GameCardProps extends ThemeOverrideProps {
|
|
|
52
52
|
imageAlt?: string;
|
|
53
53
|
/** Custom className for the container */
|
|
54
54
|
className?: string;
|
|
55
|
+
/** Test ID for testing frameworks */
|
|
56
|
+
testID?: string;
|
|
55
57
|
}
|
|
56
58
|
|
|
57
59
|
declare const GameCard: React.FC<GameCardProps>;
|
package/web/index.d.ts
CHANGED
|
@@ -52,6 +52,8 @@ interface GameCardProps extends ThemeOverrideProps {
|
|
|
52
52
|
imageAlt?: string;
|
|
53
53
|
/** Custom className for the container */
|
|
54
54
|
className?: string;
|
|
55
|
+
/** Test ID for testing frameworks */
|
|
56
|
+
testID?: string;
|
|
55
57
|
}
|
|
56
58
|
|
|
57
59
|
declare const GameCard: React.FC<GameCardProps>;
|
package/web/index.js
CHANGED
|
@@ -249,7 +249,8 @@ var Box = import_react2.default.forwardRef(
|
|
|
249
249
|
top: typeof props.top === "number" ? `${props.top}px` : props.top,
|
|
250
250
|
left: typeof props.left === "number" ? `${props.left}px` : props.left,
|
|
251
251
|
right: typeof props.right === "number" ? `${props.right}px` : props.right,
|
|
252
|
-
bottom: typeof props.bottom === "number" ? `${props.bottom}px` : props.bottom
|
|
252
|
+
bottom: typeof props.bottom === "number" ? `${props.bottom}px` : props.bottom,
|
|
253
|
+
...props.style
|
|
253
254
|
}
|
|
254
255
|
}
|
|
255
256
|
);
|
|
@@ -306,6 +307,8 @@ var Text = ({
|
|
|
306
307
|
className,
|
|
307
308
|
id,
|
|
308
309
|
role,
|
|
310
|
+
testID,
|
|
311
|
+
"data-testid": dataTestId,
|
|
309
312
|
numberOfLines: _numberOfLines,
|
|
310
313
|
...props
|
|
311
314
|
}) => {
|
|
@@ -316,7 +319,8 @@ var Text = ({
|
|
|
316
319
|
style,
|
|
317
320
|
className,
|
|
318
321
|
id,
|
|
319
|
-
role
|
|
322
|
+
role,
|
|
323
|
+
"data-testid": dataTestId || testID
|
|
320
324
|
}
|
|
321
325
|
);
|
|
322
326
|
};
|
|
@@ -461,6 +465,7 @@ var GameCard = ({
|
|
|
461
465
|
onPress,
|
|
462
466
|
imageAlt,
|
|
463
467
|
className,
|
|
468
|
+
testID,
|
|
464
469
|
themeMode,
|
|
465
470
|
themeProductContext
|
|
466
471
|
}) => {
|
|
@@ -709,6 +714,7 @@ var GameCard = ({
|
|
|
709
714
|
return /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
|
|
710
715
|
Box,
|
|
711
716
|
{
|
|
717
|
+
testID,
|
|
712
718
|
className,
|
|
713
719
|
flexDirection: "column",
|
|
714
720
|
width: "100%",
|
package/web/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.tsx","../../src/GameCard.tsx","../../../../foundation/primitives-web/src/Box.tsx","../../../../foundation/primitives-web/src/filterDOMProps.ts","../../../../../node_modules/@emotion/memoize/dist/memoize.esm.js","../../../../../node_modules/@emotion/is-prop-valid/dist/is-prop-valid.esm.js","../../../../foundation/primitives-web/src/Text.tsx","../../../../foundation/primitives-web/src/LinearGradient.tsx","../../../../foundation/primitives-web/src/index.tsx"],"sourcesContent":["export * from \"./GameCard\";\nexport * from \"./types\";\n","import React, { useState } from \"react\";\n// @ts-expect-error - this will be resolved at build time\nimport { Box, Text, LinearGradient, isWeb } from \"@xsolla/xui-primitives\";\nimport { useResolvedTheme } from \"@xsolla/xui-core\";\nimport type {\n GameCardProps,\n GameCardSize,\n GameCardImageRatio,\n GameCardPlatform,\n GameCardLayout,\n} from \"./types\";\n\nconst IMAGE_RATIOS: Record<Exclude<GameCardImageRatio, \"custom\">, number> = {\n \"16:9\": 240 / 135,\n \"1:1\": 1,\n \"2:3\": 240 / 360,\n \"3:2\": 240 / 160,\n \"4:3\": 360 / 270,\n \"9:16\": 135 / 240,\n};\n\nconst BORDER_RADIUS = 8;\nconst TAG_INSET = 8;\nconst TAG_GAP = 4;\n\ninterface SizeConfig {\n titleFontSize: number;\n titleLineHeight: number;\n subtitleFontSize: number;\n subtitleLineHeight: number;\n}\n\nconst getSizeConfig = (\n size: GameCardSize,\n platform: GameCardPlatform\n): SizeConfig => {\n const isDesktop = platform === \"desktop\";\n switch (size) {\n case \"lg\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"md\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"sm\":\n return {\n titleFontSize: 12,\n titleLineHeight: 16,\n subtitleFontSize: 10,\n subtitleLineHeight: 14,\n };\n }\n};\n\nconst getFooterPadding = (platform: GameCardPlatform): number =>\n platform === \"desktop\" ? 16 : 12;\n\nconst getFooterGap = (): number => 12;\n\nconst resolveAspectRatio = (\n imageRatio: GameCardImageRatio,\n customWidth?: number,\n customHeight?: number\n): number => {\n if (imageRatio === \"custom\" && customWidth && customHeight) {\n return customWidth / customHeight;\n }\n return (\n IMAGE_RATIOS[imageRatio as Exclude<GameCardImageRatio, \"custom\">] ??\n IMAGE_RATIOS[\"16:9\"]\n );\n};\n\nconst ellipsisStyle = isWeb\n ? {\n overflow: \"hidden\" as const,\n textOverflow: \"ellipsis\" as const,\n whiteSpace: \"nowrap\" as const,\n }\n : undefined;\n\nexport const GameCard: React.FC<GameCardProps> = ({\n image,\n title,\n subtitle,\n size = \"lg\",\n imageRatio = \"16:9\",\n customImageWidth,\n customImageHeight,\n badge,\n tagsTopLeft,\n tagsTopRight,\n tagsBottomLeft,\n tagsBottomRight,\n trailing,\n buttonText,\n onButtonClick,\n buttonDisabled,\n layout = \"horizontal\",\n platform = \"mobile\",\n hideFooter = false,\n hoverContent,\n onPress,\n imageAlt,\n className,\n themeMode,\n themeProductContext,\n}) => {\n const { theme } = useResolvedTheme({ themeMode, themeProductContext });\n const config = getSizeConfig(size, platform);\n const footerPadding = getFooterPadding(platform);\n const footerGap = getFooterGap();\n const aspectRatio = resolveAspectRatio(\n imageRatio,\n customImageWidth,\n customImageHeight\n );\n\n const [isHovered, setIsHovered] = useState(false);\n\n const wrapperProps = onPress ? { onPress } : {};\n const hoverHandlers =\n isWeb && hoverContent\n ? {\n onMouseEnter: () => setIsHovered(true),\n onMouseLeave: () => setIsHovered(false),\n }\n : {};\n\n const isHorizontal = layout === \"horizontal\";\n\n const renderPlaceholder = () => (\n <Box\n width=\"100%\"\n height=\"100%\"\n backgroundColor={theme.colors.background.secondary}\n alignItems=\"center\"\n justifyContent=\"center\"\n >\n <Box\n width={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n height={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n alignItems=\"center\"\n justifyContent=\"center\"\n style={{ opacity: 0.4 }}\n >\n <Text\n color={theme.colors.content.tertiary}\n fontSize={24}\n style={{ textAlign: \"center\" as const }}\n >\n {\"\\u{1F5BC}\"}\n </Text>\n </Box>\n </Box>\n );\n\n const renderImage = () => (\n <Box\n position=\"relative\"\n width=\"100%\"\n overflow=\"hidden\"\n style={{ aspectRatio }}\n {...hoverHandlers}\n >\n {image ? (\n <>\n <Box\n as=\"img\"\n src={image}\n alt={imageAlt || title}\n position=\"absolute\"\n top={0}\n left={0}\n width=\"100%\"\n height=\"100%\"\n style={\n isWeb\n ? {\n objectFit: \"cover\" as const,\n pointerEvents: \"none\" as const,\n }\n : undefined\n }\n />\n <LinearGradient\n colors={[\"transparent\", \"rgba(0, 0, 0, 0.48)\"]}\n start={{ x: 0, y: 0 }}\n end={{ x: 0, y: 1 }}\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height=\"100%\"\n style={{ maxHeight: 206 }}\n />\n </>\n ) : (\n renderPlaceholder()\n )}\n\n {/* Tag zones */}\n {(badge || tagsTopLeft) && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {badge}\n {tagsTopLeft}\n </Box>\n )}\n\n {tagsTopRight && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsTopRight}\n </Box>\n )}\n\n {tagsBottomLeft && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {tagsBottomLeft}\n </Box>\n )}\n\n {tagsBottomRight && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsBottomRight}\n </Box>\n )}\n\n {/* Hover overlay */}\n {isWeb && hoverContent && isHovered && (\n <Box\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height={72}\n flexDirection=\"row\"\n alignItems=\"center\"\n gap={8}\n padding={16}\n borderRadius={4}\n overflow=\"hidden\"\n style={{\n backdropFilter: \"blur(15px)\",\n WebkitBackdropFilter: \"blur(15px)\",\n backgroundColor: theme.colors.layer.float,\n }}\n >\n {hoverContent}\n </Box>\n )}\n </Box>\n );\n\n const renderFooter = () => (\n <Box\n backgroundColor={theme.colors.overlay.mono}\n padding={footerPadding}\n flexDirection={isHorizontal ? \"row\" : \"column\"}\n alignItems={isHorizontal ? \"center\" : \"flex-start\"}\n justifyContent={isHorizontal ? undefined : \"center\"}\n gap={footerGap}\n >\n <Box\n flex={isHorizontal ? 1 : undefined}\n width={isHorizontal ? undefined : \"100%\"}\n flexDirection=\"column\"\n style={{ minWidth: 0 }}\n >\n <Text\n color={theme.colors.content.primary}\n fontSize={config.titleFontSize}\n lineHeight={config.titleLineHeight}\n fontWeight=\"500\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {title}\n </Text>\n {subtitle && (\n <Text\n color={theme.colors.content.tertiary}\n fontSize={config.subtitleFontSize}\n lineHeight={config.subtitleLineHeight}\n fontWeight=\"400\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {subtitle}\n </Text>\n )}\n </Box>\n\n {trailing}\n {!trailing && buttonText && (\n <Box\n onPress={buttonDisabled ? undefined : onButtonClick}\n backgroundColor={theme.colors.control.mono.secondary.bg}\n borderRadius={BORDER_RADIUS}\n height={40}\n paddingHorizontal={20}\n alignItems=\"center\"\n justifyContent=\"center\"\n style={\n isWeb\n ? {\n opacity: buttonDisabled ? 0.4 : 1,\n backdropFilter: \"blur(30px)\",\n WebkitBackdropFilter: \"blur(30px)\",\n border: `1px solid ${theme.colors.control.mono.secondary.border}`,\n cursor: buttonDisabled\n ? \"not-allowed\"\n : onButtonClick\n ? \"pointer\"\n : \"default\",\n }\n : { opacity: buttonDisabled ? 0.4 : 1 }\n }\n >\n <Text\n color={theme.colors.control.mono.text.secondary}\n fontSize={14}\n lineHeight={18}\n fontWeight=\"500\"\n style={{ letterSpacing: 0.4 }}\n >\n {buttonText}\n </Text>\n </Box>\n )}\n </Box>\n );\n\n return (\n <Box\n className={className}\n flexDirection=\"column\"\n width=\"100%\"\n {...wrapperProps}\n >\n <Box\n borderRadius={BORDER_RADIUS}\n overflow=\"hidden\"\n flexDirection=\"column\"\n style={\n isWeb\n ? {\n borderRadius: `${BORDER_RADIUS}px`,\n overflow: \"hidden\",\n border: `1px solid ${theme.colors.border.secondary}`,\n }\n : {\n borderRadius: BORDER_RADIUS,\n overflow: \"hidden\",\n borderWidth: 1,\n borderColor: theme.colors.border.secondary,\n }\n }\n >\n {renderImage()}\n {!hideFooter && renderFooter()}\n </Box>\n </Box>\n );\n};\n","import React from \"react\";\nimport styled from \"styled-components\";\nimport type { BoxProps } from \"@xsolla/xui-primitives-core\";\nimport { createFilteredElement } from \"./filterDOMProps\";\n\nconst FilteredDiv = createFilteredElement(\"div\");\n\nconst StyledBox = styled(FilteredDiv)<BoxProps>`\n display: flex;\n box-sizing: border-box;\n background-color: ${(props) => props.backgroundColor || \"transparent\"};\n border-color: ${(props) => props.borderColor || \"transparent\"};\n border-width: ${(props) =>\n typeof props.borderWidth === \"number\"\n ? `${props.borderWidth}px`\n : props.borderWidth || 0};\n\n ${(props) =>\n props.borderBottomWidth !== undefined &&\n `\n border-bottom-width: ${typeof props.borderBottomWidth === \"number\" ? `${props.borderBottomWidth}px` : props.borderBottomWidth};\n border-bottom-color: ${props.borderBottomColor || props.borderColor || \"transparent\"};\n border-bottom-style: solid;\n `}\n ${(props) =>\n props.borderTopWidth !== undefined &&\n `\n border-top-width: ${typeof props.borderTopWidth === \"number\" ? `${props.borderTopWidth}px` : props.borderTopWidth};\n border-top-color: ${props.borderTopColor || props.borderColor || \"transparent\"};\n border-top-style: solid;\n `}\n ${(props) =>\n props.borderLeftWidth !== undefined &&\n `\n border-left-width: ${typeof props.borderLeftWidth === \"number\" ? `${props.borderLeftWidth}px` : props.borderLeftWidth};\n border-left-color: ${props.borderLeftColor || props.borderColor || \"transparent\"};\n border-left-style: solid;\n `}\n ${(props) =>\n props.borderRightWidth !== undefined &&\n `\n border-right-width: ${typeof props.borderRightWidth === \"number\" ? `${props.borderRightWidth}px` : props.borderRightWidth};\n border-right-color: ${props.borderRightColor || props.borderColor || \"transparent\"};\n border-right-style: solid;\n `}\n\n border-style: ${(props) =>\n props.borderStyle ||\n (props.borderWidth ||\n props.borderBottomWidth ||\n props.borderTopWidth ||\n props.borderLeftWidth ||\n props.borderRightWidth\n ? \"solid\"\n : \"none\")};\n border-radius: ${(props) =>\n typeof props.borderRadius === \"number\"\n ? `${props.borderRadius}px`\n : props.borderRadius || 0};\n height: ${(props) =>\n typeof props.height === \"number\"\n ? `${props.height}px`\n : props.height || \"auto\"};\n width: ${(props) =>\n typeof props.width === \"number\"\n ? `${props.width}px`\n : props.width || \"auto\"};\n min-width: ${(props) =>\n typeof props.minWidth === \"number\"\n ? `${props.minWidth}px`\n : props.minWidth || \"auto\"};\n min-height: ${(props) =>\n typeof props.minHeight === \"number\"\n ? `${props.minHeight}px`\n : props.minHeight || \"auto\"};\n max-width: ${(props) =>\n typeof props.maxWidth === \"number\"\n ? `${props.maxWidth}px`\n : props.maxWidth || \"none\"};\n max-height: ${(props) =>\n typeof props.maxHeight === \"number\"\n ? `${props.maxHeight}px`\n : props.maxHeight || \"none\"};\n\n padding: ${(props) =>\n typeof props.padding === \"number\"\n ? `${props.padding}px`\n : props.padding || 0};\n ${(props) =>\n props.paddingHorizontal &&\n `\n padding-left: ${typeof props.paddingHorizontal === \"number\" ? `${props.paddingHorizontal}px` : props.paddingHorizontal};\n padding-right: ${typeof props.paddingHorizontal === \"number\" ? `${props.paddingHorizontal}px` : props.paddingHorizontal};\n `}\n ${(props) =>\n props.paddingVertical &&\n `\n padding-top: ${typeof props.paddingVertical === \"number\" ? `${props.paddingVertical}px` : props.paddingVertical};\n padding-bottom: ${typeof props.paddingVertical === \"number\" ? `${props.paddingVertical}px` : props.paddingVertical};\n `}\n ${(props) =>\n props.paddingTop !== undefined &&\n `padding-top: ${typeof props.paddingTop === \"number\" ? `${props.paddingTop}px` : props.paddingTop};`}\n ${(props) =>\n props.paddingBottom !== undefined &&\n `padding-bottom: ${typeof props.paddingBottom === \"number\" ? `${props.paddingBottom}px` : props.paddingBottom};`}\n ${(props) =>\n props.paddingLeft !== undefined &&\n `padding-left: ${typeof props.paddingLeft === \"number\" ? `${props.paddingLeft}px` : props.paddingLeft};`}\n ${(props) =>\n props.paddingRight !== undefined &&\n `padding-right: ${typeof props.paddingRight === \"number\" ? `${props.paddingRight}px` : props.paddingRight};`}\n\n margin: ${(props) =>\n typeof props.margin === \"number\" ? `${props.margin}px` : props.margin || 0};\n ${(props) =>\n props.marginTop !== undefined &&\n `margin-top: ${typeof props.marginTop === \"number\" ? `${props.marginTop}px` : props.marginTop};`}\n ${(props) =>\n props.marginBottom !== undefined &&\n `margin-bottom: ${typeof props.marginBottom === \"number\" ? `${props.marginBottom}px` : props.marginBottom};`}\n ${(props) =>\n props.marginLeft !== undefined &&\n `margin-left: ${typeof props.marginLeft === \"number\" ? `${props.marginLeft}px` : props.marginLeft};`}\n ${(props) =>\n props.marginRight !== undefined &&\n `margin-right: ${typeof props.marginRight === \"number\" ? `${props.marginRight}px` : props.marginRight};`}\n\n flex-direction: ${(props) => props.flexDirection || \"column\"};\n flex-wrap: ${(props) => props.flexWrap || \"nowrap\"};\n align-items: ${(props) => props.alignItems || \"stretch\"};\n justify-content: ${(props) => props.justifyContent || \"flex-start\"};\n cursor: ${(props) =>\n props.cursor\n ? props.cursor\n : props.onClick || props.onPress\n ? \"pointer\"\n : \"inherit\"};\n position: ${(props) => props.position || \"static\"};\n top: ${(props) =>\n typeof props.top === \"number\" ? `${props.top}px` : props.top};\n bottom: ${(props) =>\n typeof props.bottom === \"number\" ? `${props.bottom}px` : props.bottom};\n left: ${(props) =>\n typeof props.left === \"number\" ? `${props.left}px` : props.left};\n right: ${(props) =>\n typeof props.right === \"number\" ? `${props.right}px` : props.right};\n flex: ${(props) => props.flex};\n flex-shrink: ${(props) => props.flexShrink ?? 1};\n gap: ${(props) =>\n typeof props.gap === \"number\" ? `${props.gap}px` : props.gap || 0};\n align-self: ${(props) => props.alignSelf || \"auto\"};\n overflow: ${(props) => props.overflow || \"visible\"};\n overflow-x: ${(props) => props.overflowX || \"visible\"};\n overflow-y: ${(props) => props.overflowY || \"visible\"};\n z-index: ${(props) => props.zIndex};\n opacity: ${(props) => (props.disabled ? 0.5 : 1)};\n pointer-events: ${(props) => (props.disabled ? \"none\" : \"auto\")};\n\n &:hover {\n ${(props) =>\n props.hoverStyle?.backgroundColor &&\n `background-color: ${props.hoverStyle.backgroundColor};`}\n ${(props) =>\n props.hoverStyle?.borderColor &&\n `border-color: ${props.hoverStyle.borderColor};`}\n }\n\n &:active {\n ${(props) =>\n props.pressStyle?.backgroundColor &&\n `background-color: ${props.pressStyle.backgroundColor};`}\n }\n`;\n\nexport const Box = React.forwardRef<\n HTMLDivElement | HTMLButtonElement,\n BoxProps\n>(\n (\n {\n children,\n onPress,\n onKeyDown,\n onKeyUp,\n role,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n \"aria-current\": ariaCurrent,\n \"aria-disabled\": ariaDisabled,\n \"aria-live\": ariaLive,\n \"aria-busy\": ariaBusy,\n \"aria-describedby\": ariaDescribedBy,\n \"aria-expanded\": ariaExpanded,\n \"aria-haspopup\": ariaHasPopup,\n \"aria-pressed\": ariaPressed,\n \"aria-controls\": ariaControls,\n tabIndex,\n as,\n src,\n alt,\n onError,\n onLoad,\n type,\n disabled,\n id,\n testID,\n \"data-testid\": dataTestId,\n ...props\n },\n ref\n ) => {\n // Handle as=\"img\" for rendering images with proper border-radius\n if (as === \"img\" && src) {\n return (\n <img\n src={src}\n alt={alt || \"\"}\n onError={onError}\n onLoad={onLoad}\n style={{\n display: \"block\",\n objectFit: \"cover\",\n width:\n typeof props.width === \"number\"\n ? `${props.width}px`\n : props.width,\n height:\n typeof props.height === \"number\"\n ? `${props.height}px`\n : props.height,\n borderRadius:\n typeof props.borderRadius === \"number\"\n ? `${props.borderRadius}px`\n : props.borderRadius,\n position: props.position,\n top: typeof props.top === \"number\" ? `${props.top}px` : props.top,\n left:\n typeof props.left === \"number\" ? `${props.left}px` : props.left,\n right:\n typeof props.right === \"number\"\n ? `${props.right}px`\n : props.right,\n bottom:\n typeof props.bottom === \"number\"\n ? `${props.bottom}px`\n : props.bottom,\n }}\n />\n );\n }\n\n return (\n <StyledBox\n ref={ref}\n elementType={as}\n id={id}\n type={as === \"button\" ? type || \"button\" : undefined}\n disabled={as === \"button\" ? disabled : undefined}\n onClick={onPress}\n onKeyDown={onKeyDown}\n onKeyUp={onKeyUp}\n role={role}\n aria-label={ariaLabel}\n aria-labelledby={ariaLabelledBy}\n aria-current={ariaCurrent}\n aria-disabled={ariaDisabled}\n aria-busy={ariaBusy}\n aria-describedby={ariaDescribedBy}\n aria-expanded={ariaExpanded}\n aria-haspopup={ariaHasPopup}\n aria-pressed={ariaPressed}\n aria-controls={ariaControls}\n aria-live={ariaLive}\n tabIndex={tabIndex !== undefined ? tabIndex : undefined}\n data-testid={dataTestId || testID}\n {...props}\n >\n {children}\n </StyledBox>\n );\n }\n);\n\nBox.displayName = \"Box\";\n","import React from \"react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\n// Props that @emotion/is-prop-valid incorrectly treats as valid HTML.\n// These are React Native or component-specific props that match\n// valid HTML patterns (on* event handlers, SVG attributes).\nexport const ADDITIONAL_BLOCKED_PROPS = new Set([\n // RN-only event handlers (pass isPropValid's on* pattern)\n \"onPress\",\n \"onChangeText\",\n \"onLayout\",\n \"onMoveShouldSetResponder\",\n \"onResponderGrant\",\n \"onResponderMove\",\n \"onResponderRelease\",\n \"onResponderTerminate\",\n // SVG attributes that pass isPropValid\n \"strokeWidth\",\n // CSS properties that pass isPropValid but are used as component props\n \"overflow\",\n \"cursor\",\n \"fontSize\",\n \"fontWeight\",\n \"fontFamily\",\n \"textDecoration\",\n]);\n\nfunction shouldForwardProp(key: string): boolean {\n if (ADDITIONAL_BLOCKED_PROPS.has(key)) return false;\n return isPropValid(key);\n}\n\n/**\n * Creates a React component that renders the given HTML tag\n * but filters out non-HTML props before they reach the DOM.\n *\n * Uses @emotion/is-prop-valid (same library styled-components v4\n * uses internally) to automatically block invalid HTML attributes,\n * plus a small blocklist for false positives (RN on* handlers, SVG attrs).\n *\n * Usage: `const FilteredDiv = createFilteredElement(\"div\");`\n * Then: `const StyledBox = styled(FilteredDiv)<BoxProps>\\`...\\`;`\n *\n * styled-components can still read ALL props for CSS interpolation,\n * but only valid HTML attributes are forwarded to the DOM element.\n */\nexport function createFilteredElement(defaultTag: string) {\n const Component = React.forwardRef<HTMLElement, Record<string, unknown>>(\n ({ children, elementType, ...props }, ref) => {\n const Tag = (elementType as string) || defaultTag;\n const htmlProps: Record<string, unknown> = {};\n for (const key of Object.keys(props)) {\n if (shouldForwardProp(key)) {\n htmlProps[key] = props[key];\n }\n }\n return React.createElement(\n Tag,\n { ref, ...htmlProps },\n children as React.ReactNode\n );\n }\n );\n Component.displayName = `Filtered(${defaultTag})`;\n return Component;\n}\n","function memoize(fn) {\n var cache = {};\n return function (arg) {\n if (cache[arg] === undefined) cache[arg] = fn(arg);\n return cache[arg];\n };\n}\n\nexport default memoize;\n","import memoize from '@emotion/memoize';\n\nvar reactPropsRegex = /^((children|dangerouslySetInnerHTML|key|ref|autoFocus|defaultValue|defaultChecked|innerHTML|suppressContentEditableWarning|suppressHydrationWarning|valueLink|accept|acceptCharset|accessKey|action|allow|allowUserMedia|allowPaymentRequest|allowFullScreen|allowTransparency|alt|async|autoComplete|autoPlay|capture|cellPadding|cellSpacing|challenge|charSet|checked|cite|classID|className|cols|colSpan|content|contentEditable|contextMenu|controls|controlsList|coords|crossOrigin|data|dateTime|decoding|default|defer|dir|disabled|disablePictureInPicture|download|draggable|encType|form|formAction|formEncType|formMethod|formNoValidate|formTarget|frameBorder|headers|height|hidden|high|href|hrefLang|htmlFor|httpEquiv|id|inputMode|integrity|is|keyParams|keyType|kind|label|lang|list|loading|loop|low|marginHeight|marginWidth|max|maxLength|media|mediaGroup|method|min|minLength|multiple|muted|name|nonce|noValidate|open|optimum|pattern|placeholder|playsInline|poster|preload|profile|radioGroup|readOnly|referrerPolicy|rel|required|reversed|role|rows|rowSpan|sandbox|scope|scoped|scrolling|seamless|selected|shape|size|sizes|slot|span|spellCheck|src|srcDoc|srcLang|srcSet|start|step|style|summary|tabIndex|target|title|type|useMap|value|width|wmode|wrap|about|datatype|inlist|prefix|property|resource|typeof|vocab|autoCapitalize|autoCorrect|autoSave|color|inert|itemProp|itemScope|itemType|itemID|itemRef|on|results|security|unselectable|accentHeight|accumulate|additive|alignmentBaseline|allowReorder|alphabetic|amplitude|arabicForm|ascent|attributeName|attributeType|autoReverse|azimuth|baseFrequency|baselineShift|baseProfile|bbox|begin|bias|by|calcMode|capHeight|clip|clipPathUnits|clipPath|clipRule|colorInterpolation|colorInterpolationFilters|colorProfile|colorRendering|contentScriptType|contentStyleType|cursor|cx|cy|d|decelerate|descent|diffuseConstant|direction|display|divisor|dominantBaseline|dur|dx|dy|edgeMode|elevation|enableBackground|end|exponent|externalResourcesRequired|fill|fillOpacity|fillRule|filter|filterRes|filterUnits|floodColor|floodOpacity|focusable|fontFamily|fontSize|fontSizeAdjust|fontStretch|fontStyle|fontVariant|fontWeight|format|from|fr|fx|fy|g1|g2|glyphName|glyphOrientationHorizontal|glyphOrientationVertical|glyphRef|gradientTransform|gradientUnits|hanging|horizAdvX|horizOriginX|ideographic|imageRendering|in|in2|intercept|k|k1|k2|k3|k4|kernelMatrix|kernelUnitLength|kerning|keyPoints|keySplines|keyTimes|lengthAdjust|letterSpacing|lightingColor|limitingConeAngle|local|markerEnd|markerMid|markerStart|markerHeight|markerUnits|markerWidth|mask|maskContentUnits|maskUnits|mathematical|mode|numOctaves|offset|opacity|operator|order|orient|orientation|origin|overflow|overlinePosition|overlineThickness|panose1|paintOrder|pathLength|patternContentUnits|patternTransform|patternUnits|pointerEvents|points|pointsAtX|pointsAtY|pointsAtZ|preserveAlpha|preserveAspectRatio|primitiveUnits|r|radius|refX|refY|renderingIntent|repeatCount|repeatDur|requiredExtensions|requiredFeatures|restart|result|rotate|rx|ry|scale|seed|shapeRendering|slope|spacing|specularConstant|specularExponent|speed|spreadMethod|startOffset|stdDeviation|stemh|stemv|stitchTiles|stopColor|stopOpacity|strikethroughPosition|strikethroughThickness|string|stroke|strokeDasharray|strokeDashoffset|strokeLinecap|strokeLinejoin|strokeMiterlimit|strokeOpacity|strokeWidth|surfaceScale|systemLanguage|tableValues|targetX|targetY|textAnchor|textDecoration|textRendering|textLength|to|transform|u1|u2|underlinePosition|underlineThickness|unicode|unicodeBidi|unicodeRange|unitsPerEm|vAlphabetic|vHanging|vIdeographic|vMathematical|values|vectorEffect|version|vertAdvY|vertOriginX|vertOriginY|viewBox|viewTarget|visibility|widths|wordSpacing|writingMode|x|xHeight|x1|x2|xChannelSelector|xlinkActuate|xlinkArcrole|xlinkHref|xlinkRole|xlinkShow|xlinkTitle|xlinkType|xmlBase|xmlns|xmlnsXlink|xmlLang|xmlSpace|y|y1|y2|yChannelSelector|z|zoomAndPan|for|class|autofocus)|(([Dd][Aa][Tt][Aa]|[Aa][Rr][Ii][Aa]|x)-.*))$/; // https://esbench.com/bench/5bfee68a4cd7e6009ef61d23\n\nvar index = memoize(function (prop) {\n return reactPropsRegex.test(prop) || prop.charCodeAt(0) === 111\n /* o */\n && prop.charCodeAt(1) === 110\n /* n */\n && prop.charCodeAt(2) < 91;\n}\n/* Z+1 */\n);\n\nexport default index;\n","import React from \"react\";\nimport styled from \"styled-components\";\nimport { TextProps } from \"@xsolla/xui-primitives-core\";\nimport { createFilteredElement } from \"./filterDOMProps\";\n\nconst FilteredSpan = createFilteredElement(\"span\");\n\nconst StyledText = styled(FilteredSpan)<TextProps>`\n color: ${(props) => props.color || \"inherit\"};\n font-size: ${(props) =>\n typeof props.fontSize === \"number\"\n ? `${props.fontSize}px`\n : props.fontSize || \"inherit\"};\n font-weight: ${(props) => props.fontWeight || \"normal\"};\n font-family: ${(props) =>\n props.fontFamily ||\n '\"Aktiv Grotesk\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif'};\n line-height: ${(props) =>\n typeof props.lineHeight === \"number\"\n ? `${props.lineHeight}px`\n : props.lineHeight || \"inherit\"};\n white-space: ${(props) => props.whiteSpace || \"normal\"};\n text-align: ${(props) => props.textAlign || \"inherit\"};\n text-decoration: ${(props) => props.textDecoration || \"none\"};\n`;\n\nexport const Text: React.FC<TextProps> = ({\n style,\n className,\n id,\n role,\n numberOfLines: _numberOfLines,\n ...props\n}) => {\n return (\n <StyledText\n {...props}\n style={style}\n className={className}\n id={id}\n role={role}\n />\n );\n};\n","import React from \"react\";\nimport styled from \"styled-components\";\nimport type { LinearGradientProps } from \"@xsolla/xui-primitives-core\";\n\nfunction buildCssGradient(\n colors: string[],\n start: { x: number; y: number },\n end: { x: number; y: number },\n locations?: number[]\n): string {\n const dx = end.x - start.x;\n const dy = end.y - start.y;\n const angle = Math.round((Math.atan2(dx, -dy) * 180) / Math.PI);\n\n const stops = colors\n .map((color, i) => {\n const pct = locations\n ? locations[i] * 100\n : (i / (colors.length - 1)) * 100;\n return `${color} ${pct}%`;\n })\n .join(\", \");\n\n return `linear-gradient(${angle}deg, ${stops})`;\n}\n\nconst StyledGradient = styled.div<{ $gradient: string }>`\n background: ${(props) => props.$gradient};\n`;\n\nexport const LinearGradient: React.FC<LinearGradientProps> = ({\n colors,\n start = { x: 0, y: 0 },\n end = { x: 0, y: 1 },\n locations,\n children,\n position,\n top,\n bottom,\n left,\n right,\n width,\n height,\n borderRadius,\n overflow,\n zIndex,\n style,\n \"data-testid\": dataTestId,\n}) => {\n const gradient = buildCssGradient(colors, start, end, locations);\n\n const containerStyle: React.CSSProperties = {\n position: position || undefined,\n top: typeof top === \"number\" ? `${top}px` : top,\n bottom: typeof bottom === \"number\" ? `${bottom}px` : bottom,\n left: typeof left === \"number\" ? `${left}px` : left,\n right: typeof right === \"number\" ? `${right}px` : right,\n width: typeof width === \"number\" ? `${width}px` : width,\n height: typeof height === \"number\" ? `${height}px` : height,\n borderRadius:\n typeof borderRadius === \"number\" ? `${borderRadius}px` : borderRadius,\n overflow,\n zIndex,\n ...style,\n };\n\n return (\n <StyledGradient\n $gradient={gradient}\n style={containerStyle}\n data-testid={dataTestId}\n >\n {children}\n </StyledGradient>\n );\n};\n","export * from \"./Box\";\nexport * from \"./Text\";\nexport * from \"./Spinner\";\nexport * from \"./Icon\";\nexport * from \"./Divider\";\nexport * from \"./Input\";\nexport * from \"./TextArea\";\nexport * from \"./LinearGradient\";\n\nexport const isWeb = true;\nexport const isNative = false;\n"],"mappings":"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","names":["import_react","import_react","React","styled","React","import_styled_components","import_jsx_runtime","styled","import_styled_components","import_jsx_runtime","styled","import_jsx_runtime"]}
|
|
1
|
+
{"version":3,"sources":["../../src/index.tsx","../../src/GameCard.tsx","../../../../foundation/primitives-web/src/Box.tsx","../../../../foundation/primitives-web/src/filterDOMProps.ts","../../../../../node_modules/@emotion/memoize/dist/memoize.esm.js","../../../../../node_modules/@emotion/is-prop-valid/dist/is-prop-valid.esm.js","../../../../foundation/primitives-web/src/Text.tsx","../../../../foundation/primitives-web/src/LinearGradient.tsx","../../../../foundation/primitives-web/src/index.tsx"],"sourcesContent":["export * from \"./GameCard\";\nexport * from \"./types\";\n","import React, { useState } from \"react\";\n// @ts-expect-error - this will be resolved at build time\nimport { Box, Text, LinearGradient, isWeb } from \"@xsolla/xui-primitives\";\nimport { useResolvedTheme } from \"@xsolla/xui-core\";\nimport type {\n GameCardProps,\n GameCardSize,\n GameCardImageRatio,\n GameCardPlatform,\n GameCardLayout,\n} from \"./types\";\n\nconst IMAGE_RATIOS: Record<Exclude<GameCardImageRatio, \"custom\">, number> = {\n \"16:9\": 240 / 135,\n \"1:1\": 1,\n \"2:3\": 240 / 360,\n \"3:2\": 240 / 160,\n \"4:3\": 360 / 270,\n \"9:16\": 135 / 240,\n};\n\nconst BORDER_RADIUS = 8;\nconst TAG_INSET = 8;\nconst TAG_GAP = 4;\n\ninterface SizeConfig {\n titleFontSize: number;\n titleLineHeight: number;\n subtitleFontSize: number;\n subtitleLineHeight: number;\n}\n\nconst getSizeConfig = (\n size: GameCardSize,\n platform: GameCardPlatform\n): SizeConfig => {\n const isDesktop = platform === \"desktop\";\n switch (size) {\n case \"lg\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"md\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"sm\":\n return {\n titleFontSize: 12,\n titleLineHeight: 16,\n subtitleFontSize: 10,\n subtitleLineHeight: 14,\n };\n }\n};\n\nconst getFooterPadding = (platform: GameCardPlatform): number =>\n platform === \"desktop\" ? 16 : 12;\n\nconst getFooterGap = (): number => 12;\n\nconst resolveAspectRatio = (\n imageRatio: GameCardImageRatio,\n customWidth?: number,\n customHeight?: number\n): number => {\n if (imageRatio === \"custom\" && customWidth && customHeight) {\n return customWidth / customHeight;\n }\n return (\n IMAGE_RATIOS[imageRatio as Exclude<GameCardImageRatio, \"custom\">] ??\n IMAGE_RATIOS[\"16:9\"]\n );\n};\n\nconst ellipsisStyle = isWeb\n ? {\n overflow: \"hidden\" as const,\n textOverflow: \"ellipsis\" as const,\n whiteSpace: \"nowrap\" as const,\n }\n : undefined;\n\nexport const GameCard: React.FC<GameCardProps> = ({\n image,\n title,\n subtitle,\n size = \"lg\",\n imageRatio = \"16:9\",\n customImageWidth,\n customImageHeight,\n badge,\n tagsTopLeft,\n tagsTopRight,\n tagsBottomLeft,\n tagsBottomRight,\n trailing,\n buttonText,\n onButtonClick,\n buttonDisabled,\n layout = \"horizontal\",\n platform = \"mobile\",\n hideFooter = false,\n hoverContent,\n onPress,\n imageAlt,\n className,\n testID,\n themeMode,\n themeProductContext,\n}) => {\n const { theme } = useResolvedTheme({ themeMode, themeProductContext });\n const config = getSizeConfig(size, platform);\n const footerPadding = getFooterPadding(platform);\n const footerGap = getFooterGap();\n const aspectRatio = resolveAspectRatio(\n imageRatio,\n customImageWidth,\n customImageHeight\n );\n\n const [isHovered, setIsHovered] = useState(false);\n\n const wrapperProps = onPress ? { onPress } : {};\n const hoverHandlers =\n isWeb && hoverContent\n ? {\n onMouseEnter: () => setIsHovered(true),\n onMouseLeave: () => setIsHovered(false),\n }\n : {};\n\n const isHorizontal = layout === \"horizontal\";\n\n const renderPlaceholder = () => (\n <Box\n width=\"100%\"\n height=\"100%\"\n backgroundColor={theme.colors.background.secondary}\n alignItems=\"center\"\n justifyContent=\"center\"\n >\n <Box\n width={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n height={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n alignItems=\"center\"\n justifyContent=\"center\"\n style={{ opacity: 0.4 }}\n >\n <Text\n color={theme.colors.content.tertiary}\n fontSize={24}\n style={{ textAlign: \"center\" as const }}\n >\n {\"\\u{1F5BC}\"}\n </Text>\n </Box>\n </Box>\n );\n\n const renderImage = () => (\n <Box\n position=\"relative\"\n width=\"100%\"\n overflow=\"hidden\"\n style={{ aspectRatio }}\n {...hoverHandlers}\n >\n {image ? (\n <>\n <Box\n as=\"img\"\n src={image}\n alt={imageAlt || title}\n position=\"absolute\"\n top={0}\n left={0}\n width=\"100%\"\n height=\"100%\"\n style={\n isWeb\n ? {\n objectFit: \"cover\" as const,\n pointerEvents: \"none\" as const,\n }\n : undefined\n }\n />\n <LinearGradient\n colors={[\"transparent\", \"rgba(0, 0, 0, 0.48)\"]}\n start={{ x: 0, y: 0 }}\n end={{ x: 0, y: 1 }}\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height=\"100%\"\n style={{ maxHeight: 206 }}\n />\n </>\n ) : (\n renderPlaceholder()\n )}\n\n {/* Tag zones */}\n {(badge || tagsTopLeft) && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {badge}\n {tagsTopLeft}\n </Box>\n )}\n\n {tagsTopRight && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsTopRight}\n </Box>\n )}\n\n {tagsBottomLeft && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {tagsBottomLeft}\n </Box>\n )}\n\n {tagsBottomRight && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsBottomRight}\n </Box>\n )}\n\n {/* Hover overlay */}\n {isWeb && hoverContent && isHovered && (\n <Box\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height={72}\n flexDirection=\"row\"\n alignItems=\"center\"\n gap={8}\n padding={16}\n borderRadius={4}\n overflow=\"hidden\"\n style={{\n backdropFilter: \"blur(15px)\",\n WebkitBackdropFilter: \"blur(15px)\",\n backgroundColor: theme.colors.layer.float,\n }}\n >\n {hoverContent}\n </Box>\n )}\n </Box>\n );\n\n const renderFooter = () => (\n <Box\n backgroundColor={theme.colors.overlay.mono}\n padding={footerPadding}\n flexDirection={isHorizontal ? \"row\" : \"column\"}\n alignItems={isHorizontal ? \"center\" : \"flex-start\"}\n justifyContent={isHorizontal ? undefined : \"center\"}\n gap={footerGap}\n >\n <Box\n flex={isHorizontal ? 1 : undefined}\n width={isHorizontal ? undefined : \"100%\"}\n flexDirection=\"column\"\n style={{ minWidth: 0 }}\n >\n <Text\n color={theme.colors.content.primary}\n fontSize={config.titleFontSize}\n lineHeight={config.titleLineHeight}\n fontWeight=\"500\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {title}\n </Text>\n {subtitle && (\n <Text\n color={theme.colors.content.tertiary}\n fontSize={config.subtitleFontSize}\n lineHeight={config.subtitleLineHeight}\n fontWeight=\"400\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {subtitle}\n </Text>\n )}\n </Box>\n\n {trailing}\n {!trailing && buttonText && (\n <Box\n onPress={buttonDisabled ? undefined : onButtonClick}\n backgroundColor={theme.colors.control.mono.secondary.bg}\n borderRadius={BORDER_RADIUS}\n height={40}\n paddingHorizontal={20}\n alignItems=\"center\"\n justifyContent=\"center\"\n style={\n isWeb\n ? {\n opacity: buttonDisabled ? 0.4 : 1,\n backdropFilter: \"blur(30px)\",\n WebkitBackdropFilter: \"blur(30px)\",\n border: `1px solid ${theme.colors.control.mono.secondary.border}`,\n cursor: buttonDisabled\n ? \"not-allowed\"\n : onButtonClick\n ? \"pointer\"\n : \"default\",\n }\n : { opacity: buttonDisabled ? 0.4 : 1 }\n }\n >\n <Text\n color={theme.colors.control.mono.text.secondary}\n fontSize={14}\n lineHeight={18}\n fontWeight=\"500\"\n style={{ letterSpacing: 0.4 }}\n >\n {buttonText}\n </Text>\n </Box>\n )}\n </Box>\n );\n\n return (\n <Box\n testID={testID}\n className={className}\n flexDirection=\"column\"\n width=\"100%\"\n {...wrapperProps}\n >\n <Box\n borderRadius={BORDER_RADIUS}\n overflow=\"hidden\"\n flexDirection=\"column\"\n style={\n isWeb\n ? {\n borderRadius: `${BORDER_RADIUS}px`,\n overflow: \"hidden\",\n border: `1px solid ${theme.colors.border.secondary}`,\n }\n : {\n borderRadius: BORDER_RADIUS,\n overflow: \"hidden\",\n borderWidth: 1,\n borderColor: theme.colors.border.secondary,\n }\n }\n >\n {renderImage()}\n {!hideFooter && renderFooter()}\n </Box>\n </Box>\n );\n};\n","import React from \"react\";\nimport styled from \"styled-components\";\nimport type { BoxProps } from \"@xsolla/xui-primitives-core\";\nimport { createFilteredElement } from \"./filterDOMProps\";\n\nconst FilteredDiv = createFilteredElement(\"div\");\n\nconst StyledBox = styled(FilteredDiv)<BoxProps>`\n display: flex;\n box-sizing: border-box;\n background-color: ${(props) => props.backgroundColor || \"transparent\"};\n border-color: ${(props) => props.borderColor || \"transparent\"};\n border-width: ${(props) =>\n typeof props.borderWidth === \"number\"\n ? `${props.borderWidth}px`\n : props.borderWidth || 0};\n\n ${(props) =>\n props.borderBottomWidth !== undefined &&\n `\n border-bottom-width: ${typeof props.borderBottomWidth === \"number\" ? `${props.borderBottomWidth}px` : props.borderBottomWidth};\n border-bottom-color: ${props.borderBottomColor || props.borderColor || \"transparent\"};\n border-bottom-style: solid;\n `}\n ${(props) =>\n props.borderTopWidth !== undefined &&\n `\n border-top-width: ${typeof props.borderTopWidth === \"number\" ? `${props.borderTopWidth}px` : props.borderTopWidth};\n border-top-color: ${props.borderTopColor || props.borderColor || \"transparent\"};\n border-top-style: solid;\n `}\n ${(props) =>\n props.borderLeftWidth !== undefined &&\n `\n border-left-width: ${typeof props.borderLeftWidth === \"number\" ? `${props.borderLeftWidth}px` : props.borderLeftWidth};\n border-left-color: ${props.borderLeftColor || props.borderColor || \"transparent\"};\n border-left-style: solid;\n `}\n ${(props) =>\n props.borderRightWidth !== undefined &&\n `\n border-right-width: ${typeof props.borderRightWidth === \"number\" ? `${props.borderRightWidth}px` : props.borderRightWidth};\n border-right-color: ${props.borderRightColor || props.borderColor || \"transparent\"};\n border-right-style: solid;\n `}\n\n border-style: ${(props) =>\n props.borderStyle ||\n (props.borderWidth ||\n props.borderBottomWidth ||\n props.borderTopWidth ||\n props.borderLeftWidth ||\n props.borderRightWidth\n ? \"solid\"\n : \"none\")};\n border-radius: ${(props) =>\n typeof props.borderRadius === \"number\"\n ? `${props.borderRadius}px`\n : props.borderRadius || 0};\n height: ${(props) =>\n typeof props.height === \"number\"\n ? `${props.height}px`\n : props.height || \"auto\"};\n width: ${(props) =>\n typeof props.width === \"number\"\n ? `${props.width}px`\n : props.width || \"auto\"};\n min-width: ${(props) =>\n typeof props.minWidth === \"number\"\n ? `${props.minWidth}px`\n : props.minWidth || \"auto\"};\n min-height: ${(props) =>\n typeof props.minHeight === \"number\"\n ? `${props.minHeight}px`\n : props.minHeight || \"auto\"};\n max-width: ${(props) =>\n typeof props.maxWidth === \"number\"\n ? `${props.maxWidth}px`\n : props.maxWidth || \"none\"};\n max-height: ${(props) =>\n typeof props.maxHeight === \"number\"\n ? `${props.maxHeight}px`\n : props.maxHeight || \"none\"};\n\n padding: ${(props) =>\n typeof props.padding === \"number\"\n ? `${props.padding}px`\n : props.padding || 0};\n ${(props) =>\n props.paddingHorizontal &&\n `\n padding-left: ${typeof props.paddingHorizontal === \"number\" ? `${props.paddingHorizontal}px` : props.paddingHorizontal};\n padding-right: ${typeof props.paddingHorizontal === \"number\" ? `${props.paddingHorizontal}px` : props.paddingHorizontal};\n `}\n ${(props) =>\n props.paddingVertical &&\n `\n padding-top: ${typeof props.paddingVertical === \"number\" ? `${props.paddingVertical}px` : props.paddingVertical};\n padding-bottom: ${typeof props.paddingVertical === \"number\" ? `${props.paddingVertical}px` : props.paddingVertical};\n `}\n ${(props) =>\n props.paddingTop !== undefined &&\n `padding-top: ${typeof props.paddingTop === \"number\" ? `${props.paddingTop}px` : props.paddingTop};`}\n ${(props) =>\n props.paddingBottom !== undefined &&\n `padding-bottom: ${typeof props.paddingBottom === \"number\" ? `${props.paddingBottom}px` : props.paddingBottom};`}\n ${(props) =>\n props.paddingLeft !== undefined &&\n `padding-left: ${typeof props.paddingLeft === \"number\" ? `${props.paddingLeft}px` : props.paddingLeft};`}\n ${(props) =>\n props.paddingRight !== undefined &&\n `padding-right: ${typeof props.paddingRight === \"number\" ? `${props.paddingRight}px` : props.paddingRight};`}\n\n margin: ${(props) =>\n typeof props.margin === \"number\" ? `${props.margin}px` : props.margin || 0};\n ${(props) =>\n props.marginTop !== undefined &&\n `margin-top: ${typeof props.marginTop === \"number\" ? `${props.marginTop}px` : props.marginTop};`}\n ${(props) =>\n props.marginBottom !== undefined &&\n `margin-bottom: ${typeof props.marginBottom === \"number\" ? `${props.marginBottom}px` : props.marginBottom};`}\n ${(props) =>\n props.marginLeft !== undefined &&\n `margin-left: ${typeof props.marginLeft === \"number\" ? `${props.marginLeft}px` : props.marginLeft};`}\n ${(props) =>\n props.marginRight !== undefined &&\n `margin-right: ${typeof props.marginRight === \"number\" ? `${props.marginRight}px` : props.marginRight};`}\n\n flex-direction: ${(props) => props.flexDirection || \"column\"};\n flex-wrap: ${(props) => props.flexWrap || \"nowrap\"};\n align-items: ${(props) => props.alignItems || \"stretch\"};\n justify-content: ${(props) => props.justifyContent || \"flex-start\"};\n cursor: ${(props) =>\n props.cursor\n ? props.cursor\n : props.onClick || props.onPress\n ? \"pointer\"\n : \"inherit\"};\n position: ${(props) => props.position || \"static\"};\n top: ${(props) =>\n typeof props.top === \"number\" ? `${props.top}px` : props.top};\n bottom: ${(props) =>\n typeof props.bottom === \"number\" ? `${props.bottom}px` : props.bottom};\n left: ${(props) =>\n typeof props.left === \"number\" ? `${props.left}px` : props.left};\n right: ${(props) =>\n typeof props.right === \"number\" ? `${props.right}px` : props.right};\n flex: ${(props) => props.flex};\n flex-shrink: ${(props) => props.flexShrink ?? 1};\n gap: ${(props) =>\n typeof props.gap === \"number\" ? `${props.gap}px` : props.gap || 0};\n align-self: ${(props) => props.alignSelf || \"auto\"};\n overflow: ${(props) => props.overflow || \"visible\"};\n overflow-x: ${(props) => props.overflowX || \"visible\"};\n overflow-y: ${(props) => props.overflowY || \"visible\"};\n z-index: ${(props) => props.zIndex};\n opacity: ${(props) => (props.disabled ? 0.5 : 1)};\n pointer-events: ${(props) => (props.disabled ? \"none\" : \"auto\")};\n\n &:hover {\n ${(props) =>\n props.hoverStyle?.backgroundColor &&\n `background-color: ${props.hoverStyle.backgroundColor};`}\n ${(props) =>\n props.hoverStyle?.borderColor &&\n `border-color: ${props.hoverStyle.borderColor};`}\n }\n\n &:active {\n ${(props) =>\n props.pressStyle?.backgroundColor &&\n `background-color: ${props.pressStyle.backgroundColor};`}\n }\n`;\n\nexport const Box = React.forwardRef<\n HTMLDivElement | HTMLButtonElement,\n BoxProps\n>(\n (\n {\n children,\n onPress,\n onKeyDown,\n onKeyUp,\n role,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n \"aria-current\": ariaCurrent,\n \"aria-disabled\": ariaDisabled,\n \"aria-live\": ariaLive,\n \"aria-busy\": ariaBusy,\n \"aria-describedby\": ariaDescribedBy,\n \"aria-expanded\": ariaExpanded,\n \"aria-haspopup\": ariaHasPopup,\n \"aria-pressed\": ariaPressed,\n \"aria-controls\": ariaControls,\n tabIndex,\n as,\n src,\n alt,\n onError,\n onLoad,\n type,\n disabled,\n id,\n testID,\n \"data-testid\": dataTestId,\n ...props\n },\n ref\n ) => {\n // Handle as=\"img\" for rendering images with proper border-radius\n if (as === \"img\" && src) {\n return (\n <img\n src={src}\n alt={alt || \"\"}\n onError={onError}\n onLoad={onLoad}\n style={{\n display: \"block\",\n objectFit: \"cover\",\n width:\n typeof props.width === \"number\"\n ? `${props.width}px`\n : props.width,\n height:\n typeof props.height === \"number\"\n ? `${props.height}px`\n : props.height,\n borderRadius:\n typeof props.borderRadius === \"number\"\n ? `${props.borderRadius}px`\n : props.borderRadius,\n position: props.position,\n top: typeof props.top === \"number\" ? `${props.top}px` : props.top,\n left:\n typeof props.left === \"number\" ? `${props.left}px` : props.left,\n right:\n typeof props.right === \"number\"\n ? `${props.right}px`\n : props.right,\n bottom:\n typeof props.bottom === \"number\"\n ? `${props.bottom}px`\n : props.bottom,\n ...props.style,\n }}\n />\n );\n }\n\n return (\n <StyledBox\n ref={ref}\n elementType={as}\n id={id}\n type={as === \"button\" ? type || \"button\" : undefined}\n disabled={as === \"button\" ? disabled : undefined}\n onClick={onPress}\n onKeyDown={onKeyDown}\n onKeyUp={onKeyUp}\n role={role}\n aria-label={ariaLabel}\n aria-labelledby={ariaLabelledBy}\n aria-current={ariaCurrent}\n aria-disabled={ariaDisabled}\n aria-busy={ariaBusy}\n aria-describedby={ariaDescribedBy}\n aria-expanded={ariaExpanded}\n aria-haspopup={ariaHasPopup}\n aria-pressed={ariaPressed}\n aria-controls={ariaControls}\n aria-live={ariaLive}\n tabIndex={tabIndex !== undefined ? tabIndex : undefined}\n data-testid={dataTestId || testID}\n {...props}\n >\n {children}\n </StyledBox>\n );\n }\n);\n\nBox.displayName = \"Box\";\n","import React from \"react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\n// Props that @emotion/is-prop-valid incorrectly treats as valid HTML.\n// These are React Native or component-specific props that match\n// valid HTML patterns (on* event handlers, SVG attributes).\nexport const ADDITIONAL_BLOCKED_PROPS = new Set([\n // RN-only event handlers (pass isPropValid's on* pattern)\n \"onPress\",\n \"onChangeText\",\n \"onLayout\",\n \"onMoveShouldSetResponder\",\n \"onResponderGrant\",\n \"onResponderMove\",\n \"onResponderRelease\",\n \"onResponderTerminate\",\n // SVG attributes that pass isPropValid\n \"strokeWidth\",\n // CSS properties that pass isPropValid but are used as component props\n \"overflow\",\n \"cursor\",\n \"fontSize\",\n \"fontWeight\",\n \"fontFamily\",\n \"textDecoration\",\n]);\n\nfunction shouldForwardProp(key: string): boolean {\n if (ADDITIONAL_BLOCKED_PROPS.has(key)) return false;\n return isPropValid(key);\n}\n\n/**\n * Creates a React component that renders the given HTML tag\n * but filters out non-HTML props before they reach the DOM.\n *\n * Uses @emotion/is-prop-valid (same library styled-components v4\n * uses internally) to automatically block invalid HTML attributes,\n * plus a small blocklist for false positives (RN on* handlers, SVG attrs).\n *\n * Usage: `const FilteredDiv = createFilteredElement(\"div\");`\n * Then: `const StyledBox = styled(FilteredDiv)<BoxProps>\\`...\\`;`\n *\n * styled-components can still read ALL props for CSS interpolation,\n * but only valid HTML attributes are forwarded to the DOM element.\n */\nexport function createFilteredElement(defaultTag: string) {\n const Component = React.forwardRef<HTMLElement, Record<string, unknown>>(\n ({ children, elementType, ...props }, ref) => {\n const Tag = (elementType as string) || defaultTag;\n const htmlProps: Record<string, unknown> = {};\n for (const key of Object.keys(props)) {\n if (shouldForwardProp(key)) {\n htmlProps[key] = props[key];\n }\n }\n return React.createElement(\n Tag,\n { ref, ...htmlProps },\n children as React.ReactNode\n );\n }\n );\n Component.displayName = `Filtered(${defaultTag})`;\n return Component;\n}\n","function memoize(fn) {\n var cache = {};\n return function (arg) {\n if (cache[arg] === undefined) cache[arg] = fn(arg);\n return cache[arg];\n };\n}\n\nexport default memoize;\n","import memoize from '@emotion/memoize';\n\nvar reactPropsRegex = /^((children|dangerouslySetInnerHTML|key|ref|autoFocus|defaultValue|defaultChecked|innerHTML|suppressContentEditableWarning|suppressHydrationWarning|valueLink|accept|acceptCharset|accessKey|action|allow|allowUserMedia|allowPaymentRequest|allowFullScreen|allowTransparency|alt|async|autoComplete|autoPlay|capture|cellPadding|cellSpacing|challenge|charSet|checked|cite|classID|className|cols|colSpan|content|contentEditable|contextMenu|controls|controlsList|coords|crossOrigin|data|dateTime|decoding|default|defer|dir|disabled|disablePictureInPicture|download|draggable|encType|form|formAction|formEncType|formMethod|formNoValidate|formTarget|frameBorder|headers|height|hidden|high|href|hrefLang|htmlFor|httpEquiv|id|inputMode|integrity|is|keyParams|keyType|kind|label|lang|list|loading|loop|low|marginHeight|marginWidth|max|maxLength|media|mediaGroup|method|min|minLength|multiple|muted|name|nonce|noValidate|open|optimum|pattern|placeholder|playsInline|poster|preload|profile|radioGroup|readOnly|referrerPolicy|rel|required|reversed|role|rows|rowSpan|sandbox|scope|scoped|scrolling|seamless|selected|shape|size|sizes|slot|span|spellCheck|src|srcDoc|srcLang|srcSet|start|step|style|summary|tabIndex|target|title|type|useMap|value|width|wmode|wrap|about|datatype|inlist|prefix|property|resource|typeof|vocab|autoCapitalize|autoCorrect|autoSave|color|inert|itemProp|itemScope|itemType|itemID|itemRef|on|results|security|unselectable|accentHeight|accumulate|additive|alignmentBaseline|allowReorder|alphabetic|amplitude|arabicForm|ascent|attributeName|attributeType|autoReverse|azimuth|baseFrequency|baselineShift|baseProfile|bbox|begin|bias|by|calcMode|capHeight|clip|clipPathUnits|clipPath|clipRule|colorInterpolation|colorInterpolationFilters|colorProfile|colorRendering|contentScriptType|contentStyleType|cursor|cx|cy|d|decelerate|descent|diffuseConstant|direction|display|divisor|dominantBaseline|dur|dx|dy|edgeMode|elevation|enableBackground|end|exponent|externalResourcesRequired|fill|fillOpacity|fillRule|filter|filterRes|filterUnits|floodColor|floodOpacity|focusable|fontFamily|fontSize|fontSizeAdjust|fontStretch|fontStyle|fontVariant|fontWeight|format|from|fr|fx|fy|g1|g2|glyphName|glyphOrientationHorizontal|glyphOrientationVertical|glyphRef|gradientTransform|gradientUnits|hanging|horizAdvX|horizOriginX|ideographic|imageRendering|in|in2|intercept|k|k1|k2|k3|k4|kernelMatrix|kernelUnitLength|kerning|keyPoints|keySplines|keyTimes|lengthAdjust|letterSpacing|lightingColor|limitingConeAngle|local|markerEnd|markerMid|markerStart|markerHeight|markerUnits|markerWidth|mask|maskContentUnits|maskUnits|mathematical|mode|numOctaves|offset|opacity|operator|order|orient|orientation|origin|overflow|overlinePosition|overlineThickness|panose1|paintOrder|pathLength|patternContentUnits|patternTransform|patternUnits|pointerEvents|points|pointsAtX|pointsAtY|pointsAtZ|preserveAlpha|preserveAspectRatio|primitiveUnits|r|radius|refX|refY|renderingIntent|repeatCount|repeatDur|requiredExtensions|requiredFeatures|restart|result|rotate|rx|ry|scale|seed|shapeRendering|slope|spacing|specularConstant|specularExponent|speed|spreadMethod|startOffset|stdDeviation|stemh|stemv|stitchTiles|stopColor|stopOpacity|strikethroughPosition|strikethroughThickness|string|stroke|strokeDasharray|strokeDashoffset|strokeLinecap|strokeLinejoin|strokeMiterlimit|strokeOpacity|strokeWidth|surfaceScale|systemLanguage|tableValues|targetX|targetY|textAnchor|textDecoration|textRendering|textLength|to|transform|u1|u2|underlinePosition|underlineThickness|unicode|unicodeBidi|unicodeRange|unitsPerEm|vAlphabetic|vHanging|vIdeographic|vMathematical|values|vectorEffect|version|vertAdvY|vertOriginX|vertOriginY|viewBox|viewTarget|visibility|widths|wordSpacing|writingMode|x|xHeight|x1|x2|xChannelSelector|xlinkActuate|xlinkArcrole|xlinkHref|xlinkRole|xlinkShow|xlinkTitle|xlinkType|xmlBase|xmlns|xmlnsXlink|xmlLang|xmlSpace|y|y1|y2|yChannelSelector|z|zoomAndPan|for|class|autofocus)|(([Dd][Aa][Tt][Aa]|[Aa][Rr][Ii][Aa]|x)-.*))$/; // https://esbench.com/bench/5bfee68a4cd7e6009ef61d23\n\nvar index = memoize(function (prop) {\n return reactPropsRegex.test(prop) || prop.charCodeAt(0) === 111\n /* o */\n && prop.charCodeAt(1) === 110\n /* n */\n && prop.charCodeAt(2) < 91;\n}\n/* Z+1 */\n);\n\nexport default index;\n","import React from \"react\";\nimport styled from \"styled-components\";\nimport { TextProps } from \"@xsolla/xui-primitives-core\";\nimport { createFilteredElement } from \"./filterDOMProps\";\n\nconst FilteredSpan = createFilteredElement(\"span\");\n\nconst StyledText = styled(FilteredSpan)<TextProps>`\n color: ${(props) => props.color || \"inherit\"};\n font-size: ${(props) =>\n typeof props.fontSize === \"number\"\n ? `${props.fontSize}px`\n : props.fontSize || \"inherit\"};\n font-weight: ${(props) => props.fontWeight || \"normal\"};\n font-family: ${(props) =>\n props.fontFamily ||\n '\"Aktiv Grotesk\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif'};\n line-height: ${(props) =>\n typeof props.lineHeight === \"number\"\n ? `${props.lineHeight}px`\n : props.lineHeight || \"inherit\"};\n white-space: ${(props) => props.whiteSpace || \"normal\"};\n text-align: ${(props) => props.textAlign || \"inherit\"};\n text-decoration: ${(props) => props.textDecoration || \"none\"};\n`;\n\nexport const Text: React.FC<TextProps> = ({\n style,\n className,\n id,\n role,\n testID,\n \"data-testid\": dataTestId,\n numberOfLines: _numberOfLines,\n ...props\n}) => {\n return (\n <StyledText\n {...props}\n style={style}\n className={className}\n id={id}\n role={role}\n data-testid={dataTestId || testID}\n />\n );\n};\n","import React from \"react\";\nimport styled from \"styled-components\";\nimport type { LinearGradientProps } from \"@xsolla/xui-primitives-core\";\n\nfunction buildCssGradient(\n colors: string[],\n start: { x: number; y: number },\n end: { x: number; y: number },\n locations?: number[]\n): string {\n const dx = end.x - start.x;\n const dy = end.y - start.y;\n const angle = Math.round((Math.atan2(dx, -dy) * 180) / Math.PI);\n\n const stops = colors\n .map((color, i) => {\n const pct = locations\n ? locations[i] * 100\n : (i / (colors.length - 1)) * 100;\n return `${color} ${pct}%`;\n })\n .join(\", \");\n\n return `linear-gradient(${angle}deg, ${stops})`;\n}\n\nconst StyledGradient = styled.div<{ $gradient: string }>`\n background: ${(props) => props.$gradient};\n`;\n\nexport const LinearGradient: React.FC<LinearGradientProps> = ({\n colors,\n start = { x: 0, y: 0 },\n end = { x: 0, y: 1 },\n locations,\n children,\n position,\n top,\n bottom,\n left,\n right,\n width,\n height,\n borderRadius,\n overflow,\n zIndex,\n style,\n \"data-testid\": dataTestId,\n}) => {\n const gradient = buildCssGradient(colors, start, end, locations);\n\n const containerStyle: React.CSSProperties = {\n position: position || undefined,\n top: typeof top === \"number\" ? `${top}px` : top,\n bottom: typeof bottom === \"number\" ? `${bottom}px` : bottom,\n left: typeof left === \"number\" ? `${left}px` : left,\n right: typeof right === \"number\" ? `${right}px` : right,\n width: typeof width === \"number\" ? `${width}px` : width,\n height: typeof height === \"number\" ? `${height}px` : height,\n borderRadius:\n typeof borderRadius === \"number\" ? `${borderRadius}px` : borderRadius,\n overflow,\n zIndex,\n ...style,\n };\n\n return (\n <StyledGradient\n $gradient={gradient}\n style={containerStyle}\n data-testid={dataTestId}\n >\n {children}\n </StyledGradient>\n );\n};\n","export * from \"./Box\";\nexport * from \"./Text\";\nexport * from \"./Spinner\";\nexport * from \"./Icon\";\nexport * from \"./Divider\";\nexport * from \"./Input\";\nexport * from \"./TextArea\";\nexport * from \"./LinearGradient\";\n\nexport const isWeb = true;\nexport const isNative = false;\n"],"mappings":"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","names":["import_react","import_react","React","styled","React","import_styled_components","import_jsx_runtime","styled","import_styled_components","import_jsx_runtime","styled","import_jsx_runtime"]}
|
package/web/index.mjs
CHANGED
|
@@ -213,7 +213,8 @@ var Box = React2.forwardRef(
|
|
|
213
213
|
top: typeof props.top === "number" ? `${props.top}px` : props.top,
|
|
214
214
|
left: typeof props.left === "number" ? `${props.left}px` : props.left,
|
|
215
215
|
right: typeof props.right === "number" ? `${props.right}px` : props.right,
|
|
216
|
-
bottom: typeof props.bottom === "number" ? `${props.bottom}px` : props.bottom
|
|
216
|
+
bottom: typeof props.bottom === "number" ? `${props.bottom}px` : props.bottom,
|
|
217
|
+
...props.style
|
|
217
218
|
}
|
|
218
219
|
}
|
|
219
220
|
);
|
|
@@ -270,6 +271,8 @@ var Text = ({
|
|
|
270
271
|
className,
|
|
271
272
|
id,
|
|
272
273
|
role,
|
|
274
|
+
testID,
|
|
275
|
+
"data-testid": dataTestId,
|
|
273
276
|
numberOfLines: _numberOfLines,
|
|
274
277
|
...props
|
|
275
278
|
}) => {
|
|
@@ -280,7 +283,8 @@ var Text = ({
|
|
|
280
283
|
style,
|
|
281
284
|
className,
|
|
282
285
|
id,
|
|
283
|
-
role
|
|
286
|
+
role,
|
|
287
|
+
"data-testid": dataTestId || testID
|
|
284
288
|
}
|
|
285
289
|
);
|
|
286
290
|
};
|
|
@@ -425,6 +429,7 @@ var GameCard = ({
|
|
|
425
429
|
onPress,
|
|
426
430
|
imageAlt,
|
|
427
431
|
className,
|
|
432
|
+
testID,
|
|
428
433
|
themeMode,
|
|
429
434
|
themeProductContext
|
|
430
435
|
}) => {
|
|
@@ -673,6 +678,7 @@ var GameCard = ({
|
|
|
673
678
|
return /* @__PURE__ */ jsx4(
|
|
674
679
|
Box,
|
|
675
680
|
{
|
|
681
|
+
testID,
|
|
676
682
|
className,
|
|
677
683
|
flexDirection: "column",
|
|
678
684
|
width: "100%",
|
package/web/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/GameCard.tsx","../../../../foundation/primitives-web/src/Box.tsx","../../../../foundation/primitives-web/src/filterDOMProps.ts","../../../../../node_modules/@emotion/memoize/dist/memoize.esm.js","../../../../../node_modules/@emotion/is-prop-valid/dist/is-prop-valid.esm.js","../../../../foundation/primitives-web/src/Text.tsx","../../../../foundation/primitives-web/src/LinearGradient.tsx","../../../../foundation/primitives-web/src/index.tsx"],"sourcesContent":["import React, { useState } from \"react\";\n// @ts-expect-error - this will be resolved at build time\nimport { Box, Text, LinearGradient, isWeb } from \"@xsolla/xui-primitives\";\nimport { useResolvedTheme } from \"@xsolla/xui-core\";\nimport type {\n GameCardProps,\n GameCardSize,\n GameCardImageRatio,\n GameCardPlatform,\n GameCardLayout,\n} from \"./types\";\n\nconst IMAGE_RATIOS: Record<Exclude<GameCardImageRatio, \"custom\">, number> = {\n \"16:9\": 240 / 135,\n \"1:1\": 1,\n \"2:3\": 240 / 360,\n \"3:2\": 240 / 160,\n \"4:3\": 360 / 270,\n \"9:16\": 135 / 240,\n};\n\nconst BORDER_RADIUS = 8;\nconst TAG_INSET = 8;\nconst TAG_GAP = 4;\n\ninterface SizeConfig {\n titleFontSize: number;\n titleLineHeight: number;\n subtitleFontSize: number;\n subtitleLineHeight: number;\n}\n\nconst getSizeConfig = (\n size: GameCardSize,\n platform: GameCardPlatform\n): SizeConfig => {\n const isDesktop = platform === \"desktop\";\n switch (size) {\n case \"lg\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"md\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"sm\":\n return {\n titleFontSize: 12,\n titleLineHeight: 16,\n subtitleFontSize: 10,\n subtitleLineHeight: 14,\n };\n }\n};\n\nconst getFooterPadding = (platform: GameCardPlatform): number =>\n platform === \"desktop\" ? 16 : 12;\n\nconst getFooterGap = (): number => 12;\n\nconst resolveAspectRatio = (\n imageRatio: GameCardImageRatio,\n customWidth?: number,\n customHeight?: number\n): number => {\n if (imageRatio === \"custom\" && customWidth && customHeight) {\n return customWidth / customHeight;\n }\n return (\n IMAGE_RATIOS[imageRatio as Exclude<GameCardImageRatio, \"custom\">] ??\n IMAGE_RATIOS[\"16:9\"]\n );\n};\n\nconst ellipsisStyle = isWeb\n ? {\n overflow: \"hidden\" as const,\n textOverflow: \"ellipsis\" as const,\n whiteSpace: \"nowrap\" as const,\n }\n : undefined;\n\nexport const GameCard: React.FC<GameCardProps> = ({\n image,\n title,\n subtitle,\n size = \"lg\",\n imageRatio = \"16:9\",\n customImageWidth,\n customImageHeight,\n badge,\n tagsTopLeft,\n tagsTopRight,\n tagsBottomLeft,\n tagsBottomRight,\n trailing,\n buttonText,\n onButtonClick,\n buttonDisabled,\n layout = \"horizontal\",\n platform = \"mobile\",\n hideFooter = false,\n hoverContent,\n onPress,\n imageAlt,\n className,\n themeMode,\n themeProductContext,\n}) => {\n const { theme } = useResolvedTheme({ themeMode, themeProductContext });\n const config = getSizeConfig(size, platform);\n const footerPadding = getFooterPadding(platform);\n const footerGap = getFooterGap();\n const aspectRatio = resolveAspectRatio(\n imageRatio,\n customImageWidth,\n customImageHeight\n );\n\n const [isHovered, setIsHovered] = useState(false);\n\n const wrapperProps = onPress ? { onPress } : {};\n const hoverHandlers =\n isWeb && hoverContent\n ? {\n onMouseEnter: () => setIsHovered(true),\n onMouseLeave: () => setIsHovered(false),\n }\n : {};\n\n const isHorizontal = layout === \"horizontal\";\n\n const renderPlaceholder = () => (\n <Box\n width=\"100%\"\n height=\"100%\"\n backgroundColor={theme.colors.background.secondary}\n alignItems=\"center\"\n justifyContent=\"center\"\n >\n <Box\n width={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n height={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n alignItems=\"center\"\n justifyContent=\"center\"\n style={{ opacity: 0.4 }}\n >\n <Text\n color={theme.colors.content.tertiary}\n fontSize={24}\n style={{ textAlign: \"center\" as const }}\n >\n {\"\\u{1F5BC}\"}\n </Text>\n </Box>\n </Box>\n );\n\n const renderImage = () => (\n <Box\n position=\"relative\"\n width=\"100%\"\n overflow=\"hidden\"\n style={{ aspectRatio }}\n {...hoverHandlers}\n >\n {image ? (\n <>\n <Box\n as=\"img\"\n src={image}\n alt={imageAlt || title}\n position=\"absolute\"\n top={0}\n left={0}\n width=\"100%\"\n height=\"100%\"\n style={\n isWeb\n ? {\n objectFit: \"cover\" as const,\n pointerEvents: \"none\" as const,\n }\n : undefined\n }\n />\n <LinearGradient\n colors={[\"transparent\", \"rgba(0, 0, 0, 0.48)\"]}\n start={{ x: 0, y: 0 }}\n end={{ x: 0, y: 1 }}\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height=\"100%\"\n style={{ maxHeight: 206 }}\n />\n </>\n ) : (\n renderPlaceholder()\n )}\n\n {/* Tag zones */}\n {(badge || tagsTopLeft) && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {badge}\n {tagsTopLeft}\n </Box>\n )}\n\n {tagsTopRight && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsTopRight}\n </Box>\n )}\n\n {tagsBottomLeft && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {tagsBottomLeft}\n </Box>\n )}\n\n {tagsBottomRight && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsBottomRight}\n </Box>\n )}\n\n {/* Hover overlay */}\n {isWeb && hoverContent && isHovered && (\n <Box\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height={72}\n flexDirection=\"row\"\n alignItems=\"center\"\n gap={8}\n padding={16}\n borderRadius={4}\n overflow=\"hidden\"\n style={{\n backdropFilter: \"blur(15px)\",\n WebkitBackdropFilter: \"blur(15px)\",\n backgroundColor: theme.colors.layer.float,\n }}\n >\n {hoverContent}\n </Box>\n )}\n </Box>\n );\n\n const renderFooter = () => (\n <Box\n backgroundColor={theme.colors.overlay.mono}\n padding={footerPadding}\n flexDirection={isHorizontal ? \"row\" : \"column\"}\n alignItems={isHorizontal ? \"center\" : \"flex-start\"}\n justifyContent={isHorizontal ? undefined : \"center\"}\n gap={footerGap}\n >\n <Box\n flex={isHorizontal ? 1 : undefined}\n width={isHorizontal ? undefined : \"100%\"}\n flexDirection=\"column\"\n style={{ minWidth: 0 }}\n >\n <Text\n color={theme.colors.content.primary}\n fontSize={config.titleFontSize}\n lineHeight={config.titleLineHeight}\n fontWeight=\"500\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {title}\n </Text>\n {subtitle && (\n <Text\n color={theme.colors.content.tertiary}\n fontSize={config.subtitleFontSize}\n lineHeight={config.subtitleLineHeight}\n fontWeight=\"400\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {subtitle}\n </Text>\n )}\n </Box>\n\n {trailing}\n {!trailing && buttonText && (\n <Box\n onPress={buttonDisabled ? undefined : onButtonClick}\n backgroundColor={theme.colors.control.mono.secondary.bg}\n borderRadius={BORDER_RADIUS}\n height={40}\n paddingHorizontal={20}\n alignItems=\"center\"\n justifyContent=\"center\"\n style={\n isWeb\n ? {\n opacity: buttonDisabled ? 0.4 : 1,\n backdropFilter: \"blur(30px)\",\n WebkitBackdropFilter: \"blur(30px)\",\n border: `1px solid ${theme.colors.control.mono.secondary.border}`,\n cursor: buttonDisabled\n ? \"not-allowed\"\n : onButtonClick\n ? \"pointer\"\n : \"default\",\n }\n : { opacity: buttonDisabled ? 0.4 : 1 }\n }\n >\n <Text\n color={theme.colors.control.mono.text.secondary}\n fontSize={14}\n lineHeight={18}\n fontWeight=\"500\"\n style={{ letterSpacing: 0.4 }}\n >\n {buttonText}\n </Text>\n </Box>\n )}\n </Box>\n );\n\n return (\n <Box\n className={className}\n flexDirection=\"column\"\n width=\"100%\"\n {...wrapperProps}\n >\n <Box\n borderRadius={BORDER_RADIUS}\n overflow=\"hidden\"\n flexDirection=\"column\"\n style={\n isWeb\n ? {\n borderRadius: `${BORDER_RADIUS}px`,\n overflow: \"hidden\",\n border: `1px solid ${theme.colors.border.secondary}`,\n }\n : {\n borderRadius: BORDER_RADIUS,\n overflow: \"hidden\",\n borderWidth: 1,\n borderColor: theme.colors.border.secondary,\n }\n }\n >\n {renderImage()}\n {!hideFooter && renderFooter()}\n </Box>\n </Box>\n );\n};\n","import React from \"react\";\nimport styled from \"styled-components\";\nimport type { BoxProps } from \"@xsolla/xui-primitives-core\";\nimport { createFilteredElement } from \"./filterDOMProps\";\n\nconst FilteredDiv = createFilteredElement(\"div\");\n\nconst StyledBox = styled(FilteredDiv)<BoxProps>`\n display: flex;\n box-sizing: border-box;\n background-color: ${(props) => props.backgroundColor || \"transparent\"};\n border-color: ${(props) => props.borderColor || \"transparent\"};\n border-width: ${(props) =>\n typeof props.borderWidth === \"number\"\n ? `${props.borderWidth}px`\n : props.borderWidth || 0};\n\n ${(props) =>\n props.borderBottomWidth !== undefined &&\n `\n border-bottom-width: ${typeof props.borderBottomWidth === \"number\" ? `${props.borderBottomWidth}px` : props.borderBottomWidth};\n border-bottom-color: ${props.borderBottomColor || props.borderColor || \"transparent\"};\n border-bottom-style: solid;\n `}\n ${(props) =>\n props.borderTopWidth !== undefined &&\n `\n border-top-width: ${typeof props.borderTopWidth === \"number\" ? `${props.borderTopWidth}px` : props.borderTopWidth};\n border-top-color: ${props.borderTopColor || props.borderColor || \"transparent\"};\n border-top-style: solid;\n `}\n ${(props) =>\n props.borderLeftWidth !== undefined &&\n `\n border-left-width: ${typeof props.borderLeftWidth === \"number\" ? `${props.borderLeftWidth}px` : props.borderLeftWidth};\n border-left-color: ${props.borderLeftColor || props.borderColor || \"transparent\"};\n border-left-style: solid;\n `}\n ${(props) =>\n props.borderRightWidth !== undefined &&\n `\n border-right-width: ${typeof props.borderRightWidth === \"number\" ? `${props.borderRightWidth}px` : props.borderRightWidth};\n border-right-color: ${props.borderRightColor || props.borderColor || \"transparent\"};\n border-right-style: solid;\n `}\n\n border-style: ${(props) =>\n props.borderStyle ||\n (props.borderWidth ||\n props.borderBottomWidth ||\n props.borderTopWidth ||\n props.borderLeftWidth ||\n props.borderRightWidth\n ? \"solid\"\n : \"none\")};\n border-radius: ${(props) =>\n typeof props.borderRadius === \"number\"\n ? `${props.borderRadius}px`\n : props.borderRadius || 0};\n height: ${(props) =>\n typeof props.height === \"number\"\n ? `${props.height}px`\n : props.height || \"auto\"};\n width: ${(props) =>\n typeof props.width === \"number\"\n ? `${props.width}px`\n : props.width || \"auto\"};\n min-width: ${(props) =>\n typeof props.minWidth === \"number\"\n ? `${props.minWidth}px`\n : props.minWidth || \"auto\"};\n min-height: ${(props) =>\n typeof props.minHeight === \"number\"\n ? `${props.minHeight}px`\n : props.minHeight || \"auto\"};\n max-width: ${(props) =>\n typeof props.maxWidth === \"number\"\n ? `${props.maxWidth}px`\n : props.maxWidth || \"none\"};\n max-height: ${(props) =>\n typeof props.maxHeight === \"number\"\n ? `${props.maxHeight}px`\n : props.maxHeight || \"none\"};\n\n padding: ${(props) =>\n typeof props.padding === \"number\"\n ? `${props.padding}px`\n : props.padding || 0};\n ${(props) =>\n props.paddingHorizontal &&\n `\n padding-left: ${typeof props.paddingHorizontal === \"number\" ? `${props.paddingHorizontal}px` : props.paddingHorizontal};\n padding-right: ${typeof props.paddingHorizontal === \"number\" ? `${props.paddingHorizontal}px` : props.paddingHorizontal};\n `}\n ${(props) =>\n props.paddingVertical &&\n `\n padding-top: ${typeof props.paddingVertical === \"number\" ? `${props.paddingVertical}px` : props.paddingVertical};\n padding-bottom: ${typeof props.paddingVertical === \"number\" ? `${props.paddingVertical}px` : props.paddingVertical};\n `}\n ${(props) =>\n props.paddingTop !== undefined &&\n `padding-top: ${typeof props.paddingTop === \"number\" ? `${props.paddingTop}px` : props.paddingTop};`}\n ${(props) =>\n props.paddingBottom !== undefined &&\n `padding-bottom: ${typeof props.paddingBottom === \"number\" ? `${props.paddingBottom}px` : props.paddingBottom};`}\n ${(props) =>\n props.paddingLeft !== undefined &&\n `padding-left: ${typeof props.paddingLeft === \"number\" ? `${props.paddingLeft}px` : props.paddingLeft};`}\n ${(props) =>\n props.paddingRight !== undefined &&\n `padding-right: ${typeof props.paddingRight === \"number\" ? `${props.paddingRight}px` : props.paddingRight};`}\n\n margin: ${(props) =>\n typeof props.margin === \"number\" ? `${props.margin}px` : props.margin || 0};\n ${(props) =>\n props.marginTop !== undefined &&\n `margin-top: ${typeof props.marginTop === \"number\" ? `${props.marginTop}px` : props.marginTop};`}\n ${(props) =>\n props.marginBottom !== undefined &&\n `margin-bottom: ${typeof props.marginBottom === \"number\" ? `${props.marginBottom}px` : props.marginBottom};`}\n ${(props) =>\n props.marginLeft !== undefined &&\n `margin-left: ${typeof props.marginLeft === \"number\" ? `${props.marginLeft}px` : props.marginLeft};`}\n ${(props) =>\n props.marginRight !== undefined &&\n `margin-right: ${typeof props.marginRight === \"number\" ? `${props.marginRight}px` : props.marginRight};`}\n\n flex-direction: ${(props) => props.flexDirection || \"column\"};\n flex-wrap: ${(props) => props.flexWrap || \"nowrap\"};\n align-items: ${(props) => props.alignItems || \"stretch\"};\n justify-content: ${(props) => props.justifyContent || \"flex-start\"};\n cursor: ${(props) =>\n props.cursor\n ? props.cursor\n : props.onClick || props.onPress\n ? \"pointer\"\n : \"inherit\"};\n position: ${(props) => props.position || \"static\"};\n top: ${(props) =>\n typeof props.top === \"number\" ? `${props.top}px` : props.top};\n bottom: ${(props) =>\n typeof props.bottom === \"number\" ? `${props.bottom}px` : props.bottom};\n left: ${(props) =>\n typeof props.left === \"number\" ? `${props.left}px` : props.left};\n right: ${(props) =>\n typeof props.right === \"number\" ? `${props.right}px` : props.right};\n flex: ${(props) => props.flex};\n flex-shrink: ${(props) => props.flexShrink ?? 1};\n gap: ${(props) =>\n typeof props.gap === \"number\" ? `${props.gap}px` : props.gap || 0};\n align-self: ${(props) => props.alignSelf || \"auto\"};\n overflow: ${(props) => props.overflow || \"visible\"};\n overflow-x: ${(props) => props.overflowX || \"visible\"};\n overflow-y: ${(props) => props.overflowY || \"visible\"};\n z-index: ${(props) => props.zIndex};\n opacity: ${(props) => (props.disabled ? 0.5 : 1)};\n pointer-events: ${(props) => (props.disabled ? \"none\" : \"auto\")};\n\n &:hover {\n ${(props) =>\n props.hoverStyle?.backgroundColor &&\n `background-color: ${props.hoverStyle.backgroundColor};`}\n ${(props) =>\n props.hoverStyle?.borderColor &&\n `border-color: ${props.hoverStyle.borderColor};`}\n }\n\n &:active {\n ${(props) =>\n props.pressStyle?.backgroundColor &&\n `background-color: ${props.pressStyle.backgroundColor};`}\n }\n`;\n\nexport const Box = React.forwardRef<\n HTMLDivElement | HTMLButtonElement,\n BoxProps\n>(\n (\n {\n children,\n onPress,\n onKeyDown,\n onKeyUp,\n role,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n \"aria-current\": ariaCurrent,\n \"aria-disabled\": ariaDisabled,\n \"aria-live\": ariaLive,\n \"aria-busy\": ariaBusy,\n \"aria-describedby\": ariaDescribedBy,\n \"aria-expanded\": ariaExpanded,\n \"aria-haspopup\": ariaHasPopup,\n \"aria-pressed\": ariaPressed,\n \"aria-controls\": ariaControls,\n tabIndex,\n as,\n src,\n alt,\n onError,\n onLoad,\n type,\n disabled,\n id,\n testID,\n \"data-testid\": dataTestId,\n ...props\n },\n ref\n ) => {\n // Handle as=\"img\" for rendering images with proper border-radius\n if (as === \"img\" && src) {\n return (\n <img\n src={src}\n alt={alt || \"\"}\n onError={onError}\n onLoad={onLoad}\n style={{\n display: \"block\",\n objectFit: \"cover\",\n width:\n typeof props.width === \"number\"\n ? `${props.width}px`\n : props.width,\n height:\n typeof props.height === \"number\"\n ? `${props.height}px`\n : props.height,\n borderRadius:\n typeof props.borderRadius === \"number\"\n ? `${props.borderRadius}px`\n : props.borderRadius,\n position: props.position,\n top: typeof props.top === \"number\" ? `${props.top}px` : props.top,\n left:\n typeof props.left === \"number\" ? `${props.left}px` : props.left,\n right:\n typeof props.right === \"number\"\n ? `${props.right}px`\n : props.right,\n bottom:\n typeof props.bottom === \"number\"\n ? `${props.bottom}px`\n : props.bottom,\n }}\n />\n );\n }\n\n return (\n <StyledBox\n ref={ref}\n elementType={as}\n id={id}\n type={as === \"button\" ? type || \"button\" : undefined}\n disabled={as === \"button\" ? disabled : undefined}\n onClick={onPress}\n onKeyDown={onKeyDown}\n onKeyUp={onKeyUp}\n role={role}\n aria-label={ariaLabel}\n aria-labelledby={ariaLabelledBy}\n aria-current={ariaCurrent}\n aria-disabled={ariaDisabled}\n aria-busy={ariaBusy}\n aria-describedby={ariaDescribedBy}\n aria-expanded={ariaExpanded}\n aria-haspopup={ariaHasPopup}\n aria-pressed={ariaPressed}\n aria-controls={ariaControls}\n aria-live={ariaLive}\n tabIndex={tabIndex !== undefined ? tabIndex : undefined}\n data-testid={dataTestId || testID}\n {...props}\n >\n {children}\n </StyledBox>\n );\n }\n);\n\nBox.displayName = \"Box\";\n","import React from \"react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\n// Props that @emotion/is-prop-valid incorrectly treats as valid HTML.\n// These are React Native or component-specific props that match\n// valid HTML patterns (on* event handlers, SVG attributes).\nexport const ADDITIONAL_BLOCKED_PROPS = new Set([\n // RN-only event handlers (pass isPropValid's on* pattern)\n \"onPress\",\n \"onChangeText\",\n \"onLayout\",\n \"onMoveShouldSetResponder\",\n \"onResponderGrant\",\n \"onResponderMove\",\n \"onResponderRelease\",\n \"onResponderTerminate\",\n // SVG attributes that pass isPropValid\n \"strokeWidth\",\n // CSS properties that pass isPropValid but are used as component props\n \"overflow\",\n \"cursor\",\n \"fontSize\",\n \"fontWeight\",\n \"fontFamily\",\n \"textDecoration\",\n]);\n\nfunction shouldForwardProp(key: string): boolean {\n if (ADDITIONAL_BLOCKED_PROPS.has(key)) return false;\n return isPropValid(key);\n}\n\n/**\n * Creates a React component that renders the given HTML tag\n * but filters out non-HTML props before they reach the DOM.\n *\n * Uses @emotion/is-prop-valid (same library styled-components v4\n * uses internally) to automatically block invalid HTML attributes,\n * plus a small blocklist for false positives (RN on* handlers, SVG attrs).\n *\n * Usage: `const FilteredDiv = createFilteredElement(\"div\");`\n * Then: `const StyledBox = styled(FilteredDiv)<BoxProps>\\`...\\`;`\n *\n * styled-components can still read ALL props for CSS interpolation,\n * but only valid HTML attributes are forwarded to the DOM element.\n */\nexport function createFilteredElement(defaultTag: string) {\n const Component = React.forwardRef<HTMLElement, Record<string, unknown>>(\n ({ children, elementType, ...props }, ref) => {\n const Tag = (elementType as string) || defaultTag;\n const htmlProps: Record<string, unknown> = {};\n for (const key of Object.keys(props)) {\n if (shouldForwardProp(key)) {\n htmlProps[key] = props[key];\n }\n }\n return React.createElement(\n Tag,\n { ref, ...htmlProps },\n children as React.ReactNode\n );\n }\n );\n Component.displayName = `Filtered(${defaultTag})`;\n return Component;\n}\n","function memoize(fn) {\n var cache = {};\n return function (arg) {\n if (cache[arg] === undefined) cache[arg] = fn(arg);\n return cache[arg];\n };\n}\n\nexport default memoize;\n","import memoize from '@emotion/memoize';\n\nvar reactPropsRegex = /^((children|dangerouslySetInnerHTML|key|ref|autoFocus|defaultValue|defaultChecked|innerHTML|suppressContentEditableWarning|suppressHydrationWarning|valueLink|accept|acceptCharset|accessKey|action|allow|allowUserMedia|allowPaymentRequest|allowFullScreen|allowTransparency|alt|async|autoComplete|autoPlay|capture|cellPadding|cellSpacing|challenge|charSet|checked|cite|classID|className|cols|colSpan|content|contentEditable|contextMenu|controls|controlsList|coords|crossOrigin|data|dateTime|decoding|default|defer|dir|disabled|disablePictureInPicture|download|draggable|encType|form|formAction|formEncType|formMethod|formNoValidate|formTarget|frameBorder|headers|height|hidden|high|href|hrefLang|htmlFor|httpEquiv|id|inputMode|integrity|is|keyParams|keyType|kind|label|lang|list|loading|loop|low|marginHeight|marginWidth|max|maxLength|media|mediaGroup|method|min|minLength|multiple|muted|name|nonce|noValidate|open|optimum|pattern|placeholder|playsInline|poster|preload|profile|radioGroup|readOnly|referrerPolicy|rel|required|reversed|role|rows|rowSpan|sandbox|scope|scoped|scrolling|seamless|selected|shape|size|sizes|slot|span|spellCheck|src|srcDoc|srcLang|srcSet|start|step|style|summary|tabIndex|target|title|type|useMap|value|width|wmode|wrap|about|datatype|inlist|prefix|property|resource|typeof|vocab|autoCapitalize|autoCorrect|autoSave|color|inert|itemProp|itemScope|itemType|itemID|itemRef|on|results|security|unselectable|accentHeight|accumulate|additive|alignmentBaseline|allowReorder|alphabetic|amplitude|arabicForm|ascent|attributeName|attributeType|autoReverse|azimuth|baseFrequency|baselineShift|baseProfile|bbox|begin|bias|by|calcMode|capHeight|clip|clipPathUnits|clipPath|clipRule|colorInterpolation|colorInterpolationFilters|colorProfile|colorRendering|contentScriptType|contentStyleType|cursor|cx|cy|d|decelerate|descent|diffuseConstant|direction|display|divisor|dominantBaseline|dur|dx|dy|edgeMode|elevation|enableBackground|end|exponent|externalResourcesRequired|fill|fillOpacity|fillRule|filter|filterRes|filterUnits|floodColor|floodOpacity|focusable|fontFamily|fontSize|fontSizeAdjust|fontStretch|fontStyle|fontVariant|fontWeight|format|from|fr|fx|fy|g1|g2|glyphName|glyphOrientationHorizontal|glyphOrientationVertical|glyphRef|gradientTransform|gradientUnits|hanging|horizAdvX|horizOriginX|ideographic|imageRendering|in|in2|intercept|k|k1|k2|k3|k4|kernelMatrix|kernelUnitLength|kerning|keyPoints|keySplines|keyTimes|lengthAdjust|letterSpacing|lightingColor|limitingConeAngle|local|markerEnd|markerMid|markerStart|markerHeight|markerUnits|markerWidth|mask|maskContentUnits|maskUnits|mathematical|mode|numOctaves|offset|opacity|operator|order|orient|orientation|origin|overflow|overlinePosition|overlineThickness|panose1|paintOrder|pathLength|patternContentUnits|patternTransform|patternUnits|pointerEvents|points|pointsAtX|pointsAtY|pointsAtZ|preserveAlpha|preserveAspectRatio|primitiveUnits|r|radius|refX|refY|renderingIntent|repeatCount|repeatDur|requiredExtensions|requiredFeatures|restart|result|rotate|rx|ry|scale|seed|shapeRendering|slope|spacing|specularConstant|specularExponent|speed|spreadMethod|startOffset|stdDeviation|stemh|stemv|stitchTiles|stopColor|stopOpacity|strikethroughPosition|strikethroughThickness|string|stroke|strokeDasharray|strokeDashoffset|strokeLinecap|strokeLinejoin|strokeMiterlimit|strokeOpacity|strokeWidth|surfaceScale|systemLanguage|tableValues|targetX|targetY|textAnchor|textDecoration|textRendering|textLength|to|transform|u1|u2|underlinePosition|underlineThickness|unicode|unicodeBidi|unicodeRange|unitsPerEm|vAlphabetic|vHanging|vIdeographic|vMathematical|values|vectorEffect|version|vertAdvY|vertOriginX|vertOriginY|viewBox|viewTarget|visibility|widths|wordSpacing|writingMode|x|xHeight|x1|x2|xChannelSelector|xlinkActuate|xlinkArcrole|xlinkHref|xlinkRole|xlinkShow|xlinkTitle|xlinkType|xmlBase|xmlns|xmlnsXlink|xmlLang|xmlSpace|y|y1|y2|yChannelSelector|z|zoomAndPan|for|class|autofocus)|(([Dd][Aa][Tt][Aa]|[Aa][Rr][Ii][Aa]|x)-.*))$/; // https://esbench.com/bench/5bfee68a4cd7e6009ef61d23\n\nvar index = memoize(function (prop) {\n return reactPropsRegex.test(prop) || prop.charCodeAt(0) === 111\n /* o */\n && prop.charCodeAt(1) === 110\n /* n */\n && prop.charCodeAt(2) < 91;\n}\n/* Z+1 */\n);\n\nexport default index;\n","import React from \"react\";\nimport styled from \"styled-components\";\nimport { TextProps } from \"@xsolla/xui-primitives-core\";\nimport { createFilteredElement } from \"./filterDOMProps\";\n\nconst FilteredSpan = createFilteredElement(\"span\");\n\nconst StyledText = styled(FilteredSpan)<TextProps>`\n color: ${(props) => props.color || \"inherit\"};\n font-size: ${(props) =>\n typeof props.fontSize === \"number\"\n ? `${props.fontSize}px`\n : props.fontSize || \"inherit\"};\n font-weight: ${(props) => props.fontWeight || \"normal\"};\n font-family: ${(props) =>\n props.fontFamily ||\n '\"Aktiv Grotesk\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif'};\n line-height: ${(props) =>\n typeof props.lineHeight === \"number\"\n ? `${props.lineHeight}px`\n : props.lineHeight || \"inherit\"};\n white-space: ${(props) => props.whiteSpace || \"normal\"};\n text-align: ${(props) => props.textAlign || \"inherit\"};\n text-decoration: ${(props) => props.textDecoration || \"none\"};\n`;\n\nexport const Text: React.FC<TextProps> = ({\n style,\n className,\n id,\n role,\n numberOfLines: _numberOfLines,\n ...props\n}) => {\n return (\n <StyledText\n {...props}\n style={style}\n className={className}\n id={id}\n role={role}\n />\n );\n};\n","import React from \"react\";\nimport styled from \"styled-components\";\nimport type { LinearGradientProps } from \"@xsolla/xui-primitives-core\";\n\nfunction buildCssGradient(\n colors: string[],\n start: { x: number; y: number },\n end: { x: number; y: number },\n locations?: number[]\n): string {\n const dx = end.x - start.x;\n const dy = end.y - start.y;\n const angle = Math.round((Math.atan2(dx, -dy) * 180) / Math.PI);\n\n const stops = colors\n .map((color, i) => {\n const pct = locations\n ? locations[i] * 100\n : (i / (colors.length - 1)) * 100;\n return `${color} ${pct}%`;\n })\n .join(\", \");\n\n return `linear-gradient(${angle}deg, ${stops})`;\n}\n\nconst StyledGradient = styled.div<{ $gradient: string }>`\n background: ${(props) => props.$gradient};\n`;\n\nexport const LinearGradient: React.FC<LinearGradientProps> = ({\n colors,\n start = { x: 0, y: 0 },\n end = { x: 0, y: 1 },\n locations,\n children,\n position,\n top,\n bottom,\n left,\n right,\n width,\n height,\n borderRadius,\n overflow,\n zIndex,\n style,\n \"data-testid\": dataTestId,\n}) => {\n const gradient = buildCssGradient(colors, start, end, locations);\n\n const containerStyle: React.CSSProperties = {\n position: position || undefined,\n top: typeof top === \"number\" ? `${top}px` : top,\n bottom: typeof bottom === \"number\" ? `${bottom}px` : bottom,\n left: typeof left === \"number\" ? `${left}px` : left,\n right: typeof right === \"number\" ? `${right}px` : right,\n width: typeof width === \"number\" ? `${width}px` : width,\n height: typeof height === \"number\" ? `${height}px` : height,\n borderRadius:\n typeof borderRadius === \"number\" ? `${borderRadius}px` : borderRadius,\n overflow,\n zIndex,\n ...style,\n };\n\n return (\n <StyledGradient\n $gradient={gradient}\n style={containerStyle}\n data-testid={dataTestId}\n >\n {children}\n </StyledGradient>\n );\n};\n","export * from \"./Box\";\nexport * from \"./Text\";\nexport * from \"./Spinner\";\nexport * from \"./Icon\";\nexport * from \"./Divider\";\nexport * from \"./Input\";\nexport * from \"./TextArea\";\nexport * from \"./LinearGradient\";\n\nexport const isWeb = true;\nexport const isNative = false;\n"],"mappings":"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","names":["React","React","styled","jsx","styled","styled","jsx","jsx"]}
|
|
1
|
+
{"version":3,"sources":["../../src/GameCard.tsx","../../../../foundation/primitives-web/src/Box.tsx","../../../../foundation/primitives-web/src/filterDOMProps.ts","../../../../../node_modules/@emotion/memoize/dist/memoize.esm.js","../../../../../node_modules/@emotion/is-prop-valid/dist/is-prop-valid.esm.js","../../../../foundation/primitives-web/src/Text.tsx","../../../../foundation/primitives-web/src/LinearGradient.tsx","../../../../foundation/primitives-web/src/index.tsx"],"sourcesContent":["import React, { useState } from \"react\";\n// @ts-expect-error - this will be resolved at build time\nimport { Box, Text, LinearGradient, isWeb } from \"@xsolla/xui-primitives\";\nimport { useResolvedTheme } from \"@xsolla/xui-core\";\nimport type {\n GameCardProps,\n GameCardSize,\n GameCardImageRatio,\n GameCardPlatform,\n GameCardLayout,\n} from \"./types\";\n\nconst IMAGE_RATIOS: Record<Exclude<GameCardImageRatio, \"custom\">, number> = {\n \"16:9\": 240 / 135,\n \"1:1\": 1,\n \"2:3\": 240 / 360,\n \"3:2\": 240 / 160,\n \"4:3\": 360 / 270,\n \"9:16\": 135 / 240,\n};\n\nconst BORDER_RADIUS = 8;\nconst TAG_INSET = 8;\nconst TAG_GAP = 4;\n\ninterface SizeConfig {\n titleFontSize: number;\n titleLineHeight: number;\n subtitleFontSize: number;\n subtitleLineHeight: number;\n}\n\nconst getSizeConfig = (\n size: GameCardSize,\n platform: GameCardPlatform\n): SizeConfig => {\n const isDesktop = platform === \"desktop\";\n switch (size) {\n case \"lg\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"md\":\n return {\n titleFontSize: isDesktop ? 16 : 14,\n titleLineHeight: isDesktop ? 20 : 18,\n subtitleFontSize: isDesktop ? 12 : 11,\n subtitleLineHeight: isDesktop ? 18 : 14,\n };\n case \"sm\":\n return {\n titleFontSize: 12,\n titleLineHeight: 16,\n subtitleFontSize: 10,\n subtitleLineHeight: 14,\n };\n }\n};\n\nconst getFooterPadding = (platform: GameCardPlatform): number =>\n platform === \"desktop\" ? 16 : 12;\n\nconst getFooterGap = (): number => 12;\n\nconst resolveAspectRatio = (\n imageRatio: GameCardImageRatio,\n customWidth?: number,\n customHeight?: number\n): number => {\n if (imageRatio === \"custom\" && customWidth && customHeight) {\n return customWidth / customHeight;\n }\n return (\n IMAGE_RATIOS[imageRatio as Exclude<GameCardImageRatio, \"custom\">] ??\n IMAGE_RATIOS[\"16:9\"]\n );\n};\n\nconst ellipsisStyle = isWeb\n ? {\n overflow: \"hidden\" as const,\n textOverflow: \"ellipsis\" as const,\n whiteSpace: \"nowrap\" as const,\n }\n : undefined;\n\nexport const GameCard: React.FC<GameCardProps> = ({\n image,\n title,\n subtitle,\n size = \"lg\",\n imageRatio = \"16:9\",\n customImageWidth,\n customImageHeight,\n badge,\n tagsTopLeft,\n tagsTopRight,\n tagsBottomLeft,\n tagsBottomRight,\n trailing,\n buttonText,\n onButtonClick,\n buttonDisabled,\n layout = \"horizontal\",\n platform = \"mobile\",\n hideFooter = false,\n hoverContent,\n onPress,\n imageAlt,\n className,\n testID,\n themeMode,\n themeProductContext,\n}) => {\n const { theme } = useResolvedTheme({ themeMode, themeProductContext });\n const config = getSizeConfig(size, platform);\n const footerPadding = getFooterPadding(platform);\n const footerGap = getFooterGap();\n const aspectRatio = resolveAspectRatio(\n imageRatio,\n customImageWidth,\n customImageHeight\n );\n\n const [isHovered, setIsHovered] = useState(false);\n\n const wrapperProps = onPress ? { onPress } : {};\n const hoverHandlers =\n isWeb && hoverContent\n ? {\n onMouseEnter: () => setIsHovered(true),\n onMouseLeave: () => setIsHovered(false),\n }\n : {};\n\n const isHorizontal = layout === \"horizontal\";\n\n const renderPlaceholder = () => (\n <Box\n width=\"100%\"\n height=\"100%\"\n backgroundColor={theme.colors.background.secondary}\n alignItems=\"center\"\n justifyContent=\"center\"\n >\n <Box\n width={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n height={\n imageRatio === \"16:9\" ||\n imageRatio === \"9:16\" ||\n imageRatio === \"custom\"\n ? 48\n : 56\n }\n alignItems=\"center\"\n justifyContent=\"center\"\n style={{ opacity: 0.4 }}\n >\n <Text\n color={theme.colors.content.tertiary}\n fontSize={24}\n style={{ textAlign: \"center\" as const }}\n >\n {\"\\u{1F5BC}\"}\n </Text>\n </Box>\n </Box>\n );\n\n const renderImage = () => (\n <Box\n position=\"relative\"\n width=\"100%\"\n overflow=\"hidden\"\n style={{ aspectRatio }}\n {...hoverHandlers}\n >\n {image ? (\n <>\n <Box\n as=\"img\"\n src={image}\n alt={imageAlt || title}\n position=\"absolute\"\n top={0}\n left={0}\n width=\"100%\"\n height=\"100%\"\n style={\n isWeb\n ? {\n objectFit: \"cover\" as const,\n pointerEvents: \"none\" as const,\n }\n : undefined\n }\n />\n <LinearGradient\n colors={[\"transparent\", \"rgba(0, 0, 0, 0.48)\"]}\n start={{ x: 0, y: 0 }}\n end={{ x: 0, y: 1 }}\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height=\"100%\"\n style={{ maxHeight: 206 }}\n />\n </>\n ) : (\n renderPlaceholder()\n )}\n\n {/* Tag zones */}\n {(badge || tagsTopLeft) && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {badge}\n {tagsTopLeft}\n </Box>\n )}\n\n {tagsTopRight && (\n <Box\n position=\"absolute\"\n top={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsTopRight}\n </Box>\n )}\n\n {tagsBottomLeft && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n left={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-start\"\n >\n {tagsBottomLeft}\n </Box>\n )}\n\n {tagsBottomRight && (\n <Box\n position=\"absolute\"\n bottom={TAG_INSET}\n right={TAG_INSET}\n flexDirection=\"column\"\n gap={TAG_GAP}\n alignItems=\"flex-end\"\n >\n {tagsBottomRight}\n </Box>\n )}\n\n {/* Hover overlay */}\n {isWeb && hoverContent && isHovered && (\n <Box\n position=\"absolute\"\n bottom={0}\n left={0}\n right={0}\n height={72}\n flexDirection=\"row\"\n alignItems=\"center\"\n gap={8}\n padding={16}\n borderRadius={4}\n overflow=\"hidden\"\n style={{\n backdropFilter: \"blur(15px)\",\n WebkitBackdropFilter: \"blur(15px)\",\n backgroundColor: theme.colors.layer.float,\n }}\n >\n {hoverContent}\n </Box>\n )}\n </Box>\n );\n\n const renderFooter = () => (\n <Box\n backgroundColor={theme.colors.overlay.mono}\n padding={footerPadding}\n flexDirection={isHorizontal ? \"row\" : \"column\"}\n alignItems={isHorizontal ? \"center\" : \"flex-start\"}\n justifyContent={isHorizontal ? undefined : \"center\"}\n gap={footerGap}\n >\n <Box\n flex={isHorizontal ? 1 : undefined}\n width={isHorizontal ? undefined : \"100%\"}\n flexDirection=\"column\"\n style={{ minWidth: 0 }}\n >\n <Text\n color={theme.colors.content.primary}\n fontSize={config.titleFontSize}\n lineHeight={config.titleLineHeight}\n fontWeight=\"500\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {title}\n </Text>\n {subtitle && (\n <Text\n color={theme.colors.content.tertiary}\n fontSize={config.subtitleFontSize}\n lineHeight={config.subtitleLineHeight}\n fontWeight=\"400\"\n numberOfLines={1}\n style={ellipsisStyle}\n >\n {subtitle}\n </Text>\n )}\n </Box>\n\n {trailing}\n {!trailing && buttonText && (\n <Box\n onPress={buttonDisabled ? undefined : onButtonClick}\n backgroundColor={theme.colors.control.mono.secondary.bg}\n borderRadius={BORDER_RADIUS}\n height={40}\n paddingHorizontal={20}\n alignItems=\"center\"\n justifyContent=\"center\"\n style={\n isWeb\n ? {\n opacity: buttonDisabled ? 0.4 : 1,\n backdropFilter: \"blur(30px)\",\n WebkitBackdropFilter: \"blur(30px)\",\n border: `1px solid ${theme.colors.control.mono.secondary.border}`,\n cursor: buttonDisabled\n ? \"not-allowed\"\n : onButtonClick\n ? \"pointer\"\n : \"default\",\n }\n : { opacity: buttonDisabled ? 0.4 : 1 }\n }\n >\n <Text\n color={theme.colors.control.mono.text.secondary}\n fontSize={14}\n lineHeight={18}\n fontWeight=\"500\"\n style={{ letterSpacing: 0.4 }}\n >\n {buttonText}\n </Text>\n </Box>\n )}\n </Box>\n );\n\n return (\n <Box\n testID={testID}\n className={className}\n flexDirection=\"column\"\n width=\"100%\"\n {...wrapperProps}\n >\n <Box\n borderRadius={BORDER_RADIUS}\n overflow=\"hidden\"\n flexDirection=\"column\"\n style={\n isWeb\n ? {\n borderRadius: `${BORDER_RADIUS}px`,\n overflow: \"hidden\",\n border: `1px solid ${theme.colors.border.secondary}`,\n }\n : {\n borderRadius: BORDER_RADIUS,\n overflow: \"hidden\",\n borderWidth: 1,\n borderColor: theme.colors.border.secondary,\n }\n }\n >\n {renderImage()}\n {!hideFooter && renderFooter()}\n </Box>\n </Box>\n );\n};\n","import React from \"react\";\nimport styled from \"styled-components\";\nimport type { BoxProps } from \"@xsolla/xui-primitives-core\";\nimport { createFilteredElement } from \"./filterDOMProps\";\n\nconst FilteredDiv = createFilteredElement(\"div\");\n\nconst StyledBox = styled(FilteredDiv)<BoxProps>`\n display: flex;\n box-sizing: border-box;\n background-color: ${(props) => props.backgroundColor || \"transparent\"};\n border-color: ${(props) => props.borderColor || \"transparent\"};\n border-width: ${(props) =>\n typeof props.borderWidth === \"number\"\n ? `${props.borderWidth}px`\n : props.borderWidth || 0};\n\n ${(props) =>\n props.borderBottomWidth !== undefined &&\n `\n border-bottom-width: ${typeof props.borderBottomWidth === \"number\" ? `${props.borderBottomWidth}px` : props.borderBottomWidth};\n border-bottom-color: ${props.borderBottomColor || props.borderColor || \"transparent\"};\n border-bottom-style: solid;\n `}\n ${(props) =>\n props.borderTopWidth !== undefined &&\n `\n border-top-width: ${typeof props.borderTopWidth === \"number\" ? `${props.borderTopWidth}px` : props.borderTopWidth};\n border-top-color: ${props.borderTopColor || props.borderColor || \"transparent\"};\n border-top-style: solid;\n `}\n ${(props) =>\n props.borderLeftWidth !== undefined &&\n `\n border-left-width: ${typeof props.borderLeftWidth === \"number\" ? `${props.borderLeftWidth}px` : props.borderLeftWidth};\n border-left-color: ${props.borderLeftColor || props.borderColor || \"transparent\"};\n border-left-style: solid;\n `}\n ${(props) =>\n props.borderRightWidth !== undefined &&\n `\n border-right-width: ${typeof props.borderRightWidth === \"number\" ? `${props.borderRightWidth}px` : props.borderRightWidth};\n border-right-color: ${props.borderRightColor || props.borderColor || \"transparent\"};\n border-right-style: solid;\n `}\n\n border-style: ${(props) =>\n props.borderStyle ||\n (props.borderWidth ||\n props.borderBottomWidth ||\n props.borderTopWidth ||\n props.borderLeftWidth ||\n props.borderRightWidth\n ? \"solid\"\n : \"none\")};\n border-radius: ${(props) =>\n typeof props.borderRadius === \"number\"\n ? `${props.borderRadius}px`\n : props.borderRadius || 0};\n height: ${(props) =>\n typeof props.height === \"number\"\n ? `${props.height}px`\n : props.height || \"auto\"};\n width: ${(props) =>\n typeof props.width === \"number\"\n ? `${props.width}px`\n : props.width || \"auto\"};\n min-width: ${(props) =>\n typeof props.minWidth === \"number\"\n ? `${props.minWidth}px`\n : props.minWidth || \"auto\"};\n min-height: ${(props) =>\n typeof props.minHeight === \"number\"\n ? `${props.minHeight}px`\n : props.minHeight || \"auto\"};\n max-width: ${(props) =>\n typeof props.maxWidth === \"number\"\n ? `${props.maxWidth}px`\n : props.maxWidth || \"none\"};\n max-height: ${(props) =>\n typeof props.maxHeight === \"number\"\n ? `${props.maxHeight}px`\n : props.maxHeight || \"none\"};\n\n padding: ${(props) =>\n typeof props.padding === \"number\"\n ? `${props.padding}px`\n : props.padding || 0};\n ${(props) =>\n props.paddingHorizontal &&\n `\n padding-left: ${typeof props.paddingHorizontal === \"number\" ? `${props.paddingHorizontal}px` : props.paddingHorizontal};\n padding-right: ${typeof props.paddingHorizontal === \"number\" ? `${props.paddingHorizontal}px` : props.paddingHorizontal};\n `}\n ${(props) =>\n props.paddingVertical &&\n `\n padding-top: ${typeof props.paddingVertical === \"number\" ? `${props.paddingVertical}px` : props.paddingVertical};\n padding-bottom: ${typeof props.paddingVertical === \"number\" ? `${props.paddingVertical}px` : props.paddingVertical};\n `}\n ${(props) =>\n props.paddingTop !== undefined &&\n `padding-top: ${typeof props.paddingTop === \"number\" ? `${props.paddingTop}px` : props.paddingTop};`}\n ${(props) =>\n props.paddingBottom !== undefined &&\n `padding-bottom: ${typeof props.paddingBottom === \"number\" ? `${props.paddingBottom}px` : props.paddingBottom};`}\n ${(props) =>\n props.paddingLeft !== undefined &&\n `padding-left: ${typeof props.paddingLeft === \"number\" ? `${props.paddingLeft}px` : props.paddingLeft};`}\n ${(props) =>\n props.paddingRight !== undefined &&\n `padding-right: ${typeof props.paddingRight === \"number\" ? `${props.paddingRight}px` : props.paddingRight};`}\n\n margin: ${(props) =>\n typeof props.margin === \"number\" ? `${props.margin}px` : props.margin || 0};\n ${(props) =>\n props.marginTop !== undefined &&\n `margin-top: ${typeof props.marginTop === \"number\" ? `${props.marginTop}px` : props.marginTop};`}\n ${(props) =>\n props.marginBottom !== undefined &&\n `margin-bottom: ${typeof props.marginBottom === \"number\" ? `${props.marginBottom}px` : props.marginBottom};`}\n ${(props) =>\n props.marginLeft !== undefined &&\n `margin-left: ${typeof props.marginLeft === \"number\" ? `${props.marginLeft}px` : props.marginLeft};`}\n ${(props) =>\n props.marginRight !== undefined &&\n `margin-right: ${typeof props.marginRight === \"number\" ? `${props.marginRight}px` : props.marginRight};`}\n\n flex-direction: ${(props) => props.flexDirection || \"column\"};\n flex-wrap: ${(props) => props.flexWrap || \"nowrap\"};\n align-items: ${(props) => props.alignItems || \"stretch\"};\n justify-content: ${(props) => props.justifyContent || \"flex-start\"};\n cursor: ${(props) =>\n props.cursor\n ? props.cursor\n : props.onClick || props.onPress\n ? \"pointer\"\n : \"inherit\"};\n position: ${(props) => props.position || \"static\"};\n top: ${(props) =>\n typeof props.top === \"number\" ? `${props.top}px` : props.top};\n bottom: ${(props) =>\n typeof props.bottom === \"number\" ? `${props.bottom}px` : props.bottom};\n left: ${(props) =>\n typeof props.left === \"number\" ? `${props.left}px` : props.left};\n right: ${(props) =>\n typeof props.right === \"number\" ? `${props.right}px` : props.right};\n flex: ${(props) => props.flex};\n flex-shrink: ${(props) => props.flexShrink ?? 1};\n gap: ${(props) =>\n typeof props.gap === \"number\" ? `${props.gap}px` : props.gap || 0};\n align-self: ${(props) => props.alignSelf || \"auto\"};\n overflow: ${(props) => props.overflow || \"visible\"};\n overflow-x: ${(props) => props.overflowX || \"visible\"};\n overflow-y: ${(props) => props.overflowY || \"visible\"};\n z-index: ${(props) => props.zIndex};\n opacity: ${(props) => (props.disabled ? 0.5 : 1)};\n pointer-events: ${(props) => (props.disabled ? \"none\" : \"auto\")};\n\n &:hover {\n ${(props) =>\n props.hoverStyle?.backgroundColor &&\n `background-color: ${props.hoverStyle.backgroundColor};`}\n ${(props) =>\n props.hoverStyle?.borderColor &&\n `border-color: ${props.hoverStyle.borderColor};`}\n }\n\n &:active {\n ${(props) =>\n props.pressStyle?.backgroundColor &&\n `background-color: ${props.pressStyle.backgroundColor};`}\n }\n`;\n\nexport const Box = React.forwardRef<\n HTMLDivElement | HTMLButtonElement,\n BoxProps\n>(\n (\n {\n children,\n onPress,\n onKeyDown,\n onKeyUp,\n role,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n \"aria-current\": ariaCurrent,\n \"aria-disabled\": ariaDisabled,\n \"aria-live\": ariaLive,\n \"aria-busy\": ariaBusy,\n \"aria-describedby\": ariaDescribedBy,\n \"aria-expanded\": ariaExpanded,\n \"aria-haspopup\": ariaHasPopup,\n \"aria-pressed\": ariaPressed,\n \"aria-controls\": ariaControls,\n tabIndex,\n as,\n src,\n alt,\n onError,\n onLoad,\n type,\n disabled,\n id,\n testID,\n \"data-testid\": dataTestId,\n ...props\n },\n ref\n ) => {\n // Handle as=\"img\" for rendering images with proper border-radius\n if (as === \"img\" && src) {\n return (\n <img\n src={src}\n alt={alt || \"\"}\n onError={onError}\n onLoad={onLoad}\n style={{\n display: \"block\",\n objectFit: \"cover\",\n width:\n typeof props.width === \"number\"\n ? `${props.width}px`\n : props.width,\n height:\n typeof props.height === \"number\"\n ? `${props.height}px`\n : props.height,\n borderRadius:\n typeof props.borderRadius === \"number\"\n ? `${props.borderRadius}px`\n : props.borderRadius,\n position: props.position,\n top: typeof props.top === \"number\" ? `${props.top}px` : props.top,\n left:\n typeof props.left === \"number\" ? `${props.left}px` : props.left,\n right:\n typeof props.right === \"number\"\n ? `${props.right}px`\n : props.right,\n bottom:\n typeof props.bottom === \"number\"\n ? `${props.bottom}px`\n : props.bottom,\n ...props.style,\n }}\n />\n );\n }\n\n return (\n <StyledBox\n ref={ref}\n elementType={as}\n id={id}\n type={as === \"button\" ? type || \"button\" : undefined}\n disabled={as === \"button\" ? disabled : undefined}\n onClick={onPress}\n onKeyDown={onKeyDown}\n onKeyUp={onKeyUp}\n role={role}\n aria-label={ariaLabel}\n aria-labelledby={ariaLabelledBy}\n aria-current={ariaCurrent}\n aria-disabled={ariaDisabled}\n aria-busy={ariaBusy}\n aria-describedby={ariaDescribedBy}\n aria-expanded={ariaExpanded}\n aria-haspopup={ariaHasPopup}\n aria-pressed={ariaPressed}\n aria-controls={ariaControls}\n aria-live={ariaLive}\n tabIndex={tabIndex !== undefined ? tabIndex : undefined}\n data-testid={dataTestId || testID}\n {...props}\n >\n {children}\n </StyledBox>\n );\n }\n);\n\nBox.displayName = \"Box\";\n","import React from \"react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\n// Props that @emotion/is-prop-valid incorrectly treats as valid HTML.\n// These are React Native or component-specific props that match\n// valid HTML patterns (on* event handlers, SVG attributes).\nexport const ADDITIONAL_BLOCKED_PROPS = new Set([\n // RN-only event handlers (pass isPropValid's on* pattern)\n \"onPress\",\n \"onChangeText\",\n \"onLayout\",\n \"onMoveShouldSetResponder\",\n \"onResponderGrant\",\n \"onResponderMove\",\n \"onResponderRelease\",\n \"onResponderTerminate\",\n // SVG attributes that pass isPropValid\n \"strokeWidth\",\n // CSS properties that pass isPropValid but are used as component props\n \"overflow\",\n \"cursor\",\n \"fontSize\",\n \"fontWeight\",\n \"fontFamily\",\n \"textDecoration\",\n]);\n\nfunction shouldForwardProp(key: string): boolean {\n if (ADDITIONAL_BLOCKED_PROPS.has(key)) return false;\n return isPropValid(key);\n}\n\n/**\n * Creates a React component that renders the given HTML tag\n * but filters out non-HTML props before they reach the DOM.\n *\n * Uses @emotion/is-prop-valid (same library styled-components v4\n * uses internally) to automatically block invalid HTML attributes,\n * plus a small blocklist for false positives (RN on* handlers, SVG attrs).\n *\n * Usage: `const FilteredDiv = createFilteredElement(\"div\");`\n * Then: `const StyledBox = styled(FilteredDiv)<BoxProps>\\`...\\`;`\n *\n * styled-components can still read ALL props for CSS interpolation,\n * but only valid HTML attributes are forwarded to the DOM element.\n */\nexport function createFilteredElement(defaultTag: string) {\n const Component = React.forwardRef<HTMLElement, Record<string, unknown>>(\n ({ children, elementType, ...props }, ref) => {\n const Tag = (elementType as string) || defaultTag;\n const htmlProps: Record<string, unknown> = {};\n for (const key of Object.keys(props)) {\n if (shouldForwardProp(key)) {\n htmlProps[key] = props[key];\n }\n }\n return React.createElement(\n Tag,\n { ref, ...htmlProps },\n children as React.ReactNode\n );\n }\n );\n Component.displayName = `Filtered(${defaultTag})`;\n return Component;\n}\n","function memoize(fn) {\n var cache = {};\n return function (arg) {\n if (cache[arg] === undefined) cache[arg] = fn(arg);\n return cache[arg];\n };\n}\n\nexport default memoize;\n","import memoize from '@emotion/memoize';\n\nvar reactPropsRegex = /^((children|dangerouslySetInnerHTML|key|ref|autoFocus|defaultValue|defaultChecked|innerHTML|suppressContentEditableWarning|suppressHydrationWarning|valueLink|accept|acceptCharset|accessKey|action|allow|allowUserMedia|allowPaymentRequest|allowFullScreen|allowTransparency|alt|async|autoComplete|autoPlay|capture|cellPadding|cellSpacing|challenge|charSet|checked|cite|classID|className|cols|colSpan|content|contentEditable|contextMenu|controls|controlsList|coords|crossOrigin|data|dateTime|decoding|default|defer|dir|disabled|disablePictureInPicture|download|draggable|encType|form|formAction|formEncType|formMethod|formNoValidate|formTarget|frameBorder|headers|height|hidden|high|href|hrefLang|htmlFor|httpEquiv|id|inputMode|integrity|is|keyParams|keyType|kind|label|lang|list|loading|loop|low|marginHeight|marginWidth|max|maxLength|media|mediaGroup|method|min|minLength|multiple|muted|name|nonce|noValidate|open|optimum|pattern|placeholder|playsInline|poster|preload|profile|radioGroup|readOnly|referrerPolicy|rel|required|reversed|role|rows|rowSpan|sandbox|scope|scoped|scrolling|seamless|selected|shape|size|sizes|slot|span|spellCheck|src|srcDoc|srcLang|srcSet|start|step|style|summary|tabIndex|target|title|type|useMap|value|width|wmode|wrap|about|datatype|inlist|prefix|property|resource|typeof|vocab|autoCapitalize|autoCorrect|autoSave|color|inert|itemProp|itemScope|itemType|itemID|itemRef|on|results|security|unselectable|accentHeight|accumulate|additive|alignmentBaseline|allowReorder|alphabetic|amplitude|arabicForm|ascent|attributeName|attributeType|autoReverse|azimuth|baseFrequency|baselineShift|baseProfile|bbox|begin|bias|by|calcMode|capHeight|clip|clipPathUnits|clipPath|clipRule|colorInterpolation|colorInterpolationFilters|colorProfile|colorRendering|contentScriptType|contentStyleType|cursor|cx|cy|d|decelerate|descent|diffuseConstant|direction|display|divisor|dominantBaseline|dur|dx|dy|edgeMode|elevation|enableBackground|end|exponent|externalResourcesRequired|fill|fillOpacity|fillRule|filter|filterRes|filterUnits|floodColor|floodOpacity|focusable|fontFamily|fontSize|fontSizeAdjust|fontStretch|fontStyle|fontVariant|fontWeight|format|from|fr|fx|fy|g1|g2|glyphName|glyphOrientationHorizontal|glyphOrientationVertical|glyphRef|gradientTransform|gradientUnits|hanging|horizAdvX|horizOriginX|ideographic|imageRendering|in|in2|intercept|k|k1|k2|k3|k4|kernelMatrix|kernelUnitLength|kerning|keyPoints|keySplines|keyTimes|lengthAdjust|letterSpacing|lightingColor|limitingConeAngle|local|markerEnd|markerMid|markerStart|markerHeight|markerUnits|markerWidth|mask|maskContentUnits|maskUnits|mathematical|mode|numOctaves|offset|opacity|operator|order|orient|orientation|origin|overflow|overlinePosition|overlineThickness|panose1|paintOrder|pathLength|patternContentUnits|patternTransform|patternUnits|pointerEvents|points|pointsAtX|pointsAtY|pointsAtZ|preserveAlpha|preserveAspectRatio|primitiveUnits|r|radius|refX|refY|renderingIntent|repeatCount|repeatDur|requiredExtensions|requiredFeatures|restart|result|rotate|rx|ry|scale|seed|shapeRendering|slope|spacing|specularConstant|specularExponent|speed|spreadMethod|startOffset|stdDeviation|stemh|stemv|stitchTiles|stopColor|stopOpacity|strikethroughPosition|strikethroughThickness|string|stroke|strokeDasharray|strokeDashoffset|strokeLinecap|strokeLinejoin|strokeMiterlimit|strokeOpacity|strokeWidth|surfaceScale|systemLanguage|tableValues|targetX|targetY|textAnchor|textDecoration|textRendering|textLength|to|transform|u1|u2|underlinePosition|underlineThickness|unicode|unicodeBidi|unicodeRange|unitsPerEm|vAlphabetic|vHanging|vIdeographic|vMathematical|values|vectorEffect|version|vertAdvY|vertOriginX|vertOriginY|viewBox|viewTarget|visibility|widths|wordSpacing|writingMode|x|xHeight|x1|x2|xChannelSelector|xlinkActuate|xlinkArcrole|xlinkHref|xlinkRole|xlinkShow|xlinkTitle|xlinkType|xmlBase|xmlns|xmlnsXlink|xmlLang|xmlSpace|y|y1|y2|yChannelSelector|z|zoomAndPan|for|class|autofocus)|(([Dd][Aa][Tt][Aa]|[Aa][Rr][Ii][Aa]|x)-.*))$/; // https://esbench.com/bench/5bfee68a4cd7e6009ef61d23\n\nvar index = memoize(function (prop) {\n return reactPropsRegex.test(prop) || prop.charCodeAt(0) === 111\n /* o */\n && prop.charCodeAt(1) === 110\n /* n */\n && prop.charCodeAt(2) < 91;\n}\n/* Z+1 */\n);\n\nexport default index;\n","import React from \"react\";\nimport styled from \"styled-components\";\nimport { TextProps } from \"@xsolla/xui-primitives-core\";\nimport { createFilteredElement } from \"./filterDOMProps\";\n\nconst FilteredSpan = createFilteredElement(\"span\");\n\nconst StyledText = styled(FilteredSpan)<TextProps>`\n color: ${(props) => props.color || \"inherit\"};\n font-size: ${(props) =>\n typeof props.fontSize === \"number\"\n ? `${props.fontSize}px`\n : props.fontSize || \"inherit\"};\n font-weight: ${(props) => props.fontWeight || \"normal\"};\n font-family: ${(props) =>\n props.fontFamily ||\n '\"Aktiv Grotesk\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif'};\n line-height: ${(props) =>\n typeof props.lineHeight === \"number\"\n ? `${props.lineHeight}px`\n : props.lineHeight || \"inherit\"};\n white-space: ${(props) => props.whiteSpace || \"normal\"};\n text-align: ${(props) => props.textAlign || \"inherit\"};\n text-decoration: ${(props) => props.textDecoration || \"none\"};\n`;\n\nexport const Text: React.FC<TextProps> = ({\n style,\n className,\n id,\n role,\n testID,\n \"data-testid\": dataTestId,\n numberOfLines: _numberOfLines,\n ...props\n}) => {\n return (\n <StyledText\n {...props}\n style={style}\n className={className}\n id={id}\n role={role}\n data-testid={dataTestId || testID}\n />\n );\n};\n","import React from \"react\";\nimport styled from \"styled-components\";\nimport type { LinearGradientProps } from \"@xsolla/xui-primitives-core\";\n\nfunction buildCssGradient(\n colors: string[],\n start: { x: number; y: number },\n end: { x: number; y: number },\n locations?: number[]\n): string {\n const dx = end.x - start.x;\n const dy = end.y - start.y;\n const angle = Math.round((Math.atan2(dx, -dy) * 180) / Math.PI);\n\n const stops = colors\n .map((color, i) => {\n const pct = locations\n ? locations[i] * 100\n : (i / (colors.length - 1)) * 100;\n return `${color} ${pct}%`;\n })\n .join(\", \");\n\n return `linear-gradient(${angle}deg, ${stops})`;\n}\n\nconst StyledGradient = styled.div<{ $gradient: string }>`\n background: ${(props) => props.$gradient};\n`;\n\nexport const LinearGradient: React.FC<LinearGradientProps> = ({\n colors,\n start = { x: 0, y: 0 },\n end = { x: 0, y: 1 },\n locations,\n children,\n position,\n top,\n bottom,\n left,\n right,\n width,\n height,\n borderRadius,\n overflow,\n zIndex,\n style,\n \"data-testid\": dataTestId,\n}) => {\n const gradient = buildCssGradient(colors, start, end, locations);\n\n const containerStyle: React.CSSProperties = {\n position: position || undefined,\n top: typeof top === \"number\" ? `${top}px` : top,\n bottom: typeof bottom === \"number\" ? `${bottom}px` : bottom,\n left: typeof left === \"number\" ? `${left}px` : left,\n right: typeof right === \"number\" ? `${right}px` : right,\n width: typeof width === \"number\" ? `${width}px` : width,\n height: typeof height === \"number\" ? `${height}px` : height,\n borderRadius:\n typeof borderRadius === \"number\" ? `${borderRadius}px` : borderRadius,\n overflow,\n zIndex,\n ...style,\n };\n\n return (\n <StyledGradient\n $gradient={gradient}\n style={containerStyle}\n data-testid={dataTestId}\n >\n {children}\n </StyledGradient>\n );\n};\n","export * from \"./Box\";\nexport * from \"./Text\";\nexport * from \"./Spinner\";\nexport * from \"./Icon\";\nexport * from \"./Divider\";\nexport * from \"./Input\";\nexport * from \"./TextArea\";\nexport * from \"./LinearGradient\";\n\nexport const isWeb = true;\nexport const isNative = false;\n"],"mappings":"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","names":["React","React","styled","jsx","styled","styled","jsx","jsx"]}
|