Populate history menu with edit steps

This commit is contained in:
Sascha 2021-03-18 15:45:20 +01:00
parent 25d3aca9ad
commit defd1ae00c
5 changed files with 55 additions and 24 deletions

View File

@ -1,36 +1,43 @@
import React from 'react';
import CircularProgress from '@material-ui/core/CircularProgress';
import IconButton, { IconButtonProps } from '@material-ui/core/IconButton';
import Menu from '@material-ui/core/Menu';
import MenuItem from '@material-ui/core/MenuItem';
import HistoryIcon from '@material-ui/icons/History';
const options = [
'None',
'Atria',
'Callisto',
'Dione',
'Ganymede',
'Hangouts Call',
'Luna',
'Oberon',
'Phobos',
'Pyxis',
'Sedna',
'Titania',
'Triton',
'Umbriel',
];
import Date from 'src/components/Date';
import { AddCommentFragment } from './MessageCommentFragment.generated';
import { CreateFragment } from './MessageCreateFragment.generated';
import { useMessageEditHistoryQuery } from './MessageEditHistory.generated';
const ITEM_HEIGHT = 48;
type Props = {
bugId: string;
commentId: string;
iconBtnProps?: IconButtonProps;
};
function EditHistoryMenu({ iconBtnProps }: Props) {
function EditHistoryMenu({ iconBtnProps, bugId, commentId }: Props) {
const [anchorEl, setAnchorEl] = React.useState<null | HTMLElement>(null);
const open = Boolean(anchorEl);
const { loading, error, data } = useMessageEditHistoryQuery({
variables: { bugIdPrefix: bugId },
});
if (loading) return <CircularProgress />;
if (error) return <p>Error: {error}</p>;
const comments = data?.repository?.bug?.timeline.comments as (
| AddCommentFragment
| CreateFragment
)[];
// NOTE Searching for the changed comment could be dropped if GraphQL get
// filter by id argument for timelineitems
const comment = comments.find((elem) => elem.id === commentId);
const history = comment?.history;
const handleClick = (event: React.MouseEvent<HTMLElement>) => {
setAnchorEl(event.currentTarget);
};
@ -63,13 +70,12 @@ function EditHistoryMenu({ iconBtnProps }: Props) {
},
}}
>
{options.map((option) => (
<MenuItem
key={option}
selected={option === 'Pyxis'}
onClick={handleClose}
>
{option}
<MenuItem key={0} disabled>
Edited {history?.length} times.
</MenuItem>
{history?.map((edit, index) => (
<MenuItem key={index} onClick={handleClose}>
<Date date={edit.date} />
</MenuItem>
))}
</Menu>

View File

@ -96,6 +96,8 @@ function Message({ bug, op }: Props) {
{comment.edited && (
<EditHistoryMenu
iconBtnProps={{ className: classes.headerActions }}
bugId={bug.id}
commentId={comment.id}
/>
)}
<IfLoggedIn>

View File

@ -6,4 +6,8 @@ fragment AddComment on AddCommentTimelineItem {
...authored
edited
message
history {
message
date
}
}

View File

@ -6,4 +6,8 @@ fragment Create on CreateTimelineItem {
...authored
edited
message
history {
message
date
}
}

View File

@ -0,0 +1,15 @@
#import "./MessageCommentFragment.graphql"
#import "./MessageCreateFragment.graphql"
query MessageEditHistory($bugIdPrefix: String!) {
repository {
bug(prefix: $bugIdPrefix) {
timeline {
comments: nodes {
...Create
...AddComment
}
}
}
}
}