summaryrefslogtreecommitdiffstats
path: root/src/server/content/blog.ts
diff options
context:
space:
mode:
author2023-02-16 22:57:52 +0530
committer2023-02-16 22:57:52 +0530
commit93e75949e9a2861f651e2a3602e08e9b25cf47c4 (patch)
tree9da44bdc8885c94355ee3dc7a1ae029bc2627356 /src/server/content/blog.ts
parent0.4.3 (diff)
downloadsudomsg-93e75949e9a2861f651e2a3602e08e9b25cf47c4.tar
sudomsg-93e75949e9a2861f651e2a3602e08e9b25cf47c4.tar.gz
sudomsg-93e75949e9a2861f651e2a3602e08e9b25cf47c4.tar.bz2
sudomsg-93e75949e9a2861f651e2a3602e08e9b25cf47c4.tar.lz
sudomsg-93e75949e9a2861f651e2a3602e08e9b25cf47c4.tar.xz
sudomsg-93e75949e9a2861f651e2a3602e08e9b25cf47c4.tar.zst
sudomsg-93e75949e9a2861f651e2a3602e08e9b25cf47c4.zip
Move to Server Side Render with expressjs
Backend Rewritten in typescript Signed-off-by: Marc Pervaz Boocha <mboocha@sudomsg.xyz> On branch main Your branch is up to date with 'origin/main'. Changes to be committed: new file: .editorconfig modified: .gitignore new file: Containerfile renamed: favicon/icon.svg -> assets/favicon.svg modified: assets/index.css deleted: assets/index.js deleted: assets/mandle.png deleted: assets/sw.js new file: assets/syntax.css modified: deploy deleted: eleventy.config.js deleted: favicon/192.png deleted: favicon/512.png deleted: favicon/icon.ico deleted: license modified: package-lock.json modified: package.json deleted: src/_data/env.js deleted: src/_data/metadata.js deleted: src/_includes/base.njk deleted: src/_includes/page.njk deleted: src/_includes/post.njk deleted: src/about.njk deleted: src/blog.njk new file: src/client/index.ts deleted: src/gen/atom.njk deleted: src/gen/error.njk deleted: src/gen/feedjson.11ty.js deleted: src/gen/gen.11tydata.js deleted: src/gen/manifest.11ty.js deleted: src/gen/metadata.11ty.js deleted: src/gen/robot.njk deleted: src/gen/sitemap.njk deleted: src/index.njk deleted: src/post/post.11tydata.js new file: src/server/app.ts new file: src/server/build.ts new file: src/server/content/about.ts new file: src/server/content/blog.ts new file: src/server/content/feed.ts new file: src/server/content/index.ts new file: src/server/content/robots.ts new file: src/server/content/sitemap.ts new file: src/server/content/webmanifest.ts new file: src/server/errHanadler.ts new file: src/server/img.ts new file: src/server/metadata.ts new file: src/server/router.ts new file: src/server/server.ts new file: src/server/template/Base.ts new file: src/server/template/Page.ts new file: src/server/template/Post.ts new file: src/server/template/atom.ts new file: src/server/template/header.ts new file: src/server/template/html.ts new file: src/server/template/sitemap.ts new file: src/server/template/syntax.ts new file: src/server/template/table.ts new file: src/server/template/vdom.ts new file: src/server/template/xml.ts new file: src/server/utils/createUrl.ts new file: src/server/utils/curl.ts new file: src/server/utils/isDefined.ts new file: src/server/utils/isDevel.ts new file: src/server/utils/relDir.ts new file: src/server/utils/relUrl.ts new file: src/server/utils/schema.ts new file: src/server/utils/setStingRoute.ts new file: src/server/utils/strHandler.ts new file: src/worker/sw.ts new file: src/worker/tsconfig.json new file: tsconfig.json
Diffstat (limited to 'src/server/content/blog.ts')
-rw-r--r--src/server/content/blog.ts35
1 files changed, 35 insertions, 0 deletions
diff --git a/src/server/content/blog.ts b/src/server/content/blog.ts
new file mode 100644
index 0000000..373b1ca
--- /dev/null
+++ b/src/server/content/blog.ts
@@ -0,0 +1,35 @@
+import { posts } from "../template/Post.js"
+import Base from "../template/Base.js"
+import { c } from "../template/vdom.js"
+import h from "../template/header.js"
+import relUrl from "../utils/relUrl.js"
+import schema from "../utils/schema.js"
+import metadata from "../metadata.js"
+import { div, article, a, small, time, span, p } from "../template/html.js"
+
+Base({
+ title: "Blog Posts",
+ url: "/blog",
+ content() {
+ return c(div, { itemscope: true, itemtype: schema("Blog"), role: "feed", "aria-busy": "false" },
+ ...posts.map((post, index, { length }) => {
+ const { date_mod, date_pub, title, description, url } = post
+ return c(article, { itemprop: "blogPost", itemscope: true, itemtype: schema("BlogPosting"), "aria-posinset": index, "aria-setsize": length },
+ c(h, { level: 1, itemprop: "headline" }, c(a, { href: relUrl(url), itemprop: "sameAs" }, title)),
+ c(small, {},
+ date_pub != date_mod ? [
+ c(time, { datetime: date_mod.toISOString(), itemprop: "dateModified" }, date_mod.toDateString()),
+ "- Modified "
+ ] : [],
+ c(time, { datetime: date_pub.toISOString(), itemprop: "datePublished" }, date_pub.toDateString())
+ , " - ",
+ c(span, { itemprop: "author", itemscope: true, itemtype: schema("Person") },
+ c(a, { href: metadata.author.url, rel: "author", itemprop: "url" },
+ c(span, { itemprop: "name" }, metadata.author.name))
+ ),
+ ),
+ c(p, { itemprop: "abstract" }, description)
+ )
+ }))
+ }
+}).setupRoute()