move empty/undefined sortings always to the alphabet's end

This commit is contained in:
Maximilian Krambach 2019-01-19 10:26:56 +01:00 committed by Emanuel Schütze
parent 1cdeb3bcb8
commit 91dec2370b
1 changed files with 8 additions and 2 deletions

View File

@ -209,13 +209,19 @@ export abstract class SortListService<V extends BaseViewModel> {
if (typeof firstProperty !== typeof secondProperty) {
// undefined/null items should always land at the end
if (!firstProperty) {
return ascending ? 1 : -1;
return 1;
} else if (!secondProperty) {
return ascending ? -1 : 1;
return -1;
} else {
throw new TypeError('sorting of items failed because of mismatched types');
}
} else {
if (
(firstProperty === null || firstProperty === undefined) &&
(secondProperty === null || secondProperty === undefined)
) {
return 1;
}
switch (typeof firstProperty) {
case 'boolean':
if (firstProperty === false && secondProperty === true) {