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