mirror of
https://gitlab.opencode.de/bwi/bundesmessenger/clients/bundesmessenger-ios.git
synced 2026-04-25 19:10:49 +02:00
Add theming support, and support for other top level configuration to swiftui views with VectorHostingViewController, VectorContentModifier. Add VisibilityModifier. Move from List to VStack.
This commit is contained in:
@@ -16,32 +16,40 @@
|
||||
|
||||
import SwiftUI
|
||||
|
||||
@available(iOS 13.0.0, *)
|
||||
@available(iOS 14.0.0, *)
|
||||
struct RoomNotificationSettingsView: View {
|
||||
|
||||
@Environment(\.theme) var theme: Theme
|
||||
@ObservedObject var viewModel: RoomNotificationSettingsViewModel
|
||||
|
||||
let presentedModally: Bool
|
||||
|
||||
@State var notificationState: RoomNotificationState = RoomNotificationState.all
|
||||
|
||||
|
||||
var body: some View {
|
||||
let leftButton = presentedModally ?
|
||||
@ViewBuilder
|
||||
var leftButton: some View {
|
||||
if presentedModally {
|
||||
SwiftUI.Button(VectorL10n.cancel) {
|
||||
viewModel.process(viewAction: .cancel)
|
||||
}
|
||||
: nil
|
||||
let rightButton = SwiftUI.Button(VectorL10n.save) {
|
||||
}
|
||||
}
|
||||
|
||||
var rightButton: some View {
|
||||
Button(VectorL10n.save) {
|
||||
viewModel.process(viewAction: .save)
|
||||
}
|
||||
VectorForm {
|
||||
}
|
||||
|
||||
var body: some View {
|
||||
VectorFormView {
|
||||
if let image = viewModel.viewState.avatar {
|
||||
RoomNotificationSettingsHeaderView(image: image, displayName: viewModel.viewState.displayName)
|
||||
}
|
||||
SwiftUI.Section(
|
||||
header: FormSectionHeader(text: VectorL10n.roomNotifsSettingsNotifyMeFor),
|
||||
footer: FormSectionFooter(text: viewModel.viewState.roomEncryptedString)
|
||||
header: FormSectionHeaderView(text: VectorL10n.roomNotifsSettingsNotifyMeFor),
|
||||
footer: FormSectionFooterView(text: viewModel.viewState.roomEncryptedString)
|
||||
) {
|
||||
ForEach(viewModel.viewState.notificationOptions) { option in
|
||||
FormPickerItem(title: option.title, selected: viewModel.viewState.notificationState == option) {
|
||||
FormPickerItemView(title: option.title, selected: viewModel.viewState.notificationState == option) {
|
||||
viewModel.process(viewAction: .selectNotificationState(option))
|
||||
}
|
||||
}
|
||||
@@ -56,8 +64,6 @@ struct RoomNotificationSettingsView: View {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
fileprivate extension RoomNotificationState {
|
||||
var title: String {
|
||||
@@ -78,26 +84,27 @@ fileprivate extension RoomNotificationSettingsViewState {
|
||||
}
|
||||
}
|
||||
|
||||
extension RoomNotificationState: Identifiable {
|
||||
var id: String { UUID().uuidString }
|
||||
}
|
||||
|
||||
|
||||
@available(iOS 14.0, *)
|
||||
struct RoomNotificationSettingsView_Previews: PreviewProvider {
|
||||
|
||||
|
||||
static let mockViewModel = RoomNotificationSettingsViewModel(
|
||||
roomNotificationService: MockRoomNotificationSettingsService.example,
|
||||
roomEncrypted: true,
|
||||
avatarViewData: nil
|
||||
avatarService: MockAvatarService.example,
|
||||
avatarData: .swiftUI(AvatarInput(mxContentUri: nil, itemId: "", displayName: "Alice")),
|
||||
roomEncrypted: true
|
||||
)
|
||||
|
||||
|
||||
static var previews: some View {
|
||||
Group {
|
||||
NavigationView {
|
||||
RoomNotificationSettingsView(viewModel: mockViewModel, presentedModally: true)
|
||||
.navigationBarTitleDisplayMode(.inline)
|
||||
}
|
||||
NavigationView {
|
||||
RoomNotificationSettingsView(viewModel: mockViewModel, presentedModally: true)
|
||||
.navigationBarTitleDisplayMode(.inline)
|
||||
.theme(ThemeIdentifier.dark.theme)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user