mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
126 lines
3.3 KiB
JavaScript
126 lines
3.3 KiB
JavaScript
import React, { PureComponent } from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import classnames from 'classnames';
|
|
import Box from '../box/box';
|
|
import { BackgroundColor } from '../../../helpers/constants/design-system';
|
|
import MetaFoxHorizontalLogo from './horizontal-logo';
|
|
|
|
export default class MetaFoxLogo extends PureComponent {
|
|
static propTypes = {
|
|
onClick: PropTypes.func,
|
|
unsetIconHeight: PropTypes.bool,
|
|
isOnboarding: PropTypes.bool,
|
|
///: BEGIN:ONLY_INCLUDE_IN(build-flask)
|
|
src: PropTypes.string,
|
|
///: END:ONLY_INCLUDE_IN
|
|
///: BEGIN:ONLY_INCLUDE_IN(build-mmi)
|
|
custodyImgSrc: PropTypes.string,
|
|
isUnlocked: PropTypes.bool,
|
|
///: END:ONLY_INCLUDE_IN
|
|
};
|
|
|
|
static defaultProps = {
|
|
onClick: undefined,
|
|
};
|
|
|
|
///: BEGIN:ONLY_INCLUDE_IN(build-mmi)
|
|
renderCustodyIcon(iconProps, custodyImgSrc) {
|
|
return (
|
|
<img
|
|
{...iconProps}
|
|
src={custodyImgSrc}
|
|
className={classnames(
|
|
'app-header__custody-logo',
|
|
'app-header__custody-logo--icon',
|
|
)}
|
|
alt=""
|
|
/>
|
|
);
|
|
}
|
|
///: END:ONLY_INCLUDE_IN
|
|
|
|
render() {
|
|
const {
|
|
onClick,
|
|
unsetIconHeight,
|
|
isOnboarding,
|
|
///: BEGIN:ONLY_INCLUDE_IN(build-flask)
|
|
src,
|
|
///: END:ONLY_INCLUDE_IN
|
|
///: BEGIN:ONLY_INCLUDE_IN(build-mmi)
|
|
custodyImgSrc,
|
|
isUnlocked,
|
|
///: END:ONLY_INCLUDE_IN
|
|
} = this.props;
|
|
const iconProps = unsetIconHeight ? {} : { height: 42, width: 42 };
|
|
|
|
iconProps.src = './images/logo/metamask-fox.svg';
|
|
|
|
///: BEGIN:ONLY_INCLUDE_IN(build-mmi)
|
|
iconProps.src = './build-types/mmi/images/logo/mmi-logo-with-words.svg';
|
|
///: END:ONLY_INCLUDE_IN
|
|
|
|
let renderHorizontalLogo = () => (
|
|
<MetaFoxHorizontalLogo
|
|
className={classnames({
|
|
'app-header__metafox-logo--horizontal': !isOnboarding,
|
|
'onboarding-app-header__metafox-logo--horizontal': isOnboarding,
|
|
})}
|
|
/>
|
|
);
|
|
|
|
let imageSrc = './images/logo/metamask-fox.svg';
|
|
|
|
///: BEGIN:ONLY_INCLUDE_IN(build-flask)
|
|
if (src) {
|
|
renderHorizontalLogo = () => (
|
|
<img
|
|
{...iconProps}
|
|
src={src}
|
|
className={classnames({
|
|
'app-header__metafox-logo--horizontal': !isOnboarding,
|
|
'onboarding-app-header__metafox-logo--horizontal': isOnboarding,
|
|
})}
|
|
alt=""
|
|
/>
|
|
);
|
|
|
|
imageSrc = src;
|
|
}
|
|
///: END:ONLY_INCLUDE_IN
|
|
|
|
return (
|
|
<Box
|
|
as="button"
|
|
onClick={onClick}
|
|
className={classnames({
|
|
'app-header__logo-container': !isOnboarding,
|
|
'onboarding-app-header__logo-container': isOnboarding,
|
|
'app-header__logo-container--clickable': Boolean(onClick),
|
|
})}
|
|
backgroundColor={BackgroundColor.transparent}
|
|
data-testid="app-header-logo"
|
|
>
|
|
{renderHorizontalLogo()}
|
|
|
|
<img
|
|
{...iconProps}
|
|
src={imageSrc}
|
|
className={classnames({
|
|
'app-header__metafox-logo--icon': !isOnboarding,
|
|
'onboarding-app-header__metafox-logo--icon': isOnboarding,
|
|
})}
|
|
alt=""
|
|
/>
|
|
{
|
|
///: BEGIN:ONLY_INCLUDE_IN(build-mmi)
|
|
custodyImgSrc &&
|
|
isUnlocked &&
|
|
this.renderCustodyIcon(iconProps, custodyImgSrc)
|
|
///: END:ONLY_INCLUDE_IN
|
|
}
|
|
</Box>
|
|
);
|
|
}
|
|
}
|