Module:Attached KML: Difference between revisions
Appearance
Content deleted Content added
L10n for tracking cats, expand {{main other}} |
"...not from Wikidata" is better cat name |
||
Line 22: | Line 22: | ||
cat = { -- tracking categories: full wikimarkup required, or set to the empty string ("") to not to track the condition |
cat = { -- tracking categories: full wikimarkup required, or set to the empty string ("") to not to track the condition |
||
wikidata_kml = "[[Category:Articles using KML from Wikidata]]", -- tracks mainspace articles using KML from Wikidata |
wikidata_kml = "[[Category:Articles using KML from Wikidata]]", -- tracks mainspace articles using KML from Wikidata |
||
local_kml = "[[Category:Articles using KML not |
local_kml = "[[Category:Articles using KML not from Wikidata]]", -- tracks mainspace articles not using KML from Wikidata |
||
}, |
}, |
||
} |
} |
Revision as of 00:08, 24 August 2016
This Lua module is used on approximately 14,000 pages and changes may be widely noticed. Test changes in the module's /sandbox or /testcases subpages, or in your own module sandbox. Consider discussing changes on the talk page before implementing them. |
This module is rated as beta, and is ready for widespread use. It is still new and should be used with some caution to ensure the results are as expected. |
This module depends on the following other modules: |
This module uses TemplateStyles: |
Usage
On English Wikipedia, this module is called by {{Attached KML}}
. See that template's documentation for usage instructions
Set up on another wiki
- Create template and module
- Import this module to that wiki (or copy the code over, giving attribution in the edit summary). Give the module a name that makes sense in that wiki's language (hereafter referred to as MODULENAME)
- Create a template (which should probably have the same name as the module, but referred to here as TEMPLATENAME) containing the code
<includeonly>{{#invoke:MODULENAME|main}}</includeonly><noinclude>{{TEMPLATENAME|demo=yes}}{{Documentation}}</noinclude>
- On Wikidata, add the template to d:Q6690822 and the module to d:Q26689774
- Localise the module. Edit the top bits of the module, between the comments
-- ##### Localisation (L10n) settings #####
and-- #### End of L10n settings ####
, replacing values between"
"
symbols with local values (as necessary) - Create the categories defined in the module localisation. These should be made hidden categories, either by including a Template:Hidden category (Q5879327) template, or by directly including the
__HIDDENCAT__
magic word. - Add documentation to the template (e.g. by translating Template:Attached KML/doc, adjusting as necessary per any localisations made in the previous step) and to the module (please transfer/translate these instructions so that wikimedians who read your wiki but not the English Wikipedia can also set up the module and template on another wiki).
Tracking categories
- Category:Attached KML errors (5) – tracks errors: malformed_qid, bad_qid, no_item, bad_from, error_nokml
- Category:Articles using KML from Wikidata (9,469) – tracks mainspace articles using KML from Wikidata
- Category:Articles using KML not from Wikidata (4,330) – tracks mainspace articles not using KML from Wikidata
-- ##### Localisation (L10n) settings #####
local L10n = {}
-- Template parameter names
-- (replace values in quotes with local parameter names)
L10n.para = {
display = "display",
from = "from",
header = "header",
title = "title",
wikidata = "wikidata",
}
-- Other strings
L10n.str = {
inline = "inline", -- used with display parameter: (|display=inline) or (|display=title) or (|display=inline,title) or (|display=title,inline)
title = "title", -- (as above)
dsep = ",", -- separator between inline and title (comma in the example above in the above)
kml_prefix = "Template:Attached KML/", -- local KML files are stored as subpages of this location
default_title = "Route map", -- default title for links at top of page, when title parameter not used in transclusion
default_header = "", -- default header for links in inline box, when header parameter not used in transclusion
cat = { -- tracking categories: full wikimarkup required, or set to the empty string ("") to not to track the condition
wikidata_kml = "[[Category:Articles using KML from Wikidata]]", -- tracks mainspace articles using KML from Wikidata
local_kml = "[[Category:Articles using KML not from Wikidata]]", -- tracks mainspace articles not using KML from Wikidata
},
}
-- Masks for external mapping providers, in the form:
-- externalLinkMasks[index-number] = { short = "short-label", long = "long-label", link = "url" }'
-- Links in the output will be ordered by index-number
-- Instead of kml file's raw url or encoded raw url, use __KML_URL__ or __KML_URL_E__
local externalLinks = {}
externalLinks[1] = {
short = "Bing",
long = "Display on Bing Maps",
link = "http://www.bing.com/maps/?mapurl=__KML_URL__"
}
externalLinks[2] = {
short = "Google",
long = "Display on Google Maps",
link = "https://tools.wmflabs.org/wp-world/googlmaps-proxy.php?page=__KML_URL_E__&output=classic"
}
-- #### End of L10n settings ####
-- Table of available wikis, in the order that they are to be searched for kml files
-- (once a kml file is found, further sites are not checked)
local sites = {}
sites[1] = { mw.log( string.match( mw.site.server, "%w." ) .. string.gsub(string.lower(mw.site.siteName), "[mp]edia", "") ), string.sub(mw.site.server, 3), "" } -- local wiki (listed first so local files can override files on other wikis)
sites[2] = { "commonswiki", "commons.wikimedia.org", "c:" } -- Commons would be a logical central repository for KML files (but has no files as of August 2016)
sites[3] = { "enwiki", "en.wikipedia.org", "w:en:" } -- largest source of KML files (as of August 2016)
sites[4] = { "bnwiki", "bn.wikipedia.org", "w:bn:" } -- other sites with a KML template, listed in alphabetical order
sites[5] = { "cswiki", "cs.wikipedia.org", "w:cs:" }
sites[6] = { "fawiki", "fa.wikipedia.org", "w:fa:" }
sites[7] = { "frwiki", "fr.wikipedia.org", "w:fr:" }
sites[8] = { "jawiki", "ja.wikipedia.org", "w:ja:" }
sites[9] = { "mlwiki", "ml.wikipedia.org", "w:ml:" }
sites[10] = { "svwiki", "sv.wikipedia.org", "w:sr:" }
sites[11] = { "zhwiki", "zh.wikipedia.org", "w:zh:" }
local p = {}
function p.main(frame)
local parent = frame.getParent(frame)
local qid = parent.args[L10n.para.wikidata] or nil
-- get KML file url
local wikiUrl, wikiLink, trackingWikitext
if not (parent.args[L10n.para.from]) then
if not qid then
wikiUrl, wikiLink, siteindex = getUrlFromWikidata()
elseif string.find( qid, "^Q%d+" ) then
wikiUrl, wikiLink, siteindex = getUrlFromQid(qid)
else
-- TODO: report error
end
end
if not (wikiUrl) then
wikiLink = parent.args[L10n.para.from] or tostring(mw.title.getCurrentTitle())
wikiUrl = mw.title.new( L10n.str.kml_prefix .. wikiLink ):fullUrl("action=raw","https")
siteindex = 1
trackingWikitext = string.format( "<div title=\"KML & Wikidata\" style=\"display:none;\">KML is not from Wikidata</div>{{#ifeq:{{NAMESPACE}}|{{ns:0}}|%s}}", L10n.str.cat.local_kml )
else
trackingWikitext = string.format( "<div title=\"KML & Wikidata\" style=\"display:none;\">KML is from Wikidata</div>{{#ifeq:{{NAMESPACE}}|{{ns:0}}|%s}}", L10n.str.cat.wikidata_kml )
end
-- replace __KML_URL__ or __KML_URL_E__ with actual values
local encodedWikiUrl = mw.uri.encode(wikiUrl, "PATH")
for i, v in ipairs( externalLinks ) do
local el1 = safeReplace( v.link, "__KML_URL__", wikiUrl )
local el2 = safeReplace( el1, "__KML_URL_E__", encodedWikiUrl )
externalLinks[i]["link"] = el2
end
local wikitext = ""
if parent.args[L10n.para.display] then
local display = mw.text.split(parent.args[L10n.para.display], L10n.str.dsep)
if display[1] == L10n.str.title or display[2] == L10n.str.title then
wikitext = makeTitleWikitext(parent.args[L10n.para.title] or L10n.str.default_title)
end
if display[1] == "inline" or display[2] == "inline" then
local inlineWikitext = makeInlineWikitext(parent.args[L10n.para.header] or L10n.str.default_header, wikiUrl)
wikitext = wikitext .. inlineWikitext
end
else
wikitext = makeInlineWikitext(parent.args[L10n.para.header] or L10n.str.default_header, wikiUrl)
end
wikitext = wikitext .. makeKmldataDiv(wikiLink, siteindex) .. trackingWikitext
return frame:preprocess( wikitext )
end
function safeReplace(string, pattern, replacement)
-- avoids "Lua error: invalid capture index" that occurs with string.gsub when the replacement contains one or more literal % character
local nonpattern_parts = mw.text.split( string, pattern )
return table.concat(nonpattern_parts, replacement)
end
function makeTitleWikitext(titletext)
local titleLinks = {}
for i, v in ipairs( externalLinks ) do
titleLinks[i] = string.format( "[%s %s]", v.link , v.short)
end
return string.format( "<span style=\"font-size: small;\"><span id=\"coordinates\">\'\'\'%s\'\'\': %s</span></span>", titletext, table.concat(titleLinks, " / ") )
end
function makeInlineWikitext(headertext, url)
local inlineLinks = {}
for i, v in ipairs( externalLinks ) do
inlineLinks[i] = string.format( "[%s %s]", v.link , v.long)
end
local editUrl = string.gsub( url, "action=raw", "action=edit" )
local wiki_link_class
if string.find( editUrl, mw.site.server, 1, true ) then
wiki_link_class = "plainlinks"
else
wiki_link_class = ""
end
return string.format( "<table class=\"metadata mbox-small\" style=\"border:1px solid #aaa;background-color:#f9f9f9;font-size: 88%%; line-height: 1.5em\"><tr><td style=\"width:1px\"></td><td class=\"mbox-text plainlist\">%s<span class=\"%s\">\'\'\'[%s KML file]\'\'\' ([%s edit] • [[Help:Attached KML|help]])</span>\n<ul><li>%s</li></ul></td></tr></table>", headertext, wiki_link_class, url, editUrl, table.concat(inlineLinks, "</li><li>") )
end
function makeKmldataDiv(link, s_index)
return string.format( "<div class=\"kmldata\" data-server=\"%s\" title=\"%s\" style=\"display:none;\">[[%s%s]]</div>", sites[s_index][2], link, sites[s_index][3], link )
end
function getUrlFromWikidata() -- Attempts to get url from linked wikidata items, will return nil if it can't
local entity = mw.wikibase.getEntityObject()
if not entity then return nil end
local kml_claim = entity:getBestStatements("P3096") -- P3096 is property "KML file"
if kml_claim then
-- get the QID of the first value of the property
if (kml_claim[1] and kml_claim[1].mainsnak.snaktype == "value" and kml_claim[1].mainsnak.datavalue.type == "wikibase-entityid") then
local kml_qid = "Q" .. kml_claim[1].mainsnak.datavalue.value["numeric-id"]
return getUrlFromQid( kml_qid )
else
return nil
end
else
return nil
end
end
function getUrlFromQid( kml_qid )
local kml_entity = mw.wikibase.getEntity( kml_qid )
if not kml_entity then return nil end
local kml_sitelink
local kml_siteindex
local kml_url
for i, v in ipairs( sites ) do
kml_sitelink = kml_entity:getSitelink( v[1] )
if kml_sitelink then
kml_url = "https://" .. v[2] .. "/w/index.php?title=" .. mw.uri.encode( kml_sitelink, "WIKI" ) .. "&action=raw"
kml_siteindex = i
end
if kml_url then break end
end
return kml_url or nil, kml_sitelink or nil, kml_siteindex or nil
end
return p