diff --git a/editor/EvaluationRoute.go b/editor/EvaluationRoute.go index 4d191143..c7676709 100644 --- a/editor/EvaluationRoute.go +++ b/editor/EvaluationRoute.go @@ -19,8 +19,8 @@ type JSONData struct { } type EvaluateRequest struct { - GrlText string `json:"grlText"` - Input []*JSONData `json:"jsonInput"` + GrlText string `json:"grlText"` + Input []string `json:"jsonInput"` } func InitializeEvaluationRoute(router *mux.HyperMux) { @@ -41,14 +41,22 @@ func InitializeEvaluationRoute(router *mux.HyperMux) { dataContext := ast.NewDataContext() - for _, jd := range evReq.Input { - jsonByte, err := base64.StdEncoding.DecodeString(jd.JSONData) + for _, input := range evReq.Input { + jsonByte, err := base64.StdEncoding.DecodeString(input) if err != nil { w.WriteHeader(http.StatusBadRequest) - _, _ = w.Write([]byte(fmt.Sprintf("json data named %s should be sent using base64. got %v", jd.Name, err))) + _, _ = w.Write([]byte(fmt.Sprintf("jsonInput data should be sent using base64.", err))) return } - err = dataContext.AddJSON(jd.Name, jsonByte) + var jd JSONData + err = json.Unmarshal(jsonByte, &jd) + if err != nil { + w.WriteHeader(http.StatusBadRequest) + _, _ = w.Write([]byte(fmt.Sprintf("unmarshal json data named got err %v", err))) + return + } + + err = dataContext.AddJSON(jd.Name, []byte(jd.JSONData)) if err != nil { w.WriteHeader(http.StatusBadRequest) _, _ = w.Write([]byte(fmt.Sprintf("invalid JSON data named %s when add json to context got %v", jd.Name, err))) @@ -72,7 +80,6 @@ func InitializeEvaluationRoute(router *mux.HyperMux) { _, _ = w.Write([]byte(fmt.Sprintf("invalid GRL : %s", err.Error()))) return } - eng1 := &engine.GruleEngine{MaxCycle: 5} kb := lib.NewKnowledgeBaseInstance("Evaluator", "0.0.1") err = eng1.Execute(dataContext, kb) @@ -84,7 +91,7 @@ func InitializeEvaluationRoute(router *mux.HyperMux) { respData := make(map[string]interface{}) for _, keyName := range dataContext.GetKeys() { - respData[keyName] = dataContext.Get(keyName) + respData[keyName] = dataContext.Get(keyName).Value().Interface() } resultBytes, err := json.Marshal(respData) diff --git a/editor/statics/index.html b/editor/statics/index.html index 14cd61b6..8622189a 100644 --- a/editor/statics/index.html +++ b/editor/statics/index.html @@ -18,7 +18,7 @@

- +
@@ -51,17 +51,19 @@

Data Context
-
-
-
-

- +
- +
@@ -82,6 +84,7 @@

+ diff --git a/editor/statics/js/index.js b/editor/statics/js/index.js index 11a946f9..70046f8b 100644 --- a/editor/statics/js/index.js +++ b/editor/statics/js/index.js @@ -29,13 +29,17 @@ function ShowResult() { } function executeRule() { - let grl = $("#grlText").val(); - let json = $("#jsonText").val() + let grl = $("#grleditor").text(); let grlB64 = btoa(grl); - let jsonB64 = btoa(json); - - $.post( "/evaluate", JSON.stringify({"grlText": grlB64, "jsonText": jsonB64}) , function( data, status ) { - $("#response").val(status + " : " + JSON.stringify(data) ); + let size = $('div#panelContext').find('div.jsoneditor').length; + let jsonBlob = new Array(size); + $('div#panelContext').find('div.jsoneditor').each(function(index, editor) { + let json = $(editor).text(); + let jsonB64 = btoa(json); + jsonBlob[index] = jsonB64; + }) + $.post( "/evaluate", JSON.stringify({"grlText": grlB64, "jsonInput": jsonBlob}) , function( data, status ) { + $("#response").text(status + " : " + JSON.stringify(data) ); }, "json") .fail(function(data) { $("#response").val( "Status " + data.status + " : " + data.statusText + ". ResponseText : " + data.responseText); }); @@ -69,24 +73,42 @@ function Mark() { // do nothing } -function JsonEditorTab(e) { - if (e.keyCode === 9) { // tab key - e.preventDefault(); // this will prevent us from tabbing out of the editor +function AddData(e) { + var div = document.createElement('div'); + var divBody = document.createElement('div'); + divBody.className = "card-body"; + var editor = document.createElement('div'); + editor.className = "jsoneditor"; + editor.setAttribute("contenteditable", true); + editor.setAttribute("style", style="white-space: pre-wrap; font-family: monospace; border: solid; padding: 15px 15px 15px 15px;"); + editor.setAttribute("role","textbox"); + divBody.appendChild(editor); + + var divFooter = document.createElement('div'); + divFooter.className = "card-footer"; + var button = document.createElement('button'); + button.setAttribute("type","button"); + button.className="btn btn-danger delete"; + button.innerHTML = "Delete Data"; + divFooter.appendChild(button); + + div.appendChild(divBody); + div.appendChild(divFooter); + $('div#panelContext').find("div.card-header").after(div); +} - // now insert four non-breaking spaces for the tab key - var editor = document.getElementById("jsoneditor"); - var doc = editor.ownerDocument.defaultView; - var sel = doc.getSelection(); - var range = sel.getRangeAt(0); +function JsonEditorTab(editor) { + var doc = editor.ownerDocument.defaultView; + var sel = doc.getSelection(); + var range = sel.getRangeAt(0); - var tabNode = document.createTextNode("\u00a0\u00a0\u00a0\u00a0"); - range.insertNode(tabNode); + var tabNode = document.createTextNode("\u00a0\u00a0\u00a0\u00a0"); + range.insertNode(tabNode); - range.setStartAfter(tabNode); - range.setEndAfter(tabNode); - sel.removeAllRanges(); - sel.addRange(range); - } + range.setStartAfter(tabNode); + range.setEndAfter(tabNode); + sel.removeAllRanges(); + sel.addRange(range); } function GrlEditorTab(e) { @@ -109,3 +131,17 @@ function GrlEditorTab(e) { } } +$(document).ready(function() { + $("div#panelContext").on('click','button.delete', function(event) { + event.preventDefault(); + $(this).parent().parent().remove(); + }) + + $("div#panelContext").on('keydown', 'div.jsoneditor', function(event) { + if (event.keyCode === 9) { + event.preventDefault(); + JsonEditorTab(this); + } + }) +}) +