hooking up functional transform preview

This commit is contained in:
Max Ogden 2011-07-02 20:22:55 -07:00
parent b1adc3f80b
commit acfacf1a8d
4 changed files with 44 additions and 56 deletions

View File

@ -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">&nbsp;&nbsp;OK&nbsp;&nbsp;</button> <button class="okButton button">&nbsp;&nbsp;Update All&nbsp;&nbsp;</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>

View File

@ -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
}; };
}(); }();

View File

@ -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);
}); });

View File

@ -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();
} }
} }