Module:EditAtWikidata: Difference between revisions
Jump to navigation
Jump to search
Wikimedia+Commons>Tacsipacsi (i18n (à la Commons, depending on interface language, not page language)) |
Richardpruen (talk | contribs) 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 | -- 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. | ||
-- 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 | local function trimToNil(text) | ||
if | -- Return trimmed non-empty text, or nil. | ||
if type(text) == 'string' then | |||
return text:match('(%S.-)%s*$') | |||
end | end | ||
end | end | ||
p. | function p._showMessage(args) | ||
local local_parm = trimToNil(args[1]) | |||
if local_parm then return "" end | |||
local local_parm = | -- 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 | |||
if local_parm then return | -- 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 | ||
-- This | local space = trimToNil(args.nbsp) and " " or " " | ||
local qid = | return | ||
if qid and ( | 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 | 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 local space = trimToNil(args.nbsp) and " " 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