Modul:ListenAuswahl
Version vom 6. Mai 2021, 20:03 Uhr von Stewie (Diskussion | Beiträge)
Die Dokumentation für dieses Modul kann unter Modul:ListenAuswahl/Doku erstellt werden
--[[
Lua Alternative für den ersten Teil der Vorlage:Listen, die weitere Listen je nach art der Seite nachläd.
Bisherige auswahl logik:
Teste ob die Seite von Typ Kategorie ist, wenn ja und vorhanden zeige Liste_Pagename (funktioniert)
Wenn Liste_Pagename nicht vorhanden prüfe ob Liste_Basistyp vorhanden ist und zeige diese an
Wenn nicht vorhanden prüfe ob Liste_Hauptkategorie vorhanden und zeige diese und Liste_Eigenkategorie an
Wenn NICHT Kategorie
Wenn Liste_Hauptkategorie vorhanden zeige diese an (Diese prüft ob sie auf einen Basistyp oder anderen eingebunden wird)
zeige immer Liste GehörtZu an
]]--
local p = {} --local p = {} -- p steht für Paket (engl. package)
function p.Liste( frame )
local Pagename = frame.args['Pagename']
if Pagename == nil then return nil end
local returnString = ""
local queryResult = mw.smw.ask('[['..Pagename..']]|?Seitentyp|?Basistyp#|?Hauptkategorie#|?Eigenkategorie#')
if queryResult == nil then return nil end
local Seitentyp = queryResult[1]['Seitentyp']
local Basistyp = nil
if queryResult[1]['Basistyp'] ~= nil
then
Basistyp = queryResult[1]['Basistyp']
Basistyp = string.gsub(Basistyp, "%s+", "_")
end
local Hauptkategorie = nil
if queryResult[1]['Hauptkategorie'] ~= nil
then
Hauptkategorie = queryResult[1]['Hauptkategorie']
Hauptkategorie = string.gsub(Hauptkategorie, "%s+", "_")
end
local Eigenkategorie = nil
if queryResult[1]['Eigenkategorie'] ~= nil
then
Eigenkategorie = queryResult[1]['Eigenkategorie']
Eigenkategorie = string.gsub(Eigenkategorie, "%s+", "_")
end
--teste ob Seitentyp Kategorie
if Seitentyp == 'Kategorie'
then
-- teste ob Liste_Pagename vorhanden ist
local Vorlage = mw.title.new('Liste_'..Pagename, 'Vorlage' )
-- wenn das der fall ist lade entsprechendes template
if Vorlage.exists == true
then
returnString = mw.getCurrentFrame():expandTemplate{title ="Liste_"..Pagename}
return returnString
end
end
--keine Kategorienliste vorhanden, teste ob Basistyp
if Basistyp ~= nil
then
-- teste ob Liste_Basistyp vorhanden ist
local Vorlage = mw.title.new('Liste_'..Basistyp, 'Vorlage' )
if Vorlage.exists == true
then
returnString = mw.getCurrentFrame():expandTemplate{title ="Liste_"..Basistyp}
returnString = mw.getCurrentFrame():callParserFunction{name='#invoke', args={'ListeBasistyp','Liste','Basistyp='..Basistyp}}
return returnString
end
end
--teste ob Liste_Hauptkategrie vorhanden, wenn ja diese nutzen
if Hauptkategorie ~= nil
then
local Vorlage = mw.title.new('Liste_'..Hauptkategorie, 'Vorlage' )
if Vorlage.exists == true
then
returnString = mw.getCurrentFrame():expandTemplate{title ="Liste_"..Hauptkategorie}
--returnString = returnString .. mw.getCurrentFrame():callParserFunction{name='#invoke', args={'ListeBasistyp','Liste','Basistyp='..Basistyp}}
return returnString
end
end
--eigenkategorie (kann basistyp sein dann lieber invoke funktion )
if Eigenkategorie ~= nil
then
local Vorlage = mw.title.new('Liste_'..Eigenkategorie, 'Vorlage' )
if Vorlage.exists == true
then
if Eigenkategorie == "Basistyp"
then
returnString = mw.getCurrentFrame():callParserFunction{name='#invoke', args={'ListeBasistyp','Liste','Basistyp=Basistyp'}}
end
returnString = mw.getCurrentFrame():expandTemplate{title ="Liste_"..Eigenkategorie}
return returnString
end
end
return returnString ..mw.getCurrentFrame():expandTemplate{title ="Liste_GehörtZu"}
end
return p