Handbuch:Erweiterung/Page Forms: Unterschied zwischen den Versionen

(Die Seite wurde neu angelegt: „{{DISPLAYTITLE:Seitenformulare (Page Forms)}} <section begin="training-intro" /> Mit '''Page Forms''' können Benutzer auch ohne Administrator-Rechte Formular…“)
Markierung: 2017-Quelltext-Bearbeitung
 
Keine Bearbeitungszusammenfassung
Markierung: 2017-Quelltext-Bearbeitung
Zeile 2: Zeile 2:
<section begin="training-intro" />
<section begin="training-intro" />


Mit '''Page Forms''' können Benutzer auch ohne Administrator-Rechte Formulare zum Erstellen und Bearbeiten von Seiten zum Abfragen von Daten verwenden - ohne Programmierung. Die Verwendung der Erweiterung ist [[mediawikiwiki:Extension:Page_Forms/de|auf MediaWiki dokumentiert]].
Mit '''Page Forms''' können Benutzer auch ohne Administrator-Rechte Formulare zum Erstellen und Bearbeiten von Seiten zum Abfragen von Daten verwenden - ohne Programmierung.  
 
Die Verwendung der Erweiterung ist ausführlich :Extension:Page_Forms/de|auf MediaWiki dokumentiert]].
<section end=.
<section end="training-intro" />
<section end="training-intro" />
==Hauptmerkmale==
==Hauptmerkmale==
Zeile 8: Zeile 11:
<section begin="slide-training" />
<section begin="slide-training" />


*'''Definitionsseiten im Namensraum ''Formular'''''<section end="slide-training" />                                       Formulare können über die Spezialseite <code>Spezial:CreateForm</code> erstellt werden. Hier wird die entsprechende Vorlage ausgewählt, deren Parameter-Werte über das Formular eingegeben werden sollen. Das heißt, bevor ein Formular erstellt wird, wird immer zuerst die hierzu nötige [[mediawikiwiki:Help:Templates/de|Vorlage]] erstellt. Alle erstellten Formular-Definitionsseiten werden im Namensraum Formular gespeichert. Die Bearbeitung  von bereits erstellten Formular-Definitionsseiten erfolgt über den Quelltext der Seite.
*'''Definitionsseiten im Namensraum ''Formular'''''<section end="slide-training" />                                           Formulare können über die Spezialseite <code>Spezial:CreateForm</code> erstellt werden. Hier wird die entsprechende Vorlage ausgewählt, deren Parameter-Werte über das Formular eingegeben werden sollen. Das heißt, bevor ein Formular erstellt wird, wird immer zuerst die hierzu nötige [[mediawikiwiki:Help:Templates/de|Vorlage]] erstellt. Alle erstellten Formular-Definitionsseiten werden im Namensraum ''Formular'' gespeichert. Die Bearbeitung  von bereits erstellten Formular-Definitionsseiten erfolgt über den Quelltext der Seite.
<section begin="slide-training" />
 
*'''Anwendungsbeispiel: Infoboxen'''<section end="slide-training" />                                        Die Erweiterung wird oft zum Hinzufügen und Bearbeiten von Infobox-Vorlagen verwendet. Wenn [https://www.semantic-mediawiki.org/wiki/Semantic_MediaWiki/de Semantic MediaWiki] verwendet wird, können die über das Formular gesammelten Daten in den Vorlagen gespeichert und im Wiki abgefragt werden.
<section begin="slide-training" />
<section begin="slide-training" />


*'''Vorhandene Daten über Menüpunkt bearbeiten'''<section end="slide-training" />                                       Bereits bestehende Daten können unter anderen über den Menüpunkt "Mit Formular bearbeiten" der Bearbeiten-Schaltfläche geändert werden.
*'''Anwendungsbeispiel: Infoboxen'''<section end="slide-training" />                                         Die Erweiterung wird oft zum Hinzufügen und Bearbeiten von Infobox-Vorlagen verwendet. Wenn [https://www.semantic-mediawiki.org/wiki/Semantic_MediaWiki/de Semantic MediaWiki] verwendet wird, können die über das Formular gesammelten Daten in den Vorlagen gespeichert und im Wiki abgefragt werden.
<section begin="slide-training" />
<section begin="slide-training" />


*'''Automatische Vervollständigung von Feldern'''<section end="slide-training" />                                       Benutzern werden je nach Typ des Eingabefeldes bei der Eingabe bereits existierende Werte vorgeschlagen. Dies reduziert Probleme mit der Benennung von Mehrdeutigkeiten, der Rechtschreibung, usw.
*'''Vorhandene Daten über Menüpunkt bearbeiten'''<section end="slide-training" />                                           Bereits bestehende Daten können unter anderem über den Menüpunkt "Mit Formular bearbeiten" der Bearbeiten-Schaltfläche geändert werden.
<section begin="slide-training" />
<section begin="slide-training" />


*'''Freitextfeld'''<section end="slide-training" />                                       Freier Text auf einer Wikiseite wird nicht ignoriert, wenn die Seite mit einem Formular bearbeitet wird. Vielmehr kann er in einem separaten Eingabefeld namens "Freitext" zum Bearbeiten angezeigt werden.
*'''Automatische Vervollständigung von Feldern'''<section end="slide-training" />                                           Benutzern werden je nach Typ des Eingabefeldes bei der Eingabe bereits existierende Werte vorgeschlagen. Dies reduziert Probleme bei der Dateneingabe.
<section end="training" />
<section end="training" />


==BlueSpice Input types==
==BlueSpice Input types ==
Zusätzlich zu den [[mediawikiwiki:Extension:Page_Forms/Input_types#The_input_types|standardmäßig verfügbaren Eingabetypen]] stehen in BlueSpice noch folgende Inputtypen zur Verfügung:
Zusätzlich zu den [[mediawikiwiki:Extension:Page_Forms/Input_types#The_input_types|standardmäßig verfügbaren Eingabetypen]] stehen in BlueSpice noch folgende Inputtypen zur Verfügung:
<br />
<br />
Zeile 33: Zeile 33:
|[[#bs-grid|bs-grid]]
|[[#bs-grid|bs-grid]]
|Eingabetabelle
|Eingabetabelle
|Tabelle zur kombinierten Eingabe von Parameter-Werten. Tabellenreihen werden über eine "+" Schaltfläche hinzugefügt. Folgende Vorlagen müssen zusätzlich erstellt werden:
| Tabelle zur kombinierten Eingabe von Parameter-Werten. Tabellenreihen werden über eine "+" Schaltfläche hinzugefügt. Folgende Vorlagen müssen zusätzlich erstellt werden:


*Vorlage für die Tabellenreihe sowie zugehörige columns.json-Seite
*Vorlage für die Tabellenreihe sowie zugehörige columns.json-Seite
Zeile 51: Zeile 51:
<code><nowiki>{{#arraymap:{{{meinParameter|}}}|,|@@@|[[User:@@@|@@@]]}}</nowiki></code>
<code><nowiki>{{#arraymap:{{{meinParameter|}}}|,|@@@|[[User:@@@|@@@]]}}</nowiki></code>
|-
|-
|bs-mvvisualeditor
|bs-mwvisualeditor
|Formatierter Text
|Formatierter Text
|Textbox mit vereinfachtem [[VisualEditor]].
|Textbox mit vereinfachtem [[VisualEditor]].
Zeile 57: Zeile 57:
|''bsvisualeditor''
|''bsvisualeditor''
| -
| -
|''Veraltet - ersetzt durch bs-mvvisualeditor''
|''Veraltet - ersetzt durch bs-mwvisualeditor''
|}
|}


Zeile 63: Zeile 63:
Bs-grid ermöglicht es, eine Tabelle als Eingabemethode für ein Formularfeld zu erstellen.
Bs-grid ermöglicht es, eine Tabelle als Eingabemethode für ein Formularfeld zu erstellen.
<br />
<br />
[[Datei:Handbuch:bs-grid.png|alternativtext=Beispiel des Eingabetyps "bs-grid"|zentriert|mini|650x650px|Beispiel des Eingabetyps "bs-grid"]]
[[Datei:bs-grid.png|zentriert|mini|650x650px|Beispiel des Eingabetyps "bs-grid"|verweis=Special:FilePath/Handbuch:bs-grid.png]]




Zeile 117: Zeile 117:
##'''Klicken''' Sie in der Editorleiste ''Einfügen > Vorlage.''
##'''Klicken''' Sie in der Editorleiste ''Einfügen > Vorlage.''
##'''Geben''' Sie den Text "Produkte" '''ein'''.
##'''Geben''' Sie den Text "Produkte" '''ein'''.
##'''Klicken''' Sie ''Vorlage hinzufügen.'' <br />[[Datei:Handbuch:bs-grid-Vorlage einfügen.png|alternativtext=Vorlage einfügen|zentriert|mini|450x450px|Vorlage einfügen]]<br />
##'''Klicken''' Sie ''Vorlage hinzufügen.'' <br />[[Datei:bs-grid-Vorlage einfügen.png|zentriert|mini|450x450px|Vorlage einfügen|verweis=Special:FilePath/Handbuch:bs-grid-Vorlage_einfügen.png]]<br />
##'''Speichern''' Sie die Seite.
##'''Speichern''' Sie die Seite.
##'''Öffnen''' Sie nun die Seite im Formularbearbeitungsmodus. Hier können Sie ihre Produktdaten eingeben.
##'''Öffnen''' Sie nun die Seite im Formularbearbeitungsmodus. Hier können Sie ihre Produktdaten eingeben.
##'''Speichern''' Sie die Seite erneut. Die filterbare Produktdatentabelle wird nun angezeigt.  <br />[[Datei:Handbuch:bs-grid-output.png|alternativtext=Ausgabe der Griddaten|zentriert|mini|650x650px|Ausgabe der Griddaten<br />]]
##'''Speichern''' Sie die Seite erneut. Die filterbare Produktdatentabelle wird nun angezeigt.  <br />[[Datei:bs-grid-output.png|zentriert|mini|650x650px|Ausgabe der Griddaten<br />|verweis=Special:FilePath/Handbuch:bs-grid-output.png]]


Im Quelltext sieht der produktdaten-Parameter dann so aus:<syntaxhighlight lang="text">
Im Quelltext sieht der produktdaten-Parameter dann so aus:<syntaxhighlight lang="text">
Zeile 129: Zeile 129:
}}
}}
</syntaxhighlight><br />
</syntaxhighlight><br />
==Spezialseiten==
== Spezialseiten==
<section begin="training-spezialseiten" />
<section begin="training-spezialseiten" />



Version vom 4. Mai 2023, 17:11 Uhr

Mit Page Forms können Benutzer auch ohne Administrator-Rechte Formulare zum Erstellen und Bearbeiten von Seiten zum Abfragen von Daten verwenden - ohne Programmierung.

Die Verwendung der Erweiterung ist ausführlich :Extension:Page_Forms/de|auf MediaWiki dokumentiert]].

Hauptmerkmale[Bearbeiten | Quelltext bearbeiten]

  • Definitionsseiten im Namensraum Formular
    Formulare können über die Spezialseite Spezial:CreateForm erstellt werden. Hier wird die entsprechende Vorlage ausgewählt, deren Parameter-Werte über das Formular eingegeben werden sollen. Das heißt, bevor ein Formular erstellt wird, wird immer zuerst die hierzu nötige Vorlage erstellt. Alle erstellten Formular-Definitionsseiten werden im Namensraum Formular gespeichert. Die Bearbeitung von bereits erstellten Formular-Definitionsseiten erfolgt über den Quelltext der Seite.

  • Anwendungsbeispiel: Infoboxen
    Die Erweiterung wird oft zum Hinzufügen und Bearbeiten von Infobox-Vorlagen verwendet. Wenn Semantic MediaWiki verwendet wird, können die über das Formular gesammelten Daten in den Vorlagen gespeichert und im Wiki abgefragt werden.

  • Vorhandene Daten über Menüpunkt bearbeiten
    Bereits bestehende Daten können unter anderem über den Menüpunkt "Mit Formular bearbeiten" der Bearbeiten-Schaltfläche geändert werden.

  • Automatische Vervollständigung von Feldern
    Benutzern werden je nach Typ des Eingabefeldes bei der Eingabe bereits existierende Werte vorgeschlagen. Dies reduziert Probleme bei der Dateneingabe.

BlueSpice Input types[Bearbeiten | Quelltext bearbeiten]

Zusätzlich zu den standardmäßig verfügbaren Eingabetypen stehen in BlueSpice noch folgende Inputtypen zur Verfügung:

Eingabetyp Resultat Funktion
bs-grid Eingabetabelle Tabelle zur kombinierten Eingabe von Parameter-Werten. Tabellenreihen werden über eine "+" Schaltfläche hinzugefügt. Folgende Vorlagen müssen zusätzlich erstellt werden:
  • Vorlage für die Tabellenreihe sowie zugehörige columns.json-Seite
  • Vorlage für die Ausgabe der Tabellenwerte
bs-usercombo Benutzername (verlinkt zur Profilseite) Menü zur Auswahl von Benutzernamen des Wikis (Einfachauswahl).
bs-usertags Kommaseparierte Benutzernamen (nicht verlinkt) Menü zur Auswahl von Benutzernamen des Wikis (Mehrfachauswahl).


Hinweis: Um die Benutzernamen zu verlinken, muss der Parameter in der zugehörigen Vorlage entsprechend als Link formatiert werden:

{{#arraymap:{{{meinParameter|}}}|,|@@@|[[User:@@@|@@@]]}}

bs-mwvisualeditor Formatierter Text Textbox mit vereinfachtem VisualEditor.
bsvisualeditor - Veraltet - ersetzt durch bs-mwvisualeditor

bs-grid[Bearbeiten | Quelltext bearbeiten]

Bs-grid ermöglicht es, eine Tabelle als Eingabemethode für ein Formularfeld zu erstellen.

Beispiel des Eingabetyps "bs-grid"


So verwenden Sie das Grid-Eingabefeld:

  1. Erstellen Sie die Vorlage Vorlage:Produkte/Reihe.
    1. Definieren Sie die Parameter, für die Werte gesammelt werden sollen. Hier wird eine Tabellenreihe erstellt, um später die Produktdaten als filterbare Tabelle anzuzeigen:
      <noinclude>Tabellenreihe für die Ausgabe der Produktdaten</noinclude><includeonly>
      |-
      |{{{product|}}}
      |{{{department|}}}
      |{{{availDate|}}}
      |{{{sale|}}}
      </includeonly>
      
  2. Definieren Sie das Grid in der Vorlage:Produkte/Reihe/Spalten.json:
    [
    {"header":"Produktname","dataIndex":"product", "flex":1, "editor":{"allowBlank":false}},
    {"header":"Abteilung","dataIndex":"department","editor":{"xtype":"combo","typeAhead":true,"triggerAction":"all","store":[["Baby und Kleinkind","Baby und Kleinkind"],["Jungen","Jungen"],["Mädchen","Mädchen"],["Männer","Männer"],["Frauen","Frauen"]]}},
    {"xtype":"datecolumn","header":"Verfügbar ab","dataIndex":"availDate","format":"d.m.Y","editor":{"xtype":"datefield","format":"d/m/y","minValue":"01/01/21"}},
    {"xtype":"checkcolumn","header":"Angebot?","dataIndex":"sale","headerCheckbox":true,"stopSelection":false}
    ]
    
    Hinweis: Die Syntax der json-Datei kommt aus dem Framework Ext JS. Links zur Dokumentation der Grid-Syntax finden Sie unter Verwandte Themen am Ende der Seite (JS-Kenntnisse werden vorausgesetzt).
  3. Erstellen Sie die Seite Vorlage:Produkte. Diese Vorlage wird als Ausgabeformat für die Produktdaten verwendet. Sie enthält den benötigten Parameter produktdaten:
    <noinclude>Ausgabetabelle für die Produktdaten. 
    Der Parameter "produktdaten" wird im Formular "Produke" verarbeitet.
    </noinclude><includeonly>{{#default_form: Produkte}}
    {| class="wikitable filterable"
    |+Produktübersicht der aktuellen Kollektion
    !Produktbezeichnung
    !Abteilung
    !Verfügbar ab
    !Im Angebot?
    {{{produktdaten}}}
    |}
    </includeonly>
    
  4. Erstellen Sie das Eingabeformular Formular:Produkte. Durch das Formularfeld produktdaten wird die Dateneingabe als Tabellengrid (bs-grid) definiert:
    <noinclude>Das ist das Formular "Produkte". Es wird mit der gleichnamigen Vorlage benutzt.</noinclude><includeonly>
    <div id="wikiPreview" style="display: none; padding-bottom: 25px; margin-bottom: 25px; border-bottom: 1px solid #AAAAAA;"></div>
    {{{for template|Produkte}}}
    Produkte: 
    
    {{{field|produktdaten|input type=bs-grid|colDef=Vorlage:Produkte/Reihe/Spalten.json|template=Produkte/Reihe}}}
    
    {{{end template}}}
    
    {{{standard input|save}}} {{{standard input|preview}}} {{{standard input|cancel}}}
    </includeonly>

  5. Binden Sie die Vorlage "Produkte" nun auf einer Wikiseite ein.
    1. Klicken Sie in der Editorleiste Einfügen > Vorlage.
    2. Geben Sie den Text "Produkte" ein.
    3. Klicken Sie Vorlage hinzufügen.
      Vorlage einfügen

    4. Speichern Sie die Seite.
    5. Öffnen Sie nun die Seite im Formularbearbeitungsmodus. Hier können Sie ihre Produktdaten eingeben.
    6. Speichern Sie die Seite erneut. Die filterbare Produktdatentabelle wird nun angezeigt.
      Ausgabe der Griddaten

Im Quelltext sieht der produktdaten-Parameter dann so aus:

{{Produkte
|produktdaten={{Produkte/Reihe|product=Wanderhose|department=Männer|availDate=30.07.2021|sale=true}}
{{Produkte/Reihe|product=Pullover|department=Jungen|availDate=04.07.2021}}
{{Produkte/Reihe|product=Socken|department=Frauen|availDate=03.08.2021}}
}}


Spezialseiten[Bearbeiten | Quelltext bearbeiten]

Page Forms definiert einige Spezialseiten, die zur Dateneingabe und Datenpflege gebraucht werden.

Zum Sammeln von Daten sind unter anderem folgende Spezialseiten wichtig:

drawio: Erweiterung-Page Forms-12190872

Weiterführende Links




Feedback zur Dokumentation ist im Community-Forum möglich.

Diskussionen