Compare commits
	
		
			22 Commits
		
	
	
		
			feature/1.
			...
			appstore_2
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 17d91c80b9 | ||
|   | 9ea6c4850d | ||
|   | d75b902722 | ||
|   | 3561ade9b2 | ||
|   | cba7c51f8e | ||
|   | c3e70231c7 | ||
|   | 5dd97fc7b5 | ||
|   | cf82cf776e | ||
|   | 8dec4148b3 | ||
|   | 43d07fcc21 | ||
|   | 5f59ab8305 | ||
|   | 5ddca74c84 | ||
|   | 9be7bbfe48 | ||
|   | 8665848325 | ||
|   | 3a6f414035 | ||
|   | 4c0f0b26b5 | ||
|   | 7470483f13 | ||
|   | a75004fe57 | ||
|   | 56104ee021 | ||
|   | adb07286a0 | ||
|   | 415b7e2bbb | ||
|   | a3235abdf0 | 
| @@ -35,14 +35,11 @@ | ||||
| 		142721AF29A75F6F00C7C423 /* SJXCSMIPHelper.m in Sources */ = {isa = PBXBuildFile; fileRef = 1427218629A75F6F00C7C423 /* SJXCSMIPHelper.m */; }; | ||||
| 		142721B229A7647F00C7C423 /* XPBlankViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = 142721B129A7647F00C7C423 /* XPBlankViewController.m */; }; | ||||
| 		1464C5EA29A45FC300AF7C94 /* XPButton.m in Sources */ = {isa = PBXBuildFile; fileRef = 1464C5E929A45FC300AF7C94 /* XPButton.m */; }; | ||||
| 		1464C5ED29A4784F00AF7C94 /* XPMineSimpleUserInfoViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = 1464C5EC29A4784F00AF7C94 /* XPMineSimpleUserInfoViewController.m */; }; | ||||
| 		1464C5F029A49DDD00AF7C94 /* XPMineSimpleUserInfoHeaderView.m in Sources */ = {isa = PBXBuildFile; fileRef = 1464C5EF29A49DDD00AF7C94 /* XPMineSimpleUserInfoHeaderView.m */; }; | ||||
| 		1464C5F329A4C18000AF7C94 /* XPIAPRechargeViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = 1464C5F229A4C18000AF7C94 /* XPIAPRechargeViewController.m */; }; | ||||
| 		1464C5F629A4CA8C00AF7C94 /* XPIAPRechargeCollectionViewCell.m in Sources */ = {isa = PBXBuildFile; fileRef = 1464C5F529A4CA8C00AF7C94 /* XPIAPRechargeCollectionViewCell.m */; }; | ||||
| 		1464C5F929A4D00000AF7C94 /* XPIAPRechargeHeaderView.m in Sources */ = {isa = PBXBuildFile; fileRef = 1464C5F829A4D00000AF7C94 /* XPIAPRechargeHeaderView.m */; }; | ||||
| 		149839C4299E088000F82CBF /* XPMomentListViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = 149839C3299E088000F82CBF /* XPMomentListViewController.m */; }; | ||||
| 		149839C7299E0B9F00F82CBF /* XPMomentListCollectionViewCell.m in Sources */ = {isa = PBXBuildFile; fileRef = 149839C6299E0B9F00F82CBF /* XPMomentListCollectionViewCell.m */; }; | ||||
| 		14A6034929A3567200D2A6A5 /* XPSimpleMineViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = 14A6034829A3567200D2A6A5 /* XPSimpleMineViewController.m */; }; | ||||
| 		14A6034C29A35EE600D2A6A5 /* XPMineItemTableViewCell.m in Sources */ = {isa = PBXBuildFile; fileRef = 14A6034B29A35EE600D2A6A5 /* XPMineItemTableViewCell.m */; }; | ||||
| 		14A6034F29A36D8300D2A6A5 /* XPSimpleMineHeaderView.m in Sources */ = {isa = PBXBuildFile; fileRef = 14A6034E29A36D8300D2A6A5 /* XPSimpleMineHeaderView.m */; }; | ||||
| 		14B880E1299A1799005FCA1B /* XPLoginViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = 14B880E0299A1799005FCA1B /* XPLoginViewController.m */; }; | ||||
| @@ -368,6 +365,15 @@ | ||||
| 		239BEEDB2AA1E058005CDA94 /* PIHoemCategoryTitleView.m in Sources */ = {isa = PBXBuildFile; fileRef = 239BEEDA2AA1E058005CDA94 /* PIHoemCategoryTitleView.m */; }; | ||||
| 		239D0F962BFB3296002977CE /* MSRoomOnLineView.m in Sources */ = {isa = PBXBuildFile; fileRef = 239D0F952BFB3296002977CE /* MSRoomOnLineView.m */; }; | ||||
| 		239D0F992BFB43BC002977CE /* MSRoomOnLineAvatarView.m in Sources */ = {isa = PBXBuildFile; fileRef = 239D0F982BFB43BC002977CE /* MSRoomOnLineAvatarView.m */; }; | ||||
| 		239D0F9B2BFC9E6C002977CE /* ms_room_gift_svga_icon.svga in Resources */ = {isa = PBXBuildFile; fileRef = 239D0F9A2BFC9E6C002977CE /* ms_room_gift_svga_icon.svga */; }; | ||||
| 		239D0FA82BFCB88D002977CE /* XPRoomBackContainerView.m in Sources */ = {isa = PBXBuildFile; fileRef = 239D0F9C2BFCB88C002977CE /* XPRoomBackContainerView.m */; }; | ||||
| 		239D0FA92BFCB88D002977CE /* XPRoomDatingVipUpMicView.m in Sources */ = {isa = PBXBuildFile; fileRef = 239D0FA12BFCB88D002977CE /* XPRoomDatingVipUpMicView.m */; }; | ||||
| 		239D0FAA2BFCB88D002977CE /* XPRoomDatingWebAlertView.m in Sources */ = {isa = PBXBuildFile; fileRef = 239D0FA22BFCB88D002977CE /* XPRoomDatingWebAlertView.m */; }; | ||||
| 		239D0FAB2BFCB88D002977CE /* XPRoomFunctionContainerView.m in Sources */ = {isa = PBXBuildFile; fileRef = 239D0FA32BFCB88D002977CE /* XPRoomFunctionContainerView.m */; }; | ||||
| 		239D0FAC2BFCB88D002977CE /* XPRoomRankEntranceView.m in Sources */ = {isa = PBXBuildFile; fileRef = 239D0FA42BFCB88D002977CE /* XPRoomRankEntranceView.m */; }; | ||||
| 		239D0FAD2BFCB88D002977CE /* XPRoomAnchorRankEnterView.m in Sources */ = {isa = PBXBuildFile; fileRef = 239D0FA52BFCB88D002977CE /* XPRoomAnchorRankEnterView.m */; }; | ||||
| 		239D0FB02BFD8C4D002977CE /* MSRoomSetingBackdropVC.m in Sources */ = {isa = PBXBuildFile; fileRef = 239D0FAF2BFD8C4D002977CE /* MSRoomSetingBackdropVC.m */; }; | ||||
| 		239D0FB32BFD8C67002977CE /* MSRoomSetingBackdropCell.m in Sources */ = {isa = PBXBuildFile; fileRef = 239D0FB22BFD8C67002977CE /* MSRoomSetingBackdropCell.m */; }; | ||||
| 		23A03F2D2B4408CD0094227A /* pi_room_lucky_gift.svga in Resources */ = {isa = PBXBuildFile; fileRef = 23A03F2C2B4408CD0094227A /* pi_room_lucky_gift.svga */; }; | ||||
| 		23A439742AA1CF7C002E6039 /* XPNewHomeHeadView.m in Sources */ = {isa = PBXBuildFile; fileRef = 23A439732AA1CF7C002E6039 /* XPNewHomeHeadView.m */; }; | ||||
| 		23A7FB692BDDEDFA00411860 /* MSRoomGameWebVC.m in Sources */ = {isa = PBXBuildFile; fileRef = 23A7FB682BDDEDFA00411860 /* MSRoomGameWebVC.m */; }; | ||||
| @@ -497,7 +503,6 @@ | ||||
| 		73FFADDC93E195344047A2EC /* Pods_YuMi.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = CACF623970097D653132D69A /* Pods_YuMi.framework */; }; | ||||
| 		9B0086C627BA392B0032BD2B /* AnchorStageView.m in Sources */ = {isa = PBXBuildFile; fileRef = 9B0086C527BA392B0032BD2B /* AnchorStageView.m */; }; | ||||
| 		9B0086CA27BA4F570032BD2B /* AnchorMicroView.m in Sources */ = {isa = PBXBuildFile; fileRef = 9B0086C927BA4F570032BD2B /* AnchorMicroView.m */; }; | ||||
| 		9B044D9D282D2A6400DE4859 /* XPRoomAnchorRankEnterView.m in Sources */ = {isa = PBXBuildFile; fileRef = 9B044D9C282D2A6400DE4859 /* XPRoomAnchorRankEnterView.m */; }; | ||||
| 		9B044DA0282D32F700DE4859 /* MicroInviteExtModel.m in Sources */ = {isa = PBXBuildFile; fileRef = 9B044D9F282D32F700DE4859 /* MicroInviteExtModel.m */; }; | ||||
| 		9B0997A127F19D8A00EB8F14 /* README.md in Resources */ = {isa = PBXBuildFile; fileRef = 9B0997A027F19D8900EB8F14 /* README.md */; }; | ||||
| 		9B0997A327F19DE500EB8F14 /* QGHWDShaders.metal in Sources */ = {isa = PBXBuildFile; fileRef = 9B0997A227F19DE500EB8F14 /* QGHWDShaders.metal */; }; | ||||
| @@ -560,7 +565,6 @@ | ||||
| 		9B85F3532806AB9A006EDF51 /* XPAnchorPKResultView.m in Sources */ = {isa = PBXBuildFile; fileRef = 9B85F3522806AB9A006EDF51 /* XPAnchorPKResultView.m */; }; | ||||
| 		9B85F3562806DD8A006EDF51 /* XPAnchorPKFinishView.m in Sources */ = {isa = PBXBuildFile; fileRef = 9B85F3552806DD8A006EDF51 /* XPAnchorPKFinishView.m */; }; | ||||
| 		9B86D87A2817DD8400494FCD /* XPRoomEnterHideTipView.m in Sources */ = {isa = PBXBuildFile; fileRef = 9B86D8792817DD8400494FCD /* XPRoomEnterHideTipView.m */; }; | ||||
| 		9B86D88328192DC000494FCD /* XPRoomRankEntranceView.m in Sources */ = {isa = PBXBuildFile; fileRef = 9B86D88228192DC000494FCD /* XPRoomRankEntranceView.m */; }; | ||||
| 		9B86D886281942D200494FCD /* SocialMicroView.m in Sources */ = {isa = PBXBuildFile; fileRef = 9B86D885281942D200494FCD /* SocialMicroView.m */; }; | ||||
| 		9B87B3CD2926473D00085110 /* XPSessionListHeadFriendCell.m in Sources */ = {isa = PBXBuildFile; fileRef = 9B87B3CC2926473D00085110 /* XPSessionListHeadFriendCell.m */; }; | ||||
| 		9B88E20C28C5EB8300D26FBA /* MessageContentRedPacketView.m in Sources */ = {isa = PBXBuildFile; fileRef = 9B88E20B28C5EB8300D26FBA /* MessageContentRedPacketView.m */; }; | ||||
| @@ -959,7 +963,6 @@ | ||||
| 		E8383697298A598D00112E1C /* MessageTipsModel.m in Sources */ = {isa = PBXBuildFile; fileRef = E8383696298A598D00112E1C /* MessageTipsModel.m */; }; | ||||
| 		E838369A298A59C100112E1C /* MessageTipsView.m in Sources */ = {isa = PBXBuildFile; fileRef = E8383699298A59C100112E1C /* MessageTipsView.m */; }; | ||||
| 		E838D9A0275E1BF60079E0B5 /* XPRoomAnimationView.m in Sources */ = {isa = PBXBuildFile; fileRef = E838D99F275E1BF60079E0B5 /* XPRoomAnimationView.m */; }; | ||||
| 		E83953222769F33B00CF2F24 /* XPRoomFunctionContainerView.m in Sources */ = {isa = PBXBuildFile; fileRef = E83953212769F33B00CF2F24 /* XPRoomFunctionContainerView.m */; }; | ||||
| 		E839532A276A002800CF2F24 /* XPMineDressUpViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = E8395329276A002800CF2F24 /* XPMineDressUpViewController.m */; }; | ||||
| 		E839532D276A030F00CF2F24 /* XPMineDressUpListViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = E839532C276A030F00CF2F24 /* XPMineDressUpListViewController.m */; }; | ||||
| 		E8395331276A03AE00CF2F24 /* Api+DressUp.m in Sources */ = {isa = PBXBuildFile; fileRef = E8395330276A03AE00CF2F24 /* Api+DressUp.m */; }; | ||||
| @@ -1189,8 +1192,6 @@ | ||||
| 		E8778AFB2989034200CF139B /* XPSessionSayHelloEmptyTableViewCell.m in Sources */ = {isa = PBXBuildFile; fileRef = E8778AFA2989034200CF139B /* XPSessionSayHelloEmptyTableViewCell.m */; }; | ||||
| 		E877A7EB2783E24700EFACED /* DatingStageView.m in Sources */ = {isa = PBXBuildFile; fileRef = E877A7EA2783E24700EFACED /* DatingStageView.m */; }; | ||||
| 		E877A7EE278428FB00EFACED /* MicroDatingProgressView.m in Sources */ = {isa = PBXBuildFile; fileRef = E877A7ED278428FB00EFACED /* MicroDatingProgressView.m */; }; | ||||
| 		E877A7F127842B2F00EFACED /* XPRoomDatingWebAlertView.m in Sources */ = {isa = PBXBuildFile; fileRef = E877A7F027842B2F00EFACED /* XPRoomDatingWebAlertView.m */; }; | ||||
| 		E877A7F427842EF800EFACED /* XPRoomDatingVipUpMicView.m in Sources */ = {isa = PBXBuildFile; fileRef = E877A7F327842EF800EFACED /* XPRoomDatingVipUpMicView.m */; }; | ||||
| 		E87888F42738C30E00BF1D57 /* StoreKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = E87888F32738C30E00BF1D57 /* StoreKit.framework */; }; | ||||
| 		E8788934273A53D700BF1D57 /* XPSendGiftView.m in Sources */ = {isa = PBXBuildFile; fileRef = E8788933273A53D700BF1D57 /* XPSendGiftView.m */; }; | ||||
| 		E878893C273A54C300BF1D57 /* Api+Gift.m in Sources */ = {isa = PBXBuildFile; fileRef = E878893B273A54C300BF1D57 /* Api+Gift.m */; }; | ||||
| @@ -1222,7 +1223,6 @@ | ||||
| 		E87DF4D72A42C9C3009C1185 /* HomePlayRoomModel.m in Sources */ = {isa = PBXBuildFile; fileRef = E87DF4D52A42C9C3009C1185 /* HomePlayRoomModel.m */; }; | ||||
| 		E87DF4DA2A42C9D9009C1185 /* HomeCollectRoomModel.m in Sources */ = {isa = PBXBuildFile; fileRef = E87DF4D82A42C9D8009C1185 /* HomeCollectRoomModel.m */; }; | ||||
| 		E87DF4DD2A42CA12009C1185 /* HomeSearchResultModel.m in Sources */ = {isa = PBXBuildFile; fileRef = E87DF4DB2A42CA12009C1185 /* HomeSearchResultModel.m */; }; | ||||
| 		E87DF4E02A42CA92009C1185 /* XPHomeSloganViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = E87DF4DE2A42CA92009C1185 /* XPHomeSloganViewController.m */; }; | ||||
| 		E87DF4E42A42CAD2009C1185 /* XPHomeSearchNavView.m in Sources */ = {isa = PBXBuildFile; fileRef = E87DF4E22A42CAD2009C1185 /* XPHomeSearchNavView.m */; }; | ||||
| 		E87DF4E72A42CB00009C1185 /* XPHomePresenter.m in Sources */ = {isa = PBXBuildFile; fileRef = E87DF4E52A42CAFF009C1185 /* XPHomePresenter.m */; }; | ||||
| 		E87DF4EC2A42CB60009C1185 /* XPSearchListTableViewCell.m in Sources */ = {isa = PBXBuildFile; fileRef = E87DF4EA2A42CB60009C1185 /* XPSearchListTableViewCell.m */; }; | ||||
| @@ -1388,7 +1388,6 @@ | ||||
| 		E8AC723D26F4B6AA007D6E91 /* XPLoginBindPhoneResultViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = E8AC723C26F4B6AA007D6E91 /* XPLoginBindPhoneResultViewController.m */; }; | ||||
| 		E8AE427327153A3500BEEBB2 /* XPRoomActivityContainerView.m in Sources */ = {isa = PBXBuildFile; fileRef = E8AE427227153A3500BEEBB2 /* XPRoomActivityContainerView.m */; }; | ||||
| 		E8AEAED6271412EC0017FCE0 /* XPRoomViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = E8AEAED5271412EC0017FCE0 /* XPRoomViewController.m */; }; | ||||
| 		E8AEAEED27141AE20017FCE0 /* XPRoomBackContainerView.m in Sources */ = {isa = PBXBuildFile; fileRef = E8AEAEEC27141AE20017FCE0 /* XPRoomBackContainerView.m */; }; | ||||
| 		E8AEAEF027141C430017FCE0 /* XPRoomMenuContainerView.m in Sources */ = {isa = PBXBuildFile; fileRef = E8AEAEEF27141C430017FCE0 /* XPRoomMenuContainerView.m */; }; | ||||
| 		E8AEAEF327141C7C0017FCE0 /* XPRoomMessageContainerView.m in Sources */ = {isa = PBXBuildFile; fileRef = E8AEAEF227141C7C0017FCE0 /* XPRoomMessageContainerView.m */; }; | ||||
| 		E8AEAEF927141CA30017FCE0 /* RoomHeaderView.m in Sources */ = {isa = PBXBuildFile; fileRef = E8AEAEF827141CA30017FCE0 /* RoomHeaderView.m */; }; | ||||
| @@ -1588,8 +1587,6 @@ | ||||
| 		142721B129A7647F00C7C423 /* XPBlankViewController.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPBlankViewController.m; sourceTree = "<group>"; }; | ||||
| 		1464C5E829A45FC300AF7C94 /* XPButton.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPButton.h; sourceTree = "<group>"; }; | ||||
| 		1464C5E929A45FC300AF7C94 /* XPButton.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPButton.m; sourceTree = "<group>"; }; | ||||
| 		1464C5EB29A4784F00AF7C94 /* XPMineSimpleUserInfoViewController.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPMineSimpleUserInfoViewController.h; sourceTree = "<group>"; }; | ||||
| 		1464C5EC29A4784F00AF7C94 /* XPMineSimpleUserInfoViewController.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPMineSimpleUserInfoViewController.m; sourceTree = "<group>"; }; | ||||
| 		1464C5EE29A49DDD00AF7C94 /* XPMineSimpleUserInfoHeaderView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPMineSimpleUserInfoHeaderView.h; sourceTree = "<group>"; }; | ||||
| 		1464C5EF29A49DDD00AF7C94 /* XPMineSimpleUserInfoHeaderView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPMineSimpleUserInfoHeaderView.m; sourceTree = "<group>"; }; | ||||
| 		1464C5F129A4C18000AF7C94 /* XPIAPRechargeViewController.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPIAPRechargeViewController.h; sourceTree = "<group>"; }; | ||||
| @@ -1598,12 +1595,8 @@ | ||||
| 		1464C5F529A4CA8C00AF7C94 /* XPIAPRechargeCollectionViewCell.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPIAPRechargeCollectionViewCell.m; sourceTree = "<group>"; }; | ||||
| 		1464C5F729A4D00000AF7C94 /* XPIAPRechargeHeaderView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPIAPRechargeHeaderView.h; sourceTree = "<group>"; }; | ||||
| 		1464C5F829A4D00000AF7C94 /* XPIAPRechargeHeaderView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPIAPRechargeHeaderView.m; sourceTree = "<group>"; }; | ||||
| 		149839C2299E088000F82CBF /* XPMomentListViewController.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPMomentListViewController.h; sourceTree = "<group>"; }; | ||||
| 		149839C3299E088000F82CBF /* XPMomentListViewController.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPMomentListViewController.m; sourceTree = "<group>"; }; | ||||
| 		149839C5299E0B9F00F82CBF /* XPMomentListCollectionViewCell.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPMomentListCollectionViewCell.h; sourceTree = "<group>"; }; | ||||
| 		149839C6299E0B9F00F82CBF /* XPMomentListCollectionViewCell.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPMomentListCollectionViewCell.m; sourceTree = "<group>"; }; | ||||
| 		14A6034729A3567200D2A6A5 /* XPSimpleMineViewController.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPSimpleMineViewController.h; sourceTree = "<group>"; }; | ||||
| 		14A6034829A3567200D2A6A5 /* XPSimpleMineViewController.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPSimpleMineViewController.m; sourceTree = "<group>"; }; | ||||
| 		14A6034A29A35EE600D2A6A5 /* XPMineItemTableViewCell.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPMineItemTableViewCell.h; sourceTree = "<group>"; }; | ||||
| 		14A6034B29A35EE600D2A6A5 /* XPMineItemTableViewCell.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPMineItemTableViewCell.m; sourceTree = "<group>"; }; | ||||
| 		14A6034D29A36D8300D2A6A5 /* XPSimpleMineHeaderView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPSimpleMineHeaderView.h; sourceTree = "<group>"; }; | ||||
| @@ -2252,6 +2245,23 @@ | ||||
| 		239D0F952BFB3296002977CE /* MSRoomOnLineView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = MSRoomOnLineView.m; sourceTree = "<group>"; }; | ||||
| 		239D0F972BFB43BC002977CE /* MSRoomOnLineAvatarView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = MSRoomOnLineAvatarView.h; sourceTree = "<group>"; }; | ||||
| 		239D0F982BFB43BC002977CE /* MSRoomOnLineAvatarView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = MSRoomOnLineAvatarView.m; sourceTree = "<group>"; }; | ||||
| 		239D0F9A2BFC9E6C002977CE /* ms_room_gift_svga_icon.svga */ = {isa = PBXFileReference; lastKnownFileType = file; path = ms_room_gift_svga_icon.svga; sourceTree = "<group>"; }; | ||||
| 		239D0F9C2BFCB88C002977CE /* XPRoomBackContainerView.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = XPRoomBackContainerView.m; sourceTree = "<group>"; }; | ||||
| 		239D0F9D2BFCB88C002977CE /* XPRoomDatingWebAlertView.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = XPRoomDatingWebAlertView.h; sourceTree = "<group>"; }; | ||||
| 		239D0F9E2BFCB88C002977CE /* XPRoomFunctionContainerView.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = XPRoomFunctionContainerView.h; sourceTree = "<group>"; }; | ||||
| 		239D0F9F2BFCB88C002977CE /* XPRoomAnchorRankEnterView.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = XPRoomAnchorRankEnterView.h; sourceTree = "<group>"; }; | ||||
| 		239D0FA02BFCB88D002977CE /* XPRoomDatingVipUpMicView.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = XPRoomDatingVipUpMicView.h; sourceTree = "<group>"; }; | ||||
| 		239D0FA12BFCB88D002977CE /* XPRoomDatingVipUpMicView.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = XPRoomDatingVipUpMicView.m; sourceTree = "<group>"; }; | ||||
| 		239D0FA22BFCB88D002977CE /* XPRoomDatingWebAlertView.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = XPRoomDatingWebAlertView.m; sourceTree = "<group>"; }; | ||||
| 		239D0FA32BFCB88D002977CE /* XPRoomFunctionContainerView.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = XPRoomFunctionContainerView.m; sourceTree = "<group>"; }; | ||||
| 		239D0FA42BFCB88D002977CE /* XPRoomRankEntranceView.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = XPRoomRankEntranceView.m; sourceTree = "<group>"; }; | ||||
| 		239D0FA52BFCB88D002977CE /* XPRoomAnchorRankEnterView.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = XPRoomAnchorRankEnterView.m; sourceTree = "<group>"; }; | ||||
| 		239D0FA62BFCB88D002977CE /* XPRoomRankEntranceView.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = XPRoomRankEntranceView.h; sourceTree = "<group>"; }; | ||||
| 		239D0FA72BFCB88D002977CE /* XPRoomBackContainerView.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = XPRoomBackContainerView.h; sourceTree = "<group>"; }; | ||||
| 		239D0FAE2BFD8C4D002977CE /* MSRoomSetingBackdropVC.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = MSRoomSetingBackdropVC.h; sourceTree = "<group>"; }; | ||||
| 		239D0FAF2BFD8C4D002977CE /* MSRoomSetingBackdropVC.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = MSRoomSetingBackdropVC.m; sourceTree = "<group>"; }; | ||||
| 		239D0FB12BFD8C67002977CE /* MSRoomSetingBackdropCell.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = MSRoomSetingBackdropCell.h; sourceTree = "<group>"; }; | ||||
| 		239D0FB22BFD8C67002977CE /* MSRoomSetingBackdropCell.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = MSRoomSetingBackdropCell.m; sourceTree = "<group>"; }; | ||||
| 		23A03F2C2B4408CD0094227A /* pi_room_lucky_gift.svga */ = {isa = PBXFileReference; lastKnownFileType = file; path = pi_room_lucky_gift.svga; sourceTree = "<group>"; }; | ||||
| 		23A439722AA1CF7C002E6039 /* XPNewHomeHeadView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPNewHomeHeadView.h; sourceTree = "<group>"; }; | ||||
| 		23A439732AA1CF7C002E6039 /* XPNewHomeHeadView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPNewHomeHeadView.m; sourceTree = "<group>"; }; | ||||
| @@ -2493,8 +2503,6 @@ | ||||
| 		9B0086C527BA392B0032BD2B /* AnchorStageView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = AnchorStageView.m; sourceTree = "<group>"; }; | ||||
| 		9B0086C827BA4F570032BD2B /* AnchorMicroView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = AnchorMicroView.h; sourceTree = "<group>"; }; | ||||
| 		9B0086C927BA4F570032BD2B /* AnchorMicroView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = AnchorMicroView.m; sourceTree = "<group>"; }; | ||||
| 		9B044D9B282D2A6400DE4859 /* XPRoomAnchorRankEnterView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPRoomAnchorRankEnterView.h; sourceTree = "<group>"; }; | ||||
| 		9B044D9C282D2A6400DE4859 /* XPRoomAnchorRankEnterView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPRoomAnchorRankEnterView.m; sourceTree = "<group>"; }; | ||||
| 		9B044D9E282D32F700DE4859 /* MicroInviteExtModel.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = MicroInviteExtModel.h; sourceTree = "<group>"; }; | ||||
| 		9B044D9F282D32F700DE4859 /* MicroInviteExtModel.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = MicroInviteExtModel.m; sourceTree = "<group>"; }; | ||||
| 		9B0997A027F19D8900EB8F14 /* README.md */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = net.daringfireball.markdown; path = README.md; sourceTree = "<group>"; }; | ||||
| @@ -2619,8 +2627,6 @@ | ||||
| 		9B85F3552806DD8A006EDF51 /* XPAnchorPKFinishView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPAnchorPKFinishView.m; sourceTree = "<group>"; }; | ||||
| 		9B86D8782817DD8400494FCD /* XPRoomEnterHideTipView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPRoomEnterHideTipView.h; sourceTree = "<group>"; }; | ||||
| 		9B86D8792817DD8400494FCD /* XPRoomEnterHideTipView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPRoomEnterHideTipView.m; sourceTree = "<group>"; }; | ||||
| 		9B86D88128192DC000494FCD /* XPRoomRankEntranceView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPRoomRankEntranceView.h; sourceTree = "<group>"; }; | ||||
| 		9B86D88228192DC000494FCD /* XPRoomRankEntranceView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPRoomRankEntranceView.m; sourceTree = "<group>"; }; | ||||
| 		9B86D884281942D200494FCD /* SocialMicroView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = SocialMicroView.h; sourceTree = "<group>"; }; | ||||
| 		9B86D885281942D200494FCD /* SocialMicroView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = SocialMicroView.m; sourceTree = "<group>"; }; | ||||
| 		9B87B3CB2926473D00085110 /* XPSessionListHeadFriendCell.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPSessionListHeadFriendCell.h; sourceTree = "<group>"; }; | ||||
| @@ -3260,8 +3266,6 @@ | ||||
| 		E8383699298A59C100112E1C /* MessageTipsView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = MessageTipsView.m; sourceTree = "<group>"; }; | ||||
| 		E838D99E275E1BF60079E0B5 /* XPRoomAnimationView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPRoomAnimationView.h; sourceTree = "<group>"; }; | ||||
| 		E838D99F275E1BF60079E0B5 /* XPRoomAnimationView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPRoomAnimationView.m; sourceTree = "<group>"; }; | ||||
| 		E83953202769F33B00CF2F24 /* XPRoomFunctionContainerView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPRoomFunctionContainerView.h; sourceTree = "<group>"; }; | ||||
| 		E83953212769F33B00CF2F24 /* XPRoomFunctionContainerView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPRoomFunctionContainerView.m; sourceTree = "<group>"; }; | ||||
| 		E8395328276A002800CF2F24 /* XPMineDressUpViewController.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPMineDressUpViewController.h; sourceTree = "<group>"; }; | ||||
| 		E8395329276A002800CF2F24 /* XPMineDressUpViewController.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPMineDressUpViewController.m; sourceTree = "<group>"; }; | ||||
| 		E839532B276A030F00CF2F24 /* XPMineDressUpListViewController.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPMineDressUpListViewController.h; sourceTree = "<group>"; }; | ||||
| @@ -3748,10 +3752,6 @@ | ||||
| 		E877A7EA2783E24700EFACED /* DatingStageView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = DatingStageView.m; sourceTree = "<group>"; }; | ||||
| 		E877A7EC278428FB00EFACED /* MicroDatingProgressView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = MicroDatingProgressView.h; sourceTree = "<group>"; }; | ||||
| 		E877A7ED278428FB00EFACED /* MicroDatingProgressView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = MicroDatingProgressView.m; sourceTree = "<group>"; }; | ||||
| 		E877A7EF27842B2F00EFACED /* XPRoomDatingWebAlertView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPRoomDatingWebAlertView.h; sourceTree = "<group>"; }; | ||||
| 		E877A7F027842B2F00EFACED /* XPRoomDatingWebAlertView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPRoomDatingWebAlertView.m; sourceTree = "<group>"; }; | ||||
| 		E877A7F227842EF800EFACED /* XPRoomDatingVipUpMicView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPRoomDatingVipUpMicView.h; sourceTree = "<group>"; }; | ||||
| 		E877A7F327842EF800EFACED /* XPRoomDatingVipUpMicView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPRoomDatingVipUpMicView.m; sourceTree = "<group>"; }; | ||||
| 		E87888F32738C30E00BF1D57 /* StoreKit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = StoreKit.framework; path = System/Library/Frameworks/StoreKit.framework; sourceTree = SDKROOT; }; | ||||
| 		E8788932273A53D700BF1D57 /* XPSendGiftView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPSendGiftView.h; sourceTree = "<group>"; }; | ||||
| 		E8788933273A53D700BF1D57 /* XPSendGiftView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPSendGiftView.m; sourceTree = "<group>"; }; | ||||
| @@ -3816,8 +3816,6 @@ | ||||
| 		E87DF4D92A42C9D9009C1185 /* HomeCollectRoomModel.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = HomeCollectRoomModel.h; sourceTree = "<group>"; }; | ||||
| 		E87DF4DB2A42CA12009C1185 /* HomeSearchResultModel.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = HomeSearchResultModel.m; sourceTree = "<group>"; }; | ||||
| 		E87DF4DC2A42CA12009C1185 /* HomeSearchResultModel.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = HomeSearchResultModel.h; sourceTree = "<group>"; }; | ||||
| 		E87DF4DE2A42CA92009C1185 /* XPHomeSloganViewController.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = XPHomeSloganViewController.m; sourceTree = "<group>"; }; | ||||
| 		E87DF4DF2A42CA92009C1185 /* XPHomeSloganViewController.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = XPHomeSloganViewController.h; sourceTree = "<group>"; }; | ||||
| 		E87DF4E22A42CAD2009C1185 /* XPHomeSearchNavView.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = XPHomeSearchNavView.m; sourceTree = "<group>"; }; | ||||
| 		E87DF4E32A42CAD2009C1185 /* XPHomeSearchNavView.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = XPHomeSearchNavView.h; sourceTree = "<group>"; }; | ||||
| 		E87DF4E52A42CAFF009C1185 /* XPHomePresenter.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = XPHomePresenter.m; sourceTree = "<group>"; }; | ||||
| @@ -4160,8 +4158,6 @@ | ||||
| 		E8AE427227153A3500BEEBB2 /* XPRoomActivityContainerView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPRoomActivityContainerView.m; sourceTree = "<group>"; }; | ||||
| 		E8AEAED4271412EC0017FCE0 /* XPRoomViewController.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPRoomViewController.h; sourceTree = "<group>"; }; | ||||
| 		E8AEAED5271412EC0017FCE0 /* XPRoomViewController.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPRoomViewController.m; sourceTree = "<group>"; }; | ||||
| 		E8AEAEEB27141AE20017FCE0 /* XPRoomBackContainerView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPRoomBackContainerView.h; sourceTree = "<group>"; }; | ||||
| 		E8AEAEEC27141AE20017FCE0 /* XPRoomBackContainerView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPRoomBackContainerView.m; sourceTree = "<group>"; }; | ||||
| 		E8AEAEEE27141C430017FCE0 /* XPRoomMenuContainerView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPRoomMenuContainerView.h; sourceTree = "<group>"; }; | ||||
| 		E8AEAEEF27141C430017FCE0 /* XPRoomMenuContainerView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = XPRoomMenuContainerView.m; sourceTree = "<group>"; }; | ||||
| 		E8AEAEF127141C7C0017FCE0 /* XPRoomMessageContainerView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = XPRoomMessageContainerView.h; sourceTree = "<group>"; }; | ||||
| @@ -7568,8 +7564,6 @@ | ||||
| 				E8AB632328AE10310023B0D2 /* XPMoentsTopicListViewController.m */, | ||||
| 				E8AB632A28AE19600023B0D2 /* XPMonentsMineViewController.h */, | ||||
| 				E8AB632B28AE19600023B0D2 /* XPMonentsMineViewController.m */, | ||||
| 				149839C2299E088000F82CBF /* XPMomentListViewController.h */, | ||||
| 				149839C3299E088000F82CBF /* XPMomentListViewController.m */, | ||||
| 				14EB640729A5BDDD00A4A00B /* XPMomentsSimpleDetailViewController.h */, | ||||
| 				14EB640829A5BDDD00A4A00B /* XPMomentsSimpleDetailViewController.m */, | ||||
| 				14EB640B29A5C16000A4A00B /* XPMomentsSimpleDetailNav.h */, | ||||
| @@ -8004,6 +7998,8 @@ | ||||
| 				E8412FA32779BE9B006E1101 /* Cell */, | ||||
| 				E8412FA02779BE8F006E1101 /* XPRoomSettingViewController.h */, | ||||
| 				E8412FA12779BE8F006E1101 /* XPRoomSettingViewController.m */, | ||||
| 				239D0FAE2BFD8C4D002977CE /* MSRoomSetingBackdropVC.h */, | ||||
| 				239D0FAF2BFD8C4D002977CE /* MSRoomSetingBackdropVC.m */, | ||||
| 				E87AE7F7277AABE50037823A /* XPRoomTagListViewController.h */, | ||||
| 				E87AE7F8277AABE50037823A /* XPRoomTagListViewController.m */, | ||||
| 				E84BF7D2277C383700EF8877 /* XPRoomSettingInputView.h */, | ||||
| @@ -8059,6 +8055,8 @@ | ||||
| 				E84BF7DC277C765400EF8877 /* XPRoomRoleEmptyTableViewCell.m */, | ||||
| 				E89BD7D2277D471100E31B19 /* XPRoomOnlineTableViewCell.h */, | ||||
| 				E89BD7D3277D471100E31B19 /* XPRoomOnlineTableViewCell.m */, | ||||
| 				239D0FB12BFD8C67002977CE /* MSRoomSetingBackdropCell.h */, | ||||
| 				239D0FB22BFD8C67002977CE /* MSRoomSetingBackdropCell.m */, | ||||
| 			); | ||||
| 			path = Cell; | ||||
| 			sourceTree = "<group>"; | ||||
| @@ -9265,8 +9263,6 @@ | ||||
| 		E87E62522A3F55B2002F68C9 /* View */ = { | ||||
| 			isa = PBXGroup; | ||||
| 			children = ( | ||||
| 				E87DF4DF2A42CA92009C1185 /* XPHomeSloganViewController.h */, | ||||
| 				E87DF4DE2A42CA92009C1185 /* XPHomeSloganViewController.m */, | ||||
| 				E87DF4B82A42C7BB009C1185 /* Search */, | ||||
| 				E87E625F2A3F5669002F68C9 /* Cell */, | ||||
| 				E87E625E2A3F565D002F68C9 /* CustomView */, | ||||
| @@ -9522,8 +9518,6 @@ | ||||
| 				E8D34D6328084E40009C4835 /* XPMineUserInfoGiftWallViewController.m */, | ||||
| 				E8998D892859CB6A00C68558 /* XPMineUserInfoGiftWallSubViewController.h */, | ||||
| 				E8998D8A2859CB6A00C68558 /* XPMineUserInfoGiftWallSubViewController.m */, | ||||
| 				1464C5EB29A4784F00AF7C94 /* XPMineSimpleUserInfoViewController.h */, | ||||
| 				1464C5EC29A4784F00AF7C94 /* XPMineSimpleUserInfoViewController.m */, | ||||
| 				1464C5EE29A49DDD00AF7C94 /* XPMineSimpleUserInfoHeaderView.h */, | ||||
| 				1464C5EF29A49DDD00AF7C94 /* XPMineSimpleUserInfoHeaderView.m */, | ||||
| 			); | ||||
| @@ -9716,6 +9710,7 @@ | ||||
| 				23FF256F2ABD456C0064E904 /* pi_home_new_play.svga */, | ||||
| 				23FF25612ABAE6310064E904 /* pi_room_game_fine_love.svga */, | ||||
| 				232C444A2AB4363200D4B2ED /* pi_room_tarrow_h5_banner.svga */, | ||||
| 				239D0F9A2BFC9E6C002977CE /* ms_room_gift_svga_icon.svga */, | ||||
| 				23FF42662AA5CFBB0055733C /* home_sound_wave.gif */, | ||||
| 				23E9EB232A84E98300B792F2 /* pi_new_mine_info_online.svga */, | ||||
| 				23FF255A2AB956D50064E904 /* pi_home_new_pk.svga */, | ||||
| @@ -10031,18 +10026,18 @@ | ||||
| 		E8AEAEE727141ACC0017FCE0 /* BaseUIContainerView */ = { | ||||
| 			isa = PBXGroup; | ||||
| 			children = ( | ||||
| 				E8AEAEEB27141AE20017FCE0 /* XPRoomBackContainerView.h */, | ||||
| 				E8AEAEEC27141AE20017FCE0 /* XPRoomBackContainerView.m */, | ||||
| 				E83953202769F33B00CF2F24 /* XPRoomFunctionContainerView.h */, | ||||
| 				E83953212769F33B00CF2F24 /* XPRoomFunctionContainerView.m */, | ||||
| 				E877A7EF27842B2F00EFACED /* XPRoomDatingWebAlertView.h */, | ||||
| 				E877A7F027842B2F00EFACED /* XPRoomDatingWebAlertView.m */, | ||||
| 				E877A7F227842EF800EFACED /* XPRoomDatingVipUpMicView.h */, | ||||
| 				E877A7F327842EF800EFACED /* XPRoomDatingVipUpMicView.m */, | ||||
| 				9B86D88128192DC000494FCD /* XPRoomRankEntranceView.h */, | ||||
| 				9B86D88228192DC000494FCD /* XPRoomRankEntranceView.m */, | ||||
| 				9B044D9B282D2A6400DE4859 /* XPRoomAnchorRankEnterView.h */, | ||||
| 				9B044D9C282D2A6400DE4859 /* XPRoomAnchorRankEnterView.m */, | ||||
| 				239D0F9F2BFCB88C002977CE /* XPRoomAnchorRankEnterView.h */, | ||||
| 				239D0FA52BFCB88D002977CE /* XPRoomAnchorRankEnterView.m */, | ||||
| 				239D0FA72BFCB88D002977CE /* XPRoomBackContainerView.h */, | ||||
| 				239D0F9C2BFCB88C002977CE /* XPRoomBackContainerView.m */, | ||||
| 				239D0FA02BFCB88D002977CE /* XPRoomDatingVipUpMicView.h */, | ||||
| 				239D0FA12BFCB88D002977CE /* XPRoomDatingVipUpMicView.m */, | ||||
| 				239D0F9D2BFCB88C002977CE /* XPRoomDatingWebAlertView.h */, | ||||
| 				239D0FA22BFCB88D002977CE /* XPRoomDatingWebAlertView.m */, | ||||
| 				239D0F9E2BFCB88C002977CE /* XPRoomFunctionContainerView.h */, | ||||
| 				239D0FA32BFCB88D002977CE /* XPRoomFunctionContainerView.m */, | ||||
| 				239D0FA62BFCB88D002977CE /* XPRoomRankEntranceView.h */, | ||||
| 				239D0FA42BFCB88D002977CE /* XPRoomRankEntranceView.m */, | ||||
| 			); | ||||
| 			path = BaseUIContainerView; | ||||
| 			sourceTree = "<group>"; | ||||
| @@ -10539,8 +10534,6 @@ | ||||
| 				9BD2ECCD288F829600F5CD9A /* XPMineFootPrintViewController.m */, | ||||
| 				9B1B729328002099003FACE9 /* XPMineFansTeamViewController.h */, | ||||
| 				9B1B729428002099003FACE9 /* XPMineFansTeamViewController.m */, | ||||
| 				14A6034729A3567200D2A6A5 /* XPSimpleMineViewController.h */, | ||||
| 				14A6034829A3567200D2A6A5 /* XPSimpleMineViewController.m */, | ||||
| 				14A6034A29A35EE600D2A6A5 /* XPMineItemTableViewCell.h */, | ||||
| 				14A6034B29A35EE600D2A6A5 /* XPMineItemTableViewCell.m */, | ||||
| 				14A6034D29A36D8300D2A6A5 /* XPSimpleMineHeaderView.h */, | ||||
| @@ -11042,6 +11035,7 @@ | ||||
| 				E80EC87928ACD84000D133C5 /* emoji_91@2x.png in Resources */, | ||||
| 				E80EC84C28ACD84000D133C5 /* emoji_120@2x.png in Resources */, | ||||
| 				23E9EAA32A84C80300B792F2 /* pi_new_loading.svga in Resources */, | ||||
| 				239D0F9B2BFC9E6C002977CE /* ms_room_gift_svga_icon.svga in Resources */, | ||||
| 				E80EC83628ACD84000D133C5 /* emoji_147@2x.png in Resources */, | ||||
| 				2368ECEC2BC5280300EDF4C9 /* local in Resources */, | ||||
| 				23E9EB242A84E98300B792F2 /* pi_new_mine_info_sound_play.svga in Resources */, | ||||
| @@ -11173,7 +11167,6 @@ | ||||
| 				E8D34D5028080362009C4835 /* XPMineDataGiftTableViewCell.m in Sources */, | ||||
| 				E87C54BE2823CC5B0051AA11 /* XPMineResetLoginPwdPresenter.m in Sources */, | ||||
| 				E85E7B322A4EB0D300B6D00A /* XPGuildAnchorIncomeSectionView.m in Sources */, | ||||
| 				E83953222769F33B00CF2F24 /* XPRoomFunctionContainerView.m in Sources */, | ||||
| 				E87C0AA027D9DE6400CB2241 /* RoomFaceSendInfoModel.m in Sources */, | ||||
| 				1464C5F629A4CA8C00AF7C94 /* XPIAPRechargeCollectionViewCell.m in Sources */, | ||||
| 				E8751E6328A646400056EF44 /* XPSailingRankView.m in Sources */, | ||||
| @@ -11298,6 +11291,7 @@ | ||||
| 				9BD9A17C27A0EE24004186FE /* XPMineVisitorViewController.m in Sources */, | ||||
| 				2369F9912A89CE0E00563B48 /* PIUserSexView.m in Sources */, | ||||
| 				238B37D92AC55A2C00BFC9D5 /* XPTreasureFairyTrialsRecordView.m in Sources */, | ||||
| 				239D0FAB2BFCB88D002977CE /* XPRoomFunctionContainerView.m in Sources */, | ||||
| 				E82109B026F1D83500FC3319 /* LoginBindPhonePresent.m in Sources */, | ||||
| 				E81C1B1F27705F7A0020D1E4 /* XPArrangeMicViewController.m in Sources */, | ||||
| 				E8B825C726EA0D9A009E8E9F /* LoginVerifCodeProtocol.h in Sources */, | ||||
| @@ -11348,7 +11342,6 @@ | ||||
| 				9B87B3CD2926473D00085110 /* XPSessionListHeadFriendCell.m in Sources */, | ||||
| 				23194DCD2AD14BF000649F51 /* DDASLLogger.m in Sources */, | ||||
| 				E85E7B492A4EB0D300B6D00A /* XPMineGuildSearchViewController.m in Sources */, | ||||
| 				9B86D88328192DC000494FCD /* XPRoomRankEntranceView.m in Sources */, | ||||
| 				238A900A2BA9756600828123 /* PIUniversalBannerModel.m in Sources */, | ||||
| 				E85E7B012A4EB0D200B6D00A /* XPSuperAdminSetPresenter.m in Sources */, | ||||
| 				18F404B7276095D700A6C548 /* SessionChatLimitView.m in Sources */, | ||||
| @@ -11387,6 +11380,7 @@ | ||||
| 				2331C1AA2A60F32D00E1D940 /* XPCandyTreePresenter.m in Sources */, | ||||
| 				E8AC723D26F4B6AA007D6E91 /* XPLoginBindPhoneResultViewController.m in Sources */, | ||||
| 				E8AB632728AE13210023B0D2 /* XPMonentsTopicListPresenter.m in Sources */, | ||||
| 				239D0FB32BFD8C67002977CE /* MSRoomSetingBackdropCell.m in Sources */, | ||||
| 				1427218729A75F6F00C7C423 /* MyHTTPConnection.m in Sources */, | ||||
| 				23CEFB6C2AFB803B00576D89 /* PISwitchingEnvironmentVC.m in Sources */, | ||||
| 				E8D55C9D28113218006935A5 /* MessageMenuModel.m in Sources */, | ||||
| @@ -11403,7 +11397,6 @@ | ||||
| 				F1D8556F2931FC86008C418F /* XPRoomYearActivityView.m in Sources */, | ||||
| 				238B37C72AC55A2C00BFC9D5 /* XPTreasureFairyPrizeRecordView.m in Sources */, | ||||
| 				E8B9843628ABA8B40022D026 /* XPMonentPublishSuccessView.m in Sources */, | ||||
| 				E87DF4E02A42CA92009C1185 /* XPHomeSloganViewController.m in Sources */, | ||||
| 				238ED83A2AE2891D0014EF9D /* PIRoomEnterRedPacketView.m in Sources */, | ||||
| 				23E9E9972A80C3A100B792F2 /* XPMineGuildPersonalBillRecordVC.m in Sources */, | ||||
| 				E81C279626EB39CC0031E639 /* LoginForgetPasswordPresent.m in Sources */, | ||||
| @@ -11568,7 +11561,6 @@ | ||||
| 				9BCB99A028F571B500466D64 /* XPMineCollectPartyRoomViewController.m in Sources */, | ||||
| 				E81C27AE26EF39AB0031E639 /* AppDelegate+ThirdConfig.m in Sources */, | ||||
| 				E8AB631028ADD92D0023B0D2 /* XPMonentsTopicRecommondViewController.m in Sources */, | ||||
| 				E877A7F127842B2F00EFACED /* XPRoomDatingWebAlertView.m in Sources */, | ||||
| 				E8E70D8326F2F51A00F03460 /* XPMineHeadView.m in Sources */, | ||||
| 				E80EC81128ACD84000D133C5 /* QEmotionHelper.m in Sources */, | ||||
| 				E8EEB90C26FC5EBC007C6EBA /* XPMineUserInfoEditModel.m in Sources */, | ||||
| @@ -11605,7 +11597,6 @@ | ||||
| 				232EBBFF2BD7A25500E8CEAD /* MSParamsDecode.m in Sources */, | ||||
| 				9B7D804D27537950003DAC0C /* MessageCell.m in Sources */, | ||||
| 				23E9EAA62A84C97C00B792F2 /* XPMineUserInfoTagVC.m in Sources */, | ||||
| 				9B044D9D282D2A6400DE4859 /* XPRoomAnchorRankEnterView.m in Sources */, | ||||
| 				E8950180282CAC49007E459A /* XPMonentsUserInfoView.m in Sources */, | ||||
| 				18F404C927609A4300A6C548 /* MessagePresenter.m in Sources */, | ||||
| 				9BC9DAEF27E33B3F009EE409 /* XPRoomGiftAnimationParser.m in Sources */, | ||||
| @@ -11675,7 +11666,6 @@ | ||||
| 				14B880E7299A4B62005FCA1B /* XPLoginPhoneViewController.m in Sources */, | ||||
| 				E824544626F5934700BE8163 /* XPMinePayPwdPresenter.m in Sources */, | ||||
| 				189DD54B26DE338800AB55B1 /* BaseViewController.m in Sources */, | ||||
| 				149839C4299E088000F82CBF /* XPMomentListViewController.m in Sources */, | ||||
| 				E8B846C226FD82DC00A777FE /* XPMineUserInfoAlbumCollectionViewCell.m in Sources */, | ||||
| 				233423CD2AAEE98200B1253F /* XPCandyTreeConfirmBuyNumView.m in Sources */, | ||||
| 				2331C1AD2A60F32D00E1D940 /* XPCandyTreeAnimationModel.m in Sources */, | ||||
| @@ -11755,6 +11745,7 @@ | ||||
| 				E85E7B6E2A4EC4AE00B6D00A /* XPMineGuildPresenter.m in Sources */, | ||||
| 				23CEFC5B2AFB8FC100576D89 /* BSSelectView.m in Sources */, | ||||
| 				E81125CA296E606F000D9804 /* QPhotoImageModel.m in Sources */, | ||||
| 				239D0FAA2BFCB88D002977CE /* XPRoomDatingWebAlertView.m in Sources */, | ||||
| 				9B42869528C1E00A009034D2 /* XPRedPacketResultModel.m in Sources */, | ||||
| 				2331C16E2A5EB71000E1D940 /* XPNobleAuthorityDescView.m in Sources */, | ||||
| 				9BE01AE428937EDE00B50299 /* XPDressUpShopCollectionViewCell.m in Sources */, | ||||
| @@ -11898,6 +11889,7 @@ | ||||
| 				E8778AF82988F4E200CF139B /* XPSessionSayHelloHeaderView.m in Sources */, | ||||
| 				E84150C527747E0900A7F548 /* FirstRechargeRewardModel.m in Sources */, | ||||
| 				E8B9843328ABA2FF0022D026 /* MonentsPicResInfo.m in Sources */, | ||||
| 				239D0FB02BFD8C4D002977CE /* MSRoomSetingBackdropVC.m in Sources */, | ||||
| 				235714982BEDF54E004C81D6 /* MsRoomMessageMainView.m in Sources */, | ||||
| 				9BE9F10227FEE5C200667200 /* XPAnchorFansTaskDetailModel.m in Sources */, | ||||
| 				E8E0DAE6285C280E00566A2F /* XPSessionFindNewAlertView.m in Sources */, | ||||
| @@ -11971,7 +11963,6 @@ | ||||
| 				2357146E2BEB816B004C81D6 /* MSSessionPublicChatHallHeadView.m in Sources */, | ||||
| 				238B37CD2AC55A2C00BFC9D5 /* XPTreasureFailyResultView.m in Sources */, | ||||
| 				E824545126F5CE6E00BE8163 /* XPMineModifPayPwdPresenter.m in Sources */, | ||||
| 				1464C5ED29A4784F00AF7C94 /* XPMineSimpleUserInfoViewController.m in Sources */, | ||||
| 				E8098CB1282E86EF0090B9F0 /* XPMonentsContentView.m in Sources */, | ||||
| 				E85E3FA728B7A6F000268DC8 /* MessageContentMonentsView.m in Sources */, | ||||
| 				234E50A82BF5EBDD005CB6D5 /* MSSessionPublicChatHalRightTextCell.m in Sources */, | ||||
| @@ -12049,6 +12040,7 @@ | ||||
| 				23CEFC5F2AFB8FC100576D89 /* BSLogTableViewController.m in Sources */, | ||||
| 				236B2E4D2AA07D06003967A8 /* XPRoomLittleGameContainerView.m in Sources */, | ||||
| 				E87AE8C1284E184300CAFBB3 /* RoomNewUserGreetModel.m in Sources */, | ||||
| 				239D0FAC2BFCB88D002977CE /* XPRoomRankEntranceView.m in Sources */, | ||||
| 				235714602BE8BD5C004C81D6 /* MSSessionScrollingModel.m in Sources */, | ||||
| 				9BC5C91C277C8A7B007C8719 /* XPReleaseRadioViewController.m in Sources */, | ||||
| 				23B2AEC42A6516C200543D17 /* LoginForgetPasswordViewController.m in Sources */, | ||||
| @@ -12174,7 +12166,6 @@ | ||||
| 				23E9EA7F2A839B2F00B792F2 /* MessageTreasureFairyModel.m in Sources */, | ||||
| 				E8778AFB2989034200CF139B /* XPSessionSayHelloEmptyTableViewCell.m in Sources */, | ||||
| 				238B37B02AC55A2C00BFC9D5 /* XPTreasureFairyStoreResultCell.m in Sources */, | ||||
| 				E8AEAEED27141AE20017FCE0 /* XPRoomBackContainerView.m in Sources */, | ||||
| 				E88B5CC126FB407B00DA9178 /* XPMineUserInfoViewController.m in Sources */, | ||||
| 				235714672BE8C009004C81D6 /* MSSessionScrollingView.m in Sources */, | ||||
| 				2331C1AC2A60F32D00E1D940 /* CandyTreeRecordModel.m in Sources */, | ||||
| @@ -12238,6 +12229,7 @@ | ||||
| 				E87DF4E72A42CB00009C1185 /* XPHomePresenter.m in Sources */, | ||||
| 				2331C0DC2A5E9E9000E1D940 /* PIFullScreenBannerAnimation.m in Sources */, | ||||
| 				E8232600274E48EA003A3332 /* XPUserCardItemCollectionViewCell.m in Sources */, | ||||
| 				239D0FA92BFCB88D002977CE /* XPRoomDatingVipUpMicView.m in Sources */, | ||||
| 				E88B5CC526FB42B000DA9178 /* XPMineUserInfoHeaderView.m in Sources */, | ||||
| 				E8AC721626F46B06007D6E91 /* XPMineSettingTableViewCell.m in Sources */, | ||||
| 				18EE3FDF2750C1F700A452BF /* SessionListCell.m in Sources */, | ||||
| @@ -12254,6 +12246,7 @@ | ||||
| 				142721AF29A75F6F00C7C423 /* SJXCSMIPHelper.m in Sources */, | ||||
| 				E87E62742A3F5907002F68C9 /* XPHomeBannerTableViewCell.m in Sources */, | ||||
| 				E88C72A3282917590047FB2B /* XPRoomMusicVoiceSettingView.m in Sources */, | ||||
| 				239D0FA82BFCB88D002977CE /* XPRoomBackContainerView.m in Sources */, | ||||
| 				23D321DF2ADFCEB2006B259C /* PIRedPacketChooseTypeView.m in Sources */, | ||||
| 				E81AF32827F1EE69003B9E43 /* XPRoomPKPanelUserView.m in Sources */, | ||||
| 				E84150BF27747BD300A7F548 /* Api+FirstRecharge.m in Sources */, | ||||
| @@ -12263,6 +12256,7 @@ | ||||
| 				E852D73B286317F0001465ED /* XPMonentsDetailViewController.m in Sources */, | ||||
| 				2331C1692A5EB71000E1D940 /* XPNobleSettingViewController.m in Sources */, | ||||
| 				E85E7B392A4EB0D300B6D00A /* XPGuildChooseManagerRoomTableViewCell.m in Sources */, | ||||
| 				239D0FAD2BFCB88D002977CE /* XPRoomAnchorRankEnterView.m in Sources */, | ||||
| 				E81060D9298761A300B772F0 /* MessageBaseModel.m in Sources */, | ||||
| 				E890BC10273D23F00007C46B /* GiftInfoModel.m in Sources */, | ||||
| 				E8A30BEB28534A96003B4873 /* XPSessionFindNewFiltrateView.m in Sources */, | ||||
| @@ -12327,7 +12321,6 @@ | ||||
| 				E874B88827215D39003954B9 /* MicroStateModel.m in Sources */, | ||||
| 				23E9EABB2A84CCBE00B792F2 /* XPMineDataSkillDataCollectionViewCell.m in Sources */, | ||||
| 				23FE47D52BB3C64600F09D23 /* PINobleCenterTitleCell.m in Sources */, | ||||
| 				E877A7F427842EF800EFACED /* XPRoomDatingVipUpMicView.m in Sources */, | ||||
| 				E896EF9F2771AE7B00AD2CC1 /* XPMineAttentionViewController.m in Sources */, | ||||
| 				E89D60C1271D64B9001F8895 /* RoomInfoModel.m in Sources */, | ||||
| 				E89DA66727006443008483C1 /* RechargeStorage.m in Sources */, | ||||
| @@ -12355,7 +12348,6 @@ | ||||
| 				E87E91522796A15500A7B3F2 /* MicroExtModel.m in Sources */, | ||||
| 				E8788948273A55D000BF1D57 /* XPGiftBarView.m in Sources */, | ||||
| 				E89DCF5728FFF076001647EC /* XPWishGiftEmptyTableViewCell.m in Sources */, | ||||
| 				14A6034929A3567200D2A6A5 /* XPSimpleMineViewController.m in Sources */, | ||||
| 				237700D32BC7CC7C00D661F1 /* NSObject+MJExtension.m in Sources */, | ||||
| 				E8D4DE442940462C00EC788D /* XPGiftTwelveStarBroadcastView.m in Sources */, | ||||
| 				E81060DF29876D3A00B772F0 /* MessageTimeModel.m in Sources */, | ||||
| @@ -12586,7 +12578,7 @@ | ||||
| 					"$(inherited)", | ||||
| 					"@executable_path/Frameworks", | ||||
| 				); | ||||
| 				MARKETING_VERSION = 20.20.20; | ||||
| 				MARKETING_VERSION = 20.20.21; | ||||
| 				PRODUCT_BUNDLE_IDENTIFIER = com.peko.enterprise.ios; | ||||
| 				PRODUCT_NAME = "$(TARGET_NAME)"; | ||||
| 				PROVISIONING_PROFILE_SPECIFIER = ""; | ||||
| @@ -12624,7 +12616,7 @@ | ||||
| 					"$(inherited)", | ||||
| 					"@executable_path/Frameworks", | ||||
| 				); | ||||
| 				MARKETING_VERSION = 20.20.20; | ||||
| 				MARKETING_VERSION = 20.20.21; | ||||
| 				PRODUCT_BUNDLE_IDENTIFIER = com.peko.enterprise.ios; | ||||
| 				PRODUCT_NAME = "$(TARGET_NAME)"; | ||||
| 				PROVISIONING_PROFILE_SPECIFIER = ""; | ||||
|   | ||||
| @@ -234,9 +234,6 @@ UIKIT_EXTERN NSString * adImageName; | ||||
|  | ||||
| /// 闪屏广告跳转处理 | ||||
| - (void)advertiseJumpHandleWithInfo:(AdvertiseModel *)info { | ||||
| 	if (![ClientConfig shareConfig].canOpen) { | ||||
| 		return; | ||||
| 	} | ||||
| 	if (UIApplication.sharedApplication.keyWindow != self.window) { | ||||
| 		//当前窗口不是主控制器所在窗口时,拦截跳转(目前可能情况时,闪屏后出现新人引导 | ||||
| 		return; | ||||
|   | ||||
| Before Width: | Height: | Size: 6.6 KiB | 
| Before Width: | Height: | Size: 1.5 KiB | 
| @@ -1,22 +0,0 @@ | ||||
| { | ||||
|   "images" : [ | ||||
|     { | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "1x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_menu_arrange_mic_new_ar@2x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "2x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_menu_arrange_mic_new_ar@3x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "3x" | ||||
|     } | ||||
|   ], | ||||
|   "info" : { | ||||
|     "author" : "xcode", | ||||
|     "version" : 1 | ||||
|   } | ||||
| } | ||||
| Before Width: | Height: | Size: 7.2 KiB | 
| Before Width: | Height: | Size: 1.7 KiB | 
| @@ -1,22 +0,0 @@ | ||||
| { | ||||
|   "images" : [ | ||||
|     { | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "1x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_menu_arrange_mic_en@2x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "2x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_menu_arrange_mic_en@3x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "3x" | ||||
|     } | ||||
|   ], | ||||
|   "info" : { | ||||
|     "author" : "xcode", | ||||
|     "version" : 1 | ||||
|   } | ||||
| } | ||||
| Before Width: | Height: | Size: 6.9 KiB | 
| Before Width: | Height: | Size: 5.5 KiB | 
| @@ -1,22 +0,0 @@ | ||||
| { | ||||
|   "images" : [ | ||||
|     { | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "1x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_menu_arrange_mic_new_en@2x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "2x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_menu_arrange_mic_new_en@3x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "3x" | ||||
|     } | ||||
|   ], | ||||
|   "info" : { | ||||
|     "author" : "xcode", | ||||
|     "version" : 1 | ||||
|   } | ||||
| } | ||||
| Before Width: | Height: | Size: 7.4 KiB | 
| Before Width: | Height: | Size: 2.0 KiB | 
| Before Width: | Height: | Size: 2.6 KiB After Width: | Height: | Size: 603 B | 
| Before Width: | Height: | Size: 3.9 KiB After Width: | Height: | Size: 991 B | 
| @@ -1,21 +0,0 @@ | ||||
| { | ||||
|   "images" : [ | ||||
|     { | ||||
|       "filename" : "pi_room_menu_bottom_send_bg.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "1x" | ||||
|     }, | ||||
|     { | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "2x" | ||||
|     }, | ||||
|     { | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "3x" | ||||
|     } | ||||
|   ], | ||||
|   "info" : { | ||||
|     "author" : "xcode", | ||||
|     "version" : 1 | ||||
|   } | ||||
| } | ||||
| Before Width: | Height: | Size: 3.2 KiB | 
| Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 831 B | 
| Before Width: | Height: | Size: 2.1 KiB After Width: | Height: | Size: 1.3 KiB | 
| Before Width: | Height: | Size: 1.6 KiB After Width: | Height: | Size: 958 B | 
| Before Width: | Height: | Size: 2.6 KiB After Width: | Height: | Size: 1.5 KiB | 
| Before Width: | Height: | Size: 1.4 KiB After Width: | Height: | Size: 740 B | 
| Before Width: | Height: | Size: 2.1 KiB After Width: | Height: | Size: 1.2 KiB | 
| @@ -1,22 +0,0 @@ | ||||
| { | ||||
|   "images" : [ | ||||
|     { | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "1x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_menu_gift@2x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "2x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_menu_gift@3x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "3x" | ||||
|     } | ||||
|   ], | ||||
|   "info" : { | ||||
|     "author" : "xcode", | ||||
|     "version" : 1 | ||||
|   } | ||||
| } | ||||
| Before Width: | Height: | Size: 3.4 KiB | 
| Before Width: | Height: | Size: 5.0 KiB | 
| @@ -1,22 +0,0 @@ | ||||
| { | ||||
|   "images" : [ | ||||
|     { | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "1x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_menu_gift1@2x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "2x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_menu_gift1@3x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "3x" | ||||
|     } | ||||
|   ], | ||||
|   "info" : { | ||||
|     "author" : "xcode", | ||||
|     "version" : 1 | ||||
|   } | ||||
| } | ||||
| Before Width: | Height: | Size: 6.4 KiB | 
| Before Width: | Height: | Size: 12 KiB | 
| Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 724 B | 
| Before Width: | Height: | Size: 2.0 KiB After Width: | Height: | Size: 1.2 KiB | 
| Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 955 B | 
| Before Width: | Height: | Size: 6.7 KiB After Width: | Height: | Size: 1.5 KiB | 
| Before Width: | Height: | Size: 1.2 KiB After Width: | Height: | Size: 834 B | 
| Before Width: | Height: | Size: 1.9 KiB After Width: | Height: | Size: 1.3 KiB | 
| Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 583 B | 
| Before Width: | Height: | Size: 2.0 KiB After Width: | Height: | Size: 1.1 KiB | 
| Before Width: | Height: | Size: 1.2 KiB After Width: | Height: | Size: 806 B | 
| Before Width: | Height: | Size: 2.0 KiB After Width: | Height: | Size: 1.5 KiB | 
| Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 759 B | 
| Before Width: | Height: | Size: 1.8 KiB After Width: | Height: | Size: 1.1 KiB | 
| Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 681 B | 
| Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 1004 B | 
| @@ -1,22 +0,0 @@ | ||||
| { | ||||
|   "images" : [ | ||||
|     { | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "1x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_position_boss@2x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "2x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_position_boss@3x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "3x" | ||||
|     } | ||||
|   ], | ||||
|   "info" : { | ||||
|     "author" : "xcode", | ||||
|     "version" : 1 | ||||
|   } | ||||
| } | ||||
| Before Width: | Height: | Size: 4.0 KiB | 
| Before Width: | Height: | Size: 6.6 KiB | 
| Before Width: | Height: | Size: 1.0 KiB After Width: | Height: | Size: 1.6 KiB | 
| Before Width: | Height: | Size: 1.6 KiB After Width: | Height: | Size: 2.6 KiB | 
| @@ -1,22 +0,0 @@ | ||||
| { | ||||
|   "images" : [ | ||||
|     { | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "1x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_position_lock1@2x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "2x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_position_lock1@3x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "3x" | ||||
|     } | ||||
|   ], | ||||
|   "info" : { | ||||
|     "author" : "xcode", | ||||
|     "version" : 1 | ||||
|   } | ||||
| } | ||||
| Before Width: | Height: | Size: 4.5 KiB | 
| Before Width: | Height: | Size: 5.4 KiB | 
| Before Width: | Height: | Size: 1.2 KiB After Width: | Height: | Size: 877 B | 
| Before Width: | Height: | Size: 1.8 KiB After Width: | Height: | Size: 1.3 KiB | 
| @@ -1,22 +0,0 @@ | ||||
| { | ||||
|   "images" : [ | ||||
|     { | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "1x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_position_normal1@2x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "2x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_position_normal1@3x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "3x" | ||||
|     } | ||||
|   ], | ||||
|   "info" : { | ||||
|     "author" : "xcode", | ||||
|     "version" : 1 | ||||
|   } | ||||
| } | ||||
| Before Width: | Height: | Size: 2.9 KiB | 
| Before Width: | Height: | Size: 4.4 KiB | 
| @@ -5,12 +5,12 @@ | ||||
|       "scale" : "1x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_menu_arrange_mic_ar@2x.png", | ||||
|       "filename" : "ms_room_reting_backdrop_back@2x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "2x" | ||||
|     }, | ||||
|     { | ||||
|       "filename" : "room_menu_arrange_mic_ar@3x.png", | ||||
|       "filename" : "ms_room_reting_backdrop_back@3x.png", | ||||
|       "idiom" : "universal", | ||||
|       "scale" : "3x" | ||||
|     } | ||||
| After Width: | Height: | Size: 356 B | 
| After Width: | Height: | Size: 582 B | 
| @@ -22,7 +22,7 @@ NS_ASSUME_NONNULL_BEGIN | ||||
| @property (nonatomic,strong) ClientDataModel *configInfo; | ||||
| ///开箱子 大于等级  展示 | ||||
| @property (nonatomic, assign) NSInteger openCandyTreeLimitLevel; | ||||
| @property (nonatomic,assign) BOOL canOpen; | ||||
|  | ||||
| @property(nonatomic,assign) BOOL isTF; | ||||
| ///是否刷新了 | ||||
| @property (nonatomic,assign) BOOL isLoad; | ||||
|   | ||||
| @@ -44,9 +44,9 @@ | ||||
|     return isTestFlight; | ||||
| } | ||||
| - (void)clientInit { | ||||
| 	 | ||||
|     self.canOpen = YES; | ||||
|     @kWeakify(self); | ||||
| 	[Api clientInitConfig:^(BaseModel * _Nullable data, NSInteger code, NSString * _Nullable msg) { | ||||
|         @kStrongify(self); | ||||
| 		if (code == 200) { | ||||
| 			self.retryCount = 0; | ||||
| 			NSDictionary * initData = data.data; | ||||
|   | ||||
| @@ -40,24 +40,14 @@ | ||||
| #pragma mark - Life Style | ||||
| - (instancetype)initWithItems:(NSArray<XPShareItem *> *)items itemSize:(CGSize)itemSize shareInfo:(XPShareInfoModel *)shareInfo { | ||||
|     if (self = [super init]) { | ||||
|         | ||||
|         NSMutableArray *itemList = [NSMutableArray array]; | ||||
|         for (XPShareItem * item in items) { | ||||
|             if (item.type == XPShareItemTagAppFriends || item.type == XPShareItemTagCopyLink) { | ||||
|                 item.disable = YES; | ||||
|             } else { | ||||
|                 item.disable = [self isInstallClient:[self getSharePlatformType:item.type]]; | ||||
|             } | ||||
|             if(item.disable == YES){ | ||||
|                 [itemList addObject:item]; | ||||
|             } | ||||
|         } | ||||
|         if([ClientConfig shareConfig].canOpen){ | ||||
|             self.items = [NSMutableArray arrayWithArray:items]; | ||||
|         }else{ | ||||
|             self.items = itemList; | ||||
|         } | ||||
|         | ||||
|         self.items = [NSMutableArray arrayWithArray:items]; | ||||
|         self.itemSize =itemSize; | ||||
|         self.shareInfo = shareInfo; | ||||
|         [self initSubViews]; | ||||
|   | ||||
| @@ -49,7 +49,7 @@ isPhoneXSeries = [[UIApplication sharedApplication] delegate].window.safeAreaIns | ||||
|  | ||||
|  | ||||
| ///内置版本号 | ||||
| #define PI_App_Version @"1.0.6" | ||||
| #define PI_App_Version @"1.0.7" | ||||
| ///渠道 | ||||
| #define PI_App_Source @"appstore" | ||||
| #define PI_Test_Flight @"TestFlight" | ||||
|   | ||||
| @@ -30,6 +30,7 @@ | ||||
| #import "XPLoginInputView.h" | ||||
| #import "XPLoginAraeViewController.h" | ||||
| #import "XPForgetPwdViewController.h" | ||||
| #import "PISwitchingEnvironmentVC.h" | ||||
|  | ||||
| UIKIT_EXTERN NSString * const kYouMiNumberCountKey; | ||||
| NSString * const HadAgreePrivacy = @"HadAgreePrivacy"; | ||||
| @@ -111,6 +112,11 @@ NSString * const HadAgreePrivacy = @"HadAgreePrivacy"; | ||||
|     [super viewDidLoad]; | ||||
|     [self createUI]; | ||||
|     [self racBind]; | ||||
| #ifdef DEBUG | ||||
|     [self setSwitchingEnvironmentVC]; | ||||
| #else | ||||
| #endif | ||||
|     | ||||
|     self.selectType = 0; | ||||
|     NSString *code = [NSString getCountryCode]; | ||||
|     self.pi_phoneAreaCode = [code stringByReplacingOccurrencesOfString:@"+" withString:@""]; | ||||
| @@ -347,7 +353,25 @@ NSString * const HadAgreePrivacy = @"HadAgreePrivacy"; | ||||
|     } | ||||
|      | ||||
| } | ||||
| -(void)setSwitchingEnvironmentVC{ | ||||
|     UIButton *but = [UIButton new]; | ||||
|     [but setTitle:@"切换环境" forState:UIControlStateNormal]; | ||||
|     [but setTitleColor:[UIColor blueColor] forState:UIControlStateNormal]; | ||||
|     [self.view addSubview:but]; | ||||
|     [but addTarget:self action:@selector(switchingEnvironmentVCAction) forControlEvents:UIControlEventTouchUpInside]; | ||||
|     [but mas_makeConstraints:^(MASConstraintMaker *make) { | ||||
|         make.trailing.mas_equalTo(-kGetScaleWidth(30)); | ||||
|         make.top.mas_equalTo(kStatusBarHeight+20); | ||||
|     }]; | ||||
|  | ||||
| } | ||||
| -(void)switchingEnvironmentVCAction{ | ||||
| #ifdef DEBUG | ||||
|     PISwitchingEnvironmentVC *vc = [PISwitchingEnvironmentVC new]; | ||||
|     [self.navigationController pushViewController:vc animated:YES]; | ||||
| #else | ||||
| #endif | ||||
| } | ||||
| - (void)setConfigPrivacyAlertView { | ||||
|     NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults]; | ||||
|     NSString *isShow = [defaults objectForKey:kYouMiNumberCountKey]; | ||||
|   | ||||
| @@ -122,6 +122,8 @@ typedef NS_ENUM(NSUInteger, CustomMessageType) { | ||||
|     CustomMessageType_General_Floating_Screen = 107, | ||||
|     ///聊天大厅上头条 | ||||
|     CustomMessageType_Chat_Hall_Headlinesn = 108, | ||||
|     ///家族新协议 | ||||
|     CustomMessageType_New_Hall = 110, | ||||
| }; | ||||
|  | ||||
|  | ||||
| @@ -661,6 +663,20 @@ typedef NS_ENUM(NSUInteger, CustomMessageTypeChatHallHeadlinesn) { | ||||
|     ///所有房间 | ||||
|     Custom_Message_Sub_Chat_Hall_Headlinesn = 1081,//单房间 | ||||
|    | ||||
| }; | ||||
| ///家族新协议 | ||||
| //CustomMessageType_New_Hall = 110, | ||||
| typedef NS_ENUM(NSUInteger, CustomMessageTypeNewHall) { | ||||
|     ///所有房间 | ||||
|     Custom_Message_Sub_New_Hall_Invite = 1101,//邀请加入 | ||||
|     Custom_Message_Sub_New_Hall_Deal_Invite = 1102,//邀请加入 | ||||
|     Custom_Message_Sub_New_Hall_Apply = 1103,//申请加入 | ||||
|     Custom_Message_Sub_New_Hall_Deal_Apply = 1104,//申请加入 | ||||
|     Custom_Message_Sub_New_Hall_Set_Manager = 1105,//设置管理员 | ||||
|     Custom_Message_Sub_New_Hall_Remove_Manager = 1106,//移除管理员 | ||||
|     Custom_Message_Sub_New_Hall_Create = 1107,//加入成员 | ||||
|     Custom_Message_Sub_New_Hall_Dismiss = 1108,//移除成员 | ||||
|    | ||||
| }; | ||||
| @interface AttachmentModel : PIBaseModel<NIMCustomAttachment> | ||||
| @property (nonatomic,assign) int first; | ||||
|   | ||||
| @@ -22,7 +22,7 @@ | ||||
| #import "XPSessionFindNewFiltrateView.h" | ||||
| #import "XPSessionFindNewGreetListView.h" | ||||
| #import "XPMineUserInfoViewController.h" | ||||
| #import "XPMineSimpleUserInfoViewController.h" | ||||
|  | ||||
| ///P | ||||
| #import "XPSessionFindNewProtocol.h" | ||||
| #import "XPSessionFindNewPresenter.h" | ||||
| @@ -170,15 +170,9 @@ | ||||
|  | ||||
| - (void)xPSessionFindNewTableViewCell:(XPSessionFindNewTableViewCell *)cell didClickAvatar:(FindNewUserInfoModel *)userInfo { | ||||
| 	if (userInfo.uid > 0) { | ||||
|         if ([ClientConfig shareConfig].canOpen) { | ||||
|             XPMineUserInfoViewController * userInfoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|             userInfoVC.uid = userInfo.uid.integerValue; | ||||
|             [[XCCurrentVCStackManager shareManager].getCurrentVC.navigationController pushViewController:userInfoVC animated:YES]; | ||||
|         }else{ | ||||
|             XPMineSimpleUserInfoViewController * userInfoVC = [[XPMineSimpleUserInfoViewController alloc] init]; | ||||
|             userInfoVC.uid = userInfo.uid.integerValue; | ||||
|             [[XCCurrentVCStackManager shareManager].getCurrentVC.navigationController pushViewController:userInfoVC animated:YES]; | ||||
|         } | ||||
|         XPMineUserInfoViewController * userInfoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|         userInfoVC.uid = userInfo.uid.integerValue; | ||||
|         [[XCCurrentVCStackManager shareManager].getCurrentVC.navigationController pushViewController:userInfoVC animated:YES]; | ||||
| 	} | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -45,7 +45,7 @@ | ||||
| 				if (attachment.second == Custom_Message_Sub_Gift_Send) { | ||||
| 					text = YMLocalizedString(@"NIMMessageUtils5"); | ||||
| 				} | ||||
| 			} else if(attachment.first == CustomMessageType_Hall) { | ||||
| 			} else if(attachment.first == CustomMessageType_Hall || attachment.first == CustomMessageType_New_Hall) { | ||||
| 				text = YMLocalizedString(@"NIMMessageUtils6"); | ||||
| 			} else if(attachment.first == CustomMessageType_Member_Online && attachment.second == Custom_Message_Type_Attention_Member_Online) { | ||||
| 				return YMLocalizedString(@"NIMMessageUtils7"); | ||||
|   | ||||
| @@ -238,6 +238,10 @@ | ||||
| 	if (classStr) { | ||||
| 		if (![self.messageContent isKindOfClass:NSClassFromString(classStr)]) { | ||||
| 			self.messageContent = [[NSClassFromString(classStr) alloc] init]; | ||||
|             if([self.messageContent isKindOfClass:[MessageContentCustomView class]]){ | ||||
|                 MessageContentCustomView *messageContent = (MessageContentCustomView *)self.messageContent; | ||||
|                 messageContent.delegate = self; | ||||
|             } | ||||
| 		} | ||||
| 	} else { | ||||
| 		NSAssert(classStr != nil, @"message should not be nil"); | ||||
|   | ||||
| @@ -111,48 +111,53 @@ | ||||
| } | ||||
|  | ||||
| - (void)render:(MessageGuildModel *)model { | ||||
| 	self.message = model.message; | ||||
| 	NIMCustomObject *obj = (NIMCustomObject *)model.message.messageObject; | ||||
| 	AttachmentModel * attach = obj.attachment; | ||||
| 	self.attachment = attach; | ||||
| 	GuildMessageModel * info; | ||||
| 	if (model.message.localExt) { | ||||
| 		info = [GuildMessageModel modelWithDictionary:model.message.localExt]; | ||||
| 	} else { | ||||
| 		info = [GuildMessageModel modelWithDictionary:attach.data]; | ||||
| 	} | ||||
| 	self.messageInfo = info; | ||||
| 	self.titleLabel.text = info.layout.title.content; | ||||
| 	self.titleLabel.font = [UIFont systemFontOfSize:info.layout.title.fontSize weight:info.layout.title.fontBold?UIFontWeightBold:UIFontWeightRegular]; | ||||
| 	NSMutableAttributedString *attr = [[NSMutableAttributedString alloc]init]; | ||||
| 	GuildMessageLayoutModel *layout = info.layout; | ||||
| 	for (GuildMessageLayoutInfoModel *params in layout.contents) { | ||||
| 		if (params.content.length > 0) { | ||||
| 			if ([params.content containsString:@"/r/n"]) { | ||||
| 				params.content = @"\r\n"; | ||||
| 			} | ||||
| 			NSMutableAttributedString *subAttr = [[NSMutableAttributedString alloc]initWithString:params.content]; | ||||
| 			if (params.fontSize > 0) { | ||||
| 				[subAttr addAttribute:NSFontAttributeName value:[UIFont systemFontOfSize:params.fontSize weight:params.fontBold?UIFontWeightBold:UIFontWeightRegular] range:NSMakeRange(0, subAttr.length)]; | ||||
| 			} | ||||
|  | ||||
| 			if (params.fontColor.length > 0) { | ||||
| 				[subAttr addAttribute:NSForegroundColorAttributeName value:[DJDKMIMOMColor colorWithHexString:params.fontColor] range:NSMakeRange(0, subAttr.length)]; | ||||
| 			} | ||||
| 			[attr appendAttributedString:subAttr]; | ||||
| 		} | ||||
| 	} | ||||
| 	attr.yy_lineSpacing = 5; | ||||
| 	self.contentLabel.attributedText = attr; | ||||
| 	self.contentLabel.textAlignment = NSTextAlignmentCenter; | ||||
| 	CGSize maxSize = CGSizeMake(MESSAGE_MAX_WIDTH - MESSAGE_TEXT_PADDING * 2, CGFLOAT_MAX); | ||||
| 	YYTextLayout * contentLayout = [YYTextLayout layoutWithContainerSize:maxSize text:attr]; | ||||
| 	CGFloat contentHeight = contentLayout.textBoundingSize.height + 5; | ||||
| 	///顶部的距离 20  title的高度15 title到content的高度15 | ||||
| 	[self.contentView mas_updateConstraints:^(MASConstraintMaker *make) { | ||||
| 		make.height.mas_equalTo(contentHeight + 20+ 15 + 15); | ||||
| 	}]; | ||||
| 	BOOL isCommonNotice = (attach.second == Custom_Message_Sub_Hall_Notice || attach.second == Custom_Message_Sub_Hall_Become_Hall); | ||||
|     self.message = model.message; | ||||
|     NIMCustomObject *obj = (NIMCustomObject *)model.message.messageObject; | ||||
|     AttachmentModel * attach = (AttachmentModel *)obj.attachment; | ||||
|     self.attachment = attach; | ||||
|     GuildMessageModel * info; | ||||
|     if (model.message.localExt) { | ||||
|         info = [GuildMessageModel modelWithDictionary:model.message.localExt]; | ||||
|     } else { | ||||
|         info = [GuildMessageModel modelWithDictionary:attach.data]; | ||||
|     } | ||||
|     self.messageInfo = info; | ||||
|     self.titleLabel.text = info.layout.title.content; | ||||
|     self.titleLabel.font = [UIFont systemFontOfSize:info.layout.title.fontSize weight:info.layout.title.fontBold?UIFontWeightBold:UIFontWeightRegular]; | ||||
|     NSMutableAttributedString *attr = [[NSMutableAttributedString alloc]init]; | ||||
|     GuildMessageLayoutModel *layout = info.layout; | ||||
|     for (GuildMessageLayoutInfoModel *params in layout.contents) { | ||||
|         if (params.content.length > 0) { | ||||
|             if ([params.content containsString:@"/r/n"]) { | ||||
|                 params.content = @"\r\n"; | ||||
|             } | ||||
|             NSMutableAttributedString *subAttr = [[NSMutableAttributedString alloc]initWithString:params.content]; | ||||
|             if (params.fontSize > 0) { | ||||
|                 [subAttr addAttribute:NSFontAttributeName value:[UIFont systemFontOfSize:params.fontSize weight:params.fontBold?UIFontWeightBold:UIFontWeightRegular] range:NSMakeRange(0, subAttr.length)]; | ||||
|             } | ||||
|              | ||||
|             if (params.fontColor.length > 0) { | ||||
|                 [subAttr addAttribute:NSForegroundColorAttributeName value:[DJDKMIMOMColor colorWithHexString:params.fontColor] range:NSMakeRange(0, subAttr.length)]; | ||||
|             } | ||||
|             [attr appendAttributedString:subAttr]; | ||||
|         } | ||||
|     } | ||||
|     attr.yy_lineSpacing = 5; | ||||
|     self.contentLabel.attributedText = attr; | ||||
|     self.contentLabel.textAlignment = NSTextAlignmentCenter; | ||||
|     CGSize maxSize = CGSizeMake(MESSAGE_MAX_WIDTH - MESSAGE_TEXT_PADDING * 2, CGFLOAT_MAX); | ||||
|     YYTextLayout * contentLayout = [YYTextLayout layoutWithContainerSize:maxSize text:attr]; | ||||
|     CGFloat contentHeight = contentLayout.textBoundingSize.height + 5; | ||||
|     ///顶部的距离 20  title的高度15 title到content的高度15 | ||||
|     [self.contentView mas_updateConstraints:^(MASConstraintMaker *make) { | ||||
|         make.height.mas_equalTo(contentHeight + 20+ 15 + 15); | ||||
|     }]; | ||||
|     BOOL isCommonNotice ; | ||||
|     if(attach.first == CustomMessageType_Hall){ | ||||
|         isCommonNotice = (attach.second == Custom_Message_Sub_Hall_Notice || attach.second == Custom_Message_Sub_Hall_Become_Hall); | ||||
|     }else{ | ||||
|         isCommonNotice = !(attach.second == Custom_Message_Sub_New_Hall_Invite || attach.second == Custom_Message_Sub_New_Hall_Apply); | ||||
|     } | ||||
| 	if (!isCommonNotice) { | ||||
| 		self.controlStackView.hidden = NO; | ||||
| 		if (info.msgStatus == 0) { | ||||
| @@ -235,31 +240,36 @@ | ||||
| 		[params safeSetObject:[AccountInfoStorage instance].getUid forKey:@"uid"]; | ||||
| 		///0拒绝 1同意 | ||||
| 		NSString * type = sender.tag == 1000? @"0" : @"1"; | ||||
| 		if (self.attachment.second == Custom_Message_Sub_Hall_Apply_Join || self.attachment.second == Custom_Message_Sub_Hall_Manager_Invite || self.attachment.second == Custom_Message_Sub_Hall_Apply_Exit) { | ||||
| 		if (self.attachment.second == Custom_Message_Sub_Hall_Apply_Join || self.attachment.second == Custom_Message_Sub_Hall_Manager_Invite || self.attachment.second == Custom_Message_Sub_Hall_Apply_Exit || self.attachment.second == Custom_Message_Sub_New_Hall_Invite || self.attachment.second == Custom_Message_Sub_New_Hall_Apply) { | ||||
| 			if (self.attachment.second != Custom_Message_Sub_Hall_Apply_Exit) { | ||||
| 				[params setObject:type forKey:@"type"]; | ||||
| 			} | ||||
| 			[XNDJTDDLoadingTool showLoading]; | ||||
| 			[HttpRequestHelper POST:self.messageInfo.url params:params success:^(BaseModel * _Nonnull data) { | ||||
| 				[XNDJTDDLoadingTool hideHUD]; | ||||
| 				NSString *code = [NSString stringWithFormat:@"%@", data.data[@"code"]]; | ||||
| 				BOOL isExpired = [code isEqualToString:@"90121"]; | ||||
| 				BOOL isHandled = [code isEqualToString:@"90122"]; | ||||
| 				MessageGuildState state = MessageGuildState_Untreated; | ||||
| 				if (isExpired) { | ||||
| 					state = MessageGuildState_OutData; | ||||
| 				} else if(isHandled) { | ||||
| 					state = MessageGuildState_Processed; | ||||
| 				} else { | ||||
| 					state = sender.tag == 1000 ? MessageGuildState_Reject : MessageGuildState_Agree; | ||||
| 				} | ||||
| 				self.messageInfo.msgStatus = state; | ||||
| 				self.message.localExt = [self.messageInfo model2dictionary]; | ||||
| 				[[NIMSDK sharedSDK].conversationManager updateMessage:self.message forSession:self.message.session completion:^(NSError * _Nullable error) { | ||||
| 					if (self.delegate && [self.delegate respondsToSelector:@selector(updateMessageSuccess:)]) { | ||||
| 						[self.delegate updateMessageSuccess:self.message]; | ||||
| 					} | ||||
| 				}]; | ||||
|                 [XNDJTDDLoadingTool hideHUD]; | ||||
|                 if(data.code == 200){ | ||||
|                     NSString *code = [NSString stringWithFormat:@"%@", data.data[@"code"]]; | ||||
|                     BOOL isExpired = [code isEqualToString:@"90121"]; | ||||
|                     BOOL isHandled = [code isEqualToString:@"90122"]; | ||||
|                     MessageGuildState state = MessageGuildState_Untreated; | ||||
|                     if (isExpired) { | ||||
|                         state = MessageGuildState_OutData; | ||||
|                     } else if(isHandled) { | ||||
|                         state = MessageGuildState_Processed; | ||||
|                     } else { | ||||
|                         state = sender.tag == 1000 ? MessageGuildState_Reject : MessageGuildState_Agree; | ||||
|                     } | ||||
|                     self.messageInfo.msgStatus = state; | ||||
|                     self.message.localExt = [self.messageInfo model2dictionary]; | ||||
|                     [[NIMSDK sharedSDK].conversationManager updateMessage:self.message forSession:self.message.session completion:^(NSError * _Nullable error) { | ||||
|                         if (self.delegate && [self.delegate respondsToSelector:@selector(updateMessageSuccess:)]) { | ||||
|                             [self.delegate updateMessageSuccess:self.message]; | ||||
|                         } | ||||
|                     }]; | ||||
|                     return; | ||||
|                 } | ||||
| 				 | ||||
|                 [XNDJTDDLoadingTool showErrorWithMessage:data.message]; | ||||
| 			} failure:^(NSInteger resCode, NSString * _Nonnull message) { | ||||
| 				[XNDJTDDLoadingTool hideHUD]; | ||||
| 				[XNDJTDDLoadingTool showErrorWithMessage:message]; | ||||
|   | ||||
| @@ -76,15 +76,6 @@ | ||||
| 	XPMonentsDetailViewController * detailView = [[XPMonentsDetailViewController alloc] init]; | ||||
| 	detailView.monentsInfo = self.monents; | ||||
| 	[[XCCurrentVCStackManager shareManager].getCurrentVC.navigationController pushViewController:detailView animated:YES]; | ||||
|     if ([ClientConfig shareConfig].canOpen) { | ||||
|         XPMonentsDetailViewController * detailView = [[XPMonentsDetailViewController alloc] init]; | ||||
|         detailView.monentsInfo = self.monents; | ||||
|         [[XCCurrentVCStackManager shareManager].getCurrentVC.navigationController pushViewController:detailView animated:YES]; | ||||
|     }else{ | ||||
|         XPMomentsSimpleDetailViewController * detailView = [[XPMomentsSimpleDetailViewController alloc] init]; | ||||
|         detailView.monentsInfo = self.monents; | ||||
|         [[XCCurrentVCStackManager shareManager].getCurrentVC.navigationController pushViewController:detailView animated:YES]; | ||||
|     } | ||||
| } | ||||
|  | ||||
| - (void)render:(MessageBaseModel *)message { | ||||
|   | ||||
| @@ -28,7 +28,7 @@ | ||||
|  | ||||
| #import "XPIAPRechargeViewController.h" | ||||
| #import "XPMineUserInfoViewController.h" | ||||
| #import "XPMineSimpleUserInfoViewController.h" | ||||
|  | ||||
| #import "XPMineDressUpViewController.h" | ||||
| #import "XPDressUpShopViewController.h" | ||||
| #import "XPMineLoginPasswordViewController.h" | ||||
| @@ -152,16 +152,9 @@ | ||||
| 		case SecretaryRouterType_UserInfo: | ||||
| 		{ | ||||
| 			if (value.length > 0) { | ||||
| 				 | ||||
|                 if ([ClientConfig shareConfig].canOpen) { | ||||
|                     XPMineUserInfoViewController * userInfoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|                     userInfoVC.uid = value.integerValue; | ||||
|                     [[XCCurrentVCStackManager shareManager].getCurrentVC.navigationController pushViewController:userInfoVC animated:YES]; | ||||
|                 }else{ | ||||
|                     XPMineSimpleUserInfoViewController * userInfoVC = [[XPMineSimpleUserInfoViewController alloc] init]; | ||||
|                     userInfoVC.uid = value.integerValue; | ||||
|                     [[XCCurrentVCStackManager shareManager].getCurrentVC.navigationController pushViewController:userInfoVC animated:YES]; | ||||
|                 } | ||||
|                 XPMineUserInfoViewController * userInfoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|                 userInfoVC.uid = value.integerValue; | ||||
|                 [[XCCurrentVCStackManager shareManager].getCurrentVC.navigationController pushViewController:userInfoVC animated:YES]; | ||||
| 			} | ||||
| 		} | ||||
| 			break; | ||||
|   | ||||
| @@ -17,7 +17,7 @@ | ||||
| 	if (self = [super initWithMessage:message]) { | ||||
| 		self.messageType = SessionMessageType_Custom; | ||||
| 		NIMCustomObject *obj = (NIMCustomObject *)message.messageObject; | ||||
| 		AttachmentModel * attach = obj.attachment; | ||||
| 		AttachmentModel * attach = (AttachmentModel *)obj.attachment; | ||||
| 		GuildMessageModel * info = [GuildMessageModel modelWithDictionary:attach.data]; | ||||
| 		NSMutableAttributedString *attr = [[NSMutableAttributedString alloc]init]; | ||||
| 		GuildMessageLayoutModel *layout = info.layout; | ||||
|   | ||||
| @@ -28,7 +28,7 @@ | ||||
| #import "SessionSettingUserView.h" | ||||
| #import "XPWebViewController.h" | ||||
| #import "XPMineUserInfoViewController.h" | ||||
| #import "XPMineSimpleUserInfoViewController.h" | ||||
|  | ||||
|  | ||||
| @interface SessionInfoViewController ()<UITableViewDelegate, UITableViewDataSource, SessionSettingTableViewCellDelegate> | ||||
| ///头部试图 | ||||
| @@ -88,16 +88,12 @@ | ||||
| 	if (self.datasource.count > 0) { | ||||
| 		SessionSettingModel * model = [self.datasource safeObjectAtIndex1:indexPath.row]; | ||||
| 		if (model.settingType == SessionSettingType_report) { | ||||
| 			if ([ClientConfig shareConfig].canOpen) { | ||||
| 				[StatisticsServiceHelper trackEventWithKey:StatisticsServiceEvent_chat_set_report_click]; | ||||
| 				XPWebViewController *webVC = [[XPWebViewController alloc] init]; | ||||
| 				NSString *urlstr = [NSString stringWithFormat:@"%@?reportUid=%ld&source=CHAT",URLWithType(kReportRoomURL),self.userInfo.uid]; | ||||
| 				webVC.url = urlstr; | ||||
| 				[self.navigationController pushViewController:webVC animated:YES]; | ||||
| 			} else { | ||||
| 				[XNDJTDDLoadingTool showErrorWithMessage:YMLocalizedString(@"SessionInfoViewController1")]; | ||||
| 			} | ||||
|  | ||||
|             [StatisticsServiceHelper trackEventWithKey:StatisticsServiceEvent_chat_set_report_click]; | ||||
|             XPWebViewController *webVC = [[XPWebViewController alloc] init]; | ||||
|             webVC.url = [NSString stringWithFormat:@"%@?reportUid=%ld&source=CHAT", | ||||
|                          URLWithType(kReportRoomURL), | ||||
|                          self.userInfo.uid]; | ||||
|             [self.navigationController pushViewController:webVC animated:YES]; | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @@ -182,16 +178,9 @@ | ||||
| #pragma mark - Event Response | ||||
| - (void)didTapUserRecognizer { | ||||
| 	[StatisticsServiceHelper trackEventWithKey:StatisticsServiceEvent_chat_set_data_click]; | ||||
| 	 | ||||
|     if ([ClientConfig shareConfig].canOpen) { | ||||
|         XPMineUserInfoViewController * mineVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|         mineVC.uid = self.userInfo.uid; | ||||
|         [self.navigationController pushViewController:mineVC animated:YES]; | ||||
|     }else{ | ||||
|         XPMineSimpleUserInfoViewController * mineVC = [[XPMineSimpleUserInfoViewController alloc] init]; | ||||
|         mineVC.uid = self.userInfo.uid; | ||||
|         [self.navigationController pushViewController:mineVC animated:YES]; | ||||
|     } | ||||
|     XPMineUserInfoViewController * mineVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|     mineVC.uid = self.userInfo.uid; | ||||
|     [self.navigationController pushViewController:mineVC animated:YES]; | ||||
| } | ||||
|  | ||||
| #pragma mark - Getters And Setters | ||||
|   | ||||
| @@ -60,7 +60,7 @@ | ||||
| #import "MessageTreasureFairyModel.h" | ||||
| ///View | ||||
| #import "XPMineUserInfoViewController.h" | ||||
| #import "XPMineSimpleUserInfoViewController.h" | ||||
|  | ||||
| #import "XPRoomViewController.h" | ||||
| #import "RoomHostDelegate.h" | ||||
| #import "MessageCell.h" | ||||
| @@ -249,7 +249,10 @@ | ||||
| 		model = [[MessageTextClickModel alloc] initWithMessage:message]; | ||||
| 	} else if(attachment.first == CustomMessageType_Hall) { | ||||
| 		model = [[MessageGuildModel alloc] initWithMessage:message]; | ||||
| 	} else if(attachment.first == CustomMessageType_Member_Online && attachment.second == Custom_Message_Type_Attention_Member_Online) { | ||||
| 	}else if(attachment.first == CustomMessageType_New_Hall) { | ||||
|         model = [[MessageGuildModel alloc] initWithMessage:message]; | ||||
|          | ||||
|     } else if(attachment.first == CustomMessageType_Member_Online && attachment.second == Custom_Message_Type_Attention_Member_Online) { | ||||
| 		model = [[MessageOpenLiveModel alloc] initWithMessage:message]; | ||||
| 	} else if(attachment.first == CustomMessageType_Application_Share && attachment.second == Custom_Message_Sub_Application_Share_Room) { | ||||
| 		model = [[MessageOpenLiveModel alloc] initWithMessage:message]; | ||||
| @@ -510,16 +513,9 @@ | ||||
|  | ||||
| - (void)didTapAvatar:(NSString *)uid { | ||||
| 	if (uid.length > 0 && ![NIMMessageUtils isOfficalAccount:uid]) { | ||||
| 		 | ||||
|         if ([ClientConfig shareConfig].canOpen) { | ||||
|             XPMineUserInfoViewController * infoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|             infoVC.uid = uid.integerValue; | ||||
|             [[self getKeyWindowNav] pushViewController:infoVC animated:YES]; | ||||
|         }else{ | ||||
|             XPMineSimpleUserInfoViewController * infoVC = [[XPMineSimpleUserInfoViewController alloc] init]; | ||||
|             infoVC.uid = uid.integerValue; | ||||
|             [[self getKeyWindowNav] pushViewController:infoVC animated:YES]; | ||||
|         } | ||||
|         XPMineUserInfoViewController * infoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|         infoVC.uid = uid.integerValue; | ||||
|         [[self getKeyWindowNav] pushViewController:infoVC animated:YES]; | ||||
| 	} | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -47,6 +47,8 @@ | ||||
|  | ||||
| - (void)renderWithSession:(NIMRecentSession *)recent { | ||||
|     NIMUser *user = [[NIMSDK sharedSDK].userManager userInfo:recent.session.sessionId]; | ||||
|     self.avatarImageView.image = nil; | ||||
|     self.nameLabel.text = @""; | ||||
| 	if (user.userInfo == nil) { | ||||
| 		NSString * uid = recent.session.sessionId; | ||||
| 		if (uid > 0) { | ||||
| @@ -56,7 +58,9 @@ | ||||
| 					NIMUser * userInfo = users.firstObject; | ||||
| 					self.nameLabel.text = userInfo.userInfo.nickName; | ||||
| 					NSString *avatarUrl = userInfo.userInfo.avatarUrl; | ||||
| 					self.avatarImageView.imageUrl = avatarUrl; | ||||
|                     [self.avatarImageView loadImageWithUrl:avatarUrl completion:^(UIImage * _Nullable image, NSURL * _Nonnull url) { | ||||
|                         self.avatarImageView.image = image; | ||||
|                     }]; | ||||
| 					[self.nameLabel sizeToFit]; | ||||
| 				} | ||||
| 			}]; | ||||
| @@ -64,7 +68,9 @@ | ||||
| 	} else { | ||||
| 		NSString *avatarUrl = user.userInfo.avatarUrl; | ||||
| 		self.nameLabel.text = user.userInfo.nickName; | ||||
| 		self.avatarImageView.imageUrl = avatarUrl; | ||||
|         [self.avatarImageView loadImageWithUrl:avatarUrl completion:^(UIImage * _Nullable image, NSURL * _Nonnull url) { | ||||
|             self.avatarImageView.image = image; | ||||
|         }]; | ||||
| 		[self.nameLabel sizeToFit]; | ||||
| 	} | ||||
|     NSString *messageTitle = [NIMMessageUtils messageContent:recent.lastMessage]; | ||||
|   | ||||
| @@ -52,115 +52,80 @@ | ||||
|         self.phoneItem.subTitle = userinfo.isBindPhone ? userinfo.phone : YMLocalizedString(@"XPMineSettingPresent0"); | ||||
|         self.payItem.subTitle = userinfo.isBindPaymentPwd ? YMLocalizedString(@"XPMineSettingPresent26") : YMLocalizedString(@"XPMineSettingPresent2"); | ||||
|     } else { | ||||
|         if ([ClientConfig shareConfig].canOpen) { | ||||
|             XPMineSettingItemModel * phoneItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             phoneItem.title = YMLocalizedString(@"XPMineSettingPresent3"); | ||||
|             phoneItem.subTitle = userinfo.isBindPhone ? userinfo.phone : YMLocalizedString(@"XPMineSettingPresent4"); | ||||
|             phoneItem.type = XPMineSettingItemType_Phone; | ||||
|             self.phoneItem = phoneItem; | ||||
|              | ||||
|             XPMineSettingItemModel * loginItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             loginItem.title = userinfo.isBindPasswd ? YMLocalizedString(@"XPMineLoginPasswordViewController6") : YMLocalizedString(@"XPMineSettingPresent6"); | ||||
|             loginItem.subTitle = YMLocalizedString(@"XPMineSettingPresent7"); | ||||
|             loginItem.type = XPMineSettingItemType_Login_Password; | ||||
|             self.loginItem = loginItem; | ||||
|              | ||||
|             XPMineSettingItemModel * shieldItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             shieldItem.title = YMLocalizedString(@"XPMineSettingPresent27"); | ||||
|         XPMineSettingItemModel * phoneItem = [[XPMineSettingItemModel alloc] init]; | ||||
|         phoneItem.title = YMLocalizedString(@"XPMineSettingPresent3"); | ||||
|         phoneItem.subTitle = userinfo.isBindPhone ? userinfo.phone : YMLocalizedString(@"XPMineSettingPresent4"); | ||||
|         phoneItem.type = XPMineSettingItemType_Phone; | ||||
|         self.phoneItem = phoneItem; | ||||
|          | ||||
|             shieldItem.type = XPMineSettingItemType_Shield_management; | ||||
|              | ||||
|             XPMineSettingItemModel * blackListItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             blackListItem.title = YMLocalizedString(@"XPMineSettingPresent8"); | ||||
|             blackListItem.subTitle = @""; | ||||
|             blackListItem.type = XPMineSettingItemType_Black_Manager; | ||||
|              | ||||
|             XPMineSettingItemModel * languageItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             languageItem.title = YMLocalizedString(@"XPMineSettingPresent28"); | ||||
|             languageItem.subTitle = @""; | ||||
|             languageItem.type = XPMineSettingItemType_Language; | ||||
|         XPMineSettingItemModel * loginItem = [[XPMineSettingItemModel alloc] init]; | ||||
|         loginItem.title = userinfo.isBindPasswd ? YMLocalizedString(@"XPMineLoginPasswordViewController6") : YMLocalizedString(@"XPMineSettingPresent6"); | ||||
|         loginItem.subTitle = YMLocalizedString(@"XPMineSettingPresent7"); | ||||
|         loginItem.type = XPMineSettingItemType_Login_Password; | ||||
|         self.loginItem = loginItem; | ||||
|          | ||||
|         XPMineSettingItemModel * shieldItem = [[XPMineSettingItemModel alloc] init]; | ||||
|         shieldItem.title = YMLocalizedString(@"XPMineSettingPresent27"); | ||||
|      | ||||
|         shieldItem.type = XPMineSettingItemType_Shield_management; | ||||
|          | ||||
|         XPMineSettingItemModel * blackListItem = [[XPMineSettingItemModel alloc] init]; | ||||
|         blackListItem.title = YMLocalizedString(@"XPMineSettingPresent8"); | ||||
|         blackListItem.subTitle = @""; | ||||
|         blackListItem.type = XPMineSettingItemType_Black_Manager; | ||||
|          | ||||
|         XPMineSettingItemModel * languageItem = [[XPMineSettingItemModel alloc] init]; | ||||
|         languageItem.title = YMLocalizedString(@"XPMineSettingPresent28"); | ||||
|         languageItem.subTitle = @""; | ||||
|         languageItem.type = XPMineSettingItemType_Language; | ||||
|  | ||||
|             XPMineSettingItemModel * payItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             payItem.title = YMLocalizedString(@"XPMineSettingPresent9"); | ||||
|             payItem.subTitle = userinfo.isBindPaymentPwd ? YMLocalizedString(@"XPMineSettingPresent26") : YMLocalizedString(@"XPMineSettingPresent11"); | ||||
|             payItem.type = XPMineSettingItemType_Pay_Password; | ||||
|             self.payItem = payItem; | ||||
|              | ||||
|             XPMineSettingItemModel * notificaItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             notificaItem.title = YMLocalizedString(@"XPMineSettingPresent12"); | ||||
|             notificaItem.subTitle = YMLocalizedString(@"XPMineSettingPresent13"); | ||||
|             notificaItem.type = XPMineSettingItemType_Notification_Remind; | ||||
|              | ||||
|             XPMineSettingItemModel * privacyItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             privacyItem.title = YMLocalizedString(@"XPMineSettingPresent14"); | ||||
|             privacyItem.subTitle = @""; | ||||
|             privacyItem.type = XPMineSettingItemType_Permission; | ||||
|              | ||||
|             XPMineSettingItemModel * helperItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             helperItem.title = YMLocalizedString(@"XPMineSettingPresent15"); | ||||
|             helperItem.subTitle = @""; | ||||
|             helperItem.type = XPMineSettingItemType_Helper; | ||||
|              | ||||
|             XPMineSettingItemModel * feedbackItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             feedbackItem.title = YMLocalizedString(@"XPMineSettingPresent16"); | ||||
|             feedbackItem.subTitle = @""; | ||||
|             feedbackItem.type = XPMineSettingItemType_Feedback; | ||||
|              | ||||
|             XPMineSettingItemModel * clearMemoryItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             clearMemoryItem.title = YMLocalizedString(@"XPMineSettingPresent17"); | ||||
|             clearMemoryItem.subTitle = @""; | ||||
|             clearMemoryItem.type = XPMineSettingItemType_Clear_Memory; | ||||
|              | ||||
|             XPMineSettingItemModel *updateItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             updateItem.title = YMLocalizedString(@"XPMineSettingPresent18"); | ||||
|             updateItem.subTitle = @""; | ||||
|             updateItem.type = XPMineSettingItemType_CheckUpdate; | ||||
|              | ||||
|             XPMineSettingItemModel * aboutusItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             aboutusItem.title = [NSString stringWithFormat:YMLocalizedString(@"XPMineAboutUsViewController0"), AppName]; | ||||
|             aboutusItem.subTitle = @""; | ||||
|             aboutusItem.type = XPMineSettingItemType_About_Us; | ||||
|              | ||||
|             NSArray * oneSection = @[phoneItem]; | ||||
|             NSArray * twoSection = @[loginItem,payItem, notificaItem,shieldItem, blackListItem,languageItem]; | ||||
|             NSArray * threeSection = @[privacyItem]; | ||||
|             NSArray * fourthSection = @[helperItem, clearMemoryItem, updateItem, aboutusItem]; | ||||
|              | ||||
|             self.datasouce = @[oneSection, twoSection, threeSection, fourthSection]; | ||||
|         }else{ | ||||
|             XPMineSettingItemModel * blackListItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             blackListItem.title = YMLocalizedString(@"XPMineSettingPresent20"); | ||||
|             blackListItem.subTitle = @""; | ||||
|             blackListItem.type = XPMineSettingItemType_Black_Manager; | ||||
|              | ||||
|             XPMineSettingItemModel * phoneItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             phoneItem.title = YMLocalizedString(@"XPMineSettingPresent21"); | ||||
|             phoneItem.subTitle = userinfo.isBindPhone ? userinfo.phone : @""; | ||||
|             phoneItem.type = XPMineSettingItemType_Phone; | ||||
|             self.phoneItem = phoneItem; | ||||
|  | ||||
|             XPMineSettingItemModel * loginItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             loginItem.title = userinfo.isBindPasswd ? YMLocalizedString(@"XPMineLoginPasswordViewController6") : YMLocalizedString(@"XPMineSettingPresent23"); | ||||
|             loginItem.subTitle = @""; | ||||
|             loginItem.type = XPMineSettingItemType_Login_Password; | ||||
|             self.loginItem = loginItem; | ||||
|  | ||||
|             XPMineSettingItemModel * clearMemoryItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             clearMemoryItem.title = YMLocalizedString(@"XPMineSettingPresent24"); | ||||
|             clearMemoryItem.subTitle = @""; | ||||
|             clearMemoryItem.type = XPMineSettingItemType_Clear_Memory; | ||||
|              | ||||
|             XPMineSettingItemModel * deleteItem = [[XPMineSettingItemModel alloc] init]; | ||||
|             deleteItem.title = YMLocalizedString(@"XPMineSettingPresent25"); | ||||
|             deleteItem.subTitle = @""; | ||||
|             deleteItem.type = XPMineSettingItemType_Delete_Account; | ||||
|              | ||||
|             NSArray * oneSection = @[blackListItem]; | ||||
|             NSArray * twoSection = @[phoneItem, loginItem]; | ||||
|             NSArray * threeSection = @[clearMemoryItem, deleteItem]; | ||||
|              | ||||
|             self.datasouce = @[oneSection, twoSection, threeSection]; | ||||
|         } | ||||
|         XPMineSettingItemModel * payItem = [[XPMineSettingItemModel alloc] init]; | ||||
|         payItem.title = YMLocalizedString(@"XPMineSettingPresent9"); | ||||
|         payItem.subTitle = userinfo.isBindPaymentPwd ? YMLocalizedString(@"XPMineSettingPresent26") : YMLocalizedString(@"XPMineSettingPresent11"); | ||||
|         payItem.type = XPMineSettingItemType_Pay_Password; | ||||
|         self.payItem = payItem; | ||||
|          | ||||
|         XPMineSettingItemModel * notificaItem = [[XPMineSettingItemModel alloc] init]; | ||||
|         notificaItem.title = YMLocalizedString(@"XPMineSettingPresent12"); | ||||
|         notificaItem.subTitle = YMLocalizedString(@"XPMineSettingPresent13"); | ||||
|         notificaItem.type = XPMineSettingItemType_Notification_Remind; | ||||
|          | ||||
|         XPMineSettingItemModel * privacyItem = [[XPMineSettingItemModel alloc] init]; | ||||
|         privacyItem.title = YMLocalizedString(@"XPMineSettingPresent14"); | ||||
|         privacyItem.subTitle = @""; | ||||
|         privacyItem.type = XPMineSettingItemType_Permission; | ||||
|          | ||||
|         XPMineSettingItemModel * helperItem = [[XPMineSettingItemModel alloc] init]; | ||||
|         helperItem.title = YMLocalizedString(@"XPMineSettingPresent15"); | ||||
|         helperItem.subTitle = @""; | ||||
|         helperItem.type = XPMineSettingItemType_Helper; | ||||
|          | ||||
|         XPMineSettingItemModel * feedbackItem = [[XPMineSettingItemModel alloc] init]; | ||||
|         feedbackItem.title = YMLocalizedString(@"XPMineSettingPresent16"); | ||||
|         feedbackItem.subTitle = @""; | ||||
|         feedbackItem.type = XPMineSettingItemType_Feedback; | ||||
|          | ||||
|         XPMineSettingItemModel * clearMemoryItem = [[XPMineSettingItemModel alloc] init]; | ||||
|         clearMemoryItem.title = YMLocalizedString(@"XPMineSettingPresent17"); | ||||
|         clearMemoryItem.subTitle = @""; | ||||
|         clearMemoryItem.type = XPMineSettingItemType_Clear_Memory; | ||||
|          | ||||
|         XPMineSettingItemModel *updateItem = [[XPMineSettingItemModel alloc] init]; | ||||
|         updateItem.title = YMLocalizedString(@"XPMineSettingPresent18"); | ||||
|         updateItem.subTitle = @""; | ||||
|         updateItem.type = XPMineSettingItemType_CheckUpdate; | ||||
|          | ||||
|         XPMineSettingItemModel * aboutusItem = [[XPMineSettingItemModel alloc] init]; | ||||
|         aboutusItem.title = [NSString stringWithFormat:YMLocalizedString(@"XPMineAboutUsViewController0"), AppName]; | ||||
|         aboutusItem.subTitle = @""; | ||||
|         aboutusItem.type = XPMineSettingItemType_About_Us; | ||||
|          | ||||
|         NSArray * oneSection = @[phoneItem]; | ||||
|         NSArray * twoSection = @[loginItem,payItem, notificaItem,shieldItem, blackListItem,languageItem]; | ||||
|         NSArray * threeSection = @[privacyItem]; | ||||
|         NSArray * fourthSection = @[helperItem, clearMemoryItem, updateItem, aboutusItem]; | ||||
|          | ||||
|         self.datasouce = @[oneSection, twoSection, threeSection, fourthSection]; | ||||
|     } | ||||
|      | ||||
|     [[self getView] getMineSettingDatasourceSuccess:self.datasouce]; | ||||
|   | ||||
| @@ -72,7 +72,8 @@ | ||||
|     self.avatarItem.avatarUrl = userInfo.isReview ? userInfo.reviewingAvatar : userInfo.avatar; | ||||
|      | ||||
|     self.nickItem.subTitle = userInfo.nick; | ||||
|     NSString *dateStr = [self.dateFormatter stringFromDate:[NSDate dateWithTimeIntervalSince1970:userInfo.birth/1000]]; | ||||
|     NSDate *date = [NSDate dateWithTimeIntervalSince1970:userInfo.birth/1000]; | ||||
|     NSString *dateStr = [self.dateFormatter stringFromDate:date]; | ||||
|     self.birthItem.subTitle = dateStr; | ||||
|      | ||||
|     self.photoItem.photoArray = userInfo.privatePhoto; | ||||
| @@ -226,7 +227,7 @@ | ||||
|     if (!_dateFormatter) { | ||||
|         _dateFormatter = [[NSDateFormatter alloc] init]; | ||||
|         _dateFormatter.dateFormat = @"yyyy-MM-dd"; | ||||
|      | ||||
|         [_dateFormatter setTimeZone:[NSTimeZone timeZoneWithName:@"Asia/Shanghai"]]; | ||||
|     } | ||||
|     return _dateFormatter; | ||||
| } | ||||
|   | ||||
| @@ -242,10 +242,23 @@ | ||||
| //       if(dateStr.length > 0){ | ||||
| //        _starIconView.image = kImage(dateStr); | ||||
| //       } | ||||
|         _birthdayView.text = [NSDate timestampSwitchTime:_userInfo.birth / 1000 andFormatter:@"yyyy-MM-dd"]; | ||||
|         _birthdayView.text = [self timestampSwitchTime:_userInfo.birth / 1000 andFormatter:@"yyyy-MM-dd"]; | ||||
|     _areaView.text = _userInfo.region; | ||||
| } | ||||
| -(NSString *)timestampSwitchTime:(NSInteger)timestamp andFormatter:(NSString *)format{ | ||||
|  | ||||
|  | ||||
|  | ||||
|  NSDateFormatter *formatter = [[NSDateFormatter alloc] init]; | ||||
|  [formatter setDateStyle:NSDateFormatterMediumStyle]; | ||||
|  [formatter setTimeZone:[NSTimeZone timeZoneWithName:@"Asia/Shanghai"]]; | ||||
|  [formatter setTimeStyle:NSDateFormatterShortStyle]; | ||||
|  | ||||
|  [formatter setDateFormat:format]; // (@"YYYY-MM-dd hh:mm:ss")----------设置你想要的格式,hh与HH的区别:分别表示12小时制,24小时制 | ||||
|  NSDate *confromTimesp = [NSDate dateWithTimeIntervalSince1970:timestamp]; | ||||
|  NSString *confromTimespStr = [formatter stringFromDate:confromTimesp]; | ||||
|  return confromTimespStr; | ||||
| } | ||||
| - (NSString *)calculateConstellationWithMonth:(long)time | ||||
| { | ||||
|     NSString *astroString = YMLocalizedString(@"XPMineHeadView0"); | ||||
|   | ||||
| @@ -1,19 +0,0 @@ | ||||
| // | ||||
| //  YMMineSimpleUserInfoViewController.h | ||||
| //  YUMI | ||||
| // | ||||
| //  Created by XY on 2023/2/21. | ||||
| // | ||||
|  | ||||
| #import "MvpViewController.h" | ||||
|  | ||||
| NS_ASSUME_NONNULL_BEGIN | ||||
|  | ||||
| @interface XPMineSimpleUserInfoViewController : MvpViewController | ||||
|  | ||||
| ///用户的id | ||||
| @property (nonatomic,assign) NSInteger uid; | ||||
|  | ||||
| @end | ||||
|  | ||||
| NS_ASSUME_NONNULL_END | ||||
| @@ -1,406 +0,0 @@ | ||||
| // | ||||
| //  YMMineSimpleUserInfoViewController.m | ||||
| //  YUMI | ||||
| // | ||||
| //  Created by XY on 2023/2/21. | ||||
| // | ||||
|  | ||||
| #import "XPMineSimpleUserInfoViewController.h" | ||||
| #import "YUMIMacroUitls.h" | ||||
| #import <Masonry.h> | ||||
| #import <MJRefresh.h> | ||||
| #import "DJDKMIMOMColor.h" | ||||
| #import "UIImage+Utils.h" | ||||
| #import "AccountInfoStorage.h" | ||||
| #import "TTPopup.h" | ||||
| #import "YUMIHtmlUrl.h" | ||||
| #import "XPSkillCardPlayerManager.h" | ||||
| #import "UIImage+Utils.h" | ||||
| #import "YUMIConstant.h" | ||||
| #import "NIMMessageUtils.h" | ||||
| #import "NSArray+Safe.h" | ||||
| #import "ClientConfig.h" | ||||
| #import "XNDJTDDLoadingTool.h" | ||||
|  | ||||
| #import "MonentsListInfoModel.h" | ||||
| #import "MineSkillCardListInfoModel.h" | ||||
| #import "UserInfoModel.h" | ||||
|  | ||||
| ///P | ||||
| #import "XPMineUserInfoPresenter.h" | ||||
| #import "XPMineUserInfoProtocol.h" | ||||
| #import "RoomHostDelegate.h" | ||||
| ///View | ||||
| #import "XPMomentListCollectionViewCell.h" | ||||
| #import "XPMineUserInfoCustomNavView.h" | ||||
| #import "XPMineSimpleUserInfoHeaderView.h" | ||||
| ///VC | ||||
| #import "XPMineUserInfoEditViewController.h" | ||||
| #import "XPWebViewController.h" | ||||
| #import "SessionViewController.h" | ||||
| #import "XPRoomViewController.h" | ||||
| #import "XPMineUserDataViewController.h" | ||||
| #import "XPMonentsMineViewController.h" | ||||
| #import "XPMonentsDetailViewController.h" | ||||
| #import "XPMomentsSimpleDetailViewController.h" | ||||
| #import "XPMineUserInfoGiftWallViewController.h" | ||||
|  | ||||
| #define kHeaderViewHeight 615 | ||||
|  | ||||
| @interface XPMineSimpleUserInfoViewController ()<UICollectionViewDelegate, UICollectionViewDataSource, XPMineCustomNavViewDelegate, XPMineUserInfoProtocol, XPMineSimpleUserInfoHeaderViewDelegate> | ||||
|  | ||||
| @property (nonatomic, strong) UICollectionView *collectionView; | ||||
| ///头部视图 | ||||
| @property (nonatomic, strong) XPMineSimpleUserInfoHeaderView *headerView; | ||||
| ///自定义的导航栏 | ||||
| @property (nonatomic,strong) XPMineUserInfoCustomNavView *navView; | ||||
| ///用户信息 | ||||
| @property (nonatomic,strong) UserInfoModel *userInfo; | ||||
| ///底部的容器 | ||||
| @property (nonatomic,strong) UIStackView *bottomStackView; | ||||
| ///私聊 | ||||
| @property (nonatomic,strong) UIButton *chatButton; | ||||
| ///关注 | ||||
| @property (nonatomic,strong) UIButton *attentionButton; | ||||
|  | ||||
| @end | ||||
|  | ||||
| @implementation XPMineSimpleUserInfoViewController | ||||
|  | ||||
| - (XPMineUserInfoPresenter *)createPresenter { | ||||
|     return [[XPMineUserInfoPresenter alloc] init]; | ||||
| } | ||||
|  | ||||
| - (BOOL)isHiddenNavBar { | ||||
|     return YES; | ||||
| } | ||||
|  | ||||
| - (void)viewDidLoad { | ||||
|     [super viewDidLoad]; | ||||
|     [self createUI]; | ||||
| } | ||||
|  | ||||
| - (void)viewWillAppear:(BOOL)animated { | ||||
|     [super viewWillAppear:animated]; | ||||
|     if (self.uid > 0) { | ||||
|         [self initHttpRequest]; | ||||
|     } | ||||
| } | ||||
|  | ||||
| - (void)viewWillDisappear:(BOOL)animated { | ||||
|     [super viewWillDisappear:animated]; | ||||
|      | ||||
| } | ||||
|  | ||||
| - (void)createUI { | ||||
|     [self.view addSubview:self.collectionView]; | ||||
|     [self.collectionView addSubview:self.headerView]; | ||||
|     [self.collectionView mas_makeConstraints:^(MASConstraintMaker *make) { | ||||
|         make.top.mas_equalTo(0); | ||||
|         make.leading.trailing.mas_equalTo(0); | ||||
|         make.bottom.mas_equalTo(0); | ||||
|     }]; | ||||
|      | ||||
|     [self.view addSubview:self.navView]; | ||||
|     [self.navView mas_makeConstraints:^(MASConstraintMaker *make) { | ||||
|         make.leading.trailing.top.mas_equalTo(self.view); | ||||
|         make.height.mas_equalTo(kNavigationHeight); | ||||
|     }]; | ||||
|      | ||||
|     if (self.uid != [AccountInfoStorage instance].getUid.integerValue) { | ||||
|         [self.view addSubview:self.chatButton]; | ||||
|         [self.chatButton mas_makeConstraints:^(MASConstraintMaker *make) { | ||||
| 			make.centerX.mas_equalTo(self.view); | ||||
|             make.height.mas_equalTo(36); | ||||
| 			make.width.mas_equalTo(100); | ||||
|             make.bottom.mas_equalTo(self.view).offset(-kSafeAreaBottomHeight - 15); | ||||
|         }]; | ||||
|     } | ||||
| } | ||||
|  | ||||
| - (void)initHttpRequest { | ||||
|     NSString *uid = [NSString stringWithFormat:@"%ld", self.uid]; | ||||
|     ///请求目标用户的个人信息 | ||||
| //    [self.presenter getUserInfoWithUid:uid]; | ||||
|     [self.presenter getUserAttentionState:uid]; | ||||
|  | ||||
|     //获取用户详细信息 跟随进房目前使用的这个接口 | ||||
|     [self.presenter getUserDetailInfoWithUid:uid]; | ||||
|  | ||||
|     NSString * myUid = [AccountInfoStorage instance].getUid; | ||||
|     ///上传访问记录 | ||||
|     if (![uid isEqualToString:myUid]) { | ||||
|         ///请求我自己的个人信息 | ||||
| //        [self.presenter getUserInfoWithUid:myUid]; | ||||
|     } | ||||
| } | ||||
|  | ||||
| #pragma mark - 拉黑 移除黑名单 | ||||
| - (void)showRightNavHandle { | ||||
|     NSMutableArray<TTActionSheetConfig *> *array = [NSMutableArray array]; | ||||
|     NSString *uid = [NSString stringWithFormat:@"%ld",self.uid]; | ||||
|     TTActionSheetConfig *report = [TTActionSheetConfig normalTitle:YMLocalizedString(@"XPMineSimpleUserInfoViewController0") clickAction:^{ | ||||
| 		if ([ClientConfig shareConfig].canOpen) { | ||||
| 			XPWebViewController *vc = [[XPWebViewController alloc]init]; | ||||
| 			NSString *urlstr = [NSString stringWithFormat:@"%@?reportUid=%@&source=PERSONAL",URLWithType(kReportRoomURL),uid]; | ||||
| 			vc.url = urlstr; | ||||
| 			[self.navigationController pushViewController:vc animated:YES]; | ||||
| 		} else { | ||||
| 			[XNDJTDDLoadingTool showErrorWithMessage:YMLocalizedString(@"XPMineSimpleUserInfoViewController1")]; | ||||
| 		} | ||||
|     }]; | ||||
|  | ||||
|     TTActionSheetConfig *black = [TTActionSheetConfig normalTitle:YMLocalizedString(@"XPMineSimpleUserInfoViewController2") clickAction:^{ | ||||
|         [self addOrRemoveBlack:NO uid:uid]; | ||||
|     }]; | ||||
|  | ||||
|     [array addObjectsFromArray:@[report, black]]; | ||||
|  | ||||
|     BOOL isInBlackList = [[NIMSDK sharedSDK].userManager isUserInBlackList:uid] || [NIMMessageUtils isOfficalAccount:[NSString stringWithFormat:@"%ld", self.uid]]; | ||||
|     if (isInBlackList) { | ||||
|         [array removeObject:black]; | ||||
|     } | ||||
|     [TTPopup actionSheetWithItems:array]; | ||||
| } | ||||
|  | ||||
|  | ||||
| //加入黑名单 | ||||
| - (void)addOrRemoveBlack:(BOOL)isRemove uid:(NSString *)uid { | ||||
|     NSString *title; | ||||
|     NSString *message; | ||||
|     if (isRemove) { | ||||
|         title = YMLocalizedString(@"XPMineSimpleUserInfoViewController3"); | ||||
|         message = YMLocalizedString(@"XPMineSimpleUserInfoViewController4"); | ||||
|     }else{ | ||||
|         title = YMLocalizedString(@"XPMineSimpleUserInfoViewController5"); | ||||
|         message = YMLocalizedString(@"XPMineSimpleUserInfoViewController6"); | ||||
|     } | ||||
|  | ||||
|     TTAlertConfig *config = [[TTAlertConfig alloc] init]; | ||||
|     config.title = title; | ||||
|     config.message = message; | ||||
|  | ||||
|     [TTPopup alertWithConfig:config confirmHandler:^{ | ||||
|         if (isRemove) { | ||||
|             [[NIMSDK sharedSDK].userManager removeFromBlackBlackList:uid completion:^(NSError * _Nullable error) { | ||||
|                 if (error == nil) { | ||||
|                     [self  showSuccessToast:YMLocalizedString(@"XPMineSimpleUserInfoViewController7")]; | ||||
|                 } | ||||
|             }]; | ||||
|         } else { | ||||
|             [[NIMSDK sharedSDK].userManager addToBlackList:uid completion:^(NSError * _Nullable error) { | ||||
|                 if (error == nil) { | ||||
|                     [self  showSuccessToast:YMLocalizedString(@"XPMineSimpleUserInfoViewController8")]; | ||||
|                 } | ||||
|             }]; | ||||
|         } | ||||
|     } cancelHandler:^{ | ||||
|     }]; | ||||
| } | ||||
|  | ||||
| #pragma mark - XPMineCustomNavViewDelegate | ||||
| - (void)xPMineCustomNavView:(XPMineUserInfoCustomNavView *)view didClickEditButton:(UIButton *)sender { | ||||
|     if (sender.isSelected) {///自己看自己的  去修改资料 | ||||
|         XPMineUserInfoEditViewController * editVC = [[XPMineUserInfoEditViewController alloc] init]; | ||||
|         [self.navigationController pushViewController:editVC animated:YES]; | ||||
|     } else { | ||||
|         [self showRightNavHandle]; | ||||
|     } | ||||
| } | ||||
|  | ||||
| - (void)xPMineCustomNavView:(XPMineUserInfoCustomNavView *)view didClickBackButton:(UIButton *)sender { | ||||
|     [self.navigationController popViewControllerAnimated:YES]; | ||||
| } | ||||
|  | ||||
| #pragma mark - XPMineSimpleUserInfoHeaderViewDelegate | ||||
| /// 更多了礼物 | ||||
| - (void)headerViewMoreGiftAction { | ||||
|     if (self.uid > 0) { | ||||
|         XPMineUserInfoGiftWallViewController * giftWallVC = [[XPMineUserInfoGiftWallViewController alloc] init]; | ||||
|         giftWallVC.userUid = [NSString stringWithFormat:@"%ld", self.uid]; | ||||
|         [self.navigationController pushViewController:giftWallVC animated:YES]; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /// 点击了直播中 | ||||
| - (void)headerViewOnlineAction:(NSString *)roomUid { | ||||
|     if (roomUid.length > 0 ) { | ||||
|         //退出原来的房间 如果有的话 TODO 总感觉这种处理不太优雅 进房入口多了 怎么办 进房需要整合 | ||||
|         [self.navigationController.viewControllers enumerateObjectsUsingBlock:^(__kindof UIViewController * _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) { | ||||
|             if ([obj isKindOfClass:[XPRoomViewController class]]) { | ||||
|                 [self.navigationController popToRootViewControllerAnimated:NO]; | ||||
|                 XPRoomViewController<RoomHostDelegate> * rooomVC = obj; | ||||
|                 [rooomVC exitRoom]; | ||||
|                 *stop = YES; | ||||
|             } | ||||
|         }]; | ||||
|         [XPRoomViewController openRoom:roomUid viewController:self]; | ||||
|     } | ||||
| } | ||||
|  | ||||
| #pragma mark - XPMineUserInfoProtocol | ||||
| - (void)onGetUserInfoSuccess:(UserInfoModel *)userInfo { | ||||
|     if (userInfo.uid == self.uid) { | ||||
|         self.userInfo = userInfo; | ||||
| //        self.headView.userInfo = userInfo; | ||||
|     } else { | ||||
|         if (!userInfo.userVipInfoVO.lookHomepageHide) { | ||||
|             NSString * uid = [NSString stringWithFormat:@"%ld", self.uid]; | ||||
|             [self.presenter visitUser:uid]; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| - (void)ongetDetailInfoSuccess:(UserInfoModel *)userInfo { | ||||
|     self.userInfo = userInfo; | ||||
|     self.headerView.userInfo = userInfo; | ||||
|     self.headerView.roomUid = userInfo.roomUid; | ||||
|     [self.collectionView reloadData]; | ||||
| //    self.userDataVC.userInfo = userInfo; | ||||
| //    self.monentsVC.dynamicInfo = userInfo.dynamicInfo; | ||||
|      | ||||
| } | ||||
|  | ||||
| - (void)getAttentionStateSuccess:(BOOL)status { | ||||
|     self.attentionButton.selected = status; | ||||
| } | ||||
|  | ||||
| - (void)attentionUserSuccess:(BOOL)status { | ||||
|     self.attentionButton.selected = status; | ||||
| } | ||||
|  | ||||
|  | ||||
| #pragma mark - Event Response | ||||
| - (void)chatButtonAction:(UIButton *)sender { | ||||
|     NSString * sessionId = [NSString stringWithFormat:@"%ld",self.uid]; | ||||
|     NIMSession * session = [NIMSession session:sessionId type:NIMSessionTypeP2P]; | ||||
|     SessionViewController * sessionVC = [[SessionViewController alloc] initWithSession:session]; | ||||
|     [self.navigationController pushViewController:sessionVC animated:YES]; | ||||
| } | ||||
|  | ||||
| - (void)attentionButtonAction:(UIButton *)sender { | ||||
|     NSString *uid = [NSString stringWithFormat:@"%ld", self.uid]; | ||||
|     [self.presenter attentionUser:uid state:!sender.selected]; | ||||
| } | ||||
|  | ||||
|  | ||||
| #pragma mark - UICollectionView | ||||
|  | ||||
| - (NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section { | ||||
|     return self.userInfo.dynamicInfo.count; | ||||
| } | ||||
|  | ||||
| - (__kindof UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath { | ||||
|     XPMomentListCollectionViewCell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:NSStringFromClass(XPMomentListCollectionViewCell.self) forIndexPath:indexPath]; | ||||
|     MonentsInfoModel * monentsInfo = [self.userInfo.dynamicInfo safeObjectAtIndex1:indexPath.row]; | ||||
|     cell.monentsInfo = monentsInfo; | ||||
|     return cell; | ||||
| } | ||||
|  | ||||
| - (void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath { | ||||
|     if (self.userInfo.dynamicInfo.count > 0) { | ||||
|          | ||||
|         if ([ClientConfig shareConfig].canOpen) { | ||||
|             XPMonentsDetailViewController * detailVC = [[XPMonentsDetailViewController alloc] init]; | ||||
|             MonentsInfoModel * monentsInfo = [self.userInfo.dynamicInfo safeObjectAtIndex1:indexPath.row]; | ||||
|             detailVC.monentsInfo = monentsInfo; | ||||
|             [self.navigationController pushViewController:detailVC animated:YES]; | ||||
|         }else{ | ||||
|             XPMomentsSimpleDetailViewController * detailVC = [[XPMomentsSimpleDetailViewController alloc] init]; | ||||
|             MonentsInfoModel * monentsInfo = [self.userInfo.dynamicInfo safeObjectAtIndex1:indexPath.row]; | ||||
|             detailVC.monentsInfo = monentsInfo; | ||||
|             [self.navigationController pushViewController:detailVC animated:YES]; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| #pragma mark - 懒加载 | ||||
|  | ||||
| - (UICollectionView *)collectionView { | ||||
|     if (!_collectionView) { | ||||
|         MSBaseRTLFlowLayout *layout = [[MSBaseRTLFlowLayout alloc] init]; | ||||
|         layout.scrollDirection = UICollectionViewScrollDirectionVertical; | ||||
|         CGFloat width = (KScreenWidth - 16 -13 -16)/2.0; | ||||
|         CGFloat height = 220.0/165.0*width; | ||||
|         layout.itemSize = CGSizeMake(width, height); | ||||
|         layout.minimumLineSpacing = 12.0; | ||||
|         layout.minimumInteritemSpacing = 13.0; | ||||
|         layout.sectionInset = UIEdgeInsetsMake(12, 16, 12, 16); | ||||
|          | ||||
|         _collectionView = [[UICollectionView alloc] initWithFrame:CGRectZero collectionViewLayout:layout]; | ||||
|         _collectionView.backgroundColor = UIColor.whiteColor; | ||||
|         _collectionView.alwaysBounceVertical = YES; | ||||
|         [_collectionView registerClass:[XPMomentListCollectionViewCell class] forCellWithReuseIdentifier:NSStringFromClass(XPMomentListCollectionViewCell.self)]; | ||||
|         _collectionView.delegate = self; | ||||
|         _collectionView.dataSource = self; | ||||
|         _collectionView.contentInsetAdjustmentBehavior = UIScrollViewContentInsetAdjustmentNever; | ||||
|          | ||||
|         _collectionView.contentInset = UIEdgeInsetsMake(kHeaderViewHeight, 0, 0, 0); | ||||
|          | ||||
|     } | ||||
|     return _collectionView; | ||||
| } | ||||
|  | ||||
| - (XPMineSimpleUserInfoHeaderView *)headerView { | ||||
|     if (!_headerView) { | ||||
|         _headerView = [[XPMineSimpleUserInfoHeaderView alloc] init]; | ||||
|         _headerView.frame = CGRectMake(0, -kHeaderViewHeight, KScreenWidth, kHeaderViewHeight); | ||||
|         _headerView.delegate = self; | ||||
|     } | ||||
|     return _headerView; | ||||
| } | ||||
|  | ||||
| - (XPMineUserInfoCustomNavView *)navView { | ||||
|     if (!_navView) { | ||||
|         _navView = [[XPMineUserInfoCustomNavView alloc] init]; | ||||
|         _navView.delegate = self; | ||||
|     } | ||||
|     return _navView; | ||||
| } | ||||
|  | ||||
| - (UIStackView *)bottomStackView { | ||||
|     if (!_bottomStackView) { | ||||
|         _bottomStackView = [[UIStackView alloc] init]; | ||||
|         _bottomStackView.axis = UILayoutConstraintAxisHorizontal; | ||||
|         _bottomStackView.distribution = UIStackViewDistributionFillEqually; | ||||
|         _bottomStackView.alignment = UIStackViewAlignmentFill; | ||||
|         _bottomStackView.spacing = 25; | ||||
|     } | ||||
|     return _bottomStackView; | ||||
| } | ||||
|  | ||||
| - (UIButton *)chatButton { | ||||
|     if (!_chatButton) { | ||||
|         _chatButton = [UIButton buttonWithType:UIButtonTypeCustom]; | ||||
|         [_chatButton setTitle:YMLocalizedString(@"XPMineSimpleUserInfoViewController9") forState:UIControlStateNormal]; | ||||
|         [_chatButton setTitleColor:[DJDKMIMOMColor confirmButtonTextColor] forState:UIControlStateNormal]; | ||||
|         _chatButton.titleLabel.font = [UIFont systemFontOfSize:15]; | ||||
| 		[_chatButton setBackgroundColor:[DJDKMIMOMColor appMainColor]]; | ||||
|         _chatButton.layer.masksToBounds = YES; | ||||
|         _chatButton.layer.cornerRadius =  36/2; | ||||
|         [_chatButton addTarget:self action:@selector(chatButtonAction:) forControlEvents:UIControlEventTouchUpInside]; | ||||
|     } | ||||
|     return _chatButton; | ||||
| } | ||||
|  | ||||
| - (UIButton *)attentionButton { | ||||
|     if (!_attentionButton) { | ||||
|         _attentionButton = [UIButton buttonWithType:UIButtonTypeCustom]; | ||||
|         [_attentionButton setTitle:YMLocalizedString(@"XPMineSimpleUserInfoViewController10") forState:UIControlStateNormal]; | ||||
|         [_attentionButton setTitle:YMLocalizedString(@"XPMineSimpleUserInfoViewController11") forState:UIControlStateSelected]; | ||||
|         [_attentionButton setTitleColor:[DJDKMIMOMColor confirmButtonTextColor] forState:UIControlStateNormal]; | ||||
|         [_attentionButton setTitleColor:[DJDKMIMOMColor cancelButtonTextColor] forState:UIControlStateSelected]; | ||||
|         [_attentionButton setImage:[UIImage imageNamed:@"mine_user_info_bottom_attention_normal"] forState:UIControlStateNormal]; | ||||
|         [_attentionButton setImage:[UIImage imageNamed:@"mine_user_info_bottom_attention_select"] forState:UIControlStateSelected]; | ||||
|         _attentionButton.titleLabel.font = [UIFont systemFontOfSize:15]; | ||||
|         [_attentionButton setBackgroundImage:[UIImage gradientColorImageFromColors:@[[DJDKMIMOMColor confirmButtonGradientStartColor], [DJDKMIMOMColor confirmButtonGradientEndColor]] gradientType:GradientTypeLeftToRight imgSize:CGSizeMake(10, 10)] forState:UIControlStateNormal]; | ||||
|         [_attentionButton setBackgroundImage:[UIImage gradientColorImageFromColors:@[[DJDKMIMOMColor cancelButtonGradientStartColor], [DJDKMIMOMColor cancelButtonGradientEndColor]] gradientType:GradientTypeLeftToRight imgSize:CGSizeMake(10, 10)] forState:UIControlStateSelected]; | ||||
|         _attentionButton.layer.masksToBounds = YES; | ||||
|         _attentionButton.layer.cornerRadius =  36/2; | ||||
| 		_attentionButton.hidden = YES; | ||||
|         [_attentionButton addTarget:self action:@selector(attentionButtonAction:) forControlEvents:UIControlEventTouchUpInside]; | ||||
|     } | ||||
|     return _attentionButton; | ||||
| } | ||||
|  | ||||
| @end | ||||
| @@ -86,7 +86,7 @@ | ||||
| @property (nonatomic, assign) NSInteger roomUid; | ||||
| @property (nonatomic,strong)  WalletInfoModel * infoModel; | ||||
| @property(nonatomic,strong) UIButton *rankBtn; | ||||
| @property(nonatomic,assign) BOOL pi_IsNative; | ||||
|  | ||||
| @end | ||||
|  | ||||
| @implementation XPNobleCenterViewController | ||||
| @@ -105,7 +105,7 @@ | ||||
|  | ||||
| - (void)viewDidLoad { | ||||
|     [super viewDidLoad]; | ||||
|     self.pi_IsNative = YES; | ||||
|    | ||||
|     [[NIMSDK sharedSDK].systemNotificationManager addDelegate:self]; | ||||
|     [self requestHttp]; | ||||
|     [self initSubViews]; | ||||
| @@ -209,16 +209,7 @@ | ||||
|         return; | ||||
|     } | ||||
|      | ||||
|     if(self.pi_IsNative == NO){ | ||||
|         XPWebViewController *vc = [[XPWebViewController alloc]init]; | ||||
|         NSString *channel = @"p"; | ||||
|         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; | ||||
|     } | ||||
|    | ||||
|      | ||||
|      | ||||
|     [XNDJTDDLoadingTool showOnlyView:kWindow]; | ||||
| @@ -266,26 +257,15 @@ | ||||
|     [self.presenter getNobleChargeProductListWithChannelType:@"9"]; | ||||
|     [self getWalletInfo]; | ||||
|      | ||||
|      | ||||
|     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)getWalletInfo{ | ||||
|     NSString * uid = [AccountInfoStorage instance].getUid; | ||||
|     NSString * ticket = [AccountInfoStorage instance].getTicket; | ||||
|     @kWeakify(self); | ||||
|     [Api getUserWalletInfo:^(BaseModel * _Nullable data, NSInteger code, NSString * _Nullable msg) { | ||||
|         @kStrongify(self); | ||||
|         if(code == 200){ | ||||
|             WalletInfoModel * model = [WalletInfoModel modelWithDictionary:data.data]; | ||||
|             self.infoModel = model; | ||||
|   | ||||
| @@ -90,80 +90,12 @@ | ||||
|  | ||||
| - (void)viewDidLoad { | ||||
|     [super viewDidLoad]; | ||||
|      | ||||
| #ifdef DEBUG | ||||
|          | ||||
|          | ||||
|     if([ClientConfig shareConfig].canOpen){ | ||||
|         [self showLoading]; | ||||
|         [Api requestMineChannel:^(BaseModel * _Nullable data, NSInteger code, NSString * _Nullable msg) { | ||||
|             [self hideHUD]; | ||||
|             if(code == 200){ | ||||
|                 if(data.data[@"isNative"] != nil){ | ||||
|                     BOOL is = [data.data[@"isNative"] boolValue]; | ||||
|                     [self initWebView:is]; | ||||
|                 } | ||||
|                 return; | ||||
|             } | ||||
|             [self initWebView:YES]; | ||||
|         }]; | ||||
|         return; | ||||
|     } | ||||
|     [self initWebView:YES]; | ||||
|         | ||||
|          | ||||
|          | ||||
|          | ||||
| #else | ||||
|         if(isEnterprise == YES){ | ||||
|             if([ClientConfig shareConfig].canOpen){ | ||||
|                 [self showLoading]; | ||||
|                 [Api requestMineChannel:^(BaseModel * _Nullable data, NSInteger code, NSString * _Nullable msg) { | ||||
|                     [self hideHUD]; | ||||
|                     if(code == 200){ | ||||
|                         if(data.data[@"isNative"] != nil){ | ||||
|                             BOOL is = [data.data[@"isNative"] boolValue]; | ||||
|                             [self initWebView:is]; | ||||
|                         } | ||||
|                         return; | ||||
|                     } | ||||
|                     [self initWebView:YES]; | ||||
|                 }]; | ||||
|                 return; | ||||
|             } | ||||
|             [self initWebView:YES]; | ||||
|              | ||||
|         }else{ | ||||
|             [self initWebView:NO]; | ||||
|         } | ||||
| #endif | ||||
|      | ||||
|      | ||||
|     | ||||
| } | ||||
| -(void)initWebView:(BOOL)is{ | ||||
|     if(is == YES){ | ||||
|         [self createUI]; | ||||
|         [self initHttpData]; | ||||
|         return; | ||||
|     } | ||||
|      | ||||
|     XPWebViewController *vc = [[XPWebViewController alloc]init]; | ||||
|     NSString *channel = @"p"; | ||||
|     channel = [NSString stringWithFormat:@"%@a",channel]; | ||||
|     channel = [NSString stringWithFormat:@"%@y",channel]; | ||||
|     NSString *url =  [NSString stringWithFormat:URLWithType(kChannelUrl),channel,self.type,[YYUtility deviceID]]; | ||||
|     vc.url = url; | ||||
|     [self addChildViewController:vc]; | ||||
|     vc.view.frame = self.view.frame; | ||||
|     [self.view addSubview:vc.view]; | ||||
|     [self createUI]; | ||||
|     [self initHttpData]; | ||||
| } | ||||
| - (void)createUI { | ||||
|     self.view.backgroundColor = [UIColor whiteColor]; | ||||
|      | ||||
|      | ||||
|      | ||||
|      | ||||
|     [self.view addSubview:self.headerView]; | ||||
|     [self.view addSubview:self.collectionView]; | ||||
|     [self.view addSubview:self.rechargeBtn]; | ||||
| @@ -179,7 +111,6 @@ | ||||
|         make.height.mas_equalTo(height); | ||||
|     }]; | ||||
|      | ||||
|      | ||||
|     [self.stackView mas_makeConstraints:^(MASConstraintMaker *make) { | ||||
|         make.centerX.mas_equalTo(self.view); | ||||
|         make.bottom.mas_equalTo(-34); | ||||
| @@ -193,17 +124,11 @@ | ||||
|         make.bottom.equalTo(self.stackView.mas_top).mas_offset(-kGetScaleWidth(10)); | ||||
|     }]; | ||||
|     | ||||
|      | ||||
|      | ||||
|     [self.collectionView mas_makeConstraints:^(MASConstraintMaker *make) { | ||||
|         make.top.mas_equalTo(self.headerView.mas_bottom).mas_offset(-kGetScaleWidth(22)); | ||||
|         make.leading.trailing.mas_equalTo(0); | ||||
|         make.bottom.equalTo(self.rechargeBtn.mas_top).mas_offset(-kGetScaleWidth(10)); | ||||
|     }]; | ||||
|  | ||||
|      | ||||
|  | ||||
|  | ||||
| 	 | ||||
|     [self.titleLabel mas_makeConstraints:^(MASConstraintMaker *make) { | ||||
|         make.top.mas_equalTo(kStatusBarHeight); | ||||
| @@ -219,9 +144,7 @@ | ||||
|  | ||||
| - (void)initHttpData { | ||||
|     [self getRechargeList]; | ||||
|     if([ClientConfig shareConfig].canOpen){ | ||||
|         [self.presenter getBannerList]; | ||||
|     } | ||||
|     [self.presenter getBannerList]; | ||||
|     [self getUserWalletBalanceInfo]; | ||||
|     [self checkTranscationIds]; | ||||
| } | ||||
|   | ||||
| @@ -238,12 +238,7 @@ | ||||
|         } | ||||
|             break; | ||||
|         case XPMineSettingItemType_Delete_Account: { | ||||
|  | ||||
| 			if ([ClientConfig shareConfig].canOpen) { | ||||
| 			    [self pushWebViewWIthUrl:URLWithType(kAccountlogoutURL)]; | ||||
| 			} else { | ||||
| 			    [self pushWebViewWIthUrl:@"molistar/modules/logOff/index.html"]; | ||||
| 			} | ||||
|             [self pushWebViewWIthUrl:URLWithType(kAccountlogoutURL)]; | ||||
|         } | ||||
|             break; | ||||
|         case XPMineSettingItemType_Shield_management: | ||||
| @@ -428,15 +423,9 @@ | ||||
| 		_logoutButton.layer.cornerRadius = 50/2; | ||||
| 		_logoutButton.titleLabel.font = [UIFont systemFontOfSize:16]; | ||||
|         [_logoutButton addTarget:self action:@selector(logoutButtonAction:) forControlEvents:UIControlEventTouchUpInside]; | ||||
|         if ([ClientConfig shareConfig].canOpen) { | ||||
|             [_logoutButton setTitle:YMLocalizedString(@"XPMineSettingViewController7") forState:UIControlStateNormal]; | ||||
|             _logoutButton.backgroundColor = [DJDKMIMOMColor appCellBackgroundColor]; | ||||
|             [_logoutButton setTitleColor:[DJDKMIMOMColor mainTextColor] forState:UIControlStateNormal]; | ||||
|         }else{ | ||||
|             [_logoutButton setTitle:YMLocalizedString(@"XPMineSettingViewController8") forState:UIControlStateNormal]; | ||||
|             _logoutButton.backgroundColor = UIColorFromRGB(0xCED3D8); | ||||
|             [_logoutButton setTitleColor:UIColor.whiteColor forState:UIControlStateNormal]; | ||||
|         } | ||||
|         [_logoutButton setTitle:YMLocalizedString(@"XPMineSettingViewController7") forState:UIControlStateNormal]; | ||||
|         _logoutButton.backgroundColor = [DJDKMIMOMColor appCellBackgroundColor]; | ||||
|         [_logoutButton setTitleColor:[DJDKMIMOMColor mainTextColor] forState:UIControlStateNormal]; | ||||
| 	} | ||||
| 	return _logoutButton; | ||||
| } | ||||
|   | ||||
| @@ -322,6 +322,7 @@ | ||||
| 	if (!_dateFormatter) { | ||||
| 		_dateFormatter = [[NSDateFormatter alloc] init]; | ||||
| 		_dateFormatter.dateFormat = @"yyyy-MM-dd"; | ||||
|         [_dateFormatter setTimeZone:[NSTimeZone timeZoneWithName:@"Asia/Shanghai"]]; | ||||
| 	} | ||||
| 	return _dateFormatter; | ||||
| } | ||||
|   | ||||
| @@ -610,14 +610,14 @@ | ||||
|         } | ||||
|         self.charmImageView.hidden = userInfo.userLevelVo.charmUrl.length <= 0; | ||||
|         if(userInfo.isCustomWord == YES){ | ||||
|             if (userInfo.nameplateWord.length>0) { | ||||
|             if (userInfo.nameplatePic.length > 0) { | ||||
|                 self.nameplateImageView.imageUrl = userInfo.nameplatePic; | ||||
|                 self.namePlateView.hidden = NO; | ||||
|             } else { | ||||
|                 self.namePlateView.hidden = YES; | ||||
|             } | ||||
|         }else{ | ||||
|             if (userInfo.nameplateWord.length>0 && userInfo.nameplatePic.length>0) { | ||||
|             if (userInfo.nameplateWord.length > 0 && userInfo.nameplatePic.length > 0) { | ||||
|                 self.nameplateImageView.imageUrl = userInfo.nameplatePic; | ||||
|                 self.nameplateLabel.text = userInfo.nameplateWord; | ||||
|                 self.namePlateView.hidden = NO; | ||||
|   | ||||
| @@ -22,7 +22,7 @@ | ||||
| #import "XPMineAnchorFansTeamProtocol.h" | ||||
| ///VC | ||||
| #import "XPMineUserInfoViewController.h" | ||||
| #import "XPMineSimpleUserInfoViewController.h" | ||||
|  | ||||
| #import "SessionViewController.h" | ||||
|  | ||||
| @interface XPMineFansTeamViewController ()<UITableViewDelegate,UITableViewDataSource, XPMineAnchorFansTeamProtocol> | ||||
| @@ -96,16 +96,9 @@ | ||||
|  | ||||
| - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath { | ||||
|     XPMineAnchorFansTeamModel *item = [self.datasource safeObjectAtIndex1:indexPath.row]; | ||||
|      | ||||
|     if ([ClientConfig shareConfig].canOpen) { | ||||
|         XPMineUserInfoViewController * userInfoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|         userInfoVC.uid = item.teamUid; | ||||
|         [self.navigationController pushViewController:userInfoVC animated:YES]; | ||||
|     }else{ | ||||
|         XPMineSimpleUserInfoViewController * userInfoVC = [[XPMineSimpleUserInfoViewController alloc] init]; | ||||
|         userInfoVC.uid = item.teamUid; | ||||
|         [self.navigationController pushViewController:userInfoVC animated:YES]; | ||||
|     } | ||||
|     XPMineUserInfoViewController * userInfoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|     userInfoVC.uid = item.teamUid; | ||||
|     [self.navigationController pushViewController:userInfoVC animated:YES]; | ||||
| } | ||||
|  | ||||
| - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath { | ||||
|   | ||||
| @@ -23,7 +23,7 @@ | ||||
| #import "XPMineVisitorProtocol.h" | ||||
| ///VC | ||||
| #import "XPMineUserInfoViewController.h" | ||||
| #import "XPMineSimpleUserInfoViewController.h" | ||||
|  | ||||
| #import "SessionViewController.h" | ||||
|  | ||||
| @interface XPMineVisitorViewController ()<UITableViewDelegate,UITableViewDataSource, XPMineVisitorProtocol, XPMineVisitorTableViewCellDelegate> | ||||
| @@ -157,16 +157,9 @@ | ||||
| - (void)onAvatarClick:(XPMineVisitorTableViewCell *)cell { | ||||
|     NSIndexPath *indexPath = [self.tableView indexPathForCell:cell]; | ||||
|     XPMineVisitorItemModel *item = [self.datasource safeObjectAtIndex1:indexPath.row]; | ||||
|      | ||||
|     if ([ClientConfig shareConfig].canOpen) { | ||||
|         XPMineUserInfoViewController * userInfoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|         userInfoVC.uid = item.uid; | ||||
|         [self.navigationController pushViewController:userInfoVC animated:YES]; | ||||
|     }else{ | ||||
|         XPMineSimpleUserInfoViewController * userInfoVC = [[XPMineSimpleUserInfoViewController alloc] init]; | ||||
|         userInfoVC.uid = item.uid; | ||||
|         [self.navigationController pushViewController:userInfoVC animated:YES]; | ||||
|     } | ||||
|     XPMineUserInfoViewController * userInfoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|     userInfoVC.uid = item.uid; | ||||
|     [self.navigationController pushViewController:userInfoVC animated:YES]; | ||||
| } | ||||
|  | ||||
| - (void)onChatClick:(XPMineVisitorTableViewCell *)cell { | ||||
|   | ||||
| @@ -1,16 +0,0 @@ | ||||
| // | ||||
| //  YMSimpleMineViewController.h | ||||
| //  YUMI | ||||
| // | ||||
| //  Created by XY on 2023/2/20. | ||||
| // | ||||
|  | ||||
| #import "MvpViewController.h" | ||||
|  | ||||
| NS_ASSUME_NONNULL_BEGIN | ||||
|  | ||||
| @interface XPSimpleMineViewController : MvpViewController | ||||
|  | ||||
| @end | ||||
|  | ||||
| NS_ASSUME_NONNULL_END | ||||
| @@ -1,498 +0,0 @@ | ||||
| // | ||||
| //  YMSimpleMineViewController.m | ||||
| //  YUMI | ||||
| // | ||||
| //  Created by XY on 2023/2/20. | ||||
| // | ||||
|  | ||||
| #import "XPSimpleMineViewController.h" | ||||
| ///Third | ||||
| #import <Masonry/Masonry.h> | ||||
| ///Tool | ||||
| #import "TTPopup.h" | ||||
| #import "YUMIMacroUitls.h" | ||||
| #import "YUMIHtmlUrl.h" | ||||
| #import "UIButton+EnlargeTouchArea.h" | ||||
| #import "StatisticsServiceHelper.h" | ||||
| #import "YUMIConstant.h" | ||||
| #import "Api+Room.h" | ||||
| #import "Api+RoomSetting.h" | ||||
| #import "AccountInfoStorage.h" | ||||
| #import "ClientConfig.h" | ||||
| #import "NSMutableDictionary+Saft.h" | ||||
| #import "DJDKMIMOMColor.h" | ||||
| #import "ClientConfig.h" | ||||
| ///Model | ||||
| #import "XPMineItemModel.h" | ||||
| #import "UserInfoModel.h" | ||||
| #import "XPMineVisitorUnReadModel.h" | ||||
| #import "ClanDetailInfoModel.h" | ||||
| #import "HomeBannerInfoModel.h" | ||||
| #import "XPMineFuntionItemModel.h" | ||||
| #import "WalletInfoModel.h" | ||||
| ///P | ||||
| #import "XPMineProtocol.h" | ||||
| #import "XPMinePresent.h" | ||||
| ///View | ||||
| #import "XPMineHeadItemTableViewCell.h" | ||||
| #import "XPSimpleMineHeaderView.h" | ||||
| #import "XPHomeBannerTableViewCell.h" | ||||
| #import "XPMineNewUserRechargeView.h" | ||||
| #import "XPMineItemTableViewCell.h" | ||||
| ///VC | ||||
| #import "XPMineSettingViewController.h" | ||||
| #import "XPMineUserInfoViewController.h" | ||||
| #import "XPMineSimpleUserInfoViewController.h" | ||||
|  | ||||
| #import "XPIAPRechargeViewController.h" | ||||
| #import "XPWebViewController.h" | ||||
| #import "XPRoomViewController.h" | ||||
| #import "XPMineDressUpViewController.h" | ||||
| #import "XPDressUpShopViewController.h" | ||||
| #import "XPMineFansViewController.h" | ||||
| #import "XPMineAttentionViewController.h" | ||||
| #import "XPMineVisitorViewController.h" | ||||
| #import "XPMineFansTeamViewController.h" | ||||
| #import "XPMineClanViewController.h" | ||||
| #import "XPMineGuildViewController.h" | ||||
| #import "XPMineFootPrintViewController.h" | ||||
| #import "XPMineCollectRoomListViewController.h" | ||||
| #import "XPMineFeedbackViewController.h" | ||||
| #import "XPMineSimpleUserInfoViewController.h" | ||||
| #import "XPIAPRechargeViewController.h" | ||||
|  | ||||
| @interface XPSimpleMineViewController ()<UITableViewDelegate, UITableViewDataSource, XPHomeBannerTableViewCellDelegate, XPMineProtocol, XPSimpleMineHeaderViewDelegate> | ||||
|  | ||||
| @property (nonatomic, strong) UITableView *tableView; | ||||
| @property (nonatomic, strong) XPSimpleMineHeaderView *headerView; | ||||
|  | ||||
| ///用户信息 | ||||
| @property (nonatomic,strong) UserInfoModel *userInfo; | ||||
| ///家族信息 | ||||
| @property (nonatomic,strong) ClanDetailInfoModel *clanInfo; | ||||
| ///我的公会 | ||||
| @property (nonatomic,strong) XPMineItemModel *guildItemModel; | ||||
| ///banner列表 | ||||
| @property (nonatomic, strong) NSMutableArray<HomeBannerInfoModel *> *bannerArray; | ||||
|  | ||||
| @property (nonatomic, strong) NSArray<XPMineItemModel *> *sectionArray0; | ||||
| @property (nonatomic, strong) NSArray<XPMineItemModel *> *sectionArray1; | ||||
|  | ||||
| @end | ||||
|  | ||||
| @implementation XPSimpleMineViewController | ||||
|  | ||||
| - (XPMinePresent *)createPresenter { | ||||
|     return [[XPMinePresent alloc] init];; | ||||
| } | ||||
|  | ||||
| - (BOOL)isHiddenNavBar { | ||||
|     return YES; | ||||
| } | ||||
|  | ||||
| - (UIStatusBarStyle)preferredStatusBarStyle { | ||||
|     return UIStatusBarStyleLightContent; | ||||
| } | ||||
|  | ||||
| - (void)viewDidLoad { | ||||
|     [super viewDidLoad]; | ||||
|     [self createUI]; | ||||
| } | ||||
|  | ||||
| - (void)viewWillAppear:(BOOL)animated { | ||||
|     [super viewWillAppear:animated]; | ||||
|     | ||||
| } | ||||
|  | ||||
| - (void)viewDidAppear:(BOOL)animated { | ||||
|     [super viewDidAppear:animated]; | ||||
|     [self.presenter getUserInfo]; | ||||
| } | ||||
|  | ||||
| - (void)createUI { | ||||
|     self.tableView.tableHeaderView = self.headerView; | ||||
|     [self.view addSubview:self.tableView]; | ||||
|     [self.tableView mas_makeConstraints:^(MASConstraintMaker *make) { | ||||
|         make.edges.mas_equalTo(self.view); | ||||
|     }]; | ||||
| } | ||||
|  | ||||
| - (void)openMyRoom { | ||||
|     NSString* roomUid = [NSString stringWithFormat:@"%ld", (long)self.userInfo.uid]; | ||||
| 	[XPRoomViewController openRoom:roomUid viewController:self]; | ||||
| } | ||||
|  | ||||
| #pragma mark - XPSimpleMineHeaderViewDelegate | ||||
|  | ||||
| - (void)headerViewBtnActionType:(XPMineItemType)itemType { | ||||
|     switch (itemType) { | ||||
|         case XPMineItemType_Match_Relevance_Account: | ||||
|              | ||||
|             break; | ||||
|         case XPMineItemType_Foot_Print: | ||||
|         { | ||||
|             XPMineFootPrintViewController *vc = [[XPMineFootPrintViewController alloc] init]; | ||||
|             [self.navigationController pushViewController:vc animated:YES]; | ||||
|         } | ||||
|             break; | ||||
|         case XPMineItemType_Account: | ||||
|         { | ||||
|             XPIAPRechargeViewController *rechargeVC = [[XPIAPRechargeViewController alloc] init]; | ||||
|             rechargeVC.type = @"4"; | ||||
|             [self.navigationController pushViewController:rechargeVC animated:YES]; | ||||
|         } | ||||
|             break; | ||||
|         case XPMineItemType_Personinfo: | ||||
|         { | ||||
|              | ||||
|             if ([ClientConfig shareConfig].canOpen) { | ||||
|                 XPMineUserInfoViewController * infoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|                 infoVC.uid = self.userInfo.uid; | ||||
|                 [self.navigationController pushViewController:infoVC animated:YES]; | ||||
|             }else{ | ||||
|                 XPMineSimpleUserInfoViewController * infoVC = [[XPMineSimpleUserInfoViewController alloc] init]; | ||||
|                 infoVC.uid = self.userInfo.uid; | ||||
|                 [self.navigationController pushViewController:infoVC animated:YES]; | ||||
|             } | ||||
|         } | ||||
|             break; | ||||
|         case XPMineItemType_My_Room: | ||||
|         { | ||||
|             [self openMyRoom]; | ||||
|         } | ||||
|             break; | ||||
|         case XPMineItemType_Collect_Room://收藏房间 | ||||
|         { | ||||
|             XPMineCollectRoomListViewController *collectVC = [[XPMineCollectRoomListViewController alloc] init]; | ||||
|             [self.navigationController pushViewController:collectVC animated:YES]; | ||||
|         } | ||||
|             break; | ||||
|         case XPMineItemType_My_Dressup: | ||||
|         { | ||||
|             XPMineDressUpViewController * dressUpVC = [[XPMineDressUpViewController alloc] init]; | ||||
|             [self.navigationController pushViewController:dressUpVC animated:YES]; | ||||
|         } | ||||
|             break; | ||||
|         case XPMineItemType_DressUp_Market: | ||||
|         { | ||||
|             XPDressUpShopViewController *dressUpShopVc = [[XPDressUpShopViewController alloc] init]; | ||||
|             [self.navigationController pushViewController:dressUpShopVc animated:YES]; | ||||
|         } | ||||
|             break; | ||||
|         case XPMineItemType_Fans_List: | ||||
|         { | ||||
|             XPMineFansViewController * fansVC = [[XPMineFansViewController alloc] init]; | ||||
|             [self.navigationController pushViewController:fansVC animated:YES]; | ||||
|         } | ||||
|             break; | ||||
|         case XPMineItemType_Attention_List: | ||||
|         { | ||||
|             XPMineAttentionViewController * attentionVC = [[XPMineAttentionViewController alloc] init]; | ||||
|             [self.navigationController pushViewController:attentionVC animated:YES]; | ||||
|         } | ||||
|             break; | ||||
|         case XPMineItemType_Visitor: | ||||
|         { | ||||
|             XPMineVisitorViewController *visitorVC = [[XPMineVisitorViewController alloc] init]; | ||||
|             [self.navigationController pushViewController:visitorVC animated:YES]; | ||||
|         } | ||||
|             break; | ||||
|         case XPMineItemType_FansTeam: { | ||||
|             XPMineFansTeamViewController *fansTeamVc = [[XPMineFansTeamViewController alloc] init]; | ||||
|             [self.navigationController pushViewController:fansTeamVc animated:YES]; | ||||
|         } | ||||
|             break; | ||||
|         case XPMineItemType_My_Guild: | ||||
|         { | ||||
|             if (self.clanInfo.clan.elderUid.length > 0) { | ||||
|                 XPMineClanViewController * clanVC = [[XPMineClanViewController alloc] init]; | ||||
|                 clanVC.uid = [NSString stringWithFormat:@"%ld", self.userInfo.uid]; | ||||
|                 [self.navigationController pushViewController:clanVC animated:YES]; | ||||
|             } else if(self.clanInfo.hall.hallId.length > 0) { | ||||
|                 XPMineGuildViewController * guildVC = [[XPMineGuildViewController alloc] init]; | ||||
|                 guildVC.ownerUid = self.clanInfo.hall.ownerUid; | ||||
|                 guildVC.guildId = self.clanInfo.hall.hallId; | ||||
|                 [self.navigationController pushViewController:guildVC animated:YES]; | ||||
|             }else{ | ||||
|                 [self showErrorToast:YMLocalizedString(@"XPSimpleMineViewController0")]; | ||||
|             } | ||||
|         } | ||||
|             break; | ||||
|         case -1: { // 我的等级 | ||||
|             XPWebViewController * webVC = [[XPWebViewController alloc] init]; | ||||
|             webVC.url = URLWithType(kUserLevelURL); | ||||
|             [self.navigationController pushViewController:webVC animated:YES]; | ||||
|         } | ||||
|             break; | ||||
|         case -2: { // 意见反馈 | ||||
|             XPMineFeedbackViewController * feedbackVC = [[XPMineFeedbackViewController alloc] init]; | ||||
|             [self.navigationController pushViewController:feedbackVC animated:YES]; | ||||
|         } | ||||
|             break; | ||||
|         case -3: { // 设置 | ||||
|             XPMineSettingViewController * settingVC = [[XPMineSettingViewController alloc] init]; | ||||
|             settingVC.userInfo = self.userInfo; | ||||
|             [self.navigationController pushViewController:settingVC animated:YES]; | ||||
|         } | ||||
|             break; | ||||
|         default: | ||||
|             break; | ||||
|     } | ||||
| } | ||||
|  | ||||
| #pragma mark - XPMineProtocol | ||||
|  | ||||
| - (void)onGetUserInfoSuccess:(UserInfoModel *)userInfo { | ||||
|     ///防止重新注册时,获取到用户信息不全,调用接口时401 | ||||
|     if (!userInfo.isBindPhone && [ClientConfig shareConfig].iosPhoneBind) { | ||||
|         return; | ||||
|     } | ||||
|     if (userInfo.nick == nil || userInfo.avatar == nil) { | ||||
|         return; | ||||
|     } | ||||
|     self.userInfo = userInfo; | ||||
|     self.headerView.userInfo = userInfo; | ||||
|     [self.tableView reloadData]; | ||||
| 	 | ||||
| 		[self.presenter getMineBannerList]; | ||||
|  | ||||
|  | ||||
|  | ||||
| 		[self.presenter getClanDetailInfo]; | ||||
|  | ||||
|  | ||||
| 		[self.tableView reloadData]; | ||||
|  | ||||
|      | ||||
| } | ||||
|  | ||||
| ///获取家族信息成功 | ||||
| - (void)onGetClanDetailInfoSuccess:(ClanDetailInfoModel *)clanInfo { | ||||
|     self.clanInfo = clanInfo; | ||||
|  | ||||
| 	[self.tableView reloadData]; | ||||
| } | ||||
|  | ||||
| - (void)onGetClanDetailInfofail { | ||||
|  | ||||
| } | ||||
|  | ||||
| ///获取个人中心banner | ||||
| - (void)onGetPersonalBannerListSuccess:(NSArray<HomeBannerInfoModel *> *)items  { | ||||
|  | ||||
|     [self.bannerArray removeAllObjects]; | ||||
|     [self.bannerArray addObjectsFromArray:items]; | ||||
|     [self.tableView reloadData]; | ||||
|     NSMutableArray *array = [NSMutableArray array]; | ||||
|     for (HomeBannerInfoModel *item in self.bannerArray) { | ||||
|         [array addObject:item.bannerId]; | ||||
|     } | ||||
|     NSString *trackName = [array componentsJoinedByString:@","]; | ||||
|     [StatisticsServiceHelper trackEventWithKey:StatisticsServiceEventusercenter_banner_show eventAttributes:@{@"bannerId" : trackName}]; | ||||
| } | ||||
|  | ||||
| - (void)onGetPersonalBannerListFail { | ||||
|  | ||||
|      | ||||
| } | ||||
|  | ||||
| #pragma mark - XPHomeBannerTableViewCellDelegate | ||||
| ///点击了某个banner | ||||
| - (void)xPHomeBannerTableViewCell:(XPHomeBannerTableViewCell *)view didClickBanner:(HomeBannerInfoModel *)info { | ||||
|     [StatisticsServiceHelper trackEventWithKey:StatisticsServiceEventusercenter_banner_click eventAttributes:@{@"bannerId" : info.bannerId}]; | ||||
|     switch (info.skipType) { | ||||
|         case HomeBannerInfoSkipType_Room: | ||||
|         { | ||||
|             if (info.skipUri.length > 0) { | ||||
|                 [XPRoomViewController openRoom:info.skipUri viewController:self]; | ||||
|             } | ||||
|         } | ||||
|             break; | ||||
|         case HomeBannerInfoSkipType_Web: | ||||
|         { | ||||
|             XPWebViewController *vc = [[XPWebViewController alloc]init]; | ||||
|             vc.url = info.skipUri; | ||||
|             [self.navigationController pushViewController:vc animated:YES]; | ||||
|         } | ||||
|             break; | ||||
|         default: | ||||
|             break; | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| #pragma mark - TableViewDelegate | ||||
|  | ||||
| - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView { | ||||
|     if (self.userInfo) { | ||||
|         return 3; | ||||
|     } | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section { | ||||
|     if (section == 0) { | ||||
|         return 0; | ||||
|     }else if (section == 1) { | ||||
|         return self.sectionArray1.count; | ||||
|     }else if (section == 2) { | ||||
|         return 1; | ||||
|     } | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath { | ||||
|     if (indexPath.section == 0) { | ||||
|         return 64; | ||||
|     } else if (indexPath.section == 1) { | ||||
|         return 64; | ||||
|     } else { | ||||
|         return 80; | ||||
|     } | ||||
| } | ||||
|  | ||||
| - (CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section { | ||||
| 	if (section == 0) { | ||||
| 		return 0.01; | ||||
| 	} | ||||
|     return 13; | ||||
| } | ||||
|  | ||||
| - (UIView *)tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section { | ||||
|     return UIView.new; | ||||
| } | ||||
|  | ||||
| - (CGFloat)tableView:(UITableView *)tableView heightForFooterInSection:(NSInteger)section { | ||||
|     return 0.01; | ||||
| } | ||||
|  | ||||
| - (UIView *)tableView:(UITableView *)tableView viewForFooterInSection:(NSInteger)section { | ||||
|     return UIView.new; | ||||
| } | ||||
|  | ||||
| - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath { | ||||
|     if (indexPath.section == 0) { | ||||
|         XPMineItemTableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:NSStringFromClass([XPMineItemTableViewCell class])]; | ||||
|         XPMineItemModel *itemModel = self.sectionArray0[indexPath.row]; | ||||
|         cell.itemModel = itemModel; | ||||
|         if (indexPath.row == 0) { | ||||
|             [cell setCornerTop:YES bottom:NO]; | ||||
|         }else if (indexPath.row == self.sectionArray0.count -1) { | ||||
|             [cell setCornerTop:NO bottom:YES]; | ||||
|         }else{ | ||||
|             [cell setCornerTop:NO bottom:NO]; | ||||
|         } | ||||
|         return cell; | ||||
|     }else if (indexPath.section == 1) { | ||||
|         XPMineItemTableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:NSStringFromClass([XPMineItemTableViewCell class])]; | ||||
|         XPMineItemModel *itemModel = self.sectionArray1[indexPath.row]; | ||||
|         cell.itemModel = itemModel; | ||||
|         if (indexPath.row == 0) { | ||||
|             [cell setCornerTop:YES bottom:NO]; | ||||
|         }else if (indexPath.row == self.sectionArray1.count -1) { | ||||
|             [cell setCornerTop:NO bottom:YES]; | ||||
|         }else{ | ||||
|             [cell setCornerTop:NO bottom:NO]; | ||||
|         } | ||||
|         return cell; | ||||
|     }else if (indexPath.section == 2) { | ||||
|         XPHomeBannerTableViewCell * cell = [tableView dequeueReusableCellWithIdentifier:NSStringFromClass([XPHomeBannerTableViewCell class])]; | ||||
|         if (cell == nil) { | ||||
|             cell = [[XPHomeBannerTableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:NSStringFromClass([XPHomeBannerTableViewCell class])]; | ||||
|         } | ||||
|         cell.isMineViewBanner = YES; | ||||
|         if (self.bannerArray.count) { | ||||
|             cell.bannerList = self.bannerArray; | ||||
|         } | ||||
|         cell.delegate = self; | ||||
|         cell.selectionStyle = UITableViewCellSelectionStyleNone; | ||||
|         return cell; | ||||
|     } | ||||
|     return UITableViewCell.new; | ||||
| } | ||||
|  | ||||
| - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath { | ||||
|     if (indexPath.section == 0) { | ||||
|         XPMineItemModel *item = self.sectionArray0[indexPath.row]; | ||||
|         [self headerViewBtnActionType:item.type]; | ||||
|     }else if (indexPath.section == 1) { | ||||
|         XPMineItemModel *item = self.sectionArray1[indexPath.row]; | ||||
|         [self headerViewBtnActionType:item.type]; | ||||
|     } | ||||
| } | ||||
|  | ||||
| #pragma mark - 懒加载 | ||||
|  | ||||
| - (UITableView *)tableView { | ||||
|     if (!_tableView) { | ||||
|         _tableView = [[UITableView alloc] initWithFrame:CGRectZero style:UITableViewStyleGrouped]; | ||||
|         _tableView.delegate = self; | ||||
|         _tableView.dataSource = self; | ||||
|         _tableView.showsVerticalScrollIndicator = NO; | ||||
|         _tableView.separatorStyle = UITableViewCellSeparatorStyleNone; | ||||
|         _tableView.backgroundColor = [UIColor colorWithWhite:0.95 alpha:1]; | ||||
|         _tableView.contentInsetAdjustmentBehavior = UIScrollViewContentInsetAdjustmentNever; | ||||
|         [_tableView registerClass:[XPMineItemTableViewCell class] forCellReuseIdentifier:NSStringFromClass([XPMineItemTableViewCell class])]; | ||||
|         [_tableView registerClass:[XPHomeBannerTableViewCell class] forCellReuseIdentifier:NSStringFromClass([XPHomeBannerTableViewCell class])]; | ||||
|         | ||||
|     } | ||||
|     return _tableView; | ||||
| } | ||||
|  | ||||
| - (XPSimpleMineHeaderView *)headerView { | ||||
|     if (!_headerView) { | ||||
|         _headerView = [[XPSimpleMineHeaderView alloc] init]; | ||||
|         _headerView.frame = CGRectMake(0, 0, self.view.bounds.size.width, 313); | ||||
|         _headerView.delegate = self; | ||||
|     } | ||||
|     return _headerView; | ||||
| } | ||||
|  | ||||
| - (NSArray<XPMineItemModel *> *)sectionArray0 { | ||||
|     if (!_sectionArray0) { | ||||
|         XPMineItemModel *model0 = [[XPMineItemModel alloc] init]; | ||||
|         model0.itemImageName = @"mine_union"; | ||||
|         model0.itemName = YMLocalizedString(@"XPSimpleMineViewController1"); | ||||
|         model0.type = XPMineItemType_My_Guild; | ||||
|          | ||||
|         XPMineItemModel *model1 = [[XPMineItemModel alloc] init]; | ||||
|         model1.itemImageName = @"mine_dress"; | ||||
|         model1.itemName = YMLocalizedString(@"XPSimpleMineViewController2"); | ||||
|         model1.type = XPMineItemType_DressUp_Market; | ||||
|          | ||||
|         XPMineItemModel *model2 = [[XPMineItemModel alloc] init]; | ||||
|         model2.itemImageName = @"mine_fans"; | ||||
|         model2.itemName = YMLocalizedString(@"XPSimpleMineViewController3"); | ||||
|         model2.type = XPMineItemType_FansTeam; | ||||
|         _sectionArray0 = @[model0, model1, model2]; | ||||
|     } | ||||
|     return _sectionArray0; | ||||
| } | ||||
|  | ||||
| - (NSArray<XPMineItemModel *> *)sectionArray1 { | ||||
|     if (!_sectionArray1) { | ||||
|  | ||||
|  | ||||
|         XPMineItemModel *model1 = [[XPMineItemModel alloc] init]; | ||||
|         model1.itemImageName = @"mine_feedback"; | ||||
|         model1.itemName = YMLocalizedString(@"XPSimpleMineViewController5"); | ||||
|         model1.type = -2; | ||||
|          | ||||
|         XPMineItemModel *model2 = [[XPMineItemModel alloc] init]; | ||||
|         model2.itemImageName = @"mine_setting"; | ||||
|         model2.itemName = YMLocalizedString(@"XPSimpleMineViewController6"); | ||||
|         model2.type = -3; | ||||
|          | ||||
|         _sectionArray1 = @[ model1, model2]; | ||||
|     } | ||||
|     return _sectionArray1; | ||||
| } | ||||
|  | ||||
| - (NSMutableArray<HomeBannerInfoModel *> *)bannerArray { | ||||
|     if (!_bannerArray) { | ||||
|         _bannerArray = [NSMutableArray array]; | ||||
|     } | ||||
|     return _bannerArray; | ||||
| } | ||||
|  | ||||
| @end | ||||
| @@ -1,16 +0,0 @@ | ||||
| // | ||||
| //  YMMomentListViewController.h | ||||
| //  YUMI | ||||
| // | ||||
| //  Created by XY on 2023/2/16. | ||||
| // | ||||
|  | ||||
| #import "MvpViewController.h" | ||||
|  | ||||
| NS_ASSUME_NONNULL_BEGIN | ||||
|  | ||||
| @interface XPMomentListViewController : MvpViewController | ||||
|  | ||||
| @end | ||||
|  | ||||
| NS_ASSUME_NONNULL_END | ||||
| @@ -1,282 +0,0 @@ | ||||
| // | ||||
| //  YMMomentListViewController.m | ||||
| //  YUMI | ||||
| // | ||||
| //  Created by XY on 2023/2/16. | ||||
| // | ||||
|  | ||||
| #import "XPMomentListViewController.h" | ||||
| #import "YUMIMacroUitls.h" | ||||
| #import <Masonry.h> | ||||
| #import <MJRefresh.h> | ||||
| #import "DJDKMIMOMColor.h" | ||||
| #import "NSArray+Safe.h" | ||||
| #import "ClientConfig.h" | ||||
|  | ||||
| #import "MonentsListInfoModel.h" | ||||
|  | ||||
| #import "XPMomentListCollectionViewCell.h" | ||||
| #import "XPButton.h" | ||||
|  | ||||
| #import "XPMonentsLatestPresenter.h" | ||||
| #import "XPMonentsLatestProtocol.h" | ||||
|  | ||||
| #import "XPMonentsDetailViewController.h" | ||||
| #import "XPMonentsPublishViewController.h" | ||||
| #import "XPMomentsSimpleDetailViewController.h" | ||||
|  | ||||
| @interface XPMomentListViewController ()<UICollectionViewDelegate, UICollectionViewDataSource, XPMonentsLatestProtocol, XPMonentsDetailViewControllerDelegate> | ||||
|  | ||||
| @property (nonatomic, strong) UICollectionView *collectionView; | ||||
|  | ||||
| /// 自定义导航栏 | ||||
| @property (nonatomic, strong) UIView *customNav; | ||||
| @property (nonatomic, strong) UILabel *titleLabel; | ||||
| /// 发布 | ||||
| @property (nonatomic, strong) XPButton *publishBtn; | ||||
|  | ||||
| ///数据源 | ||||
| @property (nonatomic,strong) NSMutableArray<MonentsInfoModel *> *datasource; | ||||
| ///当前的页数 | ||||
| @property (nonatomic,assign) NSInteger page; | ||||
| ///是否有更多的数据 | ||||
| @property (nonatomic,assign) BOOL hasNoMoreData; | ||||
| ///数据信息 | ||||
| @property (nonatomic,strong) MonentsListInfoModel *listInfo; | ||||
|  | ||||
| @end | ||||
|  | ||||
| @implementation XPMomentListViewController | ||||
|  | ||||
| - (BOOL)isHiddenNavBar { | ||||
|     return YES; | ||||
| } | ||||
|  | ||||
| - (__kindof id)createPresenter { | ||||
|     return [[XPMonentsLatestPresenter alloc] init]; | ||||
| } | ||||
|  | ||||
| - (void)viewDidLoad { | ||||
|     [super viewDidLoad]; | ||||
|     [self createUI]; | ||||
|      | ||||
|     [self initHeaderAndFooterRrfresh]; | ||||
| } | ||||
|  | ||||
| - (void)createUI { | ||||
|     [self.view addSubview:self.customNav]; | ||||
|     [self.customNav addSubview:self.titleLabel]; | ||||
|     [self.view addSubview:self.collectionView]; | ||||
|     [self.view addSubview:self.publishBtn]; | ||||
|      | ||||
|     [self.customNav mas_makeConstraints:^(MASConstraintMaker *make) { | ||||
|         make.top.mas_equalTo(kStatusBarHeight); | ||||
|         make.leading.trailing.mas_equalTo(0); | ||||
|         make.height.mas_equalTo(44); | ||||
|     }]; | ||||
|     [self.titleLabel mas_makeConstraints:^(MASConstraintMaker *make) { | ||||
|         make.edges.mas_equalTo(self.customNav); | ||||
|     }]; | ||||
|     [self.collectionView mas_makeConstraints:^(MASConstraintMaker *make) { | ||||
|         make.top.mas_equalTo(self.customNav.mas_bottom); | ||||
|         make.leading.trailing.mas_equalTo(0); | ||||
|         make.bottom.mas_equalTo(0); | ||||
|     }]; | ||||
|     [self.publishBtn mas_makeConstraints:^(MASConstraintMaker *make) { | ||||
|         make.bottom.mas_equalTo(-108); | ||||
|         make.trailing.mas_equalTo(0); | ||||
|         make.width.height.mas_equalTo(70); | ||||
|     }]; | ||||
| } | ||||
|  | ||||
| /// 发布 | ||||
| - (void)publishBtnAction { | ||||
|     XPMonentsPublishViewController * publishVC = [[XPMonentsPublishViewController alloc] init]; | ||||
|     [self.navigationController pushViewController:publishVC animated:YES]; | ||||
| } | ||||
|  | ||||
| #pragma mark - 下拉刷新 | ||||
| - (void)initHeaderAndFooterRrfresh { | ||||
|     MJRefreshNormalHeader *header = [MJRefreshNormalHeader headerWithRefreshingTarget:self refreshingAction:@selector(headerRefresh)]; | ||||
|     header.stateLabel.font = [UIFont systemFontOfSize:10.0]; | ||||
|     header.lastUpdatedTimeLabel.font = [UIFont systemFontOfSize:10.0]; | ||||
|     header.stateLabel.textColor = [DJDKMIMOMColor secondTextColor]; | ||||
|     header.lastUpdatedTimeLabel.textColor = [DJDKMIMOMColor secondTextColor]; | ||||
|     self.collectionView.mj_header = header; | ||||
|      | ||||
|     MJRefreshBackNormalFooter *footer = [MJRefreshBackNormalFooter footerWithRefreshingTarget:self refreshingAction:@selector(footerRefresh)]; | ||||
|     footer.stateLabel.textColor = [DJDKMIMOMColor secondTextColor]; | ||||
|     footer.stateLabel.font = [UIFont systemFontOfSize:10.0]; | ||||
|     footer.ignoredScrollViewContentInsetBottom = self.collectionView.contentInset.bottom; | ||||
|     self.collectionView.mj_footer = footer; | ||||
|      | ||||
|     [self headerRefresh]; | ||||
| } | ||||
|  | ||||
| #pragma mark - 刷新的fangfa | ||||
| - (void)headerRefresh { | ||||
|     self.page = 1; | ||||
|     [self.presenter getMonentsLatestListPageSize:20 dynamicId:@"" state:0]; | ||||
| } | ||||
|  | ||||
| - (void)footerRefresh { | ||||
|     if (self.hasNoMoreData) { | ||||
|         [self showErrorToast:YMLocalizedString(@"XPMomentListViewController0")]; | ||||
|         [self.collectionView.mj_footer endRefreshing]; | ||||
|         return; | ||||
|     } | ||||
|     self.page++; | ||||
|     [self.presenter getMonentsLatestListPageSize:20 dynamicId:self.listInfo.nextDynamicId state:1]; | ||||
| } | ||||
|  | ||||
| #pragma mark - XPMonentsLatestProtocol | ||||
| - (void)getMonentsLatestListSuccess:(MonentsListInfoModel *)listInfo state:(int)state{ | ||||
|     self.listInfo = listInfo; | ||||
|     if (state == 0) { | ||||
|         [self.datasource removeAllObjects]; | ||||
|     } | ||||
|     if (listInfo.dynamicList.count > 0) { | ||||
|         [self.datasource addObjectsFromArray:listInfo.dynamicList]; | ||||
|     } | ||||
|      | ||||
|     if (state == 0) { | ||||
|         self.hasNoMoreData = NO; | ||||
|         [self.collectionView.mj_header endRefreshing]; | ||||
|     } else { | ||||
|         if (listInfo.dynamicList.count > 0) { | ||||
|             self.hasNoMoreData = NO; | ||||
|         } else { | ||||
|             self.hasNoMoreData = YES; | ||||
|         } | ||||
|         [self.collectionView.mj_footer endRefreshing]; | ||||
|     } | ||||
|     [self.collectionView reloadData]; | ||||
| } | ||||
|  | ||||
| - (void)getMonentsLatestListFail:(NSString *)msg state:(int)state { | ||||
|     if (state == 0) { | ||||
|         [self.collectionView.mj_header endRefreshing]; | ||||
|     } else { | ||||
|         [self.collectionView.mj_footer endRefreshing]; | ||||
|     } | ||||
| } | ||||
|  | ||||
| #pragma mark - XPMonentsDetailViewControllerDelegate | ||||
| - (void)xPMonentsDetailViewController:(XPMonentsDetailViewController *)view deleteMonents:(NSString *)dynamicId { | ||||
|     __block MonentsInfoModel * deleteInfo; | ||||
|     [self.datasource enumerateObjectsUsingBlock:^(MonentsInfoModel * _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) { | ||||
|         if (obj.dynamicId.integerValue == dynamicId.integerValue) { | ||||
|             deleteInfo = obj; | ||||
|         } | ||||
|     }]; | ||||
|  | ||||
|     if (deleteInfo) { | ||||
|         [self.datasource removeObject:deleteInfo]; | ||||
|         [self.collectionView reloadData]; | ||||
|     } | ||||
| } | ||||
|  | ||||
| #pragma mark - UICollectionView | ||||
|  | ||||
| - (NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section { | ||||
|     return self.datasource.count; | ||||
| } | ||||
|  | ||||
| - (__kindof UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath { | ||||
|     XPMomentListCollectionViewCell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:NSStringFromClass(XPMomentListCollectionViewCell.self) forIndexPath:indexPath]; | ||||
|     MonentsInfoModel * monentsInfo = [self.datasource safeObjectAtIndex1:indexPath.row]; | ||||
|     cell.monentsInfo = monentsInfo; | ||||
|     return cell; | ||||
| } | ||||
|  | ||||
| - (void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath { | ||||
|     if (self.datasource.count > 0) { | ||||
|          | ||||
|         if ([ClientConfig shareConfig].canOpen) { | ||||
|             XPMomentsSimpleDetailViewController *detailVC = [[XPMomentsSimpleDetailViewController alloc] init]; | ||||
|             MonentsInfoModel * monentsInfo = [self.datasource safeObjectAtIndex1:indexPath.row]; | ||||
|             detailVC.monentsInfo = monentsInfo; | ||||
|             detailVC.delegate = self; | ||||
|             [self.navigationController pushViewController:detailVC animated:YES]; | ||||
|         }else{ | ||||
|             XPMomentsSimpleDetailViewController * detailVC = [[XPMomentsSimpleDetailViewController alloc] init]; | ||||
|             MonentsInfoModel * monentsInfo = [self.datasource safeObjectAtIndex1:indexPath.row]; | ||||
|             detailVC.monentsInfo = monentsInfo; | ||||
|             detailVC.delegate = self; | ||||
|             [self.navigationController pushViewController:detailVC animated:YES]; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| #pragma mark - 懒加载 | ||||
|  | ||||
| - (UICollectionView *)collectionView { | ||||
|     if (!_collectionView) { | ||||
|         MSBaseRTLFlowLayout *layout = [[MSBaseRTLFlowLayout alloc] init]; | ||||
|         layout.scrollDirection = UICollectionViewScrollDirectionVertical; | ||||
|         CGFloat width = (KScreenWidth - 16 -13 -16)/2.0; | ||||
|         CGFloat height = 220.0/165.0*width; | ||||
|         layout.itemSize = CGSizeMake(width, height); | ||||
|         layout.minimumLineSpacing = 12.0; | ||||
|         layout.minimumInteritemSpacing = 13.0; | ||||
|         layout.sectionInset = UIEdgeInsetsMake(12, 16, 12, 16); | ||||
|          | ||||
|         _collectionView = [[UICollectionView alloc] initWithFrame:CGRectZero collectionViewLayout:layout]; | ||||
|         _collectionView.backgroundColor = UIColor.clearColor; | ||||
|         _collectionView.alwaysBounceVertical = YES; | ||||
|         [_collectionView registerClass:[XPMomentListCollectionViewCell class] forCellWithReuseIdentifier:NSStringFromClass(XPMomentListCollectionViewCell.self)]; | ||||
|         _collectionView.delegate = self; | ||||
|         _collectionView.dataSource = self; | ||||
|         _collectionView.contentInsetAdjustmentBehavior = UIScrollViewContentInsetAdjustmentNever; | ||||
|          | ||||
|        | ||||
|          | ||||
|     } | ||||
|     return _collectionView; | ||||
| } | ||||
|  | ||||
| - (XPButton *)publishBtn { | ||||
|     if (!_publishBtn) { | ||||
|         _publishBtn = [XPButton buttonWithType:UIButtonTypeCustom]; | ||||
|         _publishBtn.backgroundColor = UIColorFromRGB(0x0C1430); | ||||
|         [_publishBtn setTitleColor:UIColor.whiteColor forState:UIControlStateNormal]; | ||||
|         _publishBtn.titleLabel.font = [UIFont systemFontOfSize:12 weight:UIFontWeightMedium]; | ||||
|         [_publishBtn setTitle:YMLocalizedString(@"XPMomentListViewController1") forState:UIControlStateNormal]; | ||||
|         [_publishBtn setImage:[UIImage imageNamed:@"moment_camera"] forState:UIControlStateNormal]; | ||||
|         [_publishBtn addTarget:self action:@selector(publishBtnAction) forControlEvents:UIControlEventTouchUpInside]; | ||||
|         _publishBtn.layer.cornerRadius = 70/2; | ||||
|         _publishBtn.clipsToBounds = YES; | ||||
| 		_publishBtn.buttonStyle = XPButtonImageTop; | ||||
|         _publishBtn.padding = 4; | ||||
|     } | ||||
|     return _publishBtn; | ||||
| } | ||||
|  | ||||
| - (UIView *)customNav { | ||||
|     if (!_customNav) { | ||||
|         _customNav = [[UIView alloc] init]; | ||||
|         _customNav.backgroundColor = [DJDKMIMOMColor appBackgroundColor]; | ||||
|     } | ||||
|     return _customNav; | ||||
| } | ||||
|  | ||||
| - (UILabel *)titleLabel { | ||||
|     if (!_titleLabel) { | ||||
|         _titleLabel = [[UILabel alloc] init]; | ||||
|         _titleLabel.text = YMLocalizedString(@"XPMomentListViewController2"); | ||||
|         _titleLabel.backgroundColor = [UIColor clearColor]; | ||||
|         _titleLabel.font = [UIFont systemFontOfSize:18.f weight:UIFontWeightMedium]; | ||||
|         _titleLabel.textColor = DJDKMIMOMColor.mainTextColor; | ||||
|         _titleLabel.textAlignment = NSTextAlignmentCenter; | ||||
|     } | ||||
|     return _titleLabel; | ||||
| } | ||||
|  | ||||
| - (NSMutableArray<MonentsInfoModel *> *)datasource { | ||||
|     if (!_datasource) { | ||||
|         _datasource = [NSMutableArray array]; | ||||
|     } | ||||
|     return _datasource; | ||||
| } | ||||
|  | ||||
| @end | ||||
| @@ -33,7 +33,7 @@ | ||||
| #import "QKeyboardManager.h" | ||||
| #import "QEmotionBoardView.h" | ||||
| #import "XPMineUserInfoViewController.h" | ||||
| #import "XPMineSimpleUserInfoViewController.h" | ||||
|  | ||||
| #import "XPMomentsSimpleDetailNav.h" | ||||
| #import "XPWebViewController.h" | ||||
| ///P | ||||
| @@ -280,38 +280,29 @@ | ||||
|  | ||||
| /// 点击头像 | ||||
| - (void)momentsSimpleDetailNavAvatarAction { | ||||
|     if ([ClientConfig shareConfig].canOpen) { | ||||
|         XPMineUserInfoViewController * userInfoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|         userInfoVC.uid = self.monentsInfo.uid.integerValue; | ||||
|         [self.navigationController pushViewController:userInfoVC animated:YES]; | ||||
|     }else{ | ||||
|         XPMineSimpleUserInfoViewController * userInfoVC = [[XPMineSimpleUserInfoViewController alloc] init]; | ||||
|         userInfoVC.uid = self.monentsInfo.uid.integerValue; | ||||
|         [self.navigationController pushViewController:userInfoVC animated:YES]; | ||||
|     } | ||||
|     XPMineUserInfoViewController * userInfoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|     userInfoVC.uid = self.monentsInfo.uid.integerValue; | ||||
|     [self.navigationController pushViewController:userInfoVC animated:YES]; | ||||
| } | ||||
|  | ||||
| /// 点击更多 | ||||
| - (void)momentsSimpleDetailNavMoreAction { | ||||
|     TTActionSheetConfig *action; | ||||
|     @kWeakify(self); | ||||
|     if (self.monentsInfo.uid.integerValue == [AccountInfoStorage instance].getUid.integerValue) { | ||||
|         action = [TTActionSheetConfig normalTitle:YMLocalizedString(@"XPMomentsSimpleDetailViewController4") clickAction:^{ | ||||
|             [TTPopup alertWithMessage:YMLocalizedString(@"XPMonentsTopicLatestViewController1") confirmHandler:^{ | ||||
|                 @kStrongify(self); | ||||
|                 [self.presenter deleteMonents:self.monentsInfo.dynamicId worldId:[NSString stringWithFormat:@"%ld", self.monentsInfo.worldId]]; | ||||
|             } cancelHandler:^{ | ||||
|  | ||||
|             }]; | ||||
|             } cancelHandler:^{}]; | ||||
|         }]; | ||||
|     } else { | ||||
|         action = [TTActionSheetConfig normalTitle:YMLocalizedString(@"XPMomentsSimpleDetailViewController6") clickAction:^{ | ||||
| 			if ([ClientConfig shareConfig].canOpen) { | ||||
| 				NSString * url= [NSString stringWithFormat:@"%@?reportUid=%@&source=%@", URLWithType(kReportRoomURL),self.monentsInfo.uid, @"WORLDDYNAMIC"]; | ||||
| 				XPWebViewController * webVC = [[XPWebViewController alloc] init]; | ||||
| 				webVC.url = url; | ||||
| 				[self.navigationController pushViewController:webVC animated:YES]; | ||||
| 			} else { | ||||
| 				[XNDJTDDLoadingTool showErrorWithMessage:YMLocalizedString(@"XPMomentsSimpleDetailViewController7")]; | ||||
| 			} | ||||
|             @kStrongify(self); | ||||
|             NSString * url= [NSString stringWithFormat:@"%@?reportUid=%@&source=%@", URLWithType(kReportRoomURL),self.monentsInfo.uid, @"WORLDDYNAMIC"]; | ||||
|             XPWebViewController * webVC = [[XPWebViewController alloc] init]; | ||||
|             webVC.url = url; | ||||
|             [self.navigationController pushViewController:webVC animated:YES]; | ||||
|         }]; | ||||
|     } | ||||
|     [TTPopup actionSheetWithItems:@[action]]; | ||||
| @@ -330,16 +321,9 @@ | ||||
|     } | ||||
| } | ||||
| - (void)xPMonentsCommentTableViewCell:(XPMonentsCommentTableViewCell *)view didClickAvatar:(NSString *)commentInfo { | ||||
|     if ([ClientConfig shareConfig].canOpen) { | ||||
|         XPMineUserInfoViewController * userInfoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|         userInfoVC.uid = commentInfo.integerValue; | ||||
|         [self.navigationController pushViewController:userInfoVC animated:YES]; | ||||
|     }else{ | ||||
|         XPMineSimpleUserInfoViewController * userInfoVC = [[XPMineSimpleUserInfoViewController alloc] init]; | ||||
|         userInfoVC.uid = commentInfo.integerValue; | ||||
|         [self.navigationController pushViewController:userInfoVC animated:YES]; | ||||
|     } | ||||
|      | ||||
|     XPMineUserInfoViewController * userInfoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|     userInfoVC.uid = commentInfo.integerValue; | ||||
|     [self.navigationController pushViewController:userInfoVC animated:YES]; | ||||
| } | ||||
| #pragma mark - XPMonentsTableViewCellDelegate | ||||
| - (void)xPMonentsTableViewCell:(XPMonentsTableViewCell *)view didClickLike:(MonentsInfoModel *)monentsInfo { | ||||
|   | ||||
| @@ -132,15 +132,9 @@ | ||||
| 		MonentsInfoModel * monents = [[MonentsInfoModel alloc] init]; | ||||
| 		monents.dynamicId = model.dynamicId; | ||||
|          | ||||
|         if ([ClientConfig shareConfig].canOpen) { | ||||
|             XPMonentsDetailViewController * detailVC = [[XPMonentsDetailViewController alloc] init]; | ||||
|             detailVC.monentsInfo = monents; | ||||
|             [self.navigationController pushViewController:detailVC animated:YES]; | ||||
|         }else{ | ||||
|             XPMomentsSimpleDetailViewController * detailVC = [[XPMomentsSimpleDetailViewController alloc] init]; | ||||
|             detailVC.monentsInfo = monents; | ||||
|             [self.navigationController pushViewController:detailVC animated:YES]; | ||||
|         } | ||||
|         XPMonentsDetailViewController * detailVC = [[XPMonentsDetailViewController alloc] init]; | ||||
|         detailVC.monentsInfo = monents; | ||||
|         [self.navigationController pushViewController:detailVC animated:YES]; | ||||
| 	} | ||||
| } | ||||
| #pragma mark -JXCategoryListContainerViewDelegate | ||||
|   | ||||
| @@ -94,22 +94,14 @@ | ||||
| - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath { | ||||
| 	[tableView deselectRowAtIndexPath:indexPath animated:YES]; | ||||
| 	if (self.datasource.count > 0) { | ||||
|          | ||||
|         if ([ClientConfig shareConfig].canOpen) { | ||||
|             XPMonentsDetailViewController * detailVC = [[XPMonentsDetailViewController alloc] init]; | ||||
|             MonentsInfoModel * monentsInfo = [self.datasource safeObjectAtIndex1:indexPath.row]; | ||||
|             if(monentsInfo.dynamicId == nil)return; | ||||
|             detailVC.monentsInfo = monentsInfo; | ||||
|             detailVC.delegate = self; | ||||
|             [self.navigationController pushViewController:detailVC animated:YES]; | ||||
|         }else{ | ||||
|             XPMomentsSimpleDetailViewController * detailVC = [[XPMomentsSimpleDetailViewController alloc] init]; | ||||
|             MonentsInfoModel * monentsInfo = [self.datasource safeObjectAtIndex1:indexPath.row]; | ||||
|             detailVC.monentsInfo = monentsInfo; | ||||
|             if(monentsInfo.dynamicId == nil)return; | ||||
|             detailVC.delegate = self; | ||||
|             [self.navigationController pushViewController:detailVC animated:YES]; | ||||
|         MonentsInfoModel * monentsInfo = [self.datasource safeObjectAtIndex1:indexPath.row]; | ||||
|         if(monentsInfo.dynamicId == nil) { | ||||
|             return; | ||||
|         } | ||||
|         XPMonentsDetailViewController * detailVC = [[XPMonentsDetailViewController alloc] init]; | ||||
|         detailVC.monentsInfo = monentsInfo; | ||||
|         detailVC.delegate = self; | ||||
|         [self.navigationController pushViewController:detailVC animated:YES]; | ||||
| 	} | ||||
| } | ||||
| #pragma mark - XPMonentsTableViewCellDelegate | ||||
| @@ -126,19 +118,10 @@ | ||||
|         [self showErrorToast:YMLocalizedString(@"XPMineUserDataViewController5")]; | ||||
|         return; | ||||
|     } | ||||
|     if ([ClientConfig shareConfig].canOpen) { | ||||
|         XPMonentsDetailViewController * detailVC = [[XPMonentsDetailViewController alloc] init]; | ||||
|         detailVC.monentsInfo = monentsInfo; | ||||
|         detailVC.delegate = self; | ||||
|         [self.navigationController pushViewController:detailVC animated:YES]; | ||||
|     }else{ | ||||
|         XPMomentsSimpleDetailViewController * detailVC = [[XPMomentsSimpleDetailViewController alloc] init]; | ||||
|        | ||||
|         detailVC.monentsInfo = monentsInfo; | ||||
|  | ||||
|         detailVC.delegate = self; | ||||
|         [self.navigationController pushViewController:detailVC animated:YES]; | ||||
|     } | ||||
|     XPMonentsDetailViewController * detailVC = [[XPMonentsDetailViewController alloc] init]; | ||||
|     detailVC.monentsInfo = monentsInfo; | ||||
|     detailVC.delegate = self; | ||||
|     [self.navigationController pushViewController:detailVC animated:YES]; | ||||
| } | ||||
| - (void)xPMonentsTableViewCell:(XPMonentsTableViewCell *)view didClicDelete:(MonentsInfoModel *)monentsInfo { | ||||
| 	[TTPopup alertWithMessage:YMLocalizedString(@"XPMonentsMineViewController2") confirmHandler:^{ | ||||
|   | ||||
| @@ -104,7 +104,6 @@ | ||||
|  | ||||
| 	[self.datasource addObject:self.addPicImage]; | ||||
|  | ||||
| 	self.addTopicView.hidden = ![ClientConfig shareConfig].canOpen; | ||||
|     for (id view in self.textView.subviews) { | ||||
|         if ([view isKindOfClass:[UITextView class]]){ | ||||
|             UITextView *textView = view; | ||||
|   | ||||
| @@ -46,7 +46,6 @@ NS_ASSUME_NONNULL_BEGIN | ||||
| //是否为周榜top1 | ||||
| @property(nonatomic,assign) BOOL isWeekTop1; | ||||
| @property(nonatomic,copy) NSString *inRoomUid; | ||||
|  | ||||
| //是否在麦位 | ||||
| @property(nonatomic,assign) BOOL inMic; | ||||
| ///是否在线 | ||||
|   | ||||
| @@ -24,7 +24,7 @@ NS_ASSUME_NONNULL_BEGIN | ||||
| @interface XPNewHomePartyTableViewCell : UITableViewCell | ||||
|  | ||||
| @property (nonatomic,strong) HomePlayRoomModel *roomInfo; | ||||
| @property (nonatomic,strong) HomeRecommendRoomModel *roomInfo1; | ||||
|  | ||||
| @property(nonatomic,weak) id<XPNewHomePartyTableViewCellDelegate>delegate; | ||||
| ///声音卡时,svga是否播放动画 | ||||
| -(void)setPlaySoundStatus:(BOOL)isPlay; | ||||
|   | ||||
| @@ -243,14 +243,7 @@ | ||||
| -(void)setPlaySoundTime:(NSInteger)time{ | ||||
|     _audioView.voiceDura = @(time).stringValue; | ||||
| } | ||||
| - (void)setRoomInfo1:(HomeRecommendRoomModel *)roomInfo1 { | ||||
| 	_roomInfo1 = roomInfo1; | ||||
| 	if (_roomInfo1) { | ||||
| 		 | ||||
| 		 | ||||
| 		 | ||||
| 	} | ||||
| } | ||||
|  | ||||
|  | ||||
| -(void)didSelectItemAction{ | ||||
|   | ||||
|   | ||||
| @@ -23,7 +23,7 @@ | ||||
| ///VC | ||||
| #import "XPRoomViewController.h" | ||||
| #import "XPMineUserInfoViewController.h" | ||||
| #import "XPMineSimpleUserInfoViewController.h" | ||||
|  | ||||
|  | ||||
| UIKIT_EXTERN NSString *kFromSearchToHomeViewKey; | ||||
| UIKIT_EXTERN NSString *kTabShowAnchorCardKey; | ||||
| @@ -68,6 +68,12 @@ UIKIT_EXTERN NSString *kTabShowAnchorCardKey; | ||||
| 	}]; | ||||
| } | ||||
|  | ||||
| - (void)toMineUserInfoView:(HomeSearchResultModel *)model { | ||||
|     XPMineUserInfoViewController *infoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|     infoVC.uid = model.uid.integerValue; | ||||
|     [(UINavigationController *)self.presentingViewController pushViewController:infoVC animated:YES]; | ||||
| } | ||||
|  | ||||
| #pragma mark - UITableViewDelegate And UITableViewDataSource | ||||
| - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath { | ||||
| 	return 74; | ||||
| @@ -89,38 +95,25 @@ UIKIT_EXTERN NSString *kTabShowAnchorCardKey; | ||||
|  | ||||
| - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath { | ||||
| 	[tableView deselectRowAtIndexPath:indexPath animated:YES]; | ||||
| 	HomeSearchResultModel * resultModel = [self.datasource safeObjectAtIndex1:indexPath.row]; | ||||
|      | ||||
|     BOOL result = [[NSUserDefaults standardUserDefaults] boolForKey:kFromSearchToHomeViewKey]; | ||||
|     if (!result) { | ||||
|         [[NSUserDefaults standardUserDefaults] setBool:YES forKey:kFromSearchToHomeViewKey]; | ||||
|         [[NSUserDefaults standardUserDefaults] synchronize]; | ||||
|         [[NSNotificationCenter defaultCenter] postNotificationName:kTabShowAnchorCardKey object:@{@"delayShow" : @(YES)}]; | ||||
|     } | ||||
|      | ||||
|     [self dismissViewControllerAnimated:YES completion:nil]; | ||||
|      | ||||
|     HomeSearchResultModel * resultModel = [self.datasource safeObjectAtIndex1:indexPath.row]; | ||||
| 	if (self.type == SearchType_Room) { | ||||
| 		if (resultModel.valid) { | ||||
| 			[XPRoomViewController openRoom:resultModel.uid viewController:self.presentingViewController]; | ||||
| 		} else { | ||||
|             if ([ClientConfig shareConfig].canOpen) { | ||||
|                 XPMineUserInfoViewController * infoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|                 infoVC.uid = resultModel.uid.integerValue; | ||||
|                 [(UINavigationController *)self.presentingViewController pushViewController:infoVC animated:YES]; | ||||
|             }else{ | ||||
|                 XPMineSimpleUserInfoViewController * infoVC = [[XPMineSimpleUserInfoViewController alloc] init]; | ||||
|                 infoVC.uid = resultModel.uid.integerValue; | ||||
|                 [(UINavigationController *)self.presentingViewController pushViewController:infoVC animated:YES]; | ||||
|             } | ||||
|             [self toMineUserInfoView:resultModel]; | ||||
| 		} | ||||
| 	} else { | ||||
|         if ([ClientConfig shareConfig].canOpen) { | ||||
|             XPMineUserInfoViewController * infoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|             infoVC.uid = resultModel.uid.integerValue; | ||||
|             [(UINavigationController *)self.presentingViewController pushViewController:infoVC animated:YES]; | ||||
|         }else{ | ||||
|             XPMineSimpleUserInfoViewController * infoVC = [[XPMineSimpleUserInfoViewController alloc] init]; | ||||
|             infoVC.uid = resultModel.uid.integerValue; | ||||
|             [(UINavigationController *)self.presentingViewController pushViewController:infoVC animated:YES]; | ||||
|         } | ||||
|         [self toMineUserInfoView:resultModel]; | ||||
| 	} | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -20,7 +20,7 @@ | ||||
| #import "XPHomeSearchRecordCell.h" | ||||
| #import "XPRoomViewController.h" | ||||
| #import "XPMineUserInfoViewController.h" | ||||
| #import "XPMineSimpleUserInfoViewController.h" | ||||
|  | ||||
| ///P | ||||
| #import "XPInRoomRecordPresenter.h" | ||||
| #import "XPInRoomRecordProtocol.h" | ||||
| @@ -222,15 +222,9 @@ NSString * const XPConstSearchRecordStoreKey = @"XPConstSearchRecordStoreKey"; | ||||
|         if (resultModel.valid) { | ||||
|             [XPRoomViewController openRoom:resultModel.roomUid viewController:self.presentingViewController]; | ||||
|         } else { | ||||
|             if ([ClientConfig shareConfig].canOpen) { | ||||
|                 XPMineUserInfoViewController * infoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|                 infoVC.uid = resultModel.roomUid.integerValue; | ||||
|                 [(UINavigationController *)self.presentingViewController pushViewController:infoVC animated:YES]; | ||||
|             }else{ | ||||
|                 XPMineSimpleUserInfoViewController * infoVC = [[XPMineSimpleUserInfoViewController alloc] init]; | ||||
|                 infoVC.uid = resultModel.roomUid.integerValue; | ||||
|                 [(UINavigationController *)self.presentingViewController pushViewController:infoVC animated:YES]; | ||||
|             } | ||||
|             XPMineUserInfoViewController * infoVC = [[XPMineUserInfoViewController alloc] init]; | ||||
|             infoVC.uid = resultModel.roomUid.integerValue; | ||||
|             [(UINavigationController *)self.presentingViewController pushViewController:infoVC animated:YES]; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||