mirror of
https://github.com/yu-i-i/overleaf-cep.git
synced 2026-05-23 17:19:37 +02:00
Admin Tools: Fix sorting
This commit is contained in:
@@ -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
|
||||
}
|
||||
|
||||
|
||||
@@ -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
|
||||
}
|
||||
|
||||
|
||||
@@ -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
|
||||
}
|
||||
|
||||
|
||||
@@ -8,7 +8,7 @@ export type Page = {
|
||||
}
|
||||
|
||||
export type Sort = {
|
||||
by: 'lastUpdated' | 'title' | 'deletedAt'
|
||||
by: 'lastUpdated' | 'title' | 'deletedAt' | 'owner'
|
||||
order: SortingOrder
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user