hooking up functional transform preview
This commit is contained in:
parent
b1adc3f80b
commit
acfacf1a8d
@ -191,7 +191,7 @@
|
|||||||
<div id="expression-preview-tabs" class="refine-tabs ui-tabs ui-widget ui-widget-content ui-corner-all">
|
<div id="expression-preview-tabs" class="refine-tabs ui-tabs ui-widget ui-widget-content ui-corner-all">
|
||||||
<span>Preview</span>
|
<span>Preview</span>
|
||||||
<div id="expression-preview-tabs-preview" class="ui-tabs-panel ui-widget-content ui-corner-bottom">
|
<div id="expression-preview-tabs-preview" class="ui-tabs-panel ui-widget-content ui-corner-bottom">
|
||||||
<div class="expression-preview-container" bind="expressionPreviewPreviewContainer" style="width: 652px; ">
|
<div id="editPreview" class="expression-preview-container" bind="expressionPreviewPreviewContainer" style="width: 652px; ">
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -208,7 +208,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="dialog-footer">
|
<div class="dialog-footer">
|
||||||
<button class="okButton button"> OK </button>
|
<button class="okButton button"> Update All </button>
|
||||||
<button class="cancelButton button">Cancel</button>
|
<button class="cancelButton button">Cancel</button>
|
||||||
</div>
|
</div>
|
||||||
</script>
|
</script>
|
||||||
@ -219,20 +219,14 @@
|
|||||||
<tbody>
|
<tbody>
|
||||||
<tr>
|
<tr>
|
||||||
<td class="expression-preview-heading">
|
<td class="expression-preview-heading">
|
||||||
row
|
before
|
||||||
</td>
|
</td>
|
||||||
<td class="expression-preview-heading">
|
<td class="expression-preview-heading">
|
||||||
value
|
after
|
||||||
</td>
|
|
||||||
<td class="expression-preview-heading">
|
|
||||||
value
|
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
{{#rows}}
|
{{#rows}}
|
||||||
<tr>
|
<tr>
|
||||||
<td width="1%">
|
|
||||||
{{count}}
|
|
||||||
</td>
|
|
||||||
<td class="expression-preview-value">
|
<td class="expression-preview-value">
|
||||||
{{before}}
|
{{before}}
|
||||||
</td>
|
</td>
|
||||||
|
|||||||
@ -5,7 +5,7 @@ var costco = function() {
|
|||||||
var toUpdate = [];
|
var toUpdate = [];
|
||||||
|
|
||||||
function handleEditorChange(e) {
|
function handleEditorChange(e) {
|
||||||
console.log(e.target.value);
|
mapDocs(e.target.value);
|
||||||
}
|
}
|
||||||
|
|
||||||
function computeChanges() {
|
function computeChanges() {
|
||||||
@ -37,47 +37,51 @@ var costco = function() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function mapDocs(funcString) {
|
function mapDocs(funcString) {
|
||||||
|
var errors = $('.expression-preview-parsing-status');
|
||||||
try {
|
try {
|
||||||
eval("var editFunc = " + funcString);
|
eval("var editFunc = " + funcString);
|
||||||
|
errors.text('No syntax error.');
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
$("#status").html("<span class='error'>error evaluating function: "
|
errors.text(e+"");
|
||||||
+ e + "</span>");
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
toUpdate = [];
|
toUpdate = [];
|
||||||
var deleted = 0
|
var deleted = 0
|
||||||
, edited = 0
|
, edited = 0
|
||||||
, failed = 0;
|
, failed = 0
|
||||||
|
, count = 0
|
||||||
getDocs(function(data) {
|
, preview = [];
|
||||||
var rows = data.rows;
|
|
||||||
rows.forEach(function(row) {
|
_.each(app.cache, function(doc) {
|
||||||
var doc = row.doc;
|
try {
|
||||||
try {
|
var updated = editFunc(_.clone(doc));
|
||||||
var updated = editFunc(_.clone(doc));
|
} catch(e) {
|
||||||
} catch(e) {
|
failed++; // ignore if it throws on this doc
|
||||||
failed++; // ignore if it throws on this doc
|
return;
|
||||||
return;
|
}
|
||||||
}
|
if(updated === null) {
|
||||||
if(updated === null) {
|
doc._deleted = true;
|
||||||
doc._deleted = true;
|
toUpdate.push(doc);
|
||||||
toUpdate.push(doc);
|
deleted++;
|
||||||
deleted++;
|
}
|
||||||
}
|
else if(updated && !_.isEqual(updated, doc)) {
|
||||||
else if(updated && !_.isEqual(updated, doc)) {
|
toUpdate.push(updated);
|
||||||
toUpdate.push(updated);
|
edited++;
|
||||||
edited++;
|
}
|
||||||
}
|
preview.push({before: doc[app.currentColumn], after: updated[app.currentColumn]});
|
||||||
});
|
count++;
|
||||||
// todo: make template for this
|
|
||||||
$("#status").html("<span class='warning'>About to edit " + edited
|
|
||||||
+ " docs and delete " + deleted + " docs from "
|
|
||||||
+ getDb().name + "</span>");
|
|
||||||
if(failed)
|
|
||||||
$("#status").append(". Edit function threw on " + failed + " docs");
|
|
||||||
$("#update-container").show();
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
util.render('editPreview', 'editPreview', {rows: preview});
|
||||||
|
//
|
||||||
|
// // todo: make template for this
|
||||||
|
// $("#status").html("<span class='warning'>About to edit " + edited
|
||||||
|
// + " docs and delete " + deleted + " docs from "
|
||||||
|
// + getDb().name + "</span>");
|
||||||
|
// if(failed)
|
||||||
|
// $("#status").append(". Edit function threw on " + failed + " docs");
|
||||||
|
// $("#update-container").show();
|
||||||
}
|
}
|
||||||
|
|
||||||
function updateDocs(callback) {
|
function updateDocs(callback) {
|
||||||
@ -93,22 +97,10 @@ var costco = function() {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function getDocs(callback) {
|
|
||||||
getDb().allDocs({
|
|
||||||
include_docs : true,
|
|
||||||
success : callback,
|
|
||||||
error: function(req, status, err) {
|
|
||||||
$("#status").html("<span class='error'>error retrieving docs: "
|
|
||||||
+ err + "</span>");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
return {
|
||||||
handleEditorChange: handleEditorChange,
|
handleEditorChange: handleEditorChange,
|
||||||
computeChanges: computeChanges,
|
computeChanges: computeChanges,
|
||||||
mapDocs: mapDocs,
|
mapDocs: mapDocs,
|
||||||
updateDocs: updateDocs,
|
updateDocs: updateDocs
|
||||||
getDocs: getDocs
|
|
||||||
};
|
};
|
||||||
}();
|
}();
|
||||||
@ -114,6 +114,7 @@ var removalist = function() {
|
|||||||
couch.request(req).then(function(response) {
|
couch.request(req).then(function(response) {
|
||||||
var offset = response.offset + 1;
|
var offset = response.offset + 1;
|
||||||
$('.viewpanel-pagingcount').text(offset + " - " + ((offset - 1) + getPageSize()));
|
$('.viewpanel-pagingcount').text(offset + " - " + ((offset - 1) + getPageSize()));
|
||||||
|
app.cache = response.rows.map(function(row) { return row.value; } );
|
||||||
removalist.renderRows(response);
|
removalist.renderRows(response);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@ -43,11 +43,12 @@ app.after = {
|
|||||||
bulkEdit: function() {
|
bulkEdit: function() {
|
||||||
var editor = $('.expression-preview-code');
|
var editor = $('.expression-preview-code');
|
||||||
editor.val("function(doc) {\n doc['"+ app.currentColumn+"'] = doc['"+ app.currentColumn+"'];\n return doc;\n}");
|
editor.val("function(doc) {\n doc['"+ app.currentColumn+"'] = doc['"+ app.currentColumn+"'];\n return doc;\n}");
|
||||||
editor.focus().get(0).setSelectionRange(18, 18);
|
editor.focus().get(0).setSelectionRange(18, 18);
|
||||||
editor.keydown(function(e) {
|
editor.keydown(function(e) {
|
||||||
// if you don't setTimeout it won't grab the latest character if you call e.target.value
|
// if you don't setTimeout it won't grab the latest character if you call e.target.value
|
||||||
window.setTimeout(function(){costco.handleEditorChange(e)}, 1, true);
|
window.setTimeout(function(){costco.handleEditorChange(e)}, 1, true);
|
||||||
});
|
});
|
||||||
|
editor.keydown();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user