Skip to content

Commit

Permalink
first guess at how to support modifying observable indices.
Browse files Browse the repository at this point in the history
  • Loading branch information
barkmadley committed Oct 22, 2011
1 parent 8de3398 commit 9be31b2
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 1 deletion.
12 changes: 12 additions & 0 deletions src/binding/editDetection/arrayToDomNodeChildren.js
Expand Up @@ -46,6 +46,7 @@
var newMappingResult = [];
var lastMappingResultIndex = 0;
var nodesToDelete = [];
var nodesToUpdateIndex = [];
var nodesAdded = [];
var insertAfterNode = null;
for (var i = 0, j = editScript.length; i < j; i++) {
Expand All @@ -57,6 +58,13 @@
if (dataToRetain.domNodes.length > 0)
insertAfterNode = dataToRetain.domNodes[dataToRetain.domNodes.length - 1];
lastMappingResultIndex++;
for (var nodeI = 0; nodeI < dataToRetain.domNodes.length; nodeI++) {
var node = dataToRetain.domNodes[nodeI];
var context = ko.storedBindingContextForNode(node);
if (context && context['$index']) {
nodesToUpdateIndex.push({ index: context['$index'], newIndex: i});
}
}
break;

case "deleted":
Expand Down Expand Up @@ -125,6 +133,10 @@

// Store a copy of the array items we just considered so we can difference it next time
ko.utils.domData.set(domNode, lastMappingResultDomDataKey, newMappingResult);

ko.utils.arrayForEach(nodesToUpdateIndex, function(obj) {
obj.index(obj.newIndex);
});
}
})();

Expand Down
2 changes: 1 addition & 1 deletion src/templating/templating.js
Expand Up @@ -119,7 +119,7 @@
ko.renderTemplateForEach = function (template, arrayOrObservableArray, options, targetNode, parentBindingContext) {
var createInnerBindingContext = function(arrayValue, index) {
var result = parentBindingContext.createChildContext(ko.utils.unwrapObservable(arrayValue));
result['$index'] = index;
result['$index'] = ko.observable(index);
return result;
};

Expand Down

0 comments on commit 9be31b2

Please sign in to comment.