@solidstarters/solid-core-ui 1.1.15 → 1.1.17

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 (173) hide show
  1. package/dist/components/auth/AuthLayout.d.ts +4 -0
  2. package/dist/components/auth/AuthLayout.d.ts.map +1 -0
  3. package/dist/components/auth/AuthLayout.js +80 -0
  4. package/dist/components/auth/AuthLayout.js.map +1 -0
  5. package/dist/components/auth/ForgotPasswordThankYou.d.ts +2 -0
  6. package/dist/components/auth/ForgotPasswordThankYou.d.ts.map +1 -0
  7. package/dist/components/auth/ForgotPasswordThankYou.js +16 -0
  8. package/dist/components/auth/ForgotPasswordThankYou.js.map +1 -0
  9. package/dist/components/auth/GoogleAuthChecking.d.ts +2 -0
  10. package/dist/components/auth/GoogleAuthChecking.d.ts.map +1 -0
  11. package/dist/components/auth/GoogleAuthChecking.js +99 -0
  12. package/dist/components/auth/GoogleAuthChecking.js.map +1 -0
  13. package/dist/components/auth/SolidChangeForcePassword.d.ts.map +1 -1
  14. package/dist/components/auth/SolidChangeForcePassword.js +44 -39
  15. package/dist/components/auth/SolidChangeForcePassword.js.map +1 -1
  16. package/dist/components/auth/SolidForgotPassword.d.ts.map +1 -1
  17. package/dist/components/auth/SolidForgotPassword.js +1 -2
  18. package/dist/components/auth/SolidForgotPassword.js.map +1 -1
  19. package/dist/components/auth/SolidInitialLoginOtp.d.ts +1 -3
  20. package/dist/components/auth/SolidInitialLoginOtp.d.ts.map +1 -1
  21. package/dist/components/auth/SolidInitialLoginOtp.js +16 -12
  22. package/dist/components/auth/SolidInitialLoginOtp.js.map +1 -1
  23. package/dist/components/auth/SolidInitiateRegisterOtp.d.ts +1 -3
  24. package/dist/components/auth/SolidInitiateRegisterOtp.d.ts.map +1 -1
  25. package/dist/components/auth/SolidInitiateRegisterOtp.js +16 -12
  26. package/dist/components/auth/SolidInitiateRegisterOtp.js.map +1 -1
  27. package/dist/components/auth/SolidLogin.d.ts.map +1 -1
  28. package/dist/components/auth/SolidLogin.js +12 -8
  29. package/dist/components/auth/SolidLogin.js.map +1 -1
  30. package/dist/components/auth/SolidRegister.d.ts.map +1 -1
  31. package/dist/components/auth/SolidRegister.js +13 -9
  32. package/dist/components/auth/SolidRegister.js.map +1 -1
  33. package/dist/components/auth/SolidResetPassword.d.ts +1 -4
  34. package/dist/components/auth/SolidResetPassword.d.ts.map +1 -1
  35. package/dist/components/auth/SolidResetPassword.js +14 -10
  36. package/dist/components/auth/SolidResetPassword.js.map +1 -1
  37. package/dist/components/common/GeneralSettings.d.ts +1 -3
  38. package/dist/components/common/GeneralSettings.d.ts.map +1 -1
  39. package/dist/components/common/GeneralSettings.js +21 -18
  40. package/dist/components/common/GeneralSettings.js.map +1 -1
  41. package/dist/components/common/NotFound.d.ts +2 -0
  42. package/dist/components/common/NotFound.d.ts.map +1 -0
  43. package/dist/components/common/NotFound.js +7 -0
  44. package/dist/components/common/NotFound.js.map +1 -0
  45. package/dist/components/common/SingleSelectAutoCompleteField.d.ts +1 -1
  46. package/dist/components/common/SingleSelectAutoCompleteField.d.ts.map +1 -1
  47. package/dist/components/common/SingleSelectAutoCompleteField.js +2 -2
  48. package/dist/components/common/SingleSelectAutoCompleteField.js.map +1 -1
  49. package/dist/components/common/SocialMediaLogin.d.ts.map +1 -1
  50. package/dist/components/common/SocialMediaLogin.js +3 -2
  51. package/dist/components/common/SocialMediaLogin.js.map +1 -1
  52. package/dist/components/common/SolidAdmin.d.ts +2 -0
  53. package/dist/components/common/SolidAdmin.d.ts.map +1 -0
  54. package/dist/components/common/SolidAdmin.js +5 -0
  55. package/dist/components/common/SolidAdmin.js.map +1 -0
  56. package/dist/components/common/SolidFormStepper.d.ts.map +1 -1
  57. package/dist/components/common/SolidFormStepper.js +8 -1
  58. package/dist/components/common/SolidFormStepper.js.map +1 -1
  59. package/dist/components/common/SolidThemeLink.d.ts +2 -0
  60. package/dist/components/common/SolidThemeLink.d.ts.map +1 -0
  61. package/dist/components/common/SolidThemeLink.js +5 -0
  62. package/dist/components/common/SolidThemeLink.js.map +1 -0
  63. package/dist/components/common/error.d.ts +9 -0
  64. package/dist/components/common/error.d.ts.map +1 -0
  65. package/dist/components/common/error.js +7 -0
  66. package/dist/components/common/error.js.map +1 -0
  67. package/dist/components/core/common/FilterComponent.js +7 -7
  68. package/dist/components/core/common/FilterComponent.js.map +1 -1
  69. package/dist/components/core/common/SolidConfigureLayoutElement.d.ts.map +1 -1
  70. package/dist/components/core/common/SolidConfigureLayoutElement.js +4 -3
  71. package/dist/components/core/common/SolidConfigureLayoutElement.js.map +1 -1
  72. package/dist/components/core/common/SolidGlobalSearchElement.d.ts.map +1 -1
  73. package/dist/components/core/common/SolidGlobalSearchElement.js +35 -15
  74. package/dist/components/core/common/SolidGlobalSearchElement.js.map +1 -1
  75. package/dist/components/core/form/SolidFormLayouts.d.ts +3 -0
  76. package/dist/components/core/form/SolidFormLayouts.d.ts.map +1 -0
  77. package/dist/components/core/form/SolidFormLayouts.js +57 -0
  78. package/dist/components/core/form/SolidFormLayouts.js.map +1 -0
  79. package/dist/components/core/form/SolidFormView.d.ts.map +1 -1
  80. package/dist/components/core/form/SolidFormView.js +13 -1
  81. package/dist/components/core/form/SolidFormView.js.map +1 -1
  82. package/dist/components/core/form/fields/SolidMediaMultipleField.d.ts.map +1 -1
  83. package/dist/components/core/form/fields/SolidMediaMultipleField.js +11 -7
  84. package/dist/components/core/form/fields/SolidMediaMultipleField.js.map +1 -1
  85. package/dist/components/core/form/fields/SolidMediaSingleField.js +3 -2
  86. package/dist/components/core/form/fields/SolidMediaSingleField.js.map +1 -1
  87. package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.d.ts.map +1 -1
  88. package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.js +4 -4
  89. package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.js.map +1 -1
  90. package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.js +1 -1
  91. package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.js.map +1 -1
  92. package/dist/components/core/kanban/SolidKanbanView.js +2 -2
  93. package/dist/components/core/kanban/SolidKanbanView.js.map +1 -1
  94. package/dist/components/core/list/SolidListView.d.ts.map +1 -1
  95. package/dist/components/core/list/SolidListView.js +6 -28
  96. package/dist/components/core/list/SolidListView.js.map +1 -1
  97. package/dist/components/core/model/CreateModel.d.ts.map +1 -1
  98. package/dist/components/core/model/CreateModel.js +66 -18
  99. package/dist/components/core/model/CreateModel.js.map +1 -1
  100. package/dist/components/core/model/FieldMetaData.d.ts.map +1 -1
  101. package/dist/components/core/model/FieldMetaData.js +2 -2
  102. package/dist/components/core/model/FieldMetaData.js.map +1 -1
  103. package/dist/components/core/model/FieldMetaDataForm.js +21 -21
  104. package/dist/components/core/model/FieldMetaDataForm.js.map +1 -1
  105. package/dist/components/core/model/ModelMetaData.js +15 -15
  106. package/dist/components/core/model/ModelMetaData.js.map +1 -1
  107. package/dist/components/core/module/CreateModule.d.ts.map +1 -1
  108. package/dist/components/core/module/CreateModule.js +5 -2
  109. package/dist/components/core/module/CreateModule.js.map +1 -1
  110. package/dist/components/core/users/CreateUser.js +2 -2
  111. package/dist/components/layout/AdminLayout.d.ts +4 -0
  112. package/dist/components/layout/AdminLayout.d.ts.map +1 -0
  113. package/dist/components/layout/AdminLayout.js +86 -0
  114. package/dist/components/layout/AdminLayout.js.map +1 -0
  115. package/dist/components/layout/AppConfig.d.ts.map +1 -1
  116. package/dist/components/layout/AppConfig.js +4 -9
  117. package/dist/components/layout/AppConfig.js.map +1 -1
  118. package/dist/components/layout/user-profile-menu.js +1 -1
  119. package/dist/components/layout/user-profile-menu.js.map +1 -1
  120. package/dist/index.d.ts +11 -0
  121. package/dist/index.d.ts.map +1 -1
  122. package/dist/index.js +12 -0
  123. package/dist/index.js.map +1 -1
  124. package/dist/nextAuth/authProviders.d.ts +4 -0
  125. package/dist/nextAuth/authProviders.d.ts.map +1 -0
  126. package/dist/nextAuth/authProviders.js +231 -0
  127. package/dist/nextAuth/authProviders.js.map +1 -0
  128. package/dist/nextAuth/refreshAccessToken.d.ts +2 -0
  129. package/dist/nextAuth/refreshAccessToken.d.ts.map +1 -0
  130. package/dist/nextAuth/refreshAccessToken.js +76 -0
  131. package/dist/nextAuth/refreshAccessToken.js.map +1 -0
  132. package/package.json +1 -1
  133. package/src/components/auth/AuthLayout.tsx +126 -0
  134. package/src/components/auth/ForgotPasswordThankYou.tsx +45 -0
  135. package/src/components/auth/GoogleAuthChecking.tsx +60 -0
  136. package/src/components/auth/SolidChangeForcePassword.tsx +21 -32
  137. package/src/components/auth/SolidForgotPassword.tsx +3 -2
  138. package/src/components/auth/SolidInitialLoginOtp.tsx +16 -8
  139. package/src/components/auth/SolidInitiateRegisterOtp.tsx +17 -9
  140. package/src/components/auth/SolidLogin.tsx +16 -10
  141. package/src/components/auth/SolidRegister.tsx +17 -9
  142. package/src/components/auth/SolidResetPassword.tsx +13 -6
  143. package/src/components/common/GeneralSettings.tsx +7 -2
  144. package/src/components/common/NotFound.tsx +22 -0
  145. package/src/components/common/SingleSelectAutoCompleteField.tsx +2 -2
  146. package/src/components/common/SocialMediaLogin.tsx +24 -25
  147. package/src/components/common/SolidAdmin.tsx +7 -0
  148. package/src/components/common/SolidFormStepper.tsx +55 -2
  149. package/src/components/common/SolidThemeLink.tsx +5 -0
  150. package/src/components/common/error.tsx +30 -0
  151. package/src/components/core/common/FilterComponent.tsx +70 -70
  152. package/src/components/core/common/SolidConfigureLayoutElement.tsx +6 -1
  153. package/src/components/core/common/SolidGlobalSearchElement.tsx +45 -17
  154. package/src/components/core/form/SolidFormLayouts.tsx +93 -0
  155. package/src/components/core/form/SolidFormView.tsx +64 -3
  156. package/src/components/core/form/fields/SolidMediaMultipleField.tsx +14 -9
  157. package/src/components/core/form/fields/SolidMediaSingleField.tsx +3 -3
  158. package/src/components/core/form/fields/relations/SolidRelationManyToManyField.tsx +25 -23
  159. package/src/components/core/form/fields/relations/SolidRelationManyToOneField.tsx +1 -1
  160. package/src/components/core/kanban/SolidKanbanView.tsx +4 -4
  161. package/src/components/core/list/SolidListView.tsx +4 -61
  162. package/src/components/core/model/CreateModel.tsx +119 -18
  163. package/src/components/core/model/FieldMetaData.tsx +2 -0
  164. package/src/components/core/model/FieldMetaDataForm.tsx +26 -26
  165. package/src/components/core/model/ModelMetaData.tsx +21 -21
  166. package/src/components/core/module/CreateModule.tsx +11 -3
  167. package/src/components/core/users/CreateUser.tsx +2 -2
  168. package/src/components/layout/AdminLayout.tsx +62 -0
  169. package/src/components/layout/AppConfig.tsx +4 -3
  170. package/src/components/layout/user-profile-menu.tsx +1 -1
  171. package/src/index.ts +17 -1
  172. package/src/nextAuth/authProviders.tsx +220 -0
  173. package/src/nextAuth/refreshAccessToken.tsx +27 -0
@@ -0,0 +1,231 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
13
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
14
+ return new (P || (P = Promise))(function (resolve, reject) {
15
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
16
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
17
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
18
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
19
+ });
20
+ };
21
+ var __generator = (this && this.__generator) || function (thisArg, body) {
22
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
23
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
24
+ function verb(n) { return function (v) { return step([n, v]); }; }
25
+ function step(op) {
26
+ if (f) throw new TypeError("Generator is already executing.");
27
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
28
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
29
+ if (y = 0, t) op = [op[0] & 2, t.value];
30
+ switch (op[0]) {
31
+ case 0: case 1: t = op; break;
32
+ case 4: _.label++; return { value: op[1], done: false };
33
+ case 5: _.label++; y = op[1]; op = [0]; continue;
34
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
35
+ default:
36
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
37
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
38
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
39
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
40
+ if (t[2]) _.ops.pop();
41
+ _.trys.pop(); continue;
42
+ }
43
+ op = body.call(thisArg, _);
44
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
45
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
46
+ }
47
+ };
48
+ import CredentialsProvider from "next-auth/providers/credentials";
49
+ import GoogleProvider from "next-auth/providers/google";
50
+ import { jwtDecode } from "jwt-decode";
51
+ import axios from "axios";
52
+ import { refreshAccessToken } from "./refreshAccessToken";
53
+ var authProviders = {
54
+ session: {
55
+ strategy: "jwt",
56
+ },
57
+ providers: [
58
+ GoogleProvider({
59
+ clientId: process.env.GOOGLE_ID,
60
+ clientSecret: process.env.GOOGLE_CLIENT_SECRET
61
+ }),
62
+ CredentialsProvider({
63
+ // @ts-ignore
64
+ authorize: function (credentials) {
65
+ var _a, _b;
66
+ return __awaiter(this, void 0, void 0, function () {
67
+ var username, email, password, accessToken, accessCode, config, loginResponse, base64decoded, accessTokenExpires, data, config, loginResponse, base64decoded, accessTokenExpires, data, config, loginResponse, base64decoded, accessTokenExpires, returnResponse, error_1;
68
+ return __generator(this, function (_c) {
69
+ switch (_c.label) {
70
+ case 0:
71
+ username = credentials.username, email = credentials.email, password = credentials.password, accessToken = credentials.accessToken, accessCode = credentials.accessCode;
72
+ _c.label = 1;
73
+ case 1:
74
+ _c.trys.push([1, 8, , 9]);
75
+ if (!accessCode) return [3 /*break*/, 3];
76
+ config = {
77
+ method: 'get',
78
+ url: "".concat(process.env.API_URL, "/api/iam/google/authenticate?accessCode=").concat(accessCode),
79
+ };
80
+ return [4 /*yield*/, axios.request(config)];
81
+ case 2:
82
+ loginResponse = _c.sent();
83
+ console.log("loginResponse", loginResponse.data);
84
+ if (loginResponse.status == 400) {
85
+ throw new Error(loginResponse.data.message);
86
+ }
87
+ if (loginResponse.status == 401) {
88
+ throw new Error(loginResponse.data.message);
89
+ }
90
+ base64decoded = jwtDecode(loginResponse.data.data.accessToken);
91
+ accessTokenExpires = base64decoded.exp;
92
+ return [2 /*return*/, __assign({ accessToken: loginResponse.data.data.accessToken, refreshToken: loginResponse.data.data.refreshToken, accessTokenExpires: accessTokenExpires }, loginResponse.data.data)];
93
+ case 3:
94
+ if (!accessToken) return [3 /*break*/, 5];
95
+ data = JSON.stringify({
96
+ username: email,
97
+ email: email,
98
+ password: password
99
+ });
100
+ config = {
101
+ method: 'get',
102
+ url: "".concat(process.env.API_URL, "/api/iam/me"),
103
+ headers: {
104
+ 'accept': '*/*',
105
+ 'Content-Type': 'application/json',
106
+ 'Authorization': "Bearer ".concat(accessToken)
107
+ }
108
+ };
109
+ return [4 /*yield*/, axios.request(config)];
110
+ case 4:
111
+ loginResponse = _c.sent();
112
+ if (loginResponse.status == 400) {
113
+ throw new Error(loginResponse.data.message);
114
+ }
115
+ if (loginResponse.status == 401) {
116
+ throw new Error(loginResponse.data.message);
117
+ }
118
+ base64decoded = jwtDecode(loginResponse.data.data.accessToken);
119
+ accessTokenExpires = base64decoded.exp;
120
+ return [2 /*return*/, __assign({ accessToken: loginResponse.data.data.accessToken, refreshToken: loginResponse.data.data.refreshToken, accessTokenExpires: accessTokenExpires }, loginResponse.data.data)];
121
+ case 5:
122
+ data = JSON.stringify({
123
+ username: email,
124
+ email: email,
125
+ password: password
126
+ });
127
+ config = {
128
+ method: 'post',
129
+ maxBodyLength: Infinity,
130
+ url: "".concat(process.env.API_URL, "/api/iam/authenticate"),
131
+ headers: {
132
+ 'accept': '*/*',
133
+ 'Content-Type': 'application/json'
134
+ },
135
+ data: data
136
+ };
137
+ return [4 /*yield*/, axios.request(config)];
138
+ case 6:
139
+ loginResponse = _c.sent();
140
+ // const authenticateResponse = await fetch(
141
+ // `${process.env.API_URL}/api/iam/authenticate`,
142
+ // {
143
+ // method: "Post",
144
+ // headers: {
145
+ // 'accept': '*/*',
146
+ // "Content-Type": "application/json"
147
+ // },
148
+ // body: JSON.stringify({
149
+ // username: email,
150
+ // email: email,
151
+ // password: password
152
+ // })
153
+ // }
154
+ // );
155
+ // const loginResponse = await authenticateResponse.json();
156
+ // const response = await fetch(
157
+ // `${process.env.API_URL}/api/iam/me`,
158
+ // {
159
+ // method: "Get",
160
+ // headers: {
161
+ // "Content-Type": "application/json",
162
+ // "Authorization": `Bearer ${loginResponse.data.accessToken}`,
163
+ // },
164
+ // }
165
+ // );
166
+ // const responseData = await response.json();
167
+ if (loginResponse.status == 400) {
168
+ throw new Error(loginResponse.data.message);
169
+ }
170
+ if (loginResponse.status == 401) {
171
+ throw new Error(loginResponse.data.data.message);
172
+ }
173
+ base64decoded = jwtDecode(loginResponse.data.data.accessToken);
174
+ accessTokenExpires = base64decoded.exp;
175
+ returnResponse = __assign({ accessToken: loginResponse.data.data.accessToken, refreshToken: loginResponse.data.data.refreshToken, accessTokenExpires: accessTokenExpires }, loginResponse.data.data);
176
+ return [2 /*return*/, returnResponse];
177
+ case 7: return [3 /*break*/, 9];
178
+ case 8:
179
+ error_1 = _c.sent();
180
+ throw new Error(error_1.message ? error_1.message : (_b = (_a = error_1 === null || error_1 === void 0 ? void 0 : error_1.response) === null || _a === void 0 ? void 0 : _a.data) === null || _b === void 0 ? void 0 : _b.message);
181
+ case 9: return [2 /*return*/];
182
+ }
183
+ });
184
+ });
185
+ },
186
+ }),
187
+ ],
188
+ callbacks: {
189
+ // @ts-ignore
190
+ jwt: function (_a) {
191
+ var token = _a.token, user = _a.user;
192
+ return __awaiter(void 0, void 0, void 0, function () {
193
+ var base64decoded, accessTokenExpires;
194
+ return __generator(this, function (_b) {
195
+ if (Date.now() >= token.accessTokenExpires) {
196
+ return [2 /*return*/, refreshAccessToken(token)]; // Call the refresh token function
197
+ }
198
+ // If there is no user (first time login or session), we return the user data
199
+ if (user) {
200
+ base64decoded = jwtDecode(user.accessToken);
201
+ accessTokenExpires = base64decoded.exp && base64decoded.exp * 1000;
202
+ return [2 /*return*/, __assign(__assign({}, token), { accessToken: user.accessToken, refreshToken: user.refreshToken, accessTokenExpires: accessTokenExpires, user: user })];
203
+ }
204
+ return [2 /*return*/, token]; // If no update needed, just return the existing token
205
+ });
206
+ });
207
+ },
208
+ // @ts-ignore
209
+ session: function (_a) {
210
+ var session = _a.session, token = _a.token;
211
+ return __awaiter(void 0, void 0, void 0, function () {
212
+ var user;
213
+ return __generator(this, function (_b) {
214
+ user = token.user || {};
215
+ session.error = token.error ? token.error : null;
216
+ // if (token.error) {
217
+ // return null
218
+ // }
219
+ session.user = __assign(__assign({}, user), { accessToken: token === null || token === void 0 ? void 0 : token.accessToken, refreshToken: token === null || token === void 0 ? void 0 : token.refreshToken, accessTokenExpires: (token === null || token === void 0 ? void 0 : token.accessTokenExpires) && (token === null || token === void 0 ? void 0 : token.accessTokenExpires) });
220
+ return [2 /*return*/, session];
221
+ });
222
+ });
223
+ },
224
+ },
225
+ pages: {
226
+ signIn: "/auth/login",
227
+ },
228
+ secret: process.env.NEXTAUTH_SECRET,
229
+ };
230
+ export default authProviders;
231
+ //# sourceMappingURL=authProviders.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"authProviders.js","sourceRoot":"","sources":["../../src/nextAuth/authProviders.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function refreshAccessToken(token: any): Promise<any>;
2
+ //# sourceMappingURL=refreshAccessToken.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"refreshAccessToken.d.ts","sourceRoot":"","sources":["../../src/nextAuth/refreshAccessToken.tsx"],"names":[],"mappings":"AAGA,wBAAsB,kBAAkB,CAAC,KAAK,EAAE,GAAG,gBAuBhD"}
@@ -0,0 +1,76 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
13
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
14
+ return new (P || (P = Promise))(function (resolve, reject) {
15
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
16
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
17
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
18
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
19
+ });
20
+ };
21
+ var __generator = (this && this.__generator) || function (thisArg, body) {
22
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
23
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
24
+ function verb(n) { return function (v) { return step([n, v]); }; }
25
+ function step(op) {
26
+ if (f) throw new TypeError("Generator is already executing.");
27
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
28
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
29
+ if (y = 0, t) op = [op[0] & 2, t.value];
30
+ switch (op[0]) {
31
+ case 0: case 1: t = op; break;
32
+ case 4: _.label++; return { value: op[1], done: false };
33
+ case 5: _.label++; y = op[1]; op = [0]; continue;
34
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
35
+ default:
36
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
37
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
38
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
39
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
40
+ if (t[2]) _.ops.pop();
41
+ _.trys.pop(); continue;
42
+ }
43
+ op = body.call(thisArg, _);
44
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
45
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
46
+ }
47
+ };
48
+ import axios from "axios";
49
+ import { jwtDecode } from "jwt-decode";
50
+ export function refreshAccessToken(token) {
51
+ var _a;
52
+ return __awaiter(this, void 0, void 0, function () {
53
+ var response, _b, accessToken, refreshToken, accessTokenExpires, error_1;
54
+ return __generator(this, function (_c) {
55
+ switch (_c.label) {
56
+ case 0:
57
+ _c.trys.push([0, 2, , 3]);
58
+ return [4 /*yield*/, axios.post("".concat(process.env.NEXT_PUBLIC_BACKEND_API_URL, "/api/iam/refresh-tokens"), { refreshToken: token.refreshToken })];
59
+ case 1:
60
+ response = _c.sent();
61
+ _b = response.data.data, accessToken = _b.accessToken, refreshToken = _b.refreshToken;
62
+ accessTokenExpires = jwtDecode(accessToken).exp;
63
+ return [2 /*return*/, __assign(__assign({}, token), { accessToken: accessToken, refreshToken: refreshToken, accessTokenExpires: accessTokenExpires * 1000 })];
64
+ case 2:
65
+ error_1 = _c.sent();
66
+ console.error("Failed to refresh access token:", error_1.message || ((_a = error_1.response) === null || _a === void 0 ? void 0 : _a.data));
67
+ return [2 /*return*/, {
68
+ // ...token,
69
+ error: "RefreshAccessTokenError",
70
+ }];
71
+ case 3: return [2 /*return*/];
72
+ }
73
+ });
74
+ });
75
+ }
76
+ //# sourceMappingURL=refreshAccessToken.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"refreshAccessToken.js","sourceRoot":"","sources":["../../src/nextAuth/refreshAccessToken.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAEvC,MAAM,UAAgB,kBAAkB,CAAC,KAAU;;;;;;;;oBAE5B,qBAAM,KAAK,CAAC,IAAI,CAC/B,UAAG,OAAO,CAAC,GAAG,CAAC,2BAA2B,4BAAyB,EACnE,EAAE,YAAY,EAAE,KAAK,CAAC,YAAY,EAAE,CACrC,EAAA;;oBAHK,QAAQ,GAAG,SAGhB;oBAEK,KAAgC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAhD,WAAW,iBAAA,EAAE,YAAY,kBAAA,CAAwB;oBAC5C,kBAAkB,GAAK,SAAS,CAAkB,WAAW,CAAC,IAA5C,CAA6C;oBAE5E,4CACK,KAAK,KACR,WAAW,aAAA,EACX,YAAY,cAAA,EACZ,kBAAkB,EAAE,kBAAkB,GAAG,IAAI,KAC7C;;;oBAEF,OAAO,CAAC,KAAK,CAAC,iCAAiC,EAAE,OAAK,CAAC,OAAO,KAAI,MAAA,OAAK,CAAC,QAAQ,0CAAE,IAAI,CAAA,CAAC,CAAC;oBACxF,sBAAO;4BACL,YAAY;4BACZ,KAAK,EAAE,yBAAyB;yBACjC,EAAC;;;;;CAEL"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@solidstarters/solid-core-ui",
3
- "version": "1.1.15",
3
+ "version": "1.1.17",
4
4
  "scripts": {
5
5
  "build": "tsc && tsc-alias",
6
6
  "clean": "rm -rf dist",
@@ -0,0 +1,126 @@
1
+ "use client"
2
+ import { AppTitle } from "@/helpers/AppTitle";
3
+ import { useLazyGetAuthSettingsQuery } from "@/redux/api/solidSettingsApi";
4
+ import { toggleTheme } from "@/redux/features/themeSlice";
5
+ import { LayoutConfig } from "@/types";
6
+ import Link from "next/link";
7
+ import { usePathname, useRouter } from "next/navigation";
8
+ import { PrimeReactContext } from "primereact/api";
9
+ import { Button } from "primereact/button";
10
+ import { Dialog } from "primereact/dialog";
11
+ import { useContext, useEffect, useState } from "react";
12
+ import { useDispatch } from "react-redux";
13
+ import { LayoutContext } from "../layout/context/layoutcontext";
14
+
15
+ export const AuthLayout = ({ children }: { children: React.ReactNode }) => {
16
+ const [trigger, { data: solidSettingsData }] = useLazyGetAuthSettingsQuery()
17
+ const [allowRegistration, setAllowRegistration] = useState<boolean | null>(null);
18
+ const [isRestricted, setIsRestricted] = useState(false);
19
+ const pathname = usePathname();
20
+ const router = useRouter();
21
+
22
+ const { changeTheme } = useContext(PrimeReactContext);
23
+ const { layoutConfig, setLayoutConfig } = useContext(LayoutContext);
24
+ const dispatch = useDispatch();
25
+ const _changeTheme = (theme: string, colorScheme: string) => {
26
+ changeTheme?.(layoutConfig.theme, theme, 'theme-css', () => {
27
+ setLayoutConfig((prevState: LayoutConfig) => ({ ...prevState, theme, colorScheme }));
28
+ });
29
+ };
30
+ useEffect(() => {
31
+ const theme = solidSettingsData?.data?.authPagesTheme; // 'dark' or 'light'
32
+ if (theme) {
33
+ dispatch(toggleTheme()); // Dispatch Redux action
34
+ _changeTheme(
35
+ theme === "dark" ? "solid-dark-purple" : "solid-light-purple",
36
+ theme
37
+ );
38
+ }
39
+ }, [solidSettingsData]);
40
+ useEffect(() => {
41
+ // Fetch settings if not already available
42
+ trigger("");
43
+
44
+ const iamAllowPublicRegistration = solidSettingsData?.data?.iamAllowPublicRegistration;
45
+
46
+ if (iamAllowPublicRegistration === false) {
47
+ setAllowRegistration(false);
48
+ if (pathname === "/auth/register") {
49
+ setIsRestricted(true);
50
+ } else {
51
+ setIsRestricted(false);
52
+ }
53
+ } else if (iamAllowPublicRegistration === true) {
54
+ setAllowRegistration(true);
55
+ setIsRestricted(false);
56
+ }
57
+ }, [solidSettingsData, pathname, trigger]);
58
+
59
+
60
+ if (allowRegistration === null) return null;
61
+
62
+ const authChildren = allowRegistration || pathname !== "/auth/register" ? children : null;
63
+ const handleRegistration = () => {
64
+ router.push("/auth/login");
65
+ setIsRestricted(false);
66
+ }
67
+ return (
68
+ <div className={`solid-auth-theme-wrapper ${solidSettingsData?.data?.authPagesLayout || 'center'}`}>
69
+ <div className={`${solidSettingsData?.data?.authPagesLayout !== 'center' ? 'grid w-full h-full m-0' : ''}`}>
70
+ {solidSettingsData?.data?.authPagesLayout === 'left' &&
71
+ <div className='col-6 flex align-items-center justify-content-center solid-login-dark-bg'>
72
+ <div className="w-full">
73
+ {authChildren}
74
+ </div>
75
+ </div>
76
+ }
77
+
78
+ <div
79
+ className={`${solidSettingsData?.data?.authPagesLayout !== 'center' ? 'col-6 position-relative' : ''}
80
+ ${solidSettingsData?.data?.authPagesLayout === 'left' ? 'solid-left-layout' : ''}
81
+ ${solidSettingsData?.data?.authPagesLayout === 'right' ? 'solid-right-layout' : ''}`.trim()}
82
+ >
83
+ {solidSettingsData?.data?.authPagesLayout !== 'center' &&
84
+ <div className="solid-logo flex align-items-center gap-3">
85
+ <img
86
+ alt="solid logo"
87
+ src={'/images/SS-Logo-1 1.png'}
88
+ className="position-relative img-fluid"
89
+ />
90
+ <AppTitle title={solidSettingsData} />
91
+ </div>
92
+ }
93
+ </div>
94
+
95
+ {solidSettingsData?.data?.authPagesLayout === 'center' && <div className="solid-center-layout">
96
+ {authChildren}
97
+ </div>}
98
+ {solidSettingsData?.data?.authPagesLayout === 'right' &&
99
+ <div className='col-6 flex align-items-center justify-content-center solid-login-dark-bg'>
100
+ <div className="w-full">
101
+ {authChildren}
102
+ </div>
103
+ </div>
104
+ }
105
+ </div>
106
+ <div className="absolute solid-auth-footer flex align-items-center justify-content-between">
107
+ <div>
108
+ <p className={`solid-auth-input-label text-sm m-0 ${solidSettingsData?.data?.authPagesLayout === 'right' ? 'right' : ''}`}>Made with <svg className="mx-1" width="12px" height="12px" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round"></g><g id="SVGRepo_iconCarrier"> <path d="M1.24264 8.24264L8 15L14.7574 8.24264C15.553 7.44699 16 6.36786 16 5.24264V5.05234C16 2.8143 14.1857 1 11.9477 1C10.7166 1 9.55233 1.55959 8.78331 2.52086L8 3.5L7.21669 2.52086C6.44767 1.55959 5.28338 1 4.05234 1C1.8143 1 0 2.8143 0 5.05234V5.24264C0 6.36786 0.44699 7.44699 1.24264 8.24264Z" fill="#ff0000"></path> </g></svg> in Mumbai</p>
109
+ </div>
110
+ <div className={`flex align-items-center gap-5 solid-auth-subtitle ${solidSettingsData?.data?.authPagesLayout === 'left' ? 'left' : ''}`}>
111
+ <p className="m-0"> <Link href={solidSettingsData ? solidSettingsData?.data?.appTnc : "#"}>Terms of Service</Link></p>
112
+ <p className="m-0"> <Link href={solidSettingsData ? solidSettingsData?.data?.appPrivacyPolicy : "#"}>Privacy Policy.</Link></p>
113
+ </div>
114
+ </div>
115
+ <Dialog
116
+ visible={isRestricted}
117
+ onHide={handleRegistration}
118
+ header="Access Restricted"
119
+ footer={<Button label="Close" onClick={handleRegistration} size="small" />}
120
+ draggable={false}
121
+ >
122
+ <p>Sign-up is not available. Please contact the admin.</p>
123
+ </Dialog>
124
+ </div>
125
+ )
126
+ }
@@ -0,0 +1,45 @@
1
+ "use client"
2
+
3
+ import Link from "next/link";
4
+ import { useSearchParams } from "next/navigation";
5
+ import { useContext } from "react";
6
+ import { LayoutContext } from "../layout/context/layoutcontext";
7
+
8
+
9
+ export const ForgotPasswordThankYou = () => {
10
+ const { layoutConfig } = useContext(LayoutContext);
11
+ const { authLayout } = layoutConfig;
12
+ const searchParams = useSearchParams();
13
+ const email = searchParams.get('email');
14
+ const decodedEmail = email ? decodeURIComponent(email) : '';
15
+ return (
16
+ <div>
17
+ <div className={`auth-container ${authLayout === 'Center' ? 'center' : 'side'}`}>
18
+ {authLayout === 'Center' &&
19
+ <div className="flex justify-content-center">
20
+ <div className="solid-logo flex align-items-center gap-3">
21
+ GoogleAuthChecking <img
22
+ alt="solid logo"
23
+ src={'/images/SS-Logo-1 1.png'}
24
+ className="position-relative img-fluid"
25
+ />
26
+ <div>
27
+ <p className="solid-logo-title">
28
+ Solid<br />Starters
29
+ </p>
30
+ </div>
31
+ </div>
32
+ </div>
33
+ }
34
+ <h5 className='text-center font-bold'>We have sent an email to yourregistered email address</h5>
35
+ <p className='font-bold text-center'>{decodedEmail}</p>
36
+ <p className='text-center'>
37
+ Please follow the instructions in the email
38
+ </p>
39
+ <div className='text-center'>
40
+ <Link href={"/"} className='btn'>Back to Home</Link>
41
+ </div>
42
+ </div>
43
+ </div>
44
+ )
45
+ }
@@ -0,0 +1,60 @@
1
+ "use client"
2
+ import { signIn } from 'next-auth/react';
3
+ import { useRouter, useSearchParams } from 'next/navigation';
4
+ import { ProgressSpinner } from 'primereact/progressspinner';
5
+ import { Toast } from 'primereact/toast';
6
+ import React, { useEffect, useRef, useState } from 'react'
7
+ export const GoogleAuthChecking = () => {
8
+ const searchParams = useSearchParams();
9
+ const accessCode = searchParams.get("accessCode");
10
+
11
+ const router = useRouter();
12
+ const [error, setError] = useState<string | null>(null);
13
+ const toast = useRef<Toast>(null);
14
+ const showToast = (severity: "success" | "error", summary: string, detail: string) => {
15
+ toast.current?.show({
16
+ severity,
17
+ summary,
18
+ detail,
19
+ life: 3000,
20
+ });
21
+ };
22
+ useEffect(() => {
23
+ const handleOAuthAuthentication = async () => {
24
+ try {
25
+ const response = await signIn("credentials", {
26
+ redirect: false,
27
+ accessCode: accessCode
28
+ // accessToken: accessToken?.accessToken,
29
+ // refreshToken: accessToken?.refreshToken
30
+ });
31
+
32
+ if (response?.error) {
33
+ showToast("error", "Login Error", response.error);
34
+ setError("Authentication failed.")
35
+ } else {
36
+ showToast("success", "Login Success", "Redirecting to dashboard...");
37
+ router.push("/admin/core/solid-core/user/list");
38
+ }
39
+ } catch (err: any) {
40
+ showToast("error", "Login Error", err?.data?.message || "Authentication failed.");
41
+ }
42
+ };
43
+
44
+ handleOAuthAuthentication();
45
+ }, [router]);
46
+
47
+ if (error) {
48
+ return (
49
+ <div className="flex items-center justify-center min-h-screen">
50
+ <h2 className="text-red-500 text-xl font-semibold">{error}</h2>
51
+ </div>
52
+ );
53
+ }
54
+ return (
55
+ <div>
56
+ <Toast ref={toast} />
57
+ <ProgressSpinner />
58
+ </div>
59
+ )
60
+ }