@tern-secure/nextjs 3.1.76 → 3.1.78
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.
- package/dist/cjs/app-router/client/TernSecureProvider.js +75 -0
- package/dist/cjs/app-router/client/TernSecureProvider.js.map +1 -0
- package/dist/cjs/app-router/server/TernSecureServerProvider.js +63 -0
- package/dist/cjs/app-router/server/TernSecureServerProvider.js.map +1 -0
- package/dist/cjs/app-router/server/auth.js +37 -0
- package/dist/cjs/app-router/server/auth.js.map +1 -0
- package/dist/cjs/boundary/TernSecureCtx.js +50 -0
- package/dist/cjs/boundary/TernSecureCtx.js.map +1 -0
- package/dist/cjs/boundary/hooks/useAuth.js +45 -0
- package/dist/cjs/boundary/hooks/useAuth.js.map +1 -0
- package/dist/cjs/components/sign-in.js +132 -0
- package/dist/cjs/components/sign-in.js.map +1 -0
- package/dist/cjs/errors.js +41 -0
- package/dist/cjs/errors.js.map +1 -0
- package/dist/cjs/index.js +49 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/types.js +17 -0
- package/dist/cjs/types.js.map +1 -0
- package/dist/cjs/utils/client-init.js +46 -0
- package/dist/cjs/utils/client-init.js.map +1 -0
- package/dist/cjs/utils/config.js +73 -0
- package/dist/cjs/utils/config.js.map +1 -0
- package/dist/cjs/utils/create-styles.js +149 -0
- package/dist/cjs/utils/create-styles.js.map +1 -0
- package/dist/esm/app-router/client/TernSecureProvider.js +40 -3
- package/dist/esm/app-router/client/TernSecureProvider.js.map +1 -0
- package/dist/esm/app-router/server/TernSecureServerProvider.js +29 -3
- package/dist/esm/app-router/server/TernSecureServerProvider.js.map +1 -0
- package/dist/esm/app-router/server/auth.js +13 -3
- package/dist/esm/app-router/server/auth.js.map +1 -0
- package/dist/esm/boundary/TernSecureCtx.js +25 -1
- package/dist/esm/boundary/TernSecureCtx.js.map +1 -0
- package/dist/esm/boundary/hooks/useAuth.js +21 -3
- package/dist/esm/boundary/hooks/useAuth.js.map +1 -0
- package/dist/esm/components/sign-in.js +108 -4
- package/dist/esm/components/sign-in.js.map +1 -0
- package/dist/esm/errors.js +16 -1
- package/dist/esm/errors.js.map +1 -0
- package/dist/esm/index.js +18 -4
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/types.js +1 -0
- package/dist/esm/types.js.map +1 -0
- package/dist/esm/utils/client-init.js +20 -3
- package/dist/esm/utils/client-init.js.map +1 -0
- package/dist/esm/utils/config.js +47 -3
- package/dist/esm/utils/config.js.map +1 -0
- package/dist/esm/utils/create-styles.js +123 -2
- package/dist/esm/utils/create-styles.js.map +1 -0
- package/package.json +3 -3
- package/dist/cjs/app-router/client/TernSecureProvider.cjs +0 -3
- package/dist/cjs/app-router/server/TernSecureServerProvider.cjs +0 -3
- package/dist/cjs/app-router/server/auth.cjs +0 -3
- package/dist/cjs/boundary/TernSecureCtx.cjs +0 -1
- package/dist/cjs/boundary/hooks/useAuth.cjs +0 -3
- package/dist/cjs/components/sign-in.cjs +0 -4
- package/dist/cjs/errors.cjs +0 -1
- package/dist/cjs/index.cjs +0 -4
- package/dist/cjs/types.cjs +0 -1
- package/dist/cjs/utils/client-init.cjs +0 -3
- package/dist/cjs/utils/config.cjs +0 -3
- package/dist/cjs/utils/create-styles.cjs +0 -2
- package/dist/esm/app-router/client/TernSecureProvider.d.ts +0 -17
- package/dist/esm/app-router/server/TernSecureServerProvider.d.ts +0 -30
- package/dist/esm/app-router/server/auth.d.ts +0 -9
- package/dist/esm/boundary/TernSecureCtx.d.ts +0 -15
- package/dist/esm/boundary/hooks/useAuth.d.ts +0 -7
- package/dist/esm/components/sign-in.d.ts +0 -25
- package/dist/esm/errors.d.ts +0 -10
- package/dist/esm/index.d.ts +0 -19
- package/dist/esm/types.d.ts +0 -49
- package/dist/esm/utils/client-init.d.ts +0 -9
- package/dist/esm/utils/config.d.ts +0 -22
- package/dist/esm/utils/create-styles.d.ts +0 -100
package/dist/esm/index.js
CHANGED
|
@@ -1,4 +1,18 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
import { TernSecureServerProvider } from "./app-router/server/TernSecureServerProvider";
|
|
2
|
+
import { TernSecureAuth, TernSecureFirestore } from "./utils/client-init";
|
|
3
|
+
import { loadFireConfig, validateConfig } from "./utils/config";
|
|
4
|
+
import { signInWithEmail } from "./app-router/server/auth";
|
|
5
|
+
import { useAuth } from "./boundary/hooks/useAuth";
|
|
6
|
+
import { SignIn } from "./components/sign-in";
|
|
7
|
+
const TernSecureProvider = TernSecureServerProvider;
|
|
8
|
+
export {
|
|
9
|
+
SignIn,
|
|
10
|
+
TernSecureAuth,
|
|
11
|
+
TernSecureFirestore,
|
|
12
|
+
TernSecureProvider,
|
|
13
|
+
loadFireConfig,
|
|
14
|
+
signInWithEmail,
|
|
15
|
+
useAuth,
|
|
16
|
+
validateConfig
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts"],"sourcesContent":["import { TernSecureServerProvider } from './app-router/server/TernSecureServerProvider'\r\nimport type { TernSecureState } from './app-router/client/TernSecureProvider'\r\nexport { TernSecureAuth, TernSecureFirestore } from './utils/client-init'\r\nexport { loadFireConfig, validateConfig } from './utils/config'\r\nexport { signInWithEmail } from './app-router/server/auth'\r\n//export { useInternalContext } from './boundary/TernSecureCtx'\r\n//export { TernSecureClientProvider } from './app-router/client/TernSecureProvider'\r\n//export { TernSecureProvider } from './app-router/server/TernSecureServerProvider'\r\nexport { useAuth } from './boundary/hooks/useAuth' \r\nexport { SignIn } from './components/sign-in'\r\n\r\nexport const TernSecureProvider = TernSecureServerProvider\r\nexport type { TernSecureState }"],"mappings":"AAAA,SAAS,gCAAgC;AAEzC,SAAS,gBAAgB,2BAA2B;AACpD,SAAS,gBAAgB,sBAAsB;AAC/C,SAAS,uBAAuB;AAIhC,SAAS,eAAe;AACxB,SAAS,cAAc;AAEhB,MAAM,qBAAqB;","names":[]}
|
package/dist/esm/types.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -1,3 +1,20 @@
|
|
|
1
|
-
import {initializeApp
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import { initializeApp } from "firebase/app";
|
|
2
|
+
import { getAuth, setPersistence, browserSessionPersistence } from "firebase/auth";
|
|
3
|
+
import { getFirestore } from "firebase/firestore";
|
|
4
|
+
import { getStorage } from "firebase/storage";
|
|
5
|
+
import { initializeConfig } from "./config";
|
|
6
|
+
const config = initializeConfig();
|
|
7
|
+
const clientApp = initializeApp(config);
|
|
8
|
+
const auth = getAuth(clientApp);
|
|
9
|
+
setPersistence(auth, browserSessionPersistence);
|
|
10
|
+
const firestore = getFirestore(clientApp);
|
|
11
|
+
const storage = getStorage(clientApp);
|
|
12
|
+
const TernSecureAuth = () => auth;
|
|
13
|
+
const TernSecureFirestore = () => firestore;
|
|
14
|
+
const TernSecureStorage = () => storage;
|
|
15
|
+
export {
|
|
16
|
+
TernSecureAuth,
|
|
17
|
+
TernSecureFirestore,
|
|
18
|
+
TernSecureStorage
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=client-init.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/utils/client-init.ts"],"sourcesContent":["import { initializeApp } from 'firebase/app';\r\nimport { getAuth, setPersistence, browserSessionPersistence } from 'firebase/auth';\r\nimport { getFirestore } from 'firebase/firestore';\r\nimport { getStorage } from 'firebase/storage';\r\nimport { initializeConfig} from './config';\r\n\r\n// Initialize immediately\r\nconst config = initializeConfig();\r\nconst clientApp = initializeApp(config)\r\nconst auth = getAuth(clientApp);\r\nsetPersistence(auth, browserSessionPersistence); //to change later user should be able to choose persistance\r\nconst firestore = getFirestore(clientApp);\r\nconst storage = getStorage(clientApp);\r\n\r\nexport const TernSecureAuth = () => auth;\r\nexport const TernSecureFirestore = () => firestore;\r\nexport const TernSecureStorage = () => storage;"],"mappings":"AAAA,SAAS,qBAAqB;AAC9B,SAAS,SAAS,gBAAgB,iCAAiC;AACnE,SAAS,oBAAoB;AAC7B,SAAS,kBAAkB;AAC3B,SAAS,wBAAuB;AAGhC,MAAM,SAAS,iBAAiB;AAChC,MAAM,YAAY,cAAc,MAAM;AACtC,MAAM,OAAO,QAAQ,SAAS;AAC9B,eAAe,MAAM,yBAAyB;AAC9C,MAAM,YAAY,aAAa,SAAS;AACxC,MAAM,UAAU,WAAW,SAAS;AAE7B,MAAM,iBAAiB,MAAM;AAC7B,MAAM,sBAAsB,MAAM;AAClC,MAAM,oBAAoB,MAAM;","names":[]}
|
package/dist/esm/utils/config.js
CHANGED
|
@@ -1,3 +1,47 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
const loadFireConfig = () => ({
|
|
2
|
+
apiKey: process.env.NEXT_PUBLIC_FIREBASE_API_KEY || "",
|
|
3
|
+
authDomain: process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN || "",
|
|
4
|
+
projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID || "",
|
|
5
|
+
storageBucket: process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET || "",
|
|
6
|
+
messagingSenderId: process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID || "",
|
|
7
|
+
appId: process.env.NEXT_PUBLIC_FIREBASE_APP_ID || "",
|
|
8
|
+
measurementId: process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID || void 0
|
|
9
|
+
});
|
|
10
|
+
const validateConfig = (config) => {
|
|
11
|
+
const requiredFields = [
|
|
12
|
+
"apiKey",
|
|
13
|
+
"authDomain",
|
|
14
|
+
"projectId",
|
|
15
|
+
"storageBucket",
|
|
16
|
+
"messagingSenderId",
|
|
17
|
+
"appId"
|
|
18
|
+
];
|
|
19
|
+
const errors = [];
|
|
20
|
+
requiredFields.forEach((field) => {
|
|
21
|
+
if (!config[field]) {
|
|
22
|
+
errors.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(field).toUpperCase()}`);
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
return {
|
|
26
|
+
isValid: errors.length === 0,
|
|
27
|
+
errors,
|
|
28
|
+
config
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
const initializeConfig = () => {
|
|
32
|
+
const config = loadFireConfig();
|
|
33
|
+
const validationResult = validateConfig(config);
|
|
34
|
+
if (!validationResult.isValid) {
|
|
35
|
+
throw new Error(
|
|
36
|
+
`Firebase configuration validation failed:
|
|
37
|
+
${validationResult.errors.join("\n")}`
|
|
38
|
+
);
|
|
39
|
+
}
|
|
40
|
+
return config;
|
|
41
|
+
};
|
|
42
|
+
export {
|
|
43
|
+
initializeConfig,
|
|
44
|
+
loadFireConfig,
|
|
45
|
+
validateConfig
|
|
46
|
+
};
|
|
47
|
+
//# sourceMappingURL=config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/utils/config.ts"],"sourcesContent":["import { TernSecureConfig, ConfigValidationResult } from '../types'\r\n\r\n/**\r\n * Loads Firebase configuration from environment variables\r\n * @returns {TernSecureConfig} Firebase configuration object\r\n */\r\nexport const loadFireConfig = (): TernSecureConfig => ({\r\n apiKey: process.env.NEXT_PUBLIC_FIREBASE_API_KEY || '',\r\n authDomain: process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN || '',\r\n projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID || '',\r\n storageBucket: process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET || '',\r\n messagingSenderId: process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID || '',\r\n appId: process.env.NEXT_PUBLIC_FIREBASE_APP_ID || '',\r\n measurementId: process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID || undefined,\r\n})\r\n\r\n/**\r\n * Validates Firebase configuration\r\n * @param {TernSecureConfig} config - Firebase configuration object\r\n * @throws {Error} If required configuration values are missing\r\n * @returns {TernSecureConfig} Validated configuration object\r\n */\r\nexport const validateConfig = (config: TernSecureConfig): ConfigValidationResult => {\r\n const requiredFields: (keyof TernSecureConfig)[] = [\r\n 'apiKey',\r\n 'authDomain',\r\n 'projectId',\r\n 'storageBucket',\r\n 'messagingSenderId',\r\n 'appId'\r\n ]\r\n\r\n const errors: string[] = []\r\n \r\n requiredFields.forEach(field => {\r\n if (!config[field]) {\r\n errors.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(field).toUpperCase()}`)\r\n }\r\n })\r\n\r\n return {\r\n isValid: errors.length === 0,\r\n errors,\r\n config\r\n }\r\n}\r\n\r\n/**\r\n * Initializes configuration with validation\r\n * @throws {Error} If configuration is invalid\r\n */\r\nexport const initializeConfig = (): TernSecureConfig => {\r\n const config = loadFireConfig()\r\n const validationResult = validateConfig(config)\r\n\r\n if (!validationResult.isValid) {\r\n throw new Error(\r\n `Firebase configuration validation failed:\\n${validationResult.errors.join('\\n')}`\r\n )\r\n }\r\n\r\n return config\r\n}"],"mappings":"AAMO,MAAM,iBAAiB,OAAyB;AAAA,EACrD,QAAQ,QAAQ,IAAI,gCAAgC;AAAA,EACpD,YAAY,QAAQ,IAAI,oCAAoC;AAAA,EAC5D,WAAW,QAAQ,IAAI,mCAAmC;AAAA,EAC1D,eAAe,QAAQ,IAAI,uCAAuC;AAAA,EAClE,mBAAmB,QAAQ,IAAI,4CAA4C;AAAA,EAC3E,OAAO,QAAQ,IAAI,+BAA+B;AAAA,EAClD,eAAe,QAAQ,IAAI,uCAAuC;AACpE;AAQO,MAAM,iBAAiB,CAAC,WAAqD;AAClF,QAAM,iBAA6C;AAAA,IACjD;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAEA,QAAM,SAAmB,CAAC;AAE1B,iBAAe,QAAQ,WAAS;AAC9B,QAAI,CAAC,OAAO,KAAK,GAAG;AAClB,aAAO,KAAK,gDAAgD,OAAO,KAAK,EAAE,YAAY,CAAC,EAAE;AAAA,IAC3F;AAAA,EACF,CAAC;AAED,SAAO;AAAA,IACL,SAAS,OAAO,WAAW;AAAA,IAC3B;AAAA,IACA;AAAA,EACF;AACF;AAMO,MAAM,mBAAmB,MAAwB;AACtD,QAAM,SAAS,eAAe;AAC9B,QAAM,mBAAmB,eAAe,MAAM;AAE9C,MAAI,CAAC,iBAAiB,SAAS;AAC7B,UAAM,IAAI;AAAA,MACR;AAAA,EAA8C,iBAAiB,OAAO,KAAK,IAAI,CAAC;AAAA,IAClF;AAAA,EACF;AAEA,SAAO;AACT;","names":[]}
|
|
@@ -1,2 +1,123 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
"use client";
|
|
2
|
+
const PREFIX = "tern";
|
|
3
|
+
const styleInjection = {
|
|
4
|
+
isInjected: false,
|
|
5
|
+
styleElement: null
|
|
6
|
+
};
|
|
7
|
+
const defaultClassNames = {
|
|
8
|
+
container: `${PREFIX}-container`,
|
|
9
|
+
header: `${PREFIX}-header`,
|
|
10
|
+
title: `${PREFIX}-title`,
|
|
11
|
+
formWrapper: `${PREFIX}-formWrapper`,
|
|
12
|
+
formContainer: `${PREFIX}-formContainer`,
|
|
13
|
+
form: `${PREFIX}-form`,
|
|
14
|
+
label: `${PREFIX}-label`,
|
|
15
|
+
input: `${PREFIX}-input`,
|
|
16
|
+
button: `${PREFIX}-button`,
|
|
17
|
+
error: `${PREFIX}-error`
|
|
18
|
+
};
|
|
19
|
+
function createStyleSheet(styles2) {
|
|
20
|
+
if (typeof window === "undefined") return defaultClassNames;
|
|
21
|
+
if (styleInjection.isInjected) {
|
|
22
|
+
return defaultClassNames;
|
|
23
|
+
}
|
|
24
|
+
let styleElement = document.querySelector("[data-tern-secure]");
|
|
25
|
+
if (!styleElement) {
|
|
26
|
+
styleElement = document.createElement("style");
|
|
27
|
+
styleElement.setAttribute("data-tern-secure", "");
|
|
28
|
+
document.head.appendChild(styleElement);
|
|
29
|
+
styleInjection.styleElement = styleElement;
|
|
30
|
+
}
|
|
31
|
+
const cssRules = Object.entries(styles2).map(([key, rules]) => {
|
|
32
|
+
const className = defaultClassNames[key];
|
|
33
|
+
const cssProperties = Object.entries(rules).map(([prop, value]) => {
|
|
34
|
+
const cssProperty = prop.replace(/([A-Z])/g, "-$1").toLowerCase();
|
|
35
|
+
return `${cssProperty}: ${value};`;
|
|
36
|
+
}).join(" ");
|
|
37
|
+
return `.${className} { ${cssProperties} }`;
|
|
38
|
+
}).join("\n");
|
|
39
|
+
styleElement.textContent = cssRules;
|
|
40
|
+
styleInjection.isInjected = true;
|
|
41
|
+
return defaultClassNames;
|
|
42
|
+
}
|
|
43
|
+
const styleConfig = {
|
|
44
|
+
container: {
|
|
45
|
+
display: "flex",
|
|
46
|
+
minHeight: "100%",
|
|
47
|
+
flex: "1",
|
|
48
|
+
flexDirection: "column",
|
|
49
|
+
justifyContent: "center",
|
|
50
|
+
padding: "3rem 1.5rem"
|
|
51
|
+
},
|
|
52
|
+
header: {
|
|
53
|
+
margin: "0 auto",
|
|
54
|
+
width: "100%",
|
|
55
|
+
maxWidth: "28rem"
|
|
56
|
+
},
|
|
57
|
+
title: {
|
|
58
|
+
marginTop: "1.5rem",
|
|
59
|
+
textAlign: "center",
|
|
60
|
+
fontSize: "1.875rem",
|
|
61
|
+
fontWeight: "700",
|
|
62
|
+
lineHeight: "2.25rem",
|
|
63
|
+
letterSpacing: "-0.025em",
|
|
64
|
+
color: "var(--tern-text-primary, #111827)"
|
|
65
|
+
},
|
|
66
|
+
formWrapper: {
|
|
67
|
+
marginTop: "2.5rem",
|
|
68
|
+
margin: "0 auto",
|
|
69
|
+
width: "100%",
|
|
70
|
+
maxWidth: "30rem"
|
|
71
|
+
},
|
|
72
|
+
formContainer: {
|
|
73
|
+
padding: "3rem 1.5rem",
|
|
74
|
+
boxShadow: "0 1px 3px 0 rgb(0 0 0 / 0.1)",
|
|
75
|
+
borderRadius: "0.5rem",
|
|
76
|
+
backgroundColor: "var(--tern-background, white)"
|
|
77
|
+
},
|
|
78
|
+
form: {
|
|
79
|
+
display: "flex",
|
|
80
|
+
flexDirection: "column",
|
|
81
|
+
gap: "1rem"
|
|
82
|
+
},
|
|
83
|
+
label: {
|
|
84
|
+
display: "block",
|
|
85
|
+
fontSize: "0.875rem",
|
|
86
|
+
fontWeight: "500",
|
|
87
|
+
color: "var(--tern-text-secondary, #374151)"
|
|
88
|
+
},
|
|
89
|
+
input: {
|
|
90
|
+
marginTop: "0.25rem",
|
|
91
|
+
display: "block",
|
|
92
|
+
width: "100%",
|
|
93
|
+
padding: "0.5rem 0.75rem",
|
|
94
|
+
borderRadius: "0.375rem",
|
|
95
|
+
border: "1px solid var(--tern-border, #D1D5DB)",
|
|
96
|
+
backgroundColor: "var(--tern-input-background, white)",
|
|
97
|
+
color: "var(--tern-text-primary, #111827)"
|
|
98
|
+
},
|
|
99
|
+
button: {
|
|
100
|
+
display: "flex",
|
|
101
|
+
width: "100%",
|
|
102
|
+
justifyContent: "center",
|
|
103
|
+
padding: "0.5rem 1rem",
|
|
104
|
+
fontSize: "0.875rem",
|
|
105
|
+
fontWeight: "500",
|
|
106
|
+
color: "white",
|
|
107
|
+
backgroundColor: "var(--tern-primary, #2563EB)",
|
|
108
|
+
border: "none",
|
|
109
|
+
borderRadius: "0.375rem",
|
|
110
|
+
cursor: "pointer"
|
|
111
|
+
},
|
|
112
|
+
error: {
|
|
113
|
+
color: "var(--tern-error, #DC2626)",
|
|
114
|
+
fontSize: "0.875rem"
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
const styles = createStyleSheet(styleConfig);
|
|
118
|
+
export {
|
|
119
|
+
defaultClassNames,
|
|
120
|
+
styleConfig,
|
|
121
|
+
styles
|
|
122
|
+
};
|
|
123
|
+
//# sourceMappingURL=create-styles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/utils/create-styles.ts"],"sourcesContent":["'use client'\r\n\r\nconst PREFIX = 'tern'\r\n\r\n// Singleton to track style injection\r\nconst styleInjection = {\r\n isInjected: false,\r\n styleElement: null as HTMLStyleElement | null\r\n}\r\n\r\nexport const defaultClassNames = {\r\n container: `${PREFIX}-container`,\r\n header: `${PREFIX}-header`,\r\n title: `${PREFIX}-title`,\r\n formWrapper: `${PREFIX}-formWrapper`,\r\n formContainer: `${PREFIX}-formContainer`,\r\n form: `${PREFIX}-form`,\r\n label: `${PREFIX}-label`,\r\n input: `${PREFIX}-input`,\r\n button: `${PREFIX}-button`,\r\n error: `${PREFIX}-error`\r\n} as const\r\n\r\n// Create styles once and cache them\r\nfunction createStyleSheet(styles: Record<string, React.CSSProperties>) {\r\n if (typeof window === 'undefined') return defaultClassNames\r\n\r\n // Return early if styles are already injected\r\n if (styleInjection.isInjected) {\r\n return defaultClassNames\r\n }\r\n\r\n // Find existing style element or create new one\r\n let styleElement = document.querySelector<HTMLStyleElement>('[data-tern-secure]')\r\n \r\n if (!styleElement) {\r\n styleElement = document.createElement('style')\r\n styleElement.setAttribute('data-tern-secure', '')\r\n document.head.appendChild(styleElement)\r\n styleInjection.styleElement = styleElement\r\n }\r\n\r\n // Create CSS rules\r\n const cssRules = Object.entries(styles).map(([key, rules]) => {\r\n const className = defaultClassNames[key as keyof typeof defaultClassNames]\r\n const cssProperties = Object.entries(rules).map(([prop, value]) => {\r\n const cssProperty = prop.replace(/([A-Z])/g, '-$1').toLowerCase()\r\n return `${cssProperty}: ${value};`\r\n }).join(' ')\r\n\r\n return `.${className} { ${cssProperties} }`\r\n }).join('\\n')\r\n\r\n // Insert styles only once\r\n styleElement.textContent = cssRules\r\n styleInjection.isInjected = true\r\n\r\n return defaultClassNames\r\n}\r\n\r\n// Style configuration\r\nexport const styleConfig = {\r\n container: {\r\n display: 'flex',\r\n minHeight: '100%',\r\n flex: '1',\r\n flexDirection: 'column',\r\n justifyContent: 'center',\r\n padding: '3rem 1.5rem'\r\n },\r\n header: {\r\n margin: '0 auto',\r\n width: '100%',\r\n maxWidth: '28rem'\r\n },\r\n title: {\r\n marginTop: '1.5rem',\r\n textAlign: 'center',\r\n fontSize: '1.875rem',\r\n fontWeight: '700',\r\n lineHeight: '2.25rem',\r\n letterSpacing: '-0.025em',\r\n color: 'var(--tern-text-primary, #111827)'\r\n },\r\n formWrapper: {\r\n marginTop: '2.5rem',\r\n margin: '0 auto',\r\n width: '100%',\r\n maxWidth: '30rem'\r\n },\r\n formContainer: {\r\n padding: '3rem 1.5rem',\r\n boxShadow: '0 1px 3px 0 rgb(0 0 0 / 0.1)',\r\n borderRadius: '0.5rem',\r\n backgroundColor: 'var(--tern-background, white)'\r\n },\r\n form: {\r\n display: 'flex',\r\n flexDirection: 'column',\r\n gap: '1rem'\r\n },\r\n label: {\r\n display: 'block',\r\n fontSize: '0.875rem',\r\n fontWeight: '500',\r\n color: 'var(--tern-text-secondary, #374151)'\r\n },\r\n input: {\r\n marginTop: '0.25rem',\r\n display: 'block',\r\n width: '100%',\r\n padding: '0.5rem 0.75rem',\r\n borderRadius: '0.375rem',\r\n border: '1px solid var(--tern-border, #D1D5DB)',\r\n backgroundColor: 'var(--tern-input-background, white)',\r\n color: 'var(--tern-text-primary, #111827)'\r\n },\r\n button: {\r\n display: 'flex',\r\n width: '100%',\r\n justifyContent: 'center',\r\n padding: '0.5rem 1rem',\r\n fontSize: '0.875rem',\r\n fontWeight: '500',\r\n color: 'white',\r\n backgroundColor: 'var(--tern-primary, #2563EB)',\r\n border: 'none',\r\n borderRadius: '0.375rem',\r\n cursor: 'pointer'\r\n },\r\n error: {\r\n color: 'var(--tern-error, #DC2626)',\r\n fontSize: '0.875rem'\r\n }\r\n} as const\r\n\r\n// Export pre-created styles\r\nexport const styles = createStyleSheet(styleConfig)\r\n\r\n"],"mappings":";AAEA,MAAM,SAAS;AAGf,MAAM,iBAAiB;AAAA,EACrB,YAAY;AAAA,EACZ,cAAc;AAChB;AAEO,MAAM,oBAAoB;AAAA,EAC/B,WAAW,GAAG,MAAM;AAAA,EACpB,QAAQ,GAAG,MAAM;AAAA,EACjB,OAAO,GAAG,MAAM;AAAA,EAChB,aAAa,GAAG,MAAM;AAAA,EACtB,eAAe,GAAG,MAAM;AAAA,EACxB,MAAM,GAAG,MAAM;AAAA,EACf,OAAO,GAAG,MAAM;AAAA,EAChB,OAAO,GAAG,MAAM;AAAA,EAChB,QAAQ,GAAG,MAAM;AAAA,EACjB,OAAO,GAAG,MAAM;AAClB;AAGA,SAAS,iBAAiBA,SAA6C;AACrE,MAAI,OAAO,WAAW,YAAa,QAAO;AAG1C,MAAI,eAAe,YAAY;AAC7B,WAAO;AAAA,EACT;AAGA,MAAI,eAAe,SAAS,cAAgC,oBAAoB;AAEhF,MAAI,CAAC,cAAc;AACjB,mBAAe,SAAS,cAAc,OAAO;AAC7C,iBAAa,aAAa,oBAAoB,EAAE;AAChD,aAAS,KAAK,YAAY,YAAY;AACtC,mBAAe,eAAe;AAAA,EAChC;AAGA,QAAM,WAAW,OAAO,QAAQA,OAAM,EAAE,IAAI,CAAC,CAAC,KAAK,KAAK,MAAM;AAC5D,UAAM,YAAY,kBAAkB,GAAqC;AACzE,UAAM,gBAAgB,OAAO,QAAQ,KAAK,EAAE,IAAI,CAAC,CAAC,MAAM,KAAK,MAAM;AACjE,YAAM,cAAc,KAAK,QAAQ,YAAY,KAAK,EAAE,YAAY;AAChE,aAAO,GAAG,WAAW,KAAK,KAAK;AAAA,IACjC,CAAC,EAAE,KAAK,GAAG;AAEX,WAAO,IAAI,SAAS,MAAM,aAAa;AAAA,EACzC,CAAC,EAAE,KAAK,IAAI;AAGZ,eAAa,cAAc;AAC3B,iBAAe,aAAa;AAE5B,SAAO;AACT;AAGO,MAAM,cAAc;AAAA,EACzB,WAAW;AAAA,IACT,SAAS;AAAA,IACT,WAAW;AAAA,IACX,MAAM;AAAA,IACN,eAAe;AAAA,IACf,gBAAgB;AAAA,IAChB,SAAS;AAAA,EACX;AAAA,EACA,QAAQ;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,UAAU;AAAA,EACZ;AAAA,EACA,OAAO;AAAA,IACL,WAAW;AAAA,IACX,WAAW;AAAA,IACX,UAAU;AAAA,IACV,YAAY;AAAA,IACZ,YAAY;AAAA,IACZ,eAAe;AAAA,IACf,OAAO;AAAA,EACT;AAAA,EACA,aAAa;AAAA,IACX,WAAW;AAAA,IACX,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,UAAU;AAAA,EACZ;AAAA,EACA,eAAe;AAAA,IACb,SAAS;AAAA,IACT,WAAW;AAAA,IACX,cAAc;AAAA,IACd,iBAAiB;AAAA,EACnB;AAAA,EACA,MAAM;AAAA,IACJ,SAAS;AAAA,IACT,eAAe;AAAA,IACf,KAAK;AAAA,EACP;AAAA,EACA,OAAO;AAAA,IACL,SAAS;AAAA,IACT,UAAU;AAAA,IACV,YAAY;AAAA,IACZ,OAAO;AAAA,EACT;AAAA,EACA,OAAO;AAAA,IACL,WAAW;AAAA,IACX,SAAS;AAAA,IACT,OAAO;AAAA,IACP,SAAS;AAAA,IACT,cAAc;AAAA,IACd,QAAQ;AAAA,IACR,iBAAiB;AAAA,IACjB,OAAO;AAAA,EACT;AAAA,EACA,QAAQ;AAAA,IACN,SAAS;AAAA,IACT,OAAO;AAAA,IACP,gBAAgB;AAAA,IAChB,SAAS;AAAA,IACT,UAAU;AAAA,IACV,YAAY;AAAA,IACZ,OAAO;AAAA,IACP,iBAAiB;AAAA,IACjB,QAAQ;AAAA,IACR,cAAc;AAAA,IACd,QAAQ;AAAA,EACV;AAAA,EACA,OAAO;AAAA,IACL,OAAO;AAAA,IACP,UAAU;AAAA,EACZ;AACF;AAGO,MAAM,SAAS,iBAAiB,WAAW;","names":["styles"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tern-secure/nextjs",
|
|
3
|
-
"version": "3.1.
|
|
3
|
+
"version": "3.1.78",
|
|
4
4
|
"packageManager": "npm@10.9.0",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"publishConfig": {
|
|
@@ -58,12 +58,12 @@
|
|
|
58
58
|
},
|
|
59
59
|
"exports": {
|
|
60
60
|
".": {
|
|
61
|
-
"types": "./dist/esm/index.
|
|
61
|
+
"types": "./dist/esm/index.js",
|
|
62
62
|
"import": "./dist/esm/index.js",
|
|
63
63
|
"require": "./dist/cjs/index.js"
|
|
64
64
|
},
|
|
65
65
|
"./server": {
|
|
66
|
-
"types": "./dist/esm/server/index.
|
|
66
|
+
"types": "./dist/esm/server/index.js",
|
|
67
67
|
"import": "./dist/esm/server/index.js",
|
|
68
68
|
"require": "./dist/cjs/server/index.js"
|
|
69
69
|
}
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
'use strict';var R=require('react'),app=require('firebase/app'),auth=require('firebase/auth'),firestore=require('firebase/firestore'),storage=require('firebase/storage'),jsxRuntime=require('react/jsx-runtime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var R__default=/*#__PURE__*/_interopDefault(R);var d=()=>({apiKey:process.env.NEXT_PUBLIC_FIREBASE_API_KEY||"",authDomain:process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN||"",projectId:process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID||"",storageBucket:process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET||"",messagingSenderId:process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID||"",appId:process.env.NEXT_PUBLIC_FIREBASE_APP_ID||"",measurementId:process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID||void 0}),E=e=>{let r=["apiKey","authDomain","projectId","storageBucket","messagingSenderId","appId"],t=[];return r.forEach(n=>{e[n]||t.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(n).toUpperCase()}`);}),{isValid:t.length===0,errors:t,config:e}},s=()=>{let e=d(),r=E(e);if(!r.isValid)throw new Error(`Firebase configuration validation failed:
|
|
2
|
-
${r.errors.join(`
|
|
3
|
-
`)}`);return e};var m=s(),o=app.initializeApp(m),c=auth.getAuth(o);auth.setPersistence(c,auth.browserSessionPersistence);firestore.getFirestore(o);storage.getStorage(o);var u=()=>c;var A=Symbol("TERN_SECURE_CONTEXT"),a=R.createContext(null);a.displayName="TernSecureContext";function l({children:e}){return jsxRuntime.jsx(a.Provider,{value:{_contextKey:A},children:e})}var B=R__default.default.createContext(null),F=u();function H({children:e,initialState:r}){let[t,n]=R.useState(r);return R.useEffect(()=>{let p=auth.onAuthStateChanged(F,i=>{n(i?{loading:!1,isSignedIn:!0,userId:i.uid,error:null}:{loading:!1,isSignedIn:!1,userId:null,error:null});});return ()=>p()},[]),jsxRuntime.jsx(l,{children:jsxRuntime.jsx(B.Provider,{value:t,children:e})})}exports.AuthStateContext=B;exports.TernSecureClientProvider=H;
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
'use strict';var h=require('react'),app=require('firebase/app'),auth=require('firebase/auth'),firestore=require('firebase/firestore'),storage=require('firebase/storage'),jsxRuntime=require('react/jsx-runtime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var h__default=/*#__PURE__*/_interopDefault(h);var f=()=>({apiKey:process.env.NEXT_PUBLIC_FIREBASE_API_KEY||"",authDomain:process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN||"",projectId:process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID||"",storageBucket:process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET||"",messagingSenderId:process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID||"",appId:process.env.NEXT_PUBLIC_FIREBASE_APP_ID||"",measurementId:process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID||void 0}),C=e=>{let r=["apiKey","authDomain","projectId","storageBucket","messagingSenderId","appId"],t=[];return r.forEach(n=>{e[n]||t.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(n).toUpperCase()}`);}),{isValid:t.length===0,errors:t,config:e}},a=()=>{let e=f(),r=C(e);if(!r.isValid)throw new Error(`Firebase configuration validation failed:
|
|
2
|
-
${r.errors.join(`
|
|
3
|
-
`)}`);return e};var v=a(),i=app.initializeApp(v),c=auth.getAuth(i);auth.setPersistence(c,auth.browserSessionPersistence);firestore.getFirestore(i);storage.getStorage(i);var u=()=>c;var R=Symbol("TERN_SECURE_CONTEXT"),l=h.createContext(null);l.displayName="TernSecureContext";function S({children:e}){return jsxRuntime.jsx(l.Provider,{value:{_contextKey:R},children:e})}var U=h__default.default.createContext(null),b=u();function p({children:e,initialState:r}){let[t,n]=h.useState(r);return h.useEffect(()=>{let T=auth.onAuthStateChanged(b,s=>{n(s?{loading:!1,isSignedIn:!0,userId:s.uid,error:null}:{loading:!1,isSignedIn:!1,userId:null,error:null});});return ()=>T()},[]),jsxRuntime.jsx(S,{children:jsxRuntime.jsx(U.Provider,{value:t,children:e})})}function L(){return jsxRuntime.jsx("div",{"aria-label":"Loading authentication",role:"status",className:"tern-secure-loading",children:jsxRuntime.jsx("span",{className:"sr-only",children:"Loading authentication..."})})}function oe({children:e}){let r={loading:!0,isSignedIn:!1,userId:null,error:null};return jsxRuntime.jsx(h__default.default.Suspense,{fallback:jsxRuntime.jsx(L,{}),children:jsxRuntime.jsx(p,{initialState:r,children:e})})}exports.TernSecureServerProvider=oe;
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
'use strict';var app=require('firebase/app'),auth=require('firebase/auth'),firestore=require('firebase/firestore'),storage=require('firebase/storage');var c=()=>({apiKey:process.env.NEXT_PUBLIC_FIREBASE_API_KEY||"",authDomain:process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN||"",projectId:process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID||"",storageBucket:process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET||"",messagingSenderId:process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID||"",appId:process.env.NEXT_PUBLIC_FIREBASE_APP_ID||"",measurementId:process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID||void 0}),p=e=>{let r=["apiKey","authDomain","projectId","storageBucket","messagingSenderId","appId"],n=[];return r.forEach(o=>{e[o]||n.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(o).toUpperCase()}`);}),{isValid:n.length===0,errors:n,config:e}},t=()=>{let e=c(),r=p(e);if(!r.isValid)throw new Error(`Firebase configuration validation failed:
|
|
2
|
-
${r.errors.join(`
|
|
3
|
-
`)}`);return e};var f=t(),i=app.initializeApp(f),s=auth.getAuth(i);auth.setPersistence(s,auth.browserSessionPersistence);firestore.getFirestore(i);storage.getStorage(i);var a=()=>s;async function N({email:e,password:r}){let n=a();return auth.signInWithEmailAndPassword(n,e,r)}exports.signInWithEmail=N;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
'use strict';var react=require('react'),jsxRuntime=require('react/jsx-runtime');var c=Symbol("TERN_SECURE_CONTEXT"),t=react.createContext(null);t.displayName="TernSecureContext";var l=e=>{let r=react.useContext(t);if(!r)throw new Error(`${e} must be used within TernSecureProvider`);return r};function T({children:e}){return jsxRuntime.jsx(t.Provider,{value:{_contextKey:c},children:e})}exports.TernSecureCtxProvider=T;exports.useInternalContext=l;
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
'use strict';var x=require('react');require('react/jsx-runtime');var app=require('firebase/app'),auth=require('firebase/auth'),firestore=require('firebase/firestore'),storage=require('firebase/storage');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var x__default=/*#__PURE__*/_interopDefault(x);var i=x.createContext(null);i.displayName="TernSecureContext";var s=e=>{let r=x.useContext(i);if(!r)throw new Error(`${e} must be used within TernSecureProvider`);return r};var p=()=>({apiKey:process.env.NEXT_PUBLIC_FIREBASE_API_KEY||"",authDomain:process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN||"",projectId:process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID||"",storageBucket:process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET||"",messagingSenderId:process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID||"",appId:process.env.NEXT_PUBLIC_FIREBASE_APP_ID||"",measurementId:process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID||void 0}),f=e=>{let r=["apiKey","authDomain","projectId","storageBucket","messagingSenderId","appId"],t=[];return r.forEach(o=>{e[o]||t.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(o).toUpperCase()}`);}),{isValid:t.length===0,errors:t,config:e}},u=()=>{let e=p(),r=f(e);if(!r.isValid)throw new Error(`Firebase configuration validation failed:
|
|
2
|
-
${r.errors.join(`
|
|
3
|
-
`)}`);return e};var m=u(),n=app.initializeApp(m),c=auth.getAuth(n);auth.setPersistence(c,auth.browserSessionPersistence);firestore.getFirestore(n);storage.getStorage(n);var S=x__default.default.createContext(null);function Q(){s("useAuth");let e=x.useContext(S);if(!e)throw new Error("Auth state not found");return {userId:e.userId,loading:e.loading,error:e.error,isSignedIn:e.isSignedIn}}exports.useAuth=Q;
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
'use strict';var react=require('react'),app=require('firebase/app'),auth=require('firebase/auth'),firestore=require('firebase/firestore'),storage=require('firebase/storage'),jsxRuntime=require('react/jsx-runtime');var P=()=>({apiKey:process.env.NEXT_PUBLIC_FIREBASE_API_KEY||"",authDomain:process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN||"",projectId:process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID||"",storageBucket:process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET||"",messagingSenderId:process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID||"",appId:process.env.NEXT_PUBLIC_FIREBASE_APP_ID||"",measurementId:process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID||void 0}),R=n=>{let e=["apiKey","authDomain","projectId","storageBucket","messagingSenderId","appId"],i=[];return e.forEach(s=>{n[s]||i.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(s).toUpperCase()}`);}),{isValid:i.length===0,errors:i,config:n}},y=()=>{let n=P(),e=R(n);if(!e.isValid)throw new Error(`Firebase configuration validation failed:
|
|
2
|
-
${e.errors.join(`
|
|
3
|
-
`)}`);return n};var j=y(),C=app.initializeApp(j),_=auth.getAuth(C);auth.setPersistence(_,auth.browserSessionPersistence);firestore.getFirestore(C);storage.getStorage(C);var x=()=>_;async function T({email:n,password:e}){let i=x();return auth.signInWithEmailAndPassword(i,n,e)}var o="tern",S={isInjected:!1,styleElement:null},f={container:`${o}-container`,header:`${o}-header`,title:`${o}-title`,formWrapper:`${o}-formWrapper`,formContainer:`${o}-formContainer`,form:`${o}-form`,label:`${o}-label`,input:`${o}-input`,button:`${o}-button`,error:`${o}-error`};function k(n){if(typeof window>"u"||S.isInjected)return f;let e=document.querySelector("[data-tern-secure]");e||(e=document.createElement("style"),e.setAttribute("data-tern-secure",""),document.head.appendChild(e),S.styleElement=e);let i=Object.entries(n).map(([s,h])=>{let r=f[s],d=Object.entries(h).map(([b,c])=>`${b.replace(/([A-Z])/g,"-$1").toLowerCase()}: ${c};`).join(" ");return `.${r} { ${d} }`}).join(`
|
|
4
|
-
`);return e.textContent=i,S.isInjected=!0,f}var X={container:{display:"flex",minHeight:"100%",flex:"1",flexDirection:"column",justifyContent:"center",padding:"3rem 1.5rem"},header:{margin:"0 auto",width:"100%",maxWidth:"28rem"},title:{marginTop:"1.5rem",textAlign:"center",fontSize:"1.875rem",fontWeight:"700",lineHeight:"2.25rem",letterSpacing:"-0.025em",color:"var(--tern-text-primary, #111827)"},formWrapper:{marginTop:"2.5rem",margin:"0 auto",width:"100%",maxWidth:"30rem"},formContainer:{padding:"3rem 1.5rem",boxShadow:"0 1px 3px 0 rgb(0 0 0 / 0.1)",borderRadius:"0.5rem",backgroundColor:"var(--tern-background, white)"},form:{display:"flex",flexDirection:"column",gap:"1rem"},label:{display:"block",fontSize:"0.875rem",fontWeight:"500",color:"var(--tern-text-secondary, #374151)"},input:{marginTop:"0.25rem",display:"block",width:"100%",padding:"0.5rem 0.75rem",borderRadius:"0.375rem",border:"1px solid var(--tern-border, #D1D5DB)",backgroundColor:"var(--tern-input-background, white)",color:"var(--tern-text-primary, #111827)"},button:{display:"flex",width:"100%",justifyContent:"center",padding:"0.5rem 1rem",fontSize:"0.875rem",fontWeight:"500",color:"white",backgroundColor:"var(--tern-primary, #2563EB)",border:"none",borderRadius:"0.375rem",cursor:"pointer"},error:{color:"var(--tern-error, #DC2626)",fontSize:"0.875rem"}},t=k(X);function ie({onSuccess:n,onError:e,redirectUrl:i,className:s="",style:h,customStyles:r={}}){let[d,b]=react.useState(""),[c,v]=react.useState(""),[m,I]=react.useState(!1),[p,$]=react.useState(""),N=async l=>{l.preventDefault(),I(!0),$("");try{await T({email:d,password:c}),n?.(),i&&(window.location.href=i);}catch(u){let w=u instanceof Error?u.message:"Failed to sign in";$(w),e?.(u instanceof Error?u:new Error("Failed to sign in"));}finally{I(!1);}};return jsxRuntime.jsxs("div",{className:`${t.container} ${r.container||""}`,style:h,children:[jsxRuntime.jsx("div",{className:`${t.header} ${r.header||""}`,children:jsxRuntime.jsx("h2",{className:`${t.title} ${r.title||""}`,children:"Sign in to your account"})}),jsxRuntime.jsx("div",{className:`${t.formWrapper} ${r.formWrapper||""}`,children:jsxRuntime.jsx("div",{className:`${t.formContainer} ${r.formContainer||""}`,children:jsxRuntime.jsxs("form",{onSubmit:N,className:`${t.form} ${r.form||""} ${s}`,role:"form","aria-label":"Sign in form",children:[p&&jsxRuntime.jsx("div",{className:`${t.error} ${r.errorText||""}`,role:"alert","aria-live":"polite",children:p}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{htmlFor:"email",className:`${t.label} ${r.label||""}`,children:"Email"}),jsxRuntime.jsx("input",{id:"email",type:"email",value:d,onChange:l=>b(l.target.value),placeholder:"Enter your email",required:!0,className:`${t.input} ${r.input||""}`,disabled:m,"aria-required":"true","aria-invalid":!!p})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{htmlFor:"password",className:`${t.label} ${r.label||""}`,children:"Password"}),jsxRuntime.jsx("input",{id:"password",type:"password",value:c,onChange:l=>v(l.target.value),placeholder:"Enter your password",required:!0,className:`${t.input} ${r.input||""}`,disabled:m,"aria-required":"true","aria-invalid":!!p})]}),jsxRuntime.jsx("button",{type:"submit",disabled:m,className:`${t.button} ${r.button||""}`,"data-testid":"sign-in-submit",children:m?"Signing in...":"Sign in"})]})})})]})}exports.SignIn=ie;
|
package/dist/cjs/errors.cjs
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
'use strict';var t={SERVER_SIDE_INITIALIZATION:"TernSecure must be initialized on the client side",NOT_INITIALIZED:"TernSecure services are not initialized. Call initializeTernSecure() first",HOOK_CONTEXT:e=>`${e} must be used within TernSecureProvider`},r=class extends Error{constructor(i){super(i),this.name="TernSecureError";}};exports.ERRORS=t;exports.TernSecureError=r;
|
package/dist/cjs/index.cjs
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
'use strict';var Q=require('react'),app=require('firebase/app'),auth=require('firebase/auth'),firestore=require('firebase/firestore'),storage=require('firebase/storage'),jsxRuntime=require('react/jsx-runtime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var Q__default=/*#__PURE__*/_interopDefault(Q);var _=()=>({apiKey:process.env.NEXT_PUBLIC_FIREBASE_API_KEY||"",authDomain:process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN||"",projectId:process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID||"",storageBucket:process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET||"",messagingSenderId:process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID||"",appId:process.env.NEXT_PUBLIC_FIREBASE_APP_ID||"",measurementId:process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID||void 0}),R=e=>{let r=["apiKey","authDomain","projectId","storageBucket","messagingSenderId","appId"],o=[];return r.forEach(s=>{e[s]||o.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(s).toUpperCase()}`);}),{isValid:o.length===0,errors:o,config:e}},A=()=>{let e=_(),r=R(e);if(!r.isValid)throw new Error(`Firebase configuration validation failed:
|
|
2
|
-
${r.errors.join(`
|
|
3
|
-
`)}`);return e};var O=A(),E=app.initializeApp(O),w=auth.getAuth(E);auth.setPersistence(w,auth.browserSessionPersistence);var V=firestore.getFirestore(E);storage.getStorage(E);var u=()=>w,H=()=>V;var J=Symbol("TERN_SECURE_CONTEXT"),x=Q.createContext(null);x.displayName="TernSecureContext";var F=e=>{let r=Q.useContext(x);if(!r)throw new Error(`${e} must be used within TernSecureProvider`);return r};function B({children:e}){return jsxRuntime.jsx(x.Provider,{value:{_contextKey:J},children:e})}var I=Q__default.default.createContext(null),ne=u();function D({children:e,initialState:r}){let[o,s]=Q.useState(r);return Q.useEffect(()=>{let l=auth.onAuthStateChanged(ne,t=>{s(t?{loading:!1,isSignedIn:!0,userId:t.uid,error:null}:{loading:!1,isSignedIn:!1,userId:null,error:null});});return ()=>l()},[]),jsxRuntime.jsx(B,{children:jsxRuntime.jsx(I.Provider,{value:o,children:e})})}function ie(){return jsxRuntime.jsx("div",{"aria-label":"Loading authentication",role:"status",className:"tern-secure-loading",children:jsxRuntime.jsx("span",{className:"sr-only",children:"Loading authentication..."})})}function U({children:e}){let r={loading:!0,isSignedIn:!1,userId:null,error:null};return jsxRuntime.jsx(Q__default.default.Suspense,{fallback:jsxRuntime.jsx(ie,{}),children:jsxRuntime.jsx(D,{initialState:r,children:e})})}async function b({email:e,password:r}){let o=u();return auth.signInWithEmailAndPassword(o,e,r)}function le(){F("useAuth");let e=Q.useContext(I);if(!e)throw new Error("Auth state not found");return {userId:e.userId,loading:e.loading,error:e.error,isSignedIn:e.isSignedIn}}var i="tern",P={isInjected:!1,styleElement:null},C={container:`${i}-container`,header:`${i}-header`,title:`${i}-title`,formWrapper:`${i}-formWrapper`,formContainer:`${i}-formContainer`,form:`${i}-form`,label:`${i}-label`,input:`${i}-input`,button:`${i}-button`,error:`${i}-error`};function ce(e){if(typeof window>"u"||P.isInjected)return C;let r=document.querySelector("[data-tern-secure]");r||(r=document.createElement("style"),r.setAttribute("data-tern-secure",""),document.head.appendChild(r),P.styleElement=r);let o=Object.entries(e).map(([s,l])=>{let t=C[s],p=Object.entries(l).map(([T,m])=>`${T.replace(/([A-Z])/g,"-$1").toLowerCase()}: ${m};`).join(" ");return `.${t} { ${p} }`}).join(`
|
|
4
|
-
`);return r.textContent=o,P.isInjected=!0,C}var ue={container:{display:"flex",minHeight:"100%",flex:"1",flexDirection:"column",justifyContent:"center",padding:"3rem 1.5rem"},header:{margin:"0 auto",width:"100%",maxWidth:"28rem"},title:{marginTop:"1.5rem",textAlign:"center",fontSize:"1.875rem",fontWeight:"700",lineHeight:"2.25rem",letterSpacing:"-0.025em",color:"var(--tern-text-primary, #111827)"},formWrapper:{marginTop:"2.5rem",margin:"0 auto",width:"100%",maxWidth:"30rem"},formContainer:{padding:"3rem 1.5rem",boxShadow:"0 1px 3px 0 rgb(0 0 0 / 0.1)",borderRadius:"0.5rem",backgroundColor:"var(--tern-background, white)"},form:{display:"flex",flexDirection:"column",gap:"1rem"},label:{display:"block",fontSize:"0.875rem",fontWeight:"500",color:"var(--tern-text-secondary, #374151)"},input:{marginTop:"0.25rem",display:"block",width:"100%",padding:"0.5rem 0.75rem",borderRadius:"0.375rem",border:"1px solid var(--tern-border, #D1D5DB)",backgroundColor:"var(--tern-input-background, white)",color:"var(--tern-text-primary, #111827)"},button:{display:"flex",width:"100%",justifyContent:"center",padding:"0.5rem 1rem",fontSize:"0.875rem",fontWeight:"500",color:"white",backgroundColor:"var(--tern-primary, #2563EB)",border:"none",borderRadius:"0.375rem",cursor:"pointer"},error:{color:"var(--tern-error, #DC2626)",fontSize:"0.875rem"}},n=ce(ue);function de({onSuccess:e,onError:r,redirectUrl:o,className:s="",style:l,customStyles:t={}}){let[p,T]=Q.useState(""),[m,y]=Q.useState(""),[f,$]=Q.useState(!1),[S,N]=Q.useState(""),W=async c=>{c.preventDefault(),$(!0),N("");try{await b({email:p,password:m}),e?.(),o&&(window.location.href=o);}catch(g){let k=g instanceof Error?g.message:"Failed to sign in";N(k),r?.(g instanceof Error?g:new Error("Failed to sign in"));}finally{$(!1);}};return jsxRuntime.jsxs("div",{className:`${n.container} ${t.container||""}`,style:l,children:[jsxRuntime.jsx("div",{className:`${n.header} ${t.header||""}`,children:jsxRuntime.jsx("h2",{className:`${n.title} ${t.title||""}`,children:"Sign in to your account"})}),jsxRuntime.jsx("div",{className:`${n.formWrapper} ${t.formWrapper||""}`,children:jsxRuntime.jsx("div",{className:`${n.formContainer} ${t.formContainer||""}`,children:jsxRuntime.jsxs("form",{onSubmit:W,className:`${n.form} ${t.form||""} ${s}`,role:"form","aria-label":"Sign in form",children:[S&&jsxRuntime.jsx("div",{className:`${n.error} ${t.errorText||""}`,role:"alert","aria-live":"polite",children:S}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{htmlFor:"email",className:`${n.label} ${t.label||""}`,children:"Email"}),jsxRuntime.jsx("input",{id:"email",type:"email",value:p,onChange:c=>T(c.target.value),placeholder:"Enter your email",required:!0,className:`${n.input} ${t.input||""}`,disabled:f,"aria-required":"true","aria-invalid":!!S})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{htmlFor:"password",className:`${n.label} ${t.label||""}`,children:"Password"}),jsxRuntime.jsx("input",{id:"password",type:"password",value:m,onChange:c=>y(c.target.value),placeholder:"Enter your password",required:!0,className:`${n.input} ${t.input||""}`,disabled:f,"aria-required":"true","aria-invalid":!!S})]}),jsxRuntime.jsx("button",{type:"submit",disabled:f,className:`${n.button} ${t.button||""}`,"data-testid":"sign-in-submit",children:f?"Signing in...":"Sign in"})]})})})]})}var Ge=U;exports.SignIn=de;exports.TernSecureAuth=u;exports.TernSecureFirestore=H;exports.TernSecureProvider=Ge;exports.loadFireConfig=_;exports.signInWithEmail=b;exports.useAuth=le;exports.validateConfig=R;
|
package/dist/cjs/types.cjs
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
'use strict';var app=require('firebase/app'),auth=require('firebase/auth'),firestore=require('firebase/firestore'),storage=require('firebase/storage');var c=()=>({apiKey:process.env.NEXT_PUBLIC_FIREBASE_API_KEY||"",authDomain:process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN||"",projectId:process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID||"",storageBucket:process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET||"",messagingSenderId:process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID||"",appId:process.env.NEXT_PUBLIC_FIREBASE_APP_ID||"",measurementId:process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID||void 0}),a=e=>{let r=["apiKey","authDomain","projectId","storageBucket","messagingSenderId","appId"],o=[];return r.forEach(i=>{e[i]||o.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(i).toUpperCase()}`);}),{isValid:o.length===0,errors:o,config:e}},t=()=>{let e=c(),r=a(e);if(!r.isValid)throw new Error(`Firebase configuration validation failed:
|
|
2
|
-
${r.errors.join(`
|
|
3
|
-
`)}`);return e};var f=t(),n=app.initializeApp(f),s=auth.getAuth(n);auth.setPersistence(s,auth.browserSessionPersistence);var u=firestore.getFirestore(n),d=storage.getStorage(n),R=()=>s,P=()=>u,F=()=>d;exports.TernSecureAuth=R;exports.TernSecureFirestore=P;exports.TernSecureStorage=F;
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
'use strict';var o=()=>({apiKey:process.env.NEXT_PUBLIC_FIREBASE_API_KEY||"",authDomain:process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN||"",projectId:process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID||"",storageBucket:process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET||"",messagingSenderId:process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID||"",appId:process.env.NEXT_PUBLIC_FIREBASE_APP_ID||"",measurementId:process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID||void 0}),s=e=>{let n=["apiKey","authDomain","projectId","storageBucket","messagingSenderId","appId"],r=[];return n.forEach(i=>{e[i]||r.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(i).toUpperCase()}`);}),{isValid:r.length===0,errors:r,config:e}},t=()=>{let e=o(),n=s(e);if(!n.isValid)throw new Error(`Firebase configuration validation failed:
|
|
2
|
-
${n.errors.join(`
|
|
3
|
-
`)}`);return e};exports.initializeConfig=t;exports.loadFireConfig=o;exports.validateConfig=s;
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
'use strict';var e="tern",n={isInjected:!1,styleElement:null},t={container:`${e}-container`,header:`${e}-header`,title:`${e}-title`,formWrapper:`${e}-formWrapper`,formContainer:`${e}-formContainer`,form:`${e}-form`,label:`${e}-label`,input:`${e}-input`,button:`${e}-button`,error:`${e}-error`};function p(o){if(typeof window>"u"||n.isInjected)return t;let r=document.querySelector("[data-tern-secure]");r||(r=document.createElement("style"),r.setAttribute("data-tern-secure",""),document.head.appendChild(r),n.styleElement=r);let i=Object.entries(o).map(([a,l])=>{let s=t[a],c=Object.entries(l).map(([m,d])=>`${m.replace(/([A-Z])/g,"-$1").toLowerCase()}: ${d};`).join(" ");return `.${s} { ${c} }`}).join(`
|
|
2
|
-
`);return r.textContent=i,n.isInjected=!0,t}var u={container:{display:"flex",minHeight:"100%",flex:"1",flexDirection:"column",justifyContent:"center",padding:"3rem 1.5rem"},header:{margin:"0 auto",width:"100%",maxWidth:"28rem"},title:{marginTop:"1.5rem",textAlign:"center",fontSize:"1.875rem",fontWeight:"700",lineHeight:"2.25rem",letterSpacing:"-0.025em",color:"var(--tern-text-primary, #111827)"},formWrapper:{marginTop:"2.5rem",margin:"0 auto",width:"100%",maxWidth:"30rem"},formContainer:{padding:"3rem 1.5rem",boxShadow:"0 1px 3px 0 rgb(0 0 0 / 0.1)",borderRadius:"0.5rem",backgroundColor:"var(--tern-background, white)"},form:{display:"flex",flexDirection:"column",gap:"1rem"},label:{display:"block",fontSize:"0.875rem",fontWeight:"500",color:"var(--tern-text-secondary, #374151)"},input:{marginTop:"0.25rem",display:"block",width:"100%",padding:"0.5rem 0.75rem",borderRadius:"0.375rem",border:"1px solid var(--tern-border, #D1D5DB)",backgroundColor:"var(--tern-input-background, white)",color:"var(--tern-text-primary, #111827)"},button:{display:"flex",width:"100%",justifyContent:"center",padding:"0.5rem 1rem",fontSize:"0.875rem",fontWeight:"500",color:"white",backgroundColor:"var(--tern-primary, #2563EB)",border:"none",borderRadius:"0.375rem",cursor:"pointer"},error:{color:"var(--tern-error, #DC2626)",fontSize:"0.875rem"}},y=p(u);exports.defaultClassNames=t;exports.styleConfig=u;exports.styles=y;
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
-
import React__default from 'react';
|
|
3
|
-
|
|
4
|
-
type TernSecureState = {
|
|
5
|
-
userId: string | null;
|
|
6
|
-
loading: boolean;
|
|
7
|
-
error: string | null;
|
|
8
|
-
isSignedIn: boolean;
|
|
9
|
-
};
|
|
10
|
-
declare const AuthStateContext: React__default.Context<TernSecureState | null>;
|
|
11
|
-
interface TernSecureClientProps {
|
|
12
|
-
children: React__default.ReactNode;
|
|
13
|
-
initialState: TernSecureState;
|
|
14
|
-
}
|
|
15
|
-
declare function TernSecureClientProvider({ children, initialState }: TernSecureClientProps): react_jsx_runtime.JSX.Element;
|
|
16
|
-
|
|
17
|
-
export { AuthStateContext, TernSecureClientProvider, type TernSecureState };
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
-
import React__default from 'react';
|
|
3
|
-
|
|
4
|
-
interface TernSecureServerProviderProps {
|
|
5
|
-
children: React__default.ReactNode;
|
|
6
|
-
}
|
|
7
|
-
/**
|
|
8
|
-
* Root Provider for TernSecure
|
|
9
|
-
* Use this in your Next.js App Router root layout
|
|
10
|
-
* Automatically handles client/server boundary and authentication state
|
|
11
|
-
*
|
|
12
|
-
* @example
|
|
13
|
-
* // app/layout.tsx
|
|
14
|
-
* import { TernSecureProvider } from '@tern/secure'
|
|
15
|
-
*
|
|
16
|
-
* export default function RootLayout({ children }) {
|
|
17
|
-
* return (
|
|
18
|
-
* <html>
|
|
19
|
-
* <body>
|
|
20
|
-
* <TernSecureProvider>
|
|
21
|
-
* {children}
|
|
22
|
-
* </TernSecureProvider>
|
|
23
|
-
* </body>
|
|
24
|
-
* </html>
|
|
25
|
-
* )
|
|
26
|
-
* }
|
|
27
|
-
*/
|
|
28
|
-
declare function TernSecureServerProvider({ children }: TernSecureServerProviderProps): react_jsx_runtime.JSX.Element;
|
|
29
|
-
|
|
30
|
-
export { TernSecureServerProvider, type TernSecureServerProviderProps };
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { UserCredential } from 'firebase/auth';
|
|
2
|
-
|
|
3
|
-
interface SignInCredentials {
|
|
4
|
-
email: string;
|
|
5
|
-
password: string;
|
|
6
|
-
}
|
|
7
|
-
declare function signInWithEmail({ email, password }: SignInCredentials): Promise<UserCredential>;
|
|
8
|
-
|
|
9
|
-
export { type SignInCredentials, signInWithEmail };
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
-
|
|
3
|
-
type TernSecureCtxValue = {
|
|
4
|
-
_contextKey: Symbol;
|
|
5
|
-
};
|
|
6
|
-
declare const useInternalContext: (hookname: string) => TernSecureCtxValue;
|
|
7
|
-
/**
|
|
8
|
-
* Provider component for TernSecure
|
|
9
|
-
* Must be used in client components only
|
|
10
|
-
*/
|
|
11
|
-
declare function TernSecureCtxProvider({ children }: {
|
|
12
|
-
children: React.ReactNode;
|
|
13
|
-
}): react_jsx_runtime.JSX.Element;
|
|
14
|
-
|
|
15
|
-
export { TernSecureCtxProvider, type TernSecureCtxValue, useInternalContext };
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
-
import * as React from 'react';
|
|
3
|
-
|
|
4
|
-
interface SignInProps {
|
|
5
|
-
onSuccess?: () => void;
|
|
6
|
-
onError?: (error: Error) => void;
|
|
7
|
-
redirectUrl?: string;
|
|
8
|
-
className?: string;
|
|
9
|
-
style?: React.CSSProperties;
|
|
10
|
-
customStyles?: {
|
|
11
|
-
container?: string;
|
|
12
|
-
header?: string;
|
|
13
|
-
title?: string;
|
|
14
|
-
formWrapper?: string;
|
|
15
|
-
formContainer?: string;
|
|
16
|
-
form?: string;
|
|
17
|
-
input?: string;
|
|
18
|
-
button?: string;
|
|
19
|
-
errorText?: string;
|
|
20
|
-
label?: string;
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
|
-
declare function SignIn({ onSuccess, onError, redirectUrl, className, style, customStyles }: SignInProps): react_jsx_runtime.JSX.Element;
|
|
24
|
-
|
|
25
|
-
export { SignIn, type SignInProps };
|
package/dist/esm/errors.d.ts
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
declare const ERRORS: {
|
|
2
|
-
readonly SERVER_SIDE_INITIALIZATION: "TernSecure must be initialized on the client side";
|
|
3
|
-
readonly NOT_INITIALIZED: "TernSecure services are not initialized. Call initializeTernSecure() first";
|
|
4
|
-
readonly HOOK_CONTEXT: (hookName: string) => string;
|
|
5
|
-
};
|
|
6
|
-
declare class TernSecureError extends Error {
|
|
7
|
-
constructor(message: string);
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
export { ERRORS, TernSecureError };
|
package/dist/esm/index.d.ts
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { TernSecureServerProvider } from './app-router/server/TernSecureServerProvider.js';
|
|
2
|
-
export { TernSecureState } from './app-router/client/TernSecureProvider.js';
|
|
3
|
-
export { TernSecureAuth, TernSecureFirestore } from './utils/client-init.js';
|
|
4
|
-
export { loadFireConfig, validateConfig } from './utils/config.js';
|
|
5
|
-
export { signInWithEmail } from './app-router/server/auth.js';
|
|
6
|
-
export { useAuth } from './boundary/hooks/useAuth.js';
|
|
7
|
-
export { SignIn } from './components/sign-in.js';
|
|
8
|
-
import 'react/jsx-runtime';
|
|
9
|
-
import 'react';
|
|
10
|
-
import '@firebase/storage';
|
|
11
|
-
import '@firebase/firestore';
|
|
12
|
-
import '@firebase/auth';
|
|
13
|
-
import './types.js';
|
|
14
|
-
import 'firebase/app';
|
|
15
|
-
import 'firebase/auth';
|
|
16
|
-
|
|
17
|
-
declare const TernSecureProvider: typeof TernSecureServerProvider;
|
|
18
|
-
|
|
19
|
-
export { TernSecureProvider };
|
package/dist/esm/types.d.ts
DELETED
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import { FirebaseOptions } from 'firebase/app';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* TernSecure Firebase configuration interface
|
|
5
|
-
* Extends Firebase's base configuration options
|
|
6
|
-
*/
|
|
7
|
-
interface TernSecureConfig extends FirebaseOptions {
|
|
8
|
-
apiKey: string;
|
|
9
|
-
authDomain: string;
|
|
10
|
-
projectId: string;
|
|
11
|
-
storageBucket: string;
|
|
12
|
-
messagingSenderId: string;
|
|
13
|
-
appId: string;
|
|
14
|
-
measurementId?: string;
|
|
15
|
-
}
|
|
16
|
-
/**
|
|
17
|
-
* TernSecure initialization options
|
|
18
|
-
*/
|
|
19
|
-
interface TernSecureOptions {
|
|
20
|
-
/** Environment setting for different configurations */
|
|
21
|
-
environment?: 'development' | 'production';
|
|
22
|
-
/** Geographic region for data storage */
|
|
23
|
-
region?: string;
|
|
24
|
-
/** Custom error handler */
|
|
25
|
-
onError?: (error: Error) => void;
|
|
26
|
-
/** Debug mode flag */
|
|
27
|
-
debug?: boolean;
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* Firebase initialization state
|
|
31
|
-
*/
|
|
32
|
-
interface FirebaseState {
|
|
33
|
-
/** Whether Firebase has been initialized */
|
|
34
|
-
initialized: boolean;
|
|
35
|
-
/** Any initialization errors */
|
|
36
|
-
error: Error | null;
|
|
37
|
-
/** Timestamp of last initialization attempt */
|
|
38
|
-
lastInitAttempt?: number;
|
|
39
|
-
}
|
|
40
|
-
/**
|
|
41
|
-
* Configuration validation result
|
|
42
|
-
*/
|
|
43
|
-
interface ConfigValidationResult {
|
|
44
|
-
isValid: boolean;
|
|
45
|
-
errors: string[];
|
|
46
|
-
config: TernSecureConfig;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
export type { ConfigValidationResult, FirebaseState, TernSecureConfig, TernSecureOptions };
|