Files
RN_Template/RN_TEMPLATE/app/screens/ShowroomScreen/demos/DemoAutoImage.tsx

230 lines
51 KiB
TypeScript
Raw Normal View History

2026-02-05 13:16:05 +08:00
/* eslint-disable react/jsx-key, react-native/no-inline-styles */
import { Image, ImageStyle, TextStyle, View, ViewStyle } from "react-native"
import { AutoImage } from "@/components/AutoImage"
import { Text } from "@/components/Text"
import { translate } from "@/i18n/translate"
import { $styles } from "@/theme/styles"
import type { ThemedStyle } from "@/theme/types"
import { s } from "@/utils/responsive"
import { DemoDivider } from "../DemoDivider"
import { Demo } from "./types"
import { DemoUseCase } from "../DemoUseCase"
const $imageContainer: ViewStyle = {
alignItems: "center",
}
const $aspectRatioDescription: ThemedStyle<TextStyle> = ({ spacing }) => ({
textAlign: "center",
width: "100%",
marginTop: spacing.xs,
})
const $aspectRatioWidthExampleContainer: ViewStyle = {
justifyContent: "space-between",
}
const $aspectRatioHeightExampleContainer: ViewStyle = {
alignItems: "stretch",
justifyContent: "space-between",
height: s(130),
}
const $aspectRatioBox: ThemedStyle<ViewStyle & ImageStyle> = (theme) => ({
borderRadius: s(4),
borderWidth: 3,
borderColor: theme.colors.palette.secondary300,
backgroundColor: theme.colors.palette.neutral800,
})
export const DemoAutoImage: Demo = {
name: "AutoImage",
description: "demoAutoImage:description",
data: ({ theme, themed }) => [
<DemoUseCase name="demoAutoImage:useCase.remoteUri.name">
<View style={$imageContainer}>
<AutoImage
source={{
uri: "https://user-images.githubusercontent.com/1775841/184508739-f90d0ce5-7219-42fd-a91f-3382d016eae0.png",
}}
/>
</View>
</DemoUseCase>,
<DemoUseCase name="demoAutoImage:useCase.base64Uri.name">
<View style={$imageContainer}>
<AutoImage
source={{
uri: `
}}
/>
</View>
</DemoUseCase>,
<DemoUseCase
name="demoAutoImage:useCase.scaledToFitDimensions.name"
description="demoAutoImage:useCase.scaledToFitDimensions.description"
>
<View style={[$styles.row, $aspectRatioWidthExampleContainer]}>
<Text
text="<View />"
size="xxs"
weight="bold"
style={{ flexBasis: "33.3333%", color: theme.colors.palette.secondary400 }}
/>
<Text
text="<Image />"
size="xxs"
weight="bold"
style={{
flexBasis: "33.3333%",
textAlign: "center",
color: theme.colors.palette.secondary400,
}}
/>
<Text
text="<AutoImage />"
size="xxs"
weight="bold"
style={{
flexBasis: "33.3333%",
textAlign: "right",
color: theme.colors.palette.secondary400,
}}
/>
</View>
<DemoDivider size={5} />
<View style={[$styles.row, $aspectRatioWidthExampleContainer, { height: s(80) }]}>
<View style={themed([$aspectRatioBox, { width: s(60) }])} />
<Image
source={{
uri: "https://user-images.githubusercontent.com/1775841/188244137-a35ab1b9-658d-4701-b1dd-7caa51173fa9.png",
}}
style={themed([$aspectRatioBox, { width: s(60) }])}
resizeMode="contain"
/>
<AutoImage
maxWidth={60}
style={themed($aspectRatioBox)}
source={{
uri: "https://user-images.githubusercontent.com/1775841/188244137-a35ab1b9-658d-4701-b1dd-7caa51173fa9.png",
}}
/>
</View>
<Text weight="bold" size="xs" style={themed($aspectRatioDescription)}>
{translate("demoAutoImage:useCase.scaledToFitDimensions.heightAuto")}
</Text>
<DemoDivider size={40} />
<View style={$styles.row}>
<View style={$aspectRatioHeightExampleContainer}>
<Text
text="<View />"
size="xxs"
weight="bold"
style={{ color: theme.colors.palette.secondary400 }}
/>
<Text
text="<Image />"
size="xxs"
weight="bold"
style={{ color: theme.colors.palette.secondary400 }}
/>
<Text
text="<AutoImage />"
size="xxs"
weight="bold"
style={{ color: theme.colors.palette.secondary400 }}
/>
</View>
<View
style={[$aspectRatioHeightExampleContainer, { flex: 1, marginStart: theme.spacing.sm }]}
>
<View style={themed([$aspectRatioBox, { height: s(32) }])} />
<Image
source={{
uri: "https://user-images.githubusercontent.com/1775841/188244137-a35ab1b9-658d-4701-b1dd-7caa51173fa9.png",
}}
style={themed([$aspectRatioBox, { height: s(32) }])}
resizeMode="contain"
/>
<AutoImage
maxHeight={32}
style={themed([$aspectRatioBox, { alignSelf: "center" }])}
source={{
uri: "https://user-images.githubusercontent.com/1775841/188244137-a35ab1b9-658d-4701-b1dd-7caa51173fa9.png",
}}
/>
</View>
</View>
<Text weight="bold" size="xs" style={themed($aspectRatioDescription)}>
{translate("demoAutoImage:useCase.scaledToFitDimensions.widthAuto")}
</Text>
<DemoDivider size={40} />
<View style={[$styles.row, $aspectRatioWidthExampleContainer]}>
<Text
text="<View />"
size="xxs"
weight="bold"
style={{ flexBasis: "33.3333%", color: theme.colors.palette.secondary400 }}
/>
<Text
text="<Image />"
size="xxs"
weight="bold"
style={{
flexBasis: "33.3333%",
textAlign: "center",
color: theme.colors.palette.secondary400,
}}
/>
<Text
text="<AutoImage />"
size="xxs"
weight="bold"
style={{
flexBasis: "33.3333%",
textAlign: "right",
color: theme.colors.palette.secondary400,
}}
/>
</View>
<DemoDivider size={5} />
<View style={[$styles.row, $aspectRatioWidthExampleContainer]}>
<View style={themed([$aspectRatioBox, { width: s(60), height: s(60) }])} />
<Image
source={{
uri: "https://user-images.githubusercontent.com/1775841/188244137-a35ab1b9-658d-4701-b1dd-7caa51173fa9.png",
}}
style={themed([$aspectRatioBox, { width: s(60), height: s(60) }])}
resizeMode="contain"
/>
<AutoImage
maxWidth={60}
maxHeight={60}
style={themed($aspectRatioBox)}
source={{
uri: "https://user-images.githubusercontent.com/1775841/188244137-a35ab1b9-658d-4701-b1dd-7caa51173fa9.png",
}}
/>
</View>
<Text weight="bold" size="xs" style={themed($aspectRatioDescription)}>
{translate("demoAutoImage:useCase.scaledToFitDimensions.bothManual")}
</Text>
</DemoUseCase>,
],
}