Module:EditAtWikidata: Difference between revisions

Safer nicotine wiki Tobacco Harm Reduction
Jump to navigation Jump to search
Wikimedia+Commons>Tacsipacsi
(i18n (à la Commons, depending on interface language, not page language))
m (1 revision imported: Templates and CSS files)
 
(3 intermediate revisions by 2 users not shown)
Line 1: Line 1:
-- Module to display an icon with a tooltip such as "Edit this at Wikidata"
-- Module to display an icon with a tooltip such as "Edit this at Wikidata".
-- Icon will be linked to the Wikidata entry for the article where this is placed.
-- Icon is linked to the Wikidata entry for the article where this is placed.
-- This message is only displayed if a local_parameter is not supplied
-- This message is only displayed if a local_parameter is not supplied
-- i.e. when called from a template, it can be coded not to display the message  
-- i.e. when called from a template, it can be coded not to display the message.
-- when a local parameter is in use, preventing the value form Wikidata being fetched.
-- The qid of a Wikidata entry can optionally be supplied for testing outside the article.
-- The qid of a Wikidata entry can optionally be supplied for testing outside the article.
-- Usage:
-- Usage:
-- {{#invoke:EditAtWikidata|showMessage|local_parameter}}
-- {{#invoke:EditAtWikidata|showMessage|local_parameter}}
-- {{#invoke:EditAtWikidata|showMessage|qid=<ArticleID|local_parameter}}
-- {{#invoke:EditAtWikidata|showMessage|qid=<ArticleID>|local_parameter}}


local p = {}
local p = {}


local i18n = {}
local i18n =
{
["message"] = "Edit this at Wikidata"
}


local function getMessage(name)
local function trimToNil(text)
if not i18n[name] then
-- Return trimmed non-empty text, or nil.
local lang = mw.getCurrentFrame():preprocess('{{int:lang}}')
if type(text) == 'string' then
i18n[name] = require('Module:TNT').formatInLanguage(lang, 'I18n/EditAt.tab', name)
return text:match('(%S.-)%s*$')
end
end
return i18n[name]
end
end


p.showMessage = function(frame)
function p._showMessage(args)
local local_parm = trimToNil(args[1])
-- There may be a local parameter supplied, if it's blank, set it to nil
if local_parm then return "" end
local local_parm = mw.text.trim(frame.args[1] or "")
-- Parameter qid=x specifies the Wikidata ID for the article.
if local_parm and (#local_parm == 0) then local_parm = nil end
-- This is not normally used except for testing outside the article.
local qid = trimToNil(args.qid) or mw.wikibase.getEntityIdForCurrentPage()
-- If there is a local parameter used, we don't want to display the message
if qid and mw.wikibase.entityExists(qid) then
if local_parm then return nil end
-- Parameter pid=x uses x as an anchor in the link to the Wikidata entry.
local anchor = trimToNil(args.pid)
-- Can take a named parameter |qid which is the Wikidata ID for the article.
-- Parameter nbsp replaces the leading space with &nbsp;
-- This will not normally be used except for testing outside the article.
local space = trimToNil(args.nbsp) and "&nbsp;" or " "
local qid = frame.args.qid
return
if qid and (#qid == 0) then qid = nil end
space ..
"[[File:OOjs UI icon edit-ltr-progressive.svg|frameless|text-top|10px" ..
-- The module can take a parameter pid=  
"|alt=" .. i18n.message ..
-- which will create a link to that property in the Wikidata entry for the article
"|link=https://www.wikidata.org/wiki/" .. qid ..
local propertyID = mw.text.trim(frame.args.pid or "")
(anchor and ("#" .. anchor) or "") ..
"|class=noprint" ..
-- Get the object containing all the claims for the article
"|" .. i18n.message ..
local entity = mw.wikibase.getEntityObject(qid)
"]]"
if entity then
local thisQid
if qid then thisQid = qid else thisQid = entity.id end
local icon
local msg = getMessage('EditAtWikidata')
if propertyID then
icon = " [[File:Blue pencil.svg |frameless |text-top |10px |alt=" .. msg .. " |link=https://www.wikidata.org/wiki/" .. thisQid .. "#" .. propertyID .. "|" .. msg .. "]]"
else
icon = " [[File:Blue pencil.svg |frameless |text-top |10px |alt=" .. msg .. " |link=https://www.wikidata.org/wiki/" .. thisQid .. "|" .. msg .. "]]"
end
return icon
end
end
return ""
end


function p.showMessage(frame)
return p._showMessage(frame.args)
end
end


return p
return p

Latest revision as of 18:54, 4 December 2022

Module to display an icon with a tooltip such as "Edit this at Wikidata"

  • Icon will be linked to the Wikidata entry for the article where this is placed.
  • This message is only displayed if a local_parameter is not supplied, i.e. when called from a template, it can be coded not to display the message when a local parameter is in use, preventing the value form Wikidata being fetched.
  • The qid of a Wikidata entry can optionally be supplied for testing outside the article.

Usage

To always display the icon:

  • {{#invoke:EditAtWikidata|showMessage}}

To display the icon depending on a local parameter not existing:

  • {{#invoke:EditAtWikidata|showMessage|local_parameter}}

To test the functionality outside of an article:

  • {{#invoke:EditAtWikidata|showMessage|qid=<ArticleID>|local_parameter}}

To make the link point to the given property at the Wikidata entry:

  • {{#invoke:EditAtWikidata|showMessage|pid=<PropertyID>|local_parameter}}

-- Module to display an icon with a tooltip such as "Edit this at Wikidata".
-- Icon is linked to the Wikidata entry for the article where this is placed.
-- This message is only displayed if a local_parameter is not supplied
-- i.e. when called from a template, it can be coded not to display the message.
-- The qid of a Wikidata entry can optionally be supplied for testing outside the article.
-- Usage:
-- {{#invoke:EditAtWikidata|showMessage|local_parameter}}
-- {{#invoke:EditAtWikidata|showMessage|qid=<ArticleID>|local_parameter}}

local p = {}

local i18n =
{
	["message"] = "Edit this at Wikidata"
}

local function trimToNil(text)
	-- Return trimmed non-empty text, or nil.
	if type(text) == 'string' then
		return text:match('(%S.-)%s*$')
	end
end

function p._showMessage(args)
	local local_parm = trimToNil(args[1])
	if local_parm then return "" end
	-- Parameter qid=x specifies the Wikidata ID for the article.
	-- This is not normally used except for testing outside the article.
	local qid = trimToNil(args.qid) or mw.wikibase.getEntityIdForCurrentPage()
	if qid and mw.wikibase.entityExists(qid) then
		-- Parameter pid=x uses x as an anchor in the link to the Wikidata entry.
		local anchor = trimToNil(args.pid)
		-- Parameter nbsp replaces the leading space with &nbsp;
		local space = trimToNil(args.nbsp) and "&nbsp;" or " "
		return
			space ..
			"[[File:OOjs UI icon edit-ltr-progressive.svg|frameless|text-top|10px" ..
			"|alt=" .. i18n.message ..
			"|link=https://www.wikidata.org/wiki/" .. qid ..
			(anchor and ("#" .. anchor) or "") ..
			"|class=noprint" ..
			"|" .. i18n.message ..
			"]]"
	end
	return ""
end

function p.showMessage(frame)
	return p._showMessage(frame.args)
end

return p