-
✅ The app should allow users to search for songs, albums or artists by typing in search criteria.
-
✅ The app should display the search results in a list showing the song name, artist, and album art.
-
✅ The app should support paging the search results by providing the ability to load more records. Each page limits 20 records.
-
✅ The app should allow users to filter the search results by country or media type.
-
✅ The app should provide the ability to bookmark songs by adding them to a "favorites" list, which can be accessed later.
-
✅ The app should be available in English, Traditional Chinese (Hong Kong), and Simplified Chinese (China) languages.
-
✅ The app should have a clean and intuitive design that is easy to use.
-
✅ The app should support iOS 12+ / Android 6.0+.
Pagination
-
Set a limit to get the track from API.
-
Create an array to store new tracks which get from API.
-
When user scroll to the last cell from the track table, it will call the API again and append new tracks to store in the array.
-
If the new API return the array is below the limit, it WILL NOT call the API when user scroll to the last cell. It prevents to call the API continuously.
Localizable
-
Go to the project page and Info tab.
-
Add the language which you needed in Localization. As the project requirement, I added English, Chinese (Hong Kong) and Chinese, Simplified (China).
-
Create a string file called
Localizable.string
. -
Go to the Inspector which in Xcode's right hand side. Tick all the language which you needed. The string file will create the sub-file for each language.
-
Add below code to apply the localizable for each text.
NSLocalizedString(key, comment: "")
-
Done 🍻.
Play music
-
Implement
AVFoundation
to play the music track.import AVFoundation
-
Add
PeriodicTimeObserver
to observe music's duration time and current time.self.player.addPeriodicTimeObserver()
-
Insert the track
AVPlayerItem
in to the player.self.player.insert(AVPlayerItem(url: URL(string: previewUrl)!), after: nil)
-
Play the music.
self.player.play()
-
Done 🍻.
Use model presentation
-
Apply model presentation method to show the player.
-
In modal presentation, there cannot tigger the
viewWillAppear
andviewDidAppear
function by callback. Therefore, I added observer to observe the dismiss action.vcPlay.vm.psDismiss.subscribe(onNext: { self.refreshFavourite() }).disposed(by: self.vm.disposeBag)
-
When user clicked Favourite button in the player, the track will add into Favourite. User can browse the track which can be accessed later on the top of home page.
-
Done 🍻.
-
Unit test & UI test
-
Favourite function store to local devide
-
Play previous & next for player
-
Others