@scrabble-solver/scrabble-solver 2.15.4 → 2.15.5
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 +5 -5
- package/.next/cache/.rscinfo +1 -1
- package/.next/cache/.tsbuildinfo +1 -1
- package/.next/cache/eslint/.cache_8dgz12 +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/client-production/index.pack.old +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/edge-server-production/index.pack.old +0 -0
- package/.next/cache/webpack/server-production/0.pack +0 -0
- package/.next/cache/webpack/server-production/index.pack +0 -0
- package/.next/cache/webpack/server-production/index.pack.old +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/67.js +1 -1
- package/.next/server/middleware-build-manifest.js +1 -1
- package/.next/server/pages/404.html +1 -1
- package/.next/server/pages/500.html +1 -1
- package/.next/server/pages/index.html +1 -1
- package/.next/server/pages/index.js +1 -1
- package/.next/server/pages/index.json +1 -1
- package/.next/server/pages-manifest.json +1 -1
- package/.next/static/{ySzTsF3RIcISdWO2C2H3Z → _5S9YxXzM3OLRGGJe0qQv}/_buildManifest.js +1 -1
- package/.next/static/chunks/pages/_app-c960503f8645e1de.js +1 -0
- package/.next/static/chunks/pages/index-817f862d5980cebe.js +1 -0
- package/.next/static/css/a7aa574f03b29f75.css +2 -0
- package/.next/trace +23 -23
- package/package.json +10 -10
- package/src/components/Board/Board.tsx +1 -0
- package/src/components/Button/Button.module.scss +16 -1
- package/src/components/Button/Button.tsx +3 -0
- package/src/components/Button/Link.tsx +3 -0
- package/src/components/Radio/Radio.module.scss +14 -20
- package/src/components/Radio/Radio.tsx +3 -1
- package/src/modals/MenuModal/MenuModal.tsx +11 -3
- package/src/state/sagas.ts +3 -1
- package/.next/static/chunks/pages/_app-fb5bb6aa71eaaa4e.js +0 -1
- package/.next/static/chunks/pages/index-6ef7d0f12c9321e2.js +0 -1
- package/.next/static/css/35b36298aba4ccad.css +0 -2
- /package/.next/static/{ySzTsF3RIcISdWO2C2H3Z → _5S9YxXzM3OLRGGJe0qQv}/_ssgManifest.js +0 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@scrabble-solver/scrabble-solver",
|
|
3
|
-
"version": "2.15.
|
|
3
|
+
"version": "2.15.5",
|
|
4
4
|
"description": "Scrabble Solver 2 - App",
|
|
5
5
|
"engines": {
|
|
6
6
|
"node": ">=16"
|
|
@@ -30,13 +30,13 @@
|
|
|
30
30
|
"@floating-ui/react": "^0.26.25",
|
|
31
31
|
"@kamilmielnik/trie": "^3.1.0",
|
|
32
32
|
"@reduxjs/toolkit": "^2.3.0",
|
|
33
|
-
"@scrabble-solver/configs": "^2.15.
|
|
34
|
-
"@scrabble-solver/constants": "^2.15.
|
|
35
|
-
"@scrabble-solver/dictionaries": "^2.15.
|
|
36
|
-
"@scrabble-solver/logger": "^2.15.
|
|
37
|
-
"@scrabble-solver/solver": "^2.15.
|
|
38
|
-
"@scrabble-solver/types": "^2.15.
|
|
39
|
-
"@scrabble-solver/word-definitions": "^2.15.
|
|
33
|
+
"@scrabble-solver/configs": "^2.15.5",
|
|
34
|
+
"@scrabble-solver/constants": "^2.15.5",
|
|
35
|
+
"@scrabble-solver/dictionaries": "^2.15.5",
|
|
36
|
+
"@scrabble-solver/logger": "^2.15.5",
|
|
37
|
+
"@scrabble-solver/solver": "^2.15.5",
|
|
38
|
+
"@scrabble-solver/types": "^2.15.5",
|
|
39
|
+
"@scrabble-solver/word-definitions": "^2.15.5",
|
|
40
40
|
"classnames": "^2.5.1",
|
|
41
41
|
"env-cmd": "^10.1.0",
|
|
42
42
|
"include-media": "^2.0.0",
|
|
@@ -71,7 +71,7 @@
|
|
|
71
71
|
"@types/react-window": "^1.8.8",
|
|
72
72
|
"@types/redux": "^3.6.31",
|
|
73
73
|
"@types/redux-saga": "^0.10.5",
|
|
74
|
-
"sass": "^1.80.
|
|
74
|
+
"sass": "^1.80.4"
|
|
75
75
|
},
|
|
76
|
-
"gitHead": "
|
|
76
|
+
"gitHead": "fcb31b606fe7fb501c7e00a6c00a676fb7d2174f"
|
|
77
77
|
}
|
|
@@ -178,6 +178,7 @@ const Board: FunctionComponent<Props> = ({ className }) => {
|
|
|
178
178
|
position: floatingFocus.strategy,
|
|
179
179
|
top: floatingFocus.y + cellSize,
|
|
180
180
|
left: floatingFocus.x,
|
|
181
|
+
display: floatingFocus.isPositioned ? 'block' : 'none',
|
|
181
182
|
width: cellSize,
|
|
182
183
|
height: cellSize,
|
|
183
184
|
opacity: hasFocus ? 1 : 0,
|
|
@@ -60,8 +60,13 @@
|
|
|
60
60
|
.content {
|
|
61
61
|
display: flex;
|
|
62
62
|
align-items: center;
|
|
63
|
+
justify-content: center;
|
|
63
64
|
gap: var(--spacing--l);
|
|
64
65
|
line-height: var(--button--icon--size);
|
|
66
|
+
|
|
67
|
+
@include media('<l') {
|
|
68
|
+
gap: var(--spacing--m);
|
|
69
|
+
}
|
|
65
70
|
}
|
|
66
71
|
|
|
67
72
|
.icon {
|
|
@@ -74,8 +79,18 @@
|
|
|
74
79
|
.label {
|
|
75
80
|
@include ellipsis;
|
|
76
81
|
|
|
77
|
-
flex: 1;
|
|
78
82
|
font-size: var(--font--size--h3);
|
|
79
83
|
transition: var(--transition);
|
|
80
84
|
text-align: start;
|
|
81
85
|
}
|
|
86
|
+
|
|
87
|
+
.wide {
|
|
88
|
+
.content {
|
|
89
|
+
justify-content: normal;
|
|
90
|
+
gap: var(--spacing--l);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
.label {
|
|
94
|
+
flex: 1;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
@@ -12,6 +12,7 @@ interface Props extends ButtonHTMLAttributes<HTMLButtonElement> {
|
|
|
12
12
|
iconClassName?: string;
|
|
13
13
|
tooltip?: ReactNode;
|
|
14
14
|
variant?: 'default' | 'primary';
|
|
15
|
+
wide?: boolean;
|
|
15
16
|
}
|
|
16
17
|
|
|
17
18
|
const Button: FunctionComponent<Props> = ({
|
|
@@ -21,6 +22,7 @@ const Button: FunctionComponent<Props> = ({
|
|
|
21
22
|
iconClassName,
|
|
22
23
|
tooltip,
|
|
23
24
|
variant = 'default',
|
|
25
|
+
wide,
|
|
24
26
|
...props
|
|
25
27
|
}) => {
|
|
26
28
|
return (
|
|
@@ -29,6 +31,7 @@ const Button: FunctionComponent<Props> = ({
|
|
|
29
31
|
className={classNames(styles.button, className, {
|
|
30
32
|
[styles.default]: variant === 'default',
|
|
31
33
|
[styles.primary]: variant === 'primary',
|
|
34
|
+
[styles.wide]: wide,
|
|
32
35
|
})}
|
|
33
36
|
type="button"
|
|
34
37
|
{...props}
|
|
@@ -12,6 +12,7 @@ interface Props extends AnchorHTMLAttributes<HTMLAnchorElement> {
|
|
|
12
12
|
iconClassName?: string;
|
|
13
13
|
tooltip?: ReactNode;
|
|
14
14
|
variant?: 'default' | 'primary';
|
|
15
|
+
wide?: boolean;
|
|
15
16
|
}
|
|
16
17
|
|
|
17
18
|
const Link: FunctionComponent<Props> = ({
|
|
@@ -21,6 +22,7 @@ const Link: FunctionComponent<Props> = ({
|
|
|
21
22
|
iconClassName,
|
|
22
23
|
tooltip,
|
|
23
24
|
variant = 'default',
|
|
25
|
+
wide,
|
|
24
26
|
...props
|
|
25
27
|
}) => {
|
|
26
28
|
return (
|
|
@@ -29,6 +31,7 @@ const Link: FunctionComponent<Props> = ({
|
|
|
29
31
|
className={classNames(styles.button, className, {
|
|
30
32
|
[styles.default]: variant === 'default',
|
|
31
33
|
[styles.primary]: variant === 'primary',
|
|
34
|
+
[styles.wide]: wide,
|
|
32
35
|
})}
|
|
33
36
|
{...props}
|
|
34
37
|
>
|
|
@@ -16,10 +16,8 @@ $radio-box-size: $radio-size + 2 * $radio-inner-border;
|
|
|
16
16
|
cursor: pointer;
|
|
17
17
|
|
|
18
18
|
&.checked {
|
|
19
|
-
.
|
|
20
|
-
|
|
21
|
-
background-color: var(--color--primary);
|
|
22
|
-
}
|
|
19
|
+
.iconContent {
|
|
20
|
+
background-color: var(--color--primary);
|
|
23
21
|
}
|
|
24
22
|
}
|
|
25
23
|
|
|
@@ -40,28 +38,24 @@ $radio-box-size: $radio-size + 2 * $radio-inner-border;
|
|
|
40
38
|
}
|
|
41
39
|
|
|
42
40
|
.icon {
|
|
41
|
+
display: flex;
|
|
42
|
+
justify-content: center;
|
|
43
|
+
align-items: center;
|
|
43
44
|
flex: 0 0 auto;
|
|
44
|
-
position: relative;
|
|
45
45
|
width: $radio-box-size;
|
|
46
46
|
height: $radio-box-size;
|
|
47
|
-
border-radius: 50%;
|
|
48
47
|
border: $radio-inner-border solid var(--color--primary);
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
&::after {
|
|
52
|
-
content: ' ';
|
|
53
|
-
position: absolute;
|
|
54
|
-
top: 50%;
|
|
55
|
-
left: 50%;
|
|
56
|
-
transform: translate(-50%, -50%);
|
|
57
|
-
width: $radio-inner-size;
|
|
58
|
-
height: $radio-inner-size;
|
|
59
|
-
background-color: transparent;
|
|
60
|
-
border-radius: 50%;
|
|
61
|
-
transition: var(--transition);
|
|
62
|
-
}
|
|
48
|
+
border-radius: 50%;
|
|
63
49
|
}
|
|
64
50
|
|
|
65
51
|
.content {
|
|
66
52
|
flex: 1;
|
|
67
53
|
}
|
|
54
|
+
|
|
55
|
+
.iconContent {
|
|
56
|
+
width: $radio-inner-size;
|
|
57
|
+
height: $radio-inner-size;
|
|
58
|
+
background-color: transparent;
|
|
59
|
+
border-radius: 50%;
|
|
60
|
+
transition: var(--transition);
|
|
61
|
+
}
|
|
@@ -30,7 +30,9 @@ const Radio: FunctionComponent<Props> = ({ checked, children, className, disable
|
|
|
30
30
|
onChange={onChange}
|
|
31
31
|
/>
|
|
32
32
|
|
|
33
|
-
<div aria-hidden="true" className={styles.icon} role="img"
|
|
33
|
+
<div aria-hidden="true" className={styles.icon} role="img">
|
|
34
|
+
<div className={styles.iconContent} />
|
|
35
|
+
</div>
|
|
34
36
|
|
|
35
37
|
<div className={styles.content}>{children}</div>
|
|
36
38
|
</label>
|
|
@@ -37,16 +37,23 @@ const MenuModal: FunctionComponent<Props> = ({
|
|
|
37
37
|
aria-label={translate('remaining-tiles')}
|
|
38
38
|
className={styles.button}
|
|
39
39
|
Icon={Sack}
|
|
40
|
+
wide
|
|
40
41
|
onClick={onShowRemainingTiles}
|
|
41
42
|
>
|
|
42
43
|
{translate('remaining-tiles')}
|
|
43
44
|
</Button>
|
|
44
45
|
|
|
45
|
-
<Button aria-label={translate('words')} className={styles.button} Icon={CardChecklist} onClick={onShowWords}>
|
|
46
|
+
<Button aria-label={translate('words')} className={styles.button} Icon={CardChecklist} wide onClick={onShowWords}>
|
|
46
47
|
{translate('words')}
|
|
47
48
|
</Button>
|
|
48
49
|
|
|
49
|
-
<Button
|
|
50
|
+
<Button
|
|
51
|
+
aria-label={translate('dictionary')}
|
|
52
|
+
className={styles.button}
|
|
53
|
+
Icon={BookHalf}
|
|
54
|
+
wide
|
|
55
|
+
onClick={onShowDictionary}
|
|
56
|
+
>
|
|
50
57
|
{translate('dictionary')}
|
|
51
58
|
</Button>
|
|
52
59
|
|
|
@@ -57,11 +64,12 @@ const MenuModal: FunctionComponent<Props> = ({
|
|
|
57
64
|
Icon={Github}
|
|
58
65
|
rel="noopener noreferrer"
|
|
59
66
|
target="_blank"
|
|
67
|
+
wide
|
|
60
68
|
>
|
|
61
69
|
{translate('github')}
|
|
62
70
|
</Button.Link>
|
|
63
71
|
|
|
64
|
-
<Button aria-label={translate('settings')} className={styles.button} Icon={Cog} onClick={onShowSettings}>
|
|
72
|
+
<Button aria-label={translate('settings')} className={styles.button} Icon={Cog} wide onClick={onShowSettings}>
|
|
65
73
|
<div className={styles.settings}>
|
|
66
74
|
<div className={styles.settingsLabel}>{translate('settings')}</div>
|
|
67
75
|
<Icon aria-hidden="true" className={styles.flag} role="img" />
|
package/src/state/sagas.ts
CHANGED
|
@@ -167,7 +167,9 @@ function* onLocaleChange({ payload: locale }: PayloadAction<Locale>): AnyGenerat
|
|
|
167
167
|
function* onResultCandidateChange({ payload: result }: PayloadAction<Result | null>): AnyGenerator {
|
|
168
168
|
if (result) {
|
|
169
169
|
const locale: Locale = yield select(selectLocale);
|
|
170
|
-
|
|
170
|
+
const uniqueWords = Array.from(new Set(result.words));
|
|
171
|
+
const input = uniqueWords.join(LOCALE_FEATURES[locale].separator);
|
|
172
|
+
yield put(dictionarySlice.actions.changeInput(input));
|
|
171
173
|
yield put(dictionarySlice.actions.submit());
|
|
172
174
|
}
|
|
173
175
|
}
|