// @flow import { parser } from 'rich-markdown-editor'; export default function parseDocumentIds(text: string): string[] { const value = parser.parse(text); let links = []; function findLinks(node) { // get text nodes if (node.type.name === 'text') { // get marks for text nodes node.marks.forEach(mark => { // any of the marks links? if (mark.type.name === 'link') { const { href } = mark.attrs; // any of the links to other docs? if (href.startsWith('/doc')) { const tokens = href.replace(/\/$/, '').split('/'); const lastToken = tokens[tokens.length - 1]; // don't return the same link more than once if (!links.includes(lastToken)) { links.push(lastToken); } } } }); } if (!node.content.size) { return; } node.content.descendants(findLinks); } findLinks(value); return links; }