forked from mirrors/linphone-iphone
136 lines
3.8 KiB
Swift
136 lines
3.8 KiB
Swift
/*
|
|
* Copyright (c) 2010-2023 Belledonne Communications SARL.
|
|
*
|
|
* This file is part of linphone-iphone
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
import SwiftUI
|
|
import linphonesw
|
|
import UniformTypeIdentifiers
|
|
|
|
struct SideMenu: View {
|
|
|
|
@ObservedObject private var coreContext = CoreContext.shared
|
|
|
|
@ObservedObject var callViewModel: CallViewModel
|
|
|
|
let width: CGFloat
|
|
let isOpen: Bool
|
|
let menuClose: () -> Void
|
|
let safeAreaInsets: EdgeInsets
|
|
|
|
var body: some View {
|
|
ZStack {
|
|
GeometryReader { _ in
|
|
EmptyView()
|
|
}
|
|
.background(Color.gray.opacity(0.3))
|
|
.opacity(self.isOpen ? 1.0 : 0.0)
|
|
.onTapGesture {
|
|
self.menuClose()
|
|
}
|
|
|
|
HStack {
|
|
List {
|
|
/*
|
|
Text("My Profile")
|
|
.frame(height: 40)
|
|
.frame(maxWidth: .infinity, alignment: .leading)
|
|
.background(Color.white)
|
|
.onTapGesture {
|
|
print("My Profile")
|
|
self.menuClose()
|
|
}
|
|
*/
|
|
Text("Send logs")
|
|
.frame(height: 40)
|
|
.frame(maxWidth: .infinity, alignment: .leading)
|
|
.background(Color.white)
|
|
.onTapGesture {
|
|
print("Send logs")
|
|
sendLogs()
|
|
self.menuClose()
|
|
}
|
|
Text("Clear logs")
|
|
.frame(height: 40)
|
|
.frame(maxWidth: .infinity, alignment: .leading)
|
|
.background(Color.white)
|
|
.onTapGesture {
|
|
print("Clear logs")
|
|
clearLogs()
|
|
self.menuClose()
|
|
}
|
|
Text("Logout")
|
|
.frame(height: 40)
|
|
.frame(maxWidth: .infinity, alignment: .leading)
|
|
.background(Color.white)
|
|
.onTapGesture {
|
|
print("Logout")
|
|
logout()
|
|
self.menuClose()
|
|
}
|
|
}
|
|
.frame(width: self.width - safeAreaInsets.leading)
|
|
.background(Color.white)
|
|
.offset(x: self.isOpen ? 0 : -self.width)
|
|
|
|
Spacer()
|
|
}
|
|
.padding(.leading, safeAreaInsets.leading)
|
|
.padding(.top, TelecomManager.shared.callInProgress ? 0 : safeAreaInsets.top)
|
|
.padding(.bottom, safeAreaInsets.bottom)
|
|
}
|
|
.frame(maxWidth: .infinity, maxHeight: .infinity)
|
|
}
|
|
|
|
func sendLogs() {
|
|
coreContext.doOnCoreQueue { core in
|
|
core.uploadLogCollection()
|
|
}
|
|
}
|
|
|
|
func clearLogs() {
|
|
coreContext.doOnCoreQueue { core in
|
|
Core.resetLogCollection()
|
|
DispatchQueue.main.async {
|
|
ToastViewModel.shared.toastMessage = "Success_clear_logs"
|
|
ToastViewModel.shared.displayToast = true
|
|
}
|
|
}
|
|
}
|
|
|
|
func logout() {
|
|
coreContext.doOnCoreQueue { core in
|
|
if core.defaultAccount != nil {
|
|
let authInfo = core.defaultAccount!.findAuthInfo()
|
|
if authInfo != nil {
|
|
Log.info("$TAG Found auth info for account, removing it")
|
|
core.removeAuthInfo(info: authInfo!)
|
|
} else {
|
|
Log.warn("$TAG Failed to find matching auth info for account")
|
|
}
|
|
|
|
core.removeAccount(account: core.defaultAccount!)
|
|
Log.info("$TAG Account has been removed")
|
|
|
|
DispatchQueue.main.async {
|
|
coreContext.hasDefaultAccount = false
|
|
coreContext.loggedIn = false
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|