NAME
Jifty::Manual::UsingCSSandJS - Using CSS and JavaScript
DESCRIPTION
Jifty comes bundled with a series of separately developed JavaScript libraries as well as a set of CSS definitions that both allow Jifty to functionally and beautifully work out of the box. This document describes the mechanisms behind the scenes as well as some of the details inside the included files.
BUILT-IN FEATURES
Both, CSS and JavaScript (further abbreviated as "JS") files typically reside in the share/web/static
directory of Jifty, keeping separate css
and js
subdirectories for each of both sets of files. When using Jifty without any interference into these files, all of those files will get loaded from the Jifty-provided directories.
In both cases, there are hooks for expansion by keeping empty but present files in the css
and js
directories. By simply creating and populating these files inside the share/web/static/css
and share/web/static/js
directories brings the predefined hooks to work.
Also there is a big difference of the whole operation between an application running in DevelMode
or a productive application. In DevelMode, every single CSS and JS file will get included into every single template page being rendered. On the other hand, a productive application will merge all CSS and JS definitions upon the first request and will only include one file each containing all CSS and JS definitions in a single request.
USING AND EXPANDING CSS
Assembly of CSS definitions
When Jifty assembles all CSS definitions (which is internally done inside Jifty::Web by the method include_css
, a single file, main.css
is included into the generated HTML code of the current page. This file consists of a series of @include
directives that reference every single CSS file to get used.
Expansion of CSS definitions
Jifty maintains two initially empty files, app-base.css
and app.css
that may get "overloaded" by simply providing these files in an application's share/web/static/css
directory.
These two files will get included in different order, app-base.css
being the very first and app.css
getting included very late in the CSS construction process.
This means that general definitions that should apply to all subsequently encountered styles could easily get done in app-base.css
whereas individual redefinitions, expansions or your application's own definitions could go into app.css
.
Jifty's own definitions
Jifty provides a series of definitions that are responsible for a good look without any modification. Please note that not all of the used CSS classes are already defined, but they will provide a hook for modification of the general look. Some of the styles are listed below.
- form_errors, error
-
Error messages encountered during validation are displayed inside a
<div>
tag of classform_errors
which initially is not yet defined. Every single error message is marked with a classerror
. - hints, warning, error
-
These classes are used for displaying additional information for form fields.
- form_field, mandatory, argument-$name
-
Every form field including its label is packed inside a
<div>
tag with these classes (mandatory only if the field is mandatory, of course), where$name
is the field's name. - preamble
-
This section is a
<span>
tag filled with a form field's preamble content that could contain additional instructions for the user. The content may be set by thepreamble
accessor method that is available for everyJifty::Web::Form::Field
and its successors. -
These class names are used depending on the type of widget getting rendered.
- autocomplete
-
used for the autocomplete div.
-
These classes are used in navigation bars.
- jifty, results, messages
-
These three CSS classes are used to surround a message block displaying an action's messages after having run an action.
- message, error, $moniker
-
Every single message that is displayed in an action's result box is marked with the message's type plus the action's moniker as a CSS class name.
USING AND EXPANDING JAVASCRIPT
Jifty comes bundled with a series of separately developed JavaScript libraries, like
Prototype
http://prototype.conio.net-
Prototype is a toolkit for providing AJAX support. This is a library some others depend on.
scriptaculous.js
http://script.aculo.us/-
This library provides support for animation with effects, drag & drop, AJAX controls and DOM utilities.
Rico
http://openrico.org-
Rico also provides graphical effects.
Json
http://json.org-
Hereby, major support for encoding and decoding data into the JSON data format (similar to
YAML
) is provided. behaviour.js
http://bennolan.com/behaviour/-
With
behaviour.js
, intelligent JavaScript handlers can be defined. cssQuery.js
http://dean.edwards.name/-
This library adds support for querying the DOM using CSS selectors.
Assembly of JS definitions
Jifty maintains a complete list of JS files to include. This list may be retrieved or set by the accessor Jifty->web->javascript_libs
. There should, However, rarely arise a situation to do that, because Jifty has already reserved two files that may get added to your application:
- app.js
-
Initially empty; put all JS functions you need to define here.
- app_behaviour.js
-
Reserved for defining behaviors for DOM objects using the
behaviour.js
library.
The assembly process of all JS definitions is done in Jifty::Web by the method include_javascript
.