6c38cd0019
- Cascade delete on all entities (student, module, UE, user, role, promotion) - Fix Response body reuse bug (factory functions instead of constants) - Student note viewing via CAS uid (strip non-digit prefix) - Fix middleware page visibility for students in LOCAL mode - Import result popup component (shared across all import pages) - Fix student import to use numEtud from Excel - Bulk student selection with promo change and delete - Move UE/UE-Module API and pages from notes to admin module - Move promotions page from students to admin module - Multi-year maquette import with per-year promo selection - Inline promo creation in maquette import - Static Excel templates (students, notes, maquette) - Fix XLSX export using blob download instead of writeFile - Allow students to read modules list (GET /modules)
59 lines
1.7 KiB
TypeScript
59 lines
1.7 KiB
TypeScript
import { FreshContext } from "$fresh/server.ts";
|
|
import { db } from "$root/databases/db.ts";
|
|
import { students } from "$root/databases/schema.ts";
|
|
import { and, eq } from "npm:drizzle-orm@0.45.2";
|
|
import {
|
|
getPartialsConfig,
|
|
makePartials,
|
|
} from "$root/defaults/makePartials.tsx";
|
|
import { CasContent, State } from "$root/defaults/interfaces.ts";
|
|
import NotesView from "../(_islands)/NotesView.tsx";
|
|
|
|
async function Notes(
|
|
_request: Request,
|
|
context: FreshContext<State>,
|
|
) {
|
|
const session = (context.state as unknown as { session: CasContent }).session;
|
|
|
|
let numEtud: number | null = null;
|
|
try {
|
|
if (session.eduPersonPrimaryAffiliation === "student") {
|
|
// Students: uid is "<letter>21212006" in AMU CAS — strip non-digit prefix
|
|
const etudId = parseInt(session.uid.replace(/^\D+/, ""), 10);
|
|
if (!isNaN(etudId)) {
|
|
const student = await db
|
|
.select()
|
|
.from(students)
|
|
.where(eq(students.numEtud, etudId))
|
|
.then((rows) => rows[0] ?? null);
|
|
numEtud = student?.numEtud ?? null;
|
|
}
|
|
} else {
|
|
// Employees: look up by nom/prenom
|
|
const student = await db
|
|
.select()
|
|
.from(students)
|
|
.where(
|
|
and(
|
|
eq(students.nom, session.sn),
|
|
eq(students.prenom, session.givenName),
|
|
),
|
|
)
|
|
.then((rows) => rows[0] ?? null);
|
|
numEtud = student?.numEtud ?? null;
|
|
}
|
|
} catch {
|
|
// DB lookup failed — island will show fallback message
|
|
}
|
|
|
|
return (
|
|
<NotesView
|
|
numEtud={numEtud}
|
|
prenom={session.givenName || session.displayName}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export const config = getPartialsConfig();
|
|
export default makePartials(Notes);
|