forked from Shinonome/dots-hyprland
put notif popup in lazy loader
This commit is contained in:
@@ -15,103 +15,106 @@ Scope {
|
|||||||
Variants {
|
Variants {
|
||||||
model: Quickshell.screens
|
model: Quickshell.screens
|
||||||
|
|
||||||
PanelWindow {
|
LazyLoader {
|
||||||
id: root
|
loading: true
|
||||||
visible: true
|
PanelWindow {
|
||||||
|
id: root
|
||||||
|
visible: true
|
||||||
|
|
||||||
property var modelData
|
property var modelData
|
||||||
property Component notifComponent: NotificationWidget {}
|
property Component notifComponent: NotificationWidget {}
|
||||||
property list<NotificationWidget> notificationWidgetList: []
|
property list<NotificationWidget> notificationWidgetList: []
|
||||||
|
|
||||||
screen: modelData
|
screen: modelData
|
||||||
WlrLayershell.namespace: "quickshell:notificationPopup"
|
WlrLayershell.namespace: "quickshell:notificationPopup"
|
||||||
WlrLayershell.layer: WlrLayer.Overlay
|
WlrLayershell.layer: WlrLayer.Overlay
|
||||||
exclusiveZone: 0
|
exclusiveZone: 0
|
||||||
|
|
||||||
|
anchors {
|
||||||
|
top: true
|
||||||
|
right: true
|
||||||
|
bottom: true
|
||||||
|
}
|
||||||
|
|
||||||
|
mask: Region {
|
||||||
|
item: columnLayout
|
||||||
|
}
|
||||||
|
|
||||||
|
color: "transparent"
|
||||||
|
implicitWidth: Appearance.sizes.notificationPopupWidth
|
||||||
|
|
||||||
|
// Signal handlers to add/remove notifications
|
||||||
|
Connections {
|
||||||
|
target: Notifications
|
||||||
|
function onNotify(notification) {
|
||||||
|
if (GlobalStates.sidebarRightOpenCount > 0) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
// notificationRepeater.model = [notification, ...notificationRepeater.model]
|
||||||
|
const notif = root.notifComponent.createObject(columnLayout, {
|
||||||
|
notificationObject: notification,
|
||||||
|
popup: true
|
||||||
|
});
|
||||||
|
notificationWidgetList.unshift(notif)
|
||||||
|
|
||||||
|
// Remove stuff from t he column, add back
|
||||||
|
for (let i = 0; i < notificationWidgetList.length; i++) {
|
||||||
|
if (notificationWidgetList[i].parent === columnLayout) {
|
||||||
|
notificationWidgetList[i].parent = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add notification widgets to the column
|
||||||
|
for (let i = 0; i < notificationWidgetList.length; i++) {
|
||||||
|
if (notificationWidgetList[i].parent === null) {
|
||||||
|
notificationWidgetList[i].parent = columnLayout;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function onDiscard(id) {
|
||||||
|
for (let i = notificationWidgetList.length - 1; i >= 0; i--) {
|
||||||
|
const widget = notificationWidgetList[i];
|
||||||
|
if (widget && widget.notificationObject && widget.notificationObject.id === id) {
|
||||||
|
widget.destroyWithAnimation();
|
||||||
|
notificationWidgetList.splice(i, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function onTimeout(id) {
|
||||||
|
for (let i = notificationWidgetList.length - 1; i >= 0; i--) {
|
||||||
|
const widget = notificationWidgetList[i];
|
||||||
|
if (widget && widget.notificationObject && widget.notificationObject.id === id) {
|
||||||
|
widget.destroyWithAnimation();
|
||||||
|
notificationWidgetList.splice(i, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function onDiscardAll() {
|
||||||
|
for (let i = notificationWidgetList.length - 1; i >= 0; i--) {
|
||||||
|
const widget = notificationWidgetList[i];
|
||||||
|
if (widget && widget.notificationObject) {
|
||||||
|
widget.destroyWithAnimation();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
notificationWidgetList = [];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ColumnLayout { // Scrollable window content
|
||||||
|
id: columnLayout
|
||||||
|
anchors.horizontalCenter: parent.horizontalCenter
|
||||||
|
width: parent.width - Appearance.sizes.hyprlandGapsOut * 2
|
||||||
|
spacing: 0 // The widgets themselves have margins for spacing
|
||||||
|
|
||||||
|
Item {
|
||||||
|
implicitHeight: 1
|
||||||
|
implicitWidth: 1
|
||||||
|
}
|
||||||
|
|
||||||
|
// Notifications are added by the above signal handlers
|
||||||
|
}
|
||||||
|
|
||||||
anchors {
|
|
||||||
top: true
|
|
||||||
right: true
|
|
||||||
bottom: true
|
|
||||||
}
|
}
|
||||||
|
|
||||||
mask: Region {
|
|
||||||
item: columnLayout
|
|
||||||
}
|
|
||||||
|
|
||||||
color: "transparent"
|
|
||||||
implicitWidth: Appearance.sizes.notificationPopupWidth
|
|
||||||
|
|
||||||
// Signal handlers to add/remove notifications
|
|
||||||
Connections {
|
|
||||||
target: Notifications
|
|
||||||
function onNotify(notification) {
|
|
||||||
if (GlobalStates.sidebarRightOpenCount > 0) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
// notificationRepeater.model = [notification, ...notificationRepeater.model]
|
|
||||||
const notif = root.notifComponent.createObject(columnLayout, {
|
|
||||||
notificationObject: notification,
|
|
||||||
popup: true
|
|
||||||
});
|
|
||||||
notificationWidgetList.unshift(notif)
|
|
||||||
|
|
||||||
// Remove stuff from t he column, add back
|
|
||||||
for (let i = 0; i < notificationWidgetList.length; i++) {
|
|
||||||
if (notificationWidgetList[i].parent === columnLayout) {
|
|
||||||
notificationWidgetList[i].parent = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add notification widgets to the column
|
|
||||||
for (let i = 0; i < notificationWidgetList.length; i++) {
|
|
||||||
if (notificationWidgetList[i].parent === null) {
|
|
||||||
notificationWidgetList[i].parent = columnLayout;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
function onDiscard(id) {
|
|
||||||
for (let i = notificationWidgetList.length - 1; i >= 0; i--) {
|
|
||||||
const widget = notificationWidgetList[i];
|
|
||||||
if (widget && widget.notificationObject && widget.notificationObject.id === id) {
|
|
||||||
widget.destroyWithAnimation();
|
|
||||||
notificationWidgetList.splice(i, 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
function onTimeout(id) {
|
|
||||||
for (let i = notificationWidgetList.length - 1; i >= 0; i--) {
|
|
||||||
const widget = notificationWidgetList[i];
|
|
||||||
if (widget && widget.notificationObject && widget.notificationObject.id === id) {
|
|
||||||
widget.destroyWithAnimation();
|
|
||||||
notificationWidgetList.splice(i, 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
function onDiscardAll() {
|
|
||||||
for (let i = notificationWidgetList.length - 1; i >= 0; i--) {
|
|
||||||
const widget = notificationWidgetList[i];
|
|
||||||
if (widget && widget.notificationObject) {
|
|
||||||
widget.destroyWithAnimation();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
notificationWidgetList = [];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ColumnLayout { // Scrollable window content
|
|
||||||
id: columnLayout
|
|
||||||
anchors.horizontalCenter: parent.horizontalCenter
|
|
||||||
width: parent.width - Appearance.sizes.hyprlandGapsOut * 2
|
|
||||||
spacing: 0 // The widgets themselves have margins for spacing
|
|
||||||
|
|
||||||
Item {
|
|
||||||
implicitHeight: 1
|
|
||||||
implicitWidth: 1
|
|
||||||
}
|
|
||||||
|
|
||||||
// Notifications are added by the above signal handlers
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user