Add AjouteTradiksyon to EkriTeks

This commit is contained in:
Cédric FAMIBELLE-PRONZOLA
2021-05-27 23:54:42 +02:00
parent 80ff084eec
commit d8260dcb47
+89 -17
View File
@@ -1,35 +1,81 @@
import {useEffect, useState} from 'react' import {useCallback, useEffect, useState} from 'react'
import PropTypes from 'prop-types' import PropTypes from 'prop-types'
import axios from 'axios' import axios from 'axios'
import { import {
Box, Box,
Button, Button,
Container, Container,
FormControl,
FormHelperText,
Grid, Grid,
IconButton,
InputAdornment,
InputLabel,
LinearProgress, LinearProgress,
OutlinedInput,
Snackbar, Snackbar,
TextField, TextField,
Typography Tooltip,
Typography,
withStyles
} from '@material-ui/core' } from '@material-ui/core'
import MuiAlert from '@material-ui/lab/Alert' import MuiAlert from '@material-ui/lab/Alert'
import CloseIcon from '@material-ui/icons/Close'
import AjouteTradiksyon from './ajoute-tradiksyon'
const API_URL = process.env.NEXT_PUBLIC_API_URL || 'http://localhost:1337' const API_URL = process.env.NEXT_PUBLIC_API_URL || 'http://localhost:1337'
const textLabels = {
fr: {
title: 'Traduction',
help: 'Traduction des paroles de la musique',
emoji: '🇫🇷'
},
en: {
title: 'Translation',
help: 'Translation of music lyrics',
emoji: '🇬🇧'
},
es: {
title: 'Traducción',
help: 'Traducción de la letra de la música',
emoji: '🇪🇸'
}
}
function Alert(props) { function Alert(props) {
return <MuiAlert elevation={6} variant='filled' {...props} /> return <MuiAlert elevation={6} variant='filled' {...props} />
} }
const RemoveTooltip = withStyles(() => ({
tooltip: {
fontSize: 18
}
}))(Tooltip)
function EkriTeks({session}) { function EkriTeks({session}) {
const {jwt, user} = session const {jwt, user} = session
const [teksEkri, setTeksEkri] = useState({awtis: '', tit: '', transkripsyon: '', tradiksyon: ''}) const [teksEkri, setTeksEkri] = useState({awtis: '', tit: '', transkripsyon: ''})
const [tradiksyon, setTradiksyon] = useState({fr: '', en: '', es: ''})
const [kiChawLang, setKiChwalang] = useState([])
const [error, setError] = useState('') const [error, setError] = useState('')
const [success, setSuccess] = useState('') const [success, setSuccess] = useState('')
const [loading, setLoading] = useState(false) const [loading, setLoading] = useState(false)
const [open, setOpen] = useState(false) const [open, setOpen] = useState(false)
const handleUpdate = update => { const handleUpdate = useCallback(update => {
setTeksEkri({...teksEkri, ...update}) setTeksEkri({...teksEkri, ...update})
} }, [teksEkri])
const handleUpdateTradiksyon = useCallback(update => {
setTradiksyon({...tradiksyon, ...update})
}, [tradiksyon])
const handleRemoveTradiksyon = useCallback(idTradiksyon => {
setKiChwalang(kiChawLang.filter(t => t !== idTradiksyon))
setTradiksyon({[tradiksyon.idTradiksyon]: ''})
}, [kiChawLang, setKiChwalang, setTradiksyon, tradiksyon])
const handleClose = (event, reason) => { const handleClose = (event, reason) => {
if (reason === 'clickaway') { if (reason === 'clickaway') {
@@ -43,7 +89,8 @@ function EkriTeks({session}) {
const handleClick = () => { const handleClick = () => {
setLoading(true) setLoading(true)
const {awtis, tit, transkripsyon, tradiksyon} = teksEkri const {awtis, tit, transkripsyon} = teksEkri
const {fr, en, es} = tradiksyon
if (teksEkri.awtis === '' || teksEkri.tit === '' || teksEkri.transkripsyon === '') { if (teksEkri.awtis === '' || teksEkri.tit === '' || teksEkri.transkripsyon === '') {
setError({message: 'Certains champs sont obligatoires'}) setError({message: 'Certains champs sont obligatoires'})
@@ -68,7 +115,9 @@ function EkriTeks({session}) {
tit, tit,
transkripsyon, transkripsyon,
tradiksyon: { tradiksyon: {
francais: tradiksyon === '' ? null : tradiksyon francais: fr === '' ? null : fr,
english: en === '' ? null : en,
espagnol: es === '' ? null : es
}, },
user, user,
awtis: [awtisResponse.data._id] awtis: [awtisResponse.data._id]
@@ -92,7 +141,9 @@ function EkriTeks({session}) {
} }
const handleReset = () => { const handleReset = () => {
setTeksEkri({awtis: '', tit: '', transkripsyon: '', tradiksyon: ''}) setTeksEkri({awtis: '', tit: '', transkripsyon: ''})
setTradiksyon({fr: '', en: '', es: ''})
setKiChwalang([])
} }
useEffect(() => { useEffect(() => {
@@ -158,20 +209,41 @@ function EkriTeks({session}) {
variant='outlined' variant='outlined'
onChange={event => handleUpdate({transkripsyon: event.target.value})} onChange={event => handleUpdate({transkripsyon: event.target.value})}
/> />
<TextField {kiChawLang.length > 0 && kiChawLang.map(k => (
fullWidth <FormControl key={k} fullWidth style={{marginBlock: 10}}>
<InputLabel htmlFor={`tradiksyon-${k}`}>
<span dangerouslySetInnerHTML={{__html: textLabels[k].emoji}} /> {textLabels[k].title}
</InputLabel>
<OutlinedInput
multiline multiline
helperText='Traduction des paroles de la musique'
style={{marginTop: '1em'}} style={{marginTop: '1em'}}
id='tradiksyon' id={`tradiksyon-${k}`}
name='tradiksyon' name={`tradiksyon-${k}`}
label='Tradiksyon' label={`${textLabels[k].title}`}
value={teksEkri.tradiksyon} value={tradiksyon[k]}
rows={8} rows={8}
variant='outlined' endAdornment={
onChange={event => handleUpdate({tradiksyon: event.target.value})} <InputAdornment position='end'>
<RemoveTooltip title='Effacer la traduction' placement='left'>
<IconButton
color='secondary'
style={{bottom: 75}}
aria-label='remove-tradiksyon'
edge='end'
onClick={() => handleRemoveTradiksyon(k)}
>
<CloseIcon />
</IconButton>
</RemoveTooltip>
</InputAdornment>
}
onChange={event => handleUpdateTradiksyon({[k]: event.target.value})}
/> />
<FormHelperText id={`tradiksyon-${k}`}>{textLabels[k].help}</FormHelperText>
</FormControl>
))}
</form> </form>
<AjouteTradiksyon chwaLang={kiChawLang} setChwaLang={setKiChwalang} />
<div> <div>
<Button <Button
fullWidth fullWidth