mirror of
https://github.com/simplex-chat/simplex-chat.git
synced 2026-05-07 17:47:48 +00:00
3d85480944
* ui: onboarding assets * android: fix gradle version check, pass assets dir to builds * desktop: pass assets dir to gradle builds * ui: new onboarding (#6872) * ios: improve onboarding * ios version condition * android strings * merge keys * refactor network conditions to old location * ios scroll headline * remove nav view * kotlin: refactor network commitments page to use existing view * remove unused keys * update why page * configure -> setup * padding for app bar in why page * fix why page * padding * copy translations from the website * export localizations * export again * kotlin: fix why page * fix * import localizations * custom layout * padding for system bars * paddings * more paddings * more padding 2 * update fonts * fonts * line height, padding * paddings * refactor notifications * refactor ios * notification icons in cards * restore profile field * padding * desktop layout create profile * fix * more layout * create profile layout * mobile padding * split mobile and desktop * layout * layout * background * refactor onboarding images * use DARK theme by default * page 3 and 4 layouts * restructure desktop onboarding to two panes * improve layout * improve * fonts, padding * link mobile on full page * fix, reduce noise * change to animation * fix animation * refactor * colors, animation * import * details * fix padding * fix icon * fix * button paddings * accept button on terms page * fix conditions button * close modal --------- Co-authored-by: spaced4ndy <8711996+spaced4ndy@users.noreply.github.com> Co-authored-by: shum <github.shum@liber.li> Co-authored-by: Evgeny @ SimpleX Chat <259188159+evgeny-simplex@users.noreply.github.com>
141 lines
4.7 KiB
Swift
141 lines
4.7 KiB
Swift
//
|
|
// NotificationsModeView.swift
|
|
// SimpleX (iOS)
|
|
//
|
|
// Created by Evgeny on 03/07/2022.
|
|
// Copyright © 2022 SimpleX Chat. All rights reserved.
|
|
//
|
|
// Spec: spec/client/navigation.md
|
|
|
|
import SwiftUI
|
|
import SimpleXChat
|
|
|
|
struct SetNotificationsMode: View {
|
|
@Environment(\.dismiss) var dismiss
|
|
@Binding var notificationMode: NotificationsMode
|
|
@State private var showInfo = false
|
|
|
|
var body: some View {
|
|
GeometryReader { g in
|
|
ScrollView {
|
|
VStack(alignment: .center, spacing: 20) {
|
|
Text("Push notifications")
|
|
.font(.largeTitle)
|
|
.bold()
|
|
.padding(.top, 25)
|
|
|
|
Button {
|
|
showInfo = true
|
|
} label: {
|
|
Label("How it affects privacy", systemImage: "info.circle")
|
|
.font(.headline)
|
|
}
|
|
|
|
Spacer()
|
|
|
|
ForEach(NotificationsMode.values) { mode in
|
|
NtfModeSelector(mode: mode, selection: $notificationMode)
|
|
}
|
|
|
|
Spacer()
|
|
|
|
VStack(spacing: 10) {
|
|
Button {
|
|
dismiss()
|
|
} label: {
|
|
Text("OK")
|
|
}
|
|
.buttonStyle(OnboardingButtonStyle())
|
|
onboardingButtonPlaceholder()
|
|
}
|
|
}
|
|
.padding(25)
|
|
.frame(minHeight: g.size.height)
|
|
}
|
|
}
|
|
.frame(maxHeight: .infinity)
|
|
.sheet(isPresented: $showInfo) {
|
|
NotificationsInfoView()
|
|
}
|
|
}
|
|
}
|
|
|
|
struct NtfModeSelector: View {
|
|
@EnvironmentObject var theme: AppTheme
|
|
var mode: NotificationsMode
|
|
@Binding var selection: NotificationsMode
|
|
@State private var tapped = false
|
|
|
|
var body: some View {
|
|
ZStack {
|
|
HStack(spacing: 16) {
|
|
Image(systemName: mode.icon)
|
|
.resizable()
|
|
.scaledToFill()
|
|
.frame(width: mode.icon == "bolt" ? 14 : 18, height: 18)
|
|
.foregroundColor(selection == mode ? theme.colors.primary : theme.colors.secondary)
|
|
VStack(alignment: .leading, spacing: 4) {
|
|
Text(mode.label)
|
|
.font(.headline)
|
|
.foregroundColor(selection == mode ? theme.colors.primary : theme.colors.secondary)
|
|
Text(ntfModeShortDescription(mode))
|
|
.lineLimit(2)
|
|
.font(.callout)
|
|
.fixedSize(horizontal: false, vertical: true)
|
|
}
|
|
}
|
|
.padding(.vertical, 12)
|
|
.padding(.trailing, 12)
|
|
.padding(.leading, 16)
|
|
}
|
|
.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 NotificationsInfoView: View {
|
|
var body: some View {
|
|
VStack(alignment: .leading) {
|
|
Text("Notifications privacy")
|
|
.font(.largeTitle)
|
|
.bold()
|
|
.padding(.vertical)
|
|
ScrollView {
|
|
VStack(alignment: .leading) {
|
|
Group {
|
|
ForEach(NotificationsMode.values) { mode in
|
|
VStack(alignment: .leading, spacing: 4) {
|
|
(Text(Image(systemName: mode.icon)) + textSpace + Text(mode.label))
|
|
.font(.headline)
|
|
.foregroundColor(.secondary)
|
|
Text(ntfModeDescription(mode))
|
|
.lineLimit(10)
|
|
.font(.callout)
|
|
}
|
|
}
|
|
}
|
|
.padding(.bottom)
|
|
}
|
|
}
|
|
}
|
|
.padding()
|
|
.frame(maxWidth: .infinity, maxHeight: .infinity, alignment: .top)
|
|
.modifier(ThemedBackground())
|
|
}
|
|
}
|
|
|
|
struct NotificationsModeView_Previews: PreviewProvider {
|
|
static var previews: some View {
|
|
SetNotificationsMode(notificationMode: .constant(.instant))
|
|
}
|
|
}
|