mirror of
https://github.com/MichaelMure/git-bug.git
synced 2024-12-15 02:01:43 +03:00
Populate history menu with edit steps
This commit is contained in:
parent
25d3aca9ad
commit
defd1ae00c
@ -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>
|
||||
|
@ -96,6 +96,8 @@ function Message({ bug, op }: Props) {
|
||||
{comment.edited && (
|
||||
<EditHistoryMenu
|
||||
iconBtnProps={{ className: classes.headerActions }}
|
||||
bugId={bug.id}
|
||||
commentId={comment.id}
|
||||
/>
|
||||
)}
|
||||
<IfLoggedIn>
|
||||
|
@ -6,4 +6,8 @@ fragment AddComment on AddCommentTimelineItem {
|
||||
...authored
|
||||
edited
|
||||
message
|
||||
history {
|
||||
message
|
||||
date
|
||||
}
|
||||
}
|
||||
|
@ -6,4 +6,8 @@ fragment Create on CreateTimelineItem {
|
||||
...authored
|
||||
edited
|
||||
message
|
||||
history {
|
||||
message
|
||||
date
|
||||
}
|
||||
}
|
||||
|
15
webui/src/pages/bug/MessageEditHistory.graphql
Normal file
15
webui/src/pages/bug/MessageEditHistory.graphql
Normal file
@ -0,0 +1,15 @@
|
||||
#import "./MessageCommentFragment.graphql"
|
||||
#import "./MessageCreateFragment.graphql"
|
||||
|
||||
query MessageEditHistory($bugIdPrefix: String!) {
|
||||
repository {
|
||||
bug(prefix: $bugIdPrefix) {
|
||||
timeline {
|
||||
comments: nodes {
|
||||
...Create
|
||||
...AddComment
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user