newTheme.Id = "NONAME";
}
- StyleManager.Instance.SetBrokenImageUrl(StyleManager.BrokenImageType.Small, newTheme.SmallBrokenImageUrl ?? "");
- StyleManager.Instance.SetBrokenImageUrl(StyleManager.BrokenImageType.Normal, newTheme.BrokenImageUrl ?? "");
- StyleManager.Instance.SetBrokenImageUrl(StyleManager.BrokenImageType.Large, newTheme.LargeBrokenImageUrl ?? "");
+ if (newTheme.SmallBrokenImageUrl != null) StyleManager.Instance.SetBrokenImageUrl(StyleManager.BrokenImageType.Small, newTheme.SmallBrokenImageUrl);
+ if (newTheme.BrokenImageUrl != null) StyleManager.Instance.SetBrokenImageUrl(StyleManager.BrokenImageType.Normal, newTheme.BrokenImageUrl);
+ if (newTheme.LargeBrokenImageUrl != null) StyleManager.Instance.SetBrokenImageUrl(StyleManager.BrokenImageType.Large, newTheme.LargeBrokenImageUrl);
userTheme = newTheme;
UpdateThemeForInitialize();
newTheme.Id = "NONAME";
}
- StyleManager.Instance.SetBrokenImageUrl(StyleManager.BrokenImageType.Small, newTheme.SmallBrokenImageUrl ?? "");
- StyleManager.Instance.SetBrokenImageUrl(StyleManager.BrokenImageType.Normal, newTheme.BrokenImageUrl ?? "");
- StyleManager.Instance.SetBrokenImageUrl(StyleManager.BrokenImageType.Large, newTheme.LargeBrokenImageUrl ?? "");
+ if (newTheme.SmallBrokenImageUrl != null) StyleManager.Instance.SetBrokenImageUrl(StyleManager.BrokenImageType.Small, newTheme.SmallBrokenImageUrl);
+ if (newTheme.BrokenImageUrl != null) StyleManager.Instance.SetBrokenImageUrl(StyleManager.BrokenImageType.Normal, newTheme.BrokenImageUrl);
+ if (newTheme.LargeBrokenImageUrl != null) StyleManager.Instance.SetBrokenImageUrl(StyleManager.BrokenImageType.Large, newTheme.LargeBrokenImageUrl);
- if (userTheme == null) userTheme = theme;
+ if (userTheme == null) userTheme = newTheme;
else
{
userTheme = (Theme)userTheme.Clone();
- userTheme.MergeWithoutClone(theme);
+ userTheme.MergeWithoutClone(newTheme);
}
UpdateThemeForInitialize();
}
/// <summary>
+ /// Append a theme to the current base theme and apply it.
+ /// This will change the appearance of the existing components with property <seealso cref="View.ThemeChangeSensitive"/> on.
+ /// This also affects all components created afterwards.
+ /// </summary>
+ /// <param name="theme">The theme instance to be appended.</param>
+ /// <exception cref="ArgumentNullException">Thrown when the given theme is null.</exception>
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public static void AppendBaseTheme(Theme theme)
+ {
+ var newTheme = (Theme)theme?.Clone() ?? throw new ArgumentNullException(nameof(theme));
+
+ if (string.IsNullOrEmpty(newTheme.Id))
+ {
+ newTheme.Id = "NONAME";
+ }
+
+ if (newTheme.SmallBrokenImageUrl != null) StyleManager.Instance.SetBrokenImageUrl(StyleManager.BrokenImageType.Small, newTheme.SmallBrokenImageUrl);
+ if (newTheme.BrokenImageUrl != null) StyleManager.Instance.SetBrokenImageUrl(StyleManager.BrokenImageType.Normal, newTheme.BrokenImageUrl);
+ if (newTheme.LargeBrokenImageUrl != null) StyleManager.Instance.SetBrokenImageUrl(StyleManager.BrokenImageType.Large, newTheme.LargeBrokenImageUrl);
+
+ if (baseTheme == null) baseTheme = newTheme;
+ else
+ {
+ baseTheme = (Theme)baseTheme.Clone();
+ baseTheme.MergeWithoutClone(newTheme);
+ }
+
+ UpdateThemeForInitialize();
+ NotifyThemeChanged();
+ }
+
+ /// <summary>
/// Change tizen theme.
/// User may change this to one of platform installed one.
/// Note that this is global theme changing which effects all applications.
--- /dev/null
+/*
+ * Copyright(c) 2021 Samsung Electronics Co., Ltd.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+using System;
+using System.ComponentModel;
+using Tizen.NUI.Binding;
+
+namespace Tizen.NUI.Xaml
+{
+ /// <summary>
+ /// Provide application's shared resource path for xaml.
+ /// </summary>
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ [ContentProperty(nameof(FilePath))]
+ [AcceptEmptyServiceProvider]
+ public class SharedResourcePathExtension : IMarkupExtension<string>
+ {
+ /// <summary>
+ /// Provide application's shared resource path for xaml.
+ /// </summary>
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public SharedResourcePathExtension()
+ {
+ }
+
+ /// <summary> User should specify file path as a content of this extension. </summary>
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public string FilePath { get; set; }
+
+ /// <inheritdoc/>
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public string ProvideValue(IServiceProvider serviceProvider) => Tizen.Applications.Application.Current.DirectoryInfo.SharedResource + FilePath;
+
+ /// <inheritdoc/>
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ object IMarkupExtension.ProvideValue(IServiceProvider serviceProvider)
+ {
+ return (this as IMarkupExtension<string>).ProvideValue(serviceProvider);
+ }
+ }
+}