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