const marked = require('marked') const camelCase = require('lodash/camelCase') const mdLoader = require('./NaiveUIMdLoader') const createRenderer = require('./mdRenderer') const mdRenderer = createRenderer() function template (demos, demosLiteral, isSingleColumn = false) { // return ` // ${demos} // // ${parseDemosAsAnchor(demosLiteral)} // // ` return ` ${demos} ` } function parseDemos (demosLiteral, env) { const demoFileNames = demosLiteral .split('\n') .map(demoFileName => demoFileName.trim()) .filter((demoFileName) => { if (env === 'production') { return demoFileName.length && demoFileName.indexOf('debug') < 0 && demoFileName.indexOf('Debug') < 0 } return demoFileName.length }) const demoTags = demoFileNames.map(demoFileName => `<${demoFileName}Demo id="${demoFileName}" demo-id="${demoFileName}"/>`) return demoTags.join('\n') } function parseDemosAsAnchor (demosLiteral) { const demoFileNames = demosLiteral .split('\n') .map(demoFileName => demoFileName.trim()) .filter(demoFileName => demoFileName.length) const linkTags = demoFileNames.map(demoFileName => ( ` `)) return `${linkTags.join('\n')}` } function generateScript (demosLiteral, components = [], url) { const demoFileNames = demosLiteral .split('\n') .map(demoFileName => demoFileName.trim()) .filter(demoFileName => demoFileName.length) const importStatements = demoFileNames .map(demoFileName => `import ${camelCase(demoFileName)}Demo from './${demoFileName}.demo.md'`) .concat(components.map(component => `import ${camelCase(component)} from './${component}'`)) .join('\n') const componentStatements = demoFileNames.map(demoFileName => camelCase(demoFileName) + 'Demo').concat(components).join(', ') const script = `` return script } function convertMd2ComponentDocumentation (text, env = 'development', url) { const isNoDemo = !!~text.search('') if (isNoDemo) { return mdLoader(text, url) } const isSingleColumn = !!~text.search('') const tokens = marked.lexer(text) const componentsIndex = tokens.findIndex(token => token.type === 'code' && token.lang === 'component') let components = [] if (~componentsIndex) { components = tokens[componentsIndex].text components = components.split('\n').map(component => component.trim()).filter(component => component.length) tokens.splice(componentsIndex, 1) } const demosIndex = tokens.findIndex(token => token.type === 'code' && token.lang === 'demo') let demos = { text: '' } let demosLiteral = '' let headerPart = tokens let footerPart = [] // console.log(tokens) if (~demosIndex) { headerPart = tokens.slice(0, demosIndex) footerPart = tokens.slice(demosIndex + 1) demos = tokens[demosIndex] demosLiteral = demos.text tokens.splice(demosIndex, 1, { type: 'html', pre: false, text: '\n' }) } headerPart.links = {} footerPart.links = {} const documentationHTML = `${marked.parser(headerPart, { gfm: true, renderer: mdRenderer })}\n` + '\n' + `${marked.parser(footerPart, { gfm: true, renderer: mdRenderer })}\n` // console.log(documentationHTML) // const classedDocumentationHTML = addClassToHTML(documentationHTML, 'markdown') const demosReg = // const demoTags = parseDemos(demosLiteral, env) let documentationContent = documentationHTML .replace(demosReg, template(demoTags, demosLiteral, isSingleColumn)) const titleIndex = tokens.findIndex(token => token.type === 'heading' && token.depth === 1) if (titleIndex > -1) { const titleText = JSON.stringify(tokens[titleIndex].text) const githubButton = `` const titleReg = /(]*>)(.*?)(<\/n-h1>)/ documentationContent = documentationContent.replace(titleReg, `${githubButton}`) } const documentationTemplate = ` ${documentationContent} ${parseDemosAsAnchor(demosLiteral)} ` const documentationScript = generateScript(demosLiteral, components, url) // if (components.length) console.log(`${documentationTemplate}\n\n${documentationScript}`) return `${documentationTemplate}\n\n${documentationScript}` // console.log(vueComponent) // return vueComponent // console.log(marked.parser(tokens)) // const parts = getPartsOfDemo(tokens) // const mergedParts = mergeParts(parts) // const vueComponent = genVueComponent(mergedParts) // console.log(vueComponent) // return vueComponent } // function addClassToHTML (html, className) { // const classReg = /<[^!/][^>]*>/g // return html.replace(classReg, (openTag) => { // return openTag.replace(/>/, ` class="${className}">`) // }) // } module.exports = convertMd2ComponentDocumentation // const startTime = new Date() // for (let i = 0; i < 100; ++i) { // const fs = require('fs') // const md = fs.readFileSync('./marked/component.md').toString() // console.log(convertMd2ComponentDocumentation(md)) // } // const endTime = new Date() // console.log(endTime - startTime)