2011-09-28 09:16:26 -04:00
|
|
|
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
2010-02-12 23:52:15 +01:00
|
|
|
|
2023-07-10 02:53:00 -07:00
|
|
|
import Clutter from 'gi://Clutter';
|
|
|
|
import GLib from 'gi://GLib';
|
|
|
|
import GObject from 'gi://GObject';
|
|
|
|
import St from 'gi://St';
|
2010-02-12 23:52:15 +01:00
|
|
|
|
2023-07-10 02:53:00 -07:00
|
|
|
import * as Layout from './layout.js';
|
|
|
|
import * as Main from './main.js';
|
2010-02-12 23:52:15 +01:00
|
|
|
|
2023-07-10 02:53:00 -07:00
|
|
|
const ANIMATION_TIME = 100;
|
|
|
|
const DISPLAY_TIMEOUT = 600;
|
2010-02-12 23:52:15 +01:00
|
|
|
|
2022-01-26 01:33:21 +01:00
|
|
|
|
2023-07-10 02:53:00 -07:00
|
|
|
export const WorkspaceSwitcherPopup = GObject.registerClass(
|
2022-01-26 01:33:21 +01:00
|
|
|
class WorkspaceSwitcherPopup extends Clutter.Actor {
|
2017-10-31 01:03:21 +01:00
|
|
|
_init() {
|
2020-07-08 18:06:39 +08:00
|
|
|
super._init({
|
|
|
|
offscreen_redirect: Clutter.OffscreenRedirect.ALWAYS,
|
2022-01-26 01:33:21 +01:00
|
|
|
x_expand: true,
|
|
|
|
y_expand: true,
|
|
|
|
x_align: Clutter.ActorAlign.CENTER,
|
|
|
|
y_align: Clutter.ActorAlign.END,
|
2020-07-08 18:06:39 +08:00
|
|
|
});
|
2010-02-12 23:52:15 +01:00
|
|
|
|
2022-01-26 01:33:21 +01:00
|
|
|
const constraint = new Layout.MonitorConstraint({ primary: true });
|
|
|
|
this.add_constraint(constraint);
|
2018-07-15 18:00:07 -03:00
|
|
|
|
|
|
|
Main.uiGroup.add_actor(this);
|
|
|
|
|
|
|
|
this._timeoutId = 0;
|
|
|
|
|
2022-01-26 01:33:21 +01:00
|
|
|
this._list = new St.BoxLayout({
|
|
|
|
style_class: 'workspace-switcher',
|
|
|
|
});
|
|
|
|
this.add_child(this._list);
|
2018-07-15 18:00:07 -03:00
|
|
|
|
|
|
|
this._redisplay();
|
|
|
|
|
|
|
|
this.hide();
|
|
|
|
|
|
|
|
let workspaceManager = global.workspace_manager;
|
2021-08-16 00:36:59 +02:00
|
|
|
workspaceManager.connectObject(
|
|
|
|
'workspace-added', this._redisplay.bind(this),
|
|
|
|
'workspace-removed', this._redisplay.bind(this), this);
|
2018-07-15 18:00:07 -03:00
|
|
|
|
|
|
|
this.connect('destroy', this._onDestroy.bind(this));
|
2017-10-31 02:23:39 +01:00
|
|
|
}
|
2010-06-09 19:09:48 +02:00
|
|
|
|
2017-10-31 01:03:21 +01:00
|
|
|
_redisplay() {
|
2018-01-03 15:55:38 +08:00
|
|
|
let workspaceManager = global.workspace_manager;
|
|
|
|
|
2012-02-16 13:27:09 -05:00
|
|
|
this._list.destroy_all_children();
|
2010-02-12 23:52:15 +01:00
|
|
|
|
2018-01-03 15:55:38 +08:00
|
|
|
for (let i = 0; i < workspaceManager.n_workspaces; i++) {
|
2022-01-26 01:26:44 +01:00
|
|
|
const indicator = new St.Bin({
|
|
|
|
style_class: 'ws-switcher-indicator',
|
|
|
|
});
|
|
|
|
|
|
|
|
if (i === this._activeWorkspaceIndex)
|
|
|
|
indicator.add_style_pseudo_class('active');
|
2010-02-12 23:52:15 +01:00
|
|
|
|
2019-01-29 20:36:54 +01:00
|
|
|
this._list.add_actor(indicator);
|
2010-02-12 23:52:15 +01:00
|
|
|
}
|
2017-10-31 02:23:39 +01:00
|
|
|
}
|
2010-02-12 23:52:15 +01:00
|
|
|
|
2022-01-26 01:26:44 +01:00
|
|
|
display(activeWorkspaceIndex) {
|
2012-06-27 21:13:32 +02:00
|
|
|
this._activeWorkspaceIndex = activeWorkspaceIndex;
|
|
|
|
|
|
|
|
this._redisplay();
|
2010-02-12 23:52:15 +01:00
|
|
|
if (this._timeoutId != 0)
|
2019-08-19 20:50:33 +02:00
|
|
|
GLib.source_remove(this._timeoutId);
|
|
|
|
this._timeoutId = GLib.timeout_add(GLib.PRIORITY_DEFAULT, DISPLAY_TIMEOUT, this._onTimeout.bind(this));
|
2014-04-10 19:26:52 +02:00
|
|
|
GLib.Source.set_name_by_id(this._timeoutId, '[gnome-shell] this._onTimeout');
|
2022-01-26 01:43:15 +01:00
|
|
|
|
|
|
|
const duration = this.visible ? 0 : ANIMATION_TIME;
|
|
|
|
this.show();
|
2022-01-26 01:33:21 +01:00
|
|
|
this.opacity = 0;
|
|
|
|
this.ease({
|
2022-01-26 01:43:15 +01:00
|
|
|
opacity: 255,
|
|
|
|
duration,
|
|
|
|
mode: Clutter.AnimationMode.EASE_OUT_QUAD,
|
|
|
|
});
|
2017-10-31 02:23:39 +01:00
|
|
|
}
|
2010-02-12 23:52:15 +01:00
|
|
|
|
2017-10-31 01:03:21 +01:00
|
|
|
_onTimeout() {
|
2019-08-19 20:50:33 +02:00
|
|
|
GLib.source_remove(this._timeoutId);
|
2010-02-12 23:52:15 +01:00
|
|
|
this._timeoutId = 0;
|
2022-01-26 01:33:21 +01:00
|
|
|
this.ease({
|
2018-07-20 21:46:19 +02:00
|
|
|
opacity: 0.0,
|
|
|
|
duration: ANIMATION_TIME,
|
|
|
|
mode: Clutter.AnimationMode.EASE_OUT_QUAD,
|
2019-08-20 23:43:54 +02:00
|
|
|
onComplete: () => this.destroy(),
|
2018-07-20 21:46:19 +02:00
|
|
|
});
|
2013-11-29 01:45:39 +01:00
|
|
|
return GLib.SOURCE_REMOVE;
|
2017-10-31 02:23:39 +01:00
|
|
|
}
|
2012-06-27 21:13:32 +02:00
|
|
|
|
2018-07-15 18:00:07 -03:00
|
|
|
_onDestroy() {
|
2012-06-27 21:13:32 +02:00
|
|
|
if (this._timeoutId)
|
2019-08-19 20:50:33 +02:00
|
|
|
GLib.source_remove(this._timeoutId);
|
2012-06-27 21:13:32 +02:00
|
|
|
this._timeoutId = 0;
|
2010-02-12 23:52:15 +01:00
|
|
|
}
|
2011-11-20 18:56:27 +01:00
|
|
|
});
|