@scrabble-solver/scrabble-solver 2.10.5 → 2.10.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.next/BUILD_ID +1 -1
- package/.next/build-manifest.json +10 -10
- package/.next/cache/.tsbuildinfo +1 -1
- package/.next/cache/eslint/.cache_8dgz12 +1 -1
- package/.next/cache/next-server.js.nft.json +1 -1
- package/.next/cache/webpack/client-production/0.pack +0 -0
- package/.next/cache/webpack/client-production/index.pack +0 -0
- package/.next/cache/webpack/edge-server-production/0.pack +0 -0
- package/.next/cache/webpack/edge-server-production/index.pack +0 -0
- package/.next/cache/webpack/server-production/0.pack +0 -0
- package/.next/cache/webpack/server-production/index.pack +0 -0
- package/.next/next-server.js.nft.json +1 -1
- package/.next/prerender-manifest.json +1 -1
- package/.next/routes-manifest.json +1 -1
- package/.next/server/chunks/176.js +551 -447
- package/.next/server/chunks/290.js +3 -1
- package/.next/server/chunks/579.js +24 -16
- package/.next/server/middleware-build-manifest.js +1 -1
- package/.next/server/pages/404.html +2 -2
- package/.next/server/pages/404.js.nft.json +1 -1
- package/.next/server/pages/500.html +2 -2
- package/.next/server/pages/_app.js.nft.json +1 -1
- package/.next/server/pages/api/dictionary/[locale]/[word].js +18 -16
- package/.next/server/pages/index.html +2 -2
- package/.next/server/pages/index.js +18 -11
- package/.next/server/pages/index.js.nft.json +1 -1
- package/.next/server/pages/index.json +1 -1
- package/.next/server/pages-manifest.json +1 -1
- package/.next/static/6RggBFm8kHrh-k1-CG3um/_buildManifest.js +1 -0
- package/.next/static/chunks/509-6ad4482d4351452c.js +1 -0
- package/.next/static/chunks/pages/{404-7619583a9e7188b1.js → 404-67383848027ec49b.js} +1 -1
- package/.next/static/chunks/pages/_app-c58cfa832b76cc87.js +24 -0
- package/.next/static/chunks/pages/index-146039f501e49c08.js +1 -0
- package/.next/static/css/4482c4a0064d3807.css +1 -0
- package/.next/static/css/9d1013ec684361b9.css +1 -0
- package/.next/trace +55 -55
- package/package.json +14 -14
- package/src/components/Board/components/Cell/Button.tsx +1 -0
- package/src/components/Board/components/Cell/Cell.tsx +6 -0
- package/src/components/Board/components/Cell/CellPure.tsx +10 -1
- package/src/components/Button/Button.module.scss +2 -5
- package/src/components/Button/Button.tsx +1 -0
- package/src/components/Button/Link.tsx +1 -0
- package/src/components/{SquareButton/SquareButton.module.scss → IconButton/IconButton.module.scss} +2 -3
- package/src/components/{SquareButton/SquareButton.tsx → IconButton/IconButton.tsx} +7 -6
- package/src/components/{SquareButton → IconButton}/Link.tsx +3 -2
- package/src/components/IconButton/index.ts +1 -0
- package/src/components/Logo/Logo.svg +44 -15
- package/src/components/Modal/Modal.tsx +3 -2
- package/src/components/NavButtons/NavButtons.tsx +37 -9
- package/src/components/Rack/RackTile.tsx +5 -0
- package/src/components/Results/HeaderButton.tsx +1 -0
- package/src/components/Results/Result.tsx +1 -0
- package/src/components/Results/Results.module.scss +0 -1
- package/src/components/Results/SolveButton.tsx +1 -0
- package/src/components/Solver/Solver.module.scss +11 -19
- package/src/components/Solver/Solver.tsx +18 -36
- package/src/components/Solver/components/EmptyState/EmptyState.module.scss +0 -2
- package/src/components/Solver/components/InsertButton/InsertButton.module.scss +15 -0
- package/src/components/Solver/components/{ApplyButton/ApplyButton.tsx → InsertButton/InsertButton.tsx} +10 -6
- package/src/components/Solver/components/InsertButton/index.ts +1 -0
- package/src/components/Solver/components/ResultCandidatePicker/ResultCandidatePicker.module.scss +143 -0
- package/src/components/Solver/components/ResultCandidatePicker/ResultCandidatePicker.tsx +98 -0
- package/src/components/Solver/components/SolveButton/SolveButton.tsx +11 -1
- package/src/components/Solver/components/index.ts +2 -1
- package/src/components/Tile/Tile.tsx +3 -0
- package/src/components/Tile/TilePure.tsx +3 -0
- package/src/components/Tooltip/useTooltip.tsx +14 -2
- package/src/components/index.ts +1 -2
- package/src/i18n/de.json +5 -0
- package/src/i18n/en.json +5 -0
- package/src/i18n/es.json +5 -0
- package/src/i18n/fa.json +5 -0
- package/src/i18n/fr.json +5 -0
- package/src/i18n/pl.json +5 -0
- package/src/icons/ArrowDown.svg +1 -1
- package/src/icons/ArrowLeft.svg +1 -1
- package/src/icons/ArrowRight.svg +1 -1
- package/src/icons/ArrowUp.svg +1 -1
- package/src/icons/ChevronDown.svg +1 -1
- package/src/icons/ChevronLeft.svg +4 -0
- package/src/icons/ChevronRight.svg +4 -0
- package/src/icons/List.svg +1 -1
- package/src/icons/index.ts +2 -0
- package/src/modals/MenuModal/MenuModal.module.scss +2 -3
- package/src/modals/MenuModal/MenuModal.tsx +9 -3
- package/src/modals/RemainingTilesModal/components/Character/Character.tsx +1 -0
- package/src/modals/SettingsModal/components/AutoGroupTilesSetting/AutoGroupTilesSetting.tsx +2 -2
- package/src/modals/SettingsModal/components/ConfigSetting/ConfigSetting.tsx +2 -2
- package/src/modals/SettingsModal/components/LocaleSetting/LocaleSetting.tsx +2 -2
- package/src/pages/api/dictionary/[locale]/[word].ts +3 -1
- package/src/pages/index.tsx +10 -6
- package/src/state/sagas.ts +5 -2
- package/src/state/useTranslate.ts +5 -2
- package/src/styles/mixins.scss +6 -0
- package/src/types/index.ts +6 -1
- package/.next/static/WILX-RgqlLTd4ZoPs8C_E/_buildManifest.js +0 -1
- package/.next/static/chunks/144-6768fe9a92865ec8.js +0 -1
- package/.next/static/chunks/pages/_app-fa0661b072fc6af9.js +0 -24
- package/.next/static/chunks/pages/index-1a6bbb880f28606a.js +0 -1
- package/.next/static/css/d80ffccf2315791a.css +0 -1
- package/.next/static/css/e737d5d7fbed2434.css +0 -1
- package/src/components/ResultCandidatePicker/ResultCandidatePicker.module.scss +0 -76
- package/src/components/ResultCandidatePicker/ResultCandidatePicker.tsx +0 -38
- package/src/components/Solver/components/ApplyButton/ApplyButton.module.scss +0 -5
- package/src/components/Solver/components/ApplyButton/index.ts +0 -1
- package/src/components/SquareButton/index.ts +0 -1
- /package/.next/static/{WILX-RgqlLTd4ZoPs8C_E → 6RggBFm8kHrh-k1-CG3um}/_ssgManifest.js +0 -0
- /package/src/components/{ResultCandidatePicker → Solver/components/ResultCandidatePicker}/index.ts +0 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@scrabble-solver/scrabble-solver",
|
|
3
|
-
"version": "2.10.
|
|
3
|
+
"version": "2.10.7",
|
|
4
4
|
"description": "Scrabble Solver 2 - App",
|
|
5
5
|
"engines": {
|
|
6
6
|
"node": ">=16"
|
|
@@ -30,14 +30,14 @@
|
|
|
30
30
|
"dependencies": {
|
|
31
31
|
"@kamilmielnik/trie": "^2.0.1",
|
|
32
32
|
"@popperjs/core": "^2.11.6",
|
|
33
|
-
"@reduxjs/toolkit": "^1.9.
|
|
34
|
-
"@scrabble-solver/configs": "^2.10.
|
|
35
|
-
"@scrabble-solver/constants": "^2.10.
|
|
36
|
-
"@scrabble-solver/dictionaries": "^2.10.
|
|
37
|
-
"@scrabble-solver/logger": "^2.10.
|
|
38
|
-
"@scrabble-solver/solver": "^2.10.
|
|
39
|
-
"@scrabble-solver/types": "^2.10.
|
|
40
|
-
"@scrabble-solver/word-definitions": "^2.10.
|
|
33
|
+
"@reduxjs/toolkit": "^1.9.3",
|
|
34
|
+
"@scrabble-solver/configs": "^2.10.7",
|
|
35
|
+
"@scrabble-solver/constants": "^2.10.7",
|
|
36
|
+
"@scrabble-solver/dictionaries": "^2.10.7",
|
|
37
|
+
"@scrabble-solver/logger": "^2.10.7",
|
|
38
|
+
"@scrabble-solver/solver": "^2.10.7",
|
|
39
|
+
"@scrabble-solver/types": "^2.10.7",
|
|
40
|
+
"@scrabble-solver/word-definitions": "^2.10.7",
|
|
41
41
|
"classnames": "^2.3.2",
|
|
42
42
|
"include-media": "^2.0.0",
|
|
43
43
|
"include-media-query-builder": "^1.1.0",
|
|
@@ -63,18 +63,18 @@
|
|
|
63
63
|
"devDependencies": {
|
|
64
64
|
"@svgr/webpack": "^6.5.1",
|
|
65
65
|
"@types/classnames": "^2.3.0",
|
|
66
|
-
"@types/react": "^18.0.
|
|
67
|
-
"@types/react-dom": "^18.0.
|
|
66
|
+
"@types/react": "^18.0.28",
|
|
67
|
+
"@types/react-dom": "^18.0.11",
|
|
68
68
|
"@types/react-modal": "^3.13.1",
|
|
69
69
|
"@types/react-portal": "^4.0.4",
|
|
70
70
|
"@types/react-redux": "^7.1.25",
|
|
71
71
|
"@types/react-window": "^1.8.5",
|
|
72
72
|
"@types/redux": "^3.6.31",
|
|
73
73
|
"@types/redux-saga": "^0.10.5",
|
|
74
|
-
"@types/uuid": "^9.0.
|
|
74
|
+
"@types/uuid": "^9.0.1",
|
|
75
75
|
"env-cmd": "^10.1.0",
|
|
76
|
-
"sass": "^1.
|
|
76
|
+
"sass": "^1.58.3",
|
|
77
77
|
"workbox-webpack-plugin": "^6.5.4"
|
|
78
78
|
},
|
|
79
|
-
"gitHead": "
|
|
79
|
+
"gitHead": "4d40b64882d1b9866d70ebe6a239d7d018b0cd18"
|
|
80
80
|
}
|
|
@@ -10,6 +10,7 @@ import {
|
|
|
10
10
|
selectCellBonus,
|
|
11
11
|
selectCellIsFiltered,
|
|
12
12
|
selectCellIsValid,
|
|
13
|
+
selectLocale,
|
|
13
14
|
selectTilePoints,
|
|
14
15
|
useTranslate,
|
|
15
16
|
useTypedSelector,
|
|
@@ -47,6 +48,7 @@ const Cell: FunctionComponent<Props> = ({
|
|
|
47
48
|
const { tile, x, y } = cell;
|
|
48
49
|
const dispatch = useDispatch();
|
|
49
50
|
const translate = useTranslate();
|
|
51
|
+
const locale = useTypedSelector(selectLocale);
|
|
50
52
|
const bonus = useTypedSelector((state) => selectCellBonus(state, cell));
|
|
51
53
|
const points = useTypedSelector((state) => selectTilePoints(state, cell.tile));
|
|
52
54
|
const isFiltered = useTypedSelector((state) => selectCellIsFiltered(state, cell));
|
|
@@ -83,6 +85,10 @@ const Cell: FunctionComponent<Props> = ({
|
|
|
83
85
|
|
|
84
86
|
return (
|
|
85
87
|
<CellPure
|
|
88
|
+
aria-label={translate('cell.tile.location', {
|
|
89
|
+
x: (x + 1).toLocaleString(locale),
|
|
90
|
+
y: (y + 1).toLocaleString(locale),
|
|
91
|
+
})}
|
|
86
92
|
bonus={bonus}
|
|
87
93
|
cell={cell}
|
|
88
94
|
className={className}
|
|
@@ -20,6 +20,7 @@ import styles from './Cell.module.scss';
|
|
|
20
20
|
import { getBonusClassname } from './lib';
|
|
21
21
|
|
|
22
22
|
interface Props {
|
|
23
|
+
'aria-label': string;
|
|
23
24
|
bonus: Bonus | undefined;
|
|
24
25
|
cell: Cell;
|
|
25
26
|
className?: string;
|
|
@@ -44,6 +45,7 @@ interface Props {
|
|
|
44
45
|
}
|
|
45
46
|
|
|
46
47
|
const CellPure: FunctionComponent<Props> = ({
|
|
48
|
+
'aria-label': ariaLabel,
|
|
47
49
|
bonus,
|
|
48
50
|
cell,
|
|
49
51
|
className,
|
|
@@ -87,6 +89,7 @@ const CellPure: FunctionComponent<Props> = ({
|
|
|
87
89
|
)}
|
|
88
90
|
|
|
89
91
|
<Tile
|
|
92
|
+
aria-label={ariaLabel}
|
|
90
93
|
className={styles.tile}
|
|
91
94
|
character={isEmpty ? undefined : tile.character}
|
|
92
95
|
highlighted={cell.isCandidate()}
|
|
@@ -103,7 +106,11 @@ const CellPure: FunctionComponent<Props> = ({
|
|
|
103
106
|
|
|
104
107
|
{!cell.isCandidate() && (
|
|
105
108
|
<div className={styles.actions}>
|
|
106
|
-
<Button
|
|
109
|
+
<Button
|
|
110
|
+
aria-label={translate('cell.toggle-direction')}
|
|
111
|
+
tooltip={translate('cell.toggle-direction')}
|
|
112
|
+
onClick={onDirectionToggleClick}
|
|
113
|
+
>
|
|
107
114
|
<ArrowDown
|
|
108
115
|
className={classNames(styles.toggleDirection, {
|
|
109
116
|
[styles.right]: direction === 'horizontal',
|
|
@@ -113,6 +120,7 @@ const CellPure: FunctionComponent<Props> = ({
|
|
|
113
120
|
|
|
114
121
|
{isEmpty && (
|
|
115
122
|
<Button
|
|
123
|
+
aria-label={translate('cell.filter-cell')}
|
|
116
124
|
className={classNames(styles.filterCell, {
|
|
117
125
|
[styles.filtered]: isFiltered,
|
|
118
126
|
})}
|
|
@@ -125,6 +133,7 @@ const CellPure: FunctionComponent<Props> = ({
|
|
|
125
133
|
|
|
126
134
|
{!isEmpty && (
|
|
127
135
|
<Button
|
|
136
|
+
aria-label={tile.isBlank ? translate('cell.set-not-blank') : translate('cell.set-blank')}
|
|
128
137
|
className={classNames(styles.blank, {
|
|
129
138
|
[styles.active]: tile.isBlank,
|
|
130
139
|
})}
|
|
@@ -8,7 +8,6 @@
|
|
|
8
8
|
padding: var(--spacing--m) var(--spacing--l);
|
|
9
9
|
border: var(--border);
|
|
10
10
|
border-radius: var(--border--radius);
|
|
11
|
-
color: var(--color--inactive);
|
|
12
11
|
text-transform: uppercase;
|
|
13
12
|
transition: var(--transition);
|
|
14
13
|
cursor: pointer;
|
|
@@ -37,7 +36,7 @@
|
|
|
37
36
|
|
|
38
37
|
&:focus,
|
|
39
38
|
&:hover {
|
|
40
|
-
&.default {
|
|
39
|
+
&.default:not(:disabled) {
|
|
41
40
|
.icon {
|
|
42
41
|
color: var(--color--foreground--secondary);
|
|
43
42
|
}
|
|
@@ -54,9 +53,7 @@
|
|
|
54
53
|
}
|
|
55
54
|
|
|
56
55
|
&[disabled] {
|
|
57
|
-
|
|
58
|
-
box-shadow: none;
|
|
59
|
-
cursor: not-allowed;
|
|
56
|
+
@include disabled;
|
|
60
57
|
}
|
|
61
58
|
}
|
|
62
59
|
|
|
@@ -7,6 +7,7 @@ import styles from './Button.module.scss';
|
|
|
7
7
|
import Link from './Link';
|
|
8
8
|
|
|
9
9
|
interface Props extends ButtonHTMLAttributes<HTMLButtonElement> {
|
|
10
|
+
'aria-label': string;
|
|
10
11
|
Icon?: FunctionComponent<SVGAttributes<SVGElement>>;
|
|
11
12
|
iconClassName?: string;
|
|
12
13
|
tooltip?: ReactNode;
|
|
@@ -6,6 +6,7 @@ import { useTooltip } from '../Tooltip';
|
|
|
6
6
|
import styles from './Button.module.scss';
|
|
7
7
|
|
|
8
8
|
interface Props extends AnchorHTMLAttributes<HTMLAnchorElement> {
|
|
9
|
+
'aria-label': string;
|
|
9
10
|
href: string;
|
|
10
11
|
Icon: FunctionComponent<SVGAttributes<SVGElement>>;
|
|
11
12
|
iconClassName?: string;
|
package/src/components/{SquareButton/SquareButton.module.scss → IconButton/IconButton.module.scss}
RENAMED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
@import 'styles/mixins';
|
|
2
2
|
|
|
3
|
-
.
|
|
3
|
+
.iconButton {
|
|
4
4
|
@include button-reset;
|
|
5
5
|
@include focus-effect;
|
|
6
6
|
|
|
@@ -20,8 +20,7 @@
|
|
|
20
20
|
}
|
|
21
21
|
|
|
22
22
|
&[disabled] {
|
|
23
|
-
|
|
24
|
-
opacity: var(--opacity--disabled);
|
|
23
|
+
@include disabled;
|
|
25
24
|
}
|
|
26
25
|
}
|
|
27
26
|
|
|
@@ -1,23 +1,24 @@
|
|
|
1
1
|
import classNames from 'classnames';
|
|
2
|
-
import { ButtonHTMLAttributes, FunctionComponent, MouseEventHandler,
|
|
2
|
+
import { ButtonHTMLAttributes, FunctionComponent, MouseEventHandler, SVGAttributes } from 'react';
|
|
3
3
|
|
|
4
4
|
import { useTooltip } from '../Tooltip';
|
|
5
5
|
|
|
6
|
+
import styles from './IconButton.module.scss';
|
|
6
7
|
import Link from './Link';
|
|
7
|
-
import styles from './SquareButton.module.scss';
|
|
8
8
|
|
|
9
9
|
interface Props extends ButtonHTMLAttributes<HTMLButtonElement> {
|
|
10
|
+
'aria-label': string;
|
|
10
11
|
children?: never;
|
|
11
12
|
Icon: FunctionComponent<SVGAttributes<SVGElement>>;
|
|
12
|
-
tooltip:
|
|
13
|
+
tooltip: string;
|
|
13
14
|
onClick: MouseEventHandler<HTMLButtonElement>;
|
|
14
15
|
}
|
|
15
16
|
|
|
16
|
-
const
|
|
17
|
+
const IconButton: FunctionComponent<Props> = ({ className, Icon, tooltip, ...props }) => {
|
|
17
18
|
const triggerProps = useTooltip(tooltip, props);
|
|
18
19
|
|
|
19
20
|
return (
|
|
20
|
-
<button className={classNames(styles.
|
|
21
|
+
<button className={classNames(styles.iconButton, className)} type="button" {...props} {...triggerProps}>
|
|
21
22
|
<span className={styles.content}>
|
|
22
23
|
<Icon className={styles.icon} />
|
|
23
24
|
</span>
|
|
@@ -25,6 +26,6 @@ const SquareButton: FunctionComponent<Props> = ({ className, Icon, tooltip, ...p
|
|
|
25
26
|
);
|
|
26
27
|
};
|
|
27
28
|
|
|
28
|
-
export default Object.assign(
|
|
29
|
+
export default Object.assign(IconButton, {
|
|
29
30
|
Link,
|
|
30
31
|
});
|
|
@@ -3,9 +3,10 @@ import { AnchorHTMLAttributes, FunctionComponent, SVGAttributes } from 'react';
|
|
|
3
3
|
|
|
4
4
|
import { useTooltip } from '../Tooltip';
|
|
5
5
|
|
|
6
|
-
import styles from './
|
|
6
|
+
import styles from './IconButton.module.scss';
|
|
7
7
|
|
|
8
8
|
interface Props extends AnchorHTMLAttributes<HTMLAnchorElement> {
|
|
9
|
+
'aria-label': string;
|
|
9
10
|
children?: never;
|
|
10
11
|
href: string;
|
|
11
12
|
Icon: FunctionComponent<SVGAttributes<SVGElement>>;
|
|
@@ -16,7 +17,7 @@ const Link: FunctionComponent<Props> = ({ className, Icon, tooltip, ...props })
|
|
|
16
17
|
const triggerProps = useTooltip(tooltip, props);
|
|
17
18
|
|
|
18
19
|
return (
|
|
19
|
-
<a className={classNames(styles.
|
|
20
|
+
<a className={classNames(styles.iconButton, className)} {...props} {...triggerProps}>
|
|
20
21
|
<span className={styles.content}>
|
|
21
22
|
<Icon className={styles.icon} />
|
|
22
23
|
</span>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from './IconButton';
|
|
@@ -1,62 +1,91 @@
|
|
|
1
1
|
<svg viewBox="0 0 682 166" xmlns="http://www.w3.org/2000/svg" xmlns:svg="http://www.w3.org/2000/svg">
|
|
2
|
+
<!-- S -->
|
|
2
3
|
<g transform="rotate(0, 40, 40)">
|
|
3
4
|
<path fill="#efe3ae" d="M 0,0 H 80 V 80 H 0 Z" />
|
|
4
|
-
<path
|
|
5
|
+
<path d="m 51.167969,47.628907 q 0,3.046875 -1.476563,5.296875 -1.476562,2.25 -4.3125,3.46875 -2.8125,1.21875 -6.84375,1.21875 -1.78125,0 -3.492187,-0.234375 -1.6875,-0.234375 -3.257813,-0.679687 -1.546875,-0.46875 -2.953125,-1.148438 v -6.75 q 2.4375,1.078125 5.0625,1.945313 2.625,0.867187 5.203125,0.867187 1.78125,0 2.859375,-0.46875 1.101563,-0.46875 1.59375,-1.289062 0.492188,-0.820313 0.492188,-1.875 0,-1.289063 -0.867188,-2.203125 -0.867187,-0.914063 -2.390625,-1.710938 -1.5,-0.796875 -3.398437,-1.710937 -1.195313,-0.5625 -2.601563,-1.359375 -1.40625,-0.820313 -2.671875,-1.992188 -1.265625,-1.171875 -2.085937,-2.835937 -0.796875,-1.6875 -0.796875,-4.03125 0,-3.070313 1.40625,-5.25 1.40625,-2.179688 4.007812,-3.328125 2.625,-1.171875 6.1875,-1.171875 2.671875,0 5.085938,0.632812 2.4375,0.609375 5.085937,1.78125 l -2.34375,5.648438 q -2.367187,-0.960938 -4.242187,-1.476563 -1.875,-0.539062 -3.820313,-0.539062 -1.359375,0 -2.320312,0.445312 -0.960938,0.421875 -1.453125,1.21875 -0.492188,0.773438 -0.492188,1.804688 0,1.21875 0.703125,2.0625 0.726563,0.820312 2.15625,1.59375 1.453125,0.773437 3.609375,1.804687 2.625,1.242188 4.476563,2.601563 1.875,1.335937 2.882812,3.164062 1.007813,1.804688 1.007813,4.5 z" />
|
|
5
6
|
</g>
|
|
7
|
+
|
|
8
|
+
<!-- C -->
|
|
6
9
|
<g transform="rotate(0, 126, 40)">
|
|
7
10
|
<path fill="#c7d8f9" d="m 86,0 h 80 V 80 H 86 Z" />
|
|
8
|
-
<path
|
|
11
|
+
<path d="m 129.57422,28.433595 q -2.08594,0 -3.70313,0.820312 -1.59375,0.796875 -2.69531,2.320313 -1.07812,1.523437 -1.64062,3.679687 -0.5625,2.15625 -0.5625,4.851563 0,3.632812 0.89062,6.210937 0.91406,2.554688 2.8125,3.914063 1.89844,1.335937 4.89844,1.335937 2.08594,0 4.17187,-0.46875 2.10938,-0.46875 4.57032,-1.335937 v 6.09375 q -2.27344,0.9375 -4.47657,1.335937 -2.20312,0.421875 -4.94531,0.421875 -5.29687,0 -8.71875,-2.179687 -3.39844,-2.203125 -5.03906,-6.140625 -1.64063,-3.960938 -1.64063,-9.234375 0,-3.890625 1.05469,-7.125 1.05469,-3.234375 3.09375,-5.601563 2.03906,-2.367187 5.03906,-3.65625 3,-1.289062 6.89063,-1.289062 2.55469,0 5.10937,0.65625 2.57813,0.632812 4.92188,1.757812 l -2.34375,5.90625 q -1.92188,-0.914062 -3.86719,-1.59375 -1.94531,-0.679687 -3.82031,-0.679687 z" />
|
|
9
12
|
</g>
|
|
13
|
+
|
|
14
|
+
<!-- R -->
|
|
10
15
|
<g transform="rotate(0, 212, 40)">
|
|
11
16
|
<path fill="#efe3ae" d="m 172,0 h 80 v 80 h -80 z" />
|
|
12
|
-
<path
|
|
17
|
+
<path d="m 210.45312,22.867188 q 4.66407,0 7.6875,1.125 3.04688,1.125 4.52344,3.398438 1.47656,2.273437 1.47656,5.742187 0,2.34375 -0.89062,4.101563 -0.89063,1.757812 -2.34375,2.976562 -1.45313,1.21875 -3.14063,1.992188 l 10.07813,14.929687 h -8.0625 l -8.17969,-13.148437 h -3.86719 v 13.148437 h -7.26562 V 22.867188 Z m -0.51562,5.953125 h -2.20313 v 9.257813 h 2.34375 q 3.60938,0 5.15625,-1.195313 1.57032,-1.21875 1.57032,-3.5625 0,-2.4375 -1.6875,-3.46875 -1.66407,-1.03125 -5.17969,-1.03125 z" />
|
|
13
18
|
</g>
|
|
19
|
+
|
|
20
|
+
<!-- A -->
|
|
14
21
|
<g transform="rotate(0, 298, 40)">
|
|
15
22
|
<path fill="#efe3ae" d="m 258,0 h 80 v 80 h -80 z" />
|
|
16
|
-
<path
|
|
23
|
+
<path d="m 306.73047,57.203126 -2.48438,-8.15625 h -12.49218 l -2.48438,8.15625 h -7.82812 l 12.09375,-34.40625 h 8.88281 l 12.14062,34.40625 z m -4.21875,-14.25 -2.48438,-7.96875 q -0.23437,-0.796875 -0.63281,-2.039063 -0.375,-1.265625 -0.77344,-2.554687 -0.375,-1.3125 -0.60937,-2.273438 -0.23438,0.960938 -0.65625,2.390625 -0.39844,1.40625 -0.77344,2.671875 -0.375,1.265625 -0.53906,1.804688 l -2.46094,7.96875 z" />
|
|
17
24
|
</g>
|
|
25
|
+
|
|
26
|
+
<!-- B -->
|
|
18
27
|
<g transform="rotate(0, 384, 40)">
|
|
19
28
|
<path fill="#c7d8f9" d="m 344,0 h 80 v 80 h -80 z" />
|
|
20
|
-
<path
|
|
29
|
+
<path d="m 372.1875,22.867188 h 10.66406 q 6.84375,0 10.35938,1.921875 3.51562,1.921875 3.51562,6.75 0,1.945313 -0.63281,3.515625 -0.60938,1.570313 -1.78125,2.578125 -1.17188,1.007813 -2.85938,1.3125 v 0.234375 q 1.71094,0.351563 3.09375,1.21875 1.38282,0.84375 2.20313,2.484375 0.84375,1.617188 0.84375,4.3125 0,3.117188 -1.52344,5.34375 -1.52344,2.226563 -4.35937,3.421875 -2.8125,1.171875 -6.70313,1.171875 H 372.1875 Z m 7.26562,13.570313 h 4.21875 q 3.16407,0 4.38282,-0.984375 1.21875,-1.007813 1.21875,-2.953125 0,-1.96875 -1.45313,-2.8125 -1.42969,-0.867188 -4.54687,-0.867188 h -3.82032 z m 0,5.765625 v 8.929687 h 4.73438 q 3.28125,0 4.57031,-1.265625 1.28906,-1.265625 1.28906,-3.398437 0,-1.265625 -0.5625,-2.226563 -0.5625,-0.960937 -1.89843,-1.5 -1.3125,-0.539062 -3.63282,-0.539062 z" />
|
|
21
30
|
</g>
|
|
31
|
+
|
|
32
|
+
<!-- B -->
|
|
22
33
|
<g transform="rotate(0, 470, 40)">
|
|
23
34
|
<path fill="#c7d8f9" d="m 430,0 h 80 v 80 h -80 z" />
|
|
24
|
-
<path
|
|
35
|
+
<path d="m 458.1875,22.867188 h 10.66406 q 6.84375,0 10.35938,1.921875 3.51562,1.921875 3.51562,6.75 0,1.945313 -0.63281,3.515625 -0.60938,1.570313 -1.78125,2.578125 -1.17188,1.007813 -2.85938,1.3125 v 0.234375 q 1.71094,0.351563 3.09375,1.21875 1.38282,0.84375 2.20313,2.484375 0.84375,1.617188 0.84375,4.3125 0,3.117188 -1.52344,5.34375 -1.52344,2.226563 -4.35937,3.421875 -2.8125,1.171875 -6.70313,1.171875 H 458.1875 Z m 7.26562,13.570313 h 4.21875 q 3.16407,0 4.38282,-0.984375 1.21875,-1.007813 1.21875,-2.953125 0,-1.96875 -1.45313,-2.8125 -1.42969,-0.867188 -4.54687,-0.867188 h -3.82032 z m 0,5.765625 v 8.929687 h 4.73438 q 3.28125,0 4.57031,-1.265625 1.28906,-1.265625 1.28906,-3.398437 0,-1.265625 -0.5625,-2.226563 -0.5625,-0.960937 -1.89843,-1.5 -1.3125,-0.539062 -3.63282,-0.539062 z" />
|
|
25
36
|
</g>
|
|
37
|
+
|
|
38
|
+
<!-- L -->
|
|
26
39
|
<g transform="rotate(0, 556, 40)">
|
|
27
40
|
<path fill="#efe3ae" d="m 516,0 h 80 v 80 h -80 z" />
|
|
28
|
-
<path
|
|
41
|
+
<path d="M 546.75391,57.132813 V 22.867188 h 7.26562 v 28.265625 h 13.89844 v 6 z" />
|
|
29
42
|
</g>
|
|
43
|
+
|
|
44
|
+
<!-- E -->
|
|
30
45
|
<g transform="rotate(0, 642, 40)">
|
|
31
46
|
<path fill="#efe3ae" d="m 602,0 h 80 v 80 h -80 z" />
|
|
32
|
-
<path
|
|
47
|
+
<path d="M 652.60547,57.132813 H 632.87109 V 22.867188 h 19.73438 v 5.953125 h -12.46875 v 7.523438 h 11.60156 v 5.953125 h -11.60156 v 8.835937 h 12.46875 z" />
|
|
33
48
|
</g>
|
|
49
|
+
|
|
50
|
+
<!-- S -->
|
|
34
51
|
<g transform="rotate(0, 40, 40)">
|
|
35
52
|
<path fill="#efe3ae" d="m 0,86 h 80 v 80 H 0 Z" />
|
|
36
|
-
<path
|
|
53
|
+
<path d="m 51.320312,133.6289 q 0,3.04688 -1.476562,5.29688 -1.476563,2.25 -4.3125,3.46875 -2.8125,1.21875 -6.84375,1.21875 -1.78125,0 -3.492188,-0.23438 -1.6875,-0.23437 -3.257812,-0.67968 -1.546875,-0.46875 -2.953125,-1.14844 v -6.75 q 2.4375,1.07812 5.0625,1.94531 2.625,0.86719 5.203125,0.86719 1.78125,0 2.859375,-0.46875 1.101562,-0.46875 1.59375,-1.28906 0.492187,-0.82032 0.492187,-1.875 0,-1.28907 -0.867187,-2.20313 -0.867188,-0.91406 -2.390625,-1.71094 -1.5,-0.79687 -3.398438,-1.71093 -1.195312,-0.5625 -2.601562,-1.35938 -1.40625,-0.82031 -2.671875,-1.99219 Q 31,123.83203 30.179687,122.16797 q -0.796875,-1.6875 -0.796875,-4.03125 0,-3.07032 1.40625,-5.25 1.40625,-2.17969 4.007813,-3.32813 2.625,-1.17187 6.1875,-1.17187 2.671875,0 5.085937,0.63281 2.4375,0.60937 5.085938,1.78125 l -2.34375,5.64844 q -2.367188,-0.96094 -4.242188,-1.47657 -1.875,-0.53906 -3.820312,-0.53906 -1.359375,0 -2.320313,0.44531 -0.960937,0.42188 -1.453125,1.21875 -0.492187,0.77344 -0.492187,1.80469 0,1.21875 0.703125,2.0625 0.726562,0.82031 2.15625,1.59375 1.453125,0.77344 3.609375,1.80469 2.625,1.24219 4.476562,2.60156 1.875,1.33594 2.882813,3.16406 1.007812,1.80469 1.007812,4.5 z" />
|
|
37
54
|
</g>
|
|
55
|
+
|
|
56
|
+
<!-- O -->
|
|
38
57
|
<g transform="rotate(0, 126, 40)">
|
|
39
58
|
<path fill="#efe3ae" d="m 86,86 h 80 v 80 H 86 Z" />
|
|
40
|
-
<path
|
|
59
|
+
<path d="m 142.3125,125.98828 q 0,3.96094 -0.98438,7.21875 -0.98437,3.23437 -3,5.57812 -1.99218,2.34375 -5.0625,3.60938 -3.07031,1.24219 -7.26562,1.24219 -4.19531,0 -7.26562,-1.24219 -3.07032,-1.26563 -5.08594,-3.60938 -1.99219,-2.34375 -2.97656,-5.60156 -0.98438,-3.25781 -0.98438,-7.24219 0,-5.32031 1.73438,-9.25781 1.75781,-3.96094 5.39062,-6.14062 3.63281,-2.17969 9.23438,-2.17969 5.57812,0 9.16406,2.17969 3.60937,2.17968 5.34375,6.14062 1.75781,3.96094 1.75781,9.30469 z m -25.00781,0 q 0,3.58594 0.89062,6.1875 0.91407,2.57812 2.83594,3.98437 1.92188,1.38282 4.96875,1.38282 3.09375,0 5.01562,-1.38282 1.92188,-1.40625 2.78907,-3.98437 0.89062,-2.60156 0.89062,-6.1875 0,-5.39063 -2.01562,-8.48438 -2.01563,-3.09375 -6.63281,-3.09375 -3.07032,0 -5.01563,1.40625 -1.92187,1.38282 -2.83594,3.98438 -0.89062,2.57812 -0.89062,6.1875 z" />
|
|
41
60
|
</g>
|
|
61
|
+
|
|
62
|
+
<!-- L -->
|
|
42
63
|
<g transform="rotate(0, 212, 40)">
|
|
43
64
|
<path fill="#efe3ae" d="m 172,86 h 80 v 80 h -80 z" />
|
|
44
|
-
<path
|
|
65
|
+
<path d="m 202.75391,143.13281 v -34.26563 h 7.26562 v 28.26563 h 13.89844 v 6 z" />
|
|
45
66
|
</g>
|
|
67
|
+
|
|
68
|
+
<!-- V -->
|
|
46
69
|
<g transform="rotate(0, 298, 40)">
|
|
47
70
|
<path fill="#f7c2aa" d="m 258,86 h 80 v 80 h -80 z" />
|
|
48
|
-
<path
|
|
71
|
+
<path d="m 313.59766,108.86718 -11.64844,34.26563 h -7.92188 l -11.625,-34.26563 h 7.33594 l 6.44531,20.39063 q 0.16407,0.51562 0.53907,1.94531 0.375,1.40625 0.75,3 0.39843,1.57031 0.53906,2.60156 0.14062,-1.03125 0.49219,-2.60156 0.375,-1.57031 0.72656,-2.97656 0.375,-1.42969 0.53906,-1.96875 l 6.49219,-20.39063 z" />
|
|
49
72
|
</g>
|
|
73
|
+
|
|
74
|
+
<!-- E -->
|
|
50
75
|
<g transform="rotate(0, 384, 40)">
|
|
51
76
|
<path fill="#efe3ae" d="m 344,86 h 80 v 80 h -80 z" />
|
|
52
|
-
<path
|
|
77
|
+
<path d="m 394.60547,143.13281 h -19.73438 v -34.26563 h 19.73438 v 5.95313 h -12.46875 v 7.52344 h 11.60156 v 5.95312 h -11.60156 v 8.83594 h 12.46875 z" />
|
|
53
78
|
</g>
|
|
79
|
+
|
|
80
|
+
<!-- R -->
|
|
54
81
|
<g transform="rotate(0, 470, 40)">
|
|
55
82
|
<path fill="#efe3ae" d="m 430,86 h 80 v 80 h -80 z" />
|
|
56
|
-
<path
|
|
83
|
+
<path d="m 468.45312,108.86718 q 4.66407,0 7.6875,1.125 3.04688,1.125 4.52344,3.39844 1.47656,2.27344 1.47656,5.74219 0,2.34375 -0.89062,4.10156 -0.89063,1.75781 -2.34375,2.97656 -1.45313,1.21875 -3.14063,1.99219 l 10.07813,14.92969 h -8.0625 l -8.17969,-13.14844 h -3.86719 v 13.14844 h -7.26562 v -34.26563 z m -0.51562,5.95313 h -2.20313 v 9.25781 h 2.34375 q 3.60938,0 5.15625,-1.19531 1.57032,-1.21875 1.57032,-3.5625 0,-2.4375 -1.6875,-3.46875 -1.66407,-1.03125 -5.17969,-1.03125 z" />
|
|
57
84
|
</g>
|
|
85
|
+
|
|
86
|
+
<!-- 2 -->
|
|
58
87
|
<g transform="rotate(0, 642, 40)">
|
|
59
88
|
<path fill="#bae3ba" d="m 602,86 h 80 v 80 h -80 z" />
|
|
60
|
-
<path
|
|
89
|
+
<path d="m 654.15234,143.3789 h -23.95312 v -5.03906 l 8.60156,-8.69531 q 2.60156,-2.67188 4.17188,-4.45313 1.59375,-1.80468 2.29687,-3.28125 0.72656,-1.47656 0.72656,-3.16406 0,-2.03906 -1.14843,-3.04687 -1.125,-1.03125 -3.02344,-1.03125 -1.99219,0 -3.86719,0.91406 -1.875,0.91406 -3.91406,2.60156 l -3.9375,-4.66406 q 1.47656,-1.26563 3.11719,-2.39063 1.66406,-1.125 3.84375,-1.80468 2.20312,-0.70313 5.27343,-0.70313 3.375,0 5.78907,1.21875 2.4375,1.21875 3.75,3.32813 1.3125,2.08593 1.3125,4.73437 0,2.83594 -1.125,5.17969 -1.125,2.34375 -3.28125,4.64062 -2.13282,2.29688 -5.15625,5.08594 l -4.40625,4.14844 v 0.32812 h 14.92968 z" />
|
|
61
90
|
</g>
|
|
62
91
|
</svg>
|
|
@@ -7,7 +7,7 @@ import { CrossSquareFill } from 'icons';
|
|
|
7
7
|
import { TRANSITION_DURATION_LONG } from 'parameters';
|
|
8
8
|
import { useTranslate } from 'state';
|
|
9
9
|
|
|
10
|
-
import
|
|
10
|
+
import IconButton from '../IconButton';
|
|
11
11
|
|
|
12
12
|
import { Section } from './components';
|
|
13
13
|
import styles from './Modal.module.scss';
|
|
@@ -58,7 +58,8 @@ const Modal: FunctionComponent<Props> = ({ children, className, isOpen, title, o
|
|
|
58
58
|
<div className={styles.header}>
|
|
59
59
|
<h1 className={styles.title}>{title}</h1>
|
|
60
60
|
|
|
61
|
-
<
|
|
61
|
+
<IconButton
|
|
62
|
+
aria-label={translate('common.close')}
|
|
62
63
|
className={styles.closeButton}
|
|
63
64
|
Icon={CrossSquareFill}
|
|
64
65
|
tooltip={translate('common.close')}
|
|
@@ -6,7 +6,7 @@ import { CardChecklist, Cog, Eraser, Github, Keyboard, List, Sack } from 'icons'
|
|
|
6
6
|
import { GITHUB_PROJECT_URL } from 'parameters';
|
|
7
7
|
import { selectHasInvalidWords, selectHasOverusedTiles, useTranslate, useTypedSelector } from 'state';
|
|
8
8
|
|
|
9
|
-
import
|
|
9
|
+
import IconButton from '../IconButton';
|
|
10
10
|
|
|
11
11
|
import styles from './NavButtons.module.scss';
|
|
12
12
|
|
|
@@ -37,13 +37,25 @@ const NavButtons: FunctionComponent<Props> = ({
|
|
|
37
37
|
return (
|
|
38
38
|
<div className={styles.navButtons}>
|
|
39
39
|
<div className={styles.group}>
|
|
40
|
-
<
|
|
40
|
+
<IconButton
|
|
41
|
+
aria-label={translate('common.clear')}
|
|
42
|
+
className={styles.button}
|
|
43
|
+
Icon={Eraser}
|
|
44
|
+
tooltip={translate('common.clear')}
|
|
45
|
+
onClick={onClear}
|
|
46
|
+
/>
|
|
41
47
|
</div>
|
|
42
48
|
|
|
43
49
|
<div className={styles.separator} />
|
|
44
50
|
|
|
45
51
|
<div className={styles.group}>
|
|
46
|
-
<
|
|
52
|
+
<IconButton
|
|
53
|
+
aria-label={translate('menu')}
|
|
54
|
+
className={styles.button}
|
|
55
|
+
Icon={List}
|
|
56
|
+
tooltip={translate('menu')}
|
|
57
|
+
onClick={onShowMenu}
|
|
58
|
+
/>
|
|
47
59
|
</div>
|
|
48
60
|
</div>
|
|
49
61
|
);
|
|
@@ -52,13 +64,20 @@ const NavButtons: FunctionComponent<Props> = ({
|
|
|
52
64
|
return (
|
|
53
65
|
<div className={styles.navButtons}>
|
|
54
66
|
<div className={styles.group}>
|
|
55
|
-
<
|
|
67
|
+
<IconButton
|
|
68
|
+
aria-label={translate('common.clear')}
|
|
69
|
+
className={styles.button}
|
|
70
|
+
Icon={Eraser}
|
|
71
|
+
tooltip={translate('common.clear')}
|
|
72
|
+
onClick={onClear}
|
|
73
|
+
/>
|
|
56
74
|
</div>
|
|
57
75
|
|
|
58
76
|
<div className={styles.separator} />
|
|
59
77
|
|
|
60
78
|
<div className={styles.group}>
|
|
61
|
-
<
|
|
79
|
+
<IconButton
|
|
80
|
+
aria-label={translate('remaining-tiles')}
|
|
62
81
|
className={classNames(styles.button, {
|
|
63
82
|
[styles.error]: hasOverusedTiles,
|
|
64
83
|
})}
|
|
@@ -67,7 +86,8 @@ const NavButtons: FunctionComponent<Props> = ({
|
|
|
67
86
|
onClick={onShowRemainingTiles}
|
|
68
87
|
/>
|
|
69
88
|
|
|
70
|
-
<
|
|
89
|
+
<IconButton
|
|
90
|
+
aria-label={translate('words')}
|
|
71
91
|
className={classNames(styles.button, {
|
|
72
92
|
[styles.error]: hasInvalidWords,
|
|
73
93
|
})}
|
|
@@ -80,7 +100,8 @@ const NavButtons: FunctionComponent<Props> = ({
|
|
|
80
100
|
<div className={styles.separator} />
|
|
81
101
|
|
|
82
102
|
<div className={styles.group}>
|
|
83
|
-
<
|
|
103
|
+
<IconButton.Link
|
|
104
|
+
aria-label={translate('github')}
|
|
84
105
|
className={styles.button}
|
|
85
106
|
href={GITHUB_PROJECT_URL}
|
|
86
107
|
Icon={Github}
|
|
@@ -94,7 +115,8 @@ const NavButtons: FunctionComponent<Props> = ({
|
|
|
94
115
|
|
|
95
116
|
<div className={styles.group}>
|
|
96
117
|
{!isTouchDevice && (
|
|
97
|
-
<
|
|
118
|
+
<IconButton
|
|
119
|
+
aria-label={translate('keyMap')}
|
|
98
120
|
className={styles.button}
|
|
99
121
|
Icon={Keyboard}
|
|
100
122
|
tooltip={translate('keyMap')}
|
|
@@ -102,7 +124,13 @@ const NavButtons: FunctionComponent<Props> = ({
|
|
|
102
124
|
/>
|
|
103
125
|
)}
|
|
104
126
|
|
|
105
|
-
<
|
|
127
|
+
<IconButton
|
|
128
|
+
aria-label={translate('settings')}
|
|
129
|
+
className={styles.button}
|
|
130
|
+
Icon={Cog}
|
|
131
|
+
tooltip={translate('settings')}
|
|
132
|
+
onClick={onShowSettings}
|
|
133
|
+
/>
|
|
106
134
|
</div>
|
|
107
135
|
</div>
|
|
108
136
|
);
|
|
@@ -18,6 +18,7 @@ import {
|
|
|
18
18
|
selectCharacterIsValid,
|
|
19
19
|
selectCharacterPoints,
|
|
20
20
|
selectConfig,
|
|
21
|
+
selectLocale,
|
|
21
22
|
useTranslate,
|
|
22
23
|
useTypedSelector,
|
|
23
24
|
} from 'state';
|
|
@@ -49,6 +50,7 @@ const RackTile: FunctionComponent<Props> = ({
|
|
|
49
50
|
}) => {
|
|
50
51
|
const dispatch = useDispatch();
|
|
51
52
|
const translate = useTranslate();
|
|
53
|
+
const locale = useTypedSelector(selectLocale);
|
|
52
54
|
const config = useTypedSelector(selectConfig);
|
|
53
55
|
const points = useTypedSelector((state) => selectCharacterPoints(state, character));
|
|
54
56
|
const isValid = useTypedSelector((state) => selectCharacterIsValid(state, character));
|
|
@@ -91,6 +93,9 @@ const RackTile: FunctionComponent<Props> = ({
|
|
|
91
93
|
|
|
92
94
|
return (
|
|
93
95
|
<Tile
|
|
96
|
+
aria-label={translate('rack.tile.location', {
|
|
97
|
+
index: (index + 1).toLocaleString(locale),
|
|
98
|
+
})}
|
|
94
99
|
autoFocus={index === 0}
|
|
95
100
|
className={styles.tile}
|
|
96
101
|
character={character === null ? undefined : character}
|
|
@@ -47,6 +47,10 @@
|
|
|
47
47
|
margin: 0 auto;
|
|
48
48
|
}
|
|
49
49
|
|
|
50
|
+
.submitInput {
|
|
51
|
+
display: none;
|
|
52
|
+
}
|
|
53
|
+
|
|
50
54
|
.column {
|
|
51
55
|
display: flex;
|
|
52
56
|
flex-direction: column;
|
|
@@ -58,6 +62,11 @@
|
|
|
58
62
|
}
|
|
59
63
|
}
|
|
60
64
|
|
|
65
|
+
.resultsContainer {
|
|
66
|
+
flex: 1;
|
|
67
|
+
position: relative;
|
|
68
|
+
}
|
|
69
|
+
|
|
61
70
|
.dictionary {
|
|
62
71
|
display: flex;
|
|
63
72
|
flex-direction: column;
|
|
@@ -72,11 +81,6 @@
|
|
|
72
81
|
flex: 0 0 auto;
|
|
73
82
|
}
|
|
74
83
|
|
|
75
|
-
.resultsContainer {
|
|
76
|
-
flex: 1;
|
|
77
|
-
position: relative;
|
|
78
|
-
}
|
|
79
|
-
|
|
80
84
|
.bottomContainer {
|
|
81
85
|
flex: 0 0 auto;
|
|
82
86
|
display: flex;
|
|
@@ -101,24 +105,12 @@
|
|
|
101
105
|
border: var(--border);
|
|
102
106
|
}
|
|
103
107
|
|
|
104
|
-
.submitInput {
|
|
105
|
-
display: none;
|
|
106
|
-
}
|
|
107
|
-
|
|
108
108
|
.controls {
|
|
109
109
|
width: 100%;
|
|
110
|
-
display: flex;
|
|
111
|
-
align-items: flex-start;
|
|
112
|
-
justify-content: center;
|
|
113
|
-
gap: var(--spacing--l);
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
.resultCandidatePicker {
|
|
117
|
-
flex: 1;
|
|
118
110
|
}
|
|
119
111
|
|
|
120
|
-
.
|
|
121
|
-
|
|
112
|
+
.emptyState {
|
|
113
|
+
margin-top: var(--spacing);
|
|
122
114
|
}
|
|
123
115
|
|
|
124
116
|
.solve {
|