@dsivd/prestations-ng 15.2.4 → 15.2.5-beta1
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/CHANGELOG.md +7 -0
- package/dsivd-prestations-ng-v15.2.5-beta1.tgz +0 -0
- package/esm2020/foehn-address/foehn-input-address.component.mjs +1 -1
- package/esm2020/foehn-autocomplete/foehn-autocomplete.component.mjs +11 -8
- package/esm2020/foehn-multiselect-autocomplete/foehn-multiselect-autocomplete.component.mjs +1 -1
- package/esm2020/foehn-navigation/foehn-navigation.service.mjs +4 -1
- package/fesm2015/dsivd-prestations-ng.mjs +16 -9
- package/fesm2015/dsivd-prestations-ng.mjs.map +1 -1
- package/fesm2020/dsivd-prestations-ng.mjs +15 -9
- package/fesm2020/dsivd-prestations-ng.mjs.map +1 -1
- package/foehn-autocomplete/foehn-autocomplete.component.d.ts +2 -2
- package/package.json +1 -1
- package/dsivd-prestations-ng-v15.2.4.tgz +0 -0
|
@@ -199,6 +199,9 @@ export class FoehnNavigationService {
|
|
|
199
199
|
return (this.getNextAvailableRoute(NavigationDirection.BACKWARD) === null);
|
|
200
200
|
}
|
|
201
201
|
isLastFormPage() {
|
|
202
|
+
if (!this.orderedRoutes?.length) {
|
|
203
|
+
return false;
|
|
204
|
+
}
|
|
202
205
|
if (!this.getCurrentRoute(this.getAvailableRoutes())) {
|
|
203
206
|
return true;
|
|
204
207
|
}
|
|
@@ -297,4 +300,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
297
300
|
providedIn: 'root'
|
|
298
301
|
}]
|
|
299
302
|
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.GesdemHandlerService }, { type: i3.GesdemActionRecoveryService }, { type: i1.ActivatedRoute }, { type: i4.Location }]; } });
|
|
300
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-navigation.service.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-navigation/foehn-navigation.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ActivatedRoute,\n    ActivatedRouteSnapshot,\n    CanActivate,\n    Params,\n    Route,\n    Router\n} from '@angular/router';\nimport { Injectable } from '@angular/core';\nimport { GesdemHandlerService } from '../gesdem/gesdem-handler.service';\nimport { ServiceLocator } from '../service-locator';\nimport { Location } from '@angular/common';\nimport { GesdemActionRecoveryService } from '../gesdem-action-recovery/gesdem-action-recovery.service';\nimport { BehaviorSubject, Observable } from 'rxjs';\n\nexport enum NavigationDirection {\n    FORWARD = +1,\n    BACKWARD = -1\n}\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class FoehnNavigationService {\n    currentRouteOrder: number;\n    orderedRoutes: Route[];\n    private _activatedRoute: ActivatedRoute;\n    private isInit = false;\n    private initializedAndRouteActivated: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(\n        false\n    );\n    private linearRouting = true;\n\n    constructor(\n        private router: Router,\n        private gesdemService: GesdemHandlerService,\n        private gesdemActionRecoveryService: GesdemActionRecoveryService,\n        private route: ActivatedRoute,\n        private location: Location\n    ) {}\n\n    get initialized(): boolean {\n        return this.isInit;\n    }\n\n    set activatedRoute(value: ActivatedRoute) {\n        this.throwIfNotInit();\n        this._activatedRoute = value;\n        this.initializedAndRouteActivated.next(true);\n    }\n\n    static getRootRouteRecursive(route: ActivatedRouteSnapshot): Route {\n        if (route) {\n            if (\n                route.routeConfig &&\n                route.routeConfig.data &&\n                route.routeConfig.data.root\n            ) {\n                return route.routeConfig;\n            }\n            return this.getRootRouteRecursive(route.parent);\n        }\n        return null;\n    }\n\n    initRoute(route: Route): void {\n        if (route) {\n            this.orderedRoutes = this.indexRoutesByOrder(route);\n\n            // By default the prefix should be the path of the route. (e.g. in /validation/123123-12321/page1,\n            // the prefix is \"validation\"). However, if the application is code-splitted with the routing defined\n            // in a module, this won't work. In this case, you can specify the path in $.data.basePath so the GesDem\n            // service knows where to send the request to the backend.\n            const prefix = route.data.basePath || route.path;\n            this.gesdemService.prefix = prefix;\n            this.gesdemActionRecoveryService.prefix = prefix;\n            this.linearRouting = route.data.linearRouting !== false;\n        }\n        this.throwIfNotInit();\n    }\n\n    throwIfNotInit(): void {\n        if (!this.isInit) {\n            throw new TypeError(\n                \"No route is identified as 'root'. Have you called initRoute() ?\"\n            );\n        }\n    }\n\n    updateRouteInformations(): void {\n        this.throwIfNotInit();\n        const currentRoute = this._activatedRoute.routeConfig;\n\n        let currentRouteOrder = 1;\n\n        if (\n            !!currentRoute &&\n            !!currentRoute.data &&\n            !!currentRoute.data.order\n        ) {\n            currentRouteOrder = currentRoute.data.order;\n        }\n        this.currentRouteOrder = currentRouteOrder;\n    }\n\n    getFirstRoute(): Route {\n        return this.orderedRoutes[1];\n    }\n\n    current(): Promise<boolean> {\n        this.throwIfNotInit();\n        if (!this.gesdemService.lastResponse) {\n            return Promise.reject('Erreur navigationService#current');\n        }\n        const currentRoute = this.orderedRoutes[this.currentRouteOrder];\n\n        const prefix = this.gesdemService.prefix;\n        const commands: string[] = [];\n        if (prefix) {\n            commands.push(prefix);\n        }\n\n        if (this.gesdemService.lastResponse.meta.reference) {\n            commands.push(\n                this.gesdemService.lastResponse.meta.reference,\n                currentRoute.path\n            );\n\n            const tree = this.router.createUrlTree(commands);\n            const url =\n                this.router.serializeUrl(tree) +\n                this.getQueryParamsToForwardAsString();\n            this.location.replaceState(url);\n        }\n\n        return Promise.resolve(true);\n    }\n\n    hasBeenInitialized(): Observable<boolean> {\n        return this.initializedAndRouteActivated.asObservable();\n    }\n\n    getQueryParamsToForwardAsString(): string {\n        const params = this.getQueryParamsToForward() || [];\n        let stringParams = '';\n        for (const key of Object.keys(params)) {\n            const value = params[key];\n            stringParams += stringParams ? '&' : '?';\n            stringParams += `${key}=${value}`;\n        }\n        return stringParams;\n    }\n\n    getQueryParamsToForward(): Params {\n        const reCaptchaByPassUUID = this.route.snapshot.queryParams\n            .reCaptchaByPassUUID;\n        const scrollTo = this.route.snapshot.queryParams.scrollTo;\n        if (!!reCaptchaByPassUUID || !!scrollTo) {\n            const params: Params = {};\n            if (!!reCaptchaByPassUUID) {\n                params.reCaptchaByPassUUID = reCaptchaByPassUUID;\n            }\n            if (!!scrollTo) {\n                params.scrollTo = scrollTo;\n            }\n            return params;\n        }\n        return null;\n    }\n\n    next(): Promise<boolean> {\n        this.throwIfNotInit();\n        return this.redirectToAvailableRoute(NavigationDirection.FORWARD);\n    }\n\n    previous(): Promise<boolean> {\n        this.throwIfNotInit();\n        return this.redirectToAvailableRoute(NavigationDirection.BACKWARD);\n    }\n\n    last(): Promise<boolean> {\n        this.throwIfNotInit();\n        const route = this.getAvailableRoutes();\n        const nextRoutePath = route[route.length - 1].path;\n        return this.redirect(nextRoutePath);\n    }\n\n    redirect(newPath: string): Promise<boolean> {\n        const routes = [];\n        if (this.gesdemService.prefix) {\n            routes.push(this.gesdemService.prefix);\n        }\n        routes.push(this.gesdemService.lastResponse.meta.reference, newPath);\n\n        return this.router\n            .navigate(routes, {\n                queryParams: this.getQueryParamsToForward()\n            })\n            .then(success => {\n                if (success) {\n                    this.setFocusOnPageTitle();\n                }\n                return success;\n            });\n    }\n\n    getAvailableRoutes(): Route[] {\n        return this.orderedRoutes.filter(route => this.isRouteAvailable(route));\n    }\n\n    getCurrentRouteIndex(): number {\n        // This evaluates all the guards\n        const availableRoutes = this.getAvailableRoutes();\n\n        const currentRoute = availableRoutes.find(\n            route => route.data.order === this.currentRouteOrder\n        );\n\n        if (!currentRoute) {\n            return null;\n        }\n\n        return availableRoutes.indexOf(currentRoute);\n    }\n\n    getTotalRoutesSize(): number {\n        return this.getAvailableRoutes().length;\n    }\n\n    getLastRouteOrder(): number {\n        const routes = this.getAvailableRoutes();\n        return routes[routes.length - 1].data.order;\n    }\n\n    getNextAvailableRoute(direction: NavigationDirection): Route {\n        // This evaluates all the guards\n        const availableRoutes = this.getAvailableRoutes();\n\n        // Assumes that the next or previous route is the next or previous on the array of available routes.\n        const currentRoute = this.getCurrentRoute(availableRoutes);\n        if (!currentRoute) {\n            throw new Error(\n                'Invalid routing, at least one route must be available'\n            );\n        }\n\n        const currentRouteIndex = availableRoutes.indexOf(currentRoute);\n        const targetRoute = availableRoutes[currentRouteIndex + direction];\n        if (!targetRoute) {\n            return null;\n        }\n\n        // The display index isn't always the route order as we support guards on available routes.\n        // The display index is 1-based.\n        targetRoute.data.displayIndex =\n            availableRoutes.indexOf(targetRoute) + 1;\n        return targetRoute;\n    }\n\n    isFirstFormPage(): boolean {\n        if (!this.getCurrentRoute(this.getAvailableRoutes())) {\n            return true;\n        }\n        return (\n            this.getNextAvailableRoute(NavigationDirection.BACKWARD) === null\n        );\n    }\n\n    isLastFormPage(): boolean {\n        if (!this.getCurrentRoute(this.getAvailableRoutes())) {\n            return true;\n        }\n        const nextRoute = this.getNextAvailableRoute(\n            NavigationDirection.FORWARD\n        );\n        if (!nextRoute) {\n            return true;\n        }\n\n        return nextRoute.data.order === this.getLastRouteOrder();\n    }\n\n    getNextRouteIndex(): number {\n        const nextRoute = this.getNextAvailableRoute(\n            NavigationDirection.FORWARD\n        );\n        if (!nextRoute) {\n            return null;\n        }\n\n        return nextRoute.data.displayIndex;\n    }\n\n    getPreviousRouteIndex(): number {\n        const previousRoute = this.getNextAvailableRoute(\n            NavigationDirection.BACKWARD\n        );\n        if (!previousRoute) {\n            return null;\n        }\n\n        return previousRoute.data.displayIndex;\n    }\n\n    isLinearRouting(): boolean {\n        return this.linearRouting;\n    }\n\n    private getCurrentRoute(availableRoutes: Route[]): Route {\n        return availableRoutes.find(\n            route => route.data.order === this.currentRouteOrder\n        );\n    }\n\n    private redirectToAvailableRoute(\n        direction: NavigationDirection\n    ): Promise<boolean> {\n        const route = this.getNextAvailableRoute(direction);\n        return this.redirect(route.path);\n    }\n\n    private isRouteAvailable(route: Route): boolean {\n        const { canActivate } = route;\n        if (!canActivate || !canActivate.length) {\n            return true;\n        }\n\n        // All the guards must be evaluated to true\n        return !canActivate.some(guardType => !this.evaluateGuard(guardType));\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    private evaluateGuard(guardType: any): boolean {\n        const guard: CanActivate = ServiceLocator.injector.get<CanActivate>(\n            guardType\n        );\n        const guardResult = guard.canActivate(this.route.snapshot, null);\n\n        if (typeof guardResult !== 'boolean') {\n            throw new Error(\n                'Not implemented: Dynamic routing guards only support boolean results'\n            );\n        }\n\n        return guardResult;\n    }\n\n    /**\n     * reindexe les routes par \"order\"\n     *\n     * @param applicationRoute as route\n     * @returns Route[]\n     */\n    private indexRoutesByOrder(applicationRoute: Route): Route[] {\n        this.isInit = false;\n\n        const routesToCrawl = applicationRoute.children;\n        if (!routesToCrawl.length) {\n            return [];\n        }\n\n        const result = this.flattenRoutes(routesToCrawl);\n\n        if (result.length > 0) {\n            this.isInit = true;\n        }\n\n        return result;\n    }\n\n    private flattenRoutes(\n        routesToCrawl: Route[],\n        result: Route[] = []\n    ): Route[] {\n        routesToCrawl.forEach(value => {\n            if (value.children && value.children.length) {\n                this.flattenRoutes(value.children, result);\n            }\n\n            if (!!value.data && !!value.data.order) {\n                result[value.data.order] = value;\n            }\n\n            return result;\n        });\n\n        return result;\n    }\n\n    private setFocusOnPageTitle(): void {\n        // Ensures that the focus is properly set after the page is updated.\n        setTimeout(() => {\n            const title = document.getElementById('page-title');\n            if (title) {\n                title.focus();\n            }\n        }, 0);\n    }\n}\n"]}
|
|
303
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-navigation.service.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-navigation/foehn-navigation.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ActivatedRoute,\n    ActivatedRouteSnapshot,\n    CanActivate,\n    Params,\n    Route,\n    Router\n} from '@angular/router';\nimport { Injectable } from '@angular/core';\nimport { GesdemHandlerService } from '../gesdem/gesdem-handler.service';\nimport { ServiceLocator } from '../service-locator';\nimport { Location } from '@angular/common';\nimport { GesdemActionRecoveryService } from '../gesdem-action-recovery/gesdem-action-recovery.service';\nimport { BehaviorSubject, Observable } from 'rxjs';\n\nexport enum NavigationDirection {\n    FORWARD = +1,\n    BACKWARD = -1\n}\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class FoehnNavigationService {\n    currentRouteOrder: number;\n    orderedRoutes: Route[];\n    private _activatedRoute: ActivatedRoute;\n    private isInit = false;\n    private initializedAndRouteActivated: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(\n        false\n    );\n    private linearRouting = true;\n\n    constructor(\n        private router: Router,\n        private gesdemService: GesdemHandlerService,\n        private gesdemActionRecoveryService: GesdemActionRecoveryService,\n        private route: ActivatedRoute,\n        private location: Location\n    ) {}\n\n    get initialized(): boolean {\n        return this.isInit;\n    }\n\n    set activatedRoute(value: ActivatedRoute) {\n        this.throwIfNotInit();\n        this._activatedRoute = value;\n        this.initializedAndRouteActivated.next(true);\n    }\n\n    static getRootRouteRecursive(route: ActivatedRouteSnapshot): Route {\n        if (route) {\n            if (\n                route.routeConfig &&\n                route.routeConfig.data &&\n                route.routeConfig.data.root\n            ) {\n                return route.routeConfig;\n            }\n            return this.getRootRouteRecursive(route.parent);\n        }\n        return null;\n    }\n\n    initRoute(route: Route): void {\n        if (route) {\n            this.orderedRoutes = this.indexRoutesByOrder(route);\n\n            // By default the prefix should be the path of the route. (e.g. in /validation/123123-12321/page1,\n            // the prefix is \"validation\"). However, if the application is code-splitted with the routing defined\n            // in a module, this won't work. In this case, you can specify the path in $.data.basePath so the GesDem\n            // service knows where to send the request to the backend.\n            const prefix = route.data.basePath || route.path;\n            this.gesdemService.prefix = prefix;\n            this.gesdemActionRecoveryService.prefix = prefix;\n            this.linearRouting = route.data.linearRouting !== false;\n        }\n        this.throwIfNotInit();\n    }\n\n    throwIfNotInit(): void {\n        if (!this.isInit) {\n            throw new TypeError(\n                \"No route is identified as 'root'. Have you called initRoute() ?\"\n            );\n        }\n    }\n\n    updateRouteInformations(): void {\n        this.throwIfNotInit();\n        const currentRoute = this._activatedRoute.routeConfig;\n\n        let currentRouteOrder = 1;\n\n        if (\n            !!currentRoute &&\n            !!currentRoute.data &&\n            !!currentRoute.data.order\n        ) {\n            currentRouteOrder = currentRoute.data.order;\n        }\n        this.currentRouteOrder = currentRouteOrder;\n    }\n\n    getFirstRoute(): Route {\n        return this.orderedRoutes[1];\n    }\n\n    current(): Promise<boolean> {\n        this.throwIfNotInit();\n        if (!this.gesdemService.lastResponse) {\n            return Promise.reject('Erreur navigationService#current');\n        }\n        const currentRoute = this.orderedRoutes[this.currentRouteOrder];\n\n        const prefix = this.gesdemService.prefix;\n        const commands: string[] = [];\n        if (prefix) {\n            commands.push(prefix);\n        }\n\n        if (this.gesdemService.lastResponse.meta.reference) {\n            commands.push(\n                this.gesdemService.lastResponse.meta.reference,\n                currentRoute.path\n            );\n\n            const tree = this.router.createUrlTree(commands);\n            const url =\n                this.router.serializeUrl(tree) +\n                this.getQueryParamsToForwardAsString();\n            this.location.replaceState(url);\n        }\n\n        return Promise.resolve(true);\n    }\n\n    hasBeenInitialized(): Observable<boolean> {\n        return this.initializedAndRouteActivated.asObservable();\n    }\n\n    getQueryParamsToForwardAsString(): string {\n        const params = this.getQueryParamsToForward() || [];\n        let stringParams = '';\n        for (const key of Object.keys(params)) {\n            const value = params[key];\n            stringParams += stringParams ? '&' : '?';\n            stringParams += `${key}=${value}`;\n        }\n        return stringParams;\n    }\n\n    getQueryParamsToForward(): Params {\n        const reCaptchaByPassUUID = this.route.snapshot.queryParams\n            .reCaptchaByPassUUID;\n        const scrollTo = this.route.snapshot.queryParams.scrollTo;\n        if (!!reCaptchaByPassUUID || !!scrollTo) {\n            const params: Params = {};\n            if (!!reCaptchaByPassUUID) {\n                params.reCaptchaByPassUUID = reCaptchaByPassUUID;\n            }\n            if (!!scrollTo) {\n                params.scrollTo = scrollTo;\n            }\n            return params;\n        }\n        return null;\n    }\n\n    next(): Promise<boolean> {\n        this.throwIfNotInit();\n        return this.redirectToAvailableRoute(NavigationDirection.FORWARD);\n    }\n\n    previous(): Promise<boolean> {\n        this.throwIfNotInit();\n        return this.redirectToAvailableRoute(NavigationDirection.BACKWARD);\n    }\n\n    last(): Promise<boolean> {\n        this.throwIfNotInit();\n        const route = this.getAvailableRoutes();\n        const nextRoutePath = route[route.length - 1].path;\n        return this.redirect(nextRoutePath);\n    }\n\n    redirect(newPath: string): Promise<boolean> {\n        const routes = [];\n        if (this.gesdemService.prefix) {\n            routes.push(this.gesdemService.prefix);\n        }\n        routes.push(this.gesdemService.lastResponse.meta.reference, newPath);\n\n        return this.router\n            .navigate(routes, {\n                queryParams: this.getQueryParamsToForward()\n            })\n            .then(success => {\n                if (success) {\n                    this.setFocusOnPageTitle();\n                }\n                return success;\n            });\n    }\n\n    getAvailableRoutes(): Route[] {\n        return this.orderedRoutes.filter(route => this.isRouteAvailable(route));\n    }\n\n    getCurrentRouteIndex(): number {\n        // This evaluates all the guards\n        const availableRoutes = this.getAvailableRoutes();\n\n        const currentRoute = availableRoutes.find(\n            route => route.data.order === this.currentRouteOrder\n        );\n\n        if (!currentRoute) {\n            return null;\n        }\n\n        return availableRoutes.indexOf(currentRoute);\n    }\n\n    getTotalRoutesSize(): number {\n        return this.getAvailableRoutes().length;\n    }\n\n    getLastRouteOrder(): number {\n        const routes = this.getAvailableRoutes();\n        return routes[routes.length - 1].data.order;\n    }\n\n    getNextAvailableRoute(direction: NavigationDirection): Route {\n        // This evaluates all the guards\n        const availableRoutes = this.getAvailableRoutes();\n\n        // Assumes that the next or previous route is the next or previous on the array of available routes.\n        const currentRoute = this.getCurrentRoute(availableRoutes);\n        if (!currentRoute) {\n            throw new Error(\n                'Invalid routing, at least one route must be available'\n            );\n        }\n\n        const currentRouteIndex = availableRoutes.indexOf(currentRoute);\n        const targetRoute = availableRoutes[currentRouteIndex + direction];\n        if (!targetRoute) {\n            return null;\n        }\n\n        // The display index isn't always the route order as we support guards on available routes.\n        // The display index is 1-based.\n        targetRoute.data.displayIndex =\n            availableRoutes.indexOf(targetRoute) + 1;\n        return targetRoute;\n    }\n\n    isFirstFormPage(): boolean {\n        if (!this.getCurrentRoute(this.getAvailableRoutes())) {\n            return true;\n        }\n        return (\n            this.getNextAvailableRoute(NavigationDirection.BACKWARD) === null\n        );\n    }\n\n    isLastFormPage(): boolean {\n        if (!this.orderedRoutes?.length) {\n            return false;\n        }\n\n        if (!this.getCurrentRoute(this.getAvailableRoutes())) {\n            return true;\n        }\n        const nextRoute = this.getNextAvailableRoute(\n            NavigationDirection.FORWARD\n        );\n        if (!nextRoute) {\n            return true;\n        }\n\n        return nextRoute.data.order === this.getLastRouteOrder();\n    }\n\n    getNextRouteIndex(): number {\n        const nextRoute = this.getNextAvailableRoute(\n            NavigationDirection.FORWARD\n        );\n        if (!nextRoute) {\n            return null;\n        }\n\n        return nextRoute.data.displayIndex;\n    }\n\n    getPreviousRouteIndex(): number {\n        const previousRoute = this.getNextAvailableRoute(\n            NavigationDirection.BACKWARD\n        );\n        if (!previousRoute) {\n            return null;\n        }\n\n        return previousRoute.data.displayIndex;\n    }\n\n    isLinearRouting(): boolean {\n        return this.linearRouting;\n    }\n\n    private getCurrentRoute(availableRoutes: Route[]): Route {\n        return availableRoutes.find(\n            route => route.data.order === this.currentRouteOrder\n        );\n    }\n\n    private redirectToAvailableRoute(\n        direction: NavigationDirection\n    ): Promise<boolean> {\n        const route = this.getNextAvailableRoute(direction);\n        return this.redirect(route.path);\n    }\n\n    private isRouteAvailable(route: Route): boolean {\n        const { canActivate } = route;\n        if (!canActivate || !canActivate.length) {\n            return true;\n        }\n\n        // All the guards must be evaluated to true\n        return !canActivate.some(guardType => !this.evaluateGuard(guardType));\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    private evaluateGuard(guardType: any): boolean {\n        const guard: CanActivate = ServiceLocator.injector.get<CanActivate>(\n            guardType\n        );\n        const guardResult = guard.canActivate(this.route.snapshot, null);\n\n        if (typeof guardResult !== 'boolean') {\n            throw new Error(\n                'Not implemented: Dynamic routing guards only support boolean results'\n            );\n        }\n\n        return guardResult;\n    }\n\n    /**\n     * reindexe les routes par \"order\"\n     *\n     * @param applicationRoute as route\n     * @returns Route[]\n     */\n    private indexRoutesByOrder(applicationRoute: Route): Route[] {\n        this.isInit = false;\n\n        const routesToCrawl = applicationRoute.children;\n        if (!routesToCrawl.length) {\n            return [];\n        }\n\n        const result = this.flattenRoutes(routesToCrawl);\n\n        if (result.length > 0) {\n            this.isInit = true;\n        }\n\n        return result;\n    }\n\n    private flattenRoutes(\n        routesToCrawl: Route[],\n        result: Route[] = []\n    ): Route[] {\n        routesToCrawl.forEach(value => {\n            if (value.children && value.children.length) {\n                this.flattenRoutes(value.children, result);\n            }\n\n            if (!!value.data && !!value.data.order) {\n                result[value.data.order] = value;\n            }\n\n            return result;\n        });\n\n        return result;\n    }\n\n    private setFocusOnPageTitle(): void {\n        // Ensures that the focus is properly set after the page is updated.\n        setTimeout(() => {\n            const title = document.getElementById('page-title');\n            if (title) {\n                title.focus();\n            }\n        }, 0);\n    }\n}\n"]}
|
|
@@ -934,6 +934,10 @@ class FoehnNavigationService {
|
|
|
934
934
|
return (this.getNextAvailableRoute(NavigationDirection.BACKWARD) === null);
|
|
935
935
|
}
|
|
936
936
|
isLastFormPage() {
|
|
937
|
+
var _a;
|
|
938
|
+
if (!((_a = this.orderedRoutes) === null || _a === void 0 ? void 0 : _a.length)) {
|
|
939
|
+
return false;
|
|
940
|
+
}
|
|
937
941
|
if (!this.getCurrentRoute(this.getAvailableRoutes())) {
|
|
938
942
|
return true;
|
|
939
943
|
}
|
|
@@ -5712,8 +5716,8 @@ class FoehnAutocompleteComponent extends FoehnCheckableGroupComponent {
|
|
|
5712
5716
|
* A custom value is a value that is not in the `elements` set.
|
|
5713
5717
|
*/
|
|
5714
5718
|
this.allowCustomValue = false;
|
|
5719
|
+
this.itemHeightInSuggestionListInPx = 40;
|
|
5715
5720
|
this.hideSuggestions = true;
|
|
5716
|
-
this.ITEM_CALCULATED_HEIGHT = 40;
|
|
5717
5721
|
this.currentItemGlobalIndex = -1;
|
|
5718
5722
|
this.NB_ITEMS_VISIBLE = 5;
|
|
5719
5723
|
this.filterSubject = new Subject();
|
|
@@ -5722,7 +5726,7 @@ class FoehnAutocompleteComponent extends FoehnCheckableGroupComponent {
|
|
|
5722
5726
|
.pipe(debounceTime(200))
|
|
5723
5727
|
.subscribe(this.filterElements.bind(this));
|
|
5724
5728
|
this.VIEW_PORT_HEIGHT =
|
|
5725
|
-
this.
|
|
5729
|
+
this.itemHeightInSuggestionListInPx * this.NB_ITEMS_VISIBLE;
|
|
5726
5730
|
}
|
|
5727
5731
|
ngOnInit() {
|
|
5728
5732
|
super.ngOnInit();
|
|
@@ -6024,13 +6028,14 @@ class FoehnAutocompleteComponent extends FoehnCheckableGroupComponent {
|
|
|
6024
6028
|
if (!!filteredElements) {
|
|
6025
6029
|
if (filteredElements.length < this.NB_ITEMS_VISIBLE) {
|
|
6026
6030
|
this.VIEW_PORT_HEIGHT =
|
|
6027
|
-
this.
|
|
6031
|
+
this.itemHeightInSuggestionListInPx *
|
|
6032
|
+
filteredElements.length;
|
|
6028
6033
|
if (!!this.virtualScrollViewport) {
|
|
6029
6034
|
this.virtualScrollViewport.checkViewportSize();
|
|
6030
6035
|
}
|
|
6031
6036
|
}
|
|
6032
6037
|
else {
|
|
6033
|
-
const MAX_HEIGHT = this.NB_ITEMS_VISIBLE * this.
|
|
6038
|
+
const MAX_HEIGHT = this.NB_ITEMS_VISIBLE * this.itemHeightInSuggestionListInPx;
|
|
6034
6039
|
if (this.VIEW_PORT_HEIGHT < MAX_HEIGHT) {
|
|
6035
6040
|
this.VIEW_PORT_HEIGHT = MAX_HEIGHT;
|
|
6036
6041
|
if (!!this.virtualScrollViewport) {
|
|
@@ -6190,13 +6195,13 @@ class FoehnAutocompleteComponent extends FoehnCheckableGroupComponent {
|
|
|
6190
6195
|
}
|
|
6191
6196
|
}
|
|
6192
6197
|
FoehnAutocompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FoehnAutocompleteComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
|
6193
|
-
FoehnAutocompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: FoehnAutocompleteComponent, selector: "foehn-autocomplete", inputs: { searchValueMinCharsCount: "searchValueMinCharsCount", allowCustomValue: "allowCustomValue", customValueModelGenerator: "customValueModelGenerator" }, providers: [
|
|
6198
|
+
FoehnAutocompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: FoehnAutocompleteComponent, selector: "foehn-autocomplete", inputs: { searchValueMinCharsCount: "searchValueMinCharsCount", allowCustomValue: "allowCustomValue", customValueModelGenerator: "customValueModelGenerator", itemHeightInSuggestionListInPx: "itemHeightInSuggestionListInPx" }, providers: [
|
|
6194
6199
|
{
|
|
6195
6200
|
provide: FoehnInputComponent,
|
|
6196
6201
|
useExisting: forwardRef(() => FoehnAutocompleteComponent),
|
|
6197
6202
|
multi: true
|
|
6198
6203
|
}
|
|
6199
|
-
], viewQueries: [{ propertyName: "virtualScrollViewport", first: true, predicate: CdkVirtualScrollViewport, descendants: true }, { propertyName: "suggestionsList", first: true, predicate: ["suggestionsList"], descendants: true }, { propertyName: "inputElement", first: true, predicate: ["entryComponent"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<!--\n Accessible autocomplete widget following the listbox combobox pattern.\n ref: https://www.w3.org/TR/wai-aria-practices-1.1/examples/combobox/aria1.1pattern/listbox-combo.html\n-->\n<div\n class=\"form-group autocomplete-form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.aria-expanded]=\"shouldDisplayListbox()\"\n [attr.aria-haspopup]=\"'listbox'\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <label\n [attr.for]=\"buildChildId()\"\n *ngIf=\"!!label\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\n [attr.id]=\"buildChildId() + 'Label'\"\n >\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </label>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <div *ngIf=\"!elements\">Chargement...</div>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"sr-only\">\n Utilisez les fl\u00E8ches haut et bas pour naviguer dans la liste, puis la\n touche Entrer pour s\u00E9lectionner une option.\n </div>\n\n <!-- Give screen reader users the total of results when then input changes. -->\n <div\n class=\"sr-only\"\n aria-live=\"polite\"\n role=\"status\"\n aria-atomic=\"true\"\n *ngIf=\"displayedElements && shouldDisplayListbox()\"\n >\n Nombre de r\u00E9sultats: {{ displayedElements.length }}\n <!-- Trick to have NVDA re-reading this properly -->\n <span>{{ notificationMessageUpdated ? ',' : ',,' }}</span>\n </div>\n\n <input\n [class.is-invalid]=\"hasErrorsToDisplay()\"\n class=\"form-control autocomplete\"\n type=\"text\"\n role=\"textbox\"\n [name]=\"name || label\"\n [attr.id]=\"buildChildId()\"\n [attr.placeholder]=\"placeholder || null\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-required]=\"required || null\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.autocomplete]=\"'off'\"\n [attr.aria-activedescendant]=\"getActiveDescendantId()\"\n [attr.aria-owns]=\"\n shouldDisplayListbox() ? buildChildId() + 'Listbox' : null\n \"\n [attr.list]=\"buildChildId() + 'list'\"\n [(ngModel)]=\"inputValue\"\n (ngModelChange)=\"showSuggestionsWhenInputHasFocusAndIsEmpty($event)\"\n (paste)=\"onPaste($event)\"\n (focus)=\"onInputFocus()\"\n (blur)=\"onInputBlur()\"\n (keydown)=\"onKeyDown($event)\"\n (click)=\"onInputClick()\"\n autocomplete=\"off\"\n #entryComponent\n />\n\n <button\n type=\"button\"\n *ngIf=\"displayClearButton() | async\"\n class=\"autocomplete-clear-button btn\"\n (click)=\"onClear()\"\n [id]=\"buildChildId() + 'Clear'\"\n >\n <foehn-icon-times\n class=\"autocomplete-clear-button-icon\"\n title=\"R\u00E9initialiser le champ\"\n ></foehn-icon-times>\n </button>\n\n <div\n class=\"form-group suggestions-list-container\"\n *ngIf=\"shouldDisplayListbox()\"\n >\n <cdk-virtual-scroll-viewport\n [itemSize]=\"
|
|
6204
|
+
], viewQueries: [{ propertyName: "virtualScrollViewport", first: true, predicate: CdkVirtualScrollViewport, descendants: true }, { propertyName: "suggestionsList", first: true, predicate: ["suggestionsList"], descendants: true }, { propertyName: "inputElement", first: true, predicate: ["entryComponent"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<!--\n Accessible autocomplete widget following the listbox combobox pattern.\n ref: https://www.w3.org/TR/wai-aria-practices-1.1/examples/combobox/aria1.1pattern/listbox-combo.html\n-->\n<div\n class=\"form-group autocomplete-form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.aria-expanded]=\"shouldDisplayListbox()\"\n [attr.aria-haspopup]=\"'listbox'\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <label\n [attr.for]=\"buildChildId()\"\n *ngIf=\"!!label\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\n [attr.id]=\"buildChildId() + 'Label'\"\n >\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </label>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <div *ngIf=\"!elements\">Chargement...</div>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"sr-only\">\n Utilisez les fl\u00E8ches haut et bas pour naviguer dans la liste, puis la\n touche Entrer pour s\u00E9lectionner une option.\n </div>\n\n <!-- Give screen reader users the total of results when then input changes. -->\n <div\n class=\"sr-only\"\n aria-live=\"polite\"\n role=\"status\"\n aria-atomic=\"true\"\n *ngIf=\"displayedElements && shouldDisplayListbox()\"\n >\n Nombre de r\u00E9sultats: {{ displayedElements.length }}\n <!-- Trick to have NVDA re-reading this properly -->\n <span>{{ notificationMessageUpdated ? ',' : ',,' }}</span>\n </div>\n\n <input\n [class.is-invalid]=\"hasErrorsToDisplay()\"\n class=\"form-control autocomplete\"\n type=\"text\"\n role=\"textbox\"\n [name]=\"name || label\"\n [attr.id]=\"buildChildId()\"\n [attr.placeholder]=\"placeholder || null\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-required]=\"required || null\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.autocomplete]=\"'off'\"\n [attr.aria-activedescendant]=\"getActiveDescendantId()\"\n [attr.aria-owns]=\"\n shouldDisplayListbox() ? buildChildId() + 'Listbox' : null\n \"\n [attr.list]=\"buildChildId() + 'list'\"\n [(ngModel)]=\"inputValue\"\n (ngModelChange)=\"showSuggestionsWhenInputHasFocusAndIsEmpty($event)\"\n (paste)=\"onPaste($event)\"\n (focus)=\"onInputFocus()\"\n (blur)=\"onInputBlur()\"\n (keydown)=\"onKeyDown($event)\"\n (click)=\"onInputClick()\"\n autocomplete=\"off\"\n #entryComponent\n />\n\n <button\n type=\"button\"\n *ngIf=\"displayClearButton() | async\"\n class=\"autocomplete-clear-button btn\"\n (click)=\"onClear()\"\n [id]=\"buildChildId() + 'Clear'\"\n >\n <foehn-icon-times\n class=\"autocomplete-clear-button-icon\"\n title=\"R\u00E9initialiser le champ\"\n ></foehn-icon-times>\n </button>\n\n <div\n class=\"form-group suggestions-list-container\"\n *ngIf=\"shouldDisplayListbox()\"\n >\n <cdk-virtual-scroll-viewport\n [itemSize]=\"itemHeightInSuggestionListInPx\"\n [style.height.px]=\"VIEW_PORT_HEIGHT\"\n >\n <ul\n [attr.id]=\"buildChildId() + 'Listbox'\"\n [attr.aria-labelledby]=\"buildChildId() + 'Label'\"\n role=\"listbox\"\n class=\"suggestions-list\"\n #suggestionsList\n >\n <li\n tabindex=\"-1\"\n role=\"option\"\n class=\"suggestion\"\n *cdkVirtualFor=\"\n let element of displayedElements;\n index as i\n \"\n [attr.id]=\"buildChildId() + 'Option' + i\"\n (click)=\"onClickSuggestion(element)\"\n (mousedown)=\"onListOptionMouseDown($event)\"\n (focus)=\"onListOptionFocus()\"\n (blur)=\"onListOptionBlur()\"\n [style.height.px]=\"itemHeightInSuggestionListInPx\"\n >\n <!-- Ensures that screen readers don't consider any spaces around the emphasis -->\n <span [innerHtml]=\"getLabelWithEmphasis(element)\"></span>\n </li>\n </ul>\n </cdk-virtual-scroll-viewport>\n </div>\n</div>\n", styles: ["div.suggestions-list-container{position:relative;width:100%}cdk-virtual-scroll-viewport{width:100%;position:absolute;top:0;left:0;z-index:10;background:white;overflow-y:auto;box-shadow:0 4px 8px #0003,0 6px 20px #00000030;list-style:none;margin:inherit;padding:inherit}ul.suggestions-list{list-style:none;margin:0;padding:0}li.suggestion{width:100%;padding:.5em;font-size:1em}li.suggestion:hover,.suggestion-selected{background-color:var(--vd-info)}li.suggestion:hover{cursor:pointer;background-color:#dfdfdf}input.autocomplete::-ms-clear{display:none}input.autocomplete{padding-right:30px}.autocomplete-form-group{position:relative}.autocomplete-clear-button{position:absolute;bottom:4px;right:4px;height:30px;width:30px;background:none;border:none}.autocomplete-clear-button-icon{top:4px;right:8px;position:absolute}:host ::ng-deep .autocomplete-clear-button.btn .svg-inline--fa{color:#595959!important}:host ::ng-deep .autocomplete-clear-button.btn:hover .svg-inline--fa{color:#000!important}\n"], components: [{ type: FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { type: FoehnIconTimesComponent, selector: "foehn-icon-times" }, { type: i3$1.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i3$1.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { type: i3$1.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }], pipes: { "fromDictionary": SdkDictionaryPipe, "async": i3.AsyncPipe } });
|
|
6200
6205
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FoehnAutocompleteComponent, decorators: [{
|
|
6201
6206
|
type: Component,
|
|
6202
6207
|
args: [{ selector: 'foehn-autocomplete', providers: [
|
|
@@ -6205,7 +6210,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
6205
6210
|
useExisting: forwardRef(() => FoehnAutocompleteComponent),
|
|
6206
6211
|
multi: true
|
|
6207
6212
|
}
|
|
6208
|
-
], template: "<!--\n Accessible autocomplete widget following the listbox combobox pattern.\n ref: https://www.w3.org/TR/wai-aria-practices-1.1/examples/combobox/aria1.1pattern/listbox-combo.html\n-->\n<div\n class=\"form-group autocomplete-form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.aria-expanded]=\"shouldDisplayListbox()\"\n [attr.aria-haspopup]=\"'listbox'\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <label\n [attr.for]=\"buildChildId()\"\n *ngIf=\"!!label\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\n [attr.id]=\"buildChildId() + 'Label'\"\n >\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </label>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <div *ngIf=\"!elements\">Chargement...</div>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"sr-only\">\n Utilisez les fl\u00E8ches haut et bas pour naviguer dans la liste, puis la\n touche Entrer pour s\u00E9lectionner une option.\n </div>\n\n <!-- Give screen reader users the total of results when then input changes. -->\n <div\n class=\"sr-only\"\n aria-live=\"polite\"\n role=\"status\"\n aria-atomic=\"true\"\n *ngIf=\"displayedElements && shouldDisplayListbox()\"\n >\n Nombre de r\u00E9sultats: {{ displayedElements.length }}\n <!-- Trick to have NVDA re-reading this properly -->\n <span>{{ notificationMessageUpdated ? ',' : ',,' }}</span>\n </div>\n\n <input\n [class.is-invalid]=\"hasErrorsToDisplay()\"\n class=\"form-control autocomplete\"\n type=\"text\"\n role=\"textbox\"\n [name]=\"name || label\"\n [attr.id]=\"buildChildId()\"\n [attr.placeholder]=\"placeholder || null\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-required]=\"required || null\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.autocomplete]=\"'off'\"\n [attr.aria-activedescendant]=\"getActiveDescendantId()\"\n [attr.aria-owns]=\"\n shouldDisplayListbox() ? buildChildId() + 'Listbox' : null\n \"\n [attr.list]=\"buildChildId() + 'list'\"\n [(ngModel)]=\"inputValue\"\n (ngModelChange)=\"showSuggestionsWhenInputHasFocusAndIsEmpty($event)\"\n (paste)=\"onPaste($event)\"\n (focus)=\"onInputFocus()\"\n (blur)=\"onInputBlur()\"\n (keydown)=\"onKeyDown($event)\"\n (click)=\"onInputClick()\"\n autocomplete=\"off\"\n #entryComponent\n />\n\n <button\n type=\"button\"\n *ngIf=\"displayClearButton() | async\"\n class=\"autocomplete-clear-button btn\"\n (click)=\"onClear()\"\n [id]=\"buildChildId() + 'Clear'\"\n >\n <foehn-icon-times\n class=\"autocomplete-clear-button-icon\"\n title=\"R\u00E9initialiser le champ\"\n ></foehn-icon-times>\n </button>\n\n <div\n class=\"form-group suggestions-list-container\"\n *ngIf=\"shouldDisplayListbox()\"\n >\n <cdk-virtual-scroll-viewport\n [itemSize]=\"
|
|
6213
|
+
], template: "<!--\n Accessible autocomplete widget following the listbox combobox pattern.\n ref: https://www.w3.org/TR/wai-aria-practices-1.1/examples/combobox/aria1.1pattern/listbox-combo.html\n-->\n<div\n class=\"form-group autocomplete-form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.aria-expanded]=\"shouldDisplayListbox()\"\n [attr.aria-haspopup]=\"'listbox'\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <label\n [attr.for]=\"buildChildId()\"\n *ngIf=\"!!label\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\n [attr.id]=\"buildChildId() + 'Label'\"\n >\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </label>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <div *ngIf=\"!elements\">Chargement...</div>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"sr-only\">\n Utilisez les fl\u00E8ches haut et bas pour naviguer dans la liste, puis la\n touche Entrer pour s\u00E9lectionner une option.\n </div>\n\n <!-- Give screen reader users the total of results when then input changes. -->\n <div\n class=\"sr-only\"\n aria-live=\"polite\"\n role=\"status\"\n aria-atomic=\"true\"\n *ngIf=\"displayedElements && shouldDisplayListbox()\"\n >\n Nombre de r\u00E9sultats: {{ displayedElements.length }}\n <!-- Trick to have NVDA re-reading this properly -->\n <span>{{ notificationMessageUpdated ? ',' : ',,' }}</span>\n </div>\n\n <input\n [class.is-invalid]=\"hasErrorsToDisplay()\"\n class=\"form-control autocomplete\"\n type=\"text\"\n role=\"textbox\"\n [name]=\"name || label\"\n [attr.id]=\"buildChildId()\"\n [attr.placeholder]=\"placeholder || null\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-required]=\"required || null\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.autocomplete]=\"'off'\"\n [attr.aria-activedescendant]=\"getActiveDescendantId()\"\n [attr.aria-owns]=\"\n shouldDisplayListbox() ? buildChildId() + 'Listbox' : null\n \"\n [attr.list]=\"buildChildId() + 'list'\"\n [(ngModel)]=\"inputValue\"\n (ngModelChange)=\"showSuggestionsWhenInputHasFocusAndIsEmpty($event)\"\n (paste)=\"onPaste($event)\"\n (focus)=\"onInputFocus()\"\n (blur)=\"onInputBlur()\"\n (keydown)=\"onKeyDown($event)\"\n (click)=\"onInputClick()\"\n autocomplete=\"off\"\n #entryComponent\n />\n\n <button\n type=\"button\"\n *ngIf=\"displayClearButton() | async\"\n class=\"autocomplete-clear-button btn\"\n (click)=\"onClear()\"\n [id]=\"buildChildId() + 'Clear'\"\n >\n <foehn-icon-times\n class=\"autocomplete-clear-button-icon\"\n title=\"R\u00E9initialiser le champ\"\n ></foehn-icon-times>\n </button>\n\n <div\n class=\"form-group suggestions-list-container\"\n *ngIf=\"shouldDisplayListbox()\"\n >\n <cdk-virtual-scroll-viewport\n [itemSize]=\"itemHeightInSuggestionListInPx\"\n [style.height.px]=\"VIEW_PORT_HEIGHT\"\n >\n <ul\n [attr.id]=\"buildChildId() + 'Listbox'\"\n [attr.aria-labelledby]=\"buildChildId() + 'Label'\"\n role=\"listbox\"\n class=\"suggestions-list\"\n #suggestionsList\n >\n <li\n tabindex=\"-1\"\n role=\"option\"\n class=\"suggestion\"\n *cdkVirtualFor=\"\n let element of displayedElements;\n index as i\n \"\n [attr.id]=\"buildChildId() + 'Option' + i\"\n (click)=\"onClickSuggestion(element)\"\n (mousedown)=\"onListOptionMouseDown($event)\"\n (focus)=\"onListOptionFocus()\"\n (blur)=\"onListOptionBlur()\"\n [style.height.px]=\"itemHeightInSuggestionListInPx\"\n >\n <!-- Ensures that screen readers don't consider any spaces around the emphasis -->\n <span [innerHtml]=\"getLabelWithEmphasis(element)\"></span>\n </li>\n </ul>\n </cdk-virtual-scroll-viewport>\n </div>\n</div>\n", styles: ["div.suggestions-list-container{position:relative;width:100%}cdk-virtual-scroll-viewport{width:100%;position:absolute;top:0;left:0;z-index:10;background:white;overflow-y:auto;box-shadow:0 4px 8px #0003,0 6px 20px #00000030;list-style:none;margin:inherit;padding:inherit}ul.suggestions-list{list-style:none;margin:0;padding:0}li.suggestion{width:100%;padding:.5em;font-size:1em}li.suggestion:hover,.suggestion-selected{background-color:var(--vd-info)}li.suggestion:hover{cursor:pointer;background-color:#dfdfdf}input.autocomplete::-ms-clear{display:none}input.autocomplete{padding-right:30px}.autocomplete-form-group{position:relative}.autocomplete-clear-button{position:absolute;bottom:4px;right:4px;height:30px;width:30px;background:none;border:none}.autocomplete-clear-button-icon{top:4px;right:8px;position:absolute}:host ::ng-deep .autocomplete-clear-button.btn .svg-inline--fa{color:#595959!important}:host ::ng-deep .autocomplete-clear-button.btn:hover .svg-inline--fa{color:#000!important}\n"] }]
|
|
6209
6214
|
}], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: { virtualScrollViewport: [{
|
|
6210
6215
|
type: ViewChild,
|
|
6211
6216
|
args: [CdkVirtualScrollViewport]
|
|
@@ -6221,6 +6226,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
6221
6226
|
type: Input
|
|
6222
6227
|
}], customValueModelGenerator: [{
|
|
6223
6228
|
type: Input
|
|
6229
|
+
}], itemHeightInSuggestionListInPx: [{
|
|
6230
|
+
type: Input
|
|
6224
6231
|
}] } });
|
|
6225
6232
|
|
|
6226
6233
|
class SdkDictionaryModule {
|
|
@@ -8888,7 +8895,7 @@ FoehnInputAddressComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0
|
|
|
8888
8895
|
useExisting: forwardRef(() => FoehnInputAddressComponent),
|
|
8889
8896
|
multi: true
|
|
8890
8897
|
}
|
|
8891
|
-
], viewQueries: [{ propertyName: "foreignLocalityComponent", first: true, predicate: FoehnInputForeignLocalityComponent, descendants: true }, { propertyName: "foreignStreetComponent", first: true, predicate: FoehnInputForeignStreetComponent, descendants: true }, { propertyName: "foreignHouseNumber", first: true, predicate: ["foreignHouseNumber"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n [attr.id]=\"buildId() + 'Container'\"\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [tabIndex]=\"-1\"\n>\n <fieldset\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <foehn-autocomplete\n *ngIf=\"!isOnlySwiss\"\n [label]=\"'foehn-input-address.country.label' | fromDictionary\"\n [elements]=\"countries | async\"\n elementLabel=\"shortNameFr\"\n [elementValue]=\"identity\"\n [elementValueIdentity]=\"countryIdentity\"\n (modelChange)=\"countryUpdated($event)\"\n (userInput)=\"userInputCountry()\"\n [model]=\"country\"\n [name]=\"name + '.country'\"\n [required]=\"countryRequired\"\n [disabled]=\"disabled\"\n ></foehn-autocomplete>\n\n <ng-container *ngIf=\"isSwiss()\">\n <foehn-autocomplete\n [label]=\"'foehn-input-address.locality.label' | fromDictionary\"\n [elements]=\"localities | async\"\n [elementLabel]=\"getLocalityDisplayedName\"\n [elementValue]=\"identity\"\n [elementValueIdentity]=\"localityIdentity\"\n (modelChange)=\"localityUpdated($event)\"\n (userInput)=\"userInputLocality($event)\"\n [model]=\"locality\"\n [name]=\"name + '.locality'\"\n [required]=\"swissNpaLocalityRequired\"\n [allElementDisabled]=\"!country\"\n [disabled]=\"disabled\"\n ></foehn-autocomplete>\n\n <foehn-autocomplete\n [label]=\"'foehn-input-address.street.label' | fromDictionary\"\n [elements]=\"streets | async\"\n elementLabel=\"longName\"\n [elementValue]=\"identity\"\n [elementValueIdentity]=\"streetIdentity\"\n (modelChange)=\"streetUpdated($event)\"\n [model]=\"street\"\n [name]=\"name + '.street'\"\n [allowCustomValue]=\"true\"\n [customValueModelGenerator]=\"streetGenerator\"\n [required]=\"streetRequired\"\n [helpText]=\"\n 'foehn-input-address.street.help-text' | fromDictionary\n \"\n [allElementDisabled]=\"!country\"\n (userInput)=\"userInputStreet($event)\"\n [disabled]=\"disabled\"\n ></foehn-autocomplete>\n\n <foehn-autocomplete\n [label]=\"\n 'foehn-input-address.houseNumber.label' | fromDictionary\n \"\n [elements]=\"streetNumbers | async\"\n elementLabel=\"name\"\n elementValue=\"name\"\n [(model)]=\"houseNumber\"\n [name]=\"name + '.houseNumber'\"\n [allowCustomValue]=\"true\"\n [helpText]=\"\n 'foehn-input-address.houseNumber.help-text' | fromDictionary\n \"\n [allElementDisabled]=\"!country\"\n (modelChange)=\"updateAddress()\"\n (userInput)=\"handleUserInput()\"\n [required]=\"streetNumberRequired\"\n [disabled]=\"disabled\"\n ></foehn-autocomplete>\n </ng-container>\n\n <ng-container *ngIf=\"!isSwiss()\">\n <!--\n Component <foehn-input-foreign-locality> is special because we use the same model when swiss or foreigner.\n To do so, we need:\n - Errors will be bind on 'locality' when NULL or on 'zipCode' and 'longName' model inside component when EMPTY\n - Hide label from component because we need label from children to be displayed (isLabelSrOnly: true)\n - required and disabled params are transmitted to children\n -->\n <foehn-input-foreign-locality\n [label]=\"'foehn-input-address.locality.label' | fromDictionary\"\n [name]=\"name + '.locality'\"\n [(model)]=\"locality\"\n [zipCodeRequired]=\"foreignZipCodeRequired\"\n [localityRequired]=\"foreignLocalityRequired\"\n [isLabelSrOnly]=\"true\"\n [disabled]=\"!country || disabled\"\n (modelChange)=\"updateAddress()\"\n (userInput)=\"handleUserInput()\"\n ></foehn-input-foreign-locality>\n <!--\n Component <foehn-input-foreign-street> is special because we use the same model when swiss or foreigner.\n To do so, we need:\n - Errors will be bind on 'street' when NULL or on 'longName' model inside component when EMPTY\n - required, helpText, isLabelSrOnly and disabled params are transmitted to children\n -->\n <foehn-input-foreign-street\n [label]=\"'foehn-input-address.street.label' | fromDictionary\"\n [name]=\"name + '.street'\"\n [(model)]=\"street\"\n [required]=\"foreignStreetRequired\"\n [helpText]=\"\n 'foehn-input-address.street.help-text' | fromDictionary\n \"\n [disabled]=\"!country || disabled\"\n (modelChange)=\"updateAddress()\"\n (userInput)=\"handleUserInput()\"\n ></foehn-input-foreign-street>\n\n <foehn-input-text\n #foreignHouseNumber\n [label]=\"\n 'foehn-input-address.houseNumber.label' | fromDictionary\n \"\n [name]=\"name + '.houseNumber'\"\n [(model)]=\"houseNumber\"\n [helpText]=\"\n 'foehn-input-address.houseNumber.help-text' | fromDictionary\n \"\n [disabled]=\"!country || disabled\"\n (modelChange)=\"updateAddress()\"\n (userInput)=\"handleUserInput()\"\n [required]=\"foreignStreetNumberRequired\"\n ></foehn-input-text>\n </ng-container>\n\n <foehn-input-text\n *ngIf=\"showPostOfficeBoxText\"\n [(model)]=\"postOfficeBoxText\"\n [helpText]=\"\n 'foehn-input-address.postOfficeBoxText.help-text'\n | fromDictionary\n \"\n [label]=\"\n 'foehn-input-address.postOfficeBoxText.label' | fromDictionary\n \"\n [name]=\"name + '.postOfficeBoxText'\"\n (modelChange)=\"updateAddress()\"\n (userInput)=\"handleUserInput()\"\n [required]=\"postOfficeBoxTextRequired\"\n [disabled]=\"disabled\"\n ></foehn-input-text>\n\n <foehn-input-text\n *ngIf=\"showAdressLines && showAdressLine1\"\n [(model)]=\"addressLine1\"\n [label]=\"'foehn-input-address.addressLine1.label' | fromDictionary\"\n [name]=\"name + '.addressLine1'\"\n (modelChange)=\"updateAddress()\"\n (userInput)=\"handleUserInput()\"\n [required]=\"addressLine1Required\"\n [autocomplete]=\"'address-line2'\"\n [disabled]=\"disabled\"\n ></foehn-input-text>\n\n <foehn-input-text\n *ngIf=\"showAdressLines && showAdressLine2\"\n [(model)]=\"addressLine2\"\n [label]=\"'foehn-input-address.addressLine2.label' | fromDictionary\"\n [name]=\"name + '.addressLine2'\"\n (modelChange)=\"updateAddress()\"\n (userInput)=\"handleUserInput()\"\n [required]=\"addressLine2Required\"\n [autocomplete]=\"'address-line3'\"\n [disabled]=\"disabled\"\n ></foehn-input-text>\n </fieldset>\n</div>\n", components: [{ type: FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { type: FoehnAutocompleteComponent, selector: "foehn-autocomplete", inputs: ["searchValueMinCharsCount", "allowCustomValue", "customValueModelGenerator"] }, { type: FoehnInputForeignLocalityComponent, selector: "foehn-input-foreign-locality", inputs: ["localityRequired", "zipCodeRequired"] }, { type: FoehnInputForeignStreetComponent, selector: "foehn-input-foreign-street" }, { type: FoehnInputTextComponent, selector: "foehn-input-text", inputs: ["numberOnly"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "fromDictionary": SdkDictionaryPipe, "async": i3.AsyncPipe } });
|
|
8898
|
+
], viewQueries: [{ propertyName: "foreignLocalityComponent", first: true, predicate: FoehnInputForeignLocalityComponent, descendants: true }, { propertyName: "foreignStreetComponent", first: true, predicate: FoehnInputForeignStreetComponent, descendants: true }, { propertyName: "foreignHouseNumber", first: true, predicate: ["foreignHouseNumber"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n [attr.id]=\"buildId() + 'Container'\"\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [tabIndex]=\"-1\"\n>\n <fieldset\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <foehn-autocomplete\n *ngIf=\"!isOnlySwiss\"\n [label]=\"'foehn-input-address.country.label' | fromDictionary\"\n [elements]=\"countries | async\"\n elementLabel=\"shortNameFr\"\n [elementValue]=\"identity\"\n [elementValueIdentity]=\"countryIdentity\"\n (modelChange)=\"countryUpdated($event)\"\n (userInput)=\"userInputCountry()\"\n [model]=\"country\"\n [name]=\"name + '.country'\"\n [required]=\"countryRequired\"\n [disabled]=\"disabled\"\n ></foehn-autocomplete>\n\n <ng-container *ngIf=\"isSwiss()\">\n <foehn-autocomplete\n [label]=\"'foehn-input-address.locality.label' | fromDictionary\"\n [elements]=\"localities | async\"\n [elementLabel]=\"getLocalityDisplayedName\"\n [elementValue]=\"identity\"\n [elementValueIdentity]=\"localityIdentity\"\n (modelChange)=\"localityUpdated($event)\"\n (userInput)=\"userInputLocality($event)\"\n [model]=\"locality\"\n [name]=\"name + '.locality'\"\n [required]=\"swissNpaLocalityRequired\"\n [allElementDisabled]=\"!country\"\n [disabled]=\"disabled\"\n ></foehn-autocomplete>\n\n <foehn-autocomplete\n [label]=\"'foehn-input-address.street.label' | fromDictionary\"\n [elements]=\"streets | async\"\n elementLabel=\"longName\"\n [elementValue]=\"identity\"\n [elementValueIdentity]=\"streetIdentity\"\n (modelChange)=\"streetUpdated($event)\"\n [model]=\"street\"\n [name]=\"name + '.street'\"\n [allowCustomValue]=\"true\"\n [customValueModelGenerator]=\"streetGenerator\"\n [required]=\"streetRequired\"\n [helpText]=\"\n 'foehn-input-address.street.help-text' | fromDictionary\n \"\n [allElementDisabled]=\"!country\"\n (userInput)=\"userInputStreet($event)\"\n [disabled]=\"disabled\"\n ></foehn-autocomplete>\n\n <foehn-autocomplete\n [label]=\"\n 'foehn-input-address.houseNumber.label' | fromDictionary\n \"\n [elements]=\"streetNumbers | async\"\n elementLabel=\"name\"\n elementValue=\"name\"\n [(model)]=\"houseNumber\"\n [name]=\"name + '.houseNumber'\"\n [allowCustomValue]=\"true\"\n [helpText]=\"\n 'foehn-input-address.houseNumber.help-text' | fromDictionary\n \"\n [allElementDisabled]=\"!country\"\n (modelChange)=\"updateAddress()\"\n (userInput)=\"handleUserInput()\"\n [required]=\"streetNumberRequired\"\n [disabled]=\"disabled\"\n ></foehn-autocomplete>\n </ng-container>\n\n <ng-container *ngIf=\"!isSwiss()\">\n <!--\n Component <foehn-input-foreign-locality> is special because we use the same model when swiss or foreigner.\n To do so, we need:\n - Errors will be bind on 'locality' when NULL or on 'zipCode' and 'longName' model inside component when EMPTY\n - Hide label from component because we need label from children to be displayed (isLabelSrOnly: true)\n - required and disabled params are transmitted to children\n -->\n <foehn-input-foreign-locality\n [label]=\"'foehn-input-address.locality.label' | fromDictionary\"\n [name]=\"name + '.locality'\"\n [(model)]=\"locality\"\n [zipCodeRequired]=\"foreignZipCodeRequired\"\n [localityRequired]=\"foreignLocalityRequired\"\n [isLabelSrOnly]=\"true\"\n [disabled]=\"!country || disabled\"\n (modelChange)=\"updateAddress()\"\n (userInput)=\"handleUserInput()\"\n ></foehn-input-foreign-locality>\n <!--\n Component <foehn-input-foreign-street> is special because we use the same model when swiss or foreigner.\n To do so, we need:\n - Errors will be bind on 'street' when NULL or on 'longName' model inside component when EMPTY\n - required, helpText, isLabelSrOnly and disabled params are transmitted to children\n -->\n <foehn-input-foreign-street\n [label]=\"'foehn-input-address.street.label' | fromDictionary\"\n [name]=\"name + '.street'\"\n [(model)]=\"street\"\n [required]=\"foreignStreetRequired\"\n [helpText]=\"\n 'foehn-input-address.street.help-text' | fromDictionary\n \"\n [disabled]=\"!country || disabled\"\n (modelChange)=\"updateAddress()\"\n (userInput)=\"handleUserInput()\"\n ></foehn-input-foreign-street>\n\n <foehn-input-text\n #foreignHouseNumber\n [label]=\"\n 'foehn-input-address.houseNumber.label' | fromDictionary\n \"\n [name]=\"name + '.houseNumber'\"\n [(model)]=\"houseNumber\"\n [helpText]=\"\n 'foehn-input-address.houseNumber.help-text' | fromDictionary\n \"\n [disabled]=\"!country || disabled\"\n (modelChange)=\"updateAddress()\"\n (userInput)=\"handleUserInput()\"\n [required]=\"foreignStreetNumberRequired\"\n ></foehn-input-text>\n </ng-container>\n\n <foehn-input-text\n *ngIf=\"showPostOfficeBoxText\"\n [(model)]=\"postOfficeBoxText\"\n [helpText]=\"\n 'foehn-input-address.postOfficeBoxText.help-text'\n | fromDictionary\n \"\n [label]=\"\n 'foehn-input-address.postOfficeBoxText.label' | fromDictionary\n \"\n [name]=\"name + '.postOfficeBoxText'\"\n (modelChange)=\"updateAddress()\"\n (userInput)=\"handleUserInput()\"\n [required]=\"postOfficeBoxTextRequired\"\n [disabled]=\"disabled\"\n ></foehn-input-text>\n\n <foehn-input-text\n *ngIf=\"showAdressLines && showAdressLine1\"\n [(model)]=\"addressLine1\"\n [label]=\"'foehn-input-address.addressLine1.label' | fromDictionary\"\n [name]=\"name + '.addressLine1'\"\n (modelChange)=\"updateAddress()\"\n (userInput)=\"handleUserInput()\"\n [required]=\"addressLine1Required\"\n [autocomplete]=\"'address-line2'\"\n [disabled]=\"disabled\"\n ></foehn-input-text>\n\n <foehn-input-text\n *ngIf=\"showAdressLines && showAdressLine2\"\n [(model)]=\"addressLine2\"\n [label]=\"'foehn-input-address.addressLine2.label' | fromDictionary\"\n [name]=\"name + '.addressLine2'\"\n (modelChange)=\"updateAddress()\"\n (userInput)=\"handleUserInput()\"\n [required]=\"addressLine2Required\"\n [autocomplete]=\"'address-line3'\"\n [disabled]=\"disabled\"\n ></foehn-input-text>\n </fieldset>\n</div>\n", components: [{ type: FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { type: FoehnAutocompleteComponent, selector: "foehn-autocomplete", inputs: ["searchValueMinCharsCount", "allowCustomValue", "customValueModelGenerator", "itemHeightInSuggestionListInPx"] }, { type: FoehnInputForeignLocalityComponent, selector: "foehn-input-foreign-locality", inputs: ["localityRequired", "zipCodeRequired"] }, { type: FoehnInputForeignStreetComponent, selector: "foehn-input-foreign-street" }, { type: FoehnInputTextComponent, selector: "foehn-input-text", inputs: ["numberOnly"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "fromDictionary": SdkDictionaryPipe, "async": i3.AsyncPipe } });
|
|
8892
8899
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FoehnInputAddressComponent, decorators: [{
|
|
8893
8900
|
type: Component,
|
|
8894
8901
|
args: [{ selector: 'foehn-input-address', providers: [
|
|
@@ -9215,7 +9222,7 @@ FoehnMultiselectAutocompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVer
|
|
|
9215
9222
|
useExisting: forwardRef(() => FoehnMultiselectAutocompleteComponent),
|
|
9216
9223
|
multi: true
|
|
9217
9224
|
}
|
|
9218
|
-
], viewQueries: [{ propertyName: "autocompleteComponent", first: true, predicate: ["autocompleteComponent"], descendants: true }, { propertyName: "alertMessageContainer", first: true, predicate: ["alertMessageContainer"], descendants: true }, { propertyName: "defaultDeleteFocusArea", first: true, predicate: ["defaultDeleteFocusArea"], descendants: true }, { propertyName: "selectedElemRef", predicate: ["selectedElemRef"], descendants: true }, { propertyName: "defaultElemRef", predicate: ["defaultElemRef"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<foehn-autocomplete\n #autocompleteComponent\n [name]=\"name\"\n [label]=\"label\"\n [elements]=\"elements\"\n [elementsUrl]=\"elementsUrl\"\n [elementValue]=\"elementValue\"\n [elementLabel]=\"elementLabel\"\n [elementValueIdentity]=\"elementValueIdentity\"\n [elementDisabled]=\"elementDisabled\"\n [allElementDisabled]=\"allElementDisabled\"\n [elementGroup]=\"elementGroup\"\n [allowCustomValue]=\"false\"\n [searchValueMinCharsCount]=\"searchValueMinCharsCount\"\n [customValueModelGenerator]=\"customValueModelGenerator\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n (userInput)=\"addItem($event)\"\n [(model)]=\"autocompleteInputValue\"\n (elementsLoaded)=\"onAutocompleteElementsLoaded($event)\"\n [showErrorWhenDisabled]=\"showErrorWhenDisabled\"\n [hideNotRequiredExtraLabel]=\"hideNotRequiredExtraLabel\"\n>\n <small\n *ngIf=\"!showEmptyListMessage\"\n [attr.id]=\"buildChildId('Help')\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"\n helpText\n ? helpText\n : ('foehn-multiselect-autocomplete.autocomplete.screen-reader.label'\n | fromDictionary)\n \"\n ></small>\n\n <div\n [id]=\"buildChildId('AlertMessageContainer')\"\n role=\"status\"\n #alertMessageContainer\n >\n <p\n *ngIf=\"showEmptyListMessage\"\n class=\"alert alert-info mb-0\"\n tabindex=\"0\"\n >\n {{\n 'foehn-multiselect-autocomplete.autocomplete.empty-message'\n | fromDictionary\n }}\n </p>\n </div>\n</foehn-autocomplete>\n\n<p class=\"sr-only\" aria-live=\"polite\" aria-atomic=\"true\">\n {{ srAnnouncements }}\n</p>\n\n<div\n class=\"form-group selected-list-container d-flex align-content-stretch flex-wrap\"\n [ngClass]=\"!!model && !!model.length ? 'pt-2' : 'pt-0'\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n tabindex=\"-1\"\n>\n <span\n *ngIf=\"hasDefaultDeleteFocusArea()\"\n class=\"sr-only\"\n [tabindex]=\"0\"\n [innerHTML]=\"\n 'foehn-multiselect-autocomplete.sr-default-focus.no-element-to-delete'\n | fromDictionary\n \"\n #defaultDeleteFocusArea\n ></span>\n <ng-container\n *ngFor=\"let element of model; let index = index; trackBy: trackByFn\"\n >\n <span\n *ngIf=\"!canBeDeleted(index)\"\n class=\"badge badge-pill badge-secondary mr-1 mb-1 py-2 px-3 d-flex align-items-center\"\n [tabindex]=\"disabled ? -1 : 0\"\n [attr.aria-describedby]=\"buildChildId('Label')\"\n #defaultElemRef\n >\n {{ getLabel(element) }}\n <span class=\"sr-only\">\n {{\n 'foehn-multiselect-autocomplete.sr-default-selected-element'\n | fromDictionary\n }}\n </span>\n </span>\n <button\n *ngIf=\"canBeDeleted(index)\"\n class=\"btn btn-danger badge badge-pill mr-1 mb-1 py-2 px-3 d-flex align-items-center\"\n [tabindex]=\"0\"\n [attr.aria-label]=\"getDeleteButtonAriaLabel(element)\"\n [attr.aria-describedby]=\"buildChildId('Label')\"\n [title]=\"getDeleteButtonAriaLabel(element)\"\n (click)=\"removeItem(element, index)\"\n #selectedElemRef\n >\n {{ getLabel(element) }}\n <foehn-icon-times\n aria-hidden=\"true\"\n class=\"ml-2\"\n [title]=\"getDeleteButtonAriaLabel(element)\"\n ></foehn-icon-times>\n </button>\n </ng-container>\n</div>\n", styles: ["foehn-autocomplete p.alert:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}:host ::ng-deep foehn-autocomplete .form-group{margin-bottom:0!important}.selected-list-container button>.btn,.btn-link{line-height:inherit;padding:0}.selected-list-container .btn{text-transform:none}:host ::ng-deep .btn .svg-inline--fa{color:#fff!important}.selected-list-container span.badge-pill:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}\n"], components: [{ type: FoehnAutocompleteComponent, selector: "foehn-autocomplete", inputs: ["searchValueMinCharsCount", "allowCustomValue", "customValueModelGenerator"] }, { type: FoehnIconTimesComponent, selector: "foehn-icon-times" }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "fromDictionary": SdkDictionaryPipe } });
|
|
9225
|
+
], viewQueries: [{ propertyName: "autocompleteComponent", first: true, predicate: ["autocompleteComponent"], descendants: true }, { propertyName: "alertMessageContainer", first: true, predicate: ["alertMessageContainer"], descendants: true }, { propertyName: "defaultDeleteFocusArea", first: true, predicate: ["defaultDeleteFocusArea"], descendants: true }, { propertyName: "selectedElemRef", predicate: ["selectedElemRef"], descendants: true }, { propertyName: "defaultElemRef", predicate: ["defaultElemRef"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<foehn-autocomplete\n #autocompleteComponent\n [name]=\"name\"\n [label]=\"label\"\n [elements]=\"elements\"\n [elementsUrl]=\"elementsUrl\"\n [elementValue]=\"elementValue\"\n [elementLabel]=\"elementLabel\"\n [elementValueIdentity]=\"elementValueIdentity\"\n [elementDisabled]=\"elementDisabled\"\n [allElementDisabled]=\"allElementDisabled\"\n [elementGroup]=\"elementGroup\"\n [allowCustomValue]=\"false\"\n [searchValueMinCharsCount]=\"searchValueMinCharsCount\"\n [customValueModelGenerator]=\"customValueModelGenerator\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n (userInput)=\"addItem($event)\"\n [(model)]=\"autocompleteInputValue\"\n (elementsLoaded)=\"onAutocompleteElementsLoaded($event)\"\n [showErrorWhenDisabled]=\"showErrorWhenDisabled\"\n [hideNotRequiredExtraLabel]=\"hideNotRequiredExtraLabel\"\n>\n <small\n *ngIf=\"!showEmptyListMessage\"\n [attr.id]=\"buildChildId('Help')\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"\n helpText\n ? helpText\n : ('foehn-multiselect-autocomplete.autocomplete.screen-reader.label'\n | fromDictionary)\n \"\n ></small>\n\n <div\n [id]=\"buildChildId('AlertMessageContainer')\"\n role=\"status\"\n #alertMessageContainer\n >\n <p\n *ngIf=\"showEmptyListMessage\"\n class=\"alert alert-info mb-0\"\n tabindex=\"0\"\n >\n {{\n 'foehn-multiselect-autocomplete.autocomplete.empty-message'\n | fromDictionary\n }}\n </p>\n </div>\n</foehn-autocomplete>\n\n<p class=\"sr-only\" aria-live=\"polite\" aria-atomic=\"true\">\n {{ srAnnouncements }}\n</p>\n\n<div\n class=\"form-group selected-list-container d-flex align-content-stretch flex-wrap\"\n [ngClass]=\"!!model && !!model.length ? 'pt-2' : 'pt-0'\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n tabindex=\"-1\"\n>\n <span\n *ngIf=\"hasDefaultDeleteFocusArea()\"\n class=\"sr-only\"\n [tabindex]=\"0\"\n [innerHTML]=\"\n 'foehn-multiselect-autocomplete.sr-default-focus.no-element-to-delete'\n | fromDictionary\n \"\n #defaultDeleteFocusArea\n ></span>\n <ng-container\n *ngFor=\"let element of model; let index = index; trackBy: trackByFn\"\n >\n <span\n *ngIf=\"!canBeDeleted(index)\"\n class=\"badge badge-pill badge-secondary mr-1 mb-1 py-2 px-3 d-flex align-items-center\"\n [tabindex]=\"disabled ? -1 : 0\"\n [attr.aria-describedby]=\"buildChildId('Label')\"\n #defaultElemRef\n >\n {{ getLabel(element) }}\n <span class=\"sr-only\">\n {{\n 'foehn-multiselect-autocomplete.sr-default-selected-element'\n | fromDictionary\n }}\n </span>\n </span>\n <button\n *ngIf=\"canBeDeleted(index)\"\n class=\"btn btn-danger badge badge-pill mr-1 mb-1 py-2 px-3 d-flex align-items-center\"\n [tabindex]=\"0\"\n [attr.aria-label]=\"getDeleteButtonAriaLabel(element)\"\n [attr.aria-describedby]=\"buildChildId('Label')\"\n [title]=\"getDeleteButtonAriaLabel(element)\"\n (click)=\"removeItem(element, index)\"\n #selectedElemRef\n >\n {{ getLabel(element) }}\n <foehn-icon-times\n aria-hidden=\"true\"\n class=\"ml-2\"\n [title]=\"getDeleteButtonAriaLabel(element)\"\n ></foehn-icon-times>\n </button>\n </ng-container>\n</div>\n", styles: ["foehn-autocomplete p.alert:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}:host ::ng-deep foehn-autocomplete .form-group{margin-bottom:0!important}.selected-list-container button>.btn,.btn-link{line-height:inherit;padding:0}.selected-list-container .btn{text-transform:none}:host ::ng-deep .btn .svg-inline--fa{color:#fff!important}.selected-list-container span.badge-pill:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}\n"], components: [{ type: FoehnAutocompleteComponent, selector: "foehn-autocomplete", inputs: ["searchValueMinCharsCount", "allowCustomValue", "customValueModelGenerator", "itemHeightInSuggestionListInPx"] }, { type: FoehnIconTimesComponent, selector: "foehn-icon-times" }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "fromDictionary": SdkDictionaryPipe } });
|
|
9219
9226
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FoehnMultiselectAutocompleteComponent, decorators: [{
|
|
9220
9227
|
type: Component,
|
|
9221
9228
|
args: [{ selector: 'foehn-multiselect-autocomplete', providers: [
|