import QtQuick 2.2 import QtQuick.Controls 1.1 import QtQuick.Layouts 1.0 import QtQuick.Controls.Styles 1.1 import CodeEditorExtensionManager 1.0 import Qt.labs.settings 1.0 import org.ethereum.qml.QEther 1.0 import "js/QEtherHelper.js" as QEtherHelper import "js/TransactionHelper.js" as TransactionHelper Rectangle { objectName: "mainContent" signal keyPressed(variant event) focus: true Keys.enabled: true Keys.onPressed: { root.keyPressed(event.key); } anchors.fill: parent id: root property alias rightViewVisible : rightView.visible property alias webViewVisible : webPreview.visible property alias projectViewVisible : projectList.visible property alias runOnProjectLoad : mainSettings.runOnProjectLoad property bool webViewHorizontal : codeWebSplitter.orientation === Qt.Vertical //vertical splitter positions elements vertically, splits screen horizontally property bool firstCompile: true Connections { target: codeModel onCompilationComplete: { if (firstCompile) { firstCompile = false; if (codeModel.code.successful && runOnProjectLoad) startQuickDebugging(); } } } function startQuickDebugging() { ensureRightView(); projectModel.stateListModel.debugDefaultState(); } function toggleRightView() { rightView.visible = !rightView.visible; } function ensureRightView() { rightView.visible = true; } function rightViewIsVisible() { return rightView.visible; } function hideRightView() { rightView.visible = false; } function toggleWebPreview() { webPreview.visible = !webPreview.visible; } function toggleProjectView() { projectList.visible = !projectList.visible; } function toggleWebPreviewOrientation() { codeWebSplitter.orientation = (codeWebSplitter.orientation === Qt.Vertical ? Qt.Horizontal : Qt.Vertical); } CodeEditorExtensionManager { headerView: headerPaneTabs; rightView: rightPaneTabs; } Settings { id: mainSettings property alias codeWebOrientation: codeWebSplitter.orientation property alias webWidth: webPreview.width property alias webHeight: webPreview.height property alias showProjectView: projectList.visible property bool runOnProjectLoad: false } ColumnLayout { anchors.fill: parent spacing: 0 Rectangle { width: parent.width height: 50 Layout.row: 0 Layout.fillWidth: true Layout.preferredHeight: 50 id: headerView Rectangle { gradient: Gradient { GradientStop { position: 0.0; color: "#f1f1f1" } GradientStop { position: 1.0; color: "#d9d7da" } } id: headerPaneContainer anchors.fill: parent TabView { id: headerPaneTabs tabsVisible: false antialiasing: true anchors.fill: parent style: TabViewStyle { frameOverlap: 1 tab: Rectangle {} frame: Rectangle { color: "transparent" } } } } } Rectangle { Layout.fillWidth: true Layout.preferredHeight: root.height - headerView.height; Settings { id: splitSettings property alias projectWidth: projectList.width property alias contentViewWidth: contentView.width property alias rightViewWidth: rightView.width } SplitView { anchors.fill: parent handleDelegate: Rectangle { width: 4 height: 4 color: "#cccccc" } orientation: Qt.Horizontal ProjectList { id: projectList width: 200 Layout.minimumWidth: 180 Layout.fillHeight: true } Rectangle { id: contentView Layout.fillHeight: true Layout.fillWidth: true SplitView { handleDelegate: Rectangle { width: 4 height: 4 color: "#cccccc" } id: codeWebSplitter anchors.fill: parent orientation: Qt.Vertical CodeEditorView { height: parent.height * 0.6 anchors.top: parent.top Layout.fillWidth: true Layout.fillHeight: true } WebPreview { id: webPreview height: parent.height * 0.4 Layout.fillWidth: codeWebSplitter.orientation === Qt.Vertical Layout.fillHeight: codeWebSplitter.orientation === Qt.Horizontal Layout.minimumHeight: 200 Layout.minimumWidth: 200 } } } Rectangle { visible: false; id: rightView; Layout.fillHeight: true Keys.onEscapePressed: visible = false height: parent.height; width: 515 Layout.minimumWidth: 515 anchors.right: parent.right Rectangle { anchors.fill: parent; id: rightPaneView TabView { id: rightPaneTabs tabsVisible: true antialiasing: true anchors.fill: parent style: TabViewStyle { frameOverlap: 1 tabBar: Rectangle { color: "#ededed" id: background } tab: Rectangle { color: "#ededed" implicitWidth: 80 implicitHeight: 20 radius: 2 Text { anchors.centerIn: parent text: styleData.title color: styleData.selected ? "#7da4cd" : "#202020" } } frame: Rectangle { } } } } } } } } }