taskswitcher: add support for task reordering based on opening history

This commit is contained in:
Yari Polla 2022-04-13 15:04:55 +02:00
parent f99e8ff037
commit de1b92e0c2
4 changed files with 13 additions and 7 deletions

View file

@ -171,7 +171,7 @@ Item {
groupMode: TaskManager.TasksModel.GroupDisabled groupMode: TaskManager.TasksModel.GroupDisabled
screenGeometry: plasmoid.screenGeometry screenGeometry: plasmoid.screenGeometry
sortMode: TaskManager.TasksModel.SortAlpha sortMode: TaskManager.TasksModel.SortLastActivated
virtualDesktop: virtualDesktopInfo.currentDesktop virtualDesktop: virtualDesktopInfo.currentDesktop
activity: activityInfo.currentActivity activity: activityInfo.currentActivity

View file

@ -83,9 +83,14 @@ Item {
taskSwitcherState.wasInActiveTask = tasksModel.activeTask.row >= 0; taskSwitcherState.wasInActiveTask = tasksModel.activeTask.row >= 0;
taskSwitcherState.currentlyBeingOpened = true; taskSwitcherState.currentlyBeingOpened = true;
// disable reorder feature and the relative delay
taskSwitcher.tasksModel.requestLastActivatedReorderDelay(0);
// skip to first active task // skip to first active task
if (taskSwitcherState.wasInActiveTask) { if (taskSwitcherState.wasInActiveTask) {
taskSwitcherState.goToTaskIndex(tasksModel.activeTask.row); taskSwitcherState.goToTaskIndex(tasksModel.activeTask.row);
} else {
taskSwitcherState.goToTaskIndex(tasksCount - 1);
} }
// show task switcher, hide all running apps // show task switcher, hide all running apps

View file

@ -221,6 +221,7 @@ QtObject {
taskSwitcher.instantHide(); taskSwitcher.instantHide();
if (root.wasInActiveTask) { if (root.wasInActiveTask) {
taskSwitcher.tasksModel.requestLastActivatedReorderDelay(5000);
taskSwitcher.setSingleActiveWindow(root.currentTaskIndex); taskSwitcher.setSingleActiveWindow(root.currentTaskIndex);
} }
} }

View file

@ -15,7 +15,7 @@ TaskManager.PipeWireSourceItem {
nodeId: waylandItem.nodeId nodeId: waylandItem.nodeId
onVisibleChanged: { onVisibleChanged: {
if (visible && waylandItem.uuid.length === 0) { if (visible) {
if (model.WinIdList) { if (model.WinIdList) {
waylandItem.uuid = model.WinIdList[0]; waylandItem.uuid = model.WinIdList[0];
} }