Module:TNT: Difference between revisions
Jump to navigation
Jump to search
imported>Pppery (Module has been nominated for deletion) |
imported>Yurik (resetting to the main mediawiki.org version, allows auto-syncing) |
||
Line 1: | Line 1: | ||
-- | |||
-- INTRO: (!!! DO NOT RENAME THIS PAGE !!!) | |||
-- This module allows any template or module to be copy/pasted between | |||
-- wikis without any translation changes. All translation text is stored | |||
-- in the global Data:*.tab pages on Commons, and used everywhere. | |||
-- | |||
-- SEE: https://www.mediawiki.org/wiki/Multilingual_Templates_and_Modules | |||
-- | -- | ||
-- ATTENTION: | -- ATTENTION: | ||
Line 5: | Line 12: | ||
-- Please do not modify it anywhere else, as it may get copied and override your changes. | -- Please do not modify it anywhere else, as it may get copied and override your changes. | ||
-- Suggestions can be made at https://www.mediawiki.org/wiki/Module_talk:TNT | -- Suggestions can be made at https://www.mediawiki.org/wiki/Module_talk:TNT | ||
-- | -- | ||
-- DESCRIPTION: | -- DESCRIPTION: | ||
-- The "msg" function uses a Commons dataset to translate a message | -- The "msg" function uses a Commons dataset to translate a message | ||
-- with a given key (e.g. source-table), plus optional arguments | -- with a given key (e.g. source-table), plus optional arguments | ||
-- to the wiki markup in the current content language. | -- to the wiki markup in the current content language. | ||
-- Use lang=xx to set language. | -- Use lang=xx to set language. Example: | ||
-- | -- | ||
-- | -- {{#invoke:TNT | msg | ||
- | -- | I18n/Template:Graphs.tab <!-- https://commons.wikimedia.org/wiki/Data:I18n/Template:Graphs.tab --> | ||
-- | source-table <!-- uses a translation message with id = "source-table" --> | |||
-- | param1 }} <!-- optional parameter --> | |||
-- | -- | ||
-- | |||
-- The "doc" function will generate the <templatedata> parameter documentation for templates. | -- The "doc" function will generate the <templatedata> parameter documentation for templates. | ||
-- This way all template parameters can be stored and localized in a single Commons dataset. | -- This way all template parameters can be stored and localized in a single Commons dataset. | ||
-- NOTE: "doc" assumes that all documentation is located in Data:Templatedata/* on Commons. | -- NOTE: "doc" assumes that all documentation is located in Data:Templatedata/* on Commons. | ||
-- | -- | ||
-- | -- {{#invoke:TNT | doc | Graph:Lines }} | ||
-- | -- uses https://commons.wikimedia.org/wiki/Data:Templatedata/Graph:Lines.tab | ||
-- | -- if the current page is Template:Graph:Lines/doc | ||
-- | -- | ||
Line 35: | Line 43: | ||
for k, v in pairs(frame.args) do | for k, v in pairs(frame.args) do | ||
if k == 1 then | if k == 1 then | ||
dataset = v | dataset = mw.text.trim(v) | ||
elseif k == 2 then | elseif k == 2 then | ||
id = v | id = mw.text.trim(v) | ||
elseif type(k) == 'number' then | elseif type(k) == 'number' then | ||
table.insert(params, v) | table.insert(params, v) | ||
elseif k == 'lang' and v ~= '_' then | elseif k == 'lang' and v ~= '_' then | ||
lang = v | lang = mw.text.trim(v) | ||
end | end | ||
end | end | ||
Line 55: | Line 63: | ||
-- Given a dataset name, convert it to a title with the 'commons:data:' prefix | -- Given a dataset name, convert it to a title with the 'commons:data:' prefix | ||
function link(dataset) | function link(dataset) | ||
dataset = 'Data:' .. (dataset or '') | dataset = 'Data:' .. mw.text.trim(dataset or '') | ||
if mw.site.siteName == 'Wikimedia Commons' then | if mw.site.siteName == 'Wikimedia Commons' then | ||
return dataset | return dataset |
Revision as of 03:00, 12 April 2019
Documentation for this module may be created at Module:TNT/doc
-- -- INTRO: (!!! DO NOT RENAME THIS PAGE !!!) -- This module allows any template or module to be copy/pasted between -- wikis without any translation changes. All translation text is stored -- in the global Data:*.tab pages on Commons, and used everywhere. -- -- SEE: https://www.mediawiki.org/wiki/Multilingual_Templates_and_Modules -- -- ATTENTION: -- Please do NOT rename this module - it has to be identical on all wikis. -- This code is maintained at https://www.mediawiki.org/wiki/Module:TNT -- Please do not modify it anywhere else, as it may get copied and override your changes. -- Suggestions can be made at https://www.mediawiki.org/wiki/Module_talk:TNT -- -- DESCRIPTION: -- The "msg" function uses a Commons dataset to translate a message -- with a given key (e.g. source-table), plus optional arguments -- to the wiki markup in the current content language. -- Use lang=xx to set language. Example: -- -- {{#invoke:TNT | msg -- | I18n/Template:Graphs.tab <!-- https://commons.wikimedia.org/wiki/Data:I18n/Template:Graphs.tab --> -- | source-table <!-- uses a translation message with id = "source-table" --> -- | param1 }} <!-- optional parameter --> -- -- -- The "doc" function will generate the <templatedata> parameter documentation for templates. -- This way all template parameters can be stored and localized in a single Commons dataset. -- NOTE: "doc" assumes that all documentation is located in Data:Templatedata/* on Commons. -- -- {{#invoke:TNT | doc | Graph:Lines }} -- uses https://commons.wikimedia.org/wiki/Data:Templatedata/Graph:Lines.tab -- if the current page is Template:Graph:Lines/doc -- local p = {} local i18nDataset = 'I18n/Module:TNT.tab' function p.msg(frame) local dataset, id local params = {} local lang = nil for k, v in pairs(frame.args) do if k == 1 then dataset = mw.text.trim(v) elseif k == 2 then id = mw.text.trim(v) elseif type(k) == 'number' then table.insert(params, v) elseif k == 'lang' and v ~= '_' then lang = mw.text.trim(v) end end return formatMessage(dataset, id, params, lang) end -- Converts first parameter to a interwiki-ready link. For example, it converts -- "Sandbox/Sample.tab" -> 'commons:Data:Sandbox/Sample.tab' function p.link(frame) return link(frame.args[1]) end -- Given a dataset name, convert it to a title with the 'commons:data:' prefix function link(dataset) dataset = 'Data:' .. mw.text.trim(dataset or '') if mw.site.siteName == 'Wikimedia Commons' then return dataset else return 'commons:' .. dataset end end function p.doc(frame) dataset = 'Templatedata/' .. normalizeDataset(frame.args[1]) -- TODO: add '_' parameter once lua starts reindexing properly for "all" languages local data = loadData(dataset) local names = {} for _, field in pairs(data.schema.fields) do table.insert(names, field.name) end local params = {} local paramOrder = {} for _, row in pairs(data.data) do local newVal = {} local name = nil for pos, val in pairs(row) do local columnName = names[pos] if columnName == 'name' then name = val else newVal[columnName] = val end end if name then params[name] = newVal table.insert(paramOrder, name) end end local templateData = { params=params, paramOrder=paramOrder, description=data.description } templateData = mw.text.jsonEncode(templateData) return frame:extensionTag('templatedata', templateData) .. tntMessage('edit_doc', {link(dataset)}) end function formatMessage(dataset, key, params, lang) for _, row in pairs(loadData(dataset, lang).data) do local id, msg = unpack(row) if id == key then local result = mw.message.newRawMessage(msg, unpack(params)) return result:plain() end end if dataset == i18nDataset then -- Prevent cyclical calls error('Invalid message key "' .. key .. '"') else error(tntMessage('error_bad_msgkey', {key, link(dataset)})) end end function tntMessage(key, params) return formatMessage(i18nDataset, key, params) end function normalizeDataset(dataset) if not dataset or dataset == '' then error(tntMessage('error_no_dataset', {})) end if string.sub(dataset,-4) ~= '.tab' then dataset = dataset .. '.tab' end return dataset end function loadData(dataset, lang) local data = mw.ext.data.get(dataset, lang) if data == false then if dataset == i18nDataset then -- Prevent cyclical calls error('Missing Commons dataset ' .. i18nDataset) else error(tntMessage('error_bad_dataset', {link(dataset)})) end end return data end return p