@scrabble-solver/scrabble-solver 2.10.6 → 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.
Files changed (102) hide show
  1. package/.next/BUILD_ID +1 -1
  2. package/.next/build-manifest.json +9 -9
  3. package/.next/cache/.tsbuildinfo +1 -1
  4. package/.next/cache/eslint/.cache_8dgz12 +1 -1
  5. package/.next/cache/next-server.js.nft.json +1 -1
  6. package/.next/cache/webpack/client-production/0.pack +0 -0
  7. package/.next/cache/webpack/client-production/index.pack +0 -0
  8. package/.next/cache/webpack/edge-server-production/0.pack +0 -0
  9. package/.next/cache/webpack/edge-server-production/index.pack +0 -0
  10. package/.next/cache/webpack/server-production/0.pack +0 -0
  11. package/.next/cache/webpack/server-production/index.pack +0 -0
  12. package/.next/next-server.js.nft.json +1 -1
  13. package/.next/prerender-manifest.json +1 -1
  14. package/.next/routes-manifest.json +1 -1
  15. package/.next/server/chunks/176.js +329 -359
  16. package/.next/server/chunks/290.js +3 -1
  17. package/.next/server/chunks/579.js +24 -16
  18. package/.next/server/middleware-build-manifest.js +1 -1
  19. package/.next/server/pages/404.html +2 -2
  20. package/.next/server/pages/404.js.nft.json +1 -1
  21. package/.next/server/pages/500.html +2 -2
  22. package/.next/server/pages/_app.js.nft.json +1 -1
  23. package/.next/server/pages/api/dictionary/[locale]/[word].js +18 -16
  24. package/.next/server/pages/index.html +2 -2
  25. package/.next/server/pages/index.js +14 -7
  26. package/.next/server/pages/index.js.nft.json +1 -1
  27. package/.next/server/pages/index.json +1 -1
  28. package/.next/server/pages-manifest.json +3 -3
  29. package/.next/static/6RggBFm8kHrh-k1-CG3um/_buildManifest.js +1 -0
  30. package/.next/static/chunks/509-6ad4482d4351452c.js +1 -0
  31. package/.next/static/chunks/pages/{404-ff35a4cf7f1ec85a.js → 404-67383848027ec49b.js} +1 -1
  32. package/.next/static/chunks/pages/_app-c58cfa832b76cc87.js +24 -0
  33. package/.next/static/chunks/pages/index-146039f501e49c08.js +1 -0
  34. package/.next/static/css/9d1013ec684361b9.css +1 -0
  35. package/.next/trace +55 -55
  36. package/package.json +9 -9
  37. package/src/components/Board/components/Cell/Button.tsx +1 -0
  38. package/src/components/Board/components/Cell/Cell.tsx +6 -0
  39. package/src/components/Board/components/Cell/CellPure.tsx +10 -1
  40. package/src/components/Button/Button.tsx +1 -0
  41. package/src/components/Button/Link.tsx +1 -0
  42. package/src/components/{SquareButton/SquareButton.module.scss → IconButton/IconButton.module.scss} +1 -1
  43. package/src/components/{SquareButton/SquareButton.tsx → IconButton/IconButton.tsx} +7 -6
  44. package/src/components/{SquareButton → IconButton}/Link.tsx +3 -2
  45. package/src/components/IconButton/index.ts +1 -0
  46. package/src/components/Logo/Logo.svg +44 -15
  47. package/src/components/Modal/Modal.tsx +3 -2
  48. package/src/components/NavButtons/NavButtons.tsx +37 -9
  49. package/src/components/Rack/RackTile.tsx +5 -0
  50. package/src/components/Results/HeaderButton.tsx +1 -0
  51. package/src/components/Results/Result.tsx +1 -0
  52. package/src/components/Results/Results.module.scss +0 -1
  53. package/src/components/Results/SolveButton.tsx +1 -0
  54. package/src/components/Solver/Solver.module.scss +4 -0
  55. package/src/components/Solver/Solver.tsx +26 -8
  56. package/src/components/Solver/components/EmptyState/EmptyState.module.scss +0 -2
  57. package/src/components/Solver/components/InsertButton/InsertButton.module.scss +15 -0
  58. package/src/components/Solver/components/{ApplyButton/ApplyButton.tsx → InsertButton/InsertButton.tsx} +10 -6
  59. package/src/components/Solver/components/InsertButton/index.ts +1 -0
  60. package/src/components/Solver/components/ResultCandidatePicker/ResultCandidatePicker.module.scss +30 -7
  61. package/src/components/Solver/components/ResultCandidatePicker/ResultCandidatePicker.tsx +39 -16
  62. package/src/components/Solver/components/SolveButton/SolveButton.tsx +11 -1
  63. package/src/components/Solver/components/index.ts +1 -2
  64. package/src/components/Tile/Tile.tsx +3 -0
  65. package/src/components/Tile/TilePure.tsx +3 -0
  66. package/src/components/Tooltip/useTooltip.tsx +14 -2
  67. package/src/components/index.ts +1 -1
  68. package/src/i18n/de.json +5 -0
  69. package/src/i18n/en.json +5 -0
  70. package/src/i18n/es.json +5 -0
  71. package/src/i18n/fa.json +5 -0
  72. package/src/i18n/fr.json +5 -0
  73. package/src/i18n/pl.json +5 -0
  74. package/src/icons/ArrowDown.svg +1 -1
  75. package/src/icons/ArrowLeft.svg +1 -1
  76. package/src/icons/ArrowRight.svg +1 -1
  77. package/src/icons/ArrowUp.svg +1 -1
  78. package/src/icons/ChevronDown.svg +1 -1
  79. package/src/icons/ChevronLeft.svg +1 -1
  80. package/src/icons/ChevronRight.svg +1 -1
  81. package/src/icons/List.svg +1 -1
  82. package/src/modals/MenuModal/MenuModal.tsx +9 -3
  83. package/src/modals/RemainingTilesModal/components/Character/Character.tsx +1 -0
  84. package/src/modals/SettingsModal/components/AutoGroupTilesSetting/AutoGroupTilesSetting.tsx +2 -2
  85. package/src/modals/SettingsModal/components/ConfigSetting/ConfigSetting.tsx +2 -2
  86. package/src/modals/SettingsModal/components/LocaleSetting/LocaleSetting.tsx +2 -2
  87. package/src/pages/api/dictionary/[locale]/[word].ts +3 -1
  88. package/src/pages/index.tsx +10 -6
  89. package/src/state/sagas.ts +5 -2
  90. package/src/state/useTranslate.ts +5 -2
  91. package/src/types/index.ts +6 -1
  92. package/.next/static/chunks/791-93aa8b8c22e488ac.js +0 -1
  93. package/.next/static/chunks/pages/_app-fa0661b072fc6af9.js +0 -24
  94. package/.next/static/chunks/pages/index-ded620fd5df96be0.js +0 -1
  95. package/.next/static/css/a943dd97164732d4.css +0 -1
  96. package/.next/static/iL0av55MV28b0MXfhKKt2/_buildManifest.js +0 -1
  97. package/src/components/Solver/components/ApplyButton/ApplyButton.module.scss +0 -5
  98. package/src/components/Solver/components/ApplyButton/index.ts +0 -1
  99. package/src/components/Solver/components/MobileControls/MobileControls.tsx +0 -62
  100. package/src/components/Solver/components/MobileControls/index.ts +0 -1
  101. package/src/components/SquareButton/index.ts +0 -1
  102. /package/.next/static/{iL0av55MV28b0MXfhKKt2 → 6RggBFm8kHrh-k1-CG3um}/_ssgManifest.js +0 -0
@@ -115,6 +115,19 @@ module.exports = {
115
115
  };
116
116
 
117
117
 
118
+ /***/ }),
119
+
120
+ /***/ 36085:
121
+ /***/ ((module) => {
122
+
123
+ // Exports
124
+ module.exports = {
125
+ "iconButton": "IconButton_iconButton__y4vSg",
126
+ "content": "IconButton_content__LyjuP",
127
+ "icon": "IconButton_icon___Bd1_"
128
+ };
129
+
130
+
118
131
  /***/ }),
119
132
 
120
133
  /***/ 91898:
@@ -347,35 +360,37 @@ module.exports = {
347
360
  "rackContainer": "Solver_rackContainer__2QSoB",
348
361
  "rack": "Solver_rack__9DDCR",
349
362
  "controls": "Solver_controls__2D9Ez",
363
+ "emptyState": "Solver_emptyState__P5fkX",
350
364
  "solve": "Solver_solve__MgHc7"
351
365
  };
352
366
 
353
367
 
354
368
  /***/ }),
355
369
 
356
- /***/ 36456:
370
+ /***/ 74048:
357
371
  /***/ ((module) => {
358
372
 
359
373
  // Exports
360
374
  module.exports = {
361
- "icon": "ApplyButton_icon__9TqIL"
375
+ "emptyState": "EmptyState_emptyState__XRkVh",
376
+ "iconContainer": "EmptyState_iconContainer__muJPY",
377
+ "error": "EmptyState_error__LALvw",
378
+ "warning": "EmptyState_warning__3cgae",
379
+ "info": "EmptyState_info__M93ve",
380
+ "icon": "EmptyState_icon__4Okzd",
381
+ "content": "EmptyState_content__VwtZg"
362
382
  };
363
383
 
364
384
 
365
385
  /***/ }),
366
386
 
367
- /***/ 74048:
387
+ /***/ 99725:
368
388
  /***/ ((module) => {
369
389
 
370
390
  // Exports
371
391
  module.exports = {
372
- "emptyState": "EmptyState_emptyState__XRkVh",
373
- "iconContainer": "EmptyState_iconContainer__muJPY",
374
- "error": "EmptyState_error__LALvw",
375
- "warning": "EmptyState_warning__3cgae",
376
- "info": "EmptyState_info__M93ve",
377
- "icon": "EmptyState_icon__4Okzd",
378
- "content": "EmptyState_content__VwtZg"
392
+ "insertButton": "InsertButton_insertButton__RIi9m",
393
+ "icon": "InsertButton_icon___UGZp"
379
394
  };
380
395
 
381
396
 
@@ -395,7 +410,7 @@ module.exports = {
395
410
  "word": "ResultCandidatePicker_word__uK_Oo",
396
411
  "iconContainer": "ResultCandidatePicker_iconContainer__uQ4FG",
397
412
  "icon": "ResultCandidatePicker_icon__cTxGI",
398
- "apply": "ResultCandidatePicker_apply__8zvXC"
413
+ "insert": "ResultCandidatePicker_insert__mLW3V"
399
414
  };
400
415
 
401
416
 
@@ -422,19 +437,6 @@ module.exports = {
422
437
  };
423
438
 
424
439
 
425
- /***/ }),
426
-
427
- /***/ 53539:
428
- /***/ ((module) => {
429
-
430
- // Exports
431
- module.exports = {
432
- "squareButton": "SquareButton_squareButton__qwR9a",
433
- "content": "SquareButton_content__1ucqM",
434
- "icon": "SquareButton_icon__t5YSC"
435
- };
436
-
437
-
438
440
  /***/ }),
439
441
 
440
442
  /***/ 48564:
@@ -708,6 +710,7 @@ const Cell = ({ cell , className , direction , inputRef , isBottom , isCenter ,
708
710
  const { tile , x , y } = cell;
709
711
  const dispatch = (0,react_redux__WEBPACK_IMPORTED_MODULE_3__.useDispatch)();
710
712
  const translate = (0,state__WEBPACK_IMPORTED_MODULE_5__/* .useTranslate */ .qM)();
713
+ const locale = (0,state__WEBPACK_IMPORTED_MODULE_5__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_5__/* .selectLocale */ .fN);
711
714
  const bonus = (0,state__WEBPACK_IMPORTED_MODULE_5__/* .useTypedSelector */ .ix)((state)=>(0,state__WEBPACK_IMPORTED_MODULE_5__/* .selectCellBonus */ .O0)(state, cell));
712
715
  const points = (0,state__WEBPACK_IMPORTED_MODULE_5__/* .useTypedSelector */ .ix)((state)=>(0,state__WEBPACK_IMPORTED_MODULE_5__/* .selectTilePoints */ .Zf)(state, cell.tile));
713
716
  const isFiltered = (0,state__WEBPACK_IMPORTED_MODULE_5__/* .useTypedSelector */ .ix)((state)=>(0,state__WEBPACK_IMPORTED_MODULE_5__/* .selectCellIsFiltered */ .id)(state, cell));
@@ -759,6 +762,10 @@ const Cell = ({ cell , className , direction , inputRef , isBottom , isCenter ,
759
762
  y
760
763
  ]);
761
764
  return /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_CellPure__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
765
+ "aria-label": translate("cell.tile.location", {
766
+ x: (x + 1).toLocaleString(locale),
767
+ y: (y + 1).toLocaleString(locale)
768
+ }),
762
769
  bonus: bonus,
763
770
  cell: cell,
764
771
  className: className,
@@ -819,7 +826,7 @@ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_Til
819
826
 
820
827
 
821
828
 
822
- const CellPure = ({ bonus , cell , className , direction , inputRef , isBottom , isCenter , isRight , isEmpty , isFiltered , isValid , points , size , style , tile , translate , onChange , onDirectionToggleClick , onFocus , onToggleBlankClick , onToggleFilterCellClick })=>/*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
829
+ const CellPure = ({ "aria-label": ariaLabel , bonus , cell , className , direction , inputRef , isBottom , isCenter , isRight , isEmpty , isFiltered , isValid , points , size , style , tile , translate , onChange , onDirectionToggleClick , onFocus , onToggleBlankClick , onToggleFilterCellClick })=>/*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
823
830
  className: classnames__WEBPACK_IMPORTED_MODULE_1___default()((_Cell_module_scss__WEBPACK_IMPORTED_MODULE_7___default().cell), className, (0,_lib__WEBPACK_IMPORTED_MODULE_6__/* .getBonusClassname */ .K)(cell, bonus, isCenter), {
824
831
  [(_Cell_module_scss__WEBPACK_IMPORTED_MODULE_7___default().bottom)]: isBottom,
825
832
  [(_Cell_module_scss__WEBPACK_IMPORTED_MODULE_7___default().candidate)]: cell.isCandidate(),
@@ -840,6 +847,7 @@ const CellPure = ({ bonus , cell , className , direction , inputRef , isBottom ,
840
847
  })
841
848
  }),
842
849
  /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_Tile__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z, {
850
+ "aria-label": ariaLabel,
843
851
  className: (_Cell_module_scss__WEBPACK_IMPORTED_MODULE_7___default().tile),
844
852
  character: isEmpty ? undefined : tile.character,
845
853
  highlighted: cell.isCandidate(),
@@ -857,6 +865,7 @@ const CellPure = ({ bonus , cell , className , direction , inputRef , isBottom ,
857
865
  className: (_Cell_module_scss__WEBPACK_IMPORTED_MODULE_7___default().actions),
858
866
  children: [
859
867
  /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_Button__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, {
868
+ "aria-label": translate("cell.toggle-direction"),
860
869
  tooltip: translate("cell.toggle-direction"),
861
870
  onClick: onDirectionToggleClick,
862
871
  children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(icons__WEBPACK_IMPORTED_MODULE_3__/* .ArrowDown */ .K5, {
@@ -866,6 +875,7 @@ const CellPure = ({ bonus , cell , className , direction , inputRef , isBottom ,
866
875
  })
867
876
  }),
868
877
  isEmpty && /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_Button__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, {
878
+ "aria-label": translate("cell.filter-cell"),
869
879
  className: classnames__WEBPACK_IMPORTED_MODULE_1___default()((_Cell_module_scss__WEBPACK_IMPORTED_MODULE_7___default().filterCell), {
870
880
  [(_Cell_module_scss__WEBPACK_IMPORTED_MODULE_7___default().filtered)]: isFiltered
871
881
  }),
@@ -874,6 +884,7 @@ const CellPure = ({ bonus , cell , className , direction , inputRef , isBottom ,
874
884
  children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(icons__WEBPACK_IMPORTED_MODULE_3__/* .Flag */ .WN, {})
875
885
  }),
876
886
  !isEmpty && /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_Button__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, {
887
+ "aria-label": tile.isBlank ? translate("cell.set-not-blank") : translate("cell.set-blank"),
877
888
  className: classnames__WEBPACK_IMPORTED_MODULE_1___default()((_Cell_module_scss__WEBPACK_IMPORTED_MODULE_7___default().blank), {
878
889
  [(_Cell_module_scss__WEBPACK_IMPORTED_MODULE_7___default().active)]: tile.isBlank
879
890
  }),
@@ -1894,6 +1905,113 @@ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_Emp
1894
1905
  _EmptyState__WEBPACK_IMPORTED_MODULE_0__ = (__webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__)[0];
1895
1906
 
1896
1907
 
1908
+ __webpack_async_result__();
1909
+ } catch(e) { __webpack_async_result__(e); } });
1910
+
1911
+ /***/ }),
1912
+
1913
+ /***/ 80545:
1914
+ /***/ ((module, __webpack_exports__, __webpack_require__) => {
1915
+
1916
+ "use strict";
1917
+ __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __webpack_async_result__) => { try {
1918
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
1919
+ /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__)
1920
+ /* harmony export */ });
1921
+ /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20997);
1922
+ /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__);
1923
+ /* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(59003);
1924
+ /* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);
1925
+ /* harmony import */ var _Tooltip__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7646);
1926
+ /* harmony import */ var _IconButton_module_scss__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(36085);
1927
+ /* harmony import */ var _IconButton_module_scss__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_IconButton_module_scss__WEBPACK_IMPORTED_MODULE_4__);
1928
+ /* harmony import */ var _Link__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(17062);
1929
+ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_Tooltip__WEBPACK_IMPORTED_MODULE_2__, _Link__WEBPACK_IMPORTED_MODULE_3__]);
1930
+ ([_Tooltip__WEBPACK_IMPORTED_MODULE_2__, _Link__WEBPACK_IMPORTED_MODULE_3__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
1931
+
1932
+
1933
+
1934
+
1935
+
1936
+ const IconButton = ({ className , Icon , tooltip , ...props })=>{
1937
+ const triggerProps = (0,_Tooltip__WEBPACK_IMPORTED_MODULE_2__/* .useTooltip */ .l)(tooltip, props);
1938
+ return /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("button", {
1939
+ className: classnames__WEBPACK_IMPORTED_MODULE_1___default()((_IconButton_module_scss__WEBPACK_IMPORTED_MODULE_4___default().iconButton), className),
1940
+ type: "button",
1941
+ ...props,
1942
+ ...triggerProps,
1943
+ children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("span", {
1944
+ className: (_IconButton_module_scss__WEBPACK_IMPORTED_MODULE_4___default().content),
1945
+ children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(Icon, {
1946
+ className: (_IconButton_module_scss__WEBPACK_IMPORTED_MODULE_4___default().icon)
1947
+ })
1948
+ })
1949
+ });
1950
+ };
1951
+ /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Object.assign(IconButton, {
1952
+ Link: _Link__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z
1953
+ }));
1954
+
1955
+ __webpack_async_result__();
1956
+ } catch(e) { __webpack_async_result__(e); } });
1957
+
1958
+ /***/ }),
1959
+
1960
+ /***/ 17062:
1961
+ /***/ ((module, __webpack_exports__, __webpack_require__) => {
1962
+
1963
+ "use strict";
1964
+ __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __webpack_async_result__) => { try {
1965
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
1966
+ /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__)
1967
+ /* harmony export */ });
1968
+ /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20997);
1969
+ /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__);
1970
+ /* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(59003);
1971
+ /* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);
1972
+ /* harmony import */ var _Tooltip__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7646);
1973
+ /* harmony import */ var _IconButton_module_scss__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(36085);
1974
+ /* harmony import */ var _IconButton_module_scss__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_IconButton_module_scss__WEBPACK_IMPORTED_MODULE_3__);
1975
+ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_Tooltip__WEBPACK_IMPORTED_MODULE_2__]);
1976
+ _Tooltip__WEBPACK_IMPORTED_MODULE_2__ = (__webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__)[0];
1977
+
1978
+
1979
+
1980
+
1981
+ const Link = ({ className , Icon , tooltip , ...props })=>{
1982
+ const triggerProps = (0,_Tooltip__WEBPACK_IMPORTED_MODULE_2__/* .useTooltip */ .l)(tooltip, props);
1983
+ return /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("a", {
1984
+ className: classnames__WEBPACK_IMPORTED_MODULE_1___default()((_IconButton_module_scss__WEBPACK_IMPORTED_MODULE_3___default().iconButton), className),
1985
+ ...props,
1986
+ ...triggerProps,
1987
+ children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("span", {
1988
+ className: (_IconButton_module_scss__WEBPACK_IMPORTED_MODULE_3___default().content),
1989
+ children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(Icon, {
1990
+ className: (_IconButton_module_scss__WEBPACK_IMPORTED_MODULE_3___default().icon)
1991
+ })
1992
+ })
1993
+ });
1994
+ };
1995
+ /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Link);
1996
+
1997
+ __webpack_async_result__();
1998
+ } catch(e) { __webpack_async_result__(e); } });
1999
+
2000
+ /***/ }),
2001
+
2002
+ /***/ 6193:
2003
+ /***/ ((module, __webpack_exports__, __webpack_require__) => {
2004
+
2005
+ "use strict";
2006
+ __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __webpack_async_result__) => { try {
2007
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2008
+ /* harmony export */ "Z": () => (/* reexport safe */ _IconButton__WEBPACK_IMPORTED_MODULE_0__.Z)
2009
+ /* harmony export */ });
2010
+ /* harmony import */ var _IconButton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(80545);
2011
+ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_IconButton__WEBPACK_IMPORTED_MODULE_0__]);
2012
+ _IconButton__WEBPACK_IMPORTED_MODULE_0__ = (__webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__)[0];
2013
+
2014
+
1897
2015
  __webpack_async_result__();
1898
2016
  } catch(e) { __webpack_async_result__(e); } });
1899
2017
 
@@ -2044,91 +2162,76 @@ var SvgLogo = function SvgLogo(props) {
2044
2162
  fill: "#efe3ae",
2045
2163
  d: "M0 0h80v80H0Z"
2046
2164
  })), _path2 || (_path2 = /*#__PURE__*/external_react_.createElement("path", {
2047
- "aria-label": "S",
2048
2165
  d: "M51.168 47.629q0 3.047-1.477 5.297-1.476 2.25-4.312 3.469-2.813 1.218-6.844 1.218-1.781 0-3.492-.234-1.688-.234-3.258-.68-1.547-.469-2.953-1.148V48.8q2.438 1.078 5.063 1.945 2.625.867 5.203.867 1.78 0 2.859-.468 1.102-.47 1.594-1.29.492-.82.492-1.875 0-1.289-.867-2.203-.867-.914-2.39-1.71-1.5-.797-3.4-1.712-1.195-.562-2.6-1.359-1.407-.82-2.673-1.992-1.265-1.172-2.086-2.836-.797-1.688-.797-4.031 0-3.07 1.407-5.25 1.406-2.18 4.008-3.328 2.625-1.172 6.187-1.172 2.672 0 5.086.633 2.437.609 5.086 1.78l-2.344 5.65q-2.367-.962-4.242-1.477-1.875-.54-3.82-.54-1.36 0-2.32.446-.962.422-1.454 1.219-.492.773-.492 1.804 0 1.22.703 2.063.727.82 2.156 1.594 1.454.773 3.61 1.804 2.625 1.242 4.476 2.602 1.875 1.336 2.883 3.164 1.008 1.805 1.008 4.5z"
2049
2166
  })), _path3 || (_path3 = /*#__PURE__*/external_react_.createElement("path", {
2050
2167
  fill: "#c7d8f9",
2051
2168
  d: "M86 0h80v80H86Z"
2052
2169
  })), _path4 || (_path4 = /*#__PURE__*/external_react_.createElement("path", {
2053
- "aria-label": "C",
2054
2170
  d: "M129.574 28.434q-2.086 0-3.703.82-1.594.797-2.695 2.32-1.078 1.524-1.64 3.68-.563 2.156-.563 4.851 0 3.633.89 6.211.914 2.555 2.813 3.914 1.898 1.336 4.898 1.336 2.086 0 4.172-.468 2.11-.47 4.57-1.336v6.093q-2.273.938-4.476 1.336-2.203.422-4.945.422-5.297 0-8.72-2.18-3.398-2.203-5.038-6.14-1.64-3.961-1.64-9.234 0-3.891 1.054-7.125 1.054-3.235 3.094-5.602 2.039-2.367 5.039-3.656 3-1.29 6.89-1.29 2.555 0 5.11.657 2.578.633 4.921 1.758l-2.343 5.906q-1.922-.914-3.867-1.594-1.946-.68-3.82-.68z"
2055
2171
  })), _path5 || (_path5 = /*#__PURE__*/external_react_.createElement("path", {
2056
2172
  fill: "#efe3ae",
2057
2173
  d: "M172 0h80v80h-80z"
2058
2174
  })), _path6 || (_path6 = /*#__PURE__*/external_react_.createElement("path", {
2059
- "aria-label": "R",
2060
2175
  d: "M210.453 22.867q4.664 0 7.688 1.125 3.047 1.125 4.523 3.399 1.477 2.273 1.477 5.742 0 2.344-.891 4.101-.89 1.758-2.344 2.977-1.453 1.219-3.14 1.992l10.078 14.93h-8.063l-8.18-13.149h-3.867v13.149h-7.265V22.867Zm-.515 5.953h-2.204v9.258h2.344q3.61 0 5.156-1.195 1.57-1.219 1.57-3.563 0-2.437-1.687-3.468-1.664-1.032-5.18-1.032z"
2061
2176
  })), _path7 || (_path7 = /*#__PURE__*/external_react_.createElement("path", {
2062
2177
  fill: "#efe3ae",
2063
2178
  d: "M258 0h80v80h-80z"
2064
2179
  })), _path8 || (_path8 = /*#__PURE__*/external_react_.createElement("path", {
2065
- "aria-label": "A",
2066
2180
  d: "m306.73 57.203-2.484-8.156h-12.492l-2.484 8.156h-7.829l12.094-34.406h8.883l12.14 34.406zm-4.218-14.25-2.485-7.969q-.234-.796-.632-2.039-.375-1.265-.774-2.554-.375-1.313-.61-2.274-.234.961-.656 2.39-.398 1.407-.773 2.673-.375 1.265-.539 1.804l-2.461 7.97z"
2067
2181
  })), _path9 || (_path9 = /*#__PURE__*/external_react_.createElement("path", {
2068
2182
  fill: "#c7d8f9",
2069
2183
  d: "M344 0h80v80h-80z"
2070
2184
  })), _path10 || (_path10 = /*#__PURE__*/external_react_.createElement("path", {
2071
- "aria-label": "B",
2072
2185
  d: "M372.188 22.867h10.664q6.843 0 10.359 1.922t3.516 6.75q0 1.945-.633 3.516-.61 1.57-1.781 2.578-1.172 1.008-2.86 1.312v.235q1.711.351 3.094 1.218 1.383.844 2.203 2.485.844 1.617.844 4.312 0 3.118-1.524 5.344-1.523 2.227-4.36 3.422-2.812 1.172-6.702 1.172h-12.82Zm7.265 13.57h4.219q3.164 0 4.383-.984 1.218-1.008 1.218-2.953 0-1.969-1.453-2.812-1.43-.868-4.547-.868h-3.82zm0 5.766v8.93h4.735q3.28 0 4.57-1.266 1.289-1.265 1.289-3.398 0-1.266-.563-2.227-.562-.96-1.898-1.5-1.313-.539-3.633-.539z"
2073
2186
  })), _path11 || (_path11 = /*#__PURE__*/external_react_.createElement("path", {
2074
2187
  fill: "#c7d8f9",
2075
2188
  d: "M430 0h80v80h-80z"
2076
2189
  })), _path12 || (_path12 = /*#__PURE__*/external_react_.createElement("path", {
2077
- "aria-label": "B",
2078
2190
  d: "M458.188 22.867h10.664q6.843 0 10.359 1.922t3.516 6.75q0 1.945-.633 3.516-.61 1.57-1.781 2.578-1.172 1.008-2.86 1.312v.235q1.711.351 3.094 1.218 1.383.844 2.203 2.485.844 1.617.844 4.312 0 3.118-1.524 5.344-1.523 2.227-4.36 3.422-2.812 1.172-6.702 1.172h-12.82Zm7.265 13.57h4.219q3.164 0 4.383-.984 1.218-1.008 1.218-2.953 0-1.969-1.453-2.812-1.43-.868-4.547-.868h-3.82zm0 5.766v8.93h4.735q3.28 0 4.57-1.266 1.289-1.265 1.289-3.398 0-1.266-.563-2.227-.562-.96-1.898-1.5-1.313-.539-3.633-.539z"
2079
2191
  })), _path13 || (_path13 = /*#__PURE__*/external_react_.createElement("path", {
2080
2192
  fill: "#efe3ae",
2081
2193
  d: "M516 0h80v80h-80z"
2082
2194
  })), _path14 || (_path14 = /*#__PURE__*/external_react_.createElement("path", {
2083
- "aria-label": "L",
2084
2195
  d: "M546.754 57.133V22.867h7.266v28.266h13.898v6z"
2085
2196
  })), _path15 || (_path15 = /*#__PURE__*/external_react_.createElement("path", {
2086
2197
  fill: "#efe3ae",
2087
2198
  d: "M602 0h80v80h-80z"
2088
2199
  })), _path16 || (_path16 = /*#__PURE__*/external_react_.createElement("path", {
2089
- "aria-label": "E",
2090
2200
  d: "M652.605 57.133h-19.734V22.867h19.734v5.953h-12.468v7.524h11.601v5.953h-11.601v8.836h12.468z"
2091
2201
  })), _path17 || (_path17 = /*#__PURE__*/external_react_.createElement("path", {
2092
2202
  fill: "#efe3ae",
2093
2203
  d: "M0 86h80v80H0Z"
2094
2204
  })), _path18 || (_path18 = /*#__PURE__*/external_react_.createElement("path", {
2095
- "aria-label": "S",
2096
2205
  d: "M51.32 133.629q0 3.047-1.476 5.297-1.477 2.25-4.313 3.469-2.812 1.218-6.843 1.218-1.782 0-3.493-.234-1.687-.234-3.257-.68-1.547-.469-2.954-1.148v-6.75q2.438 1.078 5.063 1.945 2.625.867 5.203.867 1.781 0 2.86-.468 1.1-.47 1.593-1.29.492-.82.492-1.875 0-1.289-.867-2.203-.867-.914-2.39-1.71-1.5-.797-3.399-1.712-1.195-.562-2.602-1.359-1.406-.82-2.671-1.992-1.266-1.172-2.086-2.836-.797-1.688-.797-4.031 0-3.07 1.406-5.25t4.008-3.328q2.625-1.172 6.187-1.172 2.672 0 5.086.633 2.438.609 5.086 1.78l-2.343 5.65q-2.368-.962-4.243-1.477-1.875-.54-3.82-.54-1.36 0-2.32.446-.961.422-1.453 1.219-.493.773-.493 1.804 0 1.22.703 2.063.727.82 2.157 1.594 1.453.773 3.61 1.804 2.624 1.242 4.476 2.602 1.875 1.336 2.883 3.164 1.007 1.805 1.007 4.5z"
2097
2206
  })), _path19 || (_path19 = /*#__PURE__*/external_react_.createElement("path", {
2098
2207
  fill: "#efe3ae",
2099
2208
  d: "M86 86h80v80H86Z"
2100
2209
  })), _path20 || (_path20 = /*#__PURE__*/external_react_.createElement("path", {
2101
- "aria-label": "O",
2102
2210
  d: "M142.313 125.988q0 3.961-.985 7.219-.984 3.234-3 5.578-1.992 2.344-5.062 3.61-3.07 1.242-7.266 1.242-4.195 0-7.266-1.242-3.07-1.266-5.086-3.61-1.992-2.344-2.976-5.601-.984-3.258-.984-7.243 0-5.32 1.734-9.257 1.758-3.961 5.39-6.141 3.633-2.18 9.235-2.18 5.578 0 9.164 2.18 3.61 2.18 5.344 6.14 1.758 3.962 1.758 9.305zm-25.008 0q0 3.586.89 6.188.914 2.578 2.836 3.984 1.922 1.383 4.969 1.383 3.094 0 5.016-1.383 1.921-1.406 2.789-3.984.89-2.602.89-6.188 0-5.39-2.015-8.484-2.016-3.094-6.633-3.094-3.07 0-5.016 1.406-1.922 1.383-2.836 3.985-.89 2.578-.89 6.187z"
2103
2211
  })), _path21 || (_path21 = /*#__PURE__*/external_react_.createElement("path", {
2104
2212
  fill: "#efe3ae",
2105
2213
  d: "M172 86h80v80h-80z"
2106
2214
  })), _path22 || (_path22 = /*#__PURE__*/external_react_.createElement("path", {
2107
- "aria-label": "L",
2108
2215
  d: "M202.754 143.133v-34.266h7.266v28.266h13.898v6z"
2109
2216
  })), _path23 || (_path23 = /*#__PURE__*/external_react_.createElement("path", {
2110
2217
  fill: "#f7c2aa",
2111
2218
  d: "M258 86h80v80h-80z"
2112
2219
  })), _path24 || (_path24 = /*#__PURE__*/external_react_.createElement("path", {
2113
- "aria-label": "V",
2114
2220
  d: "m313.598 108.867-11.649 34.266h-7.922l-11.625-34.266h7.336l6.446 20.39q.164.516.539 1.946.375 1.406.75 3 .398 1.57.539 2.602.14-1.032.492-2.602.375-1.57.726-2.976.375-1.43.54-1.97l6.492-20.39z"
2115
2221
  })), _path25 || (_path25 = /*#__PURE__*/external_react_.createElement("path", {
2116
2222
  fill: "#efe3ae",
2117
2223
  d: "M344 86h80v80h-80z"
2118
2224
  })), _path26 || (_path26 = /*#__PURE__*/external_react_.createElement("path", {
2119
- "aria-label": "E",
2120
2225
  d: "M394.605 143.133h-19.734v-34.266h19.734v5.953h-12.468v7.524h11.601v5.953h-11.601v8.836h12.468z"
2121
2226
  })), _path27 || (_path27 = /*#__PURE__*/external_react_.createElement("path", {
2122
2227
  fill: "#efe3ae",
2123
2228
  d: "M430 86h80v80h-80z"
2124
2229
  })), _path28 || (_path28 = /*#__PURE__*/external_react_.createElement("path", {
2125
- "aria-label": "R",
2126
2230
  d: "M468.453 108.867q4.664 0 7.688 1.125 3.046 1.125 4.523 3.399 1.477 2.273 1.477 5.742 0 2.344-.891 4.101-.89 1.758-2.344 2.977-1.453 1.219-3.14 1.992l10.078 14.93h-8.063l-8.18-13.149h-3.867v13.149h-7.265v-34.266zm-.515 5.953h-2.204v9.258h2.344q3.61 0 5.156-1.195 1.57-1.219 1.57-3.563 0-2.437-1.687-3.468-1.664-1.032-5.18-1.032z"
2127
2231
  })), _path29 || (_path29 = /*#__PURE__*/external_react_.createElement("path", {
2128
2232
  fill: "#bae3ba",
2129
2233
  d: "M602 86h80v80h-80z"
2130
2234
  })), _path30 || (_path30 = /*#__PURE__*/external_react_.createElement("path", {
2131
- "aria-label": 2,
2132
2235
  d: "M654.152 143.379H630.2v-5.04l8.602-8.694q2.601-2.672 4.172-4.454 1.593-1.804 2.297-3.28.726-1.477.726-3.165 0-2.039-1.148-3.047-1.125-1.031-3.024-1.031-1.992 0-3.867.914t-3.914 2.602l-3.938-4.664q1.477-1.266 3.118-2.391 1.664-1.125 3.843-1.805 2.204-.703 5.274-.703 3.375 0 5.789 1.219 2.437 1.219 3.75 3.328 1.312 2.086 1.312 4.734 0 2.836-1.125 5.18t-3.28 4.64q-2.134 2.298-5.157 5.087l-4.406 4.148v.328h14.93z"
2133
2236
  })));
2134
2237
  };
@@ -2219,12 +2322,12 @@ __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __we
2219
2322
  /* harmony import */ var icons__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(60755);
2220
2323
  /* harmony import */ var parameters__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(74200);
2221
2324
  /* harmony import */ var state__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(64579);
2222
- /* harmony import */ var _SquareButton__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(86889);
2325
+ /* harmony import */ var _IconButton__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(6193);
2223
2326
  /* harmony import */ var _components__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(40265);
2224
2327
  /* harmony import */ var _Modal_module_scss__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(55242);
2225
2328
  /* harmony import */ var _Modal_module_scss__WEBPACK_IMPORTED_MODULE_10___default = /*#__PURE__*/__webpack_require__.n(_Modal_module_scss__WEBPACK_IMPORTED_MODULE_10__);
2226
- var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([state__WEBPACK_IMPORTED_MODULE_7__, _SquareButton__WEBPACK_IMPORTED_MODULE_8__]);
2227
- ([state__WEBPACK_IMPORTED_MODULE_7__, _SquareButton__WEBPACK_IMPORTED_MODULE_8__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
2329
+ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([state__WEBPACK_IMPORTED_MODULE_7__, _IconButton__WEBPACK_IMPORTED_MODULE_8__]);
2330
+ ([state__WEBPACK_IMPORTED_MODULE_7__, _IconButton__WEBPACK_IMPORTED_MODULE_8__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
2228
2331
 
2229
2332
 
2230
2333
 
@@ -2274,7 +2377,8 @@ const Modal = ({ children , className , isOpen , title , onClose })=>{
2274
2377
  className: (_Modal_module_scss__WEBPACK_IMPORTED_MODULE_10___default().title),
2275
2378
  children: title
2276
2379
  }),
2277
- /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_SquareButton__WEBPACK_IMPORTED_MODULE_8__/* ["default"] */ .Z, {
2380
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_IconButton__WEBPACK_IMPORTED_MODULE_8__/* ["default"] */ .Z, {
2381
+ "aria-label": translate("common.close"),
2278
2382
  className: (_Modal_module_scss__WEBPACK_IMPORTED_MODULE_10___default().closeButton),
2279
2383
  Icon: icons__WEBPACK_IMPORTED_MODULE_5__/* .CrossSquareFill */ .vK,
2280
2384
  tooltip: translate("common.close"),
@@ -2378,11 +2482,11 @@ __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __we
2378
2482
  /* harmony import */ var icons__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(60755);
2379
2483
  /* harmony import */ var parameters__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(74200);
2380
2484
  /* harmony import */ var state__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(64579);
2381
- /* harmony import */ var _SquareButton__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(86889);
2485
+ /* harmony import */ var _IconButton__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(6193);
2382
2486
  /* harmony import */ var _NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(25223);
2383
2487
  /* harmony import */ var _NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default = /*#__PURE__*/__webpack_require__.n(_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7__);
2384
- var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([hooks__WEBPACK_IMPORTED_MODULE_2__, state__WEBPACK_IMPORTED_MODULE_5__, _SquareButton__WEBPACK_IMPORTED_MODULE_6__]);
2385
- ([hooks__WEBPACK_IMPORTED_MODULE_2__, state__WEBPACK_IMPORTED_MODULE_5__, _SquareButton__WEBPACK_IMPORTED_MODULE_6__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
2488
+ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([hooks__WEBPACK_IMPORTED_MODULE_2__, state__WEBPACK_IMPORTED_MODULE_5__, _IconButton__WEBPACK_IMPORTED_MODULE_6__]);
2489
+ ([hooks__WEBPACK_IMPORTED_MODULE_2__, state__WEBPACK_IMPORTED_MODULE_5__, _IconButton__WEBPACK_IMPORTED_MODULE_6__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
2386
2490
 
2387
2491
 
2388
2492
 
@@ -2403,7 +2507,8 @@ const NavButtons = ({ onClear , onShowKeyMap , onShowMenu , onShowRemainingTiles
2403
2507
  children: [
2404
2508
  /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
2405
2509
  className: (_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().group),
2406
- children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_SquareButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
2510
+ children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_IconButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
2511
+ "aria-label": translate("common.clear"),
2407
2512
  className: (_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().button),
2408
2513
  Icon: icons__WEBPACK_IMPORTED_MODULE_3__/* .Eraser */ .Gs,
2409
2514
  tooltip: translate("common.clear"),
@@ -2415,7 +2520,8 @@ const NavButtons = ({ onClear , onShowKeyMap , onShowMenu , onShowRemainingTiles
2415
2520
  }),
2416
2521
  /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
2417
2522
  className: (_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().group),
2418
- children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_SquareButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
2523
+ children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_IconButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
2524
+ "aria-label": translate("menu"),
2419
2525
  className: (_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().button),
2420
2526
  Icon: icons__WEBPACK_IMPORTED_MODULE_3__/* .List */ .aV,
2421
2527
  tooltip: translate("menu"),
@@ -2430,7 +2536,8 @@ const NavButtons = ({ onClear , onShowKeyMap , onShowMenu , onShowRemainingTiles
2430
2536
  children: [
2431
2537
  /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
2432
2538
  className: (_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().group),
2433
- children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_SquareButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
2539
+ children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_IconButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
2540
+ "aria-label": translate("common.clear"),
2434
2541
  className: (_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().button),
2435
2542
  Icon: icons__WEBPACK_IMPORTED_MODULE_3__/* .Eraser */ .Gs,
2436
2543
  tooltip: translate("common.clear"),
@@ -2443,7 +2550,8 @@ const NavButtons = ({ onClear , onShowKeyMap , onShowMenu , onShowRemainingTiles
2443
2550
  /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
2444
2551
  className: (_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().group),
2445
2552
  children: [
2446
- /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_SquareButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
2553
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_IconButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
2554
+ "aria-label": translate("remaining-tiles"),
2447
2555
  className: classnames__WEBPACK_IMPORTED_MODULE_1___default()((_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().button), {
2448
2556
  [(_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().error)]: hasOverusedTiles
2449
2557
  }),
@@ -2451,7 +2559,8 @@ const NavButtons = ({ onClear , onShowKeyMap , onShowMenu , onShowRemainingTiles
2451
2559
  tooltip: translate("remaining-tiles"),
2452
2560
  onClick: onShowRemainingTiles
2453
2561
  }),
2454
- /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_SquareButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
2562
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_IconButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
2563
+ "aria-label": translate("words"),
2455
2564
  className: classnames__WEBPACK_IMPORTED_MODULE_1___default()((_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().button), {
2456
2565
  [(_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().error)]: hasInvalidWords
2457
2566
  }),
@@ -2466,7 +2575,8 @@ const NavButtons = ({ onClear , onShowKeyMap , onShowMenu , onShowRemainingTiles
2466
2575
  }),
2467
2576
  /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
2468
2577
  className: (_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().group),
2469
- children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_SquareButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"].Link */ .Z.Link, {
2578
+ children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_IconButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"].Link */ .Z.Link, {
2579
+ "aria-label": translate("github"),
2470
2580
  className: (_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().button),
2471
2581
  href: parameters__WEBPACK_IMPORTED_MODULE_4__/* .GITHUB_PROJECT_URL */ .h4,
2472
2582
  Icon: icons__WEBPACK_IMPORTED_MODULE_3__/* .Github */ .Ey,
@@ -2481,13 +2591,15 @@ const NavButtons = ({ onClear , onShowKeyMap , onShowMenu , onShowRemainingTiles
2481
2591
  /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
2482
2592
  className: (_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().group),
2483
2593
  children: [
2484
- !isTouchDevice && /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_SquareButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
2594
+ !isTouchDevice && /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_IconButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
2595
+ "aria-label": translate("keyMap"),
2485
2596
  className: (_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().button),
2486
2597
  Icon: icons__WEBPACK_IMPORTED_MODULE_3__/* .Keyboard */ .N1,
2487
2598
  tooltip: translate("keyMap"),
2488
2599
  onClick: onShowKeyMap
2489
2600
  }),
2490
- /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_SquareButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
2601
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_IconButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
2602
+ "aria-label": translate("settings"),
2491
2603
  className: (_NavButtons_module_scss__WEBPACK_IMPORTED_MODULE_7___default().button),
2492
2604
  Icon: icons__WEBPACK_IMPORTED_MODULE_3__/* .Cog */ .Oz,
2493
2605
  tooltip: translate("settings"),
@@ -3101,6 +3213,7 @@ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([stat
3101
3213
  const RackTile = ({ activeIndexRef , character , index , inputRef , size , tile , onChange , onKeyDown })=>{
3102
3214
  const dispatch = (0,react_redux__WEBPACK_IMPORTED_MODULE_3__.useDispatch)();
3103
3215
  const translate = (0,state__WEBPACK_IMPORTED_MODULE_5__/* .useTranslate */ .qM)();
3216
+ const locale = (0,state__WEBPACK_IMPORTED_MODULE_5__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_5__/* .selectLocale */ .fN);
3104
3217
  const config = (0,state__WEBPACK_IMPORTED_MODULE_5__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_5__/* .selectConfig */ .$o);
3105
3218
  const points = (0,state__WEBPACK_IMPORTED_MODULE_5__/* .useTypedSelector */ .ix)((state)=>(0,state__WEBPACK_IMPORTED_MODULE_5__/* .selectCharacterPoints */ .Or)(state, character));
3106
3219
  const isValid = (0,state__WEBPACK_IMPORTED_MODULE_5__/* .useTypedSelector */ .ix)((state)=>(0,state__WEBPACK_IMPORTED_MODULE_5__/* .selectCharacterIsValid */ .AN)(state, character));
@@ -3154,6 +3267,9 @@ const RackTile = ({ activeIndexRef , character , index , inputRef , size , tile
3154
3267
  onKeyDown
3155
3268
  ]);
3156
3269
  return /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_Tile__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
3270
+ "aria-label": translate("rack.tile.location", {
3271
+ index: (index + 1).toLocaleString(locale)
3272
+ }),
3157
3273
  autoFocus: index === 0,
3158
3274
  className: (_Rack_module_scss__WEBPACK_IMPORTED_MODULE_7___default().tile),
3159
3275
  character: character === null ? undefined : character,
@@ -3332,6 +3448,7 @@ const HeaderButton = ({ column })=>{
3332
3448
  dispatch(state__WEBPACK_IMPORTED_MODULE_4__/* .resultsSlice.actions.sort */ ._C.actions.sort(columnId));
3333
3449
  };
3334
3450
  return /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("button", {
3451
+ "aria-label": translate(column.translationKey),
3335
3452
  className: classnames__WEBPACK_IMPORTED_MODULE_1___default()((_Results_module_scss__WEBPACK_IMPORTED_MODULE_7___default().headerButton), column.className),
3336
3453
  type: "button",
3337
3454
  onClick: ()=>handleOrderChange(column.id),
@@ -3416,6 +3533,7 @@ const Result = ({ data , index , style })=>{
3416
3533
  const handleBlur = (event)=>onBlur(result, event);
3417
3534
  const handleFocus = (event)=>onFocus(result, event);
3418
3535
  return /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("button", {
3536
+ "aria-label": result.word,
3419
3537
  className: classnames__WEBPACK_IMPORTED_MODULE_1___default()((_Results_module_scss__WEBPACK_IMPORTED_MODULE_9___default().result), {
3420
3538
  [(_Results_module_scss__WEBPACK_IMPORTED_MODULE_9___default().highlighted)]: index === highlightedIndex
3421
3539
  }),
@@ -3671,6 +3789,7 @@ const SolveButton = ({ className })=>{
3671
3789
  dispatch(state__WEBPACK_IMPORTED_MODULE_3__/* .solveSlice.actions.submit */ .TP.actions.submit());
3672
3790
  };
3673
3791
  return /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_Button__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z, {
3792
+ "aria-label": translate("results.solve"),
3674
3793
  className: className,
3675
3794
  disabled: isLoading || !isOutdated || !hasTiles,
3676
3795
  Icon: icons__WEBPACK_IMPORTED_MODULE_2__/* .Search */ .HN,
@@ -3994,6 +4113,7 @@ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([hook
3994
4113
  // eslint-disable-next-line max-statements
3995
4114
  const Solver = ({ className , height , width , onShowResults })=>{
3996
4115
  const dispatch = (0,react_redux__WEBPACK_IMPORTED_MODULE_3__.useDispatch)();
4116
+ const translate = (0,state__WEBPACK_IMPORTED_MODULE_7__/* .useTranslate */ .qM)();
3997
4117
  const isTouchDevice = (0,hooks__WEBPACK_IMPORTED_MODULE_5__/* .useIsTouchDevice */ .YQ)();
3998
4118
  const [bottomContainerRef, { height: bottomContainerHeight }] = (0,react_use__WEBPACK_IMPORTED_MODULE_4__.useMeasure)();
3999
4119
  const [resultsContainerRef, { width: resultsContainerWidth }] = (0,react_use__WEBPACK_IMPORTED_MODULE_4__.useMeasure)();
@@ -4004,7 +4124,10 @@ const Solver = ({ className , height , width , onShowResults })=>{
4004
4124
  const maxBoardWidth = width - resultsContainerWidth - (isLessThanL ? 0 : componentsSpacing) - 2 * componentsSpacing;
4005
4125
  const maxBoardHeight = Math.max(height - bottomContainerHeight, isLessThanL ? 0 : parameters__WEBPACK_IMPORTED_MODULE_6__/* .COLUMN_MIN_HEIGHT */ .z, isLessThanM ? Number.POSITIVE_INFINITY : 0);
4006
4126
  const config = (0,state__WEBPACK_IMPORTED_MODULE_7__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_7__/* .selectConfig */ .$o);
4127
+ const error = (0,state__WEBPACK_IMPORTED_MODULE_7__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_7__/* .selectSolveError */ .Rn);
4128
+ const isOutdated = (0,state__WEBPACK_IMPORTED_MODULE_7__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_7__/* .selectAreResultsOutdated */ .Mj);
4007
4129
  const resultCandidate = (0,state__WEBPACK_IMPORTED_MODULE_7__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_7__/* .selectResultCandidate */ .Xk);
4130
+ const allResults = (0,state__WEBPACK_IMPORTED_MODULE_7__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_7__/* .selectSortedResults */ .f2);
4008
4131
  const results = (0,state__WEBPACK_IMPORTED_MODULE_7__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_7__/* .selectSortedFilteredResults */ .dN);
4009
4132
  const [bestResult] = results || [];
4010
4133
  const cellWidth = (maxBoardWidth - (config.boardWidth + 1) * parameters__WEBPACK_IMPORTED_MODULE_6__/* .BORDER_WIDTH */ .YF) / config.boardWidth;
@@ -4056,12 +4179,14 @@ const Solver = ({ className , height , width , onShowResults })=>{
4056
4179
  dispatch(state__WEBPACK_IMPORTED_MODULE_7__/* .solveSlice.actions.submit */ .TP.actions.submit());
4057
4180
  };
4058
4181
  (0,react__WEBPACK_IMPORTED_MODULE_2__.useEffect)(()=>{
4059
- if (bestResult) {
4182
+ if (isLessThanL && bestResult && !isOutdated) {
4060
4183
  dispatch(state__WEBPACK_IMPORTED_MODULE_7__/* .resultsSlice.actions.changeResultCandidate */ ._C.actions.changeResultCandidate(bestResult));
4061
4184
  }
4062
4185
  }, [
4063
4186
  bestResult,
4064
- dispatch
4187
+ dispatch,
4188
+ isLessThanL,
4189
+ isOutdated
4065
4190
  ]);
4066
4191
  return /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
4067
4192
  className: classnames__WEBPACK_IMPORTED_MODULE_1___default()((_Solver_module_scss__WEBPACK_IMPORTED_MODULE_15___default().solver), className),
@@ -4140,12 +4265,26 @@ const Solver = ({ className , height , width , onShowResults })=>{
4140
4265
  })
4141
4266
  ]
4142
4267
  }),
4143
- isLessThanL && /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_components__WEBPACK_IMPORTED_MODULE_14__/* .MobileControls */ .lc, {
4268
+ isLessThanL && /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
4144
4269
  className: (_Solver_module_scss__WEBPACK_IMPORTED_MODULE_15___default().controls),
4145
4270
  style: {
4146
4271
  maxWidth: maxControlsWidth
4147
4272
  },
4148
- onShowResults: onShowResults
4273
+ children: [
4274
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_components__WEBPACK_IMPORTED_MODULE_14__/* .ResultCandidatePicker */ .WI, {
4275
+ onResultClick: onShowResults
4276
+ }),
4277
+ error && /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_components__WEBPACK_IMPORTED_MODULE_14__/* .EmptyState */ .ub, {
4278
+ className: (_Solver_module_scss__WEBPACK_IMPORTED_MODULE_15___default().emptyState),
4279
+ variant: "error",
4280
+ children: error.message
4281
+ }),
4282
+ allResults && allResults.length === 0 && !isOutdated && /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_components__WEBPACK_IMPORTED_MODULE_14__/* .EmptyState */ .ub, {
4283
+ className: (_Solver_module_scss__WEBPACK_IMPORTED_MODULE_15___default().emptyState),
4284
+ variant: "warning",
4285
+ children: translate("results.empty-state.no-results")
4286
+ })
4287
+ ]
4149
4288
  })
4150
4289
  ]
4151
4290
  })
@@ -4159,74 +4298,6 @@ const Solver = ({ className , height , width , onShowResults })=>{
4159
4298
  };
4160
4299
  /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Solver);
4161
4300
 
4162
- __webpack_async_result__();
4163
- } catch(e) { __webpack_async_result__(e); } });
4164
-
4165
- /***/ }),
4166
-
4167
- /***/ 43004:
4168
- /***/ ((module, __webpack_exports__, __webpack_require__) => {
4169
-
4170
- "use strict";
4171
- __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __webpack_async_result__) => { try {
4172
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
4173
- /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__)
4174
- /* harmony export */ });
4175
- /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20997);
4176
- /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__);
4177
- /* harmony import */ var react_redux__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6022);
4178
- /* harmony import */ var react_redux__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react_redux__WEBPACK_IMPORTED_MODULE_1__);
4179
- /* harmony import */ var icons__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(60755);
4180
- /* harmony import */ var state__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(64579);
4181
- /* harmony import */ var _Button__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(96753);
4182
- /* harmony import */ var _ApplyButton_module_scss__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(36456);
4183
- /* harmony import */ var _ApplyButton_module_scss__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_ApplyButton_module_scss__WEBPACK_IMPORTED_MODULE_5__);
4184
- var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([state__WEBPACK_IMPORTED_MODULE_3__, _Button__WEBPACK_IMPORTED_MODULE_4__]);
4185
- ([state__WEBPACK_IMPORTED_MODULE_3__, _Button__WEBPACK_IMPORTED_MODULE_4__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
4186
-
4187
-
4188
-
4189
-
4190
-
4191
-
4192
- const ApplyButton = ({ className })=>{
4193
- const dispatch = (0,react_redux__WEBPACK_IMPORTED_MODULE_1__.useDispatch)();
4194
- const resultCandidate = (0,state__WEBPACK_IMPORTED_MODULE_3__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_3__/* .selectResultCandidate */ .Xk);
4195
- const handleClick = ()=>{
4196
- if (resultCandidate) {
4197
- dispatch(state__WEBPACK_IMPORTED_MODULE_3__/* .resultsSlice.actions.applyResult */ ._C.actions.applyResult(resultCandidate));
4198
- }
4199
- };
4200
- return /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_Button__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z, {
4201
- className: className,
4202
- disabled: !resultCandidate,
4203
- Icon: icons__WEBPACK_IMPORTED_MODULE_2__/* .Check */ .Jr,
4204
- iconClassName: (_ApplyButton_module_scss__WEBPACK_IMPORTED_MODULE_5___default().icon),
4205
- type: "submit",
4206
- variant: "primary",
4207
- onClick: handleClick
4208
- });
4209
- };
4210
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ApplyButton);
4211
-
4212
- __webpack_async_result__();
4213
- } catch(e) { __webpack_async_result__(e); } });
4214
-
4215
- /***/ }),
4216
-
4217
- /***/ 13326:
4218
- /***/ ((module, __webpack_exports__, __webpack_require__) => {
4219
-
4220
- "use strict";
4221
- __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __webpack_async_result__) => { try {
4222
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
4223
- /* harmony export */ "Z": () => (/* reexport safe */ _ApplyButton__WEBPACK_IMPORTED_MODULE_0__.Z)
4224
- /* harmony export */ });
4225
- /* harmony import */ var _ApplyButton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(43004);
4226
- var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_ApplyButton__WEBPACK_IMPORTED_MODULE_0__]);
4227
- _ApplyButton__WEBPACK_IMPORTED_MODULE_0__ = (__webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__)[0];
4228
-
4229
-
4230
4301
  __webpack_async_result__();
4231
4302
  } catch(e) { __webpack_async_result__(e); } });
4232
4303
 
@@ -4293,7 +4364,7 @@ const EmptyState = ({ children , className , variant , ...props })=>{
4293
4364
 
4294
4365
  /***/ }),
4295
4366
 
4296
- /***/ 76419:
4367
+ /***/ 93056:
4297
4368
  /***/ ((module, __webpack_exports__, __webpack_require__) => {
4298
4369
 
4299
4370
  "use strict";
@@ -4303,73 +4374,63 @@ __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __we
4303
4374
  /* harmony export */ });
4304
4375
  /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20997);
4305
4376
  /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__);
4306
- /* harmony import */ var state__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(64579);
4307
- /* harmony import */ var _EmptyState__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43939);
4308
- /* harmony import */ var _ResultCandidatePicker__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(95697);
4309
- var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([state__WEBPACK_IMPORTED_MODULE_1__, _ResultCandidatePicker__WEBPACK_IMPORTED_MODULE_3__]);
4310
- ([state__WEBPACK_IMPORTED_MODULE_1__, _ResultCandidatePicker__WEBPACK_IMPORTED_MODULE_3__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
4377
+ /* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(59003);
4378
+ /* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);
4379
+ /* harmony import */ var react_redux__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6022);
4380
+ /* harmony import */ var react_redux__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(react_redux__WEBPACK_IMPORTED_MODULE_2__);
4381
+ /* harmony import */ var icons__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(60755);
4382
+ /* harmony import */ var state__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(64579);
4383
+ /* harmony import */ var _Button__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(96753);
4384
+ /* harmony import */ var _InsertButton_module_scss__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(99725);
4385
+ /* harmony import */ var _InsertButton_module_scss__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(_InsertButton_module_scss__WEBPACK_IMPORTED_MODULE_6__);
4386
+ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([state__WEBPACK_IMPORTED_MODULE_4__, _Button__WEBPACK_IMPORTED_MODULE_5__]);
4387
+ ([state__WEBPACK_IMPORTED_MODULE_4__, _Button__WEBPACK_IMPORTED_MODULE_5__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
4311
4388
 
4312
4389
 
4313
4390
 
4314
4391
 
4315
- // eslint-disable-next-line max-statements
4316
- const MobileControls = ({ onShowResults , ...props })=>{
4317
- const translate = (0,state__WEBPACK_IMPORTED_MODULE_1__/* .useTranslate */ .qM)();
4318
- const resultCandidate = (0,state__WEBPACK_IMPORTED_MODULE_1__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_1__/* .selectResultCandidate */ .Xk);
4319
- const isOutdated = (0,state__WEBPACK_IMPORTED_MODULE_1__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_1__/* .selectAreResultsOutdated */ .Mj);
4320
- const allResults = (0,state__WEBPACK_IMPORTED_MODULE_1__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_1__/* .selectSortedResults */ .f2);
4321
- const error = (0,state__WEBPACK_IMPORTED_MODULE_1__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_1__/* .selectSolveError */ .Rn);
4322
- return /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
4323
- ...props,
4324
- children: [
4325
- typeof error !== "undefined" && /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_EmptyState__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z, {
4326
- variant: "error",
4327
- onClick: onShowResults,
4328
- children: error.message
4329
- }),
4330
- typeof error === "undefined" && typeof allResults === "undefined" && /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_EmptyState__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z, {
4331
- variant: "info",
4332
- onClick: onShowResults,
4333
- children: translate("results.empty-state.uninitialized")
4334
- }),
4335
- typeof error === "undefined" && typeof allResults !== "undefined" && /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)(react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.Fragment, {
4336
- children: [
4337
- (isOutdated || !resultCandidate) && /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_EmptyState__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z, {
4338
- variant: "info",
4339
- onClick: onShowResults,
4340
- children: translate("results.empty-state.outdated")
4341
- }),
4342
- !isOutdated && allResults.length === 0 && /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_EmptyState__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z, {
4343
- variant: "warning",
4344
- onClick: onShowResults,
4345
- children: translate("results.empty-state.no-results")
4346
- }),
4347
- !isOutdated && allResults.length > 0 && resultCandidate && /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_ResultCandidatePicker__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z, {
4348
- onClick: onShowResults
4349
- })
4350
- ]
4351
- })
4352
- ]
4392
+
4393
+
4394
+
4395
+ const InsertButton = ({ className })=>{
4396
+ const dispatch = (0,react_redux__WEBPACK_IMPORTED_MODULE_2__.useDispatch)();
4397
+ const translate = (0,state__WEBPACK_IMPORTED_MODULE_4__/* .useTranslate */ .qM)();
4398
+ const resultCandidate = (0,state__WEBPACK_IMPORTED_MODULE_4__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_4__/* .selectResultCandidate */ .Xk);
4399
+ const isOutdated = (0,state__WEBPACK_IMPORTED_MODULE_4__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_4__/* .selectAreResultsOutdated */ .Mj);
4400
+ const handleClick = ()=>{
4401
+ if (resultCandidate) {
4402
+ dispatch(state__WEBPACK_IMPORTED_MODULE_4__/* .resultsSlice.actions.applyResult */ ._C.actions.applyResult(resultCandidate));
4403
+ }
4404
+ };
4405
+ return /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_Button__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, {
4406
+ "aria-label": translate("results.insert"),
4407
+ className: classnames__WEBPACK_IMPORTED_MODULE_1___default()((_InsertButton_module_scss__WEBPACK_IMPORTED_MODULE_6___default().insertButton), className),
4408
+ disabled: isOutdated || !resultCandidate,
4409
+ Icon: icons__WEBPACK_IMPORTED_MODULE_3__/* .Check */ .Jr,
4410
+ iconClassName: (_InsertButton_module_scss__WEBPACK_IMPORTED_MODULE_6___default().icon),
4411
+ type: "submit",
4412
+ variant: "primary",
4413
+ onClick: handleClick
4353
4414
  });
4354
4415
  };
4355
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (MobileControls);
4416
+ /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (InsertButton);
4356
4417
 
4357
4418
  __webpack_async_result__();
4358
4419
  } catch(e) { __webpack_async_result__(e); } });
4359
4420
 
4360
4421
  /***/ }),
4361
4422
 
4362
- /***/ 46136:
4423
+ /***/ 12343:
4363
4424
  /***/ ((module, __webpack_exports__, __webpack_require__) => {
4364
4425
 
4365
4426
  "use strict";
4366
4427
  __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __webpack_async_result__) => { try {
4367
4428
  /* harmony export */ __webpack_require__.d(__webpack_exports__, {
4368
- /* harmony export */ "Z": () => (/* reexport safe */ _MobileControls__WEBPACK_IMPORTED_MODULE_0__.Z)
4429
+ /* harmony export */ "Z": () => (/* reexport safe */ _InsertButton__WEBPACK_IMPORTED_MODULE_0__.Z)
4369
4430
  /* harmony export */ });
4370
- /* harmony import */ var _MobileControls__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(76419);
4371
- var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_MobileControls__WEBPACK_IMPORTED_MODULE_0__]);
4372
- _MobileControls__WEBPACK_IMPORTED_MODULE_0__ = (__webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__)[0];
4431
+ /* harmony import */ var _InsertButton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(93056);
4432
+ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_InsertButton__WEBPACK_IMPORTED_MODULE_0__]);
4433
+ _InsertButton__WEBPACK_IMPORTED_MODULE_0__ = (__webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__)[0];
4373
4434
 
4374
4435
 
4375
4436
  __webpack_async_result__();
@@ -4394,11 +4455,11 @@ __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __we
4394
4455
  /* harmony import */ var icons__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(60755);
4395
4456
  /* harmony import */ var state__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(64579);
4396
4457
  /* harmony import */ var _Button__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(96753);
4397
- /* harmony import */ var _ApplyButton__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(13326);
4458
+ /* harmony import */ var _InsertButton__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(12343);
4398
4459
  /* harmony import */ var _ResultCandidatePicker_module_scss__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(50495);
4399
4460
  /* harmony import */ var _ResultCandidatePicker_module_scss__WEBPACK_IMPORTED_MODULE_7___default = /*#__PURE__*/__webpack_require__.n(_ResultCandidatePicker_module_scss__WEBPACK_IMPORTED_MODULE_7__);
4400
- var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([state__WEBPACK_IMPORTED_MODULE_4__, _Button__WEBPACK_IMPORTED_MODULE_5__, _ApplyButton__WEBPACK_IMPORTED_MODULE_6__]);
4401
- ([state__WEBPACK_IMPORTED_MODULE_4__, _Button__WEBPACK_IMPORTED_MODULE_5__, _ApplyButton__WEBPACK_IMPORTED_MODULE_6__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
4461
+ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([state__WEBPACK_IMPORTED_MODULE_4__, _Button__WEBPACK_IMPORTED_MODULE_5__, _InsertButton__WEBPACK_IMPORTED_MODULE_6__]);
4462
+ ([state__WEBPACK_IMPORTED_MODULE_4__, _Button__WEBPACK_IMPORTED_MODULE_5__, _InsertButton__WEBPACK_IMPORTED_MODULE_6__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
4402
4463
 
4403
4464
 
4404
4465
 
@@ -4407,19 +4468,18 @@ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([stat
4407
4468
 
4408
4469
 
4409
4470
 
4410
- const ResultCandidatePicker = ({ className , ...props })=>{
4471
+ const ResultCandidatePicker = ({ className , onResultClick , ...props })=>{
4411
4472
  const dispatch = (0,react_redux__WEBPACK_IMPORTED_MODULE_2__.useDispatch)();
4473
+ const translate = (0,state__WEBPACK_IMPORTED_MODULE_4__/* .useTranslate */ .qM)();
4412
4474
  const locale = (0,state__WEBPACK_IMPORTED_MODULE_4__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_4__/* .selectLocale */ .fN);
4413
4475
  const isOutdated = (0,state__WEBPACK_IMPORTED_MODULE_4__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_4__/* .selectAreResultsOutdated */ .Mj);
4414
4476
  const sortedResults = (0,state__WEBPACK_IMPORTED_MODULE_4__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_4__/* .selectSortedResults */ .f2);
4415
4477
  const results = sortedResults || [];
4416
4478
  const resultCandidate = (0,state__WEBPACK_IMPORTED_MODULE_4__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_4__/* .selectResultCandidate */ .Xk);
4417
- if (!resultCandidate) {
4418
- return null;
4419
- }
4420
- const index = results.findIndex((result)=>result.id === resultCandidate.id);
4421
- const isPreviousDisabled = index <= 0;
4422
- const isNextDisabled = index >= results.length - 1;
4479
+ const index = resultCandidate ? results.findIndex((result)=>result.id === resultCandidate.id) : -1;
4480
+ const disabled = isOutdated || !resultCandidate;
4481
+ const isPreviousDisabled = index <= 0 || disabled;
4482
+ const isNextDisabled = index >= results.length - 1 || disabled;
4423
4483
  const handleNextClick = ()=>{
4424
4484
  if (!isNextDisabled) {
4425
4485
  const nextResult = results[index + 1];
@@ -4440,12 +4500,14 @@ const ResultCandidatePicker = ({ className , ...props })=>{
4440
4500
  className: (_ResultCandidatePicker_module_scss__WEBPACK_IMPORTED_MODULE_7___default().buttons),
4441
4501
  children: [
4442
4502
  /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_Button__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, {
4503
+ "aria-label": translate("common.previous"),
4443
4504
  className: (_ResultCandidatePicker_module_scss__WEBPACK_IMPORTED_MODULE_7___default().button),
4444
4505
  disabled: isPreviousDisabled,
4445
4506
  Icon: icons__WEBPACK_IMPORTED_MODULE_3__/* .ChevronLeft */ .s$,
4446
4507
  onClick: handlePreviousClick
4447
4508
  }),
4448
4509
  /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_Button__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, {
4510
+ "aria-label": translate("common.next"),
4449
4511
  className: (_ResultCandidatePicker_module_scss__WEBPACK_IMPORTED_MODULE_7___default().button),
4450
4512
  disabled: isNextDisabled,
4451
4513
  Icon: icons__WEBPACK_IMPORTED_MODULE_3__/* .ChevronRight */ ._Q,
@@ -4454,17 +4516,27 @@ const ResultCandidatePicker = ({ className , ...props })=>{
4454
4516
  ]
4455
4517
  }),
4456
4518
  /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("button", {
4519
+ "aria-label": translate("results"),
4457
4520
  className: (_ResultCandidatePicker_module_scss__WEBPACK_IMPORTED_MODULE_7___default().resultCandidate),
4458
- disabled: isOutdated,
4521
+ disabled: disabled,
4459
4522
  type: "button",
4523
+ onClick: onResultClick,
4460
4524
  children: [
4461
- /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
4462
- className: (_ResultCandidatePicker_module_scss__WEBPACK_IMPORTED_MODULE_7___default().points),
4463
- children: resultCandidate.points.toLocaleString(locale)
4525
+ resultCandidate && /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)(react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.Fragment, {
4526
+ children: [
4527
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
4528
+ className: (_ResultCandidatePicker_module_scss__WEBPACK_IMPORTED_MODULE_7___default().points),
4529
+ children: resultCandidate.points.toLocaleString(locale)
4530
+ }),
4531
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
4532
+ className: (_ResultCandidatePicker_module_scss__WEBPACK_IMPORTED_MODULE_7___default().word),
4533
+ children: resultCandidate.word
4534
+ })
4535
+ ]
4464
4536
  }),
4465
- /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
4537
+ !resultCandidate && /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
4466
4538
  className: (_ResultCandidatePicker_module_scss__WEBPACK_IMPORTED_MODULE_7___default().word),
4467
- children: resultCandidate.word
4539
+ children: " "
4468
4540
  }),
4469
4541
  /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
4470
4542
  className: (_ResultCandidatePicker_module_scss__WEBPACK_IMPORTED_MODULE_7___default().iconContainer),
@@ -4474,8 +4546,8 @@ const ResultCandidatePicker = ({ className , ...props })=>{
4474
4546
  })
4475
4547
  ]
4476
4548
  }),
4477
- /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_ApplyButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
4478
- className: (_ResultCandidatePicker_module_scss__WEBPACK_IMPORTED_MODULE_7___default().apply)
4549
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_InsertButton__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
4550
+ className: (_ResultCandidatePicker_module_scss__WEBPACK_IMPORTED_MODULE_7___default().insert)
4479
4551
  })
4480
4552
  ]
4481
4553
  });
@@ -4537,6 +4609,7 @@ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([stat
4537
4609
 
4538
4610
  const SolveButton = ({ className , onClick =lib__WEBPACK_IMPORTED_MODULE_4__/* .noop */ .ZT })=>{
4539
4611
  const dispatch = (0,react_redux__WEBPACK_IMPORTED_MODULE_2__.useDispatch)();
4612
+ const translate = (0,state__WEBPACK_IMPORTED_MODULE_5__/* .useTranslate */ .qM)();
4540
4613
  const isLoading = (0,state__WEBPACK_IMPORTED_MODULE_5__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_5__/* .selectIsLoading */ .xU);
4541
4614
  const isOutdated = (0,state__WEBPACK_IMPORTED_MODULE_5__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_5__/* .selectAreResultsOutdated */ .Mj);
4542
4615
  const rack = (0,state__WEBPACK_IMPORTED_MODULE_5__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_5__/* .selectRack */ .QB);
@@ -4546,10 +4619,12 @@ const SolveButton = ({ className , onClick =lib__WEBPACK_IMPORTED_MODULE_4__/* .
4546
4619
  onClick(event);
4547
4620
  };
4548
4621
  return /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_Button__WEBPACK_IMPORTED_MODULE_6__/* ["default"] */ .Z, {
4622
+ "aria-label": translate("results.solve"),
4549
4623
  className: classnames__WEBPACK_IMPORTED_MODULE_1___default()((_SolveButton_module_scss__WEBPACK_IMPORTED_MODULE_7___default().solveButton), className),
4550
4624
  disabled: isLoading || !isOutdated || !hasTiles,
4551
4625
  Icon: icons__WEBPACK_IMPORTED_MODULE_3__/* .Search */ .HN,
4552
4626
  iconClassName: (_SolveButton_module_scss__WEBPACK_IMPORTED_MODULE_7___default().icon),
4627
+ tooltip: translate("results.solve"),
4553
4628
  type: "submit",
4554
4629
  variant: "primary",
4555
4630
  onClick: handleClick
@@ -4586,17 +4661,16 @@ __webpack_async_result__();
4586
4661
  "use strict";
4587
4662
  __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __webpack_async_result__) => { try {
4588
4663
  /* harmony export */ __webpack_require__.d(__webpack_exports__, {
4589
- /* harmony export */ "lc": () => (/* reexport safe */ _MobileControls__WEBPACK_IMPORTED_MODULE_2__.Z),
4590
- /* harmony export */ "ly": () => (/* reexport safe */ _SolveButton__WEBPACK_IMPORTED_MODULE_4__.Z)
4664
+ /* harmony export */ "WI": () => (/* reexport safe */ _ResultCandidatePicker__WEBPACK_IMPORTED_MODULE_2__.Z),
4665
+ /* harmony export */ "ly": () => (/* reexport safe */ _SolveButton__WEBPACK_IMPORTED_MODULE_3__.Z),
4666
+ /* harmony export */ "ub": () => (/* reexport safe */ _EmptyState__WEBPACK_IMPORTED_MODULE_0__.Z)
4591
4667
  /* harmony export */ });
4592
- /* harmony import */ var _ApplyButton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(13326);
4593
- /* harmony import */ var _EmptyState__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43939);
4594
- /* harmony import */ var _MobileControls__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(46136);
4595
- /* harmony import */ var _ResultCandidatePicker__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(95697);
4596
- /* harmony import */ var _SolveButton__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(89797);
4597
- var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_ApplyButton__WEBPACK_IMPORTED_MODULE_0__, _MobileControls__WEBPACK_IMPORTED_MODULE_2__, _ResultCandidatePicker__WEBPACK_IMPORTED_MODULE_3__, _SolveButton__WEBPACK_IMPORTED_MODULE_4__]);
4598
- ([_ApplyButton__WEBPACK_IMPORTED_MODULE_0__, _MobileControls__WEBPACK_IMPORTED_MODULE_2__, _ResultCandidatePicker__WEBPACK_IMPORTED_MODULE_3__, _SolveButton__WEBPACK_IMPORTED_MODULE_4__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
4599
-
4668
+ /* harmony import */ var _EmptyState__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(43939);
4669
+ /* harmony import */ var _InsertButton__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12343);
4670
+ /* harmony import */ var _ResultCandidatePicker__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(95697);
4671
+ /* harmony import */ var _SolveButton__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(89797);
4672
+ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_InsertButton__WEBPACK_IMPORTED_MODULE_1__, _ResultCandidatePicker__WEBPACK_IMPORTED_MODULE_2__, _SolveButton__WEBPACK_IMPORTED_MODULE_3__]);
4673
+ ([_InsertButton__WEBPACK_IMPORTED_MODULE_1__, _ResultCandidatePicker__WEBPACK_IMPORTED_MODULE_2__, _SolveButton__WEBPACK_IMPORTED_MODULE_3__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
4600
4674
 
4601
4675
 
4602
4676
 
@@ -4661,113 +4735,6 @@ const SplashScreen = ({ children , className , contentClassName , onAnimationEnd
4661
4735
 
4662
4736
 
4663
4737
 
4664
- /***/ }),
4665
-
4666
- /***/ 64542:
4667
- /***/ ((module, __webpack_exports__, __webpack_require__) => {
4668
-
4669
- "use strict";
4670
- __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __webpack_async_result__) => { try {
4671
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
4672
- /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__)
4673
- /* harmony export */ });
4674
- /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20997);
4675
- /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__);
4676
- /* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(59003);
4677
- /* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);
4678
- /* harmony import */ var _Tooltip__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7646);
4679
- /* harmony import */ var _SquareButton_module_scss__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(53539);
4680
- /* harmony import */ var _SquareButton_module_scss__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_SquareButton_module_scss__WEBPACK_IMPORTED_MODULE_3__);
4681
- var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_Tooltip__WEBPACK_IMPORTED_MODULE_2__]);
4682
- _Tooltip__WEBPACK_IMPORTED_MODULE_2__ = (__webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__)[0];
4683
-
4684
-
4685
-
4686
-
4687
- const Link = ({ className , Icon , tooltip , ...props })=>{
4688
- const triggerProps = (0,_Tooltip__WEBPACK_IMPORTED_MODULE_2__/* .useTooltip */ .l)(tooltip, props);
4689
- return /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("a", {
4690
- className: classnames__WEBPACK_IMPORTED_MODULE_1___default()((_SquareButton_module_scss__WEBPACK_IMPORTED_MODULE_3___default().squareButton), className),
4691
- ...props,
4692
- ...triggerProps,
4693
- children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("span", {
4694
- className: (_SquareButton_module_scss__WEBPACK_IMPORTED_MODULE_3___default().content),
4695
- children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(Icon, {
4696
- className: (_SquareButton_module_scss__WEBPACK_IMPORTED_MODULE_3___default().icon)
4697
- })
4698
- })
4699
- });
4700
- };
4701
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Link);
4702
-
4703
- __webpack_async_result__();
4704
- } catch(e) { __webpack_async_result__(e); } });
4705
-
4706
- /***/ }),
4707
-
4708
- /***/ 17672:
4709
- /***/ ((module, __webpack_exports__, __webpack_require__) => {
4710
-
4711
- "use strict";
4712
- __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __webpack_async_result__) => { try {
4713
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
4714
- /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__)
4715
- /* harmony export */ });
4716
- /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(20997);
4717
- /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__);
4718
- /* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(59003);
4719
- /* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);
4720
- /* harmony import */ var _Tooltip__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7646);
4721
- /* harmony import */ var _Link__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(64542);
4722
- /* harmony import */ var _SquareButton_module_scss__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(53539);
4723
- /* harmony import */ var _SquareButton_module_scss__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_SquareButton_module_scss__WEBPACK_IMPORTED_MODULE_4__);
4724
- var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_Tooltip__WEBPACK_IMPORTED_MODULE_2__, _Link__WEBPACK_IMPORTED_MODULE_3__]);
4725
- ([_Tooltip__WEBPACK_IMPORTED_MODULE_2__, _Link__WEBPACK_IMPORTED_MODULE_3__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
4726
-
4727
-
4728
-
4729
-
4730
-
4731
- const SquareButton = ({ className , Icon , tooltip , ...props })=>{
4732
- const triggerProps = (0,_Tooltip__WEBPACK_IMPORTED_MODULE_2__/* .useTooltip */ .l)(tooltip, props);
4733
- return /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("button", {
4734
- className: classnames__WEBPACK_IMPORTED_MODULE_1___default()((_SquareButton_module_scss__WEBPACK_IMPORTED_MODULE_4___default().squareButton), className),
4735
- type: "button",
4736
- ...props,
4737
- ...triggerProps,
4738
- children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("span", {
4739
- className: (_SquareButton_module_scss__WEBPACK_IMPORTED_MODULE_4___default().content),
4740
- children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(Icon, {
4741
- className: (_SquareButton_module_scss__WEBPACK_IMPORTED_MODULE_4___default().icon)
4742
- })
4743
- })
4744
- });
4745
- };
4746
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Object.assign(SquareButton, {
4747
- Link: _Link__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z
4748
- }));
4749
-
4750
- __webpack_async_result__();
4751
- } catch(e) { __webpack_async_result__(e); } });
4752
-
4753
- /***/ }),
4754
-
4755
- /***/ 86889:
4756
- /***/ ((module, __webpack_exports__, __webpack_require__) => {
4757
-
4758
- "use strict";
4759
- __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __webpack_async_result__) => { try {
4760
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
4761
- /* harmony export */ "Z": () => (/* reexport safe */ _SquareButton__WEBPACK_IMPORTED_MODULE_0__.Z)
4762
- /* harmony export */ });
4763
- /* harmony import */ var _SquareButton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(17672);
4764
- var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_SquareButton__WEBPACK_IMPORTED_MODULE_0__]);
4765
- _SquareButton__WEBPACK_IMPORTED_MODULE_0__ = (__webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__)[0];
4766
-
4767
-
4768
- __webpack_async_result__();
4769
- } catch(e) { __webpack_async_result__(e); } });
4770
-
4771
4738
  /***/ }),
4772
4739
 
4773
4740
  /***/ 28887:
@@ -4878,7 +4845,7 @@ state__WEBPACK_IMPORTED_MODULE_4__ = (__webpack_async_dependencies__.then ? (awa
4878
4845
 
4879
4846
 
4880
4847
 
4881
- const Tile = ({ autoFocus , className , character ="" , disabled , highlighted , inputRef: ref , isBlank , isValid , placeholder , points , raised , size , tabIndex , onChange , onFocus =lib__WEBPACK_IMPORTED_MODULE_3__/* .noop */ .ZT , onKeyDown =lib__WEBPACK_IMPORTED_MODULE_3__/* .noop */ .ZT })=>{
4848
+ const Tile = ({ "aria-label": ariaLabel , autoFocus , className , character ="" , disabled , highlighted , inputRef: ref , isBlank , isValid , placeholder , points , raised , size , tabIndex , onChange , onFocus =lib__WEBPACK_IMPORTED_MODULE_3__/* .noop */ .ZT , onKeyDown =lib__WEBPACK_IMPORTED_MODULE_3__/* .noop */ .ZT })=>{
4882
4849
  const locale = (0,state__WEBPACK_IMPORTED_MODULE_4__/* .useTypedSelector */ .ix)(state__WEBPACK_IMPORTED_MODULE_4__/* .selectLocale */ .fN);
4883
4850
  const { pointsFontSize , tileFontSize , tileSize } = (0,lib__WEBPACK_IMPORTED_MODULE_3__/* .getTileSizes */ .vc)(size);
4884
4851
  const style = (0,react__WEBPACK_IMPORTED_MODULE_2__.useMemo)(()=>({
@@ -4916,6 +4883,7 @@ const Tile = ({ autoFocus , className , character ="" , disabled , highlighted ,
4916
4883
  inputRef
4917
4884
  ]);
4918
4885
  return /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_TilePure__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, {
4886
+ "aria-label": ariaLabel,
4919
4887
  autoFocus: autoFocus,
4920
4888
  canShowPoints: canShowPoints,
4921
4889
  character: character,
@@ -4966,7 +4934,7 @@ __webpack_async_result__();
4966
4934
 
4967
4935
 
4968
4936
 
4969
- const TilePure = ({ autoFocus , canShowPoints , character , characterStyle , className , disabled , highlighted , inputRef , isBlank , isValid , placeholder , points , pointsFormatted , pointsStyle , raised , style , tabIndex , onChange , onFocus , onKeyDown })=>/*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
4937
+ const TilePure = ({ "aria-label": ariaLabel , autoFocus , canShowPoints , character , characterStyle , className , disabled , highlighted , inputRef , isBlank , isValid , placeholder , points , pointsFormatted , pointsStyle , raised , style , tabIndex , onChange , onFocus , onKeyDown })=>/*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
4970
4938
  className: classnames__WEBPACK_IMPORTED_MODULE_1___default()((_Tile_module_scss__WEBPACK_IMPORTED_MODULE_4___default().tile), className, {
4971
4939
  [(_Tile_module_scss__WEBPACK_IMPORTED_MODULE_4___default().blank)]: isBlank,
4972
4940
  [(_Tile_module_scss__WEBPACK_IMPORTED_MODULE_4___default().disabled)]: disabled,
@@ -4983,6 +4951,7 @@ const TilePure = ({ autoFocus , canShowPoints , character , characterStyle , cla
4983
4951
  style: style,
4984
4952
  children: [
4985
4953
  /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("input", {
4954
+ "aria-label": ariaLabel,
4986
4955
  autoCapitalize: "none",
4987
4956
  autoComplete: "off",
4988
4957
  autoCorrect: "off",
@@ -5130,8 +5099,10 @@ hooks__WEBPACK_IMPORTED_MODULE_5__ = (__webpack_async_dependencies__.then ? (awa
5130
5099
 
5131
5100
 
5132
5101
 
5102
+ // eslint-disable-next-line max-statements
5133
5103
  const useTooltip = (tooltip, { className , placement ="top" , onBlur =lib__WEBPACK_IMPORTED_MODULE_6__/* .noop */ .ZT , onFocus =lib__WEBPACK_IMPORTED_MODULE_6__/* .noop */ .ZT , onMouseOut =lib__WEBPACK_IMPORTED_MODULE_6__/* .noop */ .ZT , onMouseOver =lib__WEBPACK_IMPORTED_MODULE_6__/* .noop */ .ZT } = {})=>{
5134
5104
  const id = (0,hooks__WEBPACK_IMPORTED_MODULE_5__/* .useUniqueId */ .Ld)();
5105
+ const isTouchDevice = (0,hooks__WEBPACK_IMPORTED_MODULE_5__/* .useIsTouchDevice */ .YQ)();
5135
5106
  const isEnabled = Boolean(tooltip) || tooltip === 0;
5136
5107
  const isMounted = (0,react_use__WEBPACK_IMPORTED_MODULE_4__.useMountedState)();
5137
5108
  const [isShown, setIsShown] = (0,react__WEBPACK_IMPORTED_MODULE_2__.useState)(false);
@@ -5181,7 +5152,7 @@ const useTooltip = (tooltip, { className , placement ="top" , onBlur =lib__WEBPA
5181
5152
  }, [
5182
5153
  onMouseOver
5183
5154
  ]);
5184
- const triggerProps = (0,react__WEBPACK_IMPORTED_MODULE_2__.useMemo)(()=>({
5155
+ const mouseTriggerProps = (0,react__WEBPACK_IMPORTED_MODULE_2__.useMemo)(()=>({
5185
5156
  ...ariaAttributes,
5186
5157
  ref: setReferenceElement,
5187
5158
  onBlur: handleBlur,
@@ -5195,6 +5166,13 @@ const useTooltip = (tooltip, { className , placement ="top" , onBlur =lib__WEBPA
5195
5166
  handleMouseOut,
5196
5167
  handleMouseOver
5197
5168
  ]);
5169
+ const touchTriggerProps = (0,react__WEBPACK_IMPORTED_MODULE_2__.useMemo)(()=>({
5170
+ ...ariaAttributes,
5171
+ ref: setReferenceElement
5172
+ }), [
5173
+ ariaAttributes
5174
+ ]);
5175
+ const triggerProps = isTouchDevice ? touchTriggerProps : mouseTriggerProps;
5198
5176
  (0,react_use__WEBPACK_IMPORTED_MODULE_4__.useRafLoop)(()=>{
5199
5177
  if (isMounted() && update) {
5200
5178
  update();
@@ -5278,19 +5256,19 @@ const Well = /*#__PURE__*/ (0,external_react_.forwardRef)(({ children , classNam
5278
5256
  __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __webpack_async_result__) => { try {
5279
5257
  /* harmony export */ __webpack_require__.d(__webpack_exports__, {
5280
5258
  /* harmony export */ "Ct": () => (/* reexport safe */ _Badge__WEBPACK_IMPORTED_MODULE_0__.Z),
5281
- /* harmony export */ "Ex": () => (/* reexport safe */ _Progress__WEBPACK_IMPORTED_MODULE_15__.Z),
5282
- /* harmony export */ "ME": () => (/* reexport safe */ _Solver__WEBPACK_IMPORTED_MODULE_21__.Z),
5283
- /* harmony export */ "TR": () => (/* reexport safe */ _Logo__WEBPACK_IMPORTED_MODULE_9__.Z),
5284
- /* harmony export */ "TX": () => (/* reexport safe */ _NotFound__WEBPACK_IMPORTED_MODULE_13__.Z),
5285
- /* harmony export */ "Y8": () => (/* reexport safe */ _Radio__WEBPACK_IMPORTED_MODULE_17__.Z),
5286
- /* harmony export */ "_m": () => (/* reexport safe */ _NavButtons__WEBPACK_IMPORTED_MODULE_12__.Z),
5287
- /* harmony export */ "hL": () => (/* reexport safe */ _LogoSplashScreen__WEBPACK_IMPORTED_MODULE_10__.Z),
5259
+ /* harmony export */ "Ex": () => (/* reexport safe */ _Progress__WEBPACK_IMPORTED_MODULE_16__.Z),
5260
+ /* harmony export */ "ME": () => (/* reexport safe */ _Solver__WEBPACK_IMPORTED_MODULE_22__.Z),
5261
+ /* harmony export */ "TR": () => (/* reexport safe */ _Logo__WEBPACK_IMPORTED_MODULE_10__.Z),
5262
+ /* harmony export */ "TX": () => (/* reexport safe */ _NotFound__WEBPACK_IMPORTED_MODULE_14__.Z),
5263
+ /* harmony export */ "Y8": () => (/* reexport safe */ _Radio__WEBPACK_IMPORTED_MODULE_18__.Z),
5264
+ /* harmony export */ "_m": () => (/* reexport safe */ _NavButtons__WEBPACK_IMPORTED_MODULE_13__.Z),
5265
+ /* harmony export */ "hL": () => (/* reexport safe */ _LogoSplashScreen__WEBPACK_IMPORTED_MODULE_11__.Z),
5288
5266
  /* harmony export */ "n9": () => (/* reexport safe */ _Tile__WEBPACK_IMPORTED_MODULE_26__.Z),
5289
- /* harmony export */ "ne": () => (/* reexport safe */ _Sizer__WEBPACK_IMPORTED_MODULE_20__.Z),
5290
- /* harmony export */ "sr": () => (/* reexport safe */ _Key__WEBPACK_IMPORTED_MODULE_7__.Z),
5267
+ /* harmony export */ "ne": () => (/* reexport safe */ _Sizer__WEBPACK_IMPORTED_MODULE_21__.Z),
5268
+ /* harmony export */ "sr": () => (/* reexport safe */ _Key__WEBPACK_IMPORTED_MODULE_8__.Z),
5291
5269
  /* harmony export */ "tW": () => (/* reexport safe */ _Well__WEBPACK_IMPORTED_MODULE_28__.Z),
5292
- /* harmony export */ "u9": () => (/* reexport safe */ _Results__WEBPACK_IMPORTED_MODULE_18__.Z),
5293
- /* harmony export */ "u_": () => (/* reexport safe */ _Modal__WEBPACK_IMPORTED_MODULE_11__.Z),
5270
+ /* harmony export */ "u9": () => (/* reexport safe */ _Results__WEBPACK_IMPORTED_MODULE_19__.Z),
5271
+ /* harmony export */ "u_": () => (/* reexport safe */ _Modal__WEBPACK_IMPORTED_MODULE_12__.Z),
5294
5272
  /* harmony export */ "uz": () => (/* reexport safe */ _SvgFontFix__WEBPACK_IMPORTED_MODULE_25__.Z),
5295
5273
  /* harmony export */ "zx": () => (/* reexport safe */ _Button__WEBPACK_IMPORTED_MODULE_2__.Z)
5296
5274
  /* harmony export */ });
@@ -5301,30 +5279,30 @@ __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __we
5301
5279
  /* harmony import */ var _Dictionary__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(62166);
5302
5280
  /* harmony import */ var _DictionaryInput__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(40105);
5303
5281
  /* harmony import */ var _EmptyState__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(18681);
5304
- /* harmony import */ var _Key__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(41992);
5305
- /* harmony import */ var _Loading__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(84198);
5306
- /* harmony import */ var _Logo__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(2622);
5307
- /* harmony import */ var _LogoSplashScreen__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(78395);
5308
- /* harmony import */ var _Modal__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(85906);
5309
- /* harmony import */ var _NavButtons__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(54723);
5310
- /* harmony import */ var _NotFound__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(9527);
5311
- /* harmony import */ var _PlainTiles__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(31773);
5312
- /* harmony import */ var _Progress__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(6465);
5313
- /* harmony import */ var _Rack__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(30007);
5314
- /* harmony import */ var _Radio__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(84985);
5315
- /* harmony import */ var _Results__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(21678);
5316
- /* harmony import */ var _ResultsInput__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(92833);
5317
- /* harmony import */ var _Sizer__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(77843);
5318
- /* harmony import */ var _Solver__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(89058);
5319
- /* harmony import */ var _SplashScreen__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(14676);
5320
- /* harmony import */ var _SquareButton__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(86889);
5282
+ /* harmony import */ var _IconButton__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(6193);
5283
+ /* harmony import */ var _Key__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(41992);
5284
+ /* harmony import */ var _Loading__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(84198);
5285
+ /* harmony import */ var _Logo__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(2622);
5286
+ /* harmony import */ var _LogoSplashScreen__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(78395);
5287
+ /* harmony import */ var _Modal__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(85906);
5288
+ /* harmony import */ var _NavButtons__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(54723);
5289
+ /* harmony import */ var _NotFound__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(9527);
5290
+ /* harmony import */ var _PlainTiles__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(31773);
5291
+ /* harmony import */ var _Progress__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(6465);
5292
+ /* harmony import */ var _Rack__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(30007);
5293
+ /* harmony import */ var _Radio__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(84985);
5294
+ /* harmony import */ var _Results__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(21678);
5295
+ /* harmony import */ var _ResultsInput__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(92833);
5296
+ /* harmony import */ var _Sizer__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(77843);
5297
+ /* harmony import */ var _Solver__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(89058);
5298
+ /* harmony import */ var _SplashScreen__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(14676);
5321
5299
  /* harmony import */ var _SvgFontCss__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(28887);
5322
5300
  /* harmony import */ var _SvgFontFix__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(33435);
5323
5301
  /* harmony import */ var _Tile__WEBPACK_IMPORTED_MODULE_26__ = __webpack_require__(57243);
5324
5302
  /* harmony import */ var _Tooltip__WEBPACK_IMPORTED_MODULE_27__ = __webpack_require__(7646);
5325
5303
  /* harmony import */ var _Well__WEBPACK_IMPORTED_MODULE_28__ = __webpack_require__(34473);
5326
- var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_Board__WEBPACK_IMPORTED_MODULE_1__, _Button__WEBPACK_IMPORTED_MODULE_2__, _Dictionary__WEBPACK_IMPORTED_MODULE_4__, _DictionaryInput__WEBPACK_IMPORTED_MODULE_5__, _EmptyState__WEBPACK_IMPORTED_MODULE_6__, _Loading__WEBPACK_IMPORTED_MODULE_8__, _Modal__WEBPACK_IMPORTED_MODULE_11__, _NavButtons__WEBPACK_IMPORTED_MODULE_12__, _NotFound__WEBPACK_IMPORTED_MODULE_13__, _PlainTiles__WEBPACK_IMPORTED_MODULE_14__, _Progress__WEBPACK_IMPORTED_MODULE_15__, _Rack__WEBPACK_IMPORTED_MODULE_16__, _Results__WEBPACK_IMPORTED_MODULE_18__, _ResultsInput__WEBPACK_IMPORTED_MODULE_19__, _Solver__WEBPACK_IMPORTED_MODULE_21__, _SquareButton__WEBPACK_IMPORTED_MODULE_23__, _Tile__WEBPACK_IMPORTED_MODULE_26__, _Tooltip__WEBPACK_IMPORTED_MODULE_27__]);
5327
- ([_Board__WEBPACK_IMPORTED_MODULE_1__, _Button__WEBPACK_IMPORTED_MODULE_2__, _Dictionary__WEBPACK_IMPORTED_MODULE_4__, _DictionaryInput__WEBPACK_IMPORTED_MODULE_5__, _EmptyState__WEBPACK_IMPORTED_MODULE_6__, _Loading__WEBPACK_IMPORTED_MODULE_8__, _Modal__WEBPACK_IMPORTED_MODULE_11__, _NavButtons__WEBPACK_IMPORTED_MODULE_12__, _NotFound__WEBPACK_IMPORTED_MODULE_13__, _PlainTiles__WEBPACK_IMPORTED_MODULE_14__, _Progress__WEBPACK_IMPORTED_MODULE_15__, _Rack__WEBPACK_IMPORTED_MODULE_16__, _Results__WEBPACK_IMPORTED_MODULE_18__, _ResultsInput__WEBPACK_IMPORTED_MODULE_19__, _Solver__WEBPACK_IMPORTED_MODULE_21__, _SquareButton__WEBPACK_IMPORTED_MODULE_23__, _Tile__WEBPACK_IMPORTED_MODULE_26__, _Tooltip__WEBPACK_IMPORTED_MODULE_27__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
5304
+ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_Board__WEBPACK_IMPORTED_MODULE_1__, _Button__WEBPACK_IMPORTED_MODULE_2__, _Dictionary__WEBPACK_IMPORTED_MODULE_4__, _DictionaryInput__WEBPACK_IMPORTED_MODULE_5__, _EmptyState__WEBPACK_IMPORTED_MODULE_6__, _IconButton__WEBPACK_IMPORTED_MODULE_7__, _Loading__WEBPACK_IMPORTED_MODULE_9__, _Modal__WEBPACK_IMPORTED_MODULE_12__, _NavButtons__WEBPACK_IMPORTED_MODULE_13__, _NotFound__WEBPACK_IMPORTED_MODULE_14__, _PlainTiles__WEBPACK_IMPORTED_MODULE_15__, _Progress__WEBPACK_IMPORTED_MODULE_16__, _Rack__WEBPACK_IMPORTED_MODULE_17__, _Results__WEBPACK_IMPORTED_MODULE_19__, _ResultsInput__WEBPACK_IMPORTED_MODULE_20__, _Solver__WEBPACK_IMPORTED_MODULE_22__, _Tile__WEBPACK_IMPORTED_MODULE_26__, _Tooltip__WEBPACK_IMPORTED_MODULE_27__]);
5305
+ ([_Board__WEBPACK_IMPORTED_MODULE_1__, _Button__WEBPACK_IMPORTED_MODULE_2__, _Dictionary__WEBPACK_IMPORTED_MODULE_4__, _DictionaryInput__WEBPACK_IMPORTED_MODULE_5__, _EmptyState__WEBPACK_IMPORTED_MODULE_6__, _IconButton__WEBPACK_IMPORTED_MODULE_7__, _Loading__WEBPACK_IMPORTED_MODULE_9__, _Modal__WEBPACK_IMPORTED_MODULE_12__, _NavButtons__WEBPACK_IMPORTED_MODULE_13__, _NotFound__WEBPACK_IMPORTED_MODULE_14__, _PlainTiles__WEBPACK_IMPORTED_MODULE_15__, _Progress__WEBPACK_IMPORTED_MODULE_16__, _Rack__WEBPACK_IMPORTED_MODULE_17__, _Results__WEBPACK_IMPORTED_MODULE_19__, _ResultsInput__WEBPACK_IMPORTED_MODULE_20__, _Solver__WEBPACK_IMPORTED_MODULE_22__, _Tile__WEBPACK_IMPORTED_MODULE_26__, _Tooltip__WEBPACK_IMPORTED_MODULE_27__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
5328
5306
 
5329
5307
 
5330
5308
 
@@ -5887,8 +5865,7 @@ var SvgArrowDown = function SvgArrowDown(props) {
5887
5865
  xmlns: "http://www.w3.org/2000/svg"
5888
5866
  }, props), _path || (_path = /*#__PURE__*/external_react_.createElement("path", {
5889
5867
  d: "M8 1a.5.5 0 0 1 .5.5v11.793l3.146-3.147a.5.5 0 0 1 .708.708l-4 4a.5.5 0 0 1-.708 0l-4-4a.5.5 0 0 1 .708-.708L7.5 13.293V1.5A.5.5 0 0 1 8 1z",
5890
- fill: "currentColor",
5891
- fillRule: "evenodd"
5868
+ fill: "currentColor"
5892
5869
  })));
5893
5870
  };
5894
5871
  /* harmony default export */ const ArrowDown = (SvgArrowDown);
@@ -5902,8 +5879,7 @@ var SvgArrowLeft = function SvgArrowLeft(props) {
5902
5879
  xmlns: "http://www.w3.org/2000/svg"
5903
5880
  }, props), ArrowLeft_path || (ArrowLeft_path = /*#__PURE__*/external_react_.createElement("path", {
5904
5881
  d: "M15 8a.5.5 0 0 0-.5-.5H2.707l3.147-3.146a.5.5 0 1 0-.708-.708l-4 4a.5.5 0 0 0 0 .708l4 4a.5.5 0 0 0 .708-.708L2.707 8.5H14.5A.5.5 0 0 0 15 8z",
5905
- fill: "currentColor",
5906
- fillRule: "evenodd"
5882
+ fill: "currentColor"
5907
5883
  })));
5908
5884
  };
5909
5885
  /* harmony default export */ const ArrowLeft = (SvgArrowLeft);
@@ -5917,8 +5893,7 @@ var SvgArrowRight = function SvgArrowRight(props) {
5917
5893
  xmlns: "http://www.w3.org/2000/svg"
5918
5894
  }, props), ArrowRight_path || (ArrowRight_path = /*#__PURE__*/external_react_.createElement("path", {
5919
5895
  d: "M1 8a.5.5 0 0 1 .5-.5h11.793l-3.147-3.146a.5.5 0 0 1 .708-.708l4 4a.5.5 0 0 1 0 .708l-4 4a.5.5 0 0 1-.708-.708L13.293 8.5H1.5A.5.5 0 0 1 1 8z",
5920
- fill: "currentColor",
5921
- fillRule: "evenodd"
5896
+ fill: "currentColor"
5922
5897
  })));
5923
5898
  };
5924
5899
  /* harmony default export */ const ArrowRight = (SvgArrowRight);
@@ -5932,8 +5907,7 @@ var SvgArrowUp = function SvgArrowUp(props) {
5932
5907
  xmlns: "http://www.w3.org/2000/svg"
5933
5908
  }, props), ArrowUp_path || (ArrowUp_path = /*#__PURE__*/external_react_.createElement("path", {
5934
5909
  d: "M8 15a.5.5 0 0 0 .5-.5V2.707l3.146 3.147a.5.5 0 0 0 .708-.708l-4-4a.5.5 0 0 0-.708 0l-4 4a.5.5 0 1 0 .708.708L7.5 2.707V14.5a.5.5 0 0 0 .5.5z",
5935
- fill: "currentColor",
5936
- fillRule: "evenodd"
5910
+ fill: "currentColor"
5937
5911
  })));
5938
5912
  };
5939
5913
  /* harmony default export */ const ArrowUp = (SvgArrowUp);
@@ -6019,7 +5993,6 @@ var SvgChevronDown = function SvgChevronDown(props) {
6019
5993
  viewBox: "0 0 16 16",
6020
5994
  xmlns: "http://www.w3.org/2000/svg"
6021
5995
  }, props), ChevronDown_path || (ChevronDown_path = /*#__PURE__*/external_react_.createElement("path", {
6022
- fillRule: "evenodd",
6023
5996
  d: "M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z",
6024
5997
  fill: "currentColor"
6025
5998
  })));
@@ -6035,8 +6008,7 @@ var SvgChevronLeft = function SvgChevronLeft(props) {
6035
6008
  xmlns: "http://www.w3.org/2000/svg"
6036
6009
  }, props), ChevronLeft_path || (ChevronLeft_path = /*#__PURE__*/external_react_.createElement("path", {
6037
6010
  d: "M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z",
6038
- fill: "currentColor",
6039
- fillRule: "evenodd"
6011
+ fill: "currentColor"
6040
6012
  })));
6041
6013
  };
6042
6014
  /* harmony default export */ const ChevronLeft = (SvgChevronLeft);
@@ -6050,8 +6022,7 @@ var SvgChevronRight = function SvgChevronRight(props) {
6050
6022
  xmlns: "http://www.w3.org/2000/svg"
6051
6023
  }, props), ChevronRight_path || (ChevronRight_path = /*#__PURE__*/external_react_.createElement("path", {
6052
6024
  d: "M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z",
6053
- fill: "currentColor",
6054
- fillRule: "evenodd"
6025
+ fill: "currentColor"
6055
6026
  })));
6056
6027
  };
6057
6028
  /* harmony default export */ const ChevronRight = (SvgChevronRight);
@@ -6654,7 +6625,6 @@ var SvgList = function SvgList(props) {
6654
6625
  viewBox: "0 0 16 16",
6655
6626
  xmlns: "http://www.w3.org/2000/svg"
6656
6627
  }, props), List_path || (List_path = /*#__PURE__*/external_react_.createElement("path", {
6657
- fillRule: "evenodd",
6658
6628
  d: "M2.5 12a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 0 1H3a.5.5 0 0 1-.5-.5zm0-4a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 0 1H3a.5.5 0 0 1-.5-.5zm0-4a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 0 1H3a.5.5 0 0 1-.5-.5z",
6659
6629
  fill: "currentColor"
6660
6630
  })));