2020-08-17 15:07:16 -05:00
import React from 'react'
2020-08-17 15:59:29 -05:00
import PropTypes from 'prop-types'
2020-08-17 15:39:25 -05:00
import { connect } from 'react-redux'
2020-03-05 10:44:17 -05:00
import { defineMessages , injectIntl } from 'react-intl'
import { changeListEditorTitle , submitListEditor } from '../actions/lists'
2020-04-28 01:33:58 -04:00
import { closeModal } from '../actions/modal'
import { MODAL _LIST _CREATE } from '../constants'
2020-03-05 10:44:17 -05:00
import Button from '../components/button'
import Input from '../components/input'
2020-04-28 01:33:58 -04:00
import Form from '../components/form'
2020-03-05 10:44:17 -05:00
import Text from '../components/text'
2020-08-17 15:07:16 -05:00
class ListCreate extends React . PureComponent {
2020-03-05 10:44:17 -05:00
render ( ) {
const {
value ,
intl ,
onSubmit ,
2020-04-28 01:33:58 -04:00
onChange ,
2020-03-05 10:44:17 -05:00
} = this . props
2020-04-28 01:33:58 -04:00
const isDisabled = ! value
2020-03-05 10:44:17 -05:00
return (
2020-04-28 01:33:58 -04:00
< Form >
2020-03-05 10:44:17 -05:00
< Input
title = { intl . formatMessage ( messages . label ) }
2020-04-28 01:33:58 -04:00
placeholder = { intl . formatMessage ( messages . new _list _placeholder ) }
2020-03-05 10:44:17 -05:00
value = { value }
onChange = { onChange }
/ >
2020-08-18 15:49:11 -05:00
< div className = { [ _s . d , _s . my10 , _s . py5 , _s . ml10 ] . join ( ' ' ) } >
2020-03-05 10:44:17 -05:00
< Text color = 'secondary' size = 'small' >
2020-04-28 01:33:58 -04:00
{ intl . formatMessage ( messages . list _description ) }
2020-03-05 10:44:17 -05:00
< / T e x t >
< / d i v >
< Button
2020-04-28 01:33:58 -04:00
isDisabled = { isDisabled }
onClick = { onSubmit }
2020-03-05 10:44:17 -05:00
>
2020-04-28 01:33:58 -04:00
< Text color = 'inherit' align = 'center' >
2020-03-05 10:44:17 -05:00
{ intl . formatMessage ( messages . create ) }
< / T e x t >
< / B u t t o n >
2020-04-28 01:33:58 -04:00
< / F o r m >
2020-03-05 10:44:17 -05:00
)
}
}
2020-08-18 19:22:15 -05:00
const messages = defineMessages ( {
label : { id : 'lists.new.title_placeholder' , defaultMessage : 'New list title' } ,
create : { id : 'lists.new.create_title' , defaultMessage : 'Create list' } ,
list _description : { id : 'list.description' , defaultMessage : 'Lists are private and only you can see who is on a list.\nNo one else can view your lists. No one knows that they are on your list.' } ,
new _list _placeholder : { id : 'list.title_placeholder' , defaultMessage : 'My new list...' , } ,
} )
const mapStateToProps = ( state ) => ( {
value : state . getIn ( [ 'listEditor' , 'title' ] ) ,
disabled : state . getIn ( [ 'listEditor' , 'isSubmitting' ] ) ,
} )
const mapDispatchToProps = ( dispatch , { isModal } ) => ( {
onChange : ( value ) => dispatch ( changeListEditorTitle ( value ) ) ,
onSubmit : ( ) => {
if ( isModal ) dispatch ( closeModal ( MODAL _LIST _CREATE ) )
dispatch ( submitListEditor ( true ) )
} ,
} )
ListCreate . propTypes = {
value : PropTypes . string ,
intl : PropTypes . object . isRequired ,
onChange : PropTypes . func . isRequired ,
onSubmit : PropTypes . func . isRequired ,
isModal : PropTypes . bool ,
}
export default injectIntl ( connect ( mapStateToProps , mapDispatchToProps ) ( ListCreate ) )