mirror of
https://github.com/squidfunk/mkdocs-material.git
synced 2024-06-14 11:52:32 +03:00
Fixed sidebar not focusing active item when navigation is huge
This commit is contained in:
parent
54b98b23e5
commit
26c08f1f38
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
1
material/assets/stylesheets/extra.e916454c.min.css
vendored
Normal file
1
material/assets/stylesheets/extra.e916454c.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
1
material/assets/stylesheets/extra.e916454c.min.css.map
Normal file
1
material/assets/stylesheets/extra.e916454c.min.css.map
Normal file
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -234,13 +234,13 @@
|
||||
</script>
|
||||
{% endblock %}
|
||||
{% block scripts %}
|
||||
<script src="{{ 'assets/javascripts/bundle.c45ce4b3.min.js' | url }}"></script>
|
||||
<script src="{{ 'assets/javascripts/bundle.6d7e1051.min.js' | url }}"></script>
|
||||
{% for path in config.extra_javascript %}
|
||||
<script src="{{ path | url }}"></script>
|
||||
{% endfor %}
|
||||
{% endblock %}
|
||||
{% if page.meta and page.meta.ᴴₒᴴₒᴴₒ %}
|
||||
<link rel="stylesheet" href="{{ 'assets/stylesheets/extra.ef53c8a4.min.css' | url }}">
|
||||
<link rel="stylesheet" href="{{ 'assets/stylesheets/extra.e916454c.min.css' | url }}">
|
||||
<script src="{{ 'assets/javascripts/extra/bundle.cfb3feee.min.js' | url }}" defer></script>
|
||||
{% endif %}
|
||||
</body>
|
||||
|
@ -29,9 +29,8 @@ import {
|
||||
defer,
|
||||
distinctUntilChanged,
|
||||
finalize,
|
||||
first,
|
||||
map,
|
||||
observeOn,
|
||||
take,
|
||||
tap,
|
||||
withLatestFrom
|
||||
} from "rxjs"
|
||||
@ -154,44 +153,42 @@ export function mountSidebar(
|
||||
const { y } = getElementOffset(inner)
|
||||
return defer(() => {
|
||||
const push$ = new Subject<Sidebar>()
|
||||
push$
|
||||
const next$ = push$
|
||||
.pipe(
|
||||
auditTime(0, animationFrameScheduler),
|
||||
withLatestFrom(header$)
|
||||
auditTime(0, animationFrameScheduler)
|
||||
)
|
||||
.subscribe({
|
||||
|
||||
/* Handle emission */
|
||||
next([{ height }, { height: offset }]) {
|
||||
inner.style.height = `${height - 2 * y}px`
|
||||
el.style.top = `${offset}px`
|
||||
},
|
||||
/* Update sidebar height and offset */
|
||||
next$.pipe(withLatestFrom(header$))
|
||||
.subscribe({
|
||||
|
||||
/* Handle complete */
|
||||
complete() {
|
||||
inner.style.height = ""
|
||||
el.style.top = ""
|
||||
}
|
||||
})
|
||||
/* Handle emission */
|
||||
next([{ height }, { height: offset }]) {
|
||||
inner.style.height = `${height - 2 * y}px`
|
||||
el.style.top = `${offset}px`
|
||||
},
|
||||
|
||||
/* Handle complete */
|
||||
complete() {
|
||||
inner.style.height = ""
|
||||
el.style.top = ""
|
||||
}
|
||||
})
|
||||
|
||||
/* Bring active item into view on initial load */
|
||||
push$
|
||||
.pipe(
|
||||
observeOn(animationFrameScheduler),
|
||||
take(1)
|
||||
)
|
||||
.subscribe(() => {
|
||||
for (const item of getElements(".md-nav__link--active[href]", el)) {
|
||||
const container = getElementContainer(item)
|
||||
if (typeof container !== "undefined") {
|
||||
const offset = item.offsetTop - container.offsetTop
|
||||
const { height } = getElementSize(container)
|
||||
container.scrollTo({
|
||||
top: offset - height / 2
|
||||
})
|
||||
}
|
||||
next$.pipe(first())
|
||||
.subscribe(() => {
|
||||
for (const item of getElements(".md-nav__link--active[href]", el)) {
|
||||
const container = getElementContainer(item)
|
||||
if (typeof container !== "undefined") {
|
||||
const offset = item.offsetTop - container.offsetTop
|
||||
const { height } = getElementSize(container)
|
||||
container.scrollTo({
|
||||
top: offset - height / 2
|
||||
})
|
||||
}
|
||||
})
|
||||
}
|
||||
})
|
||||
|
||||
/* Create and return component */
|
||||
return watchSidebar(el, options)
|
||||
|
Loading…
x
Reference in New Issue
Block a user