Layout
Layout controls the base layout of the application. This layout is similar to tabs
configuration except it contains a single Pane
or Split
. It is configured inside your theme.ron.
The layout can use any non-focusable Pane
(these currently are AlbumArt
, Lyrics
, ProgressBar
, Header
and Tabs
)
and additionally must contain exactly one special TabContent
pane which will display content of the
currently active tab configured in tabs. The pane sizes can be either a percent
value ie. "100%"
or size in terminal cells (rows or columns, depending on the split direction) ie. "5"
.
Examples
Below are some examples you can use as pointers how to configure the layout.
Album Art in the header
Very similar to the default layout except progress bar is moved to the top and album art is moved to the left of the header.
Click to show theme.ron
layout: Split( direction: Vertical, panes: [ ( size: "8", pane: Split( direction: Horizontal, panes: [ ( size: "21", pane: Pane(AlbumArt), ), ( size: "100%", pane: Split( direction: Vertical, panes: [ ( size: "5", pane: Pane(Header), ), ( size: "1", pane: Pane(ProgressBar), ), ( size: "3", pane: Pane(Tabs), ), ] ) ), ] ), ), ( size: "100%", pane: Pane(TabContent), ), ],),
data:image/s3,"s3://crabby-images/596db/596db26919ee4e2df4897381ea7f2da5f8790e02" alt="Example layout with album art in the header"
Default layout
This is the default layout you get when starting rmpc without any configuration.
Click to show theme.ron
layout: Split( direction: Vertical, panes: [ ( pane: Pane(Header), size: "2", ), ( pane: Pane(Tabs), size: "3", ), ( pane: Pane(TabContent), size: "100%", ), ( pane: Pane(ProgressBar), size: "1", ), ],),
data:image/s3,"s3://crabby-images/325f9/325f94b432dff7af7b7762be5bc5c714aa48a338" alt="Example default layout"
Default layout with borders
This is the default layout, but with borders around all layout panes except the tabs.
Click to show theme.ron
layout: Split( direction: Vertical, panes: [ ( size: "4", borders: "ALL", pane: Pane(Header), ), ( size: "3", pane: Pane(Tabs), ), ( size: "100%", borders: "ALL", pane: Pane(TabContent), ), ( size: "3", borders: "ALL", pane: Pane(ProgressBar), ), ],),
data:image/s3,"s3://crabby-images/48105/48105e5b1168b1bbf4487603748749f5418bc0ba" alt="Example default layout with borders"
No layout, just the tab’s content
It is also possible to not use the base layout at all and simply display just the content of the currently active tab.
layout: Pane(TabContent),