@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
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const DATE_YEAR_MONTHS: string[];
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const DATE_YEAR_QUARTERS: string[];
|
|
@@ -1,3 +1,15 @@
|
|
|
1
|
+
export * from './DATE_DAY_HOURS';
|
|
2
|
+
export * from './DATE_HOUR_MINUTES';
|
|
3
|
+
export * from './DATE_MINUTE_SECONDS';
|
|
4
|
+
export * from './DATE_MONTH_DAYS';
|
|
5
|
+
export * from './DATE_P_PROPERTIES';
|
|
6
|
+
export * from './DATE_P_VALUES';
|
|
1
7
|
export * from './DATE_PROPERTY';
|
|
8
|
+
export * from './DATE_PROPERTY_VALUE';
|
|
9
|
+
export * from './DATE_TIME_P_VALUES';
|
|
2
10
|
export * from './DATE_TIME_PROPERTIES';
|
|
3
11
|
export * from './DATE_TIME_VALUES';
|
|
12
|
+
export * from './DATE_WEEK_DAYS';
|
|
13
|
+
export * from './DATE_YEAR_DAYS';
|
|
14
|
+
export * from './DATE_YEAR_MONTHS';
|
|
15
|
+
export * from './DATE_YEAR_QUARTERS';
|
|
@@ -10,6 +10,18 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
10
10
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
11
11
|
};
|
|
12
12
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
__exportStar(require("./DATE_DAY_HOURS"), exports);
|
|
14
|
+
__exportStar(require("./DATE_HOUR_MINUTES"), exports);
|
|
15
|
+
__exportStar(require("./DATE_MINUTE_SECONDS"), exports);
|
|
16
|
+
__exportStar(require("./DATE_MONTH_DAYS"), exports);
|
|
17
|
+
__exportStar(require("./DATE_P_PROPERTIES"), exports);
|
|
18
|
+
__exportStar(require("./DATE_P_VALUES"), exports);
|
|
13
19
|
__exportStar(require("./DATE_PROPERTY"), exports);
|
|
20
|
+
__exportStar(require("./DATE_PROPERTY_VALUE"), exports);
|
|
21
|
+
__exportStar(require("./DATE_TIME_P_VALUES"), exports);
|
|
14
22
|
__exportStar(require("./DATE_TIME_PROPERTIES"), exports);
|
|
15
23
|
__exportStar(require("./DATE_TIME_VALUES"), exports);
|
|
24
|
+
__exportStar(require("./DATE_WEEK_DAYS"), exports);
|
|
25
|
+
__exportStar(require("./DATE_YEAR_DAYS"), exports);
|
|
26
|
+
__exportStar(require("./DATE_YEAR_MONTHS"), exports);
|
|
27
|
+
__exportStar(require("./DATE_YEAR_QUARTERS"), exports);
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.getDateRange = void 0;
|
|
4
4
|
const index_1 = require("../../general/index");
|
|
5
|
+
const tokens_1 = require("../../tokens");
|
|
5
6
|
/**
|
|
6
7
|
* Get date range object from a string date value
|
|
7
8
|
*
|
|
@@ -40,45 +41,52 @@ function getDateRange(value, dateGroupLabel = 'DAY', withTime = true) {
|
|
|
40
41
|
const range = {};
|
|
41
42
|
const upperCaseDateGroup = dateGroupLabel.toUpperCase();
|
|
42
43
|
const [timeFrom, timeTo] = withTime ? getStringTimeRange(value, upperCaseDateGroup) : ['', ''];
|
|
43
|
-
const isToken =
|
|
44
|
+
const isToken = tokens_1.isTokenLabel(value);
|
|
44
45
|
switch (upperCaseDateGroup) {
|
|
45
|
-
case 'YEAR':
|
|
46
|
+
case 'YEAR': {
|
|
46
47
|
const yearRange = !isToken ? getYearRange(value) : { from: `01/01/${value}`, to: `12/31/${value}` };
|
|
47
48
|
range.from = `${yearRange.from}${timeFrom}`;
|
|
48
49
|
range.to = `${yearRange.to}${timeTo}`;
|
|
49
50
|
break;
|
|
50
|
-
|
|
51
|
+
}
|
|
52
|
+
case 'QUARTER': {
|
|
51
53
|
const quarterRange = !isToken ? getQuarterRange(value) : { from: value, to: value };
|
|
52
54
|
range.from = `${quarterRange.from}${timeFrom}`;
|
|
53
55
|
range.to = `${quarterRange.to}${timeTo}`;
|
|
54
56
|
break;
|
|
55
|
-
|
|
57
|
+
}
|
|
58
|
+
case 'MONTH': {
|
|
56
59
|
const monthRange = monthInclideTokens(value) ? getMonthRangeWithToken(value) : getMonthRange(value);
|
|
57
60
|
range.from = `${monthRange.from}${timeFrom}`;
|
|
58
61
|
range.to = `${monthRange.to}${timeTo}`;
|
|
59
62
|
break;
|
|
60
|
-
|
|
63
|
+
}
|
|
64
|
+
case 'WEEK': {
|
|
61
65
|
const weekRange = !isToken ? getWeekRange(value) : { from: value, to: value };
|
|
62
66
|
range.from = `${weekRange.from}${timeFrom}`;
|
|
63
67
|
range.to = `${weekRange.to}${timeTo}`;
|
|
64
68
|
break;
|
|
65
|
-
|
|
69
|
+
}
|
|
70
|
+
case 'HOUR': {
|
|
66
71
|
const hourRange = !isToken ? getHourRange(value) : { from: value, to: value };
|
|
67
72
|
range.from = hourRange.from;
|
|
68
73
|
range.to = hourRange.to;
|
|
69
74
|
break;
|
|
70
|
-
|
|
75
|
+
}
|
|
76
|
+
case 'MINUTE': {
|
|
71
77
|
const minuteRange = !isToken ? getMinuteRange(value) : { from: value, to: value };
|
|
72
78
|
range.from = minuteRange.from;
|
|
73
79
|
range.to = minuteRange.to;
|
|
74
80
|
break;
|
|
75
|
-
|
|
81
|
+
}
|
|
82
|
+
default: {
|
|
76
83
|
const dayFrom = new Date(value);
|
|
77
84
|
const dayTo = new Date(value);
|
|
78
85
|
const includTokens = includeTokens(value, '/');
|
|
79
86
|
range.from = `${!includTokens ? getStringDate(dayFrom) : value}${timeFrom}`;
|
|
80
87
|
range.to = `${!includTokens ? getStringDate(dayTo) : value}${timeTo}`;
|
|
81
88
|
break;
|
|
89
|
+
}
|
|
82
90
|
}
|
|
83
91
|
return range;
|
|
84
92
|
}
|
|
@@ -158,7 +166,7 @@ function getWeek(date) {
|
|
|
158
166
|
if (target.getDay() !== 4) {
|
|
159
167
|
target.setMonth(0, 1 + ((4 - target.getDay()) + 7) % 7);
|
|
160
168
|
}
|
|
161
|
-
return 1 + Math.ceil((firstThursday -
|
|
169
|
+
return 1 + Math.ceil((firstThursday - +target) / 604800000);
|
|
162
170
|
}
|
|
163
171
|
function getHourRange(date) {
|
|
164
172
|
const target = new Date(date.valueOf());
|
|
@@ -173,29 +181,26 @@ function getMinuteRange(date) {
|
|
|
173
181
|
return { from: `${stringDate}${timeFrom}`, to: `${stringDate}${timeTo}` };
|
|
174
182
|
}
|
|
175
183
|
function getMonthRangeWithToken(value) {
|
|
176
|
-
|
|
177
|
-
|
|
184
|
+
const [month, year] = value.split(' ');
|
|
185
|
+
let monthToReturn = month;
|
|
186
|
+
if (!tokens_1.isTokenLabel(month)) {
|
|
178
187
|
const months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];
|
|
179
|
-
const monthIndex = months.indexOf(
|
|
180
|
-
|
|
188
|
+
const monthIndex = months.indexOf(monthToReturn) + 1;
|
|
189
|
+
monthToReturn = `${monthIndex <= 9 ? '0' : ''}${monthIndex}`;
|
|
181
190
|
}
|
|
182
191
|
return {
|
|
183
|
-
from: `${
|
|
184
|
-
to: `${
|
|
192
|
+
from: `${monthToReturn}/01/${year}`,
|
|
193
|
+
to: `${monthToReturn}/{{LAST_DAY_MONTH}}/${year}`
|
|
185
194
|
};
|
|
186
195
|
}
|
|
187
196
|
function monthInclideTokens(value) {
|
|
188
197
|
const [month, year] = value.split(' ');
|
|
189
|
-
return
|
|
190
|
-
}
|
|
191
|
-
function isTokenBoxLabel(label) {
|
|
192
|
-
const regex = new RegExp('^(\{\{)([^{}]+)(\}\})$', 'gi');
|
|
193
|
-
return regex.test(label);
|
|
198
|
+
return tokens_1.isTokenLabel(month) || tokens_1.isTokenLabel(year);
|
|
194
199
|
}
|
|
195
200
|
function includeTokens(date, separator) {
|
|
196
201
|
const dateSeparet = date.split(separator);
|
|
197
202
|
for (const iterator of dateSeparet) {
|
|
198
|
-
if (
|
|
203
|
+
if (tokens_1.isTokenLabel(iterator))
|
|
199
204
|
return true;
|
|
200
205
|
}
|
|
201
206
|
}
|
|
@@ -51,7 +51,7 @@ class RelativeStatementAdapter {
|
|
|
51
51
|
const path = this.cursor === "the_last" /* LAST */ ? 'gte'
|
|
52
52
|
: this.cursor === "the_next" /* NEXT */ ? 'lte'
|
|
53
53
|
: '';
|
|
54
|
-
return index_1.
|
|
54
|
+
return index_1._get(value, path, new Date());
|
|
55
55
|
}
|
|
56
56
|
/**
|
|
57
57
|
* Convert verbal statement to range value
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export declare const DATETIME_FORMAT = "MM
|
|
1
|
+
export declare const DATETIME_FORMAT = "MM/DD/YYYY HH:mm:ss";
|
|
2
2
|
export declare const INPUT_FORMATS: string[];
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.INPUT_FORMATS = exports.DATETIME_FORMAT = void 0;
|
|
4
|
-
exports.DATETIME_FORMAT = 'MM
|
|
4
|
+
exports.DATETIME_FORMAT = 'MM/DD/YYYY HH:mm:ss';
|
|
5
5
|
exports.INPUT_FORMATS = [
|
|
6
|
+
exports.DATETIME_FORMAT,
|
|
6
7
|
'MM/DD/YYYY',
|
|
7
8
|
'MM-DD-YYYY',
|
|
8
9
|
'YYYY-MM-DD',
|
|
9
|
-
'MM
|
|
10
|
+
'MM-DD-YYYY HH:mm:ss',
|
|
10
11
|
'YYYY-MM-DD HH:mm:ss',
|
|
11
|
-
exports.DATETIME_FORMAT
|
|
12
12
|
];
|
|
@@ -10,12 +10,12 @@ const index_1 = require("../../../general/object/index");
|
|
|
10
10
|
function formatStatement(statement) {
|
|
11
11
|
const loweredStatement = index_1.mapValues(statement, s => typeof s === 'string' ? s.toLowerCase() : s);
|
|
12
12
|
return {
|
|
13
|
-
cursor: index_1.
|
|
14
|
-
unit: index_1.
|
|
15
|
-
number: index_1.
|
|
16
|
-
anchor: index_1.
|
|
17
|
-
isCalendarDate: index_1.
|
|
18
|
-
includeCurrent: index_1.
|
|
13
|
+
cursor: index_1._get(loweredStatement, 'cursor', "this" /* THIS */),
|
|
14
|
+
unit: index_1._get(loweredStatement, 'unit', "day" /* DAY */),
|
|
15
|
+
number: index_1._get(loweredStatement, 'number', 0),
|
|
16
|
+
anchor: index_1._get(loweredStatement, 'anchor', "@now" /* NOW_TOKEN */),
|
|
17
|
+
isCalendarDate: index_1._get(loweredStatement, 'isCalendarDate', true),
|
|
18
|
+
includeCurrent: index_1._get(loweredStatement, 'includeCurrent', true)
|
|
19
19
|
};
|
|
20
20
|
}
|
|
21
21
|
exports.formatStatement = formatStatement;
|
|
@@ -30,7 +30,7 @@ exports.FDToFlatUI = FDToFlatUI;
|
|
|
30
30
|
* @returns a flattened UI filters array
|
|
31
31
|
*/
|
|
32
32
|
function FD21ToFlatUI(scopes = [], datasetsInfo = []) {
|
|
33
|
-
|
|
33
|
+
const uFilters = [];
|
|
34
34
|
if (scopes.length === 0)
|
|
35
35
|
return uFilters;
|
|
36
36
|
scopes.forEach(scope => {
|
|
@@ -42,6 +42,7 @@ function FD21ToFlatUI(scopes = [], datasetsInfo = []) {
|
|
|
42
42
|
let columnInfo;
|
|
43
43
|
if (!general_1.isEmpty(datasetInfo))
|
|
44
44
|
columnInfo = datasetInfo.options.find(cInfo => cInfo.id === filter.column.id && cInfo.qrveyid === filter.column.qrveyid && cInfo.linkid === filter.column.linkid);
|
|
45
|
+
const info = !general_1.isEmpty(filter.extras.info) ? { icon: filter.extras.info.icon, label: filter.extras.info.label } : undefined;
|
|
45
46
|
const uFilter = {
|
|
46
47
|
collapsed: filter.collapsed,
|
|
47
48
|
column: {
|
|
@@ -59,29 +60,21 @@ function FD21ToFlatUI(scopes = [], datasetsInfo = []) {
|
|
|
59
60
|
dateSection: filter.dateSection,
|
|
60
61
|
displayed: filter.displayed,
|
|
61
62
|
enabled: filter.enabled,
|
|
62
|
-
extras: {
|
|
63
|
-
panelid: filter.extras.panelid,
|
|
64
|
-
filterLabel: filter.extras.filterLabel,
|
|
65
|
-
scope: filter.extras.scope,
|
|
66
|
-
scopeid: filter.extras.scopeid,
|
|
67
|
-
section: filter.extras.section,
|
|
68
|
-
scopeInfo: {
|
|
63
|
+
extras: Object.assign(Object.assign({}, filter.extras), { panelid: filter.extras.panelid, filterLabel: filter.extras.filterLabel, info, scope: filter.extras.scope, scopeid: filter.extras.scopeid, section: filter.extras.section, scopeInfo: {
|
|
69
64
|
collapsed: scope.collapsed,
|
|
70
65
|
enabled: scope.enabled,
|
|
71
66
|
displayed: scope.displayed,
|
|
72
67
|
label: scope.label,
|
|
73
68
|
scope: scope.scope,
|
|
74
69
|
scopeid: scope.scopeid,
|
|
75
|
-
},
|
|
76
|
-
dataset: {
|
|
70
|
+
}, dataset: {
|
|
77
71
|
qrveyid: dataset.qrveyid,
|
|
78
72
|
collapsed: dataset.collapsed,
|
|
79
73
|
enabled: dataset.enabled,
|
|
80
74
|
displayed: dataset.enabled,
|
|
81
75
|
label: datasetInfo === null || datasetInfo === void 0 ? void 0 : datasetInfo.name,
|
|
82
76
|
linkid: dataset.linkid,
|
|
83
|
-
},
|
|
84
|
-
},
|
|
77
|
+
} }),
|
|
85
78
|
filterid: filter.filterid,
|
|
86
79
|
lookupDisplayIndex: filter.lookupDisplayIndex,
|
|
87
80
|
nullValues: filter.nullValues,
|
|
@@ -33,10 +33,9 @@ exports.FDToUI = FDToUI;
|
|
|
33
33
|
* @returns a UI filter Structure
|
|
34
34
|
*/
|
|
35
35
|
function FD21ToUI(scopes = [], section = "ANYWHERE" /* ANYWHERE */, enabled = true, datasetsInfo = [], version = constants_1.FILTER_STRUCTURE_VERSION) {
|
|
36
|
-
let ufData;
|
|
37
36
|
if (scopes.length === 0)
|
|
38
|
-
return
|
|
39
|
-
ufData = {
|
|
37
|
+
return;
|
|
38
|
+
const ufData = {
|
|
40
39
|
enabled,
|
|
41
40
|
section,
|
|
42
41
|
version,
|
|
@@ -29,7 +29,7 @@ exports.UIToFlatUI = UIToFlatUI;
|
|
|
29
29
|
* @returns a flattened UI filters array
|
|
30
30
|
*/
|
|
31
31
|
function UI21ToFlatUI(scopes = [], datasetsInfo = []) {
|
|
32
|
-
|
|
32
|
+
const uFilters = [];
|
|
33
33
|
if (scopes.length === 0)
|
|
34
34
|
return uFilters;
|
|
35
35
|
scopes.forEach(scope => {
|
|
@@ -41,6 +41,7 @@ function UI21ToFlatUI(scopes = [], datasetsInfo = []) {
|
|
|
41
41
|
let columnInfo;
|
|
42
42
|
if (!general_1.isEmpty(datasetInfo))
|
|
43
43
|
columnInfo = datasetInfo.options.find(cInfo => cInfo.id === filter.column.id && cInfo.qrveyid === filter.column.qrveyid && cInfo.linkid === filter.column.linkid);
|
|
44
|
+
const info = !general_1.isEmpty(filter.extras.info) ? { icon: filter.extras.info.icon, label: filter.extras.info.label } : undefined;
|
|
44
45
|
const uFilter = {
|
|
45
46
|
collapsed: filter.collapsed,
|
|
46
47
|
column: {
|
|
@@ -58,29 +59,21 @@ function UI21ToFlatUI(scopes = [], datasetsInfo = []) {
|
|
|
58
59
|
dateSection: filter.dateSection,
|
|
59
60
|
displayed: filter.displayed,
|
|
60
61
|
enabled: filter.enabled,
|
|
61
|
-
extras: {
|
|
62
|
-
panelid: filter.extras.panelid,
|
|
63
|
-
filterLabel: filter.extras.filterLabel,
|
|
64
|
-
scope: filter.extras.scope,
|
|
65
|
-
scopeid: filter.extras.scopeid,
|
|
66
|
-
section: filter.extras.section,
|
|
67
|
-
scopeInfo: {
|
|
62
|
+
extras: Object.assign(Object.assign({}, filter.extras), { panelid: filter.extras.panelid, filterLabel: filter.extras.filterLabel, info, scope: filter.extras.scope, scopeid: filter.extras.scopeid, section: filter.extras.section, scopeInfo: {
|
|
68
63
|
collapsed: scope.collapsed,
|
|
69
64
|
enabled: scope.enabled,
|
|
70
65
|
displayed: scope.displayed,
|
|
71
66
|
label: scope.label,
|
|
72
67
|
scope: scope.scope,
|
|
73
68
|
scopeid: scope.scopeid,
|
|
74
|
-
},
|
|
75
|
-
dataset: {
|
|
69
|
+
}, dataset: {
|
|
76
70
|
qrveyid: dataset.qrveyid,
|
|
77
71
|
collapsed: dataset.collapsed,
|
|
78
72
|
enabled: dataset.enabled,
|
|
79
73
|
displayed: dataset.enabled,
|
|
80
74
|
label: (datasetInfo === null || datasetInfo === void 0 ? void 0 : datasetInfo.name) || dataset.label,
|
|
81
75
|
linkid: dataset.linkid,
|
|
82
|
-
},
|
|
83
|
-
},
|
|
76
|
+
} }),
|
|
84
77
|
filterid: filter.filterid,
|
|
85
78
|
lookupDisplayIndex: filter.lookupDisplayIndex,
|
|
86
79
|
nullValues: filter.nullValues,
|
|
@@ -79,7 +79,7 @@ function buildExpressions(filterSection, scope, dataset) {
|
|
|
79
79
|
}, []);
|
|
80
80
|
}
|
|
81
81
|
const getFilterDetail = (filter, scope, dataset) => {
|
|
82
|
-
let aggregate, calculation;
|
|
82
|
+
let aggregate, calculation, info;
|
|
83
83
|
if (filter.column.aggregate != null) {
|
|
84
84
|
aggregate = {
|
|
85
85
|
abbreviation: undefined,
|
|
@@ -97,6 +97,12 @@ const getFilterDetail = (filter, scope, dataset) => {
|
|
|
97
97
|
value: filter.column.calculation,
|
|
98
98
|
};
|
|
99
99
|
}
|
|
100
|
+
if (!general_1.isEmpty(filter.extras.info)) {
|
|
101
|
+
info = {
|
|
102
|
+
icon: filter.extras.info.icon,
|
|
103
|
+
label: filter.extras.info.label,
|
|
104
|
+
};
|
|
105
|
+
}
|
|
100
106
|
return {
|
|
101
107
|
collapsed: filter.collapsed,
|
|
102
108
|
column: {
|
|
@@ -119,6 +125,8 @@ const getFilterDetail = (filter, scope, dataset) => {
|
|
|
119
125
|
},
|
|
120
126
|
dateSection: filter.dateSection,
|
|
121
127
|
enabled: filter.enabled,
|
|
128
|
+
extras: filter.extras,
|
|
129
|
+
info,
|
|
122
130
|
lookupDisplayIndex: filter.lookupDisplayIndex,
|
|
123
131
|
nullValues: filter.nullValues,
|
|
124
132
|
operator: filter.operator,
|
|
@@ -13,7 +13,7 @@ const UIToFD_1 = require("./UIToFD");
|
|
|
13
13
|
* @param datasetsInfo Collection of datasets information. If getUIFilterData is true, the datasetsInfo should be mandatory
|
|
14
14
|
* @returns A new filter data structure v2.1
|
|
15
15
|
*/
|
|
16
|
-
function adaptFilterData(filterData, getUIFilterData =
|
|
16
|
+
function adaptFilterData(filterData, getUIFilterData = true, datasetsInfo = []) {
|
|
17
17
|
if (general_1.isEmpty(filterData))
|
|
18
18
|
return;
|
|
19
19
|
filterData = general_1.cloneDeep(filterData);
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.flatUIToFD = void 0;
|
|
4
|
+
const general_1 = require("../../general");
|
|
4
5
|
const constants_1 = require("../constants");
|
|
5
6
|
/**
|
|
6
7
|
* Generates a filter data structure from the flatttened UI filters.
|
|
@@ -78,6 +79,7 @@ function buildDataset(uFilter) {
|
|
|
78
79
|
* @returns an filter structure
|
|
79
80
|
*/
|
|
80
81
|
function buildFilter(uFilter) {
|
|
82
|
+
const info = !general_1.isEmpty(uFilter.extras.info) ? { icon: uFilter.extras.info.icon, label: uFilter.extras.info.label } : undefined;
|
|
81
83
|
return {
|
|
82
84
|
collapsed: uFilter.collapsed,
|
|
83
85
|
column: {
|
|
@@ -92,13 +94,7 @@ function buildFilter(uFilter) {
|
|
|
92
94
|
displayed: uFilter.displayed,
|
|
93
95
|
filterid: uFilter.filterid,
|
|
94
96
|
enabled: uFilter.enabled,
|
|
95
|
-
extras: {
|
|
96
|
-
panelid: uFilter.extras.panelid,
|
|
97
|
-
filterLabel: uFilter.extras.filterLabel,
|
|
98
|
-
scope: uFilter.extras.scope,
|
|
99
|
-
scopeid: uFilter.extras.scopeid,
|
|
100
|
-
section: uFilter.extras.section,
|
|
101
|
-
},
|
|
97
|
+
extras: Object.assign(Object.assign({}, uFilter.extras), { panelid: uFilter.extras.panelid, filterLabel: uFilter.extras.filterLabel, info, scope: uFilter.extras.scope, scopeid: uFilter.extras.scopeid, section: uFilter.extras.section }),
|
|
102
98
|
lookupDisplayIndex: uFilter.lookupDisplayIndex,
|
|
103
99
|
nullValues: uFilter.nullValues,
|
|
104
100
|
operator: uFilter.operator,
|
|
@@ -68,7 +68,9 @@ const flatUIToOldFilterDetail = (uFilters = []) => {
|
|
|
68
68
|
},
|
|
69
69
|
dateSection: filter.dateSection,
|
|
70
70
|
enabled: filter.enabled,
|
|
71
|
+
extras: filter.extras,
|
|
71
72
|
lookupDisplayIndex: filter.lookupDisplayIndex,
|
|
73
|
+
info: filter.extras.info,
|
|
72
74
|
nullValues: filter.nullValues,
|
|
73
75
|
operator: filter.operator,
|
|
74
76
|
property: filter.property,
|
|
@@ -78,9 +80,10 @@ const flatUIToOldFilterDetail = (uFilters = []) => {
|
|
|
78
80
|
panelid: filter.extras.panelid,
|
|
79
81
|
panelName: filter.extras.filterLabel,
|
|
80
82
|
section: filter.extras.section,
|
|
81
|
-
|
|
83
|
+
uiValue: helpers_1.getUIValues(filter, true),
|
|
82
84
|
validator: filter.validator,
|
|
83
|
-
values: filter.values
|
|
85
|
+
values: filter.values,
|
|
86
|
+
_newFilters: Object.assign({}, filter)
|
|
84
87
|
};
|
|
85
88
|
});
|
|
86
89
|
};
|
|
@@ -105,7 +108,7 @@ function getLogicBody(uFilters) {
|
|
|
105
108
|
filters: [filterItem],
|
|
106
109
|
uiExtras: {
|
|
107
110
|
scopeid: props.scopeid,
|
|
108
|
-
collapsed: props.collapsed,
|
|
111
|
+
collapsed: general_1._get(props, '_newFilters.extras.scopeInfo.collapsed', false),
|
|
109
112
|
}
|
|
110
113
|
});
|
|
111
114
|
}
|
|
@@ -143,11 +146,11 @@ function getRankingExpressions(props) {
|
|
|
143
146
|
const values = props.values;
|
|
144
147
|
return values.map((_value, index) => {
|
|
145
148
|
const expression = Object.assign(Object.assign({}, getRegularExpression(Object.assign(Object.assign({}, props), { values: [props.values[index]] }))), { validationType: helpers_1.getBackendValidator(props.validator) });
|
|
146
|
-
return Object.assign(Object.assign({}, expression), { value: getValues(props, index), uiExtras: Object.assign(Object.assign({}, expression.uiExtras), { uiValue:
|
|
149
|
+
return Object.assign(Object.assign({}, expression), { value: getValues(props, index), uiExtras: Object.assign(Object.assign({}, expression.uiExtras), { uiValue: getUIValuess(props, index) }) });
|
|
147
150
|
});
|
|
148
151
|
}
|
|
149
152
|
function getRegularExpression(props) {
|
|
150
|
-
const uiValue =
|
|
153
|
+
const uiValue = getUIValuess(props);
|
|
151
154
|
return {
|
|
152
155
|
enabled: props.enabled,
|
|
153
156
|
groupValue: getGroupValue(props),
|
|
@@ -163,16 +166,20 @@ function getRegularExpression(props) {
|
|
|
163
166
|
};
|
|
164
167
|
}
|
|
165
168
|
function getGroupValue(props) {
|
|
166
|
-
if (general_1.isEmpty(props.column.aggregate) && isDateColumn_1.isDateColumn(props.column) && props.property) {
|
|
169
|
+
if (!helpers_1.arePropertiesDateP(props.column, props.property) && general_1.isEmpty(props.column.aggregate) && isDateColumn_1.isDateColumn(props.column) && props.property) {
|
|
167
170
|
return props.property;
|
|
168
171
|
}
|
|
169
172
|
}
|
|
170
173
|
function getProperty(props) {
|
|
174
|
+
var _a;
|
|
171
175
|
if (general_1.isEmpty(props.column.aggregate)) {
|
|
172
|
-
if (
|
|
176
|
+
if (helpers_1.isNullValidator(props.validator)) {
|
|
173
177
|
return undefined;
|
|
174
|
-
|
|
175
|
-
|
|
178
|
+
}
|
|
179
|
+
else if (isDateColumn_1.isDateColumn(props.column)) {
|
|
180
|
+
return helpers_1.arePropertiesDateP(props.column, props.property) ? (_a = props.property) === null || _a === void 0 ? void 0 : _a.split('p&')[1] : undefined;
|
|
181
|
+
}
|
|
182
|
+
else if (props.column.type === constants_2.COLUMN.EXPRESSION && props.property != null) {
|
|
176
183
|
return undefined;
|
|
177
184
|
}
|
|
178
185
|
else if (props.column.type === constants_2.COLUMN.LOOKUP && props.property === "display" /* LOOKUP_DISPLAY */ && props.lookupDisplayIndex != null) {
|
|
@@ -253,66 +260,36 @@ function getValues(props, rankingGroupIndex) {
|
|
|
253
260
|
case "NOT_START_WITH" /* NOT_START_WITH */:
|
|
254
261
|
case "ENDS_WITH" /* ENDS_WITH */:
|
|
255
262
|
case "NOT_END_WITH" /* NOT_END_WITH */:
|
|
256
|
-
return props.values.map(value => value.value);
|
|
263
|
+
return props.values.map(value => value.enabled ? value.value : undefined);
|
|
257
264
|
case "BETWEEN_INCLUSIVE" /* BETWEEN_INCLUSIVE */:
|
|
258
|
-
|
|
259
|
-
// lte: isDateProperty ? getDateRange(value.max, props.property).to : value.max,
|
|
260
|
-
// gte: isDateProperty ? getDateRange(value.min, props.property).from : value.min
|
|
261
|
-
// }));
|
|
262
|
-
return props.values.map(value => ({
|
|
263
|
-
lte: value.max,
|
|
264
|
-
gte: value.min
|
|
265
|
-
}));
|
|
265
|
+
return props.values.map(value => value.enabled ? ({ lte: value.max, gte: value.min }) : undefined).filter(Boolean);
|
|
266
266
|
case "BETWEEN_EXCLUSIVE" /* BETWEEN_EXCLUSIVE */:
|
|
267
|
-
return props.values.map(value => {
|
|
268
|
-
// const { min, max } = getExclusiveRangeValuesByProperty(value, props);
|
|
269
|
-
// return {
|
|
270
|
-
// [isDateProperty && !includeDateTokens(max, dateFormat) ? 'lte' : 'lt'] : isDateProperty ? getDateRange(max, props.property).to : max,
|
|
271
|
-
// [isDateProperty && !includeDateTokens(min, dateFormat) ? 'gte' : 'gt'] : isDateProperty ? getDateRange(min, props.property).from : min
|
|
272
|
-
// };
|
|
273
|
-
return {
|
|
274
|
-
lt: value.max,
|
|
275
|
-
gt: value.min
|
|
276
|
-
};
|
|
277
|
-
});
|
|
267
|
+
return props.values.map(value => value.enabled ? ({ lt: value.max, gt: value.min }) : undefined).filter(Boolean);
|
|
278
268
|
case "BEFORE" /* BEFORE */:
|
|
279
269
|
case "LESS_THAN" /* LESS_THAN */:
|
|
280
|
-
return props.values.map(value => {
|
|
281
|
-
// const { max } = getExclusiveRangeValuesByProperty(value, props);
|
|
282
|
-
// return { [isDateProperty && !includeDateTokens(max, dateFormat) ? 'lte' : 'lt'] : isDateProperty ? getDateRange(max, props.property).to : max };
|
|
283
|
-
return { lt: value.max };
|
|
284
|
-
});
|
|
270
|
+
return props.values.map(value => value.enabled ? ({ lt: value.max }) : undefined).filter(Boolean);
|
|
285
271
|
case "BEFORE_ON" /* BEFORE_ON */:
|
|
286
272
|
case "LESS_THAN_EQUAL" /* LESS_THAN_EQUAL */:
|
|
287
|
-
return props.values.map(value => (
|
|
288
|
-
// {
|
|
289
|
-
// lte: isDateProperty ? getDateRange(value.max, props.property).to : value.max
|
|
290
|
-
// }
|
|
291
|
-
{ lte: value.max }));
|
|
273
|
+
return props.values.map(value => value.enabled ? ({ lte: value.max }) : undefined).filter(Boolean);
|
|
292
274
|
case "AFTER" /* AFTER */:
|
|
293
275
|
case "GREATER_THAN" /* GREATER_THAN */:
|
|
294
|
-
return props.values.map(value => {
|
|
295
|
-
// const { min } = getExclusiveRangeValuesByProperty(value, props);
|
|
296
|
-
// return { [isDateProperty && !includeDateTokens(min, dateFormat) ? 'gte' : 'gt'] : isDateProperty ? getDateRange(min, props.property).from : min };
|
|
297
|
-
return { gt: value.min };
|
|
298
|
-
});
|
|
276
|
+
return props.values.map(value => value.enabled ? ({ gt: value.min }) : undefined).filter(Boolean);
|
|
299
277
|
case "AFTER_ON" /* AFTER_ON */:
|
|
300
278
|
case "GREATER_THAN_EQUAL" /* GREATER_THAN_EQUAL */:
|
|
301
|
-
return props.values.map(value => (
|
|
302
|
-
// {
|
|
303
|
-
// gte: isDateProperty ? getDateRange(value.min, props.property).from : value.min
|
|
304
|
-
// }
|
|
305
|
-
{ gte: value.min }));
|
|
279
|
+
return props.values.map(value => value.enabled ? ({ gte: value.min }) : undefined).filter(Boolean);
|
|
306
280
|
case "IS_NULL" /* IS_NULL */:
|
|
307
|
-
case "IS_NOT_NULL" /* IS_NOT_NULL */:
|
|
308
|
-
|
|
281
|
+
case "IS_NOT_NULL" /* IS_NOT_NULL */: {
|
|
282
|
+
const addValue = props.values.length > 0 && props.values.every(value => value.enabled);
|
|
283
|
+
return addValue ? [constants_1.FILTER_VALIDATOR_VALUE[props.validator].label] : [];
|
|
284
|
+
}
|
|
309
285
|
case "IN" /* IN */:
|
|
310
|
-
return
|
|
286
|
+
return props.values.map(value => value.enabled ? value : undefined).filter(Boolean);
|
|
311
287
|
default:
|
|
312
288
|
return [];
|
|
313
289
|
}
|
|
314
290
|
}
|
|
315
|
-
function
|
|
291
|
+
function getUIValuess(props, rankingGroupIndex) {
|
|
292
|
+
var _a, _b;
|
|
316
293
|
switch (props.validator) {
|
|
317
294
|
case "AFTER" /* AFTER */:
|
|
318
295
|
case "GREATER_THAN" /* GREATER_THAN */:
|
|
@@ -329,7 +306,7 @@ function getUIValues(props, rankingGroupIndex) {
|
|
|
329
306
|
return props.values.map(value => (Object.assign(Object.assign({}, value), { value: `${value.min} - ${value.max}`, enabled: value.enabled != null ? value.enabled : true })));
|
|
330
307
|
case "IS_NULL" /* IS_NULL */:
|
|
331
308
|
case "IS_NOT_NULL" /* IS_NOT_NULL */:
|
|
332
|
-
return [{ value: constants_1.FILTER_VALIDATOR_VALUE[props.validator].label, enabled: props.enabled }];
|
|
309
|
+
return [{ value: constants_1.FILTER_VALIDATOR_VALUE[props.validator].label, enabled: (_b = (_a = props.values[0]) === null || _a === void 0 ? void 0 : _a.enabled) !== null && _b !== void 0 ? _b : props.enabled }];
|
|
333
310
|
case "IN" /* IN */:
|
|
334
311
|
return props.values.map(value => (Object.assign(Object.assign({}, value), { value: `${date_1.RELATIVE_CURSOR_VALUE[value.cursor].label} ${value.cursor !== "this" /* THIS */ && value.number > 1 ? value.number : ''} ${getValueUiUnitRelativeDate(value)} ${value.cursor !== "this" /* THIS */ ? `from ${value.anchor || 'current date'}` : ''}`, enabled: props.enabled })));
|
|
335
312
|
default:
|
|
@@ -344,10 +321,10 @@ function getValueUiUnitRelativeDate(relative) {
|
|
|
344
321
|
}
|
|
345
322
|
function getRankingValues(values, rankingGroupIndex) {
|
|
346
323
|
const flattenValues = general_1.isNull(rankingGroupIndex) ? general_1.flattenDeep(values) : values[rankingGroupIndex];
|
|
347
|
-
return flattenValues.map(rankingValue => ({
|
|
324
|
+
return flattenValues.map(rankingValue => rankingValue.enabled ? ({
|
|
348
325
|
position: rankingValue.position - 1,
|
|
349
326
|
value: rankingValue.value.value
|
|
350
|
-
}));
|
|
327
|
+
}) : undefined).filter(Boolean);
|
|
351
328
|
}
|
|
352
329
|
function getRankingUIValues(values, rankingGroupIndex) {
|
|
353
330
|
const flattenValues = general_1.isNull(rankingGroupIndex) ? general_1.flattenDeep(values) : values[rankingGroupIndex];
|
|
@@ -360,13 +337,15 @@ function getRankingUIValues(values, rankingGroupIndex) {
|
|
|
360
337
|
}
|
|
361
338
|
function getResultValues(values, props) {
|
|
362
339
|
return values.map((value) => {
|
|
363
|
-
if (
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
340
|
+
if (value.enabled) {
|
|
341
|
+
if (props.column.type === constants_2.COLUMN.IMAGE) {
|
|
342
|
+
return value.valueid;
|
|
343
|
+
}
|
|
344
|
+
else {
|
|
345
|
+
return value.value;
|
|
346
|
+
}
|
|
368
347
|
}
|
|
369
|
-
}).filter(
|
|
348
|
+
}).filter(Boolean);
|
|
370
349
|
// return values.map((value: IFBResultValue) => {
|
|
371
350
|
// if (!isEmpty(props.column.aggregate)) {
|
|
372
351
|
// return value.value || '';
|