Module:About
Jump to navigation
Jump to search
local mArguments --initialize lazily
local mHatnote = require('Module:Hatnote')
local mHatList = require('Module:Hatnote list')
local libraryUtil = require('libraryUtil')
local checkType = libraryUtil.checkType
local p = {}
-- ↓ Convert to Cyrillic if needed
local isv_cyrl = require('Module:Alphabet')._global_cyrl
function p.about (frame)
-- A passthrough that gets args from the frame and all
mArguments = require('Module:Arguments')
args = mArguments.getArgs(frame)
return p._about(args)
end
-- ↓ Translate to Interslavic
function p._about (args, options)
-- Produces "about" hatnote.
local currentTitle = mw.title.getCurrentTitle().text
-- Type checks and defaults
checkType('_about', 1, args, 'table', true)
args = args or {}
checkType('_about', 2, options, 'table', true)
options = options or {}
local defaultOptions = {
aboutForm = string.format('%%s %s %%s. ', isv_cyrl('jest o')),
-- ↓ Simplified the check for namespace
PageType = mHatnote.findNamespaceId(currentTitle) == 0 and 'Tutoj članok' or 'Tuta stranica',
otherText = nil, --included for complete list
sectionString = 'Tutoj razděl'
}
for k, v in pairs(defaultOptions) do
if options[k] == nil then options[k] = v end
end
-- Set initial "about" string
local pageType = (args.section and options.sectionString) or options.PageType
local about = ''
if args[1] then
about = string.format(options.aboutForm, isv_cyrl(pageType), args[1])
end
--Allow passing through certain options
local fsOptions = {
otherText = options.otherText,
extratext = args.text
}
local hnOptions = {
selfref = args.selfref
}
-- Set for-see list
local forSee = mHatList._forSee(args, 2, fsOptions)
-- Concatenate and return
return mHatnote._hatnote(about .. forSee, hnOptions)
end
return p