Tipos de diálogos
Um Kirigami.Dialog é um componente simples que você pode usar para complementar o conteúdo exibido na página de um aplicativo. Ele pode exibir conteúdo não interativo (somente texto) e conteúdo interativo (formulários, listviews e botões).
Eles podem ser descartados clicando ou tocando fora de sua área ou clicando no botão fechar no cabeçalho.
Ambientes isolados
Isso funciona imediatamente para todos os diálogos do Kirigami em ambientes isolados (como o Flatpak) por meio de Portais de Área de Trabalho XDG. Ao executar em um ambiente isolado, o backend do portal apropriado é usado automaticamente, permitindo acesso aprovado pelo usuário sem exigir manipulação manual do D-Bus.Diálogo
Um Kirigami.Dialog padrão é usado para criar diálogos personalizados. Eles são muito fáceis de estender:
import QtQuick
import QtQuick.Controls as Controls
import org.kde.kirigami as Kirigami
Kirigami.ApplicationWindow {
title: "Dialog"
width: 400
height: 400
pageStack.initialPage: Kirigami.Page {
id: page
actions: Kirigami.Action {
icon.name: "list-add"
text: "Show dialog"
onTriggered: dialog.open()
}
Kirigami.Dialog {
id: dialog
title: "A simple dialog"
padding: Kirigami.Units.largeSpacing
showCloseButton: false
standardButtons: Kirigami.Dialog.NoButton
flatFooterButtons: false
Controls.Label {
text: "A generic, easy to make dialog!"
}
customFooterActions: Kirigami.Action {
text: "Copy"
icon.name: "clipboard"
}
}
}
}
Conforme mostrado no tutorial de introdução sobre diálogos, também é possível capturar um standardButton(button) para atribuir algum comportamento a ele, como uma vinculação para habilitá-lo apenas sob certas condições.
Este tipo de diálogo é genérico e se aplica à maioria dos casos de uso, além de funcionar bem com conteúdo interativo complexo (especialmente visualizações):
import QtQuick
import QtQuick.Controls as Controls
import org.kde.kirigami as Kirigami
Kirigami.ApplicationWindow {
title: "Scrollable Dialog"
width: 600
height: 600
pageStack.initialPage: Kirigami.Page {
id: page
actions: Kirigami.Action {
icon.name: "list-add"
text: scrollableDialog.title
onTriggered: scrollableDialog.open()
}
Kirigami.Dialog {
id: scrollableDialog
title: i18n("Select Number")
ListView {
id: listView
// dicas para as dimensões do diálogo
implicitWidth: Kirigami.Units.gridUnit * 16
implicitHeight: Kirigami.Units.gridUnit * 16
model: 20
delegate: Controls.RadioDelegate {
topPadding: Kirigami.Units.smallSpacing * 2
bottomPadding: Kirigami.Units.smallSpacing * 2
implicitWidth: listView.width
text: modelData
}
}
}
}
}
Na maioria dos casos, no entanto, você provavelmente desejará usar um de seus tipos de diálogo derivados, Kirigami.PromptDialog ou Kirigami.MenuDialog.
PromptDialog
Um Kirigami.PromptDialog é essencialmente um diálogo com um rótulo integrado e um contentPadding padrão, usado para solicitar ao usuário algumas informações. Este tipo de diálogo deve ser usado apenas para solicitações simples de sim/não ou solicitações de entradas curtas do usuário.
Sua propriedade principal é Kirigami.Dialog.subtitle, à qual você adicionaria texto. Se qualquer componente QML for adicionado como filho do diálogo de prompt, esse componente substituirá o subtítulo.
import QtQuick
import QtQuick.Controls as Controls
import org.kde.kirigami as Kirigami
Kirigami.ApplicationWindow {
title: "PromptDialog"
width: 400
height: 400
pageStack.initialPage: Kirigami.Page {
id: page
actions: Kirigami.Action {
icon.name: "list-add"
text: promptDialog.title
onTriggered: promptDialog.open()
}
Kirigami.PromptDialog {
id: promptDialog
title: i18n("Delete file")
subtitle: i18n("Are you sure you'd like to delete this file?")
standardButtons: Kirigami.Dialog.Ok | Kirigami.Dialog.Cancel
onAccepted: console.info("File deleted")
}
}
}
import QtQuick
import QtQuick.Layouts
import QtQuick.Controls as Controls
import org.kde.kirigami as Kirigami
Kirigami.ApplicationWindow {
title: "PromptDialog with a textfield"
width: 600
height: 600
pageStack.initialPage: Kirigami.Page {
id: page
actions: Kirigami.Action {
icon.name: "list-add"
text: textPromptDialog.title
onTriggered: textPromptDialog.open()
}
Kirigami.PromptDialog {
id: textPromptDialog
title: "New Folder"
standardButtons: Kirigami.Dialog.NoButton
customFooterActions: [
Kirigami.Action {
text: "Create Folder"
icon.name: "dialog-ok"
onTriggered: {
showPassiveNotification("Created");
textPromptDialog.close();
}
},
Kirigami.Action {
text: "Cancel"
icon.name: "dialog-cancel"
onTriggered: {
textPromptDialog.close();
}
}
]
ColumnLayout {
Controls.TextField {
Layout.fillWidth: true
placeholderText: "Folder name…"
}
}
}
}
}
MenuDialog
O Kirigami.MenuDialog é uma caixa de diálogo especializada usada para listar uma seleção de opções clicáveis para o usuário usando sua propriedade actions.
import QtQuick
import QtQuick.Controls as Controls
import org.kde.kirigami as Kirigami
Kirigami.ApplicationWindow {
title: "MenuDialog"
width: 400
height: 600
pageStack.initialPage: Kirigami.Page {
id: page
actions: Kirigami.Action {
icon.name: "list-add"
text: menuDialog.title
onTriggered: menuDialog.open()
}
Kirigami.MenuDialog {
id: menuDialog
title: i18n("Track options")
showCloseButton: false
actions: [
Kirigami.Action {
icon.name: "media-playback-start"
text: i18n("Play")
tooltip: i18n("Start playback of the selected track")
},
Kirigami.Action {
enabled: false
icon.name: "document-open-folder"
text: i18n("Show in folder")
tooltip: i18n("Show the file for this song in the file manager")
},
Kirigami.Action {
icon.name: "documentinfo"
text: i18n("View details")
tooltip: i18n("Show track metadata")
},
Kirigami.Action {
icon.name: "list-add"
text: i18n("Play next")
tooltip: i18n("Add the track to the queue, right after the current track")
},
Kirigami.Action {
icon.name: "list-add"
text: i18n("Add to queue")
tooltip: i18n("Enqueue current track")
}
]
}
}
}