aerothemeplasma/Plasma Widgets/Task Manager/org.kde.plasma.seventasks/contents/ui/code/layout.js

244 lines
8.3 KiB
JavaScript
Raw Normal View History

/*
SPDX-FileCopyrightText: 2012-2013 Eike Hein <hein@kde.org>
SPDX-License-Identifier: GPL-2.0-or-later
*/
.import org.kde.plasma.core 2.0 as PlasmaCore
var iconSizes = ["small", "smallMedium", "medium", "large", "huge", "enormous"];
function horizontalMargins() {
return taskFrame.margins.left + taskFrame.margins.right;
}
function verticalMargins() {
return taskFrame.margins.top + taskFrame.margins.bottom;
}
function adjustMargin(height, margin) {
var available = height - verticalMargins();
if (available < PlasmaCore.Units.iconSizes.small) {
return Math.floor((margin * (PlasmaCore.Units.iconSizes.small / available)) / 3);
}
return margin;
}
function launcherLayoutTasks() {
return Math.round(tasksModel.logicalLauncherCount / Math.floor(preferredMinWidth() / launcherWidth()));
}
function launcherLayoutWidthDiff() {
return (launcherLayoutTasks() * taskWidth()) - (tasksModel.logicalLauncherCount * launcherWidth());
}
function logicalTaskCount() {
var count = (tasksModel.count - tasksModel.logicalLauncherCount) + launcherLayoutTasks();
return Math.max(tasksModel.count ? 1 : 0, count);
}
function maxStripes() {
var length = tasks.vertical ? taskList.width : taskList.height;
var minimum = tasks.vertical ? preferredMinWidth() : preferredMinHeight();
return Math.min(plasmoid.configuration.maxStripes, Math.max(1, Math.floor(length / minimum)));
}
function tasksPerStripe() {
if (plasmoid.configuration.forceStripes) {
return Math.ceil(logicalTaskCount() / maxStripes());
} else {
var length = tasks.vertical ? taskList.height : taskList.width;
var minimum = tasks.vertical ? preferredMinHeight() : preferredMinWidth();
return Math.floor(length / minimum);
}
}
function calculateStripes() {
var stripes = plasmoid.configuration.forceStripes ? plasmoid.configuration.maxStripes : Math.min(plasmoid.configuration.maxStripes, Math.ceil(logicalTaskCount() / tasksPerStripe()));
return Math.min(stripes, maxStripes());
}
function full() {
return (maxStripes() == calculateStripes());
}
function optimumCapacity(width, height) {
var length = tasks.vertical ? height : width;
var maximum = tasks.vertical ? preferredMaxHeight() : preferredMaxWidth();
if (!tasks.vertical) {
// Fit more tasks in this case, that is possible to cut text, before combining tasks.
return Math.ceil(length / maximum) * maxStripes() + 1;
}
return Math.floor(length / maximum) * maxStripes();
}
function layoutWidth() {
if (plasmoid.configuration.forceStripes && !tasks.vertical) {
return Math.min(tasks.width, Math.max(preferredMaxWidth(), tasksPerStripe() * preferredMaxWidth()));
} else {
return tasks.width;
}
}
function layoutHeight() {
if (plasmoid.configuration.forceStripes && tasks.vertical) {
return Math.min(tasks.height, Math.max(preferredMaxHeight(), tasksPerStripe() * preferredMaxHeight()));
} else {
return tasks.height;
}
}
function preferredMinWidth() {
var width = launcherWidth();
if (!tasks.vertical && !tasks.iconsOnly) {
width +=
(PlasmaCore.Units.smallSpacing * 2) +
(PlasmaCore.Theme.mSize(PlasmaCore.Theme.defaultFont).width * 12);
}
return width;
}
function preferredMaxWidth() {
if (tasks.iconsOnly) {
if (tasks.vertical) {
return tasks.width + verticalMargins();
} else {
return tasks.height + horizontalMargins();
}
}
if (plasmoid.configuration.groupingStrategy != 0 && !plasmoid.configuration.groupPopups) {
return preferredMinWidth();
}
return Math.floor(preferredMinWidth() * 1.6);
}
function preferredMinHeight() {
// TODO FIXME UPSTREAM: Port to proper font metrics for descenders once we have access to them.
return PlasmaCore.Theme.mSize(PlasmaCore.Theme.defaultFont).height + 4;
}
function preferredMaxHeight() {
if (tasks.vertical) {
return verticalMargins() +
Math.min(
// Do not allow the preferred icon size to exceed the width of
// the vertical task manager.
tasks.width,
Math.max(
// This assumes that we show some text and that we need
// some minimal vertical space for it. In reality, we do
// not always show the text. We show the text only if there
// is enough horizontal space for some hard coded amount of
// 'm' characters
// - see minimumMColumns() below.
// Hence in case the user prefers icons smaller than the
// height of his font, the font height will win even if the
// text will stay invisible. We leave it for the future
// developers to improve this expresssion if the named
// corner case turns out to be important.
PlasmaCore.Units
.iconSizes[iconSizes[plasmoid.configuration.iconSize]],
PlasmaCore.Theme.mSize(PlasmaCore.Theme.defaultFont)
.height));
} else {
return verticalMargins() +
Math.min(
PlasmaCore.Units.iconSizes.small * 3,
PlasmaCore.Theme.mSize(PlasmaCore.Theme.defaultFont).height *
3);
}
}
// Returns the number of 'm' characters whose joint width must be available in the task button label
// so that the button text is rendered at all.
function minimumMColumns() {
return tasks.vertical ? 4 : 5;
}
function taskWidth() {
if (tasks.vertical) {
return Math.floor(taskList.width / calculateStripes());
} else {
if (full() && Math.max(1, logicalTaskCount()) > tasksPerStripe()) {
return Math.floor(taskList.width / Math.ceil(logicalTaskCount() / maxStripes()));
} else {
return Math.min(preferredMaxWidth(), Math.floor(taskList.width / Math.min(logicalTaskCount(), tasksPerStripe())));
}
}
}
function taskHeight() {
if (tasks.vertical) {
if (full() && Math.max(1, logicalTaskCount()) > tasksPerStripe()) {
return Math.floor(taskList.height / Math.ceil(logicalTaskCount() / maxStripes()));
} else {
return Math.min(preferredMaxHeight(), Math.floor(taskList.height / Math.min(logicalTaskCount(), tasksPerStripe())));
}
} else {
return Math.floor(taskList.height / calculateStripes());
}
}
function launcherWidth() {
var baseWidth = tasks.vertical ? preferredMinHeight() : Math.min(tasks.height, PlasmaCore.Units.iconSizes.small * 3);
return (baseWidth + horizontalMargins())
- (adjustMargin(baseWidth, taskFrame.margins.top) + adjustMargin(baseWidth, taskFrame.margins.bottom));
}
function maximumContextMenuTextWidth() {
return (PlasmaCore.Theme.mSize(PlasmaCore.Theme.defaultFont).width * 28);
}
function layout(container) {
var item;
var stripes = calculateStripes();
var taskCount = tasksModel.count - tasksModel.logicalLauncherCount;
var width = taskWidth();
var adjustedWidth = width;
var height = taskHeight();
if (!tasks.vertical && stripes == 1 && taskCount)
{
var shrink = ((tasksModel.count - tasksModel.logicalLauncherCount) * preferredMaxWidth())
+ (tasksModel.logicalLauncherCount * launcherWidth()) > taskList.width;
width = Math.min(shrink ? width + Math.floor(launcherLayoutWidthDiff() / taskCount) : width,
preferredMaxWidth());
}
for (var i = 0; i < container.count; ++i) {
item = container.itemAt(i);
if (!item) {
continue;
}
adjustedWidth = width;
if (!tasks.vertical && !tasks.iconsOnly && (plasmoid.configuration.separateLaunchers || stripes == 1)) {
if (item.m.IsLauncher === true
|| (!plasmoid.configuration.separateLaunchers && item.m.IsStartup === true && item.m.HasLauncher === true)) {
adjustedWidth = launcherWidth();
} else if (stripes > 1 && i == tasksModel.logicalLauncherCount) {
adjustedWidth += launcherLayoutWidthDiff();
}
}
item.width = adjustedWidth;
item.height = height;
item.visible = true;
}
}