@ssplib/react-components 0.0.38 → 0.0.40
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.
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
export declare const cookieName = "nextauth.token";
|
|
3
|
+
export declare function LoginProvider({ children, AUTH_URL, redirectURL, validateTokenRoute, testToken, }: {
|
|
4
|
+
children: JSX.Element | JSX.Element[];
|
|
5
|
+
AUTH_URL: string;
|
|
6
|
+
validateTokenRoute: string;
|
|
7
|
+
testToken: string;
|
|
8
|
+
redirectURL?: string;
|
|
9
|
+
}): JSX.Element;
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
26
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
27
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
28
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
29
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
30
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
31
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
32
|
+
});
|
|
33
|
+
};
|
|
34
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
35
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
36
|
+
};
|
|
37
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
38
|
+
exports.LoginProvider = exports.cookieName = void 0;
|
|
39
|
+
const cookies_next_1 = require("cookies-next");
|
|
40
|
+
const jwt_decode_1 = __importDefault(require("jwt-decode"));
|
|
41
|
+
const router_1 = require("next/router");
|
|
42
|
+
const react_1 = __importStar(require("react"));
|
|
43
|
+
const auth_1 = require("../../context/auth");
|
|
44
|
+
exports.cookieName = 'nextauth.token';
|
|
45
|
+
const userImgName = 'user-data.img';
|
|
46
|
+
function LoginProvider({ children, AUTH_URL, redirectURL = '/', validateTokenRoute, testToken, }) {
|
|
47
|
+
const [user, setUser] = (0, react_1.useState)();
|
|
48
|
+
const [userLoaded, setUserLoaded] = (0, react_1.useState)(false);
|
|
49
|
+
const router = (0, router_1.useRouter)();
|
|
50
|
+
const isAuth = !!user;
|
|
51
|
+
(0, react_1.useEffect)(() => {
|
|
52
|
+
const token = (0, cookies_next_1.getCookie)(exports.cookieName);
|
|
53
|
+
if (!token) {
|
|
54
|
+
setUserLoaded(true);
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
fetch(`${AUTH_URL}${validateTokenRoute}`, {
|
|
58
|
+
method: 'POST',
|
|
59
|
+
headers: {
|
|
60
|
+
Authorization: `Bearer ${token}`,
|
|
61
|
+
},
|
|
62
|
+
}).then((res) => {
|
|
63
|
+
if (!res.ok) {
|
|
64
|
+
logout();
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
const user = (0, jwt_decode_1.default)(token);
|
|
69
|
+
const img = localStorage.getItem(userImgName);
|
|
70
|
+
setUser({ name: user.name, image: img !== null && img !== void 0 ? img : '', roles: user.roles.map((x) => x.code), token });
|
|
71
|
+
setUserLoaded(true);
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
}, []);
|
|
75
|
+
function login() {
|
|
76
|
+
// Teste em localhost
|
|
77
|
+
// if (location && location.hostname === 'localhost') {
|
|
78
|
+
// const token = testToken
|
|
79
|
+
// setCookie(cookieName, token, { maxAge: 60 * 60 * 24 * 500 })
|
|
80
|
+
// setUser({
|
|
81
|
+
// name: 'Teste',
|
|
82
|
+
// image: '',
|
|
83
|
+
// roles: [1],
|
|
84
|
+
// token: token,
|
|
85
|
+
// })
|
|
86
|
+
// router.replace(redirectURL).finally(() => setUserLoaded(true))
|
|
87
|
+
// }
|
|
88
|
+
// //
|
|
89
|
+
// else {
|
|
90
|
+
// setUserLoaded(false)
|
|
91
|
+
// router.replace(govBrURL)
|
|
92
|
+
// }
|
|
93
|
+
}
|
|
94
|
+
// chamado no callback de login
|
|
95
|
+
function saveUserData(authData) {
|
|
96
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
97
|
+
const token = authData.ssp_token;
|
|
98
|
+
(0, cookies_next_1.setCookie)(exports.cookieName, token);
|
|
99
|
+
router.replace(redirectURL).finally(() => setUserLoaded(true));
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
function logout() {
|
|
103
|
+
setUserLoaded(false);
|
|
104
|
+
setUser(null);
|
|
105
|
+
(0, cookies_next_1.deleteCookie)(exports.cookieName);
|
|
106
|
+
localStorage.removeItem(userImgName);
|
|
107
|
+
router.replace(redirectURL).finally(() => setUserLoaded(true));
|
|
108
|
+
}
|
|
109
|
+
return react_1.default.createElement(auth_1.AuthContext.Provider, { value: { user, isAuth, userLoaded, login, logout, saveUserData, type: 'ad' } }, children);
|
|
110
|
+
}
|
|
111
|
+
exports.LoginProvider = LoginProvider;
|
|
@@ -96,7 +96,7 @@ function OAuthProvider({ children, AUTH_URL, oidcConfig, redirectURL, validateTo
|
|
|
96
96
|
function saveUserData(authData) {
|
|
97
97
|
return __awaiter(this, void 0, void 0, function* () {
|
|
98
98
|
const token = authData.ssp_token;
|
|
99
|
-
(0, cookies_next_1.setCookie)(exports.cookieName, token
|
|
99
|
+
(0, cookies_next_1.setCookie)(exports.cookieName, token);
|
|
100
100
|
const userData = (0, jwt_decode_1.default)(token);
|
|
101
101
|
const idToken = (0, jwt_decode_1.default)(authData.id_token);
|
|
102
102
|
// pegando foto de usuario
|
package/index.d.ts
CHANGED
|
@@ -16,6 +16,7 @@ import Table from './components/form/table/Table';
|
|
|
16
16
|
import NavBar from './components/navbar/NavBar';
|
|
17
17
|
import FormProvider from './components/providers/FormProvider';
|
|
18
18
|
import { OAuthProvider, cookieName as AUTH_COOKIE_NAME } from './components/providers/OAuthProvider';
|
|
19
|
+
import { LoginProvider } from './components/providers/LoginProvider';
|
|
19
20
|
import { AuthContext } from './context/auth';
|
|
20
21
|
import { FormContext } from './context/form';
|
|
21
|
-
export { CheckBox, CheckBoxWarning, DatePicker, TimePicker, FileUpload, ActiveInput, AutoComplete, Input, MaskInput, MultInput, OtherCheckBox, Stepper, StepperBlock, Switch, Table, NavBar, FormProvider, OAuthProvider, AUTH_COOKIE_NAME, AuthContext, FormContext };
|
|
22
|
+
export { CheckBox, CheckBoxWarning, DatePicker, TimePicker, FileUpload, ActiveInput, AutoComplete, Input, MaskInput, MultInput, OtherCheckBox, Stepper, StepperBlock, Switch, Table, NavBar, FormProvider, OAuthProvider, AUTH_COOKIE_NAME, AuthContext, FormContext, LoginProvider };
|
package/index.js
CHANGED
|
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.FormContext = exports.AuthContext = exports.AUTH_COOKIE_NAME = exports.OAuthProvider = exports.FormProvider = exports.NavBar = exports.Table = exports.Switch = exports.StepperBlock = exports.Stepper = exports.OtherCheckBox = exports.MultInput = exports.MaskInput = exports.Input = exports.AutoComplete = exports.ActiveInput = exports.FileUpload = exports.TimePicker = exports.DatePicker = exports.CheckBoxWarning = exports.CheckBox = void 0;
|
|
6
|
+
exports.LoginProvider = exports.FormContext = exports.AuthContext = exports.AUTH_COOKIE_NAME = exports.OAuthProvider = exports.FormProvider = exports.NavBar = exports.Table = exports.Switch = exports.StepperBlock = exports.Stepper = exports.OtherCheckBox = exports.MultInput = exports.MaskInput = exports.Input = exports.AutoComplete = exports.ActiveInput = exports.FileUpload = exports.TimePicker = exports.DatePicker = exports.CheckBoxWarning = exports.CheckBox = void 0;
|
|
7
7
|
const CheckBox_1 = __importDefault(require("./components/form/checkbox/CheckBox"));
|
|
8
8
|
exports.CheckBox = CheckBox_1.default;
|
|
9
9
|
const CheckBoxWarning_1 = __importDefault(require("./components/form/checkbox/CheckBoxWarning"));
|
|
@@ -41,6 +41,8 @@ exports.FormProvider = FormProvider_1.default;
|
|
|
41
41
|
const OAuthProvider_1 = require("./components/providers/OAuthProvider");
|
|
42
42
|
Object.defineProperty(exports, "OAuthProvider", { enumerable: true, get: function () { return OAuthProvider_1.OAuthProvider; } });
|
|
43
43
|
Object.defineProperty(exports, "AUTH_COOKIE_NAME", { enumerable: true, get: function () { return OAuthProvider_1.cookieName; } });
|
|
44
|
+
const LoginProvider_1 = require("./components/providers/LoginProvider");
|
|
45
|
+
Object.defineProperty(exports, "LoginProvider", { enumerable: true, get: function () { return LoginProvider_1.LoginProvider; } });
|
|
44
46
|
const auth_1 = require("./context/auth");
|
|
45
47
|
Object.defineProperty(exports, "AuthContext", { enumerable: true, get: function () { return auth_1.AuthContext; } });
|
|
46
48
|
const form_1 = require("./context/form");
|