From 0f0c7751e36a2b7ae9ed0fdf05f957a1f494f6e7 Mon Sep 17 00:00:00 2001 From: Santiago Lo Coco Date: Thu, 7 Nov 2024 23:42:46 +0100 Subject: [PATCH] Fix duplicated WebView(s) bug --- Assets/Scripts/EndpointLoader.cs | 44 +++++++++++++++++++++++++++++--- 1 file changed, 40 insertions(+), 4 deletions(-) diff --git a/Assets/Scripts/EndpointLoader.cs b/Assets/Scripts/EndpointLoader.cs index c761084..75a22d2 100644 --- a/Assets/Scripts/EndpointLoader.cs +++ b/Assets/Scripts/EndpointLoader.cs @@ -80,15 +80,35 @@ public class EndpointLoader : MonoBehaviour private float GetItemWidth(GameObject item) { - Renderer renderer = item.GetComponent(); - if (renderer != null) + RectTransform rectTransform = item.GetComponent(); + if (rectTransform != null) { - return renderer.bounds.size.x; + return rectTransform.rect.width * rectTransform.lossyScale.x + 0.2f; } - return 1.0f; + return 0.8f; } + /* + public void SpawnItem(string url, int position) + { + if (position < 0 || position > instantiatedItems.Count) + { + Debug.LogError("Invalid position"); + return; + } + + if (position == instantiatedItems.Count) + { + SpawnItem(url); + return; + } + + var webView = instantiatedItems[position].GetComponentInChildren(); + webView.Load(url); + } + */ + public void SpawnItem(string url) { if (dynamicItem != null) @@ -225,6 +245,15 @@ public class EndpointLoader : MonoBehaviour } else { + if (instantiatedItems.Count > 0) + { + foreach (var item in instantiatedItems) + { + Destroy(item); + } + instantiatedItems.Clear(); + } + foreach (var endpoint in endpoints) { if (endpoint.url == null || endpoint.url.Length == 0) @@ -232,6 +261,13 @@ public class EndpointLoader : MonoBehaviour Debug.LogWarning($"Endpoint URL is null for endpoint"); continue; } + /* + if (instantiatedItems.Exists(item => item.GetComponentInChildren().CurrentURL?.ToString() == endpoint.url)) + { + Debug.LogWarning($"Endpoint {endpoint.url} already exists"); + continue; + } + */ SpawnItem(endpoint.url); } }