FLEXArgumentInputView.h 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. //
  2. // FLEXArgumentInputView.h
  3. // Flipboard
  4. //
  5. // Created by Ryan Olson on 5/30/14.
  6. // Copyright (c) 2020 FLEX Team. All rights reserved.
  7. //
  8. #import <UIKit/UIKit.h>
  9. typedef NS_ENUM(NSUInteger, FLEXArgumentInputViewSize) {
  10. /// 2 lines, medium-sized
  11. FLEXArgumentInputViewSizeDefault = 0,
  12. /// One line
  13. FLEXArgumentInputViewSizeSmall,
  14. /// Several lines
  15. FLEXArgumentInputViewSizeLarge
  16. };
  17. @protocol FLEXArgumentInputViewDelegate;
  18. @interface FLEXArgumentInputView : UIView
  19. - (instancetype)initWithArgumentTypeEncoding:(const char *)typeEncoding;
  20. /// The name of the field. Optional (can be nil).
  21. @property (nonatomic, copy) NSString *title;
  22. /// To populate the filed with an initial value, set this property.
  23. /// To reteive the value input by the user, access the property.
  24. /// Primitive types and structs should/will be boxed in NSValue containers.
  25. /// Concrete subclasses should override both the setter and getter for this property.
  26. /// Subclasses can call super.inputValue to access a backing store for the value.
  27. @property (nonatomic) id inputValue;
  28. /// Setting this value to large will make some argument input views increase the size of their input field(s).
  29. /// Useful to increase the use of space if there is only one input view on screen (i.e. for property and ivar editing).
  30. @property (nonatomic) FLEXArgumentInputViewSize targetSize;
  31. /// Users of the input view can get delegate callbacks for incremental changes in user input.
  32. @property (nonatomic, weak) id <FLEXArgumentInputViewDelegate> delegate;
  33. // Subclasses can override
  34. /// If the input view has one or more text views, returns YES when one of them is focused.
  35. @property (nonatomic, readonly) BOOL inputViewIsFirstResponder;
  36. /// For subclasses to indicate that they can handle editing a field the give type and value.
  37. /// Used by FLEXArgumentInputViewFactory to create appropriate input views.
  38. + (BOOL)supportsObjCType:(const char *)type withCurrentValue:(id)value;
  39. // For subclass eyes only
  40. @property (nonatomic, readonly) UILabel *titleLabel;
  41. @property (nonatomic, readonly) NSString *typeEncoding;
  42. @property (nonatomic, readonly) CGFloat topInputFieldVerticalLayoutGuide;
  43. @end
  44. @protocol FLEXArgumentInputViewDelegate <NSObject>
  45. - (void)argumentInputViewValueDidChange:(FLEXArgumentInputView *)argumentInputView;
  46. @end