stream-chat 9.41.0 → 9.41.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.
@@ -845,6 +845,7 @@ var messagePaginationCreatedAtAround = ({
845
845
  parentSet,
846
846
  requestedPageSize,
847
847
  returnedPage,
848
+ filteredReturnedPage,
848
849
  messagePaginationOptions
849
850
  }) => {
850
851
  const newPagination = { ...parentSet.pagination };
@@ -877,9 +878,13 @@ var messagePaginationCreatedAtAround = ({
877
878
  hasNext = hasPrev = false;
878
879
  updateHasPrev = updateHasNext = true;
879
880
  } else {
881
+ const [firstFilteredPageMsg, lastFilteredPageMsg] = [
882
+ filteredReturnedPage[0],
883
+ filteredReturnedPage.slice(-1)[0]
884
+ ];
880
885
  const [firstPageMsgIsFirstInSet, lastPageMsgIsLastInSet] = [
881
- firstPageMsg?.id && firstPageMsg.id === parentSet.messages[0]?.id,
882
- lastPageMsg?.id && lastPageMsg.id === parentSet.messages.slice(-1)[0]?.id
886
+ firstFilteredPageMsg?.id && firstFilteredPageMsg.id === parentSet.messages[0]?.id,
887
+ lastFilteredPageMsg?.id && lastFilteredPageMsg.id === parentSet.messages.slice(-1)[0]?.id
883
888
  ];
884
889
  updateHasPrev = firstPageMsgIsFirstInSet;
885
890
  updateHasNext = lastPageMsgIsLastInSet;
@@ -901,6 +906,7 @@ var messagePaginationIdAround = ({
901
906
  parentSet,
902
907
  requestedPageSize,
903
908
  returnedPage,
909
+ filteredReturnedPage,
904
910
  messagePaginationOptions
905
911
  }) => {
906
912
  const newPagination = { ...parentSet.pagination };
@@ -908,10 +914,13 @@ var messagePaginationIdAround = ({
908
914
  if (!id_around) return newPagination;
909
915
  let hasPrev;
910
916
  let hasNext;
911
- const [firstPageMsg, lastPageMsg] = [returnedPage[0], returnedPage.slice(-1)[0]];
917
+ const [firstFilteredPageMsg, lastFilteredPageMsg] = [
918
+ filteredReturnedPage[0],
919
+ filteredReturnedPage.slice(-1)[0]
920
+ ];
912
921
  const [firstPageMsgIsFirstInSet, lastPageMsgIsLastInSet] = [
913
- firstPageMsg?.id === parentSet.messages[0]?.id,
914
- lastPageMsg?.id === parentSet.messages.slice(-1)[0]?.id
922
+ firstFilteredPageMsg?.id === parentSet.messages[0]?.id,
923
+ lastFilteredPageMsg?.id === parentSet.messages.slice(-1)[0]?.id
915
924
  ];
916
925
  let updateHasPrev = firstPageMsgIsFirstInSet;
917
926
  let updateHasNext = lastPageMsgIsLastInSet;
@@ -946,15 +955,19 @@ var messagePaginationLinear = ({
946
955
  parentSet,
947
956
  requestedPageSize,
948
957
  returnedPage,
958
+ filteredReturnedPage,
949
959
  messagePaginationOptions
950
960
  }) => {
951
961
  const newPagination = { ...parentSet.pagination };
952
962
  let hasPrev;
953
963
  let hasNext;
954
- const [firstPageMsg, lastPageMsg] = [returnedPage[0], returnedPage.slice(-1)[0]];
964
+ const [firstFilteredPageMsg, lastFilteredPageMsg] = [
965
+ filteredReturnedPage[0],
966
+ filteredReturnedPage.slice(-1)[0]
967
+ ];
955
968
  const [firstPageMsgIsFirstInSet, lastPageMsgIsLastInSet] = [
956
- firstPageMsg?.id && firstPageMsg.id === parentSet.messages[0]?.id,
957
- lastPageMsg?.id && lastPageMsg.id === parentSet.messages.slice(-1)[0]?.id
969
+ firstFilteredPageMsg?.id && firstFilteredPageMsg.id === parentSet.messages[0]?.id,
970
+ lastFilteredPageMsg?.id && lastFilteredPageMsg.id === parentSet.messages.slice(-1)[0]?.id
958
971
  ];
959
972
  const queriedNextMessages = messagePaginationOptions && (messagePaginationOptions.created_at_after_or_equal || messagePaginationOptions.created_at_after || messagePaginationOptions.id_gt || messagePaginationOptions.id_gte);
960
973
  const queriedPrevMessages = typeof messagePaginationOptions === "undefined" ? true : messagePaginationOptions.created_at_before_or_equal || messagePaginationOptions.created_at_before || messagePaginationOptions.id_lt || messagePaginationOptions.id_lte || messagePaginationOptions.offset;
@@ -974,8 +987,7 @@ var messagePaginationLinear = ({
974
987
  return newPagination;
975
988
  };
976
989
  var messageSetPagination = (params) => {
977
- const messagesFilteredLocally = params.returnedPage.filter(({ shadowed }) => shadowed);
978
- if (params.parentSet.messages.length + messagesFilteredLocally.length < params.returnedPage.length) {
990
+ if (params.parentSet.messages.length + (params.returnedPage.length - params.filteredReturnedPage.length) < params.returnedPage.length) {
979
991
  params.logger?.(
980
992
  "error",
981
993
  "Corrupted message set state: parent set size < returned page size"
@@ -1322,9 +1334,11 @@ var ChannelState = class {
1322
1334
  addIfDoesNotExist,
1323
1335
  messageSetToAddToIfDoesNotExist
1324
1336
  );
1337
+ const filteredMessageIds = [];
1325
1338
  for (let i = 0; i < messagesToAdd.length; i += 1) {
1326
1339
  const isFromShadowBannedUser = messagesToAdd[i].shadowed;
1327
- if (isFromShadowBannedUser) {
1340
+ if (isFromShadowBannedUser && addIfDoesNotExist) {
1341
+ filteredMessageIds.push(messagesToAdd[i].id);
1328
1342
  continue;
1329
1343
  }
1330
1344
  const isMessageFormatted = messagesToAdd[i].created_at instanceof Date;
@@ -1366,7 +1380,8 @@ var ChannelState = class {
1366
1380
  }
1367
1381
  }
1368
1382
  return {
1369
- messageSet: this.messageSets[targetMessageSetIndex]
1383
+ messageSet: this.messageSets[targetMessageSetIndex],
1384
+ filteredMessageIds
1370
1385
  };
1371
1386
  }
1372
1387
  /**
@@ -9102,7 +9117,10 @@ var Channel = class {
9102
9117
  location: { enabled: state.channel.config.shared_locations }
9103
9118
  });
9104
9119
  }
9105
- const { messageSet } = this._initializeState(state, messageSetToAddToIfDoesNotExist);
9120
+ const { messageSet, filteredMessageIds } = this._initializeState(
9121
+ state,
9122
+ messageSetToAddToIfDoesNotExist
9123
+ );
9106
9124
  messageSet.pagination = {
9107
9125
  ...messageSet.pagination,
9108
9126
  ...messageSetPagination({
@@ -9110,6 +9128,9 @@ var Channel = class {
9110
9128
  messagePaginationOptions: options?.messages,
9111
9129
  requestedPageSize: options?.messages?.limit ?? DEFAULT_QUERY_CHANNEL_MESSAGE_LIST_PAGE_SIZE,
9112
9130
  returnedPage: state.messages,
9131
+ filteredReturnedPage: state.messages.filter(
9132
+ (m) => !filteredMessageIds.includes(m.id)
9133
+ ),
9113
9134
  logger: this.getClient().logger
9114
9135
  })
9115
9136
  };
@@ -9729,7 +9750,7 @@ var Channel = class {
9729
9750
  if (!this.state.messages) {
9730
9751
  this.state.initMessages();
9731
9752
  }
9732
- const { messageSet } = this.state.addMessagesSorted(
9753
+ const { messageSet, filteredMessageIds } = this.state.addMessagesSorted(
9733
9754
  messages,
9734
9755
  false,
9735
9756
  true,
@@ -9781,7 +9802,8 @@ var Channel = class {
9781
9802
  this.messageReceiptsTracker.ingestInitial(state.read);
9782
9803
  }
9783
9804
  return {
9784
- messageSet
9805
+ messageSet,
9806
+ filteredMessageIds
9785
9807
  };
9786
9808
  }
9787
9809
  _extendEventWithOwnReactions(event) {
@@ -13984,12 +14006,15 @@ var StreamChat = class _StreamChat {
13984
14006
  c.initialized = !offlineMode;
13985
14007
  c.push_preferences = channelState.push_preferences;
13986
14008
  let updatedMessagesSet;
14009
+ let filteredMessageIds = [];
13987
14010
  if (skipInitialization === void 0) {
13988
- const { messageSet } = c._initializeState(channelState, "latest");
14011
+ const { messageSet, filteredMessageIds: _filteredMessageIds } = c._initializeState(channelState, "latest");
14012
+ filteredMessageIds = _filteredMessageIds;
13989
14013
  updatedMessagesSet = messageSet;
13990
14014
  } else if (!skipInitialization.includes(channelState.channel.id)) {
13991
14015
  c.state.clearMessages();
13992
- const { messageSet } = c._initializeState(channelState, "latest");
14016
+ const { messageSet, filteredMessageIds: _filteredMessageIds } = c._initializeState(channelState, "latest");
14017
+ filteredMessageIds = _filteredMessageIds;
13993
14018
  updatedMessagesSet = messageSet;
13994
14019
  }
13995
14020
  if (updatedMessagesSet) {
@@ -13999,6 +14024,9 @@ var StreamChat = class _StreamChat {
13999
14024
  parentSet: updatedMessagesSet,
14000
14025
  requestedPageSize: queryChannelsOptions?.message_limit || DEFAULT_QUERY_CHANNELS_MESSAGE_LIST_PAGE_SIZE,
14001
14026
  returnedPage: channelState.messages,
14027
+ filteredReturnedPage: channelState.messages.filter(
14028
+ (m) => !filteredMessageIds.includes(m.id)
14029
+ ),
14002
14030
  logger: this.logger
14003
14031
  })
14004
14032
  };
@@ -15049,7 +15077,7 @@ var StreamChat = class _StreamChat {
15049
15077
  if (this.userAgent) {
15050
15078
  return this.userAgent;
15051
15079
  }
15052
- const version = "9.41.0";
15080
+ const version = "9.41.1";
15053
15081
  const clientBundle = "browser-esm";
15054
15082
  let userAgentString = "";
15055
15083
  if (this.sdkIdentifier) {