Files
e-party-iOS/yana/Utils/LocalizationManager.swift
edwinQQQ c470dba79c feat: 更新项目配置和功能模块
- 修改Package.swift以支持iOS 15和macOS 12。
- 更新swift-tca-architecture-guidelines.mdc中的alwaysApply设置为false。
- 注释掉AppDelegate中的NIMSDK导入,移除不再使用的NIMConfigurationManager和NIMSessionManager文件。
- 添加新的API相关文件,包括EMailLoginFeature、IDLoginFeature和相关视图,增强登录功能。
- 更新APIConstants和APIEndpoints以反映新的API路径。
- 添加本地化支持文件,包含英文和中文简体的本地化字符串。
- 新增字体管理和安全工具类,支持AES和DES加密。
- 更新Xcode项目配置,调整版本号和启动画面设置。
2025-07-09 16:14:19 +08:00

135 lines
4.2 KiB
Swift
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

import Foundation
import SwiftUI
///
/// 便
///
///
/// -
/// -
/// - UserDefaults
class LocalizationManager: ObservableObject {
// MARK: -
static let shared = LocalizationManager()
// MARK: -
enum SupportedLanguage: String, CaseIterable {
case english = "en"
case chineseSimplified = "zh-Hans"
var displayName: String {
switch self {
case .english:
return "English"
case .chineseSimplified:
return "简体中文"
}
}
var localizedDisplayName: String {
switch self {
case .english:
return "English"
case .chineseSimplified:
return "简体中文"
}
}
}
// MARK: -
@Published var currentLanguage: SupportedLanguage {
didSet {
UserDefaults.standard.set(currentLanguage.rawValue, forKey: "AppLanguage")
//
objectWillChange.send()
}
}
private init() {
// UserDefaults
let savedLanguage = UserDefaults.standard.string(forKey: "AppLanguage") ?? ""
self.currentLanguage = SupportedLanguage(rawValue: savedLanguage) ?? .english
// 使
if savedLanguage.isEmpty {
self.currentLanguage = Self.getSystemPreferredLanguage()
}
}
// MARK: -
///
/// - Parameters:
/// - key: key
/// - arguments:
/// - Returns:
func localizedString(_ key: String, arguments: CVarArg...) -> String {
let format = getLocalizedString(for: key)
if arguments.isEmpty {
return format
} else {
return String(format: format, arguments: arguments)
}
}
///
private func getLocalizedString(for key: String) -> String {
guard let path = Bundle.main.path(forResource: currentLanguage.rawValue, ofType: "lproj"),
let bundle = Bundle(path: path) else {
// key
return NSLocalizedString(key, comment: "")
}
return NSLocalizedString(key, bundle: bundle, comment: "")
}
// MARK: -
///
/// - Parameter language:
func switchLanguage(to language: SupportedLanguage) {
currentLanguage = language
}
///
///
private static func getSystemPreferredLanguage() -> SupportedLanguage {
//
//
return .english
}
}
// MARK: - SwiftUI Extensions
extension View {
///
/// - Parameter key: key
/// - Returns:
func localized(_ key: String) -> some View {
self.modifier(LocalizedTextModifier(key: key))
}
}
///
struct LocalizedTextModifier: ViewModifier {
let key: String
@ObservedObject private var localizationManager = LocalizationManager.shared
func body(content: Content) -> some View {
content
}
}
// MARK: - 便
extension String {
///
var localized: String {
return LocalizationManager.shared.localizedString(self)
}
///
func localized(arguments: CVarArg...) -> String {
return LocalizationManager.shared.localizedString(self, arguments: arguments)
}
}