1
0
mirror of https://github.com/kepler155c/opus synced 2025-01-24 06:06:54 +00:00

transition refactor + inactive elements

This commit is contained in:
kepler155c@gmail.com 2017-10-07 00:27:41 -04:00
parent 91a05c07dd
commit af981dd1f8
6 changed files with 201 additions and 213 deletions

View File

@ -1,7 +1,7 @@
local Canvas = require('ui.canvas') local Canvas = require('ui.canvas')
local class = require('class') local class = require('class')
local Event = require('event') local Event = require('event')
local Tween = require('ui.tween') local Transition = require('ui.transition')
local Util = require('util') local Util = require('util')
local _rep = string.rep local _rep = string.rep
@ -34,16 +34,15 @@ end
--[[-- Top Level Manager --]]-- --[[-- Top Level Manager --]]--
local Manager = class() local Manager = class()
function Manager:init(args) function Manager:init()
local control = false local control = false
local shift = false local shift = false
local mouseDragged = false local mouseDragged = false
local pages = { }
local running = false local running = false
-- single thread all input events -- single thread all input events
local function singleThread(event, fn) local function singleThread(event, fn)
Event.on(event, function(...) Event.on(event, function(_, ...)
if not running then if not running then
running = true running = true
fn(...) fn(...)
@ -52,7 +51,7 @@ function Manager:init(args)
end) end)
end end
singleThread('term_resize', function(h, side) singleThread('term_resize', function(side)
if self.currentPage then if self.currentPage then
-- the parent doesn't have any children set... -- the parent doesn't have any children set...
-- that's why we have to resize both the parent and the current page -- that's why we have to resize both the parent and the current page
@ -67,7 +66,7 @@ function Manager:init(args)
end end
end) end)
singleThread('mouse_scroll', function(h, direction, x, y) singleThread('mouse_scroll', function(direction, x, y)
if self.target then if self.target then
local event = self:pointToChild(self.target, x, y) local event = self:pointToChild(self.target, x, y)
local directions = { local directions = {
@ -83,7 +82,7 @@ function Manager:init(args)
end) end)
-- this should be moved to the device ! -- this should be moved to the device !
singleThread('monitor_touch', function(h, side, x, y) singleThread('monitor_touch', function(side, x, y)
if self.currentPage then if self.currentPage then
if self.currentPage.parent.device.side == side then if self.currentPage.parent.device.side == side then
self:click(1, x, y) self:click(1, x, y)
@ -91,12 +90,15 @@ function Manager:init(args)
end end
end) end)
singleThread('mouse_click', function(h, button, x, y) singleThread('mouse_click', function(button, x, y)
mouseDragged = false mouseDragged = false
if button == 1 and shift and control then -- debug hack if button == 1 and shift and control then -- debug hack
local event = self:pointToChild(self.target, x, y) local event = self:pointToChild(self.target, x, y)
multishell.openTab({ path = 'sys/apps/Lua.lua', args = { event.element }, focused = true }) multishell.openTab({
path = 'sys/apps/Lua.lua',
args = { event.element, self:dump(self.currentPage) },
focused = true })
elseif self.currentPage then elseif self.currentPage then
if not self.currentPage.parent.device.side then if not self.currentPage.parent.device.side then
@ -109,7 +111,7 @@ function Manager:init(args)
end end
end) end)
singleThread('mouse_up', function(h, button, x, y) singleThread('mouse_up', function(button, x, y)
if self.currentPage and not mouseDragged then if self.currentPage and not mouseDragged then
if not self.currentPage.parent.device.side then if not self.currentPage.parent.device.side then
@ -118,7 +120,7 @@ function Manager:init(args)
end end
end) end)
singleThread('mouse_drag', function(h, button, x, y) singleThread('mouse_drag', function(button, x, y)
mouseDragged = true mouseDragged = true
if self.target then if self.target then
@ -132,7 +134,7 @@ function Manager:init(args)
end end
end) end)
singleThread('paste', function(h, text) singleThread('paste', function(text)
if clipboard.isInternal() then if clipboard.isInternal() then
text = clipboard.getData() text = clipboard.getData()
end end
@ -142,7 +144,7 @@ function Manager:init(args)
end end
end) end)
singleThread('char', function(h, ch) singleThread('char', function(ch)
control = false control = false
if self.currentPage then if self.currentPage then
self:inputEvent(self.currentPage.focused, { type = 'key', key = ch }) self:inputEvent(self.currentPage.focused, { type = 'key', key = ch })
@ -150,7 +152,7 @@ function Manager:init(args)
end end
end) end)
singleThread('key_up', function(h, code) singleThread('key_up', function(code)
if code == keys.leftCtrl or code == keys.rightCtrl then if code == keys.leftCtrl or code == keys.rightCtrl then
control = false control = false
elseif code == keys.leftShift or code == keys.rightShift then elseif code == keys.leftShift or code == keys.rightShift then
@ -158,7 +160,7 @@ function Manager:init(args)
end end
end) end)
singleThread('key', function(h, code) singleThread('key', function(code)
local ch = keys.getName(code) local ch = keys.getName(code)
if not ch then if not ch then
return return
@ -475,6 +477,31 @@ function Manager:setProperties(obj, args)
end end
end end
function Manager:dump(el)
if el then
local function clean(el)
local o = el
el = Util.shallowCopy(el)
el.parent = nil
if el.children then
local children = { }
for k,c in pairs(el.children) do
children[k] = clean(c)
end
el.children = children
end
for k,v in pairs(o) do
if type(v) == 'table' and v.UIElement then
el[k] = nil
end
end
return el
end
return clean(el)
end
end
local UI = Manager() local UI = Manager()
--[[-- Basic drawable area --]]-- --[[-- Basic drawable area --]]--
@ -652,9 +679,9 @@ function UI.Window:setTextScale(textScale)
self.parent:setTextScale(textScale) self.parent:setTextScale(textScale)
end end
function UI.Window:clear(bg, ...) function UI.Window:clear(bg, fg)
if self.canvas then if self.canvas then
self.canvas:clear(bg or self.backgroundColor) self.canvas:clear(bg or self.backgroundColor, fg or self.textColor)
else else
self:clearArea(1 + self.offx, 1 + self.offy, self.width, self.height, bg) self:clearArea(1 + self.offx, 1 + self.offy, self.width, self.height, bg)
end end
@ -755,7 +782,7 @@ function UI.Window:print(text, bg, fg, indent)
local lines = Util.split(text) local lines = Util.split(text)
for k,line in pairs(lines) do for k,line in pairs(lines) do
local fragments = pieces(line, bg, fg) local fragments = pieces(line, bg, fg)
for l, fragment in ipairs(fragments) do for _, fragment in ipairs(fragments) do
local lx = 1 local lx = 1
if type(fragment) == 'table' then -- ansi sequence if type(fragment) == 'table' then -- ansi sequence
fg = fragment.fg fg = fragment.fg
@ -897,130 +924,6 @@ function UI.Window:eventHandler(event)
return false return false
end end
--[[-- TransitionSlideLeft --]]--
UI.TransitionSlideLeft = class()
UI.TransitionSlideLeft.defaults = {
UIElement = 'TransitionSlideLeft',
ticks = 6,
easing = 'outQuint',
}
function UI.TransitionSlideLeft:init(args)
local defaults = UI:getDefaults(UI.TransitionSlideLeft, args)
UI:setProperties(self, defaults)
self.pos = { x = self.ex }
self.tween = Tween.new(self.ticks, self.pos, { x = self.x }, self.easing)
self.lastx = 0
self.lastScreen = self.canvas:copy()
end
function UI.TransitionSlideLeft:update(device)
self.tween:update(1)
local x = math.floor(self.pos.x)
if x ~= self.lastx then
self.lastx = x
self.lastScreen:dirty()
self.lastScreen:blit(device, {
x = self.ex - x + self.x,
y = self.y,
ex = self.ex,
ey = self.ey },
{ x = self.x, y = self.y })
self.canvas:blit(device, {
x = self.x,
y = self.y,
ex = self.ex - x + self.x,
ey = self.ey },
{ x = x, y = self.y })
end
return self.pos.x ~= self.x
end
--[[-- TransitionSlideRight --]]--
UI.TransitionSlideRight = class()
UI.TransitionSlideRight.defaults = {
UIElement = 'TransitionSlideRight',
ticks = 6,
easing = 'outQuint',
}
function UI.TransitionSlideRight:init(args)
local defaults = UI:getDefaults(UI.TransitionSlideRight, args)
UI:setProperties(self, defaults)
self.pos = { x = self.x }
self.tween = Tween.new(self.ticks, self.pos, { x = self.ex }, self.easing)
self.lastx = 0
self.lastScreen = self.canvas:copy()
end
function UI.TransitionSlideRight:update(device)
self.tween:update(1)
local x = math.floor(self.pos.x)
if x ~= self.lastx then
self.lastx = x
self.lastScreen:dirty()
self.lastScreen:blit(device, {
x = self.x,
y = self.y,
ex = self.ex - x + self.x,
ey = self.ey },
{ x = x, y = self.y })
self.canvas:blit(device, {
x = self.ex - x + self.x,
y = self.y,
ex = self.ex,
ey = self.ey },
{ x = self.x, y = self.y })
end
return self.pos.x ~= self.ex
end
--[[-- TransitionExpandUp --]]--
UI.TransitionExpandUp = class()
UI.TransitionExpandUp.defaults = {
UIElement = 'TransitionExpandUp',
ticks = 3,
easing = 'linear',
}
function UI.TransitionExpandUp:init(args)
local defaults = UI:getDefaults(UI.TransitionExpandUp, args)
UI:setProperties(self, defaults)
self.pos = { y = self.ey + 1 }
self.tween = Tween.new(self.ticks, self.pos, { y = self.y }, self.easing)
end
function UI.TransitionExpandUp:update(device)
self.tween:update(1)
self.canvas:blit(device, nil, { x = self.x, y = math.floor(self.pos.y) })
return self.pos.y ~= self.y
end
--[[-- TransitionGrow --]]--
UI.TransitionGrow = class()
UI.TransitionGrow.defaults = {
UIElement = 'TransitionGrow',
ticks = 3,
easing = 'linear',
}
function UI.TransitionGrow:init(args)
local defaults = UI:getDefaults(UI.TransitionGrow, args)
UI:setProperties(self, defaults)
self.tween = Tween.new(self.ticks,
{ x = self.width / 2 - 1, y = self.height / 2 - 1, w = 1, h = 1 },
{ x = 1, y = 1, w = self.width, h = self.height }, self.easing)
end
function UI.TransitionGrow:update(device)
local finished = self.tween:update(1)
local subj = self.tween.subject
local rect = { x = math.floor(subj.x), y = math.floor(subj.y) }
rect.ex = math.floor(rect.x + subj.w - 1)
rect.ey = math.floor(rect.y + subj.h - 1)
self.canvas:blit(device, rect, { x = self.x + rect.x - 1, y = self.y + rect.y - 1})
return not finished
end
--[[-- Terminal for computer / advanced computer / monitor --]]-- --[[-- Terminal for computer / advanced computer / monitor --]]--
UI.Device = class(UI.Window) UI.Device = class(UI.Window)
UI.Device.defaults = { UI.Device.defaults = {
@ -1040,7 +943,7 @@ function UI.Device:init(args)
end end
if not defaults.device.setTextScale then if not defaults.device.setTextScale then
defaults.device.setTextScale = function(...) end defaults.device.setTextScale = function() end
end end
defaults.device.setTextScale(defaults.textScale) defaults.device.setTextScale(defaults.textScale)
@ -1091,7 +994,6 @@ function UI.Device:reset()
self.device.setCursorPos(1, 1) self.device.setCursorPos(1, 1)
end end
-- refactor into canvas...
function UI.Device:addTransition(effect, args) function UI.Device:addTransition(effect, args)
if not self.transitions then if not self.transitions then
self.transitions = { } self.transitions = { }
@ -1103,28 +1005,19 @@ function UI.Device:addTransition(effect, args)
args.canvas = args.canvas or self.canvas args.canvas = args.canvas or self.canvas
if type(effect) == 'string' then if type(effect) == 'string' then
local transitions = { effect = Transition[effect]
slideLeft = UI.TransitionSlideLeft, if not effect then
slideRight = UI.TransitionSlideRight, error('Invalid transition')
expandUp = UI.TransitionExpandUp,
grow = UI.TransitionGrow,
}
local c = transitions[effect]
if not c then
error('Invalid transition: ' .. effect)
end end
effect = c(args)
else
Util.merge(effect, args)
end end
table.insert(self.transitions, effect) table.insert(self.transitions, { update = effect(args), args = args })
end end
function UI.Device:runTransitions(transitions, canvas) function UI.Device:runTransitions(transitions, canvas)
for _,t in ipairs(transitions) do for _,t in ipairs(transitions) do
canvas:punch(t) -- punch out the effect areas canvas:punch(t.args) -- punch out the effect areas
end end
canvas:blitClipped(self.device) -- and blit the remainder canvas:blitClipped(self.device) -- and blit the remainder
canvas:reset() canvas:reset()
@ -1132,7 +1025,7 @@ function UI.Device:runTransitions(transitions, canvas)
while true do while true do
for _,k in ipairs(Util.keys(transitions)) do for _,k in ipairs(Util.keys(transitions)) do
local transition = transitions[k] local transition = transitions[k]
if not transition:update(self.device) then if not transition.update(self.device) then
transitions[k] = nil transitions[k] = nil
end end
end end
@ -1353,7 +1246,6 @@ UI.Grid.defaults = {
index = 1, index = 1,
inverseSort = false, inverseSort = false,
disableHeader = false, disableHeader = false,
selectable = true,
textColor = colors.white, textColor = colors.white,
textSelectedColor = colors.white, textSelectedColor = colors.white,
backgroundColor = colors.black, backgroundColor = colors.black,
@ -1447,7 +1339,7 @@ function UI.Grid:adjustWidth()
end end
else else
for k,c in ipairs(t) do for _,c in ipairs(t) do
c.cw = #(c.heading or '') c.cw = #(c.heading or '')
w = w - c.cw w = w - c.cw
end end
@ -1591,8 +1483,8 @@ function UI.Grid:drawHeadings()
end end
function UI.Grid:sortCompare(a, b) function UI.Grid:sortCompare(a, b)
local a = safeValue(a[self.sortColumn]) a = safeValue(a[self.sortColumn])
local b = safeValue(b[self.sortColumn]) b = safeValue(b[self.sortColumn])
if type(a) == type(b) then if type(a) == type(b) then
return a < b return a < b
end end
@ -1619,7 +1511,7 @@ function UI.Grid:drawRows()
sb:clear() sb:clear()
local ind = ' ' local ind = ' '
if self.focused and index == self.index and self.selectable then if self.focused and index == self.index and not self.inactive then
ind = self.focusIndicator ind = self.focusIndicator
end end
@ -1628,7 +1520,7 @@ function UI.Grid:drawRows()
ind = ' ' ind = ' '
end end
local selected = index == self.index and self.selectable local selected = index == self.index and not self.inactive
self:write(1, y, sb:get(), self:write(1, y, sb:get(),
self:getRowBackgroundColor(row, selected), self:getRowBackgroundColor(row, selected),
@ -1662,7 +1554,7 @@ function UI.Grid:getRowBackgroundColor(row, selected)
return self.backgroundColor return self.backgroundColor
end end
function UI.Grid:getIndex(index) function UI.Grid:getIndex()
return self.index return self.index
end end
@ -1868,7 +1760,7 @@ function UI.ScrollingGrid:eventHandler(event)
self:setIndex(self.scrollOffset - 1) self:setIndex(self.scrollOffset - 1)
elseif event.y == self.height then elseif event.y == self.height then
self:setIndex(self.scrollOffset + self.pageSize) self:setIndex(self.scrollOffset + self.pageSize)
else -- else
-- ... percentage ... -- ... percentage ...
end end
return true return true
@ -2177,7 +2069,7 @@ function UI.MenuBar:init(args)
end end
local x = 1 local x = 1
for k,button in pairs(self.buttons) do for _,button in pairs(self.buttons) do
if button.UIElement then if button.UIElement then
table.insert(self.children, button) table.insert(self.children, button)
else else
@ -2189,16 +2081,16 @@ function UI.MenuBar:init(args)
x = x + buttonProperties.width x = x + buttonProperties.width
UI:setProperties(buttonProperties, button) UI:setProperties(buttonProperties, button)
local parent = self button = UI[self.buttonClass](buttonProperties)
if button.dropdown then if button.name then
buttonProperties.dropmenu = UI.DropMenu { buttons = button.dropdown } self[button.name] = button
table.insert(self.children, buttonProperties.dropmenu) else
table.insert(self.children, button)
end end
if button.name then if button.dropdown then
self[button.name] = UI[self.buttonClass](buttonProperties) button.dropmenu = UI.DropMenu { buttons = button.dropdown }
else --table.insert(self.children, buttonProperties.dropmenu)
table.insert(self.children, UI[self.buttonClass](buttonProperties))
end end
end end
end end
@ -2320,18 +2212,17 @@ function UI.DropMenu:hide()
end end
function UI.DropMenu:eventHandler(event) function UI.DropMenu:eventHandler(event)
if event.type == 'focus_lost' then if event.type == 'focus_lost' and self.enabled then
for _,child in ipairs(self.children) do for _,child in ipairs(self.children) do
if child == event.focused then if child == event.focused then
return return
end end
end end
self:hide() self:hide()
elseif event.type == 'mouse_out' then --self.parent:focusFirst()
elseif event.type == 'mouse_out' and self.enabled then
self:hide() self:hide()
if self.button then self:setFocus(self.parent)
self:setFocus(self.button)
end
else else
return UI.MenuBar.eventHandler(self, event) return UI.MenuBar.eventHandler(self, event)
end end
@ -2381,7 +2272,7 @@ function UI.Tabs:init(args)
local defaults = UI:getDefaults(UI.Tabs, args) local defaults = UI:getDefaults(UI.Tabs, args)
local buttons = { } local buttons = { }
for k,child in pairs(defaults) do for _,child in pairs(defaults) do
if type(child) == 'table' and child.UIElement then if type(child) == 'table' and child.UIElement then
table.insert(buttons, { table.insert(buttons, {
text = child.tabTitle or '', event = 'tab_select', text = child.tabTitle or '', event = 'tab_select',
@ -3007,7 +2898,7 @@ end
function UI.Chooser:eventHandler(event) function UI.Chooser:eventHandler(event)
if event.type == 'key' then if event.type == 'key' then
if event.key == 'right' or event.key == 'space' then if event.key == 'right' or event.key == 'space' then
local choice,k = Util.find(self.choices, 'value', self.value) local _,k = Util.find(self.choices, 'value', self.value)
if k and k < #self.choices then if k and k < #self.choices then
self.value = self.choices[k+1].value self.value = self.choices[k+1].value
else else
@ -3017,7 +2908,7 @@ function UI.Chooser:eventHandler(event)
self:draw() self:draw()
return true return true
elseif event.key == 'left' then elseif event.key == 'left' then
local choice,k = Util.find(self.choices, 'value', self.value) local _,k = Util.find(self.choices, 'value', self.value)
if k and k > 1 then if k and k > 1 then
self.value = self.choices[k-1].value self.value = self.choices[k-1].value
else else
@ -3079,7 +2970,6 @@ function UI.TextArea:setText(text)
end end
function UI.TextArea:draw() function UI.TextArea:draw()
local value = self.value or ''
self:clear() self:clear()
self:setCursorPos(1, 1) self:setCursorPos(1, 1)
self:print(self.value) self:print(self.value)
@ -3110,7 +3000,7 @@ end
function UI.Form:setValues(values) function UI.Form:setValues(values)
self:reset() self:reset()
self.values = values self.values = values
for k,child in pairs(self.children) do for _,child in pairs(self.children) do
if child.formKey then if child.formKey then
-- this should be child:setValue(self.values[child.formKey]) -- this should be child:setValue(self.values[child.formKey])
-- so chooser can set default choice if null -- so chooser can set default choice if null

View File

@ -0,0 +1,90 @@
local Tween = require('ui.tween')
local Transition = { }
function Transition.slideLeft(args)
local ticks = args.ticks or 6
local easing = args.easing or 'outQuint'
local pos = { x = args.ex }
local tween = Tween.new(ticks, pos, { x = args.x }, easing)
local lastScreen = args.canvas:copy()
return function(device)
local finished = tween:update(1)
local x = math.floor(pos.x)
lastScreen:dirty()
lastScreen:blit(device, {
x = args.ex - x + args.x,
y = args.y,
ex = args.ex,
ey = args.ey },
{ x = args.x, y = args.y })
args.canvas:blit(device, {
x = args.x,
y = args.y,
ex = args.ex - x + args.x,
ey = args.ey },
{ x = x, y = args.y })
return not finished
end
end
function Transition.slideRight(args)
local ticks = args.ticks or 6
local easing = args.easing or'outQuint'
local pos = { x = args.x }
local tween = Tween.new(ticks, pos, { x = args.ex }, easing)
local lastScreen = args.canvas:copy()
return function(device)
local finished = tween:update(1)
local x = math.floor(pos.x)
lastScreen:dirty()
lastScreen:blit(device, {
x = args.x,
y = args.y,
ex = args.ex - x + args.x,
ey = args.ey },
{ x = x, y = args.y })
args.canvas:blit(device, {
x = args.ex - x + args.x,
y = args.y,
ex = args.ex,
ey = args.ey },
{ x = args.x, y = args.y })
return not finished
end
end
function Transition.expandUp(args)
local ticks = args.ticks or 3
local easing = args.easing or 'linear'
local pos = { y = args.ey + 1 }
local tween = Tween.new(ticks, pos, { y = args.y }, easing)
return function(device)
local finished = tween:update(1)
args.canvas:blit(device, nil, { x = args.x, y = math.floor(pos.y) })
return not finished
end
end
function Transition.grow(args)
local ticks = args.ticks or 3
local easing = args.easing or 'linear'
local tween = Tween.new(ticks,
{ x = args.width / 2 - 1, y = args.height / 2 - 1, w = 1, h = 1 },
{ x = 1, y = 1, w = args.width, h = args.height }, easing)
return function(device)
local finished = tween:update(1)
local subj = tween.subject
local rect = { x = math.floor(subj.x), y = math.floor(subj.y) }
rect.ex = math.floor(rect.x + subj.w - 1)
rect.ey = math.floor(rect.y + subj.h - 1)
args.canvas:blit(device, rect, { x = args.x + rect.x - 1, y = args.y + rect.y - 1})
return not finished
end
end
return Transition

View File

@ -270,7 +270,7 @@ function page.container:setCategory(categoryName)
local col, row = gutter, 2 local col, row = gutter, 2
local count = #self.children local count = #self.children
local r = math.random(1, 4) local r = math.random(1, 5)
-- reposition all children -- reposition all children
for k,child in ipairs(self.children) do for k,child in ipairs(self.children) do
if r == 1 then if r == 1 then
@ -285,6 +285,13 @@ function page.container:setCategory(categoryName)
elseif r == 4 then elseif r == 4 then
child.x = self.width - col child.x = self.width - col
child.y = row child.y = row
elseif r == 5 then
child.x = col
child.y = row
if k == #self.children then
child.x = self.width
child.y = self.height
end
end end
child.tween = Tween.new(6, child, { x = col, y = row }, 'linear') child.tween = Tween.new(6, child, { x = col, y = row }, 'linear')
@ -298,19 +305,20 @@ function page.container:setCategory(categoryName)
end end
self:initChildren() self:initChildren()
local function transition(args)
local transition = { i = 1, parent = self, children = self.children } local i = 1
function transition:update(device) return function(device)
self.parent:clear() self:clear()
for _,child in ipairs(self.children) do for _,child in pairs(self.children) do
child.tween:update(1) child.tween:update(1)
child.x = math.floor(child.x) child.x = math.floor(child.x)
child.y = math.floor(child.y) child.y = math.floor(child.y)
child:draw() child:draw()
end end
self.canvas:blit(device, self, self) args.canvas:blit(device, args, args)
self.i = self.i + 1 i = i + 1
return self.i < 7 return i < 7
end
end end
self:addTransition(transition) self:addTransition(transition)
end end

View File

@ -92,7 +92,7 @@ local systemPage = UI.Page {
{ name = 'Computer ID', value = tostring(os.getComputerID()) }, { name = 'Computer ID', value = tostring(os.getComputerID()) },
{ name = 'Day', value = tostring(os.day()) }, { name = 'Day', value = tostring(os.day()) },
}, },
selectable = false, inactive = true,
columns = { columns = {
{ key = 'name', width = 12 }, { key = 'name', width = 12 },
{ key = 'value' }, { key = 'value' },

View File

@ -476,6 +476,10 @@ local function startup()
local hasError local hasError
local session = Util.readTable(SESSION_FILE) local session = Util.readTable(SESSION_FILE)
if not Opus.loadServices() then
hasError = true
end
local overviewId = multishell.openTab({ local overviewId = multishell.openTab({
path = 'sys/apps/Overview.lua', path = 'sys/apps/Overview.lua',
focused = true, focused = true,
@ -484,10 +488,6 @@ local function startup()
}) })
overviewTab = tabs[overviewId] overviewTab = tabs[overviewId]
if not Opus.loadServices() then
hasError = true
end
if not Opus.autorun() then if not Opus.autorun() then
hasError = true hasError = true
end end

View File

@ -239,7 +239,7 @@
icon = "\0301\031f \0309 \030c \030b \030e \030c \0306 \ icon = "\0301\031f \0309 \030c \030b \030e \030c \0306 \
\030 \031f \ \030 \031f \
\030 \031f \0300 \0310 ", \030 \031f \0300 \0310 ",
run = "https://pastebin.com/raw/LTRYaSKt", run = "https://gist.github.com/LDDestroier/c7528d95bc0103545c2a/raw",
}, },
[ "8d59207c8a84153b3e9f035cc3b6ec7a23671323" ] = { [ "8d59207c8a84153b3e9f035cc3b6ec7a23671323" ] = {
title = "Micropaint", title = "Micropaint",