Module:Find sources: Difference between revisions

From All Skies Encyclopaedia
imported>Mr. Stradivarius
(use MediaWiki-message-style keys)
imported>Mr. Stradivarius
(expose the renderLink function so that it can be used in the autodocs)
Line 45: Line 45:
end
end


local function renderLink(code, searchTerms, display)
function p._renderLink(code, searchTerms, display)
-- Renders the external link wikicode for one link, given the link code,
-- Renders the external link wikicode for one link, given the link code,
-- a table of search terms, and an optional display value.
-- a table of search terms, and an optional display value.
Line 121: Line 121:
' '
' '
)
)
introLink = renderLink(code, searchTerms, display)
introLink = p._renderLink(code, searchTerms, display)
else
else
introLink = ''
introLink = ''
Line 129: Line 129:
local links = {}
local links = {}
for i, t in ipairs(templateCfg.links) do
for i, t in ipairs(templateCfg.links) do
links[i] = renderLink(t.code, searchTerms, t.display)
links[i] = p._renderLink(t.code, searchTerms, t.display)
end
end
local separator = templateCfg.separator or cfg['default-separator']
local separator = templateCfg.separator or cfg['default-separator']

Revision as of 07:49, 28 September 2014

This module produces a list of links to search engines to help editors find sources about a given subject. It implements {{find sources}} and other similar templates. It is highly extensible; new templates and new link types can be added easily and by any user.

Usage

From wikitext

Usually, from wikitext this module should be used via a template, e.g. {{find sources}}. However, it is also possible to use it directly from #invoke, like this:

{{#invoke:Find sources|template|search term 1|search term 2|...}}
  • template is the name of the template that should be called. It must be the full page name of the template, without the namespace, and with the correct capitalisation. So, for Template:Find sources, the template name should be "Find sources"; "find sources" with a lower-case "f" would cause an error. This parameter is required.
  • search term 1, search term 2, etc., are the terms to be searched for in each of the search engine links. The first search term will appear in quotation marks, and subsequent search terms will be added without quotation marks. Each term will be separated by spaces. These parameters are all optional. If no parameters are given, the current page name will be used as a search term.

Alternatively the following can be used, which will convert any title to a search query, with the main portion of the title in quotation marks, and any parenthetical disambiguator outside quotation marks.

{{#invoke:Find sources|template|title=title}}
  • template as above, is the name of the template that should be called. It must be the full page name of the template, without the namespace, and with the correct capitalisation. So, for Template:Find sources, the template name should be "Find sources"; "find sources" with a lower-case "f" would cause an error. This parameter is required.
  • title the title to be converted to a search query. This is processed in the same way as the subpage name of the page if no parameters are used.

From Lua

Load the module with the following code:

local mFindSources = require('Module:Find sources')

You can then produce the list of search links like this:

mFindSources._main(template, searchTerms)
  • template is the template name, as outlined in the #From wikitext section above. This parameter is required.
  • searchTerms is an array of search terms. Each item in the array corresponds to a numbered search term as outlined in the #From wikitext section above. Alternatively, an empty table with the title key set will automatically generate a query as described above. This parameter is optional.

Example syntax:

mFindSources._main('Find sources', {'Albert Einstein', '-"Marilyn Monroe"', 'relativity', 'science'})

Available templates

The following templates are available for use:

Template Description Example Configuration
Find general sources The most widely used source-finding template. Until September 2014 it was transcluded on all AfD discussion pages. Module:Find_sources:54: invalid link code 'google'; no link config found at Module:Find sources/links/google main, documentation
Find sources mainspace A source-finding template for use in mainspace. Used in Template:Notability. Module:Find_sources:54: invalid link code 'google'; no link config found at Module:Find sources/links/google main, documentation
Find sources medical No description available Module:Find_sources:54: invalid link code 'medrs'; no link config found at Module:Find sources/links/medrs main, documentation
Find sources video games The source-finding template transcluded on AfD pages for video games and related topics. Module:Find_sources:54: invalid link code 'google'; no link config found at Module:Find sources/links/google main, documentation

Making new templates

There are two basic ingredients to making a new source-finding template. The first is the template configuration module, and the second is the template invocation on the template page.

Template configuration page

To find the name of the template configuration page, take the page name of your proposed template without the namespace prefix, and add it to the base page of "Module:Find sources/templates/". For example, for Template:Find sources, the configuration page is located at Module:Find sources/templates/Find sources. Note that the template must be capitalised exactly as the page name is, otherwise the arguments will not be passed through from the template page to the module.

The template configuration page should look something like this:

return {
	blurb = "Find sources for $1 – $2",
	introLink = {code = 'google'},
	links = {
		{code = 'google news', display = 'news'},
		{code = 'google newspapers', display = 'newspapers', tooltip = 'Search newspapers with Google Books'}
	},
	separator = ', ',
	isUsedInMainspace = true,
	class = 'custom-class',
	style = 'color: green; font-size: 110%;'
}
  • blurb - the text presented to users. There are two parameters available in the blurb, $1 and $2. $1 is the intro link, if specified, and $2 represents the other links. This field is required.
  • introLink - an optional introductory link. If specified, this must be a link table. If the display value in the link table is not set, the search terms that the user entered will be used instead.
  • links - an array of link tables defining the main links to be used by the template. This field is required.
  • separator - the text separating the search engine links. This field is optional; the default value is taken from MediaWiki:Dot-separator.
  • isUsedInMainspace - set this to true if the template will be used in the main namespace. If this is not set, when the template is used in the main namespace it will produce an error and be put in Category:Pages with templates in the wrong namespace.
  • class - a custom HTML class to apply to the template text. The "plainlinks" class is added by default. This field is optional.
  • style - custom CSS to apply to the template text. This field is optional.

Once you have created your template configuration page, you need to add the template to Module:Find sources/templates in order for it to show up in the table of templates on this documentation page.

Link tables

Link tables are used in the "introLink" and "links" fields of the template configuration. They can contain three fields, "code", "display", and "tooltip". The "code" field is required, and must be one of the link codes listed in the table below. The "display" field is optional, and specifies a custom display value for that link to be used by the template. If the display field is not set, a default value is set by the module. The "tooltip" field is also optional, and specifies a custom tooltip for the link. HTML reserved characters are escaped by the module. If the field is absent, no tooltip is displayed. For the "introLink" field, the default value is the search text entered by the user; for the "links" field, the default value is defined in the link configuration modules.

The following table contains all the available link codes, with descriptions and examples.

Code Description Example Notes
ap The Associated Press, an American news agency Module:Find_sources:54: invalid link code 'ap'; no link config found at Module:Find sources/links/ap
archive.org The Internet Archive, a digital library of public websites. Module:Find_sources:54: invalid link code 'archive.org'; no link config found at Module:Find sources/links/archive.org
bbc BBC, British public broadcaster Module:Find_sources:54: invalid link code 'bbc'; no link config found at Module:Find sources/links/bbc
bing Bing, Microsoft's flagship search engine. Module:Find_sources:54: invalid link code 'bing'; no link config found at Module:Find sources/links/bing
britannica Encyclopedia Britannica Module:Find_sources:54: invalid link code 'britannica'; no link config found at Module:Find sources/links/britannica
british library National library of the United Kingdom Module:Find_sources:54: invalid link code 'british library'; no link config found at Module:Find sources/links/british library
ccsearch CC Search: The official search engine of Creative Commons Module:Find_sources:54: invalid link code 'ccsearch'; no link config found at Module:Find sources/links/ccsearch
cochrane Cochrane Library: Leading publisher of systematic reviews. Module:Find_sources:54: invalid link code 'cochrane'; no link config found at Module:Find sources/links/cochrane
doaj DOAJ: Directory of Open Access Journals Module:Find_sources:54: invalid link code 'doaj'; no link config found at Module:Find sources/links/doaj
duckduckgo DuckDuckGo, a search engine that emphasizes protecting searchers' privacy and avoiding the "filter bubble" of personalized search results. Module:Find_sources:54: invalid link code 'duckduckgo'; no link config found at Module:Find sources/links/duckduckgo
eowb No description available Module:Find_sources:54: invalid link code 'eowb'; no link config found at Module:Find sources/links/eowb
free news sources No description available Module:Find_sources:54: invalid link code 'free news sources'; no link config found at Module:Find sources/links/free news sources
gale Gale Academic OneFile: Academic publisher portal from Gale. Access via Wikipedia Library Module:Find_sources:54: invalid link code 'gale'; no link config found at Module:Find sources/links/gale
gin No description available Module:Find_sources:54: invalid link code 'gin'; no link config found at Module:Find sources/links/gin
globe and mail The website of The Globe and Mail, a newspaper of record for Canada. Module:Find_sources:54: invalid link code 'globe and mail'; no link config found at Module:Find sources/links/globe and mail
google Google, the flagship search engine from Google Inc. Module:Find_sources:54: invalid link code 'google'; no link config found at Module:Find sources/links/google
google books Google Books, Google's search engine for books. Module:Find_sources:54: invalid link code 'google books'; no link config found at Module:Find sources/links/google books
google free images Google Images, Google's search engine for images. Only images compatible with Wikipedia's licensing are included. Module:Find_sources:54: invalid link code 'google free images'; no link config found at Module:Find sources/links/google free images
google news Google News, Google's search engine for news sites. Module:Find_sources:54: invalid link code 'google news'; no link config found at Module:Find sources/links/google news In the past this link searched news archives, but this functionality has been removed by Google. Currently, only recent news articles are searched.
google newspapers Google Newspapers, a search of Google's digital archive of print newspapers. Module:Find_sources:54: invalid link code 'google newspapers'; no link config found at Module:Find sources/links/google newspapers
google scholar Google Scholar, Google's search engine for academic papers and other scholarly research. Module:Find_sources:54: invalid link code 'google scholar'; no link config found at Module:Find sources/links/google scholar
haaretz The website of Haaretz, a newspaper of record for Israel. Module:Find_sources:54: invalid link code 'haaretz'; no link config found at Module:Find sources/links/haaretz
infoplease No description available Module:Find_sources:54: invalid link code 'infoplease'; no link config found at Module:Find sources/links/infoplease
internet archive scholar The Internet Archive Scholar, a digital library of open access academic journals. Module:Find_sources:54: invalid link code 'internet archive scholar'; no link config found at Module:Find sources/links/internet archive scholar
jstor JSTOR, an online library containing digitised versions of academic journals. Requires a subscription. Module:Find_sources:54: invalid link code 'jstor'; no link config found at Module:Find sources/links/jstor
library of congress U.S. Library of Congress Module:Find_sources:54: invalid link code 'library of congress'; no link config found at Module:Find sources/links/library of congress
mail and guardian The website of the Mail & Guardian, a newspaper of record for South Africa. Module:Find_sources:54: invalid link code 'mail and guardian'; no link config found at Module:Find sources/links/mail and guardian
medrs MEDRS: Ideal sources for biomedical material include recent literature reviews and medical guidelines; learn how to identify reliable sources for medical content. Module:Find_sources:54: invalid link code 'medrs'; no link config found at Module:Find sources/links/medrs
muse No description available Module:Find_sources:54: invalid link code 'muse'; no link config found at Module:Find sources/links/muse
new york times The website of The New York Times, a newspaper of record for the United States. Module:Find_sources:54: invalid link code 'new york times'; no link config found at Module:Find sources/links/new york times
new zealand herald The website of The New Zealand Herald, a newspaper of record for New Zealand. Module:Find_sources:54: invalid link code 'new zealand herald'; no link config found at Module:Find sources/links/new zealand herald
openlibrary No description available Module:Find_sources:54: invalid link code 'openlibrary'; no link config found at Module:Find sources/links/openlibrary
openmd OpenMD: Search engine for medical literature. Module:Find_sources:54: invalid link code 'openmd'; no link config found at Module:Find sources/links/openmd
pubmed PubMed: Search engine for biomedical literature from NLM. Module:Find_sources:54: invalid link code 'pubmed'; no link config found at Module:Find sources/links/pubmed
reuters Reuters, an international news agency Module:Find_sources:54: invalid link code 'reuters'; no link config found at Module:Find sources/links/reuters
sciencedirect ScienceDirect: Elsevier's scientific, technical, and medical research portal. Module:Find_sources:54: invalid link code 'sciencedirect'; no link config found at Module:Find sources/links/sciencedirect
south china morning post The website of the South China Morning Post, a newspaper of record for Hong Kong. Module:Find_sources:54: invalid link code 'south china morning post'; no link config found at Module:Find sources/links/south china morning post
springer Springer Nature's portal for journals, books, and reference works. Module:Find_sources:54: invalid link code 'springer'; no link config found at Module:Find sources/links/springer
statpearls StatPearls: the largest provider of healthcare continuing education worldwide, providing peer-reviewed practice-guiding knowledge authored by clinical experts. Module:Find_sources:54: invalid link code 'statpearls'; no link config found at Module:Find sources/links/statpearls
straits times The website of The Straits Times, a newspaper of record for Singapore. Module:Find_sources:54: invalid link code 'straits times'; no link config found at Module:Find sources/links/straits times
sydney morning herald The website of The Sydney Morning Herald, a newspaper of record for Australia. Module:Find_sources:54: invalid link code 'sydney morning herald'; no link config found at Module:Find sources/links/sydney morning herald
the age The website of The Age, a newspaper of record for Australia. Module:Find_sources:54: invalid link code 'the age'; no link config found at Module:Find sources/links/the age
the guardian The Guardian newspaper, U.K. Module:Find_sources:54: invalid link code 'the guardian'; no link config found at Module:Find sources/links/the guardian
the hindu The website of The Hindu, a newspaper of record for India. Module:Find_sources:54: invalid link code 'the hindu'; no link config found at Module:Find sources/links/the hindu
the times The website of The Times, a newspaper of record for the United Kingdom. Module:Find_sources:54: invalid link code 'the times'; no link config found at Module:Find sources/links/the times
times of india The website of The Times of India, a newspaper of record for India. Module:Find_sources:54: invalid link code 'times of india'; no link config found at Module:Find sources/links/times of india
trip Trip Database: Search engine for clinical research evidence. Module:Find_sources:54: invalid link code 'trip'; no link config found at Module:Find sources/links/trip
uptodate No description available Module:Find_sources:54: invalid link code 'uptodate'; no link config found at Module:Find sources/links/uptodate
vgrl Wikipedia:WikiProject Video games/Reference library internal archive search. Module:Find_sources:54: invalid link code 'vgrl'; no link config found at Module:Find sources/links/vgrl
vgrs Google RS, a custom Google search engine that limits the search to sites listed in Wikipedia:WikiProject Video games/Sources. Module:Find_sources:54: invalid link code 'vgrs'; no link config found at Module:Find sources/links/vgrs
vgtalk A search in the WikiProject Video games talk page and its archives under Wikipedia talk:WikiProject Video games. Module:Find_sources:54: invalid link code 'vgtalk'; no link config found at Module:Find sources/links/vgtalk
wikipedia library Search results from dozens of services provided via EBSCOhost to Wikipedians via Wikipedia:The Wikipedia Library. Module:Find_sources:54: invalid link code 'wikipedia library'; no link config found at Module:Find sources/links/wikipedia library
wikipedia reference search Wikipedia Reference Search, a Google search that only searches sites vetted by Wikipedians. Module:Find_sources:54: invalid link code 'wikipedia reference search'; no link config found at Module:Find sources/links/wikipedia reference search
wiley Wiley Online Library: Wiley's portal for academic articles, books, and collections. Module:Find_sources:54: invalid link code 'wiley'; no link config found at Module:Find sources/links/wiley
wsj The website of The Wall Street Journal, a newspaper of record for the United States. Module:Find_sources:54: invalid link code 'wsj'; no link config found at Module:Find sources/links/wsj

Template invocation

The template invocation on the template page itself should look like this:

{{#invoke:Find sources|template}}<noinclude>
{{#invoke:Find sources/autodoc|template}}
</noinclude>

This activates the template code and also provides automatic documentation. template is the name of the template without the namespace prefix, and must be correctly capitalised.

If you want to use custom documentation from a /doc subpage instead of the automatic documentation, use this invocation instead:

{{#invoke:Find sources|template}}<noinclude>
{{documentation}}
<!-- Categories go on the /doc subpage, and interwikis go on Wikidata. -->
</noinclude>

Adding new links

New links are added to Module:Find sources/links. Link codes should be short but descriptive, and should be in lower case. For example, the link code for Google search is "google".

The link configuration page should look something like this:

return {
	url = '//www.google.com/search?as_eq=wikipedia&q=$1',
	display = 'Google',
    description = '[[Google]], the flagship search engine from Google Inc.',
}
Parameters
Parameter Description
url The url to perform the search. This field takes a parameter $1, which is the URL-encoded search text entered by the user. This field is required.
display If a display value is not specified in the template configuration, this value is used instead. This field is required.
separator This is used to separate the search terms entered by the user. This is optional, and defaults to "+" (a URL-encoded space).
description a brief description of what the search engine link does. This is used in the template documentation to generate the list of link descriptions, and also to make the descriptions in the table of link codes above. This is optional, but recommended.
notes notes about the search engine link. These are put in the table of link codes above, but they are not put in the template documentation for individual source-finding templates. This field is optional.

Automatic documentation

Automatic documentation is provided for templates based on this module; the documentation is generated by Module:Find sources/autodoc. The autodoc module uses the following pages:

Template documentation configuration page

This page is located at the "/autodoc" subpage of the template configuration page. It is only used to generate the documentation, not to generate any of the actual template output, so it does not need to be protected. It should look something like this:

return {
	shortcuts = {'shortcut1', 'shortcut2'},
	description = 'This template is used to provide source links on [[WP:AFD|AfD]] pages',
	docIntro = 'This template produces a series of search-engine links to be used on [[WP:AFD|AfD]] pages.'
}
  • shortcuts - an array of shortcuts that redirect to the template page. These are displayed on the template documentation page using the {{template shortcut}} template.
  • description - a brief description of what the template does. This is displayed on this documentation page in the table of available templates.
  • docIntro - text to be used instead of the first sentence of the template documentation for individual source-finding templates. This is optional, and the default value is "This template produces a series of links to various search interfaces to help find additional reference material for articles."

Configuration

The messages used in this module can be found at Module:Find sources/config and Module:Find sources/autodoc/config. This can be helpful for translating this module for use in other languages. Note that any template and link configuration used must also be translated.


-- This module implements {{find sources}} and other similar templates, and
-- also provides a mechanism to easily create new source-finding templates.

-- Define constants
local ROOT_PAGE = 'Module:Find sources'
local TEMPLATE_ROOT = ROOT_PAGE .. '/templates/' -- for template config modules
local LINK_ROOT = ROOT_PAGE .. '/links/' -- for link config modules
local CONFIG_PAGE = ROOT_PAGE .. '/config' -- for global config

-- Load required modules
local checkType = require('libraryUtil').checkType
local cfg = mw.loadData(CONFIG_PAGE)

local p = {}

local function maybeLoadData(page)
	local success, data = pcall(mw.loadData, page)
	return success and data
end

local function substituteParams(msg, ...)
	local params = {...}
	if params[1] then
		return mw.message.newRawMessage(msg):params(params):plain()
	else
		return msg
	end
end

local function renderSearchString(searchTerms, separator, transformFunc)
	-- This takes a table of search terms and turns it into a search string
	-- that can be used in a URL or in a display value. The transformFunc
	-- parameter can be used to transform each search term in some way (for
	-- example, URL-encoding them).
	local searchStrings = {}
	for i, s in ipairs(searchTerms) do
		searchStrings[i] = s
	end
	if transformFunc then
		for i, s in ipairs(searchStrings) do
			searchStrings[i] = transformFunc(s)
		end
	end
	return table.concat(searchStrings, separator)
end

function p._renderLink(code, searchTerms, display)
	-- Renders the external link wikicode for one link, given the link code,
	-- a table of search terms, and an optional display value.

	-- Get link config.
	local linkCfg = maybeLoadData(LINK_ROOT .. code)
	if not linkCfg then
		error(string.format(
			"invalid link code '%s'; no link config found at [[%s]]",
			code,
			LINK_ROOT .. code
		))
	end

	-- Make URL.
	local url
	do
		local separator = linkCfg.separator or "+"
		local searchString = renderSearchString(
			searchTerms,
			separator,
			mw.uri.encode
		)
		url = substituteParams(linkCfg.url, searchString)
	end
	
	return string.format('[%s %s]', url, display or linkCfg.display)
end

function p._main(template, args)
	-- The main access point from Lua.
	checkType('_main', 1, template, 'string')
	checkType('_main', 2, args, 'table', true)
	args = args or {}
	local title = mw.title.getCurrentTitle()

	-- Get the template config.
	local templateCfgPage = TEMPLATE_ROOT .. template
	local templateCfg = maybeLoadData(templateCfgPage)
	if not templateCfg then
		error(string.format(
			"invalid template name '%s'; no template config found at [[%s]]",
			template, templateCfgPage
		))
	end

	-- Namespace check.
	if not templateCfg.isUsedInMainspace and title.namespace == 0 then
		local formatString = '<strong class="error">%s</strong>'
		if cfg['namespace-error-category'] then
			formatString = formatString .. '[[%s:%s]]'
		end
		return string.format(
			formatString,
			cfg['namespace-error'],
			mw.site.namespaces[14].name,
			cfg['namespace-error-category']
		)
	end

	-- Get the search terms from the arguments.
	local searchTerms = {}
	for i, s in ipairs(args) do
		searchTerms[i] = s
	end
	searchTerms[1] = searchTerms[1] or title.subpageText
	searchTerms[1] = '"' .. searchTerms[1] .. '"'

	-- Make the intro link
	local introLink
	if templateCfg.introLink then
		local code = templateCfg.introLink.code
		local display = templateCfg.introLink.display or renderSearchString(
			searchTerms,
			'&nbsp;'
		)
		introLink = p._renderLink(code, searchTerms, display)
	else
		introLink = ''
	end

	-- Make the other links
	local links = {}
	for i, t in ipairs(templateCfg.links) do
		links[i] = p._renderLink(t.code, searchTerms, t.display)
	end
	local separator = templateCfg.separator or cfg['default-separator']
	links = table.concat(links, separator)

	-- Make the blurb.
	local blurb = substituteParams(templateCfg.blurb, introLink, links)
	local span = mw.html.create('span')
	span
		:addClass('plainlinks')
		:addClass(templateCfg.class)
		:cssText(templateCfg.style)
		:wikitext(blurb)

	return tostring(span)
end

setmetatable(p, { __index = function(t, template)
	-- The main access point from #invoke.
	-- Invocations will look like {{#invoke:Find sources|template name}},
	-- where "template name" is a subpage of [[Module:Find sources/templates]].
	return function(frame)
		local args = require('Module:Arguments').getArgs(frame, {
			wrappers = mw.site.namespaces[10].name .. ':' .. template
		})
		return t._main(template, args)
	end
end})

return p