2019-11-09 00:16:09 +01:00
//
// T i m e l i n e P r e v i e w T a b l e V i e w C o n t r o l l e r . s w i f t
// N e t N e w s W i r e - i O S
//
// C r e a t e d b y M a u r i c e P a r k e r o n 1 1 / 8 / 1 9 .
// C o p y r i g h t © 2 0 1 9 R a n c h e r o S o f t w a r e . A l l r i g h t s r e s e r v e d .
//
import UIKit
import Articles
class TimelinePreviewTableViewController : UIViewController , UITableViewDelegate , UITableViewDataSource {
@IBOutlet weak var tableView : UITableView !
override func viewDidLoad ( ) {
super . viewDidLoad ( )
tableView . delegate = self
tableView . dataSource = self
}
func heightFor ( width : CGFloat ) -> CGFloat {
if UIApplication . shared . preferredContentSizeCategory . isAccessibilityCategory {
let layout = MasterTimelineAccessibilityCellLayout ( width : width , insets : tableView . safeAreaInsets , cellData : prototypeCellData )
return layout . height
} else {
let layout = MasterTimelineDefaultCellLayout ( width : width , insets : tableView . safeAreaInsets , cellData : prototypeCellData )
return layout . height
}
}
// MARK: - T a b l e v i e w d a t a s o u r c e
func numberOfSections ( in tableView : UITableView ) -> Int {
return 1
}
func tableView ( _ tableView : UITableView , numberOfRowsInSection section : Int ) -> Int {
return 1
}
func tableView ( _ tableView : UITableView , cellForRowAt indexPath : IndexPath ) -> UITableViewCell {
let cell = tableView . dequeueReusableCell ( withIdentifier : " Cell " , for : indexPath ) as ! MasterTimelineTableViewCell
cell . cellData = prototypeCellData
return cell
}
func tableView ( _ tableView : UITableView , didSelectRowAt indexPath : IndexPath ) {
tableView . selectRow ( at : nil , animated : true , scrollPosition : . none )
}
// MARK: A P I
func reload ( ) {
tableView . reloadData ( )
}
}
// MARK: P r i v a t e
private extension TimelinePreviewTableViewController {
var prototypeCellData : MasterTimelineCellData {
let longTitle = " Enim ut tellus elementum sagittis vitae et. Nibh praesent tristique magna sit amet purus gravida quis blandit. Neque volutpat ac tincidunt vitae semper quis lectus nulla. Massa id neque aliquam vestibulum morbi blandit. Ultrices vitae auctor eu augue. Enim eu turpis egestas pretium aenean pharetra magna. Eget gravida cum sociis natoque. Sit amet consectetur adipiscing elit. Auctor eu augue ut lectus arcu bibendum. Maecenas volutpat blandit aliquam etiam erat velit. Ut pharetra sit amet aliquam id diam maecenas ultricies. In hac habitasse platea dictumst quisque sagittis purus sit amet. "
let prototypeID = " prototype "
2020-04-13 02:12:36 +02:00
let status = ArticleStatus ( articleID : prototypeID , read : false , starred : false , dateArrived : Date ( ) )
2024-11-02 19:08:58 +01:00
let prototypeArticle = Article ( accountID : prototypeID , articleID : prototypeID , feedID : prototypeID , uniqueID : prototypeID , title : longTitle , contentHTML : nil , contentText : nil , url : nil , externalURL : nil , summary : nil , imageURL : nil , datePublished : nil , dateModified : nil , authors : nil , status : status )
2019-11-09 00:16:09 +01:00
let iconImage = IconImage ( AppAssets . faviconTemplateImage . withTintColor ( AppAssets . secondaryAccentColor ) )
2020-07-02 04:47:45 +02:00
return MasterTimelineCellData ( article : prototypeArticle , showFeedName : . feed , feedName : " Feed Name " , byline : nil , iconImage : iconImage , showIcon : true , featuredImage : nil , numberOfLines : AppDefaults . shared . timelineNumberOfLines , iconSize : AppDefaults . shared . timelineIconSize )
2019-11-09 00:16:09 +01:00
}
}