4 <title>NINJA
» DOJO
» Dev. Manual
</title>
5 <style type=
"text/css">
7 font: normal normal
11pt 'Century Gothic', 'Lucida Grande', sans-serif
;
27 border: 2px dotted
#ddd;
33 border: 2px solid
#ccc;
53 border-right: 2px solid
#ccc;
54 border-bottom: 2px solid
#ccc;
62 .warning, .note, .critical {
70 a
, a:visited
, a:active
{
72 text-decoration: none
;
76 border-bottom: 1px dotted
#47f;
81 border: 2px solid
#fa7;
86 border: 2px solid
#7b7;
91 border: 2px solid
#c44;
94 .warning em, .note em, .critical em {
105 <h1>Ninja
» DOJO
» Dev. Manual
</h1>
108 This manual is about the new layout DOJO for the Nagios GUI NINJA.
112 DOJO aims to improve the structure, style and semantics of NINJA. Making the layout more dynamic, responsive and remove deprecated
113 ways of handling layout.
116 <div class=
"critical">
117 <em>(X) Critical:
</em>
118 DOJO will effectively make all custom skins unusable due to its enourmous changes to CSS, newly released skins for
119 ninja include default, classic and hello kitty.
122 <div class=
"critical">
123 <em>(X) Critical:
</em>
124 DOJO enforces the earlier experimental NOC behaviour on ninja, it cannot be switched back to the older sidebar menu.
134 The menus have move from a sidebar style to a drop-down behaviour (earlier experimental NOC) to give the data as much space as possible.
135 Some menu-items have been moved (host problems, service problems and unhandled problems) to a joined unhandled problems quickbar icon.
141 The quickbar contains some of the older top-bar icons and functionality, such as settings and refresh but has been extended with
142 a shortcut to unhandled problems and tactical overview. In ninja it also links to this documentation.
146 The aim with the quickbar is that all customers should be able to pin menu items, filtered/saved searches and external links to an icon
147 in the topbar for easy access to as much as possible based on their needs.
152 <h2>Install SASS
</h2>
156 All developers must install SASS and Compass since we don't keep the compiled CSS in the repos, only SASS.
161 In order to install sass and compass, run the make:
169 Or install the gems manually through
173 gem install sass (may need to sudo)
<br />
174 gem install compass (may need to sudo)
<br />
178 Once installed you can proceed to browse to the skin folder of your choice and type
179 in the compass command.
183 cd ~/
<repo
>/monitor/ninja/application/views/css/default
<br />
188 Compass will poll for any changes to the SASS and compile to CSS, if no CSS is found it will do a first time
189 compilation initially.
193 Or you can run the command make in the root directory after each SASS change
200 <div class=
"critical">
201 <em>(X) Critical:
</em><br />
203 <li>Never push CSS, only SASS
</li>
204 <li>Never change CSS only SASS
</li>
216 SASS is a white-space sensitive indentation hierarchy language that does not use curly brackets or semi-colons as in regular CSS.
217 It has support for inheritance, nesting, variables and
"mixins".
222 <h3>SASS quick guide
</h3>
229 Variables in SASS are denoted using the dollar-sign and are assigned using the colon, they contain CSS values, i.e. not pure
230 numbers and text but type-specific values and can be used in place of any comparative value type.
234 $fontF:
"Verdana"<br />
239 font: $fontS $fontW normal $fontF
<br />
247 In regular CSS there is no nesting, if we want to declare a style to a parent, its children and their children, we have to create
248 three independent scopes
253 properties...
<br />
255 .container .content {
<br />
256 properties...
<br />
258 .container .content span {
<br />
259 properties...
<br />
264 In SASS we have a nested way of doing this using the indentation hierarchy
269 properties...
<br /><br />
270 .content
<br />
271 properties...
<br /><br />
272 span
<br />
273 properties...
<br />
282 SASS takes CSS nesting to another level, allowing sub-properties to be declared as nests, here we want to declare font properties
288 font
<br />
289 family:
"Verdana"<br />
290 size:
12pt
<br />
291 weight: normal
<br />
292 style: italic
<br />
300 Sort of like functions that can take
0 or more arguments and return a set of (possibly dynamic) CSS properties.
305 font
<br />
306 family:
"Verdana"<br />
307 size:
12pt
<br />
308 weight: normal
<br />
309 style: italic
<br />
315 In and of itself it does nothing, if it is not used it will
<b>not be in the resulting CSS
</b>, but if we want this font style to be used
316 in all table cells, p tags and spans but with different colors we use it as such.
321 @include demo
<br />
322 color: #
444<br />
324 @include demo
<br />
325 color: #
666<br />
327 @include demo
<br />
328 color: #
888<br />
332 The reason for using mixins and not only inherited selectors is that mixins can take arguments and return dynamic sets of properties.
333 Here we declare a global font and size but we want the selector using the mixin to determine the color and style of the font.
338 $font:
"Verdana"<br />
341 @mixin demo($color, $style)
<br />
342 font
<br />
343 family: $font
<br />
344 size: $size
<br />
345 weight: normal
<br />
346 style: $style
<br />
347 color: $color
352 @include demo(#
444, normal)
<br />
354 @include demo(#
666, oblique)
<br />
356 @include demo(#
888, italic)
<br />
364 Inheritance is used in much the same way as mixins except that they take existing selectors instead of the compilation level
365 mixin definition. Here we declare a p tag style and a span tag that inherits the style of the p tag and declares its own.
370 Both the p and span selectors
<b>will be contained in the resulting stylesheet
</b>!
375 font
<br />
376 family:
"Verdana"<br />
377 size:
12pt
<br />
378 weight: normal
<br />
379 style: italic
<br />
382 @extend p
<br />
383 color: #
567
390 Read more on SASS
<a href=
"www.sass-lang.com">website
</a>, and more about compass and its support mixins on
<a href=
"compass-style.com">theirs
</a>.
393 <h3>Configuration
</h3>
396 The new CSS is generated using the SASS 'pre-processor', giving it far more power while developing.
397 One of these powers is variables, and with variables DOJO includes a configuration file, found under
402 In this file you can set general configurations, such as the header height, fonts, different colors and more.
405 <h3>All img tag icons should be replaced by sprite spans
</h3>
408 Ninja now uses CSS sprites instead of independent icon images, a first glance test lowered the request count from
94 -
> 36 and uncached
409 load-time by
1.4 seconds. Icon images can be replaced everywhere an icon is used from the icon folders and is a PNG image.
412 <div class=
"warning">
413 <em>(!) Warning:
</em>
414 GIF icons cannot be included in spritesheets by compass, use the old icon images for icons, gif icons will be updated to PNG.
418 In order to utilize this development feature all img tags relating to icons should move from the old e.g.
422 echo html::image(
<br />
423 $this-
>add_path('icons/
12x12/shield-'.strtolower($row['status']).'.png'),
<br />
424 array(
<br />
425 'title' =
> $row['status'], 'alt' =
> $row['status'],
<br />
426 'style' =
> 'margin-bottom: -
2px'
<br />
436 echo '
<span
class=
"icon-12 x12-'.
437 <br /> strtolower($row['status']).'" '.
438 <br /> '
title=
"'.$row['status'].'"></span
>';
<br /><br />
439 // The style is omitted because inline style is no-no
443 Resulting in, maybe something like this
447 <span
class=
"icon-12 x12-up" title=
"up"></span
>';
<br />
451 The class is broken down to
456 <td>icon-
12</td><td>x12-
</td><td>up
</td>
459 <td>This is an icon and it is of size
12x12
</td>
460 <td>It is part of the spritesheet x12 (like all
12x12 icons)
</td>
461 <td>And it's the one formerly named up (up.png)
</td>
466 The class for icons such as shield-not-disabled would hence become:
471 <td>icon-
16</td><td>x16-
</td><td>shield-not-disabled
</td>
474 <td>This is an icon and it is of size
16x16
</td>
475 <td>It is part of the spritesheet x16 (like all
16x16 icons)
</td>
476 <td>And it's the one formerly named shield-not-disabled (shield-not-disabled.png)
</td>
480 <h3>Global Auxiliary Selectors
</h3>
484 Sets the opacity of the element to
0.4 by default and nothing else, the amount it sets can be configured in the SASS configuration file.
489 Floats the elements to the right and nothing else. Use .clear to restore.
494 Floats the elements to the left and nothing else. Use .clear to restore.
499 Clears both on the element and nothing else. Always use after floated elements to restore normal flow.
502 <h4>.none (legacy .white)
</h4>
504 Makes the element completely transparent by setting
0 opacity.
507 <h4>.nullify (legacy .white)
</h4>
509 Removes a lot of things, this one is already in use by all tables by default.
512 <li>background: transparent
</li>
513 <li>border-spacing:
0</li>
514 <li>vertical-align: top
</li>
515 <li>outline: none
</li>
516 <li>border: none
</li>