More actions for generation sheet

This commit is contained in:
Christoph Hagen
2025-05-04 21:49:16 +02:00
parent d779b7a42c
commit afa2e0b844
5 changed files with 140 additions and 15 deletions

View File

@ -9,6 +9,9 @@ struct GenerationContentView: View {
@EnvironmentObject
private var content: Content
@EnvironmentObject
private var selection: SelectedContent
@Environment(\.dismiss)
private var dismiss
@ -74,18 +77,34 @@ struct GenerationContentView: View {
text: "external files",
statusWhenNonEmpty: .nominal,
items: content.results.externalFiles) { $0.id }
GenerationStringIssuesView(
GenerationIssuesView(
text: "empty pages",
statusWhenNonEmpty: .warning,
items: content.results.emptyPages) { "\($0.pageId) (\($0.language))" }
GenerationStringIssuesView(
text: "draft pages",
items: $content.results.emptyPages) { pageId in
HStack {
Text("\(pageId.pageId) (\(pageId.language))")
Spacer()
Button("Show") {
show(page: pageId.pageId,
language: pageId.language)
}
}
}
GenerationIssuesActionView(
title: "draft pages",
statusWhenNonEmpty: .warning,
items: draftPages) { $0.id }
GenerationStringIssuesView(
text: "draft posts",
items: draftPages,
buttonText: "Show",
itemText: { $0.id },
action: { show($0) })
GenerationIssuesActionView(
title: "draft posts",
statusWhenNonEmpty: .warning,
items: draftPosts) { $0.id }
items: draftPosts,
buttonText: "Show",
itemText: { $0.id },
action: { show($0) })
GenerationIssuesView(
text: "additional output files",
statusWhenNonEmpty: .warning,
@ -147,6 +166,31 @@ struct GenerationContentView: View {
}
content.results.unusedFilesInOutput.remove(unusedFile)
}
private func show(page pageId: String, language: ContentLanguage? = nil) {
guard let page = content.page(pageId) else {
return
}
show(page, language: language)
}
private func show(_ page: Page, language: ContentLanguage? = nil) {
selection.page = page
if let language {
selection.language = language
}
selection.tab = .pages
dismiss()
}
private func show(_ post: Post, language: ContentLanguage? = nil) {
selection.post = post
if let language {
selection.language = language
}
selection.tab = .posts
dismiss()
}
}
#Preview {