Update app widgets samples and community scripts
This commit is contained in:
@@ -8,6 +8,8 @@
|
||||
local prefs = require "prefs"
|
||||
local fmt = require "fmt"
|
||||
|
||||
local widget = "com.todoist/com.todoist.appwidget.provider.ItemListAppWidgetProvider"
|
||||
|
||||
local curr_tab = {}
|
||||
local w_bridge = nil
|
||||
local colors = {}
|
||||
@@ -22,30 +24,23 @@ end
|
||||
function on_app_widget_updated(bridge)
|
||||
w_bridge = bridge
|
||||
colors = bridge:dump_colors()
|
||||
curr_tab = parse(bridge:dump_table())
|
||||
curr_tab = bridge:dump_table()
|
||||
curr_tab = parse(curr_tab)
|
||||
ui:show_lines(curr_tab.lines)
|
||||
end
|
||||
|
||||
function parse(t)
|
||||
local tab = {}
|
||||
tab["list"] = t.v_layout_1.frame_layout_1.relative_layout_1.text_1
|
||||
local footer = t.v_layout_1.frame_layout_2
|
||||
for k,v in pairs(footer) do
|
||||
if k:sub(1,8) == "relative" then
|
||||
footer = v
|
||||
break
|
||||
end
|
||||
end
|
||||
local images = {}
|
||||
local texts = {}
|
||||
local lines = {}
|
||||
local clicks = {}
|
||||
local tasks = t.v_layout_1.frame_layout_2.list_layout_1
|
||||
if tasks == nil then tasks = {} end
|
||||
if not tasks then tasks = {} end
|
||||
local tkeys = {}
|
||||
for k,v in pairs(tasks) do
|
||||
table.insert(tkeys,k)
|
||||
end
|
||||
table.sort(tkeys)
|
||||
table.sort(tkeys,function (a,b) return tonumber(a:match("%d+")) < tonumber(b:match("%d+")) end)
|
||||
for i1,v1 in ipairs(tkeys) do
|
||||
for k2,v2 in pairs(tasks[v1]) do
|
||||
for k3,v3 in pairs(v2) do
|
||||
@@ -56,14 +51,14 @@ function parse(t)
|
||||
local subtexts = {}
|
||||
for k4,v4 in pairs(v3) do
|
||||
if k4:sub(1,4) == "text" then
|
||||
table.insert(texts,v4)
|
||||
table.insert(clicks,k4)
|
||||
text = v4
|
||||
local color = colors[images[#texts]]
|
||||
local color = colors[images[#images]]
|
||||
if color ~= "#909090" and color then
|
||||
text = fmt.colored(fmt.bold(text),color)
|
||||
end
|
||||
elseif k4:sub(1,8) == "h_layout" then
|
||||
subtexts = recursion(v4,subtexts,#subtexts,false)
|
||||
subtexts = recursion(v4,subtexts,1,false)
|
||||
end
|
||||
end
|
||||
table.insert(lines,text..table.concat(subtexts))
|
||||
@@ -71,19 +66,30 @@ function parse(t)
|
||||
end
|
||||
end
|
||||
end
|
||||
local footer = t.v_layout_1.frame_layout_2
|
||||
for k,v in pairs(footer) do
|
||||
if k:sub(1,8) == "relative" then
|
||||
footer = v
|
||||
break
|
||||
end
|
||||
end
|
||||
for k1,v1 in pairs(footer) do
|
||||
for k2,v2 in pairs(v1) do
|
||||
if k2:sub(1,4) == "text" then
|
||||
table.insert(images,k2)
|
||||
table.insert(texts,v2)
|
||||
table.insert(lines,fmt.secondary("Add task"))
|
||||
table.insert(clicks,k2)
|
||||
local add_task = "Add task"
|
||||
if #lines ~= 0 then
|
||||
add_task = fmt.secondary(add_task)
|
||||
end
|
||||
table.insert(lines,add_task)
|
||||
break
|
||||
end
|
||||
end
|
||||
end
|
||||
tab["images"] = images
|
||||
tab["texts"] = texts
|
||||
tab["lines"] = lines
|
||||
tab["clicks"] = clicks
|
||||
return tab
|
||||
end
|
||||
|
||||
@@ -95,25 +101,25 @@ function recursion(t,tab,idx,flag)
|
||||
table.insert(tab,idx,fmt.secondary(" - ") .. fmt.colored(v,colors[k]))
|
||||
end
|
||||
elseif k:sub(1,8) == "h_layout" then
|
||||
tab = recursion(v,tab,1,true)
|
||||
tab = recursion(v,tab,#tab+1,true)
|
||||
end
|
||||
end
|
||||
return tab
|
||||
end
|
||||
|
||||
function on_click(idx)
|
||||
w_bridge:click(curr_tab.texts[idx])
|
||||
w_bridge:click(curr_tab.clicks[idx])
|
||||
end
|
||||
|
||||
function setup_app_widget()
|
||||
local id = widgets:setup("com.todoist/com.todoist.appwidget.provider.ItemListAppWidgetProvider")
|
||||
local id = widgets:setup(widget)
|
||||
if (id ~= nil) then
|
||||
prefs.wid = id
|
||||
else
|
||||
ui:show_text("Can't add widget")
|
||||
ui:show_toast("Can't add widget")
|
||||
end
|
||||
end
|
||||
|
||||
function on_settings()
|
||||
w_bridge:click(curr_tab.list)
|
||||
w_bridge:click("text_1")
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user