// 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 <UIKit/UIKit.h>
|
|
/**
|
FBSDKTooltipViewArrowDirection enum
|
|
Passed on construction to determine arrow orientation.
|
*/
|
typedef NS_ENUM(NSUInteger, FBSDKTooltipViewArrowDirection)
|
{
|
/** View is located above given point, arrow is pointing down. */
|
FBSDKTooltipViewArrowDirectionDown = 0,
|
/** View is located below given point, arrow is pointing up. */
|
FBSDKTooltipViewArrowDirectionUp = 1,
|
};
|
|
/**
|
FBSDKTooltipColorStyle enum
|
|
Passed on construction to determine color styling.
|
*/
|
typedef NS_ENUM(NSUInteger, FBSDKTooltipColorStyle)
|
{
|
/** Light blue background, white text, faded blue close button. */
|
FBSDKTooltipColorStyleFriendlyBlue = 0,
|
/** Dark gray background, white text, light gray close button. */
|
FBSDKTooltipColorStyleNeutralGray = 1,
|
};
|
|
/**
|
|
Tooltip bubble with text in it used to display tips for UI elements,
|
with a pointed arrow (to refer to the UI element).
|
|
|
|
The tooltip fades in and will automatically fade out. See `displayDuration`.
|
*/
|
@interface FBSDKTooltipView : UIView
|
|
/**
|
Gets or sets the amount of time in seconds the tooltip should be displayed.
|
Set this to zero to make the display permanent until explicitly dismissed.
|
Defaults to six seconds.
|
*/
|
@property (nonatomic, assign) CFTimeInterval displayDuration;
|
|
/**
|
Gets or sets the color style after initialization.
|
Defaults to value passed to -initWithTagline:message:colorStyle:.
|
*/
|
@property (nonatomic, assign) FBSDKTooltipColorStyle colorStyle;
|
|
/**
|
Gets or sets the message.
|
*/
|
@property (nonatomic, copy) NSString *message;
|
|
/**
|
Gets or sets the optional phrase that comprises the first part of the label (and is highlighted differently).
|
*/
|
@property (nonatomic, copy) NSString *tagline;
|
|
/**
|
Designated initializer.
|
|
@param tagline First part of the label, that will be highlighted with different color. Can be nil.
|
|
@param message Main message to display.
|
|
@param colorStyle Color style to use for tooltip.
|
|
|
|
If you need to show a tooltip for login, consider using the `FBSDKLoginTooltipView` view.
|
|
|
@see FBSDKLoginTooltipView
|
*/
|
- (instancetype)initWithTagline:(NSString *)tagline message:(NSString *)message colorStyle:(FBSDKTooltipColorStyle)colorStyle;
|
|
/**
|
Show tooltip at the top or at the bottom of given view.
|
Tooltip will be added to anchorView.window.rootViewController.view
|
|
@param anchorView view to show at, must be already added to window view hierarchy, in order to decide
|
where tooltip will be shown. (If there's not enough space at the top of the anchorView in window bounds -
|
tooltip will be shown at the bottom of it)
|
|
|
|
Use this method to present the tooltip with automatic positioning or
|
use -presentInView:withArrowPosition:direction: for manual positioning
|
If anchorView is nil or has no window - this method does nothing.
|
*/
|
- (void)presentFromView:(UIView *)anchorView;
|
|
/**
|
Adds tooltip to given view, with given position and arrow direction.
|
|
@param view View to be used as superview.
|
|
@param arrowPosition Point in view's cordinates, where arrow will be pointing
|
|
@param arrowDirection whenever arrow should be pointing up (message bubble is below the arrow) or
|
down (message bubble is above the arrow).
|
*/
|
- (void)presentInView:(UIView *)view withArrowPosition:(CGPoint)arrowPosition direction:(FBSDKTooltipViewArrowDirection)arrowDirection;
|
|
/**
|
Remove tooltip manually.
|
|
|
|
Calling this method isn't necessary - tooltip will dismiss itself automatically after the `displayDuration`.
|
*/
|
- (void)dismiss;
|
|
@end
|