sprinklers3/app/components/MessagesView.tsx

50 lines
1.4 KiB
TypeScript
Raw Normal View History

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";
2017-09-10 12:30:23 -06:00
import { injectState, State, UiMessage, UiStore } from "@app/state/";
2017-08-29 23:21:36 -06:00
2017-09-10 12:30:23 -06:00
@observer
2017-08-29 23:21:36 -06:00
class MessageView extends React.Component<{
uiStore: UiStore,
message: UiMessage,
index: number,
}> {
render() {
2017-09-10 11:23:54 -06:00
const { id, ...messageProps } = this.props.message;
2017-08-29 23:21:36 -06:00
return (
<Message
2017-09-10 11:23:54 -06:00
{...messageProps}
2017-08-29 23:21:36 -06:00
onDismiss={this.dismiss}
/>
);
}
2017-09-10 12:30:23 -06:00
private dismiss: MessageProps["onDismiss"] = (event, data) => {
2017-08-29 23:21:36 -06:00
const { uiStore, index } = this.props;
uiStore.messages.splice(index, 1);
2017-09-10 11:23:54 -06:00
if (this.props.message.onDismiss) {
this.props.message.onDismiss(event, data);
}
}
2017-08-29 23:21:36 -06:00
}
2017-09-10 12:30:23 -06:00
class MessagesView extends React.Component<{ state: State }> {
2017-08-29 23:21:36 -06:00
render() {
2017-09-10 12:30:23 -06:00
const { uiStore } = this.props.state;
const messages = uiStore.messages.map((message, index) => (
<MessageView key={message.id} uiStore={uiStore} message={message} index={index} />
2017-08-29 23:21:36 -06:00
));
return (
<div className="messages" >
2017-09-10 12:30:23 -06:00
<TransitionGroup animation="scale" duration={200}>
{messages}
</TransitionGroup>
2017-08-29 23:21:36 -06:00
</div>
);
}
2017-06-30 00:52:20 -06:00
}
2017-09-10 12:30:23 -06:00
export default injectState(observer(MessagesView));