Skip to content

Commit e7be610

Browse files
authored
Improve frontend guidelines (#23007)
Some were out-dated, some are added.
1 parent dc9cebd commit e7be610

File tree

2 files changed

+43
-8
lines changed

2 files changed

+43
-8
lines changed

docs/content/doc/developers/guidelines-frontend.en-us.md

+13-5
Original file line numberDiff line numberDiff line change
@@ -39,12 +39,20 @@ We recommend [Google HTML/CSS Style Guide](https://google.github.io/styleguide/h
3939
### Gitea specific guidelines:
4040

4141
1. Every feature (Fomantic-UI/jQuery module) should be put in separate files/directories.
42-
2. HTML ids and classes should use kebab-case.
42+
2. HTML ids and classes should use kebab-case, it's preferred to contain 2-3 feature related keywords.
4343
3. HTML ids and classes used in JavaScript should be unique for the whole project, and should contain 2-3 feature related keywords. We recommend to use the `js-` prefix for classes that are only used in JavaScript.
44-
4. jQuery events across different features could use their own namespaces if there are potential conflicts.
45-
5. CSS styling for classes provided by frameworks should not be overwritten. Always use new class-names with 2-3 feature related keywords to overwrite framework styles.
46-
6. The backend can pass complex data to the frontend by using `ctx.PageData["myModuleData"] = map[]{}`
47-
7. Simple pages and SEO-related pages use Go HTML Template render to generate static Fomantic-UI HTML output. Complex pages can use Vue3.
44+
4. CSS styling for classes provided by frameworks should not be overwritten. Always use new class names with 2-3 feature related keywords to overwrite framework styles. Gitea's helper CSS classes in `helpers.less` could be helpful.
45+
5. The backend can pass complex data to the frontend by using `ctx.PageData["myModuleData"] = map[]{}`, but do not expose whole models to the frontend to avoid leaking sensitive data.
46+
6. Simple pages and SEO-related pages use Go HTML Template render to generate static Fomantic-UI HTML output. Complex pages can use Vue3.
47+
7. Clarify variable types, prefer `elem.disabled = true` instead of `elem.setAttribute('disabled', 'anything')`, prefer `$el.prop('checked', var === 'yes')` instead of `$el.prop('checked', var)`.
48+
8. Use semantic elements, prefer `<button class="ui button">` instead of `<div class="ui button">`.
49+
9. Avoid unnecessary `!important` in CSS, add comments to explain why it's necessary if it can't be avoided.
50+
51+
### Accessibility / ARIA
52+
53+
In history, Gitea heavily uses Fomantic UI which is not an accessibility-friendly framework.
54+
Gitea uses some patches to make Fomantic UI more accessible (see the `aria.js` and `aria.md`),
55+
but there are still many problems which need a lot of work and time to fix.
4856

4957
### Framework Usage
5058

web_src/js/features/aria.md

+30-3
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,35 @@
11
**This document is used as aria/a11y reference for future developers**
22

3+
# Checkbox
4+
5+
## Accessibility-friendly Checkbox
6+
7+
The ideal checkboxes should be:
8+
9+
```html
10+
<label><input type="checkbox"> ... </label>
11+
```
12+
13+
However, related styles aren't supported (not implemented) yet, so at the moment, almost all the checkboxes are still using Fomantic UI checkbox.
14+
15+
## Fomantic UI Checkbox
16+
17+
```html
18+
<div class="ui checkbox">
19+
<input type="checkbox"> <!-- class "hidden" will be added by $.checkbox() -->
20+
<label>...</label>
21+
</div>
22+
```
23+
24+
Then the JS `$.checkbox()` should be called to make it work with keyboard and label-clicking, then it works like the ideal checkboxes.
25+
26+
There is still a problem: Fomantic UI checkbox is not friendly to screen readers, so we add IDs to all the Fomantic UI checkboxes automatically by JS.
27+
28+
# Dropdown
29+
330
## ARIA Dropdown
431

5-
There are different solutions:
32+
There are different solutions:
633
* combobox + listbox + option
734
* menu + menuitem
835

@@ -27,7 +54,7 @@ At the moment, `menu + menuitem` seems to work better with Fomantic UI Dropdown,
2754
<div class="ui dropdown"> <!-- focused here, then it's not perfect to use aria-activedescendant to point to the menu item -->
2855
<input type="hidden" ...>
2956
<div class="text">Default</div>
30-
<div class="menu transition hidden" tabindex="-1">
57+
<div class="menu" tabindex="-1"> <!-- "transition hidden|visible" classes will be added by $.dropdown() and when the dropdown is working -->
3158
<div class="item active selected">Default</div>
3259
<div class="item">...</div>
3360
</div>
@@ -38,7 +65,7 @@ At the moment, `menu + menuitem` seems to work better with Fomantic UI Dropdown,
3865
<input type="hidden" ...>
3966
<input class="search" autocomplete="off" tabindex="0"> <!-- focused here -->
4067
<div class="text"></div>
41-
<div class="menu transition visible" tabindex="-1">
68+
<div class="menu" tabindex="-1"> <!-- "transition hidden|visible" classes will be added by $.dropdown() and when the dropdown is working -->
4269
<div class="item selected">...</div>
4370
<div class="item">...</div>
4471
</div>

0 commit comments

Comments
 (0)