@dudousxd/adonis-authkit-react 0.1.2 → 0.2.0

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.
Files changed (38) hide show
  1. package/README.md +26 -0
  2. package/build/index.d.ts +31 -0
  3. package/build/index.js +16 -0
  4. package/build/src/authkit_provider.d.ts +13 -0
  5. package/build/src/authkit_provider.js +11 -0
  6. package/build/src/components/authorized_apps.d.ts +8 -0
  7. package/build/src/components/authorized_apps.js +26 -0
  8. package/build/src/components/avatar.d.ts +22 -0
  9. package/build/src/components/avatar.js +15 -0
  10. package/build/src/components/sign_in_button.d.ts +297 -0
  11. package/build/src/components/sign_in_button.js +16 -0
  12. package/build/src/components/sign_out_button.d.ts +296 -0
  13. package/build/src/components/sign_out_button.js +16 -0
  14. package/build/src/components/user_button.d.ts +8 -0
  15. package/build/src/components/user_button.js +31 -0
  16. package/build/src/components/user_profile.d.ts +6 -0
  17. package/build/src/components/user_profile.js +27 -0
  18. package/build/src/config.d.ts +25 -0
  19. package/build/src/config.js +36 -0
  20. package/build/src/hooks/use_authorized_apps.d.ts +16 -0
  21. package/build/src/hooks/use_authorized_apps.js +15 -0
  22. package/build/src/hooks/use_profile.d.ts +13 -0
  23. package/build/src/hooks/use_profile.js +28 -0
  24. package/build/src/hooks/use_resource.d.ts +11 -0
  25. package/build/src/hooks/use_resource.js +48 -0
  26. package/build/src/hooks/use_sessions.d.ts +16 -0
  27. package/build/src/hooks/use_sessions.js +15 -0
  28. package/build/src/hooks/use_sign_in.d.ts +6 -0
  29. package/build/src/hooks/use_sign_in.js +13 -0
  30. package/build/src/hooks/use_sign_out.d.ts +6 -0
  31. package/build/src/hooks/use_sign_out.js +11 -0
  32. package/build/src/hooks/use_user.d.ts +6 -0
  33. package/build/src/hooks/use_user.js +5 -0
  34. package/build/src/use_auth.js +1 -1
  35. package/build/src/utils.d.ts +2 -0
  36. package/build/src/utils.js +18 -0
  37. package/package.json +5 -3
  38. package/styles.css +189 -0
package/README.md CHANGED
@@ -108,6 +108,32 @@ import { AuthProvider } from '@dudousxd/adonis-authkit-react'
108
108
  </AuthProvider>
109
109
  ```
110
110
 
111
+ ## 5. Config + componentes prontos
112
+
113
+ Envolva a app com `<AuthkitProvider>` para configurar URLs/endpoints e use os
114
+ hooks headless e componentes prontos:
115
+
116
+ ```tsx
117
+ import '@dudousxd/adonis-authkit-react/styles.css'
118
+ import {
119
+ AuthkitProvider,
120
+ useSignIn, useSignOut, useUser, useProfile, useSessions, useAuthorizedApps,
121
+ SignInButton, SignOutButton, UserButton, UserProfile, AuthorizedApps,
122
+ } from '@dudousxd/adonis-authkit-react'
123
+
124
+ <AuthkitProvider config={{ csrfToken: page.props.csrfToken }}>
125
+ <UserButton />
126
+ <UserProfile />
127
+ <AuthorizedApps />
128
+ </AuthkitProvider>
129
+ ```
130
+
131
+ Defaults dos endpoints apontam para as rotas reais do host-kit
132
+ (`/auth/login`, `/account/logout`, `/account/security`, `/account/security/profile`,
133
+ `/account/apps`, …). Numa topologia de *client app*, aponte-os para rotas locais que
134
+ redirecionam para o IdP. Temável via CSS vars `--authkit-*`. Veja a
135
+ [doc de React](https://...) para detalhes.
136
+
111
137
  ## Helpers puros
112
138
 
113
139
  Para uso fora de componentes, as funções de papéis são exportadas e livres de React:
package/build/index.d.ts CHANGED
@@ -1,9 +1,40 @@
1
1
  export { useAuth } from './src/use_auth.js';
2
2
  export { AuthProvider, AuthContext } from './src/provider.js';
3
3
  export type { AuthProviderProps } from './src/provider.js';
4
+ export { AuthkitProvider } from './src/authkit_provider.js';
5
+ export type { AuthkitProviderProps } from './src/authkit_provider.js';
6
+ export { AuthkitConfigContext, useAuthkitConfig, resolveConfig, buildAuthUrl, DEFAULT_CONFIG, } from './src/config.js';
7
+ export type { AuthkitConfig, ResolvedAuthkitConfig, AuthkitEndpoints, } from './src/config.js';
8
+ export { useSignIn } from './src/hooks/use_sign_in.js';
9
+ export type { SignInOptions } from './src/hooks/use_sign_in.js';
10
+ export { useSignOut } from './src/hooks/use_sign_out.js';
11
+ export type { SignOutOptions } from './src/hooks/use_sign_out.js';
12
+ export { useUser } from './src/hooks/use_user.js';
13
+ export type { UseUserResult } from './src/hooks/use_user.js';
14
+ export { useProfile } from './src/hooks/use_profile.js';
15
+ export type { UseProfileResult, ProfileUpdate } from './src/hooks/use_profile.js';
16
+ export { useSessions } from './src/hooks/use_sessions.js';
17
+ export type { UseSessionsResult, AuthSession } from './src/hooks/use_sessions.js';
18
+ export { useAuthorizedApps } from './src/hooks/use_authorized_apps.js';
19
+ export type { UseAuthorizedAppsResult, AuthorizedApp } from './src/hooks/use_authorized_apps.js';
20
+ export { jsonRequest, useResource } from './src/hooks/use_resource.js';
21
+ export type { ResourceState } from './src/hooks/use_resource.js';
22
+ export { deriveInitials, currentUrl } from './src/utils.js';
4
23
  export { Authenticated, Guest } from './src/components/authenticated.js';
5
24
  export type { AuthenticatedProps, GuestProps } from './src/components/authenticated.js';
6
25
  export { Can } from './src/components/can.js';
7
26
  export type { CanProps } from './src/components/can.js';
27
+ export { SignInButton } from './src/components/sign_in_button.js';
28
+ export type { SignInButtonProps } from './src/components/sign_in_button.js';
29
+ export { SignOutButton } from './src/components/sign_out_button.js';
30
+ export type { SignOutButtonProps } from './src/components/sign_out_button.js';
31
+ export { Avatar } from './src/components/avatar.js';
32
+ export type { AvatarProps } from './src/components/avatar.js';
33
+ export { UserButton } from './src/components/user_button.js';
34
+ export type { UserButtonProps } from './src/components/user_button.js';
35
+ export { UserProfile } from './src/components/user_profile.js';
36
+ export type { UserProfileProps } from './src/components/user_profile.js';
37
+ export { AuthorizedApps } from './src/components/authorized_apps.js';
38
+ export type { AuthorizedAppsProps } from './src/components/authorized_apps.js';
8
39
  export { hasGlobalRole, hasAnyGlobalRole, hasAllGlobalRoles, hasAppRole, hasAnyAppRole, hasAllAppRoles, } from './src/roles.js';
9
40
  export type { AuthUser, AuthSharedProps, AuthState } from './src/types.js';
package/build/index.js CHANGED
@@ -1,5 +1,21 @@
1
1
  export { useAuth } from './src/use_auth.js';
2
2
  export { AuthProvider, AuthContext } from './src/provider.js';
3
+ export { AuthkitProvider } from './src/authkit_provider.js';
4
+ export { AuthkitConfigContext, useAuthkitConfig, resolveConfig, buildAuthUrl, DEFAULT_CONFIG, } from './src/config.js';
5
+ export { useSignIn } from './src/hooks/use_sign_in.js';
6
+ export { useSignOut } from './src/hooks/use_sign_out.js';
7
+ export { useUser } from './src/hooks/use_user.js';
8
+ export { useProfile } from './src/hooks/use_profile.js';
9
+ export { useSessions } from './src/hooks/use_sessions.js';
10
+ export { useAuthorizedApps } from './src/hooks/use_authorized_apps.js';
11
+ export { jsonRequest, useResource } from './src/hooks/use_resource.js';
12
+ export { deriveInitials, currentUrl } from './src/utils.js';
3
13
  export { Authenticated, Guest } from './src/components/authenticated.js';
4
14
  export { Can } from './src/components/can.js';
15
+ export { SignInButton } from './src/components/sign_in_button.js';
16
+ export { SignOutButton } from './src/components/sign_out_button.js';
17
+ export { Avatar } from './src/components/avatar.js';
18
+ export { UserButton } from './src/components/user_button.js';
19
+ export { UserProfile } from './src/components/user_profile.js';
20
+ export { AuthorizedApps } from './src/components/authorized_apps.js';
5
21
  export { hasGlobalRole, hasAnyGlobalRole, hasAllGlobalRoles, hasAppRole, hasAnyAppRole, hasAllAppRoles, } from './src/roles.js';
@@ -0,0 +1,13 @@
1
+ import { type ReactNode } from 'react';
2
+ import { type AuthkitConfig } from './config.js';
3
+ import type { AuthSharedProps } from './types.js';
4
+ export interface AuthkitProviderProps {
5
+ config?: AuthkitConfig;
6
+ value?: AuthSharedProps['authkit'];
7
+ children: ReactNode;
8
+ }
9
+ export declare function AuthkitProvider({ config, value, children }: AuthkitProviderProps): import("react").FunctionComponentElement<import("react").ProviderProps<{
10
+ user: import("./types.js").AuthUser | null;
11
+ globalRoles: string[];
12
+ appRoles?: string[];
13
+ } | undefined>> | import("react").FunctionComponentElement<import("react").ProviderProps<import("./config.js").ResolvedAuthkitConfig>>;
@@ -0,0 +1,11 @@
1
+ import { createElement } from 'react';
2
+ import { AuthContext } from './provider.js';
3
+ import { AuthkitConfigContext, resolveConfig } from './config.js';
4
+ export function AuthkitProvider({ config, value, children }) {
5
+ const resolved = resolveConfig(config);
6
+ const tree = createElement(AuthkitConfigContext.Provider, { value: resolved }, children);
7
+ if (value !== undefined) {
8
+ return createElement(AuthContext.Provider, { value }, tree);
9
+ }
10
+ return tree;
11
+ }
@@ -0,0 +1,8 @@
1
+ export interface AuthorizedAppsProps {
2
+ className?: string;
3
+ revokeLabel?: string;
4
+ emptyLabel?: string;
5
+ }
6
+ export declare function AuthorizedApps({ className, revokeLabel, emptyLabel, }: AuthorizedAppsProps): import("react").DetailedReactHTMLElement<{
7
+ className: string;
8
+ }, HTMLElement>;
@@ -0,0 +1,26 @@
1
+ import { createElement } from 'react';
2
+ import { useAuthorizedApps } from '../hooks/use_authorized_apps.js';
3
+ export function AuthorizedApps({ className, revokeLabel = 'Revogar', emptyLabel = 'Nenhum app autorizado.', }) {
4
+ const { data, loading, error, actions } = useAuthorizedApps();
5
+ if (loading && !data) {
6
+ return createElement('div', { className: 'authkit-apps__loading' }, 'Carregando…');
7
+ }
8
+ if (error) {
9
+ return createElement('p', { className: 'authkit-error', role: 'alert' }, error.message);
10
+ }
11
+ const apps = data ?? [];
12
+ if (apps.length === 0) {
13
+ return createElement('p', { className: 'authkit-apps__empty' }, emptyLabel);
14
+ }
15
+ return createElement('ul', { className: ['authkit-apps', className].filter(Boolean).join(' ') }, ...apps.map((app) => createElement('li', { key: app.clientId, className: 'authkit-apps__item' }, createElement('div', { className: 'authkit-apps__info' }, app.logoUrl
16
+ ? createElement('img', {
17
+ className: 'authkit-apps__logo',
18
+ src: app.logoUrl,
19
+ alt: '',
20
+ })
21
+ : null, createElement('span', { className: 'authkit-apps__name' }, app.name ?? app.clientId)), createElement('button', {
22
+ type: 'button',
23
+ className: 'authkit-button authkit-button--danger',
24
+ onClick: () => void actions.revoke(app.clientId),
25
+ }, revokeLabel))));
26
+ }
@@ -0,0 +1,22 @@
1
+ import type { AuthUser } from '../types.js';
2
+ export interface AvatarProps {
3
+ user: Pick<AuthUser, 'name' | 'email' | 'avatarUrl'>;
4
+ size?: number;
5
+ className?: string;
6
+ }
7
+ export declare function Avatar({ user, size, className }: AvatarProps): import("react").DetailedReactHTMLElement<{
8
+ className: string;
9
+ src: string;
10
+ alt: string;
11
+ style: {
12
+ width: number;
13
+ height: number;
14
+ };
15
+ }, HTMLElement> | import("react").DetailedReactHTMLElement<{
16
+ className: string;
17
+ style: {
18
+ width: number;
19
+ height: number;
20
+ };
21
+ 'aria-hidden': true;
22
+ }, HTMLElement>;
@@ -0,0 +1,15 @@
1
+ import { createElement } from 'react';
2
+ import { deriveInitials } from '../utils.js';
3
+ export function Avatar({ user, size = 36, className }) {
4
+ const cls = ['authkit-avatar', className].filter(Boolean).join(' ');
5
+ const style = { width: size, height: size };
6
+ if (user.avatarUrl) {
7
+ return createElement('img', {
8
+ className: cls,
9
+ src: user.avatarUrl,
10
+ alt: user.name ?? user.email ?? '',
11
+ style,
12
+ });
13
+ }
14
+ return createElement('span', { className: cls, style, 'aria-hidden': true }, deriveInitials(user.name, user.email));
15
+ }
@@ -0,0 +1,297 @@
1
+ import { type ButtonHTMLAttributes, type ReactNode } from 'react';
2
+ export interface SignInButtonProps extends Omit<ButtonHTMLAttributes<HTMLButtonElement>, 'onClick'> {
3
+ children?: ReactNode;
4
+ returnTo?: string;
5
+ showWhenAuthenticated?: boolean;
6
+ }
7
+ export declare function SignInButton({ children, returnTo, showWhenAuthenticated, className, ...rest }: SignInButtonProps): import("react").DetailedReactHTMLElement<{
8
+ id?: string | undefined | undefined;
9
+ name?: string | undefined | undefined;
10
+ value?: string | number | readonly string[] | undefined;
11
+ form?: string | undefined | undefined;
12
+ slot?: string | undefined | undefined;
13
+ style?: import("react").CSSProperties | undefined;
14
+ title?: string | undefined | undefined;
15
+ role?: import("react").AriaRole | undefined;
16
+ disabled?: boolean | undefined | undefined;
17
+ formAction?: string | ((formData: FormData) => void | Promise<void>) | undefined;
18
+ formEncType?: string | undefined | undefined;
19
+ formMethod?: string | undefined | undefined;
20
+ formNoValidate?: boolean | undefined | undefined;
21
+ formTarget?: string | undefined | undefined;
22
+ type: string;
23
+ defaultChecked?: boolean | undefined | undefined;
24
+ defaultValue?: string | number | readonly string[] | undefined;
25
+ suppressContentEditableWarning?: boolean | undefined | undefined;
26
+ suppressHydrationWarning?: boolean | undefined | undefined;
27
+ accessKey?: string | undefined | undefined;
28
+ autoCapitalize?: "off" | "none" | "on" | "sentences" | "words" | "characters" | undefined | (string & {}) | undefined;
29
+ autoFocus?: boolean | undefined | undefined;
30
+ contentEditable?: (boolean | "true" | "false") | "inherit" | "plaintext-only" | undefined;
31
+ contextMenu?: string | undefined | undefined;
32
+ dir?: string | undefined | undefined;
33
+ draggable?: (boolean | "true" | "false") | undefined;
34
+ enterKeyHint?: "enter" | "done" | "go" | "next" | "previous" | "search" | "send" | undefined | undefined;
35
+ hidden?: boolean | undefined | undefined;
36
+ lang?: string | undefined | undefined;
37
+ nonce?: string | undefined | undefined;
38
+ spellCheck?: (boolean | "true" | "false") | undefined;
39
+ tabIndex?: number | undefined | undefined;
40
+ translate?: "yes" | "no" | undefined | undefined;
41
+ radioGroup?: string | undefined | undefined;
42
+ about?: string | undefined | undefined;
43
+ content?: string | undefined | undefined;
44
+ datatype?: string | undefined | undefined;
45
+ inlist?: any;
46
+ prefix?: string | undefined | undefined;
47
+ property?: string | undefined | undefined;
48
+ rel?: string | undefined | undefined;
49
+ resource?: string | undefined | undefined;
50
+ rev?: string | undefined | undefined;
51
+ typeof?: string | undefined | undefined;
52
+ vocab?: string | undefined | undefined;
53
+ autoCorrect?: string | undefined | undefined;
54
+ autoSave?: string | undefined | undefined;
55
+ color?: string | undefined | undefined;
56
+ itemProp?: string | undefined | undefined;
57
+ itemScope?: boolean | undefined | undefined;
58
+ itemType?: string | undefined | undefined;
59
+ itemID?: string | undefined | undefined;
60
+ itemRef?: string | undefined | undefined;
61
+ results?: number | undefined | undefined;
62
+ security?: string | undefined | undefined;
63
+ unselectable?: "on" | "off" | undefined | undefined;
64
+ popover?: "" | "auto" | "manual" | "hint" | undefined | undefined;
65
+ popoverTargetAction?: "toggle" | "show" | "hide" | undefined | undefined;
66
+ popoverTarget?: string | undefined | undefined;
67
+ inert?: boolean | undefined | undefined;
68
+ inputMode?: "none" | "text" | "tel" | "url" | "email" | "numeric" | "decimal" | "search" | undefined | undefined;
69
+ is?: string | undefined | undefined;
70
+ exportparts?: string | undefined | undefined;
71
+ part?: string | undefined | undefined;
72
+ "aria-activedescendant"?: string | undefined | undefined;
73
+ "aria-atomic"?: (boolean | "true" | "false") | undefined;
74
+ "aria-autocomplete"?: "none" | "inline" | "list" | "both" | undefined | undefined;
75
+ "aria-braillelabel"?: string | undefined | undefined;
76
+ "aria-brailleroledescription"?: string | undefined | undefined;
77
+ "aria-busy"?: (boolean | "true" | "false") | undefined;
78
+ "aria-checked"?: boolean | "false" | "mixed" | "true" | undefined | undefined;
79
+ "aria-colcount"?: number | undefined | undefined;
80
+ "aria-colindex"?: number | undefined | undefined;
81
+ "aria-colindextext"?: string | undefined | undefined;
82
+ "aria-colspan"?: number | undefined | undefined;
83
+ "aria-controls"?: string | undefined | undefined;
84
+ "aria-current"?: boolean | "false" | "true" | "page" | "step" | "location" | "date" | "time" | undefined | undefined;
85
+ "aria-describedby"?: string | undefined | undefined;
86
+ "aria-description"?: string | undefined | undefined;
87
+ "aria-details"?: string | undefined | undefined;
88
+ "aria-disabled"?: (boolean | "true" | "false") | undefined;
89
+ "aria-dropeffect"?: "none" | "copy" | "execute" | "link" | "move" | "popup" | undefined | undefined;
90
+ "aria-errormessage"?: string | undefined | undefined;
91
+ "aria-expanded"?: (boolean | "true" | "false") | undefined;
92
+ "aria-flowto"?: string | undefined | undefined;
93
+ "aria-grabbed"?: (boolean | "true" | "false") | undefined;
94
+ "aria-haspopup"?: boolean | "false" | "true" | "menu" | "listbox" | "tree" | "grid" | "dialog" | undefined | undefined;
95
+ "aria-hidden"?: (boolean | "true" | "false") | undefined;
96
+ "aria-invalid"?: boolean | "false" | "true" | "grammar" | "spelling" | undefined | undefined;
97
+ "aria-keyshortcuts"?: string | undefined | undefined;
98
+ "aria-label"?: string | undefined | undefined;
99
+ "aria-labelledby"?: string | undefined | undefined;
100
+ "aria-level"?: number | undefined | undefined;
101
+ "aria-live"?: "off" | "assertive" | "polite" | undefined | undefined;
102
+ "aria-modal"?: (boolean | "true" | "false") | undefined;
103
+ "aria-multiline"?: (boolean | "true" | "false") | undefined;
104
+ "aria-multiselectable"?: (boolean | "true" | "false") | undefined;
105
+ "aria-orientation"?: "horizontal" | "vertical" | undefined | undefined;
106
+ "aria-owns"?: string | undefined | undefined;
107
+ "aria-placeholder"?: string | undefined | undefined;
108
+ "aria-posinset"?: number | undefined | undefined;
109
+ "aria-pressed"?: boolean | "false" | "mixed" | "true" | undefined | undefined;
110
+ "aria-readonly"?: (boolean | "true" | "false") | undefined;
111
+ "aria-relevant"?: "additions" | "additions removals" | "additions text" | "all" | "removals" | "removals additions" | "removals text" | "text" | "text additions" | "text removals" | undefined | undefined;
112
+ "aria-required"?: (boolean | "true" | "false") | undefined;
113
+ "aria-roledescription"?: string | undefined | undefined;
114
+ "aria-rowcount"?: number | undefined | undefined;
115
+ "aria-rowindex"?: number | undefined | undefined;
116
+ "aria-rowindextext"?: string | undefined | undefined;
117
+ "aria-rowspan"?: number | undefined | undefined;
118
+ "aria-selected"?: (boolean | "true" | "false") | undefined;
119
+ "aria-setsize"?: number | undefined | undefined;
120
+ "aria-sort"?: "none" | "ascending" | "descending" | "other" | undefined | undefined;
121
+ "aria-valuemax"?: number | undefined | undefined;
122
+ "aria-valuemin"?: number | undefined | undefined;
123
+ "aria-valuenow"?: number | undefined | undefined;
124
+ "aria-valuetext"?: string | undefined | undefined;
125
+ dangerouslySetInnerHTML?: {
126
+ __html: string | TrustedHTML;
127
+ } | undefined | undefined;
128
+ onCopy?: import("react").ClipboardEventHandler<HTMLButtonElement> | undefined;
129
+ onCopyCapture?: import("react").ClipboardEventHandler<HTMLButtonElement> | undefined;
130
+ onCut?: import("react").ClipboardEventHandler<HTMLButtonElement> | undefined;
131
+ onCutCapture?: import("react").ClipboardEventHandler<HTMLButtonElement> | undefined;
132
+ onPaste?: import("react").ClipboardEventHandler<HTMLButtonElement> | undefined;
133
+ onPasteCapture?: import("react").ClipboardEventHandler<HTMLButtonElement> | undefined;
134
+ onCompositionEnd?: import("react").CompositionEventHandler<HTMLButtonElement> | undefined;
135
+ onCompositionEndCapture?: import("react").CompositionEventHandler<HTMLButtonElement> | undefined;
136
+ onCompositionStart?: import("react").CompositionEventHandler<HTMLButtonElement> | undefined;
137
+ onCompositionStartCapture?: import("react").CompositionEventHandler<HTMLButtonElement> | undefined;
138
+ onCompositionUpdate?: import("react").CompositionEventHandler<HTMLButtonElement> | undefined;
139
+ onCompositionUpdateCapture?: import("react").CompositionEventHandler<HTMLButtonElement> | undefined;
140
+ onFocus?: import("react").FocusEventHandler<HTMLButtonElement> | undefined;
141
+ onFocusCapture?: import("react").FocusEventHandler<HTMLButtonElement> | undefined;
142
+ onBlur?: import("react").FocusEventHandler<HTMLButtonElement> | undefined;
143
+ onBlurCapture?: import("react").FocusEventHandler<HTMLButtonElement> | undefined;
144
+ onChange?: import("react").ChangeEventHandler<HTMLButtonElement, Element> | undefined;
145
+ onChangeCapture?: import("react").ChangeEventHandler<HTMLButtonElement, Element> | undefined;
146
+ onBeforeInput?: import("react").InputEventHandler<HTMLButtonElement> | undefined;
147
+ onBeforeInputCapture?: import("react").InputEventHandler<HTMLButtonElement> | undefined;
148
+ onInput?: import("react").InputEventHandler<HTMLButtonElement> | undefined;
149
+ onInputCapture?: import("react").InputEventHandler<HTMLButtonElement> | undefined;
150
+ onReset?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
151
+ onResetCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
152
+ onSubmit?: import("react").SubmitEventHandler<HTMLButtonElement> | undefined;
153
+ onSubmitCapture?: import("react").SubmitEventHandler<HTMLButtonElement> | undefined;
154
+ onInvalid?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
155
+ onInvalidCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
156
+ onLoad?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
157
+ onLoadCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
158
+ onError?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
159
+ onErrorCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
160
+ onKeyDown?: import("react").KeyboardEventHandler<HTMLButtonElement> | undefined;
161
+ onKeyDownCapture?: import("react").KeyboardEventHandler<HTMLButtonElement> | undefined;
162
+ onKeyPress?: import("react").KeyboardEventHandler<HTMLButtonElement> | undefined;
163
+ onKeyPressCapture?: import("react").KeyboardEventHandler<HTMLButtonElement> | undefined;
164
+ onKeyUp?: import("react").KeyboardEventHandler<HTMLButtonElement> | undefined;
165
+ onKeyUpCapture?: import("react").KeyboardEventHandler<HTMLButtonElement> | undefined;
166
+ onAbort?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
167
+ onAbortCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
168
+ onCanPlay?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
169
+ onCanPlayCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
170
+ onCanPlayThrough?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
171
+ onCanPlayThroughCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
172
+ onDurationChange?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
173
+ onDurationChangeCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
174
+ onEmptied?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
175
+ onEmptiedCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
176
+ onEncrypted?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
177
+ onEncryptedCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
178
+ onEnded?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
179
+ onEndedCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
180
+ onLoadedData?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
181
+ onLoadedDataCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
182
+ onLoadedMetadata?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
183
+ onLoadedMetadataCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
184
+ onLoadStart?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
185
+ onLoadStartCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
186
+ onPause?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
187
+ onPauseCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
188
+ onPlay?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
189
+ onPlayCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
190
+ onPlaying?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
191
+ onPlayingCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
192
+ onProgress?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
193
+ onProgressCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
194
+ onRateChange?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
195
+ onRateChangeCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
196
+ onSeeked?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
197
+ onSeekedCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
198
+ onSeeking?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
199
+ onSeekingCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
200
+ onStalled?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
201
+ onStalledCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
202
+ onSuspend?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
203
+ onSuspendCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
204
+ onTimeUpdate?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
205
+ onTimeUpdateCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
206
+ onVolumeChange?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
207
+ onVolumeChangeCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
208
+ onWaiting?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
209
+ onWaitingCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
210
+ onAuxClick?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
211
+ onAuxClickCapture?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
212
+ onClickCapture?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
213
+ onContextMenu?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
214
+ onContextMenuCapture?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
215
+ onDoubleClick?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
216
+ onDoubleClickCapture?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
217
+ onDrag?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
218
+ onDragCapture?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
219
+ onDragEnd?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
220
+ onDragEndCapture?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
221
+ onDragEnter?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
222
+ onDragEnterCapture?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
223
+ onDragExit?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
224
+ onDragExitCapture?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
225
+ onDragLeave?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
226
+ onDragLeaveCapture?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
227
+ onDragOver?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
228
+ onDragOverCapture?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
229
+ onDragStart?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
230
+ onDragStartCapture?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
231
+ onDrop?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
232
+ onDropCapture?: import("react").DragEventHandler<HTMLButtonElement> | undefined;
233
+ onMouseDown?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
234
+ onMouseDownCapture?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
235
+ onMouseEnter?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
236
+ onMouseLeave?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
237
+ onMouseMove?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
238
+ onMouseMoveCapture?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
239
+ onMouseOut?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
240
+ onMouseOutCapture?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
241
+ onMouseOver?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
242
+ onMouseOverCapture?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
243
+ onMouseUp?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
244
+ onMouseUpCapture?: import("react").MouseEventHandler<HTMLButtonElement> | undefined;
245
+ onSelect?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
246
+ onSelectCapture?: import("react").ReactEventHandler<HTMLButtonElement> | undefined;
247
+ onTouchCancel?: import("react").TouchEventHandler<HTMLButtonElement> | undefined;
248
+ onTouchCancelCapture?: import("react").TouchEventHandler<HTMLButtonElement> | undefined;
249
+ onTouchEnd?: import("react").TouchEventHandler<HTMLButtonElement> | undefined;
250
+ onTouchEndCapture?: import("react").TouchEventHandler<HTMLButtonElement> | undefined;
251
+ onTouchMove?: import("react").TouchEventHandler<HTMLButtonElement> | undefined;
252
+ onTouchMoveCapture?: import("react").TouchEventHandler<HTMLButtonElement> | undefined;
253
+ onTouchStart?: import("react").TouchEventHandler<HTMLButtonElement> | undefined;
254
+ onTouchStartCapture?: import("react").TouchEventHandler<HTMLButtonElement> | undefined;
255
+ onPointerDown?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
256
+ onPointerDownCapture?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
257
+ onPointerMove?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
258
+ onPointerMoveCapture?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
259
+ onPointerUp?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
260
+ onPointerUpCapture?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
261
+ onPointerCancel?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
262
+ onPointerCancelCapture?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
263
+ onPointerEnter?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
264
+ onPointerLeave?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
265
+ onPointerOver?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
266
+ onPointerOverCapture?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
267
+ onPointerOut?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
268
+ onPointerOutCapture?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
269
+ onGotPointerCapture?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
270
+ onGotPointerCaptureCapture?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
271
+ onLostPointerCapture?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
272
+ onLostPointerCaptureCapture?: import("react").PointerEventHandler<HTMLButtonElement> | undefined;
273
+ onScroll?: import("react").UIEventHandler<HTMLButtonElement> | undefined;
274
+ onScrollCapture?: import("react").UIEventHandler<HTMLButtonElement> | undefined;
275
+ onScrollEnd?: import("react").UIEventHandler<HTMLButtonElement> | undefined;
276
+ onScrollEndCapture?: import("react").UIEventHandler<HTMLButtonElement> | undefined;
277
+ onWheel?: import("react").WheelEventHandler<HTMLButtonElement> | undefined;
278
+ onWheelCapture?: import("react").WheelEventHandler<HTMLButtonElement> | undefined;
279
+ onAnimationStart?: import("react").AnimationEventHandler<HTMLButtonElement> | undefined;
280
+ onAnimationStartCapture?: import("react").AnimationEventHandler<HTMLButtonElement> | undefined;
281
+ onAnimationEnd?: import("react").AnimationEventHandler<HTMLButtonElement> | undefined;
282
+ onAnimationEndCapture?: import("react").AnimationEventHandler<HTMLButtonElement> | undefined;
283
+ onAnimationIteration?: import("react").AnimationEventHandler<HTMLButtonElement> | undefined;
284
+ onAnimationIterationCapture?: import("react").AnimationEventHandler<HTMLButtonElement> | undefined;
285
+ onToggle?: import("react").ToggleEventHandler<HTMLButtonElement> | undefined;
286
+ onBeforeToggle?: import("react").ToggleEventHandler<HTMLButtonElement> | undefined;
287
+ onTransitionCancel?: import("react").TransitionEventHandler<HTMLButtonElement> | undefined;
288
+ onTransitionCancelCapture?: import("react").TransitionEventHandler<HTMLButtonElement> | undefined;
289
+ onTransitionEnd?: import("react").TransitionEventHandler<HTMLButtonElement> | undefined;
290
+ onTransitionEndCapture?: import("react").TransitionEventHandler<HTMLButtonElement> | undefined;
291
+ onTransitionRun?: import("react").TransitionEventHandler<HTMLButtonElement> | undefined;
292
+ onTransitionRunCapture?: import("react").TransitionEventHandler<HTMLButtonElement> | undefined;
293
+ onTransitionStart?: import("react").TransitionEventHandler<HTMLButtonElement> | undefined;
294
+ onTransitionStartCapture?: import("react").TransitionEventHandler<HTMLButtonElement> | undefined;
295
+ className: string;
296
+ onClick: () => void;
297
+ }, HTMLElement> | null;
@@ -0,0 +1,16 @@
1
+ import { createElement } from 'react';
2
+ import { useSignIn } from '../hooks/use_sign_in.js';
3
+ import { useAuth } from '../use_auth.js';
4
+ export function SignInButton({ children = 'Entrar', returnTo, showWhenAuthenticated = false, className, ...rest }) {
5
+ const { signIn } = useSignIn();
6
+ const { isAuthenticated } = useAuth();
7
+ if (isAuthenticated && !showWhenAuthenticated)
8
+ return null;
9
+ const opts = returnTo ? { returnTo } : undefined;
10
+ return createElement('button', {
11
+ type: 'button',
12
+ className: ['authkit-button', 'authkit-button--primary', className].filter(Boolean).join(' '),
13
+ onClick: () => signIn(opts),
14
+ ...rest,
15
+ }, children);
16
+ }