mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-07 22:15:45 +01:00
move comparators from scm-review-plugin to ui-components
This commit is contained in:
126
scm-ui/ui-components/src/comparators.test.ts
Normal file
126
scm-ui/ui-components/src/comparators.test.ts
Normal file
@@ -0,0 +1,126 @@
|
|||||||
|
import { byKey, byValueLength, byNestedKeys } from "./comparators";
|
||||||
|
|
||||||
|
const createObject = (key: string, value?: string) => {
|
||||||
|
return {
|
||||||
|
[key]: value
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
const createObjects = (key: string, values: Array<string | undefined>) => {
|
||||||
|
return values.map(v => createObject(key, v));
|
||||||
|
};
|
||||||
|
|
||||||
|
describe("key comparator tests", () => {
|
||||||
|
it("should sort array", () => {
|
||||||
|
const array = createObjects("key", ["z", "a", "y", "b"]);
|
||||||
|
array.sort(byKey("key"));
|
||||||
|
expect(array).toEqual(createObjects("key", ["a", "b", "y", "z"]));
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should not fail if value is undefined", () => {
|
||||||
|
const array = createObjects("key", ["z", undefined, "a"]);
|
||||||
|
array.sort(byKey("key"));
|
||||||
|
expect(array).toEqual(createObjects("key", ["a", "z", undefined]));
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should not fail if key is undefined", () => {
|
||||||
|
const array = createObjects("key", ["a"]);
|
||||||
|
array.push({});
|
||||||
|
array.push(createObject("key", "z"));
|
||||||
|
array.sort(byKey("key"));
|
||||||
|
expect(array).toEqual([createObject("key", "a"), createObject("key", "z"), {}]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should not fail if item is undefined", () => {
|
||||||
|
const array: any[] = createObjects("key", ["a"]);
|
||||||
|
array.push(undefined);
|
||||||
|
array.push(createObject("key", "z"));
|
||||||
|
array.sort(byKey("key"));
|
||||||
|
expect(array).toEqual([createObject("key", "a"), createObject("key", "z"), undefined]);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("length comparator tests", () => {
|
||||||
|
it("should sort array", () => {
|
||||||
|
const array = createObjects("key", ["....", ".", "...", ".."]);
|
||||||
|
array.sort(byValueLength("key"));
|
||||||
|
expect(array).toEqual(createObjects("key", [".", "..", "...", "...."]));
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should not fail if value is undefined", () => {
|
||||||
|
const array = createObjects("key", ["..", undefined, "."]);
|
||||||
|
array.sort(byValueLength("key"));
|
||||||
|
expect(array).toEqual(createObjects("key", [".", "..", undefined]));
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should not fail if key is undefined", () => {
|
||||||
|
const array = createObjects("key", ["."]);
|
||||||
|
array.push({});
|
||||||
|
array.push(createObject("key", ".."));
|
||||||
|
array.sort(byValueLength("key"));
|
||||||
|
expect(array).toEqual([createObject("key", "."), createObject("key", ".."), {}]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should not fail if item is undefined", () => {
|
||||||
|
const array: any[] = createObjects("key", ["."]);
|
||||||
|
array.push(undefined);
|
||||||
|
array.push(createObject("key", ".."));
|
||||||
|
array.sort(byValueLength("key"));
|
||||||
|
expect(array).toEqual([createObject("key", "."), createObject("key", ".."), undefined]);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("nested key comparator tests", () => {
|
||||||
|
const createObject = (key: string, nested?: string, value?: string) => {
|
||||||
|
if (!nested) {
|
||||||
|
return {
|
||||||
|
[key]: undefined
|
||||||
|
};
|
||||||
|
}
|
||||||
|
return {
|
||||||
|
[key]: {
|
||||||
|
[nested]: value
|
||||||
|
}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
const createObjects = (key: string, nested: string, values: Array<string | undefined>) => {
|
||||||
|
return values.map(v => createObject(key, nested, v));
|
||||||
|
};
|
||||||
|
|
||||||
|
it("should sort array", () => {
|
||||||
|
const array = createObjects("key", "nested", ["z", "a", "y", "b"]);
|
||||||
|
array.sort(byNestedKeys("key", "nested"));
|
||||||
|
expect(array).toEqual(createObjects("key", "nested", ["a", "b", "y", "z"]));
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should not fail if value is undefined", () => {
|
||||||
|
const array = createObjects("key", "nested", ["z", undefined, "a"]);
|
||||||
|
array.sort(byNestedKeys("key", "nested"));
|
||||||
|
expect(array).toEqual(createObjects("key", "nested", ["a", "z", undefined]));
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should not fail if key is undefined", () => {
|
||||||
|
const array = createObjects("key", "nested", ["a"]);
|
||||||
|
array.push({});
|
||||||
|
array.push(createObject("key", "nested", "z"));
|
||||||
|
array.sort(byNestedKeys("key", "nested"));
|
||||||
|
expect(array).toEqual([createObject("key", "nested", "a"), createObject("key", "nested", "z"), {}]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should not fail if nested key is undefined", () => {
|
||||||
|
const array = createObjects("key", "nested", ["a"]);
|
||||||
|
array.push(createObject("key", undefined, "y"));
|
||||||
|
array.push(createObject("key", "nested", "z"));
|
||||||
|
array.sort(byNestedKeys("key", "nested"));
|
||||||
|
expect(array).toEqual([createObject("key", "nested", "a"), createObject("key", "nested", "z"), { key: undefined }]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should not fail if item is undefined", () => {
|
||||||
|
const array: any[] = createObjects("key", "nested", ["a"]);
|
||||||
|
array.push(undefined);
|
||||||
|
array.push(createObject("key", "nested", "z"));
|
||||||
|
array.sort(byNestedKeys("key", "nested"));
|
||||||
|
expect(array).toEqual([createObject("key", "nested", "a"), createObject("key", "nested", "z"), undefined]);
|
||||||
|
});
|
||||||
|
});
|
||||||
75
scm-ui/ui-components/src/comparators.ts
Normal file
75
scm-ui/ui-components/src/comparators.ts
Normal file
@@ -0,0 +1,75 @@
|
|||||||
|
const isUndefined = (o: any, key: string, nested?: string) => {
|
||||||
|
if (typeof o === "undefined" || typeof o[key] === "undefined") {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (nested) {
|
||||||
|
return typeof o[key][nested] === "undefined";
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
};
|
||||||
|
|
||||||
|
export const byKey = (key: string) => {
|
||||||
|
return (a: any, b: any) => {
|
||||||
|
if (isUndefined(a, key)) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isUndefined(b, key)) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (a[key] < b[key]) {
|
||||||
|
return -1;
|
||||||
|
} else if (a[key] > b[key]) {
|
||||||
|
return 1;
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
export const byValueLength = (key: string) => {
|
||||||
|
return (a: any, b: any) => {
|
||||||
|
if (isUndefined(a, key)) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isUndefined(b, key)) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (a[key].length < b[key].length) {
|
||||||
|
return -1;
|
||||||
|
} else if (a[key].length > b[key].length) {
|
||||||
|
return 1;
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
export const byNestedKeys = (key: string, nestedKey: string) => {
|
||||||
|
return (a: any, b: any) => {
|
||||||
|
if (isUndefined(a, key, nestedKey)) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isUndefined(b, key, nestedKey)) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (a[key][nestedKey] < b[key][nestedKey]) {
|
||||||
|
return -1;
|
||||||
|
} else if (a[key][nestedKey] > b[key][nestedKey]) {
|
||||||
|
return 1;
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
export default {
|
||||||
|
byKey,
|
||||||
|
byValueLength,
|
||||||
|
byNestedKeys
|
||||||
|
};
|
||||||
@@ -52,6 +52,8 @@ export { default as OverviewPageActions } from "./OverviewPageActions";
|
|||||||
export { default as CardColumnGroup } from "./CardColumnGroup";
|
export { default as CardColumnGroup } from "./CardColumnGroup";
|
||||||
export { default as CardColumn } from "./CardColumn";
|
export { default as CardColumn } from "./CardColumn";
|
||||||
|
|
||||||
|
export { default as comparators } from "./comparators";
|
||||||
|
|
||||||
export { apiClient } from "./apiclient";
|
export { apiClient } from "./apiclient";
|
||||||
export * from "./errors";
|
export * from "./errors";
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import React, { FC } from "react";
|
import React, { FC } from "react";
|
||||||
import { ColumnProps } from "./types";
|
import { ColumnProps } from "./types";
|
||||||
|
import comparators from "../comparators";
|
||||||
|
|
||||||
type Props = ColumnProps & {
|
type Props = ColumnProps & {
|
||||||
dataKey: string;
|
dataKey: string;
|
||||||
@@ -11,15 +12,7 @@ const TextColumn: FC<Props> = ({ row, dataKey }) => {
|
|||||||
|
|
||||||
TextColumn.defaultProps = {
|
TextColumn.defaultProps = {
|
||||||
createComparator: (props: Props) => {
|
createComparator: (props: Props) => {
|
||||||
return (a: any, b: any) => {
|
return comparators.byKey(props.dataKey);
|
||||||
if (a[props.dataKey] < b[props.dataKey]) {
|
|
||||||
return -1;
|
|
||||||
} else if (a[props.dataKey] > b[props.dataKey]) {
|
|
||||||
return 1;
|
|
||||||
} else {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
},
|
},
|
||||||
ascendingIcon: "sort-alpha-down-alt",
|
ascendingIcon: "sort-alpha-down-alt",
|
||||||
descendingIcon: "sort-alpha-down"
|
descendingIcon: "sort-alpha-down"
|
||||||
|
|||||||
Reference in New Issue
Block a user