Modul:Tapak web rasmi
Penampilan
local makeUrl = require('Modul:URL')._url
local p = {}
-- Pembalut untuk pcall yang mengembalikan nil pada ralat.
local function quickPcall(func)
local success, result = pcall(func)
if success then
return result
end
end
-- Dapatkan kedudukan untuk jadual ciri-ciri Wikidata. Kembalikan 1, 0 atau -1, dalam
-- urutan kedudukan.
local function getRank(prop)
local rank = prop.rank
if rank == 'preferred' then
return 1
elseif rank == 'normal' then
return 0
elseif rank == 'deprecated' then
return -1
else
-- Tiada kedudukan atau tidak ditakrifkan dianggap sebagai "normal".
return 0
end
end
-- Cari sama ada ciri Wikidata layak sebagai dalam bahasa Melayu.
local function isMalay(prop)
local ret = quickPcall(function ()
for i, lang in ipairs(prop.qualifiers.P2439) do
if lang.datavalue.value['numeric-id'] == 1860 then
return true
end
end
return false
end)
return ret == true
end
-- Mengambil URL tapak web rasmi daripada Wikidata.
local fetchWikidataUrl
fetchWikidataUrl = function()
-- Dapatkan objek untuk semua tapak rasmi di Wikidata.
local websites = quickPcall(function ()
return mw.wikibase.getEntityObject().claims.P856
end)
-- Klonkan objek jika kod lain memerlukannya dalam susunan asalnya.
websites = websites and mw.clone(websites) or {}
-- Tambah indeks jadual jika ia diperlukan dalam isihan.
for i, website in ipairs(websites) do
website._index = i
end
-- Isi tapak web, pertama mengikut kedudukan tertinggi dan kemudian tapak web dalam
-- bahasa Melayu, kemudiannya mengikut kedudukan asal tapk web dalam
-- senarai ciri. Apabila selesai, dapatkan URL daripada objek diisih tertinggi.
table.sort(websites, function(ws1, ws2)
local r1 = getRank(ws1)
local r2 = getRank(ws2)
if r1 ~= r2 then
return r1 > r2
end
local e1 = isEnglish(ws1)
local e2 = isEnglish(ws2)
if e1 ~= e2 then
return e1
end
return ws1._index < ws2._index
end)
local url = quickPcall(function ()
return websites[1].mainsnak.datavalue.value
end)
-- Cachekan hasil supaya melakukan tugas berat sekali sahaja bagi per #invoke.
fetchWikidataUrl = function ()
return url
end
return url
end
-- Berikan pautan URL, ditambah output boleh lihat yang lain.
local function renderUrl(options)
if not options.url then
return '<strong class="error">' ..
'Tiada URL dijumpai. Sila tentukan URL di sini atau tambahkan satu di Wikidata.' ..
'</strong>'
end
local ret = {}
ret[#ret + 1] = string.format(
'<span class="official-website">%s</span>',
makeUrl(options.url, options.display)
)
if options.format == 'flash' then
ret[#ret + 1] = mw.getCurrentFrame():expandTemplate{
title = 'Catatan pautan',
args = {note = 'Memerlukan [[Adobe Flash Player]]'}
}
end
if options.mobile then
ret[#ret + 1] = '(' .. makeUrl(options.mobile, 'Mudah alih') .. ')'
end
return table.concat(ret, ' ')
end
-- Berikan kategori penjejakan.
local function renderTrackingCategory(url, wikidataurl)
if mw.title.getCurrentTitle().namespace ~= 0 then
return ''
end
local category
if not url and not wikidataurl then
category = 'Tapak web rasmi yang kehilangan URL'
elseif not url and wikidataurl then
return ''
elseif url and wikidataurl then
if url:gsub('/%s*$', '') ~= wikidataurl:gsub('/%s*$', '') then
category = 'Tapak web rasmi berbeza di Wikidata dan Wikipedia'
end
else
category = 'Tapak web rasmi tiada di Wikidata'
end
return category and string.format('[[Kategori:%s]]', category) or ''
end
function p._main(args)
local wikidataurl = fetchWikidataUrl()
local url = args[1] or args.URL or args.url or wikidataurl
local formattedUrl = renderUrl{
url = url,
display = args[2] or args.name or 'Tapak web rasmi',
mobile = args.mobile,
format = args.format
}
return formattedUrl .. renderTrackingCategory(url, wikidataurl)
end
function p.main(frame)
local args = require('Modul:Arguments').getArgs(frame, {
wrappers = 'Templat:Tapak web rasmi'
})
return p._main(args)
end
return p