-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMessageAlerts.tsx
74 lines (69 loc) · 1.89 KB
/
MessageAlerts.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
import { Close } from '@navikt/ds-icons';
import { Alert, BodyShort, Button } from '@navikt/ds-react';
import { makeStyles, navCssVariables } from '@navikt/skjemadigitalisering-shared-components';
import { Message } from '../context/notifications/messageQueueReducer';
interface AlertProps {
message: Message;
clearMessage?: () => void;
}
const useStyles = makeStyles({
alert: {
marginBottom: '1rem',
},
body: {
overflowWrap: 'anywhere',
},
alertContent: {
display: 'flex',
alignItems: 'flex-start',
'& .knapp': {
color: navCssVariables.navMorkGra,
backgroundColor: 'transparent',
'& svg': {
fill: navCssVariables.navMorkGra,
},
},
},
});
export const SuccessAlert = ({ message }: AlertProps) => {
const styles = useStyles();
return (
<Alert variant="success" className={styles.alert}>
{message.message}
</Alert>
);
};
export const ErrorAlert = ({ message, clearMessage }: AlertProps) => {
const styles = useStyles();
return (
<Alert variant="error" className={styles.alert}>
<div className={styles.alertContent}>
<BodyShort className={styles.body}>{message.message}</BodyShort>
<Button
variant="tertiary"
icon={<Close aria-hidden />}
onClick={clearMessage}
type="button"
aria-label="Lukk feilmelding"
/>
</div>
</Alert>
);
};
export const WarningAlert = ({ message, clearMessage }: AlertProps) => {
const styles = useStyles();
return (
<Alert variant="warning" className={styles.alert}>
<div className={styles.alertContent}>
<BodyShort className={styles.body}>{message.message}</BodyShort>
<Button
variant="tertiary"
icon={<Close aria-hidden />}
onClick={clearMessage}
type="button"
aria-label="Lukk advarsel"
/>
</div>
</Alert>
);
};