I'm using a UIActivityViewController
to display a share sheet so users can share my app. I'm currently testing tweets and i'm getting some unexpected results. On tweeting for the first time, all goes well. On the second time, i'm getting a duplicate tweet error message, which is expected. The problem is that the completionWithItemsHandler
is returning success: Bool
as true
!
I want to be able to display my own personalised message to the user rather than the massive one that is returned currently.
Here is my code:
@IBAction func ShareButtonTapped(sender: AnyObject) { let textToShare = "I'm using Buzz! The new way to send emoji's, with sound, it's annoying, funny and amazing" var url = NSURL(string: "-Image url masked out-") var data = NSData(contentsOfURL: url!) let image = UIImage(data: data!) if let myWebsite = NSURL(string: "-redirect masked out-") { let objectsToShare = [textToShare, myWebsite] let activityVC = UIActivityViewController(activityItems: objectsToShare, applicationActivities: nil) activityVC.completionWithItemsHandler = { (activity, success, items, error) in println("Activity: \(activity) Success: \(success) Items: \(items) Error: \(error)") } self.presentViewController(activityVC, animated: true, completion: { () -> Void in }) } }
Here is my log:
2015-01-27 11:10:58.021 Buzz[3239:813859] LaunchServices: invalidationHandler called
2015-01-27 11:10:58.052 Buzz[3239:813860] LaunchServices: invalidationHandler called Activity: com.apple.UIKit.activity.PostToTwitter Success: true Items: nil Error: nil
2015-01-27 11:11:04.134 Buzz[3239:813859] LaunchServices: invalidationHandler called
2015-01-27 11:11:09.182 Buzz[3239:813859] plugin com.apple.share.Twitter.post invalidated
A standard view controller that connects the application to a number of standard services such as social networks, SMS, etc. The UIActivityViewController allows the application user to easily share data between the current application and services. A number of services such as social networks, email, and SMS are provided by the OS.
When overridden, returns the UIViewController that determines whether the status bar is hidden or unhidden. When overridden, returns the UIViewController that determines the style of the status bar. Invoked to determine if this object implements the specified protocol. Performs a copy of the underlying Objective-C object.
With BeginAppearanceTransition (Boolean, Boolean), tells child UIViewController s that their child views have just appeared or disappeared. The array of child UIViewController objects that should be searched to determine if they are the unwind segue destination.
With DecodeRestorableState (NSCoder), allows custom state restoration. With BeginAppearanceTransition (Boolean, Boolean), tells child UIViewController s that their child views have just appeared or disappeared. The array of child UIViewController objects that should be searched to determine if they are the unwind segue destination.
Use completion handler like this For SWIFT 3 AND 4, iOS 10 AND 11 :
activityVC.completionWithItemsHandler = {(activityType: UIActivityType?, completed: Bool, returnedItems: [Any]?, error: Error?) in if !completed { // User canceled return } // User completed activity } self.present(activityVC, animated: true, completion: nil)
SWIFT 2.0 iOS 8.0 >, you should use completion handler like this:
self.presentViewController(activityVC, animated: true, completion: nil) activityVC.completionWithItemsHandler = {(activityType, completed:Bool, returnedItems:[AnyObject]?, error: NSError?) in // Return if cancelled if (!completed) { return } //activity complete //some code here }
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With