Notification: Converted to Layout
+ removed fontPointSize on NIconButton. use sizeRatio instead.
This commit is contained in:
parent
a4c98f1382
commit
cf624f4d65
3 changed files with 78 additions and 87 deletions
|
|
@ -78,7 +78,7 @@ Variants {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Main notification container
|
// Main notification container
|
||||||
Column {
|
ColumnLayout {
|
||||||
id: notificationStack
|
id: notificationStack
|
||||||
// Position based on bar location
|
// Position based on bar location
|
||||||
anchors.top: Settings.data.bar.position === "top" ? parent.top : undefined
|
anchors.top: Settings.data.bar.position === "top" ? parent.top : undefined
|
||||||
|
|
@ -92,11 +92,9 @@ Variants {
|
||||||
Repeater {
|
Repeater {
|
||||||
model: notificationModel
|
model: notificationModel
|
||||||
delegate: Rectangle {
|
delegate: Rectangle {
|
||||||
width: 360 * scaling
|
Layout.preferredWidth: 360 * scaling
|
||||||
height: Math.max(
|
Layout.preferredHeight: notificationLayout.implicitHeight + (Style.marginL * 2 * scaling)
|
||||||
80 * scaling,
|
Layout.maximumHeight: Layout.preferredHeight
|
||||||
contentRow.implicitHeight + (actionsRow.visible ? actionsRow.implicitHeight + Style.marginM
|
|
||||||
* scaling : 0) + (Style.marginL * 2 * scaling))
|
|
||||||
clip: true
|
clip: true
|
||||||
radius: Style.radiusL * scaling
|
radius: Style.radiusL * scaling
|
||||||
border.color: Color.mOutline
|
border.color: Color.mOutline
|
||||||
|
|
@ -171,98 +169,87 @@ Variants {
|
||||||
}
|
}
|
||||||
|
|
||||||
ColumnLayout {
|
ColumnLayout {
|
||||||
|
id: notificationLayout
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
anchors.margins: Style.marginM * scaling
|
anchors.margins: Style.marginM * scaling
|
||||||
|
anchors.rightMargin: (Style.marginM + 32) * scaling // Leave space for close button
|
||||||
spacing: Style.marginM * scaling
|
spacing: Style.marginM * scaling
|
||||||
|
|
||||||
|
// Header section with app name and timestamp
|
||||||
RowLayout {
|
RowLayout {
|
||||||
id: contentRow
|
|
||||||
spacing: Style.marginM * scaling
|
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
|
spacing: Style.marginS * scaling
|
||||||
|
|
||||||
// Right: header on top, then avatar + texts
|
NText {
|
||||||
ColumnLayout {
|
text: `${(model.appName || model.desktopEntry)
|
||||||
id: textColumn
|
|| "Unknown App"} · ${NotificationService.formatTimestamp(model.timestamp)}`
|
||||||
spacing: Style.marginS * scaling
|
color: Color.mSecondary
|
||||||
|
font.pointSize: Style.fontSizeXS * scaling
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
Rectangle {
|
||||||
|
Layout.preferredWidth: 6 * scaling
|
||||||
|
Layout.preferredHeight: 6 * scaling
|
||||||
|
radius: Style.radiusXS * scaling
|
||||||
|
color: (model.urgency === NotificationUrgency.Critical) ? Color.mError : (model.urgency === NotificationUrgency.Low) ? Color.mOnSurface : Color.mPrimary
|
||||||
|
Layout.alignment: Qt.AlignVCenter
|
||||||
|
}
|
||||||
|
|
||||||
|
Item {
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
RowLayout {
|
// Main content section
|
||||||
spacing: Style.marginS * scaling
|
RowLayout {
|
||||||
id: appHeaderRow
|
Layout.fillWidth: true
|
||||||
NText {
|
spacing: Style.marginM * scaling
|
||||||
text: `${(model.appName || model.desktopEntry)
|
|
||||||
|| "Unknown App"} · ${NotificationService.formatTimestamp(model.timestamp)}`
|
// Avatar
|
||||||
color: Color.mSecondary
|
NImageCircled {
|
||||||
font.pointSize: Style.fontSizeXS * scaling
|
id: appAvatar
|
||||||
}
|
Layout.preferredWidth: 40 * scaling
|
||||||
Rectangle {
|
Layout.preferredHeight: 40 * scaling
|
||||||
width: 6 * scaling
|
Layout.alignment: Qt.AlignTop
|
||||||
height: 6 * scaling
|
imagePath: model.image && model.image !== "" ? model.image : ""
|
||||||
radius: Style.radiusXS * scaling
|
fallbackIcon: ""
|
||||||
color: (model.urgency === NotificationUrgency.Critical) ? Color.mError : (model.urgency === NotificationUrgency.Low) ? Color.mOnSurface : Color.mPrimary
|
borderColor: Color.transparent
|
||||||
Layout.alignment: Qt.AlignVCenter
|
borderWidth: 0
|
||||||
}
|
visible: (model.image && model.image !== "")
|
||||||
Item {
|
}
|
||||||
Layout.fillWidth: true
|
|
||||||
}
|
// Text content
|
||||||
|
ColumnLayout {
|
||||||
|
Layout.fillWidth: true
|
||||||
|
spacing: Style.marginS * scaling
|
||||||
|
|
||||||
|
NText {
|
||||||
|
text: model.summary || "No summary"
|
||||||
|
font.pointSize: Style.fontSizeL * scaling
|
||||||
|
font.weight: Style.fontWeightMedium
|
||||||
|
color: Color.mOnSurface
|
||||||
|
wrapMode: Text.WrapAtWordBoundaryOrAnywhere
|
||||||
|
Layout.fillWidth: true
|
||||||
|
maximumLineCount: 3
|
||||||
|
elide: Text.ElideRight
|
||||||
}
|
}
|
||||||
|
|
||||||
RowLayout {
|
NText {
|
||||||
id: bodyRow
|
text: model.body || ""
|
||||||
spacing: Style.marginM * scaling
|
font.pointSize: Style.fontSizeM * scaling
|
||||||
|
color: Color.mOnSurface
|
||||||
NImageCircled {
|
wrapMode: Text.WrapAtWordBoundaryOrAnywhere
|
||||||
id: appAvatar
|
Layout.fillWidth: true
|
||||||
Layout.preferredWidth: 40 * scaling
|
maximumLineCount: 5
|
||||||
Layout.preferredHeight: 40 * scaling
|
elide: Text.ElideRight
|
||||||
Layout.alignment: Qt.AlignTop
|
visible: text.length > 0
|
||||||
anchors.topMargin: textContent.childrenRect.y
|
|
||||||
imagePath: model.image && model.image !== "" ? model.image : ""
|
|
||||||
fallbackIcon: ""
|
|
||||||
borderColor: Color.transparent
|
|
||||||
borderWidth: 0
|
|
||||||
visible: (model.image && model.image !== "")
|
|
||||||
Layout.fillWidth: false
|
|
||||||
Layout.fillHeight: false
|
|
||||||
}
|
|
||||||
|
|
||||||
Column {
|
|
||||||
id: textContent
|
|
||||||
spacing: Style.marginS * scaling
|
|
||||||
Layout.fillWidth: true
|
|
||||||
// Ensure a concrete width so text wraps
|
|
||||||
width: (textColumn.width - (appAvatar.visible ? (appAvatar.width + Style.marginM * scaling) : 0))
|
|
||||||
|
|
||||||
NText {
|
|
||||||
text: model.summary || "No summary"
|
|
||||||
font.pointSize: Style.fontSizeL * scaling
|
|
||||||
font.weight: Style.fontWeightMedium
|
|
||||||
color: Color.mOnSurface
|
|
||||||
wrapMode: Text.WrapAtWordBoundaryOrAnywhere
|
|
||||||
Layout.fillWidth: true
|
|
||||||
width: parent.width
|
|
||||||
maximumLineCount: 3
|
|
||||||
elide: Text.ElideRight
|
|
||||||
}
|
|
||||||
|
|
||||||
NText {
|
|
||||||
text: model.body || ""
|
|
||||||
font.pointSize: Style.fontSizeM * scaling
|
|
||||||
color: Color.mOnSurface
|
|
||||||
wrapMode: Text.WrapAtWordBoundaryOrAnywhere
|
|
||||||
Layout.fillWidth: true
|
|
||||||
width: parent.width
|
|
||||||
maximumLineCount: 5
|
|
||||||
elide: Text.ElideRight
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Notification actions - positioned below the main content
|
// Notification actions
|
||||||
RowLayout {
|
RowLayout {
|
||||||
id: actionsRow
|
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
spacing: Style.marginS * scaling
|
spacing: Style.marginS * scaling
|
||||||
visible: model.rawNotification && model.rawNotification.actions
|
visible: model.rawNotification && model.rawNotification.actions
|
||||||
|
|
@ -271,7 +258,7 @@ Variants {
|
||||||
property var notificationActions: model.rawNotification ? model.rawNotification.actions : []
|
property var notificationActions: model.rawNotification ? model.rawNotification.actions : []
|
||||||
|
|
||||||
Repeater {
|
Repeater {
|
||||||
model: actionsRow.notificationActions
|
model: parent.notificationActions
|
||||||
|
|
||||||
delegate: NButton {
|
delegate: NButton {
|
||||||
text: {
|
text: {
|
||||||
|
|
@ -289,6 +276,7 @@ Variants {
|
||||||
pressColor: Color.mTertiary
|
pressColor: Color.mTertiary
|
||||||
outlined: false
|
outlined: false
|
||||||
customHeight: 32 * scaling
|
customHeight: 32 * scaling
|
||||||
|
Layout.preferredHeight: 32 * scaling
|
||||||
|
|
||||||
onClicked: {
|
onClicked: {
|
||||||
if (modelData && modelData.invoke) {
|
if (modelData && modelData.invoke) {
|
||||||
|
|
@ -297,14 +285,19 @@ Variants {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Spacer to push buttons to the left if needed
|
||||||
|
Item {
|
||||||
|
Layout.fillWidth: true
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Close button positioned absolutely
|
||||||
NIconButton {
|
NIconButton {
|
||||||
icon: "close"
|
icon: "close"
|
||||||
tooltipText: "Close"
|
tooltipText: "Close"
|
||||||
sizeRatio: 0.6
|
sizeRatio: 0.6
|
||||||
fontPointSize: 12
|
|
||||||
anchors.top: parent.top
|
anchors.top: parent.top
|
||||||
anchors.topMargin: Style.marginM * scaling
|
anchors.topMargin: Style.marginM * scaling
|
||||||
anchors.right: parent.right
|
anchors.right: parent.right
|
||||||
|
|
|
||||||
|
|
@ -15,7 +15,6 @@ Rectangle {
|
||||||
property string tooltipText
|
property string tooltipText
|
||||||
property bool enabled: true
|
property bool enabled: true
|
||||||
property bool hovering: false
|
property bool hovering: false
|
||||||
property real fontPointSize: Style.fontSizeM
|
|
||||||
|
|
||||||
property color colorBg: Color.mSurfaceVariant
|
property color colorBg: Color.mSurfaceVariant
|
||||||
property color colorFg: Color.mPrimary
|
property color colorFg: Color.mPrimary
|
||||||
|
|
@ -41,7 +40,7 @@ Rectangle {
|
||||||
|
|
||||||
NIcon {
|
NIcon {
|
||||||
text: root.icon
|
text: root.icon
|
||||||
font.pointSize: root.fontPointSize * scaling
|
font.pointSize: Style.fontSizeM * scaling
|
||||||
color: root.hovering ? colorFgHover : colorFg
|
color: root.hovering ? colorFgHover : colorFg
|
||||||
// Center horizontally
|
// Center horizontally
|
||||||
x: (root.width - width) / 2
|
x: (root.width - width) / 2
|
||||||
|
|
|
||||||
|
|
@ -180,7 +180,6 @@ Item {
|
||||||
colorBorder: Color.transparent
|
colorBorder: Color.transparent
|
||||||
colorBorderHover: Color.mOutline
|
colorBorderHover: Color.mOutline
|
||||||
|
|
||||||
fontPointSize: Style.fontSizeM * scaling
|
|
||||||
sizeRatio: 0.8
|
sizeRatio: 0.8
|
||||||
Layout.alignment: Qt.AlignTop
|
Layout.alignment: Qt.AlignTop
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue