define('application/models/production/trending', [
'rofl/models/api/abstract',
'rofl/lib/utils',
'application/models/broadcast',
'application/models/configuration',
'application/managers/channel',
'application/models/configuration'
], function (
Abstract,
Utils,
Broadcast,
KPNConfig,
ChannelManager,
Configuration
) {
'use strict';
var endPoints = {
program: '101/1.2.0/A/nld/smarttv/kpn/TRAY/AVA/TRENDING/YESTERDAY'
};
return Abstract.extend({
/**
* Resolves the endpoint.
*
* @param {Object} params - Search parameters.
* @param {string} params.query - Text to be searched for in the backend.
* @returns {string} Resolved endpoint.
*/
resolveEndpoint: function (params) {
var endpoint = endPoints.program;
endpoint += '?maxResults=' + params.maxResults;
return endpoint;
},
/**
* Transforms API data into the abstract model data.
*
* @param {Object} response - The data object gotten from the API.
* @returns {Object} The filled model instance.
*/
transformFrom: function (response) {
var results = Utils.getNested(response, 'resultObj', 'containers') || [],
channels = {};
if (this._formatByChannel) {
Utils.each(results, function (entry) {
if (!channels[entry.channel.channelId]) {
channels[entry.channel.channelId] = [];
}
channels[entry.channel.channelId].push(new Broadcast(entry));
});
return channels;
}
return Utils.map(results, function (entry) {
return new Broadcast(entry);
});
},
/**
* Validates the read response.
*
* @param {Object} response - The read response.
* @returns {boolean} - True if valid.
*/
validateReadResponse: function (response) {
return response.resultCode === Configuration.RESPONSE_CODES.OK;
}
});
});