[Statsig] Track likes, reposts, follows (#3195)
* [Statsig] Track likes * Move tracking to intent * Track repost/unrepost * Track profile follows/unfollows * Less copy paste * Reorder
This commit is contained in:
		
							parent
							
								
									db79c918b2
								
							
						
					
					
						commit
						7eaa573b57
					
				
					 15 changed files with 125 additions and 30 deletions
				
			
		|  | @ -56,7 +56,7 @@ export function RecommendedFollowsItem({ | |||
|   ) | ||||
| } | ||||
| 
 | ||||
| export function ProfileCard({ | ||||
| function ProfileCard({ | ||||
|   profile, | ||||
|   onFollowStateChange, | ||||
|   moderation, | ||||
|  | @ -72,7 +72,10 @@ export function ProfileCard({ | |||
|   const pal = usePalette('default') | ||||
|   const [addingMoreSuggestions, setAddingMoreSuggestions] = | ||||
|     React.useState(false) | ||||
|   const [queueFollow, queueUnfollow] = useProfileFollowMutationQueue(profile) | ||||
|   const [queueFollow, queueUnfollow] = useProfileFollowMutationQueue( | ||||
|     profile, | ||||
|     'RecommendedFollowsItem', | ||||
|   ) | ||||
| 
 | ||||
|   const onToggleFollow = React.useCallback(async () => { | ||||
|     try { | ||||
|  |  | |||
|  | @ -42,7 +42,10 @@ function PostThreadFollowBtnLoaded({ | |||
|   const {isTabletOrDesktop} = useWebMediaQueries() | ||||
|   const profile: Shadow<AppBskyActorDefs.ProfileViewBasic> = | ||||
|     useProfileShadow(profileUnshadowed) | ||||
|   const [queueFollow, queueUnfollow] = useProfileFollowMutationQueue(profile) | ||||
|   const [queueFollow, queueUnfollow] = useProfileFollowMutationQueue( | ||||
|     profile, | ||||
|     'PostThreadItem', | ||||
|   ) | ||||
|   const requireAuth = useRequireAuth() | ||||
| 
 | ||||
|   const isFollowing = !!profile.viewer?.following | ||||
|  |  | |||
|  | @ -407,6 +407,7 @@ let PostThreadItemLoaded = ({ | |||
|                 record={record} | ||||
|                 richText={richText} | ||||
|                 onPressReply={onPressReply} | ||||
|                 logContext="PostThreadItem" | ||||
|               /> | ||||
|             </View> | ||||
|           </View> | ||||
|  | @ -560,6 +561,7 @@ let PostThreadItemLoaded = ({ | |||
|                   record={record} | ||||
|                   richText={richText} | ||||
|                   onPressReply={onPressReply} | ||||
|                   logContext="PostThreadItem" | ||||
|                 /> | ||||
|               </View> | ||||
|             </View> | ||||
|  |  | |||
|  | @ -220,6 +220,7 @@ function PostInner({ | |||
|             record={record} | ||||
|             richText={richText} | ||||
|             onPressReply={onPressReply} | ||||
|             logContext="Post" | ||||
|           /> | ||||
|         </View> | ||||
|       </View> | ||||
|  |  | |||
|  | @ -310,6 +310,7 @@ let FeedItemInner = ({ | |||
|             showAppealLabelItem={ | ||||
|               post.author.did === currentAccount?.did && isModeratedPost | ||||
|             } | ||||
|             logContext="FeedItem" | ||||
|           /> | ||||
|         </View> | ||||
|       </View> | ||||
|  |  | |||
|  | @ -13,13 +13,18 @@ export function FollowButton({ | |||
|   followedType = 'default', | ||||
|   profile, | ||||
|   labelStyle, | ||||
|   logContext, | ||||
| }: { | ||||
|   unfollowedType?: ButtonType | ||||
|   followedType?: ButtonType | ||||
|   profile: Shadow<AppBskyActorDefs.ProfileViewBasic> | ||||
|   labelStyle?: StyleProp<TextStyle> | ||||
|   logContext: 'ProfileCard' | ||||
| }) { | ||||
|   const [queueFollow, queueUnfollow] = useProfileFollowMutationQueue(profile) | ||||
|   const [queueFollow, queueUnfollow] = useProfileFollowMutationQueue( | ||||
|     profile, | ||||
|     logContext, | ||||
|   ) | ||||
|   const {_} = useLingui() | ||||
| 
 | ||||
|   const onPressFollow = async () => { | ||||
|  |  | |||
|  | @ -230,7 +230,9 @@ export function ProfileCardWithFollowBtn({ | |||
|       renderButton={ | ||||
|         isMe | ||||
|           ? undefined | ||||
|           : profileShadow => <FollowButton profile={profileShadow} /> | ||||
|           : profileShadow => ( | ||||
|               <FollowButton profile={profileShadow} logContext="ProfileCard" /> | ||||
|             ) | ||||
|       } | ||||
|     /> | ||||
|   ) | ||||
|  |  | |||
|  | @ -103,7 +103,10 @@ let ProfileHeader = ({ | |||
|   const invalidHandle = isInvalidHandle(profile.handle) | ||||
|   const {isDesktop} = useWebMediaQueries() | ||||
|   const [showSuggestedFollows, setShowSuggestedFollows] = React.useState(false) | ||||
|   const [queueFollow, queueUnfollow] = useProfileFollowMutationQueue(profile) | ||||
|   const [queueFollow, queueUnfollow] = useProfileFollowMutationQueue( | ||||
|     profile, | ||||
|     'ProfileHeader', | ||||
|   ) | ||||
|   const [__, queueUnblock] = useProfileBlockMutationQueue(profile) | ||||
|   const unblockPromptControl = Prompt.usePromptControl() | ||||
|   const moderation = useMemo( | ||||
|  |  | |||
|  | @ -170,7 +170,10 @@ function SuggestedFollow({ | |||
|   const pal = usePalette('default') | ||||
|   const moderationOpts = useModerationOpts() | ||||
|   const profile = useProfileShadow(profileUnshadowed) | ||||
|   const [queueFollow, queueUnfollow] = useProfileFollowMutationQueue(profile) | ||||
|   const [queueFollow, queueUnfollow] = useProfileFollowMutationQueue( | ||||
|     profile, | ||||
|     'ProfileHeaderSuggestedFollows', | ||||
|   ) | ||||
| 
 | ||||
|   const onPressFollow = React.useCallback(async () => { | ||||
|     try { | ||||
|  |  | |||
|  | @ -52,7 +52,10 @@ let ProfileMenu = ({ | |||
| 
 | ||||
|   const [queueMute, queueUnmute] = useProfileMuteMutationQueue(profile) | ||||
|   const [queueBlock, queueUnblock] = useProfileBlockMutationQueue(profile) | ||||
|   const [, queueUnfollow] = useProfileFollowMutationQueue(profile) | ||||
|   const [, queueUnfollow] = useProfileFollowMutationQueue( | ||||
|     profile, | ||||
|     'ProfileMenu', | ||||
|   ) | ||||
| 
 | ||||
|   const blockPromptControl = Prompt.usePromptControl() | ||||
| 
 | ||||
|  |  | |||
|  | @ -44,6 +44,7 @@ let PostCtrls = ({ | |||
|   showAppealLabelItem, | ||||
|   style, | ||||
|   onPressReply, | ||||
|   logContext, | ||||
| }: { | ||||
|   big?: boolean | ||||
|   post: Shadow<AppBskyFeedDefs.PostView> | ||||
|  | @ -52,13 +53,17 @@ let PostCtrls = ({ | |||
|   showAppealLabelItem?: boolean | ||||
|   style?: StyleProp<ViewStyle> | ||||
|   onPressReply: () => void | ||||
|   logContext: 'FeedItem' | 'PostThreadItem' | 'Post' | ||||
| }): React.ReactNode => { | ||||
|   const theme = useTheme() | ||||
|   const {_} = useLingui() | ||||
|   const {openComposer} = useComposerControls() | ||||
|   const {closeModal} = useModalControls() | ||||
|   const [queueLike, queueUnlike] = usePostLikeMutationQueue(post) | ||||
|   const [queueRepost, queueUnrepost] = usePostRepostMutationQueue(post) | ||||
|   const [queueLike, queueUnlike] = usePostLikeMutationQueue(post, logContext) | ||||
|   const [queueRepost, queueUnrepost] = usePostRepostMutationQueue( | ||||
|     post, | ||||
|     logContext, | ||||
|   ) | ||||
|   const requireAuth = useRequireAuth() | ||||
| 
 | ||||
|   const defaultCtrlColor = React.useMemo( | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue