Ola Rubaj af134cac8b
Integrate flowershow packages (#923)
* [packages][m]: mv @flowershow/core package here

* [packages/core][xs]: rename to @portaljs/core

* [package.json][xs]: setup npm workspaces

* [packages/core][xs]:replace deprecated rollup executor

* [core/package.json][s]: fix mermaid versions

* [core/tsconfig][xs]: rm extends

* [core/jest.config][xs]: rm coverageDirectory

* [core/package.json][xs]: install core-js

* [packages.json][s]:use same version for all nrwl packages

* [core/.eslintrc][xs]: adjust ignorePatterns

* [core/project.json][xs]: rm publish targets

* [packages][m]: mv @flowershow/remark-wiki-link here

* [packages][m]: mv @flowershow/remark-wiki-link here

* [packages][m]: mv @flowershow/remark-embed here

* [remark-callouts/project.json][xs]: adjst test pattern

* [package.json][s]: install missing deps

* [remark-callouts][xs]: adjst fields in package.json

* [remark-callouts][s]: rm pubish targets and adjst build executor

* [remark-embed/jest.config][xs]: rm unknown option coverageDirectory

* [remark-embed][xs]: rm publish targets

* [remark-embed][s]: rename to @portaljs/remark-embed

* [remark-wiki-link/eslintrc][xs]:adjst ignorePatterns

* [package.json][xs]: install missing deps

* [remark-wiki-link/test][xs]:specify format

- also temporarily force any type on htmlExtension

* [remark-wiki-link/README][xs]: replace @flowershow with @portaljs

* [remark-wiki-link][xs]:rm old changelog

* [remark-wiki-link][xs]: adjst package.json

* [remark-wiki-link/project.json][xs]: rm publish targets

* [core][s]: rm old changelog

* [core/README][xs]:correct scope name

* [remark-callouts/README][xs]: add @portaljs to pckg name

* [remark-embed/README][xs]: add @portaljs to pckg name

* [package-lock.json][xs]: refresh after rebasing on main
2023-06-07 07:21:00 -03:00

44 lines
1.4 KiB
TypeScript

import fs from "fs";
import path from "path";
// recursively get all files in a directory
const recursiveGetFiles = (dir: string) => {
const dirents = fs.readdirSync(dir, { withFileTypes: true });
const files = dirents
.filter((dirent) => dirent.isFile())
.map((dirent) => path.join(dir, dirent.name));
const dirs = dirents
.filter((dirent) => dirent.isDirectory())
.map((dirent) => path.join(dir, dirent.name));
for (const d of dirs) {
files.push(...recursiveGetFiles(d));
}
return files;
};
export const getPermalinks = (
markdownFolder: string,
ignorePatterns: Array<RegExp> = [],
func: (str: any, ...args: any[]) => string = defaultPathToPermalinkFunc
) => {
const files = recursiveGetFiles(markdownFolder);
const filesFiltered = files.filter((file) => {
return !ignorePatterns.some((pattern) => file.match(pattern));
});
return filesFiltered.map((file) => func(file, markdownFolder));
};
const defaultPathToPermalinkFunc = (
filePath: string,
markdownFolder: string
) => {
const permalink = filePath
.replace(markdownFolder, "") // make the permalink relative to the markdown folder
.replace(/\.(mdx|md)/, "")
.replace(/\\/g, "/") // replace windows backslash with forward slash
.replace(/\/index$/, ""); // remove index from the end of the permalink
return permalink.length > 0 ? permalink : "/"; // for home page
};