diff options
Diffstat (limited to 'documentation/layout/layout-accordion.asciidoc')
-rw-r--r-- | documentation/layout/layout-accordion.asciidoc | 85 |
1 files changed, 85 insertions, 0 deletions
diff --git a/documentation/layout/layout-accordion.asciidoc b/documentation/layout/layout-accordion.asciidoc new file mode 100644 index 0000000000..37bbe9e529 --- /dev/null +++ b/documentation/layout/layout-accordion.asciidoc @@ -0,0 +1,85 @@ +--- +title: Accordion +order: 10 +layout: page +--- + +[[layout.accordion]] += [classname]#Accordion# + +[classname]#Accordion# is a multicomponent container similar to +[classname]#TabSheet#, except that the "tabs" are arranged vertically. Clicking +on a tab opens its contained component in the space between the tab and the next +one. You can use an [classname]#Accordion# identically to a +[classname]#TabSheet#, which it actually inherits. See +<<dummy/../../../framework/layout/layout-tabsheet#layout.tabsheet,"TabSheet">> +for more information. + +The following example shows how you can create a simple accordion. As the +[classname]#Accordion# is rather naked alone, we put it inside a Panel that acts +as its caption and provides it a border. + + +[source, java] +---- +// Create the accordion +Accordion accordion = new Accordion(); + +// Create the first tab, specify caption when adding +Layout tab1 = new VerticalLayout(); // Wrap in a layout +tab1.addComponent(new Image(null, // No component caption + new ThemeResource("img/planets/Mercury.jpg"))); +accordion.addTab(tab1, "Mercury", + new ThemeResource("img/planets/Mercury_symbol.png")); + +// This tab gets its caption from the component caption +Component tab2 = new Image("Venus", + new ThemeResource("img/planets/Venus.jpg")); +accordion.addTab(tab2).setIcon( + new ThemeResource("img/planets/Venus_symbol.png")); + +// And so forth the other tabs... +String[] tabs = {"Earth", "Mars", "Jupiter", "Saturn"}; +for (String caption: tabs) { + String basename = "img/planets/" + caption; + VerticalLayout tab = new VerticalLayout(); + tab.addComponent(new Embedded(null, + new ThemeResource(basename + ".jpg"))); + accordion.addTab(tab, caption, + new ThemeResource(basename + "_symbol.png")); +} +---- + +<<figure.accordion.example1>> shows what the example would look like with the +default theme. + +[[figure.accordion.example1]] +.An Accordion +image::img/accordion-example1.png[] + +== CSS Style Rules + + +[source, css] +---- +.v-accordion {} + .v-accordion-item, + .v-accordion-item-open, + .v-accordion-item-first {} + .v-accordion-item-caption {} + .v-caption {} + .v-accordion-item-content {} + .v-scollable {} +---- + +The top-level element of [classname]#Accordion# has the +[literal]#++v-accordion++# style. An [classname]#Accordion# consists of a +sequence of item elements, each of which has a caption element (the tab) and a +content area element. + +The selected item (tab) has also the [literal]#++v-accordion-open++# style. The +content area is not shown for the closed items. + + + + |