[gnome-shell] keyring: Implement new dialog design
- From: Florian Müllner <fmuellner src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-shell] keyring: Implement new dialog design
- Date: Sat, 1 Feb 2020 07:15:46 +0000 (UTC)
commit 040c1638eacabadee2d9524287c8ebfd8a532ee7
Author: Jonas Dreßler <verdre v0yd nl>
Date: Mon Jan 20 17:40:25 2020 +0100
keyring: Implement new dialog design
Replace the ClutterGridLayout of the keyring dialog with a vertical
StBoxLayout based layout according to the new dialog design:
- Center-align all the elements of the dialog
- Remove the work-spinner because requests usually finish fast enough
- Show the entry-labels as hint text of the entry
See https://gitlab.gnome.org/GNOME/gnome-shell/issues/1343
https://gitlab.gnome.org/GNOME/gnome-shell/merge_requests/942
data/theme/gnome-shell-sass/widgets/_dialogs.scss | 5 -
js/ui/components/keyring.js | 196 ++++++++--------------
2 files changed, 70 insertions(+), 131 deletions(-)
---
diff --git a/data/theme/gnome-shell-sass/widgets/_dialogs.scss
b/data/theme/gnome-shell-sass/widgets/_dialogs.scss
index 48f8b0b41b..88f28d76a6 100644
--- a/data/theme/gnome-shell-sass/widgets/_dialogs.scss
+++ b/data/theme/gnome-shell-sass/widgets/_dialogs.scss
@@ -170,8 +170,3 @@
spacing-rows: 15px;
spacing-columns: 1em;
}
-
-.keyring-dialog-control-table {
- spacing-rows: 15px;
- spacing-columns: 1em;
-}
diff --git a/js/ui/components/keyring.js b/js/ui/components/keyring.js
index 4ad55531ba..da7eeec952 100644
--- a/js/ui/components/keyring.js
+++ b/js/ui/components/keyring.js
@@ -3,7 +3,6 @@
const { Clutter, Gcr, Gio, GObject, Pango, Shell, St } = imports.gi;
-const Animation = imports.ui.animation;
const Dialog = imports.ui.dialog;
const ModalDialog = imports.ui.modalDialog;
const ShellEntry = imports.ui.shellEntry;
@@ -21,139 +20,85 @@ class KeyringDialog extends ModalDialog.ModalDialog {
this.prompt.connect('show-confirm', this._onShowConfirm.bind(this));
this.prompt.connect('prompt-close', this._onHidePrompt.bind(this));
- this._content = new Dialog.MessageDialogContent();
- this.contentLayout.add(this._content);
+ let content = new Dialog.MessageDialogContent();
- this.prompt.bind_property('message', this._content, 'title', GObject.BindingFlags.SYNC_CREATE);
- this.prompt.bind_property('description', this._content, 'description',
GObject.BindingFlags.SYNC_CREATE);
+ this.prompt.bind_property('message',
+ content, 'title', GObject.BindingFlags.SYNC_CREATE);
+ this.prompt.bind_property('description',
+ content, 'description', GObject.BindingFlags.SYNC_CREATE);
- this._workSpinner = null;
- this._controlTable = null;
-
- this._cancelButton = this.addButton({ label: '',
- action: this._onCancelButton.bind(this),
- key: Clutter.KEY_Escape });
- this._continueButton = this.addButton({ label: '',
- action: this._onContinueButton.bind(this),
- default: true });
-
- this.prompt.bind_property('cancel-label', this._cancelButton, 'label',
GObject.BindingFlags.SYNC_CREATE);
- this.prompt.bind_property('continue-label', this._continueButton, 'label',
GObject.BindingFlags.SYNC_CREATE);
- }
-
- _setWorking(working) {
- if (!this._workSpinner)
- return;
-
- if (working)
- this._workSpinner.play();
- else
- this._workSpinner.stop();
- }
-
- _buildControlTable() {
- let layout = new Clutter.GridLayout({ orientation: Clutter.Orientation.VERTICAL });
- let table = new St.Widget({
- style_class: 'keyring-dialog-control-table',
- layout_manager: layout,
- x_expand: true,
- y_expand: true,
+ let passwordBox = new St.BoxLayout({
+ style_class: 'prompt-dialog-password-layout',
+ vertical: true,
});
- layout.hookup_style(table);
- let rtl = table.get_text_direction() == Clutter.TextDirection.RTL;
- let row = 0;
-
- if (this.prompt.password_visible) {
- let label = new St.Label({ style_class: 'prompt-dialog-password-label',
- x_align: Clutter.ActorAlign.START,
- y_align: Clutter.ActorAlign.CENTER });
- label.set_text(_("Password:"));
- label.clutter_text.ellipsize = Pango.EllipsizeMode.NONE;
- this._passwordEntry = new St.PasswordEntry({
- style_class: 'prompt-dialog-password-entry',
- text: '',
- can_focus: true,
- x_expand: true,
- });
- ShellEntry.addContextMenu(this._passwordEntry);
- this._passwordEntry.clutter_text.connect('activate', this._onPasswordActivate.bind(this));
-
- this._workSpinner = new Animation.Spinner(WORK_SPINNER_ICON_SIZE, {
- animate: true,
- });
-
- if (rtl) {
- layout.attach(this._workSpinner, 0, row, 1, 1);
- layout.attach(this._passwordEntry, 1, row, 1, 1);
- layout.attach(label, 2, row, 1, 1);
- } else {
- layout.attach(label, 0, row, 1, 1);
- layout.attach(this._passwordEntry, 1, row, 1, 1);
- layout.attach(this._workSpinner, 2, row, 1, 1);
- }
- row++;
- } else {
- this._workSpinner = null;
- this._passwordEntry = null;
- }
- if (this.prompt.confirm_visible) {
- var label = new St.Label({ style_class: 'prompt-dialog-password-label',
- x_align: Clutter.ActorAlign.START,
- y_align: Clutter.ActorAlign.CENTER });
- label.set_text(_("Type again:"));
- this._confirmEntry = new St.PasswordEntry({
- style_class: 'prompt-dialog-password-entry',
- text: '',
- can_focus: true,
- x_expand: true,
- });
- ShellEntry.addContextMenu(this._confirmEntry);
- this._confirmEntry.clutter_text.connect('activate', this._onConfirmActivate.bind(this));
- if (rtl) {
- layout.attach(this._confirmEntry, 0, row, 1, 1);
- layout.attach(label, 1, row, 1, 1);
- } else {
- layout.attach(label, 0, row, 1, 1);
- layout.attach(this._confirmEntry, 1, row, 1, 1);
- }
- row++;
- } else {
- this._confirmEntry = null;
- }
+ this._passwordEntry = new St.PasswordEntry({
+ style_class: 'prompt-dialog-password-entry',
+ can_focus: true,
+ x_align: Clutter.ActorAlign.CENTER,
+ });
+ ShellEntry.addContextMenu(this._passwordEntry);
+ this._passwordEntry.clutter_text.connect('activate', this._onPasswordActivate.bind(this));
+ this.prompt.bind_property('password-visible',
+ this._passwordEntry, 'visible', GObject.BindingFlags.SYNC_CREATE);
+ passwordBox.add_child(this._passwordEntry);
+
+ this._confirmEntry = new St.PasswordEntry({
+ style_class: 'prompt-dialog-password-entry',
+ can_focus: true,
+ x_align: Clutter.ActorAlign.CENTER,
+ });
+ ShellEntry.addContextMenu(this._confirmEntry);
+ this._confirmEntry.clutter_text.connect('activate', this._onConfirmActivate.bind(this));
+ this.prompt.bind_property('confirm-visible',
+ this._confirmEntry, 'visible', GObject.BindingFlags.SYNC_CREATE);
+ passwordBox.add_child(this._confirmEntry);
- this.prompt.set_password_actor(this._passwordEntry ? this._passwordEntry.clutter_text : null);
- this.prompt.set_confirm_actor(this._confirmEntry ? this._confirmEntry.clutter_text : null);
+ this.prompt.set_password_actor(this._passwordEntry.clutter_text);
+ this.prompt.set_confirm_actor(this._confirmEntry.clutter_text);
- if (this._passwordEntry || this._confirmEntry) {
- this._capsLockWarningLabel = new ShellEntry.CapsLockWarning();
- layout.attach(this._capsLockWarningLabel, 1, row, 1, 1);
- row++;
- }
+ let warningBox = new St.BoxLayout({ vertical: true });
- if (this.prompt.choice_visible) {
- let choice = new CheckBox.CheckBox();
- this.prompt.bind_property('choice-label', choice.getLabelActor(), 'text',
GObject.BindingFlags.SYNC_CREATE);
- this.prompt.bind_property('choice-chosen', choice, 'checked', GObject.BindingFlags.SYNC_CREATE |
GObject.BindingFlags.BIDIRECTIONAL);
- layout.attach(choice, rtl ? 0 : 1, row, 1, 1);
- row++;
- }
+ let capsLockWarning = new ShellEntry.CapsLockWarning();
+ warningBox.add_child(capsLockWarning);
- let warning = new St.Label({ style_class: 'prompt-dialog-error-label',
- x_align: Clutter.ActorAlign.START });
+ let warning = new St.Label({ style_class: 'prompt-dialog-error-label' });
warning.clutter_text.ellipsize = Pango.EllipsizeMode.NONE;
warning.clutter_text.line_wrap = true;
- layout.attach(warning, rtl ? 0 : 1, row, 1, 1);
- this.prompt.bind_property('warning-visible', warning, 'visible', GObject.BindingFlags.SYNC_CREATE);
- this.prompt.bind_property('warning', warning, 'text', GObject.BindingFlags.SYNC_CREATE);
-
- if (this._controlTable) {
- this._controlTable.destroy_all_children();
- this._controlTable.destroy();
- }
+ this.prompt.bind_property('warning',
+ warning, 'text', GObject.BindingFlags.SYNC_CREATE);
+ this.prompt.connect('notify::warning-visible', () => {
+ warning.opacity = this.prompt.warning_visible ? 255 : 0;
+ });
+ warningBox.add_child(warning);
+
+ passwordBox.add_child(warningBox);
+ content.add_child(passwordBox);
+
+ this._choice = new CheckBox.CheckBox();
+ this.prompt.bind_property('choice-label', this._choice.getLabelActor(),
+ 'text', GObject.BindingFlags.SYNC_CREATE);
+ this.prompt.bind_property('choice-chosen', this._choice,
+ 'checked', GObject.BindingFlags.SYNC_CREATE | GObject.BindingFlags.BIDIRECTIONAL);
+ this.prompt.bind_property('choice-visible', this._choice,
+ 'visible', GObject.BindingFlags.SYNC_CREATE);
+ content.add_child(this._choice);
+
+ this.contentLayout.add_child(content);
+
+ this._cancelButton = this.addButton({
+ label: '',
+ action: this._onCancelButton.bind(this),
+ key: Clutter.KEY_Escape,
+ });
+ this._continueButton = this.addButton({
+ label: '',
+ action: this._onContinueButton.bind(this),
+ default: true,
+ });
- this._controlTable = table;
- this._content.add_child(table);
+ this.prompt.bind_property('cancel-label', this._cancelButton, 'label',
GObject.BindingFlags.SYNC_CREATE);
+ this.prompt.bind_property('continue-label', this._continueButton, 'label',
GObject.BindingFlags.SYNC_CREATE);
}
_updateSensitivity(sensitive) {
@@ -169,7 +114,6 @@ class KeyringDialog extends ModalDialog.ModalDialog {
this._continueButton.can_focus = sensitive;
this._continueButton.reactive = sensitive;
- this._setWorking(!sensitive);
}
_ensureOpen() {
@@ -191,16 +135,16 @@ class KeyringDialog extends ModalDialog.ModalDialog {
}
_onShowPassword() {
- this._buildControlTable();
this._ensureOpen();
this._updateSensitivity(true);
+ this._passwordEntry.text = '';
this._passwordEntry.grab_key_focus();
}
_onShowConfirm() {
- this._buildControlTable();
this._ensureOpen();
this._updateSensitivity(true);
+ this._confirmEntry.text = '';
this._continueButton.grab_key_focus();
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]