Quote post legibility (#486)
parent
10621e86e4
commit
c2a4ffc99f
|
@ -1,5 +1,4 @@
|
||||||
import {Dimensions} from 'lib/media/types'
|
import React, {useMemo, useState} from 'react'
|
||||||
import React, {useState} from 'react'
|
|
||||||
import {
|
import {
|
||||||
LayoutChangeEvent,
|
LayoutChangeEvent,
|
||||||
StyleProp,
|
StyleProp,
|
||||||
|
@ -9,10 +8,11 @@ import {
|
||||||
ViewStyle,
|
ViewStyle,
|
||||||
} from 'react-native'
|
} from 'react-native'
|
||||||
import {Image, ImageStyle} from 'expo-image'
|
import {Image, ImageStyle} from 'expo-image'
|
||||||
|
import {Dimensions} from 'lib/media/types'
|
||||||
|
|
||||||
export const DELAY_PRESS_IN = 500
|
export const DELAY_PRESS_IN = 500
|
||||||
|
|
||||||
export type ImageLayoutGridType = 'two' | 'three' | 'four'
|
export type ImageLayoutGridType = number
|
||||||
|
|
||||||
export function ImageLayoutGrid({
|
export function ImageLayoutGrid({
|
||||||
type,
|
type,
|
||||||
|
@ -69,8 +69,8 @@ function ImageLayoutGridInner({
|
||||||
onPressIn?: (index: number) => void
|
onPressIn?: (index: number) => void
|
||||||
containerInfo: Dimensions
|
containerInfo: Dimensions
|
||||||
}) {
|
}) {
|
||||||
const size1 = React.useMemo<ImageStyle>(() => {
|
const size1 = useMemo<ImageStyle>(() => {
|
||||||
if (type === 'three') {
|
if (type === 3) {
|
||||||
const size = (containerInfo.width - 10) / 3
|
const size = (containerInfo.width - 10) / 3
|
||||||
return {width: size, height: size, resizeMode: 'cover', borderRadius: 4}
|
return {width: size, height: size, resizeMode: 'cover', borderRadius: 4}
|
||||||
} else {
|
} else {
|
||||||
|
@ -79,7 +79,7 @@ function ImageLayoutGridInner({
|
||||||
}
|
}
|
||||||
}, [type, containerInfo])
|
}, [type, containerInfo])
|
||||||
const size2 = React.useMemo<ImageStyle>(() => {
|
const size2 = React.useMemo<ImageStyle>(() => {
|
||||||
if (type === 'three') {
|
if (type === 3) {
|
||||||
const size = ((containerInfo.width - 10) / 3) * 2 + 5
|
const size = ((containerInfo.width - 10) / 3) * 2 + 5
|
||||||
return {width: size, height: size, resizeMode: 'cover', borderRadius: 4}
|
return {width: size, height: size, resizeMode: 'cover', borderRadius: 4}
|
||||||
} else {
|
} else {
|
||||||
|
@ -88,7 +88,7 @@ function ImageLayoutGridInner({
|
||||||
}
|
}
|
||||||
}, [type, containerInfo])
|
}, [type, containerInfo])
|
||||||
|
|
||||||
if (type === 'two') {
|
if (type === 2) {
|
||||||
return (
|
return (
|
||||||
<View style={styles.flexRow}>
|
<View style={styles.flexRow}>
|
||||||
<TouchableOpacity
|
<TouchableOpacity
|
||||||
|
@ -109,7 +109,7 @@ function ImageLayoutGridInner({
|
||||||
</View>
|
</View>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
if (type === 'three') {
|
if (type === 3) {
|
||||||
return (
|
return (
|
||||||
<View style={styles.flexRow}>
|
<View style={styles.flexRow}>
|
||||||
<TouchableOpacity
|
<TouchableOpacity
|
||||||
|
@ -140,7 +140,7 @@ function ImageLayoutGridInner({
|
||||||
</View>
|
</View>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
if (type === 'four') {
|
if (type === 4) {
|
||||||
return (
|
return (
|
||||||
<View style={styles.flexRow}>
|
<View style={styles.flexRow}>
|
||||||
<View>
|
<View>
|
||||||
|
|
|
@ -35,7 +35,7 @@ export function QuoteEmbed({
|
||||||
)
|
)
|
||||||
return (
|
return (
|
||||||
<Link
|
<Link
|
||||||
style={[styles.container, pal.border, style]}
|
style={[styles.container, pal.borderDark, style]}
|
||||||
href={itemHref}
|
href={itemHref}
|
||||||
title={itemTitle}>
|
title={itemTitle}>
|
||||||
<PostMeta
|
<PostMeta
|
||||||
|
@ -46,15 +46,11 @@ export function QuoteEmbed({
|
||||||
postHref={itemHref}
|
postHref={itemHref}
|
||||||
timestamp={quote.indexedAt}
|
timestamp={quote.indexedAt}
|
||||||
/>
|
/>
|
||||||
|
{!isEmpty ? (
|
||||||
<Text type="post-text" style={pal.text} numberOfLines={6}>
|
<Text type="post-text" style={pal.text} numberOfLines={6}>
|
||||||
{isEmpty ? (
|
{quote.text}
|
||||||
<Text style={pal.link} lineHeight={1.5}>
|
|
||||||
View post
|
|
||||||
</Text>
|
|
||||||
) : (
|
|
||||||
quote.text
|
|
||||||
)}
|
|
||||||
</Text>
|
</Text>
|
||||||
|
) : null}
|
||||||
{AppBskyEmbedImages.isView(imagesEmbed) && (
|
{AppBskyEmbedImages.isView(imagesEmbed) && (
|
||||||
<PostEmbeds embed={imagesEmbed} />
|
<PostEmbeds embed={imagesEmbed} />
|
||||||
)}
|
)}
|
||||||
|
@ -70,7 +66,8 @@ export default QuoteEmbed
|
||||||
const styles = StyleSheet.create({
|
const styles = StyleSheet.create({
|
||||||
container: {
|
container: {
|
||||||
borderRadius: 8,
|
borderRadius: 8,
|
||||||
paddingVertical: 8,
|
marginTop: 8,
|
||||||
|
paddingVertical: 12,
|
||||||
paddingHorizontal: 12,
|
paddingHorizontal: 12,
|
||||||
borderWidth: 1,
|
borderWidth: 1,
|
||||||
},
|
},
|
||||||
|
|
|
@ -107,43 +107,8 @@ export function PostEmbeds({
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
if (embed.images.length === 4) {
|
switch (embed.images.length) {
|
||||||
return (
|
case 1:
|
||||||
<View style={[styles.imagesContainer, style]}>
|
|
||||||
<ImageLayoutGrid
|
|
||||||
type="four"
|
|
||||||
uris={embed.images.map(img => img.thumb)}
|
|
||||||
onPress={openLightbox}
|
|
||||||
onLongPress={onLongPress}
|
|
||||||
onPressIn={onPressIn}
|
|
||||||
/>
|
|
||||||
</View>
|
|
||||||
)
|
|
||||||
} else if (embed.images.length === 3) {
|
|
||||||
return (
|
|
||||||
<View style={[styles.imagesContainer, style]}>
|
|
||||||
<ImageLayoutGrid
|
|
||||||
type="three"
|
|
||||||
uris={embed.images.map(img => img.thumb)}
|
|
||||||
onPress={openLightbox}
|
|
||||||
onLongPress={onLongPress}
|
|
||||||
onPressIn={onPressIn}
|
|
||||||
/>
|
|
||||||
</View>
|
|
||||||
)
|
|
||||||
} else if (embed.images.length === 2) {
|
|
||||||
return (
|
|
||||||
<View style={[styles.imagesContainer, style]}>
|
|
||||||
<ImageLayoutGrid
|
|
||||||
type="two"
|
|
||||||
uris={embed.images.map(img => img.thumb)}
|
|
||||||
onPress={openLightbox}
|
|
||||||
onLongPress={onLongPress}
|
|
||||||
onPressIn={onPressIn}
|
|
||||||
/>
|
|
||||||
</View>
|
|
||||||
)
|
|
||||||
} else {
|
|
||||||
return (
|
return (
|
||||||
<View style={[styles.imagesContainer, style]}>
|
<View style={[styles.imagesContainer, style]}>
|
||||||
<AutoSizedImage
|
<AutoSizedImage
|
||||||
|
@ -155,6 +120,18 @@ export function PostEmbeds({
|
||||||
/>
|
/>
|
||||||
</View>
|
</View>
|
||||||
)
|
)
|
||||||
|
default:
|
||||||
|
return (
|
||||||
|
<View style={[styles.imagesContainer, style]}>
|
||||||
|
<ImageLayoutGrid
|
||||||
|
type={embed.images.length}
|
||||||
|
uris={embed.images.map(img => img.thumb)}
|
||||||
|
onPress={openLightbox}
|
||||||
|
onLongPress={onLongPress}
|
||||||
|
onPressIn={onPressIn}
|
||||||
|
/>
|
||||||
|
</View>
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -184,7 +161,7 @@ const styles = StyleSheet.create({
|
||||||
gap: 6,
|
gap: 6,
|
||||||
},
|
},
|
||||||
imagesContainer: {
|
imagesContainer: {
|
||||||
marginTop: 4,
|
marginTop: 8,
|
||||||
},
|
},
|
||||||
singleImage: {
|
singleImage: {
|
||||||
borderRadius: 8,
|
borderRadius: 8,
|
||||||
|
|
Loading…
Reference in New Issue