Module:EditAtWikidata: Difference between revisions
Jump to navigation
Jump to search
Richardpruen (talk | contribs) m (1 revision imported: Wikipedia article on Nicotine templates needed) |
Richardpruen (talk | contribs) m (1 revision imported: Templates and CSS files) |
||
(2 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: | ||
Line 16: | Line 15: | ||
} | } | ||
local function trimToNil(text) | |||
-- | -- Return trimmed non-empty text, or nil. | ||
if type(text) == 'string' then | |||
if | 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 | return | ||
space .. "[[File:OOjs UI icon edit-ltr-progressive.svg |frameless |text-top |10px |alt=" .. | space .. | ||
"[[File:OOjs UI icon edit-ltr-progressive.svg|frameless|text-top|10px" .. | |||
" |link=https://www.wikidata.org/wiki/" .. | "|alt=" .. i18n.message .. | ||
"|link=https://www.wikidata.org/wiki/" .. qid .. | |||
( | (anchor and ("#" .. anchor) or "") .. | ||
"|" .. i18n.message .. "]]" | "|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