1
0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-19 18:26:46 +01:00

fix(web,a11y): remove autofocus from input fields (#8857)

* fix(web,a11y): remove autofocus from input field

The autofocus attribute can cause the keyboard to unexpectedly appear
for mobile users, and override any other focus management that the
application is doing programatically.

* fix: always include people filter
This commit is contained in:
Ben 2024-04-17 09:15:37 +00:00 committed by GitHub
parent f58886514d
commit 1071396a4a
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 13 additions and 11 deletions

View file

@ -28,9 +28,7 @@
<Icon path={mdiMagnify} size="24" /> <Icon path={mdiMagnify} size="24" />
</div> </div>
</button> </button>
<!-- svelte-ignore a11y-autofocus -->
<input <input
autofocus
class="w-full gap-2 bg-gray-200 dark:bg-immich-dark-gray dark:text-white" class="w-full gap-2 bg-gray-200 dark:bg-immich-dark-gray dark:text-white"
type="text" type="text"
{placeholder} {placeholder}

View file

@ -1,6 +1,6 @@
<script lang="ts"> <script lang="ts">
import { type PersonResponseDto } from '@immich/sdk'; import { type PersonResponseDto } from '@immich/sdk';
import { createEventDispatcher } from 'svelte'; import { createEventDispatcher, onMount } from 'svelte';
import ImageThumbnail from '../assets/thumbnail/image-thumbnail.svelte'; import ImageThumbnail from '../assets/thumbnail/image-thumbnail.svelte';
import Button from '../elements/buttons/button.svelte'; import Button from '../elements/buttons/button.svelte';
@ -9,11 +9,17 @@
export let suggestedPeople = false; export let suggestedPeople = false;
export let thumbnailData: string; export let thumbnailData: string;
let inputElement: HTMLInputElement;
const dispatch = createEventDispatcher<{ const dispatch = createEventDispatcher<{
change: string; change: string;
cancel: void; cancel: void;
input: void; input: void;
}>(); }>();
onMount(() => {
inputElement.focus();
});
</script> </script>
<div <div
@ -27,13 +33,12 @@
autocomplete="off" autocomplete="off"
on:submit|preventDefault={() => dispatch('change', name)} on:submit|preventDefault={() => dispatch('change', name)}
> >
<!-- svelte-ignore a11y-autofocus -->
<input <input
autofocus
class="w-full gap-2 bg-gray-100 dark:bg-gray-700 dark:text-white" class="w-full gap-2 bg-gray-100 dark:bg-gray-700 dark:text-white"
type="text" type="text"
placeholder="New name or nickname" placeholder="New name or nickname"
bind:value={name} bind:value={name}
bind:this={inputElement}
on:input={() => dispatch('input')} on:input={() => dispatch('input')}
/> />
<Button size="sm" type="submit">Done</Button> <Button size="sm" type="submit">Done</Button>

View file

@ -43,21 +43,20 @@
const filterPeople = (list: PersonResponseDto[], name: string) => { const filterPeople = (list: PersonResponseDto[], name: string) => {
const nameLower = name.toLowerCase(); const nameLower = name.toLowerCase();
return name ? list.filter((p) => p.name.toLowerCase().startsWith(nameLower)) : list; return name ? list.filter((p) => p.name.toLowerCase().includes(nameLower)) : list;
}; };
</script> </script>
{#await peoplePromise then people} {#await peoplePromise then people}
{#if people && people.length > 0} {#if people && people.length > 0}
{@const peopleList = showAllPeople ? filterPeople(people, name) : people.slice(0, numberOfPeople)} {@const peopleList = showAllPeople
? filterPeople(people, name)
: filterPeople(people, name).slice(0, numberOfPeople)}
<div id="people-selection" class="-mb-4"> <div id="people-selection" class="-mb-4">
<div class="flex items-center w-full justify-between gap-6"> <div class="flex items-center w-full justify-between gap-6">
<p class="immich-form-label py-3">PEOPLE</p> <p class="immich-form-label py-3">PEOPLE</p>
<SearchBar bind:name placeholder="Filter people" isSearching={false} />
{#if showAllPeople}
<SearchBar bind:name placeholder="Filter people" isSearching={false} />
{/if}
</div> </div>
<div class="flex -mx-1 max-h-64 gap-1 mt-2 flex-wrap overflow-y-auto immich-scrollbar"> <div class="flex -mx-1 max-h-64 gap-1 mt-2 flex-wrap overflow-y-auto immich-scrollbar">