Message filters/sorters (#56)
* Add sorters for inbox/outbox * Add ascending/descending, fix selection issue * Add filters * Update translations * Fix UI * Fix luacheck * Fix fields disappearing after clicking on tabs/buttons * Fix luacheck (2) * Fix first message not sorted correctly
This commit is contained in:
parent
def93bdd0f
commit
da05b5d108
@ -1,6 +1,6 @@
|
|||||||
minetest.register_chatcommand("mail",{
|
minetest.register_chatcommand("mail",{
|
||||||
description = "Open the mail interface",
|
description = "Open the mail interface",
|
||||||
func = function(name)
|
func = function(name)
|
||||||
mail.show_inbox(name)
|
mail.show_inbox(name, "3", "1", "")
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
@ -3,12 +3,12 @@ BCC=BCC
|
|||||||
Cancel=Abbrechen
|
Cancel=Abbrechen
|
||||||
Save draft=Entwurf Speichern
|
Save draft=Entwurf Speichern
|
||||||
Send=Senden
|
Send=Senden
|
||||||
Subject=Betreff
|
|
||||||
To=An
|
|
||||||
CC=CC
|
CC=CC
|
||||||
No drafts=Keine Entwürfe
|
Edit=Bearbeiten
|
||||||
|
Note=Notiz
|
||||||
New=Neu
|
New=Neu
|
||||||
Delete=Löschen
|
Name=Name
|
||||||
|
No drafts=Keine Entwürfe
|
||||||
Player name=Spielername
|
Player name=Spielername
|
||||||
your contacts.=ihre Kontakte.
|
your contacts.=ihre Kontakte.
|
||||||
The contact=Der Kontakt
|
The contact=Der Kontakt
|
||||||
@ -17,21 +17,20 @@ Desc=Beschreibung
|
|||||||
Players=Spieler
|
Players=Spieler
|
||||||
your maillists.=ihre Verteilerlisten.
|
your maillists.=ihre Verteilerlisten.
|
||||||
The maillist=Die Verteilerliste
|
The maillist=Die Verteilerliste
|
||||||
|
Back=Zurück
|
||||||
Save=Speichern
|
Save=Speichern
|
||||||
That name=Der Name
|
That name=Der Name
|
||||||
is already in=ist bereits in
|
is already in=ist bereits in
|
||||||
name cannot=Name kann nicht
|
name cannot=Name kann nicht
|
||||||
be empty.=leer sein.
|
be empty.=leer sein.
|
||||||
Back=Zurück
|
|
||||||
Mark Read=Als gelesen makieren
|
Mark Read=Als gelesen makieren
|
||||||
Mark Unread=Als ungelesen makieren
|
Mark Unread=Als ungelesen makieren
|
||||||
(No description)=(Keine Beschreibung)
|
|
||||||
No maillist=Keine Verteilerliste
|
|
||||||
Note=Notiz
|
|
||||||
Edit=Bearbeiten
|
|
||||||
Name=Name
|
|
||||||
Date=Datum
|
|
||||||
From=Von
|
From=Von
|
||||||
|
Read=Lesen
|
||||||
|
Ascending=
|
||||||
|
Descending=
|
||||||
|
Filter=
|
||||||
|
No mail=Keine Nachrichten
|
||||||
Inbox=Posteingang
|
Inbox=Posteingang
|
||||||
Sent messages=Nachrichten senden
|
Sent messages=Nachrichten senden
|
||||||
Drafts=Entwürfe
|
Drafts=Entwürfe
|
||||||
@ -40,10 +39,14 @@ Mail lists=Verteilerlisten
|
|||||||
About=Über
|
About=Über
|
||||||
Close=Schließen
|
Close=Schließen
|
||||||
(No subject)=(Kein Betreff)
|
(No subject)=(Kein Betreff)
|
||||||
Read=Lesen
|
Date=Datum
|
||||||
No mail=Keine Nachrichten
|
|
||||||
Reply=Antworten
|
Reply=Antworten
|
||||||
Reply all=Allen antworten
|
Reply all=Allen antworten
|
||||||
Forward=Weiter
|
Forward=Weiter
|
||||||
|
(No description)=(Keine Beschreibung)
|
||||||
|
No maillist=Keine Verteilerliste
|
||||||
|
Subject=Betreff
|
||||||
|
To=An
|
||||||
|
Delete=Löschen
|
||||||
Add=Hinzufügen
|
Add=Hinzufügen
|
||||||
Remove=Entfernen
|
Remove=Entfernen
|
@ -3,19 +3,12 @@ BCC=Cci
|
|||||||
Cancel=Annuler
|
Cancel=Annuler
|
||||||
Save draft=Enregistrer le brouillon
|
Save draft=Enregistrer le brouillon
|
||||||
Send=Envoyer
|
Send=Envoyer
|
||||||
|
CC=Cc
|
||||||
Edit=Modifier
|
Edit=Modifier
|
||||||
No drafts=
|
Note=Note
|
||||||
Inbox=Boîte de réception
|
|
||||||
Sent messages=Messages envoyés
|
|
||||||
Drafts=Brouillons
|
|
||||||
Contacts=Contacts
|
|
||||||
Mail lists=Listes de diffusion
|
|
||||||
About=À propos
|
|
||||||
Close=Fermer
|
|
||||||
(No subject)=(Sans objet)
|
|
||||||
Delete=Supprimer
|
|
||||||
New=Nouveau
|
New=Nouveau
|
||||||
Subject=Objet
|
Name=Nom
|
||||||
|
No drafts=Pas de brouillons
|
||||||
Player name=Nom du joueur
|
Player name=Nom du joueur
|
||||||
your contacts.=vos contacts.
|
your contacts.=vos contacts.
|
||||||
The contact=Ce contact
|
The contact=Ce contact
|
||||||
@ -24,6 +17,7 @@ Desc=Desc
|
|||||||
Players=Joueurs
|
Players=Joueurs
|
||||||
your maillists.=vos listes de diffusion.
|
your maillists.=vos listes de diffusion.
|
||||||
The maillist=Cette liste de diffusion
|
The maillist=Cette liste de diffusion
|
||||||
|
Back=Retour
|
||||||
Save=Sauvegarder
|
Save=Sauvegarder
|
||||||
That name=Ce nom
|
That name=Ce nom
|
||||||
is already in=existe déjà
|
is already in=existe déjà
|
||||||
@ -32,18 +26,27 @@ be empty.=être vide.
|
|||||||
Mark Read=Marquer comme lu
|
Mark Read=Marquer comme lu
|
||||||
Mark Unread=Marquer non lu
|
Mark Unread=Marquer non lu
|
||||||
From=De
|
From=De
|
||||||
|
Read=Lire
|
||||||
|
Ascending=Croissant
|
||||||
|
Descending=Décroissant
|
||||||
|
Filter=Filtre
|
||||||
|
No mail=Aucun mail
|
||||||
|
Inbox=Boîte de réception
|
||||||
|
Sent messages=Messages envoyés
|
||||||
|
Drafts=Brouillons
|
||||||
|
Contacts=Contacts
|
||||||
|
Mail lists=Listes de diffusion
|
||||||
|
About=À propos
|
||||||
|
Close=Fermer
|
||||||
|
(No subject)=(Sans objet)
|
||||||
|
Date=Date
|
||||||
Reply=Répondre
|
Reply=Répondre
|
||||||
Reply all=Répondre à tous
|
Reply all=Répondre à tous
|
||||||
Forward=Transférer
|
Forward=Transférer
|
||||||
Read=Lire
|
|
||||||
No mail=Aucun mail
|
|
||||||
(No description)=Sans description
|
(No description)=Sans description
|
||||||
No maillist=Aucune liste de diffusion
|
No maillist=Aucune liste de diffusion
|
||||||
Date=Date
|
Subject=Objet
|
||||||
|
To=À
|
||||||
|
Delete=Supprimer
|
||||||
Add=Ajouter
|
Add=Ajouter
|
||||||
Remove=Enlever
|
Remove=Enlever
|
||||||
CC=Cc
|
|
||||||
Back=Retour
|
|
||||||
Name=Nom
|
|
||||||
To=À
|
|
||||||
Note=Note
|
|
||||||
|
@ -3,19 +3,12 @@ BCC=密件副本
|
|||||||
Cancel=取消
|
Cancel=取消
|
||||||
Save draft=儲存草稿
|
Save draft=儲存草稿
|
||||||
Send=發送
|
Send=發送
|
||||||
|
CC=副本
|
||||||
Edit=編輯
|
Edit=編輯
|
||||||
No drafts=沒有草稿
|
Note=備註
|
||||||
Inbox=收件箱
|
|
||||||
Sent messages=寄件備份
|
|
||||||
Drafts=草稿
|
|
||||||
Contacts=聯繫人
|
|
||||||
Mail lists=郵件列表
|
|
||||||
About=關於
|
|
||||||
Close=關閉
|
|
||||||
(No subject)=(沒有主旨)
|
|
||||||
Delete=刪除
|
|
||||||
New=新建
|
New=新建
|
||||||
Subject=主旨
|
Name=名稱
|
||||||
|
No drafts=沒有草稿
|
||||||
Player name=玩家名稱
|
Player name=玩家名稱
|
||||||
your contacts.=
|
your contacts.=
|
||||||
The contact=
|
The contact=
|
||||||
@ -24,6 +17,7 @@ Desc=描述
|
|||||||
Players=玩家
|
Players=玩家
|
||||||
your maillists.=
|
your maillists.=
|
||||||
The maillist=
|
The maillist=
|
||||||
|
Back=返回
|
||||||
Save=儲存
|
Save=儲存
|
||||||
That name=
|
That name=
|
||||||
is already in=
|
is already in=
|
||||||
@ -32,18 +26,27 @@ be empty.=
|
|||||||
Mark Read=標記已讀
|
Mark Read=標記已讀
|
||||||
Mark Unread=標記未讀
|
Mark Unread=標記未讀
|
||||||
From=寄件者
|
From=寄件者
|
||||||
|
Read=閱讀
|
||||||
|
Ascending=
|
||||||
|
Descending=
|
||||||
|
Filter=
|
||||||
|
No mail=沒有郵件
|
||||||
|
Inbox=收件箱
|
||||||
|
Sent messages=寄件備份
|
||||||
|
Drafts=草稿
|
||||||
|
Contacts=聯繫人
|
||||||
|
Mail lists=郵件列表
|
||||||
|
About=關於
|
||||||
|
Close=關閉
|
||||||
|
(No subject)=(沒有主旨)
|
||||||
|
Date=日期
|
||||||
Reply=回覆
|
Reply=回覆
|
||||||
Reply all=回覆所有人
|
Reply all=回覆所有人
|
||||||
Forward=轉寄
|
Forward=轉寄
|
||||||
Read=閱讀
|
|
||||||
No mail=沒有郵件
|
|
||||||
(No description)=(沒有描述)
|
(No description)=(沒有描述)
|
||||||
No maillist=沒有郵件列表
|
No maillist=沒有郵件列表
|
||||||
Date=日期
|
Subject=主旨
|
||||||
|
To=收件人
|
||||||
|
Delete=刪除
|
||||||
Add=加入
|
Add=加入
|
||||||
Remove=移除
|
Remove=移除
|
||||||
CC=副本
|
|
||||||
Back=返回
|
|
||||||
Name=名稱
|
|
||||||
To=收件人
|
|
||||||
Note=備註
|
|
||||||
|
@ -3,19 +3,12 @@ BCC=
|
|||||||
Cancel=
|
Cancel=
|
||||||
Save draft=
|
Save draft=
|
||||||
Send=
|
Send=
|
||||||
|
CC=
|
||||||
Edit=
|
Edit=
|
||||||
No drafts=
|
Note=
|
||||||
Inbox=
|
|
||||||
Sent messages=
|
|
||||||
Drafts=
|
|
||||||
Contacts=
|
|
||||||
Mail lists=
|
|
||||||
About=
|
|
||||||
Close=
|
|
||||||
(No subject)=
|
|
||||||
Delete=
|
|
||||||
New=
|
New=
|
||||||
Subject=
|
Name=
|
||||||
|
No drafts=
|
||||||
Player name=
|
Player name=
|
||||||
your contacts.=
|
your contacts.=
|
||||||
The contact=
|
The contact=
|
||||||
@ -24,6 +17,7 @@ Desc=
|
|||||||
Players=
|
Players=
|
||||||
your maillists.=
|
your maillists.=
|
||||||
The maillist=
|
The maillist=
|
||||||
|
Back=
|
||||||
Save=
|
Save=
|
||||||
That name=
|
That name=
|
||||||
is already in=
|
is already in=
|
||||||
@ -32,18 +26,27 @@ be empty.=
|
|||||||
Mark Read=
|
Mark Read=
|
||||||
Mark Unread=
|
Mark Unread=
|
||||||
From=
|
From=
|
||||||
|
Read=
|
||||||
|
Ascending=
|
||||||
|
Descending=
|
||||||
|
Filter=
|
||||||
|
No mail=
|
||||||
|
Inbox=
|
||||||
|
Sent messages=
|
||||||
|
Drafts=
|
||||||
|
Contacts=
|
||||||
|
Mail lists=
|
||||||
|
About=
|
||||||
|
Close=
|
||||||
|
(No subject)=
|
||||||
|
Date=
|
||||||
Reply=
|
Reply=
|
||||||
Reply all=
|
Reply all=
|
||||||
Forward=
|
Forward=
|
||||||
Read=
|
|
||||||
No mail=
|
|
||||||
(No description)=
|
(No description)=
|
||||||
No maillist=
|
No maillist=
|
||||||
Date=
|
Subject=
|
||||||
|
To=
|
||||||
|
Delete=
|
||||||
Add=
|
Add=
|
||||||
Remove=
|
Remove=
|
||||||
CC=
|
|
||||||
Back=
|
|
||||||
Name=
|
|
||||||
To=
|
|
||||||
Note=
|
|
||||||
|
71
storage.lua
71
storage.lua
@ -43,6 +43,77 @@ function mail.get_message(playername, msg_id)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function mail.sort_messages(unsorted_messages, sortfield, sortdirection)
|
||||||
|
local messages = {}
|
||||||
|
if not sortfield or sortfield == "" then
|
||||||
|
sortfield = "3"
|
||||||
|
end
|
||||||
|
if not sortdirection or sortdirection == "" then
|
||||||
|
sortdirection = "1"
|
||||||
|
end
|
||||||
|
|
||||||
|
if unsorted_messages[1] then
|
||||||
|
-- add first message
|
||||||
|
table.insert(messages, unsorted_messages[1])
|
||||||
|
table.remove(unsorted_messages, 1)
|
||||||
|
-- sort messages
|
||||||
|
for _, unsorted_msg in ipairs(unsorted_messages) do
|
||||||
|
local is_message_sorted = false
|
||||||
|
for j, sorted_msg in ipairs(messages) do
|
||||||
|
if sortfield == "1" and unsorted_msg.from >= sorted_msg.from then -- for inbox
|
||||||
|
table.insert(messages, j, unsorted_msg)
|
||||||
|
is_message_sorted = true
|
||||||
|
break
|
||||||
|
elseif sortfield == "1" and unsorted_msg.to >= sorted_msg.to then -- for outbox
|
||||||
|
table.insert(messages, j, unsorted_msg)
|
||||||
|
is_message_sorted = true
|
||||||
|
break
|
||||||
|
elseif sortfield == "2" and unsorted_msg.subject >= sorted_msg.subject then
|
||||||
|
table.insert(messages, j, unsorted_msg)
|
||||||
|
is_message_sorted = true
|
||||||
|
break
|
||||||
|
elseif sortfield == "3" and unsorted_msg.time >= sorted_msg.time then
|
||||||
|
table.insert(messages, j, unsorted_msg)
|
||||||
|
is_message_sorted = true
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if not is_message_sorted then
|
||||||
|
table.insert(messages, 1, unsorted_msg)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- reverse for descending
|
||||||
|
|
||||||
|
local sorted_messages = messages
|
||||||
|
|
||||||
|
if sortdirection == "2" then
|
||||||
|
sorted_messages = {}
|
||||||
|
for i=#messages, 1, -1 do
|
||||||
|
sorted_messages[#sorted_messages+1] = messages[i]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return sorted_messages
|
||||||
|
end
|
||||||
|
|
||||||
|
function mail.filter_messages(unfiltered_messages, filter)
|
||||||
|
if not filter or filter == "" then
|
||||||
|
return unfiltered_messages
|
||||||
|
end
|
||||||
|
|
||||||
|
local filtered_messages = {}
|
||||||
|
|
||||||
|
for _, msg in ipairs(unfiltered_messages) do
|
||||||
|
if string.find(msg.from, filter) or string.find(msg.to, filter) or string.find(msg.subject, filter) then
|
||||||
|
table.insert(filtered_messages, msg)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return filtered_messages
|
||||||
|
end
|
||||||
|
|
||||||
-- marks a mail read by its id
|
-- marks a mail read by its id
|
||||||
function mail.mark_read(playername, msg_id)
|
function mail.mark_read(playername, msg_id)
|
||||||
local entry = mail.get_storage_entry(playername)
|
local entry = mail.get_storage_entry(playername)
|
||||||
|
@ -8,10 +8,34 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
-- split inbox and sent msgs for different tests
|
-- split inbox and sent msgs for different tests
|
||||||
local entry = mail.get_storage_entry(name)
|
local entry = mail.get_storage_entry(name)
|
||||||
|
|
||||||
local messagesInbox = entry.inbox
|
local messagesInboxUnAnalyzed = entry.inbox
|
||||||
local messagesSent = entry.outbox
|
local messagesOutBoxUnAnalyzed = entry.outbox
|
||||||
local messagesDrafts = entry.drafts
|
local messagesDrafts = entry.drafts
|
||||||
|
|
||||||
|
-- filter inbox/outbox messages
|
||||||
|
|
||||||
|
local filter = fields.filter
|
||||||
|
if not filter then
|
||||||
|
filter = ""
|
||||||
|
end
|
||||||
|
|
||||||
|
local messagesInboxFiltered = mail.filter_messages(messagesInboxUnAnalyzed, filter)
|
||||||
|
local messagesOutboxFiltered = mail.filter_messages(messagesOutBoxUnAnalyzed, filter)
|
||||||
|
|
||||||
|
-- then sort them
|
||||||
|
|
||||||
|
local sortfield = tostring(fields.sortfield)
|
||||||
|
local sortdirection = tostring(fields.sortdirection)
|
||||||
|
if not sortfield or sortfield == "" or sortfield == "0" then
|
||||||
|
sortfield = "3"
|
||||||
|
end
|
||||||
|
if not sortdirection or sortdirection == "" or sortdirection == "0" then
|
||||||
|
sortdirection = "1"
|
||||||
|
end
|
||||||
|
|
||||||
|
local messagesInbox = mail.sort_messages(messagesInboxFiltered, sortfield, sortdirection, filter)
|
||||||
|
local messagesSent = mail.sort_messages(messagesOutboxFiltered, sortfield, sortdirection, filter)
|
||||||
|
|
||||||
if fields.inbox then -- inbox table
|
if fields.inbox then -- inbox table
|
||||||
local evt = minetest.explode_table_event(fields.inbox)
|
local evt = minetest.explode_table_event(fields.inbox)
|
||||||
mail.selected_idxs.inbox[name] = evt.row - 1
|
mail.selected_idxs.inbox[name] = evt.row - 1
|
||||||
@ -48,11 +72,11 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
|
|
||||||
if fields.boxtab == "1" then
|
if fields.boxtab == "1" then
|
||||||
mail.selected_idxs.boxtab[name] = 1
|
mail.selected_idxs.boxtab[name] = 1
|
||||||
mail.show_inbox(name)
|
mail.show_inbox(name, sortfield, sortdirection, filter)
|
||||||
|
|
||||||
elseif fields.boxtab == "2" then
|
elseif fields.boxtab == "2" then
|
||||||
mail.selected_idxs.boxtab[name] = 2
|
mail.selected_idxs.boxtab[name] = 2
|
||||||
mail.show_sent(name)
|
mail.show_sent(name, sortfield, sortdirection, filter)
|
||||||
|
|
||||||
elseif fields.boxtab == "3" then
|
elseif fields.boxtab == "3" then
|
||||||
mail.selected_idxs.boxtab[name] = 3
|
mail.selected_idxs.boxtab[name] = 3
|
||||||
@ -86,7 +110,7 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
mail.delete_mail(name, messagesDrafts[mail.selected_idxs.drafts[name]].id)
|
mail.delete_mail(name, messagesDrafts[mail.selected_idxs.drafts[name]].id)
|
||||||
end
|
end
|
||||||
|
|
||||||
mail.show_mail_menu(name)
|
mail.show_mail_menu(name, sortfield, sortdirection, filter)
|
||||||
|
|
||||||
elseif fields.reply then
|
elseif fields.reply then
|
||||||
if formname == "mail:inbox" and messagesInbox[mail.selected_idxs.inbox[name]] then
|
if formname == "mail:inbox" and messagesInbox[mail.selected_idxs.inbox[name]] then
|
||||||
@ -122,7 +146,7 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
mail.mark_read(name, messagesSent[mail.selected_idxs.sent[name]].id)
|
mail.mark_read(name, messagesSent[mail.selected_idxs.sent[name]].id)
|
||||||
end
|
end
|
||||||
|
|
||||||
mail.show_mail_menu(name)
|
mail.show_mail_menu(name, sortfield, sortdirection, filter)
|
||||||
|
|
||||||
elseif fields.markunread then
|
elseif fields.markunread then
|
||||||
if formname == "mail:inbox" and messagesInbox[mail.selected_idxs.inbox[name]] then
|
if formname == "mail:inbox" and messagesInbox[mail.selected_idxs.inbox[name]] then
|
||||||
@ -131,7 +155,7 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
mail.mark_unread(name, messagesSent[mail.selected_idxs.sent[name]].id)
|
mail.mark_unread(name, messagesSent[mail.selected_idxs.sent[name]].id)
|
||||||
end
|
end
|
||||||
|
|
||||||
mail.show_mail_menu(name)
|
mail.show_mail_menu(name, sortfield, sortdirection, filter)
|
||||||
|
|
||||||
elseif fields.new then
|
elseif fields.new then
|
||||||
mail.show_compose(name)
|
mail.show_compose(name)
|
||||||
@ -145,6 +169,8 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
elseif fields.about then
|
elseif fields.about then
|
||||||
mail.show_about(name)
|
mail.show_about(name)
|
||||||
|
|
||||||
|
elseif fields.sortfield or fields.sortdirection or fields.filter then
|
||||||
|
mail.show_mail_menu(name, sortfield, sortdirection, filter)
|
||||||
end
|
end
|
||||||
|
|
||||||
return true
|
return true
|
||||||
|
32
ui/inbox.lua
32
ui/inbox.lua
@ -1,7 +1,23 @@
|
|||||||
-- translation
|
-- translation
|
||||||
local S = minetest.get_translator("mail")
|
local S = minetest.get_translator("mail")
|
||||||
|
|
||||||
local inbox_formspec = "size[8.5,10;]" .. mail.theme .. [[
|
|
||||||
|
function mail.show_inbox(name, sortfield, sortdirection, filter)
|
||||||
|
if not sortfield or sortfield == "" or sortfield == "0" then
|
||||||
|
sortfield = 3
|
||||||
|
end
|
||||||
|
if not sortdirection or sortdirection == "" or sortdirection == "0" then
|
||||||
|
sortdirection = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
sortfield = tostring(sortfield)
|
||||||
|
sortdirection = tostring(sortdirection)
|
||||||
|
|
||||||
|
if not filter then
|
||||||
|
filter = ""
|
||||||
|
end
|
||||||
|
|
||||||
|
local inbox_formspec = "size[8.5,10;]" .. mail.theme .. [[
|
||||||
tabheader[0.3,1;boxtab;]] .. S("Inbox") .. "," .. S("Sent messages").. "," .. S("Drafts") .. [[;1;false;false]
|
tabheader[0.3,1;boxtab;]] .. S("Inbox") .. "," .. S("Sent messages").. "," .. S("Drafts") .. [[;1;false;false]
|
||||||
|
|
||||||
button[6,0.10;2.5,0.5;new;]] .. S("New") .. [[]
|
button[6,0.10;2.5,0.5;new;]] .. S("New") .. [[]
|
||||||
@ -17,14 +33,18 @@ local inbox_formspec = "size[8.5,10;]" .. mail.theme .. [[
|
|||||||
button[6,8.7;2.5,0.5;about;]] .. S("About") .. [[]
|
button[6,8.7;2.5,0.5;about;]] .. S("About") .. [[]
|
||||||
button_exit[6,9.5;2.5,0.5;quit;]] .. S("Close") .. [[]
|
button_exit[6,9.5;2.5,0.5;quit;]] .. S("Close") .. [[]
|
||||||
|
|
||||||
|
dropdown[0,9.4;2,0.5;sortfield;]] ..
|
||||||
|
S("From") .. "," .. S("Subject") .. "," .. S("Date") .. [[;]] .. tostring(sortfield) .. [[;1]
|
||||||
|
dropdown[2.0,9.4;2,0.5;sortdirection;]] ..
|
||||||
|
S("Ascending") .. "," .. S("Descending") .. [[;]] .. tostring(sortdirection) .. [[;1]
|
||||||
|
field[4.25,9.85;1.4,0.5;filter;]] .. S("Filter") .. [[:;]] .. filter .. [[]
|
||||||
|
button[5.14,9.52;0.85,0.5;search;Q]
|
||||||
|
|
||||||
tablecolumns[color;text;text]
|
tablecolumns[color;text;text]
|
||||||
table[0,0.7;5.75,9.35;inbox;#999,]] .. S("From") .. "," .. S("Subject")
|
table[0,0.7;5.75,8.35;inbox;#999,]] .. S("From") .. "," .. S("Subject")
|
||||||
|
|
||||||
|
|
||||||
function mail.show_inbox(name)
|
|
||||||
local formspec = { inbox_formspec }
|
local formspec = { inbox_formspec }
|
||||||
local entry = mail.get_storage_entry(name)
|
local entry = mail.get_storage_entry(name)
|
||||||
local messages = entry.inbox
|
local messages = mail.sort_messages(mail.filter_messages(entry.inbox, filter), sortfield, sortdirection)
|
||||||
|
|
||||||
mail.message_drafts[name] = nil
|
mail.message_drafts[name] = nil
|
||||||
|
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
-- helper function for tabbed overview
|
-- helper function for tabbed overview
|
||||||
|
|
||||||
function mail.show_mail_menu(playername)
|
function mail.show_mail_menu(playername, sortfield, sortdirection, filter)
|
||||||
local index = mail.selected_idxs.boxtab[playername] or 1
|
local index = mail.selected_idxs.boxtab[playername] or 1
|
||||||
if index == 1 then
|
if index == 1 then
|
||||||
mail.show_inbox(playername)
|
mail.show_inbox(playername, sortfield, sortdirection, filter)
|
||||||
elseif index == 2 then
|
elseif index == 2 then
|
||||||
mail.show_sent(playername)
|
mail.show_sent(playername, sortfield, sortdirection, filter)
|
||||||
elseif index == 3 then
|
elseif index == 3 then
|
||||||
mail.show_drafts(playername)
|
mail.show_drafts(playername)
|
||||||
end
|
end
|
||||||
|
@ -1,7 +1,23 @@
|
|||||||
-- translation
|
-- translation
|
||||||
local S = minetest.get_translator("mail")
|
local S = minetest.get_translator("mail")
|
||||||
|
|
||||||
local sent_formspec = "size[8.5,10;]" .. mail.theme .. [[
|
|
||||||
|
function mail.show_sent(name, sortfield, sortdirection, filter)
|
||||||
|
if not sortfield or sortfield == "" or sortfield == "0" then
|
||||||
|
sortfield = 3
|
||||||
|
end
|
||||||
|
if not sortdirection or sortdirection == "" or sortdirection == "0" then
|
||||||
|
sortdirection = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
sortfield = tostring(sortfield)
|
||||||
|
sortdirection = tostring(sortdirection)
|
||||||
|
|
||||||
|
if not filter then
|
||||||
|
filter = ""
|
||||||
|
end
|
||||||
|
|
||||||
|
local sent_formspec = "size[8.5,10;]" .. mail.theme .. [[
|
||||||
tabheader[0.3,1;boxtab;]] .. S("Inbox") .. "," .. S("Sent messages").. "," .. S("Drafts") .. [[;2;false;false]
|
tabheader[0.3,1;boxtab;]] .. S("Inbox") .. "," .. S("Sent messages").. "," .. S("Drafts") .. [[;2;false;false]
|
||||||
|
|
||||||
button[6,0.10;2.5,0.5;new;]] .. S("New") .. [[]
|
button[6,0.10;2.5,0.5;new;]] .. S("New") .. [[]
|
||||||
@ -15,14 +31,18 @@ local sent_formspec = "size[8.5,10;]" .. mail.theme .. [[
|
|||||||
button[6,8.7;2.5,0.5;about;]] .. S("About") .. [[]
|
button[6,8.7;2.5,0.5;about;]] .. S("About") .. [[]
|
||||||
button_exit[6,9.5;2.5,0.5;quit;]] .. S("Close") .. [[]
|
button_exit[6,9.5;2.5,0.5;quit;]] .. S("Close") .. [[]
|
||||||
|
|
||||||
|
dropdown[0,9.4;2,0.5;sortfield;]]
|
||||||
|
.. S("To") .. "," .. S("Subject") .. "," .. S("Date") .. [[;]] .. tostring(sortfield) .. [[;1]
|
||||||
|
dropdown[2.0,9.4;2,0.5;sortdirection;]]
|
||||||
|
.. S("Ascending") .. "," .. S("Descending") .. [[;]] .. tostring(sortdirection) .. [[;1]
|
||||||
|
field[4.25,9.85;1.4,0.5;filter;]].. S("Filter") .. [[:;]] .. filter .. [[]
|
||||||
|
button[5.14,9.52;0.85,0.5;search;Q]
|
||||||
|
|
||||||
tablecolumns[color;text;text]
|
tablecolumns[color;text;text]
|
||||||
table[0,0.7;5.75,9.35;sent;#999,]] .. S("To") .. "," .. S("Subject")
|
table[0,0.7;5.75,8.35;sent;#999,]] .. S("To") .. "," .. S("Subject")
|
||||||
|
|
||||||
|
|
||||||
function mail.show_sent(name)
|
|
||||||
local formspec = { sent_formspec }
|
local formspec = { sent_formspec }
|
||||||
local entry = mail.get_storage_entry(name)
|
local entry = mail.get_storage_entry(name)
|
||||||
local messages = entry.outbox
|
local messages = mail.sort_messages(mail.filter_messages(entry.outbox, filter), sortfield, sortdirection)
|
||||||
|
|
||||||
mail.message_drafts[name] = nil
|
mail.message_drafts[name] = nil
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user