Modul:Faktenbox: Unterschied zwischen den Versionen

Aus FürthWiki

(rework fbdata)
(+ Faktenbox(), datenTabUniversal(), kartenTab())
Zeile 8: Zeile 8:
local lfd = require("Modul:LinkFormDatum")
local lfd = require("Modul:LinkFormDatum")


function p.zeile(attr_name, val, attr_text)
function p.Faktenbox(frame)
-- mw.log("zeile(" .. (attr_name or "nil") .. ", val, " .. (attr_text or "nil") .. ")")
-- mw.log("Faktenbox(frame)")
-- mw.logObject(val or {})
-- mw.logObject(frame)
-- Konsolenzeile zum Debuggen:
-- =p.Faktenbox{pargs={Bild="Schwabacher Straße 12 Dez 2020 1.jpg",["Straße"]="Schwabacher Straße",location="Rathaus Fürth",Objekt="Häusle"}}
 
-- Basis-Faktenbox-Daten (Klasse/Kategorie/Formular)
-- Kein(e) Klasse/Kategorie/Formular!
local fbdata = p.fbdata(frame)
 
-- Tabs einsammeln und zusammenfügen
local box =
"<div class = factbox><tabs>" ..
p.bildTab(fbdata) ..
p.kartenTab(fbdata) ..
p.datenTabUniversal(fbdata) ..
"</tabs></div>"
 
-- Sonstige gemeinsame Dinge anfügen (Klasse, Formular, Kategorien, Wartung, ...)
box = box .. p.common(fbdata, false)
mw.log("box = " .. box)
 
-- Pre-Processing und String-Länge checken
box = fbdata.frame:preprocess(box)
box = box .. com.returnStringCheck(box)
-- mw.log("box = " .. box)
return box
end
 
function p.datenTabUniversal(fbdata)
-- mw.log("datenTab(fbdata)")
-- mw.logObject(fbdata)
-- Konsolenzeile zum Debuggen (Achtung! Bug in Fehlerbereinigungskonsole! Kann nur 1x ausgeführt werden!):
-- fab=require("Modul:Faktenbox/Work"); fbdata=p.fbdata{pargs={lat="Bla", Objekt="Häusle", Test="BlaBla"}}; print(p.datenTab(fbdata))
local t = ""
local t = ""
if mw.smw.getPropertyType(attr_name) ~= nil then
local no_show_attr = {
if type(val) ~= "table" then
["Bild"] = true,
val = str.splitAndStrip(val or "", ";")
["lat"] = true, ["lon"] = true, ["location"] = true,["locationlist"] = true, ["geojson"] = true,
["zoom"] = true, ["popuptitle"] = true, ["popuptext"] = true
}
 
-- Zusammenbau
t = t .. "<dl class = 'dataTable'>"
for a, _ in pairs(fbdata.pargs) do
if not com.isTrue(no_show_attr[a]) then
t = t .. p.zeilePargs(fbdata, {a})
end
end
if #val > 0 then
end
t = t .. "<dt>" .. "[[Attribut:" .. attr_name .. "|" .. (attr_text or attr_name) .. "]]</dt><dd>"
t = t .. "</dl>"
for i, v in ipairs(val) do
t = t .. p.faktenboxSemantikBrowsen(fbdata)
if i > 1 then
 
t = t .. ", "
-- Tab draus machen
end
t = p.tab(t, "Daten")
t = t .. "[[" .. attr_name .. "::" .. v .. "]]"
-- mw.log("t = " .. t)
end
    return t
t = t .. "</dd>"
end
 
function p.bildTab(fbdata, seite)
-- mw.log("bild(fbdata, " .. (seite or "nil") .. ")")
-- mw.logObject(fbdata.pargs)
-- Konsolenzeile zum Debuggen:
-- =p.bildTab{pargs={Bild="Erloeserkirche.jpg"}}
local t = ""
local beschreibung = que.getValues("Datei:" .. (fbdata.pargs.Bild or ""), "Beschreibung")
local beschreibung = beschreibung[1] or ""
if not com.isEmpty(fbdata.pargs.Bild) and wik.pageexists("Bild:" .. fbdata.pargs.Bild) then
t = t .. '{| class = "factbox_imagetable" border = "0" cellpadding = "0" cellspacing = "0" width = "100%"\n'
t = t .. '|-\n'
t = t .. '|[[Bild::Datei:' .. fbdata.pargs.Bild .. '|768px|link=' .. (seite or '') .. ']]\n'
if beschreibung ~= "" then
t = t .. '|-\n'
t = t .. '|' .. beschreibung .. '\n'
end
end
t = t .. '|}'
end
end
-- Tab draus machen
t = p.tab(t, "Bild")
-- mw.log("t = " .. t)
-- mw.log("t = " .. t)
return t
return t
end
end


function p.zeilePargs(fbdata, attr_names)
function p.kartenTab(fbdata)
-- mw.log("zeilePargs(fbdata, " .. (attr_name or "nil") .. ", " .. (attr_text or "nil") .. ")")
-- mw.log("kartenTab(fbdata)")
-- mw.logObject(fbdata.pargs or {})
-- mw.logObject(fbdata)
-- Konsolenzeile zum Debuggen:
-- Konsolenzeile zum Debuggen:
-- =p.zeilePargs({pargs={test=123,TeilDesEnsembles="bla"}}, {"test","TeilDesEnsembles","Blub"})
-- fab=require("Modul:Faktenbox/Work"); fbdata=p.fbdata{pargs={["location"]="Erlanger Straße 11, Fürth, Bayern, Deutschland"}}; print(p.kartenTab(fbdata))
local t = ""
t = ""
local attr_text = {
if string.find(fbdata.pagename, ";") ~= nil then
["TeilDesEnsembles"]="Teil des Ensembles",
t = "Semikolon im Artikel-/Seitennamen für korrekte Kartendarstellung nicht erlaubt!"
["TeilDesAreals"]="Teil des Areals",
else
["TeilDesGebäudeKomplexes"]="Teil des Gebäude-Komplexes",
local args_karte = com.shallowcopy(fbdata.pargs)
["DenkmalstatusBesteht"]="Denkmalstatus besteht"
args_karte["Debug"] = "Nein"
}
t = fbdata.frame:expandTemplate{title = "CommonTabs/Karte", args = args_karte}
for _, a in ipairs(attr_names) do
t = t .. p.zeile(a, fbdata.pargs[a], attr_text[a])
end
end
-- Tab draus machen
t = p.tab(t, "Karte")
-- mw.log("t = " .. t)
-- mw.log("t = " .. t)
return t
return t
Zeile 153: Zeile 211:
t = t .. lfd.linkFormDate(date, args.attr_date, args.attr_day, args.attr_year)
t = t .. lfd.linkFormDate(date, args.attr_date, args.attr_day, args.attr_year)
t = t .. "</dd>"
t = t .. "</dd>"
end
-- mw.log("t = " .. t)
return t
end
function p.zeilePargs(fbdata, attr_names)
-- mw.log("zeilePargs(fbdata, " .. (attr_name or "nil") .. ", " .. (attr_text or "nil") .. ")")
-- mw.logObject(fbdata.pargs or {})
-- Konsolenzeile zum Debuggen:
-- =p.zeilePargs({pargs={test=123,TeilDesEnsembles="bla"}}, {"test","TeilDesEnsembles","Blub"})
local t = ""
local attr_text = {
["TeilDesEnsembles"]="Teil des Ensembles",
["TeilDesAreals"]="Teil des Areals",
["TeilDesGebäudeKomplexes"]="Teil des Gebäude-Komplexes",
["DenkmalstatusBesteht"]="Denkmalstatus besteht"
}
for _, a in ipairs(attr_names) do
t = t .. p.zeile(a, fbdata.pargs[a], attr_text[a])
end
-- mw.log("t = " .. t)
return t
end
function p.zeile(attr_name, val, attr_text)
-- mw.log("zeile(" .. (attr_name or "nil") .. ", val, " .. (attr_text or "nil") .. ")")
-- mw.logObject(val or {})
local t = ""
if mw.smw.getPropertyType(attr_name) ~= nil then
if type(val) ~= "table" then
val = str.splitAndStrip(val or "", ";")
end
if #val > 0 then
t = t .. "<dt>" .. "[[Attribut:" .. attr_name .. "|" .. (attr_text or attr_name) .. "]]</dt><dd>"
for i, v in ipairs(val) do
if i > 1 then
t = t .. ", "
end
t = t .. "[[" .. attr_name .. "::" .. v .. "]]"
end
t = t .. "</dd>"
end
end
end
-- mw.log("t = " .. t)
-- mw.log("t = " .. t)
Zeile 168: Zeile 268:
t = t .. "<dd>[[Spezial:Durchsuchen/" .. fbdata.fullpagename .. "|Semantisches Browsen]]</dd>"
t = t .. "<dd>[[Spezial:Durchsuchen/" .. fbdata.fullpagename .. "|Semantisches Browsen]]</dd>"
t = t .. "</dl>"
t = t .. "</dl>"
-- mw.log("t = " .. t)
return t
end
function p.bildTab(fbdata, seite)
-- mw.log("bild(fbdata, " .. (seite or "nil") .. ")")
-- mw.logObject(fbdata.pargs)
-- Konsolenzeile zum Debuggen:
-- =p.bildTab{pargs={Bild="Erloeserkirche.jpg"}}
local t = ""
local beschreibung = que.getValues("Datei:" .. (fbdata.pargs.Bild or ""), "Beschreibung")
local beschreibung = beschreibung[1] or ""
if not com.isEmpty(fbdata.pargs.Bild) and wik.pageexists("Bild:" .. fbdata.pargs.Bild) then
t = t .. '{| class = "factbox_imagetable" border = "0" cellpadding = "0" cellspacing = "0" width = "100%"\n'
t = t .. '|-\n'
t = t .. '|[[Bild::Datei:' .. fbdata.pargs.Bild .. '|768px|link=' .. (seite or '') .. ']]\n'
if beschreibung ~= "" then
t = t .. '|-\n'
t = t .. '|' .. beschreibung .. '\n'
end
t = t .. '|}'
end
-- Tab draus machen
t = p.tab(t, "Bild")
-- mw.log("t = " .. t)
-- mw.log("t = " .. t)
return t
return t
Zeile 197: Zeile 273:


function p.common(fbdata, positionscheck)
function p.common(fbdata, positionscheck)
mw.log("common(fbdata)")
-- mw.log("common(fbdata)")
mw.logObject(fbdata)
-- mw.logObject(fbdata)
-- Konsolenzeile zum Debuggen:
-- Konsolenzeile zum Debuggen:
-- =p.common{formular="Gebäude/Work",klasse={"Gebäude","Kirche"},kategorie={"Gebäude","Kirchen"},strasse_hnr={suspekt=true},positionscheck=true,pargs={Bild="Angie Oeckl.JPG",Ehemals="Ja",DenkmalstatusBesteht="Ja",Stadtteil="Ronhof; Nordstadt ",location="bla"},pagename="Test/Test;Test"}
-- =p.common{formular="Gebäude/Work",klasse={"Gebäude","Kirche"},kategorie={"Gebäude","Kirchen"},strasse_hnr={suspekt=true},positionscheck=true,pargs={Bild="Angie Oeckl.JPG",Ehemals="Ja",DenkmalstatusBesteht="Ja",Stadtteil="Ronhof; Nordstadt ",location="bla"},pagename="Test/Test;Test"}
local t = ""
local t = ""
-- Klasse
-- Klasse
t = t .. "{{#set:KlassenName=" .. fbdata.klasse[1] .. "}}"
if fbdata.klasse ~= nil then
t = t .. "{{#set:KlassenName=" .. fbdata.klasse[1] .. "}}"
end
-- Formular
-- Formular
t = t .. "{{#default_form:" .. fbdata.formular .. "}}"
if fbdata.formular ~= nil then
t = t .. "{{#default_form:" .. fbdata.formular .. "}}"
end
-- Kategorien
-- Kategorien
local ehemals_text = ""
local ehemals_text = ""
Zeile 211: Zeile 291:
ehemals_text = " (ehemals)"
ehemals_text = " (ehemals)"
end
end
for _, k in ipairs(fbdata.kategorie) do
if fbdata.kategorie ~= nil then
t = t .. "[[Kategorie:" .. k .. ehemals_text .. "]]"
for _, k in ipairs(fbdata.kategorie) do
t = t .. "[[Kategorie:" .. k .. ehemals_text .. "]]"
end
end
end
if com.isTrue(fbdata.pargs.DenkmalstatusBesteht) then
if com.isTrue(fbdata.pargs.DenkmalstatusBesteht) then
Zeile 224: Zeile 306:
-- Wartungs-Kategorien
-- Wartungs-Kategorien
if com.isEmpty(fbdata.pargs.Bild) then
if com.isEmpty(fbdata.pargs.Bild) then
t = t .. "[[Kategorie:" .. fbdata.kategorie[1] .. " ohne Bild]]"
if fbdata.kategorie ~= nil then
t = t .. "[[Kategorie:" .. fbdata.kategorie[1] .. " ohne Bild]]"
else
t = t .. "[[Kategorie:Ohne Bild]]"
end
elseif not wik.pageexists("Bild:" .. fbdata.pargs.Bild) then
elseif not wik.pageexists("Bild:" .. fbdata.pargs.Bild) then
t = t .. "[[Kategorie:Bild nicht gefunden]]"
t = t .. "[[Kategorie:Bild nicht gefunden]]"
Zeile 234: Zeile 320:
t = t .. "[[Kategorie:Hat Slash]]"
t = t .. "[[Kategorie:Hat Slash]]"
end
end
if fbdata.strasse_hnr.suspekt then
if not com.isEmpty(fbdata.strasse_hnr) then
t = t .. "[[Kategorie:Gebäude mit verdächtiger Straße-Hausnummer-Kombination]]"
if fbdata.strasse_hnr.suspekt then
t = t .. "[[Kategorie:Gebäude mit verdächtiger Straße-Hausnummer-Kombination]]"
end
end
end
if fbdata.positionscheck and (fbdata.pargs.lat or "") == "" and (fbdata.pargs.lon or "") == "" and
if fbdata.positionscheck and (fbdata.pargs.lat or "") == "" and (fbdata.pargs.lon or "") == "" and
  (fbdata.pargs.location or "") == "" and not wik.pageexists("GeoJson:" .. (fbdata.pargs.geojson or fbdata.pagename)) then
  (fbdata.pargs.location or "") == "" and not wik.pageexists("GeoJson:" .. (fbdata.pargs.geojson or fbdata.pagename)) and
fbdata.kategorie ~= nil then
t = t .. "[[Kategorie:" .. fbdata.kategorie[1] .. ehemals_text .. " ohne Position]]"
t = t .. "[[Kategorie:" .. fbdata.kategorie[1] .. ehemals_text .. " ohne Position]]"
end
end

Version vom 15. Oktober 2025, 09:25 Uhr

Seiten-Übersicht

Zur Klasse Faktenbox gehörende Seiten:
Hauptseite Unterseiten
Allgemein
Faktenbox Vorlagen
Formulare
Module
Abfrage Vorlagen


Formulare


Sonstige


Dieses Modul enthält gemeinsame Funktionen, um eine Faktenbox zu füllen

Funktionen Modul:Faktenbox

Faktenbox()

Universelle Faktenbox ohne Formular/Klasse/Gebäude. Sie kann als zusätzliche Faktenboxen auf einer Seite eingebaut werden ähnlich Vorlage:Tabbox. Sie setzt ebenso Attribute wie die regulären Faktenboxen z.B. von Gebäuden, Straßen, Personen usw.

Funktionen Modul:Faktenbox/Tabs

universalDatenTab()

Universeller Daten-Tab zeigt alle seine übergebenen Parameter außer die für Karte und Bild an.

bildTab()

Selbsterklärend...

benennungenTab()

Tab mit Liste der Benennungen.

tab()

Vervollständigt Tab-Inhalt zu einem Tab.

Funktionen Modul:Faktenbox/Tabs/Karte

kartenTab()

Selbsterklärend...

getKartenArgs()

Karten-Argumente übernehmen und aufbereiten.

Funktionen Modul:Faktenbox/Tabs/Adressen

adressenTab()

Tab mit Liste der Adressen. Die Adressen werden bestmöglich chronologisch aufsteigend sortiert.

p.sortIndex() und p.smwDate2SortIndex()

Erstellen Sortierindizes anhand Datum und Schlüsselwörtern (z.B. Geburtshaus ganz oben) für chronologische Sortierung.

Funktionen Modul:Faktenbox/Zeilen

zeileKategorieSeite()

Diese Zeile ist die oberste Zeile eines Daten-Tabs, welche nochmal den Namen des Objekts und einen Link zur Klassen-Kategorie anzeigt und das Attribut:Seite setzt.

zeileStrasseHnr()

Wie zeile(attr, attrText, val), aber speziell ausgrichtet, um Attribut:Straße, Attribut:Hausnummer, Attribut:StraßeHnr und Attribut:AnzahlGebäude zu setzen und anzuzeigen.

zeileAktenNr()

Wie zeile(attr, attrText, val), aber speziell ausgrichtet, um Attribut:AktenNr zu setzen und anzuzeigen. Die AktenNr werden als Query-Link und mit Seitenanzahl mit dieser AktenNr angezeigt.

zeileGeoDaten()

Zeile um alle Attribut:Geokoordinaten mit OSM-Link und die Attribut:GeoJson-Karte zu anzuzeigen.

zeileDatum()

Zeile um ein Datum standardisiert per linkFormDate() anzuzeigen.

zeileSemantikBrowsenAbfrage()

Zeile mit Link zum semantischen Browsen (Datensicht) und zur Abfrage.

zeile()

Standard-Zeile um ein Attribut zu setzen und anzuzeigen. Wenn es sich beim Attribut-Wert um eine Liste mit mehreren Elementen handelt, wird vom Attribut-Anzeigetext automatisch die Mehrzahl gebildet.

Parameter Beschreibung
attr_name Attribut-Name
attr_text Optionaler Attribut-Anzeigetext. Default: attr_name. Siehe auch attr_text_anzeige
attr_val Attribut-Wert. Wenn nicht übergeben, werden die von der #invoke:-Vorlage übergegebenen Parameter (fbdata.pargs) verwendet.
fbdata fbdata-Daten-table mit von der #invoke:-Vorlage übergegebenen Parameter (fbdata.pargs).
delimiter Trennzeichen bei Werte-Listen. Bei Nicht-Übergabe wird Attribut-Wert auch nicht als Liste behandelt.
val_prefix Attribut-Wert-Prefix z.B. "ca."
val_postfix Attribut-Wert-Postfix z.B. "km"
val_show_only Attribut-Wert nur anzeigen, aber nicht setzen

setPageAttr()

Setzen eines Attributs vom Datentyp Seite in folgender Prüf- und Setzreihenfolge:

  1. Wenn val problematische Wikitext/HTML-Inhalte enthält, dann wird
    • val 1:1 angezeigt und ggf. gerendert (nicht innerhalb [[Attribut::Wert]])
    • Attribut name mit val per {{#set:Attribut=Wert}} unsichtbar im Hintergrund gesetzt, auch wenn das Verarbeitungsfehler provoziert (gewollt)
  2. Ansonsten wenn val als Seite existiert, wird diese 1:1 gesetzt und angezeigt ([[Attribut::Wert]])
  3. Ansonsten wenn val Klammerungen am Anfang oder am Ende enthält (Beispiel: "(BlaBlub) Rathaus (BlaBla)"), wird geprüft, ob eine Seite ohne die Klammerungen (also Rathaus) existiert. Wenn ja, wird "(BlaBlub) Rathaus (BlaBla)" angezeigt und das Attribut mit nur "Rathaus" gesetzt.
  4. Ansonsten wird
    • val 1:1 angezeigt und ggf. gerendert (nicht innerhalb [[Attribut::Wert]])
    • Attribut name mit val per {{#set:Attribut=Wert}} unsichtbar im Hintergrund gesetzt, auch wenn das Verarbeitungsfehler provoziert (gewollt)

setStandardAttr()

Setzen eines Standard-Attributs (nicht Datentyp Seite). Klammerwerte werden optional abgetrennt und Attribut-Wert wird optional nur angezeigt, aber nicht gesetzt.

Funktionen Modul:Faktenbox/Common

common()

Sonstige gemeinsame Dinge anfügen

  • Klasse
  • Formular
  • Kategorien
  • Wartung

fbdata()

Erstellt Faktenbox-Daten-Tabelle.

fbdata-Daten-table

Um die Parameter-Übergabe zu obigen Funktionen zu vereinfachen wird die fbdata-Daten-table verwendet, in der folgende Daten abgelegt werden:

  • fbdata.frame = frame von Faktenbox(frame)
  • fbdata.pargs = frame:getParent().args. Beispiel: fbdata.pargs["Ehemals"] oder fbdata.pargs.Ehemals
  • fbdata.klasse Klassen-table. Beispiel Kirche: fbdata.klasse = {"Kirche", "Gebäude"} ("Kirche" ist primäre und "Gebäude" sekundäre Klasse)
  • fbdata.kategorie Kategorien-table. Beispiel Kirche: fbdata.kategorie = {"Kirchen", "Gebäude"} ("Kirchen" ist primäre und "Gebäude" sekundäre Kategorie)
  • fbdata.kategorie_einzahl Einzahl-Kategorien-table als Alternative zu fbdata.klasse. Beispiel Kirche: fbdata.kategorie_einzahl = {"Kirche", "Gebäude"} ("Kirche" ist primäre und "Gebäude" sekundäre Kategorie)
  • fbdata.formular Formular
  • Pagesnames
    • frame.fullpagename
    • frame.pagename
    • frame.subpagename
  • frame.strasse_hnr Untertabelle für Straße/Hausnummer-Daten
    • frame.strasse_hnr.strasse Untertabelle für Straßen
      • frame.strasse_hnr.strasse.name Straßenname
      • frame.strasse_hnr.strasse.hausnummer Hausnummern-table dieser Straße
      • frame.strasse_hnr.strasse.suspekt Suspekte Formular-Werte dieser Straße
    • frame.strasse_hnr.suspekt Suspekte Formular-Werte aller Straßen
    • frame.strasse_hnr.anzahlGebaeude Anzahl aller gültigen Straße/Hausnummer-Kombinationen
  • Ggf. weitere Klassen-abhängige Einträge

attr_text_anzeige

Sofern kein attr_text angegeben, wird i. A. attr_name angezeigt. Jedoch wird bei manchen attr_name-Attributen stattdessen automatisch die ausgeschriebene Version angezeigt.

Beispiel: Beim Attribut:TeilDesEnsembles wird anhand der table attr_text_anzeige "Teil des Ensembles" angezeigt.

Diese Übersetzung von attr_name zur Anzeige-Version ist in attr_text_anzeige abgelegt und erfolgt global bei allen Faktenboxen.

Unterseiten

Siehe auch


p = {}
local com = require("Modul:Common")
local dev = require("Modul:Development")
local str = require("Modul:String")
local wik = require("Modul:Wiki")
local geo = require("Modul:Geo")
local que = require("Modul:Queries")
local lfd = require("Modul:LinkFormDatum")

function p.Faktenbox(frame)
--	mw.log("Faktenbox(frame)")
--	mw.logObject(frame)
	-- Konsolenzeile zum Debuggen:
	-- =p.Faktenbox{pargs={Bild="Schwabacher Straße 12 Dez 2020 1.jpg",["Straße"]="Schwabacher Straße",location="Rathaus Fürth",Objekt="Häusle"}}

	-- Basis-Faktenbox-Daten (Klasse/Kategorie/Formular)
	-- Kein(e) Klasse/Kategorie/Formular!
	local fbdata = p.fbdata(frame)

	-- Tabs einsammeln und zusammenfügen
	local box = 
		"<div class = factbox><tabs>" ..
		p.bildTab(fbdata) ..
		p.kartenTab(fbdata) ..
		p.datenTabUniversal(fbdata) ..
		"</tabs></div>"

	-- Sonstige gemeinsame Dinge anfügen (Klasse, Formular, Kategorien, Wartung, ...)
	box = box .. p.common(fbdata, false)
	mw.log("box = " .. box)

	-- Pre-Processing und String-Länge checken
	box = fbdata.frame:preprocess(box)
	box = box .. com.returnStringCheck(box)
--	mw.log("box = " .. box)
	return box
end

function p.datenTabUniversal(fbdata)
--	mw.log("datenTab(fbdata)")
--	mw.logObject(fbdata)
	-- Konsolenzeile zum Debuggen (Achtung! Bug in Fehlerbereinigungskonsole! Kann nur 1x ausgeführt werden!):
	-- fab=require("Modul:Faktenbox/Work"); fbdata=p.fbdata{pargs={lat="Bla", Objekt="Häusle", Test="BlaBla"}}; print(p.datenTab(fbdata))
	local t = ""
	local no_show_attr = {
		["Bild"] = true, 
		["lat"] = true,	["lon"] = true,	["location"] = true,["locationlist"] = true, ["geojson"] = true,
		["zoom"] = true, ["popuptitle"] = true, ["popuptext"] = true
	}

	-- Zusammenbau
	t = t .. "<dl class = 'dataTable'>"
	for a, _ in pairs(fbdata.pargs) do
		if not com.isTrue(no_show_attr[a]) then
			t = t .. p.zeilePargs(fbdata, {a})
		end
	end
	t = t .. "</dl>"
	t = t .. p.faktenboxSemantikBrowsen(fbdata)

	-- Tab draus machen
	t = p.tab(t, "Daten")
--	mw.log("t = " .. t)
    return t
end

function p.bildTab(fbdata, seite)
--	mw.log("bild(fbdata, " .. (seite or "nil") .. ")")
--	mw.logObject(fbdata.pargs)
	-- Konsolenzeile zum Debuggen:
	-- =p.bildTab{pargs={Bild="Erloeserkirche.jpg"}}
	local t = ""
	local beschreibung = que.getValues("Datei:" .. (fbdata.pargs.Bild or ""), "Beschreibung")
	local beschreibung = beschreibung[1] or ""
	if not com.isEmpty(fbdata.pargs.Bild) and wik.pageexists("Bild:" .. fbdata.pargs.Bild) then
		t = t .. '{| class = "factbox_imagetable" border = "0" cellpadding = "0" cellspacing = "0" width = "100%"\n'
		t = t .. '|-\n'
		t = t .. '|[[Bild::Datei:' .. fbdata.pargs.Bild .. '|768px|link=' .. (seite or '') .. ']]\n'
		if beschreibung ~= "" then
			t = t .. '|-\n'
			t = t .. '|' .. beschreibung .. '\n'
		end
		t = t .. '|}'
	end
	-- Tab draus machen
	t = p.tab(t, "Bild")
--	mw.log("t = " .. t)
	return t
end

function p.kartenTab(fbdata)
--	mw.log("kartenTab(fbdata)")
--	mw.logObject(fbdata)
	-- Konsolenzeile zum Debuggen:
	-- fab=require("Modul:Faktenbox/Work"); fbdata=p.fbdata{pargs={["location"]="Erlanger Straße 11, Fürth, Bayern, Deutschland"}}; print(p.kartenTab(fbdata))
	t = ""
	if string.find(fbdata.pagename, ";") ~= nil then
		t = "Semikolon im Artikel-/Seitennamen für korrekte Kartendarstellung nicht erlaubt!"
	else
		local args_karte = com.shallowcopy(fbdata.pargs)
		args_karte["Debug"] = "Nein"
		t = fbdata.frame:expandTemplate{title = "CommonTabs/Karte", args = args_karte}
	end
	-- Tab draus machen
	t = p.tab(t, "Karte")
--	mw.log("t = " .. t)
	return t
end

function p.zeileKategorieSeite(fbdata, kindex)
--	mw.log("zeileKategorieSeite(fbdata, " .. (kindex or 1) .. ")")
--	mw.logObject(fbdata)
	-- Konsolenzeile zum Debuggen:
	-- =p.zeileKategorieSeite({fullpagename="fpn",kategorie={"kat1","kat2"},klasse={"kla1","kla2"}}, 2)
	local t = ""
	t = t .. "<dt>[[:Kategorie:" .. fbdata.kategorie[kindex or 1] .. "|" .. fbdata.klasse[kindex or 1] .. "]]</dt><dd>[[Seite::" .. fbdata.fullpagename .. "]]</dd>"
--	mw.log("t = " .. t)
	return t
end

function p.zeileStrasseHnr(fbdata)
--	mw.log("zeileStrasseHnr(fbdata)")
--	mw.logObject(fbdata.strasse_hnr)
	-- Konsolenzeile zum Debuggen:
	-- =p.zeileStrasseHnr{strasse_hnr={strasse={{name="Erlanger Straße",hausnummer={"11", "13"}},{name="XY Straße",hausnummer={}}},anzahlGebaeude=3}}
	local t = ""
	for is, sh in ipairs(fbdata.strasse_hnr.strasse) do -- Straßen/Hausnummer-Kombis durchiterieren
		t = t .. "<dt>"
		if is > 1 then
			t = t .. is .. ". " -- Numerierungsanzeige "2., "3." usw.
		else
			is = "" -- keine 1, aber 2, 3, ... für weitere Verwendung
		end
		t = t .. "[[Attribut:Straße" .. is .. "|Straße]]"
		if #sh.hausnummer > 0 then
			t = t .. " / " .. "[[Attribut:Hausnummer" .. is .. "|Hausnummer]]" -- nur wenn Hausnummern vorhanden
		end
		t = t .. "</dt><dd>[[Straße" .. is .. "::" .. sh.name .. "]]"
		for ih, h in ipairs(sh.hausnummer) do -- Hausnummern durchiterieren
			local strasse_hnr_ = sh.name .. " " .. h
			if ih > 1 then
				t = t .. "," -- Kommas davor ab 2. Hausnummer
			end
			if wik.pageexists(strasse_hnr_) then -- Link, wenn Seite vorhanden
				t = t .. " [[" .. strasse_hnr_ .. "|" .. h .. "]]"
			else
				t = t .. " " .. h
			end
			t = t .. "{{#set:Hausnummer" .. is .. "=" .. h .. "|StraßeHnr=" .. strasse_hnr_ .. "}}"
		end
		t = t .. "</dd>"
	end
	t = t .. "{{#set:AnzahlGebäude=" .. fbdata.strasse_hnr.anzahlGebaeude .. "}}"
--	mw.log("t = " .. t)
	return t
end

function p.zeileAktenNr(fbdata)
--	mw.log("zeileAktenNr(fbdata)")
--	mw.logObject(fbdata.pargs)
	-- Konsolenzeile zum Debuggen:
	-- =p.zeileAktenNr{pargs={AktenNr="D-5-63-000-1464"}}
	local t = ""
	local aktennr = str.splitAndStrip(fbdata.pargs.AktenNr or "", ";")
	if #aktennr > 0 then
		t = t .. "<dt>" .. "[[Attribut:AktenNr|Akten-Nr.]]</dt><dd>"
		for i, a in ipairs(aktennr) do
			if i > 1 then
				t = t .. ",<br>"
			end
			t = t .. "{{#queryformlink:form=Abfrage Denkmalschutz|link text=[[AktenNr::" .. a .. "]]|query string=Abfrage Denkmalschutz[AktenNr]=" .. a .. "&_run}}"
			local p = que.getPages("[[:+]][[AktenNr::" .. a .. "]]", true)
			t = t .. " (" .. #p .. ")" -- Anzahl der Artikel mit dieser Akten-Nr. in Klammern
		end
		t = t .. "</dd>"
	end
--	mw.log("t=" .. t)
	return t
end

function p.zeileGeokoordinate(fbdata)
--	mw.log("zeileGeokoordinate()")
--	mw.logObject(fbdata)
	-- Konsolenzeile zum Debuggen:
	-- fbdata=p.fbdata{pargs={}}; fbdata.fullpagename="Isaak-Loewi-Straße 1, 3, 5, 7, 9, Liesl-Kießling-Straße 16"; print(p.zeileGeokoordinate(fbdata))
	local t = ""
	local geokoordinate = que.getValues(fbdata.fullpagename, "Geokoordinate", true)
	if #geokoordinate > 0 then
		t = t .. "<dt>[[Attribut:Geokoordinate|Geokoordinate]]</dt><dd>"
		for i, g in ipairs(geokoordinate) do
			if i > 1 then
				t = t .. ",<br>"
			end
			t = t .. geo.osmLink(fbdata.frame, g)
		end
		t = t .. "</dd>"
	end
--	mw.log("t = " .. t)
	return t
end

function p.zeileDatum(args)
--	mw.log("zeileDatum(args)")
--	mw.logObject(args)
	-- Konsolenzeile zum Debuggen:
	-- =p.zeileDatum{attr_date="Weihedatum",date="1959/11/15",attr_day="Weihetag",attr_year="Weihejahr"}
	local t = ""
	local date = str.strip(args.date or "")
	if date ~= "" then
		t = t .. "<dt>" .. "[[Attribut:" .. args.attr_date .. "|" .. args.attr_date .. "]]</dt><dd>"
		t = t .. lfd.linkFormDate(date, args.attr_date, args.attr_day, args.attr_year)
		t = t .. "</dd>"
	end
--	mw.log("t = " .. t)
	return t
end

function p.zeilePargs(fbdata, attr_names)
--	mw.log("zeilePargs(fbdata, " .. (attr_name or "nil") .. ", " .. (attr_text or "nil") .. ")")
--	mw.logObject(fbdata.pargs or {})
	-- Konsolenzeile zum Debuggen:
	-- =p.zeilePargs({pargs={test=123,TeilDesEnsembles="bla"}}, {"test","TeilDesEnsembles","Blub"})
	local t = ""
	local attr_text = {
		["TeilDesEnsembles"]="Teil des Ensembles",
		["TeilDesAreals"]="Teil des Areals",
		["TeilDesGebäudeKomplexes"]="Teil des Gebäude-Komplexes",
		["DenkmalstatusBesteht"]="Denkmalstatus besteht"
	}
	for _, a in ipairs(attr_names) do
		t = t .. p.zeile(a, fbdata.pargs[a], attr_text[a])
	end
--	mw.log("t = " .. t)
	return t
end

function p.zeile(attr_name, val, attr_text)
--	mw.log("zeile(" .. (attr_name or "nil") .. ", val, " .. (attr_text or "nil") .. ")")
--	mw.logObject(val or {})
	local t = ""
	if mw.smw.getPropertyType(attr_name) ~= nil then
		if type(val) ~= "table" then
			val = str.splitAndStrip(val or "", ";")
		end
		if #val > 0 then
			t = t .. "<dt>" .. "[[Attribut:" .. attr_name .. "|" .. (attr_text or attr_name) .. "]]</dt><dd>"
			for i, v in ipairs(val) do
				if i > 1 then
					t = t .. ", "
				end
				t = t .. "[[" .. attr_name .. "::" .. v .. "]]"
			end
			t = t .. "</dd>"
		end
	end
--	mw.log("t = " .. t)
	return t
end

function p.faktenboxSemantikBrowsen(fbdata)
--	mw.log("faktenboxSemantikBrowsen(fbdata)")
--	mw.logObject(fbdata)
	-- Konsolenzeile zum Debuggen:
	-- =p.faktenboxSemantikBrowsen{pargs={Bild="Erloeserkirche.jpg"}}
	local t = ""
	t = t .. "<dl class = 'dataTable'>"
	t = t .. "<dt>[[Bild:IconSearch.svg|16px|semantisches Browsen|link=[[Spezial:Durchsuchen/" .. fbdata.fullpagename .. "]]]]</dt>"
	t = t .. "<dd>[[Spezial:Durchsuchen/" .. fbdata.fullpagename .. "|Semantisches Browsen]]</dd>"
	t = t .. "</dl>"
--	mw.log("t = " .. t)
	return t
end

function p.common(fbdata, positionscheck)
--	mw.log("common(fbdata)")
--	mw.logObject(fbdata)
	-- Konsolenzeile zum Debuggen:
	-- =p.common{formular="Gebäude/Work",klasse={"Gebäude","Kirche"},kategorie={"Gebäude","Kirchen"},strasse_hnr={suspekt=true},positionscheck=true,pargs={Bild="Angie Oeckl.JPG",Ehemals="Ja",DenkmalstatusBesteht="Ja",Stadtteil="Ronhof; Nordstadt ",location="bla"},pagename="Test/Test;Test"}
	local t = ""
	-- Klasse
	if fbdata.klasse ~= nil then
		t = t .. "{{#set:KlassenName=" .. fbdata.klasse[1] .. "}}"
	end
	-- Formular
	if fbdata.formular ~= nil then
		t = t .. "{{#default_form:" .. fbdata.formular .. "}}"
	end
	-- Kategorien
	local ehemals_text = ""
	if com.isTrue(fbdata.pargs.Ehemals) then
		ehemals_text = " (ehemals)"
	end
	if fbdata.kategorie ~= nil then
		for _, k in ipairs(fbdata.kategorie) do
			t = t .. "[[Kategorie:" .. k .. ehemals_text .. "]]"
		end
	end
	if com.isTrue(fbdata.pargs.DenkmalstatusBesteht) then
		t = t .. "[[Kategorie:Denkmalliste]]"
	end
	local stadtteil = str.splitAndStrip(fbdata.pargs.Stadtteil or "", ";")
	for _, s in ipairs(stadtteil) do
		s = str.strip(tostring(s or ""))
		t = t .. "[[Kategorie:" .. s .. "]]"
	end
	-- Wartungs-Kategorien
	if com.isEmpty(fbdata.pargs.Bild) then
		if fbdata.kategorie ~= nil then
			t = t .. "[[Kategorie:" .. fbdata.kategorie[1] .. " ohne Bild]]"
		else
			t = t .. "[[Kategorie:Ohne Bild]]"
		end
	elseif not wik.pageexists("Bild:" .. fbdata.pargs.Bild) then
		t = t .. "[[Kategorie:Bild nicht gefunden]]"
	end
	if string.find(fbdata.pagename, ";") ~= nil then
		t = t .. "[[Kategorie:Hat Semikolon]]"
	end
	if string.find(fbdata.pagename, "/") ~= nil then
		t = t .. "[[Kategorie:Hat Slash]]"
	end
	if not com.isEmpty(fbdata.strasse_hnr) then
		if fbdata.strasse_hnr.suspekt then
			t = t .. "[[Kategorie:Gebäude mit verdächtiger Straße-Hausnummer-Kombination]]"
		end
	end
	if fbdata.positionscheck and (fbdata.pargs.lat or "") == "" and (fbdata.pargs.lon or "") == "" and
	   (fbdata.pargs.location or "") == "" and not wik.pageexists("GeoJson:" .. (fbdata.pargs.geojson or fbdata.pagename)) and
		fbdata.kategorie ~= nil then
		t = t .. "[[Kategorie:" .. fbdata.kategorie[1] .. ehemals_text .. " ohne Position]]"
	end
--	mw.log("t = " .. t)
	return t
end

function p.tab(t, name)
--	mw.log("tab(t)")
--	mw.logObject(t)
	t = str.strip(t)
	if t ~= "" then
		t = "<tab name = ".. name .. ">" .. t .. "</tab>"
	end
--	mw.log("t = " .. t)
	return t
end

function p.fbdata(frame)
--	mw.log("fbdata(frame)")
--	mw.logObject(frame)
	-- Konsolenzeile zum Debuggen:
	-- =p.fbdata{pargs={a=1}}
	local fbdata = {}
	fbdata.frame, fbdata.pargs = dev.GetFrameAndParentArgs(frame)
	wik.setPagenames(fbdata)
--	mw.logObject(fbdata)
	return fbdata
end

return p