Module:Wd/i18n: Difference between revisions

From wiki
Jump to navigation Jump to search
1>Xiplus
(per EP)
 
m (1 revision imported)
 
(One intermediate revision by one other user not shown)
Line 5: Line 5:
function p.init(aliasesP)
function p.init(aliasesP)
p = {
p = {
["version"] = "7",  -- increment this each time the below parameters are changed to avoid reference conflict errors
["errors"] = {
["errors"] = {
["unknown-data-type"]          = "未知或不支持的数据类型“$1”。",
["unknown-data-type"]          = "Unknown or unsupported datatype '%s'.",
["missing-required-parameter"] = "未定义必填参数,至少需要一个",
["missing-required-parameter"] = "No required parameters defined, needing at least one",
["extra-required-parameter"]  = "参数“$1”必须定义为可选参数",
["extra-required-parameter"]  = "Parameter '%s' must be defined as optional",
["no-function-specified"]      = "你必须指定要调用的函数",  -- equal to the standard module error message
["no-function-specified"]      = "You must specify a function to call",  -- equal to the standard module error message
["main-called-twice"]          = '函数“main”不能调用两次',
["main-called-twice"]          = 'The function "main" cannot be called twice',
["no-such-function"]          = '函数“$1”不存在'  -- equal to the standard module error message
["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"] = {
["info"] = {
["edit-on-wikidata"] = "在维基数据编辑"
["edit-on-wikidata"] = "Edit this on Wikidata"
},
},
["numeric"] = {
["numeric"] = {
Line 25: Line 33:
},
},
["suffixes"] = {
["suffixes"] = {
["decade-period"] = "年代",
["decade-period"] = "s",
["millennium"]    = "千年",
["millennium"]    = " millennium",
["century"]      = "世纪",
["century"]      = " century",
["million-years"] = "百万年",
["million-years"] = " million years",
["billion-years"] = "十亿年",
["billion-years"] = " billion years",
["year"]          = "",
["year"]          = " year",
["years"]        = ""
["years"]        = " years"
},
},
["julian-calendar"] = "儒略历",  -- linked page title
["julian-calendar"] = "Julian calendar",  -- linked page title
["julian"]          = "儒略历",
["julian"]          = "Julian",
["BCE"]            = "BCE",
["BCE"]            = "BCE",
["CE"]              = "CE",
["CE"]              = "CE",
["common-era"]      = "公元"  -- linked page title
["common-era"]      = "Common Era"  -- linked page title
},
},
["coord"] = {
["coord"] = {
Line 50: Line 58:
},
},
["values"] = {
["values"] = {
["unknown"] = "未知",
["unknown"] = "unknown",
["none"]    = ""
["none"]    = "none"
},
},
["cite"] = {
["cite"] = {
["version"] = "2",  -- increase this each time the below parameters are changed to avoid conflict errors
["output-types"] = {"web", "q"},  -- In this order, the output types will be tried
["web"] = {
["param-mapping"] = {
-- <= left side: all allowed reference properties for *web page sources* per https://www.wikidata.org/wiki/Help:Sources
["web"] = {
-- => right side: corresponding parameter names in (equivalent of) [[:en:Template:Cite web]] (if non-existent, keep empty i.e. "")
-- <= left side: all allowed reference properties for *web page sources* per https://www.wikidata.org/wiki/Help:Sources
[aliasesP.statedIn]       = "website",
-- => right side: corresponding parameter names in (equivalent of) [[:en:Template:Cite web]] (if non-existent, keep empty i.e. "")
[aliasesP.referenceURL]   = "url",
[aliasesP.statedIn]               = "website",
[aliasesP.publicationDate] = "date",
[aliasesP.referenceURL]           = "url",
[aliasesP.retrieved]       = "access-date",
[aliasesP.publicationDate]         = "date",
[aliasesP.title]           = "title",
[aliasesP.retrieved]               = "access-date",
[aliasesP.archiveURL]     = "archive-url",
[aliasesP.title]                   = "title",
[aliasesP.archiveDate]     = "archive-date",
[aliasesP.archiveURL]             = "archive-url",
[aliasesP.language]       = "language",
[aliasesP.archiveDate]             = "archive-date",
[aliasesP.author]         = "author", -- existence of author1, author2, author3, etc. is assumed
[aliasesP.language]               = "language",
[aliasesP.publisher]       = "publisher",
[aliasesP.author]                 = "author",
[aliasesP.quote]           = "quote",
[aliasesP.authorNameString]        = "author",
[aliasesP.pages]           = "pages"  -- extra option
[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"
}
},
},
["q"] = {
["config"] = {
-- <= left side: all allowed reference properties for *sources other than web pages* per https://www.wikidata.org/wiki/Help:Sources
-- supported fields:
-- => right side: corresponding parameter names in (equivalent of) [[:en:Template:Cite Q]] (if non-existent, keep empty i.e. "")
--    - template: name of the template used for output
[aliasesP.statedIn]               = "1",
--    - numbered-params: citation params accepting an arbitrary number of values by numbering the params (e.g. author1, author2)
[aliasesP.pages]                   = "pages",
--    - raw-value-params: params taking a raw value (which means the property is rendered with getValue with raw=true)
[aliasesP.column]                 = "at",
--     - mandatory-params: params that are required be in the template call (after potentially appending numbers to params listed in numbered-params)
[aliasesP.chapter]                 = "chapter",
-- Leaving out the "template" field causes the output type to be ignored.
[aliasesP.sectionVerseOrParagraph] = "section",
["web"] = {
["external-id"]                   = "id",  -- used for any type of database property ID
["template"] = "Cite web",
[aliasesP.title]                  = "title",
["numbered-params"] = {"author"},
[aliasesP.publicationDate]         = "date",
["mandatory-params"] = {"url"}
[aliasesP.retrieved]              = "access-date"
},
["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)
p.getOrdinalSuffix = function(num)
if tostring(num):sub(-2,-2) == '1' then
if tostring(num):sub(-2,-2) == '1' then
return "th"  -- 10th, 11th, 12th, 13th, ... 19th
return "th"  -- 10th, 11th, 12th, 13th, ... 19th
end
end
 
num = tostring(num):sub(-1)
num = tostring(num):sub(-1)
 
if num == '1' then
if num == '1' then
return "st"
return "st"
Line 106: Line 138:
p.addDelimiters = function(n)
p.addDelimiters = function(n)
local left, num, right = string.match(n, "^([^%d]*%d)(%d*)(.-)$")
local left, num, right = string.match(n, "^([^%d]*%d)(%d*)(.-)$")
 
if left and num and right then
if left and num and right then
return left .. (num:reverse():gsub("(%d%d%d)", "%1" .. p['numeric']['delimiter']):reverse()) .. right
return left .. (num:reverse():gsub("(%d%d%d)", "%1" .. p['numeric']['delimiter']):reverse()) .. right
Line 113: Line 145:
end
end
end
end
 
return p
return p
end
end


return p
return p

Latest revision as of 12:17, 23 April 2025

-- 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"] = "\nError: Unable to display the reference from Wikidata properly. Technical details:\n",
           ["malformed-reference-footer"] = "See the documentation for further details.\n\n",
           ["template-failure-reason"]    = "* Reason for the failure of Template:Tl: %s\n",
           ["missing-mandatory-param"]    = 'The output template call would miss the mandatory parameter %s.',
           ["unknown-property-in-ref"]    = 'The Wikidata reference contains the property Template:Property, 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