mirror of https://github.com/status-im/codimd.git
Update to add expand and collapse toggle for TOC, keep showing second level TOC if there is only one first level TOC
This commit is contained in:
parent
881e92b05a
commit
b6aa045997
|
@ -154,6 +154,14 @@
|
|||
color: #767676;
|
||||
}
|
||||
|
||||
.ui-toc-dropdown .toc.expand ul {
|
||||
display: block;
|
||||
}
|
||||
|
||||
.ui-toc-dropdown .nav > li:first-child:nth-last-child(1) > ul {
|
||||
display: block;
|
||||
}
|
||||
|
||||
.ui-toc-dropdown .nav>li>a:focus,.ui-toc-dropdown .nav>li>a:hover {
|
||||
padding-left: 19px;
|
||||
color: black;
|
||||
|
@ -281,7 +289,7 @@
|
|||
overflow: auto;
|
||||
}
|
||||
|
||||
.back-to-top, .go-to-bottom {
|
||||
.expand-toggle, .back-to-top, .go-to-bottom {
|
||||
display: block;
|
||||
padding: 4px 10px;
|
||||
margin-top: 10px;
|
||||
|
@ -291,12 +299,12 @@
|
|||
color: #999;
|
||||
}
|
||||
|
||||
.back-to-top:hover, .back-to-top:focus, .go-to-bottom:hover, .go-to-bottom:focus {
|
||||
.expand-toggle:hover, .expand-toggle:focus, .back-to-top:hover, .back-to-top:focus, .go-to-bottom:hover, .go-to-bottom:focus {
|
||||
color: #563d7c;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
.go-to-bottom {
|
||||
.back-to-top, .go-to-bottom {
|
||||
margin-top: 0;
|
||||
}
|
||||
|
||||
|
|
File diff suppressed because one or more lines are too long
|
@ -568,6 +568,20 @@ function removeHash() {
|
|||
history.pushState("", document.title, window.location.pathname + window.location.search);
|
||||
}
|
||||
|
||||
var tocExpand = false;
|
||||
|
||||
function checkExpandToggle() {
|
||||
var toc = $('.ui-toc-dropdown .toc');
|
||||
var toggle = $('.expand-toggle');
|
||||
if (!tocExpand) {
|
||||
toc.removeClass('expand');
|
||||
toggle.text('Expand all');
|
||||
} else {
|
||||
toc.addClass('expand');
|
||||
toggle.text('Collapse all');
|
||||
}
|
||||
}
|
||||
|
||||
//toc
|
||||
function generateToc(id) {
|
||||
var target = $('#' + id);
|
||||
|
@ -581,8 +595,16 @@ function generateToc(id) {
|
|||
});
|
||||
if (target.text() == 'undefined')
|
||||
target.html('');
|
||||
var toggle = $('<a class="expand-toggle" href="#">Expand all</a>');
|
||||
var backtotop = $('<a class="back-to-top" href="#">Back to top</a>');
|
||||
var gotobottom = $('<a class="go-to-bottom" href="#">Go to bottom</a>');
|
||||
checkExpandToggle();
|
||||
toggle.click(function (e) {
|
||||
e.preventDefault();
|
||||
e.stopPropagation();
|
||||
tocExpand = !tocExpand;
|
||||
checkExpandToggle();
|
||||
});
|
||||
backtotop.click(function (e) {
|
||||
e.preventDefault();
|
||||
e.stopPropagation();
|
||||
|
@ -597,7 +619,7 @@ function generateToc(id) {
|
|||
scrollToBottom();
|
||||
removeHash();
|
||||
});
|
||||
target.append(backtotop).append(gotobottom);
|
||||
target.append(toggle).append(backtotop).append(gotobottom);
|
||||
}
|
||||
|
||||
//smooth all hash trigger scrolling
|
||||
|
|
Loading…
Reference in New Issue