mirror of
https://github.com/logto-io/logto.git
synced 2025-01-20 21:32:31 -05:00
feat: conditional generate custom types file and export types in index
This commit is contained in:
parent
efa550834a
commit
d30260634d
2 changed files with 30 additions and 25 deletions
|
@ -1,4 +1,5 @@
|
||||||
// THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY.
|
// THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY.
|
||||||
|
|
||||||
|
export * from './custom-types';
|
||||||
export * from './oidc-model-instance';
|
export * from './oidc-model-instance';
|
||||||
export * from './user';
|
export * from './user';
|
||||||
|
|
|
@ -115,6 +115,7 @@ const generate = async () => {
|
||||||
);
|
);
|
||||||
|
|
||||||
const generatedDir = 'src/db-entries';
|
const generatedDir = 'src/db-entries';
|
||||||
|
const generatedTypesFilename = 'custom-types';
|
||||||
const header = '// THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY.\n\n';
|
const header = '// THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY.\n\n';
|
||||||
const getOutputFileName = (file: string) => pluralize(file.slice(0, -4).replace(/_/g, '-'), 1);
|
const getOutputFileName = (file: string) => pluralize(file.slice(0, -4).replace(/_/g, '-'), 1);
|
||||||
|
|
||||||
|
@ -127,9 +128,10 @@ const generate = async () => {
|
||||||
tsName: camelcase(type.name, { pascalCase: true }),
|
tsName: camelcase(type.name, { pascalCase: true }),
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
if (allTypes.length > 0) {
|
||||||
// Generate custom types
|
// Generate custom types
|
||||||
await fs.writeFile(
|
await fs.writeFile(
|
||||||
path.join(generatedDir, 'custom-types.ts'),
|
path.join(generatedDir, `${generatedTypesFilename}.ts`),
|
||||||
header +
|
header +
|
||||||
allTypes
|
allTypes
|
||||||
.map(({ tsName, values }) =>
|
.map(({ tsName, values }) =>
|
||||||
|
@ -142,6 +144,7 @@ const generate = async () => {
|
||||||
.join('\n') +
|
.join('\n') +
|
||||||
'\n'
|
'\n'
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
// Generate DB entry types
|
// Generate DB entry types
|
||||||
await Promise.all(
|
await Promise.all(
|
||||||
|
@ -160,16 +163,16 @@ const generate = async () => {
|
||||||
}),
|
}),
|
||||||
}));
|
}));
|
||||||
|
|
||||||
const importTypes =
|
const importTypes = conditionalString(
|
||||||
customTypes.length > 0
|
customTypes.length > 0 &&
|
||||||
? [
|
[
|
||||||
'import {',
|
'import {',
|
||||||
uniq(customTypes)
|
uniq(customTypes)
|
||||||
.map((value) => ` ${value}`)
|
.map((value) => ` ${value}`)
|
||||||
.join(',\n'),
|
.join(',\n'),
|
||||||
"} from './custom-types';",
|
`} from './${generatedTypesFilename}';`,
|
||||||
].join('\n') + '\n\n'
|
].join('\n') + '\n\n'
|
||||||
: '';
|
);
|
||||||
|
|
||||||
const content =
|
const content =
|
||||||
header +
|
header +
|
||||||
|
@ -202,6 +205,7 @@ const generate = async () => {
|
||||||
await fs.writeFile(
|
await fs.writeFile(
|
||||||
path.join(generatedDir, 'index.ts'),
|
path.join(generatedDir, 'index.ts'),
|
||||||
header +
|
header +
|
||||||
|
conditionalString(allTypes.length > 0 && `export * from './${generatedTypesFilename}';`) +
|
||||||
generated.map(([file]) => `export * from './${getOutputFileName(file)}';`).join('\n') +
|
generated.map(([file]) => `export * from './${getOutputFileName(file)}';`).join('\n') +
|
||||||
'\n'
|
'\n'
|
||||||
);
|
);
|
||||||
|
|
Loading…
Add table
Reference in a new issue