2017-09-10 21:38:07 -06:00
|
|
|
import * as classNames from "classnames";
|
2017-08-29 23:21:36 -06:00
|
|
|
import { observer } from "mobx-react";
|
2017-06-30 01:08:51 -06:00
|
|
|
import * as React from "react";
|
2017-09-10 11:23:54 -06:00
|
|
|
import { Message, MessageProps, TransitionGroup } from "semantic-ui-react";
|
2017-09-06 23:54:22 -06:00
|
|
|
|
2018-08-07 21:21:26 +03:00
|
|
|
import { AppState, injectState, UiMessage, UiStore } from "@client/state/";
|
2017-08-29 23:21:36 -06:00
|
|
|
|
2018-08-07 21:21:26 +03:00
|
|
|
import "@client/styles/MessagesView";
|
2018-07-25 15:55:35 -06:00
|
|
|
|
2017-09-10 12:30:23 -06:00
|
|
|
@observer
|
2017-08-29 23:21:36 -06:00
|
|
|
class MessageView extends React.Component<{
|
2018-09-02 02:57:55 -06:00
|
|
|
uiStore: UiStore;
|
|
|
|
message: UiMessage;
|
|
|
|
className?: string;
|
2017-08-29 23:21:36 -06:00
|
|
|
}> {
|
2018-09-02 02:57:55 -06:00
|
|
|
render() {
|
|
|
|
const { id, ...messageProps } = this.props.message;
|
|
|
|
const className = classNames(messageProps.className, this.props.className);
|
|
|
|
return (
|
|
|
|
<Message
|
|
|
|
{...messageProps}
|
|
|
|
className={className}
|
|
|
|
onDismiss={this.dismiss}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
2017-06-20 08:45:25 -06:00
|
|
|
|
2018-09-02 02:57:55 -06:00
|
|
|
private dismiss: MessageProps["onDismiss"] = (event, data) => {
|
|
|
|
const { uiStore, message } = this.props;
|
|
|
|
if (message.onDismiss) {
|
|
|
|
message.onDismiss(event, data);
|
2017-06-20 08:45:25 -06:00
|
|
|
}
|
2019-07-20 18:06:07 -06:00
|
|
|
uiStore.removeMessage(message);
|
2018-09-02 02:57:55 -06:00
|
|
|
};
|
2017-08-29 23:21:36 -06:00
|
|
|
}
|
2017-06-20 08:45:25 -06:00
|
|
|
|
2018-07-02 15:22:59 -06:00
|
|
|
class MessagesView extends React.Component<{ appState: AppState }> {
|
2018-09-02 02:57:55 -06:00
|
|
|
render() {
|
|
|
|
const { uiStore } = this.props.appState;
|
|
|
|
const messages = uiStore.messages.map(message => (
|
|
|
|
<MessageView key={message.id} uiStore={uiStore} message={message} />
|
|
|
|
));
|
|
|
|
messages.reverse();
|
|
|
|
return (
|
|
|
|
<TransitionGroup
|
|
|
|
as={Message.List}
|
|
|
|
className="messages"
|
|
|
|
animation="scale"
|
|
|
|
duration={200}
|
|
|
|
>
|
|
|
|
{messages}
|
|
|
|
</TransitionGroup>
|
|
|
|
);
|
|
|
|
}
|
2017-06-30 00:52:20 -06:00
|
|
|
}
|
2017-09-10 12:30:23 -06:00
|
|
|
|
|
|
|
export default injectState(observer(MessagesView));
|