commit 569c0a733fe90d0163278648951dd1c176a67fe5 Author: Tsanie Date: Thu Aug 5 16:19:53 2021 +0800 initial commit diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..0621f7a --- /dev/null +++ b/.gitignore @@ -0,0 +1,407 @@ +Ref/*.snk + +# globs +Makefile.in +*.userprefs +*.usertasks +config.make +config.status +aclocal.m4 +install-sh +autom4te.cache/ +*.tar.gz +tarballs/ +test-results/ + +# Mac bundle stuff +*.dmg +*.app + +# content below from: https://github.com/github/gitignore/blob/main/Global/macOS.gitignore +# General +.DS_Store +.AppleDouble +.LSOverride + +# Icon must end with two \r +Icon + + +# Thumbnails +._* + +# Files that might appear in the root of a volume +.DocumentRevisions-V100 +.fseventsd +.Spotlight-V100 +.TemporaryItems +.Trashes +.VolumeIcon.icns +.com.apple.timemachine.donotpresent + +# Directories potentially created on remote AFP share +.AppleDB +.AppleDesktop +Network Trash Folder +Temporary Items +.apdisk + +# content below from: https://github.com/github/gitignore/blob/main/Global/Windows.gitignore +# Windows thumbnail cache files +Thumbs.db +ehthumbs.db +ehthumbs_vista.db + +# Dump file +*.stackdump + +# Folder config file +[Dd]esktop.ini + +# Recycle Bin used on file shares +$RECYCLE.BIN/ + +# Windows Installer files +*.cab +*.msi +*.msix +*.msm +*.msp + +# Windows shortcuts +*.lnk + +# content below from: https://github.com/github/gitignore/blob/master/VisualStudio.gitignore +## Ignore Visual Studio temporary files, build results, and +## files generated by popular Visual Studio add-ons. +## +## Get latest from https://github.com/github/gitignore/blob/master/VisualStudio.gitignore + +# User-specific files +*.suo +*.user +*.userosscache +*.sln.docstates + +# User-specific files (MonoDevelop/Xamarin Studio) +*.userprefs + +# Build results +[Dd]ebug/ +[Dd]ebugPublic/ +[Rr]elease/ +[Rr]eleases/ +x64/ +x86/ +bld/ +[Bb]in/ +[Oo]bj/ +[Ll]og/ + +# Visual Studio 2015/2017 cache/options directory +.vs/ +# Uncomment if you have tasks that create the project's static files in wwwroot +#wwwroot/ + +# Visual Studio 2017 auto generated files +Generated\ Files/ + +# MSTest test Results +[Tt]est[Rr]esult*/ +[Bb]uild[Ll]og.* + +# NUNIT +*.VisualState.xml +TestResult.xml + +# Build Results of an ATL Project +[Dd]ebugPS/ +[Rr]eleasePS/ +dlldata.c + +# Benchmark Results +BenchmarkDotNet.Artifacts/ + +# .NET Core +project.lock.json +project.fragment.lock.json +artifacts/ + +# StyleCop +StyleCopReport.xml + +# Files built by Visual Studio +*_i.c +*_p.c +*_h.h +*.ilk +*.meta +*.obj +*.iobj +*.pch +*.pdb +*.ipdb +*.pgc +*.pgd +*.rsp +*.sbr +*.tlb +*.tli +*.tlh +*.tmp +*.tmp_proj +*_wpftmp.csproj +*.log +*.vspscc +*.vssscc +.builds +*.pidb +*.svclog +*.scc + +# Chutzpah Test files +_Chutzpah* + +# Visual C++ cache files +ipch/ +*.aps +*.ncb +*.opendb +*.opensdf +*.sdf +*.cachefile +*.VC.db +*.VC.VC.opendb + +# Visual Studio profiler +*.psess +*.vsp +*.vspx +*.sap + +# Visual Studio Trace Files +*.e2e + +# TFS 2012 Local Workspace +$tf/ + +# Guidance Automation Toolkit +*.gpState + +# ReSharper is a .NET coding add-in +_ReSharper*/ +*.[Rr]e[Ss]harper +*.DotSettings.user + +# JustCode is a .NET coding add-in +.JustCode + +# TeamCity is a build add-in +_TeamCity* + +# DotCover is a Code Coverage Tool +*.dotCover + +# AxoCover is a Code Coverage Tool +.axoCover/* +!.axoCover/settings.json + +# Visual Studio code coverage results +*.coverage +*.coveragexml + +# NCrunch +_NCrunch_* +.*crunch*.local.xml +nCrunchTemp_* + +# MightyMoose +*.mm.* +AutoTest.Net/ + +# Web workbench (sass) +.sass-cache/ + +# Installshield output folder +[Ee]xpress/ + +# DocProject is a documentation generator add-in +DocProject/buildhelp/ +DocProject/Help/*.HxT +DocProject/Help/*.HxC +DocProject/Help/*.hhc +DocProject/Help/*.hhk +DocProject/Help/*.hhp +DocProject/Help/Html2 +DocProject/Help/html + +# Click-Once directory +publish/ + +# Publish Web Output +*.[Pp]ublish.xml +*.azurePubxml +# Note: Comment the next line if you want to checkin your web deploy settings, +# but database connection strings (with potential passwords) will be unencrypted +*.pubxml +*.publishproj + +# Microsoft Azure Web App publish settings. Comment the next line if you want to +# checkin your Azure Web App publish settings, but sensitive information contained +# in these scripts will be unencrypted +PublishScripts/ + +# NuGet Packages +*.nupkg +# The packages folder can be ignored because of Package Restore +**/[Pp]ackages/* +# except build/, which is used as an MSBuild target. +!**/[Pp]ackages/build/ +# Uncomment if necessary however generally it will be regenerated when needed +#!**/[Pp]ackages/repositories.config +# NuGet v3's project.json files produces more ignorable files +*.nuget.props +*.nuget.targets + +# Microsoft Azure Build Output +csx/ +*.build.csdef + +# Microsoft Azure Emulator +ecf/ +rcf/ + +# Windows Store app package directories and files +AppPackages/ +BundleArtifacts/ +Package.StoreAssociation.xml +_pkginfo.txt +*.appx + +# Visual Studio cache files +# files ending in .cache can be ignored +*.[Cc]ache +# but keep track of directories ending in .cache +!*.[Cc]ache/ + +# Others +ClientBin/ +~$* +*~ +*.dbmdl +*.dbproj.schemaview +*.jfm +*.pfx +*.publishsettings +orleans.codegen.cs + +# Including strong name files can present a security risk +# (https://github.com/github/gitignore/pull/2483#issue-259490424) +#*.snk + +# Since there are multiple workflows, uncomment next line to ignore bower_components +# (https://github.com/github/gitignore/pull/1529#issuecomment-104372622) +#bower_components/ + +# RIA/Silverlight projects +Generated_Code/ + +# Backup & report files from converting an old project file +# to a newer Visual Studio version. Backup files are not needed, +# because we have git ;-) +_UpgradeReport_Files/ +Backup*/ +UpgradeLog*.XML +UpgradeLog*.htm +ServiceFabricBackup/ +*.rptproj.bak + +# SQL Server files +*.mdf +*.ldf +*.ndf + +# Business Intelligence projects +*.rdl.data +*.bim.layout +*.bim_*.settings +*.rptproj.rsuser + +# Microsoft Fakes +FakesAssemblies/ + +# GhostDoc plugin setting file +*.GhostDoc.xml + +# Node.js Tools for Visual Studio +.ntvs_analysis.dat +node_modules/ + +# Visual Studio 6 build log +*.plg + +# Visual Studio 6 workspace options file +*.opt + +# Visual Studio 6 auto-generated workspace file (contains which files were open etc.) +*.vbw + +# Visual Studio LightSwitch build output +**/*.HTMLClient/GeneratedArtifacts +**/*.DesktopClient/GeneratedArtifacts +**/*.DesktopClient/ModelManifest.xml +**/*.Server/GeneratedArtifacts +**/*.Server/ModelManifest.xml +_Pvt_Extensions + +# Paket dependency manager +.paket/paket.exe +paket-files/ + +# FAKE - F# Make +.fake/ + +# JetBrains Rider +.idea/ +*.sln.iml + +# CodeRush personal settings +.cr/personal + +# Python Tools for Visual Studio (PTVS) +__pycache__/ +*.pyc + +# Cake - Uncomment if you are using it +# tools/** +# !tools/packages.config + +# Tabs Studio +*.tss + +# Telerik's JustMock configuration file +*.jmconfig + +# BizTalk build output +*.btp.cs +*.btm.cs +*.odx.cs +*.xsd.cs + +# OpenCover UI analysis results +OpenCover/ + +# Azure Stream Analytics local run output +ASALocalRun/ + +# MSBuild Binary and Structured Log +*.binlog + +# NVidia Nsight GPU debugger configuration file +*.nvuser + +# MFractors (Xamarin productivity tool) working folder +.mfractor/ + +# Local History for Visual Studio +.localhistory/ diff --git a/Gallery.Share/App.xaml b/Gallery.Share/App.xaml new file mode 100644 index 0000000..941638c --- /dev/null +++ b/Gallery.Share/App.xaml @@ -0,0 +1,32 @@ + + + + + + #2196F3 + + + + diff --git a/Gallery.Share/App.xaml.cs b/Gallery.Share/App.xaml.cs new file mode 100644 index 0000000..02e8a23 --- /dev/null +++ b/Gallery.Share/App.xaml.cs @@ -0,0 +1,32 @@ +using System; +using Xamarin.Forms; +using Xamarin.Forms.Xaml; +using Gallery.Services; +using Gallery.Views; + +namespace Gallery +{ + public partial class App : Application + { + + public App() + { + InitializeComponent(); + + DependencyService.Register(); + MainPage = new AppShell(); + } + + protected override void OnStart() + { + } + + protected override void OnSleep() + { + } + + protected override void OnResume() + { + } + } +} diff --git a/Gallery.Share/AppShell.xaml b/Gallery.Share/AppShell.xaml new file mode 100644 index 0000000..234c874 --- /dev/null +++ b/Gallery.Share/AppShell.xaml @@ -0,0 +1,136 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/Gallery.Share/AppShell.xaml.cs b/Gallery.Share/AppShell.xaml.cs new file mode 100644 index 0000000..9f74589 --- /dev/null +++ b/Gallery.Share/AppShell.xaml.cs @@ -0,0 +1,23 @@ +using System; +using System.Collections.Generic; +using Gallery.ViewModels; +using Gallery.Views; +using Xamarin.Forms; + +namespace Gallery +{ + public partial class AppShell : Xamarin.Forms.Shell + { + public AppShell() + { + InitializeComponent(); + Routing.RegisterRoute(nameof(ItemDetailPage), typeof(ItemDetailPage)); + Routing.RegisterRoute(nameof(NewItemPage), typeof(NewItemPage)); + } + + private async void OnMenuItemClicked(object sender, EventArgs e) + { + await Shell.Current.GoToAsync("//LoginPage"); + } + } +} diff --git a/Gallery.Share/Gallery.Share.projitems b/Gallery.Share/Gallery.Share.projitems new file mode 100644 index 0000000..98455b0 --- /dev/null +++ b/Gallery.Share/Gallery.Share.projitems @@ -0,0 +1,79 @@ + + + + $(MSBuildAllProjects);$(MSBuildThisFileFullPath) + true + {E72B5C40-090B-4A1C-9170-BD33C14A9A91} + + + Gallery.Share + + + + + + + + + + + + + Views\AboutPage.xaml + + + Views\ItemDetailPage.xaml + + + Views\ItemsPage.xaml + + + Views\LoginPage.xaml + + + Views\NewItemPage.xaml + + + App.xaml + + + AppShell.xaml + + + + + + + + + + + Designer + MSBuild:UpdateDesignTimeXaml + + + Designer + MSBuild:UpdateDesignTimeXaml + + + Designer + MSBuild:UpdateDesignTimeXaml + + + Designer + MSBuild:UpdateDesignTimeXaml + + + Designer + MSBuild:UpdateDesignTimeXaml + + + Designer + MSBuild:UpdateDesignTimeXaml + + + Designer + MSBuild:UpdateDesignTimeXaml + + + \ No newline at end of file diff --git a/Gallery.Share/Gallery.Share.shproj b/Gallery.Share/Gallery.Share.shproj new file mode 100644 index 0000000..fa3bb4a --- /dev/null +++ b/Gallery.Share/Gallery.Share.shproj @@ -0,0 +1,11 @@ + + + + {E72B5C40-090B-4A1C-9170-BD33C14A9A91} + + + + + + + \ No newline at end of file diff --git a/Gallery.Share/GettingStarted.txt b/Gallery.Share/GettingStarted.txt new file mode 100644 index 0000000..fb4d8be --- /dev/null +++ b/Gallery.Share/GettingStarted.txt @@ -0,0 +1,34 @@ +Welcome to Xamarin.Forms! Here are some tips to get started building your app. + +Building Your App UI +-------------------- + +XAML Hot Reload quickly applies UI changes as you make them to your running app. +This is the most productive way to preview and iteratively create your UI. + +Try it out: + +1. Run the app by clicking the Start Debugging (play) button in the above toolbar. +2. Open \Views\AboutPage.xaml. + Don't stop the app - keep it running while making changes. +3. Change something! Hint: change the Accent color on line 14 from "#96d1ff" to "Pink". +4. Watch the About screen update on the device or emulator, with the logo background now pink. + +Keep going and try more changes! + +QuickStart Guide +---------------- + +Learn more of the fundamentals for building apps with Xamarin here: https://aka.ms/xamarin-quickstart + +Your App Shell +-------------- + +This template uses Shell, an app container that reduces the complexity of your apps by providing fundamental features including: + +- A single place to describe the app's visual hierarchy. +- Common navigation such as a flyout menu and tabs. +- A URI-based navigation scheme that permits navigation to any page in the application. +- An integrated search handler. + +Open AppShell.xaml to begin exploring. To learn more about Shell visit: https://docs.microsoft.com/xamarin/xamarin-forms/app-fundamentals/shell/introduction diff --git a/Gallery.Share/Models/Item.cs b/Gallery.Share/Models/Item.cs new file mode 100644 index 0000000..098c8e8 --- /dev/null +++ b/Gallery.Share/Models/Item.cs @@ -0,0 +1,11 @@ +using System; + +namespace Gallery.Models +{ + public class Item + { + public string Id { get; set; } + public string Text { get; set; } + public string Description { get; set; } + } +} diff --git a/Gallery.Share/Services/IDataStore.cs b/Gallery.Share/Services/IDataStore.cs new file mode 100644 index 0000000..efed17d --- /dev/null +++ b/Gallery.Share/Services/IDataStore.cs @@ -0,0 +1,15 @@ +using System; +using System.Collections.Generic; +using System.Threading.Tasks; + +namespace Gallery.Services +{ + public interface IDataStore + { + Task AddItemAsync(T item); + Task UpdateItemAsync(T item); + Task DeleteItemAsync(string id); + Task GetItemAsync(string id); + Task> GetItemsAsync(bool forceRefresh = false); + } +} diff --git a/Gallery.Share/Services/MockDataStore.cs b/Gallery.Share/Services/MockDataStore.cs new file mode 100644 index 0000000..fc5ca91 --- /dev/null +++ b/Gallery.Share/Services/MockDataStore.cs @@ -0,0 +1,60 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Threading.Tasks; +using Gallery.Models; + +namespace Gallery.Services +{ + public class MockDataStore : IDataStore + { + readonly List items; + + public MockDataStore() + { + items = new List() + { + new Item { Id = Guid.NewGuid().ToString(), Text = "First item", Description="This is an item description." }, + new Item { Id = Guid.NewGuid().ToString(), Text = "Second item", Description="This is an item description." }, + new Item { Id = Guid.NewGuid().ToString(), Text = "Third item", Description="This is an item description." }, + new Item { Id = Guid.NewGuid().ToString(), Text = "Fourth item", Description="This is an item description." }, + new Item { Id = Guid.NewGuid().ToString(), Text = "Fifth item", Description="This is an item description." }, + new Item { Id = Guid.NewGuid().ToString(), Text = "Sixth item", Description="This is an item description." } + }; + } + + public async Task AddItemAsync(Item item) + { + items.Add(item); + + return await Task.FromResult(true); + } + + public async Task UpdateItemAsync(Item item) + { + var oldItem = items.Where((Item arg) => arg.Id == item.Id).FirstOrDefault(); + items.Remove(oldItem); + items.Add(item); + + return await Task.FromResult(true); + } + + public async Task DeleteItemAsync(string id) + { + var oldItem = items.Where((Item arg) => arg.Id == id).FirstOrDefault(); + items.Remove(oldItem); + + return await Task.FromResult(true); + } + + public async Task GetItemAsync(string id) + { + return await Task.FromResult(items.FirstOrDefault(s => s.Id == id)); + } + + public async Task> GetItemsAsync(bool forceRefresh = false) + { + return await Task.FromResult(items); + } + } +} diff --git a/Gallery.Share/ViewModels/AboutViewModel.cs b/Gallery.Share/ViewModels/AboutViewModel.cs new file mode 100644 index 0000000..1fa890d --- /dev/null +++ b/Gallery.Share/ViewModels/AboutViewModel.cs @@ -0,0 +1,18 @@ +using System; +using System.Windows.Input; +using Xamarin.Essentials; +using Xamarin.Forms; + +namespace Gallery.ViewModels +{ + public class AboutViewModel : BaseViewModel + { + public AboutViewModel() + { + Title = "About"; + OpenWebCommand = new Command(async () => await Browser.OpenAsync("https://aka.ms/xamarin-quickstart")); + } + + public ICommand OpenWebCommand { get; } + } +} diff --git a/Gallery.Share/ViewModels/BaseViewModel.cs b/Gallery.Share/ViewModels/BaseViewModel.cs new file mode 100644 index 0000000..04c6118 --- /dev/null +++ b/Gallery.Share/ViewModels/BaseViewModel.cs @@ -0,0 +1,56 @@ +using System; +using System.Collections.Generic; +using System.ComponentModel; +using System.Runtime.CompilerServices; + +using Xamarin.Forms; + +using Gallery.Models; +using Gallery.Services; + +namespace Gallery.ViewModels +{ + public class BaseViewModel : INotifyPropertyChanged + { + public IDataStore DataStore => DependencyService.Get>(); + + bool isBusy = false; + public bool IsBusy + { + get { return isBusy; } + set { SetProperty(ref isBusy, value); } + } + + string title = string.Empty; + public string Title + { + get { return title; } + set { SetProperty(ref title, value); } + } + + protected bool SetProperty(ref T backingStore, T value, + [CallerMemberName] string propertyName = "", + Action onChanged = null) + { + if (EqualityComparer.Default.Equals(backingStore, value)) + return false; + + backingStore = value; + onChanged?.Invoke(); + OnPropertyChanged(propertyName); + return true; + } + + #region INotifyPropertyChanged + public event PropertyChangedEventHandler PropertyChanged; + protected void OnPropertyChanged([CallerMemberName] string propertyName = "") + { + var changed = PropertyChanged; + if (changed == null) + return; + + changed.Invoke(this, new PropertyChangedEventArgs(propertyName)); + } + #endregion + } +} diff --git a/Gallery.Share/ViewModels/ItemDetailViewModel.cs b/Gallery.Share/ViewModels/ItemDetailViewModel.cs new file mode 100644 index 0000000..e4c7236 --- /dev/null +++ b/Gallery.Share/ViewModels/ItemDetailViewModel.cs @@ -0,0 +1,57 @@ +using System; +using System.Diagnostics; +using System.Threading.Tasks; +using Gallery.Models; +using Xamarin.Forms; + +namespace Gallery.ViewModels +{ + [QueryProperty(nameof(ItemId), nameof(ItemId))] + public class ItemDetailViewModel : BaseViewModel + { + private string itemId; + private string text; + private string description; + public string Id { get; set; } + + public string Text + { + get => text; + set => SetProperty(ref text, value); + } + + public string Description + { + get => description; + set => SetProperty(ref description, value); + } + + public string ItemId + { + get + { + return itemId; + } + set + { + itemId = value; + LoadItemId(value); + } + } + + public async void LoadItemId(string itemId) + { + try + { + var item = await DataStore.GetItemAsync(itemId); + Id = item.Id; + Text = item.Text; + Description = item.Description; + } + catch (Exception) + { + Debug.WriteLine("Failed to Load Item"); + } + } + } +} diff --git a/Gallery.Share/ViewModels/ItemsViewModel.cs b/Gallery.Share/ViewModels/ItemsViewModel.cs new file mode 100644 index 0000000..8ae6361 --- /dev/null +++ b/Gallery.Share/ViewModels/ItemsViewModel.cs @@ -0,0 +1,86 @@ +using System; +using System.Collections.ObjectModel; +using System.Diagnostics; +using System.Threading.Tasks; + +using Xamarin.Forms; + +using Gallery.Models; +using Gallery.Views; + +namespace Gallery.ViewModels +{ + public class ItemsViewModel : BaseViewModel + { + private Item _selectedItem; + + public ObservableCollection Items { get; } + public Command LoadItemsCommand { get; } + public Command AddItemCommand { get; } + public Command ItemTapped { get; } + + public ItemsViewModel() + { + Title = "Browse"; + Items = new ObservableCollection(); + LoadItemsCommand = new Command(async () => await ExecuteLoadItemsCommand()); + + ItemTapped = new Command(OnItemSelected); + + AddItemCommand = new Command(OnAddItem); + } + + async Task ExecuteLoadItemsCommand() + { + IsBusy = true; + + try + { + Items.Clear(); + var items = await DataStore.GetItemsAsync(true); + foreach (var item in items) + { + Items.Add(item); + } + } + catch (Exception ex) + { + Debug.WriteLine(ex); + } + finally + { + IsBusy = false; + } + } + + public void OnAppearing() + { + IsBusy = true; + SelectedItem = null; + } + + public Item SelectedItem + { + get => _selectedItem; + set + { + SetProperty(ref _selectedItem, value); + OnItemSelected(value); + } + } + + private async void OnAddItem(object obj) + { + await Shell.Current.GoToAsync(nameof(NewItemPage)); + } + + async void OnItemSelected(Item item) + { + if (item == null) + return; + + // This will push the ItemDetailPage onto the navigation stack + await Shell.Current.GoToAsync($"{nameof(ItemDetailPage)}?{nameof(ItemDetailViewModel.ItemId)}={item.Id}"); + } + } +} diff --git a/Gallery.Share/ViewModels/LoginViewModel.cs b/Gallery.Share/ViewModels/LoginViewModel.cs new file mode 100644 index 0000000..1aa8796 --- /dev/null +++ b/Gallery.Share/ViewModels/LoginViewModel.cs @@ -0,0 +1,24 @@ +using Gallery.Views; +using System; +using System.Collections.Generic; +using System.Text; +using Xamarin.Forms; + +namespace Gallery.ViewModels +{ + public class LoginViewModel : BaseViewModel + { + public Command LoginCommand { get; } + + public LoginViewModel() + { + LoginCommand = new Command(OnLoginClicked); + } + + private async void OnLoginClicked(object obj) + { + // Prefixing with `//` switches to a different navigation stack instead of pushing to the active one + await Shell.Current.GoToAsync($"//{nameof(AboutPage)}"); + } + } +} diff --git a/Gallery.Share/ViewModels/NewItemViewModel.cs b/Gallery.Share/ViewModels/NewItemViewModel.cs new file mode 100644 index 0000000..6ba6069 --- /dev/null +++ b/Gallery.Share/ViewModels/NewItemViewModel.cs @@ -0,0 +1,65 @@ +using System; +using System.Collections.Generic; +using System.Text; +using System.Windows.Input; +using Gallery.Models; +using Xamarin.Forms; + +namespace Gallery.ViewModels +{ + public class NewItemViewModel : BaseViewModel + { + private string text; + private string description; + + public NewItemViewModel() + { + SaveCommand = new Command(OnSave, ValidateSave); + CancelCommand = new Command(OnCancel); + this.PropertyChanged += + (_, __) => SaveCommand.ChangeCanExecute(); + } + + private bool ValidateSave() + { + return !String.IsNullOrWhiteSpace(text) + && !String.IsNullOrWhiteSpace(description); + } + + public string Text + { + get => text; + set => SetProperty(ref text, value); + } + + public string Description + { + get => description; + set => SetProperty(ref description, value); + } + + public Command SaveCommand { get; } + public Command CancelCommand { get; } + + private async void OnCancel() + { + // This will pop the current page off the navigation stack + await Shell.Current.GoToAsync(".."); + } + + private async void OnSave() + { + Item newItem = new Item() + { + Id = Guid.NewGuid().ToString(), + Text = Text, + Description = Description + }; + + await DataStore.AddItemAsync(newItem); + + // This will pop the current page off the navigation stack + await Shell.Current.GoToAsync(".."); + } + } +} diff --git a/Gallery.Share/Views/AboutPage.xaml b/Gallery.Share/Views/AboutPage.xaml new file mode 100644 index 0000000..9293563 --- /dev/null +++ b/Gallery.Share/Views/AboutPage.xaml @@ -0,0 +1,52 @@ + + + + + + + + + + #96d1ff + + + + + + + + + + + + + + + + + + + + + + diff --git a/Gallery.Share/Views/NewItemPage.xaml.cs b/Gallery.Share/Views/NewItemPage.xaml.cs new file mode 100644 index 0000000..fff2546 --- /dev/null +++ b/Gallery.Share/Views/NewItemPage.xaml.cs @@ -0,0 +1,22 @@ +using System; +using System.Collections.Generic; +using System.ComponentModel; +using Xamarin.Forms; +using Xamarin.Forms.Xaml; + +using Gallery.Models; +using Gallery.ViewModels; + +namespace Gallery.Views +{ + public partial class NewItemPage : ContentPage + { + public Item Item { get; set; } + + public NewItemPage() + { + InitializeComponent(); + BindingContext = new NewItemViewModel(); + } + } +} diff --git a/Gallery.Util/Converter.cs b/Gallery.Util/Converter.cs new file mode 100644 index 0000000..b3fee07 --- /dev/null +++ b/Gallery.Util/Converter.cs @@ -0,0 +1,95 @@ +using System; +using System.Collections.Generic; +using System.Text.Json; +using System.Text.Json.Serialization; +using Gallery.Util.Model; + +namespace Gallery.Util +{ + public class GalleryItemConverter : JsonConverter + { + public override GalleryItem Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options) + { + reader.Read(); + if (reader.TokenType != JsonTokenType.StartObject) + { + return null; + } + var item = new GalleryItem(); + while (reader.Read()) + { + if (reader.TokenType == JsonTokenType.PropertyName) + { + var name = reader.GetString(); + reader.Read(); + switch (name) + { + case nameof(GalleryItem.Id): item.Id = reader.GetInt64(); break; + case nameof(GalleryItem.Tags): + if (reader.TokenType == JsonTokenType.StartArray) + { + var tags = new List(); + while (reader.Read()) + { + if (reader.TokenType == JsonTokenType.EndArray) + { + break; + } + if (reader.TokenType == JsonTokenType.String) + { + tags.Add(reader.GetString()); + } + } + item.Tags = tags.ToArray(); + } + break; + case nameof(GalleryItem.CreatedTime): item.CreatedTime = reader.GetDateTime(); break; + case nameof(GalleryItem.UpdatedTime): item.UpdatedTime = reader.GetDateTime(); break; + case nameof(GalleryItem.UserId): item.UserId = reader.GetString(); break; + case nameof(GalleryItem.UserName): item.UserName = reader.GetString(); break; + case nameof(GalleryItem.Source): item.Source = reader.GetString(); break; + case nameof(GalleryItem.PreviewUrl): item.PreviewUrl = reader.GetString(); break; + case nameof(GalleryItem.RawUrl): item.RawUrl = reader.GetString(); break; + case nameof(GalleryItem.Width): item.Width = reader.GetInt32(); break; + case nameof(GalleryItem.Height): item.Height = reader.GetInt32(); break; + } + } + } + return item; + } + + public override void Write(Utf8JsonWriter writer, GalleryItem value, JsonSerializerOptions options) + { + if (value == null) + { + writer.WriteNullValue(); + return; + } + + writer.WriteStartObject(); + + writer.WriteNumber(nameof(GalleryItem.Id), value.Id); + if (value.Tags != null) + { + writer.WritePropertyName(nameof(GalleryItem.Tags)); + writer.WriteStartArray(); + for (var i = 0; i < value.Tags.Length; i++) + { + writer.WriteStringValue(value.Tags[i]); + } + writer.WriteEndArray(); + } + writer.WriteString(nameof(GalleryItem.CreatedTime), value.CreatedTime); + writer.WriteString(nameof(GalleryItem.UpdatedTime), value.UpdatedTime); + writer.WriteString(nameof(GalleryItem.UserId), value.UserId); + writer.WriteString(nameof(GalleryItem.UserName), value.UserName); + writer.WriteString(nameof(GalleryItem.Source), value.Source); + writer.WriteString(nameof(GalleryItem.PreviewUrl), value.PreviewUrl); + writer.WriteString(nameof(GalleryItem.RawUrl), value.RawUrl); + writer.WriteNumber(nameof(GalleryItem.Width), value.Width); + writer.WriteNumber(nameof(GalleryItem.Height), value.Height); + + writer.WriteEndObject(); + } + } +} diff --git a/Gallery.Util/Gallery.Util.csproj b/Gallery.Util/Gallery.Util.csproj new file mode 100644 index 0000000..36828e1 --- /dev/null +++ b/Gallery.Util/Gallery.Util.csproj @@ -0,0 +1,23 @@ + + + + netstandard2.1 + true + ..\Ref\Tsanie.snk + + + + + + + + + + + + + + + + + diff --git a/Gallery.Util/Interface/IGallerySource.cs b/Gallery.Util/Interface/IGallerySource.cs new file mode 100644 index 0000000..d244359 --- /dev/null +++ b/Gallery.Util/Interface/IGallerySource.cs @@ -0,0 +1,11 @@ +using Gallery.Util.Model; + +namespace Gallery.Util.Interface +{ + public interface IGallerySource + { + string GetCookie(); + + GalleryItem[] GetRecentItems(int page); + } +} diff --git a/Gallery.Util/Model/GalleryItem.cs b/Gallery.Util/Model/GalleryItem.cs new file mode 100644 index 0000000..e8c9aaf --- /dev/null +++ b/Gallery.Util/Model/GalleryItem.cs @@ -0,0 +1,79 @@ +using System; +using System.Text.Json.Serialization; +using Xamarin.Forms; + +namespace Gallery.Util.Model +{ + [JsonConverter(typeof(GalleryItemConverter))] + public class GalleryItem : BindableObject + { + const double PREVIEW_WIDTH = 200.0; + + public static readonly BindableProperty TagDescriptionProperty = BindableProperty.Create(nameof(TagDescription), typeof(string), typeof(GalleryItem)); + public static readonly BindableProperty PreviewImageProperty = BindableProperty.Create(nameof(PreviewImage), typeof(ImageSource), typeof(GalleryItem)); + public static readonly BindableProperty UserNameProperty = BindableProperty.Create(nameof(UserName), typeof(string), typeof(GalleryItem)); + public static readonly BindableProperty CreatedTimeProperty = BindableProperty.Create(nameof(CreatedTime), typeof(DateTime), typeof(GalleryItem)); + public static readonly BindableProperty UpdatedTimeProperty = BindableProperty.Create(nameof(UpdatedTime), typeof(DateTime), typeof(GalleryItem)); + public static readonly BindableProperty ImageHeightProperty = BindableProperty.Create(nameof(ImageHeight), typeof(GridLength), typeof(GalleryItem), GridLength.Auto); + + [JsonIgnore] + public string TagDescription { get; set; } + [JsonIgnore] + public ImageSource PreviewImage { get; set; } + [JsonIgnore] + public GridLength ImageHeight { get; set; } + + public long Id { get; internal set; } + private string[] tags; + public string[] Tags + { + get => tags; + set + { + tags = value; + if (value != null) + { + TagDescription = string.Join(' ', tags); + } + else + { + TagDescription = null; + } + } + } + public DateTime CreatedTime { get; set; } + public DateTime UpdatedTime { get; set; } + public string UserId { get; set; } + public string UserName { get; set; } + public string Source { get; set; } + public string PreviewUrl { get; set; } + public string RawUrl { get; set; } + + private int width; + private int height; + public int Width + { + get => width; + set + { + width = value; + if (width > 0 && height > 0) + { + ImageHeight = new GridLength(PREVIEW_WIDTH * height / width); + } + } + } + public int Height + { + get => height; + set + { + height = value; + if (width > 0 && height > 0) + { + ImageHeight = new GridLength(PREVIEW_WIDTH * height / width); + } + } + } + } +} diff --git a/Gallery.iOS/AppDelegate.cs b/Gallery.iOS/AppDelegate.cs new file mode 100644 index 0000000..0fce5b6 --- /dev/null +++ b/Gallery.iOS/AppDelegate.cs @@ -0,0 +1,27 @@ +using Foundation; +using UIKit; + +namespace Gallery.iOS +{ + // The UIApplicationDelegate for the application. This class is responsible for launching the + // User Interface of the application, as well as listening (and optionally responding) to + // application events from iOS. + [Register("AppDelegate")] + public partial class AppDelegate : Xamarin.Forms.Platform.iOS.FormsApplicationDelegate + { + // + // This method is invoked when the application has loaded and is ready to run. In this + // method you should instantiate the window, load the UI into it and then make the window + // visible. + // + // You have 17 seconds to return from this method, or iOS will terminate your application. + // + public override bool FinishedLaunching(UIApplication app, NSDictionary options) + { + Xamarin.Forms.Forms.Init(); + LoadApplication(new App()); + + return base.FinishedLaunching(app, options); + } + } +} diff --git a/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Contents.json b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Contents.json new file mode 100644 index 0000000..fc9d330 --- /dev/null +++ b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Contents.json @@ -0,0 +1,117 @@ +{ + "images": [ + { + "scale": "2x", + "size": "20x20", + "idiom": "iphone", + "filename": "Icon40.png" + }, + { + "scale": "3x", + "size": "20x20", + "idiom": "iphone", + "filename": "Icon60.png" + }, + { + "scale": "2x", + "size": "29x29", + "idiom": "iphone", + "filename": "Icon58.png" + }, + { + "scale": "3x", + "size": "29x29", + "idiom": "iphone", + "filename": "Icon87.png" + }, + { + "scale": "2x", + "size": "40x40", + "idiom": "iphone", + "filename": "Icon80.png" + }, + { + "scale": "3x", + "size": "40x40", + "idiom": "iphone", + "filename": "Icon120.png" + }, + { + "scale": "2x", + "size": "60x60", + "idiom": "iphone", + "filename": "Icon120.png" + }, + { + "scale": "3x", + "size": "60x60", + "idiom": "iphone", + "filename": "Icon180.png" + }, + { + "scale": "1x", + "size": "20x20", + "idiom": "ipad", + "filename": "Icon20.png" + }, + { + "scale": "2x", + "size": "20x20", + "idiom": "ipad", + "filename": "Icon40.png" + }, + { + "scale": "1x", + "size": "29x29", + "idiom": "ipad", + "filename": "Icon29.png" + }, + { + "scale": "2x", + "size": "29x29", + "idiom": "ipad", + "filename": "Icon58.png" + }, + { + "scale": "1x", + "size": "40x40", + "idiom": "ipad", + "filename": "Icon40.png" + }, + { + "scale": "2x", + "size": "40x40", + "idiom": "ipad", + "filename": "Icon80.png" + }, + { + "scale": "1x", + "size": "76x76", + "idiom": "ipad", + "filename": "Icon76.png" + }, + { + "scale": "2x", + "size": "76x76", + "idiom": "ipad", + "filename": "Icon152.png" + }, + { + "scale": "2x", + "size": "83.5x83.5", + "idiom": "ipad", + "filename": "Icon167.png" + }, + { + "scale": "1x", + "size": "1024x1024", + "idiom": "ios-marketing", + "filename": "Icon1024.png" + } + ], + "properties": {}, + "info": { + "version": 1, + "author": "xcode" + } +} diff --git a/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon1024.png b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon1024.png new file mode 100644 index 0000000..9174c98 Binary files /dev/null and b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon1024.png differ diff --git a/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon120.png b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon120.png new file mode 100644 index 0000000..9c60a17 Binary files /dev/null and b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon120.png differ diff --git a/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon152.png b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon152.png new file mode 100644 index 0000000..448d6ef Binary files /dev/null and b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon152.png differ diff --git a/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon167.png b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon167.png new file mode 100644 index 0000000..8524768 Binary files /dev/null and b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon167.png differ diff --git a/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon180.png b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon180.png new file mode 100644 index 0000000..60a6470 Binary files /dev/null and b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon180.png differ diff --git a/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon20.png b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon20.png new file mode 100644 index 0000000..45268a6 Binary files /dev/null and b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon20.png differ diff --git a/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon29.png b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon29.png new file mode 100644 index 0000000..6a6c77a Binary files /dev/null and b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon29.png differ diff --git a/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon40.png b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon40.png new file mode 100644 index 0000000..cc7edcf Binary files /dev/null and b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon40.png differ diff --git a/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon58.png b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon58.png new file mode 100644 index 0000000..1ad04f0 Binary files /dev/null and b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon58.png differ diff --git a/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon60.png b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon60.png new file mode 100644 index 0000000..2dd5262 Binary files /dev/null and b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon60.png differ diff --git a/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon76.png b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon76.png new file mode 100644 index 0000000..b058cae Binary files /dev/null and b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon76.png differ diff --git a/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon80.png b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon80.png new file mode 100644 index 0000000..02e47a2 Binary files /dev/null and b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon80.png differ diff --git a/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon87.png b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon87.png new file mode 100644 index 0000000..4954a4b Binary files /dev/null and b/Gallery.iOS/Assets.xcassets/AppIcon.appiconset/Icon87.png differ diff --git a/Gallery.iOS/Entitlements.plist b/Gallery.iOS/Entitlements.plist new file mode 100644 index 0000000..e9a3005 --- /dev/null +++ b/Gallery.iOS/Entitlements.plist @@ -0,0 +1,7 @@ + + + + + + + diff --git a/Gallery.iOS/Gallery.iOS.csproj b/Gallery.iOS/Gallery.iOS.csproj new file mode 100644 index 0000000..777271d --- /dev/null +++ b/Gallery.iOS/Gallery.iOS.csproj @@ -0,0 +1,157 @@ + + + + Debug + iPhoneSimulator + 8.0.30703 + 2.0 + {94E59D2C-9083-4BAB-9567-A0B0C4B4266D} + {FEACFBD2-3405-455C-9665-78FE426C6842};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC} + {89a4fe7c-635d-49c9-8d8c-5cd363c0d68d} + Exe + Gallery.iOS + Resources + Gallery.iOS + true + NSUrlSessionHandler + automatic + true + + + true + portable + false + bin\iPhoneSimulator\Debug + DEBUG + prompt + 4 + x86_64 + None + true + Gallery.Dev + Apple Development: Li Chen (5559SN7Z38) + + + none + true + bin\iPhoneSimulator\Release + prompt + 4 + None + x86_64 + Gallery.Ad-Hoc + Apple Distribution: Li Chen (7HSM5CKPJ2) + + + true + portable + false + bin\iPhone\Debug + DEBUG + prompt + 4 + ARM64 + Apple Development: Li Chen (5559SN7Z38) + true + Entitlements.plist + None + -all + Gallery.Dev + + + none + true + bin\iPhone\Release + prompt + 4 + ARM64 + Apple Distribution: Li Chen (7HSM5CKPJ2) + Entitlements.plist + Gallery.Ad-Hoc + SdkOnly + + + + + + + + + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + {222C22EC-3A47-4CF5-B9FB-CA28DE9F4BC8} + Gallery.Util + + + + + \ No newline at end of file diff --git a/Gallery.iOS/Info.plist b/Gallery.iOS/Info.plist new file mode 100644 index 0000000..8be52aa --- /dev/null +++ b/Gallery.iOS/Info.plist @@ -0,0 +1,52 @@ + + + + + UIDeviceFamily + + 1 + 2 + + UISupportedInterfaceOrientations + + UIInterfaceOrientationPortrait + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + UISupportedInterfaceOrientations~ipad + + UIInterfaceOrientationPortrait + UIInterfaceOrientationPortraitUpsideDown + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + MinimumOSVersion + 13.0 + CFBundleDisplayName + Gallery + CFBundleIdentifier + org.tsanie.gallery + UILaunchStoryboardName + LaunchScreen + CFBundleName + Gallery + XSAppIconAssets + Assets.xcassets/AppIcon.appiconset + CFBundleShortVersionString + 1.0.805 + CFBundleVersion + 1 + UIAppFonts + + fa-light-300.ttf + fa-regular-400.ttf + fa-solid-900.ttf + + UIViewControllerBasedStatusBarAppearance + + UIStatusBarStyle + UIStatusBarStyleDefault + CFBundleDevelopmentRegion + China + + diff --git a/Gallery.iOS/Main.cs b/Gallery.iOS/Main.cs new file mode 100644 index 0000000..a6b7af1 --- /dev/null +++ b/Gallery.iOS/Main.cs @@ -0,0 +1,15 @@ +using UIKit; + +namespace Gallery.iOS +{ + public class Application + { + // This is the main entry point of the application. + static void Main(string[] args) + { + // if you want to use a different Application Delegate class from "AppDelegate" + // you can specify it here. + UIApplication.Main(args, null, "AppDelegate"); + } + } +} diff --git a/Gallery.iOS/Properties/AssemblyInfo.cs b/Gallery.iOS/Properties/AssemblyInfo.cs new file mode 100644 index 0000000..968e011 --- /dev/null +++ b/Gallery.iOS/Properties/AssemblyInfo.cs @@ -0,0 +1,38 @@ +using System.Reflection; +using System.Runtime.InteropServices; +using Xamarin.Forms.Xaml; + +// General Information about an assembly is controlled through the following +// set of attributes. Change these attribute values to modify the information +// associated with an assembly. +[assembly: AssemblyTitle("Gallery.iOS")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("")] +[assembly: AssemblyProduct("Gallery.iOS")] +[assembly: AssemblyCopyright("Copyright © Tsanie.Org 2021")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// Setting ComVisible to false makes the types in this assembly not visible +// to COM components. If you need to access a type in this assembly from +// COM, set the ComVisible attribute to true on that type. +[assembly: ComVisible(false)] + +// The following GUID is for the ID of the typelib if this project is exposed to COM +[assembly: Guid("72bdc44f-c588-44f3-b6df-9aace7daafdd")] + +// Version information for an assembly consists of the following four values: +// +// Major Version +// Minor Version +// Build Number +// Revision +// +// You can specify all the values or you can default the Build and Revision Numbers +// by using the '*' as shown below: +// [assembly: AssemblyVersion("1.0.*")] +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] + +[assembly: XamlCompilation(XamlCompilationOptions.Compile)] diff --git a/Gallery.iOS/Resources/Default-568h@2x.png b/Gallery.iOS/Resources/Default-568h@2x.png new file mode 100644 index 0000000..26c6461 Binary files /dev/null and b/Gallery.iOS/Resources/Default-568h@2x.png differ diff --git a/Gallery.iOS/Resources/Default-Portrait.png b/Gallery.iOS/Resources/Default-Portrait.png new file mode 100644 index 0000000..5d0d1ab Binary files /dev/null and b/Gallery.iOS/Resources/Default-Portrait.png differ diff --git a/Gallery.iOS/Resources/Default-Portrait@2x.png b/Gallery.iOS/Resources/Default-Portrait@2x.png new file mode 100644 index 0000000..0ee2688 Binary files /dev/null and b/Gallery.iOS/Resources/Default-Portrait@2x.png differ diff --git a/Gallery.iOS/Resources/Default.png b/Gallery.iOS/Resources/Default.png new file mode 100644 index 0000000..b74643c Binary files /dev/null and b/Gallery.iOS/Resources/Default.png differ diff --git a/Gallery.iOS/Resources/Default@2x.png b/Gallery.iOS/Resources/Default@2x.png new file mode 100644 index 0000000..dbd6bd3 Binary files /dev/null and b/Gallery.iOS/Resources/Default@2x.png differ diff --git a/Gallery.iOS/Resources/LaunchScreen.storyboard b/Gallery.iOS/Resources/LaunchScreen.storyboard new file mode 100644 index 0000000..db20faf --- /dev/null +++ b/Gallery.iOS/Resources/LaunchScreen.storyboard @@ -0,0 +1,39 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/Gallery.iOS/Resources/fa-light-300.ttf b/Gallery.iOS/Resources/fa-light-300.ttf new file mode 100644 index 0000000..174b27b Binary files /dev/null and b/Gallery.iOS/Resources/fa-light-300.ttf differ diff --git a/Gallery.iOS/Resources/fa-regular-400.ttf b/Gallery.iOS/Resources/fa-regular-400.ttf new file mode 100644 index 0000000..79519b4 Binary files /dev/null and b/Gallery.iOS/Resources/fa-regular-400.ttf differ diff --git a/Gallery.iOS/Resources/fa-solid-900.ttf b/Gallery.iOS/Resources/fa-solid-900.ttf new file mode 100644 index 0000000..0c9503f Binary files /dev/null and b/Gallery.iOS/Resources/fa-solid-900.ttf differ diff --git a/Gallery.iOS/Resources/icon_about.png b/Gallery.iOS/Resources/icon_about.png new file mode 100644 index 0000000..4884525 Binary files /dev/null and b/Gallery.iOS/Resources/icon_about.png differ diff --git a/Gallery.iOS/Resources/icon_about@2x.png b/Gallery.iOS/Resources/icon_about@2x.png new file mode 100644 index 0000000..f9ba9f9 Binary files /dev/null and b/Gallery.iOS/Resources/icon_about@2x.png differ diff --git a/Gallery.iOS/Resources/icon_about@3x.png b/Gallery.iOS/Resources/icon_about@3x.png new file mode 100644 index 0000000..fa470c2 Binary files /dev/null and b/Gallery.iOS/Resources/icon_about@3x.png differ diff --git a/Gallery.iOS/Resources/icon_feed.png b/Gallery.iOS/Resources/icon_feed.png new file mode 100644 index 0000000..fdf6daf Binary files /dev/null and b/Gallery.iOS/Resources/icon_feed.png differ diff --git a/Gallery.iOS/Resources/icon_feed@2x.png b/Gallery.iOS/Resources/icon_feed@2x.png new file mode 100644 index 0000000..845d96c Binary files /dev/null and b/Gallery.iOS/Resources/icon_feed@2x.png differ diff --git a/Gallery.iOS/Resources/icon_feed@3x.png b/Gallery.iOS/Resources/icon_feed@3x.png new file mode 100644 index 0000000..812cf73 Binary files /dev/null and b/Gallery.iOS/Resources/icon_feed@3x.png differ diff --git a/Gallery.iOS/Resources/xamarin_logo.png b/Gallery.iOS/Resources/xamarin_logo.png new file mode 100644 index 0000000..7d5007d Binary files /dev/null and b/Gallery.iOS/Resources/xamarin_logo.png differ diff --git a/Gallery.iOS/Resources/xamarin_logo@2x.png b/Gallery.iOS/Resources/xamarin_logo@2x.png new file mode 100644 index 0000000..a5b9fc0 Binary files /dev/null and b/Gallery.iOS/Resources/xamarin_logo@2x.png differ diff --git a/Gallery.iOS/Resources/xamarin_logo@3x.png b/Gallery.iOS/Resources/xamarin_logo@3x.png new file mode 100644 index 0000000..b36d00e Binary files /dev/null and b/Gallery.iOS/Resources/xamarin_logo@3x.png differ diff --git a/Gallery.iOS/obj/iPhoneSimulator/Debug/Gallery.iOS.csproj.AssemblyReference.cache b/Gallery.iOS/obj/iPhoneSimulator/Debug/Gallery.iOS.csproj.AssemblyReference.cache new file mode 100644 index 0000000..249fb05 Binary files /dev/null and b/Gallery.iOS/obj/iPhoneSimulator/Debug/Gallery.iOS.csproj.AssemblyReference.cache differ diff --git a/Gallery.sln b/Gallery.sln new file mode 100644 index 0000000..b1e45be --- /dev/null +++ b/Gallery.sln @@ -0,0 +1,53 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 16 +VisualStudioVersion = 16.0.810.6 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Gallery.iOS", "Gallery.iOS\Gallery.iOS.csproj", "{94E59D2C-9083-4BAB-9567-A0B0C4B4266D}" +EndProject +Project("{D954291E-2A0B-460D-934E-DC6B0785DB48}") = "Gallery.Share", "Gallery.Share\Gallery.Share.shproj", "{E72B5C40-090B-4A1C-9170-BD33C14A9A91}" +EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Gallery.Util", "Gallery.Util\Gallery.Util.csproj", "{222C22EC-3A47-4CF5-B9FB-CA28DE9F4BC8}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|iPhoneSimulator = Debug|iPhoneSimulator + Release|iPhoneSimulator = Release|iPhoneSimulator + Debug|iPhone = Debug|iPhone + Release|iPhone = Release|iPhone + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {94E59D2C-9083-4BAB-9567-A0B0C4B4266D}.Debug|iPhoneSimulator.ActiveCfg = Debug|iPhoneSimulator + {94E59D2C-9083-4BAB-9567-A0B0C4B4266D}.Debug|iPhoneSimulator.Build.0 = Debug|iPhoneSimulator + {94E59D2C-9083-4BAB-9567-A0B0C4B4266D}.Release|iPhoneSimulator.ActiveCfg = Release|iPhoneSimulator + {94E59D2C-9083-4BAB-9567-A0B0C4B4266D}.Release|iPhoneSimulator.Build.0 = Release|iPhoneSimulator + {94E59D2C-9083-4BAB-9567-A0B0C4B4266D}.Debug|iPhone.ActiveCfg = Debug|iPhone + {94E59D2C-9083-4BAB-9567-A0B0C4B4266D}.Debug|iPhone.Build.0 = Debug|iPhone + {94E59D2C-9083-4BAB-9567-A0B0C4B4266D}.Release|iPhone.ActiveCfg = Release|iPhone + {94E59D2C-9083-4BAB-9567-A0B0C4B4266D}.Release|iPhone.Build.0 = Release|iPhone + {94E59D2C-9083-4BAB-9567-A0B0C4B4266D}.Debug|Any CPU.ActiveCfg = Debug|iPhoneSimulator + {94E59D2C-9083-4BAB-9567-A0B0C4B4266D}.Debug|Any CPU.Build.0 = Debug|iPhoneSimulator + {94E59D2C-9083-4BAB-9567-A0B0C4B4266D}.Release|Any CPU.ActiveCfg = Release|iPhoneSimulator + {94E59D2C-9083-4BAB-9567-A0B0C4B4266D}.Release|Any CPU.Build.0 = Release|iPhoneSimulator + {222C22EC-3A47-4CF5-B9FB-CA28DE9F4BC8}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU + {222C22EC-3A47-4CF5-B9FB-CA28DE9F4BC8}.Debug|iPhoneSimulator.Build.0 = Debug|Any CPU + {222C22EC-3A47-4CF5-B9FB-CA28DE9F4BC8}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU + {222C22EC-3A47-4CF5-B9FB-CA28DE9F4BC8}.Release|iPhoneSimulator.Build.0 = Release|Any CPU + {222C22EC-3A47-4CF5-B9FB-CA28DE9F4BC8}.Debug|iPhone.ActiveCfg = Debug|Any CPU + {222C22EC-3A47-4CF5-B9FB-CA28DE9F4BC8}.Debug|iPhone.Build.0 = Debug|Any CPU + {222C22EC-3A47-4CF5-B9FB-CA28DE9F4BC8}.Release|iPhone.ActiveCfg = Release|Any CPU + {222C22EC-3A47-4CF5-B9FB-CA28DE9F4BC8}.Release|iPhone.Build.0 = Release|Any CPU + {222C22EC-3A47-4CF5-B9FB-CA28DE9F4BC8}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {222C22EC-3A47-4CF5-B9FB-CA28DE9F4BC8}.Debug|Any CPU.Build.0 = Debug|Any CPU + {222C22EC-3A47-4CF5-B9FB-CA28DE9F4BC8}.Release|Any CPU.ActiveCfg = Release|Any CPU + {222C22EC-3A47-4CF5-B9FB-CA28DE9F4BC8}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {A969B750-3E3E-4815-B336-02B32908D0C4} + EndGlobalSection +EndGlobal