From a6b374aba7cf001a86b9c2f995d41bef9cca0b6c Mon Sep 17 00:00:00 2001 From: Roman Gorbunov Date: Thu, 25 Jul 2019 03:59:05 -0700 Subject: [PATCH] CKRatioLayoutComponent live editing Summary: CKRatioLayoutComponent's ratio is now live editable P.S. Now it takes some time to see the view changed and the new value of everything on flipper side Reviewed By: kevin0571 Differential Revision: D16458380 fbshipit-source-id: 0f06426477b6747f6ad71716dc66e69316b23208 --- .../CKComponent+Sonar.mm | 1 + .../CKRatioLayoutComponent+Sonar.h | 14 +++++++ .../CKRatioLayoutComponent+Sonar.mm | 40 +++++++++++++++++++ 3 files changed, 55 insertions(+) create mode 100644 iOS/Plugins/FlipperKitLayoutPlugin/FlipperKitLayoutComponentKitSupport/CKRatioLayoutComponent+Sonar.h create mode 100644 iOS/Plugins/FlipperKitLayoutPlugin/FlipperKitLayoutComponentKitSupport/CKRatioLayoutComponent+Sonar.mm diff --git a/iOS/Plugins/FlipperKitLayoutPlugin/FlipperKitLayoutComponentKitSupport/CKComponent+Sonar.mm b/iOS/Plugins/FlipperKitLayoutPlugin/FlipperKitLayoutComponentKitSupport/CKComponent+Sonar.mm index e84b47081..c591cf08c 100644 --- a/iOS/Plugins/FlipperKitLayoutPlugin/FlipperKitLayoutComponentKitSupport/CKComponent+Sonar.mm +++ b/iOS/Plugins/FlipperKitLayoutPlugin/FlipperKitLayoutComponentKitSupport/CKComponent+Sonar.mm @@ -21,6 +21,7 @@ #import #import +#import "CKRatioLayoutComponent+Sonar.h" #import "CKFlexboxComponent+Sonar.h" #import "CKInsetComponent+Sonar.h" #import "CKStatelessComponent+Sonar.h" diff --git a/iOS/Plugins/FlipperKitLayoutPlugin/FlipperKitLayoutComponentKitSupport/CKRatioLayoutComponent+Sonar.h b/iOS/Plugins/FlipperKitLayoutPlugin/FlipperKitLayoutComponentKitSupport/CKRatioLayoutComponent+Sonar.h new file mode 100644 index 000000000..8cf7c6da8 --- /dev/null +++ b/iOS/Plugins/FlipperKitLayoutPlugin/FlipperKitLayoutComponentKitSupport/CKRatioLayoutComponent+Sonar.h @@ -0,0 +1,14 @@ +/* + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the LICENSE + * file in the root directory of this source tree. + */ +#import +#import + +FB_LINK_REQUIRE_CATEGORY(CKRatioLayoutComponent_Sonar) +@interface CKRatioLayoutComponent (Sonar) + +@end + diff --git a/iOS/Plugins/FlipperKitLayoutPlugin/FlipperKitLayoutComponentKitSupport/CKRatioLayoutComponent+Sonar.mm b/iOS/Plugins/FlipperKitLayoutPlugin/FlipperKitLayoutComponentKitSupport/CKRatioLayoutComponent+Sonar.mm new file mode 100644 index 000000000..fe6ffd5a6 --- /dev/null +++ b/iOS/Plugins/FlipperKitLayoutPlugin/FlipperKitLayoutComponentKitSupport/CKRatioLayoutComponent+Sonar.mm @@ -0,0 +1,40 @@ +/* + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the LICENSE + * file in the root directory of this source tree. + */ +#if FB_SONARKIT_ENABLED + +#import "CKRatioLayoutComponent+Sonar.h" + +#import +#import + +#import "CKComponent+Sonar.h" + +FB_LINKABLE(CKRatioLayoutComponent_Sonar) +@implementation CKRatioLayoutComponent (Sonar) + +- (NSArray *> *> *)sonar_additionalDataOverride +{ + return @[[SKNamed newWithName:@"CKRatioLayoutComponent" withValue:@{@"ratio": SKMutableObject((NSNumber *)[self valueForKey:@"_ratio"])}]]; +} + +- (void)setMutableData:(id)data { + [self setValue:data forKey:@"_ratio"]; +} + +- (NSDictionary *)sonar_getDataMutationsChanged { + return @{ + @"CKRatioLayoutComponent.ratio": ^(NSNumber *value) { + CGFloat ratio = [(NSNumber *)[self valueForKey:@"_ratio"] floatValue]; + ratio = value.floatValue; + return [NSNumber numberWithFloat:ratio]; + }, + }; +} + +@end + +#endif