Partial commit for #158

ClΓ‘udio created

- Component GBButton created
- New issue form partially created (only title)
- Refactoring for GBButon usage

Next steps
- Practice GraphQL calls
- Finish New issue form (add first comment and submit)

Change summary

webui/src/App.tsx                        |  2 
webui/src/components/Button/GBButton.css | 19 ++++++
webui/src/components/Button/GBButton.tsx | 22 +++++++
webui/src/pages/list/ListQuery.css       | 20 ------
webui/src/pages/list/ListQuery.tsx       |  6 
webui/src/pages/new/NewPage.tsx          | 80 ++++++++++++++++++++++++++
6 files changed, 126 insertions(+), 23 deletions(-)

Detailed changes

webui/src/App.tsx πŸ”—

@@ -4,12 +4,14 @@ import { Route, Switch } from 'react-router';
 import Layout from './layout';
 import BugPage from './pages/bug';
 import ListPage from './pages/list';
+import NewPage from './pages/new/NewPage';
 
 export default function App() {
   return (
     <Layout>
       <Switch>
         <Route path="/" exact component={ListPage} />
+        <Route path="/new" exact component={NewPage} />
         <Route path="/bug/:id" exact component={BugPage} />
       </Switch>
     </Layout>

webui/src/components/Button/GBButton.css πŸ”—

@@ -0,0 +1,19 @@
+.bt-issue {
+    background-color: #2ea44fd9;
+    border: 1px solid;
+    border-color: #1b1f2326;
+    border-radius: 6px;
+    padding: 6px 12px;
+
+    font-size: 14px;
+    color: #ffffff;
+    line-height: 20px;
+    text-decoration: none;
+
+    transition: all 0.2s cubic-bezier(0.3, 0, 0.5, 1);
+}
+
+.bt-issue:hover {
+    background-color: #2ea44f;
+    border-color: #1b1f2326;
+}

webui/src/components/Button/GBButton.tsx πŸ”—

@@ -0,0 +1,22 @@
+import React from 'react';
+import { Link } from 'react-router-dom';
+
+import './GBButton.css';
+
+interface GBButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {
+  to: string;
+  text: string;
+}
+
+/**
+ * Standard button for issue actions
+ */
+const GBButton: React.FC<GBButtonProps> = (props) => {
+  return (
+    <Link to={props.to} className="bt-issue">
+      {props.text}
+    </Link>
+  );
+};
+
+export default GBButton;

webui/src/pages/list/ListQuery.css πŸ”—

@@ -14,24 +14,4 @@ label {
     flex-direction: row;
     align-items: flex-start;
     justify-content: left;
-}
-
-.bt-new-issue {
-    background-color: #2ea44fd9;
-    border: 1px solid;
-    border-color: #1b1f2326;
-    border-radius: 6px;
-    padding: 6px 12px;
-
-    font-size: 14px;
-    color: #ffffff;
-    line-height: 20px;
-    text-decoration: none;
-
-    transition: all 0.2s cubic-bezier(0.3, 0, 0.5, 1);
-}
-
-.bt-new-issue:hover {
-    background-color: #2ea44f;
-    border-color: #1b1f2326;
 }

webui/src/pages/list/ListQuery.tsx πŸ”—

@@ -11,6 +11,8 @@ import KeyboardArrowLeft from '@material-ui/icons/KeyboardArrowLeft';
 import KeyboardArrowRight from '@material-ui/icons/KeyboardArrowRight';
 import Skeleton from '@material-ui/lab/Skeleton';
 
+import GBButton from 'src/components/Button/GBButton';
+
 import FilterToolbar from './FilterToolbar';
 import List from './List';
 import { useListBugsQuery } from './ListQuery.generated';
@@ -291,9 +293,7 @@ function ListQuery() {
             </button>
           </form>
         </div>
-        <Link to="/newIssue" className="bt-new-issue">
-          New Issue
-        </Link>
+        <GBButton to="/new" text="New Issue" />
       </header>
       <FilterToolbar query={query} queryLocation={queryLocation} />
       {content}

webui/src/pages/new/NewPage.tsx πŸ”—

@@ -0,0 +1,80 @@
+import { gql, useMutation } from '@apollo/client';
+import React, { FormEvent } from 'react';
+
+import Paper from '@material-ui/core/Paper/Paper';
+import TextField from '@material-ui/core/TextField/TextField';
+import { fade, makeStyles, Theme } from '@material-ui/core/styles';
+
+import GBButton from '../../components/Button/GBButton';
+
+/**
+ * Styles
+ */
+const useStyles = makeStyles((theme) => ({
+  main: {
+    maxWidth: 800,
+    margin: 'auto',
+    marginTop: theme.spacing(4),
+    marginBottom: theme.spacing(4),
+    padding: theme.spacing(2),
+    overflow: 'hidden',
+  },
+  titleInput: {
+    borderRadius: theme.shape.borderRadius,
+    borderColor: fade(theme.palette.primary.main, 0.2),
+    borderStyle: 'solid',
+    borderWidth: '1px',
+    backgroundColor: fade(theme.palette.primary.main, 0.05),
+    padding: theme.spacing(0, 0),
+    transition: theme.transitions.create([
+      'width',
+      'borderColor',
+      'backgroundColor',
+    ]),
+  },
+  form: {
+    display: 'flex',
+    flexDirection: 'row',
+    flexWrap: 'wrap',
+    justifyContent: 'flex-end',
+  },
+}));
+
+const NEW_BUG = gql`
+  mutation NewBug($input: NewBugInput) {
+    newBug(input: $input) {
+      title
+      message
+    }
+  }
+`;
+
+/**
+ * Form to create a new issue
+ */
+function NewPage() {
+  const classes = useStyles({ searching: false });
+  const [newBugInput] = useMutation(NEW_BUG);
+
+  function submitNewIssue(e: FormEvent) {
+    e.preventDefault();
+    // TODO Call API
+  }
+
+  return (
+    <Paper className={classes.main}>
+      <form className={classes.form} onSubmit={submitNewIssue}>
+        <TextField
+          label="Title"
+          className={classes.titleInput}
+          variant="outlined"
+          fullWidth
+          margin="dense"
+        />
+        <GBButton to="/" text="Submit new issue" />
+      </form>
+    </Paper>
+  );
+}
+
+export default NewPage;