Development 666(?)
This commit is contained in:
+116
-132
@@ -20,6 +20,8 @@ using Windows.Storage;
|
||||
using Windows.UI.Text;
|
||||
using FoxTube.Controls;
|
||||
using FoxTube.Pages;
|
||||
using System.Collections.ObjectModel;
|
||||
using System.Diagnostics;
|
||||
|
||||
// The Blank Page item template is documented at https://go.microsoft.com/fwlink/?LinkId=234238
|
||||
|
||||
@@ -34,11 +36,12 @@ namespace FoxTube
|
||||
private bool trendLoaded = false;
|
||||
private bool subsLoaded = false;
|
||||
|
||||
VideoGrid recGrid = new VideoGrid(), trendGrid = new VideoGrid(), subsGrid = new VideoGrid();
|
||||
ShowMore recMore = new ShowMore(), trendMore = new ShowMore(), subsMore = new ShowMore();
|
||||
LoadingPage recLoading = new LoadingPage(), trendLoading = new LoadingPage(), subsLoading = new LoadingPage();
|
||||
VideoGrid recGrid, trendGrid, subsGrid;
|
||||
ShowMore recMore, trendMore, subsMore;
|
||||
LoadingPage loading;
|
||||
|
||||
string trendToken, recToken, subsToken;
|
||||
string trendToken, recToken;
|
||||
Dictionary<string, string> subsTokens = new Dictionary<string, string>();
|
||||
string reg;
|
||||
|
||||
public Home()
|
||||
@@ -46,27 +49,29 @@ namespace FoxTube
|
||||
this.InitializeComponent();
|
||||
try
|
||||
{
|
||||
reg = (ApplicationData.Current.LocalSettings.Values["region"] as string).ToUpper().Remove(0, 3);
|
||||
reg = (ApplicationData.Current.LocalSettings.Values["region"] as string).ToLower().Remove(0, 3);
|
||||
}
|
||||
catch (ArgumentOutOfRangeException)
|
||||
{
|
||||
reg = (ApplicationData.Current.LocalSettings.Values["region"] as string).ToUpper();
|
||||
}
|
||||
|
||||
recMore.Clicked += RecMore_Clicked;
|
||||
trendMore.Clicked += TrendMore_Clicked;
|
||||
subsMore.Clicked += SubsMore_Clicked;
|
||||
recGrid = ((recommended.Content as ScrollViewer).Content as StackPanel).Children[0] as VideoGrid;
|
||||
trendGrid = ((trending.Content as ScrollViewer).Content as StackPanel).Children[0] as VideoGrid;
|
||||
subsGrid = ((subscriptions.Content as ScrollViewer).Content as StackPanel).Children[0] as VideoGrid;
|
||||
|
||||
recLoading.RefreshPage += refreshPage;
|
||||
subsLoading.RefreshPage += refreshPage;
|
||||
trendLoading.RefreshPage += refreshPage;
|
||||
recMore = ((recommended.Content as ScrollViewer).Content as StackPanel).Children[1] as ShowMore;
|
||||
trendMore = ((trending.Content as ScrollViewer).Content as StackPanel).Children[1] as ShowMore; ;
|
||||
subsMore = ((subscriptions.Content as ScrollViewer).Content as StackPanel).Children[1] as ShowMore;
|
||||
|
||||
loading = grid.Children[2] as LoadingPage;
|
||||
|
||||
Initialize();
|
||||
}
|
||||
|
||||
private void refreshPage(object sender, RoutedEventArgs e)
|
||||
{
|
||||
Initialize();
|
||||
(Parent as Frame).Navigate(typeof(Home));
|
||||
}
|
||||
|
||||
private void RecMore_Clicked()
|
||||
@@ -76,137 +81,102 @@ namespace FoxTube
|
||||
|
||||
private async void TrendMore_Clicked()
|
||||
{
|
||||
VideosResource.ListRequest request = SecretsVault.Service.Videos.List("id");
|
||||
request.MaxResults = 48;
|
||||
request.PageToken = trendToken;
|
||||
|
||||
request.Chart = VideosResource.ListRequest.ChartEnum.MostPopular;
|
||||
request.RegionCode = reg;
|
||||
VideoListResponse response = await request.ExecuteAsync();
|
||||
|
||||
if (!string.IsNullOrWhiteSpace(response.NextPageToken))
|
||||
trendToken = response.NextPageToken;
|
||||
else
|
||||
trendMore.Complete(true);
|
||||
|
||||
foreach (Video vid in response.Items)
|
||||
try
|
||||
{
|
||||
VideoCard vCard = new VideoCard(vid.Id);
|
||||
recGrid.Add(vCard);
|
||||
VideosResource.ListRequest request = SecretsVault.Service.Videos.List("id");
|
||||
request.MaxResults = 48;
|
||||
request.PageToken = trendToken;
|
||||
|
||||
request.Chart = VideosResource.ListRequest.ChartEnum.MostPopular;
|
||||
request.RegionCode = reg;
|
||||
VideoListResponse response = await request.ExecuteAsync();
|
||||
|
||||
if (!string.IsNullOrWhiteSpace(response.NextPageToken))
|
||||
trendToken = response.NextPageToken;
|
||||
else
|
||||
trendMore.Complete(true);
|
||||
|
||||
foreach (Video vid in response.Items)
|
||||
{
|
||||
VideoCard vCard = new VideoCard(vid.Id);
|
||||
recGrid.Add(vCard);
|
||||
}
|
||||
trendMore.Complete();
|
||||
}
|
||||
catch
|
||||
{
|
||||
trendMore.Complete(true);
|
||||
}
|
||||
trendMore.Complete();
|
||||
}
|
||||
|
||||
private void SubsMore_Clicked()
|
||||
private async void SubsMore_Clicked()
|
||||
{
|
||||
try
|
||||
{
|
||||
List<SearchResult> items = new List<SearchResult>();
|
||||
Dictionary<string, string> pairs = new Dictionary<string, string>();
|
||||
SearchResource.ListRequest request = SecretsVault.Service.Search.List("snippet");
|
||||
request.Type = "video";
|
||||
request.MaxResults = 10;
|
||||
request.Order = SearchResource.ListRequest.OrderEnum.Date;
|
||||
|
||||
foreach (KeyValuePair<string, string> i in subsTokens)
|
||||
{
|
||||
request.ChannelId = i.Key;
|
||||
request.PageToken = i.Value;
|
||||
SearchListResponse response = await request.ExecuteAsync();
|
||||
foreach (SearchResult result in response.Items)
|
||||
items.Add(result);
|
||||
if (response.NextPageToken != null)
|
||||
pairs.Add(i.Value, response.NextPageToken);
|
||||
}
|
||||
if (pairs.Count == 0)
|
||||
subsMore.Complete(true);
|
||||
else
|
||||
subsTokens = pairs;
|
||||
|
||||
items = items.OrderByDescending(x => x.Snippet.PublishedAt).ToList();
|
||||
|
||||
foreach (SearchResult i in items)
|
||||
subsGrid.Add(new VideoCard(i.Id.VideoId));
|
||||
|
||||
subsMore.Complete();
|
||||
}
|
||||
catch
|
||||
{
|
||||
subsMore.Complete(true);
|
||||
}
|
||||
}
|
||||
|
||||
public void Initialize()
|
||||
{
|
||||
GC.Collect();
|
||||
pivot.Items.Clear();
|
||||
|
||||
if(SecretsVault.IsAuthorized)
|
||||
{
|
||||
//Initializing recommended tab
|
||||
StackPanel rs = new StackPanel();
|
||||
rs.Children.Add(recGrid);
|
||||
rs.Children.Add(recMore);
|
||||
Grid rg = new Grid();
|
||||
rg.Children.Add(new ScrollViewer() { Content = rs });
|
||||
rg.Children.Add(recLoading);
|
||||
|
||||
pivot.Items.Add(new PivotItem()
|
||||
{
|
||||
Content = rg,
|
||||
Header = "Recommended"
|
||||
});
|
||||
|
||||
//Initializing trending tab
|
||||
StackPanel ts = new StackPanel();
|
||||
ts.Children.Add(trendGrid);
|
||||
ts.Children.Add(trendMore);
|
||||
Grid tg = new Grid();
|
||||
tg.Children.Add(new ScrollViewer() { Content = ts });
|
||||
tg.Children.Add(trendLoading);
|
||||
|
||||
pivot.Items.Add(new PivotItem()
|
||||
{
|
||||
Content = tg,
|
||||
Header = "Trending"
|
||||
});
|
||||
|
||||
//Initializing subscriptions tab
|
||||
StackPanel s = new StackPanel();
|
||||
s.Children.Add(subsGrid);
|
||||
s.Children.Add(subsMore);
|
||||
Grid g = new Grid();
|
||||
g.Children.Add(new ScrollViewer() { Content = s });
|
||||
g.Children.Add(subsLoading);
|
||||
|
||||
pivot.Items.Add(new PivotItem()
|
||||
{
|
||||
Content = g,
|
||||
Header = "Subscriptions"
|
||||
});
|
||||
|
||||
LoadRecommendations();
|
||||
}
|
||||
else
|
||||
{
|
||||
StackPanel ts = new StackPanel();
|
||||
ts.Children.Add(trendGrid);
|
||||
ts.Children.Add(trendMore);
|
||||
Grid tg = new Grid();
|
||||
tg.Children.Add(new ScrollViewer() { Content = ts });
|
||||
tg.Children.Add(trendLoading);
|
||||
|
||||
pivot.Items.Add(new PivotItem()
|
||||
{
|
||||
Content = tg
|
||||
});
|
||||
pivot.Items.Remove(recommended);
|
||||
pivot.Items.Remove(subscriptions);
|
||||
|
||||
LoadTrending();
|
||||
}
|
||||
}
|
||||
|
||||
private void refresh_Click(object sender, RoutedEventArgs e)
|
||||
{
|
||||
Initialize();
|
||||
}
|
||||
|
||||
private void pivot_SelectionChanged(object sender, SelectionChangedEventArgs e)
|
||||
{
|
||||
switch(pivot.SelectedIndex)
|
||||
{
|
||||
case 2:
|
||||
if (!subsLoaded)
|
||||
LoadSubscriptions();
|
||||
break;
|
||||
case 1:
|
||||
if (!trendLoaded)
|
||||
LoadTrending();
|
||||
break;
|
||||
case 0:
|
||||
if (pivot.Items.Count > 1)
|
||||
{
|
||||
if (!recLoaded)
|
||||
LoadRecommendations();
|
||||
}
|
||||
else
|
||||
{
|
||||
if (!trendLoaded)
|
||||
LoadTrending();
|
||||
}
|
||||
break;
|
||||
}
|
||||
loading.Close();
|
||||
if (pivot.SelectedItem == recommended && !recLoaded)
|
||||
LoadRecommendations();
|
||||
else if (pivot.SelectedItem == trending && !trendLoaded)
|
||||
LoadTrending();
|
||||
else if (pivot.SelectedItem == subscriptions && !subsLoaded)
|
||||
LoadSubscriptions();
|
||||
}
|
||||
|
||||
async void LoadTrending()
|
||||
{
|
||||
try
|
||||
{
|
||||
loading.Refresh();
|
||||
VideosResource.ListRequest request = SecretsVault.Service.Videos.List("id");
|
||||
request.MaxResults = 48;
|
||||
|
||||
@@ -225,16 +195,18 @@ namespace FoxTube
|
||||
trendGrid.Add(vCard);
|
||||
}
|
||||
|
||||
trendLoading.Close();
|
||||
loading.Close();
|
||||
trendLoaded = true;
|
||||
}
|
||||
catch (System.Net.Http.HttpRequestException)
|
||||
{
|
||||
trendLoading.Error("System.Net.Http.HttpRequestException", "Unable to connect to Google servers.", true);
|
||||
trendLoaded = false;
|
||||
loading.Error("System.Net.Http.HttpRequestException", "Unable to connect to Google servers.", true);
|
||||
}
|
||||
catch
|
||||
catch(Exception e)
|
||||
{
|
||||
trendLoading.Error();
|
||||
trendLoaded = false;
|
||||
loading.Error(e.GetType().ToString(), e.Message);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -242,17 +214,22 @@ namespace FoxTube
|
||||
{
|
||||
try
|
||||
{
|
||||
recLoading.Close();
|
||||
loading.Refresh();
|
||||
|
||||
throw new NotImplementedException();
|
||||
|
||||
loading.Close();
|
||||
recLoaded = true;
|
||||
recLoading.Block();
|
||||
}
|
||||
catch (System.Net.Http.HttpRequestException)
|
||||
{
|
||||
recLoading.Error("System.Net.Http.HttpRequestException", "Unable to connect to Google servers.", true);
|
||||
recLoaded = false;
|
||||
loading.Error("System.Net.Http.HttpRequestException", "Unable to connect to Google servers.", true);
|
||||
}
|
||||
catch
|
||||
catch (Exception e)
|
||||
{
|
||||
recLoading.Error();
|
||||
recLoaded = false;
|
||||
loading.Error(e.GetType().ToString(), e.Message);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -260,10 +237,11 @@ namespace FoxTube
|
||||
{
|
||||
try
|
||||
{
|
||||
loading.Refresh();
|
||||
List<SearchResult> items = new List<SearchResult>();
|
||||
SearchResource.ListRequest request = SecretsVault.Service.Search.List("snippet");
|
||||
request.Type = "video";
|
||||
request.MaxResults = 20;
|
||||
request.MaxResults = 10;
|
||||
request.Order = SearchResource.ListRequest.OrderEnum.Date;
|
||||
|
||||
foreach (Subscription i in SecretsVault.Subscriptions)
|
||||
@@ -272,23 +250,29 @@ namespace FoxTube
|
||||
SearchListResponse response = await request.ExecuteAsync();
|
||||
foreach (SearchResult result in response.Items)
|
||||
items.Add(result);
|
||||
if (response.NextPageToken != null)
|
||||
subsTokens.Add(i.Snippet.ResourceId.ChannelId, response.NextPageToken);
|
||||
}
|
||||
subsMore.Complete(true);
|
||||
|
||||
items.OrderBy(x => x.Snippet.PublishedAt.Value);
|
||||
if (subsTokens.Count == 0)
|
||||
subsMore.Complete(true);
|
||||
|
||||
items = items.OrderByDescending(x => x.Snippet.PublishedAt).ToList();
|
||||
|
||||
foreach (SearchResult i in items)
|
||||
subsGrid.Add(new VideoCard(i.Id.VideoId));
|
||||
|
||||
subsLoading.Close();
|
||||
loading.Close();
|
||||
subsLoaded = true;
|
||||
}
|
||||
catch (System.Net.Http.HttpRequestException)
|
||||
{
|
||||
subsLoading.Error("System.Net.Http.HttpRequestException", "Unable to connect to Google servers.", true);
|
||||
subsLoaded = false;
|
||||
loading.Error("System.Net.Http.HttpRequestException", "Unable to connect to Google servers.", true);
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
subsLoading.Error(e.ToString(), e.Message);
|
||||
subsLoaded = false;
|
||||
loading.Error(e.GetType().ToString(), e.Message);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user