[gnome-games/wip/exalm/views2] A hacky preferences view
- From: Alexander Mikhaylenko <alexm src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-games/wip/exalm/views2] A hacky preferences view
- Date: Sat, 6 Oct 2018 21:15:44 +0000 (UTC)
commit 2a6740d5dd0c5fc6cd21e9d5dd0f9feac691f427
Author: Alexander Mikhaylenko <exalm7659 gmail com>
Date: Sun Oct 7 02:15:26 2018 +0500
A hacky preferences view
data/org.gnome.Games.gresource.xml | 1 +
data/ui/preferences-view.ui | 138 +++++++++++++++++++++++++++++++++++++
src/meson.build | 1 +
src/ui/application-view.vala | 2 +-
src/ui/application-window.vala | 19 ++++-
src/ui/application.vala | 2 +
src/ui/collection-view.vala | 2 +-
src/ui/display-view.vala | 2 +-
src/ui/preferences-view.vala | 129 ++++++++++++++++++++++++++++++++++
9 files changed, 290 insertions(+), 6 deletions(-)
---
diff --git a/data/org.gnome.Games.gresource.xml b/data/org.gnome.Games.gresource.xml
index 74eb5322..b8fecd49 100644
--- a/data/org.gnome.Games.gresource.xml
+++ b/data/org.gnome.Games.gresource.xml
@@ -36,6 +36,7 @@
<file preprocess="xml-stripblanks">ui/preferences-page-video.ui</file>
<file preprocess="xml-stripblanks">ui/preferences-subpage-gamepad.ui</file>
<file preprocess="xml-stripblanks">ui/preferences-subpage-keyboard.ui</file>
+ <file preprocess="xml-stripblanks">ui/preferences-view.ui</file>
<file preprocess="xml-stripblanks">ui/preferences-window.ui</file>
<file preprocess="xml-stripblanks">ui/quit-dialog.ui</file>
<file preprocess="xml-stripblanks">ui/remote-display.ui</file>
diff --git a/data/ui/preferences-view.ui b/data/ui/preferences-view.ui
new file mode 100644
index 00000000..610c16fe
--- /dev/null
+++ b/data/ui/preferences-view.ui
@@ -0,0 +1,138 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<interface>
+ <!-- interface-requires gtk+ 3.8 -->
+ <template class="GamesPreferencesView" parent="GtkStack">
+ <property name="visible">True</property>
+ <property name="transition-type">slide-left-right</property>
+ <property name="transition-duration">250</property>
+ <signal name="notify::transition-running" handler="subpage_transition_finished"/>
+ <child>
+ <object class="GtkBox" id="content_box">
+ <property name="visible">True</property>
+ <child>
+ <object class="GtkStackSidebar" id="sidebar">
+ <property name="margin-top">4</property>
+ <property name="stack">stack</property>
+ <property name="vexpand">True</property>
+ <property name="visible">True</property>
+ <property name="width-request">150</property>
+ <style>
+ <class name="preferences" />
+ </style>
+ </object>
+ </child>
+ <child>
+ <object class="GtkSeparator" id="separator">
+ <property name="orientation">vertical</property>
+ <property name="visible">True</property>
+ <style>
+ <class name="sidebar"/>
+ </style>
+ </object>
+ </child>
+ <child>
+ <object class="GtkStack" id="stack">
+ <property name="visible">True</property>
+ <property name="expand">True</property>
+ <property name="visible-child">video_page</property>
+ <property name="transition-type">GTK_STACK_TRANSITION_TYPE_CROSSFADE</property>
+ <child>
+ <object class="GamesPreferencesPageVideo" id="video_page">
+ <property name="visible">True</property>
+ </object>
+ <packing>
+ <property name="name">video</property>
+ <property name="title" translatable="yes">Video</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GamesPreferencesPageControllers" id="controllers_page">
+ <property name="visible">True</property>
+ </object>
+ <packing>
+ <property name="name">controllers</property>
+ <property name="title" translatable="yes">Controllers</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GamesPreferencesPagePlugins" id="plugins_page">
+ <property name="visible">True</property>
+ </object>
+ <packing>
+ <property name="name">plugins</property>
+ <property name="title" translatable="yes">Extensions</property>
+ </packing>
+ </child>
+ </object>
+ </child>
+ </object>
+ </child>
+ </template>
+ <object class="GtkSizeGroup">
+ <property name="mode">GTK_SIZE_GROUP_HORIZONTAL</property>
+ <widgets>
+ <widget name="left_header_bar"/>
+ <widget name="sidebar"/>
+ </widgets>
+ </object>
+ <object class="GtkStack" id="titlebar_stack">
+ <property name="visible">True</property>
+ <property name="transition-type">slide-left-right</property>
+ <property name="transition-duration">250</property>
+ <child>
+ <object class="GtkBox" id="titlebar_box">
+ <property name="visible">True</property>
+ <child>
+ <object class="GtkHeaderBar" id="left_header_bar">
+ <property name="name">left_header_bar</property>
+ <property name="visible">True</property>
+ <property name="title" translatable="yes">Preferences</property>
+ <property name="show-close-button">True</property>
+ <property name="decoration_layout">menu</property>
+ <child>
+ <object class="GtkButton" id="back_button">
+ <property name="visible">True</property>
+ <signal name="clicked" handler="on_back_clicked"/>
+ <style>
+ <class name="image-button"/>
+ </style>
+ <child internal-child="accessible">
+ <object class="AtkObject" id="a11y-back">
+ <property name="accessible-name" translatable="yes">Back</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImage" id="back_image">
+ <property name="visible">True</property>
+ <property name="icon-name">go-previous-symbolic</property>
+ <property name="icon-size">1</property>
+ </object>
+ </child>
+ </object>
+ <packing>
+ <property name="pack-type">start</property>
+ </packing>
+ </child>
+ </object>
+ </child>
+ <child>
+ <object class="GtkSeparator" id="header_separator">
+ <property name="orientation">vertical</property>
+ <property name="visible">True</property>
+ <style>
+ <class name="sidebar"/>
+ </style>
+ </object>
+ </child>
+ <child>
+ <object class="GtkHeaderBar" id="right_header_bar">
+ <property name="name">right_header_bar</property>
+ <property name="visible">True</property>
+ <property name="hexpand">True</property>
+ <property name="show-close-button">True</property>
+ </object>
+ </child>
+ </object>
+ </child>
+ </object>
+</interface>
diff --git a/src/meson.build b/src/meson.build
index baaf3cb8..e3474e2c 100644
--- a/src/meson.build
+++ b/src/meson.build
@@ -161,6 +161,7 @@ vala_sources = [
'ui/preferences-subpage.vala',
'ui/preferences-subpage-gamepad.vala',
'ui/preferences-subpage-keyboard.vala',
+ 'ui/preferences-view.vala',
'ui/preferences-window.vala',
'ui/quit-dialog.vala',
'ui/remote-display.vala',
diff --git a/src/ui/application-view.vala b/src/ui/application-view.vala
index e9fe2a58..b8181543 100644
--- a/src/ui/application-view.vala
+++ b/src/ui/application-view.vala
@@ -1,7 +1,7 @@
// This file is part of GNOME Games. License: GPL-3.0+.
private interface Games.ApplicationView: Gtk.Widget {
- public abstract Gtk.HeaderBar header_bar { get; }
+ public abstract Gtk.Widget titlebar { get; }
public abstract bool is_view_active { get; set; }
diff --git a/src/ui/application-window.vala b/src/ui/application-window.vala
index 4c8ed092..33673240 100644
--- a/src/ui/application-window.vala
+++ b/src/ui/application-window.vala
@@ -19,7 +19,7 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
_current_view = value;
content_box.visible_child = current_view;
- header_bar.visible_child = current_view.header_bar;
+ header_bar.visible_child = current_view.titlebar;
if (current_view != null)
current_view.is_view_active = true;
@@ -72,8 +72,8 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
}
construct {
- header_bar.add (collection_view.header_bar);
- header_bar.add (display_view.header_bar);
+ header_bar.add (collection_view.titlebar);
+ header_bar.add (display_view.titlebar);
current_view = collection_view;
settings = new Settings ("org.gnome.Games");
@@ -302,4 +302,17 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
critical (e.message);
}
}
+
+ public void show_preferences () {
+ var view = new PreferencesView ();
+ view.back.connect (() => {
+ current_view = collection_view;
+ content_box.remove (view);
+ header_bar.remove (view.titlebar);
+ });
+ view.show_back_button = true;
+ content_box.add (view);
+ header_bar.add (view.titlebar);
+ current_view = view;
+ }
}
diff --git a/src/ui/application.vala b/src/ui/application.vala
index 7d1797fe..5070c4ac 100644
--- a/src/ui/application.vala
+++ b/src/ui/application.vala
@@ -343,6 +343,8 @@ public class Games.Application : Gtk.Application {
}
private void preferences () {
+ window.show_preferences ();
+ return;
if (preferences_window != null) {
preferences_window.present ();
diff --git a/src/ui/collection-view.vala b/src/ui/collection-view.vala
index defb606c..1ad34d67 100644
--- a/src/ui/collection-view.vala
+++ b/src/ui/collection-view.vala
@@ -30,7 +30,7 @@ private class Games.CollectionView: Gtk.Box, ApplicationView {
[GtkChild (name = "header_bar")]
private Gtk.HeaderBar _header_bar;
- public Gtk.HeaderBar header_bar {
+ public Gtk.Widget titlebar {
get { return _header_bar; }
}
diff --git a/src/ui/display-view.vala b/src/ui/display-view.vala
index e9c2020d..73bb04be 100644
--- a/src/ui/display-view.vala
+++ b/src/ui/display-view.vala
@@ -12,7 +12,7 @@ private class Games.DisplayView: Gtk.Bin, ApplicationView {
[GtkChild (name = "header_bar")]
private DisplayHeaderBar _header_bar;
- public Gtk.HeaderBar header_bar {
+ public Gtk.Widget titlebar {
get { return _header_bar; }
}
diff --git a/src/ui/preferences-view.vala b/src/ui/preferences-view.vala
new file mode 100644
index 00000000..72d6befd
--- /dev/null
+++ b/src/ui/preferences-view.vala
@@ -0,0 +1,129 @@
+// This file is part of GNOME Games. License: GPL-3.0+.
+
+[GtkTemplate (ui = "/org/gnome/Games/ui/preferences-view.ui")]
+private class Games.PreferencesView : Gtk.Stack, ApplicationView {
+ public signal void back ();
+
+ [GtkChild]
+ private Gtk.Stack titlebar_stack;
+ [GtkChild]
+ private Gtk.Box titlebar_box;
+ [GtkChild]
+ private Gtk.HeaderBar right_header_bar;
+ [GtkChild]
+ private Gtk.Box content_box;
+ [GtkChild]
+ private Gtk.Stack stack;
+ [GtkChild]
+ private Gtk.Button back_button;
+
+ public bool selection_mode { get; set; }
+
+ public bool is_view_active { get; set; }
+
+ public bool show_back_button { get; set; }
+
+ public Gtk.Widget titlebar {
+ get {
+ return titlebar_stack;
+ }
+ }
+
+ private PreferencesSubpage _subpage;
+ public PreferencesSubpage subpage {
+ get { return _subpage; }
+ set {
+ if (subpage == value)
+ return;
+
+ if (subpage != null) {
+ previous_subpage = subpage;
+ visible_child = content_box;
+ titlebar_stack.visible_child = titlebar_box;
+ selection_mode_binding.unbind ();
+ }
+
+ if (value != null) {
+ var header_bar = value.header_bar;
+
+ add (value);
+ visible_child = value;
+
+ selection_mode_binding = value.bind_property ("request-selection-mode",
+ this, "selection-mode",
+ BindingFlags.SYNC_CREATE);
+
+ titlebar_stack.add (header_bar);
+ titlebar_stack.visible_child = header_bar;
+ }
+
+ _subpage = value;
+ }
+ }
+
+ // The previous subpage instance must be kept around during the transition
+ private PreferencesSubpage previous_subpage;
+
+ private Binding subpage_binding;
+ private Binding selection_mode_binding;
+ private Binding back_button_binding;
+
+ public PreferencesView () {
+ stack.notify["visible-child-name"].connect (visible_child_changed);
+ back_button_binding = bind_property ("show-back-button", back_button,
+ "visible", BindingFlags.SYNC_CREATE);
+ visible_child_changed ();
+ }
+
+ private void visible_child_changed () {
+ var page = stack.visible_child as PreferencesPage;
+ if (page == null) {
+ right_header_bar.title = "";
+ subpage = null;
+
+ return;
+ }
+
+ var title = "";
+ stack.child_get (page, "title", out title, null);
+ right_header_bar.title = title;
+
+ subpage_binding = page.bind_property ("subpage", this, "subpage",
+ BindingFlags.SYNC_CREATE);
+ }
+
+ [GtkCallback]
+ public void subpage_transition_finished (Object object, ParamSpec param) {
+ if (transition_running || previous_subpage == null)
+ return;
+
+ remove (previous_subpage);
+ titlebar_stack.remove (previous_subpage.header_bar);
+ previous_subpage = null;
+ }
+
+ [GtkCallback]
+ private void on_back_clicked () {
+ back ();
+ }
+
+ public bool on_button_pressed (Gdk.EventButton event) {
+ return false;
+ }
+
+ public bool on_key_pressed (Gdk.EventKey event) {
+ return false;
+ }
+
+ public bool gamepad_button_press_event (Manette.Event event) {
+ return false;
+ }
+
+ public bool gamepad_button_release_event (Manette.Event event) {
+ return false;
+ }
+
+ public bool gamepad_absolute_axis_event (Manette.Event event) {
+ return false;
+ }
+}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]