Module:Keyboard vis: Difference between revisions
Jump to navigation
Jump to search
Tristanbay (talk | contribs) see if this fixes mobile formatting issue |
Tristanbay (talk | contribs) temporary test |
||
| Line 40: | Line 40: | ||
line_4 = line_4 .. CORNER_BR | line_4 = line_4 .. CORNER_BR | ||
local result = '<pre | local result = '<pre>' | ||
.. string.format('\n%s\n%s\n%s\n%s\n', line_1, line_2, line_3, line_4) | .. string.format('\n%s\n%s\n%s\n%s\n', line_1, line_2, line_3, line_4) | ||
.. '</pre>' | .. '</pre>' | ||
Revision as of 03:34, 5 December 2025
- This module has a corresponding template that is currently missing or does not use this module. (edit template)
This module displays a Halberstadt-like keyboard layout for a given MOS pattern, assuming a 2:1 step ratio.
| Introspection summary for Module:Keyboard vis | ||||||||||
|---|---|---|---|---|---|---|---|---|---|---|
|
| |||||||||
No function descriptions were provided. The Lua code may have further information.
local p = {}
local CORNER_TL = '┌' -- U+250C ┌
local CORNER_TR = '┐' -- U+2510 ┐
local CORNER_BL = '└' -- U+2514 └
local CORNER_BR = '┘' -- U+2518 ┘
local BORDER_BLACK_KEY_TOP = '╥' -- U+2565 ╥
local BORDER_WHITE_KEY_TOP = '┬' -- U+252C ┬
local BORDER_KEY_BOTTOM = '┴' -- U+2534 ┴
local BORDER_BLACK_KEY_SIDE = '║' -- U+2551 ║
local BORDER_WHITE_KEY_SIDE = '│' -- U+2502 │
-- Produces a small keyboard visualization
-- Likely to display correctly on most devices
function p.vis_small(step_pattern)
local step_pattern = step_pattern or "LLLsLLs"
local line_1 = CORNER_TL
local line_2 = BORDER_WHITE_KEY_SIDE
local line_3 = BORDER_WHITE_KEY_SIDE
local line_4 = CORNER_BL
for i = 1, #step_pattern do
local current_step = step_pattern:sub(i,i)
if current_step == "L" then
line_1 = line_1 .. BORDER_BLACK_KEY_TOP
line_2 = line_2 .. BORDER_BLACK_KEY_SIDE
line_3 = line_3 .. BORDER_WHITE_KEY_SIDE
line_4 = line_4 .. BORDER_KEY_BOTTOM
elseif current_step == "s" then
line_1 = line_1 .. BORDER_WHITE_KEY_TOP
line_2 = line_2 .. BORDER_WHITE_KEY_SIDE
line_3 = line_3 .. BORDER_WHITE_KEY_SIDE
line_4 = line_4 .. BORDER_KEY_BOTTOM
end
end
line_1 = line_1 .. CORNER_TR
line_2 = line_2 .. BORDER_WHITE_KEY_SIDE
line_3 = line_3 .. BORDER_WHITE_KEY_SIDE
line_4 = line_4 .. CORNER_BR
local result = '<pre>'
.. string.format('\n%s\n%s\n%s\n%s\n', line_1, line_2, line_3, line_4)
.. '</pre>'
return result
end
return p