icns-frontend/utils/url.ts

53 lines
1.3 KiB
TypeScript
Raw Normal View History

2022-12-15 06:02:50 +00:00
import { TwitterLoginSuccess } from "../types";
import { TWITTER_LOGIN_ERROR } from "../constants/error-message";
2022-12-15 15:43:18 +00:00
import { WALLET_INSTALL_URL } from "../constants/wallet";
2022-12-15 06:02:50 +00:00
2022-12-05 10:50:13 +00:00
export function request<TResponse>(
url: string,
config: RequestInit = {},
2022-12-15 15:43:18 +00:00
isIgnore?: boolean,
2022-12-05 10:50:13 +00:00
): Promise<TResponse> {
return fetch(url, config)
2022-12-14 15:39:51 +00:00
.then((response) => {
2022-12-15 15:43:18 +00:00
if (!response.ok && !isIgnore) {
throw new Error(
`This is an HTTP error: The status is ${response.status} ${response.statusText}`,
2022-12-14 15:39:51 +00:00
);
}
return response.json();
})
2022-12-05 10:50:13 +00:00
.then((data) => data as TResponse);
}
export function buildQueryString(query: Record<string, any>): string {
return Object.entries(query)
.map(([key, value]) =>
key && value
? `${encodeURIComponent(key)}=${encodeURIComponent(value)}`
: "",
)
.join("&");
}
2022-12-15 06:02:50 +00:00
export const checkTwitterAuthQueryParameter = (
query: string,
): TwitterLoginSuccess => {
// Twitter Login Error Check
if (query.match("error")) {
throw new Error(TWITTER_LOGIN_ERROR);
}
// Twitter state, auth code check
const [, state, code] =
query.match(/^(?=.*state=([^&]+)|)(?=.*code=([^&]+)|).+$/) || [];
return {
state,
code,
};
};
2022-12-15 15:43:18 +00:00
export const replaceToInstallPage = () => {
window.location.href = WALLET_INSTALL_URL;
};