# Słowniki warunkowe

{% hint style="info" %}
Dostępność funkcjonalności zależy od licencji i może nie być dostępna we wszystkich wdrożeniach.
{% endhint %}

Słowniki warunkowe są opcjonalnym wariantem zwykłych słowników. Za pomocą danych przekazanych do słownika istnieje możliwość napisania warunków JavaScript, które zadecydują o widoczności wybranych wartości ze słownika. Przykładowo podzbiór miast ze słownika miast na podstawie zadanego województwa.

## Definicja słownika

Okno definicji warunkowego słownika oprócz standardowych elementów będzie miało wypełnioną sekcję **Warunki widoczności**, **Parametry wejściowe** oraz klucze i wartości powiązane warunkami wyświetlania.

## Definicje warunków

Warunki dodajemy w panelu bocznym **Warunki widoczności**, który wysunie się po kliknięciu w lewej belce przycisku ![](/files/35054af01e23893599386b5b3b3d929d1662fb45).

Każdy wiersz oznacza jeden warunek, indeks pozwala powiązać warunek z kluczami i wartościami słownika. Warunek powinien być opisany wyrażeniem JavaScript, wykorzystując dane wejściowe z mapowania.

![Ilustracja 1. Przykładowe warunki zdefiniowane dla słownika](/files/891c6fe14ba042443264a02c4bb641b44acd1c40)

## Mapowanie pól wejściowych

W panelu **Parametry wejściowe**, który wysunie się po kliknięciu w lewej belce przycisku ![](/files/6a307c1cdcaa1be7198fc414987b6c22f257e170), możemy określić dane wejściowe do słownika. Kolumna **Zmienna** oznacza nazwę zmiennej, której będziemy mogli używać w wyrażeniach JavaScript definiując warunki, a **Alias** oznacza nazwę zmiennej widoczną przy podpinaniu słownika jako źródła danych.

![Ilustracja 2. Panel z przykładowymi parametrami wejściowymi](/files/e3d4697cba5091bc05e7eaa3909b45688d753012)

## Mapowanie warunków na klucze

Każdy warunek zdefiniowany wcześniej ma swoje odzwierciedlenie w tabeli kluczy i wartości jako kolumna, zgodnie z nadanym indeksem. Zaznaczenie checkboxa na przecięciu wiersza z kluczem i kolumną z warunkiem oznacza, że wartość będzie widoczna, gdy warunek zostanie zewaluowany na true.

![Ilustracja 3. Przykład wierszy słownika ze zmapowanymi warunkami](/files/c69105a3d558b88d901710e4239416920d16cb37)

## Ewaluacja warunków

Warunki są ewaluowane w kolejności wynikającej z indeksu (co ma przełożenie na: od lewej do prawej w tabeli kluczy), przy czym **pierwszy warunek który ewaluuje się na true determinuje zbiór wyświetlanych wartości**.

## Użycie warunkowego słownika

Słownik warunkowy podpinamy w taki sam sposób jak słownik zwykły (instrukcja: [Podpięcie słownikowego źródła danych](/budowanie-aplikacji/interfejs-uzytkownika/formularze/praca-z-komponentami-bazowymi/zasilanie-wartosciami-z-zewnetrznych-zrodel/podpiecie-slownikowego-zrodla-danych.md)). Jedyna różnica polega na tym, że należy dodatkowo wskazać mapowania parametrów wejściowych na komponenty:

![Ilustracja 4. Przykład mapowania pól wejściowych słownika na komponenty wniosku](/files/513f79ae34b82aee50c69427ef598f0540bb1146)

{% hint style="info" %}
Wnioski demo: demoSlownikiWarunkowe, demoCombobox
{% endhint %}


---

# Agent Instructions: 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.eximee.com/budowanie-aplikacji/interfejs-uzytkownika/slowniki/slowniki-warunkowe.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.
