mirror of
https://github.com/squidfunk/mkdocs-material.git
synced 2024-06-14 11:52:32 +03:00
Add -webkit-overflow-scrolling via JavaScript on navigation
This commit is contained in:
parent
be5c94128d
commit
e1310aa9ee
File diff suppressed because one or more lines are too long
1
material/assets/stylesheets/application-7515027b77.css
Normal file
1
material/assets/stylesheets/application-7515027b77.css
Normal file
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -36,7 +36,7 @@
|
|||||||
{% include "partials/webfonts.html" %}
|
{% include "partials/webfonts.html" %}
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
{% block styles %}
|
{% block styles %}
|
||||||
<link rel="stylesheet" href="{{ base_url }}/assets/stylesheets/application-f2889ef118.css">
|
<link rel="stylesheet" href="{{ base_url }}/assets/stylesheets/application-7515027b77.css">
|
||||||
{% if config.extra.palette %}
|
{% if config.extra.palette %}
|
||||||
<link rel="stylesheet" href="{{ base_url }}/assets/stylesheets/application-535e87ca3f.palette.css">
|
<link rel="stylesheet" href="{{ base_url }}/assets/stylesheets/application-535e87ca3f.palette.css">
|
||||||
{% endif %}
|
{% endif %}
|
||||||
@ -106,7 +106,7 @@
|
|||||||
<script src="https://cdn.mathjax.org/{{ path }}"></script>
|
<script src="https://cdn.mathjax.org/{{ path }}"></script>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
<script src="{{ base_url }}/assets/javascripts/application-34d9ef09a7.js"></script>
|
<script src="{{ base_url }}/assets/javascripts/application-7d27d432c4.js"></script>
|
||||||
<script>
|
<script>
|
||||||
/* Configuration for application */
|
/* Configuration for application */
|
||||||
var config = {
|
var config = {
|
||||||
|
@ -8,10 +8,8 @@
|
|||||||
<label class="md-nav__link" for="{{ path }}">
|
<label class="md-nav__link" for="{{ path }}">
|
||||||
{{ nav_item.title }}
|
{{ nav_item.title }}
|
||||||
</label>
|
</label>
|
||||||
<nav class="md-nav" data-md-collapse>
|
<nav class="md-nav" data-md-component="collapsible">
|
||||||
<label class="md-nav__title" for="{{ path }}">
|
<label class="md-nav__title" for="{{ path }}"></label>
|
||||||
{{ nav_item.title }}
|
|
||||||
</label>
|
|
||||||
<ul class="md-nav__list">
|
<ul class="md-nav__list">
|
||||||
{% for nav_item in nav_item.children %}
|
{% for nav_item in nav_item.children %}
|
||||||
{% set temp = path %}
|
{% set temp = path %}
|
||||||
|
@ -119,12 +119,19 @@ export default class Application {
|
|||||||
new Material.Nav.Blur("[data-md-component=toc] .md-nav__link")))
|
new Material.Nav.Blur("[data-md-component=toc] .md-nav__link")))
|
||||||
|
|
||||||
/* Component: collapsible elements for navigation */
|
/* Component: collapsible elements for navigation */
|
||||||
const collapsibles = document.querySelectorAll("[data-md-collapse]")
|
const collapsibles =
|
||||||
|
document.querySelectorAll("[data-md-component=collapsible]")
|
||||||
for (const collapse of collapsibles)
|
for (const collapse of collapsibles)
|
||||||
new Material.Event.MatchMedia("(min-width: 1200px)",
|
new Material.Event.MatchMedia("(min-width: 1200px)",
|
||||||
new Material.Event.Listener(collapse.previousElementSibling, "click",
|
new Material.Event.Listener(collapse.previousElementSibling, "click",
|
||||||
new Material.Nav.Collapse(collapse)))
|
new Material.Nav.Collapse(collapse)))
|
||||||
|
|
||||||
|
/* Component: pane monitor for iOS scrolling fixes */
|
||||||
|
new Material.Event.MatchMedia("(max-width: 1199px)",
|
||||||
|
new Material.Event.Listener(
|
||||||
|
"[data-md-component=navigation] [data-md-toggle]", "change",
|
||||||
|
new Material.Nav.Scrolling("[data-md-component=navigation] nav")))
|
||||||
|
|
||||||
/* Component: search body lock for mobile */
|
/* Component: search body lock for mobile */
|
||||||
new Material.Event.MatchMedia("(max-width: 959px)",
|
new Material.Event.MatchMedia("(max-width: 959px)",
|
||||||
new Material.Event.Listener("[data-md-toggle=search]", "change",
|
new Material.Event.Listener("[data-md-toggle=search]", "change",
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
|
|
||||||
import Blur from "./Nav/Blur"
|
import Blur from "./Nav/Blur"
|
||||||
import Collapse from "./Nav/Collapse"
|
import Collapse from "./Nav/Collapse"
|
||||||
|
import Scrolling from "./Nav/Scrolling"
|
||||||
|
|
||||||
/* ----------------------------------------------------------------------------
|
/* ----------------------------------------------------------------------------
|
||||||
* Module
|
* Module
|
||||||
@ -29,5 +30,6 @@ import Collapse from "./Nav/Collapse"
|
|||||||
|
|
||||||
export default {
|
export default {
|
||||||
Blur,
|
Blur,
|
||||||
Collapse
|
Collapse,
|
||||||
|
Scrolling
|
||||||
}
|
}
|
||||||
|
@ -82,7 +82,7 @@ export default class Blur {
|
|||||||
for (let i = this.index_; i >= 0; i--) {
|
for (let i = this.index_; i >= 0; i--) {
|
||||||
if (this.anchors_[i] > offset) {
|
if (this.anchors_[i] > offset) {
|
||||||
if (i > 0)
|
if (i > 0)
|
||||||
delete this.els_[i - 1].dataset.mdState
|
this.els_[i - 1].dataset.mdState = ""
|
||||||
} else {
|
} else {
|
||||||
this.index_ = i
|
this.index_ = i
|
||||||
break
|
break
|
||||||
@ -99,7 +99,7 @@ export default class Blur {
|
|||||||
*/
|
*/
|
||||||
reset() {
|
reset() {
|
||||||
for (const el of this.els_)
|
for (const el of this.els_)
|
||||||
delete el.dataset.mdState
|
el.dataset.mdState = ""
|
||||||
|
|
||||||
/* Reset index and page y-offset */
|
/* Reset index and page y-offset */
|
||||||
this.index_ = 0
|
this.index_ = 0
|
||||||
|
@ -59,7 +59,7 @@ export default class Collapse {
|
|||||||
|
|
||||||
/* Read height and unset pseudo-toggled state */
|
/* Read height and unset pseudo-toggled state */
|
||||||
const height = this.el_.getBoundingClientRect().height
|
const height = this.el_.getBoundingClientRect().height
|
||||||
delete this.el_.dataset.mdState
|
this.el_.dataset.mdState = ""
|
||||||
|
|
||||||
/* Set initial state and animate */
|
/* Set initial state and animate */
|
||||||
this.el_.style.maxHeight = "0px"
|
this.el_.style.maxHeight = "0px"
|
||||||
@ -70,8 +70,8 @@ export default class Collapse {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Remove state on end of transition */
|
/* Remove state on end of transition */
|
||||||
const end = function(ev) {
|
const end = ev => {
|
||||||
delete ev.target.dataset.mdState
|
ev.target.dataset.mdState = ""
|
||||||
ev.target.style.maxHeight = ""
|
ev.target.style.maxHeight = ""
|
||||||
|
|
||||||
/* Only fire once, so directly remove event listener */
|
/* Only fire once, so directly remove event listener */
|
||||||
@ -84,7 +84,7 @@ export default class Collapse {
|
|||||||
* Reset height and pseudo-toggled state
|
* Reset height and pseudo-toggled state
|
||||||
*/
|
*/
|
||||||
reset() {
|
reset() {
|
||||||
delete this.el_.dataset.mdState
|
this.el_.dataset.mdState = ""
|
||||||
this.el_.style.maxHeight = ""
|
this.el_.style.maxHeight = ""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
137
src/assets/javascripts/components/Material/Nav/Scrolling.js
Normal file
137
src/assets/javascripts/components/Material/Nav/Scrolling.js
Normal file
@ -0,0 +1,137 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2016 Martin Donath <martin.donath@squidfunk.com>
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
* of this software and associated documentation files (the "Software"), to
|
||||||
|
* deal in the Software without restriction, including without limitation the
|
||||||
|
* rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
||||||
|
* sell copies of the Software, and to permit persons to whom the Software is
|
||||||
|
* furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included in
|
||||||
|
* all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
|
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
||||||
|
* IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* ----------------------------------------------------------------------------
|
||||||
|
* Class
|
||||||
|
* ------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
export default class Scrolling {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set overflow scrolling on the current active pane (for iOS)
|
||||||
|
*
|
||||||
|
* @constructor
|
||||||
|
* @param {(string|HTMLElement)} el - Selector or HTML element
|
||||||
|
*/
|
||||||
|
constructor(el) {
|
||||||
|
this.el_ = (typeof el === "string")
|
||||||
|
? document.querySelector(el)
|
||||||
|
: el
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Setup panes
|
||||||
|
*/
|
||||||
|
setup() {
|
||||||
|
|
||||||
|
/* Initially set overflow scrolling on main pane */
|
||||||
|
this.el_.children[1].style.webkitOverflowScrolling = "touch"
|
||||||
|
|
||||||
|
/* Find all toggles and check which one is active */
|
||||||
|
const toggles = this.el_.querySelectorAll("[data-md-toggle]")
|
||||||
|
for (const toggle of toggles) {
|
||||||
|
if (!toggle.checked)
|
||||||
|
return
|
||||||
|
|
||||||
|
/* Find corresponding navigational pane */
|
||||||
|
let pane = toggle.nextElementSibling
|
||||||
|
while (pane.tagName !== "NAV")
|
||||||
|
pane = pane.nextElementSibling
|
||||||
|
|
||||||
|
/* Find current and parent list elements */
|
||||||
|
const parent = toggle.parentNode.parentNode
|
||||||
|
const target = pane.children[pane.children.length - 1]
|
||||||
|
|
||||||
|
/* Always reset all lists when transitioning */
|
||||||
|
parent.style.webkitOverflowScrolling = ""
|
||||||
|
target.style.webkitOverflowScrolling = "touch"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update active panes
|
||||||
|
*
|
||||||
|
* @param {Event} ev - Change event
|
||||||
|
*/
|
||||||
|
update(ev) {
|
||||||
|
|
||||||
|
/* Find corresponding navigational pane */
|
||||||
|
let pane = ev.target.nextElementSibling
|
||||||
|
while (pane.tagName !== "NAV")
|
||||||
|
pane = pane.nextElementSibling
|
||||||
|
|
||||||
|
/* Find current and parent list elements */
|
||||||
|
const parent = ev.target.parentNode.parentNode
|
||||||
|
const target = pane.children[pane.children.length - 1]
|
||||||
|
|
||||||
|
/* Always reset all lists when transitioning */
|
||||||
|
parent.style.webkitOverflowScrolling = ""
|
||||||
|
target.style.webkitOverflowScrolling = ""
|
||||||
|
|
||||||
|
/* Set overflow scrolling on parent */
|
||||||
|
if (!ev.target.checked) {
|
||||||
|
const end = () => {
|
||||||
|
parent.style.webkitOverflowScrolling = "touch"
|
||||||
|
pane.removeEventListener("transitionend", end)
|
||||||
|
}
|
||||||
|
pane.addEventListener("transitionend", end, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Set overflow scrolling on target */
|
||||||
|
if (ev.target.checked) {
|
||||||
|
const end = () => {
|
||||||
|
target.style.webkitOverflowScrolling = "touch"
|
||||||
|
pane.removeEventListener("transitionend", end, false)
|
||||||
|
}
|
||||||
|
pane.addEventListener("transitionend", end, false)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reset panes
|
||||||
|
*/
|
||||||
|
reset() {
|
||||||
|
|
||||||
|
/* Reset overflow scrolling on main pane */
|
||||||
|
this.el_.children[1].style.webkitOverflowScrolling = ""
|
||||||
|
|
||||||
|
/* Find all toggles and check which one is active */
|
||||||
|
const toggles = this.el_.querySelectorAll("[data-md-toggle]")
|
||||||
|
for (const toggle of toggles) {
|
||||||
|
if (!toggle.checked)
|
||||||
|
return
|
||||||
|
|
||||||
|
/* Find corresponding navigational pane */
|
||||||
|
let pane = toggle.nextElementSibling
|
||||||
|
while (pane.tagName !== "NAV")
|
||||||
|
pane = pane.nextElementSibling
|
||||||
|
|
||||||
|
/* Find current and parent list elements */
|
||||||
|
const parent = toggle.parentNode.parentNode
|
||||||
|
const target = pane.children[pane.children.length - 1]
|
||||||
|
|
||||||
|
/* Always reset all lists when transitioning */
|
||||||
|
parent.style.webkitOverflowScrolling = ""
|
||||||
|
target.style.webkitOverflowScrolling = ""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -66,7 +66,7 @@ export default class Lock {
|
|||||||
|
|
||||||
/* Exiting search mode */
|
/* Exiting search mode */
|
||||||
} else {
|
} else {
|
||||||
delete document.body.dataset.mdState
|
document.body.dataset.mdState = ""
|
||||||
|
|
||||||
/* Scroll to former position, but wait for 100ms to prevent flashes on
|
/* Scroll to former position, but wait for 100ms to prevent flashes on
|
||||||
iOS. A short timeout seems to do the trick */
|
iOS. A short timeout seems to do the trick */
|
||||||
@ -81,8 +81,8 @@ export default class Lock {
|
|||||||
* Reset locked state and page y-offset
|
* Reset locked state and page y-offset
|
||||||
*/
|
*/
|
||||||
reset() {
|
reset() {
|
||||||
if (document.body.dataset.mdState)
|
if (document.body.dataset.mdState === "lock")
|
||||||
window.scrollTo(0, this.offset_)
|
window.scrollTo(0, this.offset_)
|
||||||
delete document.body.dataset.mdState
|
document.body.dataset.mdState = ""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -86,7 +86,7 @@ export default class Position {
|
|||||||
|
|
||||||
/* Sidebar should be unlocked, if locked */
|
/* Sidebar should be unlocked, if locked */
|
||||||
} else if (this.el_.dataset.mdState === "lock") {
|
} else if (this.el_.dataset.mdState === "lock") {
|
||||||
delete this.el_.dataset.mdState
|
this.el_.dataset.mdState = ""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -94,7 +94,7 @@ export default class Position {
|
|||||||
* Reset locked state and height
|
* Reset locked state and height
|
||||||
*/
|
*/
|
||||||
reset() {
|
reset() {
|
||||||
delete this.el_.dataset.mdState
|
this.el_.dataset.mdState = ""
|
||||||
this.el_.style.height = ""
|
this.el_.style.height = ""
|
||||||
this.height_ = 0
|
this.height_ = 0
|
||||||
}
|
}
|
||||||
|
@ -90,7 +90,7 @@
|
|||||||
transition: background 0.25s;
|
transition: background 0.25s;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Link title
|
// Link title - set line height to match icon for correct alignment
|
||||||
&__title {
|
&__title {
|
||||||
position: relative;
|
position: relative;
|
||||||
padding: 0 2.0rem;
|
padding: 0 2.0rem;
|
||||||
@ -169,7 +169,7 @@
|
|||||||
|
|
||||||
// Adjust line-height to match height for correct alignment
|
// Adjust line-height to match height for correct alignment
|
||||||
&::before {
|
&::before {
|
||||||
line-height: 3.2rem;
|
line-height: 2.0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -94,7 +94,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Header title
|
// Header title - set line height to match icon for correct alignment
|
||||||
&__title {
|
&__title {
|
||||||
padding: 0 2.0rem;
|
padding: 0 2.0rem;
|
||||||
font-size: 1.8rem;
|
font-size: 1.8rem;
|
||||||
|
@ -37,10 +37,8 @@
|
|||||||
<label class="md-nav__link" for="{{ path }}">
|
<label class="md-nav__link" for="{{ path }}">
|
||||||
{{ nav_item.title }}
|
{{ nav_item.title }}
|
||||||
</label>
|
</label>
|
||||||
<nav class="md-nav" data-md-collapse>
|
<nav class="md-nav" data-md-component="collapsible">
|
||||||
<label class="md-nav__title" for="{{ path }}">
|
<label class="md-nav__title" for="{{ path }}"></label>
|
||||||
{{ nav_item.title }}
|
|
||||||
</label>
|
|
||||||
<ul class="md-nav__list">
|
<ul class="md-nav__list">
|
||||||
|
|
||||||
<!-- Render nested item list -->
|
<!-- Render nested item list -->
|
||||||
|
Loading…
Reference in New Issue
Block a user