webui: dependencies upgrades

Most upgrades are minor version without breaking changes.

One big upgrade is Apollo 2 -> 3, which required a few changes in the
Apollo setup (see src/apollo.ts).

Other changes are due to changes in Prettier, requiring to add
parenthesis around arrow function parameters.

Because of an incompatibility in older version of typescript-eslint with
newer versions of typescript, I had to switch to the "next" unstable
version of react-scripts. It should not break stuff though.

See typescript-eslint/typescript-eslint#2442
This commit is contained in:
Quentin Gliech 2020-09-30 17:31:48 +02:00
parent db20bc34e5
commit f4433d80c4
No known key found for this signature in database
GPG Key ID: 22D62B84552719FC
20 changed files with 8007 additions and 7739 deletions

View File

@ -7,6 +7,7 @@ generates:
- fragment-matcher
config:
module: es2015
apolloClientVersion: 3
./src/gqlTypes.ts:
plugins:
- typescript
@ -15,7 +16,8 @@ generates:
- introspection
./src/:
plugins:
- add: '/* eslint-disable @typescript-eslint/no-unused-vars, import/order */'
- add:
content: '/* eslint-disable @typescript-eslint/no-unused-vars, import/order */'
- typescript-operations
- typescript-react-apollo
preset: near-operation-file

15572
webui/package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -3,45 +3,42 @@
"version": "0.1.0",
"private": true,
"dependencies": {
"@apollo/react-hooks": "^3.1.3",
"@apollo/client": "^3.2.1",
"@arrows/composition": "^1.2.2",
"@material-ui/core": "^4.9.0",
"@material-ui/icons": "^4.2.1",
"@material-ui/lab": "^4.0.0-alpha.40",
"@material-ui/styles": "^4.9.0",
"@types/node": "^13.5.3",
"@types/react": "^16.9.19",
"@types/react-dom": "^16.9.5",
"@types/react-router-dom": "^5.1.3",
"apollo-boost": "^0.4.7",
"clsx": "^1.1.0",
"graphql": "^14.6.0",
"graphql.macro": "^1.4.2",
"moment": "^2.24.0",
"react": "^16.8.6",
"react-apollo": "^3.1.3",
"react-dom": "^16.8.6",
"react-moment": "^0.9.7",
"react-router": "^5.0.0",
"react-router-dom": "^5.0.0",
"react-scripts": "^3.4.1",
"remark-html": "^10.0.0",
"remark-parse": "^7.0.2",
"remark-react": "^6.0.0",
"typescript": "^3.7.5",
"unified": "^8.4.2"
"@material-ui/core": "^4.11.0",
"@material-ui/icons": "^4.9.1",
"@material-ui/lab": "^4.0.0-alpha.56",
"@material-ui/styles": "^4.10.0",
"@types/node": "^14.11.2",
"@types/react": "^16.9.49",
"@types/react-dom": "^16.9.8",
"@types/react-router-dom": "^5.1.5",
"clsx": "^1.1.1",
"graphql": "^15.3.0",
"moment": "^2.29.0",
"react": "^16.13.1",
"react-dom": "^16.13.1",
"react-moment": "^1.0.0",
"react-router": "^5.2.0",
"react-router-dom": "^5.2.0",
"react-scripts": "^4.0.0-next.98",
"remark-html": "^12.0.0",
"remark-parse": "^8.0.3",
"remark-react": "^7.0.1",
"typescript": "^4.0.3",
"unified": "^9.2.0"
},
"devDependencies": {
"@graphql-codegen/cli": "^1.15.3",
"@graphql-codegen/fragment-matcher": "^1.15.3",
"@graphql-codegen/near-operation-file-preset": "^1.15.3",
"@graphql-codegen/typescript-operations": "^1.15.3",
"@graphql-codegen/typescript-react-apollo": "^1.15.3",
"@graphql-codegen/introspection": "^1.15.3",
"eslint-config-prettier": "^6.10.0",
"eslint-plugin-graphql": "^3.1.1",
"eslint-plugin-prettier": "^3.1.2",
"prettier": "^1.19.1"
"@graphql-codegen/cli": "^1.17.10",
"@graphql-codegen/fragment-matcher": "^1.17.8",
"@graphql-codegen/introspection": "^1.18.0",
"@graphql-codegen/near-operation-file-preset": "^1.17.11",
"@graphql-codegen/typescript-operations": "^1.17.8",
"@graphql-codegen/typescript-react-apollo": "^2.0.7",
"eslint-config-prettier": "^6.12.0",
"eslint-plugin-graphql": "^4.0.0",
"eslint-plugin-prettier": "^3.1.4",
"prettier": "^2.1.2"
},
"scripts": {
"start": "npm run generate && react-scripts start",

View File

@ -1,17 +1,11 @@
import ApolloClient from 'apollo-boost';
import {
IntrospectionFragmentMatcher,
InMemoryCache,
} from 'apollo-cache-inmemory';
import { ApolloClient, InMemoryCache } from '@apollo/client';
import introspectionQueryResultData from './fragmentTypes';
import introspectionResult from './fragmentTypes';
const client = new ApolloClient({
uri: '/graphql',
cache: new InMemoryCache({
fragmentMatcher: new IntrospectionFragmentMatcher({
introspectionQueryResultData,
}),
possibleTypes: introspectionResult.possibleTypes,
}),
});

View File

@ -30,7 +30,7 @@ const createStyle = (color: Color) => ({
borderBottomColor: darken(_rgb(color), 0.2),
});
const useStyles = makeStyles(theme => ({
const useStyles = makeStyles((theme) => ({
label: {
...theme.typography.body1,
padding: '1px 6px 0.5px',

View File

@ -1,5 +1,5 @@
import { ApolloProvider } from '@apollo/client';
import React from 'react';
import { ApolloProvider } from 'react-apollo';
import ReactDOM from 'react-dom';
import { BrowserRouter } from 'react-router-dom';

View File

@ -5,7 +5,7 @@ import { makeStyles } from '@material-ui/core/styles';
import { useCurrentIdentityQuery } from './CurrentIdentity.generated';
const useStyles = makeStyles(theme => ({
const useStyles = makeStyles((theme) => ({
displayName: {
marginLeft: theme.spacing(2),
},

View File

@ -7,7 +7,7 @@ import { makeStyles } from '@material-ui/core/styles';
import CurrentIdentity from './CurrentIdentity';
const useStyles = makeStyles(theme => ({
const useStyles = makeStyles((theme) => ({
offset: {
...theme.mixins.toolbar,
},

View File

@ -12,7 +12,7 @@ import { BugFragment } from './Bug.generated';
import CommentForm from './CommentForm';
import TimelineQuery from './TimelineQuery';
const useStyles = makeStyles(theme => ({
const useStyles = makeStyles((theme) => ({
main: {
maxWidth: 1000,
margin: 'auto',
@ -103,7 +103,7 @@ function Bug({ bug }: Props) {
{bug.labels.length === 0 && (
<span className={classes.noLabel}>None yet</span>
)}
{bug.labels.map(l => (
{bug.labels.map((l) => (
<li className={classes.label} key={l.name}>
<Label label={l} key={l.name} />
</li>

View File

@ -13,7 +13,7 @@ import { useAddCommentMutation } from './CommentForm.generated';
import { TimelineDocument } from './TimelineQuery.generated';
type StyleProps = { loading: boolean };
const useStyles = makeStyles<Theme, StyleProps>(theme => ({
const useStyles = makeStyles<Theme, StyleProps>((theme) => ({
container: {
margin: theme.spacing(2, 0),
padding: theme.spacing(0, 2, 2, 2),

View File

@ -8,7 +8,7 @@ import Label from 'src/components/Label';
import { LabelChangeFragment } from './LabelChangeFragment.generated';
const useStyles = makeStyles(theme => ({
const useStyles = makeStyles((theme) => ({
main: {
...theme.typography.body2,
marginLeft: theme.spacing(1) + 40,

View File

@ -10,7 +10,7 @@ import Date from 'src/components/Date';
import { AddCommentFragment } from './MessageCommentFragment.generated';
import { CreateFragment } from './MessageCreateFragment.generated';
const useStyles = makeStyles(theme => ({
const useStyles = makeStyles((theme) => ({
author: {
fontWeight: 'bold',
},

View File

@ -8,7 +8,7 @@ import Date from 'src/components/Date';
import { SetStatusFragment } from './SetStatusFragment.generated';
const useStyles = makeStyles(theme => ({
const useStyles = makeStyles((theme) => ({
main: {
...theme.typography.body2,
marginLeft: theme.spacing(1) + 40,

View File

@ -7,7 +7,7 @@ import Date from 'src/components/Date';
import { SetTitleFragment } from './SetTitleFragment.generated';
const useStyles = makeStyles(theme => ({
const useStyles = makeStyles((theme) => ({
main: {
...theme.typography.body2,
marginLeft: theme.spacing(1) + 40,

View File

@ -8,7 +8,7 @@ import SetStatus from './SetStatus';
import SetTitle from './SetTitle';
import { TimelineItemFragment } from './TimelineQuery.generated';
const useStyles = makeStyles(theme => ({
const useStyles = makeStyles((theme) => ({
main: {
'& > *:not(:last-child)': {
marginBottom: theme.spacing(2),

View File

@ -42,7 +42,7 @@ const BugStatus: React.FC<StatusProps> = ({
}
};
const useStyles = makeStyles(theme => ({
const useStyles = makeStyles((theme) => ({
cell: {
display: 'flex',
alignItems: 'center',
@ -92,7 +92,7 @@ function BugRow({ bug }: Props) {
<span className={classes.title}>{bug.title}</span>
{bug.labels.length > 0 && (
<span className={classes.labels}>
{bug.labels.map(l => (
{bug.labels.map((l) => (
<Label key={l.name} label={l} />
))}
</span>

View File

@ -9,7 +9,7 @@ import { SvgIconProps } from '@material-ui/core/SvgIcon';
import { makeStyles } from '@material-ui/core/styles';
import ArrowDropDown from '@material-ui/icons/ArrowDropDown';
export type Query = { [key: string]: Array<string> };
export type Query = { [key: string]: string[] };
function parse(query: string): Query {
// TODO: extract the rest of the query?
@ -57,12 +57,12 @@ function quote(value: string): string {
function stringify(params: Query): string {
const parts: string[][] = Object.entries(params).map(([key, values]) => {
return values.map(value => `${key}:${quote(value)}`);
return values.map((value) => `${key}:${quote(value)}`);
});
return new Array<string>().concat(...parts).join(' ');
}
const useStyles = makeStyles(theme => ({
const useStyles = makeStyles((theme) => ({
element: {
...theme.typography.body2,
color: '#444',

View File

@ -17,7 +17,7 @@ import {
} from './Filter';
import { useBugCountQuery } from './FilterToolbar.generated';
const useStyles = makeStyles(theme => ({
const useStyles = makeStyles((theme) => ({
toolbar: {
backgroundColor: theme.palette.grey['100'],
borderColor: theme.palette.grey['300'],
@ -123,8 +123,8 @@ function FilterToolbar({ query, queryLocation }: Props) {
['edit', 'Recently updated'],
['edit-asc', 'Least recently updated'],
]}
itemActive={key => hasValue('sort', key)}
to={key => pipe(replaceParam('sort', key), loc)(params)}
itemActive={(key) => hasValue('sort', key)}
to={(key) => pipe(replaceParam('sort', key), loc)(params)}
>
Sort
</FilterDropdown>

View File

@ -1,4 +1,4 @@
import { ApolloError } from 'apollo-boost';
import { ApolloError } from '@apollo/client';
import React, { useState, useEffect, useRef } from 'react';
import { useLocation, useHistory, Link } from 'react-router-dom';
@ -16,7 +16,7 @@ import List from './List';
import { useListBugsQuery } from './ListQuery.generated';
type StylesProps = { searching?: boolean };
const useStyles = makeStyles<Theme, StylesProps>(theme => ({
const useStyles = makeStyles<Theme, StylesProps>((theme) => ({
main: {
maxWidth: 800,
margin: 'auto',
@ -211,7 +211,7 @@ function ListQuery() {
if (bugs.pageInfo.hasNextPage) {
nextPage = {
...location,
search: editParams(params, p => {
search: editParams(params, (p) => {
p.delete('last');
p.delete('before');
p.set('first', perPage);
@ -223,7 +223,7 @@ function ListQuery() {
if (bugs.pageInfo.hasPreviousPage) {
previousPage = {
...location,
search: editParams(params, p => {
search: editParams(params, (p) => {
p.delete('first');
p.delete('after');
p.set('last', perPage);
@ -234,7 +234,7 @@ function ListQuery() {
}
// Prepare params without paging for editing filters
const paramsWithoutPaging = editParams(params, p => {
const paramsWithoutPaging = editParams(params, (p) => {
p.delete('first');
p.delete('last');
p.delete('before');
@ -243,7 +243,9 @@ function ListQuery() {
// Returns a new location with the `q` param edited
const queryLocation = (query: string) => ({
...location,
search: editParams(paramsWithoutPaging, p => p.set('q', query)).toString(),
search: editParams(paramsWithoutPaging, (p) =>
p.set('q', query)
).toString(),
});
let content;

View File

@ -22,7 +22,8 @@
"node_modules/@types/",
"types/"
],
"baseUrl": "."
"baseUrl": ".",
"noFallthroughCasesInSwitch": true
},
"include": [
"src"