// Copyright (c) 2014-present, Facebook, Inc. All rights reserved.
|
//
|
// You are hereby granted a non-exclusive, worldwide, royalty-free license to use,
|
// copy, modify, and distribute this software in source code or binary form for use
|
// in connection with the web services and APIs provided by Facebook.
|
//
|
// As with any software that integrates with the Facebook platform, your use of
|
// this software is subject to the Facebook Developer Principles and Policies
|
// [http://developers.facebook.com/policy/]. This copyright notice shall be
|
// included in all copies or substantial portions of the software.
|
//
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
#import <Photos/Photos.h>
|
#import <UIKit/UIKit.h>
|
|
#import "FBSDKCoreKitImport.h"
|
#import "FBSDKShareMediaContent.h"
|
#import "FBSDKSharingValidation.h"
|
NS_ASSUME_NONNULL_BEGIN
|
|
@class FBSDKSharePhoto;
|
@class PHAsset;
|
|
/**
|
A video for sharing.
|
*/
|
NS_SWIFT_NAME(ShareVideo)
|
@interface FBSDKShareVideo : NSObject <NSSecureCoding, FBSDKCopying, FBSDKShareMedia, FBSDKSharingValidation>
|
|
/**
|
Convenience method to build a new video object from raw data.
|
- Parameter data: The NSData object that holds the raw video data.
|
*/
|
+ (instancetype)videoWithData:(NSData *)data;
|
|
/**
|
Convenience method to build a new video object with NSData and a previewPhoto.
|
- Parameter data: The NSData object that holds the raw video data.
|
- Parameter previewPhoto: The photo that represents the video.
|
*/
|
+ (instancetype)videoWithData:(NSData *)data previewPhoto:(FBSDKSharePhoto *)previewPhoto;
|
|
/**
|
Convenience method to build a new video object with a PHAsset.
|
@param videoAsset The PHAsset that represents the video in the Photos library.
|
*/
|
+ (instancetype)videoWithVideoAsset:(PHAsset *)videoAsset;
|
|
/**
|
Convenience method to build a new video object with a PHAsset and a previewPhoto.
|
@param videoAsset The PHAsset that represents the video in the Photos library.
|
@param previewPhoto The photo that represents the video.
|
*/
|
+ (instancetype)videoWithVideoAsset:(PHAsset *)videoAsset previewPhoto:(FBSDKSharePhoto *)previewPhoto;
|
|
/**
|
Convenience method to build a new video object with a videoURL.
|
@param videoURL The URL to the video.
|
*/
|
+ (instancetype)videoWithVideoURL:(NSURL *)videoURL;
|
|
/**
|
Convenience method to build a new video object with a videoURL and a previewPhoto.
|
@param videoURL The URL to the video.
|
@param previewPhoto The photo that represents the video.
|
*/
|
+ (instancetype)videoWithVideoURL:(NSURL *)videoURL previewPhoto:(FBSDKSharePhoto *)previewPhoto;
|
|
/**
|
The raw video data.
|
- Returns: The video data.
|
*/
|
@property (nonatomic, strong, nullable) NSData *data;
|
|
/**
|
The representation of the video in the Photos library.
|
@return PHAsset that represents the video in the Photos library.
|
*/
|
@property (nonatomic, copy, nullable) PHAsset *videoAsset;
|
|
/**
|
The file URL to the video.
|
@return URL that points to the location of the video on disk
|
*/
|
@property (nonatomic, copy, nullable) NSURL *videoURL;
|
|
/**
|
The photo that represents the video.
|
@return The photo
|
*/
|
@property (nonatomic, copy, nullable) FBSDKSharePhoto *previewPhoto;
|
|
/**
|
Compares the receiver to another video.
|
@param video The other video
|
@return YES if the receiver's values are equal to the other video's values; otherwise NO
|
*/
|
- (BOOL)isEqualToShareVideo:(FBSDKShareVideo *)video;
|
|
@end
|
|
@interface PHAsset (FBSDKShareVideo)
|
|
@property (nonatomic, copy, readonly) NSURL *videoURL;
|
|
@end
|
|
NS_ASSUME_NONNULL_END
|