feat:sync lost commits

This commit is contained in:
pengfei.zhou 2019-12-04 19:02:15 +08:00
parent 181bb6c924
commit e3eea2a12f
11 changed files with 125 additions and 226 deletions

View File

@ -1,25 +1,45 @@
#
# Be sure to run `pod lib lint Doric.podspec' to ensure this is a
# valid spec before submitting.
#
# Any lines starting with a # are optional, but their use is encouraged
# To learn more about a Podspec see https://guides.cocoapods.org/syntax/podspec.html
#
Pod::Spec.new do |s| Pod::Spec.new do |s|
s.name = 'Doric' s.name = 'Doric'
s.version = '0.1.0' s.version = '0.1.0'
s.summary = 'A short description of Doric.' s.summary = 'A short description of Doric.'
# This description is used to generate tags and improve search results.
# * Think: What does it do? Why did you write it? What is the focus?
# * Try to keep it short, snappy and to the point.
# * Write the description between the DESC delimiters below.
# * Finally, don't worry about the indent, CocoaPods strips it!
s.description = <<-DESC s.description = <<-DESC
Doric SDK for iOS TODO: Add long description of the pod here.
DESC DESC
s.homepage = 'https://github.com/doric-pub/doric' s.homepage = 'https://github.com/doric-pub/doric'
# s.screenshots = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2'
s.license = { :type => 'Apache-2.0', :file => 'LICENSE' } s.license = { :type => 'Apache-2.0', :file => 'LICENSE' }
s.author = { 'pengfei.zhou' => 'pengfeizhou@foxmail.com' } s.author = { 'pengfei.zhou' => 'pengfeizhou@foxmail.com' }
s.source = { :git => 'git@code.aliyun.com:Doric/doric-iOS.git', :tag => s.version.to_s } s.source = { :git => 'git@github.com:penfeizhou/doric.git', :tag => s.version.to_s }
# s.social_media_url = 'https://twitter.com/<TWITTER_USERNAME>'
s.ios.deployment_target = '8.0' s.ios.deployment_target = '8.0'
s.source_files = 'Pod/Classes/**/*' s.source_files = 'Pod/Classes/**/*'
s.resource = "Pod/Assets/*.js"
s.resource_bundles = { s.resource_bundles = {
'Doric' => ['Pod/Assets/**/*'] 'Doric' => ['Pod/Assets/**/*']
} }
s.public_header_files = 'Pod/Classes/**/*.h' s.public_header_files = 'Pod/Classes/**/*.h'
# s.frameworks = 'UIKit', 'MapKit'
# s.dependency 'AFNetworking', '~> 2.3'
# s.dependency 'SDWebImage', '~> 5.0'
s.dependency 'YYWebImage', '~>1.0.5' s.dependency 'YYWebImage', '~>1.0.5'
s.dependency 'YYImage/WebP' s.dependency 'YYImage/WebP'
s.dependency 'SocketRocket', '~> 0.5.1' s.dependency 'SocketRocket', '~> 0.5.1'

View File

@ -20,7 +20,7 @@
E2334AFE22E9D2070098A085 /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = E2334AFD22E9D2070098A085 /* main.m */; }; E2334AFE22E9D2070098A085 /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = E2334AFD22E9D2070098A085 /* main.m */; };
E2334B0822E9D2070098A085 /* ExampleTests.m in Sources */ = {isa = PBXBuildFile; fileRef = E2334B0722E9D2070098A085 /* ExampleTests.m */; }; E2334B0822E9D2070098A085 /* ExampleTests.m in Sources */ = {isa = PBXBuildFile; fileRef = E2334B0722E9D2070098A085 /* ExampleTests.m */; };
E2334B1322E9D2070098A085 /* ExampleUITests.m in Sources */ = {isa = PBXBuildFile; fileRef = E2334B1222E9D2070098A085 /* ExampleUITests.m */; }; E2334B1322E9D2070098A085 /* ExampleUITests.m in Sources */ = {isa = PBXBuildFile; fileRef = E2334B1222E9D2070098A085 /* ExampleUITests.m */; };
E247204923979232002D9E6E /* demo in Resources */ = {isa = PBXBuildFile; fileRef = E2F4481623839AC500073C7F /* demo */; }; E2F4481723839AC500073C7F /* demo in Resources */ = {isa = PBXBuildFile; fileRef = E2F4481623839AC500073C7F /* demo */; };
/* End PBXBuildFile section */ /* End PBXBuildFile section */
/* Begin PBXContainerItemProxy section */ /* Begin PBXContainerItemProxy section */
@ -293,8 +293,8 @@
isa = PBXResourcesBuildPhase; isa = PBXResourcesBuildPhase;
buildActionMask = 2147483647; buildActionMask = 2147483647;
files = ( files = (
E247204923979232002D9E6E /* demo in Resources */,
E2334AFB22E9D2070098A085 /* LaunchScreen.storyboard in Resources */, E2334AFB22E9D2070098A085 /* LaunchScreen.storyboard in Resources */,
E2F4481723839AC500073C7F /* demo in Resources */,
E2334AF822E9D2070098A085 /* Assets.xcassets in Resources */, E2334AF822E9D2070098A085 /* Assets.xcassets in Resources */,
E2334AF622E9D2060098A085 /* Main.storyboard in Resources */, E2334AF622E9D2060098A085 /* Main.storyboard in Resources */,
); );

View File

@ -1,5 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict />
</plist>

View File

@ -1,8 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>IDEDidComputeMac32BitWarning</key>
<true/>
</dict>
</plist>

View File

@ -27,6 +27,11 @@ - (void)viewDidLoad {
return ![obj containsString:@".map"]; return ![obj containsString:@".map"];
}]; }];
NSMutableArray <NSString *> *tmp = [self.demoFilePaths mutableCopy]; NSMutableArray <NSString *> *tmp = [self.demoFilePaths mutableCopy];
NSStringCompareOptions comparisonOptions = NSCaseInsensitiveSearch | NSNumericSearch | NSWidthInsensitiveSearch | NSForcedOrderingSearch;
[tmp sortUsingComparator:^NSComparisonResult(NSString *obj1, NSString *obj2) {
NSRange range = NSMakeRange(0, obj1.length);
return [obj1 compare:obj2 options:comparisonOptions range:range];
}];
[tmp insertObject:@"Dev Kit" atIndex:0]; [tmp insertObject:@"Dev Kit" atIndex:0];
self.demoFilePaths = tmp; self.demoFilePaths = tmp;
[self.view addSubview:[[UITableView new] also:^(UITableView *it) { [self.view addSubview:[[UITableView new] also:^(UITableView *it) {

View File

@ -1,31 +0,0 @@
/*
* Copyright [2019] [Doric.Pub]
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
//
// DoricLocalServer.h
// Doric
//
// Created by pengfei.zhou on 2019/8/14.
//
#import <Foundation/Foundation.h>
NS_ASSUME_NONNULL_BEGIN
@interface DoricLocalServer : NSObject
- (void)startWithPort:(NSUInteger)port;
@end
NS_ASSUME_NONNULL_END

View File

@ -1,130 +0,0 @@
/*
* Copyright [2019] [Doric.Pub]
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
//
// DoricLocalServer.m
// Doric
//
// Created by pengfei.zhou on 2019/8/14.
//
#import "DoricLocalServer.h"
#import "GCDWebServer.h"
#import "GCDWebServerDataResponse.h"
#import "DoricUtil.h"
#import "DoricContextManager.h"
#include <arpa/inet.h>
#include <net/if.h>
#include <ifaddrs.h>
typedef id (^ServerHandler)(GCDWebServerRequest *request);
@interface DoricLocalServer ()
@property(nonatomic, strong) GCDWebServer *server;
@property(nonatomic, strong) NSMutableDictionary *handlers;
@end
@implementation DoricLocalServer
- (instancetype)init {
if (self = [super init]) {
_server = [[GCDWebServer alloc] init];
_handlers = [[NSMutableDictionary alloc] init];
[self configurate];
}
return self;
}
- (NSString *)localIPAddress {
NSString *localIP = nil;
struct ifaddrs *addrs;
if (getifaddrs(&addrs) == 0) {
const struct ifaddrs *cursor = addrs;
while (cursor != NULL) {
if (cursor->ifa_addr->sa_family == AF_INET && (cursor->ifa_flags & IFF_LOOPBACK) == 0) {
//NSString *name = [NSString stringWithUTF8String:cursor->ifa_name];
//if ([name isEqualToString:@"en0"]) // Wi-Fi adapter
{
localIP = [NSString stringWithUTF8String:inet_ntoa(((struct sockaddr_in *) cursor->ifa_addr)->sin_addr)];
break;
}
}
cursor = cursor->ifa_next;
}
freeifaddrs(addrs);
}
return localIP;
}
- (GCDWebServerResponse *)handleRequest:(GCDWebServerRequest *)request {
if ([request.path hasPrefix:@"/api/"]) {
NSString *command = [request.path substringFromIndex:@"/api/".length];
ServerHandler handler = [self.handlers objectForKey:command];
if (handler) {
id dic = handler(request);
return [GCDWebServerDataResponse responseWithJSONObject:dic];
}
return [GCDWebServerDataResponse responseWithHTML:@"<html><body><p>It's a API request.</p></body></html>"];
}
NSBundle *bundle = DoricBundle();
NSString *filePath = [NSString stringWithFormat:@"%@/dist%@", bundle.bundlePath, request.path];
NSData *data = [NSData dataWithContentsOfFile:filePath];
NSURL *url = [NSURL fileURLWithPath:filePath];
NSMutableURLRequest *req = [NSMutableURLRequest requestWithURL:url];
NSHTTPURLResponse *response;
[NSURLConnection sendSynchronousRequest:req returningResponse:&response error:nil];
return [GCDWebServerDataResponse responseWithData:data contentType:response.MIMEType];
}
- (void)configurate {
__weak typeof(self) _self = self;
[self.server addDefaultHandlerForMethod:@"GET"
requestClass:[GCDWebServerRequest class]
processBlock:^GCDWebServerResponse *(GCDWebServerRequest *request) {
__strong typeof(_self) self = _self;
return [self handleRequest:request];
}];
[self.handlers setObject:^id(GCDWebServerRequest *request) {
NSMutableArray *array = [[NSMutableArray alloc] init];
for (NSValue *value in [[DoricContextManager instance] aliveContexts]) {
DoricContext *context = value.nonretainedObjectValue;
[array addObject:@{
@"source": context.source,
@"id": context.contextId,
}];
}
return array;
}
forKey:@"allContexts"];
[self.handlers setObject:^id(GCDWebServerRequest *request) {
NSString *contextId = [request.query objectForKey:@"id"];
DoricContext *context = [[DoricContextManager instance] getContext:contextId];
return @{
@"id": context.contextId,
@"source": context.source,
@"script": context.script
};
}
forKey:@"context"];
}
- (void)startWithPort:(NSUInteger)port {
[self.server startWithPort:port bonjourName:nil];
DoricLog(@"Start Server At %@:%d", [self localIPAddress], port);
}
@end

View File

@ -20,6 +20,7 @@
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>
typedef UIEdgeInsets DoricMargin; typedef UIEdgeInsets DoricMargin;
typedef UIEdgeInsets DoricPadding;
DoricMargin DoricMarginMake(CGFloat left, CGFloat top, CGFloat right, CGFloat bottom); DoricMargin DoricMarginMake(CGFloat left, CGFloat top, CGFloat right, CGFloat bottom);
@ -82,6 +83,10 @@ typedef NS_ENUM(NSInteger, DoricGravity) {
@property(nonatomic, strong) DoricLayoutConfig *layoutConfig; @property(nonatomic, strong) DoricLayoutConfig *layoutConfig;
@end @end
@interface UIView (DoricPadding)
@property(nonatomic, assign) DoricPadding padding;
@end
@interface UIView (DoricTag) @interface UIView (DoricTag)
@property(nonatomic, copy) NSString *tagString; @property(nonatomic, copy) NSString *tagString;

View File

@ -37,6 +37,24 @@ - (DoricLayoutConfig *)layoutConfig {
@end @end
static const void *kLayoutPadding = &kLayoutPadding;
@implementation UIView (DoricPadding)
@dynamic padding;
- (void)setPadding:(DoricPadding)padding {
objc_setAssociatedObject(self, kLayoutPadding, [NSValue value:&padding withObjCType:@encode(DoricPadding)], OBJC_ASSOCIATION_RETAIN_NONATOMIC);
}
- (DoricPadding)padding {
DoricPadding value;
value.left = value.right = value.top = value.bottom = 0;
[objc_getAssociatedObject(self, kLayoutPadding) getValue:&value];
return value;
}
@end
static const void *kTagString = &kTagString; static const void *kTagString = &kTagString;
@implementation UIView (DoricTag) @implementation UIView (DoricTag)
@ -79,13 +97,15 @@ - (CGSize)measureSize:(CGSize)targetSize {
|| config.heightSpec == DoricLayoutWrapContent) { || config.heightSpec == DoricLayoutWrapContent) {
height = targetSize.height - config.margin.top - config.margin.bottom; height = targetSize.height - config.margin.top - config.margin.bottom;
} }
DoricPadding padding = self.padding;
CGSize contentSize = [self sizeThatFits:CGSizeMake(width, height)]; CGSize contentSize = [self sizeThatFits:CGSizeMake(
width - padding.left - padding.right,
height - padding.top - padding.bottom)];
if (config.widthSpec == DoricLayoutWrapContent) { if (config.widthSpec == DoricLayoutWrapContent) {
width = contentSize.width; width = contentSize.width + padding.left + padding.right;
} }
if (config.heightSpec == DoricLayoutWrapContent) { if (config.heightSpec == DoricLayoutWrapContent) {
height = contentSize.height; height = contentSize.height + padding.left + padding.top + padding.bottom;
} }
return CGSizeMake(width, height); return CGSizeMake(width, height);
} }
@ -208,6 +228,8 @@ - (CGSize)sizeThatFits:(CGSize)size {
- (void)layoutSelf:(CGSize)targetSize { - (void)layoutSelf:(CGSize)targetSize {
self.width = targetSize.width; self.width = targetSize.width;
self.height = targetSize.height; self.height = targetSize.height;
DoricPadding padding = self.padding;
for (UIView *child in self.subviews) { for (UIView *child in self.subviews) {
if (child.isHidden) { if (child.isHidden) {
continue; continue;
@ -219,33 +241,35 @@ - (void)layoutSelf:(CGSize)targetSize {
if (!childConfig) { if (!childConfig) {
childConfig = [DoricLayoutConfig new]; childConfig = [DoricLayoutConfig new];
} }
CGSize size = [child measureSize:CGSizeMake(targetSize.width, targetSize.height)]; CGSize size = [child measureSize:CGSizeMake(
targetSize.width - padding.left - padding.right,
targetSize.height - padding.top - padding.bottom)];
[child layoutSelf:size]; [child layoutSelf:size];
DoricGravity gravity = childConfig.alignment; DoricGravity gravity = childConfig.alignment;
if ((gravity & LEFT) == LEFT) { if ((gravity & LEFT) == LEFT) {
child.left = 0; child.left = padding.left;
} else if ((gravity & RIGHT) == RIGHT) { } else if ((gravity & RIGHT) == RIGHT) {
child.right = targetSize.width; child.right = targetSize.width - padding.right;
} else if ((gravity & CENTER_X) == CENTER_X) { } else if ((gravity & CENTER_X) == CENTER_X) {
child.centerX = targetSize.width / 2; child.centerX = (targetSize.width - padding.left - padding.right) / 2;
} else { } else {
if (childConfig.margin.left) { if (childConfig.margin.left) {
child.left = childConfig.margin.left; child.left = childConfig.margin.left + padding.left;
} else if (childConfig.margin.right) { } else if (childConfig.margin.right) {
child.right = targetSize.width - childConfig.margin.right; child.right = targetSize.width - childConfig.margin.right - padding.right;
} }
} }
if ((gravity & TOP) == TOP) { if ((gravity & TOP) == TOP) {
child.top = 0; child.top = padding.top;
} else if ((gravity & BOTTOM) == BOTTOM) { } else if ((gravity & BOTTOM) == BOTTOM) {
child.bottom = targetSize.height; child.bottom = targetSize.height - padding.bottom;
} else if ((gravity & CENTER_Y) == CENTER_Y) { } else if ((gravity & CENTER_Y) == CENTER_Y) {
child.centerY = targetSize.height / 2; child.centerY = (targetSize.height - padding.top - padding.bottom) / 2;
} else { } else {
if (childConfig.margin.top) { if (childConfig.margin.top) {
child.top = childConfig.margin.top; child.top = childConfig.margin.top + padding.top;
} else if (childConfig.margin.bottom) { } else if (childConfig.margin.bottom) {
child.bottom = targetSize.height - childConfig.margin.bottom; child.bottom = targetSize.height - childConfig.margin.bottom - padding.bottom;
} }
} }
} }
@ -292,15 +316,16 @@ - (CGSize)sizeThatFits:(CGSize)size {
- (void)layoutSelf:(CGSize)targetSize { - (void)layoutSelf:(CGSize)targetSize {
self.width = targetSize.width; self.width = targetSize.width;
self.height = targetSize.height; self.height = targetSize.height;
CGFloat yStart = 0; DoricPadding padding = self.padding;
CGFloat yStart = padding.top;
if ((self.gravity & TOP) == TOP) { if ((self.gravity & TOP) == TOP) {
yStart = 0; yStart = padding.top;
} else if ((self.gravity & BOTTOM) == BOTTOM) { } else if ((self.gravity & BOTTOM) == BOTTOM) {
yStart = targetSize.height - self.contentHeight; yStart = targetSize.height - self.contentHeight - padding.bottom;
} else if ((self.gravity & CENTER_Y) == CENTER_Y) { } else if ((self.gravity & CENTER_Y) == CENTER_Y) {
yStart = (targetSize.height - self.contentHeight) / 2; yStart = (targetSize.height - self.contentHeight - padding.top - padding.bottom) / 2;
} }
CGFloat remain = targetSize.height - self.contentHeight; CGFloat remain = targetSize.height - self.contentHeight - padding.top - padding.bottom;
for (UIView *child in self.subviews) { for (UIView *child in self.subviews) {
if (child.isHidden) { if (child.isHidden) {
continue; continue;
@ -313,24 +338,26 @@ - (void)layoutSelf:(CGSize)targetSize {
childConfig = [DoricLayoutConfig new]; childConfig = [DoricLayoutConfig new];
} }
CGSize size = [child measureSize:CGSizeMake(targetSize.width, targetSize.height - yStart)]; CGSize size = [child measureSize:CGSizeMake(
targetSize.width - padding.left - padding.right,
targetSize.height - yStart - padding.bottom)];
if (childConfig.weight) { if (childConfig.weight) {
size.height += remain / self.contentWeight * childConfig.weight; size.height += remain / self.contentWeight * childConfig.weight;
} }
[child layoutSelf:size]; [child layoutSelf:size];
DoricGravity gravity = childConfig.alignment | self.gravity; DoricGravity gravity = childConfig.alignment | self.gravity;
if ((gravity & LEFT) == LEFT) { if ((gravity & LEFT) == LEFT) {
child.left = 0; child.left = padding.left;
} else if ((gravity & RIGHT) == RIGHT) { } else if ((gravity & RIGHT) == RIGHT) {
child.right = self.width; child.right = self.width - padding.right;
} else if ((gravity & CENTER_X) == CENTER_X) { } else if ((gravity & CENTER_X) == CENTER_X) {
child.centerX = targetSize.width / 2; child.centerX = (targetSize.width - padding.left - padding.right) / 2;
} else { } else if (childConfig.margin.left) {
if (childConfig.margin.left) { child.left = childConfig.margin.left + padding.left;
child.left = childConfig.margin.left;
} else if (childConfig.margin.right) { } else if (childConfig.margin.right) {
child.right = targetSize.width - childConfig.margin.right; child.right = targetSize.width - childConfig.margin.right - padding.right;
} } else {
child.left = padding.left;
} }
if (childConfig.margin.top) { if (childConfig.margin.top) {
yStart += childConfig.margin.top; yStart += childConfig.margin.top;
@ -380,17 +407,16 @@ - (CGSize)sizeThatFits:(CGSize)size {
- (void)layoutSelf:(CGSize)targetSize { - (void)layoutSelf:(CGSize)targetSize {
self.width = targetSize.width; self.width = targetSize.width;
self.height = targetSize.height; self.height = targetSize.height;
CGFloat xStart = 0; DoricPadding padding = self.padding;
if (self.contentWeight) { CGFloat xStart = padding.left;
xStart = 0; if ((self.gravity & LEFT) == LEFT) {
} else if ((self.gravity & LEFT) == LEFT) { xStart = padding.left;
xStart = 0;
} else if ((self.gravity & RIGHT) == RIGHT) { } else if ((self.gravity & RIGHT) == RIGHT) {
xStart = targetSize.width - self.contentWidth; xStart = targetSize.width - self.contentWidth - padding.right;
} else if ((self.gravity & CENTER_X) == CENTER_X) { } else if ((self.gravity & CENTER_X) == CENTER_X) {
xStart = (targetSize.width - self.contentWidth) / 2; xStart = (targetSize.width - self.contentWidth - padding.left - padding.right) / 2;
} }
CGFloat remain = targetSize.width - self.contentWidth; CGFloat remain = targetSize.width - self.contentWidth - padding.left - padding.right;
for (UIView *child in self.subviews) { for (UIView *child in self.subviews) {
if (child.isHidden) { if (child.isHidden) {
continue; continue;
@ -403,7 +429,9 @@ - (void)layoutSelf:(CGSize)targetSize {
childConfig = [DoricLayoutConfig new]; childConfig = [DoricLayoutConfig new];
} }
CGSize size = [child measureSize:CGSizeMake(targetSize.width - xStart, targetSize.height)]; CGSize size = [child measureSize:CGSizeMake(
targetSize.width - xStart - padding.right,
targetSize.height - padding.top - padding.bottom)];
if (childConfig.weight) { if (childConfig.weight) {
size.width += remain / self.contentWeight * childConfig.weight; size.width += remain / self.contentWeight * childConfig.weight;
} }
@ -412,17 +440,17 @@ - (void)layoutSelf:(CGSize)targetSize {
DoricGravity gravity = childConfig.alignment | self.gravity; DoricGravity gravity = childConfig.alignment | self.gravity;
if ((gravity & TOP) == TOP) { if ((gravity & TOP) == TOP) {
child.top = 0; child.top = padding.top;
} else if ((gravity & BOTTOM) == BOTTOM) { } else if ((gravity & BOTTOM) == BOTTOM) {
child.bottom = targetSize.height; child.bottom = targetSize.height - padding.bottom;
} else if ((gravity & CENTER_Y) == CENTER_Y) { } else if ((gravity & CENTER_Y) == CENTER_Y) {
child.centerY = targetSize.height / 2; child.centerY = (targetSize.height - padding.top - padding.bottom) / 2;
} else { } else if (childConfig.margin.top) {
if (childConfig.margin.top) { child.top = childConfig.margin.top + padding.top;
child.top = childConfig.margin.top;
} else if (childConfig.margin.bottom) { } else if (childConfig.margin.bottom) {
child.bottom = targetSize.height - childConfig.margin.bottom; child.bottom = targetSize.height - childConfig.margin.bottom - padding.bottom;
} } else {
child.top = padding.top;
} }
if (childConfig.margin.left) { if (childConfig.margin.left) {

View File

@ -235,7 +235,6 @@ - (void)blendView:(UIView *)view forPropName:(NSString *)name propValue:(id)prop
} else { } else {
view.clipsToBounds = YES; view.clipsToBounds = YES;
} }
} else if ([name isEqualToString:@"translationX"]) { } else if ([name isEqualToString:@"translationX"]) {
self.translationX = prop; self.translationX = prop;
} else if ([name isEqualToString:@"translationY"]) { } else if ([name isEqualToString:@"translationY"]) {
@ -250,6 +249,17 @@ - (void)blendView:(UIView *)view forPropName:(NSString *)name propValue:(id)prop
self.pivotY = prop; self.pivotY = prop;
} else if ([name isEqualToString:@"rotation"]) { } else if ([name isEqualToString:@"rotation"]) {
self.rotation = prop; self.rotation = prop;
} else if ([name isEqualToString:@"padding"]) {
DoricPadding padding;
padding.left = padding.right = padding.top = padding.bottom = 0;
if ([prop isKindOfClass:[NSDictionary class]]) {
NSDictionary *dictionary = prop;
padding.left = [dictionary[@"left"] floatValue];
padding.right = [dictionary[@"right"] floatValue];
padding.top = [dictionary[@"top"] floatValue];
padding.bottom = [dictionary[@"bottom"] floatValue];
}
self.view.padding = padding;
} else { } else {
DoricLog(@"Blend View error for View Type :%@, prop is %@", self.class, name); DoricLog(@"Blend View error for View Type :%@, prop is %@", self.class, name);
} }
@ -357,6 +367,8 @@ - (NSDictionary *)transformation {
return dictionary; return dictionary;
} }
#pragma animations
- (void)doAnimation:(id)params withPromise:(DoricPromise *)promise { - (void)doAnimation:(id)params withPromise:(DoricPromise *)promise {
CAAnimation *animation = [self parseAnimation:params]; CAAnimation *animation = [self parseAnimation:params];
AnimationCallback *originDelegate = animation.delegate; AnimationCallback *originDelegate = animation.delegate;
@ -371,6 +383,7 @@ - (void)doAnimation:(id)params withPromise:(DoricPromise *)promise {
if (originDelegate) { if (originDelegate) {
originDelegate.endBlock(callback); originDelegate.endBlock(callback);
} }
[self.view.layer removeAllAnimations];
[self transformProperties]; [self transformProperties];
[promise resolve:self.transformation]; [promise resolve:self.transformation];
}; };
@ -379,6 +392,8 @@ - (void)doAnimation:(id)params withPromise:(DoricPromise *)promise {
if (params[@"delay"]) { if (params[@"delay"]) {
animation.beginTime = CACurrentMediaTime() + [params[@"delay"] floatValue] / 1000; animation.beginTime = CACurrentMediaTime() + [params[@"delay"] floatValue] / 1000;
} }
animation.removedOnCompletion = NO;
animation.fillMode = kCAFillModeForwards;
[self.view.layer addAnimation:animation forKey:nil]; [self.view.layer addAnimation:animation forKey:nil];
} }