You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
To connect a diffable data source to a table view(iOS 13 and onward)
lazy vardataSource=configureDataSource()overridefunc viewDidLoad(){
super.viewDidLoad()
//Assign the diffable data source to your table view.
tableView.dataSource = dataSource
//Generate the current state of the table data by creating a snapshot
varsnapshot=NSDiffableDataSourceSnapshot<Section,String>()
snapshot.appendSections([.all])
snapshot.appendItems(restaurantNames, toSection:.all)
//Call the apply() function of the data source to populate the data
dataSource.apply(snapshot, animatingDifferences:false)}func configureDataSource()->UITableViewDiffableDataSource<Section,String>{letcellIdentifier="favoritecell"
//Create a UITableViewDiffableDataSource object to connect with your table andprovide the configuration of the table view cells.
letdataSource=UITableViewDiffableDataSource<Section,String>(
tableView: tableView,
cellProvider:{ tableView, indexPath, restaurantName inletcell= tableView.dequeueReusableCell(withIdentifier: cellIdentifier, for: indexPath)as!RestaurantTableViewCell
cell.nameLabel.text = restaurantName
cell.thumbnailImageView.image =UIImage(named:self.restaurantImages[indexPath.row])
cell.locationLabel.text =self.restaurantLocations[indexPath.row]
cell.typeLabel.text =self.restaurantTypes[indexPath.row]
cell.heartMark.isHidden = !self.restaurantIsFavorites[indexPath.row]
cell.heartMark.tintColor =UITraitCollection.isDarkMode ?.systemYellow :.blue
return cell
})return dataSource
}
overridefunc traitCollectionDidChange(_ previousTraitCollection:UITraitCollection?){
super.traitCollectionDidChange(previousTraitCollection)
// perform action here when user changes the text size
switchself.traitCollection.preferredContentSizeCategory {case.extraExtraLarge,.extraExtraExtraLarge,.accessibilityExtraLarge,.accessibilityExtraExtraLarge,.accessibilityExtraExtraExtraLarge:self.isDynamicLargeType =truecase.extraSmall,.small,.medium,.accessibilityMedium,.large,.extraLarge:self.isDynamicLargeType =falsedefault:self.isDynamicLargeType =false}
// reload view here when user changes the text size and change cell identifier
if previousTraitCollection?.preferredContentSizeCategory != traitCollection.preferredContentSizeCategory {self.dataSource =configureDataSource()self.viewDidLoad()}}
Set Transparent navigation bar
Before
Before
After
After
overridefunc viewDidLoad(){
super.viewDidLoad()
navigationController?.navigationBar.prefersLargeTitles =true
navigationController?.hidesBarsOnSwipe =trueif #available(iOS 14.0,*){
navigationItem.backButtonDisplayMode =.minimal
}else{
navigationItem.backButtonTitle =""}
// To customize the navigation bar, you first need to retrieve the currentUINavigationBarAppearance object
// The standardAppearance property contains thecurrent appearance settings for the standard size navigation bar
iflet appearance = navigationController?.navigationBar.standardAppearance {
appearance.configureWithTransparentBackground()iflet customFont =UIFont(name:"Nunito-Bold", size:40.0){
appearance.titleTextAttributes =[.foregroundColor:UIColor(named:"NavigationBarTitle")!,.font: customFont]
appearance.largeTitleTextAttributes =[.foregroundColor:UIColor(named:"NavigationBarTitle")!,.font: customFont]}
navigationController?.navigationBar.standardAppearance = appearance
navigationController?.navigationBar.compactAppearance = appearance
navigationController?.navigationBar.scrollEdgeAppearance = appearance
}func application(_ application:UIApplication, didFinishLaunchingWithOptions launchOptions:[UIApplication.LaunchOptionsKey:Any]?)->Bool{letnavBarAppearence=UINavigationBarAppearance()varbackButtonImage=UIImage(systemName:"arrow.backword", withConfiguration:UIImage.SymbolConfiguration(pointSize:20.0, weight:.bold))
backButtonImage = backButtonImage?.withAlignmentRectInsets(UIEdgeInsets(top:0, left:-10, bottom:0, right:0))UINavigationBar.appearance().tintColor =.white
UINavigationBar.appearance().standardAppearance = navBarAppearence
UINavigationBar.appearance().compactAppearance = navBarAppearence
UINavigationBar.appearance().scrollEdgeAppearance = navBarAppearence
returntrue}
To prevent content from becoming overly wide for iPad