diff --git a/widget/app_launcher/init.lua b/widget/app_launcher/init.lua index 26503319..2659ea2e 100644 --- a/widget/app_launcher/init.lua +++ b/widget/app_launcher/init.lua @@ -89,47 +89,6 @@ local function has_value(tab, val) return false end -local function select_app(self, x, y) - local widgets = self._private.grid:get_widgets_at(x, y) - if widgets then - self._private.active_widget = widgets[1] - if self._private.active_widget ~= nil then - if self.app_template == nil then - self._private.active_widget:get_children_by_id("background_role")[1].bg = self.app_selected_color - local name_widget = self._private.active_widget:get_children_by_id("name_role")[1] - if name_widget then - name_widget.markup = string.format("%s", self.app_name_selected_color, name_widget.text) - end - local generic_name_widget = self._private.active_widget:get_children_by_id("generic_name_role")[1] - if generic_name_widget then - generic_name_widget.markup = string.format("%s", self.app_name_selected_color, generic_name_widget.text) - end - end - self._private.active_widget:emit_signal("selected") - self._private.active_widget.selected = true - end - end -end - -local function unselect_app(self) - if self._private.active_widget ~= nil then - if self.app_template == nil then - self._private.active_widget:get_children_by_id("background_role")[1].bg = self.app_normal_color - local name_widget = self._private.active_widget:get_children_by_id("name_role")[1] - if name_widget then - name_widget.markup = string.format("%s", self.app_name_normal_color, name_widget.text) - end - local generic_name_widget = self._private.active_widget:get_children_by_id("generic_name_role")[1] - if generic_name_widget then - generic_name_widget.markup = string.format("%s", self.app_name_normal_color, generic_name_widget.text) - end - end - self._private.active_widget:emit_signal("unselected") - self._private.active_widget.selected = false - self._private.active_widget = nil - end -end - local function create_app_widget(self, app) local app_widget = nil @@ -247,12 +206,7 @@ local function create_app_widget(self, app) if self._private.active_widget == app or not self.select_before_spawn then app:spawn() else - -- Unmark the previous app - unselect_app(self) - - -- Mark this app - local pos = self._private.grid:get_widget_position(app) - select_app(self, pos.row, pos.col) + app:select() end end end) @@ -269,13 +223,53 @@ local function create_app_widget(self, app) end end + local _self = self + function app_widget:select() + if _self._private.active_widget then + _self._private.active_widget:unselect() + end + _self._private.active_widget = self + self:emit_signal("selected") + self.selected = true + + if _self.app_template == nil then + self:get_children_by_id("background_role")[1].bg = _self.app_selected_color + local name_widget = self:get_children_by_id("name_role")[1] + if name_widget then + name_widget.markup = string.format("%s", _self.app_name_selected_color, name_widget.text) + end + local generic_name_widget = self:get_children_by_id("generic_name_role")[1] + if generic_name_widget then + generic_name_widget.markup = string.format("%s", _self.app_name_selected_color, generic_name_widget.text) + end + end + end + + function app_widget:unselect() + self:emit_signal("unselected") + self.selected = false + _self._private.active_widget = nil + + if _self.app_template == nil then + self:get_children_by_id("background_role")[1].bg = _self.app_normal_color + local name_widget = self:get_children_by_id("name_role")[1] + if name_widget then + name_widget.markup = string.format("%s", _self.app_name_normal_color, name_widget.text) + end + local generic_name_widget = self:get_children_by_id("generic_name_role")[1] + if generic_name_widget then + generic_name_widget.markup = string.format("%s", _self.app_name_normal_color, generic_name_widget.text) + end + end + end + return app_widget end local function search(self, text) - unselect_app(self) + self._private.active_widget:unselect() - local pos = self._private.grid:get_widget_position(self._private.active_widget) + local old_pos = self._private.grid:get_widget_position(self._private.active_widget) -- Reset all the matched entries self._private.matched_entries = {} @@ -328,14 +322,17 @@ local function search(self, text) -- it will reselect the app whose index is the same as the app index that was previously selected -- and if matched_entries.length < current_index it will instead select the app with the greatest index if self.try_to_keep_index_after_searching then - if self._private.grid:get_widgets_at(pos.row, pos.col) == nil then + if self._private.grid:get_widgets_at(old_pos.row, old_pos.col) == nil then local app = self._private.grid.children[#self._private.grid.children] - pos = self._private.grid:get_widget_position(app) + app:select() + else + local app = self._private.grid:get_widgets_at(old_pos.row, old_pos.col)[1] + app:select() end - select_app(self, pos.row, pos.col) -- Otherwise select the first app on the list else - select_app(self, 1, 1) + local app = self._private.grid:get_widgets_at(1, 1)[1] + app:select() end end @@ -352,8 +349,8 @@ local function page_forward(self, direction) min_app_index_to_include = 0 max_app_index_to_include = self._private.apps_per_page elseif self.wrap_app_scrolling then - unselect_app(self) - select_app(self, 1, 1) + local app = self._private.grid:get_widgets_at(1, 1)[1] + app:select() return else return @@ -373,15 +370,15 @@ local function page_forward(self, direction) if self._private.current_page > 1 or self.wrap_page_scrolling then if direction == "down" then - select_app(self, 1, 1) + local app = self._private.grid:get_widgets_at(1, 1)[1] + app:select() else - local next_app = self._private.grid:get_widgets_at(pos.row, 1) - if next_app == nil then - local next_app = self._private.grid.children[#self._private.grid.children] - local next_app_pos = self._private.grid:get_widget_position(next_app) - select_app(self, next_app_pos.row, next_app_pos.col) + local app = self._private.grid:get_widgets_at(pos.row, 1)[1] + if app == nil then + local app = self._private.grid.children[#self._private.grid.children] + app:select() else - select_app(self, pos.row, 1) + app:select() end end end @@ -393,9 +390,8 @@ local function page_backward(self, direction) elseif self.wrap_page_scrolling and #self._private.matched_entries >= self._private.max_apps_per_page then self._private.current_page = self._private.pages_count elseif self.wrap_app_scrolling then - local rows, columns = self._private.grid:get_dimension() - unselect_app(self) - select_app(self, math.min(rows, #self._private.grid.children % self.apps_per_row), columns) + local app = self._private.grid.children{#self._private.grid.children} + app:select() return else return @@ -419,15 +415,16 @@ local function page_backward(self, direction) local rows, columns = self._private.grid:get_dimension() if self._private.current_page < self._private.pages_count then if direction == "up" then - select_app(self, rows, columns) + local app = self._private.grid.children{#self._private.grid.children} + app:select() else -- Keep the same row from last page - select_app(self, pos.row, columns) + local app = self._private.grid:get_widgets_at(pos.row, columns)[1] + app:select() end elseif self.wrap_page_scrolling then - local next_app = self._private.grid.children[#self._private.grid.children] - local next_app_pos = self._private.grid:get_widget_position(next_app) - select_app(self, next_app_pos.row, next_app_pos.col) + local app = self._private.grid.children[#self._private.grid.children] + app:select() end end @@ -439,10 +436,8 @@ local function scroll_up(self) local can_scroll_up = self._private.grid:index(self._private.active_widget) > 1 if can_scroll_up then - local next_app = gtable.cycle_value(self._private.grid.children, self._private.active_widget, -1) - local next_app_pos = self._private.grid:get_widget_position(next_app) - unselect_app(self) - select_app(self, next_app_pos.row, next_app_pos.col) + local app = gtable.cycle_value(self._private.grid.children, self._private.active_widget, -1) + app:select() else page_backward(self, "up") end @@ -456,10 +451,8 @@ local function scroll_down(self) local can_scroll_down = self._private.grid:index(self._private.active_widget) < #self._private.grid.children if can_scroll_down then - local next_app = gtable.cycle_value(self._private.grid.children, self._private.active_widget, 1) - local next_app_pos = self._private.grid:get_widget_position(next_app) - unselect_app(self) - select_app(self, next_app_pos.row, next_app_pos.col) + local app = gtable.cycle_value(self._private.grid.children, self._private.active_widget, 1) + app:select() else page_forward(self, "down") end @@ -474,10 +467,8 @@ local function scroll_left(self) local pos = self._private.grid:get_widget_position(self._private.active_widget) local can_scroll_left = self._private.grid:get_widgets_at(pos.row, pos.col - 1) ~= nil if can_scroll_left then - local next_app = gtable.cycle_value(self._private.grid.children, self._private.active_widget, -self.apps_per_row) - local next_app_pos = self._private.grid:get_widget_position(next_app) - unselect_app(self) - select_app(self, next_app_pos.row, next_app_pos.col) + local app = gtable.cycle_value(self._private.grid.children, self._private.active_widget, -self.apps_per_row) + app:select() else page_backward(self, "left") end @@ -492,10 +483,8 @@ local function scroll_right(self) local pos = self._private.grid:get_widget_position(self._private.active_widget) local can_scroll_right = self._private.grid:get_widgets_at(pos.row, pos.col + 1) ~= nil if can_scroll_right then - local next_app = gtable.cycle_value(self._private.grid.children, self._private.active_widget, self.apps_per_row) - local next_app_pos = self._private.grid:get_widget_position(next_app) - unselect_app(self) - select_app(self, next_app_pos.row, next_app_pos.col) + local app = gtable.cycle_value(self._private.grid.children, self._private.active_widget, self.apps_per_row) + app:select() else page_forward(self, "right") end @@ -517,7 +506,8 @@ local function reset(self) end end - select_app(self, 1, 1) + local app = self._private.grid:get_widgets_at(1, 1)[1] + app:select() end local function generate_apps(self)