mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
72d2977e72
* Add text warning on startup page * Try to detect extensions with browser API * Setup messaging between different versions of extension * Cleanup * Cleanup * Simplify check for multiple instances running * Fix a doc string + use webextension-polyfill * Fix test * Mock webextension-polyfill * Mock correctly * Catch error and show warning in both extensions * Mock as promise * Address comments * Rename build ids * Run detection code only if Chrome * Add Firefox warnings * Cleanup imports * Update connection ids * Run detection code for Firefox * Add test * Add missing await * Update tests * Cleanup * Cleanup * Improve testing * Improve tests * Log errors from sendMessage * Cleanup Co-authored-by: Frederik Bolding <frederik.bolding@gmail.com>
102 lines
4.0 KiB
JavaScript
102 lines
4.0 KiB
JavaScript
import React, { Fragment, useContext } from 'react';
|
|
import { useHistory } from 'react-router-dom';
|
|
import PropTypes from 'prop-types';
|
|
import { I18nContext } from '../../../../contexts/i18n';
|
|
import Button from '../../../ui/button';
|
|
|
|
function lineBreaksToBr(source) {
|
|
return source.split('\n').map((value, index) => {
|
|
return (
|
|
<Fragment key={index}>
|
|
{value}
|
|
<br />
|
|
</Fragment>
|
|
);
|
|
});
|
|
}
|
|
|
|
const METAMASK_LOGO = lineBreaksToBr(`MMm*mmMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMmm*mMM
|
|
MM*./***mMMMMMMMMMMMMMMMMMMMMMMMMMMm***/.*MM
|
|
MM/...///*mMMMMMMMMMMMMMMMMMMMMMMm*///.../MM
|
|
Mm.....//../*mMMMMMMMMMMMMMMMMm*/..//.....mM
|
|
M*....../*....*mMMMMMMMMMMMMm*....*/......*M
|
|
M/........*.....*//////////*...../......../M
|
|
m..........*/...//........//.../*..........m
|
|
M/..........//.../......../...//........../M
|
|
M/.........../*/./.......//./*/.........../M
|
|
M*.............////......////.............*M
|
|
Mm...............**......**...............mM
|
|
Mm/...............*/..../*.............../mM
|
|
MM/............../*/..../*/............../MM
|
|
Mm..............//./...././/..............mM
|
|
MM*............*/../..../../*............*MM
|
|
MM/........../*..../..../....*/........../MM
|
|
MMm.........//...../..../.....//.........mMM
|
|
MMm......//**....../..../......**//......mMM
|
|
MMM/..////.*......./..../......././///../MMM
|
|
MMMm*//..../......./..../......./....//*mMMM
|
|
MMMm......*////////*....*////////*......mMMM
|
|
MMM*......*////////*....*////////*......*MMM
|
|
MMM/....../*......./..../.......*/....../MMM
|
|
MMm........**/./m*./..../.**/..**........mMM
|
|
MM*........//*mMMM///..///mMMm*//........*MM
|
|
MM/........././*mM*//..//*Mm*/./........./MM
|
|
Mm..........//.../**/../**/...//..........mM
|
|
M*...........*..../*/../*/..../...........*M
|
|
M*///////////*/.../m/../m/.../*///////////*M
|
|
M*.........../*/...m/../m.../*/...........*M
|
|
Mm.........../..//.*....*./*../...........mM
|
|
MM/........../...//******//.../........../MM
|
|
MM*........../....*MMMMMM*..../..........*MM
|
|
MMm........../....*MMMMMM*..../..........mMM
|
|
MMm/........//....*MMMMMM*....//......../mMM
|
|
MMM/....../*mm*...*mmmmmm*...*mm*/....../MMM
|
|
MMM*../*mmMMMMMm///......//*mMMMMMmm*/..*MMM
|
|
MMMm*mMMMMMMMMMMm**......**mMMMMMMMMMMm*mMMM
|
|
MMMMMMMMMMMMMMMMMm/....../mMMMMMMMMMMMMMMMMM
|
|
MMMMMMMMMMMMMMMMMMmmmmmmmmMMMMMMMMMMMMMMMMMM`);
|
|
|
|
/* eslint-disable no-irregular-whitespace */
|
|
const EXPERIMENTAL_AREA = lineBreaksToBr(`█▄█ █▀█ █░█ ▀ █▀█ █▀▀ █▀▀ █▄░█ ▀█▀ █▀▀ █▀█ █ █▄░█ █▀▀ ▄▀█ █▄░█
|
|
░█░ █▄█ █▄█ ░ █▀▄ ██▄ ██▄ █░▀█ ░█░ ██▄ █▀▄ █ █░▀█ █▄█ █▀█ █░▀█
|
|
|
|
█▀▀ ▀▄▀ █▀█ █▀▀ █▀█ █ █▀▄▀█ █▀▀ █▄░█ ▀█▀ ▄▀█ █░░ ▄▀█ █▀█ █▀▀ ▄▀█
|
|
██▄ █░█ █▀▀ ██▄ █▀▄ █ █░▀░█ ██▄ █░▀█ ░█░ █▀█ █▄▄ █▀█ █▀▄ ██▄ █▀█`);
|
|
/* eslint-enable no-irregular-whitespace */
|
|
|
|
export default function ExperimentalArea({ redirectTo }) {
|
|
const t = useContext(I18nContext);
|
|
const history = useHistory();
|
|
|
|
const onClick = () => {
|
|
history.push(redirectTo);
|
|
};
|
|
|
|
return (
|
|
<div className="experimental-area">
|
|
<div className="logo">{METAMASK_LOGO}</div>
|
|
<div className="experimental-text">{EXPERIMENTAL_AREA}</div>
|
|
<div className="text">
|
|
<p>
|
|
{t('flaskWelcomeWarning1', [
|
|
<b key="doNotUse">{t('flaskWelcomeUninstall')}</b>,
|
|
])}
|
|
</p>
|
|
<br />
|
|
<p>{t('flaskWelcomeWarning2')}</p>
|
|
<br />
|
|
<p>{t('flaskWelcomeWarning3')}</p>
|
|
<br />
|
|
<p>{t('flaskWelcomeWarning4')}</p>
|
|
</div>
|
|
<Button type="primary" onClick={onClick}>
|
|
{t('flaskWelcomeWarningAcceptButton')}
|
|
</Button>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
ExperimentalArea.propTypes = {
|
|
redirectTo: PropTypes.string,
|
|
};
|