Source: models/production/trending.js

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