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.
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?
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...
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.
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.

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

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
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 ...
Moin,
diese JS-Funktion triggert lediglich die Schrittaktion "Springe zu", sofern für den Schritt in den Schritteigenschaften aktiviert:


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,
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ß



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, 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.
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...
Das kann fies sein. Man beachte den vierten Parameter der Dokumentation dieser Funktion.<br>
$this->getSubtableValue($sub, $field, $row, $raw); <br>
Setzt man $raw auf true, dann bekommt man laut Doku den "rohen Wert" zurück.
Effektiv muss man das setzen, um bei Datumswerten die Uhrzeit mit zu bekommen.
Hey,
hast du mal versucht, dir die Dialog-XML aus der Datenbank zu ziehen und in dem Editor deiner Wahl zu analysieren? Kann es sein, dass es tatsächlich ein Feld gibt, welches dort nicht rein gehört? Es klingt erstmal so als ziehe er die Struktur und hat einen Fehler dabei, diese zu rendern da ein nicht valides Feld dabei ist.
Alternativ würde ich versuchen, mal einen neuen, leeren oder minimalen Dialog dem Schritt zuzuordnen und zu schauen, ob dieser geladen wird.
Grüße
Stefan
Moin,
mein Verständnis ist, dass man mit
jQuery( '#meiniFrame' ).attr( 'src', function ( i, val ) { return val; });
das Element dazu überreden kann zu glauben, dass der source-Wert neu gesetzt wurde und damit den Inhalt neu lädt.
Ggfs muss man die Funktion etwas anpassen, damit der neue Link generiert wird oder so?
Moin Moin,
ich sehe zwei Sachen die du mal probieren könntest:
- Eigentlich brauchst du auf Dialogfunktionen kein save (außer du willst den neuen Zustand wirklich speichern). Wenn du das möchtest, probier mal bitte - und ich weiß wie doof das klingt - save zwei mal hintereinander aufzurufen. Wir haben damit tatsächlich schon so seltsame Verhalten gelöst bekommen.
- Die schönere Lösung ist eigentlich aber die Zeilen per JS zu kopieren, dann bekommen die User auch nicht den Ladebildsch...
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');
});
Moin
einfachste Variante ist das Admin-Log in den Usereinstellungen zu aktivieren, dann kommt regelmäßig eine Mail mit den fehlerhaften Schritten etc.
Moin,
wenn die Einträge in eine JobData geschrieben werden kann man theoretisch über die REST-API prüfen, ob eine Zeile existiert zu den neuen Benutzerdaten und dann den Schritt mit sowas wie
$sql = "UPDATE JRINCIDENTS SET status=0, step_status=99 WHERE workflowid=:wfid";
senden.
Alternativ kann man einen Schritt in Wiedervorlage schieben, der sich dann hin und wieder neu startet und mit einem Skript auf etwas prüft. Alternativ kann man einen Hilfsprozess schreiben der nur nach...
Hey Jan,
ich bin mir nicht sicher ob dir das hilft aber hier ist, wie wir es in unseren Systemaktivitäten lösen:
Am Beispiel aus unserer SalesForce-Aktivität:
<outputParameters>
<list id='accountOutput' name='CONST_ACCOUNT_FIELD_LIST' desc='CONST_ACCOUNT_FIELD_LIST_DESC' fix_subtable='no' udl='accountFieldList' worktable='no' subtable='yes' fixed='no' datatype='varchar' required='yes' default='1' />
</outputParameters>
Man beachte den Parameter "udl='accountFieldL...
Moin,
es ist tatsächlich so, dass für Simulator-Schritte nicht alle Funktionen verfügbar sind und die Informationen teilweise in anderen DB-Tabellen geführt werden. REST-Sachen würde ich nicht versuchen auf Simulator-Prozesse zu fahren.
Zur eigentlichen Frage:
- Du hast zwei Möglichkeiten. Entweder tatsächlich via PHP oder sonstige Wege direkt in die Datenbank die step_status-Werte setzen. In einer Deiner anderen Fragen habe ich dazu glaube ich den Code gepostet.
- Du müsstest Nicht-Sim...
Wir benutzen häufiger folgende Funktion, welche wir im onLoad aufrufen
jQuery('div.subtable').css('overflow', 'hidden');
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
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');
...
Moin,
der Trick ist ein neues Skript hinzuzufügen und bei der Skriptart "Andere" zu wählen.
Das hier funktioniert bei mir:

Moin,
das ist ein systemseitiger Fehler, kein spezieller JobRouter-Fehler, aber kannst Du mal probieren die DLL neu zu registireren? Es kann sein dass diese beim Update ausgetauscht wurde und entweder nicht registriert wurde oder nicht korrekt ausgetauscht und korrupt ist.
Mach eine Admin-cmd auf, navigiere in den Ordner C:\Windows\System32\ und führe aus
regsvr32 KERNELBASE.dll