mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-11-08 09:49:51 +00:00
Voice Chat UI fixes
This commit is contained in:
parent
d94f541205
commit
025a21fc49
@ -5968,3 +5968,5 @@ Sorry for the inconvenience.";
|
|||||||
"VoiceChat.Panel.MembersSpeaking_3_10" = "%@ members speaking";
|
"VoiceChat.Panel.MembersSpeaking_3_10" = "%@ members speaking";
|
||||||
"VoiceChat.Panel.MembersSpeaking_many" = "%@ members speaking";
|
"VoiceChat.Panel.MembersSpeaking_many" = "%@ members speaking";
|
||||||
"VoiceChat.Panel.MembersSpeaking_any" = "%@ members speaking";
|
"VoiceChat.Panel.MembersSpeaking_any" = "%@ members speaking";
|
||||||
|
|
||||||
|
"ChannelInfo.CreateVoiceChat" = "Create Voice Chat";
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
Binary file not shown.
@ -496,6 +496,40 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G
|
|||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
case let .groupPhoneCall(callId, accessHash, duration):
|
||||||
|
let peerId = message.id.peerId
|
||||||
|
if duration == nil {
|
||||||
|
let callResult = strongSelf.context.sharedContext.callManager?.joinGroupCall(context: strongSelf.context, peerId: peerId, initialCall: CachedChannelData.ActiveCall(id: callId, accessHash: accessHash), endCurrentIfAny: false, sourcePanel: nil)
|
||||||
|
if let callResult = callResult, case let .alreadyInProgress(currentPeerId) = callResult {
|
||||||
|
if currentPeerId == peerId {
|
||||||
|
strongSelf.context.sharedContext.navigateToCurrentCall(sourcePanel: nil)
|
||||||
|
} else {
|
||||||
|
let presentationData = strongSelf.context.sharedContext.currentPresentationData.with { $0 }
|
||||||
|
let _ = (strongSelf.context.account.postbox.transaction { transaction -> (Peer?, Peer?) in
|
||||||
|
return (transaction.getPeer(peerId), currentPeerId.flatMap(transaction.getPeer))
|
||||||
|
}
|
||||||
|
|> deliverOnMainQueue).start(next: { [weak self] peer, current in
|
||||||
|
guard let strongSelf = self else {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
guard let peer = peer else {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if let current = current {
|
||||||
|
strongSelf.present(textAlertController(context: strongSelf.context, title: presentationData.strings.Call_CallInProgressTitle, text: presentationData.strings.Call_CallInProgressMessage(current.compactDisplayTitle, peer.compactDisplayTitle).0, actions: [TextAlertAction(type: .defaultAction, title: presentationData.strings.Common_Cancel, action: {}), TextAlertAction(type: .genericAction, title: presentationData.strings.Common_OK, action: {
|
||||||
|
if let strongSelf = self {
|
||||||
|
let _ = strongSelf.context.sharedContext.callManager?.joinGroupCall(context: strongSelf.context, peerId: peerId, initialCall: CachedChannelData.ActiveCall(id: callId, accessHash: accessHash), endCurrentIfAny: true, sourcePanel: nil)
|
||||||
|
}
|
||||||
|
})]), in: .window(.root))
|
||||||
|
} else {
|
||||||
|
strongSelf.present(textAlertController(context: strongSelf.context, title: presentationData.strings.Call_CallInProgressTitle, text: presentationData.strings.Call_ExternalCallInProgressMessage, actions: [TextAlertAction(type: .genericAction, title: presentationData.strings.Common_OK, action: {
|
||||||
|
})]), in: .window(.root))
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break
|
||||||
default:
|
default:
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
|||||||
@ -2968,8 +2968,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD
|
|||||||
} else if let channel = peer as? TelegramChannel {
|
} else if let channel = peer as? TelegramChannel {
|
||||||
if case .group = channel.info, !channel.flags.contains(.hasVoiceChat) {
|
if case .group = channel.info, !channel.flags.contains(.hasVoiceChat) {
|
||||||
if channel.flags.contains(.isCreator) || channel.hasPermission(.manageCalls) {
|
if channel.flags.contains(.isCreator) || channel.hasPermission(.manageCalls) {
|
||||||
//TODO:localize
|
items.append(ActionSheetButtonItem(title: presentationData.strings.ChannelInfo_CreateVoiceChat, color: .accent, action: { [weak self] in
|
||||||
items.append(ActionSheetButtonItem(title: "Create Voice Chat", color: .accent, action: { [weak self] in
|
|
||||||
dismissAction()
|
dismissAction()
|
||||||
self?.requestCall(isVideo: false)
|
self?.requestCall(isVideo: false)
|
||||||
}))
|
}))
|
||||||
@ -3182,39 +3181,73 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD
|
|||||||
|
|
||||||
if let activeCall = cachedChannelData.activeCall {
|
if let activeCall = cachedChannelData.activeCall {
|
||||||
let _ = self.context.sharedContext.callManager?.joinGroupCall(context: self.context, peerId: peer.id, initialCall: activeCall, endCurrentIfAny: false, sourcePanel: nil)
|
let _ = self.context.sharedContext.callManager?.joinGroupCall(context: self.context, peerId: peer.id, initialCall: activeCall, endCurrentIfAny: false, sourcePanel: nil)
|
||||||
} else {
|
} else if let callManager = self.context.sharedContext.callManager {
|
||||||
var dismissStatus: (() -> Void)?
|
let startCall: (Bool) -> Void = { [weak self] endCurrentIfAny in
|
||||||
let statusController = OverlayStatusController(theme: self.presentationData.theme, type: .loading(cancelled: {
|
guard let strongSelf = self else {
|
||||||
dismissStatus?()
|
return
|
||||||
}))
|
}
|
||||||
dismissStatus = { [weak self, weak statusController] in
|
|
||||||
self?.activeActionDisposable.set(nil)
|
var dismissStatus: (() -> Void)?
|
||||||
statusController?.dismiss()
|
let statusController = OverlayStatusController(theme: strongSelf.presentationData.theme, type: .loading(cancelled: {
|
||||||
|
dismissStatus?()
|
||||||
|
}))
|
||||||
|
dismissStatus = { [weak self, weak statusController] in
|
||||||
|
self?.activeActionDisposable.set(nil)
|
||||||
|
statusController?.dismiss()
|
||||||
|
}
|
||||||
|
strongSelf.controller?.present(statusController, in: .window(.root))
|
||||||
|
strongSelf.activeActionDisposable.set((createGroupCall(account: strongSelf.context.account, peerId: peer.id)
|
||||||
|
|> deliverOnMainQueue).start(next: { [weak self] info in
|
||||||
|
guard let strongSelf = self else {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
let _ = strongSelf.context.sharedContext.callManager?.joinGroupCall(context: strongSelf.context, peerId: peer.id, initialCall: CachedChannelData.ActiveCall(id: info.id, accessHash: info.accessHash), endCurrentIfAny: endCurrentIfAny, sourcePanel: nil)
|
||||||
|
}, error: { [weak self] _ in
|
||||||
|
dismissStatus?()
|
||||||
|
|
||||||
|
guard let strongSelf = self else {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel)
|
||||||
|
}, completed: { [weak self] in
|
||||||
|
dismissStatus?()
|
||||||
|
|
||||||
|
guard let strongSelf = self else {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel)
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
self.controller?.present(statusController, in: .window(.root))
|
|
||||||
self.activeActionDisposable.set((createGroupCall(account: self.context.account, peerId: peer.id)
|
|
||||||
|> deliverOnMainQueue).start(next: { [weak self] info in
|
|
||||||
guard let strongSelf = self else {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
let _ = strongSelf.context.sharedContext.callManager?.joinGroupCall(context: strongSelf.context, peerId: peer.id, initialCall: CachedChannelData.ActiveCall(id: info.id, accessHash: info.accessHash), endCurrentIfAny: false, sourcePanel: nil)
|
|
||||||
}, error: { [weak self] _ in
|
|
||||||
dismissStatus?()
|
|
||||||
|
|
||||||
|
let _ = (callManager.currentGroupCallSignal
|
||||||
|
|> take(1)
|
||||||
|
|> deliverOnMainQueue).start(next: { [weak self] activeCall in
|
||||||
guard let strongSelf = self else {
|
guard let strongSelf = self else {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel)
|
|
||||||
}, completed: { [weak self] in
|
|
||||||
dismissStatus?()
|
|
||||||
|
|
||||||
guard let strongSelf = self else {
|
if let activeCall = activeCall {
|
||||||
return
|
let currentPeerId = activeCall.peerId
|
||||||
|
let presentationData = strongSelf.context.sharedContext.currentPresentationData.with { $0 }
|
||||||
|
let _ = (strongSelf.context.account.postbox.transaction { transaction -> (Peer?, Peer?) in
|
||||||
|
return (transaction.getPeer(peer.id), transaction.getPeer(currentPeerId))
|
||||||
|
} |> deliverOnMainQueue).start(next: { [weak self] peer, current in
|
||||||
|
if let peer = peer {
|
||||||
|
if let strongSelf = self, let current = current {
|
||||||
|
strongSelf.controller?.present(textAlertController(context: strongSelf.context, title: presentationData.strings.Call_CallInProgressTitle, text: presentationData.strings.Call_CallInProgressMessage(current.compactDisplayTitle, peer.compactDisplayTitle).0, actions: [TextAlertAction(type: .defaultAction, title: presentationData.strings.Common_Cancel, action: {}), TextAlertAction(type: .genericAction, title: presentationData.strings.Common_OK, action: {
|
||||||
|
startCall(true)
|
||||||
|
})]), in: .window(.root))
|
||||||
|
} else {
|
||||||
|
strongSelf.controller?.present(textAlertController(context: strongSelf.context, title: presentationData.strings.Call_CallInProgressTitle, text: presentationData.strings.Call_ExternalCallInProgressMessage, actions: [TextAlertAction(type: .genericAction, title: presentationData.strings.Common_OK, action: {
|
||||||
|
})]), in: .window(.root))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
startCall(false)
|
||||||
}
|
}
|
||||||
strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel)
|
})
|
||||||
}))
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user