2020-08-12 11:20:48 +02:00
|
|
|
-- refactor these to some proper management thing
|
|
|
|
selected_idxs = {
|
|
|
|
messages = {},
|
|
|
|
contacts = {},
|
|
|
|
to = {},
|
|
|
|
cc = {},
|
|
|
|
bcc = {},
|
|
|
|
}
|
|
|
|
message_drafts = {}
|
2019-09-16 08:06:54 +02:00
|
|
|
|
|
|
|
local theme
|
|
|
|
if minetest.get_modpath("default") then
|
|
|
|
theme = default.gui_bg .. default.gui_bg_img
|
|
|
|
else
|
|
|
|
theme = ""
|
|
|
|
end
|
|
|
|
|
|
|
|
mail.inbox_formspec = "size[8,9;]" .. theme .. [[
|
2020-08-10 13:01:33 +02:00
|
|
|
button[6,0.10;2,0.5;new;New]
|
|
|
|
button[6,0.95;2,0.5;read;Read]
|
|
|
|
button[6,1.70;2,0.5;reply;Reply]
|
|
|
|
button[6,2.45;2,0.5;replyall;Reply All]
|
|
|
|
button[6,3.20;2,0.5;forward;Forward]
|
|
|
|
button[6,3.95;2,0.5;delete;Delete]
|
|
|
|
button[6,4.82;2,0.5;markread;Mark Read]
|
|
|
|
button[6,5.55;2,0.5;markunread;Mark Unread]
|
|
|
|
button[6,6.55;2,0.5;contacts;Contacts]
|
|
|
|
button[6,7.40;2,0.5;about;About]
|
|
|
|
button_exit[6,8.45;2,0.5;quit;Close]
|
|
|
|
|
2019-09-16 08:06:54 +02:00
|
|
|
tablecolumns[color;text;text]
|
|
|
|
table[0,0;5.75,9;messages;#999,From,Subject]]
|
|
|
|
|
2020-08-10 18:41:05 +02:00
|
|
|
mail.contacts_formspec = "size[8,9;]" .. theme .. [[
|
|
|
|
button[6,0.10;2,0.5;new;New]
|
|
|
|
button[6,0.85;2,0.5;edit;Edit]
|
|
|
|
button[6,1.60;2,0.5;delete;Delete]
|
2020-07-31 23:51:13 +02:00
|
|
|
button[6,8.25;2,0.5;back;Back]
|
|
|
|
tablecolumns[color;text;text]
|
|
|
|
table[0,0;5.75,9;contacts;#999,Name,Note]]
|
|
|
|
|
2020-08-10 18:41:05 +02:00
|
|
|
mail.select_contact_formspec = "size[8,9;]" .. theme .. [[
|
2020-08-12 11:20:48 +02:00
|
|
|
tablecolumns[color;text;text]
|
|
|
|
table[0,0;3.5,9;contacts;#999,Name,Note%s]
|
|
|
|
button[3.55,2.00;1.75,0.5;toadd;→ Add]
|
|
|
|
button[3.55,2.75;1.75,0.5;toremove;← Remove]
|
|
|
|
button[3.55,6.00;1.75,0.5;ccadd;→ Add]
|
|
|
|
button[3.55,6.75;1.75,0.5;ccremove;← Remove]
|
|
|
|
tablecolumns[color;text;text]
|
|
|
|
table[5.15,0.0;2.75,4.5;to;#999,Name,Note%s]
|
|
|
|
tablecolumns[color;text;text]
|
|
|
|
table[5.15,4.6;2.75,4.5;cc;#999,Name,Note%s]
|
|
|
|
button[3.55,8.25;1.75,0.5;back;Back]
|
|
|
|
]]
|
2020-07-31 23:51:13 +02:00
|
|
|
|
2019-09-16 08:06:54 +02:00
|
|
|
|
|
|
|
function mail.show_about(name)
|
|
|
|
local formspec = [[
|
|
|
|
size[8,5;]
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
button[7.25,0;0.75,0.5;back;X]
|
2019-09-16 08:06:54 +02:00
|
|
|
label[0,0;Mail]
|
|
|
|
label[0,0.5;By cheapie]
|
|
|
|
label[0,1;http://github.com/cheapie/mail]
|
|
|
|
label[0,1.5;See LICENSE file for license information]
|
|
|
|
label[0,2.5;NOTE: Communication using this system]
|
|
|
|
label[0,3;is NOT guaranteed to be private!]
|
|
|
|
label[0,3.5;Admins are able to view the messages]
|
|
|
|
label[0,4;of any player.]
|
|
|
|
]] .. theme
|
|
|
|
|
|
|
|
minetest.show_formspec(name, "mail:about", formspec)
|
|
|
|
end
|
|
|
|
|
|
|
|
function mail.show_inbox(name)
|
|
|
|
local formspec = { mail.inbox_formspec }
|
|
|
|
local messages = mail.getMessages(name)
|
|
|
|
|
2020-08-12 11:20:48 +02:00
|
|
|
message_drafts[name] = nil
|
|
|
|
|
2019-09-16 08:06:54 +02:00
|
|
|
if messages[1] then
|
2020-01-06 12:58:26 +01:00
|
|
|
for _, message in ipairs(messages) do
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
mail.ensure_new_format(message)
|
2019-09-16 08:06:54 +02:00
|
|
|
if message.unread then
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
if not mail.player_in_list(name, message.to) then
|
|
|
|
formspec[#formspec + 1] = ",#FFD788"
|
|
|
|
else
|
|
|
|
formspec[#formspec + 1] = ",#FFD700"
|
|
|
|
end
|
2019-09-16 08:06:54 +02:00
|
|
|
else
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
if not mail.player_in_list(name, message.to) then
|
|
|
|
formspec[#formspec + 1] = ",#CCCCDD"
|
|
|
|
else
|
|
|
|
formspec[#formspec + 1] = ","
|
|
|
|
end
|
2019-09-16 08:06:54 +02:00
|
|
|
end
|
|
|
|
formspec[#formspec + 1] = ","
|
2020-08-12 11:51:01 +02:00
|
|
|
formspec[#formspec + 1] = minetest.formspec_escape(message.sender)
|
2019-09-16 08:06:54 +02:00
|
|
|
formspec[#formspec + 1] = ","
|
|
|
|
if message.subject ~= "" then
|
|
|
|
if string.len(message.subject) > 30 then
|
|
|
|
formspec[#formspec + 1] =
|
|
|
|
minetest.formspec_escape(string.sub(message.subject, 1, 27))
|
|
|
|
formspec[#formspec + 1] = "..."
|
|
|
|
else
|
|
|
|
formspec[#formspec + 1] = minetest.formspec_escape(message.subject)
|
|
|
|
end
|
|
|
|
else
|
|
|
|
formspec[#formspec + 1] = "(No subject)"
|
|
|
|
end
|
|
|
|
end
|
2020-08-12 11:20:48 +02:00
|
|
|
if selected_idxs.messages[name] then
|
2019-09-16 08:06:54 +02:00
|
|
|
formspec[#formspec + 1] = ";"
|
2020-08-12 11:20:48 +02:00
|
|
|
formspec[#formspec + 1] = tostring(selected_idxs.messages[name] + 1)
|
2019-09-16 08:06:54 +02:00
|
|
|
end
|
|
|
|
formspec[#formspec + 1] = "]"
|
|
|
|
else
|
2020-08-10 18:41:05 +02:00
|
|
|
formspec[#formspec + 1] = "]label[2.25,4.5;No mail]"
|
2019-09-16 08:06:54 +02:00
|
|
|
end
|
|
|
|
minetest.show_formspec(name, "mail:inbox", table.concat(formspec, ""))
|
|
|
|
end
|
|
|
|
|
2020-07-31 23:51:13 +02:00
|
|
|
function mail.show_contacts(name)
|
2020-08-12 11:20:48 +02:00
|
|
|
local formspec = mail.contacts_formspec .. mail.compile_contact_list(name, selected_idxs.contacts[name])
|
|
|
|
minetest.show_formspec(name, "mail:contacts", formspec)
|
2020-07-31 23:51:13 +02:00
|
|
|
end
|
|
|
|
|
2020-08-10 18:41:05 +02:00
|
|
|
function mail.show_edit_contact(name, contact_name, note, illegal_name_hint)
|
2020-07-31 23:51:13 +02:00
|
|
|
local formspec = [[
|
2020-08-10 18:41:05 +02:00
|
|
|
size[6,7]
|
|
|
|
button[4,6.25;2,0.5;back;Back]
|
|
|
|
field[0.25,0.5;4,1;name;Player name:;%s]
|
|
|
|
textarea[0.25,1.6;4,6.25;note;Note:;%s]
|
|
|
|
button[4,0.10;2,1;save;Save]
|
|
|
|
]]
|
|
|
|
if illegal_name_hint == "collision" then
|
|
|
|
formspec = formspec .. [[
|
|
|
|
label[4,1;That name]
|
|
|
|
label[4,1.5;is already in]
|
|
|
|
label[4,2;your contacts.]
|
|
|
|
]]
|
|
|
|
elseif illegal_name_hint == "empty" then
|
|
|
|
formspec = formspec .. [[
|
|
|
|
label[4,1;The contact]
|
|
|
|
label[4,1.5;name cannot]
|
|
|
|
label[4,2;be empty.]
|
|
|
|
]]
|
|
|
|
end
|
|
|
|
formspec = formspec .. theme
|
|
|
|
formspec = string.format(formspec,
|
|
|
|
minetest.formspec_escape(contact_name or ""),
|
|
|
|
minetest.formspec_escape(note or ""))
|
|
|
|
minetest.show_formspec(name, "mail:editcontact", formspec)
|
2020-07-31 23:51:13 +02:00
|
|
|
end
|
|
|
|
|
2020-08-12 11:20:48 +02:00
|
|
|
function mail.show_select_contact(name, to, cc, bcc)
|
|
|
|
local formspec = mail.select_contact_formspec
|
|
|
|
local contacts = mail.compile_contact_list(name, selected_idxs.contacts[name])
|
|
|
|
|
|
|
|
-- compile lists
|
|
|
|
if to then
|
|
|
|
to = mail.compile_contact_list(name, selected_idxs.to[name], to)
|
|
|
|
else
|
|
|
|
to = ""
|
|
|
|
end
|
|
|
|
if cc then
|
|
|
|
cc = mail.compile_contact_list(name, selected_idxs.cc[name], cc)
|
|
|
|
else
|
|
|
|
cc = ""
|
|
|
|
end
|
|
|
|
--[[if bcc then
|
|
|
|
bcc = table.concat(mail.compile_contact_list(name, selected_idxs.bcc[name], bcc)
|
|
|
|
else
|
|
|
|
bcc = ""
|
|
|
|
end]]--
|
|
|
|
formspec = string.format(formspec, contacts, to, cc)--, bcc()
|
|
|
|
minetest.show_formspec(name, "mail:selectcontact", formspec)
|
2020-07-31 23:51:13 +02:00
|
|
|
end
|
|
|
|
|
2020-08-12 11:20:48 +02:00
|
|
|
function mail.compile_contact_list(name, selected, playernames)
|
|
|
|
-- TODO: refactor this - not just compiles *a* list, but *the* list for the contacts screen (too inflexible)
|
|
|
|
local formspec = {}
|
2020-07-31 23:51:13 +02:00
|
|
|
local contacts = mail.getContacts(name)
|
|
|
|
|
2020-08-10 18:41:05 +02:00
|
|
|
local i = 0
|
2020-08-12 11:20:48 +02:00
|
|
|
if playernames == nil then
|
|
|
|
for k, contact in pairs(contacts) do
|
|
|
|
formspec[#formspec + 1] = ","
|
|
|
|
formspec[#formspec + 1] = ","
|
|
|
|
formspec[#formspec + 1] = minetest.formspec_escape(contact.name)
|
|
|
|
formspec[#formspec + 1] = ","
|
|
|
|
local note = contact.note
|
|
|
|
-- display an ellipsis if the note spans multiple lines
|
|
|
|
local idx = string.find(note, '\n')
|
|
|
|
if idx ~= nil then
|
|
|
|
note = string.sub(note, 1, idx-1) .. ' ...'
|
|
|
|
end
|
|
|
|
formspec[#formspec + 1] = minetest.formspec_escape(note)
|
|
|
|
i = i + 1
|
|
|
|
if type(selected) == "string" then
|
|
|
|
if selected == k then
|
|
|
|
selected = i
|
|
|
|
end
|
|
|
|
end
|
2020-07-31 23:51:13 +02:00
|
|
|
end
|
2020-08-12 11:20:48 +02:00
|
|
|
if i > 0 then
|
|
|
|
if selected then
|
|
|
|
formspec[#formspec + 1] = ";"
|
|
|
|
formspec[#formspec + 1] = tostring(selected + 1)
|
|
|
|
end
|
|
|
|
formspec[#formspec + 1] = "]"
|
|
|
|
else
|
|
|
|
formspec[#formspec + 1] = "]label[2,4.5;No contacts]"
|
2020-08-10 18:41:05 +02:00
|
|
|
end
|
2020-08-12 11:20:48 +02:00
|
|
|
else
|
|
|
|
if type(playernames) == "string" then
|
|
|
|
playernames = mail.parse_player_list(playernames)
|
|
|
|
end
|
|
|
|
for k,c in pairs(playernames) do
|
|
|
|
formspec[#formspec + 1] = ","
|
|
|
|
formspec[#formspec + 1] = ","
|
|
|
|
formspec[#formspec + 1] = minetest.formspec_escape(c)
|
|
|
|
formspec[#formspec + 1] = ","
|
|
|
|
if contacts[string.lower(c)] == nil then
|
|
|
|
formspec[#formspec + 1] = ""
|
|
|
|
else
|
|
|
|
local note = contacts[string.lower(c)].note
|
|
|
|
-- display an ellipsis if the note spans multiple lines
|
|
|
|
local idx = string.find(note, '\n')
|
|
|
|
if idx ~= nil then
|
|
|
|
note = string.sub(note, 1, idx-1) .. ' ...'
|
|
|
|
end
|
|
|
|
formspec[#formspec + 1] = minetest.formspec_escape(note)
|
|
|
|
end
|
|
|
|
i = i + 1
|
|
|
|
if not selected then
|
|
|
|
if type(selected) == "string" then
|
|
|
|
if k == selected then
|
|
|
|
selected = i
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if i > 0 and selected then
|
2020-07-31 23:51:13 +02:00
|
|
|
formspec[#formspec + 1] = ";"
|
2020-08-10 18:41:05 +02:00
|
|
|
formspec[#formspec + 1] = tostring(selected + 1)
|
2020-07-31 23:51:13 +02:00
|
|
|
end
|
|
|
|
formspec[#formspec + 1] = "]"
|
|
|
|
end
|
2020-08-12 11:20:48 +02:00
|
|
|
return table.concat(formspec, "")
|
2020-07-31 23:51:13 +02:00
|
|
|
end
|
|
|
|
|
2019-09-16 08:06:54 +02:00
|
|
|
function mail.show_message(name, msgnumber)
|
|
|
|
local messages = mail.getMessages(name)
|
|
|
|
local message = messages[msgnumber]
|
|
|
|
local formspec = [[
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
size[8,9]
|
|
|
|
button[7.25,0;0.75,0.5;back;X]
|
2019-09-16 08:06:54 +02:00
|
|
|
label[0,0;From: %s]
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
label[0,0.4;To: %s]
|
|
|
|
label[0,0.8;CC: %s]
|
|
|
|
label[0,1.3;Subject: %s]
|
|
|
|
textarea[0.25,1.8;8,7.8;body;;%s]
|
|
|
|
button[0,8.5;2,1;reply;Reply]
|
|
|
|
button[2,8.5;2,1;replyall;Reply All]
|
|
|
|
button[4,8.5;2,1;forward;Forward]
|
|
|
|
button[6,8.5;2,1;delete;Delete]
|
2019-09-16 08:06:54 +02:00
|
|
|
]] .. theme
|
|
|
|
|
2020-08-12 11:51:01 +02:00
|
|
|
local from = minetest.formspec_escape(message.sender)
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
local to = minetest.formspec_escape(message.to)
|
|
|
|
local cc = minetest.formspec_escape(message.cc)
|
2019-09-16 08:06:54 +02:00
|
|
|
local subject = minetest.formspec_escape(message.subject)
|
|
|
|
local body = minetest.formspec_escape(message.body)
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
formspec = string.format(formspec, from, to, cc, subject, body)
|
2019-09-16 08:06:54 +02:00
|
|
|
|
2020-08-10 18:41:05 +02:00
|
|
|
if message.unread then
|
|
|
|
message.unread = false
|
|
|
|
mail.setMessages(name, messages)
|
|
|
|
end
|
|
|
|
|
2019-09-16 08:06:54 +02:00
|
|
|
minetest.show_formspec(name,"mail:message",formspec)
|
|
|
|
end
|
|
|
|
|
2020-07-31 12:36:28 +02:00
|
|
|
function mail.show_compose(name, defaultto, defaultsubj, defaultbody, defaultcc, defaultbcc)
|
2019-09-16 08:06:54 +02:00
|
|
|
local formspec = [[
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
size[8,9]
|
2020-08-12 11:20:48 +02:00
|
|
|
button[0,0;1,1;tocontacts;To:]
|
|
|
|
field[1.1,0.3;3.2,1;to;;%s]
|
|
|
|
button[4,0;1,1;cccontacts;CC:]
|
|
|
|
field[5.1,0.3;3.1,1;cc;;%s]
|
|
|
|
button[4,0.75;1,1;bcccontacts;BCC:]
|
|
|
|
field[5.1,1.05;3.1,1;bcc;;%s]
|
|
|
|
field[0.25,2;8,1;subject;Subject:;%s]
|
|
|
|
textarea[0.25,2.5;8,6;body;;%s]
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
button[0.5,8.5;3,1;cancel;Cancel]
|
|
|
|
button[4.5,8.5;3,1;send;Send]
|
2019-09-16 08:06:54 +02:00
|
|
|
]] .. theme
|
|
|
|
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
defaultto = defaultto or ""
|
|
|
|
defaultsubj = defaultsubj or ""
|
|
|
|
defaultbody = defaultbody or ""
|
|
|
|
defaultcc = defaultcc or ""
|
|
|
|
defaultbcc = defaultbcc or ""
|
|
|
|
|
2019-09-16 08:06:54 +02:00
|
|
|
formspec = string.format(formspec,
|
2020-07-31 23:53:49 +02:00
|
|
|
minetest.formspec_escape(defaultto),
|
2020-07-31 12:36:28 +02:00
|
|
|
minetest.formspec_escape(defaultcc),
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
minetest.formspec_escape(defaultbcc),
|
|
|
|
minetest.formspec_escape(defaultsubj),
|
|
|
|
minetest.formspec_escape(defaultbody))
|
2019-09-16 08:06:54 +02:00
|
|
|
|
|
|
|
minetest.show_formspec(name, "mail:compose", formspec)
|
|
|
|
end
|
|
|
|
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
function mail.reply(name, message)
|
|
|
|
mail.ensure_new_format(message)
|
|
|
|
local replyfooter = "Type your reply here.\n\n--Original message follows--\n" ..message.body
|
2020-08-12 11:51:01 +02:00
|
|
|
mail.show_compose(name, message.sender, "Re: "..message.subject, replyfooter)
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
function mail.replyall(name, message)
|
|
|
|
mail.ensure_new_format(message)
|
|
|
|
local replyfooter = "Type your reply here.\n\n--Original message follows--\n" ..message.body
|
|
|
|
-- new recipients are the sender plus the original recipients, minus ourselves
|
|
|
|
local recipients = message.to
|
2020-08-12 11:51:01 +02:00
|
|
|
if message.sender ~= nil then
|
|
|
|
recipients = message.sender .. ", " .. recipients
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
end
|
|
|
|
recipients = mail.parse_player_list(recipients)
|
|
|
|
for k,v in pairs(recipients) do
|
|
|
|
if v == name then
|
|
|
|
table.remove(recipients, k)
|
|
|
|
break
|
|
|
|
end
|
|
|
|
end
|
|
|
|
recipients = mail.concat_player_list(recipients)
|
|
|
|
mail.show_compose(name, recipients, "Re: "..message.subject, replyfooter, message.cc)
|
|
|
|
end
|
|
|
|
|
|
|
|
function mail.forward(name, message)
|
|
|
|
local fwfooter = "Type your message here.\n\n--Original message follows--\n" ..message.body
|
|
|
|
mail.show_compose(name, "", "Fw: "..message.subject, fwfooter)
|
|
|
|
end
|
|
|
|
|
2019-09-16 08:06:54 +02:00
|
|
|
function mail.handle_receivefields(player, formname, fields)
|
|
|
|
if formname == "" and fields and fields.quit and minetest.get_modpath("unified_inventory") then
|
|
|
|
unified_inventory.set_inventory_formspec(player, "craft")
|
|
|
|
end
|
|
|
|
|
|
|
|
if formname == "mail:about" then
|
|
|
|
minetest.after(0.5, function()
|
|
|
|
mail.show_inbox(player:get_player_name())
|
|
|
|
end)
|
|
|
|
|
|
|
|
elseif formname == "mail:inbox" then
|
|
|
|
local name = player:get_player_name()
|
|
|
|
local messages = mail.getMessages(name)
|
|
|
|
|
|
|
|
if fields.messages then
|
|
|
|
local evt = minetest.explode_table_event(fields.messages)
|
2020-08-12 11:20:48 +02:00
|
|
|
selected_idxs.messages[name] = evt.row - 1
|
|
|
|
if evt.type == "DCL" and messages[selected_idxs.messages[name]] then
|
|
|
|
mail.show_message(name, selected_idxs.messages[name])
|
2019-09-16 08:06:54 +02:00
|
|
|
end
|
|
|
|
return true
|
|
|
|
end
|
|
|
|
if fields.read then
|
2020-08-12 11:20:48 +02:00
|
|
|
if messages[selected_idxs.messages[name]] then
|
|
|
|
mail.show_message(name, selected_idxs.messages[name])
|
2019-09-16 08:06:54 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
elseif fields.delete then
|
2020-08-12 11:20:48 +02:00
|
|
|
if messages[selected_idxs.messages[name]] then
|
|
|
|
table.remove(messages, selected_idxs.messages[name])
|
2020-08-10 18:41:05 +02:00
|
|
|
mail.setMessages(name, messages)
|
2019-09-16 08:06:54 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
mail.show_inbox(name)
|
2020-08-12 11:20:48 +02:00
|
|
|
elseif fields.reply and messages[selected_idxs.messages[name]] then
|
|
|
|
local message = messages[selected_idxs.messages[name]]
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
mail.reply(name, message)
|
|
|
|
|
2020-08-12 11:20:48 +02:00
|
|
|
elseif fields.replyall and messages[selected_idxs.messages[name]] then
|
|
|
|
local message = messages[selected_idxs.messages[name]]
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
mail.replyall(name, message)
|
2019-09-16 08:06:54 +02:00
|
|
|
|
2020-08-12 11:20:48 +02:00
|
|
|
elseif fields.forward and messages[selected_idxs.messages[name]] then
|
|
|
|
local message = messages[selected_idxs.messages[name]]
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
mail.forward(name, message)
|
2019-09-16 08:06:54 +02:00
|
|
|
|
|
|
|
elseif fields.markread then
|
2020-08-12 11:20:48 +02:00
|
|
|
if messages[selected_idxs.messages[name]] then
|
|
|
|
messages[selected_idxs.messages[name]].unread = false
|
2020-08-10 18:41:05 +02:00
|
|
|
-- set messages immediately, so it shows up already when updating the inbox
|
|
|
|
mail.setMessages(name, messages)
|
2019-09-16 08:06:54 +02:00
|
|
|
end
|
|
|
|
mail.show_inbox(name)
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
return true
|
2019-09-16 08:06:54 +02:00
|
|
|
|
|
|
|
elseif fields.markunread then
|
2020-08-12 11:20:48 +02:00
|
|
|
if messages[selected_idxs.messages[name]] then
|
|
|
|
messages[selected_idxs.messages[name]].unread = true
|
2020-08-10 18:41:05 +02:00
|
|
|
-- set messages immediately, so it shows up already when updating the inbox
|
|
|
|
mail.setMessages(name, messages)
|
2019-09-16 08:06:54 +02:00
|
|
|
end
|
|
|
|
mail.show_inbox(name)
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
return true
|
2019-09-16 08:06:54 +02:00
|
|
|
|
|
|
|
elseif fields.new then
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
mail.show_compose(name)
|
2019-09-16 08:06:54 +02:00
|
|
|
|
2020-08-10 18:41:05 +02:00
|
|
|
elseif fields.contacts then
|
|
|
|
mail.show_contacts(name)
|
|
|
|
|
2019-09-16 08:06:54 +02:00
|
|
|
elseif fields.quit then
|
|
|
|
if minetest.get_modpath("unified_inventory") then
|
|
|
|
unified_inventory.set_inventory_formspec(player, "craft")
|
|
|
|
end
|
|
|
|
|
|
|
|
elseif fields.about then
|
|
|
|
mail.show_about(name)
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
return true
|
|
|
|
elseif formname == "mail:message" then
|
|
|
|
local name = player:get_player_name()
|
|
|
|
local messages = mail.getMessages(name)
|
|
|
|
|
|
|
|
if fields.back then
|
|
|
|
mail.show_inbox(name)
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
return true -- don't uselessly set messages
|
2019-09-16 08:06:54 +02:00
|
|
|
elseif fields.reply then
|
2020-08-12 11:20:48 +02:00
|
|
|
local message = messages[selected_idxs.messages[name]]
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
mail.reply(name, message)
|
|
|
|
elseif fields.replyall then
|
2020-08-12 11:20:48 +02:00
|
|
|
local message = messages[selected_idxs.messages[name]]
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
mail.replyall(name, message)
|
2019-09-16 08:06:54 +02:00
|
|
|
elseif fields.forward then
|
2020-08-12 11:20:48 +02:00
|
|
|
local message = messages[selected_idxs.messages[name]]
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
mail.forward(name, message.subject)
|
2019-09-16 08:06:54 +02:00
|
|
|
elseif fields.delete then
|
2020-08-12 11:20:48 +02:00
|
|
|
if messages[selected_idxs.messages[name]] then
|
|
|
|
table.remove(messages,selected_idxs.messages[name])
|
2020-08-10 18:41:05 +02:00
|
|
|
mail.setMessages(name, messages)
|
2019-09-16 08:06:54 +02:00
|
|
|
end
|
|
|
|
mail.show_inbox(name)
|
|
|
|
end
|
|
|
|
return true
|
2020-08-10 18:41:05 +02:00
|
|
|
|
2019-09-16 08:06:54 +02:00
|
|
|
elseif formname == "mail:compose" then
|
2020-08-12 11:20:48 +02:00
|
|
|
local name = player:get_player_name()
|
2019-09-16 08:06:54 +02:00
|
|
|
if fields.send then
|
|
|
|
mail.send({
|
2020-08-10 18:41:05 +02:00
|
|
|
from = name,
|
2020-07-31 12:36:28 +02:00
|
|
|
to = fields.to,
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
cc = fields.cc,
|
|
|
|
bcc = fields.bcc,
|
2019-09-16 08:06:54 +02:00
|
|
|
subject = fields.subject,
|
fix some things, adjust GUI elements
- messages are now actually sent (bug in parse player list)
- no more crashes on sending mail (forgot to make variables local)
- actually handle CC and BCC fields instead of leaving them empty, duh
- make new functions be under the mail namespace
- add util functions to ensure the new format, parse and player list as well as checking whether a player is in that list or not
- rearrange some GUI elements (tighter spacing, grouping, increase window height to be consistent)
- convert mails to new format only as needed (old mails stay intact in case someone reverts to old version)
- mails are shaded differently in inbox, depending on whether the player is in the TO field
- FROM, TO and CC fields are all displayed when reading a mail
- add "Reply All" button (TO includes all original recipients plus the sender, but excluding the player himself, while adopting the CC field. To contrast: "Reply" just sets the original sender as TO and leaves the rest empty)
- move reply, replyall and forward to their own functions in GUI (was duplicated for inbox and show mail)
- don't needlessly set messages table when we do nothing but go back
2020-08-10 11:43:10 +02:00
|
|
|
body = fields.body,
|
2019-09-16 08:06:54 +02:00
|
|
|
})
|
2020-08-10 18:41:05 +02:00
|
|
|
local contacts = mail.getContacts(name)
|
|
|
|
local recipients = mail.parse_player_list(fields.to)
|
|
|
|
local changed = false
|
|
|
|
for _,v in pairs(recipients) do
|
|
|
|
if contacts[string.lower(v)] == nil then
|
|
|
|
contacts[string.lower(v)] = {
|
|
|
|
name = v,
|
|
|
|
note = "",
|
|
|
|
}
|
|
|
|
changed = true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if changed then
|
|
|
|
mail.setContacts(name, contacts)
|
|
|
|
end
|
2020-08-12 11:20:48 +02:00
|
|
|
|
|
|
|
minetest.after(0.5, function()
|
|
|
|
mail.show_inbox(name)
|
|
|
|
end)
|
|
|
|
|
|
|
|
elseif fields.tocontacts or fields.cccontacts or fields.bcccontacts then
|
|
|
|
message_drafts[name] = {
|
|
|
|
to = fields.to,
|
|
|
|
cc = fields.cc,
|
|
|
|
bcc = fields.bcc,
|
|
|
|
subject = fields.subject,
|
|
|
|
body = fields.body,
|
|
|
|
}
|
|
|
|
mail.show_select_contact(name, fields.to, fields.cc, fields.bcc)
|
|
|
|
elseif fields.cancel then
|
|
|
|
message_drafts[name] = nil
|
|
|
|
mail.show_inbox(name)
|
2019-09-16 08:06:54 +02:00
|
|
|
end
|
2020-08-12 11:20:48 +02:00
|
|
|
return true
|
|
|
|
|
|
|
|
elseif formname == "mail:selectcontact" then
|
|
|
|
local name = player:get_player_name()
|
|
|
|
local contacts = mail.getContacts(name)
|
|
|
|
local draft = message_drafts[name]
|
|
|
|
|
|
|
|
-- get indexes for fields with selected rows
|
|
|
|
-- execute their default button's actions if double clicked
|
|
|
|
for k,action in pairs({
|
|
|
|
contacts = "toadd",
|
|
|
|
to = "toremove",
|
|
|
|
cc = "ccremove",
|
|
|
|
bcc = "bccremove"
|
|
|
|
}) do
|
|
|
|
if fields[k] then
|
|
|
|
local evt = minetest.explode_table_event(fields[k])
|
|
|
|
selected_idxs[k][name] = evt.row - 1
|
|
|
|
if evt.type == "DCL" and selected_idxs[k][name] then
|
|
|
|
fields[action] = true
|
|
|
|
end
|
|
|
|
return true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
local update = false
|
|
|
|
-- add
|
|
|
|
for _,v in pairs({"to","cc","bcc"}) do
|
|
|
|
if fields[v.."add"] then
|
|
|
|
update = true
|
|
|
|
if selected_idxs.contacts[name] then
|
|
|
|
local i = 0
|
|
|
|
for k, contact in pairs(contacts) do
|
|
|
|
i = i+1
|
|
|
|
if i == selected_idxs.contacts[name] then
|
|
|
|
local list = mail.parse_player_list(draft[v])
|
|
|
|
list[#list+1] = contact.name
|
|
|
|
selected_idxs[v][name] = #list
|
|
|
|
draft[v] = mail.concat_player_list(list)
|
|
|
|
break
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
-- remove
|
|
|
|
for _,v in pairs({"to","cc","bcc"}) do
|
|
|
|
if fields[v.."remove"] then
|
|
|
|
update = true
|
|
|
|
if selected_idxs[v][name] then
|
|
|
|
local list = mail.parse_player_list(draft[v])
|
|
|
|
table.remove(list, selected_idxs[v][name])
|
|
|
|
if #list < selected_idxs[v][name] then
|
|
|
|
selected_idxs[v][name] = #list
|
|
|
|
end
|
|
|
|
draft[v] = mail.concat_player_list(list)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if update then
|
|
|
|
mail.show_select_contact(name, draft.to, draft.cc, draft.bcc)
|
|
|
|
return true
|
|
|
|
end
|
|
|
|
|
|
|
|
if fields.back then
|
|
|
|
-- just do the default stuff below, as ESC will
|
|
|
|
end
|
|
|
|
|
|
|
|
-- delete old idxs
|
|
|
|
for _,v in ipairs({"contacts","to","cc","bcc"}) do
|
|
|
|
selected_idxs[v][name] = nil
|
|
|
|
end
|
|
|
|
mail.show_compose(name, draft.to, draft.subject, draft.body, draft.cc, draft.bcc)
|
2019-09-16 08:06:54 +02:00
|
|
|
return true
|
2020-07-31 23:51:13 +02:00
|
|
|
|
|
|
|
elseif formname == "mail:contacts" then
|
|
|
|
local name = player:get_player_name()
|
|
|
|
local contacts = mail.getContacts(name)
|
|
|
|
|
|
|
|
if fields.contacts then
|
|
|
|
local evt = minetest.explode_table_event(fields.contacts)
|
2020-08-12 11:20:48 +02:00
|
|
|
--selected_idxs.contacts[name] = evt.row - 1
|
2020-08-10 18:41:05 +02:00
|
|
|
local i = 0
|
|
|
|
for k,c in pairs(contacts) do
|
|
|
|
i = i + 1
|
|
|
|
if i == evt.row - 1 then
|
2020-08-12 11:20:48 +02:00
|
|
|
selected_idxs.contacts[name] = k
|
2020-08-10 18:41:05 +02:00
|
|
|
break
|
|
|
|
end
|
|
|
|
end
|
2020-08-12 11:20:48 +02:00
|
|
|
if evt.type == "DCL" and contacts[selected_idxs.contacts[name]] then
|
|
|
|
mail.show_edit_contact(name, contacts[selected_idxs.contacts[name]].name, contacts[selected_idxs.contacts[name]].note)
|
2020-07-31 23:51:13 +02:00
|
|
|
end
|
|
|
|
return true
|
|
|
|
elseif fields.new then
|
2020-08-12 11:20:48 +02:00
|
|
|
selected_idxs.contacts[name] = "#NEW#"
|
2020-08-10 18:41:05 +02:00
|
|
|
mail.show_edit_contact(name, "", "")
|
2020-07-31 23:51:13 +02:00
|
|
|
elseif fields.edit then
|
2020-08-12 11:20:48 +02:00
|
|
|
mail.show_edit_contact(name, contacts[selected_idxs.contacts[name]].name, contacts[selected_idxs.contacts[name]].note)
|
2020-07-31 23:51:13 +02:00
|
|
|
elseif fields.delete then
|
2020-08-12 11:20:48 +02:00
|
|
|
if contacts[selected_idxs.contacts[name]] then
|
|
|
|
contacts[selected_idxs.contacts[name]] = nil
|
2020-08-10 18:41:05 +02:00
|
|
|
mail.setContacts(name, contacts)
|
2020-07-31 23:51:13 +02:00
|
|
|
end
|
|
|
|
|
2020-08-10 18:41:05 +02:00
|
|
|
mail.show_contacts(name)
|
2020-07-31 23:51:13 +02:00
|
|
|
|
|
|
|
elseif fields.back then
|
|
|
|
mail.show_inbox(name)
|
|
|
|
|
|
|
|
end
|
2020-08-10 18:41:05 +02:00
|
|
|
elseif formname == "mail:editcontact" then
|
|
|
|
local name = player:get_player_name()
|
|
|
|
local contacts = mail.getContacts(name)
|
2020-07-31 23:51:13 +02:00
|
|
|
|
2020-08-10 18:41:05 +02:00
|
|
|
if fields.save then
|
2020-08-12 11:20:48 +02:00
|
|
|
if selected_idxs.contacts[name] and selected_idxs.contacts[name] ~= "#NEW#" then
|
|
|
|
local contact = contacts[selected_idxs.contacts[name]]
|
|
|
|
if selected_idxs.contacts[name] ~= string.lower(fields.name) then
|
2020-08-10 18:41:05 +02:00
|
|
|
-- name changed!
|
|
|
|
if #fields.name == 0 then
|
|
|
|
mail.show_edit_contact(name, contact.name, fields.note, "empty")
|
|
|
|
return true
|
|
|
|
elseif contacts[string.lower(fields.name)] ~= nil then
|
|
|
|
mail.show_edit_contact(name, contact.name, fields.note, "collision")
|
|
|
|
return true
|
|
|
|
else
|
|
|
|
contacts[string.lower(fields.name)] = contact
|
2020-08-12 11:20:48 +02:00
|
|
|
contacts[selected_idxs.contacts[name]] = nil
|
2020-08-10 18:41:05 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
contact.name = fields.name
|
|
|
|
contact.note = fields.note
|
|
|
|
else
|
|
|
|
local contact = {
|
|
|
|
name = fields.name,
|
|
|
|
note = fields.note,
|
|
|
|
}
|
|
|
|
contacts[string.lower(contact.name)] = contact
|
|
|
|
end
|
|
|
|
mail.setContacts(name, contacts)
|
|
|
|
mail.show_contacts(name)
|
|
|
|
|
|
|
|
elseif fields.back then
|
|
|
|
mail.show_contacts(name)
|
|
|
|
|
|
|
|
end
|
2019-09-16 08:06:54 +02:00
|
|
|
|
|
|
|
elseif fields.mail then
|
|
|
|
mail.show_inbox(player:get_player_name())
|
|
|
|
else
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
minetest.register_on_player_receive_fields(mail.handle_receivefields)
|
|
|
|
|
|
|
|
|
|
|
|
if minetest.get_modpath("unified_inventory") then
|
|
|
|
mail.receive_mail_message = mail.receive_mail_message ..
|
|
|
|
" or use the mail button in the inventory"
|
|
|
|
mail.read_later_message = mail.read_later_message ..
|
|
|
|
" or by using the mail button in the inventory"
|
|
|
|
|
|
|
|
unified_inventory.register_button("mail", {
|
|
|
|
type = "image",
|
|
|
|
image = "mail_button.png",
|
|
|
|
tooltip = "Mail"
|
|
|
|
})
|
|
|
|
end
|