Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion RELEASE.md
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@

### Migliorie

- ...
- Il campo "data di inizio incarico" nel CT Incarico non è più obbligatorio se la tipologia di incarico è impostata come "Amministrativo"

### Novità

Expand Down
1 change: 1 addition & 0 deletions src/components/ItaliaTheme/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ export PDCViewWidget from 'design-comuni-plone-theme/components/ItaliaTheme/mana
export DataGridWidget from 'design-comuni-plone-theme/components/ItaliaTheme/manage/Widgets/DataGridWidget.jsx';
export ContactsConfigWidget from 'design-comuni-plone-theme/components/ItaliaTheme/manage/Widgets/ContactsWidget/ContactsConfigWidget.jsx';
export ContactsConfigForm from 'design-comuni-plone-theme/components/ItaliaTheme/manage/Widgets/ContactsWidget/ContactsConfigForm.jsx';
export ConditionallyRequiredDateWidget from 'design-comuni-plone-theme/components/ItaliaTheme/manage/Widgets/ConditionallyRequiredDateWidget.jsx';

/********* ICONS ********* */
export getItemIcon from 'design-comuni-plone-theme/components/ItaliaTheme/Icons/common/common';
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
import React from 'react';
import { DatetimeWidget } from '@plone/volto/config/Widgets';

const ConditionallyRequiredDateWidget = (props) => {
const { value, formData, onChange, id, title, required, ...rest } = props;

// Check tipo di incarico in formData
const tipoIncarico = formData?.tipologia_incarico;

// Make required only if tipo di incarico !== "amministrativo"
const isRequired = tipoIncarico !== 'amministrativo';

return (
<DatetimeWidget
{...rest}
id={id}
title={title}
value={value}
required={isRequired}
onChange={onChange}
/>
);
};

export default ConditionallyRequiredDateWidget;
4 changes: 4 additions & 0 deletions src/config/Widgets/widgets.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ import {
DataGridWidget,
ContactsConfigWidget,
ContactsConfigForm,
ConditionallyRequiredDateWidget,
} from 'design-comuni-plone-theme/components/ItaliaTheme';
import LuoghiCorrelatiEventoWidget from 'design-comuni-plone-theme/components/ItaliaTheme/manage/Widgets/LuoghiCorrelatiEventoWidget';

Expand Down Expand Up @@ -65,6 +66,9 @@ const getItaliaWidgets = (config) => {
props, //per il content-type FaqFolder
) => <IconWidget {...props} defaultOptions={defaultIconWidgetOptions} />,
cookie_consent_configuration: MultilingualWidget(),
data_inizio_incarico: (props) => (
<ConditionallyRequiredDateWidget {...props} />
),
data_conclusione_incarico: (props) => (
<DatetimeWidget {...props} dateOnly={true} />
),
Expand Down