Search the FirstSpirit Knowledge Base
Hallo Community,
ich möchte gerne auf einer PageRef eine Abfrage anwenden. Normalerweise habe ich das per Hand in der Struktur im Reiter Daten gemacht, indem ich die Abfrage ausgewählt habe. In der API gibt es eine Funktion Namens "setFilterParams(Map<String,Object> params)
". Wenn ich das richtig sehe, wende ich dies auf eine PageRef an. Jedoch ist mir nicht klar, welche Parameter ich da mit geben muss und wie ich diese bekomme.
Ist dies eigentlich die Richtige Funktion für mein anliegen?
Vielen Dank und Grüße
Peter
query = templatestore.getStoreElement("<uid>", de.espirit.firstspirit.access.store.templatestore.Query.UID_TYPE);
Versuch mal, ob der obige Code funktioniert, um an das Query zu kommen.
Du kannst überprüfen, ob "query" überhaupt einen Wert enthält, z.B. mit
context.logInfo("Query: " + query);
Ich bin mir nicht sicher, ob die uid, welche du oben genutzt hast, die richtige ist. Wenn es mit der von dir genutzten nicht funktioniert, würde ich es mal nur mit "tud_vorlagen.rubrikauswahl_aktuell" probieren.
Viele Grüße
Rouven
Hallo,
der richtige Weg erfolgt über das Interface Content2Params.
ja, darüber habe ich ja die Funktion gefunden. Nur weis ich nicht wie ich an die Parameter, die ich der Funktion übergeben soll, ran komme oder was das genau für Objekte sind. Also "Map<String,Object> params
".
Ein Codebeispiel wär sehr Hilfreich!
Gruß Peter
Die Parameter ergeben sich doch über das Query. Die kann man dann über eine neue map hinzufügen oder die vorhandene auslesen und den value setzen.
try {
pageRef.setLock(true, false);
c2p = pageRef.getContent2Params();
c2p.setRecordCountPerPage(1);
c2p.setMaxPageCount(1);
c2p.setQuery(query);
map.put(paramName, catName);
c2p.setFilterParams(map);
pageRef.save();
requestOperation.perform("PageRef successfully created");
} catch (LockException e) {
requestOperation.perform(e.getMessage());
} finally {
pageRef.setLock(false, false);
}
Danke für die schnelle Antwort.
Sehe ich das richtig, dass
setRecordCountPerPage()
= für die Anzahl der Einträge pro SeitesetMaxPageCount()
= für die maximale Seitenanzahlsteht?
Dann sind mir noch einige Sachen unklar.
setQuery()
= wählt die Query aus den Vorlagen aus, die ich verwenden möchte? Wenn ja, ist das einfach der Referenzname?map.put(paramName, catName)
= was wird damit erreicht und was steht hinter "paramName" und "catName"?Es tut mir leid, aber ich arbeite noch nicht so lange mit der API und wär für eine ausführlichere Beschreibung sehr dankbar.
peter.rossa schrieb:
Danke für die schnelle Antwort.
Sehe ich das richtig, dass
setRecordCountPerPage()
= für die Anzahl der Einträge pro SeitesetMaxPageCount()
= für die maximale Seitenanzahlsteht?
genau.
peter.rossa schrieb:
Dann sind mir noch einige Sachen unklar.
setQuery()
= wählt die Query aus den Vorlagen aus, die ich verwenden möchte? Wenn ja, ist das einfach der Referenzname?
Ja, das ist die Query aus den Vorlagen. Es ist nicht der referenzname sondern das Query Object was man sich vorher aus dem TemplateStore holen muss.Allerdings brauch man das nicht wenn die Query schon gesetzt wurde.
peter.rossa schrieb:
map.put(paramName, catName)
= was wird damit erreicht und was steht hinter "paramName" und "catName"?
Der paramName ist hier der Parameter name der in dem QueryObject benutzt wird, denn kann man wie schon gesagt auch aus der Query holen. catName ist hier der Vergleichswert. Wenn das Query z.B. einen Vergleich auf den Katergorienamen hat.
OK, das habe ich soweit verstanden. Jedoch klappt es nicht, eine Query zu setzen, da bei der Zeile map.put(paramName, catName)
immer ein Fehler geworfen wird:
"Attempt to resolve method: put() on undefined variable or class name: map at line 77"
Wo genau definier ich map und was ist der Inhalt?
Sehe ich das richtig, dass ich die Query mit dem Parameter und dem Wert nur komplett für die Pageref setzten kann.
Also duch folgende 3 Zeilen:
c2p.setQuery(query);
map.put(paramName, catName);
c2p.setFilterParams(map);
Ich habe es nur mit c2p.
setQuery(query);
versucht, jedoch wurde die Query nicht gesetzt. Lag das daran, dass kein Parameter und Wert angegeben wurde?
Hallo,
die Map kannst du vorher erstellen:
map = new java.util.HashMap();
Ich habe es nur mit
c2p.
setQuery(query);
versucht, jedoch wurde die Query nicht gesetzt. Lag das daran, dass kein Parameter und Wert angegeben wurde?
Woran erkennst du, dass die Query nicht gesetzt wird?
Es wird ja nicht zwingend für jede Abfrage ein Parameter benötigt. Insofern ist es auch möglich eine Query zu setzen ohne FilterParams zu definieren.
Wenn es nach dem deklarieren der Map immer noch nicht klappt, bitte einmal die Zeile(n) posten, in der "query" deklariert und initialisiert wird.
Viele Grüße
Rouven
Vielen Dank für die Antwort. Es kam kein Fehler mehr, jedoch wird die Abfrage immer noch nicht gesetzt, nachdem die Seitenreferenz in der Struktur angelegt wurde (siehe Screenshot).
Wie gewünscht, hier mein Code zur Fehlersuche:
/*--------------------- Imports -----------------------*/
import de.espirit.firstspirit.access.store.*;
import de.espirit.firstspirit.agency.*;
import de.espirit.or.query.*;
/*--------------------- get Language -----------------------*/
langAgent = context.requireSpecialist(LanguageAgent.TYPE);
langList = langAgent.getLanguages();
for(lang:langList) {
if(lang.getAbbreviation().equals("DE")) {
langDE = lang;
}
if (lang.getAbbreviation().equals("EN")) {
langEN = lang;
}
}
masterLang = langAgent.getMasterLanguage();
/*--------------------- show form -----------------------*/
data = context.showGui();
rubrikID = data.get("cs_kategorie").getEditor().get(lang).toString();
/*--------------------- stores -----------------------*/
storeAgent = context.requireSpecialist(StoreAgent.TYPE);
pagestore = storeAgent.getStore(Store.Type.PAGESTORE, false); // Inhalte
templatestore = storeAgent.getStore(Store.Type.TEMPLATESTORE, false); // Vorlagen
sitestore = storeAgent.getStore(Store.Type.SITESTORE, false); // Struktur
/*--------------------- Globale Variablen -----------------------*/
refPageName = "News (Details)";
query = templatestore.getStoreElement("Aktuelles_1_1@tud_vorlagen.rubrikauswahl_aktuell", IDProvider.UidType.TEMPLATESTORE);
target = context.getStoreElement();
detailSiteUid = "newsdetails_1";
/*------------------------------------------------------*/
detailSiteTemplate = pagestore.getStoreElement(detailSiteUid, IDProvider.UidType.PAGESTORE);
detailRefPage = target.createPageRef(refPageName, detailSiteTemplate);
detailContent2 = detailRefPage.createContent2Params();
detailRefPage.setLock(true, false);
try {
detailRefPage.getLanguageInfo(langDE).setDisplayName(refPageName);
detailContent2.setRecordCountPerPage(1);
detailContent2.setMaxPageCount(0);
detailContent2.setQuery(query);
map = new java.util.HashMap();
map.put("id", rubrikID);
detailContent2.setFilterParams(map);
detailRefPage.save("set display name and permissions", false);
} finally {
detailRefPage.setLock(false, false);
}
Vielen Dank im Voraus und Viele Grüße
Peter