You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
74 lines
2.2 KiB
TypeScript
74 lines
2.2 KiB
TypeScript
import React from 'react';
|
|
|
|
import { ContactType } from './session/SessionMemberListItem';
|
|
import { ToastUtils } from '../session/utils';
|
|
import { createClosedGroup as createClosedGroupV2 } from '../receiver/closedGroups';
|
|
import { VALIDATION } from '../session/constants';
|
|
|
|
export class MessageView extends React.Component {
|
|
public render() {
|
|
return (
|
|
<div className="conversation placeholder">
|
|
<div className="conversation-header" />
|
|
<div className="container">
|
|
<div className="content session-full-logo">
|
|
<img
|
|
src="images/session/brand.svg"
|
|
className="session-brand-logo"
|
|
alt="full-brand-logo"
|
|
/>
|
|
<img
|
|
src="images/session/session-text.svg"
|
|
className="session-text-logo"
|
|
alt="full-brand-logo"
|
|
/>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
}
|
|
|
|
// /////////////////////////////////////
|
|
// //////////// Management /////////////
|
|
// /////////////////////////////////////
|
|
|
|
/**
|
|
* Returns true if the group was indead created
|
|
*/
|
|
async function createClosedGroup(
|
|
groupName: string,
|
|
groupMembers: Array<ContactType>
|
|
): Promise<boolean> {
|
|
// Validate groupName and groupMembers length
|
|
if (groupName.length === 0) {
|
|
ToastUtils.pushToastError('invalidGroupName', window.i18n('invalidGroupNameTooShort'));
|
|
|
|
return false;
|
|
} else if (groupName.length > VALIDATION.MAX_GROUP_NAME_LENGTH) {
|
|
ToastUtils.pushToastError('invalidGroupName', window.i18n('invalidGroupNameTooLong'));
|
|
return false;
|
|
}
|
|
|
|
// >= because we add ourself as a member AFTER this. so a 10 group is already invalid as it will be 11 with ourself
|
|
// the same is valid with groups count < 1
|
|
|
|
if (groupMembers.length < 1) {
|
|
ToastUtils.pushToastError('pickClosedGroupMember', window.i18n('pickClosedGroupMember'));
|
|
return false;
|
|
} else if (groupMembers.length >= VALIDATION.CLOSED_GROUP_SIZE_LIMIT) {
|
|
ToastUtils.pushToastError('closedGroupMaxSize', window.i18n('closedGroupMaxSize'));
|
|
return false;
|
|
}
|
|
|
|
const groupMemberIds = groupMembers.map(m => m.id);
|
|
|
|
await createClosedGroupV2(groupName, groupMemberIds);
|
|
|
|
return true;
|
|
}
|
|
|
|
export const MainViewController = {
|
|
createClosedGroup,
|
|
};
|