mirror of
https://github.com/go-gitea/gitea.git
synced 2026-02-22 13:15:23 +01:00
fix(shortcut): Address PR review feedback
- Use `target.isContentEditable` instead of `[contenteditable="true"]` selector to properly detect all contenteditable elements - Use `CSS.escape()` for keyboard shortcut key to handle special characters - Rename scoped CSS class to `.repo-file-search-shortcut-hint` to avoid conflict with global `.repo-search-shortcut-hint` styles
This commit is contained in:
parent
663612cdab
commit
a5480131b5
@ -154,7 +154,7 @@ watch([searchQuery, filteredFiles], async () => {
|
||||
@input="handleSearchInput" @keydown="handleKeyDown"
|
||||
@focus="isInputFocused = true" @blur="isInputFocused = false"
|
||||
>
|
||||
<kbd v-show="!searchQuery && !isInputFocused" class="repo-search-shortcut-hint">T</kbd>
|
||||
<kbd v-show="!searchQuery && !isInputFocused" class="repo-file-search-shortcut-hint">T</kbd>
|
||||
</div>
|
||||
|
||||
<Teleport to="body">
|
||||
@ -202,7 +202,7 @@ watch([searchQuery, filteredFiles], async () => {
|
||||
border-color: var(--color-primary) !important;
|
||||
}
|
||||
|
||||
.repo-search-shortcut-hint {
|
||||
.repo-file-search-shortcut-hint {
|
||||
position: absolute;
|
||||
right: 10px;
|
||||
top: 50%;
|
||||
@ -219,7 +219,7 @@ watch([searchQuery, filteredFiles], async () => {
|
||||
}
|
||||
|
||||
/* Hide kbd when input is focused so it doesn't interfere with focus border */
|
||||
.repo-file-search-input-wrapper input:focus + .repo-search-shortcut-hint {
|
||||
.repo-file-search-input-wrapper input:focus + .repo-file-search-shortcut-hint {
|
||||
display: none;
|
||||
}
|
||||
|
||||
|
||||
@ -69,9 +69,9 @@ function attachGlobalEvents() {
|
||||
// Elements declare their keyboard shortcuts via data-global-keyboard-shortcut attribute.
|
||||
// When a matching key is pressed, the element is focused (for inputs) or clicked (for buttons/links).
|
||||
document.addEventListener('keydown', (e: KeyboardEvent) => {
|
||||
// Don't trigger shortcuts when typing in input fields
|
||||
// Don't trigger shortcuts when typing in input fields or contenteditable areas
|
||||
const target = e.target as HTMLElement;
|
||||
if (target.matches('input, textarea, select, [contenteditable="true"]')) {
|
||||
if (target.matches('input, textarea, select') || target.isContentEditable) {
|
||||
return;
|
||||
}
|
||||
|
||||
@ -82,7 +82,8 @@ function attachGlobalEvents() {
|
||||
|
||||
// Find element with matching shortcut (case-insensitive)
|
||||
const key = e.key.toLowerCase();
|
||||
const elem = document.querySelector<HTMLElement>(`[data-global-keyboard-shortcut="${key}"]`);
|
||||
const escapedKey = CSS.escape(key);
|
||||
const elem = document.querySelector<HTMLElement>(`[data-global-keyboard-shortcut="${escapedKey}"]`);
|
||||
if (!elem) return;
|
||||
|
||||
e.preventDefault();
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user