@connectedxm/admin 2.8.20 → 2.8.22

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.
package/dist/index.cjs CHANGED
@@ -1139,6 +1139,7 @@ __export(index_exports, {
1139
1139
  GetThreadMessageReactions: () => GetThreadMessageReactions,
1140
1140
  GetThreadMessageVideos: () => GetThreadMessageVideos,
1141
1141
  GetThreadMessages: () => GetThreadMessages,
1142
+ GetThreadMessagesPoll: () => GetThreadMessagesPoll,
1142
1143
  GetThreads: () => GetThreads,
1143
1144
  GetTier: () => GetTier,
1144
1145
  GetTierAccounts: () => GetTierAccounts,
@@ -1735,6 +1736,7 @@ __export(index_exports, {
1735
1736
  SET_THREAD_CIRCLE_ACCOUNT_QUERY_DATA: () => SET_THREAD_CIRCLE_ACCOUNT_QUERY_DATA,
1736
1737
  SET_THREAD_CIRCLE_QUERY_DATA: () => SET_THREAD_CIRCLE_QUERY_DATA,
1737
1738
  SET_THREAD_CIRCLE_THREADS_QUERY_DATA: () => SET_THREAD_CIRCLE_THREADS_QUERY_DATA,
1739
+ SET_THREAD_MESSAGES_POLL_QUERY_DATA: () => SET_THREAD_MESSAGES_POLL_QUERY_DATA,
1738
1740
  SET_THREAD_MESSAGES_QUERY_DATA: () => SET_THREAD_MESSAGES_QUERY_DATA,
1739
1741
  SET_THREAD_MESSAGE_FILES_QUERY_DATA: () => SET_THREAD_MESSAGE_FILES_QUERY_DATA,
1740
1742
  SET_THREAD_MESSAGE_IMAGES_QUERY_DATA: () => SET_THREAD_MESSAGE_IMAGES_QUERY_DATA,
@@ -1811,6 +1813,7 @@ __export(index_exports, {
1811
1813
  THREAD_CIRCLE_QUERY_KEY: () => THREAD_CIRCLE_QUERY_KEY,
1812
1814
  THREAD_CIRCLE_THREADS_QUERY_KEY: () => THREAD_CIRCLE_THREADS_QUERY_KEY,
1813
1815
  THREAD_MEMBERS_QUERY_KEY: () => THREAD_MEMBERS_QUERY_KEY,
1816
+ THREAD_MESSAGES_POLL_QUERY_KEY: () => THREAD_MESSAGES_POLL_QUERY_KEY,
1814
1817
  THREAD_MESSAGES_QUERY_KEY: () => THREAD_MESSAGES_QUERY_KEY,
1815
1818
  THREAD_MESSAGE_FILES_QUERY_KEY: () => THREAD_MESSAGE_FILES_QUERY_KEY,
1816
1819
  THREAD_MESSAGE_IMAGES_QUERY_KEY: () => THREAD_MESSAGE_IMAGES_QUERY_KEY,
@@ -2068,6 +2071,7 @@ __export(index_exports, {
2068
2071
  useCancelSubscription: () => useCancelSubscription,
2069
2072
  useCloneEvent: () => useCloneEvent,
2070
2073
  useConfirmAccountLogin: () => useConfirmAccountLogin,
2074
+ useConnectedCursorQuery: () => useConnectedCursorQuery,
2071
2075
  useConnectedInfiniteQuery: () => useConnectedInfiniteQuery,
2072
2076
  useConnectedMutation: () => useConnectedMutation,
2073
2077
  useConnectedSingleQuery: () => useConnectedSingleQuery,
@@ -2781,6 +2785,7 @@ __export(index_exports, {
2781
2785
  useGetThreadMessageReactions: () => useGetThreadMessageReactions,
2782
2786
  useGetThreadMessageVideos: () => useGetThreadMessageVideos,
2783
2787
  useGetThreadMessages: () => useGetThreadMessages,
2788
+ useGetThreadMessagesPoll: () => useGetThreadMessagesPoll,
2784
2789
  useGetThreads: () => useGetThreads,
2785
2790
  useGetTier: () => useGetTier,
2786
2791
  useGetTierAccounts: () => useGetTierAccounts,
@@ -3038,7 +3043,7 @@ module.exports = __toCommonJS(index_exports);
3038
3043
 
3039
3044
  // src/ConnectedXMProvider.tsx
3040
3045
  var import_react2 = __toESM(require("react"), 1);
3041
- var import_react_query3 = require("@tanstack/react-query");
3046
+ var import_react_query4 = require("@tanstack/react-query");
3042
3047
 
3043
3048
  // src/PermissionsWrapper.tsx
3044
3049
  var import_react = __toESM(require("react"), 1);
@@ -15755,6 +15760,8 @@ var BadgeFieldType = /* @__PURE__ */ ((BadgeFieldType2) => {
15755
15760
  BadgeFieldType2["tier"] = "tier";
15756
15761
  BadgeFieldType2["ticket"] = "ticket";
15757
15762
  BadgeFieldType2["pass"] = "pass";
15763
+ BadgeFieldType2["session"] = "session";
15764
+ BadgeFieldType2["session_question"] = "session_question";
15758
15765
  return BadgeFieldType2;
15759
15766
  })(BadgeFieldType || {});
15760
15767
  var BadgeFieldTransformation = /* @__PURE__ */ ((BadgeFieldTransformation2) => {
@@ -20874,6 +20881,71 @@ var useGetThreadMembers = (threadId = "", params = {}, options = {}) => {
20874
20881
  );
20875
20882
  };
20876
20883
 
20884
+ // src/queries/useConnectedCursorQuery.ts
20885
+ var import_react_query3 = require("@tanstack/react-query");
20886
+ var useConnectedCursorQuery = (queryKeys, queryFn, params = {}, options = {
20887
+ shouldRedirect: false
20888
+ }, domain) => {
20889
+ if (typeof params.pageSize === "undefined") params.pageSize = 25;
20890
+ const {
20891
+ onModuleForbidden,
20892
+ onNotAuthorized,
20893
+ onNotFound,
20894
+ apiUrl,
20895
+ getToken,
20896
+ organizationId,
20897
+ getExecuteAs,
20898
+ queryClient
20899
+ } = useConnectedXM();
20900
+ const { allowed } = usePermission_default(domain, domain ? "read" : void 0);
20901
+ const getNextPageParam = (lastPage) => {
20902
+ if (lastPage.cursor) {
20903
+ return lastPage.cursor;
20904
+ }
20905
+ return null;
20906
+ };
20907
+ return (0, import_react_query3.useInfiniteQuery)({
20908
+ staleTime: 60 * 1e3,
20909
+ // 60 Seconds
20910
+ retry: (failureCount, error) => {
20911
+ if (error.response?.status === 404) {
20912
+ if (onNotFound) onNotFound(error, queryKeys, options.shouldRedirect || false);
20913
+ return false;
20914
+ }
20915
+ if (error.response?.status === 403 || error.response?.status === 460 || error.response?.status === 461) {
20916
+ if (onModuleForbidden) onModuleForbidden(error, queryKeys, options.shouldRedirect || false);
20917
+ return false;
20918
+ }
20919
+ if (error.response?.status === 401) {
20920
+ if (onNotAuthorized) onNotAuthorized(error, queryKeys, options.shouldRedirect || false);
20921
+ return false;
20922
+ }
20923
+ if (failureCount < 3) return true;
20924
+ return false;
20925
+ },
20926
+ ...options,
20927
+ queryKey: [
20928
+ ...queryKeys,
20929
+ ...GetBaseInfiniteQueryKeys(params?.search)
20930
+ ],
20931
+ queryFn: ({ pageParam }) => queryFn({
20932
+ ...params,
20933
+ pageSize: params.pageSize || 25,
20934
+ cursor: pageParam,
20935
+ queryClient,
20936
+ adminApiParams: {
20937
+ apiUrl,
20938
+ getToken,
20939
+ organizationId,
20940
+ getExecuteAs
20941
+ }
20942
+ }),
20943
+ initialPageParam: null,
20944
+ getNextPageParam,
20945
+ enabled: (!domain || allowed) && options.enabled
20946
+ });
20947
+ };
20948
+
20877
20949
  // src/utilities/AppendInfiniteQuery.ts
20878
20950
  var import_immer = require("immer");
20879
20951
  var AppendInfiniteQuery = (queryClient, key, newData) => {
@@ -20997,7 +21069,7 @@ var THREAD_MESSAGES_QUERY_KEY = (threadId) => [
20997
21069
  ...THREAD_QUERY_KEY(threadId),
20998
21070
  "MESSAGES"
20999
21071
  ];
21000
- var SET_THREAD_MESSAGES_QUERY_DATA = (client, keyParams, response, baseKeys = ["en"]) => {
21072
+ var SET_THREAD_MESSAGES_QUERY_DATA = (client, keyParams, response, baseKeys = [""]) => {
21001
21073
  client.setQueryData(
21002
21074
  [
21003
21075
  ...THREAD_MESSAGES_QUERY_KEY(...keyParams),
@@ -21008,7 +21080,7 @@ var SET_THREAD_MESSAGES_QUERY_DATA = (client, keyParams, response, baseKeys = ["
21008
21080
  };
21009
21081
  var GetThreadMessages = async ({
21010
21082
  threadId,
21011
- pageParam,
21083
+ cursor,
21012
21084
  pageSize,
21013
21085
  orderBy,
21014
21086
  search,
@@ -21018,7 +21090,7 @@ var GetThreadMessages = async ({
21018
21090
  const adminApi = await GetAdminAPI(adminApiParams);
21019
21091
  const { data } = await adminApi.get(`/threads/${threadId}/messages`, {
21020
21092
  params: {
21021
- page: pageParam || void 0,
21093
+ cursor: cursor || void 0,
21022
21094
  pageSize: pageSize || void 0,
21023
21095
  orderBy: orderBy || void 0,
21024
21096
  search: search || void 0
@@ -21035,7 +21107,7 @@ var GetThreadMessages = async ({
21035
21107
  };
21036
21108
  var useGetThreadMessages = (threadId = "", params = {}, options = {}) => {
21037
21109
  const { authenticated } = useConnectedXM();
21038
- return useConnectedInfiniteQuery(
21110
+ return useConnectedCursorQuery(
21039
21111
  THREAD_MESSAGES_QUERY_KEY(threadId),
21040
21112
  (params2) => GetThreadMessages({ ...params2, threadId }),
21041
21113
  params,
@@ -21266,6 +21338,46 @@ var useGetThreadMessageVideos = (threadId, messageId, params = {}, options = {})
21266
21338
  );
21267
21339
  };
21268
21340
 
21341
+ // src/queries/threads/useGetThreadMessagesPoll.ts
21342
+ var THREAD_MESSAGES_POLL_QUERY_KEY = (threadId, lastMessageId) => [
21343
+ ...THREAD_QUERY_KEY(threadId),
21344
+ "MESSAGES",
21345
+ lastMessageId,
21346
+ "POLL"
21347
+ ];
21348
+ var SET_THREAD_MESSAGES_POLL_QUERY_DATA = (client, keyParams, response) => {
21349
+ client.setQueryData(THREAD_MESSAGES_POLL_QUERY_KEY(...keyParams), response);
21350
+ };
21351
+ var GetThreadMessagesPoll = async ({
21352
+ threadId,
21353
+ lastMessageId,
21354
+ adminApiParams
21355
+ }) => {
21356
+ const adminApi = await GetAdminAPI(adminApiParams);
21357
+ const { data } = await adminApi.get(`/threads/${threadId}/messages/poll`, {
21358
+ params: {
21359
+ lastMessageId: lastMessageId || void 0
21360
+ }
21361
+ });
21362
+ return data;
21363
+ };
21364
+ var useGetThreadMessagesPoll = (threadId = "", lastMessageId = "", options = {}) => {
21365
+ const { authenticated } = useConnectedXM();
21366
+ return useConnectedSingleQuery(
21367
+ THREAD_MESSAGES_POLL_QUERY_KEY(threadId, lastMessageId),
21368
+ (params) => GetThreadMessagesPoll({ ...params, threadId, lastMessageId }),
21369
+ {
21370
+ ...options,
21371
+ enabled: !!authenticated && !!threadId && !!lastMessageId && (options?.enabled ?? true),
21372
+ // Polling configuration - you can adjust these as needed
21373
+ refetchInterval: options.refetchInterval ?? 5e3,
21374
+ // Poll every 5 seconds
21375
+ refetchIntervalInBackground: options.refetchIntervalInBackground ?? false
21376
+ },
21377
+ "threads"
21378
+ );
21379
+ };
21380
+
21269
21381
  // src/queries/tiers/useGetTiers.ts
21270
21382
  var TIERS_QUERY_KEY = (type) => {
21271
21383
  const keys = ["TIERS"];
@@ -21701,7 +21813,7 @@ var ConnectedXMProvider = ({
21701
21813
  setSSR(false);
21702
21814
  }, []);
21703
21815
  if (ssr) {
21704
- return /* @__PURE__ */ import_react2.default.createElement(import_react_query3.QueryClientProvider, { client: queryClient }, /* @__PURE__ */ import_react2.default.createElement(
21816
+ return /* @__PURE__ */ import_react2.default.createElement(import_react_query4.QueryClientProvider, { client: queryClient }, /* @__PURE__ */ import_react2.default.createElement(
21705
21817
  ConnectedXMClientContext.Provider,
21706
21818
  {
21707
21819
  value: {
@@ -21759,15 +21871,15 @@ var useConnectedXM = () => {
21759
21871
  };
21760
21872
 
21761
21873
  // src/mutations/useConnectedMutation.ts
21762
- var import_react_query4 = require("@tanstack/react-query");
21874
+ var import_react_query5 = require("@tanstack/react-query");
21763
21875
  var useConnectedMutation = (mutation, options, permission) => {
21764
21876
  const { apiUrl, getToken, organizationId, getExecuteAs, onMutationError } = useConnectedXM();
21765
- const queryClient = (0, import_react_query4.useQueryClient)();
21877
+ const queryClient = (0, import_react_query5.useQueryClient)();
21766
21878
  const { allowed, enabled } = usePermission_default(
21767
21879
  permission?.domain,
21768
21880
  permission?.type
21769
21881
  );
21770
- return (0, import_react_query4.useMutation)({
21882
+ return (0, import_react_query5.useMutation)({
21771
21883
  mutationFn: (data) => {
21772
21884
  if (!!permission?.domain && !!permission.type) {
21773
21885
  if (!enabled) {
@@ -38864,7 +38976,7 @@ var useDeleteVideoCaption = (options = {}) => {
38864
38976
  };
38865
38977
 
38866
38978
  // src/mutations/videos/useDownloadVideoCaption.ts
38867
- var import_react_query5 = require("@tanstack/react-query");
38979
+ var import_react_query6 = require("@tanstack/react-query");
38868
38980
  var DownloadVideoCaption = async ({
38869
38981
  videoId,
38870
38982
  language,
@@ -38881,7 +38993,7 @@ var DownloadVideoCaption = async ({
38881
38993
  };
38882
38994
  var useDownloadVideoCaption = (options = {}) => {
38883
38995
  const { apiUrl, getToken, organizationId, getExecuteAs } = useConnectedXM();
38884
- return (0, import_react_query5.useMutation)({
38996
+ return (0, import_react_query6.useMutation)({
38885
38997
  mutationFn: (params) => DownloadVideoCaption({
38886
38998
  ...params,
38887
38999
  adminApiParams: {
@@ -40110,6 +40222,7 @@ var useUploadVideoCaptions = (options = {}) => {
40110
40222
  GetThreadMessageReactions,
40111
40223
  GetThreadMessageVideos,
40112
40224
  GetThreadMessages,
40225
+ GetThreadMessagesPoll,
40113
40226
  GetThreads,
40114
40227
  GetTier,
40115
40228
  GetTierAccounts,
@@ -40706,6 +40819,7 @@ var useUploadVideoCaptions = (options = {}) => {
40706
40819
  SET_THREAD_CIRCLE_ACCOUNT_QUERY_DATA,
40707
40820
  SET_THREAD_CIRCLE_QUERY_DATA,
40708
40821
  SET_THREAD_CIRCLE_THREADS_QUERY_DATA,
40822
+ SET_THREAD_MESSAGES_POLL_QUERY_DATA,
40709
40823
  SET_THREAD_MESSAGES_QUERY_DATA,
40710
40824
  SET_THREAD_MESSAGE_FILES_QUERY_DATA,
40711
40825
  SET_THREAD_MESSAGE_IMAGES_QUERY_DATA,
@@ -40782,6 +40896,7 @@ var useUploadVideoCaptions = (options = {}) => {
40782
40896
  THREAD_CIRCLE_QUERY_KEY,
40783
40897
  THREAD_CIRCLE_THREADS_QUERY_KEY,
40784
40898
  THREAD_MEMBERS_QUERY_KEY,
40899
+ THREAD_MESSAGES_POLL_QUERY_KEY,
40785
40900
  THREAD_MESSAGES_QUERY_KEY,
40786
40901
  THREAD_MESSAGE_FILES_QUERY_KEY,
40787
40902
  THREAD_MESSAGE_IMAGES_QUERY_KEY,
@@ -41039,6 +41154,7 @@ var useUploadVideoCaptions = (options = {}) => {
41039
41154
  useCancelSubscription,
41040
41155
  useCloneEvent,
41041
41156
  useConfirmAccountLogin,
41157
+ useConnectedCursorQuery,
41042
41158
  useConnectedInfiniteQuery,
41043
41159
  useConnectedMutation,
41044
41160
  useConnectedSingleQuery,
@@ -41752,6 +41868,7 @@ var useUploadVideoCaptions = (options = {}) => {
41752
41868
  useGetThreadMessageReactions,
41753
41869
  useGetThreadMessageVideos,
41754
41870
  useGetThreadMessages,
41871
+ useGetThreadMessagesPoll,
41755
41872
  useGetThreads,
41756
41873
  useGetTier,
41757
41874
  useGetTierAccounts,