* add start chat flow with UI * add feature flag for start chat * add changelog * fix naming and tests * fix empty display name in user cell * Update ElementX/Sources/Application/AppSettings.swift Co-authored-by: Alfonso Grillo <alfogrillo@element.io> * add screenshots from UI test * fix swiftFormat and add identifiers * fix warnings --------- Co-authored-by: Alfonso Grillo <alfogrillo@element.io>
83 lines
2.7 KiB
Swift
83 lines
2.7 KiB
Swift
//
|
|
// Copyright 2022 New Vector Ltd
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
//
|
|
|
|
import SwiftUI
|
|
|
|
struct DeveloperOptionsScreenScreen: View {
|
|
@ObservedObject var context: DeveloperOptionsScreenViewModel.Context
|
|
@State private var showConfetti = false
|
|
|
|
var body: some View {
|
|
Form {
|
|
Section {
|
|
Toggle(isOn: $context.shouldCollapseRoomStateEvents) {
|
|
Text("Collapse room state events")
|
|
}
|
|
.onChange(of: context.shouldCollapseRoomStateEvents) { _ in
|
|
context.send(viewAction: .changedShouldCollapseRoomStateEvents)
|
|
}
|
|
Toggle(isOn: $context.showStartChatFlow) {
|
|
Text("Show Start Chat flow")
|
|
}
|
|
.onChange(of: context.showStartChatFlow) { _ in
|
|
context.send(viewAction: .changedShowStartChatFlow)
|
|
}
|
|
}
|
|
|
|
Section {
|
|
Button {
|
|
showConfetti = true
|
|
} label: {
|
|
Text("🥳")
|
|
.frame(maxWidth: .infinity)
|
|
}
|
|
.buttonStyle(FormButtonStyle())
|
|
}
|
|
.formSectionStyle()
|
|
}
|
|
.overlay(effectsView)
|
|
.scrollContentBackground(.hidden)
|
|
.background(Color.element.formBackground.ignoresSafeArea())
|
|
.navigationTitle(ElementL10n.settingsDeveloperOptions)
|
|
.navigationBarTitleDisplayMode(.inline)
|
|
}
|
|
|
|
@ViewBuilder
|
|
private var effectsView: some View {
|
|
if showConfetti {
|
|
EffectsView(effect: .confetti)
|
|
.ignoresSafeArea()
|
|
.allowsHitTesting(false)
|
|
.task { await removeConfettiAfterDelay() }
|
|
}
|
|
}
|
|
|
|
private func removeConfettiAfterDelay() async {
|
|
try? await Task.sleep(for: .seconds(4))
|
|
showConfetti = false
|
|
}
|
|
}
|
|
|
|
// MARK: - Previews
|
|
|
|
struct DeveloperOptionsScreen_Previews: PreviewProvider {
|
|
static var previews: some View {
|
|
let viewModel = DeveloperOptionsScreenViewModel()
|
|
DeveloperOptionsScreenScreen(context: viewModel.context)
|
|
.tint(.element.accent)
|
|
}
|
|
}
|