mirror of
https://github.com/element-plus/element-plus.git
synced 2025-01-12 10:45:10 +08:00
16f069ebbe
* Revert "build!: simplify build & support native esm import (#3900)"
This reverts commit fb94222bb4
.
* remove module
* Fix linter
* Add @element-plus/icons as dependency
* update pnpm lock file
* temporary lock element-plus at 1.1.0-beta.20
83 lines
2.4 KiB
TypeScript
83 lines
2.4 KiB
TypeScript
import path from 'path'
|
|
import fs from 'fs/promises'
|
|
import { bold } from 'chalk'
|
|
import glob from 'fast-glob'
|
|
import { Project, ScriptTarget, ModuleKind } from 'ts-morph'
|
|
import { parallel } from 'gulp'
|
|
import { epRoot, buildOutput, projRoot } from './utils/paths'
|
|
import { yellow, green } from './utils/log'
|
|
import { buildConfig } from './info'
|
|
import { withTaskName } from './utils/gulp'
|
|
import { run } from './utils/process'
|
|
import type { Module } from './info'
|
|
|
|
import type { SourceFile } from 'ts-morph'
|
|
|
|
const TSCONFIG_PATH = path.resolve(projRoot, 'tsconfig.json')
|
|
|
|
export const genEntryTypes = async () => {
|
|
const files = await glob('*.ts', {
|
|
cwd: epRoot,
|
|
absolute: true,
|
|
onlyFiles: true,
|
|
})
|
|
const project = new Project({
|
|
compilerOptions: {
|
|
module: ModuleKind.ESNext,
|
|
allowJs: true,
|
|
emitDeclarationOnly: true,
|
|
noEmitOnError: false,
|
|
outDir: path.resolve(buildOutput, 'entry/types'),
|
|
target: ScriptTarget.ESNext,
|
|
rootDir: epRoot,
|
|
strict: false,
|
|
},
|
|
skipFileDependencyResolution: true,
|
|
tsConfigFilePath: TSCONFIG_PATH,
|
|
skipAddingFilesFromTsConfig: true,
|
|
})
|
|
const sourceFiles: SourceFile[] = []
|
|
files.map((f) => {
|
|
const sourceFile = project.addSourceFileAtPath(f)
|
|
sourceFiles.push(sourceFile)
|
|
})
|
|
project.addSourceFilesAtPaths(path.resolve(projRoot, 'typings', '*.d.ts'))
|
|
|
|
const diagnostics = project.getPreEmitDiagnostics()
|
|
|
|
console.log(project.formatDiagnosticsWithColorAndContext(diagnostics))
|
|
|
|
await project.emit({
|
|
emitOnlyDtsFiles: true,
|
|
})
|
|
|
|
const tasks = sourceFiles.map(async (sourceFile) => {
|
|
yellow(`Emitting file: ${bold(sourceFile.getFilePath())}`)
|
|
|
|
const emitOutput = sourceFile.getEmitOutput()
|
|
for (const outputFile of emitOutput.getOutputFiles()) {
|
|
const filepath = outputFile.getFilePath()
|
|
|
|
await fs.mkdir(path.dirname(filepath), { recursive: true })
|
|
await fs.writeFile(
|
|
filepath,
|
|
outputFile.getText().replaceAll('@element-plus', '.'),
|
|
'utf8'
|
|
)
|
|
green(`Definition for file: ${bold(sourceFile.getBaseName())} generated`)
|
|
}
|
|
})
|
|
|
|
await Promise.all(tasks)
|
|
}
|
|
|
|
export const copyEntryTypes = (() => {
|
|
const src = path.resolve(buildOutput, 'entry/types')
|
|
const copy = (module: Module) =>
|
|
withTaskName(`copyEntryTypes:${module}`, () =>
|
|
run(`rsync -a ${src}/ ${buildConfig[module].output.path}/`)
|
|
)
|
|
|
|
return parallel(copy('esm'), copy('cjs'))
|
|
})()
|