Skip to content

Commit

Permalink
feat: 사진 공개 하단 indicator 추가
Browse files Browse the repository at this point in the history
  • Loading branch information
leemhyungyu committed Nov 7, 2024
1 parent 66418ba commit c48a426
Showing 1 changed file with 38 additions and 12 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ public struct PhotoSharePingPongView: View {
@Binding var isSelctedYesButton: Bool
@Binding var isSelctedNoButton: Bool
private let doneButtonAction: (() -> Void)?
@Binding var selectionIndex: Int
@State var selectedIndex: Int = 0

public init(
isActive: Bool,
Expand All @@ -28,16 +28,14 @@ public struct PhotoSharePingPongView: View {
isSelctedYesButton: Binding<Bool> = .constant(false),
isSelctedNoButton: Binding<Bool> = .constant(false),
doneButtonAction: (() -> Void)? = nil,
selectionIndex: Binding<Int> = .constant(0),
otherProfileImageURLs: [String]? = ["1", "2", "3"]
otherProfileImageURLs: [String]?
) {
self.isActive = isActive
self.pingPongTitle = pingPongTitle
self.photoShareState = photoShareState
self._isSelctedYesButton = isSelctedYesButton
self._isSelctedNoButton = isSelctedNoButton
self.doneButtonAction = doneButtonAction
self._selectionIndex = selectionIndex
self.otherProfileImageURLs = otherProfileImageURLs
}

Expand Down Expand Up @@ -143,21 +141,49 @@ private extension PhotoSharePingPongView {
@ViewBuilder
var bothPublicView: some View {
if let images = otherProfileImageURLs {
GeometryReader { geo in
TabView(selection: $selectionIndex) {
ForEach(images.indices, id: \.self) { index in
makePeerProfileImage(url: images[0])
VStack(spacing: .lg) {
GeometryReader { geo in
TabView(selection: $selectedIndex) {
ForEach(images.indices, id: \.self) { index in
makePeerProfileImage(url: images[index])
.tag(index)
}
}
}
.tabViewStyle(PageTabViewStyle(indexDisplayMode: .never))
.frame(height: geo.size.width - 10)
.tabViewStyle(PageTabViewStyle(indexDisplayMode: .never))
.frame(height: geo.size.width - 10)
}
.aspectRatio(1, contentMode: .fit)

photoIndicatorView
}
.aspectRatio(1, contentMode: .fit)
} else {
EmptyView()
}
}

var photoIndicatorView: some View {
HStack(spacing: .xxl) {
BottleImageView(type: .local(bottleImageSystem: .icon(.leftArrow)))
.foregroundStyle(to: ColorToken.icon(.primary))
.asButton {
if selectedIndex > 0 {
selectedIndex -= 1
}
}

PageIndicatorView(pageInfo: .init(nowPage: selectedIndex + 1, totalCount: otherProfileImageURLs?.count ?? 0))

BottleImageView(type: .local(bottleImageSystem: .icon(.leftArrow)))
.foregroundStyle(to: ColorToken.icon(.primary))
.rotationEffect(.degrees(180))
.asButton {
if selectedIndex + 1 < otherProfileImageURLs?.count ?? 0 {
selectedIndex += 1
}
}
}
}

@ViewBuilder
var questionText: some View {
if photoShareState != .disabled
Expand Down

0 comments on commit c48a426

Please sign in to comment.