import QtQuick 2.2 import QtQuick.Controls 1.1 import QtQuick.Layouts 1.0 import QtQuick.Controls.Styles 1.1 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 import "." 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: scenarioExe.visible property alias webViewVisible: webPreview.visible property alias webView: webPreview property alias projectViewVisible: projectList.visible property alias projectNavigator: projectList property alias runOnProjectLoad: mainSettings.runOnProjectLoad property alias rightPane: scenarioExe property alias debuggerPanel: debugPanel property alias codeEditor: codeEditor property bool webViewHorizontal: codeWebSplitter.orientation === Qt.Vertical //vertical splitter positions elements vertically, splits screen horizontally property bool firstCompile: true property int scenarioMinWidth: 620 Connections { target: codeModel onCompilationComplete: { if (firstCompile) { firstCompile = false; if (runOnProjectLoad) startQuickDebugging(); } } } Connections { target: debugPanel onDebugExecuteLocation: { codeEditor.highlightExecution(documentId, location); } } Connections { target: codeEditor onBreakpointsChanged: { debugPanel.setBreakpoints(codeEditor.getBreakpoints()); } } function startQuickDebugging() { ensureRightView(); projectModel.stateListModel.debugDefaultState(); } function toggleRightView() { scenarioExe.visible = !scenarioExe.visible; } function ensureRightView() { scenarioExe.visible = true; } function rightViewIsVisible() { return scenarioExe.visible; } function hideRightView() { scenarioExe.visible = lfalse; } function toggleWebPreview() { webPreview.visible = !webPreview.visible; } function toggleProjectView() { projectList.visible = !projectList.visible; } function toggleWebPreviewOrientation() { codeWebSplitter.orientation = (codeWebSplitter.orientation === Qt.Vertical ? Qt.Horizontal : Qt.Vertical); } //TODO: move this to debugger.js after refactoring, introduce events function toggleBreakpoint() { codeEditor.toggleBreakpoint(); } function displayCompilationErrorIfAny() { scenarioExe.visible = true; scenarioExe.displayCompilationErrorIfAny(); } 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: true property int scenarioMinWidth: scenarioMinWidth } ColumnLayout { id: mainColumn 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 StatusPane { anchors.fill: parent webPreview: webPreview } } } Rectangle { Layout.fillWidth: true height: 1 color: "#8c8c8c" } 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: scenarioExe.width } Splitter { anchors.fill: parent orientation: Qt.Horizontal ProjectList { id: projectList width: 350 Layout.minimumWidth: 250 Layout.fillHeight: true Connections { target: projectModel.codeEditor } } Rectangle { id: contentView Layout.fillHeight: true Layout.fillWidth: true Splitter { id: codeWebSplitter anchors.fill: parent orientation: Qt.Vertical CodeEditorView { id: codeEditor 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 } } } ScenarioExecution { id: scenarioExe; visible: false; Layout.fillHeight: true Keys.onEscapePressed: visible = false Layout.minimumWidth: scenarioMinWidth anchors.right: parent.right } Debugger { id: debugPanel visible: false Layout.fillHeight: true Keys.onEscapePressed: visible = false Layout.minimumWidth: scenarioMinWidth anchors.right: parent.right } Connections { target: clientModel onDebugDataReady: { scenarioExe.visible = false debugPanel.visible = true debugPanel.width = scenarioExe.width if (scenarioExe.bc.debugTrRequested) debugPanel.setTr(scenarioExe.bc.model.blocks[scenarioExe.bc.debugTrRequested[0]].transactions[scenarioExe.bc.debugTrRequested[1]]) } } Connections { target: debugPanel onPanelClosed: { debugPanel.visible = false scenarioExe.visible = true scenarioExe.width = debugPanel.width } } } } } }