3 <TITLE>Topic Feed
</TITLE>
5 html{ Color: #E3E3E3; Background: #
700020; Font-Family: UI-Rounded, 'Hiragino Maru Gothic ProN', Quicksand, Comfortaa, Manjari, 'Arial Rounded MT', 'Arial Rounded MT Bold', Calibri, Sans-Serif; Line-Height:
1.5; Text-Shadow: Calc(
1EM /
12) Calc(
1EM /
12) #
000000 }
6 body{ Display: Grid; Box-Sizing: Border-Box; Margin: Auto; Padding-Inline:
1CH; Min-Block-Size:
100VH; Inline-Size:
100%; Max-Inline-Size:
48REM; Align-Content: Center; Justify-Content: Stretch }
7 :Any-Link{ Color: #
87E6DD }
8 footer{ Border-Block-Start: Thin Solid; Padding-Block:
1REM; Font-Size: Smaller; Text-Align: End }
9 dd :Any-Link{ Display: Block; Border: Thin Solid; Padding-Inline:
.5REM; Border-Radius:
.5REM; Min-Inline-Size: Max-Content; Inline-Size:
28CH; Color: #D6B7BF; Background: #
1A1A1A; Text-Shadow: None }
12 <NAV><P><A HRef=
/>Home
</A></P><DL></DL></NAV>
14 <A HRef=https://www.ladys.computer
/><IMG Width=
88 Height=
31 Style=
"Display: Block; Margin: Auto; Image-Rendering: Pixelated" Src=
"" Alt=
"Lady’s Computer"></A>
17 const nav = document.body.querySelector(
"nav")
18 const dl = nav.querySelector(
"dl")
19 const parser = new DOMParser
20 fetch(`${location}.jsonld`)
23 const topic = meta.subject || meta[
"@id"].split(
"/").pop()
24 document.title = topic
25 document.body.querySelector(
"h1").textContent =
"subject" in meta
28 if (
"subject" in meta) {
30 .insertBefore(document.createElement(
"p"), dl)
31 .appendChild(document.createElement(
"a"))
33 a.textContent =
"Topics" }
34 const { first, prev, next, current, items } = meta
35 if (first && first != location && first != prev) {
37 .insertBefore(document.createElement(
"p"), dl)
38 .appendChild(document.createElement(
"a"))
40 a.textContent =
"First Page" }
43 .insertBefore(document.createElement(
"p"), dl)
44 .appendChild(document.createElement(
"a"))
46 a.textContent =
"Previous Page" }
47 let prevDate = undefined
48 for (const status of items) {
49 if (status.created != prevDate) dl.appendChild(document.createElement(
"dt")).textContent = status.created
51 .appendChild(document.createElement(
"dd"))
52 .appendChild(document.createElement(
"a"))
53 a.href = status[
"@id"]
54 const { title } = status
55 if (title) a.textContent = title.length
> 28
56 ?
"".concat(...title.slice(
0,
27),
"…")
59 const summaryText = (() =
> {
61 const d = parser.parseFromString(status.content,
"application/xhtml+xml")
62 const div = document.createElement(
"div")
63 div.appendChild(document.importNode(d.documentElement, true))
64 Object.assign(div.style,
65 { position:
"absolute"
69 , overflow:
"hidden" })
70 document.body.appendChild(div)
71 const text = div.innerText
72 document.body.removeChild(div)
75 const chars = Array.from(summaryText.trim().replaceAll(/\s+/gu,
" "))
76 a.textContent = chars.length
> 28
77 ?
"".concat(...chars.slice(
0,
27),
"…")
78 : summaryText || status.identifier } }
81 .appendChild(document.createElement(
"p"))
82 .appendChild(document.createElement(
"a"))
84 a.textContent =
"Next Page" }
85 if (current && current != location && current != next) {
87 .appendChild(document.createElement(
"p"))
88 .appendChild(document.createElement(
"a"))
90 a.textContent =
"Latest Page" } })