Index: ios/chrome/browser/ui/util/label_link_controller.h |
diff --git a/ios/chrome/browser/ui/util/label_link_controller.h b/ios/chrome/browser/ui/util/label_link_controller.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..35e8928017d3f85eb8cc843f42d1673c8711764a |
--- /dev/null |
+++ b/ios/chrome/browser/ui/util/label_link_controller.h |
@@ -0,0 +1,76 @@ |
+// Copyright 2015 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef IOS_CHROME_BROWSER_UI_UTIL_LABEL_LINK_CONTROLLER_H_ |
+#define IOS_CHROME_BROWSER_UI_UTIL_LABEL_LINK_CONTROLLER_H_ |
+ |
+#import <UIKit/UIKit.h> |
+#include "ios/chrome/browser/procedural_block_types.h" |
+ |
+class GURL; |
+ |
+// A LabelLinkController manages a UILabel instance that is to have tappable |
+// substrings ("links"). The controller handles styling the link areas (if |
+// desired), and installs a gesture recognizer on the label that will trigger if |
+// the specified regions are tapped. Multiple regions of the label may be |
+// defined as links, and they may trigger different actions. |
+// Each LabelLinkController calls a single action (a block that takes a GURL |
+// parameter) for all taps; different links are defined by having different |
+// URLs associated with them. |
+// The LabelLinkController observes (via KVO) changes in the label's size, style |
+// and text. If the label's bounds or style change, the controller recomputes |
+// the link areas. If the text changes, all of the defined links for the label |
+// are cleared (since they are presumed to be meaningless). |
+// To prevent spurious recomputation of link areas, it is best to apply any |
+// text manipulations and styling to the label before initializing a |
+// LabelLinkController with it. |
+@interface LabelLinkController : NSObject |
+ |
+// If |showTapAreas| is true in a debug build, the tappable regions of the label |
+// will have colored rectangles around them, with different colors for each URL, |
+// and a darker outline around the exact text that the tappable region is for. |
+// In non-debug builds, setting this property has no effect. |
+@property(nonatomic, assign) BOOL showTapAreas; |
+ |
+// Sets the link color for any defined links, updating the controlled label's |
+// attributed text accordingly. |
+@property(nonatomic, assign) UIColor* linkColor; |
+ |
+// Sets the link underline style for any defined links, updating the controlled |
+// label's attributed text accordingly. |
+@property(nonatomic, assign) NSUnderlineStyle linkUnderlineStyle; |
+ |
+// Sets the link font for any defined links, updating the controlled label's |
+// attributed text accordingly. |
+@property(nonatomic, retain) UIFont* linkFont; |
+ |
+// Creates a new controller for |label|, whose lifetime is expected to exceed |
+// that of the receiver. |action| is the block called for any tapped link. |
+- (instancetype)initWithLabel:(UILabel*)label |
+ action:(ProceduralBlockWithURL)action; |
+ |
+// Adds a link to the controlled label at |range| in the label's text, which |
+// will call the receiver's action block when tapped, passing in |url|. |
+- (void)addLinkWithRange:(NSRange)range url:(GURL)url; |
+ |
+@end |
+ |
+@interface LabelLinkController (Testing) |
+ |
+// Testing interface for LabelLinkController. |
+ |
+// This is the class that will be instantiated to do text mapping; by default |
+// it is CoreTextMapper, but tests can assign to this property to do dependency |
+// injection. |
+@property(nonatomic, assign) Class textMapperClass; |
+// Returns the tap rects generated by the controller that are associated with |
+// |url|. |
+- (NSArray*)tapRectsForURL:(GURL)url; |
+// Simulates a tap in the controlled label at |point|. No touch events are |
+// generated, but |action| should be invoked if |point| is inside a tap rect. |
+- (void)tapLabelAtPoint:(CGPoint)point; |
+ |
+@end |
+ |
+#endif // IOS_CHROME_BROWSER_UI_UTIL_LABEL_LINK_CONTROLLER_H_ |