Skip to content

philstainer/typesafe-url-generator

Repository files navigation

Typesafe URL Generator

Package for creating typesafe urls

Getting started

You can install this package via running npm install typesafe-url-generator in your local application directory

Example Usage

Quick usage

import { qUrl } from 'typesafe-url-generator'

const url = "https://my-url.com/api/users/:id?foo=123" // url-config.ts
const myUrl = qUrl({
  url,
  replace: {id: "123"}, // <- Auto Complete (type -> {id: string})
  filters: {foo: "bar"} // <- Auto Complete (type -> {foo: string})
})
// type -> const myUrl: "https://my-url.com/api/users/123"
// return -> "https://my-url.com/api/users/123?foo=bar"

Full usage

// apiConfig.ts
import { createURLGenerator, type URLGeneratorConfig } from 'typesafe-url-generator';

const config = {
  products: {
    environments: {
      local: 'http://localhost:3000',
      development: 'https://dev',
      production: 'https://prod',
    },
    requests: {
      getProducts: '/products',
      getProduct: '/products/:id',
      getProductsByCategory: '/products/category?page=&limit=10',
    },
  },
} as const satisfies URLGeneratorConfig;

export const { generateUrl } = createURLGenerator(
  config,
  'development'
);

// someRequestFile.ts
import { generateUrl } from './apiConfig.ts'

const requestWithParams = generateUrl({
  api: 'products',
  request: 'getProducts',
});

const requestWithParams = generateUrl({
  api: 'products',
  request: 'getProduct',
  replace: {
    id: '1337', // Required
  },
});

const requestWithFilters = generateUrl({
  api: 'products',
  request: 'getProductsByCategory',
  // Optional
  filters: {
    page: '1', // Will be removed from the url if not set
    // limit: '10' Will default to 10 as defined in the config
  },
});

About

Typesafe url generator

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 2

  •  
  •