7702560b12
* feat: unassign person faces * multiple improvements * chore: regenerate api * feat: improve face interactions in photos * fix: tests * fix: tests * optimize * fix: wrong assignment on complex-multiple re-assignments * fix: thumbnails with large photos * fix: complex reassign * fix: don't send people with faces * fix: person thumbnail generation * chore: regenerate api * add tess * feat: face box even when zoomed * fix: change feature photo * feat: make the blue icon hoverable * chore: regenerate api * feat: use websocket * fix: loading spinner when clicking on the done button * fix: use the svelte way * fix: tests * simplify * fix: unused vars * fix: remove unused code * fix: add migration * chore: regenerate api * ci: add unit tests * chore: regenerate api * feat: if a new person is created for a face and the server takes more than 15 seconds to generate the person thumbnail, don't wait for it * reorganize * chore: regenerate api * feat: global edit * pr feedback * pr feedback * simplify * revert test * fix: face generation * fix: tests * fix: face generation * fix merge * feat: search names in unmerge face selector modal * fix: merge face selector * simplify feature photo generation * fix: change endpoint * pr feedback * chore: fix merge * chore: fix merge * fix: tests * fix: edit & hide buttons * fix: tests * feat: show if person is hidden * feat: rename face to person * feat: split in new panel * copy-paste-error * pr feedback * fix: feature photo * do not leak faces * fix: unmerge modal * fix: merge modal event * feat(server): remove duplicates * fix: title for image thumbnails * fix: disable side panel when there's no face until next PR --------- Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
37 lines
1.2 KiB
TypeScript
37 lines
1.2 KiB
TypeScript
import type { PersonResponseDto } from '@api';
|
|
|
|
export const searchNameLocal = (
|
|
name: string,
|
|
people: PersonResponseDto[],
|
|
slice: number,
|
|
personId?: string,
|
|
): PersonResponseDto[] => {
|
|
return name.indexOf(' ') >= 0
|
|
? people
|
|
.filter((person: PersonResponseDto) => {
|
|
if (personId) {
|
|
return person.name.toLowerCase().startsWith(name.toLowerCase()) && person.id !== personId;
|
|
} else {
|
|
return person.name.toLowerCase().startsWith(name.toLowerCase());
|
|
}
|
|
})
|
|
.slice(0, slice)
|
|
: people
|
|
.filter((person: PersonResponseDto) => {
|
|
const nameParts = person.name.split(' ');
|
|
if (personId) {
|
|
return (
|
|
nameParts.some((splitName) => splitName.toLowerCase().startsWith(name.toLowerCase())) &&
|
|
person.id !== personId
|
|
);
|
|
} else {
|
|
return nameParts.some((splitName) => splitName.toLowerCase().startsWith(name.toLowerCase()));
|
|
}
|
|
})
|
|
.slice(0, slice);
|
|
};
|
|
|
|
export const getPersonNameWithHiddenValue = (name: string, isHidden: boolean) => {
|
|
return `${name ? name + (isHidden ? ' ' : '') : ''}${isHidden ? '(hidden)' : ''}`;
|
|
};
|