Initial commit: clean project structure

This commit is contained in:
2026-02-11 22:02:29 +01:00
commit 2d341a276e
22 changed files with 5479 additions and 0 deletions

1701
server/package-lock.json generated Normal file

File diff suppressed because it is too large Load Diff

25
server/package.json Normal file
View File

@@ -0,0 +1,25 @@
{
"name": "server",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"dev": "ts-node-dev --respawn --transpile-only src/index.ts",
"test": "echo \"Error: no test specified\" && exit 1"
},
"keywords": [],
"author": "",
"license": "ISC",
"type": "commonjs",
"dependencies": {
"cors": "^2.8.6",
"express": "^5.2.1"
},
"devDependencies": {
"@types/cors": "^2.8.19",
"@types/express": "^5.0.6",
"@types/node": "^25.2.3",
"ts-node-dev": "^2.0.0",
"typescript": "^5.9.3"
}
}

23
server/src/index.ts Normal file
View File

@@ -0,0 +1,23 @@
import express from 'express';
import cors from 'cors';
const app = express();
const PORT = 3001;
app.use(cors());
app.use(express.json());
// Mock data for the archive
const messages = [
{ id: 1, userId: "101", userName: "UserA", message: "Hello from the past!", timestamp: "2026-02-11T10:00:05" },
{ id: 2, userId: "102", userName: "UserB", message: "Teletext is cool.", timestamp: "2026-02-11T10:00:10" },
{ id: 3, userId: "103", userName: "UserC", message: "This is a playback test.", timestamp: "2026-02-11T10:00:15" },
];
app.get('/api/messages', (req, res) => {
res.json(messages);
});
app.listen(PORT, () => {
console.log(`Server is running on http://localhost:${PORT}`);
});

44
server/tsconfig.json Normal file
View File

@@ -0,0 +1,44 @@
{
// Visit https://aka.ms/tsconfig to read more about this file
"compilerOptions": {
// File Layout
// "rootDir": "./src",
// "outDir": "./dist",
// Environment Settings
// See also https://aka.ms/tsconfig/module
"module": "nodenext",
"target": "esnext",
"types": [],
// For nodejs:
// "lib": ["esnext"],
// "types": ["node"],
// and npm install -D @types/node
// Other Outputs
"sourceMap": true,
"declaration": true,
"declarationMap": true,
// Stricter Typechecking Options
"noUncheckedIndexedAccess": true,
"exactOptionalPropertyTypes": true,
// Style Options
// "noImplicitReturns": true,
// "noImplicitOverride": true,
// "noUnusedLocals": true,
// "noUnusedParameters": true,
// "noFallthroughCasesInSwitch": true,
// "noPropertyAccessFromIndexSignature": true,
// Recommended Options
"strict": true,
"jsx": "react-jsx",
"verbatimModuleSyntax": true,
"isolatedModules": true,
"noUncheckedSideEffectImports": true,
"moduleDetection": "force",
"skipLibCheck": true,
}
}