diff --git a/.gitignore b/.gitignore index be7f54db9..adfd0277d 100644 --- a/.gitignore +++ b/.gitignore @@ -84,8 +84,8 @@ Derived/ ### Tuist managed dependencies ### Tuist/Dependencies -### Tuist Signing ### -Tuist/Signing +### Tuist Master.key ### +Tuist/master.key ### Secrets Secrets.xcconfig diff --git a/Projects/App/Resources/Assets.xcassets/AppIcon.appiconset/AppIcon.png b/Projects/App/Resources/Assets.xcassets/AppIcon.appiconset/AppIcon.png new file mode 100644 index 000000000..223eb6a9b Binary files /dev/null and b/Projects/App/Resources/Assets.xcassets/AppIcon.appiconset/AppIcon.png differ diff --git a/Projects/App/Resources/Assets.xcassets/AppIcon.appiconset/AppIcon_1024x1024.png b/Projects/App/Resources/Assets.xcassets/AppIcon.appiconset/AppIcon_1024x1024.png deleted file mode 100644 index 0d1eb8f84..000000000 Binary files a/Projects/App/Resources/Assets.xcassets/AppIcon.appiconset/AppIcon_1024x1024.png and /dev/null differ diff --git a/Projects/App/Resources/Assets.xcassets/AppIcon.appiconset/Contents.json b/Projects/App/Resources/Assets.xcassets/AppIcon.appiconset/Contents.json index 75e969190..cefcc878e 100644 --- a/Projects/App/Resources/Assets.xcassets/AppIcon.appiconset/Contents.json +++ b/Projects/App/Resources/Assets.xcassets/AppIcon.appiconset/Contents.json @@ -1,7 +1,7 @@ { "images" : [ { - "filename" : "AppIcon_1024x1024.png", + "filename" : "AppIcon.png", "idiom" : "universal", "platform" : "ios", "size" : "1024x1024" diff --git a/Projects/Features/ArtistFeature/Sources/ViewControllers/ArtistDetailHeaderViewController.swift b/Projects/Features/ArtistFeature/Sources/ViewControllers/ArtistDetailHeaderViewController.swift index 1afb4959b..1e7e05aac 100644 --- a/Projects/Features/ArtistFeature/Sources/ViewControllers/ArtistDetailHeaderViewController.swift +++ b/Projects/Features/ArtistFeature/Sources/ViewControllers/ArtistDetailHeaderViewController.swift @@ -181,7 +181,7 @@ extension ArtistDetailHeaderViewController { artistGroupLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 14) artistGroupLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - artistGroupLabel.setLineSpacing(kernValue: -0.5) + artistGroupLabel.setTextWithAttributes(kernValue: -0.5) artistIntroLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 14) artistIntroLabel.textColor = DesignSystemAsset.GrayColor.gray900.color @@ -189,13 +189,13 @@ extension ArtistDetailHeaderViewController { introTitleLabel.font = DesignSystemFontFamily.Pretendard.bold.font(size: 14) introTitleLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - introTitleLabel.setLineSpacing(kernValue: -0.5) + introTitleLabel.setTextWithAttributes(kernValue: -0.5) introDescriptionLabel.font = DesignSystemFontFamily.Pretendard.light.font(size: 12) introDescriptionLabel.textColor = DesignSystemAsset.GrayColor.gray900.color introDescriptionLabel.textAlignment = .left introDescriptionLabel.lineBreakMode = .byWordWrapping - introDescriptionLabel.setLineSpacing(kernValue: -0.5) + introDescriptionLabel.setTextWithAttributes(kernValue: -0.5) scrollView.scrollIndicatorInsets = UIEdgeInsets(top: 0, left: 0, bottom: 0, right: -3) } diff --git a/Projects/Modules/Utility/Sources/Utils/AES256.swift b/Projects/Features/BaseFeature/Sources/AES256.swift similarity index 96% rename from Projects/Modules/Utility/Sources/Utils/AES256.swift rename to Projects/Features/BaseFeature/Sources/AES256.swift index fc4404fd8..0e0c178e8 100644 --- a/Projects/Modules/Utility/Sources/Utils/AES256.swift +++ b/Projects/Features/BaseFeature/Sources/AES256.swift @@ -1,8 +1,8 @@ // // AES256.swift -// Utility +// BaseFeature // -// Created by KTH on 2023/02/18. +// Created by KTH on 2023/11/26. // Copyright © 2023 yongbeomkwak. All rights reserved. // diff --git a/Projects/Features/CommonFeature/Resources/EditSheetView/EditSheetView.xib b/Projects/Features/CommonFeature/Resources/EditSheetView/EditSheetView.xib index 37eca9d1e..b8944a687 100644 --- a/Projects/Features/CommonFeature/Resources/EditSheetView/EditSheetView.xib +++ b/Projects/Features/CommonFeature/Resources/EditSheetView/EditSheetView.xib @@ -1,9 +1,9 @@ - + - + @@ -11,6 +11,7 @@ + @@ -23,7 +24,7 @@ - + @@ -94,7 +95,7 @@ - + diff --git a/Projects/Features/CommonFeature/Resources/SongCartView/SongCartView.xib b/Projects/Features/CommonFeature/Resources/SongCartView/SongCartView.xib index 085b9c339..b92322f3d 100644 --- a/Projects/Features/CommonFeature/Resources/SongCartView/SongCartView.xib +++ b/Projects/Features/CommonFeature/Resources/SongCartView/SongCartView.xib @@ -1,9 +1,9 @@ - + - + @@ -24,6 +24,7 @@ + @@ -178,7 +179,7 @@ - + diff --git a/Projects/Features/CommonFeature/Sources/ViewControllers/ContainSongsViewController.swift b/Projects/Features/CommonFeature/Sources/ViewControllers/ContainSongsViewController.swift index e2edd7c8d..11034c3b1 100644 --- a/Projects/Features/CommonFeature/Sources/ViewControllers/ContainSongsViewController.swift +++ b/Projects/Features/CommonFeature/Sources/ViewControllers/ContainSongsViewController.swift @@ -135,17 +135,17 @@ extension ContainSongsViewController { titleLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) titleLabel.textColor = DesignSystemAsset.GrayColor.gray900.color titleLabel.text = "리스트에 담기" - titleLabel.setLineSpacing(kernValue: -0.5) + titleLabel.setTextWithAttributes(kernValue: -0.5) songCountLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 14) songCountLabel.textColor = DesignSystemAsset.PrimaryColor.point.color songCountLabel.text = "\(viewModel.songs.count)" - songCountLabel.setLineSpacing(kernValue: -0.5) - + songCountLabel.setTextWithAttributes(kernValue: -0.5) + subTitleLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 14) subTitleLabel.textColor = DesignSystemAsset.PrimaryColor.sub3.color subTitleLabel.text = "곡 선택" - subTitleLabel.setLineSpacing(kernValue: -0.5) + subTitleLabel.setTextWithAttributes(kernValue: -0.5) indicator.type = .circleStrokeSpin indicator.color = DesignSystemAsset.PrimaryColor.point.color diff --git a/Projects/Features/CommonFeature/Sources/ViewControllers/ContractViewController.swift b/Projects/Features/CommonFeature/Sources/ViewControllers/ContractViewController.swift index a3632d9ce..682869d11 100644 --- a/Projects/Features/CommonFeature/Sources/ViewControllers/ContractViewController.swift +++ b/Projects/Features/CommonFeature/Sources/ViewControllers/ContractViewController.swift @@ -111,8 +111,8 @@ extension ContractViewController{ titleLabel.text = type.title titleLabel.textColor = DesignSystemAsset.GrayColor.gray900.color titleLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) - titleLabel.setLineSpacing(kernValue: -0.5) - + titleLabel.setTextWithAttributes(kernValue: -0.5) + DispatchQueue.global(qos: .default).async { if let url = URL(string: self.type.url), let document = PDFDocument(url: url) { DispatchQueue.main.async { diff --git a/Projects/Features/CommonFeature/Sources/ViewControllers/NewSongsViewController.swift b/Projects/Features/CommonFeature/Sources/ViewControllers/NewSongsViewController.swift index bba330c69..b2a6fce1c 100644 --- a/Projects/Features/CommonFeature/Sources/ViewControllers/NewSongsViewController.swift +++ b/Projects/Features/CommonFeature/Sources/ViewControllers/NewSongsViewController.swift @@ -54,7 +54,7 @@ extension NewSongsViewController { self.navigationTitleLabel.text = "최신 음악" self.navigationTitleLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) self.navigationTitleLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - self.navigationTitleLabel.setLineSpacing(kernValue: -0.5) + self.navigationTitleLabel.setTextWithAttributes(kernValue: -0.5) } private func configurePage() { diff --git a/Projects/Features/CommonFeature/Sources/ViewControllers/OpenSourceLicenseViewController.swift b/Projects/Features/CommonFeature/Sources/ViewControllers/OpenSourceLicenseViewController.swift index f9a61d3c8..7ec9bab3f 100644 --- a/Projects/Features/CommonFeature/Sources/ViewControllers/OpenSourceLicenseViewController.swift +++ b/Projects/Features/CommonFeature/Sources/ViewControllers/OpenSourceLicenseViewController.swift @@ -112,7 +112,7 @@ extension OpenSourceLicenseViewController { titleStringLabel.text = "오픈소스 라이선스" titleStringLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) titleStringLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - titleStringLabel.setLineSpacing(kernValue: -0.5) + titleStringLabel.setTextWithAttributes(kernValue: -0.5) tableView.tableFooterView = UIView(frame: CGRect(x: 0, y: 0, width: APP_WIDTH(), height: 56)) tableView.scrollIndicatorInsets = UIEdgeInsets(top: 0, left: 0, bottom: 56, right: 0) } diff --git a/Projects/Features/CommonFeature/Sources/ViewControllers/PlayListDetailViewController.swift b/Projects/Features/CommonFeature/Sources/ViewControllers/PlayListDetailViewController.swift index 5384abfb6..ccc8f2196 100644 --- a/Projects/Features/CommonFeature/Sources/ViewControllers/PlayListDetailViewController.swift +++ b/Projects/Features/CommonFeature/Sources/ViewControllers/PlayListDetailViewController.swift @@ -157,15 +157,15 @@ extension PlayListDetailViewController{ self.editStateLabel.text = "편집" self.editStateLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) - self.editStateLabel.setLineSpacing(kernValue: -0.5) + self.editStateLabel.setTextWithAttributes(kernValue: -0.5) self.playListCountLabel.font = DesignSystemFontFamily.Pretendard.light.font(size: 14) self.playListCountLabel.textColor = DesignSystemAsset.GrayColor.gray900.color.withAlphaComponent(0.6) // opacity 60% - self.playListCountLabel.setLineSpacing(kernValue: -0.5) + self.playListCountLabel.setTextWithAttributes(kernValue: -0.5) self.playListNameLabel.font = DesignSystemFontFamily.Pretendard.bold.font(size: 20) - self.playListNameLabel.setLineSpacing(kernValue: -0.5) - + self.playListNameLabel.setTextWithAttributes(kernValue: -0.5) + playListInfoView.layer.borderWidth = 1 playListInfoView.layer.borderColor = colorFromRGB(0xFCFCFD).cgColor playListInfoView.layer.cornerRadius = 8 diff --git a/Projects/Features/CommonFeature/Sources/ViewControllers/ProfilePopViewController.swift b/Projects/Features/CommonFeature/Sources/ViewControllers/ProfilePopViewController.swift index 3ef03bc56..99c19f12d 100644 --- a/Projects/Features/CommonFeature/Sources/ViewControllers/ProfilePopViewController.swift +++ b/Projects/Features/CommonFeature/Sources/ViewControllers/ProfilePopViewController.swift @@ -50,7 +50,7 @@ public final class ProfilePopViewController: UIViewController, ViewControllerFro extension ProfilePopViewController{ private func configureUI(){ - + saveButton.backgroundColor = DesignSystemAsset.PrimaryColor.point.color saveButton.layer.cornerRadius = 12 saveButton.clipsToBounds = true saveButton.setAttributedTitle( diff --git a/Projects/Features/CommonFeature/Sources/ViewControllers/ServiceInfoViewController.swift b/Projects/Features/CommonFeature/Sources/ViewControllers/ServiceInfoViewController.swift index 97229dfd1..cf86b8ebe 100644 --- a/Projects/Features/CommonFeature/Sources/ViewControllers/ServiceInfoViewController.swift +++ b/Projects/Features/CommonFeature/Sources/ViewControllers/ServiceInfoViewController.swift @@ -135,7 +135,7 @@ extension ServiceInfoViewController { titleStringLabel.text = "서비스 정보" titleStringLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) titleStringLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - titleStringLabel.setLineSpacing(kernValue: -0.5) + titleStringLabel.setTextWithAttributes(kernValue: -0.5) tableView.tableHeaderView = UIView(frame: CGRect(x: 0, y: 0, width: APP_WIDTH(), height: 20)) tableView.tableFooterView = UIView(frame: CGRect(x: 0, y: 0, width: APP_WIDTH(), height: 56)) tableView.scrollIndicatorInsets = UIEdgeInsets(top: 0, left: 0, bottom: 56, right: 0) diff --git a/Projects/Features/CommonFeature/Sources/ViewControllers/TextPopupViewController.swift b/Projects/Features/CommonFeature/Sources/ViewControllers/TextPopupViewController.swift index eafc30dc4..871a5ca36 100644 --- a/Projects/Features/CommonFeature/Sources/ViewControllers/TextPopupViewController.swift +++ b/Projects/Features/CommonFeature/Sources/ViewControllers/TextPopupViewController.swift @@ -76,6 +76,7 @@ extension TextPopupViewController { ) cancelButton.setAttributedTitle(cancelAttributedString, for: .normal) + confirmButton.backgroundColor = DesignSystemAsset.PrimaryColor.point.color confirmButton.layer.cornerRadius = cancelButton.layer.cornerRadius confirmButton.clipsToBounds = true diff --git a/Projects/Features/CommonFeature/Sources/Views/CurrentPlayListTableViewCell.swift b/Projects/Features/CommonFeature/Sources/Views/CurrentPlayListTableViewCell.swift index dc4ebccd3..a8a3df391 100644 --- a/Projects/Features/CommonFeature/Sources/Views/CurrentPlayListTableViewCell.swift +++ b/Projects/Features/CommonFeature/Sources/Views/CurrentPlayListTableViewCell.swift @@ -23,10 +23,10 @@ class CurrentPlayListTableViewCell: UITableViewCell { self.playListImageView.layer.cornerRadius = 4 self.playListNameLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 14) self.playListNameLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - self.playListNameLabel.setLineSpacing(kernValue: -0.5) + self.playListNameLabel.setTextWithAttributes(kernValue: -0.5) self.playListCountLabel.font = DesignSystemFontFamily.Pretendard.light.font(size: 12) self.playListCountLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - self.playListCountLabel.setLineSpacing(kernValue: -0.5) + self.playListCountLabel.setTextWithAttributes(kernValue: -0.5) } } diff --git a/Projects/Features/CommonFeature/Sources/Views/EditSheetView.swift b/Projects/Features/CommonFeature/Sources/Views/EditSheetView.swift index 0fb80dcc5..54f235ed9 100644 --- a/Projects/Features/CommonFeature/Sources/Views/EditSheetView.swift +++ b/Projects/Features/CommonFeature/Sources/Views/EditSheetView.swift @@ -22,7 +22,7 @@ public enum EditSheetSelectType { } public class EditSheetView: UIView { - + @IBOutlet weak var contentView: UIView! @IBOutlet weak var editButton: UIButton! @IBOutlet weak var shareButton: UIButton! @IBOutlet weak var profileButton: UIButton! @@ -99,7 +99,7 @@ public extension EditSheetView { } private func configureUI() { - + contentView.backgroundColor = DesignSystemAsset.PrimaryColor.point.color let titles: [String] = ["편집", "공유하기", "프로필 변경", "닉네임 수정"] let images: [UIImage] = [DesignSystemAsset.PlayListEdit.playlistEdit.image, diff --git a/Projects/Features/CommonFeature/Sources/Views/NewSongsCell.swift b/Projects/Features/CommonFeature/Sources/Views/NewSongsCell.swift index 92d0e55bc..6b9dc3a31 100644 --- a/Projects/Features/CommonFeature/Sources/Views/NewSongsCell.swift +++ b/Projects/Features/CommonFeature/Sources/Views/NewSongsCell.swift @@ -53,13 +53,13 @@ extension NewSongsCell { titleStringLabel.text = model.title titleStringLabel.textColor = DesignSystemAsset.GrayColor.gray900.color titleStringLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 14) - titleStringLabel.setLineSpacing(kernValue: -0.5) + titleStringLabel.setTextWithAttributes(kernValue: -0.5) artistLabel.text = model.artist artistLabel.textColor = DesignSystemAsset.GrayColor.gray900.color artistLabel.font = DesignSystemFontFamily.Pretendard.light.font(size: 12) - artistLabel.setLineSpacing(kernValue: -0.5) - + artistLabel.setTextWithAttributes(kernValue: -0.5) + viewsLabel.text = model.views.addCommaToNumber() + "회" viewsLabel.font = DesignSystemFontFamily.SCoreDream._3Light.font(size: 12) diff --git a/Projects/Features/CommonFeature/Sources/Views/OpenSourceLibraryCell.swift b/Projects/Features/CommonFeature/Sources/Views/OpenSourceLibraryCell.swift index bf84cb84f..7f5d4db5f 100644 --- a/Projects/Features/CommonFeature/Sources/Views/OpenSourceLibraryCell.swift +++ b/Projects/Features/CommonFeature/Sources/Views/OpenSourceLibraryCell.swift @@ -20,11 +20,11 @@ public class OpenSourceLibraryCell: UITableViewCell { self.contentView.backgroundColor = .clear titleStringLabel.font = DesignSystemFontFamily.Pretendard.bold.font(size: 15) titleStringLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - titleStringLabel.setLineSpacing(kernValue: -0.5) + titleStringLabel.setTextWithAttributes(kernValue: -0.5) titleStringLabel.numberOfLines = 0 descriptionLabel.font = DesignSystemFontFamily.Pretendard.light.font(size: 13) descriptionLabel.textColor = DesignSystemAsset.GrayColor.gray500.color - descriptionLabel.setLineSpacing(kernValue: -0.5) + descriptionLabel.setTextWithAttributes(kernValue: -0.5) descriptionLabel.lineBreakMode = .byWordWrapping descriptionLabel.numberOfLines = 0 } diff --git a/Projects/Features/CommonFeature/Sources/Views/OpenSourceLicenseCell.swift b/Projects/Features/CommonFeature/Sources/Views/OpenSourceLicenseCell.swift index 598c1b765..842c9bf57 100644 --- a/Projects/Features/CommonFeature/Sources/Views/OpenSourceLicenseCell.swift +++ b/Projects/Features/CommonFeature/Sources/Views/OpenSourceLicenseCell.swift @@ -20,11 +20,11 @@ class OpenSourceLicenseCell: UITableViewCell { self.contentView.backgroundColor = .clear titleStringLabel.font = DesignSystemFontFamily.Pretendard.bold.font(size: 18) titleStringLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - titleStringLabel.setLineSpacing(kernValue: -0.5) + titleStringLabel.setTextWithAttributes(kernValue: -0.5) titleStringLabel.numberOfLines = 0 descriptionLabel.font = DesignSystemFontFamily.Pretendard.light.font(size: 13) descriptionLabel.textColor = DesignSystemAsset.GrayColor.gray500.color - descriptionLabel.setLineSpacing(kernValue: -0.5) + descriptionLabel.setTextWithAttributes(kernValue: -0.5) descriptionLabel.lineBreakMode = .byWordWrapping descriptionLabel.numberOfLines = 0 } diff --git a/Projects/Features/CommonFeature/Sources/Views/ServiceInfoCell.swift b/Projects/Features/CommonFeature/Sources/Views/ServiceInfoCell.swift index f9cf0390b..7025bc061 100644 --- a/Projects/Features/CommonFeature/Sources/Views/ServiceInfoCell.swift +++ b/Projects/Features/CommonFeature/Sources/Views/ServiceInfoCell.swift @@ -24,10 +24,10 @@ class ServiceInfoCell: UITableViewCell { self.contentView.backgroundColor = .clear titleStringLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) titleStringLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - titleStringLabel.setLineSpacing(kernValue: -0.5) + titleStringLabel.setTextWithAttributes(kernValue: -0.5) subTitleStringLabel.font = DesignSystemFontFamily.Pretendard.light.font(size: 12) subTitleStringLabel.textColor = DesignSystemAsset.GrayColor.gray500.color - subTitleStringLabel.setLineSpacing(kernValue: -0.5) + subTitleStringLabel.setTextWithAttributes(kernValue: -0.5) } } diff --git a/Projects/Features/CommonFeature/Sources/Views/SongCartView.swift b/Projects/Features/CommonFeature/Sources/Views/SongCartView.swift index 6516f6cd0..e7b86e176 100644 --- a/Projects/Features/CommonFeature/Sources/Views/SongCartView.swift +++ b/Projects/Features/CommonFeature/Sources/Views/SongCartView.swift @@ -35,6 +35,7 @@ public class SongCartView: UIView { @IBOutlet weak var selectCountView: UIView! @IBOutlet weak var selectCountViewLeadingConstraint: NSLayoutConstraint! @IBOutlet weak var selectCountLabel: UILabel! + @IBOutlet weak var stackContentView: UIView! @IBOutlet weak var bottomSpaceView: UIView! @IBOutlet weak var bottomSpaceViewHeight: NSLayoutConstraint! @@ -199,6 +200,7 @@ public extension SongCartView { } } + stackContentView.backgroundColor = DesignSystemAsset.PrimaryColor.point.color bottomSpaceView.backgroundColor = DesignSystemAsset.PrimaryColor.point.color bottomSpaceViewHeight.constant = SAFEAREA_BOTTOM_HEIGHT() layoutIfNeeded() diff --git a/Projects/Features/CommonFeature/Sources/Views/WarningView.swift b/Projects/Features/CommonFeature/Sources/Views/WarningView.swift index 3aff8b74f..a99a5d18e 100644 --- a/Projects/Features/CommonFeature/Sources/Views/WarningView.swift +++ b/Projects/Features/CommonFeature/Sources/Views/WarningView.swift @@ -42,7 +42,7 @@ extension WarningView { private func configureUI() { warningImageView.image = DesignSystemAsset.Search.warning.image warningLabelView.textColor = DesignSystemAsset.GrayColor.gray900.color - warningLabelView.setLineSpacing(kernValue: -0.5) + warningLabelView.setTextWithAttributes(kernValue: -0.5) warningLabelView.font = DesignSystemFontFamily.Pretendard.medium.font(size: 14) } } diff --git a/Projects/Features/HomeFeature/Sources/ViewControllers/HomeViewController.swift b/Projects/Features/HomeFeature/Sources/ViewControllers/HomeViewController.swift index 1d7ba3e53..79269a5ca 100644 --- a/Projects/Features/HomeFeature/Sources/ViewControllers/HomeViewController.swift +++ b/Projects/Features/HomeFeature/Sources/ViewControllers/HomeViewController.swift @@ -298,7 +298,7 @@ extension HomeViewController { latestSongEmptyLabel.text = "현재 집계된 음악이 없습니다." latestSongEmptyLabel.textColor = DesignSystemAsset.GrayColor.gray900.color latestSongEmptyLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 14) - latestSongEmptyLabel.setLineSpacing(kernValue: -0.5) + latestSongEmptyLabel.setTextWithAttributes(kernValue: -0.5) latestSongEmptyLabel.textAlignment = .center scrollView.refreshControl = refreshControl scrollView.delegate = self diff --git a/Projects/Features/PlayerFeature/Sources/ViewControllers/PlayerViewController.swift b/Projects/Features/PlayerFeature/Sources/ViewControllers/PlayerViewController.swift index db554fa1b..72951548e 100644 --- a/Projects/Features/PlayerFeature/Sources/ViewControllers/PlayerViewController.swift +++ b/Projects/Features/PlayerFeature/Sources/ViewControllers/PlayerViewController.swift @@ -115,18 +115,25 @@ private extension PlayerViewController { let input = PlayerViewModel.Input( viewWillAppearEvent: self.rx.methodInvoked(#selector(UIViewController.viewWillAppear)).map {_ in }, closeButtonDidTapEvent: self.playerView.closeButton.tapPublisher(), - playButtonDidTapEvent: self.playerView.playButton.tapPublisher(), + playButtonDidTapEvent: Publishers.Merge( + self.playerView.playButton.tapPublisher(), + self.miniPlayerView.playButton.tapPublisher() + ).eraseToAnyPublisher(), prevButtonDidTapEvent: self.playerView.prevButton.rx.tap.asObservable(), - nextButtonDidTapEvent: self.playerView.nextButton.rx.tap.asObservable(), + nextButtonDidTapEvent: Observable.merge( + self.playerView.nextButton.rx.tap.asObservable(), + self.miniPlayerView.nextButton.rx.tap.asObservable() + ), sliderValueChangedEvent: self.playerView.playTimeSlider.rx.value.changed.asObservable(), repeatButtonDidTapEvent: self.playerView.repeatButton.tapPublisher(), shuffleButtonDidTapEvent: self.playerView.shuffleButton.tapPublisher(), likeButtonDidTapEvent: self.playerView.likeButton.tapPublisher(), addPlaylistButtonDidTapEvent: self.playerView.addPlayistButton.tapPublisher(), - playlistButtonDidTapEvent: self.playerView.playistButton.tapPublisher(), - miniExtendButtonDidTapEvent: self.miniPlayerView.extendButton.tapPublisher(), - miniPlayButtonDidTapEvent: self.miniPlayerView.playButton.tapPublisher(), - miniCloseButtonDidTapEvent: self.miniPlayerView.closeButton.tapPublisher() + playlistButtonDidTapEvent: Publishers.Merge( + self.playerView.playistButton.tapPublisher(), + self.miniPlayerView.playlistButton.tapPublisher() + ).eraseToAnyPublisher(), + miniExtendButtonDidTapEvent: self.miniPlayerView.extendButton.tapPublisher() ) let output = self.viewModel.transform(from: input) @@ -214,11 +221,6 @@ private extension PlayerViewController { placeholder: placeholderImage, options: transitionOptions ) - self.miniPlayerView.thumbnailImageView.kf.setImage( - with: sdURL, - placeholder: placeholderImage, - options: transitionOptions - ) }.store(in: &subscription) } diff --git a/Projects/Features/PlayerFeature/Sources/ViewControllers/PlaylistViewController.swift b/Projects/Features/PlayerFeature/Sources/ViewControllers/PlaylistViewController.swift index 5f431d93b..1c080eedb 100644 --- a/Projects/Features/PlayerFeature/Sources/ViewControllers/PlaylistViewController.swift +++ b/Projects/Features/PlayerFeature/Sources/ViewControllers/PlaylistViewController.swift @@ -129,6 +129,7 @@ private extension PlaylistViewController { private func bindViewModel() { let input = PlaylistViewModel.Input( + viewWillAppearEvent: self.rx.methodInvoked(#selector(UIViewController.viewWillAppear)).map { _ in }, closeButtonDidTapEvent: playlistView.closeButton.tapPublisher, editButtonDidTapEvent: playlistView.editButton.tapPublisher, repeatButtonDidTapEvent: playlistView.repeatButton.tapPublisher, @@ -145,6 +146,7 @@ private extension PlaylistViewController { ) let output = self.viewModel.transform(from: input) + bindCountOfSongs(output: output) bindPlaylistTableView(output: output) bindSongCart(output: output) bindCloseButton(output: output) @@ -156,6 +158,13 @@ private extension PlaylistViewController { bindwaveStreamAnimationView(output: output) } + private func bindCountOfSongs(output: PlaylistViewModel.Output) { + output.countOfSongs.sink { [weak self] count in + guard let self else { return } + self.playlistView.countLabel.text = count == 0 ? "" : String(count) + }.store(in: &subscription) + } + private func bindPlaylistTableView(output: PlaylistViewModel.Output) { playlistView.playlistTableView.rx .sentMessage(#selector(playlistView.playlistTableView.reloadData)) diff --git a/Projects/Features/PlayerFeature/Sources/ViewModels/PlayerViewModel.swift b/Projects/Features/PlayerFeature/Sources/ViewModels/PlayerViewModel.swift index ca0d2768d..4a50f87e9 100644 --- a/Projects/Features/PlayerFeature/Sources/ViewModels/PlayerViewModel.swift +++ b/Projects/Features/PlayerFeature/Sources/ViewModels/PlayerViewModel.swift @@ -30,8 +30,6 @@ final class PlayerViewModel: ViewModelType { let addPlaylistButtonDidTapEvent: AnyPublisher let playlistButtonDidTapEvent: AnyPublisher let miniExtendButtonDidTapEvent: AnyPublisher - let miniPlayButtonDidTapEvent: AnyPublisher - let miniCloseButtonDidTapEvent: AnyPublisher } struct Output { var playerState = CurrentValueSubject(.unstarted) @@ -112,7 +110,7 @@ final class PlayerViewModel: ViewModelType { } private func bindInput(input: Input, output: Output) { - input.playButtonDidTapEvent.merge(with: input.miniPlayButtonDidTapEvent).sink { [weak self] _ in + input.playButtonDidTapEvent.sink { [weak self] _ in guard let self else { return } let state = self.playState.state if state == .playing { @@ -130,10 +128,6 @@ final class PlayerViewModel: ViewModelType { self?.playState.switchPlayerMode(to: .full) }.store(in: &subscription) - input.miniCloseButtonDidTapEvent.sink { [weak self] _ in - self?.playState.switchPlayerMode(to: .close) - self?.playState.stop() - }.store(in: &subscription) input.repeatButtonDidTapEvent.sink { [weak self] _ in guard let self else { return } diff --git a/Projects/Features/PlayerFeature/Sources/ViewModels/PlaylistViewModel.swift b/Projects/Features/PlayerFeature/Sources/ViewModels/PlaylistViewModel.swift index 3ab30a477..8caca13d7 100644 --- a/Projects/Features/PlayerFeature/Sources/ViewModels/PlaylistViewModel.swift +++ b/Projects/Features/PlayerFeature/Sources/ViewModels/PlaylistViewModel.swift @@ -21,6 +21,7 @@ internal typealias PlayListSectionModel = SectionModel final class PlaylistViewModel: ViewModelType { struct Input { + let viewWillAppearEvent: Observable let closeButtonDidTapEvent: AnyPublisher let editButtonDidTapEvent: AnyPublisher let repeatButtonDidTapEvent: AnyPublisher @@ -48,6 +49,7 @@ final class PlaylistViewModel: ViewModelType { var shuffleMode = CurrentValueSubject(.off) let dataSource: BehaviorRelay<[PlayListSectionModel]> = BehaviorRelay(value: []) let indexOfSelectedSongs: BehaviorRelay<[Int]> = BehaviorRelay(value: []) + let countOfSongs = CurrentValueSubject(0) } private let playState = PlayState.shared @@ -85,6 +87,12 @@ final class PlaylistViewModel: ViewModelType { } private func bindInput(input: Input, output: Output) { + input.viewWillAppearEvent.subscribe { [weak self] _ in + guard let self else { return } + let count = self.playState.playList.count + output.countOfSongs.send(count) + }.disposed(by: disposeBag) + input.closeButtonDidTapEvent.sink { _ in output.willClosePlaylist.send() }.store(in: &subscription) diff --git a/Projects/Features/PlayerFeature/Sources/Views/LyricsTabelViewCell.swift b/Projects/Features/PlayerFeature/Sources/Views/LyricsTabelViewCell.swift index 33ecdb570..f39d23a7c 100644 --- a/Projects/Features/PlayerFeature/Sources/Views/LyricsTabelViewCell.swift +++ b/Projects/Features/PlayerFeature/Sources/Views/LyricsTabelViewCell.swift @@ -15,15 +15,10 @@ import Utility internal class LyricsTableViewCell: UITableViewCell { static let identifier = "LyricsTableViewCell" static let lyricMaxWidth: CGFloat = (270 * APP_WIDTH())/375.0 - - private lazy var lyricsLabel = UILabel().then { - $0.font = .init(font: DesignSystemFontFamily.Pretendard.medium, size: 14) - $0.textColor = DesignSystemAsset.GrayColor.gray500.color - $0.setLineSpacing(kernValue: -0.5, lineHeightMultiple: 1.44) - $0.text = "" + + private lazy var lyricsLabel = WMLabel(text: "가사", textColor: DesignSystemAsset.GrayColor.gray500.color, font: .t6(weight: .medium), alignment: .center, lineHeight: UIFont.WMFontSystem.t6().lineHeight, kernValue: -0.5).then { $0.numberOfLines = 0 $0.preferredMaxLayoutWidth = LyricsTableViewCell.lyricMaxWidth - $0.textAlignment = .center } override init(style: UITableViewCell.CellStyle, reuseIdentifier: String?) { diff --git a/Projects/Features/PlayerFeature/Sources/Views/MiniPlayerView.swift b/Projects/Features/PlayerFeature/Sources/Views/MiniPlayerView.swift index 18a2b76a0..2e2dfe502 100644 --- a/Projects/Features/PlayerFeature/Sources/Views/MiniPlayerView.swift +++ b/Projects/Features/PlayerFeature/Sources/Views/MiniPlayerView.swift @@ -34,22 +34,16 @@ final class MiniPlayerView: UIView { $0.backgroundColor = DesignSystemAsset.PrimaryColor.point.color } - internal lazy var thumbnailImageView = UIImageView().then { - $0.image = DesignSystemAsset.Player.dummyThumbnailSmall.image - $0.contentMode = .scaleAspectFill - $0.layer.cornerRadius = 4 - $0.clipsToBounds = true + internal lazy var titleArtistStackView: UIStackView = UIStackView(arrangedSubviews: [titleLabel, artistLabel]).then { + $0.axis = .vertical + $0.distribution = .fill } - - internal lazy var titleArtistLabelView: UIView = UIView() - + internal lazy var titleLabel = MarqueeLabel().then { $0.font = .init(font: DesignSystemFontFamily.Pretendard.medium, size: 14) $0.textColor = DesignSystemAsset.GrayColor.gray900.color - $0.setLineSpacing(kernValue: -0.5, lineHeightMultiple: 1.44) - $0.text = "리와인드(RE:WIND)" - $0.setLineHeight(lineHeight: 24) - $0.lineBreakMode = .byTruncatingTail + $0.text = "제목" + $0.setTextWithAttributes(lineHeight: 24, kernValue: -0.5) $0.leadingBuffer = 0 $0.trailingBuffer = 35 $0.fadeLength = 3 @@ -60,10 +54,8 @@ final class MiniPlayerView: UIView { internal lazy var artistLabel = MarqueeLabel().then { $0.font = .init(font: DesignSystemFontFamily.Pretendard.light, size: 12) $0.textColor = DesignSystemAsset.GrayColor.gray900.color - $0.setLineSpacing(kernValue: -0.5, lineHeightMultiple: 1.26) - $0.text = "이세계아이돌" - $0.setLineHeight(lineHeight: 18) - $0.lineBreakMode = .byTruncatingTail + $0.text = "아티스트" + $0.setTextWithAttributes(lineHeight: 18, kernValue: -0.5) $0.leadingBuffer = 0 $0.trailingBuffer = 20 $0.fadeLength = 3 @@ -76,11 +68,20 @@ final class MiniPlayerView: UIView { $0.tintColor = .systemGray } + internal lazy var nextButton = UIButton().then { + $0.setImage(DesignSystemAsset.Player.nextOn.image, for: .normal) + $0.tintColor = .systemGray + } + internal lazy var closeButton = UIButton().then { $0.setImage(DesignSystemAsset.Player.miniClose.image, for: .normal) $0.tintColor = .systemGray } + internal lazy var playlistButton = UIButton().then { + $0.setImage(DesignSystemAsset.Player.playList.image, for: .normal) + } + override init(frame: CGRect) { super.init(frame: frame) configureUI() @@ -99,12 +100,10 @@ private extension MiniPlayerView { self.configureBlur() self.configureContent() self.configurePlayTime() - self.configureThumbnail() self.configureTitleArtist() - self.configureTitleLabel() - self.configureArtistLabel() self.configurePlayButton() - self.configureCloseButton() + self.configureNextButton() + self.configurePlaylistButton() } private func configureSubViews() { @@ -112,13 +111,11 @@ private extension MiniPlayerView { self.addSubview(contentView) self.contentView.addSubview(totalPlayTimeView) self.totalPlayTimeView.addSubview(currentPlayTimeView) - self.contentView.addSubview(thumbnailImageView) - self.contentView.addSubview(titleArtistLabelView) - self.titleArtistLabelView.addSubview(titleLabel) - self.titleArtistLabelView.addSubview(artistLabel) + self.contentView.addSubview(titleArtistStackView) self.contentView.addSubview(extendButton) self.contentView.addSubview(playButton) - self.contentView.addSubview(closeButton) + self.contentView.addSubview(nextButton) + self.contentView.addSubview(playlistButton) } private func configureBlur() { @@ -149,47 +146,33 @@ private extension MiniPlayerView { } } - private func configureThumbnail() { - let height = 40 - let width = height * 16 / 9 - thumbnailImageView.snp.makeConstraints { - $0.centerY.equalToSuperview() - $0.left.equalToSuperview().offset(20) - $0.width.equalTo(width) - $0.height.equalTo(height) - } - } - private func configureTitleArtist() { - titleArtistLabelView.snp.makeConstraints { + titleArtistStackView.snp.makeConstraints { $0.top.equalToSuperview().offset(7) $0.bottom.equalToSuperview().offset(-7) - $0.left.equalTo(thumbnailImageView.snp.right).offset(8) + $0.left.equalToSuperview().offset(20) $0.right.equalTo(playButton.snp.left).offset(-12) } } - private func configureTitleLabel() { - titleLabel.snp.makeConstraints { - $0.top.left.right.equalToSuperview() - } - } - private func configureArtistLabel() { - artistLabel.snp.makeConstraints { - $0.bottom.left.right.equalToSuperview() + private func configurePlayButton() { + playButton.snp.makeConstraints { + $0.centerY.equalToSuperview() + $0.right.equalTo(nextButton.snp.left).offset(-20) + $0.width.height.equalTo(32) } } - private func configurePlayButton() { - playButton.snp.makeConstraints { + private func configureNextButton() { + nextButton.snp.makeConstraints { $0.centerY.equalToSuperview() - $0.right.equalTo(closeButton.snp.left).offset(-20) + $0.right.equalTo(playlistButton.snp.left).offset(-20) $0.width.height.equalTo(32) } } - private func configureCloseButton() { - closeButton.snp.makeConstraints { + private func configurePlaylistButton() { + playlistButton.snp.makeConstraints { $0.centerY.equalToSuperview() $0.right.equalToSuperview().offset(-16) $0.width.height.equalTo(32) diff --git a/Projects/Features/PlayerFeature/Sources/Views/PlayerView.swift b/Projects/Features/PlayerFeature/Sources/Views/PlayerView.swift index 71c7a93aa..395047b43 100644 --- a/Projects/Features/PlayerFeature/Sources/Views/PlayerView.swift +++ b/Projects/Features/PlayerFeature/Sources/Views/PlayerView.swift @@ -39,27 +39,19 @@ public final class PlayerView: UIView { $0.tintColor = .systemGray } - internal lazy var titleLabel = MarqueeLabel().then { - $0.font = .init(font: DesignSystemFontFamily.Pretendard.medium, size: 16) - $0.textColor = DesignSystemAsset.GrayColor.gray900.color - $0.setLineSpacing(kernValue: -0.5, lineHeightMultiple: 1.26) - $0.setLineHeight(lineHeight: 24) - $0.lineBreakMode = .byTruncatingTail - $0.textAlignment = .center - $0.leadingBuffer = 0 - $0.trailingBuffer = 35 - $0.fadeLength = 3 - $0.animationDelay = 1 - $0.speed = .rate(30) + internal lazy var titleArtistStackView: UIStackView = UIStackView(arrangedSubviews: [titleLabel, artistLabel]).then { + $0.axis = .vertical + $0.distribution = .fill } + internal lazy var titleLabel = WMFlowLabel(text: "제목", textColor: DesignSystemAsset.GrayColor.gray900.color, font: .t5(weight: .medium), alignment: .center, lineHeight: UIFont.WMFontSystem.t5().lineHeight, kernValue: -0.5, leadingBuffer: 0, trailingBuffer: 35) + internal lazy var artistLabel = MarqueeLabel().then { $0.font = .init(font: DesignSystemFontFamily.Pretendard.medium, size: 14) $0.textColor = DesignSystemAsset.GrayColor.gray900.color $0.alpha = 0.6 - $0.setLineSpacing(kernValue: -0.5, lineHeightMultiple: 1.2) - $0.setLineHeight(lineHeight: 20) - $0.lineBreakMode = .byTruncatingTail + $0.text = "아티스트" + $0.setTextWithAttributes(lineHeight: 20, kernValue: -0.5) $0.textAlignment = .center $0.leadingBuffer = 0 $0.trailingBuffer = 20 @@ -88,7 +80,7 @@ public final class PlayerView: UIView { let circleSize: CGFloat = 8.0 let circleImage: UIImage? = makeCircleWith(size: CGSize(width: circleSize, height: circleSize), - color: colorFromRGB(0x08DEF7), + color: DesignSystemAsset.PrimaryColor.point.color, padding: 20) $0.layer.cornerRadius = 1 $0.setThumbImage(circleImage, for: .normal) @@ -102,15 +94,15 @@ public final class PlayerView: UIView { internal lazy var currentPlayTimeLabel = UILabel().then { $0.font = .init(font: DesignSystemFontFamily.Pretendard.medium, size: 12) $0.textColor = DesignSystemAsset.PrimaryColor.point.color - $0.setLineSpacing(kernValue: -0.5, lineHeightMultiple: 1.26) $0.text = "-:--" + $0.setTextWithAttributes(lineHeight: 18, kernValue: -0.5, lineHeightMultiple: 1.26) } internal lazy var totalPlayTimeLabel = UILabel().then { $0.font = .init(font: DesignSystemFontFamily.Pretendard.medium, size: 12) $0.textColor = DesignSystemAsset.GrayColor.gray400.color - $0.setLineSpacing(kernValue: -0.5, lineHeightMultiple: 1.26) $0.text = "-:--" + $0.setTextWithAttributes(lineHeight: 18, kernValue: -0.5, lineHeightMultiple: 1.26) } private lazy var buttonBarView: UIView = UIView() @@ -156,14 +148,16 @@ public final class PlayerView: UIView { internal lazy var likeButton = LikeButton().then { $0.titleLabel.font = UIFont(font: DesignSystemFontFamily.Pretendard.medium, size: 12) - $0.titleLabel.setLineSpacing(kernValue: -0.5, lineHeightMultiple: 0.98) + $0.title = "좋아요" + $0.titleLabel.setTextWithAttributes(lineHeight: 14, kernValue: -0.5, lineHeightMultiple: 0.98) $0.isLiked = false } internal lazy var viewsView = VerticalImageButton().then { $0.image = DesignSystemAsset.Player.views.image $0.titleLabel.font = UIFont(font: DesignSystemFontFamily.Pretendard.medium, size: 12) - $0.titleLabel.setLineSpacing(kernValue: -0.5, lineHeightMultiple: 0.98) + $0.title = "조회수" + $0.titleLabel.setTextWithAttributes(lineHeight: 14, kernValue: -0.5, lineHeightMultiple: 0.98) $0.titleLabel.textColor = DesignSystemAsset.GrayColor.gray400.color } @@ -171,7 +165,7 @@ public final class PlayerView: UIView { $0.image = DesignSystemAsset.Player.playerMusicAdd.image $0.title = "노래담기" $0.titleLabel.font = UIFont(font: DesignSystemFontFamily.Pretendard.medium, size: 12) - $0.titleLabel.setLineSpacing(kernValue: -0.5, lineHeightMultiple: 0.98) + $0.titleLabel.setTextWithAttributes(lineHeight: 14, kernValue: -0.5, lineHeightMultiple: 0.98) $0.titleLabel.textColor = DesignSystemAsset.GrayColor.gray400.color } @@ -179,7 +173,7 @@ public final class PlayerView: UIView { $0.image = DesignSystemAsset.Player.playList.image $0.title = "재생목록" $0.titleLabel.font = UIFont(font: DesignSystemFontFamily.Pretendard.medium, size: 12) - $0.titleLabel.setLineSpacing(kernValue: -0.5, lineHeightMultiple: 0.98) + $0.titleLabel.setTextWithAttributes(lineHeight: 14, kernValue: -0.5, lineHeightMultiple: 0.98) $0.titleLabel.textColor = DesignSystemAsset.GrayColor.gray400.color } @@ -231,8 +225,7 @@ private extension PlayerView { self.contentView.addSubview(bottomBarView) self.titleBarView.addSubview(closeButton) - self.titleBarView.addSubview(titleLabel) - self.titleBarView.addSubview(artistLabel) + self.titleBarView.addSubview(titleArtistStackView) self.playTimeView.addSubview(currentPlayTimeLabel) self.playTimeView.addSubview(totalPlayTimeLabel) @@ -284,13 +277,10 @@ private extension PlayerView { $0.left.equalToSuperview().offset(20) $0.width.height.equalTo(32) } - titleLabel.snp.makeConstraints { + titleArtistStackView.snp.makeConstraints { + $0.centerX.centerY.equalToSuperview() $0.top.equalToSuperview().offset(2) - $0.left.equalTo(closeButton.snp.right).offset(10) - $0.right.equalToSuperview().offset(-62) - } - artistLabel.snp.makeConstraints { - $0.top.equalTo(titleLabel.snp.bottom) + $0.bottom.equalToSuperview().offset(-2) $0.left.equalTo(closeButton.snp.right).offset(10) $0.right.equalToSuperview().offset(-62) } diff --git a/Projects/Features/PlayerFeature/Sources/Views/PlaylistTableViewCell.swift b/Projects/Features/PlayerFeature/Sources/Views/PlaylistTableViewCell.swift index e8f3350e7..bf2ca22f1 100644 --- a/Projects/Features/PlayerFeature/Sources/Views/PlaylistTableViewCell.swift +++ b/Projects/Features/PlayerFeature/Sources/Views/PlaylistTableViewCell.swift @@ -29,12 +29,17 @@ internal class PlaylistTableViewCell: UITableViewCell { $0.clipsToBounds = true } + internal lazy var titleArtistStackView = UIStackView(arrangedSubviews: [titleLabel, artistLabel]).then { + $0.axis = .vertical + $0.distribution = .fill + } + internal lazy var titleLabel = UILabel().then { $0.font = .init(font: DesignSystemFontFamily.Pretendard.medium, size: 14) $0.textColor = DesignSystemAsset.GrayColor.gray900.color - $0.setLineSpacing(kernValue: -0.5, lineHeightMultiple: 1.44) $0.text = "곡 제목" - $0.setLineHeight(lineHeight: 24) + $0.setTextWithAttributes(lineHeight: 24, kernValue: -0.5) + $0.textAlignment = .left $0.lineBreakMode = .byTruncatingTail } @@ -42,9 +47,8 @@ internal class PlaylistTableViewCell: UITableViewCell { internal lazy var artistLabel = UILabel().then { $0.font = .init(font: DesignSystemFontFamily.Pretendard.light, size: 12) $0.textColor = DesignSystemAsset.GrayColor.gray900.color - $0.setLineSpacing(kernValue: -0.5, lineHeightMultiple: 1.26) $0.text = "아티스트명" - $0.setLineHeight(lineHeight: 18) + $0.setTextWithAttributes(lineHeight: 18, kernValue: -0.5) $0.textAlignment = .left $0.lineBreakMode = .byTruncatingTail } @@ -93,8 +97,7 @@ internal class PlaylistTableViewCell: UITableViewCell { private func configureContents() { self.backgroundColor = .clear self.contentView.addSubview(self.thumbnailImageView) - self.contentView.addSubview(self.titleLabel) - self.contentView.addSubview(self.artistLabel) + self.contentView.addSubview(self.titleArtistStackView) self.contentView.addSubview(self.playImageView) self.contentView.addSubview(self.waveStreamAnimationView) self.contentView.addSubview(self.superButton) @@ -108,16 +111,11 @@ internal class PlaylistTableViewCell: UITableViewCell { $0.height.equalTo(height) } - titleLabel.snp.makeConstraints { - $0.left.equalTo(thumbnailImageView.snp.right).offset(8) - $0.right.equalTo(playImageView.snp.left).offset(-16) - $0.bottom.equalTo(contentView.snp.centerY) - } - - artistLabel.snp.makeConstraints { + titleArtistStackView.snp.makeConstraints { + $0.top.equalTo(thumbnailImageView.snp.top) $0.left.equalTo(thumbnailImageView.snp.right).offset(8) $0.right.equalTo(playImageView.snp.left).offset(-16) - $0.top.equalTo(contentView.snp.centerY) + $0.bottom.equalTo(thumbnailImageView.snp.bottom) } playImageView.snp.makeConstraints { diff --git a/Projects/Features/PlayerFeature/Sources/Views/PlaylistView.swift b/Projects/Features/PlayerFeature/Sources/Views/PlaylistView.swift index 7ae085fc7..6290c53c9 100644 --- a/Projects/Features/PlayerFeature/Sources/Views/PlaylistView.swift +++ b/Projects/Features/PlayerFeature/Sources/Views/PlaylistView.swift @@ -20,19 +20,34 @@ public final class PlaylistView: UIView { private lazy var contentView = UIView() - internal lazy var titleBarView: UIView = UIView() + internal lazy var titleBarView = UIView() internal lazy var closeButton = UIButton().then { $0.setImage(DesignSystemAsset.Navigation.close.image, for: .normal) $0.tintColor = .systemGray } - internal lazy var titleLabel = UILabel().then { - $0.font = .init(font: DesignSystemFontFamily.Pretendard.medium, size: 16) - $0.textColor = DesignSystemAsset.GrayColor.gray900.color - $0.setLineSpacing(kernValue: -0.5, lineHeightMultiple: 1.26) - $0.text = "재생목록" - $0.setLineHeight(lineHeight: 24) + internal lazy var titleCountStackView = UIStackView(arrangedSubviews: [titleLabel, countLabel]).then { + $0.axis = .horizontal + $0.distribution = .fill + $0.spacing = 4 + } + +// internal lazy var titleLabel = UILabel().then { +// $0.font = .init(font: DesignSystemFontFamily.Pretendard.medium, size: 16) +// $0.textColor = DesignSystemAsset.GrayColor.gray900.color +// $0.text = "재생목록" +// $0.setTextWithAttributes(lineHeight: 24, kernValue: -0.5) +// $0.textAlignment = .center +// } + + lazy var titleLabel = WMLabel(text: "재생목록", textColor: DesignSystemAsset.GrayColor.gray900.color, font: .t5(weight: .medium), alignment: .center, lineHeight: 24, kernValue: -0.5) + + internal lazy var countLabel = UILabel().then { + $0.font = .init(font: DesignSystemFontFamily.Pretendard.bold, size: 18) + $0.textColor = DesignSystemAsset.PrimaryColor.point.color + $0.text = "0" + $0.setTextWithAttributes(lineHeight: 28, kernValue: -0.5) $0.textAlignment = .center } @@ -141,7 +156,7 @@ private extension PlaylistView { self.addSubview(contentView) contentView.addSubview(titleBarView) titleBarView.addSubview(closeButton) - titleBarView.addSubview(titleLabel) + titleBarView.addSubview(titleCountStackView) titleBarView.addSubview(editButton) contentView.addSubview(playlistTableView) contentView.addSubview(blurEffectView) @@ -186,7 +201,7 @@ private extension PlaylistView { $0.centerY.equalToSuperview() } - titleLabel.snp.makeConstraints { + titleCountStackView.snp.makeConstraints { $0.centerX.centerY.equalToSuperview() } diff --git a/Projects/Features/RootFeature/Sources/ViewControllers/IntroViewController.swift b/Projects/Features/RootFeature/Sources/ViewControllers/IntroViewController.swift index 1a173b57f..169137d00 100644 --- a/Projects/Features/RootFeature/Sources/ViewControllers/IntroViewController.swift +++ b/Projects/Features/RootFeature/Sources/ViewControllers/IntroViewController.swift @@ -42,8 +42,16 @@ extension IntroViewController { private func inputBind() { input.fetchPermissionCheck.onNext(()) } +} +extension IntroViewController { private func outputBind() { + permissionResult() + appInfoResult() + userInfoAndLottieEnded() + } + + private func permissionResult() { output.permissionResult .do(onNext: { [weak self] (permission) in guard let self = self else { return } @@ -55,24 +63,23 @@ extension IntroViewController { self.present(permission, animated: true) }) .filter { return ($0 ?? false) == true } - .do(onNext: { [weak self] (_) in - guard let self = self else { return } - self.lottiePlay() - self.input.startLottieAnimation.onNext(()) - }) .map{ _ in () } .bind(to: input.fetchAppCheck) .disposed(by: disposeBag) - + } + + private func appInfoResult(){ output.appInfoResult .withUnretained(self) .subscribe(onNext: { owner, result in switch result { case let .success(entity): + owner.lottiePlay(specialLogo: entity.specialLogo) + var textPopupVc: TextPopupViewController let updateTitle: String = "왁타버스 뮤직이 업데이트 되었습니다." let updateMessage: String = "최신 버전으로 업데이트 후 이용하시기 바랍니다.\n감사합니다." - + switch entity.flag { case .normal: owner.input.fetchUserInfoCheck.onNext(()) @@ -131,6 +138,7 @@ extension IntroViewController { owner.showPanModal(content: textPopupVc) case let .failure(error): + owner.lottiePlay(specialLogo: false) owner.showPanModal( content: TextPopupViewController.viewController( text: error.asWMError.errorDescription ?? "", @@ -141,17 +149,20 @@ extension IntroViewController { } }) .disposed(by: disposeBag) - + } + + private func userInfoAndLottieEnded() { Observable.zip( output.userInfoResult, - output.endLottieAnimation + output.endedLottieAnimation ) { (result, _) -> Result in return result } .withUnretained(self) .subscribe(onNext: { (owner, result) in switch result{ - case .success(_): + case let .success(suc): + DEBUG_LOG("success: \(suc)✅✅") owner.showTabBar() case .failure(let error): @@ -177,13 +188,17 @@ extension IntroViewController { self.navigationController?.pushViewController(viewController, animated: false) } - private func lottiePlay() { - let animationView = LottieAnimationView(name: "Splash_Logo_Main", bundle: DesignSystemResources.bundle) + private func lottiePlay(specialLogo: Bool) { + let animationView = LottieAnimationView( + name: specialLogo ? "Splash_Logo_Special" : "Splash_Logo_Main", + bundle: DesignSystemResources.bundle + ) animationView.frame = self.logoContentView.bounds animationView.backgroundColor = .clear animationView.contentMode = .scaleAspectFill animationView.loopMode = .playOnce - + animationView.clipsToBounds = false + self.logoContentView.addSubview(animationView) let originWidth: CGFloat = 156.0 @@ -199,6 +214,9 @@ extension IntroViewController { $0.centerX.equalTo(self.logoContentView.snp.centerX) $0.centerY.equalTo(self.logoContentView.snp.centerY) } - animationView.play() + + animationView.play { _ in + self.input.endedLottieAnimation.onNext(()) + } } } diff --git a/Projects/Features/RootFeature/Sources/ViewControllers/PermissionViewController.swift b/Projects/Features/RootFeature/Sources/ViewControllers/PermissionViewController.swift index 986f9294b..4a8713c76 100644 --- a/Projects/Features/RootFeature/Sources/ViewControllers/PermissionViewController.swift +++ b/Projects/Features/RootFeature/Sources/ViewControllers/PermissionViewController.swift @@ -136,6 +136,7 @@ extension PermissionViewController { .kern: -0.5] ) self.confirmButton.setAttributedTitle(confirmAttributedString, for: .normal) + self.confirmButton.backgroundColor = DesignSystemAsset.PrimaryColor.point.color self.borderViewWidthConstraint.constant = APP_WIDTH() < 375 ? (APP_WIDTH()-40.0) : 335.0 self.view.layoutIfNeeded() diff --git a/Projects/Features/RootFeature/Sources/ViewModels/IntroViewModel.swift b/Projects/Features/RootFeature/Sources/ViewModels/IntroViewModel.swift index 09db1aa65..1792270dd 100644 --- a/Projects/Features/RootFeature/Sources/ViewModels/IntroViewModel.swift +++ b/Projects/Features/RootFeature/Sources/ViewModels/IntroViewModel.swift @@ -26,14 +26,14 @@ final public class IntroViewModel: ViewModelType { var fetchPermissionCheck: PublishSubject = PublishSubject() var fetchAppCheck: PublishSubject = PublishSubject() var fetchUserInfoCheck: PublishSubject = PublishSubject() - var startLottieAnimation: PublishSubject = PublishSubject() + var endedLottieAnimation: PublishSubject = PublishSubject() } public struct Output { var permissionResult: PublishSubject = PublishSubject() var appInfoResult: PublishSubject> = PublishSubject() var userInfoResult: PublishSubject> = PublishSubject() - var endLottieAnimation: PublishSubject = PublishSubject() + var endedLottieAnimation: PublishSubject = PublishSubject() } public init( @@ -57,9 +57,8 @@ final public class IntroViewModel: ViewModelType { .bind(to: output.permissionResult) .disposed(by: disposeBag) - input.startLottieAnimation - .delay(RxTimeInterval.milliseconds(1200), scheduler: MainScheduler.instance) - .bind(to: output.endLottieAnimation) + input.endedLottieAnimation + .bind(to: output.endedLottieAnimation) .disposed(by: disposeBag) input.fetchAppCheck @@ -71,10 +70,12 @@ final public class IntroViewModel: ViewModelType { if wmError == .offline { return Single.create { single in single(.success(AppInfoEntity( - flag: .offline, - title: "", - description: wmError.errorDescription ?? "", - version: "")) + flag: .offline, + title: "", + description: wmError.errorDescription ?? "", + version: "", + specialLogo: false) + ) ) return Disposables.create() } diff --git a/Projects/Features/SearchFeature/Sources/View/EntireSectionHeader.swift b/Projects/Features/SearchFeature/Sources/View/EntireSectionHeader.swift index 084838fe1..886b46b25 100644 --- a/Projects/Features/SearchFeature/Sources/View/EntireSectionHeader.swift +++ b/Projects/Features/SearchFeature/Sources/View/EntireSectionHeader.swift @@ -62,11 +62,11 @@ extension EntireSectionHeader { private func configureUI() { self.categoryLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) self.categoryLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - self.categoryLabel.setLineSpacing(kernValue: -0.5) + self.categoryLabel.setTextWithAttributes(kernValue: -0.5) self.numberOfSongLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) self.numberOfSongLabel.textColor = DesignSystemAsset.PrimaryColor.point.color - self.numberOfSongLabel.setLineSpacing(kernValue: -0.5) + self.numberOfSongLabel.setTextWithAttributes(kernValue: -0.5) let attrTitle = NSAttributedString( string: "전체보기", diff --git a/Projects/Features/SearchFeature/Sources/View/RecentRecordHeaderView.swift b/Projects/Features/SearchFeature/Sources/View/RecentRecordHeaderView.swift index f69b58c5b..8cbb36111 100644 --- a/Projects/Features/SearchFeature/Sources/View/RecentRecordHeaderView.swift +++ b/Projects/Features/SearchFeature/Sources/View/RecentRecordHeaderView.swift @@ -44,11 +44,11 @@ class RecentRecordHeaderView: UIView { self.recentLabel.text = "최근 검색어" self.recentLabel.font = DesignSystemFontFamily.Pretendard.bold.font(size: 16) self.recentLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - self.recentLabel.setLineSpacing(kernValue: -0.5) + self.recentLabel.setTextWithAttributes(kernValue: -0.5) self.removeAllLabel.text = "전체삭제" self.removeAllLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 14) self.removeAllLabel.textColor = DesignSystemAsset.GrayColor.gray400.color - self.removeAllLabel.setLineSpacing(kernValue: -0.5) + self.removeAllLabel.setTextWithAttributes(kernValue: -0.5) } } diff --git a/Projects/Features/SearchFeature/Sources/View/RecentRecordTableViewCell.swift b/Projects/Features/SearchFeature/Sources/View/RecentRecordTableViewCell.swift index f9a4dec5d..afc40c563 100644 --- a/Projects/Features/SearchFeature/Sources/View/RecentRecordTableViewCell.swift +++ b/Projects/Features/SearchFeature/Sources/View/RecentRecordTableViewCell.swift @@ -32,7 +32,7 @@ class RecentRecordTableViewCell: UITableViewCell { recentRemoveButton.setImage(DesignSystemAsset.Search.keywordRemove.image, for: .normal) recentLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 14) recentLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - recentLabel.setLineSpacing(kernValue: -0.5) + recentLabel.setTextWithAttributes(kernValue: -0.5) } @IBAction func pressRemoveAction(_ sender: Any) { diff --git a/Projects/Features/SignInFeature/Sources/Views/LoginUIExtension.swift b/Projects/Features/SignInFeature/Sources/Views/LoginUIExtension.swift index 67a741929..07ebb7130 100644 --- a/Projects/Features/SignInFeature/Sources/Views/LoginUIExtension.swift +++ b/Projects/Features/SignInFeature/Sources/Views/LoginUIExtension.swift @@ -99,7 +99,7 @@ extension LoginViewController { versionLabel.text = "버전 정보 " + APP_VERSION() versionLabel.textColor = DesignSystemAsset.GrayColor.gray400.color versionLabel.font = DesignSystemFontFamily.Pretendard.light.font(size: 12) - versionLabel.setLineSpacing(kernValue: -0.5) + versionLabel.setTextWithAttributes(kernValue: -0.5) versionLabel.textAlignment = .center } } diff --git a/Projects/Features/StorageFeature/Sources/ViewControllers/AfterLoginViewController.swift b/Projects/Features/StorageFeature/Sources/ViewControllers/AfterLoginViewController.swift index 202012a3c..86062869d 100644 --- a/Projects/Features/StorageFeature/Sources/ViewControllers/AfterLoginViewController.swift +++ b/Projects/Features/StorageFeature/Sources/ViewControllers/AfterLoginViewController.swift @@ -16,6 +16,7 @@ import PanModal import CommonFeature import KeychainModule import DataMappingModule +import BaseFeature public final class AfterLoginViewController: TabmanViewController, ViewControllerFromStoryBoard, EditSheetViewType { diff --git a/Projects/Features/StorageFeature/Sources/ViewControllers/AskSongViewController.swift b/Projects/Features/StorageFeature/Sources/ViewControllers/AskSongViewController.swift index 5d322ac43..d5bb0d088 100644 --- a/Projects/Features/StorageFeature/Sources/ViewControllers/AskSongViewController.swift +++ b/Projects/Features/StorageFeature/Sources/ViewControllers/AskSongViewController.swift @@ -112,7 +112,7 @@ extension AskSongViewController { titleLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) titleLabel.textColor = DesignSystemAsset.GrayColor.gray900.color titleLabel.text = viewModel.type == .add ? "노래 추가" : "노래 수정" - titleLabel.setLineSpacing(kernValue: -0.5) + titleLabel.setTextWithAttributes(kernValue: -0.5) let style = NSMutableParagraphStyle() style.lineHeightMultiple = 1.35 @@ -161,7 +161,7 @@ extension AskSongViewController { descriptionLabels[i].text = title descriptionLabels[i].font = DesignSystemFontFamily.Pretendard.medium.font(size: 18) descriptionLabels[i].textColor = DesignSystemAsset.GrayColor.gray900.color - descriptionLabels[i].setLineSpacing(kernValue: -0.5) + descriptionLabels[i].setTextWithAttributes(kernValue: -0.5) if i < 3 { textFields[i].attributedPlaceholder = NSAttributedString(string: placeHolder,attributes:placeHolderAttributes) //플레이스 홀더 설정 diff --git a/Projects/Features/StorageFeature/Sources/ViewControllers/BugReportViewController.swift b/Projects/Features/StorageFeature/Sources/ViewControllers/BugReportViewController.swift index a891c0ae8..a656b5802 100644 --- a/Projects/Features/StorageFeature/Sources/ViewControllers/BugReportViewController.swift +++ b/Projects/Features/StorageFeature/Sources/ViewControllers/BugReportViewController.swift @@ -127,12 +127,12 @@ extension BugReportViewController { titleLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) titleLabel.textColor = DesignSystemAsset.GrayColor.gray900.color titleLabel.text = "버그제보" - titleLabel.setLineSpacing(kernValue: -0.5) + titleLabel.setTextWithAttributes(kernValue: -0.5) descriptionLabel1.text = "겪으신 버그에 대해 설명해 주세요." descriptionLabel1.font = DesignSystemFontFamily.Pretendard.medium.font(size: 18) descriptionLabel1.textColor = DesignSystemAsset.GrayColor.gray900.color - descriptionLabel1.setLineSpacing(kernValue: -0.5) + descriptionLabel1.setTextWithAttributes(kernValue: -0.5) baseLine1.backgroundColor = unPointColor baseLine2.backgroundColor = unPointColor @@ -140,12 +140,12 @@ extension BugReportViewController { descriptionLabel2.text = "버그와 관련된 사진이나 영상을 첨부 해주세요." descriptionLabel2.font = DesignSystemFontFamily.Pretendard.medium.font(size: 18) descriptionLabel2.textColor = DesignSystemAsset.GrayColor.gray900.color - descriptionLabel2.setLineSpacing(kernValue: -0.5) + descriptionLabel2.setTextWithAttributes(kernValue: -0.5) descriptionLabel3.text = "왁물원 닉네임을 알려주세요." descriptionLabel3.font = DesignSystemFontFamily.Pretendard.medium.font(size: 18) descriptionLabel3.textColor = DesignSystemAsset.GrayColor.gray900.color - descriptionLabel3.setLineSpacing(kernValue: -0.5) + descriptionLabel3.setTextWithAttributes(kernValue: -0.5) scrollView.delegate = self textView.delegate = self @@ -166,7 +166,7 @@ extension BugReportViewController { noticeLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) noticeLabel.textColor = DesignSystemAsset.GrayColor.gray400.color noticeImageView.image = DesignSystemAsset.Navigation.close.image - noticeLabel.setLineSpacing(kernValue: -0.5) + noticeLabel.setTextWithAttributes(kernValue: -0.5) textField.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) textField.attributedPlaceholder = NSAttributedString(string: placeHolder,attributes:placeHolderAttributes) @@ -176,7 +176,7 @@ extension BugReportViewController { infoLabel.text = "닉네임을 알려주시면 피드백을 받으시는 데 도움이 됩니다." infoLabel.font = DesignSystemFontFamily.Pretendard.light.font(size: 12) infoLabel.textColor = DesignSystemAsset.GrayColor.gray500.color - infoLabel.setLineSpacing(kernValue: -0.5) + infoLabel.setTextWithAttributes(kernValue: -0.5) self.completionButton.layer.cornerRadius = 12 self.completionButton.clipsToBounds = true diff --git a/Projects/Features/StorageFeature/Sources/ViewControllers/QuestionViewController.swift b/Projects/Features/StorageFeature/Sources/ViewControllers/QuestionViewController.swift index 2c937b10d..f569eb083 100644 --- a/Projects/Features/StorageFeature/Sources/ViewControllers/QuestionViewController.swift +++ b/Projects/Features/StorageFeature/Sources/ViewControllers/QuestionViewController.swift @@ -87,14 +87,14 @@ extension QuestionViewController { self.titleLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) self.titleLabel.textColor = DesignSystemAsset.GrayColor.gray900.color self.titleLabel.text = "문의하기" - self.titleLabel.setLineSpacing(kernValue: -0.5) + self.titleLabel.setTextWithAttributes(kernValue: -0.5) self.closeButton.setImage(DesignSystemAsset.Navigation.crossClose.image, for: .normal) self.descriptionLabel.text = "어떤 것 관련해서 문의주셨나요?" self.descriptionLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 20) self.descriptionLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - self.descriptionLabel.setLineSpacing(kernValue: -0.5) + self.descriptionLabel.setTextWithAttributes(kernValue: -0.5) self.nextButton.layer.cornerRadius = 12 self.nextButton.clipsToBounds = true diff --git a/Projects/Features/StorageFeature/Sources/ViewControllers/RequestViewController.swift b/Projects/Features/StorageFeature/Sources/ViewControllers/RequestViewController.swift index 9f6fbb38e..4bbd919f9 100644 --- a/Projects/Features/StorageFeature/Sources/ViewControllers/RequestViewController.swift +++ b/Projects/Features/StorageFeature/Sources/ViewControllers/RequestViewController.swift @@ -124,7 +124,7 @@ extension RequestViewController{ self.backButton.setImage(DesignSystemAsset.Navigation.back.image, for: .normal) self.titleLabel.text = "건의사항" self.titleLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) - self.titleLabel.setLineSpacing(kernValue: -0.5) + self.titleLabel.setTextWithAttributes(kernValue: -0.5) let buttons: [UIButton] = [self.questionButton, self.qnaButton, self.noticeButton, self.serviceButton, self.bombButton] let superViews: [UIView] = [self.questionSuperView, self.qnaSuperView, self.noticeSuperView, self.serviceSuperView, self.bombSuperView] @@ -170,7 +170,7 @@ extension RequestViewController{ descriptionLabel.text = "왁타버스 뮤직 팀에 속한 모든 팀원들은 부아내비 (부려먹는 게 아니라 내가 비빈거다)라는 모토를 가슴에 새기고 일하고 있습니다." descriptionLabel.font = DesignSystemFontFamily.Pretendard.light.font(size: 12) - descriptionLabel.setLineSpacing(kernValue: -0.5, lineHeightMultiple: 1.26) + descriptionLabel.setTextWithAttributes(kernValue: -0.5, lineHeightMultiple: 1.26) let withDrawAttributedString = NSMutableAttributedString.init(string: "회원탈퇴") withDrawAttributedString.addAttributes( diff --git a/Projects/Features/StorageFeature/Sources/ViewControllers/SuggestFunctionViewController.swift b/Projects/Features/StorageFeature/Sources/ViewControllers/SuggestFunctionViewController.swift index 0bd591c50..b086f050b 100644 --- a/Projects/Features/StorageFeature/Sources/ViewControllers/SuggestFunctionViewController.swift +++ b/Projects/Features/StorageFeature/Sources/ViewControllers/SuggestFunctionViewController.swift @@ -60,14 +60,14 @@ extension SuggestFunctionViewController { private func configureUI(){ titleLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) titleLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - titleLabel.setLineSpacing(kernValue: -0.5) + titleLabel.setTextWithAttributes(kernValue: -0.5) closeButton.setImage(DesignSystemAsset.Navigation.crossClose.image, for: .normal) descriptionLabel1.text = "제안해 주고 싶은 기능에 대해 설명해 주세요." descriptionLabel1.font = DesignSystemFontFamily.Pretendard.medium.font(size: 18) descriptionLabel1.textColor = DesignSystemAsset.GrayColor.gray900.color - descriptionLabel1.setLineSpacing(kernValue: -0.5) + descriptionLabel1.setTextWithAttributes(kernValue: -0.5) textView.delegate = self textView.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) @@ -82,7 +82,7 @@ extension SuggestFunctionViewController { descriptionLabel2.text = "어떤 플랫폼과 관련된 기능인가요?" descriptionLabel2.font = DesignSystemFontFamily.Pretendard.medium.font(size: 18) descriptionLabel2.textColor = DesignSystemAsset.GrayColor.gray900.color - descriptionLabel2.setLineSpacing(kernValue: -0.5) + descriptionLabel2.setTextWithAttributes(kernValue: -0.5) let superViews: [UIView] = [self.mobileAppSuperView, self.webSiteSuperView] let buttons: [UIButton] = [self.mobileAppButton, self.webSiteButton] diff --git a/Projects/Features/StorageFeature/Sources/ViewControllers/WakMusicFeedbackViewController.swift b/Projects/Features/StorageFeature/Sources/ViewControllers/WakMusicFeedbackViewController.swift index 37ab4b71d..e82d8ea48 100644 --- a/Projects/Features/StorageFeature/Sources/ViewControllers/WakMusicFeedbackViewController.swift +++ b/Projects/Features/StorageFeature/Sources/ViewControllers/WakMusicFeedbackViewController.swift @@ -51,14 +51,14 @@ extension WakMusicFeedbackViewController { private func configureUI(){ titleLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) titleLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - titleLabel.setLineSpacing(kernValue: -0.5) + titleLabel.setTextWithAttributes(kernValue: -0.5) closeButton.setImage(DesignSystemAsset.Navigation.crossClose.image, for: .normal) descriptionLabel1.text = "문의하실 내용을 적어주세요." descriptionLabel1.font = DesignSystemFontFamily.Pretendard.medium.font(size: 18) descriptionLabel1.textColor = DesignSystemAsset.GrayColor.gray900.color - descriptionLabel1.setLineSpacing(kernValue: -0.5) + descriptionLabel1.setTextWithAttributes(kernValue: -0.5) textView.delegate = self textView.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) diff --git a/Projects/Features/StorageFeature/Sources/Views/AnswerTableViewCell.swift b/Projects/Features/StorageFeature/Sources/Views/AnswerTableViewCell.swift index 25873b653..f6efa2f36 100644 --- a/Projects/Features/StorageFeature/Sources/Views/AnswerTableViewCell.swift +++ b/Projects/Features/StorageFeature/Sources/Views/AnswerTableViewCell.swift @@ -18,7 +18,8 @@ class AnswerTableViewCell: UITableViewCell { override func awakeFromNib() { super.awakeFromNib() answerLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 14) - answerLabel.setLineSpacing(kernValue: -0.5, lineSpacing: 6) + answerLabel.setTextWithAttributes(kernValue: -0.5, lineSpacing: 6) + } } diff --git a/Projects/Features/StorageFeature/Sources/Views/NoticeDetailHeaderView.swift b/Projects/Features/StorageFeature/Sources/Views/NoticeDetailHeaderView.swift index 06487ef40..33cf0ff7b 100644 --- a/Projects/Features/StorageFeature/Sources/Views/NoticeDetailHeaderView.swift +++ b/Projects/Features/StorageFeature/Sources/Views/NoticeDetailHeaderView.swift @@ -23,19 +23,19 @@ class NoticeDetailHeaderView: UICollectionReusableView { titleStringLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 18) titleStringLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - titleStringLabel.setLineSpacing(kernValue: -0.5, lineSpacing: 0, lineHeightMultiple: 1.26) + titleStringLabel.setTextWithAttributes(kernValue: -0.5, lineSpacing: 0, lineHeightMultiple: 1.26) dateLabel.font = DesignSystemFontFamily.Pretendard.light.font(size: 12) dateLabel.textColor = DesignSystemAsset.GrayColor.gray500.color - dateLabel.setLineSpacing(kernValue: -0.5, lineSpacing: 0, lineHeightMultiple: 0) + dateLabel.setTextWithAttributes(kernValue: -0.5, lineSpacing: 0, lineHeightMultiple: 0) timeLabel.font = DesignSystemFontFamily.Pretendard.light.font(size: 12) timeLabel.textColor = DesignSystemAsset.GrayColor.gray500.color - timeLabel.setLineSpacing(kernValue: -0.5, lineSpacing: 0, lineHeightMultiple: 0) + timeLabel.setTextWithAttributes(kernValue: -0.5, lineSpacing: 0, lineHeightMultiple: 0) contentStringLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 14) contentStringLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - contentStringLabel.setLineSpacing(kernValue: -0.5, lineSpacing: 0, lineHeightMultiple: 1.26) + contentStringLabel.setTextWithAttributes(kernValue: -0.5, lineSpacing: 0, lineHeightMultiple: 1.26) } } diff --git a/Projects/Features/StorageFeature/Sources/Views/NoticeListCell.swift b/Projects/Features/StorageFeature/Sources/Views/NoticeListCell.swift index b19485d13..33db60670 100644 --- a/Projects/Features/StorageFeature/Sources/Views/NoticeListCell.swift +++ b/Projects/Features/StorageFeature/Sources/Views/NoticeListCell.swift @@ -24,15 +24,15 @@ class NoticeListCell: UITableViewCell { titleStringLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) titleStringLabel.textColor = DesignSystemAsset.GrayColor.gray900.color - titleStringLabel.setLineSpacing(kernValue: -0.5, lineSpacing: 0, lineHeightMultiple: 1.26) - + titleStringLabel.setTextWithAttributes(kernValue: -0.5, lineSpacing: 0, lineHeightMultiple: 1.26) + dayLabel.font = DesignSystemFontFamily.Pretendard.light.font(size: 12) dayLabel.textColor = DesignSystemAsset.GrayColor.gray500.color - dayLabel.setLineSpacing(kernValue: -0.5, lineSpacing: 0, lineHeightMultiple: 0) + dayLabel.setTextWithAttributes(kernValue: -0.5, lineSpacing: 0, lineHeightMultiple: 0) timeLabel.font = DesignSystemFontFamily.Pretendard.light.font(size: 12) timeLabel.textColor = DesignSystemAsset.GrayColor.gray500.color - timeLabel.setLineSpacing(kernValue: -0.5, lineSpacing: 0, lineHeightMultiple: 0) + timeLabel.setTextWithAttributes(kernValue: -0.5, lineSpacing: 0, lineHeightMultiple: 0) } } diff --git a/Projects/Features/StorageFeature/Sources/Views/QuestionTableViewCell.swift b/Projects/Features/StorageFeature/Sources/Views/QuestionTableViewCell.swift index 9fb0136cd..51571203e 100644 --- a/Projects/Features/StorageFeature/Sources/Views/QuestionTableViewCell.swift +++ b/Projects/Features/StorageFeature/Sources/Views/QuestionTableViewCell.swift @@ -20,9 +20,9 @@ class QuestionTableViewCell: UITableViewCell { override func awakeFromNib() { super.awakeFromNib() categoryLabel.font = DesignSystemFontFamily.Pretendard.light.font(size: 12) - categoryLabel.setLineSpacing(kernValue: -0.5) + categoryLabel.setTextWithAttributes(kernValue: -0.5) titleLabel.font = DesignSystemFontFamily.Pretendard.medium.font(size: 16) - titleLabel.setLineSpacing(kernValue: -0.5, lineSpacing: 5) + titleLabel.setTextWithAttributes(kernValue: -0.5, lineSpacing: 5) } } diff --git a/Projects/Modules/Utility/Sources/Extensions/Extension+UILabel.swift b/Projects/Modules/Utility/Sources/Extensions/Extension+UILabel.swift deleted file mode 100644 index 725626619..000000000 --- a/Projects/Modules/Utility/Sources/Extensions/Extension+UILabel.swift +++ /dev/null @@ -1,50 +0,0 @@ -// -// Extension+UILabel.swift -// Utility -// -// Created by YoungK on 2023/01/09. -// Copyright © 2023 yongbeomkwak. All rights reserved. -// - -import UIKit - -public extension UILabel { - /// 레이블의 자간, 행간을 조절하는 메소드입니다. - /// - Parameter kernValue: 글자간의 간격 - /// - Parameter lineSpacing: 줄 간격 (한 줄과 다음 줄 사이의 간격) - /// - Parameter lineHeightMultiple: 줄 간격의 배수 (lineSpacing * lineHeightMultiple) - func setLineSpacing(kernValue: Double = 0.0, - lineSpacing: CGFloat = 0.0, - lineHeightMultiple: CGFloat = 0.0) { - guard let labelText = self.text else { return } - - let paragraphStyle = NSMutableParagraphStyle() - paragraphStyle.lineSpacing = lineSpacing - paragraphStyle.lineHeightMultiple = lineHeightMultiple - paragraphStyle.lineBreakMode = .byTruncatingTail - - let attributedString = NSMutableAttributedString(string: labelText, - attributes: [ - .paragraphStyle: paragraphStyle, - .kern: kernValue - ]) - - self.attributedText = attributedString - } - - func setLineHeight(lineHeight: CGFloat){ - if let text = self.text { - let style = NSMutableParagraphStyle() - style.maximumLineHeight = lineHeight - style.minimumLineHeight = lineHeight - - let attributes: [NSAttributedString.Key: Any] = [ - .paragraphStyle: style, - .baselineOffset: (lineHeight - font.lineHeight) / 4 - ] - let attrString = NSAttributedString(string: text, - attributes: attributes) - self.attributedText = attrString - } - } -} diff --git a/Projects/Services/DataMappingModule/Sources/App/Response/AppInfoDTO.swift b/Projects/Services/DataMappingModule/Sources/App/Response/AppInfoDTO.swift index 9373386a5..88944aab1 100644 --- a/Projects/Services/DataMappingModule/Sources/App/Response/AppInfoDTO.swift +++ b/Projects/Services/DataMappingModule/Sources/App/Response/AppInfoDTO.swift @@ -11,4 +11,5 @@ import Foundation public struct AppInfoDTO: Codable { public let flag: AppInfoFlagType public let title, description, version: String? + public let specialLogo: Bool? } diff --git a/Projects/Services/DomainModule/Sources/App/Entity/AppInfoEntity.swift b/Projects/Services/DomainModule/Sources/App/Entity/AppInfoEntity.swift index a27663fae..5bc3a2dd4 100644 --- a/Projects/Services/DomainModule/Sources/App/Entity/AppInfoEntity.swift +++ b/Projects/Services/DomainModule/Sources/App/Entity/AppInfoEntity.swift @@ -14,15 +14,18 @@ public struct AppInfoEntity: Equatable { flag: AppInfoFlagType, title: String, description: String, - version: String + version: String, + specialLogo: Bool ) { self.flag = flag self.title = title self.description = description self.version = version + self.specialLogo = specialLogo } public let flag: AppInfoFlagType public let title, description, version: String + public let specialLogo: Bool } diff --git a/Projects/Services/NetworkModule/Sources/App/DataTransfer/FetchCheckVersionTransfer.swift b/Projects/Services/NetworkModule/Sources/App/DataTransfer/FetchCheckVersionTransfer.swift index dc95b343f..3215d5851 100644 --- a/Projects/Services/NetworkModule/Sources/App/DataTransfer/FetchCheckVersionTransfer.swift +++ b/Projects/Services/NetworkModule/Sources/App/DataTransfer/FetchCheckVersionTransfer.swift @@ -17,7 +17,8 @@ public extension AppInfoDTO { flag: flag, title: title ?? "", description: description ?? "", - version: version ?? "" + version: version ?? "", + specialLogo: specialLogo ?? false ) } } diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Color/PrimaryColor.xcassets/POINT.colorset/Contents.json b/Projects/UsertInterfaces/DesignSystem/Resources/Color/PrimaryColor.xcassets/POINT.colorset/Contents.json index 70d5a6793..916ca5520 100644 --- a/Projects/UsertInterfaces/DesignSystem/Resources/Color/PrimaryColor.xcassets/POINT.colorset/Contents.json +++ b/Projects/UsertInterfaces/DesignSystem/Resources/Color/PrimaryColor.xcassets/POINT.colorset/Contents.json @@ -5,9 +5,9 @@ "color-space" : "srgb", "components" : { "alpha" : "1.000", - "blue" : "0.969", - "green" : "0.871", - "red" : "0.031" + "blue" : "0.950", + "green" : "0.785", + "red" : "0.036" } }, "idiom" : "universal" diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/Contents.json b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/Contents.json index 5608e9ec7..2b077804e 100644 --- a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/Contents.json +++ b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/Contents.json @@ -5,12 +5,12 @@ "scale" : "1x" }, { - "filename" : "document_on@2x.png", + "filename" : "ic_24_document_on-1.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "document_on@3x.png", + "filename" : "ic_24_document_on.png", "idiom" : "universal", "scale" : "3x" } diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/document_on@2x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/document_on@2x.png deleted file mode 100644 index 94d05eafc..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/document_on@2x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/document_on@3x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/document_on@3x.png deleted file mode 100644 index 549e6d07b..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/document_on@3x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/ic_24_document_on-1.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/ic_24_document_on-1.png new file mode 100644 index 000000000..f031cc779 Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/ic_24_document_on-1.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/ic_24_document_on.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/ic_24_document_on.png new file mode 100644 index 000000000..b56d388c4 Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Artist.xcassets/document_on.imageset/ic_24_document_on.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/Contents.json b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/Contents.json index f54604927..4a9459e18 100644 --- a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/Contents.json +++ b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/Contents.json @@ -5,12 +5,12 @@ "scale" : "1x" }, { - "filename" : "ic_32_play_point@2x.png", + "filename" : "ic_32_play_point-1.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "ic_32_play_point@3x.png", + "filename" : "ic_32_play_point.png", "idiom" : "universal", "scale" : "3x" } diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/ic_32_play_point-1.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/ic_32_play_point-1.png new file mode 100644 index 000000000..ad1b5ecfd Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/ic_32_play_point-1.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/ic_32_play_point.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/ic_32_play_point.png new file mode 100644 index 000000000..74ee7fc38 Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/ic_32_play_point.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/ic_32_play_point@2x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/ic_32_play_point@2x.png deleted file mode 100644 index 0f10adc80..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/ic_32_play_point@2x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/ic_32_play_point@3x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/ic_32_play_point@3x.png deleted file mode 100644 index 07d8b5a21..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Home.xcassets/play_small.imageset/ic_32_play_point@3x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/Contents.json b/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/Contents.json index 1c6209a01..fbea48b8f 100644 --- a/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/Contents.json +++ b/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/Contents.json @@ -5,12 +5,12 @@ "scale" : "1x" }, { - "filename" : "check_on@2x.png", + "filename" : "ic_32_Check_on-1.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "check_on@3x.png", + "filename" : "ic_32_Check_on.png", "idiom" : "universal", "scale" : "3x" } diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/check_on@2x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/check_on@2x.png deleted file mode 100644 index 17ccf2435..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/check_on@2x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/check_on@3x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/check_on@3x.png deleted file mode 100644 index bc671e74c..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/check_on@3x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/ic_32_Check_on-1.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/ic_32_Check_on-1.png new file mode 100644 index 000000000..17a28e708 Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/ic_32_Check_on-1.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/ic_32_Check_on.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/ic_32_Check_on.png new file mode 100644 index 000000000..36c1171e8 Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/PlayListEdit.xcassets/check_on.imageset/ic_32_Check_on.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/Contents.json b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/Contents.json index a029f6ae9..4f02d0550 100644 --- a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/Contents.json +++ b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/Contents.json @@ -5,12 +5,12 @@ "scale" : "1x" }, { - "filename" : "ic_80_play@2x.png", + "filename" : "ic_80_play-1.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "ic_80_play@3x.png", + "filename" : "ic_80_play.png", "idiom" : "universal", "scale" : "3x" } diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/ic_80_play-1.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/ic_80_play-1.png new file mode 100644 index 000000000..2851a849f Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/ic_80_play-1.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/ic_80_play.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/ic_80_play.png new file mode 100644 index 000000000..a8a22b4df Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/ic_80_play.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/ic_80_play@2x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/ic_80_play@2x.png deleted file mode 100644 index aa1305938..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/ic_80_play@2x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/ic_80_play@3x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/ic_80_play@3x.png deleted file mode 100644 index 2cdc3ac4b..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_large.imageset/ic_80_play@3x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/Contents.json b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/Contents.json index c9f3912da..4a9459e18 100644 --- a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/Contents.json +++ b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/Contents.json @@ -5,12 +5,12 @@ "scale" : "1x" }, { - "filename" : "play@2x.png", + "filename" : "ic_32_play_point-1.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "play@3x.png", + "filename" : "ic_32_play_point.png", "idiom" : "universal", "scale" : "3x" } diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/ic_32_play_point-1.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/ic_32_play_point-1.png new file mode 100644 index 000000000..ad1b5ecfd Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/ic_32_play_point-1.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/ic_32_play_point.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/ic_32_play_point.png new file mode 100644 index 000000000..74ee7fc38 Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/ic_32_play_point.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/play@2x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/play@2x.png deleted file mode 100644 index 0f10adc80..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/play@2x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/play@3x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/play@3x.png deleted file mode 100644 index 07d8b5a21..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/play_medium.imageset/play@3x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/Contents.json b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/Contents.json index faa72558b..c4654b9f6 100644 --- a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/Contents.json +++ b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/Contents.json @@ -5,12 +5,12 @@ "scale" : "1x" }, { - "filename" : "repeat_on_1@2x.png", + "filename" : "ic_32_repeat_on_1-1.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "repeat_on_1@3x.png", + "filename" : "ic_32_repeat_on_1.png", "idiom" : "universal", "scale" : "3x" } diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/ic_32_repeat_on_1-1.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/ic_32_repeat_on_1-1.png new file mode 100644 index 000000000..026dec99b Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/ic_32_repeat_on_1-1.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/ic_32_repeat_on_1.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/ic_32_repeat_on_1.png new file mode 100644 index 000000000..f035bcf35 Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/ic_32_repeat_on_1.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/repeat_on_1@2x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/repeat_on_1@2x.png deleted file mode 100644 index 022c45739..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/repeat_on_1@2x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/repeat_on_1@3x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/repeat_on_1@3x.png deleted file mode 100644 index 1679ceb41..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_1.imageset/repeat_on_1@3x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/Contents.json b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/Contents.json index fe37b5a6b..43192be9c 100644 --- a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/Contents.json +++ b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/Contents.json @@ -5,12 +5,12 @@ "scale" : "1x" }, { - "filename" : "repeat_on_all@2x.png", + "filename" : "ic_32_repeat_on_all-1.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "repeat_on_all@3x.png", + "filename" : "ic_32_repeat_on_all.png", "idiom" : "universal", "scale" : "3x" } diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/ic_32_repeat_on_all-1.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/ic_32_repeat_on_all-1.png new file mode 100644 index 000000000..83afced3f Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/ic_32_repeat_on_all-1.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/ic_32_repeat_on_all.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/ic_32_repeat_on_all.png new file mode 100644 index 000000000..d26bbc2a2 Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/ic_32_repeat_on_all.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/repeat_on_all@2x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/repeat_on_all@2x.png deleted file mode 100644 index aeffb68b5..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/repeat_on_all@2x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/repeat_on_all@3x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/repeat_on_all@3x.png deleted file mode 100644 index 203f521c1..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/repeat_on_all.imageset/repeat_on_all@3x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/Contents.json b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/Contents.json index d4e663544..9142474a2 100644 --- a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/Contents.json +++ b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/Contents.json @@ -5,12 +5,12 @@ "scale" : "1x" }, { - "filename" : "shuffle_on@2x.png", + "filename" : "ic_32_random_on-1.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "shuffle_on@3x.png", + "filename" : "ic_32_random_on.png", "idiom" : "universal", "scale" : "3x" } diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/ic_32_random_on-1.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/ic_32_random_on-1.png new file mode 100644 index 000000000..984b765dc Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/ic_32_random_on-1.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/ic_32_random_on.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/ic_32_random_on.png new file mode 100644 index 000000000..0dee60d4b Binary files /dev/null and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/ic_32_random_on.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/shuffle_on@2x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/shuffle_on@2x.png deleted file mode 100644 index 30308cdec..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/shuffle_on@2x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/shuffle_on@3x.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/shuffle_on@3x.png deleted file mode 100644 index f83f295a3..000000000 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Player.xcassets/shuffle_on.imageset/shuffle_on@3x.png and /dev/null differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Storage.xcassets/play.imageset/ic_32_play_point-1.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Storage.xcassets/play.imageset/ic_32_play_point-1.png index 84047286d..e890925f6 100644 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Storage.xcassets/play.imageset/ic_32_play_point-1.png and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Storage.xcassets/play.imageset/ic_32_play_point-1.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Storage.xcassets/play.imageset/ic_32_play_point.png b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Storage.xcassets/play.imageset/ic_32_play_point.png index 106031908..ecdec6ce9 100644 Binary files a/Projects/UsertInterfaces/DesignSystem/Resources/Image/Storage.xcassets/play.imageset/ic_32_play_point.png and b/Projects/UsertInterfaces/DesignSystem/Resources/Image/Storage.xcassets/play.imageset/ic_32_play_point.png differ diff --git a/Projects/UsertInterfaces/DesignSystem/Resources/Lottie/Splash_Logo_Special.json b/Projects/UsertInterfaces/DesignSystem/Resources/Lottie/Splash_Logo_Special.json new file mode 100644 index 000000000..fdbf4f821 --- /dev/null +++ b/Projects/UsertInterfaces/DesignSystem/Resources/Lottie/Splash_Logo_Special.json @@ -0,0 +1 @@ +{"v":"4.8.0","meta":{"g":"LottieFiles AE 3.5.2","a":"","k":"","d":"","tc":""},"fr":29.9700012207031,"ip":0,"op":81.0000032991976,"w":1500,"h":1900,"nm":"Main","ddd":0,"assets":[{"id":"image_0","w":289,"h":158,"u":"","p":"","e":1},{"id":"image_1","w":213,"h":218,"u":"","p":"","e":1},{"id":"image_2","w":57,"h":57,"u":"","p":"","e":1},{"id":"image_3","w":108,"h":95,"u":"","p":"","e":1},{"id":"image_4","w":134,"h":134,"u":"","p":"","e":1},{"id":"image_5","w":1215,"h":727,"u":"","p":"","e":1},{"id":"comp_0","layers":[{"ddd":0,"ind":1,"ty":0,"nm":"Santa-hat","refId":"comp_1","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.7],"y":[1]},"o":{"x":[0.167],"y":[0.167]},"t":38,"s":[20]},{"i":{"x":[0.7],"y":[1]},"o":{"x":[0.167],"y":[0]},"t":50,"s":[-1]},{"t":60.0000024438501,"s":[0]}],"ix":10},"p":{"a":1,"k":[{"i":{"x":0.7,"y":1},"o":{"x":0.167,"y":0.167},"t":38,"s":[1242,432,0],"to":[-226,98,0],"ti":[0,0,0]},{"i":{"x":0.7,"y":1},"o":{"x":0.167,"y":0},"t":50,"s":[1000,1038,0],"to":[0,0,0],"ti":[0,0,0]},{"t":60.0000024438501,"s":[1000,1000,0]}],"ix":2},"a":{"a":0,"k":[1000,1000,0],"ix":1},"s":{"a":1,"k":[{"i":{"x":[0.7,0.7,0.667],"y":[1,1,1]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,17]},"t":38,"s":[0,0,100]},{"i":{"x":[0.7,0.7,0.667],"y":[1,1,1]},"o":{"x":[0.167,0.167,0.167],"y":[0,0,0]},"t":50,"s":[102,102,100]},{"t":60.0000024438501,"s":[100,100,100]}],"ix":6}},"ao":0,"w":2000,"h":2000,"ip":38.0000015477717,"op":188.000007657397,"st":38.0000015477717,"bm":0},{"ddd":0,"ind":2,"ty":2,"nm":"코","refId":"image_4","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[1002.3,1057.09,0],"ix":2},"a":{"a":0,"k":[66.691,66.691,0],"ix":1},"s":{"a":1,"k":[{"i":{"x":[0.667,0.667,0.667],"y":[1,1,1]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,20]},"t":30,"s":[0,0,100]},{"i":{"x":[0.667,0.667,0.667],"y":[1,1,1]},"o":{"x":[0.333,0.333,0.333],"y":[0,0,0]},"t":37,"s":[120,120,100]},{"t":43.0000017514259,"s":[100,100,100]}],"ix":6}},"ao":0,"ip":30.0000012219251,"op":316.000012870944,"st":16.0000006516934,"bm":0},{"ddd":0,"ind":3,"ty":2,"nm":"레이어 1","refId":"image_5","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[999.842,999.509,0],"ix":2},"a":{"a":0,"k":[607.335,363.363,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"hasMask":true,"masksProperties":[{"inv":false,"mode":"s","pt":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":25,"s":[{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[684.493,521.855],[533.493,521.855],[533.493,498.855],[684.493,498.855]],"c":true}]},{"t":26.0000010590017,"s":[{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[684.493,351.855],[533.493,351.855],[533.493,498.855],[684.493,498.855]],"c":true}]}],"ix":1},"o":{"a":0,"k":100,"ix":3},"x":{"a":0,"k":0,"ix":4},"nm":"Mask 1"}],"ip":0,"op":150.000006109625,"st":0,"bm":0}]},{"id":"comp_1","layers":[{"ddd":0,"ind":1,"ty":2,"nm":"레이어 7","refId":"image_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[1101.137,636.976,0],"ix":2},"a":{"a":0,"k":[144.114,78.956,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":262.000010671479,"st":-38.0000015477717,"bm":0},{"ddd":0,"ind":2,"ty":2,"nm":"레이어 5","refId":"image_1","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[1106.338,523.097,0],"ix":2},"a":{"a":0,"k":[106.174,108.906,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":262.000010671479,"st":-38.0000015477717,"bm":0},{"ddd":0,"ind":3,"ty":2,"nm":"레이어 6","parent":4,"refId":"image_2","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[106.33,87.413,0],"ix":2},"a":{"a":0,"k":[28.363,28.363,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":262.000010671479,"st":-38.0000015477717,"bm":0},{"ddd":0,"ind":4,"ty":2,"nm":"레이어 4","refId":"image_3","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.412],"y":[1]},"o":{"x":[0.167],"y":[0.167]},"t":5,"s":[-36]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":23,"s":[6]},{"t":34.0000013848484,"s":[0]}],"ix":10},"p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.167,"y":0.167},"t":5,"s":[1147.83,439.265,0],"to":[0,0,0],"ti":[0,0,0]},{"t":23.0000009368092,"s":[1140.83,439.265,0]}],"ix":2},"a":{"a":0,"k":[19.909,22.168,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":262.000010671479,"st":-38.0000015477717,"bm":0}]},{"id":"comp_2","layers":[{"ddd":0,"ind":1,"ty":4,"nm":"우4 Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[1100.134,778,0],"ix":2},"a":{"a":0,"k":[382.57,398,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[55.268,0],[0,-55.267],[0,0]],"o":[[0,0],[0,-55.267],[-55.267,0],[0,0],[0,0]],"v":[[100.071,80.571],[100.071,-15.43],[-0.001,-115.5],[-100.071,-15.43],[-100.071,115.5]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[382.571,398],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"tm","s":{"a":0,"k":0,"ix":1},"e":{"a":1,"k":[{"i":{"x":[0],"y":[1]},"o":{"x":[0.167],"y":[0.167]},"t":18,"s":[0]},{"t":32.0000013033867,"s":[100]}],"ix":2},"o":{"a":0,"k":0,"ix":3},"m":1,"ix":2,"nm":"Trim Paths 1","mn":"ADBE Vector Filter - Trim","hd":false}],"ip":12.00000048877,"op":162.000006598395,"st":12.00000048877,"bm":0},{"ddd":0,"ind":2,"ty":4,"nm":"우3 Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[1299.852,1016.022,0],"ix":2},"a":{"a":0,"k":[382.148,539.336,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[55.034,0],[0,-55.034],[0,0]],"o":[[0,0],[0,-55.034],[-55.034,0],[0,0],[0,0]],"v":[[99.648,67.078],[99.648,-157.188],[0,-256.835],[-99.648,-157.188],[-99.648,256.836]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[382.148,539.336],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"tm","s":{"a":0,"k":0,"ix":1},"e":{"a":1,"k":[{"i":{"x":[0],"y":[1]},"o":{"x":[0.167],"y":[0.167]},"t":12,"s":[0]},{"t":27.0000010997325,"s":[100]}],"ix":2},"o":{"a":0,"k":0,"ix":3},"m":1,"ix":2,"nm":"Trim Paths 1","mn":"ADBE Vector Filter - Trim","hd":false}],"ip":12.00000048877,"op":162.000006598395,"st":12.00000048877,"bm":0},{"ddd":0,"ind":3,"ty":4,"nm":"우2 Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[1399.4,1120.619,0],"ix":2},"a":{"a":0,"k":[56.5,112.119,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[56.5,56.5],[56.5,167.738]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"tm","s":{"a":0,"k":0,"ix":1},"e":{"a":1,"k":[{"i":{"x":[0],"y":[1]},"o":{"x":[0.167],"y":[0.167]},"t":12,"s":[0]},{"t":22.0000008960784,"s":[100]}],"ix":2},"o":{"a":0,"k":0,"ix":3},"m":1,"ix":2,"nm":"Trim Paths 1","mn":"ADBE Vector Filter - Trim","hd":false}],"ip":12.00000048877,"op":162.000006598395,"st":12.00000048877,"bm":0},{"ddd":0,"ind":4,"ty":4,"nm":"우1 Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[1600.4,1038.493,0],"ix":2},"a":{"a":0,"k":[56.5,101.107,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[56.5,56.5],[56.5,145.714]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"tm","s":{"a":1,"k":[{"i":{"x":[0],"y":[1]},"o":{"x":[0.15],"y":[0]},"t":12,"s":[100]},{"t":32.0000013033867,"s":[0]}],"ix":1},"e":{"a":0,"k":100,"ix":2},"o":{"a":0,"k":0,"ix":3},"m":1,"ix":2,"nm":"Trim Paths 1","mn":"ADBE Vector Filter - Trim","hd":false}],"ip":12.00000048877,"op":162.000006598395,"st":12.00000048877,"bm":0},{"ddd":0,"ind":5,"ty":4,"nm":"좌4 Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[900.05,1237.107,0],"ix":2},"a":{"a":0,"k":[382.45,382.893,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[-55.201,0],[0,55.201]],"o":[[0,0],[0,55.201],[55.201,0],[0,0]],"v":[[-99.95,-100.393],[-99.95,0.443],[0,100.393],[99.95,0.443]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[382.45,382.893],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"tm","s":{"a":0,"k":0,"ix":1},"e":{"a":1,"k":[{"i":{"x":[0],"y":[1]},"o":{"x":[0.167],"y":[0.167]},"t":18,"s":[0]},{"t":32.0000013033867,"s":[100]}],"ix":2},"o":{"a":0,"k":0,"ix":3},"m":1,"ix":2,"nm":"Trim Paths 1","mn":"ADBE Vector Filter - Trim","hd":false}],"ip":12.00000048877,"op":162.000006598395,"st":12.00000048877,"bm":0},{"ddd":0,"ind":6,"ty":4,"nm":"좌3 Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[700.412,983.8,0],"ix":2},"a":{"a":0,"k":[382.112,539.3,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[-55.014,0],[0,55.014],[0,0]],"o":[[0,0],[0,55.014],[55.014,0],[0,0],[0,0]],"v":[[-99.612,75.086],[-99.612,157.189],[0,256.8],[99.612,157.189],[99.612,-256.8]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[382.112,539.3],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"tm","s":{"a":0,"k":0,"ix":1},"e":{"a":1,"k":[{"i":{"x":[0],"y":[1]},"o":{"x":[0.167],"y":[0.167]},"t":12,"s":[0]},{"t":27.0000010997325,"s":[100]}],"ix":2},"o":{"a":0,"k":0,"ix":3},"m":1,"ix":2,"nm":"Trim Paths 1","mn":"ADBE Vector Filter - Trim","hd":false}],"ip":12.00000048877,"op":162.000006598395,"st":12.00000048877,"bm":0},{"ddd":0,"ind":7,"ty":4,"nm":"좌2 Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[600.8,953.493,0],"ix":2},"a":{"a":0,"k":[56.5,186.107,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[56.5,56.5],[56.5,315.714]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"tm","s":{"a":1,"k":[{"i":{"x":[0],"y":[1]},"o":{"x":[0.167],"y":[0.167]},"t":12,"s":[100]},{"t":22.0000008960784,"s":[0]}],"ix":1},"e":{"a":0,"k":100,"ix":2},"o":{"a":0,"k":0,"ix":3},"m":1,"ix":2,"nm":"Trim Paths 1","mn":"ADBE Vector Filter - Trim","hd":false}],"ip":12.00000048877,"op":162.000006598395,"st":12.00000048877,"bm":0},{"ddd":0,"ind":8,"ty":4,"nm":"좌1 Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[399.7,1038.493,0],"ix":2},"a":{"a":0,"k":[56.5,101.107,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[56.5,56.5],[56.5,145.714]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"tm","s":{"a":1,"k":[{"i":{"x":[0],"y":[1]},"o":{"x":[0.1],"y":[0]},"t":12,"s":[100]},{"t":32.0000013033867,"s":[0]}],"ix":1},"e":{"a":0,"k":100,"ix":2},"o":{"a":0,"k":0,"ix":3},"m":1,"ix":2,"nm":"Trim Paths 1","mn":"ADBE Vector Filter - Trim","hd":false}],"ip":12.00000048877,"op":162.000006598395,"st":12.00000048877,"bm":0},{"ddd":0,"ind":9,"ty":4,"nm":"축 Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[1000.05,1070.993,0],"ix":2},"a":{"a":0,"k":[656.85,68.607,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[1257.2,80.714],[1257.2,56.5]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 2","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[1056.3,80.714],[1056.3,56.5]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 2","np":2,"cix":2,"bm":0,"ix":2,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[856.9,80.714],[856.9,56.5]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 3","np":2,"cix":2,"bm":0,"ix":3,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[56.5,56.5],[56.5,80.714]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 4","np":2,"cix":2,"bm":0,"ix":4,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[257.6,56.5],[257.6,80.714]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 5","np":2,"cix":2,"bm":0,"ix":5,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[456.9,56.5],[456.9,80.714]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 6","np":2,"cix":2,"bm":0,"ix":6,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[656.8,56.5],[656.8,80.714]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":113,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 7","np":2,"cix":2,"bm":0,"ix":7,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":150.000006109625,"st":0,"bm":0}]},{"id":"comp_3","layers":[{"ddd":0,"ind":1,"ty":4,"nm":"WAKTAVERSE Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[999.842,1381.684,0],"ix":2},"a":{"a":0,"k":[632.828,69.651,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"hasMask":true,"masksProperties":[{"inv":false,"mode":"a","pt":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[0.25,0.25],[0.25,139.052],[1265.407,139.052],[1265.407,0.25]],"c":true},"ix":1},"o":{"a":0,"k":100,"ix":3},"x":{"a":0,"k":0,"ix":4},"nm":"Mask 1"}],"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[3.814,-14.183],[0,0],[3.778,13.966],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[-3.591,13.966],[0,0],[-3.816,-14.146],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[107.042,-8.294],[96.905,33.397],[96.044,33.397],[85.907,-8.294],[71.544,-65.752],[33.092,-65.752],[73.639,65.742],[117.589,65.742],[158.135,-65.752],[120.955,-65.752]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ind":1,"ty":"sh","ix":2,"ks":{"a":0,"k":{"i":[[16.673,6.564],[0,0],[0,6.384],[-8.647,0],[-9.044,-6.384],[0,0],[15.239,0],[0,-22.869],[-14.4,-5.762],[0,0],[0,-6.375],[10.722,0],[9.487,7.62],[0,0],[-16.88,0],[0,22.641]],"o":[[0,0],[-12.146,-4.743],[0,-5.978],[9.883,0],[0,0],[-12.354,-12.136],[-29.243,0],[0,19.35],[0,0],[11.344,4.517],[0,5.979],[-9.883,0],[0,0],[14.4,12.976],[33.364,0],[0,-18.521]],"v":[[496.076,-10.086],[479.819,-16.461],[460.053,-29.842],[474.057,-38.923],[500.82,-29.257],[518.539,-51.503],[474.057,-69.401],[424.209,-27.795],[451.189,9.463],[467.852,16.46],[485.977,29.436],[470.738,38.923],[439.411,25.937],[419.25,50.258],[469.898,69.401],[522.226,26.56]],"c":true},"ix":2},"nm":"Path 2","mn":"ADBE Vector Shape - Group","hd":false},{"ind":2,"ty":"sh","ix":3,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[215.521,13.122],[259.069,13.122],[259.069,-15.998],[215.521,-15.998],[215.521,-36.622],[266.443,-36.622],[266.443,-65.752],[180.217,-65.752],[180.217,65.742],[268.48,65.742],[268.48,36.622],[215.521,36.622]],"c":true},"ix":2},"nm":"Path 3","mn":"ADBE Vector Shape - Group","hd":false},{"ind":3,"ty":"sh","ix":4,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[579.609,36.622],[579.609,13.122],[623.12,13.122],[623.12,-15.998],[579.609,-15.998],[579.609,-36.622],[630.542,-36.622],[630.542,-65.752],[544.312,-65.752],[544.312,65.742],[632.578,65.742],[632.578,36.622]],"c":true},"ix":2},"nm":"Path 4","mn":"ADBE Vector Shape - Group","hd":false},{"ind":4,"ty":"sh","ix":5,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[-2.896,13.362],[0,0],[-3.3,-12.571],[0,0]],"o":[[0,0],[3.3,-12.533],[0,0],[3.299,13.146],[0,0],[0,0]],"v":[[-42.405,10.906],[-40.205,1.806],[-30.673,-39.885],[-29.83,-39.885],[-19.896,1.806],[-17.697,10.906]],"c":true},"ix":2},"nm":"Path 5","mn":"ADBE Vector Shape - Group","hd":false},{"ind":5,"ty":"sh","ix":6,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-50.983,-65.752],[-91.968,65.742],[-55.528,65.742],[-48.819,37.838],[-11.281,37.838],[-4.609,65.742],[33.076,65.742],[-7.908,-65.752]],"c":true},"ix":2},"nm":"Path 6","mn":"ADBE Vector Shape - Group","hd":false},{"ind":6,"ty":"sh","ix":7,"ks":{"a":0,"k":{"i":[[13.834,0],[0,0],[0,0],[0,0],[0,-11.316]],"o":[[0,0],[0,0],[0,0],[13.834,0],[0,11.326]],"v":[[341.865,-5.861],[329.248,-5.861],[329.248,-38.235],[341.865,-38.235],[363.008,-23.269]],"c":true},"ix":2},"nm":"Path 7","mn":"ADBE Vector Shape - Group","hd":false},{"ind":7,"ty":"sh","ix":8,"ks":{"a":0,"k":{"i":[[0,18.775],[28.469,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,-32.77],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[12.862,-6.913]],"v":[[397.211,-23.269],[344.308,-65.752],[294.224,-65.752],[294.224,65.742],[329.248,65.742],[329.248,21.647],[342.686,21.647],[365.46,65.742],[404.557,65.742],[375.767,14.631]],"c":true},"ix":2},"nm":"Path 8","mn":"ADBE Vector Shape - Group","hd":false},{"ind":8,"ty":"sh","ix":9,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[-2.896,13.324],[0,0],[-3.298,-12.57],[0,0]],"o":[[0,0],[3.262,-12.57],[0,0],[3.298,13.145],[0,0],[0,0]],"v":[[-413.804,10.944],[-411.605,1.843],[-402.113,-39.847],[-401.27,-39.847],[-391.34,1.843],[-389.139,10.944]],"c":true},"ix":2},"nm":"Path 9","mn":"ADBE Vector Shape - Group","hd":false},{"ind":9,"ty":"sh","ix":10,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-422.417,-65.752],[-463.389,65.742],[-426.961,65.742],[-420.254,37.838],[-382.726,37.838],[-376.02,65.742],[-338.345,65.742],[-379.318,-65.752]],"c":true},"ix":2},"nm":"Path 10","mn":"ADBE Vector Shape - Group","hd":false},{"ind":10,"ty":"sh","ix":11,"ks":{"a":0,"k":{"i":[[0,0],[1.453,-13.937],[0,0],[2.534,13.146],[0,0],[0,0],[0,0],[2.496,-13.758],[0,0],[1.453,13.759],[0,0],[0,0],[0,0],[0,0],[0,0],[-1.49,9.741],[0,0],[-2.123,-10.138],[0,0],[0,0],[0,0],[0,0]],"o":[[-1.491,13.363],[0,0],[-2.533,-13.975],[0,0],[0,0],[0,0],[-2.534,13.542],[0,0],[-1.49,-13.758],[0,0],[0,0],[0,0],[0,0],[0,0],[2.086,-10.1],[0,0],[1.266,9.713],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-505.463,-8.294],[-510.083,32.972],[-510.94,32.972],[-518.503,-8.294],[-531.542,-65.752],[-561.831,-65.752],[-574.87,-8.294],[-582.433,32.972],[-583.29,32.972],[-587.911,-8.294],[-595.474,-65.752],[-632.578,-65.752],[-608.586,65.742],[-563.544,65.742],[-553.448,13.556],[-548.381,-17.215],[-547.524,-17.215],[-542.458,13.556],[-531.99,65.742],[-486.127,65.742],[-463.402,-65.752],[-497.9,-65.752]],"c":true},"ix":2},"nm":"Path 11","mn":"ADBE Vector Shape - Group","hd":false},{"ind":11,"ty":"sh","ix":12,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-194.926,-36.622],[-158.134,-36.622],[-158.134,65.742],[-121.382,65.742],[-121.382,-36.622],[-84.593,-36.622],[-84.593,-65.752],[-194.926,-65.752]],"c":true},"ix":2},"nm":"Path 12","mn":"ADBE Vector Shape - Group","hd":false},{"ind":12,"ty":"sh","ix":13,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-206.528,-65.752],[-245.621,-65.752],[-279.71,-16.781],[-280.52,-16.781],[-280.52,-65.752],[-316.301,-65.752],[-316.301,65.742],[-280.52,65.742],[-280.52,32.972],[-267.635,15.168],[-237.708,65.742],[-198.613,65.742],[-246.837,-12.339]],"c":true},"ix":2},"nm":"Path 13","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0,"y":1},"o":{"x":1,"y":0.417},"t":0,"s":[632.828,229.651],"to":[0,-26.667],"ti":[0,26.667]},{"i":{"x":0,"y":0},"o":{"x":0,"y":0},"t":20,"s":[632.828,69.651],"to":[0,0],"ti":[0,0]},{"t":32.0000013033867,"s":[632.828,69.651]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":14,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":150.000006109625,"st":0,"bm":0},{"ddd":0,"ind":2,"ty":4,"nm":"MUSIC Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[1009.031,1571.617,0],"ix":2},"a":{"a":0,"k":[458.13,69.652,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"hasMask":true,"masksProperties":[{"inv":false,"mode":"a","pt":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[0.25,0.25],[0.25,139.053],[916.011,139.053],[916.011,0.25]],"c":true},"ix":1},"o":{"a":0,"k":100,"ix":3},"x":{"a":0,"k":0,"ix":4},"nm":"Mask 1"}],"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[218.845,69.402],[255.622,69.402],[255.622,-62.093],[218.845,-62.093]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ind":1,"ty":"sh","ix":2,"ks":{"a":0,"k":{"i":[[16.701,6.591],[0,0],[0,6.384],[-8.643,0],[-9.044,-6.385],[0,0],[15.242,0],[0,-22.859],[-14.404,-5.762],[0,0],[0,-6.384],[10.72,0],[9.481,7.62],[0,0],[-16.882,0],[0,22.641]],"o":[[0,0],[-12.142,-4.743],[0,-5.979],[9.882,0],[0,0],[-12.362,-12.146],[-29.245,0],[0,19.36],[0,0],[11.341,4.526],[0,5.979],[-9.883,0],[0,0],[14.404,12.976],[33.366,0],[0.036,-18.521]],"v":[[78.67,-10.076],[62.406,-16.46],[42.642,-29.842],[56.646,-38.923],[83.411,-29.257],[101.132,-51.494],[56.646,-69.402],[6.799,-27.795],[33.781,9.463],[50.447,16.46],[68.569,29.446],[53.328,38.924],[22.004,25.937],[1.839,50.257],[52.488,69.402],[104.816,26.561]],"c":true},"ix":2},"nm":"Path 2","mn":"ADBE Vector Shape - Group","hd":false},{"ind":2,"ty":"sh","ix":3,"ks":{"a":0,"k":{"i":[[0,0],[10.505,0],[0,25.122],[-15.993,0],[-6.742,-5.761],[0,0],[18.115,0],[0,-44.915],[-34.958,0],[-11.589,13.165]],"o":[[-5.885,6.158],[-17.672,0],[0,-24.311],[9.241,0],[0,0],[-9.694,-9.478],[-34.514,0],[0,45.718],[17.672,0],[0,0]],"v":[[438.946,27.399],[414.125,38.924],[384.636,-0.202],[414.531,-38.923],[437.266,-29.041],[456.203,-51.682],[413.672,-69.402],[347.548,1.041],[412.814,69.402],[457.88,49.636]],"c":true},"ix":2},"nm":"Path 3","mn":"ADBE Vector Shape - Group","hd":false},{"ind":3,"ty":"sh","ix":4,"ks":{"a":0,"k":{"i":[[0,0],[2.52,-7.695],[0,0],[2.521,7.27],[0,0],[0,0],[0,0],[0,0],[0,0],[1.668,13.146],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-13.325],[0,0],[0,0],[0,0],[0,0]],"o":[[-2.52,7.27],[0,0],[-2.52,-7.695],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-13.353],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-1.667,13.146],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-383.75,-8.294],[-390.865,14.773],[-391.719,14.773],[-398.834,-8.294],[-419.37,-62.093],[-457.88,-62.093],[-457.88,69.402],[-425.633,69.402],[-425.633,30.567],[-430.229,-16.347],[-429.376,-16.347],[-418.479,15.205],[-401.725,58.688],[-382.451,58.688],[-365.698,15.205],[-354.393,-16.347],[-353.54,-16.347],[-358.136,30.567],[-358.136,69.402],[-325.482,69.402],[-325.482,-62.093],[-364.068,-62.093]],"c":true},"ix":2},"nm":"Path 4","mn":"ADBE Vector Shape - Group","hd":false},{"ind":4,"ty":"sh","ix":5,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[13.996,0],[0,23.028],[0,0],[0,0],[0,0],[-37.469,0],[0,44.104],[0,0],[0,0]],"o":[[0,0],[0,23.028],[-13.996,0],[0,0],[0,0],[0,0],[0,44.104],[37.471,0],[0,0],[0,0],[0,0]],"v":[[-135.339,8.633],[-135.266,8.633],[-155.859,39.998],[-176.052,8.633],[-176.052,-62.093],[-211.482,-62.093],[-211.482,4.654],[-155.896,69.402],[-101.148,4.654],[-101.148,-62.093],[-135.339,-62.093]],"c":true},"ix":2},"nm":"Path 5","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.062745098039,0.094117647059,0.156862745098,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0,"y":1},"o":{"x":1,"y":0.417},"t":0,"s":[458.13,-90.348],"to":[0,26.667],"ti":[0,-26.667]},{"t":20.0000008146167,"s":[458.13,69.652]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":6,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":150.000006109625,"st":0,"bm":0}]}],"layers":[{"ddd":0,"ind":1,"ty":0,"nm":"FINAL","refId":"comp_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[750,797,0],"ix":2},"a":{"a":0,"k":[1000,1000,0],"ix":1},"s":{"a":0,"k":[102,102,100],"ix":6}},"ao":0,"hasMask":true,"masksProperties":[{"inv":false,"mode":"a","pt":{"a":1,"k":[{"i":{"x":0.094,"y":1},"o":{"x":0.5,"y":1},"t":25,"s":[{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[-800,-228],[-800,1772],[-296,1772],[1200,-228]],"c":true}]},{"t":30.0000012219251,"s":[{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[-800,-228],[-800,1771.999],[1272.003,2068],[2768,68]],"c":true}]}],"ix":1},"o":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":25,"s":[0]},{"t":30.0000012219251,"s":[100]}],"ix":3},"x":{"a":0,"k":0,"ix":4},"nm":"Mask 1"}],"w":2000,"h":2000,"ip":0,"op":81.0000032991976,"st":0,"bm":0},{"ddd":0,"ind":2,"ty":0,"nm":"S3","refId":"comp_2","sr":1,"ks":{"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":8,"s":[100]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.333],"y":[0]},"t":26,"s":[100]},{"t":30.0000012219251,"s":[0]}],"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[749.5,797,0],"ix":2},"a":{"a":0,"k":[1000,1000,0],"ix":1},"s":{"a":0,"k":[94,94,100],"ix":6}},"ao":0,"w":2000,"h":2000,"ip":0,"op":81.0000032991976,"st":0,"bm":0},{"ddd":0,"ind":3,"ty":0,"nm":"LOGO TYPE","refId":"comp_3","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[750,1084,0],"ix":2},"a":{"a":0,"k":[1000,1000,0],"ix":1},"s":{"a":0,"k":[102,102,100],"ix":6}},"ao":0,"w":2000,"h":2000,"ip":20.0000008146167,"op":81.0000032991976,"st":20.0000008146167,"bm":0}],"markers":[]} \ No newline at end of file diff --git a/Projects/UsertInterfaces/DesignSystem/Sources/Extension+UILabel.swift b/Projects/UsertInterfaces/DesignSystem/Sources/Extension+UILabel.swift new file mode 100644 index 000000000..219750d0e --- /dev/null +++ b/Projects/UsertInterfaces/DesignSystem/Sources/Extension+UILabel.swift @@ -0,0 +1,95 @@ +// +// Extension+UILabel.swift +// Utility +// +// Created by YoungK on 2023/01/09. +// Copyright © 2023 yongbeomkwak. All rights reserved. +// + +import UIKit + +public extension UILabel { + @available(*, deprecated, renamed: "setTextWithAttributes", message: "setLineSpacing과 setLineHeight 통합됨") + /// 레이블의 높이, 자간, 행간을 조절하는 메소드입니다. + /// - Parameter kernValue: 글자간의 간격 + /// - Parameter lineSpacing: 줄 간격 (한 줄과 다음 줄 사이의 간격) + /// - Parameter lineHeightMultiple: 줄 간격의 배수 (lineSpacing * lineHeightMultiple) + func setLineSpacing(kernValue: Double = 0.0, + lineSpacing: CGFloat = 0.0, + lineHeightMultiple: CGFloat = 0.0) { + guard let labelText = self.text else { return } + + let paragraphStyle = NSMutableParagraphStyle() + paragraphStyle.lineSpacing = lineSpacing + paragraphStyle.lineHeightMultiple = lineHeightMultiple + paragraphStyle.lineBreakMode = .byTruncatingTail + + let attributedString = NSMutableAttributedString(string: labelText, + attributes: [ + .paragraphStyle: paragraphStyle, + .kern: kernValue + ]) + + self.attributedText = attributedString + } + + @available(*, deprecated, renamed: "setTextWithAttributes", message: "setLineSpacing과 setLineHeight 통합됨") + func setLineHeight(lineHeight: CGFloat){ + if let text = self.text { + let style = NSMutableParagraphStyle() + style.maximumLineHeight = lineHeight + style.minimumLineHeight = lineHeight + + let attributes: [NSAttributedString.Key: Any] = [ + .paragraphStyle: style, + .baselineOffset: (lineHeight - font.lineHeight) / 2 + ] + let attrString = NSAttributedString(string: text, + attributes: attributes) + self.attributedText = attrString + } + } + + /// 레이블의 높이, 자간, 행간을 조절하는 메소드입니다. + /// - Parameter lineHeight: 레이블 자체의 높이 + /// - Parameter kernValue: 글자간의 간격 + /// - Parameter lineSpacing: 줄 간격 (한 줄과 다음 줄 사이의 간격) + /// - Parameter lineHeightMultiple: 줄 간격의 배수 (lineSpacing * lineHeightMultiple) + func setTextWithAttributes(lineHeight: CGFloat? = nil, + kernValue: Double? = nil, + lineSpacing: CGFloat? = nil, + lineHeightMultiple: CGFloat? = nil, + alignment: NSTextAlignment = .left) { + guard let labelText = self.text else { return } + + let paragraphStyle = NSMutableParagraphStyle() + + if let lineSpacing { paragraphStyle.lineSpacing = lineSpacing } + if let lineHeightMultiple { paragraphStyle.lineHeightMultiple = lineHeightMultiple } + + paragraphStyle.lineBreakMode = .byTruncatingTail + paragraphStyle.alignment = alignment + + let style = NSMutableParagraphStyle() + + let baselineOffset: CGFloat + + if let lineHeight { + style.maximumLineHeight = lineHeight + style.minimumLineHeight = lineHeight + baselineOffset = (lineHeight - font.lineHeight) / 2 + } else { + baselineOffset = 0 + } + + let attributes: [NSAttributedString.Key: Any] = [ + .paragraphStyle: paragraphStyle, + .kern: kernValue ?? 0.0, + .baselineOffset: baselineOffset + ] + + let attributedString = NSMutableAttributedString(string: labelText, attributes: attributes) + + self.attributedText = attributedString + } +} diff --git a/Projects/UsertInterfaces/DesignSystem/Sources/Temp.swift b/Projects/UsertInterfaces/DesignSystem/Sources/Temp.swift deleted file mode 100644 index 9bdd50472..000000000 --- a/Projects/UsertInterfaces/DesignSystem/Sources/Temp.swift +++ /dev/null @@ -1,9 +0,0 @@ -// -// Temp.swift -// DesignSystem -// -// Created by yongbeomkwak on 2023/02/09. -// Copyright © 2023 yongbeomkwak. All rights reserved. -// - -import Foundation diff --git a/Projects/UsertInterfaces/DesignSystem/Sources/WMFlowLabel.swift b/Projects/UsertInterfaces/DesignSystem/Sources/WMFlowLabel.swift new file mode 100644 index 000000000..5aecc59cb --- /dev/null +++ b/Projects/UsertInterfaces/DesignSystem/Sources/WMFlowLabel.swift @@ -0,0 +1,42 @@ +// +// WMFlowLabel.swift +// DesignSystem +// +// Created by YoungK on 11/25/23. +// Copyright © 2023 yongbeomkwak. All rights reserved. +// + +import UIKit +import MarqueeLabel + +public final class WMFlowLabel: MarqueeLabel { + public init( + text: String = "", + textColor: UIColor = .init(), + font: UIFont.WMFontSystem, + alignment: NSTextAlignment = .left, + lineHeight: CGFloat? = nil, + kernValue: Double? = nil, + lineSpacing: CGFloat? = nil, + lineHeightMultiple: CGFloat? = nil, + leadingBuffer: CGFloat = 0, + trailingBuffer: CGFloat = 0, + animationDelay: CGFloat = 1, + animationSpeed: CGFloat = 30, + fadeLength: CGFloat = 3 + ) { + super.init(frame: .zero, rate: animationSpeed, fadeLength: fadeLength) + self.text = text + self.textColor = textColor + self.font = .setFont(font) + self.textAlignment = alignment + self.setTextWithAttributes(lineHeight: lineHeight, kernValue: kernValue, lineSpacing: lineSpacing, lineHeightMultiple: lineHeightMultiple, alignment: alignment) + self.leadingBuffer = leadingBuffer + self.trailingBuffer = trailingBuffer + self.animationDelay = animationDelay + } + + required init?(coder: NSCoder) { + fatalError("init(coder:) has not been implemented") + } +} diff --git a/Projects/UsertInterfaces/DesignSystem/Sources/WMFontSystem.swift b/Projects/UsertInterfaces/DesignSystem/Sources/WMFontSystem.swift new file mode 100644 index 000000000..90a119202 --- /dev/null +++ b/Projects/UsertInterfaces/DesignSystem/Sources/WMFontSystem.swift @@ -0,0 +1,115 @@ +// +// WMFontSystem.swift +// DesignSystem +// +// Created by YoungK on 11/22/23. +// Copyright © 2023 yongbeomkwak. All rights reserved. +// + +import UIKit + +protocol WMFontable { + var font: UIFont { get } + var lineHeight: CGFloat { get } +} + +public extension UIFont { + enum WMFontSystem: WMFontable { + /// size: 24 height: 36 + case t1(weight: WMFontWeight = .medium) + /// size: 22 height: 32 + case t2(weight: WMFontWeight = .medium) + /// size: 20 height: 32 + case t3(weight: WMFontWeight = .medium) + /// size: 18 height: 28 + case t4(weight: WMFontWeight = .medium) + /// size: 16 height: 24 + case t5(weight: WMFontWeight = .medium) + /// size: 14 height: 14 + case t6(weight: WMFontWeight = .medium) + /// size: 14 height: 20 + case t6_1(weight: WMFontWeight = .medium) + /// size: 12 height: 18 + case t7(weight: WMFontWeight = .medium) + /// size: 12 height: 14 + case t7_1(weight: WMFontWeight = .medium) + /// size: 11 height: 16 + case t8(weight: WMFontWeight = .medium) + } + + static func setFont(_ style: WMFontSystem) -> UIFont { + return style.font + } +} + +public extension UIFont.WMFontSystem { + enum WMFontWeight { + case light, medium, bold + } + + var font: UIFont { + return UIFont(font: weight.font, size: size) ?? .init() + } + + var lineHeight: CGFloat { + return height + } +} + +private extension UIFont.WMFontSystem { + var weight: WMFontWeight { + switch self { + case let .t1(weight), + let .t2(weight), + let .t3(weight), + let .t4(weight), + let .t5(weight), + let .t6(weight), + let .t6_1(weight), + let .t7(weight), + let .t7_1(weight), + let .t8(weight): + return weight + } + } + + var size: CGFloat { + switch self { + case .t1: return 24 + case .t2: return 22 + case .t3: return 20 + case .t4: return 18 + case .t5: return 16 + case .t6: return 14 + case .t6_1: return 14 + case .t7: return 12 + case .t7_1: return 12 + case .t8: return 11 + } + } + + var height: CGFloat { + switch self { + case .t1: return 36 + case .t2: return 32 + case .t3: return 32 + case .t4: return 28 + case .t5: return 24 + case .t6: return 20 + case .t6_1: return 20 + case .t7: return 18 + case .t7_1: return 14 + case .t8: return 16 + } + } +} + +public extension UIFont.WMFontSystem.WMFontWeight { + var font: DesignSystemFontConvertible { + switch self { + case .light: return DesignSystemFontFamily.Pretendard.light + case .medium: return DesignSystemFontFamily.Pretendard.medium + case .bold: return DesignSystemFontFamily.Pretendard.bold + } + } +} diff --git a/Projects/UsertInterfaces/DesignSystem/Sources/WMLabel.swift b/Projects/UsertInterfaces/DesignSystem/Sources/WMLabel.swift new file mode 100644 index 000000000..97da8bba1 --- /dev/null +++ b/Projects/UsertInterfaces/DesignSystem/Sources/WMLabel.swift @@ -0,0 +1,46 @@ +// +// WMLabel.swift +// DesignSystem +// +// Created by YoungK on 11/22/23. +// Copyright © 2023 yongbeomkwak. All rights reserved. +// + +import UIKit +import MarqueeLabel + +public final class WMLabel: UILabel { + public init( + text: String, + textColor: UIColor = .init(), + font: UIFont.WMFontSystem, + alignment: NSTextAlignment = .left, + lineHeight: CGFloat? = nil, + kernValue: Double? = nil, + lineSpacing: CGFloat? = nil, + lineHeightMultiple: CGFloat? = nil + ) { + super.init(frame: .zero) + self.text = text + self.textColor = textColor + self.font = .setFont(font) + self.textAlignment = alignment + self.setTextWithAttributes(lineHeight: lineHeight, kernValue: kernValue, lineSpacing: lineSpacing, lineHeightMultiple: lineHeightMultiple, alignment: alignment) + } + + convenience init( + text: String, + textColor: UIColor = .init(), + font: UIFont.WMFontSystem, + alignment: NSTextAlignment = .left, + lineHeight: CGFloat? = nil, + kernValue: Double? = nil + ) { + self.init(text: text, textColor: textColor, font: font, alignment: alignment, lineHeight: lineHeight, kernValue: kernValue, lineSpacing: nil, lineHeightMultiple: nil) + } + + required init?(coder: NSCoder) { + fatalError("init(coder:) has not been implemented") + } +} + diff --git a/Tuist/Dependencies.swift b/Tuist/Dependencies.swift index 6879c1765..131ef98e4 100644 --- a/Tuist/Dependencies.swift +++ b/Tuist/Dependencies.swift @@ -18,7 +18,7 @@ let dependencies = Dependencies( .remote(url: "https://github.com/RxSwiftCommunity/RxKeyboard.git", requirement: .upToNextMajor(from: "2.0.1")), .remote(url: "https://github.com/huri000/SwiftEntryKit", requirement: .upToNextMajor(from: "2.0.0")), .remote(url: "https://github.com/kyungkoo/naveridlogin-ios-sp", requirement: .upToNextMajor(from: "4.1.5")), - .remote(url: "https://github.com/krzyzanowskim/CryptoSwift.git", requirement: .upToNextMajor(from: "1.6.0")), + .remote(url: "https://github.com/krzyzanowskim/CryptoSwift.git", requirement: .upToNextMajor(from: "1.8.0")), .remote(url: "https://github.com/cbpowell/MarqueeLabel.git", requirement: .upToNextMajor(from: "4.3.0")), .remote(url: "https://github.com/firebase/firebase-ios-sdk.git", requirement: .upToNextMajor(from: "10.7.0")), .remote(url: "https://github.com/ninjaprox/NVActivityIndicatorView.git", requirement: .upToNextMajor(from: "5.1.1")) diff --git a/Tuist/ProjectDescriptionHelpers/Environment.swift b/Tuist/ProjectDescriptionHelpers/Environment.swift index f03a89a63..f689e38fd 100644 --- a/Tuist/ProjectDescriptionHelpers/Environment.swift +++ b/Tuist/ProjectDescriptionHelpers/Environment.swift @@ -9,7 +9,7 @@ public enum Environment { public static let deploymentTarget: DeploymentTarget = .iOS(targetVersion: "14.0", devices: [.iphone]) public static let platform = Platform.iOS public static let baseSetting: SettingsDictionary = SettingsDictionary() - .marketingVersion("2.1.0") + .marketingVersion("2.2.0") .currentProjectVersion("0") .debugInformationFormat(DebugInformationFormat.dwarfWithDsym) .otherLinkerFlags(["-ObjC"]) diff --git a/Tuist/Signing/WaktaverseMusic.Debug.cer.encrypted b/Tuist/Signing/WaktaverseMusic.Debug.cer.encrypted new file mode 100644 index 000000000..fb7149af1 --- /dev/null +++ b/Tuist/Signing/WaktaverseMusic.Debug.cer.encrypted @@ -0,0 +1 @@ +Fl4nwJKCBazx3DL8xzU56w==-T+kG/m0iP7xrs0Zyj9AW3W9WaKpn7Uv2npPpllC2pj0zpE3D2DtQS1ZVodWXZaUpqiYX0qRooP5E74x0hdi0tltfN5KrzIEeJdLv5Lq8DRjN3Fe4geVe/AvM3seAs3JyN/wFGvDzJzCro+pF/kVrYoV3oN8qRKyfSZnP/RndjwM7xMb5oi+goVOoXHiMI4tpMFoQ9Tbg0HKod/RGlZI5e5SzMJEMbJoQS7HM/ougWpG+C4qif9AFRSVrWtF9ePXNeIxni1PModWZY2xfsh01UUNrFLHAz4+ZqCu9jmpVKTDHPwZ3srmZNKNUqftssYezsKwZyrM6fnE7kEpNbt3gD6DRV0NwM1zAJgx52us6biQcsLBQyUyU6wmIWEGGsHIcE92I5Ug/55VrgThq3cq7QMGMb3UUHq9XwgrtimrbeJ8ptF/xPPPRlZmCC1o6DcOcrKW+2kjl502kjR5k9Ou6B+8LkIHgdotLVV8CyOwAEjZQBsJIM8zUjuIByY9wcUWBhPuiPGvcZZxpLu0M53RSWdgUQUZZlpc/pOt3Dclic8jIWdct4pfpbM/JRnalKLXofTEsiQhkkkneUCxdsxVNpWYb5ZAyVzpVLa1+5iIl3dvn5Fcd2w8WxGg6S4x9DP78CreWYvq/c7Sk8Zc4qqu4U9cVsUJv/1qgHfcdwWD5ZbmlEHx30RAWMbD/3pEU50AZlqUxIp1S5jp43Gy4zlqByQFIAC/nmiw+c/MKfzGQT/a1uSVBeE3LMvWDjtO4DFLTAY6gPppWs5F5co4d/5LoYPqfK/zkMR9cZeEXLSHguvkKJWx9lUTFxkCTGKTb2qddk8d52RfQ2GWQbiHFwjgMhKgvDWXPLoQfwyBS71c06X9i728/i49FFCdn2jpPB4SxIT4yJZYvxy0MWib02jCIs399+DaFfhRp4BGjhX2Lk2GebE3O78OpuLtQDWr7yV46gJFj/4UYZtjQXQxV0gMF8rZgpa4mXy8xeEWC1lzLdA/dopiX9HfqwBl/mnJTs4lHNHzsmoz5Az5yT+C9guS4Bh4+f8KI5eUtnb8qPjqdqb/i3UBp8PwHL4uY/X6urN0/NLHV149yuPjkiT62aXnKErNIInnVXPsROdzWyczZlCyBW0He0aSjcwqnvDJYN95v8IZHlxN6KhGRtPfB0YhBXbkHbVNfshU8zRJyArvjtSRFJk1irAyHqQdBTFUGC+TFOc/NVGEXQvlc65HVBhhI4lkOWdon/tUBS+OEIj5Un3ekPyH0VJPz05MAR6AJlYw7ZB+cLSdKgZs6u68TXQ36YESzT2vERquD7M8Ae4JRHUt05/3i/HnpxUJat2lwwVcWtUVM9VXDxGB7QeZT0/KG5tWZimNw9fqnsuJD9MxYoqsixveZDG+Z0xMdvjbbr2py4KlagPA4ms3wQWzhG1sHKN+e/KnFDVAxMNHVFJ/1JAClPTEXZwYx/trBXB8f1Ad8kPFYrlJ0tk4i9n16RiFBebGC/1fH8HBS7jSVF9FzNwG4U82PJGj8r07DXVLzrgzwu6QIh2rVTm+0fob8BII/lekrnGz9ZOIA1DW4ev8q3ieEFbJTwsZxssfXkfN3zwy3OUHwj3wMGiFzqfWMT5OXPvRhDkImvtxMB6+/6lN7quGoi/RTXtAcASHx0YhldDGXe+Kod1pNgODPM/J75RxCjY2lG0zWsTGuKeYTAp9wcffefCbi5a8zUCqgerc3lRZHlr2SZMf2sP0iE12Ruq6Q81BrQGgaitG3FOpTDv69gQxysVyVQgbU1IE6fcEPU46SvfscLydENCDNzZmDfPdra70oY53E6pU+MZL7wYG2P7V2k+jC9+Jn6/cFebZcR2MSdGqUogb0uXwi0uCZj5lgN8t+z94ihbr0stEtAaCjVa5zrswWFqHjoBjZ+q2qW+yTw4CHlCWPyCz3ajpnYIsb/kYk1fIWTz8nB2ScJJ56Pnrg9WXrLm6psEKHw1U= \ No newline at end of file diff --git a/Tuist/Signing/WaktaverseMusic.Debug.mobileprovision b/Tuist/Signing/WaktaverseMusic.Debug.mobileprovision new file mode 100644 index 000000000..e8f8ab71b Binary files /dev/null and b/Tuist/Signing/WaktaverseMusic.Debug.mobileprovision differ diff --git a/Tuist/Signing/WaktaverseMusic.Debug.p12.encrypted b/Tuist/Signing/WaktaverseMusic.Debug.p12.encrypted new file mode 100644 index 000000000..8d7863ec6 --- /dev/null +++ b/Tuist/Signing/WaktaverseMusic.Debug.p12.encrypted @@ -0,0 +1 @@ ++igvqE/zcwI5++0yDFtrcg==-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 \ No newline at end of file diff --git a/Tuist/Signing/WaktaverseMusic.Release.cer.encrypted b/Tuist/Signing/WaktaverseMusic.Release.cer.encrypted new file mode 100644 index 000000000..7a3eaad1c --- /dev/null +++ b/Tuist/Signing/WaktaverseMusic.Release.cer.encrypted @@ -0,0 +1 @@ +oU0HjBuBMWyrb1YdO4yw3A==-+z+6H0ANiVeU/bmsXCXAAzxKSW90TcIWMSOSm84gHx6NU32JIU6QUr9MgoMFM1is1klDMvDusoTAjW1KWN23Zyi+4i5YblewH2e3u0c20ScBAFH27c25E/GlhpQ7SjDIVUGs+hSob9Iu8YFXfyA91sc9UCreFrcHjRESFOXAnuOlklrFqxrpEu+5FlVnDj55JwoJSh98N4uCWQUkC1uklGgEVwUruAEuwSJVE2Cb/NgkfmzFh4mcucsBuSrcEUerQnplTIjxgJ7DFNOH2FwgT8iFpW1IA0QM/hYQPh3xwAwMivNH6zfARjSLuE8wArQ87i2SCQ2rdKOan4b74xZX1ZLn2JEqctfTbDeF15dY7Vn3Lk1CMgw0yDLbUAm3E2M+Lb8ZocYp7MTyrUKeo4EaqyQiXpT2o58SzwLZ6EfD9TJhN64huFCBtJNDu3oh+JDXLcMXadgvGxi3Tn4nrDyaWra2jUzkbV14Jy0bKAR7xHY5XNPXnmBsdqCDMzX7EPHIXLX3rx2RaqVD/1dh1l0KdydWIreOm1jJPY3bBcZofAxHeZUr7g/4T81A0OagvVFQcVcluucpEydJYxW7cm5MRgiuCR8PlYChoeI+pvlpE36i+VvFYGg9PCA703KDqLFC2dxirs6G/f5Hc2NlRbdpAdtadZvJmw5se90vWaQGUiyLx1HjXgOy7VGkzM6zIdLJyryQxlTS+h5QtGf1DwHwee7YjY985/UjpZrKOC6xgNGJTpkzgDtC1cxA8iHUuE5vgX2OBkH8+ZnMiYjOu0VACVld/AMX6TtyNrM28HqEYVHq23SN4rHUVq/yALCp+Y4rK0adVzMIG6dN1wRggGz9rHwezanD5+I+Sg8cXinIr5uhr+Wg2VdsYAGmS7qVHgRv1HM6gzW4elQIuWE6xI94I0evZPS0QHnylV2yz6fAeubW2lhXUiJMpIfpup6T9ZHTrEu4tmjCht3y/+Tz73SCXBOv8osx8wfU1UvKsoX1wrLjz5n6SmQWZmQ47jjxWwyRb60AG59QLgIPl/lJQP+Y+16bWrcPAkL16KEifK/xEGjyGTs5N9YDPv5Smq+m4RkqYkyDh+PMUsBq0rBS8drmwf8bsxUC8yymQT84kTIO+usV1Cx8TbwJypL587bVR7PMi9oB6Em0+YeVWIzzkr/T2AmDZE0pQuQNEKmdkg67EWaxA5oPKViZnnv7n4cj8Tt3ceanR8Fc4EwXr8zpioCIuYGxTN/tWLKHHpHFJpSt36DIqDsHjE9Il8AIUfI8NeaMJjbZmwvcDxQ8RB9TfuVUsrCzxhUnC++hK5s4PUUSxlYffGq3va0UtHTCKF70EDl4vvas8Iu7vYGmm4cntdEuUmtdijTbECWrZpC3RSUV5Ti9ORkRBuhR5OP+hpf992SeWq3gic/Gl0VLluqJmq3SZYVPh/C3nrOdgCO+RaaHZZqna+GYshS2eQXfurujotq5aN/5QjZ7Je9gA/j+8YcdjAqaX11ofweSjVuDLSONWEizlB1Ji8AFj5jUSklPL5nGWWTzJKq+ko4SfUdcmgAr225j6bvVSxPvJD1mc103UgmRQ/1p4c7b85tFIHKpqxo40wCnqX67NA1HiZCFuDiu7fs8QJR0jj8xSGILprWkthZbK/DNfwWo8upD9HNpq7AKG2KALXtqpjASH8Qzm1/N6US4JUgxXrFk/+dRePj0CcRYXhEx1KU1TTd+InVm6o/7DFMAaJW1T8PWgkE+4KKApwyo1/DuakgIOv9ROZ9CMuA0mqX9KCIQ0MCR6Gl2CNYP/JwzifsS7Gzsd+L+Emf1td+or7qNFNJ0q2J9cPie2XMZR81kw9sc6OAxuDri1StjYkvyoVoAHuekYaYxkr9zK1iw5nJ26ruE84XBZJ88VuNaie9iBp57utEicejHuoDBdALYsVxasfqXss+NTLvf5y/EsaWQcDc9bwgiB244g4TUk2M3CNPymvV0DWb0 \ No newline at end of file diff --git a/Tuist/Signing/WaktaverseMusic.Release.mobileprovision b/Tuist/Signing/WaktaverseMusic.Release.mobileprovision new file mode 100644 index 000000000..e856884de Binary files /dev/null and b/Tuist/Signing/WaktaverseMusic.Release.mobileprovision differ diff --git a/Tuist/Signing/WaktaverseMusic.Release.p12.encrypted b/Tuist/Signing/WaktaverseMusic.Release.p12.encrypted new file mode 100644 index 000000000..3f9286d7a --- /dev/null +++ b/Tuist/Signing/WaktaverseMusic.Release.p12.encrypted @@ -0,0 +1 @@ +NcuPxzd+cio70b8yx9ccsA==-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 \ No newline at end of file diff --git a/Tuist/master.key b/Tuist/master.key deleted file mode 100644 index e2110a299..000000000 --- a/Tuist/master.key +++ /dev/null @@ -1 +0,0 @@ -6w7vPFaZPcME3zFm8L24EjBSCiTiYZP25DDLNEQeCE4=