From 87dfabcd01615b36e95d7bacb6e2688c7b627cf8 Mon Sep 17 00:00:00 2001 From: Jayden <95338403+linjie-firework@users.noreply.github.com> Date: Mon, 13 May 2024 09:51:39 +0800 Subject: [PATCH 1/4] [Bug] IOS Flutter SDK- Translation: English is not translated in the Subtitle section (#14) --- FireworkVideoUI.podspec | 2 +- .../AppLanguage/AppLanguageManager.swift | 2 +- .../Foundation/NSLocale+AppLanguage.swift | 49 +++++++++++++++++++ .../NumberFormatter+AppLanguage.swift | 25 ---------- .../Extensions/ObjCRuntime/Swizzle.swift | 17 ++++++- 5 files changed, 67 insertions(+), 28 deletions(-) create mode 100644 Sources/FireworkVideoUI/AppLanguage/Extensions/Foundation/NSLocale+AppLanguage.swift delete mode 100644 Sources/FireworkVideoUI/AppLanguage/Extensions/Foundation/NumberFormatter+AppLanguage.swift diff --git a/FireworkVideoUI.podspec b/FireworkVideoUI.podspec index 0e20e2f..8fbf8dd 100644 --- a/FireworkVideoUI.podspec +++ b/FireworkVideoUI.podspec @@ -1,6 +1,6 @@ Pod::Spec.new do |s| s.name = 'FireworkVideoUI' - s.version = '0.1.0' + s.version = '0.1.1' s.summary = 'An extension library meant to provide easier interfaces for the FireworkVideoSDK.' s.homepage = 'https://github.com/loopsocial/firework_ios_sdk_ui_extensions' s.license = 'Apache License, Version 2.0' diff --git a/Sources/FireworkVideoUI/AppLanguage/AppLanguageManager.swift b/Sources/FireworkVideoUI/AppLanguage/AppLanguageManager.swift index 89cac35..b227c8a 100644 --- a/Sources/FireworkVideoUI/AppLanguage/AppLanguageManager.swift +++ b/Sources/FireworkVideoUI/AppLanguage/AppLanguageManager.swift @@ -103,13 +103,13 @@ public class AppLanguageManager { UIViewController.swizzleViewControllerMethodsForAppLanguage() Bundle.swizzleBundleMethodsForAppLanguage() URLSession.swizzleURLSessionMethodsForAppLanguage() - NumberFormatter.swizzleNumberFormatterMethodsForAppLanguage() UIImageView.swizzleImageViewMethodsForAppLanguage() UILabel.swizzleLabelMethodsForAppLanguage() UITextField.swizzleTextFieldMethodsForAppLanguage() UITextView.swizzleTextViewMethodsForAppLanguage() UIWindow.swizzleWindowMethodsForAppLanguage() UIView.swizzleViewMethodsForAppLanguage() + NSLocale.swizzleNSLocaleMethodsForAppLanguage() } LayoutFlipManager.swizzelMethods() diff --git a/Sources/FireworkVideoUI/AppLanguage/Extensions/Foundation/NSLocale+AppLanguage.swift b/Sources/FireworkVideoUI/AppLanguage/Extensions/Foundation/NSLocale+AppLanguage.swift new file mode 100644 index 0000000..748b97b --- /dev/null +++ b/Sources/FireworkVideoUI/AppLanguage/Extensions/Foundation/NSLocale+AppLanguage.swift @@ -0,0 +1,49 @@ +// +// Locale+AppLanguage.swift +// +// Created by linjie jiang on 5/7/24. +// + +import Foundation + +extension NSLocale { + static func swizzleNSLocaleMethodsForAppLanguage() { + Swizzle.swizzleClassSelector( + cls: self, + originalSelector: #selector(getter: NSLocale.current), + customSelector: #selector(NSLocale.fw_current)) + Swizzle.swizzleClassSelector( + cls: self, + originalSelector: #selector(getter: NSLocale.autoupdatingCurrent), + customSelector: #selector(NSLocale.fw_autoupdatingCurrent)) + Swizzle.swizzleClassSelector( + cls: self, + originalSelector: #selector(getter: NSLocale.preferredLanguages), + customSelector: #selector(NSLocale.fw_preferredLanguages)) + } + + @objc class func fw_current() -> Locale { + if let language = AppLanguageManager.shared.appLanguage { + return Locale(identifier: language) + } + + return fw_current() + } + + @objc class func fw_autoupdatingCurrent() -> Locale { + if let language = AppLanguageManager.shared.appLanguage { + return Locale(identifier: language) + } + + return fw_autoupdatingCurrent() + } + + @objc class func fw_preferredLanguages() -> [String] { + let languages = fw_preferredLanguages() + if let language = AppLanguageManager.shared.appLanguage { + return [language] + languages + } + + return languages + } +} diff --git a/Sources/FireworkVideoUI/AppLanguage/Extensions/Foundation/NumberFormatter+AppLanguage.swift b/Sources/FireworkVideoUI/AppLanguage/Extensions/Foundation/NumberFormatter+AppLanguage.swift deleted file mode 100644 index 8a0735e..0000000 --- a/Sources/FireworkVideoUI/AppLanguage/Extensions/Foundation/NumberFormatter+AppLanguage.swift +++ /dev/null @@ -1,25 +0,0 @@ -// -// NumberFormatter+AppLanguage.swift -// -// Created by linjie jiang on 2023/2/20. -// - -import Foundation - -extension NumberFormatter { - static func swizzleNumberFormatterMethodsForAppLanguage() { - Swizzle.swizzleSelector( - cls: self, - originalSelector: #selector(NumberFormatter.string(from:)), - customSelector: #selector(NumberFormatter.fw_string(from:))) - } - - @objc func fw_string(from number: NSNumber) -> String? { - if let language = AppLanguageManager.shared.appLanguage, - self.numberStyle == .currency { - self.locale = Locale(identifier: language) - } - - return fw_string(from: number) - } -} diff --git a/Sources/FireworkVideoUI/Extensions/ObjCRuntime/Swizzle.swift b/Sources/FireworkVideoUI/Extensions/ObjCRuntime/Swizzle.swift index 401326a..a886f93 100644 --- a/Sources/FireworkVideoUI/Extensions/ObjCRuntime/Swizzle.swift +++ b/Sources/FireworkVideoUI/Extensions/ObjCRuntime/Swizzle.swift @@ -32,6 +32,21 @@ public class Swizzle { guard let originalMethod = class_getClassMethod(cls, originalSelector) else { return } guard let customMethod = class_getClassMethod(cls, customSelector) else { return } - method_exchangeImplementations(originalMethod, customMethod) + let clsType: AnyClass? = object_getClass(cls) + if class_addMethod( + clsType, + originalSelector, + method_getImplementation(customMethod), + method_getTypeEncoding(customMethod) + ) { + class_replaceMethod( + clsType, + customSelector, + method_getImplementation(originalMethod), + method_getTypeEncoding(originalMethod) + ) + } else { + method_exchangeImplementations(originalMethod, customMethod) + } } } From 14e9a0b08d18bfb162b8c782b523727ee0c3f495 Mon Sep 17 00:00:00 2001 From: Jayden <95338403+linjie-firework@users.noreply.github.com> Date: Mon, 20 May 2024 21:51:22 +0800 Subject: [PATCH 2/4] Bug fix: [Flutter SDK] [RTL] Some of the images/texts are in the wrong direction (#15) * Bug fix: [Flutter SDK] [RTL] Some of the images/texts are in the wrong direction * Update UIView+AppLanguage.swift --- .../Extensions/UIKit/UIView+AppLanguage.swift | 31 +++++++++++++++++++ .../Extensions/UIKit/UIView+LayoutFlip.swift | 10 ++++-- 2 files changed, 38 insertions(+), 3 deletions(-) diff --git a/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UIView+AppLanguage.swift b/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UIView+AppLanguage.swift index 8893eca..914642e 100644 --- a/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UIView+AppLanguage.swift +++ b/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UIView+AppLanguage.swift @@ -8,6 +8,10 @@ import UIKit import FireworkVideo import AVFoundation +private let gNamesOfImagesWithDirection: [String] = [ + "c3RyZWFtLWdhdGUtYmFjaw==".decodeBase64String(), +] + extension UIView { static func swizzleViewMethodsForAppLanguage() { Swizzle.swizzleSelector( @@ -61,6 +65,33 @@ extension UIView { } DispatchQueue.main.async { + if AppLanguageManager.shared.shouldHorizontalFlip { + let swiftUIImageLayerClassName = "SW1hZ2VMYXllcg==".decodeBase64String() + let swiftUITextLayerClassName = "Q0dEcmF3aW5nTGF5ZXI=".decodeBase64String() + let layerClassName = String(describing: type(of: self.layer)) + if layerClassName == swiftUITextLayerClassName { + view.viewType = .normal + } else if layerClassName == swiftUIImageLayerClassName { + var resultViewType = LayoutFlipViewType.normal + if let contents = self.layer.contents as? CFTypeRef, + CFGetTypeID(contents) == CGImage.typeID { + let image = self.layer.contents as! CGImage + for imageName in gNamesOfImagesWithDirection { + let imageWithDirection = UIImage( + named: imageName, + in: Bundle(for: FireworkVideoSDK.self), + compatibleWith: nil + )?.cgImage + if image == imageWithDirection { + resultViewType = .flip + break + } + } + } + view.viewType = resultViewType + } + } + if view.layer.sublayers?.first(where: { layer in layer is AVPlayerLayer }) != nil, AppLanguageManager.shared.shouldHorizontalFlip { diff --git a/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/UIView+LayoutFlip.swift b/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/UIView+LayoutFlip.swift index c23bb00..9577206 100644 --- a/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/UIView+LayoutFlip.swift +++ b/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/UIView+LayoutFlip.swift @@ -17,8 +17,8 @@ private let gNoFlipClasses: [Any] = [ "PUPhotosSectionHeaderContentView", "UITableViewIndex", "UIWebView", - "X1VJUmVtb3RlVmlldw==".decodeBase64String(), // _UIRemoteView - "VUlBdXRvY29ycmVjdFRleHRWaWV3".decodeBase64String() // UIAutocorrectTextView + "X1VJUmVtb3RlVmlldw==".decodeBase64String(), + "VUlBdXRvY29ycmVjdFRleHRWaWV3".decodeBase64String(), ] enum LayoutFlipViewType: Int { @@ -151,7 +151,11 @@ extension UIView { let shouldSetFlipTransform = shouldFlipSuperview != shouldFlipCurrentView if shouldSetFlipTransform && LayoutFlipManager.shared.enableHorizontalFlip { - layer.basicTransform = CGAffineTransformMakeScale(-1, 1) + if layer.anchorPoint == CGPointZero { + layer.basicTransform = CGAffineTransformConcat(CGAffineTransformMakeScale(-1, 1), CGAffineTransform(translationX: layer.bounds.width, y: 0)) + } else { + layer.basicTransform = CGAffineTransformMakeScale(-1, 1) + } } else { layer.basicTransform = CGAffineTransformIdentity } From 48a0c89a125098db8c88e04664cbd2df2068762d Mon Sep 17 00:00:00 2001 From: Jayden <95338403+linjie-firework@users.noreply.github.com> Date: Mon, 20 May 2024 22:23:20 +0800 Subject: [PATCH 3/4] Fix warning: Forming 'UnsafeRawPointer' to an inout variable of type String exposes the internal representation rather than the string contents. (#16) --- .../AppLanguage/Extensions/UIKit/UILabel+AppLanguage.swift | 2 +- .../Extensions/UIKit/UITextField+AppLanguage.swift | 2 +- .../Extensions/UIKit/UITextView+AppLanguage.swift | 2 +- .../Extensions/Foundation/NSObject+LayoutFlip.swift | 2 +- .../LayoutFlip/Extensions/UIKit/CALayer+LayoutFlip.swift | 6 +++--- .../LayoutFlip/Extensions/UIKit/UIView+LayoutFlip.swift | 6 +++--- 6 files changed, 10 insertions(+), 10 deletions(-) diff --git a/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UILabel+AppLanguage.swift b/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UILabel+AppLanguage.swift index 97dc013..4059e7a 100644 --- a/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UILabel+AppLanguage.swift +++ b/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UILabel+AppLanguage.swift @@ -8,7 +8,7 @@ import UIKit extension UILabel { private struct AssociatedKeys { - static var hasCalculatedTextAlignment = "hasCalculatedTextAlignmentKey" + static var hasCalculatedTextAlignment: UInt8 = 0 } private var hasCalculatedTextAlignment: Bool { diff --git a/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UITextField+AppLanguage.swift b/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UITextField+AppLanguage.swift index f5f0b78..9acd08c 100644 --- a/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UITextField+AppLanguage.swift +++ b/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UITextField+AppLanguage.swift @@ -8,7 +8,7 @@ import UIKit extension UITextField { private struct AssociatedKeys { - static var hasCalculatedTextAlignment = "hasCalculatedTextAlignmentKey" + static var hasCalculatedTextAlignment: UInt8 = 0 } private var hasCalculatedTextAlignment: Bool { diff --git a/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UITextView+AppLanguage.swift b/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UITextView+AppLanguage.swift index d9d2f95..a1c02ee 100644 --- a/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UITextView+AppLanguage.swift +++ b/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UITextView+AppLanguage.swift @@ -8,7 +8,7 @@ import UIKit extension UITextView { private struct AssociatedKeys { - static var hasCalculatedTextAlignment = "hasCalculatedTextAlignmentKey" + static var hasCalculatedTextAlignment: UInt8 = 0 } private var hasCalculatedTextAlignment: Bool { diff --git a/Sources/FireworkVideoUI/LayoutFlip/Extensions/Foundation/NSObject+LayoutFlip.swift b/Sources/FireworkVideoUI/LayoutFlip/Extensions/Foundation/NSObject+LayoutFlip.swift index 42091eb..d39257d 100644 --- a/Sources/FireworkVideoUI/LayoutFlip/Extensions/Foundation/NSObject+LayoutFlip.swift +++ b/Sources/FireworkVideoUI/LayoutFlip/Extensions/Foundation/NSObject+LayoutFlip.swift @@ -10,7 +10,7 @@ typealias ReloadClosure = () -> Void extension NSObject { private struct AssociatedKeys { - static var reloadClosures = "reloadBlocks" + static var reloadClosures: UInt8 = 0 } private var reloadClosures: [String: ReloadClosure] { diff --git a/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/CALayer+LayoutFlip.swift b/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/CALayer+LayoutFlip.swift index 5d4ffe4..34be76b 100644 --- a/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/CALayer+LayoutFlip.swift +++ b/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/CALayer+LayoutFlip.swift @@ -8,9 +8,9 @@ import UIKit extension CALayer { private struct AssociatedKeys { - static var basicTransform = "basicTransform" - static var isRenderStartLayer = "isRenderStartLayer" - static var affineTransform = "affineTransform" + static var basicTransform: UInt8 = 0 + static var isRenderStartLayer: UInt8 = 0 + static var affineTransform: UInt8 = 0 } static func swizzleLayerMethodsForLayoutFlip() { diff --git a/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/UIView+LayoutFlip.swift b/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/UIView+LayoutFlip.swift index 9577206..e459aea 100644 --- a/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/UIView+LayoutFlip.swift +++ b/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/UIView+LayoutFlip.swift @@ -32,9 +32,9 @@ enum LayoutFlipViewType: Int { extension UIView { private struct AssociatedKeys { - static var viewType = "viewType" - static var calculatedViewType = "calculatedViewType" - static var lastType = "lastType" + static var viewType: UInt8 = 0 + static var calculatedViewType: UInt8 = 0 + static var lastType: UInt8 = 0 } static func swizzleViewMethodsForLayoutFlip() { From fabca5c47495256a6ebcbc93c31f52b1c5cc6068 Mon Sep 17 00:00:00 2001 From: Jayden <95338403+linjie-firework@users.noreply.github.com> Date: Thu, 23 May 2024 19:12:52 +0800 Subject: [PATCH 4/4] [CPS-830] Bug fix: iOS RN SDK - DS - Invalid access token overlaps with the icon (#18) * Bug fix: CPS-830 * Update FireworkVideoUI.podspec --- FireworkVideoUI.podspec | 2 +- .../Extensions/UIKit/UIView+AppLanguage.swift | 47 ++++++++++--------- .../Extensions/UIKit/UIView+LayoutFlip.swift | 9 ++++ 3 files changed, 34 insertions(+), 24 deletions(-) diff --git a/FireworkVideoUI.podspec b/FireworkVideoUI.podspec index 8fbf8dd..e4ea145 100644 --- a/FireworkVideoUI.podspec +++ b/FireworkVideoUI.podspec @@ -1,6 +1,6 @@ Pod::Spec.new do |s| s.name = 'FireworkVideoUI' - s.version = '0.1.1' + s.version = '0.1.2' s.summary = 'An extension library meant to provide easier interfaces for the FireworkVideoSDK.' s.homepage = 'https://github.com/loopsocial/firework_ios_sdk_ui_extensions' s.license = 'Apache License, Version 2.0' diff --git a/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UIView+AppLanguage.swift b/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UIView+AppLanguage.swift index 914642e..7f733ba 100644 --- a/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UIView+AppLanguage.swift +++ b/Sources/FireworkVideoUI/AppLanguage/Extensions/UIKit/UIView+AppLanguage.swift @@ -64,31 +64,32 @@ extension UIView { view.viewType = .normal } + let swiftUIImageLayerClassName = "SW1hZ2VMYXllcg==".decodeBase64String() + let swiftUITextLayerClassName = "Q0dEcmF3aW5nTGF5ZXI=".decodeBase64String() + let layerClassName = String(describing: type(of: self.layer)) + + if AppLanguageManager.shared.shouldHorizontalFlip, + layerClassName == swiftUITextLayerClassName || + layerClassName == swiftUIImageLayerClassName { + view.viewType = .normal + } + DispatchQueue.main.async { - if AppLanguageManager.shared.shouldHorizontalFlip { - let swiftUIImageLayerClassName = "SW1hZ2VMYXllcg==".decodeBase64String() - let swiftUITextLayerClassName = "Q0dEcmF3aW5nTGF5ZXI=".decodeBase64String() - let layerClassName = String(describing: type(of: self.layer)) - if layerClassName == swiftUITextLayerClassName { - view.viewType = .normal - } else if layerClassName == swiftUIImageLayerClassName { - var resultViewType = LayoutFlipViewType.normal - if let contents = self.layer.contents as? CFTypeRef, - CFGetTypeID(contents) == CGImage.typeID { - let image = self.layer.contents as! CGImage - for imageName in gNamesOfImagesWithDirection { - let imageWithDirection = UIImage( - named: imageName, - in: Bundle(for: FireworkVideoSDK.self), - compatibleWith: nil - )?.cgImage - if image == imageWithDirection { - resultViewType = .flip - break - } - } + if AppLanguageManager.shared.shouldHorizontalFlip, + layerClassName == swiftUIImageLayerClassName, + let contents = self.layer.contents as? CFTypeRef, + CFGetTypeID(contents) == CGImage.typeID { + let image = self.layer.contents as! CGImage + for imageName in gNamesOfImagesWithDirection { + let imageWithDirection = UIImage( + named: imageName, + in: Bundle(for: FireworkVideoSDK.self), + compatibleWith: nil + )?.cgImage + if image == imageWithDirection { + view.viewType = .flip + break } - view.viewType = resultViewType } } diff --git a/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/UIView+LayoutFlip.swift b/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/UIView+LayoutFlip.swift index e459aea..a7fb95f 100644 --- a/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/UIView+LayoutFlip.swift +++ b/Sources/FireworkVideoUI/LayoutFlip/Extensions/UIKit/UIView+LayoutFlip.swift @@ -50,6 +50,10 @@ extension UIView { cls: self, originalSelector: #selector(UIView.snapshotView(afterScreenUpdates:)), customSelector: #selector(UIView.fw_snapshotView(afterScreenUpdates:))) + Swizzle.swizzleSelector( + cls: self, + originalSelector: #selector(UIView.layoutSubviews), + customSelector: #selector(UIView.fw_layoutSubviews)) } var viewType: LayoutFlipViewType { @@ -137,6 +141,11 @@ extension UIView { return view } + @objc func fw_layoutSubviews() { + fw_layoutSubviews() + renewLayerTransformForceRecursively(false) + } + func renewLayerTransformForceRecursively(_ forceRecursively: Bool) { if !isIOSSDKView { return