|  |  |  | import React from 'react'; | 
					
						
							|  |  |  | import { useDispatch, useSelector } from 'react-redux'; | 
					
						
							|  |  |  | // tslint:disable-next-line: no-submodule-imports
 | 
					
						
							|  |  |  | import useUpdate from 'react-use/lib/useUpdate'; | 
					
						
							|  |  |  | import { SettingsKey } from '../../../data/settings-key'; | 
					
						
							|  |  |  | import { CallManager } from '../../../session/utils'; | 
					
						
							|  |  |  | import { sessionPassword, updateConfirmModal } from '../../../state/ducks/modalDialog'; | 
					
						
							|  |  |  | import { SectionType, setOverlayMode, showLeftPaneSection } from '../../../state/ducks/section'; | 
					
						
							|  |  |  | import { toggleMessageRequests } from '../../../state/ducks/userConfig'; | 
					
						
							|  |  |  | import { getHideMessageRequestBanner } from '../../../state/selectors/userConfig'; | 
					
						
							|  |  |  | import { SessionButtonColor } from '../../basic/SessionButton'; | 
					
						
							|  |  |  | import { PasswordAction } from '../../dialog/SessionPasswordDialog'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import { SessionSettingButtonItem, SessionToggleWithDescription } from '../SessionSettingListItem'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const toggleCallMediaPermissions = async (triggerUIUpdate: () => void) => { | 
					
						
							|  |  |  |   const currentValue = window.getCallMediaPermissions(); | 
					
						
							|  |  |  |   if (!currentValue) { | 
					
						
							|  |  |  |     window.inboxStore?.dispatch( | 
					
						
							|  |  |  |       updateConfirmModal({ | 
					
						
							|  |  |  |         message: window.i18n('callMediaPermissionsDialogContent'), | 
					
						
							|  |  |  |         okTheme: SessionButtonColor.Danger, | 
					
						
							|  |  |  |         onClickOk: async () => { | 
					
						
							|  |  |  |           await window.toggleCallMediaPermissionsTo(true); | 
					
						
							|  |  |  |           triggerUIUpdate(); | 
					
						
							|  |  |  |           CallManager.onTurnedOnCallMediaPermissions(); | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         onClickCancel: async () => { | 
					
						
							|  |  |  |           await window.toggleCallMediaPermissionsTo(false); | 
					
						
							|  |  |  |           triggerUIUpdate(); | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     await window.toggleCallMediaPermissionsTo(false); | 
					
						
							|  |  |  |     triggerUIUpdate(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function displayPasswordModal( | 
					
						
							|  |  |  |   passwordAction: PasswordAction, | 
					
						
							|  |  |  |   onPasswordUpdated: (action: string) => void | 
					
						
							|  |  |  | ) { | 
					
						
							|  |  |  |   window.inboxStore?.dispatch( | 
					
						
							|  |  |  |     sessionPassword({ | 
					
						
							|  |  |  |       passwordAction, | 
					
						
							|  |  |  |       onOk: () => { | 
					
						
							|  |  |  |         onPasswordUpdated(passwordAction); | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const SettingsCategoryPrivacy = (props: { | 
					
						
							|  |  |  |   hasPassword: boolean | null; | 
					
						
							|  |  |  |   onPasswordUpdated: (action: string) => void; | 
					
						
							|  |  |  | }) => { | 
					
						
							|  |  |  |   const forceUpdate = useUpdate(); | 
					
						
							|  |  |  |   const dispatch = useDispatch(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (props.hasPassword !== null) { | 
					
						
							|  |  |  |     return ( | 
					
						
							|  |  |  |       <> | 
					
						
							|  |  |  |         <SessionToggleWithDescription | 
					
						
							|  |  |  |           onClickToggle={async () => { | 
					
						
							|  |  |  |             await window.toggleMediaPermissions(); | 
					
						
							|  |  |  |             forceUpdate(); | 
					
						
							|  |  |  |           }} | 
					
						
							|  |  |  |           title={window.i18n('mediaPermissionsTitle')} | 
					
						
							|  |  |  |           description={window.i18n('mediaPermissionsDescription')} | 
					
						
							|  |  |  |           active={Boolean(window.getSettingValue('media-permissions'))} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |         {window.sessionFeatureFlags.useCallMessage && ( | 
					
						
							|  |  |  |           <SessionToggleWithDescription | 
					
						
							|  |  |  |             onClickToggle={async () => { | 
					
						
							|  |  |  |               await toggleCallMediaPermissions(forceUpdate); | 
					
						
							|  |  |  |               forceUpdate(); | 
					
						
							|  |  |  |             }} | 
					
						
							|  |  |  |             title={window.i18n('callMediaPermissionsTitle')} | 
					
						
							|  |  |  |             description={window.i18n('callMediaPermissionsDescription')} | 
					
						
							|  |  |  |             active={Boolean(window.getCallMediaPermissions())} | 
					
						
							|  |  |  |           /> | 
					
						
							|  |  |  |         )} | 
					
						
							|  |  |  |         <SessionToggleWithDescription | 
					
						
							|  |  |  |           onClickToggle={() => { | 
					
						
							|  |  |  |             const old = Boolean(window.getSettingValue(SettingsKey.settingsReadReceipt)); | 
					
						
							|  |  |  |             window.setSettingValue(SettingsKey.settingsReadReceipt, !old); | 
					
						
							|  |  |  |             forceUpdate(); | 
					
						
							|  |  |  |           }} | 
					
						
							|  |  |  |           title={window.i18n('readReceiptSettingTitle')} | 
					
						
							|  |  |  |           description={window.i18n('readReceiptSettingDescription')} | 
					
						
							|  |  |  |           active={window.getSettingValue(SettingsKey.settingsReadReceipt)} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |         <SessionToggleWithDescription | 
					
						
							|  |  |  |           onClickToggle={() => { | 
					
						
							|  |  |  |             const old = Boolean(window.getSettingValue(SettingsKey.settingsTypingIndicator)); | 
					
						
							|  |  |  |             window.setSettingValue(SettingsKey.settingsTypingIndicator, !old); | 
					
						
							|  |  |  |             forceUpdate(); | 
					
						
							|  |  |  |           }} | 
					
						
							|  |  |  |           title={window.i18n('typingIndicatorsSettingTitle')} | 
					
						
							|  |  |  |           description={window.i18n('typingIndicatorsSettingDescription')} | 
					
						
							|  |  |  |           active={Boolean(window.getSettingValue(SettingsKey.settingsTypingIndicator))} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |         <SessionToggleWithDescription | 
					
						
							|  |  |  |           onClickToggle={() => { | 
					
						
							|  |  |  |             const old = Boolean(window.getSettingValue(SettingsKey.settingsAutoUpdate)); | 
					
						
							|  |  |  |             window.setSettingValue(SettingsKey.settingsAutoUpdate, !old); | 
					
						
							|  |  |  |             forceUpdate(); | 
					
						
							|  |  |  |           }} | 
					
						
							|  |  |  |           title={window.i18n('autoUpdateSettingTitle')} | 
					
						
							|  |  |  |           description={window.i18n('autoUpdateSettingDescription')} | 
					
						
							|  |  |  |           active={Boolean(window.getSettingValue(SettingsKey.settingsAutoUpdate))} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |         <SessionToggleWithDescription | 
					
						
							|  |  |  |           onClickToggle={() => { | 
					
						
							|  |  |  |             dispatch(toggleMessageRequests()); | 
					
						
							|  |  |  |           }} | 
					
						
							|  |  |  |           title={window.i18n('hideRequestBanner')} | 
					
						
							|  |  |  |           description={window.i18n('hideRequestBannerDescription')} | 
					
						
							|  |  |  |           active={useSelector(getHideMessageRequestBanner)} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |         <SessionSettingButtonItem | 
					
						
							|  |  |  |           title={window.i18n('openMessageRequestInbox')} | 
					
						
							|  |  |  |           description={window.i18n('openMessageRequestInboxDescription')} | 
					
						
							|  |  |  |           onClick={() => { | 
					
						
							|  |  |  |             dispatch(showLeftPaneSection(SectionType.Message)); | 
					
						
							|  |  |  |             dispatch(setOverlayMode('message-requests')); | 
					
						
							|  |  |  |           }} | 
					
						
							|  |  |  |           buttonColor={SessionButtonColor.Primary} | 
					
						
							|  |  |  |           buttonText={window.i18n('openMessageRequestInbox')} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |         {!props.hasPassword && ( | 
					
						
							|  |  |  |           <SessionSettingButtonItem | 
					
						
							|  |  |  |             title={window.i18n('setAccountPasswordTitle')} | 
					
						
							|  |  |  |             description={window.i18n('setAccountPasswordDescription')} | 
					
						
							|  |  |  |             onClick={() => { | 
					
						
							|  |  |  |               displayPasswordModal('set', props.onPasswordUpdated); | 
					
						
							|  |  |  |             }} | 
					
						
							|  |  |  |             buttonColor={SessionButtonColor.Primary} | 
					
						
							|  |  |  |             buttonText={window.i18n('setPassword')} | 
					
						
							|  |  |  |           /> | 
					
						
							|  |  |  |         )} | 
					
						
							|  |  |  |         {props.hasPassword && ( | 
					
						
							|  |  |  |           <SessionSettingButtonItem | 
					
						
							|  |  |  |             title={window.i18n('changeAccountPasswordTitle')} | 
					
						
							|  |  |  |             description={window.i18n('changeAccountPasswordDescription')} | 
					
						
							|  |  |  |             onClick={() => { | 
					
						
							|  |  |  |               displayPasswordModal('change', props.onPasswordUpdated); | 
					
						
							|  |  |  |             }} | 
					
						
							|  |  |  |             buttonColor={SessionButtonColor.Primary} | 
					
						
							|  |  |  |             buttonText={window.i18n('changePassword')} | 
					
						
							|  |  |  |           /> | 
					
						
							|  |  |  |         )} | 
					
						
							|  |  |  |         {props.hasPassword && ( | 
					
						
							|  |  |  |           <SessionSettingButtonItem | 
					
						
							|  |  |  |             title={window.i18n('removeAccountPasswordTitle')} | 
					
						
							|  |  |  |             description={window.i18n('removeAccountPasswordDescription')} | 
					
						
							|  |  |  |             onClick={() => { | 
					
						
							|  |  |  |               displayPasswordModal('remove', props.onPasswordUpdated); | 
					
						
							|  |  |  |             }} | 
					
						
							|  |  |  |             buttonColor={SessionButtonColor.Danger} | 
					
						
							|  |  |  |             buttonText={window.i18n('removePassword')} | 
					
						
							|  |  |  |           /> | 
					
						
							|  |  |  |         )} | 
					
						
							|  |  |  |       </> | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return null; | 
					
						
							|  |  |  | }; |