swup 4.0.0-rc.14 → 4.0.0-rc.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (83) hide show
  1. package/README.md +100 -0
  2. package/dist/Swup.cjs +1 -1
  3. package/dist/Swup.cjs.map +1 -1
  4. package/dist/Swup.modern.js +1 -1
  5. package/dist/Swup.modern.js.map +1 -1
  6. package/dist/Swup.module.js +1 -1
  7. package/dist/Swup.module.js.map +1 -1
  8. package/dist/Swup.umd.js +1 -1
  9. package/dist/Swup.umd.js.map +1 -1
  10. package/dist/types/Swup.d.ts +62 -54
  11. package/dist/types/helpers/Location.d.ts +10 -7
  12. package/dist/types/helpers/delegateEvent.d.ts +3 -5
  13. package/dist/types/helpers/matchPath.d.ts +3 -0
  14. package/dist/types/helpers.d.ts +7 -10
  15. package/dist/types/index.d.ts +9 -6
  16. package/dist/types/modules/Cache.d.ts +15 -15
  17. package/dist/types/modules/Classes.d.ts +13 -0
  18. package/dist/types/modules/Context.d.ts +73 -0
  19. package/dist/types/modules/Hooks.d.ts +241 -0
  20. package/dist/types/modules/__test__/hooks.test.d.ts +1 -0
  21. package/dist/types/modules/__test__/replaceContent.test.d.ts +1 -0
  22. package/dist/types/modules/awaitAnimations.d.ts +21 -0
  23. package/dist/types/modules/enterPage.d.ts +6 -3
  24. package/dist/types/modules/fetchPage.d.ts +24 -4
  25. package/dist/types/modules/getAnchorElement.d.ts +8 -0
  26. package/dist/types/modules/leavePage.d.ts +6 -3
  27. package/dist/types/modules/plugins.d.ts +12 -5
  28. package/dist/types/modules/renderPage.d.ts +7 -7
  29. package/dist/types/modules/replaceContent.d.ts +8 -11
  30. package/dist/types/modules/visit.d.ts +33 -0
  31. package/dist/types/utils/index.d.ts +3 -1
  32. package/dist/types/utils.d.ts +1 -1
  33. package/package.json +7 -6
  34. package/src/Swup.ts +83 -65
  35. package/src/__test__/index.test.ts +3 -3
  36. package/src/helpers/Location.ts +2 -2
  37. package/src/helpers/delegateEvent.ts +2 -2
  38. package/src/helpers.ts +0 -1
  39. package/src/index.ts +34 -4
  40. package/src/modules/Cache.ts +2 -2
  41. package/src/modules/Classes.ts +48 -0
  42. package/src/modules/Context.ts +49 -19
  43. package/src/modules/Hooks.ts +103 -83
  44. package/src/modules/__test__/cache.test.ts +6 -6
  45. package/src/modules/__test__/hooks.test.ts +111 -40
  46. package/src/modules/__test__/replaceContent.test.ts +92 -0
  47. package/src/modules/{getAnimationPromises.ts → awaitAnimations.ts} +13 -18
  48. package/src/modules/enterPage.ts +21 -17
  49. package/src/modules/fetchPage.ts +12 -12
  50. package/src/modules/getAnchorElement.ts +2 -1
  51. package/src/modules/leavePage.ts +16 -12
  52. package/src/modules/plugins.ts +11 -8
  53. package/src/modules/renderPage.ts +28 -18
  54. package/src/modules/replaceContent.ts +24 -16
  55. package/src/modules/visit.ts +143 -0
  56. package/src/utils/index.ts +1 -2
  57. package/dist/types/helpers/cleanupAnimationClasses.d.ts +0 -2
  58. package/dist/types/helpers/fetch.d.ts +0 -5
  59. package/dist/types/helpers/getDataFromHtml.d.ts +0 -7
  60. package/dist/types/helpers/markSwupElements.d.ts +0 -1
  61. package/dist/types/modules/destroy.d.ts +0 -2
  62. package/dist/types/modules/enable.d.ts +0 -2
  63. package/dist/types/modules/events.d.ts +0 -33
  64. package/dist/types/modules/getAnimationPromises.d.ts +0 -7
  65. package/dist/types/modules/getPageData.d.ts +0 -6
  66. package/dist/types/modules/handleLinkToSamePage.d.ts +0 -2
  67. package/dist/types/modules/isSameResolvedUrl.d.ts +0 -8
  68. package/dist/types/modules/linkClickHandler.d.ts +0 -3
  69. package/dist/types/modules/loadPage.d.ts +0 -12
  70. package/dist/types/modules/off.d.ts +0 -3
  71. package/dist/types/modules/on.d.ts +0 -5
  72. package/dist/types/modules/popStateHandler.d.ts +0 -2
  73. package/dist/types/modules/resolveUrl.d.ts +0 -7
  74. package/dist/types/modules/shouldIgnoreVisit.d.ts +0 -4
  75. package/dist/types/modules/transitions.d.ts +0 -6
  76. package/dist/types/modules/triggerEvent.d.ts +0 -3
  77. package/dist/types/modules/triggerWillOpenNewWindow.d.ts +0 -2
  78. package/dist/types/modules/updateTransition.d.ts +0 -2
  79. package/readme.md +0 -78
  80. package/src/helpers/cleanupAnimationClasses.ts +0 -8
  81. package/src/modules/loadPage.ts +0 -99
  82. /package/dist/types/{modules/__test__/events.test.d.ts → helpers/__test__/matchPath.test.d.ts} +0 -0
  83. /package/dist/types/modules/__test__/{fetchPage.test.d.ts → cache.test.d.ts} +0 -0
package/README.md ADDED
@@ -0,0 +1,100 @@
1
+ <div align="center">
2
+
3
+ **swup 4 is released  🎉  Check out the [release notes](https://swup.js.org/announcements/swup-4/) and [upgrade guide](https://swup.js.org/getting-started/upgrading/).**
4
+
5
+ </div>
6
+
7
+ <br>
8
+
9
+ <p align="center">
10
+ <img width="280" alt="swup" src="https://swup.js.org/assets/images/swup-logo.svg">
11
+ </p>
12
+
13
+ <div align="center">
14
+
15
+ [![npm version](https://img.shields.io/npm/v/swup.svg)](https://www.npmjs.com/package/swup)
16
+ [![Bundle size](https://img.shields.io/bundlephobia/minzip/swup?label=size)](https://bundlephobia.com/package/swup)
17
+ [![npm downloads](https://img.shields.io/npm/dt/swup.svg)](https://www.npmjs.com/package/swup)
18
+ [![Test status](https://img.shields.io/github/actions/workflow/status/swup/swup/e2e-tests.yml?branch=master&label=tests)](https://github.com/swup/swup/actions/workflows/e2e-tests.yml)
19
+ [![License](https://img.shields.io/github/license/swup/swup.svg)](https://github.com/swup/swup/blob/master/LICENSE)
20
+
21
+ </div>
22
+
23
+ <br>
24
+
25
+ # Swup
26
+
27
+ Versatile and extensible **page transition library** for server-rendered websites.
28
+
29
+ [Features](#features) •
30
+ [Demos](#demos) •
31
+ [Plugins](#plugins) •
32
+ [Themes](#themes) •
33
+ [Documentation](https://swup.js.org/getting-started) •
34
+ [Discussions](https://github.com/swup/swup/discussions)
35
+
36
+ ## Overview
37
+
38
+ Swup adds **page transitions** to server-rendered websites. It manages the complete page load lifecycle
39
+ and smoothly animates between the current and next page. In addition, it offers many other
40
+ quality-of-life improvements like **caching**, **smart preloading**, native **browser history** and
41
+ enhanced **accessibility**.
42
+
43
+ Make your site feel like a snappy single-page app — without any of the complexity.
44
+
45
+ ## Features
46
+
47
+ - ✏️ Works out of the box with [minimal markup](https://swup.js.org/getting-started/example/)
48
+ - ✨ Auto-detects [CSS transitions](https://swup.js.org/getting-started/how-it-works/) & animations for perfect timing
49
+ - 🔗 Updates URLs and preserves native [browser history](https://swup.js.org/options/#animatehistorybrowsing)
50
+ - 🏓 Manages the scroll position between pages and anchor links
51
+ - 🚀 Uses a [cache](https://swup.js.org/api/cache/) to speed up subsequent page loads
52
+ - 📡 Offers [hooks](https://swup.js.org/hooks/) to customize and extend the page load lifecycle
53
+ - 🔌 Has a powerful [plugin system](https://swup.js.org/plugins/) and many official and third-party plugins
54
+ - 🎨 Provides ready-to-go [themes](https://swup.js.org/themes/) to get started quickly
55
+
56
+ ## Demos
57
+
58
+ Explore our [interactive demos](https://swup.js.org/getting-started/demos/) to see swup in action.
59
+
60
+ ## Documentation
61
+
62
+ Visit our [official documentation](https://swup.js.org/getting-started) to learn more.
63
+
64
+ ## Plugins
65
+
66
+ Swup is small by design. Extended features can be added via [plugins](https://swup.js.org/plugins/):
67
+
68
+ - Display a [progress bar](https://swup.js.org/plugins/progress-plugin/) while loading
69
+ - Enable [smooth scrolling](https://swup.js.org/plugins/scroll-plugin/) between visits
70
+ - Update [meta tags and stylesheets](https://swup.js.org/plugins/head-plugin/) after page loads
71
+ - Add support for [preloading pages](https://swup.js.org/plugins/preload-plugin/) in the background
72
+ - Improve [accessibility](https://swup.js.org/plugins/a11y-plugin/) for screen readers
73
+ - Perform your [animations in JS](https://swup.js.org/plugins/js-plugin/) instead of CSS transitions
74
+ - Animate [form submissions](https://swup.js.org/plugins/forms-plugin/)
75
+ - Get help in [debug mode](https://swup.js.org/plugins/debug-plugin/)
76
+
77
+ Check out the list of [official plugins](https://swup.js.org/plugins/) and [third-party integrations](https://swup.js.org/third-party-integrations/).
78
+
79
+ ## Themes
80
+
81
+ Get started quickly with one of three official themes: [fade](https://swup.js.org/themes/fade-theme/),
82
+ [slide](https://swup.js.org/themes/slide-theme/), and [overlay](https://swup.js.org/themes/overlay-theme/).
83
+
84
+ ## Examples
85
+
86
+ <img src="https://user-images.githubusercontent.com/9338324/49190360-50125480-f372-11e8-89e9-d2fb091a2240.gif" width="100%">
87
+
88
+ Take a look at the [interactive demos](https://swup.js.org/getting-started/demos/) and
89
+ [sites using swup](https://github.com/swup/swup/discussions/333) for more examples.
90
+
91
+ ## Having trouble?
92
+
93
+ If you're having trouble implementing swup, check out the [Common Issues](https://swup.js.org/other/common-issues) section of the docs, look at [closed issues](https://github.com/swup/swup/issues?q=is%3Aissue+is%3Aclosed) or create a [new discussion](https://github.com/swup/swup/discussions/new).
94
+
95
+ ## Want to Contribute?
96
+
97
+ <a href="https://github.com/swup/swup/discussions/424">We're looking for maintainers!</a>   👀
98
+
99
+ Become a sponsor on [Open Collective](https://opencollective.com/swup) or support development through
100
+ [GitHub sponsors](https://github.com/sponsors/gmrchk).
package/dist/Swup.cjs CHANGED
@@ -1,2 +1,2 @@
1
- function t(t){return t&&"object"==typeof t&&"default"in t?t:{default:t}}var e=/*#__PURE__*/t(require("delegate-it"));const n=(t,e)=>String(t).toLowerCase().replace(/[\s/_.]+/g,"-").replace(/[^\w-]+/g,"").replace(/--+/g,"-").replace(/^-+|-+$/g,"")||e||"",i=function(t){let{hash:e}=void 0===t?{}:t;return location.pathname+location.search+(e?location.hash:"")},s=function(t,e){void 0===e&&(e={});const n={url:t=t||i({hash:!0}),random:Math.random(),source:"swup",...e};history.pushState(n,"",t)},o=function(t,e){void 0===t&&(t=null),void 0===e&&(e={}),t=t||i({hash:!0});const n={...history.state,url:t,random:Math.random(),source:"swup",...e};history.replaceState(n,"",t)},r=function(t,n,i,s){let{base:o=document,...r}=void 0===s?{}:s;const a=e.default(o,t,n,i,r);return{destroy:()=>a.destroy()}},a=function(t,e){return void 0===e&&(e=document),e.querySelector(t)},l=function(t,e){return void 0===e&&(e=document),Array.from(e.querySelectorAll(t))},c=t=>{requestAnimationFrame(()=>{requestAnimationFrame(()=>{t()})})},u=t=>window.CSS&&window.CSS.escape?CSS.escape(t):t,h=t=>1e3*Number(t.slice(0,-1).replace(",",".")),d=(t,e)=>{let n=document.createElement("html");n.innerHTML=t;let i=[];e.forEach(t=>{if(null==a(t,n))return console.warn(`[swup] Container ${t} not found on page.`),null;l(t).length!==l(t,n).length&&console.warn("[swup] Mismatched number of containers found on new page."),l(t).forEach((e,s)=>{l(t,n)[s].setAttribute("data-swup",String(i.length)),i.push(l(t,n)[s].outerHTML)})});const s=a("title",n)?.innerText||"",o=a("body",n)?.className;return n.innerHTML="",n=null,{title:s,pageClass:o,blocks:i,originalContent:t}},p=(t,e)=>{const n={url:window.location.pathname+window.location.search,method:"GET",data:null,headers:{}},{url:i,method:s,headers:o,data:r}={...n,...t},a=new XMLHttpRequest;return a.onreadystatechange=function(){4===a.readyState&&e(a)},a.open(s,i,!0),Object.entries(o).forEach(t=>{let[e,n]=t;a.setRequestHeader(e,n)}),a.send(r),a};class g extends URL{constructor(t,e){void 0===e&&(e=document.baseURI),super(t.toString(),e)}get url(){return this.pathname+this.search}static fromElement(t){const e=t.getAttribute("href")||t.getAttribute("xlink:href");return new g(e)}static fromUrl(t){return new g(t)}}const m=(t,e)=>{let n=0;e.forEach(e=>{null==a(e,t)?console.warn(`[swup] Container ${e} not found on page.`):l(e).forEach((i,s)=>{l(e,t)[s].setAttribute("data-swup",String(n)),n++})})},f=t=>/^to-/.test(t)||["is-changing","is-rendering","is-popstate"].includes(t),v=()=>{const t=document.documentElement.className.split(" ").filter(f);document.documentElement.classList.remove(...t)};class w{constructor(t){this.pages={},this.last=null,this.swup=void 0,this.swup=t}getCacheUrl(t){return this.swup.resolveUrl(g.fromUrl(t).url)}cacheUrl(t){t.url=this.getCacheUrl(t.url),t.url in this.pages==0&&(this.pages[t.url]=t),t.responseURL=this.getCacheUrl(t.responseURL),this.last=this.pages[t.url],this.swup.log(`Cache (${Object.keys(this.pages).length})`,this.pages)}getPage(t){return t=this.getCacheUrl(t),this.pages[t]}getCurrentPage(){return this.getPage(i())}exists(t){return(t=this.getCacheUrl(t))in this.pages}empty(){this.pages={},this.last=null,this.swup.log("Cache cleared")}remove(t){delete this.pages[this.getCacheUrl(t)]}}const E=function(t){let{event:e,skipTransition:n}=void 0===t?{}:t;if(n)return this.triggerEvent("transitionEnd",e),this.cleanupAnimationClasses(),[Promise.resolve()];c(()=>{this.triggerEvent("animationInStart"),document.documentElement.classList.remove("is-animating")});const i=this.getAnimationPromises("in");return Promise.all(i).then(()=>{this.triggerEvent("animationInDone"),this.triggerEvent("transitionEnd",e),this.cleanupAnimationClasses()}),i},P=t=>t?("#"===t.charAt(0)&&(t=t.substring(1)),t=decodeURIComponent(t),t=u(t),a(`#${t}`)||a(`a[name='${t}']`)):null;let S="transition",b="transitionend",k="animation",U="animationend";function y(t){const e=this.options.animationSelector;if(!1===e)return[Promise.resolve()];const n=l(e,document.body);return n.length?n.map(t=>function(t,e,n){void 0===n&&(n=null);const{type:i,timeout:s,propCount:o}=function(t,e){void 0===e&&(e=null);const n=window.getComputedStyle(t),i=`${S}Duration`,s=`${k}Delay`,o=`${k}Duration`,r=n[`${S}Delay`].split(", "),a=(n[i]||"").split(", "),l=L(r,a),c=(n[s]||"").split(", "),u=(n[o]||"").split(", "),h=L(c,u);let d="",p=0,g=0;return"transition"===e?l>0&&(d="transition",p=l,g=a.length):"animation"===e?h>0&&(d="animation",p=h,g=u.length):(p=Math.max(l,h),d=p>0?l>h?"transition":"animation":null,g=d?"transition"===d?a.length:u.length:0),{type:d,timeout:p,propCount:g}}(t,n);return i&&s?new Promise(e=>{const n="transition"===i?b:U,r=performance.now();let a=0;const l=()=>{t.removeEventListener(n,c),e()},c=e=>{if(e.target===t){if(!(t=>!!t.elapsedTime)(e))throw new Error("Not a transition or animation event.");(performance.now()-r)/1e3<e.elapsedTime||++a>=o&&l()}};setTimeout(()=>{a<o&&l()},s+1),t.addEventListener(n,c)}):(console.warn(`[swup] No CSS transition duration defined for element of selector ${e}`),Promise.resolve())}(t,e)):(console.warn(`[swup] No animated elements found by selector ${e}`),[Promise.resolve()])}function L(t,e){for(;t.length<e.length;)t=t.concat(t);return Math.max(...e.map((e,n)=>h(e)+h(t[n])))}void 0===window.ontransitionend&&void 0!==window.onwebkittransitionend&&(S="WebkitTransition",b="webkitTransitionEnd"),void 0===window.onanimationend&&void 0!==window.onwebkitanimationend&&(k="WebkitAnimation",U="webkitAnimationEnd");const C=function(t){const e=d(t.responseText,this.options.containers);return e?{...e,responseURL:t.responseURL||window.location.href}:(console.warn("[swup] Received page is invalid."),null)};function T(t){const e=this.options.requestHeaders,{url:n}=t;return this.cache.exists(n)?(this.triggerEvent("pageRetrievedFromCache"),Promise.resolve(this.cache.getPage(n))):new Promise((i,s)=>{p({...t,headers:e},t=>{if(500===t.status)return this.triggerEvent("serverError"),void s(n);const e=this.getPageData(t);if(!e||!e.blocks.length)return void s(n);const o={...e,url:n};this.cache.cacheUrl(o),this.triggerEvent("pageLoaded"),i(o)})})}const x=function(t){let{event:e,skipTransition:n}=void 0===t?{}:t;const i=e instanceof PopStateEvent;if(n)return this.triggerEvent("animationSkipped"),[Promise.resolve()];this.triggerEvent("animationOutStart"),document.documentElement.classList.add("is-changing","is-leaving","is-animating"),i&&document.documentElement.classList.add("is-popstate");const s=this.getAnimationPromises("out");return Promise.all(s).then(()=>{this.triggerEvent("animationOutDone")}),s};function H(t){const{url:e}=t;this.shouldIgnoreVisit(e)?window.location.href=e:this.performPageLoad(t)}function R(t){const{url:e,event:o,customTransition:r}=t??{},a=o instanceof PopStateEvent,l=this.shouldSkipTransition({url:e,event:o});this.triggerEvent("transitionStart",o),this.updateTransition(i(),e,r),null!=r&&document.documentElement.classList.add(`to-${n(r)}`);const c=this.leavePage({event:o,skipTransition:l}),u=this.fetchPage(t);a||s(e+(this.scrollToElement||"")),this.currentPageUrl=i(),Promise.all([u,...c]).then(t=>{let[e]=t;this.renderPage(e,{event:o,skipTransition:l})}).catch(t=>{void 0!==t&&(this.options.skipPopStateHandling=()=>(window.location=t,!0),history.go(-1))})}const A=function(t){let{blocks:e,title:n}=t;return e.forEach((t,e)=>{document.body.querySelector(`[data-swup="${e}"]`).outerHTML=t}),document.title=n,Promise.resolve()};function $(t,e){const n=this._handlers[t];n?n.push(e):console.warn(`Unsupported event ${t}.`)}function _(t,e){if(t&&e){const n=this._handlers[t];n.includes(e)?this._handlers[t]=n.filter(t=>t!==e):console.warn(`Handler for event '${t}' not found.`)}else t?this._handlers[t]=[]:Object.keys(this._handlers).forEach(t=>{this._handlers[t]=[]})}function q(t,e){this._handlers[t].forEach(t=>{try{t(e)}catch(t){console.error(t)}});const n=new CustomEvent(`swup:${t}`,{detail:t});document.dispatchEvent(n)}const D=function(t){if(t?.isSwupPlugin){if(t.swup=this,!t._checkRequirements||t._checkRequirements())return t._beforeMount&&t._beforeMount(),t.mount(),this.plugins.push(t),this.plugins}else console.error("Not a swup plugin instance",t)};function I(t){const e=this.findPlugin(t);if(e)return e.unmount(),e._afterUnmount&&e._afterUnmount(),this.plugins=this.plugins.filter(t=>t!==e),this.plugins;console.error("No such plugin",e)}function M(t){return this.plugins.find(e=>e===t||e.name===t)}const N=function(t,e){let{event:n,skipTransition:s}=void 0===e?{}:e;if(document.documentElement.classList.remove("is-leaving"),!this.isSameResolvedUrl(i(),t.url))return;const{url:r}=g.fromUrl(t.responseURL);this.isSameResolvedUrl(i(),r)||(this.cache.cacheUrl({...t,url:r}),this.currentPageUrl=i(),o(r)),s||document.documentElement.classList.add("is-rendering"),this.triggerEvent("willReplaceContent",n),this.replaceContent(t).then(()=>{this.triggerEvent("contentReplaced",n),this.triggerEvent("pageView",n),this.options.cache||this.cache.empty(),this.enterPage({event:n,skipTransition:s}),this.scrollToElement=null})};function W(t,e,n){this.transition={from:t,to:e,custom:n}}function O(t){let{event:e}=t;return!(!(e instanceof PopStateEvent)||this.options.animateHistoryBrowsing)}exports.Location=g,exports.classify=n,exports.cleanupAnimationClasses=v,exports.createHistoryRecord=s,exports.default=class{constructor(t){void 0===t&&(t={}),this.version="3.0.4",this._handlers={animationInDone:[],animationInStart:[],animationOutDone:[],animationOutStart:[],animationSkipped:[],clickLink:[],contentReplaced:[],disabled:[],enabled:[],openPageInNewTab:[],pageLoaded:[],pageRetrievedFromCache:[],pageView:[],popState:[],samePage:[],samePageWithHash:[],serverError:[],transitionStart:[],transitionEnd:[],willReplaceContent:[]},this.scrollToElement=null,this.options=void 0,this.plugins=[],this.transition={},this.cache=void 0,this.currentPageUrl=i(),this.delegatedListeners={},this.boundPopStateHandler=void 0,this.loadPage=H,this.performPageLoad=R,this.leavePage=x,this.renderPage=N,this.replaceContent=A,this.enterPage=E,this.triggerEvent=q,this.delegateEvent=r,this.on=$,this.off=_,this.updateTransition=W,this.shouldSkipTransition=O,this.getAnimationPromises=y,this.getPageData=C,this.fetchPage=T,this.getAnchorElement=P,this.log=()=>{},this.use=D,this.unuse=I,this.findPlugin=M,this.getCurrentUrl=i,this.cleanupAnimationClasses=v,this.defaults={animateHistoryBrowsing:!1,animationSelector:'[class*="transition-"]',cache:!0,containers:["#swup"],ignoreVisit:function(t,e){let{el:n}=void 0===e?{}:e;return!!n?.closest("[data-no-swup]")},linkSelector:"a[href]",plugins:[],resolveUrl:t=>t,requestHeaders:{"X-Requested-With":"swup",Accept:"text/html, application/xhtml+xml"},skipPopStateHandling:t=>"swup"!==t.state?.source},this.options={...this.defaults,...t},this.boundPopStateHandler=this.popStateHandler.bind(this),this.cache=new w(this),this.enable()}enable(){"undefined"!=typeof Promise?(this.delegatedListeners.click=r(this.options.linkSelector,"click",this.linkClickHandler.bind(this)),window.addEventListener("popstate",this.boundPopStateHandler),m(document.documentElement,this.options.containers),this.options.plugins.forEach(t=>this.use(t)),o(),this.triggerEvent("enabled"),document.documentElement.classList.add("swup-enabled"),this.triggerEvent("pageView")):console.warn("Promise is not supported")}destroy(){this.delegatedListeners.click.destroy(),window.removeEventListener("popstate",this.boundPopStateHandler),this.cache.empty(),this.options.plugins.forEach(t=>{this.unuse(t)}),l("[data-swup]").forEach(t=>{t.removeAttribute("data-swup")}),this.off(),this.triggerEvent("disabled"),document.documentElement.classList.remove("swup-enabled")}shouldIgnoreVisit(t,e){let{el:n}=void 0===e?{}:e;const{origin:i,url:s,hash:o}=g.fromUrl(t);return i!==window.location.origin||!(!n||!this.triggerWillOpenNewWindow(n))||!!this.options.ignoreVisit(s+o,{el:n})}linkClickHandler(t){const e=t.delegateTarget,{href:n,url:s,hash:o}=g.fromElement(e);if(this.shouldIgnoreVisit(n,{el:e}))return;if(t.metaKey||t.ctrlKey||t.shiftKey||t.altKey)return void this.triggerEvent("openPageInNewTab",t);if(0!==t.button)return;if(this.triggerEvent("clickLink",t),t.preventDefault(),!s||s===i())return void this.handleLinkToSamePage(s,o,t);if(this.isSameResolvedUrl(s,i()))return;this.scrollToElement=o||null;const r=e.getAttribute("data-swup-transition")||void 0;this.performPageLoad({url:s,customTransition:r})}handleLinkToSamePage(t,e,n){if(e){if(this.triggerEvent("samePageWithHash",n),!P(e))return console.warn(`Element for offset not found (#${e})`);o(t+e)}else this.triggerEvent("samePage",n)}triggerWillOpenNewWindow(t){return!!t.matches('[download], [target="_blank"]')}popStateHandler(t){if(this.options.skipPopStateHandling(t))return;if(this.isSameResolvedUrl(i(),this.currentPageUrl))return;const e=t.state?.url??location.href;if(this.shouldIgnoreVisit(e))return;const{url:n,hash:s}=g.fromUrl(e);s?this.scrollToElement=s:t.preventDefault(),this.triggerEvent("popState",t),this.options.animateHistoryBrowsing||(document.documentElement.classList.remove("is-animating"),v()),this.performPageLoad({url:n,event:t})}resolveUrl(t){if("function"!=typeof this.options.resolveUrl)return console.warn("[swup] options.resolveUrl expects a callback function."),t;const e=this.options.resolveUrl(t);return e&&"string"==typeof e?e.startsWith("//")||e.startsWith("http")?(console.warn("[swup] options.resolveUrl needs to return a relative url"),t):e:(console.warn("[swup] options.resolveUrl needs to return a url"),t)}isSameResolvedUrl(t,e){return this.resolveUrl(t)===this.resolveUrl(e)}},exports.delegateEvent=r,exports.escapeCssIdentifier=u,exports.fetch=p,exports.getCurrentUrl=i,exports.getDataFromHtml=d,exports.markSwupElements=m,exports.nextTick=c,exports.query=a,exports.queryAll=l,exports.toMs=h,exports.updateHistoryRecord=o;
1
+ var t=require("delegate-it"),e=require("path-to-regexp");function r(t){return t&&"object"==typeof t&&"default"in t?t:{default:t}}var n=/*#__PURE__*/r(t);const o=(t,e)=>String(t).toLowerCase().replace(/[\s/_.]+/g,"-").replace(/[^\w-]+/g,"").replace(/--+/g,"-").replace(/^-+|-+$/g,"")||e||"",i=function(t){let{hash:e}=void 0===t?{}:t;return location.pathname+location.search+(e?location.hash:"")},s=function(t,e){void 0===e&&(e={});const r={url:t=t||i({hash:!0}),random:Math.random(),source:"swup",...e};history.pushState(r,"",t)},a=function(t,e){void 0===t&&(t=null),void 0===e&&(e={}),t=t||i({hash:!0});const r={...history.state,url:t,random:Math.random(),source:"swup",...e};history.replaceState(r,"",t)},c=(t,e,r,o)=>{const i=new AbortController;return o={...o,signal:i.signal},n.default(t,e,r,o),{destroy:()=>i.abort()}};class l extends URL{constructor(t,e){void 0===e&&(e=document.baseURI),super(t.toString(),e)}get url(){return this.pathname+this.search}static fromElement(t){const e=t.getAttribute("href")||t.getAttribute("xlink:href")||"";return new l(e)}static fromUrl(t){return new l(t)}}class u{constructor(t){this.swup=void 0,this.pages=new Map,this.swup=t}get size(){return this.pages.size}get all(){return this.pages}has(t){return this.pages.has(this.resolve(t))}get(t){return this.pages.get(this.resolve(t))}set(t,e){t=this.resolve(t),e={...e,url:t},this.pages.set(t,e),this.swup.hooks.triggerSync("cache:set",{page:e})}update(t,e){t=this.resolve(t),e={...this.get(t),...e,url:t},this.pages.set(t,e)}delete(t){this.pages.delete(this.resolve(t))}clear(){this.pages.clear(),this.swup.hooks.triggerSync("cache:clear")}prune(t){this.pages.forEach((e,r)=>{t(r,e)&&this.delete(r)})}resolve(t){const{url:e}=l.fromUrl(t);return this.swup.resolveUrl(e)}}const h=function(t,e){return void 0===e&&(e=document),e.querySelector(t)},m=function(t,e){return void 0===e&&(e=document),Array.from(e.querySelectorAll(t))},d=()=>new Promise(t=>{requestAnimationFrame(()=>{requestAnimationFrame(()=>{t()})})});function p(t){return!!t&&("object"==typeof t||"function"==typeof t)&&"function"==typeof t.then}function f(t,e,r){return void 0===e&&(e=[]),void 0===r&&(r={}),new Promise((n,o)=>{const i=t.apply(r,e);p(i)?i.then(n,o):n(i)})}const g=t=>window.CSS&&window.CSS.escape?CSS.escape(t):t,v=t=>1e3*Number(t.slice(0,-1).replace(",","."));class w{constructor(t){this.swup=void 0,this.swupClasses=["to-","is-changing","is-rendering","is-popstate","is-animating"],this.swup=t}get selectors(){const{scope:t}=this.swup.context.animation;return"containers"===t?this.swup.context.containers:"html"===t?["html"]:Array.isArray(t)?t:[]}get selector(){return this.selectors.join(",")}get targets(){return this.selector.trim()?m(this.selector):[]}add(){this.targets.forEach(t=>t.classList.add(...[].slice.call(arguments)))}remove(){this.targets.forEach(t=>t.classList.remove(...[].slice.call(arguments)))}clear(){this.targets.forEach(t=>{const e=t.className.split(" ").filter(t=>this.isSwupClass(t));t.classList.remove(...e)})}isSwupClass(t){return this.swupClasses.some(e=>t.startsWith(e))}}function y(t){let{to:e,from:r=this.currentPageUrl,hash:n,animate:o=!0,animation:i,el:s,event:a,action:c="push",resetScroll:l=!0}=t;return{from:{url:r},to:{url:e},containers:this.options.containers,animation:{animate:o,wait:!1,name:i,scope:this.options.animationScope,selector:this.options.animationSelector},trigger:{el:s,event:a},history:{action:c,popstate:!1,direction:void 0},scroll:{reset:l,target:n}}}const x="undefined"!=typeof Symbol?Symbol.iterator||(Symbol.iterator=Symbol("Symbol.iterator")):"@@iterator";function P(t,e,r){if(!t.s){if(r instanceof k){if(!r.s)return void(r.o=P.bind(null,t,e));1&e&&(e=r.s),r=r.v}if(r&&r.then)return void r.then(P.bind(null,t,e),P.bind(null,t,2));t.s=e,t.v=r;const n=t.o;n&&n(t)}}const k=/*#__PURE__*/function(){function t(){}return t.prototype.then=function(e,r){const n=new t,o=this.s;if(o){const t=1&o?e:r;if(t){try{P(n,1,t(this.v))}catch(t){P(n,2,t)}return n}return this}return this.o=function(t){try{const o=t.v;1&t.s?P(n,1,e?e(o):o):r?P(n,1,r(o)):P(n,2,o)}catch(t){P(n,2,t)}},n},t}();function S(t){return t instanceof k&&1&t.s}class b{constructor(t){this.swup=void 0,this.registry=new Map,this.hooks=["animation:out:start","animation:out:end","animation:in:start","animation:in:end","animation:skip","animation:await","cache:clear","cache:set","content:replace","content:scroll","enable","disable","fetch:request","fetch:error","history:popstate","link:click","link:self","link:anchor","link:newtab","page:request","page:load","page:view","visit:start","visit:end"],this.swup=t,this.init()}init(){this.hooks.forEach(t=>this.create(t))}create(t){this.registry.has(t)||this.registry.set(t,new Map)}has(t){return this.registry.has(t)}get(t){const e=this.registry.get(t);if(e)return e;console.error(`Unknown hook '${t}'`)}clear(){this.registry.forEach(t=>t.clear())}on(t,e,r){void 0===r&&(r={});const n=this.get(t);if(!n)return console.warn(`Hook '${t}' not found.`),()=>{};const o=n.size+1,i={...r,id:o,hook:t,handler:e};return n.set(e,i),()=>this.off(t,e)}before(t,e,r){return void 0===r&&(r={}),this.on(t,e,{...r,before:!0})}replace(t,e,r){return void 0===r&&(r={}),this.on(t,e,{...r,replace:!0})}once(t,e,r){return void 0===r&&(r={}),this.on(t,e,{...r,once:!0})}off(t,e){const r=this.get(t);r&&e?r.delete(e)||console.warn(`Handler for hook '${t}' not found.`):r&&r.clear()}trigger(t,e,r){try{const n=this,{before:o,handler:i,after:s,replaced:a}=n.getHandlers(t,r);return Promise.resolve(n.execute(o,e)).then(function(){return Promise.resolve(n.execute(i,e,a?r:void 0)).then(function(r){let[o]=r;return Promise.resolve(n.execute(s,e)).then(function(){return n.dispatchDomEvent(t,e),o})})})}catch(t){return Promise.reject(t)}}triggerSync(t,e,r){const{before:n,after:o,handler:i,replaced:s}=this.getHandlers(t,r);this.executeSync(n,e);const[a]=this.executeSync(i,e,s?r:void 0);return this.executeSync(o,e),this.dispatchDomEvent(t,e),a}execute(t,e,r){try{const n=this,o=[],i=function(t,e,r){if("function"==typeof t[x]){var n,o,i,s=t[x]();if(function t(r){try{for(;!(n=s.next()).done;)if((r=e(n.value))&&r.then){if(!S(r))return void r.then(t,i||(i=P.bind(null,o=new k,2)));r=r.v}o?P(o,1,r):o=r}catch(t){P(o||(o=new k),2,t)}}(),s.return){var a=function(t){try{n.done||s.return()}catch(t){}return t};if(o&&o.then)return o.then(a,function(t){throw a(t)});a()}return o}if(!("length"in t))throw new TypeError("Object is not iterable");for(var c=[],l=0;l<t.length;l++)c.push(t[l]);return function(t,e,r){var n,o,i=-1;return function r(s){try{for(;++i<t.length;)if((s=e(i))&&s.then){if(!S(s))return void s.then(r,o||(o=P.bind(null,n=new k,2)));s=s.v}n?P(n,1,s):n=s}catch(t){P(n||(n=new k),2,t)}}(),n}(c,function(t){return e(c[t])})}(t,function(t){let{hook:i,handler:s,once:a}=t;return Promise.resolve(f(s,[n.swup.context,e,r])).then(function(t){o.push(t),a&&n.off(i,s)})});return Promise.resolve(i&&i.then?i.then(function(){return o}):o)}catch(t){return Promise.reject(t)}}executeSync(t,e,r){const n=[];for(const{hook:o,handler:i,once:s}of t){const t=i(this.swup.context,e,r);n.push(t),p(t)&&console.warn(`Promise returned from handler for synchronous hook '${o}'.Swup will not wait for it to resolve.`),s&&this.off(o,i)}return n}getHandlers(t,e){const r=this.get(t);if(!r)return{found:!1,before:[],handler:[],after:[],replaced:!1};const n=this.sortRegistrations,o=Array.from(r.values()),i=o.filter(t=>{let{before:e,replace:r}=t;return e&&!r}).sort(n),s=o.filter(t=>{let{replace:e}=t;return e}).sort(n),a=o.filter(t=>{let{before:e,replace:r}=t;return!e&&!r}).sort(n),c=s.length>0;let l=[];return c?l=[{id:0,hook:t,handler:s[0].handler}]:e&&(l=[{id:0,hook:t,handler:e}]),{found:!0,before:i,handler:l,after:a,replaced:c}}sortRegistrations(t,e){return(t.priority??0)-(e.priority??0)||t.id-e.id||0}dispatchDomEvent(t,e){document.dispatchEvent(new CustomEvent(`swup:${t}`,{detail:{hook:t,args:e,context:this.swup.context}}))}}const U=t=>{if(t&&"#"===t.charAt(0)&&(t=t.substring(1)),!t)return null;const e=decodeURIComponent(t);let r=document.getElementById(t)||document.getElementById(e)||h(`a[name='${g(t)}']`)||h(`a[name='${g(e)}']`);return r||"top"!==t||(r=document.body),r},E=function(t){let{elements:e,selector:r}=t;try{if(!1===r&&!e)return Promise.resolve();let t=[];if(e)t=Array.from(e);else if(r&&(t=m(r,document.body),!t.length))return console.warn(`[swup] No elements found matching animationSelector \`${r}\``),Promise.resolve();const n=t.map(t=>function(t){const{type:e,timeout:r,propCount:n}=function(t,e){const r=window.getComputedStyle(t),n=$(r,`${C}Delay`),o=$(r,`${C}Duration`),i=q(n,o),s=$(r,`${H}Delay`),a=$(r,`${H}Duration`),c=q(s,a);let l=null,u=0,h=0;return e===C?i>0&&(l=C,u=i,h=o.length):e===H?c>0&&(l=H,u=c,h=a.length):(u=Math.max(i,c),l=u>0?i>c?C:H:null,h=l?l===C?o.length:a.length:0),{type:l,timeout:u,propCount:h}}(t);return!(!e||!r)&&new Promise(o=>{const i=`${e}end`,s=performance.now();let a=0;const c=()=>{t.removeEventListener(i,l),o()},l=e=>{if(e.target===t){if(!function(t){return[`${C}end`,`${H}end`].includes(t.type)}(e))throw new Error("Not a transition or animation event.");(performance.now()-s)/1e3<e.elapsedTime||++a>=n&&c()}};setTimeout(()=>{a<n&&c()},r+1),t.addEventListener(i,l)})}(t));return n.filter(Boolean).length>0?Promise.resolve(Promise.all(n)).then(function(){}):(r&&console.warn(`[swup] No CSS animation duration defined on elements matching \`${r}\``),Promise.resolve())}catch(t){return Promise.reject(t)}},C="transition",H="animation";function $(t,e){return(t[e]||"").split(", ")}function q(t,e){for(;t.length<e.length;)t=t.concat(t);return Math.max(...e.map((e,r)=>v(e)+v(t[r])))}const A=function(t,e){void 0===e&&(e={});try{const r=this;if("string"!=typeof t)throw new Error("swup.visit() requires a URL parameter");r.context.to.url=l.fromUrl(t).url;const{animation:n,animate:o,history:c}=e;return e.referrer=e.referrer||r.currentPageUrl,!1===o&&(r.context.animation.animate=!1),c&&(r.context.history.action=c),r.context.animation.animate?n&&(r.context.animation.name=n):r.classes.clear(),Promise.resolve(function(n,o){try{var c=Promise.resolve(r.hooks.trigger("visit:start")).then(function(){function n(){const t=r.leavePage();return Promise.resolve(Promise.all([o,t])).then(function(t){let[e]=t;return Promise.resolve(r.renderPage(r.context.to.url,e)).then(function(){return Promise.resolve(r.enterPage()).then(function(){return Promise.resolve(r.hooks.trigger("visit:end",void 0,()=>r.classes.clear())).then(function(){})})})})}const o=r.hooks.trigger("page:request",{url:r.context.to.url,options:e},function(t,e){let{options:n}=e;try{return Promise.resolve(r.fetchPage(t.to.url,n))}catch(t){return Promise.reject(t)}});if(!r.context.history.popstate){const e=t+(r.context.scroll.target||"");"replace"===r.context.history.action?a(e):s(e,{index:r.currentHistoryIndex+1})}r.currentPageUrl=i();const c=function(){if(r.context.animation.wait)return Promise.resolve(o).then(function(t){let{html:e}=t;r.context.to.html=e})}();return c&&c.then?c.then(n):n()})}catch(t){return o(t)}return c&&c.then?c.then(void 0,o):c}(0,function(t){t&&(console.error(t),r.options.skipPopStateHandling=()=>(window.location.href=r.context.to.url,!0),history.go(-1))}))}catch(t){return Promise.reject(t)}};function R(t,e,r){if(void 0===e&&(e={}),void 0===r&&(r={}),this.shouldIgnoreVisit(t))return void(window.location.href=t);const{url:n,hash:o}=l.fromUrl(t);this.context=this.createContext({...r,to:n,hash:o}),this.performVisit(n,e)}const j=function(t,e){void 0===e&&(e={});try{let n;const o=this;function r(r){if(n)return r;const i={...o.options.requestHeaders,...e.headers};return e={...e,headers:i},Promise.resolve(o.hooks.trigger("fetch:request",{url:t,options:e},(t,e)=>{let{url:r,options:n}=e;return fetch(r,n)})).then(function(r){const{status:n,url:i}=r;return Promise.resolve(r.text()).then(function(s){if(500===n)throw o.hooks.trigger("fetch:error",{status:n,response:r,url:i}),new I(`Server error: ${i}`,{status:n,url:i});if(!s)throw new I(`Empty response: ${i}`,{status:n,url:i});const{url:a}=l.fromUrl(i),c={url:a,html:s};t===a&&o.cache.set(c.url,c);const u=function(){if(!1!==e.triggerHooks)return Promise.resolve(o.hooks.trigger("page:load",{page:c,cache:!1})).then(function(){})}();return u&&u.then?u.then(function(){return c}):c})})}t=l.fromUrl(t).url;const i=function(){if(o.cache.has(t)){function r(){return n=1,i}const i=o.cache.get(t),s=function(){if(!1!==e.triggerHooks)return Promise.resolve(o.hooks.trigger("page:load",{page:i,cache:!0})).then(function(){})}();return s&&s.then?s.then(r):r()}}();return Promise.resolve(i&&i.then?i.then(r):r(i))}catch(s){return Promise.reject(s)}};class I extends Error{constructor(t,e){super(t),this.url=void 0,this.status=void 0,this.name="FetchError",this.url=e.url,this.status=e.status}}const L=function(){try{let e;const r=this;function t(t){return e?t:Promise.resolve(r.hooks.trigger("animation:out:start",void 0,()=>{r.classes.add("is-changing","is-leaving","is-animating"),r.context.history.popstate&&r.classes.add("is-popstate"),r.context.animation.name&&r.classes.add(`to-${o(r.context.animation.name)}`)})).then(function(){return Promise.resolve(r.hooks.trigger("animation:await",{direction:"out"},function(t,e){let{direction:n}=e;try{return Promise.resolve(r.awaitAnimations({selector:t.animation.selector,direction:n})).then(function(){})}catch(t){return Promise.reject(t)}})).then(function(){return Promise.resolve(r.hooks.trigger("animation:out:end")).then(function(){})})})}const n=function(){if(!r.context.animation.animate)return Promise.resolve(r.hooks.trigger("animation:skip")).then(function(){e=1})}();return Promise.resolve(n&&n.then?n.then(t):t(n))}catch(i){return Promise.reject(i)}},D=function(t,e){var r;let{html:n}=t,{containers:o}=void 0===e?this.options:e;const i=(new DOMParser).parseFromString(n,"text/html"),s=(null==(r=i.querySelector("title"))?void 0:r.innerText)||"";return document.title=s,o.map(t=>{const e=document.querySelector(t),r=i.querySelector(t);return e&&r?(e.replaceWith(r),!0):(e||console.warn(`[swup] Container missing in current document: ${t}`),r||console.warn(`[swup] Container missing in incoming document: ${t}`),!1)}).filter(Boolean).length===o.length},V=function(){try{const t=this;if(!t.context.animation.animate)return Promise.resolve();const e=t.hooks.trigger("animation:await",{direction:"in"},function(e,r){let{direction:n}=r;try{return Promise.resolve(t.awaitAnimations({selector:e.animation.selector,direction:n})).then(function(){})}catch(t){return Promise.reject(t)}});return Promise.resolve(d()).then(function(){return Promise.resolve(t.hooks.trigger("animation:in:start",void 0,()=>{t.classes.remove("is-animating")})).then(function(){return Promise.resolve(e).then(function(){return Promise.resolve(t.hooks.trigger("animation:in:end")).then(function(){})})})})}catch(t){return Promise.reject(t)}},M=function(t,e){try{const r=this,{url:n,html:s}=e;return r.classes.remove("is-leaving"),r.isSameResolvedUrl(i(),t)?(r.isSameResolvedUrl(i(),n)||(a(n),r.currentPageUrl=i(),r.context.to.url=r.currentPageUrl),r.context.animation.animate&&r.classes.add("is-rendering"),r.context.to.html=s,Promise.resolve(r.hooks.trigger("content:replace",{page:e},(t,e)=>{let{page:n}=e;if(!r.replaceContent(n,{containers:t.containers}))throw new Error("[swup] Container mismatch, aborting");r.context.animation.animate&&(r.classes.add("is-animating","is-changing","is-rendering"),r.context.animation.name&&r.classes.add(`to-${o(r.context.animation.name)}`))})).then(function(){return Promise.resolve(r.hooks.trigger("content:scroll",{options:{behavior:"auto"}},(t,e)=>{let{options:n}=e;if(r.context.scroll.target){const t=r.getAnchorElement(r.context.scroll.target);if(t)return void t.scrollIntoView(n)}r.context.scroll.reset&&window.scrollTo(0,0)})).then(function(){return Promise.resolve(r.hooks.trigger("page:view",{url:r.currentPageUrl,title:document.title})).then(function(){r.options.cache||r.cache.clear()})})})):Promise.resolve()}catch(t){return Promise.reject(t)}},N=function(t){var e;if(null==(e=t)?void 0:e.isSwupPlugin){if(t.swup=this,!t._checkRequirements||t._checkRequirements())return t._beforeMount&&t._beforeMount(),t.mount(),this.plugins.push(t),this.plugins}else console.error("Not a swup plugin instance",t)};function W(t){const e=this.findPlugin(t);if(e)return e.unmount(),e._afterUnmount&&e._afterUnmount(),this.plugins=this.plugins.filter(t=>t!==e),this.plugins;console.error("No such plugin",e)}function _(t){return this.plugins.find(e=>e===t||e.name===t)}exports.Location=l,exports.classify=o,exports.createHistoryRecord=s,exports.default=class{constructor(t){void 0===t&&(t={}),this.version="4.0.0-rc.21",this.options=void 0,this.plugins=[],this.context=void 0,this.cache=void 0,this.hooks=void 0,this.classes=void 0,this.currentPageUrl=i(),this.currentHistoryIndex=1,this.clickDelegate=void 0,this.visit=R,this.performVisit=A,this.leavePage=L,this.renderPage=M,this.replaceContent=D,this.enterPage=V,this.delegateEvent=c,this.fetchPage=j,this.awaitAnimations=E,this.getAnchorElement=U,this.use=N,this.unuse=W,this.findPlugin=_,this.getCurrentUrl=i,this.createContext=y,this.log=()=>{},this.defaults={animateHistoryBrowsing:!1,animationSelector:'[class*="transition-"]',animationScope:"html",cache:!0,containers:["#swup"],ignoreVisit:function(t,e){let{el:r}=void 0===e?{}:e;return!(null==r||!r.closest("[data-no-swup]"))},linkSelector:"a[href]",plugins:[],resolveUrl:t=>t,requestHeaders:{"X-Requested-With":"swup",Accept:"text/html, application/xhtml+xml"},skipPopStateHandling:t=>{var e;return"swup"!==(null==(e=t.state)?void 0:e.source)}},this.options={...this.defaults,...t},this.linkClickHandler=this.linkClickHandler.bind(this),this.popStateHandler=this.popStateHandler.bind(this),this.cache=new u(this),this.classes=new w(this),this.hooks=new b(this),this.context=this.createContext({to:void 0}),this.checkRequirements()&&this.enable()}checkRequirements(){return"undefined"!=typeof Promise||(console.warn("Promise is not supported"),!1)}enable(){try{const t=this,{linkSelector:e}=t.options;return t.clickDelegate=t.delegateEvent(e,"click",t.linkClickHandler),window.addEventListener("popstate",t.popStateHandler),t.options.plugins.forEach(e=>t.use(e)),a(null,{index:1}),Promise.resolve(t.hooks.trigger("enable",void 0,()=>{document.documentElement.classList.add("swup-enabled")})).then(function(){return Promise.resolve(d()).then(function(){return Promise.resolve(t.hooks.trigger("page:view",{url:t.currentPageUrl,title:document.title})).then(function(){})})})}catch(t){return Promise.reject(t)}}destroy(){try{const t=this;return t.clickDelegate.destroy(),window.removeEventListener("popstate",t.popStateHandler),t.cache.clear(),t.options.plugins.forEach(e=>t.unuse(e)),Promise.resolve(t.hooks.trigger("disable",void 0,()=>{document.documentElement.classList.remove("swup-enabled")})).then(function(){t.hooks.clear()})}catch(t){return Promise.reject(t)}}shouldIgnoreVisit(t,e){let{el:r,event:n}=void 0===e?{}:e;const{origin:o,url:i,hash:s}=l.fromUrl(t);return o!==window.location.origin||!(!r||!this.triggerWillOpenNewWindow(r))||!!this.options.ignoreVisit(i+s,{el:r,event:n})}linkClickHandler(t){const e=t.delegateTarget,{href:r,url:n,hash:o}=l.fromElement(e),i=e.getAttribute("data-swup-animation")||void 0;let s;const c=e.getAttribute("data-swup-history");c&&["push","replace"].includes(c)&&(s=c),this.shouldIgnoreVisit(r,{el:e,event:t})||(this.context=this.createContext({to:n,hash:o,animation:i,el:e,event:t,action:s}),t.metaKey||t.ctrlKey||t.shiftKey||t.altKey?this.hooks.trigger("link:newtab",{href:r}):0===t.button&&this.hooks.triggerSync("link:click",{el:e,event:t},()=>{const e=this.context.from.url??"";t.preventDefault(),n&&n!==e?this.isSameResolvedUrl(n,e)||this.performVisit(n):o?(a(n+o),this.hooks.triggerSync("link:anchor",{hash:o,options:{behavior:"auto"}},(t,e)=>{let{hash:r,options:n}=e;const o=this.getAnchorElement(r);o&&o.scrollIntoView(n)})):this.hooks.triggerSync("link:self",void 0,t=>{t.scroll.reset&&window.scroll({top:0,left:0,behavior:"auto"})})}))}triggerWillOpenNewWindow(t){return!!t.matches('[download], [target="_blank"]')}popStateHandler(t){var e,r;const n=(null==(e=t.state)?void 0:e.url)??location.href;if(this.options.skipPopStateHandling(t))return;if(this.isSameResolvedUrl(i(),this.currentPageUrl))return;if(this.shouldIgnoreVisit(n,{event:t}))return;const{url:o,hash:s}=l.fromUrl(n);this.context=this.createContext({to:o,hash:s,event:t,animate:this.options.animateHistoryBrowsing,resetScroll:this.options.animateHistoryBrowsing}),this.context.history.popstate=!0;const a=Number(null==(r=t.state)?void 0:r.index);a&&(this.context.history.direction=a-this.currentHistoryIndex>0?"forwards":"backwards"),this.hooks.triggerSync("history:popstate",{event:t},()=>{this.performVisit(o)})}resolveUrl(t){if("function"!=typeof this.options.resolveUrl)return console.warn("[swup] options.resolveUrl expects a callback function."),t;const e=this.options.resolveUrl(t);return e&&"string"==typeof e?e.startsWith("//")||e.startsWith("http")?(console.warn("[swup] options.resolveUrl needs to return a relative url"),t):e:(console.warn("[swup] options.resolveUrl needs to return a url"),t)}isSameResolvedUrl(t,e){return this.resolveUrl(t)===this.resolveUrl(e)}},exports.delegateEvent=c,exports.escapeCssIdentifier=g,exports.getCurrentUrl=i,exports.isPromise=p,exports.matchPath=(t,r)=>{try{return e.match(t,r)}catch(e){throw new Error(`[swup] Error parsing path "${t}":\n${e}`)}},exports.nextTick=d,exports.query=h,exports.queryAll=m,exports.runAsPromise=f,exports.toMs=v,exports.updateHistoryRecord=a;
2
2
  //# sourceMappingURL=Swup.cjs.map
package/dist/Swup.cjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"Swup.cjs","sources":["../src/helpers/classify.ts","../src/helpers/getCurrentUrl.ts","../src/helpers/createHistoryRecord.ts","../src/helpers/updateHistoryRecord.ts","../src/helpers/delegateEvent.ts","../src/utils/index.ts","../src/helpers/getDataFromHtml.ts","../src/helpers/fetch.ts","../src/helpers/Location.ts","../src/helpers/markSwupElements.ts","../src/helpers/cleanupAnimationClasses.ts","../src/modules/Cache.ts","../src/modules/enterPage.ts","../src/modules/getAnchorElement.ts","../src/modules/getAnimationPromises.ts","../src/modules/getPageData.ts","../src/modules/fetchPage.ts","../src/modules/leavePage.ts","../src/modules/loadPage.ts","../src/modules/replaceContent.ts","../src/modules/events.ts","../src/modules/plugins.ts","../src/modules/renderPage.ts","../src/modules/transitions.ts","../src/Swup.ts"],"sourcesContent":["export const classify = (text: string, fallback?: string): string => {\n\tconst output = String(text)\n\t\t.toLowerCase()\n\t\t// .normalize('NFD') // split an accented letter in the base letter and the acent\n\t\t// .replace(/[\\u0300-\\u036f]/g, '') // remove all previously split accents\n\t\t.replace(/[\\s/_.]+/g, '-') // replace spaces and _./ with '-'\n\t\t.replace(/[^\\w-]+/g, '') // remove all non-word chars\n\t\t.replace(/--+/g, '-') // replace repeating '-' with single '-'\n\t\t.replace(/^-+|-+$/g, ''); // trim '-' from edges\n\treturn output || fallback || '';\n};\n","export const getCurrentUrl = ({ hash }: { hash?: boolean } = {}): string => {\n\treturn location.pathname + location.search + (hash ? location.hash : '');\n};\n","import { getCurrentUrl } from './getCurrentUrl';\n\nexport const createHistoryRecord = (\n\turl: string,\n\tcustomData: Record<string, unknown> = {}\n): void => {\n\turl = url || getCurrentUrl({ hash: true });\n\tconst data = {\n\t\turl,\n\t\trandom: Math.random(),\n\t\tsource: 'swup',\n\t\t...customData\n\t};\n\thistory.pushState(data, '', url);\n};\n","import { getCurrentUrl } from './getCurrentUrl';\n\nexport const updateHistoryRecord = (\n\turl: string | null = null,\n\tcustomData: Record<string, unknown> = {}\n): void => {\n\turl = url || getCurrentUrl({ hash: true });\n\tconst data = {\n\t\t...history.state,\n\t\turl,\n\t\trandom: Math.random(),\n\t\tsource: 'swup',\n\t\t...customData\n\t};\n\thistory.replaceState(data, '', url);\n};\n","import delegate, { EventType } from 'delegate-it';\nimport { ParseSelector } from 'typed-query-selector/parser';\n\nexport type Unsubscribe = {\n\tdestroy: () => void;\n};\nexport const delegateEvent = <Selector extends string, TEvent extends EventType>(\n\tselector: Selector,\n\ttype: TEvent,\n\tcallback: delegate.EventHandler<GlobalEventHandlersEventMap[TEvent]>,\n\t{ base = document, ...eventOptions } = {}\n): Unsubscribe => {\n\tconst delegation = delegate<string, ParseSelector<Selector, HTMLElement>, TEvent>(\n\t\tbase,\n\t\tselector,\n\t\ttype,\n\t\tcallback,\n\t\teventOptions\n\t);\n\treturn { destroy: () => delegation.destroy() };\n};\n","export const query = (selector: string, context: Document | Element = document) => {\n\treturn context.querySelector<HTMLElement>(selector);\n};\n\nexport const queryAll = (\n\tselector: string,\n\tcontext: Document | Element = document\n): HTMLElement[] => {\n\treturn Array.from(context.querySelectorAll(selector));\n};\n\nexport const nextTick = (callback: () => void) => {\n\trequestAnimationFrame(() => {\n\t\trequestAnimationFrame(() => {\n\t\t\tcallback();\n\t\t});\n\t});\n};\n\nexport const escapeCssIdentifier = (ident: string) => {\n\t// @ts-ignore this is for support check, so it's correct that TS complains\n\tif (window.CSS && window.CSS.escape) {\n\t\treturn CSS.escape(ident);\n\t} else {\n\t\treturn ident;\n\t}\n};\n\n// Fix for Chrome below v61 formatting CSS floats with comma in some locales\nexport const toMs = (s: string) => {\n\treturn Number(s.slice(0, -1).replace(',', '.')) * 1000;\n};\n","import { query, queryAll } from '../utils';\n\nexport type PageHtmlData = {\n\ttitle: string;\n\toriginalContent: string;\n\tblocks: string[];\n\tpageClass?: string;\n};\n\nexport const getDataFromHtml = (html: string, containers: string[]): PageHtmlData => {\n\tlet fakeDom = document.createElement('html');\n\tfakeDom.innerHTML = html;\n\tlet blocks: string[] = [];\n\n\tcontainers.forEach((selector) => {\n\t\tif (query(selector, fakeDom) == null) {\n\t\t\tconsole.warn(`[swup] Container ${selector} not found on page.`);\n\t\t\treturn null;\n\t\t} else {\n\t\t\tif (queryAll(selector).length !== queryAll(selector, fakeDom).length) {\n\t\t\t\tconsole.warn(`[swup] Mismatched number of containers found on new page.`);\n\t\t\t}\n\t\t\tqueryAll(selector).forEach((item, index) => {\n\t\t\t\tqueryAll(selector, fakeDom)[index].setAttribute('data-swup', String(blocks.length));\n\t\t\t\tblocks.push(queryAll(selector, fakeDom)[index].outerHTML);\n\t\t\t});\n\t\t}\n\t});\n\n\tconst title = query('title', fakeDom)?.innerText || '';\n\tconst pageClass = query('body', fakeDom)?.className;\n\n\t// to prevent memory leaks\n\tfakeDom.innerHTML = '';\n\t// @ts-ignore don't want to type it as possible null, since it's created at the top of the function always\n\tfakeDom = null;\n\n\treturn { title, pageClass, blocks, originalContent: html };\n};\n","import { TransitionOptions } from '../modules/loadPage';\nimport { Options } from '../Swup';\n\nexport const fetch = (\n\toptions: TransitionOptions & { headers: Options['requestHeaders'] },\n\tcallback: (request: XMLHttpRequest) => void\n): XMLHttpRequest => {\n\tconst defaults = {\n\t\turl: window.location.pathname + window.location.search,\n\t\tmethod: 'GET',\n\t\tdata: null,\n\t\theaders: {}\n\t};\n\n\tconst { url, method, headers, data } = { ...defaults, ...options };\n\n\tconst request = new XMLHttpRequest();\n\n\trequest.onreadystatechange = function () {\n\t\tif (request.readyState === 4) {\n\t\t\t// if (request.status === 500) {} else {}\n\t\t\tcallback(request);\n\t\t}\n\t};\n\n\trequest.open(method, url, true);\n\tObject.entries(headers).forEach(([key, header]) => {\n\t\trequest.setRequestHeader(key, header);\n\t});\n\trequest.send(data);\n\n\treturn request;\n};\n","/**\n * A helper for creating a Location from either an element\n * or a URL object/string\n *\n */\n\nexport class Location extends URL {\n\tconstructor(url: string, base: string = document.baseURI) {\n\t\tsuper(url.toString(), base);\n\t}\n\n\tget url() {\n\t\treturn this.pathname + this.search;\n\t}\n\n\t/**\n\t * Instantiate a Location from an element's href attribute\n\t * @param {Element} el\n\t * @return new Location instance\n\t */\n\tstatic fromElement(el: HTMLAnchorElement): Location {\n\t\tconst href = el.getAttribute('href') || el.getAttribute('xlink:href');\n\t\treturn new Location(href!);\n\t}\n\n\t/**\n\t * Instantiate a Location from a URL object or string\n\t * @param {URL|string} url\n\t * @return new Location instance\n\t */\n\tstatic fromUrl(url: string): Location {\n\t\treturn new Location(url);\n\t}\n}\n","import { query, queryAll } from '../utils';\n\nexport const markSwupElements = (element: Element, containers: string[]): void => {\n\tlet blocks = 0;\n\n\tcontainers.forEach((selector) => {\n\t\tif (query(selector, element) == null) {\n\t\t\tconsole.warn(`[swup] Container ${selector} not found on page.`);\n\t\t} else {\n\t\t\tqueryAll(selector).forEach((item: Element, index: number) => {\n\t\t\t\tqueryAll(selector, element)[index].setAttribute('data-swup', String(blocks));\n\t\t\t\tblocks++;\n\t\t\t});\n\t\t}\n\t});\n};\n","export const isSwupClass = (className: string): boolean =>\n\t/^to-/.test(className) || ['is-changing', 'is-rendering', 'is-popstate'].includes(className);\n\nexport const cleanupAnimationClasses = (): void => {\n\tconst htmlClasses = document.documentElement.className.split(' ');\n\tconst removeClasses = htmlClasses.filter(isSwupClass);\n\tdocument.documentElement.classList.remove(...removeClasses);\n};\n","import { getCurrentUrl, Location } from '../helpers';\nimport Swup from '../Swup';\nimport { PageData } from './getPageData';\n\nexport interface PageRecord extends PageData {\n\turl: string;\n\tresponseURL: string;\n}\nexport class Cache {\n\tpages: Record<string, PageRecord> = {};\n\tlast: PageRecord | null = null;\n\tswup: Swup;\n\n\tconstructor(swup: Swup) {\n\t\tthis.swup = swup;\n\t}\n\n\tgetCacheUrl(url: string): string {\n\t\treturn this.swup.resolveUrl(Location.fromUrl(url).url);\n\t}\n\n\tcacheUrl(page: PageRecord) {\n\t\tpage.url = this.getCacheUrl(page.url);\n\t\tif (page.url in this.pages === false) {\n\t\t\tthis.pages[page.url] = page;\n\t\t}\n\t\tpage.responseURL = this.getCacheUrl(page.responseURL);\n\t\tthis.last = this.pages[page.url];\n\t\tthis.swup.log(`Cache (${Object.keys(this.pages).length})`, this.pages);\n\t}\n\n\tgetPage(url: string): PageRecord {\n\t\turl = this.getCacheUrl(url);\n\t\treturn this.pages[url];\n\t}\n\n\tgetCurrentPage(): PageRecord {\n\t\treturn this.getPage(getCurrentUrl());\n\t}\n\n\texists(url: string): boolean {\n\t\turl = this.getCacheUrl(url);\n\t\treturn url in this.pages;\n\t}\n\n\tempty(): void {\n\t\tthis.pages = {};\n\t\tthis.last = null;\n\t\tthis.swup.log('Cache cleared');\n\t}\n\n\tremove(url: string): void {\n\t\tdelete this.pages[this.getCacheUrl(url)];\n\t}\n}\n","import { nextTick } from '../utils';\nimport Swup from '../Swup';\nimport { PageRenderOptions } from './renderPage';\n\nexport const enterPage = function (this: Swup, { event, skipTransition }: PageRenderOptions = {}) {\n\tif (skipTransition) {\n\t\tthis.triggerEvent('transitionEnd', event);\n\t\tthis.cleanupAnimationClasses();\n\t\treturn [Promise.resolve()];\n\t}\n\n\tnextTick(() => {\n\t\tthis.triggerEvent('animationInStart');\n\t\tdocument.documentElement.classList.remove('is-animating');\n\t});\n\n\tconst animationPromises = this.getAnimationPromises('in');\n\tPromise.all(animationPromises).then(() => {\n\t\tthis.triggerEvent('animationInDone');\n\t\tthis.triggerEvent('transitionEnd', event);\n\t\tthis.cleanupAnimationClasses();\n\t});\n\treturn animationPromises;\n};\n","import { escapeCssIdentifier, query } from '../utils';\n\nexport const getAnchorElement = (hash: string): Element | null => {\n\tif (!hash) {\n\t\treturn null;\n\t}\n\n\tif (hash.charAt(0) === '#') {\n\t\thash = hash.substring(1);\n\t}\n\n\thash = decodeURIComponent(hash);\n\thash = escapeCssIdentifier(hash);\n\n\t// https://html.spec.whatwg.org/#find-a-potential-indicated-element\n\treturn query(`#${hash}`) || query(`a[name='${hash}']`);\n};\n","import { queryAll, toMs } from '../utils';\nimport Swup from '../Swup';\n\n// Transition property/event sniffing\nlet transitionProp = 'transition';\nlet transitionEndEvent = 'transitionend';\nlet animationProp = 'animation';\nlet animationEndEvent = 'animationend';\n\nif (window.ontransitionend === undefined && window.onwebkittransitionend !== undefined) {\n\ttransitionProp = 'WebkitTransition';\n\ttransitionEndEvent = 'webkitTransitionEnd';\n}\n\nif (window.onanimationend === undefined && window.onwebkitanimationend !== undefined) {\n\tanimationProp = 'WebkitAnimation';\n\tanimationEndEvent = 'webkitAnimationEnd';\n}\n\nexport function getAnimationPromises(\n\tthis: Swup,\n\t// we don't use this argument, but JS plugin depends on it with\n\t// its own version of getAnimationPromises, so it must be specified when\n\t// getAnimationPromises is being used\n\tanimationType: 'in' | 'out'\n): Promise<void>[] {\n\tconst selector = this.options.animationSelector;\n\n\t// Allow usage of swup without animations\n\tif (selector === false) {\n\t\t// Use array of a single resolved promise instead of an empty array to allow\n\t\t// possible future use with Promise.race() which requires an actual value\n\t\treturn [Promise.resolve()];\n\t}\n\n\tconst animatedElements = queryAll(selector, document.body);\n\n\t// Warn if no animated containers found on page, but keep things going\n\tif (!animatedElements.length) {\n\t\tconsole.warn(`[swup] No animated elements found by selector ${selector}`);\n\t\treturn [Promise.resolve()];\n\t}\n\n\treturn animatedElements.map((element) => getAnimationPromiseForElement(element, selector));\n}\n\nconst isTransitionOrAnimationEvent = (event: any): event is TransitionEvent | AnimationEvent =>\n\t!!event.elapsedTime;\n\nfunction getAnimationPromiseForElement(\n\telement: Element,\n\tselector: string,\n\texpectedType: 'animation' | 'transition' | null = null\n): Promise<void> {\n\tconst { type, timeout, propCount } = getTransitionInfo(element, expectedType);\n\n\t// Resolve immediately if no transition defined\n\tif (!type || !timeout) {\n\t\tconsole.warn(\n\t\t\t`[swup] No CSS transition duration defined for element of selector ${selector}`\n\t\t);\n\t\treturn Promise.resolve();\n\t}\n\n\treturn new Promise((resolve) => {\n\t\tconst endEvent = type === 'transition' ? transitionEndEvent : animationEndEvent;\n\t\tconst startTime = performance.now();\n\t\tlet propsTransitioned = 0;\n\n\t\tconst end = () => {\n\t\t\telement.removeEventListener(endEvent, onEnd);\n\t\t\tresolve();\n\t\t};\n\n\t\tconst onEnd: EventListener = (event) => {\n\t\t\t// Skip transitions on child elements\n\t\t\tif (event.target !== element) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (!isTransitionOrAnimationEvent(event)) {\n\t\t\t\tthrow new Error('Not a transition or animation event.');\n\t\t\t}\n\n\t\t\t// Skip transitions that happened before we started listening\n\t\t\tconst elapsedTime = (performance.now() - startTime) / 1000;\n\t\t\tif (elapsedTime < event.elapsedTime) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// End if all properties have transitioned\n\t\t\tif (++propsTransitioned >= propCount) {\n\t\t\t\tend();\n\t\t\t}\n\t\t};\n\n\t\tsetTimeout(() => {\n\t\t\tif (propsTransitioned < propCount) {\n\t\t\t\tend();\n\t\t\t}\n\t\t}, timeout + 1);\n\n\t\telement.addEventListener(endEvent, onEnd);\n\t});\n}\n\nexport function getTransitionInfo(\n\telement: Element,\n\texpectedType: 'animation' | 'transition' | null = null\n) {\n\tconst styles = window.getComputedStyle(element);\n\n\t// not sure what to do about the below mess other than casting, but it's a mess\n\tconst transitionDelay = `${transitionProp}Delay` as keyof CSSStyleDeclaration;\n\tconst transitionDuration = `${transitionProp}Duration` as keyof CSSStyleDeclaration;\n\tconst animationDelay = `${animationProp}Delay` as keyof CSSStyleDeclaration;\n\tconst animationDuration = `${animationProp}Duration` as keyof CSSStyleDeclaration;\n\n\tconst transitionDelays = (\n\t\tstyles[transitionDelay] as CSSStyleDeclaration['transitionDelay']\n\t).split(', ');\n\tconst transitionDurations = (\n\t\t(styles[transitionDuration] || '') as CSSStyleDeclaration['transitionDuration']\n\t).split(', ');\n\tconst transitionTimeout = calculateTimeout(transitionDelays, transitionDurations);\n\n\tconst animationDelays = (\n\t\t(styles[animationDelay] || '') as CSSStyleDeclaration['animationDelay']\n\t).split(', ');\n\tconst animationDurations = (\n\t\t(styles[animationDuration] || '') as CSSStyleDeclaration['animationDuration']\n\t).split(', ');\n\tconst animationTimeout = calculateTimeout(animationDelays, animationDurations);\n\n\tlet type: string | null = '';\n\tlet timeout = 0;\n\tlet propCount = 0;\n\n\tif (expectedType === 'transition') {\n\t\tif (transitionTimeout > 0) {\n\t\t\ttype = 'transition';\n\t\t\ttimeout = transitionTimeout;\n\t\t\tpropCount = transitionDurations.length;\n\t\t}\n\t} else if (expectedType === 'animation') {\n\t\tif (animationTimeout > 0) {\n\t\t\ttype = 'animation';\n\t\t\ttimeout = animationTimeout;\n\t\t\tpropCount = animationDurations.length;\n\t\t}\n\t} else {\n\t\ttimeout = Math.max(transitionTimeout, animationTimeout);\n\t\ttype =\n\t\t\ttimeout > 0\n\t\t\t\t? transitionTimeout > animationTimeout\n\t\t\t\t\t? 'transition'\n\t\t\t\t\t: 'animation'\n\t\t\t\t: null;\n\t\tpropCount = type\n\t\t\t? type === 'transition'\n\t\t\t\t? transitionDurations.length\n\t\t\t\t: animationDurations.length\n\t\t\t: 0;\n\t}\n\n\treturn {\n\t\ttype,\n\t\ttimeout,\n\t\tpropCount\n\t};\n}\n\nfunction calculateTimeout(delays: string[], durations: string[]) {\n\twhile (delays.length < durations.length) {\n\t\tdelays = delays.concat(delays);\n\t}\n\n\treturn Math.max(...durations.map((duration, i) => toMs(duration) + toMs(delays[i])));\n}\n","import { getDataFromHtml } from '../helpers';\nimport Swup from '../Swup';\nimport { PageHtmlData } from '../helpers/getDataFromHtml';\n\nexport type PageData = PageHtmlData & {\n\tresponseURL: string;\n};\nexport const getPageData = function (this: Swup, request: XMLHttpRequest): PageData | null {\n\t// this method can be replaced in case other content than html is expected to be received from server\n\t// this function should always return { title, pageClass, originalContent, blocks, responseURL }\n\t// in case page has invalid structure - return null\n\tconst html = request.responseText;\n\tconst pageHtmlData = getDataFromHtml(html, this.options.containers);\n\n\tif (!pageHtmlData) {\n\t\tconsole.warn('[swup] Received page is invalid.');\n\t\treturn null;\n\t}\n\n\treturn {\n\t\t...pageHtmlData,\n\t\tresponseURL: request.responseURL || window.location.href\n\t};\n};\n","import Swup from '../Swup';\nimport { fetch } from '../helpers';\nimport { TransitionOptions } from './loadPage';\nimport { PageRecord } from './Cache';\n\nexport function fetchPage(this: Swup, data: TransitionOptions): Promise<PageRecord> {\n\tconst headers = this.options.requestHeaders;\n\tconst { url } = data;\n\n\tif (this.cache.exists(url)) {\n\t\tthis.triggerEvent('pageRetrievedFromCache');\n\t\treturn Promise.resolve(this.cache.getPage(url));\n\t}\n\n\treturn new Promise((resolve, reject) => {\n\t\tfetch({ ...data, headers }, (response) => {\n\t\t\tif (response.status === 500) {\n\t\t\t\tthis.triggerEvent('serverError');\n\t\t\t\treject(url);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\t// get json data\n\t\t\tconst page = this.getPageData(response);\n\t\t\tif (!page || !page.blocks.length) {\n\t\t\t\treject(url);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\t// render page\n\t\t\tconst cacheablePageData = { ...page, url };\n\t\t\tthis.cache.cacheUrl(cacheablePageData);\n\t\t\tthis.triggerEvent('pageLoaded');\n\t\t\tresolve(cacheablePageData);\n\t\t});\n\t});\n}\n","import Swup from '../Swup';\nimport { PageRenderOptions } from './renderPage';\n\nexport const leavePage = function (this: Swup, { event, skipTransition }: PageRenderOptions = {}) {\n\tconst isHistoryVisit = event instanceof PopStateEvent;\n\n\tif (skipTransition) {\n\t\tthis.triggerEvent('animationSkipped');\n\t\treturn [Promise.resolve()];\n\t}\n\n\tthis.triggerEvent('animationOutStart');\n\n\t// handle classes\n\tdocument.documentElement.classList.add('is-changing', 'is-leaving', 'is-animating');\n\tif (isHistoryVisit) {\n\t\tdocument.documentElement.classList.add('is-popstate');\n\t}\n\n\t// animation promise stuff\n\tconst animationPromises: Promise<void>[] = this.getAnimationPromises('out');\n\tPromise.all(animationPromises).then(() => {\n\t\tthis.triggerEvent('animationOutDone');\n\t});\n\n\treturn animationPromises;\n};\n","import { classify, createHistoryRecord, getCurrentUrl } from '../helpers';\nimport Swup from '../Swup';\nimport { PageRecord } from './Cache';\n\nexport type TransitionOptions = {\n\turl: string;\n\tcustomTransition?: string;\n};\n\nexport type PageLoadOptions = {\n\turl: string;\n\tevent?: PopStateEvent;\n\tcustomTransition?: string;\n};\n\nexport function loadPage(this: Swup, data: TransitionOptions) {\n\tconst { url } = data;\n\n\t// Check if the visit should be ignored\n\tif (this.shouldIgnoreVisit(url)) {\n\t\twindow.location.href = url;\n\t} else {\n\t\tthis.performPageLoad(data);\n\t}\n}\n\nexport function performPageLoad(this: Swup, data: PageLoadOptions) {\n\tconst { url, event, customTransition } = data ?? {};\n\n\tconst isHistoryVisit = event instanceof PopStateEvent;\n\tconst skipTransition = this.shouldSkipTransition({ url, event });\n\n\tthis.triggerEvent('transitionStart', event);\n\n\t// set transition object\n\tthis.updateTransition(getCurrentUrl(), url, customTransition);\n\tif (customTransition != null) {\n\t\tdocument.documentElement.classList.add(`to-${classify(customTransition)}`);\n\t}\n\n\t// start/skip animation\n\tconst animationPromises = this.leavePage({ event, skipTransition });\n\n\t// Load page data\n\tconst fetchPromise = this.fetchPage(data);\n\n\t// create history record if this is not a popstate call (with or without anchor)\n\tif (!isHistoryVisit) {\n\t\tcreateHistoryRecord(url + (this.scrollToElement || ''));\n\t}\n\n\tthis.currentPageUrl = getCurrentUrl();\n\n\t// when everything is ready, render the page\n\tPromise.all<PageRecord | void>([fetchPromise, ...animationPromises])\n\t\t.then(([pageData]) => {\n\t\t\tthis.renderPage(pageData as PageRecord, { event, skipTransition });\n\t\t})\n\t\t.catch((errorUrl) => {\n\t\t\t// Return early if errorUrl is not defined (probably aborted preload request)\n\t\t\tif (errorUrl === undefined) return;\n\n\t\t\t// Rewrite `skipPopStateHandling` to redirect manually when `history.go` is processed\n\t\t\tthis.options.skipPopStateHandling = () => {\n\t\t\t\twindow.location = errorUrl;\n\t\t\t\treturn true;\n\t\t\t};\n\n\t\t\t// Go back to the actual page we're still at\n\t\t\thistory.go(-1);\n\t\t});\n}\n","/**\n * Perform the replacement of content after loading a page.\n *\n * This method can be replaced or augmented by plugins to allow pausing.\n *\n * It takes an object with the page data as return from `getPageData` and has to\n * return a Promise that resolves once all content has been replaced and the\n * site is ready to start animating in the new page.\n *\n * @param {object} page The page object\n * @returns Promise\n */\nexport const replaceContent = function ({ blocks, title }: { blocks: string[]; title: string }) {\n\t// Replace content blocks\n\tblocks.forEach((html, i) => {\n\t\t// we know the block exists at this point\n\t\tconst block = document.body.querySelector(`[data-swup=\"${i}\"]`)!;\n\t\tblock.outerHTML = html;\n\t});\n\n\t// Update browser title\n\tdocument.title = title;\n\n\t// Return a Promise to allow plugins to defer\n\treturn Promise.resolve();\n};\n","import Swup from '../Swup';\nimport delegate from 'delegate-it';\n\ntype HandlersEventMap = {\n\tanimationInDone: undefined;\n\tanimationInStart: undefined;\n\tanimationOutDone: undefined;\n\tanimationOutStart: undefined;\n\tanimationSkipped: undefined;\n\tclickLink: delegate.Event<MouseEvent>;\n\tcontentReplaced: PopStateEvent | undefined;\n\tdisabled: undefined;\n\tenabled: undefined;\n\topenPageInNewTab: delegate.Event<MouseEvent>;\n\tpageLoaded: undefined;\n\tpageRetrievedFromCache: undefined;\n\tpageView: PopStateEvent | undefined;\n\tpopState: PopStateEvent;\n\tsamePage: delegate.Event<MouseEvent>;\n\tsamePageWithHash: delegate.Event<MouseEvent>;\n\tserverError: undefined;\n\ttransitionStart: PopStateEvent | undefined;\n\ttransitionEnd: PopStateEvent | undefined;\n\twillReplaceContent: PopStateEvent | undefined;\n};\ntype AvailableEventNames = keyof HandlersEventMap;\n\nexport type Handler<T extends keyof HandlersEventMap> = (event: HandlersEventMap[T]) => void;\nexport type Handlers = {\n\t[Key in keyof HandlersEventMap]: Handler<Key>[];\n};\n\nexport function on<TEventType extends AvailableEventNames>(\n\tthis: Swup,\n\tevent: TEventType,\n\thandler: Handler<TEventType>\n): void {\n\tconst eventHandlers = this._handlers[event] as Handler<TEventType>[];\n\n\tif (eventHandlers) {\n\t\teventHandlers.push(handler);\n\t} else {\n\t\tconsole.warn(`Unsupported event ${event}.`);\n\t}\n}\n\nexport function off<TEventType extends AvailableEventNames>(\n\tthis: Swup,\n\tevent?: TEventType,\n\thandler?: Handler<TEventType>\n) {\n\tif (event && handler) {\n\t\tconst eventHandlers = this._handlers[event] as Handler<TEventType>[];\n\t\t// Remove specific handler\n\t\tif (eventHandlers.includes(handler)) {\n\t\t\t(this._handlers[event] as Handler<TEventType>[]) = eventHandlers.filter(\n\t\t\t\t(h) => h !== handler\n\t\t\t);\n\t\t} else {\n\t\t\tconsole.warn(`Handler for event '${event}' not found.`);\n\t\t}\n\t} else if (event) {\n\t\t// Remove all handlers for specific event\n\t\tthis._handlers[event] = [];\n\t} else {\n\t\t// Remove all handlers for all events\n\t\tObject.keys(this._handlers).forEach((event) => {\n\t\t\tthis._handlers[event as keyof HandlersEventMap] = [];\n\t\t});\n\t}\n}\n\nexport function triggerEvent<TEventType extends AvailableEventNames>(\n\tthis: Swup,\n\teventName: TEventType,\n\toriginalEvent?: HandlersEventMap[TEventType]\n): void {\n\tconst eventHandlers = this._handlers[eventName] as Handler<TEventType>[];\n\n\t// call saved handlers with \"on\" method and pass originalEvent object if available\n\teventHandlers.forEach((handler) => {\n\t\ttry {\n\t\t\thandler(originalEvent as HandlersEventMap[TEventType]);\n\t\t} catch (error) {\n\t\t\tconsole.error(error);\n\t\t}\n\t});\n\n\t// trigger event on document with prefix \"swup:\"\n\tconst event = new CustomEvent(`swup:${eventName}`, { detail: eventName });\n\tdocument.dispatchEvent(event);\n}\n","import Swup from '../Swup';\n\nexport type Plugin = {\n\tname: string;\n\tisSwupPlugin: true;\n\tmount: () => void;\n\tunmount: () => void;\n\n\t// the instance is assigned later on after passing to swup\n\tswup?: Swup;\n\n\t// these are possibly undefined for backward compatibility\n\tversion?: string;\n\trequires?: Record<string, string>;\n\t_beforeMount?: () => void;\n\t_afterUnmount?: () => void;\n\t_checkRequirements?: () => boolean;\n};\n\nconst isSwupPlugin = (maybeInvalidPlugin: unknown): maybeInvalidPlugin is Plugin => {\n\t// @ts-ignore\n\treturn maybeInvalidPlugin?.isSwupPlugin;\n};\n\nexport const use = function (this: Swup, plugin: unknown) {\n\tif (!isSwupPlugin(plugin)) {\n\t\tconsole.error('Not a swup plugin instance', plugin);\n\t\treturn;\n\t}\n\n\tplugin.swup = this;\n\tif (plugin._checkRequirements) {\n\t\tif (!plugin._checkRequirements()) {\n\t\t\treturn;\n\t\t}\n\t}\n\tif (plugin._beforeMount) {\n\t\tplugin._beforeMount();\n\t}\n\tplugin.mount();\n\n\tthis.plugins.push(plugin);\n\n\treturn this.plugins;\n};\n\nexport function unuse(this: Swup, pluginOrName: Plugin | string) {\n\tconst plugin = this.findPlugin(pluginOrName);\n\tif (!plugin) {\n\t\tconsole.error('No such plugin', plugin);\n\t\treturn;\n\t}\n\n\tplugin.unmount();\n\tif (plugin._afterUnmount) {\n\t\tplugin._afterUnmount();\n\t}\n\n\tthis.plugins = this.plugins.filter((p) => p !== plugin);\n\n\treturn this.plugins;\n}\n\nexport function findPlugin(this: Swup, pluginOrName: Plugin | string) {\n\treturn this.plugins.find((plugin) => plugin === pluginOrName || plugin.name === pluginOrName);\n}\n","import { Location, updateHistoryRecord, getCurrentUrl } from '../helpers';\nimport Swup from '../Swup';\nimport { PageRecord } from './Cache';\n\nexport type PageRenderOptions = {\n\tevent?: PopStateEvent;\n\tskipTransition?: boolean;\n};\n\nexport const renderPage = function (\n\tthis: Swup,\n\tpage: PageRecord,\n\t{ event, skipTransition }: PageRenderOptions = {}\n) {\n\tdocument.documentElement.classList.remove('is-leaving');\n\n\t// do nothing if another page was requested in the meantime\n\tif (!this.isSameResolvedUrl(getCurrentUrl(), page.url)) {\n\t\treturn;\n\t}\n\n\tconst { url } = Location.fromUrl(page.responseURL);\n\n\t// update cache and state if the url was redirected\n\tif (!this.isSameResolvedUrl(getCurrentUrl(), url)) {\n\t\tthis.cache.cacheUrl({ ...page, url });\n\t\tthis.currentPageUrl = getCurrentUrl();\n\t\tupdateHistoryRecord(url);\n\t}\n\n\t// only add for page loads with transitions\n\tif (!skipTransition) {\n\t\tdocument.documentElement.classList.add('is-rendering');\n\t}\n\n\tthis.triggerEvent('willReplaceContent', event);\n\n\tthis.replaceContent(page).then(() => {\n\t\tthis.triggerEvent('contentReplaced', event);\n\t\tthis.triggerEvent('pageView', event);\n\n\t\t// empty cache if it's disabled (in case preload plugin filled it)\n\t\tif (!this.options.cache) {\n\t\t\tthis.cache.empty();\n\t\t}\n\n\t\t// Perform in transition\n\t\tthis.enterPage({ event, skipTransition });\n\n\t\t// reset scroll-to element\n\t\tthis.scrollToElement = null;\n\t});\n};\n","import Swup from '../Swup';\n\nexport function updateTransition(this: Swup, from: string, to: string, custom?: string): void {\n\tthis.transition = { from, to, custom };\n}\n\nexport function shouldSkipTransition(this: Swup, { event }: { url?: string; event?: Event }) {\n\tconst isHistoryVisit = event instanceof PopStateEvent;\n\treturn !!(isHistoryVisit && !this.options.animateHistoryBrowsing);\n}\n","import delegate from 'delegate-it';\n\nimport version from './config/version';\n\nimport {\n\tcleanupAnimationClasses,\n\tdelegateEvent,\n\tgetCurrentUrl,\n\tLocation,\n\tmarkSwupElements,\n\tupdateHistoryRecord\n} from './helpers';\nimport { Unsubscribe } from './helpers/delegateEvent';\n\nimport { Cache } from './modules/Cache';\nimport { enterPage } from './modules/enterPage';\nimport { getAnchorElement } from './modules/getAnchorElement';\nimport { getAnimationPromises } from './modules/getAnimationPromises';\nimport { getPageData } from './modules/getPageData';\nimport { fetchPage } from './modules/fetchPage';\nimport { leavePage } from './modules/leavePage';\nimport { loadPage, performPageLoad } from './modules/loadPage';\nimport { replaceContent } from './modules/replaceContent';\nimport { on, off, triggerEvent, Handlers } from './modules/events';\nimport { use, unuse, findPlugin, Plugin } from './modules/plugins';\nimport { renderPage } from './modules/renderPage';\nimport { updateTransition, shouldSkipTransition } from './modules/transitions';\n\nimport { queryAll } from './utils';\n\nexport type Transition = {\n\tfrom?: string;\n\tto?: string;\n\tcustom?: string;\n};\n\ntype DelegatedListeners = {\n\tclick?: Unsubscribe;\n};\n\nexport type Options = {\n\tanimateHistoryBrowsing: boolean;\n\tanimationSelector: string | false;\n\tlinkSelector: string;\n\tcache: boolean;\n\tcontainers: string[];\n\trequestHeaders: Record<string, string>;\n\tplugins: Plugin[];\n\tskipPopStateHandling: (event: any) => boolean;\n\tignoreVisit: (url: string, { el }: { el?: Element }) => boolean;\n\tresolveUrl: (url: string) => string;\n};\n\nexport default class Swup {\n\tversion = version;\n\n\t_handlers: Handlers = {\n\t\tanimationInDone: [],\n\t\tanimationInStart: [],\n\t\tanimationOutDone: [],\n\t\tanimationOutStart: [],\n\t\tanimationSkipped: [],\n\t\tclickLink: [],\n\t\tcontentReplaced: [],\n\t\tdisabled: [],\n\t\tenabled: [],\n\t\topenPageInNewTab: [],\n\t\tpageLoaded: [],\n\t\tpageRetrievedFromCache: [],\n\t\tpageView: [],\n\t\tpopState: [],\n\t\tsamePage: [],\n\t\tsamePageWithHash: [],\n\t\tserverError: [],\n\t\ttransitionStart: [],\n\t\ttransitionEnd: [],\n\t\twillReplaceContent: []\n\t};\n\n\t// variable for anchor to scroll to after render\n\tscrollToElement: string | null = null;\n\t// variable for save options\n\toptions: Options;\n\t// running plugin instances\n\tplugins: Plugin[] = [];\n\t// variable for current transition info object\n\ttransition: Transition = {};\n\t// cache instance\n\tcache: Cache;\n\t// allows us to compare the current and new path inside popStateHandler\n\tcurrentPageUrl = getCurrentUrl();\n\t// variable for keeping event listeners from \"delegate\"\n\tdelegatedListeners: DelegatedListeners = {};\n\t// so we are able to remove the listener\n\tboundPopStateHandler: (event: PopStateEvent) => void;\n\n\tloadPage = loadPage;\n\tperformPageLoad = performPageLoad;\n\tleavePage = leavePage;\n\trenderPage = renderPage;\n\treplaceContent = replaceContent;\n\tenterPage = enterPage;\n\ttriggerEvent = triggerEvent;\n\tdelegateEvent = delegateEvent;\n\ton = on;\n\toff = off;\n\tupdateTransition = updateTransition;\n\tshouldSkipTransition = shouldSkipTransition;\n\tgetAnimationPromises = getAnimationPromises;\n\tgetPageData = getPageData;\n\tfetchPage = fetchPage;\n\tgetAnchorElement = getAnchorElement;\n\tlog: (message: string, context?: any) => void = () => {}; // here so it can be used by plugins\n\tuse = use;\n\tunuse = unuse;\n\tfindPlugin = findPlugin;\n\tgetCurrentUrl = getCurrentUrl;\n\tcleanupAnimationClasses = cleanupAnimationClasses;\n\n\tdefaults: Options = {\n\t\tanimateHistoryBrowsing: false,\n\t\tanimationSelector: '[class*=\"transition-\"]',\n\t\tcache: true,\n\t\tcontainers: ['#swup'],\n\t\tignoreVisit: (url, { el } = {}) => !!el?.closest('[data-no-swup]'),\n\t\tlinkSelector: 'a[href]',\n\t\tplugins: [],\n\t\tresolveUrl: (url) => url,\n\t\trequestHeaders: {\n\t\t\t'X-Requested-With': 'swup',\n\t\t\tAccept: 'text/html, application/xhtml+xml'\n\t\t},\n\t\tskipPopStateHandling: (event) => event.state?.source !== 'swup'\n\t};\n\n\tconstructor(options: Partial<Options> = {}) {\n\t\t// Merge defaults and options\n\t\tthis.options = { ...this.defaults, ...options };\n\n\t\tthis.boundPopStateHandler = this.popStateHandler.bind(this);\n\n\t\tthis.cache = new Cache(this);\n\n\t\tthis.enable();\n\t}\n\n\tenable() {\n\t\t// Check for Promise support\n\t\tif (typeof Promise === 'undefined') {\n\t\t\tconsole.warn('Promise is not supported');\n\t\t\treturn;\n\t\t}\n\n\t\t// Add event listeners\n\t\tthis.delegatedListeners.click = delegateEvent(\n\t\t\tthis.options.linkSelector,\n\t\t\t'click',\n\t\t\tthis.linkClickHandler.bind(this)\n\t\t);\n\n\t\twindow.addEventListener('popstate', this.boundPopStateHandler);\n\n\t\t// Initial save to cache\n\t\tif (this.options.cache) {\n\t\t\t// Disabled to avoid caching modified dom state: logic moved to preload plugin\n\t\t\t// https://github.com/swup/swup/issues/475\n\t\t}\n\n\t\t// Mark swup blocks in html\n\t\tmarkSwupElements(document.documentElement, this.options.containers);\n\n\t\t// Mount plugins\n\t\tthis.options.plugins.forEach((plugin) => this.use(plugin));\n\n\t\t// Modify initial history record\n\t\tupdateHistoryRecord();\n\n\t\t// Trigger enabled event\n\t\tthis.triggerEvent('enabled');\n\n\t\t// Add swup-enabled class to html tag\n\t\tdocument.documentElement.classList.add('swup-enabled');\n\n\t\t// Trigger page view event\n\t\tthis.triggerEvent('pageView');\n\t}\n\n\tdestroy() {\n\t\t// remove delegated listeners\n\t\tthis.delegatedListeners.click!.destroy();\n\n\t\t// remove popstate listener\n\t\twindow.removeEventListener('popstate', this.boundPopStateHandler);\n\n\t\t// empty cache\n\t\tthis.cache.empty();\n\n\t\t// unmount plugins\n\t\tthis.options.plugins.forEach((plugin) => {\n\t\t\tthis.unuse(plugin);\n\t\t});\n\n\t\t// remove swup data atributes from blocks\n\t\tqueryAll('[data-swup]').forEach((element) => {\n\t\t\telement.removeAttribute('data-swup');\n\t\t});\n\n\t\t// remove handlers\n\t\tthis.off();\n\n\t\t// trigger disable event\n\t\tthis.triggerEvent('disabled');\n\n\t\t// remove swup-enabled class from html tag\n\t\tdocument.documentElement.classList.remove('swup-enabled');\n\t}\n\n\tshouldIgnoreVisit(href: string, { el }: { el?: Element } = {}) {\n\t\tconst { origin, url, hash } = Location.fromUrl(href);\n\n\t\t// Ignore if the new origin doesn't match the current one\n\t\tif (origin !== window.location.origin) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// Ignore if the link/form would open a new window (or none at all)\n\t\tif (el && this.triggerWillOpenNewWindow(el)) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// Ignore if the visit should be ignored as per user options\n\t\tif (this.options.ignoreVisit(url + hash, { el })) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// Finally, allow the visit\n\t\treturn false;\n\t}\n\n\tlinkClickHandler(event: delegate.Event<MouseEvent>) {\n\t\tconst linkEl = event.delegateTarget;\n\t\tconst { href, url, hash } = Location.fromElement(linkEl as HTMLAnchorElement);\n\n\t\t// Exit early if the link should be ignored\n\t\tif (this.shouldIgnoreVisit(href, { el: linkEl })) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Exit early if control key pressed\n\t\tif (event.metaKey || event.ctrlKey || event.shiftKey || event.altKey) {\n\t\t\tthis.triggerEvent('openPageInNewTab', event);\n\t\t\treturn;\n\t\t}\n\n\t\t// Exit early if other than left mouse button\n\t\tif (event.button !== 0) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis.triggerEvent('clickLink', event);\n\t\tevent.preventDefault();\n\n\t\t// Handle links to the same page and exit early, where applicable\n\t\tif (!url || url === getCurrentUrl()) {\n\t\t\tthis.handleLinkToSamePage(url, hash, event);\n\t\t\treturn;\n\t\t}\n\n\t\t// Exit early if the resolved path hasn't changed\n\t\tif (this.isSameResolvedUrl(url, getCurrentUrl())) return;\n\n\t\t// Store the element that should be scrolled to after loading the next page\n\t\tthis.scrollToElement = hash || null;\n\n\t\t// Get the custom transition name, if present\n\t\tconst customTransition = linkEl.getAttribute('data-swup-transition') || undefined;\n\n\t\t// Finally, proceed with loading the page\n\t\tthis.performPageLoad({ url, customTransition });\n\t}\n\n\thandleLinkToSamePage(url: string, hash: string, event: delegate.Event<MouseEvent>) {\n\t\t// Emit event and exit early if the url points to the same page without hash\n\t\tif (!hash) {\n\t\t\tthis.triggerEvent('samePage', event);\n\t\t\treturn;\n\t\t}\n\n\t\t// link to the same URL with hash\n\t\tthis.triggerEvent('samePageWithHash', event);\n\n\t\tconst element = getAnchorElement(hash);\n\n\t\t// Warn and exit early if no matching element was found for the hash\n\t\tif (!element) {\n\t\t\treturn console.warn(`Element for offset not found (#${hash})`);\n\t\t}\n\n\t\tupdateHistoryRecord(url + hash);\n\t}\n\n\ttriggerWillOpenNewWindow(triggerEl: Element) {\n\t\tif (triggerEl.matches('[download], [target=\"_blank\"]')) {\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n\n\tpopStateHandler(event: PopStateEvent) {\n\t\t// Exit early if this event should be ignored\n\t\tif (this.options.skipPopStateHandling(event)) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Exit early if the resolved path hasn't changed\n\t\tif (this.isSameResolvedUrl(getCurrentUrl(), this.currentPageUrl)) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst href = event.state?.url ?? location.href;\n\n\t\t// Exit early if the link should be ignored\n\t\tif (this.shouldIgnoreVisit(href)) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst { url, hash } = Location.fromUrl(href);\n\n\t\tif (hash) {\n\t\t\tthis.scrollToElement = hash;\n\t\t} else {\n\t\t\tevent.preventDefault();\n\t\t}\n\n\t\tthis.triggerEvent('popState', event);\n\n\t\tif (!this.options.animateHistoryBrowsing) {\n\t\t\tdocument.documentElement.classList.remove('is-animating');\n\t\t\tcleanupAnimationClasses();\n\t\t}\n\n\t\tthis.performPageLoad({ url, event });\n\t}\n\n\t/**\n\t * Utility function to validate and run the global option 'resolveUrl'\n\t * @param {string} url\n\t * @returns {string} the resolved url\n\t */\n\tresolveUrl(url: string) {\n\t\tif (typeof this.options.resolveUrl !== 'function') {\n\t\t\tconsole.warn(`[swup] options.resolveUrl expects a callback function.`);\n\t\t\treturn url;\n\t\t}\n\t\tconst result = this.options.resolveUrl(url);\n\t\tif (!result || typeof result !== 'string') {\n\t\t\tconsole.warn(`[swup] options.resolveUrl needs to return a url`);\n\t\t\treturn url;\n\t\t}\n\t\tif (result.startsWith('//') || result.startsWith('http')) {\n\t\t\tconsole.warn(`[swup] options.resolveUrl needs to return a relative url`);\n\t\t\treturn url;\n\t\t}\n\t\treturn result;\n\t}\n\n\t/**\n\t * Compares the resolved version of two paths and returns true if they are the same\n\t * @param {string} url1\n\t * @param {string} url2\n\t * @returns {boolean}\n\t */\n\tisSameResolvedUrl(url1: string, url2: string) {\n\t\treturn this.resolveUrl(url1) === this.resolveUrl(url2);\n\t}\n}\n"],"names":["classify","text","fallback","String","toLowerCase","replace","getCurrentUrl","_temp","hash","location","pathname","search","createHistoryRecord","url","customData","data","random","Math","source","history","pushState","updateHistoryRecord","state","replaceState","delegateEvent","selector","type","callback","base","document","eventOptions","delegation","delegate","destroy","query","context","querySelector","queryAll","Array","from","querySelectorAll","nextTick","requestAnimationFrame","escapeCssIdentifier","ident","window","CSS","escape","toMs","s","Number","slice","getDataFromHtml","html","containers","fakeDom","createElement","innerHTML","blocks","forEach","console","warn","length","item","index","setAttribute","push","outerHTML","title","innerText","pageClass","className","originalContent","fetch","options","defaults","method","headers","request","onreadystatechange","readyState","open","Object","entries","_ref","key","header","setRequestHeader","send","Location","constructor","baseURI","super","toString","this","static","el","getAttribute","href","markSwupElements","element","isSwupClass","test","includes","cleanupAnimationClasses","removeClasses","documentElement","split","filter","classList","remove","Cache","swup","pages","last","getCacheUrl","resolveUrl","fromUrl","cacheUrl","page","responseURL","log","keys","getPage","getCurrentPage","exists","empty","enterPage","event","skipTransition","triggerEvent","Promise","resolve","animationPromises","getAnimationPromises","all","then","getAnchorElement","charAt","substring","decodeURIComponent","transitionProp","transitionEndEvent","animationProp","animationEndEvent","animationType","animationSelector","body","animatedElements","map","expectedType","timeout","propCount","styles","getComputedStyle","animationDelay","transitionDelays","transitionDurations","transitionDuration","transitionTimeout","calculateTimeout","animationDelays","animationDurations","animationDuration","animationTimeout","max","getTransitionInfo","performance","now","end","removeEventListener","endEvent","onEnd","target","elapsedTime","isTransitionOrAnimationEvent","Error","startTime","propsTransitioned","setTimeout","addEventListener","getAnimationPromiseForElement","delays","durations","concat","duration","i","undefined","ontransitionend","onwebkittransitionend","onanimationend","onwebkitanimationend","getPageData","pageHtmlData","responseText","fetchPage","requestHeaders","cache","reject","response","status","cacheablePageData","leavePage","isHistoryVisit","add","loadPage","shouldIgnoreVisit","performPageLoad","customTransition","PopStateEvent","shouldSkipTransition","updateTransition","fetchPromise","scrollToElement","currentPageUrl","pageData","renderPage","catch","errorUrl","skipPopStateHandling","go","replaceContent","handler","eventHandlers","_handlers","off","h","eventName","originalEvent","error","CustomEvent","detail","dispatchEvent","plugin","isSwupPlugin","_checkRequirements","_beforeMount","mount","plugins","pluginOrName","findPlugin","unmount","_afterUnmount","p","find","name","isSameResolvedUrl","to","custom","transition","animateHistoryBrowsing","version","animationInDone","animationInStart","animationOutDone","animationOutStart","animationSkipped","clickLink","contentReplaced","disabled","enabled","openPageInNewTab","pageLoaded","pageRetrievedFromCache","pageView","popState","samePage","samePageWithHash","serverError","transitionStart","transitionEnd","willReplaceContent","delegatedListeners","boundPopStateHandler","on","use","unuse","ignoreVisit","closest","linkSelector","Accept","popStateHandler","bind","enable","click","linkClickHandler","removeAttribute","_temp2","origin","triggerWillOpenNewWindow","linkEl","delegateTarget","fromElement","metaKey","ctrlKey","shiftKey","altKey","button","preventDefault","handleLinkToSamePage","triggerEl","matches","result","startsWith","url1","url2"],"mappings":"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"}
1
+ {"version":3,"file":"Swup.cjs","sources":["../src/helpers/classify.ts","../src/helpers/getCurrentUrl.ts","../src/helpers/createHistoryRecord.ts","../src/helpers/updateHistoryRecord.ts","../src/helpers/delegateEvent.ts","../src/helpers/Location.ts","../src/modules/Cache.ts","../src/utils/index.ts","../src/modules/Classes.ts","../src/modules/Context.ts","../src/modules/Hooks.ts","../src/modules/getAnchorElement.ts","../src/modules/awaitAnimations.ts","../src/modules/visit.ts","../src/modules/fetchPage.ts","../src/modules/leavePage.ts","../src/modules/replaceContent.ts","../src/modules/enterPage.ts","../src/modules/renderPage.ts","../src/modules/plugins.ts","../src/Swup.ts","../src/helpers/matchPath.ts"],"sourcesContent":["export const classify = (text: string, fallback?: string): string => {\n\tconst output = String(text)\n\t\t.toLowerCase()\n\t\t// .normalize('NFD') // split an accented letter in the base letter and the acent\n\t\t// .replace(/[\\u0300-\\u036f]/g, '') // remove all previously split accents\n\t\t.replace(/[\\s/_.]+/g, '-') // replace spaces and _./ with '-'\n\t\t.replace(/[^\\w-]+/g, '') // remove all non-word chars\n\t\t.replace(/--+/g, '-') // replace repeating '-' with single '-'\n\t\t.replace(/^-+|-+$/g, ''); // trim '-' from edges\n\treturn output || fallback || '';\n};\n","export const getCurrentUrl = ({ hash }: { hash?: boolean } = {}): string => {\n\treturn location.pathname + location.search + (hash ? location.hash : '');\n};\n","import { getCurrentUrl } from './getCurrentUrl.js';\n\nexport const createHistoryRecord = (\n\turl: string,\n\tcustomData: Record<string, unknown> = {}\n): void => {\n\turl = url || getCurrentUrl({ hash: true });\n\tconst data = {\n\t\turl,\n\t\trandom: Math.random(),\n\t\tsource: 'swup',\n\t\t...customData\n\t};\n\thistory.pushState(data, '', url);\n};\n","import { getCurrentUrl } from './getCurrentUrl.js';\n\nexport const updateHistoryRecord = (\n\turl: string | null = null,\n\tcustomData: Record<string, unknown> = {}\n): void => {\n\turl = url || getCurrentUrl({ hash: true });\n\tconst data = {\n\t\t...history.state,\n\t\turl,\n\t\trandom: Math.random(),\n\t\tsource: 'swup',\n\t\t...customData\n\t};\n\thistory.replaceState(data, '', url);\n};\n","import delegate, { DelegateEventHandler, DelegateOptions, EventType } from 'delegate-it';\nimport { ParseSelector } from 'typed-query-selector/parser.js';\n\nexport type DelegateEventUnsubscribe = {\n\tdestroy: () => void;\n};\n\nexport const delegateEvent = <Selector extends string, TEvent extends EventType>(\n\tselector: Selector,\n\ttype: TEvent,\n\tcallback: DelegateEventHandler<GlobalEventHandlersEventMap[TEvent]>,\n\toptions?: DelegateOptions\n): DelegateEventUnsubscribe => {\n\tconst controller = new AbortController();\n\toptions = { ...options, signal: controller.signal };\n\tdelegate<string, ParseSelector<Selector, HTMLElement>, TEvent>(\n\t\tselector,\n\t\ttype,\n\t\tcallback,\n\t\toptions\n\t);\n\treturn { destroy: () => controller.abort() };\n};\n","/**\n * A helper for creating a Location from either an element\n * or a URL object/string\n *\n */\n\nexport class Location extends URL {\n\tconstructor(url: URL | string, base: string = document.baseURI) {\n\t\tsuper(url.toString(), base);\n\t}\n\n\t/**\n\t * The full local path including query params.\n\t */\n\tget url(): string {\n\t\treturn this.pathname + this.search;\n\t}\n\n\t/**\n\t * Instantiate a Location from an element's href attribute\n\t * @param el\n\t * @returns new Location instance\n\t */\n\tstatic fromElement(el: Element): Location {\n\t\tconst href = el.getAttribute('href') || el.getAttribute('xlink:href') || '';\n\t\treturn new Location(href!);\n\t}\n\n\t/**\n\t * Instantiate a Location from a URL object or string\n\t * @param url\n\t * @returns new Location instance\n\t */\n\tstatic fromUrl(url: URL | string): Location {\n\t\treturn new Location(url);\n\t}\n}\n","import Swup from '../Swup.js';\nimport { Location } from '../helpers.js';\nimport { PageData } from './fetchPage.js';\n\nexport interface CacheData extends PageData {}\n\nexport class Cache {\n\tprivate swup: Swup;\n\tprivate pages: Map<string, CacheData> = new Map();\n\n\tconstructor(swup: Swup) {\n\t\tthis.swup = swup;\n\t}\n\n\tget size() {\n\t\treturn this.pages.size;\n\t}\n\n\tget all() {\n\t\treturn this.pages;\n\t}\n\n\tpublic has(url: string): boolean {\n\t\treturn this.pages.has(this.resolve(url));\n\t}\n\n\tpublic get(url: string): CacheData | undefined {\n\t\treturn this.pages.get(this.resolve(url));\n\t}\n\n\tpublic set(url: string, page: CacheData) {\n\t\turl = this.resolve(url);\n\t\tpage = { ...page, url };\n\t\tthis.pages.set(url, page);\n\t\tthis.swup.hooks.triggerSync('cache:set', { page });\n\t}\n\n\tpublic update(url: string, page: CacheData) {\n\t\turl = this.resolve(url);\n\t\tpage = { ...this.get(url), ...page, url };\n\t\tthis.pages.set(url, page);\n\t}\n\n\tpublic delete(url: string): void {\n\t\tthis.pages.delete(this.resolve(url));\n\t}\n\n\tpublic clear(): void {\n\t\tthis.pages.clear();\n\t\tthis.swup.hooks.triggerSync('cache:clear');\n\t}\n\n\tpublic prune(predicate: (url: string, page: CacheData) => boolean): void {\n\t\tthis.pages.forEach((page, url) => {\n\t\t\tif (predicate(url, page)) {\n\t\t\t\tthis.delete(url);\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate resolve(urlToResolve: string): string {\n\t\tconst { url } = Location.fromUrl(urlToResolve);\n\t\treturn this.swup.resolveUrl(url);\n\t}\n}\n","export const query = (selector: string, context: Document | Element = document) => {\n\treturn context.querySelector<HTMLElement>(selector);\n};\n\nexport const queryAll = (\n\tselector: string,\n\tcontext: Document | Element = document\n): HTMLElement[] => {\n\treturn Array.from(context.querySelectorAll(selector));\n};\n\nexport const nextTick = (): Promise<void> => {\n\treturn new Promise((resolve) => {\n\t\trequestAnimationFrame(() => {\n\t\t\trequestAnimationFrame(() => {\n\t\t\t\tresolve();\n\t\t\t});\n\t\t});\n\t});\n};\n\nexport function isPromise<T>(obj: any): obj is PromiseLike<T> {\n\treturn (\n\t\t!!obj &&\n\t\t(typeof obj === 'object' || typeof obj === 'function') &&\n\t\ttypeof obj.then === 'function'\n\t);\n}\n\nexport function runAsPromise(func: Function, args: any[] = [], ctx: any = {}): Promise<any> {\n\treturn new Promise((resolve, reject) => {\n\t\tconst result = func.apply(ctx, args);\n\t\tif (isPromise(result)) {\n\t\t\tresult.then(resolve, reject);\n\t\t} else {\n\t\t\tresolve(result);\n\t\t}\n\t});\n}\n\nexport const escapeCssIdentifier = (ident: string) => {\n\t// @ts-ignore this is for support check, so it's correct that TS complains\n\tif (window.CSS && window.CSS.escape) {\n\t\treturn CSS.escape(ident);\n\t}\n\treturn ident;\n};\n\n// Fix for Chrome below v61 formatting CSS floats with comma in some locales\nexport const toMs = (s: string) => {\n\treturn Number(s.slice(0, -1).replace(',', '.')) * 1000;\n};\n","import Swup from '../Swup.js';\nimport { queryAll } from '../utils.js';\n\nexport class Classes {\n\tpublic swup: Swup;\n\n\tswupClasses = ['to-', 'is-changing', 'is-rendering', 'is-popstate', 'is-animating'];\n\n\tconstructor(swup: Swup) {\n\t\tthis.swup = swup;\n\t}\n\n\tget selectors(): string[] {\n\t\tconst { scope } = this.swup.context.animation;\n\t\tif (scope === 'containers') return this.swup.context.containers;\n\t\tif (scope === 'html') return ['html'];\n\t\tif (Array.isArray(scope)) return scope;\n\t\treturn [];\n\t}\n\n\tget selector(): string {\n\t\treturn this.selectors.join(',');\n\t}\n\n\tget targets(): HTMLElement[] {\n\t\tif (!this.selector.trim()) return [];\n\t\treturn queryAll(this.selector) as HTMLElement[];\n\t}\n\n\tpublic add(...classes: string[]): void {\n\t\tthis.targets.forEach((target) => target.classList.add(...classes));\n\t}\n\n\tpublic remove(...classes: string[]): void {\n\t\tthis.targets.forEach((target) => target.classList.remove(...classes));\n\t}\n\n\tpublic clear(): void {\n\t\tthis.targets.forEach((target) => {\n\t\t\tconst remove = target.className.split(' ').filter((c) => this.isSwupClass(c));\n\t\t\ttarget.classList.remove(...remove);\n\t\t});\n\t}\n\n\tprivate isSwupClass(className: string): boolean {\n\t\treturn this.swupClasses.some((c) => className.startsWith(c));\n\t}\n}\n","import Swup, { Options } from '../Swup.js';\nimport { HistoryAction, HistoryDirection } from './visit.js';\n\nexport interface Context<TEvent = Event> {\n\t/** The previous page, about to leave */\n\tfrom: FromContext;\n\t/** The next page, about to enter */\n\tto: ToContext;\n\t/** The content containers, about to be replaced */\n\tcontainers: Options['containers'];\n\t/** Information about animated page transitions */\n\tanimation: AnimationContext;\n\t/** What triggered this visit */\n\ttrigger: TriggerContext<TEvent>;\n\t/** Browser history behavior on this visit */\n\thistory: HistoryContext;\n\t/** Scroll behavior on this visit */\n\tscroll: ScrollContext;\n}\n\nexport interface FromContext {\n\t/** The URL of the previous page */\n\turl: string;\n}\n\nexport interface ToContext {\n\t/** The URL of the next page */\n\turl?: string;\n\t/** The HTML content of the next page */\n\thtml?: string;\n}\n\nexport interface AnimationContext {\n\t/** Whether this visit is animated. Default: `true` */\n\tanimate: boolean;\n\t/** Whether to wait for the next page to load before starting the animation. Default: `false` */\n\twait: boolean;\n\t/** Name of a custom animation to run. */\n\tname?: string;\n\t/** Elements on which to add animation classes. Default: `html` element */\n\tscope: 'html' | 'containers' | string[];\n\t/** Selector for detecting animation timing. Default: `[class*=\"transition-\"]` */\n\tselector: Options['animationSelector'];\n}\n\nexport interface ScrollContext {\n\t/** Whether to reset the scroll position after the visit. Default: `true` */\n\treset: boolean;\n\t/** Anchor element to scroll to on the next page. */\n\ttarget?: string;\n}\n\nexport interface TriggerContext<TEvent = Event> {\n\t/** DOM element that triggered this visit. */\n\tel?: Element;\n\t/** DOM event that triggered this visit. */\n\tevent?: TEvent;\n}\n\nexport interface HistoryContext {\n\t/** History action to perform: `push` for creating a new history entry, `replace` for replacing the current entry. Default: `push` */\n\taction: HistoryAction;\n\t/** Whether this visit was triggered by a browser history navigation. */\n\tpopstate: boolean;\n\t/** The direction of travel in case of a browser history navigation: backward or forward. */\n\tdirection: HistoryDirection | undefined;\n}\n\nexport interface ContextInitOptions {\n\tto: string | undefined;\n\tfrom?: string;\n\thash?: string;\n\tanimate?: boolean;\n\tanimation?: string;\n\ttargets?: string[];\n\tel?: Element;\n\tevent?: Event;\n\taction?: HistoryAction;\n\tresetScroll?: boolean;\n}\n\nexport function createContext(\n\tthis: Swup,\n\t{\n\t\tto,\n\t\tfrom = this.currentPageUrl,\n\t\thash: target,\n\t\tanimate = true,\n\t\tanimation: name,\n\t\tel,\n\t\tevent,\n\t\taction = 'push',\n\t\tresetScroll: reset = true\n\t}: ContextInitOptions\n): Context {\n\treturn {\n\t\tfrom: { url: from },\n\t\tto: { url: to },\n\t\tcontainers: this.options.containers,\n\t\tanimation: {\n\t\t\tanimate,\n\t\t\twait: false,\n\t\t\tname,\n\t\t\tscope: this.options.animationScope,\n\t\t\tselector: this.options.animationSelector\n\t\t},\n\t\ttrigger: {\n\t\t\tel,\n\t\t\tevent\n\t\t},\n\t\thistory: {\n\t\t\taction,\n\t\t\tpopstate: false,\n\t\t\tdirection: undefined\n\t\t},\n\t\tscroll: {\n\t\t\treset,\n\t\t\ttarget\n\t\t}\n\t};\n}\n","import { DelegateEvent } from 'delegate-it';\n\nimport Swup, { Options } from '../Swup.js';\nimport { isPromise, runAsPromise } from '../utils.js';\nimport { Context } from './Context.js';\nimport { FetchOptions, PageData } from './fetchPage.js';\nimport { AnimationDirection } from './awaitAnimations.js';\n\nexport interface HookDefinitions {\n\t'animation:out:start': undefined;\n\t'animation:out:end': undefined;\n\t'animation:in:start': undefined;\n\t'animation:in:end': undefined;\n\t'animation:skip': undefined;\n\t'animation:await': { direction: AnimationDirection };\n\t'cache:clear': undefined;\n\t'cache:set': { page: PageData };\n\t'content:replace': { page: PageData };\n\t'content:scroll': { options: ScrollIntoViewOptions };\n\t'enable': undefined;\n\t'disable': undefined;\n\t'fetch:request': { url: string; options: FetchOptions };\n\t'fetch:error': { url: string; status: number; response: Response };\n\t'history:popstate': { event: PopStateEvent };\n\t'link:click': { el: HTMLAnchorElement; event: DelegateEvent<MouseEvent> };\n\t'link:self': undefined;\n\t'link:anchor': { hash: string; options: ScrollIntoViewOptions };\n\t'link:newtab': { href: string };\n\t'page:request': { url: string; options: FetchOptions };\n\t'page:load': { page: PageData; cache?: boolean };\n\t'page:view': { url: string; title: string };\n\t'visit:start': undefined;\n\t'visit:end': undefined;\n}\n\nexport type HookArguments<T extends HookName> = HookDefinitions[T];\n\nexport type HookName = keyof HookDefinitions;\n\nexport type Handler<T extends HookName> = (\n\t/** The global context object for the current visit */\n\tcontext: Context,\n\t/** The local arguments passed into the handler */\n\targs: HookArguments<T>,\n\t/** The default handler to be executed, available if replacing an internal hook handler */\n\tdefaultHandler?: Handler<T>\n) => Promise<any> | void;\n\nexport type Handlers = {\n\t[K in HookName]: Handler<K>[];\n};\n\nexport type HookUnregister = () => void;\n\nexport type HookOptions = {\n\t/** Execute the hook once, then remove the handler */\n\tonce?: boolean;\n\t/** Execute the hook before the internal default handler */\n\tbefore?: boolean;\n\t/** Set a priority for when to execute this hook. Lower numbers execute first. Default: `0` */\n\tpriority?: number;\n\t/** Replace the internal default handler with this hook handler */\n\treplace?: boolean;\n};\n\nexport type HookRegistration<T extends HookName> = {\n\tid: number;\n\thook: T;\n\thandler: Handler<T>;\n} & HookOptions;\n\ntype HookLedger<T extends HookName> = Map<Handler<T>, HookRegistration<T>>;\n\ninterface HookRegistry extends Map<HookName, HookLedger<HookName>> {\n\tget<K extends HookName>(key: K): HookLedger<K> | undefined;\n\tset<K extends HookName>(key: K, value: HookLedger<K>): this;\n}\n\n/**\n * Hook registry.\n *\n * Create, trigger and handle hooks.\n *\n */\nexport class Hooks {\n\tprotected swup: Swup;\n\tprotected registry: HookRegistry = new Map();\n\n\t// Can we deduplicate this somehow? Or make it error when not in sync with HookDefinitions?\n\t// https://stackoverflow.com/questions/53387838/how-to-ensure-an-arrays-values-the-keys-of-a-typescript-interface/53395649\n\treadonly hooks: HookName[] = [\n\t\t'animation:out:start',\n\t\t'animation:out:end',\n\t\t'animation:in:start',\n\t\t'animation:in:end',\n\t\t'animation:skip',\n\t\t'animation:await',\n\t\t'cache:clear',\n\t\t'cache:set',\n\t\t'content:replace',\n\t\t'content:scroll',\n\t\t'enable',\n\t\t'disable',\n\t\t'fetch:request',\n\t\t'fetch:error',\n\t\t'history:popstate',\n\t\t'link:click',\n\t\t'link:self',\n\t\t'link:anchor',\n\t\t'link:newtab',\n\t\t'page:request',\n\t\t'page:load',\n\t\t'page:view',\n\t\t'visit:start',\n\t\t'visit:end'\n\t];\n\n\tconstructor(swup: Swup) {\n\t\tthis.swup = swup;\n\t\tthis.init();\n\t}\n\n\t/**\n\t * Create ledgers for all core hooks.\n\t */\n\tprotected init() {\n\t\tthis.hooks.forEach((hook) => this.create(hook));\n\t}\n\n\t/**\n\t * Register a new hook.\n\t */\n\tcreate(hook: HookName) {\n\t\tif (!this.registry.has(hook)) {\n\t\t\tthis.registry.set(hook, new Map());\n\t\t}\n\t}\n\n\t/**\n\t * Check if a hook is registered.\n\t */\n\thas(hook: HookName): boolean {\n\t\treturn this.registry.has(hook);\n\t}\n\n\t/**\n\t * Get the ledger with all registrations for a hook.\n\t */\n\tprotected get<T extends HookName>(hook: T): HookLedger<T> | undefined {\n\t\tconst ledger = this.registry.get(hook);\n\t\tif (ledger) {\n\t\t\treturn ledger;\n\t\t}\n\t\tconsole.error(`Unknown hook '${hook}'`);\n\t}\n\n\t/**\n\t * Remove all handlers of all hooks.\n\t */\n\tclear() {\n\t\tthis.registry.forEach((ledger) => ledger.clear());\n\t}\n\n\t/**\n\t * Register a new hook handler.\n\t * @param hook Name of the hook to listen for\n\t * @param handler The handler function to execute\n\t * @param options Object to specify how and when the handler is executed\n\t * Available options:\n\t * - `once`: Only execute the handler once\n\t * - `before`: Execute the handler before the default handler\n\t * - `priority`: Specify the order in which the handlers are executed\n\t * - `replace`: Replace the default handler with this handler\n\t * @returns A function to unregister the handler\n\t */\n\ton<T extends HookName>(hook: T, handler: Handler<T>): HookUnregister;\n\ton<T extends HookName>(hook: T, handler: Handler<T>, options: HookOptions): HookUnregister;\n\ton<T extends HookName>(\n\t\thook: T,\n\t\thandler: Handler<T>,\n\t\toptions: HookOptions = {}\n\t): HookUnregister {\n\t\tconst ledger = this.get(hook);\n\t\tif (!ledger) {\n\t\t\tconsole.warn(`Hook '${hook}' not found.`);\n\t\t\treturn () => {};\n\t\t}\n\n\t\tconst id = ledger.size + 1;\n\t\tconst registration: HookRegistration<T> = { ...options, id, hook, handler };\n\t\tledger.set(handler, registration);\n\n\t\treturn () => this.off(hook, handler);\n\t}\n\n\t/**\n\t * Register a new hook handler to run before the default handler.\n\t * Shortcut for `hooks.on(hook, handler, { before: true })`.\n\t * @param hook Name of the hook to listen for\n\t * @param handler The handler function to execute\n\t * @param options Any other event options (see `hooks.on()` for details)\n\t * @returns A function to unregister the handler\n\t * @see on\n\t */\n\tbefore<T extends HookName>(hook: T, handler: Handler<T>): HookUnregister;\n\tbefore<T extends HookName>(hook: T, handler: Handler<T>, options: HookOptions): HookUnregister;\n\tbefore<T extends HookName>(\n\t\thook: T,\n\t\thandler: Handler<T>,\n\t\toptions: HookOptions = {}\n\t): HookUnregister {\n\t\treturn this.on(hook, handler, { ...options, before: true });\n\t}\n\n\t/**\n\t * Register a new hook handler to replace the default handler.\n\t * Shortcut for `hooks.on(hook, handler, { replace: true })`.\n\t * @param hook Name of the hook to listen for\n\t * @param handler The handler function to execute instead of the default handler\n\t * @param options Any other event options (see `hooks.on()` for details)\n\t * @returns A function to unregister the handler\n\t * @see on\n\t */\n\treplace<T extends HookName>(hook: T, handler: Handler<T>): HookUnregister;\n\treplace<T extends HookName>(hook: T, handler: Handler<T>, options: HookOptions): HookUnregister;\n\treplace<T extends HookName>(\n\t\thook: T,\n\t\thandler: Handler<T>,\n\t\toptions: HookOptions = {}\n\t): HookUnregister {\n\t\treturn this.on(hook, handler, { ...options, replace: true });\n\t}\n\n\t/**\n\t * Register a new hook handler to run once.\n\t * Shortcut for `hooks.on(hook, handler, { once: true })`.\n\t * @param hook Name of the hook to listen for\n\t * @param handler The handler function to execute\n\t * @param options Any other event options (see `hooks.on()` for details)\n\t * @see on\n\t */\n\tonce<T extends HookName>(hook: T, handler: Handler<T>): HookUnregister;\n\tonce<T extends HookName>(hook: T, handler: Handler<T>, options: HookOptions): HookUnregister;\n\tonce<T extends HookName>(\n\t\thook: T,\n\t\thandler: Handler<T>,\n\t\toptions: HookOptions = {}\n\t): HookUnregister {\n\t\treturn this.on(hook, handler, { ...options, once: true });\n\t}\n\n\t/**\n\t * Unregister a hook handler.\n\t * @param hook Name of the hook the handler is registered for\n\t * @param handler The handler function that was registered.\n\t * If omitted, all handlers for the hook will be removed.\n\t */\n\toff<T extends HookName>(hook: T): void;\n\toff<T extends HookName>(hook: T, handler: Handler<T>): void;\n\toff<T extends HookName>(hook: T, handler?: Handler<T>): void {\n\t\tconst ledger = this.get(hook);\n\t\tif (ledger && handler) {\n\t\t\tconst deleted = ledger.delete(handler);\n\t\t\tif (!deleted) {\n\t\t\t\tconsole.warn(`Handler for hook '${hook}' not found.`);\n\t\t\t}\n\t\t} else if (ledger) {\n\t\t\tledger.clear();\n\t\t}\n\t}\n\n\t/**\n\t * Trigger a hook asynchronously, executing its default handler and all registered handlers.\n\t * Will execute all handlers in order and `await` any `Promise`s they return.\n\t * @param hook Name of the hook to trigger\n\t * @param args Arguments to pass to the handler\n\t * @param defaultHandler A default implementation of this hook to execute\n\t * @returns The resolved return value of the executed default handler\n\t */\n\tasync trigger<T extends HookName>(\n\t\thook: T,\n\t\targs?: HookArguments<T>,\n\t\tdefaultHandler?: Handler<T>\n\t): Promise<any> {\n\t\tconst { before, handler, after, replaced } = this.getHandlers(hook, defaultHandler);\n\t\tawait this.execute(before, args);\n\t\tconst [result] = await this.execute(handler, args, replaced ? defaultHandler : undefined);\n\t\tawait this.execute(after, args);\n\t\tthis.dispatchDomEvent(hook, args);\n\t\treturn result;\n\t}\n\n\t/**\n\t * Trigger a hook synchronously, executing its default handler and all registered handlers.\n\t * Will execute all handlers in order, but will **not** `await` any `Promise`s they return.\n\t * @param hook Name of the hook to trigger\n\t * @param args Arguments to pass to the handler\n\t * @param defaultHandler A default implementation of this hook to execute\n\t * @returns The (possibly unresolved) return value of the executed default handler\n\t */\n\ttriggerSync<T extends HookName>(\n\t\thook: T,\n\t\targs?: HookArguments<T>,\n\t\tdefaultHandler?: Handler<T>\n\t): any {\n\t\tconst { before, after, handler, replaced } = this.getHandlers(hook, defaultHandler);\n\t\tthis.executeSync(before, args);\n\t\tconst [result] = this.executeSync(handler, args, replaced ? defaultHandler : undefined);\n\t\tthis.executeSync(after, args);\n\t\tthis.dispatchDomEvent(hook, args);\n\t\treturn result;\n\t}\n\n\t/**\n\t * Execute the handlers for a hook, in order, as `Promise`s that will be `await`ed.\n\t * @param registrations The registrations (handler + options) to execute\n\t * @param args Arguments to pass to the handler\n\t */\n\tasync execute<T extends HookName>(\n\t\tregistrations: HookRegistration<T>[],\n\t\targs?: HookArguments<T>,\n\t\tdefaultHandler?: Handler<T>\n\t): Promise<any> {\n\t\tconst results = [];\n\t\tfor (const { hook, handler, once } of registrations) {\n\t\t\tconst result = await runAsPromise(handler, [this.swup.context, args, defaultHandler]);\n\t\t\tresults.push(result);\n\t\t\tif (once) {\n\t\t\t\tthis.off(hook, handler);\n\t\t\t}\n\t\t}\n\t\treturn results;\n\t}\n\n\t/**\n\t * Execute the handlers for a hook, in order, without `await`ing any returned `Promise`s.\n\t * @param registrations The registrations (handler + options) to execute\n\t * @param args Arguments to pass to the handler\n\t */\n\texecuteSync<T extends HookName>(\n\t\tregistrations: HookRegistration<T>[],\n\t\targs?: HookArguments<T>,\n\t\tdefaultHandler?: Handler<T>\n\t): any[] {\n\t\tconst results = [];\n\t\tfor (const { hook, handler, once } of registrations) {\n\t\t\tconst result = handler(this.swup.context, args as HookArguments<T>, defaultHandler);\n\t\t\tresults.push(result);\n\t\t\tif (isPromise(result)) {\n\t\t\t\tconsole.warn(\n\t\t\t\t\t`Promise returned from handler for synchronous hook '${hook}'.` +\n\t\t\t\t\t\t`Swup will not wait for it to resolve.`\n\t\t\t\t);\n\t\t\t}\n\t\t\tif (once) {\n\t\t\t\tthis.off(hook, handler);\n\t\t\t}\n\t\t}\n\t\treturn results;\n\t}\n\n\t/**\n\t * Get all registered handlers for a hook, sorted by priority and registration order.\n\t * @param hook Name of the hook\n\t * @param defaultHandler The optional default handler of this hook\n\t * @returns An object with the handlers sorted into `before` and `after` arrays,\n\t * as well as a flag indicating if the original handler was replaced\n\t */\n\tgetHandlers<T extends HookName>(hook: T, defaultHandler?: Handler<T>) {\n\t\tconst ledger = this.get(hook);\n\t\tif (!ledger) {\n\t\t\treturn { found: false, before: [], handler: [], after: [], replaced: false };\n\t\t}\n\n\t\tconst sort = this.sortRegistrations;\n\t\tconst registrations = Array.from(ledger.values());\n\n\t\tconst before = registrations.filter(({ before, replace }) => before && !replace).sort(sort);\n\t\tconst replace = registrations.filter(({ replace }) => replace).sort(sort);\n\t\tconst after = registrations.filter(({ before, replace }) => !before && !replace).sort(sort);\n\t\tconst replaced = replace.length > 0;\n\n\t\tlet handler: HookRegistration<T>[] = [];\n\t\tif (replaced) {\n\t\t\thandler = [{ id: 0, hook, handler: replace[0].handler }];\n\t\t} else if (defaultHandler) {\n\t\t\thandler = [{ id: 0, hook, handler: defaultHandler }];\n\t\t}\n\n\t\treturn { found: true, before, handler, after, replaced };\n\t}\n\n\t/**\n\t * Sort two hook registrations by priority and registration order.\n\t * @param a The registration object to compare\n\t * @param b The other registration object to compare with\n\t * @returns The sort direction\n\t */\n\tsortRegistrations<T extends HookName>(a: HookRegistration<T>, b: HookRegistration<T>): number {\n\t\tconst priority = (a.priority ?? 0) - (b.priority ?? 0);\n\t\tconst id = a.id - b.id;\n\t\treturn priority || id || 0;\n\t}\n\n\t/**\n\t * Trigger a custom event on the `document`. Prefixed with `swup:`\n\t * @param hook Name of the hook to trigger.\n\t */\n\tdispatchDomEvent<T extends HookName>(hook: T, args?: HookArguments<T>): void {\n\t\tconst detail = { hook, args, context: this.swup.context };\n\t\tdocument.dispatchEvent(new CustomEvent(`swup:${hook}`, { detail }));\n\t}\n}\n","import { escapeCssIdentifier as escape, query } from '../utils.js';\n\n/**\n * Find the anchor element for a given hash.\n *\n * @param hash Hash with or without leading '#'\n * @returns The element, if found, or null.\n *\n * @see https://html.spec.whatwg.org/#find-a-potential-indicated-element\n */\nexport const getAnchorElement = (hash: string): Element | null => {\n\tif (hash && hash.charAt(0) === '#') {\n\t\thash = hash.substring(1);\n\t}\n\n\tif (!hash) {\n\t\treturn null;\n\t}\n\n\tconst decoded = decodeURIComponent(hash);\n\tlet element =\n\t\tdocument.getElementById(hash) ||\n\t\tdocument.getElementById(decoded) ||\n\t\tquery(`a[name='${escape(hash)}']`) ||\n\t\tquery(`a[name='${escape(decoded)}']`);\n\n\tif (!element && hash === 'top') {\n\t\telement = document.body;\n\t}\n\n\treturn element;\n};\n","import { queryAll, toMs } from '../utils.js';\nimport Swup, { Options } from '../Swup.js';\n\nconst TRANSITION = 'transition';\nconst ANIMATION = 'animation';\n\ntype AnimationTypes = typeof TRANSITION | typeof ANIMATION;\ntype AnimationProperties = 'Delay' | 'Duration';\ntype AnimationStyleKeys = `${AnimationTypes}${AnimationProperties}` | 'transitionProperty';\ntype AnimationStyleDeclarations = Pick<CSSStyleDeclaration, AnimationStyleKeys>;\n\nexport type AnimationDirection = 'in' | 'out';\n\n/**\n * Return a Promise that resolves when all animations are done on the page.\n *\n * @note We don't make use of the `direction` argument, but it's required by JS plugin\n */\nexport async function awaitAnimations(\n\tthis: Swup,\n\t{\n\t\telements,\n\t\tselector\n\t}: {\n\t\tselector: Options['animationSelector'];\n\t\telements?: NodeListOf<HTMLElement> | HTMLElement[];\n\t\tdirection?: AnimationDirection;\n\t}\n): Promise<void> {\n\t// Allow usage of swup without animations\n\tif (selector === false && !elements) {\n\t\treturn;\n\t}\n\n\t// Allow passing in elements\n\tlet animatedElements: HTMLElement[] = [];\n\tif (elements) {\n\t\tanimatedElements = Array.from(elements);\n\t} else if (selector) {\n\t\tanimatedElements = queryAll(selector, document.body);\n\t\t// Warn if no elements match the selector, but keep things going\n\t\tif (!animatedElements.length) {\n\t\t\tconsole.warn(`[swup] No elements found matching animationSelector \\`${selector}\\``);\n\t\t\treturn;\n\t\t}\n\t}\n\n\tconst awaitedAnimations = animatedElements.map((el) => awaitAnimationsOnElement(el));\n\tconst hasAnimations = awaitedAnimations.filter(Boolean).length > 0;\n\tif (!hasAnimations) {\n\t\tif (selector) {\n\t\t\tconsole.warn(\n\t\t\t\t`[swup] No CSS animation duration defined on elements matching \\`${selector}\\``\n\t\t\t);\n\t\t}\n\t\treturn;\n\t}\n\n\tawait Promise.all(awaitedAnimations);\n}\n\nfunction awaitAnimationsOnElement(element: Element): Promise<void> | false {\n\tconst { type, timeout, propCount } = getTransitionInfo(element);\n\n\t// Resolve immediately if no transition defined\n\tif (!type || !timeout) {\n\t\treturn false;\n\t}\n\n\treturn new Promise((resolve) => {\n\t\tconst endEvent = `${type}end`;\n\t\tconst startTime = performance.now();\n\t\tlet propsTransitioned = 0;\n\n\t\tconst end = () => {\n\t\t\telement.removeEventListener(endEvent, onEnd);\n\t\t\tresolve();\n\t\t};\n\n\t\tconst onEnd: EventListener = (event) => {\n\t\t\t// Skip transitions on child elements\n\t\t\tif (event.target !== element) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (!isTransitionOrAnimationEvent(event)) {\n\t\t\t\tthrow new Error('Not a transition or animation event.');\n\t\t\t}\n\n\t\t\t// Skip transitions that happened before we started listening\n\t\t\tconst elapsedTime = (performance.now() - startTime) / 1000;\n\t\t\tif (elapsedTime < event.elapsedTime) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// End if all properties have transitioned\n\t\t\tif (++propsTransitioned >= propCount) {\n\t\t\t\tend();\n\t\t\t}\n\t\t};\n\n\t\tsetTimeout(() => {\n\t\t\tif (propsTransitioned < propCount) {\n\t\t\t\tend();\n\t\t\t}\n\t\t}, timeout + 1);\n\n\t\telement.addEventListener(endEvent, onEnd);\n\t});\n}\n\nexport function getTransitionInfo(element: Element, expectedType?: AnimationTypes) {\n\tconst styles = window.getComputedStyle(element) as AnimationStyleDeclarations;\n\n\tconst transitionDelays = getStyleProperties(styles, `${TRANSITION}Delay`);\n\tconst transitionDurations = getStyleProperties(styles, `${TRANSITION}Duration`);\n\tconst transitionTimeout = calculateTimeout(transitionDelays, transitionDurations);\n\tconst animationDelays = getStyleProperties(styles, `${ANIMATION}Delay`);\n\tconst animationDurations = getStyleProperties(styles, `${ANIMATION}Duration`);\n\tconst animationTimeout = calculateTimeout(animationDelays, animationDurations);\n\n\tlet type: AnimationTypes | null = null;\n\tlet timeout = 0;\n\tlet propCount = 0;\n\n\tif (expectedType === TRANSITION) {\n\t\tif (transitionTimeout > 0) {\n\t\t\ttype = TRANSITION;\n\t\t\ttimeout = transitionTimeout;\n\t\t\tpropCount = transitionDurations.length;\n\t\t}\n\t} else if (expectedType === ANIMATION) {\n\t\tif (animationTimeout > 0) {\n\t\t\ttype = ANIMATION;\n\t\t\ttimeout = animationTimeout;\n\t\t\tpropCount = animationDurations.length;\n\t\t}\n\t} else {\n\t\ttimeout = Math.max(transitionTimeout, animationTimeout);\n\t\ttype = timeout > 0 ? (transitionTimeout > animationTimeout ? TRANSITION : ANIMATION) : null;\n\t\tpropCount = type\n\t\t\t? type === TRANSITION\n\t\t\t\t? transitionDurations.length\n\t\t\t\t: animationDurations.length\n\t\t\t: 0;\n\t}\n\n\treturn {\n\t\ttype,\n\t\ttimeout,\n\t\tpropCount\n\t};\n}\n\nfunction isTransitionOrAnimationEvent(event: any): event is TransitionEvent | AnimationEvent {\n\treturn [`${TRANSITION}end`, `${ANIMATION}end`].includes(event.type);\n}\n\nfunction getStyleProperties(styles: AnimationStyleDeclarations, key: AnimationStyleKeys): string[] {\n\treturn (styles[key] || '').split(', ');\n}\n\nfunction calculateTimeout(delays: string[], durations: string[]): number {\n\twhile (delays.length < durations.length) {\n\t\tdelays = delays.concat(delays);\n\t}\n\n\treturn Math.max(...durations.map((duration, i) => toMs(duration) + toMs(delays[i])));\n}\n","import Swup from '../Swup.js';\nimport { createHistoryRecord, updateHistoryRecord, getCurrentUrl, Location } from '../helpers.js';\nimport { FetchOptions } from './fetchPage.js';\nimport { ContextInitOptions } from './Context.js';\n\nexport type HistoryAction = 'push' | 'replace';\nexport type HistoryDirection = 'forwards' | 'backwards';\n\ntype VisitOptions = {\n\t/** Whether this visit is animated. Default: `true` */\n\tanimate?: boolean;\n\t/** Name of a custom animation to run. */\n\tanimation?: string;\n\t/** History action to perform: `push` for creating a new history entry, `replace` for replacing the current entry. Default: `push` */\n\thistory?: HistoryAction;\n};\n\n/**\n * Navigate to a new URL.\n * @param url The URL to navigate to.\n * @param options Options for how to perform this visit.\n * @returns Promise<void>\n */\nexport function visit(\n\tthis: Swup,\n\turl: string,\n\toptions: VisitOptions & FetchOptions = {},\n\tcontext: Omit<ContextInitOptions, 'to'> = {}\n) {\n\t// Check if the visit should be ignored\n\tif (this.shouldIgnoreVisit(url)) {\n\t\twindow.location.href = url;\n\t\treturn;\n\t}\n\n\tconst { url: to, hash } = Location.fromUrl(url);\n\tthis.context = this.createContext({ ...context, to, hash });\n\tthis.performVisit(to, options);\n}\n\n/**\n * Start a visit to a new URL.\n *\n * Internal method that assumes the global context has already been set up.\n *\n * As a user, you should call `swup.visit(url)` instead.\n *\n * @param url The URL to navigate to.\n * @param options Options for how to perform this visit.\n * @returns Promise<void>\n */\nexport async function performVisit(\n\tthis: Swup,\n\turl: string,\n\toptions: VisitOptions & FetchOptions = {}\n) {\n\tif (typeof url !== 'string') {\n\t\tthrow new Error(`swup.visit() requires a URL parameter`);\n\t}\n\n\tthis.context.to.url = Location.fromUrl(url).url;\n\tconst { animation, animate, history: historyAction } = options;\n\toptions.referrer = options.referrer || this.currentPageUrl;\n\n\tif (animate === false) {\n\t\tthis.context.animation.animate = false;\n\t}\n\tif (historyAction) {\n\t\tthis.context.history.action = historyAction;\n\t}\n\n\t// Clean up old animation classes and set custom animation name\n\tif (!this.context.animation.animate) {\n\t\tthis.classes.clear();\n\t} else if (animation) {\n\t\tthis.context.animation.name = animation;\n\t}\n\n\ttry {\n\t\tawait this.hooks.trigger('visit:start');\n\n\t\t// Begin fetching page\n\t\tconst pagePromise = this.hooks.trigger(\n\t\t\t'page:request',\n\t\t\t{ url: this.context.to.url, options },\n\t\t\tasync (context, { options }) => await this.fetchPage(context.to.url as string, options)\n\t\t);\n\n\t\t// Create history record if this is not a popstate call (with or without anchor)\n\t\tif (!this.context.history.popstate) {\n\t\t\tconst newUrl = url + (this.context.scroll.target || '');\n\t\t\tif (this.context.history.action === 'replace') {\n\t\t\t\tupdateHistoryRecord(newUrl);\n\t\t\t} else {\n\t\t\t\tconst index = this.currentHistoryIndex + 1;\n\t\t\t\tcreateHistoryRecord(newUrl, { index });\n\t\t\t}\n\t\t}\n\n\t\tthis.currentPageUrl = getCurrentUrl();\n\n\t\t// Wait for page before starting to animate out?\n\t\tif (this.context.animation.wait) {\n\t\t\tconst { html } = await pagePromise;\n\t\t\tthis.context.to.html = html;\n\t\t}\n\n\t\t// Wait for page to load and leave animation to finish\n\t\tconst animationPromise = this.leavePage();\n\t\tconst [page] = await Promise.all([pagePromise, animationPromise]);\n\n\t\t// Render page: replace content and scroll to top/fragment\n\t\tawait this.renderPage(this.context.to.url, page);\n\n\t\t// Wait for enter animation\n\t\tawait this.enterPage();\n\n\t\t// Finalize visit\n\t\tawait this.hooks.trigger('visit:end', undefined, () => this.classes.clear());\n\n\t\t// Reset context after visit?\n\t\t// if (this.context.to && this.isSameResolvedUrl(this.context.to.url, requestedUrl)) {\n\t\t// \tthis.createContext({ to: undefined });\n\t\t// }\n\t} catch (error: unknown) {\n\t\t// Return early if error is undefined (probably aborted preload request)\n\t\tif (!error) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Log to console as we swallow almost all hook errors\n\t\tconsole.error(error);\n\n\t\t// Rewrite `skipPopStateHandling` to redirect manually when `history.go` is processed\n\t\tthis.options.skipPopStateHandling = () => {\n\t\t\twindow.location.href = this.context.to.url as string;\n\t\t\treturn true;\n\t\t};\n\n\t\t// Go back to the actual page we're still at\n\t\thistory.go(-1);\n\t}\n}\n","import Swup from '../Swup.js';\nimport { Location } from '../helpers.js';\n\nexport interface PageData {\n\turl: string;\n\thtml: string;\n}\n\nexport interface FetchOptions extends RequestInit {\n\tmethod?: 'GET' | 'POST';\n\tbody?: string | FormData | URLSearchParams;\n\theaders?: Record<string, string>;\n}\n\nexport class FetchError extends Error {\n\turl: string;\n\tstatus: number;\n\tconstructor(message: string, details: { url: string; status: number }) {\n\t\tsuper(message);\n\t\tthis.name = 'FetchError';\n\t\tthis.url = details.url;\n\t\tthis.status = details.status;\n\t}\n}\n\n/**\n * Fetch a page from the server, return it and cache it.\n */\nexport async function fetchPage(\n\tthis: Swup,\n\turl: URL | string,\n\toptions: FetchOptions & { triggerHooks?: boolean } = {}\n): Promise<PageData> {\n\turl = Location.fromUrl(url).url;\n\n\tif (this.cache.has(url)) {\n\t\tconst page = this.cache.get(url) as PageData;\n\t\tif (options.triggerHooks !== false) {\n\t\t\tawait this.hooks.trigger('page:load', { page, cache: true });\n\t\t}\n\t\treturn page;\n\t}\n\n\tconst headers = { ...this.options.requestHeaders, ...options.headers };\n\toptions = { ...options, headers };\n\n\t// Allow hooking before this and returning a custom response-like object (e.g. custom fetch implementation)\n\tconst response: Response = await this.hooks.trigger(\n\t\t'fetch:request',\n\t\t{ url, options },\n\t\t(context, { url, options }) => fetch(url, options)\n\t);\n\n\tconst { status, url: responseUrl } = response;\n\tconst html = await response.text();\n\n\tif (status === 500) {\n\t\tthis.hooks.trigger('fetch:error', { status, response, url: responseUrl });\n\t\tthrow new FetchError(`Server error: ${responseUrl}`, { status, url: responseUrl });\n\t}\n\n\tif (!html) {\n\t\tthrow new FetchError(`Empty response: ${responseUrl}`, { status, url: responseUrl });\n\t}\n\n\t// Resolve real url after potential redirect\n\tconst { url: finalUrl } = Location.fromUrl(responseUrl);\n\tconst page = { url: finalUrl, html };\n\n\t// Only save cache entry for non-redirects\n\tif (url === finalUrl) {\n\t\tthis.cache.set(page.url, page);\n\t}\n\n\tif (options.triggerHooks !== false) {\n\t\tawait this.hooks.trigger('page:load', { page, cache: false });\n\t}\n\n\treturn page;\n}\n","import Swup from '../Swup.js';\nimport { classify } from '../helpers.js';\n\n/**\n * Perform the out/leave animation of the current page.\n * @returns Promise<void>\n */\nexport const leavePage = async function (this: Swup) {\n\tif (!this.context.animation.animate) {\n\t\tawait this.hooks.trigger('animation:skip');\n\t\treturn;\n\t}\n\n\tawait this.hooks.trigger('animation:out:start', undefined, () => {\n\t\tthis.classes.add('is-changing', 'is-leaving', 'is-animating');\n\t\tif (this.context.history.popstate) {\n\t\t\tthis.classes.add('is-popstate');\n\t\t}\n\t\tif (this.context.animation.name) {\n\t\t\tthis.classes.add(`to-${classify(this.context.animation.name)}`);\n\t\t}\n\t});\n\n\tawait this.hooks.trigger(\n\t\t'animation:await',\n\t\t{ direction: 'out' },\n\t\tasync (context, { direction }) => {\n\t\t\tawait this.awaitAnimations({ selector: context.animation.selector, direction });\n\t\t}\n\t);\n\n\tawait this.hooks.trigger('animation:out:end');\n};\n","import Swup, { Options } from '../Swup.js';\nimport { PageData } from './fetchPage.js';\n\n/**\n * Perform the replacement of content after loading a page.\n *\n * It takes an object with the page data as returned from `fetchPage` and a list\n * of container selectors to replace.\n *\n * @returns Whether all containers were replaced.\n */\nexport const replaceContent = function (\n\tthis: Swup,\n\t{ html }: PageData,\n\t{ containers }: { containers: Options['containers'] } = this.options\n): boolean {\n\tconst incomingDocument = new DOMParser().parseFromString(html, 'text/html');\n\n\t// Update browser title\n\tconst title = incomingDocument.querySelector('title')?.innerText || '';\n\tdocument.title = title;\n\n\t// Update content containers\n\tconst replaced = containers\n\t\t.map((selector) => {\n\t\t\tconst currentEl = document.querySelector(selector);\n\t\t\tconst incomingEl = incomingDocument.querySelector(selector);\n\t\t\tif (currentEl && incomingEl) {\n\t\t\t\tcurrentEl.replaceWith(incomingEl);\n\t\t\t\treturn true;\n\t\t\t}\n\t\t\tif (!currentEl) {\n\t\t\t\tconsole.warn(`[swup] Container missing in current document: ${selector}`);\n\t\t\t}\n\t\t\tif (!incomingEl) {\n\t\t\t\tconsole.warn(`[swup] Container missing in incoming document: ${selector}`);\n\t\t\t}\n\t\t\treturn false;\n\t\t})\n\t\t.filter(Boolean);\n\n\treturn replaced.length === containers.length;\n};\n","import Swup from '../Swup.js';\nimport { nextTick } from '../utils.js';\n\n/**\n * Perform the in/enter animation of the next page.\n * @returns Promise<void>\n */\nexport const enterPage = async function (this: Swup) {\n\tif (!this.context.animation.animate) {\n\t\treturn;\n\t}\n\n\tconst animation = this.hooks.trigger(\n\t\t'animation:await',\n\t\t{ direction: 'in' },\n\t\tasync (context, { direction }) => {\n\t\t\tawait this.awaitAnimations({ selector: context.animation.selector, direction });\n\t\t}\n\t);\n\n\tawait nextTick();\n\n\tawait this.hooks.trigger('animation:in:start', undefined, () => {\n\t\tthis.classes.remove('is-animating');\n\t});\n\n\tawait animation;\n\n\tawait this.hooks.trigger('animation:in:end');\n};\n","import { updateHistoryRecord, getCurrentUrl, classify } from '../helpers.js';\nimport Swup from '../Swup.js';\nimport { PageData } from './fetchPage.js';\n\n/**\n * Render the next page: replace the content and update scroll position.\n * @returns Promise<void>\n */\nexport const renderPage = async function (this: Swup, requestedUrl: string, page: PageData) {\n\tconst { url, html } = page;\n\n\tthis.classes.remove('is-leaving');\n\n\t// do nothing if another page was requested in the meantime\n\tif (!this.isSameResolvedUrl(getCurrentUrl(), requestedUrl)) {\n\t\treturn;\n\t}\n\n\t// update state if the url was redirected\n\tif (!this.isSameResolvedUrl(getCurrentUrl(), url)) {\n\t\tupdateHistoryRecord(url);\n\t\tthis.currentPageUrl = getCurrentUrl();\n\t\tthis.context.to.url = this.currentPageUrl;\n\t}\n\n\t// only add for animated page loads\n\tif (this.context.animation.animate) {\n\t\tthis.classes.add('is-rendering');\n\t}\n\n\t// save html into context for easier retrieval\n\tthis.context.to.html = html;\n\n\t// replace content: allow handlers and plugins to overwrite paga data and containers\n\tawait this.hooks.trigger('content:replace', { page }, (context, { page }) => {\n\t\tconst success = this.replaceContent(page, { containers: context.containers });\n\t\tif (!success) {\n\t\t\tthrow new Error('[swup] Container mismatch, aborting');\n\t\t}\n\t\tif (this.context.animation.animate) {\n\t\t\t// Make sure to add these classes to new containers as well\n\t\t\tthis.classes.add('is-animating', 'is-changing', 'is-rendering');\n\t\t\tif (this.context.animation.name) {\n\t\t\t\tthis.classes.add(`to-${classify(this.context.animation.name)}`);\n\t\t\t}\n\t\t}\n\t});\n\n\tawait this.hooks.trigger(\n\t\t'content:scroll',\n\t\t{ options: { behavior: 'auto' } },\n\t\t(context, { options }) => {\n\t\t\tif (this.context.scroll.target) {\n\t\t\t\tconst target = this.getAnchorElement(this.context.scroll.target);\n\t\t\t\tif (target) {\n\t\t\t\t\ttarget.scrollIntoView(options);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (this.context.scroll.reset) {\n\t\t\t\twindow.scrollTo(0, 0);\n\t\t\t}\n\t\t}\n\t);\n\n\tawait this.hooks.trigger('page:view', { url: this.currentPageUrl, title: document.title });\n\n\t// empty cache if it's disabled (in case preload plugin filled it)\n\tif (!this.options.cache) {\n\t\tthis.cache.clear();\n\t}\n};\n","import Swup from '../Swup.js';\n\nexport type Plugin = {\n\t/** Identify as a swup plugin */\n\tisSwupPlugin: true;\n\t/** Name of this plugin */\n\tname: string;\n\t/** Version of this plugin. Currently not in use, defined here for backward compatiblity. */\n\tversion?: string;\n\t/** The swup instance that mounted this plugin */\n\tswup?: Swup;\n\t/** Version requirements of this plugin. Example: `{ swup: '>=4' }` */\n\trequires?: Record<string, string | string[]>;\n\t/** Run on mount */\n\tmount: () => void;\n\t/** Run on unmount */\n\tunmount: () => void;\n\t_beforeMount?: () => void;\n\t_afterUnmount?: () => void;\n\t_checkRequirements?: () => boolean;\n};\n\nconst isSwupPlugin = (maybeInvalidPlugin: unknown): maybeInvalidPlugin is Plugin => {\n\t// @ts-ignore\n\treturn maybeInvalidPlugin?.isSwupPlugin;\n};\n\nexport const use = function (this: Swup, plugin: unknown) {\n\tif (!isSwupPlugin(plugin)) {\n\t\tconsole.error('Not a swup plugin instance', plugin);\n\t\treturn;\n\t}\n\n\tplugin.swup = this;\n\tif (plugin._checkRequirements) {\n\t\tif (!plugin._checkRequirements()) {\n\t\t\treturn;\n\t\t}\n\t}\n\tif (plugin._beforeMount) {\n\t\tplugin._beforeMount();\n\t}\n\tplugin.mount();\n\n\tthis.plugins.push(plugin);\n\n\treturn this.plugins;\n};\n\nexport function unuse(this: Swup, pluginOrName: Plugin | string) {\n\tconst plugin = this.findPlugin(pluginOrName);\n\tif (!plugin) {\n\t\tconsole.error('No such plugin', plugin);\n\t\treturn;\n\t}\n\n\tplugin.unmount();\n\tif (plugin._afterUnmount) {\n\t\tplugin._afterUnmount();\n\t}\n\n\tthis.plugins = this.plugins.filter((p) => p !== plugin);\n\n\treturn this.plugins;\n}\n\nexport function findPlugin(this: Swup, pluginOrName: Plugin | string) {\n\treturn this.plugins.find((plugin) => plugin === pluginOrName || plugin.name === pluginOrName);\n}\n","import { DelegateEvent } from 'delegate-it';\n\nimport version from './config/version.js';\n\nimport { delegateEvent, getCurrentUrl, Location, updateHistoryRecord } from './helpers.js';\nimport { DelegateEventUnsubscribe } from './helpers/delegateEvent.js';\n\nimport { Cache } from './modules/Cache.js';\nimport { Classes } from './modules/Classes.js';\nimport { Context, createContext } from './modules/Context.js';\nimport { Hooks } from './modules/Hooks.js';\nimport { getAnchorElement } from './modules/getAnchorElement.js';\nimport { awaitAnimations } from './modules/awaitAnimations.js';\nimport { visit, performVisit, HistoryAction } from './modules/visit.js';\nimport { fetchPage } from './modules/fetchPage.js';\nimport { leavePage } from './modules/leavePage.js';\nimport { replaceContent } from './modules/replaceContent.js';\nimport { enterPage } from './modules/enterPage.js';\nimport { renderPage } from './modules/renderPage.js';\nimport { use, unuse, findPlugin, Plugin } from './modules/plugins.js';\nimport { nextTick } from './utils.js';\n\nexport type Options = {\n\t/** Whether history visits are animated. Default: `false` */\n\tanimateHistoryBrowsing: boolean;\n\t/** Selector for detecting animation timing. Default: `[class*=\"transition-\"]` */\n\tanimationSelector: string | false;\n\t/** Elements on which to add animation classes. Default: `html` element */\n\tanimationScope: 'html' | 'containers';\n\t/** Enable in-memory page cache. Default: `true` */\n\tcache: boolean;\n\t/** Content containers to be replaced on page visits. Default: `['#swup']` */\n\tcontainers: string[];\n\t/** Callback for ignoring visits. Receives the element and event that triggered the visit. */\n\tignoreVisit: (url: string, { el, event }: { el?: Element; event?: Event }) => boolean;\n\t/** Selector for links that trigger visits. Default: `'a[href]'` */\n\tlinkSelector: string;\n\t/** Plugins to register on startup. */\n\tplugins: Plugin[];\n\t/** Custom headers sent along with fetch requests. */\n\trequestHeaders: Record<string, string>;\n\t/** Rewrite URLs before loading them. */\n\tresolveUrl: (url: string) => string;\n\t/** Callback for telling swup to ignore certain popstate events. */\n\tskipPopStateHandling: (event: any) => boolean;\n};\n\nexport default class Swup {\n\t/** Library version */\n\tversion: string = version;\n\t/** Options passed into the instance */\n\toptions: Options;\n\t/** Registered plugin instances */\n\tplugins: Plugin[] = [];\n\t/** Global context of the current visit */\n\tcontext: Context;\n\t/** Cache instance */\n\tcache: Cache;\n\t/** Hook registry */\n\thooks: Hooks;\n\t/** Animation class manager */\n\tclasses: Classes;\n\t/** URL of the currently visible page */\n\tcurrentPageUrl = getCurrentUrl();\n\t/** Index of the current history entry */\n\tcurrentHistoryIndex = 1;\n\t/** Delegated event subscription handle */\n\tprivate clickDelegate?: DelegateEventUnsubscribe;\n\n\tvisit = visit;\n\tperformVisit = performVisit;\n\tleavePage = leavePage;\n\trenderPage = renderPage;\n\treplaceContent = replaceContent;\n\tenterPage = enterPage;\n\tdelegateEvent = delegateEvent;\n\tfetchPage = fetchPage;\n\tawaitAnimations = awaitAnimations;\n\tgetAnchorElement = getAnchorElement;\n\tuse = use;\n\tunuse = unuse;\n\tfindPlugin = findPlugin;\n\tgetCurrentUrl = getCurrentUrl;\n\tcreateContext = createContext;\n\tlog: (message: string, context?: any) => void = () => {}; // here so it can be used by plugins\n\n\t/** Default options before merging user options */\n\tdefaults: Options = {\n\t\tanimateHistoryBrowsing: false,\n\t\tanimationSelector: '[class*=\"transition-\"]',\n\t\tanimationScope: 'html',\n\t\tcache: true,\n\t\tcontainers: ['#swup'],\n\t\tignoreVisit: (url, { el, event } = {}) => !!el?.closest('[data-no-swup]'),\n\t\tlinkSelector: 'a[href]',\n\t\tplugins: [],\n\t\tresolveUrl: (url) => url,\n\t\trequestHeaders: {\n\t\t\t'X-Requested-With': 'swup',\n\t\t\t'Accept': 'text/html, application/xhtml+xml'\n\t\t},\n\t\tskipPopStateHandling: (event) => event.state?.source !== 'swup'\n\t};\n\n\tconstructor(options: Partial<Options> = {}) {\n\t\t// Merge defaults and options\n\t\tthis.options = { ...this.defaults, ...options };\n\n\t\tthis.linkClickHandler = this.linkClickHandler.bind(this);\n\t\tthis.popStateHandler = this.popStateHandler.bind(this);\n\n\t\tthis.cache = new Cache(this);\n\t\tthis.classes = new Classes(this);\n\t\tthis.hooks = new Hooks(this);\n\t\tthis.context = this.createContext({ to: undefined });\n\n\t\tif (!this.checkRequirements()) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis.enable();\n\t}\n\n\tcheckRequirements() {\n\t\tif (typeof Promise === 'undefined') {\n\t\t\tconsole.warn('Promise is not supported');\n\t\t\treturn false;\n\t\t}\n\t\treturn true;\n\t}\n\n\tasync enable() {\n\t\t// Add event listener\n\t\tconst { linkSelector } = this.options;\n\t\tthis.clickDelegate = this.delegateEvent(linkSelector, 'click', this.linkClickHandler);\n\n\t\twindow.addEventListener('popstate', this.popStateHandler);\n\n\t\t// Initial save to cache\n\t\tif (this.options.cache) {\n\t\t\t// Disabled to avoid caching modified dom state: logic moved to preload plugin\n\t\t\t// https://github.com/swup/swup/issues/475\n\t\t}\n\n\t\t// Mount plugins\n\t\tthis.options.plugins.forEach((plugin) => this.use(plugin));\n\n\t\t// Modify initial history record\n\t\tupdateHistoryRecord(null, { index: 1 });\n\n\t\t// Trigger enable hook\n\t\tawait this.hooks.trigger('enable', undefined, () => {\n\t\t\t// Add swup-enabled class to html tag\n\t\t\tdocument.documentElement.classList.add('swup-enabled');\n\t\t});\n\n\t\tawait nextTick();\n\n\t\t// Trigger page view hook\n\t\tawait this.hooks.trigger('page:view', { url: this.currentPageUrl, title: document.title });\n\t}\n\n\tasync destroy() {\n\t\t// remove delegated listener\n\t\tthis.clickDelegate!.destroy();\n\n\t\t// remove popstate listener\n\t\twindow.removeEventListener('popstate', this.popStateHandler);\n\n\t\t// empty cache\n\t\tthis.cache.clear();\n\n\t\t// unmount plugins\n\t\tthis.options.plugins.forEach((plugin) => this.unuse(plugin));\n\n\t\t// trigger disable hook\n\t\tawait this.hooks.trigger('disable', undefined, () => {\n\t\t\t// remove swup-enabled class from html tag\n\t\t\tdocument.documentElement.classList.remove('swup-enabled');\n\t\t});\n\n\t\t// remove handlers\n\t\tthis.hooks.clear();\n\t}\n\n\tshouldIgnoreVisit(href: string, { el, event }: { el?: Element; event?: Event } = {}) {\n\t\tconst { origin, url, hash } = Location.fromUrl(href);\n\n\t\t// Ignore if the new origin doesn't match the current one\n\t\tif (origin !== window.location.origin) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// Ignore if the link/form would open a new window (or none at all)\n\t\tif (el && this.triggerWillOpenNewWindow(el)) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// Ignore if the visit should be ignored as per user options\n\t\tif (this.options.ignoreVisit(url + hash, { el, event })) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// Finally, allow the visit\n\t\treturn false;\n\t}\n\n\tlinkClickHandler(event: DelegateEvent<MouseEvent>) {\n\t\tconst el = event.delegateTarget as HTMLAnchorElement;\n\t\tconst { href, url, hash } = Location.fromElement(el);\n\n\t\t// Get the animation name, if specified\n\t\tconst animation = el.getAttribute('data-swup-animation') || undefined;\n\n\t\t// Get the history action, if specified\n\t\tlet historyAction: HistoryAction | undefined;\n\t\tconst historyAttr = el.getAttribute('data-swup-history');\n\t\tif (historyAttr && ['push', 'replace'].includes(historyAttr)) {\n\t\t\thistoryAction = historyAttr as HistoryAction;\n\t\t}\n\n\t\t// Exit early if the link should be ignored\n\t\tif (this.shouldIgnoreVisit(href, { el, event })) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis.context = this.createContext({\n\t\t\tto: url,\n\t\t\thash,\n\t\t\tanimation,\n\t\t\tel,\n\t\t\tevent,\n\t\t\taction: historyAction\n\t\t});\n\n\t\t// Exit early if control key pressed\n\t\tif (event.metaKey || event.ctrlKey || event.shiftKey || event.altKey) {\n\t\t\tthis.hooks.trigger('link:newtab', { href });\n\t\t\treturn;\n\t\t}\n\n\t\t// Exit early if other than left mouse button\n\t\tif (event.button !== 0) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis.hooks.triggerSync('link:click', { el, event }, () => {\n\t\t\tconst from = this.context.from.url ?? '';\n\n\t\t\tevent.preventDefault();\n\n\t\t\t// Handle links to the same page: with or without hash\n\t\t\tif (!url || url === from) {\n\t\t\t\tif (hash) {\n\t\t\t\t\tupdateHistoryRecord(url + hash);\n\t\t\t\t\tthis.hooks.triggerSync(\n\t\t\t\t\t\t'link:anchor',\n\t\t\t\t\t\t{ hash, options: { behavior: 'auto' } },\n\t\t\t\t\t\t(context, { hash, options }) => {\n\t\t\t\t\t\t\tconst target = this.getAnchorElement(hash);\n\t\t\t\t\t\t\tif (target) {\n\t\t\t\t\t\t\t\ttarget.scrollIntoView(options);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\tthis.hooks.triggerSync('link:self', undefined, (context) => {\n\t\t\t\t\t\tif (!context.scroll.reset) return;\n\t\t\t\t\t\twindow.scroll({ top: 0, left: 0, behavior: 'auto' });\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Exit early if the resolved path hasn't changed\n\t\t\tif (this.isSameResolvedUrl(url, from)) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Finally, proceed with loading the page\n\t\t\tthis.performVisit(url);\n\t\t});\n\t}\n\n\ttriggerWillOpenNewWindow(triggerEl: Element) {\n\t\tif (triggerEl.matches('[download], [target=\"_blank\"]')) {\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n\n\tpopStateHandler(event: PopStateEvent) {\n\t\tconst href = event.state?.url ?? location.href;\n\n\t\t// Exit early if this event should be ignored\n\t\tif (this.options.skipPopStateHandling(event)) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Exit early if the resolved path hasn't changed\n\t\tif (this.isSameResolvedUrl(getCurrentUrl(), this.currentPageUrl)) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Exit early if the link should be ignored\n\t\tif (this.shouldIgnoreVisit(href, { event })) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst { url, hash } = Location.fromUrl(href);\n\t\tconst animate = this.options.animateHistoryBrowsing;\n\t\tconst resetScroll = this.options.animateHistoryBrowsing;\n\n\t\tthis.context = this.createContext({\n\t\t\tto: url,\n\t\t\thash,\n\t\t\tevent,\n\t\t\tanimate,\n\t\t\tresetScroll\n\t\t});\n\n\t\t// Mark as popstate visit\n\t\tthis.context.history.popstate = true;\n\n\t\t// Determine direction of history visit\n\t\tconst index = Number(event.state?.index);\n\t\tif (index) {\n\t\t\tconst direction = index - this.currentHistoryIndex > 0 ? 'forwards' : 'backwards';\n\t\t\tthis.context.history.direction = direction;\n\t\t}\n\n\t\t// Does this even do anything?\n\t\t// if (!hash) {\n\t\t// \tevent.preventDefault();\n\t\t// }\n\n\t\tthis.hooks.triggerSync('history:popstate', { event }, () => {\n\t\t\tthis.performVisit(url);\n\t\t});\n\t}\n\n\t/**\n\t * Utility function to validate and run the global option 'resolveUrl'\n\t * @param {string} url\n\t * @returns {string} the resolved url\n\t */\n\tresolveUrl(url: string) {\n\t\tif (typeof this.options.resolveUrl !== 'function') {\n\t\t\tconsole.warn(`[swup] options.resolveUrl expects a callback function.`);\n\t\t\treturn url;\n\t\t}\n\t\tconst result = this.options.resolveUrl(url);\n\t\tif (!result || typeof result !== 'string') {\n\t\t\tconsole.warn(`[swup] options.resolveUrl needs to return a url`);\n\t\t\treturn url;\n\t\t}\n\t\tif (result.startsWith('//') || result.startsWith('http')) {\n\t\t\tconsole.warn(`[swup] options.resolveUrl needs to return a relative url`);\n\t\t\treturn url;\n\t\t}\n\t\treturn result;\n\t}\n\n\t/**\n\t * Compares the resolved version of two paths and returns true if they are the same\n\t * @param {string} url1\n\t * @param {string} url2\n\t * @returns {boolean}\n\t */\n\tisSameResolvedUrl(url1: string, url2: string) {\n\t\treturn this.resolveUrl(url1) === this.resolveUrl(url2);\n\t}\n}\n","import { match } from 'path-to-regexp';\n\nimport type {\n\tPath,\n\tParseOptions,\n\tTokensToRegexpOptions,\n\tRegexpToFunctionOptions,\n\tMatchFunction\n} from 'path-to-regexp';\n\nexport { Path };\n\nexport const matchPath = <P extends object = object>(\n\tpath: Path,\n\toptions?: ParseOptions & TokensToRegexpOptions & RegexpToFunctionOptions\n): MatchFunction<P> => {\n\ttry {\n\t\treturn match<P>(path, options);\n\t} catch (error) {\n\t\tthrow new Error(`[swup] Error parsing path \"${path}\":\\n${error}`);\n\t}\n};\n"],"names":["classify","text","fallback","String","toLowerCase","replace","getCurrentUrl","_temp","hash","location","pathname","search","createHistoryRecord","url","customData","data","random","Math","source","history","pushState","updateHistoryRecord","state","replaceState","delegateEvent","selector","type","callback","options","controller","AbortController","signal","delegate","destroy","abort","Location","URL","constructor","base","document","baseURI","super","toString","this","static","el","href","getAttribute","Cache","swup","pages","Map","size","all","has","resolve","get","set","page","hooks","triggerSync","update","delete","clear","prune","predicate","forEach","urlToResolve","fromUrl","resolveUrl","query","context","querySelector","queryAll","Array","from","querySelectorAll","nextTick","Promise","requestAnimationFrame","isPromise","obj","then","runAsPromise","func","args","ctx","reject","result","apply","escapeCssIdentifier","ident","window","CSS","escape","toMs","s","Number","slice","Classes","swupClasses","selectors","scope","animation","containers","isArray","join","targets","trim","add","target","classList","call","arguments","remove","className","split","filter","c","isSwupClass","some","startsWith","createContext","_ref","to","currentPageUrl","animate","name","event","action","resetScroll","reset","wait","animationScope","animationSelector","trigger","popstate","direction","undefined","scroll","_iteratorSymbol","Symbol","iterator","_settle","pact","value","_Pact","o","bind","v","observer","onFulfilled","onRejected","e","_this","_isSettledPact","thenable","Hooks","registry","init","hook","create","ledger","console","error","on","handler","warn","id","registration","off","before","once","defaultHandler","after","replaced","getHandlers","execute","dispatchDomEvent","executeSync","registrations","_this2","results","body","check","step","_cycle","next","done","return","_fixup","TypeError","i","length","push","array","_forTo","values","_forOf","_ref2","found","sort","sortRegistrations","_ref3","_ref4","_ref5","a","b","priority","dispatchEvent","CustomEvent","detail","getAnchorElement","charAt","substring","decoded","decodeURIComponent","element","getElementById","awaitAnimations","elements","animatedElements","awaitedAnimations","map","timeout","propCount","expectedType","styles","getComputedStyle","transitionDelays","getStyleProperties","TRANSITION","transitionDurations","transitionTimeout","calculateTimeout","animationDelays","ANIMATION","animationDurations","animationTimeout","max","getTransitionInfo","endEvent","startTime","performance","now","propsTransitioned","end","removeEventListener","onEnd","includes","isTransitionOrAnimationEvent","Error","elapsedTime","setTimeout","addEventListener","awaitAnimationsOnElement","Boolean","key","delays","durations","concat","duration","performVisit","historyAction","referrer","classes","_temp2","animationPromise","leavePage","pagePromise","renderPage","enterPage","fetchPage","newUrl","index","currentHistoryIndex","html","_catch","skipPopStateHandling","go","visit","shouldIgnoreVisit","_exit","_temp5","_result","headers","requestHeaders","fetch","response","status","responseUrl","FetchError","finalUrl","cache","_temp3","triggerHooks","_temp4","message","details","replaceContent","_incomingDocument$que","incomingDocument","DOMParser","parseFromString","title","innerText","currentEl","incomingEl","replaceWith","requestedUrl","isSameResolvedUrl","behavior","scrollIntoView","scrollTo","use","plugin","maybeInvalidPlugin","isSwupPlugin","_checkRequirements","_beforeMount","mount","plugins","unuse","pluginOrName","findPlugin","unmount","_afterUnmount","p","find","version","clickDelegate","log","defaults","animateHistoryBrowsing","ignoreVisit","closest","linkSelector","Accept","_event$state","linkClickHandler","popStateHandler","checkRequirements","enable","documentElement","origin","triggerWillOpenNewWindow","delegateTarget","fromElement","historyAttr","metaKey","ctrlKey","shiftKey","altKey","button","preventDefault","top","left","triggerEl","matches","_event$state2","_event$state3","url1","url2","matchPath","path","match"],"mappings":"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"}