Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 | 179x 179x 179x 179x 179x 146x 179x 179x 18x 2x 28x 16x 12x 12x 12x 12x 12x 4x 179x 61x 2x 59x 96x 96x 59x 57x 59x 59x 179x 137x 137x 713x | import { UrlMatchResult, UrlSegment } from '@angular/router'; import { MonoTypeOperatorFunction } from 'rxjs'; import { filter } from 'rxjs/operators'; import { CategoryView } from 'ish-core/models/category-view/category-view.model'; import { Category } from 'ish-core/models/category/category.model'; import { CoreState } from 'ish-core/store/core/core-store'; import { selectRouteParam, selectRouteParamAorB } from 'ish-core/store/core/router'; import { sanitizeSlugData } from 'ish-core/utils/routing'; /** * generate a localized category slug * * @param category category element for slug * @returns localized, formatted category slug */ export function generateLocalizedCategorySlug(category: Category) { return sanitizeSlugData(category?.name); } // matcher to check if a given url is a category route const categoryRouteFormat = /^\/(?!category|categoryref\/.*$)(.*?)-?ctg(.*)$/; /** * check if given url is a category route * * @param segments current url segments * @returns match result if given url is a category route or not */ export function matchCategoryRoute(segments: UrlSegment[]): UrlMatchResult { // compatibility to old routes if (segments && segments.length === 2 && (segments[0].path === 'category' || segments[0].path === 'categoryref')) { return { consumed: [] }; } // generate complete url path const url = `/${segments.map(s => s.path).join('/')}`; // check that complete url path is a category route if (categoryRouteFormat.test(url)) { // select categoryUniqueId to render a category component const match = categoryRouteFormat.exec(url); const posParams: { [id: string]: UrlSegment } = {}; if (match[2]) { posParams.categoryUniqueId = new UrlSegment(match[2], {}); } return { consumed: [], posParams, }; } return; } /** * generate a localized category url from a category view * * @param category category view * @returns localized category url */ export function generateCategoryUrl(category: CategoryView): string { if (!category) { return '/'; } // generate for each path element from the given category view a category slug and join them together to a complete route let route = `/${category.pathElements ?.filter(x => !!x) .map(el => generateLocalizedCategorySlug(el)) .join('/')}`; // add to category route the category identifier if (route !== '/') { route += '-'; } route += `ctg${category.uniqueId}`; return route; } export function ofCategoryUrl(): MonoTypeOperatorFunction<{}> { return source$ => source$.pipe( filter( (state: CoreState) => !selectRouteParam('sku')(state) && !!selectRouteParamAorB('categoryUniqueId', 'categoryRefId')(state) ) ); } |