Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/shaps80/imessagestylereveal
Adds iMessage style timestamp support. Written in Swift!
https://github.com/shaps80/imessagestylereveal
imessage ios swift timestamp ui uitableview
Last synced: 2 months ago
JSON representation
Adds iMessage style timestamp support. Written in Swift!
- Host: GitHub
- URL: https://github.com/shaps80/imessagestylereveal
- Owner: shaps80
- License: mit
- Created: 2014-04-05T02:42:42.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2019-11-25T13:15:08.000Z (about 5 years ago)
- Last Synced: 2024-09-21T09:02:33.327Z (3 months ago)
- Topics: imessage, ios, swift, timestamp, ui, uitableview
- Language: Swift
- Homepage: http://shaps.me/blog/imessage-style-reveal/
- Size: 776 KB
- Stars: 147
- Watchers: 10
- Forks: 20
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
Purpose
--------------I recently needed to build the iMessage style pull-to-reveal timestamps feature for a personal project and decided to open source the implementation.
Installation
--------------Simply add the following to your Podfile:
Latest release uses Swift 5:
`pod RevealableCell`If you need Swift 2.2:
`pod 'RevealableCell', '1.1'`If you need Swift 3.0:
`pod 'RevealableCell', '2.0'`---
Then add the following import at the top of your source file(s):
Swift
`import RevealableCell`
Obj-C
`@import RevealableCell`Usage
-------In order to use RevealableCell in your application, follow the steps below:
1. Your cell must be a subclass of RevealableTableViewCell
2. You must register a nib or a RevealableView subclass using:`tableView.registerNib(nib, forRevealableViewReuseIdentifier: "identifier")` or
`tableView.registerClass(revealableViewClass, forRevealableViewReuseIdentifier: "identifier")`
3. In `cellForRowAtIndexPath` you can dequeue and configure an instance using:```swift
if let view = tableView.dequeueReusableRevealableViewWithIdentifier("identifier") as? MyRevealableView {
view.titleLabel.text = "" // configure
cell.setRevealableView(view, style: .Slide, direction: .Left)
}
```
This new implementation, provides reusable views of the same type as well as allowing you to have
different styles or directions for individual cells.
Run this project, to see a demo similar to the iMessage app on your iOS device.Additional Info
-------RevealableViews also support AutoLayout now, so if you've setup your constraints correctly, the views will auto-size their widths (per cell) for you. However, you can also specify a fixed width for each cell using
`cell.revealableView.width = 100`
Note: The height will always be the same as the cell and the position is based on the `.style` of the `RevealableView`
Feel free to use in any way you see fit. Please try and reference me somewhere in your app if you use this in a production app and maybe even tell me about it via Twitter [@shaps](http://twitter.com/shaps) ;)
![Screenshot](http://shaps.me/assets/img/blog/iMessageStyleReveal.jpg)
Supported OS & SDK Versions
-----------------------------* Supported build target - iOS 8.0
* Earliest supported deployment target - iOS 8.0