shift-shell/components/shellsettingsplugin/mobileshellsettings.h

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

376 lines
14 KiB
C
Raw Normal View History

/*
* SPDX-FileCopyrightText: 2022 Devin Lin <devin@kde.org>
*
* SPDX-License-Identifier: GPL-2.0-or-later
*/
#pragma once
#include <KConfigGroup>
#include <KConfigWatcher>
#include <KSharedConfig>
#include <QDBusConnection>
#include <QObject>
2026-05-22 07:39:11 +00:00
#include <QStringList>
#include <qqmlregistration.h>
/**
* @short Wrapper class to access and control mobile shell specific settings.
*
* @author Devin Lin <devin@kde.org>
*/
class MobileShellSettings : public QObject
{
Q_OBJECT
QML_NAMED_ELEMENT(Settings)
QML_SINGLETON
// general
Q_PROPERTY(bool vibrationsEnabled READ vibrationsEnabled WRITE setVibrationsEnabled NOTIFY vibrationsEnabledChanged)
Q_PROPERTY(int vibrationDuration READ vibrationDuration WRITE setVibrationDuration NOTIFY vibrationDurationChanged)
Q_PROPERTY(bool animationsEnabled READ animationsEnabled WRITE setAnimationsEnabled NOTIFY animationsEnabledChanged)
// status bar
Q_PROPERTY(bool dateInStatusBar READ dateInStatusBar WRITE setDateInStatusBar NOTIFY dateInStatusBarChanged)
Q_PROPERTY(float statusBarScaleFactor READ statusBarScaleFactor WRITE setStatusBarScaleFactor NOTIFY statusBarScaleFactorChanged)
Q_PROPERTY(bool showBatteryPercentage READ showBatteryPercentage WRITE setShowBatteryPercentage NOTIFY showBatteryPercentageChanged)
// navigation panel
Q_PROPERTY(bool navigationPanelEnabled READ navigationPanelEnabled WRITE setNavigationPanelEnabled NOTIFY navigationPanelEnabledChanged)
Q_PROPERTY(bool alwaysShowKeyboardToggleOnNavigationPanel READ alwaysShowKeyboardToggleOnNavigationPanel WRITE setAlwaysShowKeyboardToggleOnNavigationPanel NOTIFY alwaysShowKeyboardToggleOnNavigationPanelChanged)
Q_PROPERTY(bool gesturePanelEnabled READ gesturePanelEnabled WRITE setGesturePanelEnabled NOTIFY gesturePanelEnabledChanged)
// action drawer
Q_PROPERTY(ActionDrawerMode actionDrawerTopLeftMode READ actionDrawerTopLeftMode WRITE setActionDrawerTopLeftMode NOTIFY actionDrawerTopLeftModeChanged)
Q_PROPERTY(ActionDrawerMode actionDrawerTopRightMode READ actionDrawerTopRightMode WRITE setActionDrawerTopRightMode NOTIFY actionDrawerTopRightModeChanged)
// quicksettings
Q_PROPERTY(int quickSettingsColumns READ quickSettingsColumns WRITE setQuickSettingsColumns NOTIFY quickSettingsColumnsChanged)
// convergence mode
Q_PROPERTY(bool convergenceModeEnabled READ convergenceModeEnabled WRITE setConvergenceModeEnabled NOTIFY convergenceModeEnabledChanged)
// Auto Hide Panels
Q_PROPERTY(bool autoHidePanelsEnabled READ autoHidePanelsEnabled WRITE setAutoHidePanelsEnabled NOTIFY autoHidePanelsEnabledChanged)
// Gaming mode
Q_PROPERTY(bool gamingModeEnabled READ gamingModeEnabled WRITE setGamingModeEnabled NOTIFY gamingModeEnabledChanged)
Q_PROPERTY(bool gamingDismissHintEnabled READ gamingDismissHintEnabled WRITE setGamingDismissHintEnabled NOTIFY gamingDismissHintEnabledChanged)
// Dynamic (BSP) window tiling — only meaningful in convergence mode.
// When false, KWin's native quick-tile behaviour is used unmodified.
Q_PROPERTY(bool dynamicTilingEnabled READ dynamicTilingEnabled WRITE setDynamicTilingEnabled NOTIFY dynamicTilingEnabledChanged)
Q_PROPERTY(QString dynamicTilingWindowRequestAction READ dynamicTilingWindowRequestAction NOTIFY dynamicTilingWindowRequestChanged)
Q_PROPERTY(QString dynamicTilingWindowRequestId READ dynamicTilingWindowRequestId NOTIFY dynamicTilingWindowRequestChanged)
Q_PROPERTY(int dynamicTilingWindowRequestSerial READ dynamicTilingWindowRequestSerial NOTIFY dynamicTilingWindowRequestChanged)
2026-05-22 07:39:11 +00:00
Q_PROPERTY(QStringList dynamicTilingMaximizedWindowIds READ dynamicTilingMaximizedWindowIds NOTIFY dynamicTilingWindowStateChanged)
Q_PROPERTY(int dynamicTilingWindowStateSerial READ dynamicTilingWindowStateSerial NOTIFY dynamicTilingWindowStateChanged)
// Snap layout picker — only meaningful in convergence mode when dynamic tiling is off.
Q_PROPERTY(bool snapLayoutsEnabled READ snapLayoutsEnabled WRITE setSnapLayoutsEnabled NOTIFY snapLayoutsEnabledChanged)
// logout dialog
Q_PROPERTY(bool allowLogout READ allowLogout READ allowLogout NOTIFY allowLogoutChanged)
// locksreen shortcut icons
Q_PROPERTY(LockscreenButtonAction lockscreenLeftButtonAction READ lockscreenLeftButtonAction WRITE setLockscreenLeftButtonAction NOTIFY lockscreenLeftButtonActionChanged)
Q_PROPERTY(LockscreenButtonAction lockscreenRightButtonAction READ lockscreenRightButtonAction WRITE setLockscreenRightButtonAction NOTIFY lockscreenRightButtonActionChanged)
public:
MobileShellSettings(QObject *parent = nullptr);
enum ActionDrawerMode {
Pinned = 0, /** The drawer when pulled down is in its pinned mode. A second swipe fully expands it.*/
Expanded /** The drawer is fully expanded when pulled down.*/
};
Q_ENUM(ActionDrawerMode)
enum LockscreenButtonAction {
None, // hide the button
Flashlight, // toggle flashlight/torch
Camera, // camera
OpenApp // cant be selected, no support yet
};
Q_ENUM(LockscreenButtonAction)
/**
* Get whether shell vibrations are enabled.
*/
bool vibrationsEnabled() const;
/**
* Set whether shell vibrations should be enabled.
*
* @param vibrationsEnabled Whether vibrations are enabled.
*/
void setVibrationsEnabled(bool vibrationsEnabled);
/**
* Get the duration of a standard vibration event, in milliseconds.
* Different types of vibration events may be calculated off of this.
*/
int vibrationDuration() const;
/**
* Set the duration of a standard vibration event, in milliseconds.
*
* @param vibrationDuration The duration of a standard vibration event.
*/
void setVibrationDuration(int vibrationDuration);
/**
* Whether animations are enabled in the shell.
*
* If false, vibrations will either be disabled or minimized as much as possible.
* TODO: integrate with animation speed (in settings at "Workspace Behaviour->General Behaviour"),
* which affects applications as well.
*/
bool animationsEnabled() const;
/**
* Set whether animations are enabled in the shell.
*
* @param animationsEnabled Whether animations should be enabled in the shell.
*/
void setAnimationsEnabled(bool animationsEnabled);
/**
* Whether date is shown in the status bar.
*
* If true, date will be shown in the status bar next to the clock.
*/
bool dateInStatusBar() const;
/**
* Set whether date is shown in the status bar.
*
* @param dateInStatusBar Whether date is shown in the status bar.
*/
void setDateInStatusBar(bool dateInStatusBar);
/**
* Scale factor for status bar height.
*
* Status bar height will be multiplied by this value.
*/
float statusBarScaleFactor() const;
/**
* Set the scale factor for the status bar's height.
*
* @param statusBarScaleFactor Scale factor for status bar height.
*/
void setStatusBarScaleFactor(float statusBarScaleFactor);
/**
* Whether the battery percentage is shown in the status bar.
*
* If true, the percentage will be shown next to the battery in the status bar.
*/
bool showBatteryPercentage() const;
/**
* Set whether the battery percentage is shown in the status bar.
*
* @param showBatteryPercentage Whether the battery percentage is shown in the status bar.
*/
void setShowBatteryPercentage(bool showBatteryPercentage);
/**
* Whether the navigation panel is enabled.
*
* If this is false, then gesture based navigation is used.
*/
bool navigationPanelEnabled() const;
/**
* Set whether the navigation panel is enabled.
*
* @param navigationPanelEnabled Whether the navigation panel should be enabled.
*/
void setNavigationPanelEnabled(bool navigationPanelEnabled);
/**
* Whether the gesture panel is enabled.
*
* This is only applicable when navigationPanelEnabled() = false (gesture mode).
*/
bool gesturePanelEnabled() const;
/**
* Set whether the gesture panel is enabled.
*
* @param gesturePanelEnabled Whether the gesture panel should be enabled.
*/
void setGesturePanelEnabled(bool gesturePanelEnabled);
/**
* Set whether the keyboard toggle button should always show on the navigation panel, regardless of
* whether the app properly supports virtual keyboards.
*
* If this is false, then the keyboard toggle only shows on the navigation panel if the app doesn't
* support virtual keyboards.
*/
bool alwaysShowKeyboardToggleOnNavigationPanel() const;
/**
* Set whether the keyboard toggle button should always show on the navigation panel, regardless of
* whether the app properly supports virtual keyboards.
*
* @param alwaysShowKeyboardToggleOnNavigationPanel
*/
void setAlwaysShowKeyboardToggleOnNavigationPanel(bool alwaysShowKeyboardToggleOnNavigationPanel);
/**
* The mode of the action drawer when swiped down from the top left.
*/
ActionDrawerMode actionDrawerTopLeftMode() const;
/**
* Set the mode of the action drawer when swiped down from the top left.
*
* @param actionDrawerMode The mode of the action drawer.
*/
void setActionDrawerTopLeftMode(ActionDrawerMode actionDrawerMode);
/**
* The mode of the action drawer when swiped down from the top right.
*/
ActionDrawerMode actionDrawerTopRightMode() const;
/**
* Set the mode of the action drawer when swiped down from the top right.
*
* @param actionDrawerMode The mode of the action drawer.
*/
void setActionDrawerTopRightMode(ActionDrawerMode actionDrawerMode);
/**
* The number of columns to use for the QuickSettings drawer.
*/
int quickSettingsColumns() const;
/**
* Set the number of columns to use for the QuickSettings drawer.
*
* @param columns The number of columns to use.
*/
void setQuickSettingsColumns(int columns);
/**
* Whether convergence/docked mode is enabled.
*/
bool convergenceModeEnabled() const;
/**
* Set whether convergence/docked mode is enabled.
*
* @param enabled
*/
void setConvergenceModeEnabled(bool enabled);
/**
* Whether Auto Hide Panels is enabled.
*/
bool autoHidePanelsEnabled() const;
/**
* Set whether Auto Hide Panels is enabled.
*
* @param enabled
*/
void setAutoHidePanelsEnabled(bool enabled);
bool gamingModeEnabled() const;
void setGamingModeEnabled(bool enabled);
bool gamingDismissHintEnabled() const;
void setGamingDismissHintEnabled(bool enabled);
/**
* Whether the SHIFT BSP dynamic tiling script is active.
* Defaults to true; only takes effect in convergence mode (and when
* gaming mode is off).
*/
bool dynamicTilingEnabled() const;
void setDynamicTilingEnabled(bool enabled);
QString dynamicTilingWindowRequestAction() const;
QString dynamicTilingWindowRequestId() const;
int dynamicTilingWindowRequestSerial() const;
Q_INVOKABLE void requestDynamicTilingWindowAction(const QString &windowId, const QString &action);
2026-05-22 07:39:11 +00:00
QStringList dynamicTilingMaximizedWindowIds() const;
int dynamicTilingWindowStateSerial() const;
Q_INVOKABLE bool isDynamicTilingWindowMaximized(const QString &windowId) const;
Q_INVOKABLE void reportDynamicTilingWindowState(const QStringList &maximizedWindowIds);
/**
* Whether the SHIFT snap layout picker is enabled.
* Defaults to true; only takes effect in convergence mode when gaming mode
* and dynamic tiling are off.
*/
bool snapLayoutsEnabled() const;
void setSnapLayoutsEnabled(bool enabled);
/**
* Whether logout button is shown in the logout/shutdown dialog.
*/
bool allowLogout() const;
/**
* The action of the left lock screen shortcut
*/
LockscreenButtonAction lockscreenLeftButtonAction() const;
/**
* Set the action of the left lock screen shortcut
*
* @param action
*/
void setLockscreenLeftButtonAction(LockscreenButtonAction action);
/**
* The action of the right lock screen shortcut
*/
LockscreenButtonAction lockscreenRightButtonAction() const;
/**
* Set the action of the right lock screen shortcut
*
* @param action
*/
void setLockscreenRightButtonAction(LockscreenButtonAction action);
Q_SIGNALS:
void vibrationsEnabledChanged();
void vibrationDurationChanged();
void navigationPanelEnabledChanged();
void gesturePanelEnabledChanged();
void alwaysShowKeyboardToggleOnNavigationPanelChanged();
void keyboardButtonEnabledChanged();
void animationsEnabledChanged();
void dateInStatusBarChanged();
void statusBarScaleFactorChanged();
void showBatteryPercentageChanged();
void taskSwitcherPreviewsEnabledChanged();
void actionDrawerTopLeftModeChanged();
void actionDrawerTopRightModeChanged();
void quickSettingsColumnsChanged();
void convergenceModeEnabledChanged();
void autoHidePanelsEnabledChanged();
void gamingModeEnabledChanged();
void gamingDismissHintEnabledChanged();
void dynamicTilingEnabledChanged();
void dynamicTilingWindowRequestChanged();
2026-05-22 07:39:11 +00:00
void dynamicTilingWindowStateChanged();
void snapLayoutsEnabledChanged();
void allowLogoutChanged();
void lockscreenLeftButtonActionChanged();
void lockscreenRightButtonActionChanged();
private:
void updateNavigationBarsInPlasma();
KConfigWatcher::Ptr m_configWatcher;
KSharedConfig::Ptr m_config;
};