Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mentionapp/mntpulltoreact
One gesture, many actions. An evolution of Pull to Refresh.
https://github.com/mentionapp/mntpulltoreact
Last synced: about 1 month ago
JSON representation
One gesture, many actions. An evolution of Pull to Refresh.
- Host: GitHub
- URL: https://github.com/mentionapp/mntpulltoreact
- Owner: mentionapp
- License: apache-2.0
- Created: 2014-05-26T16:06:29.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2015-04-29T13:28:24.000Z (over 9 years ago)
- Last Synced: 2024-11-24T20:02:20.754Z (about 2 months ago)
- Language: Objective-C
- Homepage:
- Size: 896 KB
- Stars: 767
- Watchers: 39
- Forks: 59
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ios - mntpulltoreact - One gesture, many actions. An evolution of Pull to Refresh. (UI / Pull to Refresh)
- awesome-cocoa - mntpulltoreact
- awesome-ios-star - mntpulltoreact - One gesture, many actions. An evolution of Pull to Refresh. (UI / Pull to Refresh)
README
MNTPullToReact
==============
MNTPullToReact is an extended evolution of the famous Pull to Refresh interaction. The main idea comes from a unique question: can the natural pulling gesture do more than just refresh and therefore avoid ugly action buttons that take up precious content space?You can bind as many reactions as you'd like to MNTPullToReact and have your user access specific application actions through this unique and well known gesture.
MNTPullToReact is very easy to use and highly customizable.
- [Easy to use](#easy-to-use)
- [Highly customizable](#highly-customizable)If you're using MNTPullToReact in your application, add your application link to the [application list](#applications).
Finally, before the demo, I'd like to thank all of the contributors. If I forget, please add yourself to the [contributors list](#contributors). There will always be something to do or improve, and as such, you can read the [to-do list](#to-do) if you're looking for a specific way to contribute.
-- Guillaume Sempe, Lead Mobile Developer, mention
## Demo
## Easy to use
MNTPullToReact is a subclass of `UIControl` and embraces the common [target-action](https://developer.apple.com/library/ios/documentation/general/conceptual/Devpedia-CocoaApp/TargetAction.html) design pattern widely used in Apple's own controls. It also mimics the Apple `UIRefreshControl` control interface to facilitate its usage by developers already familiar with the Apple Pull to Refresh control.| What | `UIRefreshControl` | `MNTPullToReact` |
| --------------------------- | ----------------------------- | ----------------------------- |
| Property to know the status | `BOOL refreshing` | `NSInteger action` |
| Initiate an action | `beginRefreshing` | `beginAction:` |
| Terminate an action | `endRefreshing` | `endAction:` |
| Event on action needed | `UIControlEventValueChanged ` | `UIControlEventValueChanged ` |### Short code sample
Here is a short code sample that uses the MNTPullToReactDefaultView under the hood. The following code creates a pull to react with 4 actions.``` objective-c
// Import the library header
#import "PullToReact.h"// In the viewDidLoad create the control
MNTPullToReactControl *reactControl = [[MNTPullToReactControl alloc] initWithNumberOfActions:4];
[reactControl addTarget:self action:@selector(reaction:) forControlEvents:UIControlEventValueChanged];
self.tableView.reactControl = reactControl;// Than create the target-action method
- (void)reaction:(id)sender
{
// Do the reaction thing
[reactControl endAction:reactControl.action];
}
```### Step by step usage
+ Add it to your projectIf you use [CocoaPods](http://cocoapods.org/), add this line to your `Podfile`:
``` ruby
pod 'MNTPullToReact', '~> 1.0'
```
If you don't use CocoaPods, then add all of the required files to your project and set the needed settings according to the [podspec](https://github.com/mentionapp/mntpulltoreact/blob/master/MNTPullToReact.podspec) of the library.
Please note: do not forget to add -ObjC to the other linker flags.
```
OTHER_LDFLAGS -ObjC
```+ In your view controller or your subclass, import the library header.
``` objective-c
#import "PullToReact.h"
```+ Set the new `reactControl` property of the `UITableView` class to the Pull to React you want to use.
``` objective-c
MNTPullToReactControl *reactControl = [[MNTPullToReactControl alloc] initWithNumberOfActions:4];
[reactControl addTarget:_delegateAndDataSource action:@selector(reaction:) forControlEvents:UIControlEventValueChanged];
self.reactControl = reactControl;
```
+ Add the target class to the action method implementation.
``` objective-c
#pragma mark - Pull to react target-action method
- (void)reaction:(id)sender
{
MNTPullToReactControl *reactControl = (MNTPullToReactControl *)sender;
NSLog(@"Doing action %ld", (long)reactControl.action);
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_BACKGROUND, 0), ^{
usleep(1100 * 1000);
dispatch_async(dispatch_get_main_queue(), ^{
[reactControl endAction:reactControl.action];
});
});
}
```
Once your asynchronous task has terminated, do not forget to call the `endAction:` method to inform the Pull to React control.## Highly customizable
You can customize your own Pull to React features without any limits by subclassing the MNTPullToReactView class.
To see how to make amazing Pull to React designs, you can go through the [examples](https://github.com/mentionapp/mntpulltoreact/tree/master/ExampleCustomContent) provided in the library.
## To-do
- Improve and finish the documentation to get it added to http://cocoadocs.org/.
- Extended the library to be able to have a Pull to React control above a `UIWebView`.
- Add the ability to put Pull to React controls on other sides of the targeted view (on the left, on the right, and at the bottom).## Applications
If you're using MNTPullToReact in your application, add your App Store link to the list here.## Contributors
- [Julie Chabin](https://github.com/syswarren)
- [Alex Manthei](https://github.com/amanthei)