botserver/packages/default.gbui/src/players/GBBulletPlayer.js

96 lines
3.8 KiB
JavaScript
Raw Normal View History

2018-04-21 02:59:30 -03:00
/*****************************************************************************\
2024-01-09 17:40:48 -03:00
| ® |
| |
| |
| |
| |
2018-04-21 02:59:30 -03:00
| |
2024-04-20 17:24:00 -03:00
| General Bots Copyright (c) pragmatismo.cloud. All rights reserved. |
2018-04-21 02:59:30 -03:00
| Licensed under the AGPL-3.0. |
| |
2018-04-21 02:59:30 -03:00
| According to our dual licensing model, this program can be used either |
| under the terms of the GNU Affero General Public License, version 3, |
| or under a proprietary license. |
| |
| The texts of the GNU Affero General Public License with an additional |
| permission and of our proprietary license can be found at and |
| in the LICENSE file you have received along with this program. |
| |
| This program is distributed in the hope that it will be useful, |
| but WITHOUT ANY WARRANTY; without even the implied warranty of |
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| GNU Affero General Public License for more details. |
| |
2024-04-20 17:24:00 -03:00
| "General Bots" is a registered trademark of pragmatismo.cloud. |
2018-04-21 02:59:30 -03:00
| The licensing of the program under the AGPLv3 does not imply a |
| trademark license. Therefore any rights, title and interest in |
| our trademarks remain entirely with us. |
| |
\*****************************************************************************/
import React, { Component } from "react";
class RenderItem extends Component {
send(item) {
setTimeout(()=>{
window.botConnection
.postActivity({
type: "event",
name: "answerEvent",
data: item.questionId,
2018-04-21 02:59:30 -03:00
locale: "en-us",
textFormat: "plain",
timestamp: new Date().toISOString(),
from: window.user
2018-04-21 02:59:30 -03:00
})
},400);
}
render() {
return (
<ul>
{this.props.list.map((item) => (
2018-04-21 02:59:30 -03:00
<li key={item.questionId}>
<label className="gb-bullet-player-item" onClick={this.send.bind(this, item)}>{item.content}</label>
</li>
))}
</ul>
);
}
}
class GBBulletPlayer extends Component {
constructor() {
super();
this.state = {
list: []
};
}
play(data) {
this.setState({ list: data });
}
stop() {
this.setState({ list: [] });
}
render() {
return (
<div
className="gb-bullet-player"
ref={i => (this.playerText = i)}
>
<RenderItem
app={this.props.app}
list={this.state.list}
ref={i => (this.playerList = i)}
/>
</div>
);
}
}
export default GBBulletPlayer;