Server Admin und Senior Entwickler
demandflow.deAnsehen
Abzeichen 7
Editor Frischling 10 × Eureka! Anfänger Enthusiast Reporter UnterstützerWenn ich nicht falsch liege ist das so einfach leider nicht.
Meiner Ansicht nach sind die Inboxes auch nur SQL-Views auf die DB.
Der einfachste Weg dahin wäre wahrscheinlich über die API, da diese die Vorgänge und Schritte pro Inbox ausgeben kann.
GET /application/workitemboxes/:inbox/processes
liefert die Vorgänge dieser Inbox. Man könnte einen Call auf die drei Inboxes machen und die jeweiligen Vorgänge zurück liefern.
Ich begrüße Sie,
dies nennt die JobRouter "MultiSelect"-Felder. Hierzu gibt es zwei Bibliotheken, einmal die von Timo Günter gefundenen "Selectize" und "Select2", wobei sich ersteres mehr durchgesetzt hat und meines Wissens mit dem JobRouter mitgeliefert wird.
Wie funktioniert das? Üblicherweise gibt es ein Anzeige-, und ein Speicherfeld, wobei im Speicherfeld eine JSON-Codierte oder kommagetrennte Liste ebgelegt wird, welche beim Laden des Dialoges wieder in das Multiselect-Ansichtsfeld ko...
Ja, durch die Abfrage der gewünschten Subtable-Fields im SQL-Statement können die Werte kommagetrennt angezeigt werden.
(Select SUBSTRING((
SELECT DISTINCT ', ' + ISNULL(Feldname,'') AS 'data()'
FROM Untertabellenname
WHERE step_id=JRINCIDENTS.process_step_id
FOR XML PATH('')), 2 , 9999)) As Ergebnisfeld,
Moin,
wenn Du in den Editor klickst und dann Ctrl+F drückst kriegst du ein Suchen-Fenster. Wenn Du das aufklappst hat das eine Suchen und Ersetzen Funktion wie man sie kennt.
Grüße
Stefan

In diesem Fall hat die JobRouter-Engine bei SUM(amount) das (amount) mit dem Prozesstabellenfeld ersetzt.
Nach einer Änderung zu SUM( amount )(man beachte hier die Leerzeichen) sollte die Abfrage nun auch im Dialog funktionieren.
Hallo,
ich gebe auch mal meinen Senf dazu.
Ich glaube, dass du es dir komplizierter machst als notwendig. Wenn ich deine Beschreibung richtig verstanden habe, dann bereitest du deine Daten auf für einen folgenden E-Mail-Schritt.
Dies im Frontend zu machen mit timeouts und allem drum und dran wird nicht verlässlich funktionieren, da du den netzwerkseitigen Aspekt der Enduser betrachten musst und deren Performance nicht kennst. Daher die Frage:
Was hält dich davon ab, die Funktionalität sch...
Moin,
setz dir einen Marker in der Prozesstabelle (z.B. PT-Feld WAS_REJECTED = 1) und setz in dem Schritt eine Weiterleitungsregel an erster Stelle mit einer Bedingung. Bedeutet die Weiterleitung wird nur ausgeführt wenn diese Kondition zutrifft.

Moin,
diese JS-Funktion triggert lediglich die Schrittaktion "Springe zu", sofern für den Schritt in den Schritteigenschaften aktiviert:


Moin, da kommt ggfs noch eine Antwort von den größeren Front-End Spezialisten, aber üblicherweise legen wir eine ausgeblendete Sektion auf dem Dialog an (Beispiel #Rueckfrage) mit allen Feldern die wir brauchen und erzeugen dann einen jQuery Dialog-Popup mit dem INhalt dieser Section. Hat den schönen Vorteil, dass dieser Dialog im Standard-JR gebaut werden kann und das Design komplett dem JobRouter-CI entspricht. Hier ein Beispiel
https://jqueryui.com/dialog/#modal-confirmation
Hey,
ich habe hier eine Beispiel-Aktivität liegen, da ist in der getActivityType() nicht
return SystemActivity::ACTIVITY_TYPE_NON_PHP;
sondern
return parent::ACTIVITY_TYPE_NON_PHP;
Aber das kann auch damit nichts zu tun haben...
Moin,
das ist über JR lösbar. Es folgen drei Screenshots mit der Konfiguration einer RadioButton-Group und dem Ergebnis. Der Wert 1 oder 0 wird entsprechend gesetzt.
Gruß



Hey Marc,
ich würde dann den Prozess nicht über JobImport starten sondern über die REST-API, dann bekommst du direkt die ProcessID zurück und kannst dann damit weiter arbeiten, würde das gehen?
Grüße
Hey,
ja haben wir, siehe wie folgt. Kann man aus Dialogfunktionen und aus Regelausführungsfunktionen nutzen.
ACHTUNG: Der Aufruf von Utility:: funktioniert glaub ich ab 2024.1 nicht mehr. Muss man den Pfad klassisch zusammenbauen.
private function createExcel($preparedArray) {
require_once(Utility::getJobRouterPath() . '\library\vendor\phpoffice\phpspreadsheet\src\Bootstrap.php');
$spreadsheet = new \PhpOffice\PhpSpreadsheet\Spreadsheet();
$spreadsheet->ge...
Hey, auf den ersten Blick (und ungeprüft) bin ich der Ansicht, dass die Hauptdatei zwingend SystemActivity.php heißen muss.
Hast du etwas in den Logs?
Moin,
es geht um diesen Code:
$$('.jr-section-title.sectionName').each(function(element) {
$(element).stopObserving('click');
});
"$$" ist im JobRouter ein "Shorthand" für die Funktion Prototype.Selector.select(expression, document), welche einen Selector entgegennimmt und ein Array an zutreffenden Elementen zurück gibt. Über diese wird dann mit dem "each" iteriert und jedem davon wird gesagt, nicht mehr auf Clicks zu hören. Heißt diese Funktion deaktiviert das ...
Ja, den Inhalt des Cache-Verzeichnisses sicherheitshalber in einen Backup-Ordner verschieben und dann folgende URL aufrufen
http://meinJobRouter/jobrouter/setup/scripts/generateConfigurationcache.php
Vorsicht, in älteren JR-Versionen kann es vorkommen, dass /cache/tpl_cache und die Unterordner "Mobile" und "Screen" nicht erzeugt werden können und vom Admin erzeugt werden müssen.
Wahrscheinlich hast du eine neuere Version aber laut meiner Doku fehlt da das "v2"
GET https://meinefirma.de/jobrouter/api/rest/v2/designer/process/superprozess/1/phpfunctions
Moin!
Ich war mir zuerst kurz nicht sicher, ob Ihr die "inoffizielle" API von Chris Müller meint, einem JR Entwickler in privater Kapazität
Link hier
oder die offizielle Erweiterung aus der JR Repo,
Link hier
Persönlich kenne ich das Projekt, habe es aber nicht im Einsatz. Aber eine nette Sache, dass es angeboten wird.
Moin Moin,
das ist natürlich eine sehr individuelle Frage, da jeder Entwickler da eigene Präferenzen hat.
Wichtig ist jedoch vorneweg die Konsistenz.
Wenn ich zu einem bestehenden Projekt dazukomme dann analysiere ich die bisherigen Konventionen und führe diese weiter.
Wenn ich mit jemandem zusammen einen neuen Prozess entwickle dann spreche ich mich mit jener Person ab, sodass es konsistent ist.
Wenn ich jedoch alleine einen neuen Prozess entwickle mache ich es üblicherweise so:
Date...
Hey Jan,
Dominic kam mir zuvor aber ja, es gibt noch ein verstecktes User-Feld, welches an dieser Stelle befüllt werden muss. Etwas fies:

Hey Swen,
wenn JR in deinem Kontext das (TABELLENFELD) nicht auflöst wirst du nicht umher kommen, einen kleinen Umweg über eine Dialogfunktion zu drehen, also sowas wie
jr_execute_dialog_function('fetchFieldInfo', {},
function (resultObject) {
jr_notify_info(returnObject.result.myMessage);
},
function(errorObject) {
jr_notify_error(errorObject.message);
});
Aufgrund der Datenbakclients müssen Transaktionen auf externen Datenbanken selbst organisiert werden, also Regeln im Regelablauf speziell mit BEGIN TRANSACTION, COMMIT und ROLLBACK angelegt werden.
Problem: Wenn man in einem Schritt mehrere Regeln hat und die Regel mit der Transaktion auf die externe DB erfolgreich durchläuft (und man die Daten committed), aber eine der nachfolgenden Regeln Fehler verursacht, dann wird der JobRouter-Schritt zurückgerollt, die schon committete Transaktion a...
Moin,
zweierlei:
die Zeitüberwachung ist jetzt bei den Weiterleitungsregeln
Und die Eskalationen sind Rechte Maustaste auf dem Schritt --> Eskalationen
EDIT:
Teil 1 steht in JRRULES

übersetzt sich zu
processname version step rule_id parent_id label category always ...
Moin,
welche JobRouterVersion fahrt ihr denn? Der phpfunctions-endpoint kam erst vor Kurzem dazu. In meinen JobRoutern existiert der zum Beispiel noch nicht.
Du kannst die verfügbaren Endpoints deines JR einsehen via
https://meinServer.de/jobrouter/api/rest/v2
Ich sehe den erst irgendwann ab den 2022er Versionen
Ich habe die andere Frage gelöscht. Welche JobRouter-Version ist es denn? Wir können schauen ob man am Montag mal einen Teams-Call macht und drauf schaut
Hi,
vielleicht noch ein weiterer Ansatz als Ergänzung zu den Punkten von Jan:
Was passiert vor dem TTFB:
- DNS lookup: Mach mal intern einen DNS Lookup von einer ungecacheten Maschine und schau ob vielleicht Euer DNS intern aktuell Probleme macht. Dies würde sich wahrscheinlich aber noch auf weitere Dinge auswirken in Eurem Netz
- SSL handshake: Normalerweise unproblematisch aber wer weiß
- Webserver-Verarbeitung: Nutzt Ihr Redis oder irgendwelche erweiterten Caches, die erst abgefra...
Man kann über eine DialogFunction xlsx generieren.
Man sammelt die Daten in einer Map und macht dann im JS so etwas in der Richtung (verkürzt aus einem Projekt und ungetestet)
JS:
jr_execute_dialog_function(
'getXlsx',
{ data: data },
function(/** @type {{ status: string; result: { data: string; }; }} */ response) {
if (response.status === 'ok') {
var a = document.createElement('a');
...
Hallo,
ich würde es hier wahrscheinlich tatsächlich über die API machen. Der korrekte Weg den iframe zu befüllen ist folgendermaßen:
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, "https:// . . ./api/rest/v2/application/jobarchive/archives/ARCHIVNAME/documents/" . $revId . "/file");
curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_BINARYTRANSFER, true);
curl_setopt($ch, C...
Dieser Link ist nur für diesen Schritt gültig. Er verfällt auch nicht. Sollte der Schritt inzwischen bearbeitet worden sein, dann wird der Schritt im üblichen "Bearbeitet"-Modus (also readonly) geöffnet.
Der Link kann nicht manipuliert werden, beispielsweise durch die Änderung der User-ID, da er gegen eine Checksum geprüft wird und dann als ungültig erkannt wird.
Der Key kann weder für die REST API noch für den Webservice genutzt werden.
Technisch gesehen ist es kein Cookie/Token welc...
Ja, das ist möglich.
Via JS kann - zum Beispiel im onLoad - folgender Code aufgerufen werden:
$$('.jr-section-title.sectionName').each(function(element) {
$(element).stopObserving('click');
});