Revert "overview: highlight windows on launcher hover"
This reverts commit 76229a3601
.
Pushed by accident.
This commit is contained in:
parent
76229a3601
commit
86596749fa
115
js/ui/dash.js
115
js/ui/dash.js
@ -20,7 +20,6 @@ const DASH_ANIMATION_TIME = 0.2;
|
|||||||
const DASH_ITEM_LABEL_SHOW_TIME = 0.15;
|
const DASH_ITEM_LABEL_SHOW_TIME = 0.15;
|
||||||
const DASH_ITEM_LABEL_HIDE_TIME = 0.1;
|
const DASH_ITEM_LABEL_HIDE_TIME = 0.1;
|
||||||
const DASH_ITEM_HOVER_TIMEOUT = 300;
|
const DASH_ITEM_HOVER_TIMEOUT = 300;
|
||||||
const HOVERED_APP_NOTIFICATION_TIMEOUT = 20;
|
|
||||||
|
|
||||||
function getAppFromSource(source) {
|
function getAppFromSource(source) {
|
||||||
if (source instanceof AppDisplay.AppWellIcon) {
|
if (source instanceof AppDisplay.AppWellIcon) {
|
||||||
@ -58,7 +57,6 @@ const DashItemContainer = new Lang.Class({
|
|||||||
this._childScale = 1;
|
this._childScale = 1;
|
||||||
this._childOpacity = 255;
|
this._childOpacity = 255;
|
||||||
this.animatingOut = false;
|
this.animatingOut = false;
|
||||||
this.appIcon = null;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_allocate: function(actor, box, flags) {
|
_allocate: function(actor, box, flags) {
|
||||||
@ -377,12 +375,9 @@ const Dash = new Lang.Class({
|
|||||||
this._dragPlaceholder = null;
|
this._dragPlaceholder = null;
|
||||||
this._dragPlaceholderPos = -1;
|
this._dragPlaceholderPos = -1;
|
||||||
this._animatingPlaceholdersCount = 0;
|
this._animatingPlaceholdersCount = 0;
|
||||||
this._setHoverTimeoutId = 0;
|
this._showLabelTimeoutId = 0;
|
||||||
this._resetHoverTimeoutId = 0;
|
this._resetHoverTimeoutId = 0;
|
||||||
this._userAlreadyHovering = false;
|
this._labelShowing = false;
|
||||||
this._hoveredItem = null;
|
|
||||||
this._hoveredAppTimeoutId = 0;
|
|
||||||
this._primaryAction = true;
|
|
||||||
|
|
||||||
this._container = new DashActor();
|
this._container = new DashActor();
|
||||||
this._box = new St.BoxLayout({ vertical: true,
|
this._box = new St.BoxLayout({ vertical: true,
|
||||||
@ -392,7 +387,7 @@ const Dash = new Lang.Class({
|
|||||||
|
|
||||||
this._showAppsIcon = new ShowAppsIcon();
|
this._showAppsIcon = new ShowAppsIcon();
|
||||||
this._showAppsIcon.icon.setIconSize(this.iconSize);
|
this._showAppsIcon.icon.setIconSize(this.iconSize);
|
||||||
this._hookUpItem(this._showAppsIcon);
|
this._hookUpLabel(this._showAppsIcon);
|
||||||
|
|
||||||
this.showAppsButton = this._showAppsIcon.toggleButton;
|
this.showAppsButton = this._showAppsIcon.toggleButton;
|
||||||
|
|
||||||
@ -426,19 +421,6 @@ const Dash = new Lang.Class({
|
|||||||
Lang.bind(this, this._onDragCancelled));
|
Lang.bind(this, this._onDragCancelled));
|
||||||
Main.overview.connect('window-drag-end',
|
Main.overview.connect('window-drag-end',
|
||||||
Lang.bind(this, this._onDragEnd));
|
Lang.bind(this, this._onDragEnd));
|
||||||
|
|
||||||
Main.overview.connect('hiding',
|
|
||||||
Lang.bind(this, function() {
|
|
||||||
this._userAlreadyHovering = false;
|
|
||||||
|
|
||||||
if (this._hoveredItem)
|
|
||||||
this._hoveredItem.hideLabel();
|
|
||||||
|
|
||||||
this._setHoveredItem(null, this._primaryAction);
|
|
||||||
}));
|
|
||||||
|
|
||||||
global.stage.connect('captured-event',
|
|
||||||
Lang.bind(this, this._onCapturedEvent));
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_onDragBegin: function() {
|
_onDragBegin: function() {
|
||||||
@ -486,14 +468,26 @@ const Dash = new Lang.Class({
|
|||||||
return DND.DragMotionResult.CONTINUE;
|
return DND.DragMotionResult.CONTINUE;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_appIdListToHash: function(apps) {
|
||||||
|
let ids = {};
|
||||||
|
for (let i = 0; i < apps.length; i++)
|
||||||
|
ids[apps[i].get_id()] = apps[i];
|
||||||
|
return ids;
|
||||||
|
},
|
||||||
|
|
||||||
_queueRedisplay: function () {
|
_queueRedisplay: function () {
|
||||||
Main.queueDeferredWork(this._workId);
|
Main.queueDeferredWork(this._workId);
|
||||||
},
|
},
|
||||||
|
|
||||||
_hookUpItem: function(item) {
|
_hookUpLabel: function(item) {
|
||||||
item.child.connect('notify::hover', Lang.bind(this, function() {
|
item.child.connect('notify::hover', Lang.bind(this, function() {
|
||||||
this._onHover(item);
|
this._onHover(item);
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
Main.overview.connect('hiding', Lang.bind(this, function() {
|
||||||
|
this._labelShowing = false;
|
||||||
|
item.hideLabel();
|
||||||
|
}));
|
||||||
},
|
},
|
||||||
|
|
||||||
_createAppItem: function(app) {
|
_createAppItem: function(app) {
|
||||||
@ -514,7 +508,6 @@ const Dash = new Lang.Class({
|
|||||||
}));
|
}));
|
||||||
|
|
||||||
let item = new DashItemContainer();
|
let item = new DashItemContainer();
|
||||||
item.appIcon = appIcon;
|
|
||||||
item.setChild(appIcon.actor);
|
item.setChild(appIcon.actor);
|
||||||
|
|
||||||
// Override default AppWellIcon label_actor, now the
|
// Override default AppWellIcon label_actor, now the
|
||||||
@ -523,7 +516,7 @@ const Dash = new Lang.Class({
|
|||||||
item.setLabelText(app.get_name());
|
item.setLabelText(app.get_name());
|
||||||
|
|
||||||
appIcon.icon.setIconSize(this.iconSize);
|
appIcon.icon.setIconSize(this.iconSize);
|
||||||
this._hookUpItem(item);
|
this._hookUpLabel(item);
|
||||||
|
|
||||||
return item;
|
return item;
|
||||||
},
|
},
|
||||||
@ -532,9 +525,9 @@ const Dash = new Lang.Class({
|
|||||||
// When the menu closes, it calls sync_hover, which means
|
// When the menu closes, it calls sync_hover, which means
|
||||||
// that the notify::hover handler does everything we need to.
|
// that the notify::hover handler does everything we need to.
|
||||||
if (opened) {
|
if (opened) {
|
||||||
if (this._setHoverTimeoutId > 0) {
|
if (this._showLabelTimeoutId > 0) {
|
||||||
Mainloop.source_remove(this._setHoverTimeoutId);
|
Mainloop.source_remove(this._showLabelTimeoutId);
|
||||||
this._setHoverTimeoutId = 0;
|
this._showLabelTimeoutId = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
item.hideLabel();
|
item.hideLabel();
|
||||||
@ -543,82 +536,32 @@ const Dash = new Lang.Class({
|
|||||||
|
|
||||||
_onHover: function (item) {
|
_onHover: function (item) {
|
||||||
if (item.child.get_hover()) {
|
if (item.child.get_hover()) {
|
||||||
if (this._setHoverTimeoutId == 0) {
|
if (this._showLabelTimeoutId == 0) {
|
||||||
let timeout = this._userAlreadyHovering ? 0 : DASH_ITEM_HOVER_TIMEOUT;
|
let timeout = this._labelShowing ? 0 : DASH_ITEM_HOVER_TIMEOUT;
|
||||||
|
this._showLabelTimeoutId = Mainloop.timeout_add(timeout,
|
||||||
this._setHoverTimeoutId = Mainloop.timeout_add(timeout,
|
|
||||||
Lang.bind(this, function() {
|
Lang.bind(this, function() {
|
||||||
|
this._labelShowing = true;
|
||||||
item.showLabel();
|
item.showLabel();
|
||||||
this._setHoveredItem(item, this._primaryAction);
|
|
||||||
this._userAlreadyHovering = true;
|
|
||||||
return false;
|
return false;
|
||||||
}));
|
}));
|
||||||
|
|
||||||
if (this._resetHoverTimeoutId > 0) {
|
if (this._resetHoverTimeoutId > 0) {
|
||||||
Mainloop.source_remove(this._resetHoverTimeoutId);
|
Mainloop.source_remove(this._resetHoverTimeoutId);
|
||||||
this._resetHoverTimeoutId = 0;
|
this._resetHoverTimeoutId = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (this._setHoverTimeoutId > 0)
|
if (this._showLabelTimeoutId > 0)
|
||||||
Mainloop.source_remove(this._setHoverTimeoutId);
|
Mainloop.source_remove(this._showLabelTimeoutId);
|
||||||
this._setHoverTimeoutId = 0;
|
this._showLabelTimeoutId = 0;
|
||||||
|
|
||||||
item.hideLabel();
|
item.hideLabel();
|
||||||
this._setHoveredItem(null, this._primaryAction);
|
if (this._labelShowing) {
|
||||||
|
|
||||||
if (this._userAlreadyHovering)
|
|
||||||
this._resetHoverTimeoutId = Mainloop.timeout_add(DASH_ITEM_HOVER_TIMEOUT,
|
this._resetHoverTimeoutId = Mainloop.timeout_add(DASH_ITEM_HOVER_TIMEOUT,
|
||||||
Lang.bind(this, function() {
|
Lang.bind(this, function() {
|
||||||
this._userAlreadyHovering = false;
|
this._labelShowing = false;
|
||||||
return false;
|
return false;
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
},
|
|
||||||
|
|
||||||
_setHoveredItem: function(item, primaryAction) {
|
|
||||||
if (this._hoveredItem == item && this._primaryAction == primaryAction)
|
|
||||||
return;
|
|
||||||
|
|
||||||
this._hoveredItem = item;
|
|
||||||
this._primaryAction = primaryAction;
|
|
||||||
|
|
||||||
let app = null;
|
|
||||||
|
|
||||||
if (item != null && item.appIcon != null)
|
|
||||||
app = getAppFromSource(item.appIcon);
|
|
||||||
|
|
||||||
// The leave and enter events will both be dispatched before we tick into the next
|
|
||||||
// frame, so the _setHoverItem(null) should have no immediate effect.
|
|
||||||
if (this._hoveredAppTimeoutId > 0)
|
|
||||||
Mainloop.source_remove(this._hoveredAppTimeoutId);
|
|
||||||
|
|
||||||
this._hoveredAppTimeoutId = Mainloop.timeout_add(HOVERED_APP_NOTIFICATION_TIMEOUT,
|
|
||||||
Lang.bind(this, function() {
|
|
||||||
this._hoveredAppTimeoutId = 0;
|
|
||||||
this.emit('hovered-app-changed', app, primaryAction);
|
|
||||||
return false;
|
|
||||||
}));
|
|
||||||
},
|
|
||||||
|
|
||||||
_onCapturedEvent: function(actor, event) {
|
|
||||||
let keyPress = (event.type() == Clutter.EventType.KEY_PRESS);
|
|
||||||
let keyRelease = (event.type() == Clutter.EventType.KEY_RELEASE);
|
|
||||||
|
|
||||||
if (!keyPress && !keyRelease)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
let key = event.get_key_symbol();
|
|
||||||
|
|
||||||
if (key == Clutter.KEY_Alt_L || key == Clutter.KEY_Alt_R) {
|
|
||||||
let primaryAction = !keyPress;
|
|
||||||
|
|
||||||
if (this._primaryAction != primaryAction) {
|
|
||||||
this._setHoveredItem(this._hoveredItem, primaryAction);
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_adjustIconSize: function() {
|
_adjustIconSize: function() {
|
||||||
|
@ -176,8 +176,6 @@ const Overview = new Lang.Class({
|
|||||||
this._modal = false; // have a modal grab
|
this._modal = false; // have a modal grab
|
||||||
this.animationInProgress = false;
|
this.animationInProgress = false;
|
||||||
this._hideInProgress = false;
|
this._hideInProgress = false;
|
||||||
this.hoveredApp = null;
|
|
||||||
this.primaryAction = false;
|
|
||||||
|
|
||||||
// During transitions, we raise this to the top to avoid having the overview
|
// During transitions, we raise this to the top to avoid having the overview
|
||||||
// area be reactive; it causes too many issues such as double clicks on
|
// area be reactive; it causes too many issues such as double clicks on
|
||||||
@ -234,9 +232,6 @@ const Overview = new Lang.Class({
|
|||||||
this._group.add_actor(this._searchEntry);
|
this._group.add_actor(this._searchEntry);
|
||||||
|
|
||||||
this._dash = new Dash.Dash();
|
this._dash = new Dash.Dash();
|
||||||
this._dash.connect('hovered-app-changed',
|
|
||||||
Lang.bind(this, this._hoveredAppChanged));
|
|
||||||
|
|
||||||
this._viewSelector = new ViewSelector.ViewSelector(this._searchEntry,
|
this._viewSelector = new ViewSelector.ViewSelector(this._searchEntry,
|
||||||
this._dash.showAppsButton);
|
this._dash.showAppsButton);
|
||||||
this._group.add_actor(this._viewSelector.actor);
|
this._group.add_actor(this._viewSelector.actor);
|
||||||
@ -561,12 +556,6 @@ const Overview = new Lang.Class({
|
|||||||
this._viewSelector.actor.set_size(viewWidth, viewHeight);
|
this._viewSelector.actor.set_size(viewWidth, viewHeight);
|
||||||
},
|
},
|
||||||
|
|
||||||
_hoveredAppChanged: function(dash, app, primaryAction) {
|
|
||||||
this.hoveredApp = app;
|
|
||||||
this.primaryAction = primaryAction;
|
|
||||||
this.emit('hovered-app-changed', app, primaryAction);
|
|
||||||
},
|
|
||||||
|
|
||||||
//// Public methods ////
|
//// Public methods ////
|
||||||
|
|
||||||
beginItemDrag: function(source) {
|
beginItemDrag: function(source) {
|
||||||
|
@ -27,11 +27,8 @@ const WINDOW_CLONE_MAXIMUM_SCALE = 0.7;
|
|||||||
|
|
||||||
const LIGHTBOX_FADE_TIME = 0.1;
|
const LIGHTBOX_FADE_TIME = 0.1;
|
||||||
const CLOSE_BUTTON_FADE_TIME = 0.1;
|
const CLOSE_BUTTON_FADE_TIME = 0.1;
|
||||||
const DIMMED_WINDOW_FADE_IN_TIME = 0.2;
|
|
||||||
const DIMMED_WINDOW_FADE_OUT_TIME = 0.15;
|
|
||||||
|
|
||||||
const DRAGGING_WINDOW_OPACITY = 100;
|
const DRAGGING_WINDOW_OPACITY = 100;
|
||||||
const DIMMED_WINDOW_OPACITY = 100;
|
|
||||||
|
|
||||||
const BUTTON_LAYOUT_SCHEMA = 'org.gnome.shell.overrides';
|
const BUTTON_LAYOUT_SCHEMA = 'org.gnome.shell.overrides';
|
||||||
const BUTTON_LAYOUT_KEY = 'button-layout';
|
const BUTTON_LAYOUT_KEY = 'button-layout';
|
||||||
@ -195,16 +192,6 @@ const WindowClone = new Lang.Class({
|
|||||||
this.actor.destroy();
|
this.actor.destroy();
|
||||||
},
|
},
|
||||||
|
|
||||||
setDimmed: function(dimmed, withAnimation) {
|
|
||||||
let opacity = dimmed ? DIMMED_WINDOW_OPACITY : 255;
|
|
||||||
let time = dimmed ? DIMMED_WINDOW_FADE_IN_TIME : DIMMED_WINDOW_FADE_OUT_TIME;
|
|
||||||
|
|
||||||
Tweener.addTween(this.actor,
|
|
||||||
{ opacity: opacity,
|
|
||||||
time: withAnimation ? time : 0,
|
|
||||||
transition: 'easeOutQuad' });
|
|
||||||
},
|
|
||||||
|
|
||||||
zoomFromOverview: function() {
|
zoomFromOverview: function() {
|
||||||
if (this._zooming) {
|
if (this._zooming) {
|
||||||
// If the user clicked on the zoomed window, or we are
|
// If the user clicked on the zoomed window, or we are
|
||||||
@ -1014,9 +1001,6 @@ const Workspace = new Lang.Class({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this._hoveredAppChangedId = Main.overview.connect('hovered-app-changed',
|
|
||||||
Lang.bind(this, this._hoveredAppChanged));
|
|
||||||
|
|
||||||
// Track window changes
|
// Track window changes
|
||||||
if (this.metaWorkspace) {
|
if (this.metaWorkspace) {
|
||||||
this._windowAddedId = this.metaWorkspace.connect('window-added',
|
this._windowAddedId = this.metaWorkspace.connect('window-added',
|
||||||
@ -1362,8 +1346,6 @@ const Workspace = new Lang.Class({
|
|||||||
|
|
||||||
this._currentLayout = null;
|
this._currentLayout = null;
|
||||||
this.positionWindows(WindowPositionFlags.ANIMATE);
|
this.positionWindows(WindowPositionFlags.ANIMATE);
|
||||||
|
|
||||||
this._updateCloneDimmed(clone, Main.overview.hoveredApp, Main.overview.primaryAction, false);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_windowAdded : function(metaWorkspace, metaWin) {
|
_windowAdded : function(metaWorkspace, metaWin) {
|
||||||
@ -1474,8 +1456,6 @@ const Workspace = new Lang.Class({
|
|||||||
}
|
}
|
||||||
Tweener.removeTweens(actor);
|
Tweener.removeTweens(actor);
|
||||||
|
|
||||||
Main.overview.disconnect(this._hoveredAppChangedId);
|
|
||||||
|
|
||||||
if (this.metaWorkspace) {
|
if (this.metaWorkspace) {
|
||||||
this.metaWorkspace.disconnect(this._windowAddedId);
|
this.metaWorkspace.disconnect(this._windowAddedId);
|
||||||
this.metaWorkspace.disconnect(this._windowRemovedId);
|
this.metaWorkspace.disconnect(this._windowRemovedId);
|
||||||
@ -1679,22 +1659,6 @@ const Workspace = new Lang.Class({
|
|||||||
Main.activateWindow(clone.metaWindow, time, wsIndex);
|
Main.activateWindow(clone.metaWindow, time, wsIndex);
|
||||||
},
|
},
|
||||||
|
|
||||||
_hoveredAppChanged: function(overview, hoveredApp, primaryAction) {
|
|
||||||
for (let i = 0; i < this._windows.length; i++) {
|
|
||||||
this._updateCloneDimmed(this._windows[i], hoveredApp, primaryAction, true);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_updateCloneDimmed: function(clone, hoveredApp, primaryAction, withAnimation) {
|
|
||||||
let app = Shell.WindowTracker.get_default().get_window_app(clone.metaWindow);
|
|
||||||
let dimmed = (hoveredApp != null && app != hoveredApp);
|
|
||||||
|
|
||||||
if (primaryAction)
|
|
||||||
dimmed = dimmed && (hoveredApp.state != Shell.AppState.STOPPED);
|
|
||||||
|
|
||||||
clone.setDimmed(dimmed, withAnimation);
|
|
||||||
},
|
|
||||||
|
|
||||||
// Draggable target interface
|
// Draggable target interface
|
||||||
handleDragOver : function(source, actor, x, y, time) {
|
handleDragOver : function(source, actor, x, y, time) {
|
||||||
if (source.realWindow && !this._isMyWindow(source.realWindow))
|
if (source.realWindow && !this._isMyWindow(source.realWindow))
|
||||||
|
@ -20,9 +20,6 @@ let MAX_THUMBNAIL_SCALE = 1/8.;
|
|||||||
const RESCALE_ANIMATION_TIME = 0.2;
|
const RESCALE_ANIMATION_TIME = 0.2;
|
||||||
const SLIDE_ANIMATION_TIME = 0.2;
|
const SLIDE_ANIMATION_TIME = 0.2;
|
||||||
|
|
||||||
// the window opacity is very low as windows can be layered, contrary to the view selector
|
|
||||||
const DIMMED_WINDOW_OPACITY = 50;
|
|
||||||
|
|
||||||
// When we create workspaces by dragging, we add a "cut" into the top and
|
// When we create workspaces by dragging, we add a "cut" into the top and
|
||||||
// bottom of each workspace so that the user doesn't have to hit the
|
// bottom of each workspace so that the user doesn't have to hit the
|
||||||
// placeholder exactly.
|
// placeholder exactly.
|
||||||
@ -61,16 +58,6 @@ const WindowClone = new Lang.Class({
|
|||||||
this.inDrag = false;
|
this.inDrag = false;
|
||||||
},
|
},
|
||||||
|
|
||||||
setDimmed: function(dimmed, withAnimation) {
|
|
||||||
let opacity = dimmed ? DIMMED_WINDOW_OPACITY : 255;
|
|
||||||
let time = dimmed ? Workspace.DIMMED_WINDOW_FADE_IN_TIME : Workspace.DIMMED_WINDOW_FADE_OUT_TIME;
|
|
||||||
|
|
||||||
Tweener.addTween(this.actor,
|
|
||||||
{ opacity: opacity,
|
|
||||||
time: withAnimation ? time : 0,
|
|
||||||
transition: 'easeOutQuad' });
|
|
||||||
},
|
|
||||||
|
|
||||||
setStackAbove: function (actor) {
|
setStackAbove: function (actor) {
|
||||||
this._stackAbove = actor;
|
this._stackAbove = actor;
|
||||||
if (this._stackAbove == null)
|
if (this._stackAbove == null)
|
||||||
@ -205,9 +192,6 @@ const WorkspaceThumbnail = new Lang.Class({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this._hoveredAppChangedId = Main.overview.connect('hovered-app-changed',
|
|
||||||
Lang.bind(this, this._hoveredAppChanged));
|
|
||||||
|
|
||||||
// Track window changes
|
// Track window changes
|
||||||
this._windowAddedId = this.metaWorkspace.connect('window-added',
|
this._windowAddedId = this.metaWorkspace.connect('window-added',
|
||||||
Lang.bind(this, this._windowAdded));
|
Lang.bind(this, this._windowAdded));
|
||||||
@ -328,8 +312,6 @@ const WorkspaceThumbnail = new Lang.Class({
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
let clone = this._addWindowClone(win);
|
let clone = this._addWindowClone(win);
|
||||||
|
|
||||||
this._updateCloneDimmed(clone, Main.overview.hoveredApp, Main.overview.primaryAction, false);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_windowAdded : function(metaWorkspace, metaWin) {
|
_windowAdded : function(metaWorkspace, metaWin) {
|
||||||
@ -386,8 +368,6 @@ const WorkspaceThumbnail = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_onDestroy: function(actor) {
|
_onDestroy: function(actor) {
|
||||||
Main.overview.disconnect(this._hoveredAppChangedId);
|
|
||||||
|
|
||||||
this.workspaceRemoved();
|
this.workspaceRemoved();
|
||||||
|
|
||||||
this._windows = [];
|
this._windows = [];
|
||||||
@ -455,23 +435,6 @@ const WorkspaceThumbnail = new Lang.Class({
|
|||||||
this.metaWorkspace.activate(time);
|
this.metaWorkspace.activate(time);
|
||||||
},
|
},
|
||||||
|
|
||||||
_hoveredAppChanged: function(overview, hoveredApp, primaryAction) {
|
|
||||||
for (let i = 0; i < this._windows.length; i++) {
|
|
||||||
this._updateCloneDimmed(this._windows[i], hoveredApp, primaryAction, true);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_updateCloneDimmed: function(clone, hoveredApp, primaryAction, withAnimation) {
|
|
||||||
let app = Shell.WindowTracker.get_default().get_window_app(clone.metaWindow);
|
|
||||||
let dimmed = (hoveredApp != null && app != hoveredApp);
|
|
||||||
|
|
||||||
if (primaryAction)
|
|
||||||
dimmed = dimmed && (hoveredApp.state != Shell.AppState.STOPPED);
|
|
||||||
|
|
||||||
clone.setDimmed(dimmed, withAnimation);
|
|
||||||
},
|
|
||||||
|
|
||||||
|
|
||||||
// Draggable target interface used only by ThumbnailsBox
|
// Draggable target interface used only by ThumbnailsBox
|
||||||
handleDragOverInternal : function(source, time) {
|
handleDragOverInternal : function(source, time) {
|
||||||
if (source == Main.xdndHandler) {
|
if (source == Main.xdndHandler) {
|
||||||
|
Loading…
Reference in New Issue
Block a user