1
0
mirror of https://github.com/oceanprotocol/market.git synced 2024-12-02 05:57:29 +01:00

add Terms form field

This commit is contained in:
Matthias Kretschmann 2020-07-17 15:06:28 +02:00
parent da6eef9bba
commit 8526a0af2d
Signed by: m
GPG Key ID: 606EEEF3C479A91F
12 changed files with 68 additions and 16 deletions

View File

@ -85,7 +85,7 @@
{ {
"name": "termsAndConditions", "name": "termsAndConditions",
"label": "Terms & Conditions", "label": "Terms & Conditions",
"type": "checkbox", "type": "terms",
"options": ["I agree to these Terms and Conditions"], "options": ["I agree to these Terms and Conditions"],
"required": true "required": true
} }

View File

@ -2,7 +2,8 @@ import React, { ReactElement } from 'react'
import slugify from '@sindresorhus/slugify' import slugify from '@sindresorhus/slugify'
import styles from './InputElement.module.css' import styles from './InputElement.module.css'
import { InputProps } from '.' import { InputProps } from '.'
import FilesInput from '../../molecules/FilesInput' import FilesInput from '../../molecules/FormFields/FilesInput'
import Terms from '../../molecules/FormFields/Terms'
export default function InputElement(props: InputProps): ReactElement { export default function InputElement(props: InputProps): ReactElement {
const { type, options, rows, name } = props const { type, options, rows, name } = props
@ -55,6 +56,8 @@ export default function InputElement(props: InputProps): ReactElement {
) )
case 'files': case 'files':
return <FilesInput name={name} {...props} /> return <FilesInput name={name} {...props} />
case 'terms':
return <Terms name={name} {...props} />
default: default:
return ( return (
<input <input

View File

@ -29,8 +29,8 @@ export interface InputProps {
pattern?: string pattern?: string
min?: string min?: string
disabled?: boolean disabled?: boolean
field?: FieldInputProps<any> field?: any
form?: FormikState<any> form?: any
} }
export default function Input(props: Partial<InputProps>): ReactElement { export default function Input(props: Partial<InputProps>): ReactElement {

View File

@ -1,3 +0,0 @@
.input {
composes: input from '../../atoms/Input/InputElement.module.css';
}

View File

@ -1,7 +1,7 @@
import React, { ReactElement } from 'react' import React, { ReactElement } from 'react'
import { File as FileMetadata } from '@oceanprotocol/lib/dist/node/ddo/interfaces/File' import { File as FileMetadata } from '@oceanprotocol/lib/dist/node/ddo/interfaces/File'
import { prettySize } from '../../../utils' import { prettySize } from '../../../../utils'
import cleanupContentType from '../../../utils/cleanupContentType' import cleanupContentType from '../../../../utils/cleanupContentType'
import styles from './Info.module.css' import styles from './Info.module.css'
export default function FileInfo({ export default function FileInfo({

View File

@ -0,0 +1,3 @@
.input {
composes: input from '../../../atoms/Input/InputElement.module.css';
}

View File

@ -1,12 +1,11 @@
import React, { ReactElement } from 'react' import React, { ReactElement } from 'react'
import isUrl from 'is-url-superb' import isUrl from 'is-url-superb'
import Button from '../../atoms/Button' import Button from '../../../atoms/Button'
import { useField } from 'formik' import { useField } from 'formik'
import Loader from '../../atoms/Loader' import Loader from '../../../atoms/Loader'
import InputElement from '../../atoms/Input/InputElement' import { InputProps } from '../../../atoms/Input'
import { InputProps } from '../../atoms/Input'
import styles from './Input.module.css' import styles from './Input.module.css'
import InputGroup from '../../atoms/Input/InputGroup' import InputGroup from '../../../atoms/Input/InputGroup'
export default function FileInput({ export default function FileInput({
handleButtonClick, handleButtonClick,

View File

@ -3,8 +3,8 @@ import { useField } from 'formik'
import { toast } from 'react-toastify' import { toast } from 'react-toastify'
import FileInfo from './Info' import FileInfo from './Info'
import FileInput from './Input' import FileInput from './Input'
import { getFileInfo } from '../../../utils' import { getFileInfo } from '../../../../utils'
import { InputProps } from '../../atoms/Input' import { InputProps } from '../../../atoms/Input'
interface Values { interface Values {
url: string url: string

View File

@ -0,0 +1,23 @@
.terms {
padding: calc(var(--spacer) / 2);
border: 1px solid var(--brand-grey-lighter);
background-color: var(--brand-grey-dimmed);
border-radius: var(--border-radius);
margin-bottom: calc(var(--spacer) / 2);
font-size: var(--font-size-small);
max-height: 250px;
/* smooth overflow scrolling for pre-iOS 13 */
overflow: auto;
-webkit-overflow-scrolling: touch;
}
.terms h1 {
font-size: var(--font-size-base);
margin-bottom: calc(var(--spacer) / 2);
}
.terms h2 {
font-size: var(--font-size-small);
margin-bottom: calc(var(--spacer) / 2);
}

View File

@ -0,0 +1,27 @@
import React, { ReactElement } from 'react'
import { InputProps } from '../../atoms/Input'
import InputElement from '../../atoms/Input/InputElement'
import styles from './Terms.module.css'
import { graphql, useStaticQuery } from 'gatsby'
const query = graphql`
query TermsQuery {
terms: markdownRemark(fields: { slug: { eq: "/terms" } }) {
html
}
}
`
export default function Terms(props: InputProps): ReactElement {
const data = useStaticQuery(query)
return (
<>
<div
className={styles.terms}
dangerouslySetInnerHTML={{ __html: data.terms.html }}
/>
<InputElement {...props} type="checkbox" />
</>
)
}