LookinDashboardBlueprint.h 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. //
  2. // LookinDashboardBlueprint.h
  3. // Lookin
  4. //
  5. // Created by Li Kai on 2019/6/5.
  6. // https://lookin.work
  7. //
  8. #import <Foundation/Foundation.h>
  9. #import "LookinAttrIdentifiers.h"
  10. #import "LookinAttrType.h"
  11. /**
  12. 该对象定义了:
  13. - 每一个 Attr 的信息
  14. - 哪些 GroupID, SectionID, AttrID 是合法的
  15. - 这些 ID 的父子顺序,比如 LookinAttrGroup_Frame 包含哪些 Section
  16. - 这些 ID 展示顺序(比如哪个 Group 在前、哪个 Group 在后)
  17. */
  18. @interface LookinDashboardBlueprint : NSObject
  19. + (NSArray<LookinAttrGroupIdentifier> *)groupIDs;
  20. + (NSArray<LookinAttrSectionIdentifier> *)sectionIDsForGroupID:(LookinAttrGroupIdentifier)groupID;
  21. + (NSArray<LookinAttrIdentifier> *)attrIDsForSectionID:(LookinAttrSectionIdentifier)sectionID;
  22. /// 返回包含目标 attr 的 groupID 和 sectionID
  23. + (void)getHostGroupID:(inout LookinAttrGroupIdentifier *)groupID sectionID:(inout LookinAttrSectionIdentifier *)sectionID fromAttrID:(LookinAttrIdentifier)attrID;
  24. /// 返回某个 group 的标题
  25. + (NSString *)groupTitleWithGroupID:(LookinAttrGroupIdentifier)groupID;
  26. /// 返回某个 section 的标题,nil 则表示不显示标题
  27. + (NSString *)sectionTitleWithSectionID:(LookinAttrSectionIdentifier)secID;
  28. /// 当某个 LookinAttribute 确定是 NSObject 类型时,该方法返回它具体是什么对象,比如 UIColor 等
  29. + (LookinAttrType)objectAttrTypeWithAttrID:(LookinAttrIdentifier)attrID;
  30. /// 返回某个 LookinAttribute 代表的属性是哪一个类拥有的,比如 LookinAttrSec_UILabel_TextColor 是 UILabel 才有的
  31. + (NSString *)classNameWithAttrID:(LookinAttrIdentifier)attrID;
  32. /// 一个 attr 要么属于 UIView 要么属于 CALayer,如果它属于 UIView 那么该方法返回 YES
  33. + (BOOL)isUIViewPropertyWithAttrID:(LookinAttrIdentifier)attrID;
  34. /// 如果某个 attribute 是 enum,则这里会返回相应的 enum 的名称(如 @"NSTextAlignment"),进而可通过这个名称查询可用的枚举值列表
  35. + (NSString *)enumListNameWithAttrID:(LookinAttrIdentifier)attrID;
  36. /// 如果返回 YES,则说明用户在 Lookin 里修改了该 Attribute 的值后,应该重新拉取和更新相关图层的位置、截图等信息
  37. + (BOOL)needPatchAfterModificationWithAttrID:(LookinAttrIdentifier)attrID;
  38. /// 完整的名字
  39. + (NSString *)fullTitleWithAttrID:(LookinAttrIdentifier)attrID;
  40. /// 在某些 textField 和 checkbox 里会显示这里返回的 title
  41. + (NSString *)briefTitleWithAttrID:(LookinAttrIdentifier)attrID;
  42. /// 获取 getter 方法
  43. + (SEL)getterWithAttrID:(LookinAttrIdentifier)attrID;
  44. /// 获取 setter 方法
  45. + (SEL)setterWithAttrID:(LookinAttrIdentifier)attrID;
  46. /// 获取 “hideIfNil” 的值。如果为 YES,则当读取 getter 获取的 value 为 nil 时,Lookin 不会传输该 attr
  47. /// 如果为 NO,则即使 value 为 nil 也会传输(比如 label 的 text 属性,即使它是 nil 我们也要显示,所以它的 hideIfNil 应该为 NO)
  48. + (BOOL)hideIfNilWithAttrID:(LookinAttrIdentifier)attrID;
  49. /// 该属性需要的最低的 iOS 版本,比如 safeAreaInsets 从 iOS 11.0 开始出现,则该方法返回 11,如果返回 0 则表示不限制 iOS 版本(注意 Lookin 项目仅支持 iOS 8.0+)
  50. + (NSInteger)minAvailableOSVersionWithAttrID:(LookinAttrIdentifier)attrID;
  51. @end