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
- helpfulAction : QtQuick.Controls.Action
- hoveredLink : string
- icon- icon.color : color
- icon.height : int
- icon.name : string
- icon.source : string
- icon.width : int
 
- text : string
- type : enumeration
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.
| 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.
| 
hoveredLink : string  | 
This property holds the link embedded in the explanatory message text that the user is hovering over.
| icon group | 
|---|
| icon.color : color | 
| icon.height : int | 
| icon.name : string | 
| icon.source : string | 
| icon.width : int | 
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.
| 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.
| type : enumeration | 
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.
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.