diff --git a/Editor.meta b/Editor.meta
deleted file mode 100644
index 088d0ea..0000000
--- a/Editor.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: 26c29dd5c4e5b44da83fe6d7f7501b48
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Editor/WebViewBuildPostprocessor.cs b/Editor/WebViewBuildPostprocessor.cs
deleted file mode 100644
index 703632d..0000000
--- a/Editor/WebViewBuildPostprocessor.cs
+++ /dev/null
@@ -1,239 +0,0 @@
-#if UNITY_EDITOR
-using System.IO;
-using System.Xml;
-using UnityEditor;
-using System.Text;
-using UnityEditor.Android;
-using UnityEditor.Callbacks;
-
-#if UNITY_IOS
-using UnityEditor.iOS.Xcode;
-#endif
-
-namespace ReadyPlayerMe.WebView.Editor
-{
- ///
- /// Receives a callback after the Android Gradle project is generated,
- /// and the callback is used for generating a manifest file with required permissions.
- ///
- public class WebViewBuildPostprocessor : IPostGenerateGradleAndroidProject
- {
- public int callbackOrder => 1;
-
- public void OnPostGenerateGradleAndroidProject(string basePath)
- {
- var manifestPath = GetManifestPath(basePath);
- var androidManifest = new AndroidManifest(manifestPath);
-
- androidManifest
- .SetHardwareAccelerated(true)
- .SetUsesCleartextTraffic(true)
- .UseCamera()
- .UseMicrophone()
- .UseGallery()
- .AllowBackup();
-
- androidManifest.Save();
- }
-
- private string GetManifestPath(string basePath)
- {
- var pathBuilder = new StringBuilder(basePath);
- pathBuilder.Append(Path.DirectorySeparatorChar).Append("src");
- pathBuilder.Append(Path.DirectorySeparatorChar).Append("main");
- pathBuilder.Append(Path.DirectorySeparatorChar).Append("AndroidManifest.xml");
- return pathBuilder.ToString();
- }
-
- [PostProcessBuild(100)]
- public static void OnPostprocessBuild(BuildTarget buildTarget, string path)
- {
-#if UNITY_IOS
- if (buildTarget == BuildTarget.iOS) {
- string projPath = path + "/Unity-iPhone.xcodeproj/project.pbxproj";
- PBXProject proj = new PBXProject();
- proj.ReadFromString(File.ReadAllText(projPath));
- proj.AddFrameworkToProject(proj.GetUnityFrameworkTargetGuid(), "WebKit.framework", false);
- File.WriteAllText(projPath, proj.WriteToString());
- }
-#endif
- }
- }
-
- ///
- /// AndroidManifest.xml file that is created with necessary permissions.
- ///
- internal class AndroidXmlDocument : XmlDocument
- {
- private string manifestPath;
- protected XmlNamespaceManager namespaceManager;
- public readonly string AndroidXmlNamespace = "http://schemas.android.com/apk/res/android";
- public readonly string ToolsXmlNamespace = "http://schemas.android.com/tools";
-
- public AndroidXmlDocument(string path)
- {
- manifestPath = path;
- using (var reader = new XmlTextReader(manifestPath))
- {
- reader.Read();
- Load(reader);
- }
-
- namespaceManager = new XmlNamespaceManager(NameTable);
- namespaceManager.AddNamespace("android", AndroidXmlNamespace);
- namespaceManager.AddNamespace("tools", ToolsXmlNamespace);
- }
-
- public string Save()
- {
- return SaveAs(manifestPath);
- }
-
- public string SaveAs(string path)
- {
- using (var writer = new XmlTextWriter(path, new UTF8Encoding(false)))
- {
- writer.Formatting = Formatting.Indented;
- Save(writer);
- }
-
- return path;
- }
- }
-
- internal class AndroidManifest : AndroidXmlDocument
- {
- private const string NodeKey = "name";
- private const string UsesFeature = "uses-feature";
- private const string UsesPermission = "uses-permission";
-
- private const string CameraPermission = "android.permission.CAMERA";
- private const string CameraFeature = "android.hardware.camera";
-
- private const string MicrophonePermission = "android.permission.MICROPHONE";
- private const string MicrophoneFeature = "android.hardware.microphone";
-
- private const string ReadExternalStoragePermission = "android.permission.READ_EXTERNAL_STORAGE";
- private const string WriteExternalStoragePermission = "android.permission.Write_EXTERNAL_STORAGE";
-
- private const string UsesCleartextTrafficAttribute = "usesCleartextTraffic";
- private const string HardwareAcceleratedAttribute = "hardwareAccelerated";
-
- private const string XPath = "/manifest/application/activity[intent-filter/action/@android:name='android.intent.action.MAIN' and intent-filter/category/@android:name='android.intent.category.LAUNCHER']";
-
- private static XmlNode ActivityWithLaunchIntent = null;
-
- private readonly XmlElement ManifestElement;
-
- public AndroidManifest(string path) : base(path)
- {
- ManifestElement = SelectSingleNode("/manifest") as XmlElement;
- }
-
- internal XmlNode GetActivityWithLaunchIntent()
- {
- return ActivityWithLaunchIntent ?? SelectSingleNode(XPath, namespaceManager);
- }
-
- #region Node Edit Methods
-
- private XmlAttribute CreateAndroidAttribute(string key, string value)
- {
- XmlAttribute attr = CreateAttribute("android", key, AndroidXmlNamespace);
- attr.Value = value;
- return attr;
- }
-
- private XmlAttribute CreateToolsAttribute(string key, string value)
- {
- XmlAttribute attr = CreateAttribute("tools", key, ToolsXmlNamespace);
- attr.Value = value;
- return attr;
- }
-
- internal void UpdateAttribute(XmlElement activity, string attribute, bool enabled)
- {
- var value = enabled.ToString();
-
- if (activity.GetAttribute(attribute, AndroidXmlNamespace) != value)
- {
- activity.SetAttribute(attribute, AndroidXmlNamespace, value);
- }
- }
-
- internal void UpdateNode(string nodeName, string nodeValue)
- {
- XmlNodeList node = SelectNodes($"/manifest/{nodeName}[@android:{NodeKey}='{nodeValue}']", namespaceManager);
- if (node?.Count == 0)
- {
- XmlElement elem = CreateElement(nodeName);
- elem.Attributes.Append(CreateAndroidAttribute(NodeKey, nodeValue));
- ManifestElement.AppendChild(elem);
- }
- }
-
- internal void UseFeature(string feature)
- {
- UpdateNode(UsesFeature, feature);
- }
-
- internal void UsePermission(string permission)
- {
- UpdateNode(UsesPermission, permission);
- }
-
- #endregion
-
- #region AndroidManifest Options
-
- internal AndroidManifest SetUsesCleartextTraffic(bool enabled)
- {
- var activity = GetActivityWithLaunchIntent() as XmlElement;
- UpdateAttribute(activity, UsesCleartextTrafficAttribute, enabled);
- return this;
- }
-
- internal AndroidManifest AllowBackup()
- {
- XmlNode elem = SelectSingleNode("/manifest/application");
- if (elem?.Attributes != null)
- {
- elem.Attributes.Append(CreateAndroidAttribute("allowBackup", "false"));
- elem.Attributes.Append(CreateToolsAttribute("replace", "android:allowBackup"));
- }
-
- return this;
- }
-
- internal AndroidManifest SetHardwareAccelerated(bool enabled)
- {
- var activity = GetActivityWithLaunchIntent() as XmlElement;
- UpdateAttribute(activity, HardwareAcceleratedAttribute, enabled);
- return this;
- }
-
- internal AndroidManifest UseCamera()
- {
- UsePermission(CameraPermission);
- UseFeature(CameraFeature);
- return this;
- }
-
- internal AndroidManifest UseMicrophone()
- {
- UsePermission(MicrophonePermission);
- UseFeature(MicrophoneFeature);
- return this;
- }
-
- internal AndroidManifest UseGallery()
- {
- UsePermission(ReadExternalStoragePermission);
- UsePermission(WriteExternalStoragePermission);
- return this;
- }
-
- #endregion
- }
-}
-#endif
diff --git a/Editor/WebViewBuildPostprocessor.cs.meta b/Editor/WebViewBuildPostprocessor.cs.meta
deleted file mode 100644
index 9eded63..0000000
--- a/Editor/WebViewBuildPostprocessor.cs.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 0856672d812a15e459cee5e879c109d7
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Editor/WebViewEditor.cs b/Editor/WebViewEditor.cs
deleted file mode 100644
index 6c1af45..0000000
--- a/Editor/WebViewEditor.cs
+++ /dev/null
@@ -1,25 +0,0 @@
-#if UNITY_EDITOR
-using UnityEditor;
-using UnityEngine;
-
-namespace ReadyPlayerMe.WebView.Editor
-{
- public class WebViewEditor : UnityEditor.Editor
- {
- private const string WEB_VIEW_CANVAS_FILE_NAME = "WebView Canvas";
-
- ///
- /// Loads a WebView Canvas prefab to the current scene.
- ///
- [MenuItem("GameObject/UI/Ready Player Me/WebView Canvas", false)]
- private static void LoadWebViewCanvas()
- {
- var prefab = Resources.Load(WEB_VIEW_CANVAS_FILE_NAME);
- GameObject instance = Instantiate(prefab);
- instance.name = WEB_VIEW_CANVAS_FILE_NAME;
- Selection.activeGameObject = instance;
- EditorUtility.SetDirty(instance);
- }
- }
-}
-#endif
diff --git a/Editor/WebViewEditor.cs.meta b/Editor/WebViewEditor.cs.meta
deleted file mode 100644
index 6784b0b..0000000
--- a/Editor/WebViewEditor.cs.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 055a341980f246a47b8227fd1ae60f27
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Runtime/Data/Enums.cs b/Runtime/Data/Enums.cs
index 8087f1c..40a46a5 100644
--- a/Runtime/Data/Enums.cs
+++ b/Runtime/Data/Enums.cs
@@ -1,6 +1,3 @@
-using System;
-using System.Reflection;
-
namespace ReadyPlayerMe.WebView
{
///
@@ -22,97 +19,4 @@ public enum WebkitContentMode
Mobile = 1,
Desktop = 2
}
-
- ///
- /// Defines all the options for the language translation of the Ready Player Me website.
- ///
- public enum Language
- {
- [StringValue("")] Default,
- [StringValue("ch")] Chinese,
- [StringValue("de")] German,
- [StringValue("en-IE")] EnglishIreland,
- [StringValue("en")] English,
- [StringValue("es-MX")] SpanishMexico,
- [StringValue("es")] Spanish,
- [StringValue("fr")] French,
- [StringValue("it")] Italian,
- [StringValue("jp")] Japanese,
- [StringValue("kr")] Korean,
- [StringValue("pt-BR")] PortugueseBrazil,
- [StringValue("pt")] Portuguese,
- [StringValue("tr")] Turkish
- }
-
- ///
- /// Defines the options for the avatar body type.
- ///
- public enum BodyType
- {
- Selectable,
- [StringValue("fullbody")] FullBody,
- [StringValue("halfbody")] HalfBody
- }
-
- ///
- /// Defines the options used for the avatars gender.
- ///
- public enum Gender
- {
- None,
- [StringValue("male")] Male,
- [StringValue("female")] Female
- }
-
- ///
- /// Defines the options used for the WebView and Message panel UI.
- ///
- public enum MessageType
- {
- [StringValue("Loading...")]
- Loading,
- [StringValue("Network is not reachable.")]
- NetworkError,
- [StringValue("WebView is only supported on Android and iOS.\nBuild and run on a mobile device.")]
- NotSupported
- }
-
- // Attribute for storing a string value in the enum field
- public class StringValueAttribute : Attribute
- {
-
- public StringValueAttribute(string value)
- {
- Value = value;
- }
-
- public string Value { get; }
- }
-
- // Extension methods and helpers for enums
- public static class EnumHelpers
- {
- // Helps extracting the string value stored in the StringValue attribute of the enum field
- public static string GetValue(this T enumerationValue) where T : struct
- {
- Type type = enumerationValue.GetType();
- if (!type.IsEnum)
- {
- throw new ArgumentException("EnumerationValue must be of Enum type", nameof(enumerationValue));
- }
-
- MemberInfo[] memberInfo = type.GetMember(enumerationValue.ToString());
- if (memberInfo.Length > 0)
- {
- var attrs = memberInfo[0].GetCustomAttributes(typeof(StringValueAttribute), false);
-
- if (attrs.Length > 0)
- {
- return ((StringValueAttribute) attrs[0]).Value;
- }
- }
-
- return enumerationValue.ToString();
- }
- }
}
diff --git a/Runtime/Data/Enums.cs.meta b/Runtime/Data/Enums.cs.meta
index 9504841..1f7ef85 100644
--- a/Runtime/Data/Enums.cs.meta
+++ b/Runtime/Data/Enums.cs.meta
@@ -1,5 +1,5 @@
fileFormatVersion: 2
-guid: 852f772df746d354090fa33a897207f1
+guid: 273ee7af478906247bc2bb04ca620999
MonoImporter:
externalObjects: {}
serializedVersion: 2
diff --git a/Runtime/Data/ScreenPadding.cs b/Runtime/Data/ScreenPadding.cs
deleted file mode 100644
index cfb2805..0000000
--- a/Runtime/Data/ScreenPadding.cs
+++ /dev/null
@@ -1,14 +0,0 @@
-namespace ReadyPlayerMe.WebView
-{
- ///
- /// A simple class used to define the padding properties used by the WebView UI.
- ///
- [System.Serializable]
- public class ScreenPadding
- {
- public int left = 0;
- public int top = 0;
- public int right = 0;
- public int bottom = 0;
- }
-}
diff --git a/Runtime/Data/ScreenPadding.cs.meta b/Runtime/Data/ScreenPadding.cs.meta
deleted file mode 100644
index 06af241..0000000
--- a/Runtime/Data/ScreenPadding.cs.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: d156c0f4d728b8f4493c7664a4473772
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Runtime/Data/UrlConfig.cs b/Runtime/Data/UrlConfig.cs
deleted file mode 100644
index 34237fd..0000000
--- a/Runtime/Data/UrlConfig.cs
+++ /dev/null
@@ -1,68 +0,0 @@
-using System;
-using System.Text;
-using Newtonsoft.Json;
-using ReadyPlayerMe.Core;
-using UnityEngine;
-
-namespace ReadyPlayerMe.WebView
-{
- ///
- /// This class is used to define all the settings related to the URL that is used for creating the URL to be loaded in the WebView browser.
- ///
- [System.Serializable]
- public class UrlConfig
- {
- private const string TAG = nameof(UrlConfig);
- private const string CLEAR_CACHE_PARAM = "clearCache";
- private const string FRAME_API_PARAM = "frameApi";
- private const string QUICK_START_PARAM = "quickStart";
- private const string SELECT_BODY_PARAM = "selectBodyType";
- private const string LOGIN_TOKEN_PARAM = "token";
-
- [Tooltip("Language of the RPM website.")]
- public Language language = Language.Default;
-
- [Tooltip("Check if you want user to create a new avatar every visit. If not checked, avatar editor will continue from previously created avatar.")]
- public bool clearCache;
-
- [Tooltip("Start with preset full-body avatars. Checking this option makes avatar editor ignore Gender and Body Type options.")]
- public bool quickStart;
-
- [Tooltip("Skip gender selection and create avatars with selected gender. Ignored if Quick Start is checked.")]
- public Gender gender = Gender.None;
-
- [Tooltip("Skip body type selection and create avatars with selected body type. Ignored if Quick Start is checked.")]
- public BodyType bodyType = BodyType.Selectable;
-
- ///
- /// Builds RPM website URL for partner with given parameters.
- ///
- /// The Url to load in the WebView.
- public string BuildUrl(string loginToken = "")
- {
- var builder = new StringBuilder($"https://{CoreSettingsHandler.CoreSettings.Subdomain}.readyplayer.me/");
- builder.Append(language != Language.Default ? $"{language.GetValue()}/" : string.Empty);
- builder.Append($"avatar?{FRAME_API_PARAM}");
- builder.Append(clearCache ? $"&{CLEAR_CACHE_PARAM}" : string.Empty);
- if (loginToken != string.Empty)
- {
- builder.Append($"&{LOGIN_TOKEN_PARAM}={loginToken}");
- }
-
- if (quickStart)
- {
- builder.Append($"&{QUICK_START_PARAM}");
- }
- else
- {
- builder.Append(gender != Gender.None ? $"&gender={gender.GetValue()}" : string.Empty);
- builder.Append(bodyType == BodyType.Selectable ? $"&{SELECT_BODY_PARAM}" : $"&bodyType={bodyType.GetValue()}");
- }
-
- var url = builder.ToString();
- SDKLogger.AvatarLoaderLogger.Log(TAG, url);
-
- return url;
- }
- }
-}
diff --git a/Runtime/Data/UrlConfig.cs.meta b/Runtime/Data/UrlConfig.cs.meta
deleted file mode 100644
index 0e0d185..0000000
--- a/Runtime/Data/UrlConfig.cs.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 109e041e67cd7274c86eabd46af564ec
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Runtime/Data/WebMessage.cs b/Runtime/Data/WebMessage.cs
deleted file mode 100644
index daf3890..0000000
--- a/Runtime/Data/WebMessage.cs
+++ /dev/null
@@ -1,12 +0,0 @@
-using System.Collections.Generic;
-
-namespace ReadyPlayerMe.WebView
-{
- public struct WebMessage
- {
- public string type;
- public string source;
- public string eventName;
- public Dictionary data;
- }
-}
diff --git a/Runtime/Data/WebMessage.cs.meta b/Runtime/Data/WebMessage.cs.meta
deleted file mode 100644
index 516925c..0000000
--- a/Runtime/Data/WebMessage.cs.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 02b9cae38652cf34085cec61e073c265
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Runtime/MessagePanel.cs b/Runtime/MessagePanel.cs
deleted file mode 100644
index 86553cf..0000000
--- a/Runtime/MessagePanel.cs
+++ /dev/null
@@ -1,52 +0,0 @@
-using UnityEngine;
-using UnityEngine.UI;
-
-namespace ReadyPlayerMe.WebView
-{
- ///
- /// This class is responsible for displaying and updating a UI panel and message text.
- ///
- public class MessagePanel : MonoBehaviour
- {
- [SerializeField] private Text messageLabel;
-
- ///
- /// Set message from a string value.
- ///
- /// Message to display.
- public void SetMessage(string message)
- {
- messageLabel.text = message;
- }
-
- ///
- /// Set message from a message type.
- ///
- /// Describes the option for the message that is to be displayed.
- public void SetMessage(MessageType type)
- {
- messageLabel.text = type.GetValue();
- }
-
- ///
- /// Set message panel visibility.
- ///
- public void SetVisible(bool visible)
- {
- gameObject.SetActive(visible);
- }
-
- ///
- /// Set message panel padding in pixels.
- ///
- public void SetMargins(int left, int top, int right, int bottom)
- {
- var rect = transform as RectTransform;
- if (rect != null)
- {
- rect.offsetMax = new Vector2(-right, -top);
- rect.offsetMin = new Vector2(left, bottom);
- }
- }
- }
-}
diff --git a/Runtime/MessagePanel.cs.meta b/Runtime/MessagePanel.cs.meta
deleted file mode 100644
index 063383f..0000000
--- a/Runtime/MessagePanel.cs.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: da6aecf803b15f446ad259836bb2cf4f
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Runtime/Native/WebViewBase.cs b/Runtime/Native/WebViewBase.cs
index 1c243e9..9fdc4eb 100644
--- a/Runtime/Native/WebViewBase.cs
+++ b/Runtime/Native/WebViewBase.cs
@@ -1,4 +1,5 @@
using System;
+using ReadyPlayerMe.Core.WebView;
using UnityEngine;
namespace ReadyPlayerMe.WebView
diff --git a/Runtime/WebMessageHelper.cs b/Runtime/WebMessageHelper.cs
deleted file mode 100644
index ce08b8b..0000000
--- a/Runtime/WebMessageHelper.cs
+++ /dev/null
@@ -1,38 +0,0 @@
-namespace ReadyPlayerMe.WebView
-{
- public struct AssetRecord
- {
- public string UserId;
- public string AssetId;
- }
-
- public static class WebMessageHelper
- {
- private const string DATA_URL_FIELD_NAME = "url";
- private const string ID_KEY = "id";
- private const string USER_ID_KEY = "userId";
- private const string ASSET_ID_KEY = "assetId";
-
- public static string GetAvatarUrl(this WebMessage webMessage)
- {
- webMessage.data.TryGetValue(DATA_URL_FIELD_NAME, out var avatarUrl);
- return avatarUrl ?? string.Empty;
- }
-
- public static string GetUserId(this WebMessage webMessage)
- {
- webMessage.data.TryGetValue(ID_KEY, out var userId);
- return userId ?? string.Empty;
- }
-
- public static AssetRecord GetAssetRecord(this WebMessage webMessage)
- {
- webMessage.data.TryGetValue(ASSET_ID_KEY, out var assetId);
- webMessage.data.TryGetValue(USER_ID_KEY, out var userId);
- var assetRecord = new AssetRecord();
- assetRecord.AssetId = assetId;
- assetRecord.UserId = userId;
- return assetRecord;
- }
- }
-}
diff --git a/Runtime/WebMessageHelper.cs.meta b/Runtime/WebMessageHelper.cs.meta
deleted file mode 100644
index 92c464b..0000000
--- a/Runtime/WebMessageHelper.cs.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: cc0f294ec3d9d994ead938c7159b55d9
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Runtime/WebViewEvents.cs b/Runtime/WebViewEvents.cs
deleted file mode 100644
index ed25006..0000000
--- a/Runtime/WebViewEvents.cs
+++ /dev/null
@@ -1,23 +0,0 @@
-using System;
-using UnityEngine.Events;
-
-namespace ReadyPlayerMe.WebView
-{
- // Event to call when avatar is created, receives GLB url.
- [Serializable] public class WebViewEvent : UnityEvent
- {
- }
-
- // Event to call when avatar is created, receives GLB url.
- [Serializable] public class AssetUnlockEvent : UnityEvent
- {
- }
-
- public static class WebViewEvents
- {
- public const string AVATAR_EXPORT = "v1.avatar.exported";
- public const string USER_SET = "v1.user.set";
- public const string USER_AUTHORIZED = "v1.user.authorized";
- public const string ASSET_UNLOCK = "v1.asset.unlock";
- }
-}
diff --git a/Runtime/WebViewEvents.cs.meta b/Runtime/WebViewEvents.cs.meta
deleted file mode 100644
index 42ac6ad..0000000
--- a/Runtime/WebViewEvents.cs.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 9437fef0b1489a04c9d987396b9c08b1
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Runtime/WebViewPanel.cs b/Runtime/WebViewPanel.cs
index ee8c81e..17164b3 100644
--- a/Runtime/WebViewPanel.cs
+++ b/Runtime/WebViewPanel.cs
@@ -1,6 +1,7 @@
using System;
using Newtonsoft.Json;
using ReadyPlayerMe.Core;
+using ReadyPlayerMe.Core.WebView;
using UnityEngine;
namespace ReadyPlayerMe.WebView
diff --git a/Tests/Editor.meta b/Tests/Editor.meta
deleted file mode 100644
index 1976200..0000000
--- a/Tests/Editor.meta
+++ /dev/null
@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: eddad676e6e0cae4989e0d7c1449ba6f
-folderAsset: yes
-DefaultImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Tests/Editor/ReadyPlayerMe.WebView.Editor.Tests.asmdef b/Tests/Editor/ReadyPlayerMe.WebView.Editor.Tests.asmdef
deleted file mode 100644
index 0888c5d..0000000
--- a/Tests/Editor/ReadyPlayerMe.WebView.Editor.Tests.asmdef
+++ /dev/null
@@ -1,22 +0,0 @@
-{
- "name": "ReadyPlayerMe.WebView.Editor.Tests",
- "rootNamespace": "",
- "references": [
- "GUID:292600d1b44837d4b8ce752a20ebe446",
- "GUID:96af4ea235d92d245a095007c6ca3701",
- "GUID:69ab3f10cf42d0b42a6cd1353c374377"
- ],
- "includePlatforms": [
- "Editor"
- ],
- "excludePlatforms": [],
- "allowUnsafeCode": false,
- "overrideReferences": false,
- "precompiledReferences": [],
- "autoReferenced": true,
- "defineConstraints": [
- "UNITY_INCLUDE_TESTS"
- ],
- "versionDefines": [],
- "noEngineReferences": false
-}
\ No newline at end of file
diff --git a/Tests/Editor/ReadyPlayerMe.WebView.Editor.Tests.asmdef.meta b/Tests/Editor/ReadyPlayerMe.WebView.Editor.Tests.asmdef.meta
deleted file mode 100644
index db9663e..0000000
--- a/Tests/Editor/ReadyPlayerMe.WebView.Editor.Tests.asmdef.meta
+++ /dev/null
@@ -1,7 +0,0 @@
-fileFormatVersion: 2
-guid: b534849a0738e744780ff9f9eb311446
-AssemblyDefinitionImporter:
- externalObjects: {}
- userData:
- assetBundleName:
- assetBundleVariant:
diff --git a/Tests/Editor/UrlConfigTests.cs b/Tests/Editor/UrlConfigTests.cs
deleted file mode 100644
index e1e65a9..0000000
--- a/Tests/Editor/UrlConfigTests.cs
+++ /dev/null
@@ -1,112 +0,0 @@
-using UnityEngine;
-using NUnit.Framework;
-
-namespace ReadyPlayerMe.WebView.Tests
-{
- public class UrlConfigTests : MonoBehaviour
- {
- private const string URL_DEFAULT = "https://demo.readyplayer.me/avatar?frameApi&selectBodyType";
- private const string URL_LANG_GERMAN = "https://demo.readyplayer.me/de/avatar?frameApi&selectBodyType";
- private const string URL_LANG_BRAZIL = "https://demo.readyplayer.me/pt-BR/avatar?frameApi&selectBodyType";
-
- private const string URL_GENDER_MALE = "https://demo.readyplayer.me/avatar?frameApi&gender=male&selectBodyType";
- private const string URL_GENDER_NONE = "https://demo.readyplayer.me/avatar?frameApi&gender=male&selectBodyType";
-
- private const string URL_TYPE_FULLBODY = "https://demo.readyplayer.me/avatar?frameApi&bodyType=fullbody";
- private const string URL_TYPE_HALFBODY = "https://demo.readyplayer.me/avatar?frameApi&bodyType=halfbody";
-
- private const string URL_CLEAR_CACHE = "https://demo.readyplayer.me/avatar?frameApi&clearCache&selectBodyType";
-
- private const string URL_QUICK_START = "https://demo.readyplayer.me/avatar?frameApi&quickStart";
- private const string URL_TOKEN = "https://demo.readyplayer.me/avatar?frameApi&token=TOKEN&selectBodyType";
- private const string LOGIN_TOKEN = "TOKEN";
-
- public UrlConfig config;
-
- [SetUp]
- public void Setup()
- {
- config = new UrlConfig();
- }
-
- [Test]
- public void Url_Name_Change_German()
- {
- config.language = Language.German;
- var res = config.BuildUrl();
- Assert.AreEqual(URL_LANG_GERMAN, res);
- }
-
- [Test]
- public void Url_Name_Change_Brazil()
- {
- config.language = Language.PortugueseBrazil;
- var res = config.BuildUrl();
- Assert.AreEqual(URL_LANG_BRAZIL, res);
- }
-
- [Test]
- public void Url_Gender_Change_Male()
- {
- config.gender = Gender.Male;
- var res = config.BuildUrl();
- Assert.AreEqual(URL_GENDER_MALE, res);
- }
-
- [Test]
- public void Url_Gender_Change_None()
- {
- config.gender = Gender.Male;
- var res = config.BuildUrl();
- Assert.AreEqual(URL_GENDER_NONE, res);
- }
-
- [Test]
- public void Url_BodyType_Change_Fullbody()
- {
- config.bodyType = BodyType.FullBody;
- var res = config.BuildUrl();
- Assert.AreEqual(URL_TYPE_FULLBODY, res);
- }
-
- [Test]
- public void Url_BodyType_Change_Halfbody()
- {
- config.bodyType = BodyType.HalfBody;
- var res = config.BuildUrl();
- Assert.AreEqual(URL_TYPE_HALFBODY, res);
- }
-
- [Test]
- public void Url_ClearCache_Change()
- {
- config.clearCache = true;
- var res = config.BuildUrl();
- Assert.AreEqual(URL_CLEAR_CACHE, res);
- }
-
- [Test]
- public void Url_QuickStart_Change()
- {
- config.quickStart = true;
- var res = config.BuildUrl();
- Assert.AreEqual(URL_QUICK_START, res);
- }
-
- [Test]
- public void Url_With_Token()
- {
- var testConfig = new UrlConfig();
- var res = testConfig.BuildUrl(LOGIN_TOKEN);
- Assert.AreEqual(URL_TOKEN, res);
- }
-
- [Test]
- public void Url_Default()
- {
- var testConfig = new UrlConfig();
- var res = testConfig.BuildUrl();
- Assert.AreEqual(URL_DEFAULT, res);
- }
- }
-}
diff --git a/Tests/Editor/UrlConfigTests.cs.meta b/Tests/Editor/UrlConfigTests.cs.meta
deleted file mode 100644
index 6e24c63..0000000
--- a/Tests/Editor/UrlConfigTests.cs.meta
+++ /dev/null
@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: e32128773bea8b447859a8c9fec9452d
-MonoImporter:
- externalObjects: {}
- serializedVersion: 2
- defaultReferences: []
- executionOrder: 0
- icon: {instanceID: 0}
- userData:
- assetBundleName:
- assetBundleVariant: