mitgliederverwaltung/lib/mv_web
Simon a12888de2f
All checks were successful
continuous-integration/drone/push Build is passing
Improve member view table behavior+style, fix config settings (#493)
## Description of the implemented changes
The changes were:
- [x] Bugfixing
- [x] New Feature
- [ ] Breaking Change
- [x] Refactoring

This PR standardizes interactive table behavior and improves settings robustness.
It makes the new hover/focus-visible row highlight the default for clickable tables, keeps sticky first-column behavior configurable (and optimized for member selection UX), and tightens SMTP source-of-truth handling so ENV-based and UI-based configuration do not conflict.

## What has been changed?
- Refactored `CoreComponents.table` to expose interaction state via `data-row-interactive` and moved default row hover/focus styling to CSS.
- Made the new row highlight behavior (`hover` + `:has(:focus-visible)`) the default for clickable zebra tables.
- Kept sticky-first-column as an explicit table option and preserved sticky-specific selection accent behavior.
- Updated member overview table usage to the sticky-first-column mode and refined scrolling behavior (table scrollbar within container, not page-coupled).
- Adjusted table-related tests to validate the new interaction contract (attribute/CSS-driven behavior instead of legacy ring classes).
- Improved SMTP config handling:
  - clearer ENV-vs-Settings behavior (ENV-only mode when host env is set),
  - read-only and warning behavior in global settings UI when required env keys are missing,
  - updated related config/tests/docs.
- Updated docs and changelog (`CHANGELOG.md`, `DESIGN_GUIDELINES.md`, `CODE_GUIDELINES.md`, SMTP concept docs).
- Updated gettext catalogs (`default.pot`, `en`, `de`) for new/changed UI strings.

## Definition of Done
### Code Quality
- [x] No new technical depths
- [x] Linting passed
- [x] Documentation is added were needed

### Accessibility
- [x] New elements are properly defined with html-tags
- [x] Colour contrast follows WCAG criteria
- [x] Aria labels are added when needed
- [x] Everything is accessible by keyboard
- [x] Tab-Order is comprehensible
- [x] All interactive elements have a visible focus

### Testing
- [x] Tests for new code are written
- [x] All tests pass
- [ ] axe-core dev tools show no critical or major issues

## Additional Notes
- Branch includes 4 commits:
  - `fix: make sure smtp can be set either via env or ui`
  - `fix: make horizontal scrollbars sticky to bottom`
  - `docs: update changelog`
  - `feat: make checkbox column in member view sticky`
- Full fast suite passed (`mix test --exclude slow --exclude ui`): 2017 tests, 0 failures (plus expected non-failing warning logs in test output).
- Reviewer focus areas:
  1. **Cross-table UX consistency** after moving row interaction styling to component/CSS contract.
  2. **Sticky table behavior** (selection accent stripe, zebra background, keyboard focus visibility).
  3. **SMTP precedence and UI constraints** in global settings when ENV mode is active.
  4. **Regression risk in tests** that previously asserted ring-based row classes.
- No breaking API changes expected; behavior change is primarily visual/interaction-level and intentional.

Reviewed-on: #493
Co-authored-by: Simon <s.thiessen@local-it.org>
Co-committed-by: Simon <s.thiessen@local-it.org>
2026-05-08 15:04:53 +02:00
..
components Improve member view table behavior+style, fix config settings (#493) 2026-05-08 15:04:53 +02:00
controllers Improve oidc only mode (#474) 2026-03-16 19:09:07 +01:00
emails feat: prevent join requests with equal mail 2026-03-13 11:18:34 +01:00
helpers feat: add timezone handling 2026-03-13 18:22:12 +01:00
live Improve member view table behavior+style, fix config settings (#493) 2026-05-08 15:04:53 +02:00
member_live/index style: consistent badges with sufficient color contrast 2026-02-26 08:33:52 +01:00
plugs Improve oidc only mode (#474) 2026-03-16 19:09:07 +01:00
templates/emails feat: prevent join requests with equal mail 2026-03-13 11:18:34 +01:00
translations Merge branch 'main' into feat/299_plz 2026-02-24 11:44:19 +01:00
auth_overrides.ex feat: allow disabling registration 2026-03-13 16:40:39 +01:00
authorization.ex Authorization: document can_access_page? nil-safety 2026-02-03 17:16:09 +01:00
endpoint.ex refactor: address review comments for join view 2026-03-10 22:54:41 +01:00
error_helpers.ex refactor(web): extract format_ash_error to MvWeb.ErrorHelpers 2026-01-27 17:39:04 +01:00
gettext.ex Add generated starter app 2025-03-18 15:05:27 +01:00
join_notifier_impl.ex refactor: review remarks 2026-03-13 17:55:17 +01:00
join_rate_limit.ex refactor: address review comments for join view 2026-03-10 22:54:41 +01:00
live_helpers.ex Improve oidc only mode (#474) 2026-03-16 19:09:07 +01:00
live_user_auth.ex Fix Credo Design (AliasUsage): add aliases in lib 2026-03-04 16:21:15 +01:00
locale_controller.ex Locale: default German in dev/prod, English in test; validate locale in LocaleController 2026-02-24 15:13:10 +01:00
page_paths.ex feat: add approval ui for join requests 2026-03-11 02:04:03 +01:00
router.ex Improve oidc only mode (#474) 2026-03-16 19:09:07 +01:00
telemetry.ex Add generated starter app 2025-03-18 15:05:27 +01:00