updates
This commit is contained in:
4
.idea/watcherTasks.xml
generated
Normal file
4
.idea/watcherTasks.xml
generated
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="ProjectTasksOptions" suppressed-tasks="SCSS" />
|
||||||
|
</project>
|
||||||
@@ -90,6 +90,13 @@
|
|||||||
line-height: normal;
|
line-height: normal;
|
||||||
margin: 0 0 24px;
|
margin: 0 0 24px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.row {
|
||||||
|
display: flex;
|
||||||
|
gap: 1rem;
|
||||||
|
align-items: center;
|
||||||
|
padding: 5px 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.appPageSection__withBorder {
|
.appPageSection__withBorder {
|
||||||
|
|||||||
@@ -8,8 +8,8 @@
|
|||||||
.p-badge {
|
.p-badge {
|
||||||
color: var(--menuitem-active-color);
|
color: var(--menuitem-active-color);
|
||||||
}
|
}
|
||||||
.p-button:not(.p-button-outlined, .p-button-secondary),
|
.p-button:not(.p-button-outlined, .p-button-secondary, .p-confirm-popup-reject),
|
||||||
.p-button:not(.p-button-outlined, .p-button-secondary) span {
|
.p-button:not(.p-button-outlined, .p-button-secondary, .p-confirm-popup-reject) span {
|
||||||
color: var(--menuitem-active-color);
|
color: var(--menuitem-active-color);
|
||||||
}
|
}
|
||||||
.p-fileupload-row {
|
.p-fileupload-row {
|
||||||
|
|||||||
@@ -1,7 +1,8 @@
|
|||||||
import React, { useEffect, useState, useCallback } from 'react';
|
import React, { useEffect, useState, useCallback } from 'react';
|
||||||
import { classNames } from 'primereact/utils';
|
import { classNames } from 'primereact/utils';
|
||||||
import { __ } from '@wordpress/i18n';
|
import { __ } from '@wordpress/i18n';
|
||||||
import { head } from 'ramda';
|
import { head, isEmpty } from 'ramda';
|
||||||
|
import { diff } from 'deep-object-diff';
|
||||||
|
|
||||||
// components
|
// components
|
||||||
import { Button } from 'primereact/button';
|
import { Button } from 'primereact/button';
|
||||||
@@ -116,18 +117,27 @@ const FormFieldRepeaterFaq = ({
|
|||||||
}, [stateFieldData]);
|
}, [stateFieldData]);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const storeFieldData = data[fieldName] ?? [];
|
const storeFieldData = data ?? [];
|
||||||
setStateFieldData(storeFieldData);
|
setStateFieldData(storeFieldData);
|
||||||
setStateOptionsData([...options, ...storeFieldData]);
|
setStateOptionsData([...options, ...storeFieldData]);
|
||||||
register(fieldName, config)
|
register(fieldName, config)
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
const diffData = diff(data, stateFieldData);
|
||||||
|
|
||||||
|
if (!isEmpty(diffData)) {
|
||||||
|
const storeFieldData = data ?? [];
|
||||||
|
setStateFieldData(storeFieldData);
|
||||||
|
}
|
||||||
|
}, [data]);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
setStateOptionsData([...options]);
|
setStateOptionsData([...options]);
|
||||||
}, [options]);
|
}, [options]);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
setDataFn(fieldName, [...stateFieldData], { shouldValidate: true });
|
setDataFn(fieldName, stateFieldData, { shouldValidate: true });
|
||||||
}, [stateFieldData]);
|
}, [stateFieldData]);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
|||||||
@@ -10,6 +10,7 @@ import { Avatar } from 'primereact/avatar';
|
|||||||
|
|
||||||
const TopBarProfileMenu = ({ menuLeftRef }) => {
|
const TopBarProfileMenu = ({ menuLeftRef }) => {
|
||||||
const userData = useTrackedStore().main.userData();
|
const userData = useTrackedStore().main.userData();
|
||||||
|
const fulleName = `${userData.firstName} ${userData.lastName}`;
|
||||||
|
|
||||||
let items = [
|
let items = [
|
||||||
{
|
{
|
||||||
@@ -18,19 +19,19 @@ const TopBarProfileMenu = ({ menuLeftRef }) => {
|
|||||||
<div className="topBar__menuProfileItem">
|
<div className="topBar__menuProfileItem">
|
||||||
<Avatar image="https://primefaces.org/cdn/primereact/images/avatar/amyelsner.png" shape="circle" />
|
<Avatar image="https://primefaces.org/cdn/primereact/images/avatar/amyelsner.png" shape="circle" />
|
||||||
<div className="userInfo">
|
<div className="userInfo">
|
||||||
<span className="userName">{`${userData.firstName} ${userData.lastName}`}</span>
|
<span className="userName" title={fulleName}>{fulleName}</span>
|
||||||
<span className="userEmail">{userData.email}</span>
|
<span className="userEmail" title={userData.email}>{userData.email}</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
/*{
|
||||||
label: __('Il mio profilo', 'gepafin'),
|
label: __('Il mio profilo', 'gepafin'),
|
||||||
command: () => {
|
command: () => {
|
||||||
console.log('go to profile page')
|
console.log('go to profile page')
|
||||||
}
|
}
|
||||||
},
|
},*/
|
||||||
{
|
{
|
||||||
separator: true
|
separator: true
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ import { __ } from '@wordpress/i18n';
|
|||||||
import { useNavigate } from 'react-router-dom';
|
import { useNavigate } from 'react-router-dom';
|
||||||
import { useForm } from 'react-hook-form';
|
import { useForm } from 'react-hook-form';
|
||||||
import { isEmpty, isNil, is } from 'ramda';
|
import { isEmpty, isNil, is } from 'ramda';
|
||||||
|
import { klona } from 'klona';
|
||||||
|
|
||||||
// components
|
// components
|
||||||
import FormField from '../../../../components/FormField';
|
import FormField from '../../../../components/FormField';
|
||||||
@@ -12,6 +13,8 @@ import BandoEditFormActions from '../BandoEditFormActions';
|
|||||||
import UnsavedChangesDetector from '../../../../components/UnsavedChangesDetector';
|
import UnsavedChangesDetector from '../../../../components/UnsavedChangesDetector';
|
||||||
import BandoService from '../../../../service/bando-service';
|
import BandoService from '../../../../service/bando-service';
|
||||||
import LookupdataService from '../../../../service/lookupdata-service';
|
import LookupdataService from '../../../../service/lookupdata-service';
|
||||||
|
|
||||||
|
// store
|
||||||
import { storeSet, useStore } from '../../../../store';
|
import { storeSet, useStore } from '../../../../store';
|
||||||
|
|
||||||
const BandoEditFormStep1 = forwardRef(function ({ initialData, getFormErrors }, ref) {
|
const BandoEditFormStep1 = forwardRef(function ({ initialData, getFormErrors }, ref) {
|
||||||
@@ -126,7 +129,11 @@ const BandoEditFormStep1 = forwardRef(function ({ initialData, getFormErrors },
|
|||||||
}, [initialData]);
|
}, [initialData]);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
reset(formInitialData);
|
const newFormData = klona(formInitialData);
|
||||||
|
if (!isNil(formInitialData.dates) && formInitialData.dates.length) {
|
||||||
|
newFormData.dates = formInitialData.dates.map(v => is(String, v) ? new Date(v) : (v ? v : ''));
|
||||||
|
}
|
||||||
|
reset(newFormData);
|
||||||
}, [formInitialData]);
|
}, [formInitialData]);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
@@ -259,7 +266,7 @@ const BandoEditFormStep1 = forwardRef(function ({ initialData, getFormErrors },
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<FormFieldRepeaterFaq
|
<FormFieldRepeaterFaq
|
||||||
data={values}
|
data={values['faq']}
|
||||||
setDataFn={setValue}
|
setDataFn={setValue}
|
||||||
fieldName="faq"
|
fieldName="faq"
|
||||||
options={faqOptions}
|
options={faqOptions}
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ import { __ } from '@wordpress/i18n';
|
|||||||
import { useNavigate } from 'react-router-dom';
|
import { useNavigate } from 'react-router-dom';
|
||||||
import { useForm } from 'react-hook-form';
|
import { useForm } from 'react-hook-form';
|
||||||
import { is, isEmpty, isNil } from 'ramda';
|
import { is, isEmpty, isNil } from 'ramda';
|
||||||
|
import { klona } from 'klona';
|
||||||
|
|
||||||
// components
|
// components
|
||||||
import FormField from '../../../../components/FormField';
|
import FormField from '../../../../components/FormField';
|
||||||
@@ -121,7 +122,11 @@ const BandoEditFormStep2 = forwardRef(function ({ initialData, getFormErrors },
|
|||||||
}, [initialData]);
|
}, [initialData]);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
reset(formInitialData);
|
const newFormData = klona(formInitialData);
|
||||||
|
if (!isNil(formInitialData.dates) && formInitialData.dates.length) {
|
||||||
|
newFormData.dates = formInitialData.dates.map(v => is(String, v) ? new Date(v) : (v ? v : ''));
|
||||||
|
}
|
||||||
|
reset(newFormData);
|
||||||
}, [formInitialData]);
|
}, [formInitialData]);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
|
|||||||
@@ -308,7 +308,7 @@ const BandoEdit = () => {
|
|||||||
<div className="appPageSection">
|
<div className="appPageSection">
|
||||||
<h2>{__('Publicca il Form', 'gepafin')}</h2>
|
<h2>{__('Publicca il Form', 'gepafin')}</h2>
|
||||||
|
|
||||||
<div className="appPageSection__actions">
|
<div className="row">
|
||||||
<Button
|
<Button
|
||||||
type="button"
|
type="button"
|
||||||
outlined
|
outlined
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ import React, { useState, useEffect } from 'react';
|
|||||||
import { __ } from '@wordpress/i18n';
|
import { __ } from '@wordpress/i18n';
|
||||||
import { useParams, useNavigate } from 'react-router-dom';
|
import { useParams, useNavigate } from 'react-router-dom';
|
||||||
import { isEmpty } from 'ramda';
|
import { isEmpty } from 'ramda';
|
||||||
|
import { classNames } from 'primereact/utils';
|
||||||
|
|
||||||
// components
|
// components
|
||||||
import { Button } from 'primereact/button';
|
import { Button } from 'primereact/button';
|
||||||
@@ -114,7 +115,7 @@ const BandoForms = () => {
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div className="appPageSection__withBorder">
|
<div className={classNames(["appPageSection__withBorder", (isEmpty(forms) ? 'disabled' : '')])}>
|
||||||
<h2>{__('Modifica form esistente', 'gepafin')}</h2>
|
<h2>{__('Modifica form esistente', 'gepafin')}</h2>
|
||||||
<div className="row">
|
<div className="row">
|
||||||
<p>{__('Continua a lavorare su un form precedentemente salvato', 'gepafin')}</p>
|
<p>{__('Continua a lavorare su un form precedentemente salvato', 'gepafin')}</p>
|
||||||
|
|||||||
@@ -100,11 +100,13 @@ const BuilderElementSettings = ({ closeSettings }) => {
|
|||||||
? settings.map((o) => <div className="formElementSettings__field" key={o.name}>
|
? settings.map((o) => <div className="formElementSettings__field" key={o.name}>
|
||||||
<label htmlFor={o.name}>{o.name}</label>
|
<label htmlFor={o.name}>{o.name}</label>
|
||||||
{o.name === 'options'
|
{o.name === 'options'
|
||||||
? <ElementSettingRepeater value={o.value} name={o.name} setDataFn={onUpdateOptions} />
|
?
|
||||||
|
<ElementSettingRepeater value={o.value} name={o.name} setDataFn={onUpdateOptions}/>
|
||||||
: <InputText id={o.name} aria-describedby={`${o.name}-help`}
|
: <InputText id={o.name} aria-describedby={`${o.name}-help`}
|
||||||
value={o.value}
|
value={o.value}
|
||||||
onChange={(e) => onChange(e.target.value, o.name)}/>}
|
onChange={(e) => onChange(e.target.value, o.name)}/>}
|
||||||
</div>) : null}
|
</div>)
|
||||||
|
: null}
|
||||||
</TabPanel>
|
</TabPanel>
|
||||||
<TabPanel header={__('Validation', 'gepafin')}>
|
<TabPanel header={__('Validation', 'gepafin')}>
|
||||||
{validators
|
{validators
|
||||||
@@ -128,11 +130,11 @@ const BuilderElementSettings = ({ closeSettings }) => {
|
|||||||
: null}
|
: null}
|
||||||
{textBasedValidatorFields.includes(k) && !isNil(validators[k])
|
{textBasedValidatorFields.includes(k) && !isNil(validators[k])
|
||||||
? <div className="formElementSettings__field">
|
? <div className="formElementSettings__field">
|
||||||
<label htmlFor={k}>{k}</label>
|
<label htmlFor={k}>{k}</label>
|
||||||
<InputText id={k} aria-describedby={`${k}-help`}
|
<InputText id={k} aria-describedby={`${k}-help`}
|
||||||
value={validators[k]}
|
value={validators[k]}
|
||||||
onChange={(e) => onChangeValidator(e.target.value, k)}/>
|
onChange={(e) => onChangeValidator(e.target.value, k)}/>
|
||||||
</div> : null}
|
</div> : null}
|
||||||
</div>) : null}
|
</div>) : null}
|
||||||
</TabPanel>
|
</TabPanel>
|
||||||
</TabView>
|
</TabView>
|
||||||
|
|||||||
@@ -11,9 +11,10 @@ import { storeSet, storeGet, useStore } from '../../store';
|
|||||||
// components
|
// components
|
||||||
import FormBuilder from './components/FormBuilder';
|
import FormBuilder from './components/FormBuilder';
|
||||||
import { Button } from 'primereact/button';
|
import { Button } from 'primereact/button';
|
||||||
|
import { ConfirmPopup, confirmPopup } from 'primereact/confirmpopup';
|
||||||
// components
|
|
||||||
import { InputText } from 'primereact/inputtext';
|
import { InputText } from 'primereact/inputtext';
|
||||||
|
|
||||||
|
// api
|
||||||
import FormsService from '../../service/forms-service';
|
import FormsService from '../../service/forms-service';
|
||||||
|
|
||||||
const BandoFormsEdit = () => {
|
const BandoFormsEdit = () => {
|
||||||
@@ -46,7 +47,7 @@ const BandoFormsEdit = () => {
|
|||||||
if (bandoFormId === 0) {
|
if (bandoFormId === 0) {
|
||||||
FormsService.createFormForCall(bandoId, formData, formCreateCallback, errFormCreateCallback);
|
FormsService.createFormForCall(bandoId, formData, formCreateCallback, errFormCreateCallback);
|
||||||
} else {
|
} else {
|
||||||
FormsService.updateForm(bandoFormId, formData, formCreateCallback, errFormCreateCallback)
|
FormsService.updateForm(bandoFormId, formData, formCreateCallback, errFormCreateCallback);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -71,10 +72,40 @@ const BandoFormsEdit = () => {
|
|||||||
navigate(`/bandi/${bandoId}/forms/${formId}/preview`);
|
navigate(`/bandi/${bandoId}/forms/${formId}/preview`);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const confirmDelete = (event) => {
|
||||||
|
confirmPopup({
|
||||||
|
target: event.currentTarget,
|
||||||
|
message: __('Sei sicuro di cancellare questo form?', 'gepafin'),
|
||||||
|
icon: 'pi pi-info-circle',
|
||||||
|
defaultFocus: 'reject',
|
||||||
|
acceptClassName: 'p-button-danger',
|
||||||
|
accept: doDelete,
|
||||||
|
reject: () => {}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
const doPublish = () => {
|
const doPublish = () => {
|
||||||
console.log('doPublish');
|
console.log('doPublish');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const doDelete = () => {
|
||||||
|
storeSet.main.setAsyncRequest();
|
||||||
|
FormsService.deleteForm(formId, formDeleteCallback, errFormDeleteCallback)
|
||||||
|
}
|
||||||
|
|
||||||
|
const formDeleteCallback = (data) => {
|
||||||
|
if (data.status === 'SUCCESS') {
|
||||||
|
const bandoId = getBandoId();
|
||||||
|
navigate(`/bandi/${bandoId}/forms`);
|
||||||
|
}
|
||||||
|
storeSet.main.unsetAsyncRequest();
|
||||||
|
}
|
||||||
|
|
||||||
|
const errFormDeleteCallback = (data) => {
|
||||||
|
console.log('errFormDeleteCallback', data)
|
||||||
|
storeSet.main.unsetAsyncRequest();
|
||||||
|
}
|
||||||
|
|
||||||
const getElementItemsCallback = (data) => {
|
const getElementItemsCallback = (data) => {
|
||||||
if (data.status === 'SUCCESS') {
|
if (data.status === 'SUCCESS') {
|
||||||
storeSet.main.elementItems(data.data);
|
storeSet.main.elementItems(data.data);
|
||||||
@@ -172,6 +203,13 @@ const BandoFormsEdit = () => {
|
|||||||
onClick={doPublish}
|
onClick={doPublish}
|
||||||
label={__('Pubblica', 'gepafin')}/>
|
label={__('Pubblica', 'gepafin')}/>
|
||||||
</div>
|
</div>
|
||||||
|
<div className="appPageSection__actions">
|
||||||
|
<ConfirmPopup />
|
||||||
|
<Button
|
||||||
|
onClick={confirmDelete}
|
||||||
|
severity="danger"
|
||||||
|
label={__('Cancella', 'gepafin')} icon="pi pi-trash" iconPos="right"/>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -23,4 +23,8 @@ export default class FormsService {
|
|||||||
static getFormById = (id, callback, errCallback) => {
|
static getFormById = (id, callback, errCallback) => {
|
||||||
NetworkService.get(`${API_BASE_URL}/form/${id}`, callback, errCallback);
|
NetworkService.get(`${API_BASE_URL}/form/${id}`, callback, errCallback);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static deleteForm = (id, callback, errCallback) => {
|
||||||
|
NetworkService.delete(`${API_BASE_URL}/form/${id}`, {}, callback, errCallback);
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user