enhance: タイムラインからRenoteを除外するオプションを追加
This commit is contained in:
		| @@ -19,6 +19,7 @@ class GlobalTimelineChannel extends Channel { | ||||
| 	public static shouldShare = true; | ||||
| 	public static requireCredential = false; | ||||
| 	private withReplies: boolean; | ||||
| 	private withRenotes: boolean; | ||||
|  | ||||
| 	constructor( | ||||
| 		private metaService: MetaService, | ||||
| @@ -37,7 +38,8 @@ class GlobalTimelineChannel extends Channel { | ||||
| 		const policies = await this.roleService.getUserPolicies(this.user ? this.user.id : null); | ||||
| 		if (!policies.gtlAvailable) return; | ||||
|  | ||||
| 		this.withReplies = params.withReplies as boolean; | ||||
| 		this.withReplies = params.withReplies ?? false; | ||||
| 		this.withRenotes = params.withRenotes ?? true; | ||||
|  | ||||
| 		// Subscribe events | ||||
| 		this.subscriber.on('notesStream', this.onNote); | ||||
| @@ -68,6 +70,8 @@ class GlobalTimelineChannel extends Channel { | ||||
| 			if (reply.userId !== this.user!.id && note.userId !== this.user!.id && reply.userId !== note.userId) return; | ||||
| 		} | ||||
|  | ||||
| 		if (note.renote && note.text == null && (note.fileIds == null || note.fileIds.length === 0) && !this.withRenotes) return; | ||||
|  | ||||
| 		// Ignore notes from instances the user has muted | ||||
| 		if (isInstanceMuted(note, new Set<string>(this.userProfile?.mutedInstances ?? []))) return; | ||||
|  | ||||
|   | ||||
| @@ -17,6 +17,7 @@ class HomeTimelineChannel extends Channel { | ||||
| 	public static shouldShare = true; | ||||
| 	public static requireCredential = true; | ||||
| 	private withReplies: boolean; | ||||
| 	private withRenotes: boolean; | ||||
|  | ||||
| 	constructor( | ||||
| 		private noteEntityService: NoteEntityService, | ||||
| @@ -30,7 +31,8 @@ class HomeTimelineChannel extends Channel { | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async init(params: any) { | ||||
| 		this.withReplies = params.withReplies as boolean; | ||||
| 		this.withReplies = params.withReplies ?? false; | ||||
| 		this.withRenotes = params.withRenotes ?? true; | ||||
|  | ||||
| 		this.subscriber.on('notesStream', this.onNote); | ||||
| 	} | ||||
| @@ -77,6 +79,8 @@ class HomeTimelineChannel extends Channel { | ||||
| 			if (reply.userId !== this.user!.id && note.userId !== this.user!.id && reply.userId !== note.userId) return; | ||||
| 		} | ||||
|  | ||||
| 		if (note.renote && note.text == null && (note.fileIds == null || note.fileIds.length === 0) && !this.withRenotes) return; | ||||
|  | ||||
| 		// 流れてきたNoteがミュートしているユーザーが関わるものだったら無視する | ||||
| 		if (isUserRelated(note, this.userIdsWhoMeMuting)) return; | ||||
| 		// 流れてきたNoteがブロックされているユーザーが関わるものだったら無視する | ||||
|   | ||||
| @@ -19,6 +19,7 @@ class HybridTimelineChannel extends Channel { | ||||
| 	public static shouldShare = true; | ||||
| 	public static requireCredential = true; | ||||
| 	private withReplies: boolean; | ||||
| 	private withRenotes: boolean; | ||||
|  | ||||
| 	constructor( | ||||
| 		private metaService: MetaService, | ||||
| @@ -37,7 +38,8 @@ class HybridTimelineChannel extends Channel { | ||||
| 		const policies = await this.roleService.getUserPolicies(this.user ? this.user.id : null); | ||||
| 		if (!policies.ltlAvailable) return; | ||||
|  | ||||
| 		this.withReplies = params.withReplies as boolean; | ||||
| 		this.withReplies = params.withReplies ?? false; | ||||
| 		this.withRenotes = params.withRenotes ?? true; | ||||
|  | ||||
| 		// Subscribe events | ||||
| 		this.subscriber.on('notesStream', this.onNote); | ||||
| @@ -89,6 +91,8 @@ class HybridTimelineChannel extends Channel { | ||||
| 			if (reply.userId !== this.user!.id && note.userId !== this.user!.id && reply.userId !== note.userId) return; | ||||
| 		} | ||||
|  | ||||
| 		if (note.renote && note.text == null && (note.fileIds == null || note.fileIds.length === 0) && !this.withRenotes) return; | ||||
|  | ||||
| 		// 流れてきたNoteがミュートしているユーザーが関わるものだったら無視する | ||||
| 		if (isUserRelated(note, this.userIdsWhoMeMuting)) return; | ||||
| 		// 流れてきたNoteがブロックされているユーザーが関わるものだったら無視する | ||||
|   | ||||
| @@ -18,6 +18,7 @@ class LocalTimelineChannel extends Channel { | ||||
| 	public static shouldShare = true; | ||||
| 	public static requireCredential = false; | ||||
| 	private withReplies: boolean; | ||||
| 	private withRenotes: boolean; | ||||
|  | ||||
| 	constructor( | ||||
| 		private metaService: MetaService, | ||||
| @@ -36,7 +37,8 @@ class LocalTimelineChannel extends Channel { | ||||
| 		const policies = await this.roleService.getUserPolicies(this.user ? this.user.id : null); | ||||
| 		if (!policies.ltlAvailable) return; | ||||
|  | ||||
| 		this.withReplies = params.withReplies as boolean; | ||||
| 		this.withReplies = params.withReplies ?? false; | ||||
| 		this.withRenotes = params.withRenotes ?? true; | ||||
|  | ||||
| 		// Subscribe events | ||||
| 		this.subscriber.on('notesStream', this.onNote); | ||||
| @@ -68,6 +70,8 @@ class LocalTimelineChannel extends Channel { | ||||
| 			if (reply.userId !== this.user.id && note.userId !== this.user.id && reply.userId !== note.userId) return; | ||||
| 		} | ||||
|  | ||||
| 		if (note.renote && note.text == null && (note.fileIds == null || note.fileIds.length === 0) && !this.withRenotes) return; | ||||
|  | ||||
| 		// 流れてきたNoteがミュートしているユーザーが関わるものだったら無視する | ||||
| 		if (isUserRelated(note, this.userIdsWhoMeMuting)) return; | ||||
| 		// 流れてきたNoteがブロックされているユーザーが関わるものだったら無視する | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 syuilo
					syuilo