Files
2024-03-24 19:43:45 -07:00

124 lines
4.5 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.BlogPlugin = void 0;
const tslib_1 = require("tslib");
const fs = tslib_1.__importStar(require("fs"));
const path = tslib_1.__importStar(require("path"));
const document_1 = require("./document");
const logger_1 = tslib_1.__importDefault(require("@docusaurus/logger"));
const progress = tslib_1.__importStar(require("./progress"));
class BlogPlugin {
context;
options;
imageGenerator;
imageRenderer;
static plugin = 'docusaurus-plugin-content-blog';
pages = [];
constructor(context, options, imageGenerator, imageRenderer) {
this.context = context;
this.options = options;
this.imageGenerator = imageGenerator;
this.imageRenderer = imageRenderer;
}
process = async () => {
await this.loadData();
await this.generate();
};
loadData = async () => {
const plugins = this.context.plugins.filter((plugin) => plugin.name === BlogPlugin.plugin);
for (const plugin of plugins) {
await this.loadInstance(plugin);
}
};
loadInstance = async (plugin) => {
const content = plugin.content;
const options = plugin.options;
content.blogListPaginated.forEach((value) => {
this.pages.push({
data: value,
plugin: options,
pageType: 'list',
permalink: value.metadata.permalink,
});
});
content.blogPosts.forEach((post) => {
this.pages.push({
data: post,
plugin: options,
pageType: 'post',
permalink: post.metadata.permalink,
});
});
if (content.blogTagsListPath) {
const filePath = this.getHtmlPath(content.blogTagsListPath);
fs.existsSync(filePath) &&
this.pages.push({
pageType: 'tags',
plugin: options,
data: {
permalink: content.blogTagsListPath,
},
permalink: content.blogTagsListPath,
});
}
if (options.archiveBasePath) {
const permalink = path.join('/', options.routeBasePath, options.archiveBasePath);
fs.existsSync(this.getHtmlPath(permalink)) &&
this.pages.push({
plugin: options,
pageType: 'archive',
data: { permalink: permalink },
permalink,
});
}
{
Object.entries(content.blogTags).map(([key, value]) => {
value.pages.forEach((page) => {
this.pages.push({
pageType: 'tag',
plugin: options,
data: { ...page.metadata, label: value.label },
permalink: page.metadata.permalink,
});
});
});
}
};
generate = async () => {
logger_1.default.info(`Generating og images for ${this.pages.length} blog pages`);
const bar = progress.defaultBar();
bar.start(this.pages.length, 0, { prefix: 'rendering images', suffix: '-' });
for (const page of this.pages) {
const document = new document_1.Document(this.getHtmlPath(page.permalink));
bar.update({ suffix: page.permalink });
await document.load();
if (!document.loaded) {
bar.increment();
continue;
}
const image = await this.imageRenderer({
...page,
document,
websiteOutDir: this.context.outDir,
}, this.context);
if (!image) {
await document.write();
bar.increment();
continue;
}
const generated = await this.imageGenerator.generate(...image);
await document.setImage(generated.url);
await document.write();
bar.increment();
}
bar.stop();
logger_1.default.success('Generated og images for blog pages');
};
getHtmlPath = (permalink, baseUrl) => path.join(this.stripLangFromPath(this.context.outDir), permalink, 'index.html');
stripLangFromPath = (path) => {
const lang = this.context.i18n.locales.find((locale) => path.endsWith(`/${locale}`));
return lang ? path.slice(0, -lang.length - 1) : path;
};
}
exports.BlogPlugin = BlogPlugin;