sprinklers3/client/components/MessagesView.tsx

58 lines
1.5 KiB
TypeScript
Raw Normal View History

import * as classNames from "classnames";
2017-08-29 23:21:36 -06:00
import { observer } from "mobx-react";
import * as React from "react";
2017-09-10 11:23:54 -06:00
import { Message, MessageProps, TransitionGroup } from "semantic-ui-react";
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";
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}
/>
);
}
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);
}
2018-09-02 02:57:55 -06:00
uiStore.messages.remove(message);
};
2017-08-29 23:21:36 -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));