A JSON string is received from the server and I am trying to custom map using the KO Mapping plugin, so that I can add validation using KO validation plugin.
There is a model object named Player which has a property named Trophies which is an array of objects.
// Business Objects
var myPlayer = function (player) {
this.ID = ko.observable(player.ID);
this.Name = ko.observable(player.Name).extend({required: true});
this.Rank = ko.observable(player.Rank);
this.Trophies = ko.observableArray(player.Trophies);
}
var myTrophy = function (trophy) {
this.Name = ko.observable(trophy.Name).extend({required: true});
this.Year = ko.observable(trophy.Year).extend({required: true});
}
I don't know how to call the myTrophy so that I can Custom Map the Trophies array along with validation.
//KO binding
var playerModel = ko.mapping.fromJSON(jsonString, mapping);
ko.applyBindings(playerModel);
// Mapping
var mapping = {
'Player': {
create: function (options) {
var _player = new myPlayer(options.data);
return _player;
}
}
}
Here is the jsfiddle
if you notice in jsfiddle, if I remove the Name property I get the validation message 'This is Required' similarly I would like to get validation message for Trophy Name and Year. Let me know if you need more details. Thanks