Skip to content

Commit

Permalink
1.9.0 (385)
Browse files Browse the repository at this point in the history
  • Loading branch information
denis15yo committed Nov 28, 2024
1 parent 5286949 commit 1e4ca47
Show file tree
Hide file tree
Showing 40 changed files with 1,168 additions and 374 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -81,3 +81,4 @@ submodules/FFMpegBinding/SharedHeaders/*
submodules/OpenSSLEncryptionProvider/SharedHeaders/*


*.storekit
6 changes: 3 additions & 3 deletions MODULE.bazel.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions Nicegram/NGData/BUILD
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ swift_library(
"//Nicegram/NGEnv:NGEnv",
"//Nicegram/NGAppCache:NGAppCache",
"@swiftpkg_nicegram_assistant_ios//:NGCore",
"@swiftpkg_nicegram_assistant_ios//:FeatBilling"
],
visibility = [
"//visibility:public",
Expand Down
41 changes: 30 additions & 11 deletions Nicegram/NGData/Sources/NGSettings.swift
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import FeatPremium
import FeatBilling
import Postbox
import Foundation
import NGAppCache
Expand Down Expand Up @@ -57,6 +58,9 @@ public struct NGSettings {

@NGStorage(key: "rememberFolderOnExit", defaultValue: false)
public static var rememberFolderOnExit: Bool

@NGStorage(key: "useOpenAI", defaultValue: false)
public static var useOpenAI: Bool

@NGStorage(key: "lastFolder", defaultValue: -1)
public static var lastFolder: Int32
Expand Down Expand Up @@ -124,6 +128,9 @@ public struct NGSettings {

@NGStorage(key: "hideMentionNotification", defaultValue: false)
public static var hideMentionNotification: Bool

@NGStorage(key: "appleSpeechToTextLocale", defaultValue: [:])
public static var appleSpeechToTextLocale: [Int64: Locale]
}

public struct NGWebSettings {
Expand Down Expand Up @@ -151,30 +158,33 @@ public struct NGSharedSettings {

public var VarNGSharedSettings = NGSharedSettings()

public func checkPremium(completion: @escaping (Bool) -> Void) {
Task {
let refreshPremiumSubStatusUseCase = BillingContainer.shared.refreshPremiumSubStatusUseCase()
await refreshPremiumSubStatusUseCase()

await MainActor.run {
completion(PremiumContainer.shared.getPremiumStatusUseCase().hasPremiumOnDevice())
}
}
}

public func isPremium() -> Bool {
if #available(iOS 13.0, *) {
#if DEBUG
return true
#else
return PremiumContainer.shared
.getPremiumStatusUseCase()
.hasPremiumOnDevice()
#endif
} else {
return false
}
}

public func usetrButton() -> [(Bool, [String])] {
if isPremium() {
var ignoredLangs = NGSettings.ignoreTranslate
if !NGSettings.useIgnoreLanguages {
ignoredLangs = []
}
return [(NGSettings.oneTapTr, ignoredLangs)]
var ignoredLangs = NGSettings.ignoreTranslate
if !NGSettings.useIgnoreLanguages {
ignoredLangs = []
}
return [(false, [])]
return [(NGSettings.oneTapTr, ignoredLangs)]
}

public class SystemNGSettings {
Expand Down Expand Up @@ -217,6 +227,15 @@ public class SystemNGSettings {
UD.set(newValue, forKey: "inDoubleBottom")
}
}

public var hideReactionsToYourMessages: Bool {
get {
return UD.bool(forKey: "hideReactionsToYourMessages")
}
set {
UD.set(newValue, forKey: "hideReactionsToYourMessages")
}
}
}

public var VarSystemNGSettings = SystemNGSettings()
26 changes: 26 additions & 0 deletions Nicegram/NGSpeechToText/BUILD
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
load("@build_bazel_rules_swift//swift:swift.bzl", "swift_library")

swift_library(
name = "NGSpeechToText",
module_name = "NGSpeechToText",
srcs = glob([
"Sources/**/*.swift",
]),
deps = [
"//submodules/AccountContext:AccountContext",
"//submodules/Display:Display",
"//submodules/ItemListUI:ItemListUI",
"//submodules/SSignalKit/SwiftSignalKit:SwiftSignalKit",
"//submodules/TelegramCore:TelegramCore",
"//submodules/TelegramPresentationData:TelegramPresentationData",
"//submodules/PresentationDataUtils:PresentationDataUtils",
"//submodules/TelegramUI/Components/ChatControllerInteraction",
"//submodules/TranslateUI:TranslateUI",
"//submodules/Media/ConvertOpusToAAC",
"//Nicegram/NGUI:NGUI",
"@swiftpkg_nicegram_assistant_ios//:FeatPremiumUI",
],
visibility = [
"//visibility:public",
],
)
237 changes: 237 additions & 0 deletions Nicegram/NGSpeechToText/Sources/ConvertSpeechToText.swift
Original file line number Diff line number Diff line change
@@ -0,0 +1,237 @@
import Foundation
import TelegramCore
import ChatControllerInteraction
import Postbox
import FeatPremiumUI
import AccountContext
import TelegramPresentationData
import NGData
import NGUI

public enum SpeechToTextMessageSource {
case chat, contextMenu
}

public func convertSpeechToText(
from source: SpeechToTextMessageSource = .chat,
languageStyle: RecognitionLanguagesControllerStyle = .normal,
context: AccountContext,
mediaFile: TelegramMediaFile,
message: Message?,
presentationData: PresentationData,
controllerInteraction: ChatControllerInteraction,
completion: (() -> Void)? = nil,
closeWithoutSelect: (() -> Void)? = nil
) {
var id: Int64?
if let peer = message?.peers.toDict().first?.value {
switch EnginePeer(peer) {
case let .channel(channel):
id = channel.id.toInt64()
case let .legacyGroup(group):
id = group.id.toInt64()
case let .user(user):
id = user.id.toInt64()
default:
return
}
}

checkPremium { isPremium in
if isPremium &&
NGSettings.useOpenAI {
startConvertSpeechToTextTask(
from: source,
context: context,
mediaFile: mediaFile,
source: .openAI,
message: message,
presentationData: presentationData,
controllerInteraction: controllerInteraction,
completion: completion
)
} else {
if let id,
let locale = NGSettings.appleSpeechToTextLocale[id],
languageStyle == .normal {
startConvertSpeechToTextTask(
from: source,
context: context,
mediaFile: mediaFile,
source: .apple(locale),
message: message,
presentationData: presentationData,
controllerInteraction: controllerInteraction,
completion: completion
)
} else {
let appleSpeechToTextLocale = NGSettings.appleSpeechToTextLocale
let currentLocale = appleSpeechToTextLocale[id]

showLanguages(
with: context,
controllerInteraction: controllerInteraction,
style: languageStyle,
currentLocale: currentLocale
) { locale in
if let id {
var appleSpeechToTextLocale = NGSettings.appleSpeechToTextLocale
appleSpeechToTextLocale[id] = locale
NGSettings.appleSpeechToTextLocale = appleSpeechToTextLocale
}
_ = controllerInteraction.navigationController()?.popViewController(animated: true)
startConvertSpeechToTextTask(
from: source,
context: context,
mediaFile: mediaFile,
source: .apple(locale),
message: message,
presentationData: presentationData,
controllerInteraction: controllerInteraction,
completion: completion
)
} selectWhisper: {
_ = controllerInteraction.navigationController()?.popViewController(animated: true)

if (isPremium) {
controllerInteraction.navigationController()?.pushViewController(premiumController(context: context))
} else {
PremiumUITgHelper.routeToPremium(
source: .settings
)
}
} closeWithoutSelect: {
closeWithoutSelect?()
}
}
}
}
}

private func showLanguages(
with context: AccountContext,
controllerInteraction: ChatControllerInteraction,
style: RecognitionLanguagesControllerStyle = .normal,
currentLocale: Locale?,
selectLocale: @escaping (Locale) -> Void,
selectWhisper: @escaping () -> Void,
closeWithoutSelect: @escaping () -> Void
) {
let controller = recognitionLanguagesController(
context: context,
style: style,
currentLocale: currentLocale,
selectLocale: selectLocale,
selectWhisper: selectWhisper,
closeWithoutSelect: closeWithoutSelect
)
controller.navigationPresentation = .modal

controllerInteraction.navigationController()?.pushViewController(controller, animated: true)
}

private func startConvertSpeechToTextTask(
from messageSource: SpeechToTextMessageSource,
context: AccountContext,
mediaFile: TelegramMediaFile,
source: TgSpeechToTextManager.Source,
message: Message?,
presentationData: PresentationData,
controllerInteraction: ChatControllerInteraction,
completion: (() -> Void)? = nil
) {
Task { @MainActor in
let manager = TgSpeechToTextManager(
accountContext: context
)

if messageSource == .contextMenu {
message?.setSpeechToTextLoading(context: context)
}

let result = await manager.convertSpeechToText(
mediaFile: mediaFile,
source: source
)

switch result {
case .success(let text):
switch messageSource {
case .chat:
message?.updateAudioTranscriptionAttribute(text: text, error: nil, context: context)
case .contextMenu:
message?.setSpeechToTextTranslation(text, context: context)
}
case .needsPremium:
PremiumUITgHelper.routeToPremium(
source: .speechToText
)
case .error(let error):
switch error {
case .recognition(_):
if messageSource == .contextMenu {
message?.removeSpeechToTextMeta(context: context)
}
convertSpeechToText(
from: messageSource,
languageStyle: .whisper,
context: context,
mediaFile: mediaFile,
message: message,
presentationData: presentationData,
controllerInteraction: controllerInteraction
)
case .notAvailable:
if messageSource == .contextMenu {
message?.removeSpeechToTextMeta(context: context)
}
let c = getIAPErrorController(
context: context,
"Speech to text recognizer not available.",
presentationData
)
controllerInteraction.presentGlobalOverlayController(c, nil)
case .authorizationStatus:
if messageSource == .contextMenu {
message?.removeSpeechToTextMeta(context: context)
}
let c = getIAPErrorController(
context: context,
"Speech to text recognizer autorization status error.",
presentationData
)
controllerInteraction.presentGlobalOverlayController(c, nil)
case let .api(error):
switch messageSource {
case .chat:
message?.updateAudioTranscriptionAttribute(text: "", error: error, context: context)
case .contextMenu:
message?.removeSpeechToTextMeta(context: context)
}

let c = getIAPErrorController(
context: context,
error.localizedDescription,
presentationData
)
controllerInteraction.presentGlobalOverlayController(c, nil)
case let .other(error):
switch messageSource {
case .chat:
message?.updateAudioTranscriptionAttribute(text: "", error: error, context: context)
case .contextMenu:
message?.removeSpeechToTextMeta(context: context)
}

let c = getIAPErrorController(
context: context,
error.localizedDescription,
presentationData
)
controllerInteraction.presentGlobalOverlayController(c, nil)
}
}

completion?()
}
}
Loading

0 comments on commit 1e4ca47

Please sign in to comment.