diff --git a/README.md b/README.md
index b8f9aa7fc..fb99e2b91 100644
--- a/README.md
+++ b/README.md
@@ -1,4 +1,5 @@
-# React Chat Widget
+# Krosai Widget
+
[![circle-ci](https://img.shields.io/circleci/project/github/Wolox/react-chat-widget.svg)](https://circleci.com/gh/Wolox/react-chat-widget)
[![npm](https://img.shields.io/npm/v/react-chat-widget.svg)](https://www.npmjs.com/package/react-chat-widget)
@@ -6,9 +7,8 @@
## Features
-- Plain text message UI
-- Snippet style for links (only as responses for now)
-- Fully customizable
+- Assistant Call Feature
+- Assistant Chat Feature
- Easy to use
![demonstration](./assets/chat-demonstration.gif)
@@ -16,13 +16,15 @@
## Installation
#### npm
+
```bash
-npm install --save react-chat-widget
+npm install --save krosai-widget
```
#### yarn
+
```bash
-yarn add react-chat-widget
+yarn add krosai-widget
```
## Usage
@@ -30,10 +32,8 @@ yarn add react-chat-widget
1- Add the Widget component to your root component
```js
-import React from 'react';
-import { Widget } from 'react-chat-widget';
-
-import 'react-chat-widget/lib/styles.css';
+import React from "react";
+import { Widget } from "krosai-widget";
function App() {
return (
@@ -46,56 +46,18 @@ function App() {
export default App;
```
-2- The only required prop you need to use is the `handleNewUserMessage`, which will receive the input from the user.
-
-```js
-import React from 'react';
-import { Widget } from 'react-chat-widget';
-
-import 'react-chat-widget/lib/styles.css';
-
-function App() {
- const handleNewUserMessage = (newMessage) => {
- console.log(`New message incoming! ${newMessage}`);
- // Now send the message throught the backend API
- };
-
- return (
-
-
-
- );
-}
-
-export default App;
-```
-
-3- Import the methods for you to add messages in the Widget. (See [messages](#messages))
+2- The only required prop you need to use is the `widget_id`, which will receive the widget details from the custom widget on the console.
```js
-import React from 'react';
-import { Widget, addResponseMessage } from 'react-chat-widget';
-
-import 'react-chat-widget/lib/styles.css';
+import React from "react";
+import { Widget } from "krosai-widget";
function App() {
- useEffect(() => {
- addResponseMessage('Welcome to this awesome chat!');
- }, []);
-
- const handleNewUserMessage = (newMessage) => {
- console.log(`New message incoming! ${newMessage}`);
- // Now send the message throught the backend API
- addResponseMessage(response);
};
return (
-
+
);
}
@@ -103,162 +65,13 @@ function App() {
export default App;
```
-4- Customize the widget to match your app design! You can add both props to manage the title of the widget and the avatar it will use. Of course, feel free to change the styles the widget will have in the CSS
-
-```js
-import React, { useEffect } from 'react';
-import { Widget, addResponseMessage } from 'react-chat-widget';
-
-import 'react-chat-widget/lib/styles.css';
-
-import logo from './logo.svg';
-
-function App() {
- useEffect(() => {
- addResponseMessage('Welcome to this **awesome** chat!');
- }, []);
-
- const handleNewUserMessage = (newMessage) => {
- console.log(`New message incoming! ${newMessage}`);
- // Now send the message throught the backend API
- };
-
- return (
-
-
-
- );
-}
-
-export default App;
-
-```
-
## API
#### Props
-|prop|type|required|default value|description|
-|---|--- |--- |--- |--- |
-|**handleNewUserMessage**|(...args: any[]) => any|YES| |Function to handle the user input, will receive the full text message when submitted|
-|**title**|string|NO|'Welcome'|Title of the widget|
-|**subtitle**|string|NO|'This is your chat subtitle'|Subtitle of the widget|
-|**senderPlaceHolder**|string|NO|'Type a message...'|The placeholder of the message input|
-|**profileAvatar**|string|NO| |The profile image that will be set on the responses|
-|**profileClientAvatar**|string|NO| |The profile image that will be set on the client messages|
-|**titleAvatar**|string|NO| |The picture image that will be shown next to the chat title|
-|**showCloseButton**|boolean|NO|false|Show or hide the close button in full screen mode|
-|**fullScreenMode**|boolean|NO|false|Allow the use of full screen in full desktop mode|
-|**autofocus**|boolean|NO|true|Autofocus or not the user input|
-|**launcher**|(handleToggle) => ElementType|NO||Custom Launcher component to use instead of the default|
-|**handleQuickButtonClicked**|(...args: any[]) => any|NO||Function to handle the user clicking a quick button, will receive the 'value' when clicked.|
-|**showTimeStamp**|boolean|NO|true|Show time stamp on messages|
-|**chatId**|string|NO|'rcw-chat-container'|Chat container id for a11y|
-|**handleToggle**|(...args: any[]) => any|NO|'rcw-chat-container'|Function to handle when the widget is toggled, will receive the toggle status|
-|**launcherOpenLabel**|string|NO|'Open chat'|Alt value for the laucher when closed|
-|**launcherCloseLabel**|string|NO|'Close chat'|Alt value for the laucher when open|
-|**launcherOpenImg**|string|NO|''|local or remote image url, if not provided it will show default image|
-|**launcherCloseImg**|string|NO|''|local or remote image url, if not provided it will show default image|
-|**sendButtonAlt**|string|NO|'Send'|Send button alt for a11y purposes|
-|**handleTextInputChange**|(event) => any|NO| |Prop that triggers on input change|
-|**handleSubmit**|(event) => any|NO| |Prop that triggers when a message is submitted, used for custom validation|
-|**resizable**|boolean|NO|false|Prop that allows to resize the widget by dragging it's left border|
-|**emojis**|boolean|NO|false|enable emoji picker|
-|**showBadge**|boolean|NO|true|Prop that allows to show or hide the unread message badge|
-
-#### Styles
-
-To change the styles you need the widget to have, simply override the CSS classes wrapping them within the containers and add your own style to them! All classes are prefixed with `rcw-` so they don't override your other classes in case you are not hasing them.
-To override, you can do, for expample:
-
-```css
-.rcw-conversation-container > .rcw-header {
- background-color: red;
-}
-
-.rcw-message > .rcw-response {
- background-color: black;
- color: white;
-}
-```
-
-That way, you can leave the JS clean and keep the styles within the CSS.
-
-#### Messages
-
-As of v3.0, messages now have an optional ID that can be added on creation.If you want to add new messages, you can use the following methods:
-
-- **addResponseMessage**
- - params:
- - text: string (supports markdown)
- - id: string (optional)
- - Method to add a new message written as a response to a user input.
-
-- **addUserMessage**
- - params:
- - text: string (supports markdown)
- - id: string (optional)
- - This method will add a new message written as a user. Keep in mind it will not trigger the prop handleNewUserMessage()
-
-- **addLinkSnippet**
- - params:
- - link
- - Method to add a link snippet. You need to provide this method with a link object, which must be in the shape of:
- ```js
- {
- title: 'My awesome link',
- link: 'https://github.com/Wolox/react-chat-widget',
- target: '_blank'
- }
- ```
- - By default, `target` value is `_blank` which will open the link in a new window.
-
-- **renderCustomComponent**
- - params:
- - component: Component to be render,
- - props: props the component needs,
- - showAvatar: boolean, default value: false; the component will be rendered with the avatar like the messages
- - Method to render a custom component inside the messages container. With this method, you can add whatever component you need the widget to have.
-
-- **setQuickButtons**
- - params:
- - buttons: An array of objects with the keys `label` and `value`
-
-**Markdown is supported for both the responses and user messages.**
-
-#### Widget behavior
-
-You can also control certain actions of the widget:
-
-- **toggleWidget**
- - params: No params expected
- - This method is to toggle the widget at will without the need to trigger the click event on the launcher
-
-- **toggleInputDisabled**
- - params: No params expected
- - Method to toggle the availability of the message input for the user to write on
-
-- **toggleMsgLoader**
- - Toggles the message loader that shows as a "typing..." style.
-
-- **deleteMessages***
- - params:
- - count: messages to delete counting from last to first
- - id: message id to delete
- - Delete messages that either have an id you previously set with the `addResponseMessage` or delete based on position or both of them. For example `deleteMessages(2, 'myId')` will delete the message that has the id `myId` and the previous message.
-
-- **markAllAsRead**
- - Marks all response messages as read. The user messages doesn't have the read/unread property.
-
-- **setBadgeCount**
- - params:
- - count: number
- - As of v3.0, the `badge` prop is being changed to be managed from within the Widget. This method is manually set the badge number.
+| prop | type | required | default value | description |
+| ------------- | ------ | -------- | ------------- | -------------------- |
+| **widget_id** | string | => | YES | 'Kros00000000000000' | This is the prop you pass, will receive the full details of the widget when submitted |
#### Widget components
@@ -266,29 +79,13 @@ You can also control certain actions of the widget:
You can use a custom component for the Launcher if you need one that's not the default, simply use the **launcher** prop:
-```js
-import React from 'react';
-import { Widget } from 'react-chat-widget';
-
-...
-
-function MyApp() {
- const getCustomLauncher = (handleToggle) =>
-
-
- return (
- getCustomLauncher(handleToggle)}
- />
- )
-}
```
-`getCustomLauncher()` is a method that will return the `Launcher` component as seen in the example. By default, the function passed by that prop, will receive the `handleToggle` parameter which is the method that will toggle the widget.
+`Kros00000000000000` is your widget ID that will be used to get the components of your widget as seen in the example. By default, the ID passed by that prop, will receive the details of the custom widget parameter.
## About
This project is maintained by [Martín Callegari](https://github.com/mcallegari10) and it was written by [Wolox](http://www.wolox.com.ar).
![Wolox](https://raw.githubusercontent.com/Wolox/press-kit/master/logos/logo_banner.png)
+```
diff --git a/assets/LogoIcon.png b/assets/LogoIcon.png
new file mode 100644
index 000000000..3c9022a34
Binary files /dev/null and b/assets/LogoIcon.png differ
diff --git a/assets/telegram.svg b/assets/telegram.svg
new file mode 100644
index 000000000..d1b372488
--- /dev/null
+++ b/assets/telegram.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/assets/widget-logo.png b/assets/widget-logo.png
new file mode 100644
index 000000000..929de701f
Binary files /dev/null and b/assets/widget-logo.png differ
diff --git a/custom.d.ts b/custom.d.ts
index 1a3dd3c2a..69ba292db 100644
--- a/custom.d.ts
+++ b/custom.d.ts
@@ -2,3 +2,13 @@ declare module "*.svg" {
const content: any;
export default content;
}
+
+declare module "*.png" {
+ const content: any;
+ export default content;
+}
+
+declare module "*.jpg" {
+ const content: any;
+ export default content;
+}
diff --git a/dev/App.tsx b/dev/App.tsx
index db8d88df3..6d055cfe7 100644
--- a/dev/App.tsx
+++ b/dev/App.tsx
@@ -1,53 +1,68 @@
-import { Component } from 'react';
+import { Component } from "react";
-import { Widget, addResponseMessage, setQuickButtons, toggleMsgLoader, addLinkSnippet } from '../index';
-import { addUserMessage } from '..';
+import {
+ Widget,
+ addResponseMessage,
+ setQuickButtons,
+ toggleMsgLoader,
+ addLinkSnippet,
+} from "../index";
+import { addUserMessage } from "..";
+import React from "react";
export default class App extends Component {
componentDidMount() {
- addResponseMessage('Welcome to this awesome chat!');
- addLinkSnippet({ link: 'https://google.com', title: 'Google' });
- addResponseMessage('![](https://raw.githubusercontent.com/Wolox/press-kit/master/logos/logo_banner.png)');
- addResponseMessage('![vertical](https://d2sofvawe08yqg.cloudfront.net/reintroducing-react/hero2x?1556470143)');
+ addResponseMessage("Welcome to krosai, how can i help you!");
+ // addLinkSnippet({ link: 'https://google.com', title: 'Google' });
+ // addResponseMessage('![](https://raw.githubusercontent.com/Wolox/press-kit/master/logos/logo_banner.png)');
+ // addResponseMessage('![vertical](https://d2sofvawe08yqg.cloudfront.net/reintroducing-react/hero2x?1556470143)');
}
handleNewUserMessage = (newMessage: any) => {
toggleMsgLoader();
setTimeout(() => {
toggleMsgLoader();
- if (newMessage === 'fruits') {
- setQuickButtons([ { label: 'Apple', value: 'apple' }, { label: 'Orange', value: 'orange' }, { label: 'Pear', value: 'pear' }, { label: 'Banana', value: 'banana' } ]);
+ if (newMessage === "fruits") {
+ setQuickButtons([
+ { label: "Apple", value: "apple" },
+ { label: "Orange", value: "orange" },
+ { label: "Pear", value: "pear" },
+ { label: "Banana", value: "banana" },
+ ]);
} else {
addResponseMessage(newMessage);
}
}, 2000);
- }
+ };
handleQuickButtonClicked = (e: any) => {
- addResponseMessage('Selected ' + e);
+ addResponseMessage("Selected " + e);
setQuickButtons([]);
- }
+ };
handleSubmit = (msgText: string) => {
- if(msgText.length < 80) {
+ if (msgText.length < 80) {
addUserMessage("Uh oh, please write a bit more.");
return false;
}
return true;
- }
+ };
render() {
return (
-
+ <>
+ {/* @ts-expect-error Server Component */}
+
+ >
);
}
}
diff --git a/dev/index.html b/dev/index.html
index 580ad4157..84e7b516b 100644
--- a/dev/index.html
+++ b/dev/index.html
@@ -2,11 +2,17 @@
+
+
+
- Dev Widget
+ KrosAI Widget