Słowny opis procedury obiegu faktury.
Sekretariat tworzy dokument typu faktura w systemie. Uzupełnia formularz dokumentu, zamieszcza skan i po zapisaniu dokumentu w systemie uruchomiona zostanie procedura.
Ten etap rozpoczyna procedurę obiegu faktury.
-etap wykonywany przez użytkownika
-brak akcji
-brak własności
-przypisanie do grupy Sekretariat o identyfikatorze grp_id = 21
Własność:
{stages.orgarr}
Wyrażenie:
SELECT array_agg(o.orunid) FROM users_link_org_units o LEFT JOIN users_link_group g ON o.usr_id = g.usr_id WHERE g.grp_id = 21
Przypisanie zadania work-flow spowoduje, że dany etap w procedurze będzie możliwy do wykonania tylko przez przypisaną jednostkę. Zapytanie SQL powyżej wyświetla w tablicy identyfikatory jednostek z grupy o identyfikatorze grp_id = 21.
Oczywiście aby procedura prawidłowo zadziałała po zaimportowaniu, należy wstawić ID grupy, która ma odpowiadać za realizację tego zadania work-flow.
UWAGA. Funkcja array_agg(); jest obsługiwana od wersji 8.4 serwera bazy danych PostgreSQL. Jeżeli wersja serwera bazy danych jest niższa należy usunąć przypisanie z tego etapu.
Ten etap sprawdza, czy faktura została już zarejestrowana w dzienniku.
zarejestrowany:
SELECT reg_id IS NOT NULL FROM documents WHERE doc_id = {DOC_ID}
niezarejestrowany:
SELECT reg_id IS NULL FROM documents WHERE doc_id = {DOC_ID}
Warunki odnoszą się do kolumny reg_id z tabeli documents, która przechowuje identyfikator rejestru z którym dana faktura jest powiązana lub pustą wartość w sytuacji kiedy dokument nie jest powiązany z żadnym rejestrem.
-etap wykonywany przez system
-akcja (aktywacja):
Rejestr:
SQL::SELECT reg_id FROM registers WHERE reg_id = 4
-brak własności
-brak przypisania