import React from 'react'; import hljs from 'highlight.js'; import { Menu } from '../../'; export function objectToComponent(object, index) { if (object === null) return; const children = object.children; if (object.type === 'html') { return React.createElement('div', { key: index, dangerouslySetInnerHTML: { __html: children } }); } if (object.type === 'code') { const highlightedCode = hljs.highlight('javascript', children).value; return (
          
        
); } if (typeof children === 'string') { return React.createElement(object.type, { key: index, dangerouslySetInnerHTML: { __html: children } }); } return React.createElement( object.type, { key: index }, children && children.map(objectToComponent) // `hr` has no children ); } export function flattenMenu(menu) { if (menu.type === Menu.Item) { return menu; } if (Array.isArray(menu)) { return menu.reduce((acc, item) => { return acc.concat(flattenMenu(item)); }, []); } return flattenMenu(menu.props.children); }