From 4a1b58114c1c7fb38b7e302aecfbf2dccf047381 Mon Sep 17 00:00:00 2001 From: yann300 Date: Fri, 27 Feb 2015 16:54:18 +0100 Subject: [PATCH] - Add validation for deployment values. --- mix/qml/DeploymentDialog.qml | 38 +++++++++++++++++++++++++++++++++--- mix/qml/ProjectModel.qml | 1 + 2 files changed, 36 insertions(+), 3 deletions(-) diff --git a/mix/qml/DeploymentDialog.qml b/mix/qml/DeploymentDialog.qml index 5dbdd356e..703246998 100644 --- a/mix/qml/DeploymentDialog.qml +++ b/mix/qml/DeploymentDialog.qml @@ -80,6 +80,20 @@ Window { }); } + function stopForInputError(inError) + { + errorDialog.text = ""; + if (inError.length > 0) + { + errorDialog.text = qsTr("The length of a string cannot exceed 32 characters.\nPlease verify the following value(s):\n\n") + for (var k in inError) + errorDialog.text += inError[k] + "\n"; + errorDialog.open(); + return true; + } + return false; + } + function pad(h) { // TODO move this to QHashType class @@ -250,6 +264,12 @@ Window { icon: StandardIcon.Warning } + MessageDialog { + id: errorDialog + standardButtons: StandardButton.Ok + icon: StandardIcon.Error + } + RowLayout { anchors.bottom: parent.bottom @@ -259,7 +279,15 @@ Window { text: qsTr("Deploy contract / Package resources"); tooltip: qsTr("Deploy contract and package resources files.") onClicked: { - deployWarningDialog.open(); + var inError = []; + var ethUrl = ProjectModelCode.formatAppUrl(applicationUrlEth.text); + for (var k in ethUrl) + { + if (ethUrl[k].length > 32) + inError.push(qsTr("Member too long: " + ethUrl[k]) + "\n"); + } + if (!stopForInputError(inError)) + deployWarningDialog.open(); } } @@ -287,10 +315,14 @@ Window { if (applicationUrlHttp.text === "" || deploymentDialog.packageHash === "") { deployDialog.title = text; - deployDialog.text = qsTr("Please provide the link where the resources are stored and ensure the package is aleary built using the deployment step. ") + deployDialog.text = qsTr("Please provide the link where the resources are stored and ensure the package is aleary built using the deployment step.") deployDialog.open(); + return; } - else + var inError = []; + if (applicationUrlHttp.text.length > 32) + inError.push(qsTr(applicationUrlHttp.text)); + if (!stopForInputError(inError)) ProjectModelCode.registerToUrlHint(); } } diff --git a/mix/qml/ProjectModel.qml b/mix/qml/ProjectModel.qml index 7e4e8cb49..d3b4070aa 100644 --- a/mix/qml/ProjectModel.qml +++ b/mix/qml/ProjectModel.qml @@ -59,6 +59,7 @@ Item { function addExistingFiles(paths) { ProjectModelCode.doAddExistingFiles(paths); } function deployProject() { ProjectModelCode.deployProject(false); } function registerToUrlHint() { ProjectModelCode.registerToUrlHint(); } + function formatAppUrl() { ProjectModelCode.formatAppUrl(url); } Connections { target: appContext