Initial port to Libadwaita 1.4

This commit is contained in:
kramo
2023-07-04 18:49:06 +02:00
parent 0efa05514c
commit 5fd6ea20f4
9 changed files with 335 additions and 355 deletions

View File

@@ -47,323 +47,314 @@ template $CartridgesWindow : Adw.ApplicationWindow {
title: _("Cartridges"); title: _("Cartridges");
Adw.ToastOverlay toast_overlay { Adw.ToastOverlay toast_overlay {
Stack stack { Adw.NavigationView navigation_view {
visible-child: library_view; Adw.NavigationPage library_page {
transition-type: over_left; title: _("Cartridges");
Overlay details_view { Adw.ToolbarView library_view {
name: "details_view"; [top]
Adw.HeaderBar header_bar {
[start]
MenuButton {
tooltip-text: _("Add Game");
icon-name: "list-add-symbolic";
menu-model: add_games;
}
[overlay] [end]
Box details_view_box { MenuButton primary_menu_button {
orientation: vertical; tooltip-text: _("Main Menu");
icon-name: "open-menu-symbolic";
menu-model: primary_menu;
}
Adw.HeaderBar { [end]
[start] ToggleButton search_button {
Button back_button { tooltip-text: _("Search");
tooltip-text: _("Back"); icon-name: "system-search-symbolic";
action-name: "win.go_back"; action-name: "win.toggle_search";
icon-name: "go-previous-symbolic"; }
} }
[title] [top]
Adw.WindowTitle details_view_header_bar_title { SearchBar search_bar {
title: _("Game Details"); search-mode-enabled: bind-property search_button.active bidirectional;
} key-capture-widget: library_view;
styles [
"flat",
]
}
Adw.Bin {
hexpand: true;
vexpand: true;
Box {
halign: center;
valign: center;
margin-start: 24;
margin-end: 24;
margin-top: 24;
margin-bottom: 24;
Adw.Clamp { Adw.Clamp {
maximum-size: 200; maximum-size: 500;
tightening-threshold: 500;
Overlay { SearchEntry search_entry {
[overlay] hexpand: true;
Spinner details_view_spinner {
margin-start: 72;
margin-end: 72;
}
Picture details_view_cover {
halign: end;
valign: start;
width-request: 200;
height-request: 300;
styles [
"card",
]
}
} }
} }
}
Overlay library_overlay {
ScrolledWindow scrolledwindow {
FlowBox library {
homogeneous: true;
halign: center;
valign: start;
column-spacing: 12;
row-spacing: 12;
margin-top: 15;
margin-bottom: 15;
margin-start: 15;
margin-end: 15;
selection-mode: none;
}
}
}
}
}
}
}
}
Adw.NavigationPage hidden_library_page {
title: _("Hidden Games");
Adw.ToolbarView hidden_library_view {
[top]
Adw.HeaderBar hidden_header_bar {
[end]
MenuButton hidden_primary_menu_button {
tooltip-text: _("Main Menu");
icon-name: "open-menu-symbolic";
menu-model: primary_menu;
}
[end]
ToggleButton hidden_search_button {
tooltip-text: _("Search");
icon-name: "system-search-symbolic";
action-name: "win.toggle_search";
}
}
[top]
SearchBar hidden_search_bar {
search-mode-enabled: bind-property hidden_search_button.active bidirectional;
key-capture-widget: hidden_library_view;
Adw.Clamp {
maximum-size: 500;
tightening-threshold: 500;
SearchEntry hidden_search_entry {
hexpand: true;
}
}
}
Overlay hidden_library_overlay {
ScrolledWindow hidden_scrolledwindow {
FlowBox hidden_library {
homogeneous: true;
halign: center;
valign: start;
column-spacing: 12;
row-spacing: 12;
margin-top: 15;
margin-bottom: 15;
margin-start: 15;
margin-end: 15;
selection-mode: none;
}
}
}
styles [
"background",
]
}
}
Adw.NavigationPage details_page {
title: _("Game Details");
Overlay details_view {
name: "details_view";
[overlay]
Box details_view_box {
orientation: vertical;
Adw.HeaderBar {
styles [
"flat",
]
}
Adw.Bin {
hexpand: true;
vexpand: true;
Box {
halign: center;
valign: center;
margin-start: 24;
margin-end: 24;
margin-top: 24;
margin-bottom: 24;
Adw.Clamp {
maximum-size: 200;
Overlay {
[overlay]
Spinner details_view_spinner {
margin-start: 72;
margin-end: 72;
}
Picture details_view_cover {
halign: end;
valign: start;
width-request: 200;
height-request: 300;
styles [
"card",
]
}
}
}
Box {
orientation: vertical;
margin-start: 48;
vexpand: true;
valign: center;
Label details_view_title {
label: _("Game Title");
hexpand: true;
halign: start;
max-width-chars: 24;
wrap: true;
wrap-mode: word_char;
natural-wrap-mode: word;
styles [
"title-1",
]
}
Label details_view_developer {
margin-top: 6;
hexpand: true;
halign: start;
max-width-chars: 36;
wrap: true;
wrap-mode: word_char;
natural-wrap-mode: word;
styles [
"heading",
]
}
Box {
orientation: horizontal;
margin-top: 15;
hexpand: true;
halign: start;
Label details_view_added {
wrap: true;
wrap-mode: word_char;
natural-wrap-mode: word;
}
Label details_view_last_played {
margin-start: 12;
wrap: true;
wrap-mode: word_char;
natural-wrap-mode: word;
}
}
Box {
hexpand: true;
vexpand: true;
valign: center;
Button details_view_play_button {
name: "details_view_play_button";
action-name: "app.launch_game";
label: _("Play");
halign: start;
margin-top: 24;
styles [
"opaque",
"pill",
]
}
Box { Box {
orientation: vertical; halign: start;
margin-start: 48;
vexpand: true;
valign: center; valign: center;
margin-top: 24;
margin-start: 9;
Label details_view_title { Button {
label: _("Game Title"); icon-name: "document-edit-symbolic";
hexpand: true; action-name: "app.edit_game";
halign: start; tooltip-text: _("Edit");
max-width-chars: 24;
wrap: true;
wrap-mode: word_char;
natural-wrap-mode: word;
styles [ styles [
"title-1", "raised",
"circular",
] ]
} }
Label details_view_developer { Button details_view_hide_button {
margin-top: 6; action-name: "app.hide_game";
hexpand: true;
halign: start;
max-width-chars: 36;
wrap: true;
wrap-mode: word_char;
natural-wrap-mode: word;
styles [ styles [
"heading", "raised",
"circular",
] ]
} }
Box { Button {
orientation: horizontal; icon-name: "user-trash-symbolic";
margin-top: 15; action-name: "app.remove_game";
hexpand: true; tooltip-text: _("Remove");
halign: start;
Label details_view_added { styles [
wrap: true; "raised",
wrap-mode: word_char; "circular",
natural-wrap-mode: word; ]
}
Label details_view_last_played {
margin-start: 12;
wrap: true;
wrap-mode: word_char;
natural-wrap-mode: word;
}
} }
Box { MenuButton {
hexpand: true; icon-name: "system-search-symbolic";
vexpand: true; menu-model: search;
valign: center; tooltip-text: _("Search");
Button details_view_play_button { styles [
name: "details_view_play_button"; "raised",
action-name: "app.launch_game"; "circular",
label: _("Play"); ]
halign: start;
margin-top: 24;
styles [
"opaque",
"pill",
]
}
Box {
halign: start;
valign: center;
margin-top: 24;
margin-start: 9;
Button {
icon-name: "document-edit-symbolic";
action-name: "app.edit_game";
tooltip-text: _("Edit");
styles ["raised", "circular"]
}
Button details_view_hide_button {
action-name: "app.hide_game";
styles ["raised", "circular"]
}
Button {
icon-name: "user-trash-symbolic";
action-name: "app.remove_game";
tooltip-text: _("Remove");
styles ["raised", "circular"]
}
MenuButton {
icon-name: "system-search-symbolic";
menu-model: search;
tooltip-text: _("Search");
styles ["raised", "circular"]
}
styles [
"toolbar",
]
}
} }
styles [
"toolbar",
]
} }
} }
} }
} }
Picture details_view_blurred_cover {
keep-aspect-ratio: false;
}
} }
}
Box library_view { Picture details_view_blurred_cover {
orientation: vertical; keep-aspect-ratio: false;
Adw.HeaderBar header_bar {
[start]
MenuButton {
tooltip-text: _("Add Game");
icon-name: "list-add-symbolic";
menu-model: add_games;
}
[end]
MenuButton primary_menu_button {
tooltip-text: _("Main Menu");
icon-name: "open-menu-symbolic";
menu-model: primary_menu;
}
[end]
ToggleButton search_button {
tooltip-text: _("Search");
icon-name: "system-search-symbolic";
action-name: "win.toggle_search";
}
}
SearchBar search_bar {
search-mode-enabled: bind-property search_button.active bidirectional;
key-capture-widget: library_view;
Adw.Clamp {
maximum-size: 500;
tightening-threshold: 500;
SearchEntry search_entry {
hexpand: true;
}
}
}
Adw.Bin library_bin {
ScrolledWindow scrolledwindow {
hexpand: true;
vexpand: true;
FlowBox library {
homogeneous: true;
halign: center;
valign: start;
column-spacing: 12;
row-spacing: 12;
margin-top: 15;
margin-bottom: 15;
margin-start: 15;
margin-end: 15;
selection-mode: none;
}
}
}
}
Box hidden_library_view {
orientation: vertical;
Adw.HeaderBar hidden_header_bar {
[start]
Button hidden_back_button {
tooltip-text: _("Back");
action-name: "win.go_back";
icon-name: "go-previous-symbolic";
}
[title]
Adw.WindowTitle {
title: _("Hidden Games");
}
[end]
MenuButton hidden_primary_menu_button {
tooltip-text: _("Main Menu");
icon-name: "open-menu-symbolic";
menu-model: primary_menu;
}
[end]
ToggleButton hidden_search_button {
tooltip-text: _("Search");
icon-name: "system-search-symbolic";
action-name: "win.toggle_search";
}
}
SearchBar hidden_search_bar {
search-mode-enabled: bind-property hidden_search_button.active bidirectional;
key-capture-widget: hidden_library_view;
Adw.Clamp {
maximum-size: 500;
tightening-threshold: 500;
SearchEntry hidden_search_entry {
hexpand: true;
}
}
}
Adw.Bin hidden_library_bin {
ScrolledWindow hidden_scrolledwindow {
hexpand: true;
vexpand: true;
FlowBox hidden_library {
homogeneous: true;
halign: center;
valign: start;
column-spacing: 12;
row-spacing: 12;
margin-top: 15;
margin-bottom: 15;
margin-start: 15;
margin-end: 15;
selection-mode: none;
}
}
}
styles [
"background",
]
}
} }
} }
} }

View File

@@ -91,7 +91,7 @@
<default>1110</default> <default>1110</default>
</key> </key>
<key name="height" type="i"> <key name="height" type="i">
<default>820</default> <default>795</default>
</key> </key>
<key name="is-maximized" type="b"> <key name="is-maximized" type="b">
<default>false</default> <default>false</default>

View File

@@ -1,7 +1,7 @@
{ {
"id" : "hu.kramo.Cartridges.Devel", "id" : "hu.kramo.Cartridges.Devel",
"runtime" : "org.gnome.Platform", "runtime" : "org.gnome.Platform",
"runtime-version" : "44", "runtime-version" : "master",
"sdk" : "org.gnome.Sdk", "sdk" : "org.gnome.Sdk",
"command" : "cartridges", "command" : "cartridges",
"finish-args" : [ "finish-args" : [

View File

@@ -219,7 +219,7 @@ class DetailsWindow(Adw.Window):
self.game_cover.pictures.remove(self.cover) self.game_cover.pictures.remove(self.cover)
self.close() self.close()
self.win.show_details_view(self.game) self.win.show_details_page(self.game)
def update_cover_callback(self, manager: SGDBManager): def update_cover_callback(self, manager: SGDBManager):
# Set the game as not loading # Set the game as not loading

View File

@@ -141,8 +141,8 @@ class Game(Gtk.Box):
self.hidden = not self.hidden self.hidden = not self.hidden
self.save() self.save()
if self.win.stack.get_visible_child() == self.win.details_view: if self.win.navigation_view.get_visible_page() == self.win.details_page:
self.win.on_go_back_action() self.win.navigation_view.pop()
self.update() self.update()
@@ -161,8 +161,8 @@ class Game(Gtk.Box):
self.save() self.save()
self.update() self.update()
if self.win.stack.get_visible_child() == self.win.details_view: if self.win.navigation_view.get_visible_page() == self.win.details_page:
self.win.on_go_back_action() self.win.navigation_view.pop()
# The variable is the title of the game # The variable is the title of the game
self.create_toast( self.create_toast(
@@ -196,7 +196,7 @@ class Game(Gtk.Box):
if shared.schema.get_boolean("cover-launches-game") ^ button: if shared.schema.get_boolean("cover-launches-game") ^ button:
self.launch() self.launch()
else: else:
self.win.show_details_view(self) self.win.show_details_page(self)
def set_play_icon(self): def set_play_icon(self):
self.play_button.set_icon_name( self.play_button.set_icon_name(

View File

@@ -114,7 +114,6 @@ class CartridgesApplication(Adw.Application):
("lutris_search",), ("lutris_search",),
("hltb_search",), ("hltb_search",),
("show_hidden", ("<primary>h",), self.win), ("show_hidden", ("<primary>h",), self.win),
("go_back", ("<alt>Left",), self.win),
("go_to_parent", ("<alt>Up",), self.win), ("go_to_parent", ("<alt>Up",), self.win),
("go_home", ("<alt>Home",), self.win), ("go_home", ("<alt>Home",), self.win),
("toggle_search", ("<primary>f",), self.win), ("toggle_search", ("<primary>f",), self.win),
@@ -236,7 +235,7 @@ class CartridgesApplication(Adw.Application):
self.win.active_game.remove_game() self.win.active_game.remove_game()
def on_remove_game_details_view_action(self, *_args): def on_remove_game_details_view_action(self, *_args):
if self.win.stack.get_visible_child() == self.win.details_view: if self.win.navigation_view.get_visible_page() == self.win.details_page:
self.on_remove_game_action() self.on_remove_game_action()
def search(self, uri): def search(self, uri):

View File

@@ -222,8 +222,8 @@ class PreferencesWindow(Adw.PreferencesWindow):
game.save() game.save()
game.update() game.update()
if self.win.stack.get_visible_child() == self.win.details_view: if self.win.navigation_view.get_visible_page() == self.win.details_page:
self.win.on_go_back_action() self.win.navigation_view.pop()
self.add_toast(self.toast) self.add_toast(self.toast)

View File

@@ -57,10 +57,10 @@ class DisplayManager(Manager):
game.win.game_covers[game.game_id] = game.game_cover game.win.game_covers[game.game_id] = game.game_cover
if ( if (
game.win.stack.get_visible_child() == game.win.details_view game.win.navigation_view.get_visible_page() == game.win.details_page
and game.win.active_game == game and game.win.active_game == game
): ):
game.win.show_details_view(game) game.win.show_details_page(game)
if not game.removed and not game.blacklisted: if not game.removed and not game.blacklisted:
if game.hidden: if game.hidden:

View File

@@ -27,25 +27,26 @@ from src.utils.relative_date import relative_date
class CartridgesWindow(Adw.ApplicationWindow): class CartridgesWindow(Adw.ApplicationWindow):
__gtype_name__ = "CartridgesWindow" __gtype_name__ = "CartridgesWindow"
navigation_view = Gtk.Template.Child()
toast_overlay = Gtk.Template.Child() toast_overlay = Gtk.Template.Child()
primary_menu_button = Gtk.Template.Child() primary_menu_button = Gtk.Template.Child()
stack = Gtk.Template.Child()
details_view = Gtk.Template.Child() details_view = Gtk.Template.Child()
library_page = Gtk.Template.Child()
library_view = Gtk.Template.Child() library_view = Gtk.Template.Child()
library = Gtk.Template.Child() library = Gtk.Template.Child()
scrolledwindow = Gtk.Template.Child() scrolledwindow = Gtk.Template.Child()
library_bin = Gtk.Template.Child() library_overlay = Gtk.Template.Child()
notice_empty = Gtk.Template.Child() notice_empty = Gtk.Template.Child()
notice_no_results = Gtk.Template.Child() notice_no_results = Gtk.Template.Child()
search_bar = Gtk.Template.Child() search_bar = Gtk.Template.Child()
search_entry = Gtk.Template.Child() search_entry = Gtk.Template.Child()
search_button = Gtk.Template.Child() search_button = Gtk.Template.Child()
details_page = Gtk.Template.Child()
details_view_box = Gtk.Template.Child() details_view_box = Gtk.Template.Child()
details_view_cover = Gtk.Template.Child() details_view_cover = Gtk.Template.Child()
details_view_spinner = Gtk.Template.Child() details_view_spinner = Gtk.Template.Child()
details_view_title = Gtk.Template.Child() details_view_title = Gtk.Template.Child()
details_view_header_bar_title = Gtk.Template.Child()
details_view_blurred_cover = Gtk.Template.Child() details_view_blurred_cover = Gtk.Template.Child()
details_view_play_button = Gtk.Template.Child() details_view_play_button = Gtk.Template.Child()
details_view_developer = Gtk.Template.Child() details_view_developer = Gtk.Template.Child()
@@ -53,11 +54,12 @@ class CartridgesWindow(Adw.ApplicationWindow):
details_view_last_played = Gtk.Template.Child() details_view_last_played = Gtk.Template.Child()
details_view_hide_button = Gtk.Template.Child() details_view_hide_button = Gtk.Template.Child()
hidden_library_page = Gtk.Template.Child()
hidden_primary_menu_button = Gtk.Template.Child() hidden_primary_menu_button = Gtk.Template.Child()
hidden_library = Gtk.Template.Child() hidden_library = Gtk.Template.Child()
hidden_library_view = Gtk.Template.Child() hidden_library_view = Gtk.Template.Child()
hidden_scrolledwindow = Gtk.Template.Child() hidden_scrolledwindow = Gtk.Template.Child()
hidden_library_bin = Gtk.Template.Child() hidden_library_overlay = Gtk.Template.Child()
hidden_notice_empty = Gtk.Template.Child() hidden_notice_empty = Gtk.Template.Child()
hidden_notice_no_results = Gtk.Template.Child() hidden_notice_no_results = Gtk.Template.Child()
hidden_search_bar = Gtk.Template.Child() hidden_search_bar = Gtk.Template.Child()
@@ -73,8 +75,6 @@ class CartridgesWindow(Adw.ApplicationWindow):
def __init__(self, **kwargs): def __init__(self, **kwargs):
super().__init__(**kwargs) super().__init__(**kwargs)
self.previous_page = self.library_view
self.details_view.set_measure_overlay(self.details_view_box, True) self.details_view.set_measure_overlay(self.details_view_box, True)
self.details_view.set_clip_overlay(self.details_view_box, False) self.details_view.set_clip_overlay(self.details_view_box, False)
@@ -99,12 +99,11 @@ class CartridgesWindow(Adw.ApplicationWindow):
self.search_entry.connect("search-changed", self.search_changed, False) self.search_entry.connect("search-changed", self.search_changed, False)
self.hidden_search_entry.connect("search-changed", self.search_changed, True) self.hidden_search_entry.connect("search-changed", self.search_changed, True)
self.search_entry.connect("activate", self.show_details_view_search) self.search_entry.connect("activate", self.show_details_page_search)
self.hidden_search_entry.connect("activate", self.show_details_view_search) self.hidden_search_entry.connect("activate", self.show_details_page_search)
back_mouse_button = Gtk.GestureClick(button=8) self.navigation_view.connect("popped", self.set_show_hidden)
(back_mouse_button).connect("pressed", self.on_go_back_action) self.navigation_view.connect("pushed", self.set_show_hidden)
self.add_controller(back_mouse_button)
style_manager = Adw.StyleManager.get_default() style_manager = Adw.StyleManager.get_default()
style_manager.connect("notify::dark", self.set_details_view_opacity) style_manager.connect("notify::dark", self.set_details_view_opacity)
@@ -121,25 +120,38 @@ class CartridgesWindow(Adw.ApplicationWindow):
if game.removed or game.blacklisted: if game.removed or game.blacklisted:
continue continue
if game.hidden: if game.hidden:
if game.filtered and hidden_child != self.hidden_scrolledwindow: if game.filtered and hidden_child:
hidden_child = self.hidden_notice_no_results hidden_child = self.hidden_notice_no_results
continue continue
hidden_child = self.hidden_scrolledwindow hidden_child = None
else: else:
if game.filtered and child != self.scrolledwindow: if game.filtered and child:
child = self.notice_no_results child = self.notice_no_results
continue continue
child = self.scrolledwindow child = None
self.library_bin.set_child(child) def remove_from_overlay(widget):
self.hidden_library_bin.set_child(hidden_child) if isinstance(widget.get_parent(), Gtk.Overlay):
widget.get_parent().remove_overlay(widget)
if child:
self.library_overlay.add_overlay(child)
else:
remove_from_overlay(self.notice_empty)
remove_from_overlay(self.notice_no_results)
if hidden_child:
self.hidden_library_overlay.add_overlay(hidden_child)
else:
remove_from_overlay(self.hidden_notice_empty)
remove_from_overlay(self.hidden_notice_no_results)
def filter_func(self, child): def filter_func(self, child):
game = child.get_child() game = child.get_child()
text = ( text = (
( (
self.hidden_search_entry self.hidden_search_entry
if self.stack.get_visible_child() == self.hidden_library_view if self.navigation_view.get_visible_page() == self.hidden_library_page
else self.search_entry else self.search_entry
) )
.get_text() .get_text()
@@ -159,7 +171,7 @@ class CartridgesWindow(Adw.ApplicationWindow):
def set_active_game(self, _widget, _pspec, game): def set_active_game(self, _widget, _pspec, game):
self.active_game = game self.active_game = game
def show_details_view(self, game): def show_details_page(self, game):
self.active_game = game self.active_game = game
self.details_view_cover.set_opacity(int(not game.loading)) self.details_view_cover.set_opacity(int(not game.loading))
@@ -186,7 +198,7 @@ class CartridgesWindow(Adw.ApplicationWindow):
) )
self.details_view_title.set_label(game.name) self.details_view_title.set_label(game.name)
self.details_view_header_bar_title.set_title(game.name) self.details_page.set_title(game.name)
date = relative_date(game.added) date = relative_date(game.added)
self.details_view_added.set_label( self.details_view_added.set_label(
@@ -201,14 +213,14 @@ class CartridgesWindow(Adw.ApplicationWindow):
_("Last played: {}").format(last_played_date) _("Last played: {}").format(last_played_date)
) )
if self.stack.get_visible_child() != self.details_view: if self.navigation_view.get_visible_page() != self.details_page:
self.navigate(self.details_view) self.navigation_view.push(self.details_page)
self.set_focus(self.details_view_play_button) self.set_focus(self.details_view_play_button)
self.set_details_view_opacity() self.set_details_view_opacity()
def set_details_view_opacity(self, *_args): def set_details_view_opacity(self, *_args):
if self.stack.get_visible_child() != self.details_view: if self.navigation_view.get_visible_page() != self.details_page:
return return
if ( if (
@@ -243,42 +255,20 @@ class CartridgesWindow(Adw.ApplicationWindow):
return ((get_value(0) > get_value(1)) ^ order) * 2 - 1 return ((get_value(0) > get_value(1)) ^ order) * 2 - 1
def navigate(self, next_page): def set_show_hidden(self, widget, *_args):
levels = (self.library_view, self.hidden_library_view, self.details_view) self.lookup_action("show_hidden").set_enabled(
self.stack.set_transition_type( widget.get_visible_page() == self.library_page
Gtk.StackTransitionType.UNDER_RIGHT
if levels.index(self.stack.get_visible_child()) - levels.index(next_page)
> 0
else Gtk.StackTransitionType.OVER_LEFT
) )
if next_page in (self.library_view, self.hidden_library_view):
self.previous_page = next_page
self.lookup_action("show_hidden").set_enabled(
next_page == self.library_view
)
self.stack.set_visible_child(next_page)
def on_go_back_action(self, *_args):
if self.stack.get_visible_child() == self.hidden_library_view:
self.navigate(self.library_view)
elif self.stack.get_visible_child() == self.details_view:
self.on_go_to_parent_action()
def on_go_to_parent_action(self, *_args): def on_go_to_parent_action(self, *_args):
if self.stack.get_visible_child() == self.details_view: if self.navigation_view.get_visible_page() == self.details_page:
self.navigate( self.navigation_view.pop()
self.hidden_library_view
if self.previous_page == self.hidden_library_view
else self.library_view
)
def on_go_home_action(self, *_args): def on_go_home_action(self, *_args):
self.navigate(self.library_view) self.navigation_view.pop_to_page(self.library_page)
def on_show_hidden_action(self, *_args): def on_show_hidden_action(self, *_args):
self.navigate(self.hidden_library_view) self.navigation_view.push(self.hidden_library_page)
def on_sort_action(self, action, state): def on_sort_action(self, action, state):
action.set_state(state) action.set_state(state)
@@ -288,10 +278,10 @@ class CartridgesWindow(Adw.ApplicationWindow):
shared.state_schema.set_string("sort-mode", self.sort_state) shared.state_schema.set_string("sort-mode", self.sort_state)
def on_toggle_search_action(self, *_args): def on_toggle_search_action(self, *_args):
if self.stack.get_visible_child() == self.library_view: if self.navigation_view.get_visible_page() == self.library_page:
search_bar = self.search_bar search_bar = self.search_bar
search_entry = self.search_entry search_entry = self.search_entry
elif self.stack.get_visible_child() == self.hidden_library_view: elif self.navigation_view.get_visible_page() == self.hidden_library_page:
search_bar = self.hidden_search_bar search_bar = self.hidden_search_bar
search_entry = self.hidden_search_entry search_entry = self.hidden_search_entry
else: else:
@@ -311,9 +301,9 @@ class CartridgesWindow(Adw.ApplicationWindow):
): ):
self.on_toggle_search_action() self.on_toggle_search_action()
else: else:
self.on_go_back_action() self.navigation_view.pop()
def show_details_view_search(self, widget): def show_details_page_search(self, widget):
library = ( library = (
self.hidden_library if widget == self.hidden_search_entry else self.library self.hidden_library if widget == self.hidden_search_entry else self.library
) )
@@ -324,7 +314,7 @@ class CartridgesWindow(Adw.ApplicationWindow):
break break
if self.filter_func(child): if self.filter_func(child):
self.show_details_view(child.get_child()) self.show_details_page(child.get_child())
break break
index += 1 index += 1
@@ -349,9 +339,9 @@ class CartridgesWindow(Adw.ApplicationWindow):
self.toasts.pop((game, undo)) self.toasts.pop((game, undo))
def on_open_menu_action(self, *_args): def on_open_menu_action(self, *_args):
if self.stack.get_visible_child() == self.library_view: if self.navigation_view.get_visible_page() == self.library_page:
self.primary_menu_button.popup() self.primary_menu_button.popup()
elif self.stack.get_visible_child() == self.hidden_library_view: elif self.navigation_view.get_visible_page() == self.hidden_library_page:
self.hidden_primary_menu_button.popup() self.hidden_primary_menu_button.popup()
def on_close_action(self, *_args): def on_close_action(self, *_args):