1
0
mirror of https://github.com/AvengeMedia/DankMaterialShell.git synced 2026-04-14 17:52:10 -04:00

Merge branch 'master' of github.com:bbedward/DankMaterialShell into notif-work

This commit is contained in:
bbedward
2025-08-12 11:05:25 -04:00
2 changed files with 53 additions and 5 deletions

View File

@@ -148,20 +148,29 @@ Singleton {
onStreamFinished: { onStreamFinished: {
const out = matugenCollector.text const out = matugenCollector.text
if (!out.length) { const startIndex = out.indexOf('{')
const endIndex = out.lastIndexOf('}')
let jsonStringOnly = ""
if (startIndex !== -1 && endIndex !== -1 && endIndex > startIndex) {
jsonStringOnly = out.substring(startIndex, endIndex + 1)
}
if (!jsonStringOnly.length) {
ToastService.wallpaperErrorStatus = "error" ToastService.wallpaperErrorStatus = "error"
ToastService.showError("Wallpaper Processing Failed") ToastService.showError("Wallpaper Processing Failed: Empty JSON extracted from matugen output.")
return return
} }
try { try {
root.matugenJson = out root.matugenJson = jsonStringOnly
root.matugenColors = JSON.parse(out) root.matugenColors = JSON.parse(jsonStringOnly)
root.colorsUpdated() root.colorsUpdated()
generateAppConfigs() generateAppConfigs()
ToastService.clearWallpaperError() ToastService.clearWallpaperError()
} catch (e) { } catch (e) {
ToastService.wallpaperErrorStatus = "error" ToastService.wallpaperErrorStatus = "error"
ToastService.showError("Wallpaper Processing Failed") const stderr = matugenErr.text
const msg = "Wallpaper processing failed (JSON parse error after extraction)"
+ (stderr ? `: ${stderr}` : ` with output: ${jsonStringOnly}`)
ToastService.showError(msg)
} }
} }
} }
@@ -169,6 +178,16 @@ Singleton {
stderr: StdioCollector { stderr: StdioCollector {
id: matugenErr id: matugenErr
} }
onExited: code => {
if (code !== 0) {
ToastService.wallpaperErrorStatus = "error"
const stderr = matugenErr.text
const msg = "Matugen command failed with exit code " + code
+ (stderr ? `: ${stderr}` : ". No stderr output.")
ToastService.showError(msg)
}
}
} }
function generateAppConfigs() { function generateAppConfigs() {

View File

@@ -13,6 +13,35 @@ Item {
loader.activeAsync = true loader.activeAsync = true
} }
function checkLockedOnStartup() {
lockStateChecker.running = true
}
Component.onCompleted: {
checkLockedOnStartup()
}
Process {
id: lockStateChecker
command: ["sh", "-c", "loginctl show-session $(loginctl list-sessions --no-legend | awk '{print $1}' | head -1) --property=LockedHint"]
running: false
onExited: (exitCode, exitStatus) => {
if (exitCode !== 0) {
console.warn("Failed to check session lock state, exit code:", exitCode)
}
}
stdout: StdioCollector {
onStreamFinished: {
if (text.trim() === "LockedHint=yes") {
console.log("Session is locked on startup, activating lock screen")
loader.activeAsync = true
}
}
}
}
LazyLoader { LazyLoader {
id: loader id: loader