summaryrefslogtreecommitdiff
path: root/Xamarin.Forms.Platform.Android
diff options
context:
space:
mode:
authorJason Smith <jason.smith@xamarin.com>2016-04-24 12:25:26 -0400
committerRui Marinho <me@ruimarinho.net>2016-04-24 12:25:26 -0400
commit5907152c50ee2c658b266f2804e6b383bb15a6f1 (patch)
tree9beb907623359723456c5c03b08922bebc4f41f3 /Xamarin.Forms.Platform.Android
parentfeac1ba3ed6df5e27b3fa2076bd15c190cbacd1c (diff)
downloadxamarin-forms-5907152c50ee2c658b266f2804e6b383bb15a6f1.tar.gz
xamarin-forms-5907152c50ee2c658b266f2804e6b383bb15a6f1.tar.bz2
xamarin-forms-5907152c50ee2c658b266f2804e6b383bb15a6f1.zip
Evolve feature branch (#117)
* Initial import of evolve features * [Android] Add Xamarin.Forms.Platform.Android.AppLinks project * [iOS] Fix issues with c# 6 features on iOS AppLinks * Added naive stanza to update-docs-windows.bat to produce Pages docs. Not tested. (#69) * Update packages * Add AppLinks android nuspec and fix linker issues * Fix build * Fix nusepc * Fix nuspec * Update android support nugets to 23.2.1 * Update Xamarin.UITest * Add CardView * [iOS] Fix app link for CoreSpotlight * [Android] Update AppLinks android support libs * Add Newtonsoft.Json dependency to nuspec * Fix NRE when setting ControlTemplate to null * Move to ModernHttpClient for download * Try fix build * Preserve android app links * Fix margin issue * General coding and simple fixes
Diffstat (limited to 'Xamarin.Forms.Platform.Android')
-rw-r--r--Xamarin.Forms.Platform.Android/AndroidAppIndexProvider.cs41
-rw-r--r--Xamarin.Forms.Platform.Android/AppCompat/FormsAppCompatActivity.cs15
-rw-r--r--Xamarin.Forms.Platform.Android/Xamarin.Forms.Platform.Android.csproj1
3 files changed, 57 insertions, 0 deletions
diff --git a/Xamarin.Forms.Platform.Android/AndroidAppIndexProvider.cs b/Xamarin.Forms.Platform.Android/AndroidAppIndexProvider.cs
new file mode 100644
index 00000000..e9b85eec
--- /dev/null
+++ b/Xamarin.Forms.Platform.Android/AndroidAppIndexProvider.cs
@@ -0,0 +1,41 @@
+´╗┐using Android.Content;
+using System;
+using System.Reflection;
+using System.Linq;
+using System.Globalization;
+
+namespace Xamarin.Forms.Platform.Android
+{
+ public class AndroidAppIndexProvider : IAppIndexingProvider
+ {
+ public AndroidAppIndexProvider(Context context)
+ {
+ var assemblyAppLinks = GetAssemblyForAppLinks(AppLinksAssemblyName);
+
+ if (assemblyAppLinks != null)
+ {
+ Type type = assemblyAppLinks.GetType($"{AppLinksAssemblyName}.{AppLinksClassName}");
+
+ if (type != null)
+ {
+ var applink = Activator.CreateInstance(type, new object[] { context }, null);
+
+ if (applink != null)
+ {
+ AppLinks = applink as IAppLinks;
+ }
+ }
+ }
+ }
+
+ public IAppLinks AppLinks { get; }
+
+ private Assembly GetAssemblyForAppLinks(string assemblyName)
+ {
+ return Device.GetAssemblies().FirstOrDefault(assembly => assembly.GetName().Name == assemblyName);
+ }
+
+ const string AppLinksAssemblyName = "Xamarin.Forms.Platform.Android.AppLinks";
+ const string AppLinksClassName = "AndroidAppLinks";
+ }
+} \ No newline at end of file
diff --git a/Xamarin.Forms.Platform.Android/AppCompat/FormsAppCompatActivity.cs b/Xamarin.Forms.Platform.Android/AppCompat/FormsAppCompatActivity.cs
index 8eeeae09..6bd7df2b 100644
--- a/Xamarin.Forms.Platform.Android/AppCompat/FormsAppCompatActivity.cs
+++ b/Xamarin.Forms.Platform.Android/AppCompat/FormsAppCompatActivity.cs
@@ -119,8 +119,11 @@ namespace Xamarin.Forms.Platform.Android
throw new ArgumentNullException("application");
_application = application;
+ (application as IApplicationController)?.SetAppIndexingProvider(new AndroidAppIndexProvider(this));
Xamarin.Forms.Application.Current = application;
+ CheckForAppLink(Intent);
+
application.PropertyChanged += AppOnPropertyChanged;
SetMainPage();
@@ -205,6 +208,7 @@ namespace Xamarin.Forms.Platform.Android
protected override void OnNewIntent(Intent intent)
{
base.OnNewIntent(intent);
+ CheckForAppLink(intent);
}
protected override void OnPause()
@@ -292,6 +296,17 @@ namespace Xamarin.Forms.Platform.Android
InternalSetPage(_application.MainPage);
}
+ void CheckForAppLink(Intent intent)
+ {
+ string action = intent.Action;
+ string strLink = intent.DataString;
+ if (Intent.ActionView != action || string.IsNullOrWhiteSpace(strLink))
+ return;
+
+ var link = new Uri(strLink);
+ _application?.SendOnAppLinkRequestReceived(link);
+ }
+
int GetColorPrimaryDark()
{
FormsAppCompatActivity context = this;
diff --git a/Xamarin.Forms.Platform.Android/Xamarin.Forms.Platform.Android.csproj b/Xamarin.Forms.Platform.Android/Xamarin.Forms.Platform.Android.csproj
index f9ee72e9..2dea12eb 100644
--- a/Xamarin.Forms.Platform.Android/Xamarin.Forms.Platform.Android.csproj
+++ b/Xamarin.Forms.Platform.Android/Xamarin.Forms.Platform.Android.csproj
@@ -239,6 +239,7 @@
<Compile Include="Renderers\OpenGLViewRenderer.cs" />
<Compile Include="AppCompat\CarouselPageRenderer.cs" />
<Compile Include="AppCompat\FormsFragmentPagerAdapter.cs" />
+ <Compile Include="AndroidAppIndexProvider.cs" />
</ItemGroup>
<Import Project="$(MSBuildExtensionsPath)\Xamarin\Android\Xamarin.Android.CSharp.targets" />
<!-- To modify your build process, add your task inside one of the targets below and uncomment it.