summaryrefslogtreecommitdiff
path: root/StoneIsland/plugins/cordova-plugin-google-analytics/wp8/UniversalAnalytics.cs
diff options
context:
space:
mode:
authorJules Laplace <julescarbon@gmail.com>2017-09-21 15:50:05 +0200
committerJules Laplace <julescarbon@gmail.com>2017-09-21 15:50:05 +0200
commitcc8e24461c625400143677956bdffb9268d8050b (patch)
tree71cdae83f6b1e15ab99471fe3b1995fb907d5154 /StoneIsland/plugins/cordova-plugin-google-analytics/wp8/UniversalAnalytics.cs
parentc1bd61b6ad4b3d4d1cd2da81f6ec403565cc1f4b (diff)
analytics plugin
Diffstat (limited to 'StoneIsland/plugins/cordova-plugin-google-analytics/wp8/UniversalAnalytics.cs')
-rw-r--r--StoneIsland/plugins/cordova-plugin-google-analytics/wp8/UniversalAnalytics.cs399
1 files changed, 399 insertions, 0 deletions
diff --git a/StoneIsland/plugins/cordova-plugin-google-analytics/wp8/UniversalAnalytics.cs b/StoneIsland/plugins/cordova-plugin-google-analytics/wp8/UniversalAnalytics.cs
new file mode 100644
index 00000000..b4307922
--- /dev/null
+++ b/StoneIsland/plugins/cordova-plugin-google-analytics/wp8/UniversalAnalytics.cs
@@ -0,0 +1,399 @@
+/*
+ * Copyright (c) 2016 Dan Polivy
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy of
+ * this software and associated documentation files (the "Software"), to deal in
+ * the Software without restriction, including without limitation the rights to
+ * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
+ * the Software, and to permit persons to whom the Software is furnished to do so,
+ * subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in all
+ * copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
+ * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
+ * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
+ * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
+ * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+ */
+
+using System;
+using GoogleAnalytics.Core;
+using WPCordovaClassLib.Cordova;
+using WPCordovaClassLib.Cordova.Commands;
+using WPCordovaClassLib.Cordova.JSON;
+using System.Collections.Generic;
+using System.Windows;
+using System.Diagnostics;
+using System.Threading.Tasks;
+using Microsoft.Phone.Shell;
+
+namespace Cordova.Extension.Commands
+{
+ /// <summary>
+ /// UniversalAnalytics plugin class containing methods called from JavaScript
+ /// </summary>
+ public class UniversalAnalytics : BaseCommand
+ {
+ private TrackerManager _trackerManager = new TrackerManager(new UniversalAnalyticsPlugin.PlatformInfoProvider());
+ private Tracker _tracker;
+ private bool _trackerStarted = false;
+ DateTime? _suspended;
+ private IDictionary<int, string> _customDimensions = new Dictionary<int, string>();
+
+ public UniversalAnalytics()
+ {
+ this.AutoAppLifetimeTracking = false;
+ this.SessionTimeout = 30;
+ }
+
+ /// <summary>
+ /// Session timeout length, in seconds.
+ /// </summary>
+ public int? SessionTimeout {
+ get;
+ set;
+ }
+
+ /// <summary>
+ /// Determines whether events are automatically sent for app lifetime tracking.
+ /// </summary>
+ public bool AutoAppLifetimeTracking { get; set; }
+
+ public void startTrackerWithId(string options)
+ {
+ // If the tracker is already started, don't start it again
+ if (_trackerStarted)
+ {
+ DispatchCommandResult(new PluginResult(PluginResult.Status.ERROR, "Tracker is already started"));
+ return;
+ }
+
+ string[] args = JsonHelper.Deserialize<string[]>(options);
+
+ if (!_trackerStarted && args.Length > 0 && args[0].Length > 0)
+ {
+ _tracker = _trackerManager.GetTracker(args[0]);
+
+ // Set additional Tracker parameters here
+ _tracker.SetStartSession(true);
+ _tracker.IsUseSecure = true;
+ _tracker.AppName = UniversalAnalyticsPlugin.Helpers.GetAppAttribute("Title");
+ _tracker.AppVersion = UniversalAnalyticsPlugin.Helpers.GetAppAttribute("Version");
+
+ _trackerStarted = true;
+
+ Deployment.Current.Dispatcher.BeginInvoke(() =>
+ {
+ Application.Current.UnhandledException += Analytics_UnhandledException;
+ TaskScheduler.UnobservedTaskException += TaskScheduler_UnobservedTaskException;
+ });
+
+ DispatchCommandResult(new PluginResult(PluginResult.Status.OK, "Tracker started"));
+ }
+ else
+ {
+ DispatchCommandResult(new PluginResult(PluginResult.Status.ERROR, "Tracker id is not valid"));
+ }
+ }
+
+ public override void OnResume(object sender, ActivatedEventArgs e)
+ {
+ if (_suspended.HasValue && SessionTimeout.HasValue)
+ {
+ var suspendedAgo = DateTime.UtcNow.Subtract(_suspended.Value);
+ if (suspendedAgo > TimeSpan.FromSeconds((double)SessionTimeout))
+ {
+ _tracker.SetStartSession(true);
+ }
+ }
+
+ if (_trackerStarted && AutoAppLifetimeTracking)
+ {
+ _tracker.SendEvent("app", "resume", !e.IsApplicationInstancePreserved ? "tombstoned" : null, 0);
+ }
+ }
+
+ public override void OnPause(object sender, DeactivatedEventArgs e)
+ {
+ if (_trackerStarted && AutoAppLifetimeTracking)
+ {
+ _tracker.SendEvent("app", "suspend", e.Reason.ToString(), 0);
+ }
+
+ _suspended = DateTime.UtcNow;
+ }
+
+ private void TaskScheduler_UnobservedTaskException(object sender, UnobservedTaskExceptionEventArgs e)
+ {
+ var ex = e.Exception.InnerException ?? e.Exception; // inner exception contains better info for unobserved tasks
+ _tracker.SendException(ex.ToString(), false);
+ }
+
+ private void Analytics_UnhandledException(object sender, ApplicationUnhandledExceptionEventArgs e)
+ {
+ _tracker.SendException(e.ExceptionObject.ToString(), true);
+
+ if (Debugger.IsAttached)
+ {
+ // An unhandled exception has occurred; break into the debugger
+ Debugger.Break();
+ }
+ }
+
+ public void setUserId(string options)
+ {
+ if (!_trackerStarted)
+ {
+ DispatchCommandResult(new PluginResult(PluginResult.Status.ERROR, "Tracker not started"));
+ return;
+ }
+
+ string[] args = JsonHelper.Deserialize<string[]>(options);
+ string userId = null;
+
+ if (args.Length > 0) userId = args[0];
+
+ _tracker.UserId = userId;
+ DispatchCommandResult(new PluginResult(PluginResult.Status.OK, "Set user id: " + args[0]));
+ }
+
+ public void debugMode(string options)
+ {
+ _trackerManager.IsDebugEnabled = true;
+
+ DispatchCommandResult(new PluginResult(PluginResult.Status.OK, "debugMode enabled"));
+ }
+
+ public void trackView(string options)
+ {
+ if (!_trackerStarted)
+ {
+ DispatchCommandResult(new PluginResult(PluginResult.Status.ERROR, "Tracker not started"));
+ return;
+ }
+
+ string[] args = JsonHelper.Deserialize<string[]>(options);
+
+ if (args.Length > 0 && args[0] != null && args[0].Length > 0)
+ {
+ addCustomDimensionsToTracker(_tracker);
+ _tracker.SendView(args[0]);
+ DispatchCommandResult(new PluginResult(PluginResult.Status.OK, "Track Screen: " + args[0]));
+ }
+ else
+ {
+ DispatchCommandResult(new PluginResult(PluginResult.Status.ERROR, "Expected one non-empty string argument"));
+ }
+ }
+
+ public void addCustomDimension(string options)
+ {
+ string[] args = JsonHelper.Deserialize<string[]>(options);
+
+ int index = 0;
+ bool hasIndex = false;
+ string value = null;
+
+ if (args.Length > 0) hasIndex = int.TryParse(args[0], out index);
+ if (args.Length > 1) value = args[1];
+
+ if (hasIndex && value != null)
+ {
+ // Remove the key if it already exists
+ _customDimensions.Remove(index);
+ _customDimensions.Add(index, value);
+ DispatchCommandResult(new PluginResult(PluginResult.Status.OK, "Add Custom Dimension: " + index));
+ }
+ else
+ {
+ DispatchCommandResult(new PluginResult(PluginResult.Status.ERROR, "Expected non-empty integer, string arguments"));
+ }
+ }
+
+ public void trackEvent(string options)
+ {
+ if (!_trackerStarted)
+ {
+ DispatchCommandResult(new PluginResult(PluginResult.Status.ERROR, "Tracker not started"));
+ return;
+ }
+
+ string[] args = JsonHelper.Deserialize<string[]>(options);
+
+ // Default values
+ string category = null, action = null, label = null;
+ long value = 0;
+
+ if (args.Length > 0) category = args[0];
+ if (args.Length > 1) action = args[1];
+ if (args.Length > 2) label = args[2];
+ if (args.Length > 3) long.TryParse(args[3], out value);
+
+ addCustomDimensionsToTracker(_tracker);
+ _tracker.SendEvent(category, action, label, value);
+
+ DispatchCommandResult(new PluginResult(PluginResult.Status.OK, "Track Event: " + category));
+ }
+
+ public void trackException(string options)
+ {
+ if (!_trackerStarted)
+ {
+ DispatchCommandResult(new PluginResult(PluginResult.Status.ERROR, "Tracker not started"));
+ return;
+ }
+
+ string[] args = JsonHelper.Deserialize<string[]>(options);
+
+ if (args.Length == 0 || args[0] == null || args[0].Length == 0)
+ {
+ DispatchCommandResult(new PluginResult(PluginResult.Status.ERROR, "Expected non-empty string arguments."));
+ return;
+ }
+
+ // Default values
+ string description = null;
+ bool isFatal = false;
+
+ if (args.Length > 0) description = args[0];
+ if (args.Length > 1) bool.TryParse(args[1], out isFatal);
+
+ addCustomDimensionsToTracker(_tracker);
+ _tracker.SendException(description, isFatal);
+
+ DispatchCommandResult(new PluginResult(PluginResult.Status.OK, "Track Exception: " + description));
+ }
+
+ public void trackTiming(string options)
+ {
+ if (!_trackerStarted)
+ {
+ DispatchCommandResult(new PluginResult(PluginResult.Status.ERROR, "Tracker not started"));
+ return;
+ }
+
+ string[] args = JsonHelper.Deserialize<string[]>(options);
+
+ if (args.Length == 0 || args[0] == null || args[0].Length == 0)
+ {
+ DispatchCommandResult(new PluginResult(PluginResult.Status.ERROR, "Expected non-empty string arguments."));
+ return;
+ }
+
+ // Default values
+ string category = null, variable = null, label = null;
+ long intervalInMs = 0;
+
+ if (args.Length > 0) category = args[0];
+ if (args.Length > 1) long.TryParse(args[1], out intervalInMs);
+ if (args.Length > 2) variable = args[2];
+ if (args.Length > 3) label = args[3];
+
+ addCustomDimensionsToTracker(_tracker);
+ _tracker.SendTiming(TimeSpan.FromMilliseconds(intervalInMs), category, variable, label);
+
+ DispatchCommandResult(new PluginResult(PluginResult.Status.OK, "Track Timing: " + category));
+ }
+
+ public void addTransaction(string options)
+ {
+ if (!_trackerStarted)
+ {
+ DispatchCommandResult(new PluginResult(PluginResult.Status.ERROR, "Tracker not started"));
+ return;
+ }
+
+ string[] args = JsonHelper.Deserialize<string[]>(options);
+
+ if (args.Length == 0 || args[0] == null || args[0].Length == 0)
+ {
+ DispatchCommandResult(new PluginResult(PluginResult.Status.ERROR, "Expected non-empty ID."));
+ return;
+ }
+
+ Transaction transaction = new Transaction();
+
+ // Default values
+ double revenue = 0, tax = 0, shipping = 0;
+
+ if (args.Length > 0) transaction.TransactionId = args[0];
+ if (args.Length > 1) transaction.Affiliation = args[1];
+ if (args.Length > 2)
+ {
+ double.TryParse(args[2], out revenue);
+ transaction.TotalCostInMicros = (long)(revenue * 1000000);
+ }
+ if (args.Length > 3)
+ {
+ double.TryParse(args[3], out tax);
+ transaction.TotalTaxInMicros = (long)(tax * 1000000);
+ }
+ if (args.Length > 4)
+ {
+ double.TryParse(args[4], out shipping);
+ transaction.ShippingCostInMicros = (long)(shipping * 1000000);
+ }
+ if (args.Length > 5) transaction.CurrencyCode = args[5];
+
+ addCustomDimensionsToTracker(_tracker);
+ _tracker.SendTransaction(transaction);
+
+ DispatchCommandResult(new PluginResult(PluginResult.Status.OK, "Add Transaction: " + transaction.TransactionId));
+ }
+
+ public void addTransactionItem(string options)
+ {
+ if (!_trackerStarted)
+ {
+ DispatchCommandResult(new PluginResult(PluginResult.Status.ERROR, "Tracker not started"));
+ return;
+ }
+
+ string[] args = JsonHelper.Deserialize<string[]>(options);
+
+ if (args.Length == 0 || args[0] == null || args[0].Length == 0)
+ {
+ DispatchCommandResult(new PluginResult(PluginResult.Status.ERROR, "Expected non-empty ID."));
+ return;
+ }
+
+ TransactionItem transactionItem = new TransactionItem();
+
+ // Default values
+ double price = 0;
+ long quantity = 0;
+
+ if (args.Length > 0) transactionItem.TransactionId = args[0];
+ if (args.Length > 1) transactionItem.Name = args[1];
+ if (args.Length > 2) transactionItem.SKU = args[2];
+ if (args.Length > 3) transactionItem.Category = args[3];
+ if (args.Length > 4)
+ {
+ double.TryParse(args[4], out price);
+ transactionItem.PriceInMicros = (long)(price * 1000000);
+ }
+ if (args.Length > 5)
+ {
+ long.TryParse(args[5], out quantity);
+ transactionItem.Quantity = quantity;
+ }
+ if (args.Length > 6) transactionItem.CurrencyCode = args[6];
+
+ addCustomDimensionsToTracker(_tracker);
+ _tracker.SendTransactionItem(transactionItem);
+
+ DispatchCommandResult(new PluginResult(PluginResult.Status.OK, "Add Transaction Item: " + transactionItem.TransactionId));
+ }
+
+ private void addCustomDimensionsToTracker(Tracker tracker)
+ {
+ foreach (KeyValuePair<int, string> dimension in _customDimensions)
+ {
+ tracker.SetCustomDimension(dimension.Key, dimension.Value);
+ }
+ }
+ }
+} \ No newline at end of file