filter workspaces by monitor
This commit is contained in:
parent
50cbbf6665
commit
f6e61ffa3b
2 changed files with 9 additions and 4 deletions
|
|
@ -1,4 +1,5 @@
|
|||
import QtQuick
|
||||
import Quickshell
|
||||
import Quickshell.Io
|
||||
import "." as M
|
||||
|
||||
|
|
@ -6,8 +7,12 @@ Row {
|
|||
id: root
|
||||
spacing: 4
|
||||
|
||||
property var _workspaces: []
|
||||
required property var bar
|
||||
|
||||
property var _allWorkspaces: []
|
||||
property int _activeId: -1
|
||||
readonly property string _output: bar.screen?.name ?? ""
|
||||
readonly property var _workspaces: _allWorkspaces.filter(w => w.output === root._output)
|
||||
|
||||
// Initial state
|
||||
Process {
|
||||
|
|
@ -18,7 +23,7 @@ Row {
|
|||
onStreamFinished: {
|
||||
try {
|
||||
const ws = JSON.parse(text);
|
||||
root._workspaces = ws.sort((a, b) => a.idx - b.idx);
|
||||
root._allWorkspaces = ws.sort((a, b) => a.idx - b.idx);
|
||||
for (const w of ws) {
|
||||
if (w.is_focused)
|
||||
root._activeId = w.id;
|
||||
|
|
@ -39,7 +44,7 @@ Row {
|
|||
try {
|
||||
const ev = JSON.parse(line);
|
||||
if (ev.WorkspacesChanged !== undefined) {
|
||||
root._workspaces = ev.WorkspacesChanged.workspaces
|
||||
root._allWorkspaces = ev.WorkspacesChanged.workspaces
|
||||
.sort((a, b) => a.idx - b.idx);
|
||||
} else if (ev.WorkspaceActivated !== undefined) {
|
||||
if (ev.WorkspaceActivated.focused)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue