2019-06-23 00:45:51 +01:00
|
|
|
import React from 'react';
|
2019-06-12 07:12:03 +01:00
|
|
|
import MessageBox from '@/components/MessageBox';
|
2019-06-23 00:45:51 +01:00
|
|
|
import { State, useStoreState } from 'easy-peasy';
|
2019-07-10 05:25:57 +01:00
|
|
|
import { ApplicationStore } from '@/state';
|
2019-06-12 07:12:03 +01:00
|
|
|
|
|
|
|
type Props = Readonly<{
|
2019-06-23 07:45:09 +01:00
|
|
|
byKey?: string;
|
2019-06-17 00:57:57 +01:00
|
|
|
spacerClass?: string;
|
2019-06-23 00:45:51 +01:00
|
|
|
withBottomSpace?: boolean;
|
2019-06-12 07:12:03 +01:00
|
|
|
}>;
|
|
|
|
|
2019-06-23 07:45:09 +01:00
|
|
|
export default ({ withBottomSpace, spacerClass, byKey }: Props) => {
|
2019-07-10 05:25:57 +01:00
|
|
|
const flashes = useStoreState((state: State<ApplicationStore>) => state.flashes.items);
|
2019-06-12 07:12:03 +01:00
|
|
|
|
2019-06-23 07:45:09 +01:00
|
|
|
let filtered = flashes;
|
|
|
|
if (byKey) {
|
|
|
|
filtered = flashes.filter(flash => flash.key === byKey);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (filtered.length === 0) {
|
2019-06-23 00:45:51 +01:00
|
|
|
return null;
|
2019-06-12 07:12:03 +01:00
|
|
|
}
|
|
|
|
|
2019-06-23 00:45:51 +01:00
|
|
|
// noinspection PointlessBooleanExpressionJS
|
|
|
|
return (
|
|
|
|
<div className={withBottomSpace === false ? undefined : 'mb-2'}>
|
|
|
|
{
|
2019-06-23 07:45:09 +01:00
|
|
|
filtered.map((flash, index) => (
|
2019-06-23 00:45:51 +01:00
|
|
|
<React.Fragment key={flash.id || flash.type + flash.message}>
|
|
|
|
{index > 0 && <div className={spacerClass || 'mt-2'}></div>}
|
|
|
|
<MessageBox type={flash.type} title={flash.title}>
|
|
|
|
{flash.message}
|
|
|
|
</MessageBox>
|
|
|
|
</React.Fragment>
|
|
|
|
))
|
|
|
|
}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|