Secure your code as it's written. Use Snyk Code to scan source code in minutes - no build needed - and fix issues immediately.
import { AccountContext, ActionContext, AuthorizeContext, MediaContext, SigningContext } from '../components/contexts';
import { subscribeAccounts, subscribeAuthorize, subscribeSigning } from '../messaging';
import Accounts from './Accounts';
import Authorize from './Authorize';
import CreateAccount from './CreateAccount';
import Export from './Export';
import Forget from './Forget';
import ImportQr from './ImportQr';
import ImportSeed from './ImportSeed';
import Settings from './Settings';
import Signing from './Signing';
import Welcome from './Welcome';
// load the ui settings, actually only used for address prefix atm
// probably overkill (however can replace once we have actual others)
const { prefix } = settings.get();
// FIXME Duplicated in Settings, horrible...
setSS58Format(prefix === -1 ? 42 : prefix);
// Request permission for video, based on access we can hide/show import
async function requestMediaAccess (cameraOn: boolean): Promise {
if (!cameraOn) {
return false;
}
try {
await navigator.mediaDevices.getUserMedia({ video: true });
return true;
} catch (error) {
console.error('Permission for video declined', error.message);
function General ({ className, isModalContent, onClose, t }: Props): React.ReactElement {
// tri-state: null = nothing changed, false = no reload, true = reload required
const [changed, setChanged] = useState(null);
const [settings, setSettings] = useState(uiSettings.get());
useEffect((): void => {
const prev = uiSettings.get();
const hasChanges = Object.entries(settings).some(([key, value]): boolean => (prev as any)[key] !== value);
const needsReload = prev.apiUrl !== settings.apiUrl || prev.prefix !== settings.prefix;
setChanged(
hasChanges
? needsReload
: null
);
}, [settings]);
const _handleChange = (key: keyof SettingsStruct) => (value: T): void => {
setSettings({ ...settings, [key]: value });
};
useEffect((): void => {
const prev = uiSettings.get();
const hasChanges = Object.entries(settings).some(([key, value]): boolean => (prev as any)[key] !== value);
const needsReload = prev.apiUrl !== settings.apiUrl || prev.prefix !== settings.prefix;
setChanged(
hasChanges
? needsReload
: null
);
}, [settings]);
export default function Popup (): React.ReactElement<{}> {
const [accounts, setAccounts] = useState(null);
const [authRequests, setAuthRequests] = useState(null);
const [cameraOn, setCameraOn] = useState(settings.get().camera === 'on');
const [mediaAllowed, setMediaAllowed] = useState(false);
const [signRequests, setSignRequests] = useState(null);
const [isWelcomeDone, setWelcomeDone] = useState(false);
const _onAction = (to?: string): void => {
setWelcomeDone(window.localStorage.getItem('welcome_read') === 'ok');
if (to) {
window.location.hash = to;
}
};
useEffect((): void => {
Promise.all([
subscribeAccounts(setAccounts),
subscribeAuthorize(setAuthRequests),