[gnome-games/wip/exalm/views: 5/14] application-window: Use DisplayBox
- From: Alexander Mikhaylenko <alexm src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-games/wip/exalm/views: 5/14] application-window: Use DisplayBox
- Date: Thu, 4 Oct 2018 16:44:37 +0000 (UTC)
commit fffa18df65819223634b8b40afd3bd014b48e37f
Author: Alexander Mikhaylenko <exalm7659 gmail com>
Date: Thu Oct 4 21:05:10 2018 +0500
application-window: Use DisplayBox
data/ui/application-window.ui | 15 +-------
src/ui/application-window.vala | 79 +++++++++++++++++++++---------------------
2 files changed, 41 insertions(+), 53 deletions(-)
---
diff --git a/data/ui/application-window.ui b/data/ui/application-window.ui
index b75b4732..b05633d8 100644
--- a/data/ui/application-window.ui
+++ b/data/ui/application-window.ui
@@ -21,29 +21,16 @@
</object>
</child>
<child>
- <object class="GamesDisplayBox" id="display_box">
+ <object class="GamesDisplayView" id="display_view">
<property name="visible">True</property>
<signal name="back" handler="on_display_back"/>
</object>
- <packing>
- <property name="name">display</property>
- </packing>
</child>
</object>
</child>
<child type="titlebar">
<object class="GtkStack" id="header_bar">
<property name="visible">True</property>
- <child>
- <object class="GamesDisplayHeaderBar" id="display_header_bar">
- <property name="visible">True</property>
- <property name="show_close_button">True</property>
- <signal name="back" handler="on_display_back"/>
- </object>
- <packing>
- <property name="name">display</property>
- </packing>
- </child>
</object>
</child>
</template>
diff --git a/src/ui/application-window.vala b/src/ui/application-window.vala
index d1aaa302..7d838674 100644
--- a/src/ui/application-window.vala
+++ b/src/ui/application-window.vala
@@ -21,21 +21,23 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
content_box.visible_child = collection_view;
header_bar.visible_child = collection_view.header_bar;
+ display_view.is_view_active = false;
collection_view.is_view_active = true;
is_fullscreen = false;
- if (display_box.runner != null) {
- display_box.runner.stop ();
- display_box.runner = null;
+ if (display_view.display_box.runner != null) {
+ display_view.display_box.runner.stop ();
+ display_view.display_box.runner = null;
}
break;
case UiState.DISPLAY:
- content_box.visible_child = display_box;
- header_bar.visible_child = display_header_bar;
+ content_box.visible_child = display_view;
+ header_bar.visible_child = display_view.header_bar;
collection_view.is_view_active = false;
+ display_view.is_view_active = true;
search_mode = false;
@@ -74,12 +76,10 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
[GtkChild]
private CollectionView collection_view;
[GtkChild]
- private DisplayBox display_box;
+ private DisplayView display_view;
[GtkChild]
private Gtk.Stack header_bar;
- [GtkChild]
- private DisplayHeaderBar display_header_bar;
private Settings settings;
@@ -108,6 +108,7 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
public ApplicationWindow (ListModel collection) {
collection_view.window = this;
+ display_view.window = this;
collection_view.collection = collection;
collection.items_changed.connect (() => {
is_collection_empty = collection.get_n_items () == 0;
@@ -117,7 +118,7 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
construct {
header_bar.add (collection_view.header_bar);
- header_bar.visible_child = collection_view.header_bar;
+ header_bar.add (display_view.header_bar);
settings = new Settings ("org.gnome.Games");
@@ -140,9 +141,9 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
header_bar_search_binding = bind_property ("search-mode",
collection_view.collection_header_bar, "search-mode",
BindingFlags.BIDIRECTIONAL);
- box_fullscreen_binding = bind_property ("is-fullscreen", display_box, "is-fullscreen",
+ box_fullscreen_binding = bind_property ("is-fullscreen", display_view.display_box,
"is-fullscreen",
BindingFlags.BIDIRECTIONAL);
- header_bar_fullscreen_binding = bind_property ("is-fullscreen", display_header_bar,
"is-fullscreen",
+ header_bar_fullscreen_binding = bind_property ("is-fullscreen",
display_view.display_header_bar, "is-fullscreen",
BindingFlags.BIDIRECTIONAL);
box_empty_collection_binding = bind_property ("is-collection-empty",
collection_view.collection_box, "is-collection-empty",
@@ -340,8 +341,8 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
}
private void run_game_with_cancellable (Game game, Cancellable cancellable) {
- display_header_bar.game_title = game.name;
- display_box.header_bar.game_title = game.name;
+ display_view.display_header_bar.game_title = game.name;
+ display_view.display_box.header_bar.game_title = game.name;
ui_state = UiState.DISPLAY;
// Reset the UI parts depending on the runner to avoid an
@@ -352,11 +353,11 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
if (runner == null)
return;
- display_header_bar.can_fullscreen = runner.can_fullscreen;
- display_box.header_bar.can_fullscreen = runner.can_fullscreen;
- display_box.runner = runner;
- display_header_bar.media_set = runner.media_set;
- display_box.header_bar.media_set = runner.media_set;
+ display_view.display_header_bar.can_fullscreen = runner.can_fullscreen;
+ display_view.display_box.header_bar.can_fullscreen = runner.can_fullscreen;
+ display_view.display_box.runner = runner;
+ display_view.display_header_bar.media_set = runner.media_set;
+ display_view.display_box.header_bar.media_set = runner.media_set;
is_fullscreen = settings.get_boolean ("fullscreen") && runner.can_fullscreen;
@@ -376,14 +377,14 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
return runner;
reset_display_page ();
- display_box.display_running_game_failed (game, error_message);
+ display_view.display_box.display_running_game_failed (game, error_message);
return null;
}
catch (Error e) {
warning (e.message);
reset_display_page ();
- display_box.display_running_game_failed (game, _("An unexpected error occurred."));
+ display_view.display_box.display_running_game_failed (game, _("An unexpected error
occurred."));
return null;
}
@@ -417,7 +418,7 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
private bool try_run_with_cancellable (Runner runner, bool resume, Cancellable cancellable) {
try {
if (resume)
- display_box.runner.resume ();
+ display_view.display_box.runner.resume ();
else
runner.start ();
@@ -450,7 +451,7 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
response = Gtk.ResponseType.CANCEL;
if (response == Gtk.ResponseType.CANCEL) {
- display_box.runner = null;
+ display_view.display_box.runner = null;
ui_state = UiState.COLLECTION;
return;
@@ -465,12 +466,12 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
}
public bool quit_game_with_cancellable (Cancellable cancellable) {
- if (display_box.runner == null)
+ if (display_view.display_box.runner == null)
return true;
- display_box.runner.stop ();
+ display_view.display_box.runner.stop ();
- if (display_box.runner.can_quit_safely)
+ if (display_view.display_box.runner.can_quit_safely)
return true;
if (quit_dialog != null)
@@ -498,9 +499,9 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
}
private bool cancel_quitting_game () {
- if (display_box.runner != null)
+ if (display_view.display_box.runner != null)
try {
- display_box.runner.resume ();
+ display_view.display_box.runner.resume ();
}
catch (Error e) {
warning (e.message);
@@ -562,7 +563,7 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
if (is_active)
try {
- display_box.runner.resume ();
+ display_view.display_box.runner.resume ();
}
catch (Error e) {
warning (e.message);
@@ -570,7 +571,7 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
else if (with_delay)
focus_out_timeout_id = Timeout.add (FOCUS_OUT_DELAY_MILLISECONDS,
on_focus_out_delay_elapsed);
else
- display_box.runner.pause ();
+ display_view.display_box.runner.pause ();
}
private bool on_focus_out_delay_elapsed () {
@@ -580,7 +581,7 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
return false;
if (!is_active)
- display_box.runner.pause ();
+ display_view.display_box.runner.pause ();
return false;
}
@@ -589,7 +590,7 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
if (ui_state != UiState.DISPLAY)
return false;
- if (display_box.runner == null)
+ if (display_view.display_box.runner == null)
return false;
if (run_game_cancellable != null)
@@ -626,21 +627,21 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
if ((event.keyval == Gdk.Key.f || event.keyval == Gdk.Key.F) &&
(event.state & default_modifiers) == Gdk.ModifierType.CONTROL_MASK &&
- display_header_bar.can_fullscreen) {
+ display_view.display_header_bar.can_fullscreen) {
is_fullscreen = !is_fullscreen;
settings.set_boolean ("fullscreen", is_fullscreen);
return true;
}
- if (event.keyval == Gdk.Key.F11 && display_header_bar.can_fullscreen) {
+ if (event.keyval == Gdk.Key.F11 && display_view.display_header_bar.can_fullscreen) {
is_fullscreen = !is_fullscreen;
settings.set_boolean ("fullscreen", is_fullscreen);
return true;
}
- if (event.keyval == Gdk.Key.Escape && display_header_bar.can_fullscreen) {
+ if (event.keyval == Gdk.Key.Escape && display_view.display_header_bar.can_fullscreen) {
is_fullscreen = false;
settings.set_boolean ("fullscreen", false);
@@ -690,11 +691,11 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
}
private void reset_display_page () {
- display_header_bar.can_fullscreen = false;
- display_box.header_bar.can_fullscreen = false;
- display_box.runner = null;
- display_header_bar.media_set = null;
- display_box.header_bar.media_set = null;
+ display_view.display_header_bar.can_fullscreen = false;
+ display_view.display_box.header_bar.can_fullscreen = false;
+ display_view.display_box.runner = null;
+ display_view.display_header_bar.media_set = null;
+ display_view.display_box.header_bar.media_set = null;
}
private void on_konami_code_performed () {
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]