Mercurial Hosting > chat
diff src/index.html.luan @ 21:5a56297713a3
move chat to home
author | Franklin Schmidt <fschmidt@gmail.com> |
---|---|
date | Tue, 05 Nov 2024 12:57:41 -0700 |
parents | src/chat.html.luan@dade6a560494 |
children | c54c806fcc6e |
line wrap: on
line diff
--- a/src/index.html.luan Mon Nov 04 21:37:58 2024 -0700 +++ b/src/index.html.luan Tue Nov 05 12:57:41 2024 -0700 @@ -1,13 +1,90 @@ local Luan = require "luan:Luan.luan" local error = Luan.error +local ipairs = Luan.ipairs or error() +local pairs = Luan.pairs or error() +local range = Luan.range or error() +local Table = require "luan:Table.luan" +local concat = Table.concat or error() +local is_empty = Table.is_empty or error() +local size = Table.size 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 started = Shared.started or error() +local chats_html = Shared.chats_html or error() +local http_push_to_users = Shared.http_push_to_users or error() +local User = require "site:/lib/User.luan" +local current_user = User.current or error() +local get_user_by_email = User.get_by_email or error() +local Utils = require "site:/lib/Utils.luan" +local to_set = Utils.to_set or error() +local Db = require "site:/lib/Db.luan" +local run_in_transaction = Db.run_in_transaction or error() +local Chat = require "site:/lib/Chat.luan" +local chat_search = Chat.search or error() +local Logging = require "luan:logging/Logging.luan" +local logger = Logging.logger "index.html" +local function get_chat(with) + local t = {} + local ids = {} + for email in pairs(with) do + local with_user = get_user_by_email(email) or error() + local id = with_user.id + t[#t+1] = "+chat_user_ids:"..id + ids[#ids+1] = id + end + local query = concat(t," ") + local need_push = false + local chat = run_in_transaction( function() + local chats = chat_search(query) + local n = #chats + if n == 0 then + local chat = Chat.new{ + user_ids = ids + } + chat.save() + need_push = true + return chat + elseif n == 1 then + return chats[1] + else + error("multiple chats for: "..query) + end + end ) + if need_push then + local js = "getChats('"..chat.id.."')" + http_push_to_users( chat.user_ids, js ) + end + return chat +end + return function() + local with = Http.request.parameters.with + with = to_set(with) + local user = current_user() + if user == nil then + local url = "/login.html" + if not is_empty(with) then + local t = {} + for email in pairs(with) do + t[#t+1] = "with="..email + end + url = url.."?"..concat(t,"&") + end + Http.response.send_redirect(url) + return + end + local selected = nil + if not is_empty(with) then + with[user.email] = true + if size(with) > 1 then + selected = get_chat(with) + end + end Io.stdout = Http.response.text_writer() %> <!doctype html> @@ -15,21 +92,37 @@ <head> <% head() %> <style> - h1 { - margin-bottom: 0; - } - h3 { - margin-top: 8px; - } + @import "chat.css?s=<%=started%>"; </style> + <script src="chat.js?s=<%=started%>"></script> </head> <body> <% header() %> <div content> - <h1>Web Chat</h1> - <h3>A free web-based instant messaging service</h3> - <p><a href="https://hg.reactionary.software/repo/chat/">source code</a></p> + <div chats> +<% chats_html() %> + </div> + <div posts></div> </div> + <dialog delete_chat> + <h2>Delete Chat</h2> + <p>Are you sure that you want to delete this chat?</p> + <div buttons> + <button cancel onclick="closeModal(this)">Cancel</button> + <button go onclick="doDeleteChat(this)">Delete</button> + </div> + </dialog> + <script> +<% + if selected ~= nil then +%> + let div = document.querySelector('div[chat="<%=selected.id%>"]'); + selectChat(div); +<% + end +%> + setUserEventSource(<%=user.id%>); + </script> </body> </html> <%