@qrvey/utils 1.1.0-9 → 1.1.2-1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintignore +5 -0
- package/.eslintrc.json +37 -0
- package/README.md +474 -285
- package/bitbucket-pipelines.yml +25 -0
- package/dist/cjs/constants/COLUMN.js +0 -1
- package/dist/cjs/constants/COLUMN_PROPERTY.d.ts +6 -0
- package/dist/cjs/constants/COLUMN_PROPERTY.js +0 -1
- package/dist/cjs/constants/COLUMN_PROPERTY_VALUE.js +4 -1
- package/dist/cjs/date/constants/DATE_DAY_HOURS.d.ts +1 -0
- package/dist/cjs/date/constants/DATE_DAY_HOURS.js +29 -0
- package/dist/cjs/date/constants/DATE_HOUR_MINUTES.d.ts +1 -0
- package/dist/cjs/date/constants/DATE_HOUR_MINUTES.js +65 -0
- package/dist/cjs/date/constants/DATE_MINUTE_SECONDS.d.ts +1 -0
- package/dist/cjs/date/constants/DATE_MINUTE_SECONDS.js +5 -0
- package/dist/cjs/date/constants/DATE_MONTH_DAYS.d.ts +1 -0
- package/dist/cjs/date/constants/DATE_MONTH_DAYS.js +36 -0
- package/dist/cjs/date/constants/DATE_PROPERTY.js +0 -1
- package/dist/cjs/date/constants/DATE_PROPERTY_VALUE.d.ts +8 -0
- package/dist/cjs/date/constants/DATE_PROPERTY_VALUE.js +17 -0
- package/dist/cjs/date/constants/DATE_P_PROPERTIES.d.ts +2 -0
- package/dist/cjs/date/constants/DATE_P_PROPERTIES.js +11 -0
- package/dist/cjs/date/constants/DATE_P_VALUES.d.ts +6 -0
- package/dist/cjs/date/constants/DATE_P_VALUES.js +8 -0
- package/dist/cjs/date/constants/DATE_TIME_P_VALUES.d.ts +6 -0
- package/dist/cjs/date/constants/DATE_TIME_P_VALUES.js +8 -0
- package/dist/cjs/date/constants/DATE_TIME_VALUES.js +1 -1
- package/dist/cjs/date/constants/DATE_WEEK_DAYS.d.ts +1 -0
- package/dist/cjs/date/constants/DATE_WEEK_DAYS.js +6 -0
- package/dist/cjs/date/constants/DATE_YEAR_DAYS.d.ts +1 -0
- package/dist/cjs/date/constants/DATE_YEAR_DAYS.js +370 -0
- package/dist/cjs/date/constants/DATE_YEAR_MONTHS.d.ts +1 -0
- package/dist/cjs/date/constants/DATE_YEAR_MONTHS.js +4 -0
- package/dist/cjs/date/constants/DATE_YEAR_QUARTERS.d.ts +1 -0
- package/dist/cjs/date/constants/DATE_YEAR_QUARTERS.js +4 -0
- package/dist/cjs/date/constants/index.d.ts +12 -0
- package/dist/cjs/date/constants/index.js +12 -0
- package/dist/cjs/date/range/getDateRange.js +26 -21
- package/dist/cjs/date/relative/Adapter.js +1 -1
- package/dist/cjs/date/relative/constants/DATE_FORMATS.d.ts +1 -1
- package/dist/cjs/date/relative/constants/DATE_FORMATS.js +3 -3
- package/dist/cjs/date/relative/helpers/formatStatement.js +6 -6
- package/dist/cjs/filters/adapters/FDToFlatUI.js +5 -12
- package/dist/cjs/filters/adapters/FDToUI.js +2 -3
- package/dist/cjs/filters/adapters/UIToFlatUI.js +5 -12
- package/dist/cjs/filters/adapters/UIToOldLogic.js +9 -1
- package/dist/cjs/filters/adapters/adaptFilterData.js +1 -1
- package/dist/cjs/filters/adapters/flatUIToFD.js +3 -7
- package/dist/cjs/filters/adapters/flatUIToOldLogic.js +41 -62
- package/dist/cjs/filters/adapters/flatUIToUI.js +2 -7
- package/dist/cjs/filters/adapters/logicToFlatUI.js +89 -74
- package/dist/cjs/filters/adapters/transformFilters.d.ts +1 -1
- package/dist/cjs/filters/adapters/transformFilters.js +18 -25
- package/dist/cjs/filters/constants/backend/FILTER_BACKEND_VALIDATOR.js +0 -1
- package/dist/cjs/filters/constants/common/FILTER_GROUPED_COLUMN_OPERATOR.d.ts +2 -0
- package/dist/cjs/filters/constants/common/FILTER_GROUPED_COLUMN_OPERATOR.js +4 -0
- package/dist/cjs/filters/constants/common/FILTER_OPERATOR.js +0 -1
- package/dist/cjs/filters/constants/common/FILTER_VALIDATOR.js +0 -1
- package/dist/cjs/filters/constants/common/index.d.ts +1 -0
- package/dist/cjs/filters/constants/common/index.js +1 -0
- package/dist/cjs/filters/helpers/backend/buildExpression.d.ts +6 -0
- package/dist/cjs/filters/helpers/backend/buildExpression.js +9 -2
- package/dist/cjs/filters/helpers/backend/getBackendGroupValue.js +2 -1
- package/dist/cjs/filters/helpers/backend/getBackendProperty.js +7 -2
- package/dist/cjs/filters/helpers/backend/getBackendValues.js +34 -18
- package/dist/cjs/filters/helpers/common/arePropertiesDateP.d.ts +8 -0
- package/dist/cjs/filters/helpers/common/arePropertiesDateP.js +16 -0
- package/dist/cjs/filters/helpers/common/getFilterColumnLabel.js +1 -1
- package/dist/cjs/filters/helpers/common/getFilterid.js +1 -1
- package/dist/cjs/filters/helpers/common/getFiltersByParams.js +5 -5
- package/dist/cjs/filters/helpers/common/getFiltersByVisibility.js +1 -1
- package/dist/cjs/filters/helpers/common/getMergeFiltersSettings.d.ts +7 -0
- package/dist/cjs/filters/helpers/common/getMergeFiltersSettings.js +16 -0
- package/dist/cjs/filters/helpers/common/getParamsToGetFilterSettings.d.ts +5 -0
- package/dist/cjs/filters/helpers/common/getParamsToGetFilterSettings.js +11 -1
- package/dist/cjs/filters/helpers/common/index.d.ts +2 -0
- package/dist/cjs/filters/helpers/common/index.js +2 -0
- package/dist/cjs/filters/helpers/common/mergeFilters.d.ts +2 -1
- package/dist/cjs/filters/helpers/common/mergeFilters.js +27 -10
- package/dist/cjs/filters/helpers/common/resolveDatasetConditions.js +1 -1
- package/dist/cjs/filters/helpers/common/resolveFilterConditions.js +2 -3
- package/dist/cjs/filters/helpers/common/resolveScopeConditions.js +1 -1
- package/dist/cjs/filters/helpers/getAggFiltersFromFilterData.d.ts +1 -1
- package/dist/cjs/filters/helpers/getAggFiltersFromFilterData.js +18 -19
- package/dist/cjs/filters/helpers/getScopesByHierarchy.js +2 -2
- package/dist/cjs/filters/helpers/ui/excludeUIFlatFiltersByScopes.d.ts +1 -1
- package/dist/cjs/filters/helpers/ui/excludeUIFlatFiltersByScopes.js +1 -1
- package/dist/cjs/filters/helpers/ui/getUIFlatFilterByParams.d.ts +1 -1
- package/dist/cjs/filters/helpers/ui/getUIFlatFilterByParams.js +1 -1
- package/dist/cjs/filters/helpers/ui/getUIFlatFiltersByParams.d.ts +1 -1
- package/dist/cjs/filters/helpers/ui/getUIFlatFiltersByParams.js +1 -1
- package/dist/cjs/filters/helpers/ui/getUIFlatFiltersByScopes.d.ts +1 -1
- package/dist/cjs/filters/helpers/ui/getUIFlatFiltersByScopes.js +1 -1
- package/dist/cjs/filters/helpers/ui/getUIValues.js +6 -5
- package/dist/cjs/filters/interfaces/OLD_IFilterDetail.d.ts +3 -0
- package/dist/cjs/filters/interfaces/common/IFSFilterExtras.d.ts +3 -0
- package/dist/cjs/filters/interfaces/common/IFSFilterExtrasInfo.d.ts +4 -0
- package/dist/cjs/filters/interfaces/common/IFSFilterExtrasInfo.js +2 -0
- package/dist/cjs/filters/interfaces/common/IFSMergeFiltersSettings.d.ts +7 -0
- package/dist/cjs/filters/interfaces/common/IFSMergeFiltersSettings.js +2 -0
- package/dist/cjs/filters/interfaces/common/IFSParamsToGetFilter.d.ts +2 -1
- package/dist/cjs/filters/interfaces/common/IFSParamsToGetFilterEnableds.d.ts +9 -0
- package/dist/cjs/filters/interfaces/common/IFSParamsToGetFilterEnableds.js +2 -0
- package/dist/cjs/filters/interfaces/common/IFSParamsToGetFilterSettings.d.ts +5 -0
- package/dist/cjs/filters/interfaces/common/index.d.ts +3 -0
- package/dist/cjs/filters/interfaces/common/index.js +3 -0
- package/dist/cjs/filters/interfaces/panel/IFPSettingsFilterPanelBodyScopeScope.d.ts +1 -0
- package/dist/cjs/filters/interfaces/panel/IFPSettingsFilterPanelHeader.d.ts +1 -0
- package/dist/cjs/filters/interfaces/panel/IFPSettingsFilterPanelSettings.d.ts +4 -0
- package/dist/cjs/filters/interfaces/panel/IFPSettingsFilterPanelSettingsScope.d.ts +7 -0
- package/dist/cjs/filters/interfaces/panel/IFPSettingsFilterPanelSettingsScope.js +2 -0
- package/dist/cjs/filters/interfaces/panel/index.d.ts +1 -0
- package/dist/cjs/filters/interfaces/panel/index.js +1 -0
- package/dist/cjs/format/definition.d.ts +3 -2
- package/dist/cjs/format/format.d.ts +1 -1
- package/dist/cjs/format/format.js +25 -26
- package/dist/cjs/general/array/delete.d.ts +4 -4
- package/dist/cjs/general/array/delete.js +8 -6
- package/dist/cjs/general/array/filterNestedTree.js +1 -1
- package/dist/cjs/general/array/flattenDeep.d.ts +1 -1
- package/dist/cjs/general/array/flattenDeep.js +4 -2
- package/dist/cjs/general/array/getFirstIndexFromArray.d.ts +1 -1
- package/dist/cjs/general/array/getFirstIndexFromArray.js +7 -5
- package/dist/cjs/general/array/getLastIndexFromArray.d.ts +1 -1
- package/dist/cjs/general/array/getLastIndexFromArray.js +6 -4
- package/dist/cjs/general/function/debounce.d.ts +1 -1
- package/dist/cjs/general/function/throttled.d.ts +1 -1
- package/dist/cjs/general/function/throttled.js +1 -1
- package/dist/cjs/general/mix/importScripts.d.ts +1 -1
- package/dist/cjs/general/mix/isEmpty.d.ts +5 -4
- package/dist/cjs/general/mix/isEmpty.js +12 -6
- package/dist/cjs/general/mix/randomId.d.ts +1 -1
- package/dist/cjs/general/mix/randomId.js +1 -2
- package/dist/cjs/general/mix/size.d.ts +1 -1
- package/dist/cjs/general/object/cloneDeep.d.ts +4 -4
- package/dist/cjs/general/object/cloneDeep.js +14 -6
- package/dist/cjs/general/object/get.d.ts +47 -15
- package/dist/cjs/general/object/get.js +61 -37
- package/dist/cjs/general/object/getAttribute.d.ts +1 -1
- package/dist/cjs/general/object/hasProperty.d.ts +1 -1
- package/dist/cjs/general/object/hasProperty.js +1 -1
- package/dist/cjs/general/object/index.d.ts +1 -0
- package/dist/cjs/general/object/index.js +1 -0
- package/dist/cjs/general/object/isObject.d.ts +6 -0
- package/dist/cjs/general/object/isObject.js +12 -0
- package/dist/cjs/general/object/mapValues.d.ts +1 -1
- package/dist/cjs/general/object/mapValues.js +0 -1
- package/dist/cjs/general/object/omit.js +1 -1
- package/dist/cjs/general/object/pick.js +0 -1
- package/dist/cjs/index.d.ts +2 -0
- package/dist/cjs/index.js +2 -0
- package/dist/cjs/qrvey/getColumnsLabel.js +4 -4
- package/dist/cjs/qrvey/index.d.ts +3 -0
- package/dist/cjs/qrvey/index.js +15 -0
- package/dist/cjs/tokens/index.d.ts +1 -0
- package/dist/cjs/tokens/index.js +13 -0
- package/dist/cjs/tokens/isTokenLabel.d.ts +6 -0
- package/dist/cjs/tokens/isTokenLabel.js +16 -0
- package/dist/constants/COLUMN.js +0 -1
- package/dist/constants/COLUMN_PROPERTY.d.ts +6 -0
- package/dist/constants/COLUMN_PROPERTY.js +0 -1
- package/dist/constants/COLUMN_PROPERTY_VALUE.js +4 -1
- package/dist/date/constants/DATE_DAY_HOURS.d.ts +1 -0
- package/dist/date/constants/DATE_DAY_HOURS.js +26 -0
- package/dist/date/constants/DATE_HOUR_MINUTES.d.ts +1 -0
- package/dist/date/constants/DATE_HOUR_MINUTES.js +62 -0
- package/dist/date/constants/DATE_MINUTE_SECONDS.d.ts +1 -0
- package/dist/date/constants/DATE_MINUTE_SECONDS.js +2 -0
- package/dist/date/constants/DATE_MONTH_DAYS.d.ts +1 -0
- package/dist/date/constants/DATE_MONTH_DAYS.js +33 -0
- package/dist/date/constants/DATE_PROPERTY.js +0 -1
- package/dist/date/constants/DATE_PROPERTY_VALUE.d.ts +8 -0
- package/dist/date/constants/DATE_PROPERTY_VALUE.js +14 -0
- package/dist/date/constants/DATE_P_PROPERTIES.d.ts +2 -0
- package/dist/date/constants/DATE_P_PROPERTIES.js +8 -0
- package/dist/date/constants/DATE_P_VALUES.d.ts +6 -0
- package/dist/date/constants/DATE_P_VALUES.js +5 -0
- package/dist/date/constants/DATE_TIME_P_VALUES.d.ts +6 -0
- package/dist/date/constants/DATE_TIME_P_VALUES.js +5 -0
- package/dist/date/constants/DATE_TIME_VALUES.js +1 -1
- package/dist/date/constants/DATE_WEEK_DAYS.d.ts +1 -0
- package/dist/date/constants/DATE_WEEK_DAYS.js +3 -0
- package/dist/date/constants/DATE_YEAR_DAYS.d.ts +1 -0
- package/dist/date/constants/DATE_YEAR_DAYS.js +367 -0
- package/dist/date/constants/DATE_YEAR_MONTHS.d.ts +1 -0
- package/dist/date/constants/DATE_YEAR_MONTHS.js +1 -0
- package/dist/date/constants/DATE_YEAR_QUARTERS.d.ts +1 -0
- package/dist/date/constants/DATE_YEAR_QUARTERS.js +1 -0
- package/dist/date/constants/index.d.ts +12 -0
- package/dist/date/constants/index.js +12 -0
- package/dist/date/range/getDateRange.js +26 -21
- package/dist/date/relative/Adapter.js +2 -2
- package/dist/date/relative/constants/DATE_FORMATS.d.ts +1 -1
- package/dist/date/relative/constants/DATE_FORMATS.js +3 -3
- package/dist/date/relative/helpers/formatStatement.js +7 -7
- package/dist/filters/adapters/FDToFlatUI.js +5 -12
- package/dist/filters/adapters/FDToUI.js +2 -3
- package/dist/filters/adapters/UIToFlatUI.js +5 -12
- package/dist/filters/adapters/UIToOldLogic.js +9 -1
- package/dist/filters/adapters/adaptFilterData.js +1 -1
- package/dist/filters/adapters/flatUIToFD.js +3 -7
- package/dist/filters/adapters/flatUIToOldLogic.js +42 -63
- package/dist/filters/adapters/flatUIToUI.js +3 -8
- package/dist/filters/adapters/logicToFlatUI.js +91 -76
- package/dist/filters/adapters/transformFilters.d.ts +1 -1
- package/dist/filters/adapters/transformFilters.js +19 -26
- package/dist/filters/constants/backend/FILTER_BACKEND_VALIDATOR.js +0 -1
- package/dist/filters/constants/common/FILTER_GROUPED_COLUMN_OPERATOR.d.ts +2 -0
- package/dist/filters/constants/common/FILTER_GROUPED_COLUMN_OPERATOR.js +1 -0
- package/dist/filters/constants/common/FILTER_OPERATOR.js +0 -1
- package/dist/filters/constants/common/FILTER_VALIDATOR.js +0 -1
- package/dist/filters/constants/common/index.d.ts +1 -0
- package/dist/filters/constants/common/index.js +1 -0
- package/dist/filters/helpers/backend/buildExpression.d.ts +6 -0
- package/dist/filters/helpers/backend/buildExpression.js +9 -2
- package/dist/filters/helpers/backend/getBackendGroupValue.js +2 -1
- package/dist/filters/helpers/backend/getBackendProperty.js +8 -3
- package/dist/filters/helpers/backend/getBackendValues.js +34 -18
- package/dist/filters/helpers/common/arePropertiesDateP.d.ts +8 -0
- package/dist/filters/helpers/common/arePropertiesDateP.js +12 -0
- package/dist/filters/helpers/common/getFilterColumnLabel.js +1 -1
- package/dist/filters/helpers/common/getFilterid.js +1 -1
- package/dist/filters/helpers/common/getFiltersByParams.js +6 -6
- package/dist/filters/helpers/common/getFiltersByVisibility.js +1 -1
- package/dist/filters/helpers/common/getMergeFiltersSettings.d.ts +7 -0
- package/dist/filters/helpers/common/getMergeFiltersSettings.js +12 -0
- package/dist/filters/helpers/common/getParamsToGetFilterSettings.d.ts +5 -0
- package/dist/filters/helpers/common/getParamsToGetFilterSettings.js +11 -1
- package/dist/filters/helpers/common/index.d.ts +2 -0
- package/dist/filters/helpers/common/index.js +2 -0
- package/dist/filters/helpers/common/mergeFilters.d.ts +2 -1
- package/dist/filters/helpers/common/mergeFilters.js +27 -10
- package/dist/filters/helpers/common/resolveDatasetConditions.js +1 -1
- package/dist/filters/helpers/common/resolveFilterConditions.js +2 -3
- package/dist/filters/helpers/common/resolveScopeConditions.js +1 -1
- package/dist/filters/helpers/getAggFiltersFromFilterData.d.ts +1 -1
- package/dist/filters/helpers/getAggFiltersFromFilterData.js +18 -19
- package/dist/filters/helpers/getScopesByHierarchy.js +2 -2
- package/dist/filters/helpers/ui/excludeUIFlatFiltersByScopes.d.ts +1 -1
- package/dist/filters/helpers/ui/excludeUIFlatFiltersByScopes.js +1 -1
- package/dist/filters/helpers/ui/getUIFlatFilterByParams.d.ts +1 -1
- package/dist/filters/helpers/ui/getUIFlatFilterByParams.js +1 -1
- package/dist/filters/helpers/ui/getUIFlatFiltersByParams.d.ts +1 -1
- package/dist/filters/helpers/ui/getUIFlatFiltersByParams.js +1 -1
- package/dist/filters/helpers/ui/getUIFlatFiltersByScopes.d.ts +1 -1
- package/dist/filters/helpers/ui/getUIFlatFiltersByScopes.js +1 -1
- package/dist/filters/helpers/ui/getUIValues.js +6 -5
- package/dist/filters/interfaces/OLD_IFilterDetail.d.ts +3 -0
- package/dist/filters/interfaces/common/IFSFilterExtras.d.ts +3 -0
- package/dist/filters/interfaces/common/IFSFilterExtrasInfo.d.ts +4 -0
- package/dist/filters/interfaces/common/IFSFilterExtrasInfo.js +1 -0
- package/dist/filters/interfaces/common/IFSMergeFiltersSettings.d.ts +7 -0
- package/dist/filters/interfaces/common/IFSMergeFiltersSettings.js +1 -0
- package/dist/filters/interfaces/common/IFSParamsToGetFilter.d.ts +2 -1
- package/dist/filters/interfaces/common/IFSParamsToGetFilterEnableds.d.ts +9 -0
- package/dist/filters/interfaces/common/IFSParamsToGetFilterEnableds.js +1 -0
- package/dist/filters/interfaces/common/IFSParamsToGetFilterSettings.d.ts +5 -0
- package/dist/filters/interfaces/common/index.d.ts +3 -0
- package/dist/filters/interfaces/common/index.js +3 -0
- package/dist/filters/interfaces/panel/IFPSettingsFilterPanelBodyScopeScope.d.ts +1 -0
- package/dist/filters/interfaces/panel/IFPSettingsFilterPanelHeader.d.ts +1 -0
- package/dist/filters/interfaces/panel/IFPSettingsFilterPanelSettings.d.ts +4 -0
- package/dist/filters/interfaces/panel/IFPSettingsFilterPanelSettingsScope.d.ts +7 -0
- package/dist/filters/interfaces/panel/IFPSettingsFilterPanelSettingsScope.js +1 -0
- package/dist/filters/interfaces/panel/index.d.ts +1 -0
- package/dist/filters/interfaces/panel/index.js +1 -0
- package/dist/format/definition.d.ts +3 -2
- package/dist/format/format.d.ts +1 -1
- package/dist/format/format.js +12 -13
- package/dist/general/array/delete.d.ts +4 -4
- package/dist/general/array/delete.js +8 -6
- package/dist/general/array/filterNestedTree.js +1 -1
- package/dist/general/array/flattenDeep.d.ts +1 -1
- package/dist/general/array/flattenDeep.js +4 -2
- package/dist/general/array/getFirstIndexFromArray.d.ts +1 -1
- package/dist/general/array/getFirstIndexFromArray.js +7 -5
- package/dist/general/array/getLastIndexFromArray.d.ts +1 -1
- package/dist/general/array/getLastIndexFromArray.js +6 -4
- package/dist/general/function/debounce.d.ts +1 -1
- package/dist/general/function/throttled.d.ts +1 -1
- package/dist/general/function/throttled.js +1 -1
- package/dist/general/mix/importScripts.d.ts +1 -1
- package/dist/general/mix/isEmpty.d.ts +5 -4
- package/dist/general/mix/isEmpty.js +12 -6
- package/dist/general/mix/randomId.d.ts +1 -1
- package/dist/general/mix/randomId.js +1 -2
- package/dist/general/mix/size.d.ts +1 -1
- package/dist/general/object/cloneDeep.d.ts +4 -4
- package/dist/general/object/cloneDeep.js +14 -6
- package/dist/general/object/get.d.ts +47 -15
- package/dist/general/object/get.js +59 -34
- package/dist/general/object/getAttribute.d.ts +1 -1
- package/dist/general/object/hasProperty.d.ts +1 -1
- package/dist/general/object/hasProperty.js +1 -1
- package/dist/general/object/index.d.ts +1 -0
- package/dist/general/object/index.js +1 -0
- package/dist/general/object/isObject.d.ts +6 -0
- package/dist/general/object/isObject.js +8 -0
- package/dist/general/object/mapValues.d.ts +1 -1
- package/dist/general/object/mapValues.js +0 -1
- package/dist/general/object/omit.js +1 -1
- package/dist/general/object/pick.js +0 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.js +2 -0
- package/dist/qrvey/getColumnsLabel.js +5 -5
- package/dist/qrvey/index.d.ts +3 -0
- package/dist/qrvey/index.js +3 -0
- package/dist/tokens/index.d.ts +1 -0
- package/dist/tokens/index.js +1 -0
- package/dist/tokens/isTokenLabel.d.ts +6 -0
- package/dist/tokens/isTokenLabel.js +12 -0
- package/package.json +17 -10
- package/prepareToPublish.js +52 -0
- package/src/constants/COLUMN.ts +1 -1
- package/src/constants/COLUMN_PROPERTY.ts +13 -2
- package/src/constants/COLUMN_PROPERTY_VALUE.ts +6 -1
- package/src/date/constants/DATE_DAY_HOURS.ts +27 -0
- package/src/date/constants/DATE_HOUR_MINUTES.ts +63 -0
- package/src/date/constants/DATE_MINUTE_SECONDS.ts +3 -0
- package/src/date/constants/DATE_MONTH_DAYS.ts +34 -0
- package/src/date/constants/DATE_PROPERTY.ts +1 -1
- package/src/date/constants/DATE_PROPERTY_VALUE.ts +16 -0
- package/src/date/constants/DATE_P_PROPERTIES.ts +10 -0
- package/src/date/constants/DATE_P_VALUES.ts +7 -0
- package/src/date/constants/DATE_TIME_PROPERTIES.ts +0 -1
- package/src/date/constants/DATE_TIME_P_VALUES.ts +7 -0
- package/src/date/constants/DATE_TIME_VALUES.ts +1 -1
- package/src/date/constants/DATE_WEEK_DAYS.ts +4 -0
- package/src/date/constants/DATE_YEAR_DAYS.ts +368 -0
- package/src/date/constants/DATE_YEAR_MONTHS.ts +2 -0
- package/src/date/constants/DATE_YEAR_QUARTERS.ts +1 -0
- package/src/date/constants/index.ts +12 -0
- package/src/date/range/getDateRange.ts +46 -42
- package/src/date/relative/Adapter.ts +2 -2
- package/src/date/relative/constants/DATE_FORMATS.ts +3 -4
- package/src/date/relative/constants/RELATIVE_CURSOR_VALUE.ts +1 -1
- package/src/date/relative/helpers/formatStatement.ts +8 -8
- package/src/date/relative/index.ts +1 -1
- package/src/filters/adapters/FDToFlatUI.ts +7 -3
- package/src/filters/adapters/FDToUI.ts +5 -6
- package/src/filters/adapters/UIToFD.ts +1 -1
- package/src/filters/adapters/UIToFlatUI.ts +9 -5
- package/src/filters/adapters/UIToOldLogic.ts +11 -3
- package/src/filters/adapters/adaptFilterData.ts +1 -1
- package/src/filters/adapters/flatUIToFD.ts +5 -1
- package/src/filters/adapters/flatUIToOldLogic.ts +57 -71
- package/src/filters/adapters/flatUIToUI.ts +4 -1
- package/src/filters/adapters/logicToFlatUI.ts +101 -77
- package/src/filters/adapters/transformFilters.ts +22 -30
- package/src/filters/constants/backend/FILTER_BACKEND_VALIDATOR.ts +1 -1
- package/src/filters/constants/common/FILTER_GROUPED_COLUMN_OPERATOR.ts +3 -0
- package/src/filters/constants/common/FILTER_OPERATOR.ts +1 -1
- package/src/filters/constants/common/FILTER_VALIDATOR.ts +1 -1
- package/src/filters/constants/common/index.ts +1 -0
- package/src/filters/helpers/backend/buildExpression.ts +11 -3
- package/src/filters/helpers/backend/buildFilters.ts +2 -2
- package/src/filters/helpers/backend/getBackendGroupValue.ts +2 -1
- package/src/filters/helpers/backend/getBackendProperty.ts +6 -3
- package/src/filters/helpers/backend/getBackendValues.ts +27 -23
- package/src/filters/helpers/builder/getFilterBuilderGeneralConfig.ts +1 -1
- package/src/filters/helpers/common/areFiltersEquals.ts +1 -1
- package/src/filters/helpers/common/arePropertiesDateP.ts +14 -0
- package/src/filters/helpers/common/excludeFiltersByParams.ts +1 -1
- package/src/filters/helpers/common/getFilterColumnLabel.ts +1 -1
- package/src/filters/helpers/common/getFilterLabel.ts +1 -1
- package/src/filters/helpers/common/getFilterid.ts +1 -1
- package/src/filters/helpers/common/getFiltersByAggregateColumn.ts +1 -1
- package/src/filters/helpers/common/getFiltersByParams.ts +6 -7
- package/src/filters/helpers/common/getFiltersByVisibility.ts +1 -1
- package/src/filters/helpers/common/getMergeFiltersSettings.ts +13 -0
- package/src/filters/helpers/common/getParamsToGetFilterSettings.ts +11 -1
- package/src/filters/helpers/common/index.ts +2 -0
- package/src/filters/helpers/common/isInValidator.ts +1 -1
- package/src/filters/helpers/common/mergeFilters.ts +30 -17
- package/src/filters/helpers/common/resolveDatasetConditions.ts +1 -1
- package/src/filters/helpers/common/resolveFilterConditions.ts +2 -3
- package/src/filters/helpers/common/resolveScopeConditions.ts +1 -1
- package/src/filters/helpers/getAggFiltersFromFilterData.ts +20 -23
- package/src/filters/helpers/getAvailableScopesIDsByConfig.ts +1 -1
- package/src/filters/helpers/getScopesByHierarchy.ts +2 -2
- package/src/filters/helpers/ui/excludeUIFlatFiltersByScopes.ts +2 -2
- package/src/filters/helpers/ui/getUIFlatFilterByParams.ts +1 -1
- package/src/filters/helpers/ui/getUIFlatFiltersByParams.ts +1 -1
- package/src/filters/helpers/ui/getUIFlatFiltersByScopes.ts +1 -1
- package/src/filters/helpers/ui/getUIValues.ts +9 -9
- package/src/filters/helpers/ui/resolveUIFlatFiltersByParams.ts +1 -1
- package/src/filters/interfaces/OLD_IFilterDetail.ts +4 -0
- package/src/filters/interfaces/backend/IFBExpression.ts +1 -1
- package/src/filters/interfaces/common/IFSFilterExtras.ts +4 -0
- package/src/filters/interfaces/common/IFSFilterExtrasInfo.ts +5 -0
- package/src/filters/interfaces/common/IFSMergeFiltersSettings.ts +8 -0
- package/src/filters/interfaces/common/IFSParamsToGetFilter.ts +2 -1
- package/src/filters/interfaces/common/IFSParamsToGetFilterEnableds.ts +9 -0
- package/src/filters/interfaces/common/IFSParamsToGetFilterSettings.ts +5 -0
- package/src/filters/interfaces/common/index.ts +3 -0
- package/src/filters/interfaces/panel/IFPSettingsFilterPanelBodyScopeScope.ts +1 -0
- package/src/filters/interfaces/panel/IFPSettingsFilterPanelHeader.ts +1 -0
- package/src/filters/interfaces/panel/IFPSettingsFilterPanelSettings.ts +4 -0
- package/src/filters/interfaces/panel/IFPSettingsFilterPanelSettingsScope.ts +7 -0
- package/src/filters/interfaces/panel/IFilterPanelConfig.ts +0 -2
- package/src/filters/interfaces/panel/index.ts +1 -0
- package/src/filters/interfaces/ui/IFUFilterExtras.ts +1 -1
- package/src/format/definition.ts +7 -8
- package/src/format/format.ts +19 -22
- package/src/general/array/delete.ts +10 -6
- package/src/general/array/filterNestedTree.ts +1 -1
- package/src/general/array/flattenDeep.ts +3 -2
- package/src/general/array/getFirstIndexFromArray.ts +8 -6
- package/src/general/array/getLastIndexFromArray.ts +7 -5
- package/src/general/function/debounce.ts +2 -2
- package/src/general/function/throttled.ts +3 -3
- package/src/general/mix/importScripts.ts +1 -1
- package/src/general/mix/isEmpty.ts +12 -7
- package/src/general/mix/isNull.ts +2 -2
- package/src/general/mix/randomId.ts +2 -2
- package/src/general/mix/size.ts +1 -1
- package/src/general/object/cloneDeep.ts +15 -6
- package/src/general/object/get.ts +59 -31
- package/src/general/object/getAttribute.ts +1 -1
- package/src/general/object/hasProperty.ts +1 -1
- package/src/general/object/index.ts +3 -2
- package/src/general/object/isObject.ts +8 -0
- package/src/general/object/mapValues.ts +2 -2
- package/src/general/object/omit.ts +2 -2
- package/src/general/object/pick.ts +1 -1
- package/src/general/string/capitalize.ts +1 -1
- package/src/index.ts +3 -1
- package/src/qrvey/getColumnsLabel.ts +5 -5
- package/src/qrvey/index.ts +3 -0
- package/src/qrvey/isComplexColumn.ts +1 -1
- package/src/qrvey/isDateColumn.ts +1 -1
- package/src/stencil/decorators/Config.ts +2 -2
- package/src/tokens/index.ts +1 -0
- package/src/tokens/isTokenLabel.ts +13 -0
- package/src/typescript/decorators/Debounce.ts +2 -2
- package/src/typescript/decorators/Throttled.ts +2 -2
- package/test/format.test.js +97 -5
- package/test/general/array/delete.test.js +64 -0
- package/test/general/array/flattenDeep.test.js +44 -0
- package/test/general/array/getFirstIndexFromArray.test.js +56 -0
- package/test/general/array/getLastIndexFromArray.test.js +56 -0
- package/test/general/mix/isEmpty.test.js +144 -0
- package/test/general/object/cloneDeep.test.js +152 -0
- package/test/general/object/get.test.js +247 -0
- package/test/relative.test.js +24 -24
|
@@ -14,7 +14,7 @@ export function getFiltersByVisibility(filterData: IFSData | IFUData, scopes: IF
|
|
|
14
14
|
filterData = cloneDeep(filterData);
|
|
15
15
|
|
|
16
16
|
filterData = getFiltersByScopesIds(filterData, scopes);
|
|
17
|
-
filterData = getFiltersByParams(filterData, { enableds: true });
|
|
17
|
+
filterData = getFiltersByParams(filterData, { enableds: { datasets: true, scopes: true, values: true } }, { filterEmptyArrays: { filter: false } });
|
|
18
18
|
|
|
19
19
|
return filterData;
|
|
20
20
|
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { IFSMergeFiltersSettings } from "../../interfaces/common/IFSMergeFiltersSettings";
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Transforms the given MergeFilters settings object. Adds the missing properties if they do not exist.
|
|
5
|
+
* @param settings an object to the MergeFilters settings
|
|
6
|
+
* @returns a new MergeFilters settings object.
|
|
7
|
+
*/
|
|
8
|
+
export function getMergeFiltersSettings(settings?: IFSMergeFiltersSettings): IFSMergeFiltersSettings {
|
|
9
|
+
return {
|
|
10
|
+
overwriteValues: settings?.overwriteValues ?? false,
|
|
11
|
+
setGroupedColumnOperator: settings?.setGroupedColumnOperator ?? true
|
|
12
|
+
};
|
|
13
|
+
}
|
|
@@ -1,5 +1,10 @@
|
|
|
1
1
|
import { IFSParamsToGetFilterSettings } from "../../interfaces";
|
|
2
2
|
|
|
3
|
+
/**
|
|
4
|
+
* Transforms the given ParamsToGetFilter settings object. Adds the missing properties if they do not exist.
|
|
5
|
+
* @param settings an object to the ParamsToGetFilter settings
|
|
6
|
+
* @returns a new ParamsToGetFilter settings object.
|
|
7
|
+
*/
|
|
3
8
|
export function getParamsToGetFilterSettings(settings?: IFSParamsToGetFilterSettings): IFSParamsToGetFilterSettings {
|
|
4
9
|
return {
|
|
5
10
|
letPassUndefinedParams: {
|
|
@@ -11,6 +16,11 @@ export function getParamsToGetFilterSettings(settings?: IFSParamsToGetFilterSett
|
|
|
11
16
|
dataset: settings?.letPassUndefinedProperties?.dataset ?? false,
|
|
12
17
|
filter: settings?.letPassUndefinedProperties?.filter ?? false,
|
|
13
18
|
scope: settings?.letPassUndefinedProperties?.scope ?? false,
|
|
19
|
+
},
|
|
20
|
+
filterEmptyArrays: {
|
|
21
|
+
dataset: settings?.filterEmptyArrays?.dataset ?? true,
|
|
22
|
+
filter: settings?.filterEmptyArrays?.filter ?? true,
|
|
23
|
+
scope: settings?.filterEmptyArrays?.scope ?? true,
|
|
14
24
|
}
|
|
15
|
-
}
|
|
25
|
+
};
|
|
16
26
|
}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export * from './areFiltersEquals';
|
|
2
|
+
export * from './arePropertiesDateP';
|
|
2
3
|
export * from './excludeFiltersByAggregateColumn';
|
|
3
4
|
export * from './excludeFiltersByParams';
|
|
4
5
|
export * from './excludeFiltersByScopes';
|
|
@@ -10,6 +11,7 @@ export * from './getFiltersByParams';
|
|
|
10
11
|
export * from './getFiltersByScopes';
|
|
11
12
|
export * from './getFiltersByScopesIds';
|
|
12
13
|
export * from './getFiltersByVisibility';
|
|
14
|
+
export * from './getMergeFiltersSettings';
|
|
13
15
|
export * from './getParamsToGetFilterSettings';
|
|
14
16
|
export * from './haveFiltersByDataset';
|
|
15
17
|
export * from './isBetweenValidator';
|
|
@@ -6,6 +6,6 @@ import { IFValidator } from "../../interfaces";
|
|
|
6
6
|
* @param validator The validator
|
|
7
7
|
* @returns true: it is a In validator; false: it is not a In validator
|
|
8
8
|
*/
|
|
9
|
-
export function isInValidator(validator: IFValidator) {
|
|
9
|
+
export function isInValidator(validator: IFValidator): boolean {
|
|
10
10
|
return validator === FILTER_VALIDATOR.IN;
|
|
11
11
|
}
|
|
@@ -1,5 +1,10 @@
|
|
|
1
1
|
import { cloneDeep, isEmpty } from "../../../general";
|
|
2
|
-
import {
|
|
2
|
+
import { FILTER_GROUPED_COLUMN_OPERATOR } from "../../constants/common/FILTER_GROUPED_COLUMN_OPERATOR";
|
|
3
|
+
import { IFSData, IFSDataset, IFSFilter, IFSScope, IFSValue, IFSValueRange, IFSValueRelativeDate, IFUData, IFValue } from "../../interfaces";
|
|
4
|
+
import { IFSMergeFiltersSettings } from "../../interfaces/common/IFSMergeFiltersSettings";
|
|
5
|
+
import { getMergeFiltersSettings } from "./getMergeFiltersSettings";
|
|
6
|
+
import { isInValidator } from "./isInValidator";
|
|
7
|
+
import { isNullValidator } from "./isNullValidator";
|
|
3
8
|
import { isRangeValidator } from "./isRangeValidator";
|
|
4
9
|
import { isRegularValidator } from "./isRegularValidator";
|
|
5
10
|
import { resolveDatasetConditions } from "./resolveDatasetConditions";
|
|
@@ -13,7 +18,7 @@ import { resolveScopeConditions } from "./resolveScopeConditions";
|
|
|
13
18
|
* @param overwriteValues Flag to overwrite or not the filter values
|
|
14
19
|
* @returns a new filter data structure
|
|
15
20
|
*/
|
|
16
|
-
export function mergeFilters(filterData1: IFSData | IFUData, filterData2: IFSData | IFUData,
|
|
21
|
+
export function mergeFilters(filterData1: IFSData | IFUData, filterData2: IFSData | IFUData, settings?: IFSMergeFiltersSettings): IFSData | IFUData {
|
|
17
22
|
if (isEmpty(filterData1) || isEmpty(filterData1.scopes)) {
|
|
18
23
|
if (isEmpty(filterData2) || isEmpty(filterData2.scopes)) return;
|
|
19
24
|
return filterData2;
|
|
@@ -23,12 +28,13 @@ export function mergeFilters(filterData1: IFSData | IFUData, filterData2: IFSDat
|
|
|
23
28
|
filterData1 = cloneDeep(filterData1);
|
|
24
29
|
filterData2 = cloneDeep(filterData2);
|
|
25
30
|
|
|
31
|
+
settings = getMergeFiltersSettings(settings);
|
|
26
32
|
return {
|
|
27
33
|
enabled: filterData1.enabled,
|
|
28
|
-
scopes: mergeScopes(filterData1.scopes, filterData2.scopes,
|
|
34
|
+
scopes: mergeScopes(filterData1.scopes, filterData2.scopes, settings),
|
|
29
35
|
section: filterData1.section,
|
|
30
36
|
version: filterData1.version
|
|
31
|
-
}
|
|
37
|
+
};
|
|
32
38
|
}
|
|
33
39
|
|
|
34
40
|
/**
|
|
@@ -38,14 +44,14 @@ export function mergeFilters(filterData1: IFSData | IFUData, filterData2: IFSDat
|
|
|
38
44
|
* @param overwriteValues Flag to overwrite or not the filter values
|
|
39
45
|
* @returns a new scope structure array
|
|
40
46
|
*/
|
|
41
|
-
function mergeScopes(scopes1: IFSScope[] = [], scopes2: IFSScope[] = [],
|
|
47
|
+
function mergeScopes(scopes1: IFSScope[] = [], scopes2: IFSScope[] = [], settings?: IFSMergeFiltersSettings): IFSScope[] {
|
|
42
48
|
let newScopes = scopes1.reduce((scopes: IFSScope[], scope1: IFSScope) => {
|
|
43
49
|
const scope2Index = scopes2.findIndex(scope2 => resolveScopeConditions(scope2, { scope: scope1.scope, scopeid: scope1.scopeid }));
|
|
44
50
|
if (scope2Index > -1) {
|
|
45
51
|
scope1 = {
|
|
46
52
|
...scope1,
|
|
47
|
-
datasets: mergeDatasets(scope1.datasets, scopes2[scope2Index].datasets,
|
|
48
|
-
}
|
|
53
|
+
datasets: mergeDatasets(scope1.datasets, scopes2[scope2Index].datasets, settings)
|
|
54
|
+
};
|
|
49
55
|
scopes2.splice(scope2Index, 1);
|
|
50
56
|
}
|
|
51
57
|
scopes.push(scope1);
|
|
@@ -63,14 +69,14 @@ function mergeScopes(scopes1: IFSScope[] = [], scopes2: IFSScope[] = [], overwri
|
|
|
63
69
|
* @param overwriteValues Flag to overwrite or not the filter values
|
|
64
70
|
* @returns a new dataset structure array
|
|
65
71
|
*/
|
|
66
|
-
function mergeDatasets(datasets1: IFSDataset[] = [], datasets2: IFSDataset[] = [],
|
|
72
|
+
function mergeDatasets(datasets1: IFSDataset[] = [], datasets2: IFSDataset[] = [], settings?: IFSMergeFiltersSettings): IFSDataset[] {
|
|
67
73
|
let newDatasets = datasets1.reduce((datasets: IFSDataset[], dataset1: IFSDataset) => {
|
|
68
74
|
const dataset2Index = datasets2.findIndex(dataset2 => resolveDatasetConditions(dataset2, { qrveyid: dataset1.qrveyid, linkid: dataset1.linkid }));
|
|
69
75
|
if (dataset2Index > -1) {
|
|
70
76
|
dataset1 = {
|
|
71
77
|
...dataset1,
|
|
72
|
-
filters: mergeFilterss(dataset1.filters, datasets2[dataset2Index].filters,
|
|
73
|
-
}
|
|
78
|
+
filters: mergeFilterss(dataset1.filters, datasets2[dataset2Index].filters, settings)
|
|
79
|
+
};
|
|
74
80
|
datasets2.splice(dataset2Index, 1);
|
|
75
81
|
}
|
|
76
82
|
datasets.push(dataset1);
|
|
@@ -88,15 +94,14 @@ function mergeDatasets(datasets1: IFSDataset[] = [], datasets2: IFSDataset[] = [
|
|
|
88
94
|
* @param overwriteValues Flag to overwrite or not the filter values
|
|
89
95
|
* @returns a new filter structure array
|
|
90
96
|
*/
|
|
91
|
-
function mergeFilterss(filters1: IFSFilter[] = [], filters2: IFSFilter[] = [],
|
|
97
|
+
function mergeFilterss(filters1: IFSFilter[] = [], filters2: IFSFilter[] = [], settings?: IFSMergeFiltersSettings): IFSFilter[] {
|
|
92
98
|
let newFilters = filters1.reduce((filters: IFSFilter[], filter1: IFSFilter) => {
|
|
93
99
|
const filter2Index = filters2.findIndex(filter2 => resolveFilterConditions(filter2, { column: filter1.column, dateSection: filter1.dateSection, panelid: filter1.extras.panelid, property: filter1.property, validator: filter1.validator }));
|
|
94
100
|
if (filter2Index > -1) {
|
|
95
|
-
filter1 = {
|
|
96
|
-
...filter1,
|
|
97
|
-
values: mergeValues(filter1, filters2[filter2Index], overwriteValues)
|
|
98
|
-
}
|
|
101
|
+
filter1 = { ...filter1, values: mergeValues(filter1, filters2[filter2Index], settings.overwriteValues) };
|
|
99
102
|
filters2.splice(filter2Index, 1);
|
|
103
|
+
} else {
|
|
104
|
+
filter1 = { ...filter1, operator: settings.setGroupedColumnOperator ? FILTER_GROUPED_COLUMN_OPERATOR : filter1.operator };
|
|
100
105
|
}
|
|
101
106
|
filters.push(filter1);
|
|
102
107
|
return filters;
|
|
@@ -118,7 +123,15 @@ function mergeValues(filter1: IFSFilter, filter2: IFSFilter, overwrite = false):
|
|
|
118
123
|
|
|
119
124
|
let newValues = [];
|
|
120
125
|
if (!overwrite) {
|
|
121
|
-
if (
|
|
126
|
+
if (isInValidator(filter1.validator)) {
|
|
127
|
+
newValues = filter1.values.reduce((values: IFValue[], value1: IFSValueRelativeDate) => {
|
|
128
|
+
const value2Index = (filter2.values as IFSValueRelativeDate[]).findIndex(value2 => value2.anchor === value1.anchor && value2.cursor === value1.cursor && value2.includeCurrent === value1.includeCurrent && value2.isCalendarDate === value1.isCalendarDate && value2.number === value1.number && value2.unit === value1.unit);
|
|
129
|
+
if (value2Index === -1) {
|
|
130
|
+
values.push(filter2.values[value2Index]);
|
|
131
|
+
}
|
|
132
|
+
return values;
|
|
133
|
+
}, filter1.values as IFValue[]);
|
|
134
|
+
} else if (isRangeValidator(filter1.validator)) {
|
|
122
135
|
newValues = filter1.values.reduce((values: IFValue[], value1: IFSValueRange) => {
|
|
123
136
|
const value2Index = (filter2.values as IFSValueRange[]).findIndex(value2 => value2.max === value1.max && value2.min === value1.min);
|
|
124
137
|
if (value2Index === -1) {
|
|
@@ -126,7 +139,7 @@ function mergeValues(filter1: IFSFilter, filter2: IFSFilter, overwrite = false):
|
|
|
126
139
|
}
|
|
127
140
|
return values;
|
|
128
141
|
}, filter1.values as IFValue[]);
|
|
129
|
-
} else if (isRegularValidator(filter1.validator)) {
|
|
142
|
+
} else if (isRegularValidator(filter1.validator) || isNullValidator(filter1.validator)) {
|
|
130
143
|
newValues = filter1.values.reduce((values: IFValue[], value1: IFSValue) => {
|
|
131
144
|
const value2Index = (filter2.values as IFSValue[]).findIndex(value2 => value2.imageUrl === value1.imageUrl && value2.value === value1.value);
|
|
132
145
|
if (value2Index === -1) {
|
|
@@ -10,7 +10,7 @@ import { IFSDataset, IFSParamsToGetFilter } from "../../interfaces";
|
|
|
10
10
|
* @returns true: the condition is satisfied
|
|
11
11
|
*/
|
|
12
12
|
export function resolveDatasetConditions(dataset: IFSDataset, params: IFSParamsToGetFilter, letPassUndefinedProperties = false, letPassUndefinedParams = true): boolean {
|
|
13
|
-
return (!_hasProperty(params, 'enableds') || (letPassUndefinedProperties && dataset.enabled == null) || (letPassUndefinedParams && params.enableds == null) || params.enableds === dataset.enabled) &&
|
|
13
|
+
return (!_hasProperty(params, 'enableds') || !_hasProperty(params.enableds, 'datasets') || (letPassUndefinedProperties && dataset.enabled == null) || (letPassUndefinedParams && params.enableds.datasets == null) || params.enableds.datasets === dataset.enabled) &&
|
|
14
14
|
(!_hasProperty(params, 'qrveyid') || (letPassUndefinedProperties && dataset.qrveyid == null) || (letPassUndefinedParams && isEmpty(params.qrveyid)) || params.qrveyid === dataset.qrveyid) &&
|
|
15
15
|
(!_hasProperty(params, 'linkid') || (letPassUndefinedProperties && dataset.linkid == null) || (letPassUndefinedParams && isEmpty(params.linkid)) || params.linkid === dataset.linkid) &&
|
|
16
16
|
dataset.filters.length > 0;
|
|
@@ -10,7 +10,7 @@ import { IFSFilter, IFSParamsToGetFilter } from "../../interfaces";
|
|
|
10
10
|
* @returns true: the condition is satisfied
|
|
11
11
|
*/
|
|
12
12
|
export function resolveFilterConditions(filter: IFSFilter, params: IFSParamsToGetFilter, letPassUndefinedProperties = false, letPassUndefinedParams = true): boolean {
|
|
13
|
-
return (!_hasProperty(params, 'enableds') || (letPassUndefinedProperties && filter.enabled == null) || (letPassUndefinedParams && params.enableds == null) || params.enableds === filter.enabled) &&
|
|
13
|
+
return (!_hasProperty(params, 'enableds') || !_hasProperty(params.enableds, 'filters') || (letPassUndefinedProperties && filter.enabled == null) || (letPassUndefinedParams && params.enableds.filters == null) || params.enableds.filters === filter.enabled) &&
|
|
14
14
|
(!_hasProperty(params, 'dateSection') || (letPassUndefinedProperties && filter.dateSection == null) || (letPassUndefinedParams && isEmpty(params.dateSection)) || params.dateSection === filter.dateSection) &&
|
|
15
15
|
(!_hasProperty(params, 'panelid') || (letPassUndefinedProperties && filter.extras.panelid == null) || (letPassUndefinedParams && isEmpty(params.panelid)) || params.panelid === filter.extras.panelid) &&
|
|
16
16
|
(!_hasProperty(params, 'property') || (letPassUndefinedProperties && filter.property == null) || (letPassUndefinedParams && isEmpty(params.property)) || params.property === filter.property) &&
|
|
@@ -18,6 +18,5 @@ export function resolveFilterConditions(filter: IFSFilter, params: IFSParamsToGe
|
|
|
18
18
|
(!_hasProperty(params, 'column') || (letPassUndefinedProperties && filter.column == null) || (letPassUndefinedParams && isEmpty(params.column)) || (params.column?.id === filter.column.id &&
|
|
19
19
|
params.column?.qrveyid === filter.column.qrveyid &&
|
|
20
20
|
params.column?.linkid === filter.column.linkid &&
|
|
21
|
-
params.column?.aggregate === filter.column.aggregate))
|
|
22
|
-
filter.values.length > 0
|
|
21
|
+
params.column?.aggregate === filter.column.aggregate));
|
|
23
22
|
}
|
|
@@ -10,7 +10,7 @@ import { IFSParamsToGetFilter, IFSScope } from "../../interfaces";
|
|
|
10
10
|
* @returns true: the condition is satisfied
|
|
11
11
|
*/
|
|
12
12
|
export function resolveScopeConditions(scope: IFSScope, params: IFSParamsToGetFilter, letPassUndefinedProperties = false, letPassUndefinedParams = true): boolean {
|
|
13
|
-
return (!_hasProperty(params, 'enableds') || (letPassUndefinedProperties && scope.enabled == null) || (letPassUndefinedParams && params.enableds == null) || params.enableds === scope.enabled) &&
|
|
13
|
+
return (!_hasProperty(params, 'enableds') || !_hasProperty(params.enableds, 'scopes') || (letPassUndefinedProperties && scope.enabled == null) || (letPassUndefinedParams && params.enableds.scopes == null) || params.enableds.scopes === scope.enabled) &&
|
|
14
14
|
(!_hasProperty(params, 'scope') || (letPassUndefinedProperties && scope.scope == null) || (letPassUndefinedParams && isEmpty(params.scope)) || scope.scope === params.scope) &&
|
|
15
15
|
(!_hasProperty(params, 'scopeid') || (letPassUndefinedProperties && scope.scopeid == null) || (letPassUndefinedParams && isEmpty(params.scopeid)) || scope.scopeid === params.scopeid) &&
|
|
16
16
|
scope.datasets.filter.length > 0;
|
|
@@ -1,8 +1,6 @@
|
|
|
1
1
|
import { isEmpty } from "../../general";
|
|
2
|
-
import {
|
|
3
|
-
import { getBackendValidator, getBackendValues } from "./backend";
|
|
2
|
+
import { IFBFilterAggregate, IFSData } from "../interfaces";
|
|
4
3
|
import { getFiltersByAggregateColumn } from "./common";
|
|
5
|
-
import { FDToFlatUI } from "../adapters";
|
|
6
4
|
|
|
7
5
|
/**
|
|
8
6
|
*
|
|
@@ -11,30 +9,29 @@ import { FDToFlatUI } from "../adapters";
|
|
|
11
9
|
* @returns
|
|
12
10
|
*/
|
|
13
11
|
// [TODO: FILTERS - FIX AGGREGATE FILTERS]
|
|
14
|
-
export function getAggFiltersFromFilterData(filterData: IFSData,
|
|
12
|
+
export function getAggFiltersFromFilterData(filterData: IFSData, _summaries: any[]): IFBFilterAggregate {
|
|
15
13
|
filterData = { ...getFiltersByAggregateColumn(filterData) };
|
|
16
14
|
if (isEmpty(filterData)) return;
|
|
17
15
|
|
|
18
|
-
const uFilters = FDToFlatUI(filterData);
|
|
16
|
+
// const uFilters = FDToFlatUI(filterData);
|
|
19
17
|
|
|
20
|
-
const aggFilters: IFBExpressionAggregate[] = uFilters.map(uFilter => {
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
}).filter(Boolean);
|
|
18
|
+
// const aggFilters: IFBExpressionAggregate[] = uFilters.map(uFilter => {
|
|
19
|
+
// const summaryIndex = summaries.findIndex(summary =>
|
|
20
|
+
// uFilter.column.id === summary.questionid &&
|
|
21
|
+
// uFilter.column.qrveyid === summary.qrveyid &&
|
|
22
|
+
// uFilter.column.linkid === summary.linkid &&
|
|
23
|
+
// uFilter.column.aggregate === summary.aggregate
|
|
24
|
+
// );
|
|
25
|
+
// if (summaryIndex > -1) {
|
|
26
|
+
// return {
|
|
27
|
+
// enabled: uFilter.enabled,
|
|
28
|
+
// summaryIndex,
|
|
29
|
+
// validationType: getBackendValidator(uFilter.validator),
|
|
30
|
+
// value: getBackendValues(uFilter),
|
|
31
|
+
// };
|
|
32
|
+
// }
|
|
33
|
+
// }).filter(Boolean);
|
|
36
34
|
|
|
37
|
-
debugger
|
|
38
35
|
// // [TODO: FILTERS - Adapt filter.validator and filter.values in the backend format]
|
|
39
36
|
// const aggFilters: IFBFilterAggregate[] = filterData.scopes.map((scope) => {
|
|
40
37
|
// scope.datasets.forEach(dataset => {
|
|
@@ -61,5 +58,5 @@ export function getAggFiltersFromFilterData(filterData: IFSData, summaries: any[
|
|
|
61
58
|
|
|
62
59
|
// }).filter(aggFilter => aggFilter && aggFilter.expressions && aggFilter.expressions.length);
|
|
63
60
|
|
|
64
|
-
return // aggFilters && concatAggFilters(aggFilters);
|
|
61
|
+
return; // aggFilters && concatAggFilters(aggFilters);
|
|
65
62
|
}
|
|
@@ -14,5 +14,5 @@ export function getAvailableScopesIDsByConfig(config: any = {}): IFSAvailableSco
|
|
|
14
14
|
tabid: getAttribute(config, 'tab_id') || config.tabid,
|
|
15
15
|
pageid: getAttribute(config, 'page_id') || config.pageid,
|
|
16
16
|
defaultid: getAttribute(config, 'default_id') || config.defaultid,
|
|
17
|
-
}
|
|
17
|
+
};
|
|
18
18
|
}
|
|
@@ -10,9 +10,9 @@ import { IFScope, IFSScopeID } from "../interfaces";
|
|
|
10
10
|
export function getScopesByHierarchy(scopes: IFSScopeID[] = [], currentScope: IFScope = FILTER_SCOPE.GLOBAL): IFSScopeID[] {
|
|
11
11
|
const scopeIndex = scopes.findIndex(s => s.label === currentScope);
|
|
12
12
|
const chartScopeIndex = scopes.findIndex(s => s.label === FILTER_SCOPE.CHART);
|
|
13
|
-
return
|
|
13
|
+
return scopeIndex !== -1
|
|
14
14
|
? scopes.slice(0, scopeIndex)
|
|
15
|
-
:
|
|
15
|
+
: chartScopeIndex !== -1
|
|
16
16
|
? scopes.slice(0, chartScopeIndex)
|
|
17
17
|
: [];
|
|
18
18
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { cloneDeep, isEmpty } from "../../../general";
|
|
2
|
-
import { IFScope,
|
|
2
|
+
import { IFScope, IFUFlattenedFilter } from "../../interfaces";
|
|
3
3
|
|
|
4
4
|
/**
|
|
5
5
|
* Excludes and returns a UI Flat Filters without filters by the given scopes
|
|
@@ -7,7 +7,7 @@ import { IFScope, IFSData, IFUFlattenedFilter } from "../../interfaces";
|
|
|
7
7
|
* @param scopes collection of scopes types
|
|
8
8
|
* @returns The new array of UI Flattened filters
|
|
9
9
|
*/
|
|
10
|
-
export function excludeUIFlatFiltersByScopes(uFilters: IFUFlattenedFilter[] = [], scopes: IFScope[]): IFUFlattenedFilter[] {
|
|
10
|
+
export function excludeUIFlatFiltersByScopes(uFilters: IFUFlattenedFilter[] = [], scopes: IFScope[] = []): IFUFlattenedFilter[] {
|
|
11
11
|
if (isEmpty(uFilters)) return [];
|
|
12
12
|
|
|
13
13
|
uFilters = cloneDeep(uFilters);
|
|
@@ -14,7 +14,7 @@ import { resolveUIFlatFilterByParams } from "./resolveUIFlatFiltersByParams";
|
|
|
14
14
|
* - Property type
|
|
15
15
|
* @returns The index of the uFilter array or the Filter object s
|
|
16
16
|
*/
|
|
17
|
-
export function getUIFlatFilterByParams(uFilters: IFUFlattenedFilter[] = [], params: IFUParamsToGetFilter, getIndex = false): number | IFUFlattenedFilter {
|
|
17
|
+
export function getUIFlatFilterByParams(uFilters: IFUFlattenedFilter[] = [], params: IFUParamsToGetFilter = {}, getIndex = false): number | IFUFlattenedFilter {
|
|
18
18
|
if (isEmpty(params)) return;
|
|
19
19
|
uFilters = cloneDeep(uFilters);
|
|
20
20
|
|
|
@@ -15,7 +15,7 @@ import { resolveUIFlatFilterByParams } from "./resolveUIFlatFiltersByParams";
|
|
|
15
15
|
* - Enabled flags
|
|
16
16
|
* @returns The index of the uFilter array or the Filter object s
|
|
17
17
|
*/
|
|
18
|
-
export function getUIFlatFiltersByParams(uFilters: IFUFlattenedFilter[] = [], params: IFUParamsToGetFilter): IFUFlattenedFilter[] {
|
|
18
|
+
export function getUIFlatFiltersByParams(uFilters: IFUFlattenedFilter[] = [], params: IFUParamsToGetFilter = {}): IFUFlattenedFilter[] {
|
|
19
19
|
if (isEmpty(params)) return;
|
|
20
20
|
uFilters = cloneDeep(uFilters);
|
|
21
21
|
|
|
@@ -7,7 +7,7 @@ import { IFScope, IFUFlattenedFilter } from "../../interfaces";
|
|
|
7
7
|
* @param scopes collection of scopes types
|
|
8
8
|
* @returns The new array of UI Flattened filters
|
|
9
9
|
*/
|
|
10
|
-
export function getUIFlatFiltersByScopes(uFilters: IFUFlattenedFilter[] = [], scopes: IFScope[]): IFUFlattenedFilter[] {
|
|
10
|
+
export function getUIFlatFiltersByScopes(uFilters: IFUFlattenedFilter[] = [], scopes: IFScope[] = []): IFUFlattenedFilter[] {
|
|
11
11
|
if (isEmpty(uFilters)) return [];
|
|
12
12
|
uFilters = cloneDeep(uFilters);
|
|
13
13
|
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { FILTER_VALIDATOR, FILTER_VALIDATOR_VALUE} from "../../constants";
|
|
1
|
+
import { FILTER_VALIDATOR, FILTER_VALIDATOR_VALUE } from "../../constants";
|
|
2
2
|
import { RELATIVE_CURSOR, RELATIVE_CURSOR_VALUE } from "../../../date";
|
|
3
3
|
import { IFSFilter, IFSValue, IFSValueRange, IFSValueRanking, IFSValueRelativeDate, IFUValue } from "../../interfaces";
|
|
4
4
|
import { COLUMN } from "../../../constants";
|
|
@@ -12,7 +12,7 @@ export function getUIValues(filter: IFSFilter, addEnableds = false, rankingGroup
|
|
|
12
12
|
case FILTER_VALIDATOR.GREATER_THAN_EQUAL:
|
|
13
13
|
return (filter.values as IFSValueRange[]).map(value => ({
|
|
14
14
|
value: value.min,
|
|
15
|
-
enabled: addEnableds ?
|
|
15
|
+
enabled: addEnableds ? value.enabled != null ? value.enabled : true : undefined,
|
|
16
16
|
}));
|
|
17
17
|
case FILTER_VALIDATOR.BEFORE_ON:
|
|
18
18
|
case FILTER_VALIDATOR.LESS_THAN_EQUAL:
|
|
@@ -20,26 +20,26 @@ export function getUIValues(filter: IFSFilter, addEnableds = false, rankingGroup
|
|
|
20
20
|
case FILTER_VALIDATOR.LESS_THAN:
|
|
21
21
|
return (filter.values as IFSValueRange[]).map(value => ({
|
|
22
22
|
value: value.max,
|
|
23
|
-
enabled: addEnableds ?
|
|
23
|
+
enabled: addEnableds ? value.enabled != null ? value.enabled : true : undefined,
|
|
24
24
|
}));
|
|
25
25
|
case FILTER_VALIDATOR.BETWEEN_INCLUSIVE:
|
|
26
26
|
case FILTER_VALIDATOR.BETWEEN_EXCLUSIVE:
|
|
27
27
|
return (filter.values as IFSValueRange[]).map(value => ({
|
|
28
28
|
value: `${value.min} - ${value.max}`,
|
|
29
|
-
enabled: addEnableds ?
|
|
29
|
+
enabled: addEnableds ? value.enabled != null ? value.enabled : true : undefined,
|
|
30
30
|
}));
|
|
31
31
|
case FILTER_VALIDATOR.IS_NULL:
|
|
32
32
|
case FILTER_VALIDATOR.IS_NOT_NULL:
|
|
33
33
|
return [{
|
|
34
34
|
value: FILTER_VALIDATOR_VALUE[filter.validator].label,
|
|
35
|
-
enabled: addEnableds ? filter.enabled : undefined,
|
|
35
|
+
enabled: addEnableds ? (filter.values as IFSValue[])[0]?.enabled : undefined,
|
|
36
36
|
}];
|
|
37
37
|
case FILTER_VALIDATOR.IN:
|
|
38
38
|
return (filter.values as IFSValueRelativeDate[]).map(value => ({
|
|
39
39
|
value:
|
|
40
40
|
`${RELATIVE_CURSOR_VALUE[value.cursor].label} ${value.cursor !== RELATIVE_CURSOR.THIS && value.number > 1 ? value.number : ''} ${getValueUiUnitRelativeDate(value)} ${value.cursor !== RELATIVE_CURSOR.THIS ? `from ${value.anchor || 'current date'}`: ''}`,
|
|
41
41
|
enabled: addEnableds ? filter.enabled : undefined,
|
|
42
|
-
}))
|
|
42
|
+
}));
|
|
43
43
|
default:
|
|
44
44
|
if (filter.column.type === COLUMN.RANKING && isEmpty(filter.column.aggregate)) {
|
|
45
45
|
return getRankingUIValues(filter.values as IFSValueRanking[][], addEnableds, rankingGroupIndex);
|
|
@@ -47,17 +47,17 @@ export function getUIValues(filter: IFSFilter, addEnableds = false, rankingGroup
|
|
|
47
47
|
return ((filter.values || []) as IFSValue[]).map(val => ({
|
|
48
48
|
imageUrl: val.imageUrl,
|
|
49
49
|
value: val.value,
|
|
50
|
-
enabled: addEnableds ?
|
|
50
|
+
enabled: addEnableds ? val.enabled != null ? val.enabled : true : undefined,
|
|
51
51
|
valueid: val.valueid,
|
|
52
52
|
}));
|
|
53
53
|
}
|
|
54
54
|
}
|
|
55
55
|
|
|
56
56
|
function getValueUiUnitRelativeDate(relative: IFSValueRelativeDate) {
|
|
57
|
-
return relative.cursor !== RELATIVE_CURSOR.THIS && relative.number > 1 ? `${relative.unit}s`: relative.unit
|
|
57
|
+
return relative.cursor !== RELATIVE_CURSOR.THIS && relative.number > 1 ? `${relative.unit}s`: relative.unit;
|
|
58
58
|
}
|
|
59
59
|
|
|
60
|
-
function getRankingUIValues(values: IFSValueRanking[][], addEnableds = false
|
|
60
|
+
function getRankingUIValues(values: IFSValueRanking[][], addEnableds = false, rankingGroupIndex?: number) {
|
|
61
61
|
const flattenValues: IFSValueRanking[] = rankingGroupIndex == null ? flattenDeep(values) : values[rankingGroupIndex];
|
|
62
62
|
return flattenValues.map((rankingValue) => ({
|
|
63
63
|
rankingIndex: rankingGroupIndex,
|
|
@@ -16,5 +16,5 @@ export function resolveUIFlatFilterByParams(filter: IFUFlattenedFilter, params:
|
|
|
16
16
|
(isEmpty(params.scopeid) || filter.extras.scopeid === params.scopeid) &&
|
|
17
17
|
(isEmpty(params.panelid) || filter.extras.panelid === params.panelid) &&
|
|
18
18
|
(isEmpty(params.validator) || filter.validator === params.validator) &&
|
|
19
|
-
(isEmpty(params.property) || filter.property === params.property)
|
|
19
|
+
(isEmpty(params.property) || filter.property === params.property);
|
|
20
20
|
}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { IQrveyColumn } from "../../interfaces/Qrvey.Interface";
|
|
2
|
+
import { IFSFilterExtrasInfo } from "./common";
|
|
2
3
|
import { IFDateSection } from "./IFDateSection";
|
|
3
4
|
import { IFOperator } from "./IFOperator";
|
|
4
5
|
import { IFProperty } from "./IFProperty";
|
|
@@ -25,6 +26,7 @@ export interface OLD_IFilterDetail {
|
|
|
25
26
|
panelid?: string;
|
|
26
27
|
panelName?: string;
|
|
27
28
|
expressionid?: string;
|
|
29
|
+
info?: IFSFilterExtrasInfo;
|
|
28
30
|
scope?: IFScope;
|
|
29
31
|
scopeid?: string;
|
|
30
32
|
scopeEnabled?: boolean;
|
|
@@ -37,4 +39,6 @@ export interface OLD_IFilterDetail {
|
|
|
37
39
|
}[] | IFUValue[];
|
|
38
40
|
section?: IFSection;
|
|
39
41
|
groupValue?: IFProperty
|
|
42
|
+
|
|
43
|
+
extras?: any; // Specific case for those filters that need to store something else
|
|
40
44
|
}
|