diff --git a/examples/SampleApp/App.tsx b/examples/SampleApp/App.tsx index 421521984..f28a2daca 100644 --- a/examples/SampleApp/App.tsx +++ b/examples/SampleApp/App.tsx @@ -183,7 +183,7 @@ const DrawerNavigatorWrapper: React.FC<{ enableOfflineSupport // @ts-expect-error ImageComponent={FastImage} - isMessageAIGenerated={(message: MessageType) => message.ai_generated} + isMessageAIGenerated={(message: MessageType) => !!message.ai_generated} > diff --git a/package/src/components/ImageGallery/components/ImageGalleryFooter.tsx b/package/src/components/ImageGallery/components/ImageGalleryFooter.tsx index 8a6a33807..e2bd876f9 100644 --- a/package/src/components/ImageGallery/components/ImageGalleryFooter.tsx +++ b/package/src/components/ImageGallery/components/ImageGalleryFooter.tsx @@ -21,6 +21,10 @@ import { VideoType, } from '../../../native'; +const ReanimatedSafeAreaView = Animated.createAnimatedComponent + ? Animated.createAnimatedComponent(SafeAreaView) + : SafeAreaView; + import { DefaultStreamChatGenerics, FileTypes } from '../../../types/types'; import type { Photo } from '../ImageGallery'; @@ -154,28 +158,26 @@ export const ImageGalleryFooterWithContext = < }; return ( - setHeight(event.nativeEvent.layout.height)} pointerEvents={'box-none'} style={styles.wrapper} > - - - {photo.type === FileTypes.Video ? ( - videoControlElement ? ( - videoControlElement({ duration, onPlayPause, paused, progress, videoRef }) - ) : ( - - ) - ) : null} - + + {photo.type === FileTypes.Video ? ( + videoControlElement ? ( + videoControlElement({ duration, onPlayPause, paused, progress, videoRef }) + ) : ( + + ) + ) : null} {leftElement ? ( leftElement({ openGridView, photo, share, shareMenuOpen }) @@ -204,8 +206,8 @@ export const ImageGalleryFooterWithContext = < )} - - + + ); }; diff --git a/package/src/components/ImageGallery/components/ImageGalleryHeader.tsx b/package/src/components/ImageGallery/components/ImageGalleryHeader.tsx index ef835f842..a2afec24d 100644 --- a/package/src/components/ImageGallery/components/ImageGalleryHeader.tsx +++ b/package/src/components/ImageGallery/components/ImageGalleryHeader.tsx @@ -16,6 +16,10 @@ import type { DefaultStreamChatGenerics } from '../../../types/types'; import { getDateString } from '../../../utils/i18n/getDateString'; import type { Photo } from '../ImageGallery'; +const ReanimatedSafeAreaView = Animated.createAnimatedComponent + ? Animated.createAnimatedComponent(SafeAreaView) + : SafeAreaView; + export type ImageGalleryHeaderCustomComponent< StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics, > = ({ @@ -58,6 +62,7 @@ export const ImageGalleryHeader = < centerContainer, container, dateText, + innerContainer, leftContainer, rightContainer, usernameText, @@ -93,12 +98,12 @@ export const ImageGalleryHeader = < }; return ( - setHeight(event.nativeEvent.layout.height)} pointerEvents={'box-none'} > - - + + {leftElement ? ( leftElement({ hideOverlay, photo }) ) : ( @@ -124,8 +129,8 @@ export const ImageGalleryHeader = < )} - - + + ); }; @@ -137,16 +142,16 @@ const styles = StyleSheet.create({ flex: 1, justifyContent: 'center', }, - container: { - flexDirection: 'row', - justifyContent: 'space-between', - paddingVertical: 8, - }, date: { fontSize: 12, fontWeight: '500', opacity: 0.5, }, + innerContainer: { + flexDirection: 'row', + justifyContent: 'space-between', + paddingVertical: 8, + }, leftContainer: { flex: 1, justifyContent: 'center', diff --git a/package/src/contexts/themeContext/utils/theme.ts b/package/src/contexts/themeContext/utils/theme.ts index e769e3471..21e5468f6 100644 --- a/package/src/contexts/themeContext/utils/theme.ts +++ b/package/src/contexts/themeContext/utils/theme.ts @@ -226,6 +226,7 @@ export type Theme = { centerContainer: ViewStyle; container: ViewStyle; dateText: TextStyle; + innerContainer: ViewStyle; leftContainer: ViewStyle; rightContainer: ViewStyle; usernameText: TextStyle; @@ -983,6 +984,7 @@ export const defaultTheme: Theme = { centerContainer: {}, container: {}, dateText: {}, + innerContainer: {}, leftContainer: {}, rightContainer: {}, usernameText: {},