Wikipedia Smooth Scroll

Adds smooth scrolling for in-page links on Wikipedia and sister sites

K instalaci tototo skriptu si budete muset nainstalovat rozšíření jako Tampermonkey, Greasemonkey nebo Violentmonkey.

You will need to install an extension such as Tampermonkey to install this script.

K instalaci tohoto skriptu si budete muset nainstalovat rozšíření jako Tampermonkey nebo Violentmonkey.

K instalaci tohoto skriptu si budete muset nainstalovat rozšíření jako Tampermonkey nebo Userscripts.

You will need to install an extension such as Tampermonkey to install this script.

K instalaci tohoto skriptu si budete muset nainstalovat manažer uživatelských skriptů.

(Už mám manažer uživatelských skriptů, nechte mě ho nainstalovat!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(Už mám manažer uživatelských stylů, nechte mě ho nainstalovat!)

// ==UserScript==
// @name         Wikipedia Smooth Scroll
// @description  Adds smooth scrolling for in-page links on Wikipedia and sister sites
// @version      0.2
// @author       Daniel Bronshtein
// @license      MIT
// @homepage     https://github.com/DaniBr/wikipedia-smooth-scroll
// @grant        none
// @run-at       document-idle
// @match https://*.wikipedia.org/wiki/*
// @match https://*.wiktionary.org/wiki/*
// @match https://*.wikibooks.org/wiki/*
// @match https://*.wikiquote.org/wiki/*
// @match https://*.wikivoyage.org/wiki/*
// @match https://*.wikisource.org/wiki/*
// @match https://*.wikinews.org/wiki/*
// @match https://*.wikiversity.org/wiki/*
// @match https://*.wikifunctions.org/wiki/*
// @namespace https://greasyfork.org/users/1450663
// ==/UserScript==
(function(){
  function scrollSmoothlyTo(element) {
    element.scrollIntoView({
      behavior: 'smooth'
    })
  }
  
  function getIdFromInternalLink(link) {
    try {
      return decodeURIComponent(link.getAttribute('href').substring(1))
    } catch (e) {
      return link.getAttribute('href').substring(1)
    }
  }
  
  function handleInternalLinkClick(event) {
    const link = event.currentTarget
    const id = getIdFromInternalLink(link)
    const element = document.getElementById(id)
    
    if (!element) return
    scrollSmoothlyTo(element)
    history.pushState({ scrollTo: id }, '', link.href)
    event.preventDefault()
  }
  
  document.querySelectorAll("a[href^='#']").forEach(link => {
    link.addEventListener('click', handleInternalLinkClick)
  })
  
  //ToDo: add smooth scrolling on popstate (when navigating back and forward)
})()