Bước tới nội dung

Mô đun:TNT

Bách khoa toàn thư mở Wikipedia
Tài liệu mô đun[xem] [sửa] [lịch sử] [làm mới]

This module allows templates and modules to be easily translated as part of themultilingual templates and modules project.Instead of storing English text in a module or a template, TNT module allows modules to be designed language-neutral, and store multilingual text in thetabular data pageson Commons. This way your module or template will use those translated strings (messages), or if the message has not yet been translated, will fallback to English. When someone updates the translation table, your page will automatically update (might take some time, or you can purge it), but no change in the template or module is needed on any of the wikis. This process is very similar to MediaWiki'slocalisation,and supports all standard localization conventions such as {{PLURAL|...}} andother parameters.

This module can be used from templates using #invoke, and from other modules. For a simple example, seeData:I18n/Template:Graphs.tab- a table with two messages, each message having a single parameter. By convention, all translation tables should have '''Data:I18n/...''' prefix to separate them from other types of data.

Sử dụng từ Bản mẫu[sửa mã nguồn]

Miêu tả Mã Wiki
In a template, this command translatessource_tablemessage using Commons'Data:I18n/Template:Graphs.tabtranslation table.
{{#gọi:TNT | msg
| I18n/Bản mẫu:Graphs.tab
| source_table
}}
If your message contains parameters, you can specify them after the message ID.
{{#gọi:TNT | msg
| I18n/Bản mẫu:My Template.tab
| message-with-two-params
| param1
| param2
}}

Đang dịch tham số bản mẫu[sửa mã nguồn]

Template parameters are usually stored as aJSONtemplatedatablock inside the template's /doc subpage. This makes it convenient to translate, but when a new parameter is added to a global template, all /doc pages need to be updated in every language. TNT helps with this by automatically generating the templatedata block from a table stored on Commons. Placing this line into every /doc sub-page will useData:Templatedata/Graph:Lines.tabtable to generate all the needed templatedata information in every language. Even if the local community has not translated the full template documentation, they will be able to see all template parameters, centrally updated.
{{#gọi:TNT | doc | Graph:Lines }}

Sử dụng từ Mô đun[sửa mã nguồn]

Just like templates, modules should also use this module for localization:

localTNT=require('Mô đun:TNT')

-- format <messageId> string with two parameters using a translation table.
localtext=TNT.format('I18n/My_module_messages','messageId','param1','param2',...)

-- Same, but translate to a specific language.
localtext=TNT.formatInLanguage('fr','I18n/My_module_messages','messageId','param1','param2',...)

Sử dụng TNTTools[sửa mã nguồn]

Mô đun:TNTToolshas:

  • Question functions: with boolean or numerical indexed return. To be called from other modules or from templates. With:
    • Case sensitive option.
    • Possibility of more than one translated text value (where each value is separated by "|" ).
  • To put aside write, adding "I18n/" as a prefix and ".tab" extension as a suffix for the table names.
  • Several examples.

--
-- 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:
--
-- {{#gọi:TNT | msg
-- | I18n/Bản mẫu: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.
--
-- {{#gọi:TNT | doc | Graph:Lines }}
-- uses https://commons.wikimedia.org/wiki/Data:Templatedata/Graph:Lines.tab
-- if the current page is Bản mẫu:Graph:Lines/doc
--

localp={}
locali18nDataset='I18n/Mô đun:TNT.tab'

-- Forward declaration of the local functions
localsanitizeDataset,loadData,link,formatMessage

functionp.msg(frame)
localdataset,id
localparams={}
locallang=nil
fork,vinpairs(frame.args)do
ifk==1then
dataset=mw.text.trim(v)
elseifk==2then
id=mw.text.trim(v)
elseiftype(k)=='number'then
table.insert(params,mw.text.trim(v))
elseifk=='lang'andv~='_'then
lang=mw.text.trim(v)
end
end
returnformatMessage(dataset,id,params,lang)
end

-- Identical to p.msg() above, but used from other lua modules
-- Parameters: name of dataset, message key, optional arguments
-- Example with 2 params: format('I18n/Mô đun:TNT', 'error_bad_msgkey', 'my-key', 'my-dataset')
functionp.format(dataset,key,...)
localcheckType=require('libraryUtil').checkType
checkType('format',1,dataset,'string')
checkType('format',2,key,'string')
returnformatMessage(dataset,key,{...})
end


-- Identical to p.msg() above, but used from other lua modules with the language param
-- Parameters: language code, name of dataset, message key, optional arguments
-- Example with 2 params: formatInLanguage('es', I18n/Mô đun:TNT', 'error_bad_msgkey', 'my-key', 'my-dataset')
functionp.formatInLanguage(lang,dataset,key,...)
localcheckType=require('libraryUtil').checkType
checkType('formatInLanguage',1,lang,'string')
checkType('formatInLanguage',2,dataset,'string')
checkType('formatInLanguage',3,key,'string')
returnformatMessage(dataset,key,{...},lang)
end

-- Obsolete function that adds a 'c:' prefix to the first param.
-- "Sandbox/Sample.tab" -> 'c:Data:Sandbox/Sample.tab'
functionp.link(frame)
returnlink(frame.args[1])
end

functionp.doc(frame)
localdataset='Templatedata/'..sanitizeDataset(frame.args[1])
returnframe:extensionTag('templatedata',p.getTemplateData(dataset))..
formatMessage(i18nDataset,'edit_doc',{link(dataset)})
end

functionp.getTemplateData(dataset)
-- TODO: add '_' parameter once lua starts reindexing properly for "all" languages
localdata=loadData(dataset)
localnames={}
for_,fieldinpairs(data.schema.fields)do
table.insert(names,field.name)
end

localparams={}
localparamOrder={}
for_,rowinpairs(data.data)do
localnewVal={}
localname=nil
forpos,valinpairs(row)do
localcolumnName=names[pos]
ifcolumnName=='name'then
name=val
else
newVal[columnName]=val
end
end
ifnamethen
params[name]=newVal
table.insert(paramOrder,name)
end
end

-- Work around json encoding treating { "1":{...}} as an [{...}]
params['zzz123']=''

localjson=mw.text.jsonEncode({
params=params,
paramOrder=paramOrder,
description=data.description
})

json=string.gsub(json,' "zzz123": "",?',"")

returnjson
end

-- Local functions

sanitizeDataset=function(dataset)
ifnotdatasetthen
returnnil
end
dataset=mw.text.trim(dataset)
ifdataset==''then
returnnil
elseifstring.sub(dataset,-4)~='.tab'then
returndataset..'.tab'
else
returndataset
end
end

loadData=function(dataset,lang)
dataset=sanitizeDataset(dataset)
ifnotdatasetthen
error(formatMessage(i18nDataset,'error_no_dataset',{}))
end

-- Give helpful error to thirdparties who try and copy this module.
ifnotmw.extornotmw.ext.dataornotmw.ext.data.getthen
error('Thiếu phần mở rộng JsonConfig; Không thể tải https://commons.wikimedia.org/wiki/Data:'..dataset)
end

localdata=mw.ext.data.get(dataset,lang)

ifdata==falsethen
ifdataset==i18nDatasetthen
-- Prevent cyclical calls
error('Thiếu tập dữ liệu Commons '..i18nDataset)
else
error(formatMessage(i18nDataset,'error_bad_dataset',{link(dataset)}))
end
end
returndata
end

-- Given a dataset name, convert it to a title with the 'commons:data:' prefix
link=function(dataset)
return'c:Data:'..mw.text.trim(datasetor'')
end

formatMessage=function(dataset,key,params,lang)
for_,rowinpairs(loadData(dataset,lang).data)do
localid,msg=unpack(row)
ifid==keythen
localresult=mw.message.newRawMessage(msg,unpack(paramsor{}))
returnresult:plain()
end
end
ifdataset==i18nDatasetthen
-- Prevent cyclical calls
error('Từ khóa tin nhắn không hợp lệ "'..key..' "')
else
error(formatMessage(i18nDataset,'error_bad_msgkey',{key,link(dataset)}))
end
end

returnp