Newer
Older
import React from 'react'

Alexandru Munteanu
committed
import { th } from '@pubsweet/ui-toolkit'

Alexandru Munteanu
committed
import { FilePicker } from '@pubsweet/ui'

Alexandru Munteanu
committed
import styled, { css } from 'styled-components'
import { compose, withProps } from 'recompose'

Alexandru Munteanu
committed
import { Label, ActionLink, Text, Row, Item, FileItem, DragHandle } from './'

Alexandru Munteanu
committed
const EXTENSIONS = {
pdf: 'PDF',
doc: 'Doc',
docx: 'DocX',
png: 'PNG',
}
const FileSection = ({
title,
isLast,
isFirst,
required,
supportedFormats,

Alexandru Munteanu
committed
allowedFileExtensions,

Alexandru Munteanu
committed
}) => (
<Root isFirst={isFirst} isLast={isLast}>
<Row alignItems="center">
<Item>
<Label required={required}>{title}</Label>

Alexandru Munteanu
committed
<FilePicker
allowedFileExtensions={allowedFileExtensions}
onUpload={file => console.log('uploaded ', file)}
>
<ActionLink icon="plus" size="small">
UPLOAD FILE
</ActionLink>
</FilePicker>

Alexandru Munteanu
committed
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
</Item>
{supportedFormats && (
<Item justify="flex-end">
<Text fontStyle="italic" secondary>
Supported file formats: {supportedFormats}
</Text>
</Item>
)}
</Row>
<FileItem
dragHandle={DragHandle}
file={{
id: 'file1',
name: 'myfile.docx',
size: 51312,
}}
mb={1}
/>
<FileItem
dragHandle={DragHandle}
file={{
id: 'file1',
name: 'myfile.docx',
size: 51312,
}}
mb={1}
/>
</Root>
)
export default compose(
withProps(({ allowedFileExtensions = [] }) => ({
supportedFormats: allowedFileExtensions
.map(ext => EXTENSIONS[ext.toLowerCase()])
.join(', '),
})),
)(FileSection)
// #region styles

Alexandru Munteanu
committed
const radiusHelpers = props => {
const marginTop = props.isFirst
? css`
border-top-left-radius: ${th('borderRadius')};
border-top-right-radius: ${th('borderRadius')};
`
: css``
const marginBottom = props.isLast
? css`
border-bottom-left-radius: ${th('borderRadius')};
border-bottom-right-radius: ${th('borderRadius')};
`
: css``
return css`
border-radius: none;
${marginTop};
${marginBottom};
`
}
const Root = styled.div`

Alexandru Munteanu
committed
background: ${th('colorBackground')};
min-height: calc(${th('gridUnit')} * 22);
padding: 0 ${th('gridUnit')};
${radiusHelpers};
border-bottom: ${props => (!props.isLast ? '1px dashed #dbdbdb' : 'none')};
`
// #endregion