fix: 引用RNがpure RNとして連合され、pure RNが引用RNとして連合される (#12744)
* fix: quote notes are rendered as pure renote * fix: filesが指定されてて空配列のときにQuote扱いされる * chore: isQuoteの仕様をmisc/is-quote.tsと揃える * docs: is-quote.tsの方にNoteCreateService.isQuoteのことを書いて更新忘れを防ぐ
This commit is contained in:
		
							parent
							
								
									433d46e57f
								
							
						
					
					
						commit
						52b94dbc4a
					
				
					 2 changed files with 6 additions and 4 deletions
				
			
		| 
						 | 
				
			
			@ -293,7 +293,7 @@ export class NoteCreateService implements OnApplicationShutdown {
 | 
			
		|||
		}
 | 
			
		||||
 | 
			
		||||
		// Check blocking
 | 
			
		||||
		if (data.renote && this.isQuote(data)) {
 | 
			
		||||
		if (this.isQuote(data)) {
 | 
			
		||||
			if (data.renote.userHost === null) {
 | 
			
		||||
				if (data.renote.userId !== user.id) {
 | 
			
		||||
					const blocked = await this.userBlockingService.checkBlocked(data.renote.userId, user.id);
 | 
			
		||||
| 
						 | 
				
			
			@ -730,8 +730,9 @@ export class NoteCreateService implements OnApplicationShutdown {
 | 
			
		|||
	}
 | 
			
		||||
 | 
			
		||||
	@bindThis
 | 
			
		||||
	private isQuote(note: Option): boolean {
 | 
			
		||||
		return !!note.text || !!note.cw || !!note.files || !!note.poll;
 | 
			
		||||
	private isQuote(note: Option): note is Option & { renote: MiNote } {
 | 
			
		||||
		// sync with misc/is-quote.ts
 | 
			
		||||
		return !!note.renote && (!!note.text || !!note.cw || (!!note.files && !!note.files.length) || !!note.poll);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	@bindThis
 | 
			
		||||
| 
						 | 
				
			
			@ -799,7 +800,7 @@ export class NoteCreateService implements OnApplicationShutdown {
 | 
			
		|||
	private async renderNoteOrRenoteActivity(data: Option, note: MiNote) {
 | 
			
		||||
		if (data.localOnly) return null;
 | 
			
		||||
 | 
			
		||||
		const content = data.renote && this.isQuote(data)
 | 
			
		||||
		const content = data.renote && !this.isQuote(data)
 | 
			
		||||
			? this.apRendererService.renderAnnounce(data.renote.uri ? data.renote.uri : `${this.config.url}/notes/${data.renote.id}`, note)
 | 
			
		||||
			: this.apRendererService.renderCreate(await this.apRendererService.renderNote(note, false), note);
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -7,5 +7,6 @@ import type { MiNote } from '@/models/Note.js';
 | 
			
		|||
 | 
			
		||||
// eslint-disable-next-line import/no-default-export
 | 
			
		||||
export default function(note: MiNote): boolean {
 | 
			
		||||
	// sync with NoteCreateService.isQuote
 | 
			
		||||
	return note.renoteId != null && (note.text != null || note.hasPoll || (note.fileIds != null && note.fileIds.length > 0));
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue