@gamepark/react-game 6.16.0 → 6.17.2
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/GameContext.d.ts +2 -0
- package/dist/components/GameProvider/GameContext.js.map +1 -1
- package/dist/components/GameProvider/GameProvider.js +5 -3
- package/dist/components/GameProvider/GameProvider.js.map +1 -1
- package/dist/components/JournalTabs/Chat/Chat.d.ts +7 -0
- package/dist/components/JournalTabs/Chat/Chat.js +37 -0
- package/dist/components/JournalTabs/Chat/Chat.js.map +1 -0
- package/dist/components/JournalTabs/Chat/ChatMessage.d.ts +7 -0
- package/dist/components/JournalTabs/Chat/ChatMessage.js +29 -0
- package/dist/components/JournalTabs/Chat/ChatMessage.js.map +1 -0
- package/dist/components/JournalTabs/Chat/ChatMessageAuthor.d.ts +3 -0
- package/dist/components/JournalTabs/Chat/ChatMessageAuthor.js +37 -0
- package/dist/components/JournalTabs/Chat/ChatMessageAuthor.js.map +1 -0
- package/dist/components/JournalTabs/Chat/ChatTextInput.d.ts +19 -0
- package/dist/components/JournalTabs/Chat/ChatTextInput.js +71 -0
- package/dist/components/JournalTabs/Chat/ChatTextInput.js.map +1 -0
- package/dist/components/JournalTabs/Chat/CommonChat.d.ts +12 -0
- package/dist/components/JournalTabs/Chat/CommonChat.js +58 -0
- package/dist/components/JournalTabs/Chat/CommonChat.js.map +1 -0
- package/dist/components/JournalTabs/Chat/LocalChat.d.ts +6 -0
- package/dist/components/JournalTabs/Chat/LocalChat.js +49 -0
- package/dist/components/JournalTabs/Chat/LocalChat.js.map +1 -0
- package/dist/components/JournalTabs/Chat/RemoteChat.d.ts +7 -0
- package/dist/components/JournalTabs/Chat/RemoteChat.js +46 -0
- package/dist/components/JournalTabs/Chat/RemoteChat.js.map +1 -0
- package/dist/components/JournalTabs/Chat/SignInToChat.d.ts +1 -0
- package/dist/components/JournalTabs/Chat/SignInToChat.js +35 -0
- package/dist/components/JournalTabs/Chat/SignInToChat.js.map +1 -0
- package/dist/components/JournalTabs/Chat/index.d.ts +5 -0
- package/dist/components/JournalTabs/Chat/index.js +22 -0
- package/dist/components/JournalTabs/Chat/index.js.map +1 -0
- package/dist/components/JournalTabs/History/ActionHistoryEntry.d.ts +12 -0
- package/dist/components/JournalTabs/History/ActionHistoryEntry.js +62 -0
- package/dist/components/JournalTabs/History/ActionHistoryEntry.js.map +1 -0
- package/dist/components/JournalTabs/History/History.d.ts +6 -0
- package/dist/components/JournalTabs/History/History.js +54 -0
- package/dist/components/JournalTabs/History/History.js.map +1 -0
- package/dist/components/JournalTabs/History/HistoryEntry.d.ts +11 -0
- package/dist/components/JournalTabs/History/HistoryEntry.js +42 -0
- package/dist/components/JournalTabs/History/HistoryEntry.js.map +1 -0
- package/dist/components/JournalTabs/History/MaterialHistory.d.ts +11 -0
- package/dist/components/JournalTabs/History/MaterialHistory.js +3 -0
- package/dist/components/JournalTabs/History/MaterialHistory.js.map +1 -0
- package/dist/components/JournalTabs/History/PlayerActionHistory.d.ts +8 -0
- package/dist/components/JournalTabs/History/PlayerActionHistory.js +42 -0
- package/dist/components/JournalTabs/History/PlayerActionHistory.js.map +1 -0
- package/dist/components/JournalTabs/History/PlayerHistoryEntry.d.ts +8 -0
- package/dist/components/JournalTabs/History/PlayerHistoryEntry.js +44 -0
- package/dist/components/JournalTabs/History/PlayerHistoryEntry.js.map +1 -0
- package/dist/components/JournalTabs/History/StartHistory.d.ts +2 -0
- package/dist/components/JournalTabs/History/StartHistory.js +30 -0
- package/dist/components/JournalTabs/History/StartHistory.js.map +1 -0
- package/dist/components/JournalTabs/History/index.d.ts +5 -0
- package/dist/components/JournalTabs/History/index.js +22 -0
- package/dist/components/JournalTabs/History/index.js.map +1 -0
- package/dist/components/JournalTabs/JournalTabs.d.ts +5 -0
- package/dist/components/JournalTabs/JournalTabs.js +74 -0
- package/dist/components/JournalTabs/JournalTabs.js.map +1 -0
- package/dist/components/JournalTabs/index.d.ts +1 -0
- package/dist/components/JournalTabs/index.js +18 -0
- package/dist/components/JournalTabs/index.js.map +1 -0
- package/dist/components/Picture/Picture.js +1 -0
- package/dist/components/Picture/Picture.js.map +1 -1
- package/dist/components/PlayerPanel/PlayerPanel.d.ts +4 -3
- package/dist/components/PlayerPanel/PlayerPanel.js +16 -10
- package/dist/components/PlayerPanel/PlayerPanel.js.map +1 -1
- package/dist/components/buttons/PlayMoveButton/PlayMoveButton.js +21 -23
- package/dist/components/buttons/PlayMoveButton/PlayMoveButton.js.map +1 -1
- package/dist/components/dialogs/FailuresDialog.js +3 -3
- package/dist/components/dialogs/FailuresDialog.js.map +1 -1
- package/dist/components/dialogs/ResultDialog/ResultDialog.js +9 -6
- package/dist/components/dialogs/ResultDialog/ResultDialog.js.map +1 -1
- package/dist/components/dialogs/RulesDialog/MaterialRulesDialogContent.js +5 -5
- package/dist/components/dialogs/RulesDialog/MaterialRulesDialogContent.js.map +1 -1
- package/dist/components/dialogs/RulesDialog/RulesDialog.d.ts +1 -1
- package/dist/components/dialogs/RulesDialog/RulesDialog.js +1 -1
- package/dist/components/dialogs/RulesDialog/RulesDialog.js.map +1 -1
- package/dist/components/index.d.ts +1 -0
- package/dist/components/index.js +1 -0
- package/dist/components/index.js.map +1 -1
- package/dist/components/material/Dices/CubicDiceDescription.d.ts +5 -4
- package/dist/components/material/Dices/CubicDiceDescription.js +5 -5
- package/dist/components/material/Dices/CubicDiceDescription.js.map +1 -1
- package/dist/components/material/DraggableMaterial.d.ts +2 -0
- package/dist/components/material/DraggableMaterial.js +65 -33
- package/dist/components/material/DraggableMaterial.js.map +1 -1
- package/dist/components/material/FlatMaterial/FlatMaterial.d.ts +10 -10
- package/dist/components/material/FlatMaterial/FlatMaterial.js +19 -19
- package/dist/components/material/FlatMaterial/FlatMaterial.js.map +1 -1
- package/dist/components/material/GameTable/DraggableStockItem.d.ts +4 -0
- package/dist/components/material/GameTable/DraggableStockItem.js +82 -0
- package/dist/components/material/GameTable/DraggableStockItem.js.map +1 -0
- package/dist/components/material/GameTable/DynamicItemsDisplay.d.ts +4 -0
- package/dist/components/material/GameTable/DynamicItemsDisplay.js +72 -0
- package/dist/components/material/GameTable/DynamicItemsDisplay.js.map +1 -0
- package/dist/components/material/GameTable/FocusableElement.d.ts +13 -0
- package/dist/components/material/GameTable/FocusableElement.js +63 -0
- package/dist/components/material/GameTable/FocusableElement.js.map +1 -0
- package/dist/components/material/GameTable/FocusableLocation.d.ts +8 -0
- package/dist/components/material/GameTable/FocusableLocation.js +37 -0
- package/dist/components/material/GameTable/FocusableLocation.js.map +1 -0
- package/dist/components/material/GameTable/FocusableLocations.d.ts +0 -0
- package/dist/components/material/GameTable/FocusableLocations.js +2 -0
- package/dist/components/material/GameTable/FocusableLocations.js.map +1 -0
- package/dist/components/material/GameTable/GameMaterialDisplay.d.ts +7 -1
- package/dist/components/material/GameTable/GameMaterialDisplay.js +16 -133
- package/dist/components/material/GameTable/GameMaterialDisplay.js.map +1 -1
- package/dist/components/material/GameTable/GameTable.d.ts +2 -0
- package/dist/components/material/GameTable/GameTable.js +7 -6
- package/dist/components/material/GameTable/GameTable.js.map +1 -1
- package/dist/components/material/GameTable/GameTableNavigation.d.ts +5 -1
- package/dist/components/material/GameTable/GameTableNavigation.js +18 -6
- package/dist/components/material/GameTable/GameTableNavigation.js.map +1 -1
- package/dist/components/material/GameTable/ItemDisplay.d.ts +15 -0
- package/dist/components/material/GameTable/ItemDisplay.js +51 -0
- package/dist/components/material/GameTable/ItemDisplay.js.map +1 -0
- package/dist/components/material/GameTable/StaticItemsDisplay.d.ts +4 -0
- package/dist/components/material/GameTable/StaticItemsDisplay.js +67 -0
- package/dist/components/material/GameTable/StaticItemsDisplay.js.map +1 -0
- package/dist/components/material/GameTable/StaticLocationsDisplay.d.ts +4 -0
- package/dist/components/material/GameTable/StaticLocationsDisplay.js +35 -0
- package/dist/components/material/GameTable/StaticLocationsDisplay.js.map +1 -0
- package/dist/components/material/GameTable/focus/FocusProvider.d.ts +10 -0
- package/dist/components/material/GameTable/focus/FocusProvider.js +78 -0
- package/dist/components/material/GameTable/focus/FocusProvider.js.map +1 -0
- package/dist/components/material/GameTable/focus/FocusableElement.d.ts +13 -0
- package/dist/components/material/GameTable/focus/FocusableElement.js +63 -0
- package/dist/components/material/GameTable/focus/FocusableElement.js.map +1 -0
- package/dist/components/material/GameTable/focus/FocusableLocation.d.ts +8 -0
- package/dist/components/material/GameTable/focus/FocusableLocation.js +38 -0
- package/dist/components/material/GameTable/focus/FocusableLocation.js.map +1 -0
- package/dist/components/material/GameTable/focus/LocationsWithFocus.d.ts +8 -0
- package/dist/components/material/GameTable/focus/LocationsWithFocus.js +30 -0
- package/dist/components/material/GameTable/focus/LocationsWithFocus.js.map +1 -0
- package/dist/components/material/GameTable/focus/MaterialFocus.d.ts +20 -0
- package/dist/components/material/GameTable/focus/MaterialFocus.js +3 -0
- package/dist/components/material/GameTable/focus/MaterialFocus.js.map +1 -0
- package/dist/components/material/GameTable/focus/index.d.ts +3 -0
- package/dist/components/material/GameTable/focus/index.js +20 -0
- package/dist/components/material/GameTable/focus/index.js.map +1 -0
- package/dist/components/material/GameTable/index.d.ts +1 -0
- package/dist/components/material/GameTable/index.js +1 -0
- package/dist/components/material/GameTable/index.js.map +1 -1
- package/dist/components/material/GameTable/locations.utils.d.ts +0 -0
- package/dist/components/material/GameTable/locations.utils.js +2 -0
- package/dist/components/material/GameTable/locations.utils.js.map +1 -0
- package/dist/components/material/MaterialComponent.d.ts +2 -2
- package/dist/components/material/MaterialComponent.js +7 -7
- package/dist/components/material/MaterialComponent.js.map +1 -1
- package/dist/components/material/MaterialDescription.d.ts +10 -9
- package/dist/components/material/MaterialDescription.js +11 -38
- package/dist/components/material/MaterialDescription.js.map +1 -1
- package/dist/components/material/MobileMaterialDescription.d.ts +9 -0
- package/dist/components/material/MobileMaterialDescription.js +68 -0
- package/dist/components/material/MobileMaterialDescription.js.map +1 -0
- package/dist/components/material/Writing/WritingDescription.d.ts +5 -5
- package/dist/components/material/Writing/WritingDescription.js +15 -15
- package/dist/components/material/Writing/WritingDescription.js.map +1 -1
- package/dist/components/material/animations/CreateItemAnimations.d.ts +2 -1
- package/dist/components/material/animations/CreateItemAnimations.js +10 -3
- package/dist/components/material/animations/CreateItemAnimations.js.map +1 -1
- package/dist/components/material/animations/MaterialGameAnimations.d.ts +1 -1
- package/dist/components/material/animations/MaterialGameAnimations.js +1 -1
- package/dist/components/material/animations/MaterialGameAnimations.js.map +1 -1
- package/dist/components/material/animations/MoveItemAnimations.js +1 -1
- package/dist/components/material/animations/MoveItemAnimations.js.map +1 -1
- package/dist/components/material/index.d.ts +1 -0
- package/dist/components/material/index.js +1 -0
- package/dist/components/material/index.js.map +1 -1
- package/dist/components/material/locations/LocationDescription.d.ts +1 -2
- package/dist/components/material/locations/LocationDescription.js +1 -4
- package/dist/components/material/locations/LocationDescription.js.map +1 -1
- package/dist/components/material/locations/LocationsMask.d.ts +1 -1
- package/dist/components/material/locations/LocationsMask.js +1 -3
- package/dist/components/material/locations/LocationsMask.js.map +1 -1
- package/dist/components/material/locations/SimpleDropArea.js +65 -34
- package/dist/components/material/locations/SimpleDropArea.js.map +1 -1
- package/dist/components/material/utils/useIsAnimatingPlayerAction.js +8 -3
- package/dist/components/material/utils/useIsAnimatingPlayerAction.js.map +1 -1
- package/dist/components/menus/EjectPlayer/EjectPlayerButton.js +2 -2
- package/dist/components/menus/EjectPlayer/EjectPlayerButton.js.map +1 -1
- package/dist/components/menus/EjectPlayer/EjectPlayerDialog.js +2 -2
- package/dist/components/menus/EjectPlayer/EjectPlayerDialog.js.map +1 -1
- package/dist/components/menus/EjectPlayer/EjectPlayerPopButton.js +2 -2
- package/dist/components/menus/EjectPlayer/EjectPlayerPopButton.js.map +1 -1
- package/dist/components/menus/Fullscreen/FullscreenButton.js +3 -2
- package/dist/components/menus/Fullscreen/FullscreenButton.js.map +1 -1
- package/dist/components/menus/Fullscreen/FullscreenDialog.js +2 -2
- package/dist/components/menus/Fullscreen/FullscreenDialog.js.map +1 -1
- package/dist/components/menus/Fullscreen/FullscreenPopButton.js +3 -2
- package/dist/components/menus/Fullscreen/FullscreenPopButton.js.map +1 -1
- package/dist/components/menus/Menu/Menu.js +19 -19
- package/dist/components/menus/Menu/Menu.js.map +1 -1
- package/dist/components/menus/RestartTutorialButton/RestartTutorialButton.js +2 -2
- package/dist/components/menus/RestartTutorialButton/RestartTutorialButton.js.map +1 -1
- package/dist/components/menus/SoundButton/SoundButton.js +3 -2
- package/dist/components/menus/SoundButton/SoundButton.js.map +1 -1
- package/dist/components/menus/TimeStatsButton/TimeStatsButton.js +2 -2
- package/dist/components/menus/TimeStatsButton/TimeStatsButton.js.map +1 -1
- package/dist/components/menus/UndoButton/UndoButton.js +2 -2
- package/dist/components/menus/UndoButton/UndoButton.js.map +1 -1
- package/dist/components/menus/UndoButton/UndoPopButton.js +2 -2
- package/dist/components/menus/UndoButton/UndoPopButton.js.map +1 -1
- package/dist/components/tutorial/FocusableElement.d.ts +0 -0
- package/dist/components/tutorial/FocusableElement.js +2 -0
- package/dist/components/tutorial/FocusableElement.js.map +1 -0
- package/dist/components/tutorial/MaterialTutorial.d.ts +4 -14
- package/dist/components/tutorial/MaterialTutorial.js +1 -60
- package/dist/components/tutorial/MaterialTutorial.js.map +1 -1
- package/dist/components/tutorial/MaterialTutorialDisplay.js +39 -24
- package/dist/components/tutorial/MaterialTutorialDisplay.js.map +1 -1
- package/dist/components/tutorial/TutorialRulesWrapper.js +25 -5
- package/dist/components/tutorial/TutorialRulesWrapper.js.map +1 -1
- package/dist/css/GameTheme.d.ts +4 -0
- package/dist/css/GameTheme.js +3 -0
- package/dist/css/GameTheme.js.map +1 -1
- package/dist/hooks/useHistory.d.ts +6 -0
- package/dist/hooks/useHistory.js +82 -0
- package/dist/hooks/useHistory.js.map +1 -0
- package/dist/hooks/useLegalMoves.js +5 -3
- package/dist/hooks/useLegalMoves.js.map +1 -1
- package/dist/hooks/useRankedPlayers.js.map +1 -1
- package/dist/hooks/useZoomToElements.d.ts +9 -1
- package/dist/hooks/useZoomToElements.js +20 -17
- package/dist/hooks/useZoomToElements.js.map +1 -1
- package/dist/locators/ItemLocator.d.ts +1 -1
- package/dist/locators/ItemLocator.js +3 -3
- package/dist/locators/ItemLocator.js.map +1 -1
- package/dist/utilities/findIfUnique.util.d.ts +1 -0
- package/dist/utilities/findIfUnique.util.js +17 -0
- package/dist/utilities/findIfUnique.util.js.map +1 -0
- package/dist/utilities/index.d.ts +1 -0
- package/dist/utilities/index.js +1 -0
- package/dist/utilities/index.js.map +1 -1
- package/package.json +3 -3
|
@@ -1,12 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.
|
|
3
|
+
exports.isMaterialTutorial = exports.TutorialStepType = exports.MaterialTutorial = void 0;
|
|
7
4
|
var rules_api_1 = require("@gamepark/rules-api");
|
|
8
|
-
var fast_deep_equal_1 = __importDefault(require("fast-deep-equal"));
|
|
9
|
-
var sumBy_1 = __importDefault(require("lodash/sumBy"));
|
|
10
5
|
var MaterialTutorial = (function () {
|
|
11
6
|
function MaterialTutorial() {
|
|
12
7
|
}
|
|
@@ -44,58 +39,4 @@ function isMaterialTutorial(tutorialDescription) {
|
|
|
44
39
|
return !!tutorialDescription && typeof tutorialDescription.material === 'function';
|
|
45
40
|
}
|
|
46
41
|
exports.isMaterialTutorial = isMaterialTutorial;
|
|
47
|
-
function isItemFocus(itemType, itemIndex, focus) {
|
|
48
|
-
if (Array.isArray(focus)) {
|
|
49
|
-
return focus.some(function (focus) { return isItemFocus(itemType, itemIndex, focus); });
|
|
50
|
-
}
|
|
51
|
-
return isMaterialFocus(focus) && focus.type === itemType && focus.getIndexes().includes(itemIndex);
|
|
52
|
-
}
|
|
53
|
-
exports.isItemFocus = isItemFocus;
|
|
54
|
-
function isMaterialFocus(focus) {
|
|
55
|
-
return typeof focus === 'object' && focus.entries !== undefined;
|
|
56
|
-
}
|
|
57
|
-
exports.isMaterialFocus = isMaterialFocus;
|
|
58
|
-
function countTutorialFocusRefs(focus) {
|
|
59
|
-
var _a;
|
|
60
|
-
if (!focus)
|
|
61
|
-
return 0;
|
|
62
|
-
if (Array.isArray(focus)) {
|
|
63
|
-
return (0, sumBy_1.default)(focus, function (focus) { return countTutorialFocusRefs(focus); });
|
|
64
|
-
}
|
|
65
|
-
if (isMaterialFocus(focus)) {
|
|
66
|
-
return (0, sumBy_1.default)(focus.getItems(), function (item) { var _a; return (_a = item.quantity) !== null && _a !== void 0 ? _a : 1; });
|
|
67
|
-
}
|
|
68
|
-
else if (isStaticItem(focus)) {
|
|
69
|
-
return (_a = focus.item.quantity) !== null && _a !== void 0 ? _a : 1;
|
|
70
|
-
}
|
|
71
|
-
else if (isLocationBuilder(focus)) {
|
|
72
|
-
return 1;
|
|
73
|
-
}
|
|
74
|
-
else {
|
|
75
|
-
return 0;
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
exports.countTutorialFocusRefs = countTutorialFocusRefs;
|
|
79
|
-
function isStaticItem(focus) {
|
|
80
|
-
return typeof focus === 'object' && typeof focus.type === 'number' && typeof focus.item === 'object';
|
|
81
|
-
}
|
|
82
|
-
exports.isStaticItem = isStaticItem;
|
|
83
|
-
function isStaticItemFocus(itemType, item, focus) {
|
|
84
|
-
if (Array.isArray(focus)) {
|
|
85
|
-
return focus.some(function (focus) { return isStaticItemFocus(itemType, item, focus); });
|
|
86
|
-
}
|
|
87
|
-
return isStaticItem(focus) && focus.type === itemType && (0, fast_deep_equal_1.default)(focus.item, item);
|
|
88
|
-
}
|
|
89
|
-
exports.isStaticItemFocus = isStaticItemFocus;
|
|
90
|
-
function isLocationBuilder(focus) {
|
|
91
|
-
return typeof focus === 'object' && typeof focus.location === 'object';
|
|
92
|
-
}
|
|
93
|
-
exports.isLocationBuilder = isLocationBuilder;
|
|
94
|
-
function isLocationFocus(location, focus) {
|
|
95
|
-
if (Array.isArray(focus)) {
|
|
96
|
-
return focus.some(function (focus) { return isLocationFocus(location, focus); });
|
|
97
|
-
}
|
|
98
|
-
return isLocationBuilder(focus) && (0, fast_deep_equal_1.default)(focus.location, location);
|
|
99
|
-
}
|
|
100
|
-
exports.isLocationFocus = isLocationFocus;
|
|
101
42
|
//# sourceMappingURL=MaterialTutorial.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MaterialTutorial.js","sourceRoot":"","sources":["../../../src/components/tutorial/MaterialTutorial.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"MaterialTutorial.js","sourceRoot":"","sources":["../../../src/components/tutorial/MaterialTutorial.ts"],"names":[],"mappings":";;;AACA,iDAS4B;AAK5B;IAAA;IA8BA,CAAC;IAvBC,mCAAQ,GAAR,UAAS,IAA2B,EAAE,IAAO;;QAC3C,OAAO,IAAI,oBAAQ,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,KAAK,CAAC,IAAI,CAAC,mCAAI,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,MAAM,CAAC,UAAA,KAAK,IAAI,OAAA,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,KAAK,CAAC,EAAvB,CAAuB,CAAC,CAAC,CAAA;IACrH,CAAC;IAED,mCAAQ,GAAR,UAAS,IAAO;QACd,OAAO,IAAI,2BAAe,CAAC,EAAE,IAAI,MAAA,EAAE,CAAC,CAAA;IACtC,CAAC;IAED,wCAAa,GAAb;QACE,IAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QAC3C,IAAI,CAAC,YAAY,GAAG,CAAC,CAAA;QACrB,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;IAC7B,CAAC;IAED,sCAAW,GAAX,UAAY,KAA6B;QACvC,IAAI,KAAK,CAAC,IAAI,CAAC,YAAY,KAAK,SAAS,IAAI,KAAK,CAAC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;YACxF,IAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;YAChD,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,SAAS,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;gBAAE,OAAM;YACtG,IAAM,KAAK,GAAG,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;YACnD,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAA;SACvD;QACD,OAAO,SAAS,CAAA;IAClB,CAAC;IACH,uBAAC;AAAD,CAAC,AA9BD,IA8BC;AA9BqB,4CAAgB;AAgCtC,IAAY,gBAEX;AAFD,WAAY,gBAAgB;IAC1B,yDAAS,CAAA;IAAE,uDAAI,CAAA;AACjB,CAAC,EAFW,gBAAgB,GAAhB,wBAAgB,KAAhB,wBAAgB,QAE3B;AAoBD,SAAgB,kBAAkB,CAChC,mBAAwD;IAExD,OAAO,CAAC,CAAC,mBAAmB,IAAI,OAAQ,mBAAwC,CAAC,QAAQ,KAAK,UAAU,CAAA;AAC1G,CAAC;AAJD,gDAIC"}
|
|
@@ -20,52 +20,67 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
20
20
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
21
21
|
exports.MaterialTutorialDisplay = void 0;
|
|
22
22
|
var jsx_runtime_1 = require("@emotion/react/jsx-runtime");
|
|
23
|
-
var
|
|
24
|
-
var hooks_1 = require("../../hooks");
|
|
25
|
-
var rules_api_1 = require("@gamepark/rules-api");
|
|
26
|
-
var react_1 = require("react");
|
|
27
|
-
var react_i18next_1 = require("react-i18next");
|
|
28
|
-
var react_2 = require("@emotion/react");
|
|
29
|
-
var buttons_1 = require("../buttons");
|
|
30
|
-
var react_fontawesome_1 = require("@fortawesome/react-fontawesome");
|
|
31
|
-
var faForwardFast_1 = require("@fortawesome/free-solid-svg-icons/faForwardFast");
|
|
32
|
-
var css_1 = require("../../css");
|
|
33
|
-
var minBy_1 = __importDefault(require("lodash/minBy"));
|
|
34
|
-
var maxBy_1 = __importDefault(require("lodash/maxBy"));
|
|
23
|
+
var react_1 = require("@emotion/react");
|
|
35
24
|
var faBackward_1 = require("@fortawesome/free-solid-svg-icons/faBackward");
|
|
36
25
|
var faForward_1 = require("@fortawesome/free-solid-svg-icons/faForward");
|
|
37
|
-
var
|
|
26
|
+
var faForwardFast_1 = require("@fortawesome/free-solid-svg-icons/faForwardFast");
|
|
38
27
|
var faPlay_1 = require("@fortawesome/free-solid-svg-icons/faPlay");
|
|
39
|
-
var
|
|
28
|
+
var react_fontawesome_1 = require("@fortawesome/react-fontawesome");
|
|
40
29
|
var react_client_1 = require("@gamepark/react-client");
|
|
30
|
+
var rules_api_1 = require("@gamepark/rules-api");
|
|
31
|
+
var maxBy_1 = __importDefault(require("lodash/maxBy"));
|
|
32
|
+
var minBy_1 = __importDefault(require("lodash/minBy"));
|
|
33
|
+
var react_2 = require("react");
|
|
34
|
+
var react_i18next_1 = require("react-i18next");
|
|
35
|
+
var react_redux_1 = require("react-redux");
|
|
36
|
+
var css_1 = require("../../css");
|
|
37
|
+
var hooks_1 = require("../../hooks");
|
|
38
|
+
var useTutorialStep_1 = require("../../hooks/useTutorialStep");
|
|
39
|
+
var buttons_1 = require("../buttons");
|
|
40
|
+
var dialogs_1 = require("../dialogs");
|
|
41
|
+
var material_1 = require("../material");
|
|
41
42
|
var MaterialTutorialDisplay = function () {
|
|
42
43
|
var t = (0, react_i18next_1.useTranslation)().t;
|
|
43
44
|
var game = (0, hooks_1.useGame)();
|
|
44
45
|
var tutorialStep = (0, useTutorialStep_1.useTutorialStep)();
|
|
45
46
|
var tutorialMoves = (0, hooks_1.useLegalMoves)(rules_api_1.isSetTutorialStep);
|
|
47
|
+
var closeTutorialPopup = (0, hooks_1.useLegalMove)(rules_api_1.isCloseTutorialPopup);
|
|
46
48
|
var popup = tutorialStep === null || tutorialStep === void 0 ? void 0 : tutorialStep.popup;
|
|
47
49
|
var dispatch = (0, react_redux_1.useDispatch)();
|
|
48
|
-
(0,
|
|
50
|
+
(0, react_2.useEffect)(function () {
|
|
49
51
|
dispatch((0, react_client_1.playTutorialMovesAction)(Infinity));
|
|
50
52
|
}, []);
|
|
51
53
|
var nextStepMove = (0, minBy_1.default)(tutorialMoves, function (move) { return move.step; });
|
|
52
54
|
var passMove = (0, maxBy_1.default)(tutorialMoves, function (move) { return move.step; });
|
|
53
55
|
var _a = (0, hooks_1.useUndo)(), undo = _a[0], canUndo = _a[1];
|
|
54
56
|
var canUndoLastMove = canUndo();
|
|
57
|
+
var setFocus = (0, material_1.useFocusContext)().setFocus;
|
|
58
|
+
(0, react_2.useEffect)(function () {
|
|
59
|
+
if (game && !game.tutorialPopupClosed) {
|
|
60
|
+
if (tutorialStep === null || tutorialStep === void 0 ? void 0 : tutorialStep.focus) {
|
|
61
|
+
setFocus(__assign({ materials: [], staticItems: [], locations: [], highlight: true }, tutorialStep.focus(game)));
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
setFocus(undefined);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
setFocus(undefined, false);
|
|
69
|
+
}
|
|
70
|
+
}, [tutorialStep, game === null || game === void 0 ? void 0 : game.tutorialPopupClosed]);
|
|
55
71
|
return ((0, jsx_runtime_1.jsx)(dialogs_1.Dialog, __assign({ open: popup !== undefined && !(game === null || game === void 0 ? void 0 : game.tutorialPopupClosed), css: [
|
|
56
72
|
tutorialDialogCss,
|
|
57
73
|
(popup === null || popup === void 0 ? void 0 : popup.position) && (0, css_1.transformCss)("translate(".concat(popup.position.x, "em, ").concat(popup.position.y, "em)"))
|
|
58
74
|
], backdropCss: backdropCss }, { children: popup &&
|
|
59
|
-
(0, jsx_runtime_1.jsx)(
|
|
60
|
-
(0, jsx_runtime_1.jsxs)(buttons_1.PlayMoveButton, __assign({ move:
|
|
61
|
-
: (0, jsx_runtime_1.jsxs)(buttons_1.PlayMoveButton, __assign({ move:
|
|
75
|
+
(0, jsx_runtime_1.jsx)(react_1.ThemeProvider, __assign({ theme: function (theme) { return (__assign(__assign({}, theme), { buttons: (0, css_1.buttonCss)('#002448', '#c2ebf1', '#ade4ec') })); } }, { children: (0, jsx_runtime_1.jsxs)("div", __assign({ css: rules }, { children: [passMove && (0, jsx_runtime_1.jsxs)(buttons_1.PlayMoveButton, __assign({ move: passMove, css: passButton }, { children: [t('Pass'), "\u00A0", (0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { icon: faForwardFast_1.faForwardFast })] })), (0, jsx_runtime_1.jsx)("p", { children: popup.text(t) }), (0, jsx_runtime_1.jsxs)("p", __assign({ css: buttonsLine }, { children: [(0, jsx_runtime_1.jsxs)(buttons_1.ThemeButton, __assign({ disabled: !canUndoLastMove, onClick: function () { return undo(); } }, { children: [(0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { icon: faBackward_1.faBackward }), "\u00A0", t('Previous')] })), closeTutorialPopup ?
|
|
76
|
+
(0, jsx_runtime_1.jsxs)(buttons_1.PlayMoveButton, __assign({ move: closeTutorialPopup }, { children: [t('OK'), "\u00A0", (0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { icon: faPlay_1.faPlay })] }))
|
|
77
|
+
: (0, jsx_runtime_1.jsxs)(buttons_1.PlayMoveButton, __assign({ move: nextStepMove, disabled: !nextStepMove }, { children: [t('Next'), "\u00A0", (0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { icon: faForward_1.faForward })] }))] }))] })) })) })));
|
|
62
78
|
};
|
|
63
79
|
exports.MaterialTutorialDisplay = MaterialTutorialDisplay;
|
|
64
|
-
var rules = (0,
|
|
65
|
-
var backdropCss = (0,
|
|
66
|
-
var passButton = (0,
|
|
67
|
-
var buttonsLine = (0,
|
|
68
|
-
var tutorialDialogCss = (0,
|
|
69
|
-
var closeTutorialPopup = { kind: rules_api_1.MoveKind.LocalMove, type: rules_api_1.LocalMoveType.CloseTutorialPopup };
|
|
80
|
+
var rules = (0, react_1.css)(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n margin: 0 1em;\n font-size: 3em;\n padding-top: 1em;\n\n > h2 {\n margin: 0 1em;\n text-align: center;\n }\n\n > p {\n white-space: break-spaces;\n }\n"], ["\n margin: 0 1em;\n font-size: 3em;\n padding-top: 1em;\n\n > h2 {\n margin: 0 1em;\n text-align: center;\n }\n\n > p {\n white-space: break-spaces;\n }\n"])));
|
|
81
|
+
var backdropCss = (0, react_1.css)(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n background: none;\n pointer-events: none;\n z-index: 900;\n"], ["\n background: none;\n pointer-events: none;\n z-index: 900;\n"])));
|
|
82
|
+
var passButton = (0, react_1.css)(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n position: absolute;\n font-size: 0.7em;\n top: 1em;\n right: 1.8em;\n"], ["\n position: absolute;\n font-size: 0.7em;\n top: 1em;\n right: 1.8em;\n"])));
|
|
83
|
+
var buttonsLine = (0, react_1.css)(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n display: flex;\n justify-content: space-between;\n"], ["\n display: flex;\n justify-content: space-between;\n"])));
|
|
84
|
+
var tutorialDialogCss = (0, react_1.css)(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n width: 80em;\n pointer-events: auto;\n transition: transform 0.1s ease-in-out;\n"], ["\n width: 80em;\n pointer-events: auto;\n transition: transform 0.1s ease-in-out;\n"])));
|
|
70
85
|
var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5;
|
|
71
86
|
//# sourceMappingURL=MaterialTutorialDisplay.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MaterialTutorialDisplay.js","sourceRoot":"","sources":["../../../src/components/tutorial/MaterialTutorialDisplay.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AACA,
|
|
1
|
+
{"version":3,"file":"MaterialTutorialDisplay.js","sourceRoot":"","sources":["../../../src/components/tutorial/MaterialTutorialDisplay.tsx"],"names":[],"mappings":"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"}
|
|
@@ -20,7 +20,7 @@ function wrapRulesWithTutorial(tutorial, Rules) {
|
|
|
20
20
|
return playerId === ((_b = (_a = tutorialStep.move) === null || _a === void 0 ? void 0 : _a.player) !== null && _b !== void 0 ? _b : this.game.players[0]);
|
|
21
21
|
};
|
|
22
22
|
Rules.prototype.getLegalMoves = function (playerId) {
|
|
23
|
-
var _a;
|
|
23
|
+
var _a, _b;
|
|
24
24
|
var game = this.game;
|
|
25
25
|
if (game.tutorialStep === undefined || game.tutorialStep >= tutorial.steps.length) {
|
|
26
26
|
return getLegalMoves.bind(this)(playerId);
|
|
@@ -31,6 +31,9 @@ function wrapRulesWithTutorial(tutorial, Rules) {
|
|
|
31
31
|
if (playerId !== player)
|
|
32
32
|
return [];
|
|
33
33
|
var legalMoves = getLegalMoves.bind(this)(playerId);
|
|
34
|
+
if ((_b = game.tutorialInterrupt) === null || _b === void 0 ? void 0 : _b.length) {
|
|
35
|
+
legalMoves = [];
|
|
36
|
+
}
|
|
34
37
|
var filter_1 = tutorialStep.move.filter;
|
|
35
38
|
if (filter_1) {
|
|
36
39
|
legalMoves = legalMoves.filter(function (move) { return filter_1(move, game); });
|
|
@@ -52,12 +55,29 @@ function wrapRulesWithTutorial(tutorial, Rules) {
|
|
|
52
55
|
};
|
|
53
56
|
var play = Rules.prototype.play;
|
|
54
57
|
Rules.prototype.play = function (move) {
|
|
58
|
+
var _a;
|
|
55
59
|
var game = this.game;
|
|
56
|
-
var
|
|
57
|
-
|
|
58
|
-
|
|
60
|
+
var stepIndex = game.tutorialStep;
|
|
61
|
+
var consequences = play.bind(this)(move);
|
|
62
|
+
if (move.kind !== rules_api_1.MoveKind.LocalMove && stepIndex !== undefined && stepIndex < tutorial.steps.length) {
|
|
63
|
+
var step = tutorial.steps[stepIndex];
|
|
64
|
+
if (step.move) {
|
|
65
|
+
game.tutorialStepComplete = true;
|
|
66
|
+
if (step.move.interrupt) {
|
|
67
|
+
var interruptIndex = consequences.findIndex(step.move.interrupt);
|
|
68
|
+
if (interruptIndex !== -1) {
|
|
69
|
+
this.game.tutorialInterrupt = consequences.slice(interruptIndex);
|
|
70
|
+
consequences.splice(interruptIndex, consequences.length - interruptIndex);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
else if (move.kind === rules_api_1.MoveKind.LocalMove && move.type === rules_api_1.LocalMoveType.CloseTutorialPopup) {
|
|
76
|
+
var moves = (_a = this.game.tutorialInterrupt) !== null && _a !== void 0 ? _a : [];
|
|
77
|
+
delete this.game.tutorialInterrupt;
|
|
78
|
+
return moves;
|
|
59
79
|
}
|
|
60
|
-
return
|
|
80
|
+
return consequences;
|
|
61
81
|
};
|
|
62
82
|
var getAutomaticMoves = Rules.prototype.getAutomaticMoves;
|
|
63
83
|
Rules.prototype.getAutomaticMoves = function () {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TutorialRulesWrapper.js","sourceRoot":"","sources":["../../../src/components/tutorial/TutorialRulesWrapper.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"TutorialRulesWrapper.js","sourceRoot":"","sources":["../../../src/components/tutorial/TutorialRulesWrapper.ts"],"names":[],"mappings":"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"}
|
package/dist/css/GameTheme.d.ts
CHANGED
package/dist/css/GameTheme.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GameTheme.js","sourceRoot":"","sources":["../../src/css/GameTheme.ts"],"names":[],"mappings":";;;AACA,uDAAqD;AAErD,IAAA,mCAAgB,EAAC,wHAAwH,CAAC,CAAA;
|
|
1
|
+
{"version":3,"file":"GameTheme.js","sourceRoot":"","sources":["../../src/css/GameTheme.ts"],"names":[],"mappings":";;;AACA,uDAAqD;AAErD,IAAA,mCAAgB,EAAC,wHAAwH,CAAC,CAAA;AA4B7H,QAAA,YAAY,GAAc;IACrC,IAAI,EAAE;QACJ,UAAU,EAAE,QAAQ;QACpB,UAAU,EAAE;YACV,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,UAAU,GAAG,iBAAiB;YACjD,OAAO,EAAE,oBAAoB;SAC9B;KACF;IACD,MAAM,EAAE;QACN,eAAe,EAAE,SAAS;QAC1B,KAAK,EAAE,SAAS;KACjB;IACD,QAAQ,EAAE;QACR,eAAe,EAAE,sBAAsB;KACxC;CACF,CAAA"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.useHistory = void 0;
|
|
7
|
+
var jsx_runtime_1 = require("react/jsx-runtime");
|
|
8
|
+
var rules_api_1 = require("@gamepark/rules-api");
|
|
9
|
+
var keyBy_1 = __importDefault(require("lodash/keyBy"));
|
|
10
|
+
var react_1 = require("react");
|
|
11
|
+
var react_redux_1 = require("react-redux");
|
|
12
|
+
var components_1 = require("../components");
|
|
13
|
+
var useActions_1 = require("./useActions");
|
|
14
|
+
var useHistory = function () {
|
|
15
|
+
var _a, _b;
|
|
16
|
+
var context = (0, react_1.useContext)(components_1.gameContext);
|
|
17
|
+
var setup = (_a = (0, react_redux_1.useSelector)(function (state) { return state.setup; })) !== null && _a !== void 0 ? _a : {};
|
|
18
|
+
var actions = (_b = (0, useActions_1.useActions)()) !== null && _b !== void 0 ? _b : [];
|
|
19
|
+
var filteredActions = (0, react_1.useMemo)(function () { return (actions !== null && actions !== void 0 ? actions : []).filter(function (a) { return !a.pending && a.id !== undefined; }); }, [actions]);
|
|
20
|
+
var historyRef = (0, react_1.useRef)(new Map());
|
|
21
|
+
var _c = (0, react_1.useState)(0), historySize = _c[0], setHistorySize = _c[1];
|
|
22
|
+
var rules = (0, react_1.useRef)();
|
|
23
|
+
(0, react_1.useEffect)(function () {
|
|
24
|
+
if (!rules.current && setup) {
|
|
25
|
+
rules.current = new context.Rules(JSON.parse(JSON.stringify(setup)));
|
|
26
|
+
}
|
|
27
|
+
}, [setup]);
|
|
28
|
+
var MaterialHistory = context.MaterialHistory;
|
|
29
|
+
var getMoveEntry = (0, react_1.useCallback)(function (action, move, consequenceIndex, rules) {
|
|
30
|
+
var historyContext = {
|
|
31
|
+
consequenceIndex: consequenceIndex,
|
|
32
|
+
action: action,
|
|
33
|
+
game: JSON.parse(JSON.stringify(rules.game))
|
|
34
|
+
};
|
|
35
|
+
return (0, jsx_runtime_1.jsx)(MaterialHistory, { move: move, context: historyContext });
|
|
36
|
+
}, [context]);
|
|
37
|
+
var addActionEntries = (0, react_1.useCallback)(function (histories, action) {
|
|
38
|
+
var _a, _b;
|
|
39
|
+
histories.set(action.id, []);
|
|
40
|
+
var actionEntry = getMoveEntry(action, action.move, undefined, rules.current);
|
|
41
|
+
(_a = rules.current) === null || _a === void 0 ? void 0 : _a.play(action.move);
|
|
42
|
+
histories.get(action.id).push(actionEntry);
|
|
43
|
+
for (var index = 0; index < action.consequences.length; index++) {
|
|
44
|
+
var consequence = action.consequences[index];
|
|
45
|
+
var consequenceEntry = getMoveEntry(action, consequence, index, rules.current);
|
|
46
|
+
(_b = rules.current) === null || _b === void 0 ? void 0 : _b.play(consequence);
|
|
47
|
+
histories.get(action.id).push(consequenceEntry);
|
|
48
|
+
}
|
|
49
|
+
}, []);
|
|
50
|
+
(0, react_1.useEffect)(function () {
|
|
51
|
+
var histories = historyRef.current;
|
|
52
|
+
var actualSize = histories.size;
|
|
53
|
+
if (actualSize < filteredActions.length) {
|
|
54
|
+
for (var _i = 0, filteredActions_1 = filteredActions; _i < filteredActions_1.length; _i++) {
|
|
55
|
+
var action = filteredActions_1[_i];
|
|
56
|
+
if (histories.has(action.id))
|
|
57
|
+
continue;
|
|
58
|
+
addActionEntries(histories, action);
|
|
59
|
+
}
|
|
60
|
+
setHistorySize(histories.size);
|
|
61
|
+
historyRef.current = histories;
|
|
62
|
+
}
|
|
63
|
+
else if (actualSize > filteredActions.length) {
|
|
64
|
+
var actionsById = (0, keyBy_1.default)(filteredActions, function (a) { return a.id; });
|
|
65
|
+
for (var _a = 0, _b = Array.from(histories.keys()); _a < _b.length; _a++) {
|
|
66
|
+
var key = _b[_a];
|
|
67
|
+
if (!(key in actionsById))
|
|
68
|
+
histories.delete(key);
|
|
69
|
+
}
|
|
70
|
+
rules.current = new context.Rules(JSON.parse(JSON.stringify(setup)));
|
|
71
|
+
(0, rules_api_1.replayActions)(rules.current, filteredActions);
|
|
72
|
+
setHistorySize(histories.size);
|
|
73
|
+
historyRef.current = histories;
|
|
74
|
+
}
|
|
75
|
+
}, [filteredActions.length]);
|
|
76
|
+
return {
|
|
77
|
+
histories: historyRef.current,
|
|
78
|
+
size: historySize
|
|
79
|
+
};
|
|
80
|
+
};
|
|
81
|
+
exports.useHistory = useHistory;
|
|
82
|
+
//# sourceMappingURL=useHistory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useHistory.js","sourceRoot":"","sources":["../../src/hooks/useHistory.tsx"],"names":[],"mappings":"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"}
|
|
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.useLegalMove = exports.useLegalMoves = void 0;
|
|
4
4
|
var react_1 = require("react");
|
|
5
5
|
var react_redux_1 = require("react-redux");
|
|
6
|
+
var useIsAnimatingPlayerAction_1 = require("../components/material/utils/useIsAnimatingPlayerAction");
|
|
6
7
|
var usePlayerId_1 = require("./usePlayerId");
|
|
7
8
|
var useRules_1 = require("./useRules");
|
|
8
9
|
var cache = {
|
|
@@ -13,15 +14,16 @@ function useLegalMoves(predicate) {
|
|
|
13
14
|
var rules = (0, useRules_1.useRules)();
|
|
14
15
|
var playerId = (0, usePlayerId_1.usePlayerId)();
|
|
15
16
|
var gameOver = (0, react_redux_1.useSelector)(function (state) { return state.gameOver; });
|
|
16
|
-
|
|
17
|
+
var isAnimatingPlayerAction = (0, useIsAnimatingPlayerAction_1.useIsAnimatingPlayerAction)();
|
|
18
|
+
if (rules && playerId !== undefined && cache.game !== rules.game && !isAnimatingPlayerAction) {
|
|
17
19
|
cache.game = rules.game;
|
|
18
20
|
cache.moves = rules.getLegalMoves(playerId);
|
|
19
21
|
}
|
|
20
22
|
return (0, react_1.useMemo)(function () {
|
|
21
|
-
if (gameOver)
|
|
23
|
+
if (gameOver || isAnimatingPlayerAction)
|
|
22
24
|
return [];
|
|
23
25
|
return predicate ? cache.moves.filter(predicate) : cache.moves;
|
|
24
|
-
}, [cache.moves, predicate, gameOver]);
|
|
26
|
+
}, [cache.moves, predicate, gameOver, isAnimatingPlayerAction]);
|
|
25
27
|
}
|
|
26
28
|
exports.useLegalMoves = useLegalMoves;
|
|
27
29
|
function useLegalMove(predicate) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useLegalMoves.js","sourceRoot":"","sources":["../../src/hooks/useLegalMoves.ts"],"names":[],"mappings":";;;AACA,+BAA+B;AAC/B,2CAAyC;AACzC,6CAA2C;AAC3C,uCAAqC;AAOrC,IAAM,KAAK,GAAU;IACnB,IAAI,EAAE,SAAS;IACf,KAAK,EAAE,EAAE;CACV,CAAA;AAED,SAAgB,aAAa,CAAa,SAAmC;IAC3E,IAAM,KAAK,GAAG,IAAA,mBAAQ,GAAE,CAAA;IACxB,IAAM,QAAQ,GAAG,IAAA,yBAAW,GAAE,CAAA;IAC9B,IAAM,QAAQ,GAAG,IAAA,yBAAW,EAAC,UAAC,KAAoB,IAAK,OAAA,KAAK,CAAC,QAAQ,EAAd,CAAc,CAAC,CAAA;IACtE,IAAI,KAAK,IAAI,QAAQ,KAAK,SAAS,IAAI,KAAK,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,EAAE;
|
|
1
|
+
{"version":3,"file":"useLegalMoves.js","sourceRoot":"","sources":["../../src/hooks/useLegalMoves.ts"],"names":[],"mappings":";;;AACA,+BAA+B;AAC/B,2CAAyC;AACzC,sGAAoG;AACpG,6CAA2C;AAC3C,uCAAqC;AAOrC,IAAM,KAAK,GAAU;IACnB,IAAI,EAAE,SAAS;IACf,KAAK,EAAE,EAAE;CACV,CAAA;AAED,SAAgB,aAAa,CAAa,SAAmC;IAC3E,IAAM,KAAK,GAAG,IAAA,mBAAQ,GAAE,CAAA;IACxB,IAAM,QAAQ,GAAG,IAAA,yBAAW,GAAE,CAAA;IAC9B,IAAM,QAAQ,GAAG,IAAA,yBAAW,EAAC,UAAC,KAAoB,IAAK,OAAA,KAAK,CAAC,QAAQ,EAAd,CAAc,CAAC,CAAA;IACtE,IAAM,uBAAuB,GAAG,IAAA,uDAA0B,GAAE,CAAA;IAC5D,IAAI,KAAK,IAAI,QAAQ,KAAK,SAAS,IAAI,KAAK,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,IAAI,CAAC,uBAAuB,EAAE;QAC5F,KAAK,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAA;QACvB,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAA;KAC5C;IACD,OAAO,IAAA,eAAO,EAAC;QACX,IAAI,QAAQ,IAAI,uBAAuB;YAAE,OAAO,EAAE,CAAA;QAClD,OAAO,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAA;IAChE,CAAC,EACD,CAAC,KAAK,CAAC,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,uBAAuB,CAAC,CAAC,CAAA;AAChE,CAAC;AAdD,sCAcC;AAED,SAAgB,YAAY,CAAa,SAAmC;IAC1E,IAAM,KAAK,GAAG,aAAa,CAAC,SAAS,CAAC,CAAA;IACtC,OAAO,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;AAChD,CAAC;AAHD,oCAGC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useRankedPlayers.js","sourceRoot":"","sources":["../../src/hooks/useRankedPlayers.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"useRankedPlayers.js","sourceRoot":"","sources":["../../src/hooks/useRankedPlayers.ts"],"names":[],"mappings":";;;AACA,iDAAgE;AAChE,2CAAuD;AACvD,6CAA4C;AAC5C,uCAAqC;AAE9B,IAAM,gBAAgB,GAAG;IAC9B,IAAM,KAAK,GAAG,IAAA,mBAAQ,GAAE,CAAA;IACxB,IAAM,SAAS,GAAG,IAAA,0BAAY,GAAE,CAAA;IAChC,IAAM,cAAc,GAAG,IAAA,yBAAW,EAAC,UAAC,KAAwC;QAC1E,OAAA,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,IAAI,EAAN,CAAM,CAAC,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,EAAE,EAAJ,CAAI,CAAC;IAAhD,CAAgD,EAAE,0BAAY,CAAC,CAAA;IACjE,IAAM,aAAa,GAAG,SAAS,CAAC,GAAG,CAAC,UAAA,EAAE,IAAI,OAAA,CAAC,EAAE,EAAE,IAAA,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,cAAc,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE,CAAC,EAApD,CAAoD,CAAC,CAAA;IAC/F,IAAI,KAAK,IAAI,IAAA,yBAAa,EAAC,KAAK,CAAC,EAAE;QACjC,aAAa,CAAC,IAAI,CAAC,UAAC,OAAO,EAAE,OAAO;YAClC,IAAI,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,EAAE;gBAChC,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;aAChD;YACD,OAAO,IAAA,uBAAW,EAAC,KAAK,EAAE,OAAO,CAAC,EAAE,EAAE,OAAO,CAAC,EAAE,CAAC,CAAA;QACnD,CAAC,CAAC,CAAA;QACF,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,aAAa,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC7C,IAAI,aAAa,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE;gBAC7B,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,aAAa,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAA;aAClD;iBAAM,IAAI,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE;gBAChC,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,aAAa,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAA;aACtD;iBAAM;gBACL,IAAM,IAAI,GAAG,IAAA,uBAAW,EAAC,KAAK,EAAE,aAAa,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;gBAC7E,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAA;aAC/F;SACF;KACF;IACD,OAAO,aAAa,CAAA;AACtB,CAAC,CAAA;AAzBY,QAAA,gBAAgB,oBAyB5B"}
|
|
@@ -1,2 +1,10 @@
|
|
|
1
|
+
import { Margin } from '../components';
|
|
1
2
|
import { animations } from '../utilities/animations.constants';
|
|
2
|
-
export declare function useZoomToElements(): (elements: HTMLElement[],
|
|
3
|
+
export declare function useZoomToElements(): (elements: HTMLElement[], options?: ZoomToElementsOptions) => void;
|
|
4
|
+
type ZoomToElementsOptions = {
|
|
5
|
+
scale?: number;
|
|
6
|
+
animationTime?: number;
|
|
7
|
+
animationType?: keyof typeof animations;
|
|
8
|
+
margin?: Margin;
|
|
9
|
+
};
|
|
10
|
+
export {};
|
|
@@ -2,50 +2,53 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.useZoomToElements = void 0;
|
|
4
4
|
var react_zoom_pan_pinch_1 = require("react-zoom-pan-pinch");
|
|
5
|
+
var animations_util_1 = require("../utilities/animations.util");
|
|
5
6
|
var bounds_util_1 = require("../utilities/bounds.util");
|
|
6
7
|
var zoom_util_1 = require("../utilities/zoom.util");
|
|
7
|
-
var animations_util_1 = require("../utilities/animations.util");
|
|
8
8
|
function useZoomToElements() {
|
|
9
9
|
var libraryContext = (0, react_zoom_pan_pinch_1.useTransformContext)();
|
|
10
10
|
return zoomToElements(libraryContext);
|
|
11
11
|
}
|
|
12
12
|
exports.useZoomToElements = useZoomToElements;
|
|
13
|
-
var zoomToElements = function (contextInstance) { return function (nodes,
|
|
14
|
-
if (
|
|
15
|
-
if (animationType === void 0) { animationType = 'easeOut'; }
|
|
13
|
+
var zoomToElements = function (contextInstance) { return function (nodes, options) {
|
|
14
|
+
if (options === void 0) { options = {}; }
|
|
16
15
|
(0, animations_util_1.handleCancelAnimation)(contextInstance);
|
|
17
16
|
var wrapperComponent = contextInstance.wrapperComponent;
|
|
17
|
+
var scale = options.scale, _a = options.animationTime, animationTime = _a === void 0 ? 600 : _a, _b = options.animationType, animationType = _b === void 0 ? 'easeOut' : _b, margin = options.margin;
|
|
18
18
|
var targets = nodes.map(function (node) {
|
|
19
19
|
return typeof node === 'string' ? document.getElementById(node) : node;
|
|
20
20
|
});
|
|
21
21
|
if (wrapperComponent && targets.length && targets.every(function (target) { return wrapperComponent.contains(target); })) {
|
|
22
|
-
var targetState = calculateZoomToNodes(contextInstance, targets, scale);
|
|
22
|
+
var targetState = calculateZoomToNodes(contextInstance, targets, { customZoom: scale, margin: margin });
|
|
23
23
|
(0, animations_util_1.animate)(contextInstance, targetState, animationTime, animationType);
|
|
24
24
|
}
|
|
25
25
|
}; };
|
|
26
|
-
function calculateZoomToNodes(contextInstance, nodes,
|
|
26
|
+
function calculateZoomToNodes(contextInstance, nodes, options) {
|
|
27
|
+
if (options === void 0) { options = {}; }
|
|
27
28
|
var wrapperComponent = contextInstance.wrapperComponent, contentComponent = contextInstance.contentComponent, transformState = contextInstance.transformState;
|
|
28
29
|
var _a = contextInstance.setup, limitToBounds = _a.limitToBounds, minScale = _a.minScale, maxScale = _a.maxScale;
|
|
29
30
|
if (!wrapperComponent || !contentComponent)
|
|
30
31
|
return transformState;
|
|
32
|
+
var customZoom = options.customZoom, _b = options.margin, _c = _b === void 0 ? {} : _b, _d = _c.bottom, bottom = _d === void 0 ? 0 : _d, _e = _c.left, left = _e === void 0 ? 0 : _e, _f = _c.right, right = _f === void 0 ? 0 : _f, _g = _c.top, top = _g === void 0 ? 0 : _g;
|
|
31
33
|
var wrapperRect = wrapperComponent.getBoundingClientRect();
|
|
34
|
+
var fontSize = parseFloat(window.getComputedStyle(contentComponent.firstElementChild, null).getPropertyValue('font-size'));
|
|
32
35
|
var nodesRect = nodes.map(function (node) { return node.getBoundingClientRect(); });
|
|
33
36
|
var nodesWidth = Math.max.apply(Math, nodesRect.map(function (rect) { return rect.x + rect.width; })) - Math.min.apply(Math, nodesRect.map(function (rect) { return rect.x; }));
|
|
34
37
|
var nodesHeight = Math.max.apply(Math, nodesRect.map(function (rect) { return rect.y + rect.height; })) - Math.min.apply(Math, nodesRect.map(function (rect) { return rect.y; }));
|
|
35
38
|
var nodesOffset = nodes.map(function (node) { return getOffset(node, wrapperComponent, contentComponent, transformState); });
|
|
36
|
-
var
|
|
37
|
-
var
|
|
38
|
-
var
|
|
39
|
-
var
|
|
40
|
-
var scaleX = wrapperComponent.offsetWidth /
|
|
41
|
-
var scaleY = wrapperComponent.offsetHeight /
|
|
39
|
+
var focusLeft = Math.min.apply(Math, nodesOffset.map(function (offset) { return offset.x; })) - left * fontSize;
|
|
40
|
+
var focusTop = Math.min.apply(Math, nodesOffset.map(function (offset) { return offset.y; })) - top * fontSize;
|
|
41
|
+
var focusWidth = nodesWidth / transformState.scale + (left + right) * fontSize;
|
|
42
|
+
var focusHeight = nodesHeight / transformState.scale + (top + bottom) * fontSize;
|
|
43
|
+
var scaleX = wrapperComponent.offsetWidth / focusWidth;
|
|
44
|
+
var scaleY = wrapperComponent.offsetHeight / focusHeight;
|
|
42
45
|
var newScale = (0, zoom_util_1.checkZoomBounds)(customZoom || Math.min(scaleX, scaleY), minScale, maxScale, 0, false);
|
|
43
|
-
var offsetX = (wrapperRect.width -
|
|
44
|
-
var offsetY = (wrapperRect.height -
|
|
45
|
-
var newPositionX = (wrapperRect.left -
|
|
46
|
-
var newPositionY = (wrapperRect.top -
|
|
46
|
+
var offsetX = (wrapperRect.width - focusWidth * newScale) / 2;
|
|
47
|
+
var offsetY = (wrapperRect.height - focusHeight * newScale) / 2;
|
|
48
|
+
var newPositionX = (wrapperRect.left - focusLeft) * newScale + offsetX;
|
|
49
|
+
var newPositionY = (wrapperRect.top - focusTop) * newScale + offsetY;
|
|
47
50
|
var bounds = (0, bounds_util_1.calculateBounds)(contextInstance, newScale);
|
|
48
|
-
var
|
|
51
|
+
var _h = (0, bounds_util_1.getMouseBoundedPosition)(newPositionX, newPositionY, bounds, limitToBounds, 0, 0, wrapperComponent), x = _h.x, y = _h.y;
|
|
49
52
|
return { positionX: x, positionY: y, scale: newScale };
|
|
50
53
|
}
|
|
51
54
|
function getOffset(element, wrapper, content, state) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useZoomToElements.js","sourceRoot":"","sources":["../../src/hooks/useZoomToElements.ts"],"names":[],"mappings":";;;AAAA,6DAA4G;
|
|
1
|
+
{"version":3,"file":"useZoomToElements.js","sourceRoot":"","sources":["../../src/hooks/useZoomToElements.ts"],"names":[],"mappings":"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"}
|
|
@@ -11,7 +11,7 @@ export declare class ItemLocator<P extends number = number, M extends number = n
|
|
|
11
11
|
transformItemLocation(item: MaterialItem<P, L>, context: ItemContext<P, M, L>): string[];
|
|
12
12
|
protected transformOwnItemLocation(item: MaterialItem<P, L>, context: ItemContext<P, M, L>): string[];
|
|
13
13
|
getTranslate3d(item: MaterialItem<P, L>, context: ItemContext<P, M, L>): string;
|
|
14
|
-
getParentItemId(_location: Location<P, L>): number | undefined;
|
|
14
|
+
getParentItemId(_location: Location<P, L>, _context: ItemContext<P, M, L>): number | undefined;
|
|
15
15
|
position: XYCoordinates;
|
|
16
16
|
getPosition(item: MaterialItem<P, L>, context: ItemContext<P, M, L>): Coordinates;
|
|
17
17
|
positionOnParent: XYCoordinates;
|
|
@@ -67,13 +67,13 @@ var ItemLocator = (function () {
|
|
|
67
67
|
var parentMaterial = this.parentItemType ? context.material[this.parentItemType] : undefined;
|
|
68
68
|
if (parentMaterial) {
|
|
69
69
|
var positionOnParent = this.getPositionOnParent(item.location, context);
|
|
70
|
-
var _b = parentMaterial.getSize(this.getParentItemId(item.location
|
|
70
|
+
var _b = parentMaterial.getSize(this.getParentItemId(item.location, context)), width = _b.width, height = _b.height;
|
|
71
71
|
x += width * (positionOnParent.x - 50) / 100;
|
|
72
72
|
y += height * (positionOnParent.y - 50) / 100;
|
|
73
73
|
}
|
|
74
74
|
return "translate3d(".concat(x, "em, ").concat(y, "em, ").concat(z, "em)");
|
|
75
75
|
};
|
|
76
|
-
ItemLocator.prototype.getParentItemId = function (_location) {
|
|
76
|
+
ItemLocator.prototype.getParentItemId = function (_location, _context) {
|
|
77
77
|
return undefined;
|
|
78
78
|
};
|
|
79
79
|
ItemLocator.prototype.getPosition = function (item, context) {
|
|
@@ -104,7 +104,7 @@ var ItemLocator = (function () {
|
|
|
104
104
|
return (_a = parentLocator === null || parentLocator === void 0 ? void 0 : parentLocator.transformItemLocation(parentItem, __assign(__assign({}, context), { type: this.parentItemType, displayIndex: 0 }))) !== null && _a !== void 0 ? _a : [];
|
|
105
105
|
}
|
|
106
106
|
else {
|
|
107
|
-
var parentItemId_1 = this.getParentItemId(location);
|
|
107
|
+
var parentItemId_1 = this.getParentItemId(location, context);
|
|
108
108
|
var staticItem = parentMaterial === null || parentMaterial === void 0 ? void 0 : parentMaterial.getStaticItems(context).find(function (item) { return (0, fast_deep_equal_1.default)(item.id, parentItemId_1); });
|
|
109
109
|
if (!staticItem)
|
|
110
110
|
return [];
|