wm-fontis-tibi-2023/frontend/src/index.ts

78 lines
2.3 KiB
TypeScript
Raw Normal View History

2023-07-13 15:20:36 +02:00
import App from "./App.svelte"
2023-07-14 13:58:27 +02:00
import { location } from "./lib/store"
2023-07-13 13:12:19 +02:00
const publishLocation = (_p?: string) => {
let _s: string
let _h: string
if (_p) {
const parts = _p.split("#")
_p = parts.shift()
_h = parts.join()
if (_h) _h = "#" + _h
const parts2 = _p.split("?")
2023-07-13 16:28:54 +02:00
_p = parts2.shift()
2023-07-13 13:12:19 +02:00
_s = parts2.join()
if (_s) _s = "?" + _s
}
const newLocation = {
2023-07-13 16:28:54 +02:00
path: _p || (typeof window !== "undefined" && window.location?.pathname),
search: _p ? _s : typeof window !== "undefined" && window.location?.search,
2023-07-13 13:12:19 +02:00
hash: _p ? _h : typeof window !== "undefined" && window.location?.hash,
push: !!_p,
pop: !_p,
categoryPath: "",
}
newLocation.categoryPath = newLocation.path.replace(/\/[^_\/]+_[^\/]+$/, "")
location.set(newLocation)
}
if (typeof history !== "undefined") {
if (typeof Proxy !== "undefined") {
// modern browser
const historyApply = (target, thisArg, argumentsList) => {
2023-07-13 16:28:54 +02:00
publishLocation(argumentsList && argumentsList.length >= 2 && argumentsList[2])
2023-07-13 13:12:19 +02:00
Reflect.apply(target, thisArg, argumentsList)
}
history.pushState = new Proxy(history.pushState, {
apply: historyApply,
})
history.replaceState = new Proxy(history.replaceState, {
apply: historyApply,
})
} else {
// ie11
const pushStateFn = history.pushState
const replaceStateFn = history.replaceState
history.pushState = function (data: any, title: string, url?: string) {
publishLocation(url)
return pushStateFn.apply(history, arguments)
}
2023-07-13 16:28:54 +02:00
history.replaceState = function (data: any, title: string, url?: string) {
2023-07-13 13:12:19 +02:00
publishLocation(url)
return replaceStateFn.apply(history, arguments)
}
}
} // else ssr -> no history handling
typeof window !== "undefined" &&
window.addEventListener("popstate", (event) => {
publishLocation()
})
let appContainer = document?.getElementById("appContainer")
const hydrate = true //import.meta?.env?.MODE !== "development"
console.log("Features: ", { hydrate })
const app = new App({
target: appContainer,
props: {},
hydrate,
})
2023-07-13 16:28:54 +02:00
export default app