Wiki source code of Special CSS Classes
Version 15.1 by Lucas Charpentier (Sereza7) on 2024/01/16
Show last authors
author | version | line-number | content |
---|---|---|---|
1 | XWiki has some special classes that are used in certain conditions to assure consistency and enhance functionality. The following classes are defined at least starting with [[the Colibri Skin>>extensions:Extension.Colibri Skin]]: | ||
2 | |||
3 | {{toc/}} | ||
4 | |||
5 | = A. General classes = | ||
6 | |||
7 | * **##.hidden##** | ||
8 | use to 'display: none' elements | ||
9 | |||
10 | * **##.sr-only##** | ||
11 | use to hide elements visually but keep them visible semantically {{footnote}}https://dev.xwiki.org/xwiki/bin/view/Community/CodeStyle/XhtmlCssCodeStyle/Properly%20hiding%20elements/{{/footnote}} | ||
12 | |||
13 | * **##.invisible##** | ||
14 | use to 'visibility: hidden' elements | ||
15 | |||
16 | * **##.clearfloats##** | ||
17 | use to clear floats when using floated containers, in order to keep the parent's layout correct | ||
18 | |||
19 | * **##.separator##** | ||
20 | use to contain separators ( {{html}}·{{/html}} , | ) | ||
21 | used in #document-info and blog .entry-footer | ||
22 | |||
23 | * **##.itemCount##** | ||
24 | use to contain numeric values that describe quantitative information about an item | ||
25 | used in #docExtraTabs, #document-info, .blog-category-level | ||
26 | example: Comments (1) | ||
27 | |||
28 | * **##.noitems##** | ||
29 | use to contain empty state messages | ||
30 | used in #docextrapanes | ||
31 | example: 'No comments for this document', 'No attachments for this document' | ||
32 | |||
33 | * **##.icon##** | ||
34 | use for icon buttons ([[example>>xwiki:Documentation.DevGuide.FrontendResources.StandardIconClasses||anchor="iconClass"]]) | ||
35 | used in .icon.rss in 'Quick Links' panel | ||
36 | |||
37 | * **##.hasIcon##** | ||
38 | use for elements that also have a background-icon attached ([[example>>xwiki:Documentation.DevGuide.FrontendResources.StandardIconClasses||anchor="hasIconClass"]]) | ||
39 | works in pair with other classes that specify the icon that will be used (ex: .iconRSS, .tmEdit, .etc) | ||
40 | used in menus | ||
41 | * **##.hasIcon##** | ||
42 | use for avatar icons. | ||
43 | |||
44 | * **##.loading##** | ||
45 | sets an animated GIF as being the background image (center aligned) of the element | ||
46 | generally used on Ajax requests in order to express the loading status | ||
47 | example of usage: on loading each of the Annotations, Comments, Attachments, History and Informations tabs | ||
48 | |||
49 | * **##.column##** + (**##.full##** | **##.half##** | **##.third##**) | ||
50 | classes for generic (1|2|3) column layout | ||
51 | |||
52 | * **##.drawer-opener##** | ||
53 | {{version since="XWiki 15.10"}} Used with a proper value of `aria-controls`, allows to trigger the opening of a drawer element. [[Details on creating a drawer>>xwiki:Documentation.DevGuide.FrontendResources.Drawer]] {{/version}} | ||
54 | |||
55 | = B. Classes used for Form elements = | ||
56 | |||
57 | == B1. Buttons containers == | ||
58 | |||
59 | * **##.buttonwrapper##** | ||
60 | use as an external container for buttons (required for Toucan skin) | ||
61 | |||
62 | * **##.buttonwrapper .button##** | ||
63 | use ##.button## on ##input## or ##a## elements to display as buttons | ||
64 | |||
65 | * **##.secondary.button##** | ||
66 | use for secondary actions, like ##cancel## | ||
67 | |||
68 | * **##.icon-button##** | ||
69 | ** **##.icon-button.add-button##** | ||
70 | ** **##.icon-button.remove-button##** | ||
71 | use for small icon actions, like ##add## and ##remove## ([[example>>xwiki:Documentation.DevGuide.FrontendResources.StandardIconClasses||anchor="iconButtonClass"]]) | ||
72 | |||
73 | * **##.button.disabled##** | ||
74 | use to display a button in it's disabled state | ||
75 | |||
76 | == B2. Behavior classnames == | ||
77 | |||
78 | * **##.withTip##** | ||
79 | introduced in [[XWIKI-4163>>https://jira.xwiki.org/browse/XWIKI-4163]] | ||
80 | description: automatically hides and reinserts the default text for input fields, acting as a tip. | ||
81 | warning: will be replaced by the ##placeholder## attribute introduced in HTML5 | ||
82 | |||
83 | * **##.useTitleAsTip##** | ||
84 | introduced in 5.1 Milestone 1 | ||
85 | description: when ##.withTip## is applied, use the value of the title attribute as the tip (i.e. the text displayed in the text input when it's empty); this is useful when the initial value of the text input is different than the tip (place-holder), e.g. a search input might have as initial value the submitted search query, but you still want to display a tip when the user clears the query. | ||
86 | warning: will be replaced by the ##placeholder## attribute introduced in HTML5 | ||
87 | |||
88 | * **##.suggestDocuments##** | ||
89 | introduced in [[XWIKI-5301>>https://jira.xwiki.org/browse/XWIKI-5301]] | ||
90 | description: all input fields with classname suggestDocuments will receive an autocomplete control suggesting document names. | ||
91 | |||
92 | * **##.suggestSpaces##** | ||
93 | introduced in [[XWIKI-5657>>https://jira.xwiki.org/browse/XWIKI-5657]] (XWiki 2.6 RC2) | ||
94 | description: all input fields with classname suggestSpaces will receive an autocomplete control suggesting space names. | ||
95 | |||
96 | * --**##.suggestUsers##**-- | ||
97 | introduced in [[XWIKI-5649>>https://jira.xwiki.org/browse/XWIKI-5649]] (XWiki 2.6 RC2) | ||
98 | {{warning}}deprecated since XWiki 10.6RC1, use ##suggest-users## instead{{/warning}} | ||
99 | description: all input fields with classname suggestUsers will receive an autocomplete control suggesting document names of documents that contains user objects | ||
100 | |||
101 | * --**##.suggestGroups##**-- | ||
102 | introduced in [[XWIKI-5649>>ttp://jira.xwiki.org/browse/XWIKI-5649]] (XWiki 2.6 RC2) | ||
103 | {{warning}}deprecated since XWiki 10.6RC1, use ##suggest-groups## instead{{/warning}} | ||
104 | description: all input fields with classname suggestGroups will receive an autocomplete control suggesting document names of documents that contains group objects | ||
105 | |||
106 | * **##.suggested##** | ||
107 | description: blocks normal browser autocomplete and initializes the suggest object early instead of waiting for the field to be focused (if the suggests is declared on focus). | ||
108 | |||
109 | * **##.maximizable##** | ||
110 | introduced in [[XWIKI-5660>>https://jira.xwiki.org/browse/XWIKI-5660]] (XWiki 2.6 RC2) description: offers a link for users to maximize the element on which this classname is applied, | ||
111 | making it possible to view that element in fullscreen mode. | ||
112 | {{warning}}Needs to be used together with a skinx call to the ##uicomponents/widgets/fullScreen.js## script{{/warning}} | ||
113 | |||
114 | = Classes for the responsiveness = | ||
115 | |||
116 | With [[Flamingo>>extensions:Extension.Flamingo Skin]], you can use [[Bootstrap classes>>http://getbootstrap.com/]] plus some XWiki specific classes: | ||
117 | |||
118 | * **##.responsive-table##** | ||
119 | introduced in [[XWIKI-11576>>https://jira.xwiki.org/browse/XWIKI-11576]] (XWiki 6.4M2 & 6.2.5) description: make a table responsible to the screen-size. To use it, just add the ".responsive-table" class to you table, be sure you have proper <thead> and <tbody> tags in it, and put the title of the each column in the "data-title" attribute of every cell. | ||
120 | Example:((( | ||
121 | {{code language="html"}} | ||
122 | <table class="responsive-table"> | ||
123 | <thead> | ||
124 | <tr> | ||
125 | <th>Name</th> | ||
126 | <th>Age</th> | ||
127 | </tr> | ||
128 | </thead> | ||
129 | <tbody> | ||
130 | <tr> | ||
131 | <td data-title="Name">John Smith</td> | ||
132 | <td data-title="Age">42</td> | ||
133 | </tr> | ||
134 | </tbody> | ||
135 | </table> | ||
136 | {{/code}} | ||
137 | ))) | ||
138 | |||
139 | = Further References = | ||
140 | |||
141 | * XWiki's structure is defined in templates that generate specific layout classes (.main, #mainContentArea, etc) | ||
142 | ** [[XWiki CSS Layout>>xwiki:Documentation.DevGuide.Tutorials.Skins.CSSLayout]] //(outdated)// | ||
143 | * XWiki provides by default a [[list of Skins>>xwiki:Documentation.UserGuide.Features.Skins]], each with its own characteristics | ||
144 | ** [[XWiki Albatross CSS Files>>xwiki:Documentation.DevGuide.Tutorials.Skins.CSS files]] //(deprecated)// | ||
145 | |||
146 | = Special CSS Classes = | ||
147 | |||
148 | * When writing CSS code for XWiki there are some [[code style rules>>dev:Community.XhtmlCssCodeStyle]] that need to be followed in order to assure consistency and quality. | ||
149 | |||
150 | {{putFootnotes/}} |