import { C as noop, s as safe_not_equal } from "./index-a23f1e07.js"; const subscriber_queue = []; function writable(value, start = noop) { let stop; const subscribers = /* @__PURE__ */ new Set(); function set(new_value) { if (safe_not_equal(value, new_value)) { value = new_value; if (stop) { const run_queue = !subscriber_queue.length; for (const subscriber of subscribers) { subscriber[1](); subscriber_queue.push(subscriber, value); } if (run_queue) { for (let i = 0; i < subscriber_queue.length; i += 2) { subscriber_queue[i][0](subscriber_queue[i + 1]); } subscriber_queue.length = 0; } } } } function update(fn) { set(fn(value)); } function subscribe(run, invalidate = noop) { const subscriber = [run, invalidate]; subscribers.add(subscriber); if (subscribers.size === 1) { stop = start(set) || noop; } run(value); return () => { subscribers.delete(subscriber); if (subscribers.size === 0) { stop(); stop = null; } }; } return { set, update, subscribe }; } const base = ""; let assets = base; function set_assets(path) { assets = path; } let version = ""; function set_version(value) { version = value; } const SNAPSHOT_KEY = "sveltekit:snapshot"; const SCROLL_KEY = "sveltekit:scroll"; const INDEX_KEY = "sveltekit:index"; const PRELOAD_PRIORITIES = ( /** @type {const} */ { tap: 1, hover: 2, viewport: 3, eager: 4, off: -1 } ); function get_base_uri(doc) { let baseURI = doc.baseURI; if (!baseURI) { const baseTags = doc.getElementsByTagName("base"); baseURI = baseTags.length ? baseTags[0].href : doc.URL; } return baseURI; } function scroll_state() { return { x: pageXOffset, y: pageYOffset }; } function link_option(element, name) { const value = ( /** @type {ValidLinkOptions | null} */ element.getAttribute(`data-sveltekit-${name}`) ); return value; } const levels = { ...PRELOAD_PRIORITIES, "": PRELOAD_PRIORITIES.hover }; function parent_element(element) { let parent = element.assignedSlot ?? element.parentNode; if ((parent == null ? void 0 : parent.nodeType) === 11) parent = parent.host; return ( /** @type {Element} */ parent ); } function find_anchor(element, target) { while (element && element !== target) { if (element.nodeName.toUpperCase() === "A" && element.hasAttribute("href")) { return ( /** @type {HTMLAnchorElement | SVGAElement} */ element ); } element = /** @type {Element} */ parent_element(element); } } function get_link_info(a, base2) { let url; try { url = new URL(a instanceof SVGAElement ? a.href.baseVal : a.href, document.baseURI); } catch { } const target = a instanceof SVGAElement ? a.target.baseVal : a.target; const external = !url || !!target || is_external_url(url, base2) || (a.getAttribute("rel") || "").split(/\s+/).includes("external") || a.hasAttribute("download"); return { url, external, target }; } function get_router_options(element) { let noscroll = null; let preload_code = null; let preload_data = null; let reload = null; let el = element; while (el && el !== document.documentElement) { if (preload_code === null) preload_code = link_option(el, "preload-code"); if (preload_data === null) preload_data = link_option(el, "preload-data"); if (noscroll === null) noscroll = link_option(el, "noscroll"); if (reload === null) reload = link_option(el, "reload"); el = /** @type {Element} */ parent_element(el); } return { preload_code: levels[preload_code ?? "off"], preload_data: levels[preload_data ?? "off"], noscroll: noscroll === "off" ? false : noscroll === "" ? true : null, reload: reload === "off" ? false : reload === "" ? true : null }; } function notifiable_store(value) { const store = writable(value); let ready = true; function notify() { ready = true; store.update((val) => val); } function set(new_value) { ready = false; store.set(new_value); } function subscribe(run) { let old_value; return store.subscribe((new_value) => { if (old_value === void 0 || ready && new_value !== old_value) { run(old_value = new_value); } }); } return { notify, set, subscribe }; } function create_updated_store() { const { set, subscribe } = writable(false); let timeout; async function check() { clearTimeout(timeout); const res = await fetch(`${assets}/${"_app/version.json"}`, { headers: { pragma: "no-cache", "cache-control": "no-cache" } }); if (res.ok) { const data = await res.json(); const updated = data.version !== version; if (updated) { set(true); clearTimeout(timeout); } return updated; } else { throw new Error(`Version check failed: ${res.status}`); } } return { subscribe, check }; } function is_external_url(url, base2) { return url.origin !== location.origin || !url.pathname.startsWith(base2); } let client; function init(opts) { client = opts.client; } const stores = { url: notifiable_store({}), page: notifiable_store({}), navigating: writable( /** @type {import('types').Navigation | null} */ null ), updated: create_updated_store() }; export { INDEX_KEY as I, PRELOAD_PRIORITIES as P, SCROLL_KEY as S, SNAPSHOT_KEY as a, get_link_info as b, get_router_options as c, scroll_state as d, base as e, find_anchor as f, get_base_uri as g, init as h, is_external_url as i, set_assets as j, set_version as k, client as l, stores as s };