kaggle-environments 0.2.1__py3-none-any.whl → 1.20.1__py3-none-any.whl
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.
Potentially problematic release.
This version of kaggle-environments might be problematic. Click here for more details.
- kaggle_environments/__init__.py +49 -13
- kaggle_environments/agent.py +177 -124
- kaggle_environments/api.py +31 -0
- kaggle_environments/core.py +295 -170
- kaggle_environments/envs/cabt/cabt.js +164 -0
- kaggle_environments/envs/cabt/cabt.json +28 -0
- kaggle_environments/envs/cabt/cabt.py +186 -0
- kaggle_environments/envs/cabt/cg/__init__.py +0 -0
- kaggle_environments/envs/cabt/cg/cg.dll +0 -0
- kaggle_environments/envs/cabt/cg/game.py +75 -0
- kaggle_environments/envs/cabt/cg/libcg.so +0 -0
- kaggle_environments/envs/cabt/cg/sim.py +48 -0
- kaggle_environments/envs/cabt/test_cabt.py +120 -0
- kaggle_environments/envs/chess/chess.js +4289 -0
- kaggle_environments/envs/chess/chess.json +60 -0
- kaggle_environments/envs/chess/chess.py +4241 -0
- kaggle_environments/envs/chess/test_chess.py +60 -0
- kaggle_environments/envs/connectx/connectx.ipynb +3186 -0
- kaggle_environments/envs/connectx/connectx.js +1 -1
- kaggle_environments/envs/connectx/connectx.json +15 -1
- kaggle_environments/envs/connectx/connectx.py +6 -23
- kaggle_environments/envs/connectx/test_connectx.py +70 -24
- kaggle_environments/envs/football/football.ipynb +75 -0
- kaggle_environments/envs/football/football.json +91 -0
- kaggle_environments/envs/football/football.py +277 -0
- kaggle_environments/envs/football/helpers.py +95 -0
- kaggle_environments/envs/football/test_football.py +360 -0
- kaggle_environments/envs/halite/__init__.py +0 -0
- kaggle_environments/envs/halite/halite.ipynb +44741 -0
- kaggle_environments/envs/halite/halite.js +199 -83
- kaggle_environments/envs/halite/halite.json +31 -18
- kaggle_environments/envs/halite/halite.py +164 -303
- kaggle_environments/envs/halite/helpers.py +720 -0
- kaggle_environments/envs/halite/test_halite.py +190 -0
- kaggle_environments/envs/hungry_geese/__init__.py +0 -0
- kaggle_environments/envs/{battlegeese/battlegeese.js → hungry_geese/hungry_geese.js} +38 -22
- kaggle_environments/envs/{battlegeese/battlegeese.json → hungry_geese/hungry_geese.json} +21 -14
- kaggle_environments/envs/hungry_geese/hungry_geese.py +316 -0
- kaggle_environments/envs/hungry_geese/test_hungry_geese.py +0 -0
- kaggle_environments/envs/identity/identity.json +6 -5
- kaggle_environments/envs/identity/identity.py +15 -2
- kaggle_environments/envs/kore_fleets/__init__.py +0 -0
- kaggle_environments/envs/kore_fleets/helpers.py +1005 -0
- kaggle_environments/envs/kore_fleets/kore_fleets.ipynb +114 -0
- kaggle_environments/envs/kore_fleets/kore_fleets.js +658 -0
- kaggle_environments/envs/kore_fleets/kore_fleets.json +164 -0
- kaggle_environments/envs/kore_fleets/kore_fleets.py +555 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/Bot.java +54 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/README.md +26 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/jars/hamcrest-core-1.3.jar +0 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/jars/junit-4.13.2.jar +0 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Board.java +518 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Cell.java +61 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Configuration.java +24 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Direction.java +166 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Fleet.java +72 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/KoreJson.java +97 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Observation.java +72 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Pair.java +13 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Player.java +68 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Point.java +65 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Shipyard.java +70 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/ShipyardAction.java +59 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/main.py +73 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/BoardTest.java +567 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/ConfigurationTest.java +25 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/KoreJsonTest.java +62 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/ObservationTest.java +46 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/PointTest.java +21 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/ShipyardTest.java +22 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/configuration.json +1 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/fullob.json +1 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/observation.json +1 -0
- kaggle_environments/envs/kore_fleets/starter_bots/python/__init__.py +0 -0
- kaggle_environments/envs/kore_fleets/starter_bots/python/main.py +27 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/Bot.ts +34 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/DoNothingBot.ts +12 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/MinerBot.ts +62 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/README.md +55 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/interpreter.ts +402 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Board.ts +514 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Cell.ts +63 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Configuration.ts +25 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Direction.ts +169 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Fleet.ts +76 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/KoreIO.ts +70 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Observation.ts +45 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Pair.ts +11 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Player.ts +68 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Point.ts +65 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Shipyard.ts +72 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/ShipyardAction.ts +58 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/main.py +73 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/miner.py +73 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/package.json +23 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/BoardTest.ts +551 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/ConfigurationTest.ts +16 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/ObservationTest.ts +33 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/PointTest.ts +17 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/ShipyardTest.ts +18 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/configuration.json +1 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/fullob.json +1 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/observation.json +1 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/tsconfig.json +22 -0
- kaggle_environments/envs/kore_fleets/test_kore_fleets.py +331 -0
- kaggle_environments/envs/lux_ai_2021/README.md +3 -0
- kaggle_environments/envs/lux_ai_2021/__init__.py +0 -0
- kaggle_environments/envs/lux_ai_2021/agents.py +11 -0
- kaggle_environments/envs/lux_ai_2021/dimensions/754.js +2 -0
- kaggle_environments/envs/lux_ai_2021/dimensions/754.js.LICENSE.txt +296 -0
- kaggle_environments/envs/lux_ai_2021/dimensions/main.js +1 -0
- kaggle_environments/envs/lux_ai_2021/index.html +43 -0
- kaggle_environments/envs/lux_ai_2021/lux_ai_2021.json +100 -0
- kaggle_environments/envs/lux_ai_2021/lux_ai_2021.py +231 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/__init__.py +0 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/lux/game_constants.js +6 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/lux/game_constants.json +59 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/lux/game_objects.js +145 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/lux/io.js +14 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/lux/kit.js +209 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/lux/map.js +107 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/lux/parser.js +79 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/main.js +88 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/main.py +75 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/simple.tar.gz +0 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/__init__.py +0 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/annotate.py +20 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/constants.py +25 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/game.py +86 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/game_constants.json +59 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/game_constants.py +7 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/game_map.py +106 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/game_objects.py +154 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/random_agent.py +38 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/simple_agent.py +82 -0
- kaggle_environments/envs/lux_ai_2021/test_lux.py +19 -0
- kaggle_environments/envs/lux_ai_2021/testing.md +23 -0
- kaggle_environments/envs/lux_ai_2021/todo.md.og +18 -0
- kaggle_environments/envs/lux_ai_s3/README.md +21 -0
- kaggle_environments/envs/lux_ai_s3/agents.py +5 -0
- kaggle_environments/envs/lux_ai_s3/index.html +42 -0
- kaggle_environments/envs/lux_ai_s3/lux_ai_s3.json +47 -0
- kaggle_environments/envs/lux_ai_s3/lux_ai_s3.py +178 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/__init__.py +1 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/env.py +819 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/globals.py +9 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/params.py +101 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/profiler.py +141 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/pygame_render.py +222 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/spaces.py +27 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/state.py +464 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/utils.py +12 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/wrappers.py +156 -0
- kaggle_environments/envs/lux_ai_s3/test_agents/python/agent.py +78 -0
- kaggle_environments/envs/lux_ai_s3/test_agents/python/lux/__init__.py +0 -0
- kaggle_environments/envs/lux_ai_s3/test_agents/python/lux/kit.py +31 -0
- kaggle_environments/envs/lux_ai_s3/test_agents/python/lux/utils.py +17 -0
- kaggle_environments/envs/lux_ai_s3/test_agents/python/main.py +66 -0
- kaggle_environments/envs/lux_ai_s3/test_lux.py +9 -0
- kaggle_environments/envs/mab/__init__.py +0 -0
- kaggle_environments/envs/mab/agents.py +12 -0
- kaggle_environments/envs/mab/mab.js +100 -0
- kaggle_environments/envs/mab/mab.json +74 -0
- kaggle_environments/envs/mab/mab.py +146 -0
- kaggle_environments/envs/open_spiel/__init__.py +0 -0
- kaggle_environments/envs/open_spiel/games/__init__.py +0 -0
- kaggle_environments/envs/open_spiel/games/chess/chess.js +441 -0
- kaggle_environments/envs/open_spiel/games/chess/image_config.jsonl +20 -0
- kaggle_environments/envs/open_spiel/games/chess/openings.jsonl +20 -0
- kaggle_environments/envs/open_spiel/games/connect_four/__init__.py +0 -0
- kaggle_environments/envs/open_spiel/games/connect_four/connect_four.js +284 -0
- kaggle_environments/envs/open_spiel/games/connect_four/connect_four_proxy.py +86 -0
- kaggle_environments/envs/open_spiel/games/go/__init__.py +0 -0
- kaggle_environments/envs/open_spiel/games/go/go.js +481 -0
- kaggle_environments/envs/open_spiel/games/go/go_proxy.py +99 -0
- kaggle_environments/envs/open_spiel/games/tic_tac_toe/__init__.py +0 -0
- kaggle_environments/envs/open_spiel/games/tic_tac_toe/tic_tac_toe.js +345 -0
- kaggle_environments/envs/open_spiel/games/tic_tac_toe/tic_tac_toe_proxy.py +98 -0
- kaggle_environments/envs/open_spiel/games/universal_poker/__init__.py +0 -0
- kaggle_environments/envs/open_spiel/games/universal_poker/universal_poker.js +431 -0
- kaggle_environments/envs/open_spiel/games/universal_poker/universal_poker_proxy.py +159 -0
- kaggle_environments/envs/open_spiel/html_playthrough_generator.py +31 -0
- kaggle_environments/envs/open_spiel/observation.py +128 -0
- kaggle_environments/envs/open_spiel/open_spiel.py +565 -0
- kaggle_environments/envs/open_spiel/proxy.py +138 -0
- kaggle_environments/envs/open_spiel/test_open_spiel.py +191 -0
- kaggle_environments/envs/rps/__init__.py +0 -0
- kaggle_environments/envs/rps/agents.py +84 -0
- kaggle_environments/envs/rps/helpers.py +25 -0
- kaggle_environments/envs/rps/rps.js +117 -0
- kaggle_environments/envs/rps/rps.json +63 -0
- kaggle_environments/envs/rps/rps.py +90 -0
- kaggle_environments/envs/rps/test_rps.py +110 -0
- kaggle_environments/envs/rps/utils.py +7 -0
- kaggle_environments/envs/tictactoe/test_tictactoe.py +43 -77
- kaggle_environments/envs/tictactoe/tictactoe.ipynb +1397 -0
- kaggle_environments/envs/tictactoe/tictactoe.json +10 -2
- kaggle_environments/envs/tictactoe/tictactoe.py +1 -1
- kaggle_environments/errors.py +2 -4
- kaggle_environments/helpers.py +377 -0
- kaggle_environments/main.py +340 -0
- kaggle_environments/schemas.json +23 -18
- kaggle_environments/static/player.html +206 -74
- kaggle_environments/utils.py +46 -73
- {kaggle_environments-0.2.1.dist-info → kaggle_environments-1.20.1.dist-info}/METADATA +36 -114
- kaggle_environments-1.20.1.dist-info/RECORD +211 -0
- {kaggle_environments-0.2.1.dist-info → kaggle_environments-1.20.1.dist-info}/WHEEL +1 -2
- kaggle_environments-1.20.1.dist-info/entry_points.txt +3 -0
- kaggle_environments/envs/battlegeese/battlegeese.py +0 -223
- kaggle_environments/temp.py +0 -14
- kaggle_environments-0.2.1.dist-info/RECORD +0 -32
- kaggle_environments-0.2.1.dist-info/entry_points.txt +0 -3
- kaggle_environments-0.2.1.dist-info/top_level.txt +0 -1
- {kaggle_environments-0.2.1.dist-info → kaggle_environments-1.20.1.dist-info/licenses}/LICENSE +0 -0
|
@@ -0,0 +1,441 @@
|
|
|
1
|
+
function renderer(options) {
|
|
2
|
+
const { environment, step, parent, width = 400, height = 400 } = options; // Chess-specific constants
|
|
3
|
+
|
|
4
|
+
const DEFAULT_NUM_ROWS = 8;
|
|
5
|
+
const DEFAULT_NUM_COLS = 8;
|
|
6
|
+
const PIECE_IMAGES_SRC = {
|
|
7
|
+
p: '',
|
|
8
|
+
r: '',
|
|
9
|
+
b: '',
|
|
10
|
+
q: '',
|
|
11
|
+
N: '',
|
|
12
|
+
K: '',
|
|
13
|
+
P: '',
|
|
14
|
+
R: '',
|
|
15
|
+
B: '',
|
|
16
|
+
Q: '',
|
|
17
|
+
n: '',
|
|
18
|
+
k: ''
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
const LIGHT_SQUARE_COLOR = '#f0d9b5';
|
|
22
|
+
const DARK_SQUARE_COLOR = '#b58863';
|
|
23
|
+
|
|
24
|
+
let currentBoardElement = null;
|
|
25
|
+
let currentStatusTextElement = null;
|
|
26
|
+
let currentWinnerTextElement = null;
|
|
27
|
+
let currentMessageBoxElement = typeof document !== 'undefined' ? document.getElementById('messageBox') : null;
|
|
28
|
+
let currentRendererContainer = null;
|
|
29
|
+
let currentBoardContainer = null;
|
|
30
|
+
let currentTitleElement = null;
|
|
31
|
+
let squareSize = 0;
|
|
32
|
+
|
|
33
|
+
function _showMessage(message, type = 'info', duration = 3000) {
|
|
34
|
+
if (typeof document === 'undefined' || !document.body) return;
|
|
35
|
+
if (!currentMessageBoxElement) {
|
|
36
|
+
currentMessageBoxElement = document.createElement('div');
|
|
37
|
+
currentMessageBoxElement.id = 'messageBox';
|
|
38
|
+
Object.assign(currentMessageBoxElement.style, {
|
|
39
|
+
position: 'fixed',
|
|
40
|
+
top: '10px',
|
|
41
|
+
left: '50%',
|
|
42
|
+
transform: 'translateX(-50%)',
|
|
43
|
+
padding: '0.75rem 1rem',
|
|
44
|
+
borderRadius: '0.375rem',
|
|
45
|
+
boxShadow: '0 2px 4px rgba(0,0,0,0.1)',
|
|
46
|
+
zIndex: '1000',
|
|
47
|
+
opacity: '0',
|
|
48
|
+
transition: 'opacity 0.3s ease-in-out, background-color 0.3s',
|
|
49
|
+
fontSize: '0.875rem',
|
|
50
|
+
fontFamily: "'Inter', sans-serif",
|
|
51
|
+
color: 'white'
|
|
52
|
+
});
|
|
53
|
+
document.body.appendChild(currentMessageBoxElement);
|
|
54
|
+
}
|
|
55
|
+
currentMessageBoxElement.textContent = message;
|
|
56
|
+
currentMessageBoxElement.style.backgroundColor = type === 'error' ? '#ef4444' : '#10b981';
|
|
57
|
+
currentMessageBoxElement.style.opacity = '1';
|
|
58
|
+
setTimeout(() => {
|
|
59
|
+
if (currentMessageBoxElement) currentMessageBoxElement.style.opacity = '0';
|
|
60
|
+
}, duration);
|
|
61
|
+
}
|
|
62
|
+
function _ensureRendererElements(parentElementToClear, rows, cols) {
|
|
63
|
+
if (!parentElementToClear) return false;
|
|
64
|
+
parentElementToClear.innerHTML = '';
|
|
65
|
+
|
|
66
|
+
// NEW: Check for mobile screen size to apply responsive styles.
|
|
67
|
+
const isMobile = window.innerWidth < 768;
|
|
68
|
+
|
|
69
|
+
currentRendererContainer = document.createElement('div');
|
|
70
|
+
Object.assign(currentRendererContainer.style, {
|
|
71
|
+
display: 'flex',
|
|
72
|
+
flexDirection: 'column',
|
|
73
|
+
alignItems: 'center',
|
|
74
|
+
padding: isMobile ? '10px' : '20px', // Responsive padding
|
|
75
|
+
boxSizing: 'border-box',
|
|
76
|
+
width: '100%',
|
|
77
|
+
height: '100%',
|
|
78
|
+
fontFamily: "'Inter', sans-serif"
|
|
79
|
+
});
|
|
80
|
+
parentElementToClear.appendChild(currentRendererContainer);
|
|
81
|
+
|
|
82
|
+
if (!environment.viewer) {
|
|
83
|
+
const headerContainer = document.createElement('div');
|
|
84
|
+
Object.assign(headerContainer.style, {
|
|
85
|
+
display: 'flex',
|
|
86
|
+
justifyContent: 'center',
|
|
87
|
+
alignItems: 'center',
|
|
88
|
+
width: '100%',
|
|
89
|
+
marginBottom: '1rem',
|
|
90
|
+
color: 'white',
|
|
91
|
+
flexShrink: '0',
|
|
92
|
+
flexDirection: isMobile ? 'column' : 'row' // Stacks header vertically on mobile
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
// Player 2 (White) - Left side
|
|
96
|
+
const whitePlayerContainer = document.createElement('div');
|
|
97
|
+
Object.assign(whitePlayerContainer.style, {
|
|
98
|
+
display: 'flex',
|
|
99
|
+
alignItems: 'center'
|
|
100
|
+
});
|
|
101
|
+
const whitePawnImg = document.createElement('img');
|
|
102
|
+
whitePawnImg.src = PIECE_IMAGES_SRC.P;
|
|
103
|
+
Object.assign(whitePawnImg.style, { height: '30px', marginRight: '8px' });
|
|
104
|
+
const whitePlayerName = document.createElement('span');
|
|
105
|
+
whitePlayerName.textContent = environment.info?.TeamNames?.[1] || 'Player 2';
|
|
106
|
+
Object.assign(whitePlayerName.style, {
|
|
107
|
+
fontSize: isMobile ? '1rem' : '1.1rem', // Responsive font size
|
|
108
|
+
fontWeight: 'bold'
|
|
109
|
+
});
|
|
110
|
+
whitePlayerContainer.appendChild(whitePawnImg);
|
|
111
|
+
whitePlayerContainer.appendChild(whitePlayerName);
|
|
112
|
+
|
|
113
|
+
// Center Title
|
|
114
|
+
currentTitleElement = document.createElement('h1');
|
|
115
|
+
currentTitleElement.textContent = 'Chess';
|
|
116
|
+
Object.assign(currentTitleElement.style, {
|
|
117
|
+
fontSize: isMobile ? '1.5rem' : '1.875rem', // Responsive font size
|
|
118
|
+
fontWeight: 'bold',
|
|
119
|
+
textAlign: 'center',
|
|
120
|
+
color: '#e5e7eb',
|
|
121
|
+
margin: isMobile ? '10px 0' : '0 40px', // Responsive margin
|
|
122
|
+
order: isMobile ? '0' : 'initial' // Ensures title is between players on desktop
|
|
123
|
+
});
|
|
124
|
+
|
|
125
|
+
// Player 1 (Black) - Right side
|
|
126
|
+
const blackPlayerContainer = document.createElement('div');
|
|
127
|
+
Object.assign(blackPlayerContainer.style, {
|
|
128
|
+
display: 'flex',
|
|
129
|
+
alignItems: 'center'
|
|
130
|
+
});
|
|
131
|
+
const blackPlayerName = document.createElement('span');
|
|
132
|
+
blackPlayerName.textContent = environment.info?.TeamNames?.[0] || 'Player 1';
|
|
133
|
+
Object.assign(blackPlayerName.style, {
|
|
134
|
+
fontSize: isMobile ? '1rem' : '1.1rem', // Responsive font size
|
|
135
|
+
fontWeight: 'bold'
|
|
136
|
+
});
|
|
137
|
+
const blackPawnImg = document.createElement('img');
|
|
138
|
+
blackPawnImg.src = PIECE_IMAGES_SRC.p;
|
|
139
|
+
Object.assign(blackPawnImg.style, { height: '30px', marginLeft: '8px' });
|
|
140
|
+
blackPlayerContainer.appendChild(blackPlayerName);
|
|
141
|
+
blackPlayerContainer.appendChild(blackPawnImg);
|
|
142
|
+
|
|
143
|
+
// Assemble the header - order matters for mobile stacking
|
|
144
|
+
if (isMobile) {
|
|
145
|
+
// On mobile: White Player, then Black Player, then Title for a "vs" feel
|
|
146
|
+
headerContainer.appendChild(whitePlayerContainer);
|
|
147
|
+
const vsText = document.createElement('div');
|
|
148
|
+
vsText.textContent = 'vs';
|
|
149
|
+
Object.assign(vsText.style, { margin: '4px 0', fontStyle: 'italic' });
|
|
150
|
+
headerContainer.appendChild(vsText);
|
|
151
|
+
headerContainer.appendChild(blackPlayerContainer);
|
|
152
|
+
// Title is not added here for mobile to keep it separate or could be added last
|
|
153
|
+
} else {
|
|
154
|
+
// On desktop: White Player, Title, Black Player
|
|
155
|
+
headerContainer.appendChild(whitePlayerContainer);
|
|
156
|
+
headerContainer.appendChild(currentTitleElement);
|
|
157
|
+
headerContainer.appendChild(blackPlayerContainer);
|
|
158
|
+
}
|
|
159
|
+
currentRendererContainer.appendChild(headerContainer);
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
// ... (The rest of the function for the board and status container remains the same, but let's add responsive fonts to the status)
|
|
163
|
+
|
|
164
|
+
// Board container...
|
|
165
|
+
currentBoardContainer = document.createElement('div');
|
|
166
|
+
Object.assign(currentBoardContainer.style, {
|
|
167
|
+
display: 'flex',
|
|
168
|
+
justifyContent: 'center',
|
|
169
|
+
alignItems: 'center',
|
|
170
|
+
flexGrow: '1',
|
|
171
|
+
width: '100%',
|
|
172
|
+
minHeight: '0'
|
|
173
|
+
});
|
|
174
|
+
currentRendererContainer.appendChild(currentBoardContainer);
|
|
175
|
+
|
|
176
|
+
// ... code to create board and squares ...
|
|
177
|
+
currentBoardElement = document.createElement('div');
|
|
178
|
+
Object.assign(currentBoardElement.style, {
|
|
179
|
+
display: 'grid',
|
|
180
|
+
border: '2px solid #333'
|
|
181
|
+
});
|
|
182
|
+
currentBoardContainer.appendChild(currentBoardElement);
|
|
183
|
+
for (let r = 0; r < rows; r++) {
|
|
184
|
+
for (let c = 0; c < cols; c++) {
|
|
185
|
+
const square = document.createElement('div');
|
|
186
|
+
square.id = `cell-${r}-${c}`;
|
|
187
|
+
Object.assign(square.style, {
|
|
188
|
+
backgroundColor: (r + c) % 2 === 0 ? LIGHT_SQUARE_COLOR : DARK_SQUARE_COLOR,
|
|
189
|
+
display: 'flex',
|
|
190
|
+
alignItems: 'center',
|
|
191
|
+
justifyContent: 'center'
|
|
192
|
+
});
|
|
193
|
+
currentBoardElement.appendChild(square);
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
// Status Container
|
|
198
|
+
const statusContainer = document.createElement('div');
|
|
199
|
+
Object.assign(statusContainer.style, {
|
|
200
|
+
padding: '5px',
|
|
201
|
+
backgroundColor: 'white',
|
|
202
|
+
borderRadius: '8px',
|
|
203
|
+
boxShadow: '0 4px 6px -1px rgba(0,0,0,0.1), 0 2px 4px -1px rgba(0,0,0,0.06)',
|
|
204
|
+
textAlign: 'center',
|
|
205
|
+
width: 'auto',
|
|
206
|
+
minWidth: '200px',
|
|
207
|
+
maxWidth: '90vw',
|
|
208
|
+
marginTop: '10px',
|
|
209
|
+
flexShrink: '0'
|
|
210
|
+
});
|
|
211
|
+
if (!environment.viewer) {
|
|
212
|
+
currentRendererContainer.appendChild(statusContainer);
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
currentStatusTextElement = document.createElement('p');
|
|
216
|
+
Object.assign(currentStatusTextElement.style, {
|
|
217
|
+
fontSize: isMobile ? '0.8rem' : '1.1rem', // Responsive font size
|
|
218
|
+
fontWeight: '600',
|
|
219
|
+
margin: '0 0 5px 0'
|
|
220
|
+
});
|
|
221
|
+
statusContainer.appendChild(currentStatusTextElement);
|
|
222
|
+
|
|
223
|
+
currentWinnerTextElement = document.createElement('p');
|
|
224
|
+
Object.assign(currentWinnerTextElement.style, {
|
|
225
|
+
fontSize: isMobile ? '0.9rem' : '1.1rem', // Responsive font size
|
|
226
|
+
fontWeight: '700',
|
|
227
|
+
margin: '5px 0 0 0'
|
|
228
|
+
});
|
|
229
|
+
statusContainer.appendChild(currentWinnerTextElement);
|
|
230
|
+
|
|
231
|
+
return true;
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
function _getTeamNameForColor(color, teamNames) {
|
|
235
|
+
if (!teamNames || teamNames.length < 2) return null;
|
|
236
|
+
return color.toLowerCase() === 'white' ? teamNames[1] : teamNames[0];
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
function _deriveWinnerFromRewards(currentStepAgents, teamNames) {
|
|
240
|
+
if (!currentStepAgents || currentStepAgents.length < 2) return null;
|
|
241
|
+
|
|
242
|
+
const player0Reward = currentStepAgents[0].reward;
|
|
243
|
+
const player1Reward = currentStepAgents[1].reward;
|
|
244
|
+
|
|
245
|
+
if (player0Reward === player1Reward) {
|
|
246
|
+
return 'draw';
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
const winnerPlayerIndex = player0Reward === 1 ? 0 : 1;
|
|
250
|
+
const color = winnerPlayerIndex === 0 ? 'Black' : 'White';
|
|
251
|
+
|
|
252
|
+
if (teamNames) {
|
|
253
|
+
const teamName = _getTeamNameForColor(color, teamNames);
|
|
254
|
+
return `${color} (${teamName})`;
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
return color.toLowerCase();
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
function _parseFen(fen) {
|
|
261
|
+
if (!fen || typeof fen !== 'string') return null;
|
|
262
|
+
|
|
263
|
+
const [piecePlacement, activeColor, castling, enPassant, halfmoveClock, fullmoveNumber] = fen.split(' ');
|
|
264
|
+
const board = [];
|
|
265
|
+
const rows = piecePlacement.split('/');
|
|
266
|
+
|
|
267
|
+
for (const row of rows) {
|
|
268
|
+
const boardRow = [];
|
|
269
|
+
for (const char of row) {
|
|
270
|
+
if (isNaN(parseInt(char))) {
|
|
271
|
+
boardRow.push(char);
|
|
272
|
+
} else {
|
|
273
|
+
for (let i = 0; i < parseInt(char); i++) {
|
|
274
|
+
boardRow.push(null);
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
board.push(boardRow);
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
return {
|
|
282
|
+
board,
|
|
283
|
+
activeColor,
|
|
284
|
+
castling,
|
|
285
|
+
enPassant,
|
|
286
|
+
halfmoveClock,
|
|
287
|
+
fullmoveNumber
|
|
288
|
+
};
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
function _renderBoardDisplay(gameStateToDisplay, displayRows, displayCols) {
|
|
292
|
+
if (!currentBoardContainer || !currentBoardElement || !currentStatusTextElement || !currentWinnerTextElement)
|
|
293
|
+
return;
|
|
294
|
+
|
|
295
|
+
const isMobile = window.innerWidth < 768;
|
|
296
|
+
|
|
297
|
+
// Calculate and apply board size
|
|
298
|
+
const containerWidth = currentBoardContainer?.clientWidth ?? width;
|
|
299
|
+
const containerHeight = currentBoardContainer?.clientHeight ?? height;
|
|
300
|
+
let smallestContainerEdge = Math.min(containerWidth, containerHeight);
|
|
301
|
+
// This is greedily trying to take as much space as possible, which can cause some conflict with flex box calculations for other elements
|
|
302
|
+
// we are going to take 24px off (arbitrary) to give the flex box renderer a bit of space to work with. Without it we will get some clipping.
|
|
303
|
+
smallestContainerEdge = smallestContainerEdge > 200 ? smallestContainerEdge - 24 : smallestContainerEdge;
|
|
304
|
+
const newSquareSize = Math.floor(smallestContainerEdge / displayCols);
|
|
305
|
+
|
|
306
|
+
if (newSquareSize !== squareSize) {
|
|
307
|
+
squareSize = newSquareSize;
|
|
308
|
+
Object.assign(currentBoardElement.style, {
|
|
309
|
+
gridTemplateColumns: `repeat(${displayCols}, ${squareSize}px)`,
|
|
310
|
+
gridTemplateRows: `repeat(${displayRows}, ${squareSize}px)`,
|
|
311
|
+
width: `${displayCols * squareSize}px`,
|
|
312
|
+
height: `${displayRows * squareSize}px`
|
|
313
|
+
});
|
|
314
|
+
|
|
315
|
+
const squares = currentBoardElement.querySelectorAll('div[id^="cell-"]');
|
|
316
|
+
squares.forEach((square) => {
|
|
317
|
+
Object.assign(square.style, {
|
|
318
|
+
width: `${squareSize}px`,
|
|
319
|
+
height: `${squareSize}px`
|
|
320
|
+
});
|
|
321
|
+
});
|
|
322
|
+
}
|
|
323
|
+
|
|
324
|
+
// Clear and render board pieces...
|
|
325
|
+
for (let r = 0; r < displayRows; r++) {
|
|
326
|
+
for (let c = 0; c < displayCols; c++) {
|
|
327
|
+
const squareElement = currentBoardElement.querySelector(`#cell-${r}-${c}`);
|
|
328
|
+
if (squareElement) squareElement.innerHTML = '';
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
|
|
332
|
+
if (!gameStateToDisplay || !gameStateToDisplay.board) {
|
|
333
|
+
currentStatusTextElement.textContent = 'Waiting for game data...';
|
|
334
|
+
currentWinnerTextElement.textContent = '';
|
|
335
|
+
return;
|
|
336
|
+
}
|
|
337
|
+
|
|
338
|
+
const { board, activeColor, isTerminal, winner } = gameStateToDisplay;
|
|
339
|
+
const pieceSize = Math.floor(squareSize * 0.9);
|
|
340
|
+
for (let r_data = 0; r_data < displayRows; r_data++) {
|
|
341
|
+
for (let c_data = 0; c_data < displayCols; c_data++) {
|
|
342
|
+
const piece = board[r_data][c_data];
|
|
343
|
+
const squareElement = currentBoardElement.querySelector(`#cell-${r_data}-${c_data}`);
|
|
344
|
+
if (squareElement && piece) {
|
|
345
|
+
const pieceImg = document.createElement('img');
|
|
346
|
+
pieceImg.src = PIECE_IMAGES_SRC[piece];
|
|
347
|
+
pieceImg.style.width = `${pieceSize}px`;
|
|
348
|
+
pieceImg.style.height = `${pieceSize}px`;
|
|
349
|
+
squareElement.appendChild(pieceImg);
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
}
|
|
353
|
+
|
|
354
|
+
// Render status text
|
|
355
|
+
currentStatusTextElement.innerHTML = '';
|
|
356
|
+
currentWinnerTextElement.innerHTML = '';
|
|
357
|
+
if (isTerminal) {
|
|
358
|
+
const winnerText = winner
|
|
359
|
+
? String(winner).toLowerCase() === 'draw'
|
|
360
|
+
? "It's a Draw!"
|
|
361
|
+
: winner
|
|
362
|
+
: 'Game ended.';
|
|
363
|
+
if (isMobile) {
|
|
364
|
+
currentStatusTextElement.innerHTML = `<div style="font-size: 0.9rem; color: #666;">Winner</div>`;
|
|
365
|
+
currentWinnerTextElement.innerHTML = `<div style="font-size: 1.1rem; font-weight: bold;">${winnerText}</div>`;
|
|
366
|
+
} else {
|
|
367
|
+
currentStatusTextElement.textContent = 'Game Over!';
|
|
368
|
+
currentWinnerTextElement.innerHTML = `Winner: <span style="font-weight: bold;">${winnerText}</span>`;
|
|
369
|
+
}
|
|
370
|
+
} else {
|
|
371
|
+
const playerColor = String(activeColor).toLowerCase() === 'w' ? 'White' : 'Black';
|
|
372
|
+
const teamName = _getTeamNameForColor(playerColor, environment.info?.TeamNames);
|
|
373
|
+
const currentPlayerText = teamName ? `${playerColor} (${teamName})` : playerColor;
|
|
374
|
+
|
|
375
|
+
if (isMobile) {
|
|
376
|
+
currentStatusTextElement.innerHTML = `<div style="font-size: 0.9rem; color: #666;">Current Player</div>`;
|
|
377
|
+
currentWinnerTextElement.innerHTML = `<div style="font-size: 1.1rem; font-weight: bold;">${currentPlayerText}</div>`;
|
|
378
|
+
} else {
|
|
379
|
+
currentStatusTextElement.innerHTML = `Current Player: <span style="font-weight: bold;">${currentPlayerText}</span>`;
|
|
380
|
+
currentWinnerTextElement.innerHTML = ''; // Clear winner text when game is active
|
|
381
|
+
}
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
|
|
385
|
+
if (!_ensureRendererElements(parent, DEFAULT_NUM_ROWS, DEFAULT_NUM_COLS)) {
|
|
386
|
+
if (parent && typeof parent.innerHTML !== 'undefined') {
|
|
387
|
+
parent.innerHTML =
|
|
388
|
+
"<p style='color:red; font-family: sans-serif;'>Critical Error: Renderer element setup failed.</p>";
|
|
389
|
+
}
|
|
390
|
+
return;
|
|
391
|
+
}
|
|
392
|
+
|
|
393
|
+
if (!environment || !environment.steps || !environment.steps[step]) {
|
|
394
|
+
_renderBoardDisplay(null, DEFAULT_NUM_ROWS, DEFAULT_NUM_COLS);
|
|
395
|
+
if (currentStatusTextElement) currentStatusTextElement.textContent = 'Initializing environment...';
|
|
396
|
+
return;
|
|
397
|
+
}
|
|
398
|
+
|
|
399
|
+
const currentStepAgents = environment.steps[step];
|
|
400
|
+
if (!currentStepAgents || !Array.isArray(currentStepAgents) || currentStepAgents.length === 0) {
|
|
401
|
+
_renderBoardDisplay(null, DEFAULT_NUM_ROWS, DEFAULT_NUM_COLS);
|
|
402
|
+
if (currentStatusTextElement) currentStatusTextElement.textContent = 'Waiting for agent data...';
|
|
403
|
+
return;
|
|
404
|
+
}
|
|
405
|
+
|
|
406
|
+
const agent = currentStepAgents[0];
|
|
407
|
+
|
|
408
|
+
if (!agent || typeof agent.observation === 'undefined') {
|
|
409
|
+
_renderBoardDisplay(null, DEFAULT_NUM_ROWS, DEFAULT_NUM_COLS);
|
|
410
|
+
if (currentStatusTextElement) currentStatusTextElement.textContent = 'Waiting for observation data...';
|
|
411
|
+
return;
|
|
412
|
+
}
|
|
413
|
+
const observationForRenderer = agent.observation;
|
|
414
|
+
|
|
415
|
+
let gameSpecificState = null;
|
|
416
|
+
|
|
417
|
+
if (
|
|
418
|
+
observationForRenderer &&
|
|
419
|
+
typeof observationForRenderer.observationString === 'string' &&
|
|
420
|
+
observationForRenderer.observationString.trim() !== ''
|
|
421
|
+
) {
|
|
422
|
+
try {
|
|
423
|
+
const fen = observationForRenderer.observationString;
|
|
424
|
+
const parsedFen = _parseFen(fen);
|
|
425
|
+
if (parsedFen) {
|
|
426
|
+
const winner = observationForRenderer.isTerminal
|
|
427
|
+
? _deriveWinnerFromRewards(currentStepAgents, environment.info?.TeamNames)
|
|
428
|
+
: null;
|
|
429
|
+
gameSpecificState = {
|
|
430
|
+
...parsedFen,
|
|
431
|
+
isTerminal: observationForRenderer.isTerminal,
|
|
432
|
+
winner: winner
|
|
433
|
+
};
|
|
434
|
+
}
|
|
435
|
+
} catch (e) {
|
|
436
|
+
_showMessage('Error: Corrupted game state (obs_string).', 'error');
|
|
437
|
+
}
|
|
438
|
+
}
|
|
439
|
+
|
|
440
|
+
_renderBoardDisplay(gameSpecificState, DEFAULT_NUM_ROWS, DEFAULT_NUM_COLS);
|
|
441
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
{"color": "green", "pieceSet": "caliente"}
|
|
2
|
+
{"color": "blue", "pieceSet": "cardinal"}
|
|
3
|
+
{"color": "brown", "pieceSet": "cburnett"}
|
|
4
|
+
{"color": "brown", "pieceSet": "celtic"}
|
|
5
|
+
{"color": "ic", "pieceSet": "chessnut"}
|
|
6
|
+
{"color": "ic", "pieceSet": "companion"}
|
|
7
|
+
{"color": "green", "pieceSet": "dubrovny"}
|
|
8
|
+
{"color": "blue", "pieceSet": "fantasy"}
|
|
9
|
+
{"color": "green", "pieceSet": "fresca"}
|
|
10
|
+
{"color": "green", "pieceSet": "gioco"}
|
|
11
|
+
{"color": "purple", "pieceSet": "icpieces"}
|
|
12
|
+
{"color": "blue", "pieceSet": "leipzig"}
|
|
13
|
+
{"color": "brown", "pieceSet": "libra"}
|
|
14
|
+
{"color": "blue", "pieceSet": "maestro"}
|
|
15
|
+
{"color": "brown", "pieceSet": "merida"}
|
|
16
|
+
{"color": "ic", "pieceSet": "mpchess"}
|
|
17
|
+
{"color": "brown", "pieceSet": "pirouetti"}
|
|
18
|
+
{"color": "green", "pieceSet": "spatial"}
|
|
19
|
+
{"color": "purple", "pieceSet": "staunty"}
|
|
20
|
+
{"color": "pink", "pieceSet": "tatiana"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
{"name": "Sicilian Defense", "eco": "B20", "pgn": "1. e4 c5", "fen": "rnbqkbnr/pp1ppppp/8/2p5/4P3/8/PPPP1PPP/RNBQKBNR w KQkq - 0 2", "initialActions": [2426, 1258]}
|
|
2
|
+
{"name": "King's Pawn Game", "eco": "C20", "pgn": "1. e4 e5", "fen": "rnbqkbnr/pppp1ppp/8/4p3/4P3/8/PPPP1PPP/RNBQKBNR w KQkq - 0 2", "initialActions": [2426, 2426]}
|
|
3
|
+
{"name": "Indian Defense", "eco": "A45", "pgn": "1. d4 Nf6", "fen": "rnbqkb1r/pppppppp/5n2/8/3P4/8/PPP1PPPP/RNBQKBNR w KQkq - 1 2", "initialActions": [1842, 3572]}
|
|
4
|
+
{"name": "Queen's Pawn Game", "eco": "D00", "pgn": "1. d4 d5", "fen": "rnbqkbnr/ppp1pppp/8/3p4/3P4/8/PPP1PPPP/RNBQKBNR w KQkq - 0 2", "initialActions": [1842, 1842]}
|
|
5
|
+
{"name": "French Defense", "eco": "C00", "pgn": "1. e4 e6", "fen": "rnbqkbnr/pppp1ppp/4p3/8/4P3/8/PPPP1PPP/RNBQKBNR w KQkq - 0 2", "initialActions": [2426, 2425]}
|
|
6
|
+
{"name": "Scandinavian Defense", "eco": "B01", "pgn": "1. e4 d5", "fen": "rnbqkbnr/ppp1pppp/8/3p4/4P3/8/PPPP1PPP/RNBQKBNR w KQkq - 0 2", "initialActions": [2426, 1842]}
|
|
7
|
+
{"name": "Caro-Kann Defense", "eco": "B10", "pgn": "1. e4 c6", "fen": "rnbqkbnr/pp1ppppp/2p5/8/4P3/8/PPPP1PPP/RNBQKBNR w KQkq - 0 2", "initialActions": [2426, 1257]}
|
|
8
|
+
{"name": "Horwitz Defense", "eco": "A40", "pgn": "1. d4 e6", "fen": "rnbqkbnr/pppp1ppp/4p3/8/3P4/8/PPP1PPPP/RNBQKBNR w KQkq - 0 2", "initialActions": [1842, 2425]}
|
|
9
|
+
{"name": "Pirc Defense", "eco": "B00", "pgn": "1. e4 d6", "fen": "rnbqkbnr/ppp1pppp/3p4/8/4P3/8/PPPP1PPP/RNBQKBNR w KQkq - 0 2", "initialActions": [2426, 1841]}
|
|
10
|
+
{"name": "Modern Defense", "eco": "B06", "pgn": "1. e4 g6", "fen": "rnbqkbnr/pppppp1p/6p1/8/4P3/8/PPPP1PPP/RNBQKBNR w KQkq - 0 2", "initialActions": [2426, 3593]}
|
|
11
|
+
{"name": "Benoni Defense: Old Benoni", "eco": "A43", "pgn": "1. d4 c5", "fen": "rnbqkbnr/pp1ppppp/8/2p5/3P4/8/PPP1PPPP/RNBQKBNR w KQkq - 0 2", "initialActions": [1842, 1258]}
|
|
12
|
+
{"name": "Alekhine Defense", "eco": "B02", "pgn": "1. e4 Nf6", "fen": "rnbqkb1r/pppppppp/5n2/8/4P3/8/PPPP1PPP/RNBQKBNR w KQkq - 1 2", "initialActions": [2426, 3572]}
|
|
13
|
+
{"name": "Zukertort Opening", "eco": "A06", "pgn": "1. Nf3 d5", "fen": "rnbqkbnr/ppp1pppp/8/3p4/8/5N2/PPPPPPPP/RNBQKB1R w KQkq - 0 2", "initialActions": [3572, 1842]}
|
|
14
|
+
{"name": "Queen's Pawn Game: Modern Defense", "eco": "A40", "pgn": "1. d4 g6", "fen": "rnbqkbnr/pppppp1p/6p1/8/3P4/8/PPP1PPPP/RNBQKBNR w KQkq - 0 2", "initialActions": [1842, 3593]}
|
|
15
|
+
{"name": "Queen's Pawn Game", "eco": "A41", "pgn": "1. d4 d6", "fen": "rnbqkbnr/ppp1pppp/3p4/8/3P4/8/PPP1PPPP/RNBQKBNR w KQkq - 0 2", "initialActions": [1842, 1841]}
|
|
16
|
+
{"name": "Zukertort Opening", "eco": "A05", "pgn": "1. Nf3 Nf6", "fen": "rnbqkb1r/pppppppp/5n2/8/8/5N2/PPPPPPPP/RNBQKB1R w KQkq - 2 2", "initialActions": [3572, 3572]}
|
|
17
|
+
{"name": "Queen's Pawn Game", "eco": "A40", "pgn": "1. d4 c6", "fen": "rnbqkbnr/pp1ppppp/2p5/8/3P4/8/PPP1PPPP/RNBQKBNR w KQkq - 0 2", "initialActions": [1842, 1257]}
|
|
18
|
+
{"name": "English Opening: Anglo-Indian Defense", "eco": "A15", "pgn": "1. c4 Nf6", "fen": "rnbqkb1r/pppppppp/5n2/8/2P5/8/PP1PPPPP/RNBQKBNR w KQkq - 1 2", "initialActions": [1258, 3572]}
|
|
19
|
+
{"name": "English Opening: King's English Variation", "eco": "A20", "pgn": "1. c4 e5", "fen": "rnbqkbnr/pppp1ppp/8/4p3/2P5/8/PP1PPPPP/RNBQKBNR w KQkq - 0 2", "initialActions": [1258, 2426]}
|
|
20
|
+
{"name": "Nimzowitsch Defense", "eco": "B00", "pgn": "1. e4 Nc6", "fen": "r1bqkbnr/pppppppp/2n5/8/4P3/8/PPPP1PPP/RNBQKBNR w KQkq - 1 2", "initialActions": [2426, 656]}
|
|
File without changes
|