REF make filesytem module pretty
This commit is contained in:
parent
f7a145cae6
commit
d4a29b362f
|
@ -1,87 +1,90 @@
|
||||||
local Line = require 'Line'
|
local Line = require 'Line'
|
||||||
local Util = require 'Util'
|
local Util = require 'Util'
|
||||||
local Common = require 'Common'
|
local Common = require 'Common'
|
||||||
local Geometry = require 'Geometry'
|
local Geometry = require 'Geometry'
|
||||||
|
|
||||||
local _FS_PATHS_ = {'/', '/boot', '/home', '/mnt/data', '/mnt/dcache', "/tmp"}
|
|
||||||
local _MODULE_Y_ = 170
|
|
||||||
local _SPACING_ = 20
|
|
||||||
local _BAR_PAD_ = 100
|
|
||||||
local _SEPARATOR_SPACING_ = 20
|
|
||||||
|
|
||||||
local FS_NUM = #_FS_PATHS_
|
|
||||||
|
|
||||||
local header = Common.Header(
|
|
||||||
Geometry.RIGHT_X,
|
|
||||||
_MODULE_Y_,
|
|
||||||
Geometry.SECTION_WIDTH,
|
|
||||||
'FILE SYSTEMS'
|
|
||||||
)
|
|
||||||
|
|
||||||
local conky_used_perc = {}
|
|
||||||
|
|
||||||
for i, v in pairs(_FS_PATHS_) do
|
|
||||||
conky_used_perc[i] = '${fs_used_perc '..v..'}'
|
|
||||||
end
|
|
||||||
|
|
||||||
local smart = Common.initTextRow(
|
|
||||||
Geometry.RIGHT_X,
|
|
||||||
header.bottom_y,
|
|
||||||
Geometry.SECTION_WIDTH,
|
|
||||||
'SMART Daemon'
|
|
||||||
)
|
|
||||||
|
|
||||||
local _SEP_Y_ = header.bottom_y + _SEPARATOR_SPACING_
|
|
||||||
|
|
||||||
local separator = Common.initSeparator(
|
|
||||||
Geometry.RIGHT_X,
|
|
||||||
_SEP_Y_,
|
|
||||||
Geometry.SECTION_WIDTH
|
|
||||||
)
|
|
||||||
|
|
||||||
local _BAR_Y_ = _SEP_Y_ + _SEPARATOR_SPACING_
|
|
||||||
|
|
||||||
local fs = Common.compound_bar(
|
|
||||||
Geometry.RIGHT_X,
|
|
||||||
_BAR_Y_,
|
|
||||||
Geometry.SECTION_WIDTH,
|
|
||||||
_BAR_PAD_,
|
|
||||||
{'root', 'boot', 'home', 'data', 'dcache', 'tmpfs'},
|
|
||||||
_SPACING_,
|
|
||||||
12,
|
|
||||||
0.8
|
|
||||||
)
|
|
||||||
|
|
||||||
_SPACING_ = nil
|
|
||||||
_BAR_PAD_ = nil
|
|
||||||
_FS_PATHS_ = nil
|
|
||||||
_SEPARATOR_SPACING_ = nil
|
|
||||||
_BAR_Y_ = nil
|
|
||||||
_SEP_Y_ = nil
|
|
||||||
|
|
||||||
local update = function(cr)
|
|
||||||
local smart_pid = Util.execute_cmd('pidof smartd', nil, '*n')
|
|
||||||
Common.text_row_set(smart, cr, (smart_pid == '') and 'Error' or 'Running')
|
|
||||||
|
|
||||||
for i = 1, FS_NUM do
|
|
||||||
local percent = Util.conky_numeric(conky_used_perc[i])
|
|
||||||
Common.compound_bar_set(fs, i, percent * 0.01)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
local draw_static = function(cr)
|
|
||||||
Common.drawHeader(cr, header)
|
|
||||||
Common.text_row_draw_static(smart, cr)
|
|
||||||
Line.draw(separator, cr)
|
|
||||||
Common.compound_bar_draw_static(fs, cr)
|
|
||||||
end
|
|
||||||
|
|
||||||
local draw_dynamic = function(cr, trigger)
|
|
||||||
if trigger == 0 then update(cr) end
|
|
||||||
Common.text_row_draw_dynamic(smart, cr)
|
|
||||||
Common.compound_bar_draw_dynamic(fs, cr)
|
|
||||||
end
|
|
||||||
|
|
||||||
return function()
|
return function()
|
||||||
|
local FS_PATHS = {'/', '/boot', '/home', '/mnt/data', '/mnt/dcache', "/tmp"}
|
||||||
|
local MODULE_Y = 170
|
||||||
|
local SPACING = 20
|
||||||
|
local BAR_PAD = 100
|
||||||
|
local SEPARATOR_SPACING = 20
|
||||||
|
|
||||||
|
-----------------------------------------------------------------------------
|
||||||
|
-- header
|
||||||
|
|
||||||
|
local header = Common.Header(
|
||||||
|
Geometry.RIGHT_X,
|
||||||
|
MODULE_Y,
|
||||||
|
Geometry.SECTION_WIDTH,
|
||||||
|
'FILE SYSTEMS'
|
||||||
|
)
|
||||||
|
|
||||||
|
-----------------------------------------------------------------------------
|
||||||
|
-- smartd
|
||||||
|
|
||||||
|
local smart = Common.initTextRow(
|
||||||
|
Geometry.RIGHT_X,
|
||||||
|
header.bottom_y,
|
||||||
|
Geometry.SECTION_WIDTH,
|
||||||
|
'SMART Daemon'
|
||||||
|
)
|
||||||
|
|
||||||
|
local SEP_Y = header.bottom_y + SEPARATOR_SPACING
|
||||||
|
|
||||||
|
local separator = Common.initSeparator(
|
||||||
|
Geometry.RIGHT_X,
|
||||||
|
SEP_Y,
|
||||||
|
Geometry.SECTION_WIDTH
|
||||||
|
)
|
||||||
|
|
||||||
|
-----------------------------------------------------------------------------
|
||||||
|
-- filesystem bar chart
|
||||||
|
|
||||||
|
local BAR_Y = SEP_Y + SEPARATOR_SPACING
|
||||||
|
|
||||||
|
local fs = Common.compound_bar(
|
||||||
|
Geometry.RIGHT_X,
|
||||||
|
BAR_Y,
|
||||||
|
Geometry.SECTION_WIDTH,
|
||||||
|
BAR_PAD,
|
||||||
|
{'root', 'boot', 'home', 'data', 'dcache', 'tmpfs'},
|
||||||
|
SPACING,
|
||||||
|
12,
|
||||||
|
0.8
|
||||||
|
)
|
||||||
|
|
||||||
|
local FS_NUM = #FS_PATHS
|
||||||
|
local CONKY_USED_PERC = {}
|
||||||
|
for i, v in pairs(FS_PATHS) do
|
||||||
|
CONKY_USED_PERC[i] = '${fs_used_perc '..v..'}'
|
||||||
|
end
|
||||||
|
|
||||||
|
-----------------------------------------------------------------------------
|
||||||
|
-- main functions
|
||||||
|
|
||||||
|
local update = function(cr)
|
||||||
|
local smart_pid = Util.execute_cmd('pidof smartd', nil, '*n')
|
||||||
|
Common.text_row_set(smart, cr, (smart_pid == '') and 'Error' or 'Running')
|
||||||
|
|
||||||
|
for i = 1, FS_NUM do
|
||||||
|
local percent = Util.conky_numeric(CONKY_USED_PERC[i])
|
||||||
|
Common.compound_bar_set(fs, i, percent * 0.01)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local draw_static = function(cr)
|
||||||
|
Common.drawHeader(cr, header)
|
||||||
|
Common.text_row_draw_static(smart, cr)
|
||||||
|
Line.draw(separator, cr)
|
||||||
|
Common.compound_bar_draw_static(fs, cr)
|
||||||
|
end
|
||||||
|
|
||||||
|
local draw_dynamic = function(cr, trigger)
|
||||||
|
if trigger == 0 then update(cr) end
|
||||||
|
Common.text_row_draw_dynamic(smart, cr)
|
||||||
|
Common.compound_bar_draw_dynamic(fs, cr)
|
||||||
|
end
|
||||||
|
|
||||||
return {static = draw_static, dynamic = draw_dynamic}
|
return {static = draw_static, dynamic = draw_dynamic}
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue