Files
isparkclaw-webui/tests/test_sprint50.py
nesquena-hermes c68420d9aa fix(ui): constrain slash autocomplete width to composer — v0.50.98 (closes #633) (#750)
## Summary

Rebased-on-behalf of @franksong2702 (originally PR #728 — had CHANGELOG conflict after #747 merged).

Moves `#cmdDropdown` from outside `composer-box` to inside it, so the `position:absolute` anchor is scoped to the composer width rather than the full chat panel. CSS updated to use `bottom:calc(100% + 4px)` and `width:auto;max-width:100%` for clean upward positioning.

Closes #633

## Changes
- `static/index.html` — moved `cmd-dropdown` div inside `composer-box`
- `static/style.css` — updated `.cmd-dropdown` positioning (remove `margin-bottom`, use `bottom:calc(100% + 4px)`, add `width:auto;max-width:100%`)
- `tests/test_sprint50.py` — 2 new structural tests verifying DOM position and CSS rules

## Tests
1493 passed, 1 warning (2 new tests added)

**Original author:** @franksong2702
2026-04-19 23:17:00 -07:00

40 lines
1.3 KiB
Python

"""Tests for small UX regressions fixed after v0.50.96.
Covers:
- #633: slash command autocomplete dropdown should be constrained to the
composer width rather than the full chat panel width.
"""
import pathlib
REPO = pathlib.Path(__file__).parent.parent
def read(rel):
return (REPO / rel).read_text()
def test_cmd_dropdown_moved_inside_composer_box():
src = read("static/index.html")
composer_start = src.index('<div class="composer-box" id="composerBox">')
dropdown_idx = src.index('<div class="cmd-dropdown" id="cmdDropdown"></div>')
textarea_idx = src.index('<textarea id="msg"')
assert composer_start < dropdown_idx < textarea_idx, (
"cmdDropdown should live inside composerBox, before the textarea, so its "
"absolute positioning is scoped to the composer instead of the full chat panel"
)
def test_cmd_dropdown_css_scoped_to_composer_width():
src = read("static/style.css")
assert ".cmd-dropdown{display:none;position:absolute;left:0;right:0;" in src, (
"cmdDropdown should be absolutely positioned with left/right anchors"
)
assert "width:auto;max-width:100%;" in src, (
"cmdDropdown width should be constrained to the positioned composer ancestor"
)
assert "bottom:calc(100% + 4px);" in src, (
"cmdDropdown should sit just above the composer box"
)