mirror of
				https://github.com/mealie-recipes/mealie.git
				synced 2025-10-31 10:13:32 -04:00 
			
		
		
		
	
		
			
	
	
		
			39 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
		
		
			
		
	
	
			39 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
|  | const parts = { | ||
|  |   host: "http://localhost.com", | ||
|  |   prefix: "/api", | ||
|  | }; | ||
|  | 
 | ||
|  | export function overrideParts(host: string, prefix: string) { | ||
|  |   parts.host = host; | ||
|  |   parts.prefix = prefix; | ||
|  | } | ||
|  | 
 | ||
|  | export type QueryValue = string | string[] | number | number[] | boolean | null | undefined; | ||
|  | 
 | ||
|  | /** | ||
|  |  * route is a the main URL builder for the API. It will use a predefined host and prefix (global) | ||
|  |  * in the urls.ts file and then append the passed in path parameter uring the `URL` class from the | ||
|  |  * browser. It will also append any query parameters passed in as the second parameter. | ||
|  |  * | ||
|  |  * The default host `http://localhost.com` is removed from the path if it is present. This allows us | ||
|  |  * to bootstrap the API with different hosts as needed (like for testing) but still allows us to use | ||
|  |  * relative URLs in production because the API and client bundle are served from the same server/host. | ||
|  |  */ | ||
|  | export function route(rest: string, params: Record<string, QueryValue> | null = null): string { | ||
|  |   const url = new URL(parts.prefix + rest, parts.host); | ||
|  | 
 | ||
|  |   if (params) { | ||
|  |     for (const [key, value] of Object.entries(params)) { | ||
|  |       if (Array.isArray(value)) { | ||
|  |         for (const item of value) { | ||
|  |           url.searchParams.append(key, String(item)); | ||
|  |         } | ||
|  |       } else { | ||
|  |         url.searchParams.append(key, String(value)); | ||
|  |       } | ||
|  |     } | ||
|  |   } | ||
|  | 
 | ||
|  |   return url.toString().replace("http://localhost.com", ""); | ||
|  | } |