@daffodil/category 0.42.4 → 0.44.0
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/driver/magento/category.service.d.ts +2 -3
- package/driver/magento/models/complete-category-response.d.ts +6 -6
- package/driver/magento/models/get-products-response.d.ts +3 -5
- package/driver/magento/models/public_api.d.ts +0 -10
- package/driver/magento/models/requests/get-products-by-categories-request.d.ts +2 -3
- package/driver/magento/queries/public_api.d.ts +0 -1
- package/driver/magento/testing/factories/public_api.d.ts +0 -4
- package/driver/magento/transformers/applied-filter-transformer.service.d.ts +6 -13
- package/driver/magento/transformers/public_api.d.ts +0 -1
- package/driver/magento/transformers/pure/add-metadata-types-to-aggregates.d.ts +3 -0
- package/esm2020/driver/in-memory/backend/category.service.mjs +10 -10
- package/esm2020/driver/in-memory/drivers/category.service.mjs +5 -5
- package/esm2020/driver/magento/category-driver.module.mjs +2 -4
- package/esm2020/driver/magento/category.service.mjs +26 -25
- package/esm2020/driver/magento/models/complete-category-response.mjs +1 -1
- package/esm2020/driver/magento/models/get-products-response.mjs +1 -1
- package/esm2020/driver/magento/models/public_api.mjs +2 -4
- package/esm2020/driver/magento/models/requests/get-products-by-categories-request.mjs +1 -1
- package/esm2020/driver/magento/queries/get-products.mjs +9 -18
- package/esm2020/driver/magento/queries/public_api.mjs +1 -2
- package/esm2020/driver/magento/testing/factories/category.factory.mjs +3 -1
- package/esm2020/driver/magento/testing/factories/public_api.mjs +1 -5
- package/esm2020/driver/magento/transformers/applied-filter-transformer.service.mjs +13 -44
- package/esm2020/driver/magento/transformers/category-page-config-transformer.service.mjs +3 -17
- package/esm2020/driver/magento/transformers/public_api.mjs +1 -2
- package/esm2020/driver/magento/transformers/pure/add-metadata-types-to-aggregates.mjs +16 -0
- package/esm2020/models/category-page-metadata.mjs +1 -1
- package/esm2020/models/category-request.mjs +1 -1
- package/esm2020/models/public_api.mjs +1 -2
- package/esm2020/public_api.mjs +1 -3
- package/esm2020/routing/effects/collection-route.effects.mjs +21 -0
- package/esm2020/routing/injection-tokens/public_api.mjs +2 -0
- package/esm2020/routing/injection-tokens/request/builder.token.mjs +8 -0
- package/esm2020/routing/injection-tokens/request/builders.token.mjs +30 -0
- package/esm2020/routing/module.mjs +72 -0
- package/esm2020/routing/public_api.mjs +3 -1
- package/esm2020/routing/resolvers/category-page/category-page.resolver.mjs +3 -6
- package/esm2020/routing/resolvers/category-page-id/category-page-id.resolver.mjs +11 -8
- package/esm2020/routing/resolvers/category-page-url/category-page-url.resolver.mjs +11 -13
- package/esm2020/state/actions/category-page-filter.actions.mjs +52 -16
- package/esm2020/state/actions/category-page.actions.mjs +1 -37
- package/esm2020/state/effects/category-page-filter.effects.mjs +14 -13
- package/esm2020/state/effects/category-page.effects.mjs +14 -12
- package/esm2020/state/facades/collection/facade.mjs +20 -0
- package/esm2020/state/facades/page/category-facade.interface.mjs +2 -0
- package/esm2020/state/facades/page/category.facade.mjs +52 -0
- package/esm2020/state/facades/public_api.mjs +3 -0
- package/esm2020/state/public_api.mjs +2 -2
- package/esm2020/state/reducers/category/category-reducer-state.interface.mjs +1 -1
- package/esm2020/state/reducers/category/category.reducer.mjs +14 -113
- package/esm2020/state/reducers/category-reducers.interface.mjs +1 -1
- package/esm2020/state/reducers/category-reducers.mjs +3 -1
- package/esm2020/state/reducers/page-metadata/reducer.mjs +57 -0
- package/esm2020/state/reducers/page-metadata/state.interface.mjs +2 -0
- package/esm2020/state/reducers/public_api.mjs +2 -1
- package/esm2020/state/selectors/category-page/category-page.selector.mjs +4 -24
- package/esm2020/state/selectors/category.selector.mjs +3 -1
- package/esm2020/state/selectors/collection/selectors.mjs +10 -0
- package/esm2020/state/testing/category-testing.module.mjs +5 -2
- package/esm2020/state/testing/mock-category-facade.mjs +1 -1
- package/esm2020/testing/factories/category-page-metadata.factory.mjs +11 -32
- package/esm2020/testing/factories/category.factory.mjs +1 -1
- package/esm2020/testing/factories/public_api.mjs +1 -2
- package/fesm2015/daffodil-category-driver-in-memory.mjs +13 -13
- package/fesm2015/daffodil-category-driver-in-memory.mjs.map +1 -1
- package/fesm2015/daffodil-category-driver-magento-testing.mjs +3 -174
- package/fesm2015/daffodil-category-driver-magento-testing.mjs.map +1 -1
- package/fesm2015/daffodil-category-driver-magento.mjs +45 -208
- package/fesm2015/daffodil-category-driver-magento.mjs.map +1 -1
- package/fesm2015/daffodil-category-routing.mjs +139 -32
- package/fesm2015/daffodil-category-routing.mjs.map +1 -1
- package/fesm2015/daffodil-category-state-testing.mjs +4 -1
- package/fesm2015/daffodil-category-state-testing.mjs.map +1 -1
- package/fesm2015/daffodil-category-state.mjs +218 -214
- package/fesm2015/daffodil-category-state.mjs.map +1 -1
- package/fesm2015/daffodil-category-testing.mjs +10 -364
- package/fesm2015/daffodil-category-testing.mjs.map +1 -1
- package/fesm2015/daffodil-category.mjs +1 -512
- package/fesm2015/daffodil-category.mjs.map +1 -1
- package/fesm2020/daffodil-category-driver-in-memory.mjs +13 -13
- package/fesm2020/daffodil-category-driver-in-memory.mjs.map +1 -1
- package/fesm2020/daffodil-category-driver-magento-testing.mjs +3 -174
- package/fesm2020/daffodil-category-driver-magento-testing.mjs.map +1 -1
- package/fesm2020/daffodil-category-driver-magento.mjs +48 -215
- package/fesm2020/daffodil-category-driver-magento.mjs.map +1 -1
- package/fesm2020/daffodil-category-routing.mjs +139 -28
- package/fesm2020/daffodil-category-routing.mjs.map +1 -1
- package/fesm2020/daffodil-category-state-testing.mjs +4 -1
- package/fesm2020/daffodil-category-state-testing.mjs.map +1 -1
- package/fesm2020/daffodil-category-state.mjs +233 -295
- package/fesm2020/daffodil-category-state.mjs.map +1 -1
- package/fesm2020/daffodil-category-testing.mjs +10 -383
- package/fesm2020/daffodil-category-testing.mjs.map +1 -1
- package/fesm2020/daffodil-category.mjs +1 -565
- package/fesm2020/daffodil-category.mjs.map +1 -1
- package/models/category-page-metadata.d.ts +3 -12
- package/models/category-request.d.ts +3 -30
- package/models/public_api.d.ts +1 -2
- package/package.json +4 -4
- package/public_api.d.ts +0 -2
- package/routing/effects/collection-route.effects.d.ts +10 -0
- package/routing/injection-tokens/public_api.d.ts +1 -0
- package/routing/injection-tokens/request/builder.token.d.ts +6 -0
- package/routing/injection-tokens/request/builders.token.d.ts +26 -0
- package/routing/module.d.ts +8 -0
- package/routing/public_api.d.ts +2 -0
- package/routing/resolvers/category-page-id/category-page-id.resolver.d.ts +3 -1
- package/routing/resolvers/category-page-url/category-page-url.resolver.d.ts +3 -3
- package/state/actions/category-page-filter.actions.d.ts +60 -20
- package/state/actions/category-page.actions.d.ts +3 -42
- package/state/effects/category-page-filter.effects.d.ts +2 -2
- package/state/facades/collection/facade.d.ts +9 -0
- package/state/facades/{category-facade.interface.d.ts → page/category-facade.interface.d.ts} +3 -44
- package/state/facades/{category.facade.d.ts → page/category.facade.d.ts} +3 -14
- package/state/facades/public_api.d.ts +3 -0
- package/state/public_api.d.ts +1 -2
- package/state/reducers/category/category-reducer-state.interface.d.ts +5 -5
- package/state/reducers/category/category.reducer.d.ts +2 -2
- package/state/reducers/category-reducers.interface.d.ts +5 -0
- package/state/reducers/page-metadata/reducer.d.ts +11 -0
- package/state/reducers/page-metadata/state.interface.d.ts +2 -0
- package/state/reducers/public_api.d.ts +2 -0
- package/state/selectors/category-page/category-page.selector.d.ts +2 -44
- package/state/selectors/category.selector.d.ts +2 -1
- package/state/selectors/collection/selectors.d.ts +5 -0
- package/state/testing/mock-category-facade.d.ts +6 -6
- package/testing/factories/category-page-metadata.factory.d.ts +4 -18
- package/testing/factories/public_api.d.ts +0 -1
- package/driver/magento/models/aggregation.d.ts +0 -16
- package/driver/magento/models/filter-type-field.interface.d.ts +0 -7
- package/driver/magento/models/filter-type.enum.d.ts +0 -5
- package/driver/magento/models/get-filter-types-response.interface.d.ts +0 -6
- package/driver/magento/models/page-info.d.ts +0 -5
- package/driver/magento/models/requests/filters.d.ts +0 -13
- package/driver/magento/models/requests/sort.d.ts +0 -7
- package/driver/magento/models/sort-fields.d.ts +0 -8
- package/driver/magento/queries/get-filter-types.d.ts +0 -2
- package/driver/magento/testing/factories/aggregation/aggregation.factory.d.ts +0 -12
- package/driver/magento/testing/factories/aggregation/public_api.d.ts +0 -3
- package/driver/magento/testing/factories/aggregation/type/price.factory.d.ts +0 -8
- package/driver/magento/testing/factories/aggregation/type/select.factory.d.ts +0 -8
- package/driver/magento/testing/factories/filter-type-field.factory.d.ts +0 -8
- package/driver/magento/testing/factories/page-info.factory.d.ts +0 -8
- package/driver/magento/testing/factories/sort-fields.factory.d.ts +0 -8
- package/driver/magento/transformers/applied-sort-option-transformer.service.d.ts +0 -9
- package/driver/magento/transformers/pure/aggregate/add-metadata-types-to-aggregates.d.ts +0 -2
- package/driver/magento/transformers/pure/aggregate/get-matched-attribute-type.d.ts +0 -3
- package/driver/magento/transformers/pure/aggregate/transform.d.ts +0 -3
- package/driver/magento/transformers/pure/aggregate/type/equal.d.ts +0 -3
- package/driver/magento/transformers/pure/aggregate/type/range.d.ts +0 -8
- package/driver/magento/transformers/pure/sort-default-option-first.d.ts +0 -2
- package/errors/codes.enum.d.ts +0 -15
- package/errors/map.d.ts +0 -5
- package/errors/public_api.d.ts +0 -2
- package/esm2020/driver/magento/models/aggregation.mjs +0 -2
- package/esm2020/driver/magento/models/filter-type-field.interface.mjs +0 -2
- package/esm2020/driver/magento/models/filter-type.enum.mjs +0 -8
- package/esm2020/driver/magento/models/get-filter-types-response.interface.mjs +0 -2
- package/esm2020/driver/magento/models/page-info.mjs +0 -2
- package/esm2020/driver/magento/models/requests/filters.mjs +0 -9
- package/esm2020/driver/magento/models/requests/sort.mjs +0 -6
- package/esm2020/driver/magento/models/sort-fields.mjs +0 -2
- package/esm2020/driver/magento/queries/get-filter-types.mjs +0 -15
- package/esm2020/driver/magento/testing/factories/aggregation/aggregation.factory.mjs +0 -24
- package/esm2020/driver/magento/testing/factories/aggregation/public_api.mjs +0 -4
- package/esm2020/driver/magento/testing/factories/aggregation/type/price.factory.mjs +0 -49
- package/esm2020/driver/magento/testing/factories/aggregation/type/select.factory.mjs +0 -44
- package/esm2020/driver/magento/testing/factories/filter-type-field.factory.mjs +0 -32
- package/esm2020/driver/magento/testing/factories/page-info.factory.mjs +0 -25
- package/esm2020/driver/magento/testing/factories/sort-fields.factory.mjs +0 -28
- package/esm2020/driver/magento/transformers/applied-sort-option-transformer.service.mjs +0 -28
- package/esm2020/driver/magento/transformers/pure/aggregate/add-metadata-types-to-aggregates.mjs +0 -16
- package/esm2020/driver/magento/transformers/pure/aggregate/get-matched-attribute-type.mjs +0 -2
- package/esm2020/driver/magento/transformers/pure/aggregate/transform.mjs +0 -14
- package/esm2020/driver/magento/transformers/pure/aggregate/type/equal.mjs +0 -16
- package/esm2020/driver/magento/transformers/pure/aggregate/type/range.mjs +0 -15
- package/esm2020/driver/magento/transformers/pure/sort-default-option-first.mjs +0 -12
- package/esm2020/errors/codes.enum.mjs +0 -12
- package/esm2020/errors/map.mjs +0 -8
- package/esm2020/errors/public_api.mjs +0 -3
- package/esm2020/filters/array-to-dict/array-to-dict.mjs +0 -6
- package/esm2020/filters/behaviors/apply/apply-filter.mjs +0 -24
- package/esm2020/filters/behaviors/apply/apply-request-to-filters.mjs +0 -12
- package/esm2020/filters/behaviors/apply/apply-requests-to-filters.mjs +0 -12
- package/esm2020/filters/behaviors/apply/public_api.mjs +0 -4
- package/esm2020/filters/behaviors/clear/clear-filter.mjs +0 -21
- package/esm2020/filters/behaviors/clear/clear-filters.mjs +0 -12
- package/esm2020/filters/behaviors/clear/public_api.mjs +0 -3
- package/esm2020/filters/behaviors/remove/public_api.mjs +0 -4
- package/esm2020/filters/behaviors/remove/remove-filter.mjs +0 -25
- package/esm2020/filters/behaviors/remove/remove-request-from-filters.mjs +0 -12
- package/esm2020/filters/behaviors/remove/remove-requests-from-filters.mjs +0 -13
- package/esm2020/filters/behaviors/toggle/public_api.mjs +0 -3
- package/esm2020/filters/behaviors/toggle/toggle-request-on-filters.mjs +0 -10
- package/esm2020/filters/behaviors/toggle/toggle.mjs +0 -22
- package/esm2020/filters/compute-applied-filters/compute-applied-filters.mjs +0 -21
- package/esm2020/filters/errors/codes.enum.mjs +0 -13
- package/esm2020/filters/errors/filter-not-found.error.mjs +0 -12
- package/esm2020/filters/errors/map.mjs +0 -15
- package/esm2020/filters/errors/public_api.mjs +0 -5
- package/esm2020/filters/errors/request-name-mismatch.error.mjs +0 -13
- package/esm2020/filters/errors/request-type-mismatch.error.mjs +0 -13
- package/esm2020/filters/errors/unknown-filter-type.error.mjs +0 -13
- package/esm2020/filters/find-applied/find-applied-options.mjs +0 -5
- package/esm2020/filters/find-applied/public_api.mjs +0 -2
- package/esm2020/filters/is-applied/is-filter-applied.mjs +0 -18
- package/esm2020/filters/is-applied/is-toggle-request-applied-to-filter.mjs +0 -18
- package/esm2020/filters/is-applied/public_api.mjs +0 -3
- package/esm2020/filters/public_api.mjs +0 -14
- package/esm2020/filters/to-request/filter-to-request.mjs +0 -20
- package/esm2020/filters/to-request/filters-to-requests.mjs +0 -15
- package/esm2020/filters/to-request/public_api.mjs +0 -3
- package/esm2020/filters/type/equal/array-to-dict/option.mjs +0 -6
- package/esm2020/filters/type/equal/behaviors/apply/apply.mjs +0 -20
- package/esm2020/filters/type/equal/behaviors/clear/clear.mjs +0 -17
- package/esm2020/filters/type/equal/behaviors/remove/remove.mjs +0 -23
- package/esm2020/filters/type/equal/behaviors/toggle/toggle.mjs +0 -24
- package/esm2020/filters/type/equal/is-applied/is-applied.mjs +0 -5
- package/esm2020/filters/type/equal/is-applied/is-toggle-request-applied-to-filter.mjs +0 -5
- package/esm2020/filters/type/equal/public_api.mjs +0 -2
- package/esm2020/filters/type/equal/to-request/filter-to-request.mjs +0 -17
- package/esm2020/filters/type/range/array-to-dict/pair.mjs +0 -7
- package/esm2020/filters/type/range/behaviors/apply/apply.mjs +0 -24
- package/esm2020/filters/type/range/behaviors/clear/clear.mjs +0 -11
- package/esm2020/filters/type/range/behaviors/remove/remove.mjs +0 -17
- package/esm2020/filters/type/range/behaviors/toggle/toggle.mjs +0 -15
- package/esm2020/filters/type/range/compute-pair-label.mjs +0 -3
- package/esm2020/filters/type/range/is-applied/is-applied.mjs +0 -5
- package/esm2020/filters/type/range/is-applied/is-toggle-request-applied-to-filter.mjs +0 -6
- package/esm2020/filters/type/range/public_api.mjs +0 -3
- package/esm2020/filters/type/range/to-request/filter-to-request.mjs +0 -19
- package/esm2020/filters/type/range-numeric/to-request/filter-to-request.mjs +0 -6
- package/esm2020/filters/validators/public_api.mjs +0 -3
- package/esm2020/filters/validators/request-name-match.mjs +0 -16
- package/esm2020/filters/validators/request-type-match.mjs +0 -12
- package/esm2020/models/filters/category-filter-base.mjs +0 -2
- package/esm2020/models/filters/category-filter-option-base.mjs +0 -2
- package/esm2020/models/filters/category-filter-option.mjs +0 -2
- package/esm2020/models/filters/category-filter.mjs +0 -2
- package/esm2020/models/filters/category-filterable.mjs +0 -2
- package/esm2020/models/filters/filter-request.mjs +0 -2
- package/esm2020/models/filters/filter-toggle-request.mjs +0 -2
- package/esm2020/models/filters/public_api.mjs +0 -5
- package/esm2020/models/filters/type/category-filter-type.mjs +0 -9
- package/esm2020/models/filters/type/equal/filter.mjs +0 -2
- package/esm2020/models/filters/type/equal/option.mjs +0 -2
- package/esm2020/models/filters/type/equal/public_api.mjs +0 -2
- package/esm2020/models/filters/type/equal/request.mjs +0 -2
- package/esm2020/models/filters/type/equal/toggle-request.mjs +0 -2
- package/esm2020/models/filters/type/range/filter-base.mjs +0 -2
- package/esm2020/models/filters/type/range/option.mjs +0 -2
- package/esm2020/models/filters/type/range/pair.mjs +0 -2
- package/esm2020/models/filters/type/range/public_api.mjs +0 -2
- package/esm2020/models/filters/type/range/request-base.mjs +0 -2
- package/esm2020/models/filters/type/range/request-option.mjs +0 -2
- package/esm2020/models/filters/type/range/separator.mjs +0 -6
- package/esm2020/models/filters/type/range-numeric/filter.mjs +0 -2
- package/esm2020/models/filters/type/range-numeric/public_api.mjs +0 -2
- package/esm2020/models/filters/type/range-numeric/request.mjs +0 -2
- package/esm2020/models/filters/type/range-numeric/toggle-request.mjs +0 -2
- package/esm2020/state/facades/category-facade.interface.mjs +0 -2
- package/esm2020/state/facades/category.facade.mjs +0 -62
- package/esm2020/state/reducers/category/pure/build-metadata-from-request.mjs +0 -13
- package/esm2020/testing/factories/filters/filter.factory.mjs +0 -50
- package/esm2020/testing/factories/filters/public_api.mjs +0 -5
- package/esm2020/testing/factories/filters/request.factory.mjs +0 -27
- package/esm2020/testing/factories/filters/toggle-request.mjs +0 -35
- package/esm2020/testing/factories/filters/type/equal/option.mjs +0 -29
- package/esm2020/testing/factories/filters/type/equal/public_api.mjs +0 -4
- package/esm2020/testing/factories/filters/type/equal/request.mjs +0 -29
- package/esm2020/testing/factories/filters/type/equal/toggle-request.mjs +0 -29
- package/esm2020/testing/factories/filters/type/equal.mjs +0 -30
- package/esm2020/testing/factories/filters/type/public_api.mjs +0 -5
- package/esm2020/testing/factories/filters/type/range-numeric/option.mjs +0 -27
- package/esm2020/testing/factories/filters/type/range-numeric/pair.mjs +0 -37
- package/esm2020/testing/factories/filters/type/range-numeric/public_api.mjs +0 -6
- package/esm2020/testing/factories/filters/type/range-numeric/request-option.mjs +0 -27
- package/esm2020/testing/factories/filters/type/range-numeric/request.mjs +0 -38
- package/esm2020/testing/factories/filters/type/range-numeric/toggle-request.mjs +0 -38
- package/esm2020/testing/factories/filters/type/range-numeric.mjs +0 -32
- package/filters/array-to-dict/array-to-dict.d.ts +0 -6
- package/filters/behaviors/apply/apply-filter.d.ts +0 -8
- package/filters/behaviors/apply/apply-request-to-filters.d.ts +0 -9
- package/filters/behaviors/apply/apply-requests-to-filters.d.ts +0 -9
- package/filters/behaviors/apply/public_api.d.ts +0 -3
- package/filters/behaviors/clear/clear-filter.d.ts +0 -8
- package/filters/behaviors/clear/clear-filters.d.ts +0 -9
- package/filters/behaviors/clear/public_api.d.ts +0 -2
- package/filters/behaviors/remove/public_api.d.ts +0 -3
- package/filters/behaviors/remove/remove-filter.d.ts +0 -9
- package/filters/behaviors/remove/remove-request-from-filters.d.ts +0 -9
- package/filters/behaviors/remove/remove-requests-from-filters.d.ts +0 -10
- package/filters/behaviors/toggle/public_api.d.ts +0 -2
- package/filters/behaviors/toggle/toggle-request-on-filters.d.ts +0 -7
- package/filters/behaviors/toggle/toggle.d.ts +0 -6
- package/filters/compute-applied-filters/compute-applied-filters.d.ts +0 -7
- package/filters/errors/codes.enum.d.ts +0 -11
- package/filters/errors/filter-not-found.error.d.ts +0 -8
- package/filters/errors/map.d.ts +0 -13
- package/filters/errors/public_api.d.ts +0 -4
- package/filters/errors/request-name-mismatch.error.d.ts +0 -9
- package/filters/errors/request-type-mismatch.error.d.ts +0 -9
- package/filters/errors/unknown-filter-type.error.d.ts +0 -9
- package/filters/find-applied/find-applied-options.d.ts +0 -5
- package/filters/find-applied/public_api.d.ts +0 -1
- package/filters/is-applied/is-filter-applied.d.ts +0 -5
- package/filters/is-applied/is-toggle-request-applied-to-filter.d.ts +0 -5
- package/filters/is-applied/public_api.d.ts +0 -2
- package/filters/public_api.d.ts +0 -13
- package/filters/to-request/filter-to-request.d.ts +0 -6
- package/filters/to-request/filters-to-requests.d.ts +0 -7
- package/filters/to-request/public_api.d.ts +0 -2
- package/filters/type/equal/array-to-dict/option.d.ts +0 -6
- package/filters/type/equal/behaviors/apply/apply.d.ts +0 -8
- package/filters/type/equal/behaviors/clear/clear.d.ts +0 -8
- package/filters/type/equal/behaviors/remove/remove.d.ts +0 -11
- package/filters/type/equal/behaviors/toggle/toggle.d.ts +0 -11
- package/filters/type/equal/is-applied/is-applied.d.ts +0 -5
- package/filters/type/equal/is-applied/is-toggle-request-applied-to-filter.d.ts +0 -5
- package/filters/type/equal/public_api.d.ts +0 -1
- package/filters/type/equal/to-request/filter-to-request.d.ts +0 -5
- package/filters/type/range/array-to-dict/pair.d.ts +0 -6
- package/filters/type/range/behaviors/apply/apply.d.ts +0 -8
- package/filters/type/range/behaviors/clear/clear.d.ts +0 -8
- package/filters/type/range/behaviors/remove/remove.d.ts +0 -11
- package/filters/type/range/behaviors/toggle/toggle.d.ts +0 -10
- package/filters/type/range/compute-pair-label.d.ts +0 -1
- package/filters/type/range/is-applied/is-applied.d.ts +0 -5
- package/filters/type/range/is-applied/is-toggle-request-applied-to-filter.d.ts +0 -5
- package/filters/type/range/public_api.d.ts +0 -2
- package/filters/type/range/to-request/filter-to-request.d.ts +0 -5
- package/filters/type/range-numeric/to-request/filter-to-request.d.ts +0 -5
- package/filters/validators/public_api.d.ts +0 -2
- package/filters/validators/request-name-match.d.ts +0 -7
- package/filters/validators/request-type-match.d.ts +0 -7
- package/models/filters/category-filter-base.d.ts +0 -25
- package/models/filters/category-filter-option-base.d.ts +0 -9
- package/models/filters/category-filter-option.d.ts +0 -6
- package/models/filters/category-filter.d.ts +0 -9
- package/models/filters/category-filterable.d.ts +0 -11
- package/models/filters/filter-request.d.ts +0 -7
- package/models/filters/filter-toggle-request.d.ts +0 -6
- package/models/filters/public_api.d.ts +0 -11
- package/models/filters/type/category-filter-type.d.ts +0 -7
- package/models/filters/type/equal/filter.d.ts +0 -25
- package/models/filters/type/equal/option.d.ts +0 -19
- package/models/filters/type/equal/public_api.d.ts +0 -4
- package/models/filters/type/equal/request.d.ts +0 -18
- package/models/filters/type/equal/toggle-request.d.ts +0 -18
- package/models/filters/type/range/filter-base.d.ts +0 -24
- package/models/filters/type/range/option.d.ts +0 -14
- package/models/filters/type/range/pair.d.ts +0 -20
- package/models/filters/type/range/public_api.d.ts +0 -6
- package/models/filters/type/range/request-base.d.ts +0 -20
- package/models/filters/type/range/request-option.d.ts +0 -14
- package/models/filters/type/range/separator.d.ts +0 -5
- package/models/filters/type/range-numeric/filter.d.ts +0 -11
- package/models/filters/type/range-numeric/public_api.d.ts +0 -3
- package/models/filters/type/range-numeric/request.d.ts +0 -11
- package/models/filters/type/range-numeric/toggle-request.d.ts +0 -12
- package/state/reducers/category/pure/build-metadata-from-request.d.ts +0 -2
- package/testing/factories/filters/filter.factory.d.ts +0 -18
- package/testing/factories/filters/public_api.d.ts +0 -4
- package/testing/factories/filters/request.factory.d.ts +0 -15
- package/testing/factories/filters/toggle-request.d.ts +0 -18
- package/testing/factories/filters/type/equal/option.d.ts +0 -17
- package/testing/factories/filters/type/equal/public_api.d.ts +0 -3
- package/testing/factories/filters/type/equal/request.d.ts +0 -16
- package/testing/factories/filters/type/equal/toggle-request.d.ts +0 -16
- package/testing/factories/filters/type/equal.d.ts +0 -17
- package/testing/factories/filters/type/public_api.d.ts +0 -4
- package/testing/factories/filters/type/range-numeric/option.d.ts +0 -15
- package/testing/factories/filters/type/range-numeric/pair.d.ts +0 -23
- package/testing/factories/filters/type/range-numeric/public_api.d.ts +0 -5
- package/testing/factories/filters/type/range-numeric/request-option.d.ts +0 -15
- package/testing/factories/filters/type/range-numeric/request.d.ts +0 -23
- package/testing/factories/filters/type/range-numeric/toggle-request.d.ts +0 -20
- package/testing/factories/filters/type/range-numeric.d.ts +0 -19
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"daffodil-category.mjs","sources":["../../../libs/category/src/models/filters/type/category-filter-type.ts","../../../libs/category/src/models/filters/type/range/separator.ts","../../../libs/category/src/models/category-request.ts","../../../libs/category/src/filters/errors/codes.enum.ts","../../../libs/category/src/errors/codes.enum.ts","../../../libs/category/src/filters/errors/filter-not-found.error.ts","../../../libs/category/src/filters/errors/request-name-mismatch.error.ts","../../../libs/category/src/filters/errors/request-type-mismatch.error.ts","../../../libs/category/src/filters/errors/unknown-filter-type.error.ts","../../../libs/category/src/filters/errors/map.ts","../../../libs/category/src/errors/map.ts","../../../libs/category/src/injection-tokens/error-matcher.token.ts","../../../libs/category/src/filters/type/equal/behaviors/apply/apply.ts","../../../libs/category/src/filters/type/range/compute-pair-label.ts","../../../libs/category/src/filters/type/range/behaviors/apply/apply.ts","../../../libs/category/src/filters/validators/request-name-match.ts","../../../libs/category/src/filters/validators/request-type-match.ts","../../../libs/category/src/filters/behaviors/apply/apply-filter.ts","../../../libs/category/src/filters/behaviors/apply/apply-request-to-filters.ts","../../../libs/category/src/filters/behaviors/apply/apply-requests-to-filters.ts","../../../libs/category/src/filters/type/equal/behaviors/clear/clear.ts","../../../libs/category/src/filters/type/range/behaviors/clear/clear.ts","../../../libs/category/src/filters/behaviors/clear/clear-filter.ts","../../../libs/category/src/filters/behaviors/clear/clear-filters.ts","../../../libs/category/src/filters/type/equal/behaviors/remove/remove.ts","../../../libs/category/src/filters/type/range/behaviors/remove/remove.ts","../../../libs/category/src/filters/behaviors/remove/remove-filter.ts","../../../libs/category/src/filters/behaviors/remove/remove-request-from-filters.ts","../../../libs/category/src/filters/behaviors/remove/remove-requests-from-filters.ts","../../../libs/category/src/filters/type/equal/behaviors/toggle/toggle.ts","../../../libs/category/src/filters/type/range/behaviors/toggle/toggle.ts","../../../libs/category/src/filters/behaviors/toggle/toggle.ts","../../../libs/category/src/filters/behaviors/toggle/toggle-request-on-filters.ts","../../../libs/category/src/filters/type/equal/is-applied/is-applied.ts","../../../libs/category/src/filters/type/range/is-applied/is-applied.ts","../../../libs/category/src/filters/is-applied/is-filter-applied.ts","../../../libs/category/src/filters/type/equal/is-applied/is-toggle-request-applied-to-filter.ts","../../../libs/category/src/filters/type/range/is-applied/is-toggle-request-applied-to-filter.ts","../../../libs/category/src/filters/is-applied/is-toggle-request-applied-to-filter.ts","../../../libs/category/src/filters/find-applied/find-applied-options.ts","../../../libs/category/src/filters/type/equal/to-request/filter-to-request.ts","../../../libs/category/src/filters/type/range/to-request/filter-to-request.ts","../../../libs/category/src/filters/type/range-numeric/to-request/filter-to-request.ts","../../../libs/category/src/filters/to-request/filter-to-request.ts","../../../libs/category/src/filters/to-request/filters-to-requests.ts","../../../libs/category/src/filters/type/range/array-to-dict/pair.ts","../../../libs/category/src/filters/type/equal/array-to-dict/option.ts","../../../libs/category/src/filters/array-to-dict/array-to-dict.ts","../../../libs/category/src/filters/compute-applied-filters/compute-applied-filters.ts","../../../libs/category/src/daffodil-category.ts"],"sourcesContent":["/**\n * The known types of filters.\n */\nexport enum DaffCategoryFilterType {\n Equal = 'equal',\n RangeNumeric = 'rangeNumeric'\n}\n","/**\n * The separator between a range type filter's values\n * e.g. \"price\": \"30-40\".\n */\nexport const DaffCategoryFromToFilterSeparator = '-';\n","import {\n ID,\n DaffLocatable,\n} from '@daffodil/core';\nimport { DaffSortDirectionEnum } from '@daffodil/core/state';\n\nimport { DaffCategory } from './category';\nimport { DaffCategoryFilterRequest } from './filters/public_api';\n\n/**\n * When you request a category page, there's two ways to do so, via URL or via ID.\n */\nexport enum DaffCategoryRequestKind {\n URL = 'URL',\n // eslint-disable-next-line @typescript-eslint/no-shadow\n ID = 'ID'\n}\n\n/**\n * A model of the request sent to the {@link DaffCategoryServiceInterface} to retrieve information\n * about a category.\n */\nexport interface DaffCategoryBaseRequest {\n /**\n * The properties by which to filter the items of the category being requested.\n */\n filter_requests?: DaffCategoryFilterRequest[];\n\n /**\n * The option by which to sort a category's items.\n */\n applied_sort_option?: string;\n\n /**\n * The direction by which to sort the category's items.\n */\n applied_sort_direction?: DaffSortDirectionEnum;\n\n /**\n * What page of the category's items to retrieve.\n */\n current_page?: number;\n\n /**\n * The number of items per-page to request.\n */\n page_size?: number;\n}\n\n/**\n * The request used to retrieve a category and its relevant items.\n */\nexport type DaffCategoryRequest = DaffCategoryIdRequest | DaffCategoryUrlRequest;\n\n/**\n * A request used to retrieve a category by its uid.\n */\nexport interface DaffCategoryIdRequest extends DaffCategoryBaseRequest {\n id: DaffCategory['id'];\n kind: DaffCategoryRequestKind.ID;\n}\n\n/**\n * A request used to retrieve a category by its URL.\n * The qualified URL without domain.\n * e.g. a/path/to/the/category.html\n */\nexport interface DaffCategoryUrlRequest extends DaffCategoryBaseRequest, DaffLocatable {\n kind: DaffCategoryRequestKind.URL;\n};\n","/**\n * The error codes applicable to the filter behaviors of `@daffodil/category`.\n *\n * @docs-private\n */\nexport enum DaffCategoryFilterErrorCodes {\n FILTER_REQUEST_TYPE_MISMATCH = 'DAFF_CATEGORY_FILTER_REQUEST_TYPE_MISMATCH',\n FILTER_REQUEST_NAME_MISMATCH = 'DAFF_CATEGORY_FILTER_REQUEST_NAME_MISMATCH',\n FILTER_NOT_FOUND = 'DAFF_CATEGORY_FILTER_NOT_FOUND',\n UNKNOWN_FILTER_TYPE = 'DAFF_CATEGORY_UNKNOWN_FILTER_TYPE',\n}\n","import { DaffCategoryFilterErrorCodes } from '../filters/errors/codes.enum';\n\n/**\n *\n * The available error codes of the @daffodil/category package.\n *\n * Note that this only contains errors in the root @daffodil/category package, not\n * any of its subpackages e.g. `@daffodil/category/testing`.\n */\nexport const DaffCategoryErrorCodes = {\n ...DaffCategoryFilterErrorCodes,\n};\nexport type DaffCategoryErrorCodes = DaffCategoryFilterErrorCodes;\n","import {\n DaffInheritableError,\n DaffError,\n} from '@daffodil/core';\n\nimport { DaffCategoryErrorCodes } from '../../errors/codes.enum';\n\n/**\n * An error thrown when a lookup for a filter.\n */\nexport class DaffCategoryFilterNotFound extends DaffInheritableError implements DaffError {\n public readonly code: string = DaffCategoryErrorCodes.FILTER_NOT_FOUND;\n\n constructor(message?: string) {\n\t super(message);\n }\n}\n","import {\n DaffInheritableError,\n DaffError,\n} from '@daffodil/core';\n\nimport { DaffCategoryErrorCodes } from '../../errors/codes.enum';\n\n/**\n * An error thrown when an operation targeting a filter matching one name\n * matches a filter of another name.\n */\nexport class DaffCategoryFilterRequestNameMismatch extends DaffInheritableError implements DaffError {\n public readonly code: string = DaffCategoryErrorCodes.FILTER_REQUEST_NAME_MISMATCH;\n\n constructor(message?: string) {\n\t super(message);\n }\n}\n","import {\n DaffInheritableError,\n DaffError,\n} from '@daffodil/core';\n\nimport { DaffCategoryErrorCodes } from '../../errors/codes.enum';\n\n/**\n * An error thrown when an operation targeting a filter matching one type\n * matches a filter of another type.\n */\nexport class DaffCategoryFilterRequestTypeMismatch extends DaffInheritableError implements DaffError {\n public readonly code: string = DaffCategoryErrorCodes.FILTER_REQUEST_TYPE_MISMATCH;\n\n constructor(message?: string) {\n\t super(message);\n }\n}\n","import {\n DaffInheritableError,\n DaffError,\n} from '@daffodil/core';\n\nimport { DaffCategoryErrorCodes } from '../../errors/codes.enum';\n\n/**\n * An error thrown when an operation targeting a filter matches a type unknown\n * to Daffodil.\n */\nexport class DaffCategoryUnknownFilterType extends DaffInheritableError implements DaffError {\n public readonly code: string = DaffCategoryErrorCodes.UNKNOWN_FILTER_TYPE;\n\n constructor(message?: string) {\n\t super(message);\n }\n}\n","import { DaffCategoryFilterErrorCodes } from './codes.enum';\nimport { DaffCategoryFilterNotFound } from './filter-not-found.error';\nimport { DaffCategoryFilterRequestNameMismatch } from './request-name-mismatch.error';\nimport { DaffCategoryFilterRequestTypeMismatch } from './request-type-mismatch.error';\nimport { DaffCategoryUnknownFilterType } from './unknown-filter-type.error';\n\n/**\n * A mapping from error codes to error class constructors.\n */\nexport const DaffCategoryFiltersErrorMap = {\n [DaffCategoryFilterErrorCodes.FILTER_REQUEST_TYPE_MISMATCH]: DaffCategoryFilterRequestTypeMismatch,\n [DaffCategoryFilterErrorCodes.FILTER_REQUEST_NAME_MISMATCH]: DaffCategoryFilterRequestNameMismatch,\n [DaffCategoryFilterErrorCodes.FILTER_NOT_FOUND]: DaffCategoryFilterNotFound,\n [DaffCategoryFilterErrorCodes.UNKNOWN_FILTER_TYPE]: DaffCategoryUnknownFilterType,\n};\n","import { DaffCategoryFiltersErrorMap } from '../filters/errors/map';\n/**\n * A mapping from error codes to error class constructors.\n */\nexport const DaffCategoryErrorMap: typeof DaffCategoryFiltersErrorMap = {\n ...DaffCategoryFiltersErrorMap,\n};\n","import { InjectionToken } from '@angular/core';\n\nimport { daffTransformErrorToStateError } from '@daffodil/core/state';\n\n/**\n * Transforms `DaffError`s into `DaffStateError`s before they are serialized into state.\n * Can be used to further refine Daffodil errors into more specific app errors.\n */\nexport const DAFF_CATEGORY_ERROR_MATCHER = new InjectionToken<typeof daffTransformErrorToStateError>(\n 'DAFF_CATEGORY_ERROR_MATCHER',\n { factory: () => daffTransformErrorToStateError },\n);\n","import {\n DaffCategoryFilterEqual,\n DaffCategoryFilterEqualRequest,\n} from '../../../../../models/public_api';\n\n/**\n * Applies a {@link DaffCategoryFilterEqualRequest} to a {@link DaffCategoryFilterEqual}\n *\n * @idempotent {filter}\n * @docs-private\n */\nexport const daffApplyFilterEqual = (\n request: DaffCategoryFilterEqualRequest,\n filter: DaffCategoryFilterEqual,\n): DaffCategoryFilterEqual => ({\n ...filter,\n options: request.value.reduce((acc, value) => {\n const option = filter.options[value];\n\n if (option) {\n acc[value] = {\n ...option,\n applied: true,\n };\n }\n\n return acc;\n }, { ...filter.options }),\n});\n","import { DaffCategoryFromToFilterSeparator } from '../../../models/public_api';\n\nexport const daffCategoryComputeFilterRangePairLabel = (min, max): string =>\n `${min}${DaffCategoryFromToFilterSeparator}${max}`;\n","import {\n DaffCategoryFilterRangeRequestBase,\n DaffCategoryFilterRangeBase,\n} from '../../../../../models/public_api';\nimport { daffCategoryComputeFilterRangePairLabel } from '../../compute-pair-label';\n\n/**\n * Applies a {@link DaffCategoryFilterRangeRequestBase} to a {@link DaffCategoryFilterRangeBase}\n *\n * @idempotent {filter}\n * @docs-private\n */\nexport const daffApplyFilterRange = <T, U extends DaffCategoryFilterRangeRequestBase<T>, V extends DaffCategoryFilterRangeBase<T>>(\n request: U,\n filter: V,\n): V => ({\n ...filter,\n options: {\n [daffCategoryComputeFilterRangePairLabel(request.value.min, request.value.max)]: {\n min: {\n value: request.value.min,\n label: String(request.value.min),\n },\n max: {\n value: request.value.max,\n label: String(request.value.max),\n },\n applied: true,\n },\n },\n});\n","import {\n DaffCategoryFilterRequest,\n DaffCategoryFilter,\n DaffCategoryFilterToggleRequest,\n} from '../../models/public_api';\nimport { DaffCategoryFilterNotFound } from '../errors/filter-not-found.error';\nimport { DaffCategoryFilterRequestNameMismatch } from '../errors/request-name-mismatch.error';\n\n/**\n * Ensures that the names of the filter and the filter request match.\n *\n * @throws {@link DaffCategoryFilterNotFound} if the names do not match.\n */\nexport const daffCategoryValidateFilterRequestNameMatch = (\n request: DaffCategoryFilterRequest | DaffCategoryFilterToggleRequest,\n filter: DaffCategoryFilter,\n): void => {\n if (!filter) {\n throw new DaffCategoryFilterNotFound('Filter does not exist');\n }\n if (request.name !== filter.name) {\n throw new DaffCategoryFilterRequestNameMismatch('Filter name does not match request name');\n }\n};\n","import {\n DaffCategoryFilterRequest,\n DaffCategoryFilter,\n DaffCategoryFilterToggleRequest,\n} from '../../models/public_api';\nimport { DaffCategoryFilterRequestTypeMismatch } from '../errors/request-type-mismatch.error';\n\n/**\n * Ensures that the types of the filter and the filter request match.\n *\n * @throws {@link DaffCategoryFilterRequestTypeMismatch} if the types do not match.\n */\nexport const daffCategoryValidateFilterRequestTypeMatch = (\n request: DaffCategoryFilterRequest | DaffCategoryFilterToggleRequest,\n filter: DaffCategoryFilter,\n): void => {\n if (request.type !== filter.type) {\n throw new DaffCategoryFilterRequestTypeMismatch('Filter types don\\'t match');\n }\n};\n","import {\n DaffCategoryFilterRequest,\n DaffCategoryFilter,\n DaffCategoryFilterType,\n DaffCategoryFilterEqual,\n DaffCategoryFilterRangeNumeric,\n} from '../../../models/public_api';\nimport { DaffCategoryUnknownFilterType } from '../../errors/unknown-filter-type.error';\nimport { daffApplyFilterEqual } from '../../type/equal/behaviors/apply/apply';\nimport { daffApplyFilterRange } from '../../type/range/behaviors/apply/apply';\nimport {\n daffCategoryValidateFilterRequestNameMatch,\n daffCategoryValidateFilterRequestTypeMatch,\n} from '../../validators/public_api';\n\n/**\n * Applies a filter request to the matching filter.\n *\n * @idempotent {filter}\n * @throws {@link DaffCategoryUnknownFilterType}\n */\nexport const daffApplyFilter = (request: DaffCategoryFilterRequest, filter: DaffCategoryFilter): DaffCategoryFilter => {\n daffCategoryValidateFilterRequestNameMatch(request, filter);\n daffCategoryValidateFilterRequestTypeMatch(request, filter);\n\n switch (request.type) {\n case DaffCategoryFilterType.Equal:\n return daffApplyFilterEqual(request, <DaffCategoryFilterEqual>filter);\n case(DaffCategoryFilterType.RangeNumeric):\n return daffApplyFilterRange(request, <DaffCategoryFilterRangeNumeric>filter);\n default:\n throw new DaffCategoryUnknownFilterType('Unknown filter type');\n }\n};\n","import { Dict } from '@daffodil/core';\n\nimport {\n DaffCategoryFilterRequest,\n DaffCategoryFilter,\n} from '../../../models/public_api';\nimport { daffApplyFilter } from './apply-filter';\n\n/**\n * Applies a {@link DaffCategoryFilterRequest} to a {@link Dict} of {@link DaffCategoryFilter}\n * returning the updated {@link Dict}.\n *\n * @idempotent {filters}\n */\nexport const daffApplyRequestToFilters = (request: DaffCategoryFilterRequest, filters: Dict<DaffCategoryFilter>): Dict<DaffCategoryFilter> => ({\n ...filters,\n [request.name]: daffApplyFilter(request, filters[request.name]),\n});\n\n\n","import { Dict } from '@daffodil/core';\n\nimport {\n DaffCategoryFilterRequest,\n DaffCategoryFilter,\n} from '../../../models/public_api';\nimport { daffApplyFilter } from './apply-filter';\n\n/**\n * Applies filters from a {@link DaffCategoryFilterRequest} to a {@link Dict}\n * of {@link DaffCategoryFilter}.\n *\n * @idempotent {filters}\n */\nexport const daffApplyRequestsToFilters = (\n filtersRequests: DaffCategoryFilterRequest[],\n filters: Dict<DaffCategoryFilter>,\n): Dict<DaffCategoryFilter> =>\n filtersRequests.reduce((acc, request) => {\n acc[request.name] = daffApplyFilter(request, filters[request.name]);\n return acc;\n }, { ...filters });\n\n\n","import { DaffCategoryFilterEqual } from '../../../../../models/public_api';\n\n/**\n * Unapplies the applied filter options of a {@link DaffCategoryFilterEqual}\n *\n * @idempotent {filter}\n * @docs-private\n */\nexport const daffClearFilterEqual = (filter: DaffCategoryFilterEqual): DaffCategoryFilterEqual => ({\n ...filter,\n options: Object.keys(filter.options).map((key) => filter.options[key]).reduce((acc, option) => {\n acc[option.value] = {\n ...option,\n applied: false,\n };\n return acc;\n }, { ...filter.options }),\n});\n","import { DaffCategoryFilterRangeBase } from '../../../../../models/public_api';\n\n/**\n * Unapplies the applied filter options of a {@link DaffCategoryFilterRangeBase}\n *\n * @idempotent {filter}\n * @docs-private\n */\nexport const daffClearFilterRange = <T, U extends DaffCategoryFilterRangeBase<T>>(filter: U): U => ({\n ...filter,\n options: {},\n});\n","import {\n DaffCategoryFilterType,\n DaffCategoryFilter,\n} from '../../../models/public_api';\nimport { DaffCategoryUnknownFilterType } from '../../errors/unknown-filter-type.error';\nimport { daffClearFilterEqual } from '../../type/equal/behaviors/clear/clear';\nimport { daffClearFilterRange } from '../../type/range/behaviors/clear/clear';\n\n/**\n * Undoes the applied state of all applied filter options of a {@link DaffCategoryFilter}\n * returning the filter.\n *\n * @idempotent {filter}\n */\nexport const daffClearFilter = (filter: DaffCategoryFilter): DaffCategoryFilter => {\n switch (filter.type) {\n case DaffCategoryFilterType.RangeNumeric:\n return daffClearFilterRange(filter);\n case DaffCategoryFilterType.Equal:\n return daffClearFilterEqual(filter);\n default:\n throw new DaffCategoryUnknownFilterType('Unknown filter type');\n }\n};\n","import { Dict } from '@daffodil/core';\n\nimport { DaffCategoryFilter } from '../../../models/public_api';\nimport { daffClearFilter } from './clear-filter';\n\n/**\n * Undoes the applied state of all applied filter options of a {@link Dict} of {@link DaffCategoryFilter}\n * returning updated {@link Dict}.\n *\n * @idempotent {filters}\n */\nexport const daffClearFilters = (filters: Dict<DaffCategoryFilter>): Dict<DaffCategoryFilter> =>\n Object.keys(filters).map((key) => filters[key]).reduce((acc, filter) => {\n acc[filter.name] = daffClearFilter(filter);\n return acc;\n }, {});\n","import {\n DaffCategoryFilterEqualRequest,\n DaffCategoryFilter,\n DaffCategoryFilterEqual,\n} from '../../../../../models/public_api';\n\n/**\n * Removes the matching filter options of a {@link DaffCategoryFilterEqual}\n * that match the {@link DaffCategoryFilterEqualRequest}\n *\n * If there are no matching options, returns the original {@link DaffCategoryFilterEqual}\n *\n * @idempotent {filter}\n * @docs-private\n */\nexport const daffRemoveFilterEqual = (\n request: DaffCategoryFilterEqualRequest,\n filter: DaffCategoryFilterEqual,\n): DaffCategoryFilter => ({\n ...filter,\n options: request.value.reduce((acc, value) => {\n const option = filter.options[value];\n\n if (option) {\n acc[value] = {\n ...option,\n applied: false,\n };\n }\n\n return acc;\n }, { ...filter.options }),\n});\n","import {\n DaffCategoryFilterRangeRequestBase,\n DaffCategoryFilterRangeBase,\n} from '../../../../../models/public_api';\nimport { daffCategoryComputeFilterRangePairLabel } from '../../compute-pair-label';\n\n/**\n * Removes the matching filter options of a {@link DaffCategoryFilterRangeBase}\n * that match the {@link DaffCategoryFilterRangeRequestBase}\n *\n * If there are no matching options, returns the original {@link DaffCategoryFilterRangeBase}\n *\n * @idempotent {filter}\n * @docs-private\n */\nexport const daffRemoveFilterRange = <T, U extends DaffCategoryFilterRangeBase<T>>(\n request: DaffCategoryFilterRangeRequestBase<T>,\n filter: U,\n): U =>\n filter.options[daffCategoryComputeFilterRangePairLabel(request.value.min, request.value.max)]\n ? ({\n ...filter,\n options: {},\n })\n : filter;\n","import {\n DaffCategoryFilterRequest,\n DaffCategoryFilter,\n DaffCategoryFilterType,\n DaffCategoryFilterEqual,\n DaffCategoryFilterRangeNumeric,\n} from '../../../models/public_api';\nimport { DaffCategoryUnknownFilterType } from '../../errors/unknown-filter-type.error';\nimport { daffRemoveFilterEqual } from '../../type/equal/behaviors/remove/remove';\nimport { daffRemoveFilterRange } from '../../type/range/behaviors/remove/remove';\nimport {\n daffCategoryValidateFilterRequestNameMatch,\n daffCategoryValidateFilterRequestTypeMatch,\n} from '../../validators/public_api';\n\n/**\n * Undoes any applied options of a {@link DaffCategoryFilter} that match the\n * {@link DaffCategoryFilterRequest}, returning the {@link DaffCategoryFilter}.\n *\n * @idempotent {filter}\n * @pure\n */\nexport const daffRemoveFilter = (request: DaffCategoryFilterRequest, filter: DaffCategoryFilter): DaffCategoryFilter => {\n daffCategoryValidateFilterRequestNameMatch(request, filter);\n daffCategoryValidateFilterRequestTypeMatch(request, filter);\n\n switch (request.type) {\n case DaffCategoryFilterType.Equal:\n return daffRemoveFilterEqual(request, <DaffCategoryFilterEqual>filter);\n case (DaffCategoryFilterType.RangeNumeric):\n return daffRemoveFilterRange(request, <DaffCategoryFilterRangeNumeric>filter);\n default:\n throw new DaffCategoryUnknownFilterType('Unknown filter type');\n }\n};\n","import { Dict } from '@daffodil/core';\n\nimport {\n DaffCategoryFilterRequest,\n DaffCategoryFilter,\n} from '../../../models/public_api';\nimport { daffRemoveFilter } from './remove-filter';\n\n/**\n * Undoes any applied options of a particular filter of a {@link Dict} of {@link DaffCategoryFilter}\n * that match the {@link DaffCategoryFilterRequest}, returning the {@link Dict} of {@link DaffCategoryFilter}.\n *\n * @idempotent {filters}\n */\nexport const daffRemoveRequestFromFilters = (\n request: DaffCategoryFilterRequest,\n filters: Dict<DaffCategoryFilter>,\n): Dict<DaffCategoryFilter> => ({\n ...filters,\n [request.name]: daffRemoveFilter(request, filters[request.name]),\n});\n","import { Dict } from '@daffodil/core';\n\nimport {\n DaffCategoryFilterRequest,\n DaffCategoryFilter,\n} from '../../../models/public_api';\nimport { daffRemoveFilter } from './remove-filter';\n\n/**\n * Undoes all applied options of a {@link Dict} of {@link DaffCategoryFilter}\n * that match any of the {@link DaffCategoryFilterRequest},\n * returning the updated {@link Dict} of {@link DaffCategoryFilter}.\n *\n * @idempotent {filters}\n */\nexport const daffRemoveRequestsFromFilters = (\n requests: (DaffCategoryFilterRequest)[],\n filters: Dict<DaffCategoryFilter>,\n): Dict<DaffCategoryFilter> =>\n requests.reduce((acc, request) => {\n acc[request.name] = daffRemoveFilter(request, filters[request.name]);\n return acc;\n }, { ...filters });\n","import { DaffCategoryFilterEqual } from '../../../../../models/public_api';\nimport { DaffCategoryFilterEqualToggleRequest } from '../../../../../models/public_api';\n\n/**\n * Oscillates the applied state of the matching filter options of a {@link DaffCategoryFilterEqual}\n * that match the {@link DaffCategoryFilterEqualRequest}\n *\n * If there are no matching options, returns the original {@link DaffCategoryFilterEqual}\n *\n * @docs-private\n */\nexport const daffToggleFilterEqual = (\n request: DaffCategoryFilterEqualToggleRequest,\n filter: DaffCategoryFilterEqual,\n): DaffCategoryFilterEqual => {\n const option = filter.options[request.value];\n\n return option\n ? {\n ...filter,\n options: {\n ...filter.options,\n [option.value]: {\n ...option,\n applied: !option.applied,\n },\n },\n }\n : filter;\n};\n","import {\n DaffCategoryFilterRangeBase,\n DaffCategoryFilterRangeRequestBase,\n} from '../../../../../models/public_api';\nimport { daffCategoryComputeFilterRangePairLabel } from '../../compute-pair-label';\nimport { daffApplyFilterRange } from '../apply/apply';\nimport { daffRemoveFilterRange } from '../remove/remove';\n\n/**\n * Oscillates the applied state of the matching filter options of a {@link DaffCategoryFilterRangeBase}\n * that match the {@link DaffCategoryFilterRangeRequestBase}\n *\n * If there are no matching options, returns the original {@link DaffCategoryFilterRangeBase}\n *\n * @docs-private\n */\nexport const daffToggleFilterRange = <T, U extends DaffCategoryFilterRangeBase<T>>(\n request: DaffCategoryFilterRangeRequestBase<T>,\n filter: U,\n): U =>\n filter.options[daffCategoryComputeFilterRangePairLabel(request.value.min, request.value.max)]\n ? daffRemoveFilterRange(request, filter)\n : daffApplyFilterRange(request, filter);\n","import {\n DaffCategoryFilterToggleRequest,\n DaffCategoryFilter,\n DaffCategoryFilterType,\n DaffCategoryFilterEqual,\n DaffCategoryFilterRangeNumeric,\n} from '../../../models/public_api';\nimport { DaffCategoryUnknownFilterType } from '../../errors/unknown-filter-type.error';\nimport { daffToggleFilterEqual } from '../../type/equal/behaviors/toggle/toggle';\nimport { daffToggleFilterRange } from '../../type/range/behaviors/toggle/toggle';\nimport {\n daffCategoryValidateFilterRequestNameMatch,\n daffCategoryValidateFilterRequestTypeMatch,\n} from '../../validators/public_api';\n\n/**\n * Toggles the state of the filters (and their options) in the {@link DaffCategoryFilter}\n * that match the {@link DaffCategoryFilterToggleRequest} .\n */\nexport function daffToggleFilter(\n request: DaffCategoryFilterToggleRequest,\n filter: DaffCategoryFilter,\n): DaffCategoryFilter {\n daffCategoryValidateFilterRequestNameMatch(request, filter);\n daffCategoryValidateFilterRequestTypeMatch(request, filter);\n\n switch (request.type) {\n case DaffCategoryFilterType.Equal:\n return daffToggleFilterEqual(request, <DaffCategoryFilterEqual>filter);\n case(DaffCategoryFilterType.RangeNumeric):\n return daffToggleFilterRange(request, <DaffCategoryFilterRangeNumeric>filter);\n default:\n throw new DaffCategoryUnknownFilterType('Unknown filter type');\n }\n}\n","import { Dict } from '@daffodil/core';\n\nimport {\n DaffCategoryFilter,\n DaffCategoryFilterToggleRequest,\n} from '../../../models/public_api';\nimport { daffToggleFilter } from './toggle';\n\n/**\n * Toggles the state of a filter option in the {@link Dict<DaffCategoryFilter>}\n * that matches the {@link DaffCategoryFilterToggleRequest}.\n */\nexport const daffToggleRequestOnFilters = (\n request: DaffCategoryFilterToggleRequest,\n filters: Dict<DaffCategoryFilter>): Dict<DaffCategoryFilter> => ({\n ...filters,\n [request.name]: daffToggleFilter(request, filters[request.name]),\n});\n\n\n","import { DaffCategoryFilterEqual } from '../../../../models/public_api';\n\n/**\n * Determines whether or not the {@link DaffCategoryFilterEqual} has any applied options.\n */\nexport const daffIsFilterEqualApplied = (filter: DaffCategoryFilterEqual): boolean =>\n Object.keys(filter.options).map((key) => filter.options[key]).findIndex(option => option.applied) > -1;\n","import { DaffCategoryFilterRangeBase } from '../../../../models/public_api';\n\n/**\n * Determines whether or not a {@link DaffCategoryFilterRangeBase} has any applied options.\n */\nexport const daffIsFilterRangeApplied = <T>(filter: DaffCategoryFilterRangeBase<T>): boolean =>\n Object.keys(filter.options).length > 0;\n","import {\n DaffCategoryFilterType,\n DaffCategoryFilter,\n} from '../../models/public_api';\nimport { DaffCategoryUnknownFilterType } from '../errors/unknown-filter-type.error';\nimport { daffIsFilterEqualApplied } from '../type/equal/is-applied/is-applied';\nimport { daffIsFilterRangeApplied } from '../type/range/is-applied/is-applied';\n\n/**\n * Determines whether or not a filter has any currently applied options.\n */\nexport const daffIsFilterApplied = (filter: DaffCategoryFilter): boolean => {\n switch (filter.type) {\n case DaffCategoryFilterType.RangeNumeric:\n return daffIsFilterRangeApplied(filter);\n case DaffCategoryFilterType.Equal:\n return daffIsFilterEqualApplied(filter);\n default:\n throw new DaffCategoryUnknownFilterType('Unknown filter type');\n }\n};\n","import {\n DaffCategoryFilterEqualToggleRequest,\n DaffCategoryFilterEqual,\n} from '../../../../models/public_api';\n\n/**\n * Determines whether or not any {@link DaffCategoryFilterEqual} options matching {@link DaffCategoryFilterEqualToggleRequest} are applied.\n */\nexport const daffIsEqualToggleRequestAppliedToFilter = (\n request: DaffCategoryFilterEqualToggleRequest,\n filter: DaffCategoryFilterEqual,\n): boolean => !!filter.options[request.value]?.applied;\n","import {\n DaffCategoryFilterRangeRequestBase,\n DaffCategoryFilterRangeBase,\n} from '../../../../models/public_api';\nimport { daffCategoryComputeFilterRangePairLabel } from '../compute-pair-label';\n\n/**\n * Determines whether or not any {@link DaffCategoryFilterRangeBase} options matching {@link DaffCategoryFilterRangeRequestBase} are applied.\n */\nexport const daffIsRangeToggleRequestAppliedToFilter = <T>(\n request: DaffCategoryFilterRangeRequestBase<T>,\n filter: DaffCategoryFilterRangeBase<T>,\n): boolean =>\n daffCategoryComputeFilterRangePairLabel(request.value.min, request.value.max) in filter.options;\n","import {\n DaffCategoryFilter,\n DaffCategoryFilterToggleRequest,\n DaffCategoryFilterType,\n DaffCategoryFilterRangeNumericToggleRequest,\n DaffCategoryFilterEqualToggleRequest,\n} from '../../models/public_api';\nimport { DaffCategoryUnknownFilterType } from '../errors/unknown-filter-type.error';\nimport { daffIsEqualToggleRequestAppliedToFilter } from '../type/equal/is-applied/is-toggle-request-applied-to-filter';\nimport { daffIsRangeToggleRequestAppliedToFilter } from '../type/range/is-applied/is-toggle-request-applied-to-filter';\n\n/**\n * Determines whether or not a {@link DaffCategoryFilterToggleRequest} is already applied to a {@link DaffCategoryFilter}.\n */\nexport const daffIsToggleRequestAppliedToFilter = (request: DaffCategoryFilterToggleRequest, filter: DaffCategoryFilter): boolean => {\n switch (filter.type) {\n case DaffCategoryFilterType.RangeNumeric:\n return daffIsRangeToggleRequestAppliedToFilter(<DaffCategoryFilterRangeNumericToggleRequest>request, filter);\n case DaffCategoryFilterType.Equal:\n return daffIsEqualToggleRequestAppliedToFilter(<DaffCategoryFilterEqualToggleRequest>request, filter);\n default:\n throw new DaffCategoryUnknownFilterType('Unknown filter type');\n }\n};\n","import { DaffCategoryFilterBase } from '../../models/public_api';\n\n/**\n * Finds the applied options in the filter.\n */\nexport const daffCategoryFindAppliedFilterOptions = <T extends DaffCategoryFilterBase>(filter: T): T['options'][string][] =>\n Object.keys(filter.options).map((key) => <T['options'][string]>filter.options[key]).filter((option) => option.applied);\n","import {\n DaffCategoryFilterEqual,\n DaffCategoryFilterEqualRequest,\n DaffCategoryFilterType,\n} from '../../../../models/public_api';\nimport { daffCategoryFindAppliedFilterOptions } from '../../../find-applied/public_api';\n\n/**\n * Builds an {@link DaffCategoryFilterEqualRequest} from the passed filter and options.\n */\nexport const daffCategoryFilterEqualToRequest = (\n filter: DaffCategoryFilterEqual,\n): DaffCategoryFilterEqualRequest | null => {\n const options = daffCategoryFindAppliedFilterOptions(filter);\n if(!options.length){\n return null;\n }\n\n return {\n type: DaffCategoryFilterType.Equal,\n name: filter.name,\n value: options.map(option => option.value),\n };\n};\n","import {\n DaffCategoryFilterRangeBase,\n DaffCategoryFilterRangeRequestBase,\n} from '../../../../models/public_api';\nimport { daffCategoryFindAppliedFilterOptions } from '../../../find-applied/public_api';\n\n/**\n * Builds a {@link DaffCategoryFilterRangeRequestBase} from the passed {@link DaffCategoryFilterRangeBase} and options.\n */\nexport const daffCategoryFilterRangeToRequest = <T, U extends DaffCategoryFilterRangeBase<T>>(\n filter: U,\n): DaffCategoryFilterRangeRequestBase<T> => {\n const options = daffCategoryFindAppliedFilterOptions(filter);\n if(!options.length){\n return null;\n }\n\n return {\n type: filter.type,\n name: filter.name,\n value: {\n min: options[0].min.value,\n max: options[0].max.value,\n },\n };\n};\n","import {\n DaffCategoryFilterRangeNumeric,\n DaffCategoryFilterRangeNumericRequest,\n} from '../../../../models/public_api';\nimport { daffCategoryFilterRangeToRequest } from '../../range/to-request/filter-to-request';\n\n/**\n * Transforms a {@link DaffCategoryFilterRangeNumeric} into a {@link DaffCategoryFilterRangeNumericRequest}\n */\nexport const daffCategoryFilterRangeNumericToRequest = (\n filter: DaffCategoryFilterRangeNumeric,\n): DaffCategoryFilterRangeNumericRequest => <DaffCategoryFilterRangeNumericRequest>daffCategoryFilterRangeToRequest(filter);\n","import {\n DaffCategoryFilter,\n DaffCategoryFilterRequest,\n DaffCategoryFilterType,\n} from '../../models/public_api';\nimport { DaffCategoryUnknownFilterType } from '../errors/unknown-filter-type.error';\nimport { daffCategoryFilterEqualToRequest } from '../type/equal/to-request/filter-to-request';\nimport { daffCategoryFilterRangeNumericToRequest } from '../type/range-numeric/to-request/filter-to-request';\n\n/**\n * Builds a category filter request from a category filter.\n * Returns null if the category filter does not have at least one applied option.\n */\nexport function daffCategoryFilterToRequest(filter: DaffCategoryFilter): DaffCategoryFilterRequest | null {\n switch (filter.type) {\n case DaffCategoryFilterType.RangeNumeric:\n return daffCategoryFilterRangeNumericToRequest(filter);\n case DaffCategoryFilterType.Equal:\n return daffCategoryFilterEqualToRequest(filter);\n default:\n throw new DaffCategoryUnknownFilterType('Unknown filter type');\n }\n};\n","import { Dict } from '@daffodil/core';\n\nimport {\n DaffCategoryFilter,\n DaffCategoryFilterRequest,\n} from '../../models/public_api';\nimport { daffCategoryFilterToRequest } from './filter-to-request';\n\n/**\n * Builds a list of filter requests from a list of filters.\n * Requests are only built for the filters that have at least one applied option.\n */\nexport function daffCategoryFiltersToRequests(filters: Dict<DaffCategoryFilter>): DaffCategoryFilterRequest[] {\n return Object.keys(filters).map((key) => filters[key]).reduce((acc: DaffCategoryFilterRequest[], filter) => {\n const request = daffCategoryFilterToRequest(filter);\n\n if (request) {\n acc.push(request);\n }\n\n return acc;\n }, []);\n}\n","import {\n Dict,\n daffArrayToDict,\n} from '@daffodil/core';\n\nimport { DaffCategoryFilterRangePair } from '../../../../models/public_api';\nimport { daffCategoryComputeFilterRangePairLabel } from '../compute-pair-label';\n\n/**\n * Transforms an {@link DaffCategoryFilterRangePair[]} to a {@link Dict<DaffCategoryFilterRangePair>}.\n */\nexport const daffCategoryFilterRangePairArrayToDict = <T>(pairs: DaffCategoryFilterRangePair<T>[]): Dict<DaffCategoryFilterRangePair<T>> =>\n daffArrayToDict(pairs, pair => daffCategoryComputeFilterRangePairLabel(pair.min.value, pair.max.value));\n","import {\n Dict,\n daffArrayToDict,\n} from '@daffodil/core';\n\nimport { DaffCategoryFilterEqualOption } from '../../../../models/public_api';\n\n/**\n * Converts a list of category equal filter options to a dict of options keyed by option value.\n */\nexport const daffCategoryFilterEqualOptionArrayToDict =\n (options: DaffCategoryFilterEqualOption[]): Dict<DaffCategoryFilterEqualOption> =>\n daffArrayToDict(options, option => option.value);\n","import {\n Dict,\n daffArrayToDict,\n} from '@daffodil/core';\n\nimport { DaffCategoryFilter } from '../../models/public_api';\n\n/**\n * Converts a list of category filters into a {@link Dict} of filters keyed by filter name.\n */\nexport const daffCategoryFilterArrayToDict = (filters: DaffCategoryFilter[]): Dict<DaffCategoryFilter> =>\n daffArrayToDict(filters, filter => filter.name);\n","import { Dict } from '@daffodil/core';\n\nimport {\n DaffCategoryFilter,\n DaffCategoryFilterType,\n DaffCategoryFilterEqualOption,\n DaffCategoryFilterRangePair,\n} from '../../models/public_api';\nimport { daffCategoryFindAppliedFilterOptions } from '../find-applied/public_api';\nimport { daffCategoryFilterEqualOptionArrayToDict } from '../type/equal/public_api';\nimport { daffCategoryFilterRangePairArrayToDict } from '../type/range/public_api';\n\n/**\n * Returns a {@link Dict<DaffCategoryFilter>} and only their applied options.\n * {@link DaffCategoryFilter} that have no applied options will be omitted.\n */\nexport const daffCategoryComputeAppliedFilters = (filters: Dict<DaffCategoryFilter>): Dict<DaffCategoryFilter> =>\n Object.keys(filters).map(key => filters[key]).reduce((acc, filter) => {\n const appliedOptions = daffCategoryFindAppliedFilterOptions(filter);\n\n if (appliedOptions.length > 0) {\n acc[filter.name] = {\n ...filter,\n options: filter.type === DaffCategoryFilterType.Equal\n ? daffCategoryFilterEqualOptionArrayToDict(<DaffCategoryFilterEqualOption[]>appliedOptions)\n : daffCategoryFilterRangePairArrayToDict(<DaffCategoryFilterRangePair<unknown>[]>appliedOptions),\n };\n }\n\n return acc;\n }, {});\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
1
|
+
{"version":3,"file":"daffodil-category.mjs","sources":["../../../libs/category/src/models/category-request.ts","../../../libs/category/src/injection-tokens/error-matcher.token.ts","../../../libs/category/src/daffodil-category.ts"],"sourcesContent":["import {\n ID,\n DaffLocatable,\n} from '@daffodil/core';\nimport { DaffProductCollectionRequest } from '@daffodil/product';\n\nimport { DaffCategory } from './category';\n\n/**\n * When you request a category page, there's two ways to do so, via URL or via ID.\n */\nexport enum DaffCategoryRequestKind {\n URL = 'URL',\n // eslint-disable-next-line @typescript-eslint/no-shadow\n ID = 'ID'\n}\n\n/**\n * The request used to retrieve a category and its relevant items.\n */\nexport type DaffCategoryRequest = DaffCategoryIdRequest | DaffCategoryUrlRequest;\n\n/**\n * A request used to retrieve a category by its uid.\n */\nexport interface DaffCategoryIdRequest extends DaffProductCollectionRequest {\n id: DaffCategory['id'];\n kind: DaffCategoryRequestKind.ID;\n}\n\n/**\n * A request used to retrieve a category by its URL.\n * The qualified URL without domain.\n * e.g. a/path/to/the/category.html\n */\nexport interface DaffCategoryUrlRequest extends DaffProductCollectionRequest, DaffLocatable {\n kind: DaffCategoryRequestKind.URL;\n};\n","import { InjectionToken } from '@angular/core';\n\nimport { daffTransformErrorToStateError } from '@daffodil/core/state';\n\n/**\n * Transforms `DaffError`s into `DaffStateError`s before they are serialized into state.\n * Can be used to further refine Daffodil errors into more specific app errors.\n */\nexport const DAFF_CATEGORY_ERROR_MATCHER = new InjectionToken<typeof daffTransformErrorToStateError>(\n 'DAFF_CATEGORY_ERROR_MATCHER',\n { factory: () => daffTransformErrorToStateError },\n);\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;AAQA;;AAEG;IACS,wBAIX;AAJD,CAAA,UAAY,uBAAuB,EAAA;AACjC,IAAA,uBAAA,CAAA,KAAA,CAAA,GAAA,KAAW,CAAA;;AAEX,IAAA,uBAAA,CAAA,IAAA,CAAA,GAAA,IAAS,CAAA;AACX,CAAC,EAJW,uBAAuB,KAAvB,uBAAuB,GAIlC,EAAA,CAAA,CAAA,CAAA;AAsBA;;ACjCD;;;AAGG;AACU,MAAA,2BAA2B,GAAG,IAAI,cAAc,CAC3D,6BAA6B,EAC7B,EAAE,OAAO,EAAE,MAAM,8BAA8B,EAAE;;ACVnD;;AAEG;;;;"}
|
@@ -1,16 +1,7 @@
|
|
1
|
-
import { DaffIdentifiable
|
2
|
-
import {
|
3
|
-
import { DaffCategoryFilterable } from './filters/public_api';
|
1
|
+
import { DaffIdentifiable } from '@daffodil/core';
|
2
|
+
import { DaffProductCollectionMetadata } from '@daffodil/product';
|
4
3
|
/**
|
5
4
|
* The DaffCategoryPageMetadata describes the properties of a Category Page.
|
6
5
|
*/
|
7
|
-
export interface DaffCategoryPageMetadata extends
|
8
|
-
/**
|
9
|
-
* The total number of products in the currently visible category.
|
10
|
-
*/
|
11
|
-
total_products: number;
|
12
|
-
/**
|
13
|
-
* The identifiers of the products currently visible in the category.
|
14
|
-
*/
|
15
|
-
product_ids: ID[];
|
6
|
+
export interface DaffCategoryPageMetadata extends DaffProductCollectionMetadata, DaffIdentifiable {
|
16
7
|
}
|
@@ -1,7 +1,6 @@
|
|
1
1
|
import { DaffLocatable } from '@daffodil/core';
|
2
|
-
import {
|
2
|
+
import { DaffProductCollectionRequest } from '@daffodil/product';
|
3
3
|
import { DaffCategory } from './category';
|
4
|
-
import { DaffCategoryFilterRequest } from './filters/public_api';
|
5
4
|
/**
|
6
5
|
* When you request a category page, there's two ways to do so, via URL or via ID.
|
7
6
|
*/
|
@@ -9,32 +8,6 @@ export declare enum DaffCategoryRequestKind {
|
|
9
8
|
URL = "URL",
|
10
9
|
ID = "ID"
|
11
10
|
}
|
12
|
-
/**
|
13
|
-
* A model of the request sent to the {@link DaffCategoryServiceInterface} to retrieve information
|
14
|
-
* about a category.
|
15
|
-
*/
|
16
|
-
export interface DaffCategoryBaseRequest {
|
17
|
-
/**
|
18
|
-
* The properties by which to filter the items of the category being requested.
|
19
|
-
*/
|
20
|
-
filter_requests?: DaffCategoryFilterRequest[];
|
21
|
-
/**
|
22
|
-
* The option by which to sort a category's items.
|
23
|
-
*/
|
24
|
-
applied_sort_option?: string;
|
25
|
-
/**
|
26
|
-
* The direction by which to sort the category's items.
|
27
|
-
*/
|
28
|
-
applied_sort_direction?: DaffSortDirectionEnum;
|
29
|
-
/**
|
30
|
-
* What page of the category's items to retrieve.
|
31
|
-
*/
|
32
|
-
current_page?: number;
|
33
|
-
/**
|
34
|
-
* The number of items per-page to request.
|
35
|
-
*/
|
36
|
-
page_size?: number;
|
37
|
-
}
|
38
11
|
/**
|
39
12
|
* The request used to retrieve a category and its relevant items.
|
40
13
|
*/
|
@@ -42,7 +15,7 @@ export declare type DaffCategoryRequest = DaffCategoryIdRequest | DaffCategoryUr
|
|
42
15
|
/**
|
43
16
|
* A request used to retrieve a category by its uid.
|
44
17
|
*/
|
45
|
-
export interface DaffCategoryIdRequest extends
|
18
|
+
export interface DaffCategoryIdRequest extends DaffProductCollectionRequest {
|
46
19
|
id: DaffCategory['id'];
|
47
20
|
kind: DaffCategoryRequestKind.ID;
|
48
21
|
}
|
@@ -51,6 +24,6 @@ export interface DaffCategoryIdRequest extends DaffCategoryBaseRequest {
|
|
51
24
|
* The qualified URL without domain.
|
52
25
|
* e.g. a/path/to/the/category.html
|
53
26
|
*/
|
54
|
-
export interface DaffCategoryUrlRequest extends
|
27
|
+
export interface DaffCategoryUrlRequest extends DaffProductCollectionRequest, DaffLocatable {
|
55
28
|
kind: DaffCategoryRequestKind.URL;
|
56
29
|
}
|
package/models/public_api.d.ts
CHANGED
@@ -1,7 +1,6 @@
|
|
1
1
|
export { DaffGetCategoryResponse } from './get-category-response';
|
2
|
-
export * from './filters/public_api';
|
3
2
|
export { DaffCategoryPageMetadata } from './category-page-metadata';
|
4
3
|
export { DaffCategoryBreadcrumb } from './category-breadcrumb';
|
5
4
|
export { DaffCategory } from './category';
|
6
5
|
export { DaffGenericCategory } from './generic-category';
|
7
|
-
export { DaffCategoryRequest,
|
6
|
+
export { DaffCategoryRequest, DaffCategoryRequestKind, DaffCategoryIdRequest, DaffCategoryUrlRequest, } from './category-request';
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@daffodil/category",
|
3
|
-
"version": "0.
|
3
|
+
"version": "0.44.0",
|
4
4
|
"description": "An ecommerce categories package that has multi-platform support and state management features.",
|
5
5
|
"repository": {
|
6
6
|
"type": "git",
|
@@ -18,8 +18,8 @@
|
|
18
18
|
"peerDependencies": {
|
19
19
|
"@angular/common": "^13.0.0",
|
20
20
|
"@angular/core": "^13.0.0",
|
21
|
-
"@daffodil/core": "0.
|
22
|
-
"@daffodil/product": "0.
|
21
|
+
"@daffodil/core": "0.44.0",
|
22
|
+
"@daffodil/product": "0.44.0",
|
23
23
|
"@ngrx/effects": "^13.0.0",
|
24
24
|
"@ngrx/entity": "^13.0.0",
|
25
25
|
"@ngrx/store": "^13.0.0",
|
@@ -27,7 +27,7 @@
|
|
27
27
|
},
|
28
28
|
"optionalDependencies": {
|
29
29
|
"@apollo/client": "^3.0.0",
|
30
|
-
"@daffodil/driver": "0.
|
30
|
+
"@daffodil/driver": "0.44.0",
|
31
31
|
"angular-in-memory-web-api": "^0.13.0",
|
32
32
|
"apollo-angular": "^3.0.1",
|
33
33
|
"@faker-js/faker": "^5.5.3"
|
package/public_api.d.ts
CHANGED
@@ -0,0 +1,10 @@
|
|
1
|
+
import { ActivatedRoute, Router } from '@angular/router';
|
2
|
+
import { Actions } from '@ngrx/effects';
|
3
|
+
import { DaffCategoryProductCollectionFacade } from '@daffodil/category/state';
|
4
|
+
import { DaffProductGetQueryParamsFromRequest, DaffProductRoutingCollectionEffects } from '@daffodil/product/routing';
|
5
|
+
import * as i0 from "@angular/core";
|
6
|
+
export declare class DaffCategoryRoutingCollectionEffects extends DaffProductRoutingCollectionEffects {
|
7
|
+
constructor(actions$: Actions, router: Router, collectionFacade: DaffCategoryProductCollectionFacade, getQueryParams: DaffProductGetQueryParamsFromRequest, route: ActivatedRoute);
|
8
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DaffCategoryRoutingCollectionEffects, never>;
|
9
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<DaffCategoryRoutingCollectionEffects>;
|
10
|
+
}
|
@@ -0,0 +1 @@
|
|
1
|
+
export { DAFF_CATEGORY_ROUTING_OPTIONS_BUILDERS, daffProvideCategoryRoutingRequestBuilders, DaffCategoryRoutingRequestBuilder, } from './request/builders.token';
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
2
|
+
import { DaffCategoryRoutingRequestBuilder } from './builders.token';
|
3
|
+
/**
|
4
|
+
* An internal token to combine the {@link DAFF_CATEGORY_ROUTING_OPTIONS_BUILDERS} into a single builder.
|
5
|
+
*/
|
6
|
+
export declare const DAFF_CATEGORY_ROUTING_OPTIONS_BUILDER: InjectionToken<DaffCategoryRoutingRequestBuilder<import("@daffodil/product").DaffProductCollectionRequest>>;
|
@@ -0,0 +1,26 @@
|
|
1
|
+
import { InjectionToken, ValueProvider } from '@angular/core';
|
2
|
+
import { ActivatedRouteSnapshot } from '@angular/router';
|
3
|
+
import { DaffProductCollectionRequest } from '@daffodil/product';
|
4
|
+
export declare type DaffCategoryRoutingRequestBuilder<T extends DaffProductCollectionRequest = DaffProductCollectionRequest> = (route: ActivatedRouteSnapshot) => T;
|
5
|
+
/**
|
6
|
+
* A multi-provider injection token for category request builders.
|
7
|
+
* These builders are called with the requested route during the resolve step
|
8
|
+
* and return options to pass to the category driver.
|
9
|
+
*/
|
10
|
+
export declare const DAFF_CATEGORY_ROUTING_OPTIONS_BUILDERS: InjectionToken<DaffCategoryRoutingRequestBuilder<DaffProductCollectionRequest>[]>;
|
11
|
+
/**
|
12
|
+
* Provides category request builders for the routing layer.
|
13
|
+
*
|
14
|
+
* See {@link DAFF_CATEGORY_ROUTING_OPTIONS_BUILDERS}.
|
15
|
+
*
|
16
|
+
* ```ts
|
17
|
+
* providers: [
|
18
|
+
* ...daffProvideCategoryRoutingRequestBuilders(
|
19
|
+
* route => ({
|
20
|
+
* currentPage: route.queryParams.page
|
21
|
+
* })
|
22
|
+
* )
|
23
|
+
* ]
|
24
|
+
* ```
|
25
|
+
*/
|
26
|
+
export declare function daffProvideCategoryRoutingRequestBuilders(...builders: DaffCategoryRoutingRequestBuilder[]): ValueProvider[];
|
@@ -0,0 +1,8 @@
|
|
1
|
+
import * as i0 from "@angular/core";
|
2
|
+
import * as i1 from "@daffodil/product/routing";
|
3
|
+
import * as i2 from "@ngrx/effects";
|
4
|
+
export declare class DaffCategoryRoutingModule {
|
5
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DaffCategoryRoutingModule, never>;
|
6
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<DaffCategoryRoutingModule, never, [typeof i1.DaffProductRoutingModule, typeof i2.EffectsFeatureModule], never>;
|
7
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<DaffCategoryRoutingModule>;
|
8
|
+
}
|
package/routing/public_api.d.ts
CHANGED
@@ -2,6 +2,7 @@ import { ActivatedRouteSnapshot, Resolve } from '@angular/router';
|
|
2
2
|
import { ActionsSubject, Store } from '@ngrx/store';
|
3
3
|
import { Observable } from 'rxjs';
|
4
4
|
import { DaffCategoryReducersState } from '@daffodil/category/state';
|
5
|
+
import { DaffCategoryRoutingRequestBuilder } from '../../injection-tokens/public_api';
|
5
6
|
import * as i0 from "@angular/core";
|
6
7
|
/**
|
7
8
|
* Resolves category data for category pages, and will only resolve the url after a category request succeeds or fails. This resolver expects a url
|
@@ -9,9 +10,10 @@ import * as i0 from "@angular/core";
|
|
9
10
|
*/
|
10
11
|
export declare class DaffCategoryPageIdResolver implements Resolve<Observable<boolean>> {
|
11
12
|
private platformId;
|
13
|
+
private requestBuilder;
|
12
14
|
private store;
|
13
15
|
private dispatcher;
|
14
|
-
constructor(platformId: string, store: Store<DaffCategoryReducersState>, dispatcher: ActionsSubject);
|
16
|
+
constructor(platformId: string, requestBuilder: DaffCategoryRoutingRequestBuilder, store: Store<DaffCategoryReducersState>, dispatcher: ActionsSubject);
|
15
17
|
resolve(route: ActivatedRouteSnapshot): Observable<boolean>;
|
16
18
|
static ɵfac: i0.ɵɵFactoryDeclaration<DaffCategoryPageIdResolver, never>;
|
17
19
|
static ɵprov: i0.ɵɵInjectableDeclaration<DaffCategoryPageIdResolver>;
|
@@ -3,21 +3,21 @@ import { ActionsSubject, Store } from '@ngrx/store';
|
|
3
3
|
import { Observable } from 'rxjs';
|
4
4
|
import { DaffCategoryReducersState } from '@daffodil/category/state';
|
5
5
|
import { DaffRoutingUriNormalizer } from '@daffodil/core/routing';
|
6
|
+
import { DaffCategoryRoutingRequestBuilder } from '../../injection-tokens/public_api';
|
6
7
|
import * as i0 from "@angular/core";
|
7
8
|
/**
|
8
9
|
* Resolves category data for category pages, and will only resolve the url
|
9
10
|
* after a category request succeeds or fails. This resolver will take a full
|
10
11
|
* a url of the form `some/url.html(secondary:outlet)?query=param#fragment` and attempt to resolve a product from it.
|
11
12
|
* Assumes that the URL to be resolved is the primary outlet.
|
12
|
-
*
|
13
|
-
* Will check the `p` and `page` query params for a page number value.
|
14
13
|
*/
|
15
14
|
export declare class DaffCategoryPageUrlResolver implements Resolve<Observable<boolean>> {
|
16
15
|
private platformId;
|
16
|
+
private requestBuilder;
|
17
17
|
private store;
|
18
18
|
private dispatcher;
|
19
19
|
private urlNormalizer;
|
20
|
-
constructor(platformId: string, store: Store<DaffCategoryReducersState>, dispatcher: ActionsSubject, urlNormalizer: DaffRoutingUriNormalizer);
|
20
|
+
constructor(platformId: string, requestBuilder: DaffCategoryRoutingRequestBuilder, store: Store<DaffCategoryReducersState>, dispatcher: ActionsSubject, urlNormalizer: DaffRoutingUriNormalizer);
|
21
21
|
resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean>;
|
22
22
|
static ɵfac: i0.ɵɵFactoryDeclaration<DaffCategoryPageUrlResolver, never>;
|
23
23
|
static ɵprov: i0.ɵɵInjectableDeclaration<DaffCategoryPageUrlResolver>;
|
@@ -1,15 +1,19 @@
|
|
1
1
|
import { Action } from '@ngrx/store';
|
2
|
-
import {
|
2
|
+
import { DaffCategoryRequest } from '@daffodil/category';
|
3
|
+
import { DaffProductFilterRequest, DaffProductFilterToggleRequest } from '@daffodil/product';
|
3
4
|
/**
|
4
5
|
* The possible types of category page filter actions.
|
5
6
|
*/
|
6
|
-
export declare enum
|
7
|
+
export declare enum DaffCategoryPageProductCollectionActionTypes {
|
7
8
|
CategoryPageChangeFiltersAction = "[@daffodil/category] Category Page Change Filters Action",
|
8
9
|
CategoryPageReplaceFiltersAction = "[@daffodil/category] Category Page Replace Filters Action",
|
9
10
|
CategoryPageApplyFiltersAction = "[@daffodil/category] Category Page Apply Filters Action",
|
10
11
|
CategoryPageRemoveFiltersAction = "[@daffodil/category] Category Page Remove Filters Action",
|
11
12
|
CategoryPageClearFiltersAction = "[@daffodil/category] Category Page Clear Filters Action",
|
12
|
-
CategoryPageToggleFilterAction = "[@daffodil/category] Category Page Toggle Filter Action"
|
13
|
+
CategoryPageToggleFilterAction = "[@daffodil/category] Category Page Toggle Filter Action",
|
14
|
+
CategoryPageChangeSizeAction = "[@daffodil/category] Category Page Change Size Action",
|
15
|
+
CategoryPageChangeCurrentPageAction = "[@daffodil/category] Category Page Change Current Page Action",
|
16
|
+
CategoryPageChangeSortingOptionAction = "[@daffodil/category] Category Page Change Sorting Option Action"
|
13
17
|
}
|
14
18
|
/**
|
15
19
|
* An action for changing the filters for the current category.
|
@@ -18,9 +22,9 @@ export declare enum DaffCategoryPageFilterActionTypes {
|
|
18
22
|
* @deprecated use {@link DaffCategoryPageReplaceFilters} or {@link DaffCategoryPageApplyFilters}
|
19
23
|
*/
|
20
24
|
export declare class DaffCategoryPageChangeFilters implements Action {
|
21
|
-
filters:
|
22
|
-
readonly type =
|
23
|
-
constructor(filters:
|
25
|
+
filters: DaffProductFilterRequest[];
|
26
|
+
readonly type = DaffCategoryPageProductCollectionActionTypes.CategoryPageChangeFiltersAction;
|
27
|
+
constructor(filters: DaffProductFilterRequest[]);
|
24
28
|
}
|
25
29
|
/**
|
26
30
|
* An action for replacing the filters for the current category.
|
@@ -29,9 +33,9 @@ export declare class DaffCategoryPageChangeFilters implements Action {
|
|
29
33
|
* @param filters - Filters to be set on the current category.
|
30
34
|
*/
|
31
35
|
export declare class DaffCategoryPageReplaceFilters implements Action {
|
32
|
-
filters:
|
33
|
-
readonly type =
|
34
|
-
constructor(filters:
|
36
|
+
filters: DaffProductFilterRequest[];
|
37
|
+
readonly type = DaffCategoryPageProductCollectionActionTypes.CategoryPageReplaceFiltersAction;
|
38
|
+
constructor(filters: DaffProductFilterRequest[]);
|
35
39
|
}
|
36
40
|
/**
|
37
41
|
* An action for applying the specified filters for the current category.
|
@@ -39,9 +43,9 @@ export declare class DaffCategoryPageReplaceFilters implements Action {
|
|
39
43
|
* @param filters - Filters to be applied to the current category.
|
40
44
|
*/
|
41
45
|
export declare class DaffCategoryPageApplyFilters implements Action {
|
42
|
-
filters:
|
43
|
-
readonly type =
|
44
|
-
constructor(filters:
|
46
|
+
filters: DaffProductFilterRequest[];
|
47
|
+
readonly type = DaffCategoryPageProductCollectionActionTypes.CategoryPageApplyFiltersAction;
|
48
|
+
constructor(filters: DaffProductFilterRequest[]);
|
45
49
|
}
|
46
50
|
/**
|
47
51
|
* An action for removing the specified filters for the current category.
|
@@ -49,15 +53,15 @@ export declare class DaffCategoryPageApplyFilters implements Action {
|
|
49
53
|
* @param filters - Filters to be removed from the current category.
|
50
54
|
*/
|
51
55
|
export declare class DaffCategoryPageRemoveFilters implements Action {
|
52
|
-
filters:
|
53
|
-
readonly type =
|
54
|
-
constructor(filters:
|
56
|
+
filters: DaffProductFilterRequest[];
|
57
|
+
readonly type = DaffCategoryPageProductCollectionActionTypes.CategoryPageRemoveFiltersAction;
|
58
|
+
constructor(filters: DaffProductFilterRequest[]);
|
55
59
|
}
|
56
60
|
/**
|
57
61
|
* An action for removing all the filters for the current category.
|
58
62
|
*/
|
59
63
|
export declare class DaffCategoryPageClearFilters implements Action {
|
60
|
-
readonly type =
|
64
|
+
readonly type = DaffCategoryPageProductCollectionActionTypes.CategoryPageClearFiltersAction;
|
61
65
|
}
|
62
66
|
/**
|
63
67
|
* An action for toggling a filters for the current category.
|
@@ -65,8 +69,44 @@ export declare class DaffCategoryPageClearFilters implements Action {
|
|
65
69
|
* @param filter - Filter to be toggled on the current category.
|
66
70
|
*/
|
67
71
|
export declare class DaffCategoryPageToggleFilter implements Action {
|
68
|
-
filter:
|
69
|
-
readonly type =
|
70
|
-
constructor(filter:
|
72
|
+
filter: DaffProductFilterToggleRequest;
|
73
|
+
readonly type = DaffCategoryPageProductCollectionActionTypes.CategoryPageToggleFilterAction;
|
74
|
+
constructor(filter: DaffProductFilterToggleRequest);
|
71
75
|
}
|
72
|
-
|
76
|
+
/**
|
77
|
+
* An action for changing the number of products shown on each page for the selected category.
|
78
|
+
*
|
79
|
+
* @param pageSize - The number of products per page.
|
80
|
+
*/
|
81
|
+
export declare class DaffCategoryPageChangePageSize implements Action {
|
82
|
+
pageSize: number;
|
83
|
+
readonly type = DaffCategoryPageProductCollectionActionTypes.CategoryPageChangeSizeAction;
|
84
|
+
constructor(pageSize: number);
|
85
|
+
}
|
86
|
+
/**
|
87
|
+
* An action for changing the current page of products for the selected category.
|
88
|
+
*
|
89
|
+
* @param currentPage - The current page of products for the selected category.
|
90
|
+
*/
|
91
|
+
export declare class DaffCategoryPageChangeCurrentPage implements Action {
|
92
|
+
currentPage: number;
|
93
|
+
readonly type = DaffCategoryPageProductCollectionActionTypes.CategoryPageChangeCurrentPageAction;
|
94
|
+
constructor(currentPage: number);
|
95
|
+
}
|
96
|
+
/**
|
97
|
+
* An action for changing the sorting option for the selected category.
|
98
|
+
*
|
99
|
+
* @param sort - The sort option to be applied.
|
100
|
+
*/
|
101
|
+
export declare class DaffCategoryPageChangeSortingOption implements Action {
|
102
|
+
sort: {
|
103
|
+
option: DaffCategoryRequest['appliedSortOption'];
|
104
|
+
direction: DaffCategoryRequest['appliedSortDirection'];
|
105
|
+
};
|
106
|
+
readonly type = DaffCategoryPageProductCollectionActionTypes.CategoryPageChangeSortingOptionAction;
|
107
|
+
constructor(sort: {
|
108
|
+
option: DaffCategoryRequest['appliedSortOption'];
|
109
|
+
direction: DaffCategoryRequest['appliedSortDirection'];
|
110
|
+
});
|
111
|
+
}
|
112
|
+
export declare type DaffCategoryPageProductCollectionActions = DaffCategoryPageChangeFilters | DaffCategoryPageReplaceFilters | DaffCategoryPageApplyFilters | DaffCategoryPageRemoveFilters | DaffCategoryPageClearFilters | DaffCategoryPageToggleFilter | DaffCategoryPageChangePageSize | DaffCategoryPageChangeCurrentPage | DaffCategoryPageChangeSortingOption;
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import { Action } from '@ngrx/store';
|
2
|
-
import {
|
2
|
+
import { DaffGenericCategory, DaffCategory, DaffGetCategoryResponse, DaffCategoryIdRequest, DaffCategoryUrlRequest } from '@daffodil/category';
|
3
3
|
import { DaffStateError } from '@daffodil/core/state';
|
4
4
|
import { DaffProduct } from '@daffodil/product';
|
5
5
|
/**
|
@@ -9,10 +9,7 @@ export declare enum DaffCategoryPageActionTypes {
|
|
9
9
|
CategoryPageLoadAction = "[@daffodil/category] Category Page Load Action",
|
10
10
|
CategoryPageLoadByUrlAction = "[@daffodil/category] Category Page Load By URL Action",
|
11
11
|
CategoryPageLoadSuccessAction = "[@daffodil/category] Category Page Load Success Action",
|
12
|
-
CategoryPageLoadFailureAction = "[@daffodil/category] Category Page Load Failure Action"
|
13
|
-
CategoryPageChangeSizeAction = "[@daffodil/category] Category Page Change Size Action",
|
14
|
-
CategoryPageChangeCurrentPageAction = "[@daffodil/category] Category Page Change Current Page Action",
|
15
|
-
CategoryPageChangeSortingOptionAction = "[@daffodil/category] Category Page Change Sorting Option Action"
|
12
|
+
CategoryPageLoadFailureAction = "[@daffodil/category] Category Page Load Failure Action"
|
16
13
|
}
|
17
14
|
/**
|
18
15
|
* An action triggered to initialize a category page load request.
|
@@ -58,40 +55,4 @@ export declare class DaffCategoryPageLoadFailure implements Action {
|
|
58
55
|
readonly type = DaffCategoryPageActionTypes.CategoryPageLoadFailureAction;
|
59
56
|
constructor(errorMessage: DaffStateError);
|
60
57
|
}
|
61
|
-
|
62
|
-
* An action for changing the number of products shown on each page for the selected category.
|
63
|
-
*
|
64
|
-
* @param pageSize - The number of products per page.
|
65
|
-
*/
|
66
|
-
export declare class DaffCategoryPageChangePageSize implements Action {
|
67
|
-
pageSize: number;
|
68
|
-
readonly type = DaffCategoryPageActionTypes.CategoryPageChangeSizeAction;
|
69
|
-
constructor(pageSize: number);
|
70
|
-
}
|
71
|
-
/**
|
72
|
-
* An action for changing the current page of products for the selected category.
|
73
|
-
*
|
74
|
-
* @param currentPage - The current page of products for the selected category.
|
75
|
-
*/
|
76
|
-
export declare class DaffCategoryPageChangeCurrentPage implements Action {
|
77
|
-
currentPage: number;
|
78
|
-
readonly type = DaffCategoryPageActionTypes.CategoryPageChangeCurrentPageAction;
|
79
|
-
constructor(currentPage: number);
|
80
|
-
}
|
81
|
-
/**
|
82
|
-
* An action for changing the sorting option for the selected category.
|
83
|
-
*
|
84
|
-
* @param sort - The sort option to be applied.
|
85
|
-
*/
|
86
|
-
export declare class DaffCategoryPageChangeSortingOption implements Action {
|
87
|
-
sort: {
|
88
|
-
option: DaffCategoryRequest['applied_sort_option'];
|
89
|
-
direction: DaffCategoryRequest['applied_sort_direction'];
|
90
|
-
};
|
91
|
-
readonly type = DaffCategoryPageActionTypes.CategoryPageChangeSortingOptionAction;
|
92
|
-
constructor(sort: {
|
93
|
-
option: DaffCategoryRequest['applied_sort_option'];
|
94
|
-
direction: DaffCategoryRequest['applied_sort_direction'];
|
95
|
-
});
|
96
|
-
}
|
97
|
-
export declare type DaffCategoryPageActions<U extends DaffGenericCategory<U> = DaffCategory, W extends DaffProduct = DaffProduct> = DaffCategoryPageLoad | DaffCategoryPageLoadByUrl | DaffCategoryPageLoadSuccess<U, W> | DaffCategoryPageLoadFailure | DaffCategoryPageChangePageSize | DaffCategoryPageChangeCurrentPage | DaffCategoryPageChangeSortingOption;
|
58
|
+
export declare type DaffCategoryPageActions<U extends DaffGenericCategory<U> = DaffCategory, W extends DaffProduct = DaffProduct> = DaffCategoryPageLoad | DaffCategoryPageLoadByUrl | DaffCategoryPageLoadSuccess<U, W> | DaffCategoryPageLoadFailure;
|
@@ -7,14 +7,14 @@ import { ErrorTransformer } from '@daffodil/core/state';
|
|
7
7
|
import { DaffProduct } from '@daffodil/product';
|
8
8
|
import { DaffProductGridLoadSuccess } from '@daffodil/product/state';
|
9
9
|
import { DaffCategoryPageLoadSuccess, DaffCategoryPageLoadFailure } from '../actions/category-page.actions';
|
10
|
-
import {
|
10
|
+
import { DaffCategoryProductCollectionFacade } from '../facades/public_api';
|
11
11
|
import * as i0 from "@angular/core";
|
12
12
|
export declare class DaffCategoryPageFilterEffects<V extends DaffGenericCategory<V>, W extends DaffProduct> {
|
13
13
|
private actions$;
|
14
14
|
private driver;
|
15
15
|
private errorMatcher;
|
16
16
|
private facade;
|
17
|
-
constructor(actions$: Actions, driver: DaffCategoryServiceInterface<V, W>, errorMatcher: ErrorTransformer, facade:
|
17
|
+
constructor(actions$: Actions, driver: DaffCategoryServiceInterface<V, W>, errorMatcher: ErrorTransformer, facade: DaffCategoryProductCollectionFacade);
|
18
18
|
/**
|
19
19
|
* Updates the filters applied to the category page. It will take the currently
|
20
20
|
* applied filters from state, form them into a request, and attempt to apply
|
@@ -0,0 +1,9 @@
|
|
1
|
+
import { Store } from '@ngrx/store';
|
2
|
+
import { DaffProductCollectionFacade, DaffProductCollectionFacadeInterface } from '@daffodil/product/state';
|
3
|
+
import { DaffCategoryStateRootSlice } from '../../reducers/public_api';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
export declare class DaffCategoryProductCollectionFacade extends DaffProductCollectionFacade<DaffCategoryStateRootSlice> implements DaffProductCollectionFacadeInterface {
|
6
|
+
constructor(store: Store<DaffCategoryStateRootSlice>);
|
7
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DaffCategoryProductCollectionFacade, never>;
|
8
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<DaffCategoryProductCollectionFacade>;
|
9
|
+
}
|