Browse Source

change ProjectModel to be a context property instead of a singleton to

work around issue #809
cl-refactor
arkpar 10 years ago
parent
commit
aeff8b3a4d
  1. 10
      mix/AppContext.cpp
  2. 3
      mix/qml/CodeEditorView.qml
  3. 17
      mix/qml/ProjectList.qml
  4. 2
      mix/qml/ProjectModel.qml
  5. 5
      mix/qml/StateList.qml
  6. 29
      mix/qml/main.qml

10
mix/AppContext.cpp

@ -22,16 +22,17 @@
* - KeyEventManager * - KeyEventManager
*/ */
#include <stdexcept>
#include <QDebug> #include <QDebug>
#include <QMessageBox> #include <QMessageBox>
#include <QQmlComponent> #include <QQmlComponent>
#include <QQmlContext> #include <QQmlContext>
#include <QQmlApplicationEngine> #include <QQmlApplicationEngine>
#include <libwebthree/WebThree.h>
#include "CodeModel.h" #include "CodeModel.h"
#include "FileIo.h" #include "FileIo.h"
#include "ClientModel.h" #include "ClientModel.h"
#include "AppContext.h" #include "AppContext.h"
#include <libwebthree/WebThree.h>
using namespace dev; using namespace dev;
using namespace dev::eth; using namespace dev::eth;
@ -48,7 +49,12 @@ AppContext::AppContext(QQmlApplicationEngine* _engine)
m_fileIo.reset(new FileIo()); m_fileIo.reset(new FileIo());
m_applicationEngine->rootContext()->setContextProperty("appContext", this); m_applicationEngine->rootContext()->setContextProperty("appContext", this);
qmlRegisterType<FileIo>("org.ethereum.qml", 1, 0, "FileIo"); qmlRegisterType<FileIo>("org.ethereum.qml", 1, 0, "FileIo");
qmlRegisterSingletonType(QUrl("qrc:/qml/ProjectModel.qml"), "org.ethereum.qml.ProjectModel", 1, 0, "ProjectModel"); QQmlComponent projectModelComponent(m_applicationEngine, QUrl("qrc:/qml/ProjectModel.qml"));
QObject* projectModel = projectModelComponent.create();
if (projectModelComponent.isError())
throw std::runtime_error("Error loading ProjectModel: " + projectModelComponent.errorString().toStdString());
QQmlEngine::setObjectOwnership(projectModel, QQmlEngine::JavaScriptOwnership);
m_applicationEngine->rootContext()->setContextProperty("projectModel", projectModel);
m_applicationEngine->rootContext()->setContextProperty("codeModel", m_codeModel.get()); m_applicationEngine->rootContext()->setContextProperty("codeModel", m_codeModel.get());
m_applicationEngine->rootContext()->setContextProperty("fileIo", m_fileIo.get()); m_applicationEngine->rootContext()->setContextProperty("fileIo", m_fileIo.get());

3
mix/qml/CodeEditorView.qml

@ -2,7 +2,6 @@ import QtQuick 2.0
import QtQuick.Window 2.0 import QtQuick.Window 2.0
import QtQuick.Layouts 1.0 import QtQuick.Layouts 1.0
import QtQuick.Controls 1.0 import QtQuick.Controls 1.0
import org.ethereum.qml.ProjectModel 1.0
Item { Item {
@ -40,7 +39,7 @@ Item {
} }
Connections { Connections {
target: ProjectModel target: projectModel
onDocumentOpened: { onDocumentOpened: {
openDocument(document); openDocument(document);
} }

17
mix/qml/ProjectList.qml

@ -2,7 +2,6 @@ import QtQuick 2.0
import QtQuick.Window 2.0 import QtQuick.Window 2.0
import QtQuick.Layouts 1.0 import QtQuick.Layouts 1.0
import QtQuick.Controls 1.0 import QtQuick.Controls 1.0
import org.ethereum.qml.ProjectModel 1.0
Item { Item {
property bool renameMode: false; property bool renameMode: false;
@ -11,16 +10,16 @@ Item {
Text { Text {
Layout.fillWidth: true Layout.fillWidth: true
color: "blue" color: "blue"
text: ProjectModel.projectData ? ProjectModel.projectData.title : "" text: projectModel.projectData ? projectModel.projectData.title : ""
horizontalAlignment: Text.AlignHCenter horizontalAlignment: Text.AlignHCenter
visible: !ProjectModel.isEmpty; visible: !projectModel.isEmpty;
} }
ListView { ListView {
id: projectList id: projectList
Layout.fillWidth: true Layout.fillWidth: true
Layout.fillHeight: true Layout.fillHeight: true
model: ProjectModel.listModel model: projectModel.listModel
delegate: renderDelegate delegate: renderDelegate
highlight: Rectangle { highlight: Rectangle {
@ -31,8 +30,8 @@ Item {
clip: true clip: true
onCurrentIndexChanged: { onCurrentIndexChanged: {
if (currentIndex >= 0 && currentIndex < ProjectModel.listModel.count) if (currentIndex >= 0 && currentIndex < projectModel.listModel.count)
ProjectModel.openDocument(ProjectModel.listModel.get(currentIndex).documentId); projectModel.openDocument(projectModel.listModel.get(currentIndex).documentId);
} }
} }
Menu { Menu {
@ -46,7 +45,7 @@ Item {
MenuItem { MenuItem {
text: qsTr("Delete") text: qsTr("Delete")
onTriggered: { onTriggered: {
ProjectModel.removeDocument(projectList.model.get(projectList.currentIndex).documentId); projectModel.removeDocument(projectList.model.get(projectList.currentIndex).documentId);
} }
} }
} }
@ -103,7 +102,7 @@ Item {
function close(accept) { function close(accept) {
renameMode = false; renameMode = false;
if (accept) if (accept)
ProjectModel.renameDocument(projectList.model.get(projectList.currentIndex).documentId, textInput.text); projectModel.renameDocument(projectList.model.get(projectList.currentIndex).documentId, textInput.text);
} }
} }
MouseArea { MouseArea {
@ -119,7 +118,7 @@ Item {
} }
} }
Connections { Connections {
target: ProjectModel target: projectModel
onProjectLoaded: { onProjectLoaded: {
projectList.currentIndex = 0; projectList.currentIndex = 0;
} }

2
mix/qml/ProjectModel.qml

@ -1,5 +1,3 @@
pragma Singleton
import QtQuick 2.0 import QtQuick 2.0
import QtQuick.Window 2.0 import QtQuick.Window 2.0
import QtQuick.Layouts 1.0 import QtQuick.Layouts 1.0

5
mix/qml/StateList.qml

@ -3,7 +3,6 @@ import QtQuick.Controls.Styles 1.1
import QtQuick.Controls 1.1 import QtQuick.Controls 1.1
import QtQuick.Dialogs 1.1 import QtQuick.Dialogs 1.1
import QtQuick.Layouts 1.1 import QtQuick.Layouts 1.1
import org.ethereum.qml.ProjectModel 1.0
Rectangle { Rectangle {
color: "#ededed" color: "#ededed"
@ -16,7 +15,7 @@ Rectangle {
property var stateList: [] property var stateList: []
Connections { Connections {
target: ProjectModel target: projectModel
onProjectClosed: { onProjectClosed: {
stateListModel.clear(); stateListModel.clear();
} }
@ -91,7 +90,7 @@ Rectangle {
} }
function save() { function save() {
ProjectModel.saveProject(); projectModel.saveProject();
} }
} }

29
mix/qml/main.qml

@ -5,7 +5,6 @@ import QtQuick.Dialogs 1.1
import QtQuick.Layouts 1.1 import QtQuick.Layouts 1.1
import QtQuick.Window 2.1 import QtQuick.Window 2.1
import CodeEditorExtensionManager 1.0 import CodeEditorExtensionManager 1.0
import org.ethereum.qml.ProjectModel 1.0
ApplicationWindow { ApplicationWindow {
id: mainApplication id: mainApplication
@ -101,7 +100,7 @@ ApplicationWindow {
text: qsTr("&New project") text: qsTr("&New project")
shortcut: "Ctrl+N" shortcut: "Ctrl+N"
enabled: true; enabled: true;
onTriggered: ProjectModel.createProject(); onTriggered: projectModel.createProject();
} }
Action { Action {
@ -109,54 +108,54 @@ ApplicationWindow {
text: qsTr("&Open project") text: qsTr("&Open project")
shortcut: "Ctrl+O" shortcut: "Ctrl+O"
enabled: true; enabled: true;
onTriggered: ProjectModel.browseProject(); onTriggered: projectModel.browseProject();
} }
Action { Action {
id: addNewJsFileAction id: addNewJsFileAction
text: qsTr("New JavaScript file") text: qsTr("New JavaScript file")
shortcut: "Ctrl+Alt+J" shortcut: "Ctrl+Alt+J"
enabled: !ProjectModel.isEmpty enabled: !projectModel.isEmpty
onTriggered: ProjectModel.newJsFile(); onTriggered: projectModel.newJsFile();
} }
Action { Action {
id: addNewHtmlFileAction id: addNewHtmlFileAction
text: qsTr("New HTML file") text: qsTr("New HTML file")
shortcut: "Ctrl+Alt+H" shortcut: "Ctrl+Alt+H"
enabled: !ProjectModel.isEmpty enabled: !projectModel.isEmpty
onTriggered: ProjectModel.newHtmlFile(); onTriggered: projectModel.newHtmlFile();
} }
Action { Action {
id: addNewContractAction id: addNewContractAction
text: qsTr("New contract") text: qsTr("New contract")
shortcut: "Ctrl+Alt+C" shortcut: "Ctrl+Alt+C"
enabled: !ProjectModel.isEmpty enabled: !projectModel.isEmpty
onTriggered: ProjectModel.newContract(); onTriggered: projectModel.newContract();
} }
Action { Action {
id: addExistingFileAction id: addExistingFileAction
text: qsTr("Add existing file") text: qsTr("Add existing file")
shortcut: "Ctrl+Alt+A" shortcut: "Ctrl+Alt+A"
enabled: !ProjectModel.isEmpty enabled: !projectModel.isEmpty
onTriggered: ProjectModel.addExistingFile(); onTriggered: projectModel.addExistingFile();
} }
Action { Action {
id: saveAllFilesAction id: saveAllFilesAction
text: qsTr("Save all") text: qsTr("Save all")
shortcut: "Ctrl+S" shortcut: "Ctrl+S"
enabled: !ProjectModel.isEmpty enabled: !projectModel.isEmpty
onTriggered: ProjectModel.saveAll(); onTriggered: projectModel.saveAll();
} }
Action { Action {
id: closeProjectAction id: closeProjectAction
text: qsTr("Close project") text: qsTr("Close project")
shortcut: "Ctrl+W" shortcut: "Ctrl+W"
enabled: !ProjectModel.isEmpty enabled: !projectModel.isEmpty
onTriggered: ProjectModel.closeProject(); onTriggered: projectModel.closeProject();
} }
} }

Loading…
Cancel
Save