Add multiple selection (#60)
* Add multiple selection * Fix wrong messages issues * Update translations * Mix colors for unread/cc in inbox with selected green * Fix duplicates when clicking on select all with already one selected, and add the number of selected items * Fixes * Remove old translations files * Fix filter priority
This commit is contained in:
parent
67bda9a788
commit
191e511a05
4
init.lua
4
init.lua
@ -23,7 +23,9 @@ mail = {
|
|||||||
bcc = {},
|
bcc = {},
|
||||||
boxtab = {},
|
boxtab = {},
|
||||||
sortfield = {},
|
sortfield = {},
|
||||||
sortdirection = {}
|
sortdirection = {},
|
||||||
|
filter = {},
|
||||||
|
multipleselection = {}
|
||||||
},
|
},
|
||||||
|
|
||||||
message_drafts = {}
|
message_drafts = {}
|
||||||
|
@ -3,33 +3,39 @@ BCC=BCC
|
|||||||
Cancel=Abbrechen
|
Cancel=Abbrechen
|
||||||
Save draft=Entwurf Speichern
|
Save draft=Entwurf Speichern
|
||||||
Send=Senden
|
Send=Senden
|
||||||
CC=CC
|
Delete=Löschen
|
||||||
Edit=Bearbeiten
|
|
||||||
Note=Notiz
|
|
||||||
New=Neu
|
New=Neu
|
||||||
Name=Name
|
|
||||||
No drafts=Keine Entwürfe
|
No drafts=Keine Entwürfe
|
||||||
|
Edit=Bearbeiten
|
||||||
|
Subject=Betreff
|
||||||
Player name=Spielername
|
Player name=Spielername
|
||||||
your contacts.=ihre Kontakte.
|
your contacts.=ihre Kontakte.
|
||||||
The contact=Der Kontakt
|
The contact=Der Kontakt
|
||||||
Maillist name=Verteilerlistenname
|
|
||||||
Desc=Beschreibung
|
|
||||||
Players=Spieler
|
|
||||||
your maillists.=ihre Verteilerlisten.
|
|
||||||
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
|
||||||
|
Note=Notiz
|
||||||
|
Maillist name=Verteilerlistenname
|
||||||
|
Desc=Beschreibung
|
||||||
|
Players=Spieler
|
||||||
|
your maillists.=ihre Verteilerlisten.
|
||||||
|
The maillist=Die Verteilerliste
|
||||||
Mark Read=Als gelesen makieren
|
Mark Read=Als gelesen makieren
|
||||||
Mark Unread=Als ungelesen makieren
|
Mark Unread=Als ungelesen makieren
|
||||||
From=Von
|
From=Von
|
||||||
|
(No description)=(Keine Beschreibung)
|
||||||
|
No maillist=Keine Verteilerliste
|
||||||
|
CC=CC
|
||||||
Read=Lesen
|
Read=Lesen
|
||||||
Ascending=
|
Ascending=
|
||||||
Descending=
|
Descending=
|
||||||
Filter=
|
Filter=
|
||||||
|
Allow multiple selection=
|
||||||
|
selected=
|
||||||
|
(Un)select all=
|
||||||
No mail=Keine Nachrichten
|
No mail=Keine Nachrichten
|
||||||
Inbox=Posteingang
|
Inbox=Posteingang
|
||||||
Sent messages=Nachrichten senden
|
Sent messages=Nachrichten senden
|
||||||
@ -43,10 +49,7 @@ Date=Datum
|
|||||||
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
|
||||||
|
Name=Name
|
||||||
|
To=An
|
||||||
|
@ -3,33 +3,39 @@ BCC=Cci
|
|||||||
Cancel=Annuler
|
Cancel=Annuler
|
||||||
Save draft=Enregistrer le brouillon
|
Save draft=Enregistrer le brouillon
|
||||||
Send=Envoyer
|
Send=Envoyer
|
||||||
CC=Cc
|
Delete=Supprimer
|
||||||
Edit=Modifier
|
|
||||||
Note=Note
|
|
||||||
New=Nouveau
|
New=Nouveau
|
||||||
Name=Nom
|
|
||||||
No drafts=Pas de brouillons
|
No drafts=Pas de brouillons
|
||||||
|
Edit=Modifier
|
||||||
|
Subject=Objet
|
||||||
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
|
||||||
Maillist name=Nom de la liste de diffusion
|
|
||||||
Desc=Desc
|
|
||||||
Players=Joueurs
|
|
||||||
your maillists.=vos listes 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à
|
||||||
name cannot=nom ne peut pas
|
name cannot=nom ne peut pas
|
||||||
be empty.=être vide.
|
be empty.=être vide.
|
||||||
|
Back=Retour
|
||||||
|
Note=Note
|
||||||
|
Maillist name=Nom de la liste de diffusion
|
||||||
|
Desc=Desc
|
||||||
|
Players=Joueurs
|
||||||
|
your maillists.=vos listes de diffusion.
|
||||||
|
The maillist=Cette liste de diffusion
|
||||||
Mark Read=Marquer comme lu
|
Mark Read=Marquer comme lu
|
||||||
Mark Unread=Marquer non lu
|
Mark Unread=Marquer non lu
|
||||||
From=De
|
From=De
|
||||||
|
(No description)=Sans description
|
||||||
|
No maillist=Aucune liste de diffusion
|
||||||
|
CC=Cc
|
||||||
Read=Lire
|
Read=Lire
|
||||||
Ascending=Croissant
|
Ascending=Croissant
|
||||||
Descending=Décroissant
|
Descending=Décroissant
|
||||||
Filter=Filtre
|
Filter=Filtre
|
||||||
|
Allow multiple selection=Autoriser la sélection multiple
|
||||||
|
selected=sélectionnés
|
||||||
|
(Un)select all=Tout (dé)selectionner
|
||||||
No mail=Aucun mail
|
No mail=Aucun mail
|
||||||
Inbox=Boîte de réception
|
Inbox=Boîte de réception
|
||||||
Sent messages=Messages envoyés
|
Sent messages=Messages envoyés
|
||||||
@ -43,10 +49,7 @@ Date=Date
|
|||||||
Reply=Répondre
|
Reply=Répondre
|
||||||
Reply all=Répondre à tous
|
Reply all=Répondre à tous
|
||||||
Forward=Transférer
|
Forward=Transférer
|
||||||
(No description)=Sans description
|
|
||||||
No maillist=Aucune liste de diffusion
|
|
||||||
Subject=Objet
|
|
||||||
To=À
|
|
||||||
Delete=Supprimer
|
|
||||||
Add=Ajouter
|
Add=Ajouter
|
||||||
Remove=Enlever
|
Remove=Enlever
|
||||||
|
Name=Nom
|
||||||
|
To=À
|
||||||
|
@ -3,33 +3,39 @@ BCC=密件副本
|
|||||||
Cancel=取消
|
Cancel=取消
|
||||||
Save draft=儲存草稿
|
Save draft=儲存草稿
|
||||||
Send=發送
|
Send=發送
|
||||||
CC=副本
|
Delete=刪除
|
||||||
Edit=編輯
|
|
||||||
Note=備註
|
|
||||||
New=新建
|
New=新建
|
||||||
Name=名稱
|
|
||||||
No drafts=沒有草稿
|
No drafts=沒有草稿
|
||||||
|
Edit=編輯
|
||||||
|
Subject=主旨
|
||||||
Player name=玩家名稱
|
Player name=玩家名稱
|
||||||
your contacts.=
|
your contacts.=
|
||||||
The contact=
|
The contact=
|
||||||
Maillist name=郵件列表名稱
|
|
||||||
Desc=描述
|
|
||||||
Players=玩家
|
|
||||||
your maillists.=
|
|
||||||
The maillist=
|
|
||||||
Back=返回
|
|
||||||
Save=儲存
|
Save=儲存
|
||||||
That name=
|
That name=
|
||||||
is already in=
|
is already in=
|
||||||
name cannot=
|
name cannot=
|
||||||
be empty.=
|
be empty.=
|
||||||
|
Back=返回
|
||||||
|
Note=備註
|
||||||
|
Maillist name=郵件列表名稱
|
||||||
|
Desc=描述
|
||||||
|
Players=玩家
|
||||||
|
your maillists.=
|
||||||
|
The maillist=
|
||||||
Mark Read=標記已讀
|
Mark Read=標記已讀
|
||||||
Mark Unread=標記未讀
|
Mark Unread=標記未讀
|
||||||
From=寄件者
|
From=寄件者
|
||||||
|
(No description)=(沒有描述)
|
||||||
|
No maillist=沒有郵件列表
|
||||||
|
CC=副本
|
||||||
Read=閱讀
|
Read=閱讀
|
||||||
Ascending=
|
Ascending=
|
||||||
Descending=
|
Descending=
|
||||||
Filter=
|
Filter=
|
||||||
|
Allow multiple selection=
|
||||||
|
selected=
|
||||||
|
(Un)select all=
|
||||||
No mail=沒有郵件
|
No mail=沒有郵件
|
||||||
Inbox=收件箱
|
Inbox=收件箱
|
||||||
Sent messages=寄件備份
|
Sent messages=寄件備份
|
||||||
@ -43,10 +49,7 @@ Date=日期
|
|||||||
Reply=回覆
|
Reply=回覆
|
||||||
Reply all=回覆所有人
|
Reply all=回覆所有人
|
||||||
Forward=轉寄
|
Forward=轉寄
|
||||||
(No description)=(沒有描述)
|
|
||||||
No maillist=沒有郵件列表
|
|
||||||
Subject=主旨
|
|
||||||
To=收件人
|
|
||||||
Delete=刪除
|
|
||||||
Add=加入
|
Add=加入
|
||||||
Remove=移除
|
Remove=移除
|
||||||
|
Name=名稱
|
||||||
|
To=收件人
|
||||||
|
@ -3,33 +3,39 @@ BCC=
|
|||||||
Cancel=
|
Cancel=
|
||||||
Save draft=
|
Save draft=
|
||||||
Send=
|
Send=
|
||||||
CC=
|
Delete=
|
||||||
Edit=
|
|
||||||
Note=
|
|
||||||
New=
|
New=
|
||||||
Name=
|
|
||||||
No drafts=
|
No drafts=
|
||||||
|
Edit=
|
||||||
|
Subject=
|
||||||
Player name=
|
Player name=
|
||||||
your contacts.=
|
your contacts.=
|
||||||
The contact=
|
The contact=
|
||||||
Maillist name=
|
|
||||||
Desc=
|
|
||||||
Players=
|
|
||||||
your maillists.=
|
|
||||||
The maillist=
|
|
||||||
Back=
|
|
||||||
Save=
|
Save=
|
||||||
That name=
|
That name=
|
||||||
is already in=
|
is already in=
|
||||||
name cannot=
|
name cannot=
|
||||||
be empty.=
|
be empty.=
|
||||||
|
Back=
|
||||||
|
Note=
|
||||||
|
Maillist name=
|
||||||
|
Desc=
|
||||||
|
Players=
|
||||||
|
your maillists.=
|
||||||
|
The maillist=
|
||||||
Mark Read=
|
Mark Read=
|
||||||
Mark Unread=
|
Mark Unread=
|
||||||
From=
|
From=
|
||||||
|
(No description)=
|
||||||
|
No maillist=
|
||||||
|
CC=
|
||||||
Read=
|
Read=
|
||||||
Ascending=
|
Ascending=
|
||||||
Descending=
|
Descending=
|
||||||
Filter=
|
Filter=
|
||||||
|
Allow multiple selection=
|
||||||
|
selected=
|
||||||
|
(Un)select all=
|
||||||
No mail=
|
No mail=
|
||||||
Inbox=
|
Inbox=
|
||||||
Sent messages=
|
Sent messages=
|
||||||
@ -43,10 +49,7 @@ Date=
|
|||||||
Reply=
|
Reply=
|
||||||
Reply all=
|
Reply all=
|
||||||
Forward=
|
Forward=
|
||||||
(No description)=
|
|
||||||
No maillist=
|
|
||||||
Subject=
|
|
||||||
To=
|
|
||||||
Delete=
|
|
||||||
Add=
|
Add=
|
||||||
Remove=
|
Remove=
|
||||||
|
Name=
|
||||||
|
To=
|
||||||
|
@ -40,9 +40,9 @@ function mail.show_drafts(name)
|
|||||||
formspec[#formspec + 1] = S("(No subject)")
|
formspec[#formspec + 1] = S("(No subject)")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if mail.selected_idxs.sent[name] then
|
if mail.selected_idxs.drafts[name] then
|
||||||
formspec[#formspec + 1] = ";"
|
formspec[#formspec + 1] = ";"
|
||||||
formspec[#formspec + 1] = tostring(mail.selected_idxs.sent[name] + 1)
|
formspec[#formspec + 1] = tostring(mail.selected_idxs.drafts[name] + 1)
|
||||||
end
|
end
|
||||||
formspec[#formspec + 1] = "]"
|
formspec[#formspec + 1] = "]"
|
||||||
else
|
else
|
||||||
|
161
ui/events.lua
161
ui/events.lua
@ -17,15 +17,29 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
|
|
||||||
-- Get player name and handle / convert common input fields
|
-- Get player name and handle / convert common input fields
|
||||||
local name = player:get_player_name()
|
local name = player:get_player_name()
|
||||||
local filter = fields.filter or ""
|
local filter = fields.filter or mail.selected_idxs.filter[name] or ""
|
||||||
local sortfieldindex = tonumber(fields.sortfield or mail.selected_idxs.sortfield[name]) or 3
|
local sortfieldindex = tonumber(fields.sortfield or mail.selected_idxs.sortfield[name]) or 3
|
||||||
local sortdirection = fields.sortdirection or mail.selected_idxs.sortdirection[name] or "1"
|
local sortdirection = fields.sortdirection or mail.selected_idxs.sortdirection[name] or "1"
|
||||||
local inboxsortfield = ({"from","subject","time"})[sortfieldindex]
|
local inboxsortfield = ({"from","subject","time"})[sortfieldindex]
|
||||||
local outboxsortfield = ({"to","subject","time"})[sortfieldindex]
|
local outboxsortfield = ({"to","subject","time"})[sortfieldindex]
|
||||||
|
|
||||||
|
-- Be sure that inbox/outbox selected idxs aren't nil
|
||||||
|
mail.selected_idxs.inbox[name] = mail.selected_idxs.inbox[name] or {}
|
||||||
|
mail.selected_idxs.sent[name] = mail.selected_idxs.sent[name] or {}
|
||||||
|
|
||||||
-- Store common player configuration for reuse
|
-- Store common player configuration for reuse
|
||||||
mail.selected_idxs.sortfield[name] = sortfieldindex
|
mail.selected_idxs.sortfield[name] = sortfieldindex
|
||||||
mail.selected_idxs.sortdirection[name] = sortdirection
|
mail.selected_idxs.sortdirection[name] = sortdirection
|
||||||
|
mail.selected_idxs.filter[name] = filter
|
||||||
|
if fields.multipleselection then
|
||||||
|
mail.selected_idxs.multipleselection[name] = fields.multipleselection == "true"
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Avoid several selected after disabling the multiple selection
|
||||||
|
if not mail.selected_idxs.multipleselection[name] then
|
||||||
|
mail.selected_idxs.inbox[name] = { mail.selected_idxs.inbox[name][#mail.selected_idxs.inbox[name]] }
|
||||||
|
mail.selected_idxs.sent[name] = { mail.selected_idxs.sent[name][#mail.selected_idxs.sent[name]] }
|
||||||
|
end
|
||||||
|
|
||||||
-- 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)
|
||||||
@ -36,18 +50,60 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
-- Hanmdle formspec event
|
-- Hanmdle formspec event
|
||||||
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
|
if mail.selected_idxs.multipleselection[name] then
|
||||||
if evt.type == "DCL" and getInbox()[mail.selected_idxs.inbox[name]] then
|
if not mail.selected_idxs.inbox[name] then
|
||||||
mail.show_message(name, getInbox()[mail.selected_idxs.inbox[name]].id)
|
mail.selected_idxs.inbox[name] = {}
|
||||||
|
end
|
||||||
|
local selected_id = 0
|
||||||
|
if mail.selected_idxs.inbox[name] and #mail.selected_idxs.inbox[name] > 0 then
|
||||||
|
for i, selected_msg in ipairs(mail.selected_idxs.inbox[name]) do
|
||||||
|
if getInbox()[evt.row-1].id == selected_msg then
|
||||||
|
selected_id = i
|
||||||
|
table.remove(mail.selected_idxs.inbox[name], i)
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if selected_id == 0 then
|
||||||
|
table.insert(mail.selected_idxs.inbox[name], getInbox()[evt.row-1].id)
|
||||||
|
end
|
||||||
|
else
|
||||||
|
mail.selected_idxs.inbox[name] = { getInbox()[evt.row-1].id }
|
||||||
|
end
|
||||||
|
if evt.type == "DCL" and getInbox()[evt.row-1] then
|
||||||
|
mail.show_message(name, getInbox()[evt.row-1].id)
|
||||||
|
else
|
||||||
|
mail.show_mail_menu(name)
|
||||||
end
|
end
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
if fields.sent then -- sent table
|
if fields.sent then -- sent table
|
||||||
local evt = minetest.explode_table_event(fields.sent)
|
local evt = minetest.explode_table_event(fields.sent)
|
||||||
mail.selected_idxs.sent[name] = evt.row - 1
|
if mail.selected_idxs.multipleselection[name] then
|
||||||
if evt.type == "DCL" and getOutbox()[mail.selected_idxs.sent[name]] then
|
if not mail.selected_idxs.sent[name] then
|
||||||
mail.show_message(name, getOutbox()[mail.selected_idxs.sent[name]].id)
|
mail.selected_idxs.sent[name] = {}
|
||||||
|
end
|
||||||
|
local selected_id = 0
|
||||||
|
if mail.selected_idxs.sent[name] and #mail.selected_idxs.sent[name] > 0 then
|
||||||
|
for i, selected_msg in ipairs(mail.selected_idxs.sent[name]) do
|
||||||
|
if getOutbox()[evt.row-1].id == selected_msg then
|
||||||
|
selected_id = i
|
||||||
|
table.remove(mail.selected_idxs.sent[name], i)
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if selected_id == 0 then
|
||||||
|
table.insert(mail.selected_idxs.sent[name], getOutbox()[evt.row-1].id)
|
||||||
|
end
|
||||||
|
else
|
||||||
|
mail.selected_idxs.sent[name] = { getOutbox()[evt.row-1].id }
|
||||||
|
end
|
||||||
|
if evt.type == "DCL" and getOutbox()[evt.row-1] then
|
||||||
|
mail.show_message(name, getOutbox()[evt.row-1].id)
|
||||||
|
else
|
||||||
|
mail.show_mail_menu(name)
|
||||||
end
|
end
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
@ -81,10 +137,10 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
mail.show_drafts(name)
|
mail.show_drafts(name)
|
||||||
|
|
||||||
elseif fields.read then
|
elseif fields.read then
|
||||||
if formname == "mail:inbox" and getInbox()[mail.selected_idxs.inbox[name]] then -- inbox table
|
if formname == "mail:inbox" and mail.selected_idxs.inbox[name] then -- inbox table
|
||||||
mail.show_message(name, getInbox()[mail.selected_idxs.inbox[name]].id)
|
mail.show_message(name, mail.selected_idxs.inbox[name][#mail.selected_idxs.inbox[name]])
|
||||||
elseif formname == "mail:sent" and getOutbox()[mail.selected_idxs.sent[name]] then -- sent table
|
elseif formname == "mail:sent" and mail.selected_idxs.sent[name] then -- sent table
|
||||||
mail.show_message(name, getOutbox()[mail.selected_idxs.sent[name]].id)
|
mail.show_message(name, mail.selected_idxs.inbox[name][#mail.selected_idxs.inbox[name]])
|
||||||
end
|
end
|
||||||
|
|
||||||
elseif fields.edit then
|
elseif fields.edit then
|
||||||
@ -100,10 +156,14 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
end
|
end
|
||||||
|
|
||||||
elseif fields.delete then
|
elseif fields.delete then
|
||||||
if formname == "mail:inbox" and getInbox()[mail.selected_idxs.inbox[name]] then -- inbox table
|
if formname == "mail:inbox" and mail.selected_idxs.inbox[name] then -- inbox table
|
||||||
mail.delete_mail(name, getInbox()[mail.selected_idxs.inbox[name]].id)
|
for _, msg_id in ipairs(mail.selected_idxs.inbox[name]) do
|
||||||
elseif formname == "mail:sent" and getOutbox()[mail.selected_idxs.sent[name]] then -- sent table
|
mail.delete_mail(name, msg_id)
|
||||||
mail.delete_mail(name, getOutbox()[mail.selected_idxs.sent[name]].id)
|
end
|
||||||
|
elseif formname == "mail:sent" and mail.selected_idxs.sent[name] then -- sent table
|
||||||
|
for _, msg_id in ipairs(mail.selected_idxs.sent[name]) do
|
||||||
|
mail.delete_mail(name, msg_id)
|
||||||
|
end
|
||||||
elseif formname == "mail:drafts" and messagesDrafts[mail.selected_idxs.drafts[name]] then -- drafts table
|
elseif formname == "mail:drafts" and messagesDrafts[mail.selected_idxs.drafts[name]] then -- drafts table
|
||||||
mail.delete_mail(name, messagesDrafts[mail.selected_idxs.drafts[name]].id)
|
mail.delete_mail(name, messagesDrafts[mail.selected_idxs.drafts[name]].id)
|
||||||
end
|
end
|
||||||
@ -111,46 +171,46 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
mail.show_mail_menu(name, sortfieldindex, sortdirection, filter)
|
mail.show_mail_menu(name, sortfieldindex, sortdirection, filter)
|
||||||
|
|
||||||
elseif fields.reply then
|
elseif fields.reply then
|
||||||
if formname == "mail:inbox" and getInbox()[mail.selected_idxs.inbox[name]] then
|
if formname == "mail:inbox" and mail.selected_idxs.inbox[name] then
|
||||||
local message = getInbox()[mail.selected_idxs.inbox[name]]
|
local message = mail.get_message(name, mail.selected_idxs.inbox[name][#mail.selected_idxs.inbox[name]])
|
||||||
mail.reply(name, message)
|
mail.reply(name, message)
|
||||||
elseif formname == "mail:sent" and getOutbox()[mail.selected_idxs.sent[name]] then
|
elseif formname == "mail:sent" and mail.selected_idxs.sent[name] then
|
||||||
local message = getOutbox()[mail.selected_idxs.sent[name]]
|
local message = mail.get_message(name, mail.selected_idxs.sent[name][#mail.selected_idxs.sent[name]])
|
||||||
mail.reply(name, message)
|
mail.reply(name, message)
|
||||||
end
|
end
|
||||||
|
|
||||||
elseif fields.replyall then
|
elseif fields.replyall then
|
||||||
if formname == "mail:inbox" and getInbox()[mail.selected_idxs.inbox[name]] then
|
if formname == "mail:inbox" and mail.selected_idxs.inbox[name] then
|
||||||
local message = getInbox()[mail.selected_idxs.inbox[name]]
|
local message = mail.get_message(name, mail.selected_idxs.inbox[name][#mail.selected_idxs.inbox[name]])
|
||||||
mail.replyall(name, message)
|
mail.replyall(name, message)
|
||||||
elseif formname == "mail:sent" and getOutbox()[mail.selected_idxs.sent[name]] then
|
elseif formname == "mail:sent" and mail.selected_idxs.sent[name] then
|
||||||
local message = getOutbox()[mail.selected_idxs.sent[name]]
|
local message = mail.get_message(name, mail.selected_idxs.sent[name][#mail.selected_idxs.sent[name]])
|
||||||
mail.replyall(name, message)
|
mail.replyall(name, message)
|
||||||
end
|
end
|
||||||
|
|
||||||
elseif fields.forward then
|
elseif fields.forward then
|
||||||
if formname == "mail:inbox" and getInbox()[mail.selected_idxs.inbox[name]] then
|
if formname == "mail:inbox" and mail.selected_idxs.inbox[name] then
|
||||||
local message = getInbox()[mail.selected_idxs.inbox[name]]
|
local message = mail.get_message(name, mail.selected_idxs.inbox[name][#mail.selected_idxs.inbox[name]])
|
||||||
mail.forward(name, message)
|
mail.forward(name, message)
|
||||||
elseif formname == "mail:sent" and getOutbox()[mail.selected_idxs.sent[name]] then
|
elseif formname == "mail:sent" and mail.selected_idxs.sent[name] then
|
||||||
local message = getOutbox()[mail.selected_idxs.sent[name]]
|
local message = mail.get_message(name, mail.selected_idxs.sent[name][#mail.selected_idxs.sent[name]])
|
||||||
mail.forward(name, message)
|
mail.forward(name, message)
|
||||||
end
|
end
|
||||||
|
|
||||||
elseif fields.markread then
|
elseif fields.markread then
|
||||||
if formname == "mail:inbox" and getInbox()[mail.selected_idxs.inbox[name]] then
|
if formname == "mail:inbox" and mail.selected_idxs.inbox[name] then
|
||||||
mail.mark_read(name, getInbox()[mail.selected_idxs.inbox[name]].id)
|
for _, msg_id in ipairs(mail.selected_idxs.inbox[name]) do
|
||||||
elseif formname == "mail:sent" and getOutbox()[mail.selected_idxs.sent[name]] then
|
mail.mark_read(name, msg_id)
|
||||||
mail.mark_read(name, getOutbox()[mail.selected_idxs.sent[name]].id)
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
mail.show_mail_menu(name, sortfieldindex, sortdirection, filter)
|
mail.show_mail_menu(name, sortfieldindex, sortdirection, filter)
|
||||||
|
|
||||||
elseif fields.markunread then
|
elseif fields.markunread then
|
||||||
if formname == "mail:inbox" and getInbox()[mail.selected_idxs.inbox[name]] then
|
if formname == "mail:inbox" and mail.selected_idxs.inbox[name] then
|
||||||
mail.mark_unread(name, getInbox()[mail.selected_idxs.inbox[name]].id)
|
for _, msg_id in ipairs(mail.selected_idxs.inbox[name]) do
|
||||||
elseif formname == "mail:sent" and getOutbox()[mail.selected_idxs.sent[name]] then
|
mail.mark_unread(name, msg_id)
|
||||||
mail.mark_unread(name, getOutbox()[mail.selected_idxs.sent[name]].id)
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
mail.show_mail_menu(name, sortfieldindex, sortdirection, filter)
|
mail.show_mail_menu(name, sortfieldindex, sortdirection, filter)
|
||||||
@ -167,6 +227,37 @@ 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.selectall then
|
||||||
|
if formname == "mail:inbox" then
|
||||||
|
if not mail.selected_idxs.inbox[name] then
|
||||||
|
mail.selected_idxs.inbox[name] = {}
|
||||||
|
end
|
||||||
|
if #mail.selected_idxs.inbox[name] >= #getInbox() then -- if selection is full
|
||||||
|
mail.selected_idxs.inbox[name] = {}
|
||||||
|
else
|
||||||
|
mail.selected_idxs.inbox[name] = {} -- reset to avoid duplicates
|
||||||
|
mail.selected_idxs.multipleselection[name] = true
|
||||||
|
for _, msg in ipairs(getInbox()) do
|
||||||
|
table.insert(mail.selected_idxs.inbox[name], msg.id)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
elseif formname == "mail:sent" then
|
||||||
|
if not mail.selected_idxs.sent[name] then
|
||||||
|
mail.selected_idxs.sent[name] = {}
|
||||||
|
end
|
||||||
|
if #mail.selected_idxs.sent[name] >= #getOutbox() then -- if selection is full
|
||||||
|
mail.selected_idxs.sent[name] = {}
|
||||||
|
else
|
||||||
|
mail.selected_idxs.inbox[name] = {} -- reset to avoid duplicates
|
||||||
|
mail.selected_idxs.multipleselection[name] = true
|
||||||
|
for _, msg in ipairs(getOutbox()) do
|
||||||
|
table.insert(mail.selected_idxs.sent[name], msg.id)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
mail.show_mail_menu(name)
|
||||||
|
|
||||||
elseif fields.sortfield or fields.sortdirection or fields.filter then
|
elseif fields.sortfield or fields.sortdirection or fields.filter then
|
||||||
mail.show_mail_menu(name, sortfieldindex, sortdirection, filter)
|
mail.show_mail_menu(name, sortfieldindex, sortdirection, filter)
|
||||||
end
|
end
|
||||||
|
62
ui/inbox.lua
62
ui/inbox.lua
@ -5,7 +5,8 @@ local S = minetest.get_translator("mail")
|
|||||||
function mail.show_inbox(name, sortfieldindex, sortdirection, filter)
|
function mail.show_inbox(name, sortfieldindex, sortdirection, filter)
|
||||||
sortfieldindex = tonumber(sortfieldindex or mail.selected_idxs.sortfield[name]) or 3
|
sortfieldindex = tonumber(sortfieldindex or mail.selected_idxs.sortfield[name]) or 3
|
||||||
sortdirection = sortdirection or mail.selected_idxs.sortdirection[name] or "1"
|
sortdirection = sortdirection or mail.selected_idxs.sortdirection[name] or "1"
|
||||||
filter = filter or ""
|
filter = filter or mail.selected_idxs.filter[name] or ""
|
||||||
|
mail.selected_idxs.inbox[name] = mail.selected_idxs.inbox[name] or {}
|
||||||
|
|
||||||
local inbox_formspec = "size[8.5,10;]" .. mail.theme .. [[
|
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]
|
||||||
@ -23,15 +24,20 @@ function mail.show_inbox(name, sortfieldindex, sortdirection, filter)
|
|||||||
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;]] ..
|
dropdown[0,8.4;2,0.5;sortfield;]] ..
|
||||||
S("From") .. "," .. S("Subject") .. "," .. S("Date") .. [[;]] .. sortfieldindex .. [[;true]
|
S("From") .. "," .. S("Subject") .. "," .. S("Date") .. [[;]] .. sortfieldindex .. [[;true]
|
||||||
dropdown[2.0,9.4;2,0.5;sortdirection;]] ..
|
dropdown[2.0,8.4;2,0.5;sortdirection;]] ..
|
||||||
S("Ascending") .. "," .. S("Descending") .. [[;]] .. sortdirection .. [[;true]
|
S("Ascending") .. "," .. S("Descending") .. [[;]] .. sortdirection .. [[;true]
|
||||||
field[4.25,9.85;1.4,0.5;filter;]] .. S("Filter") .. [[:;]] .. filter .. [[]
|
field[4.25,8.85;1.4,0.5;filter;]] .. S("Filter") .. [[:;]] .. filter .. [[]
|
||||||
button[5.14,9.52;0.85,0.5;search;Q]
|
button[5.14,8.52;0.85,0.5;search;Q]
|
||||||
|
|
||||||
|
checkbox[0,9.1;multipleselection;]] .. S("Allow multiple selection") .. [[;]] ..
|
||||||
|
tostring(mail.selected_idxs.multipleselection[name]) .. [[]
|
||||||
|
label[0,9.65;]] .. tostring(#mail.selected_idxs.inbox[name]) .. " " .. S("selected") .. [[]
|
||||||
|
button[3.5,9.5;2.5,0.5;selectall;]] .. S("(Un)select all") .. [[]
|
||||||
|
|
||||||
tablecolumns[color;text;text]
|
tablecolumns[color;text;text]
|
||||||
table[0,0.7;5.75,8.35;inbox;#999,]] .. S("From") .. "," .. S("Subject")
|
table[0,0.7;5.75,7.35;inbox;#999,]] .. S("From") .. "," .. S("Subject")
|
||||||
local formspec = { inbox_formspec }
|
local formspec = { inbox_formspec }
|
||||||
local entry = mail.get_storage_entry(name)
|
local entry = mail.get_storage_entry(name)
|
||||||
local sortfield = ({"from","subject","time"})[sortfieldindex]
|
local sortfield = ({"from","subject","time"})[sortfieldindex]
|
||||||
@ -41,17 +47,43 @@ function mail.show_inbox(name, sortfieldindex, sortdirection, filter)
|
|||||||
|
|
||||||
if #messages > 0 then
|
if #messages > 0 then
|
||||||
for _, message in ipairs(messages) do
|
for _, message in ipairs(messages) do
|
||||||
if not message.read then
|
local selected_id = 0
|
||||||
if not mail.player_in_list(name, message.to) then
|
-- check if message is in selection list and return its id
|
||||||
formspec[#formspec + 1] = ",#FFD788"
|
if mail.selected_idxs.inbox[name] and #mail.selected_idxs.inbox[name] > 0 then
|
||||||
|
for i, selected_msg in ipairs(mail.selected_idxs.inbox[name]) do
|
||||||
|
if message.id == selected_msg then
|
||||||
|
selected_id = i
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if selected_id > 0 then
|
||||||
|
if not message.read then
|
||||||
|
if not mail.player_in_list(name, message.to) then
|
||||||
|
formspec[#formspec + 1] = ",#A39E5D"
|
||||||
|
else
|
||||||
|
formspec[#formspec + 1] = ",#A39E19"
|
||||||
|
end
|
||||||
else
|
else
|
||||||
formspec[#formspec + 1] = ",#FFD700"
|
if not mail.player_in_list(name, message.to) then
|
||||||
|
formspec[#formspec + 1] = ",#899888"
|
||||||
|
else
|
||||||
|
formspec[#formspec + 1] = ",#466432"
|
||||||
|
end
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if not mail.player_in_list(name, message.to) then
|
if not message.read then
|
||||||
formspec[#formspec + 1] = ",#CCCCDD"
|
if not mail.player_in_list(name, message.to) then
|
||||||
|
formspec[#formspec + 1] = ",#FFD788"
|
||||||
|
else
|
||||||
|
formspec[#formspec + 1] = ",#FFD700"
|
||||||
|
end
|
||||||
else
|
else
|
||||||
formspec[#formspec + 1] = ","
|
if not mail.player_in_list(name, message.to) then
|
||||||
|
formspec[#formspec + 1] = ",#CCCCDD"
|
||||||
|
else
|
||||||
|
formspec[#formspec + 1] = ","
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
formspec[#formspec + 1] = ","
|
formspec[#formspec + 1] = ","
|
||||||
@ -68,10 +100,6 @@ function mail.show_inbox(name, sortfieldindex, sortdirection, filter)
|
|||||||
formspec[#formspec + 1] = S("(No subject)")
|
formspec[#formspec + 1] = S("(No subject)")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if mail.selected_idxs.inbox[name] then
|
|
||||||
formspec[#formspec + 1] = ";"
|
|
||||||
formspec[#formspec + 1] = tostring(mail.selected_idxs.inbox[name] + 1)
|
|
||||||
end
|
|
||||||
formspec[#formspec + 1] = "]"
|
formspec[#formspec + 1] = "]"
|
||||||
else
|
else
|
||||||
formspec[#formspec + 1] = "]label[2.25,4.5;" .. S("No mail") .. "]"
|
formspec[#formspec + 1] = "]label[2.25,4.5;" .. S("No mail") .. "]"
|
||||||
|
@ -90,10 +90,6 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local name = player:get_player_name()
|
local name = player:get_player_name()
|
||||||
local entry = mail.get_storage_entry(name)
|
|
||||||
|
|
||||||
local messagesInbox = entry.inbox
|
|
||||||
local messagesSent = entry.outbox
|
|
||||||
|
|
||||||
if fields.back then
|
if fields.back then
|
||||||
mail.show_mail_menu(name)
|
mail.show_mail_menu(name)
|
||||||
@ -101,36 +97,36 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
|
|
||||||
elseif fields.reply then
|
elseif fields.reply then
|
||||||
local message = ""
|
local message = ""
|
||||||
if messagesInbox[mail.selected_idxs.inbox[name]] then
|
if mail.selected_idxs.inbox[name] then
|
||||||
message = messagesInbox[mail.selected_idxs.inbox[name]]
|
message = mail.get_message(name, mail.selected_idxs.inbox[name][#mail.selected_idxs.inbox[name]])
|
||||||
elseif messagesSent[mail.selected_idxs.sent[name]] then
|
elseif mail.selected_idxs.sent[name] then
|
||||||
message = messagesSent[mail.selected_idxs.sent[name]]
|
message = mail.get_message(name, mail.selected_idxs.sent[name][#mail.selected_idxs.sent[name]])
|
||||||
end
|
end
|
||||||
mail.reply(name, message)
|
mail.reply(name, message)
|
||||||
|
|
||||||
elseif fields.replyall then
|
elseif fields.replyall then
|
||||||
local message = ""
|
local message = ""
|
||||||
if messagesInbox[mail.selected_idxs.inbox[name]] then
|
if mail.selected_idxs.inbox[name] then
|
||||||
message = messagesInbox[mail.selected_idxs.inbox[name]]
|
message = mail.get_message(name, mail.selected_idxs.inbox[name][#mail.selected_idxs.inbox[name]])
|
||||||
elseif messagesSent[mail.selected_idxs.sent[name]] then
|
elseif mail.selected_idxs.sent[name] then
|
||||||
message = messagesSent[mail.selected_idxs.sent[name]]
|
message = mail.get_message(name, mail.selected_idxs.sent[name][#mail.selected_idxs.sent[name]])
|
||||||
end
|
end
|
||||||
mail.replyall(name, message)
|
mail.replyall(name, message)
|
||||||
|
|
||||||
elseif fields.forward then
|
elseif fields.forward then
|
||||||
local message = ""
|
local message = ""
|
||||||
if messagesInbox[mail.selected_idxs.inbox[name]] then
|
if mail.selected_idxs.inbox[name] then
|
||||||
message = messagesInbox[mail.selected_idxs.inbox[name]]
|
message = mail.get_message(name, mail.selected_idxs.inbox[name][#mail.selected_idxs.inbox[name]])
|
||||||
elseif messagesSent[mail.selected_idxs.sent[name]] then
|
elseif mail.selected_idxs.sent[name] then
|
||||||
message = messagesSent[mail.selected_idxs.sent[name]]
|
message = mail.get_message(name, mail.selected_idxs.sent[name][#mail.selected_idxs.sent[name]])
|
||||||
end
|
end
|
||||||
mail.forward(name, message)
|
mail.forward(name, message)
|
||||||
|
|
||||||
elseif fields.delete then
|
elseif fields.delete then
|
||||||
if messagesInbox[mail.selected_idxs.inbox[name]] then
|
if mail.selected_idxs.inbox[name] then
|
||||||
mail.delete_mail(name, messagesInbox[mail.selected_idxs.inbox[name]].id)
|
mail.delete_mail(name, mail.selected_idxs.inbox[name][#mail.selected_idxs.inbox[name]])
|
||||||
elseif messagesSent[mail.selected_idxs.sent[name]] then
|
elseif mail.selected_idxs.sent[name] then
|
||||||
mail.delete_mail(name, messagesSent[mail.selected_idxs.sent[name]].id)
|
mail.delete_mail(name, mail.selected_idxs.sent[name][#mail.selected_idxs.sent[name]])
|
||||||
end
|
end
|
||||||
mail.show_mail_menu(name)
|
mail.show_mail_menu(name)
|
||||||
end
|
end
|
||||||
|
@ -5,7 +5,8 @@ local S = minetest.get_translator("mail")
|
|||||||
function mail.show_sent(name, sortfieldindex, sortdirection, filter)
|
function mail.show_sent(name, sortfieldindex, sortdirection, filter)
|
||||||
sortfieldindex = tonumber(sortfieldindex or mail.selected_idxs.sortfield[name]) or 3
|
sortfieldindex = tonumber(sortfieldindex or mail.selected_idxs.sortfield[name]) or 3
|
||||||
sortdirection = sortdirection or mail.selected_idxs.sortdirection[name] or "1"
|
sortdirection = sortdirection or mail.selected_idxs.sortdirection[name] or "1"
|
||||||
filter = filter or ""
|
filter = filter or mail.selected_idxs.filter[name] or ""
|
||||||
|
mail.selected_idxs.sent[name] = mail.selected_idxs.sent[name] or {}
|
||||||
|
|
||||||
local sent_formspec = "size[8.5,10;]" .. mail.theme .. [[
|
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]
|
||||||
@ -21,15 +22,20 @@ function mail.show_sent(name, sortfieldindex, sortdirection, filter)
|
|||||||
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;]]
|
dropdown[0,8.4;2,0.5;sortfield;]] ..
|
||||||
.. S("To") .. "," .. S("Subject") .. "," .. S("Date") .. [[;]] .. sortfieldindex .. [[;1]
|
S("To") .. "," .. S("Subject") .. "," .. S("Date") .. [[;]] .. sortfieldindex .. [[;true]
|
||||||
dropdown[2.0,9.4;2,0.5;sortdirection;]]
|
dropdown[2.0,8.4;2,0.5;sortdirection;]] ..
|
||||||
.. S("Ascending") .. "," .. S("Descending") .. [[;]] .. sortdirection .. [[;1]
|
S("Ascending") .. "," .. S("Descending") .. [[;]] .. sortdirection .. [[;true]
|
||||||
field[4.25,9.85;1.4,0.5;filter;]].. S("Filter") .. [[:;]] .. filter .. [[]
|
field[4.25,8.85;1.4,0.5;filter;]] .. S("Filter") .. [[:;]] .. filter .. [[]
|
||||||
button[5.14,9.52;0.85,0.5;search;Q]
|
button[5.14,8.52;0.85,0.5;search;Q]
|
||||||
|
|
||||||
|
checkbox[0,9.1;multipleselection;]] .. S("Allow multiple selection") .. [[;]] ..
|
||||||
|
tostring(mail.selected_idxs.multipleselection[name]) .. [[]
|
||||||
|
label[0,9.65;]] .. tostring(#mail.selected_idxs.sent[name]) .. " " .. S("selected") .. [[]
|
||||||
|
button[3.5,9.5;2.5,0.5;selectall;]] .. S("(Un)select all") .. [[]
|
||||||
|
|
||||||
tablecolumns[color;text;text]
|
tablecolumns[color;text;text]
|
||||||
table[0,0.7;5.75,8.35;sent;#999,]] .. S("To") .. "," .. S("Subject")
|
table[0,0.7;5.75,7.35;sent;#999,]] .. S("To") .. "," .. S("Subject")
|
||||||
local formspec = { sent_formspec }
|
local formspec = { sent_formspec }
|
||||||
local entry = mail.get_storage_entry(name)
|
local entry = mail.get_storage_entry(name)
|
||||||
local sortfield = ({"to","subject","time"})[sortfieldindex]
|
local sortfield = ({"to","subject","time"})[sortfieldindex]
|
||||||
@ -39,7 +45,21 @@ function mail.show_sent(name, sortfieldindex, sortdirection, filter)
|
|||||||
|
|
||||||
if #messages > 0 then
|
if #messages > 0 then
|
||||||
for _, message in ipairs(messages) do
|
for _, message in ipairs(messages) do
|
||||||
formspec[#formspec + 1] = ","
|
local selected_id = 0
|
||||||
|
-- check if message is in selection list and return its id
|
||||||
|
if mail.selected_idxs.sent[name] and #mail.selected_idxs.sent[name] > 0 then
|
||||||
|
for i, selected_msg in ipairs(mail.selected_idxs.sent[name]) do
|
||||||
|
if message.id == selected_msg then
|
||||||
|
selected_id = i
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if selected_id > 0 then
|
||||||
|
formspec[#formspec + 1] = ",#466432"
|
||||||
|
else
|
||||||
|
formspec[#formspec + 1] = ","
|
||||||
|
end
|
||||||
formspec[#formspec + 1] = ","
|
formspec[#formspec + 1] = ","
|
||||||
formspec[#formspec + 1] = minetest.formspec_escape(message.to)
|
formspec[#formspec + 1] = minetest.formspec_escape(message.to)
|
||||||
formspec[#formspec + 1] = ","
|
formspec[#formspec + 1] = ","
|
||||||
@ -54,10 +74,6 @@ function mail.show_sent(name, sortfieldindex, sortdirection, filter)
|
|||||||
formspec[#formspec + 1] = S("(No subject)")
|
formspec[#formspec + 1] = S("(No subject)")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if mail.selected_idxs.sent[name] then
|
|
||||||
formspec[#formspec + 1] = ";"
|
|
||||||
formspec[#formspec + 1] = tostring(mail.selected_idxs.sent[name] + 1)
|
|
||||||
end
|
|
||||||
formspec[#formspec + 1] = "]"
|
formspec[#formspec + 1] = "]"
|
||||||
else
|
else
|
||||||
formspec[#formspec + 1] = "]label[2.25,4.5;" .. S("No mail") .. "]"
|
formspec[#formspec + 1] = "]label[2.25,4.5;" .. S("No mail") .. "]"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user