@tern-secure/nextjs 3.1.76 → 3.1.77

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 (73) hide show
  1. package/dist/cjs/app-router/client/TernSecureProvider.js +75 -0
  2. package/dist/cjs/app-router/client/TernSecureProvider.js.map +1 -0
  3. package/dist/cjs/app-router/server/TernSecureServerProvider.js +63 -0
  4. package/dist/cjs/app-router/server/TernSecureServerProvider.js.map +1 -0
  5. package/dist/cjs/app-router/server/auth.js +37 -0
  6. package/dist/cjs/app-router/server/auth.js.map +1 -0
  7. package/dist/cjs/boundary/TernSecureCtx.js +50 -0
  8. package/dist/cjs/boundary/TernSecureCtx.js.map +1 -0
  9. package/dist/cjs/boundary/hooks/useAuth.js +45 -0
  10. package/dist/cjs/boundary/hooks/useAuth.js.map +1 -0
  11. package/dist/cjs/components/sign-in.js +132 -0
  12. package/dist/cjs/components/sign-in.js.map +1 -0
  13. package/dist/cjs/errors.js +41 -0
  14. package/dist/cjs/errors.js.map +1 -0
  15. package/dist/cjs/index.js +49 -0
  16. package/dist/cjs/index.js.map +1 -0
  17. package/dist/cjs/types.js +17 -0
  18. package/dist/cjs/types.js.map +1 -0
  19. package/dist/cjs/utils/client-init.js +46 -0
  20. package/dist/cjs/utils/client-init.js.map +1 -0
  21. package/dist/cjs/utils/config.js +73 -0
  22. package/dist/cjs/utils/config.js.map +1 -0
  23. package/dist/cjs/utils/create-styles.js +149 -0
  24. package/dist/cjs/utils/create-styles.js.map +1 -0
  25. package/dist/esm/app-router/client/TernSecureProvider.js +40 -3
  26. package/dist/esm/app-router/client/TernSecureProvider.js.map +1 -0
  27. package/dist/esm/app-router/server/TernSecureServerProvider.js +29 -3
  28. package/dist/esm/app-router/server/TernSecureServerProvider.js.map +1 -0
  29. package/dist/esm/app-router/server/auth.js +13 -3
  30. package/dist/esm/app-router/server/auth.js.map +1 -0
  31. package/dist/esm/boundary/TernSecureCtx.js +25 -1
  32. package/dist/esm/boundary/TernSecureCtx.js.map +1 -0
  33. package/dist/esm/boundary/hooks/useAuth.js +21 -3
  34. package/dist/esm/boundary/hooks/useAuth.js.map +1 -0
  35. package/dist/esm/components/sign-in.js +108 -4
  36. package/dist/esm/components/sign-in.js.map +1 -0
  37. package/dist/esm/errors.js +16 -1
  38. package/dist/esm/errors.js.map +1 -0
  39. package/dist/esm/index.js +18 -4
  40. package/dist/esm/index.js.map +1 -0
  41. package/dist/esm/types.js +1 -0
  42. package/dist/esm/types.js.map +1 -0
  43. package/dist/esm/utils/client-init.js +20 -3
  44. package/dist/esm/utils/client-init.js.map +1 -0
  45. package/dist/esm/utils/config.js +47 -3
  46. package/dist/esm/utils/config.js.map +1 -0
  47. package/dist/esm/utils/create-styles.js +123 -2
  48. package/dist/esm/utils/create-styles.js.map +1 -0
  49. package/package.json +1 -1
  50. package/dist/cjs/app-router/client/TernSecureProvider.cjs +0 -3
  51. package/dist/cjs/app-router/server/TernSecureServerProvider.cjs +0 -3
  52. package/dist/cjs/app-router/server/auth.cjs +0 -3
  53. package/dist/cjs/boundary/TernSecureCtx.cjs +0 -1
  54. package/dist/cjs/boundary/hooks/useAuth.cjs +0 -3
  55. package/dist/cjs/components/sign-in.cjs +0 -4
  56. package/dist/cjs/errors.cjs +0 -1
  57. package/dist/cjs/index.cjs +0 -4
  58. package/dist/cjs/types.cjs +0 -1
  59. package/dist/cjs/utils/client-init.cjs +0 -3
  60. package/dist/cjs/utils/config.cjs +0 -3
  61. package/dist/cjs/utils/create-styles.cjs +0 -2
  62. package/dist/esm/app-router/client/TernSecureProvider.d.ts +0 -17
  63. package/dist/esm/app-router/server/TernSecureServerProvider.d.ts +0 -30
  64. package/dist/esm/app-router/server/auth.d.ts +0 -9
  65. package/dist/esm/boundary/TernSecureCtx.d.ts +0 -15
  66. package/dist/esm/boundary/hooks/useAuth.d.ts +0 -7
  67. package/dist/esm/components/sign-in.d.ts +0 -25
  68. package/dist/esm/errors.d.ts +0 -10
  69. package/dist/esm/index.d.ts +0 -19
  70. package/dist/esm/types.d.ts +0 -49
  71. package/dist/esm/utils/client-init.d.ts +0 -9
  72. package/dist/esm/utils/config.d.ts +0 -22
  73. package/dist/esm/utils/create-styles.d.ts +0 -100
package/dist/esm/index.js CHANGED
@@ -1,4 +1,18 @@
1
- import Q,{createContext,useContext,useState,useEffect}from'react';import {initializeApp}from'firebase/app';import {getAuth,setPersistence,browserSessionPersistence,signInWithEmailAndPassword,onAuthStateChanged}from'firebase/auth';import {getFirestore}from'firebase/firestore';import {getStorage}from'firebase/storage';import {jsxs,jsx}from'react/jsx-runtime';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(),x=initializeApp(O),w=getAuth(x);setPersistence(w,browserSessionPersistence);var V=getFirestore(x);getStorage(x);var u=()=>w,H=()=>V;var J=Symbol("TERN_SECURE_CONTEXT"),E=createContext(null);E.displayName="TernSecureContext";var F=e=>{let r=useContext(E);if(!r)throw new Error(`${e} must be used within TernSecureProvider`);return r};function B({children:e}){return jsx(E.Provider,{value:{_contextKey:J},children:e})}var I=Q.createContext(null),ne=u();function D({children:e,initialState:r}){let[o,s]=useState(r);return useEffect(()=>{let l=onAuthStateChanged(ne,t=>{s(t?{loading:!1,isSignedIn:!0,userId:t.uid,error:null}:{loading:!1,isSignedIn:!1,userId:null,error:null});});return ()=>l()},[]),jsx(B,{children:jsx(I.Provider,{value:o,children:e})})}function ie(){return jsx("div",{"aria-label":"Loading authentication",role:"status",className:"tern-secure-loading",children:jsx("span",{className:"sr-only",children:"Loading authentication..."})})}function U({children:e}){let r={loading:!0,isSignedIn:!1,userId:null,error:null};return jsx(Q.Suspense,{fallback:jsx(ie,{}),children:jsx(D,{initialState:r,children:e})})}async function b({email:e,password:r}){let o=u();return signInWithEmailAndPassword(o,e,r)}function le(){F("useAuth");let e=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=="undefined"||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]=useState(""),[m,y]=useState(""),[f,$]=useState(!1),[g,N]=useState(""),W=async c=>{c.preventDefault(),$(!0),N("");try{await b({email:p,password:m}),e==null||e(),o&&(window.location.href=o);}catch(S){let k=S instanceof Error?S.message:"Failed to sign in";N(k),r==null||r(S instanceof Error?S:new Error("Failed to sign in"));}finally{$(!1);}};return jsxs("div",{className:`${n.container} ${t.container||""}`,style:l,children:[jsx("div",{className:`${n.header} ${t.header||""}`,children:jsx("h2",{className:`${n.title} ${t.title||""}`,children:"Sign in to your account"})}),jsx("div",{className:`${n.formWrapper} ${t.formWrapper||""}`,children:jsx("div",{className:`${n.formContainer} ${t.formContainer||""}`,children:jsxs("form",{onSubmit:W,className:`${n.form} ${t.form||""} ${s}`,role:"form","aria-label":"Sign in form",children:[g&&jsx("div",{className:`${n.error} ${t.errorText||""}`,role:"alert","aria-live":"polite",children:g}),jsxs("div",{children:[jsx("label",{htmlFor:"email",className:`${n.label} ${t.label||""}`,children:"Email"}),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":!!g})]}),jsxs("div",{children:[jsx("label",{htmlFor:"password",className:`${n.label} ${t.label||""}`,children:"Password"}),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":!!g})]}),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;export{de as SignIn,u as TernSecureAuth,H as TernSecureFirestore,Ge as TernSecureProvider,_ as loadFireConfig,b as signInWithEmail,le as useAuth,R as validateConfig};
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}from'firebase/app';import {getAuth,setPersistence,browserSessionPersistence}from'firebase/auth';import {getFirestore}from'firebase/firestore';import {getStorage}from'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=initializeApp(f),s=getAuth(n);setPersistence(s,browserSessionPersistence);var u=getFirestore(n),d=getStorage(n),R=()=>s,P=()=>u,F=()=>d;export{R as TernSecureAuth,P as TernSecureFirestore,F as TernSecureStorage};
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":[]}
@@ -1,3 +1,47 @@
1
- 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};export{t as initializeConfig,o as loadFireConfig,s as validateConfig};
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
- 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=="undefined"||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);export{t as defaultClassNames,u as styleConfig,y as styles};
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.76",
3
+ "version": "3.1.77",
4
4
  "packageManager": "npm@10.9.0",
5
5
  "type": "module",
6
6
  "publishConfig": {
@@ -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;
@@ -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;
@@ -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;
@@ -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,7 +0,0 @@
1
- import { TernSecureState } from '../../app-router/client/TernSecureProvider.js';
2
- import 'react/jsx-runtime';
3
- import 'react';
4
-
5
- declare function useAuth(): TernSecureState;
6
-
7
- export { useAuth };
@@ -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 };
@@ -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 };
@@ -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 };
@@ -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 };
@@ -1,9 +0,0 @@
1
- import * as _firebase_storage from '@firebase/storage';
2
- import * as _firebase_firestore from '@firebase/firestore';
3
- import * as _firebase_auth from '@firebase/auth';
4
-
5
- declare const TernSecureAuth: () => _firebase_auth.Auth;
6
- declare const TernSecureFirestore: () => _firebase_firestore.Firestore;
7
- declare const TernSecureStorage: () => _firebase_storage.FirebaseStorage;
8
-
9
- export { TernSecureAuth, TernSecureFirestore, TernSecureStorage };