This repository has been archived on 2022-08-14. You can view files and clone it, but cannot push or open issues or pull requests.
Files
outline/app/scenes/Settings/components/EventListItem.js
Tom Moor 978eda3ad2 fix: Deleted collections not showing in audit log
feat: Show titles of objects in audit log
fix: modelId not saved with share events
fix: List item squashes avatar at small screen sizes
2019-08-07 20:52:59 -07:00

144 lines
3.7 KiB
JavaScript

// @flow
import * as React from 'react';
import { Link } from 'react-router-dom';
import { capitalize } from 'lodash';
import styled from 'styled-components';
import Time from 'shared/components/Time';
import ListItem from 'components/List/Item';
import Avatar from 'components/Avatar';
import Event from 'models/Event';
type Props = {
event: Event,
};
const description = event => {
switch (event.name) {
case 'teams.create':
return 'Created the team';
case 'shares.create':
case 'shares.revoke':
return (
<React.Fragment>
{capitalize(event.verbPastTense)} a{' '}
<Link to={`/share/${event.modelId || ''}`}>public link</Link> to the{' '}
<Link to={`/doc/${event.documentId}`}>{event.data.name}</Link>{' '}
document
</React.Fragment>
);
case 'users.create':
return (
<React.Fragment>{event.data.name} created an account</React.Fragment>
);
case 'users.invite':
return (
<React.Fragment>
{capitalize(event.verbPastTense)} {event.data.name} (<a
href={`mailto:${event.data.email || ''}`}
>
{event.data.email || ''}
</a>)
</React.Fragment>
);
case 'collections.add_user':
return (
<React.Fragment>
Added {event.data.name} to a private{' '}
<Link to={`/collections/${event.collectionId || ''}`}>
collection
</Link>
</React.Fragment>
);
case 'collections.remove_user':
return (
<React.Fragment>
Remove {event.data.name} from a private{' '}
<Link to={`/collections/${event.collectionId || ''}`}>
collection
</Link>
</React.Fragment>
);
default:
}
if (event.documentId) {
if (event.name === 'documents.delete') {
return (
<React.Fragment>
Deleted the <strong>{event.data.title}</strong> document
</React.Fragment>
);
}
return (
<React.Fragment>
{capitalize(event.verbPastTense)} the{' '}
<Link to={`/doc/${event.documentId}`}>{event.data.title}</Link> document
</React.Fragment>
);
}
if (event.collectionId) {
if (event.name === 'collections.delete') {
return (
<React.Fragment>
Deleted the <strong>{event.data.name}</strong> collection
</React.Fragment>
);
}
return (
<React.Fragment>
{capitalize(event.verbPastTense)} the{' '}
<Link to={`/collections/${event.collectionId || ''}`}>
{event.data.name}
</Link>{' '}
collection
</React.Fragment>
);
}
if (event.userId) {
return (
<React.Fragment>
{capitalize(event.verbPastTense)} the user {event.data.name}
</React.Fragment>
);
}
return '';
};
const EventListItem = ({ event }: Props) => {
return (
<ListItem
key={event.id}
title={event.actor.name}
image={<Avatar src={event.actor.avatarUrl} size={32} />}
subtitle={
<React.Fragment>
{description(event)} <Time dateTime={event.createdAt} /> ago &middot;{' '}
<strong>{event.name}</strong>
</React.Fragment>
}
actions={
event.actorIpAddress ? (
<IP>
<a
href={`http://geoiplookup.net/ip/${event.actorIpAddress}`}
target="_blank"
rel="noreferrer noopener"
>
{event.actorIpAddress}
</a>
</IP>
) : (
undefined
)
}
/>
);
};
const IP = styled('span')`
color: ${props => props.theme.textTertiary};
font-size: 12px;
`;
export default EventListItem;