|
|
1行目: |
1行目: |
| local yesno = require('Module:Yesno')
| | __HIDDENCAT__ |
| local mList = require('Module:List')
| | [[file:Photo 2018 April.jpeg| thumb |2018年 鴨川でのお花見]] |
| local mTableTools = require('Module:TableTools')
| | == 研究室主宰者== |
| local mMessageBox = require('Module:Message box')
| | <gallery widths=150px heights=200px> |
| local TNT = require('Module:TNT')
| | Yasunori Hayashi.jpg|link=林 康紀|[[林 康紀]] |
| | </gallery> |
|
| |
|
| local p = {}
| | ==教室スタッフ== |
| | <gallery widths=150px heights=200px> |
| | Takeo Saneyoshi.jpg|link=實吉 岳郎|[[實吉 岳郎]] |
| | Misa Arizono.jpg|link=有薗 美沙|[[有薗 美沙]] |
| | Kotaro Mizuta.jpg|link=水田 恒太郎|[[水田 恒太郎]] |
| | Akihiro Goto.jpg|link=後藤 明弘|[https://researchmap.jp/7000017647?lang=ja 後藤 明弘] |
| | Nozomi Asaoka.jpg|link=淺岡 希美|[[淺岡 希美]] |
| | Taisei Hirouchi.jpg|link=廣内 大成|[[廣内 大成]] |
| | </gallery> |
|
| |
|
| local function format(msg, ...)
| | ==大学院生== |
| return TNT.format('I18n/Uses TemplateStyles', msg, ...)
| | <gallery widths=150px heights=200px> |
| end
| | Yaolong Li.jpg|link=李 耀龍|[[李 耀龍]] (D3) |
| | Leah Men Shin Kuo.jpg|link=郭 孟昕|[[郭 孟昕]] (D1) |
| | Yung-chia Chang.jpg|link=張 永佳|[[張 永佳]] (M2) |
| | Tomohiro Mitsugi.jpeg|link=三木 智博|[[三木 智博]] (M2) |
| | Seiya Ogura.jpg|link=小椋 星哉|[[小椋 星哉]] (M2) |
| | Xinzhi Jiang.jpg|link=蒋 欣知|[[蒋 欣知]] (M1) |
| | </gallery> |
|
| |
|
| local function getConfig()
| | ==研究生== |
| return mw.loadData('Module:Uses TemplateStyles/config')
| | <gallery widths=150px heights=200px> |
| end
| | Bohan Peng.jpg|[[Bohan Peng]] |
| | </gallery> |
|
| |
|
| local function renderBox(tStyles)
| | ==テクニカルスタッフ== |
| local boxArgs = {
| | <gallery widths=150px heights=200px> |
| type = 'notice',
| | Junko Kurahashi.jpg|[[倉橋 順子]] |
| small = true,
| | </gallery> |
| image = string.format('[[File:Farm-Fresh css add.svg|32px|alt=%s]]', format('logo-alt'))
| | [[en:Members]] |
| }
| |
| if #tStyles < 1 then
| |
| boxArgs.text = string.format('<strong class="error">%s</strong>', format('error-emptylist'))
| |
| else
| |
| local cfg = getConfig()
| |
| local tStylesLinks = {}
| |
| for i, ts in ipairs(tStyles) do
| |
| local link = string.format('[[:%s]]', ts)
| |
| local sandboxLink = nil
| |
| local tsTitle = mw.title.new(ts)
| |
| if tsTitle and cfg['sandbox_title'] then
| |
| local tsSandboxTitle = mw.title.new(string.format(
| |
| '%s:%s/%s/%s', tsTitle.nsText, tsTitle.baseText, cfg['sandbox_title'], tsTitle.subpageText))
| |
| if tsSandboxTitle and tsSandboxTitle.exists then
| |
| sandboxLink = format('sandboxlink', link, ':' .. tsSandboxTitle.prefixedText)
| |
| end
| |
| end
| |
| tStylesLinks[i] = sandboxLink or link
| |
| end
| |
| local tStylesList = mList.makeList('bulleted', tStylesLinks)
| |
| boxArgs.text = format(
| |
| mw.title.getCurrentTitle():inNamespaces(828,829) and 'header-module' or 'header-template') ..
| |
| '\n' .. tStylesList
| |
| end
| |
| return mMessageBox.main('mbox', boxArgs)
| |
| end
| |
| | |
| local function renderTrackingCategories(args, tStyles, titleObj)
| |
| if yesno(args.nocat) then
| |
| return ''
| |
| end
| |
|
| |
| local cfg = getConfig()
| |
|
| |
| local cats = {}
| |
|
| |
| -- Error category
| |
| if #tStyles < 1 and cfg['error_category'] then
| |
| cats[#cats + 1] = cfg['error_category']
| |
| end
| |
|
| |
| -- TemplateStyles category
| |
| titleObj = titleObj or mw.title.getCurrentTitle()
| |
| if (titleObj.namespace == 10 or titleObj.namespace == 828)
| |
| and not cfg['subpage_blacklist'][titleObj.subpageText]
| |
| then
| |
| local category = args.category or cfg['default_category']
| |
| if category then
| |
| cats[#cats + 1] = category
| |
| end
| |
| if not yesno(args.noprotcat) and (cfg['protection_conflict_category'] or cfg['padlock_pattern']) then
| |
| local currentProt = titleObj.protectionLevels["edit"] and titleObj.protectionLevels["edit"][1] or nil
| |
| local addedLevelCat = false
| |
| local addedPadlockCat = false
| |
| for i, ts in ipairs(tStyles) do
| |
| local tsTitleObj = mw.title.new(ts)
| |
| local tsProt = tsTitleObj.protectionLevels["edit"] and tsTitleObj.protectionLevels["edit"][1] or nil
| |
| if cfg['padlock_pattern'] and tsProt and not addedPadlockCat then
| |
| local content = tsTitleObj:getContent()
| |
| if not content:find(cfg['padlock_pattern']) then
| |
| cats[#cats + 1] = cfg['missing_padlock_category']
| |
| addedPadlockCat = true
| |
| end
| |
| end
| |
| if cfg['protection_conflict_category'] and currentProt and tsProt ~= currentProt and not addedLevelCat then
| |
| currentProt = cfg['protection_hierarchy'][currentProt] or 0
| |
| tsProt = cfg['protection_hierarchy'][tsProt] or 0
| |
| if tsProt < currentProt then
| |
| addedLevelCat = true
| |
| cats[#cats + 1] = cfg['protection_conflict_category']
| |
| end
| |
| end
| |
| end
| |
| end
| |
| end
| |
| for i, cat in ipairs(cats) do
| |
| cats[i] = string.format('[[Category:%s]]', cat)
| |
| end
| |
| return table.concat(cats)
| |
| end
| |
| | |
| function p._main(args, cfg)
| |
| local tStyles = mTableTools.compressSparseArray(args)
| |
| local box = renderBox(tStyles)
| |
| local trackingCategories = renderTrackingCategories(args, tStyles)
| |
| return box .. trackingCategories
| |
| end
| |
| | |
| function p.main(frame)
| |
| local origArgs = frame:getParent().args
| |
| local args = {}
| |
| for k, v in pairs(origArgs) do
| |
| v = v:match('^%s*(.-)%s*$')
| |
| if v ~= '' then
| |
| args[k] = v
| |
| end
| |
| end
| |
| return p._main(args)
| |
| end
| |
| | |
| return p
| |