2024-04-03 13:34:26 +02:00
|
|
|
import type { AiDoc } from '../classes.aidoc.js';
|
|
|
|
import * as plugins from '../plugins.js';
|
2024-10-28 21:15:59 +01:00
|
|
|
import * as paths from '../paths.js';
|
2024-04-03 13:34:26 +02:00
|
|
|
import { ProjectContext } from './projectcontext.js';
|
2024-10-28 21:15:59 +01:00
|
|
|
import { logger } from '../logging.js';
|
2024-04-03 13:34:26 +02:00
|
|
|
|
|
|
|
export class Readme {
|
|
|
|
// INSTANCE
|
|
|
|
private aiDocsRef: AiDoc;
|
|
|
|
private projectDir: string;
|
|
|
|
|
|
|
|
constructor(aiDocsRef: AiDoc, projectDirArg: string) {
|
|
|
|
this.aiDocsRef = aiDocsRef;
|
|
|
|
this.projectDir = projectDirArg;
|
|
|
|
}
|
|
|
|
|
|
|
|
public async build() {
|
|
|
|
let finalReadmeString = ``;
|
|
|
|
|
|
|
|
// we can now assemble the directory structure.
|
|
|
|
const projectContext = new ProjectContext(this.projectDir);
|
|
|
|
const contextString = await projectContext.update();
|
|
|
|
|
|
|
|
// lets first check legal before introducung any cost
|
2024-06-22 13:20:55 +02:00
|
|
|
const npmExtraJson = JSON.parse(
|
2024-10-28 21:15:59 +01:00
|
|
|
(await projectContext.gatherFiles()).smartfilesNpmextraJSON.contents.toString()
|
2024-06-22 13:20:55 +02:00
|
|
|
);
|
|
|
|
const legalInfo = npmExtraJson?.tsdoc?.legal;
|
2024-04-03 13:34:26 +02:00
|
|
|
if (!legalInfo) {
|
|
|
|
const error = new Error(`No legal information found in npmextra.json`);
|
|
|
|
console.log(error);
|
|
|
|
}
|
|
|
|
|
2024-05-17 17:38:35 +02:00
|
|
|
let result = await this.aiDocsRef.openaiInstance.chat({
|
|
|
|
systemMessage: `
|
2024-04-03 13:34:26 +02:00
|
|
|
You create markdown readmes for npm projects. You only output the markdown readme.
|
|
|
|
|
|
|
|
The Readme should follow the following template:
|
|
|
|
|
|
|
|
# Project Name
|
|
|
|
[
|
|
|
|
The name is the module name of package.json
|
|
|
|
The description is in the description field of package.json
|
|
|
|
]
|
|
|
|
|
|
|
|
## Install
|
|
|
|
[
|
|
|
|
Write a short text on how to install the project
|
|
|
|
]
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
[
|
|
|
|
Give code examples here.
|
|
|
|
Construct sensible scenarios for the user.
|
|
|
|
Make sure to show a complete set of features of the module.
|
|
|
|
Don't omit use cases.
|
|
|
|
It does not matter how much time you need.
|
|
|
|
ALWAYS USE ESM SYNTAX AND TYPESCRIPT.
|
|
|
|
DON'T CHICKEN OUT. Write at least 4000 words. More if necessary.
|
|
|
|
If there is already a readme, take the Usage section as base. Remove outdated content, and expand and improve upon the valid parts.
|
|
|
|
Super important: Check for completenes.
|
|
|
|
Don't include any licensing information. This will be added in a later step.
|
|
|
|
Avoid "in conclusions".
|
|
|
|
|
2024-04-12 15:28:55 +02:00
|
|
|
Good to know:
|
|
|
|
* npmextra.json contains overall module information.
|
|
|
|
* readme.hints.md provides valuable hints about module ideas.
|
2024-04-03 13:34:26 +02:00
|
|
|
]
|
2024-05-17 17:38:35 +02:00
|
|
|
`,
|
|
|
|
messageHistory: [],
|
|
|
|
userMessage: contextString,
|
|
|
|
});
|
2024-04-03 13:34:26 +02:00
|
|
|
|
2024-05-17 17:38:35 +02:00
|
|
|
finalReadmeString += result.message + '\n' + legalInfo;
|
2024-04-03 13:34:26 +02:00
|
|
|
|
|
|
|
console.log(`\n======================\n`);
|
2024-05-17 17:38:35 +02:00
|
|
|
console.log(result.message);
|
2024-04-03 13:34:26 +02:00
|
|
|
console.log(`\n======================\n`);
|
|
|
|
|
|
|
|
const readme = (await projectContext.gatherFiles()).smartfilesReadme;
|
|
|
|
readme.contents = Buffer.from(finalReadmeString);
|
|
|
|
await readme.write();
|
|
|
|
|
2024-10-28 21:15:59 +01:00
|
|
|
// lets care about monorepo aspects
|
|
|
|
const tsPublishInstance = new plugins.tspublish.TsPublish();
|
2024-10-28 21:20:50 +01:00
|
|
|
const subModules = await tsPublishInstance.getModuleSubDirs(paths.cwd);
|
2024-10-28 21:15:59 +01:00
|
|
|
logger.log('info', `Found ${Object.keys(subModules).length} sub modules`);
|
|
|
|
for (const subModule of Object.keys(subModules)) {
|
|
|
|
logger.log('info', `Building readme for ${subModule}`);
|
|
|
|
const subModuleContextString = await projectContext.update();
|
|
|
|
let result = await this.aiDocsRef.openaiInstance.chat({
|
|
|
|
systemMessage: `
|
|
|
|
You create markdown readmes for npm projects. You only output the markdown readme.
|
|
|
|
|
|
|
|
IMPORTANT: YOU ARE NOW CREATING THE README FOR THE FOLLOWING SUB MODULE: ${subModule} !!!!!!!!!!!
|
|
|
|
The Sub Module will be published with the following data:
|
|
|
|
${JSON.stringify(plugins.smartfile.fs.toStringSync(plugins.path.join(paths.cwd, subModule, 'tspublish.json')), null, 2)}
|
|
|
|
|
|
|
|
|
|
|
|
The Readme should follow the following template:
|
|
|
|
|
|
|
|
# Project Name
|
|
|
|
[
|
|
|
|
The name is the module name of package.json
|
|
|
|
The description is in the description field of package.json
|
|
|
|
]
|
|
|
|
|
|
|
|
## Install
|
|
|
|
[
|
|
|
|
Write a short text on how to install the project
|
|
|
|
]
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
[
|
|
|
|
Give code examples here.
|
|
|
|
Construct sensible scenarios for the user.
|
|
|
|
Make sure to show a complete set of features of the module.
|
|
|
|
Don't omit use cases.
|
|
|
|
It does not matter how much time you need.
|
|
|
|
ALWAYS USE ESM SYNTAX AND TYPESCRIPT.
|
|
|
|
DON'T CHICKEN OUT. Write at least 4000 words. More if necessary.
|
|
|
|
If there is already a readme, take the Usage section as base. Remove outdated content, and expand and improve upon the valid parts.
|
|
|
|
Super important: Check for completenes.
|
|
|
|
Don't include any licensing information. This will be added in a later step.
|
|
|
|
Avoid "in conclusions".
|
|
|
|
|
|
|
|
Good to know:
|
|
|
|
* npmextra.json contains overall module information.
|
|
|
|
* readme.hints.md provides valuable hints about module ideas.
|
2025-01-14 17:42:19 +01:00
|
|
|
* Your output lands directly in the readme.md file.
|
|
|
|
* Don't use \`\`\` at the beginning or the end. It'll cause problems. Only use it for codeblocks. You are directly writing markdown. No need to introduce it weirdly.
|
2024-10-28 21:15:59 +01:00
|
|
|
]
|
|
|
|
`,
|
|
|
|
messageHistory: [],
|
|
|
|
userMessage: subModuleContextString,
|
|
|
|
});
|
|
|
|
|
|
|
|
const subModuleReadmeString = result.message + '\n' + legalInfo;
|
|
|
|
await plugins.smartfile.memory.toFs(subModuleReadmeString, plugins.path.join(paths.cwd, subModule, 'readme.md'));
|
|
|
|
logger.log('success', `Built readme for ${subModule}`);
|
|
|
|
}
|
2024-05-17 17:38:35 +02:00
|
|
|
return result.message;
|
2024-04-03 13:34:26 +02:00
|
|
|
}
|
2024-06-22 13:20:55 +02:00
|
|
|
}
|