@devlusoft/devix 0.2.0 → 0.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli/build.js +30 -308
- package/dist/cli/build.js.map +3 -3
- package/dist/cli/dev.js +32 -395
- package/dist/cli/dev.js.map +3 -3
- package/dist/cli/generate.js +30 -434
- package/dist/cli/generate.js.map +3 -3
- package/dist/cli/index.js +33 -698
- package/dist/cli/index.js.map +3 -3
- package/dist/cli/start.js +1 -89
- package/dist/cli/start.js.map +2 -2
- package/dist/config.js +1 -16
- package/dist/config.js.map +2 -2
- package/dist/runtime/api-context.js +1 -17
- package/dist/runtime/api-context.js.map +2 -2
- package/dist/runtime/client-router.js +1 -58
- package/dist/runtime/client-router.js.map +2 -2
- package/dist/runtime/context.js +1 -14
- package/dist/runtime/context.js.map +2 -2
- package/dist/runtime/error-boundary.js +1 -36
- package/dist/runtime/error-boundary.js.map +2 -2
- package/dist/runtime/fetch.js +1 -34
- package/dist/runtime/fetch.js.map +2 -2
- package/dist/runtime/head.js +1 -68
- package/dist/runtime/head.js.map +2 -2
- package/dist/runtime/index.d.ts +1 -0
- package/dist/runtime/index.js +1 -367
- package/dist/runtime/index.js.map +3 -3
- package/dist/runtime/link.js +1 -42
- package/dist/runtime/link.js.map +2 -2
- package/dist/runtime/metadata.js +1 -21
- package/dist/runtime/metadata.js.map +2 -2
- package/dist/runtime/router-provider.js +1 -258
- package/dist/runtime/router-provider.js.map +2 -2
- package/dist/server/api-router.js +1 -64
- package/dist/server/api-router.js.map +2 -2
- package/dist/server/api.js +1 -123
- package/dist/server/api.js.map +2 -2
- package/dist/server/collect-css.js +1 -14
- package/dist/server/collect-css.js.map +2 -2
- package/dist/server/index.js +1 -132
- package/dist/server/index.js.map +2 -2
- package/dist/server/pages-router.js +1 -63
- package/dist/server/pages-router.js.map +2 -2
- package/dist/server/render.js +1 -305
- package/dist/server/render.js.map +2 -2
- package/dist/server/routes.js +1 -41
- package/dist/server/routes.js.map +2 -2
- package/dist/utils/async.js +1 -13
- package/dist/utils/async.js.map +2 -2
- package/dist/utils/banner.js +1 -33
- package/dist/utils/banner.js.map +2 -2
- package/dist/utils/cookies.js +1 -28
- package/dist/utils/cookies.js.map +2 -2
- package/dist/utils/duration.js +1 -21
- package/dist/utils/duration.js.map +2 -2
- package/dist/utils/env.js +1 -13
- package/dist/utils/env.js.map +2 -2
- package/dist/utils/html.js +1 -11
- package/dist/utils/html.js.map +2 -2
- package/dist/utils/patterns.js +1 -7
- package/dist/utils/patterns.js.map +2 -2
- package/dist/utils/response.d.ts +4 -1
- package/dist/utils/response.js +1 -9
- package/dist/utils/response.js.map +3 -3
- package/dist/vite/codegen/api.js +6 -12
- package/dist/vite/codegen/api.js.map +2 -2
- package/dist/vite/codegen/client-routes.js +6 -12
- package/dist/vite/codegen/client-routes.js.map +2 -2
- package/dist/vite/codegen/context.js +2 -8
- package/dist/vite/codegen/context.js.map +2 -2
- package/dist/vite/codegen/entry-client.js +4 -10
- package/dist/vite/codegen/entry-client.js.map +2 -2
- package/dist/vite/codegen/extract-methods.js +1 -15
- package/dist/vite/codegen/extract-methods.js.map +2 -2
- package/dist/vite/codegen/render.js +6 -12
- package/dist/vite/codegen/render.js.map +2 -2
- package/dist/vite/codegen/routes-dts.js +11 -49
- package/dist/vite/codegen/routes-dts.js.map +3 -3
- package/dist/vite/codegen/scan-api.js +1 -77
- package/dist/vite/codegen/scan-api.js.map +3 -3
- package/dist/vite/codegen/write-routes-dts.js +1 -16
- package/dist/vite/codegen/write-routes-dts.js.map +2 -2
- package/dist/vite/index.js +30 -247
- package/dist/vite/index.js.map +3 -3
- package/package.json +2 -2
package/dist/cli/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/vite/codegen/entry-client.ts", "../../src/vite/codegen/client-routes.ts", "../../src/vite/codegen/render.ts", "../../src/vite/codegen/api.ts", "../../src/utils/patterns.ts", "../../src/server/pages-router.ts", "../../src/server/api-router.ts", "../../src/vite/codegen/context.ts", "../../src/vite/codegen/extract-methods.ts", "../../src/vite/codegen/routes-dts.ts", "../../src/vite/codegen/scan-api.ts", "../../src/vite/codegen/write-routes-dts.ts", "../../src/vite/index.ts", "../../src/server/routes.ts", "../../src/utils/banner.ts", "../../src/server/collect-css.ts", "../../src/utils/duration.ts", "../../src/utils/env.ts", "../../src/cli/dev.ts", "../../src/cli/build.ts", "../../src/cli/generate.ts", "../../src/cli/start.ts", "../../src/cli/index.ts"],
|
|
4
|
-
"sourcesContent": ["interface EntryClientOptions {\n cssUrls: string[]\n}\n\nexport function generateEntryClient({cssUrls}: EntryClientOptions): string {\n const cssImports = cssUrls.map(u => `import '${u}'`).join('\\n')\n\n return `\n${cssImports}\nimport \"@vitejs/plugin-react/preamble\"\nimport React from \"react\"\nimport {hydrateRoot, createRoot} from 'react-dom/client'\nimport {matchClientRoute, loadErrorPage, getDefaultErrorPage} from 'virtual:devix/client-routes'\nimport {RouterProvider} from '@devlusoft/devix'\n\nconst root = document.getElementById('devix-root')\n\nif (!window.__DEVIX__) {\n const ErrorPage = getDefaultErrorPage()\n createRoot(root).render(React.createElement(ErrorPage, {statusCode: 500, message: 'Server error'}))\n} else {\n const {metadata, viewport, clientEntry} = window.__DEVIX__\n const loaderData = window.__LOADER_DATA__\n const layoutsData = window.__LAYOUTS_DATA__ ?? []\n\n const matched = matchClientRoute(window.location.pathname)\n\n if (matched) {\n const [pageMod, ...layoutMods] = await Promise.all([\n matched.load(),\n ...matched.loadLayouts.map(l => l()),\n ])\n hydrateRoot(\n root,\n React.createElement(RouterProvider, {\n clientEntry,\n initialData: loaderData,\n initialParams: matched.params,\n initialPage: pageMod.default,\n initialLayouts: layoutMods.map(m => m.default),\n initialLayoutsData: layoutsData,\n initialMeta: metadata,\n initialViewport: viewport,\n })\n )\n } else {\n const ErrorPage = await loadErrorPage() ?? getDefaultErrorPage()\n createRoot(root).render(\n React.createElement(RouterProvider, {\n clientEntry,\n initialData: null,\n initialParams: {},\n initialPage: () => null,\n initialLayouts: [],\n initialLayoutsData: [],\n initialMeta: null,\n initialError: {statusCode: 404, message: 'Not found'},\n initialErrorPage: ErrorPage,\n })\n )\n }\n}\n`\n}", "interface ClientRoutesOptions {\n pagesDir: string\n matcherPath: string\n}\n\nexport function generateClientRoutes({pagesDir, matcherPath}: ClientRoutesOptions) {\n return `\nimport React from 'react'\nimport { createMatcher } from '${matcherPath}'\nconst pageFiles = import.meta.glob(['/${pagesDir}/**/*.tsx', '!**/error.tsx', '!**/layout.tsx'])\nconst layoutFiles = import.meta.glob('/${pagesDir}/**/layout.tsx')\nconst errorFiles = import.meta.glob('/${pagesDir}/**/error.tsx')\n\nexport const matchClientRoute = createMatcher(pageFiles, layoutFiles)\n\nexport async function loadErrorPage() {\n const key = Object.keys(errorFiles)[0]\n if (!key) return null\n const mod = await errorFiles[key]()\n return mod?.default ?? null\n}\n\nexport function getDefaultErrorPage() {\n return function DefaultError({ statusCode, message }) {\n return React.createElement('main', {\n style: { minHeight: '100dvh', display: 'flex', flexDirection: 'column', \n alignItems: 'center', justifyContent: 'center', gap: '8px',\n fontFamily: 'system-ui, sans-serif' }\n },\n React.createElement('h1', {style: {fontSize: '4rem', fontWeight: 700}}, statusCode),\n React.createElement('p', {style: {color: '#666'}}, message ?? 'An unexpected error occurred'),\n )\n }\n}\n`\n}", "interface RenderOptions {\n pagesDir: string\n renderPath: string\n}\n\nexport function generateRender({pagesDir, renderPath}: RenderOptions): string {\n return `\nimport { render as _render, runLoader as _runLoader, getStaticRoutes as _getStaticRoutes } from '${renderPath}'\n\nconst _pages = import.meta.glob(['/${pagesDir}/**/*.tsx', '!**/error.tsx', '!**/layout.tsx'])\nconst _layouts = import.meta.glob('/${pagesDir}/**/layout.tsx')\n\nconst _glob = {\n pages: _pages,\n layouts: _layouts,\n pagesDir: '/${pagesDir}',\n}\n\nexport function render(url, request, options) {\n return _render(url, request, _glob, options)\n}\n\nexport function runLoader(url, request, options) {\n return _runLoader(url, request, _glob, options)\n}\n\nexport function getStaticRoutes() {\n return _getStaticRoutes(_glob)\n}\n`\n}\n", "interface ApiOptions {\n apiPath: string\n appDir: string\n}\n\nexport function generateApi({apiPath, appDir}: ApiOptions): string {\n return `\nimport { handleApiRequest as _handleApiRequest } from '${apiPath}'\n\nconst _routes = import.meta.glob(['/${appDir}/api/**/*.ts', '!**/middleware.ts'])\nconst _middlewares = import.meta.glob('/${appDir}/api/**/middleware.ts')\n\nconst _glob = {\n routes: _routes,\n middlewares: _middlewares,\n apiDir: '/${appDir}/api',\n}\n\nexport function handleApiRequest(url, request) {\n return _handleApiRequest(url, request, _glob)\n}\n`\n}\n", "export function routePattern(rel: string): string {\n return rel\n .replace(/\\.(tsx|ts|jsx|js)$/, '')\n .replace(/\\(.*?\\)\\//g, '')\n .replace(/^index$|\\/index$/, '')\n .replace(/\\[([^\\]]+)]/g, ':$1')\n || '/'\n}", "import {routePattern} from \"../utils/patterns\";\n\nexport interface Page {\n path: string\n key: string\n params: string[]\n regex: RegExp\n}\n\nexport interface Layout {\n dir: string\n key: string\n}\n\nexport interface PagesResult {\n pages: Page[]\n layouts: Layout[]\n}\n\nfunction keyToRoutePattern(key: string, pagesDir: string): string {\n const rel = key.slice(pagesDir.length + 1).replace(/\\\\/g, '/')\n const pattern = routePattern(rel)\n return pattern === \"/\" ? \"/\" : `/${pattern}`\n}\n\nfunction keyToDir(key: string): string {\n return key.slice(0, key.lastIndexOf('/'))\n}\n\nlet cache: PagesResult | null = null\n\nexport function invalidatePagesCache() {\n cache = null\n}\n\nexport function buildPages(pageKeys: string[], layoutKeys: string[], pagesDir: string): PagesResult {\n if (cache) return cache\n\n const pages: Page[] = []\n const layouts: Layout[] = []\n\n for (const key of layoutKeys) {\n layouts.push({dir: keyToDir(key), key})\n }\n\n for (const key of pageKeys) {\n const pattern = keyToRoutePattern(key, pagesDir)\n const params = [...pattern.matchAll(/:([^/]+)/g)].map(m => m[1])\n const regexStr = pattern\n .replace(/:[^/]+/g, '([^/]+)')\n .replace(/\\//g, '\\\\/')\n pages.push({path: pattern, key, params, regex: new RegExp(`^${regexStr}$`)})\n }\n\n pages.sort((a, b) => {\n const aScore = (a.path.match(/:/g) || []).length\n const bScore = (b.path.match(/:/g) || []).length\n if (aScore !== bScore) return aScore - bScore\n return b.path.length - a.path.length\n })\n\n cache = {pages, layouts}\n return cache\n}\n\nexport function collectLayoutChain(pageKey: string, layouts: Layout[]): Layout[] {\n const pageDir = keyToDir(pageKey)\n\n return layouts\n .filter(layout => pageDir.startsWith(layout.dir))\n .sort((a, b) => a.dir.split('/').length - b.dir.split('/').length)\n}\n\nexport function matchPage(pathname: string, pages: Page[]): {\n page: Page\n params: Record<string, string>\n} | null {\n for (const page of pages) {\n const match = pathname.match(page.regex)\n if (match) {\n const params: Record<string, string> = {}\n page.params.forEach((name, i) => {\n params[name] = decodeURIComponent(match[i + 1])\n })\n return {page, params}\n }\n }\n return null\n}\n", "import {routePattern} from \"../utils/patterns\";\n\nexport interface ApiRoute {\n path: string\n key: string\n params: string[]\n regex: RegExp\n}\n\nexport interface ApiMiddleware {\n dir: string\n key: string\n}\n\nexport interface ApiResult {\n routes: ApiRoute[]\n middlewares: ApiMiddleware[]\n}\n\nexport function keyToRoutePattern(key: string, apiDir: string): string {\n const rel = key.slice(apiDir.length + 1).replace(/\\\\/g, '/')\n const pattern = routePattern(rel)\n return pattern === '/' ? '/api' : `/api/${pattern}`.replace('/api//', '/api/')\n}\n\nfunction keyToDir(key: string): string {\n return key.slice(0, key.lastIndexOf('/'))\n}\n\nlet cache: ApiResult | null = null\n\nexport function invalidateApiCache() {\n cache = null\n}\n\nexport function buildRoutes(routeKeys: string[], middlewareKeys: string[], apiDir: string): ApiResult {\n if (cache) return cache\n\n const routes: ApiRoute[] = []\n const middlewares: ApiMiddleware[] = []\n\n for (const key of middlewareKeys) {\n middlewares.push({dir: keyToDir(key), key})\n }\n\n for (const key of routeKeys) {\n const pattern = keyToRoutePattern(key, apiDir)\n const params = [...pattern.matchAll(/:([^/]+)/g)].map(m => m[1])\n const regexStr = pattern\n .replace(/:[^/]+/g, '([^/]+)')\n .replace(/\\//g, '\\\\/')\n routes.push({path: pattern, key, params, regex: new RegExp(`^${regexStr}$`)})\n }\n routes.sort((a, b) => {\n const aScore = (a.path.match(/:/g) || []).length\n const bScore = (b.path.match(/:/g) || []).length\n if (aScore !== bScore) return aScore - bScore\n return b.path.length - a.path.length\n })\n\n cache = {routes, middlewares}\n return cache\n}\n\nexport function collectMiddlewareChain(routeKey: string, middlewares: ApiMiddleware[]): ApiMiddleware[] {\n const routeDir = keyToDir(routeKey)\n\n return middlewares\n .filter(mw => routeDir.startsWith(mw.dir))\n .sort((a, b) => a.dir.split('/').length - b.dir.split('/').length)\n}\n\nexport function matchRoute(\n pathname: string,\n routes: ApiRoute[]\n): {route: ApiRoute; params: Record<string, string>} | null {\n for (const route of routes) {\n const match = pathname.match(route.regex)\n if (match) {\n const params: Record<string, string> = {}\n route.params.forEach((name, i) => {\n params[name] = decodeURIComponent(match[i + 1])\n })\n return {route, params}\n }\n }\n return null\n}\n", "export function generateContext(): string {\n return `\nexport {RouterContext} from '@devlusoft/devix/runtime/context'\n`\n}", "const HTTP_METHODS = ['GET', 'POST', 'PUT', 'PATCH', 'DELETE', 'HEAD', 'OPTIONS'] as const\nexport type HttpMethod = (typeof HTTP_METHODS)[number]\n\nconst METHOD_EXPORT_RE = /export\\s+(?:const|async\\s+function|function)\\s+(GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS)\\b/g\n\nfunction stripComments(content: string): string {\n return content\n .replace(/\\/\\*[\\s\\S]*?\\*\\//g, '')\n .replace(/\\/\\/.*$/gm, '')\n}\n\nexport function extractHttpMethods(content: string): HttpMethod[] {\n const found = new Set<HttpMethod>()\n for (const match of stripComments(content).matchAll(METHOD_EXPORT_RE)) {\n found.add(match[1] as HttpMethod)\n }\n return [...found]\n}\n", "import { keyToRoutePattern } from '../../server/api-router'\nimport type { HttpMethod } from './extract-methods'\n\nexport interface RouteEntry {\n filePath: string\n urlPattern: string\n identifier: string\n methods: HttpMethod[]\n}\n\nexport function filePathToIdentifier(filePath: string, apiDir: string): string {\n return '_api_' + filePath\n .slice(`${apiDir}/`.length)\n .replace(/\\.(ts|tsx)$/, '')\n .replace(/[^a-zA-Z0-9]/g, '_')\n}\n\nexport function buildRouteEntry(filePath: string, apiDir: string, methods: HttpMethod[]): RouteEntry {\n return {\n filePath,\n urlPattern: keyToRoutePattern(filePath, apiDir),\n identifier: filePathToIdentifier(filePath, apiDir),\n methods,\n }\n}\n\nexport function generateRoutesDts(entries: RouteEntry[], apiDir: string): string {\n if (entries.length === 0) {\n return `// auto-generado por devix \u2014 no editar\\ndeclare module '@devlusoft/devix' {\\n interface ApiRoutes {}\\n}\\n`\n }\n\n const imports = entries\n .map(e => {\n const importPath = '../' + e.filePath.replace(/\\.(ts|tsx)$/, '')\n return `import type * as ${e.identifier} from '${importPath}'`\n })\n .join('\\n')\n\n const routeLines = entries.flatMap(e =>\n e.methods.map(m =>\n ` '${m} ${e.urlPattern}': InferRoute<(typeof ${e.identifier})['${m}']>`\n )\n ).join('\\n')\n\n return `// auto-generado por devix \u2014 no editar\n${imports}\n\ntype InferRoute<T> = T extends (...args: any[]) => any\n ? Exclude<Awaited<ReturnType<T>>, Response | null | void>\n : never\n\ndeclare module '@devlusoft/devix' {\n interface ApiRoutes {\n${routeLines}\n }\n}\n`\n}\n", "import {readFileSync, readdirSync, statSync} from 'node:fs'\nimport {join, relative} from 'node:path'\nimport {extractHttpMethods} from './extract-methods'\nimport {buildRouteEntry} from './routes-dts'\nimport type {RouteEntry} from './routes-dts'\n\nfunction walkDir(dir: string, root: string): string[] {\n const entries: string[] = []\n for (const name of readdirSync(dir)) {\n const full = join(dir, name)\n if (statSync(full).isDirectory()) {\n entries.push(...walkDir(full, root))\n } else if (/\\.(ts|tsx)$/.test(name)) {\n entries.push(relative(root, full).replace(/\\\\/g, '/'))\n }\n }\n return entries\n}\n\nexport function scanApiFiles(appDir: string, projectRoot: string): RouteEntry[] {\n const apiDir = join(projectRoot, appDir, 'api')\n\n let files: string[]\n try {\n files = walkDir(apiDir, projectRoot)\n } catch {\n return []\n }\n\n return files\n .filter(f => !f.endsWith('middleware.ts') && !f.endsWith('middleware.tsx'))\n .flatMap(filePath => {\n try {\n const content = readFileSync(join(projectRoot, filePath), 'utf-8')\n const methods = extractHttpMethods(content)\n if (methods.length === 0) return []\n return [buildRouteEntry(filePath, `${appDir}/api`, methods)]\n } catch {\n return []\n }\n })\n}\n", "import {mkdirSync, readFileSync, writeFileSync, existsSync} from 'node:fs'\nimport {join} from 'node:path'\n\nexport function writeRoutesDts(content: string, projectRoot: string): boolean {\n const devixDir = join(projectRoot, '.devix')\n const outPath = join(devixDir, 'routes.d.ts')\n\n mkdirSync(devixDir, {recursive: true})\n\n if (existsSync(outPath) && readFileSync(outPath, 'utf-8') === content) {\n return false\n }\n\n writeFileSync(outPath, content, 'utf-8')\n return true\n}\n", "import {UserConfig, Plugin, mergeConfig} from 'vite'\nimport type {DevixConfig} from '../config'\nimport react from '@vitejs/plugin-react'\nimport {fileURLToPath} from 'node:url'\nimport {dirname, resolve} from 'node:path'\nimport {generateEntryClient} from './codegen/entry-client'\nimport {generateClientRoutes} from './codegen/client-routes'\nimport {generateRender} from './codegen/render'\nimport {generateApi} from './codegen/api'\nimport {invalidatePagesCache} from \"../server/pages-router\";\nimport {invalidateApiCache} from \"../server/api-router\";\nimport {generateContext} from \"./codegen/context\";\nimport {scanApiFiles} from \"./codegen/scan-api\";\nimport {generateRoutesDts} from \"./codegen/routes-dts\";\nimport {writeRoutesDts} from \"./codegen/write-routes-dts\";\n\nconst __dirname = dirname(fileURLToPath(import.meta.url))\n\nconst VIRTUAL_ENTRY_CLIENT = 'virtual:devix/entry-client'\nconst VIRTUAL_CLIENT_ROUTES = 'virtual:devix/client-routes'\nconst VIRTUAL_RENDER = 'virtual:devix/render'\nconst VIRTUAL_API = 'virtual:devix/api'\nconst VIRTUAL_CONTEXT = 'virtual:devix/context'\n\nexport function devix(config: DevixConfig): UserConfig {\n const appDir = config.appDir ?? 'app'\n const pagesDir = `${appDir}/pages`\n const cssUrls = (config.css ?? []).map(u => u.startsWith('/') ? u : `/${u.replace(/^\\.\\//, '')}`)\n\n const renderPath = resolve(__dirname, '../server/render.js').replace(/\\\\/g, '/')\n const apiPath = resolve(__dirname, '../server/api.js').replace(/\\\\/g, '/')\n const matcherPath = resolve(__dirname, '../runtime/client-router.js').replace(/\\\\/g, '/')\n\n const virtualPlugin: Plugin = {\n name: 'devix',\n enforce: 'pre',\n\n resolveId(id) {\n if (id === VIRTUAL_ENTRY_CLIENT) return `\\0${VIRTUAL_ENTRY_CLIENT}`\n if (id === VIRTUAL_CLIENT_ROUTES) return `\\0${VIRTUAL_CLIENT_ROUTES}`\n if (id === VIRTUAL_RENDER) return `\\0${VIRTUAL_RENDER}`\n if (id === VIRTUAL_API) return `\\0${VIRTUAL_API}`\n if (id === VIRTUAL_CONTEXT) return `\\0${VIRTUAL_CONTEXT}`\n },\n\n load(id) {\n if (id === `\\0${VIRTUAL_ENTRY_CLIENT}`)\n return generateEntryClient({cssUrls})\n if (id === `\\0${VIRTUAL_CLIENT_ROUTES}`)\n return generateClientRoutes({pagesDir, matcherPath})\n if (id === `\\0${VIRTUAL_RENDER}`)\n return generateRender({pagesDir, renderPath})\n if (id === `\\0${VIRTUAL_API}`)\n return generateApi({apiPath, appDir})\n if (id === `\\0${VIRTUAL_CONTEXT}`)\n return generateContext()\n },\n\n buildStart() {\n const root = process.cwd()\n const entries = scanApiFiles(appDir, root)\n writeRoutesDts(generateRoutesDts(entries, `${appDir}/api`), root)\n },\n\n configureServer(server) {\n const root = process.cwd()\n\n const regenerateDts = () => {\n const entries = scanApiFiles(appDir, root)\n writeRoutesDts(generateRoutesDts(entries, `${appDir}/api`), root)\n }\n\n server.watcher.on('add', (file) => {\n if (file.startsWith(resolve(root, pagesDir))) invalidatePagesCache()\n if (file.includes(`${appDir}/api`)) { invalidateApiCache(); regenerateDts() }\n })\n server.watcher.on('unlink', (file) => {\n if (file.startsWith(resolve(root, pagesDir))) invalidatePagesCache()\n if (file.includes(`${appDir}/api`)) { invalidateApiCache(); regenerateDts() }\n })\n server.watcher.on('change', (file) => {\n if (file.includes(`${appDir}/api`) && !file.endsWith('middleware.ts')) {\n regenerateDts()\n }\n })\n },\n }\n\n const base: UserConfig = {\n plugins: [react(), virtualPlugin],\n ssr: {noExternal: ['@devlusoft/devix']},\n ...(config.envPrefix ? {envPrefix: config.envPrefix} : {}),\n }\n\n return mergeConfig(base, config.vite ?? {})\n}", "import type {Hono} from 'hono'\nimport type {Manifest} from 'vite'\n\ninterface ServerOptions {\n renderModule: any\n apiModule: any\n manifest?: Manifest\n loaderTimeout?: number\n}\n\nexport function registerApiRoutes(app: Hono, {apiModule, renderModule, loaderTimeout}: ServerOptions) {\n app.all('/api/*', async (c) => {\n try {\n return await apiModule.handleApiRequest(c.req.url, c.req.raw)\n } catch (e) {\n console.error(e)\n return c.json({error: 'internal error'}, 500)\n }\n })\n\n app.get('/_data/*', async (c) => {\n try {\n const {pathname, search} = new URL(c.req.url, 'http://localhost')\n const url = pathname.replace(/^\\/_data/, '') + search\n\n const data = await renderModule.runLoader(url, c.req.raw, {loaderTimeout})\n return c.json(data)\n } catch (e) {\n console.error(e)\n return c.json({error: 'internal error'}, 500)\n }\n })\n}\n\nexport function registerSsrRoute(app: Hono, {renderModule, manifest, loaderTimeout}: ServerOptions) {\n app.get('*', async (c) => {\n try {\n const {html, statusCode, headers} = await renderModule.render(c.req.url, c.req.raw, {manifest, loaderTimeout})\n const res = c.html(`<!DOCTYPE html>${html}`, statusCode)\n for (const [key, value] of Object.entries(headers as Record<string, string>)) {\n res.headers.set(key, value)\n }\n return res\n } catch (e) {\n console.error(e)\n return c.text('Internal Server Error', 500)\n }\n })\n}", "import pc from 'picocolors'\nimport {networkInterfaces} from 'node:os'\nimport {createRequire} from 'node:module'\n\nfunction getNetworkUrl(port: number): string | null {\n const nets = networkInterfaces()\n for (const interfaces of Object.values(nets)) {\n for (const net of interfaces ?? []) {\n if (net.family === 'IPv4' && !net.internal) {\n return `http://${net.address}:${port}/`\n }\n }\n }\n return null\n}\n\nexport function printDevBanner(port: number) {\n const req = createRequire(import.meta.url)\n const version = req('../../package.json').version\n const networkUrl = getNetworkUrl(port)\n\n console.log()\n console.log(` ${pc.bold(pc.yellow('devix'))} ${pc.dim(`v${version}`)}`)\n console.log()\n console.log(` ${pc.green('\u279C')} ${pc.bold('Local:')} ${pc.cyan(`http://localhost:${port}/`)}`)\n if (networkUrl) {\n console.log(` ${pc.green('\u279C')} ${pc.bold('Network:')} ${pc.cyan(networkUrl)}`)\n } else {\n console.log(` ${pc.green('\u279C')} ${pc.bold('Network:')} ${pc.dim('use --host to expose')}`)\n }\n console.log()\n}", "import type {ViteDevServer} from 'vite'\n\nexport async function collectCss(vite: ViteDevServer): Promise<string[]> {\n const cssUrls = new Set<string>()\n\n for (const [, mod] of vite.moduleGraph.idToModuleMap) {\n if (!mod.id) continue\n if (mod.id.endsWith('.css') || mod.id.includes('.css?')) {\n cssUrls.add(mod.url)\n }\n }\n\n return [...cssUrls]\n}", "export function parseDuration(value: number | string): number {\n if (typeof value === 'number') return value\n const match = value.trim().match(/^(\\d+(?:\\.\\d+)?)\\s*(ms|s|m|h)?$/)\n if (!match) throw new Error(`[devix] Invalid duration: \"${value}\". Use a number (ms) or a string like \"5s\", \"2m\", \"500ms\".`)\n const n = parseFloat(match[1])\n switch (match[2]) {\n case 'h': return n * 3_600_000\n case 'm': return n * 60_000\n case 's': return n * 1_000\n case 'ms':\n default: return n\n }\n}\n", "import {loadEnv} from 'vite'\n\nexport function loadDotenv(mode: string) {\n const env = loadEnv(mode, process.cwd(), '')\n for (const [key, value] of Object.entries(env)) {\n if (process.env[key] === undefined) {\n process.env[key] = value\n }\n }\n}\n", "import {createServer} from 'node:http'\nimport {createServer as createViteServer} from 'vite'\nimport {getRequestListener} from '@hono/node-server'\nimport {Hono} from 'hono'\nimport type {DevixConfig} from '../config'\nimport {devix} from '../vite'\nimport {registerApiRoutes} from '../server/routes'\nimport {printDevBanner} from \"../utils/banner\";\nimport {collectCss} from \"../server/collect-css\";\nimport {parseDuration} from \"../utils/duration\";\nimport {loadDotenv} from \"../utils/env\";\n\nloadDotenv('development')\n\nconst VIRTUAL_RENDER = 'virtual:devix/render'\nconst VIRTUAL_API = 'virtual:devix/api'\n\nconst config: DevixConfig = (await import(`${process.cwd()}/devix.config.ts`)).default\nconst port = Number(process.env.PORT) || config.port || 3000\nconst host = typeof config.host === 'string' ? config.host : config.host ? '0.0.0.0' : 'localhost'\n\nconst vite = await createViteServer({\n ...devix(config),\n configFile: false,\n appType: 'custom',\n server: {middlewareMode: true},\n})\n\nconst renderModule = {\n render: async (...args: any[]) => (await vite.ssrLoadModule(VIRTUAL_RENDER)).render(...args),\n runLoader: async (...args: any[]) => (await vite.ssrLoadModule(VIRTUAL_RENDER)).runLoader(...args),\n}\n\nconst apiModule = {\n handleApiRequest: async (...args: any[]) => (await vite.ssrLoadModule(VIRTUAL_API)).handleApiRequest(...args),\n}\n\nconst app = new Hono()\n\nregisterApiRoutes(app, {renderModule, apiModule})\n\napp.get('*', async (c) => {\n try {\n const {html, statusCode, headers} = await renderModule.render(c.req.url, c.req.raw, {loaderTimeout: parseDuration(config.loaderTimeout ?? 10_000)})\n\n const cssUrls = await collectCss(vite)\n const cssLinks = cssUrls.map(url => `<link rel=\"stylesheet\" href=\"${url}\">`).join('\\n')\n\n const htmlWithCss = cssLinks ? html.replace('</head>', `${cssLinks}\\n</head>`) : html\n const transformed = await vite.transformIndexHtml(c.req.url, `<!DOCTYPE html>${htmlWithCss}`)\n\n const res = c.html(transformed, statusCode)\n for (const [key, value] of Object.entries(headers as Record<string, string>)) {\n res.headers.set(key, value)\n }\n return res\n } catch (e) {\n vite.ssrFixStacktrace(e as Error)\n console.error(e)\n return c.text('Internal Server Error', 500)\n }\n})\n\nconst honoHandler = getRequestListener(app.fetch)\n\ncreateServer(async (req, res) => {\n await new Promise<void>(resolve => vite.middlewares(req, res, resolve))\n if (!res.writableEnded) await honoHandler(req, res)\n}).listen(port, host, () => {\n printDevBanner(port)\n})\n\nexport {}", "import {writeFileSync} from 'node:fs'\nimport {resolve} from 'node:path'\nimport {build} from 'vite'\nimport type {DevixConfig} from '../config'\nimport {devix} from '../vite'\nimport {parseDuration} from '../utils/duration'\n\nconst config: DevixConfig = (await import(`${process.cwd()}/devix.config.ts`)).default\nconst baseConfig = devix(config)\n\nawait build({\n ...baseConfig,\n configFile: false,\n build: {\n outDir: 'dist/client',\n manifest: true,\n rolldownOptions: {\n input: 'virtual:devix/entry-client',\n },\n },\n})\n\nawait build({\n ...baseConfig,\n configFile: false,\n build: {\n ssr: true,\n outDir: 'dist/server',\n rolldownOptions: {\n input: {\n render: 'virtual:devix/render',\n api: 'virtual:devix/api',\n },\n },\n },\n})\n\nconst runtimeConfig = {\n port: config.port ?? 3000,\n host: config.host ?? false,\n loaderTimeout: parseDuration(config.loaderTimeout ?? 10_000),\n output: config.output ?? 'server',\n}\n\nwriteFileSync(\n resolve(process.cwd(), 'dist/devix.config.json'),\n JSON.stringify(runtimeConfig, null, 2),\n 'utf-8'\n)\n\n\nexport {}", "import {readFileSync, mkdirSync, writeFileSync} from 'node:fs'\nimport {resolve, join} from 'node:path'\nimport type {Manifest} from 'vite'\nimport type {DevixConfig} from '../config'\n\nconst userConfig: DevixConfig = (await import(`${process.cwd()}/devix.config.ts`)).default\nif (userConfig.output !== 'static') {\n console.warn('[devix] Tip: set output: \"static\" in devix.config.ts to skip the SSR server at runtime.')\n}\n\nawait import('./build.js')\n\nconst t = Date.now()\nconst renderModule = await import(resolve(process.cwd(), 'dist/server/render.js') + `?t=${t}`)\n\nconst manifest: Manifest = JSON.parse(\n readFileSync(resolve(process.cwd(), 'dist/client/.vite/manifest.json'), 'utf-8')\n)\n\nconst urls: string[] = await renderModule.getStaticRoutes()\n\nconsole.log(`[devix] Generating ${urls.length} static page${urls.length === 1 ? '' : 's'}...`)\n\nfor (const url of urls) {\n const fullUrl = `http://localhost${url}`\n const {html, statusCode} = await renderModule.render(fullUrl, new Request(fullUrl), {manifest})\n\n if (statusCode !== 200) {\n console.warn(`[devix] Skipping ${url} \u2014 status ${statusCode}`)\n continue\n }\n\n const outPath = url === '/'\n ? join(process.cwd(), 'dist/client/index.html')\n : join(process.cwd(), 'dist/client', url, 'index.html')\n\n mkdirSync(join(outPath, '..'), {recursive: true})\n writeFileSync(outPath, `<!DOCTYPE html>${html}`, 'utf-8')\n console.log(` \u2713 ${url}`)\n}\n\nconsole.log('[devix] Generation complete.')\n\nexport {}\n", "import {readFileSync} from 'node:fs'\nimport {serve} from '@hono/node-server'\nimport {serveStatic} from '@hono/node-server/serve-static'\nimport {Hono} from 'hono'\nimport {resolve} from 'node:path'\nimport type {Manifest} from 'vite'\nimport {registerApiRoutes, registerSsrRoute} from '../server/routes'\nimport {loadDotenv} from '../utils/env'\n\nloadDotenv('production')\n\nlet renderModule: any\nlet apiModule: any\nlet manifest: Manifest\nlet runtimeConfig: { port: number, host: string | boolean, loaderTimeout: number, output: 'server' | 'static' }\n\ntry {\n runtimeConfig = JSON.parse(readFileSync(resolve(process.cwd(), 'dist/devix.config.json'), 'utf-8'))\n if (runtimeConfig.output !== 'static') {\n renderModule = await import(resolve(process.cwd(), 'dist/server/render.js'))\n apiModule = await import(resolve(process.cwd(), 'dist/server/api.js'))\n }\n manifest = JSON.parse(readFileSync(resolve(process.cwd(), 'dist/client/.vite/manifest.json'), 'utf-8'))\n} catch {\n console.error('[devix] Build not found. Run \"devix build\" first.')\n process.exit(1)\n}\n\nconst port = Number(process.env.PORT) || runtimeConfig!.port || 3000\nconst host = typeof runtimeConfig!.host === 'string'\n ? runtimeConfig!.host\n : runtimeConfig!.host ? '0.0.0.0' : (process.env.HOST || '0.0.0.0')\n\nconst app = new Hono()\n\napp.use('/*', serveStatic({\n root: './dist/client',\n onFound: (_path, c) => {\n c.header('Cache-Control', _path.includes('/assets/')\n ? 'public, immutable, max-age=31536000'\n : 'no-cache')\n }\n}))\n\nif (runtimeConfig!.output === 'static') {\n console.log('[devix] Static mode \u2014 serving pre-generated files from dist/client')\n} else {\n registerApiRoutes(app, {renderModule, apiModule, manifest})\n registerSsrRoute(app, {renderModule, apiModule, manifest, loaderTimeout: runtimeConfig!.loaderTimeout})\n}\n\nserve({fetch: app.fetch, port, hostname: host}, (info) => console.log(`http://${info.address}:${info.port}`))\n\nexport {}", "#!/usr/bin/env node\nimport {readFileSync} from 'node:fs'\nimport {join, dirname} from 'node:path'\nimport {fileURLToPath} from 'node:url'\n\nconst command = process.argv[2]\n\nswitch (command) {\n case 'dev':\n await import(\"./dev.js\")\n break\n case \"build\":\n await import(\"./build.js\")\n break\n case \"generate\":\n await import(\"./generate.js\")\n break\n case \"start\":\n await import(\"./start.js\")\n break\n case '--version':\n case '-v': {\n const pkg = JSON.parse(readFileSync(join(dirname(fileURLToPath(import.meta.url)), '../../package.json'), 'utf-8'))\n console.log(pkg.version)\n break\n }\n case '--help':\n case '-h':\n console.log(`\ndevix \u2014 a lightweight SSR framework\n\nUsage:\n devix dev Start development server\n devix build Build for production\n devix generate Build and generate static HTML (SSG)\n devix start Start production server\n\nOptions:\n -v, --version Show version\n -h, --help Show this help\n\nOutput modes (set in devix.config.ts):\n output: \"server\" SSR mode \u2014 devix start handles requests dynamically (default)\n output: \"static\" SSG mode \u2014 devix generate pre-renders all pages; devix start serves static files only\n `.trim())\n break\n default:\n console.error(`Unknown command: ${command}`)\n console.error('Usage: devix <dev|build|generate|start>')\n process.exit(1)\n}\n\nexport {}"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["cache", "readFileSync", "join", "config", "app", "apiModule", "renderModule", "manifest", "port", "vite", "VIRTUAL_RENDER", "VIRTUAL_API", "resolve", "writeFileSync", "resolve", "config", "readFileSync", "mkdirSync", "writeFileSync", "resolve", "join", "renderModule", "readFileSync", "Hono", "resolve", "renderModule", "apiModule", "manifest", "runtimeConfig", "port", "host", "app", "readFileSync", "join", "dirname", "fileURLToPath"]
|
|
4
|
+
"sourcesContent": ["interface EntryClientOptions {\n cssUrls: string[]\n}\n\nexport function generateEntryClient({cssUrls}: EntryClientOptions): string {\n const cssImports = cssUrls.map(u => `import '${u}'`).join('\\n')\n\n return `\n${cssImports}\nimport \"@vitejs/plugin-react/preamble\"\nimport React from \"react\"\nimport {hydrateRoot, createRoot} from 'react-dom/client'\nimport {matchClientRoute, loadErrorPage, getDefaultErrorPage} from 'virtual:devix/client-routes'\nimport {RouterProvider} from '@devlusoft/devix'\n\nconst root = document.getElementById('devix-root')\n\nif (!window.__DEVIX__) {\n const ErrorPage = getDefaultErrorPage()\n createRoot(root).render(React.createElement(ErrorPage, {statusCode: 500, message: 'Server error'}))\n} else {\n const {metadata, viewport, clientEntry} = window.__DEVIX__\n const loaderData = window.__LOADER_DATA__\n const layoutsData = window.__LAYOUTS_DATA__ ?? []\n\n const matched = matchClientRoute(window.location.pathname)\n\n if (matched) {\n const [pageMod, ...layoutMods] = await Promise.all([\n matched.load(),\n ...matched.loadLayouts.map(l => l()),\n ])\n hydrateRoot(\n root,\n React.createElement(RouterProvider, {\n clientEntry,\n initialData: loaderData,\n initialParams: matched.params,\n initialPage: pageMod.default,\n initialLayouts: layoutMods.map(m => m.default),\n initialLayoutsData: layoutsData,\n initialMeta: metadata,\n initialViewport: viewport,\n })\n )\n } else {\n const ErrorPage = await loadErrorPage() ?? getDefaultErrorPage()\n createRoot(root).render(\n React.createElement(RouterProvider, {\n clientEntry,\n initialData: null,\n initialParams: {},\n initialPage: () => null,\n initialLayouts: [],\n initialLayoutsData: [],\n initialMeta: null,\n initialError: {statusCode: 404, message: 'Not found'},\n initialErrorPage: ErrorPage,\n })\n )\n }\n}\n`\n}", "interface ClientRoutesOptions {\n pagesDir: string\n matcherPath: string\n}\n\nexport function generateClientRoutes({pagesDir, matcherPath}: ClientRoutesOptions) {\n return `\nimport React from 'react'\nimport { createMatcher } from '${matcherPath}'\nconst pageFiles = import.meta.glob(['/${pagesDir}/**/*.tsx', '!**/error.tsx', '!**/layout.tsx'])\nconst layoutFiles = import.meta.glob('/${pagesDir}/**/layout.tsx')\nconst errorFiles = import.meta.glob('/${pagesDir}/**/error.tsx')\n\nexport const matchClientRoute = createMatcher(pageFiles, layoutFiles)\n\nexport async function loadErrorPage() {\n const key = Object.keys(errorFiles)[0]\n if (!key) return null\n const mod = await errorFiles[key]()\n return mod?.default ?? null\n}\n\nexport function getDefaultErrorPage() {\n return function DefaultError({ statusCode, message }) {\n return React.createElement('main', {\n style: { minHeight: '100dvh', display: 'flex', flexDirection: 'column', \n alignItems: 'center', justifyContent: 'center', gap: '8px',\n fontFamily: 'system-ui, sans-serif' }\n },\n React.createElement('h1', {style: {fontSize: '4rem', fontWeight: 700}}, statusCode),\n React.createElement('p', {style: {color: '#666'}}, message ?? 'An unexpected error occurred'),\n )\n }\n}\n`\n}", "interface RenderOptions {\n pagesDir: string\n renderPath: string\n}\n\nexport function generateRender({pagesDir, renderPath}: RenderOptions): string {\n return `\nimport { render as _render, runLoader as _runLoader, getStaticRoutes as _getStaticRoutes } from '${renderPath}'\n\nconst _pages = import.meta.glob(['/${pagesDir}/**/*.tsx', '!**/error.tsx', '!**/layout.tsx'])\nconst _layouts = import.meta.glob('/${pagesDir}/**/layout.tsx')\n\nconst _glob = {\n pages: _pages,\n layouts: _layouts,\n pagesDir: '/${pagesDir}',\n}\n\nexport function render(url, request, options) {\n return _render(url, request, _glob, options)\n}\n\nexport function runLoader(url, request, options) {\n return _runLoader(url, request, _glob, options)\n}\n\nexport function getStaticRoutes() {\n return _getStaticRoutes(_glob)\n}\n`\n}\n", "interface ApiOptions {\n apiPath: string\n appDir: string\n}\n\nexport function generateApi({apiPath, appDir}: ApiOptions): string {\n return `\nimport { handleApiRequest as _handleApiRequest } from '${apiPath}'\n\nconst _routes = import.meta.glob(['/${appDir}/api/**/*.ts', '!**/middleware.ts'])\nconst _middlewares = import.meta.glob('/${appDir}/api/**/middleware.ts')\n\nconst _glob = {\n routes: _routes,\n middlewares: _middlewares,\n apiDir: '/${appDir}/api',\n}\n\nexport function handleApiRequest(url, request) {\n return _handleApiRequest(url, request, _glob)\n}\n`\n}\n", "export function routePattern(rel: string): string {\n return rel\n .replace(/\\.(tsx|ts|jsx|js)$/, '')\n .replace(/\\(.*?\\)\\//g, '')\n .replace(/^index$|\\/index$/, '')\n .replace(/\\[([^\\]]+)]/g, ':$1')\n || '/'\n}", "import {routePattern} from \"../utils/patterns\";\n\nexport interface Page {\n path: string\n key: string\n params: string[]\n regex: RegExp\n}\n\nexport interface Layout {\n dir: string\n key: string\n}\n\nexport interface PagesResult {\n pages: Page[]\n layouts: Layout[]\n}\n\nfunction keyToRoutePattern(key: string, pagesDir: string): string {\n const rel = key.slice(pagesDir.length + 1).replace(/\\\\/g, '/')\n const pattern = routePattern(rel)\n return pattern === \"/\" ? \"/\" : `/${pattern}`\n}\n\nfunction keyToDir(key: string): string {\n return key.slice(0, key.lastIndexOf('/'))\n}\n\nlet cache: PagesResult | null = null\n\nexport function invalidatePagesCache() {\n cache = null\n}\n\nexport function buildPages(pageKeys: string[], layoutKeys: string[], pagesDir: string): PagesResult {\n if (cache) return cache\n\n const pages: Page[] = []\n const layouts: Layout[] = []\n\n for (const key of layoutKeys) {\n layouts.push({dir: keyToDir(key), key})\n }\n\n for (const key of pageKeys) {\n const pattern = keyToRoutePattern(key, pagesDir)\n const params = [...pattern.matchAll(/:([^/]+)/g)].map(m => m[1])\n const regexStr = pattern\n .replace(/:[^/]+/g, '([^/]+)')\n .replace(/\\//g, '\\\\/')\n pages.push({path: pattern, key, params, regex: new RegExp(`^${regexStr}$`)})\n }\n\n pages.sort((a, b) => {\n const aScore = (a.path.match(/:/g) || []).length\n const bScore = (b.path.match(/:/g) || []).length\n if (aScore !== bScore) return aScore - bScore\n return b.path.length - a.path.length\n })\n\n cache = {pages, layouts}\n return cache\n}\n\nexport function collectLayoutChain(pageKey: string, layouts: Layout[]): Layout[] {\n const pageDir = keyToDir(pageKey)\n\n return layouts\n .filter(layout => pageDir.startsWith(layout.dir))\n .sort((a, b) => a.dir.split('/').length - b.dir.split('/').length)\n}\n\nexport function matchPage(pathname: string, pages: Page[]): {\n page: Page\n params: Record<string, string>\n} | null {\n for (const page of pages) {\n const match = pathname.match(page.regex)\n if (match) {\n const params: Record<string, string> = {}\n page.params.forEach((name, i) => {\n params[name] = decodeURIComponent(match[i + 1])\n })\n return {page, params}\n }\n }\n return null\n}\n", "import {routePattern} from \"../utils/patterns\";\n\nexport interface ApiRoute {\n path: string\n key: string\n params: string[]\n regex: RegExp\n}\n\nexport interface ApiMiddleware {\n dir: string\n key: string\n}\n\nexport interface ApiResult {\n routes: ApiRoute[]\n middlewares: ApiMiddleware[]\n}\n\nexport function keyToRoutePattern(key: string, apiDir: string): string {\n const rel = key.slice(apiDir.length + 1).replace(/\\\\/g, '/')\n const pattern = routePattern(rel)\n return pattern === '/' ? '/api' : `/api/${pattern}`.replace('/api//', '/api/')\n}\n\nfunction keyToDir(key: string): string {\n return key.slice(0, key.lastIndexOf('/'))\n}\n\nlet cache: ApiResult | null = null\n\nexport function invalidateApiCache() {\n cache = null\n}\n\nexport function buildRoutes(routeKeys: string[], middlewareKeys: string[], apiDir: string): ApiResult {\n if (cache) return cache\n\n const routes: ApiRoute[] = []\n const middlewares: ApiMiddleware[] = []\n\n for (const key of middlewareKeys) {\n middlewares.push({dir: keyToDir(key), key})\n }\n\n for (const key of routeKeys) {\n const pattern = keyToRoutePattern(key, apiDir)\n const params = [...pattern.matchAll(/:([^/]+)/g)].map(m => m[1])\n const regexStr = pattern\n .replace(/:[^/]+/g, '([^/]+)')\n .replace(/\\//g, '\\\\/')\n routes.push({path: pattern, key, params, regex: new RegExp(`^${regexStr}$`)})\n }\n routes.sort((a, b) => {\n const aScore = (a.path.match(/:/g) || []).length\n const bScore = (b.path.match(/:/g) || []).length\n if (aScore !== bScore) return aScore - bScore\n return b.path.length - a.path.length\n })\n\n cache = {routes, middlewares}\n return cache\n}\n\nexport function collectMiddlewareChain(routeKey: string, middlewares: ApiMiddleware[]): ApiMiddleware[] {\n const routeDir = keyToDir(routeKey)\n\n return middlewares\n .filter(mw => routeDir.startsWith(mw.dir))\n .sort((a, b) => a.dir.split('/').length - b.dir.split('/').length)\n}\n\nexport function matchRoute(\n pathname: string,\n routes: ApiRoute[]\n): {route: ApiRoute; params: Record<string, string>} | null {\n for (const route of routes) {\n const match = pathname.match(route.regex)\n if (match) {\n const params: Record<string, string> = {}\n route.params.forEach((name, i) => {\n params[name] = decodeURIComponent(match[i + 1])\n })\n return {route, params}\n }\n }\n return null\n}\n", "export function generateContext(): string {\n return `\nexport {RouterContext} from '@devlusoft/devix/runtime/context'\n`\n}", "const HTTP_METHODS = ['GET', 'POST', 'PUT', 'PATCH', 'DELETE', 'HEAD', 'OPTIONS'] as const\nexport type HttpMethod = (typeof HTTP_METHODS)[number]\n\nconst METHOD_EXPORT_RE = /export\\s+(?:const|async\\s+function|function)\\s+(GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS)\\b/g\n\nfunction stripComments(content: string): string {\n return content\n .replace(/\\/\\*[\\s\\S]*?\\*\\//g, '')\n .replace(/\\/\\/.*$/gm, '')\n}\n\nexport function extractHttpMethods(content: string): HttpMethod[] {\n const found = new Set<HttpMethod>()\n for (const match of stripComments(content).matchAll(METHOD_EXPORT_RE)) {\n found.add(match[1] as HttpMethod)\n }\n return [...found]\n}\n", "import { keyToRoutePattern } from '../../server/api-router'\nimport type { HttpMethod } from './extract-methods'\n\nexport interface RouteEntry {\n filePath: string\n urlPattern: string\n identifier: string\n methods: HttpMethod[]\n}\n\nexport function filePathToIdentifier(filePath: string, apiDir: string): string {\n return '_api_' + filePath\n .slice(`${apiDir}/`.length)\n .replace(/\\.(ts|tsx)$/, '')\n .replace(/[^a-zA-Z0-9]/g, '_')\n}\n\nexport function buildRouteEntry(filePath: string, apiDir: string, methods: HttpMethod[]): RouteEntry {\n return {\n filePath,\n urlPattern: keyToRoutePattern(filePath, apiDir),\n identifier: filePathToIdentifier(filePath, apiDir),\n methods,\n }\n}\n\nexport function generateRoutesDts(entries: RouteEntry[], apiDir: string): string {\n if (entries.length === 0) {\n return `// auto-generado por devix \u2014 no editar\\ndeclare module '@devlusoft/devix' {\\n interface ApiRoutes {}\\n}\\n`\n }\n\n const imports = entries\n .map(e => {\n const importPath = '../' + e.filePath.replace(/\\.(ts|tsx)$/, '')\n return `import type * as ${e.identifier} from '${importPath}'`\n })\n .join('\\n')\n\n const routeLines = entries.flatMap(e =>\n e.methods.map(m =>\n ` '${m} ${e.urlPattern}': InferRoute<(typeof ${e.identifier})['${m}']>`\n )\n ).join('\\n')\n\n return `// auto-generado por devix \u2014 no editar\n${imports}\n\ntype JsonResponse<T> = Response & { readonly __body: T }\ntype InferRoute<T> = T extends (...args: any[]) => any\n ? Awaited<ReturnType<T>> extends JsonResponse<infer U>\n ? U\n : Exclude<Awaited<ReturnType<T>>, Response | null | void>\n : never\n\ndeclare module '@devlusoft/devix' {\n interface ApiRoutes {\n${routeLines}\n }\n}\n`\n}\n", "import {readFileSync, readdirSync, statSync} from 'node:fs'\nimport {join, relative} from 'node:path'\nimport {extractHttpMethods} from './extract-methods'\nimport {buildRouteEntry} from './routes-dts'\nimport type {RouteEntry} from './routes-dts'\n\nfunction walkDir(dir: string, root: string): string[] {\n const entries: string[] = []\n for (const name of readdirSync(dir)) {\n const full = join(dir, name)\n if (statSync(full).isDirectory()) {\n entries.push(...walkDir(full, root))\n } else if (/\\.(ts|tsx)$/.test(name)) {\n entries.push(relative(root, full).replace(/\\\\/g, '/'))\n }\n }\n return entries\n}\n\nexport function scanApiFiles(appDir: string, projectRoot: string): RouteEntry[] {\n const apiDir = join(projectRoot, appDir, 'api')\n\n let files: string[]\n try {\n files = walkDir(apiDir, projectRoot)\n } catch {\n return []\n }\n\n return files\n .filter(f => !f.endsWith('middleware.ts') && !f.endsWith('middleware.tsx'))\n .flatMap(filePath => {\n try {\n const content = readFileSync(join(projectRoot, filePath), 'utf-8')\n const methods = extractHttpMethods(content)\n if (methods.length === 0) return []\n return [buildRouteEntry(filePath, `${appDir}/api`, methods)]\n } catch {\n return []\n }\n })\n}\n", "import {mkdirSync, readFileSync, writeFileSync, existsSync} from 'node:fs'\nimport {join} from 'node:path'\n\nexport function writeRoutesDts(content: string, projectRoot: string): boolean {\n const devixDir = join(projectRoot, '.devix')\n const outPath = join(devixDir, 'routes.d.ts')\n\n mkdirSync(devixDir, {recursive: true})\n\n if (existsSync(outPath) && readFileSync(outPath, 'utf-8') === content) {\n return false\n }\n\n writeFileSync(outPath, content, 'utf-8')\n return true\n}\n", "import {UserConfig, Plugin, mergeConfig} from 'vite'\nimport type {DevixConfig} from '../config'\nimport react from '@vitejs/plugin-react'\nimport {fileURLToPath} from 'node:url'\nimport {dirname, resolve} from 'node:path'\nimport {generateEntryClient} from './codegen/entry-client'\nimport {generateClientRoutes} from './codegen/client-routes'\nimport {generateRender} from './codegen/render'\nimport {generateApi} from './codegen/api'\nimport {invalidatePagesCache} from \"../server/pages-router\";\nimport {invalidateApiCache} from \"../server/api-router\";\nimport {generateContext} from \"./codegen/context\";\nimport {scanApiFiles} from \"./codegen/scan-api\";\nimport {generateRoutesDts} from \"./codegen/routes-dts\";\nimport {writeRoutesDts} from \"./codegen/write-routes-dts\";\n\nconst __dirname = dirname(fileURLToPath(import.meta.url))\n\nconst VIRTUAL_ENTRY_CLIENT = 'virtual:devix/entry-client'\nconst VIRTUAL_CLIENT_ROUTES = 'virtual:devix/client-routes'\nconst VIRTUAL_RENDER = 'virtual:devix/render'\nconst VIRTUAL_API = 'virtual:devix/api'\nconst VIRTUAL_CONTEXT = 'virtual:devix/context'\n\nexport function devix(config: DevixConfig): UserConfig {\n const appDir = config.appDir ?? 'app'\n const pagesDir = `${appDir}/pages`\n const cssUrls = (config.css ?? []).map(u => u.startsWith('/') ? u : `/${u.replace(/^\\.\\//, '')}`)\n\n const renderPath = resolve(__dirname, '../server/render.js').replace(/\\\\/g, '/')\n const apiPath = resolve(__dirname, '../server/api.js').replace(/\\\\/g, '/')\n const matcherPath = resolve(__dirname, '../runtime/client-router.js').replace(/\\\\/g, '/')\n\n const virtualPlugin: Plugin = {\n name: 'devix',\n enforce: 'pre',\n\n resolveId(id) {\n if (id === VIRTUAL_ENTRY_CLIENT) return `\\0${VIRTUAL_ENTRY_CLIENT}`\n if (id === VIRTUAL_CLIENT_ROUTES) return `\\0${VIRTUAL_CLIENT_ROUTES}`\n if (id === VIRTUAL_RENDER) return `\\0${VIRTUAL_RENDER}`\n if (id === VIRTUAL_API) return `\\0${VIRTUAL_API}`\n if (id === VIRTUAL_CONTEXT) return `\\0${VIRTUAL_CONTEXT}`\n },\n\n load(id) {\n if (id === `\\0${VIRTUAL_ENTRY_CLIENT}`)\n return generateEntryClient({cssUrls})\n if (id === `\\0${VIRTUAL_CLIENT_ROUTES}`)\n return generateClientRoutes({pagesDir, matcherPath})\n if (id === `\\0${VIRTUAL_RENDER}`)\n return generateRender({pagesDir, renderPath})\n if (id === `\\0${VIRTUAL_API}`)\n return generateApi({apiPath, appDir})\n if (id === `\\0${VIRTUAL_CONTEXT}`)\n return generateContext()\n },\n\n buildStart() {\n const root = process.cwd()\n const entries = scanApiFiles(appDir, root)\n writeRoutesDts(generateRoutesDts(entries, `${appDir}/api`), root)\n },\n\n configureServer(server) {\n const root = process.cwd()\n\n const regenerateDts = () => {\n const entries = scanApiFiles(appDir, root)\n writeRoutesDts(generateRoutesDts(entries, `${appDir}/api`), root)\n }\n\n server.watcher.on('add', (file) => {\n if (file.startsWith(resolve(root, pagesDir))) invalidatePagesCache()\n if (file.includes(`${appDir}/api`)) { invalidateApiCache(); regenerateDts() }\n })\n server.watcher.on('unlink', (file) => {\n if (file.startsWith(resolve(root, pagesDir))) invalidatePagesCache()\n if (file.includes(`${appDir}/api`)) { invalidateApiCache(); regenerateDts() }\n })\n server.watcher.on('change', (file) => {\n if (file.includes(`${appDir}/api`) && !file.endsWith('middleware.ts')) {\n regenerateDts()\n }\n })\n },\n }\n\n const base: UserConfig = {\n plugins: [react(), virtualPlugin],\n ssr: {noExternal: ['@devlusoft/devix']},\n ...(config.envPrefix ? {envPrefix: config.envPrefix} : {}),\n }\n\n return mergeConfig(base, config.vite ?? {})\n}", "import type {Hono} from 'hono'\nimport type {Manifest} from 'vite'\n\ninterface ServerOptions {\n renderModule: any\n apiModule: any\n manifest?: Manifest\n loaderTimeout?: number\n}\n\nexport function registerApiRoutes(app: Hono, {apiModule, renderModule, loaderTimeout}: ServerOptions) {\n app.all('/api/*', async (c) => {\n try {\n return await apiModule.handleApiRequest(c.req.url, c.req.raw)\n } catch (e) {\n console.error(e)\n return c.json({error: 'internal error'}, 500)\n }\n })\n\n app.get('/_data/*', async (c) => {\n try {\n const {pathname, search} = new URL(c.req.url, 'http://localhost')\n const url = pathname.replace(/^\\/_data/, '') + search\n\n const data = await renderModule.runLoader(url, c.req.raw, {loaderTimeout})\n return c.json(data)\n } catch (e) {\n console.error(e)\n return c.json({error: 'internal error'}, 500)\n }\n })\n}\n\nexport function registerSsrRoute(app: Hono, {renderModule, manifest, loaderTimeout}: ServerOptions) {\n app.get('*', async (c) => {\n try {\n const {html, statusCode, headers} = await renderModule.render(c.req.url, c.req.raw, {manifest, loaderTimeout})\n const res = c.html(`<!DOCTYPE html>${html}`, statusCode)\n for (const [key, value] of Object.entries(headers as Record<string, string>)) {\n res.headers.set(key, value)\n }\n return res\n } catch (e) {\n console.error(e)\n return c.text('Internal Server Error', 500)\n }\n })\n}", "import pc from 'picocolors'\nimport {networkInterfaces} from 'node:os'\nimport {createRequire} from 'node:module'\n\nfunction getNetworkUrl(port: number): string | null {\n const nets = networkInterfaces()\n for (const interfaces of Object.values(nets)) {\n for (const net of interfaces ?? []) {\n if (net.family === 'IPv4' && !net.internal) {\n return `http://${net.address}:${port}/`\n }\n }\n }\n return null\n}\n\nexport function printDevBanner(port: number) {\n const req = createRequire(import.meta.url)\n const version = req('../../package.json').version\n const networkUrl = getNetworkUrl(port)\n\n console.log()\n console.log(` ${pc.bold(pc.yellow('devix'))} ${pc.dim(`v${version}`)}`)\n console.log()\n console.log(` ${pc.green('\u279C')} ${pc.bold('Local:')} ${pc.cyan(`http://localhost:${port}/`)}`)\n if (networkUrl) {\n console.log(` ${pc.green('\u279C')} ${pc.bold('Network:')} ${pc.cyan(networkUrl)}`)\n } else {\n console.log(` ${pc.green('\u279C')} ${pc.bold('Network:')} ${pc.dim('use --host to expose')}`)\n }\n console.log()\n}", "import type {ViteDevServer} from 'vite'\n\nexport async function collectCss(vite: ViteDevServer): Promise<string[]> {\n const cssUrls = new Set<string>()\n\n for (const [, mod] of vite.moduleGraph.idToModuleMap) {\n if (!mod.id) continue\n if (mod.id.endsWith('.css') || mod.id.includes('.css?')) {\n cssUrls.add(mod.url)\n }\n }\n\n return [...cssUrls]\n}", "export function parseDuration(value: number | string): number {\n if (typeof value === 'number') return value\n const match = value.trim().match(/^(\\d+(?:\\.\\d+)?)\\s*(ms|s|m|h)?$/)\n if (!match) throw new Error(`[devix] Invalid duration: \"${value}\". Use a number (ms) or a string like \"5s\", \"2m\", \"500ms\".`)\n const n = parseFloat(match[1])\n switch (match[2]) {\n case 'h': return n * 3_600_000\n case 'm': return n * 60_000\n case 's': return n * 1_000\n case 'ms':\n default: return n\n }\n}\n", "import {loadEnv} from 'vite'\n\nexport function loadDotenv(mode: string) {\n const env = loadEnv(mode, process.cwd(), '')\n for (const [key, value] of Object.entries(env)) {\n if (process.env[key] === undefined) {\n process.env[key] = value\n }\n }\n}\n", "import {createServer} from 'node:http'\nimport {createServer as createViteServer} from 'vite'\nimport {getRequestListener} from '@hono/node-server'\nimport {Hono} from 'hono'\nimport type {DevixConfig} from '../config'\nimport {devix} from '../vite'\nimport {registerApiRoutes} from '../server/routes'\nimport {printDevBanner} from \"../utils/banner\";\nimport {collectCss} from \"../server/collect-css\";\nimport {parseDuration} from \"../utils/duration\";\nimport {loadDotenv} from \"../utils/env\";\n\nloadDotenv('development')\n\nconst VIRTUAL_RENDER = 'virtual:devix/render'\nconst VIRTUAL_API = 'virtual:devix/api'\n\nconst config: DevixConfig = (await import(`${process.cwd()}/devix.config.ts`)).default\nconst port = Number(process.env.PORT) || config.port || 3000\nconst host = typeof config.host === 'string' ? config.host : config.host ? '0.0.0.0' : 'localhost'\n\nconst vite = await createViteServer({\n ...devix(config),\n configFile: false,\n appType: 'custom',\n server: {middlewareMode: true},\n})\n\nconst renderModule = {\n render: async (...args: any[]) => (await vite.ssrLoadModule(VIRTUAL_RENDER)).render(...args),\n runLoader: async (...args: any[]) => (await vite.ssrLoadModule(VIRTUAL_RENDER)).runLoader(...args),\n}\n\nconst apiModule = {\n handleApiRequest: async (...args: any[]) => (await vite.ssrLoadModule(VIRTUAL_API)).handleApiRequest(...args),\n}\n\nconst app = new Hono()\n\nregisterApiRoutes(app, {renderModule, apiModule})\n\napp.get('*', async (c) => {\n try {\n const {html, statusCode, headers} = await renderModule.render(c.req.url, c.req.raw, {loaderTimeout: parseDuration(config.loaderTimeout ?? 10_000)})\n\n const cssUrls = await collectCss(vite)\n const cssLinks = cssUrls.map(url => `<link rel=\"stylesheet\" href=\"${url}\">`).join('\\n')\n\n const htmlWithCss = cssLinks ? html.replace('</head>', `${cssLinks}\\n</head>`) : html\n const transformed = await vite.transformIndexHtml(c.req.url, `<!DOCTYPE html>${htmlWithCss}`)\n\n const res = c.html(transformed, statusCode)\n for (const [key, value] of Object.entries(headers as Record<string, string>)) {\n res.headers.set(key, value)\n }\n return res\n } catch (e) {\n vite.ssrFixStacktrace(e as Error)\n console.error(e)\n return c.text('Internal Server Error', 500)\n }\n})\n\nconst honoHandler = getRequestListener(app.fetch)\n\ncreateServer(async (req, res) => {\n await new Promise<void>(resolve => vite.middlewares(req, res, resolve))\n if (!res.writableEnded) await honoHandler(req, res)\n}).listen(port, host, () => {\n printDevBanner(port)\n})\n\nexport {}", "import {writeFileSync} from 'node:fs'\nimport {resolve} from 'node:path'\nimport {build} from 'vite'\nimport type {DevixConfig} from '../config'\nimport {devix} from '../vite'\nimport {parseDuration} from '../utils/duration'\n\nconst config: DevixConfig = (await import(`${process.cwd()}/devix.config.ts`)).default\nconst baseConfig = devix(config)\n\nawait build({\n ...baseConfig,\n configFile: false,\n build: {\n outDir: 'dist/client',\n manifest: true,\n rolldownOptions: {\n input: 'virtual:devix/entry-client',\n },\n },\n})\n\nawait build({\n ...baseConfig,\n configFile: false,\n build: {\n ssr: true,\n outDir: 'dist/server',\n rolldownOptions: {\n input: {\n render: 'virtual:devix/render',\n api: 'virtual:devix/api',\n },\n },\n },\n})\n\nconst runtimeConfig = {\n port: config.port ?? 3000,\n host: config.host ?? false,\n loaderTimeout: parseDuration(config.loaderTimeout ?? 10_000),\n output: config.output ?? 'server',\n}\n\nwriteFileSync(\n resolve(process.cwd(), 'dist/devix.config.json'),\n JSON.stringify(runtimeConfig, null, 2),\n 'utf-8'\n)\n\n\nexport {}", "import {readFileSync, mkdirSync, writeFileSync} from 'node:fs'\nimport {resolve, join} from 'node:path'\nimport type {Manifest} from 'vite'\nimport type {DevixConfig} from '../config'\n\nconst userConfig: DevixConfig = (await import(`${process.cwd()}/devix.config.ts`)).default\nif (userConfig.output !== 'static') {\n console.warn('[devix] Tip: set output: \"static\" in devix.config.ts to skip the SSR server at runtime.')\n}\n\nawait import('./build.js')\n\nconst t = Date.now()\nconst renderModule = await import(resolve(process.cwd(), 'dist/server/render.js') + `?t=${t}`)\n\nconst manifest: Manifest = JSON.parse(\n readFileSync(resolve(process.cwd(), 'dist/client/.vite/manifest.json'), 'utf-8')\n)\n\nconst urls: string[] = await renderModule.getStaticRoutes()\n\nconsole.log(`[devix] Generating ${urls.length} static page${urls.length === 1 ? '' : 's'}...`)\n\nfor (const url of urls) {\n const fullUrl = `http://localhost${url}`\n const {html, statusCode} = await renderModule.render(fullUrl, new Request(fullUrl), {manifest})\n\n if (statusCode !== 200) {\n console.warn(`[devix] Skipping ${url} \u2014 status ${statusCode}`)\n continue\n }\n\n const outPath = url === '/'\n ? join(process.cwd(), 'dist/client/index.html')\n : join(process.cwd(), 'dist/client', url, 'index.html')\n\n mkdirSync(join(outPath, '..'), {recursive: true})\n writeFileSync(outPath, `<!DOCTYPE html>${html}`, 'utf-8')\n console.log(` \u2713 ${url}`)\n}\n\nconsole.log('[devix] Generation complete.')\n\nexport {}\n", "import {readFileSync} from 'node:fs'\nimport {serve} from '@hono/node-server'\nimport {serveStatic} from '@hono/node-server/serve-static'\nimport {Hono} from 'hono'\nimport {resolve} from 'node:path'\nimport type {Manifest} from 'vite'\nimport {registerApiRoutes, registerSsrRoute} from '../server/routes'\nimport {loadDotenv} from '../utils/env'\n\nloadDotenv('production')\n\nlet renderModule: any\nlet apiModule: any\nlet manifest: Manifest\nlet runtimeConfig: { port: number, host: string | boolean, loaderTimeout: number, output: 'server' | 'static' }\n\ntry {\n runtimeConfig = JSON.parse(readFileSync(resolve(process.cwd(), 'dist/devix.config.json'), 'utf-8'))\n if (runtimeConfig.output !== 'static') {\n renderModule = await import(resolve(process.cwd(), 'dist/server/render.js'))\n apiModule = await import(resolve(process.cwd(), 'dist/server/api.js'))\n }\n manifest = JSON.parse(readFileSync(resolve(process.cwd(), 'dist/client/.vite/manifest.json'), 'utf-8'))\n} catch {\n console.error('[devix] Build not found. Run \"devix build\" first.')\n process.exit(1)\n}\n\nconst port = Number(process.env.PORT) || runtimeConfig!.port || 3000\nconst host = typeof runtimeConfig!.host === 'string'\n ? runtimeConfig!.host\n : runtimeConfig!.host ? '0.0.0.0' : (process.env.HOST || '0.0.0.0')\n\nconst app = new Hono()\n\napp.use('/*', serveStatic({\n root: './dist/client',\n onFound: (_path, c) => {\n c.header('Cache-Control', _path.includes('/assets/')\n ? 'public, immutable, max-age=31536000'\n : 'no-cache')\n }\n}))\n\nif (runtimeConfig!.output === 'static') {\n console.log('[devix] Static mode \u2014 serving pre-generated files from dist/client')\n} else {\n registerApiRoutes(app, {renderModule, apiModule, manifest})\n registerSsrRoute(app, {renderModule, apiModule, manifest, loaderTimeout: runtimeConfig!.loaderTimeout})\n}\n\nserve({fetch: app.fetch, port, hostname: host}, (info) => console.log(`http://${info.address}:${info.port}`))\n\nexport {}", "#!/usr/bin/env node\nimport {readFileSync} from 'node:fs'\nimport {join, dirname} from 'node:path'\nimport {fileURLToPath} from 'node:url'\n\nconst command = process.argv[2]\n\nswitch (command) {\n case 'dev':\n await import(\"./dev.js\")\n break\n case \"build\":\n await import(\"./build.js\")\n break\n case \"generate\":\n await import(\"./generate.js\")\n break\n case \"start\":\n await import(\"./start.js\")\n break\n case '--version':\n case '-v': {\n const pkg = JSON.parse(readFileSync(join(dirname(fileURLToPath(import.meta.url)), '../../package.json'), 'utf-8'))\n console.log(pkg.version)\n break\n }\n case '--help':\n case '-h':\n console.log(`\ndevix \u2014 a lightweight SSR framework\n\nUsage:\n devix dev Start development server\n devix build Build for production\n devix generate Build and generate static HTML (SSG)\n devix start Start production server\n\nOptions:\n -v, --version Show version\n -h, --help Show this help\n\nOutput modes (set in devix.config.ts):\n output: \"server\" SSR mode \u2014 devix start handles requests dynamically (default)\n output: \"static\" SSG mode \u2014 devix generate pre-renders all pages; devix start serves static files only\n `.trim())\n break\n default:\n console.error(`Unknown command: ${command}`)\n console.error('Usage: devix <dev|build|generate|start>')\n process.exit(1)\n}\n\nexport {}"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["generateEntryClient", "cssUrls", "u", "init_entry_client", "__esmMin", "generateClientRoutes", "pagesDir", "matcherPath", "init_client_routes", "__esmMin", "generateRender", "pagesDir", "renderPath", "init_render", "__esmMin", "generateApi", "apiPath", "appDir", "init_api", "__esmMin", "routePattern", "rel", "init_patterns", "__esmMin", "invalidatePagesCache", "cache", "init_pages_router", "__esmMin", "init_patterns", "keyToRoutePattern", "key", "apiDir", "rel", "pattern", "routePattern", "invalidateApiCache", "cache", "init_api_router", "__esmMin", "init_patterns", "generateContext", "init_context", "__esmMin", "stripComments", "content", "extractHttpMethods", "found", "match", "METHOD_EXPORT_RE", "init_extract_methods", "__esmMin", "filePathToIdentifier", "filePath", "apiDir", "buildRouteEntry", "methods", "keyToRoutePattern", "generateRoutesDts", "entries", "imports", "e", "importPath", "routeLines", "m", "init_routes_dts", "__esmMin", "init_api_router", "readFileSync", "readdirSync", "statSync", "join", "relative", "walkDir", "dir", "root", "entries", "name", "full", "scanApiFiles", "appDir", "projectRoot", "apiDir", "files", "f", "filePath", "content", "methods", "extractHttpMethods", "buildRouteEntry", "init_scan_api", "__esmMin", "init_extract_methods", "init_routes_dts", "mkdirSync", "readFileSync", "writeFileSync", "existsSync", "join", "writeRoutesDts", "content", "projectRoot", "devixDir", "outPath", "init_write_routes_dts", "__esmMin", "mergeConfig", "react", "fileURLToPath", "dirname", "resolve", "devix", "config", "appDir", "pagesDir", "cssUrls", "u", "renderPath", "__dirname", "apiPath", "matcherPath", "virtualPlugin", "id", "VIRTUAL_ENTRY_CLIENT", "VIRTUAL_CLIENT_ROUTES", "VIRTUAL_RENDER", "VIRTUAL_API", "VIRTUAL_CONTEXT", "generateEntryClient", "generateClientRoutes", "generateRender", "generateApi", "generateContext", "root", "entries", "scanApiFiles", "writeRoutesDts", "generateRoutesDts", "server", "regenerateDts", "file", "invalidatePagesCache", "invalidateApiCache", "base", "init_vite", "__esmMin", "init_entry_client", "init_client_routes", "init_render", "init_api", "init_pages_router", "init_api_router", "init_context", "init_scan_api", "init_routes_dts", "init_write_routes_dts", "registerApiRoutes", "app", "apiModule", "renderModule", "loaderTimeout", "c", "e", "pathname", "search", "url", "data", "registerSsrRoute", "manifest", "html", "statusCode", "headers", "res", "key", "value", "init_routes", "__esmMin", "pc", "networkInterfaces", "createRequire", "getNetworkUrl", "port", "nets", "interfaces", "net", "printDevBanner", "version", "networkUrl", "init_banner", "__esmMin", "collectCss", "vite", "cssUrls", "mod", "init_collect_css", "__esmMin", "parseDuration", "value", "match", "n", "init_duration", "__esmMin", "loadEnv", "loadDotenv", "mode", "env", "key", "value", "init_env", "__esmMin", "dev_exports", "createServer", "createViteServer", "getRequestListener", "Hono", "VIRTUAL_RENDER", "VIRTUAL_API", "config", "port", "host", "vite", "renderModule", "apiModule", "app", "honoHandler", "init_dev", "__esmMin", "init_vite", "init_routes", "init_banner", "init_collect_css", "init_duration", "init_env", "loadDotenv", "devix", "args", "registerApiRoutes", "c", "html", "statusCode", "headers", "parseDuration", "cssLinks", "collectCss", "url", "htmlWithCss", "transformed", "res", "key", "value", "e", "req", "resolve", "printDevBanner", "build_exports", "writeFileSync", "resolve", "build", "config", "baseConfig", "runtimeConfig", "init_build", "__esmMin", "init_vite", "init_duration", "devix", "parseDuration", "generate_exports", "readFileSync", "mkdirSync", "writeFileSync", "resolve", "join", "userConfig", "t", "renderModule", "manifest", "urls", "init_generate", "__esmMin", "url", "fullUrl", "html", "statusCode", "outPath", "start_exports", "readFileSync", "serve", "serveStatic", "Hono", "resolve", "renderModule", "apiModule", "manifest", "runtimeConfig", "port", "host", "app", "init_start", "__esmMin", "init_routes", "init_env", "loadDotenv", "_path", "c", "registerApiRoutes", "registerSsrRoute", "info", "readFileSync", "join", "dirname", "fileURLToPath", "command", "pkg"]
|
|
7
7
|
}
|
package/dist/cli/start.js
CHANGED
|
@@ -1,90 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
import { readFileSync } from "node:fs";
|
|
3
|
-
import { serve } from "@hono/node-server";
|
|
4
|
-
import { serveStatic } from "@hono/node-server/serve-static";
|
|
5
|
-
import { Hono } from "hono";
|
|
6
|
-
import { resolve } from "node:path";
|
|
7
|
-
|
|
8
|
-
// src/server/routes.ts
|
|
9
|
-
function registerApiRoutes(app2, { apiModule: apiModule2, renderModule: renderModule2, loaderTimeout }) {
|
|
10
|
-
app2.all("/api/*", async (c) => {
|
|
11
|
-
try {
|
|
12
|
-
return await apiModule2.handleApiRequest(c.req.url, c.req.raw);
|
|
13
|
-
} catch (e) {
|
|
14
|
-
console.error(e);
|
|
15
|
-
return c.json({ error: "internal error" }, 500);
|
|
16
|
-
}
|
|
17
|
-
});
|
|
18
|
-
app2.get("/_data/*", async (c) => {
|
|
19
|
-
try {
|
|
20
|
-
const { pathname, search } = new URL(c.req.url, "http://localhost");
|
|
21
|
-
const url = pathname.replace(/^\/_data/, "") + search;
|
|
22
|
-
const data = await renderModule2.runLoader(url, c.req.raw, { loaderTimeout });
|
|
23
|
-
return c.json(data);
|
|
24
|
-
} catch (e) {
|
|
25
|
-
console.error(e);
|
|
26
|
-
return c.json({ error: "internal error" }, 500);
|
|
27
|
-
}
|
|
28
|
-
});
|
|
29
|
-
}
|
|
30
|
-
function registerSsrRoute(app2, { renderModule: renderModule2, manifest: manifest2, loaderTimeout }) {
|
|
31
|
-
app2.get("*", async (c) => {
|
|
32
|
-
try {
|
|
33
|
-
const { html, statusCode, headers } = await renderModule2.render(c.req.url, c.req.raw, { manifest: manifest2, loaderTimeout });
|
|
34
|
-
const res = c.html(`<!DOCTYPE html>${html}`, statusCode);
|
|
35
|
-
for (const [key, value] of Object.entries(headers)) {
|
|
36
|
-
res.headers.set(key, value);
|
|
37
|
-
}
|
|
38
|
-
return res;
|
|
39
|
-
} catch (e) {
|
|
40
|
-
console.error(e);
|
|
41
|
-
return c.text("Internal Server Error", 500);
|
|
42
|
-
}
|
|
43
|
-
});
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
// src/utils/env.ts
|
|
47
|
-
import { loadEnv } from "vite";
|
|
48
|
-
function loadDotenv(mode) {
|
|
49
|
-
const env = loadEnv(mode, process.cwd(), "");
|
|
50
|
-
for (const [key, value] of Object.entries(env)) {
|
|
51
|
-
if (process.env[key] === void 0) {
|
|
52
|
-
process.env[key] = value;
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
// src/cli/start.ts
|
|
58
|
-
loadDotenv("production");
|
|
59
|
-
var renderModule;
|
|
60
|
-
var apiModule;
|
|
61
|
-
var manifest;
|
|
62
|
-
var runtimeConfig;
|
|
63
|
-
try {
|
|
64
|
-
runtimeConfig = JSON.parse(readFileSync(resolve(process.cwd(), "dist/devix.config.json"), "utf-8"));
|
|
65
|
-
if (runtimeConfig.output !== "static") {
|
|
66
|
-
renderModule = await import(resolve(process.cwd(), "dist/server/render.js"));
|
|
67
|
-
apiModule = await import(resolve(process.cwd(), "dist/server/api.js"));
|
|
68
|
-
}
|
|
69
|
-
manifest = JSON.parse(readFileSync(resolve(process.cwd(), "dist/client/.vite/manifest.json"), "utf-8"));
|
|
70
|
-
} catch {
|
|
71
|
-
console.error('[devix] Build not found. Run "devix build" first.');
|
|
72
|
-
process.exit(1);
|
|
73
|
-
}
|
|
74
|
-
var port = Number(process.env.PORT) || runtimeConfig.port || 3e3;
|
|
75
|
-
var host = typeof runtimeConfig.host === "string" ? runtimeConfig.host : runtimeConfig.host ? "0.0.0.0" : process.env.HOST || "0.0.0.0";
|
|
76
|
-
var app = new Hono();
|
|
77
|
-
app.use("/*", serveStatic({
|
|
78
|
-
root: "./dist/client",
|
|
79
|
-
onFound: (_path, c) => {
|
|
80
|
-
c.header("Cache-Control", _path.includes("/assets/") ? "public, immutable, max-age=31536000" : "no-cache");
|
|
81
|
-
}
|
|
82
|
-
}));
|
|
83
|
-
if (runtimeConfig.output === "static") {
|
|
84
|
-
console.log("[devix] Static mode \u2014 serving pre-generated files from dist/client");
|
|
85
|
-
} else {
|
|
86
|
-
registerApiRoutes(app, { renderModule, apiModule, manifest });
|
|
87
|
-
registerSsrRoute(app, { renderModule, apiModule, manifest, loaderTimeout: runtimeConfig.loaderTimeout });
|
|
88
|
-
}
|
|
89
|
-
serve({ fetch: app.fetch, port, hostname: host }, (info) => console.log(`http://${info.address}:${info.port}`));
|
|
1
|
+
import{readFileSync as y}from"node:fs";import{serve as b}from"@hono/node-server";import{serveStatic as O}from"@hono/node-server/serve-static";import{Hono as j}from"hono";import{resolve as c}from"node:path";function v(r,{apiModule:s,renderModule:n,loaderTimeout:i}){r.all("/api/*",async e=>{try{return await s.handleApiRequest(e.req.url,e.req.raw)}catch(t){return console.error(t),e.json({error:"internal error"},500)}}),r.get("/_data/*",async e=>{try{let{pathname:t,search:l}=new URL(e.req.url,"http://localhost"),u=t.replace(/^\/_data/,"")+l,a=await n.runLoader(u,e.req.raw,{loaderTimeout:i});return e.json(a)}catch(t){return console.error(t),e.json({error:"internal error"},500)}})}function h(r,{renderModule:s,manifest:n,loaderTimeout:i}){r.get("*",async e=>{try{let{html:t,statusCode:l,headers:u}=await s.render(e.req.url,e.req.raw,{manifest:n,loaderTimeout:i}),a=e.html(`<!DOCTYPE html>${t}`,l);for(let[w,S]of Object.entries(u))a.headers.set(w,S);return a}catch(t){return console.error(t),e.text("Internal Server Error",500)}})}import{loadEnv as x}from"vite";function g(r){let s=x(r,process.cwd(),"");for(let[n,i]of Object.entries(s))process.env[n]===void 0&&(process.env[n]=i)}g("production");var d,m,f,o;try{o=JSON.parse(y(c(process.cwd(),"dist/devix.config.json"),"utf-8")),o.output!=="static"&&(d=await import(c(process.cwd(),"dist/server/render.js")),m=await import(c(process.cwd(),"dist/server/api.js"))),f=JSON.parse(y(c(process.cwd(),"dist/client/.vite/manifest.json"),"utf-8"))}catch{console.error('[devix] Build not found. Run "devix build" first.'),process.exit(1)}var R=Number(process.env.PORT)||o.port||3e3,M=typeof o.host=="string"?o.host:o.host?"0.0.0.0":process.env.HOST||"0.0.0.0",p=new j;p.use("/*",O({root:"./dist/client",onFound:(r,s)=>{s.header("Cache-Control",r.includes("/assets/")?"public, immutable, max-age=31536000":"no-cache")}}));o.output==="static"?console.log("[devix] Static mode \u2014 serving pre-generated files from dist/client"):(v(p,{renderModule:d,apiModule:m,manifest:f}),h(p,{renderModule:d,apiModule:m,manifest:f,loaderTimeout:o.loaderTimeout}));b({fetch:p.fetch,port:R,hostname:M},r=>console.log(`http://${r.address}:${r.port}`));
|
|
90
2
|
//# sourceMappingURL=start.js.map
|
package/dist/cli/start.js.map
CHANGED
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/cli/start.ts", "../../src/server/routes.ts", "../../src/utils/env.ts"],
|
|
4
4
|
"sourcesContent": ["import {readFileSync} from 'node:fs'\nimport {serve} from '@hono/node-server'\nimport {serveStatic} from '@hono/node-server/serve-static'\nimport {Hono} from 'hono'\nimport {resolve} from 'node:path'\nimport type {Manifest} from 'vite'\nimport {registerApiRoutes, registerSsrRoute} from '../server/routes'\nimport {loadDotenv} from '../utils/env'\n\nloadDotenv('production')\n\nlet renderModule: any\nlet apiModule: any\nlet manifest: Manifest\nlet runtimeConfig: { port: number, host: string | boolean, loaderTimeout: number, output: 'server' | 'static' }\n\ntry {\n runtimeConfig = JSON.parse(readFileSync(resolve(process.cwd(), 'dist/devix.config.json'), 'utf-8'))\n if (runtimeConfig.output !== 'static') {\n renderModule = await import(resolve(process.cwd(), 'dist/server/render.js'))\n apiModule = await import(resolve(process.cwd(), 'dist/server/api.js'))\n }\n manifest = JSON.parse(readFileSync(resolve(process.cwd(), 'dist/client/.vite/manifest.json'), 'utf-8'))\n} catch {\n console.error('[devix] Build not found. Run \"devix build\" first.')\n process.exit(1)\n}\n\nconst port = Number(process.env.PORT) || runtimeConfig!.port || 3000\nconst host = typeof runtimeConfig!.host === 'string'\n ? runtimeConfig!.host\n : runtimeConfig!.host ? '0.0.0.0' : (process.env.HOST || '0.0.0.0')\n\nconst app = new Hono()\n\napp.use('/*', serveStatic({\n root: './dist/client',\n onFound: (_path, c) => {\n c.header('Cache-Control', _path.includes('/assets/')\n ? 'public, immutable, max-age=31536000'\n : 'no-cache')\n }\n}))\n\nif (runtimeConfig!.output === 'static') {\n console.log('[devix] Static mode \u2014 serving pre-generated files from dist/client')\n} else {\n registerApiRoutes(app, {renderModule, apiModule, manifest})\n registerSsrRoute(app, {renderModule, apiModule, manifest, loaderTimeout: runtimeConfig!.loaderTimeout})\n}\n\nserve({fetch: app.fetch, port, hostname: host}, (info) => console.log(`http://${info.address}:${info.port}`))\n\nexport {}", "import type {Hono} from 'hono'\nimport type {Manifest} from 'vite'\n\ninterface ServerOptions {\n renderModule: any\n apiModule: any\n manifest?: Manifest\n loaderTimeout?: number\n}\n\nexport function registerApiRoutes(app: Hono, {apiModule, renderModule, loaderTimeout}: ServerOptions) {\n app.all('/api/*', async (c) => {\n try {\n return await apiModule.handleApiRequest(c.req.url, c.req.raw)\n } catch (e) {\n console.error(e)\n return c.json({error: 'internal error'}, 500)\n }\n })\n\n app.get('/_data/*', async (c) => {\n try {\n const {pathname, search} = new URL(c.req.url, 'http://localhost')\n const url = pathname.replace(/^\\/_data/, '') + search\n\n const data = await renderModule.runLoader(url, c.req.raw, {loaderTimeout})\n return c.json(data)\n } catch (e) {\n console.error(e)\n return c.json({error: 'internal error'}, 500)\n }\n })\n}\n\nexport function registerSsrRoute(app: Hono, {renderModule, manifest, loaderTimeout}: ServerOptions) {\n app.get('*', async (c) => {\n try {\n const {html, statusCode, headers} = await renderModule.render(c.req.url, c.req.raw, {manifest, loaderTimeout})\n const res = c.html(`<!DOCTYPE html>${html}`, statusCode)\n for (const [key, value] of Object.entries(headers as Record<string, string>)) {\n res.headers.set(key, value)\n }\n return res\n } catch (e) {\n console.error(e)\n return c.text('Internal Server Error', 500)\n }\n })\n}", "import {loadEnv} from 'vite'\n\nexport function loadDotenv(mode: string) {\n const env = loadEnv(mode, process.cwd(), '')\n for (const [key, value] of Object.entries(env)) {\n if (process.env[key] === undefined) {\n process.env[key] = value\n }\n }\n}\n"],
|
|
5
|
-
"mappings": "
|
|
6
|
-
"names": ["app", "apiModule", "renderModule", "manifest"]
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["readFileSync", "serve", "serveStatic", "Hono", "resolve", "registerApiRoutes", "app", "apiModule", "renderModule", "loaderTimeout", "c", "e", "pathname", "search", "url", "data", "registerSsrRoute", "manifest", "html", "statusCode", "headers", "res", "key", "value", "loadEnv", "loadDotenv", "mode", "env", "key", "value", "loadDotenv", "renderModule", "apiModule", "manifest", "runtimeConfig", "readFileSync", "resolve", "port", "host", "app", "Hono", "serveStatic", "_path", "c", "registerApiRoutes", "registerSsrRoute", "serve", "info"]
|
|
7
7
|
}
|
package/dist/config.js
CHANGED
|
@@ -1,17 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
function defineConfig(config) {
|
|
3
|
-
return config;
|
|
4
|
-
}
|
|
5
|
-
function resolveDirs(config) {
|
|
6
|
-
const appDir = config.appDir ?? "app";
|
|
7
|
-
return {
|
|
8
|
-
appDir,
|
|
9
|
-
pagesDir: `${appDir}/pages`,
|
|
10
|
-
apiDir: `${appDir}/api`
|
|
11
|
-
};
|
|
12
|
-
}
|
|
13
|
-
export {
|
|
14
|
-
defineConfig,
|
|
15
|
-
resolveDirs
|
|
16
|
-
};
|
|
1
|
+
function e(i){return i}function t(i){let r=i.appDir??"app";return{appDir:r,pagesDir:`${r}/pages`,apiDir:`${r}/api`}}export{e as defineConfig,t as resolveDirs};
|
|
17
2
|
//# sourceMappingURL=config.js.map
|
package/dist/config.js.map
CHANGED
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/config.ts"],
|
|
4
4
|
"sourcesContent": ["import type { UserConfig } from \"vite\"\n\nexport interface DevixConfig {\n port?: number\n host?: string | boolean\n css?: string[]\n appDir?: string\n envPrefix?: string | string[]\n html?: { lang?: string }\n vite?: UserConfig\n loaderTimeout?: number | string\n output?: 'server' | 'static'\n}\n\nexport interface ResolvedDirs {\n appDir: string\n pagesDir: string\n apiDir: string\n}\n\nexport function defineConfig(config: DevixConfig): DevixConfig { return config }\n\nexport function resolveDirs(config: DevixConfig): ResolvedDirs {\n const appDir = config.appDir ?? \"app\"\n return {\n appDir,\n pagesDir: `${appDir}/pages`,\n apiDir: `${appDir}/api`,\n }\n}"],
|
|
5
|
-
"mappings": "
|
|
6
|
-
"names": []
|
|
5
|
+
"mappings": "AAoBO,SAASA,EAAaC,EAAkC,CAAE,OAAOA,CAAO,CAExE,SAASC,EAAYD,EAAmC,CAC3D,IAAME,EAASF,EAAO,QAAU,MAChC,MAAO,CACH,OAAAE,EACA,SAAU,GAAGA,CAAM,SACnB,OAAQ,GAAGA,CAAM,MACrB,CACJ",
|
|
6
|
+
"names": ["defineConfig", "config", "resolveDirs", "appDir"]
|
|
7
7
|
}
|
|
@@ -1,18 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
var RouteContext = class {
|
|
3
|
-
params;
|
|
4
|
-
_state = /* @__PURE__ */ new Map();
|
|
5
|
-
constructor(params = {}) {
|
|
6
|
-
this.params = params;
|
|
7
|
-
}
|
|
8
|
-
set(key, value) {
|
|
9
|
-
this._state.set(key, value);
|
|
10
|
-
}
|
|
11
|
-
get(key) {
|
|
12
|
-
return this._state.get(key);
|
|
13
|
-
}
|
|
14
|
-
};
|
|
15
|
-
export {
|
|
16
|
-
RouteContext
|
|
17
|
-
};
|
|
1
|
+
var t=class{params;_state=new Map;constructor(e={}){this.params=e}set(e,n){this._state.set(e,n)}get(e){return this._state.get(e)}};export{t as RouteContext};
|
|
18
2
|
//# sourceMappingURL=api-context.js.map
|
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/runtime/api-context.ts"],
|
|
4
4
|
"sourcesContent": ["export class RouteContext {\n readonly params: Record<string, string>\n private _state = new Map<string, unknown>()\n\n constructor(params: Record<string, string> = {}) {\n this.params = params\n }\n\n set<T>(key: string, value: T): void {\n this._state.set(key, value)\n }\n\n get<T>(key: string): T | undefined {\n return this._state.get(key) as T\n }\n}\n\nexport type RouteResult = Response | Record<string, unknown> | unknown[] | null | void\n\nexport type RouteHandler = (ctx: RouteContext, req: Request) => Promise<RouteResult> | RouteResult\n\nexport interface MiddlewareModule {\n middleware: (ctx: RouteContext, req: Request) => Promise<Response | null> | Response | null\n}\n\nexport interface RouteModule {\n GET?: RouteHandler\n POST?: RouteHandler\n PUT?: RouteHandler\n PATCH?: RouteHandler\n DELETE?: RouteHandler\n HEAD?: RouteHandler\n OPTIONS?: RouteHandler\n}\n"],
|
|
5
|
-
"mappings": "
|
|
6
|
-
"names": []
|
|
5
|
+
"mappings": "AAAO,IAAMA,EAAN,KAAmB,CACb,OACD,OAAS,IAAI,IAErB,YAAYC,EAAiC,CAAC,EAAG,CAC7C,KAAK,OAASA,CAClB,CAEA,IAAOC,EAAaC,EAAgB,CAChC,KAAK,OAAO,IAAID,EAAKC,CAAK,CAC9B,CAEA,IAAOD,EAA4B,CAC/B,OAAO,KAAK,OAAO,IAAIA,CAAG,CAC9B,CACJ",
|
|
6
|
+
"names": ["RouteContext", "params", "key", "value"]
|
|
7
7
|
}
|
|
@@ -1,59 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
function routePattern(rel) {
|
|
3
|
-
return rel.replace(/\.(tsx|ts|jsx|js)$/, "").replace(/\(.*?\)\//g, "").replace(/^index$|\/index$/, "").replace(/\[([^\]]+)]/g, ":$1") || "/";
|
|
4
|
-
}
|
|
5
|
-
|
|
6
|
-
// src/runtime/client-router.ts
|
|
7
|
-
function fileToRoutePattern(filePath, pagesPrefix) {
|
|
8
|
-
const rel = filePath.slice(pagesPrefix.length);
|
|
9
|
-
return routePattern(rel);
|
|
10
|
-
}
|
|
11
|
-
function collectLayoutChain(pageFile, layoutFiles) {
|
|
12
|
-
const parts = pageFile.split("/");
|
|
13
|
-
const chain = [];
|
|
14
|
-
for (let i = 3; i <= parts.length - 1; i++) {
|
|
15
|
-
const dir = parts.slice(0, i).join("/");
|
|
16
|
-
const lp = `${dir}/layout.tsx`;
|
|
17
|
-
const lpts = `${dir}/layout.ts`;
|
|
18
|
-
if (layoutFiles[lp]) {
|
|
19
|
-
chain.push(layoutFiles[lp]);
|
|
20
|
-
} else if (layoutFiles[lpts]) {
|
|
21
|
-
chain.push(layoutFiles[lpts]);
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
return chain;
|
|
25
|
-
}
|
|
26
|
-
function createMatcher(pageFiles, layoutFiles) {
|
|
27
|
-
const routes = Object.keys(pageFiles).filter((f) => !f.split("/").pop().startsWith("layout")).map((file) => {
|
|
28
|
-
const pagesPrefix = file.slice(0, file.indexOf("/pages/") + "/pages".length);
|
|
29
|
-
const pattern = fileToRoutePattern(file, pagesPrefix);
|
|
30
|
-
const params = [...pattern.matchAll(/:([^/]+)/g)].map((m) => m[1]);
|
|
31
|
-
return { file, pattern, params, load: pageFiles[file], loadLayouts: collectLayoutChain(
|
|
32
|
-
file,
|
|
33
|
-
layoutFiles
|
|
34
|
-
) };
|
|
35
|
-
}).sort((a, b) => {
|
|
36
|
-
const aScore = (a.pattern.match(/:/g) || []).length;
|
|
37
|
-
const bScore = (b.pattern.match(/:/g) || []).length;
|
|
38
|
-
if (aScore !== bScore) return aScore - bScore;
|
|
39
|
-
return b.pattern.length - a.pattern.length;
|
|
40
|
-
});
|
|
41
|
-
return function matchClientRoute(pathname) {
|
|
42
|
-
for (const route of routes) {
|
|
43
|
-
const regexStr = route.pattern.replace(/:[^/]+/g, "([^/]+)").replace(/\//g, "\\/");
|
|
44
|
-
const match = pathname.match(new RegExp(`^${regexStr}$`));
|
|
45
|
-
if (match) {
|
|
46
|
-
const params = {};
|
|
47
|
-
route.params.forEach((name, i) => {
|
|
48
|
-
params[name] = decodeURIComponent(match[i + 1]);
|
|
49
|
-
});
|
|
50
|
-
return { load: route.load, loadLayouts: route.loadLayouts, params };
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
return null;
|
|
54
|
-
};
|
|
55
|
-
}
|
|
56
|
-
export {
|
|
57
|
-
createMatcher
|
|
58
|
-
};
|
|
1
|
+
function l(o){return o.replace(/\.(tsx|ts|jsx|js)$/,"").replace(/\(.*?\)\//g,"").replace(/^index$|\/index$/,"").replace(/\[([^\]]+)]/g,":$1")||"/"}function g(o,a){let c=o.slice(a.length);return l(c)}function m(o,a){let c=o.split("/"),t=[];for(let e=3;e<=c.length-1;e++){let r=c.slice(0,e).join("/"),n=`${r}/layout.tsx`,s=`${r}/layout.ts`;a[n]?t.push(a[n]):a[s]&&t.push(a[s])}return t}function y(o,a){let c=Object.keys(o).filter(t=>!t.split("/").pop().startsWith("layout")).map(t=>{let e=t.slice(0,t.indexOf("/pages/")+6),r=g(t,e),n=[...r.matchAll(/:([^/]+)/g)].map(s=>s[1]);return{file:t,pattern:r,params:n,load:o[t],loadLayouts:m(t,a)}}).sort((t,e)=>{let r=(t.pattern.match(/:/g)||[]).length,n=(e.pattern.match(/:/g)||[]).length;return r!==n?r-n:e.pattern.length-t.pattern.length});return function(e){for(let r of c){let n=r.pattern.replace(/:[^/]+/g,"([^/]+)").replace(/\//g,"\\/"),s=e.match(new RegExp(`^${n}$`));if(s){let p={};return r.params.forEach((i,u)=>{p[i]=decodeURIComponent(s[u+1])}),{load:r.load,loadLayouts:r.loadLayouts,params:p}}}return null}}export{y as createMatcher};
|
|
59
2
|
//# sourceMappingURL=client-router.js.map
|
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/utils/patterns.ts", "../../src/runtime/client-router.ts"],
|
|
4
4
|
"sourcesContent": ["export function routePattern(rel: string): string {\n return rel\n .replace(/\\.(tsx|ts|jsx|js)$/, '')\n .replace(/\\(.*?\\)\\//g, '')\n .replace(/^index$|\\/index$/, '')\n .replace(/\\[([^\\]]+)]/g, ':$1')\n || '/'\n}", "import {ComponentType} from \"react\";\nimport {routePattern} from \"../utils/patterns\";\n\nexport interface ClientMatch {\n load: () => Promise<{ default: ComponentType<any> }>\n loadLayouts: Array<() => Promise<{ default: ComponentType<any> }>>\n params: Record<string, string>\n}\n\ntype GlobMap = Record<string, () => Promise<any>>\n\nfunction fileToRoutePattern(filePath: string, pagesPrefix: string): string {\n const rel = filePath.slice(pagesPrefix.length)\n return routePattern(rel)\n}\n\nfunction collectLayoutChain(pageFile: string, layoutFiles: GlobMap): Array<() => Promise<any>> {\n const parts = pageFile.split('/')\n const chain: Array<() => Promise<any>> = []\n\n for (let i = 3; i <= parts.length - 1; i++) {\n const dir = parts.slice(0, i).join('/')\n const lp = `${dir}/layout.tsx`\n const lpts = `${dir}/layout.ts`\n if (layoutFiles[lp]) {\n chain.push(layoutFiles[lp])\n } else if (layoutFiles[lpts]) {\n chain.push(layoutFiles[lpts])\n }\n }\n\n return chain\n}\n\nexport function createMatcher(pageFiles: GlobMap, layoutFiles: GlobMap) {\n const routes = Object.keys(pageFiles)\n .filter(f => !f.split('/').pop()!.startsWith('layout'))\n .map(file => {\n const pagesPrefix = file.slice(0, file.indexOf('/pages/') + '/pages'.length)\n const pattern = fileToRoutePattern(file, pagesPrefix)\n const params = [...pattern.matchAll(/:([^/]+)/g)].map(m => m[1])\n return { file, pattern, params, load: pageFiles[file], loadLayouts: collectLayoutChain(file,\n layoutFiles) }\n })\n .sort((a, b) => {\n const aScore = (a.pattern.match(/:/g) || []).length\n const bScore = (b.pattern.match(/:/g) || []).length\n if (aScore !== bScore) return aScore - bScore\n return b.pattern.length - a.pattern.length\n })\n\n return function matchClientRoute(pathname: string): ClientMatch | null {\n for (const route of routes) {\n const regexStr = route.pattern\n .replace(/:[^/]+/g, '([^/]+)')\n .replace(/\\//g, '\\\\/')\n const match = pathname.match(new RegExp(`^${regexStr}$`))\n\n if (match) {\n const params: Record<string, string> = {}\n route.params.forEach((name, i) => {\n params[name] = decodeURIComponent(match[i + 1])\n })\n return { load: route.load, loadLayouts: route.loadLayouts, params }\n }\n }\n return null\n }\n}"],
|
|
5
|
-
"mappings": "
|
|
6
|
-
"names": []
|
|
5
|
+
"mappings": "AAAO,SAASA,EAAaC,EAAqB,CAC9C,OAAOA,EACE,QAAQ,qBAAsB,EAAE,EAChC,QAAQ,aAAc,EAAE,EACxB,QAAQ,mBAAoB,EAAE,EAC9B,QAAQ,eAAgB,KAAK,GAC/B,GACX,CCIA,SAASC,EAAmBC,EAAkBC,EAA6B,CACvE,IAAMC,EAAMF,EAAS,MAAMC,EAAY,MAAM,EAC7C,OAAOE,EAAaD,CAAG,CAC3B,CAEA,SAASE,EAAmBC,EAAkBC,EAAiD,CAC3F,IAAMC,EAAQF,EAAS,MAAM,GAAG,EAC1BG,EAAmC,CAAC,EAE1C,QAASC,EAAI,EAAGA,GAAKF,EAAM,OAAS,EAAGE,IAAK,CACxC,IAAMC,EAAMH,EAAM,MAAM,EAAGE,CAAC,EAAE,KAAK,GAAG,EAChCE,EAAK,GAAGD,CAAG,cACXE,EAAO,GAAGF,CAAG,aACfJ,EAAYK,CAAE,EACdH,EAAM,KAAKF,EAAYK,CAAE,CAAC,EACnBL,EAAYM,CAAI,GACvBJ,EAAM,KAAKF,EAAYM,CAAI,CAAC,CAEpC,CAEA,OAAOJ,CACX,CAEO,SAASK,EAAcC,EAAoBR,EAAsB,CACpE,IAAMS,EAAS,OAAO,KAAKD,CAAS,EAC/B,OAAOE,GAAK,CAACA,EAAE,MAAM,GAAG,EAAE,IAAI,EAAG,WAAW,QAAQ,CAAC,EACrD,IAAIC,GAAQ,CACT,IAAMhB,EAAcgB,EAAK,MAAM,EAAGA,EAAK,QAAQ,SAAS,EAAI,CAAe,EACrEC,EAAUnB,EAAmBkB,EAAMhB,CAAW,EAC9CkB,EAAS,CAAC,GAAGD,EAAQ,SAAS,WAAW,CAAC,EAAE,IAAIE,GAAKA,EAAE,CAAC,CAAC,EAC/D,MAAO,CAAE,KAAAH,EAAM,QAAAC,EAAS,OAAAC,EAAQ,KAAML,EAAUG,CAAI,EAAG,YAAab,EAAmBa,EAC/EX,CAAW,CAAE,CACzB,CAAC,EACA,KAAK,CAACe,EAAGC,IAAM,CACZ,IAAMC,GAAUF,EAAE,QAAQ,MAAM,IAAI,GAAK,CAAC,GAAG,OACvCG,GAAUF,EAAE,QAAQ,MAAM,IAAI,GAAK,CAAC,GAAG,OAC7C,OAAIC,IAAWC,EAAeD,EAASC,EAChCF,EAAE,QAAQ,OAASD,EAAE,QAAQ,MACxC,CAAC,EAEL,OAAO,SAA0BI,EAAsC,CACnE,QAAWC,KAASX,EAAQ,CACxB,IAAMY,EAAWD,EAAM,QAClB,QAAQ,UAAW,SAAS,EAC5B,QAAQ,MAAO,KAAK,EACnBE,EAAQH,EAAS,MAAM,IAAI,OAAO,IAAIE,CAAQ,GAAG,CAAC,EAExD,GAAIC,EAAO,CACP,IAAMT,EAAiC,CAAC,EACxC,OAAAO,EAAM,OAAO,QAAQ,CAACG,EAAMpB,IAAM,CAC9BU,EAAOU,CAAI,EAAI,mBAAmBD,EAAMnB,EAAI,CAAC,CAAC,CAClD,CAAC,EACM,CAAE,KAAMiB,EAAM,KAAM,YAAaA,EAAM,YAAa,OAAAP,CAAO,CACtE,CACJ,CACA,OAAO,IACX,CACJ",
|
|
6
|
+
"names": ["routePattern", "rel", "fileToRoutePattern", "filePath", "pagesPrefix", "rel", "routePattern", "collectLayoutChain", "pageFile", "layoutFiles", "parts", "chain", "i", "dir", "lp", "lpts", "createMatcher", "pageFiles", "routes", "f", "file", "pattern", "params", "m", "a", "b", "aScore", "bScore", "pathname", "route", "regexStr", "match", "name"]
|
|
7
7
|
}
|
package/dist/runtime/context.js
CHANGED
|
@@ -1,15 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
import { createContext } from "react";
|
|
3
|
-
var g = globalThis;
|
|
4
|
-
g.__devix_RouterContext__ ??= createContext(null);
|
|
5
|
-
var RouterContext = g.__devix_RouterContext__;
|
|
6
|
-
g.__devix_PageMetaContext__ ??= createContext(null);
|
|
7
|
-
g.__devix_RouteDataContext__ ??= createContext(null);
|
|
8
|
-
var PageMetaContext = g.__devix_PageMetaContext__;
|
|
9
|
-
var RouteDataContext = g.__devix_RouteDataContext__;
|
|
10
|
-
export {
|
|
11
|
-
PageMetaContext,
|
|
12
|
-
RouteDataContext,
|
|
13
|
-
RouterContext
|
|
14
|
-
};
|
|
1
|
+
import{createContext as e}from"react";var t=globalThis;t.__devix_RouterContext__??=e(null);var r=t.__devix_RouterContext__;t.__devix_PageMetaContext__??=e(null);t.__devix_RouteDataContext__??=e(null);var l=t.__devix_PageMetaContext__,u=t.__devix_RouteDataContext__;export{l as PageMetaContext,u as RouteDataContext,r as RouterContext};
|
|
15
2
|
//# sourceMappingURL=context.js.map
|
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/runtime/context.tsx"],
|
|
4
4
|
"sourcesContent": ["import {createContext, Context, ComponentType} from \"react\";\nimport {Metadata, Viewport} from \"../types\";\nimport {LayoutProps, PageProps} from \"../server/types\";\n\nexport interface RouterContextValue {\n pathname: string\n params: Record<string, string>\n loaderData: unknown\n layoutsData: unknown[]\n Page: ComponentType<PageProps>\n layouts: ComponentType<LayoutProps>[]\n metadata: Metadata | null\n viewport?: Viewport\n navigate: (to: string) => void\n isNavigating: boolean\n}\n\nexport interface PageMetaContextValue {\n metadata: Metadata | null\n viewport?: Viewport\n clientEntry?: string\n}\n\nexport interface RouteDataContextValue {\n loaderData: unknown\n params: Record<string, string>\n}\n\nconst g = globalThis as any\n\ng.__devix_RouterContext__ ??= createContext<RouterContextValue | null>(null)\nexport const RouterContext: Context<RouterContextValue | null> = g.__devix_RouterContext__\n\ng.__devix_PageMetaContext__ ??= createContext<PageMetaContextValue | null>(null)\ng.__devix_RouteDataContext__ ??= createContext<RouteDataContextValue | null>(null)\n\nexport const PageMetaContext: Context<PageMetaContextValue | null> = g.__devix_PageMetaContext__\nexport const RouteDataContext: Context<RouteDataContextValue | null> = g.__devix_RouteDataContext__\n\n"],
|
|
5
|
-
"mappings": "
|
|
6
|
-
"names": []
|
|
5
|
+
"mappings": "AAAA,OAAQ,iBAAAA,MAA4C,QA4BpD,IAAMC,EAAI,WAEVA,EAAE,0BAA4BD,EAAyC,IAAI,EACpE,IAAME,EAAoDD,EAAE,wBAEnEA,EAAE,4BAA8BD,EAA2C,IAAI,EAC/EC,EAAE,6BAA+BD,EAA4C,IAAI,EAE1E,IAAMG,EAAwDF,EAAE,0BAC1DG,EAA0DH,EAAE",
|
|
6
|
+
"names": ["createContext", "g", "RouterContext", "PageMetaContext", "RouteDataContext"]
|
|
7
7
|
}
|