mirror of
https://cheapiesystems.com/git/digistuff
synced 2024-11-28 10:03:49 +01:00
Add textlist command to touchscreen
This commit is contained in:
parent
0ffc118f4c
commit
0e61a770c9
@ -37,6 +37,15 @@ digistuff.update_ts_formspec = function (pos)
|
|||||||
end
|
end
|
||||||
choices = string.sub(choices,1,-2)
|
choices = string.sub(choices,1,-2)
|
||||||
fs = fs..string.format("dropdown[%s,%s;%s,%s;%s;%s;%s]",field.X,field.Y,field.W,field.H,field.name,choices,field.selected_id)
|
fs = fs..string.format("dropdown[%s,%s;%s,%s;%s;%s;%s]",field.X,field.Y,field.W,field.H,field.name,choices,field.selected_id)
|
||||||
|
elseif field.type == "textlist" then
|
||||||
|
local listelements = ""
|
||||||
|
for _,i in ipairs(field.listelements) do
|
||||||
|
if type(i) == "string" then
|
||||||
|
listelements = listelements..minetest.formspec_escape(i)..","
|
||||||
|
end
|
||||||
|
end
|
||||||
|
listelements = string.sub(listelements,1,-2)
|
||||||
|
fs = fs..string.format("textlist[%s,%s;%s,%s;%s;%s;%s;%s]",field.X,field.Y,field.W,field.H,field.name,listelements,field.selected_id,field.transparent)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -209,6 +218,23 @@ digistuff.process_command = function (meta, data, msg)
|
|||||||
end
|
end
|
||||||
local field = {type="dropdown",X=msg.X,Y=msg.Y,W=msg.W,H=msg.H,name=msg.name,selected_id=msg.selected_id,choices=msg.choices}
|
local field = {type="dropdown",X=msg.X,Y=msg.Y,W=msg.W,H=msg.H,name=msg.name,selected_id=msg.selected_id,choices=msg.choices}
|
||||||
table.insert(data,field)
|
table.insert(data,field)
|
||||||
|
elseif msg.command == "addtextlist" then
|
||||||
|
for _,i in pairs({"X","Y","W","H","selected_id"}) do
|
||||||
|
if not msg[i] or type(msg[i]) ~= "number" then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if not msg.name or type(msg.name) ~= "string" then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if not msg.listelements or type(msg.listelements) ~= "table" or #msg.listelements < 1 then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if not msg.transparent or type(msg.transparent) ~= "boolean" then
|
||||||
|
msg.transparent = false
|
||||||
|
end
|
||||||
|
local field = {type="textlist",X=msg.X,Y=msg.Y,W=msg.W,H=msg.H,name=msg.name,selected_id=msg.selected_id,listelements=msg.listelements,transparent=msg.transparent}
|
||||||
|
table.insert(data,field)
|
||||||
elseif msg.command == "lock" then
|
elseif msg.command == "lock" then
|
||||||
meta:set_int("locked",1)
|
meta:set_int("locked",1)
|
||||||
elseif msg.command == "unlock" then
|
elseif msg.command == "unlock" then
|
||||||
|
Loading…
Reference in New Issue
Block a user