PlaceholderMessage QML Type
A placeholder message indicating that a view is empty. More...
Import Statement: | import org.kde.kirigami |
Inherits: | |
Inherited By: |
Properties
- explanation : string
(since 5.80)
- helpfulAction : QtQuick.Controls.Action
(since 5.70)
- hoveredLink : string
- icon : P.ActionIconGroup
(since 5.70)
- icon.color : color
(since 5.70)
- icon.height : int
(since 5.70)
- icon.name : string
(since 5.70)
- icon.source : string
(since 5.70)
- icon.width : int
(since 5.70)
- text : string
(since 5.70)
- type : int
(since 5.94)
Signals
- linkActivated(string link)
- linkHovered(string link)
Detailed Description
The message comprises a label with text, an optional explanation below the main text, an optional icon above all the text, and an optional button below all the text which can be used to easily show the user what to do next to add content to the view.
The explanatory text is selectable and can contain clickable links. In this latter case, client code must implement an ``onLinkactivated:`` signal handler or the links will not work.
The top-level component is a ColumnLayout, so additional components items can simply be added as child items and they will be positioned sanely.
Example usage:
used as a "this view is empty" message:
import org.kde.kirigami as Kirigami ListView { id: listView model: [...] delegate: [...] Kirigami.PlaceholderMessage { anchors.centerIn: parent width: parent.width - (Kirigami.Units.largeSpacing * 4) visible: listView.count === 0 text: "There are no items in this list" } }
Used as a "here's how to proceed" message:
import org.kde.kirigami as Kirigami ListView { id: listView model: [...] delegate: [...] Kirigami.PlaceholderMessage { anchors.centerIn: parent width: parent.width - (Kirigami.Units.largeSpacing * 4) visible: listView.count === 0 text: "Add an item to proceed" helpfulAction: Kirigami.Action { icon.name: "list-add" text: "Add item..." onTriggered: { [...] } } } [...] }
Used as a "there was a problem here" message
import org.kde.kirigami as Kirigami Kirigami.Page { id: root readonly property bool networkConnected: [...] Kirigami.PlaceholderMessage { anchors.centerIn: parent width: parent.width - (Kirigami.Units.largeSpacing * 4) visible: root.networkConnected icon.name: "network-disconnect" text: "Unable to load content" explanation: "Please try again later." " Visit <a href="https://foo.com/com>this link</a> for more details." onLinkActivated: link => Qt.openUrlExternally(link) } }
Used as a "Here's what you do next" button
import org.kde.kirigami as Kirigami Kirigami.Page { id: root Kirigami.PlaceholderMessage { anchors.centerIn: parent width: parent.width - (Kirigami.Units.largeSpacing * 4) visible: root.loading helpfulAction: Kirigami.Action { icon.name: "list-add" text: "Add item..." onTriggered: { [...] } } } }
Property Documentation
explanation : string |
This property holds the smaller explanatory text to show below the larger title-style text
Useful for providing a user-friendly explanation on how to proceed.
Optional; if not defined, the message will have no supplementary explanatory text.
This property was introduced in 5.80.
helpfulAction : QtQuick.Controls.Action |
This property holds an action that helps the user proceed.
Typically used to guide the user to the next step for adding content or items to an empty view.
Optional; if undefined, no button will appear below the text label.
This property was introduced in 5.70.
hoveredLink : string |
This property holds the link embedded in the explanatory message text that the user is hovering over.
icon : P.ActionIconGroup |
TODO qdoc grouped properties don't work yet
This property provides an icon to display above the top text label.
Note: It accepts icon.name and icon.source to set the icon source. It is suggested to use icon.name.
Optional; if undefined, the message will have no icon. Falls back to undefined
if the specified icon is not valid or cannot be loaded.
This property was introduced in 5.70.
icon.color : color |
TODO qdoc grouped properties don't work yet
This property provides an icon to display above the top text label.
Note: It accepts icon.name and icon.source to set the icon source. It is suggested to use icon.name.
Optional; if undefined, the message will have no icon. Falls back to undefined
if the specified icon is not valid or cannot be loaded.
This property was introduced in 5.70.
icon.height : int |
TODO qdoc grouped properties don't work yet
This property provides an icon to display above the top text label.
Note: It accepts icon.name and icon.source to set the icon source. It is suggested to use icon.name.
Optional; if undefined, the message will have no icon. Falls back to undefined
if the specified icon is not valid or cannot be loaded.
This property was introduced in 5.70.
icon.name : string |
TODO qdoc grouped properties don't work yet
This property provides an icon to display above the top text label.
Note: It accepts icon.name and icon.source to set the icon source. It is suggested to use icon.name.
Optional; if undefined, the message will have no icon. Falls back to undefined
if the specified icon is not valid or cannot be loaded.
This property was introduced in 5.70.
icon.source : string |
TODO qdoc grouped properties don't work yet
This property provides an icon to display above the top text label.
Note: It accepts icon.name and icon.source to set the icon source. It is suggested to use icon.name.
Optional; if undefined, the message will have no icon. Falls back to undefined
if the specified icon is not valid or cannot be loaded.
This property was introduced in 5.70.
icon.width : int |
TODO qdoc grouped properties don't work yet
This property provides an icon to display above the top text label.
Note: It accepts icon.name and icon.source to set the icon source. It is suggested to use icon.name.
Optional; if undefined, the message will have no icon. Falls back to undefined
if the specified icon is not valid or cannot be loaded.
This property was introduced in 5.70.
text : string |
This property holds the text to show in the placeholder label.
Optional; if not defined, the message will have no large text label text. If both text and explanation are omitted, the message will have no text and only an icon, action button, and/or other custom content.
This property was introduced in 5.70.
type : int |
This property holds the PlaceholderMessage type.
The type of the message. This can be:
- Kirigami.PlaceholderMessage.Type.Actionable: Makes it more attention-getting. Useful when the user is expected to interact with the message.
- Kirigami.PlaceholderMessage.Type.Informational: Makes it less prominent. Useful when the message in only informational.
default: if a helpfulAction is provided this will be of type Actionable otherwise of type Informational.
This property was introduced in 5.94.
Signal Documentation
linkActivated(string link) |
This signal is emitted when a link is clicked or tapped in the explanatory message text.
link The clicked or tapped link.
Note: The corresponding handler is onLinkActivated
.
linkHovered(string link) |
This signal is emitted when a link is hovered in the explanatory message text.
link The hovered link.
Note: The corresponding handler is onLinkHovered
.