Introduction
Introduction
libpanel is a library of widgets, developed initially for use in GNOME Builder, to provide movable panels of widgets with GTK 4.0.
It also provides a few other independent widgets like
PanelOmniBar, PanelStatusbar and PanelThemeSelector.
A typical UI using libpanel would see in the top level content box a
PanelDock. You can also add a PanelStatusbar at the
bottom, independently.
Dock
A dock is made out of 5 areas, start, end, top, bottom and center (the
areas are defined in PanelArea). The center area is always
visible and is the main part of the user interface. The start and end
areas are vertical panes on each side of the center, in the reading
order of the locale, which would beft left and right respectively in
English. The top and bottom area are horizontal panes above and below respectively.
Example builder for a PanelDock:
<object class="PanelDock" id="dock">
    <property name="reveal-end">false</property>
    <property name="vexpand">true</property>
    <child>
        <object class="PanelGrid" id="grid">
            <signal name="create-frame" handler="create_frame_cb"/>
        </object>
    </child>
    <child type="end">
        <object class="PanelPaned">
            <property name="orientation">vertical</property>
            <child>
                <object class="PanelFrame">
                    <child>
                        <object class="PanelWidget">
                            <property name="title">Color</property>
                            <property name="tooltip">Color</property>
                            <property name="can-maximize">true</property>
                            <property name="icon-name">color-select-symbolic</property>
                            <child>
                                <object class="GtkColorChooserWidget"></object>
                            </child>
                        </object>
                    </child>
                    <child>
                        <object class="PanelWidget">
                            <property name="title">Swatches</property>
                            <property name="icon-name">preferences-color-symbolic</property>
                            <property name="can-maximize">true</property>
                            <child>
                                <object class="GtkScrolledWindow">
                                    <child>
                                        <object class="GtkListBox"></object>
                                    </child>
                                </object>
                            </child>
                        </object>
                    </child>
                </object>
            </child>
        </object>
    </child>
</object>
This builder fragment creates a PanelDock with a paned on the end
area. PanelPaned is the widget representing the area, it will
contain other widgets.
Frames
PanelFrame contains stacked PanelWidget that will be
managed by a switcher widget. These PanelWidget will be the
containers for your widgets.
Frames are meant to contain widgets that you can move from one dock panel to another, and receive widgets from a different location. It will handle all that logic for you.
A panel frame will have a PanelFrameSwitcher to manage
switching between the stacked widget.
Showing paned
You can control the visibility (or reveal) of the various paned areas
of the dock. One easy way is to put a PanelToggleButton that
will be bound to one of the four areas of a PanelDock. The
button will automatically reveal or hide the paned when clicked on.
A toggle button for the area in the left (start in the English locale):
 
Center area
The center area is the main user interface. Typically you would have the documents displayed, and when all the paned areas are hidden, it would remain the only visible part.
Widgets can be layout in a PanelGrid that you add. You connect
to the PanelGrid::create-frame signal to be able to create
frames as requested. This will allow to manage multiple views of
document, switch between them etc,
Otherwise place a PanelWidget as a child to contain your own
widgets as its children.
Currently the only way to build the center area is by using a .ui
file and GtkBuilder.
Status bar
A PanelStatusbar can be added at the end of the window content
box. This is typically where you’d add a PanelToggleButton for
the area PANEL_AREA_BOTTOM. The status bar widget can be used
independently from the presence of a panel dock.
Omni bar
The omni bar is a more complex widget to provide information and actions, and also display a progress. Typically it would be added to the window header bar.
 
The omni bar can be used independently from the presence of a panel dock.
Theme selector
The PanelThemeSelector is a widget that allow to easily
provide a preference for the user to choose dark or light theme for
the application.
It provides three options:
 
- follow the system theme: it will use whatever is the global user preference.
- light: always use the light theme.
- dark: always use the dark theme.
You just specify an action name to be notified. It will do the rest.