mirror of
https://github.com/terribleplan/next.js.git
synced 2024-01-19 02:48:18 +00:00
20fe65ce41
Fixes #5845 Implement tslint for core files **What is this?** Implements tslint for both next and next-server, but keeps standardjs/eslint for the .js files that are still there, we're gradually migrating to Typescript. **How does it work?** Before every commit (pre-commit) we execute the following `tslint` command: `tslint -c tslint.json 'packages/**/*.ts` **TSLint Rules** In order to avoid as much changes as possible I marked some rules as false. This way we can improve the linter but making sure this step will not break things. (see tslint.json) **Note** After merging this PR, you'll need to update your dependencies since it adds tslint to package.json
23 lines
664 B
TypeScript
23 lines
664 B
TypeScript
export type ManifestItem = {
|
|
id: number|string,
|
|
name: string,
|
|
file: string,
|
|
publicPath: string,
|
|
}
|
|
|
|
export type Manifest = {[moduleId: string]: ManifestItem[]}
|
|
|
|
type DynamicImportBundles = Set<ManifestItem>
|
|
|
|
// Based on https://github.com/jamiebuilds/react-loadable/pull/132
|
|
export function getDynamicImportBundles(manifest: Manifest, moduleIds: string[]): DynamicImportBundles {
|
|
return moduleIds.reduce((bundles: DynamicImportBundles, moduleId: string): DynamicImportBundles => {
|
|
if (typeof manifest[moduleId] === 'undefined') {
|
|
return bundles
|
|
}
|
|
|
|
manifest[moduleId].map((item) => bundles.add(item))
|
|
return bundles
|
|
}, new Set())
|
|
}
|