changeset 66:2ff1f78bb13e

minor
author Franklin Schmidt <fschmidt@gmail.com>
date Fri, 22 Aug 2025 07:25:35 -0600
parents ecb851fabd75
children 1793510fa36a
files src/lib/Course.luan src/private/tools/courses.html.luan src/private/tools/tools.html src/your_courses.html.luan
diffstat 4 files changed, 56 insertions(+), 1 deletions(-) [+]
line wrap: on
line diff
diff -r ecb851fabd75 -r 2ff1f78bb13e src/lib/Course.luan
--- a/src/lib/Course.luan	Fri Aug 22 05:51:22 2025 -0600
+++ b/src/lib/Course.luan	Fri Aug 22 07:25:35 2025 -0600
@@ -8,6 +8,8 @@
 local Db = require "site:/lib/Db.luan"
 local Shared = require "site:/lib/Shared.luan"
 local languages = Shared.languages or error()
+local User = require "site:/lib/User.luan"
+local get_user_by_id = User.get_by_id or error()
 
 
 local Course = {}
@@ -62,6 +64,10 @@
 		return languages[course.language]
 	end
 
+	function course.get_user()
+		return get_user_by_id(course.user_id)
+	end
+
 	return course
 end
 
diff -r ecb851fabd75 -r 2ff1f78bb13e src/private/tools/courses.html.luan
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/private/tools/courses.html.luan	Fri Aug 22 07:25:35 2025 -0600
@@ -0,0 +1,48 @@
+local Luan = require "luan:Luan.luan"
+local error = Luan.error
+local ipairs = Luan.ipairs or error()
+local Html = require "luan:Html.luan"
+local html_encode = Html.encode or error()
+local Io = require "luan:Io.luan"
+local Http = require "luan:http/Http.luan"
+local Shared = require "site:/lib/Shared.luan"
+local head = Shared.head or error()
+local header = Shared.header or error()
+local Course = require "site:/lib/Course.luan"
+local course_search = Course.search or error()
+local Logging = require "luan:logging/Logging.luan"
+local logger = Logging.logger "courses.html"
+
+
+return function()
+	local courses = course_search( "type:course", "course_updated desc" )
+	Io.stdout = Http.response.text_writer()
+%>
+<!doctype html>
+<html lang="en">
+	<head>
+<%		head() %>
+		<style>
+			td {
+				padding: 8px 8px;
+			}
+		</style>
+	</head>
+	<body>
+<%		header() %>
+		<div content>
+			<h1>Courses</h1>
+			<table>
+<%	for _, course in ipairs(courses) do %>
+				<tr>
+					<td><%= course.language_name() %></td>
+					<td><a href="/view_course.html?course=<%=course.id%>"><%= course.name_html() %></a></td>
+					<td><%= html_encode(course.get_user().email) %></td>
+				</tr>
+<%	end %>
+			</table>
+		</div>
+	</body>
+</html>
+<%
+end
diff -r ecb851fabd75 -r 2ff1f78bb13e src/private/tools/tools.html
--- a/src/private/tools/tools.html	Fri Aug 22 05:51:22 2025 -0600
+++ b/src/private/tools/tools.html	Fri Aug 22 07:25:35 2025 -0600
@@ -12,6 +12,7 @@
 			<p><a href="/">home</a></p>
 			<p><a href="../local/logs/">logs</a></p>
 			<p><a href="chats.html">chats</a></p>
+			<p><a href="courses.html">courses</a></p>
 			<p><a href="chat_form.html">chat</a></p>
 			<p><a href="lucene.html">lucene</a></p>
 		</div>
diff -r ecb851fabd75 -r 2ff1f78bb13e src/your_courses.html.luan
--- a/src/your_courses.html.luan	Fri Aug 22 05:51:22 2025 -0600
+++ b/src/your_courses.html.luan	Fri Aug 22 07:25:35 2025 -0600
@@ -13,7 +13,7 @@
 local Course = require "site:/lib/Course.luan"
 local course_search = Course.search or error()
 local Logging = require "luan:logging/Logging.luan"
-local logger = Logging.logger "chats.html"
+local logger = Logging.logger "your_courses.html"
 
 
 return function()