Skip to content

Commit

Permalink
Merge pull request #89 from SAPConversationalAI/mergeToOpenSource
Browse files Browse the repository at this point in the history
Merge to open source
  • Loading branch information
JWandrocke authored May 9, 2022
2 parents 0638f93 + b61da88 commit 8a943f9
Show file tree
Hide file tree
Showing 5 changed files with 79 additions and 5 deletions.
2 changes: 1 addition & 1 deletion package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "webchat",
"version": "1.4.46",
"version": "1.4.47",
"description": "",
"main": "lib/index.js",
"scripts": {
Expand Down
4 changes: 3 additions & 1 deletion src/components/Live/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@ import pathOr from 'ramda/es/pathOr'
import Message from 'components/Message'
import IsTyping from 'components/Message/isTyping'

import { isLastMessageForIndex } from 'helpers'

import './style.scss'

class Live extends Component {
Expand Down Expand Up @@ -119,7 +121,7 @@ class Live extends Component {
sendMessage={sendMessage}
preferences={preferences}
onImageLoaded={this.onImageLoaded}
isLastMessage={messages.length === index + 1}
isLastMessage={isLastMessageForIndex(messages, index)}
retry={message.retry}
isSending={message.isSending}
onRetrySendMessage={() => onRetrySendMessage(message)}
Expand Down
34 changes: 32 additions & 2 deletions src/helpers.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@

import { pathOr } from 'ramda'

export const truncate = (string, length) => {
// console.assert(typeof string === 'string', `Expected a 'string', but got a type:'${typeof string}' - '${string}'`)
if (typeof string === 'string') {
Expand Down Expand Up @@ -83,12 +85,40 @@ export const safeStringValue = (content) => {
export const validButtonContent = (element) => {
if (element) {
const { type, value, title } = element
const data = {
return {
type,
value,
title,
}
return data
}
return element
}

/**
* Determine if this is the last message, ignore client_data types at the end
* Only for Quick Replies
*
* @param {*} messages - Array of messages
* @param {*} index - 0 based index to test
* @returns
*/
export const isLastMessageForIndex = (messages, index) => {
if (messages && Array.isArray(messages) && index >= 0 && index < messages.length) {
let offset = 1
const messageType = pathOr('', ['attachment', 'type'], messages[index])
if (typeof messageType === 'string' && messageType.toLowerCase() === 'quickreplies') {
// Loop back to the index to adjust offset for client_data type
for (let i = messages.length - 1; i > index; --i) {
const type = pathOr('', ['attachment', 'type'], messages[i])
if (typeof type === 'string' && type.toLowerCase() === 'client_data') {
offset++
} else {
break
}
}
}
// Should return true if this is a type client_data and is the last message?
return messages.length === index + offset
}
return false // No messsage or index out of range
}
42 changes: 42 additions & 0 deletions src/test/helpers.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import {
validButtonContent,
getCredentialsFromLocalStorage,
storeCredentialsToLocalStorage,
isLastMessageForIndex,
} from 'helpers'

describe('Test the helper utilities', () => {
Expand Down Expand Up @@ -50,5 +51,46 @@ describe('Test the helper utilities', () => {
storeCredentialsToLocalStorage('chatId', 'conversation-Id', 1, 'channelId')
assert.propertyVal(getCredentialsFromLocalStorage('channelId', 1), 'conversationId', 'conversation-Id')
})

it('Test isLastMessageForIndex', () => {
assert.isFalse(isLastMessageForIndex(), 'No params')
assert.isFalse(isLastMessageForIndex([], 0), 'Empty params')
assert.isTrue(isLastMessageForIndex([{ attachment: { type: 'foo' } }], 0), 'Is first and last message')
assert.isTrue(isLastMessageForIndex([
{ attachment: { type: 'quickreplies' } },
{ attachment: { type: 'client_data' } }], 0), 'Has client data after the first (quickreplies) message')
assert.isFalse(isLastMessageForIndex([
{ attachment: { type: 'text' } },
{ attachment: { type: 'client_data' } }], 0), 'Has client data after the first (text) message')
assert.isTrue(isLastMessageForIndex([
{ attachment: { type: 'quickreplies' } },
{ attachment: { type: 'client_data' } },
{ attachment: { type: 'client_data' } }], 0), 'Has two client data after the first message')
assert.isTrue(isLastMessageForIndex([{ attachment: { type: 'client_data' } }], 0), 'Only client data')
assert.isFalse(isLastMessageForIndex([
{ attachment: { type: 'quickreplies' } },
{ attachment: { type: 'client_data' } },
{ attachment: { type: 'buttons' } },
{ attachment: { type: 'client_data' } }], 0))
assert.isFalse(isLastMessageForIndex([
{ attachment: { type: 'quickreplies' } },
{ attachment: { type: 'client_data' } },
{ attachment: { type: 'buttons' } },
{ attachment: { type: 'client_data' } }], 1))
assert.isTrue(isLastMessageForIndex([
{ attachment: { type: 'button' } },
{ attachment: { type: 'client_data' } },
{ attachment: { type: 'quickreplies' } },
{ attachment: { type: 'client_data' } }], 2))
assert.isFalse(isLastMessageForIndex([
{ attachment: { type: 'quickreplies' } },
{ attachment: { type: 'buttons' } }], 2), 'Test out of range')
assert.isTrue(isLastMessageForIndex([
{ attachment: { type: 'quickreplies' } },
{ attachment: { type: 'buttons' } }], 1), 'Test is Last one')
assert.isFalse(isLastMessageForIndex([
{ attachment: { type: 'quickreplies' } },
{ attachment: { type: 'buttons' } }], 0), 'Is First message')
})
})

0 comments on commit 8a943f9

Please sign in to comment.