plasma-taskmanager-zoom/contents/ui/code/tools.js

219 lines
8.1 KiB
JavaScript

/*
SPDX-FileCopyrightText: 2012-2016 Eike Hein <hein@kde.org>
SPDX-FileCopyrightText: 2020 Nate Graham <nate@kde.org>
SPDX-License-Identifier: GPL-2.0-or-later
*/
.pragma library
.import org.kde.taskmanager as TaskManager
.import org.kde.plasma.core as PlasmaCore // Needed by TaskManager
// Can't be `let`, or else QML counterpart won't be able to assign to it.
var taskManagerInstanceCount = 0;
function activateNextPrevTask(anchor, next, wheelSkipMinimized, tasks) {
// FIXME TODO: Unnecessarily convoluted and costly; optimize.
let taskIndexList = [];
const activeTaskIndex = tasks.tasksModel.activeTask;
for (let i = 0; i < tasks.taskList.children.length - 1; ++i) {
const task = tasks.taskList.children[i];
const modelIndex = task.modelIndex(i);
if (!task.model.IsLauncher && !task.model.IsStartup) {
if (task.model.IsGroupParent) {
if (task === anchor) { // If the anchor is a group parent, collect only windows within the group.
taskIndexList = [];
}
for (let j = 0; j < tasks.tasksModel.rowCount(modelIndex); ++j) {
const childModelIndex = tasks.tasksModel.makeModelIndex(i, j);
const childHidden = tasks.tasksModel.data(childModelIndex, TaskManager.AbstractTasksModel.IsHidden);
if (!wheelSkipMinimized || !childHidden) {
taskIndexList.push(childModelIndex);
}
}
if (task === anchor) { // See above.
break;
}
} else {
if (!wheelSkipMinimized || !task.model.IsHidden) {
taskIndexList.push(modelIndex);
}
}
}
}
if (!taskIndexList.length) {
return;
}
let target = taskIndexList[0];
for (let i = 0; i < taskIndexList.length; ++i) {
if (taskIndexList[i] === activeTaskIndex)
{
if (next && i < (taskIndexList.length - 1)) {
target = taskIndexList[i + 1];
} else if (!next) {
if (i) {
target = taskIndexList[i - 1];
} else {
target = taskIndexList[taskIndexList.length - 1];
}
}
break;
}
}
tasks.tasksModel.requestActivate(target);
}
function activateTask(index, model, modifiers, task, plasmoid, tasks, windowViewAvailable) {
if (modifiers & Qt.ShiftModifier) {
tasks.tasksModel.requestNewInstance(index);
return;
}
// Publish delegate geometry again if there are more than one task manager instance
if (taskManagerInstanceCount >= 2) {
tasks.tasksModel.requestPublishDelegateGeometry(task.modelIndex(), tasks.backend.globalRect(task), task);
}
if (model.IsGroupParent) {
// Option 1 (default): Cycle through this group's tasks
// ====================================================
// If the grouped task does not include the currently active task, bring
// forward the most recently used task in the group according to the
// Stacking order.
// Otherwise cycle through all tasks in the group without paying attention
// to the stacking order, which otherwise would change with every click
if (plasmoid.configuration.groupedTaskVisualization === 0) {
let childTaskList = [];
let highestStacking = -1;
let lastUsedTask = undefined;
// Build list of child tasks and get stacking order data for them
for (let i = 0; i < tasks.tasksModel.rowCount(task.modelIndex(index)); ++i) {
const childTaskModelIndex = tasks.tasksModel.makeModelIndex(task.index, i);
childTaskList.push(childTaskModelIndex);
const stacking = tasks.tasksModel.data(childTaskModelIndex, TaskManager.AbstractTasksModel.StackingOrder);
if (stacking > highestStacking) {
highestStacking = stacking;
lastUsedTask = childTaskModelIndex;
}
}
// If the active task is from a different app from the group that
// was clicked on switch to the last-used task from that app.
if (!childTaskList.some(index => tasks.tasksModel.data(index, TaskManager.AbstractTasksModel.IsActive))) {
tasks.tasksModel.requestActivate(lastUsedTask);
} else {
// If the active task is already among in the group that was
// activated, cycle through all tasks according to the order of
// the immutable model index so the order doesn't change with
// every click.
for (let j = 0; j < childTaskList.length; ++j) {
const childTask = childTaskList[j];
if (tasks.tasksModel.data(childTask, TaskManager.AbstractTasksModel.IsActive)) {
// Found the current task. Activate the next one
let nextTask = j + 1;
if (nextTask >= childTaskList.length) {
nextTask = 0;
}
tasks.tasksModel.requestActivate(childTaskList[nextTask]);
break;
}
}
}
}
// Option 2: show tooltips for all child tasks
// ===========================================
else if (plasmoid.configuration.groupedTaskVisualization === 1) {
if (tasks.toolTipOpenedByClick) {
task.hideImmediately();
} else {
tasks.toolTipOpenedByClick = task;
task.updateMainItemBindings(); // BUG 452187
task.showToolTip();
}
}
// Option 3: show Window View for all child tasks
// ==================================================
// Make sure the Window View effect is are actually enabled though;
// if not, fall through to the next option.
else if (plasmoid.configuration.groupedTaskVisualization === 2 && windowViewAvailable) {
task.hideToolTip();
tasks.activateWindowView(model.WinIdList);
}
// Option 4: show group dialog/textual list
// ========================================
// This is also the final fallback option if Window View
// is chosen but not actually available
else {
if (tasks.groupDialog) {
task.hideToolTip();
tasks.groupDialog.visible = false;
} else {
createGroupDialog(task, tasks);
}
}
} else {
if (model.IsMinimized) {
tasks.tasksModel.requestToggleMinimized(index);
tasks.tasksModel.requestActivate(index);
} else if (model.IsActive && plasmoid.configuration.minimizeActiveTaskOnClick) {
tasks.tasksModel.requestToggleMinimized(index);
} else {
tasks.tasksModel.requestActivate(index);
}
}
}
function taskPrefix(prefix, location) {
let effectivePrefix;
switch (location) {
case PlasmaCore.Types.LeftEdge:
effectivePrefix = "west-" + prefix;
break;
case PlasmaCore.Types.TopEdge:
effectivePrefix = "north-" + prefix;
break;
case PlasmaCore.Types.RightEdge:
effectivePrefix = "east-" + prefix;
break;
default:
effectivePrefix = "south-" + prefix;
}
return [effectivePrefix, prefix];
}
function taskPrefixHovered(prefix, location) {
return [
...taskPrefix((prefix || "launcher") + "-hover", location),
...prefix ? taskPrefix("hover", location) : [],
...taskPrefix(prefix, location),
];
}
function createGroupDialog(visualParent, tasks) {
if (!visualParent) {
return;
}
if (tasks.groupDialog) {
tasks.groupDialog.visualParent = visualParent;
return;
}
tasks.groupDialog = tasks.groupDialogComponent.createObject(tasks, { visualParent });
}