Skip to content

Commit

Permalink
feat: upgrade template structure
Browse files Browse the repository at this point in the history
  • Loading branch information
obeys committed Dec 11, 2024
1 parent b07723d commit 78a53ce
Show file tree
Hide file tree
Showing 19 changed files with 250 additions and 19 deletions.
9 changes: 4 additions & 5 deletions build/esbuild-build.ts
Original file line number Diff line number Diff line change
@@ -1,15 +1,14 @@
import esbuild, { BuildOptions } from "esbuild";

const ENTRY_POINTS = {
typescript: ["static/main.ts"],
// css: ["static/style.css"],
};
const typescriptEntries = ["src/main.ts"];
const cssEntries = ["static/style.css"];
const entries = [...typescriptEntries, ...cssEntries];

const DATA_URL_LOADERS = [".png", ".woff", ".woff2", ".eot", ".ttf", ".svg"];

export const esbuildOptions: BuildOptions = {
sourcemap: true,
entryPoints: [...ENTRY_POINTS.typescript /* ...ENTRY_POINTS.css */],
entryPoints: entries,
bundle: true,
minify: false,
loader: Object.fromEntries(DATA_URL_LOADERS.map((ext) => [ext, "dataurl"])),
Expand Down
5 changes: 5 additions & 0 deletions src/components/component1.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
export function createPage1Content(): HTMLElement {
const container = document.createElement("div");
container.textContent = "This is the content of page 1";
return container;
}
5 changes: 5 additions & 0 deletions src/components/component2.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
export function createPage2Content(): HTMLElement {
const container = document.createElement("div");
container.textContent = "This is the content of page 2";
return container;
}
13 changes: 13 additions & 0 deletions src/controllers/404.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
export async function load404Page() {
const contentArea = document.getElementById("content-area");

if (contentArea) {
try {
const response = await fetch("./404.html");
const html = await response.text();
contentArea.innerHTML = html;
} catch (error) {
console.error("Failed to load 404 page:", error);
}
}
}
13 changes: 13 additions & 0 deletions src/controllers/home.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
export async function loadHomePage() {
const contentArea = document.getElementById("content-area");

if (contentArea) {
try {
const response = await fetch("./home.html");
const html = await response.text();
contentArea.innerHTML = html;
} catch (error) {
console.error("Failed to load home page:", error);
}
}
}
15 changes: 15 additions & 0 deletions src/controllers/page1.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
import { createPage1Content } from "../components/component1";

export async function loadPage1() {
const contentArea = document.getElementById("content-area");

if (contentArea) {
try {
const content = createPage1Content();
contentArea.innerHTML = "";

Check warning on line 9 in src/controllers/page1.ts

View workflow job for this annotation

GitHub Actions / check-for-empty-strings

Detected an empty string. If this is during variable initialization, consider using a different approach. For more information, visit: https://www.github.com/ubiquity/ts-template/issues/31
contentArea.appendChild(content);
} catch (error) {
console.error("Failed to load page 1:", error);
}
}
}
15 changes: 15 additions & 0 deletions src/controllers/page2.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
import { createPage2Content } from "../components/component2";

export async function loadPage2() {
const contentArea = document.getElementById("content-area");

if (contentArea) {
try {
const content = createPage2Content();
contentArea.innerHTML = "";

Check warning on line 9 in src/controllers/page2.ts

View workflow job for this annotation

GitHub Actions / check-for-empty-strings

Detected an empty string. If this is during variable initialization, consider using a different approach. For more information, visit: https://www.github.com/ubiquity/ts-template/issues/31
contentArea.appendChild(content);
} catch (error) {
console.error("Failed to load page 2:", error);
}
}
}
17 changes: 17 additions & 0 deletions src/main.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
import { handleRouting } from "./router";
import { initializeState } from "./on-load";

export async function mainModule() {
try {
await initializeState();
console.log("State initialized");

await handleRouting();
} catch (error) {
console.error("Error in main: ", error);
}
}

mainModule().catch((error) => {
console.error("Unhandled error:", error);
});
16 changes: 16 additions & 0 deletions src/on-load.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
import { GlobalState } from "./types";

export const globalState: GlobalState = {
isLoading: false,
data: {},
};

export async function initializeState() {
globalState.isLoading = true;
try {
// Initial data loading goes here
globalState.data = {};
} finally {
globalState.isLoading = false;
}
}
47 changes: 47 additions & 0 deletions src/router.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
import { loadPage1 } from "./controllers/page1";
import { loadPage2 } from "./controllers/page2";
import { load404Page } from "./controllers/404";
import { loadHomePage } from "./controllers/home";

function normalizeRoute(hash: string): string {
// Remove file extensions
let route = hash.replace(/\.[^/.]+$/, "");

Check warning on line 8 in src/router.ts

View workflow job for this annotation

GitHub Actions / check-for-empty-strings

Detected an empty string. If this is during variable initialization, consider using a different approach. For more information, visit: https://www.github.com/ubiquity/ts-template/issues/31
// Ensure hash starts with #/
if (!route.startsWith("#")) route = "#" + route;
if (!route.startsWith("#/")) route = "#/" + route.substring(1);
// Remove trailing slash except for root
if (route !== "#/") route = route.replace(/\/$/, "");

Check warning on line 13 in src/router.ts

View workflow job for this annotation

GitHub Actions / check-for-empty-strings

Detected an empty string. If this is during variable initialization, consider using a different approach. For more information, visit: https://www.github.com/ubiquity/ts-template/issues/31
return route;
}

// URL Path based routing
export async function handleRouting() {
const contentArea = document.getElementById("content-area");

if (!contentArea) return;

const route = normalizeRoute(window.location.hash);

switch (route) {
case "#/page1":
await loadPage1();
break;
case "#/page2":
await loadPage2();
break;
case "#/":
case "#/home":
case "#/index":
await loadHomePage();
break;
default:
// Redirect to home if no route matches
await load404Page();
break;
}
}

// Run handleRouting on hashchange
window.addEventListener("hashchange", () => {
handleRouting().catch(console.error);
});
4 changes: 4 additions & 0 deletions src/types.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
export interface GlobalState {
isLoading: boolean;
data: Record<string, unknown>;
}
30 changes: 30 additions & 0 deletions static/404.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
<div id="Page404">
<div>
<p>Oops!</p>
<p>We can't seem to find the page you're looking for</p>
<p>
<b>Here are some helpful links instead:</b>
</p>
<ul>
<li>
<a href="//github.com/ubiquity/ubiquity-dollar/wiki" target="_blank">Docs</a>
</li>
<li>
<a href="//dao.ubq.fi/faq" target="_blank">FAQ</a>
</li>
<li>
<a href="//github.com/ubiquity/ubiquity-dollar" target="_blank">Github</a>
</li>
<li>
<a href="//discord.gg/SjymJ5maJ4" target="_blank">Discord</a>
</li>
<li>
<a href="//t.me/ubiquitydao" target="_blank">Telegram</a>
</li>
<li>
<a href="//x.com/UbiquityDAO" target="_blank">X</a>
</li>
</ul>
</div>
<div> 404 </div>
</div>
3 changes: 3 additions & 0 deletions static/home.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<div class="content">
<h1>Ubiquity TypeScript Template Home</h1>
</div>
12 changes: 10 additions & 2 deletions static/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,15 @@
<link rel="stylesheet" href="style.css" />
</head>
<body>
<h1>Ubiquity TypeScript Template</h1>
<script type="module" src="dist/main.js"></script>
<nav id="nav-selector">
<a href="#">Home</a>
<a href="#/page1">Page 1</a>
<a href="#/page2">Page 2</a>
</nav>

<div id="content-area">
<!-- This is where the content from pages will be rendered -->
</div>
<script type="module" src="dist/src/main.js"></script>
</body>
</html>
11 changes: 0 additions & 11 deletions static/main.ts

This file was deleted.

3 changes: 3 additions & 0 deletions static/page1.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<div class="content">
<h1>Ubiquity TypeScript Template Page 1</h1>
</div>
3 changes: 3 additions & 0 deletions static/page2.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<div class="content">
<h1>Ubiquity TypeScript Template Page 2</h1>
</div>
46 changes: 46 additions & 0 deletions static/style.css
Original file line number Diff line number Diff line change
Expand Up @@ -14,3 +14,49 @@ body {
url(./fonts/ubiquity-nova-standard.woff) format("woff"),
url(./fonts/ubiquity-nova-standard.ttf) format("truetype");
}

#nav-selector {
display: flex;
gap: 20px;
justify-content: center;
}

#nav-selector a {
color: #fff;
text-decoration: none;
font-size: 1rem;
}

/* Page 404 styles */
#Page404 {
display: flex;
height: 100%;
justify-content: space-between;
align-items: center;
padding: 2rem;
}
#Page404 a {
text-decoration: underline;
}
#Page404 ul {
padding: 0;
margin: 0;
}
#Page404 li {
width: 100%;
}
#Page404 > div:nth-child(1) {
display: flex;
flex-direction: column;
justify-content: center;
padding: 16px;
}
#Page404 > div:nth-child(1) > p:nth-child(1) {
font-size: 2rem;
}
#Page404 > div:nth-child(2) {
align-items: center;
display: flex;
font-size: 4rem;
padding: 16px;
}
2 changes: 1 addition & 1 deletion tests/main.test.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { mainModule } from "../static/main";
import { mainModule } from "../src/main";
import { db } from "./__mocks__/db";
import { server } from "./__mocks__/node";
import usersGet from "./__mocks__/users-get.json";
Expand Down

0 comments on commit 78a53ce

Please sign in to comment.