From 90d2720b046a508a09f5e7fa6c48b5b6a2af0490 Mon Sep 17 00:00:00 2001 From: Jared Sinclair Date: Sun, 23 Mar 2014 13:02:47 -0400 Subject: [PATCH 1/2] Update README.md --- README.md | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/README.md b/README.md index c4fc1e3..6290afa 100644 --- a/README.md +++ b/README.md @@ -12,6 +12,7 @@ - [Why OvershareKit?](#why-oversharekit) - [Screenshot](#screenshot) - [How to Use OvershareKit](#how-to-use-oversharekit) +- [OvershareKit Versus UIActivityViewController](#oversharekit-versus-uiactivityviewcontroller) - [Architecture](#architecture) - [Authentication](#authentication) - [Application-Specific Credentials](#application-specific-credentials) @@ -61,6 +62,25 @@ After including OvershareKit in your Xcode project (see the detailed requirement 3) There is no step 3. +## OvershareKit Versus UIActivityViewController + +We are frequently asked why someone would use OvershareKit instead of `UIActivityViewController` (UIAVC) and `UIActivity`. UIAVC is great for apps that know they’ll never have a need for any of the following: + +1. Never need to integrate with more than one or two third party services. +2. Never need to tweak the UI for the activity sheet and sharing screens. +3. Never care to provide separate, media-specific content for each sharing type (email versus SMS, etc.) +4. Never need to have multiple items such as a Copy Text versus a Copy Link in the same sheet. +5. Don't mind that all non-system-provided activities get stuck with boring monochromatic icons. + +Many apps can't fit comfortably within those restrictions, which is why we made OvershareKit. + +The most important difference between UIAVC and OvershareKit is in how content is structured. UIAVC uses unstructured arrays of content (which contain one or more of a grab-bag of objects, usually strings, images and URLs). UIAVC lets each UIActivity decide which of these objects, if any, it will act upon and how. The shortcoming of this API design is that activities don't know anything about the context in which a sharing session is taking place. For example, the formatting for an email message generated from an Instagram post should look very different from an email generated from an RSS article. But with UIAVC, there's no easy way to communicate that context. Most crucially, it is impossible to do this using UIAVC without providing substitutes for the system-provided mail activities. + +Activities should not be given that much responsibility over content. The content should be ready to consume *before* it is handed to an activity. Furthermore, the content should be formatted in a manner that is appropriate to each type of activity. + +This is why OvershareKit uses an instance of `OSKShareableContent` that bristles with many flavors of `OSKShareableContentItem`. This API design allows the part of your app that has knowledge of context to prepare all the various types of `OSKShareableContentItems` before handing it off to an OvershareKit sharing session. This results in a more satisfying sharing experience for the user, and less overall hassle for the developer. + + ## Architecture OvershareKit has lots of classes, but here are the main players: From 6431ad4fc3190a4d8088cc6a19a39b7e7a10ea44 Mon Sep 17 00:00:00 2001 From: Jared Sinclair Date: Sun, 23 Mar 2014 13:05:35 -0400 Subject: [PATCH 2/2] Update README.md --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 6290afa..a300b54 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,4 @@ -# OvershareKit +OvershareKit ============ #### A soup-to-nuts sharing library for iOS.