mirror of
https://github.com/danog/sass-site.git
synced 2024-11-26 20:14:53 +01:00
Surface category labels in the JS API doc sidebar (#587)
This is kind of a hacky workaround until TypeStrong/typedoc#1532 is implemented for real.
This commit is contained in:
parent
2da5e6ef69
commit
67ec2dbdbb
21
source/assets/css/vendor/typedoc/_style.css
vendored
21
source/assets/css/vendor/typedoc/_style.css
vendored
@ -85,10 +85,6 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.typedoc .container-main {
|
|
||||||
padding-bottom: 200px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.typedoc .row {
|
.typedoc .row {
|
||||||
display: flex;
|
display: flex;
|
||||||
position: relative;
|
position: relative;
|
||||||
@ -1274,3 +1270,20 @@ input[type="checkbox"]:checked + .tsd-widget:before {
|
|||||||
.typedoc h1, .typedoc h2, .typedoc h3, .typedoc h4, .typedoc h5, .typedoc h6 {
|
.typedoc h1, .typedoc h2, .typedoc h3, .typedoc h4, .typedoc h5, .typedoc h6 {
|
||||||
font-weight: 700;
|
font-weight: 700;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Undo the global link style for the TypeDoc navigation. */
|
||||||
|
.tsd-navigation a {
|
||||||
|
border-bottom: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Add styles for our custom category labels in the navigation. */
|
||||||
|
.tsd-navigation .sl-tsd-category-label {
|
||||||
|
font-weight: bold;
|
||||||
|
padding-left: 25px;
|
||||||
|
}
|
||||||
|
.tsd-navigation .sl-tsd-category-label span {
|
||||||
|
display: block;
|
||||||
|
padding-top: 2px;
|
||||||
|
padding-bottom: 2px;
|
||||||
|
border-left: 2px solid transparent;
|
||||||
|
}
|
||||||
|
@ -38,6 +38,62 @@ class SassSiteRenderContext extends DefaultThemeRenderContext {
|
|||||||
return context.oldMember(props);
|
return context.oldMember(props);
|
||||||
}, this);
|
}, this);
|
||||||
|
|
||||||
|
// Make categories visible in the sidebar as well as in the main page's index.
|
||||||
|
// Hopefully this will no longer be necessary once TypeStrong/typedoc#1532 is
|
||||||
|
// implemented.
|
||||||
|
oldNavigation = this.navigation;
|
||||||
|
navigation = bind(function(context, props) {
|
||||||
|
const navigation = context.oldNavigation(props);
|
||||||
|
const childrenByCategories = context._groupByCategory(props.model);
|
||||||
|
if (childrenByCategories.size === 0) return navigation;
|
||||||
|
|
||||||
|
const secondary = navigation.children[navigation.children.length - 1];
|
||||||
|
if (!secondary) return navigation;
|
||||||
|
|
||||||
|
const firstLI = secondary.children[0].children[0];
|
||||||
|
const ul = firstLI.props["class"].startsWith("current ")
|
||||||
|
? firstLI.children[1]
|
||||||
|
: secondary.children[0];
|
||||||
|
|
||||||
|
ul.children = Array.from(childrenByCategories).map(([title, children]) =>
|
||||||
|
JSX.createElement(JSX.Fragment, null,
|
||||||
|
JSX.createElement("li", {class: "sl-tsd-category-label"},
|
||||||
|
JSX.createElement("span", null, title)),
|
||||||
|
...children.map(child =>
|
||||||
|
JSX.createElement("li", {class: child.cssClasses},
|
||||||
|
JSX.createElement("a", {
|
||||||
|
href: context.urlTo(child), class: "tsd-kind-icon"
|
||||||
|
}, child.name)))));
|
||||||
|
|
||||||
|
return navigation;
|
||||||
|
}, this);
|
||||||
|
|
||||||
|
// Returns a map from category titles to the set of members of those
|
||||||
|
// categories.
|
||||||
|
_groupByCategory = (model) => {
|
||||||
|
const map = new Map();
|
||||||
|
function addCategoriesToMap(categories) {
|
||||||
|
for (const category of categories) {
|
||||||
|
const children = map.get(category.title);
|
||||||
|
if (children) {
|
||||||
|
children.push(...category.children);
|
||||||
|
} else {
|
||||||
|
map.set(category.title, [...category.children]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (model.categories) {
|
||||||
|
addCategoriesToMap(model.categories);
|
||||||
|
} else if (model.groups) {
|
||||||
|
for (const group of model.groups) {
|
||||||
|
if (group.categories) addCategoriesToMap(group.categories);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return map;
|
||||||
|
};
|
||||||
|
|
||||||
// Add compatibility indicators to the beginning of documentation blocks.
|
// Add compatibility indicators to the beginning of documentation blocks.
|
||||||
oldComment = this.comment;
|
oldComment = this.comment;
|
||||||
comment = bind((context, props) => {
|
comment = bind((context, props) => {
|
||||||
|
Loading…
Reference in New Issue
Block a user