/** * Classe permettant de construire une URL pour l'interrogation d'une API externe */ class Url { /** * Concatenate a base url and a tail * @param base * @param tails * @private */ public static join (base: string, ...tails: string[]): string { let url = base tails.forEach((tail: string) => { url = url.replace(/^|\/$/g, '') + '/' + tail.replace(/^\/?|$/g, '') }) return url } /** * Prepend the 'https://' part if neither 'http://' of 'https://' is present, else: does nothing * * @param url */ public static prependHttps (url: string): string { if (!url.match(/^https?:\/\/.*/)) { url = 'https://' + url; } return url; } /** * Parse an URI to retrieve the page number * * @param uri * @param parameter * @param default_ * @private */ public static getParameter( uri: string, parameter: string, default_: string | null = null ): string | null { const urlParams = new URL(uri).searchParams; const res = urlParams.get('page'); return res ?? default_ } /** * Extrait l'ID de l'URI passée en paramètre * L'uri est supposée être de la forme `.../foo/bar/{id}`, où l'id est un identifiant numérique * * @param uri */ public static extractIdFromUri (uri: string): number|null { const partUri: Array = uri.split('/') const id:any = partUri.pop() if(isNaN(id)) throw new Error('id is not a number') return parseInt(id) } /** * Découpe une URI au niveau des '/' * Utilisé entre autres pour le breadcrumb * * @param uri */ public static split(uri: string) { if (uri.startsWith('/')) { uri = uri.substring(1) } return uri.split('/') } } export default Url