Difference between revisions of "Module:EditAtWikidata"

From Eat Every Plant
Jump to navigation Jump to search
m (1 revision: Angiosperm families - QR - 2nd try)
 
m (1 revision: Fuchsia)
 
(One intermediate revision by the same user 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 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
 
-- 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.
 
-- 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 = {}
Line 13: Line 13:
 
local i18n =
 
local i18n =
 
{
 
{
    ["message"] = "Edit this at Wikidata"
+
["message"] = "Edit this at Wikidata"
 
}
 
}
  
 
p.showMessage = function(frame)
 
p.showMessage = function(frame)
 
 
-- There may be a local parameter supplied, if it's blank, set it to nil
 
-- There may be a local parameter supplied, if it's blank, set it to nil
 
local local_parm =  mw.text.trim(frame.args[1] or "")
 
local local_parm =  mw.text.trim(frame.args[1] or "")
if local_parm and (#local_parm == 0) then local_parm = nil end
+
if local_parm and (local_parm == "") then local_parm = nil end
+
 
 
-- If there is a local parameter used, we don't want to display the message
 
-- If there is a local parameter used, we don't want to display the message
 
if local_parm then return nil end
 
if local_parm then return nil end
+
 
 
-- Can take a named parameter |qid which is the Wikidata ID for the article.
 
-- Can take a named parameter |qid which is the Wikidata ID for the article.
 
-- This will not normally be used except for testing outside the article.
 
-- This will not normally be used except for testing outside the article.
 
local qid = frame.args.qid
 
local qid = frame.args.qid
if qid and (#qid == 0) then qid = nil end
+
if qid and (qid == "") then qid = nil end
+
 
-- The module can take a parameter pid=  
+
-- The module can take a parameter pid=
 
-- which will create a link to that property in the Wikidata entry for the article
 
-- which will create a link to that property in the Wikidata entry for the article
 
local propertyID = mw.text.trim(frame.args.pid or "")
 
local propertyID = mw.text.trim(frame.args.pid or "")
+
 
 
-- Get the object containing all the claims for the article
 
-- Get the object containing all the claims for the article
 
local entity = mw.wikibase.getEntityObject(qid)
 
local entity = mw.wikibase.getEntityObject(qid)
Line 39: Line 38:
 
local thisQid
 
local thisQid
 
if qid then thisQid = qid else thisQid = entity.id end
 
if qid then thisQid = qid else thisQid = entity.id end
+
return
local icon
+
" [[File:Blue pencil.svg |frameless |text-top |10px |alt=" ..
if propertyID then
+
i18n.message ..
icon = " [[File:Blue pencil.svg |frameless |text-top |10px |alt=" .. i18n.message .. " |link=https://www.wikidata.org/wiki/" .. thisQid .. "#" .. propertyID .. "|" .. i18n.message .. "]]"
+
" |link=https://www.wikidata.org/wiki/" ..
else
+
thisQid ..
icon = " [[File:Blue pencil.svg |frameless |text-top |10px |alt=" .. i18n.message .. " |link=https://www.wikidata.org/wiki/" .. thisQid .. "|" .. i18n.message .. "]]"
+
(propertyID == "" and "" or ("#" .. propertyID)) ..
end
+
"|" .. i18n.message .. "]]"
 
return icon
 
 
end
 
end
 
 
end
 
end
 
  
 
return p
 
return p

Latest revision as of 21:34, 3 August 2018

-- 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: -- --

local p = {}

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

p.showMessage = function(frame) -- There may be a local parameter supplied, if it's blank, set it to nil local local_parm = mw.text.trim(frame.args[1] or "") if local_parm and (local_parm == "") then local_parm = nil end

-- If there is a local parameter used, we don't want to display the message if local_parm then return nil end

-- Can take a named parameter |qid which is the Wikidata ID for the article. -- This will not normally be used except for testing outside the article. 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 return " " .. i18n.message .. "" end end

return p