WebUI: Add comment-and-close of a bug in one step

When a user has some text entered in the comment field, the close bug
button will change to "Close bug with comment". This way the user does
not have to comment and close a bug in two separate steps.
This commit is contained in:
Sascha 2021-05-25 14:07:27 +02:00
parent 3d4385483e
commit 098bcd0c1f
4 changed files with 91 additions and 8 deletions

View File

@ -18,7 +18,7 @@ const useStyles = makeStyles((theme: Theme) => ({
interface Props { interface Props {
bug: BugFragment; bug: BugFragment;
disabled: boolean; disabled?: boolean;
} }
function CloseBugButton({ bug, disabled }: Props) { function CloseBugButton({ bug, disabled }: Props) {

View File

@ -0,0 +1,11 @@
mutation AddCommentAndCloseBug($input: AddCommentAndCloseBugInput!) {
addCommentAndClose(input: $input) {
statusOperation {
status
}
commentOperation {
message
}
}
}

View File

@ -0,0 +1,69 @@
import React from 'react';
import Button from '@material-ui/core/Button';
import { makeStyles, Theme } from '@material-ui/core/styles';
import ErrorOutlineIcon from '@material-ui/icons/ErrorOutline';
import { BugFragment } from 'src/pages/bug/Bug.generated';
import { TimelineDocument } from 'src/pages/bug/TimelineQuery.generated';
import { useAddCommentAndCloseBugMutation } from './CloseBugWithComment.generated';
const useStyles = makeStyles((theme: Theme) => ({
closeIssueIcon: {
color: theme.palette.secondary.dark,
paddingTop: '0.1rem',
},
}));
interface Props {
bug: BugFragment;
comment: string;
}
function CloseBugWithCommentButton({ bug, comment }: Props) {
const [
addCommentAndCloseBug,
{ loading, error },
] = useAddCommentAndCloseBugMutation();
const classes = useStyles();
function addCommentAndCloseBugAction() {
addCommentAndCloseBug({
variables: {
input: {
prefix: bug.id,
message: comment,
},
},
refetchQueries: [
// TODO: update the cache instead of refetching
{
query: TimelineDocument,
variables: {
id: bug.id,
first: 100,
},
},
],
awaitRefetchQueries: true,
});
}
if (loading) return <div>Loading...</div>;
if (error) return <div>Error</div>;
return (
<div>
<Button
variant="contained"
onClick={() => addCommentAndCloseBugAction()}
startIcon={<ErrorOutlineIcon className={classes.closeIssueIcon} />}
>
Close bug with comment
</Button>
</div>
);
}
export default CloseBugWithCommentButton;

View File

@ -6,6 +6,7 @@ import { makeStyles, Theme } from '@material-ui/core/styles';
import CommentInput from '../../components/CommentInput/CommentInput'; import CommentInput from '../../components/CommentInput/CommentInput';
import CloseBugButton from 'src/components/CloseBugButton/CloseBugButton'; import CloseBugButton from 'src/components/CloseBugButton/CloseBugButton';
import CloseBugWithCommentButton from 'src/components/CloseBugWithCommentButton/CloseBugWithCommentButton';
import ReopenBugButton from 'src/components/ReopenBugButton/ReopenBugButton'; import ReopenBugButton from 'src/components/ReopenBugButton/ReopenBugButton';
import { BugFragment } from './Bug.generated'; import { BugFragment } from './Bug.generated';
@ -77,12 +78,14 @@ function CommentForm({ bug }: Props) {
if (issueComment.length > 0) submit(); if (issueComment.length > 0) submit();
}; };
function getCloseButton() { function getBugStatusButton() {
return <CloseBugButton bug={bug} disabled={issueComment.length > 0} />; if (bug.status === 'OPEN' && issueComment.length > 0) {
} return <CloseBugWithCommentButton bug={bug} comment={issueComment} />;
} else if (bug.status === 'OPEN') {
function getReopenButton() { return <CloseBugButton bug={bug} />;
return <ReopenBugButton bug={bug} disabled={issueComment.length > 0} />; } else {
return <ReopenBugButton bug={bug} disabled={issueComment.length > 0} />;
}
} }
return ( return (
@ -94,7 +97,7 @@ function CommentForm({ bug }: Props) {
onChange={(comment: string) => setIssueComment(comment)} onChange={(comment: string) => setIssueComment(comment)}
/> />
<div className={classes.actions}> <div className={classes.actions}>
{bug.status === 'OPEN' ? getCloseButton() : getReopenButton()} {getBugStatusButton()}
<Button <Button
className={classes.greenButton} className={classes.greenButton}
variant="contained" variant="contained"