...
Element | Opis | Przykłady akcji | Wybór w PWE | ||||||
---|---|---|---|---|---|---|---|---|---|
ActionDestination.form() | Formularz Akcja dodana do formularza inicjowana jest metodą | Akcje w których nie można wskazać głównego elementu np.
| |||||||
ActionDestination.variable() | Zmienna Akcja dodana do zmiennej formularza inicjowana jest metodą
| Akcje w których można jednoznacznie wskazać zmienną, której akcje dotyczy (w największym stopniu) np.
| |||||||
ActionDestination.variableSet() | Tabelka dynamiczna Akcja dodana do zmiennej formularza inicjowana jest metodą
| Akcje które dotyczą tabelki dynamicznej i potrzebują jej identyfikator np.
| |||||||
ActionDestination.button() | Przycisk Akcja dodana do przycisku formularza inicjowana jest metodą
| Akcje których źródłem jest przycisk np.
|
Inicjalizacja akcji
Warning |
---|
Funkcjonalność jeszcze niedostępna. |
Twórca procesu w akcji określić może jej typ inicjalizacji. Dostępne typy:
- Brak inicjalizacji (NONE)
- Pojedyncza inicjalizacja (SINGLE)
- Ciągła inicjalizacja (CONTINUOUS)
Wybrany parametr jest możliwy do odczytu w akcji w funkcji getInitializationType. Ustawienie tego parametru NIE WPŁYWA na działanie akcji, jeżeli nie zaimplementował tego twórca akcji.
Przypisanie elementu docelowego do parametru (bindTo)
...
Code Block |
---|
PW.FormActions.create('message', { // domyślne akcje defaultActions: { button: function(button){ this.showMsg(); }, variable: function(variable, newValue, oldValue){ this.showMsg(); }, variableSet: function(variableSet, added, updated, removed){ this.showMsg(); } }, showMsg: function(){ ServiceFactory.getMessageService().showSuccess(this.get('msg')); } }); |
Wiele źródeł (targetów) akcji
Warning |
---|
Funkcjonalność jeszcze niedostępna. |
Możliwe jest określenie więcej niż jednego źródła (targetu) dla akcji np. w celu wywołania dokładnie tej samej akcji, jeżeli została zmieniona wartość jednej z wielu określonych zmiennych. Aby dodać wsparcie do wielu targetów dla akcji, w builderze należy wywołać multitarget():
Code Block | ||
---|---|---|
| ||
@Define
public void action( ActionDefinitionBuilder action )
{
action
.id( "hide-variables" )
.name( "action.hide-variables.name" )
.description( "action.hide-variables.desc" )
.icon( SilkIconPack.EYE )
.category( Categories.TEST )
.multitarget()
.destination( ActionDestination.button() )
.parameter()
.id( "variables" )
.name( "action.hide-variables.variables.name" )
.description( "action.hide-variables.variables.desc" )
.type( Types.VARIABLE_ARRAY )
.create();
} |
Jeżeli akcja została dodana (przeciągnięta) do:
- przycisków
- zmiennych nagłówkowych
- tabeli
możliwe jest dodanie kolejnych obiektów tego samego typu jako źródeł wywoływania akcji. Jeżeli źródłem jest tabela, kolejno dodawane obiekty muszą być zmiennymi tabelarycznymi. Akcja pozostaje jednym i tym samym obiektem JavaScriptowym, lecz więcej niż jeden obiekt może wywołać zdarzenia defaultActions:
- dla przycisków - każdy z dodanych przycisków wywołuje po kliknięciu zdarzenie button przekazując do funkcji zdarzenia samego siebie
- dla zmiennych nagłówkowych - każda z dodanych zmiennych po zmianie wartości wywołuje zdarzenie variable przekazując do funkcji zdarzenia samą siebie
- dla tabeli - jeżeli nie określono dodatkowych zmiennych tabelarycznych, każda zmiana w tabeli dynamicznej wywołuje zdarzenie variableSet. Jeżeli określono dodatkowe zmienne - zmiana w tabeli dynamicznej wywołuje zdarzenie variableSet tylko wtedy, gdy zmiana zaszła w którejś ze zdefiniowanych zmiennych tabelarycznych (przy dodaniu lub usunięciu wiersza zdarzenie variableSet jest zawsze wywoływane).
Również inicjalizacja akcji dla określonych zmiennych zmienia nieznacznie swoje zachowanie:
- buttonInit - przekazuje tablicę przycisków (nawet, gdy określony został tylko jeden przycisk)
- variableInit - przekazuje tablicę zmiennych nagłówkowych (nawet, gdy została określona tylko jedna zmienna)
Symbol błyskawicy zostaje wyświetlony przy każdym z dodanych targetów, lecz edycja takiej akcji jest globalna.
Rejestracja akcji we wtyczce
...