Merge commit '7621e2f8dec938cf48181c8b10afc9b01f444e68' into beta

This commit is contained in:
Ilya Laktyushin
2025-12-06 02:17:48 +04:00
commit 8344b97e03
28070 changed files with 7995182 additions and 0 deletions
@@ -0,0 +1,57 @@
import Foundation
import SwiftSignalKit
import AudioToolbox
import AppBundle
private func loadSystemSoundFromBundle(name: String) -> SystemSoundID? {
let path = "\(getAppBundle().resourcePath!)/\(name)"
let url = URL(fileURLWithPath: path)
var sound: SystemSoundID = 0
if AudioServicesCreateSystemSoundID(url as CFURL, &sound) == noErr {
return sound
}
return nil
}
public final class ServiceSoundManager {
private let queue = Queue()
private var messageDeliverySound: SystemSoundID?
private var incomingMessageSound: SystemSoundID?
init() {
self.queue.async {
self.messageDeliverySound = loadSystemSoundFromBundle(name: "MessageSent.mp3")
self.incomingMessageSound = loadSystemSoundFromBundle(name: "notification.mp3")
}
}
public func playMessageDeliveredSound() {
self.queue.async {
if let messageDeliverySound = self.messageDeliverySound {
AudioServicesPlaySystemSound(messageDeliverySound)
}
}
}
public func playIncomingMessageSound() {
self.queue.async {
if let incomingMessageSound = self.incomingMessageSound {
AudioServicesPlaySystemSound(incomingMessageSound)
}
}
}
public func playVibrationSound() {
self.queue.async {
AudioServicesPlaySystemSound(kSystemSoundID_Vibrate)
}
}
public func playLockSound() {
self.queue.async {
AudioServicesPlaySystemSound(1100)
}
}
}
public let serviceSoundManager = ServiceSoundManager()