signal-desktop/ts/groupChange.ts

594 lines
17 KiB
TypeScript
Raw Normal View History

2020-09-09 02:25:05 +00:00
import { FullJSXType } from './components/Intl';
import { LocalizerType } from './types/Util';
import { ReplacementValuesType } from './types/I18N';
import { missingCaseError } from './util/missingCaseError';
import { AccessControlClass, MemberClass } from './textsecure.d';
import { GroupV2ChangeDetailType, GroupV2ChangeType } from './groups';
export type SmartContactRendererType = (conversationId: string) => FullJSXType;
export type StringRendererType = (
id: string,
i18n: LocalizerType,
components?: Array<FullJSXType> | ReplacementValuesType<FullJSXType>
) => FullJSXType;
export type RenderOptionsType = {
AccessControlEnum: typeof AccessControlClass.AccessRequired;
from?: string;
i18n: LocalizerType;
ourConversationId: string;
renderContact: SmartContactRendererType;
renderString: StringRendererType;
RoleEnum: typeof MemberClass.Role;
};
export function renderChange(
change: GroupV2ChangeType,
options: RenderOptionsType
2020-09-11 19:37:01 +00:00
): Array<FullJSXType> {
2020-09-09 02:25:05 +00:00
const { details, from } = change;
return details.map((detail: GroupV2ChangeDetailType) =>
renderChangeDetail(detail, {
...options,
from,
})
);
}
export function renderChangeDetail(
detail: GroupV2ChangeDetailType,
options: RenderOptionsType
): FullJSXType {
const {
AccessControlEnum,
from,
i18n,
ourConversationId,
renderContact,
renderString,
RoleEnum,
} = options;
const fromYou = Boolean(from && from === ourConversationId);
2020-10-06 17:06:34 +00:00
if (detail.type === 'create') {
if (fromYou) {
return renderString('GroupV2--create--you', i18n);
}
if (from) {
return renderString('GroupV2--create--other', i18n, {
memberName: renderContact(from),
});
}
return renderString('GroupV2--create--unknown', i18n);
}
2020-09-09 02:25:05 +00:00
if (detail.type === 'title') {
const { newTitle } = detail;
if (newTitle) {
if (fromYou) {
return renderString('GroupV2--title--change--you', i18n, [newTitle]);
2020-09-11 19:37:01 +00:00
}
if (from) {
2020-09-09 02:25:05 +00:00
return renderString('GroupV2--title--change--other', i18n, {
memberName: renderContact(from),
newTitle,
});
}
2020-09-11 19:37:01 +00:00
return renderString('GroupV2--title--change--unknown', i18n, [newTitle]);
2020-09-09 02:25:05 +00:00
}
2020-09-11 19:37:01 +00:00
if (fromYou) {
return renderString('GroupV2--title--remove--you', i18n);
}
if (from) {
return renderString('GroupV2--title--remove--other', i18n, [
renderContact(from),
]);
}
return renderString('GroupV2--title--remove--unknown', i18n);
}
if (detail.type === 'avatar') {
2020-09-09 02:25:05 +00:00
if (detail.removed) {
if (fromYou) {
return renderString('GroupV2--avatar--remove--you', i18n);
}
2020-09-11 19:37:01 +00:00
if (from) {
return renderString('GroupV2--avatar--remove--other', i18n, [
2020-09-09 02:25:05 +00:00
renderContact(from),
]);
}
2020-09-11 19:37:01 +00:00
return renderString('GroupV2--avatar--remove--unknown', i18n);
}
if (fromYou) {
return renderString('GroupV2--avatar--change--you', i18n);
}
if (from) {
return renderString('GroupV2--avatar--change--other', i18n, [
renderContact(from),
]);
2020-09-09 02:25:05 +00:00
}
2020-09-11 19:37:01 +00:00
return renderString('GroupV2--avatar--change--unknown', i18n);
}
if (detail.type === 'access-attributes') {
2020-09-09 02:25:05 +00:00
const { newPrivilege } = detail;
if (newPrivilege === AccessControlEnum.ADMINISTRATOR) {
if (fromYou) {
return renderString('GroupV2--access-attributes--admins--you', i18n);
2020-09-11 19:37:01 +00:00
}
if (from) {
2020-09-09 02:25:05 +00:00
return renderString('GroupV2--access-attributes--admins--other', i18n, [
renderContact(from),
]);
}
2020-09-11 19:37:01 +00:00
return renderString('GroupV2--access-attributes--admins--unknown', i18n);
}
if (newPrivilege === AccessControlEnum.MEMBER) {
2020-09-09 02:25:05 +00:00
if (fromYou) {
return renderString('GroupV2--access-attributes--all--you', i18n);
2020-09-11 19:37:01 +00:00
}
if (from) {
2020-09-09 02:25:05 +00:00
return renderString('GroupV2--access-attributes--all--other', i18n, [
renderContact(from),
]);
}
2020-09-11 19:37:01 +00:00
return renderString('GroupV2--access-attributes--all--unknown', i18n);
2020-09-09 02:25:05 +00:00
}
2020-09-11 19:37:01 +00:00
throw new Error(
`access-attributes change type, privilege ${newPrivilege} is unknown`
);
2020-09-09 02:25:05 +00:00
} else if (detail.type === 'access-members') {
const { newPrivilege } = detail;
if (newPrivilege === AccessControlEnum.ADMINISTRATOR) {
if (fromYou) {
return renderString('GroupV2--access-members--admins--you', i18n);
2020-09-11 19:37:01 +00:00
}
if (from) {
2020-09-09 02:25:05 +00:00
return renderString('GroupV2--access-members--admins--other', i18n, [
renderContact(from),
]);
}
2020-09-11 19:37:01 +00:00
return renderString('GroupV2--access-members--admins--unknown', i18n);
}
if (newPrivilege === AccessControlEnum.MEMBER) {
2020-09-09 02:25:05 +00:00
if (fromYou) {
return renderString('GroupV2--access-members--all--you', i18n);
2020-09-11 19:37:01 +00:00
}
if (from) {
2020-09-09 02:25:05 +00:00
return renderString('GroupV2--access-members--all--other', i18n, [
renderContact(from),
]);
}
2020-09-11 19:37:01 +00:00
return renderString('GroupV2--access-members--all--unknown', i18n);
2020-09-09 02:25:05 +00:00
}
2020-09-11 19:37:01 +00:00
throw new Error(
`access-members change type, privilege ${newPrivilege} is unknown`
);
2020-09-09 02:25:05 +00:00
} else if (detail.type === 'member-add') {
const { conversationId } = detail;
const weAreJoiner = conversationId === ourConversationId;
if (weAreJoiner) {
if (fromYou) {
return renderString('GroupV2--member-add--you--you', i18n);
2020-09-11 19:37:01 +00:00
}
if (from) {
2020-09-09 02:25:05 +00:00
return renderString('GroupV2--member-add--you--other', i18n, [
renderContact(from),
]);
}
2020-09-11 19:37:01 +00:00
return renderString('GroupV2--member-add--you--unknown', i18n);
}
if (fromYou) {
return renderString('GroupV2--member-add--other--you', i18n, [
renderContact(conversationId),
]);
}
if (from) {
return renderString('GroupV2--member-add--other--other', i18n, {
adderName: renderContact(from),
addeeName: renderContact(conversationId),
});
2020-09-09 02:25:05 +00:00
}
2020-09-11 19:37:01 +00:00
return renderString('GroupV2--member-add--other--unknown', i18n, [
renderContact(conversationId),
]);
2020-09-09 02:25:05 +00:00
} else if (detail.type === 'member-add-from-invite') {
const { conversationId, inviter } = detail;
const weAreJoiner = conversationId === ourConversationId;
const weAreInviter = Boolean(inviter && inviter === ourConversationId);
if (!from || from !== conversationId) {
if (weAreJoiner) {
// They can't be the same, no fromYou check here
if (from) {
return renderString('GroupV2--member-add--you--other', i18n, [
renderContact(from),
]);
}
return renderString('GroupV2--member-add--you--unknown', i18n);
}
if (fromYou) {
return renderString('GroupV2--member-add--invited--you', i18n, {
inviteeName: renderContact(conversationId),
});
}
if (from) {
return renderString('GroupV2--member-add--invited--other', i18n, {
memberName: renderContact(from),
inviteeName: renderContact(conversationId),
});
}
return renderString('GroupV2--member-add--invited--unknown', i18n, {
inviteeName: renderContact(conversationId),
});
}
2020-09-09 02:25:05 +00:00
if (weAreJoiner) {
if (inviter) {
return renderString('GroupV2--member-add--from-invite--you', i18n, [
renderContact(inviter),
]);
}
return renderString(
'GroupV2--member-add--from-invite--you-no-from',
i18n
);
2020-09-11 19:37:01 +00:00
}
if (weAreInviter) {
2020-09-09 02:25:05 +00:00
return renderString('GroupV2--member-add--from-invite--from-you', i18n, [
renderContact(conversationId),
]);
}
if (inviter) {
return renderString('GroupV2--member-add--from-invite--other', i18n, {
inviteeName: renderContact(conversationId),
inviterName: renderContact(inviter),
});
}
return renderString(
'GroupV2--member-add--from-invite--other-no-from',
i18n,
{
inviteeName: renderContact(conversationId),
}
);
2020-09-09 02:25:05 +00:00
} else if (detail.type === 'member-remove') {
const { conversationId } = detail;
const weAreLeaver = conversationId === ourConversationId;
if (weAreLeaver) {
if (fromYou) {
return renderString('GroupV2--member-remove--you--you', i18n);
2020-09-11 19:37:01 +00:00
}
if (from) {
2020-09-09 02:25:05 +00:00
return renderString('GroupV2--member-remove--you--other', i18n, [
renderContact(from),
]);
}
2020-09-11 19:37:01 +00:00
return renderString('GroupV2--member-remove--you--unknown', i18n);
2020-09-09 02:25:05 +00:00
}
2020-09-11 19:37:01 +00:00
if (fromYou) {
return renderString('GroupV2--member-remove--other--you', i18n, [
renderContact(conversationId),
]);
}
if (from && from === conversationId) {
return renderString('GroupV2--member-remove--other--self', i18n, [
renderContact(from),
]);
}
if (from) {
return renderString('GroupV2--member-remove--other--other', i18n, {
adminName: renderContact(from),
memberName: renderContact(conversationId),
});
}
return renderString('GroupV2--member-remove--other--unknown', i18n, [
renderContact(conversationId),
]);
2020-09-09 02:25:05 +00:00
} else if (detail.type === 'member-privilege') {
const { conversationId, newPrivilege } = detail;
const weAreMember = conversationId === ourConversationId;
if (newPrivilege === RoleEnum.ADMINISTRATOR) {
if (weAreMember) {
if (from) {
return renderString(
'GroupV2--member-privilege--promote--you--other',
i18n,
[renderContact(from)]
);
}
2020-09-11 19:37:01 +00:00
return renderString(
'GroupV2--member-privilege--promote--you--unknown',
i18n
);
}
if (fromYou) {
return renderString(
'GroupV2--member-privilege--promote--other--you',
i18n,
[renderContact(conversationId)]
);
2020-09-09 02:25:05 +00:00
}
2020-09-11 19:37:01 +00:00
if (from) {
return renderString(
'GroupV2--member-privilege--promote--other--other',
i18n,
{
adminName: renderContact(from),
memberName: renderContact(conversationId),
}
);
}
return renderString(
'GroupV2--member-privilege--promote--other--unknown',
i18n,
[renderContact(conversationId)]
);
}
if (newPrivilege === RoleEnum.DEFAULT) {
2020-09-09 02:25:05 +00:00
if (weAreMember) {
if (from) {
return renderString(
'GroupV2--member-privilege--demote--you--other',
i18n,
[renderContact(from)]
);
}
2020-09-11 19:37:01 +00:00
return renderString(
'GroupV2--member-privilege--demote--you--unknown',
i18n
);
2020-09-09 02:25:05 +00:00
}
2020-09-11 19:37:01 +00:00
if (fromYou) {
return renderString(
'GroupV2--member-privilege--demote--other--you',
i18n,
[renderContact(conversationId)]
);
}
if (from) {
return renderString(
'GroupV2--member-privilege--demote--other--other',
i18n,
{
adminName: renderContact(from),
memberName: renderContact(conversationId),
}
);
}
return renderString(
'GroupV2--member-privilege--demote--other--unknown',
i18n,
[renderContact(conversationId)]
2020-09-09 02:25:05 +00:00
);
}
2020-09-11 19:37:01 +00:00
throw new Error(
`member-privilege change type, privilege ${newPrivilege} is unknown`
);
2020-09-09 02:25:05 +00:00
} else if (detail.type === 'pending-add-one') {
const { conversationId } = detail;
const weAreInvited = conversationId === ourConversationId;
if (weAreInvited) {
if (from) {
return renderString('GroupV2--pending-add--one--you--other', i18n, [
renderContact(from),
]);
}
2020-09-11 19:37:01 +00:00
return renderString('GroupV2--pending-add--one--you--unknown', i18n);
}
if (fromYou) {
return renderString('GroupV2--pending-add--one--other--you', i18n, [
renderContact(conversationId),
]);
2020-09-09 02:25:05 +00:00
}
2020-09-11 19:37:01 +00:00
if (from) {
return renderString('GroupV2--pending-add--one--other--other', i18n, [
renderContact(from),
]);
}
return renderString('GroupV2--pending-add--one--other--unknown', i18n);
2020-09-09 02:25:05 +00:00
} else if (detail.type === 'pending-add-many') {
const { count } = detail;
if (fromYou) {
return renderString('GroupV2--pending-add--many--you', i18n, [
count.toString(),
]);
2020-09-11 19:37:01 +00:00
}
if (from) {
2020-09-09 02:25:05 +00:00
return renderString('GroupV2--pending-add--many--other', i18n, {
memberName: renderContact(from),
count: count.toString(),
});
}
2020-09-11 19:37:01 +00:00
return renderString('GroupV2--pending-add--many--unknown', i18n, [
count.toString(),
]);
2020-09-09 02:25:05 +00:00
} else if (detail.type === 'pending-remove-one') {
const { inviter, conversationId } = detail;
const weAreInviter = Boolean(inviter && inviter === ourConversationId);
2020-10-06 17:06:34 +00:00
const weAreInvited = conversationId === ourConversationId;
2020-09-09 02:25:05 +00:00
const sentByInvited = Boolean(from && from === conversationId);
2020-10-06 17:06:34 +00:00
const sentByInviter = Boolean(from && inviter && from === inviter);
2020-09-09 02:25:05 +00:00
if (weAreInviter) {
2020-10-06 17:06:34 +00:00
if (sentByInvited) {
2020-09-09 02:25:05 +00:00
return renderString('GroupV2--pending-remove--decline--you', i18n, [
renderContact(conversationId),
]);
2020-09-11 19:37:01 +00:00
}
if (fromYou) {
2020-09-09 02:25:05 +00:00
return renderString(
'GroupV2--pending-remove--revoke-invite-from-you--one--you',
i18n,
[renderContact(conversationId)]
);
2020-09-11 19:37:01 +00:00
}
if (from) {
2020-09-09 02:25:05 +00:00
return renderString(
'GroupV2--pending-remove--revoke-invite-from-you--one--other',
i18n,
{
adminName: renderContact(from),
inviteeName: renderContact(conversationId),
}
);
}
2020-09-11 19:37:01 +00:00
return renderString(
'GroupV2--pending-remove--revoke-invite-from-you--one--unknown',
i18n,
[renderContact(conversationId)]
);
}
if (sentByInvited) {
2020-10-06 17:06:34 +00:00
if (fromYou) {
return renderString('GroupV2--pending-remove--decline--from-you', i18n);
}
2020-09-09 02:25:05 +00:00
if (inviter) {
return renderString('GroupV2--pending-remove--decline--other', i18n, [
renderContact(inviter),
]);
}
2020-09-11 19:37:01 +00:00
return renderString('GroupV2--pending-remove--decline--unknown', i18n);
}
2020-10-06 17:06:34 +00:00
if (inviter && sentByInviter) {
if (weAreInvited) {
return renderString(
'GroupV2--pending-remove--revoke-own--to-you',
i18n,
[renderContact(inviter)]
);
}
return renderString(
'GroupV2--pending-remove--revoke-own--unknown',
i18n,
[renderContact(inviter)]
);
}
2020-09-11 19:37:01 +00:00
if (inviter) {
2020-09-09 02:25:05 +00:00
if (fromYou) {
return renderString(
'GroupV2--pending-remove--revoke-invite-from--one--you',
i18n,
[renderContact(inviter)]
);
2020-09-11 19:37:01 +00:00
}
if (from) {
2020-09-09 02:25:05 +00:00
return renderString(
'GroupV2--pending-remove--revoke-invite-from--one--other',
i18n,
{
adminName: renderContact(from),
memberName: renderContact(inviter),
}
);
}
2020-09-11 19:37:01 +00:00
return renderString(
'GroupV2--pending-remove--revoke-invite-from--one--unknown',
i18n,
[renderContact(inviter)]
);
}
if (fromYou) {
return renderString('GroupV2--pending-remove--revoke--one--you', i18n);
2020-09-09 02:25:05 +00:00
}
2020-09-11 19:37:01 +00:00
if (from) {
return renderString('GroupV2--pending-remove--revoke--one--other', i18n, [
renderContact(from),
]);
}
return renderString('GroupV2--pending-remove--revoke--one--unknown', i18n);
2020-09-09 02:25:05 +00:00
} else if (detail.type === 'pending-remove-many') {
const { count, inviter } = detail;
const weAreInviter = Boolean(inviter && inviter === ourConversationId);
if (weAreInviter) {
if (fromYou) {
return renderString(
'GroupV2--pending-remove--revoke-invite-from-you--many--you',
i18n,
[count.toString()]
);
2020-09-11 19:37:01 +00:00
}
if (from) {
2020-09-09 02:25:05 +00:00
return renderString(
'GroupV2--pending-remove--revoke-invite-from-you--many--other',
i18n,
{
adminName: renderContact(from),
count: count.toString(),
}
);
}
2020-09-11 19:37:01 +00:00
return renderString(
'GroupV2--pending-remove--revoke-invite-from-you--many--unknown',
i18n,
[count.toString()]
);
}
if (inviter) {
2020-09-09 02:25:05 +00:00
if (fromYou) {
return renderString(
'GroupV2--pending-remove--revoke-invite-from--many--you',
i18n,
{
count: count.toString(),
memberName: renderContact(inviter),
}
);
2020-09-11 19:37:01 +00:00
}
if (from) {
2020-09-09 02:25:05 +00:00
return renderString(
'GroupV2--pending-remove--revoke-invite-from--many--other',
i18n,
{
adminName: renderContact(from),
count: count.toString(),
memberName: renderContact(inviter),
}
);
}
2020-09-11 19:37:01 +00:00
return renderString(
'GroupV2--pending-remove--revoke-invite-from--many--unknown',
i18n,
{
count: count.toString(),
memberName: renderContact(inviter),
}
);
}
if (fromYou) {
return renderString('GroupV2--pending-remove--revoke--many--you', i18n, [
count.toString(),
]);
}
if (from) {
return renderString(
'GroupV2--pending-remove--revoke--many--other',
i18n,
{
memberName: renderContact(from),
count: count.toString(),
}
);
2020-09-09 02:25:05 +00:00
}
2020-09-11 19:37:01 +00:00
return renderString(
'GroupV2--pending-remove--revoke--many--unknown',
i18n,
[count.toString()]
);
2020-09-09 02:25:05 +00:00
} else {
throw missingCaseError(detail);
}
}