mirror of
https://github.com/MichaelMure/git-bug.git
synced 2025-01-07 10:36:36 +03:00
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:
parent
3d4385483e
commit
098bcd0c1f
@ -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) {
|
||||||
|
@ -0,0 +1,11 @@
|
|||||||
|
mutation AddCommentAndCloseBug($input: AddCommentAndCloseBugInput!) {
|
||||||
|
addCommentAndClose(input: $input) {
|
||||||
|
statusOperation {
|
||||||
|
status
|
||||||
|
}
|
||||||
|
commentOperation {
|
||||||
|
message
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -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;
|
@ -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"
|
||||||
|
Loading…
Reference in New Issue
Block a user