Moduuli:Kuuntele
Siirry navigaatioon
Siirry hakuun
Tämän moduulin ohjeistuksen voi tehdä sivulle Moduuli:Kuuntele/ohje
-- This module implements {{ääninäytelaatikko}}
local p = {}
-- ei esitetä ohjetekstiä: teksti pitäisi näyttää vähintään kerran
-- mutta jos on muu painava syy ja vähennetään toistoa
local nohelptext = false
-- ei esitetä kuvaa soittimessa: oletuksena näkyy vasemmalla puolella
-- mutta jos esitetään muutoin se helpottaa mobiilisovelluksen toimintaa
local noimage = false
local function seurantaluokat(noFile, noName, notAvailable)
-- toistaiseksi vain yksi
local luokat = '[[Luokka:Ääninäytteelliset sivut]]'
if (noFile == true) then
luokat = luokat .. '[[Luokka:Ääninäytelaatikot ilman tiedostoja]]'
end
if (noName == true) then
luokat = luokat .. '[[Luokka:Ääninäytelaatikot ilman nimeä]]'
end
if (notAvailable == true) then
luokat = luokat .. '[[Luokka:Ääninäytelaatikon tiedosto ei ole saatavilla]]'
end
return luokat
end
-- soittimen aikajana
local function kappalelohko(tiedosto, nimi, leveys)
--local text1 = string.format('[[:File:%s|%s]]', filename, title)
--local text2 = string.format('[[File:%s|%spx|noicon]]', filename, leveys)
local text1 = '[[:File:' .. tiedosto ..'|' .. nimi ..']]'
local text2 = '[[File:' .. tiedosto .. '|' .. leveys .. 'px|noicon]]'
return text1 .. text2
end
-- kuvaileva teksti aikajanan alle
local function kuvauslohko(parent, teksti)
local desc = parent:tag('div')
desc:addClass('kuuntele-kuvauslohko')
:wikitext(teksti)
end
-- soitin, jossa aikajana ja kuvaus yhdelle kappaleelle
local function soitinlohko(parent, tiedosto, nimi, kuvaus, leveys)
local alaluokka = 'listenlist'
if (noimage == true) then
alaluokka = 'listen-noimage'
end
if (tiedosto and nimi) then
local lista = parent:tag('div')
lista:addClass('medialist ' .. alaluokka)
:cssText('width:' .. leveys .. 'px;padding-top:0em;padding-bottom:0em;')
local entry = lista:tag('div')
:wikitext(
kappalelohko(tiedosto, nimi, leveys))
if (kuvaus) then
kuvauslohko(lista, kuvaus)
end
end
end
-- kaksoispisteet pisteeksi
-- TODO: kesto pitäisi esittää pisteellä eroteltuna, ei kaksoispisteellä..
-- katso saako sen jotenkin pakotettua soittimen parametreihin vai käyttääkö se aina itse haettua
local function korjaakesto(kesto)
if kesto == nil then
return nil
end
local tunnit, minuutit, sekunnit
-- Try to match times like "1:23:45".
tunnit, minuutit, sekunnit = kesto:match('^(%d+):(%d%d):(%d%d)$')
if tunnit and minuutit and sekunnit then
kesto = tunnit .. '.' .. minuutit .. '.' .. sekunnit
return kesto
end
-- The previous attempt didn't match. Try to match times like "1:23".
minuutit, sekunnit = kesto:match('^(%d?%d):(%d%d)$')
if minuutit and sekunnit then
-- allow minutes.seconds even if either is zero (it is used in some articles)
kesto = minuutit .. '.' .. sekunnit
return kesto
end
return kesto
end
local function rivinumero(args, field)
local maxnum = 0
for k, v in pairs(args) do
local num = tostring(k):match('^' .. field .. '([1-9]%d*)$')
if num then
local numero = tonumber(num)
if numero > maxnum then
maxnum = numero
end
end
end
return maxnum
end
function p._main(args)
-- ohjeteksti (pitäisi olla vähintään kerran sivulla mutta kerran laatikossa voi olla ok?)
if args['helpnote'] and args['helpnote'] == 'no' then
nohelptext = true
end
if args['eiohjetta'] and args['eiohjetta'] == 'kyllä' then
nohelptext = true
end
if args['eikuvaa'] and args['eikuvaa'] == 'kyllä' then
noimage = true
end
-- laske leveydet jos piilotetaan kuva
local leveys = 300
local leveysali = 265
if (args['leveys']) then
leveys = args['leveys']
if (args['leveysali']) then
leveysali = args['leveysali']
end
elseif (noimage == true) then
-- ei ole pakotettu leveyksiä ja ei esitetä kuvaa
leveys = 250
leveysali = 245
end
-- TODO: virheen tarkistus
--if (leveys < 250 or leveysali < 240) then
-- virhe: liian pieni laatikko -> soitin ei toimi oikein mobiiliversiossa
--end
-- vasen tai oikea reuna
-- TODO: keskitys ? vain jos upotetaan?
local sijoitus = 'right'
if (args['sijoitus']) then
if (args['sijoitus'] == 'vasen' or args['sijoitus'] == 'left') then
sijoitus = 'left'
end
if (args['sijoitus'] == 'oikea' or args['sijoitus'] == 'right') then
sijoitus = 'right'
end
end
local rivit = rivinumero(args, 'tiedosto')
local mallinetyylit = mw.getCurrentFrame():extensionTag{
name = 'templatestyles', args = { src = 'Moduuli:Kuuntele/styles.css' }
}
-- laatikon tiedot
local rootnode = mw.html.create()
local margin
if (sijoitus == 'left') then
margin = 'margin:3px 1em 3px 0; padding: 0 2em 0 0;'
else
margin = 'margin:3px 0 3px 1em; padding: 0 2em 0 0;'
end
-- laatikon ulkokehys
local juuri = rootnode:tag('div')
juuri:addClass('kuuntele-laatikko')
:cssText('float:' .. sijoitus .. '; clear:' .. sijoitus .. '; width:' .. leveys .. 'px; '.. margin .. ';')
-- laatikon ylälaidan otsikko
if (args['otsikko']) then
local otsake = juuri:tag('div')
otsake:addClass('kuuntele-otsikko')
:wikitext(args['otsikko'])
end
-- jos ei ole tiedostoa tai numeroituja rivejä -> virhe -> näytetään laatikossa
if (not args['tiedosto'] and rivit == 0) then
local virheteksti = juuri:tag('span')
virheteksti:addClass('error')
:wikitext('Ei tiedostoa')
local laatikonteksti = mallinetyylit .. tostring(rootnode)
return laatikonteksti .. seurantaluokat(true, false, false)
end
-- jos ei ole nimeä tai numeroituja rivejä -> virhe -> näytetään laatikossa
if (not args['nimi'] and rivit == 0) then
local virheteksti = juuri:tag('span')
virheteksti:addClass('error')
:wikitext('Ei nimeä')
local laatikonteksti = mallinetyylit .. tostring(rootnode)
return laatikonteksti .. seurantaluokat(false, true, false)
end
-- TODO: tarkista yritetäänkö ulkoista linkkiä
-- -> virhe, ei sallita
--if (args['tiedosto'].substr('http:// ')) then
-- virhe: ei voida sallia ulkoisia linkkejä? vai voidaanko?
--end
-- numeroimaton kappale ja soitin
if (args['tiedosto'] and args['nimi']) then
soitinlohko(juuri, args['tiedosto'], args['nimi'], args['kuvaus'], leveysali)
end
-- numeroidut lisärivit
local rivinro = 1
while (rivinro <= rivit) do
local numero = tostring(rivinro)
if (args['tiedosto' .. numero] and args['nimi' .. numero]) then
soitinlohko(juuri, args['tiedosto' .. numero], args['nimi' .. numero], args['kuvaus' .. numero], leveysali)
end
-- TODO: jos vain jompikumpi annettu voi olla typo -> seurantaluokka
rivinro = rivinro +1
end
-- ohjeteksti
if (nohelptext == false) then
local helptext = juuri:tag('p')
helptext:addClass('kuuntele-ohje')
:wikitext('Äänitiedostojen [[Wikipedia:Ääni ja video|kuunteluohjeet]]')
end
--local laatikonteksti = tostring(rootnode)
local laatikonteksti = mallinetyylit .. tostring(rootnode)
return laatikonteksti .. seurantaluokat(false, false, false)
end
function p.main(frame)
local origArgs
if frame == mw.getCurrentFrame() then
origArgs = frame:getParent().args
for k, v in pairs( frame.args ) do
origArgs = frame.args
break
end
else
origArgs = frame
end
local args = {}
for k, v in pairs(origArgs) do
if v ~= '' then
args[k] = v
end
end
return p._main(args)
end
return p