Roadmap to becoming a developer in 2022
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

81 lines
1.8 KiB

import type { MarkdownFileType } from './file';
export interface GuideFrontmatter {
title: string;
description: string;
author: {
name: string;
url: string;
imageUrl: string;
};
canonicalUrl?: string;
// alternate path where this guide has been published
excludedBySlug?: string;
seo: {
title: string;
description: string;
};
isNew: boolean;
type: 'visual' | 'textual';
date: string;
sitemap: {
priority: number;
changefreq: 'daily' | 'weekly' | 'monthly' | 'yearly';
};
tags: string[];
}
export type GuideFileType = MarkdownFileType<GuideFrontmatter> & {
id: string;
};
/**
* Generates id from the given guide file
* @param filePath Markdown file path
*
* @returns unique guide identifier
*/
function guidePathToId(filePath: string): string {
const fileName = filePath.split('/').pop() || '';
return fileName.replace('.md', '');
}
/**
* Gets all the guides sorted by the publishing date
* @returns Promisifed guide files
*/
export async function getAllGuides(): Promise<GuideFileType[]> {
// @ts-ignore
const guides = await import.meta.glob<GuideFileType>(
'/src/data/guides/*.md',
{
eager: true,
},
);
const guideFiles = Object.values(guides) as GuideFileType[];
const enrichedGuides = guideFiles.map((guideFile) => ({
...guideFile,
id: guidePathToId(guideFile.file),
}));
return enrichedGuides.sort(
(a, b) =>
new Date(b.frontmatter.date).valueOf() -
new Date(a.frontmatter.date).valueOf(),
);
}
/**
* Gets the guide by the given id
* @param id Guide identifier
* @returns Promisified guide file
*/
export async function getGuideById(
id: string,
): Promise<GuideFileType | undefined> {
const allGuides = await getAllGuides();
return allGuides.find((guide) => guide.id === id);
}