mirror of
https://github.com/antebudimir/feishin.git
synced 2026-01-02 10:53:33 +00:00
110 lines
2.6 KiB
TypeScript
110 lines
2.6 KiB
TypeScript
|
|
import { nanoid } from 'nanoid/non-secure';
|
||
|
|
import { QueryBuilderGroup } from '/@/renderer/types';
|
||
|
|
|
||
|
|
export const parseQueryBuilderChildren = (groups: QueryBuilderGroup[], data: any[]) => {
|
||
|
|
if (groups.length === 0) {
|
||
|
|
return data;
|
||
|
|
}
|
||
|
|
|
||
|
|
const filterGroups: any[] = [];
|
||
|
|
|
||
|
|
for (const group of groups) {
|
||
|
|
const rootType = group.type;
|
||
|
|
const query: any = {
|
||
|
|
[rootType]: [],
|
||
|
|
};
|
||
|
|
|
||
|
|
for (const rule of group.rules) {
|
||
|
|
if (rule.field && rule.operator) {
|
||
|
|
const [table, field] = rule.field.split('.');
|
||
|
|
const operator = rule.operator;
|
||
|
|
const value = field !== 'releaseDate' ? rule.value : new Date(rule.value);
|
||
|
|
|
||
|
|
switch (table) {
|
||
|
|
default:
|
||
|
|
query[rootType].push({
|
||
|
|
[operator]: {
|
||
|
|
[table]: value,
|
||
|
|
},
|
||
|
|
});
|
||
|
|
break;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
if (group.group.length > 0) {
|
||
|
|
const b = parseQueryBuilderChildren(group.group, data);
|
||
|
|
b.forEach((c) => query[rootType].push(c));
|
||
|
|
}
|
||
|
|
|
||
|
|
data.push(query);
|
||
|
|
filterGroups.push(query);
|
||
|
|
}
|
||
|
|
|
||
|
|
return filterGroups;
|
||
|
|
};
|
||
|
|
|
||
|
|
// Convert QueryBuilderGroup to default query
|
||
|
|
export const convertQueryGroupToNDQuery = (filter: QueryBuilderGroup) => {
|
||
|
|
const rootQueryType = filter.type;
|
||
|
|
const rootQuery = {
|
||
|
|
[rootQueryType]: [] as any[],
|
||
|
|
};
|
||
|
|
|
||
|
|
for (const rule of filter.rules) {
|
||
|
|
if (rule.field && rule.operator) {
|
||
|
|
const [table] = rule.field.split('.');
|
||
|
|
const operator = rule.operator;
|
||
|
|
const value = rule.value;
|
||
|
|
|
||
|
|
switch (table) {
|
||
|
|
default:
|
||
|
|
rootQuery[rootQueryType].push({
|
||
|
|
[operator]: {
|
||
|
|
[table]: value,
|
||
|
|
},
|
||
|
|
});
|
||
|
|
break;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
const groups = parseQueryBuilderChildren(filter.group, []);
|
||
|
|
for (const group of groups) {
|
||
|
|
rootQuery[rootQueryType].push(group);
|
||
|
|
}
|
||
|
|
|
||
|
|
return rootQuery;
|
||
|
|
};
|
||
|
|
|
||
|
|
// Convert default query to QueryBuilderGroup
|
||
|
|
export const convertNDQueryToQueryGroup = (query: Record<string, any>) => {
|
||
|
|
const rootType = Object.keys(query)[0];
|
||
|
|
const rootGroup: QueryBuilderGroup = {
|
||
|
|
group: [],
|
||
|
|
rules: [],
|
||
|
|
type: rootType as 'any' | 'all',
|
||
|
|
uniqueId: nanoid(),
|
||
|
|
};
|
||
|
|
|
||
|
|
for (const rule of query[rootType]) {
|
||
|
|
if (rule.any || rule.all) {
|
||
|
|
const group = convertNDQueryToQueryGroup(rule);
|
||
|
|
rootGroup.group.push(group);
|
||
|
|
} else {
|
||
|
|
const operator = Object.keys(rule)[0];
|
||
|
|
const field = Object.keys(rule[operator])[0];
|
||
|
|
const value = rule[operator][field];
|
||
|
|
|
||
|
|
rootGroup.rules.push({
|
||
|
|
field,
|
||
|
|
operator,
|
||
|
|
uniqueId: nanoid(),
|
||
|
|
value,
|
||
|
|
});
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
return rootGroup;
|
||
|
|
};
|