| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 |
- /**
- * 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<string> = 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
|