modernize backend to target the same ES and TS standards as the rest of the app
This commit is contained in:
parent
22f49db21f
commit
9beeca5942
29 changed files with 460 additions and 232 deletions
|
|
@ -6,11 +6,49 @@
|
|||
import { appendContentWarning } from './append-content-warning.js';
|
||||
import type { Packed } from './json-schema.js';
|
||||
|
||||
// export type PackedNoteForSummary = Omit<Partial<Packed<'Note'>>, 'user'> & {
|
||||
// user: Omit<Partial<Packed<'Note'>['user']>, 'instance'> & {
|
||||
// instance?: Partial<Packed<'Note'>['user']['instance']> | null;
|
||||
// };
|
||||
// };
|
||||
|
||||
// Workaround for weird typescript but
|
||||
// type Pivot<N, U, I> = {
|
||||
// [KNote in keyof N]?: KNote extends 'user'
|
||||
// ? {
|
||||
// [KUser in keyof U]?: KUser extends 'instance'
|
||||
// ? {
|
||||
// [KInst in keyof I]?: I[KInst] | undefined;
|
||||
// }
|
||||
// : U[KUser]
|
||||
// }
|
||||
// : N[KNote]
|
||||
// };
|
||||
// type Pivot<N extends { user: U }, U extends { instance?: I | null }, I extends object> = Split<N, 'user'> & {
|
||||
// user: Split<U, 'instance'> & {
|
||||
// instance: I | undefined;
|
||||
// };
|
||||
// };
|
||||
//
|
||||
// type Split<T, O extends keyof T, R extends keyof T = Exclude<keyof T, O>> = {
|
||||
// [K in (keyof T) & R]: T[K];
|
||||
// } & {
|
||||
// [K in (keyof T) & O]?: T[K] | undefined;
|
||||
// };
|
||||
//
|
||||
// export type PackedNoteForSummary = Pivot<Packed<'Note'>, Packed<'Note'>['user'], NonNullable<Packed<'Note'>['user']['instance']>>;
|
||||
export type PackedNoteForSummary = DeepPartial<Packed<'Note'>>;
|
||||
|
||||
// Do we really not have a type for this yet??
|
||||
type DeepPartial<T extends object> = {
|
||||
[K in keyof T]?: T[K] extends object ? DeepPartial<T[K]> : T[K];
|
||||
};
|
||||
|
||||
/**
|
||||
* 投稿を表す文字列を取得します。
|
||||
* @param {*} note (packされた)投稿
|
||||
*/
|
||||
export const getNoteSummary = (note: Packed<'Note'>): string => {
|
||||
export const getNoteSummary = (note: PackedNoteForSummary): string => {
|
||||
if (note.deletedAt) {
|
||||
return '(❌⛔)';
|
||||
}
|
||||
|
|
@ -26,13 +64,13 @@ export const getNoteSummary = (note: Packed<'Note'>): string => {
|
|||
if (note.mandatoryCW) {
|
||||
cw = appendContentWarning(cw, `Note is flagged: "${note.mandatoryCW}"`);
|
||||
}
|
||||
if (note.user.mandatoryCW) {
|
||||
if (note.user?.mandatoryCW) {
|
||||
const username = note.user.host
|
||||
? `@${note.user.username}@${note.user.host}`
|
||||
: `@${note.user.username}`;
|
||||
cw = appendContentWarning(cw, `${username} is flagged: "${note.user.mandatoryCW}"`);
|
||||
}
|
||||
if (note.user.instance?.mandatoryCW) {
|
||||
if (note.user?.instance?.mandatoryCW) {
|
||||
cw = appendContentWarning(cw, `${note.user.host} is flagged: "${note.user.instance.mandatoryCW}"`);
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue