|
16 | 16 | * limitations under the License. |
17 | 17 | */ |
18 | 18 |
|
19 | | -import { RECOMMEND_TIME, TIME_FORMATTER } from 'globalConstants'; |
| 19 | +import { DataViewFieldType } from 'app/constants'; |
| 20 | +import { ChartDataRequestFilter } from 'app/types/ChartDataRequest'; |
| 21 | +import { |
| 22 | + FilterSqlOperator, |
| 23 | + RECOMMEND_TIME, |
| 24 | + TIME_FORMATTER, |
| 25 | +} from 'globalConstants'; |
20 | 26 | import moment, { Moment, unitOfTime } from 'moment'; |
21 | 27 |
|
22 | 28 | export function getTimeRange( |
@@ -75,3 +81,36 @@ export function recommendTimeRangeConverter(relativeTimeRange) { |
75 | 81 | } |
76 | 82 | return timeRange; |
77 | 83 | } |
| 84 | + |
| 85 | +export const splitRangerDateFilters = (filters: ChartDataRequestFilter[]) => { |
| 86 | + if (!Array.isArray(filters)) return filters; |
| 87 | + const newFilter = [] as ChartDataRequestFilter[]; |
| 88 | + filters.forEach(filter => { |
| 89 | + let isTargetFilter = false; |
| 90 | + if ( |
| 91 | + filter.sqlOperator === FilterSqlOperator.Between && |
| 92 | + filter.values?.[0].valueType === DataViewFieldType.DATE |
| 93 | + ) { |
| 94 | + isTargetFilter = true; |
| 95 | + } |
| 96 | + if (!isTargetFilter) { |
| 97 | + newFilter.push(filter); |
| 98 | + return; |
| 99 | + } |
| 100 | + // split date range filters |
| 101 | + if (filter.values?.[0] && filter.values?.[1]) { |
| 102 | + const start: ChartDataRequestFilter = { |
| 103 | + ...filter, |
| 104 | + sqlOperator: FilterSqlOperator.GreaterThanOrEqual, |
| 105 | + values: [filter.values?.[0]], |
| 106 | + }; |
| 107 | + const end: ChartDataRequestFilter = { |
| 108 | + ...filter, |
| 109 | + sqlOperator: FilterSqlOperator.LessThan, |
| 110 | + values: [filter.values?.[1]], |
| 111 | + }; |
| 112 | + newFilter.push(start, end); |
| 113 | + } |
| 114 | + }); |
| 115 | + return newFilter; |
| 116 | +}; |
0 commit comments