mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-07 13:22:07 -05:00
JSDocs: Move Utils.publishMenu() funcitonality to Render.classes(), but have it not render the template yet, as it is requied by both docs and templatedocs, through the index rendering functions Render.index() (previoulsy Render.menu()) and Render.indexjs (previously Render.packagesjs).
This commit is contained in:
parent
928cd7c39e
commit
2d71ff9c9e
7 changed files with 67 additions and 62 deletions
|
@ -84,9 +84,9 @@ function publish(symbolSet) {
|
||||||
}
|
}
|
||||||
IO.saveFile(publish.conf.packagesDir, name, html);
|
IO.saveFile(publish.conf.packagesDir, name, html);
|
||||||
}
|
}
|
||||||
if (renderMode == 'docs')
|
if (templatedocs) {
|
||||||
Utils.publishMenu();
|
IO.saveFile(publish.conf.outDir, 'packages.js', Render.indexjs());
|
||||||
if (renderMode == 'templatedocs') {
|
} else {
|
||||||
IO.saveFile(publish.conf.outDir, 'packages.js', Render.packagesjs());
|
IO.saveFile(publish.conf.classesDir, 'index.html', Render.index());
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -14,9 +14,9 @@ var Render = new function() {
|
||||||
example: 'example.tmpl',
|
example: 'example.tmpl',
|
||||||
constructor: 'constructor.tmpl',
|
constructor: 'constructor.tmpl',
|
||||||
html: 'html.tmpl',
|
html: 'html.tmpl',
|
||||||
menu: 'packages.tmpl',
|
index: 'index.tmpl',
|
||||||
operator: 'operator.tmpl',
|
indexjs: 'indexjs.tmpl',
|
||||||
packagesjs: 'packagesjs.tmpl'
|
operator: 'operator.tmpl'
|
||||||
};
|
};
|
||||||
publish.classes = [];
|
publish.classes = [];
|
||||||
for (var i in templates) {
|
for (var i in templates) {
|
||||||
|
@ -328,11 +328,64 @@ var Render = new function() {
|
||||||
html: function(content) {
|
html: function(content) {
|
||||||
return templates.html.process(content);
|
return templates.html.process(content);
|
||||||
},
|
},
|
||||||
menu: function(html) {
|
classes: function() {
|
||||||
return templates.menu.process(html);
|
// TODO: Use Template instead?
|
||||||
|
var renderMode = publish.conf.renderMode;
|
||||||
|
load(JSDOC.opt.t + 'classLayout.js');
|
||||||
|
function parseClassNames(classNames) {
|
||||||
|
var out = '';
|
||||||
|
for (var i = 0, l = classNames.length; i < l; i++) {
|
||||||
|
if (typeof classNames[i] == 'string') {
|
||||||
|
var name = classNames[i];
|
||||||
|
out += (name == 'ruler') ? getRuler() : getLink(name);
|
||||||
|
} else {
|
||||||
|
for (var j in classNames[i]) {
|
||||||
|
out += getHeading(j);
|
||||||
|
out += parseClassNames(classNames[i][j]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
function getLink(name) {
|
||||||
|
var link = name;
|
||||||
|
if (name.indexOf(':') > 0) {
|
||||||
|
var names = name.split(':');
|
||||||
|
name = names[0];
|
||||||
|
link = names[1];
|
||||||
|
}
|
||||||
|
if (renderMode == 'docs') {
|
||||||
|
link += '.html';
|
||||||
|
} else if (renderMode == 'templatedocs') {
|
||||||
|
link = link.toLowerCase();
|
||||||
|
link = '/reference/' + (link == '_global_' ? 'global' : link);
|
||||||
|
}
|
||||||
|
return '<li><a href="' + link + '">' + name + '</a></li>\n';
|
||||||
|
}
|
||||||
|
|
||||||
|
function getRuler() {
|
||||||
|
return '<li><hr /></li>\n';
|
||||||
|
}
|
||||||
|
|
||||||
|
function getHeading(title) {
|
||||||
|
return '<li><h3>' + title + '</h3></li>\n';
|
||||||
|
}
|
||||||
|
var first = true,
|
||||||
|
out = '<ul class="package-classes">';
|
||||||
|
for (var i in classLayout) {
|
||||||
|
out += '<li' + (first ? ' class="first">' : '>');
|
||||||
|
out += '<h2>' + i + '</h2></li>\n';
|
||||||
|
out += parseClassNames(classLayout[i]);
|
||||||
|
first = false;
|
||||||
|
}
|
||||||
|
out += '</ul>';
|
||||||
|
return out;
|
||||||
},
|
},
|
||||||
packagesjs: function() {
|
index: function(html) {
|
||||||
return templates.packagesjs.process(publish.classes);
|
return templates.index.process(html);
|
||||||
|
},
|
||||||
|
indexjs: function() {
|
||||||
|
return templates.indexjs.process(publish.classes);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
};
|
};
|
|
@ -41,54 +41,6 @@ var Utils = {
|
||||||
throw Error('Could not delete ' + path);
|
throw Error('Could not delete ' + path);
|
||||||
},
|
},
|
||||||
|
|
||||||
publishMenu: function() {
|
|
||||||
load(JSDOC.opt.t + 'classLayout.js');
|
|
||||||
function parseClassNames(classNames) {
|
|
||||||
var out = '';
|
|
||||||
for (var i = 0, l = classNames.length; i < l; i++) {
|
|
||||||
if (typeof classNames[i] == 'string') {
|
|
||||||
var name = classNames[i];
|
|
||||||
out += (name == 'ruler') ? getRuler() : getLink(name);
|
|
||||||
} else {
|
|
||||||
for (var j in classNames[i]) {
|
|
||||||
out += getHeading(j);
|
|
||||||
out += parseClassNames(classNames[i][j]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return out;
|
|
||||||
}
|
|
||||||
function getLink(name) {
|
|
||||||
var link = name;
|
|
||||||
if (name.indexOf(':') > 0) {
|
|
||||||
var names = name.split(':');
|
|
||||||
name = names[0];
|
|
||||||
link = names[1];
|
|
||||||
}
|
|
||||||
return '<li><a href="' + link + '.html">' + name + '</a></li>\n';
|
|
||||||
}
|
|
||||||
|
|
||||||
function getRuler() {
|
|
||||||
return '<li><hr /></li>\n';
|
|
||||||
}
|
|
||||||
|
|
||||||
function getHeading(title) {
|
|
||||||
return '<li><h3>' + title + '</h3></li>\n';
|
|
||||||
}
|
|
||||||
var first = true,
|
|
||||||
out = '<ul class="package-classes">';
|
|
||||||
for (var i in classLayout) {
|
|
||||||
out += '<li' + (first ? ' class="first">' : '>');
|
|
||||||
out += '<h2>' + i + '</h2></li>\n';
|
|
||||||
out += parseClassNames(classLayout[i]);
|
|
||||||
first = false;
|
|
||||||
}
|
|
||||||
out += '</ul>';
|
|
||||||
|
|
||||||
var classesIndex = Render.menu(out);
|
|
||||||
IO.saveFile(publish.conf.packagesDir, 'packages.html', classesIndex);
|
|
||||||
},
|
|
||||||
|
|
||||||
makeSortby: function(attribute) {
|
makeSortby: function(attribute) {
|
||||||
return function(a, b) {
|
return function(a, b) {
|
||||||
if (a[attribute] != undefined && b[attribute] != undefined) {
|
if (a[attribute] != undefined && b[attribute] != undefined) {
|
||||||
|
|
|
@ -6,7 +6,7 @@ Paper.js API
|
||||||
</title>
|
</title>
|
||||||
</head>
|
</head>
|
||||||
<frameset cols="230,*">
|
<frameset cols="230,*">
|
||||||
<frame src="packages/packages.html" name="packageListFrame" title="All Packages">
|
<frame src="classes/index.html" name="packageListFrame" title="All Packages">
|
||||||
<frame src="about:blank" name="classFrame" title="Class and interface descriptions">
|
<frame src="about:blank" name="classFrame" title="Class and interface descriptions">
|
||||||
</frameset>
|
</frameset>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -11,6 +11,6 @@
|
||||||
<body class="reference">
|
<body class="reference">
|
||||||
<div class="reference-packages">
|
<div class="reference-packages">
|
||||||
<h1>Paper.js</h1>
|
<h1>Paper.js</h1>
|
||||||
{+ data +}
|
{+ Render.classes() +}
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
|
@ -0,0 +1 @@
|
||||||
|
createPackage("", {+ JSON.stringify(data) +}, "", {+ JSON.stringify(Render.classes()) +});
|
|
@ -1 +0,0 @@
|
||||||
createPackage("Paper", {+ JSON.stringify(data) +});
|
|
Loading…
Reference in a new issue