tweb/src/components/sidebarRight/tabs/editContact.ts

221 lines
7.8 KiB
TypeScript

/*
* https://github.com/morethanwords/tweb
* Copyright (C) 2019-2021 Eduard Kuzmenko
* https://github.com/morethanwords/tweb/blob/master/LICENSE
*/
import {SliderSuperTab} from '../../slider'
import InputField from '../../inputField';
import EditPeer from '../../editPeer';
import Row, {CreateRowFromCheckboxField} from '../../row';
import CheckboxField from '../../checkboxField';
import Button from '../../button';
import PeerTitle from '../../peerTitle';
import rootScope from '../../../lib/rootScope';
import PopupPeer from '../../popups/peer';
import PopupElement, {addCancelButton} from '../../popups';
import {i18n} from '../../../lib/langPack';
import {attachClickEvent} from '../../../helpers/dom/clickEvent';
import toggleDisability from '../../../helpers/dom/toggleDisability';
import getPeerId from '../../../lib/appManagers/utils/peers/getPeerId';
import formatUserPhone from '../../wrappers/formatUserPhone';
import SettingSection from '../../settingSection';
import wrapPeerTitle from '../../wrappers/peerTitle';
export default class AppEditContactTab extends SliderSuperTab {
private nameInputField: InputField;
private lastNameInputField: InputField;
private editPeer: EditPeer;
private sharePhoneCheckboxField: CheckboxField;
public peerId: PeerId;
public async init() {
const {peerId} = this;
const userId = peerId.toUserId();
this.container.classList.add('edit-peer-container', 'edit-contact-container');
const [isContact, privacy] = await Promise.all([
this.managers.appUsersManager.isContact(userId),
this.managers.appPrivacyManager.getPrivacy('inputPrivacyKeyPhoneNumber')
]);
const isNew = !isContact;
this.setTitle(isNew ? 'AddContactTitle' : 'Edit');
{
const section = new SettingSection({noDelimiter: true});
const inputFields: InputField[] = [];
const inputWrapper = document.createElement('div');
inputWrapper.classList.add('input-wrapper');
this.nameInputField = new InputField({
label: 'FirstName',
name: 'contact-name',
maxLength: 70,
required: true
});
this.lastNameInputField = new InputField({
label: 'LastName',
name: 'contact-lastname',
maxLength: 70
});
if(userId) {
const user = await this.managers.appUsersManager.getUser(userId);
if(isNew) {
this.nameInputField.setDraftValue(user.first_name);
this.lastNameInputField.setDraftValue(user.last_name);
} else {
this.nameInputField.setOriginalValue(user.first_name);
this.lastNameInputField.setOriginalValue(user.last_name);
}
}
inputWrapper.append(this.nameInputField.container, this.lastNameInputField.container);
inputFields.push(this.nameInputField, this.lastNameInputField);
this.editPeer = new EditPeer({
peerId: peerId,
inputFields,
listenerSetter: this.listenerSetter,
doNotEditAvatar: true
});
this.content.append(this.editPeer.nextBtn);
if(peerId) {
const div = document.createElement('div');
div.classList.add('avatar-edit');
div.append(this.editPeer.avatarElem);
const notificationsCheckboxField = new CheckboxField({
text: 'Notifications'
});
notificationsCheckboxField.input.addEventListener('change', (e) => {
if(!e.isTrusted) {
return;
}
this.managers.appMessagesManager.togglePeerMute({peerId});
});
this.listenerSetter.add(rootScope)('notify_settings', async(update) => {
if(update.peer._ !== 'notifyPeer') return;
const peerId = getPeerId(update.peer.peer);
if(peerId === peerId) {
const enabled = !(await this.managers.appNotificationsManager.isMuted(update.notify_settings));
if(enabled !== notificationsCheckboxField.checked) {
notificationsCheckboxField.checked = enabled;
}
}
});
const profileNameDiv = document.createElement('div');
profileNameDiv.classList.add('profile-name');
profileNameDiv.append(new PeerTitle({
peerId: peerId
}).element);
// profileNameDiv.innerHTML = 'Karen Stanford';
const profileSubtitleDiv = document.createElement('div');
profileSubtitleDiv.classList.add('profile-subtitle');
profileSubtitleDiv.append(i18n('EditContact.OriginalName'));
section.content.append(div, profileNameDiv, profileSubtitleDiv, inputWrapper);
if(!isNew) {
const notificationsRow = new Row({
checkboxField: notificationsCheckboxField,
withCheckboxSubtitle: true,
listenerSetter: this.listenerSetter
});
const enabled = !(await this.managers.appNotificationsManager.isPeerLocalMuted({peerId, respectType: false}));
notificationsCheckboxField.checked = enabled;
section.content.append(notificationsRow.container);
} else {
const user = await this.managers.appUsersManager.getUser(userId);
const phoneRow = new Row({
icon: 'phone',
titleLangKey: user.phone ? undefined : 'MobileHidden',
title: user.phone ? formatUserPhone(user.phone) : undefined,
subtitleLangKey: user.phone ? 'Phone' : 'MobileHiddenExceptionInfo',
subtitleLangArgs: user.phone ? undefined : [new PeerTitle({peerId: peerId}).element]
});
section.content.append(phoneRow.container);
}
} else {
section.content.append(inputWrapper);
}
this.scrollable.append(section.container);
}
if(!isNew) {
const section = new SettingSection();
const btnDelete = Button('btn-primary btn-transparent danger', {icon: 'delete', text: 'PeerInfo.DeleteContact'});
attachClickEvent(btnDelete, () => {
PopupElement.createPopup(PopupPeer, 'popup-delete-contact', {
peerId: peerId,
titleLangKey: 'DeleteContact',
descriptionLangKey: 'AreYouSureDeleteContact',
buttons: addCancelButton([{
langKey: 'Delete',
callback: () => {
const toggle = toggleDisability([btnDelete], true);
this.managers.appUsersManager.deleteContacts([userId]).then(() => {
this.close();
}, () => {
toggle();
});
},
isDanger: true
}])
}).show();
}, {listenerSetter: this.listenerSetter});
section.content.append(btnDelete);
this.scrollable.append(section.container);
} else if(
privacy.some((privacyRule) => privacyRule._ === 'privacyValueDisallowAll') &&
!privacy.some((privacyRule) => privacyRule._ === 'privacyValueAllowUsers' && privacyRule.users.includes(userId))
) {
const section = new SettingSection({
caption: 'NewContact.Exception.ShareMyPhoneNumber.Desc',
captionArgs: [await wrapPeerTitle({peerId: this.peerId})]
});
const checkboxField = this.sharePhoneCheckboxField = new CheckboxField({
text: 'NewContact.Exception.ShareMyPhoneNumber',
checked: true
});
const row = CreateRowFromCheckboxField(checkboxField);
section.content.append(row.container);
this.scrollable.append(section.container);
}
attachClickEvent(this.editPeer.nextBtn, async() => {
this.editPeer.nextBtn.disabled = true;
this.managers.appUsersManager.addContact(
userId,
this.nameInputField.value,
this.lastNameInputField.value,
(await this.managers.appUsersManager.getUser(userId)).phone,
this.sharePhoneCheckboxField?.checked
).finally(() => {
this.editPeer.nextBtn.removeAttribute('disabled');
this.close();
});
}, {listenerSetter: this.listenerSetter});
}
}