stream-chat-react-native-core 8.8.1 → 8.9.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/lib/commonjs/components/Message/Message.js +3 -3
  2. package/lib/commonjs/components/Message/Message.js.map +1 -1
  3. package/lib/commonjs/components/Message/hooks/useMessageDeliveryData.js +7 -4
  4. package/lib/commonjs/components/Message/hooks/useMessageDeliveryData.js.map +1 -1
  5. package/lib/commonjs/components/Message/hooks/useMessageReadData.js +7 -4
  6. package/lib/commonjs/components/Message/hooks/useMessageReadData.js.map +1 -1
  7. package/lib/commonjs/components/Poll/components/PollAnswersList.js +2 -2
  8. package/lib/commonjs/components/Poll/components/PollAnswersList.js.map +1 -1
  9. package/lib/commonjs/components/Poll/components/PollResults/PollOptionFullResults.js +3 -3
  10. package/lib/commonjs/components/Poll/components/PollResults/PollOptionFullResults.js.map +1 -1
  11. package/lib/commonjs/components/index.js +33 -22
  12. package/lib/commonjs/components/index.js.map +1 -1
  13. package/lib/commonjs/version.json +1 -1
  14. package/lib/module/components/Message/Message.js +3 -3
  15. package/lib/module/components/Message/Message.js.map +1 -1
  16. package/lib/module/components/Message/hooks/useMessageDeliveryData.js +7 -4
  17. package/lib/module/components/Message/hooks/useMessageDeliveryData.js.map +1 -1
  18. package/lib/module/components/Message/hooks/useMessageReadData.js +7 -4
  19. package/lib/module/components/Message/hooks/useMessageReadData.js.map +1 -1
  20. package/lib/module/components/Poll/components/PollAnswersList.js +2 -2
  21. package/lib/module/components/Poll/components/PollAnswersList.js.map +1 -1
  22. package/lib/module/components/Poll/components/PollResults/PollOptionFullResults.js +3 -3
  23. package/lib/module/components/Poll/components/PollResults/PollOptionFullResults.js.map +1 -1
  24. package/lib/module/components/index.js +33 -22
  25. package/lib/module/components/index.js.map +1 -1
  26. package/lib/module/version.json +1 -1
  27. package/lib/typescript/components/Message/hooks/useMessageDeliveryData.d.ts +3 -3
  28. package/lib/typescript/components/Message/hooks/useMessageDeliveryData.d.ts.map +1 -1
  29. package/lib/typescript/components/Message/hooks/useMessageReadData.d.ts +3 -3
  30. package/lib/typescript/components/Message/hooks/useMessageReadData.d.ts.map +1 -1
  31. package/lib/typescript/components/Poll/components/PollResults/PollOptionFullResults.d.ts +1 -1
  32. package/lib/typescript/components/Poll/components/PollResults/PollOptionFullResults.d.ts.map +1 -1
  33. package/lib/typescript/components/index.d.ts +3 -0
  34. package/lib/typescript/components/index.d.ts.map +1 -1
  35. package/package.json +1 -1
  36. package/src/components/Message/Message.tsx +3 -3
  37. package/src/components/Message/hooks/useMessageDeliveryData.ts +10 -6
  38. package/src/components/Message/hooks/useMessageReadData.ts +10 -6
  39. package/src/components/Poll/components/PollAnswersList.tsx +2 -2
  40. package/src/components/Poll/components/PollResults/PollOptionFullResults.tsx +2 -2
  41. package/src/components/index.ts +3 -0
  42. package/src/version.json +1 -1
@@ -1,25 +1,29 @@
1
1
  import { useCallback, useEffect, useState } from 'react';
2
2
 
3
- import { Event, LocalMessage } from 'stream-chat';
3
+ import { Event, LocalMessage, UserResponse } from 'stream-chat';
4
4
 
5
5
  import { useChannelContext } from '../../../contexts/channelContext/ChannelContext';
6
6
  import { useChatContext } from '../../../contexts/chatContext/ChatContext';
7
7
 
8
- export const useMessageDeliveredData = ({ message }: { message: LocalMessage }) => {
8
+ export const useMessageDeliveredData = ({ message }: { message?: LocalMessage }) => {
9
9
  const { channel } = useChannelContext();
10
10
  const { client } = useChatContext();
11
11
  const calculate = useCallback(() => {
12
- if (!message.created_at) {
13
- return 0;
12
+ if (!message?.created_at) {
13
+ return [];
14
14
  }
15
15
  const messageRef = {
16
16
  msgId: message.id,
17
17
  timestampMs: new Date(message.created_at).getTime(),
18
18
  };
19
- return channel.messageReceiptsTracker.deliveredForMessage(messageRef).length;
19
+ return channel.messageReceiptsTracker.deliveredForMessage(messageRef);
20
20
  }, [channel, message]);
21
21
 
22
- const [deliveredToCount, setDeliveredToCount] = useState<number>(calculate());
22
+ const [deliveredToCount, setDeliveredToCount] = useState<UserResponse[]>([]);
23
+
24
+ useEffect(() => {
25
+ setDeliveredToCount(calculate());
26
+ }, [calculate]);
23
27
 
24
28
  useEffect(() => {
25
29
  const { unsubscribe } = channel.on('message.delivered', (event: Event) => {
@@ -1,26 +1,30 @@
1
1
  import { useCallback, useEffect, useState } from 'react';
2
2
 
3
- import { Event, LocalMessage } from 'stream-chat';
3
+ import { Event, LocalMessage, UserResponse } from 'stream-chat';
4
4
 
5
5
  import { useChannelContext } from '../../../contexts/channelContext/ChannelContext';
6
6
  import { useChatContext } from '../../../contexts/chatContext/ChatContext';
7
7
 
8
- export const useMessageReadData = ({ message }: { message: LocalMessage }) => {
8
+ export const useMessageReadData = ({ message }: { message?: LocalMessage }) => {
9
9
  const { channel } = useChannelContext();
10
10
  const { client } = useChatContext();
11
11
  const calculate = useCallback(() => {
12
- if (!message.created_at) {
13
- return 0;
12
+ if (!message?.created_at) {
13
+ return [];
14
14
  }
15
15
  const messageRef = {
16
16
  msgId: message.id,
17
17
  timestampMs: new Date(message.created_at).getTime(),
18
18
  };
19
19
 
20
- return channel.messageReceiptsTracker.readersForMessage(messageRef).length;
20
+ return channel.messageReceiptsTracker.readersForMessage(messageRef);
21
21
  }, [channel, message]);
22
22
 
23
- const [readBy, setReadBy] = useState<number>(calculate());
23
+ const [readBy, setReadBy] = useState<UserResponse[]>([]);
24
+
25
+ useEffect(() => {
26
+ setReadBy(calculate());
27
+ }, [calculate]);
24
28
 
25
29
  useEffect(() => {
26
30
  const { unsubscribe } = channel.on('message.read', (event: Event) => {
@@ -126,7 +126,7 @@ export const PollAnswerListItem = ({ answer }: { answer: PollAnswer }) => {
126
126
  );
127
127
  };
128
128
 
129
- const PollAnswerListItemComponent = ({ item }: { item: PollAnswer }) => (
129
+ const renderPollAnswerListItem = ({ item }: { item: PollAnswer }) => (
130
130
  <PollAnswerListItem answer={item} />
131
131
  );
132
132
 
@@ -149,7 +149,7 @@ export const PollAnswersListContent = ({
149
149
  data={pollAnswers}
150
150
  keyExtractor={(item) => `poll_answer_${item.id}`}
151
151
  onEndReached={() => hasNextPage && loadMore()}
152
- renderItem={PollAnswerListItemComponent}
152
+ renderItem={renderPollAnswerListItem}
153
153
  {...additionalFlatListProps}
154
154
  />
155
155
  <AnswerListAddCommentButton />
@@ -21,7 +21,7 @@ export type PollOptionFullResultsProps = PollContextValue & {
21
21
  PollOptionFullResultsContent?: React.ComponentType<{ option: PollOption }>;
22
22
  };
23
23
 
24
- export const PollOptionFullResultsItem = ({ item }: { item: PollVoteClass }) => (
24
+ export const renderPollOptionFullResultsItem = ({ item }: { item: PollVoteClass }) => (
25
25
  <PollVote vote={item} />
26
26
  );
27
27
 
@@ -65,7 +65,7 @@ export const PollOptionFullResultsContent = ({
65
65
  keyExtractor={(item) => `option_full_results_${item.id}`}
66
66
  ListHeaderComponent={PollOptionFullResultsHeader}
67
67
  onEndReached={() => hasNextPage && loadMore()}
68
- renderItem={PollOptionFullResultsItem}
68
+ renderItem={renderPollOptionFullResultsItem}
69
69
  {...additionalFlatListProps}
70
70
  />
71
71
  </View>
@@ -64,6 +64,7 @@ export * from './ChannelPreview/hooks/useChannelPreviewDisplayPresence';
64
64
  export * from './ChannelPreview/hooks/useLatestMessagePreview';
65
65
  export * from './ChannelPreview/hooks/useChannelPreviewData';
66
66
  export * from './ChannelPreview/hooks/useIsChannelMuted';
67
+ export * from './ChannelPreview/hooks/useMessageDeliveryStatus';
67
68
 
68
69
  export * from './Chat/Chat';
69
70
  export * from './Chat/hooks/useCreateChatClient';
@@ -93,6 +94,8 @@ export * from './Message/hooks/useCreateMessageContext';
93
94
  export * from './Message/hooks/useMessageActions';
94
95
  export * from './Message/hooks/useMessageActionHandlers';
95
96
  export * from './Message/hooks/useStreamingMessage';
97
+ export * from './Message/hooks/useMessageDeliveryData';
98
+ export * from './Message/hooks/useMessageReadData';
96
99
  export * from './Message/Message';
97
100
  export * from './Message/MessageSimple/MessageAvatar';
98
101
  export * from './Message/MessageSimple/MessageBounce';
package/src/version.json CHANGED
@@ -1,3 +1,3 @@
1
1
  {
2
- "version": "8.8.1"
2
+ "version": "8.9.0-beta.1"
3
3
  }