@messenger-box/platform-mobile 10.0.3-alpha.18 → 10.0.3-alpha.180

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 (98) hide show
  1. package/lib/compute.js +2 -3
  2. package/lib/compute.js.map +1 -1
  3. package/lib/index.js.map +1 -1
  4. package/lib/module.js.map +1 -1
  5. package/lib/queries/inboxQueries.js +65 -0
  6. package/lib/queries/inboxQueries.js.map +1 -0
  7. package/lib/routes.json +2 -3
  8. package/lib/screens/inbox/DialogMessages.js +8 -3
  9. package/lib/screens/inbox/DialogMessages.js.map +1 -1
  10. package/lib/screens/inbox/DialogThreadMessages.js +6 -11
  11. package/lib/screens/inbox/DialogThreadMessages.js.map +1 -1
  12. package/lib/screens/inbox/DialogThreads.js +58 -20
  13. package/lib/screens/inbox/DialogThreads.js.map +1 -1
  14. package/lib/screens/inbox/Inbox.js.map +1 -1
  15. package/lib/screens/inbox/components/CachedImage/consts.js.map +1 -1
  16. package/lib/screens/inbox/components/CachedImage/index.js +125 -115
  17. package/lib/screens/inbox/components/CachedImage/index.js.map +1 -1
  18. package/lib/screens/inbox/components/DialogItem.js +160 -0
  19. package/lib/screens/inbox/components/DialogItem.js.map +1 -0
  20. package/lib/screens/inbox/components/GiftedChatInboxComponent.js +313 -0
  21. package/lib/screens/inbox/components/GiftedChatInboxComponent.js.map +1 -0
  22. package/lib/screens/inbox/components/SlackMessageContainer/ImageViewerModal.js +2 -0
  23. package/lib/screens/inbox/components/SlackMessageContainer/ImageViewerModal.js.map +1 -1
  24. package/lib/screens/inbox/components/SlackMessageContainer/PaymentMessage.js +194 -0
  25. package/lib/screens/inbox/components/SlackMessageContainer/PaymentMessage.js.map +1 -0
  26. package/lib/screens/inbox/components/SlackMessageContainer/SlackBubble.js +144 -32
  27. package/lib/screens/inbox/components/SlackMessageContainer/SlackBubble.js.map +1 -1
  28. package/lib/screens/inbox/components/SlackMessageContainer/SlackMessage.js +3 -4
  29. package/lib/screens/inbox/components/SlackMessageContainer/SlackMessage.js.map +1 -1
  30. package/lib/screens/inbox/components/SubscriptionHandler.js +22 -0
  31. package/lib/screens/inbox/components/SubscriptionHandler.js.map +1 -0
  32. package/lib/screens/inbox/components/ThreadsViewItem.js +67 -47
  33. package/lib/screens/inbox/components/ThreadsViewItem.js.map +1 -1
  34. package/lib/screens/inbox/config/config.js +4 -2
  35. package/lib/screens/inbox/config/config.js.map +1 -1
  36. package/lib/screens/inbox/containers/ConversationView.js +1098 -1093
  37. package/lib/screens/inbox/containers/ConversationView.js.map +1 -1
  38. package/lib/screens/inbox/containers/Dialogs.js +179 -333
  39. package/lib/screens/inbox/containers/Dialogs.js.map +1 -1
  40. package/lib/screens/inbox/containers/ThreadConversationView.js +873 -866
  41. package/lib/screens/inbox/containers/ThreadConversationView.js.map +1 -1
  42. package/lib/screens/inbox/containers/ThreadsView.js +81 -54
  43. package/lib/screens/inbox/containers/ThreadsView.js.map +1 -1
  44. package/lib/screens/inbox/hooks/useInboxMessages.js +31 -0
  45. package/lib/screens/inbox/hooks/useInboxMessages.js.map +1 -0
  46. package/lib/screens/inbox/hooks/useSafeDialogThreadsMachine.js +108 -0
  47. package/lib/screens/inbox/hooks/useSafeDialogThreadsMachine.js.map +1 -0
  48. package/lib/screens/inbox/workflow/dialog-threads-xstate.js +151 -0
  49. package/lib/screens/inbox/workflow/dialog-threads-xstate.js.map +1 -0
  50. package/package.json +5 -5
  51. package/CHANGELOG.md +0 -156
  52. package/jest.config.js +0 -24
  53. package/lib/screens/inbox/components/DialogsListItem.js +0 -175
  54. package/lib/screens/inbox/components/DialogsListItem.js.map +0 -1
  55. package/lib/screens/inbox/components/ServiceDialogsListItem.js +0 -165
  56. package/lib/screens/inbox/components/ServiceDialogsListItem.js.map +0 -1
  57. package/lib/screens/inbox/containers/workflow/conversation-xstate.js +0 -380
  58. package/lib/screens/inbox/containers/workflow/conversation-xstate.js.map +0 -1
  59. package/lib/screens/inbox/containers/workflow/dialogs-xstate.js +0 -235
  60. package/lib/screens/inbox/containers/workflow/dialogs-xstate.js.map +0 -1
  61. package/lib/screens/inbox/containers/workflow/thread-conversation-xstate.js +0 -438
  62. package/lib/screens/inbox/containers/workflow/thread-conversation-xstate.js.map +0 -1
  63. package/rollup.config.mjs +0 -45
  64. package/src/components/index.ts +0 -0
  65. package/src/compute.ts +0 -63
  66. package/src/index.ts +0 -7
  67. package/src/module.ts +0 -10
  68. package/src/navigation/InboxNavigation.tsx +0 -102
  69. package/src/navigation/index.ts +0 -1
  70. package/src/screens/inbox/DialogMessages.tsx +0 -21
  71. package/src/screens/inbox/DialogThreadMessages.tsx +0 -97
  72. package/src/screens/inbox/DialogThreads.tsx +0 -129
  73. package/src/screens/inbox/Inbox.tsx +0 -17
  74. package/src/screens/inbox/components/CachedImage/consts.ts +0 -6
  75. package/src/screens/inbox/components/CachedImage/index.tsx +0 -223
  76. package/src/screens/inbox/components/DialogsHeader.tsx +0 -30
  77. package/src/screens/inbox/components/DialogsListItem.tsx +0 -302
  78. package/src/screens/inbox/components/ServiceDialogsListItem.tsx +0 -287
  79. package/src/screens/inbox/components/SlackMessageContainer/ImageViewerModal.tsx +0 -113
  80. package/src/screens/inbox/components/SlackMessageContainer/SlackBubble.tsx +0 -313
  81. package/src/screens/inbox/components/SlackMessageContainer/SlackMessage.tsx +0 -145
  82. package/src/screens/inbox/components/SlackMessageContainer/index.ts +0 -3
  83. package/src/screens/inbox/components/SupportServiceDialogsListItem.tsx +0 -283
  84. package/src/screens/inbox/components/ThreadsViewItem.tsx +0 -321
  85. package/src/screens/inbox/config/config.ts +0 -15
  86. package/src/screens/inbox/config/index.ts +0 -1
  87. package/src/screens/inbox/containers/ConversationView.tsx +0 -1782
  88. package/src/screens/inbox/containers/Dialogs.tsx +0 -544
  89. package/src/screens/inbox/containers/SupportServiceDialogs.tsx +0 -119
  90. package/src/screens/inbox/containers/ThreadConversationView.tsx +0 -1537
  91. package/src/screens/inbox/containers/ThreadsView.tsx +0 -305
  92. package/src/screens/inbox/containers/workflow/apollo/handleResult.ts +0 -20
  93. package/src/screens/inbox/containers/workflow/conversation-xstate.ts +0 -313
  94. package/src/screens/inbox/containers/workflow/dialogs-xstate.ts +0 -196
  95. package/src/screens/inbox/containers/workflow/thread-conversation-xstate.ts +0 -401
  96. package/src/screens/index.ts +0 -4
  97. package/tsconfig.json +0 -13
  98. package/webpack.config.js +0 -58
@@ -1 +0,0 @@
1
- {"version":3,"file":"thread-conversation-xstate.js","sources":["../../../../../src/screens/inbox/containers/workflow/thread-conversation-xstate.ts"],"sourcesContent":["import { assign, setup } from 'xstate';\nimport { merge } from 'lodash-es';\n\nexport const enum Actions {\n INITIAL_CONTEXT = 'INITIAL_CONTEXT',\n ERROR_HANDLED = 'ERROR_HANDLED',\n SEND_THREAD_MESSAGE = 'SEND_THREAD_MESSAGE',\n SEND_THREAD_MESSAGE_WITH_FILE = 'SEND_THREAD_MESSAGE_WITH_FILE',\n SET_THREAD_MESSAGES = 'SET_THREAD_MESSAGES',\n CLEAR_MESSAGES = 'CLEAR_MESSAGES',\n FETCH_MORE_MESSAGES = 'FETCH_MORE_MESSAGES',\n SUBSCRIBE_TO_THREAD_MESSAGES = 'SUBSCRIBE_TO_THREAD_MESSAGES',\n START_LOADING = 'START_LOADING',\n STOP_LOADING = 'STOP_LOADING',\n SET_IMAGE = 'SET_IMAGE',\n CLEAR_IMAGE = 'CLEAR_IMAGE',\n SET_MESSAGE_TEXT = 'SET_MESSAGE_TEXT',\n}\n\nexport const enum BaseState {\n Idle = 'idle',\n Error = 'error',\n Loading = 'loading',\n Done = 'done',\n FetchThreadMessages = 'fetchThreadMessages',\n}\n\nexport const enum MainState {\n SendThreadMessage = 'sendThreadMessage',\n SendThreadMessageWithFile = 'sendThreadMessageWithFile',\n FetchMoreMessages = 'fetchMoreMessages',\n}\n\nexport const threadConversationXstate = setup({\n types: {\n context: {} as {\n channelId: string | null;\n postParentId: string | null;\n role: string | null;\n threadMessages: any[];\n totalCount: number;\n skip: number;\n loading: boolean;\n loadingOldMessages: boolean;\n error: string | null;\n selectedImage: string;\n files: any[];\n images: any[];\n messageText: string;\n imageLoading: boolean;\n postThread: any;\n threadPost: any[];\n isScrollToBottom: boolean;\n },\n },\n actions: {\n errorState: assign(({ context, event }) => {\n return {\n ...context,\n error: event.data?.message || 'An error occurred',\n loading: false,\n loadingOldMessages: false,\n imageLoading: false,\n };\n }),\n setInitialContext: assign(({ context, event }) => {\n return merge({\n ...context,\n channelId: event.data?.channelId || null,\n postParentId: event.data?.postParentId || null,\n role: event.data?.role || null,\n loading: false,\n });\n }),\n setThreadMessages: assign(({ context, event }) => {\n const messages = event.data?.messages || [];\n console.log(`setThreadMessages: Setting ${messages.length} messages`);\n\n // Create a set of unique IDs to remove duplicates\n const messageIds = new Set();\n const uniqueMessages = [];\n\n // Process messages to ensure uniqueness\n messages.forEach((msg) => {\n if (msg.id && !messageIds.has(msg.id)) {\n messageIds.add(msg.id);\n uniqueMessages.push(msg);\n }\n });\n\n console.log(`setThreadMessages: After deduplication, have ${uniqueMessages.length} unique messages`);\n\n return {\n ...context,\n threadMessages: uniqueMessages,\n totalCount: event.data?.totalCount || 0,\n loading: false,\n loadingOldMessages: false,\n threadPost: event.data?.threadPost || [],\n postThread: event.data?.postThread || null,\n };\n }),\n addThreadMessages: assign(({ context, event }) => {\n const newMessages = event.data?.messages || [];\n console.log('Adding thread messages and disabling loading state. New messages:', newMessages.length);\n\n if (newMessages.length === 0) {\n return {\n ...context,\n loadingOldMessages: false,\n loading: false,\n };\n }\n\n // Create a map of existing message IDs for quick lookup\n const existingMessageIds = new Set();\n context.threadMessages.forEach((msg) => existingMessageIds.add(msg.id));\n\n // Filter out any duplicate messages\n const uniqueNewMessages = newMessages.filter((msg) => {\n if (!msg.id || existingMessageIds.has(msg.id)) {\n console.log('Skipping duplicate message:', msg.id);\n return false; // Skip messages with no ID or duplicates\n }\n existingMessageIds.add(msg.id); // Add to set to catch duplicates in the new messages\n return true;\n });\n\n console.log(`After filtering, adding ${uniqueNewMessages.length} unique messages`);\n\n return {\n ...context,\n threadMessages: [...context.threadMessages, ...uniqueNewMessages],\n loadingOldMessages: false,\n loading: false,\n };\n }),\n addNewMessage: assign(({ context, event }) => {\n const message = event.data?.message;\n console.log('Adding new message to thread:', message?.id);\n if (!message) {\n console.warn('No message data provided to addNewMessage action');\n return context;\n }\n\n // Prevent duplicate messages by checking for the same ID\n const existingMessageIndex = context.threadMessages.findIndex((msg) => msg.id === message.id);\n if (existingMessageIndex !== -1) {\n console.log('Message already exists, not adding duplicate:', message.id);\n return {\n ...context,\n loading: false,\n };\n }\n\n // Use a set to ensure we only have unique message IDs\n const messageIds = new Set();\n const uniqueMessages = [...context.threadMessages];\n\n // Add all existing message IDs to the set\n uniqueMessages.forEach((msg) => messageIds.add(msg.id));\n\n // Only add the new message if its ID isn't already in the set\n if (!messageIds.has(message.id)) {\n uniqueMessages.unshift(message); // Add to beginning (newest first)\n }\n\n console.log('Successfully added new message to thread');\n return {\n ...context,\n threadMessages: uniqueMessages,\n totalCount: context.totalCount + 1,\n loading: false,\n };\n }),\n updateSkip: assign(({ context, event }) => {\n console.log('Setting loadingOldMessages to true');\n return {\n ...context,\n skip: context.threadMessages.length,\n loadingOldMessages: true,\n loading: event.data?.loading !== undefined ? event.data.loading : context.loading,\n };\n }),\n clearMessages: assign(({ context }) => {\n return {\n ...context,\n threadMessages: [],\n totalCount: 0,\n skip: 0,\n };\n }),\n setPostParentId: assign(({ context, event }) => {\n return {\n ...context,\n postParentId: event.data?.postParentId || null,\n };\n }),\n setPostThread: assign(({ context, event }) => {\n return {\n ...context,\n postThread: event.data?.postThread || null,\n };\n }),\n startLoading: assign(({ context, event }) => {\n return {\n ...context,\n loading: true,\n loadingOldMessages:\n event.data?.loadingOldMessages !== undefined\n ? event.data.loadingOldMessages\n : context.loadingOldMessages,\n };\n }),\n stopLoading: assign(({ context, event }) => {\n return {\n ...context,\n loading: false,\n loadingOldMessages:\n event.data?.loadingOldMessages !== undefined\n ? event.data.loadingOldMessages\n : context.loadingOldMessages,\n };\n }),\n startImageLoading: assign(({ context }) => {\n return {\n ...context,\n imageLoading: true,\n };\n }),\n stopImageLoading: assign(({ context }) => {\n return {\n ...context,\n imageLoading: false,\n };\n }),\n setSelectedImage: assign(({ context, event }) => {\n return {\n ...context,\n selectedImage: event.data?.image || '',\n files: event.data?.files || context.files,\n images: event.data?.images || context.images,\n imageLoading: false,\n };\n }),\n clearImageData: assign(({ context }) => {\n return {\n ...context,\n selectedImage: '',\n files: [],\n images: [],\n };\n }),\n setMessageText: assign(({ context, event }) => {\n return {\n ...context,\n messageText: event.data?.messageText || '',\n };\n }),\n setScrollToBottom: assign(({ context, event }) => {\n return {\n ...context,\n isScrollToBottom: event.data?.isScrollToBottom || false,\n };\n }),\n },\n guards: {\n hasMoreMessages: ({ context }) => {\n return context.totalCount > context.threadMessages.length;\n },\n },\n}).createMachine({\n id: 'thread-conversation-view',\n initial: BaseState.Idle,\n context: {\n channelId: null,\n postParentId: null,\n role: null,\n threadMessages: [],\n totalCount: 0,\n skip: 0,\n loading: false,\n loadingOldMessages: false,\n error: null,\n selectedImage: '',\n files: [],\n images: [],\n messageText: '',\n imageLoading: false,\n postThread: null,\n threadPost: [],\n isScrollToBottom: false,\n },\n states: {\n [BaseState.Idle]: {\n on: {\n [Actions.INITIAL_CONTEXT]: {\n target: BaseState.FetchThreadMessages,\n actions: ['setInitialContext'],\n },\n [Actions.SEND_THREAD_MESSAGE]: {\n target: MainState.SendThreadMessage,\n actions: ['startLoading'],\n },\n [Actions.SEND_THREAD_MESSAGE_WITH_FILE]: {\n target: MainState.SendThreadMessageWithFile,\n actions: ['startLoading'],\n },\n [Actions.FETCH_MORE_MESSAGES]: {\n target: MainState.FetchMoreMessages,\n actions: ['updateSkip'],\n guard: 'hasMoreMessages',\n },\n [Actions.CLEAR_MESSAGES]: {\n target: BaseState.Idle,\n actions: ['clearMessages'],\n },\n [Actions.START_LOADING]: {\n target: BaseState.Idle,\n actions: ['startLoading'],\n },\n [Actions.STOP_LOADING]: {\n target: BaseState.Idle,\n actions: ['stopLoading'],\n },\n [Actions.SET_IMAGE]: {\n target: BaseState.Idle,\n actions: ['setSelectedImage'],\n },\n [Actions.CLEAR_IMAGE]: {\n target: BaseState.Idle,\n actions: ['clearImageData'],\n },\n [Actions.SET_MESSAGE_TEXT]: {\n target: BaseState.Idle,\n actions: ['setMessageText'],\n },\n },\n },\n [BaseState.Error]: {\n entry: ['errorState'],\n on: {\n [Actions.ERROR_HANDLED]: {\n target: BaseState.Idle,\n },\n },\n },\n [BaseState.FetchThreadMessages]: {\n invoke: {\n src: 'fetchThreadMessages',\n input: ({ context, event }) => ({ context, event }),\n onDone: {\n target: BaseState.Idle,\n actions: ['setThreadMessages'],\n },\n onError: {\n target: BaseState.Error,\n },\n },\n },\n [MainState.SendThreadMessage]: {\n invoke: {\n src: 'sendThreadMessage',\n input: ({ context, event }) => ({ context, event }),\n onDone: {\n target: BaseState.Idle,\n actions: ['addNewMessage', 'stopLoading'],\n },\n onError: {\n target: BaseState.Error,\n },\n },\n },\n [MainState.SendThreadMessageWithFile]: {\n invoke: {\n src: 'sendThreadMessageWithFile',\n input: ({ context, event }) => ({ context, event }),\n onDone: {\n target: BaseState.Idle,\n actions: ['addNewMessage', 'clearImageData', 'stopLoading'],\n },\n onError: {\n target: BaseState.Error,\n },\n },\n },\n [MainState.FetchMoreMessages]: {\n invoke: {\n src: 'fetchMoreThreadMessages',\n input: ({ context, event }) => ({ context, event }),\n onDone: {\n target: BaseState.Idle,\n actions: ['addThreadMessages'],\n },\n onError: {\n target: BaseState.Error,\n },\n },\n },\n },\n} as any);\n"],"names":["Actions","BaseState","MainState"],"mappings":"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"}
package/rollup.config.mjs DELETED
@@ -1,45 +0,0 @@
1
- import json from '@rollup/plugin-json';
2
- import resolve from '@rollup/plugin-node-resolve';
3
- import { createRollupConfig } from '../../../rollup.config.base.mjs';
4
-
5
- // Define any additional plugins specific to this bundle
6
- const additionalPlugins = [
7
- json(),
8
- resolve(), // resolves node_modules
9
- ];
10
-
11
- // Use the createRollupConfig function to merge the base and specific configurations
12
- export default (commandLineArgs) => {
13
- const isWatchMode = commandLineArgs.watch;
14
- return [
15
- createRollupConfig(
16
- {
17
- input: ['src/index.ts'],
18
- output: [
19
- {
20
- dir: 'lib',
21
- format: 'es',
22
- name: 'Inbox',
23
- compact: true,
24
- exports: 'named',
25
- sourcemap: true,
26
- preserveModules: true,
27
- chunkFileNames: '[name]-[hash].[format].js',
28
- globals: { react: 'React' },
29
- },
30
- ],
31
- plugins: [
32
- // Spread in additional plugins specific to this config
33
- ...additionalPlugins,
34
- ],
35
- // Enable caching for faster rebuilds
36
- cache: true,
37
- },
38
- {
39
- isWatchMode,
40
- generateRoutesJSON: true,
41
- useEsbuild: true,
42
- },
43
- ),
44
- ];
45
- };
File without changes
package/src/compute.ts DELETED
@@ -1,63 +0,0 @@
1
- /* eslint-disable import/no-extraneous-dependencies */
2
- import { getFilteredRoutes } from '@common-stack/client-react/lib/utils/filteredRoutes.js';
3
- import type { IRouteModule } from '@common-stack/core';
4
-
5
- export const inboxPageStore: IRouteModule[] = [
6
- {
7
- key: 'message',
8
- path: '/message',
9
- name: 'Message',
10
- exact: true,
11
- component: () => import('./screens/inbox/DialogMessages'),
12
- props: {
13
- initialParams: { channelId: null, role: null, isShowThreadMessage: true },
14
- options: {
15
- headerShown: true,
16
- title: 'Inbox',
17
- headerBackTitleVisible: false,
18
- gestureEnabled: false,
19
- swipeEnabled: false,
20
- },
21
- },
22
- },
23
- {
24
- key: 'thread',
25
- path: '/thread',
26
- name: 'Thread',
27
- exact: true,
28
- component: () => import('./screens/inbox/DialogThreads'),
29
- props: {
30
- initialParams: { channelId: null, postParentId: null, role: null },
31
- options: {
32
- headerShown: true,
33
- title: 'Thread',
34
- headerBackTitleVisible: false,
35
- gestureEnabled: false,
36
- swipeEnabled: false,
37
- },
38
- },
39
- },
40
- {
41
- key: 'threadmessage',
42
- path: '/threadmessage',
43
- name: 'ThreadMessage',
44
- exact: true,
45
- component: () => import('./screens/inbox/DialogThreadMessages'),
46
- props: {
47
- initialParams: { channelId: null, postParentId: null, isPostParentIdThread: null, role: null },
48
- options: {
49
- headerShown: true,
50
- title: 'Inbox',
51
- headerBackTitleVisible: false,
52
- gestureEnabled: false,
53
- swipeEnabled: false,
54
- },
55
- },
56
- },
57
- ];
58
-
59
- const selectedRoutes = ['message', 'thread', 'threadmessage'];
60
-
61
- const filteredRoutes = getFilteredRoutes(inboxPageStore, selectedRoutes);
62
-
63
- export { filteredRoutes };
package/src/index.ts DELETED
@@ -1,7 +0,0 @@
1
- import PlatformModule from './module';
2
-
3
- import { Feature } from '@common-stack/client-react';
4
-
5
- export default new Feature(PlatformModule);
6
- // export * from './navigation';
7
- export * from './screens';
package/src/module.ts DELETED
@@ -1,10 +0,0 @@
1
- /* eslint-disable import/no-extraneous-dependencies */
2
- import { Feature } from '@common-stack/client-react';
3
- import { schema, typePolicies, dataIdFromObject } from '@messenger-box/platform-client';
4
- import {filteredRoutes} from './compute';
5
-
6
- export default new Feature({
7
- dataIdFromObject,
8
- clientStateParams: { typeDefs: schema, typePolicies },
9
- routeConfig: filteredRoutes as any,
10
- });
@@ -1,102 +0,0 @@
1
- import * as React from 'react';
2
- import { Feature } from '@common-stack/client-react';
3
- import { DialogMessages } from '../screens/inbox/DialogMessages';
4
- import { DialogThreads } from '../screens/inbox/DialogThreads';
5
- import { DialogThreadMessages } from '../screens/inbox/DialogThreadMessages';
6
- import { Button, Icon } from '@admin-layout/gluestack-ui-mobile';
7
- import { MaterialIcons } from '@expo/vector-icons';
8
-
9
- const inboxConfig = {
10
- ['//message']: {
11
- exact: true,
12
- name: 'Message',
13
- props: {
14
- initialParams: { channelId: null, role: null, isShowThreadMessage: true },
15
- component: (props: any) => (
16
- <DialogMessages
17
- {...props}
18
- channelId={props?.route?.params?.channelId}
19
- role={props?.route?.params?.role}
20
- isShowThreadMessage={props?.route?.params?.isShowThreadMessage}
21
- />
22
- ),
23
- options: ({ navigation }: any) => {
24
- return {
25
- headerShown: true,
26
- title: 'Inbox',
27
- headerBackTitleVisible: false,
28
- gestureEnabled: false,
29
- swipeEnabled: false,
30
- headerLeft: (props: any) => (
31
- <Button className="bg-transparent" onPress={() => navigation.goBack()}>
32
- <MaterialIcons size={20} name="arrow-back-ios" color={'black'} />
33
- </Button>
34
- ),
35
- };
36
- },
37
- },
38
- },
39
- ['//thread']: {
40
- exact: true,
41
- name: 'Thread',
42
- props: {
43
- initialParams: { channelId: null, postParentId: null, role: null },
44
- component: (props: any) => (
45
- <DialogThreads
46
- {...props}
47
- channelId={props?.route?.params?.channelId}
48
- postParentId={props?.route?.params?.postParentId}
49
- role={props?.route?.params?.role}
50
- />
51
- ),
52
- options: ({ navigation }: any) => {
53
- return {
54
- headerShown: true,
55
- title: 'Thread',
56
- headerBackTitleVisible: false,
57
- gestureEnabled: false,
58
- swipeEnabled: false,
59
- headerLeft: (props: any) => (
60
- <Button className="bg-transparent" onPress={() => navigation.goBack()}>
61
- <MaterialIcons size={20} name="arrow-back-ios" color={'black'} />
62
- </Button>
63
- ),
64
- };
65
- },
66
- },
67
- },
68
- ['//threadmessage']: {
69
- exact: true,
70
- name: 'ThreadMessage',
71
- props: {
72
- initialParams: { channelId: null, postParentId: null, isPostParentIdThread: null, role: null },
73
- component: (props: any) => (
74
- <DialogThreadMessages
75
- {...props}
76
- channelId={props?.route?.params?.channelId}
77
- postParentId={props?.route?.params?.postParentId}
78
- isPostParentIdThread={props?.route?.params?.isPostParentIdThread}
79
- role={props?.route?.params?.role}
80
- />
81
- ),
82
- options: ({ navigation }: any) => {
83
- return {
84
- headerShown: true,
85
- title: 'Inbox',
86
- headerBackTitleVisible: false,
87
- gestureEnabled: false,
88
- swipeEnabled: false,
89
- headerLeft: (props: any) => (
90
- <Button className="bg-transparent" onPress={() => navigation.goBack()}>
91
- <MaterialIcons size={20} name="arrow-back-ios" color={'black'} />
92
- </Button>
93
- ),
94
- };
95
- },
96
- },
97
- },
98
- };
99
-
100
- export const inboxFeature = new Feature({
101
- routeConfig: inboxConfig as any,
102
- });
@@ -1 +0,0 @@
1
- export * from './InboxNavigation';
@@ -1,21 +0,0 @@
1
- import * as React from 'react';
2
- import { Box } from '@admin-layout/gluestack-ui-mobile';
3
- import { ConversationView } from './containers/ConversationView';
4
- import { navigationRef } from '@common-stack/client-react';
5
-
6
- export function DialogMessages({ channelId, role, isShowThreadMessage = true, ...rest }) {
7
- const currentRoute = navigationRef.isReady() ? navigationRef?.getCurrentRoute() : null;
8
- return (
9
- // <Box bg={'white'} flex={1} pt={5}>
10
- <Box className="bg-white flex-1">
11
- <ConversationView
12
- {...rest}
13
- channelId={currentRoute?.params?.channelId ?? channelId}
14
- role={role}
15
- isShowThreadMessage={isShowThreadMessage}
16
- />
17
- </Box>
18
- );
19
- }
20
-
21
- export default DialogMessages;
@@ -1,97 +0,0 @@
1
- import * as React from 'react';
2
- import { Box, Spinner, Text } from '@admin-layout/gluestack-ui-mobile';
3
- import { ThreadConversationView } from './containers/ThreadConversationView';
4
- import { ThreadsView } from './containers/ThreadsView';
5
- import { useViewChannelDetailQuery, useSendThreadMessageMutation } from 'common/graphql';
6
- import { useFocusEffect } from '@react-navigation/native';
7
- // import { useSelector } from 'react-redux';
8
- import colors from 'tailwindcss/colors';
9
-
10
- export function DialogThreadMessages({ channelId, postParentId, isPostParentIdThread, role }) {
11
- const {
12
- data,
13
- loading: channelLoading,
14
- refetch,
15
- } = useViewChannelDetailQuery({
16
- variables: {
17
- id: channelId?.toString(),
18
- },
19
- });
20
-
21
- const [sendThreadMessage] = useSendThreadMessageMutation();
22
- const [loading, setLoading] = React.useState<boolean>(true);
23
- const [channel, setChannel] = React.useState<any>(null);
24
- const [parentId, setParentId] = React.useState<any>(postParentId);
25
-
26
- const refetchChannelDetail = React.useCallback(
27
- (id: string) => {
28
- return refetch({ id: id?.toString() });
29
- },
30
- [channelId],
31
- );
32
-
33
- useFocusEffect(
34
- React.useCallback(() => {
35
- // Do something when the screen is focused
36
- if (channelId) refetch({ id: channelId?.toString() });
37
- return () => {};
38
- }, [channelId]),
39
- );
40
-
41
- React.useEffect(() => {
42
- setParentId(postParentId);
43
- }, [postParentId]);
44
-
45
- React.useEffect(() => {
46
- if (data?.viewChannelDetail) {
47
- setChannel(data?.viewChannelDetail);
48
- setLoading(false);
49
- }
50
- }, [data]);
51
-
52
- // React.useEffect(() => {
53
- // async function sendInitialMessage(channel: any) {
54
- // const content = `Welcome to ${channel?.title}`;
55
- // const createdBy = channel?.creator?.id;
56
- // await sendThreadMessage({
57
- // variables: {
58
- // channelId,
59
- // threadMessageInput: {
60
- // content,
61
- // role,
62
- // },
63
- // responderId: createdBy,
64
- // },
65
- // update: (cache, { data, errors }: any) => {
66
- // if (!data) {
67
- // return;
68
- // }
69
- // setParentId(data?.sendThreadMessage?.lastMessage?.id);
70
- // },
71
- // });
72
- // }
73
- // if ((!parentId || parentId == 0) && channel) {
74
- // sendInitialMessage(channel);
75
- // }
76
-
77
- // if (parentId) setLoading(false);
78
- // }, [parentId, channel]);
79
-
80
- return (
81
- <Box className="bg-white flex-1">
82
- {/* {loading && !parentId ? ( */}
83
- {loading ? (
84
- <Spinner color={colors.blue[500]} />
85
- ) : (
86
- <ThreadConversationView
87
- channelId={channelId}
88
- postParentId={parentId}
89
- isPostParentIdThread={isPostParentIdThread}
90
- role={role}
91
- />
92
- )}
93
- </Box>
94
- );
95
- }
96
-
97
- export default DialogThreadMessages;
@@ -1,129 +0,0 @@
1
- import * as React from 'react';
2
- import { Box, Spinner, Text } from '@admin-layout/gluestack-ui-mobile';
3
- import { ThreadConversationView } from './containers/ThreadConversationView';
4
- import { ThreadsView } from './containers/ThreadsView';
5
- import { useViewChannelDetailQuery, useThreadMessagesQuery } from 'common/graphql';
6
- import { useFocusEffect } from '@react-navigation/native';
7
- import { useSelector } from 'react-redux';
8
- import { config } from './config';
9
- import colors from 'tailwindcss/colors';
10
- const { MESSAGES_PER_PAGE } = config;
11
-
12
- export function DialogThreads({ channelId, postParentId, role }) {
13
- const {
14
- data: channelData,
15
- loading: channelLoading,
16
- refetch: channelRefetch,
17
- } = useViewChannelDetailQuery({
18
- variables: {
19
- id: channelId?.toString(),
20
- },
21
- });
22
-
23
- const {
24
- data: threadsData,
25
- loading: threadLoading,
26
- error: threadsError,
27
- refetch: threadsRefetch,
28
- subscribeToMore: threadsSubscribeToMore,
29
- } = useThreadMessagesQuery({
30
- variables: {
31
- channelId: channelId?.toString(),
32
- role: role?.toString(),
33
- limit: MESSAGES_PER_PAGE,
34
- repliesLimit2: 5,
35
- },
36
- // fetchPolicy: 'cache-and-network',
37
- });
38
-
39
- const channelsDetail = React.useMemo(() => {
40
- if (!channelData?.viewChannelDetail) return null;
41
- return channelData?.viewChannelDetail;
42
- }, [channelData]);
43
-
44
- const refetchChannelDetail = React.useCallback(
45
- (id: string) => {
46
- return channelRefetch({ id: id?.toString() });
47
- },
48
- [channelId],
49
- );
50
-
51
- useFocusEffect(
52
- React.useCallback(() => {
53
- // Do something when the screen is focused
54
- if (channelId) refetchChannelDetail(channelId);
55
- return () => {};
56
- }, []),
57
- );
58
-
59
- return (
60
- // <Box bg={'white'} flex={1} pt={5}>
61
- <>
62
- {channelLoading ? (
63
- <Spinner color={colors.blue[500]} />
64
- ) : (
65
- <>
66
- <Box
67
- // $dark-borderColor="$coolGray600"
68
- // $dark-backgroundColor="$trueGray700"
69
- // $light-backgroundColor="$trueGray50"
70
- className="flex-1 bg-gray-200 dark:border-gray-500 dark:bg-gray-500 "
71
- >
72
- <ThreadsView
73
- data={threadsData}
74
- loading={threadLoading}
75
- refetch={threadsRefetch}
76
- subscribeToMore={threadsSubscribeToMore}
77
- error={threadsError}
78
- channelId={channelId}
79
- role={role}
80
- channelsDetail={channelsDetail}
81
- refetchChannelDetail={refetchChannelDetail}
82
- />
83
- </Box>
84
- </>
85
- )}
86
- </>
87
- );
88
-
89
- // return (
90
- // // <Box bg={'white'} flex={1} pt={5}>
91
- // <>
92
- // {channelLoading ? (
93
- // <Spinner />
94
- // ) : (
95
- // <>
96
- // {postParentId || postParentId == 0 ? (
97
- // <Box bg={'white'} flex={1}>
98
- // <ThreadConversationView
99
- // channelId={channelId}
100
- // postParentId={postParentId}
101
- // channelsDetail={channelsDetail}
102
- // refetchChannelDetail={refetchChannelDetail}
103
- // />
104
- // </Box>
105
- // ) : (
106
- // <Box
107
- // flex={1}
108
- // _dark={{
109
- // borderColor: 'coolGray.600',
110
- // backgroundColor: 'gray.700',
111
- // }}
112
- // _light={{
113
- // backgroundColor: 'gray.50',
114
- // }}
115
- // >
116
- // <ThreadsView
117
- // channelId={channelId}
118
- // channelsDetail={channelsDetail}
119
- // refetchChannelDetail={refetchChannelDetail}
120
- // />
121
- // </Box>
122
- // )}
123
- // </>
124
- // )}
125
- // </>
126
- // );
127
- }
128
-
129
- export default DialogThreads;
@@ -1,17 +0,0 @@
1
- import * as React from 'react';
2
- import { Box, Text } from '@admin-layout/gluestack-ui-mobile';
3
-
4
- import { Dialogs } from './containers/Dialogs';
5
- // import { SupportServiceDialogs } from './containers/SupportServiceDialogs';
6
-
7
- export const Inbox = (props: any) => {
8
- const { channelFilters, channelRole, supportServices } = props;
9
- return (
10
- <Box className="flex-1 bg-white">
11
- {/* {supportServices && (
12
- <SupportServiceDialogs channelFilters={channelFilters} channelRole={channelRole} {...props} />
13
- )} */}
14
- <Dialogs channelFilters={channelFilters} channelRole={channelRole} {...props} />
15
- </Box>
16
- );
17
- };
@@ -1,6 +0,0 @@
1
- import * as FileSystem from 'expo-file-system';
2
-
3
- // Make sure cache directory path ends with a slash
4
- export const IMAGE_CACHE_FOLDER = `${FileSystem.cacheDirectory}/image-cache/`;
5
- // export const IMAGE_CACHE_FOLDER = `${FileSystem.documentDirectory}images/`
6
- export default IMAGE_CACHE_FOLDER;