Apply styles and map script to manually loaded files

This commit is contained in:
Catalin Constantin Mititiuc 2025-06-16 22:41:30 -07:00
parent 9769b26ddb
commit 873a5939ef
8 changed files with 37 additions and 15 deletions

View File

@ -378,6 +378,7 @@ img.logo {
.map-placeholder {
position: absolute;
user-select: none;
}
input[type="file"] {

View File

@ -1,6 +1,6 @@
<?xml version="1.0" standalone="no"?>
<svg viewBox="-18 -150 2320 3360" xmlns="http://www.w3.org/2000/svg">
<link xmlns="http://www.w3.org/1999/xhtml" rel="stylesheet" href="../css/map.css" type="text/css"/>
<!-- <link xmlns="http://www.w3.org/1999/xhtml" rel="stylesheet" href="/assets/css/map.css" type="text/css"/> -->
<style>
g[data-edge="north"] { --i: -2; }
g[data-edge="south"] { --i: 52; }
@ -1935,5 +1935,5 @@
</g>
</g>
</g>
<script href="../../map.js"></script>
<script></script>
</svg>

Before

Width:  |  Height:  |  Size: 84 KiB

After

Width:  |  Height:  |  Size: 84 KiB

View File

@ -91,5 +91,5 @@
</g>
<g class="grid"/>
</g>
<script href="../../map.js" data-cols="33" data-rows="77"></script>
<script data-cols="33" data-rows="77"></script>
</svg>

Before

Width:  |  Height:  |  Size: 3.9 KiB

After

Width:  |  Height:  |  Size: 3.9 KiB

View File

@ -88,5 +88,5 @@
</g>
<g class="grid"/>
</g>
<script href="../../map.js" data-cols="33" data-rows="25"></script>
<script data-cols="33" data-rows="25"></script>
</svg>

Before

Width:  |  Height:  |  Size: 3.6 KiB

After

Width:  |  Height:  |  Size: 3.6 KiB

View File

@ -86,5 +86,5 @@
<g class="grid"/>
</g>
<script href="../../map.js" data-cols="33" data-rows="50"></script>
<script data-cols="33" data-rows="50"></script>
</svg>

Before

Width:  |  Height:  |  Size: 2.8 KiB

After

Width:  |  Height:  |  Size: 2.7 KiB

View File

@ -65,16 +65,35 @@ function clearMoveEndedIndicators(records) {
}
function load() {
URL.revokeObjectURL(this.data);
const svg = this.contentDocument.querySelector('svg'),
startLocs = svg.querySelector('.start-locations');
startLocs = svg.querySelector('.start-locations'),
scriptEl = this.contentDocument.querySelector('script');
const linkEl = document.createElement('link');
linkEl.setAttribute('xmlns', 'http://www.w3.org/1999/xhtml');
linkEl.setAttribute('rel', 'stylesheet');
linkEl.setAttribute('href', 'http://localhost:8080/assets/css/map.css');
linkEl.setAttribute('type', 'text/css');
linkEl.onload = function (e) {
console.log('map.css loaded');
if (scriptEl) {
scriptEl.onload = function () {
console.log('map.js loaded');
gameboard.start(svg);
recordSheet.start(startLocs, gameboard.getUnits(), gameboard.unSelect, gameboard.select);
};
scriptEl.setAttribute('href', 'http://localhost:8080/map.js');
}
};
svg.prepend(linkEl);
this.style.opacity = 1;
mapPlaceholder.style.opacity = 0;
URL.revokeObjectURL(this.data);
panzoom.start(svg);
gameboard.start(svg);
recordSheet.start(startLocs, gameboard.getUnits(), gameboard.unSelect, gameboard.select);
recordSheet.clear();
}
document.querySelectorAll('.end-turn').forEach(el =>

View File

@ -270,6 +270,8 @@ export function start(el) {
}
});
});
console.log('gameboard.js loaded');
}
export function select(selected) {

View File

@ -83,12 +83,6 @@ function createRecords(units) {
return grouped;
}
function clear() {
document.querySelectorAll('#attacker-record > div, #defender-record > div').forEach(el => el.remove());
document.querySelector('#attacker-record .name').textContent = 'attacker';
document.querySelector('#defender-record .name').textContent = 'defender';
}
function addEventListeners(unSelectCounter, selectCounter) {
document.querySelectorAll('.soldier-record').forEach(el =>
el.addEventListener('click', () => {
@ -103,6 +97,12 @@ function addEventListeners(unSelectCounter, selectCounter) {
);
}
export function clear() {
document.querySelectorAll('#attacker-record > div, #defender-record > div').forEach(el => el.remove());
document.querySelector('#attacker-record .name').textContent = 'attacker';
document.querySelector('#defender-record .name').textContent = 'defender';
}
export function unSelect() {
const selected = getSelected();