noctalia-shell/Services/Colors.qml
2025-08-14 15:17:54 +02:00

166 lines
5.6 KiB
QML

pragma Singleton
import QtQuick
import Quickshell
import Quickshell.Io
import qs.Services
Singleton {
id: root
// Backgrounds
property color backgroundPrimary: useMatugen ? matugenTheme.backgroundPrimary : defaultTheme.backgroundPrimary
property color backgroundSecondary: useMatugen ? matugenTheme.backgroundSecondary : defaultTheme.backgroundSecondary
property color backgroundTertiary: useMatugen ? matugenTheme.backgroundTertiary : defaultTheme.backgroundTertiary
// Surfaces & Elevation
property color surface: useMatugen ? matugenTheme.surface : defaultTheme.surface
property color surfaceVariant: useMatugen ? matugenTheme.surfaceVariant : defaultTheme.surfaceVariant
// Text Colors
property color textPrimary: useMatugen ? matugenTheme.textPrimary : defaultTheme.textPrimary
property color textSecondary: useMatugen ? matugenTheme.textSecondary : defaultTheme.textSecondary
property color textDisabled: useMatugen ? matugenTheme.textDisabled : defaultTheme.textDisabled
// Accent Colors
property color accentPrimary: useMatugen ? matugenTheme.accentPrimary : defaultTheme.accentPrimary
property color accentSecondary: useMatugen ? matugenTheme.accentSecondary : defaultTheme.accentSecondary
property color accentTertiary: useMatugen ? matugenTheme.accentTertiary : defaultTheme.accentTertiary
// Error/Warning
property color error: useMatugen ? matugenTheme.error : defaultTheme.error
property color warning: useMatugen ? matugenTheme.warning : defaultTheme.warning
// Hover
property color hover: useMatugen ? matugenTheme.hover : defaultTheme.hover
// Additional Theme Properties
property color onAccent: useMatugen ? matugenTheme.onAccent : defaultTheme.onAccent
property color outline: useMatugen ? matugenTheme.outline : defaultTheme.outline
// Shadows & Overlays
property color shadow: applyOpacity(useMatugen ? matugenTheme.shadow : defaultTheme.shadow, "B3")
property color overlay: applyOpacity(useMatugen ? matugenTheme.overlay : defaultTheme.overlay, "66")
// Check if we should use Matugen theme
property bool useMatugen: Settings.data.wallpaper.generateTheme && matugenFile.loaded
function applyOpacity(color, opacity) {
// Convert color to string and apply opacity
return color.toString().replace("#", "#" + opacity)
}
// Default theme colors
QtObject {
id: defaultTheme
property color backgroundPrimary: "#191724"
property color backgroundSecondary: "#1f1d2e"
property color backgroundTertiary: "#26233a"
property color surface: "#1b1927"
property color surfaceVariant: "#262337"
property color textPrimary: "#e0def4"
property color textSecondary: "#908caa"
property color textDisabled: "#6e6a86"
property color accentPrimary: "#ebbcba"
property color accentSecondary: "#31748f"
property color accentTertiary: "#9ccfd8"
property color error: "#eb6f92"
property color warning: "#f6c177"
property color hover: "#c4a7e7"
property color onAccent: "#191724"
property color outline: "#44415a"
property color shadow: "#191724"
property color overlay: "#191724"
}
// Matugen theme colors (loaded from theme.json)
QtObject {
id: matugenTheme
property color backgroundPrimary: matugenData.backgroundPrimary
property color backgroundSecondary: matugenData.backgroundSecondary
property color backgroundTertiary: matugenData.backgroundTertiary
property color surface: matugenData.surface
property color surfaceVariant: matugenData.surfaceVariant
property color textPrimary: matugenData.textPrimary
property color textSecondary: matugenData.textSecondary
property color textDisabled: matugenData.textDisabled
property color accentPrimary: matugenData.accentPrimary
property color accentSecondary: matugenData.accentSecondary
property color accentTertiary: matugenData.accentTertiary
property color error: matugenData.error
property color warning: matugenData.warning
property color hover: matugenData.hover
property color onAccent: matugenData.onAccent
property color outline: matugenData.outline
property color shadow: matugenData.shadow
property color overlay: matugenData.overlay
}
// FileView to load Matugen theme data from Theme.json
FileView {
id: matugenFile
path: Settings.configDir + "theme.json"
watchChanges: true
onFileChanged: reload()
onAdapterUpdated: writeAdapter()
onLoadFailed: function (error) {
if (error.toString().includes("No such file") || error === 2) {
// File doesn't exist, create it with default values
writeAdapter()
}
}
JsonAdapter {
id: matugenData
// Backgrounds
property string backgroundPrimary: "#191724"
property string backgroundSecondary: "#1f1d2e"
property string backgroundTertiary: "#26233a"
// Surfaces & Elevation
property string surface: "#1b1927"
property string surfaceVariant: "#262337"
// Text Colors
property string textPrimary: "#e0def4"
property string textSecondary: "#908caa"
property string textDisabled: "#6e6a86"
// Accent Colors
property string accentPrimary: "#ebbcba"
property string accentSecondary: "#31748f"
property string accentTertiary: "#9ccfd8"
// Error/Warning
property string error: "#eb6f92"
property string warning: "#f6c177"
// Hover
property string hover: "#c4a7e7"
// Additional Theme Properties
property string onAccent: "#191724"
property string outline: "#44415a"
// Shadows & Overlays
property string shadow: "#191724"
property string overlay: "#191724"
}
}
}