Move quickshell to its own module
This commit is contained in:
parent
1dd031aa6b
commit
b6bff47ed1
9 changed files with 34 additions and 30 deletions
|
@ -52,10 +52,6 @@ in {
|
|||
wrapper
|
||||
hyprpaper
|
||||
|
||||
pamtester # quickshell lockscreen
|
||||
quickshell.packages.${system}.default
|
||||
(writeShellScriptBin "quickshell-lock" "quickshell -c ${impurity.link ./lockscreen/shell.qml}")
|
||||
|
||||
# environment programs
|
||||
wl-clipboard
|
||||
grim
|
||||
|
|
|
@ -146,7 +146,7 @@ bind = ,XF86AudioPrev, exec, playerctl previous
|
|||
|
||||
bind = $mod+SHIFT, s, exec, grim -g "$(slurp)" - | wl-copy
|
||||
|
||||
bind = $mod, PERIOD, exec, quickshell-lock
|
||||
bind = $mod, PERIOD, exec, quickshell -c lockscreen
|
||||
|
||||
bind = $mod, h, hy3:movefocus, l
|
||||
bind = $mod, j, hy3:movefocus, d
|
||||
|
|
|
@ -1,43 +0,0 @@
|
|||
import QtQuick
|
||||
import Quickshell
|
||||
import Quickshell.Io
|
||||
|
||||
QtObject {
|
||||
property int status: AuthContext.Status.FirstEntry
|
||||
signal success();
|
||||
|
||||
enum Status {
|
||||
FirstEntry,
|
||||
Authenticating,
|
||||
LoginFailed
|
||||
}
|
||||
|
||||
property string password
|
||||
|
||||
property var pamtester: Process {
|
||||
property bool failed: true
|
||||
|
||||
command: ["pamtester", "login", Quickshell.env("USER"), "authenticate"]
|
||||
|
||||
onStarted: this.write(`${password}\n`)
|
||||
|
||||
stdout: SplitParser {
|
||||
// fails go to stderr
|
||||
onRead: pamtester.failed = false
|
||||
}
|
||||
|
||||
onExited: {
|
||||
if (failed) {
|
||||
status = AuthContext.Status.LoginFailed
|
||||
} else {
|
||||
success();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function tryLogin(password: string) {
|
||||
this.password = password
|
||||
status = AuthContext.Status.Authenticating;
|
||||
pamtester.running = true;
|
||||
}
|
||||
}
|
|
@ -1,53 +0,0 @@
|
|||
import QtQuick
|
||||
import QtQuick.Controls.Universal
|
||||
import QtQuick.Layouts
|
||||
import Quickshell
|
||||
|
||||
Item {
|
||||
required property AuthContext context
|
||||
|
||||
Item {
|
||||
anchors.centerIn: parent
|
||||
scale: 2
|
||||
|
||||
TextField {
|
||||
id: entryBox
|
||||
anchors.centerIn: parent
|
||||
width: 300
|
||||
|
||||
enabled: context.status != AuthContext.Status.Authenticating
|
||||
focus: true
|
||||
horizontalAlignment: TextInput.AlignHCenter
|
||||
echoMode: TextInput.Password
|
||||
inputMethodHints: Qt.ImhSensitiveData
|
||||
placeholderText: "Enter password"
|
||||
|
||||
onAccepted: {
|
||||
if (text != "") context.tryLogin(text)
|
||||
}
|
||||
|
||||
onEnabledChanged: {
|
||||
if (enabled) text = ""
|
||||
}
|
||||
}
|
||||
|
||||
Text {
|
||||
id: status
|
||||
color: "white"
|
||||
|
||||
anchors {
|
||||
horizontalCenter: entryBox.horizontalCenter
|
||||
top: entryBox.bottom
|
||||
topMargin: 20
|
||||
}
|
||||
|
||||
text: {
|
||||
switch (context.status) {
|
||||
case AuthContext.Status.FirstEntry: return ""
|
||||
case AuthContext.Status.Authenticating: return "Authenticating"
|
||||
case AuthContext.Status.LoginFailed: return "Login Failed"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,33 +0,0 @@
|
|||
import QtQuick
|
||||
import QtQuick.Controls
|
||||
import Quickshell
|
||||
import Quickshell.Wayland
|
||||
|
||||
ShellRoot {
|
||||
AuthContext {
|
||||
id: authContext
|
||||
onSuccess: {
|
||||
lock.locked = false;
|
||||
Qt.quit()
|
||||
}
|
||||
}
|
||||
|
||||
SessionLock {
|
||||
id: lock
|
||||
locked: true
|
||||
|
||||
SessionLockSurface {
|
||||
id: surface
|
||||
Image {
|
||||
anchors.fill: parent
|
||||
source: screen.name == "DP-1" ? "../5120x1440.png" : "../1920x1080.png"
|
||||
}
|
||||
|
||||
Lockscreen {
|
||||
anchors.fill: parent
|
||||
context: authContext
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -1,21 +0,0 @@
|
|||
import QtQuick
|
||||
import Quickshell
|
||||
|
||||
ShellRoot {
|
||||
AuthContext {
|
||||
id: authContext
|
||||
onSuccess: Qt.quit()
|
||||
}
|
||||
|
||||
FloatingWindow {
|
||||
Image {
|
||||
anchors.fill: parent
|
||||
source: "../1920x1080.png"
|
||||
}
|
||||
|
||||
Lockscreen {
|
||||
anchors.fill: parent
|
||||
context: authContext
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue