204 lines
5.2 KiB
204 lines
5.2 KiB
import QtQuick 2.2
|
|
import QtQuick.Controls 1.1
|
|
import QtQuick.Layouts 1.0
|
|
import QtQuick.Controls.Styles 1.1
|
|
import QtWebEngine 1.0
|
|
import QtWebEngine.experimental 1.0
|
|
import org.ethereum.qml.Clipboard 1.0
|
|
import "js/ErrorLocationFormater.js" as ErrorLocationFormater
|
|
|
|
Item {
|
|
signal breakpointsChanged
|
|
signal editorTextChanged
|
|
signal loadComplete
|
|
property bool isClean: true
|
|
property string currentText: ""
|
|
property string currentMode: ""
|
|
property bool initialized: false
|
|
property bool unloaded: false
|
|
property var currentBreakpoints: []
|
|
property string sourceName
|
|
property var document
|
|
property int fontSize: 0
|
|
|
|
function setText(text, mode) {
|
|
currentText = text;
|
|
if (mode !== undefined)
|
|
currentMode = mode;
|
|
if (initialized && editorBrowser) {
|
|
editorBrowser.runJavaScript("setTextBase64(\"" + Qt.btoa(text) + "\")");
|
|
editorBrowser.runJavaScript("setMode(\"" + currentMode + "\")");
|
|
}
|
|
setFocus();
|
|
}
|
|
|
|
function setFocus() {
|
|
if (editorBrowser)
|
|
editorBrowser.forceActiveFocus();
|
|
}
|
|
|
|
function getText() {
|
|
return currentText;
|
|
}
|
|
|
|
function syncClipboard() {
|
|
if (Qt.platform.os == "osx" && editorBrowser) {
|
|
var text = clipboard.text;
|
|
editorBrowser.runJavaScript("setClipboardBase64(\"" + Qt.btoa(text) + "\")");
|
|
}
|
|
}
|
|
|
|
function highlightExecution(location) {
|
|
if (initialized && editorBrowser)
|
|
editorBrowser.runJavaScript("highlightExecution(" + location.start + "," + location.end + ")");
|
|
}
|
|
|
|
function showWarning(content) {
|
|
if (initialized && editorBrowser)
|
|
editorBrowser.runJavaScript("showWarning('" + content + "')");
|
|
}
|
|
|
|
function getBreakpoints() {
|
|
return currentBreakpoints;
|
|
}
|
|
|
|
function toggleBreakpoint() {
|
|
if (initialized && editorBrowser)
|
|
editorBrowser.runJavaScript("toggleBreakpoint()");
|
|
}
|
|
|
|
function changeGeneration() {
|
|
if (initialized && editorBrowser)
|
|
editorBrowser.runJavaScript("changeGeneration()", function(result) {});
|
|
}
|
|
|
|
function goToCompilationError() {
|
|
if (initialized && editorBrowser)
|
|
editorBrowser.runJavaScript("goToCompilationError()", function(result) {});
|
|
}
|
|
|
|
function setFontSize(size) {
|
|
fontSize = size;
|
|
if (initialized && editorBrowser)
|
|
editorBrowser.runJavaScript("setFontSize(" + size + ")", function(result) {});
|
|
}
|
|
|
|
function setGasCosts(gasCosts) {
|
|
if (initialized && editorBrowser)
|
|
editorBrowser.runJavaScript("setGasCosts('" + JSON.stringify(gasCosts) + "')", function(result) {});
|
|
}
|
|
|
|
function displayGasEstimation(show) {
|
|
if (initialized && editorBrowser)
|
|
editorBrowser.runJavaScript("displayGasEstimation('" + show + "')", function(result) {});
|
|
}
|
|
|
|
Clipboard
|
|
{
|
|
id: clipboard
|
|
}
|
|
|
|
Connections {
|
|
target: clipboard
|
|
onClipboardChanged: syncClipboard()
|
|
}
|
|
|
|
anchors.top: parent.top
|
|
id: codeEditorView
|
|
anchors.fill: parent
|
|
WebEngineView {
|
|
id: editorBrowser
|
|
url: "qrc:///qml/html/codeeditor.html"
|
|
anchors.fill: parent
|
|
experimental.settings.javascriptCanAccessClipboard: true
|
|
onJavaScriptConsoleMessage: {
|
|
console.log("editor: " + sourceID + ":" + lineNumber + ":" + message);
|
|
}
|
|
|
|
Component.onDestruction:
|
|
{
|
|
codeModel.onCompilationComplete.disconnect(compilationComplete);
|
|
codeModel.onCompilationError.disconnect(compilationError);
|
|
}
|
|
|
|
onLoadingChanged:
|
|
{
|
|
if (!loading && editorBrowser) {
|
|
initialized = true;
|
|
setFontSize(fontSize);
|
|
setText(currentText, currentMode);
|
|
runJavaScript("getTextChanged()", function(result) { });
|
|
pollTimer.running = true;
|
|
syncClipboard();
|
|
if (currentMode === "solidity")
|
|
{
|
|
codeModel.onCompilationComplete.connect(compilationComplete);
|
|
codeModel.onCompilationError.connect(compilationError);
|
|
}
|
|
parent.changeGeneration();
|
|
loadComplete();
|
|
}
|
|
}
|
|
|
|
|
|
function compilationComplete()
|
|
{
|
|
if (editorBrowser)
|
|
{
|
|
editorBrowser.runJavaScript("compilationComplete()", function(result) { });
|
|
parent.displayGasEstimation(gasEstimationAction.checked);
|
|
}
|
|
|
|
|
|
}
|
|
|
|
function compilationError(error, firstLocation, secondLocations)
|
|
{
|
|
if (!editorBrowser || !error)
|
|
return;
|
|
var detail = error.split('\n')[0];
|
|
var reg = detail.match(/:\d+:\d+:/g);
|
|
if (reg !== null)
|
|
detail = detail.replace(reg[0], "");
|
|
displayErrorAnnotations(detail, firstLocation, secondLocations);
|
|
}
|
|
|
|
function displayErrorAnnotations(detail, location, secondaryErrors)
|
|
{
|
|
editorBrowser.runJavaScript("compilationError('" + sourceName + "', '" + JSON.stringify(location) + "', '" + detail + "', '" + JSON.stringify(secondaryErrors) + "')", function(result){});
|
|
}
|
|
|
|
Timer
|
|
{
|
|
id: pollTimer
|
|
interval: 30
|
|
running: false
|
|
repeat: true
|
|
onTriggered: {
|
|
if (!editorBrowser)
|
|
return;
|
|
editorBrowser.runJavaScript("getTextChanged()", function(result) {
|
|
if (result === true && editorBrowser) {
|
|
editorBrowser.runJavaScript("getText()" , function(textValue) {
|
|
currentText = textValue;
|
|
editorTextChanged();
|
|
});
|
|
}
|
|
});
|
|
editorBrowser.runJavaScript("getBreakpointsChanged()", function(result) {
|
|
if (result === true && editorBrowser) {
|
|
editorBrowser.runJavaScript("getBreakpoints()" , function(bp) {
|
|
if (currentBreakpoints !== bp) {
|
|
currentBreakpoints = bp;
|
|
breakpointsChanged();
|
|
}
|
|
});
|
|
}
|
|
});
|
|
editorBrowser.runJavaScript("isClean()", function(result) {
|
|
isClean = result;
|
|
});
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|