- Barry Books as trsvax
Bootstrap is a grid based CSS framework started by Twitter. Tapestry is a Java based web framework.
- Converts existing components such a BeanEditForm and Grid into Bootstrap Forms/Tables
- Components such as ButtonGroup that make creating Bootstrap HTML easier.
- Uses Tapestry chain of command so functionality can be extended/overridden.
- Extensive configuration via the environment
The module attaches a mixin called FW to all existing components. The mixin calls a chain of command with render events. In general the cleaupRender phase is used to modify the DOM created by components so that it is compatible with Bootstrap CSS.
Bootstrap Components:
-
Breadcrumb
- format Breadcrumbs
-
ButtonGroup
- Turns a set of links into a ButtonGroup
-
Code
- based on Code
-
DropDown
- marks a set of links so they are formated as a drop down. Can be used in Nav and ButtonGroup
-
Nav
- based on Nav
-
NavBar
- based on NavBar
-
Pagination
- based on Pagination
-
Thumbnail
- based on Thumbnails
Bootstap Mixins
-
Draggable
- makes elements Draggable
-
Droppable
- makes elements Droppable
-
FW
- internal mixin for attaching framework chain to component
-
*LoopEnviromentMixin
- add to Loop component to support paging
-
Pager
- integrates Pagination and Loop to implement paged data sets
-
PushEnvironment
- push new objects into the environment
-
Sortable
- makes elements [Sortable]http://jqueryui.com/demos/sortable/)
##Using Bootstrap: Just include the jar file to your project, add the following to your Layout.
@Exclude(stylesheet={"core"}) //If you do not want Tapestry CSS
@Import(stylesheet={
"classpath:/com/trsvax/bootstrap/assets/bootstrap/css/bootstrap.css",
"classpath:/com/trsvax/bootstrap/assets/bootstrap/css/bootstrap-responsive.css"
},
library={
"classpath:/com/trsvax/bootstrap/assets/bootstrap/js/bootstrap.js"
}
)
then modify your Layout.tml Layouts
<body>
<div class="container">
<t:body/>
</div>
</body>
The fw mixins adds an fwtype parameter to the Grid. If this value is null the Grid works as before. Providing a Table Option will cause the table to be formated by Bootstrap
as with Grid an fwtype parameter will format the form with Bootstrap. based on Forms
Add fwtype parameter to the BeanDisplay. If the value is null the BeanDisplat looks as before. Use values "dl" or "dl-horizontal" to apply mixin. Any other CSS classes can be additionally specified here, i.e., bootstrap "well".
Add fwtype parameter to the Alerts. If the value is null the Alerts looks as before. Value fwtype="alert" changes look and feel according to bootstrap alerts.
Alerts will work better with Tapestry 5.3.6 and above (see TAP5-1996).
There are two Tapestry configurations that allow you to customize Bootstrap. First the EnvironmentSetup.class defines a set of mapped objects that set defaults for most of the components/mixins. For example the following sets the default table type to "table" which will cause all Grid tables to be formated by Bootstrap.
@Contribute(EnvironmentSetup.class)
public static void provideEnvironmentSetup(MappedConfiguration<Class, Object> configuration) {
configuration.override(TableEnvironment.class, new TableValues(null).withType("table"));
}
Second is the BootstrapProvider chain. This contains an ordered list of provides that create the Bootstrap Provider. The chain is called by the FW mixin for every component. You can override existing providers or add your own.