Admin Tools: Fix sorting

This commit is contained in:
yu-i-i
2026-01-30 00:23:02 +01:00
parent 91e97dbdf2
commit ada07fb779
4 changed files with 38 additions and 30 deletions

View File

@@ -111,16 +111,23 @@ function _applyFilters(projects, filters) {
function _sortAndPaginate(projects, sort, page) {
if (
(sort.by && !['lastUpdated', 'title', 'deletedAt'].includes(sort.by)) ||
(sort.by && !['lastUpdated', 'title', 'deletedAt', 'owner'].includes(sort.by)) ||
(sort.order && !['asc', 'desc'].includes(sort.order))
) {
throw new OError('Invalid sorting criteria', { sort })
}
const sortedProjects = _.orderBy(
projects,
[sort.by || 'lastUpdated'],
[sort.order || 'desc']
)
// sorting by owner is not implemented, it is mot needed
const sortedProjects =
sort.by === 'title'
? [...projects].sort((a, b) =>
(a.name ?? '\uffff').localeCompare(b.name ?? '\uffff')
)
: _.orderBy(
projects,
[sort.by || 'lastUpdated'],
[sort.order || 'desc']
)
return sortedProjects
}

View File

@@ -266,11 +266,23 @@ function _sortAndPaginate(users, sort, page) {
throw new OError('Invalid sorting criteria', { sort })
}
const sortedUsers = _.orderBy(
users,
[sort.by || 'signUpDate'],
[sort.order || 'desc']
)
const LAST = '\uffff'
const sortedUsers =
sort.by === 'name'
? [...users].sort((a, b) =>
(a.lastName ?? LAST).localeCompare(b.lastName ?? LAST, undefined, { sensitivity: 'base' }) ||
(a.firstName ?? LAST).localeCompare(b.firstName ?? LAST, undefined, { sensitivity: 'base' }) ||
(a.email ?? LAST).localeCompare(b.email ?? LAST, undefined, { sensitivity: 'base' })
)
: _.orderBy(
users,
[u => {
const key = sort.by || 'signUpDate'
const value = u[key]
return typeof value === 'string' ? (value ?? LAST).toLowerCase() : value
}],
[sort.order || 'desc']
)
return sortedUsers
}

View File

@@ -5,7 +5,6 @@ import {
useContext,
useEffect,
useMemo,
useRef,
useState,
} from 'react'
import {
@@ -130,7 +129,6 @@ export function UserListProvider({ children }: UserListProviderProps) {
'user-list-filter',
'all'
)
const prevSortRef = useRef<Sort>(sort)
const [searchText, setSearchText] = useState('')
@@ -160,11 +158,11 @@ export function UserListProvider({ children }: UserListProviderProps) {
}, [prefetchedUsersBlob, runAsync])
const addUserToView = useCallback((newUser: Partial<User>) => {
setLoadedUsers(prev => sortUsers([newUser, ...prev], prevSortRef.current))
setLoadedUsers(prev => [newUser as User, ...prev])
}, [])
const processedUsers = useMemo(() => {
let users = [...loadedUsers]
let users = loadedUsers
if (searchText.length) {
const searchTextLowerCase = searchText.toLowerCase()
@@ -177,11 +175,7 @@ export function UserListProvider({ children }: UserListProviderProps) {
users = arrayFilter(users, filters[filter])
if (prevSortRef.current !== sort) {
users = sortUsers(users, sort)
}
return users
return sortUsers(users, sort)
}, [loadedUsers, searchText, filter, sort])
const visibleUsers = useMemo(() => {
@@ -198,10 +192,6 @@ export function UserListProvider({ children }: UserListProviderProps) {
MAX_USER_PER_PAGE
)
useEffect(() => {
prevSortRef.current = sort
}, [sort])
const selfVisibleCount = useMemo(() => {
return visibleUsers.some(u => u.id === selfId) ? 1 : 0
}, [visibleUsers])
@@ -238,8 +228,8 @@ export function UserListProvider({ children }: UserListProviderProps) {
)
const selectedUsers = useMemo(() => {
return visibleUsers.filter(user => selectedUserIds.has(user.id))
}, [selectedUserIds, visibleUsers])
return loadedUsers.filter(user => selectedUserIds.has(user.id))
}, [selectedUserIds, loadedUsers])
const selectOrUnselectAllUsers = useCallback(
(checked: any) => {
@@ -258,7 +248,7 @@ export function UserListProvider({ children }: UserListProviderProps) {
}
return selectedUserIds
})
} ,
},
[visibleUsers]
)
@@ -356,7 +346,7 @@ export function UserListProvider({ children }: UserListProviderProps) {
)
if (!loadedUsers || loadedUsers.length === 0) {
return null
return null
}
return (
@@ -377,4 +367,3 @@ export function useUserListContext() {
}
return context
}

View File

@@ -8,7 +8,7 @@ export type Page = {
}
export type Sort = {
by: 'lastUpdated' | 'title' | 'deletedAt'
by: 'lastUpdated' | 'title' | 'deletedAt' | 'owner'
order: SortingOrder
}