-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtitle.js
61 lines (55 loc) · 1.78 KB
/
title.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
(() => {
/* DOM */
const bodyClass = document.body.classList
const entry = document.getElementsByTagName("textarea")[0]
const titleDOM = document.getElementsByTagName("h1")[0]
/* localStorage management */
const lsn = "~ddb:" // localStorage namespace
const getPref = (pref) => localStorage.getItem(lsn + pref)
const getPrefs = () => ({
prefForce: getPref("force") === "true",
prefTheme: getPref("theme") || "dark",
})
/* Update the state of the document based on client preferences. */
const renderPreferences = () => {
const { prefForce, prefTheme } = getPrefs()
if(prefForce) {
bodyClass.add(prefTheme)
}
}
renderPreferences()
/* Display the title. */
const setTitle = (title) => {
if(title) {
titleDOM.childNodes.forEach(child => child.remove())
titleDOM.append(document.createTextNode(title))
document.title = title
}
}
/* Update title based on the document fragment. */
const hashchangeHandler = () => {
const here = new URL(window.location.href)
const title = decodeURI(here.hash.slice(1))
const updated = setTitle(title)
entry.value = title
}
/* Update the title on page load */
hashchangeHandler()
/* and any time the hash changes, eg. when using the back button. */
addEventListener("hashchange", hashchangeHandler)
/* Add a way to easily edit the title. */
const checkKey = (evt) => {
const code = evt.code
if(code === "Escape") {
entry.classList.toggle("hidden")
const title = entry.value
setTitle(title)
if(entry.classList.contains("hidden")) {
const here = new URL(window.location.href)
here.hash = `#${encodeURI(title)}`
history.pushState({}, "", here)
}
}
}
document.addEventListener("keyup", checkKey)
})()