You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
103 lines
2.5 KiB
TypeScript
103 lines
2.5 KiB
TypeScript
import React from 'react';
|
|
|
|
import { Flex } from '../basic/Flex';
|
|
import styled from 'styled-components';
|
|
import { SessionIcon, SessionIconType } from '../icon';
|
|
import { noop } from 'lodash';
|
|
|
|
// NOTE We don't change the color strip on the left based on the type. 16/09/2022
|
|
export enum SessionToastType {
|
|
Info = 'info',
|
|
Success = 'success',
|
|
Warning = 'warning',
|
|
Error = 'error',
|
|
}
|
|
|
|
type Props = {
|
|
title: string;
|
|
id?: string;
|
|
type?: SessionToastType;
|
|
icon?: SessionIconType;
|
|
description?: string;
|
|
closeToast?: any;
|
|
onToastClick?: () => void;
|
|
};
|
|
|
|
const TitleDiv = styled.div`
|
|
font-size: var(--font-size-md);
|
|
line-height: var(--font-size-md);
|
|
font-family: var(--font-default);
|
|
color: var(--text-primary-color);
|
|
text-overflow: ellipsis;
|
|
`;
|
|
|
|
const DescriptionDiv = styled.div`
|
|
font-size: var(--font-size-sm);
|
|
color: var(--text-secondary-color);
|
|
text-overflow: ellipsis;
|
|
font-family: var(--font-default);
|
|
padding-top: var(--margins-xs);
|
|
`;
|
|
|
|
const IconDiv = styled.div`
|
|
flex-shrink: 0;
|
|
padding-inline-end: var(--margins-xs);
|
|
margin: 0 var(--margins-xs);
|
|
`;
|
|
|
|
// tslint:disable: use-simple-attributes
|
|
|
|
export const SessionToast = (props: Props) => {
|
|
const { title, description, type, icon } = props;
|
|
|
|
const toastDesc = description ? description : '';
|
|
const toastIconSize = toastDesc ? 'huge' : 'medium';
|
|
|
|
// Set a custom icon or allow the theme to define the icon
|
|
let toastIcon = icon || undefined;
|
|
if (!toastIcon) {
|
|
switch (type) {
|
|
case SessionToastType.Info:
|
|
toastIcon = 'info';
|
|
break;
|
|
case SessionToastType.Success:
|
|
toastIcon = 'check';
|
|
break;
|
|
case SessionToastType.Error:
|
|
toastIcon = 'error';
|
|
break;
|
|
case SessionToastType.Warning:
|
|
toastIcon = 'warning';
|
|
break;
|
|
default:
|
|
toastIcon = 'info';
|
|
}
|
|
}
|
|
|
|
const onToastClick = props?.onToastClick || noop;
|
|
|
|
return (
|
|
// tslint:disable-next-line: use-simple-attributes
|
|
<Flex
|
|
container={true}
|
|
alignItems="center"
|
|
onClick={onToastClick}
|
|
data-testid="session-toast"
|
|
padding="var(--margins-sm) 0"
|
|
>
|
|
<IconDiv>
|
|
<SessionIcon iconType={toastIcon} iconSize={toastIconSize} />
|
|
</IconDiv>
|
|
<Flex
|
|
container={true}
|
|
justifyContent="flex-start"
|
|
flexDirection="column"
|
|
className="session-toast"
|
|
>
|
|
<TitleDiv>{title}</TitleDiv>
|
|
{toastDesc && <DescriptionDiv>{toastDesc}</DescriptionDiv>}
|
|
</Flex>
|
|
</Flex>
|
|
);
|
|
};
|