status-desktop/storybook/pages/StatusToastMessagePage.qml

81 lines
41 KiB
QML
Raw Permalink Normal View History

import QtQuick 2.14
import QtQuick.Controls 2.14
import QtQuick.Layouts 1.12
import utils 1.0
import StatusQ.Components 0.1
import StatusQ.Core.Theme 0.1
import Storybook 1.0
import Models 1.0
SplitView {
id: root
Logs { id: logs }
orientation: Qt.Vertical
GridLayout {
id: toastArea
SplitView.fillWidth: true
SplitView.fillHeight: true
columns: 3
columnSpacing: 16
rowSpacing: 16
Repeater {
id: toastRepeater
width: parent.width
height: childrenRect.height
model: [
{"title":"anna.eth wants to verify your identity", "subTitle":"Provide the code in the letter I sent to you on February 1st.", "icon":"contact", "loading":false, "type":0,"url":"", "duration":0},
{"title":"Verification Request Sent", "subTitle":"", "icon":"checkmark-circle", "loading":false, "type":1,"url":"", "duration":4000},
{"title":"Collectible is being minted...", "subTitle":"View on Etherscan", "icon":"", "loading":true, "type":0,"url":"http://google.com", "duration":0},
{"title":"Contact request sent", "subTitle":"", "icon":"checkmark-circle", "loading":false, "type":1,"url":"", "duration":4000},
{"title":"Test User", "subTitle":"Hello message...", "icon":"", "loading":false, "type":0,"url":"", "duration":4000},
{"title":"This device is no longer the control node for the Socks Community", "subTitle":"", "icon":"info", "loading":false, "type":0,"url":"", "duration":0},
{"title":`This is, but not now, probably later on the road even it doesn't make sense, a very long title with <a style="text-decoration:none" href="www.qt.io">hyperlink</a>.`, "subTitle":"", "icon":"info", "loading":false, "type":2,"url":"", "duration":0},
{"title":`First community asset received`, "subTitle":"Navigate to somewhere", "loading":false, "actionType": "type" ,"type":2,"url":"", "duration":0, "image": "
]
delegate: StatusToastMessage {
primaryText: modelData.title
secondaryText: modelData.subTitle
image: modelData.image ? modelData.image : ""
imageRadius: 8
icon.name: modelData.icon ? modelData.icon : ""
loading: modelData.loading
type: modelData.type
linkUrl: modelData.url
duration: modelData.duration
actionRequired: !!modelData.actionType
onLinkActivated: {
Qt.openUrlExternally(link);
}
onClose: {
logs.logEvent("StatusToastMessage::close: " + modelData.title)
}
onClicked: {
logs.logEvent("StatusToastMessage::clicked: " + modelData.title)
}
}
}
}
LogsAndControlsPanel {
id: logsAndControlsPanel
SplitView.minimumHeight: 100
logsView.logText: logs.logText
}
}
// category: Components
// category: Components