import React, { useState, useEffect, useRef } from 'react'; import { __, sprintf } from '@wordpress/i18n'; import { useNavigate, useParams } from 'react-router-dom'; import { is, isEmpty, pathOr, isNil } from 'ramda'; // store import { storeSet, useStore } from '../../store'; // tools import getNumberWithCurrency from '../../helpers/getNumberWithCurrency'; import getDateFromISOstring from '../../helpers/getDateFromISOstring'; import set404FromErrorResponse from '../../helpers/set404FromErrorResponse'; import renderHtmlContent from '../../helpers/renderHtmlContent'; // components import { Skeleton } from 'primereact/skeleton'; import { Accordion } from 'primereact/accordion'; import { AccordionTab } from 'primereact/accordion'; import { InputTextarea } from 'primereact/inputtextarea'; import { Button } from 'primereact/button'; import { Messages } from 'primereact/messages'; import { Message } from 'primereact/message'; // api import BandoService from '../../service/bando-service'; import FaqItemService from '../../service/faq-item-service'; import ApplicationService from '../../service/application-service'; const BandoViewBeneficiario = () => { const isAsyncRequest = useStore().main.isAsyncRequest(); const companies = useStore().main.companies(); const { id } = useParams(); const navigate = useNavigate(); const [data, setData] = useState({}); const [newQuestion, setNewQuestion] = useState(''); const [applicationObj, setApplicationObj] = useState(true); const bandoMsgs = useRef(null); const chosenCompanyId = pathOr(0, [0], companies); const scaricaBando = () => { } const scaricaModulistica = () => { } const getBandoId = () => { const parsed = parseInt(id) return !isNaN(parsed) ? parsed : 0; } const submitApplication = () => { if (applicationObj && applicationObj.id) { navigate(`/imieibandi/${applicationObj.id}`); } else { const bandoId = getBandoId(); ApplicationService.createApplication(bandoId, {}, createApplCallback, errCreateApplCallback) } } const createApplCallback = (data) => { storeSet.main.unsetAsyncRequest(); if (data.status === 'SUCCESS') { navigate(`/imieibandi/${data.data.id}`); } } const errCreateApplCallback = (data) => { if (bandoMsgs.current && data.message) { bandoMsgs.current.show([ { sticky: true, severity: 'error', summary: '', detail: data.message, closable: true } ]); } storeSet.main.unsetAsyncRequest(); } const saveToFavourites = () => { } const submitNewQuestion = () => { if (newQuestion) { if (bandoMsgs.current) { bandoMsgs.current.clear(); } const obj = { "id": null, "lookUpDataId": null, "title": newQuestion, "value": newQuestion, "response": "", "isVisible": false } storeSet.main.setAsyncRequest(); FaqItemService.addQuestion(id, obj, createCallBack, errCreateCallback) } } const createCallBack = (data) => { if (data.status === 'SUCCESS') { setNewQuestion(''); if (bandoMsgs.current && data.message) { bandoMsgs.current.show([ { sticky: true, severity: 'success', summary: '', detail: data.message, closable: true } ]); setTimeout(() => { bandoMsgs.current.clear(); }, 5000); } } storeSet.main.unsetAsyncRequest(); } const errCreateCallback = (data) => { if (bandoMsgs.current && data.message) { bandoMsgs.current.show([ { sticky: true, severity: 'error', summary: '', detail: data.message, closable: true } ]); } storeSet.main.unsetAsyncRequest(); } const getBandoCallback = (data) => { if (data.status === 'SUCCESS') { setData(getFormattedBandiData(data.data)); } } const errGetBandoCallback = (data) => { if (bandoMsgs.current && data.message) { bandoMsgs.current.show([ { sticky: true, severity: 'error', summary: '', detail: data.message, closable: true } ]); } set404FromErrorResponse(data); } const getFormattedBandiData = (data) => { data.dates = data.dates.map(v => is(String, v) ? new Date(v) : (v ? v : '')); return data; }; const getApplCallback = (data) => { if (data.status === 'SUCCESS') { if(data.data.length) { setApplicationObj(data.data[0]); } } storeSet.main.unsetAsyncRequest(); } const errGetApplCallback = (data) => { set404FromErrorResponse(data); storeSet.main.unsetAsyncRequest(); } useEffect(() => { const bandoId = getBandoId(); storeSet.main.setAsyncRequest(); BandoService.getBando(bandoId, getBandoCallback, errGetBandoCallback); ApplicationService.getApplications(getApplCallback, errGetApplCallback, [['callId', bandoId]]) }, [id]); return (
{!isAsyncRequest && !isEmpty(data) ?

{data.name}

{__('Data:', 'gepafin')} {getDateFromISOstring(data.createdDate)}

: <> }
{!isAsyncRequest && !isEmpty(data) ?
{data.name}/

{__('Descrizione breve', 'gepafin')}

{renderHtmlContent(data.descriptionShort)}

{__('Importo totale', 'gepafin')} {getNumberWithCurrency(data.amount)}

{__('Importo minimo per progetto', 'gepafin')} {getNumberWithCurrency(data.amountMin)}

{__('Importo massimo per progetto', 'gepafin')} {getNumberWithCurrency(data.amountMax)}

{__('Data apertura', 'gepafin')} {getDateFromISOstring(data.dates[0])} {data.startTime}

{__('Data chiusura', 'gepafin')} {getDateFromISOstring(data.dates[1])} {data.endTime}

{__('Descrizione dettagliata', 'gepafin')}

{renderHtmlContent(data.descriptionLong)}

{__('Requisiti di Partecipazione', 'gepafin')}

    {data.aimedTo.map((o, i) =>
  • {o.value}
  • )}

{__('Documentazione Richiesta', 'gepafin')}

{data.documentationRequested}

{__('Criteri di Valutazione', 'gepafin')}

    {data.criteria.map((o, i) =>
  • {`${o.value} ${sprintf(__('(%d punti)'), o.score)}`}
  • )}

{__('Allegati', 'gepafin')}

{__('FAQ', 'gepafin')}

{data.faq .filter(o => o.isVisible) .map((o, i) =>

{o.response}

)}

{__('Non hai trovato la risposta che cercavi?', 'gepafin')}

setNewQuestion(e.target.value)} aria-describedby="newQuestion-help"/> {__('Riceverai una notifica quando ti risponderemo', 'gepafin')}
{chosenCompanyId === 0 ? <> : null}

{__('Download Documenti', 'gepafin')}

{__('Contatti per Assistenza', 'gepafin')}

Email: {data.email}

{!isNil(data.phoneNumber) ?

{__('Telefono', 'gepafin')}: +39 {data.phoneNumber}

: null}
: <> }
) } export default BandoViewBeneficiario;