Obtenha todos os vídeos do YouTube em uma lista de reprodução usando o Angular JS
Desejo obter todos os vídeos do YouTube em uma lista de reprodução especificada. Atualmente, a API permite extrair 50 registros por vez, mas você pode extrair o próximo conjunto de registros passando um token da próxima página.
Ainda sou novo na Angular e estou tendo problemas para realizar esta tarefa.
Aqui está o que eu tenho atualmente:
var app = angular.module('ph', []);
var key = '';
app.factory('youtubeService', ['$http', function ($http) {
function getPlaylists(channelId) {
return $.get("https://www.googleapis.com/youtube/v3/playlists", { part: 'snippet', channelId: channelId, key: key, maxResults: 50 });
}
function getPlaylistVideos(playlistId) {
var items = [];
var nextPageToken = "";
$.get('https://www.googleapis.com/youtube/v3/playlistItems', { part: 'snippet', maxResults: 50, playlistId: playlistId, key: key }).then(function (firstResponse) {
items = firstResponse.items;
var numberOfPages = Math.ceil(firstResponse.pageInfo.totalResults / 50);
for (var page = 1; page <= numberOfPages; page++) {
$.get('https://www.googleapis.com/youtube/v3/playlistItems', { part: 'snippet', maxResults: 50, pageToken: nextPageToken, playlistId: playlistId, key: key }).then(function(response) {
items = items.concat(response.items);
nextPageToken = response.nextPageToken;
});
}
});
return items;
}
function getVideos(keyword) {
return $.get('https://www.googleapis.com/youtube/v3/search', { part: 'snippet', q: keyword, key: key, type: 'video' });
}
return { getPlaylists: getPlaylists, getPlaylistVideos: getPlaylistVideos, getVideos: getVideos }
}]);
app.controller('ctrl', ['$http', '$scope', 'youtubeService', function ($http, $scope, youtubeService) {
youtubeService.getPlaylists('UC-9-kyTW8ZkZNDHQJ6FgpwQ').then(function (response) {
$scope.$apply(function () {
$scope.playlists = response.items;
});
});
$scope.getPlaylistVideos = function (selection) {
youtubeService.getPlaylistVideos(selection.id).then(function (response) {
$scope.$apply(function () {
$scope.playlistvideos = response.items;
});
});
}
$scope.getVideos = function (selection) {
youtubeService.getVideos(selection).then(function (response) {
$scope.$apply(function () {
$scope.videos = response.items;
});
});
}
}]);
O que preciso fazer na função getPlaylistVideos para que ela retorne todos os vídeos em uma lista de reprodução? Em vez de apenas 50.
Este é o código que eu tinha antes para retornar a primeira página:
function getPlaylistVideos(playlistId) {
return $.get('https://www.googleapis.com/youtube/v3/playlistItems', { part: 'snippet', maxResults: 50, playlistId: playlistId, key: key});
}
Um exemplo de ID de lista de reprodução é PLFPg_IUxqnZNTAbUMEZ76_snWd-ED5en7.
Qualquer ajuda é muito apreciada!
Resposta Modificada$scope.getPlaylistVideos = function (selection) {
// pass the nextPageToken attribute to the getPlaylistVideos method.
youtubeService.getPlaylistVideos("PLFPg_IUxqnZNTAbUMEZ76_snWd-ED5en7", $scope.nextPageToken).then(function (response) {
$scope.$apply(function () {
angular.forEach(response.items, function (item) {
$scope.playlistvideos.push(item);
});
if (typeof response.nextPageToken != 'undefined') {
$scope.nextPageToken = response.nextPageToken;
// call the get playlist function again
$scope.getPlaylistVideos(selection);
}
});
});
}