Compare commits
	
		
			6 Commits
		
	
	
		
			hotfix/1.2
			...
			enterprise
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 6116d259c2 | ||
|   | ae8d0804e1 | ||
|   | cab4294e86 | ||
|   | 80eddb8c3d | ||
|   | dbdf90a38c | ||
|   | 4f6cf8cbca | 
							
								
								
									
										4
									
								
								Podfile
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								Podfile
									
									
									
									
									
								
							| @@ -82,6 +82,10 @@ post_install do |installer| | |||||||
|     project.targets.each do |target| |     project.targets.each do |target| | ||||||
|       target.build_configurations.each do |config| |       target.build_configurations.each do |config| | ||||||
|             config.build_settings['IPHONEOS_DEPLOYMENT_TARGET'] = '11.0' |             config.build_settings['IPHONEOS_DEPLOYMENT_TARGET'] = '11.0' | ||||||
|  | xcconfig_path = config.base_configuration_reference.real_path | ||||||
|  |             xcconfig = File.read(xcconfig_path) | ||||||
|  |             xcconfig_mod = xcconfig.gsub(/DT_TOOLCHAIN_DIR/, "TOOLCHAIN_DIR") | ||||||
|  |             File.open(xcconfig_path, "w") { |file| file << xcconfig_mod } | ||||||
|        end |        end | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ | |||||||
| 	archiveVersion = 1; | 	archiveVersion = 1; | ||||||
| 	classes = { | 	classes = { | ||||||
| 	}; | 	}; | ||||||
| 	objectVersion = 51; | 	objectVersion = 54; | ||||||
| 	objects = { | 	objects = { | ||||||
| 
 | 
 | ||||||
| /* Begin PBXBuildFile section */ | /* Begin PBXBuildFile section */ | ||||||
| @@ -345,6 +345,7 @@ | |||||||
| 		23E9EB252A84E98300B792F2 /* pi_new_mine_info_online.svga in Resources */ = {isa = PBXBuildFile; fileRef = 23E9EB232A84E98300B792F2 /* pi_new_mine_info_online.svga */; }; | 		23E9EB252A84E98300B792F2 /* pi_new_mine_info_online.svga in Resources */ = {isa = PBXBuildFile; fileRef = 23E9EB232A84E98300B792F2 /* pi_new_mine_info_online.svga */; }; | ||||||
| 		23E9EB312A85E5D100B792F2 /* pi_app_logo_new_bg.png in Resources */ = {isa = PBXBuildFile; fileRef = 23E9EB302A85E5D100B792F2 /* pi_app_logo_new_bg.png */; }; | 		23E9EB312A85E5D100B792F2 /* pi_app_logo_new_bg.png in Resources */ = {isa = PBXBuildFile; fileRef = 23E9EB302A85E5D100B792F2 /* pi_app_logo_new_bg.png */; }; | ||||||
| 		23E9EB332A85E97C00B792F2 /* pi_login_new_logo.png in Resources */ = {isa = PBXBuildFile; fileRef = 23E9EB322A85E97B00B792F2 /* pi_login_new_logo.png */; }; | 		23E9EB332A85E97C00B792F2 /* pi_login_new_logo.png in Resources */ = {isa = PBXBuildFile; fileRef = 23E9EB322A85E97B00B792F2 /* pi_login_new_logo.png */; }; | ||||||
|  | 		23F364322AF0A7E100286D79 /* YYTextAsyncLayer+XPTextAsyncLayer.m in Sources */ = {isa = PBXBuildFile; fileRef = 23F364312AF0A7E100286D79 /* YYTextAsyncLayer+XPTextAsyncLayer.m */; }; | ||||||
| 		23FF255B2AB956D50064E904 /* pi_home_new_pk.svga in Resources */ = {isa = PBXBuildFile; fileRef = 23FF255A2AB956D50064E904 /* pi_home_new_pk.svga */; }; | 		23FF255B2AB956D50064E904 /* pi_home_new_pk.svga in Resources */ = {isa = PBXBuildFile; fileRef = 23FF255A2AB956D50064E904 /* pi_home_new_pk.svga */; }; | ||||||
| 		23FF25622ABAE6310064E904 /* pi_room_game_fine_love.svga in Resources */ = {isa = PBXBuildFile; fileRef = 23FF25612ABAE6310064E904 /* pi_room_game_fine_love.svga */; }; | 		23FF25622ABAE6310064E904 /* pi_room_game_fine_love.svga in Resources */ = {isa = PBXBuildFile; fileRef = 23FF25612ABAE6310064E904 /* pi_room_game_fine_love.svga */; }; | ||||||
| 		23FF25652ABC3B3C0064E904 /* XPHomeGameView.m in Sources */ = {isa = PBXBuildFile; fileRef = 23FF25642ABC3B3B0064E904 /* XPHomeGameView.m */; }; | 		23FF25652ABC3B3C0064E904 /* XPHomeGameView.m in Sources */ = {isa = PBXBuildFile; fileRef = 23FF25642ABC3B3B0064E904 /* XPHomeGameView.m */; }; | ||||||
| @@ -2103,6 +2104,8 @@ | |||||||
| 		23E9EB232A84E98300B792F2 /* pi_new_mine_info_online.svga */ = {isa = PBXFileReference; lastKnownFileType = file; path = pi_new_mine_info_online.svga; sourceTree = "<group>"; }; | 		23E9EB232A84E98300B792F2 /* pi_new_mine_info_online.svga */ = {isa = PBXFileReference; lastKnownFileType = file; path = pi_new_mine_info_online.svga; sourceTree = "<group>"; }; | ||||||
| 		23E9EB302A85E5D100B792F2 /* pi_app_logo_new_bg.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = pi_app_logo_new_bg.png; sourceTree = "<group>"; }; | 		23E9EB302A85E5D100B792F2 /* pi_app_logo_new_bg.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = pi_app_logo_new_bg.png; sourceTree = "<group>"; }; | ||||||
| 		23E9EB322A85E97B00B792F2 /* pi_login_new_logo.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = pi_login_new_logo.png; sourceTree = "<group>"; }; | 		23E9EB322A85E97B00B792F2 /* pi_login_new_logo.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = pi_login_new_logo.png; sourceTree = "<group>"; }; | ||||||
|  | 		23F364302AF0A7E000286D79 /* YYTextAsyncLayer+XPTextAsyncLayer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = "YYTextAsyncLayer+XPTextAsyncLayer.h"; sourceTree = "<group>"; }; | ||||||
|  | 		23F364312AF0A7E100286D79 /* YYTextAsyncLayer+XPTextAsyncLayer.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = "YYTextAsyncLayer+XPTextAsyncLayer.m"; sourceTree = "<group>"; }; | ||||||
| 		23FF255A2AB956D50064E904 /* pi_home_new_pk.svga */ = {isa = PBXFileReference; lastKnownFileType = file; path = pi_home_new_pk.svga; sourceTree = "<group>"; }; | 		23FF255A2AB956D50064E904 /* pi_home_new_pk.svga */ = {isa = PBXFileReference; lastKnownFileType = file; path = pi_home_new_pk.svga; sourceTree = "<group>"; }; | ||||||
| 		23FF25612ABAE6310064E904 /* pi_room_game_fine_love.svga */ = {isa = PBXFileReference; lastKnownFileType = file; path = pi_room_game_fine_love.svga; sourceTree = "<group>"; }; | 		23FF25612ABAE6310064E904 /* pi_room_game_fine_love.svga */ = {isa = PBXFileReference; lastKnownFileType = file; path = pi_room_game_fine_love.svga; sourceTree = "<group>"; }; | ||||||
| 		23FF25632ABC3B3B0064E904 /* XPHomeGameView.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = XPHomeGameView.h; sourceTree = "<group>"; }; | 		23FF25632ABC3B3B0064E904 /* XPHomeGameView.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = XPHomeGameView.h; sourceTree = "<group>"; }; | ||||||
| @@ -6834,6 +6837,8 @@ | |||||||
| 				2323E0362ABDAE8F00CCAD2F /* FBSDKSettings+PISDKSettings.m */, | 				2323E0362ABDAE8F00CCAD2F /* FBSDKSettings+PISDKSettings.m */, | ||||||
| 				E81C27AC26EF39AB0031E639 /* AppDelegate+ThirdConfig.h */, | 				E81C27AC26EF39AB0031E639 /* AppDelegate+ThirdConfig.h */, | ||||||
| 				E81C27AD26EF39AB0031E639 /* AppDelegate+ThirdConfig.m */, | 				E81C27AD26EF39AB0031E639 /* AppDelegate+ThirdConfig.m */, | ||||||
|  | 				23F364302AF0A7E000286D79 /* YYTextAsyncLayer+XPTextAsyncLayer.h */, | ||||||
|  | 				23F364312AF0A7E100286D79 /* YYTextAsyncLayer+XPTextAsyncLayer.m */, | ||||||
| 			); | 			); | ||||||
| 			path = AppDelegate; | 			path = AppDelegate; | ||||||
| 			sourceTree = "<group>"; | 			sourceTree = "<group>"; | ||||||
| @@ -11179,6 +11184,7 @@ | |||||||
| 				9B044DA0282D32F700DE4859 /* MicroInviteExtModel.m in Sources */, | 				9B044DA0282D32F700DE4859 /* MicroInviteExtModel.m in Sources */, | ||||||
| 				E8D7D74B282BA1EC0007D7BD /* XPMonentsTableViewCell.m in Sources */, | 				E8D7D74B282BA1EC0007D7BD /* XPMonentsTableViewCell.m in Sources */, | ||||||
| 				E8D34D5A28082357009C4835 /* UserGiftWallInfoModel.m in Sources */, | 				E8D34D5A28082357009C4835 /* UserGiftWallInfoModel.m in Sources */, | ||||||
|  | 				23F364322AF0A7E100286D79 /* YYTextAsyncLayer+XPTextAsyncLayer.m in Sources */, | ||||||
| 				E82107842987E35300DE7040 /* MessageMonentsAutoModel.m in Sources */, | 				E82107842987E35300DE7040 /* MessageMonentsAutoModel.m in Sources */, | ||||||
| 				189DD52E26DE255300AB55B1 /* AppDelegate.m in Sources */, | 				189DD52E26DE255300AB55B1 /* AppDelegate.m in Sources */, | ||||||
| 				E83DB4842746661800D8CBD1 /* XPRoomGiftBroadcastView.m in Sources */, | 				E83DB4842746661800D8CBD1 /* XPRoomGiftBroadcastView.m in Sources */, | ||||||
| @@ -11813,7 +11819,7 @@ | |||||||
| 					"$(inherited)", | 					"$(inherited)", | ||||||
| 					"@executable_path/Frameworks", | 					"@executable_path/Frameworks", | ||||||
| 				); | 				); | ||||||
| 				MARKETING_VERSION = 20.10.0; | 				MARKETING_VERSION = 20.10.2; | ||||||
| 				PRODUCT_BUNDLE_IDENTIFIER = com.peko.enterprise.ios; | 				PRODUCT_BUNDLE_IDENTIFIER = com.peko.enterprise.ios; | ||||||
| 				PRODUCT_NAME = "$(TARGET_NAME)"; | 				PRODUCT_NAME = "$(TARGET_NAME)"; | ||||||
| 				PROVISIONING_PROFILE_SPECIFIER = ""; | 				PROVISIONING_PROFILE_SPECIFIER = ""; | ||||||
| @@ -11848,7 +11854,7 @@ | |||||||
| 					"$(inherited)", | 					"$(inherited)", | ||||||
| 					"@executable_path/Frameworks", | 					"@executable_path/Frameworks", | ||||||
| 				); | 				); | ||||||
| 				MARKETING_VERSION = 20.10.0; | 				MARKETING_VERSION = 20.10.2; | ||||||
| 				PRODUCT_BUNDLE_IDENTIFIER = com.peko.enterprise.ios; | 				PRODUCT_BUNDLE_IDENTIFIER = com.peko.enterprise.ios; | ||||||
| 				PRODUCT_NAME = "$(TARGET_NAME)"; | 				PRODUCT_NAME = "$(TARGET_NAME)"; | ||||||
| 				PROVISIONING_PROFILE_SPECIFIER = ""; | 				PROVISIONING_PROFILE_SPECIFIER = ""; | ||||||
|   | |||||||
| @@ -31,7 +31,7 @@ | |||||||
|       </Testables> |       </Testables> | ||||||
|    </TestAction> |    </TestAction> | ||||||
|    <LaunchAction |    <LaunchAction | ||||||
|       buildConfiguration = "Release" |       buildConfiguration = "Debug" | ||||||
|       selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" |       selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" | ||||||
|       selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" |       selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" | ||||||
|       launchStyle = "0" |       launchStyle = "0" | ||||||
|   | |||||||
							
								
								
									
										16
									
								
								YuMi/Appdelegate/YYTextAsyncLayer+XPTextAsyncLayer.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								YuMi/Appdelegate/YYTextAsyncLayer+XPTextAsyncLayer.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | // | ||||||
|  | //  YYTextAsyncLayer+XPTextAsyncLayer.h | ||||||
|  | //  xplan-ios | ||||||
|  | // | ||||||
|  | //  Created by duoban on 2023/10/28. | ||||||
|  | // | ||||||
|  |  | ||||||
|  | #import <YYText/YYTextAsyncLayer.h> | ||||||
|  |  | ||||||
|  | NS_ASSUME_NONNULL_BEGIN | ||||||
|  |  | ||||||
|  | @interface YYTextAsyncLayer (XPTextAsyncLayer) | ||||||
|  |  | ||||||
|  | @end | ||||||
|  |  | ||||||
|  | NS_ASSUME_NONNULL_END | ||||||
							
								
								
									
										26
									
								
								YuMi/Appdelegate/YYTextAsyncLayer+XPTextAsyncLayer.m
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								YuMi/Appdelegate/YYTextAsyncLayer+XPTextAsyncLayer.m
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | |||||||
|  | // | ||||||
|  | //  YYTextAsyncLayer+XPTextAsyncLayer.m | ||||||
|  | //  xplan-ios | ||||||
|  | // | ||||||
|  | //  Created by duoban on 2023/10/28. | ||||||
|  | // | ||||||
|  |  | ||||||
|  | #import "YYTextAsyncLayer+XPTextAsyncLayer.h" | ||||||
|  |  | ||||||
|  | @implementation YYTextAsyncLayer (XPTextAsyncLayer) | ||||||
|  | ///iOS17bug,如果不把方法替换会闪退 | ||||||
|  | +(void)load { | ||||||
|  |     Method xp_displayMethod = class_getInstanceMethod(self, @selector(display)); | ||||||
|  |     Method xp_swizzingMethod = class_getInstanceMethod(self, @selector(xp_swizzing_display)); | ||||||
|  |     method_exchangeImplementations(xp_displayMethod, xp_swizzingMethod); | ||||||
|  | } | ||||||
|  | -(void)xp_swizzing_display{ | ||||||
|  |     //通过变量名称获取类中的实例成员变量 | ||||||
|  |     if (self.bounds.size.width <= 0 || self.bounds.size.height <= 0) { | ||||||
|  |         self.contents = nil; | ||||||
|  |         return; | ||||||
|  |     } else { | ||||||
|  |         [self xp_swizzing_display]; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | @end | ||||||
| @@ -100,7 +100,8 @@ typedef NS_ENUM(NSUInteger, URLType) { | |||||||
|     kTreasureRuleURL, |     kTreasureRuleURL, | ||||||
|     ///夺宝记录 |     ///夺宝记录 | ||||||
|     kTreasureRecordURL, |     kTreasureRecordURL, | ||||||
|     kChannelUrl, |     ///第三方充值 | ||||||
|  |     kThirdPartyPay, | ||||||
| }; | }; | ||||||
|  |  | ||||||
| NSString * const URLWithType(URLType type); | NSString * const URLWithType(URLType type); | ||||||
|   | |||||||
| @@ -18,8 +18,6 @@ NSString * const URLWithType(URLType type) { | |||||||
|     prefix = [NSString stringWithFormat:@"%@o",prefix]; |     prefix = [NSString stringWithFormat:@"%@o",prefix]; | ||||||
|      |      | ||||||
|      |      | ||||||
|      |  | ||||||
|      |  | ||||||
|   NSDictionary *newDic = @{ |   NSDictionary *newDic = @{ | ||||||
|       @(kTreasureTicketBuyURL) : @"modules/act-treasureSnatching/index.html",///夺宝购买 |       @(kTreasureTicketBuyURL) : @"modules/act-treasureSnatching/index.html",///夺宝购买 | ||||||
|       @(kTreasureRankListURL)  : @"modules/act-treasureSnatching/list.html",///夺宝达人 |       @(kTreasureRankListURL)  : @"modules/act-treasureSnatching/list.html",///夺宝达人 | ||||||
| @@ -28,7 +26,7 @@ NSString * const URLWithType(URLType type) { | |||||||
|       @(kNobleRankURL)         : @"modules/noble/index.html",///排行榜 |       @(kNobleRankURL)         : @"modules/noble/index.html",///排行榜 | ||||||
|       @(kGoldEarningsRecord)   : @"modules/myincome/index.html#/GoldLog",///金币收益记录 |       @(kGoldEarningsRecord)   : @"modules/myincome/index.html#/GoldLog",///金币收益记录 | ||||||
|       @(kCandyTreeRuleURL)     : @"modules/rule/newWishingWellRule.html",///糖果树规则 modules/rank/index.html#/wishingWellRule |       @(kCandyTreeRuleURL)     : @"modules/rule/newWishingWellRule.html",///糖果树规则 modules/rank/index.html#/wishingWellRule | ||||||
|       @(kChannelUrl)           : @"modules/%@/index.html?channelType=%@&deviceId=%@", |       @(kThirdPartyPay)        : @"modules/pay/index.html?channelType=%@&deviceId=%@",///第三方充值 | ||||||
|   }; |   }; | ||||||
|     NSString * newUrl = [newDic objectForKey:@(type)]; |     NSString * newUrl = [newDic objectForKey:@(type)]; | ||||||
|     if(newUrl != nil){ |     if(newUrl != nil){ | ||||||
|   | |||||||
| @@ -49,7 +49,7 @@ isPhoneXSeries = [[UIApplication sharedApplication] delegate].window.safeAreaIns | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #define PI_App_Version @"2.1.0" | #define PI_App_Version @"2.1.2" | ||||||
| #ifdef DEBUG | #ifdef DEBUG | ||||||
| #define API_HOST_URL [NSString stringWithFormat:@"%@%@",@"http://beta.api",@".pekolive.com"] | #define API_HOST_URL [NSString stringWithFormat:@"%@%@",@"http://beta.api",@".pekolive.com"] | ||||||
|  |  | ||||||
|   | |||||||
| @@ -26,7 +26,6 @@ | |||||||
| #import "XPRoomViewController.h" | #import "XPRoomViewController.h" | ||||||
| #import "XPWebViewController.h" | #import "XPWebViewController.h" | ||||||
| #import "XPMineRechargeViewController.h" | #import "XPMineRechargeViewController.h" | ||||||
| #import "XPIAPRechargeViewController.h" |  | ||||||
| #import "XPMineUserInfoViewController.h" | #import "XPMineUserInfoViewController.h" | ||||||
| #import "XPMineSimpleUserInfoViewController.h" | #import "XPMineSimpleUserInfoViewController.h" | ||||||
| #import "XPMineDressUpViewController.h" | #import "XPMineDressUpViewController.h" | ||||||
| @@ -143,10 +142,10 @@ | |||||||
| 		case SecretaryRouterType_Purse: | 		case SecretaryRouterType_Purse: | ||||||
| 		case SecretaryRouterType_Recharge: | 		case SecretaryRouterType_Recharge: | ||||||
| 		{ | 		{ | ||||||
| //			XPMineRechargeViewController * rechargeVC = [[XPMineRechargeViewController alloc] init]; |             XPWebViewController * webVC =[[XPWebViewController alloc] init]; | ||||||
|             XPIAPRechargeViewController * rechargeVC = [[XPIAPRechargeViewController alloc] init]; |             webVC.url = [NSString stringWithFormat:URLWithType(kThirdPartyPay),@"4",[YYUtility deviceID]]; | ||||||
|                 rechargeVC.type = @"4"; |             webVC.isPush = YES; | ||||||
| 			[[XCCurrentVCStackManager shareManager].getCurrentVC.navigationController pushViewController:rechargeVC animated:YES]; |             [[XCCurrentVCStackManager shareManager].getCurrentVC.navigationController pushViewController:webVC animated:YES]; | ||||||
| 		} | 		} | ||||||
| 			break; | 			break; | ||||||
| 		case SecretaryRouterType_UserInfo: | 		case SecretaryRouterType_UserInfo: | ||||||
|   | |||||||
| @@ -28,7 +28,6 @@ | |||||||
| #import "XPMineDressUpViewController.h" | #import "XPMineDressUpViewController.h" | ||||||
| #import "XPDressUpShopCardViewController.h" | #import "XPDressUpShopCardViewController.h" | ||||||
| #import "XPMineRechargeViewController.h" | #import "XPMineRechargeViewController.h" | ||||||
| #import "XPIAPRechargeViewController.h" |  | ||||||
|  |  | ||||||
| @interface XPDressUpShopViewController ()<JXCategoryViewDelegate, JXCategoryListContainerViewDelegate, SDCycleScrollViewDelegate> | @interface XPDressUpShopViewController ()<JXCategoryViewDelegate, JXCategoryListContainerViewDelegate, SDCycleScrollViewDelegate> | ||||||
|  |  | ||||||
| @@ -233,10 +232,10 @@ | |||||||
| } | } | ||||||
|  |  | ||||||
| - (void)rechargeButtonAction:(UIButton *)sender { | - (void)rechargeButtonAction:(UIButton *)sender { | ||||||
| //    XPMineRechargeViewController *vc = [[XPMineRechargeViewController alloc] init]; |     XPWebViewController * webVC =[[XPWebViewController alloc] init]; | ||||||
|     XPIAPRechargeViewController * rechargeVC = [[XPIAPRechargeViewController alloc] init]; |        webVC.url = [NSString stringWithFormat:URLWithType(kThirdPartyPay),@"4",[YYUtility deviceID]]; | ||||||
|     rechargeVC.type = @"4"; |        webVC.isPush = YES; | ||||||
|     [self.navigationController pushViewController:rechargeVC animated:YES]; |        [self.navigationController pushViewController:webVC animated:YES]; | ||||||
| } | } | ||||||
|  |  | ||||||
| #pragma mark - Getters And Setters | #pragma mark - Getters And Setters | ||||||
|   | |||||||
| @@ -12,7 +12,6 @@ | |||||||
| #import "XPWebViewController.h" | #import "XPWebViewController.h" | ||||||
| #import "XPExchangeDiamondsVC.h" | #import "XPExchangeDiamondsVC.h" | ||||||
| #import "XPIncomeRecordGoldDetailsVC.h" | #import "XPIncomeRecordGoldDetailsVC.h" | ||||||
| #import "XPIAPRechargeViewController.h" |  | ||||||
| ///Present | ///Present | ||||||
| #import "XPIncomeRecordPresent.h" | #import "XPIncomeRecordPresent.h" | ||||||
| ///Protocol | ///Protocol | ||||||
| @@ -116,8 +115,9 @@ | |||||||
|         } |         } | ||||||
|         case ClickType_Diamond_Pay: |         case ClickType_Diamond_Pay: | ||||||
|         { |         { | ||||||
|             XPIAPRechargeViewController * webVC =[[XPIAPRechargeViewController alloc] init]; |             XPWebViewController * webVC =[[XPWebViewController alloc] init]; | ||||||
|             webVC.type = @"4"; |             webVC.url = [NSString stringWithFormat:URLWithType(kThirdPartyPay),@"4",[YYUtility deviceID]]; | ||||||
|  |             webVC.isPush = YES; | ||||||
|             [self.navigationController pushViewController:webVC animated:YES]; |             [self.navigationController pushViewController:webVC animated:YES]; | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
| @@ -138,16 +138,16 @@ | |||||||
|         default: |         default: | ||||||
|         { |         { | ||||||
|              |              | ||||||
| //            NSString * myUid = [AccountInfoStorage instance].getUid; |             NSString * myUid = [AccountInfoStorage instance].getUid; | ||||||
| //            if(![self.clanInfo.clan.elderUid isEqualToString:myUid]){ |             if(![self.clanInfo.clan.elderUid isEqualToString:myUid]){ | ||||||
|                 XPWebViewController * webVC =[[XPWebViewController alloc] init]; |                 XPWebViewController * webVC =[[XPWebViewController alloc] init]; | ||||||
|                 webVC.url = URLWithType(kGoldEarningsRecord); |                 webVC.url = URLWithType(kGoldEarningsRecord); | ||||||
|                 [self.navigationController pushViewController:webVC animated:YES]; |                 [self.navigationController pushViewController:webVC animated:YES]; | ||||||
| //                return; |                 return; | ||||||
| //                 |                  | ||||||
| //            } |             } | ||||||
| //            XPIncomeRecordGoldDetailsVC *goldDetailVC = [XPIncomeRecordGoldDetailsVC new]; |             XPIncomeRecordGoldDetailsVC *goldDetailVC = [XPIncomeRecordGoldDetailsVC new]; | ||||||
| //            [self.navigationController pushViewController:goldDetailVC animated:YES]; |             [self.navigationController pushViewController:goldDetailVC animated:YES]; | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -180,7 +180,7 @@ | |||||||
| } | } | ||||||
| - (NSArray *)listData{ | - (NSArray *)listData{ | ||||||
|     if(!_listData){ |     if(!_listData){ | ||||||
|         _listData = @[YMLocalizedString(@"XPNobleCenterPayView2"),@"Apple Pay"]; |         _listData = @[YMLocalizedString(@"XPNobleCenterPayView2")]; | ||||||
|     } |     } | ||||||
|     return _listData; |     return _listData; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -17,8 +17,8 @@ | |||||||
| #import "DJDKMIMOMColor.h" | #import "DJDKMIMOMColor.h" | ||||||
| #import "ThemeColor+NobleCenter.h" | #import "ThemeColor+NobleCenter.h" | ||||||
| #import "Api+NobleCenter.h" | #import "Api+NobleCenter.h" | ||||||
| #import "Api+Main.h" |  | ||||||
|  |  | ||||||
|  | #import "XPIAPHelper.h" | ||||||
| #import "RechargeStorage.h" | #import "RechargeStorage.h" | ||||||
| #import "AccountInfoStorage.h" | #import "AccountInfoStorage.h" | ||||||
| #import "UIImage+Utils.h" | #import "UIImage+Utils.h" | ||||||
| @@ -31,7 +31,6 @@ | |||||||
| #import "XPWebViewController.h" | #import "XPWebViewController.h" | ||||||
| #import "XPNobleSettingViewController.h" | #import "XPNobleSettingViewController.h" | ||||||
| #import "XPSkillCardPlayerManager.h" | #import "XPSkillCardPlayerManager.h" | ||||||
| #import "SessionViewController.h" |  | ||||||
| ///P | ///P | ||||||
| #import "XPNobleCenterPresenter.h" | #import "XPNobleCenterPresenter.h" | ||||||
| #import "Api+Gift.h" | #import "Api+Gift.h" | ||||||
| @@ -43,9 +42,6 @@ | |||||||
| #import "WalletInfoModel.h" | #import "WalletInfoModel.h" | ||||||
| #import "XPNobleCenterPayView.h" | #import "XPNobleCenterPayView.h" | ||||||
| #import "XPNobleCenterProtocol.h" | #import "XPNobleCenterProtocol.h" | ||||||
| #import "XPIAPRechargeViewController.h" |  | ||||||
| #import "YuMi-swift.h" |  | ||||||
| #import "ClientConfig.h" |  | ||||||
| @interface XPNobleCenterViewController ()<XPNobleCenterProtocol,XPNobleCenterPayViewDelegate,JXCategoryViewDelegate, JXCategoryListContainerViewDelegate,XPNobleCenterNavViewDelegate, NIMSystemNotificationManagerDelegate> | @interface XPNobleCenterViewController ()<XPNobleCenterProtocol,XPNobleCenterPayViewDelegate,JXCategoryViewDelegate, JXCategoryListContainerViewDelegate,XPNobleCenterNavViewDelegate, NIMSystemNotificationManagerDelegate> | ||||||
| ///分页标题 | ///分页标题 | ||||||
| @property (nonatomic, strong) NSArray<NSString *> *titles; | @property (nonatomic, strong) NSArray<NSString *> *titles; | ||||||
| @@ -82,7 +78,6 @@ | |||||||
| @property (nonatomic, assign) NSInteger roomUid; | @property (nonatomic, assign) NSInteger roomUid; | ||||||
| @property (nonatomic,strong)  WalletInfoModel * infoModel; | @property (nonatomic,strong)  WalletInfoModel * infoModel; | ||||||
| @property(nonatomic,strong) UIButton *rankBtn; | @property(nonatomic,strong) UIButton *rankBtn; | ||||||
| @property(nonatomic,assign) BOOL pi_IsNative; |  | ||||||
| @end | @end | ||||||
|  |  | ||||||
| @implementation XPNobleCenterViewController | @implementation XPNobleCenterViewController | ||||||
| @@ -96,12 +91,13 @@ | |||||||
| } | } | ||||||
|  |  | ||||||
| - (void)dealloc { | - (void)dealloc { | ||||||
|     |     [XPIAPHelper shareHelper].delegate = nil; | ||||||
| } | } | ||||||
|  |  | ||||||
| - (void)viewDidLoad { | - (void)viewDidLoad { | ||||||
|     [super viewDidLoad]; |     [super viewDidLoad]; | ||||||
|     self.pi_IsNative = YES; |      | ||||||
|  |     [XPIAPHelper shareHelper].delegate = self; | ||||||
|     [[NIMSDK sharedSDK].systemNotificationManager addDelegate:self]; |     [[NIMSDK sharedSDK].systemNotificationManager addDelegate:self]; | ||||||
|     [self requestHttp]; |     [self requestHttp]; | ||||||
|     [self initSubViews]; |     [self initSubViews]; | ||||||
| @@ -119,8 +115,8 @@ | |||||||
|         [self.presenter getUserInfo]; |         [self.presenter getUserInfo]; | ||||||
|     } |     } | ||||||
|     if([XPSkillCardPlayerManager shareInstance].isInRoom == YES && [XPSkillCardPlayerManager shareInstance].isInRoomFirstRecharge == NO){ |     if([XPSkillCardPlayerManager shareInstance].isInRoom == YES && [XPSkillCardPlayerManager shareInstance].isInRoomFirstRecharge == NO){ | ||||||
|         [XPSkillCardPlayerManager shareInstance].isInRoomFirstRecharge = YES; |             [XPSkillCardPlayerManager shareInstance].isInRoomFirstRecharge = YES; | ||||||
|     } |         } | ||||||
| } | } | ||||||
|  |  | ||||||
| - (XPNobleCenterPresenter *)createPresenter { | - (XPNobleCenterPresenter *)createPresenter { | ||||||
| @@ -199,8 +195,9 @@ | |||||||
|             config.message = YMLocalizedString(@"XPNobleCenterViewController3"); |             config.message = YMLocalizedString(@"XPNobleCenterViewController3"); | ||||||
|             config.actionStyle = TTAlertActionBothStyle; |             config.actionStyle = TTAlertActionBothStyle; | ||||||
|             [TTPopup alertWithConfig:config showBorder:NO confirmHandler:^{ |             [TTPopup alertWithConfig:config showBorder:NO confirmHandler:^{ | ||||||
|                  |                 XPWebViewController * webVC =[[XPWebViewController alloc] init]; | ||||||
|                 XPIAPRechargeViewController * webVC =[[XPIAPRechargeViewController alloc] init]; |                 webVC.url = [NSString stringWithFormat:URLWithType(kThirdPartyPay),@"5",[YYUtility deviceID]]; | ||||||
|  |                 webVC.isPush = YES; | ||||||
|                 [self.navigationController pushViewController:webVC animated:YES]; |                 [self.navigationController pushViewController:webVC animated:YES]; | ||||||
|             } cancelHandler:^{ |             } cancelHandler:^{ | ||||||
|  |  | ||||||
| @@ -211,22 +208,10 @@ | |||||||
|         [self.presenter openVipWithDiamondRoomUid:roomUid]; |         [self.presenter openVipWithDiamondRoomUid:roomUid]; | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|      |     XPWebViewController * webVC =[[XPWebViewController alloc] init]; | ||||||
|     if(self.pi_IsNative == NO){ |     webVC.url = [NSString stringWithFormat:URLWithType(kThirdPartyPay),@"5",[YYUtility deviceID]]; | ||||||
|         XPWebViewController *vc = [[XPWebViewController alloc]init]; |     webVC.isPush = YES; | ||||||
|         NSString *channel = @"p"; |     [self.navigationController pushViewController:webVC animated:YES]; | ||||||
|         channel = [NSString stringWithFormat:@"%@a",channel]; |  | ||||||
|         channel = [NSString stringWithFormat:@"%@y",channel]; |  | ||||||
|         NSString *url =  [NSString stringWithFormat:URLWithType(kChannelUrl),channel,@"5",[YYUtility deviceID]]; |  | ||||||
|         vc.url = url; |  | ||||||
|         [self.navigationController pushViewController:vc animated:YES]; |  | ||||||
|         return; |  | ||||||
|     } |  | ||||||
|      |  | ||||||
|     if(self.rechargeModel.list.count == 0)return; |  | ||||||
|     [XNDJTDDLoadingTool showOnlyView:kWindow]; |  | ||||||
|     RechargeListModel *rechargeModel = [self.rechargeModel.list safeObjectAtIndex1:0]; |  | ||||||
|     [self.presenter requestNobleIAPRechargeOrderWithChargeProdId:rechargeModel.chargeProdId roomUid:self.roomUid ? [NSString stringWithFormat:@"%zd", self.roomUid] : nil]; |  | ||||||
| } | } | ||||||
| -(void)openVipWithDiamondSuccess{ | -(void)openVipWithDiamondSuccess{ | ||||||
|     [self requestHttp]; |     [self requestHttp]; | ||||||
| @@ -247,34 +232,14 @@ | |||||||
|             self.infoModel = model; |             self.infoModel = model; | ||||||
|         } |         } | ||||||
|     }  uid:uid ticket:ticket]; |     }  uid:uid ticket:ticket]; | ||||||
|      |  | ||||||
|      |  | ||||||
|      |  | ||||||
|     if([ClientConfig shareConfig].canOpen){ |  | ||||||
|         [Api requestMineChannel:^(BaseModel * _Nullable data, NSInteger code, NSString * _Nullable msg) { |  | ||||||
|             if(code == 200){ |  | ||||||
|                 if(data.data[@"isNative"] != nil){ |  | ||||||
|                     self.pi_IsNative = [data.data[@"isNative"] boolValue]; |  | ||||||
|                     |  | ||||||
|                 } |  | ||||||
|                |  | ||||||
|             } |  | ||||||
|             |  | ||||||
|         }]; |  | ||||||
|        |  | ||||||
|     } |  | ||||||
|      |  | ||||||
| } | } | ||||||
|  |  | ||||||
| ///批量验证 | ///批量验证 | ||||||
| - (void)checkTranscationIds { | - (void)checkTranscationIds { | ||||||
|     NSString * uid = [AccountInfoStorage instance].getUid; |     NSString * uid = [AccountInfoStorage instance].getUid; | ||||||
|     NSArray * array = [RechargeStorage getAllReciptsWithUid:uid]; |     NSArray * array = [RechargeStorage getAllReciptsWithUid:uid]; | ||||||
|     for (NSDictionary *transcation in array) { |     if (array.count > 0) { | ||||||
|         NSString *orderId = transcation[@"orderId"]; |         [self.presenter checkTranscationIds:array]; | ||||||
|         NSString *transcationId = transcation[@"transcationId"]; |  | ||||||
|         ///二次验证 |  | ||||||
|          [self.presenter checkReceiptWithOrderId:orderId transcationId:transcationId errorToast:NO]; |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -319,185 +284,12 @@ | |||||||
|     self.openNobleButton.text = title; |     self.openNobleButton.text = title; | ||||||
| } | } | ||||||
|  |  | ||||||
| ///请求充值id的状态成功 |  | ||||||
| - (void)requestIAPRechargeOrderSuccess:(NSString *)orderId chargeProdId:(NSString *)chargeProdId uuid:(NSString *)uuid{ |  | ||||||
|  |  | ||||||
|     if (orderId.length > 0) { |  | ||||||
|         self.orderId  = orderId; |  | ||||||
|         if (@available(iOS 15.0, *)) { |  | ||||||
|              |  | ||||||
|             PIIAPRegulate *iap = [PIIAPRegulate shared]; |  | ||||||
|             [iap demandCommodityThingWithProductId:chargeProdId uuid:uuid completionHandler:^(NSError * _Nullable error) { |  | ||||||
|                  |  | ||||||
|             }]; |  | ||||||
|             @kWeakify(self); |  | ||||||
|             iap.ConditionBlock = ^(enum StoreConditionResult state, NSDictionary<NSString *,id> * _Nullable result) { |  | ||||||
|                 @kStrongify(self); |  | ||||||
|                  |  | ||||||
|                 [self rechargeNewProcessStatus:state]; |  | ||||||
|                 switch (state) { |  | ||||||
|                     case StoreConditionResultVerifiedServer: |  | ||||||
|                     { |  | ||||||
|                         NSString *transactionId = result[@"transactionId"]; |  | ||||||
|                          |  | ||||||
|                         [self rechargeSuccess:transactionId]; |  | ||||||
|                          |  | ||||||
|                     } |  | ||||||
|                         break; |  | ||||||
|                          |  | ||||||
|                     default: |  | ||||||
|                     { |  | ||||||
|                          |  | ||||||
|                          |  | ||||||
|                     } |  | ||||||
|                         break; |  | ||||||
|                 } |  | ||||||
|             }; |  | ||||||
|              |  | ||||||
|         } else { |  | ||||||
|             [XNDJTDDLoadingTool hideOnlyView:kWindow]; |  | ||||||
|             [self showErrorToast:YMLocalizedString(@"XPIAPRechargeViewController10")]; |  | ||||||
|         } |  | ||||||
|          |  | ||||||
|          |  | ||||||
|     } else { |  | ||||||
|         [XNDJTDDLoadingTool hideOnlyView:kWindow]; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| ///请求充值账单失败 |  | ||||||
| - (void)requestIAPRechargeOrderFail:(NSString *)message code:(NSInteger)code { |  | ||||||
|     [XNDJTDDLoadingTool hideOnlyView:kWindow]; |  | ||||||
|      |  | ||||||
|     if(code == 50000){ |  | ||||||
|          |  | ||||||
|         TTAlertConfig *config = [[TTAlertConfig alloc]init]; |  | ||||||
|         config.title = YMLocalizedString(@"XPIAPRechargeViewController7"); |  | ||||||
|         config.message = YMLocalizedString(@"XPIAPRechargeViewController8"); |  | ||||||
|         TTAlertButtonConfig *confirmButtonConfig = [[TTAlertButtonConfig alloc]init]; |  | ||||||
|         confirmButtonConfig.title = YMLocalizedString(@"XPIAPRechargeViewController9"); |  | ||||||
|         UIImage *image = [UIImage gradientColorImageFromColors:@[UIColorFromRGB(0x13E2F5),UIColorFromRGB(0x9DB4FF),UIColorFromRGB(0xCC67FF)] gradientType:GradientTypeLeftToRight imgSize:CGSizeMake(200, 200)]; |  | ||||||
|         confirmButtonConfig.backgroundColor = [UIColor colorWithPatternImage:image]; |  | ||||||
|         confirmButtonConfig.cornerRadius = 38/2; |  | ||||||
|         config.confirmButtonConfig = confirmButtonConfig; |  | ||||||
|         [TTPopup alertWithConfig:config confirmHandler:^{ |  | ||||||
|             [self.presenter getContactCustomerService]; |  | ||||||
|         } cancelHandler:^{ |  | ||||||
|         }]; |  | ||||||
|         return; |  | ||||||
|     } |  | ||||||
|      |  | ||||||
|      |  | ||||||
|     [self showErrorToast:message]; |  | ||||||
|      |  | ||||||
|      |  | ||||||
|      |  | ||||||
| } |  | ||||||
| - (void)getContactCustomerServiceSuccessWithUid:(NSString *)uid{ |  | ||||||
|     [self hideHUD]; |  | ||||||
|     dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{ |  | ||||||
|         NIMSession * session = [NIMSession session:uid type:NIMSessionTypeP2P]; |  | ||||||
|         SessionViewController * sessionVC = [[SessionViewController alloc] initWithSession:session]; |  | ||||||
|         [self.navigationController pushViewController:sessionVC animated:YES]; |  | ||||||
|     }); |  | ||||||
|      |  | ||||||
| } |  | ||||||
| ///二次校验成功 |  | ||||||
| - (void)checkReceiptSuccess:(NSString *)transcationId { |  | ||||||
|     [XNDJTDDLoadingTool hideOnlyView:kWindow]; |  | ||||||
|     if (@available(iOS 15.0, *)) { |  | ||||||
|         PIIAPRegulate *iap = [PIIAPRegulate shared]; |  | ||||||
|         [iap verifyBusinessAccomplishWithTransaction:[NSString stringWithFormat:@"%@",transcationId] completionHandler:^{ |  | ||||||
|              |  | ||||||
|         }]; |  | ||||||
|     } |  | ||||||
|     [self deleteRechageReciptWithTransactionIdentifier:transcationId]; |  | ||||||
|     self.orderId = nil; |  | ||||||
|     //5秒之后如果没有收到开通成功的云信消息,则请求一次用户信息 |  | ||||||
|     dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(5.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{ |  | ||||||
|         if (!self.userInfo.userVipInfoVO) { |  | ||||||
|             ///刷新一下用户的信息 |  | ||||||
|             [self.presenter getUserInfo]; |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
| - (void)checkReceiptFailWithCode:(NSInteger)code transcationId:(NSString *)transcationId{ |  | ||||||
|     [XNDJTDDLoadingTool hideOnlyView:kWindow]; |  | ||||||
|     if(code == 1444){ |  | ||||||
|         if (@available(iOS 15.0, *)) { |  | ||||||
|             PIIAPRegulate *iap = [PIIAPRegulate shared]; |  | ||||||
|             [iap verifyBusinessAccomplishWithTransaction:[NSString stringWithFormat:@"%@",transcationId] completionHandler:^{ |  | ||||||
|                  |  | ||||||
|             }]; |  | ||||||
|         } |  | ||||||
|         [self deleteRechageReciptWithTransactionIdentifier:transcationId]; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| ///删除本地保存的 |  | ||||||
| - (void)deleteRechageReciptWithTransactionIdentifier:(NSString *)transactionIdentifier { |  | ||||||
|     NSString * uid = [AccountInfoStorage instance].getUid; |  | ||||||
|     BOOL deleteSuccess = [RechargeStorage delegateTranscationId:transactionIdentifier uid:uid]; |  | ||||||
|     if (deleteSuccess) { |  | ||||||
| #warning to do 保存失败 需要埋点 |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| - (void)checkTranscationIdsSuccess { |  | ||||||
|     NSString * uid = [AccountInfoStorage instance].getUid; |  | ||||||
|     [RechargeStorage delegateAllTranscationIdsWithUid:uid]; |  | ||||||
| } |  | ||||||
| -(void)rankAction{ | -(void)rankAction{ | ||||||
|     XPWebViewController * webVC =[[XPWebViewController alloc] init]; |     XPWebViewController * webVC =[[XPWebViewController alloc] init]; | ||||||
|     webVC.url = URLWithType(kNobleRankURL); |     webVC.url = URLWithType(kNobleRankURL); | ||||||
|     [self.navigationController pushViewController:webVC animated:YES]; |     [self.navigationController pushViewController:webVC animated:YES]; | ||||||
| } | } | ||||||
| #pragma mark - XPIAPHelperDelegate |  | ||||||
| ///当前充值的状态 |  | ||||||
| - (void)rechargeNewProcessStatus:(StoreConditionResult)status { |  | ||||||
|  |  | ||||||
|      |  | ||||||
|     if (status == StoreConditionResultPay || status == StoreConditionResultStart || status == StoreConditionResultVerifiedServer) { |  | ||||||
|        |  | ||||||
|     }else if (status == StoreConditionResultUnowned) { |  | ||||||
|         [XNDJTDDLoadingTool hideOnlyView:kWindow]; |  | ||||||
|         [self showErrorToast:YMLocalizedString(@"XPIAPRechargeViewController1")]; |  | ||||||
|     }else{ |  | ||||||
|         [XNDJTDDLoadingTool hideOnlyView:kWindow]; |  | ||||||
|         [self showErrorToast:YMLocalizedString(@"XPIAPRechargeViewController0")]; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ///充值成功回调id |  | ||||||
| - (void)rechargeSuccess:(NSString *)transactionIdentifier { |  | ||||||
|     ///保存唯一凭证 |  | ||||||
|     [self saveRechageReciptWithTransactionIdentifier:transactionIdentifier]; |  | ||||||
|     ///二次验证 |  | ||||||
|     [self.presenter checkReceiptWithOrderId:self.orderId transcationId:transactionIdentifier errorToast:YES]; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ///充值成功之后保存订单到钥匙串 |  | ||||||
| - (void)saveRechageReciptWithTransactionIdentifier:(NSString *)transactionIdentifier { |  | ||||||
|     NSData *receipt = [NSData dataWithContentsOfURL:[[NSBundle mainBundle] appStoreReceiptURL]]; |  | ||||||
|     NSString *encodeStr = [receipt base64EncodedStringWithOptions:NSDataBase64EncodingEndLineWithLineFeed]; |  | ||||||
|     NSMutableDictionary *dictionary = [NSMutableDictionary dictionary]; |  | ||||||
|     if(transactionIdentifier != nil){ |  | ||||||
|         [dictionary setObject:transactionIdentifier forKey:@"transcationId"]; |  | ||||||
|     } |  | ||||||
|     if(encodeStr != nil){ |  | ||||||
|         [dictionary setObject:encodeStr forKey:@"recipt"]; |  | ||||||
|     } |  | ||||||
|     if(self.orderId != nil){ |  | ||||||
|         [dictionary setObject:self.orderId forKey:@"orderId"]; |  | ||||||
|     } |  | ||||||
|     if(dictionary.allKeys.count == 0)return; |  | ||||||
|     NSString *reciptJson = [dictionary toJSONString]; |  | ||||||
|     NSString * uid = [AccountInfoStorage instance].getUid; |  | ||||||
|     BOOL saveSuccess = [RechargeStorage saveTranscationId:transactionIdentifier recipt:reciptJson uid:uid]; |  | ||||||
|     if (!saveSuccess) { |  | ||||||
| #warning to do 保存失败 需要埋点 |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #pragma mark - JXCategoryViewDelegate | #pragma mark - JXCategoryViewDelegate | ||||||
| - (NSInteger)numberOfListsInlistContainerView:(JXCategoryListContainerView *)listContainerView { | - (NSInteger)numberOfListsInlistContainerView:(JXCategoryListContainerView *)listContainerView { | ||||||
|     return self.titles.count; |     return self.titles.count; | ||||||
|   | |||||||
| @@ -120,7 +120,7 @@ | |||||||
|     NSString *channel = @"p"; |     NSString *channel = @"p"; | ||||||
|     channel = [NSString stringWithFormat:@"%@a",channel]; |     channel = [NSString stringWithFormat:@"%@a",channel]; | ||||||
|     channel = [NSString stringWithFormat:@"%@y",channel]; |     channel = [NSString stringWithFormat:@"%@y",channel]; | ||||||
|     NSString *url =  [NSString stringWithFormat:URLWithType(kChannelUrl),channel,self.type,[YYUtility deviceID]]; |     NSString *url =  [NSString stringWithFormat:URLWithType(kTreasureTicketBuyURL),channel,self.type,[YYUtility deviceID]]; | ||||||
|     vc.url = url; |     vc.url = url; | ||||||
|     [self addChildViewController:vc]; |     [self addChildViewController:vc]; | ||||||
|     vc.view.frame = self.view.frame; |     vc.view.frame = self.view.frame; | ||||||
|   | |||||||
| @@ -55,13 +55,8 @@ | |||||||
| #import "XPMineCollectRoomListViewController.h" | #import "XPMineCollectRoomListViewController.h" | ||||||
| #import "XPMineMainGuildListVC.h" | #import "XPMineMainGuildListVC.h" | ||||||
| #import "XPMineGiveDiamondVC.h" | #import "XPMineGiveDiamondVC.h" | ||||||
| #import "XPIAPRechargeViewController.h" |  | ||||||
| #import "XPIncomeRecordVC.h" | #import "XPIncomeRecordVC.h" | ||||||
| #import "XPNobleCenterViewController.h" | #import "XPNobleCenterViewController.h" | ||||||
| #import "LittleGameInfoModel.h" |  | ||||||
| #import "HomeLittleGameRoomModel.h" |  | ||||||
| #import "XPLittleGameRoomOpenView.h" |  | ||||||
| #import "XPMineGameTableViewCell.h" |  | ||||||
| UIKIT_EXTERN NSString *kRequestRicket; | UIKIT_EXTERN NSString *kRequestRicket; | ||||||
|  |  | ||||||
| @interface XPMineViewController ()<UITableViewDelegate, UITableViewDataSource, XPMineProtocol, XPMineHeadItemTableViewCellDelegate, XPMineHeadViewDelegate, XPHomeBannerTableViewCellDelegate> | @interface XPMineViewController ()<UITableViewDelegate, UITableViewDataSource, XPMineProtocol, XPMineHeadItemTableViewCellDelegate, XPMineHeadViewDelegate, XPHomeBannerTableViewCellDelegate> | ||||||
| @@ -87,10 +82,6 @@ UIKIT_EXTERN NSString *kRequestRicket; | |||||||
| @property (nonatomic,assign) BOOL isRefreshRoomInfo; | @property (nonatomic,assign) BOOL isRefreshRoomInfo; | ||||||
| ///是否正在请示数据,防止过多请求 | ///是否正在请示数据,防止过多请求 | ||||||
| @property (nonatomic,assign) BOOL isRequestData; | @property (nonatomic,assign) BOOL isRequestData; | ||||||
| ///游戏列表 |  | ||||||
| @property (nonatomic, strong) NSMutableArray<LittleGameInfoModel *> *littleGameArray; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @end | @end | ||||||
|  |  | ||||||
| @implementation XPMineViewController | @implementation XPMineViewController | ||||||
| @@ -228,22 +219,8 @@ UIKIT_EXTERN NSString *kRequestRicket; | |||||||
| 			break; | 			break; | ||||||
| 		case XPMineItemType_My_Room: | 		case XPMineItemType_My_Room: | ||||||
| 		{ | 		{ | ||||||
|             NSString* roomUid = [NSString stringWithFormat:@"%ld", (long)self.userInfo.uid]; | 			NSString* roomUid = [NSString stringWithFormat:@"%ld", (long)self.userInfo.uid]; | ||||||
|             [Api getRoomInfo:^(BaseModel * _Nullable data, NSInteger code, NSString * _Nullable msg) { | 			[XPRoomViewController openRoom:roomUid viewController:self]; | ||||||
|                 if (code == 200) { |  | ||||||
|                     RoomInfoModel * roomInfo = [RoomInfoModel modelWithJSON:data.data]; |  | ||||||
|                     if (roomInfo.isReselect) { |  | ||||||
|                         XPLittleGameRoomOpenView * roomOpenView = [[XPLittleGameRoomOpenView alloc] init]; |  | ||||||
|                         roomOpenView.roomInfo = roomInfo; |  | ||||||
|                         roomOpenView.currentVC = self; |  | ||||||
|                         [TTPopup popupView:roomOpenView style:TTPopupStyleActionSheet]; |  | ||||||
|                     } else { |  | ||||||
|                         [XPRoomViewController openRoom:roomUid viewController:self]; |  | ||||||
|                     } |  | ||||||
|                 } else { |  | ||||||
|                     [self showErrorToast:msg]; |  | ||||||
|                 } |  | ||||||
|             } uid:roomUid intoUid:roomUid]; |  | ||||||
| 		} | 		} | ||||||
| 			break; | 			break; | ||||||
| 		case XPMineItemType_Collect_Room://收藏房间 | 		case XPMineItemType_Collect_Room://收藏房间 | ||||||
| @@ -431,9 +408,10 @@ UIKIT_EXTERN NSString *kRequestRicket; | |||||||
| } | } | ||||||
| ///点击充值 | ///点击充值 | ||||||
| -(void)pushThirdPartyPayVC{ | -(void)pushThirdPartyPayVC{ | ||||||
| 	XPIAPRechargeViewController * webVC =[[XPIAPRechargeViewController alloc] init]; |     XPWebViewController * webVC =[[XPWebViewController alloc] init]; | ||||||
|     webVC.type = @"4"; |     webVC.url = [NSString stringWithFormat:URLWithType(kThirdPartyPay),@"4",[YYUtility deviceID]]; | ||||||
| 	[self.navigationController pushViewController:webVC animated:YES]; |     webVC.isPush = YES; | ||||||
|  |     [self.navigationController pushViewController:webVC animated:YES]; | ||||||
| } | } | ||||||
| ///点击收益记录 | ///点击收益记录 | ||||||
| -(void)pushEarningsRecordVC{ | -(void)pushEarningsRecordVC{ | ||||||
| @@ -447,24 +425,9 @@ UIKIT_EXTERN NSString *kRequestRicket; | |||||||
| ///点击我的房间 | ///点击我的房间 | ||||||
| -(void)pushMyRoomVC{ | -(void)pushMyRoomVC{ | ||||||
| 	if(self.isRefreshRoomInfo == YES)return; | 	if(self.isRefreshRoomInfo == YES)return; | ||||||
|     self.isRefreshRoomInfo = YES; | 	self.isRefreshRoomInfo = YES; | ||||||
|     NSString* roomUid = [NSString stringWithFormat:@"%ld", (long)self.userInfo.uid]; | 	NSString* roomUid = [NSString stringWithFormat:@"%ld", (long)self.userInfo.uid]; | ||||||
|     [Api getRoomInfo:^(BaseModel * _Nullable data, NSInteger code, NSString * _Nullable msg) { | 	[XPRoomViewController openRoom:roomUid viewController:self]; | ||||||
|         self.isRefreshRoomInfo = NO; |  | ||||||
|         if (code == 200) { |  | ||||||
|             RoomInfoModel * roomInfo = [RoomInfoModel modelWithJSON:data.data]; |  | ||||||
|             if (roomInfo.isReselect) { |  | ||||||
|                 XPLittleGameRoomOpenView * roomOpenView = [[XPLittleGameRoomOpenView alloc] init]; |  | ||||||
|                 roomOpenView.roomInfo = roomInfo; |  | ||||||
|                 roomOpenView.currentVC = self; |  | ||||||
|                 [TTPopup popupView:roomOpenView style:TTPopupStyleActionSheet]; |  | ||||||
|             } else { |  | ||||||
|                 [XPRoomViewController openRoom:roomUid viewController:self]; |  | ||||||
|             } |  | ||||||
|         } else { |  | ||||||
|             [self showErrorToast:msg]; |  | ||||||
|         } |  | ||||||
|     } uid:roomUid intoUid:roomUid]; |  | ||||||
| } | } | ||||||
| #pragma mark - XPMineHeadViewDelegate | #pragma mark - XPMineHeadViewDelegate | ||||||
| ///点击头像 | ///点击头像 | ||||||
| @@ -522,21 +485,7 @@ UIKIT_EXTERN NSString *kRequestRicket; | |||||||
| - (void)onGetMineFuntionItemFailWithGroup:(dispatch_group_t)group{ | - (void)onGetMineFuntionItemFailWithGroup:(dispatch_group_t)group{ | ||||||
| 	dispatch_group_leave(group); | 	dispatch_group_leave(group); | ||||||
| } | } | ||||||
| ///获取小游戏列表 |  | ||||||
| - (void)onGetLittleGameListSuccess:(NSArray<LittleGameInfoModel *> *)items WithGroup:(nonnull dispatch_group_t)group{ |  | ||||||
|     [self.littleGameArray removeAllObjects]; |  | ||||||
|     [self.littleGameArray addObjectsFromArray:items]; |  | ||||||
|     dispatch_group_leave(group); |  | ||||||
|     NSMutableArray *array = [NSMutableArray array]; |  | ||||||
|     for (LittleGameInfoModel *item in self.littleGameArray) { |  | ||||||
|         [array addObject:item.name]; |  | ||||||
|     } |  | ||||||
|     NSString *trackName = [array componentsJoinedByString:@","]; |  | ||||||
|     [StatisticsServiceHelper trackEventWithKey:StatisticsServiceEventusercenter_quick_entry_show eventAttributes:@{@"gameName" : trackName}]; |  | ||||||
| } |  | ||||||
| - (void)onGetLittleGameListFailWithGroup:(dispatch_group_t)group{ |  | ||||||
|     dispatch_group_leave(group); |  | ||||||
| } |  | ||||||
| ///获取个人中心banner | ///获取个人中心banner | ||||||
| - (void)onGetPersonalBannerListSuccess:(NSArray<HomeBannerInfoModel *> *)items WithGroup:(nonnull dispatch_group_t)group{ | - (void)onGetPersonalBannerListSuccess:(NSArray<HomeBannerInfoModel *> *)items WithGroup:(nonnull dispatch_group_t)group{ | ||||||
| 	[self.bannerArray removeAllObjects]; | 	[self.bannerArray removeAllObjects]; | ||||||
| @@ -585,10 +534,7 @@ UIKIT_EXTERN NSString *kRequestRicket; | |||||||
| 		dispatch_group_async(group, queue, ^{ | 		dispatch_group_async(group, queue, ^{ | ||||||
| 			[self.presenter getPersonItemListWithGroup:group]; | 			[self.presenter getPersonItemListWithGroup:group]; | ||||||
| 		}); | 		}); | ||||||
|         dispatch_group_enter(group); |  | ||||||
|         dispatch_group_async(group, queue, ^{ |  | ||||||
|             [self.presenter getLittleGameListWithGroup:group]; |  | ||||||
|         }); |  | ||||||
| 		dispatch_group_enter(group); | 		dispatch_group_enter(group); | ||||||
| 		dispatch_group_async(group, queue, ^{ | 		dispatch_group_async(group, queue, ^{ | ||||||
| 			[self.presenter getMineBannerListWithGroup:group]; | 			[self.presenter getMineBannerListWithGroup:group]; | ||||||
| @@ -597,8 +543,6 @@ UIKIT_EXTERN NSString *kRequestRicket; | |||||||
|         dispatch_group_async(group, queue, ^{ |         dispatch_group_async(group, queue, ^{ | ||||||
|             [self.presenter getNobleInfoWithGroup:group]; |             [self.presenter getNobleInfoWithGroup:group]; | ||||||
|         }); |         }); | ||||||
|          |  | ||||||
|          |  | ||||||
| 		dispatch_group_notify(group,dispatch_get_main_queue(), ^{ | 		dispatch_group_notify(group,dispatch_get_main_queue(), ^{ | ||||||
| 			self.isRequestData = NO; | 			self.isRequestData = NO; | ||||||
| 			self.userInfo = userInfo; | 			self.userInfo = userInfo; | ||||||
| @@ -636,58 +580,6 @@ UIKIT_EXTERN NSString *kRequestRicket; | |||||||
| - (void)onGetClanDetailInfofailWithGroup:(dispatch_group_t)group{ | - (void)onGetClanDetailInfofailWithGroup:(dispatch_group_t)group{ | ||||||
| 	dispatch_group_leave(group); | 	dispatch_group_leave(group); | ||||||
| } | } | ||||||
|  |  | ||||||
| ///匹配游戏房成功 |  | ||||||
| - (void)quickMatchLittleGameRoomSuccess:(HomeLittleGameRoomModel *)roomInfo mgId:(NSString *)mgId { |  | ||||||
|     if (roomInfo.isPick && roomInfo.uid.length > 0) { |  | ||||||
|         [StatisticsServiceHelper trackEventWithKey:StatisticsServiceEventusercenter_quick_entrysuccess_click eventAttributes:@{@"roomUid" : roomInfo.uid}]; |  | ||||||
|         [XPRoomViewController openRoom:roomInfo.uid viewController:self]; |  | ||||||
|     } else if (roomInfo.needOpenSelfRoom) { |  | ||||||
|         NSString* roomUid = [NSString stringWithFormat:@"%ld", (long)self.userInfo.uid]; |  | ||||||
|         [StatisticsServiceHelper trackEventWithKey:StatisticsServiceEventusercenter_quick_entrysuccess_click eventAttributes:@{@"roomUid" : roomUid}]; |  | ||||||
|         [Api getRoomInfo:^(BaseModel * _Nullable data, NSInteger code, NSString * _Nullable msg) { |  | ||||||
|             if (code == 200) { |  | ||||||
|                 RoomInfoModel * roomInfo = [RoomInfoModel modelWithJSON:data.data]; |  | ||||||
|                 if (roomInfo.mgId != [mgId intValue]) {///更新房间游戏类型 |  | ||||||
|                     NSMutableDictionary * params = [NSMutableDictionary dictionary]; |  | ||||||
|                     NSString * uid = [AccountInfoStorage instance].getUid; |  | ||||||
|                     NSString * ticket = [AccountInfoStorage instance].getTicket; |  | ||||||
|                     [params setObject:ticket forKey:@"ticket"]; |  | ||||||
|                     [params setObject:uid forKey:@"uid"]; |  | ||||||
|                     [params setObject:[NSString stringWithFormat:@"%ld", roomInfo.uid] forKey:@"roomUid"]; |  | ||||||
|                     if (roomInfo.title.length > 0) { |  | ||||||
|                         [params setObject:roomInfo.title forKey:@"title"]; |  | ||||||
|                     } |  | ||||||
|                     if (roomInfo.roomPwd.length > 0) { |  | ||||||
|                         [params setObject:roomInfo.roomPwd forKey:@"roomPwd"]; |  | ||||||
|                     } else{ |  | ||||||
|                         [params setObject:@"" forKey:@"roomPwd"]; |  | ||||||
|                     } |  | ||||||
|                     if (roomInfo.tagId > 0) { |  | ||||||
|                         [params setObject:[NSString stringWithFormat:@"%ld", roomInfo.tagId] forKey:@"tagId"]; |  | ||||||
|                     } |  | ||||||
|                     [params setObject:@(RoomType_MiniGame) forKey:@"type"]; |  | ||||||
|                     [params setObject:mgId forKey:@"mgId"]; |  | ||||||
|                     [params setObject:@(roomInfo.hasAnimationEffect) forKey:@"hasAnimationEffect"]; |  | ||||||
|                     [Api ownerUpdateRoomInfo:^(BaseModel * _Nullable data, NSInteger code, NSString * _Nullable msg) { |  | ||||||
|                         if (code == 200) { |  | ||||||
|                             [XPRoomViewController openRoom:[AccountInfoStorage instance].getUid mgId:mgId viewController:self]; |  | ||||||
|                         } |  | ||||||
|                     } params:params]; |  | ||||||
|                 } |  | ||||||
|             } else { |  | ||||||
|                 [self showErrorToast:msg]; |  | ||||||
|             } |  | ||||||
|         } uid:roomUid intoUid:roomUid]; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ///匹配游戏房失败 |  | ||||||
| - (void)quickMatchLittleGameRoomFail:(NSString *)mgId { |  | ||||||
|     [XPRoomViewController openRoom:[NSString stringWithFormat:@"%ld", self.userInfo.uid] mgId:mgId viewController:self]; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #pragma mark - XPMineHeadItemTableViewCellDelegate | #pragma mark - XPMineHeadItemTableViewCellDelegate | ||||||
| - (void)xPMineHeadItemTableViewCell:(XPMineHeadItemTableViewCell *)cell didSelectItem:(XPMineFuntionItemModel *)item { | - (void)xPMineHeadItemTableViewCell:(XPMineHeadItemTableViewCell *)cell didSelectItem:(XPMineFuntionItemModel *)item { | ||||||
| 	[StatisticsServiceHelper trackEventWithKey:StatisticsServiceEventusercenter_function_click eventAttributes:@{@"functionName" : item.centerName}]; | 	[StatisticsServiceHelper trackEventWithKey:StatisticsServiceEventusercenter_function_click eventAttributes:@{@"functionName" : item.centerName}]; | ||||||
| @@ -717,11 +609,7 @@ UIKIT_EXTERN NSString *kRequestRicket; | |||||||
| 			break; | 			break; | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| #pragma mark - XPMineGameTableViewCellDelegate |  | ||||||
| ///选择了某个游戏 |  | ||||||
| - (void)xPMineGameTableViewCell:(XPMineGameTableViewCell *)cell didSelectItem:(LittleGameInfoModel *)item { |  | ||||||
|     [self.presenter quickMatchLittleGameWithMgId:item.mgId]; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #pragma mark - NSNotification | #pragma mark - NSNotification | ||||||
| - (void)onVisitorUnReadCountUpdate:(NSNotification *)noti { | - (void)onVisitorUnReadCountUpdate:(NSNotification *)noti { | ||||||
| @@ -735,6 +623,7 @@ UIKIT_EXTERN NSString *kRequestRicket; | |||||||
| 		_tableView.delegate = self; | 		_tableView.delegate = self; | ||||||
| 		_tableView.dataSource = self; | 		_tableView.dataSource = self; | ||||||
| 		_tableView.showsVerticalScrollIndicator = NO; | 		_tableView.showsVerticalScrollIndicator = NO; | ||||||
|  |         _tableView.contentInset = UIEdgeInsetsMake(0, 0, 100, 0); | ||||||
| 		_tableView.separatorStyle = UITableViewCellSeparatorStyleNone;; | 		_tableView.separatorStyle = UITableViewCellSeparatorStyleNone;; | ||||||
| 		[_tableView registerClass:[XPMineTheGuildCell class] forCellReuseIdentifier:NSStringFromClass([XPMineTheGuildCell class])]; | 		[_tableView registerClass:[XPMineTheGuildCell class] forCellReuseIdentifier:NSStringFromClass([XPMineTheGuildCell class])]; | ||||||
| 		[_tableView registerClass:[XPMinePersonalCenterCell class] forCellReuseIdentifier:NSStringFromClass([XPMinePersonalCenterCell class])]; | 		[_tableView registerClass:[XPMinePersonalCenterCell class] forCellReuseIdentifier:NSStringFromClass([XPMinePersonalCenterCell class])]; | ||||||
| @@ -767,12 +656,6 @@ UIKIT_EXTERN NSString *kRequestRicket; | |||||||
| 	} | 	} | ||||||
| 	return _functionArray; | 	return _functionArray; | ||||||
| } | } | ||||||
| - (NSMutableArray<LittleGameInfoModel *> *)littleGameArray { |  | ||||||
|     if (!_littleGameArray) { |  | ||||||
|         _littleGameArray = [NSMutableArray array]; |  | ||||||
|     } |  | ||||||
|     return _littleGameArray; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| - (NSMutableArray<HomeBannerInfoModel *> *)bannerArray { | - (NSMutableArray<HomeBannerInfoModel *> *)bannerArray { | ||||||
| 	if (!_bannerArray) { | 	if (!_bannerArray) { | ||||||
|   | |||||||
| @@ -44,7 +44,6 @@ | |||||||
| #import "XPMineUserInfoViewController.h" | #import "XPMineUserInfoViewController.h" | ||||||
| #import "XPMineSimpleUserInfoViewController.h" | #import "XPMineSimpleUserInfoViewController.h" | ||||||
| #import "XPMineRechargeViewController.h" | #import "XPMineRechargeViewController.h" | ||||||
| #import "XPIAPRechargeViewController.h" |  | ||||||
| #import "XPWebViewController.h" | #import "XPWebViewController.h" | ||||||
| #import "XPRoomViewController.h" | #import "XPRoomViewController.h" | ||||||
| #import "XPMineDressUpViewController.h" | #import "XPMineDressUpViewController.h" | ||||||
| @@ -59,7 +58,6 @@ | |||||||
| #import "XPMineCollectRoomListViewController.h" | #import "XPMineCollectRoomListViewController.h" | ||||||
| #import "XPMineFeedbackViewController.h" | #import "XPMineFeedbackViewController.h" | ||||||
| #import "XPMineSimpleUserInfoViewController.h" | #import "XPMineSimpleUserInfoViewController.h" | ||||||
| #import "XPIAPRechargeViewController.h" |  | ||||||
|  |  | ||||||
| @interface XPSimpleMineViewController ()<UITableViewDelegate, UITableViewDataSource, XPHomeBannerTableViewCellDelegate, XPMineProtocol, XPSimpleMineHeaderViewDelegate> | @interface XPSimpleMineViewController ()<UITableViewDelegate, UITableViewDataSource, XPHomeBannerTableViewCellDelegate, XPMineProtocol, XPSimpleMineHeaderViewDelegate> | ||||||
|  |  | ||||||
| @@ -137,10 +135,10 @@ | |||||||
|             break; |             break; | ||||||
|         case XPMineItemType_Account: |         case XPMineItemType_Account: | ||||||
|         { |         { | ||||||
| //            XPMineRechargeViewController * rechargeVC = [[XPMineRechargeViewController alloc] init]; |             XPWebViewController * webVC =[[XPWebViewController alloc] init]; | ||||||
|             XPIAPRechargeViewController *rechargeVC = [[XPIAPRechargeViewController alloc] init]; |             webVC.url = [NSString stringWithFormat:URLWithType(kThirdPartyPay),@"4",[YYUtility deviceID]]; | ||||||
|             rechargeVC.type = @"4"; |             webVC.isPush = YES; | ||||||
|             [self.navigationController pushViewController:rechargeVC animated:YES]; |             [self.navigationController pushViewController:webVC animated:YES]; | ||||||
|         } |         } | ||||||
|             break; |             break; | ||||||
|         case XPMineItemType_Personinfo: |         case XPMineItemType_Personinfo: | ||||||
| @@ -441,7 +439,7 @@ | |||||||
|         _tableView.contentInsetAdjustmentBehavior = UIScrollViewContentInsetAdjustmentNever; |         _tableView.contentInsetAdjustmentBehavior = UIScrollViewContentInsetAdjustmentNever; | ||||||
|         [_tableView registerClass:[XPMineItemTableViewCell class] forCellReuseIdentifier:NSStringFromClass([XPMineItemTableViewCell class])]; |         [_tableView registerClass:[XPMineItemTableViewCell class] forCellReuseIdentifier:NSStringFromClass([XPMineItemTableViewCell class])]; | ||||||
|         [_tableView registerClass:[XPHomeBannerTableViewCell class] forCellReuseIdentifier:NSStringFromClass([XPHomeBannerTableViewCell class])]; |         [_tableView registerClass:[XPHomeBannerTableViewCell class] forCellReuseIdentifier:NSStringFromClass([XPHomeBannerTableViewCell class])]; | ||||||
|         |         _tableView.contentInset = UIEdgeInsetsMake(0, 0, 100, 0); | ||||||
|     } |     } | ||||||
|     return _tableView; |     return _tableView; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -30,7 +30,6 @@ | |||||||
| #import "XCCurrentVCStackManager.h" | #import "XCCurrentVCStackManager.h" | ||||||
| #import "XPCandyTreeInsufficientBalanceView.h" | #import "XPCandyTreeInsufficientBalanceView.h" | ||||||
| #import "XPWebViewController.h" | #import "XPWebViewController.h" | ||||||
| #import "XPIAPRechargeViewController.h" |  | ||||||
| #import "XPCandyTreeBuyView.h" | #import "XPCandyTreeBuyView.h" | ||||||
| #import "XPCandyTreeConfirmBuyView.h" | #import "XPCandyTreeConfirmBuyView.h" | ||||||
| #import "XPCandyTreeBuySuccessView.h" | #import "XPCandyTreeBuySuccessView.h" | ||||||
| @@ -41,7 +40,7 @@ | |||||||
| #define KitemHeight  (20 + 5) | #define KitemHeight  (20 + 5) | ||||||
|  |  | ||||||
| UIKIT_EXTERN NSString * const kRoomReceivedCandyNotificationKey; | UIKIT_EXTERN NSString * const kRoomReceivedCandyNotificationKey; | ||||||
| @interface XPCandyTreeViewController ()<XPCandyTreeInsufficientBalanceViewDelegate,XPCandyRankContainerViewDelegate,XPCandyTreeProtocol, NIMSystemNotificationManagerDelegate,XPCandyTreeBuyViewDelegate,XPCandyTreeConfirmBuyViewDelegate,XPIAPRechargeViewControllerDelegate> | @interface XPCandyTreeViewController ()<XPCandyTreeInsufficientBalanceViewDelegate,XPCandyRankContainerViewDelegate,XPCandyTreeProtocol, NIMSystemNotificationManagerDelegate,XPCandyTreeBuyViewDelegate,XPCandyTreeConfirmBuyViewDelegate> | ||||||
| @property(nonatomic,strong) UIButton *backView; | @property(nonatomic,strong) UIButton *backView; | ||||||
|  |  | ||||||
| ///中间内容的容器 | ///中间内容的容器 | ||||||
| @@ -454,12 +453,18 @@ UIKIT_EXTERN NSString * const kRoomReceivedCandyNotificationKey; | |||||||
|  |  | ||||||
| #pragma mark -XPCandyTreeInsufficientBalanceViewDelegate | #pragma mark -XPCandyTreeInsufficientBalanceViewDelegate | ||||||
| - (void)payBalanceAction{ | - (void)payBalanceAction{ | ||||||
|     XPIAPRechargeViewController * webVC =[[XPIAPRechargeViewController alloc] init]; |  | ||||||
|     webVC.delegate = self; |     XPWebViewController * webVC =[[XPWebViewController alloc] init]; | ||||||
|     webVC.type = @"4"; |     webVC.url = [NSString stringWithFormat:URLWithType(kThirdPartyPay),@"4",[YYUtility deviceID]]; | ||||||
|  |     webVC.isPush = YES; | ||||||
|  |     @kWeakify(self) | ||||||
|  |     webVC.CloseWebViewBlock = ^(BOOL result){ | ||||||
|  |        @kStrongify(self) | ||||||
|  |         [self.presenter getCandyTreeInfo]; | ||||||
|  |     }; | ||||||
|     [[XCCurrentVCStackManager shareManager].getCurrentVC.navigationController pushViewController:webVC animated:YES]; |     [[XCCurrentVCStackManager shareManager].getCurrentVC.navigationController pushViewController:webVC animated:YES]; | ||||||
| } | } | ||||||
| #pragma mark - XPIAPRechargeViewControllerDelegate |  | ||||||
| -(void)paySuccess{ | -(void)paySuccess{ | ||||||
|     [self.presenter getLoveSettingInfo]; |     [self.presenter getLoveSettingInfo]; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| // | // | ||||||
| //  XPFirstRechargeView.h | //  XPFirstRechargeView.h | ||||||
| //  YuMi | //  xplan-ios | ||||||
| // | // | ||||||
| //  Created by YuMi on 2023/2/27. | //  Created by duoban on 2023/2/27. | ||||||
| // | // | ||||||
|  |  | ||||||
| #import <UIKit/UIKit.h> | #import <UIKit/UIKit.h> | ||||||
|   | |||||||
| @@ -1,26 +1,15 @@ | |||||||
| // | // | ||||||
| //  XPFirstRechargeView.m | //  XPFirstRechargeView.m | ||||||
| //  YuMi | //  xplan-ios | ||||||
| // | // | ||||||
| //  Created by YuMi on 2023/2/27. | //  Created by duoban on 2023/2/27. | ||||||
| // | // | ||||||
| ///Third | ///Third | ||||||
| #import <Masonry/Masonry.h> | #import <Masonry/Masonry.h> | ||||||
| #import <NIMSDK/NIMSDK.h> |  | ||||||
| ///Tool | ///Tool | ||||||
| #import <Base64/MF_Base64Additions.h> |  | ||||||
| #import "YUMIMacroUitls.h" |  | ||||||
| #import "ThemeColor+FirstRecharge.h" | #import "ThemeColor+FirstRecharge.h" | ||||||
| #import "UIImage+Utils.h" | #import "UIImage+Utils.h" | ||||||
| #import "XPFirstRechargeFlowLayout.h" | #import "XPFirstRechargeFlowLayout.h" | ||||||
| #import "NSArray+Safe.h" |  | ||||||
| #import "XNDJTDDLoadingTool.h" |  | ||||||
| #import "AccountInfoStorage.h" |  | ||||||
| #import "YYUtility.h" |  | ||||||
| #import "Api+Mine.h" |  | ||||||
| #import "Api+Main.h" |  | ||||||
|  |  | ||||||
| #import "RechargeStorage.h" |  | ||||||
| ///Model | ///Model | ||||||
| #import "FirstRechargeModel.h" | #import "FirstRechargeModel.h" | ||||||
| ///View | ///View | ||||||
| @@ -31,14 +20,11 @@ | |||||||
| #import "XPFirstRechargeProtocol.h" | #import "XPFirstRechargeProtocol.h" | ||||||
| ///VC | ///VC | ||||||
| #import "XPMineRechargeViewController.h" | #import "XPMineRechargeViewController.h" | ||||||
|  |  | ||||||
| #import "XPWebViewController.h" | #import "XPWebViewController.h" | ||||||
| #import "XPFirstRechargeView.h" | #import "XPFirstRechargeView.h" | ||||||
| #import "Api+FirstRecharge.h" | #import "Api+FirstRecharge.h" | ||||||
| #import "FirstRechargeModel.h" | #import "FirstRechargeModel.h" | ||||||
| #import "XPSkillCardPlayerManager.h" | #import "XPSkillCardPlayerManager.h" | ||||||
| #import "YuMi-swift.h" |  | ||||||
| #import "ClientConfig.h" |  | ||||||
| @interface XPFirstRechargeView ()<UICollectionViewDelegate, UICollectionViewDataSource,UICollectionViewDelegateFlowLayout> | @interface XPFirstRechargeView ()<UICollectionViewDelegate, UICollectionViewDataSource,UICollectionViewDelegateFlowLayout> | ||||||
| /// | /// | ||||||
| @property (nonatomic,strong) UIButton *backBtn; | @property (nonatomic,strong) UIButton *backBtn; | ||||||
| @@ -70,17 +56,9 @@ | |||||||
| @property (nonatomic,weak) UINavigationController * currentNav; | @property (nonatomic,weak) UINavigationController * currentNav; | ||||||
| /// | /// | ||||||
| @property (nonatomic,strong) XPFirstRechargeCollectionView *rechargeView; | @property (nonatomic,strong) XPFirstRechargeCollectionView *rechargeView; | ||||||
| @property (nonatomic,strong) FirstRechargeModel *currentInfo; |  | ||||||
| @property (nonatomic,copy) NSString *orderId; |  | ||||||
| @property(nonatomic,assign) BOOL pi_IsNative; |  | ||||||
| @end | @end | ||||||
| @implementation XPFirstRechargeView | @implementation XPFirstRechargeView | ||||||
|  |  | ||||||
| - (void)dealloc { |  | ||||||
|      |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| -(instancetype)initWithFrame:(CGRect)frame{ | -(instancetype)initWithFrame:(CGRect)frame{ | ||||||
|     self = [super initWithFrame:frame]; |     self = [super initWithFrame:frame]; | ||||||
|     if(self){ |     if(self){ | ||||||
| @@ -88,7 +66,6 @@ | |||||||
|         [self initSubViewConstraints]; |         [self initSubViewConstraints]; | ||||||
|         [self getFirstRechargeRewardList]; |         [self getFirstRechargeRewardList]; | ||||||
|         |         | ||||||
|          |  | ||||||
|     } |     } | ||||||
|     return self; |     return self; | ||||||
| } | } | ||||||
| @@ -104,22 +81,6 @@ | |||||||
|         } |         } | ||||||
|         [XNDJTDDLoadingTool showErrorWithMessage:msg]; |         [XNDJTDDLoadingTool showErrorWithMessage:msg]; | ||||||
|     }  channelType:@"3"]; |     }  channelType:@"3"]; | ||||||
|     [self checkTranscationIds]; |  | ||||||
|     if([ClientConfig shareConfig].canOpen){ |  | ||||||
|        |  | ||||||
|         [Api requestMineChannel:^(BaseModel * _Nullable data, NSInteger code, NSString * _Nullable msg) { |  | ||||||
|  |  | ||||||
|             if(code == 200){ |  | ||||||
|                 if(data.data[@"isNative"] != nil){ |  | ||||||
|                     self.pi_IsNative = [data.data[@"isNative"] boolValue]; |  | ||||||
|                     |  | ||||||
|                 } |  | ||||||
|                |  | ||||||
|             } |  | ||||||
|             |  | ||||||
|         }]; |  | ||||||
|        |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| #pragma mark - Private Method | #pragma mark - Private Method | ||||||
| - (void)initSubViews { | - (void)initSubViews { | ||||||
| @@ -211,8 +172,8 @@ | |||||||
|      |      | ||||||
|     NSString * title = model.chargeProdTitle; |     NSString * title = model.chargeProdTitle; | ||||||
|     NSString * giveMoneyStr = [NSString stringWithFormat:@"%ld", model.giveMoney]; |     NSString * giveMoneyStr = [NSString stringWithFormat:@"%ld", model.giveMoney]; | ||||||
|     NSMutableAttributedString * attribute = [[NSMutableAttributedString alloc] initWithString:title attributes:@{NSFontAttributeName:[UIFont systemFontOfSize:12], NSForegroundColorAttributeName:UIColorFromRGB(0xBE5AF6)}]; |     NSMutableAttributedString * attribute = [[NSMutableAttributedString alloc] initWithString:title attributes:@{NSFontAttributeName:kFontRegular(12), NSForegroundColorAttributeName:UIColorFromRGB(0xBE5AF6)}]; | ||||||
|     [attribute addAttribute:NSFontAttributeName     value:[UIFont systemFontOfSize:12 weight:UIFontWeightSemibold] range:[title rangeOfString:giveMoneyStr]]; |     [attribute addAttribute:NSFontAttributeName     value:kFontSemibold(12) range:[title rangeOfString:giveMoneyStr]]; | ||||||
|     [self.extraButton setAttributedTitle:attribute forState:UIControlStateNormal]; |     [self.extraButton setAttributedTitle:attribute forState:UIControlStateNormal]; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -221,7 +182,6 @@ | |||||||
|     if (array.count <= 0) return; |     if (array.count <= 0) return; | ||||||
|     self.typeArrowView.hidden = NO; |     self.typeArrowView.hidden = NO; | ||||||
|     self.originArray = array; |     self.originArray = array; | ||||||
|     self.currentInfo = [array safeObjectAtIndex1:0]; |  | ||||||
|     if (self.segmentView.arrangedSubviews.count > 0) { |     if (self.segmentView.arrangedSubviews.count > 0) { | ||||||
|         [[self.segmentView arrangedSubviews] enumerateObjectsUsingBlock:^(__kindof UIView * _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) { |         [[self.segmentView arrangedSubviews] enumerateObjectsUsingBlock:^(__kindof UIView * _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) { | ||||||
|             [obj removeFromSuperview]; |             [obj removeFromSuperview]; | ||||||
| @@ -229,11 +189,11 @@ | |||||||
|     } |     } | ||||||
|     for (int i = 0 ; i < array.count; i++) { |     for (int i = 0 ; i < array.count; i++) { | ||||||
|         FirstRechargeModel * modelInfo = [array safeObjectAtIndex1:i]; |         FirstRechargeModel * modelInfo = [array safeObjectAtIndex1:i]; | ||||||
|         NSString * title = [NSString stringWithFormat:@"$%.2f", modelInfo.chargeMoney]; |         NSString * title = [NSString stringWithFormat:@"$%.2f ", modelInfo.chargeMoney]; | ||||||
|         UIButton * button = [UIButton buttonWithType:UIButtonTypeCustom]; |         UIButton * button = [UIButton buttonWithType:UIButtonTypeCustom]; | ||||||
|         [button setTitleColor:[UIColor whiteColor] forState:UIControlStateSelected]; |         [button setTitleColor:[UIColor whiteColor] forState:UIControlStateSelected]; | ||||||
|         [button setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal]; |         [button setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal]; | ||||||
|         button.titleLabel.font = [UIFont systemFontOfSize:15 weight:UIFontWeightMedium]; |         button.titleLabel.font = kFontMedium(15); | ||||||
|         [button setTitle:title forState:UIControlStateNormal]; |         [button setTitle:title forState:UIControlStateNormal]; | ||||||
|         [button setTitle:title forState:UIControlStateSelected]; |         [button setTitle:title forState:UIControlStateSelected]; | ||||||
|         button.tag = i; |         button.tag = i; | ||||||
| @@ -281,232 +241,17 @@ | |||||||
|     return cell; |     return cell; | ||||||
| } | } | ||||||
|  |  | ||||||
| #pragma mark - 充值 |  | ||||||
| /// 获取充值的订单编号 |  | ||||||
| /// @param chargeProdId  苹果服务器的充值 的id |  | ||||||
| - (void)requestIAPRechargeOrderWithChargeProdId:(NSString *)chargeProdId { |  | ||||||
|      |  | ||||||
|     NSString * uid = [AccountInfoStorage instance].getUid; |  | ||||||
|     NSString * ticket = [AccountInfoStorage instance].getTicket; |  | ||||||
|     NSString * deviceInfo = [YYUtility deviceID]; |  | ||||||
|     NSString * clientIp= [YYUtility ipAddress]; |  | ||||||
|     [Api requestIAPRecharge:^(BaseModel * _Nullable data, NSInteger code, NSString * _Nullable msg) { |  | ||||||
|         if (code == 200) { |  | ||||||
|             NSString *orderId = (NSString *)data.data[@"recordId"]; |  | ||||||
|             NSString *uuid = (NSString *)data.data[@"appAccountToken"]; |  | ||||||
|             [self requestIAPRechargeOrderSuccess:orderId chargeProdId:chargeProdId uuid:uuid]; |  | ||||||
|         } else { |  | ||||||
|             [XNDJTDDLoadingTool hideOnlyView:kWindow]; |  | ||||||
|             if(code == 50000){ |  | ||||||
|                 if(self.delegate && [self.delegate respondsToSelector:@selector(contactCustomerService)]){ |  | ||||||
|                     [self.delegate contactCustomerService]; |  | ||||||
|                 } |  | ||||||
|                 [self backAction]; |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|             [XNDJTDDLoadingTool showErrorWithMessage:msg]; |  | ||||||
|         } |  | ||||||
|     } chargeProdId:chargeProdId uid:uid ticket:ticket deviceInfo:deviceInfo clientIp:clientIp]; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| - (void)requestIAPRechargeOrderSuccess:(NSString *)orderId chargeProdId:(NSString *)chargeProdId uuid:(NSString *)uuid{ |  | ||||||
|     if (orderId.length > 0) { |  | ||||||
|         self.orderId  = orderId; |  | ||||||
|          |  | ||||||
|         if (@available(iOS 15.0, *)) { |  | ||||||
|              |  | ||||||
|             PIIAPRegulate *iap = [PIIAPRegulate shared]; |  | ||||||
|             [iap demandCommodityThingWithProductId:chargeProdId uuid:uuid completionHandler:^(NSError * _Nullable error) { |  | ||||||
|                  |  | ||||||
|             }]; |  | ||||||
|             @kWeakify(self); |  | ||||||
|             iap.ConditionBlock = ^(enum StoreConditionResult state, NSDictionary<NSString *,id> * _Nullable result) { |  | ||||||
|                 @kStrongify(self); |  | ||||||
|                  |  | ||||||
|                 [self rechargeNewProcessStatus:state]; |  | ||||||
|                 switch (state) { |  | ||||||
|                     case StoreConditionResultVerifiedServer: |  | ||||||
|                     { |  | ||||||
|                         NSString *transactionId = result[@"transactionId"]; |  | ||||||
|                          |  | ||||||
|                         [self rechargeSuccess:transactionId]; |  | ||||||
|                          |  | ||||||
|                     } |  | ||||||
|                         break; |  | ||||||
|                          |  | ||||||
|                     default: |  | ||||||
|                     { |  | ||||||
|                          |  | ||||||
|                          |  | ||||||
|                     } |  | ||||||
|                         break; |  | ||||||
|                 } |  | ||||||
|             }; |  | ||||||
|              |  | ||||||
|         } else { |  | ||||||
|             [XNDJTDDLoadingTool hideOnlyView:kWindow]; |  | ||||||
|             [XNDJTDDLoadingTool showErrorWithMessage:YMLocalizedString(@"XPIAPRechargeViewController10")]; |  | ||||||
|         } |  | ||||||
|          |  | ||||||
|          |  | ||||||
|     }else{ |  | ||||||
|         [XNDJTDDLoadingTool hideOnlyView:kWindow]; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| #pragma mark - XPIAPHelperDelegate |  | ||||||
|  |  | ||||||
| ///当前充值的状态 |  | ||||||
| - (void)rechargeNewProcessStatus:(StoreConditionResult)status { |  | ||||||
|  |  | ||||||
|      |  | ||||||
|     if (status == StoreConditionResultPay || status == StoreConditionResultStart || status == StoreConditionResultVerifiedServer) { |  | ||||||
|         |  | ||||||
|     }else if (status == StoreConditionResultUnowned) { |  | ||||||
|         [XNDJTDDLoadingTool hideOnlyView:kWindow]; |  | ||||||
|         [XNDJTDDLoadingTool showErrorWithMessage:YMLocalizedString(@"XPIAPRechargeViewController1")]; |  | ||||||
|     }else{ |  | ||||||
|         [XNDJTDDLoadingTool hideOnlyView:kWindow]; |  | ||||||
|         [XNDJTDDLoadingTool showErrorWithMessage:YMLocalizedString(@"XPIAPRechargeViewController0")]; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ///充值成功回调id |  | ||||||
| - (void)rechargeSuccess:(NSString *)transactionIdentifier { |  | ||||||
|     ///保存唯一凭证 |  | ||||||
|     [self saveRechageReciptWithTransactionIdentifier:transactionIdentifier]; |  | ||||||
|     ///二次验证 |  | ||||||
|     [self checkReceiptWithOrderId:self.orderId transcationId:transactionIdentifier errorToast:YES]; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ///充值成功之后保存订单到钥匙串 |  | ||||||
| - (void)saveRechageReciptWithTransactionIdentifier:(NSString *)transactionIdentifier { |  | ||||||
|     NSData *receipt = [NSData dataWithContentsOfURL:[[NSBundle mainBundle] appStoreReceiptURL]]; |  | ||||||
|     NSString *encodeStr = [receipt base64EncodedStringWithOptions:NSDataBase64EncodingEndLineWithLineFeed]; |  | ||||||
|     NSMutableDictionary *dictionary = [NSMutableDictionary dictionary]; |  | ||||||
|     if(transactionIdentifier != nil){ |  | ||||||
|         [dictionary setObject:transactionIdentifier forKey:@"transcationId"]; |  | ||||||
|     } |  | ||||||
|     if(encodeStr != nil){ |  | ||||||
|         [dictionary setObject:encodeStr forKey:@"recipt"]; |  | ||||||
|     } |  | ||||||
|     if(self.orderId != nil){ |  | ||||||
|         [dictionary setObject:self.orderId forKey:@"orderId"]; |  | ||||||
|     } |  | ||||||
|     if(dictionary.allKeys.count == 0)return; |  | ||||||
|     NSString *reciptJson = [dictionary toJSONString]; |  | ||||||
|     NSString * uid = [AccountInfoStorage instance].getUid; |  | ||||||
|     BOOL saveSuccess = [RechargeStorage saveTranscationId:transactionIdentifier recipt:reciptJson uid:uid]; |  | ||||||
|     if (!saveSuccess) { |  | ||||||
| #warning to do 保存失败 需要埋点 |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ///删除本地保存的 |  | ||||||
| - (void)deleteRechageReciptWithTransactionIdentifier:(NSString *)transactionIdentifier { |  | ||||||
|     NSString * uid = [AccountInfoStorage instance].getUid; |  | ||||||
|     BOOL deleteSuccess = [RechargeStorage delegateTranscationId:transactionIdentifier uid:uid]; |  | ||||||
|     if (deleteSuccess) { |  | ||||||
| #warning to do 保存失败 需要埋点 |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| ///批量验证 |  | ||||||
| - (void)checkTranscationIds { |  | ||||||
|     NSString * uid = [AccountInfoStorage instance].getUid; |  | ||||||
|     NSArray * array = [RechargeStorage getAllReciptsWithUid:uid]; |  | ||||||
|     |  | ||||||
| //    [self.presenter checkReceiptWithOrderId:self.orderId transcationId:transactionIdentifier]; |  | ||||||
| //    NSMutableArray *list = [NSMutableArray array]; |  | ||||||
| //    for (NSDictionary *transcationDic in array) { |  | ||||||
| //        NSString *transcationId = transcationDic[@"transcationId"]; |  | ||||||
| //        if(transcationId){ |  | ||||||
| //            [list addObject:transcationId]; |  | ||||||
| //        } |  | ||||||
| //    } |  | ||||||
| //    if(list.count > 0){ |  | ||||||
| //        if (@available(iOS 15.0, *)) { |  | ||||||
| //            PIIAPRegulate *iap = [PIIAPRegulate shared]; |  | ||||||
| //            [iap allTransactionWithList:list completionHandler:^{ |  | ||||||
| // |  | ||||||
| //            }]; |  | ||||||
| // |  | ||||||
| //        } |  | ||||||
| //    } |  | ||||||
|      |  | ||||||
|     for (NSDictionary *transcation in array) { |  | ||||||
|         NSString *orderId = transcation[@"orderId"]; |  | ||||||
|         NSString *transcationId = transcation[@"transcationId"]; |  | ||||||
|         ///二次验证 |  | ||||||
|         [self checkReceiptWithOrderId:orderId transcationId:transcationId errorToast:NO] ; |  | ||||||
|     } |  | ||||||
|     |  | ||||||
| } |  | ||||||
| - (void)checkReceiptWithOrderId:(NSString *)orderId transcationId:(NSString *)transcationId errorToast:(BOOL)errorToast{ |  | ||||||
|     NSString * uid = [AccountInfoStorage instance].getUid; |  | ||||||
|     NSString * ticket = [AccountInfoStorage instance].getTicket; |  | ||||||
|      |  | ||||||
|     [Api checkReceipt:^(BaseModel * _Nullable data, NSInteger code, NSString * _Nullable msg) { |  | ||||||
|         [XNDJTDDLoadingTool hideOnlyView:kWindow]; |  | ||||||
|         if (code == 200) { |  | ||||||
|             [self checkReceiptSuccess:transcationId]; |  | ||||||
|         } else { |  | ||||||
|             if(code == 1444){ |  | ||||||
|                 if (@available(iOS 15.0, *)) { |  | ||||||
|                     PIIAPRegulate *iap = [PIIAPRegulate shared]; |  | ||||||
|                     [iap verifyBusinessAccomplishWithTransaction:[NSString stringWithFormat:@"%@",transcationId] completionHandler:^{ |  | ||||||
|                          |  | ||||||
|                     }]; |  | ||||||
|                 } |  | ||||||
|                 [self deleteRechageReciptWithTransactionIdentifier:transcationId]; |  | ||||||
|             } |  | ||||||
|             if(errorToast == YES){ |  | ||||||
|                 [XNDJTDDLoadingTool showErrorWithMessage:msg]; |  | ||||||
|             } |  | ||||||
|             |  | ||||||
|         } |  | ||||||
|     }  chooseEnv:@"true" chargeRecordId:orderId transcationId:transcationId uid:uid ticket:ticket]; |  | ||||||
|     |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ///二次验证成功 |  | ||||||
| - (void)checkReceiptSuccess:(NSString *)transcationId { |  | ||||||
|     if (@available(iOS 15.0, *)) { |  | ||||||
|         PIIAPRegulate *iap = [PIIAPRegulate shared]; |  | ||||||
|         [iap verifyBusinessAccomplishWithTransaction:[NSString stringWithFormat:@"%@",transcationId] completionHandler:^{ |  | ||||||
|              |  | ||||||
|         }]; |  | ||||||
|     } |  | ||||||
|     [self deleteRechageReciptWithTransactionIdentifier:transcationId]; |  | ||||||
|     self.orderId = nil; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #pragma mark - Event Response | #pragma mark - Event Response | ||||||
|  |  | ||||||
|  |  | ||||||
| - (void)rewardHelpButtonAction:(UIButton *)sender { | - (void)rewardHelpButtonAction:(UIButton *)sender { | ||||||
|     sender.selected = !sender.selected; |     sender.selected = !sender.selected; | ||||||
|     self.descripBgView.hidden = !sender.selected; |     self.descripBgView.hidden = !sender.selected; | ||||||
| } | } | ||||||
|  |  | ||||||
| - (void)rechargeButtonAction { | - (void)rechargeButtonAction { | ||||||
|      |     if(self.delegate && [self.delegate respondsToSelector:@selector(rechargeHandle)]){ | ||||||
|     if(self.pi_IsNative == NO){ |         [self.delegate rechargeHandle]; | ||||||
|         if(self.delegate && [self.delegate respondsToSelector:@selector(rechargeHandle)]){ |  | ||||||
|             [self.delegate rechargeHandle]; |  | ||||||
|         } |  | ||||||
|         [self backAction]; |  | ||||||
|         return; |  | ||||||
|     } |  | ||||||
|      |  | ||||||
|     if (self.currentInfo == nil|| self.currentInfo.chargeProdId == nil) { |  | ||||||
|         return; |  | ||||||
|     } |  | ||||||
|     FirstRechargeModel *model = self.currentInfo; |  | ||||||
|     if (model.chargeProdId) { |  | ||||||
|         [XNDJTDDLoadingTool showOnlyView:kWindow]; |  | ||||||
|         [self requestIAPRechargeOrderWithChargeProdId:model.chargeProdId]; |  | ||||||
|     } |     } | ||||||
|  |     [self backAction];    | ||||||
| } | } | ||||||
| -(void)backAction{ | -(void)backAction{ | ||||||
|     [self removeFromSuperview]; |     [self removeFromSuperview]; | ||||||
| @@ -514,7 +259,6 @@ | |||||||
| - (void)buttonAction:(UIButton *)sender { | - (void)buttonAction:(UIButton *)sender { | ||||||
|     if (sender.tag <= self.originArray.count) { |     if (sender.tag <= self.originArray.count) { | ||||||
|         FirstRechargeModel * model = [self.originArray safeObjectAtIndex1:sender.tag]; |         FirstRechargeModel * model = [self.originArray safeObjectAtIndex1:sender.tag]; | ||||||
|         self.currentInfo = model; |  | ||||||
|         [self createExtraRewardAttrebute:model]; |         [self createExtraRewardAttrebute:model]; | ||||||
|         self.rewardArray = model.firstChargeRewardList; |         self.rewardArray = model.firstChargeRewardList; | ||||||
|         self.collectionView.hidden = self.rewardArray.count < 2; |         self.collectionView.hidden = self.rewardArray.count < 2; | ||||||
| @@ -598,7 +342,7 @@ | |||||||
| - (UIButton *)extraButton { | - (UIButton *)extraButton { | ||||||
|     if (!_extraButton) { |     if (!_extraButton) { | ||||||
|         _extraButton = [UIButton buttonWithType:UIButtonTypeCustom]; |         _extraButton = [UIButton buttonWithType:UIButtonTypeCustom]; | ||||||
|         [_extraButton setBackgroundImage:[UIImage imageNamed:@"room_first_recharge_extra"] forState:UIControlStateNormal]; |         [_extraButton setBackgroundImage:kImage(@"room_first_recharge_extra") forState:UIControlStateNormal]; | ||||||
|          |          | ||||||
|     } |     } | ||||||
|     return _extraButton; |     return _extraButton; | ||||||
| @@ -653,7 +397,7 @@ | |||||||
|         [_rechargeButton setBackgroundImage:[UIImage imageNamed:@"room_first_recharge_recharge"] forState:UIControlStateNormal]; |         [_rechargeButton setBackgroundImage:[UIImage imageNamed:@"room_first_recharge_recharge"] forState:UIControlStateNormal]; | ||||||
|         [_rechargeButton setBackgroundImage:[UIImage imageNamed:@"room_first_recharge_recharge"] forState:UIControlStateSelected]; |         [_rechargeButton setBackgroundImage:[UIImage imageNamed:@"room_first_recharge_recharge"] forState:UIControlStateSelected]; | ||||||
|         [_rechargeButton setTitle:YMLocalizedString(@"XPFirstRechargeViewController1") forState:UIControlStateNormal]; |         [_rechargeButton setTitle:YMLocalizedString(@"XPFirstRechargeViewController1") forState:UIControlStateNormal]; | ||||||
|         _rechargeButton.titleLabel.font = [UIFont systemFontOfSize:18 weight:UIFontWeightSemibold]; |         _rechargeButton.titleLabel.font = kFontSemibold(18); | ||||||
|         [_rechargeButton setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal]; |         [_rechargeButton setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal]; | ||||||
|         [_rechargeButton addTarget:self action:@selector(rechargeButtonAction) forControlEvents:UIControlEventTouchUpInside]; |         [_rechargeButton addTarget:self action:@selector(rechargeButtonAction) forControlEvents:UIControlEventTouchUpInside]; | ||||||
|     } |     } | ||||||
| @@ -662,7 +406,7 @@ | |||||||
| - (UIImageView *)typeArrowView{ | - (UIImageView *)typeArrowView{ | ||||||
|     if (!_typeArrowView){ |     if (!_typeArrowView){ | ||||||
|         _typeArrowView = [UIImageView new]; |         _typeArrowView = [UIImageView new]; | ||||||
|         _typeArrowView.image = [UIImage imageNamed:@"room_first_recharge_recharge_arrow"]; |         _typeArrowView.image = kImage(@"room_first_recharge_recharge_arrow"); | ||||||
|         _typeArrowView.hidden = YES; |         _typeArrowView.hidden = YES; | ||||||
|     } |     } | ||||||
|     return _typeArrowView; |     return _typeArrowView; | ||||||
|   | |||||||
| @@ -1202,18 +1202,19 @@ | |||||||
| 		CGFloat scale = image.size.width / image.size.height; | 		CGFloat scale = image.size.width / image.size.height; | ||||||
| 		imageView.bounds = CGRectMake(0, 0, 18 * scale, 18); | 		imageView.bounds = CGRectMake(0, 0, 18 * scale, 18); | ||||||
| 	} else { | 	} else { | ||||||
| 		NSURL *imgUrl = [NSURL URLWithString:imageName]; | //		NSURL *imgUrl = [NSURL URLWithString:imageName]; | ||||||
| 		UIImage *myImage = [UIImage imageWithData:[NSData dataWithContentsOfURL:imgUrl]]; | // | ||||||
| 		if (myImage) { | //		UIImage *myImage = [UIImage imageWithData:[NSData dataWithContentsOfURL:imgUrl]]; | ||||||
| 			CGFloat scale = myImage.size.width / myImage.size.height; | //		if (myImage) { | ||||||
| 			if (scale == 0) { | //			CGFloat scale = myImage.size.width / myImage.size.height; | ||||||
| 				imageView.bounds = CGRectMake(0, 0, 60, 18); | //			if (scale == 0) { | ||||||
| 			}else { | //				imageView.bounds = CGRectMake(0, 0, 60, 18); | ||||||
| 				imageView.bounds = CGRectMake(0, 0, 18* scale, 18); | //			}else { | ||||||
| 			} | //				imageView.bounds = CGRectMake(0, 0, 18* scale, 18); | ||||||
| 		} else { | //			} | ||||||
|  | //		} else { | ||||||
| 			imageView.bounds = CGRectMake(0, 0, 60, 18); | 			imageView.bounds = CGRectMake(0, 0, 60, 18); | ||||||
| 		} | //		} | ||||||
| 	} | 	} | ||||||
| 	imageView.contentMode = UIViewContentModeScaleAspectFit; | 	imageView.contentMode = UIViewContentModeScaleAspectFit; | ||||||
| 	// 铭牌文字 | 	// 铭牌文字 | ||||||
|   | |||||||
| @@ -74,6 +74,7 @@ NSString * const kRoomShowTopicKey = @"kRoomShowTopicKey"; | |||||||
| ///是否是大的  只有在小游戏的时候有用 | ///是否是大的  只有在小游戏的时候有用 | ||||||
| @property (nonatomic,assign) BOOL isLarge; | @property (nonatomic,assign) BOOL isLarge; | ||||||
| @property(nonatomic,strong) PIRoomPhotoAlbumItemModel *lookUpModel; | @property(nonatomic,strong) PIRoomPhotoAlbumItemModel *lookUpModel; | ||||||
|  | @property(nonatomic,assign) BOOL isLoadHistoryMessage; | ||||||
| @end | @end | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -86,6 +87,7 @@ NSString * const kRoomShowTopicKey = @"kRoomShowTopicKey"; | |||||||
| - (instancetype)initWithDelegate:(id<RoomHostDelegate>)delegate { | - (instancetype)initWithDelegate:(id<RoomHostDelegate>)delegate { | ||||||
| 	self = [super init]; | 	self = [super init]; | ||||||
| 	if (self) { | 	if (self) { | ||||||
|  |         self.isLoadHistoryMessage = YES; | ||||||
| 		self.hostDelegate = delegate; | 		self.hostDelegate = delegate; | ||||||
| 		[self initSubViews]; | 		[self initSubViews]; | ||||||
| 		[self initSubViewConstraints]; | 		[self initSubViewConstraints]; | ||||||
| @@ -286,6 +288,7 @@ NSString * const kRoomShowTopicKey = @"kRoomShowTopicKey"; | |||||||
| #pragma mark - 添加数据并且做自动滚动 | #pragma mark - 添加数据并且做自动滚动 | ||||||
| ///添加信息 | ///添加信息 | ||||||
| - (void)addRoomMessage:(NIMMessage *)message { | - (void)addRoomMessage:(NIMMessage *)message { | ||||||
|  |     if(self.isLoadHistoryMessage == YES)return; | ||||||
| 	[self.incomingMessages addObject:message]; | 	[self.incomingMessages addObject:message]; | ||||||
| 	if (!self.isMiniEnter) {/// 最小化进房的话 不需要重新保存 | 	if (!self.isMiniEnter) {/// 最小化进房的话 不需要重新保存 | ||||||
| 		if (self.hostDelegate.getRoomInfo.isCloseScreen) { | 		if (self.hostDelegate.getRoomInfo.isCloseScreen) { | ||||||
| @@ -711,78 +714,99 @@ NSString * const kRoomShowTopicKey = @"kRoomShowTopicKey"; | |||||||
|                 option.order = NIMMessageSearchOrderDesc; |                 option.order = NIMMessageSearchOrderDesc; | ||||||
|                 option.messageTypes = @[@(NIMMessageTypeText)]; |                 option.messageTypes = @[@(NIMMessageTypeText)]; | ||||||
|                 [[NIMSDK sharedSDK].chatroomManager fetchMessageHistory:roomId option:option result:^(NSError * _Nullable error, NSArray<NIMMessage *> * _Nullable messages) { |                 [[NIMSDK sharedSDK].chatroomManager fetchMessageHistory:roomId option:option result:^(NSError * _Nullable error, NSArray<NIMMessage *> * _Nullable messages) { | ||||||
|                     if (self.datasource.count > kRoomMessageMaxLength) { |                     dispatch_async(dispatch_get_main_queue(), ^{///富文本会操作UI,需要回到主线程操作UI,防止加载卡顿 | ||||||
|                         NSIndexSet *set = [NSIndexSet indexSetWithIndexesInRange:NSMakeRange(0, kRoomMessageMaxLength/2)]; |                         if (self.datasource.count > kRoomMessageMaxLength) { | ||||||
|                         NSArray *needRemoveMsgArray = [self.datasource objectsAtIndexes:set]; |                             NSIndexSet *set = [NSIndexSet indexSetWithIndexesInRange:NSMakeRange(0, kRoomMessageMaxLength/2)]; | ||||||
|                         [self.datasource removeObjectsInArray:needRemoveMsgArray]; |                             NSArray *needRemoveMsgArray = [self.datasource objectsAtIndexes:set]; | ||||||
|                     } |                             [self.datasource removeObjectsInArray:needRemoveMsgArray]; | ||||||
|                     // 执行插入 |                         } | ||||||
|                     for (NIMMessage *item in messages.reverseObjectEnumerator) { |                         // 执行插入 | ||||||
|                         [self.datasource addObject:[self.messageParser parseMessageAttribute:item]]; |                         for (NIMMessage *item in messages.reverseObjectEnumerator) { | ||||||
|                         if (!self.isMiniEnter) {/// 最小化进房的话 不需要重新保存 |                             [self.datasource addObject:[self.messageParser parseMessageAttribute:item]]; | ||||||
|                             if (self.hostDelegate.getRoomInfo.isCloseScreen) { |                             if (!self.isMiniEnter) {/// 最小化进房的话 不需要重新保存 | ||||||
|                                 NIMCustomObject *obj = (NIMCustomObject *)item.messageObject; |                                 if (self.hostDelegate.getRoomInfo.isCloseScreen) { | ||||||
|                                 if (obj.attachment != nil && [obj.attachment isKindOfClass:[AttachmentModel class]]) { |                                     NIMCustomObject *obj = (NIMCustomObject *)item.messageObject; | ||||||
|                                     AttachmentModel *attachment = (AttachmentModel *)obj.attachment; |                                     if (obj.attachment != nil && [obj.attachment isKindOfClass:[AttachmentModel class]]) { | ||||||
|                                     if (attachment.first == CustomMessageType_Update_RoomInfo && attachment.second == Custom_Message_Sub_Update_RoomInfo_MessageState){ |                                         AttachmentModel *attachment = (AttachmentModel *)obj.attachment; | ||||||
|                                         [[XPRoomMiniManager shareManager] saveRoomMessage:item]; |                                         if (attachment.first == CustomMessageType_Update_RoomInfo && attachment.second == Custom_Message_Sub_Update_RoomInfo_MessageState){ | ||||||
|  |                                             [[XPRoomMiniManager shareManager] saveRoomMessage:item]; | ||||||
|  |                                         } | ||||||
|                                     } |                                     } | ||||||
|  |                                 } else { | ||||||
|  |                                     [[XPRoomMiniManager shareManager] saveRoomMessage:item]; | ||||||
|                                 } |                                 } | ||||||
|                             } else { |  | ||||||
|                                 [[XPRoomMiniManager shareManager] saveRoomMessage:item]; |  | ||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|                     } |                         self.isLoadHistoryMessage = NO; | ||||||
|                     [self.messageTableView reloadData]; |                         [self.messageTableView reloadData]; | ||||||
|                     //执行插入动画并滚动 |                         //执行插入动画并滚动 | ||||||
|                     [self scrollToBottom:YES]; |                         [self scrollToBottom:YES]; | ||||||
|                     BOOL hideEnter = [self handleHideEnter:message]; |                         BOOL hideEnter = [self handleHideEnter:message]; | ||||||
|                     if (!hideEnter) { |                         if (!hideEnter) { | ||||||
|                         ///插入进房消息及房间公告提示 |                             ///插入进房消息及房间公告提示 | ||||||
|                         [self addRoomMessage:message]; |                             [self addRoomMessage:message]; | ||||||
|                     } |                         } | ||||||
|                     if (!roomInfo.hasAnimationEffect) { |                         if (!roomInfo.hasAnimationEffect) { | ||||||
|                         [self roomInfoNoGiftAnimationMessage:message]; |                             [self roomInfoNoGiftAnimationMessage:message]; | ||||||
|                     } |                         } | ||||||
|                     [self createUserEnterRoomAddRoomtopicMessage]; |                         [self createUserEnterRoomAddRoomtopicMessage]; | ||||||
|                 }]; |                      }); | ||||||
|  |                     }]; | ||||||
|  |                 | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (self.datasource.count > kRoomMessageMaxLength) { |             dispatch_async(dispatch_get_main_queue(), ^{ | ||||||
|                 NSIndexSet *set = [NSIndexSet indexSetWithIndexesInRange:NSMakeRange(0, kRoomMessageMaxLength/2)]; |                 if (self.datasource.count > kRoomMessageMaxLength) { | ||||||
|                 NSArray *needRemoveMsgArray = [self.datasource objectsAtIndexes:set]; |                     NSIndexSet *set = [NSIndexSet indexSetWithIndexesInRange:NSMakeRange(0, kRoomMessageMaxLength/2)]; | ||||||
|                 [self.datasource removeObjectsInArray:needRemoveMsgArray]; |                     NSArray *needRemoveMsgArray = [self.datasource objectsAtIndexes:set]; | ||||||
|             } |                     [self.datasource removeObjectsInArray:needRemoveMsgArray]; | ||||||
|             // 执行插入 |                 } | ||||||
|             for (NIMMessage *item in messages) { |                 // 执行插入 | ||||||
|                 [self.datasource addObject:[self.messageParser parseMessageAttribute:item]]; |                 for (NIMMessage *item in messages) { | ||||||
|                 if (!self.isMiniEnter) {/// 最小化进房的话 不需要重新保存 |                     [self.datasource addObject:[self.messageParser parseMessageAttribute:item]]; | ||||||
|                     if (self.hostDelegate.getRoomInfo.isCloseScreen) { |                     if (!self.isMiniEnter) {/// 最小化进房的话 不需要重新保存 | ||||||
|                         NIMCustomObject *obj = (NIMCustomObject *)item.messageObject; |                         if (self.hostDelegate.getRoomInfo.isCloseScreen) { | ||||||
|                         if (obj.attachment != nil && [obj.attachment isKindOfClass:[AttachmentModel class]]) { |                             NIMCustomObject *obj = (NIMCustomObject *)item.messageObject; | ||||||
|                             AttachmentModel *attachment = (AttachmentModel *)obj.attachment; |                             if (obj.attachment != nil && [obj.attachment isKindOfClass:[AttachmentModel class]]) { | ||||||
|                             if (attachment.first == CustomMessageType_Update_RoomInfo && attachment.second == Custom_Message_Sub_Update_RoomInfo_MessageState){ |                                 AttachmentModel *attachment = (AttachmentModel *)obj.attachment; | ||||||
|                                 [[XPRoomMiniManager shareManager] saveRoomMessage:item]; |                                 if (attachment.first == CustomMessageType_Update_RoomInfo && attachment.second == Custom_Message_Sub_Update_RoomInfo_MessageState){ | ||||||
|  |                                     [[XPRoomMiniManager shareManager] saveRoomMessage:item]; | ||||||
|  |                                 } | ||||||
|                             } |                             } | ||||||
|  |                         } else { | ||||||
|  |                             [[XPRoomMiniManager shareManager] saveRoomMessage:item]; | ||||||
|                         } |                         } | ||||||
|                     } else { |  | ||||||
|                         [[XPRoomMiniManager shareManager] saveRoomMessage:item]; |  | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|  |                 self.isLoadHistoryMessage = NO; | ||||||
|  |                 [self.messageTableView reloadData]; | ||||||
|  |                 //执行插入动画并滚动 | ||||||
|  |                 [self scrollToBottom:YES]; | ||||||
|  |                 BOOL hideEnter = [self handleHideEnter:message]; | ||||||
|  |                 if (!hideEnter) { | ||||||
|  |                     ///插入进房消息及房间公告提示 | ||||||
|  |                     [self addRoomMessage:message]; | ||||||
|  |                 } | ||||||
|  |                 if (!roomInfo.hasAnimationEffect) { | ||||||
|  |                     [self roomInfoNoGiftAnimationMessage:message]; | ||||||
|  |                 } | ||||||
|  |                 [self createUserEnterRoomAddRoomtopicMessage]; | ||||||
|  |                 }); | ||||||
|  |         }else{ | ||||||
|  |             dispatch_async(dispatch_get_main_queue(), ^{ | ||||||
|  |             self.isLoadHistoryMessage = NO; | ||||||
|  |             BOOL hideEnter = [self handleHideEnter:message]; | ||||||
|  |             if (!hideEnter) { | ||||||
|  |                 ///插入进房消息及房间公告提示 | ||||||
|  |                 [self addRoomMessage:message]; | ||||||
|             } |             } | ||||||
|             [self.messageTableView reloadData]; |             if (!roomInfo.hasAnimationEffect) { | ||||||
|             //执行插入动画并滚动 |                 [self roomInfoNoGiftAnimationMessage:message]; | ||||||
|             [self scrollToBottom:YES]; |             } | ||||||
|  |             [self createUserEnterRoomAddRoomtopicMessage]; | ||||||
|  |             }); | ||||||
|         } |         } | ||||||
|         BOOL hideEnter = [self handleHideEnter:message]; |          | ||||||
|         if (!hideEnter) { |  | ||||||
|             ///插入进房消息及房间公告提示 |  | ||||||
|             [self addRoomMessage:message]; |  | ||||||
|         } |  | ||||||
|         if (!roomInfo.hasAnimationEffect) { |  | ||||||
|             [self roomInfoNoGiftAnimationMessage:message]; |  | ||||||
|         } |  | ||||||
|         [self createUserEnterRoomAddRoomtopicMessage]; |  | ||||||
|     }]; |     }]; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -44,9 +44,8 @@ | |||||||
| #import "XPGiftProtocol.h" | #import "XPGiftProtocol.h" | ||||||
| ///VC | ///VC | ||||||
| #import "XPMineRechargeViewController.h" | #import "XPMineRechargeViewController.h" | ||||||
| #import "XPIAPRechargeViewController.h" |  | ||||||
| #import "XPWebViewController.h" | #import "XPWebViewController.h" | ||||||
| UIKIT_EXTERN NSString * const kFreeGiftCountdownNotification; |  | ||||||
| UIKIT_EXTERN NSString * kShowFirstRechargeView; | UIKIT_EXTERN NSString * kShowFirstRechargeView; | ||||||
|  |  | ||||||
| @interface XPSendGiftView ()< XPGiftBarViewDelegate, XPGiftProtocol, XPGiftInfoViewDelegate, XPGraffitiGiftViewDelegate, XPGiftUsersViewDelegate, XPGiftHeadTypeViewDelegate, XPGiftLuckyGiftBroadcastViewDelegate, XPGiftTwelveStarBroadcastViewDelegate> | @interface XPSendGiftView ()< XPGiftBarViewDelegate, XPGiftProtocol, XPGiftInfoViewDelegate, XPGraffitiGiftViewDelegate, XPGiftUsersViewDelegate, XPGiftHeadTypeViewDelegate, XPGiftLuckyGiftBroadcastViewDelegate, XPGiftTwelveStarBroadcastViewDelegate> | ||||||
| @@ -89,8 +88,6 @@ UIKIT_EXTERN NSString * kShowFirstRechargeView; | |||||||
| @property (nonatomic,assign) GiftSegmentType segmentType; | @property (nonatomic,assign) GiftSegmentType segmentType; | ||||||
| ///福袋礼物全服记录 | ///福袋礼物全服记录 | ||||||
| @property (nonatomic,strong) NSArray *records; | @property (nonatomic,strong) NSArray *records; | ||||||
| ///背包礼物数据 |  | ||||||
| @property (nonatomic,copy) NSArray<GiftInfoModel *> * packGiftList; |  | ||||||
| @end | @end | ||||||
|  |  | ||||||
| @implementation XPSendGiftView | @implementation XPSendGiftView | ||||||
| @@ -99,9 +96,7 @@ UIKIT_EXTERN NSString * kShowFirstRechargeView; | |||||||
| 	return [[XPGiftPresenter alloc] init]; | 	return [[XPGiftPresenter alloc] init]; | ||||||
| } | } | ||||||
|  |  | ||||||
| -(void)dealloc{ |  | ||||||
|     [[NSNotificationCenter defaultCenter]removeObserver:self]; |  | ||||||
| } |  | ||||||
| - (instancetype)initWithType:(SendGiftType)type uid:(NSString * __nullable)uid{ | - (instancetype)initWithType:(SendGiftType)type uid:(NSString * __nullable)uid{ | ||||||
| 	if (self = [super init]) { | 	if (self = [super init]) { | ||||||
| 		self.modalPresentationStyle = UIModalPresentationOverFullScreen; | 		self.modalPresentationStyle = UIModalPresentationOverFullScreen; | ||||||
| @@ -129,17 +124,8 @@ UIKIT_EXTERN NSString * kShowFirstRechargeView; | |||||||
| 	[self.stackView addArrangedSubview:self.giftInfoView]; | 	[self.stackView addArrangedSubview:self.giftInfoView]; | ||||||
| 	[self.stackView addArrangedSubview:self.giftBarView]; | 	[self.stackView addArrangedSubview:self.giftBarView]; | ||||||
| 	[self.stackView addArrangedSubview:self.bottomView]; | 	[self.stackView addArrangedSubview:self.bottomView]; | ||||||
|     [[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(getFreeGiftCountdownNotification:) name:kFreeGiftCountdownNotification object:nil]; |  | ||||||
| } | } | ||||||
| -(void)getFreeGiftCountdownNotification:(NSNotification *)not{ |  | ||||||
|     NSDictionary *freeDic = not.userInfo; |  | ||||||
|     BOOL isReset = [freeDic[@"isReset"] boolValue];///礼物清零 |  | ||||||
|  |  | ||||||
|     if(isReset == YES){ |  | ||||||
|         [self.presenter getPackGiftList]; |  | ||||||
|         self.giftInfoView.isDelFreeGift = NO; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| - (void)initSubViewConstraints { | - (void)initSubViewConstraints { | ||||||
| 	[self.topView mas_makeConstraints:^(MASConstraintMaker *make) { | 	[self.topView mas_makeConstraints:^(MASConstraintMaker *make) { | ||||||
| 		make.left.right.top.mas_equalTo(self.view); | 		make.left.right.top.mas_equalTo(self.view); | ||||||
| @@ -448,12 +434,11 @@ UIKIT_EXTERN NSString * kShowFirstRechargeView; | |||||||
|  |  | ||||||
| ///充值 | ///充值 | ||||||
| - (void)xPGiftBarViewDidClickRecharge:(XPGiftBarView *)view { | - (void)xPGiftBarViewDidClickRecharge:(XPGiftBarView *)view { | ||||||
| 	[self dismissViewControllerAnimated:NO completion:^{ |     [self dismissViewControllerAnimated:YES completion:nil]; | ||||||
| //		XPMineRechargeViewController * rechargeVC = [[XPMineRechargeViewController alloc] init]; |     XPWebViewController * webVC =[[XPWebViewController alloc] init]; | ||||||
|         XPIAPRechargeViewController * rechargeVC = [[XPIAPRechargeViewController alloc] init]; |     webVC.isPush = YES; | ||||||
|         rechargeVC.type = @"4"; |     webVC.url = [NSString stringWithFormat:URLWithType(kThirdPartyPay),@"4",[YYUtility deviceID]]; | ||||||
| 		[[XCCurrentVCStackManager shareManager].getCurrentVC.navigationController pushViewController:rechargeVC animated:YES]; |     [self.delegate.getCurrentNav pushViewController:webVC animated:YES]; | ||||||
| 	}]; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| - (void)xPGiftBarViewDidClickFirstRecharge:(XPGiftBarView *)view { | - (void)xPGiftBarViewDidClickFirstRecharge:(XPGiftBarView *)view { | ||||||
| @@ -627,28 +612,7 @@ UIKIT_EXTERN NSString * kShowFirstRechargeView; | |||||||
| } | } | ||||||
| ///背包礼物 | ///背包礼物 | ||||||
| - (void)getPacketGiftListSuccess:(NSArray<GiftInfoModel *> *)giftList { | - (void)getPacketGiftListSuccess:(NSArray<GiftInfoModel *> *)giftList { | ||||||
|     self.packGiftList = giftList; | 	self.giftInfoView.packOriginArray = giftList; | ||||||
|     NSMutableArray<GiftInfoModel *> *giftArray = [NSMutableArray arrayWithArray:self.packGiftList]; |  | ||||||
|     BOOL isHaveFreeGift = NO; |  | ||||||
|     for (int i = 0 ; i < self.packGiftList.count; i++) { |  | ||||||
|         GiftInfoModel *infoModel = self.packGiftList[i]; |  | ||||||
|         if(infoModel.giftId == self.freeModel.giftId.integerValue){ |  | ||||||
|             [giftArray removeObjectAtIndex:i]; |  | ||||||
|             [giftArray insertObject:infoModel atIndex:0]; |  | ||||||
|             isHaveFreeGift = YES; |  | ||||||
|             break; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     if(isHaveFreeGift == NO &&  self.freeModel.curStage != nil && self.freeModel.curStage.integerValue == 0 ){ |  | ||||||
|         GiftInfoModel *infoModel = [GiftInfoModel new]; |  | ||||||
|         infoModel.giftId = self.freeModel.giftId.integerValue; |  | ||||||
|         infoModel.count = 0; |  | ||||||
|         infoModel.giftUrl = self.freeModel.giftUrl; |  | ||||||
|         infoModel.giftName = self.freeModel.giftName; |  | ||||||
|         [giftArray insertObject:infoModel atIndex:0]; |  | ||||||
|     } |  | ||||||
|     self.giftInfoView.freeModel = self.freeModel; |  | ||||||
|     self.giftInfoView.packOriginArray = giftArray; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| - (void)getPacketGiftListFail:(NSString *)message { | - (void)getPacketGiftListFail:(NSString *)message { | ||||||
| @@ -682,11 +646,7 @@ UIKIT_EXTERN NSString * kShowFirstRechargeView; | |||||||
| 	} else { | 	} else { | ||||||
| 		[self.presenter getUserWallInfo]; | 		[self.presenter getUserWallInfo]; | ||||||
| 	} | 	} | ||||||
|     dispatch_time_t delayTime = dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)); | 	[self sendCustomMessage:receiveInfo oringinDic:originDic]; | ||||||
|     dispatch_after(delayTime, dispatch_get_main_queue(), ^{ |  | ||||||
|         [self sendCustomMessage:receiveInfo oringinDic:originDic]; |  | ||||||
|     }); |  | ||||||
| 	 |  | ||||||
|   ///发送涂鸦礼物消息 |   ///发送涂鸦礼物消息 | ||||||
| 	[self sendGraffitiGiftMessage]; | 	[self sendGraffitiGiftMessage]; | ||||||
| 	if (self.segmentType == GiftSegmentType_Graffiti) { | 	if (self.segmentType == GiftSegmentType_Graffiti) { | ||||||
|   | |||||||
| @@ -21,8 +21,8 @@ | |||||||
| #import "XPMinePayPwdViewController.h" | #import "XPMinePayPwdViewController.h" | ||||||
| #import "BaseNavigationController.h" | #import "BaseNavigationController.h" | ||||||
| #import "XPMineRechargeViewController.h" | #import "XPMineRechargeViewController.h" | ||||||
| #import "XPIAPRechargeViewController.h" |  | ||||||
| #import "XPRoomHalfWebView.h" | #import "XPRoomHalfWebView.h" | ||||||
|  | #import "XPWebViewController.h" | ||||||
| ///P | ///P | ||||||
| #import "XPRoomRedPacketPresenter.h" | #import "XPRoomRedPacketPresenter.h" | ||||||
| #import "XPRoomRedPacketProtocol.h" | #import "XPRoomRedPacketProtocol.h" | ||||||
| @@ -31,6 +31,7 @@ | |||||||
| #import "RoomInfoModel.h" | #import "RoomInfoModel.h" | ||||||
| #import "UserInfoModel.h" | #import "UserInfoModel.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| @interface XPRoomSendRedPacketViewController ()<YYTextViewDelegate, XPRoomRedPacketProtocol, XPRoomRedPacketPwdViewDelegate> | @interface XPRoomSendRedPacketViewController ()<YYTextViewDelegate, XPRoomRedPacketProtocol, XPRoomRedPacketPwdViewDelegate> | ||||||
|  |  | ||||||
| ///host代理 | ///host代理 | ||||||
| @@ -403,10 +404,10 @@ | |||||||
| } | } | ||||||
|  |  | ||||||
| - (void)onRechargeButtonClick:(UIButton *)sender { | - (void)onRechargeButtonClick:(UIButton *)sender { | ||||||
| //    XPMineRechargeViewController *rechargeVC = [[XPMineRechargeViewController alloc] init]; |     XPWebViewController * webVC =[[XPWebViewController alloc] init]; | ||||||
|     XPIAPRechargeViewController * rechargeVC = [[XPIAPRechargeViewController alloc] init]; |        webVC.url = [NSString stringWithFormat:URLWithType(kThirdPartyPay),@"4",[YYUtility deviceID]]; | ||||||
|     rechargeVC.type = @"4"; |     webVC.isPush = YES; | ||||||
|     [self.navigationController pushViewController:rechargeVC animated:YES]; |     [self.navigationController pushViewController:webVC animated:YES]; | ||||||
| } | } | ||||||
|  |  | ||||||
| - (void)onRuleButtonClick:(UIButton *)sender { | - (void)onRuleButtonClick:(UIButton *)sender { | ||||||
|   | |||||||
| @@ -454,7 +454,9 @@ | |||||||
| 							//构造会话 | 							//构造会话 | ||||||
| 							NSString * sessionId = [NSString stringWithFormat:@"%ld", roomInfo.roomId]; | 							NSString * sessionId = [NSString stringWithFormat:@"%ld", roomInfo.roomId]; | ||||||
| 							NIMSession *session = [NIMSession session:sessionId type:NIMSessionTypeChatroom]; | 							NIMSession *session = [NIMSession session:sessionId type:NIMSessionTypeChatroom]; | ||||||
| 							[[NIMSDK sharedSDK].chatManager sendMessage:message toSession:session error:nil]; |                             [[NIMSDK sharedSDK].chatManager sendMessage:message toSession:session completion:^(NSError * _Nullable error) { | ||||||
|  |                                  | ||||||
|  |                             }]; | ||||||
| 						} | 						} | ||||||
| 					} roomUid:roomUid micUid:uid position:position uid:uid]; | 					} roomUid:roomUid micUid:uid position:position uid:uid]; | ||||||
| 				} | 				} | ||||||
|   | |||||||
| @@ -40,9 +40,10 @@ | |||||||
| ///P | ///P | ||||||
| #import "XPTreasureFailyPresenter.h" | #import "XPTreasureFailyPresenter.h" | ||||||
| #import "XPTreasureFailyProtocol.h" | #import "XPTreasureFailyProtocol.h" | ||||||
| #import "XPIAPRechargeViewController.h" |  | ||||||
| #import "TreasureFairyUserInfoModel.h" | #import "TreasureFairyUserInfoModel.h" | ||||||
| @interface XPTreasureFairyViewController ()<XPTreasureFailyProtocol, NIMSystemNotificationManagerDelegate, XPTreasureFairyMoreViewDelegate,XPTreasureFairyWebViewDelegate,XPIAPRechargeViewControllerDelegate,XPTreasureFairyBottomViewDelegate,PITreasureFairyBuyElfShardViewDelegate> | @interface XPTreasureFairyViewController ()<XPTreasureFailyProtocol, NIMSystemNotificationManagerDelegate, XPTreasureFairyMoreViewDelegate,XPTreasureFairyWebViewDelegate,XPTreasureFairyBottomViewDelegate,PITreasureFairyBuyElfShardViewDelegate> | ||||||
|  |  | ||||||
| ///点击消失 | ///点击消失 | ||||||
| @property (nonatomic,strong) UIView *dismissView; | @property (nonatomic,strong) UIView *dismissView; | ||||||
| ///背景 | ///背景 | ||||||
| @@ -477,70 +478,43 @@ | |||||||
| -(void)payWithFairyHandler{ | -(void)payWithFairyHandler{ | ||||||
|     [TTPopup dismiss]; |     [TTPopup dismiss]; | ||||||
|  |  | ||||||
|     XPIAPRechargeViewController * rechargeVC = [[XPIAPRechargeViewController alloc] init]; |        XPWebViewController *payVC = [[XPWebViewController alloc] initWithCustomizeNav:YES]; | ||||||
|     rechargeVC.delegate = self; |        payVC.view.backgroundColor = [UIColor whiteColor]; | ||||||
|     rechargeVC.isFairyPay = YES; |        payVC.webview.opaque = NO; | ||||||
|     rechargeVC.type = @"4"; |        payVC.isFairyPay = YES; | ||||||
|     rechargeVC.view.backgroundColor = [UIColor whiteColor]; |        [self addChildViewController:payVC]; | ||||||
|     [self addChildViewController:rechargeVC]; |        [self.view addSubview:payVC.view]; | ||||||
|     [self.view addSubview:rechargeVC.view]; |        @kWeakify(payVC); | ||||||
|  |         payVC.CloseWebViewBlock = ^(BOOL result) { | ||||||
|  |            @kStrongify(payVC); | ||||||
|  |             dispatch_async(dispatch_get_main_queue(), ^{ | ||||||
|  |                 [UIView animateWithDuration:0.5 animations:^{ | ||||||
|  |                     payVC.view.frame = CGRectMake(0, KScreenHeight, KScreenWidth, KScreenHeight); | ||||||
|  |                 }completion:^(BOOL finished) { | ||||||
|  |                     [payVC.view removeFromSuperview]; | ||||||
|  |                     [self getDiamonds]; | ||||||
|  |                 }]; | ||||||
|  |             }); | ||||||
|              |              | ||||||
|     rechargeVC.view.frame = CGRectMake(0, KScreenHeight, KScreenWidth, KScreenHeight); |        }; | ||||||
|     [UIView animateWithDuration:0.5 animations:^{ |        payVC.view.frame = CGRectMake(0, KScreenHeight, KScreenWidth, KScreenHeight); | ||||||
|         rechargeVC.view.frame = CGRectMake(0, 0, KScreenWidth, KScreenHeight); |        [UIView animateWithDuration:0.5 animations:^{ | ||||||
|     }completion:^(BOOL finished) { |            payVC.view.frame = CGRectMake(0, 0, KScreenWidth, KScreenHeight); | ||||||
|          |        }completion:^(BOOL finished) { | ||||||
|          |            dispatch_async(dispatch_get_main_queue(), ^{ | ||||||
|     }]; |                payVC.roomUid = self.roomUid; | ||||||
|  |                payVC.url = [NSString stringWithFormat:URLWithType(kThirdPartyPay),@"4",[YYUtility deviceID]]; | ||||||
|  |            }); | ||||||
|             |             | ||||||
|  |        }]; | ||||||
|         |         | ||||||
| } | } | ||||||
| #pragma mark - XPIAPRechargeViewController |  | ||||||
| - (void)paySuccess{ |  | ||||||
| //    [self ticketRecognizer]; |  | ||||||
|     [self getDiamonds]; |  | ||||||
|     [self showSuccessToast:YMLocalizedString(@"PITreasureFairyBuyElfShardView3")]; |  | ||||||
|  |  | ||||||
| } |  | ||||||
| #pragma mark - Event Response | #pragma mark - Event Response | ||||||
| - (void)dismissVC { | - (void)dismissVC { | ||||||
| 	[self dismissViewControllerAnimated:YES completion:nil]; | 	[self dismissViewControllerAnimated:YES completion:nil]; | ||||||
| } | } | ||||||
|  |  | ||||||
| - (void)ticketRecognizer { |  | ||||||
| 	self.moreView.hidden = YES; |  | ||||||
|     XPIAPRechargeViewController * rechargeVC = [[XPIAPRechargeViewController alloc] init]; |  | ||||||
|     rechargeVC.delegate = self; |  | ||||||
|     rechargeVC.isFairyPay = YES; |  | ||||||
|     rechargeVC.type = @"4"; |  | ||||||
|     rechargeVC.view.backgroundColor = [UIColor whiteColor]; |  | ||||||
|     [self addChildViewController:rechargeVC]; |  | ||||||
|     [self.view addSubview:rechargeVC.view]; |  | ||||||
|     rechargeVC.view.frame = CGRectMake(0, KScreenHeight, KScreenWidth, KScreenHeight); |  | ||||||
|     [UIView animateWithDuration:0.5 animations:^{ |  | ||||||
|         rechargeVC.view.frame = CGRectMake(0, 0, KScreenWidth, KScreenHeight); |  | ||||||
|     }completion:^(BOOL finished) { |  | ||||||
|          |  | ||||||
|          |  | ||||||
|     }]; |  | ||||||
|  |  | ||||||
|      |  | ||||||
| //	CGFloat kscale = 550.0 / 375.0; |  | ||||||
| //	XPTreasureFairyWebView * webView = [[XPTreasureFairyWebView alloc] initWithFrame:CGRectMake(0, 0, KScreenWidth, KScreenWidth * kscale)]; |  | ||||||
| //    webView.delegate = self; |  | ||||||
| //	webView.url = URLWithType(kTreasureTicketBuyURL); |  | ||||||
| //	TTPopupService * config = [[TTPopupService alloc] init]; |  | ||||||
| //	config.style = TTPopupStyleActionSheet; |  | ||||||
| //	config.contentView = webView; |  | ||||||
| //	config.maskBackgroundAlpha = 0.5; |  | ||||||
| //	@kWeakify(self); |  | ||||||
| //	config.didFinishDismissHandler = ^(BOOL isDismissOnBackgroundTouch) { |  | ||||||
| //		@kStrongify(self); |  | ||||||
| //		[self.presenter getTreasureFailyInfo]; |  | ||||||
| //	}; |  | ||||||
| //	[TTPopup popupWithConfig:config]; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| - (void)fairyDrawRecognizer { | - (void)fairyDrawRecognizer { | ||||||
| 	self.moreView.hidden = YES; | 	self.moreView.hidden = YES; | ||||||
| 	if (self.isRewardAnimting) { | 	if (self.isRewardAnimting) { | ||||||
| @@ -663,7 +637,7 @@ | |||||||
|         config.message = YMLocalizedString(@"XPTreasureFairyViewController5"); |         config.message = YMLocalizedString(@"XPTreasureFairyViewController5"); | ||||||
|         config.confirmButtonConfig.title = YMLocalizedString(@"XPTreasureFairyViewController6"); |         config.confirmButtonConfig.title = YMLocalizedString(@"XPTreasureFairyViewController6"); | ||||||
|         [TTPopup alertWithConfig:config confirmHandler:^{ |         [TTPopup alertWithConfig:config confirmHandler:^{ | ||||||
|             [self ticketRecognizer]; |             [self payWithFairyHandler]; | ||||||
|         } cancelHandler:^{ |         } cancelHandler:^{ | ||||||
|  |  | ||||||
|         }]; |         }]; | ||||||
|   | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -412,32 +412,32 @@ UIKIT_EXTERN NSString *kTabShowAnchorCardKey; | |||||||
| } | } | ||||||
| #pragma mark - 网络状态监听 | #pragma mark - 网络状态监听 | ||||||
| - (void)networkReachability{ | - (void)networkReachability{ | ||||||
|     @kWeakify(self); | //    @kWeakify(self); | ||||||
| 	[[AFNetworkReachabilityManager sharedManager] startMonitoring]; | //	[[AFNetworkReachabilityManager sharedManager] startMonitoring]; | ||||||
| 	[[AFNetworkReachabilityManager sharedManager] setReachabilityStatusChangeBlock:^(AFNetworkReachabilityStatus status) { | //	[[AFNetworkReachabilityManager sharedManager] setReachabilityStatusChangeBlock:^(AFNetworkReachabilityStatus status) { | ||||||
|         @kStrongify(self); | //        @kStrongify(self); | ||||||
| 		switch (status) { | //		switch (status) { | ||||||
| 			case AFNetworkReachabilityStatusUnknown: | //			case AFNetworkReachabilityStatusUnknown: | ||||||
| 				self.isFirstReachability = YES; | //				self.isFirstReachability = YES; | ||||||
| 				break; | //				break; | ||||||
| 			case AFNetworkReachabilityStatusNotReachable: | //			case AFNetworkReachabilityStatusNotReachable: | ||||||
| 				self.isFirstReachability = YES; | //				self.isFirstReachability = YES; | ||||||
| 				break; | //				break; | ||||||
| 			case AFNetworkReachabilityStatusReachableViaWWAN: | //			case AFNetworkReachabilityStatusReachableViaWWAN: | ||||||
| 			case AFNetworkReachabilityStatusReachableViaWiFi: | //			case AFNetworkReachabilityStatusReachableViaWiFi: | ||||||
| 			{ | //			{ | ||||||
| 				if (self.isFirstReachability) { | //				if (self.isFirstReachability) { | ||||||
| 					[[NSNotificationCenter defaultCenter] postNotificationName:kNetworkReachabilityKey object:nil userInfo:nil]; | //					[[NSNotificationCenter defaultCenter] postNotificationName:kNetworkReachabilityKey object:nil userInfo:nil]; | ||||||
| 					[self.presenter autoLogin]; | //					[self.presenter autoLogin]; | ||||||
| 					[[ClientConfig shareConfig] clientInit]; | //					[[ClientConfig shareConfig] clientInit]; | ||||||
| 				} | //				} | ||||||
| 				self.isFirstReachability = YES; | //				self.isFirstReachability = YES; | ||||||
| 			} | //			} | ||||||
| 				break; | //				break; | ||||||
| 			default: | //			default: | ||||||
| 				break; | //				break; | ||||||
| 		} | //		} | ||||||
| 	}]; | //	}]; | ||||||
| } | } | ||||||
|  |  | ||||||
| #pragma mark - BaseMvpProtocol | #pragma mark - BaseMvpProtocol | ||||||
|   | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Reference in New Issue
	
	Block a user