ModulesVC is a collection view controller used for modules/sections selection. I used it as my home screen for users to click module icons to goto specific areas within my app.
Using CocoaPods
pod 'ModulesVC'
- Create a new view and view controller
- import ModulesVC
- Conform your view controller to ModulesVC
- Configure your modules (see below)
- Call setupCollectionView()
let module1 = KModule.init(title: "Users", action: "segueUsers", icon: UIImage(named: "icons8-swirl")!)
let module2 = KModule.init(title: "Cable Count Calculator", action: "test", icon: UIImage(named: "icons8-swirl")!, remoteIconURL: "https://img.icons8.com/external-flaticons-flat-flat-icons/64/000000/external-test-nursing-flaticons-flat-flat-icons.png", badgeText: "New", isEnabled: false, watermark: UIImage(named: "icons8-disabled"))
modules = [module2,module2]
- Title is displayed as a UILabel at the bottom of the module icon.
- Action is used to call didSelectModule function when module icon is tapped. By default if the module's isEnabled is set to false then an access denied alert will be displayed, otherwise it will perform default actions according to the action field (See Default Actions below).
- Icon is the icon to display for the module
- badgeText is optional and if not nil will display a badge in the upper right of the module icon with the badgeText
- isEnabled sets the module to enabled for the user
- watermark is optional and used to set an image as a watermark over the top of the module icon if module isEnabled=false
- [segue]: will perform segue. example: To peform segue with identifier "users"
module.action = "[segue]users"
- [url]: will launch url in default browser. example: To launch https://google.com in default browser:
module.action = "[url]https://google.com"
Module text and badge can be customized by passing "settings bundles". The easiest way to do this is by using the buildModule() function.
var settingsBundle: KModuleSettings = KModuleSettings()
settingsBundle.badge.badgeColor = .gray
settingsBundle.badge.textColor = .white
settingsBundle.title.textColor = .brown
settingsBundle.title.font = UIFont(name: "Marker Felt", size: 17)!
settingsBundle.watermark.alpha = 0.85
var module3 = buildModule(title: "Users", action: "segueUsers", icon: UIImage(named: "icons8-swirl")!, remoteIconURL: "https://img.icons8.com/external-flaticons-flat-flat-icons/64/000000/external-test-nursing-flaticons-flat-flat-icons.png", badgeText: "New", isEnabled: false, watermark: UIImage(named: "icons8-disabled"), badgeSettings: settingsBundle.badge, titleSettings: settingsBundle.title, watermarkSettings: settingsBundle.watermark)
modules = [module3]
///Sets Icon Width. Default is 100
iconWidth = 100
///Sets cell background color. Default is clear
cellBackgroundColor = .clear
///Sets collectionView background color. Default is clear
collectionViewBackgroundColor = .clear
By default remote icons are downloaded and saved in cache for 90 days. Once the cache has expired the icon will be re-downloaded next time it is used. This can be changed by overriding setIconImageCachExpiration()
override func setIconCacheExpiration() {
iconCache.diskStorage.config.expiration = .days(90)
iconCache.memoryStorage.config.expiration = .days(90)
}
By default collection view constraints are set to view bounds. This can be changed by overriding setCollectionViewConstraints()
override func setCollectionViewConstraints() {
collectionView.topAnchor.constraint(equalTo: view.topAnchor).isActive = true
collectionView.leadingAnchor.constraint(equalTo: view.leadingAnchor).isActive = true
collectionView.bottomAnchor.constraint(equalTo: view.bottomAnchor).isActive = true
collectionView.trailingAnchor.constraint(equalTo: view.trailingAnchor).isActive = true
}
If you need code to be called each time the collection view is reloaded you can override reloadCollectionView()
override func reloadCollectionView() {
self.collectionView.reloadData()
}
You can override the function didSelectModule() to customize actions when user taps on module icon.
override func didSelectModule(_ module: KModule) {
guard module.isEnabled else {
let settings = module.settings.alert
ShowAlert.centerView(theme: settings.theme, title: settings.title, message: settings.message, seconds: settings.seconds, invokeHaptics: true)
return
}
let action = module.action
if action.lowercased().hasPrefix("[segue]") {
let segue = action.replacingOccurrences(of: "[segue]", with: "")
performSegue(withIdentifier: segue, sender: self)
} else if action.lowercased().hasPrefix("[url]") {
let url = action.replacingOccurrences(of: "[url]", with: "")
launchURL(url)
}
}