|
|
|
import { shell } from 'electron'
|
|
|
|
import React from 'react'
|
|
|
|
import PropTypes from 'prop-types'
|
|
|
|
import { FormattedMessage } from 'react-intl'
|
|
|
|
import FaAngleLeft from 'react-icons/lib/fa/angle-left'
|
|
|
|
import FaAngleRight from 'react-icons/lib/fa/angle-right'
|
|
|
|
import ZapLogo from 'components/Icon/ZapLogo'
|
|
|
|
import ZapLogoBlack from 'components/Icon/ZapLogoBlack'
|
|
|
|
import { Button } from 'components/UI'
|
|
|
|
import messages from './messages'
|
|
|
|
import styles from './FormContainer.scss'
|
|
|
|
|
|
|
|
const FormContainer = ({ title, description, back, next, children, theme }) => (
|
|
|
|
<div className={`${styles.container} ${theme}`}>
|
|
|
|
<header className={styles.header}>
|
|
|
|
<section>
|
|
|
|
{theme === 'light' ? (
|
|
|
|
<ZapLogoBlack width="70px" height="32px" />
|
|
|
|
) : (
|
|
|
|
<ZapLogo width="70px" height="32px" />
|
|
|
|
)}
|
|
|
|
</section>
|
|
|
|
<section>
|
|
|
|
<div
|
|
|
|
className={styles.help}
|
|
|
|
onClick={() =>
|
|
|
|
shell.openExternal('https://ln-zap.github.io/zap-tutorials/zap-desktop-getting-started')
|
|
|
|
}
|
|
|
|
>
|
|
|
|
<FormattedMessage {...messages.help} />
|
|
|
|
</div>
|
|
|
|
</section>
|
|
|
|
</header>
|
|
|
|
|
|
|
|
<div className={styles.info}>
|
|
|
|
<h1>{title}</h1>
|
|
|
|
<p>{description}</p>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div className={styles.content}>{children}</div>
|
|
|
|
|
|
|
|
<footer className={styles.footer}>
|
|
|
|
<div className={styles.buttonsContainer}>
|
|
|
|
<section>
|
|
|
|
{back && (
|
|
|
|
<Button variant="secondary" onClick={back} px={0}>
|
|
|
|
<FaAngleLeft />
|
|
|
|
<FormattedMessage {...messages.back} />
|
|
|
|
</Button>
|
|
|
|
)}
|
|
|
|
</section>
|
|
|
|
<section>
|
|
|
|
{next && (
|
|
|
|
<Button onClick={next}>
|
|
|
|
<FormattedMessage {...messages.next} />
|
|
|
|
<FaAngleRight />
|
|
|
|
</Button>
|
|
|
|
)}
|
|
|
|
</section>
|
|
|
|
</div>
|
|
|
|
</footer>
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
|
|
|
|
FormContainer.propTypes = {
|
|
|
|
title: PropTypes.object.isRequired,
|
|
|
|
description: PropTypes.object.isRequired,
|
|
|
|
theme: PropTypes.string.isRequired,
|
|
|
|
|
|
|
|
back: PropTypes.func,
|
|
|
|
next: PropTypes.func,
|
|
|
|
|
|
|
|
children: PropTypes.object.isRequired
|
|
|
|
}
|
|
|
|
|
|
|
|
export default FormContainer
|