https://github.com/pircate/easyrefresher
The refresh control associated with the scroll view.
https://github.com/pircate/easyrefresher
refresh swift
Last synced: 10 months ago
JSON representation
The refresh control associated with the scroll view.
- Host: GitHub
- URL: https://github.com/pircate/easyrefresher
- Owner: Pircate
- License: mit
- Created: 2019-05-07T07:13:09.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2021-01-27T03:09:41.000Z (about 5 years ago)
- Last Synced: 2025-05-07T01:05:08.034Z (10 months ago)
- Topics: refresh, swift
- Language: Swift
- Homepage:
- Size: 10.7 MB
- Stars: 16
- Watchers: 1
- Forks: 4
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# EasyRefresher
[](https://travis-ci.org/Pircate/EasyRefresher)
[](https://cocoapods.org/pods/EasyRefresher)
[](https://cocoapods.org/pods/EasyRefresher)
[](https://cocoapods.org/pods/EasyRefresher)
## Example
To run the example project, clone the repo, and run `pod install` from the Example directory first.
## Requirements
* iOS 10.0
* Swift 5.0
## Installation
EasyRefresher is available through [CocoaPods](https://cocoapods.org). To install
it, simply add the following line to your Podfile:
```ruby
pod 'EasyRefresher'
```
## Preview


## Usage
* Add Refresher
```swift
tableView.refresh.header.addRefreshClosure {
self.reqeust {
self.tableView.refresh.header.endRefreshing()
}
}
tableView.refresh.footer = AutoRefreshFooter(triggerMode: .percent(0.5)) {
self.reqeust {
self.tableView.refresh.footer.endRefreshing()
}
}
tableView.refresh.header = RefreshHeader(delegate: self)
```
* Manual Trigger
```swift
tableView.refresh.header.beginRefreshing()
```
* State Title
```swift
tableView.refresh.header.setTitle("loading...", for: .refreshing)
tableView.refresh.footer.setAttributedTitle(
NSAttributedString(string: "已到最后一页", attributes: [.foregroundColor: UIColor.red]), for: .disabled
)
```
* Last updated time
```swift
tableView.refresh.header.lastUpdatedTimeText = { date in
guard let date = date else { return "暂无更新记录" }
return "上次刷新时间:\(date)"
}
```
* UIActivityIndicatorView Style
```swift
tableView.refresh.header.activityIndicatorStyle = .white
```
* Disabled
```swift
// End refreshing and set state to disabled
tableView.refresh.footer.isEnabled = false
```
* Remove
```swift
tableView.refresh.footer.removeFromScrollView()
```
* Impact feedback
```swift
tableView.refresh.header.impactFeedbackMode = .on(style: .medium)
```
* Custom State View
```swift
extension CustomStateView: RefreshStateful {
public func refresher(_ refresher: Refresher, didChangeState state: RefreshState) {
}
public func refresher(_ refresher: Refresher, didChangeOffset offset: CGFloat) {
}
}
tableView.refresh.footer = AppearanceRefreshFooter(stateView: CustomStateView()) {
self.reqeust {
self.tableView.refresh.footer.endRefreshing()
}
}
```
## Author
Pircate, swifter.dev@gmail.com
## License
EasyRefresher is available under the MIT license. See the LICENSE file for more info.