passepartout-apple/Library/Sources/CommonUtils/Views/LongContentView.swift

107 lines
2.7 KiB
Swift
Raw Normal View History

2022-04-12 13:09:14 +00:00
//
// LongContentView.swift
// Passepartout
//
// Created by Davide De Rosa on 3/4/22.
2024-01-14 13:34:21 +00:00
// Copyright (c) 2024 Davide De Rosa. All rights reserved.
2022-04-12 13:09:14 +00:00
//
// https://github.com/passepartoutvpn
//
// This file is part of Passepartout.
//
// Passepartout is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Passepartout is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Passepartout. If not, see <http://www.gnu.org/licenses/>.
//
#if !os(tvOS)
2022-04-12 13:09:14 +00:00
import SwiftUI
2024-09-23 13:02:26 +00:00
public struct LongContentView: View {
2023-03-17 20:55:47 +00:00
2024-09-23 13:02:26 +00:00
@Binding
public var content: String
public var copySystemImage: String?
2022-04-12 13:09:14 +00:00
2024-09-23 13:02:26 +00:00
public var body: some View {
contentView
2024-09-23 13:02:26 +00:00
.toolbar {
Button {
Utils.copyToPasteboard(content)
2024-09-23 13:02:26 +00:00
} label: {
Image(systemName: copySystemImage ?? "doc.on.doc")
}
}
}
@ViewBuilder
private var contentView: some View {
if #available(iOS 17, macOS 14, *) {
TextEditor(text: $content)
// .contentMargins(8)
// .scrollContentBackground(.hidden)
.scrollClipDisabled()
} else {
TextEditor(text: $content)
}
2022-04-12 13:09:14 +00:00
}
}
2024-09-23 13:02:26 +00:00
public struct LongContentLink<Preview: View>: View {
2022-04-12 13:09:14 +00:00
private let title: String
2023-03-17 20:55:47 +00:00
2024-09-23 13:02:26 +00:00
@Binding
private var content: String
2023-03-17 20:55:47 +00:00
2022-04-12 13:09:14 +00:00
private let preview: String?
private let previewLabel: ((String) -> Preview)?
2023-03-17 20:55:47 +00:00
2024-09-23 13:02:26 +00:00
public init(
2022-04-12 13:09:14 +00:00
_ title: String,
content: Binding<String>,
preview: String? = nil,
previewLabel: ((String) -> Preview)? = nil
) {
self.title = title
_content = content
self.preview = preview
self.previewLabel = previewLabel
}
2023-03-17 20:55:47 +00:00
2024-09-23 13:02:26 +00:00
public var body: some View {
2022-04-12 13:09:14 +00:00
NavigationLink {
LongContentView(content: $content)
2024-09-23 13:02:26 +00:00
.font(.body)
.monospaced()
2022-04-12 13:09:14 +00:00
.navigationTitle(title)
2024-09-23 13:02:26 +00:00
#if os(iOS)
.navigationBarTitleDisplayMode(.inline)
#endif
2022-04-12 13:09:14 +00:00
} label: {
HStack {
Text(title)
Spacer()
previewLabel.map {
$0(preview ?? content)
.lineLimit(1)
.truncationMode(.middle)
}
}
}
}
}
#endif