Mercurial Hosting > lang
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()