/* Copyright (C) 2015 Michael Bohlender, This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ import QtQuick 2.4 import QtQuick.Controls 1.3 import QtQuick.Layouts 1.1 import org.kde.kirigami 1.0 as Kirigami import org.kube.framework.actions 1.0 as KubeAction import org.kube.framework.settings 1.0 as KubeSettings import org.kube.framework.domain 1.0 as KubeFramework import org.kube.framework.theme 1.0 import org.kube.components 1.0 as KubeComponents ApplicationWindow { id: app //FIXME remove fixed pixel hight //for now just convinience during testing height: 1080 * 0.7 width: 1920 * 0.7 visible: true //BEGIN Actions KubeAction.Context { id: maillistcontext property variant mail property bool isDraft mail: mailListView.currentMail isDraft: mailListView.isDraft } KubeAction.Context { id: folderListContext property variant folder folder: folderListView.currentFolder } KubeAction.Action { id: replyAction actionId: "org.kde.kube.actions.reply" context: maillistcontext } KubeAction.Action { id: editAction actionId: "org.kde.kube.actions.edit" context: maillistcontext } KubeAction.Action { id: markAsReadAction actionId: "org.kde.kube.actions.mark-as-read" context: maillistcontext } KubeAction.Action { id: deleteAction actionId: "org.kde.kube.actions.move-to-trash" context: maillistcontext } KubeAction.Action { id: syncAction actionId: "org.kde.kube.actions.synchronize" context: folderListContext } //END Actions //BEGIN Main content SplitView { anchors { top: toolbar.bottom left: app.left } height: app.height - toolbar.height width: app.width KubeComponents.FolderListView { id: folderListView width: Kirigami.Units.gridUnit * 10 Layout.maximumWidth: app.width * 0.25 Layout.minimumWidth: Kirigami.Units.gridUnit * 5 focus: true } KubeComponents.MailListView { id: mailListView parentFolder: folderListView.currentFolder width: Kirigami.Units.gridUnit * 20 Layout.maximumWidth: app.width * 0.4 Layout.minimumWidth: Kirigami.Units.gridUnit * 10 focus: true } KubeComponents.SingleMailView { id: mailView mail: mailListView.currentMail Layout.fillWidth: true } } //END Main content //BEGIN Toolbar ToolBar { id: toolbar anchors { top: app.top } width: app.width height: Kirigami.Units.iconSizes.medium + Kirigami.Units.smallSpacing * 2 Row { width: parent.width height: parent.height spacing: 1 //to account for the SplitView borders //BEGIN Folderlist section RowLayout { height: parent.height width: folderListView.width - 5 //to adjust for the toolbar spacing KubeComponents.AccountSwitcher { } } //END Folderlist section //BEGIN MailList section Item { height: parent.height width: mailListView.width Row { anchors.centerIn: parent spacing: Kirigami.Units.smallSpacing ToolButton { iconName: "mail-mark-unread" text: "Mark As Read" enabled: markAsReadAction.ready tooltip: "mark mail as read" onClicked: { markAsReadAction.execute() } } ToolButton { iconName: "mail-mark-important" text: "Mark Important" enabled: false tooltip: "mark mail as important" onClicked: { } } ToolButton { iconName: "edit-delete" text: "Delete Mail" enabled: deleteAction.ready tooltip: "delete email" onClicked: { deleteAction.execute() } } } } //END MailList section //BEGIN MailView sections RowLayout{ height: parent.height width: mailView.width Component { id: composerComponent KubeComponents.FocusComposer { id: composer anchors.fill: parent } } KubeAction.ActionHandler { actionId: "org.kde.kube.actions.reply" function isReady(context) { return context.mail ? true : false; } function handler(context) { var component = composerComponent.createObject(app) component.loadMessage(context.mail, false) } } KubeAction.ActionHandler { actionId: "org.kde.kube.actions.edit" function isReady(context) { return context.mail && context.isDraft; } function handler(context) { var component= composerComponent.createObject(app, {"draftMessage": context.mail}) component.loadMessage(context.mail, true) } } Button { id: newMailButton //iconName: "mail-message-new" text: "New Email" tooltip: "compose new email" onClicked: { composerComponent.createObject(app) } } KubeComponents.Outbox { } /* ToolButton { iconName: "mail-message-reply" text: "Reply" enabled: replyAction.ready onClicked: { replyAction.execute() } } * ToolButton { * iconName: "mail-message-edit" * text: "Edit" * enabled: editAction.ready * onClicked: { * editAction.execute() } } */ Item { Layout.fillWidth: true } TextField { id: searchBar Layout.minimumWidth: Kirigami.Units.gridUnit * 15 height: toolbar.height placeholderText: "Search..." } Item { width: Kirigami.Units.smallSpacing } } //END MailView section } } //END ToolBar }