Packages
WARNING: could not import PlutoUI.@with_terminal into workspace#3
StructBond
Generating automatic widgets for custom structs is quite straightforward with the aid of the @fielddata
macro and the StructBond
type.
The top-left arrow can be used to show-hide the field elements (useful inside a BondTable
, shown below), while the green toggle on the top-right can be used to disable temporarily the synch between the JS widgets and the bond values in Pluto.
Markdown description, including $LaTeX$
This field is special
3
9
"lolasdasdf"
""
20
Default Type Widgets
1
@NTBond
Sometimes custom structs are not needed and it would be useful to just use the same nice bond structure of StructBond
to simply create arbitrary NamedTuples.
This is possible with the convenience macro @NTBond
which can be called as shown below to create a nice display for an interactive bond creating an arbitrary NamedTuple.
The macro simply create a StructBond
wrapping the desired NamedTuple type.
Bold field
3
3
8
@BondsList
In some cases, one does not want to have a single bond wrapping either a Structure or a NamedTuple because single independent bonds are more convenient.
@BondsList
is a convenience macro to create an object of type BondsList
which simply allow to add a description to separate bonds and group them all together in a table-like format equivalent to those of StructBond
.
Note
Unlike StructBond
, a BondsList is already composed of bond created with @bind
and it just groups them up with a description. The output of @BondsList
is not supposed to be bound to a variable using @bind
.
The bonds grouped in a BondsList still act and update independently from one another.
See the example below for understanding the synthax. The header of a BondsList is shown in an orange background to easily differentiate it from StructBond
.
Altitude $h$ [m]
1.5e10
160
Popout
The structures above can also be used nested within one another. To facilitate accessing nested structures, one can use the Popout
type.
In its simple form, you can give an instance of a StructBond, a bond wrapping a StructBond or a BondsList as input to Popout to create a table that is hidden behind a popup window. If an instance present, but you want a custom type for which you have defined custom bonds and descriptions with @fielddata
to appear as popout, you can use the function popoutwrap(TYPE)
to generate a small icon which hides a popup containing the StructBond
of the provided type TYPE
.
The StructBond table appears on hover upon the icon, can be made fixed by clicking on the icon and can then be moved around or resized. A double click on the header of the popout hides it again:
Wonder!
5
4
The ability to also wrap pre-existing bonds around StructBonds is convenient for organizing the various bonds one have in a BondsList
or BondTable
As an example, one can create a BondsList
containing the two StructBond
bonds generated at the beginning of this notebook with the follwing code.
Markdown description, including $LaTeX$
This field is special
Bold field
3
9
"lolasdasdf"
""
20
3
3
8
BondTable
The final convenience structure provided by this module is the BondTable
. It can be created to group a list of bonds in a floating table that stays on the left side of the notebook (similar to the TableOfContents of PlutoUI) and can be moved around and resized or hidden for convenience.
The BondTable is intended to be used either with bonds containing StructBond
or with BondsList
. Future types with similar structure will also be added.
Here is an example of a bondtable containing all the examples of this notebook.
Markdown description, including $LaTeX$
This field is special
Bold field
Altitude $h$ [m]
Markdown description, including $LaTeX$
This field is special
Bold field
3
3
8
3
9
"lolasdasdf"
""
20
1.5e10
160