mirror of
https://github.com/AvengeMedia/DankMaterialShell.git
synced 2026-04-15 18:22:08 -04:00
Merge branch 'master' of github.com:bbedward/DankMaterialShell into notif-work
This commit is contained in:
@@ -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() {
|
||||||
|
|||||||
@@ -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
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user