CNTimelineCell
data:image/s3,"s3://crabby-images/7d85a/7d85a658f48d8c49be98b3c39f8b1320a41fc601" alt="License: MIT"
CNTimelineCell is a helpful framework to generate a timeline with UITableView.
Sample screenshot:
data:image/s3,"s3://crabby-images/f395b/f395b4eced5d4e4a0da2b92bb8f55297c162df78" alt="withStyles"
Requirements
Installation
Swift Package Manager
The Swift Package Manager is a tool for automating the distribution of Swift code and is integrated into the swift
compiler.
Once you have your Swift package set up, adding CNTimelineCell as a dependency is as easy as adding it to the dependencies
value of your Package.swift
.
dependencies: [
.package(url: "https://github.com/chrisnyw/CNTimelineCell", from: "0.3")
]
How to use
- Import CNTimelineCell
Import CNTimelineCell
when you need.
import CNTimelineCell
Prepare your [CNTimelineCellItem]
, for examples:
let dataItem: [CNTimelineCellItem] = [CNTimelineCellItem(title: "Sample", content: "Sample for LeftTimeline\nlineType = .none", leftType: .none),
CNTimelineCellItem(title: "Start", content: "lineType = .start", image: UIImage(named: "star"), leftType: .start),
CNTimelineCellItem(title: "Spot", content: "lineType = .spot", leftType: .spot),
CNTimelineCellItem(title: "Line", content: "lineType = .line", image: UIImage(named: "moon"), leftType: .line),
CNTimelineCellItem(title: "End", content: "lineType = .end", image: UIImage(named: "school"), leftType: .end),]
Register TableViewCell as below:
let timelineTableViewCellNib = UINib(nibName: CNTimelineCell.identifier, bundle: CNTimelineCell.bundle)
self.tableView.register(timelineTableViewCellNib, forCellReuseIdentifier: CNTimelineCell.identifier)
Render your cell:
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: CNTimelineCell.identifier, for: indexPath) as! CNTimelineCell
let timelineItem = dataItem[indexPath.row]
cell.setCell(item: timelineItem)
// or set pass your custom CNTimelineCellStyle:
// cell.setCell(item: timelineItem, style: timelineStyle)
return cell
}
With the configuration above, you will have the result like this:
data:image/s3,"s3://crabby-images/b5250/b525001cd923cd64e99154fd9637f30c6de7bdc1" alt="sampleBasic"
Configuration
CNTimelineCellItem
var title: String
message title
var content: String?
message content
var image: UIImage?
image icon
var leftType: TimelineType
left TimelineType (default: .none
)
var rightType: TimelineType
right TimelineType (default: .none
)
Sample CNTimelineCellItem:
let dataItem: [CNTimelineCellItem] = [CNTimelineCellItem(title: "Good morning", content: "Today is sunny day!", image: UIImage(named: "light")),
CNTimelineCellItem(title: "08:00 am", content: "Tom wakes up", image: UIImage(named: "star"), leftType: .start),
CNTimelineCellItem(title: "08:05 am", content: "Breakfast time", leftType: .spot),
CNTimelineCellItem(title: "08:30 am", content: "Mary wakes up", image: UIImage(named: "star"), leftType: .line, rightType: .start),
CNTimelineCellItem(title: "09:00 am", content: "School time", image: UIImage(named: "school"), leftType: .spot, rightType: .spot),
CNTimelineCellItem(title: "09:00 am - 12:00pm", content: "Many lessons\nMath\nEnglish\netc...", leftType: .line, rightType: .line),
CNTimelineCellItem(title: "12:05 pm", content: "Lunch together", image: UIImage(named: "restaurant"), leftType: .spot, rightType: .spot),
CNTimelineCellItem(title: "01:00 pm", content: "Outdoor activities, play games in sports court.", image: UIImage(named: "sports_basketball"), leftType: .spot, rightType: .spot),
CNTimelineCellItem(title: "until 03:00 pm", content: "Afternoon lesson", leftType: .line, rightType: .line),
CNTimelineCellItem(title: "03:00 pm", content: "Free time", leftType: .spot, rightType: .spot),
CNTimelineCellItem(title: "03:30 pm", content: "Art lesson", leftType: .line, rightType: .spot),
CNTimelineCellItem(title: "03:15 pm", content: "Take a nap", leftType: .end, rightType: .line),
CNTimelineCellItem(title: "04:00 pm", content: "Play in playground", leftType: .none, rightType: .spot),
CNTimelineCellItem(title: "04:15 pm", content: "Wake up from nap", leftType: .start, rightType: .line),
CNTimelineCellItem(title: "05:00 pm", content: "Play TV games", leftType: .spot, rightType: .line),
CNTimelineCellItem(title: "07:00 pm", content: "Dinner", image: UIImage(named: "restaurant"), leftType: .line, rightType: .spot),
CNTimelineCellItem(title: "08:00 pm", content: "Dinner", image: UIImage(named: "restaurant"), leftType: .spot, rightType: .line),
CNTimelineCellItem(title: "10:00 pm", content: "Goto sleep", image: UIImage(named: "bed"), leftType: .line, rightType: .end),
CNTimelineCellItem(title: "10:30 pm", content: "Goto sleep", image: UIImage(named: "single_bed"), leftType: .end, rightType: .none),
CNTimelineCellItem(title: "Awesome", content: "That's all for the day", image: UIImage(named: "auto_awesome")),]
Update style and item in cellForRowAtIndexPath
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: CNTimelineCell.identifier, for: indexPath) as! CNTimelineCell
let timelineItem = dataItem[indexPath.row]
//// // sample for change border color
if indexPath.row == dataItem.count-1 || indexPath.row == 0 {
timelineStyle.bubbleStyle.borderColor = .orange
} else {
timelineStyle.bubbleStyle.borderColor = .init(red: 0/255, green: 147/255, blue: 51/255, alpha: 1)
}
//
//// // sample for change backgroundColor of bubbleView
if indexPath.row == 3 {
timelineStyle.bubbleStyle.backgroundColor = .lightGray
timelineStyle.messageSeparator = .orange
} else {
timelineStyle.bubbleStyle.backgroundColor = .clear
timelineStyle.messageSeparator = .lightGray
}
cell.setCell(item: timelineItem, style: timelineStyle)
return cell
}
Output:
data:image/s3,"s3://crabby-images/f395b/f395b4eced5d4e4a0da2b92bb8f55297c162df78" alt="SampleOutput"
Styling
LineType
There are five line types in TimelineType: start
, end
, spot
, line
and none
LineType |
.start |
.spot |
.line |
.end |
.none |
LineType style |
data:image/s3,"s3://crabby-images/b9f97/b9f972bcbad42589d3f90ba47e926573bf66a0a6" alt="" |
data:image/s3,"s3://crabby-images/2959c/2959c1c055cfade94cf08640f651ea6dceabebc4" alt="" |
data:image/s3,"s3://crabby-images/2cc29/2cc2940691c2cd6f6ca9982a1add003b534d3958" alt="" |
data:image/s3,"s3://crabby-images/fc6f8/fc6f8bd8aefdc174cc68954bae8da815e8a31a28" alt="" |
data:image/s3,"s3://crabby-images/83e3e/83e3e86c1b037b697eed16d4d6b70ec92d661f4c" alt="" |
LineStyle
Line style can be configured by LineStyle struct.
var lineWidth: CGFloat
width of the central line (default: 6.0
)
var spotDiameter: CGFloat
diameter of circle spot (default: 20.0
)
var spotColor: UIColor
color of central circle spot (default .white
)
var lineColor: UIColor
color of line (default RGB(0, 144, 182)
)
var spotOffsetY: CGFloat
vertical offset of spot (default: 29.0
)
LineStyle |
default |
lineWidth = 10 |
spotDiameter = 12 |
spotColor = .orange |
lineColor = .magenta |
.spotOffsetY = 50 |
Output |
data:image/s3,"s3://crabby-images/b9f97/b9f972bcbad42589d3f90ba47e926573bf66a0a6" alt="" |
data:image/s3,"s3://crabby-images/c2fee/c2feed3d850e30b42785d27ade57637a4bbabb8f" alt="" |
data:image/s3,"s3://crabby-images/d1832/d18322b187307c4d510bd28e2da5f5bf7678d073" alt="" |
data:image/s3,"s3://crabby-images/d218d/d218d3285aa24885d5eaaf4261781227c345c1b6" alt="" |
data:image/s3,"s3://crabby-images/a0575/a0575f514371b2b397cdf40da0c055a6231239f9" alt="" |
data:image/s3,"s3://crabby-images/2da78/2da787e61a7f6082fa4b7de35529de70bb0cbfef" alt="" |
BubbleStyle
Set the dialog style using BubbleStyle object
var arrowOffsetY: CGFloat
vertical offset of arrow (default: 30.0
)
var borderWidth: CGFloat
width of border (default: 2.0
)
var borderColor: UIColor
color of border (default: RBC(0, 147, 51)
)
public var backgroundColor: UIColor
button background color (default .clear
)
BubbleStyle |
Output |
default |
data:image/s3,"s3://crabby-images/e5358/e53586db71c05310b6f34cd8c83ab68bba333b96" alt="" |
borderWidth = 8.0 |
data:image/s3,"s3://crabby-images/3b6f0/3b6f024785064ecf743a1c181c73468097a4c7c5" alt="" |
borderColor = .orange |
data:image/s3,"s3://crabby-images/5f937/5f937cb50d8513c7e7c2b088b86debe61e81d2f5" alt="" |
backgroundColor = .systemGray6 |
data:image/s3,"s3://crabby-images/c5982/c59821e09840723465e65b4997324c16f7bbfcb3" alt="" |
arrowOffsetY = 50.0 |
data:image/s3,"s3://crabby-images/97892/978925e99f28ea64ae5770a581e53fe4d4d569f5" alt="" |
CNTimelineCellStyle
Pass the LineStyle and BubbleStyle to CNTimelineCellStyle object to configure CNTimelineCell
var leftLineStyle: LineStyle
left Timeline style (default: LineStyle()
)
var rightLineStyle: LineStyle
right Timeline style (default: LineStyle()
)
var bubbleStyle: BubbleStyle
bubble message style (default: BubbleStyle()
)
var messageSeparator: UIColor
color of separator line in message (default: .lightGray
)
Author
Chris Ng (chrisnyw@gmail.com)
License
CNTimelineCell is available under the MIT license. See the LICENSE file for more info.
CNTimelineCell
Sample screenshot:data:image/s3,"s3://crabby-images/f395b/f395b4eced5d4e4a0da2b92bb8f55297c162df78" alt="withStyles"
Requirements
Installation
Swift Package Manager
The Swift Package Manager is a tool for automating the distribution of Swift code and is integrated into the
swift
compiler.Once you have your Swift package set up, adding CNTimelineCell as a dependency is as easy as adding it to the
dependencies
value of yourPackage.swift
.How to use
- Import CNTimelineCell
Import
CNTimelineCell
when you need.Prepare your
[CNTimelineCellItem]
, for examples:Register TableViewCell as below:
Render your cell:
With the configuration above, you will have the result like this:data:image/s3,"s3://crabby-images/b5250/b525001cd923cd64e99154fd9637f30c6de7bdc1" alt="sampleBasic"
Configuration
CNTimelineCellItem
var title: String
message titlevar content: String?
message contentvar image: UIImage?
image iconvar leftType: TimelineType
left TimelineType (default:.none
)var rightType: TimelineType
right TimelineType (default:.none
)Sample CNTimelineCellItem:
Update style and item in cellForRowAtIndexPath
Output:
Styling
LineType
There are five line types in TimelineType:
start
,end
,spot
,line
andnone
LineStyle
Line style can be configured by LineStyle struct.
var lineWidth: CGFloat
width of the central line (default:6.0
)var spotDiameter: CGFloat
diameter of circle spot (default:20.0
)var spotColor: UIColor
color of central circle spot (default.white
)var lineColor: UIColor
color of line (defaultRGB(0, 144, 182)
)var spotOffsetY: CGFloat
vertical offset of spot (default:29.0
)BubbleStyle
Set the dialog style using BubbleStyle object
var arrowOffsetY: CGFloat
vertical offset of arrow (default:30.0
)var borderWidth: CGFloat
width of border (default:2.0
)var borderColor: UIColor
color of border (default:RBC(0, 147, 51)
)public var backgroundColor: UIColor
button background color (default.clear
)CNTimelineCellStyle
Pass the LineStyle and BubbleStyle to CNTimelineCellStyle object to configure CNTimelineCell
var leftLineStyle: LineStyle
left Timeline style (default:LineStyle()
)var rightLineStyle: LineStyle
right Timeline style (default:LineStyle()
)var bubbleStyle: BubbleStyle
bubble message style (default:BubbleStyle()
)var messageSeparator: UIColor
color of separator line in message (default:.lightGray
)Author
Chris Ng (chrisnyw@gmail.com)
License
CNTimelineCell is available under the MIT license. See the LICENSE file for more info.