fix: bundle UI dist into server package for npm publishing
The server's static-ui mode resolves the UI dist path relative to its own directory. In the monorepo it finds ../../ui/dist, but when published to npm the UI package isn't available. - server/src/app.ts: try ../ui-dist (published) then ../../ui/dist (dev), gracefully degrade to API-only if neither exists - server/package.json: include ui-dist/ in published files - scripts/release.sh: build UI and copy dist to server/ui-dist before publishing, clean up in restore step Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -125,7 +125,7 @@ echo ""
|
|||||||
echo "==> Step 4/7: Building all packages..."
|
echo "==> Step 4/7: Building all packages..."
|
||||||
cd "$REPO_ROOT"
|
cd "$REPO_ROOT"
|
||||||
|
|
||||||
# Build packages in dependency order (excluding UI and CLI)
|
# Build packages in dependency order (excluding CLI)
|
||||||
pnpm --filter @paperclipai/shared build
|
pnpm --filter @paperclipai/shared build
|
||||||
pnpm --filter @paperclipai/adapter-utils build
|
pnpm --filter @paperclipai/adapter-utils build
|
||||||
pnpm --filter @paperclipai/db build
|
pnpm --filter @paperclipai/db build
|
||||||
@@ -133,7 +133,12 @@ pnpm --filter @paperclipai/adapter-claude-local build
|
|||||||
pnpm --filter @paperclipai/adapter-codex-local build
|
pnpm --filter @paperclipai/adapter-codex-local build
|
||||||
pnpm --filter @paperclipai/adapter-openclaw build
|
pnpm --filter @paperclipai/adapter-openclaw build
|
||||||
pnpm --filter @paperclipai/server build
|
pnpm --filter @paperclipai/server build
|
||||||
echo " ✓ All packages built"
|
|
||||||
|
# Build UI and bundle into server package for static serving
|
||||||
|
pnpm --filter @paperclipai/ui build
|
||||||
|
rm -rf "$REPO_ROOT/server/ui-dist"
|
||||||
|
cp -r "$REPO_ROOT/ui/dist" "$REPO_ROOT/server/ui-dist"
|
||||||
|
echo " ✓ All packages built (including UI)"
|
||||||
|
|
||||||
# ── Step 5: Build CLI bundle ─────────────────────────────────────────────────
|
# ── Step 5: Build CLI bundle ─────────────────────────────────────────────────
|
||||||
|
|
||||||
@@ -183,6 +188,9 @@ if [ -f "$CLI_DIR/README.md" ]; then
|
|||||||
rm "$CLI_DIR/README.md"
|
rm "$CLI_DIR/README.md"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Remove UI dist bundled into server for publishing
|
||||||
|
rm -rf "$REPO_ROOT/server/ui-dist"
|
||||||
|
|
||||||
# Commit all changes
|
# Commit all changes
|
||||||
git add -A
|
git add -A
|
||||||
git commit -m "chore: release v$NEW_VERSION"
|
git commit -m "chore: release v$NEW_VERSION"
|
||||||
|
|||||||
@@ -17,7 +17,8 @@
|
|||||||
"types": "./dist/index.d.ts"
|
"types": "./dist/index.d.ts"
|
||||||
},
|
},
|
||||||
"files": [
|
"files": [
|
||||||
"dist"
|
"dist",
|
||||||
|
"ui-dist"
|
||||||
],
|
],
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"dev": "tsx src/index.ts",
|
"dev": "tsx src/index.ts",
|
||||||
|
|||||||
@@ -124,12 +124,20 @@ export async function createApp(
|
|||||||
|
|
||||||
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
||||||
if (opts.uiMode === "static") {
|
if (opts.uiMode === "static") {
|
||||||
// Serve built UI from ui/dist in production.
|
// Try published location first (server/ui-dist/), then monorepo dev location (../../ui/dist)
|
||||||
const uiDist = path.resolve(__dirname, "../../ui/dist");
|
const candidates = [
|
||||||
app.use(express.static(uiDist));
|
path.resolve(__dirname, "../ui-dist"),
|
||||||
app.get(/.*/, (_req, res) => {
|
path.resolve(__dirname, "../../ui/dist"),
|
||||||
res.sendFile(path.join(uiDist, "index.html"));
|
];
|
||||||
});
|
const uiDist = candidates.find((p) => fs.existsSync(path.join(p, "index.html")));
|
||||||
|
if (uiDist) {
|
||||||
|
app.use(express.static(uiDist));
|
||||||
|
app.get(/.*/, (_req, res) => {
|
||||||
|
res.sendFile(path.join(uiDist, "index.html"));
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
console.warn("[paperclip] UI dist not found; running in API-only mode");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (opts.uiMode === "vite-dev") {
|
if (opts.uiMode === "vite-dev") {
|
||||||
|
|||||||
Reference in New Issue
Block a user