ILocalizationSource.cs 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. using System.Collections.Generic;
  2. using System.Globalization;
  3. using Abp.Configuration.Startup;
  4. using Abp.Dependency;
  5. namespace Abp.Localization.Sources
  6. {
  7. /// <summary>
  8. /// A Localization Source is used to obtain localized strings.
  9. /// </summary>
  10. public interface ILocalizationSource
  11. {
  12. /// <summary>
  13. /// Unique Name of the source.
  14. /// </summary>
  15. string Name { get; }
  16. /// <summary>
  17. /// This method is called by ABP before first usage.
  18. /// </summary>
  19. void Initialize(ILocalizationConfiguration configuration, IIocResolver iocResolver);
  20. /// <summary>
  21. /// Gets localized string for given name in current language.
  22. /// Fallbacks to default language if not found in current culture.
  23. /// </summary>
  24. /// <param name="name">Key name</param>
  25. /// <returns>Localized string</returns>
  26. string GetString(string name);
  27. /// <summary>
  28. /// Gets localized string for given name and specified culture.
  29. /// Fallbacks to default language if not found in given culture.
  30. /// </summary>
  31. /// <param name="name">Key name</param>
  32. /// <param name="culture">culture information</param>
  33. /// <returns>Localized string</returns>
  34. string GetString(string name, CultureInfo culture);
  35. /// <summary>
  36. /// Gets localized string for given name in current language.
  37. /// Returns null if not found.
  38. /// </summary>
  39. /// <param name="name">Key name</param>
  40. /// <param name="tryDefaults">
  41. /// True: Fallbacks to default language if not found in current culture.
  42. /// </param>
  43. /// <returns>Localized string</returns>
  44. string GetStringOrNull(string name, bool tryDefaults = true);
  45. /// <summary>
  46. /// Gets localized string for given name and specified culture.
  47. /// Returns null if not found.
  48. /// </summary>
  49. /// <param name="name">Key name</param>
  50. /// <param name="culture">culture information</param>
  51. /// <param name="tryDefaults">
  52. /// True: Fallbacks to default language if not found in current culture.
  53. /// </param>
  54. /// <returns>Localized string</returns>
  55. string GetStringOrNull(string name, CultureInfo culture, bool tryDefaults = true);
  56. /// <summary>
  57. /// Gets all strings in current language.
  58. /// </summary>
  59. /// <param name="includeDefaults">
  60. /// True: Fallbacks to default language texts if not found in current culture.
  61. /// </param>
  62. IReadOnlyList<LocalizedString> GetAllStrings(bool includeDefaults = true);
  63. /// <summary>
  64. /// Gets all strings in specified culture.
  65. /// </summary>
  66. /// <param name="culture">culture information</param>
  67. /// <param name="includeDefaults">
  68. /// True: Fallbacks to default language texts if not found in current culture.
  69. /// </param>
  70. IReadOnlyList<LocalizedString> GetAllStrings(CultureInfo culture, bool includeDefaults = true);
  71. }
  72. }