e72ac76422
We no longer use tslint so these comments don't do anything.
65 lines
1.6 KiB
TypeScript
65 lines
1.6 KiB
TypeScript
import { promises } from 'fs'
|
|
import { join } from 'path'
|
|
import {
|
|
PAGES_MANIFEST,
|
|
SERVER_DIRECTORY,
|
|
SERVERLESS_DIRECTORY,
|
|
FONT_MANIFEST,
|
|
} from '../lib/constants'
|
|
import { normalizePagePath, denormalizePagePath } from './normalize-page-path'
|
|
import { PagesManifest } from '../../build/webpack/plugins/pages-manifest-plugin'
|
|
|
|
export function pageNotFoundError(page: string): Error {
|
|
const err: any = new Error(`Cannot find module for page: ${page}`)
|
|
err.code = 'ENOENT'
|
|
return err
|
|
}
|
|
|
|
export function getPagePath(
|
|
page: string,
|
|
distDir: string,
|
|
serverless: boolean,
|
|
dev?: boolean
|
|
): string {
|
|
const serverBuildPath = join(
|
|
distDir,
|
|
serverless && !dev ? SERVERLESS_DIRECTORY : SERVER_DIRECTORY
|
|
)
|
|
const pagesManifest = require(join(
|
|
serverBuildPath,
|
|
PAGES_MANIFEST
|
|
)) as PagesManifest
|
|
|
|
try {
|
|
page = denormalizePagePath(normalizePagePath(page))
|
|
} catch (err) {
|
|
console.error(err)
|
|
throw pageNotFoundError(page)
|
|
}
|
|
|
|
if (!pagesManifest[page]) {
|
|
throw pageNotFoundError(page)
|
|
}
|
|
return join(serverBuildPath, pagesManifest[page])
|
|
}
|
|
|
|
export function requirePage(
|
|
page: string,
|
|
distDir: string,
|
|
serverless: boolean
|
|
): any {
|
|
const pagePath = getPagePath(page, distDir, serverless)
|
|
if (pagePath.endsWith('.html')) {
|
|
return promises.readFile(pagePath, 'utf8')
|
|
}
|
|
return require(pagePath)
|
|
}
|
|
|
|
export function requireFontManifest(distDir: string, serverless: boolean) {
|
|
const serverBuildPath = join(
|
|
distDir,
|
|
serverless ? SERVERLESS_DIRECTORY : SERVER_DIRECTORY
|
|
)
|
|
const fontManifest = require(join(serverBuildPath, FONT_MANIFEST))
|
|
return fontManifest
|
|
}
|