Merge branch 'develop' into feat/mission-2
📊 Quality / 🔒 Security Audit (pull_request) Has been cancelled
📊 Quality / 📋 Dependency Freshness (pull_request) Has been cancelled
📊 Quality / 📦 Bundle Size (pull_request) Has been cancelled
🔍 Lint / 🪄 Check lint (pull_request) Has been cancelled
🔍 Lint / 🎨 Check format (pull_request) Has been cancelled
🔍 Lint / 🔎 Typecheck (pull_request) Has been cancelled
🔍 Lint / 🏗 Build (pull_request) Has been cancelled
📊 Quality / 🔒 Security Audit (pull_request) Has been cancelled
📊 Quality / 📋 Dependency Freshness (pull_request) Has been cancelled
📊 Quality / 📦 Bundle Size (pull_request) Has been cancelled
🔍 Lint / 🪄 Check lint (pull_request) Has been cancelled
🔍 Lint / 🎨 Check format (pull_request) Has been cancelled
🔍 Lint / 🔎 Typecheck (pull_request) Has been cancelled
🔍 Lint / 🏗 Build (pull_request) Has been cancelled
This commit is contained in:
@@ -0,0 +1,69 @@
|
|||||||
|
name: 🔁 Weekly Branch Promotions
|
||||||
|
|
||||||
|
on:
|
||||||
|
schedule:
|
||||||
|
- cron: "0 6 * * 1"
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
pull-requests: write
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
group: weekly-branch-promotions
|
||||||
|
cancel-in-progress: false
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
open-promotion-pr:
|
||||||
|
name: Open ${{ matrix.head }} → ${{ matrix.base }}
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- head: develop
|
||||||
|
base: design
|
||||||
|
title: "chore: merge develop into design"
|
||||||
|
- head: design
|
||||||
|
base: main
|
||||||
|
title: "chore: merge design into main"
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: ⬇️ Checkout
|
||||||
|
uses: actions/checkout@v6
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
|
||||||
|
- name: 🔁 Open promotion PR
|
||||||
|
env:
|
||||||
|
GH_TOKEN: ${{ github.token }}
|
||||||
|
BASE_BRANCH: ${{ matrix.base }}
|
||||||
|
HEAD_BRANCH: ${{ matrix.head }}
|
||||||
|
PR_TITLE: ${{ matrix.title }}
|
||||||
|
run: |
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
git fetch origin "$BASE_BRANCH" "$HEAD_BRANCH"
|
||||||
|
|
||||||
|
if git merge-base --is-ancestor "origin/$HEAD_BRANCH" "origin/$BASE_BRANCH"; then
|
||||||
|
echo "No promotion needed: $BASE_BRANCH already contains $HEAD_BRANCH."
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
existing_pr="$(gh pr list \
|
||||||
|
--state open \
|
||||||
|
--base "$BASE_BRANCH" \
|
||||||
|
--head "$GITHUB_REPOSITORY_OWNER:$HEAD_BRANCH" \
|
||||||
|
--json number \
|
||||||
|
--jq '.[0].number // empty')"
|
||||||
|
|
||||||
|
if [ -n "$existing_pr" ]; then
|
||||||
|
echo "Promotion PR already open: #$existing_pr."
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
gh pr create \
|
||||||
|
--base "$BASE_BRANCH" \
|
||||||
|
--head "$HEAD_BRANCH" \
|
||||||
|
--title "$PR_TITLE" \
|
||||||
|
--body "Automated weekly promotion PR from \`$HEAD_BRANCH\` to \`$BASE_BRANCH\`."
|
||||||
@@ -8,6 +8,7 @@
|
|||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"dev": "vite",
|
"dev": "vite",
|
||||||
|
"dev:three-debug": "vite --mode three-debug --host 0.0.0.0",
|
||||||
"build": "tsc -b && vite build",
|
"build": "tsc -b && vite build",
|
||||||
"lint": "eslint .",
|
"lint": "eslint .",
|
||||||
"lint:fix": "eslint . --fix",
|
"lint:fix": "eslint . --fix",
|
||||||
|
|||||||
@@ -52,7 +52,7 @@ export const REPAIR_MISSIONS: Record<RepairMissionId, RepairMissionConfig> = {
|
|||||||
description:
|
description:
|
||||||
"Repair the damaged cooling module before relaunching the bike",
|
"Repair the damaged cooling module before relaunching the bike",
|
||||||
modelPath: "/models/ebike/model.gltf",
|
modelPath: "/models/ebike/model.gltf",
|
||||||
modelScale: 0.0055,
|
modelScale: 0.50,
|
||||||
stageUiPath: "/assets/UI/ebike.webm",
|
stageUiPath: "/assets/UI/ebike.webm",
|
||||||
interactUiPath: REPAIR_INTERACT_UI_PATH,
|
interactUiPath: REPAIR_INTERACT_UI_PATH,
|
||||||
brokenUiPath: REPAIR_BROKEN_UI_PATH,
|
brokenUiPath: REPAIR_BROKEN_UI_PATH,
|
||||||
|
|||||||
+33
-13
@@ -9,6 +9,9 @@ import { parseMapNodes } from "./src/utils/map/mapNodeValidation";
|
|||||||
import { parseSrt } from "./src/utils/subtitles/parseSrt";
|
import { parseSrt } from "./src/utils/subtitles/parseSrt";
|
||||||
|
|
||||||
const __dirname = fileURLToPath(new URL(".", import.meta.url));
|
const __dirname = fileURLToPath(new URL(".", import.meta.url));
|
||||||
|
const THREE_SOURCE_ENTRY = fileURLToPath(
|
||||||
|
new URL("./node_modules/three/src/Three.js", import.meta.url),
|
||||||
|
);
|
||||||
|
|
||||||
const MAX_MAP_PAYLOAD_BYTES = 1024 * 1024;
|
const MAX_MAP_PAYLOAD_BYTES = 1024 * 1024;
|
||||||
const MAX_SRT_PAYLOAD_BYTES = 256 * 1024;
|
const MAX_SRT_PAYLOAD_BYTES = 256 * 1024;
|
||||||
@@ -634,18 +637,35 @@ function resolvePublicPath(publicPath: string): string | null {
|
|||||||
return resolvedPath;
|
return resolvedPath;
|
||||||
}
|
}
|
||||||
|
|
||||||
export default defineConfig({
|
export default defineConfig(({ mode }) => {
|
||||||
plugins: [
|
const isThreeDebug = mode === "three-debug";
|
||||||
react(),
|
|
||||||
saveMapPlugin(),
|
return {
|
||||||
saveSrtPlugin(),
|
plugins: [
|
||||||
saveDialogueManifestPlugin(),
|
react(),
|
||||||
saveCinematicManifestPlugin(),
|
saveMapPlugin(),
|
||||||
validateDialoguesPlugin(),
|
saveSrtPlugin(),
|
||||||
],
|
saveDialogueManifestPlugin(),
|
||||||
resolve: {
|
saveCinematicManifestPlugin(),
|
||||||
alias: {
|
validateDialoguesPlugin(),
|
||||||
"@": fileURLToPath(new URL("./src", import.meta.url)),
|
],
|
||||||
|
resolve: {
|
||||||
|
alias: [
|
||||||
|
{
|
||||||
|
find: "@",
|
||||||
|
replacement: fileURLToPath(new URL("./src", import.meta.url)),
|
||||||
|
},
|
||||||
|
...(isThreeDebug
|
||||||
|
? [{ find: /^three$/, replacement: THREE_SOURCE_ENTRY }]
|
||||||
|
: []),
|
||||||
|
],
|
||||||
},
|
},
|
||||||
},
|
...(isThreeDebug
|
||||||
|
? {
|
||||||
|
optimizeDeps: {
|
||||||
|
exclude: ["three"],
|
||||||
|
},
|
||||||
|
}
|
||||||
|
: {}),
|
||||||
|
};
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user