モジュール:Clickable button 2/sandbox
表示
これはモジュール:Clickable button 2 (差分)のモジュール・サンドボックスページです。 |
このLuaモジュールは18,000のページで使われています。 余計な混乱やサーバーへの負荷を避けるために、どんな変更でも最初はモジュールのサンドボックス・サブページ、テストケース・サブページで試すべきです。そうすれば、試した変更を1度の編集でこのモジュールに加えることができます。しかし、最初にあなたの提案した変更を、この項目のノートで議論するようにお願いします。 |
このモジュールは保護されています。このモジュールは非常に多くのページで使用されています。荒らしまたは過失によって多くのページが影響を受け、また些細な編集でもサーバーに多大な負荷をかけるため、編集保護されています。 |
このモジュールは{{Clickable button 2}}を実装しています。
ウィキテキストから使う
[編集]ウィキテキストから使うときは一般的には{{Clickable button 2}}を使うべきです。どうしても必要なときは{{#invoke:Clickable button 2|main|args}}
のように呼び出せます。使える引数の一覧はテンプレートの説明文をご参照ください。
Luaモジュールから使う
[編集]ほかのLuaモジュールから使うときは、まずこのモジュールをロードしてください。
local mClickableButton2 = require('Module:Clickable button 2')
続いて、luaMain関数でボタンを生成することができます。
mClickableButton2.luaMain(args)
args引数はモジュールに渡される引数のテーブルです。指定できる引数とその使い方については{{Clickable button 2}}の説明文をご参照ください。
-- This module implements {{clickable button 2}}.
local yesno = require('Module:Yesno')
local p = {}
function p.main(frame)
local args = require('Module:Arguments').getArgs(frame, {
wrappers = 'Template:Clickable button 2'
})
return p.luaMain(args)
end
function p.luaMain(args)
if not args[1] and not args.url then
return ''
end
local data = p.makeLinkData(args)
local link = p.renderLink(data)
local trackingCategories = p.renderTrackingCategories(args)
return link .. trackingCategories
end
function p.makeLinkData(args)
local data = {}
-- Get the link and display values, and find whether we are outputting a
-- wikilink or a URL.
if args.url then
data.isUrl = true
data.link = args.url
if args[1] then
data.display = args[1]
else
data.display = args.url
end
else
data.isUrl = false
data.link = args[1]
if args[2] then
data.display = args[2]
else
data.display = args[1]
end
end
-- Classes
local class = args.class and args.class:lower()
data.classes = {}
if class == 'ui-button-green'
or class == 'ui-button-blue'
or class == 'ui-button-red'
then
table.insert(
data.classes,
'submit ui-button ui-widget ui-state-default ui-corner-all'
.. ' ui-button-text-only ui-button-text'
)
else
table.insert(data.classes, 'mw-ui-button')
end
if class then
table.insert(data.classes, class)
end
-- Styles
do
--[[
-- Check whether we are on the same page as we have specified in
-- args[1], but not if we are using a URL link, as then args[1] is only
-- a display value. If we are currently on the page specified in
-- args[1] make the button colour darker so that it stands out from
-- other buttons on the page.
--]]
local success, linkTitle, currentTitle
if not data.isUrl then
currentTitle = mw.title.getCurrentTitle()
success, linkTitle = pcall(mw.title.new, args[1])
end
if success
and linkTitle
and mw.title.equals(currentTitle, linkTitle)
then
if class == 'ui-button-blue'
or class == 'mw-ui-progressive'
or class == 'mw-ui-constructive'
then
data.backgroundColor = '#2962CB'
elseif class == 'ui-button-green' then
data.backgroundColor = '#008B6D'
elseif class == 'ui-button-red' or class == 'mw-ui-destructive' then
data.backgroundColor = '#A6170F'
else
data.backgroundColor = '#CCC'
data.color = '#666'
end
end
-- Add user-specified styles.
data.style = args.style
-- Add rounded corner style if specified.
if args.cornerRadius then
data.style = (data.style or '') .. string.format('border-radius: %s;', args.cornerRadius)
end
-- Add button size if specified.
if args.width or args.height then
data.style = (data.style or '') .. string.format('width: %s;', args.width or 'auto')
data.style = data.style .. string.format(' height: %s;', args.height or 'auto')
-- Add centering styles
data.style = data.style .. ' display: flex; align-items: center; justify-content: center;'
end
-- Add text size if specified.
if args.textSize then
data.style = (data.style or '') .. string.format('font-size: %s;', args.textSize)
end
-- Add border color if specified.
if args.borderColor then
data.style = (data.style or '') .. string.format('border: 2px solid %s;', args.borderColor)
end
-- Add border width if specified.
if args.borderWidth then
local borderWidth = tonumber(args.borderWidth) or 1 -- Default to 1px if invalid value
data.style = (data.style or '') .. string.format('border-width: %spx;', borderWidth)
end
end
return data
end
function p.renderLink(data)
-- Render the display span tag.
local display
do
local displaySpan = mw.html.create('span')
for i, class in ipairs(data.classes or {}) do
displaySpan:addClass(class)
end
displaySpan
:attr('role', 'button')
:attr('aria-disabled', 'false')
:css{
['background-color'] = data.backgroundColor,
color = data.color
}
if data.style then
displaySpan:cssText(data.style)
end
displaySpan:wikitext(data.display)
display = tostring(displaySpan)
end
-- Render the link
local link
if data.isUrl then
link = string.format('[%s %s]', data.link, display)
else
link = string.format('[[%s|%s]]', data.link, display)
end
return string.format('<span class="plainlinks">%s</span>', link)
end
function p.renderTrackingCategories(args)
if yesno(args.category) == false then
return ''
end
local class = args.class and args.class:lower()
if class == 'ui-button-green'
or class == 'ui-button-blue'
or class == 'ui-button-red'
then
return ''
else
return ''
end
end
return p