mirror of
https://github.com/vector-im/element-ios.git
synced 2024-10-01 00:32:41 +00:00
70ae9d6e03
Labs: Rich text-editor fix for "does not support inserting custom iOS emojis"
72 lines
2.5 KiB
Swift
72 lines
2.5 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 Foundation
|
|
import SwiftUI
|
|
import WysiwygComposer
|
|
|
|
enum MockComposerScreenState: MockScreenState, CaseIterable {
|
|
case send
|
|
case edit
|
|
case reply
|
|
|
|
var screenType: Any.Type {
|
|
Composer.self
|
|
}
|
|
|
|
var screenView: ([Any], AnyView) {
|
|
let viewModel: ComposerViewModel
|
|
let bindings = ComposerBindings(focused: false)
|
|
|
|
switch self {
|
|
case .send: viewModel = ComposerViewModel(initialViewState: ComposerViewState(bindings: bindings))
|
|
case .edit: viewModel = ComposerViewModel(initialViewState: ComposerViewState(sendMode: .edit, bindings: bindings))
|
|
case .reply: viewModel = ComposerViewModel(initialViewState: ComposerViewState(eventSenderDisplayName: "TestUser", sendMode: .reply, bindings: bindings))
|
|
}
|
|
|
|
let wysiwygviewModel = WysiwygComposerViewModel(minHeight: 20, maxHeight: 360)
|
|
|
|
viewModel.callback = { [weak viewModel, weak wysiwygviewModel] result in
|
|
guard let viewModel = viewModel else { return }
|
|
switch result {
|
|
case .cancel:
|
|
if viewModel.sendMode == .edit {
|
|
wysiwygviewModel?.setHtmlContent("")
|
|
}
|
|
viewModel.sendMode = .send
|
|
default: break
|
|
}
|
|
}
|
|
|
|
return (
|
|
[viewModel, wysiwygviewModel],
|
|
AnyView(VStack {
|
|
Spacer()
|
|
Composer(viewModel: viewModel.context,
|
|
wysiwygViewModel: wysiwygviewModel,
|
|
resizeAnimationDuration: 0.1,
|
|
sendMessageAction: { _ in },
|
|
showSendMediaActions: { })
|
|
}.frame(
|
|
minWidth: 0,
|
|
maxWidth: .infinity,
|
|
minHeight: 0,
|
|
maxHeight: .infinity,
|
|
alignment: .topLeading
|
|
))
|
|
)
|
|
}
|
|
}
|