Module:Make Wikisource link
Appearance
![]() | This module is rated as beta, and is ready for widespread use. It is still new and should be used with some caution to ensure the results are as expected. |
![]() | This module is subject to page protection. It is a highly visible module in use by a very large number of pages, or is substituted very frequently. Because vandalism or mistakes would affect many pages, and even trivial editing might cause substantial load on the servers, it is protected from editing. |
![]() | This module depends on the following other modules: |
This module creates a link to a page at Wikisource. It is intended to be called from {{Wikisource/outer core}}; you probably should not use it anywhere else.
If no link at Wikidata is found, it populates the category Category:Wikisource templates with missing id.
Usage
{{#invoke:Make Wikisource link|makeLink|{{{1}}}|{{{2}}}|{{{3}}}|nocat={{{nocat}}}|explicit_lang_param={{{explicit_lang_param}}}|implicit_lang_param={{{implicit_lang_param}}}}}
local p = {}
local getArgs = require('Module:Arguments').getArgs
function p.getSourceName(frame)
local args = getArgs(frame)
local lang = args['explicit-lang-param'] or args['implicit-lang-param'] or 'en'
-- if we have a language parameter, we look at the second unnamed parameter for the source title
local checkIndex = args['implicit-lang-param'] and 2 or 1
if args[checkIndex] then
-- we have a source title parameter, so return that
return args[checkIndex]
else
-- now we check Wikidata
-- there's probably a better way to do this
local wikidataSitelink = mw.wikibase.getSitelink(
wikibase.getEntityIdForCurrentPage() or '',
lang .. 'wikisource'
)
if wikidataSitelink then
return wikidataSitelink
else
-- if Wikidata returns nothing, search for the {{PAGENAME}}
return 'Special:Search/' .. mw.title.getCurrentTitle().text
end
end
end
return p