Skip to content

Commit dd1cb97

Browse files
authored
fix: restore React Native compatibility (#286)
1 parent 05335e1 commit dd1cb97

File tree

1 file changed

+5
-4
lines changed

1 file changed

+5
-4
lines changed

src/data/encodeQueryString.ts

Lines changed: 5 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -12,17 +12,18 @@ export const encodeQueryString = ({
1212
const searchParams = new URLSearchParams()
1313
// We generally want tag at the start of the query string
1414
const {tag, ...opts} = options
15-
if (tag) searchParams.set('tag', tag)
16-
searchParams.set('query', query)
15+
// We're using `append` instead of `set` to support React Native: https://github.com/facebook/react-native/blob/1982c4722fcc51aa87e34cf562672ee4aff540f1/packages/react-native/Libraries/Blob/URL.js#L86-L88
16+
if (tag) searchParams.append('tag', tag)
17+
searchParams.append('query', query)
1718

1819
// Iterate params, the keys are prefixed with `$` and their values JSON stringified
1920
for (const [key, value] of Object.entries(params)) {
20-
searchParams.set(`$${key}`, JSON.stringify(value))
21+
searchParams.append(`$${key}`, JSON.stringify(value))
2122
}
2223
// Options are passed as-is
2324
for (const [key, value] of Object.entries(opts)) {
2425
// Skip falsy values
25-
if (value) searchParams.set(key, `${value}`)
26+
if (value) searchParams.append(key, `${value}`)
2627
}
2728

2829
return `?${searchParams}`

0 commit comments

Comments
 (0)