Questions & Answers

SOLVED
j_mueller
Elite Observer

Absatz in FS_LIST per WebEdit / ContentCreator bearbeiten

Jump to solution

Hallo Community,

wir versuchen zur Zeit in einigen Templates die Bearbeitung im WebEdit bzw. ContentCreator zu ermรถglichen.

Leider hakt es bei der FS_LIST etwas. Bisher ist es uns nicht mรถglich die einzelnen Absรคtze direkt editierbar zu machen. Zum Einsatz kommt eine Normale FS_LIST mit DATASOURCE 'inline'.

Die Ausgabe sieht nun folgendermaรŸen aus:

<div class="clearfix fs-list" $CMS_VALUE(editorId(target:#row.sections, editorName:"st_listing"))$>

    $CMS_FOR(s, #row.sections)$

        <div class="section" $CMS_VALUE(editorId(target:s))$>

            $CMS_VALUE(s)$

        </div>

    $CMS_END_FOR$

</div>

(Preview-Screenshot im Anhang)

Testweise habe ich im umschlieรŸenden DIV den Editor aktiviert. Durch den Parameter editorName erscheint im Popup auch nur die entsprechende FS_LIST, genau wie man es erwarten wรผrde. (Ausnahme: Wenn man die Sprache wechselt, kommt das komplette Formular => Bug?)

Lieber wรคre uns aber, wenn jeder Absatz fรผr sich editierbar wรคre, daher habe ich, wie in der Doku beschrieben, zunรคchst den target-Parameter gesetzt und die entsprechende Section รผbergeben. Leider erscheint beim Editieren das komplette Formular der Entity. Das Ergebnis ist also 'schlechter' als, wenn man den Bearbeitungsbutton der gesamten Liste anklickt. (Mit den Pametern element und editorName habe ich auch schon etwas gespielt, leider ohne Erfolg.)

Wie schon der #row Parameter erahnen lรคsst, befinden wir uns auf einer Detailseite mit Content-Projektion.

FS-Version: 5.1.311.65223

Wir wรผrden uns freuen, wenn jemand einen Lรถsungsansatz parat hรคtte...

Schรถne GrรผรŸe

Julius

0 Kudos
1 Solution

Accepted Solutions

Hi Julius,

ich glaube, der Groschen ist gerade bei einer Diskussion mit meinem Kollegen gefallen. Versuche doch bitte mal, statt #row.sections nur sections einzusetzen. Die inneren Editoren eines Datensatzes werden innerhalb der Auswertung jeweils direkt in den Kontext gepackt und kรถnnen dort ohne #row angesprochen werden. Hier erfolgt auch das Hinzufรผgen der nรถtigen Zusatzinformation, die fรผr die editorId()-Funktion benรถtigt wird.

Beste GrรผรŸe

Stefan

View solution in original post

0 Kudos
7 Replies
StefanSchulz
I'm new here

Hallo Julius,

bin auch nach lรคngerem Grรผbeln auf keine Idee gekommen, woran es in deinem Beispiel hakt. Kannst du mal die Java-Klasse von s ermitteln und hier posten?

Was auf jeden Fall gehen sollte, wenn der Block mit editorId() in der Vorlage definiert ist, die fรผr die Ausgabe von s genutzt wird.

Beste GrรผรŸe

Stefan

0 Kudos

Hallo Julius,

wie ist der aktuelle Stand deines Problems? Falls du noch weitere Unterstรผtzung benรถtigst, solltests du Stefans Frage beantworten. Wenn du dein Problem bereits lรถsen konntest, wรคre es gut, wenn du die Lรถsung hier kurz beschreiben wรผrdest.

Viele GrรผรŸe

Tim

0 Kudos

Hallo Stefan,

ich habe mich nun um andere Aufgaben in dem Projekt gekรผmmert, aber das Thema ist noch aktuell und ich habe keine Lรถsung.

Die Klasse von s ist:

de.espirit.firstspirit.client.access.editor.FormDataImpl

Innerhalb des Absatztemplates habe ich auch schon versucht einfach folgendes zu setzen:

<div class="fold-wrap">

  <div class="body" $CMS_VALUE(editorId())$>$CMS_VALUE(st_body, default:"")$</div>

</div>

Dann erscheint beim Hovern ein roter Rahmen ganz ohne Buttons.

Gleiches verhalten, wenn ich mir im รคuรŸeren Datenbanktemplate das Feld aus der FormData hole:

$CMS_VALUE(editorId(target:s.get(#global.language, "st_body")))$

Und auch, wenn ich in der Section #this รผbergebe:

$CMS_VALUE(editorId(target:#this))$

Weitere Ideen habe ich leider nicht...

Schaffst du es denn ein Datenbanktemplate mit FS_LIST und editorId() je Section aufzubauen?

Schรถne GrรผรŸe

Julius

P.S.: Bei mir steht immer, dass die Frage als beantwortet angenommen wurde... Das ist aber nicht der Fall... ๐Ÿ˜‰

0 Kudos

Hi Julius,

ich glaube, der Groschen ist gerade bei einer Diskussion mit meinem Kollegen gefallen. Versuche doch bitte mal, statt #row.sections nur sections einzusetzen. Die inneren Editoren eines Datensatzes werden innerhalb der Auswertung jeweils direkt in den Kontext gepackt und kรถnnen dort ohne #row angesprochen werden. Hier erfolgt auch das Hinzufรผgen der nรถtigen Zusatzinformation, die fรผr die editorId()-Funktion benรถtigt wird.

Beste GrรผรŸe

Stefan

0 Kudos

Hi Stefan,

erstmal vielen Dank fรผr die Antwort.

Ich verstehe jedoch nicht ganz, wie du es meinst - wobei mir gerade auffรคllt, dass ich vielleicht die neueste Info vergessen habe:

Der รคuรŸere Editor der Sections funktioniert mittlerweile. Es kommt also nicht das ganz Formular, sondern nur die zu editierende FS_LIST:

<div class="sections" $CMS_VALUE(editorId(view:"content_sgg", target:#row.sections, editorName:"st_listing"))$>

   $CMS_IF(!#row.sections.isEmpty())$

       $CMS_FOR(section, #row.sections)$

           <div class="contentContainer" $CMS_VALUE(editorId(target:section))$>$CMS_VALUE(section)$</div>

       $CMS_END_FOR$

   $CMS_END_IF$

</div>

Dabei spielt es keine Rolle ob ich #row.sections oder sections verwende. Beides funktioniert nur, wenn ich den Parameter view mitgebe.

Das innere Konstrukt funktioniert nach wie vor nicht. Auch wenn ich in der inneren Vorlage (also in der Vorlage innerhalb von $CMS_VALUE(section)$) die editorIds nur mit editorName angebe, klappt es leider nicht...

Schรถne GrรผรŸe

Julius

0 Kudos

Hi Julius,

hast du mal geschaut, welche Klassen sections und section haben, wenn du nicht mit #row arbeitest?

GruรŸ

Stefan

Hi Stefan,

okay das war der entscheidende Hinweis!

Vielleicht vorher noch etwas zur Erklรคrung: Das Feld in unserer Datenbank heiรŸt 'sections' (also #row.sections). Das Feld im Formular heiรŸt 'st_listing'. (nicht fragen, historisch bedingt...)

Der Unterschied ist also:

#row.sections (db): de.espirit.firstspirit.client.access.editor.FormDataListImpl

st_listing (form): de.espirit.firstspirit.generate.IdentifiableFormDataList

Beide lassen sich loopen, die Kind-Elemente sind dann:

(db-feld): de.espirit.firstspirit.client.access.editor.FormDataImpl

(form-form): de.espirit.firstspirit.generate.IdentifiableIdProvidingFormData

Mit letzterem Funktioniert es wie es soll...

Jetzt nochmal kurz dazu, warum alles nicht frรผher funktioniert hat (falls jemand eine รคhnlichen Projektaufbau hat):

Wir haben im System eine Datenbankvorlage namens 'content'. Das ist die Standard-Vorlage, รผber die wir 90% der Inhalte ausgegeben. Dort ist auch das Formular, รผber das die Daten gepflegt werden.

Nun haben wir einen Bereich, der vom Standard abweicht - also eine andere Ausgabe besitzt. Fรผr den gibt es eine andere Datenbankvorlage, die sich auf die selbe Datenquelle bezieht. Diesen Bereich wollten wir jetzt รผber den ContentCreator Pflegbar machen. In dieser Vorlage gibt es jedoch kein Formular...

Irgendwie bin ich jetzt davon ausgegangen, dass FirstSpirit auch ohne Formular in der Lage ist den richtigen Editor zu erzeugen. Dass das rein von der Logik her so nicht ganz klappen kann, ist mir jetzt auch bewusst geworden.

Bei den anderen Feldern hat es jedoch durch Angabe der view funktioniert:

<div class="headline" $CMS_VALUE(editorId(view:"content_sgg", editorName:"cs_headline", target:#row.headline))$>

   $CMS_VALUE(if(#row.headline.empty, "<i>รœberschrift</i>", #row.headline))$

</div>

Also verstehe ich das richtig, dass man bei einfachen Feldern praktisch ein beliebliges Datenbank-Template zum Rendern verwenden kann und dann durch Angabe der View zum einen die Rechte auf den Datensatz und das Template, und durch Angabe von 'editorName' das Formular-Feld und durch target das Datenbank-Feld definieren kann?

Geht das denn jetzt auch fรผr komplexe Felder wie die FS-List?

Oder kann ich den ContentCreator generell nur verwenden, wenn mein Template ein Formular besitzt? Wie ist hier die Best Practice, wenn man mehrere Datenbankvorlagen verwenden mรถchte, ohne dann mehrere gleiche Formulare zu definieren? (Bei ร„nderungen fehleranfรคllig...)

Schรถne GrรผรŸe

Julius

0 Kudos

Type a product name