87 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Swift
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Swift
		
	
	
	
	
	
//
 | 
						|
//  HomeLatestContentView.swift
 | 
						|
//  SodaLive
 | 
						|
//
 | 
						|
//  Created by klaus on 7/11/25.
 | 
						|
//
 | 
						|
 | 
						|
import SwiftUI
 | 
						|
 | 
						|
struct HomeLatestContentView: View {
 | 
						|
    
 | 
						|
    let onClickMore: () -> Void
 | 
						|
    let themeList: [String]
 | 
						|
    let contentList: [AudioContentMainItem]
 | 
						|
    
 | 
						|
    let selectTheme: (String) -> Void
 | 
						|
    @State private var selectedTheme = "전체"
 | 
						|
    
 | 
						|
    let rows = [
 | 
						|
        GridItem(.flexible(), alignment: .leading),
 | 
						|
        GridItem(.flexible(), alignment: .leading)
 | 
						|
    ]
 | 
						|
    
 | 
						|
    var body: some View {
 | 
						|
        HStack(spacing: 0) {
 | 
						|
            Text("최신")
 | 
						|
                .font(.custom(Font.preBold.rawValue, size: 24))
 | 
						|
                .foregroundColor(.button)
 | 
						|
            
 | 
						|
            Text(" 콘텐츠")
 | 
						|
                .font(.custom(Font.preBold.rawValue, size: 24))
 | 
						|
                .foregroundColor(.white)
 | 
						|
            
 | 
						|
            Spacer()
 | 
						|
            
 | 
						|
            Text("전체보기")
 | 
						|
                .font(.custom(Font.preRegular.rawValue, size: 14))
 | 
						|
                .foregroundColor(.init(hex: "78909C"))
 | 
						|
                .onTapGesture { onClickMore() }
 | 
						|
        }
 | 
						|
        .padding(.horizontal, 24)
 | 
						|
        
 | 
						|
        if !themeList.isEmpty {
 | 
						|
            ContentMainContentThemeView(
 | 
						|
                themeList: themeList,
 | 
						|
                selectTheme: selectTheme,
 | 
						|
                selectedTheme: $selectedTheme
 | 
						|
            )
 | 
						|
        }
 | 
						|
        
 | 
						|
        ScrollView(.horizontal, showsIndicators: false) {
 | 
						|
            LazyHGrid(rows: rows, spacing: 16) {
 | 
						|
                ForEach(0..<contentList.count, id: \.self) { index in
 | 
						|
                    ContentItemView(item: contentList[index])
 | 
						|
                }
 | 
						|
            }
 | 
						|
            .padding(.horizontal, 24)
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
#Preview {
 | 
						|
    HomeLatestContentView(
 | 
						|
        onClickMore: {},
 | 
						|
        themeList: ["전체", "테스트1", "테스트2"],
 | 
						|
        contentList: [
 | 
						|
            AudioContentMainItem(
 | 
						|
                contentId: 1,
 | 
						|
                creatorId: 3,
 | 
						|
                title: "ㅓ처랴햐햫햐햐",
 | 
						|
                coverImageUrl: "https://test-cf.sodalive.net/profile/default-profile.png",
 | 
						|
                creatorNickname: "유저1",
 | 
						|
                isPointAvailable: true
 | 
						|
            ),
 | 
						|
            AudioContentMainItem(
 | 
						|
                contentId: 2,
 | 
						|
                creatorId: 8,
 | 
						|
                title: "ㅓ처랴햐햫햐햐",
 | 
						|
                coverImageUrl: "https://test-cf.sodalive.net/profile/default-profile.png",
 | 
						|
                creatorNickname: "유저2",
 | 
						|
                isPointAvailable: false
 | 
						|
            )
 | 
						|
        ],
 | 
						|
        selectTheme: { _ in }
 | 
						|
    )
 | 
						|
}
 |