Изменения
Перейти к навигации
Перейти к поиску
Строка 1:
Строка 1:
+
+
+
− local cfg = mw.loadData('Module:Sidebar/configuration')
− +
+
− --[[
− Categorizes calling templates and modules with a 'style' parameter of any sort
− for tracking to convert to TemplateStyles.
−
− TODO after a long cleanup: Catch sidebars in other namespaces than Template and Module.
− TODO would probably want to remove /log and /archive as CS1 does
− ]]
− local function categorizeTemplatesWithInlineStyles(args)
− local title = mw.title.getCurrentTitle()
− if title.namespace ~= 10 and title.namespace ~= 828 then return '' end
− for _, pattern in ipairs (cfg.i18n.pattern.uncategorized_conversion_titles) do
− if title.text:match(pattern) then return '' end
− end
−
− for key, _ in pairs(args) do
− if mw.ustring.find(key, cfg.i18n.pattern.style_conversion) or key == 'width' then
− return cfg.i18n.category.conversion
− end
− end
− end
−
− --[[
− For compatibility with the original {{sidebar with collapsible lists}}
− implementation, which passed some parameters through {{#if}} to trim their
− whitespace. This also triggered the automatic newline behavior.
− ]]
− -- See ([[meta:Help:Newlines and spaces#Automatic newline]])
+
+
+
+
Строка 42:
Строка 22:
− --[[+
− Finds whether a sidebar has a subgroup sidebar.
− ]]
− local function hasSubgroup(s)
− if mw.ustring.find(s, cfg.i18n.pattern.subgroup) then
− return true
− else
− return false
− end
− end
−
− local function has_navbar(navbar_mode, sidebar_name)
− return navbar_mode ~= cfg.i18n.navbar_none and
− navbar_mode ~= cfg.i18n.navbar_off and
− (
− sidebar_name or
− mw.getCurrentFrame():getParent():getTitle():gsub(cfg.i18n.pattern.sandbox, '') ~=
− cfg.i18n.title_not_to_add_navbar
− )
− end
−
− local function has_list_class(args, htmlclass)
− local patterns = {
− '^' .. htmlclass .. '$',
− '%s' .. htmlclass .. '$',
− '^' .. htmlclass .. '%s',
− '%s' .. htmlclass .. '%s'
− }
−
− for arg, value in pairs(args) do
− if type(arg) == 'string' and mw.ustring.find(arg, 'class') then
− for _, pattern in ipairs(patterns) do
− if mw.ustring.find(args[arg] or '', pattern) then
− return true
− end
− end
− end
− end
− return false
− end
−
− -- there are a lot of list classes in the wild, so we add their TemplateStyles
− local function add_list_styles(args)
− local frame = mw.getCurrentFrame()
− local function add_list_templatestyles(htmlclass, templatestyles)
− if has_list_class(args, htmlclass) then
− return frame:extensionTag{
− name = 'templatestyles', args = { src = templatestyles }
− }
− else
− return ''
− end
− end
−
− local plainlist_styles = add_list_templatestyles('plainlist', cfg.i18n.plainlist_templatestyles)
− local hlist_styles = add_list_templatestyles('hlist', cfg.i18n.hlist_templatestyles)
−
− -- a second workaround for [[phab:T303378]]
− -- when that issue is fixed, we can actually use has_navbar not to emit the
− -- tag here if we want
− if has_navbar(args.navbar, args.name) and hlist_styles == '' then
− hlist_styles = frame:extensionTag{
− name = 'templatestyles', args = { src = cfg.i18n.hlist_templatestyles}
− }
− end
−
− -- hlist -> plainlist is best-effort to preserve old Common.css ordering. [hlist_note]
− return hlist_styles .. plainlist_styles
− end
−
− -- work around [[phab:T303378]]
− -- for each arg: find all the templatestyles strip markers, insert them into a
− -- table. then remove all templatestyles markers from the arg
− local function move_hiding_templatestyles(args)
− local gfind = string.gfind
− local gsub = string.gsub
− local templatestyles_markers = {}
− local strip_marker_pattern = '(\127[^\127]*UNIQ%-%-templatestyles%-%x+%-QINU[^\127]*\127)'
− for k, arg in pairs(args) do
− for marker in gfind(arg, strip_marker_pattern) do
− table.insert(templatestyles_markers, marker)
− end
− args[k] = gsub(arg, strip_marker_pattern, '')
− end
− return templatestyles_markers
− end
−
− --[[
− Main sidebar function. Takes the frame, args, and an optional collapsibleClass.
− The collapsibleClass is and should be used only for sidebars with collapsible
− lists, as in p.collapsible.
− ]]
−
− local hiding_templatestyles = table.concat(move_hiding_templatestyles(args))
− +
− root = root:tag('table')
− +
− :addClass(cfg.i18n.class.sidebar)+
− -- force collapsibleclass to be sidebar-collapse otherwise output nothing+
− :addClass(collapsibleClass == cfg.i18n.class.collapse and cfg.i18n.class.collapse or nil)+
−
−
− :addClass(args.float == cfg.i18n.float_left and cfg.i18n.class.float_left or nil)
−
− +
+
+
+
+
+
+
+
+
+
+
Строка 159:
Строка 51:
− :addClass(cfg.i18n.class.outer_title)
+
+
+
+
Строка 169:
Строка 64:
− :addClass(cfg.i18n.class.top_image)
+
Строка 177:
Строка 72:
− +
+
Строка 187:
Строка 83:
− :addClass(args.topimage and cfg.i18n.class.pretitle_with_top_image
− or cfg.i18n.class.pretitle)
+
+
− else+
− root
− :addClass(cfg.i18n.class.subgroup)
− :addClass(args.bodyclass or args.class)
− :cssText(args.bodystyle or args.style)
Строка 205:
Строка 97:
+
− :addClass(args.pretitle and cfg.i18n.class.title_with_pretitle
− or cfg.i18n.class.title)
+
+
+
+
Строка 222:
Строка 117:
− :addClass(cfg.i18n.class.image)
+
Строка 230:
Строка 125:
− +
+
Строка 240:
Строка 136:
− :addClass(cfg.i18n.class.above)
+
+
Строка 254:
Строка 151:
− +
− -- and content3 are specified)
Строка 268:
Строка 164:
− :addClass(cfg.i18n.class.heading)
− +
Строка 283:
Строка 178:
− :addClass(hasSubgroup(content) and cfg.i18n.class.content_with_subgroup
− or cfg.i18n.class.content)
− +
Строка 292:
Строка 185:
− -- Without a linebreak after the </td>, a nested list like+
− -- "* {{hlist| ...}}" doesn't parse correctly.
− :newline()
Строка 302:
Строка 193:
− :addClass(cfg.i18n.class.below)
+
+
Строка 309:
Строка 201:
− +
− root+
− :tag('tr')+
− :tag('td')+
− :addClass(cfg.i18n.class.navbar)+
− :cssText(args.navbarstyle)+
− :wikitext(require('Module:Navbar')._navbar{+
− args.name,+
− mini = 1,+
− fontstyle = args.navbarfontstyle+
− })+
− end+
− +
− local base_templatestyles = frame:extensionTag{+
− name = 'templatestyles', args = { src = cfg.i18n.templatestyles }+
− }
−
− local templatestyles = ''
− if args['templatestyles'] and args['templatestyles'] ~= '' then
− templatestyles = frame:extensionTag{
− name = 'templatestyles', args = { src = args['templatestyles'] }
− }
− end
−
− local child_templatestyles = ''
− if args['child templatestyles'] and args['child templatestyles'] ~= '' then
− child_templatestyles = frame:extensionTag{
− name = 'templatestyles', args = { src = args['child templatestyles'] }
− }
− end
−
− local grandchild_templatestyles = ''
− if args['grandchild templatestyles'] and args['grandchild templatestyles'] ~= '' then
− grandchild_templatestyles = frame:extensionTag{
− name = 'templatestyles', args = { src = args['grandchild templatestyles'] }
− }
− +
− add_list_styles(args), -- see [hlist_note] above about ordering
− base_templatestyles,
− templatestyles,
− child_templatestyles,
− grandchild_templatestyles,
− hiding_templatestyles,
− tostring(root),
− (child and cfg.i18n.category.child or ''),
− categorizeTemplatesWithInlineStyles(args)
− })
− local function list_title(args, is_centered_list_titles, num)
−
− local title_text = trimAndAddAutomaticNewline(args['list' .. num .. 'title']
− or cfg.i18n.default_list_title)
−
− local title
− if is_centered_list_titles then
− -- collapsible can be finicky, so provide some CSS/HTML to support
− title = mw.html.create('div')
− :addClass(cfg.i18n.class.list_title_centered)
− :wikitext(title_text)
− else
− title = mw.html.create()
− :wikitext(title_text)
− end
−
− local title_container = mw.html.create('div')
− :addClass(cfg.i18n.class.list_title)
− -- don't /need/ a listnumtitleclass because you can do
− -- .templateclass .listnumclass .sidebar-list-title
− :addClass(args.listtitleclass)
− :cssText(args.basestyle)
− :cssText(args.listtitlestyle)
− :cssText(args['list' .. num .. 'titlestyle'])
− :node(title)
− :done()
−
− return title_container
− end
−
− --[[
− Main entry point for sidebar with collapsible lists.
− Does the work of creating the collapsible lists themselves and including them
− into the args.
− ]]
− +
− frame:getParent():getTitle():gsub(cfg.i18n.pattern.collapse_sandbox, '') ==+
− cfg.i18n.collapse_title_not_to_add_navbar then+
− +
+
+
−
− local is_centered_list_titles = false
− if args['centered list titles'] and args['centered list titles'] ~= '' then
− is_centered_list_titles = true
− end
− +
− (args.expanded == 'all' or args.expanded == args['list' .. num .. 'name'])+
− :addClass(cfg.i18n.class.list)+
− +
− +
− +
− :node(list_title(args, is_centered_list_titles, num))
− +
− +
− +
− -- .templatename .listnumclass .sidebar-list +
+
+
+
+
+
+
+
+
+
+
+
+
Строка 442:
Строка 276:
− +
устаревший модуль, см. mw:Extension:Scribunto/Lua_reference_manual#strict
--
-- Этот модуль обеспечивает работу шаблона {{Sidebar}}
--
require('strict')
require('strict')
local p = {}
local p = {}
local getArgs = require('Module:Arguments').getArgs
local getArgs = require('Модуль:Arguments').getArgs
local navbar = require('Модуль:Navbar')._navbar
local function trimAndAddAutomaticNewline(s)
local function trimAndAddAutomaticNewline(s)
-- For compatibility with the original {{sidebar with collapsible lists}}
-- implementation, which passed some parameters through {{#if}} to trim
-- their whitespace. This also triggered the automatic newline behavior.
-- ([[meta:Help:Newlines and spaces#Automatic newline]])
s = mw.ustring.gsub(s, "^%s*(.-)%s*$", "%1")
s = mw.ustring.gsub(s, "^%s*(.-)%s*$", "%1")
if mw.ustring.find(s, '^[#*:;]') or mw.ustring.find(s, '^{|') then
if mw.ustring.find(s, '^[#*:;]') or mw.ustring.find(s, '^{|') then
end
end
function p.sidebar(frame, args)
function p.sidebar(frame, args, collapsibleClass)
if not args then
if not args then
args = getArgs(frame)
args = getArgs(frame)
end
end
local root = mw.html.create()
local root = mw.html.create()
local child = args.child and mw.text.trim(args.child) == cfg.i18n.child_yes
local child = args.child and mw.text.trim(args.child) == 'yes'
if not child then
if not child then
root
root = root
:tag('table')
:addClass('vertical-navbox')
:addClass(args.wraplinks ~= 'true' and 'nowraplinks' or nil)
:addClass('nomobile')
:addClass(args.float == cfg.i18n.float_none and cfg.i18n.class.float_none or nil)
:addClass(args.wraplinks ~= cfg.i18n.wrap_true and cfg.i18n.class.wraplinks or nil)
:addClass(args.bodyclass or args.class)
:addClass(args.bodyclass or args.class)
:css('width', args.width or nil)
:css('float', args.float or 'right')
:css('clear', (args.float == 'none' and 'both') or args.float or 'right')
:css('width', args.width or '22.0em')
:css('margin', args.float == 'left' and '0 1.0em 1.0em 0' or '0 0 1.0em 1.0em')
:css('background', '#f9f9f9')
:css('border', '1px solid #aaa')
:css('padding', '0.2em')
:css('border-spacing', '0.4em 0')
:css('text-align', 'center')
:css('line-height', '1.4em')
:css('font-size', '88%')
:cssText(args.bodystyle or args.style)
:cssText(args.bodystyle or args.style)
root
root
:tag('caption')
:tag('caption')
:addClass(args.outertitleclass)
:addClass(args.outertitleclass)
:css('padding-bottom', '0.2em')
:css('font-size', '125%')
:css('line-height', '1.2em')
:css('font-weight', 'bold')
:cssText(args.outertitlestyle)
:cssText(args.outertitlestyle)
:wikitext(args.outertitle)
:wikitext(args.outertitle)
imageCell
imageCell
:addClass(args.topimageclass)
:addClass(args.topimageclass)
:css('padding', '0.4em 0')
:cssText(args.topimagestyle)
:cssText(args.topimagestyle)
:wikitext(args.topimage)
:wikitext(args.topimage)
imageCell
imageCell
:tag('div')
:tag('div')
:addClass(cfg.i18n.class.top_caption)
:css('padding-top', '0.2em')
:css('line-height', '1.2em')
:cssText(args.topcaptionstyle)
:cssText(args.topcaptionstyle)
:wikitext(args.topcaption)
:wikitext(args.topcaption)
:tag('tr')
:tag('tr')
:tag('td')
:tag('td')
:addClass(args.pretitleclass)
:addClass(args.pretitleclass)
:cssText(args.basestyle)
:cssText(args.basestyle)
:css('padding-top', args.topimage and '0.2em' or '0.4em')
:css('line-height', '1.2em')
:cssText(args.pretitlestyle)
:cssText(args.pretitlestyle)
:wikitext(args.pretitle)
:wikitext(args.pretitle)
end
end
end
end
root
root
:wikitext(args.title)
:wikitext(args.title)
:wikitext('</th></tr>') -- @todo replace this with unclosed again once mw.html gets it
else
else
root
root
:tag('tr')
:tag('tr')
:tag('th')
:tag('th')
:addClass(args.titleclass)
:addClass(args.titleclass)
:cssText(args.basestyle)
:cssText(args.basestyle)
:css('padding', '0.2em 0.4em 0.2em')
:css('padding-top', args.pretitle and 0)
:css('font-size', '145%')
:css('line-height', '1.2em')
:cssText(args.titlestyle)
:cssText(args.titlestyle)
:wikitext(args.title)
:wikitext(args.title)
imageCell
imageCell
:addClass(args.imageclass)
:addClass(args.imageclass)
:css('padding', '0.2em 0 0.4em')
:cssText(args.imagestyle)
:cssText(args.imagestyle)
:wikitext(args.image)
:wikitext(args.image)
imageCell
imageCell
:tag('div')
:tag('div')
:addClass(cfg.i18n.class.caption)
:css('padding-top', '0.2em')
:css('line-height', '1.2em')
:cssText(args.captionstyle)
:cssText(args.captionstyle)
:wikitext(args.caption)
:wikitext(args.caption)
:tag('tr')
:tag('tr')
:tag('td')
:tag('td')
:addClass(args.aboveclass)
:addClass(args.aboveclass)
:css('padding', '0.3em 0.4em 0.3em')
:css('font-weight', 'bold')
:cssText(args.abovestyle)
:cssText(args.abovestyle)
:newline() -- newline required for bullet-points to work
:newline() -- newline required for bullet-points to work
end
end
table.sort(rowNums)
table.sort(rowNums)
-- remove duplicates from the list (e.g. 3 will be duplicated if both heading3
-- remove duplicates from the list (e.g. 3 will be duplicated if both heading3 and content3 are specified)
for i = #rowNums, 1, -1 do
for i = #rowNums, 1, -1 do
if rowNums[i] == rowNums[i - 1] then
if rowNums[i] == rowNums[i - 1] then
:tag('tr')
:tag('tr')
:tag('th')
:tag('th')
:addClass(args.headingclass)
:addClass(args.headingclass)
:addClass(args['heading' .. num .. 'class'])
:css('padding', '0.1em')
:cssText(args.basestyle)
:cssText(args.basestyle)
:cssText(args.headingstyle)
:cssText(args.headingstyle)
:tag('tr')
:tag('tr')
:tag('td')
:tag('td')
:addClass(args.contentclass)
:addClass(args.contentclass)
:addClass(args['content' .. num .. 'class'])
:css('padding', '0 0.1em 0.4em')
:cssText(args.contentstyle)
:cssText(args.contentstyle)
:cssText(args['content' .. num .. 'style'])
:cssText(args['content' .. num .. 'style'])
:wikitext(content)
:wikitext(content)
:done()
:done()
:newline() -- Without a linebreak after the </td>, a nested list like "* {{hlist| ...}}" doesn't parse correctly.
end
end
end
end
:tag('tr')
:tag('tr')
:tag('td')
:tag('td')
:addClass(args.belowclass)
:addClass(args.belowclass)
:css('padding', '0.3em 0.4em 0.3em')
:css('font-weight', 'bold')
:cssText(args.belowstyle)
:cssText(args.belowstyle)
:newline()
:newline()
end
end
if not child and has_navbar(args.navbar, args.name) then
if not child then
local navbarArg = args.navbar or args.tnavbar
if navbarArg ~= 'none' and navbarArg ~= 'off' and (args.name or frame:getParent():getTitle():gsub('/sandbox$', '') ~= 'Шаблон:Sidebar') then
root
:tag('tr')
:tag('td')
:css('text-align', 'right')
:css('font-size', '115%')
:cssText(args.navbarstyle or args.tnavbarstyle)
:wikitext(navbar{
args.name,
mini = 1,
fontstyle = args.navbarfontstyle or args.tnavbarfontstyle
})
end
end
end
return table.concat({
return tostring(root)
end
end
function p.collapsible(frame)
function p.collapsible(frame)
local args = getArgs(frame)
local args = getArgs(frame)
if not args.name and
args.abovestyle = 'border-top: 1px solid #aaa; border-bottom: 1px solid #aaa;' .. (args.abovestyle or '')
args.belowstyle = 'border-top: 1px solid #aaa; border-bottom: 1px solid #aaa;' .. (args.belowstyle or '')
args.navbar = cfg.i18n.navbar_none
args.navbarstyle = 'padding-top: 0.6em;' .. (args.navbarstyle or args.tnavbarstyle or '')
if not args.name and frame:getParent():getTitle():gsub('/sandbox$', '') == 'Шаблон:Sidebar with collapsible lists' then
args.navbar = 'none'
end
end
local contentArgs = {}
local contentArgs = {}
for k, v in pairs(args) do
for k, v in pairs(args) do
local num = string.match(k, '^list(%d+)$')
local num = string.match(k, '^list(%d+)$')
if num then
if num then
local expand = args.expanded and
local expand = args.expanded and (args.expanded == 'all' or args.expanded == args['list' .. num .. 'name'])
local row = mw.html.create('div')
local row = mw.html.create('div')
row
row
:addClass('NavFrame')
:addClass('mw-collapsible')
:addClass((not expand) and 'collapsed' or nil)
:addClass((not expand) and 'mw-collapsed' or nil)
:css('border', 'none')
:addClass(args['list' .. num .. 'class'])
:css('padding', 0)
:cssText(args.listframestyle)
:cssText(args.listframestyle)
:cssText(args['list' .. num .. 'framestyle'])
:cssText(args['list' .. num .. 'framestyle'])
:tag('div')
:tag('div')
:addClass(cfg.i18n.class.list_content)
:addClass('NavHead')
:addClass('mw-collapsible-content')
:addClass(args.listtitleclass)
-- don't /need/ a listnumstyleclass because you can do
:css('font-size', '105%')
:css('background', 'transparent')
:css('text-align', 'left')
:cssText(args.basestyle)
:cssText(args.listtitlestyle)
:cssText(args['list' .. num .. 'titlestyle'])
:wikitext(trimAndAddAutomaticNewline(args['list' .. num .. 'title'] or 'List'))
:done()
:tag('div')
:addClass('NavContent')
:addClass(args.listclass)
:addClass(args.listclass)
:addClass(args['list' .. num .. 'class'])
:css('font-size', '105%')
:css('padding', '0.2em 0 0.4em')
:css('text-align', 'center')
:cssText(args.liststyle)
:cssText(args.liststyle)
:cssText(args['list' .. num .. 'style'])
:cssText(args['list' .. num .. 'style'])
end
end
return p.sidebar(frame, args, cfg.i18n.class.collapse)
return p.sidebar(frame, args)
end
end
return p
return p