pragma ComponentBehavior: Bound import QtQuick import QtCore import QtQuick.Controls as QQC2 import QtQuick.Layouts import org.kde.kirigami as Kirigami import org.kde.kirigamiaddons.formcard as FormCard import org.deprecated.kodereviewer 1.0 Kirigami.ScrollablePage { id: root property var pullRequest property NetworkManager connection Kirigami.Theme.colorSet: Kirigami.Theme.View Kirigami.Theme.inherit: false property string currentView: "info" actions: [ Kirigami.Action { id: reviewChangesAction text: "Review changes" icon.name: "preview-symbolic" enabled: !!root.pullRequest onTriggered: reviewChangesDialog.open() }, Kirigami.Action { id: openFiles text: "Files" icon.name: "file-catalog-symbolic" enabled: !!root.pullRequest onTriggered: { if(contextDrawer.opened) { contextDrawer.close() } else { contextDrawer.open() } } } ] ReviewDialog { id: reviewChangesDialog onAccepted: { root.connection.createReview( root.pullRequest.number, root.pullRequest.last_commit, reviewBodyText, event ) clearForm() } } Loader { id: commentModelLoader active: !!root.pullRequest sourceComponent: CommentModel { id: commentModel pullRequest: root.pullRequest onPullRequestChanged: root.connection.getPullRequestComments(root.pullRequest.number) } } Loader { id: fileModelLoader active: !!root.pullRequest sourceComponent: FileModel { id: fileModel pullRequest: root.pullRequest onPullRequestChanged: root.connection.getFiles(root.pullRequest.number) } } Kirigami.PlaceholderMessage { visible: !root.pullRequest anchors.centerIn: parent icon.name: "org.deprecated.kodereviewer" text: "Select a pull request" } ColumnLayout { id: mainLayout anchors.fill: parent PullRequestDescription { visible: !!root.pullRequest && root.currentView == "info" pullRequest: root.pullRequest Layout.fillWidth: true Layout.fillHeight: true //anchors.fill: parent } Kirigami.CardsListView { visible: !!root.pullRequest && root.currentView == "comments" //anchors.fill: parent Layout.fillWidth: true Layout.fillHeight: true model: commentModelLoader.item delegate: CommentDelegate {} footerPositioning: ListView.OverlayFooter } Editor { visible: !!root.pullRequest && root.currentView == "files" Layout.fillWidth: true Layout.fillHeight: true id: editor text: "" file: "" //fileModel: fileModelLoader.item } } Connections { target: contextDrawer function onFileSelected(filename, text) { print("ASDF") editor.filename = filename + '.diff' editor.text = text } } footer: Kirigami.NavigationTabBar { actions: [ Kirigami.Action { icon.name: "info" text: i18n("Info") onTriggered: root.currentView = "info" }, Kirigami.Action { icon.name: "comment-symbolic" text: i18n("Comments") onTriggered: root.currentView = "comments" }, Kirigami.Action { icon.name: "file-catalog-symbolic" text: i18n("Files") onTriggered: root.currentView = "files" } ] } }