Permissions popup context iso
This commit is contained in:
parent
f3715411c6
commit
7b5faa1cc1
49 changed files with 562 additions and 506 deletions
68
ts/windows/permissions/preload.ts
Normal file
68
ts/windows/permissions/preload.ts
Normal file
|
@ -0,0 +1,68 @@
|
|||
// Copyright 2021 Signal Messenger, LLC
|
||||
// SPDX-License-Identifier: AGPL-3.0-only
|
||||
|
||||
import React from 'react';
|
||||
import ReactDOM from 'react-dom';
|
||||
import { contextBridge, ipcRenderer } from 'electron';
|
||||
|
||||
// It is important to call this as early as possible
|
||||
import '../context';
|
||||
|
||||
import { createSetting } from '../../util/preload';
|
||||
import { SignalWindow } from '../configure';
|
||||
import { PermissionsPopup } from '../../components/PermissionsPopup';
|
||||
import { initialize as initializeLogging } from '../../logging/set_up_renderer_logging';
|
||||
|
||||
const mediaCameraPermissions = createSetting('mediaCameraPermissions', {
|
||||
getter: false,
|
||||
});
|
||||
const mediaPermissions = createSetting('mediaPermissions', {
|
||||
getter: false,
|
||||
});
|
||||
|
||||
contextBridge.exposeInMainWorld(
|
||||
'nativeThemeListener',
|
||||
window.SignalContext.nativeThemeListener
|
||||
);
|
||||
|
||||
contextBridge.exposeInMainWorld('SignalWindow', {
|
||||
...SignalWindow,
|
||||
renderWindow: () => {
|
||||
const forCalling = SignalWindow.config.forCalling === 'true';
|
||||
const forCamera = SignalWindow.config.forCamera === 'true';
|
||||
|
||||
let message;
|
||||
if (forCalling) {
|
||||
if (forCamera) {
|
||||
message = SignalWindow.i18n('videoCallingPermissionNeeded');
|
||||
} else {
|
||||
message = SignalWindow.i18n('audioCallingPermissionNeeded');
|
||||
}
|
||||
} else {
|
||||
message = SignalWindow.i18n('audioPermissionNeeded');
|
||||
}
|
||||
|
||||
function onClose() {
|
||||
ipcRenderer.send('close-permissions-popup');
|
||||
}
|
||||
|
||||
ReactDOM.render(
|
||||
React.createElement(PermissionsPopup, {
|
||||
i18n: SignalWindow.i18n,
|
||||
message,
|
||||
onAccept: () => {
|
||||
if (!forCamera) {
|
||||
mediaPermissions.setValue(true);
|
||||
} else {
|
||||
mediaCameraPermissions.setValue(true);
|
||||
}
|
||||
onClose();
|
||||
},
|
||||
onClose,
|
||||
}),
|
||||
document.getElementById('app')
|
||||
);
|
||||
},
|
||||
});
|
||||
|
||||
initializeLogging();
|
Loading…
Add table
Add a link
Reference in a new issue