Labeling & moderation updates [DRAFT] (#1057)
* First pass moving to the new labeling sdk (it compiles) * Correct behaviors around interpreting label moderation * Improve moderation state rendering * Improve hiders and alerts * Improve handling of mutes * Improve profile warnings * Add profile blurring to profile header * Add blocks to test cases * Render labels on profile cards, do not filter * Filter profiles from suggestions using moderation * Apply profile blurring to ProfileCard * Handle blocked and deleted quote posts * Temporarily translate content filtering settings to new labels * Fix types * Tune ContentHider & PostHider click targets * Put a warning on profilecard label pills * Fix screenhider learnmore link on mobile * Enforce no-override on user avatar * Dont enumerate profile blur-media labels in alerts * Fixes to muted posts (esp quotes of muted users) * Fixes to account/profile warnings * Bump @atproto/api@0.5.0 * Bump @atproto/api@0.5.1 * Fix tests * 1.43 * Remove log * Bump @atproto/api@0.5.2
This commit is contained in:
		
							parent
							
								
									3ae5a6b631
								
							
						
					
					
						commit
						b154d3ea21
					
				
					 43 changed files with 1193 additions and 717 deletions
				
			
		|  | @ -26,7 +26,7 @@ import {PostEmbeds} from '../util/post-embeds' | |||
| import {PostCtrls} from '../util/post-ctrls/PostCtrls' | ||||
| import {PostHider} from '../util/moderation/PostHider' | ||||
| import {ContentHider} from '../util/moderation/ContentHider' | ||||
| import {ImageHider} from '../util/moderation/ImageHider' | ||||
| import {PostAlerts} from '../util/moderation/PostAlerts' | ||||
| import {PostSandboxWarning} from '../util/PostSandboxWarning' | ||||
| import {ErrorMessage} from '../util/error/ErrorMessage' | ||||
| import {usePalette} from 'lib/hooks/usePalette' | ||||
|  | @ -159,10 +159,9 @@ export const PostThreadItem = observer(function PostThreadItem({ | |||
| 
 | ||||
|   if (item._isHighlightedPost) { | ||||
|     return ( | ||||
|       <PostHider | ||||
|       <Link | ||||
|         testID={`postThreadItem-by-${item.post.author.handle}`} | ||||
|         style={[styles.outer, styles.outerHighlighted, pal.border, pal.view]} | ||||
|         moderation={item.moderation.thread}> | ||||
|         style={[styles.outer, styles.outerHighlighted, pal.border, pal.view]}> | ||||
|         <PostSandboxWarning /> | ||||
|         <View style={styles.layout}> | ||||
|           <View style={styles.layoutAvi}> | ||||
|  | @ -227,7 +226,16 @@ export const PostThreadItem = observer(function PostThreadItem({ | |||
|           </View> | ||||
|         </View> | ||||
|         <View style={[s.pl10, s.pr10, s.pb10]}> | ||||
|           <ContentHider moderation={item.moderation.view}> | ||||
|           <ContentHider | ||||
|             moderation={item.moderation.content} | ||||
|             ignoreMute | ||||
|             style={styles.contentHider} | ||||
|             childContainerStyle={styles.contentHiderChild}> | ||||
|             <PostAlerts | ||||
|               moderation={item.moderation.content} | ||||
|               includeMute | ||||
|               style={styles.alert} | ||||
|             /> | ||||
|             {item.richText?.text ? ( | ||||
|               <View | ||||
|                 style={[ | ||||
|  | @ -242,9 +250,11 @@ export const PostThreadItem = observer(function PostThreadItem({ | |||
|                 /> | ||||
|               </View> | ||||
|             ) : undefined} | ||||
|             <ImageHider moderation={item.moderation.view} style={s.mb10}> | ||||
|               <PostEmbeds embed={item.post.embed} style={s.mb10} /> | ||||
|             </ImageHider> | ||||
|             {item.post.embed && ( | ||||
|               <ContentHider moderation={item.moderation.embed} style={s.mb10}> | ||||
|                 <PostEmbeds embed={item.post.embed} style={s.mb10} /> | ||||
|               </ContentHider> | ||||
|             )} | ||||
|           </ContentHider> | ||||
|           <ExpandedPostDetails | ||||
|             post={item.post} | ||||
|  | @ -311,7 +321,7 @@ export const PostThreadItem = observer(function PostThreadItem({ | |||
|             /> | ||||
|           </View> | ||||
|         </View> | ||||
|       </PostHider> | ||||
|       </Link> | ||||
|     ) | ||||
|   } else { | ||||
|     return ( | ||||
|  | @ -325,7 +335,7 @@ export const PostThreadItem = observer(function PostThreadItem({ | |||
|             pal.view, | ||||
|             item._showParentReplyLine && styles.noTopBorder, | ||||
|           ]} | ||||
|           moderation={item.moderation.thread}> | ||||
|           moderation={item.moderation.content}> | ||||
|           {item._showParentReplyLine && ( | ||||
|             <View | ||||
|               style={[ | ||||
|  | @ -360,32 +370,34 @@ export const PostThreadItem = observer(function PostThreadItem({ | |||
|                 timestamp={item.post.indexedAt} | ||||
|                 postHref={itemHref} | ||||
|               /> | ||||
|               <ContentHider | ||||
|                 moderation={item.moderation.thread} | ||||
|                 containerStyle={styles.contentHider}> | ||||
|                 {item.richText?.text ? ( | ||||
|                   <View style={styles.postTextContainer}> | ||||
|                     <RichText | ||||
|                       type="post-text" | ||||
|                       richText={item.richText} | ||||
|                       style={[pal.text, s.flex1]} | ||||
|                       lineHeight={1.3} | ||||
|                     /> | ||||
|                   </View> | ||||
|                 ) : undefined} | ||||
|                 <ImageHider style={s.mb10} moderation={item.moderation.thread}> | ||||
|               <PostAlerts | ||||
|                 moderation={item.moderation.content} | ||||
|                 style={styles.alert} | ||||
|               /> | ||||
|               {item.richText?.text ? ( | ||||
|                 <View style={styles.postTextContainer}> | ||||
|                   <RichText | ||||
|                     type="post-text" | ||||
|                     richText={item.richText} | ||||
|                     style={[pal.text, s.flex1]} | ||||
|                     lineHeight={1.3} | ||||
|                   /> | ||||
|                 </View> | ||||
|               ) : undefined} | ||||
|               {item.post.embed && ( | ||||
|                 <ContentHider style={s.mb10} moderation={item.moderation.embed}> | ||||
|                   <PostEmbeds embed={item.post.embed} style={s.mb10} /> | ||||
|                 </ImageHider> | ||||
|                 {needsTranslation && ( | ||||
|                   <View style={[pal.borderDark, styles.translateLink]}> | ||||
|                     <Link href={translatorUrl} title="Translate"> | ||||
|                       <Text type="sm" style={pal.link}> | ||||
|                         Translate this post | ||||
|                       </Text> | ||||
|                     </Link> | ||||
|                   </View> | ||||
|                 )} | ||||
|               </ContentHider> | ||||
|                 </ContentHider> | ||||
|               )} | ||||
|               {needsTranslation && ( | ||||
|                 <View style={[pal.borderDark, styles.translateLink]}> | ||||
|                   <Link href={translatorUrl} title="Translate"> | ||||
|                     <Text type="sm" style={pal.link}> | ||||
|                       Translate this post | ||||
|                     </Text> | ||||
|                   </Link> | ||||
|                 </View> | ||||
|               )} | ||||
|               <PostCtrls | ||||
|                 itemUri={itemUri} | ||||
|                 itemCid={itemCid} | ||||
|  | @ -515,6 +527,9 @@ const styles = StyleSheet.create({ | |||
|     paddingRight: 5, | ||||
|     maxWidth: 240, | ||||
|   }, | ||||
|   alert: { | ||||
|     marginBottom: 6, | ||||
|   }, | ||||
|   postTextContainer: { | ||||
|     flexDirection: 'row', | ||||
|     alignItems: 'center', | ||||
|  | @ -531,7 +546,10 @@ const styles = StyleSheet.create({ | |||
|     marginBottom: 6, | ||||
|   }, | ||||
|   contentHider: { | ||||
|     marginTop: 4, | ||||
|     marginBottom: 6, | ||||
|   }, | ||||
|   contentHiderChild: { | ||||
|     marginTop: 6, | ||||
|   }, | ||||
|   expandedInfo: { | ||||
|     flexDirection: 'row', | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue