From cf21ff338a64650ff8ee4b69bc0db2b5257dfaed Mon Sep 17 00:00:00 2001 From: baegteun Date: Sun, 10 Mar 2024 21:15:08 +0900 Subject: [PATCH 1/3] :wastebasket: :: [#458] ArtistFeature / ArtistViewModel deprecated --- .../Sources/ViewControllers/ArtistViewController.swift | 1 + .../ArtistFeature/Sources/ViewModels/ArtistViewModel.swift | 5 +++++ 2 files changed, 6 insertions(+) diff --git a/Projects/Features/ArtistFeature/Sources/ViewControllers/ArtistViewController.swift b/Projects/Features/ArtistFeature/Sources/ViewControllers/ArtistViewController.swift index 90376dafc..d966be4e6 100644 --- a/Projects/Features/ArtistFeature/Sources/ViewControllers/ArtistViewController.swift +++ b/Projects/Features/ArtistFeature/Sources/ViewControllers/ArtistViewController.swift @@ -35,6 +35,7 @@ public final class ArtistViewController: BaseViewController, ViewControllerFromS navigationController?.interactivePopGestureRecognizer?.delegate = nil } + @available(*, deprecated) public static func viewController( viewModel: ArtistViewModel, artistDetailComponent: ArtistDetailComponent diff --git a/Projects/Features/ArtistFeature/Sources/ViewModels/ArtistViewModel.swift b/Projects/Features/ArtistFeature/Sources/ViewModels/ArtistViewModel.swift index a2564add1..b87e29623 100644 --- a/Projects/Features/ArtistFeature/Sources/ViewModels/ArtistViewModel.swift +++ b/Projects/Features/ArtistFeature/Sources/ViewModels/ArtistViewModel.swift @@ -14,6 +14,11 @@ import RxCocoa import RxSwift import Utility +@available( + *, + deprecated, + message: "'ArtistViewModel' is deprecated. This will remove in a future. use instead of 'ArtistReactor'." +) public final class ArtistViewModel: ViewModelType { var disposeBag = DisposeBag() var fetchArtistListUseCase: FetchArtistListUseCase From 2912f27a425600b9ad2611fe3c088868dddb71f1 Mon Sep 17 00:00:00 2001 From: baegteun Date: Sun, 10 Mar 2024 22:04:40 +0900 Subject: [PATCH 2/3] =?UTF-8?q?:recycle:=20::=20[#458]=20ArtistFeature=20/?= =?UTF-8?q?=20ArtistViewController=EC=9D=98=20=EB=8F=84=EB=A9=94=EC=9D=B8?= =?UTF-8?q?=20=EB=A1=9C=EC=A7=81=20=EA=B4=80=EB=A6=AC=20=EA=B0=9D=EC=B2=B4?= =?UTF-8?q?=20viewModel=EC=97=90=EC=84=9C=20ReactorKit=EC=9C=BC=EB=A1=9C?= =?UTF-8?q?=20=EC=A0=84=ED=99=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../Sources/Components/ArtistComponent.swift | 3 +- .../Sources/Reactors/ArtistReactor.swift | 88 +++++++++++++++++++ .../ArtistViewController.swift | 70 ++++++++++++++- 3 files changed, 156 insertions(+), 5 deletions(-) create mode 100644 Projects/Features/ArtistFeature/Sources/Reactors/ArtistReactor.swift diff --git a/Projects/Features/ArtistFeature/Sources/Components/ArtistComponent.swift b/Projects/Features/ArtistFeature/Sources/Components/ArtistComponent.swift index 43e992450..4b50e485b 100644 --- a/Projects/Features/ArtistFeature/Sources/Components/ArtistComponent.swift +++ b/Projects/Features/ArtistFeature/Sources/Components/ArtistComponent.swift @@ -18,8 +18,9 @@ public protocol ArtistDependency: Dependency { public final class ArtistComponent: Component { public func makeView() -> ArtistViewController { + let reactor = ArtistReactor(fetchArtistListUseCase: dependency.fetchArtistListUseCase) return ArtistViewController.viewController( - viewModel: ArtistViewModel(fetchArtistListUseCase: dependency.fetchArtistListUseCase), + reactor: reactor, artistDetailComponent: dependency.artistDetailComponent ) } diff --git a/Projects/Features/ArtistFeature/Sources/Reactors/ArtistReactor.swift b/Projects/Features/ArtistFeature/Sources/Reactors/ArtistReactor.swift new file mode 100644 index 000000000..af85f94fe --- /dev/null +++ b/Projects/Features/ArtistFeature/Sources/Reactors/ArtistReactor.swift @@ -0,0 +1,88 @@ +import ArtistDomainInterface +import ReactorKit +import Utility + +public final class ArtistReactor: Reactor { + public enum Action { + case viewDidLoad + } + + public enum Mutation { + case updateArtistList([ArtistListEntity]) + } + + public struct State { + var artistList: [ArtistListEntity] + } + + public var initialState: State + + private let fetchArtistListUseCase: any FetchArtistListUseCase + + init( + fetchArtistListUseCase: any FetchArtistListUseCase + ) { + self.fetchArtistListUseCase = fetchArtistListUseCase + self.initialState = .init( + artistList: [] + ) + } + + public func mutate(action: Action) -> Observable { + switch action { + case .viewDidLoad: + return fetchArtistListUseCase.execute() + .catchAndReturn([]) + .asObservable() + .map { [weak self] artistList in + guard let self, !artistList.isEmpty else { + DEBUG_LOG("데이터가 없습니다.") + return artistList + } + var newArtistList = artistList + + if newArtistList.count == 1 { + let hiddenItem: ArtistListEntity = self.makeHiddenArtistEntity() + newArtistList.append(hiddenItem) + } else { + newArtistList.swapAt(0, 1) + } + return newArtistList + } + .map(Mutation.updateArtistList) + + default: + return .empty() + } + } + + public func reduce(state: State, mutation: Mutation) -> State { + var newState = state + switch mutation { + case let .updateArtistList(artistList): + newState.artistList = artistList + } + return newState + } +} + +private extension ArtistReactor { + func makeHiddenArtistEntity() -> ArtistListEntity { + ArtistListEntity( + artistId: "", + name: "", + short: "", + group: "", + title: "", + description: "", + color: [], + youtube: "", + twitch: "", + instagram: "", + imageRoundVersion: 0, + imageSquareVersion: 0, + graduated: false, + isHiddenItem: true + ) + } +} diff --git a/Projects/Features/ArtistFeature/Sources/ViewControllers/ArtistViewController.swift b/Projects/Features/ArtistFeature/Sources/ViewControllers/ArtistViewController.swift index d966be4e6..bdd24a43d 100644 --- a/Projects/Features/ArtistFeature/Sources/ViewControllers/ArtistViewController.swift +++ b/Projects/Features/ArtistFeature/Sources/ViewControllers/ArtistViewController.swift @@ -4,12 +4,19 @@ import DomainModule import NeedleFoundation import NVActivityIndicatorView import PDFKit +import ReactorKit import RxCocoa import RxSwift import UIKit import Utility -public final class ArtistViewController: BaseViewController, ViewControllerFromStoryBoard, EqualHandleTappedType { +public final class ArtistViewController: + BaseViewController, + ViewControllerFromStoryBoard, + EqualHandleTappedType, + StoryboardView { + public typealias Reactor = ArtistReactor + @IBOutlet weak var collectionView: UICollectionView! @IBOutlet weak var activityIndicator: NVActivityIndicatorView! @@ -17,12 +24,11 @@ public final class ArtistViewController: BaseViewController, ViewControllerFromS private lazy var input = ArtistViewModel.Input() private lazy var output = viewModel.transform(from: input) var artistDetailComponent: ArtistDetailComponent! - var disposeBag: DisposeBag = DisposeBag() + public var disposeBag: DisposeBag = DisposeBag() override public func viewDidLoad() { super.viewDidLoad() configureUI() - bindRx() } override public func viewDidAppear(_ animated: Bool) { @@ -35,6 +41,51 @@ public final class ArtistViewController: BaseViewController, ViewControllerFromS navigationController?.interactivePopGestureRecognizer?.delegate = nil } + public func bind(reactor: ArtistReactor) { + bindAction(reactor: reactor) + bindState(reactor: reactor) + } + + private func bindAction(reactor: ArtistReactor) { + reactor.action.onNext(Reactor.Action.viewDidLoad) + // Storyboard 기반이기에 바로 viewDidLoad로 onNext, 만약 codebase로 전환 시 `methodInvoked(#selector(viewDidLoad))` 로 옵저빙 + + collectionView.rx.itemSelected + .withLatestFrom(reactor.state.map(\.artistList)) { ($0, $1) } + .do(onNext: { [collectionView] indexPath, _ in + guard let cell = collectionView?.cellForItem(at: indexPath) as? ArtistListCell else { return } + cell.animateSizeDownToUp(timeInterval: 0.3) + }) + .delay(RxTimeInterval.milliseconds(100), scheduler: MainScheduler.instance) + .map { $0.1[$0.0.row] } + .bind(with: self) { owner, artist in + let viewController = owner.artistDetailComponent.makeView(model: artist) + owner.navigationController?.pushViewController(viewController, animated: true) + } + .disposed(by: disposeBag) + } + + private func bindState(reactor: ArtistReactor) { + let sharedState = reactor.state.share(replay: 1) + + sharedState.map(\.artistList) + .do(onNext: { [activityIndicator] _ in + activityIndicator?.stopAnimating() + }) + .bind(to: collectionView.rx.items) { collectionView, index, artist in + let indexPath = IndexPath(item: index, section: 0) + guard let cell = collectionView.dequeueReusableCell( + withReuseIdentifier: "ArtistListCell", + for: indexPath + ) as? ArtistListCell else { + return UICollectionViewCell() + } + cell.update(model: artist) + return cell + } + .disposed(by: disposeBag) + } + @available(*, deprecated) public static func viewController( viewModel: ArtistViewModel, @@ -45,9 +96,20 @@ public final class ArtistViewController: BaseViewController, ViewControllerFromS viewController.artistDetailComponent = artistDetailComponent return viewController } + + public static func viewController( + reactor: ArtistReactor, + artistDetailComponent: ArtistDetailComponent + ) -> ArtistViewController { + let viewController = ArtistViewController.viewController(storyBoardName: "Artist", bundle: Bundle.module) + viewController.reactor = reactor + viewController.artistDetailComponent = artistDetailComponent + return viewController + } } extension ArtistViewController { + @available(*, deprecated, message: "'bindRx()' is deprecated. This will replace 'bind(:)'") private func bindRx() { output.dataSource .skip(1) @@ -138,7 +200,7 @@ public extension ArtistViewController { if viewControllersCount > 1 { self.navigationController?.popToRootViewController(animated: true) } else { - guard !output.dataSource.value.isEmpty else { return } + guard reactor?.currentState.artistList.isEmpty == false else { return } self.collectionView.setContentOffset(CGPoint(x: 0, y: -STATUS_BAR_HEGHIT()), animated: true) } } From c04a96641cbee41ae9a9b42566c73eb2f787f024 Mon Sep 17 00:00:00 2001 From: baegteun Date: Tue, 12 Mar 2024 18:16:49 +0900 Subject: [PATCH 3/3] =?UTF-8?q?:memo:=20::=20[#458]=20ArtistFeature=20/=20?= =?UTF-8?q?AristList=EC=9D=98=20=ED=8A=B9=EB=B3=84=20=EB=A1=9C=EC=A7=81=20?= =?UTF-8?q?=EB=AC=B8=EC=84=9C=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../Sources/Application/NeedleGenerated.swift | 2387 ++++++++++------- .../Sources/Reactors/ArtistReactor.swift | 47 +- 2 files changed, 1389 insertions(+), 1045 deletions(-) diff --git a/Projects/App/Sources/Application/NeedleGenerated.swift b/Projects/App/Sources/Application/NeedleGenerated.swift index 3cf2e461e..c28703e4c 100644 --- a/Projects/App/Sources/Application/NeedleGenerated.swift +++ b/Projects/App/Sources/Application/NeedleGenerated.swift @@ -29,9 +29,9 @@ import NetworkModule import NoticeDomain import NoticeDomainInterface import PanModal +import PlayerFeature import PlayListDomain import PlayListDomainInterface -import PlayerFeature import RootFeature import RxCocoa import RxKeyboard @@ -48,7 +48,7 @@ import UserDomainInterface import Utility // swiftlint:disable unused_declaration -private let needleDependenciesHash : String? = nil +private let needleDependenciesHash: String? = nil // MARK: - Traversal Helpers @@ -60,1132 +60,1407 @@ private func parent1(_ component: NeedleFoundation.Scope) -> NeedleFoundation.Sc #if !NEEDLE_DYNAMIC -private class ArtistDependency132a213bf62ad60c622cProvider: ArtistDependency { - var fetchArtistListUseCase: any FetchArtistListUseCase { - return appComponent.fetchArtistListUseCase - } - var artistDetailComponent: ArtistDetailComponent { - return appComponent.artistDetailComponent - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent - } -} -/// ^->AppComponent->ArtistComponent -private func factorye0c5444f5894148bdd93f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return ArtistDependency132a213bf62ad60c622cProvider(appComponent: parent1(component) as! AppComponent) -} -private class ArtistDetailDependencyee413dcf7a70e89df6d9Provider: ArtistDetailDependency { - var artistMusicComponent: ArtistMusicComponent { - return appComponent.artistMusicComponent - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent - } -} -/// ^->AppComponent->ArtistDetailComponent -private func factory35314797fadaf164ece6f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return ArtistDetailDependencyee413dcf7a70e89df6d9Provider(appComponent: parent1(component) as! AppComponent) -} -private class ArtistMusicContentDependency1615ac8469e54ec51921Provider: ArtistMusicContentDependency { - var fetchArtistSongListUseCase: any FetchArtistSongListUseCase { - return appComponent.fetchArtistSongListUseCase - } - var containSongsComponent: ContainSongsComponent { - return appComponent.containSongsComponent - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent - } -} -/// ^->AppComponent->ArtistMusicContentComponent -private func factory8b6ffa46033e2529b5daf47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return ArtistMusicContentDependency1615ac8469e54ec51921Provider(appComponent: parent1(component) as! AppComponent) -} -private class ArtistMusicDependencya0f5073287829dfbc260Provider: ArtistMusicDependency { - var artistMusicContentComponent: ArtistMusicContentComponent { - return appComponent.artistMusicContentComponent - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent - } -} -/// ^->AppComponent->ArtistMusicComponent -private func factory382e7f8466df35a3f1d9f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return ArtistMusicDependencya0f5073287829dfbc260Provider(appComponent: parent1(component) as! AppComponent) -} -private class PlaylistDependency6f376d117dc0f38671edProvider: PlaylistDependency { - var containSongsComponent: ContainSongsComponent { - return appComponent.containSongsComponent - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent - } -} -/// ^->AppComponent->PlaylistComponent -private func factory3a0a6eb1061d8d5a2deff47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return PlaylistDependency6f376d117dc0f38671edProvider(appComponent: parent1(component) as! AppComponent) -} -private class PlayerDependencyf8a3d594cc3b9254f8adProvider: PlayerDependency { - var fetchLyricsUseCase: any FetchLyricsUseCase { - return appComponent.fetchLyricsUseCase - } - var addLikeSongUseCase: any AddLikeSongUseCase { - return appComponent.addLikeSongUseCase - } - var cancelLikeSongUseCase: any CancelLikeSongUseCase { - return appComponent.cancelLikeSongUseCase - } - var fetchLikeNumOfSongUseCase: any FetchLikeNumOfSongUseCase { - return appComponent.fetchLikeNumOfSongUseCase - } - var fetchFavoriteSongsUseCase: any FetchFavoriteSongsUseCase { - return appComponent.fetchFavoriteSongsUseCase - } - var postPlaybackLogUseCase: any PostPlaybackLogUseCase { - return appComponent.postPlaybackLogUseCase - } - var playlistComponent: PlaylistComponent { - return appComponent.playlistComponent - } - var containSongsComponent: ContainSongsComponent { - return appComponent.containSongsComponent - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent - } -} -/// ^->AppComponent->PlayerComponent -private func factorybc7f802f601dd5913533f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return PlayerDependencyf8a3d594cc3b9254f8adProvider(appComponent: parent1(component) as! AppComponent) -} -private class MainTabBarDependencycd05b79389a6a7a6c20fProvider: MainTabBarDependency { - var fetchNoticeUseCase: any FetchNoticeUseCase { - return appComponent.fetchNoticeUseCase - } - var homeComponent: HomeComponent { - return appComponent.homeComponent - } - var chartComponent: ChartComponent { - return appComponent.chartComponent - } - var searchComponent: SearchComponent { - return appComponent.searchComponent - } - var artistComponent: ArtistComponent { - return appComponent.artistComponent - } - var storageComponent: StorageComponent { - return appComponent.storageComponent - } - var noticePopupComponent: NoticePopupComponent { - return appComponent.noticePopupComponent + private class ArtistDependency132a213bf62ad60c622cProvider: ArtistDependency { + var fetchArtistListUseCase: any FetchArtistListUseCase { + return appComponent.fetchArtistListUseCase + } + + var artistDetailComponent: ArtistDetailComponent { + return appComponent.artistDetailComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - var noticeComponent: NoticeComponent { - return appComponent.noticeComponent + + /// ^->AppComponent->ArtistComponent + private func factorye0c5444f5894148bdd93f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return ArtistDependency132a213bf62ad60c622cProvider(appComponent: parent1(component) as! AppComponent) } - var noticeDetailComponent: NoticeDetailComponent { - return appComponent.noticeDetailComponent + + private class ArtistDetailDependencyee413dcf7a70e89df6d9Provider: ArtistDetailDependency { + var artistMusicComponent: ArtistMusicComponent { + return appComponent.artistMusicComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + /// ^->AppComponent->ArtistDetailComponent + private func factory35314797fadaf164ece6f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return ArtistDetailDependencyee413dcf7a70e89df6d9Provider(appComponent: parent1(component) as! AppComponent) } -} -/// ^->AppComponent->MainTabBarComponent -private func factorye547a52b3fce5887c8c7f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return MainTabBarDependencycd05b79389a6a7a6c20fProvider(appComponent: parent1(component) as! AppComponent) -} -private class BottomTabBarDependency237c2bd1c7be62020295Provider: BottomTabBarDependency { + private class ArtistMusicContentDependency1615ac8469e54ec51921Provider: ArtistMusicContentDependency { + var fetchArtistSongListUseCase: any FetchArtistSongListUseCase { + return appComponent.fetchArtistSongListUseCase + } - init() { + var containSongsComponent: ContainSongsComponent { + return appComponent.containSongsComponent + } + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } -} -/// ^->AppComponent->BottomTabBarComponent -private func factoryd34fa9e493604a6295bde3b0c44298fc1c149afb(_ component: NeedleFoundation.Scope) -> AnyObject { - return BottomTabBarDependency237c2bd1c7be62020295Provider() -} -private class MainContainerDependencyd9d908a1d0cf8937bbadProvider: MainContainerDependency { - var bottomTabBarComponent: BottomTabBarComponent { - return appComponent.bottomTabBarComponent - } - var mainTabBarComponent: MainTabBarComponent { - return appComponent.mainTabBarComponent - } - var playerComponent: PlayerComponent { - return appComponent.playerComponent - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent - } -} -/// ^->AppComponent->MainContainerComponent -private func factory8e19f48d5d573d3ea539f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return MainContainerDependencyd9d908a1d0cf8937bbadProvider(appComponent: parent1(component) as! AppComponent) -} -private class ChartDependencyafd8882010751c9ef054Provider: ChartDependency { - var chartContentComponent: ChartContentComponent { - return appComponent.chartContentComponent - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent - } -} -/// ^->AppComponent->ChartComponent -private func factoryeac6a4df54bbd391d31bf47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return ChartDependencyafd8882010751c9ef054Provider(appComponent: parent1(component) as! AppComponent) -} -private class ChartContentDependency3b8e41cfba060e4d16caProvider: ChartContentDependency { - var fetchChartRankingUseCase: any FetchChartRankingUseCase { - return appComponent.fetchChartRankingUseCase - } - var fetchChartUpdateTimeUseCase: any FetchChartUpdateTimeUseCase { - return appComponent.fetchChartUpdateTimeUseCase - } - var containSongsComponent: ContainSongsComponent { - return appComponent.containSongsComponent - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent - } -} -/// ^->AppComponent->ChartContentComponent -private func factoryc9a137630ce76907f36ff47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return ChartContentDependency3b8e41cfba060e4d16caProvider(appComponent: parent1(component) as! AppComponent) -} -private class AskSongDependency02772625c56a0dda0140Provider: AskSongDependency { - var modifySongUseCase: any ModifySongUseCase { - return appComponent.modifySongUseCase - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent - } -} -/// ^->AppComponent->AskSongComponent -private func factory37544fa026b309cd68d7f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return AskSongDependency02772625c56a0dda0140Provider(appComponent: parent1(component) as! AppComponent) -} -private class SuggestFunctionDependency229560bbe33097b02547Provider: SuggestFunctionDependency { - var suggestFunctionUseCase: any SuggestFunctionUseCase { - return appComponent.suggestFunctionUseCase - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent - } -} -/// ^->AppComponent->SuggestFunctionComponent -private func factory63287bff3999ed1787ddf47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return SuggestFunctionDependency229560bbe33097b02547Provider(appComponent: parent1(component) as! AppComponent) -} -private class StorageDependency1447167c38e97ef97427Provider: StorageDependency { - var signInComponent: SignInComponent { - return appComponent.signInComponent - } - var afterLoginComponent: AfterLoginComponent { - return appComponent.afterLoginComponent - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent - } -} -/// ^->AppComponent->StorageComponent -private func factory2415399d25299b97b98bf47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return StorageDependency1447167c38e97ef97427Provider(appComponent: parent1(component) as! AppComponent) -} -private class FaqDependency899aad15f17210a3af31Provider: FaqDependency { - var faqContentComponent: FaqContentComponent { - return appComponent.faqContentComponent - } - var fetchFaqCategoriesUseCase: any FetchFaqCategoriesUseCase { - return appComponent.fetchFaqCategoriesUseCase - } - var fetchFaqUseCase: any FetchFaqUseCase { - return appComponent.fetchFaqUseCase - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent - } -} -/// ^->AppComponent->FaqComponent -private func factory4e13cc6545633ffc2ed5f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return FaqDependency899aad15f17210a3af31Provider(appComponent: parent1(component) as! AppComponent) -} -private class QuestionDependencyf7010567c2d88e76d191Provider: QuestionDependency { - var suggestFunctionComponent: SuggestFunctionComponent { - return appComponent.suggestFunctionComponent - } - var wakMusicFeedbackComponent: WakMusicFeedbackComponent { - return appComponent.wakMusicFeedbackComponent - } - var askSongComponent: AskSongComponent { - return appComponent.askSongComponent - } - var bugReportComponent: BugReportComponent { - return appComponent.bugReportComponent - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent - } -} -/// ^->AppComponent->QuestionComponent -private func factoryedad1813a36115eec11ef47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return QuestionDependencyf7010567c2d88e76d191Provider(appComponent: parent1(component) as! AppComponent) -} -private class MyPlayListDependency067bbf42b28f80e413acProvider: MyPlayListDependency { - var multiPurposePopComponent: MultiPurposePopComponent { - return appComponent.multiPurposePopComponent - } - var playListDetailComponent: PlayListDetailComponent { - return appComponent.playListDetailComponent - } - var fetchPlayListUseCase: any FetchPlayListUseCase { - return appComponent.fetchPlayListUseCase - } - var editPlayListOrderUseCase: any EditPlayListOrderUseCase { - return appComponent.editPlayListOrderUseCase - } - var deletePlayListUseCase: any DeletePlayListUseCase { - return appComponent.deletePlayListUseCase + + /// ^->AppComponent->ArtistMusicContentComponent + private func factory8b6ffa46033e2529b5daf47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return ArtistMusicContentDependency1615ac8469e54ec51921Provider( + appComponent: parent1(component) as! AppComponent + ) } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + private class ArtistMusicDependencya0f5073287829dfbc260Provider: ArtistMusicDependency { + var artistMusicContentComponent: ArtistMusicContentComponent { + return appComponent.artistMusicContentComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } -} -/// ^->AppComponent->MyPlayListComponent -private func factory51a57a92f76af93a9ec2f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return MyPlayListDependency067bbf42b28f80e413acProvider(appComponent: parent1(component) as! AppComponent) -} -private class AfterLoginDependencya880b76858e0a77ed700Provider: AfterLoginDependency { - var fetchUserInfoUseCase: any FetchUserInfoUseCase { - return appComponent.fetchUserInfoUseCase + + /// ^->AppComponent->ArtistMusicComponent + private func factory382e7f8466df35a3f1d9f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return ArtistMusicDependencya0f5073287829dfbc260Provider(appComponent: parent1(component) as! AppComponent) } - var requestComponent: RequestComponent { - return appComponent.requestComponent + + private class PlaylistDependency6f376d117dc0f38671edProvider: PlaylistDependency { + var containSongsComponent: ContainSongsComponent { + return appComponent.containSongsComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - var profilePopComponent: ProfilePopComponent { - return appComponent.profilePopComponent + + /// ^->AppComponent->PlaylistComponent + private func factory3a0a6eb1061d8d5a2deff47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return PlaylistDependency6f376d117dc0f38671edProvider(appComponent: parent1(component) as! AppComponent) } - var myPlayListComponent: MyPlayListComponent { - return appComponent.myPlayListComponent + + private class PlayerDependencyf8a3d594cc3b9254f8adProvider: PlayerDependency { + var fetchLyricsUseCase: any FetchLyricsUseCase { + return appComponent.fetchLyricsUseCase + } + + var addLikeSongUseCase: any AddLikeSongUseCase { + return appComponent.addLikeSongUseCase + } + + var cancelLikeSongUseCase: any CancelLikeSongUseCase { + return appComponent.cancelLikeSongUseCase + } + + var fetchLikeNumOfSongUseCase: any FetchLikeNumOfSongUseCase { + return appComponent.fetchLikeNumOfSongUseCase + } + + var fetchFavoriteSongsUseCase: any FetchFavoriteSongsUseCase { + return appComponent.fetchFavoriteSongsUseCase + } + + var postPlaybackLogUseCase: any PostPlaybackLogUseCase { + return appComponent.postPlaybackLogUseCase + } + + var playlistComponent: PlaylistComponent { + return appComponent.playlistComponent + } + + var containSongsComponent: ContainSongsComponent { + return appComponent.containSongsComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - var multiPurposePopComponent: MultiPurposePopComponent { - return appComponent.multiPurposePopComponent + + /// ^->AppComponent->PlayerComponent + private func factorybc7f802f601dd5913533f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return PlayerDependencyf8a3d594cc3b9254f8adProvider(appComponent: parent1(component) as! AppComponent) } - var favoriteComponent: FavoriteComponent { - return appComponent.favoriteComponent + + private class MainTabBarDependencycd05b79389a6a7a6c20fProvider: MainTabBarDependency { + var fetchNoticeUseCase: any FetchNoticeUseCase { + return appComponent.fetchNoticeUseCase + } + + var homeComponent: HomeComponent { + return appComponent.homeComponent + } + + var chartComponent: ChartComponent { + return appComponent.chartComponent + } + + var searchComponent: SearchComponent { + return appComponent.searchComponent + } + + var artistComponent: ArtistComponent { + return appComponent.artistComponent + } + + var storageComponent: StorageComponent { + return appComponent.storageComponent + } + + var noticePopupComponent: NoticePopupComponent { + return appComponent.noticePopupComponent + } + + var noticeComponent: NoticeComponent { + return appComponent.noticeComponent + } + + var noticeDetailComponent: NoticeDetailComponent { + return appComponent.noticeDetailComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + /// ^->AppComponent->MainTabBarComponent + private func factorye547a52b3fce5887c8c7f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return MainTabBarDependencycd05b79389a6a7a6c20fProvider(appComponent: parent1(component) as! AppComponent) } -} -/// ^->AppComponent->AfterLoginComponent -private func factory6cc9c8141e04494113b8f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return AfterLoginDependencya880b76858e0a77ed700Provider(appComponent: parent1(component) as! AppComponent) -} -private class FavoriteDependency8f7fd37aeb6f0e5d0e30Provider: FavoriteDependency { - var containSongsComponent: ContainSongsComponent { - return appComponent.containSongsComponent + + private class BottomTabBarDependency237c2bd1c7be62020295Provider: BottomTabBarDependency { + init() {} } - var fetchFavoriteSongsUseCase: any FetchFavoriteSongsUseCase { - return appComponent.fetchFavoriteSongsUseCase + + /// ^->AppComponent->BottomTabBarComponent + private func factoryd34fa9e493604a6295bde3b0c44298fc1c149afb(_ component: NeedleFoundation.Scope) -> AnyObject { + return BottomTabBarDependency237c2bd1c7be62020295Provider() } - var editFavoriteSongsOrderUseCase: any EditFavoriteSongsOrderUseCase { - return appComponent.editFavoriteSongsOrderUseCase + + private class MainContainerDependencyd9d908a1d0cf8937bbadProvider: MainContainerDependency { + var bottomTabBarComponent: BottomTabBarComponent { + return appComponent.bottomTabBarComponent + } + + var mainTabBarComponent: MainTabBarComponent { + return appComponent.mainTabBarComponent + } + + var playerComponent: PlayerComponent { + return appComponent.playerComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - var deleteFavoriteListUseCase: any DeleteFavoriteListUseCase { - return appComponent.deleteFavoriteListUseCase + + /// ^->AppComponent->MainContainerComponent + private func factory8e19f48d5d573d3ea539f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return MainContainerDependencyd9d908a1d0cf8937bbadProvider(appComponent: parent1(component) as! AppComponent) } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + private class ChartDependencyafd8882010751c9ef054Provider: ChartDependency { + var chartContentComponent: ChartContentComponent { + return appComponent.chartContentComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } -} -/// ^->AppComponent->FavoriteComponent -private func factory8e4acb90bd0d9b48604af47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return FavoriteDependency8f7fd37aeb6f0e5d0e30Provider(appComponent: parent1(component) as! AppComponent) -} -private class RequestDependencyd4f6f0030dbf2a90cf21Provider: RequestDependency { - var withdrawUserInfoUseCase: any WithdrawUserInfoUseCase { - return appComponent.withdrawUserInfoUseCase + + /// ^->AppComponent->ChartComponent + private func factoryeac6a4df54bbd391d31bf47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return ChartDependencyafd8882010751c9ef054Provider(appComponent: parent1(component) as! AppComponent) } - var faqComponent: FaqComponent { - return appComponent.faqComponent + + private class ChartContentDependency3b8e41cfba060e4d16caProvider: ChartContentDependency { + var fetchChartRankingUseCase: any FetchChartRankingUseCase { + return appComponent.fetchChartRankingUseCase + } + + var fetchChartUpdateTimeUseCase: any FetchChartUpdateTimeUseCase { + return appComponent.fetchChartUpdateTimeUseCase + } + + var containSongsComponent: ContainSongsComponent { + return appComponent.containSongsComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - var questionComponent: QuestionComponent { - return appComponent.questionComponent + + /// ^->AppComponent->ChartContentComponent + private func factoryc9a137630ce76907f36ff47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return ChartContentDependency3b8e41cfba060e4d16caProvider(appComponent: parent1(component) as! AppComponent) } - var containSongsComponent: ContainSongsComponent { - return appComponent.containSongsComponent + + private class AskSongDependency02772625c56a0dda0140Provider: AskSongDependency { + var modifySongUseCase: any ModifySongUseCase { + return appComponent.modifySongUseCase + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - var noticeComponent: NoticeComponent { - return appComponent.noticeComponent + + /// ^->AppComponent->AskSongComponent + private func factory37544fa026b309cd68d7f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return AskSongDependency02772625c56a0dda0140Provider(appComponent: parent1(component) as! AppComponent) } - var serviceInfoComponent: ServiceInfoComponent { - return appComponent.serviceInfoComponent + + private class SuggestFunctionDependency229560bbe33097b02547Provider: SuggestFunctionDependency { + var suggestFunctionUseCase: any SuggestFunctionUseCase { + return appComponent.suggestFunctionUseCase + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + /// ^->AppComponent->SuggestFunctionComponent + private func factory63287bff3999ed1787ddf47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return SuggestFunctionDependency229560bbe33097b02547Provider(appComponent: parent1(component) as! AppComponent) } -} -/// ^->AppComponent->RequestComponent -private func factory13954fb3ec537bab80bcf47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return RequestDependencyd4f6f0030dbf2a90cf21Provider(appComponent: parent1(component) as! AppComponent) -} -private class NoticeDetailDependency714af3aed40eaebda420Provider: NoticeDetailDependency { + private class StorageDependency1447167c38e97ef97427Provider: StorageDependency { + var signInComponent: SignInComponent { + return appComponent.signInComponent + } - init() { + var afterLoginComponent: AfterLoginComponent { + return appComponent.afterLoginComponent + } + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } -} -/// ^->AppComponent->NoticeDetailComponent -private func factory3db143c2f80d621d5a7fe3b0c44298fc1c149afb(_ component: NeedleFoundation.Scope) -> AnyObject { - return NoticeDetailDependency714af3aed40eaebda420Provider() -} -private class NoticeDependencyaec92ef53617a421bdf3Provider: NoticeDependency { - var fetchNoticeUseCase: any FetchNoticeUseCase { - return appComponent.fetchNoticeUseCase - } - var noticeDetailComponent: NoticeDetailComponent { - return appComponent.noticeDetailComponent + + /// ^->AppComponent->StorageComponent + private func factory2415399d25299b97b98bf47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return StorageDependency1447167c38e97ef97427Provider(appComponent: parent1(component) as! AppComponent) } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + private class FaqDependency899aad15f17210a3af31Provider: FaqDependency { + var faqContentComponent: FaqContentComponent { + return appComponent.faqContentComponent + } + + var fetchFaqCategoriesUseCase: any FetchFaqCategoriesUseCase { + return appComponent.fetchFaqCategoriesUseCase + } + + var fetchFaqUseCase: any FetchFaqUseCase { + return appComponent.fetchFaqUseCase + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } -} -/// ^->AppComponent->NoticeComponent -private func factoryaf8e5665e5b9217918f5f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return NoticeDependencyaec92ef53617a421bdf3Provider(appComponent: parent1(component) as! AppComponent) -} -private class BugReportDependencyeea5818852f336c35729Provider: BugReportDependency { - var reportBugUseCase: any ReportBugUseCase { - return appComponent.reportBugUseCase + + /// ^->AppComponent->FaqComponent + private func factory4e13cc6545633ffc2ed5f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return FaqDependency899aad15f17210a3af31Provider(appComponent: parent1(component) as! AppComponent) } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + private class QuestionDependencyf7010567c2d88e76d191Provider: QuestionDependency { + var suggestFunctionComponent: SuggestFunctionComponent { + return appComponent.suggestFunctionComponent + } + + var wakMusicFeedbackComponent: WakMusicFeedbackComponent { + return appComponent.wakMusicFeedbackComponent + } + + var askSongComponent: AskSongComponent { + return appComponent.askSongComponent + } + + var bugReportComponent: BugReportComponent { + return appComponent.bugReportComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } -} -/// ^->AppComponent->BugReportComponent -private func factoryafa28e93c96a785ed32af47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return BugReportDependencyeea5818852f336c35729Provider(appComponent: parent1(component) as! AppComponent) -} -private class WakMusicFeedbackDependency8d09739bdcd24807ec82Provider: WakMusicFeedbackDependency { - var inquiryWeeklyChartUseCase: any InquiryWeeklyChartUseCase { - return appComponent.inquiryWeeklyChartUseCase + + /// ^->AppComponent->QuestionComponent + private func factoryedad1813a36115eec11ef47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return QuestionDependencyf7010567c2d88e76d191Provider(appComponent: parent1(component) as! AppComponent) } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + private class MyPlayListDependency067bbf42b28f80e413acProvider: MyPlayListDependency { + var multiPurposePopComponent: MultiPurposePopComponent { + return appComponent.multiPurposePopComponent + } + + var playListDetailComponent: PlayListDetailComponent { + return appComponent.playListDetailComponent + } + + var fetchPlayListUseCase: any FetchPlayListUseCase { + return appComponent.fetchPlayListUseCase + } + + var editPlayListOrderUseCase: any EditPlayListOrderUseCase { + return appComponent.editPlayListOrderUseCase + } + + var deletePlayListUseCase: any DeletePlayListUseCase { + return appComponent.deletePlayListUseCase + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } -} -/// ^->AppComponent->WakMusicFeedbackComponent -private func factory32abe9db091bc43329a1f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return WakMusicFeedbackDependency8d09739bdcd24807ec82Provider(appComponent: parent1(component) as! AppComponent) -} -private class RootDependency3944cc797a4a88956fb5Provider: RootDependency { - var mainContainerComponent: MainContainerComponent { - return appComponent.mainContainerComponent + + /// ^->AppComponent->MyPlayListComponent + private func factory51a57a92f76af93a9ec2f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return MyPlayListDependency067bbf42b28f80e413acProvider(appComponent: parent1(component) as! AppComponent) } - var permissionComponent: PermissionComponent { - return appComponent.permissionComponent + + private class AfterLoginDependencya880b76858e0a77ed700Provider: AfterLoginDependency { + var fetchUserInfoUseCase: any FetchUserInfoUseCase { + return appComponent.fetchUserInfoUseCase + } + + var requestComponent: RequestComponent { + return appComponent.requestComponent + } + + var profilePopComponent: ProfilePopComponent { + return appComponent.profilePopComponent + } + + var myPlayListComponent: MyPlayListComponent { + return appComponent.myPlayListComponent + } + + var multiPurposePopComponent: MultiPurposePopComponent { + return appComponent.multiPurposePopComponent + } + + var favoriteComponent: FavoriteComponent { + return appComponent.favoriteComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - var fetchUserInfoUseCase: any FetchUserInfoUseCase { - return appComponent.fetchUserInfoUseCase + + /// ^->AppComponent->AfterLoginComponent + private func factory6cc9c8141e04494113b8f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return AfterLoginDependencya880b76858e0a77ed700Provider(appComponent: parent1(component) as! AppComponent) } - var fetchAppCheckUseCase: any FetchAppCheckUseCase { - return appComponent.fetchAppCheckUseCase + + private class FavoriteDependency8f7fd37aeb6f0e5d0e30Provider: FavoriteDependency { + var containSongsComponent: ContainSongsComponent { + return appComponent.containSongsComponent + } + + var fetchFavoriteSongsUseCase: any FetchFavoriteSongsUseCase { + return appComponent.fetchFavoriteSongsUseCase + } + + var editFavoriteSongsOrderUseCase: any EditFavoriteSongsOrderUseCase { + return appComponent.editFavoriteSongsOrderUseCase + } + + var deleteFavoriteListUseCase: any DeleteFavoriteListUseCase { + return appComponent.deleteFavoriteListUseCase + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + /// ^->AppComponent->FavoriteComponent + private func factory8e4acb90bd0d9b48604af47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return FavoriteDependency8f7fd37aeb6f0e5d0e30Provider(appComponent: parent1(component) as! AppComponent) } -} -/// ^->AppComponent->RootComponent -private func factory264bfc4d4cb6b0629b40f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return RootDependency3944cc797a4a88956fb5Provider(appComponent: parent1(component) as! AppComponent) -} -private class PermissionDependency517ed7598d8c08817d14Provider: PermissionDependency { + private class RequestDependencyd4f6f0030dbf2a90cf21Provider: RequestDependency { + var withdrawUserInfoUseCase: any WithdrawUserInfoUseCase { + return appComponent.withdrawUserInfoUseCase + } - init() { + var faqComponent: FaqComponent { + return appComponent.faqComponent + } + var questionComponent: QuestionComponent { + return appComponent.questionComponent + } + + var containSongsComponent: ContainSongsComponent { + return appComponent.containSongsComponent + } + + var noticeComponent: NoticeComponent { + return appComponent.noticeComponent + } + + var serviceInfoComponent: ServiceInfoComponent { + return appComponent.serviceInfoComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } -} -/// ^->AppComponent->PermissionComponent -private func factoryc1d4d80afbccf86bf1c0e3b0c44298fc1c149afb(_ component: NeedleFoundation.Scope) -> AnyObject { - return PermissionDependency517ed7598d8c08817d14Provider() -} -private class SignInDependency5dda0dd015447272446cProvider: SignInDependency { - var fetchTokenUseCase: any FetchTokenUseCase { - return appComponent.fetchTokenUseCase - } - var fetchNaverUserInfoUseCase: any FetchNaverUserInfoUseCase { - return appComponent.fetchNaverUserInfoUseCase + + /// ^->AppComponent->RequestComponent + private func factory13954fb3ec537bab80bcf47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return RequestDependencyd4f6f0030dbf2a90cf21Provider(appComponent: parent1(component) as! AppComponent) } - var fetchUserInfoUseCase: any FetchUserInfoUseCase { - return appComponent.fetchUserInfoUseCase + + private class NoticeDetailDependency714af3aed40eaebda420Provider: NoticeDetailDependency { + init() {} } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + /// ^->AppComponent->NoticeDetailComponent + private func factory3db143c2f80d621d5a7fe3b0c44298fc1c149afb(_ component: NeedleFoundation.Scope) -> AnyObject { + return NoticeDetailDependency714af3aed40eaebda420Provider() } -} -/// ^->AppComponent->SignInComponent -private func factoryda2925fd76da866a652af47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return SignInDependency5dda0dd015447272446cProvider(appComponent: parent1(component) as! AppComponent) -} -private class HomeDependency443c4e1871277bd8432aProvider: HomeDependency { - var fetchChartRankingUseCase: any FetchChartRankingUseCase { - return appComponent.fetchChartRankingUseCase + + private class NoticeDependencyaec92ef53617a421bdf3Provider: NoticeDependency { + var fetchNoticeUseCase: any FetchNoticeUseCase { + return appComponent.fetchNoticeUseCase + } + + var noticeDetailComponent: NoticeDetailComponent { + return appComponent.noticeDetailComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - var fetchNewSongsUseCase: any FetchNewSongsUseCase { - return appComponent.fetchNewSongsUseCase + + /// ^->AppComponent->NoticeComponent + private func factoryaf8e5665e5b9217918f5f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return NoticeDependencyaec92ef53617a421bdf3Provider(appComponent: parent1(component) as! AppComponent) } - var fetchRecommendPlayListUseCase: any FetchRecommendPlayListUseCase { - return appComponent.fetchRecommendPlayListUseCase + + private class BugReportDependencyeea5818852f336c35729Provider: BugReportDependency { + var reportBugUseCase: any ReportBugUseCase { + return appComponent.reportBugUseCase + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - var playListDetailComponent: PlayListDetailComponent { - return appComponent.playListDetailComponent + + /// ^->AppComponent->BugReportComponent + private func factoryafa28e93c96a785ed32af47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return BugReportDependencyeea5818852f336c35729Provider(appComponent: parent1(component) as! AppComponent) } - var newSongsComponent: NewSongsComponent { - return appComponent.newSongsComponent + + private class WakMusicFeedbackDependency8d09739bdcd24807ec82Provider: WakMusicFeedbackDependency { + var inquiryWeeklyChartUseCase: any InquiryWeeklyChartUseCase { + return appComponent.inquiryWeeklyChartUseCase + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + /// ^->AppComponent->WakMusicFeedbackComponent + private func factory32abe9db091bc43329a1f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return WakMusicFeedbackDependency8d09739bdcd24807ec82Provider(appComponent: parent1(component) as! AppComponent) } -} -/// ^->AppComponent->HomeComponent -private func factory67229cdf0f755562b2b1f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return HomeDependency443c4e1871277bd8432aProvider(appComponent: parent1(component) as! AppComponent) -} -private class AfterSearchDependency61822c19bc2eb46d7c52Provider: AfterSearchDependency { - var afterSearchContentComponent: AfterSearchContentComponent { - return appComponent.afterSearchContentComponent + + private class RootDependency3944cc797a4a88956fb5Provider: RootDependency { + var mainContainerComponent: MainContainerComponent { + return appComponent.mainContainerComponent + } + + var permissionComponent: PermissionComponent { + return appComponent.permissionComponent + } + + var fetchUserInfoUseCase: any FetchUserInfoUseCase { + return appComponent.fetchUserInfoUseCase + } + + var fetchAppCheckUseCase: any FetchAppCheckUseCase { + return appComponent.fetchAppCheckUseCase + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - var fetchSearchSongUseCase: any FetchSearchSongUseCase { - return appComponent.fetchSearchSongUseCase + + /// ^->AppComponent->RootComponent + private func factory264bfc4d4cb6b0629b40f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return RootDependency3944cc797a4a88956fb5Provider(appComponent: parent1(component) as! AppComponent) } - var containSongsComponent: ContainSongsComponent { - return appComponent.containSongsComponent + + private class PermissionDependency517ed7598d8c08817d14Provider: PermissionDependency { + init() {} } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + /// ^->AppComponent->PermissionComponent + private func factoryc1d4d80afbccf86bf1c0e3b0c44298fc1c149afb(_ component: NeedleFoundation.Scope) -> AnyObject { + return PermissionDependency517ed7598d8c08817d14Provider() } -} -/// ^->AppComponent->AfterSearchComponent -private func factoryeb2da679e35e2c4fb9a5f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return AfterSearchDependency61822c19bc2eb46d7c52Provider(appComponent: parent1(component) as! AppComponent) -} -private class AfterSearchComponentDependency028b0697c8624344f660Provider: AfterSearchComponentDependency { + private class SignInDependency5dda0dd015447272446cProvider: SignInDependency { + var fetchTokenUseCase: any FetchTokenUseCase { + return appComponent.fetchTokenUseCase + } + + var fetchNaverUserInfoUseCase: any FetchNaverUserInfoUseCase { + return appComponent.fetchNaverUserInfoUseCase + } - init() { + var fetchUserInfoUseCase: any FetchUserInfoUseCase { + return appComponent.fetchUserInfoUseCase + } + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } -} -/// ^->AppComponent->AfterSearchContentComponent -private func factorycaaccdf52467bfa87f73e3b0c44298fc1c149afb(_ component: NeedleFoundation.Scope) -> AnyObject { - return AfterSearchComponentDependency028b0697c8624344f660Provider() -} -private class SearchDependencya86903a2c751a4f762e8Provider: SearchDependency { - var beforeSearchComponent: BeforeSearchComponent { - return appComponent.beforeSearchComponent + + /// ^->AppComponent->SignInComponent + private func factoryda2925fd76da866a652af47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return SignInDependency5dda0dd015447272446cProvider(appComponent: parent1(component) as! AppComponent) } - var afterSearchComponent: AfterSearchComponent { - return appComponent.afterSearchComponent + + private class HomeDependency443c4e1871277bd8432aProvider: HomeDependency { + var fetchChartRankingUseCase: any FetchChartRankingUseCase { + return appComponent.fetchChartRankingUseCase + } + + var fetchNewSongsUseCase: any FetchNewSongsUseCase { + return appComponent.fetchNewSongsUseCase + } + + var fetchRecommendPlayListUseCase: any FetchRecommendPlayListUseCase { + return appComponent.fetchRecommendPlayListUseCase + } + + var playListDetailComponent: PlayListDetailComponent { + return appComponent.playListDetailComponent + } + + var newSongsComponent: NewSongsComponent { + return appComponent.newSongsComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + /// ^->AppComponent->HomeComponent + private func factory67229cdf0f755562b2b1f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return HomeDependency443c4e1871277bd8432aProvider(appComponent: parent1(component) as! AppComponent) } -} -/// ^->AppComponent->SearchComponent -private func factorye3d049458b2ccbbcb3b6f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return SearchDependencya86903a2c751a4f762e8Provider(appComponent: parent1(component) as! AppComponent) -} -private class BeforeSearchDependencyebdecb1d478a4766488dProvider: BeforeSearchDependency { - var playListDetailComponent: PlayListDetailComponent { - return appComponent.playListDetailComponent + + private class AfterSearchDependency61822c19bc2eb46d7c52Provider: AfterSearchDependency { + var afterSearchContentComponent: AfterSearchContentComponent { + return appComponent.afterSearchContentComponent + } + + var fetchSearchSongUseCase: any FetchSearchSongUseCase { + return appComponent.fetchSearchSongUseCase + } + + var containSongsComponent: ContainSongsComponent { + return appComponent.containSongsComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - var fetchRecommendPlayListUseCase: any FetchRecommendPlayListUseCase { - return appComponent.fetchRecommendPlayListUseCase + + /// ^->AppComponent->AfterSearchComponent + private func factoryeb2da679e35e2c4fb9a5f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return AfterSearchDependency61822c19bc2eb46d7c52Provider(appComponent: parent1(component) as! AppComponent) } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + private class AfterSearchComponentDependency028b0697c8624344f660Provider: AfterSearchComponentDependency { + init() {} } -} -/// ^->AppComponent->BeforeSearchComponent -private func factory9bb852337d5550979293f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return BeforeSearchDependencyebdecb1d478a4766488dProvider(appComponent: parent1(component) as! AppComponent) -} -private class ContainSongsDependencydbd9ae8a072db3a22630Provider: ContainSongsDependency { - var multiPurposePopComponent: MultiPurposePopComponent { - return appComponent.multiPurposePopComponent + + /// ^->AppComponent->AfterSearchContentComponent + private func factorycaaccdf52467bfa87f73e3b0c44298fc1c149afb(_ component: NeedleFoundation.Scope) -> AnyObject { + return AfterSearchComponentDependency028b0697c8624344f660Provider() } - var fetchPlayListUseCase: any FetchPlayListUseCase { - return appComponent.fetchPlayListUseCase + + private class SearchDependencya86903a2c751a4f762e8Provider: SearchDependency { + var beforeSearchComponent: BeforeSearchComponent { + return appComponent.beforeSearchComponent + } + + var afterSearchComponent: AfterSearchComponent { + return appComponent.afterSearchComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - var addSongIntoPlayListUseCase: any AddSongIntoPlayListUseCase { - return appComponent.addSongIntoPlayListUseCase + + /// ^->AppComponent->SearchComponent + private func factorye3d049458b2ccbbcb3b6f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return SearchDependencya86903a2c751a4f762e8Provider(appComponent: parent1(component) as! AppComponent) } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + private class BeforeSearchDependencyebdecb1d478a4766488dProvider: BeforeSearchDependency { + var playListDetailComponent: PlayListDetailComponent { + return appComponent.playListDetailComponent + } + + var fetchRecommendPlayListUseCase: any FetchRecommendPlayListUseCase { + return appComponent.fetchRecommendPlayListUseCase + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } -} -/// ^->AppComponent->ContainSongsComponent -private func factory4d4f4455414271fee232f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return ContainSongsDependencydbd9ae8a072db3a22630Provider(appComponent: parent1(component) as! AppComponent) -} -private class ServiceInfoDependency17ccca17be0fc87c9a2eProvider: ServiceInfoDependency { - var openSourceLicenseComponent: OpenSourceLicenseComponent { - return appComponent.openSourceLicenseComponent + + /// ^->AppComponent->BeforeSearchComponent + private func factory9bb852337d5550979293f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return BeforeSearchDependencyebdecb1d478a4766488dProvider(appComponent: parent1(component) as! AppComponent) } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + private class ContainSongsDependencydbd9ae8a072db3a22630Provider: ContainSongsDependency { + var multiPurposePopComponent: MultiPurposePopComponent { + return appComponent.multiPurposePopComponent + } + + var fetchPlayListUseCase: any FetchPlayListUseCase { + return appComponent.fetchPlayListUseCase + } + + var addSongIntoPlayListUseCase: any AddSongIntoPlayListUseCase { + return appComponent.addSongIntoPlayListUseCase + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } -} -/// ^->AppComponent->ServiceInfoComponent -private func factory3afd170b9974b0dbd863f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return ServiceInfoDependency17ccca17be0fc87c9a2eProvider(appComponent: parent1(component) as! AppComponent) -} -private class MultiPurposePopDependency30141c7a9a9e67e148afProvider: MultiPurposePopDependency { - var createPlayListUseCase: any CreatePlayListUseCase { - return appComponent.createPlayListUseCase + + /// ^->AppComponent->ContainSongsComponent + private func factory4d4f4455414271fee232f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return ContainSongsDependencydbd9ae8a072db3a22630Provider(appComponent: parent1(component) as! AppComponent) } - var loadPlayListUseCase: any LoadPlayListUseCase { - return appComponent.loadPlayListUseCase + + private class ServiceInfoDependency17ccca17be0fc87c9a2eProvider: ServiceInfoDependency { + var openSourceLicenseComponent: OpenSourceLicenseComponent { + return appComponent.openSourceLicenseComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - var setUserNameUseCase: any SetUserNameUseCase { - return appComponent.setUserNameUseCase + + /// ^->AppComponent->ServiceInfoComponent + private func factory3afd170b9974b0dbd863f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return ServiceInfoDependency17ccca17be0fc87c9a2eProvider(appComponent: parent1(component) as! AppComponent) } - var editPlayListNameUseCase: any EditPlayListNameUseCase { - return appComponent.editPlayListNameUseCase + + private class MultiPurposePopDependency30141c7a9a9e67e148afProvider: MultiPurposePopDependency { + var createPlayListUseCase: any CreatePlayListUseCase { + return appComponent.createPlayListUseCase + } + + var loadPlayListUseCase: any LoadPlayListUseCase { + return appComponent.loadPlayListUseCase + } + + var setUserNameUseCase: any SetUserNameUseCase { + return appComponent.setUserNameUseCase + } + + var editPlayListNameUseCase: any EditPlayListNameUseCase { + return appComponent.editPlayListNameUseCase + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + /// ^->AppComponent->MultiPurposePopComponent + private func factory972fcba2860fcb8ad7b8f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return MultiPurposePopDependency30141c7a9a9e67e148afProvider(appComponent: parent1(component) as! AppComponent) } -} -/// ^->AppComponent->MultiPurposePopComponent -private func factory972fcba2860fcb8ad7b8f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return MultiPurposePopDependency30141c7a9a9e67e148afProvider(appComponent: parent1(component) as! AppComponent) -} -private class NewSongsDependencyee634cc0cae21fc2a9e3Provider: NewSongsDependency { - var newSongsContentComponent: NewSongsContentComponent { - return appComponent.newSongsContentComponent + + private class NewSongsDependencyee634cc0cae21fc2a9e3Provider: NewSongsDependency { + var newSongsContentComponent: NewSongsContentComponent { + return appComponent.newSongsContentComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + /// ^->AppComponent->NewSongsComponent + private func factory379179b05dd24ff979edf47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return NewSongsDependencyee634cc0cae21fc2a9e3Provider(appComponent: parent1(component) as! AppComponent) } -} -/// ^->AppComponent->NewSongsComponent -private func factory379179b05dd24ff979edf47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return NewSongsDependencyee634cc0cae21fc2a9e3Provider(appComponent: parent1(component) as! AppComponent) -} -private class PlayListDetailDependencyb06fb5392859952b82a2Provider: PlayListDetailDependency { - var fetchPlayListDetailUseCase: any FetchPlayListDetailUseCase { - return appComponent.fetchPlayListDetailUseCase + + private class PlayListDetailDependencyb06fb5392859952b82a2Provider: PlayListDetailDependency { + var fetchPlayListDetailUseCase: any FetchPlayListDetailUseCase { + return appComponent.fetchPlayListDetailUseCase + } + + var editPlayListUseCase: any EditPlayListUseCase { + return appComponent.editPlayListUseCase + } + + var removeSongsUseCase: any RemoveSongsUseCase { + return appComponent.removeSongsUseCase + } + + var multiPurposePopComponent: MultiPurposePopComponent { + return appComponent.multiPurposePopComponent + } + + var containSongsComponent: ContainSongsComponent { + return appComponent.containSongsComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } - var editPlayListUseCase: any EditPlayListUseCase { - return appComponent.editPlayListUseCase + + /// ^->AppComponent->PlayListDetailComponent + private func factory9e077ee814ce180ea399f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return PlayListDetailDependencyb06fb5392859952b82a2Provider(appComponent: parent1(component) as! AppComponent) } - var removeSongsUseCase: any RemoveSongsUseCase { - return appComponent.removeSongsUseCase + + private class OpenSourceLicenseDependencyb6842dcc36b26380b91aProvider: OpenSourceLicenseDependency { + init() {} } - var multiPurposePopComponent: MultiPurposePopComponent { - return appComponent.multiPurposePopComponent + + /// ^->AppComponent->OpenSourceLicenseComponent + private func factoryd505894818021731340ae3b0c44298fc1c149afb(_ component: NeedleFoundation.Scope) -> AnyObject { + return OpenSourceLicenseDependencyb6842dcc36b26380b91aProvider() } - var containSongsComponent: ContainSongsComponent { - return appComponent.containSongsComponent + + private class NoticePopupDependency579e3504f53119c2eef1Provider: NoticePopupDependency { + init() {} } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + /// ^->AppComponent->NoticePopupComponent + private func factorycd081aacb61d6a707ca7e3b0c44298fc1c149afb(_ component: NeedleFoundation.Scope) -> AnyObject { + return NoticePopupDependency579e3504f53119c2eef1Provider() } -} -/// ^->AppComponent->PlayListDetailComponent -private func factory9e077ee814ce180ea399f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return PlayListDetailDependencyb06fb5392859952b82a2Provider(appComponent: parent1(component) as! AppComponent) -} -private class OpenSourceLicenseDependencyb6842dcc36b26380b91aProvider: OpenSourceLicenseDependency { + private class ProfilePopDependency081172e20caa75abdb54Provider: ProfilePopDependency { + var fetchProfileListUseCase: any FetchProfileListUseCase { + return appComponent.fetchProfileListUseCase + } - init() { + var setProfileUseCase: any SetProfileUseCase { + return appComponent.setProfileUseCase + } + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } -} -/// ^->AppComponent->OpenSourceLicenseComponent -private func factoryd505894818021731340ae3b0c44298fc1c149afb(_ component: NeedleFoundation.Scope) -> AnyObject { - return OpenSourceLicenseDependencyb6842dcc36b26380b91aProvider() -} -private class NoticePopupDependency579e3504f53119c2eef1Provider: NoticePopupDependency { + /// ^->AppComponent->ProfilePopComponent + private func factorybd14b11ccce6dac94a24f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return ProfilePopDependency081172e20caa75abdb54Provider(appComponent: parent1(component) as! AppComponent) + } - init() { + private class NewSongsContentDependency93a05f20fa300c5bbec3Provider: NewSongsContentDependency { + var fetchNewSongsUseCase: any FetchNewSongsUseCase { + return appComponent.fetchNewSongsUseCase + } + var fetchChartUpdateTimeUseCase: any FetchChartUpdateTimeUseCase { + return appComponent.fetchChartUpdateTimeUseCase + } + + var containSongsComponent: ContainSongsComponent { + return appComponent.containSongsComponent + } + + private let appComponent: AppComponent + init(appComponent: AppComponent) { + self.appComponent = appComponent + } } -} -/// ^->AppComponent->NoticePopupComponent -private func factorycd081aacb61d6a707ca7e3b0c44298fc1c149afb(_ component: NeedleFoundation.Scope) -> AnyObject { - return NoticePopupDependency579e3504f53119c2eef1Provider() -} -private class ProfilePopDependency081172e20caa75abdb54Provider: ProfilePopDependency { - var fetchProfileListUseCase: any FetchProfileListUseCase { - return appComponent.fetchProfileListUseCase - } - var setProfileUseCase: any SetProfileUseCase { - return appComponent.setProfileUseCase - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent - } -} -/// ^->AppComponent->ProfilePopComponent -private func factorybd14b11ccce6dac94a24f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return ProfilePopDependency081172e20caa75abdb54Provider(appComponent: parent1(component) as! AppComponent) -} -private class NewSongsContentDependency93a05f20fa300c5bbec3Provider: NewSongsContentDependency { - var fetchNewSongsUseCase: any FetchNewSongsUseCase { - return appComponent.fetchNewSongsUseCase - } - var fetchChartUpdateTimeUseCase: any FetchChartUpdateTimeUseCase { - return appComponent.fetchChartUpdateTimeUseCase - } - var containSongsComponent: ContainSongsComponent { - return appComponent.containSongsComponent - } - private let appComponent: AppComponent - init(appComponent: AppComponent) { - self.appComponent = appComponent + + /// ^->AppComponent->NewSongsContentComponent + private func factorye130e1fbfcbc622a4c38f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { + return NewSongsContentDependency93a05f20fa300c5bbec3Provider(appComponent: parent1(component) as! AppComponent) } -} -/// ^->AppComponent->NewSongsContentComponent -private func factorye130e1fbfcbc622a4c38f47b58f8f304c97af4d5(_ component: NeedleFoundation.Scope) -> AnyObject { - return NewSongsContentDependency93a05f20fa300c5bbec3Provider(appComponent: parent1(component) as! AppComponent) -} #else -extension AppComponent: Registration { - public func registerItems() { - - localTable["keychain-any Keychain"] = { [unowned self] in self.keychain as Any } - localTable["remotePlayDataSource-any RemotePlayDataSource"] = { [unowned self] in self.remotePlayDataSource as Any } - localTable["playRepository-any PlayRepository"] = { [unowned self] in self.playRepository as Any } - localTable["postPlaybackLogUseCase-any PostPlaybackLogUseCase"] = { [unowned self] in self.postPlaybackLogUseCase as Any } - localTable["searchComponent-SearchComponent"] = { [unowned self] in self.searchComponent as Any } - localTable["afterSearchComponent-AfterSearchComponent"] = { [unowned self] in self.afterSearchComponent as Any } - localTable["afterSearchContentComponent-AfterSearchContentComponent"] = { [unowned self] in self.afterSearchContentComponent as Any } - localTable["homeComponent-HomeComponent"] = { [unowned self] in self.homeComponent as Any } - localTable["newSongsComponent-NewSongsComponent"] = { [unowned self] in self.newSongsComponent as Any } - localTable["newSongsContentComponent-NewSongsContentComponent"] = { [unowned self] in self.newSongsContentComponent as Any } - localTable["remoteSongsDataSource-any RemoteSongsDataSource"] = { [unowned self] in self.remoteSongsDataSource as Any } - localTable["songsRepository-any SongsRepository"] = { [unowned self] in self.songsRepository as Any } - localTable["fetchSearchSongUseCase-any FetchSearchSongUseCase"] = { [unowned self] in self.fetchSearchSongUseCase as Any } - localTable["fetchLyricsUseCase-any FetchLyricsUseCase"] = { [unowned self] in self.fetchLyricsUseCase as Any } - localTable["fetchNewSongsUseCase-any FetchNewSongsUseCase"] = { [unowned self] in self.fetchNewSongsUseCase as Any } - localTable["signInComponent-SignInComponent"] = { [unowned self] in self.signInComponent as Any } - localTable["storageComponent-StorageComponent"] = { [unowned self] in self.storageComponent as Any } - localTable["afterLoginComponent-AfterLoginComponent"] = { [unowned self] in self.afterLoginComponent as Any } - localTable["requestComponent-RequestComponent"] = { [unowned self] in self.requestComponent as Any } - localTable["remoteAuthDataSource-any RemoteAuthDataSource"] = { [unowned self] in self.remoteAuthDataSource as Any } - localTable["authRepository-any AuthRepository"] = { [unowned self] in self.authRepository as Any } - localTable["fetchTokenUseCase-any FetchTokenUseCase"] = { [unowned self] in self.fetchTokenUseCase as Any } - localTable["fetchNaverUserInfoUseCase-any FetchNaverUserInfoUseCase"] = { [unowned self] in self.fetchNaverUserInfoUseCase as Any } - localTable["remoteLikeDataSource-any RemoteLikeDataSource"] = { [unowned self] in self.remoteLikeDataSource as Any } - localTable["likeRepository-any LikeRepository"] = { [unowned self] in self.likeRepository as Any } - localTable["fetchLikeNumOfSongUseCase-any FetchLikeNumOfSongUseCase"] = { [unowned self] in self.fetchLikeNumOfSongUseCase as Any } - localTable["addLikeSongUseCase-any AddLikeSongUseCase"] = { [unowned self] in self.addLikeSongUseCase as Any } - localTable["cancelLikeSongUseCase-any CancelLikeSongUseCase"] = { [unowned self] in self.cancelLikeSongUseCase as Any } - localTable["beforeSearchComponent-BeforeSearchComponent"] = { [unowned self] in self.beforeSearchComponent as Any } - localTable["playListDetailComponent-PlayListDetailComponent"] = { [unowned self] in self.playListDetailComponent as Any } - localTable["multiPurposePopComponent-MultiPurposePopComponent"] = { [unowned self] in self.multiPurposePopComponent as Any } - localTable["myPlayListComponent-MyPlayListComponent"] = { [unowned self] in self.myPlayListComponent as Any } - localTable["containSongsComponent-ContainSongsComponent"] = { [unowned self] in self.containSongsComponent as Any } - localTable["remotePlayListDataSource-any RemotePlayListDataSource"] = { [unowned self] in self.remotePlayListDataSource as Any } - localTable["playListRepository-any PlayListRepository"] = { [unowned self] in self.playListRepository as Any } - localTable["fetchRecommendPlayListUseCase-any FetchRecommendPlayListUseCase"] = { [unowned self] in self.fetchRecommendPlayListUseCase as Any } - localTable["fetchPlayListDetailUseCase-any FetchPlayListDetailUseCase"] = { [unowned self] in self.fetchPlayListDetailUseCase as Any } - localTable["createPlayListUseCase-any CreatePlayListUseCase"] = { [unowned self] in self.createPlayListUseCase as Any } - localTable["editPlayListUseCase-any EditPlayListUseCase"] = { [unowned self] in self.editPlayListUseCase as Any } - localTable["editPlayListNameUseCase-any EditPlayListNameUseCase"] = { [unowned self] in self.editPlayListNameUseCase as Any } - localTable["loadPlayListUseCase-any LoadPlayListUseCase"] = { [unowned self] in self.loadPlayListUseCase as Any } - localTable["addSongIntoPlayListUseCase-any AddSongIntoPlayListUseCase"] = { [unowned self] in self.addSongIntoPlayListUseCase as Any } - localTable["removeSongsUseCase-any RemoveSongsUseCase"] = { [unowned self] in self.removeSongsUseCase as Any } - localTable["artistComponent-ArtistComponent"] = { [unowned self] in self.artistComponent as Any } - localTable["remoteArtistDataSource-RemoteArtistDataSourceImpl"] = { [unowned self] in self.remoteArtistDataSource as Any } - localTable["artistRepository-any ArtistRepository"] = { [unowned self] in self.artistRepository as Any } - localTable["fetchArtistListUseCase-any FetchArtistListUseCase"] = { [unowned self] in self.fetchArtistListUseCase as Any } - localTable["artistDetailComponent-ArtistDetailComponent"] = { [unowned self] in self.artistDetailComponent as Any } - localTable["fetchArtistSongListUseCase-any FetchArtistSongListUseCase"] = { [unowned self] in self.fetchArtistSongListUseCase as Any } - localTable["artistMusicComponent-ArtistMusicComponent"] = { [unowned self] in self.artistMusicComponent as Any } - localTable["artistMusicContentComponent-ArtistMusicContentComponent"] = { [unowned self] in self.artistMusicContentComponent as Any } - localTable["profilePopComponent-ProfilePopComponent"] = { [unowned self] in self.profilePopComponent as Any } - localTable["favoriteComponent-FavoriteComponent"] = { [unowned self] in self.favoriteComponent as Any } - localTable["remoteUserDataSource-any RemoteUserDataSource"] = { [unowned self] in self.remoteUserDataSource as Any } - localTable["userRepository-any UserRepository"] = { [unowned self] in self.userRepository as Any } - localTable["fetchProfileListUseCase-any FetchProfileListUseCase"] = { [unowned self] in self.fetchProfileListUseCase as Any } - localTable["setProfileUseCase-any SetProfileUseCase"] = { [unowned self] in self.setProfileUseCase as Any } - localTable["setUserNameUseCase-any SetUserNameUseCase"] = { [unowned self] in self.setUserNameUseCase as Any } - localTable["fetchPlayListUseCase-any FetchPlayListUseCase"] = { [unowned self] in self.fetchPlayListUseCase as Any } - localTable["fetchFavoriteSongsUseCase-any FetchFavoriteSongsUseCase"] = { [unowned self] in self.fetchFavoriteSongsUseCase as Any } - localTable["editFavoriteSongsOrderUseCase-any EditFavoriteSongsOrderUseCase"] = { [unowned self] in self.editFavoriteSongsOrderUseCase as Any } - localTable["editPlayListOrderUseCase-any EditPlayListOrderUseCase"] = { [unowned self] in self.editPlayListOrderUseCase as Any } - localTable["deletePlayListUseCase-any DeletePlayListUseCase"] = { [unowned self] in self.deletePlayListUseCase as Any } - localTable["deleteFavoriteListUseCase-any DeleteFavoriteListUseCase"] = { [unowned self] in self.deleteFavoriteListUseCase as Any } - localTable["fetchUserInfoUseCase-any FetchUserInfoUseCase"] = { [unowned self] in self.fetchUserInfoUseCase as Any } - localTable["withdrawUserInfoUseCase-any WithdrawUserInfoUseCase"] = { [unowned self] in self.withdrawUserInfoUseCase as Any } - localTable["mainContainerComponent-MainContainerComponent"] = { [unowned self] in self.mainContainerComponent as Any } - localTable["bottomTabBarComponent-BottomTabBarComponent"] = { [unowned self] in self.bottomTabBarComponent as Any } - localTable["mainTabBarComponent-MainTabBarComponent"] = { [unowned self] in self.mainTabBarComponent as Any } - localTable["playerComponent-PlayerComponent"] = { [unowned self] in self.playerComponent as Any } - localTable["playlistComponent-PlaylistComponent"] = { [unowned self] in self.playlistComponent as Any } - localTable["openSourceLicenseComponent-OpenSourceLicenseComponent"] = { [unowned self] in self.openSourceLicenseComponent as Any } - localTable["serviceInfoComponent-ServiceInfoComponent"] = { [unowned self] in self.serviceInfoComponent as Any } - localTable["permissionComponent-PermissionComponent"] = { [unowned self] in self.permissionComponent as Any } - localTable["noticePopupComponent-NoticePopupComponent"] = { [unowned self] in self.noticePopupComponent as Any } - localTable["noticeComponent-NoticeComponent"] = { [unowned self] in self.noticeComponent as Any } - localTable["noticeDetailComponent-NoticeDetailComponent"] = { [unowned self] in self.noticeDetailComponent as Any } - localTable["remoteNoticeDataSource-any RemoteNoticeDataSource"] = { [unowned self] in self.remoteNoticeDataSource as Any } - localTable["noticeRepository-any NoticeRepository"] = { [unowned self] in self.noticeRepository as Any } - localTable["fetchNoticeUseCase-any FetchNoticeUseCase"] = { [unowned self] in self.fetchNoticeUseCase as Any } - localTable["fetchNoticeCategoriesUseCase-any FetchNoticeCategoriesUseCase"] = { [unowned self] in self.fetchNoticeCategoriesUseCase as Any } - localTable["questionComponent-QuestionComponent"] = { [unowned self] in self.questionComponent as Any } - localTable["suggestFunctionComponent-SuggestFunctionComponent"] = { [unowned self] in self.suggestFunctionComponent as Any } - localTable["wakMusicFeedbackComponent-WakMusicFeedbackComponent"] = { [unowned self] in self.wakMusicFeedbackComponent as Any } - localTable["askSongComponent-AskSongComponent"] = { [unowned self] in self.askSongComponent as Any } - localTable["bugReportComponent-BugReportComponent"] = { [unowned self] in self.bugReportComponent as Any } - localTable["remoteSuggestDataSource-any RemoteSuggestDataSource"] = { [unowned self] in self.remoteSuggestDataSource as Any } - localTable["suggestRepository-any SuggestRepository"] = { [unowned self] in self.suggestRepository as Any } - localTable["reportBugUseCase-any ReportBugUseCase"] = { [unowned self] in self.reportBugUseCase as Any } - localTable["suggestFunctionUseCase-any SuggestFunctionUseCase"] = { [unowned self] in self.suggestFunctionUseCase as Any } - localTable["modifySongUseCase-any ModifySongUseCase"] = { [unowned self] in self.modifySongUseCase as Any } - localTable["inquiryWeeklyChartUseCase-any InquiryWeeklyChartUseCase"] = { [unowned self] in self.inquiryWeeklyChartUseCase as Any } - localTable["faqComponent-FaqComponent"] = { [unowned self] in self.faqComponent as Any } - localTable["faqContentComponent-FaqContentComponent"] = { [unowned self] in self.faqContentComponent as Any } - localTable["remoteFaqDataSource-any RemoteFaqDataSource"] = { [unowned self] in self.remoteFaqDataSource as Any } - localTable["faqRepository-any FaqRepository"] = { [unowned self] in self.faqRepository as Any } - localTable["fetchFaqCategoriesUseCase-any FetchFaqCategoriesUseCase"] = { [unowned self] in self.fetchFaqCategoriesUseCase as Any } - localTable["fetchFaqUseCase-any FetchFaqUseCase"] = { [unowned self] in self.fetchFaqUseCase as Any } - localTable["remoteAppDataSource-any RemoteAppDataSource"] = { [unowned self] in self.remoteAppDataSource as Any } - localTable["appRepository-any AppRepository"] = { [unowned self] in self.appRepository as Any } - localTable["fetchAppCheckUseCase-any FetchAppCheckUseCase"] = { [unowned self] in self.fetchAppCheckUseCase as Any } - localTable["chartComponent-ChartComponent"] = { [unowned self] in self.chartComponent as Any } - localTable["chartContentComponent-ChartContentComponent"] = { [unowned self] in self.chartContentComponent as Any } - localTable["remoteChartDataSource-any RemoteChartDataSource"] = { [unowned self] in self.remoteChartDataSource as Any } - localTable["chartRepository-any ChartRepository"] = { [unowned self] in self.chartRepository as Any } - localTable["fetchChartRankingUseCase-any FetchChartRankingUseCase"] = { [unowned self] in self.fetchChartRankingUseCase as Any } - localTable["fetchChartUpdateTimeUseCase-any FetchChartUpdateTimeUseCase"] = { [unowned self] in self.fetchChartUpdateTimeUseCase as Any } - } -} -extension ArtistComponent: Registration { - public func registerItems() { - keyPathToName[\ArtistDependency.fetchArtistListUseCase] = "fetchArtistListUseCase-any FetchArtistListUseCase" - keyPathToName[\ArtistDependency.artistDetailComponent] = "artistDetailComponent-ArtistDetailComponent" + extension AppComponent: Registration { + public func registerItems() { + localTable["keychain-any Keychain"] = { self.keychain as Any } + localTable["remotePlayDataSource-any RemotePlayDataSource"] = { self.remotePlayDataSource as Any } + localTable["playRepository-any PlayRepository"] = { self.playRepository as Any } + localTable["postPlaybackLogUseCase-any PostPlaybackLogUseCase"] = { self.postPlaybackLogUseCase as Any } + localTable["searchComponent-SearchComponent"] = { self.searchComponent as Any } + localTable["afterSearchComponent-AfterSearchComponent"] = { self.afterSearchComponent as Any } + localTable["afterSearchContentComponent-AfterSearchContentComponent"] = { + self.afterSearchContentComponent as Any + } + localTable["homeComponent-HomeComponent"] = { self.homeComponent as Any } + localTable["newSongsComponent-NewSongsComponent"] = { self.newSongsComponent as Any } + localTable["newSongsContentComponent-NewSongsContentComponent"] = { self.newSongsContentComponent as Any } + localTable["remoteSongsDataSource-any RemoteSongsDataSource"] = { self.remoteSongsDataSource as Any } + localTable["songsRepository-any SongsRepository"] = { self.songsRepository as Any } + localTable["fetchSearchSongUseCase-any FetchSearchSongUseCase"] = { self.fetchSearchSongUseCase as Any } + localTable["fetchLyricsUseCase-any FetchLyricsUseCase"] = { self.fetchLyricsUseCase as Any } + localTable["fetchNewSongsUseCase-any FetchNewSongsUseCase"] = { self.fetchNewSongsUseCase as Any } + localTable["signInComponent-SignInComponent"] = { self.signInComponent as Any } + localTable["storageComponent-StorageComponent"] = { self.storageComponent as Any } + localTable["afterLoginComponent-AfterLoginComponent"] = { self.afterLoginComponent as Any } + localTable["requestComponent-RequestComponent"] = { self.requestComponent as Any } + localTable["remoteAuthDataSource-any RemoteAuthDataSource"] = { self.remoteAuthDataSource as Any } + localTable["authRepository-any AuthRepository"] = { self.authRepository as Any } + localTable["fetchTokenUseCase-any FetchTokenUseCase"] = { self.fetchTokenUseCase as Any } + localTable["fetchNaverUserInfoUseCase-any FetchNaverUserInfoUseCase"] = { + self.fetchNaverUserInfoUseCase as Any + } + localTable["remoteLikeDataSource-any RemoteLikeDataSource"] = { self.remoteLikeDataSource as Any } + localTable["likeRepository-any LikeRepository"] = { self.likeRepository as Any } + localTable["fetchLikeNumOfSongUseCase-any FetchLikeNumOfSongUseCase"] = { + self.fetchLikeNumOfSongUseCase as Any + } + localTable["addLikeSongUseCase-any AddLikeSongUseCase"] = { self.addLikeSongUseCase as Any } + localTable["cancelLikeSongUseCase-any CancelLikeSongUseCase"] = { self.cancelLikeSongUseCase as Any } + localTable["beforeSearchComponent-BeforeSearchComponent"] = { self.beforeSearchComponent as Any } + localTable["playListDetailComponent-PlayListDetailComponent"] = { self.playListDetailComponent as Any } + localTable["multiPurposePopComponent-MultiPurposePopComponent"] = { self.multiPurposePopComponent as Any } + localTable["myPlayListComponent-MyPlayListComponent"] = { self.myPlayListComponent as Any } + localTable["containSongsComponent-ContainSongsComponent"] = { self.containSongsComponent as Any } + localTable["remotePlayListDataSource-any RemotePlayListDataSource"] = { + self.remotePlayListDataSource as Any + } + localTable["playListRepository-any PlayListRepository"] = { self.playListRepository as Any } + localTable["fetchRecommendPlayListUseCase-any FetchRecommendPlayListUseCase"] = { + self.fetchRecommendPlayListUseCase as Any + } + localTable["fetchPlayListDetailUseCase-any FetchPlayListDetailUseCase"] = { + self.fetchPlayListDetailUseCase as Any + } + localTable["createPlayListUseCase-any CreatePlayListUseCase"] = { self.createPlayListUseCase as Any } + localTable["editPlayListUseCase-any EditPlayListUseCase"] = { self.editPlayListUseCase as Any } + localTable["editPlayListNameUseCase-any EditPlayListNameUseCase"] = { self.editPlayListNameUseCase as Any } + localTable["loadPlayListUseCase-any LoadPlayListUseCase"] = { self.loadPlayListUseCase as Any } + localTable["addSongIntoPlayListUseCase-any AddSongIntoPlayListUseCase"] = { + self.addSongIntoPlayListUseCase as Any + } + localTable["removeSongsUseCase-any RemoveSongsUseCase"] = { self.removeSongsUseCase as Any } + localTable["artistComponent-ArtistComponent"] = { self.artistComponent as Any } + localTable["remoteArtistDataSource-RemoteArtistDataSourceImpl"] = { self.remoteArtistDataSource as Any } + localTable["artistRepository-any ArtistRepository"] = { self.artistRepository as Any } + localTable["fetchArtistListUseCase-any FetchArtistListUseCase"] = { self.fetchArtistListUseCase as Any } + localTable["artistDetailComponent-ArtistDetailComponent"] = { self.artistDetailComponent as Any } + localTable["fetchArtistSongListUseCase-any FetchArtistSongListUseCase"] = { + self.fetchArtistSongListUseCase as Any + } + localTable["artistMusicComponent-ArtistMusicComponent"] = { self.artistMusicComponent as Any } + localTable["artistMusicContentComponent-ArtistMusicContentComponent"] = { + self.artistMusicContentComponent as Any + } + localTable["profilePopComponent-ProfilePopComponent"] = { self.profilePopComponent as Any } + localTable["favoriteComponent-FavoriteComponent"] = { self.favoriteComponent as Any } + localTable["remoteUserDataSource-any RemoteUserDataSource"] = { self.remoteUserDataSource as Any } + localTable["userRepository-any UserRepository"] = { self.userRepository as Any } + localTable["fetchProfileListUseCase-any FetchProfileListUseCase"] = { self.fetchProfileListUseCase as Any } + localTable["setProfileUseCase-any SetProfileUseCase"] = { self.setProfileUseCase as Any } + localTable["setUserNameUseCase-any SetUserNameUseCase"] = { self.setUserNameUseCase as Any } + localTable["fetchPlayListUseCase-any FetchPlayListUseCase"] = { self.fetchPlayListUseCase as Any } + localTable["fetchFavoriteSongsUseCase-any FetchFavoriteSongsUseCase"] = { + self.fetchFavoriteSongsUseCase as Any + } + localTable["editFavoriteSongsOrderUseCase-any EditFavoriteSongsOrderUseCase"] = { + self.editFavoriteSongsOrderUseCase as Any + } + localTable["editPlayListOrderUseCase-any EditPlayListOrderUseCase"] = { + self.editPlayListOrderUseCase as Any + } + localTable["deletePlayListUseCase-any DeletePlayListUseCase"] = { self.deletePlayListUseCase as Any } + localTable["deleteFavoriteListUseCase-any DeleteFavoriteListUseCase"] = { + self.deleteFavoriteListUseCase as Any + } + localTable["fetchUserInfoUseCase-any FetchUserInfoUseCase"] = { self.fetchUserInfoUseCase as Any } + localTable["withdrawUserInfoUseCase-any WithdrawUserInfoUseCase"] = { self.withdrawUserInfoUseCase as Any } + localTable["mainContainerComponent-MainContainerComponent"] = { self.mainContainerComponent as Any } + localTable["bottomTabBarComponent-BottomTabBarComponent"] = { self.bottomTabBarComponent as Any } + localTable["mainTabBarComponent-MainTabBarComponent"] = { self.mainTabBarComponent as Any } + localTable["playerComponent-PlayerComponent"] = { self.playerComponent as Any } + localTable["playlistComponent-PlaylistComponent"] = { self.playlistComponent as Any } + localTable["openSourceLicenseComponent-OpenSourceLicenseComponent"] = { + self.openSourceLicenseComponent as Any + } + localTable["serviceInfoComponent-ServiceInfoComponent"] = { self.serviceInfoComponent as Any } + localTable["permissionComponent-PermissionComponent"] = { self.permissionComponent as Any } + localTable["noticePopupComponent-NoticePopupComponent"] = { self.noticePopupComponent as Any } + localTable["noticeComponent-NoticeComponent"] = { self.noticeComponent as Any } + localTable["noticeDetailComponent-NoticeDetailComponent"] = { self.noticeDetailComponent as Any } + localTable["remoteNoticeDataSource-any RemoteNoticeDataSource"] = { self.remoteNoticeDataSource as Any } + localTable["noticeRepository-any NoticeRepository"] = { self.noticeRepository as Any } + localTable["fetchNoticeUseCase-any FetchNoticeUseCase"] = { self.fetchNoticeUseCase as Any } + localTable["fetchNoticeCategoriesUseCase-any FetchNoticeCategoriesUseCase"] = { + self.fetchNoticeCategoriesUseCase as Any + } + localTable["questionComponent-QuestionComponent"] = { self.questionComponent as Any } + localTable["suggestFunctionComponent-SuggestFunctionComponent"] = { self.suggestFunctionComponent as Any } + localTable["wakMusicFeedbackComponent-WakMusicFeedbackComponent"] = { self.wakMusicFeedbackComponent as Any + } + localTable["askSongComponent-AskSongComponent"] = { self.askSongComponent as Any } + localTable["bugReportComponent-BugReportComponent"] = { self.bugReportComponent as Any } + localTable["remoteSuggestDataSource-any RemoteSuggestDataSource"] = { self.remoteSuggestDataSource as Any } + localTable["suggestRepository-any SuggestRepository"] = { self.suggestRepository as Any } + localTable["reportBugUseCase-any ReportBugUseCase"] = { self.reportBugUseCase as Any } + localTable["suggestFunctionUseCase-any SuggestFunctionUseCase"] = { self.suggestFunctionUseCase as Any } + localTable["modifySongUseCase-any ModifySongUseCase"] = { self.modifySongUseCase as Any } + localTable["inquiryWeeklyChartUseCase-any InquiryWeeklyChartUseCase"] = { + self.inquiryWeeklyChartUseCase as Any + } + localTable["faqComponent-FaqComponent"] = { self.faqComponent as Any } + localTable["faqContentComponent-FaqContentComponent"] = { self.faqContentComponent as Any } + localTable["remoteFaqDataSource-any RemoteFaqDataSource"] = { self.remoteFaqDataSource as Any } + localTable["faqRepository-any FaqRepository"] = { self.faqRepository as Any } + localTable["fetchFaqCategoriesUseCase-any FetchFaqCategoriesUseCase"] = { + self.fetchFaqCategoriesUseCase as Any + } + localTable["fetchFaqUseCase-any FetchFaqUseCase"] = { self.fetchFaqUseCase as Any } + localTable["remoteAppDataSource-any RemoteAppDataSource"] = { self.remoteAppDataSource as Any } + localTable["appRepository-any AppRepository"] = { self.appRepository as Any } + localTable["fetchAppCheckUseCase-any FetchAppCheckUseCase"] = { self.fetchAppCheckUseCase as Any } + localTable["chartComponent-ChartComponent"] = { self.chartComponent as Any } + localTable["chartContentComponent-ChartContentComponent"] = { self.chartContentComponent as Any } + localTable["remoteChartDataSource-any RemoteChartDataSource"] = { self.remoteChartDataSource as Any } + localTable["chartRepository-any ChartRepository"] = { self.chartRepository as Any } + localTable["fetchChartRankingUseCase-any FetchChartRankingUseCase"] = { + self.fetchChartRankingUseCase as Any + } + localTable["fetchChartUpdateTimeUseCase-any FetchChartUpdateTimeUseCase"] = { + self.fetchChartUpdateTimeUseCase as Any + } + } } -} -extension ArtistDetailComponent: Registration { - public func registerItems() { - keyPathToName[\ArtistDetailDependency.artistMusicComponent] = "artistMusicComponent-ArtistMusicComponent" + + extension ArtistComponent: Registration { + public func registerItems() { + keyPathToName[\ArtistDependency.fetchArtistListUseCase] = + "fetchArtistListUseCase-any FetchArtistListUseCase" + keyPathToName[\ArtistDependency.artistDetailComponent] = "artistDetailComponent-ArtistDetailComponent" + } } -} -extension ArtistMusicContentComponent: Registration { - public func registerItems() { - keyPathToName[\ArtistMusicContentDependency.fetchArtistSongListUseCase] = "fetchArtistSongListUseCase-any FetchArtistSongListUseCase" - keyPathToName[\ArtistMusicContentDependency.containSongsComponent] = "containSongsComponent-ContainSongsComponent" + + extension ArtistDetailComponent: Registration { + public func registerItems() { + keyPathToName[\ArtistDetailDependency.artistMusicComponent] = "artistMusicComponent-ArtistMusicComponent" + } } -} -extension ArtistMusicComponent: Registration { - public func registerItems() { - keyPathToName[\ArtistMusicDependency.artistMusicContentComponent] = "artistMusicContentComponent-ArtistMusicContentComponent" + + extension ArtistMusicContentComponent: Registration { + public func registerItems() { + keyPathToName[\ArtistMusicContentDependency.fetchArtistSongListUseCase] = + "fetchArtistSongListUseCase-any FetchArtistSongListUseCase" + keyPathToName[\ArtistMusicContentDependency.containSongsComponent] = + "containSongsComponent-ContainSongsComponent" + } } -} -extension PlaylistComponent: Registration { - public func registerItems() { - keyPathToName[\PlaylistDependency.containSongsComponent] = "containSongsComponent-ContainSongsComponent" + + extension ArtistMusicComponent: Registration { + public func registerItems() { + keyPathToName[\ArtistMusicDependency.artistMusicContentComponent] = + "artistMusicContentComponent-ArtistMusicContentComponent" + } } -} -extension PlayerComponent: Registration { - public func registerItems() { - keyPathToName[\PlayerDependency.fetchLyricsUseCase] = "fetchLyricsUseCase-any FetchLyricsUseCase" - keyPathToName[\PlayerDependency.addLikeSongUseCase] = "addLikeSongUseCase-any AddLikeSongUseCase" - keyPathToName[\PlayerDependency.cancelLikeSongUseCase] = "cancelLikeSongUseCase-any CancelLikeSongUseCase" - keyPathToName[\PlayerDependency.fetchLikeNumOfSongUseCase] = "fetchLikeNumOfSongUseCase-any FetchLikeNumOfSongUseCase" - keyPathToName[\PlayerDependency.fetchFavoriteSongsUseCase] = "fetchFavoriteSongsUseCase-any FetchFavoriteSongsUseCase" - keyPathToName[\PlayerDependency.postPlaybackLogUseCase] = "postPlaybackLogUseCase-any PostPlaybackLogUseCase" - keyPathToName[\PlayerDependency.playlistComponent] = "playlistComponent-PlaylistComponent" - keyPathToName[\PlayerDependency.containSongsComponent] = "containSongsComponent-ContainSongsComponent" + + extension PlaylistComponent: Registration { + public func registerItems() { + keyPathToName[\PlaylistDependency.containSongsComponent] = "containSongsComponent-ContainSongsComponent" + } } -} -extension MainTabBarComponent: Registration { - public func registerItems() { - keyPathToName[\MainTabBarDependency.fetchNoticeUseCase] = "fetchNoticeUseCase-any FetchNoticeUseCase" - keyPathToName[\MainTabBarDependency.homeComponent] = "homeComponent-HomeComponent" - keyPathToName[\MainTabBarDependency.chartComponent] = "chartComponent-ChartComponent" - keyPathToName[\MainTabBarDependency.searchComponent] = "searchComponent-SearchComponent" - keyPathToName[\MainTabBarDependency.artistComponent] = "artistComponent-ArtistComponent" - keyPathToName[\MainTabBarDependency.storageComponent] = "storageComponent-StorageComponent" - keyPathToName[\MainTabBarDependency.noticePopupComponent] = "noticePopupComponent-NoticePopupComponent" - keyPathToName[\MainTabBarDependency.noticeComponent] = "noticeComponent-NoticeComponent" - keyPathToName[\MainTabBarDependency.noticeDetailComponent] = "noticeDetailComponent-NoticeDetailComponent" + + extension PlayerComponent: Registration { + public func registerItems() { + keyPathToName[\PlayerDependency.fetchLyricsUseCase] = "fetchLyricsUseCase-any FetchLyricsUseCase" + keyPathToName[\PlayerDependency.addLikeSongUseCase] = "addLikeSongUseCase-any AddLikeSongUseCase" + keyPathToName[\PlayerDependency.cancelLikeSongUseCase] = "cancelLikeSongUseCase-any CancelLikeSongUseCase" + keyPathToName[\PlayerDependency.fetchLikeNumOfSongUseCase] = + "fetchLikeNumOfSongUseCase-any FetchLikeNumOfSongUseCase" + keyPathToName[\PlayerDependency.fetchFavoriteSongsUseCase] = + "fetchFavoriteSongsUseCase-any FetchFavoriteSongsUseCase" + keyPathToName[\PlayerDependency.postPlaybackLogUseCase] = + "postPlaybackLogUseCase-any PostPlaybackLogUseCase" + keyPathToName[\PlayerDependency.playlistComponent] = "playlistComponent-PlaylistComponent" + keyPathToName[\PlayerDependency.containSongsComponent] = "containSongsComponent-ContainSongsComponent" + } } -} -extension BottomTabBarComponent: Registration { - public func registerItems() { + extension MainTabBarComponent: Registration { + public func registerItems() { + keyPathToName[\MainTabBarDependency.fetchNoticeUseCase] = "fetchNoticeUseCase-any FetchNoticeUseCase" + keyPathToName[\MainTabBarDependency.homeComponent] = "homeComponent-HomeComponent" + keyPathToName[\MainTabBarDependency.chartComponent] = "chartComponent-ChartComponent" + keyPathToName[\MainTabBarDependency.searchComponent] = "searchComponent-SearchComponent" + keyPathToName[\MainTabBarDependency.artistComponent] = "artistComponent-ArtistComponent" + keyPathToName[\MainTabBarDependency.storageComponent] = "storageComponent-StorageComponent" + keyPathToName[\MainTabBarDependency.noticePopupComponent] = "noticePopupComponent-NoticePopupComponent" + keyPathToName[\MainTabBarDependency.noticeComponent] = "noticeComponent-NoticeComponent" + keyPathToName[\MainTabBarDependency.noticeDetailComponent] = "noticeDetailComponent-NoticeDetailComponent" + } } -} -extension MainContainerComponent: Registration { - public func registerItems() { - keyPathToName[\MainContainerDependency.bottomTabBarComponent] = "bottomTabBarComponent-BottomTabBarComponent" - keyPathToName[\MainContainerDependency.mainTabBarComponent] = "mainTabBarComponent-MainTabBarComponent" - keyPathToName[\MainContainerDependency.playerComponent] = "playerComponent-PlayerComponent" + + extension BottomTabBarComponent: Registration { + public func registerItems() {} } -} -extension ChartComponent: Registration { - public func registerItems() { - keyPathToName[\ChartDependency.chartContentComponent] = "chartContentComponent-ChartContentComponent" + + extension MainContainerComponent: Registration { + public func registerItems() { + keyPathToName[\MainContainerDependency.bottomTabBarComponent] = + "bottomTabBarComponent-BottomTabBarComponent" + keyPathToName[\MainContainerDependency.mainTabBarComponent] = "mainTabBarComponent-MainTabBarComponent" + keyPathToName[\MainContainerDependency.playerComponent] = "playerComponent-PlayerComponent" + } } -} -extension ChartContentComponent: Registration { - public func registerItems() { - keyPathToName[\ChartContentDependency.fetchChartRankingUseCase] = "fetchChartRankingUseCase-any FetchChartRankingUseCase" - keyPathToName[\ChartContentDependency.fetchChartUpdateTimeUseCase] = "fetchChartUpdateTimeUseCase-any FetchChartUpdateTimeUseCase" - keyPathToName[\ChartContentDependency.containSongsComponent] = "containSongsComponent-ContainSongsComponent" + + extension ChartComponent: Registration { + public func registerItems() { + keyPathToName[\ChartDependency.chartContentComponent] = "chartContentComponent-ChartContentComponent" + } } -} -extension AskSongComponent: Registration { - public func registerItems() { - keyPathToName[\AskSongDependency.modifySongUseCase] = "modifySongUseCase-any ModifySongUseCase" + + extension ChartContentComponent: Registration { + public func registerItems() { + keyPathToName[\ChartContentDependency.fetchChartRankingUseCase] = + "fetchChartRankingUseCase-any FetchChartRankingUseCase" + keyPathToName[\ChartContentDependency.fetchChartUpdateTimeUseCase] = + "fetchChartUpdateTimeUseCase-any FetchChartUpdateTimeUseCase" + keyPathToName[\ChartContentDependency.containSongsComponent] = "containSongsComponent-ContainSongsComponent" + } } -} -extension SuggestFunctionComponent: Registration { - public func registerItems() { - keyPathToName[\SuggestFunctionDependency.suggestFunctionUseCase] = "suggestFunctionUseCase-any SuggestFunctionUseCase" + + extension AskSongComponent: Registration { + public func registerItems() { + keyPathToName[\AskSongDependency.modifySongUseCase] = "modifySongUseCase-any ModifySongUseCase" + } } -} -extension StorageComponent: Registration { - public func registerItems() { - keyPathToName[\StorageDependency.signInComponent] = "signInComponent-SignInComponent" - keyPathToName[\StorageDependency.afterLoginComponent] = "afterLoginComponent-AfterLoginComponent" + + extension SuggestFunctionComponent: Registration { + public func registerItems() { + keyPathToName[\SuggestFunctionDependency.suggestFunctionUseCase] = + "suggestFunctionUseCase-any SuggestFunctionUseCase" + } } -} -extension FaqComponent: Registration { - public func registerItems() { - keyPathToName[\FaqDependency.faqContentComponent] = "faqContentComponent-FaqContentComponent" - keyPathToName[\FaqDependency.fetchFaqCategoriesUseCase] = "fetchFaqCategoriesUseCase-any FetchFaqCategoriesUseCase" - keyPathToName[\FaqDependency.fetchFaqUseCase] = "fetchFaqUseCase-any FetchFaqUseCase" + + extension StorageComponent: Registration { + public func registerItems() { + keyPathToName[\StorageDependency.signInComponent] = "signInComponent-SignInComponent" + keyPathToName[\StorageDependency.afterLoginComponent] = "afterLoginComponent-AfterLoginComponent" + } } -} -extension QuestionComponent: Registration { - public func registerItems() { - keyPathToName[\QuestionDependency.suggestFunctionComponent] = "suggestFunctionComponent-SuggestFunctionComponent" - keyPathToName[\QuestionDependency.wakMusicFeedbackComponent] = "wakMusicFeedbackComponent-WakMusicFeedbackComponent" - keyPathToName[\QuestionDependency.askSongComponent] = "askSongComponent-AskSongComponent" - keyPathToName[\QuestionDependency.bugReportComponent] = "bugReportComponent-BugReportComponent" + + extension FaqComponent: Registration { + public func registerItems() { + keyPathToName[\FaqDependency.faqContentComponent] = "faqContentComponent-FaqContentComponent" + keyPathToName[\FaqDependency.fetchFaqCategoriesUseCase] = + "fetchFaqCategoriesUseCase-any FetchFaqCategoriesUseCase" + keyPathToName[\FaqDependency.fetchFaqUseCase] = "fetchFaqUseCase-any FetchFaqUseCase" + } } -} -extension MyPlayListComponent: Registration { - public func registerItems() { - keyPathToName[\MyPlayListDependency.multiPurposePopComponent] = "multiPurposePopComponent-MultiPurposePopComponent" - keyPathToName[\MyPlayListDependency.playListDetailComponent] = "playListDetailComponent-PlayListDetailComponent" - keyPathToName[\MyPlayListDependency.fetchPlayListUseCase] = "fetchPlayListUseCase-any FetchPlayListUseCase" - keyPathToName[\MyPlayListDependency.editPlayListOrderUseCase] = "editPlayListOrderUseCase-any EditPlayListOrderUseCase" - keyPathToName[\MyPlayListDependency.deletePlayListUseCase] = "deletePlayListUseCase-any DeletePlayListUseCase" + + extension QuestionComponent: Registration { + public func registerItems() { + keyPathToName[\QuestionDependency.suggestFunctionComponent] = + "suggestFunctionComponent-SuggestFunctionComponent" + keyPathToName[\QuestionDependency.wakMusicFeedbackComponent] = + "wakMusicFeedbackComponent-WakMusicFeedbackComponent" + keyPathToName[\QuestionDependency.askSongComponent] = "askSongComponent-AskSongComponent" + keyPathToName[\QuestionDependency.bugReportComponent] = "bugReportComponent-BugReportComponent" + } } -} -extension AfterLoginComponent: Registration { - public func registerItems() { - keyPathToName[\AfterLoginDependency.fetchUserInfoUseCase] = "fetchUserInfoUseCase-any FetchUserInfoUseCase" - keyPathToName[\AfterLoginDependency.requestComponent] = "requestComponent-RequestComponent" - keyPathToName[\AfterLoginDependency.profilePopComponent] = "profilePopComponent-ProfilePopComponent" - keyPathToName[\AfterLoginDependency.myPlayListComponent] = "myPlayListComponent-MyPlayListComponent" - keyPathToName[\AfterLoginDependency.multiPurposePopComponent] = "multiPurposePopComponent-MultiPurposePopComponent" - keyPathToName[\AfterLoginDependency.favoriteComponent] = "favoriteComponent-FavoriteComponent" + + extension MyPlayListComponent: Registration { + public func registerItems() { + keyPathToName[\MyPlayListDependency.multiPurposePopComponent] = + "multiPurposePopComponent-MultiPurposePopComponent" + keyPathToName[\MyPlayListDependency.playListDetailComponent] = + "playListDetailComponent-PlayListDetailComponent" + keyPathToName[\MyPlayListDependency.fetchPlayListUseCase] = "fetchPlayListUseCase-any FetchPlayListUseCase" + keyPathToName[\MyPlayListDependency.editPlayListOrderUseCase] = + "editPlayListOrderUseCase-any EditPlayListOrderUseCase" + keyPathToName[\MyPlayListDependency.deletePlayListUseCase] = + "deletePlayListUseCase-any DeletePlayListUseCase" + } } -} -extension FavoriteComponent: Registration { - public func registerItems() { - keyPathToName[\FavoriteDependency.containSongsComponent] = "containSongsComponent-ContainSongsComponent" - keyPathToName[\FavoriteDependency.fetchFavoriteSongsUseCase] = "fetchFavoriteSongsUseCase-any FetchFavoriteSongsUseCase" - keyPathToName[\FavoriteDependency.editFavoriteSongsOrderUseCase] = "editFavoriteSongsOrderUseCase-any EditFavoriteSongsOrderUseCase" - keyPathToName[\FavoriteDependency.deleteFavoriteListUseCase] = "deleteFavoriteListUseCase-any DeleteFavoriteListUseCase" + + extension AfterLoginComponent: Registration { + public func registerItems() { + keyPathToName[\AfterLoginDependency.fetchUserInfoUseCase] = "fetchUserInfoUseCase-any FetchUserInfoUseCase" + keyPathToName[\AfterLoginDependency.requestComponent] = "requestComponent-RequestComponent" + keyPathToName[\AfterLoginDependency.profilePopComponent] = "profilePopComponent-ProfilePopComponent" + keyPathToName[\AfterLoginDependency.myPlayListComponent] = "myPlayListComponent-MyPlayListComponent" + keyPathToName[\AfterLoginDependency.multiPurposePopComponent] = + "multiPurposePopComponent-MultiPurposePopComponent" + keyPathToName[\AfterLoginDependency.favoriteComponent] = "favoriteComponent-FavoriteComponent" + } } -} -extension RequestComponent: Registration { - public func registerItems() { - keyPathToName[\RequestDependency.withdrawUserInfoUseCase] = "withdrawUserInfoUseCase-any WithdrawUserInfoUseCase" - keyPathToName[\RequestDependency.faqComponent] = "faqComponent-FaqComponent" - keyPathToName[\RequestDependency.questionComponent] = "questionComponent-QuestionComponent" - keyPathToName[\RequestDependency.containSongsComponent] = "containSongsComponent-ContainSongsComponent" - keyPathToName[\RequestDependency.noticeComponent] = "noticeComponent-NoticeComponent" - keyPathToName[\RequestDependency.serviceInfoComponent] = "serviceInfoComponent-ServiceInfoComponent" + + extension FavoriteComponent: Registration { + public func registerItems() { + keyPathToName[\FavoriteDependency.containSongsComponent] = "containSongsComponent-ContainSongsComponent" + keyPathToName[\FavoriteDependency.fetchFavoriteSongsUseCase] = + "fetchFavoriteSongsUseCase-any FetchFavoriteSongsUseCase" + keyPathToName[\FavoriteDependency.editFavoriteSongsOrderUseCase] = + "editFavoriteSongsOrderUseCase-any EditFavoriteSongsOrderUseCase" + keyPathToName[\FavoriteDependency.deleteFavoriteListUseCase] = + "deleteFavoriteListUseCase-any DeleteFavoriteListUseCase" + } } -} -extension NoticeDetailComponent: Registration { - public func registerItems() { + extension RequestComponent: Registration { + public func registerItems() { + keyPathToName[\RequestDependency.withdrawUserInfoUseCase] = + "withdrawUserInfoUseCase-any WithdrawUserInfoUseCase" + keyPathToName[\RequestDependency.faqComponent] = "faqComponent-FaqComponent" + keyPathToName[\RequestDependency.questionComponent] = "questionComponent-QuestionComponent" + keyPathToName[\RequestDependency.containSongsComponent] = "containSongsComponent-ContainSongsComponent" + keyPathToName[\RequestDependency.noticeComponent] = "noticeComponent-NoticeComponent" + keyPathToName[\RequestDependency.serviceInfoComponent] = "serviceInfoComponent-ServiceInfoComponent" + } } -} -extension NoticeComponent: Registration { - public func registerItems() { - keyPathToName[\NoticeDependency.fetchNoticeUseCase] = "fetchNoticeUseCase-any FetchNoticeUseCase" - keyPathToName[\NoticeDependency.noticeDetailComponent] = "noticeDetailComponent-NoticeDetailComponent" + + extension NoticeDetailComponent: Registration { + public func registerItems() {} } -} -extension BugReportComponent: Registration { - public func registerItems() { - keyPathToName[\BugReportDependency.reportBugUseCase] = "reportBugUseCase-any ReportBugUseCase" + + extension NoticeComponent: Registration { + public func registerItems() { + keyPathToName[\NoticeDependency.fetchNoticeUseCase] = "fetchNoticeUseCase-any FetchNoticeUseCase" + keyPathToName[\NoticeDependency.noticeDetailComponent] = "noticeDetailComponent-NoticeDetailComponent" + } } -} -extension WakMusicFeedbackComponent: Registration { - public func registerItems() { - keyPathToName[\WakMusicFeedbackDependency.inquiryWeeklyChartUseCase] = "inquiryWeeklyChartUseCase-any InquiryWeeklyChartUseCase" + + extension BugReportComponent: Registration { + public func registerItems() { + keyPathToName[\BugReportDependency.reportBugUseCase] = "reportBugUseCase-any ReportBugUseCase" + } } -} -extension FaqContentComponent: Registration { - public func registerItems() { + extension WakMusicFeedbackComponent: Registration { + public func registerItems() { + keyPathToName[\WakMusicFeedbackDependency.inquiryWeeklyChartUseCase] = + "inquiryWeeklyChartUseCase-any InquiryWeeklyChartUseCase" + } } -} -extension RootComponent: Registration { - public func registerItems() { - keyPathToName[\RootDependency.mainContainerComponent] = "mainContainerComponent-MainContainerComponent" - keyPathToName[\RootDependency.permissionComponent] = "permissionComponent-PermissionComponent" - keyPathToName[\RootDependency.fetchUserInfoUseCase] = "fetchUserInfoUseCase-any FetchUserInfoUseCase" - keyPathToName[\RootDependency.fetchAppCheckUseCase] = "fetchAppCheckUseCase-any FetchAppCheckUseCase" + + extension FaqContentComponent: Registration { + public func registerItems() {} } -} -extension PermissionComponent: Registration { - public func registerItems() { + extension RootComponent: Registration { + public func registerItems() { + keyPathToName[\RootDependency.mainContainerComponent] = "mainContainerComponent-MainContainerComponent" + keyPathToName[\RootDependency.permissionComponent] = "permissionComponent-PermissionComponent" + keyPathToName[\RootDependency.fetchUserInfoUseCase] = "fetchUserInfoUseCase-any FetchUserInfoUseCase" + keyPathToName[\RootDependency.fetchAppCheckUseCase] = "fetchAppCheckUseCase-any FetchAppCheckUseCase" + } } -} -extension SignInComponent: Registration { - public func registerItems() { - keyPathToName[\SignInDependency.fetchTokenUseCase] = "fetchTokenUseCase-any FetchTokenUseCase" - keyPathToName[\SignInDependency.fetchNaverUserInfoUseCase] = "fetchNaverUserInfoUseCase-any FetchNaverUserInfoUseCase" - keyPathToName[\SignInDependency.fetchUserInfoUseCase] = "fetchUserInfoUseCase-any FetchUserInfoUseCase" + + extension PermissionComponent: Registration { + public func registerItems() {} } -} -extension HomeComponent: Registration { - public func registerItems() { - keyPathToName[\HomeDependency.fetchChartRankingUseCase] = "fetchChartRankingUseCase-any FetchChartRankingUseCase" - keyPathToName[\HomeDependency.fetchNewSongsUseCase] = "fetchNewSongsUseCase-any FetchNewSongsUseCase" - keyPathToName[\HomeDependency.fetchRecommendPlayListUseCase] = "fetchRecommendPlayListUseCase-any FetchRecommendPlayListUseCase" - keyPathToName[\HomeDependency.playListDetailComponent] = "playListDetailComponent-PlayListDetailComponent" - keyPathToName[\HomeDependency.newSongsComponent] = "newSongsComponent-NewSongsComponent" + + extension SignInComponent: Registration { + public func registerItems() { + keyPathToName[\SignInDependency.fetchTokenUseCase] = "fetchTokenUseCase-any FetchTokenUseCase" + keyPathToName[\SignInDependency.fetchNaverUserInfoUseCase] = + "fetchNaverUserInfoUseCase-any FetchNaverUserInfoUseCase" + keyPathToName[\SignInDependency.fetchUserInfoUseCase] = "fetchUserInfoUseCase-any FetchUserInfoUseCase" + } } -} -extension AfterSearchComponent: Registration { - public func registerItems() { - keyPathToName[\AfterSearchDependency.afterSearchContentComponent] = "afterSearchContentComponent-AfterSearchContentComponent" - keyPathToName[\AfterSearchDependency.fetchSearchSongUseCase] = "fetchSearchSongUseCase-any FetchSearchSongUseCase" - keyPathToName[\AfterSearchDependency.containSongsComponent] = "containSongsComponent-ContainSongsComponent" + + extension HomeComponent: Registration { + public func registerItems() { + keyPathToName[\HomeDependency.fetchChartRankingUseCase] = + "fetchChartRankingUseCase-any FetchChartRankingUseCase" + keyPathToName[\HomeDependency.fetchNewSongsUseCase] = "fetchNewSongsUseCase-any FetchNewSongsUseCase" + keyPathToName[\HomeDependency.fetchRecommendPlayListUseCase] = + "fetchRecommendPlayListUseCase-any FetchRecommendPlayListUseCase" + keyPathToName[\HomeDependency.playListDetailComponent] = "playListDetailComponent-PlayListDetailComponent" + keyPathToName[\HomeDependency.newSongsComponent] = "newSongsComponent-NewSongsComponent" + } } -} -extension AfterSearchContentComponent: Registration { - public func registerItems() { + extension AfterSearchComponent: Registration { + public func registerItems() { + keyPathToName[\AfterSearchDependency.afterSearchContentComponent] = + "afterSearchContentComponent-AfterSearchContentComponent" + keyPathToName[\AfterSearchDependency.fetchSearchSongUseCase] = + "fetchSearchSongUseCase-any FetchSearchSongUseCase" + keyPathToName[\AfterSearchDependency.containSongsComponent] = "containSongsComponent-ContainSongsComponent" + } } -} -extension SearchComponent: Registration { - public func registerItems() { - keyPathToName[\SearchDependency.beforeSearchComponent] = "beforeSearchComponent-BeforeSearchComponent" - keyPathToName[\SearchDependency.afterSearchComponent] = "afterSearchComponent-AfterSearchComponent" + + extension AfterSearchContentComponent: Registration { + public func registerItems() {} } -} -extension BeforeSearchComponent: Registration { - public func registerItems() { - keyPathToName[\BeforeSearchDependency.playListDetailComponent] = "playListDetailComponent-PlayListDetailComponent" - keyPathToName[\BeforeSearchDependency.fetchRecommendPlayListUseCase] = "fetchRecommendPlayListUseCase-any FetchRecommendPlayListUseCase" + + extension SearchComponent: Registration { + public func registerItems() { + keyPathToName[\SearchDependency.beforeSearchComponent] = "beforeSearchComponent-BeforeSearchComponent" + keyPathToName[\SearchDependency.afterSearchComponent] = "afterSearchComponent-AfterSearchComponent" + } } -} -extension ContainSongsComponent: Registration { - public func registerItems() { - keyPathToName[\ContainSongsDependency.multiPurposePopComponent] = "multiPurposePopComponent-MultiPurposePopComponent" - keyPathToName[\ContainSongsDependency.fetchPlayListUseCase] = "fetchPlayListUseCase-any FetchPlayListUseCase" - keyPathToName[\ContainSongsDependency.addSongIntoPlayListUseCase] = "addSongIntoPlayListUseCase-any AddSongIntoPlayListUseCase" + + extension BeforeSearchComponent: Registration { + public func registerItems() { + keyPathToName[\BeforeSearchDependency.playListDetailComponent] = + "playListDetailComponent-PlayListDetailComponent" + keyPathToName[\BeforeSearchDependency.fetchRecommendPlayListUseCase] = + "fetchRecommendPlayListUseCase-any FetchRecommendPlayListUseCase" + } } -} -extension ServiceInfoComponent: Registration { - public func registerItems() { - keyPathToName[\ServiceInfoDependency.openSourceLicenseComponent] = "openSourceLicenseComponent-OpenSourceLicenseComponent" + + extension ContainSongsComponent: Registration { + public func registerItems() { + keyPathToName[\ContainSongsDependency.multiPurposePopComponent] = + "multiPurposePopComponent-MultiPurposePopComponent" + keyPathToName[\ContainSongsDependency.fetchPlayListUseCase] = + "fetchPlayListUseCase-any FetchPlayListUseCase" + keyPathToName[\ContainSongsDependency.addSongIntoPlayListUseCase] = + "addSongIntoPlayListUseCase-any AddSongIntoPlayListUseCase" + } } -} -extension MultiPurposePopComponent: Registration { - public func registerItems() { - keyPathToName[\MultiPurposePopDependency.createPlayListUseCase] = "createPlayListUseCase-any CreatePlayListUseCase" - keyPathToName[\MultiPurposePopDependency.loadPlayListUseCase] = "loadPlayListUseCase-any LoadPlayListUseCase" - keyPathToName[\MultiPurposePopDependency.setUserNameUseCase] = "setUserNameUseCase-any SetUserNameUseCase" - keyPathToName[\MultiPurposePopDependency.editPlayListNameUseCase] = "editPlayListNameUseCase-any EditPlayListNameUseCase" + + extension ServiceInfoComponent: Registration { + public func registerItems() { + keyPathToName[\ServiceInfoDependency.openSourceLicenseComponent] = + "openSourceLicenseComponent-OpenSourceLicenseComponent" + } } -} -extension NewSongsComponent: Registration { - public func registerItems() { - keyPathToName[\NewSongsDependency.newSongsContentComponent] = "newSongsContentComponent-NewSongsContentComponent" + + extension MultiPurposePopComponent: Registration { + public func registerItems() { + keyPathToName[\MultiPurposePopDependency.createPlayListUseCase] = + "createPlayListUseCase-any CreatePlayListUseCase" + keyPathToName[\MultiPurposePopDependency.loadPlayListUseCase] = + "loadPlayListUseCase-any LoadPlayListUseCase" + keyPathToName[\MultiPurposePopDependency.setUserNameUseCase] = "setUserNameUseCase-any SetUserNameUseCase" + keyPathToName[\MultiPurposePopDependency.editPlayListNameUseCase] = + "editPlayListNameUseCase-any EditPlayListNameUseCase" + } } -} -extension PlayListDetailComponent: Registration { - public func registerItems() { - keyPathToName[\PlayListDetailDependency.fetchPlayListDetailUseCase] = "fetchPlayListDetailUseCase-any FetchPlayListDetailUseCase" - keyPathToName[\PlayListDetailDependency.editPlayListUseCase] = "editPlayListUseCase-any EditPlayListUseCase" - keyPathToName[\PlayListDetailDependency.removeSongsUseCase] = "removeSongsUseCase-any RemoveSongsUseCase" - keyPathToName[\PlayListDetailDependency.multiPurposePopComponent] = "multiPurposePopComponent-MultiPurposePopComponent" - keyPathToName[\PlayListDetailDependency.containSongsComponent] = "containSongsComponent-ContainSongsComponent" + + extension NewSongsComponent: Registration { + public func registerItems() { + keyPathToName[\NewSongsDependency.newSongsContentComponent] = + "newSongsContentComponent-NewSongsContentComponent" + } } -} -extension OpenSourceLicenseComponent: Registration { - public func registerItems() { + extension PlayListDetailComponent: Registration { + public func registerItems() { + keyPathToName[\PlayListDetailDependency.fetchPlayListDetailUseCase] = + "fetchPlayListDetailUseCase-any FetchPlayListDetailUseCase" + keyPathToName[\PlayListDetailDependency.editPlayListUseCase] = "editPlayListUseCase-any EditPlayListUseCase" + keyPathToName[\PlayListDetailDependency.removeSongsUseCase] = "removeSongsUseCase-any RemoveSongsUseCase" + keyPathToName[\PlayListDetailDependency.multiPurposePopComponent] = + "multiPurposePopComponent-MultiPurposePopComponent" + keyPathToName[\PlayListDetailDependency.containSongsComponent] = + "containSongsComponent-ContainSongsComponent" + } } -} -extension NoticePopupComponent: Registration { - public func registerItems() { + extension OpenSourceLicenseComponent: Registration { + public func registerItems() {} } -} -extension ProfilePopComponent: Registration { - public func registerItems() { - keyPathToName[\ProfilePopDependency.fetchProfileListUseCase] = "fetchProfileListUseCase-any FetchProfileListUseCase" - keyPathToName[\ProfilePopDependency.setProfileUseCase] = "setProfileUseCase-any SetProfileUseCase" + + extension NoticePopupComponent: Registration { + public func registerItems() {} } -} -extension NewSongsContentComponent: Registration { - public func registerItems() { - keyPathToName[\NewSongsContentDependency.fetchNewSongsUseCase] = "fetchNewSongsUseCase-any FetchNewSongsUseCase" - keyPathToName[\NewSongsContentDependency.fetchChartUpdateTimeUseCase] = "fetchChartUpdateTimeUseCase-any FetchChartUpdateTimeUseCase" - keyPathToName[\NewSongsContentDependency.containSongsComponent] = "containSongsComponent-ContainSongsComponent" + + extension ProfilePopComponent: Registration { + public func registerItems() { + keyPathToName[\ProfilePopDependency.fetchProfileListUseCase] = + "fetchProfileListUseCase-any FetchProfileListUseCase" + keyPathToName[\ProfilePopDependency.setProfileUseCase] = "setProfileUseCase-any SetProfileUseCase" + } } -} + extension NewSongsContentComponent: Registration { + public func registerItems() { + keyPathToName[\NewSongsContentDependency.fetchNewSongsUseCase] = + "fetchNewSongsUseCase-any FetchNewSongsUseCase" + keyPathToName[\NewSongsContentDependency.fetchChartUpdateTimeUseCase] = + "fetchChartUpdateTimeUseCase-any FetchChartUpdateTimeUseCase" + keyPathToName[\NewSongsContentDependency.containSongsComponent] = + "containSongsComponent-ContainSongsComponent" + } + } #endif @@ -1194,61 +1469,121 @@ private func factoryEmptyDependencyProvider(_ component: NeedleFoundation.Scope) } // MARK: - Registration -private func registerProviderFactory(_ componentPath: String, _ factory: @escaping (NeedleFoundation.Scope) -> AnyObject) { +private func registerProviderFactory( + _ componentPath: String, + _ factory: @escaping (NeedleFoundation.Scope) -> AnyObject +) { __DependencyProviderRegistry.instance.registerDependencyProviderFactory(for: componentPath, factory) } #if !NEEDLE_DYNAMIC -@inline(never) private func register1() { - registerProviderFactory("^->AppComponent", factoryEmptyDependencyProvider) - registerProviderFactory("^->AppComponent->ArtistComponent", factorye0c5444f5894148bdd93f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->ArtistDetailComponent", factory35314797fadaf164ece6f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->ArtistMusicContentComponent", factory8b6ffa46033e2529b5daf47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->ArtistMusicComponent", factory382e7f8466df35a3f1d9f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->PlaylistComponent", factory3a0a6eb1061d8d5a2deff47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->PlayerComponent", factorybc7f802f601dd5913533f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->MainTabBarComponent", factorye547a52b3fce5887c8c7f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->BottomTabBarComponent", factoryd34fa9e493604a6295bde3b0c44298fc1c149afb) - registerProviderFactory("^->AppComponent->MainContainerComponent", factory8e19f48d5d573d3ea539f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->ChartComponent", factoryeac6a4df54bbd391d31bf47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->ChartContentComponent", factoryc9a137630ce76907f36ff47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->AskSongComponent", factory37544fa026b309cd68d7f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->SuggestFunctionComponent", factory63287bff3999ed1787ddf47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->StorageComponent", factory2415399d25299b97b98bf47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->FaqComponent", factory4e13cc6545633ffc2ed5f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->QuestionComponent", factoryedad1813a36115eec11ef47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->MyPlayListComponent", factory51a57a92f76af93a9ec2f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->AfterLoginComponent", factory6cc9c8141e04494113b8f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->FavoriteComponent", factory8e4acb90bd0d9b48604af47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->RequestComponent", factory13954fb3ec537bab80bcf47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->NoticeDetailComponent", factory3db143c2f80d621d5a7fe3b0c44298fc1c149afb) - registerProviderFactory("^->AppComponent->NoticeComponent", factoryaf8e5665e5b9217918f5f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->BugReportComponent", factoryafa28e93c96a785ed32af47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->WakMusicFeedbackComponent", factory32abe9db091bc43329a1f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->FaqContentComponent", factoryEmptyDependencyProvider) - registerProviderFactory("^->AppComponent->RootComponent", factory264bfc4d4cb6b0629b40f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->PermissionComponent", factoryc1d4d80afbccf86bf1c0e3b0c44298fc1c149afb) - registerProviderFactory("^->AppComponent->SignInComponent", factoryda2925fd76da866a652af47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->HomeComponent", factory67229cdf0f755562b2b1f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->AfterSearchComponent", factoryeb2da679e35e2c4fb9a5f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->AfterSearchContentComponent", factorycaaccdf52467bfa87f73e3b0c44298fc1c149afb) - registerProviderFactory("^->AppComponent->SearchComponent", factorye3d049458b2ccbbcb3b6f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->BeforeSearchComponent", factory9bb852337d5550979293f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->ContainSongsComponent", factory4d4f4455414271fee232f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->ServiceInfoComponent", factory3afd170b9974b0dbd863f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->MultiPurposePopComponent", factory972fcba2860fcb8ad7b8f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->NewSongsComponent", factory379179b05dd24ff979edf47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->PlayListDetailComponent", factory9e077ee814ce180ea399f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->OpenSourceLicenseComponent", factoryd505894818021731340ae3b0c44298fc1c149afb) - registerProviderFactory("^->AppComponent->NoticePopupComponent", factorycd081aacb61d6a707ca7e3b0c44298fc1c149afb) - registerProviderFactory("^->AppComponent->ProfilePopComponent", factorybd14b11ccce6dac94a24f47b58f8f304c97af4d5) - registerProviderFactory("^->AppComponent->NewSongsContentComponent", factorye130e1fbfcbc622a4c38f47b58f8f304c97af4d5) -} + @inline(never) private func register1() { + registerProviderFactory("^->AppComponent", factoryEmptyDependencyProvider) + registerProviderFactory("^->AppComponent->ArtistComponent", factorye0c5444f5894148bdd93f47b58f8f304c97af4d5) + registerProviderFactory( + "^->AppComponent->ArtistDetailComponent", + factory35314797fadaf164ece6f47b58f8f304c97af4d5 + ) + registerProviderFactory( + "^->AppComponent->ArtistMusicContentComponent", + factory8b6ffa46033e2529b5daf47b58f8f304c97af4d5 + ) + registerProviderFactory( + "^->AppComponent->ArtistMusicComponent", + factory382e7f8466df35a3f1d9f47b58f8f304c97af4d5 + ) + registerProviderFactory("^->AppComponent->PlaylistComponent", factory3a0a6eb1061d8d5a2deff47b58f8f304c97af4d5) + registerProviderFactory("^->AppComponent->PlayerComponent", factorybc7f802f601dd5913533f47b58f8f304c97af4d5) + registerProviderFactory("^->AppComponent->MainTabBarComponent", factorye547a52b3fce5887c8c7f47b58f8f304c97af4d5) + registerProviderFactory( + "^->AppComponent->BottomTabBarComponent", + factoryd34fa9e493604a6295bde3b0c44298fc1c149afb + ) + registerProviderFactory( + "^->AppComponent->MainContainerComponent", + factory8e19f48d5d573d3ea539f47b58f8f304c97af4d5 + ) + registerProviderFactory("^->AppComponent->ChartComponent", factoryeac6a4df54bbd391d31bf47b58f8f304c97af4d5) + registerProviderFactory( + "^->AppComponent->ChartContentComponent", + factoryc9a137630ce76907f36ff47b58f8f304c97af4d5 + ) + registerProviderFactory("^->AppComponent->AskSongComponent", factory37544fa026b309cd68d7f47b58f8f304c97af4d5) + registerProviderFactory( + "^->AppComponent->SuggestFunctionComponent", + factory63287bff3999ed1787ddf47b58f8f304c97af4d5 + ) + registerProviderFactory("^->AppComponent->StorageComponent", factory2415399d25299b97b98bf47b58f8f304c97af4d5) + registerProviderFactory("^->AppComponent->FaqComponent", factory4e13cc6545633ffc2ed5f47b58f8f304c97af4d5) + registerProviderFactory("^->AppComponent->QuestionComponent", factoryedad1813a36115eec11ef47b58f8f304c97af4d5) + registerProviderFactory("^->AppComponent->MyPlayListComponent", factory51a57a92f76af93a9ec2f47b58f8f304c97af4d5) + registerProviderFactory("^->AppComponent->AfterLoginComponent", factory6cc9c8141e04494113b8f47b58f8f304c97af4d5) + registerProviderFactory("^->AppComponent->FavoriteComponent", factory8e4acb90bd0d9b48604af47b58f8f304c97af4d5) + registerProviderFactory("^->AppComponent->RequestComponent", factory13954fb3ec537bab80bcf47b58f8f304c97af4d5) + registerProviderFactory( + "^->AppComponent->NoticeDetailComponent", + factory3db143c2f80d621d5a7fe3b0c44298fc1c149afb + ) + registerProviderFactory("^->AppComponent->NoticeComponent", factoryaf8e5665e5b9217918f5f47b58f8f304c97af4d5) + registerProviderFactory("^->AppComponent->BugReportComponent", factoryafa28e93c96a785ed32af47b58f8f304c97af4d5) + registerProviderFactory( + "^->AppComponent->WakMusicFeedbackComponent", + factory32abe9db091bc43329a1f47b58f8f304c97af4d5 + ) + registerProviderFactory("^->AppComponent->FaqContentComponent", factoryEmptyDependencyProvider) + registerProviderFactory("^->AppComponent->RootComponent", factory264bfc4d4cb6b0629b40f47b58f8f304c97af4d5) + registerProviderFactory("^->AppComponent->PermissionComponent", factoryc1d4d80afbccf86bf1c0e3b0c44298fc1c149afb) + registerProviderFactory("^->AppComponent->SignInComponent", factoryda2925fd76da866a652af47b58f8f304c97af4d5) + registerProviderFactory("^->AppComponent->HomeComponent", factory67229cdf0f755562b2b1f47b58f8f304c97af4d5) + registerProviderFactory( + "^->AppComponent->AfterSearchComponent", + factoryeb2da679e35e2c4fb9a5f47b58f8f304c97af4d5 + ) + registerProviderFactory( + "^->AppComponent->AfterSearchContentComponent", + factorycaaccdf52467bfa87f73e3b0c44298fc1c149afb + ) + registerProviderFactory("^->AppComponent->SearchComponent", factorye3d049458b2ccbbcb3b6f47b58f8f304c97af4d5) + registerProviderFactory( + "^->AppComponent->BeforeSearchComponent", + factory9bb852337d5550979293f47b58f8f304c97af4d5 + ) + registerProviderFactory( + "^->AppComponent->ContainSongsComponent", + factory4d4f4455414271fee232f47b58f8f304c97af4d5 + ) + registerProviderFactory( + "^->AppComponent->ServiceInfoComponent", + factory3afd170b9974b0dbd863f47b58f8f304c97af4d5 + ) + registerProviderFactory( + "^->AppComponent->MultiPurposePopComponent", + factory972fcba2860fcb8ad7b8f47b58f8f304c97af4d5 + ) + registerProviderFactory("^->AppComponent->NewSongsComponent", factory379179b05dd24ff979edf47b58f8f304c97af4d5) + registerProviderFactory( + "^->AppComponent->PlayListDetailComponent", + factory9e077ee814ce180ea399f47b58f8f304c97af4d5 + ) + registerProviderFactory( + "^->AppComponent->OpenSourceLicenseComponent", + factoryd505894818021731340ae3b0c44298fc1c149afb + ) + registerProviderFactory( + "^->AppComponent->NoticePopupComponent", + factorycd081aacb61d6a707ca7e3b0c44298fc1c149afb + ) + registerProviderFactory("^->AppComponent->ProfilePopComponent", factorybd14b11ccce6dac94a24f47b58f8f304c97af4d5) + registerProviderFactory( + "^->AppComponent->NewSongsContentComponent", + factorye130e1fbfcbc622a4c38f47b58f8f304c97af4d5 + ) + } #endif public func registerProviderFactories() { -#if !NEEDLE_DYNAMIC - register1() -#endif + #if !NEEDLE_DYNAMIC + register1() + #endif } diff --git a/Projects/Features/ArtistFeature/Sources/Reactors/ArtistReactor.swift b/Projects/Features/ArtistFeature/Sources/Reactors/ArtistReactor.swift index af85f94fe..30fc37e93 100644 --- a/Projects/Features/ArtistFeature/Sources/Reactors/ArtistReactor.swift +++ b/Projects/Features/ArtistFeature/Sources/Reactors/ArtistReactor.swift @@ -31,25 +31,7 @@ public final class ArtistReactor: Reactor { public func mutate(action: Action) -> Observable { switch action { case .viewDidLoad: - return fetchArtistListUseCase.execute() - .catchAndReturn([]) - .asObservable() - .map { [weak self] artistList in - guard let self, !artistList.isEmpty else { - DEBUG_LOG("데이터가 없습니다.") - return artistList - } - var newArtistList = artistList - - if newArtistList.count == 1 { - let hiddenItem: ArtistListEntity = self.makeHiddenArtistEntity() - newArtistList.append(hiddenItem) - } else { - newArtistList.swapAt(0, 1) - } - return newArtistList - } - .map(Mutation.updateArtistList) + return viewDidLoad() default: return .empty() @@ -66,6 +48,33 @@ public final class ArtistReactor: Reactor { } } +// MARK: - Mutate +private extension ArtistReactor { + func viewDidLoad() -> Observable { + return fetchArtistListUseCase.execute() + .catchAndReturn([]) + .asObservable() + .map { [weak self] artistList in + guard let self, !artistList.isEmpty else { + DEBUG_LOG("데이터가 없습니다.") + return artistList + } + var newArtistList = artistList + + // Waterfall Grid UI가 기본적으로 왼쪽부터 쌓이게 되기에 첫번째 Cell을 hide 시킵니다 + if newArtistList.count == 1 { + let hiddenItem: ArtistListEntity = self.makeHiddenArtistEntity() + newArtistList.append(hiddenItem) + } else { + newArtistList.swapAt(0, 1) + } + return newArtistList + } + .map(Mutation.updateArtistList) + } +} + +// MARK: - Reusable private extension ArtistReactor { func makeHiddenArtistEntity() -> ArtistListEntity { ArtistListEntity(