function ExpressionPreviewDialog(title, cellIndex, rowIndices, values, expression, onDone) { this._cellIndex = cellIndex; this._rowIndices = rowIndices; this._values = values; this._results = null; this._expression = expression; this._onDone = onDone; this._timerID = null; this._createDialog(title); } ExpressionPreviewDialog.prototype._createDialog = function(title) { var self = this; var frame = DialogSystem.createDialog(); frame.width("600px"); var header = $('
').addClass("dialog-header").text(title).appendTo(frame); var body = $('
').addClass("dialog-body").appendTo(frame); var footer = $('
').addClass("dialog-footer").appendTo(frame); var p = $('

').text("Expression: ").appendTo(body); this._input = $('').width("400px").keypress(function(){ self._scheduleUpdate(); }).appendTo(p); this._preview = $('
').addClass("expression-preview-container").appendTo(body); $('').html("  OK  ").click(function() { DialogSystem.dismissUntil(level - 1); self._onDone(self._expression); }).appendTo(footer); $('').text("Cancel").click(function() { DialogSystem.dismissUntil(level - 1); }).appendTo(footer); var level = DialogSystem.showDialog(frame); this._input[0].value = this._expression; this._input[0].focus(); this._update(); }; ExpressionPreviewDialog.prototype._scheduleUpdate = function() { if (this._timerID != null) { window.clearTimeout(this._timerID); } var self = this; this._timerID = window.setTimeout(function() { self._update(); }, 300); }; ExpressionPreviewDialog.prototype._update = function() { var self = this; var expression = this._expression = $.trim(this._input[0].value); $.post( "/command/preview-expression?" + $.param({ project: theProject.id, expression: expression, cellIndex: this._cellIndex }), { rowIndices: JSON.stringify(this._rowIndices) }, function(data) { if (data.code != "error") { self._results = data.results; } else { self._results = null; } self._renderPreview(expression); }, "json" ); }; ExpressionPreviewDialog.prototype._renderPreview = function(expression) { var container = this._preview.empty(); var table = $('
').appendTo(container)[0]; var tr = table.insertRow(0); $(tr.insertCell(0)).addClass("expression-preview-heading").text("row"); $(tr.insertCell(1)).addClass("expression-preview-heading").text("value"); $(tr.insertCell(2)).addClass("expression-preview-heading").text(expression); var renderValue = function(td, v) { if (v != null) { td.html($.isArray(v) ? JSON.stringify(v) : v); } else { $('(null)').addClass("expression-preview-empty").appendTo(td); } }; for (var i = 0; i < this._values.length; i++) { var tr = table.insertRow(table.rows.length); $(tr.insertCell(0)).attr("width", "1%").html((this._rowIndices[i] + 1) + "."); renderValue($(tr.insertCell(1)), this._values[i]); var tdValue = $(tr.insertCell(2)); if (this._results != null) { var v = this._results[i]; renderValue(tdValue, v); } else { $('(error)').addClass("expression-preview-empty").appendTo(tdValue); } } };