Skip to content
Snippets Groups Projects
Commit 509782a9 authored by Benoît Harrault's avatar Benoît Harrault
Browse files

Merge branch '39-improve-clean-code' into 'master'

Resolve "Improve/clean code"

Closes #39

See merge request !36
parents 35e20a2f eb0b9b89
No related branches found
No related tags found
1 merge request!36Resolve "Improve/clean code"
...@@ -61,6 +61,9 @@ try { ...@@ -61,6 +61,9 @@ try {
$topArtistsCount = 40; $topArtistsCount = 40;
$playlistsCount = 24; $playlistsCount = 24;
$tracksCountInShortPlaylist = 50;
$tracksCountInLongPlaylist = 100;
$templateData = [ $templateData = [
'user' => $user, 'user' => $user,
'playlists' => [], 'playlists' => [],
...@@ -76,8 +79,20 @@ $generatePlaylistFromSelectedTopArtists = isset($_GET['generate-playlist-top-art ...@@ -76,8 +79,20 @@ $generatePlaylistFromSelectedTopArtists = isset($_GET['generate-playlist-top-art
$generatePlaylistFromRandomTopArtists = isset($_GET['generate-playlist-random-top-artists']); $generatePlaylistFromRandomTopArtists = isset($_GET['generate-playlist-random-top-artists']);
$showPlaylistContent = isset($_GET['show-playlist']); $showPlaylistContent = isset($_GET['show-playlist']);
$action = '';
if ($generatePlaylistFromPlaylist) { if ($generatePlaylistFromPlaylist) {
$action = 'generate-playlist-from-playlist';
} elseif ($generatePlaylistFromSelectedTopArtists) {
$action = 'generate-playlist-from-selected-top-artists';
} elseif ($generatePlaylistFromRandomTopArtists) {
$action = 'generate-playlist-from-random-top-artists';
} elseif ($showPlaylistContent) {
$action = 'show-playlist-content';
} else {
}
switch ($action) {
case 'generate-playlist-from-playlist':
$selectedPlaylists = $_GET['selected-playlist']; $selectedPlaylists = $_GET['selected-playlist'];
printLog('Will create new playlist with recommendations from playlists: '.join(', ', $selectedPlaylists).'".'); printLog('Will create new playlist with recommendations from playlists: '.join(', ', $selectedPlaylists).'".');
$recommendedTrackIds = []; $recommendedTrackIds = [];
...@@ -130,11 +145,14 @@ if ($generatePlaylistFromPlaylist) { ...@@ -130,11 +145,14 @@ if ($generatePlaylistFromPlaylist) {
$recommendedTrackIds = $filteredTrackIds; $recommendedTrackIds = $filteredTrackIds;
} }
$newPlaylist = createPlaylistWithRandomTracks($api, $recommendedTrackIds, $generateLongPlaylist ? 100 : 50); $newPlaylist = createPlaylistWithRandomTracks(
$api,
$recommendedTrackIds,
$generateLongPlaylist ? $tracksCountInLongPlaylist : $tracksCountInShortPlaylist
);
$templateData['infos'][] = getCreatedPlaylistInformationMessage($api, $newPlaylist); $templateData['infos'][] = getCreatedPlaylistInformationMessage($api, $newPlaylist);
break;
} elseif ($generatePlaylistFromSelectedTopArtists) { case 'generate-playlist-from-selected-top-artists':
$selectedArtists = $_GET['selected-artist']; $selectedArtists = $_GET['selected-artist'];
printLog('Will create new playlist with filterted recommendations from artists: '.join(', ', $selectedArtists).'".'); printLog('Will create new playlist with filterted recommendations from artists: '.join(', ', $selectedArtists).'".');
$recommendedTrackIds = []; $recommendedTrackIds = [];
...@@ -168,15 +186,23 @@ if ($generatePlaylistFromPlaylist) { ...@@ -168,15 +186,23 @@ if ($generatePlaylistFromPlaylist) {
} }
} }
$newPlaylist = createPlaylistWithRandomTracks($api, $recommendedTrackIds, $generateLongPlaylist ? 100 : 50); $newPlaylist = createPlaylistWithRandomTracks(
$api,
$recommendedTrackIds,
$generateLongPlaylist ? $tracksCountInLongPlaylist : $tracksCountInShortPlaylist
);
$templateData['infos'][] = getCreatedPlaylistInformationMessage($api, $newPlaylist); $templateData['infos'][] = getCreatedPlaylistInformationMessage($api, $newPlaylist);
break;
} elseif ($generatePlaylistFromRandomTopArtists) { case 'generate-playlist-from-random-top-artists':
$countInTopArtists = random_int(4, 6); $countInTopArtists = random_int(4, 6);
$countInLessTopArtists = random_int(4, 6); $countInLessTopArtists = random_int(4, 6);
$limitBetweenTopAndLessTop = $topArtistsCount; $limitBetweenTopAndLessTop = $topArtistsCount;
$selectedArtists = getRandomArtistsFromTopArtists($api, $countInTopArtists, $countInLessTopArtists, $limitBetweenTopAndLessTop); $selectedArtists = getRandomArtistsFromTopArtists(
$api,
$countInTopArtists,
$countInLessTopArtists,
$limitBetweenTopAndLessTop
);
printLog('Will create new playlist with filterted recommendations from random artists: '.join(', ', $selectedArtists).'".'); printLog('Will create new playlist with filterted recommendations from random artists: '.join(', ', $selectedArtists).'".');
$recommendedTrackIds = []; $recommendedTrackIds = [];
...@@ -192,7 +218,7 @@ if ($generatePlaylistFromPlaylist) { ...@@ -192,7 +218,7 @@ if ($generatePlaylistFromPlaylist) {
'seed_artists' => $selectedArtist, 'seed_artists' => $selectedArtist,
'limit' => 100 'limit' => 100
]); ]);
printLog(' -> Got '.count($recommendations->tracks).' recommendatations.'); printLog(' -> Got '.count($recommendations->tracks).' recommendations.');
// Filter by artist if requested, remove duplicates // Filter by artist if requested, remove duplicates
foreach ($recommendations->tracks as $recommendedTrack) { foreach ($recommendations->tracks as $recommendedTrack) {
...@@ -209,20 +235,25 @@ if ($generatePlaylistFromPlaylist) { ...@@ -209,20 +235,25 @@ if ($generatePlaylistFromPlaylist) {
} }
} }
$newPlaylist = createPlaylistWithRandomTracks($api, $recommendedTrackIds, $generateLongPlaylist ? 100 : 50); $newPlaylist = createPlaylistWithRandomTracks(
$api,
$recommendedTrackIds,
$generateLongPlaylist ? $tracksCountInLongPlaylist : $tracksCountInShortPlaylist
);
$templateData['infos'][] = getCreatedPlaylistInformationMessage($api, $newPlaylist); $templateData['infos'][] = getCreatedPlaylistInformationMessage($api, $newPlaylist);
break;
} elseif ($showPlaylistContent) { case 'show-playlist-content':
printLog('Get content of playlist: '.($generateLongPlaylist ? 'yes' : 'no')); printLog('Get content of playlist');
$playlistId = $_GET['id']; $playlistId = $_GET['id'];
$playlist = $api->getPlaylist($playlistId); $playlist = $api->getPlaylist($playlistId);
$templateData['infos'][] = getPlaylistInformationMessage($api, $playlist); $templateData['infos'][] = getPlaylistInformationMessage($api, $playlist);
$templateData['playlist'] = createDisplayablePlaylist($playlist); $templateData['playlist'] = createDisplayablePlaylist($playlist);
break;
} else { default:
$templateData['topArtists'] = $api->getMyTop('artists', ['limit' => $topArtistsCount, 'time_range' => 'short_term'])->items; $templateData['topArtists'] = $api->getMyTop('artists', ['limit' => $topArtistsCount, 'time_range' => 'short_term'])->items;
$templateData['playlists'] = $api->getUserPlaylists($user['id'], ['limit' => $playlistsCount])->items; $templateData['playlists'] = $api->getUserPlaylists($user['id'], ['limit' => $playlistsCount])->items;
break;
} }
require '../template.php'; require '../template.php';
...@@ -11,17 +11,17 @@ function generateShowPlaylistUrl($playlistId) { ...@@ -11,17 +11,17 @@ function generateShowPlaylistUrl($playlistId) {
return '/view-playlist-'.$playlistId; return '/view-playlist-'.$playlistId;
} }
function generatePlaylistName() function generatePlaylistName($prefix)
{ {
$now = new DateTime(); $now = new DateTime();
$name = 'Fresh playlist ['.$now->format('Y-m-d H:i:s').']'; $name = $prefix.' ['.$now->format('Y-m-d H:i:s').']';
return $name; return $name;
} }
function createEmptyPlaylist($api) function createEmptyPlaylist($api, $playlistName = 'Auto playlist')
{ {
$name = generatePlaylistName(); $name = generatePlaylistName($playlistName);
printLog('Create new playlist "'.$name.'".'); printLog('Create new playlist "'.$name.'".');
$playlist = $api->createPlaylist([ $playlist = $api->createPlaylist([
'name' => $name, 'name' => $name,
...@@ -30,11 +30,16 @@ function createEmptyPlaylist($api) ...@@ -30,11 +30,16 @@ function createEmptyPlaylist($api)
return $playlist; return $playlist;
} }
function pickRandomTracksFromArray($recommendedTrackIds, $count = 50) function pickRandomTracksFromArray($recommendedTrackIds, $count = 0)
{ {
$recommendedTrackIds = array_keys($recommendedTrackIds); $recommendedTrackIds = array_keys($recommendedTrackIds);
printLog('=> Got '.count($recommendedTrackIds).' unique recommendatations.'); printLog('=> Got '.count($recommendedTrackIds).' unique tracks.');
shuffle($recommendedTrackIds); shuffle($recommendedTrackIds);
if (!$count) {
return $recommendedTrackIds;
}
$pickedTrackIds = array_slice($recommendedTrackIds, 0, $count); $pickedTrackIds = array_slice($recommendedTrackIds, 0, $count);
printLog('Keep '.count($pickedTrackIds).' random tracks.'); printLog('Keep '.count($pickedTrackIds).' random tracks.');
...@@ -77,7 +82,7 @@ function getRandomArtistsFromTopArtists($api, $countInTopArtists, $countInLessTo ...@@ -77,7 +82,7 @@ function getRandomArtistsFromTopArtists($api, $countInTopArtists, $countInLessTo
function createPlaylistWithRandomTracks($api, $trackIds, $count = 50) function createPlaylistWithRandomTracks($api, $trackIds, $count = 50)
{ {
$playlist = createEmptyPlaylist($api); $playlist = createEmptyPlaylist($api, 'Fresh playlist');
$pickedTrackIds = pickRandomTracksFromArray($trackIds, $count); $pickedTrackIds = pickRandomTracksFromArray($trackIds, $count);
$api->replacePlaylistTracks($playlist->id, $pickedTrackIds); $api->replacePlaylistTracks($playlist->id, $pickedTrackIds);
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment