Skip to content
On this page

@shaggytools/nhtsa-api-wrapper / Exports / utils/queryString

Module: utils/queryString

Table of contents

Type Aliases

Functions

Type Aliases

QueryStringParams

Ƭ QueryStringParams: Record<string, QueryStringTypes>

Object to build the query string with

Defined in

utils/queryString.ts:13


QueryStringParamsEncoded

Ƭ QueryStringParamsEncoded<T>:

Object returned by encodeQueryStringParams()

Type parameters

Name
T

Defined in

utils/queryString.ts:16


QueryStringTypes

Ƭ QueryStringTypes: string | number | boolean

Valid URI component types

Defined in

utils/queryString.ts:10

Functions

createQueryString

createQueryString<T>(params?, allowEmptyParams?): string

This function is used internally by other package functions. As a consumer of this package, you should not need to use this function directly in most cases.

Utility function to generate a query string conforming to URI component standards. Takes an an optional object of search parameters and returns an encoded query string.

This function will always override params.format with { format: 'json' }. This is hardcoded into the package and cannot be overridden, this package provides no support for CSV or XML formats at this time. This means the default query string will be "?format=json" even if no params are provided by user.

  • Ignores parameters that are not strings, numbers, or booleans, and also ignores empty strings by default.

  • If you don't provide an object as the first argument, an error will be thrown. Providing an empty object will not throw an error.

  • If the second argument, allowEmptyParams, is set to true, the function will include keys with empty string values in the final query string, e.g. 'emptyKey='.

Type parameters

NameType
Textends QueryStringParams

Parameters

NameTypeDefault valueDescription
paramsTundefinedAn object of search parameters to be converted to a query string.
allowEmptyParams?booleanfalseSet to true to include keys with empty string values, e.g. 'emptyKey='.

Returns

string

  • A query string of search parameters for use in a final fetch URL.

Defined in

utils/queryString.ts:100


encodeQueryStringParams

encodeQueryStringParams<T>(params): QueryStringParamsEncoded<T>

This function is used internally by other package functions. As a consumer of this package, you should not need to use this function directly in most cases.

Utility function to perform URI component encoding on all values in an object, for use in URL query strings.

  • Returns an object of valid URI encoded parameters with same keys as the original object.
  • Will silently filter out parameters with values that are not type string, number, or boolean.
  • It filters invalid key/values so that encodeURIComponent() does not throw an error.

In it's current implementation, this function assumes that invalid types have already been filtered out, and that all values are valid. If you need to be sure that all keys are present in the returned object, you can use the validateArgument() function to check the types of all values are valid before calling this function.

This function is not exported by the package, but is used internally by other functions. However, it is exported by the package as part of the composable function useQueryString, and renamed to encodeParams for less verbose use.

Type parameters

NameType
Textends QueryStringParams

Parameters

NameTypeDescription
paramsTAn object of search parameters to be encoded.

Returns

QueryStringParamsEncoded<T>

  • A new object of same keys as the original object with values converted to URI component strings. Any keys with values not a string, number, or boolean are filtered out of final object.

Defined in

utils/queryString.ts:44

Released under the MIT License.