[geary/wip/714104-refine-account-dialog: 20/69] Add initial replacement account editor pane.
- From: Michael Gratton <mjog src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [geary/wip/714104-refine-account-dialog: 20/69] Add initial replacement account editor pane.
- Date: Fri, 30 Nov 2018 12:50:01 +0000 (UTC)
commit 2f0a7b9c18edceefb4ec29e8558fa3eab9dd18d8
Author: Michael James Gratton <mike vee net>
Date: Sun Jun 3 19:28:02 2018 +1000
Add initial replacement account editor pane.
po/POTFILES.in | 3 +
src/client/accounts/accounts-editor-edit-pane.vala | 161 ++++++++++++++++
src/client/accounts/accounts-editor-row.vala | 68 +++++++
src/client/accounts/accounts-editor.vala | 117 ++++++-----
src/client/application/geary-application.vala | 5 +-
src/client/meson.build | 2 +
ui/accounts_editor.ui | 51 ++++-
ui/accounts_editor_edit_pane.ui | 213 +++++++++++++++++++++
ui/geary.css | 12 +-
ui/org.gnome.Geary.gresource.xml | 1 +
10 files changed, 575 insertions(+), 58 deletions(-)
---
diff --git a/po/POTFILES.in b/po/POTFILES.in
index 4cd98244..35b8c704 100644
--- a/po/POTFILES.in
+++ b/po/POTFILES.in
@@ -18,6 +18,8 @@ src/client/accounts/account-dialogs.vala
src/client/accounts/account-manager.vala
src/client/accounts/account-spinner-page.vala
src/client/accounts/accounts-editor.vala
+src/client/accounts/accounts-editor-edit-pane.vala
+src/client/accounts/accounts-editor-row.vala
src/client/accounts/add-edit-page.vala
src/client/accounts/editor.vala
src/client/accounts/goa-service-information.vala
@@ -408,6 +410,7 @@ ui/account_cannot_remove.glade
ui/account_list.glade
ui/account_spinner.glade
ui/accounts_editor.ui
+ui/accounts_editor_edit_pane.ui
ui/certificate_warning_dialog.glade
ui/composer-headerbar.ui
ui/composer-link-popover.ui
diff --git a/src/client/accounts/accounts-editor-edit-pane.vala
b/src/client/accounts/accounts-editor-edit-pane.vala
new file mode 100644
index 00000000..932efd1b
--- /dev/null
+++ b/src/client/accounts/accounts-editor-edit-pane.vala
@@ -0,0 +1,161 @@
+/*
+ * Copyright 2018 Michael Gratton <mike vee net>
+ *
+ * This software is licensed under the GNU Lesser General Public License
+ * (version 2.1 or later). See the COPYING file in this distribution.
+ */
+
+/**
+ * The main account editor window.
+ */
+[GtkTemplate (ui = "/org/gnome/Geary/accounts_editor_edit_pane.ui")]
+public class Accounts.EditorEditPane : Gtk.Grid {
+
+
+ private Geary.AccountInformation account;
+
+ [GtkChild]
+ private Gtk.ListBox details_list;
+
+ [GtkChild]
+ private Gtk.ListBox addresses_list;
+
+ [GtkChild]
+ private Gtk.ScrolledWindow signature_scrolled;
+
+ private ClientWebView signature_preview;
+
+ [GtkChild]
+ private Gtk.ListBox settings_list;
+
+
+ public EditorEditPane(GearyApplication application,
+ Geary.AccountInformation account) {
+ this.account = account;
+
+ PropertyRow nickname_row = new PropertyRow(
+ account,
+ "nickname",
+ // Translators: This label in the account editor is for
+ // the user's name for an account.
+ _("Account name")
+ );
+ nickname_row.set_dim_label(true);
+
+ this.details_list.set_header_func(Editor.seperator_headers);
+ this.details_list.add(nickname_row);
+
+ this.addresses_list.set_header_func(Editor.seperator_headers);
+ this.addresses_list.add(
+ new AddressRow(account.primary_mailbox, get_login_session_name())
+ );
+
+ string? default_name = account.primary_mailbox.name;
+ if (Geary.String.is_empty_or_whitespace(default_name)) {
+ default_name = null;
+ }
+ if (account.alternate_mailboxes != null) {
+ foreach (Geary.RFC822.MailboxAddress alt
+ in account.alternate_mailboxes) {
+ this.addresses_list.add(new AddressRow(alt, default_name));
+ }
+ }
+
+ this.addresses_list.add(new AddRow());
+
+ this.signature_preview = new ClientWebView(application.config);
+ this.signature_preview.load_html(account.email_signature);
+ this.signature_preview.show();
+
+ this.signature_scrolled.add(this.signature_preview);
+
+ this.settings_list.set_header_func(Editor.seperator_headers);
+ // No settings to show at the moment, so hide the list and its
+ // frame until we do.
+ this.settings_list.get_parent().hide();
+ }
+
+ private string? get_login_session_name() {
+ string? name = Environment.get_real_name();
+ if (Geary.String.is_empty(name) || name == "Unknown") {
+ name = null;
+ }
+ return name;
+ }
+
+}
+
+
+private class Accounts.PropertyRow : LabelledEditorRow {
+
+
+ private GLib.Object object;
+ private string property_name;
+
+ private Gtk.Label value = new Gtk.Label("");
+
+
+ public PropertyRow(Object object,
+ string property_name,
+ string label) {
+ base(label);
+
+ this.object = object;
+ this.property_name = property_name;
+
+ this.value.show();
+ this.layout.add(this.value);
+
+ update();
+ }
+
+ public void update() {
+ string? value = null;
+ this.object.get(this.property_name, ref value);
+
+ if (value != null) {
+ this.value.set_text(value);
+ }
+ }
+
+}
+
+
+private class Accounts.AddressRow : LabelledEditorRow {
+
+
+ private Geary.RFC822.MailboxAddress address;
+ private string? fallback_name;
+
+ private Gtk.Label value = new Gtk.Label("");
+
+
+ public AddressRow(Geary.RFC822.MailboxAddress address,
+ string? fallback_name) {
+ base("");
+ this.address = address;
+ this.fallback_name = fallback_name;
+
+ this.value.show();
+ this.layout.add(this.value);
+
+ update();
+ }
+
+ public void update() {
+ string? name = Geary.String.is_empty_or_whitespace(this.address.name)
+ ? this.fallback_name
+ : this.address.name;
+
+ if (Geary.String.is_empty_or_whitespace(name)) {
+ name = _("No name set");
+ set_dim_label(true);
+ } else {
+ set_dim_label(false);
+ }
+
+ this.label.set_text(name);
+ this.value.set_text(this.address.address.strip());
+ }
+
+}
diff --git a/src/client/accounts/accounts-editor-row.vala b/src/client/accounts/accounts-editor-row.vala
new file mode 100644
index 00000000..f142897b
--- /dev/null
+++ b/src/client/accounts/accounts-editor-row.vala
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2018 Michael Gratton <mike vee net>
+ *
+ * This software is licensed under the GNU Lesser General Public License
+ * (version 2.1 or later). See the COPYING file in this distribution.
+ */
+
+
+internal class Accounts.EditorRow : Gtk.ListBoxRow {
+
+
+ protected Gtk.Grid layout { get; private set; default = new Gtk.Grid(); }
+
+
+ public EditorRow() {
+ get_style_context().add_class("geary-settings");
+
+ this.layout.orientation = Gtk.Orientation.HORIZONTAL;
+ this.layout.show();
+ add(this.layout);
+
+ this.show();
+ }
+
+}
+
+
+internal class Accounts.LabelledEditorRow : EditorRow {
+
+
+ protected Gtk.Label label { get; private set; default = new Gtk.Label(""); }
+
+
+ public LabelledEditorRow(string label) {
+ this.label.set_text(label);
+ this.label.set_hexpand(true);
+ this.label.halign = Gtk.Align.START;
+ this.label.show();
+
+ this.layout.add(this.label);
+ }
+
+ public void set_dim_label(bool is_dim) {
+ if (is_dim) {
+ this.label.get_style_context().add_class(Gtk.STYLE_CLASS_DIM_LABEL);
+ } else {
+ this.label.get_style_context().remove_class(Gtk.STYLE_CLASS_DIM_LABEL);
+ }
+ }
+
+}
+
+
+internal class Accounts.AddRow : EditorRow {
+
+
+ public AddRow() {
+ Gtk.Image add_icon = new Gtk.Image.from_icon_name(
+ "list-add-symbolic", Gtk.IconSize.BUTTON
+ );
+ add_icon.set_hexpand(true);
+ add_icon.show();
+
+ this.layout.add(add_icon);
+ }
+
+
+}
diff --git a/src/client/accounts/accounts-editor.vala b/src/client/accounts/accounts-editor.vala
index eb4729ab..cdf46c4e 100644
--- a/src/client/accounts/accounts-editor.vala
+++ b/src/client/accounts/accounts-editor.vala
@@ -12,6 +12,15 @@
public class Accounts.Editor : Gtk.Dialog {
+ internal static void seperator_headers(Gtk.ListBoxRow row,
+ Gtk.ListBoxRow? first) {
+ if (first == null) {
+ row.set_header(null);
+ } else if (row.get_header() == null) {
+ row.set_header(new Gtk.Separator(Gtk.Orientation.HORIZONTAL));
+ }
+ }
+
private static int ordinal_sort(Gtk.ListBoxRow a, Gtk.ListBoxRow b) {
AccountRow? account_a = a as AccountRow;
AccountRow? account_b = b as AccountRow;
@@ -27,25 +36,46 @@ public class Accounts.Editor : Gtk.Dialog {
);
}
- private static void update_header(Gtk.ListBoxRow row, Gtk.ListBoxRow? first) {
- if (first == null) {
- row.set_header(null);
- } else if (row.get_header() == null) {
- row.set_header(new Gtk.Separator(Gtk.Orientation.HORIZONTAL));
- }
- }
+
+ /**
+ * The current application instance.
+ *
+ * Note this hides the {@link GtkWindow.application} property
+ * since we don't want the application to know about this dialog -
+ * it should not prevent the app from closing.
+ */
+ internal new GearyApplication application { get; private set; }
private AccountManager accounts;
+ [GtkChild]
+ private Gtk.HeaderBar default_header;
+
+ [GtkChild]
+ private Gtk.Stack editor_panes;
+
+ [GtkChild]
+ private Gtk.Button back_button;
+
+ [GtkChild]
+ private Gtk.Grid list_pane;
+
[GtkChild]
private Gtk.ListBox accounts_list;
- public Editor(AccountManager accounts, Gtk.Window parent) {
- this.accounts = accounts;
+ public Editor(GearyApplication application, Gtk.Window parent) {
+ this.application = application;
+ this.accounts = application.controller.account_manager;
+
+ set_titlebar(this.default_header);
set_transient_for(parent);
+ set_modal(true);
+
+ // XXX Glade 3.22 won't let us set this
+ get_content_area().border_width = 2;
- this.accounts_list.set_header_func(update_header);
+ this.accounts_list.set_header_func(seperator_headers);
this.accounts_list.set_sort_func(ordinal_sort);
foreach (Geary.AccountInformation account in accounts.iterable()) {
@@ -70,6 +100,15 @@ public class Accounts.Editor : Gtk.Dialog {
this.accounts_list.add(new AccountRow(account, status));
}
+ private void show_account(Geary.AccountInformation account) {
+ EditorEditPane account_pane = new EditorEditPane(
+ (GearyApplication) this.application,account
+ );
+ this.editor_panes.add(account_pane);
+ this.editor_panes.set_visible_child(account_pane);
+ this.back_button.show();
+ }
+
private AccountRow? get_account_row(Geary.AccountInformation account) {
AccountRow? row = null;
this.accounts_list.foreach((child) => {
@@ -101,12 +140,30 @@ public class Accounts.Editor : Gtk.Dialog {
}
}
+ [GtkCallback]
+ private void on_accounts_list_row_activated(Gtk.ListBoxRow activated) {
+ AccountRow? row = activated as AccountRow;
+ if (row != null) {
+ show_account(row.account);
+ }
+ }
+
+ [GtkCallback]
+ private void on_back_button_clicked() {
+ Gtk.Widget visible_pane = this.editor_panes.get_visible_child();
+ if (visible_pane != list_pane) {
+ this.editor_panes.remove(visible_pane);
+ } else {
+ this.back_button.hide();
+ }
+ }
+
}
-private class Accounts.AccountRow : Gtk.ListBoxRow {
+private class Accounts.AccountRow : EditorRow {
- public Geary.AccountInformation account;
+ internal Geary.AccountInformation account;
private Gtk.Image unavailable_icon = new Gtk.Image.from_icon_name(
"dialog-warning-symbolic", Gtk.IconSize.BUTTON
@@ -118,20 +175,16 @@ private class Accounts.AccountRow : Gtk.ListBoxRow {
public AccountRow(Geary.AccountInformation account,
AccountManager.Status status) {
this.account = account;
- get_style_context().add_class("geary-settings");
-
- this.unavailable_icon.no_show_all = true;
+ this.account_name.show();
this.account_name.set_hexpand(true);
this.account_name.halign = Gtk.Align.START;
- Gtk.Grid layout = new Gtk.Grid();
- layout.orientation = Gtk.Orientation.HORIZONTAL;
- layout.add(this.unavailable_icon);
- layout.add(this.account_name);
- layout.add(this.account_details);
+ this.account_details.show();
- add(layout);
+ this.layout.add(this.unavailable_icon);
+ this.layout.add(this.account_name);
+ this.layout.add(this.account_details);
update(status);
}
@@ -187,25 +240,3 @@ private class Accounts.AccountRow : Gtk.ListBoxRow {
}
}
-
-private class Accounts.AddRow : Gtk.ListBoxRow {
-
-
- public AddRow() {
- get_style_context().add_class("geary-settings");
-
- Gtk.Image add_icon = new Gtk.Image.from_icon_name(
- "list-add-symbolic", Gtk.IconSize.BUTTON
- );
- add_icon.set_hexpand(true);
-
- Gtk.Grid layout = new Gtk.Grid();
- layout.orientation = Gtk.Orientation.HORIZONTAL;
-
- layout.add(add_icon);
-
- add(layout);
- }
-
-
-}
diff --git a/src/client/application/geary-application.vala b/src/client/application/geary-application.vala
index d3cf494b..96e831dc 100644
--- a/src/client/application/geary-application.vala
+++ b/src/client/application/geary-application.vala
@@ -422,10 +422,7 @@ public class GearyApplication : Gtk.Application {
}
private void on_activate_accounts() {
- Accounts.Editor editor = new Accounts.Editor(
- this.controller.account_manager, get_active_window()
- );
- editor.show_all();
+ Accounts.Editor editor = new Accounts.Editor(this, get_active_window());
editor.run();
editor.destroy();
}
diff --git a/src/client/meson.build b/src/client/meson.build
index 906a274e..e248cf2e 100644
--- a/src/client/meson.build
+++ b/src/client/meson.build
@@ -20,6 +20,8 @@ geary_client_vala_sources = files(
'accounts/account-manager.vala',
'accounts/account-spinner-page.vala',
'accounts/accounts-editor.vala',
+ 'accounts/accounts-editor-edit-pane.vala',
+ 'accounts/accounts-editor-row.vala',
'accounts/add-edit-page.vala',
'accounts/goa-service-information.vala',
'accounts/local-service-information.vala',
diff --git a/ui/accounts_editor.ui b/ui/accounts_editor.ui
index 7750d947..e15b5fd9 100644
--- a/ui/accounts_editor.ui
+++ b/ui/accounts_editor.ui
@@ -13,7 +13,6 @@
<object class="GtkBox">
<property name="can_focus">False</property>
<property name="orientation">vertical</property>
- <property name="spacing">2</property>
<child internal-child="action_area">
<object class="GtkButtonBox">
<property name="can_focus">False</property>
@@ -32,11 +31,12 @@
</packing>
</child>
<child>
- <object class="GtkStack">
+ <object class="GtkStack" id="editor_panes">
<property name="visible">True</property>
<property name="can_focus">False</property>
+ <property name="transition_type">slide-left-right</property>
<child>
- <object class="GtkGrid">
+ <object class="GtkGrid" id="list_pane">
<property name="visible">True</property>
<property name="can_focus">False</property>
<child>
@@ -59,8 +59,8 @@
<object class="GtkFrame">
<property name="visible">True</property>
<property name="can_focus">False</property>
- <property name="margin_top">32</property>
- <property name="margin_bottom">32</property>
+ <property name="hexpand">True</property>
+ <property name="vexpand">True</property>
<property name="label_xalign">0</property>
<property name="shadow_type">in</property>
<child>
@@ -69,6 +69,7 @@
<property name="visible">True</property>
<property name="can_focus">False</property>
<property name="selection_mode">none</property>
+ <signal name="row-activated" handler="on_accounts_list_row_activated"
swapped="no"/>
</object>
</child>
<child type="label_item">
@@ -107,13 +108,43 @@
</child>
</object>
</child>
- <child type="titlebar">
- <object class="GtkHeaderBar">
+ <child>
+ <placeholder/>
+ </child>
+ <style>
+ <class name="geary-accounts-editor"/>
+ </style>
+ </template>
+ <object class="GtkHeaderBar" id="default_header">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="title">Accounts</property>
+ <property name="has_subtitle">False</property>
+ <property name="show_close_button">True</property>
+ <child>
+ <object class="GtkGrid">
<property name="visible">True</property>
<property name="can_focus">False</property>
- <property name="title">Accounts</property>
- <property name="show_close_button">True</property>
+ <child>
+ <object class="GtkButton" id="back_button">
+ <property name="can_focus">True</property>
+ <property name="receives_default">True</property>
+ <signal name="clicked" handler="on_back_button_clicked" swapped="no"/>
+ <child>
+ <object class="GtkImage">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="no_show_all">True</property>
+ <property name="icon_name">go-previous-symbolic</property>
+ </object>
+ </child>
+ </object>
+ <packing>
+ <property name="left_attach">0</property>
+ <property name="top_attach">0</property>
+ </packing>
+ </child>
</object>
</child>
- </template>
+ </object>
</interface>
diff --git a/ui/accounts_editor_edit_pane.ui b/ui/accounts_editor_edit_pane.ui
new file mode 100644
index 00000000..5e0ce99b
--- /dev/null
+++ b/ui/accounts_editor_edit_pane.ui
@@ -0,0 +1,213 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!-- Generated with glade 3.22.0 -->
+<interface>
+ <requires lib="gtk+" version="3.20"/>
+ <template class="AccountsEditorEditPane" parent="GtkGrid">
+ <property name="name">1</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <child>
+ <object class="GtkScrolledWindow">
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="hexpand">True</property>
+ <property name="vexpand">True</property>
+ <property name="hscrollbar_policy">never</property>
+ <property name="min_content_height">400</property>
+ <child>
+ <object class="GtkViewport">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <child>
+ <object class="GtkGrid">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <child>
+ <object class="GtkFrame">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="hexpand">True</property>
+ <property name="label_xalign">0</property>
+ <property name="shadow_type">in</property>
+ <child>
+ <object class="GtkListBox" id="details_list">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="selection_mode">none</property>
+ </object>
+ </child>
+ <child type="label_item">
+ <placeholder/>
+ </child>
+ </object>
+ <packing>
+ <property name="left_attach">0</property>
+ <property name="top_attach">0</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkLabel">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="halign">start</property>
+ <property name="label" translatable="yes">Email addresses</property>
+ <style>
+ <class name="geary-settings-heading"/>
+ </style>
+ </object>
+ <packing>
+ <property name="left_attach">0</property>
+ <property name="top_attach">1</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkFrame">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="hexpand">True</property>
+ <property name="label_xalign">0</property>
+ <property name="shadow_type">in</property>
+ <child>
+ <object class="GtkListBox" id="addresses_list">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="selection_mode">none</property>
+ </object>
+ </child>
+ <child type="label_item">
+ <placeholder/>
+ </child>
+ </object>
+ <packing>
+ <property name="left_attach">0</property>
+ <property name="top_attach">2</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkLabel">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="halign">start</property>
+ <property name="label" translatable="yes">Signature</property>
+ <style>
+ <class name="geary-settings-heading"/>
+ </style>
+ </object>
+ <packing>
+ <property name="left_attach">0</property>
+ <property name="top_attach">3</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkFrame">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="hexpand">True</property>
+ <property name="label_xalign">0</property>
+ <property name="shadow_type">in</property>
+ <child>
+ <object class="GtkListBox" id="settings_list">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="selection_mode">none</property>
+ </object>
+ </child>
+ <child type="label_item">
+ <placeholder/>
+ </child>
+ </object>
+ <packing>
+ <property name="left_attach">0</property>
+ <property name="top_attach">5</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkButtonBox">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="layout_style">end</property>
+ <child>
+ <object class="GtkButton">
+ <property name="label" translatable="yes" comments="This is a button in the account
settings to show server settings.">Server Settings</property>
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="receives_default">True</property>
+ </object>
+ <packing>
+ <property name="expand">True</property>
+ <property name="fill">True</property>
+ <property name="pack_type">end</property>
+ <property name="position">0</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkButton">
+ <property name="label" translatable="yes" comments="This is the remove account
button in the account settings.">Remove Account</property>
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="receives_default">True</property>
+ <property name="tooltip_text" translatable="yes">Remove this account from
Geary</property>
+ <style>
+ <class name="destructive-action"/>
+ </style>
+ </object>
+ <packing>
+ <property name="expand">True</property>
+ <property name="fill">True</property>
+ <property name="pack_type">end</property>
+ <property name="position">1</property>
+ <property name="secondary">True</property>
+ </packing>
+ </child>
+ <style>
+ <class name="geary-settings"/>
+ </style>
+ </object>
+ <packing>
+ <property name="left_attach">0</property>
+ <property name="top_attach">6</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkFrame">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="label_xalign">0</property>
+ <property name="shadow_type">in</property>
+ <child>
+ <object class="GtkScrolledWindow" id="signature_scrolled">
+ <property name="height_request">80</property>
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="vexpand">True</property>
+ <property name="vscrollbar_policy">never</property>
+ <property name="min_content_height">40</property>
+ <child>
+ <placeholder/>
+ </child>
+ </object>
+ </child>
+ <child type="label_item">
+ <placeholder/>
+ </child>
+ </object>
+ <packing>
+ <property name="left_attach">0</property>
+ <property name="top_attach">4</property>
+ </packing>
+ </child>
+ <style>
+ <class name="geary-account-view"/>
+ </style>
+ </object>
+ </child>
+ </object>
+ </child>
+ </object>
+ <packing>
+ <property name="left_attach">0</property>
+ <property name="top_attach">0</property>
+ </packing>
+ </child>
+ </template>
+</interface>
diff --git a/ui/geary.css b/ui/geary.css
index e34940e5..320b4f86 100644
--- a/ui/geary.css
+++ b/ui/geary.css
@@ -194,6 +194,16 @@ grid.geary-account-view image:dir(rtl) {
margin-left: 6px;
}
+label.geary-settings-heading {
+ font-weight: bold;
+ margin-top: 24px;
+ margin-bottom: 12px;
+}
+
row.geary-settings {
- padding: 16px;
+ padding: 18px;
+}
+
+buttonbox.geary-settings {
+ margin-top: 36px;
}
diff --git a/ui/org.gnome.Geary.gresource.xml b/ui/org.gnome.Geary.gresource.xml
index 9b8e3bd2..975dbde7 100644
--- a/ui/org.gnome.Geary.gresource.xml
+++ b/ui/org.gnome.Geary.gresource.xml
@@ -5,6 +5,7 @@
<file compressed="true" preprocess="xml-stripblanks">account_list.glade</file>
<file compressed="true" preprocess="xml-stripblanks">account_spinner.glade</file>
<file compressed="true" preprocess="xml-stripblanks">accounts_editor.ui</file>
+ <file compressed="true" preprocess="xml-stripblanks">accounts_editor_edit_pane.ui</file>
<file compressed="true" preprocess="xml-stripblanks">certificate_warning_dialog.glade</file>
<file compressed="true">client-web-view.js</file>
<file compressed="true">client-web-view-allow-remote-images.js</file>
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]