Files
yaak/src-web/lib/getNodeText.ts
2024-02-17 22:03:42 -08:00

23 lines
571 B
TypeScript

import type { ReactNode } from 'react';
/**
* Get the text content from a ReactNode
* https://stackoverflow.com/questions/50428910/get-text-content-from-node-in-react
*/
export function getNodeText(node: ReactNode): string {
if (['string', 'number'].includes(typeof node)) {
return String(node);
}
if (Array.isArray(node)) {
return node.map(getNodeText).join('');
}
if (typeof node === 'object' && node) {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
return getNodeText((node as any).props.children);
}
return '';
}