From e13c0ca9e8d489899e4a9eb49fb1bbed153a5e66 Mon Sep 17 00:00:00 2001 From: "Jasper St. Pierre" Date: Wed, 4 Dec 2013 22:45:44 -0500 Subject: [PATCH] messageTray: Remove support for notifications with images This sufficiently complicates the code, and won't fit in the new design. --- data/theme/gnome-shell.css | 8 ----- js/ui/messageTray.js | 64 +------------------------------------ js/ui/notificationDaemon.js | 8 +---- 3 files changed, 2 insertions(+), 78 deletions(-) diff --git a/data/theme/gnome-shell.css b/data/theme/gnome-shell.css index b9c0de6d8..70a830620 100644 --- a/data/theme/gnome-shell.css +++ b/data/theme/gnome-shell.css @@ -1556,14 +1556,6 @@ StScrollBar StButton#vhandle:active { height: 36px; } -/* We use row-span = 2 for the image cell, which prevents its height preferences to be - taken into account during allocation, so its height ends up being limited by the height - of the content in the other rows. To avoid showing a stretched image, we set the minimum - height of the table to be ICON_SIZE + IMAGE_SIZE + spacing-rows = 24 + 125 + 10 = 159 */ -.notification-with-image { - min-height: 159px; -} - .summary-boxpointer { -arrow-border-radius: 15px; -arrow-background-color: rgba(0,0,0,0.9); diff --git a/js/ui/messageTray.js b/js/ui/messageTray.js index 2f36fcf82..879288875 100644 --- a/js/ui/messageTray.js +++ b/js/ui/messageTray.js @@ -483,8 +483,6 @@ const Notification = new Lang.Class({ ICON_SIZE: 24, - IMAGE_SIZE: 125, - _init: function(source, title, banner, params) { this.source = source; this.title = title; @@ -504,7 +502,6 @@ const Notification = new Lang.Class({ this._titleFitsInBannerMode = true; this._spacing = 0; this._scrollPolicy = Gtk.PolicyType.AUTOMATIC; - this._imageBin = null; this._soundName = null; this._soundFile = null; this._soundPlayed = false; @@ -536,14 +533,6 @@ const Notification = new Lang.Class({ y_expand: false, y_fill: false }); - // This is an empty cell that overlaps with this._bannerBox cell to ensure - // that this._bannerBox cell expands horizontally, while not forcing the - // this._imageBin that is also in col: 2 to expand horizontally. - this._table.add(new St.Bin(), { row: 0, - col: 2, - y_expand: false, - y_fill: false }); - this._titleLabel = new St.Label(); this._bannerBox.add_actor(this._titleLabel); this._bannerUrlHighlighter = new URLHighlighter(); @@ -608,10 +597,8 @@ const Notification = new Lang.Class({ this._actionArea = null; this._buttonBox = null; } - if (params.clear) - this.unsetImage(); - if (!this._scrollArea && !this._actionArea && !this._imageBin) + if (!this._scrollArea && !this._actionArea) this._table.remove_style_class_name('multi-line-notification'); if (params.gicon) { @@ -701,7 +688,6 @@ const Notification = new Lang.Class({ visible: this.expanded }); this._table.add(this._scrollArea, { row: 1, col: 2 }); - this._updateLastColumnSettings(); this._contentArea = new St.BoxLayout({ style_class: 'notification-body', vertical: true }); this._scrollArea.add_actor(this._contentArea); @@ -782,53 +768,9 @@ const Notification = new Lang.Class({ this._table.add_style_class_name('multi-line-notification'); this._table.add(this._actionArea, props); - this._updateLastColumnSettings(); this.updated(); }, - _updateLastColumnSettings: function() { - if (this._scrollArea) - this._table.child_set(this._scrollArea, { col: this._imageBin ? 2 : 1, - col_span: this._imageBin ? 1 : 2 }); - if (this._actionArea) - this._table.child_set(this._actionArea, { col: this._imageBin ? 2 : 1, - col_span: this._imageBin ? 1 : 2 }); - }, - - setImage: function(image) { - this.unsetImage(); - - if (!image) - return; - - this._imageBin = new St.Bin({ opacity: 230, - child: image, - visible: this.expanded }); - - this._table.add_style_class_name('multi-line-notification'); - this._table.add_style_class_name('notification-with-image'); - this._addBannerBody(); - this._updateLastColumnSettings(); - this._table.add(this._imageBin, { row: 1, - col: 1, - row_span: 2, - x_expand: false, - y_expand: false, - x_fill: false, - y_fill: false }); - }, - - unsetImage: function() { - if (this._imageBin) { - this._table.remove_style_class_name('notification-with-image'); - this._table.remove_actor(this._imageBin); - this._imageBin = null; - this._updateLastColumnSettings(); - if (!this._scrollArea && !this._actionArea) - this._table.remove_style_class_name('multi-line-notification'); - } - }, - addButton: function(button, callback) { if (!this._buttonBox) { let box = new St.BoxLayout({ style_class: 'notification-actions' }); @@ -1048,8 +990,6 @@ const Notification = new Lang.Class({ this.actor.remove_style_class_name('notification-unexpanded'); // Show additional content that we keep hidden in banner mode - if (this._imageBin) - this._imageBin.show(); if (this._actionArea) this._actionArea.show(); if (this._scrollArea) @@ -1088,8 +1028,6 @@ const Notification = new Lang.Class({ this.expanded = false; // Hide additional content that we keep hidden in banner mode - if (this._imageBin) - this._imageBin.hide(); if (this._actionArea) this._actionArea.hide(); if (this._scrollArea) diff --git a/js/ui/notificationDaemon.js b/js/ui/notificationDaemon.js index 7828d7cf9..31b30ccb2 100644 --- a/js/ui/notificationDaemon.js +++ b/js/ui/notificationDaemon.js @@ -364,8 +364,6 @@ const FdoNotificationDaemon = new Lang.Class({ let gicon = this._iconForNotificationData(icon, hints); let gimage = this._imageForNotificationData(hints); - let image = null; - // If an icon is not specified, we use 'image-data' or 'image-path' hint for an icon // and don't show a large image. There are currently many applications that use // notify_notification_set_icon_from_pixbuf() from libnotify, which in turn sets @@ -374,10 +372,7 @@ const FdoNotificationDaemon = new Lang.Class({ // So the logic here does the right thing for this case. If both an icon and either // one of 'image-data' or 'image-path' are specified, we show both an icon and // a large image. - if (gicon && gimage) - image = new St.Icon({ gicon: gimage, - icon_size: notification.IMAGE_SIZE }); - else if (!gicon && gimage) + if (!gicon && gimage) gicon = gimage; else if (!gicon) gicon = this._fallbackIconForNotificationData(hints); @@ -387,7 +382,6 @@ const FdoNotificationDaemon = new Lang.Class({ clear: true, soundFile: hints['sound-file'], soundName: hints['sound-name'] }); - notification.setImage(image); let hasDefaultAction = false;