@shware/http 0.4.3 → 1.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -3,6 +3,10 @@ var __defProp = Object.defineProperty;
3
3
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
5
5
  var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
6
10
  var __copyProps = (to, from, except, desc) => {
7
11
  if (from && typeof from === "object" || typeof from === "function") {
8
12
  for (let key of __getOwnPropNames(from))
@@ -13,7 +17,50 @@ var __copyProps = (to, from, except, desc) => {
13
17
  };
14
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
15
19
 
16
- // src/google-one-tap/index.ts
20
+ // src/google-one-tap/index.tsx
17
21
  var google_one_tap_exports = {};
22
+ __export(google_one_tap_exports, {
23
+ useGoogleOneTap: () => useGoogleOneTap
24
+ });
18
25
  module.exports = __toCommonJS(google_one_tap_exports);
26
+ var import_react = require("react");
27
+ function useGoogleOneTap({ clientId, callback }) {
28
+ const [loaded, setLoaded] = (0, import_react.useState)(false);
29
+ const ref = (0, import_react.useRef)(callback);
30
+ ref.current = callback;
31
+ (0, import_react.useEffect)(() => {
32
+ const scriptId = "google-one-tap";
33
+ const script = document.createElement("script");
34
+ script.id = scriptId;
35
+ script.async = true;
36
+ script.defer = true;
37
+ script.src = "https://accounts.google.com/gsi/client";
38
+ script.onload = () => {
39
+ window.google.accounts.id.initialize({
40
+ ux_mode: "popup",
41
+ context: "signin",
42
+ auto_select: false,
43
+ client_id: clientId,
44
+ use_fedcm_for_prompt: true,
45
+ cancel_on_tap_outside: false,
46
+ callback: ref.current
47
+ });
48
+ setLoaded(true);
49
+ };
50
+ document.head.appendChild(script);
51
+ return () => {
52
+ setLoaded(false);
53
+ script.remove();
54
+ };
55
+ }, [clientId]);
56
+ return {
57
+ loaded,
58
+ prompt: () => window.google?.accounts?.id?.prompt(),
59
+ cancel: () => window.google?.accounts?.id?.cancel()
60
+ };
61
+ }
62
+ // Annotate the CommonJS export names for ESM import in node:
63
+ 0 && (module.exports = {
64
+ useGoogleOneTap
65
+ });
19
66
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/google-one-tap/index.ts"],"sourcesContent":["export type { GoogleAccounts, IdConfiguration } from './types';\n"],"mappings":";;;;;;;;;;;;;;;;AAAA;AAAA;","names":[]}
1
+ {"version":3,"sources":["../../src/google-one-tap/index.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\nimport type { GoogleAccounts, CredentialResponse } from './types';\n\ndeclare global {\n interface Window {\n google: {\n accounts: GoogleAccounts;\n };\n }\n}\n\nexport type Props = {\n clientId: string;\n callback: (response: CredentialResponse) => void | Promise<void>;\n};\n\n/** debug: chrome://settings/content/federatedIdentityApi */\nexport function useGoogleOneTap({ clientId, callback }: Props) {\n const [loaded, setLoaded] = useState(false);\n const ref = useRef(callback);\n ref.current = callback;\n\n useEffect(() => {\n const scriptId = 'google-one-tap';\n const script = document.createElement('script');\n script.id = scriptId;\n script.async = true;\n script.defer = true;\n script.src = 'https://accounts.google.com/gsi/client';\n script.onload = () => {\n window.google.accounts.id.initialize({\n ux_mode: 'popup',\n context: 'signin',\n auto_select: false,\n client_id: clientId,\n use_fedcm_for_prompt: true,\n cancel_on_tap_outside: false,\n callback: ref.current,\n });\n setLoaded(true);\n };\n\n document.head.appendChild(script);\n\n return () => {\n setLoaded(false);\n script.remove();\n };\n }, [clientId]);\n\n return {\n loaded,\n prompt: () => window.google?.accounts?.id?.prompt(),\n cancel: () => window.google?.accounts?.id?.cancel(),\n };\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAA4C;AAiBrC,SAAS,gBAAgB,EAAE,UAAU,SAAS,GAAU;AAC7D,QAAM,CAAC,QAAQ,SAAS,QAAI,uBAAS,KAAK;AAC1C,QAAM,UAAM,qBAAO,QAAQ;AAC3B,MAAI,UAAU;AAEd,8BAAU,MAAM;AACd,UAAM,WAAW;AACjB,UAAM,SAAS,SAAS,cAAc,QAAQ;AAC9C,WAAO,KAAK;AACZ,WAAO,QAAQ;AACf,WAAO,QAAQ;AACf,WAAO,MAAM;AACb,WAAO,SAAS,MAAM;AACpB,aAAO,OAAO,SAAS,GAAG,WAAW;AAAA,QACnC,SAAS;AAAA,QACT,SAAS;AAAA,QACT,aAAa;AAAA,QACb,WAAW;AAAA,QACX,sBAAsB;AAAA,QACtB,uBAAuB;AAAA,QACvB,UAAU,IAAI;AAAA,MAChB,CAAC;AACD,gBAAU,IAAI;AAAA,IAChB;AAEA,aAAS,KAAK,YAAY,MAAM;AAEhC,WAAO,MAAM;AACX,gBAAU,KAAK;AACf,aAAO,OAAO;AAAA,IAChB;AAAA,EACF,GAAG,CAAC,QAAQ,CAAC;AAEb,SAAO;AAAA,IACL;AAAA,IACA,QAAQ,MAAM,OAAO,QAAQ,UAAU,IAAI,OAAO;AAAA,IAClD,QAAQ,MAAM,OAAO,QAAQ,UAAU,IAAI,OAAO;AAAA,EACpD;AACF;","names":[]}
@@ -1 +1,21 @@
1
- export { GoogleAccounts, IdConfiguration } from './types.cjs';
1
+ import { GoogleAccounts, CredentialResponse } from './types.cjs';
2
+
3
+ declare global {
4
+ interface Window {
5
+ google: {
6
+ accounts: GoogleAccounts;
7
+ };
8
+ }
9
+ }
10
+ type Props = {
11
+ clientId: string;
12
+ callback: (response: CredentialResponse) => void | Promise<void>;
13
+ };
14
+ /** debug: chrome://settings/content/federatedIdentityApi */
15
+ declare function useGoogleOneTap({ clientId, callback }: Props): {
16
+ loaded: boolean;
17
+ prompt: () => void;
18
+ cancel: () => void;
19
+ };
20
+
21
+ export { type Props, useGoogleOneTap };
@@ -1 +1,21 @@
1
- export { GoogleAccounts, IdConfiguration } from './types.js';
1
+ import { GoogleAccounts, CredentialResponse } from './types.js';
2
+
3
+ declare global {
4
+ interface Window {
5
+ google: {
6
+ accounts: GoogleAccounts;
7
+ };
8
+ }
9
+ }
10
+ type Props = {
11
+ clientId: string;
12
+ callback: (response: CredentialResponse) => void | Promise<void>;
13
+ };
14
+ /** debug: chrome://settings/content/federatedIdentityApi */
15
+ declare function useGoogleOneTap({ clientId, callback }: Props): {
16
+ loaded: boolean;
17
+ prompt: () => void;
18
+ cancel: () => void;
19
+ };
20
+
21
+ export { type Props, useGoogleOneTap };
@@ -1 +1,41 @@
1
+ // src/google-one-tap/index.tsx
2
+ import { useEffect, useRef, useState } from "react";
3
+ function useGoogleOneTap({ clientId, callback }) {
4
+ const [loaded, setLoaded] = useState(false);
5
+ const ref = useRef(callback);
6
+ ref.current = callback;
7
+ useEffect(() => {
8
+ const scriptId = "google-one-tap";
9
+ const script = document.createElement("script");
10
+ script.id = scriptId;
11
+ script.async = true;
12
+ script.defer = true;
13
+ script.src = "https://accounts.google.com/gsi/client";
14
+ script.onload = () => {
15
+ window.google.accounts.id.initialize({
16
+ ux_mode: "popup",
17
+ context: "signin",
18
+ auto_select: false,
19
+ client_id: clientId,
20
+ use_fedcm_for_prompt: true,
21
+ cancel_on_tap_outside: false,
22
+ callback: ref.current
23
+ });
24
+ setLoaded(true);
25
+ };
26
+ document.head.appendChild(script);
27
+ return () => {
28
+ setLoaded(false);
29
+ script.remove();
30
+ };
31
+ }, [clientId]);
32
+ return {
33
+ loaded,
34
+ prompt: () => window.google?.accounts?.id?.prompt(),
35
+ cancel: () => window.google?.accounts?.id?.cancel()
36
+ };
37
+ }
38
+ export {
39
+ useGoogleOneTap
40
+ };
1
41
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
1
+ {"version":3,"sources":["../../src/google-one-tap/index.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\nimport type { GoogleAccounts, CredentialResponse } from './types';\n\ndeclare global {\n interface Window {\n google: {\n accounts: GoogleAccounts;\n };\n }\n}\n\nexport type Props = {\n clientId: string;\n callback: (response: CredentialResponse) => void | Promise<void>;\n};\n\n/** debug: chrome://settings/content/federatedIdentityApi */\nexport function useGoogleOneTap({ clientId, callback }: Props) {\n const [loaded, setLoaded] = useState(false);\n const ref = useRef(callback);\n ref.current = callback;\n\n useEffect(() => {\n const scriptId = 'google-one-tap';\n const script = document.createElement('script');\n script.id = scriptId;\n script.async = true;\n script.defer = true;\n script.src = 'https://accounts.google.com/gsi/client';\n script.onload = () => {\n window.google.accounts.id.initialize({\n ux_mode: 'popup',\n context: 'signin',\n auto_select: false,\n client_id: clientId,\n use_fedcm_for_prompt: true,\n cancel_on_tap_outside: false,\n callback: ref.current,\n });\n setLoaded(true);\n };\n\n document.head.appendChild(script);\n\n return () => {\n setLoaded(false);\n script.remove();\n };\n }, [clientId]);\n\n return {\n loaded,\n prompt: () => window.google?.accounts?.id?.prompt(),\n cancel: () => window.google?.accounts?.id?.cancel(),\n };\n}\n"],"mappings":";AAAA,SAAS,WAAW,QAAQ,gBAAgB;AAiBrC,SAAS,gBAAgB,EAAE,UAAU,SAAS,GAAU;AAC7D,QAAM,CAAC,QAAQ,SAAS,IAAI,SAAS,KAAK;AAC1C,QAAM,MAAM,OAAO,QAAQ;AAC3B,MAAI,UAAU;AAEd,YAAU,MAAM;AACd,UAAM,WAAW;AACjB,UAAM,SAAS,SAAS,cAAc,QAAQ;AAC9C,WAAO,KAAK;AACZ,WAAO,QAAQ;AACf,WAAO,QAAQ;AACf,WAAO,MAAM;AACb,WAAO,SAAS,MAAM;AACpB,aAAO,OAAO,SAAS,GAAG,WAAW;AAAA,QACnC,SAAS;AAAA,QACT,SAAS;AAAA,QACT,aAAa;AAAA,QACb,WAAW;AAAA,QACX,sBAAsB;AAAA,QACtB,uBAAuB;AAAA,QACvB,UAAU,IAAI;AAAA,MAChB,CAAC;AACD,gBAAU,IAAI;AAAA,IAChB;AAEA,aAAS,KAAK,YAAY,MAAM;AAEhC,WAAO,MAAM;AACX,gBAAU,KAAK;AACf,aAAO,OAAO;AAAA,IAChB;AAAA,EACF,GAAG,CAAC,QAAQ,CAAC;AAEb,SAAO;AAAA,IACL;AAAA,IACA,QAAQ,MAAM,OAAO,QAAQ,UAAU,IAAI,OAAO;AAAA,IAClD,QAAQ,MAAM,OAAO,QAAQ,UAAU,IAAI,OAAO;AAAA,EACpD;AACF;","names":[]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/google-one-tap/types.ts"],"sourcesContent":["interface ClientConfigError extends Error {\n message: string;\n stack?: string;\n type: 'unknown' | 'popup_closed' | 'popup_failed_to_open';\n}\n\ninterface OverridableTokenClientConfig {\n scope?: string;\n include_granted_scopes?: boolean;\n prompt?: string;\n enable_granular_consent?: boolean;\n enable_serial_consent?: boolean;\n login_hint?: string;\n hint?: string;\n state?: string;\n}\n\ninterface TokenClient {\n requestAccessToken: (overrideConfig?: OverridableTokenClientConfig) => void;\n}\n\ninterface CodeClient {\n requestCode: () => void;\n}\n\ninterface TokenResponse {\n access_token: string;\n expires_in: string;\n hd: string;\n prompt: string;\n token_type: string;\n scope: string;\n state: string;\n error: string;\n error_description: string;\n error_uri: string;\n}\n\ninterface CodeResponse {\n code: string;\n scope: string;\n state: string;\n error: string;\n error_description: string;\n error_uri: string;\n}\n\ninterface TokenClientConfig {\n client_id: string;\n scope: string;\n include_granted_scopes?: boolean;\n prompt?: '' | 'none' | 'consent' | 'select_account';\n enable_granular_consent?: boolean;\n enable_serial_consent?: boolean;\n login_hint?: string;\n hint?: string;\n hd?: string;\n hosted_domain?: string;\n state?: string;\n callback: (tokenResponse: TokenResponse) => void;\n error_callback?: (error: ClientConfigError) => void;\n}\n\ninterface CodeClientConfig {\n client_id: string;\n scope: string;\n include_granted_scopes?: boolean;\n redirect_uri?: string;\n state?: string;\n enable_granular_consent?: boolean;\n enable_serial_consent?: boolean;\n login_hint?: string;\n hint?: string;\n hd?: string;\n hosted_domain?: string;\n ux_mode?: 'popup' | 'redirect';\n select_account?: boolean;\n callback?: (response: CodeResponse) => void;\n error_callback?: (error: ClientConfigError) => void;\n}\n\ninterface RevocationResponse {\n successful: boolean;\n error?: string;\n}\n\ninterface Credential {\n id: string;\n password: string;\n}\n\ninterface CredentialResponse {\n credential: string;\n select_by: string;\n}\n\nexport interface IdConfiguration {\n client_id: string;\n auto_select?: boolean;\n login_uri?: string;\n cancel_on_tap_outside?: boolean;\n prompt_parent_id?: string;\n nonce?: string;\n context?: 'signin' | 'signup' | 'use';\n state_cookie_domain?: string;\n ux_mode?: 'popup' | 'redirect';\n allowed_parent_origin?: string | string[];\n itp_support?: boolean;\n login_hint?: string;\n hd?: string;\n use_fedcm_for_prompt?: boolean;\n callback?: (response: CredentialResponse) => void;\n native_callback?: (response: CredentialResponse) => void;\n intermediate_iframe_close_callback?: () => void;\n}\n\ninterface PromptMomentNotification {\n isDisplayMoment(): boolean;\n isDisplayed(): boolean;\n isNotDisplayed(): boolean;\n getNotDisplayedReason():\n | 'browser_not_supported'\n | 'invalid_client'\n | 'missing_client_id'\n | 'opt_out_or_no_session'\n | 'secure_http_required'\n | 'suppressed_by_user'\n | 'unregistered_origin'\n | 'unknown_reason';\n\n isSkippedMoment(): boolean;\n getSkippedReason(): 'auto_cancel' | 'user_cancel' | 'tap_outside' | 'issuing_failed';\n isDismissedMoment(): boolean;\n getDismissedReason(): 'credential_returned' | 'cancel_called' | 'flow_restarted';\n getMomentType(): 'display' | 'skipped' | 'dismissed';\n}\n\ninterface GsiButtonConfiguration {\n type: 'standard' | 'icon';\n theme?: 'outline' | 'filled_blue' | 'filled_black';\n size?: 'small' | 'medium' | 'large';\n text?: 'signin_with' | 'signup_with' | 'continue_with' | 'signin';\n shape?: 'rectangular' | 'pill' | 'circle' | 'square';\n logo_alignment?: 'left' | 'center';\n width?: number;\n locale?: string;\n state?: string;\n click_listener?: () => void;\n}\n\nexport interface GoogleAccounts {\n oauth2: {\n initCodeClient(config: CodeClientConfig): CodeClient;\n initTokenClient(config: TokenClientConfig): TokenClient;\n hasGrantedAllScopes(\n tokenResponse: TokenResponse,\n firstScope: string,\n ...restScopes: string[]\n ): boolean;\n hasGrantedAnyScope(\n tokenResponse: TokenResponse,\n firstScope: string,\n ...restScopes: string[]\n ): boolean;\n revoke(accessToken: string, done: () => void): void;\n };\n id: {\n initialize(idConfig: IdConfiguration): void;\n prompt(momentListener?: (promptMomentNotification: PromptMomentNotification) => void): void;\n renderButton(parent: HTMLElement, options: GsiButtonConfiguration): void;\n disableAutoSelect(): void;\n storeCredential(credential: Credential, callback?: () => void): void;\n cancel(): void;\n revoke(hint: string, callback?: (response: RevocationResponse) => void): void;\n };\n}\n"],"mappings":";;;;;;;;;;;;;;;;AAAA;AAAA;","names":[]}
1
+ {"version":3,"sources":["../../src/google-one-tap/types.ts"],"sourcesContent":["interface ClientConfigError extends Error {\n message: string;\n stack?: string;\n type: 'unknown' | 'popup_closed' | 'popup_failed_to_open';\n}\n\ninterface OverridableTokenClientConfig {\n scope?: string;\n include_granted_scopes?: boolean;\n prompt?: string;\n enable_granular_consent?: boolean;\n enable_serial_consent?: boolean;\n login_hint?: string;\n hint?: string;\n state?: string;\n}\n\ninterface TokenClient {\n requestAccessToken: (overrideConfig?: OverridableTokenClientConfig) => void;\n}\n\ninterface CodeClient {\n requestCode: () => void;\n}\n\ninterface TokenResponse {\n access_token: string;\n expires_in: string;\n hd: string;\n prompt: string;\n token_type: string;\n scope: string;\n state: string;\n error: string;\n error_description: string;\n error_uri: string;\n}\n\ninterface CodeResponse {\n code: string;\n scope: string;\n state: string;\n error: string;\n error_description: string;\n error_uri: string;\n}\n\ninterface TokenClientConfig {\n client_id: string;\n scope: string;\n include_granted_scopes?: boolean;\n prompt?: '' | 'none' | 'consent' | 'select_account';\n enable_granular_consent?: boolean;\n enable_serial_consent?: boolean;\n login_hint?: string;\n hint?: string;\n hd?: string;\n hosted_domain?: string;\n state?: string;\n callback: (tokenResponse: TokenResponse) => void;\n error_callback?: (error: ClientConfigError) => void;\n}\n\ninterface CodeClientConfig {\n client_id: string;\n scope: string;\n include_granted_scopes?: boolean;\n redirect_uri?: string;\n state?: string;\n enable_granular_consent?: boolean;\n enable_serial_consent?: boolean;\n login_hint?: string;\n hint?: string;\n hd?: string;\n hosted_domain?: string;\n ux_mode?: 'popup' | 'redirect';\n select_account?: boolean;\n callback?: (response: CodeResponse) => void;\n error_callback?: (error: ClientConfigError) => void;\n}\n\ninterface RevocationResponse {\n successful: boolean;\n error?: string;\n}\n\ninterface Credential {\n id: string;\n password: string;\n}\n\nexport interface CredentialResponse {\n credential: string;\n select_by: string;\n}\n\nexport interface IdConfiguration {\n client_id: string;\n auto_select?: boolean;\n login_uri?: string;\n cancel_on_tap_outside?: boolean;\n prompt_parent_id?: string;\n nonce?: string;\n context?: 'signin' | 'signup' | 'use';\n state_cookie_domain?: string;\n ux_mode?: 'popup' | 'redirect';\n allowed_parent_origin?: string | string[];\n itp_support?: boolean;\n login_hint?: string;\n hd?: string;\n use_fedcm_for_prompt?: boolean;\n callback?: (response: CredentialResponse) => void;\n native_callback?: (response: CredentialResponse) => void;\n intermediate_iframe_close_callback?: () => void;\n}\n/**\n * ref: https://developers.google.com/identity/gsi/web/guides/fedcm-migration?s=dc&utm_source=devtools&utm_campaign=stable#display_moment\n */\nexport interface PromptMomentNotification {\n /** @deprecated */\n isDisplayMoment(): boolean;\n\n /** @deprecated */\n isDisplayed(): boolean;\n\n /** @deprecated */\n isNotDisplayed(): boolean;\n\n /** @deprecated */\n getNotDisplayedReason():\n | 'browser_not_supported'\n | 'invalid_client'\n | 'missing_client_id'\n | 'opt_out_or_no_session'\n | 'secure_http_required'\n | 'suppressed_by_user'\n | 'unregistered_origin'\n | 'unknown_reason';\n\n /** @deprecated */\n getSkippedReason(): 'auto_cancel' | 'user_cancel' | 'tap_outside' | 'issuing_failed';\n\n isSkippedMoment(): boolean;\n isDismissedMoment(): boolean;\n getDismissedReason(): 'credential_returned' | 'cancel_called' | 'flow_restarted';\n getMomentType(): 'display' | 'skipped' | 'dismissed';\n}\n\ninterface GsiButtonConfiguration {\n type: 'standard' | 'icon';\n theme?: 'outline' | 'filled_blue' | 'filled_black';\n size?: 'small' | 'medium' | 'large';\n text?: 'signin_with' | 'signup_with' | 'continue_with' | 'signin';\n shape?: 'rectangular' | 'pill' | 'circle' | 'square';\n logo_alignment?: 'left' | 'center';\n width?: number;\n locale?: string;\n state?: string;\n click_listener?: () => void;\n}\n\nexport interface GoogleAccounts {\n oauth2: {\n initCodeClient(config: CodeClientConfig): CodeClient;\n initTokenClient(config: TokenClientConfig): TokenClient;\n hasGrantedAllScopes(\n tokenResponse: TokenResponse,\n firstScope: string,\n ...restScopes: string[]\n ): boolean;\n hasGrantedAnyScope(\n tokenResponse: TokenResponse,\n firstScope: string,\n ...restScopes: string[]\n ): boolean;\n revoke(accessToken: string, done: () => void): void;\n };\n id: {\n initialize(idConfig: IdConfiguration): void;\n prompt(momentListener?: (promptMomentNotification: PromptMomentNotification) => void): void;\n renderButton(parent: HTMLElement, options: GsiButtonConfiguration): void;\n disableAutoSelect(): void;\n storeCredential(credential: Credential, callback?: () => void): void;\n cancel(): void;\n revoke(hint: string, callback?: (response: RevocationResponse) => void): void;\n };\n}\n"],"mappings":";;;;;;;;;;;;;;;;AAAA;AAAA;","names":[]}
@@ -102,13 +102,21 @@ interface IdConfiguration {
102
102
  native_callback?: (response: CredentialResponse) => void;
103
103
  intermediate_iframe_close_callback?: () => void;
104
104
  }
105
+ /**
106
+ * ref: https://developers.google.com/identity/gsi/web/guides/fedcm-migration?s=dc&utm_source=devtools&utm_campaign=stable#display_moment
107
+ */
105
108
  interface PromptMomentNotification {
109
+ /** @deprecated */
106
110
  isDisplayMoment(): boolean;
111
+ /** @deprecated */
107
112
  isDisplayed(): boolean;
113
+ /** @deprecated */
108
114
  isNotDisplayed(): boolean;
115
+ /** @deprecated */
109
116
  getNotDisplayedReason(): 'browser_not_supported' | 'invalid_client' | 'missing_client_id' | 'opt_out_or_no_session' | 'secure_http_required' | 'suppressed_by_user' | 'unregistered_origin' | 'unknown_reason';
110
- isSkippedMoment(): boolean;
117
+ /** @deprecated */
111
118
  getSkippedReason(): 'auto_cancel' | 'user_cancel' | 'tap_outside' | 'issuing_failed';
119
+ isSkippedMoment(): boolean;
112
120
  isDismissedMoment(): boolean;
113
121
  getDismissedReason(): 'credential_returned' | 'cancel_called' | 'flow_restarted';
114
122
  getMomentType(): 'display' | 'skipped' | 'dismissed';
@@ -144,4 +152,4 @@ interface GoogleAccounts {
144
152
  };
145
153
  }
146
154
 
147
- export type { GoogleAccounts, IdConfiguration };
155
+ export type { CredentialResponse, GoogleAccounts, IdConfiguration, PromptMomentNotification };
@@ -102,13 +102,21 @@ interface IdConfiguration {
102
102
  native_callback?: (response: CredentialResponse) => void;
103
103
  intermediate_iframe_close_callback?: () => void;
104
104
  }
105
+ /**
106
+ * ref: https://developers.google.com/identity/gsi/web/guides/fedcm-migration?s=dc&utm_source=devtools&utm_campaign=stable#display_moment
107
+ */
105
108
  interface PromptMomentNotification {
109
+ /** @deprecated */
106
110
  isDisplayMoment(): boolean;
111
+ /** @deprecated */
107
112
  isDisplayed(): boolean;
113
+ /** @deprecated */
108
114
  isNotDisplayed(): boolean;
115
+ /** @deprecated */
109
116
  getNotDisplayedReason(): 'browser_not_supported' | 'invalid_client' | 'missing_client_id' | 'opt_out_or_no_session' | 'secure_http_required' | 'suppressed_by_user' | 'unregistered_origin' | 'unknown_reason';
110
- isSkippedMoment(): boolean;
117
+ /** @deprecated */
111
118
  getSkippedReason(): 'auto_cancel' | 'user_cancel' | 'tap_outside' | 'issuing_failed';
119
+ isSkippedMoment(): boolean;
112
120
  isDismissedMoment(): boolean;
113
121
  getDismissedReason(): 'credential_returned' | 'cancel_called' | 'flow_restarted';
114
122
  getMomentType(): 'display' | 'skipped' | 'dismissed';
@@ -144,4 +152,4 @@ interface GoogleAccounts {
144
152
  };
145
153
  }
146
154
 
147
- export type { GoogleAccounts, IdConfiguration };
155
+ export type { CredentialResponse, GoogleAccounts, IdConfiguration, PromptMomentNotification };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@shware/http",
3
- "version": "0.4.3",
3
+ "version": "1.0.1",
4
4
  "private": false,
5
5
  "type": "module",
6
6
  "scripts": {
@@ -40,6 +40,7 @@
40
40
  "devDependencies": {
41
41
  "@types/jest": "^29.5.14",
42
42
  "@types/node": "^24.0.1",
43
+ "@types/react": "^19.1.8",
43
44
  "jest": "^30.0.0",
44
45
  "ts-jest": "^29.4.0",
45
46
  "typescript": "^5.8.3"
@@ -48,8 +49,9 @@
48
49
  "zod": "^3.25.63"
49
50
  },
50
51
  "peerDependencies": {
52
+ "axios": "^1.10.0",
51
53
  "hono": "^4.7.9",
52
- "axios": "^1.10.0"
54
+ "react": "^19.0.0"
53
55
  },
54
56
  "peerDependenciesMeta": {
55
57
  "hono": {
@@ -57,6 +59,9 @@
57
59
  },
58
60
  "axios": {
59
61
  "optional": true
62
+ },
63
+ "react": {
64
+ "optional": true
60
65
  }
61
66
  }
62
67
  }