Module:EditAtWikidata: Difference between revisions
Content deleted Content added
Johnrdorazio (talk | contribs) No edit summary |
update from Module:EditAtWikidata/sandbox per talk: tweaks + greatly reduce memory usage + class=noprint |
||
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. |
||
-- 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: |
||
Line 16: | Line 15: | ||
} |
} |
||
local function trimToNil(text) |
|||
-- Return trimmed non-empty text, or nil. |
|||
-- There may be a local parameter supplied, if it's blank, set it to nil |
|||
if type(text) == 'string' then |
|||
⚫ | |||
return text:match('(%S.-)%s*$') |
|||
if local_parm and (local_parm == "") then local_parm = nil end |
|||
⚫ | |||
end |
|||
-- If there is a local parameter used, we don't want to display the message |
|||
⚫ | |||
⚫ | |||
⚫ | |||
local qid = frame.args.qid |
|||
if qid and (qid == "") then qid = nil end |
|||
-- The module can take a parameter pid= |
|||
-- which will create a link to that property in the Wikidata entry for the article |
|||
local propertyID = mw.text.trim(frame.args.pid or "") |
|||
-- Get the object containing all the claims for the article |
|||
local entity = mw.wikibase.getEntityObject(qid) |
|||
if entity then |
|||
local thisQid |
|||
if qid then thisQid = qid else thisQid = entity.id end |
|||
⚫ | |||
local space |
|||
if frame.args.nbsp and (frame.args.nbsp ~= "") then |
|||
⚫ | |||
else |
|||
space = " " |
|||
⚫ | |||
function p._showMessage(args) |
|||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
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) |
|||
⚫ | |||
local space = trimToNil(args.nbsp) and " " or " " |
|||
return |
return |
||
⚫ | |||
"[[File:OOjs UI icon edit-ltr-progressive.svg|frameless|text-top|10px" .. |
|||
⚫ | |||
"|alt=" .. i18n.message .. |
|||
" |
"|link=https://www.wikidata.org/wiki/" .. qid .. |
||
thisQid .. |
|||
( |
(anchor and ("#" .. anchor) or "") .. |
||
"|" .. |
"|class=noprint" .. |
||
⚫ | |||
"]]" |
|||
end |
end |
||
return "" |
|||
end |
|||
function p.showMessage(frame) |
|||
return p._showMessage(frame.args) |
|||
end |
end |
||
Revision as of 22:49, March 13, 2022
Documentation for this module may be created at Module:EditAtWikidata/doc
-- 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