mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-07-24 17:32:15 +00:00
* increase timeout and modify login async * run e2e if testing is changed * improve cdk fix * fix travis update projects * disable ghostMode lite server * lint fix * fix timeout * multiple try * Update content-services-e2e.sh * Update search-e2e.sh * Update process-services-e2e.sh * Update core-e2e.sh * Update protractor.conf.ts * fix unit * remove async * increqase notification time * 3 parallel * dix path issue in save * small refactor protractor ts * fix save * create license check first script adf cli * modify regex check * refactor notification history component * decrease notification * fix notification message problem * fix test * update packages wit high risk * revert cahnge login sso e2e * fix dep * fix documentation duplication and issue * fix after review * fix after review * try 6 parallel test * back to 3 parallel test no real time improve with 6
260 lines
7.0 KiB
TypeScript
260 lines
7.0 KiB
TypeScript
import * as fs from "fs";
|
|
import * as path from "path";
|
|
|
|
import * as replaceSection from "mdast-util-heading-range";
|
|
import * as remark from "remark";
|
|
|
|
import * as ejs from "ejs";
|
|
|
|
import { MDNav } from "../mdNav";
|
|
import { ngNameToClassName } from "../ngHelpers";
|
|
|
|
import {
|
|
ComponentInfo
|
|
} from "../SourceInfoClasses"
|
|
|
|
let templateFolder = path.resolve("tools", "doc", "templates");
|
|
|
|
let nameExceptions;
|
|
|
|
|
|
export function processDocs(mdCache, aggData, _errorMessages) {
|
|
nameExceptions = aggData.config.typeNameExceptions;
|
|
|
|
let pathnames = Object.keys(mdCache);
|
|
let internalErrors;
|
|
|
|
pathnames.forEach(pathname => {
|
|
internalErrors = [];
|
|
updateFile(mdCache[pathname].mdOutTree, pathname, aggData, internalErrors);
|
|
|
|
if (internalErrors.length > 0) {
|
|
showErrors(pathname, internalErrors);
|
|
}
|
|
});
|
|
}
|
|
|
|
|
|
function showErrors(filename, errorMessages) {
|
|
console.log(filename);
|
|
|
|
errorMessages.forEach(message => {
|
|
console.log(" " + message);
|
|
});
|
|
|
|
console.log("");
|
|
}
|
|
|
|
|
|
function updateFile(tree, pathname, aggData, errorMessages) {
|
|
|
|
let className = ngNameToClassName(path.basename(pathname, ".md"), nameExceptions);
|
|
let classTypeMatch = className.match(/component|directive|service/i);
|
|
let compData = aggData.classInfo[className];
|
|
|
|
if (classTypeMatch && compData) {
|
|
let classType = classTypeMatch[0].toLowerCase();
|
|
|
|
// Copy docs back from the .md file when the JSDocs are empty.
|
|
let inputMD = getPropDocsFromMD(tree, "Properties", 3);
|
|
let outputMD = getPropDocsFromMD(tree, "Events", 2);
|
|
updatePropDocsFromMD(compData, inputMD, outputMD, errorMessages);
|
|
|
|
if (classType === "service") {
|
|
let methodMD = getMethodDocsFromMD(tree);
|
|
updateMethodDocsFromMD(compData, methodMD, errorMessages);
|
|
}
|
|
|
|
let templateName = path.resolve(templateFolder, classType + ".ejs");
|
|
let templateSource = fs.readFileSync(templateName, "utf8");
|
|
let template = ejs.compile(templateSource);
|
|
|
|
let mdText = template(compData);
|
|
mdText = mdText.replace(/^ +\|/mg, "|");
|
|
|
|
let newSection = remark().parse(mdText.trim()).children;
|
|
|
|
replaceSection(tree, "Class members", (before, section, after) => {
|
|
newSection.unshift(before);
|
|
newSection.push(after);
|
|
return newSection;
|
|
});
|
|
|
|
compData.errors.forEach(err => {
|
|
errorMessages.push(err);
|
|
})
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
function getPropDocsFromMD(tree, sectionHeading, docsColumn) {
|
|
let result = {}
|
|
|
|
let nav = new MDNav(tree);
|
|
|
|
let classMemHeading = nav
|
|
.heading(h => {
|
|
return (h.children[0].type === "text") && (h.children[0].value === "Class members");
|
|
});
|
|
|
|
let propsTable = classMemHeading
|
|
.heading(h => {
|
|
return (h.children[0].type === "text") && (h.children[0].value === sectionHeading);
|
|
}).table();
|
|
|
|
let propTableRow = propsTable.childNav
|
|
.tableRow(()=>true, 1).childNav;
|
|
|
|
let i = 1;
|
|
|
|
while (!propTableRow.empty) {
|
|
let propName = propTableRow
|
|
.tableCell().childNav
|
|
.text().item.value;
|
|
|
|
let propDocText = propTableRow
|
|
.tableCell(()=>true, docsColumn).childNav
|
|
.text().item;
|
|
|
|
if (propDocText) {
|
|
result[propName] = propDocText.value;
|
|
}
|
|
|
|
i++;
|
|
propTableRow = propsTable.childNav
|
|
.tableRow(()=>true, i).childNav;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
|
|
|
|
function getMethodDocsFromMD(tree) {
|
|
let result = {}
|
|
|
|
let nav = new MDNav(tree);
|
|
|
|
let classMemHeading = nav
|
|
.heading(h => {
|
|
return (h.children[0].type === "text") && (h.children[0].value === "Class members");
|
|
});
|
|
|
|
let methListItems = classMemHeading
|
|
.heading(h => {
|
|
return (h.children[0].type === "text") && (h.children[0].value === "Methods");
|
|
}).list().childNav;
|
|
|
|
let methItem = methListItems
|
|
.listItem();
|
|
|
|
let i = 0;
|
|
|
|
while (!methItem.empty) {
|
|
let methNameSection = methItem.childNav
|
|
.paragraph().childNav
|
|
.strong().childNav;
|
|
|
|
let methName = '';
|
|
|
|
// Method docs must be in "new" format with names and types styled separately.
|
|
if (!methNameSection.empty) {
|
|
methName = methNameSection.text().item.value;
|
|
|
|
let methDoc = methItem.childNav
|
|
.paragraph().childNav
|
|
.html()
|
|
.text().value;
|
|
|
|
let params = getMDMethodParams(methItem);
|
|
|
|
result[methName] = {
|
|
"docText": methDoc.replace(/^\n/, ""),
|
|
"params": params
|
|
};
|
|
}
|
|
|
|
i++;
|
|
|
|
methItem = methListItems
|
|
.listItem(l=>true, i);
|
|
}
|
|
|
|
return result;
|
|
}
|
|
|
|
|
|
function getMDMethodParams(methItem: MDNav) {
|
|
let result = {};
|
|
|
|
let paramList = methItem.childNav.list().childNav;
|
|
|
|
let paramListItems = paramList
|
|
.listItems();
|
|
|
|
paramListItems.forEach(paramListItem => {
|
|
let paramNameNode = paramListItem.childNav
|
|
.paragraph().childNav
|
|
.emph().childNav;
|
|
|
|
let paramName;
|
|
|
|
if (!paramNameNode.empty) {
|
|
paramName = paramNameNode.text().item.value.replace(/:/, "");
|
|
} else {
|
|
paramName = paramListItem.childNav
|
|
.paragraph().childNav
|
|
.strong().childNav
|
|
.text().item.value;
|
|
}
|
|
|
|
let paramDoc = paramListItem.childNav
|
|
.paragraph().childNav
|
|
.text(t=>true, 1).value; //item.value;
|
|
|
|
result[paramName] = paramDoc.replace(/^[ -]+/, "");
|
|
});
|
|
|
|
return result;
|
|
}
|
|
|
|
|
|
function updatePropDocsFromMD(comp: ComponentInfo, inputDocs, outputDocs, errorMessages) {
|
|
comp.properties.forEach(prop => {
|
|
let propMDDoc: string;
|
|
|
|
if (prop.isInput) {
|
|
propMDDoc = inputDocs[prop.name];
|
|
} else if (prop.isOutput) {
|
|
propMDDoc = outputDocs[prop.name];
|
|
}
|
|
|
|
// If JSDocs are empty but MD docs aren't then the Markdown is presumably more up-to-date.
|
|
if (!prop.docText && propMDDoc) {
|
|
prop.docText = propMDDoc;
|
|
errorMessages.push(`Warning: empty JSDocs for property "${prop.name}" may need sync with the .md file.`);
|
|
}
|
|
});
|
|
}
|
|
|
|
|
|
function updateMethodDocsFromMD(comp: ComponentInfo, methodDocs, errorMessages) {
|
|
comp.methods.forEach(meth => {
|
|
let currMethMD = methodDocs[meth.name]
|
|
|
|
// If JSDocs are empty but MD docs aren't then the Markdown is presumably more up-to-date.
|
|
if (!meth.docText && currMethMD && currMethMD.docText) {
|
|
meth.docText = currMethMD.docText;
|
|
errorMessages.push(`Warning: empty JSDocs for method sig "${meth.name}" may need sync with the .md file.`);
|
|
}
|
|
|
|
meth.params.forEach(param => {
|
|
if (!param.docText && currMethMD && currMethMD.params[param.name])
|
|
{
|
|
param.docText = currMethMD.params[param.name];
|
|
errorMessages.push(`Warning: empty JSDocs for parameter "${param.name} (${meth.name})" may need sync with the .md file.`);
|
|
}
|
|
});
|
|
});
|
|
}
|