Fix deployment
All checks were successful
gitea/minesweeper-frontend/pipeline/head This commit looks good
All checks were successful
gitea/minesweeper-frontend/pipeline/head This commit looks good
This commit is contained in:
parent
9e20fe6829
commit
37e43f25b0
26
Dockerfile
26
Dockerfile
@ -1,13 +1,21 @@
|
|||||||
FROM node:20-alpine as builder
|
FROM node:20-alpine
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
COPY . .
|
COPY . .
|
||||||
ARG VITE_APP_BACKEND_ADDRESS
|
ARG VITE_SOCKET_URL
|
||||||
ENV VITE_APP_BACKEND_ADDRESS $VITE_APP_BACKEND_ADDRESS
|
ENV VITE_SOCKET_URL $VITE_SOCKET_URL
|
||||||
RUN npm install
|
RUN npm install
|
||||||
RUN npm run build
|
CMD ["npm", "run", "dev"]
|
||||||
|
|
||||||
FROM nginx:1.25.4-alpine-slim as prod
|
# FROM node:20-alpine as builder
|
||||||
COPY --from=builder /app/dist /usr/share/nginx/html
|
# WORKDIR /app
|
||||||
COPY nginx.conf /etc/nginx/conf.d
|
# COPY . .
|
||||||
EXPOSE 3000
|
# ARG VITE_SOCKET_URL
|
||||||
CMD ["nginx", "-g", "daemon off;"]
|
# ENV VITE_SOCKET_URL $VITE_SOCKET_URL
|
||||||
|
# RUN npm install
|
||||||
|
# RUN npm run build
|
||||||
|
|
||||||
|
# FROM nginx:1.25.4-alpine-slim as prod
|
||||||
|
# COPY --from=builder /app/dist /usr/share/nginx/html
|
||||||
|
# COPY nginx.conf /etc/nginx/conf.d
|
||||||
|
# EXPOSE 5173
|
||||||
|
# CMD ["nginx", "-g", "daemon off;"]
|
||||||
3
Jenkinsfile
vendored
3
Jenkinsfile
vendored
@ -4,13 +4,14 @@ pipeline {
|
|||||||
environment {
|
environment {
|
||||||
IMAGE_NAME = "darkbird/minesweeper-frontend:latest"
|
IMAGE_NAME = "darkbird/minesweeper-frontend:latest"
|
||||||
REGISTRY_IMAGE_NAME = "registry.xdarkbird.duckdns.org/darkbird/minesweeper-frontend:latest"
|
REGISTRY_IMAGE_NAME = "registry.xdarkbird.duckdns.org/darkbird/minesweeper-frontend:latest"
|
||||||
|
VITE_SOCKET_URL = "http://darkbird.es:5174"
|
||||||
}
|
}
|
||||||
|
|
||||||
stages {
|
stages {
|
||||||
stage('Docker build') {
|
stage('Docker build') {
|
||||||
steps {
|
steps {
|
||||||
sh """
|
sh """
|
||||||
docker build --build-arg VITE_SOCKET_URL=http://minesweeper-backend.darkbird.es --network="host" -t ${IMAGE_NAME} .
|
docker build --build-arg VITE_SOCKET_URL=${VITE_SOCKET_URL} --network="host" -t ${IMAGE_NAME} .
|
||||||
"""
|
"""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -2,7 +2,6 @@
|
|||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8" />
|
<meta charset="UTF-8" />
|
||||||
<link rel="icon" type="image/svg+xml" href="/vite.svg" />
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||||
<title>Minesweeper</title>
|
<title>Minesweeper</title>
|
||||||
</head>
|
</head>
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
server {
|
server {
|
||||||
listen 3000;
|
listen 5173;
|
||||||
root /usr/share/nginx/html;
|
root /usr/share/nginx/html;
|
||||||
index index.html;
|
index index.html;
|
||||||
etag on;
|
etag on;
|
||||||
|
|||||||
@ -21,7 +21,7 @@ const Game = ({ room, playerSocketId, handleDisconnect, handleTileClick, handleS
|
|||||||
<div>
|
<div>
|
||||||
<div style={{ paddingLeft: '2em', paddingRight: '2em' }}>
|
<div style={{ paddingLeft: '2em', paddingRight: '2em' }}>
|
||||||
{
|
{
|
||||||
room.gameMode === 'turns'
|
room.gameMode === 'rounds'
|
||||||
? <button
|
? <button
|
||||||
className="confirm-button"
|
className="confirm-button"
|
||||||
disabled={isSelectionConfirmed()}
|
disabled={isSelectionConfirmed()}
|
||||||
|
|||||||
@ -21,10 +21,10 @@ const RoomInfo = ({ room, handleDisconnect }) => {
|
|||||||
room.players.map((user, idx) =>
|
room.players.map((user, idx) =>
|
||||||
<li key={idx}>
|
<li key={idx}>
|
||||||
<span className="player-color-indicator" style={{ backgroundColor: user.color }}></span>
|
<span className="player-color-indicator" style={{ backgroundColor: user.color }}></span>
|
||||||
{user.socketId === room.currentPlayer ? <span> →</span> : <></>}
|
{room.gameMode === "turns" && user.socketId === room.currentPlayer ? <span> →</span> : <></>}
|
||||||
{user.tombstone ? <span>💀</span> : <></>}
|
{user.tombstone ? <span>💀</span> : <></>}
|
||||||
<span>{user.name}</span>
|
<span>{user.name}</span>
|
||||||
{user.confirmedSelection ? <span>✅</span> : <></>}
|
{room.gameMode === "rounds" && user.confirmedSelection ? <span>✅</span> : <></>}
|
||||||
</li>)
|
</li>)
|
||||||
}
|
}
|
||||||
</ul>
|
</ul>
|
||||||
|
|||||||
@ -1,10 +1,7 @@
|
|||||||
import { StrictMode } from 'react'
|
|
||||||
import { createRoot } from 'react-dom/client'
|
import { createRoot } from 'react-dom/client'
|
||||||
import './index.css'
|
import './index.css'
|
||||||
import App from './App.jsx'
|
import App from './App.jsx'
|
||||||
|
|
||||||
createRoot(document.getElementById('root')).render(
|
createRoot(document.getElementById('root')).render(
|
||||||
<StrictMode>
|
|
||||||
<App />
|
<App />
|
||||||
</StrictMode>,
|
|
||||||
)
|
)
|
||||||
|
|||||||
@ -1,56 +1,56 @@
|
|||||||
import { io } from 'socket.io-client';
|
import { io } from "socket.io-client";
|
||||||
|
|
||||||
const URL = 'http://192.168.0.134:5174';
|
const URL = import.meta.env.VITE_SOCKET_URL || "http://darkbird.es:5174";
|
||||||
console.log('Backend URL', URL);
|
console.log("Backend URL", URL);
|
||||||
export const socket = io(URL, {
|
export const socket = io(URL, {
|
||||||
autoConnect: false,
|
autoConnect: false,
|
||||||
transports: ['websocket'],
|
transports: ["websocket"],
|
||||||
withCredentials: true,
|
withCredentials: true,
|
||||||
});
|
});
|
||||||
|
|
||||||
export const setupSocketEffect = (socket, setRoom) => {
|
export const setupSocketEffect = (socket, setRoom) => {
|
||||||
const socketHandlers = [
|
const socketHandlers = [
|
||||||
{
|
{
|
||||||
event: 'connect',
|
event: "connect",
|
||||||
handler: () => {
|
handler: () => {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
event: 'disconnect',
|
event: "disconnect",
|
||||||
handler: () => {
|
handler: () => {
|
||||||
setRoom(null);
|
setRoom(null);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
event: 'error',
|
event: "error",
|
||||||
handler: (error) => {
|
handler: (error) => {
|
||||||
console.error(error);
|
console.error("Socket error", error);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
event: 'youJoinedRoom',
|
event: "youJoinedRoom",
|
||||||
handler: (data) => {
|
handler: (data) => {
|
||||||
setRoom({ ...data });
|
setRoom({ ...data });
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
event: 'roomUserJoined',
|
event: "roomUserJoined",
|
||||||
handler: (data) => {
|
handler: (data) => {
|
||||||
setRoom({ ...data });
|
setRoom({ ...data });
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
event: 'roomUserLeft',
|
event: "roomUserLeft",
|
||||||
handler: (data) => {
|
handler: (data) => {
|
||||||
setRoom({ ...data });
|
setRoom({ ...data });
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
event: 'updateRoom',
|
event: "updateRoom",
|
||||||
handler: (data) => {
|
handler: (data) => {
|
||||||
setRoom({ ...data });
|
setRoom({ ...data });
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
socketHandlers.forEach(({ event, handler }) => {
|
socketHandlers.forEach(({ event, handler }) => {
|
||||||
|
|||||||
@ -7,7 +7,7 @@ export default defineConfig(({ command, mode }) => {
|
|||||||
return {
|
return {
|
||||||
plugins: [react()],
|
plugins: [react()],
|
||||||
server: {
|
server: {
|
||||||
port: 3000,
|
port: 5173,
|
||||||
host: true,
|
host: true,
|
||||||
watch: {
|
watch: {
|
||||||
usePolling: true,
|
usePolling: true,
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user