I'm trying to sort users by online property:
var userViewModel = function(data){
var self = this;
self.name = ko.observable(data.name);
self.online = ko.observable(data.online);
};
var mainViewModel = function(data){
var self = this;
self.users = ko.observableArray(data.users.map(function(user){
var model = new userViewModel(user);
model.online.subscribe(function(){
self.users.sort(function (a, b) { return b.online() - a.online(); });
});
return model;
}));
self.users.subscribe(function(){
console.log('users have changed');
});
};
HTML:
<div data-bind="foreach: users">
Online: <div data-bind="text: online"></div>
<div data-bind="text: name"></div>
</div>
Everything is working fine, but when changing online property, users are sorted and "users have changed" is logged. I understand it happens because I'm changing original array. What I want is - not to change original array, just display it sorted (like angular does it)