wexts 2.0.7 → 2.0.8

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 (110) hide show
  1. package/dist/chunk-63MTCWU2.mjs +361 -0
  2. package/dist/chunk-63MTCWU2.mjs.map +1 -0
  3. package/dist/chunk-67IJ6H4J.mjs +44 -0
  4. package/dist/chunk-67IJ6H4J.mjs.map +1 -0
  5. package/dist/chunk-7NSRDJ5C.mjs +1 -0
  6. package/dist/chunk-7NSRDJ5C.mjs.map +1 -0
  7. package/dist/chunk-ASDXAK6G.js +44 -0
  8. package/dist/chunk-ASDXAK6G.js.map +1 -0
  9. package/dist/chunk-CKZ4VSCB.mjs +18 -0
  10. package/dist/chunk-CKZ4VSCB.mjs.map +1 -0
  11. package/dist/chunk-DW6GOKMF.js +57 -0
  12. package/dist/chunk-DW6GOKMF.js.map +1 -0
  13. package/dist/chunk-GKVPGKAH.js +66 -0
  14. package/dist/chunk-GKVPGKAH.js.map +1 -0
  15. package/dist/chunk-HSFLZUJN.mjs +57 -0
  16. package/dist/chunk-HSFLZUJN.mjs.map +1 -0
  17. package/dist/chunk-HU63F22V.js +361 -0
  18. package/dist/chunk-HU63F22V.js.map +1 -0
  19. package/dist/chunk-JMBD6DOP.js +225 -0
  20. package/dist/chunk-JMBD6DOP.js.map +1 -0
  21. package/dist/chunk-K7EIJSYQ.js +1 -0
  22. package/dist/chunk-K7EIJSYQ.js.map +1 -0
  23. package/dist/chunk-OTBYRUBE.mjs +225 -0
  24. package/dist/chunk-OTBYRUBE.mjs.map +1 -0
  25. package/dist/chunk-WMHVXEYQ.mjs +66 -0
  26. package/dist/chunk-WMHVXEYQ.mjs.map +1 -0
  27. package/dist/cli/index.js +146 -25
  28. package/dist/cli/index.js.map +1 -1
  29. package/dist/cli/index.mjs +130 -7
  30. package/dist/cli/index.mjs.map +1 -1
  31. package/dist/client/index.js +2 -2
  32. package/dist/client/index.mjs +2 -2
  33. package/dist/codegen/index.d.mts +1 -0
  34. package/dist/codegen/index.d.ts +1 -0
  35. package/dist/codegen/index.js +13 -0
  36. package/dist/codegen/index.js.map +1 -0
  37. package/dist/codegen/index.mjs +13 -0
  38. package/dist/codegen/index.mjs.map +1 -0
  39. package/dist/dev-server/index.d.mts +1 -0
  40. package/dist/dev-server/index.d.ts +1 -0
  41. package/dist/dev-server/index.js +13 -0
  42. package/dist/dev-server/index.js.map +1 -0
  43. package/dist/dev-server/index.mjs +13 -0
  44. package/dist/dev-server/index.mjs.map +1 -0
  45. package/dist/index-SjUaHgFr.d.mts +75 -0
  46. package/dist/index-SjUaHgFr.d.ts +75 -0
  47. package/dist/index-tFGPFVfQ.d.mts +67 -0
  48. package/dist/index-tFGPFVfQ.d.ts +67 -0
  49. package/dist/index.d.mts +83 -164
  50. package/dist/index.d.ts +83 -164
  51. package/dist/index.js +89 -22
  52. package/dist/index.js.map +1 -1
  53. package/dist/index.mjs +76 -9
  54. package/dist/index.mjs.map +1 -1
  55. package/dist/nest/index.js +2 -2
  56. package/dist/nest/index.mjs +2 -2
  57. package/dist/next/index.d.mts +61 -3
  58. package/dist/next/index.d.ts +61 -3
  59. package/dist/next/index.js +140 -7
  60. package/dist/next/index.js.map +1 -1
  61. package/dist/next/index.mjs +102 -7
  62. package/dist/next/index.mjs.map +1 -1
  63. package/dist/types/index.js +1 -1
  64. package/dist/types/index.mjs +2 -1
  65. package/package.json +1 -1
  66. package/templates/nestjs-api/package-lock.json +5623 -0
  67. package/templates/nestjs-api/package.json +21 -19
  68. package/templates/nestjs-api/prisma/migrations/20251123205437_init/migration.sql +24 -0
  69. package/templates/nestjs-api/prisma/migrations/migration_lock.toml +3 -0
  70. package/templates/nestjs-api/src/auth/auth.controller.ts +5 -5
  71. package/templates/nestjs-api/src/main.ts +1 -1
  72. package/templates/nestjs-api/src/todos/todos.controller.ts +7 -7
  73. package/templates/nestjs-api/src/users/users.controller.ts +3 -3
  74. package/templates/nestjs-api/tsconfig.json +20 -1
  75. package/templates/nextjs-web/app/actions/auth.ts +79 -0
  76. package/templates/nextjs-web/app/dashboard/error.tsx +39 -0
  77. package/templates/nextjs-web/app/dashboard/loading.tsx +14 -0
  78. package/templates/nextjs-web/app/dashboard/page.tsx +2 -172
  79. package/templates/nextjs-web/app/globals.css +80 -15
  80. package/templates/nextjs-web/app/layout.tsx +7 -5
  81. package/templates/nextjs-web/app/login/page.tsx +2 -104
  82. package/templates/nextjs-web/app/page.tsx +1 -1
  83. package/templates/nextjs-web/app/register/page.tsx +2 -127
  84. package/templates/nextjs-web/components/ui/button.tsx +56 -0
  85. package/templates/nextjs-web/components/ui/card.tsx +79 -0
  86. package/templates/nextjs-web/components/ui/input.tsx +25 -0
  87. package/templates/nextjs-web/components/ui/label.tsx +24 -0
  88. package/templates/nextjs-web/features/auth/LoginForm.tsx +140 -0
  89. package/templates/nextjs-web/features/auth/RegisterForm.tsx +159 -0
  90. package/templates/nextjs-web/features/auth/api.ts +35 -0
  91. package/templates/nextjs-web/features/auth/index.ts +3 -0
  92. package/templates/nextjs-web/features/dashboard/DashboardView.tsx +204 -0
  93. package/templates/nextjs-web/features/dashboard/api.ts +9 -0
  94. package/templates/nextjs-web/features/dashboard/components.tsx +74 -0
  95. package/templates/nextjs-web/features/dashboard/index.ts +3 -0
  96. package/templates/nextjs-web/hooks/index.ts +4 -0
  97. package/templates/nextjs-web/lib/api-client.ts +89 -0
  98. package/templates/nextjs-web/lib/axios-global-config.ts +17 -0
  99. package/templates/nextjs-web/lib/utils.ts +6 -0
  100. package/templates/nextjs-web/lib/wexts-client.ts +4 -0
  101. package/templates/nextjs-web/next-env.d.ts +6 -0
  102. package/templates/nextjs-web/next.config.ts +20 -0
  103. package/templates/nextjs-web/package-lock.json +3254 -0
  104. package/templates/nextjs-web/package.json +23 -14
  105. package/templates/nextjs-web/postcss.config.js +6 -0
  106. package/templates/nextjs-web/tailwind.config.ts +55 -1
  107. package/templates/nextjs-web/tsconfig.json +41 -39
  108. package/templates/nestjs-api/.env.example +0 -4
  109. package/templates/nextjs-web/next.config.mjs +0 -4
  110. /package/templates/nextjs-web/{.env.local.example → .env} +0 -0
@@ -1,13 +1,146 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
1
+ "use client";
2
+ "use strict";
3
+ var __create = Object.create;
4
+ var __defProp = Object.defineProperty;
5
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
+ var __getOwnPropNames = Object.getOwnPropertyNames;
7
+ var __getProtoOf = Object.getPrototypeOf;
8
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
9
+ var __export = (target, all) => {
10
+ for (var name in all)
11
+ __defProp(target, name, { get: all[name], enumerable: true });
12
+ };
13
+ var __copyProps = (to, from, except, desc) => {
14
+ if (from && typeof from === "object" || typeof from === "function") {
15
+ for (let key of __getOwnPropNames(from))
16
+ if (!__hasOwnProp.call(to, key) && key !== except)
17
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
18
+ }
19
+ return to;
20
+ };
21
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
22
+ // If the importer is in node compatibility mode or this is not an ESM
23
+ // file that has been converted to a CommonJS file using a Babel-
24
+ // compatible transform (i.e. "__esModule" has not been set), then set
25
+ // "default" to the CommonJS "module.exports" for node compatibility.
26
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
27
+ mod
28
+ ));
29
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
2
30
 
31
+ // src/next/index.ts
32
+ var next_exports = {};
33
+ __export(next_exports, {
34
+ FusionProvider: () => FusionProvider,
35
+ useAuth: () => useAuth,
36
+ useFusion: () => useFusion
37
+ });
38
+ module.exports = __toCommonJS(next_exports);
3
39
 
40
+ // src/next/provider.tsx
41
+ var import_react = __toESM(require("react"));
4
42
 
5
- var _chunkNU2UB242js = require('../chunk-NU2UB242.js');
6
- require('../chunk-MTHKZO55.js');
7
- require('../chunk-PZ5AY32C.js');
43
+ // src/client/fetcher.ts
44
+ var FusionFetcher = class {
45
+ baseUrl;
46
+ constructor(baseUrl = "/api") {
47
+ this.baseUrl = baseUrl;
48
+ }
49
+ async request(method, path, body) {
50
+ const headers = {
51
+ "Content-Type": "application/json"
52
+ };
53
+ if (typeof window !== "undefined") {
54
+ const token = localStorage.getItem("fusion_token");
55
+ if (token) headers["Authorization"] = `Bearer ${token}`;
56
+ }
57
+ const response = await fetch(`${this.baseUrl}${path}`, {
58
+ method,
59
+ headers,
60
+ body: body ? JSON.stringify(body) : void 0
61
+ });
62
+ if (!response.ok) {
63
+ throw new Error(`Fusion API Error: ${response.statusText}`);
64
+ }
65
+ return response.json();
66
+ }
67
+ get(path) {
68
+ return this.request("GET", path);
69
+ }
70
+ post(path, body) {
71
+ return this.request("POST", path, body);
72
+ }
73
+ put(path, body) {
74
+ return this.request("PUT", path, body);
75
+ }
76
+ delete(path) {
77
+ return this.request("DELETE", path);
78
+ }
79
+ };
80
+ var apiFetcher = new FusionFetcher();
8
81
 
82
+ // src/next/provider.tsx
83
+ var FusionContext = (0, import_react.createContext)(null);
84
+ function FusionProvider({ children, baseUrl = "/api" }) {
85
+ const client = import_react.default.useMemo(() => new FusionFetcher(baseUrl), [baseUrl]);
86
+ return /* @__PURE__ */ import_react.default.createElement(FusionContext.Provider, { value: { client } }, children);
87
+ }
88
+ function useFusion() {
89
+ const context = (0, import_react.useContext)(FusionContext);
90
+ if (!context) {
91
+ throw new Error("useFusion must be used within FusionProvider");
92
+ }
93
+ return context;
94
+ }
9
95
 
10
-
11
-
12
- exports.FusionProvider = _chunkNU2UB242js.FusionProvider; exports.useAuth = _chunkNU2UB242js.useAuth; exports.useFusion = _chunkNU2UB242js.useFusion;
96
+ // src/next/useAuth.ts
97
+ var import_react2 = require("react");
98
+ function useAuth() {
99
+ const { client } = useFusion();
100
+ const [user, setUser] = (0, import_react2.useState)(null);
101
+ const [loading, setLoading] = (0, import_react2.useState)(true);
102
+ (0, import_react2.useEffect)(() => {
103
+ const token = localStorage.getItem("fusion_token");
104
+ if (token) {
105
+ loadUser();
106
+ } else {
107
+ setLoading(false);
108
+ }
109
+ }, []);
110
+ const loadUser = async () => {
111
+ try {
112
+ const userData = await client.get("/auth/me");
113
+ setUser(userData);
114
+ } catch (error) {
115
+ localStorage.removeItem("fusion_token");
116
+ } finally {
117
+ setLoading(false);
118
+ }
119
+ };
120
+ const login = async (email, password) => {
121
+ const response = await client.post("/auth/login", {
122
+ email,
123
+ password
124
+ });
125
+ localStorage.setItem("fusion_token", response.token);
126
+ setUser(response.user);
127
+ };
128
+ const logout = async () => {
129
+ localStorage.removeItem("fusion_token");
130
+ setUser(null);
131
+ };
132
+ return {
133
+ user,
134
+ loading,
135
+ login,
136
+ logout,
137
+ isAuthenticated: !!user
138
+ };
139
+ }
140
+ // Annotate the CommonJS export names for ESM import in node:
141
+ 0 && (module.exports = {
142
+ FusionProvider,
143
+ useAuth,
144
+ useFusion
145
+ });
13
146
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["c:\\Users\\ziad\\Desktop\\wexts\\packages\\dist\\next\\index.js"],"names":[],"mappings":"AAAA;AACE;AACA;AACA;AACF,uDAA6B;AAC7B,gCAA6B;AAC7B,gCAA6B;AAC7B;AACE;AACA;AACA;AACF,qJAAC","file":"C:\\Users\\ziad\\Desktop\\wexts\\packages\\dist\\next\\index.js"}
1
+ {"version":3,"sources":["../../src/next/index.ts","../../src/next/provider.tsx","../../src/client/fetcher.ts","../../src/next/useAuth.ts"],"sourcesContent":["export * from './provider';\r\nexport * from './useAuth';\r\n","'use client';\r\n\r\nimport React, { createContext, useContext, ReactNode } from 'react';\r\nimport { FusionFetcher } from '../client/fetcher';\r\n\r\ninterface FusionContextType {\r\n client: FusionFetcher;\r\n}\r\n\r\nconst FusionContext = createContext<FusionContextType | null>(null);\r\n\r\nexport interface FusionProviderProps {\r\n children: ReactNode;\r\n baseUrl?: string;\r\n}\r\n\r\n/**\r\n * FusionProvider - Provides API client to React components\r\n * Usage:\r\n * ```tsx\r\n * <FusionProvider baseUrl=\"/api\">\r\n * <App />\r\n * </FusionProvider>\r\n * ```\r\n */\r\nexport function FusionProvider({ children, baseUrl = '/api' }: FusionProviderProps) {\r\n const client = React.useMemo(() => new FusionFetcher(baseUrl), [baseUrl]);\r\n\r\n return (\r\n <FusionContext.Provider value={{ client }}>\r\n {children}\r\n </FusionContext.Provider>\r\n );\r\n}\r\n\r\n/**\r\n * useFusion hook - Access API client in components\r\n * Usage:\r\n * ```tsx\r\n * const { client } = useFusion();\r\n * const data = await client.get('/users');\r\n * ```\r\n */\r\nexport function useFusion(): FusionContextType {\r\n const context = useContext(FusionContext);\r\n if (!context) {\r\n throw new Error('useFusion must be used within FusionProvider');\r\n }\r\n return context;\r\n}\r\n","// packages/api-client/src/fetcher.ts\r\n\r\nexport class FusionFetcher {\r\n private baseUrl: string;\r\n\r\n constructor(baseUrl: string = '/api') {\r\n this.baseUrl = baseUrl;\r\n }\r\n\r\n private async request<T>(method: string, path: string, body?: any): Promise<T> {\r\n const headers: Record<string, string> = {\r\n 'Content-Type': 'application/json',\r\n };\r\n\r\n // Automatically attach Fusion Token if present\r\n if (typeof window !== 'undefined') {\r\n const token = localStorage.getItem('fusion_token');\r\n if (token) headers['Authorization'] = `Bearer ${token}`;\r\n }\r\n\r\n const response = await fetch(`${this.baseUrl}${path}`, {\r\n method,\r\n headers,\r\n body: body ? JSON.stringify(body) : undefined,\r\n });\r\n\r\n if (!response.ok) {\r\n throw new Error(`Fusion API Error: ${response.statusText}`);\r\n }\r\n\r\n return response.json();\r\n }\r\n\r\n get<T>(path: string) { return this.request<T>('GET', path); }\r\n post<T>(path: string, body: any) { return this.request<T>('POST', path, body); }\r\n put<T>(path: string, body: any) { return this.request<T>('PUT', path, body); }\r\n delete<T>(path: string) { return this.request<T>('DELETE', path); }\r\n}\r\n\r\nexport const apiFetcher = new FusionFetcher();\r\n","'use client';\r\n\r\nimport { useState, useEffect } from 'react';\r\nimport { useFusion } from './provider';\r\n\r\nexport interface AuthUser {\r\n id: string;\r\n email: string;\r\n name?: string;\r\n}\r\n\r\nexport interface UseAuthReturn {\r\n user: AuthUser | null;\r\n loading: boolean;\r\n login: (email: string, password: string) => Promise<void>;\r\n logout: () => Promise<void>;\r\n isAuthenticated: boolean;\r\n}\r\n\r\n/**\r\n * useAuth hook - Authentication state management\r\n * Usage:\r\n * ```tsx\r\n * const { user, login, logout, isAuthenticated } = useAuth();\r\n * ```\r\n */\r\nexport function useAuth(): UseAuthReturn {\r\n const { client } = useFusion();\r\n const [user, setUser] = useState<AuthUser | null>(null);\r\n const [loading, setLoading] = useState(true);\r\n\r\n useEffect(() => {\r\n // Check for existing session\r\n const token = localStorage.getItem('fusion_token');\r\n if (token) {\r\n // Validate token and load user\r\n loadUser();\r\n } else {\r\n setLoading(false);\r\n }\r\n }, []);\r\n\r\n const loadUser = async () => {\r\n try {\r\n const userData = await client.get<AuthUser>('/auth/me');\r\n setUser(userData);\r\n } catch (error) {\r\n localStorage.removeItem('fusion_token');\r\n } finally {\r\n setLoading(false);\r\n }\r\n };\r\n\r\n const login = async (email: string, password: string) => {\r\n const response = await client.post<{ token: string; user: AuthUser }>('/auth/login', {\r\n email,\r\n password,\r\n });\r\n localStorage.setItem('fusion_token', response.token);\r\n setUser(response.user);\r\n };\r\n\r\n const logout = async () => {\r\n localStorage.removeItem('fusion_token');\r\n setUser(null);\r\n };\r\n\r\n return {\r\n user,\r\n loading,\r\n login,\r\n logout,\r\n isAuthenticated: !!user,\r\n };\r\n}\r\n"],"mappings":"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","names":["React","import_react"]}
@@ -1,10 +1,105 @@
1
- import {
2
- FusionProvider,
3
- useAuth,
4
- useFusion
5
- } from "../chunk-RS23R3ZQ.mjs";
6
- import "../chunk-6SVQEGEX.mjs";
7
- import "../chunk-J5LGTIGS.mjs";
1
+ "use client";
2
+
3
+ // src/next/provider.tsx
4
+ import React, { createContext, useContext } from "react";
5
+
6
+ // src/client/fetcher.ts
7
+ var FusionFetcher = class {
8
+ baseUrl;
9
+ constructor(baseUrl = "/api") {
10
+ this.baseUrl = baseUrl;
11
+ }
12
+ async request(method, path, body) {
13
+ const headers = {
14
+ "Content-Type": "application/json"
15
+ };
16
+ if (typeof window !== "undefined") {
17
+ const token = localStorage.getItem("fusion_token");
18
+ if (token) headers["Authorization"] = `Bearer ${token}`;
19
+ }
20
+ const response = await fetch(`${this.baseUrl}${path}`, {
21
+ method,
22
+ headers,
23
+ body: body ? JSON.stringify(body) : void 0
24
+ });
25
+ if (!response.ok) {
26
+ throw new Error(`Fusion API Error: ${response.statusText}`);
27
+ }
28
+ return response.json();
29
+ }
30
+ get(path) {
31
+ return this.request("GET", path);
32
+ }
33
+ post(path, body) {
34
+ return this.request("POST", path, body);
35
+ }
36
+ put(path, body) {
37
+ return this.request("PUT", path, body);
38
+ }
39
+ delete(path) {
40
+ return this.request("DELETE", path);
41
+ }
42
+ };
43
+ var apiFetcher = new FusionFetcher();
44
+
45
+ // src/next/provider.tsx
46
+ var FusionContext = createContext(null);
47
+ function FusionProvider({ children, baseUrl = "/api" }) {
48
+ const client = React.useMemo(() => new FusionFetcher(baseUrl), [baseUrl]);
49
+ return /* @__PURE__ */ React.createElement(FusionContext.Provider, { value: { client } }, children);
50
+ }
51
+ function useFusion() {
52
+ const context = useContext(FusionContext);
53
+ if (!context) {
54
+ throw new Error("useFusion must be used within FusionProvider");
55
+ }
56
+ return context;
57
+ }
58
+
59
+ // src/next/useAuth.ts
60
+ import { useState, useEffect } from "react";
61
+ function useAuth() {
62
+ const { client } = useFusion();
63
+ const [user, setUser] = useState(null);
64
+ const [loading, setLoading] = useState(true);
65
+ useEffect(() => {
66
+ const token = localStorage.getItem("fusion_token");
67
+ if (token) {
68
+ loadUser();
69
+ } else {
70
+ setLoading(false);
71
+ }
72
+ }, []);
73
+ const loadUser = async () => {
74
+ try {
75
+ const userData = await client.get("/auth/me");
76
+ setUser(userData);
77
+ } catch (error) {
78
+ localStorage.removeItem("fusion_token");
79
+ } finally {
80
+ setLoading(false);
81
+ }
82
+ };
83
+ const login = async (email, password) => {
84
+ const response = await client.post("/auth/login", {
85
+ email,
86
+ password
87
+ });
88
+ localStorage.setItem("fusion_token", response.token);
89
+ setUser(response.user);
90
+ };
91
+ const logout = async () => {
92
+ localStorage.removeItem("fusion_token");
93
+ setUser(null);
94
+ };
95
+ return {
96
+ user,
97
+ loading,
98
+ login,
99
+ logout,
100
+ isAuthenticated: !!user
101
+ };
102
+ }
8
103
  export {
9
104
  FusionProvider,
10
105
  useAuth,
@@ -1 +1 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
1
+ {"version":3,"sources":["../../src/next/provider.tsx","../../src/client/fetcher.ts","../../src/next/useAuth.ts"],"sourcesContent":["'use client';\r\n\r\nimport React, { createContext, useContext, ReactNode } from 'react';\r\nimport { FusionFetcher } from '../client/fetcher';\r\n\r\ninterface FusionContextType {\r\n client: FusionFetcher;\r\n}\r\n\r\nconst FusionContext = createContext<FusionContextType | null>(null);\r\n\r\nexport interface FusionProviderProps {\r\n children: ReactNode;\r\n baseUrl?: string;\r\n}\r\n\r\n/**\r\n * FusionProvider - Provides API client to React components\r\n * Usage:\r\n * ```tsx\r\n * <FusionProvider baseUrl=\"/api\">\r\n * <App />\r\n * </FusionProvider>\r\n * ```\r\n */\r\nexport function FusionProvider({ children, baseUrl = '/api' }: FusionProviderProps) {\r\n const client = React.useMemo(() => new FusionFetcher(baseUrl), [baseUrl]);\r\n\r\n return (\r\n <FusionContext.Provider value={{ client }}>\r\n {children}\r\n </FusionContext.Provider>\r\n );\r\n}\r\n\r\n/**\r\n * useFusion hook - Access API client in components\r\n * Usage:\r\n * ```tsx\r\n * const { client } = useFusion();\r\n * const data = await client.get('/users');\r\n * ```\r\n */\r\nexport function useFusion(): FusionContextType {\r\n const context = useContext(FusionContext);\r\n if (!context) {\r\n throw new Error('useFusion must be used within FusionProvider');\r\n }\r\n return context;\r\n}\r\n","// packages/api-client/src/fetcher.ts\r\n\r\nexport class FusionFetcher {\r\n private baseUrl: string;\r\n\r\n constructor(baseUrl: string = '/api') {\r\n this.baseUrl = baseUrl;\r\n }\r\n\r\n private async request<T>(method: string, path: string, body?: any): Promise<T> {\r\n const headers: Record<string, string> = {\r\n 'Content-Type': 'application/json',\r\n };\r\n\r\n // Automatically attach Fusion Token if present\r\n if (typeof window !== 'undefined') {\r\n const token = localStorage.getItem('fusion_token');\r\n if (token) headers['Authorization'] = `Bearer ${token}`;\r\n }\r\n\r\n const response = await fetch(`${this.baseUrl}${path}`, {\r\n method,\r\n headers,\r\n body: body ? JSON.stringify(body) : undefined,\r\n });\r\n\r\n if (!response.ok) {\r\n throw new Error(`Fusion API Error: ${response.statusText}`);\r\n }\r\n\r\n return response.json();\r\n }\r\n\r\n get<T>(path: string) { return this.request<T>('GET', path); }\r\n post<T>(path: string, body: any) { return this.request<T>('POST', path, body); }\r\n put<T>(path: string, body: any) { return this.request<T>('PUT', path, body); }\r\n delete<T>(path: string) { return this.request<T>('DELETE', path); }\r\n}\r\n\r\nexport const apiFetcher = new FusionFetcher();\r\n","'use client';\r\n\r\nimport { useState, useEffect } from 'react';\r\nimport { useFusion } from './provider';\r\n\r\nexport interface AuthUser {\r\n id: string;\r\n email: string;\r\n name?: string;\r\n}\r\n\r\nexport interface UseAuthReturn {\r\n user: AuthUser | null;\r\n loading: boolean;\r\n login: (email: string, password: string) => Promise<void>;\r\n logout: () => Promise<void>;\r\n isAuthenticated: boolean;\r\n}\r\n\r\n/**\r\n * useAuth hook - Authentication state management\r\n * Usage:\r\n * ```tsx\r\n * const { user, login, logout, isAuthenticated } = useAuth();\r\n * ```\r\n */\r\nexport function useAuth(): UseAuthReturn {\r\n const { client } = useFusion();\r\n const [user, setUser] = useState<AuthUser | null>(null);\r\n const [loading, setLoading] = useState(true);\r\n\r\n useEffect(() => {\r\n // Check for existing session\r\n const token = localStorage.getItem('fusion_token');\r\n if (token) {\r\n // Validate token and load user\r\n loadUser();\r\n } else {\r\n setLoading(false);\r\n }\r\n }, []);\r\n\r\n const loadUser = async () => {\r\n try {\r\n const userData = await client.get<AuthUser>('/auth/me');\r\n setUser(userData);\r\n } catch (error) {\r\n localStorage.removeItem('fusion_token');\r\n } finally {\r\n setLoading(false);\r\n }\r\n };\r\n\r\n const login = async (email: string, password: string) => {\r\n const response = await client.post<{ token: string; user: AuthUser }>('/auth/login', {\r\n email,\r\n password,\r\n });\r\n localStorage.setItem('fusion_token', response.token);\r\n setUser(response.user);\r\n };\r\n\r\n const logout = async () => {\r\n localStorage.removeItem('fusion_token');\r\n setUser(null);\r\n };\r\n\r\n return {\r\n user,\r\n loading,\r\n login,\r\n logout,\r\n isAuthenticated: !!user,\r\n };\r\n}\r\n"],"mappings":";;;AAEA,OAAO,SAAS,eAAe,kBAA6B;;;ACArD,IAAM,gBAAN,MAAoB;AAAA,EACf;AAAA,EAER,YAAY,UAAkB,QAAQ;AAClC,SAAK,UAAU;AAAA,EACnB;AAAA,EAEA,MAAc,QAAW,QAAgB,MAAc,MAAwB;AAC3E,UAAM,UAAkC;AAAA,MACpC,gBAAgB;AAAA,IACpB;AAGA,QAAI,OAAO,WAAW,aAAa;AAC/B,YAAM,QAAQ,aAAa,QAAQ,cAAc;AACjD,UAAI,MAAO,SAAQ,eAAe,IAAI,UAAU,KAAK;AAAA,IACzD;AAEA,UAAM,WAAW,MAAM,MAAM,GAAG,KAAK,OAAO,GAAG,IAAI,IAAI;AAAA,MACnD;AAAA,MACA;AAAA,MACA,MAAM,OAAO,KAAK,UAAU,IAAI,IAAI;AAAA,IACxC,CAAC;AAED,QAAI,CAAC,SAAS,IAAI;AACd,YAAM,IAAI,MAAM,qBAAqB,SAAS,UAAU,EAAE;AAAA,IAC9D;AAEA,WAAO,SAAS,KAAK;AAAA,EACzB;AAAA,EAEA,IAAO,MAAc;AAAE,WAAO,KAAK,QAAW,OAAO,IAAI;AAAA,EAAG;AAAA,EAC5D,KAAQ,MAAc,MAAW;AAAE,WAAO,KAAK,QAAW,QAAQ,MAAM,IAAI;AAAA,EAAG;AAAA,EAC/E,IAAO,MAAc,MAAW;AAAE,WAAO,KAAK,QAAW,OAAO,MAAM,IAAI;AAAA,EAAG;AAAA,EAC7E,OAAU,MAAc;AAAE,WAAO,KAAK,QAAW,UAAU,IAAI;AAAA,EAAG;AACtE;AAEO,IAAM,aAAa,IAAI,cAAc;;;AD9B5C,IAAM,gBAAgB,cAAwC,IAAI;AAgB3D,SAAS,eAAe,EAAE,UAAU,UAAU,OAAO,GAAwB;AAChF,QAAM,SAAS,MAAM,QAAQ,MAAM,IAAI,cAAc,OAAO,GAAG,CAAC,OAAO,CAAC;AAExE,SACI,oCAAC,cAAc,UAAd,EAAuB,OAAO,EAAE,OAAO,KACnC,QACL;AAER;AAUO,SAAS,YAA+B;AAC3C,QAAM,UAAU,WAAW,aAAa;AACxC,MAAI,CAAC,SAAS;AACV,UAAM,IAAI,MAAM,8CAA8C;AAAA,EAClE;AACA,SAAO;AACX;;;AE/CA,SAAS,UAAU,iBAAiB;AAwB7B,SAAS,UAAyB;AACrC,QAAM,EAAE,OAAO,IAAI,UAAU;AAC7B,QAAM,CAAC,MAAM,OAAO,IAAI,SAA0B,IAAI;AACtD,QAAM,CAAC,SAAS,UAAU,IAAI,SAAS,IAAI;AAE3C,YAAU,MAAM;AAEZ,UAAM,QAAQ,aAAa,QAAQ,cAAc;AACjD,QAAI,OAAO;AAEP,eAAS;AAAA,IACb,OAAO;AACH,iBAAW,KAAK;AAAA,IACpB;AAAA,EACJ,GAAG,CAAC,CAAC;AAEL,QAAM,WAAW,YAAY;AACzB,QAAI;AACA,YAAM,WAAW,MAAM,OAAO,IAAc,UAAU;AACtD,cAAQ,QAAQ;AAAA,IACpB,SAAS,OAAO;AACZ,mBAAa,WAAW,cAAc;AAAA,IAC1C,UAAE;AACE,iBAAW,KAAK;AAAA,IACpB;AAAA,EACJ;AAEA,QAAM,QAAQ,OAAO,OAAe,aAAqB;AACrD,UAAM,WAAW,MAAM,OAAO,KAAwC,eAAe;AAAA,MACjF;AAAA,MACA;AAAA,IACJ,CAAC;AACD,iBAAa,QAAQ,gBAAgB,SAAS,KAAK;AACnD,YAAQ,SAAS,IAAI;AAAA,EACzB;AAEA,QAAM,SAAS,YAAY;AACvB,iBAAa,WAAW,cAAc;AACtC,YAAQ,IAAI;AAAA,EAChB;AAEA,SAAO;AAAA,IACH;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,iBAAiB,CAAC,CAAC;AAAA,EACvB;AACJ;","names":[]}
@@ -1,2 +1,2 @@
1
- "use strict";require('../chunk-2MCBBWEA.js');
1
+ "use strict";require('../chunk-K7EIJSYQ.js');
2
2
  //# sourceMappingURL=index.js.map
@@ -1,2 +1,3 @@
1
- import "../chunk-EFZPSZWO.mjs";
1
+ import "../chunk-7NSRDJ5C.mjs";
2
+ import "../chunk-CKZ4VSCB.mjs";
2
3
  //# sourceMappingURL=index.mjs.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "wexts",
3
- "version": "2.0.7",
3
+ "version": "2.0.8",
4
4
  "description": "Modern full-stack framework combining NestJS 11 and Next.js 16",
5
5
  "main": "./dist/index.js",
6
6
  "module": "./dist/index.mjs",