# Modificare i campi di un Nested Form

Attraverso la [sezione Logic](https://docs.opencityitalia.it/guida-alla-creazione-dei-servizi-digitali/creare-un-servizio/le-funzioni/impostare-delle-azioni-automatiche-le-logiche) è possibile modificare dinamicamente alcune proprietà dei componenti presenti all’interno di un nested form.

In questo modo, il nested form non viene modificato in modo permanente nella sua definizione originale, ma assume una struttura differente solo all’interno del servizio in cui le logiche sono state configurate.

## Vincoli e prerequisiti

La modifica delle proprietà di un Nested Form tramite condizioni logiche è una funzionalità potente ma delicata: se utilizzata in modo improprio, può compromettere il servizio, interrompendo il flusso di compilazione e pregiudicando l'esperienza utente.

Per questo motivo, prima di intervenire sulle proprietà, è bene avere in mente le seguenti regole:

* per ragioni tecniche legate all'invio della pratica, il codice fiscale del richiedente (`applicant`) **non può essere reso facoltativo**;
* è **fortemente sconsigliato** rendere facoltativo l’indirizzo email del richiedente (`applicant`), poiché in tal caso l’utente non riceverebbe le notifiche relative all'avanzamento delle sue pratiche;&#x20;
* in generale, i campi che definiscono il nested form (es. l'importo dell'ISEE) **non devono essere resi facoltativi;**

## Configura la logica

Collocati nella sezione "Logic" del componente e aggiungi una logica avanzata

<figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FlibZvI5TnezK9VGzUzsA%2Fimage.png?alt=media&#x26;token=7893fe57-2997-480a-b8ff-f2039b6baf2b" alt=""><figcaption></figcaption></figure>

Inserisci il nome della logica creata (1) e come *trigger* seleziona la tipologia "Javascript" (2).

<figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FhSBmOji9ifWGkiG33Kas%2Fimage.png?alt=media&#x26;token=97542648-fe4d-47dc-ad65-25472d0e1545" alt=""><figcaption></figcaption></figure>

Se la modifica deve essere sempre eseguita, digita `result = true` nel campo "Text Area".

<figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FNpspcSIyr2hbTTpnS6ju%2Fimage.png?alt=media&#x26;token=001d35a6-7761-4ae7-a0f7-06f194391f19" alt=""><figcaption></figcaption></figure>

Se la modifica dipende dal valore di un campo variabile (ad esempio, una select ruolo in cui i valori sono "Genitore", "Tutore" e "Affidatario"), è necessario definire esplicitamente **tutte le condizioni in altrettante logiche**. Infatti, il form **non ripristina automaticamente lo stato precedente** se viene configurata solo una delle due condizioni. &#x20;

<div><figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FLm9sBk70qtpjTGcN1zu5%2Fimage%20(14).png?alt=media&#x26;token=7fddef31-2fc0-4197-9b64-4fb28d3df1b7" alt=""><figcaption></figcaption></figure> <figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FSDXuucfOk9j0RxlqmkT1%2Fimage%20(13).png?alt=media&#x26;token=3617bc30-76c3-454f-927e-850569522f89" alt=""><figcaption></figcaption></figure></div>

Una volta creata la logica, clicca su "Add Action" per aggiungere l'azione da eseguire

<figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2F2PpgSvfOqTXDHoK83kfn%2Fimage.png?alt=media&#x26;token=d0d3c578-c21b-464e-aa5f-b9e6073171b0" alt=""><figcaption></figcaption></figure>

Configura l'azione inserendo il titolo (1) e indicando la tipologia "Custom Action" (2).

<figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FkvRKupv5KDs2jBfaWmzN%2Fimage.png?alt=media&#x26;token=a9afc002-29c7-491a-95bc-36dbded35dee" alt=""><figcaption></figcaption></figure>

La tipologia "Custom Action" attiva la sezione "Custom action (Javascript)", da usare per inserire il codice della tua azione.

<figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FJkDkgEZqhr3tXOsi8UAJ%2Fimage.png?alt=media&#x26;token=f4967053-bbb2-4a41-a909-5ebeab5b011f" alt=""><figcaption></figcaption></figure>

## Recuperare il *property name* dei componenti del nested form

Il property name dei campi varia a seconda dello specifico "Nested Form" utilizzato; per recuperare il property name corretto, inserisci il seguente codice nella sezione "Custom action" della logica: `console.log(data.[api_key del nested form])`

{% hint style="info" %}
Le chiavi API corrispondono a quelle utilizzate per la [precompilazione dei dati](https://docs.opencityitalia.it/guida-alla-creazione-dei-servizi-digitali/creare-un-servizio/precompilazione-dei-dati#tabella-di-configurazione-del-once-only).
{% endhint %}

<figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2F8hE9ixz3GBAZW1QeycnW%2Fimage.png?alt=media&#x26;token=e554298e-9da4-434d-9d37-37cd0fbb1554" alt=""><figcaption></figcaption></figure>

{% hint style="info" %}
Nell'esempio riportato in immagine, l'admin vuole recuperare i property name dei campi che compongono il nested form  OC-ISEE (`economic_situation_indicator`)
{% endhint %}

Successivamente, apri la console del browser e clicca sull'icona di modifica della pagina. Nella console, cerca e clicca sull'output `object` per espanderlo: in questo modo, potrai ispezionare i valori (`data`) dei campi che compongono il nested form.

<div data-full-width="true"><figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2Fpyb8oowQSYizoPIxhOgE%2FScreenshot-2025-11-03-16-05-14-Display-3-11-03-2025_04_05_PM.png?alt=media&#x26;token=dc29ce57-9da5-4db1-a96d-cc1b41213e9c" alt=""><figcaption></figcaption></figure> <figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2F5ywbsOpW0iUOf08TOgzZ%2Fimage.png?alt=media&#x26;token=c2f73e2a-9979-4e04-88b8-fb6c0fb5f7a3" alt=""><figcaption></figcaption></figure></div>

## Elenco delle proprietà modificabili di un nested form

Durante la modifica della proprietà, ricorda di racchiudere il tuo codice inserendo:

1. `window.FormioHelper.editFormProperties(instance, {` all'inizio.
2. `})` alla fine (per chiudere la funzione).

In pratica, la struttura del tuo codice dovrà assomigliare a questa:

```javascript
window.FormioHelper.editFormProperties(instance, {
// Il codice personalizzato
})
```

<details>

<summary>Obbligatorietà</summary>

Inserisci il codice JavaScript nel campo "Custom Action (Javascript)" per rendere opzionale un campo del Nested Form (ad esempio, "Foglio" nel form "OC - Immobili").

```javascript
window.FormioHelper.editFormProperties(instance, {
  sheet: {
    "validate.required": false,
  }
});
```

Al contrario, per rendere obbligatorio un campo che non è obbligatorio di default, sostituisci **`false`** con **`true`**.

<div data-full-width="true"><figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2F6FQX64brJ8c1eYQnyqje%2Fimage%20(1).png?alt=media&#x26;token=b5580f79-081c-4675-a259-00a75c8b9695" alt=""><figcaption></figcaption></figure> <figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FdbCembA6G9Wvqj3OQO2J%2Fimage%20(2).png?alt=media&#x26;token=adba5afa-886f-4f95-b23d-1cb1638c558d" alt=""><figcaption></figcaption></figure></div>

</details>

<details>

<summary>Etichetta</summary>

Inserisci il codice JavaScript nel campo "Custom Action (Javascript)" per modificare l'etichetta (label) di un campo del Nested Form (ad esempio, cambiare "Particella o mappale" in "Particella" nel form "OC - Immobili").

```javascript
window.FormioHelper.editFormProperties(instance, {
  parcel: {
    "label": "Particella",
  }
});
```

<div data-full-width="true"><figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FbEDQ606nqyTnZICnjsh4%2Fimage%20(3).png?alt=media&#x26;token=6f7bc659-2d29-429b-90be-11e96589e9e5" alt=""><figcaption></figcaption></figure></div>

</details>

<details>

<summary>Visibilità del componente</summary>

Inserisci il codice JavaScript nel campo "Custom Action (Javascript)" per nascondere un campo del Nested Form (ad esempio, nascondere il campo "Subalterno" nel form "OC - Immobili").

```javascript
window.FormioHelper.editFormProperties(instance, {
  subunit: {
    "hidden": true,
  }
});
```

Al contrario, per rendere visibile un campo che non è visibile di default, sostituisci **`false`** con **`true`**  (ad esempio nei casi in cui la modifica dipenda da un [valore variabile](#configura-la-logica))

<div data-full-width="true"><figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FHCMFwwiYE2mKAigkl9Cd%2Fimage%20(4).png?alt=media&#x26;token=7445a035-2e22-4c05-99cd-1be321e943fb" alt=""><figcaption></figcaption></figure> <figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2F6LQNGZbbAnk7JMBJXLYV%2Fimage%20(5).png?alt=media&#x26;token=f68b685b-77f3-4440-8fe4-d12a91677a41" alt=""><figcaption></figcaption></figure></div>

</details>

<details>

<summary>Suffisso e prefisso di un campo</summary>

Inserisci il codice JavaScript nel campo "Custom Action (Javascript)" per inserire un suffisso e/o un prefisso di un campo del Nested Form (ad esempio, per il campo "Volumetria del fabbricato" nel form "OC - Immobili").

```javascript
window.FormioHelper.editFormProperties(instance, {
  volume: {
    "prefix": "volumetria",
    "suffix": "metri cubi"
  },
});
```

<div data-full-width="true"><figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FoL61vUq1ArxjLh3MVHg3%2Fimage%20(6).png?alt=media&#x26;token=026e2bca-4869-42f9-92d7-00beab070d0a" alt=""><figcaption></figcaption></figure></div>

Per nascondere il suffisso di un campo, inserisci:

```javascript
window.FormioHelper.editFormProperties(instance, {
  volume: {
    "suffix": "",
  }
});
```

<figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FBXLQjF7FlHkHwjFVx1Vx%2Fimage%20(15).png?alt=media&#x26;token=4eda8658-69ea-41e8-8750-c132508c764b" alt=""><figcaption></figcaption></figure>

Per nascondere il prefisso di un campo, invece, inserisci:

```javascript
window.FormioHelper.editFormProperties(instance, {
  volume: {
    "prefix": "",
  }
});
```

<figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2F0x4VXb86plRJfyiEPSHr%2Fimage%20(16).png?alt=media&#x26;token=5f96395f-1fa8-468c-ae2c-f156245d58a3" alt=""><figcaption></figcaption></figure>

</details>

<details>

<summary>Tooltip di un campo</summary>

Inserisci il codice JavaScript nel campo "Custom Action (Javascript)" per inserire un tooltip associato ad un campo del Nested Form (ad esempio, aggiungere o modificare il tooltip del campo "Foglio" nel form "OC - Immobili").

```javascript
window.FormioHelper.editFormProperties(instance, {
  sheet: {
    "tooltip": "Numero di una porzione di territorio nel catasto comunale",
  }
});
```

<div data-full-width="true"><figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FHLUJhCA6sztrdmSojEdK%2Fimage%20(7).png?alt=media&#x26;token=cff00973-41dd-44cd-8aca-8c08b7519fa6" alt=""><figcaption></figcaption></figure></div>

Per nascondere invece il tooltip di un campo, inserisci:

```javascript
window.FormioHelper.editFormProperties(instance, {
  sheet: {
    "tooltip": ""
  }
});
```

<div data-full-width="true"><figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FORBykZoJqyVPlO69iZhg%2Fimage%20(8).png?alt=media&#x26;token=35f55301-9fa3-4ed1-aceb-8ea20c0c10f7" alt=""><figcaption></figcaption></figure></div>

</details>

<details>

<summary>Descrizione di un campo</summary>

Inserisci il codice JavaScript nel campo "Custom Action (Javascript)" per inserire la descrizione di un campo del Nested Form (ad esempio, modificare o aggiungere la descrizione del campo "Foglio" nel form "OC - Immobili").

```javascript
window.FormioHelper.editFormProperties(instance, {
  sheet: {
    "description": "Numero che identifica una porzione di territorio nel catasto comunale",
  }
});
```

<div data-full-width="true"><figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FQXICUkBKvPq33fPTjdCx%2Fimage%20(9).png?alt=media&#x26;token=6e81e23e-64c5-4ad8-ba23-a805a338da05" alt=""><figcaption></figcaption></figure></div>

Per nascondere invece la descrizione di un campo, inserisci:

```javascript
window.FormioHelper.editFormProperties(instance, {
  sheet: {
    "description": ""
  }
});
```

<div data-full-width="true"><figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2F4khsH4cjFZ7LeNUrFyT0%2Fimage%20(10).png?alt=media&#x26;token=4efbe2d1-3f1a-4680-9176-71782ce06e1d" alt=""><figcaption></figcaption></figure></div>

</details>

## Modificare un componente di un Nested Form annidato

Per modificare i campi presenti in Nested Form che a loro volta contengono altri Nested Form, è necessario indicare il percorso completo del campo, racchiudendolo tra virgolette.

Per esempio, voglio rendere non obbligatorio il campo "Indirizzo" contenuto nel nested form OC - Residenza, a sua volta contento nel nested form OC - Immobili.&#x20;

La sintassi sarà  `"address.street_address"` , dove:

* `address` = property name del nested form OC - Residenza all’interno di OC - Immobili
* `street_address` = property name del campo "Indirizzo" all’interno di OC - Residenza

```javascript
window.FormioHelper.editFormProperties(instance, {
  "address.street_address": {
    "validate.required": false
    }
});
```

<div data-full-width="true"><figure><img src="https://4252442743-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2FrdV0mwA7iy2c3I7wu5BX%2Fuploads%2FmgIStLks4sEtebjiDDe7%2Fimage%20(11).png?alt=media&#x26;token=8045a54e-5693-4f1b-8195-b6ec8c717bfc" alt=""><figcaption></figcaption></figure></div>
