1
0
mirror of https://github.com/KDE/latte-dock.git synced 2025-01-13 05:17:48 +03:00
latte-dock/declarativeimports/components/BadgeText.qml
Michail Vourlakos 733f372adc update progress badge properly
--send repaint signals properly for BadgeText

BUG:410318
2019-07-28 23:30:09 +03:00

194 lines
5.6 KiB
QML

/*
* Copyright 2019 Michail Vourlakos <mvourlakos@gmail.com>
*
* This file is part of Latte-Dock
*
* Latte-Dock is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of
* the License, or (at your option) any later version.
*
* Latte-Dock is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
import QtQuick 2.2
import QtGraphicalEffects 1.0
import org.kde.plasma.plasmoid 2.0
Rectangle {
property double proportion: 0
property double previousProportion: 0
property bool style3d: true
property int numberValue
property string textValue
property bool fullCircle: true
property bool showNumber: true
property bool showText: false
property bool textWithBackgroundColor: false
property int radiusPerCentage: 100
property int minimumWidth: 0
property int maximumWidth: 9999
property double circleOpacity: 1
property double fontPixelSize: partSize // * 0.55
property double stdThickness: partSize < 0 ? 0 : partSize // "/2.1"
property double circleThicknessAttr: fullCircle ? 0 : stdThickness * 0.9
property double partSize: height / 2
property double pi2: Math.PI * 2
width: Math.max(minimumWidth, valueText.width + 4*units.smallSpacing)
color: theme.backgroundColor
radius: (radiusPerCentage / 100) * (height / 2)
border.width: 0 //Math.max(1,width/64)
property int borderWidth: 1
property real borderOpacity: 1
property color borderColor: theme.textColor
property color textColor: theme.textColor
property color highlightedColor: theme.buttonFocusColor
readonly property bool singleCharacter: (showNumber && numberValue<=9 && numberValue>=0)|| (showText && textValue.length===1)
onProportionChanged: {
if (proportion<0.03) {
previousProportion = 0;
}
//console.log(previousProportion + " - "+proportion);
var currentStep = (proportion - previousProportion);
if ((currentStep >= 0.01) || (proportion>=1 && previousProportion !==1)) {
// console.log("request repaint...");
previousProportion = proportion;
repaint();
}
}
function repaint() {
canvas.requestPaint()
}
Canvas {
id: canvas
property int lineWidth: 1
property bool fill: true
property bool stroke: true
property real alpha: 1.0
// edge bleeding fix
readonly property double filler: 0.01
width: parent.width - 2 * parent.borderWidth
height: parent.height - 2 * parent.borderWidth
opacity: proportion > 0 ? 1 : 0
anchors.centerIn: parent
property color drawColor: highlightedColor
onDrawColorChanged: requestPaint();
onPaint: {
var ctx = getContext('2d');
ctx.clearRect(0, 0, canvas.width, canvas.height);
ctx.fillStyle = drawColor;
var startRadian = - Math.PI / 2;
var radians = pi2 * proportion;
ctx.beginPath();
ctx.arc(width/2, height/2, stdThickness, startRadian, startRadian + radians + filler, false);
ctx.arc(width/2, height/2, circleThicknessAttr, startRadian + radians + filler, startRadian, true);
ctx.closePath();
ctx.fill();
}
}
Rectangle {
id: badgerBackground
anchors.fill: canvas
color: canvas.drawColor
visible: proportion === 1 && showNumber
radius: parent.radius
}
Text {
id: valueText
anchors.centerIn: canvas
width: Math.min(maximumWidth - 4*units.smallSpacing, implicitWidth)
horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignVCenter
elide: Text.ElideRight
text: {
if (showNumber) {
if (numberValue > 9999) {
return i18nc("Over 9999 new messages, overlay, keep short", "9,999+");
} else if (numberValue > 0) {
return numberValue.toLocaleString(Qt.locale(), 'f', 0);
}
}
if (showText) {
return textValue;
}
return "";
}
font.pixelSize: 0.62 * parent.height
font.bold: true
color: textWithBackgroundColor ? parent.color : parent.textColor
visible: showNumber || showText
}
Rectangle{
anchors.fill: parent
anchors.topMargin: parent.borderWidth
anchors.bottomMargin: parent.borderWidth
anchors.leftMargin: parent.borderWidth
anchors.rightMargin: parent.borderWidth
color: "transparent"
border.width: parent.borderWidth > 0 ? parent.borderWidth+1 : 0
border.color: "black"
radius: parent.radius
opacity: 0.4
visible: style3d
}
Rectangle{
anchors.fill: parent
border.width: parent.borderWidth
border.color: {
if (style3d) {
return parent.borderColor
}
return proportion === 1 ? parent.highlightedColor : parent.color
}
color: "transparent"
radius: parent.radius
opacity: parent.borderOpacity
}
}