Module:Wd/i18n and Module:Wd/i18n/sandbox: Difference between pages
Appearance
(Difference between pages)
Content deleted Content added
Undid revision 1249540561 by Janhrach (talk) |
This is the sandbox actually being used. Tag: New redirect |
||
Line 1: | Line 1: | ||
#REDIRECT [[Module:Wd/sandbox/i18n]] |
|||
-- The values and functions in this submodule should be localized per wiki. |
|||
local p = {} |
|||
function p.init(aliasesP) |
|||
p = { |
|||
["version"] = "7", -- increment this each time the below parameters are changed to avoid reference conflict errors |
|||
["errors"] = { |
|||
["unknown-data-type"] = "Unknown or unsupported datatype '%s'.", |
|||
["missing-required-parameter"] = "No required parameters defined, needing at least one", |
|||
["extra-required-parameter"] = "Parameter '%s' must be defined as optional", |
|||
["no-function-specified"] = "You must specify a function to call", -- equal to the standard module error message |
|||
["main-called-twice"] = 'The function "main" cannot be called twice', |
|||
["no-such-function"] = 'The function "%s" does not exist', -- equal to the standard module error message |
|||
["no-such-reference-template"] = 'Error: template "%s", which is set in %s as the output template for the citation-output type "%s", does not exist', |
|||
-- Parts of the error message signalling a malformed reference. |
|||
["malformed-reference-header"] = "<span style=\"color:#dd3333\">\nError: Unable to display the reference from Wikidata properly. Technical details:\n", |
|||
["malformed-reference-footer"] = "See [[Module:wd/doc#References|the documentation]] for further details.\n</span>\n[[Category:Module:Wd reference errors]]", |
|||
["template-failure-reason"] = "* Reason for the failure of {{tl|%s}}: %s\n", |
|||
["missing-mandatory-param"] = 'The output template call would miss the mandatory parameter <code>%s</code>.', |
|||
["unknown-property-in-ref"] = 'The Wikidata reference contains the property {{property|%s}}, which is not assigned to any parameter of this template.' |
|||
}, |
|||
["info"] = { |
|||
["edit-on-wikidata"] = "Edit this on Wikidata" |
|||
}, |
|||
["numeric"] = { |
|||
["decimal-mark"] = ".", |
|||
["delimiter"] = "," |
|||
}, |
|||
["datetime"] = { |
|||
["prefixes"] = { |
|||
["decade-period"] = "" |
|||
}, |
|||
["suffixes"] = { |
|||
["decade-period"] = "s", |
|||
["millennium"] = " millennium", |
|||
["century"] = " century", |
|||
["million-years"] = " million years", |
|||
["billion-years"] = " billion years", |
|||
["year"] = " year", |
|||
["years"] = " years" |
|||
}, |
|||
["julian-calendar"] = "Julian calendar", -- linked page title |
|||
["julian"] = "Julian", |
|||
["BCE"] = "BCE", |
|||
["CE"] = "CE", |
|||
["common-era"] = "Common Era" -- linked page title |
|||
}, |
|||
["coord"] = { |
|||
["latitude-north"] = "N", |
|||
["latitude-south"] = "S", |
|||
["longitude-east"] = "E", |
|||
["longitude-west"] = "W", |
|||
["degrees"] = "°", |
|||
["minutes"] = "'", |
|||
["seconds"] = '"', |
|||
["separator"] = ", " |
|||
}, |
|||
["values"] = { |
|||
["unknown"] = "unknown", |
|||
["none"] = "none" |
|||
}, |
|||
["cite"] = { |
|||
["output-types"] = {"web", "q"}, -- In this order, the output types will be tried |
|||
["param-mapping"] = { |
|||
["web"] = { |
|||
-- <= left side: all allowed reference properties for *web page sources* per https://www.wikidata.org/wiki/Help:Sources |
|||
-- => right side: corresponding parameter names in (equivalent of) [[:en:Template:Cite web]] (if non-existent, keep empty i.e. "") |
|||
[aliasesP.statedIn] = "website", |
|||
[aliasesP.referenceURL] = "url", |
|||
[aliasesP.publicationDate] = "date", |
|||
[aliasesP.retrieved] = "access-date", |
|||
[aliasesP.title] = "title", |
|||
[aliasesP.archiveURL] = "archive-url", |
|||
[aliasesP.archiveDate] = "archive-date", |
|||
[aliasesP.language] = "language", |
|||
[aliasesP.author] = "author", |
|||
[aliasesP.authorNameString] = "author", |
|||
[aliasesP.publisher] = "publisher", |
|||
[aliasesP.quote] = "quote", |
|||
[aliasesP.pages] = "pages", -- extra option |
|||
[aliasesP.publishedIn] = "website", |
|||
[aliasesP.sectionVerseOrParagraph] = "at" |
|||
}, |
|||
["q"] = { |
|||
-- <= left side: all allowed reference properties for *sources other than web pages* per https://www.wikidata.org/wiki/Help:Sources |
|||
-- => right side: corresponding parameter names in (equivalent of) [[:en:Template:Cite Q]] (if non-existent, keep empty i.e. "") |
|||
[aliasesP.statedIn] = "1", |
|||
[aliasesP.pages] = "pages", |
|||
[aliasesP.column] = "at", |
|||
[aliasesP.chapter] = "chapter", |
|||
[aliasesP.sectionVerseOrParagraph] = "section", |
|||
["external-id"] = "id", -- used for any type of database property ID |
|||
[aliasesP.title] = "title", |
|||
[aliasesP.publicationDate] = "date", |
|||
[aliasesP.retrieved] = "access-date" |
|||
} |
|||
}, |
|||
["config"] = { |
|||
-- supported fields: |
|||
-- - template: name of the template used for output |
|||
-- - numbered-params: citation params accepting an arbitrary number of values by numbering the params (e.g. author1, author2) |
|||
-- - raw-value-params: params taking a raw value (which means the property is rendered with getValue with raw=true) |
|||
-- - mandatory-params: params that are required be in the template call (after potentially appending numbers to params listed in numbered-params) |
|||
-- Leaving out the "template" field causes the output type to be ignored. |
|||
["web"] = { |
|||
["template"] = "Cite web", |
|||
["numbered-params"] = {"author"}, |
|||
["mandatory-params"] = {"url"} |
|||
}, |
|||
["q"] = { |
|||
["template"] = "Cite Q", |
|||
["raw-value-params"] = {"1"}, -- the first, unnamed parameter of CiteQ takes a QID, not the name of the item cited |
|||
["mandatory-params"] = {"1"} |
|||
} |
|||
} |
|||
} |
|||
} |
|||
p.getOrdinalSuffix = function(num) |
|||
if tostring(num):sub(-2,-2) == '1' then |
|||
return "th" -- 10th, 11th, 12th, 13th, ... 19th |
|||
end |
|||
num = tostring(num):sub(-1) |
|||
if num == '1' then |
|||
return "st" |
|||
elseif num == '2' then |
|||
return "nd" |
|||
elseif num == '3' then |
|||
return "rd" |
|||
else |
|||
return "th" |
|||
end |
|||
end |
|||
p.addDelimiters = function(n) |
|||
local left, num, right = string.match(n, "^([^%d]*%d)(%d*)(.-)$") |
|||
if left and num and right then |
|||
return left .. (num:reverse():gsub("(%d%d%d)", "%1" .. p['numeric']['delimiter']):reverse()) .. right |
|||
else |
|||
return n |
|||
end |
|||
end |
|||
return p |
|||
end |
|||
return p |