Refactor index.html to use separate files for scripts and style
This commit is contained in:
parent
6baa194e5b
commit
cd21e4e8bd
6 changed files with 129 additions and 158 deletions
13
public/scripts/copy-game-link.js
Normal file
13
public/scripts/copy-game-link.js
Normal file
|
|
@ -0,0 +1,13 @@
|
|||
function copyGameLink() {
|
||||
const gameLinkInput = document.getElementById('game-link');
|
||||
if (gameLinkInput) {
|
||||
navigator.clipboard
|
||||
.writeText(gameLinkInput.value)
|
||||
.then(() => {
|
||||
alert('Game link copied to clipboard!');
|
||||
})
|
||||
.catch((err) => {
|
||||
console.error('Failed to copy link: ', err);
|
||||
});
|
||||
}
|
||||
}
|
||||
41
public/scripts/display-ws-connection.js
Normal file
41
public/scripts/display-ws-connection.js
Normal file
|
|
@ -0,0 +1,41 @@
|
|||
// Get gameId and playerId from meta tags generated by the server
|
||||
const gameIdMeta = document.querySelector('meta[name="gameId"]');
|
||||
const playerIdMeta = document.querySelector('meta[name="playerId"]');
|
||||
if (!gameIdMeta || !playerIdMeta) {
|
||||
console.error('Game ID or Player ID meta tags not found.');
|
||||
}
|
||||
const gameId = gameIdMeta.content;
|
||||
const playerId = playerIdMeta.content;
|
||||
|
||||
// Dynamically construct WebSocket URL
|
||||
const wsUrl = `ws://${window.location.host}/ws?gameId=${gameId}&playerId=${playerId}`;
|
||||
|
||||
// Get the game container element
|
||||
const gameContainer = document.getElementById('game-container');
|
||||
|
||||
// Set the ws-connect attribute
|
||||
gameContainer.setAttribute('ws-connect', wsUrl);
|
||||
|
||||
// Tell HTMX to connect the WebSocket
|
||||
htmx.trigger(gameContainer, ' and connect');
|
||||
|
||||
// Update the game link input
|
||||
const gameLinkInput = document.getElementById('game-link');
|
||||
if (!gameLinkInput) {
|
||||
console.error('Missing game-link element.')
|
||||
}
|
||||
gameLinkInput.value =
|
||||
window.location.origin +
|
||||
window.location.pathname +
|
||||
`?gameId=${gameId}`;
|
||||
|
||||
// Update the WebSocket status indicator
|
||||
const wsStatusDiv = document.getElementById('ws-status');
|
||||
|
||||
gameContainer.addEventListener('htmx:wsClose', function () {
|
||||
if (wsStatusDiv) wsStatusDiv.textContent = 'Disconnected';
|
||||
});
|
||||
|
||||
gameContainer.addEventListener('htmx:wsError', function () {
|
||||
if (wsStatusDiv) wsStatusDiv.textContent = 'Connection Error';
|
||||
});
|
||||
13
public/scripts/send-ws-messages.js
Normal file
13
public/scripts/send-ws-messages.js
Normal file
|
|
@ -0,0 +1,13 @@
|
|||
document.addEventListener('htmx:wsConfigSend', function(e) {
|
||||
if (e.target.classList.contains('board-cell')) {
|
||||
const row = parseInt(e.target.dataset.row);
|
||||
const col = parseInt(e.target.dataset.col);
|
||||
|
||||
// Set the custom JSON data
|
||||
e.detail.parameters = {
|
||||
type: "make_move",
|
||||
row: row,
|
||||
col: col
|
||||
};
|
||||
}
|
||||
});
|
||||
Loading…
Add table
Add a link
Reference in a new issue