This project is now part of the Rocket.Chat monorepo. Please open any new issues and pull requests there.
This branch contains a button component @ /src/components/Messages/MessageAction
.
For example you can send a following rich message payload to use with this component:
const msgObject = {
_id: Random.id(),
rid: item.rid,
msg: 'Sorry I am not sure of your request. Please select one of the following options:',
attachments: [{
actions: [
{
type: 'button',
msg_in_chat_window: true,
msg_processing_type: 'sendMessage',
text: 'Contact Salesforce Agent',
msg: 'getSessionId',
},
{
type: 'button',
msg_in_chat_window: true,
msg_processing_type: 'sendMessage',
text: 'Send Random String',
msg: 'randomWord',
},
{
type: 'button',
msg_in_chat_window: true,
msg_processing_type: 'sendMessage',
text: 'Close Chat',
msg: 'closeChat',
},
],
}],
};
Currently, it's very common to find chat pop-ups when you're browsing websites.
Those widgets, at Rocket.Chat, are called LiveChat.
LiveChat is a small and lightweight application designed to provide B2C (Business-to-customer) communication between Agents and website visitors and is developed with Preact.
With your Rocket.chat running locally at http://localhost:3000
- Install all node dependencies.
yarn
- Build preact application to
/build
folder
yarn dev
- In another terminal, run webpack with hot reload at http://localhost:8080
yarn start
- Open this file below in your browser
widget-demo.html
OBS: For a better performance, you can run this widget-demo.html
on a http server.
To select a different host on your local widget, check this configuration at /src/api.js
file.
const host = window.SERVER_URL
|| queryString.parse(window.location.search).serverUrl
|| (process.env.NODE_ENV === 'development' ? 'http://localhost:3000' : null);
Here, you can change to your new configuration.
const host = window.SERVER_URL
|| queryString.parse(window.location.search).serverUrl
|| (process.env.NODE_ENV === 'development' ? 'https://your.rocketserver.com' : null);
# install dependencies
yarn
# serve with hot reload at localhost:8080
yarn start
# build preact application to "build" folder
yarn dev
# build for production with minification
yarn build
# test the production build locally
yarn serve
# run tests with jest and preact-render-spy
yarn test
# run the storybook
yarn storybook
## Screens:
![image](https://user-images.githubusercontent.com/5263975/44279585-497b2980-a228-11e8-81a2-36bc3389549e.png)
![image](https://user-images.githubusercontent.com/5263975/44279599-5730af00-a228-11e8-8873-553ef53ee25a.png)
![image](https://user-images.githubusercontent.com/5263975/44279626-6f083300-a228-11e8-8886-c430b28a8e75.png)
![image](https://user-images.githubusercontent.com/5263975/44279634-74657d80-a228-11e8-9583-bf8079972696.png)
![image](https://user-images.githubusercontent.com/5263975/44279639-7b8c8b80-a228-11e8-9815-1a0e3540c4f5.png)
![image](https://user-images.githubusercontent.com/5263975/44279643-847d5d00-a228-11e8-804e-27b973dee8b2.png)
![image](https://user-images.githubusercontent.com/5263975/44279655-90691f00-a228-11e8-8511-4a328a77e5bb.png)