From 9fc159e7b32fc3f25cf868d9351d4368e9fee651 Mon Sep 17 00:00:00 2001 From: Liam Cho Date: Tue, 17 Dec 2024 12:59:01 +0900 Subject: [PATCH 1/4] feat: Added messageStackDirection in Constant --- src/components/chat/ui/ChatMessageList.tsx | 11 +++++++++-- src/const.ts | 5 +++++ 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/src/components/chat/ui/ChatMessageList.tsx b/src/components/chat/ui/ChatMessageList.tsx index fd05608e3..1ef6855c7 100644 --- a/src/components/chat/ui/ChatMessageList.tsx +++ b/src/components/chat/ui/ChatMessageList.tsx @@ -20,7 +20,14 @@ import { useTypingTargetMessageId } from '../hooks/useTypingTargetMessageId'; export const ChatMessageList = () => { const { channel, dataSource, scrollSource, handlers } = useChatContext(); - const { botStudioEditProps, customUserAgentParam, stringSet, dateLocale, enableMessageGrouping } = useConstantState(); + const { + botStudioEditProps, + customUserAgentParam, + stringSet, + dateLocale, + enableMessageGrouping, + messageStackDirection = 'bottom', + } = useConstantState(); const typingTargetMessageId = useTypingTargetMessageId(); const { filteredMessages, shouldShowOriginalDate, renderBotStudioWelcomeMessages } = useBotStudioView(); @@ -42,7 +49,7 @@ export const ChatMessageList = () => { scrollPositionRef={scrollSource.scrollPositionRef} scrollDistanceFromBottomRef={scrollSource.scrollDistanceFromBottomRef} onScrollPosition={(it) => scrollSource.setIsScrollBottomReached(it === 'bottom')} - stackDirection={'bottom'} + stackDirection={messageStackDirection} messages={filteredMessages} onLoadPrev={dataSource.loadPrevious} onLoadNext={dataSource.loadNext} diff --git a/src/const.ts b/src/const.ts index 57bce938e..696b7e93c 100644 --- a/src/const.ts +++ b/src/const.ts @@ -187,6 +187,11 @@ export interface Constant extends ConstantFeatureFlags, ConstantAIFeatures, Cons * @description Message input state controlling properties. */ messageInputControls?: MessageInputControls; + /** + * @public + * @description + * */ + messageStackDirection?: 'top' | 'bottom'; /** * @private * @description Whether to show the beta mark. From f507a6a7dccee9cd54328a1d714da9584ac03c1b Mon Sep 17 00:00:00 2001 From: Liam Cho Date: Tue, 17 Dec 2024 14:12:19 +0900 Subject: [PATCH 2/4] minor --- README.md | 31 ++++++++++++++++--------------- src/const.ts | 1 - 2 files changed, 16 insertions(+), 16 deletions(-) diff --git a/README.md b/README.md index e9b323db0..945ffcf05 100644 --- a/README.md +++ b/README.md @@ -108,25 +108,26 @@ export default App; ``` ### Available props -| Prop Name | Type | Required | Default Value | Description | -|-------------------------|-----------------------------------------|----------|---------------|----------------------------------------------------------------------------------------------------------------| -| `applicationId` | `string` | Yes | N/A | Your Sendbird application ID | -| `botId` | `string` | Yes | N/A | Your Sendbird bot ID | | -| `userNickName` | `string` | No | N/A | The nickname of the user | | -| `enableEmojiFeedback` | `boolean` | No | `true` | Enables emoji feedback functionality. | -| `enableMention` | `boolean` | No | `true` | Enables mention functionality. | -| `deviceType` | `'desktop' \| 'mobile'` | No | N/A | Device type to be used in the widget | -| `stringSet` | `{ [key: string]: string }` | No | N/A | Customizable string set. Available string sets can be found [here](https://github.com/sendbird/sendbird-uikit-react/blob/main/src/ui/Label/stringSet.ts). | +| Prop Name | Type | Required | Default Value | Description | +|-------------------------|---------------------------------------|----------|---------------|----------------------------------------------------------------------------------------------------------------| +| `applicationId` | `string` | Yes | N/A | Your Sendbird application ID | +| `botId` | `string` | Yes | N/A | Your Sendbird bot ID | | +| `userNickName` | `string` | No | N/A | The nickname of the user | | +| `enableEmojiFeedback` | `boolean` | No | `true` | Enables emoji feedback functionality. | +| `enableMention` | `boolean` | No | `true` | Enables mention functionality. | +| `deviceType` | `'desktop' \| 'mobile'` | No | N/A | Device type to be used in the widget | +| `stringSet` | `{ [key: string]: string }` | No | N/A | Customizable string set. Available string sets can be found [here](https://github.com/sendbird/sendbird-uikit-react/blob/main/src/ui/Label/stringSet.ts). | | `customRefreshComponent` | `{ icon: string, style: React.CSSProperties, width: string, height: string, onClick: () => void }` | No | N/A | Customizable refresh component. You can set properties such as `icon`, `style`, `width`, `height`, and `onClick`. | -| `userId` | `string` | No | N/A | User ID to be used in the widget connect. Must be used with `sessionToken` and `configureSession`. The example usage can be found [here](./custom-session-guide.md). | -| `sessionToken` | `string` | No | N/A | Session token to be used in the widget connect. Must be used with `userId` and `configureSession`. The example usage can be found [here](./custom-session-guide.md). | -| `configureSession` | `() => SessionHandler` | No | N/A | Session configuration function. Must be used with `userId` and `sessionToken`. The example usage can be found [here](./custom-session-guide.md). | -| `autoOpen` | `boolean` | No | N/A | Determines whether the chatbot widget automatically opens when the browser window is opened. This property is being ignored in mobile view. | -| `enableResetHistoryOnConnect` | `boolean` | No | `false` | Determines whether the chatbot widget history is reset when the user connects. | +| `userId` | `string` | No | N/A | User ID to be used in the widget connect. Must be used with `sessionToken` and `configureSession`. The example usage can be found [here](./custom-session-guide.md). | +| `sessionToken` | `string` | No | N/A | Session token to be used in the widget connect. Must be used with `userId` and `configureSession`. The example usage can be found [here](./custom-session-guide.md). | +| `configureSession` | `() => SessionHandler` | No | N/A | Session configuration function. Must be used with `userId` and `sessionToken`. The example usage can be found [here](./custom-session-guide.md). | +| `autoOpen` | `boolean` | No | N/A | Determines whether the chatbot widget automatically opens when the browser window is opened. This property is being ignored in mobile view. | +| `enableResetHistoryOnConnect` | `boolean` | No | `false` | Determines whether the chatbot widget history is reset when the user connects. | | `messageInputControls.blockWhileBotResponding` | `boolean \| number` | No | N/A | Allows to control enabled/disabled state of the message input for waiting for the bot's reply mesage. If number value is given, a timer will be set to force unblock the message input. | | `dateLocale` | `Locale` | No | `enUS` | Locale value to be applied to string values of message timestamp and date separator. Locale values must be imported from `date-fns`. | -| `enableHideWidgetForDeactivatedUser` | `boolean` | No | `false` | Determines whether the chatbot widget is hidden when the user is deactivated. | +| `enableHideWidgetForDeactivatedUser` | `boolean` | No | `false` | Determines whether the chatbot widget is hidden when the user is deactivated. | | `enableWidgetExpandButton` | `boolean` | No | `false` | Determines whether the expand button is displayed in the chatbot widget. | +| `messageStackDirection` | `'top' \| 'bottom'` | No | N/A | Determines direction at which message stack starts in the message list. | ## For internal contributors - [Release guide](./release-guide.md) diff --git a/src/const.ts b/src/const.ts index 696b7e93c..34658a150 100644 --- a/src/const.ts +++ b/src/const.ts @@ -189,7 +189,6 @@ export interface Constant extends ConstantFeatureFlags, ConstantAIFeatures, Cons messageInputControls?: MessageInputControls; /** * @public - * @description * */ messageStackDirection?: 'top' | 'bottom'; /** From 677f07fe31f7472df20a41169d24f4e28f46af7f Mon Sep 17 00:00:00 2001 From: Liam Cho Date: Tue, 17 Dec 2024 14:18:39 +0900 Subject: [PATCH 3/4] minor --- README.md | 32 ++++++++++++++++---------------- 1 file changed, 16 insertions(+), 16 deletions(-) diff --git a/README.md b/README.md index 945ffcf05..fdf4ae591 100644 --- a/README.md +++ b/README.md @@ -109,25 +109,25 @@ export default App; ### Available props | Prop Name | Type | Required | Default Value | Description | -|-------------------------|---------------------------------------|----------|---------------|----------------------------------------------------------------------------------------------------------------| -| `applicationId` | `string` | Yes | N/A | Your Sendbird application ID | -| `botId` | `string` | Yes | N/A | Your Sendbird bot ID | | -| `userNickName` | `string` | No | N/A | The nickname of the user | | -| `enableEmojiFeedback` | `boolean` | No | `true` | Enables emoji feedback functionality. | -| `enableMention` | `boolean` | No | `true` | Enables mention functionality. | -| `deviceType` | `'desktop' \| 'mobile'` | No | N/A | Device type to be used in the widget | -| `stringSet` | `{ [key: string]: string }` | No | N/A | Customizable string set. Available string sets can be found [here](https://github.com/sendbird/sendbird-uikit-react/blob/main/src/ui/Label/stringSet.ts). | -| `customRefreshComponent` | `{ icon: string, style: React.CSSProperties, width: string, height: string, onClick: () => void }` | No | N/A | Customizable refresh component. You can set properties such as `icon`, `style`, `width`, `height`, and `onClick`. | -| `userId` | `string` | No | N/A | User ID to be used in the widget connect. Must be used with `sessionToken` and `configureSession`. The example usage can be found [here](./custom-session-guide.md). | -| `sessionToken` | `string` | No | N/A | Session token to be used in the widget connect. Must be used with `userId` and `configureSession`. The example usage can be found [here](./custom-session-guide.md). | -| `configureSession` | `() => SessionHandler` | No | N/A | Session configuration function. Must be used with `userId` and `sessionToken`. The example usage can be found [here](./custom-session-guide.md). | -| `autoOpen` | `boolean` | No | N/A | Determines whether the chatbot widget automatically opens when the browser window is opened. This property is being ignored in mobile view. | -| `enableResetHistoryOnConnect` | `boolean` | No | `false` | Determines whether the chatbot widget history is reset when the user connects. | +|-------------------------|---------------------------------------|----------|------------|----------------------------------------------------------------------------------------------------------------| +| `applicationId` | `string` | Yes | N/A | Your Sendbird application ID | +| `botId` | `string` | Yes | N/A | Your Sendbird bot ID | | +| `userNickName` | `string` | No | N/A | The nickname of the user | | +| `enableEmojiFeedback` | `boolean` | No | `true` | Enables emoji feedback functionality. | +| `enableMention` | `boolean` | No | `true` | Enables mention functionality. | +| `deviceType` | `'desktop' \| 'mobile'` | No | N/A | Device type to be used in the widget | +| `stringSet` | `{ [key: string]: string }` | No | N/A | Customizable string set. Available string sets can be found [here](https://github.com/sendbird/sendbird-uikit-react/blob/main/src/ui/Label/stringSet.ts). | +| `customRefreshComponent` | `{ icon: string, style: React.CSSProperties, width: string, height: string, onClick: () => void }` | No | N/A | Customizable refresh component. You can set properties such as `icon`, `style`, `width`, `height`, and `onClick`. | +| `userId` | `string` | No | N/A | User ID to be used in the widget connect. Must be used with `sessionToken` and `configureSession`. The example usage can be found [here](./custom-session-guide.md). | +| `sessionToken` | `string` | No | N/A | Session token to be used in the widget connect. Must be used with `userId` and `configureSession`. The example usage can be found [here](./custom-session-guide.md). | +| `configureSession` | `() => SessionHandler` | No | N/A | Session configuration function. Must be used with `userId` and `sessionToken`. The example usage can be found [here](./custom-session-guide.md). | +| `autoOpen` | `boolean` | No | N/A | Determines whether the chatbot widget automatically opens when the browser window is opened. This property is being ignored in mobile view. | +| `enableResetHistoryOnConnect` | `boolean` | No | `false` | Determines whether the chatbot widget history is reset when the user connects. | | `messageInputControls.blockWhileBotResponding` | `boolean \| number` | No | N/A | Allows to control enabled/disabled state of the message input for waiting for the bot's reply mesage. If number value is given, a timer will be set to force unblock the message input. | | `dateLocale` | `Locale` | No | `enUS` | Locale value to be applied to string values of message timestamp and date separator. Locale values must be imported from `date-fns`. | -| `enableHideWidgetForDeactivatedUser` | `boolean` | No | `false` | Determines whether the chatbot widget is hidden when the user is deactivated. | +| `enableHideWidgetForDeactivatedUser` | `boolean` | No | `false` | Determines whether the chatbot widget is hidden when the user is deactivated. | | `enableWidgetExpandButton` | `boolean` | No | `false` | Determines whether the expand button is displayed in the chatbot widget. | -| `messageStackDirection` | `'top' \| 'bottom'` | No | N/A | Determines direction at which message stack starts in the message list. | +| `messageStackDirection` | `'top' \| 'bottom'` | No | `bottom` | Determines direction at which message stack starts in the message list. | ## For internal contributors - [Release guide](./release-guide.md) From 411e0864bd7045c315e30e1eb32b948d576e74a4 Mon Sep 17 00:00:00 2001 From: Hyungu Kang | Airen Date: Tue, 17 Dec 2024 14:19:25 +0900 Subject: [PATCH 4/4] Update README.md --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index fdf4ae591..5a02403c8 100644 --- a/README.md +++ b/README.md @@ -127,7 +127,7 @@ export default App; | `dateLocale` | `Locale` | No | `enUS` | Locale value to be applied to string values of message timestamp and date separator. Locale values must be imported from `date-fns`. | | `enableHideWidgetForDeactivatedUser` | `boolean` | No | `false` | Determines whether the chatbot widget is hidden when the user is deactivated. | | `enableWidgetExpandButton` | `boolean` | No | `false` | Determines whether the expand button is displayed in the chatbot widget. | -| `messageStackDirection` | `'top' \| 'bottom'` | No | `bottom` | Determines direction at which message stack starts in the message list. | +| `messageStackDirection` | `'top' \| 'bottom'` | No | `'bottom'` | Determines direction at which message stack starts in the message list. | ## For internal contributors - [Release guide](./release-guide.md)