Bootstraps the shared frontend build glue for webapp-template-derived projects: bin/fetch-openapi.sh — pull Swagger JSON from a running backend bin/postprocess-openapi.py — fix oatpp 1.3 rough edges before orval bin/inject-hashed-filenames.py — rewrite HTML tags, config-driven src/vite-config.ts — defineAdminConfig / defineGuestConfig templates/orval.config.template.ts — starting point for derived repos Package name @uschuster/webapp-scaffold. Consumed as a devDependency through the internal Forgejo npm registry; binaries exposed for use in package.json scripts. createCoreFetch + i18n deferred to v0.2 / v0.3. Closes fewo-webapp#414 Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
1.9 KiB
1.9 KiB
@uschuster/webapp-scaffold
Shared frontend build glue for webapp-template-derived projects.
What's in v0.1
| Path | Purpose |
|---|---|
bin/fetch-openapi.sh |
Pull the oatpp Swagger spec from a running backend. Configurable via OPENAPI_URL / APP_URL / APP_TEST_PORT, optional Bearer via APP_API_KEY. JSON-validated. |
bin/postprocess-openapi.py |
Clean up oatpp 1.3's rough edges (missing operationIds, missing tags) before handing the spec to Orval. |
bin/inject-hashed-filenames.py |
Rewrite HTML script tags to point at Vite's manifest-declared hashed bundle. Config-driven so projects with multiple entry points (admin + guest) use a single invocation. |
src/vite-config.ts |
defineAdminConfig({root, vendorChunks?, outDir?}) and defineGuestConfig({root, entry?, vendorChunks?, outDir?}) helpers that bake in the VITE_BASE-driven prefix convention, manifest output, and the static/{dist,guest/dist} output layout the StaticController expects. |
templates/orval.config.template.ts |
Starting orval.config.ts for derived projects to copy-and-tweak. |
Install
{
"devDependencies": {
"@uschuster/webapp-scaffold": "^0.1.0"
}
}
Register the internal Forgejo npm registry (see your ~/.npmrc):
@uschuster:registry=http://127.0.0.1:3000/api/packages/uwe.admin/npm/
Consumer wiring
// frontend/vite.config.ts
import { defineAdminConfig } from '@uschuster/webapp-scaffold';
export default defineAdminConfig({ root: __dirname });
# frontend/package.json > scripts > codegen
webapp-scaffold-fetch-openapi && \
webapp-scaffold-postprocess-openapi && \
orval
Roadmap
- v0.2 —
createCoreFetchfactory (the Orval-mutatorcoreFetchwrapper, lifted from webapp-template, extended withsyncTables+ conflict hooks). - v0.3 — i18n system (de/en × formal/informal with fallback chain).