mirror of
https://gitlab.com/MrFry/qmining-page
synced 2025-04-01 20:23:44 +02:00
214 lines
5.6 KiB
JavaScript
214 lines
5.6 KiB
JavaScript
import React, { useState } from 'react'
|
|
import fetch from 'unfetch'
|
|
import Head from 'next/head'
|
|
|
|
import Button from '../components/Button.js'
|
|
|
|
import styles from './feedback.module.css'
|
|
import constants from '../constants.json'
|
|
|
|
const results = {
|
|
success: 'SUCCESS',
|
|
error: 'ERROR',
|
|
notSent: 'NOTSENT',
|
|
invalid: 'INVALID',
|
|
}
|
|
|
|
export default function Feedback() {
|
|
const [form, setForm] = useState({})
|
|
const [file, setFile] = useState(undefined)
|
|
const [result, setResult] = useState(results.notSent)
|
|
const [fileResult, setFileResult] = useState(results.notSent)
|
|
|
|
const onChange = (event) => {
|
|
setForm({
|
|
...form,
|
|
[event.target.name]: event.target.value,
|
|
})
|
|
}
|
|
|
|
const renderTextInputArea = (params) => {
|
|
return (
|
|
<div className={styles.inputArea}>
|
|
<div className={styles.textTitle}>{params.text}</div>
|
|
<textarea
|
|
autoFocus={params.autoFocus}
|
|
onChange={(event) => params.onChange(event)}
|
|
value={form[params.name] || ''}
|
|
className={styles.feedback}
|
|
name={params.name}
|
|
/>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
const onFileChangeHandler = (event) => {
|
|
setForm({
|
|
...form,
|
|
file: event.target.files[0].name,
|
|
})
|
|
setFile(event.target.files[0])
|
|
}
|
|
|
|
const renderFileUploader = () => {
|
|
return (
|
|
<div className={styles.inputArea}>
|
|
<div className={styles.textTitle}>Fájl csatolása</div>
|
|
<input
|
|
className={styles.fileInput}
|
|
type="file"
|
|
name="file"
|
|
onChange={onFileChangeHandler}
|
|
/>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
const handleSubmit = async () => {
|
|
if (!form.description) {
|
|
setResult(results.invalid)
|
|
}
|
|
|
|
const t = document.getElementById('cid').value
|
|
let cid = ''
|
|
let version = ''
|
|
if (t) {
|
|
cid = t.split('|')[0]
|
|
version = t.split('|')[1]
|
|
}
|
|
|
|
const rawResponse = await fetch(constants.apiUrl + 'postfeedback', {
|
|
method: 'POST',
|
|
credentials: 'include',
|
|
headers: {
|
|
Accept: 'application/json',
|
|
'Content-Type': 'application/json',
|
|
},
|
|
body: JSON.stringify({
|
|
...form,
|
|
cid: cid,
|
|
version: version,
|
|
}),
|
|
})
|
|
rawResponse
|
|
.json()
|
|
.then((resp) => {
|
|
if (resp.success) {
|
|
setResult(results.success)
|
|
} else {
|
|
setResult(results.error)
|
|
}
|
|
})
|
|
.catch((err) => {
|
|
setResult(results.error)
|
|
console.error(err)
|
|
})
|
|
|
|
if (file) {
|
|
const formData = new FormData() // eslint-disable-line
|
|
formData.append('file', file)
|
|
|
|
const rawFileResponse = await fetch(
|
|
constants.apiUrl + 'postfeedbackfile',
|
|
{
|
|
method: 'POST',
|
|
credentials: 'include',
|
|
headers: {
|
|
Accept: 'application/json',
|
|
},
|
|
body: formData,
|
|
}
|
|
)
|
|
rawFileResponse
|
|
.json()
|
|
.then((resp) => {
|
|
if (resp.success) {
|
|
setFileResult(results.success)
|
|
} else {
|
|
setFileResult(results.error)
|
|
}
|
|
})
|
|
.catch((err) => {
|
|
setFileResult(results.error)
|
|
console.error('FILE error', err)
|
|
})
|
|
}
|
|
}
|
|
|
|
const renderResult = () => {
|
|
if (results === result.success) {
|
|
return <div>sucess</div>
|
|
} else if (results === result.error) {
|
|
return <div>error</div>
|
|
} else if (results === result.invalid) {
|
|
return <div>invalid</div>
|
|
} else {
|
|
return null
|
|
}
|
|
}
|
|
|
|
// action={constants.apiUrl + 'badtestsender'} encType='multipart/form-data' method='post'
|
|
const renderForm = (props) => {
|
|
return (
|
|
<div className={styles.feedback}>
|
|
{props.noDesc ? (
|
|
<div className={styles.errorMsg}>Mező kitöltése kötelező!</div>
|
|
) : null}
|
|
{renderTextInputArea({
|
|
text: 'Rövid leírás',
|
|
name: 'description',
|
|
onChange: onChange,
|
|
autoFocus: true,
|
|
})}
|
|
<div className={styles.desc}>
|
|
Bal aluli levelesláda ikonnál keresd majd a választ
|
|
</div>
|
|
{renderFileUploader()}
|
|
<div className={styles.buttonContainer}>
|
|
<button className={styles.button} onClick={handleSubmit}>
|
|
Küldés
|
|
</button>
|
|
</div>
|
|
<input type="text" id="cid" name="cid" hidden />
|
|
{renderResult()}
|
|
</div>
|
|
)
|
|
}
|
|
|
|
const renderStuff = () => {
|
|
if (result === results.notSent && fileResult === results.notSent) {
|
|
return <div className={styles.textTitle}>{renderForm({})}</div>
|
|
} else if (result === results.invalid) {
|
|
return (
|
|
<div className={styles.textTitle}>{renderForm({ noDesc: true })}</div>
|
|
)
|
|
} else if (result === results.success && !file) {
|
|
return <div className={styles.textTitle}>Visszajelzés elküldve c:</div>
|
|
} else if (result === results.error && fileResult === results.success) {
|
|
return <div className={styles.textTitle}>Hiba küldés közben :c</div>
|
|
} else if (result === results.success && fileResult === results.error) {
|
|
return (
|
|
<div className={styles.textTitle}>
|
|
Visszajelzés elküldve, de fájlt nem sikerült elküldeni :c
|
|
</div>
|
|
)
|
|
} else if (result === results.success && fileResult === results.success) {
|
|
return <div className={styles.textTitle}>Visszajelzés elküldve c:</div>
|
|
} else {
|
|
return <div className={styles.textTitle}>Bit of a fuckup here</div>
|
|
}
|
|
}
|
|
|
|
return (
|
|
<div>
|
|
<Head>
|
|
<title>Feedback - Qmining | Frylabs.net</title>
|
|
</Head>
|
|
<Button text="IRC chat" href="/irc" />
|
|
<p />
|
|
<hr />
|
|
<p />
|
|
{renderStuff()}
|
|
</div>
|
|
)
|
|
}
|