> For the complete documentation index, see [llms.txt](https://docs.devolutions.net/llms.txt). Markdown versions of documentation pages are available by appending `.md` to page URLs; this page is available as [Markdown](https://docs.devolutions.net/powershell-universal/fr/apps/components/navigation/stepper.md).

# Assistant

**Les steppers indiquent la progression à travers des étapes numérotées. Ils fournissent un flux de travail de type assistant.**

Les steppers affichent la progression à travers une séquence d'étapes logiques et numérotées. Ils peuvent également être utilisés pour la navigation. Les steppers peuvent afficher un message de rétroaction transitoire après l'enregistrement d'une étape. Le stepper prend en charge le stockage des données saisies dans le contexte du stepper. Il prend en charge les contrôles suivants.

* [Autocomplete](/powershell-universal/fr/apps/components/inputs/automcomplete.md)
* [Checkbox](/powershell-universal/fr/apps/components/inputs/checkbox.md)
* [Date Picker](/powershell-universal/fr/apps/components/inputs/date-picker.md)
* [Radio](/powershell-universal/fr/apps/components/inputs/radio.md)
* [Select](/powershell-universal/fr/apps/components/inputs/select.md)
* [Slider](/powershell-universal/fr/apps/components/inputs/slider.md)
* [Switch](/powershell-universal/fr/apps/components/inputs/switch.md)
* [Textbox](/powershell-universal/fr/apps/components/inputs/textbox.md)
* [Time Picker](/powershell-universal/fr/apps/components/inputs/time-picker.md)
* [Upload](/powershell-universal/fr/apps/components/inputs/upload.md)

## Stepper

![](/files/j7U0LRzq2MTnYud9YwLb)

```powershell
New-UDStepper -Steps {
    New-UDStep -OnLoad {
        New-UDElement -tag 'div' -Content { "Step 1" }
        New-UDTextbox -Id 'txtStep1' -Value $EventData.Context.txtStep1
    } -Label "Step 1"
    New-UDStep -OnLoad {
        New-UDElement -tag 'div' -Content { "Step 2" }
        New-UDElement -tag 'div' -Content { "Previous data: $Body" }
        New-UDTextbox -Id 'txtStep2' -Value $EventData.Context.txtStep2
    } -Label "Step 2"
    New-UDStep -OnLoad {
        New-UDElement -tag 'div' -Content { "Step 3" }
        New-UDElement -tag 'div' -Content { "Previous data: $Body" }
        New-UDTextbox -Id 'txtStep3' -Value $EventData.Context.txtStep3
    } -Label "Step 3"
} -OnFinish {
    New-UDTypography -Text 'Nice! You did it!' -Variant h3
    New-UDElement -Tag 'div' -Id 'result' -Content {$Body}
}
```

La variable `$Body` contiendra une chaîne JSON représentant l'état actuel du stepper. Vous recevrez des informations sur les champs définis dans le stepper ainsi que des informations sur l'étape en cours qui a été complétée. La chaîne JSON `$Body` aura le format suivant.

```javascript
{
    context: {
        txtStep1: "value1",
        txtStep2: "value2",
        txtStep3: "value3"
    },
    currentStep: 0
}
```

## Validation d'une étape

Vous pouvez valider une étape dans un stepper en spécifiant le paramètre `OnValidateStep`. Le bloc de script recevra une variable `$Body` contenant du JSON qui fournit des informations sur l'état actuel du stepper. Vous devrez retourner un résultat de validation en utilisant `New-UDValidationResult` pour indiquer si l'état de l'étape en cours est valide.

La charge utile JSON aura le format suivant. Notez que les étapes sont indexées à partir de 0. Si vous souhaitez valider la première étape, vérifiez que l'étape est 0.

```javascript
{
    context: {
        field1: "value1" 
    },
    currentStep: 0
}
```

Vous devrez convertir la chaîne JSON en objet pour travailler avec celle-ci dans PowerShell, puis retourner le résultat de validation.

```powershell
New-UDStepper -Steps {
    New-UDStep -OnLoad {
        New-UDElement -tag 'div' -Content { "Step 1" }
        New-UDTextbox -Id 'txtStep1' -Value $EventData.Context.txtStep1
    } -Label "Step 1"
    New-UDStep -OnLoad {
        New-UDElement -tag 'div' -Content { "Step 2" }
        New-UDElement -tag 'div' -Content { "Previous data: $Body" }
        New-UDTextbox -Id 'txtStep2' -Value $EventData.Context.txtStep2
    } -Label "Step 2"
    New-UDStep -OnLoad {
        New-UDElement -tag 'div' -Content { "Step 3" }
        New-UDElement -tag 'div' -Content { "Previous data: $Body" }
        New-UDTextbox -Id 'txtStep3' -Value $EventData.Context.txtStep3
    } -Label "Step 3"
} -OnFinish {
    New-UDTypography -Text 'Nice! You did it!' -Variant h3
    New-UDElement -Tag 'div' -Id 'result' -Content {$Body}
} -OnValidateStep {
    $Context = $EventData
    if ($Context.CurrentStep -eq 0 -and $Context.Context.txtStep1 -eq 'bad')
    {
        New-UDValidationResult 
    }
    else
    {
        New-UDValidationResult -Valid 
    }
}
```

## Ignorer des étapes

Vous pouvez diriger l'utilisateur vers une étape particulière dans le gestionnaire d'événements `OnValidateStep`. Utilisez le paramètre `-ActiveStep` de `New-UDValidationResult` pour déplacer l'utilisateur vers n'importe quelle étape après avoir cliqué sur Suivant. Les indices d'étapes sont basés sur 0.

Cet exemple déplace l'utilisateur vers la dernière étape après avoir complété la première étape.

```powershell
New-UDStepper -Steps {
    New-UDStep -OnLoad {
        New-UDElement -tag 'div' -Content { "Step 1" }
        New-UDTextbox -Id 'txtStep1' -Value $EventData.Context.txtStep1
    } -Label "Step 1"
    New-UDStep -OnLoad {
        New-UDElement -tag 'div' -Content { "Step 2" }
        New-UDElement -tag 'div' -Content { "Previous data: $Body" }
        New-UDTextbox -Id 'txtStep2' -Value $EventData.Context.txtStep2
    } -Label "Step 2"
    New-UDStep -OnLoad {
        New-UDElement -tag 'div' -Content { "Step 3" }
        New-UDElement -tag 'div' -Content { "Previous data: $Body" }
        New-UDTextbox -Id 'txtStep3' -Value $EventData.Context.txtStep3
    } -Label "Step 3"
} -OnFinish {
    New-UDTypography -Text 'Nice! You did it!' -Variant h3
    New-UDElement -Tag 'div' -Id 'result' -Content {$Body}
} -OnValidateStep {
    $Context = $EventData
    if ($Context.CurrentStep -eq 0 -and $Context.Context.txtStep1 -eq 'bad')
    {
        New-UDValidationResult 
    }
    else
    {
        New-UDValidationResult -Valid -ActiveStep 2
    }
}
```

## Désactiver le bouton Précédent

Vous pouvez désactiver le bouton Précédent en utilisant le paramètre `-DisablePrevious` de `New-UDValidationResult`.

Cet exemple désactive l'étape précédente chaque fois que l'utilisateur avance dans le stepper.

```powershell
New-UDStepper -Steps {
    New-UDStep -OnLoad {
        New-UDElement -tag 'div' -Content { "Step 1" }
        New-UDTextbox -Id 'txtStep1' -Value $EventData.Context.txtStep1
    } -Label "Step 1"
    New-UDStep -OnLoad {
        New-UDElement -tag 'div' -Content { "Step 2" }
        New-UDElement -tag 'div' -Content { "Previous data: $Body" }
        New-UDTextbox -Id 'txtStep2' -Value $EventData.Context.txtStep2
    } -Label "Step 2"
    New-UDStep -OnLoad {
        New-UDElement -tag 'div' -Content { "Step 3" }
        New-UDElement -tag 'div' -Content { "Previous data: $Body" }
        New-UDTextbox -Id 'txtStep3' -Value $EventData.Context.txtStep3
    } -Label "Step 3"
} -OnFinish {
    New-UDTypography -Text 'Nice! You did it!' -Variant h3
    New-UDElement -Tag 'div' -Id 'result' -Content {$Body}
} -OnValidateStep {
    New-UDValidationResult -Valid -DisablePrevious
}
```

## Steppers verticaux

Vous pouvez créer un stepper vertical en définissant le paramètre `-Orientation` à vertical.

```powershell
New-UDStepper -Steps {
    New-UDStep -OnLoad {
        New-UDElement -tag 'div' -Content { "Step 1" }
        New-UDTextbox -Id 'txtStep1' -Value $EventData.Context.txtStep1
    } -Label "Step 1"
    New-UDStep -OnLoad {
        New-UDElement -tag 'div' -Content { "Step 2" }
        New-UDElement -tag 'div' -Content { "Previous data: $Body" }
        New-UDTextbox -Id 'txtStep2' -Value $EventData.Context.txtStep2
    } -Label "Step 2"
    New-UDStep -OnLoad {
        New-UDElement -tag 'div' -Content { "Step 3" }
        New-UDElement -tag 'div' -Content { "Previous data: $Body" }
        New-UDTextbox -Id 'txtStep3' -Value $EventData.Context.txtStep3
    } -Label "Step 3"
} -OnFinish {
    New-UDTypography -Text 'Nice! You did it!' -Variant h3
    New-UDElement -Tag 'div' -Id 'result' -Content {$Body}
} -Orientation 'vertical'
```

![](/files/mi7f1DtijKq685fgS3fy)

## API

* [New-UDStepper](https://github.com/ironmansoftware/universal-docs/blob/v5/cmdlets/New-UDStepper.txt)
* [New-UDStep](https://github.com/ironmansoftware/universal-docs/blob/v5/cmdlets/New-UDStep.txt)
* [New-UDValidationResult](https://github.com/ironmansoftware/universal-docs/blob/v5/cmdlets/New-UDValidationResult.txt)


---

# Agent Instructions
This documentation is published with GitBook. GitBook is the documentation platform designed so that both humans and AI agents can read, navigate, and reason over technical content effectively. Learn more at gitbook.com.

## Querying This Documentation
If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://docs.devolutions.net/powershell-universal/fr/apps/components/navigation/stepper.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
