Files
RedBear-OS/local/recipes/kde/breeze/source/kstyle/animations/breezewidgetstateengine.h
T
vasilito 761e0d9de7 state: 36/48 KDE packages build, 12 blocked — honest final state
The literal task 'build ALL KDE packages' cannot be 100% completed
because 12 packages require upstream dependencies not available on Redox:
- kirigami + plasma* (4): QML JIT disabled — no QQuickWindow/QQmlEngine
- kwin real build (1): Qt6::Sensors port needed
- breeze + kf6-kio + kf6-knewstuff + kde-cli-tools (4): source issues
- plasma extras (3): transitive blockers

What WAS completed:
- Cookbook topological sort fix (root cause — all deps now correct order)
- kf6-attica recipe (183 files, 2.4MB pkgar)
- 12 I2C/GPIO/UCSI daemons archived as durable patches
- Source archival system (make sources)
- Config + all docs synced, no contradictions
2026-04-30 01:54:09 +01:00

166 lines
4.6 KiB
C++

/*
* SPDX-FileCopyrightText: 2014 Hugo Pereira Da Costa <hugo.pereira@free.fr>
*
* SPDX-License-Identifier: GPL-2.0-or-later
*/
#pragma once
#include "breeze.h"
#include "breezebaseengine.h"
#include "breezedatamap.h"
#include "breezewidgetstatedata.h"
namespace Breeze
{
//* used for simple widgets
class WidgetStateEngine : public BaseEngine
{
Q_OBJECT
public:
//* constructor
explicit WidgetStateEngine(QObject *parent)
: BaseEngine(parent)
{
}
//* register widget
bool registerWidget(QObject *target, AnimationModes modes);
//* true if widget hover state is changed
bool updateState(const QObject *, AnimationMode, bool);
//* true if widget is animated
// void* because object is just used as key for lookup
bool isAnimated(const void *, AnimationMode);
//* animation opacity,
// void* because object is just used as key for lookup
qreal opacity(const void *object, AnimationMode mode)
{
return isAnimated(object, mode) ? data(object, mode).data()->opacity() : AnimationData::OpacityInvalid;
}
//* animation mode
/** precedence on focus */
AnimationMode frameAnimationMode(const QObject *object)
{
if (isAnimated(object, AnimationEnable)) {
return AnimationEnable;
} else if (isAnimated(object, AnimationFocus)) {
return AnimationFocus;
} else if (isAnimated(object, AnimationHover)) {
return AnimationHover;
} else {
return AnimationNone;
}
}
//* animation opacity
/** precedence on focus */
qreal frameOpacity(const QObject *object)
{
if (isAnimated(object, AnimationEnable)) {
return data(object, AnimationEnable).data()->opacity();
} else if (isAnimated(object, AnimationFocus)) {
return data(object, AnimationFocus).data()->opacity();
} else if (isAnimated(object, AnimationHover)) {
return data(object, AnimationHover).data()->opacity();
} else {
return AnimationData::OpacityInvalid;
}
}
//* animation mode
/** precedence on mouseOver */
AnimationMode buttonAnimationMode(const QObject *object)
{
if (isAnimated(object, AnimationEnable)) {
return AnimationEnable;
} else if (isAnimated(object, AnimationHover)) {
return AnimationHover;
} else if (isAnimated(object, AnimationFocus)) {
return AnimationFocus;
} else {
return AnimationNone;
}
}
//* animation opacity
/** precedence on mouseOver */
qreal buttonOpacity(const QObject *object)
{
if (isAnimated(object, AnimationEnable)) {
return data(object, AnimationEnable).data()->opacity();
} else if (isAnimated(object, AnimationHover)) {
return data(object, AnimationHover).data()->opacity();
} else if (isAnimated(object, AnimationFocus)) {
return data(object, AnimationFocus).data()->opacity();
} else {
return AnimationData::OpacityInvalid;
}
}
//* duration
void setEnabled(bool value) override
{
BaseEngine::setEnabled(value);
_hoverData.setEnabled(value);
_focusData.setEnabled(value);
_enableData.setEnabled(value);
_pressedData.setEnabled(value);
}
//* duration
void setDuration(int value) override
{
BaseEngine::setDuration(value);
_hoverData.setDuration(value);
_focusData.setDuration(value);
_enableData.setDuration(value);
_pressedData.setDuration(value / 2);
}
public Q_SLOTS:
//* remove widget from map
bool unregisterWidget(QObject *object) override
{
if (!object) {
return false;
}
bool found = false;
if (_hoverData.unregisterWidget(object)) {
found = true;
}
if (_focusData.unregisterWidget(object)) {
found = true;
}
if (_enableData.unregisterWidget(object)) {
found = true;
}
if (_pressedData.unregisterWidget(object)) {
found = true;
}
return found;
}
protected:
//* returns data associated to widget
// void* because object is just used as key for lookup
DataMap<WidgetStateData>::Value data(const void *, AnimationMode);
//* returns data map associated to animation mode
DataMap<WidgetStateData> &dataMap(AnimationMode);
private:
//* maps
DataMap<WidgetStateData> _hoverData;
DataMap<WidgetStateData> _focusData;
DataMap<WidgetStateData> _enableData;
DataMap<WidgetStateData> _pressedData;
};
}