@gamepark/react-game 7.5.12 → 7.5.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/GameProvider/GameProvider.js +10 -2
- package/dist/components/GameProvider/GameProvider.js.map +1 -1
- package/dist/components/PlayerPanel/StyledPlayerPanel.js.map +1 -1
- package/dist/components/material/DraggableMaterial.js +3 -4
- package/dist/components/material/DraggableMaterial.js.map +1 -1
- package/dist/components/material/GameTable/DevTools/DevToolEntry.d.ts +20 -0
- package/dist/components/material/GameTable/DevTools/DevToolEntry.js +53 -0
- package/dist/components/material/GameTable/DevTools/DevToolEntry.js.map +1 -0
- package/dist/components/material/GameTable/DevTools/DevToolsHub.d.ts +12 -0
- package/dist/components/material/GameTable/DevTools/DevToolsHub.js +200 -0
- package/dist/components/material/GameTable/DevTools/DevToolsHub.js.map +1 -0
- package/dist/components/material/GameTable/DevTools/ExportPanel.d.ts +7 -0
- package/dist/components/material/GameTable/DevTools/ExportPanel.js +80 -0
- package/dist/components/material/GameTable/DevTools/ExportPanel.js.map +1 -0
- package/dist/components/material/GameTable/DevTools/GamePanel.d.ts +9 -0
- package/dist/components/material/GameTable/DevTools/GamePanel.js +183 -0
- package/dist/components/material/GameTable/DevTools/GamePanel.js.map +1 -0
- package/dist/components/material/GameTable/DevTools/SaveLoadPanel.d.ts +7 -0
- package/dist/components/material/GameTable/DevTools/SaveLoadPanel.js +334 -0
- package/dist/components/material/GameTable/DevTools/SaveLoadPanel.js.map +1 -0
- package/dist/components/material/GameTable/DevTools/index.d.ts +3 -0
- package/dist/components/material/GameTable/DevTools/index.js +3 -0
- package/dist/components/material/GameTable/DevTools/index.js.map +1 -0
- package/dist/components/material/GameTable/index.d.ts +1 -1
- package/dist/components/material/GameTable/index.js +1 -1
- package/dist/components/material/GameTable/index.js.map +1 -1
- package/dist/components/material/animations/AnimationBuilder.d.ts +2 -2
- package/dist/components/material/animations/AnimationBuilder.js +1 -1
- package/dist/components/material/animations/AnimationBuilder.js.map +1 -1
- package/dist/components/tutorial/MaterialTutorial.d.ts +1 -1
- package/dist/hooks/useLegalMoves.d.ts +1 -6
- package/dist/hooks/useLegalMoves.js +2 -7
- package/dist/hooks/useLegalMoves.js.map +1 -1
- package/package.json +3 -3
|
@@ -15,6 +15,7 @@ const gameId = query.get('game');
|
|
|
15
15
|
const locale = query.get('locale') || 'en';
|
|
16
16
|
export const GameProvider = ({ materialI18n, theme = {}, children, ...props }) => {
|
|
17
17
|
setupTranslation(props.game);
|
|
18
|
+
initDatadog(props.game);
|
|
18
19
|
useEffect(() => {
|
|
19
20
|
if (isMaterialTutorial(props.tutorial)) {
|
|
20
21
|
wrapRulesWithTutorial(props.tutorial, props.Rules);
|
|
@@ -28,10 +29,17 @@ export const GameProvider = ({ materialI18n, theme = {}, children, ...props }) =
|
|
|
28
29
|
_jsx(LocalGameProvider, { ...props, children: children }) })] }) }));
|
|
29
30
|
};
|
|
30
31
|
// Init Datadog logs
|
|
31
|
-
|
|
32
|
+
let datadogInitialized = false;
|
|
33
|
+
function initDatadog(service) {
|
|
34
|
+
if (datadogInitialized || process.env.NODE_ENV !== 'production')
|
|
35
|
+
return;
|
|
36
|
+
datadogInitialized = true;
|
|
32
37
|
datadogLogs.init({
|
|
33
38
|
clientToken: process.env.DATADOG_CLIENT_TOKEN ?? 'pubdb04a43151132f11ed7347e785e3902a',
|
|
34
|
-
site: 'datadoghq.eu'
|
|
39
|
+
site: 'datadoghq.eu',
|
|
40
|
+
service,
|
|
41
|
+
version: process.env.VERSION,
|
|
42
|
+
beforeSend: (event) => !event.message?.includes('sockjs')
|
|
35
43
|
});
|
|
36
44
|
datadogLogs.logger.setLevel(process.env.LOGGER_LEVEL || StatusType.error);
|
|
37
45
|
// The following code may be removed later, see: https://github.com/DataDog/browser-sdk/issues/400
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GameProvider.js","sourceRoot":"","sources":["../../../src/components/GameProvider/GameProvider.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAA;AAC/D,OAAO,EAAE,GAAG,EAAE,MAAM,EAAS,aAAa,EAAE,MAAM,gBAAgB,CAAA;AAClE,OAAO,EAAE,iBAAiB,EAA0B,kBAAkB,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAA;AACpH,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAqB,SAAS,EAAE,MAAM,OAAO,CAAA;AACpD,OAAO,EAAmB,YAAY,EAAE,MAAM,WAAW,CAAA;AACzD,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAE/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAA;AACnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAA;AAChD,OAAO,EAAE,qBAAqB,EAAE,MAAM,kCAAkC,CAAA;AACxE,OAAO,EAAe,WAAW,EAAE,MAAM,eAAe,CAAA;AAExD,MAAM,KAAK,GAAG,IAAI,eAAe,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAA;AACzD,MAAM,MAAM,GAAG,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;AAChC,MAAM,MAAM,GAAG,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAA;AAO1C,MAAM,CAAC,MAAM,YAAY,GAAG,CAC1B,EAAE,YAAY,EAAE,KAAK,GAAG,EAAE,EAAE,QAAQ,EAAE,GAAG,KAAK,EAAkF,EAChI,EAAE;IACF,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;
|
|
1
|
+
{"version":3,"file":"GameProvider.js","sourceRoot":"","sources":["../../../src/components/GameProvider/GameProvider.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"StyledPlayerPanel.js","sourceRoot":"","sources":["../../../src/components/PlayerPanel/StyledPlayerPanel.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAiB,SAAS,EAAS,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AAG/E,OAAO,EAA4C,WAAW,EAAE,MAAM,EAAE,MAAM,OAAO,CAAA;AACrF,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAA;AACrD,OAAO,EAAE,MAAM,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAA;AACzD,OAAO,EAAiB,eAAe,EAAE,MAAM,aAAa,CAAA;AAC5D,OAAO,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AACnE,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAmBrC,MAAM,CAAC,MAAM,iBAAiB,GAA+B,CAAC,KAAK,EAAE,EAAE;IACrE,MAAM,EACJ,MAAM,EACN,UAAU,EACV,YAAY,EACZ,WAAW,EACX,eAAe,EACf,QAAQ,GAAG,EAAE,EACb,eAAe,GAAG,CAAC,EACnB,WAAW,EACX,KAAK,EACL,GAAG,IAAI,EACR,GAAG,KAAK,CAAA;IACT,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAA;IACxB,MAAM,EAAE,QAAQ,EAAE,GAAG,eAAe,EAAE,CAAA;IACtC,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;IAC3C,MAAM,QAAQ,GAAG,QAAQ,EAAE,EAAE,MAAM,EAAE,CAAA;IACrC,MAAM,KAAK,GAAG,QAAQ,EAAiB,CAAA;IACvC,MAAM,YAAY,GAAG,KAAK,EAAE,YAAY,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,KAAK,CAAA;IAC5D,MAAM,QAAQ,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAA;IAC7C,MAAM,WAAW,GAAG,WAAW,CAAC,GAAG,EAAE;QACnC,IAAI,CAAC,WAAW;YAAE,OAAM;QACxB,QAAQ,CAAC,WAAW,CAAC,CAAA;IACvB,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAA;IACjB,MAAM,IAAI,GAAG,WAAW,CAAA,CAAC,CAAC,WAAW,CAAA,CAAC,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,CAAA,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAA,CAAC,CAAC,SAAS,CAAA;IACpF,MAAM,iBAAiB,GAAG,CAAC,WAAW,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAA,CAAC,CAAC,QAAQ,CAAA;IAC9E,MAAM,UAAU,GAAG,QAAQ,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,CAAC,WAAW,CAAA;IAEvD,OAAO,CACL,eAAK,GAAG,EAAE,QAAQ,EACb,GAAG,EAAE,CAAC,gBAAgB,EAAE,UAAU,EAAE,eAAe,IAAI,aAAa,CAAC,eAAe,CAAC,EAAE,WAAW,IAAI,SAAS,EAAE,CAAC,UAAU,IAAI,YAAY,EAAE,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,EACvK,OAAO,EAAE,WAAW,KAAM,IAAI,aACjC,KAAC,MAAM,IAAC,GAAG,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,CAAC,EAAE,EACrC,iBAAiB,EAAE,EAAE,SAAS,EAAE,wBAAwB,CAAC,QAAQ,CAAC,EAAE,QAAQ,EAAE,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,4BAAG,KAAK,GAAI,CAAC,CAAC,CAAC,KAAK,EAAE,GAAG,EAC1I,UAAU,IAAI,YAAY,IAAI,cAAK,GAAG,EAAE,SAAS,YAChD,cAAK,GAAG,EAAE,YAAY,IAAI,SAAS,GAAG,GAClC,EACN,aAAI,GAAG,EAAE,CAAC,SAAS,EAAE,IAAI,EAAE,KAAK,CAAC,WAAW,EAAE,SAAS,CAAC,YAAG,UAAU,GAAM,EAC1E,CAAC,IAAI,IAAI,CAAC,QAAQ,IAAI,CACrB,KAAC,WAAW,IACV,QAAQ,EAAE,MAAM,CAAC,EAAE,EACnB,GAAG,EAAE,CAAC,UAAU,EAAE,IAAI,EAAE,KAAK,CAAC,WAAW,EAAE,SAAS,EAAE,cAAc,CAAC,EACrE,WAAW,EAAE,CAAC,kBAAkB,EAAE,qBAAqB,CAAC,GACxD,CACH,EAEA,IAAI,IAAI,CACP,eAAK,GAAG,EAAE,oBAAoB,aAC3B,CAAC,QAAQ,IAAI,CACZ,KAAC,WAAW,IACV,QAAQ,EAAE,MAAM,CAAC,EAAE,EACnB,GAAG,EAAE,CAAC,UAAU,EAAE,IAAI,EAAE,KAAK,CAAC,WAAW,EAAE,SAAS,EAAE,cAAc,CAAC,EACrE,WAAW,EAAE,CAAC,kBAAkB,EAAE,qBAAqB,CAAC,GACxD,
|
|
1
|
+
{"version":3,"file":"StyledPlayerPanel.js","sourceRoot":"","sources":["../../../src/components/PlayerPanel/StyledPlayerPanel.tsx"],"names":[],"mappings":"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"}
|
|
@@ -5,7 +5,7 @@ import { isMoveItemsAtOnce, isSelectItem } from '@gamepark/rules-api';
|
|
|
5
5
|
import { isEqual } from 'es-toolkit';
|
|
6
6
|
import { forwardRef, memo, useCallback, useEffect, useMemo, useRef, useState } from 'react';
|
|
7
7
|
import { grabbingCursor, grabCursor } from '../../css';
|
|
8
|
-
import {
|
|
8
|
+
import { useMaterialContextRef, usePlay } from '../../hooks';
|
|
9
9
|
import { getLocationOriginCss } from '../../locators';
|
|
10
10
|
import { combineEventListeners, findIfUnique } from '../../utilities';
|
|
11
11
|
import { useScale } from './GameTable';
|
|
@@ -90,14 +90,13 @@ const DraggableMaterialInnerBase = forwardRef(({ highlight, type, index, display
|
|
|
90
90
|
};
|
|
91
91
|
}
|
|
92
92
|
}, [itemContext, play, legalMoves]);
|
|
93
|
-
const legalMovesForLongClick = useLegalMoves({ includeDuringAnimations: true });
|
|
94
93
|
const onLongClickMove = useMemo(() => {
|
|
95
94
|
if (unselect || onShortClickMove)
|
|
96
95
|
return;
|
|
97
|
-
const move = findIfUnique(
|
|
96
|
+
const move = findIfUnique(legalMoves, move => description.canLongClick(move, itemContext));
|
|
98
97
|
if (move !== undefined)
|
|
99
98
|
return () => play(move);
|
|
100
|
-
}, [itemContext, play,
|
|
99
|
+
}, [itemContext, play, legalMoves]);
|
|
101
100
|
const hadMenu = useRef(!!menu);
|
|
102
101
|
useEffect(() => {
|
|
103
102
|
if (hadMenu.current && !menu && !menuAlwaysVisible && item.selected) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DraggableMaterial.js","sourceRoot":"","sources":["../../../src/components/material/DraggableMaterial.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAiC,aAAa,EAAE,YAAY,EAAE,MAAM,eAAe,CAAA;AAC1F,OAAO,EAAE,GAAG,EAAwB,MAAM,gBAAgB,CAAA;AAC1D,OAAO,EAAiC,iBAAiB,EAAE,YAAY,EAA6C,MAAM,qBAAqB,CAAA;AAC/I,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAA;AACpC,OAAc,EAAE,UAAU,EAAE,IAAI,EAAE,WAAW,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAClG,OAAO,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,WAAW,CAAA;AAEtD,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"DraggableMaterial.js","sourceRoot":"","sources":["../../../src/components/material/DraggableMaterial.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { FC, ReactNode } from 'react';
|
|
2
|
+
export declare const devToolBtnCss: import("@emotion/utils").SerializedStyles;
|
|
3
|
+
export declare const devToolIconCss: import("@emotion/utils").SerializedStyles;
|
|
4
|
+
export declare const devToolLabelCss: import("@emotion/utils").SerializedStyles;
|
|
5
|
+
export declare const devToolDescCss: import("@emotion/utils").SerializedStyles;
|
|
6
|
+
/**
|
|
7
|
+
* A single entry in the DevToolsHub panel.
|
|
8
|
+
* Use this instead of raw `<button>` when adding custom tools via `children`.
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* <DevToolsHub>
|
|
12
|
+
* <DevToolEntry icon="✦" label="Card Viewer" desc="Browse agents" onClick={() => setShowCards(true)} />
|
|
13
|
+
* </DevToolsHub>
|
|
14
|
+
*/
|
|
15
|
+
export declare const DevToolEntry: FC<{
|
|
16
|
+
icon: ReactNode;
|
|
17
|
+
label: string;
|
|
18
|
+
desc?: string;
|
|
19
|
+
onClick?: () => void;
|
|
20
|
+
}>;
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
2
|
+
/** @jsxImportSource @emotion/react */
|
|
3
|
+
import { css, keyframes } from '@emotion/react';
|
|
4
|
+
const GP_PRIMARY = '#28B8CE';
|
|
5
|
+
const toolReveal = keyframes `
|
|
6
|
+
from { opacity: 0; transform: translateX(-6px); }
|
|
7
|
+
to { opacity: 1; transform: translateX(0); }
|
|
8
|
+
`;
|
|
9
|
+
export const devToolBtnCss = css `
|
|
10
|
+
position: relative;
|
|
11
|
+
display: grid;
|
|
12
|
+
grid-template-columns: 28px 1fr;
|
|
13
|
+
grid-template-rows: auto auto;
|
|
14
|
+
align-items: center;
|
|
15
|
+
gap: 0 10px;
|
|
16
|
+
padding: 10px 12px;
|
|
17
|
+
border: none;
|
|
18
|
+
border-radius: 8px;
|
|
19
|
+
background: transparent;
|
|
20
|
+
cursor: pointer;
|
|
21
|
+
text-align: left;
|
|
22
|
+
transition: background 0.15s;
|
|
23
|
+
animation: ${toolReveal} 0.25s ease-out backwards;
|
|
24
|
+
font-family: inherit;
|
|
25
|
+
&:hover { background: rgba(40, 184, 206, 0.08); }
|
|
26
|
+
&:active { background: rgba(40, 184, 206, 0.14); }
|
|
27
|
+
`;
|
|
28
|
+
export const devToolIconCss = css `
|
|
29
|
+
grid-row: 1 / -1;
|
|
30
|
+
font-size: 15px;
|
|
31
|
+
color: ${GP_PRIMARY};
|
|
32
|
+
display: flex; align-items: center; justify-content: center;
|
|
33
|
+
width: 28px; height: 28px;
|
|
34
|
+
border-radius: 6px;
|
|
35
|
+
background: rgba(40, 184, 206, 0.08);
|
|
36
|
+
`;
|
|
37
|
+
export const devToolLabelCss = css `
|
|
38
|
+
font-size: 14px; font-weight: 700; color: #e0f0f4; line-height: 1.2;
|
|
39
|
+
`;
|
|
40
|
+
export const devToolDescCss = css `
|
|
41
|
+
font-size: 12px; color: #5a8a98; line-height: 1.2;
|
|
42
|
+
`;
|
|
43
|
+
/**
|
|
44
|
+
* A single entry in the DevToolsHub panel.
|
|
45
|
+
* Use this instead of raw `<button>` when adding custom tools via `children`.
|
|
46
|
+
*
|
|
47
|
+
* @example
|
|
48
|
+
* <DevToolsHub>
|
|
49
|
+
* <DevToolEntry icon="✦" label="Card Viewer" desc="Browse agents" onClick={() => setShowCards(true)} />
|
|
50
|
+
* </DevToolsHub>
|
|
51
|
+
*/
|
|
52
|
+
export const DevToolEntry = ({ icon, label, desc, onClick }) => (_jsxs("button", { css: devToolBtnCss, onClick: onClick, children: [_jsx("span", { css: devToolIconCss, children: icon }), _jsx("span", { css: devToolLabelCss, children: label }), desc && _jsx("span", { css: devToolDescCss, children: desc })] }));
|
|
53
|
+
//# sourceMappingURL=DevToolEntry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DevToolEntry.js","sourceRoot":"","sources":["../../../../../src/components/material/GameTable/DevTools/DevToolEntry.tsx"],"names":[],"mappings":";AAAA,sCAAsC;AACtC,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAG/C,MAAM,UAAU,GAAG,SAAS,CAAA;AAE5B,MAAM,UAAU,GAAG,SAAS,CAAA;;;CAG3B,CAAA;AAED,MAAM,CAAC,MAAM,aAAa,GAAG,GAAG,CAAA;;;;;;;;;;;;;;eAcjB,UAAU;;;;CAIxB,CAAA;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,GAAG,CAAA;;;WAGtB,UAAU;;;;;CAKpB,CAAA;AAED,MAAM,CAAC,MAAM,eAAe,GAAG,GAAG,CAAA;;CAEjC,CAAA;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,GAAG,CAAA;;CAEhC,CAAA;AAED;;;;;;;;GAQG;AACH,MAAM,CAAC,MAAM,YAAY,GAKpB,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,CACvC,kBAAQ,GAAG,EAAE,aAAa,EAAE,OAAO,EAAE,OAAO,aAC1C,eAAM,GAAG,EAAE,cAAc,YAAG,IAAI,GAAQ,EACxC,eAAM,GAAG,EAAE,eAAe,YAAG,KAAK,GAAQ,EACzC,IAAI,IAAI,eAAM,GAAG,EAAE,cAAc,YAAG,IAAI,GAAQ,IAC1C,CACV,CAAA"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { FC, PropsWithChildren } from 'react';
|
|
2
|
+
export type GameOption = {
|
|
3
|
+
key: string;
|
|
4
|
+
label: string;
|
|
5
|
+
type: 'boolean';
|
|
6
|
+
};
|
|
7
|
+
type DevToolsHubProps = PropsWithChildren<{
|
|
8
|
+
fabBottom?: string;
|
|
9
|
+
gameOptions?: GameOption[];
|
|
10
|
+
}>;
|
|
11
|
+
export declare const DevToolsHub: FC<DevToolsHubProps>;
|
|
12
|
+
export {};
|
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "@emotion/react/jsx-runtime";
|
|
2
|
+
/** @jsxImportSource @emotion/react */
|
|
3
|
+
import { css, keyframes } from '@emotion/react';
|
|
4
|
+
import { useCallback, useContext, useRef, useState } from 'react';
|
|
5
|
+
import { createPortal } from 'react-dom';
|
|
6
|
+
import { gameContext } from '../../../GameProvider/GameContext';
|
|
7
|
+
import { GamePanel } from './GamePanel';
|
|
8
|
+
import { SaveLoadPanel } from './SaveLoadPanel';
|
|
9
|
+
import { ExportPanel } from './ExportPanel';
|
|
10
|
+
const menuItems = [
|
|
11
|
+
{ id: 'game', icon: '\u2699', label: 'Game' },
|
|
12
|
+
{ id: 'save', icon: '\u2B73', label: 'Save / Load' },
|
|
13
|
+
{ id: 'export', icon: '\u2398', label: 'Export' },
|
|
14
|
+
];
|
|
15
|
+
export const DevToolsHub = ({ children, fabBottom, gameOptions }) => {
|
|
16
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
17
|
+
const [activeMenu, setActiveMenu] = useState(null);
|
|
18
|
+
const [flash, setFlash] = useState(null);
|
|
19
|
+
const flashTimeout = useRef(null);
|
|
20
|
+
const gameName = useContext(gameContext)?.game ?? 'unknown';
|
|
21
|
+
const doFlash = useCallback((msg) => {
|
|
22
|
+
if (flashTimeout.current)
|
|
23
|
+
clearTimeout(flashTimeout.current);
|
|
24
|
+
setFlash(msg);
|
|
25
|
+
flashTimeout.current = setTimeout(() => setFlash(null), 1500);
|
|
26
|
+
}, []);
|
|
27
|
+
const g = typeof window !== 'undefined' ? window.game : undefined;
|
|
28
|
+
const exec = useCallback((action, successMsg) => {
|
|
29
|
+
if (!g) {
|
|
30
|
+
doFlash('game helper not available');
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
action();
|
|
34
|
+
doFlash(successMsg);
|
|
35
|
+
}, [g, doFlash]);
|
|
36
|
+
const allMenuItems = children
|
|
37
|
+
? [...menuItems, { id: 'custom', icon: '\u2726', label: 'Custom' }]
|
|
38
|
+
: menuItems;
|
|
39
|
+
const root = document.getElementById('root');
|
|
40
|
+
if (!root)
|
|
41
|
+
return null;
|
|
42
|
+
return createPortal(_jsxs(_Fragment, { children: [_jsx("button", { css: fabCss, onClick: () => { setIsOpen(o => !o); if (isOpen)
|
|
43
|
+
setActiveMenu(null); }, "data-open": isOpen, style: fabBottom ? { bottom: fabBottom } : undefined, children: _jsxs("svg", { css: logoCss, viewBox: "0 0 46 46", "data-open": isOpen, children: [_jsx("circle", { cx: "11", cy: "11", r: "7" }), _jsx("circle", { cx: "35", cy: "11", r: "7" }), _jsx("circle", { cx: "11", cy: "35", r: "7" }), _jsx("circle", { cx: "35", cy: "35", r: "7" })] }) }), isOpen && (_jsxs(_Fragment, { children: [_jsx("div", { css: backdropCss, onClick: () => { setIsOpen(false); setActiveMenu(null); } }), _jsxs("div", { css: hubContainerCss, style: fabBottom ? { bottom: `calc(${fabBottom} + 48px)` } : undefined, children: [_jsxs("div", { css: mainMenuCss, children: [_jsxs("div", { css: panelHeaderCss, children: [_jsxs("svg", { css: headerLogoCss, viewBox: "0 0 46 46", children: [_jsx("circle", { cx: "11", cy: "11", r: "7" }), _jsx("circle", { cx: "35", cy: "11", r: "7" }), _jsx("circle", { cx: "11", cy: "35", r: "7" }), _jsx("circle", { cx: "35", cy: "35", r: "7" })] }), _jsx("span", { css: panelTitleCss, children: "Dev Tools" }), _jsx("span", { css: panelBadgeCss, children: "GP" })] }), _jsx("div", { css: menuListCss, children: allMenuItems.map(item => (_jsxs("button", { css: [menuItemCss, activeMenu === item.id && menuItemActiveCss], onClick: () => setActiveMenu(prev => prev === item.id ? null : item.id), onMouseEnter: () => setActiveMenu(item.id), children: [_jsx("span", { css: menuItemIconCss, children: item.icon }), _jsx("span", { css: menuItemLabelCss, children: item.label }), _jsx("span", { css: menuChevronCss, children: '\u25B8' })] }, item.id))) }), flash && _jsx("div", { css: flashCss, children: flash }, flash)] }), activeMenu && (_jsxs("div", { css: subPanelCss, children: [_jsx("div", { css: subPanelHeaderCss, children: _jsx("span", { css: subPanelTitleCss, children: allMenuItems.find(m => m.id === activeMenu)?.label }) }), _jsxs("div", { css: subPanelContentCss, children: [activeMenu === 'game' && _jsx(GamePanel, { exec: exec, g: g, gameOptions: gameOptions }), activeMenu === 'save' && _jsx(SaveLoadPanel, { gameName: gameName, doFlash: doFlash }), activeMenu === 'export' && _jsx(ExportPanel, { gameName: gameName, doFlash: doFlash }), activeMenu === 'custom' && children] })] }))] })] }))] }), root);
|
|
44
|
+
};
|
|
45
|
+
// ── Styles ──
|
|
46
|
+
const GP_PRIMARY = '#28B8CE';
|
|
47
|
+
const GP_DARK = '#002448';
|
|
48
|
+
const GP_SURFACE = '#0a1929';
|
|
49
|
+
const GP_ACCENT = '#9fe2f7';
|
|
50
|
+
const fabPulse = keyframes `
|
|
51
|
+
0%, 100% { box-shadow: 0 0 0 0 rgba(40, 184, 206, 0.25); }
|
|
52
|
+
50% { box-shadow: 0 0 0 5px rgba(40, 184, 206, 0); }
|
|
53
|
+
`;
|
|
54
|
+
const fabCss = css `
|
|
55
|
+
position: fixed; bottom: 16px; left: 16px; z-index: 900;
|
|
56
|
+
width: 40px; height: 40px;
|
|
57
|
+
border-radius: 10px;
|
|
58
|
+
border: 1px solid rgba(40, 184, 206, 0.4);
|
|
59
|
+
background: linear-gradient(145deg, ${GP_SURFACE}, ${GP_DARK});
|
|
60
|
+
cursor: pointer;
|
|
61
|
+
display: flex; align-items: center; justify-content: center;
|
|
62
|
+
padding: 0;
|
|
63
|
+
animation: ${fabPulse} 3s ease-in-out infinite;
|
|
64
|
+
transition: all 0.2s;
|
|
65
|
+
&:hover { border-color: rgba(40, 184, 206, 0.7); animation: none; }
|
|
66
|
+
&[data-open="true"] { animation: none; background: ${GP_PRIMARY}; border-color: ${GP_PRIMARY}; }
|
|
67
|
+
`;
|
|
68
|
+
const logoCss = css `
|
|
69
|
+
width: 22px; height: 22px;
|
|
70
|
+
fill: ${GP_PRIMARY};
|
|
71
|
+
transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
|
|
72
|
+
&[data-open="true"] { fill: ${GP_DARK}; transform: rotate(90deg); }
|
|
73
|
+
`;
|
|
74
|
+
const backdropCss = css `
|
|
75
|
+
position: fixed; inset: 0; z-index: 899;
|
|
76
|
+
`;
|
|
77
|
+
const hubContainerCss = css `
|
|
78
|
+
position: fixed; bottom: 64px; left: 16px; z-index: 900;
|
|
79
|
+
display: flex; align-items: flex-end; gap: 6px;
|
|
80
|
+
`;
|
|
81
|
+
const slideUp = keyframes `
|
|
82
|
+
from { opacity: 0; transform: translateY(8px) scale(0.97); }
|
|
83
|
+
to { opacity: 1; transform: translateY(0) scale(1); }
|
|
84
|
+
`;
|
|
85
|
+
const slideRight = keyframes `
|
|
86
|
+
from { opacity: 0; transform: translateX(-8px) scale(0.97); }
|
|
87
|
+
to { opacity: 1; transform: translateX(0) scale(1); }
|
|
88
|
+
`;
|
|
89
|
+
const panelBg = `linear-gradient(170deg, #0f2035 0%, ${GP_SURFACE} 100%)`;
|
|
90
|
+
const panelShadow = `0 12px 40px rgba(0,0,0,0.5), 0 0 0 1px rgba(0,0,0,0.3), inset 0 1px 0 rgba(159,226,247,0.05)`;
|
|
91
|
+
const mainMenuCss = css `
|
|
92
|
+
position: relative; width: 200px;
|
|
93
|
+
background: ${panelBg};
|
|
94
|
+
border: 1px solid rgba(40, 184, 206, 0.25);
|
|
95
|
+
border-radius: 12px;
|
|
96
|
+
box-shadow: ${panelShadow};
|
|
97
|
+
animation: ${slideUp} 0.2s ease-out;
|
|
98
|
+
font-family: 'Mulish', sans-serif;
|
|
99
|
+
overflow: hidden;
|
|
100
|
+
`;
|
|
101
|
+
const subPanelCss = css `
|
|
102
|
+
width: 320px; max-height: calc(100vh - 80px);
|
|
103
|
+
display: flex; flex-direction: column;
|
|
104
|
+
background: ${panelBg};
|
|
105
|
+
border: 1px solid rgba(40, 184, 206, 0.25);
|
|
106
|
+
border-radius: 12px;
|
|
107
|
+
box-shadow: ${panelShadow};
|
|
108
|
+
animation: ${slideRight} 0.15s ease-out;
|
|
109
|
+
font-family: 'Mulish', sans-serif;
|
|
110
|
+
overflow: hidden;
|
|
111
|
+
`;
|
|
112
|
+
const subPanelHeaderCss = css `
|
|
113
|
+
padding: 10px 16px;
|
|
114
|
+
border-bottom: 1px solid rgba(40, 184, 206, 0.15);
|
|
115
|
+
background: rgba(40, 184, 206, 0.04);
|
|
116
|
+
flex-shrink: 0;
|
|
117
|
+
`;
|
|
118
|
+
const subPanelTitleCss = css `
|
|
119
|
+
font-size: 12px; font-weight: 800; color: #5a8a98;
|
|
120
|
+
text-transform: uppercase; letter-spacing: 0.1em;
|
|
121
|
+
`;
|
|
122
|
+
const subPanelContentCss = css `
|
|
123
|
+
display: flex; flex-direction: column;
|
|
124
|
+
padding: 6px; gap: 2px;
|
|
125
|
+
overflow-y: auto; flex: 1; min-height: 0;
|
|
126
|
+
`;
|
|
127
|
+
const panelHeaderCss = css `
|
|
128
|
+
display: flex; align-items: center; gap: 8px;
|
|
129
|
+
padding: 12px 16px;
|
|
130
|
+
border-bottom: 1px solid rgba(40, 184, 206, 0.15);
|
|
131
|
+
background: rgba(40, 184, 206, 0.04);
|
|
132
|
+
`;
|
|
133
|
+
const headerLogoCss = css `
|
|
134
|
+
width: 18px; height: 18px; fill: ${GP_ACCENT}; flex-shrink: 0;
|
|
135
|
+
`;
|
|
136
|
+
const panelTitleCss = css `
|
|
137
|
+
font-size: 14px; font-weight: 800; color: #e0f0f4;
|
|
138
|
+
text-transform: uppercase; letter-spacing: 0.08em; flex: 1;
|
|
139
|
+
`;
|
|
140
|
+
const panelBadgeCss = css `
|
|
141
|
+
font-size: 9px; font-weight: 800;
|
|
142
|
+
padding: 2px 6px; border-radius: 4px;
|
|
143
|
+
background: rgba(40, 184, 206, 0.15);
|
|
144
|
+
color: ${GP_PRIMARY}; letter-spacing: 0.1em;
|
|
145
|
+
`;
|
|
146
|
+
const menuListCss = css `
|
|
147
|
+
display: flex; flex-direction: column; padding: 6px; gap: 2px;
|
|
148
|
+
`;
|
|
149
|
+
const menuItemCss = css `
|
|
150
|
+
position: relative;
|
|
151
|
+
display: flex; align-items: center; gap: 10px;
|
|
152
|
+
padding: 10px 12px;
|
|
153
|
+
border: none; border-radius: 8px;
|
|
154
|
+
background: transparent;
|
|
155
|
+
cursor: pointer; text-align: left;
|
|
156
|
+
transition: background 0.15s;
|
|
157
|
+
font-family: inherit;
|
|
158
|
+
&:hover { background: rgba(40, 184, 206, 0.08); }
|
|
159
|
+
`;
|
|
160
|
+
const menuItemActiveCss = css `
|
|
161
|
+
background: rgba(40, 184, 206, 0.12);
|
|
162
|
+
&::before {
|
|
163
|
+
content: ''; position: absolute; left: 0; top: 50%;
|
|
164
|
+
transform: translateY(-50%);
|
|
165
|
+
width: 3px; height: 18px;
|
|
166
|
+
border-radius: 0 3px 3px 0;
|
|
167
|
+
background: ${GP_PRIMARY};
|
|
168
|
+
}
|
|
169
|
+
`;
|
|
170
|
+
const menuItemIconCss = css `
|
|
171
|
+
font-size: 15px; color: ${GP_PRIMARY};
|
|
172
|
+
display: flex; align-items: center; justify-content: center;
|
|
173
|
+
width: 28px; height: 28px; border-radius: 6px;
|
|
174
|
+
background: rgba(40, 184, 206, 0.08); flex-shrink: 0;
|
|
175
|
+
`;
|
|
176
|
+
const menuItemLabelCss = css `
|
|
177
|
+
font-size: 13px; font-weight: 700; color: #e0f0f4; flex: 1;
|
|
178
|
+
`;
|
|
179
|
+
const menuChevronCss = css `
|
|
180
|
+
font-size: 10px; color: #3a6070;
|
|
181
|
+
`;
|
|
182
|
+
const flashFade = keyframes `
|
|
183
|
+
0% { opacity: 0; transform: translateY(6px); }
|
|
184
|
+
15% { opacity: 1; transform: translateY(0); }
|
|
185
|
+
85% { opacity: 1; transform: translateY(0); }
|
|
186
|
+
100% { opacity: 0; transform: translateY(-6px); }
|
|
187
|
+
`;
|
|
188
|
+
const flashCss = css `
|
|
189
|
+
position: absolute; bottom: 100%; left: 0; right: 0;
|
|
190
|
+
margin-bottom: 8px; padding: 6px 14px;
|
|
191
|
+
font-size: 12px; font-weight: 700; color: ${GP_PRIMARY};
|
|
192
|
+
text-align: center;
|
|
193
|
+
background: linear-gradient(145deg, ${GP_SURFACE}, ${GP_DARK});
|
|
194
|
+
border: 1px solid rgba(40, 184, 206, 0.3);
|
|
195
|
+
border-radius: 8px;
|
|
196
|
+
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
|
|
197
|
+
white-space: nowrap; pointer-events: none;
|
|
198
|
+
animation: ${flashFade} 1.5s ease-out forwards;
|
|
199
|
+
`;
|
|
200
|
+
//# sourceMappingURL=DevToolsHub.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DevToolsHub.js","sourceRoot":"","sources":["../../../../../src/components/material/GameTable/DevTools/DevToolsHub.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "@emotion/react/jsx-runtime";
|
|
2
|
+
/** @jsxImportSource @emotion/react */
|
|
3
|
+
import { css, keyframes } from '@emotion/react';
|
|
4
|
+
import { useCallback } from 'react';
|
|
5
|
+
const GP_PRIMARY = '#28B8CE';
|
|
6
|
+
export const ExportPanel = ({ gameName, doFlash }) => {
|
|
7
|
+
const handleDownloadState = useCallback(() => {
|
|
8
|
+
const raw = localStorage.getItem(gameName);
|
|
9
|
+
if (!raw) {
|
|
10
|
+
doFlash('No game state in localStorage');
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
const blob = new Blob([raw], { type: 'application/json' });
|
|
14
|
+
const url = URL.createObjectURL(blob);
|
|
15
|
+
const a = document.createElement('a');
|
|
16
|
+
a.href = url;
|
|
17
|
+
a.download = `${gameName}-state-${new Date().toISOString().slice(0, 19).replace(/:/g, '-')}.json`;
|
|
18
|
+
a.click();
|
|
19
|
+
URL.revokeObjectURL(url);
|
|
20
|
+
doFlash('State downloaded');
|
|
21
|
+
}, [gameName, doFlash]);
|
|
22
|
+
const copyToClipboard = useCallback(async (text, label) => {
|
|
23
|
+
try {
|
|
24
|
+
await navigator.clipboard.writeText(text);
|
|
25
|
+
doFlash(`${label} copied!`);
|
|
26
|
+
}
|
|
27
|
+
catch {
|
|
28
|
+
doFlash('Copy failed');
|
|
29
|
+
}
|
|
30
|
+
}, [doFlash]);
|
|
31
|
+
return (_jsxs(_Fragment, { children: [_jsxs("button", { css: toolBtnCss, onClick: handleDownloadState, children: [_jsx("span", { css: toolIconCss, children: '\u2913' }), _jsx("span", { css: toolLabelCss, children: "Download State" }), _jsx("span", { css: toolDescCss, children: "Save state as .json file" })] }), _jsxs("button", { css: toolBtnCss, onClick: () => {
|
|
32
|
+
const raw = localStorage.getItem(gameName);
|
|
33
|
+
if (raw) {
|
|
34
|
+
void copyToClipboard(raw, `${gameName} state`);
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
doFlash(`No "${gameName}" key in localStorage`);
|
|
38
|
+
}
|
|
39
|
+
}, children: [_jsx("span", { css: toolIconCss, children: '\u29C9' }), _jsx("span", { css: toolLabelCss, children: "Copy LocalStorage" }), _jsxs("span", { css: toolDescCss, children: ["Copy \"", gameName, "\" key to clipboard"] })] })] }));
|
|
40
|
+
};
|
|
41
|
+
// ── Styles ──
|
|
42
|
+
const toolReveal = keyframes `
|
|
43
|
+
from { opacity: 0; transform: translateX(-6px); }
|
|
44
|
+
to { opacity: 1; transform: translateX(0); }
|
|
45
|
+
`;
|
|
46
|
+
const toolBtnCss = css `
|
|
47
|
+
position: relative;
|
|
48
|
+
display: grid;
|
|
49
|
+
grid-template-columns: 28px 1fr;
|
|
50
|
+
grid-template-rows: auto auto;
|
|
51
|
+
align-items: center;
|
|
52
|
+
gap: 0 10px;
|
|
53
|
+
padding: 10px 12px;
|
|
54
|
+
border: none;
|
|
55
|
+
border-radius: 8px;
|
|
56
|
+
background: transparent;
|
|
57
|
+
cursor: pointer;
|
|
58
|
+
text-align: left;
|
|
59
|
+
transition: background 0.15s;
|
|
60
|
+
animation: ${toolReveal} 0.25s ease-out backwards;
|
|
61
|
+
font-family: inherit;
|
|
62
|
+
&:hover { background: rgba(40, 184, 206, 0.08); }
|
|
63
|
+
&:active { background: rgba(40, 184, 206, 0.14); }
|
|
64
|
+
`;
|
|
65
|
+
const toolIconCss = css `
|
|
66
|
+
grid-row: 1 / -1;
|
|
67
|
+
font-size: 15px;
|
|
68
|
+
color: ${GP_PRIMARY};
|
|
69
|
+
display: flex; align-items: center; justify-content: center;
|
|
70
|
+
width: 28px; height: 28px;
|
|
71
|
+
border-radius: 6px;
|
|
72
|
+
background: rgba(40, 184, 206, 0.08);
|
|
73
|
+
`;
|
|
74
|
+
const toolLabelCss = css `
|
|
75
|
+
font-size: 14px; font-weight: 700; color: #e0f0f4; line-height: 1.2;
|
|
76
|
+
`;
|
|
77
|
+
const toolDescCss = css `
|
|
78
|
+
font-size: 12px; color: #5a8a98; line-height: 1.2;
|
|
79
|
+
`;
|
|
80
|
+
//# sourceMappingURL=ExportPanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ExportPanel.js","sourceRoot":"","sources":["../../../../../src/components/material/GameTable/DevTools/ExportPanel.tsx"],"names":[],"mappings":"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"}
|