From 20aa6d95470cabf76f8c6080bbe65845336e13c7 Mon Sep 17 00:00:00 2001 From: biancalui <60601155+biancalui-emarsys@users.noreply.github.com> Date: Mon, 19 Sep 2022 17:48:27 +0800 Subject: [PATCH] fix: fix EMSRecommendationFilter mapper MV-333 --- ios/MapUtil.m | 49 +++++++++++++++++++++---------------------------- 1 file changed, 21 insertions(+), 28 deletions(-) diff --git a/ios/MapUtil.m b/ios/MapUtil.m index 8d43324..e3f7ed7 100644 --- a/ios/MapUtil.m +++ b/ios/MapUtil.m @@ -153,70 +153,61 @@ + (EMSProduct *)mapToProduct:(NSDictionary *)object { } +(NSArray *)mapToRecommendationFilter:(NSDictionary *)map { - NSMutableArray *filters = [NSMutableArray array]; NSString *type = @""; NSString *field = @""; - NSString *comprasion = @""; + NSString *comparison = @""; NSString *expectation = @""; - NSMutableArray *expectations = [NSMutableArray array]; - EMSRecommendationFilter *filter = [[EMSRecommendationFilter alloc] init]; - if ([map objectForKey:@"type"]) { type = [map objectForKey:@"type"]; } - else if ([map objectForKey:@"field"]) { - type = [map objectForKey:@"field"]; + if ([map objectForKey:@"field"]) { + field = [map objectForKey:@"field"]; } - else if ([map objectForKey:@"comprasion"]) { - type = [map objectForKey:@"comprasion"]; + if ([map objectForKey:@"comparison"]) { + comparison = [map objectForKey:@"comparison"]; } - if ([map objectForKey:@"expectations"] && [[map objectForKey:@"expectations"] isMemberOfClass:[NSArray class]]) { + if ([[map objectForKey:@"expectations"] isKindOfClass:[NSString class]]) { + expectation = [map objectForKey:@"expectations"]; + } else if ([[map objectForKey:@"expectations"] isKindOfClass:[NSArray class]]) { NSArray *expArray = [map mutableArrayValueForKey: @"expectations"]; for (NSString *item in expArray) { - expectation = item; [expectations addObject:item]; } } - if ([map objectForKey:@"expectations"] && [[map objectForKey:@"expectations"] isMemberOfClass:[NSArray class]]) { - NSArray *expArray = [map mutableArrayValueForKey: @"expectations"]; - for (NSString *item in expArray) { - expectation = item; - [expectations addObject:item]; - } - } + EMSRecommendationFilter *filter = [[EMSRecommendationFilter alloc] init]; - if ([type caseInsensitiveCompare:@"include"]) { - if ([comprasion caseInsensitiveCompare:@"IS"]) { + if ([type caseInsensitiveCompare:@"include"] == NSOrderedSame) { + if ([comparison caseInsensitiveCompare:@"IS"] == NSOrderedSame) { filter = [EMSRecommendationFilter includeFilterWithField:(field) isValue: (expectation)]; } - else if ([comprasion caseInsensitiveCompare:@"IN"]) { + else if ([comparison caseInsensitiveCompare:@"IN"] == NSOrderedSame) { filter = [EMSRecommendationFilter includeFilterWithField:(field) inValues: (expectations)]; } - else if ([comprasion caseInsensitiveCompare:@"HAS"]) { + else if ([comparison caseInsensitiveCompare:@"HAS"] == NSOrderedSame) { filter = [EMSRecommendationFilter includeFilterWithField:(field) hasValue: (expectation)]; } - else if ([comprasion caseInsensitiveCompare:@"OVERLAPS"]) { + else if ([comparison caseInsensitiveCompare:@"OVERLAPS"] == NSOrderedSame) { filter = [EMSRecommendationFilter includeFilterWithField:(field) overlapsValues: (expectations)]; } else { NSLog(@"Not correct comparison value!"); } } - else if ([type caseInsensitiveCompare:@"exclude"]) { - if ([comprasion caseInsensitiveCompare:@"IS"]) { + else if ([type caseInsensitiveCompare:@"exclude"] == NSOrderedSame) { + if ([comparison caseInsensitiveCompare:@"IS"] == NSOrderedSame) { filter = [EMSRecommendationFilter excludeFilterWithField:(field) isValue: (expectation)]; } - else if ([comprasion caseInsensitiveCompare:@"IN"]) { + else if ([comparison caseInsensitiveCompare:@"IN"] == NSOrderedSame) { filter = [EMSRecommendationFilter excludeFilterWithField:(field) inValues: (expectations)]; } - else if ([comprasion caseInsensitiveCompare:@"HAS"]) { + else if ([comparison caseInsensitiveCompare:@"HAS"] == NSOrderedSame) { filter = [EMSRecommendationFilter excludeFilterWithField:(field) hasValue: (expectation)]; } - else if ([comprasion caseInsensitiveCompare:@"OVERLAPS"]) { + else if ([comparison caseInsensitiveCompare:@"OVERLAPS"] == NSOrderedSame) { filter = [EMSRecommendationFilter excludeFilterWithField:(field) overlapsValues: (expectations)]; } else { @@ -226,6 +217,8 @@ + (EMSProduct *)mapToProduct:(NSDictionary *)object { NSLog(@"Not correct type"); } + NSMutableArray *filters = [NSMutableArray array]; + if (filter != nil) { [filters addObject: filter]; }