[NUI] Add SetDefaultNavigator
authorJaehyun Cho <jae_hyun.cho@samsung.com>
Mon, 28 Nov 2022 08:25:27 +0000 (17:25 +0900)
committerdongsug-song <35130733+dongsug-song@users.noreply.github.com>
Tue, 6 Dec 2022 08:08:09 +0000 (17:08 +0900)
To use customized Navigator as default navigator, SetDefaultNavigator
is added.

src/Tizen.NUI.Components/Controls/Navigation/Navigator.cs
src/Tizen.NUI.Components/Utils/NUIWindowExtensions.cs

index f5f65e20dbd7ab717f8bfa5880f200de1ad8c552..e483a2a586c70103ea858e650794ee5377af4407 100755 (executable)
@@ -840,6 +840,43 @@ namespace Tizen.NUI.Components
             return defaultNavigator;
         }
 
+        /// <summary>
+        /// Sets the default navigator of the given window.
+        /// SetDefaultNavigator does not remove the previous default navigator from the window.
+        /// Therefore, if a user does not want to show the previous default navigator, then it should be removed from the window manually.
+        /// </summary>
+        /// <exception cref="ArgumentNullException">Thrown when the argument window is null.</exception>
+        /// <exception cref="ArgumentNullException">Thrown when the argument newNavigator is null.</exception>
+        [EditorBrowsable(EditorBrowsableState.Never)]
+        public static void SetDefaultNavigator(Window window, Navigator newNavigator)
+        {
+            if (window == null)
+            {
+                throw new ArgumentNullException(nameof(window), "window should not be null.");
+            }
+
+            if (newNavigator == null)
+            {
+                throw new ArgumentNullException(nameof(newNavigator), "newNavigator should not be null.");
+            }
+
+            if (windowNavigator.ContainsKey(window) == true)
+            {
+                var oldNavigator = windowNavigator[window];
+                if (oldNavigator == newNavigator)
+                {
+                    return;
+                }
+
+                navigatorWindow.Remove(oldNavigator);
+                windowNavigator.Remove(window);
+            }
+
+            window.Add(newNavigator);
+            windowNavigator.Add(window, newNavigator);
+            navigatorWindow.Add(newNavigator, window);
+        }
+
         /// <summary>
         /// Called when the back navigation is started.
         /// </summary>
index 84bf8b3afcde6f62308bcc9d38af970d71167382..7e113a0e488e1ce36223ede443341ebb59f04ca8 100755 (executable)
@@ -37,5 +37,15 @@ namespace Tizen.NUI.Components
         {
             return Navigator.GetDefaultNavigator(window);
         }
+
+        /// <summary>
+        /// Sets the default navigator of the given window.
+        /// </summary>
+        /// <exception cref="ArgumentNullException">Thrown when the argument window is null.</exception>
+        [EditorBrowsable(EditorBrowsableState.Never)]
+        public static void SetDefaultNavigator(this Window window, Navigator navigator)
+        {
+            Navigator.SetDefaultNavigator(window, navigator);
+        }
     }
 }