Skip to content

Commit

Permalink
ui: dont display images when users have collapse image setting enabled
Browse files Browse the repository at this point in the history
  • Loading branch information
ericholguin committed Oct 14, 2023
1 parent 423e8b1 commit a3c4840
Showing 1 changed file with 31 additions and 17 deletions.
48 changes: 31 additions & 17 deletions damus/Views/NoteContentView.swift
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ struct NoteContentView: View {

let damus_state: DamusState
let event: NostrEvent
@State var show_images: Bool
@State var blur_images: Bool
let size: EventViewKind
let preview_height: CGFloat?
let options: EventViewOptions
Expand All @@ -39,10 +39,10 @@ struct NoteContentView: View {
return self.artifacts_model.state.artifacts ?? .separated(.just_content(event.get_content(damus_state.keypair)))
}

init(damus_state: DamusState, event: NostrEvent, show_images: Bool, size: EventViewKind, options: EventViewOptions) {
init(damus_state: DamusState, event: NostrEvent, blur_images: Bool, size: EventViewKind, options: EventViewOptions) {
self.damus_state = damus_state
self.event = event
self.show_images = show_images
self.blur_images = blur_images
self.size = size
self.options = options
self.preview_height = lookup_cached_preview_size(previews: damus_state.previews, evid: event.id)
Expand All @@ -61,7 +61,7 @@ struct NoteContentView: View {
}

var preview: LinkViewRepresentable? {
guard show_images,
guard blur_images,
case .loaded(let preview) = preview_model.state,
case .value(let cached) = preview else {
return nil
Expand Down Expand Up @@ -92,7 +92,7 @@ struct NoteContentView: View {

func previewView(links: [URL]) -> some View {
Group {
if let preview = self.preview, show_images {
if let preview = self.preview, blur_images {
if let preview_height {
preview
.frame(height: preview_height)
Expand Down Expand Up @@ -133,17 +133,31 @@ struct NoteContentView: View {
}
}

if show_images && artifacts.media.count > 0 {
ImageCarousel(state: damus_state, evid: event.id, urls: artifacts.media)
} else if !show_images && artifacts.media.count > 0 {
ZStack {
ImageCarousel(state: damus_state, evid: event.id, urls: artifacts.media)
Blur()
.onTapGesture {
show_images = true
if damus_state.settings.collapse_images {
ForEach(artifacts.media.indices, id: \.self) { index in
switch artifacts.media[index] {
case .image(let url), .video(let url):
if with_padding {
truncatedText(content: url_str(url))
.padding(.horizontal)
} else {
truncatedText(content: url_str(url))
}
}
}
} else {
if blur_images && artifacts.media.count > 0 {
ImageCarousel(state: damus_state, evid: event.id, urls: artifacts.media)
} else if !blur_images && artifacts.media.count > 0 {
ZStack {
ImageCarousel(state: damus_state, evid: event.id, urls: artifacts.media)
Blur()
.onTapGesture {
blur_images = true
}
}
//.cornerRadius(10)
}
//.cornerRadius(10)
}

if artifacts.invoices.count > 0 {
Expand Down Expand Up @@ -618,17 +632,17 @@ struct NoteContentView_Previews: PreviewProvider {

Group {
VStack {
NoteContentView(damus_state: state, event: test_note, show_images: true, size: .normal, options: [])
NoteContentView(damus_state: state, event: test_note, blur_images: true, size: .normal, options: [])
}
.previewDisplayName("Short note")

VStack {
NoteContentView(damus_state: state, event: test_encoded_note_with_image!, show_images: true, size: .normal, options: [])
NoteContentView(damus_state: state, event: test_encoded_note_with_image!, blur_images: true, size: .normal, options: [])
}
.previewDisplayName("Note with image")

VStack {
NoteContentView(damus_state: state2, event: test_longform_event.event, show_images: true, size: .normal, options: [.wide])
NoteContentView(damus_state: state2, event: test_longform_event.event, blur_images: true, size: .normal, options: [.wide])
.border(Color.red)
}
.previewDisplayName("Long-form note")
Expand Down

0 comments on commit a3c4840

Please sign in to comment.