tweb/src/components/sidebarLeft/tabs/newGroup.ts
morethanwords ca1213c32f Support noforwards
Fix chat date blinking
Fix displaying sent messages to new dialog
Scroll to date bubble if message is bigger than viewport
Fix releasing keyboard by inline helper
Fix clearing self user
Fix displaying sent public poll
Update contacts counter in dialogs placeholder
Improve multiselect animation
Disable lottie icon animations if they're disabled
Fix changing mtproto transport during authorization
2022-01-08 16:52:14 +04:00

114 lines
3.5 KiB
TypeScript

/*
* https://github.com/morethanwords/tweb
* Copyright (C) 2019-2021 Eduard Kuzmenko
* https://github.com/morethanwords/tweb/blob/master/LICENSE
*/
import appSidebarLeft, { SettingSection } from "..";
import { InputFile } from "../../../layer";
import appChatsManager from "../../../lib/appManagers/appChatsManager";
import appDialogsManager from "../../../lib/appManagers/appDialogsManager";
import appUsersManager from "../../../lib/appManagers/appUsersManager";
import { SearchGroup } from "../../appSearch";
import InputField from "../../inputField";
import { SliderSuperTab } from "../../slider";
import AvatarEdit from "../../avatarEdit";
import { i18n } from "../../../lib/langPack";
import ButtonCorner from "../../buttonCorner";
export default class AppNewGroupTab extends SliderSuperTab {
private avatarEdit: AvatarEdit;
private uploadAvatar: () => Promise<InputFile> = null;
private peerIds: PeerId[];
private nextBtn: HTMLButtonElement;
private groupNameInputField: InputField;
list: HTMLUListElement;
protected init() {
this.container.classList.add('new-group-container');
this.setTitle('NewGroup');
this.avatarEdit = new AvatarEdit((_upload) => {
this.uploadAvatar = _upload;
});
const section = new SettingSection({});
const inputWrapper = document.createElement('div');
inputWrapper.classList.add('input-wrapper');
this.groupNameInputField = new InputField({
label: 'CreateGroup.NameHolder',
maxLength: 128
});
inputWrapper.append(this.groupNameInputField.container);
this.groupNameInputField.input.addEventListener('input', () => {
const value = this.groupNameInputField.value;
this.nextBtn.classList.toggle('is-visible', !!value.length && !this.groupNameInputField.input.classList.contains('error'));
});
this.nextBtn = ButtonCorner({icon: 'arrow_next'});
this.nextBtn.addEventListener('click', () => {
const title = this.groupNameInputField.value;
this.nextBtn.disabled = true;
appChatsManager.createChat(title, this.peerIds.map(peerId => peerId.toUserId())).then((chatId) => {
if(this.uploadAvatar) {
this.uploadAvatar().then((inputFile) => {
appChatsManager.editPhoto(chatId, inputFile);
});
}
appSidebarLeft.removeTabFromHistory(this);
appSidebarLeft.selectTab(0);
});
});
const chatsSection = new SettingSection({
name: 'Members',
nameArgs: [this.peerIds.length]
});
const list = this.list = appDialogsManager.createChatList({
new: true
});
chatsSection.content.append(list);
section.content.append(this.avatarEdit.container, inputWrapper);
this.content.append(this.nextBtn);
this.scrollable.append(section.container, chatsSection.container);
}
public onCloseAfterTimeout() {
this.avatarEdit.clear();
this.uploadAvatar = null;
this.groupNameInputField.value = '';
this.nextBtn.disabled = false;
}
public open(peerIds: PeerId[]) {
this.peerIds = peerIds;
const result = super.open();
result.then(() => {
this.peerIds.forEach(userId => {
let {dom} = appDialogsManager.addDialogNew({
dialog: userId,
container: this.list,
drawStatus: false,
rippleEnabled: false,
avatarSize: 48
});
dom.lastMessageSpan.append(appUsersManager.getUserStatusString(userId));
});
});
return result;
}
}