mirror of
https://github.com/simplex-chat/simplex-chat.git
synced 2026-04-04 06:56:12 +00:00
* ios: wallpapers (#4304) * ios: wallpapers * theme selection * applied theme colors and preset wallpaper * more places with background * one more * accent color * defaults * rename * background * no change to cell color * unneeded * changes * no global tint * defaults * removed unneeded class * for merging * ios: wallpapers types (#4325) * types and api * divided types per target * creating directory for wallpapers * creating wallpaper dir at launch * ios: wallpapers appearance (#4335) * appearance * changes * refactor * scale * lambda to function --------- Co-authored-by: Evgeny Poberezkin <2769109+epoberezkin@users.noreply.github.com> * ios: wallpapers user/chat overrides (#4345) * ios: wallpapers user/chat overrides * chat overrides * color picker updates colors correctly * fix state update * labels * background for light theme * small optimization * removed commented code * ios: enhancements to wallpapers (#4361) * ios: enhancements to wallpapers * colors for background * ios: wallpapers import/export (#4362) * ios: wallpapers import/export * comment * ios: wallpapers theme updates (#4365) * ios: wallpapers theme updates * group member background * colors * profile picture colors * unneeded * optimizations, images, state fixes * fixes * no editing of title color * rename Menus and alerts, refactor * tint applying fix * fixes * migration of accent and themes * fix updating system theme * migration changes * limiting color range * ios: wallpapers rename enum (#4384) * ios: wallpapers rename enum2 (#4385) * ios: wallpapers rename enum2 * change * colors were commented * fix build and look --------- Co-authored-by: Stanislav Dmitrenko <7953703+avently@users.noreply.github.com>
117 lines
3.8 KiB
Swift
117 lines
3.8 KiB
Swift
//
|
|
// NotificationsModeView.swift
|
|
// SimpleX (iOS)
|
|
//
|
|
// Created by Evgeny on 03/07/2022.
|
|
// Copyright © 2022 SimpleX Chat. All rights reserved.
|
|
//
|
|
|
|
import SwiftUI
|
|
import SimpleXChat
|
|
|
|
struct SetNotificationsMode: View {
|
|
@EnvironmentObject var m: ChatModel
|
|
@State private var notificationMode = NotificationsMode.instant
|
|
@State private var showAlert: NotificationAlert?
|
|
|
|
var body: some View {
|
|
ScrollView {
|
|
VStack(alignment: .leading, spacing: 16) {
|
|
Text("Push notifications")
|
|
.font(.largeTitle)
|
|
.bold()
|
|
.frame(maxWidth: .infinity)
|
|
|
|
Text("Send notifications:")
|
|
ForEach(NotificationsMode.values) { mode in
|
|
NtfModeSelector(mode: mode, selection: $notificationMode)
|
|
}
|
|
|
|
Spacer()
|
|
|
|
Button {
|
|
if let token = m.deviceToken {
|
|
setNotificationsMode(token, notificationMode)
|
|
} else {
|
|
AlertManager.shared.showAlertMsg(title: "No device token!")
|
|
}
|
|
onboardingStageDefault.set(.onboardingComplete)
|
|
m.onboardingStage = .onboardingComplete
|
|
} label: {
|
|
if case .off = notificationMode {
|
|
Text("Use chat")
|
|
} else {
|
|
Text("Enable notifications")
|
|
}
|
|
}
|
|
.font(.title)
|
|
.frame(maxWidth: .infinity)
|
|
}
|
|
.padding()
|
|
.frame(maxWidth: .infinity, maxHeight: .infinity, alignment: .bottom)
|
|
}
|
|
}
|
|
|
|
private func setNotificationsMode(_ token: DeviceToken, _ mode: NotificationsMode) {
|
|
switch mode {
|
|
case .off:
|
|
m.tokenStatus = .new
|
|
m.notificationMode = .off
|
|
default:
|
|
Task {
|
|
do {
|
|
let status = try await apiRegisterToken(token: token, notificationMode: mode)
|
|
await MainActor.run {
|
|
m.tokenStatus = status
|
|
m.notificationMode = mode
|
|
}
|
|
} catch let error {
|
|
let a = getErrorAlert(error, "Error enabling notifications")
|
|
AlertManager.shared.showAlertMsg(
|
|
title: a.title,
|
|
message: a.message
|
|
)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
struct NtfModeSelector: View {
|
|
@EnvironmentObject var theme: AppTheme
|
|
var mode: NotificationsMode
|
|
@Binding var selection: NotificationsMode
|
|
@State private var tapped = false
|
|
|
|
var body: some View {
|
|
ZStack {
|
|
VStack(alignment: .leading, spacing: 4) {
|
|
Text(mode.label)
|
|
.font(.headline)
|
|
.foregroundColor(selection == mode ? theme.colors.primary : theme.colors.secondary)
|
|
Text(ntfModeDescription(mode))
|
|
.lineLimit(10)
|
|
.font(.subheadline)
|
|
}
|
|
.padding(12)
|
|
}
|
|
.frame(maxWidth: .infinity, alignment: .leading)
|
|
.background(tapped ? Color(uiColor: .secondarySystemFill) : theme.colors.background)
|
|
.clipShape(RoundedRectangle(cornerRadius: 18))
|
|
.overlay(
|
|
RoundedRectangle(cornerRadius: 18)
|
|
.stroke(selection == mode ? theme.colors.primary : Color(uiColor: .secondarySystemFill), lineWidth: 2)
|
|
)
|
|
._onButtonGesture { down in
|
|
tapped = down
|
|
if down { selection = mode }
|
|
} perform: {}
|
|
}
|
|
}
|
|
|
|
struct NotificationsModeView_Previews: PreviewProvider {
|
|
static var previews: some View {
|
|
SetNotificationsMode()
|
|
}
|
|
}
|