@niledatabase/react 2.2.0-alpha.1 → 2.2.0-alpha.2
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/context/index.d.ts +2 -2
- package/dist/context/types.d.ts +3 -3
- package/dist/react.cjs.development.js +1 -1
- package/dist/react.cjs.development.js.map +1 -1
- package/dist/react.cjs.production.min.js +1 -1
- package/dist/react.cjs.production.min.js.map +1 -1
- package/dist/react.esm.js +1 -1
- package/dist/react.esm.js.map +1 -1
- package/package.json +3 -13
package/dist/context/index.d.ts
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import
|
|
2
|
+
import Browser from '@niledatabase/browser';
|
|
3
3
|
import { NileProviderProps, NileReactConfig } from './types';
|
|
4
4
|
export declare const BaseQueryProvider: ({ children, }: {
|
|
5
5
|
children: JSX.Element;
|
|
6
6
|
}) => JSX.Element;
|
|
7
7
|
export declare const NileProvider: (props: NileProviderProps) => React.JSX.Element;
|
|
8
8
|
export declare const useNileConfig: () => NileReactConfig;
|
|
9
|
-
export declare const useApi: () =>
|
|
9
|
+
export declare const useApi: () => Browser;
|
package/dist/context/types.d.ts
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import
|
|
1
|
+
import Browser from '@niledatabase/browser';
|
|
2
2
|
import { Theme } from '@mui/joy/styles';
|
|
3
3
|
export interface NileReactConfig {
|
|
4
4
|
tenantId?: string;
|
|
5
5
|
basePath?: string;
|
|
6
6
|
}
|
|
7
7
|
export type NileContext = NileReactConfig & {
|
|
8
|
-
api:
|
|
8
|
+
api: Browser;
|
|
9
9
|
theme?: Theme;
|
|
10
10
|
};
|
|
11
11
|
export type NileProviderProps = NileReactConfig & {
|
|
@@ -14,5 +14,5 @@ export type NileProviderProps = NileReactConfig & {
|
|
|
14
14
|
QueryProvider?: (props: {
|
|
15
15
|
children: JSX.Element;
|
|
16
16
|
}) => JSX.Element;
|
|
17
|
-
api?:
|
|
17
|
+
api?: Browser;
|
|
18
18
|
};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("@niledatabase/browser"),r=require("@tanstack/react-query"),a=require("@mui/material/CssBaseline"),n=require("@mui/joy/styles"),o=require("@mui/utils/deepmerge"),l=require("@mui/material/styles"),i=require("@mui/joy/Box"),s=require("@mui/joy/Button"),c=require("@mui/joy/Stack"),u=require("@mui/joy/Typography"),m=require("@mui/joy/Alert"),d=require("react-hook-form"),p=require("@mui/joy/Input"),b=require("@mui/joy/FormControl"),f=require("@mui/joy/FormHelperText"),g=require("@mui/icons-material/Error"),h=require("@mui/joy/FormLabel"),y=require("@mui/joy/Select"),x=require("@mui/joy/Option"),E=require("@mui/joy/Tooltip"),v=require("@mui/joy"),C=require("@mui/joy/Checkbox"),w=require("@mui/joy/List"),S=require("@mui/joy/ListItem"),T=require("@mui/x-data-grid"),F=require("@mui/icons-material/Add"),q=require("lodash/isNull"),k=require("lodash/isUndefined"),A=require("@mui/icons-material/CopyAll"),j=require("@mui/icons-material/CheckCircleOutlined");function P(e){var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var a=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,a.get?a:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,t}var I=P(e);const M={primary:{50:"#fff7ed",100:"#FFEAD2",200:"#FFDCB5",300:"#FFCE97",400:"#FFC480",500:"#FDC067",600:"#FFB262",700:"#FFAA57",800:"#FFA24D",900:"#FF933C",solidColor:"rgba(var(--nile-palette-primary-contrastTextChannel) / 1)",softColor:"rgba(var(--nile-palette-primary-contrastTextChannel) / .5)",solidDisabledBg:"var(--nile-palette-grey-600)",solidDisabledColor:"var(--nile-palette-grey-700)",plainHoverBg:"rgba(var(--nile-palette-primary-mainChannel) / var(--nile-palette-action-hoverOpacity))",outlinedHoverBg:"rgba(var(--nile-palette-primary-mainChannel) / var(--nile-palette-action-selectedOpacity))"},neutral:{outlinedHoverBg:"rgba(var(--nile-palette-neutral-mainChannel) / var(--nile-palette-action-selectedOpacity))",softBg:"rgba(45, 45, 51)"},purple:{50:"#f0edff",100:"#d8d3ff",200:"#beb6fe",300:"#a298fb",400:"#8a7ff7",500:"#7269f3",600:"#6663eb",700:"#565ae1",800:"#4754d8",900:"#2d47c9"},blue:{50:"#dff8ff",100:"#adedff",200:"#6fe2ff",300:"#12d6fb",400:"#00ccf6",500:"#00c2f0",600:"#00b2dc",700:"#009dc0",800:"#008aa6",900:"#006778"},divider:"#181818",text:{primary:"#fff7ed",tertiary:"rgba(255 255 255 / 0.5)"},background:{surface:"#000",body:"#000",default:"#000"},tableCell:{border:"none"}},{unstable_sxConfig:O,...U}=l.experimental_extendTheme({cssVarPrefix:"nile",colorSchemes:{dark:{palette:{primary:{main:"#FFCE97"}}}}}),{unstable_sxConfig:B,...V}=n.extendTheme({cssVarPrefix:"nile",components:{JoyInput:{styleOverrides:{input:{":disabled":{color:"var(--nile-palette-neutral-500)"},"::placeholder":{opacity:.6},color:"white"}}}},colorSchemes:{dark:{palette:M},light:{palette:M}}}),D={...U,...V,colorSchemes:o(U.colorSchemes,V.colorSchemes),typography:{...U.typography,...V.typography}};function R({theme:t,children:r}){return e.createElement(n.CssVarsProvider,{theme:t??D,defaultMode:"dark"},e.createElement(a,{enableColorScheme:!0}),r)}D.generateCssVars=e=>({css:{...U.generateCssVars(e).css,...V.generateCssVars(e).css},vars:o(U.generateCssVars(e).vars,V.generateCssVars(e).vars)}),D.unstable_sxConfig={...O,...B};const L=new r.QueryClient,N={api:t({basePath:"https://api.thenile.dev",credentials:"include"}),basePath:""},$=e.createContext(N),{Provider:z}=$,H=({children:t})=>e.createElement(r.QueryClientProvider,{client:L},t),G=()=>e.useContext($),_=()=>{const{basePath:t,tenantId:r}=G();return e.useMemo((()=>({tenantId:r,basePath:t})),[t,r])},W=()=>G().api;var Q;function J(){return J=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var a in r)Object.prototype.hasOwnProperty.call(r,a)&&(e[a]=r[a])}return e},J.apply(this,arguments)}var K=function(e){return I.createElement("svg",J({xmlns:"http://www.w3.org/2000/svg",width:18,height:18},e),Q||(Q=I.createElement("g",{fillRule:"evenodd"},I.createElement("path",{fill:"#EA4335",d:"M9 3.48c1.69 0 2.83.73 3.48 1.34l2.54-2.48C13.46.89 11.43 0 9 0 5.48 0 2.44 2.02.96 4.96l2.91 2.26C4.6 5.05 6.62 3.48 9 3.48"}),I.createElement("path",{fill:"#4285F4",d:"M17.64 9.2c0-.74-.06-1.28-.19-1.84H9v3.34h4.96c-.1.83-.64 2.08-1.84 2.92l2.84 2.2c1.7-1.57 2.68-3.88 2.68-6.62"}),I.createElement("path",{fill:"#FBBC05",d:"M3.88 10.78A5.5 5.5 0 0 1 3.58 9c0-.62.11-1.22.29-1.78L.96 4.96A9 9 0 0 0 0 9c0 1.45.35 2.82.96 4.04z"}),I.createElement("path",{fill:"#34A853",d:"M9 18c2.43 0 4.47-.8 5.96-2.18l-2.84-2.2c-.76.53-1.78.9-3.12.9-2.38 0-4.4-1.57-5.12-3.74L.97 13.04C2.45 15.98 5.48 18 9 18"}),I.createElement("path",{fill:"none",d:"M0 0h18v18H0z"}))))};function X(e){const{options:t,attribute:r,display:a,helperText:n}=e,{watch:o,control:l}=d.useFormContext(),s=o(r.name),m={};return n&&(m.color="danger"),I.createElement(d.Controller,{name:r.name,rules:{required:Boolean(r.required)},control:l,render:({field:e})=>I.createElement(c,null,I.createElement(h,{htmlFor:`${e.name}`},a.label),I.createElement(i,{role:"group","aria-labelledby":r.name,sx:{borderRadius:"var(--joy-radius-sm)",p:.5,border:n?"1px solid var(--joy-palette-danger-outlinedBorder)":"none"}},I.createElement(w,{orientation:"horizontal",wrap:!0,sx:{"--List-gap":"8px"}},t.map((a=>(m.id=String(a.value),I.createElement(S,{key:`${a.value}-${a.label}`},I.createElement(C,{overlay:t.length>1,...m,checked:s.includes(a.value),disableIcon:t.length>1,variant:"soft",label:a.label,onChange:t=>{if(r.allowMultiple)if(t.target.checked)s?e.onChange(s.concat(a.value)):e.onChange([a.value]);else{const t=s.filter((e=>e!==a.value));t.length>0?e.onChange(t):e.onChange("")}else t.target.checked?e.onChange(a.value):e.onChange("")}}))))))),I.createElement(u,{sx:{color:"var(--joy-palette-danger-500)"},level:"body-sm"},n))})}var Y;exports.FormAttributeType=void 0,(Y=exports.FormAttributeType||(exports.FormAttributeType={})).Text="text",Y.Password="password",Y.Select="select",Y.Number="number",Y.Float="float",Y.Checkbox="checkbox",Y.Switch="switch";const Z=e=>!0===e.allowMultiple&&!Array.isArray(e.defaultValue)&&e.defaultValue?"number"==typeof e.defaultValue?[e.defaultValue]:[String(e.defaultValue)]:e.defaultValue??"";function ee(t){const{error:r,attr:a}=t;return r?e.createElement(E,{title:r,color:"danger",sx:{cursor:"pointer"}},e.createElement(h,null,a.label??a.name,e.createElement(g,{sx:{ml:.5,"--Icon-color":"#c41c1c"},fontSize:"small"}))):e.createElement(h,null,a.label??a.name)}function te(t){const{mutation:r,buttonText:a,attributes:n,cancelButton:o,loading:l,successMessage:u}=t,m=e.useMemo((()=>n.reduce(((e,t)=>(e[t.name]=Z(t),e)),{})),[n]),g=d.useForm({defaultValues:m}),{register:h,control:E,handleSubmit:C,formState:{errors:w}}=g,S=e.useCallback((e=>{r.mutate(e)}),[r]);return e.createElement(d.FormProvider,{...g},e.createElement(c,{component:"form",onSubmit:C((e=>S(e))),spacing:2},n.map((t=>{const r={},a={key:t.name,label:t.label??t.name,id:t.label??t.name,placeholder:t.placeholder??t.label??t.name,error:Boolean(w[t.name]),disabled:Boolean(t.disabled)},n=t.options??[],o=t.helpText??"";let l="";switch(t.required&&(l=w[t.name]?`${t.label??t.name} is required`:"",r.required=!0),t.type){case exports.FormAttributeType.Switch:return e.createElement(b,{key:a.key,id:a.id,orientation:"horizontal",sx:{alignItems:"center"}},e.createElement(i,null,e.createElement(ee,{error:l,attr:t}),e.createElement(f,{id:`${t.name}-helper-text`},o)),e.createElement(d.Controller,{control:E,rules:{required:Boolean(t.required)},name:t.name,render:({field:r})=>{const a={};return w[t.name]&&(a.color="danger"),e.createElement(v.Switch,{id:`switch-field-${t.name}`,...a,...r,checked:Boolean(r.value),onChange:e=>{r.onChange(e.target.checked)},color:r.value?"success":"neutral",endDecorator:r.value?n[0].label:n[1].label,sx:{"--Switch-thumbSize":"28px"}})}}));case exports.FormAttributeType.Checkbox:return e.createElement(X,{key:a.key,attribute:t,display:a,options:n,helperText:o});case exports.FormAttributeType.Select:return e.createElement(b,{key:a.key,id:a.id},e.createElement(ee,{error:l,attr:t}),e.createElement(d.Controller,{control:E,rules:{required:Boolean(t.required)},name:t.name,render:({field:r})=>{const l={};w[t.name]&&(l.color="danger");const i=String(r.value);return e.createElement(c,null,e.createElement(y,{id:`select-field-${t.name}`,placeholder:`${a.placeholder}...`,...l,...r,value:i,onChange:(e,t)=>{r.onChange(t)}},n.map((t=>e.createElement(x,{key:String(t.value??""),value:t.value},t.label)))),e.createElement(f,{id:`${t.name}-helper-text`},o))}}));case exports.FormAttributeType.Password:return e.createElement(b,{key:a.key,id:a.id},e.createElement(ee,{error:l,attr:t}),e.createElement(p,{...a,...h(t.name,r),type:exports.FormAttributeType.Password}),e.createElement(f,{id:`${t.name}-helper-text`},o));case exports.FormAttributeType.Number:return e.createElement(b,{key:a.key,id:a.id},e.createElement(ee,{error:l,attr:t}),e.createElement(p,{...a,...h(t.name,r),type:exports.FormAttributeType.Number}),e.createElement(f,{id:`${t.name}-helper-text`},o));case exports.FormAttributeType.Text:default:return e.createElement(b,{key:a.key,id:a.id},e.createElement(ee,{error:l,attr:t}),e.createElement(p,{...a,...h(t.name,r)}),e.createElement(f,{id:`${t.name}-helper-text`},o))}})),o?e.createElement(c,{spacing:2,direction:"row"},o,e.createElement(i,null,e.createElement(s,{type:"submit"},a))):e.createElement(i,null,e.createElement(c,{direction:"row",gap:2},e.createElement(s,{type:"submit",loading:l},a),u))))}function re(t){const{open:a,setOpen:n,refetch:o}=t,{tenantId:l}=_(),i=W(),[s,c]=e.useState(),{watch:u,register:m,handleSubmit:p}=d.useForm(),b=u("email");e.useEffect((()=>{null!=s&&c()}),[b]);const f=r.useMutation((e=>i.users.createTenantUser({signUpRequest:e,tenantId:String(l)})),{onSuccess(e){o&&o(e),n(!1)},onError(e){e instanceof Error&&c(e.message)}}),g=e.useCallback((async e=>{c(""),f.mutate(e)}),[f]);return e.createElement(v.Modal,{open:a},e.createElement(v.ModalDialog,null,e.createElement(v.Stack,{spacing:2},e.createElement(v.Typography,{level:"h4"},"Create user"),e.createElement(e.Fragment,null,s&&e.createElement(v.Typography,{color:"danger"},s)),e.createElement(v.Stack,{component:"form",sx:{width:"40ch"},spacing:1,onSubmit:p((e=>g(e)))},e.createElement(v.FormControl,{sx:{"--FormHelperText-color":"var(--joy-palette-danger-500)"}},e.createElement(v.FormLabel,{htmlFor:"email"},"Email"),e.createElement(v.Input,{...m("email"),fullWidth:!0,size:"lg",id:"email",name:"email",autoComplete:"current-email",required:!0,error:Boolean(s)})),e.createElement(v.FormControl,{sx:{"--FormHelperText-color":"var(--joy-palette-danger-500)"}},e.createElement(v.FormLabel,{htmlFor:"password"},"Password"),e.createElement(v.Input,{...m("password"),fullWidth:!0,size:"lg",id:"password",autoComplete:"current-password",type:"password",required:!0})),e.createElement(v.Stack,{direction:"row",sx:{pt:2},spacing:2},e.createElement(v.Button,{onClick:()=>n(!1),variant:"plain"},"Cancel"),e.createElement(v.Button,{type:"submit"},"Create"))))))}function ae(t){const{allowCreation:r,buttonText:a,onUserCreateSuccess:n}=t,[o,l]=e.useState(!1);return r?e.createElement(c,{alignItems:"flex-end",gap:1},e.createElement(re,{open:o,setOpen:l,refetch:n}),e.createElement(s,{startDecorator:e.createElement(F,null),size:"sm",onClick:()=>l(!0)},a)):null}const ne=e=>Object.keys(e).reduce(((t,r)=>{const a=e[r];return a instanceof Set?t[r]=Array.from(a).join(", "):Array.isArray(a)?t[r]=a.join(", "):t[r]=a,t}),{}),oe=(e,t,r)=>{if(!e)return[[],[]];const a=e.map(ne),n=Object.keys(a[0]),o={},l=n?.map((e=>{const n=function(e,t,r){let a=r&&e?r.measureText(String(e)).width:50;a+=27;let n=a;return n=16+Math.ceil(r?r.measureText(t.reduce(((t,r)=>{let a=r[String(e)];return(q(a)||k(a))&&(a=""),a=a?.toString(),t.length>a.length?t:a}),"")).width:50),n<a&&(n=a),n+=8,n}(e,a,t),l=e.slice();if(r.includes(l))return null==o[l]?o[l]=l.length:o[l]+=1,{field:l.padEnd(o[l]),headerName:l.padEnd(o[l]),width:n}})).filter(Boolean)??[];return[l,a]};function le(t,r){const a=function(){const[t,r]=e.useState();return e.useEffect((()=>{const e=document.createElement("canvas").getContext("2d");e&&(e.font="18px Roboto",r(e))}),[]),t}(),[n,o]=e.useMemo((()=>oe(t,a,r)),[t,a,r]);return[n,o]}function ie(t){const{config:a,providerName:n,onSuccess:o,onError:l,allowEdit:i=!0,configurationGuide:s}=t,d=W(),[p,b]=e.useState(!1),[f,g]=e.useState(!1),[h,y]=e.useState(a),x=e.useRef(),E=e.useMemo((()=>{const e=[{name:"enabled",label:"Allow Okta logins",type:exports.FormAttributeType.Switch,defaultValue:!0===h?.enabled,options:[{label:"Enabled"},{label:"Disabled"}],disabled:!i},{name:"clientId",label:"Client id",type:exports.FormAttributeType.Text,defaultValue:h?.clientId??"",required:!0,disabled:!i},{name:"configUrl",label:"Config url",type:exports.FormAttributeType.Text,defaultValue:h?.configUrl??"",helpText:"The URL of the .well-known/openid-configuration for the identity provider",required:!0,disabled:!i},{name:"emailDomains",label:"Email domains",type:exports.FormAttributeType.Text,defaultValue:h?.emailDomains?.join(", ")??"",required:!0,helpText:"A comma seperated list of email domains (yourDomain.com) to be used",disabled:!i}];return h?.clientId||e.splice(2,0,{name:"clientSecret",label:"Client secret",type:exports.FormAttributeType.Password,defaultValue:"",required:!0,disabled:!i}),e}),[i,h?.clientId,h?.configUrl,h?.emailDomains,h?.enabled]),v=r.useMutation((e=>{b(!0);const t={providerName:n.toLowerCase(),updateProviderRequest:{...e,emailDomains:e.emailDomains.split(",")}};return null!=h?d.auth.updateProvider(t):d.auth.createProvider(t)}),{onSuccess:(e,t)=>{y(e),g(!0),o&&o(e,t)},onError:l,onSettled:(e,t,r)=>{b(!1),x.current&&clearTimeout(x.current),x.current=setTimeout((()=>{g(!1)}),3e3),e||(t&&!t?.message.includes("Unterminated string")||y({enabled:r.enabled,clientId:r.clientId,configUrl:r.configUrl,emailDomains:r.emailDomains.split(", ")}),g(!0),o&&o(e,r))}});return e.useEffect((()=>{})),e.createElement(c,{gap:2,position:"relative"},e.createElement(u,{level:"h4"},"Step 1"),s,e.createElement(u,{level:"h4"},"Step 2"),e.createElement(te,{mutation:v,buttonText:"Update",attributes:E,loading:p,successMessage:e.createElement(m,{color:"success",sx:{opacity:f?1:0,transition:"opacity 200ms",height:"0.9rem"},startDecorator:e.createElement(j,null)},e.createElement(u,{textAlign:"center",fontSize:"sm"},"Provider updated"))}))}function se({callbackUrl:t}){const[r,a]=e.useState(!1),n=e.useRef();return e.useEffect((()=>{n.current&&clearTimeout(n.current),n.current=setTimeout((()=>{a(!1)}),3250)}),[r]),e.createElement(c,{gap:2},e.createElement(u,null,"In order for Okta to redirect properly, provide the following URL as the"," ",e.createElement(i,{component:"span",sx:{fontFamily:"monospace"}},"Sign-in redirect URIs")," ","in the admin configuration of your application."),e.createElement(p,{onClick:async()=>{t&&(await navigator.clipboard.writeText(t),a(!0))},sx:e=>({input:{cursor:"pointer"},span:{cursor:"pointer"},"&:hover svg":{"--Icon-color":e.palette.primary[500]}}),value:t,readOnly:!0,endDecorator:e.createElement(E,{title:"Copy Okta redirect URL"},e.createElement(i,{position:"relative",width:r?"82px":"24px",height:"24px"},e.createElement(i,{position:"absolute",top:"0",left:"0",sx:{opacity:r?0:1,transition:"opacity 300ms"}},e.createElement(A,null)),e.createElement(i,{position:"absolute",top:"0",left:"0",sx:{opacity:r?1:0,transition:"opacity 300ms"}},e.createElement(c,{direction:"row",gap:1},e.createElement(j,null),e.createElement(u,{color:"primary"},"Copied!")))))}))}exports.GoogleLoginButton=function(t){const{databaseId:r,newTenantName:a}=t,{basePath:n}=_(),o=`${n}/databases/${encodeURIComponent(r??"")}/users/oidc/google/login`,l=a?"?newTenant="+encodeURIComponent(a):"",m=(t?.href??o)+l;return e.createElement(i,{component:"a",href:m,display:"flex",flex:1,sx:{textDecoration:"none"}},e.createElement(i,null,e.createElement(s,{sx:{padding:0,textTransform:"initial",flex:1},"aria-label":"log in with google"},e.createElement(c,{direction:"row",alignItems:"center",p:0,flex:1,fontFamily:"Roboto, sans-serif",fontSize:"14px",display:"inline-flex",color:"rgb(255 255, 255)",boxShadow:"rgb(0 0 0 / 24%) 0px 2px 2px 0px rgb(0 0 0 / 24%) 0px 0px 1px 0px",borderRadius:"4px",border:"1px solid transparent",fontWeight:"500",sx:{backgroundColor:"rgb(66 133, 244)"}},e.createElement(i,{padding:"11px",display:"flex",border:"1px solid rgb(66, 133, 244)",borderRadius:"4px",sx:{background:"rgb(255, 255, 255)"}},e.createElement(K,{"aria-hidden":"true"})),e.createElement(i,{padding:"10px",flex:1},e.createElement(u,{sx:{color:"white"},fontWeight:700,fontFamily:"Roboto, sans-serif",fontSize:"14px",height:"20px"},"Continue with Google"))))))},exports.NileProvider=r=>{const{children:a,theme:n,tenantId:o,QueryProvider:l=H,basePath:i="https://api.thenile.dev",api:s}=r,c=e.useMemo((()=>({api:s??t({basePath:i,credentials:"include"}),tenantId:String(o),basePath:i})),[s,i,o]);return e.createElement(l,null,e.createElement(R,{theme:n},e.createElement(z,{value:c},a)))},exports.Okta=function(t){const{callbackUrl:r,providers:a,...n}=t;if(!a)return null;const o=a?.find((e=>"okta"===e.provider));return e.createElement(ie,{...n,config:o,providerName:"Okta",configurationGuide:e.createElement(se,{callbackUrl:r})})},exports.SSOForm=ie,exports.SingleSignOnForm=function(t){const{attributes:a,onSuccess:n,onError:o,beforeMutate:l,nextButtonText:i="Next",loginButtonText:s="Log in",disableSSO:c=!1}=t,u=W(),[m,d]=e.useState(c?s:i),p=r.useMutation((async e=>{const t=(l&&l(e))??e;return await u.auth.login({loginRequest:{email:t.email,password:t.password},sso:!c})}),{onSuccess:(e,t)=>{e&&(e?.redirectURI?window.location.href=e.redirectURI:m!==s?d(s):n&&n(e,t))},onError:(e,t)=>{m===s?o&&o(e,t):d(s)}}),b=e.useMemo((()=>{const e=[{name:"email",label:"Email",type:exports.FormAttributeType.Text,defaultValue:"",required:!0}];return m===s&&e.push({name:"password",label:"Password",type:exports.FormAttributeType.Password,defaultValue:"",required:!0}),a&&a.length>0?e.concat(a):e}),[a,m,s]);return e.createElement(te,{mutation:p,buttonText:m,attributes:b})},exports.UserLoginForm=function(t){const[a,n]=e.useState(),{attributes:o,onSuccess:l,onError:i,beforeMutate:s}=t,u=W(),d=r.useMutation((async e=>{n(void 0);const t=(s&&s(e))??e;return await u.auth.login({loginRequest:t})}),{onSuccess:l,onError:i}),p=e.useMemo((()=>{const e=[{name:"email",label:"Email",type:exports.FormAttributeType.Text,defaultValue:"",required:!0},{name:"password",label:"Password",type:exports.FormAttributeType.Password,defaultValue:"",required:!0}];return o&&o.length>0?e.concat(o):e}),[o]);return e.createElement(c,{gap:2},a?e.createElement(m,{color:"danger"},a):null,e.createElement(te,{mutation:d,buttonText:"Log in",attributes:p}))},exports.UserSignupForm=function(t){const[a,n]=e.useState(),{buttonText:o="Sign up",onSuccess:l,onError:i,attributes:s,beforeMutate:u}=t,d=W(),p=r.useMutation((async e=>{n(void 0);const t=(u&&u(e))??e,{email:r,password:a,preferredName:o,newTenant:l,...i}=t;return Object.keys(i).length>0&&console.warn("additional metadata not supported yet."),d.auth.signUp({signUpRequest:{email:r,password:a,preferredName:o,newTenant:l}})}),{onSuccess:l,onError:(e,t)=>{n(e.message),i&&i(e,t)}}),b=e.useMemo((()=>{const e=[{name:"email",label:"Email",type:exports.FormAttributeType.Text,defaultValue:"",required:!0},{name:"password",label:"Password",type:exports.FormAttributeType.Password,defaultValue:"",required:!0}];return s&&s.length>0?e.concat(s):e}),[s]);return e.createElement(c,{gap:2},a?e.createElement(m,{color:"danger"},a):null,e.createElement(te,{mutation:p,buttonText:o,attributes:b}))},exports.UserTenantList=function(t){const{data:r,allowCreation:a=!0,buttonText:n="Add a user",onUserCreateSuccess:o,slots:l,include:i=["email","preferedName"]}=t,s={width:"100%",height:"100%",...l?.dataGrid??{}},[u,m]=le(r,i);return e.createElement(c,{flex:1},e.createElement(ae,{allowCreation:a,buttonText:n,onUserCreateSuccess:o}),e.createElement(T.DataGrid,{sx:s,rows:m,columns:u,hideFooter:!0}))};
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("@niledatabase/browser"),r=require("@tanstack/react-query"),a=require("@mui/material/CssBaseline"),n=require("@mui/joy/styles"),o=require("@mui/utils/deepmerge"),l=require("@mui/material/styles"),i=require("@mui/joy/Box"),s=require("@mui/joy/Button"),c=require("@mui/joy/Stack"),u=require("@mui/joy/Typography"),m=require("@mui/joy/Alert"),d=require("react-hook-form"),p=require("@mui/joy/Input"),b=require("@mui/joy/FormControl"),f=require("@mui/joy/FormHelperText"),g=require("@mui/icons-material/Error"),h=require("@mui/joy/FormLabel"),y=require("@mui/joy/Select"),x=require("@mui/joy/Option"),E=require("@mui/joy/Tooltip"),v=require("@mui/joy"),w=require("@mui/joy/Checkbox"),C=require("@mui/joy/List"),S=require("@mui/joy/ListItem"),T=require("@mui/x-data-grid"),F=require("@mui/icons-material/Add"),q=require("lodash/isNull"),k=require("lodash/isUndefined"),A=require("@mui/icons-material/CopyAll"),j=require("@mui/icons-material/CheckCircleOutlined");function P(e){var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var a=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,a.get?a:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,t}var I=P(e);const M={primary:{50:"#fff7ed",100:"#FFEAD2",200:"#FFDCB5",300:"#FFCE97",400:"#FFC480",500:"#FDC067",600:"#FFB262",700:"#FFAA57",800:"#FFA24D",900:"#FF933C",solidColor:"rgba(var(--nile-palette-primary-contrastTextChannel) / 1)",softColor:"rgba(var(--nile-palette-primary-contrastTextChannel) / .5)",solidDisabledBg:"var(--nile-palette-grey-600)",solidDisabledColor:"var(--nile-palette-grey-700)",plainHoverBg:"rgba(var(--nile-palette-primary-mainChannel) / var(--nile-palette-action-hoverOpacity))",outlinedHoverBg:"rgba(var(--nile-palette-primary-mainChannel) / var(--nile-palette-action-selectedOpacity))"},neutral:{outlinedHoverBg:"rgba(var(--nile-palette-neutral-mainChannel) / var(--nile-palette-action-selectedOpacity))",softBg:"rgba(45, 45, 51)"},purple:{50:"#f0edff",100:"#d8d3ff",200:"#beb6fe",300:"#a298fb",400:"#8a7ff7",500:"#7269f3",600:"#6663eb",700:"#565ae1",800:"#4754d8",900:"#2d47c9"},blue:{50:"#dff8ff",100:"#adedff",200:"#6fe2ff",300:"#12d6fb",400:"#00ccf6",500:"#00c2f0",600:"#00b2dc",700:"#009dc0",800:"#008aa6",900:"#006778"},divider:"#181818",text:{primary:"#fff7ed",tertiary:"rgba(255 255 255 / 0.5)"},background:{surface:"#000",body:"#000",default:"#000"},tableCell:{border:"none"}},{unstable_sxConfig:O,...U}=l.experimental_extendTheme({cssVarPrefix:"nile",colorSchemes:{dark:{palette:{primary:{main:"#FFCE97"}}}}}),{unstable_sxConfig:B,...V}=n.extendTheme({cssVarPrefix:"nile",components:{JoyInput:{styleOverrides:{input:{":disabled":{color:"var(--nile-palette-neutral-500)"},"::placeholder":{opacity:.6},color:"white"}}}},colorSchemes:{dark:{palette:M},light:{palette:M}}}),D={...U,...V,colorSchemes:o(U.colorSchemes,V.colorSchemes),typography:{...U.typography,...V.typography}};function R({theme:t,children:r}){return e.createElement(n.CssVarsProvider,{theme:t??D,defaultMode:"dark"},e.createElement(a,{enableColorScheme:!0}),r)}D.generateCssVars=e=>({css:{...U.generateCssVars(e).css,...V.generateCssVars(e).css},vars:o(U.generateCssVars(e).vars,V.generateCssVars(e).vars)}),D.unstable_sxConfig={...O,...B};const L=new r.QueryClient,N={api:new t({basePath:"https://api.thenile.dev",credentials:"include"}),basePath:""},$=e.createContext(N),{Provider:z}=$,H=({children:t})=>e.createElement(r.QueryClientProvider,{client:L},t),G=()=>e.useContext($),_=()=>{const{basePath:t,tenantId:r}=G();return e.useMemo((()=>({tenantId:r,basePath:t})),[t,r])},W=()=>G().api;var Q;function J(){return J=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var a in r)Object.prototype.hasOwnProperty.call(r,a)&&(e[a]=r[a])}return e},J.apply(this,arguments)}var K=function(e){return I.createElement("svg",J({xmlns:"http://www.w3.org/2000/svg",width:18,height:18},e),Q||(Q=I.createElement("g",{fillRule:"evenodd"},I.createElement("path",{fill:"#EA4335",d:"M9 3.48c1.69 0 2.83.73 3.48 1.34l2.54-2.48C13.46.89 11.43 0 9 0 5.48 0 2.44 2.02.96 4.96l2.91 2.26C4.6 5.05 6.62 3.48 9 3.48"}),I.createElement("path",{fill:"#4285F4",d:"M17.64 9.2c0-.74-.06-1.28-.19-1.84H9v3.34h4.96c-.1.83-.64 2.08-1.84 2.92l2.84 2.2c1.7-1.57 2.68-3.88 2.68-6.62"}),I.createElement("path",{fill:"#FBBC05",d:"M3.88 10.78A5.5 5.5 0 0 1 3.58 9c0-.62.11-1.22.29-1.78L.96 4.96A9 9 0 0 0 0 9c0 1.45.35 2.82.96 4.04z"}),I.createElement("path",{fill:"#34A853",d:"M9 18c2.43 0 4.47-.8 5.96-2.18l-2.84-2.2c-.76.53-1.78.9-3.12.9-2.38 0-4.4-1.57-5.12-3.74L.97 13.04C2.45 15.98 5.48 18 9 18"}),I.createElement("path",{fill:"none",d:"M0 0h18v18H0z"}))))};function X(e){const{options:t,attribute:r,display:a,helperText:n}=e,{watch:o,control:l}=d.useFormContext(),s=o(r.name),m={};return n&&(m.color="danger"),I.createElement(d.Controller,{name:r.name,rules:{required:Boolean(r.required)},control:l,render:({field:e})=>I.createElement(c,null,I.createElement(h,{htmlFor:`${e.name}`},a.label),I.createElement(i,{role:"group","aria-labelledby":r.name,sx:{borderRadius:"var(--joy-radius-sm)",p:.5,border:n?"1px solid var(--joy-palette-danger-outlinedBorder)":"none"}},I.createElement(C,{orientation:"horizontal",wrap:!0,sx:{"--List-gap":"8px"}},t.map((a=>(m.id=String(a.value),I.createElement(S,{key:`${a.value}-${a.label}`},I.createElement(w,{overlay:t.length>1,...m,checked:s.includes(a.value),disableIcon:t.length>1,variant:"soft",label:a.label,onChange:t=>{if(r.allowMultiple)if(t.target.checked)s?e.onChange(s.concat(a.value)):e.onChange([a.value]);else{const t=s.filter((e=>e!==a.value));t.length>0?e.onChange(t):e.onChange("")}else t.target.checked?e.onChange(a.value):e.onChange("")}}))))))),I.createElement(u,{sx:{color:"var(--joy-palette-danger-500)"},level:"body-sm"},n))})}var Y;exports.FormAttributeType=void 0,(Y=exports.FormAttributeType||(exports.FormAttributeType={})).Text="text",Y.Password="password",Y.Select="select",Y.Number="number",Y.Float="float",Y.Checkbox="checkbox",Y.Switch="switch";const Z=e=>!0===e.allowMultiple&&!Array.isArray(e.defaultValue)&&e.defaultValue?"number"==typeof e.defaultValue?[e.defaultValue]:[String(e.defaultValue)]:e.defaultValue??"";function ee(t){const{error:r,attr:a}=t;return r?e.createElement(E,{title:r,color:"danger",sx:{cursor:"pointer"}},e.createElement(h,null,a.label??a.name,e.createElement(g,{sx:{ml:.5,"--Icon-color":"#c41c1c"},fontSize:"small"}))):e.createElement(h,null,a.label??a.name)}function te(t){const{mutation:r,buttonText:a,attributes:n,cancelButton:o,loading:l,successMessage:u}=t,m=e.useMemo((()=>n.reduce(((e,t)=>(e[t.name]=Z(t),e)),{})),[n]),g=d.useForm({defaultValues:m}),{register:h,control:E,handleSubmit:w,formState:{errors:C}}=g,S=e.useCallback((e=>{r.mutate(e)}),[r]);return e.createElement(d.FormProvider,{...g},e.createElement(c,{component:"form",onSubmit:w((e=>S(e))),spacing:2},n.map((t=>{const r={},a={key:t.name,label:t.label??t.name,id:t.label??t.name,placeholder:t.placeholder??t.label??t.name,error:Boolean(C[t.name]),disabled:Boolean(t.disabled)},n=t.options??[],o=t.helpText??"";let l="";switch(t.required&&(l=C[t.name]?`${t.label??t.name} is required`:"",r.required=!0),t.type){case exports.FormAttributeType.Switch:return e.createElement(b,{key:a.key,id:a.id,orientation:"horizontal",sx:{alignItems:"center"}},e.createElement(i,null,e.createElement(ee,{error:l,attr:t}),e.createElement(f,{id:`${t.name}-helper-text`},o)),e.createElement(d.Controller,{control:E,rules:{required:Boolean(t.required)},name:t.name,render:({field:r})=>{const a={};return C[t.name]&&(a.color="danger"),e.createElement(v.Switch,{id:`switch-field-${t.name}`,...a,...r,checked:Boolean(r.value),onChange:e=>{r.onChange(e.target.checked)},color:r.value?"success":"neutral",endDecorator:r.value?n[0].label:n[1].label,sx:{"--Switch-thumbSize":"28px"}})}}));case exports.FormAttributeType.Checkbox:return e.createElement(X,{key:a.key,attribute:t,display:a,options:n,helperText:o});case exports.FormAttributeType.Select:return e.createElement(b,{key:a.key,id:a.id},e.createElement(ee,{error:l,attr:t}),e.createElement(d.Controller,{control:E,rules:{required:Boolean(t.required)},name:t.name,render:({field:r})=>{const l={};C[t.name]&&(l.color="danger");const i=String(r.value);return e.createElement(c,null,e.createElement(y,{id:`select-field-${t.name}`,placeholder:`${a.placeholder}...`,...l,...r,value:i,onChange:(e,t)=>{r.onChange(t)}},n.map((t=>e.createElement(x,{key:String(t.value??""),value:t.value},t.label)))),e.createElement(f,{id:`${t.name}-helper-text`},o))}}));case exports.FormAttributeType.Password:return e.createElement(b,{key:a.key,id:a.id},e.createElement(ee,{error:l,attr:t}),e.createElement(p,{...a,...h(t.name,r),type:exports.FormAttributeType.Password}),e.createElement(f,{id:`${t.name}-helper-text`},o));case exports.FormAttributeType.Number:return e.createElement(b,{key:a.key,id:a.id},e.createElement(ee,{error:l,attr:t}),e.createElement(p,{...a,...h(t.name,r),type:exports.FormAttributeType.Number}),e.createElement(f,{id:`${t.name}-helper-text`},o));case exports.FormAttributeType.Text:default:return e.createElement(b,{key:a.key,id:a.id},e.createElement(ee,{error:l,attr:t}),e.createElement(p,{...a,...h(t.name,r)}),e.createElement(f,{id:`${t.name}-helper-text`},o))}})),o?e.createElement(c,{spacing:2,direction:"row"},o,e.createElement(i,null,e.createElement(s,{type:"submit"},a))):e.createElement(i,null,e.createElement(c,{direction:"row",gap:2},e.createElement(s,{type:"submit",loading:l},a),u))))}function re(t){const{open:a,setOpen:n,refetch:o}=t,{tenantId:l}=_(),i=W(),[s,c]=e.useState(),{watch:u,register:m,handleSubmit:p}=d.useForm(),b=u("email");e.useEffect((()=>{null!=s&&c()}),[b]);const f=r.useMutation((e=>i.users.createTenantUser({signUpRequest:e,tenantId:String(l)})),{onSuccess(e){o&&o(e),n(!1)},onError(e){e instanceof Error&&c(e.message)}}),g=e.useCallback((async e=>{c(""),f.mutate(e)}),[f]);return e.createElement(v.Modal,{open:a},e.createElement(v.ModalDialog,null,e.createElement(v.Stack,{spacing:2},e.createElement(v.Typography,{level:"h4"},"Create user"),e.createElement(e.Fragment,null,s&&e.createElement(v.Typography,{color:"danger"},s)),e.createElement(v.Stack,{component:"form",sx:{width:"40ch"},spacing:1,onSubmit:p((e=>g(e)))},e.createElement(v.FormControl,{sx:{"--FormHelperText-color":"var(--joy-palette-danger-500)"}},e.createElement(v.FormLabel,{htmlFor:"email"},"Email"),e.createElement(v.Input,{...m("email"),fullWidth:!0,size:"lg",id:"email",name:"email",autoComplete:"current-email",required:!0,error:Boolean(s)})),e.createElement(v.FormControl,{sx:{"--FormHelperText-color":"var(--joy-palette-danger-500)"}},e.createElement(v.FormLabel,{htmlFor:"password"},"Password"),e.createElement(v.Input,{...m("password"),fullWidth:!0,size:"lg",id:"password",autoComplete:"current-password",type:"password",required:!0})),e.createElement(v.Stack,{direction:"row",sx:{pt:2},spacing:2},e.createElement(v.Button,{onClick:()=>n(!1),variant:"plain"},"Cancel"),e.createElement(v.Button,{type:"submit"},"Create"))))))}function ae(t){const{allowCreation:r,buttonText:a,onUserCreateSuccess:n}=t,[o,l]=e.useState(!1);return r?e.createElement(c,{alignItems:"flex-end",gap:1},e.createElement(re,{open:o,setOpen:l,refetch:n}),e.createElement(s,{startDecorator:e.createElement(F,null),size:"sm",onClick:()=>l(!0)},a)):null}const ne=e=>Object.keys(e).reduce(((t,r)=>{const a=e[r];return a instanceof Set?t[r]=Array.from(a).join(", "):Array.isArray(a)?t[r]=a.join(", "):t[r]=a,t}),{}),oe=(e,t,r)=>{if(!e)return[[],[]];const a=e.map(ne),n=Object.keys(a[0]),o={},l=n?.map((e=>{const n=function(e,t,r){let a=r&&e?r.measureText(String(e)).width:50;a+=27;let n=a;return n=16+Math.ceil(r?r.measureText(t.reduce(((t,r)=>{let a=r[String(e)];return(q(a)||k(a))&&(a=""),a=a?.toString(),t.length>a.length?t:a}),"")).width:50),n<a&&(n=a),n+=8,n}(e,a,t),l=e.slice();if(r.includes(l))return null==o[l]?o[l]=l.length:o[l]+=1,{field:l.padEnd(o[l]),headerName:l.padEnd(o[l]),width:n}})).filter(Boolean)??[];return[l,a]};function le(t,r){const a=function(){const[t,r]=e.useState();return e.useEffect((()=>{const e=document.createElement("canvas").getContext("2d");e&&(e.font="18px Roboto",r(e))}),[]),t}(),[n,o]=e.useMemo((()=>oe(t,a,r)),[t,a,r]);return[n,o]}function ie(t){const{config:a,providerName:n,onSuccess:o,onError:l,allowEdit:i=!0,configurationGuide:s}=t,d=W(),[p,b]=e.useState(!1),[f,g]=e.useState(!1),[h,y]=e.useState(a),x=e.useRef(),E=e.useMemo((()=>{const e=[{name:"enabled",label:"Allow Okta logins",type:exports.FormAttributeType.Switch,defaultValue:!0===h?.enabled,options:[{label:"Enabled"},{label:"Disabled"}],disabled:!i},{name:"clientId",label:"Client id",type:exports.FormAttributeType.Text,defaultValue:h?.clientId??"",required:!0,disabled:!i},{name:"configUrl",label:"Config url",type:exports.FormAttributeType.Text,defaultValue:h?.configUrl??"",helpText:"The URL of the .well-known/openid-configuration for the identity provider",required:!0,disabled:!i},{name:"emailDomains",label:"Email domains",type:exports.FormAttributeType.Text,defaultValue:h?.emailDomains?.join(", ")??"",required:!0,helpText:"A comma seperated list of email domains (yourDomain.com) to be used",disabled:!i}];return h?.clientId||e.splice(2,0,{name:"clientSecret",label:"Client secret",type:exports.FormAttributeType.Password,defaultValue:"",required:!0,disabled:!i}),e}),[i,h?.clientId,h?.configUrl,h?.emailDomains,h?.enabled]),v=r.useMutation((e=>{b(!0);const t={providerName:n.toLowerCase(),updateProviderRequest:{...e,emailDomains:e.emailDomains.split(",")}};return null!=h?d.auth.updateProvider(t):d.auth.createProvider(t)}),{onSuccess:(e,t)=>{y(e),g(!0),o&&o(e,t)},onError:l,onSettled:(e,t,r)=>{b(!1),x.current&&clearTimeout(x.current),x.current=setTimeout((()=>{g(!1)}),3e3),e||(t&&!t?.message.includes("Unterminated string")||y({enabled:r.enabled,clientId:r.clientId,configUrl:r.configUrl,emailDomains:r.emailDomains.split(", ")}),g(!0),o&&o(e,r))}});return e.useEffect((()=>{})),e.createElement(c,{gap:2,position:"relative"},e.createElement(u,{level:"h4"},"Step 1"),s,e.createElement(u,{level:"h4"},"Step 2"),e.createElement(te,{mutation:v,buttonText:"Update",attributes:E,loading:p,successMessage:e.createElement(m,{color:"success",sx:{opacity:f?1:0,transition:"opacity 200ms",height:"0.9rem"},startDecorator:e.createElement(j,null)},e.createElement(u,{textAlign:"center",fontSize:"sm"},"Provider updated"))}))}function se({callbackUrl:t}){const[r,a]=e.useState(!1),n=e.useRef();return e.useEffect((()=>{n.current&&clearTimeout(n.current),n.current=setTimeout((()=>{a(!1)}),3250)}),[r]),e.createElement(c,{gap:2},e.createElement(u,null,"In order for Okta to redirect properly, provide the following URL as the"," ",e.createElement(i,{component:"span",sx:{fontFamily:"monospace"}},"Sign-in redirect URIs")," ","in the admin configuration of your application."),e.createElement(p,{onClick:async()=>{t&&(await navigator.clipboard.writeText(t),a(!0))},sx:e=>({input:{cursor:"pointer"},span:{cursor:"pointer"},"&:hover svg":{"--Icon-color":e.palette.primary[500]}}),value:t,readOnly:!0,endDecorator:e.createElement(E,{title:"Copy Okta redirect URL"},e.createElement(i,{position:"relative",width:r?"82px":"24px",height:"24px"},e.createElement(i,{position:"absolute",top:"0",left:"0",sx:{opacity:r?0:1,transition:"opacity 300ms"}},e.createElement(A,null)),e.createElement(i,{position:"absolute",top:"0",left:"0",sx:{opacity:r?1:0,transition:"opacity 300ms"}},e.createElement(c,{direction:"row",gap:1},e.createElement(j,null),e.createElement(u,{color:"primary"},"Copied!")))))}))}exports.GoogleLoginButton=function(t){const{databaseId:r,newTenantName:a}=t,{basePath:n}=_(),o=`${n}/databases/${encodeURIComponent(r??"")}/users/oidc/google/login`,l=a?"?newTenant="+encodeURIComponent(a):"",m=(t?.href??o)+l;return e.createElement(i,{component:"a",href:m,display:"flex",flex:1,sx:{textDecoration:"none"}},e.createElement(i,null,e.createElement(s,{sx:{padding:0,textTransform:"initial",flex:1},"aria-label":"log in with google"},e.createElement(c,{direction:"row",alignItems:"center",p:0,flex:1,fontFamily:"Roboto, sans-serif",fontSize:"14px",display:"inline-flex",color:"rgb(255 255, 255)",boxShadow:"rgb(0 0 0 / 24%) 0px 2px 2px 0px rgb(0 0 0 / 24%) 0px 0px 1px 0px",borderRadius:"4px",border:"1px solid transparent",fontWeight:"500",sx:{backgroundColor:"rgb(66 133, 244)"}},e.createElement(i,{padding:"11px",display:"flex",border:"1px solid rgb(66, 133, 244)",borderRadius:"4px",sx:{background:"rgb(255, 255, 255)"}},e.createElement(K,{"aria-hidden":"true"})),e.createElement(i,{padding:"10px",flex:1},e.createElement(u,{sx:{color:"white"},fontWeight:700,fontFamily:"Roboto, sans-serif",fontSize:"14px",height:"20px"},"Continue with Google"))))))},exports.NileProvider=r=>{const{children:a,theme:n,tenantId:o,QueryProvider:l=H,basePath:i="https://api.thenile.dev",api:s}=r,c=e.useMemo((()=>({api:s??new t({basePath:i,credentials:"include"}),tenantId:String(o),basePath:i})),[s,i,o]);return e.createElement(l,null,e.createElement(R,{theme:n},e.createElement(z,{value:c},a)))},exports.Okta=function(t){const{callbackUrl:r,providers:a,...n}=t;if(!a)return null;const o=a?.find((e=>"okta"===e.provider));return e.createElement(ie,{...n,config:o,providerName:"Okta",configurationGuide:e.createElement(se,{callbackUrl:r})})},exports.SSOForm=ie,exports.SingleSignOnForm=function(t){const{attributes:a,onSuccess:n,onError:o,beforeMutate:l,nextButtonText:i="Next",loginButtonText:s="Log in",disableSSO:c=!1}=t,u=W(),[m,d]=e.useState(c?s:i),p=r.useMutation((async e=>{const t=(l&&l(e))??e;return await u.auth.login({loginRequest:{email:t.email,password:t.password},sso:!c})}),{onSuccess:(e,t)=>{e&&(e?.redirectURI?window.location.href=e.redirectURI:m!==s?d(s):n&&n(e,t))},onError:(e,t)=>{m===s?o&&o(e,t):d(s)}}),b=e.useMemo((()=>{const e=[{name:"email",label:"Email",type:exports.FormAttributeType.Text,defaultValue:"",required:!0}];return m===s&&e.push({name:"password",label:"Password",type:exports.FormAttributeType.Password,defaultValue:"",required:!0}),a&&a.length>0?e.concat(a):e}),[a,m,s]);return e.createElement(te,{mutation:p,buttonText:m,attributes:b})},exports.UserLoginForm=function(t){const[a,n]=e.useState(),{attributes:o,onSuccess:l,onError:i,beforeMutate:s}=t,u=W(),d=r.useMutation((async e=>{n(void 0);const t=(s&&s(e))??e;return await u.auth.login({loginRequest:t})}),{onSuccess:l,onError:i}),p=e.useMemo((()=>{const e=[{name:"email",label:"Email",type:exports.FormAttributeType.Text,defaultValue:"",required:!0},{name:"password",label:"Password",type:exports.FormAttributeType.Password,defaultValue:"",required:!0}];return o&&o.length>0?e.concat(o):e}),[o]);return e.createElement(c,{gap:2},a?e.createElement(m,{color:"danger"},a):null,e.createElement(te,{mutation:d,buttonText:"Log in",attributes:p}))},exports.UserSignupForm=function(t){const[a,n]=e.useState(),{buttonText:o="Sign up",onSuccess:l,onError:i,attributes:s,beforeMutate:u}=t,d=W(),p=r.useMutation((async e=>{n(void 0);const t=(u&&u(e))??e,{email:r,password:a,preferredName:o,newTenant:l,...i}=t;return Object.keys(i).length>0&&console.warn("additional metadata not supported yet."),d.auth.signUp({signUpRequest:{email:r,password:a,preferredName:o,newTenant:l}})}),{onSuccess:l,onError:(e,t)=>{n(e.message),i&&i(e,t)}}),b=e.useMemo((()=>{const e=[{name:"email",label:"Email",type:exports.FormAttributeType.Text,defaultValue:"",required:!0},{name:"password",label:"Password",type:exports.FormAttributeType.Password,defaultValue:"",required:!0}];return s&&s.length>0?e.concat(s):e}),[s]);return e.createElement(c,{gap:2},a?e.createElement(m,{color:"danger"},a):null,e.createElement(te,{mutation:p,buttonText:o,attributes:b}))},exports.UserTenantList=function(t){const{data:r,allowCreation:a=!0,buttonText:n="Add a user",onUserCreateSuccess:o,slots:l,include:i=["email","preferedName"]}=t,s={width:"100%",height:"100%",...l?.dataGrid??{}},[u,m]=le(r,i);return e.createElement(c,{flex:1},e.createElement(ae,{allowCreation:a,buttonText:n,onUserCreateSuccess:o}),e.createElement(T.DataGrid,{sx:s,rows:m,columns:u,hideFooter:!0}))};
|
|
2
2
|
//# sourceMappingURL=react.cjs.development.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"react.cjs.development.js","sources":["../src/context/config.ts","../src/context/theme.tsx","../src/context/index.tsx","../src/GoogleLoginButton/google.svg","../src/lib/SimpleForm/CheckGroup/index.tsx","../src/lib/SimpleForm/types.ts","../src/lib/SimpleForm/index.tsx","../src/UserTenantList/UserModal.tsx","../src/UserTenantList/CreateUser.tsx","../src/UserTenantList/useDataParser.ts","../src/utils/getColumnSize.ts","../src/hooks/useTextSizer.ts","../src/SSO/BaseSSOForm.tsx","../src/SSO/Okta.tsx","../src/GoogleLoginButton/GoogleLoginButton.tsx","../src/LoginForm/SingleSignOn.tsx","../src/LoginForm/LoginForm.tsx","../src/SignUpForm/SignUpForm.tsx","../src/UserTenantList/UserList.tsx"],"sourcesContent":["/* eslint-disable @typescript-eslint/ban-ts-comment */\nimport deepmerge from '@mui/utils/deepmerge';\nimport { extendTheme as extendJoyTheme } from '@mui/joy/styles';\nimport { experimental_extendTheme as extendMuiTheme } from '@mui/material/styles';\n\nconst palette = {\n primary: {\n '50': '#fff7ed',\n '100': '#FFEAD2',\n '200': '#FFDCB5',\n '300': '#FFCE97', //primary\n '400': '#FFC480',\n '500': '#FDC067',\n '600': '#FFB262',\n '700': '#FFAA57',\n '800': '#FFA24D',\n '900': '#FF933C',\n solidColor: 'rgba(var(--nile-palette-primary-contrastTextChannel) / 1)',\n softColor: 'rgba(var(--nile-palette-primary-contrastTextChannel) / .5)',\n solidDisabledBg: 'var(--nile-palette-grey-600)',\n solidDisabledColor: 'var(--nile-palette-grey-700)',\n plainHoverBg:\n 'rgba(var(--nile-palette-primary-mainChannel) / var(--nile-palette-action-hoverOpacity))',\n outlinedHoverBg:\n 'rgba(var(--nile-palette-primary-mainChannel) / var(--nile-palette-action-selectedOpacity))',\n },\n neutral: {\n outlinedHoverBg:\n 'rgba(var(--nile-palette-neutral-mainChannel) / var(--nile-palette-action-selectedOpacity))',\n softBg: 'rgba(45, 45, 51)',\n },\n // @ts-ignore\n purple: {\n '50': '#f0edff',\n '100': '#d8d3ff', // primary\n '200': '#beb6fe',\n '300': '#a298fb',\n '400': '#8a7ff7',\n '500': '#7269f3',\n '600': '#6663eb',\n '700': '#565ae1',\n '800': '#4754d8',\n '900': '#2d47c9',\n },\n blue: {\n '50': '#dff8ff',\n '100': '#adedff',\n '200': '#6fe2ff', // primary\n '300': '#12d6fb',\n '400': '#00ccf6',\n '500': '#00c2f0',\n '600': '#00b2dc',\n '700': '#009dc0',\n '800': '#008aa6',\n '900': '#006778',\n },\n divider: '#181818',\n text: {\n primary: '#fff7ed',\n tertiary: 'rgba(255 255 255 / 0.5)',\n },\n background: {\n surface: '#000',\n body: '#000',\n default: '#000',\n },\n tableCell: {\n border: 'none',\n },\n};\n\nconst { unstable_sxConfig: muiSxConfig, ...muiTheme } = extendMuiTheme({\n cssVarPrefix: 'nile',\n colorSchemes: {\n dark: {\n palette: {\n primary: {\n main: '#FFCE97',\n },\n },\n },\n },\n});\n\nconst { unstable_sxConfig: joySxConfig, ...joyTheme } = extendJoyTheme({\n cssVarPrefix: 'nile',\n components: {\n JoyInput: {\n styleOverrides: {\n input: {\n ':disabled': { color: 'var(--nile-palette-neutral-500)' },\n '::placeholder': {\n opacity: 0.6,\n },\n color: 'white',\n },\n },\n },\n },\n colorSchemes: {\n dark: { palette },\n light: { palette },\n },\n});\nconst mergedTheme = {\n ...muiTheme,\n ...joyTheme,\n colorSchemes: deepmerge(muiTheme.colorSchemes, joyTheme.colorSchemes),\n typography: {\n ...muiTheme.typography,\n ...joyTheme.typography,\n },\n} as unknown as ReturnType<typeof extendJoyTheme>;\n\nmergedTheme.generateCssVars = (colorScheme) => ({\n css: {\n ...muiTheme.generateCssVars(colorScheme).css,\n ...joyTheme.generateCssVars(colorScheme).css,\n },\n //@ts-expect-error - new dev\n vars: deepmerge(\n muiTheme.generateCssVars(colorScheme).vars,\n joyTheme.generateCssVars(colorScheme).vars\n ),\n});\n\nmergedTheme.unstable_sxConfig = {\n ...muiSxConfig,\n ...joySxConfig,\n};\nexport default mergedTheme;\n","// eslint-disable-next-line @typescript-eslint/ban-ts-comment\nimport React from 'react';\nimport CssBaseline from '@mui/material/CssBaseline';\nimport { Theme } from '@mui/joy/styles';\nimport { CssVarsProvider as JoyCssVarsProvider } from '@mui/joy/styles';\n\nimport defaultTheme from './config';\n\nexport default function Themer({\n theme,\n children,\n}: {\n theme?: Theme;\n children: JSX.Element;\n}) {\n return (\n <JoyCssVarsProvider theme={theme ?? defaultTheme} defaultMode=\"dark\">\n <CssBaseline enableColorScheme />\n {children}\n </JoyCssVarsProvider>\n );\n}\n","// eslint-disable-next-line @typescript-eslint/ban-ts-comment\nimport React, { useMemo, createContext, useContext } from 'react';\nimport BrowserApi, { Client } from '@niledatabase/browser';\nimport { QueryClientProvider, QueryClient } from '@tanstack/react-query';\n\nimport ThemeProvider from './theme';\nimport { NileContext, NileProviderProps, NileReactConfig } from './types';\n\nconst queryClient = new QueryClient();\n\nconst defaultContext: NileContext = {\n api: BrowserApi({\n basePath: 'https://api.thenile.dev',\n credentials: 'include',\n }),\n basePath: '',\n};\n\nconst context = createContext<NileContext>(defaultContext);\n\nconst { Provider } = context;\n\nexport const BaseQueryProvider = ({\n children,\n}: {\n children: JSX.Element;\n}): JSX.Element => {\n return (\n <QueryClientProvider client={queryClient}>{children}</QueryClientProvider>\n );\n};\n\nexport const NileProvider = (props: NileProviderProps) => {\n const {\n children,\n theme,\n tenantId,\n QueryProvider = BaseQueryProvider,\n basePath = 'https://api.thenile.dev',\n api,\n } = props;\n\n const values = useMemo<NileContext>((): NileContext => {\n return {\n api:\n api ??\n BrowserApi({\n basePath,\n credentials: 'include',\n }),\n tenantId: String(tenantId),\n basePath,\n };\n }, [api, basePath, tenantId]);\n\n return (\n <QueryProvider>\n <ThemeProvider theme={theme}>\n <Provider value={values}>{children}</Provider>\n </ThemeProvider>\n </QueryProvider>\n );\n};\n\nconst useNileContext = (): NileContext => {\n return useContext(context);\n};\n\nexport const useNileConfig = (): NileReactConfig => {\n const { basePath, tenantId } = useNileContext();\n return useMemo(\n () => ({\n tenantId,\n basePath,\n }),\n [basePath, tenantId]\n );\n};\n\nexport const useApi = (): Client => {\n return useNileContext().api;\n};\n","<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"18\" height=\"18\">\n <g fill=\"#000\" fill-rule=\"evenodd\">\n <path d=\"M9 3.48c1.69 0 2.83.73 3.48 1.34l2.54-2.48C13.46.89 11.43 0 9 0 5.48 0 2.44 2.02.96 4.96l2.91 2.26C4.6 5.05 6.62 3.48 9 3.48z\" fill=\"#EA4335\" />\n <path d=\"M17.64 9.2c0-.74-.06-1.28-.19-1.84H9v3.34h4.96c-.1.83-.64 2.08-1.84 2.92l2.84 2.2c1.7-1.57 2.68-3.88 2.68-6.62z\" fill=\"#4285F4\" />\n <path d=\"M3.88 10.78A5.54 5.54 0 0 1 3.58 9c0-.62.11-1.22.29-1.78L.96 4.96A9.008 9.008 0 0 0 0 9c0 1.45.35 2.82.96 4.04l2.92-2.26z\" fill=\"#FBBC05\" />\n <path d=\"M9 18c2.43 0 4.47-.8 5.96-2.18l-2.84-2.2c-.76.53-1.78.9-3.12.9-2.38 0-4.4-1.57-5.12-3.74L.97 13.04C2.45 15.98 5.48 18 9 18z\" fill=\"#34A853\" />\n <path fill=\"none\" d=\"M0 0h18v18H0z\" />\n </g>\n</svg>","import * as React from 'react';\nimport Box from '@mui/joy/Box';\nimport Checkbox from '@mui/joy/Checkbox';\nimport List from '@mui/joy/List';\nimport { Controller, useFormContext } from 'react-hook-form';\nimport Stack from '@mui/joy/Stack';\nimport FormLabel from '@mui/joy/FormLabel';\nimport ListItem from '@mui/joy/ListItem';\nimport Typography from '@mui/joy/Typography';\n\nimport { Attribute, DisplayProps, Options } from '../types';\n\ntype Props = {\n attribute: Attribute;\n display: DisplayProps;\n options: Options;\n helperText: string;\n};\nexport default function CheckGroup(props: Props) {\n const { options, attribute, display, helperText } = props;\n const { watch, control } = useFormContext();\n const currentVals = watch(attribute.name);\n const checkProps: { color?: 'danger'; id?: string } = {};\n if (helperText) {\n checkProps.color = 'danger';\n }\n return (\n <Controller\n name={attribute.name}\n rules={{ required: Boolean(attribute.required) }}\n control={control}\n render={({ field }) => {\n return (\n <Stack>\n <FormLabel htmlFor={`${field.name}`}>{display.label}</FormLabel>\n <Box\n role=\"group\"\n aria-labelledby={attribute.name}\n sx={{\n borderRadius: 'var(--joy-radius-sm)',\n p: 0.5,\n border: helperText\n ? '1px solid var(--joy-palette-danger-outlinedBorder)'\n : 'none',\n }}\n >\n <List\n orientation=\"horizontal\"\n wrap\n sx={{\n '--List-gap': '8px',\n }}\n >\n {options.map((item) => {\n checkProps.id = String(item.value);\n return (\n <ListItem key={`${item.value}-${item.label}`}>\n <Checkbox\n overlay={options.length > 1}\n {...checkProps}\n checked={currentVals.includes(item.value)}\n disableIcon={options.length > 1}\n variant=\"soft\"\n label={item.label}\n onChange={(event) => {\n if (attribute.allowMultiple) {\n if (event.target.checked) {\n if (!currentVals) {\n field.onChange([item.value]);\n } else {\n field.onChange(currentVals.concat(item.value));\n }\n } else {\n const remaining = currentVals.filter(\n (val: string | number) => val !== item.value\n );\n if (remaining.length > 0) {\n field.onChange(remaining);\n } else {\n field.onChange('');\n }\n }\n } else {\n if (event.target.checked) {\n field.onChange(item.value);\n } else {\n field.onChange('');\n }\n }\n }}\n />\n </ListItem>\n );\n })}\n </List>\n </Box>\n <Typography\n sx={{ color: 'var(--joy-palette-danger-500)' }}\n level=\"body-sm\"\n >\n {helperText}\n </Typography>\n </Stack>\n );\n }}\n />\n );\n}\n","export enum AttributeType {\n Text = 'text',\n Password = 'password',\n Select = 'select',\n Number = 'number',\n Float = 'float',\n Checkbox = 'checkbox',\n Switch = 'switch',\n}\ntype SimplePrimitive = number | string | boolean;\n\n// possibly no value for `<Switch/>`\nexport type Options = { label: string; value?: SimplePrimitive }[];\nexport type Attribute = {\n name: string;\n type?: AttributeType;\n defaultValue?: SimplePrimitive;\n options?: Options;\n allowMultiple?: boolean;\n label?: string;\n required?: boolean;\n placeholder?: string;\n helpText?: string;\n disabled?: boolean;\n};\n\nexport type DisplayProps = {\n key: string;\n id: string;\n label: string;\n placeholder: string;\n error?: boolean;\n color?: 'danger';\n disabled?: boolean;\n};\n","import React from 'react';\nimport Button from '@mui/joy/Button';\nimport { Controller, FormProvider, useForm } from 'react-hook-form';\nimport Stack from '@mui/joy/Stack';\nimport Input from '@mui/joy/Input';\nimport FormControl from '@mui/joy/FormControl';\nimport FormHelperText from '@mui/joy/FormHelperText';\nimport Error from '@mui/icons-material/Error';\nimport FormLabel from '@mui/joy/FormLabel';\nimport Select from '@mui/joy/Select';\nimport Option from '@mui/joy/Option';\nimport Box from '@mui/joy/Box';\nimport Tooltip from '@mui/joy/Tooltip';\nimport { Switch } from '@mui/joy';\n\nimport CheckGroup from './CheckGroup';\nimport { Attribute, AttributeType, DisplayProps } from './types';\n\ntype AttrMap = {\n [key: string]: string | number | boolean | string[] | number[];\n};\n\ntype FieldConfig = {\n required?: boolean;\n};\n\nexport const getAttributeDefault = (\n attribute: Attribute\n): string | number | boolean | string[] | number[] => {\n // have to look to see if it is an enum\n if (attribute.allowMultiple === true) {\n if (!Array.isArray(attribute.defaultValue) && attribute.defaultValue) {\n if (typeof attribute.defaultValue === 'number') {\n return [attribute.defaultValue];\n }\n return [String(attribute.defaultValue)];\n }\n }\n return attribute.defaultValue ?? '';\n};\n\nfunction Labler(props: { error?: string; attr: Attribute }) {\n const { error, attr } = props;\n if (error) {\n return (\n <Tooltip title={error} color=\"danger\" sx={{ cursor: 'pointer' }}>\n <FormLabel>\n {attr.label ?? attr.name}\n <Error sx={{ ml: 0.5, '--Icon-color': '#c41c1c' }} fontSize=\"small\" />\n </FormLabel>\n </Tooltip>\n );\n }\n return <FormLabel>{attr.label ?? attr.name}</FormLabel>;\n}\nexport default function SimpleForm(props: {\n buttonText: string;\n cancelButton?: React.ReactNode;\n attributes: Attribute[];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n mutation: any;\n loading?: boolean;\n successMessage?: JSX.Element;\n}) {\n const {\n mutation,\n buttonText,\n attributes,\n cancelButton,\n loading,\n successMessage,\n } = props;\n\n const defaultValues = React.useMemo(\n () =>\n attributes.reduce((accum: AttrMap, attr: Attribute) => {\n accum[attr.name] = getAttributeDefault(attr);\n return accum;\n }, {}),\n [attributes]\n );\n\n const methods = useForm({\n defaultValues,\n });\n\n const {\n register,\n control,\n handleSubmit,\n formState: { errors },\n } = methods;\n const onSubmit = React.useCallback(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (data: any) => {\n mutation.mutate(data);\n },\n [mutation]\n );\n\n return (\n <FormProvider {...methods}>\n <Stack\n component=\"form\"\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n onSubmit={handleSubmit((data) => onSubmit(data as any))}\n spacing={2}\n >\n {attributes.map((attr: Attribute): React.ReactNode => {\n const fieldConfig: FieldConfig = {};\n const display: DisplayProps = {\n key: attr.name,\n label: attr.label ?? attr.name,\n id: attr.label ?? attr.name,\n placeholder: attr.placeholder ?? attr.label ?? attr.name,\n error: Boolean(errors[attr.name]),\n disabled: Boolean(attr.disabled),\n };\n const options = attr.options ?? [];\n const helperText = attr.helpText ?? '';\n let error = '';\n\n if (attr.required) {\n error = errors[attr.name]\n ? `${attr.label ?? attr.name} is required`\n : '';\n fieldConfig.required = true;\n }\n\n switch (attr.type) {\n case AttributeType.Switch:\n return (\n <FormControl\n key={display.key}\n id={display.id}\n orientation=\"horizontal\"\n sx={{ alignItems: 'center' }}\n >\n <Box>\n <Labler error={error} attr={attr} />\n <FormHelperText id={`${attr.name}-helper-text`}>\n {helperText}\n </FormHelperText>\n </Box>\n <Controller\n control={control}\n rules={{ required: Boolean(attr.required) }}\n name={attr.name}\n render={({ field }) => {\n const color: { color?: 'danger' } = {};\n if (errors[attr.name]) {\n color.color = 'danger';\n }\n return (\n <Switch\n id={`switch-field-${attr.name}`}\n {...color}\n {...field}\n checked={Boolean(field.value)}\n onChange={(event) => {\n field.onChange(event.target.checked);\n }}\n color={field.value ? 'success' : 'neutral'}\n endDecorator={\n field.value ? options[0].label : options[1].label\n }\n sx={{\n '--Switch-thumbSize': '28px',\n }}\n />\n );\n }}\n />\n </FormControl>\n );\n case AttributeType.Checkbox:\n return (\n <CheckGroup\n key={display.key}\n attribute={attr}\n display={display}\n options={options}\n helperText={helperText}\n />\n );\n case AttributeType.Select:\n return (\n <FormControl key={display.key} id={display.id}>\n <Labler error={error} attr={attr} />\n <Controller\n control={control}\n rules={{ required: Boolean(attr.required) }}\n name={attr.name}\n render={({ field }) => {\n const color: { color?: 'danger' } = {};\n if (errors[attr.name]) {\n color.color = 'danger';\n }\n const value = String(field.value);\n return (\n <Stack>\n <Select\n id={`select-field-${attr.name}`}\n placeholder={`${display.placeholder}...`}\n {...color}\n {...field}\n value={value}\n onChange={(_, newValue) => {\n field.onChange(newValue);\n }}\n >\n {options.map((option) => {\n return (\n <Option\n key={String(option.value ?? '')}\n value={option.value}\n >\n {option.label}\n </Option>\n );\n })}\n </Select>\n <FormHelperText id={`${attr.name}-helper-text`}>\n {helperText}\n </FormHelperText>\n </Stack>\n );\n }}\n />\n </FormControl>\n );\n case AttributeType.Password:\n return (\n <FormControl key={display.key} id={display.id}>\n <Labler error={error} attr={attr} />\n <Input\n {...display}\n {...register(attr.name, fieldConfig)}\n type={AttributeType.Password}\n />\n <FormHelperText id={`${attr.name}-helper-text`}>\n {helperText}\n </FormHelperText>\n </FormControl>\n );\n case AttributeType.Number:\n return (\n <FormControl key={display.key} id={display.id}>\n <Labler error={error} attr={attr} />\n <Input\n {...display}\n {...register(attr.name, fieldConfig)}\n type={AttributeType.Number}\n />\n <FormHelperText id={`${attr.name}-helper-text`}>\n {helperText}\n </FormHelperText>\n </FormControl>\n );\n\n case AttributeType.Text:\n default:\n return (\n <FormControl key={display.key} id={display.id}>\n <Labler error={error} attr={attr} />\n <Input {...display} {...register(attr.name, fieldConfig)} />\n <FormHelperText id={`${attr.name}-helper-text`}>\n {helperText}\n </FormHelperText>\n </FormControl>\n );\n }\n })}\n {cancelButton ? (\n <Stack spacing={2} direction=\"row\">\n {cancelButton}\n <Box>\n <Button type=\"submit\">{buttonText}</Button>\n </Box>\n </Stack>\n ) : (\n <Box>\n <Stack direction=\"row\" gap={2}>\n <Button type=\"submit\" loading={loading}>\n {buttonText}\n </Button>\n {successMessage}\n </Stack>\n </Box>\n )}\n </Stack>\n </FormProvider>\n );\n}\n","import React from 'react';\nimport {\n Button,\n Stack,\n Typography,\n FormControl,\n FormLabel,\n Input,\n Modal,\n ModalDialog,\n} from '@mui/joy';\nimport { useForm } from 'react-hook-form';\nimport { useMutation } from '@tanstack/react-query';\nimport { SignUp201Response, SignUpRequest } from '@niledatabase/browser';\n\nimport { useApi, useNileConfig } from '../context';\n\nexport type UserFormProps = {\n open: boolean;\n setOpen: (open: boolean) => void;\n refetch?: (user: SignUp201Response) => void;\n};\n\nexport default function AddUser(props: UserFormProps) {\n const { open, setOpen, refetch } = props;\n const { tenantId } = useNileConfig();\n const api = useApi();\n const [errorText, setErrorText] = React.useState<void | string>();\n const { watch, register, handleSubmit } = useForm<SignUpRequest>();\n const email = watch('email');\n\n React.useEffect(() => {\n if (errorText != null) {\n setErrorText();\n }\n // if email changes, no more error\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [email]);\n\n const mutation = useMutation(\n (data: SignUpRequest) =>\n api.users.createTenantUser({\n signUpRequest: data,\n tenantId: String(tenantId),\n }),\n {\n onSuccess(data) {\n refetch && refetch(data);\n setOpen(false);\n },\n onError(e) {\n if (e instanceof Error) {\n setErrorText(e.message);\n }\n },\n }\n );\n\n const handleUpdate = React.useCallback(\n async (data: SignUpRequest) => {\n setErrorText('');\n mutation.mutate(data);\n },\n [mutation]\n );\n\n return (\n <Modal open={open}>\n <ModalDialog>\n <Stack spacing={2}>\n <Typography level=\"h4\">Create user</Typography>\n <>\n {errorText && <Typography color=\"danger\">{errorText}</Typography>}\n </>\n <Stack\n component=\"form\"\n sx={{\n width: '40ch',\n }}\n spacing={1}\n onSubmit={handleSubmit((data) =>\n handleUpdate(data as SignUpRequest)\n )}\n >\n <FormControl\n sx={{\n '--FormHelperText-color': 'var(--joy-palette-danger-500)',\n }}\n >\n <FormLabel htmlFor=\"email\">Email</FormLabel>\n <Input\n {...register('email')}\n fullWidth\n size=\"lg\"\n id=\"email\"\n name=\"email\"\n autoComplete=\"current-email\"\n required\n error={Boolean(errorText)}\n />\n </FormControl>\n <FormControl\n sx={{\n '--FormHelperText-color': 'var(--joy-palette-danger-500)',\n }}\n >\n <FormLabel htmlFor=\"password\">Password</FormLabel>\n <Input\n {...register('password')}\n fullWidth\n size=\"lg\"\n id=\"password\"\n autoComplete=\"current-password\"\n type=\"password\"\n required\n />\n </FormControl>\n <Stack direction=\"row\" sx={{ pt: 2 }} spacing={2}>\n <Button onClick={() => setOpen(false)} variant=\"plain\">\n Cancel\n </Button>\n <Button type=\"submit\">Create</Button>\n </Stack>\n </Stack>\n </Stack>\n </ModalDialog>\n </Modal>\n );\n}\n","import React from 'react';\nimport Button from '@mui/joy/Button';\nimport Stack from '@mui/joy/Stack';\nimport { useState } from 'react';\nimport Add from '@mui/icons-material/Add';\nimport { SignUp201Response } from '@niledatabase/browser';\n\nimport UserModal from './UserModal';\n\ntype Props = {\n allowCreation: boolean;\n buttonText: string;\n onUserCreateSuccess?: (user: SignUp201Response) => void;\n};\nexport default function CreateUser(props: Props) {\n const { allowCreation, buttonText, onUserCreateSuccess } = props;\n const [open, setOpen] = useState(false);\n if (!allowCreation) {\n return null;\n }\n\n return (\n <Stack alignItems=\"flex-end\" gap={1}>\n <UserModal open={open} setOpen={setOpen} refetch={onUserCreateSuccess} />\n <Button startDecorator={<Add />} size=\"sm\" onClick={() => setOpen(true)}>\n {buttonText}\n </Button>\n </Stack>\n );\n}\n","import { useMemo } from 'react';\nimport { GridColDef, GridRowsProp } from '@mui/x-data-grid';\nimport { User } from '@niledatabase/browser';\n\nimport getColumnSize from '../utils/getColumnSize';\nimport useTextSizer from '../hooks/useTextSizer';\n\nexport const internalRowId = '_nile_data_grid_identifier';\n\ntype Cleaned = { [key: string]: string | Set<string> };\n\nconst makeRenderable = (vals: User) => {\n return Object.keys(vals).reduce((cleaned: Cleaned, key) => {\n const val = (vals as Cleaned)[key];\n if (val instanceof Set) {\n cleaned[key] = Array.from(val).join(', ');\n } else if (Array.isArray(val)) {\n cleaned[key] = val.join(', ');\n } else {\n cleaned[key] = val;\n }\n return cleaned;\n }, {});\n};\n\nconst parseResults = (\n data: void | User[],\n ctx: CanvasRenderingContext2D | void,\n include: string[]\n): [GridColDef[], GridRowsProp] => {\n if (!data) {\n return [[], []];\n }\n const rows = data.map(makeRenderable);\n const fields = Object.keys(rows[0]);\n\n const existentCols: { [key: string]: number } = {};\n\n const mapCols = (col: string): GridColDef | void => {\n const width = getColumnSize(col, rows, ctx);\n const name = col.slice();\n if (include.includes(name)) {\n // add spaces to the end of column names so they are not duplicated in the UI\n if (existentCols[name] == null) {\n existentCols[name] = name.length;\n } else {\n existentCols[name] += 1;\n }\n return {\n field: name.padEnd(existentCols[name]),\n headerName: name.padEnd(existentCols[name]),\n width,\n };\n }\n };\n const cols = fields?.map(mapCols).filter(Boolean) ?? [];\n\n return [cols as GridColDef[], rows];\n};\n\nexport default function useDataParser(\n data: void | User[],\n include: string[]\n): [GridColDef[], GridRowsProp] {\n const ctx = useTextSizer();\n const [cols, rows] = useMemo(\n () => parseResults(data, ctx, include),\n [data, ctx, include]\n );\n return [cols, rows];\n}\n","import { GridRowsProp } from '@mui/x-data-grid';\nimport isNull from 'lodash/isNull';\nimport isUndefined from 'lodash/isUndefined';\n\nexport default function getColumnSize(\n column: unknown,\n rows: GridRowsProp,\n canvasContext: void | CanvasRenderingContext2D\n) {\n const dataWidthReducer = (\n longest: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n nextRow: { [key: string]: any }\n ) => {\n let value = nextRow[String(column)];\n if (isNull(value) || isUndefined(value)) {\n value = '';\n }\n value = value?.toString();\n return longest.length > value.length ? longest : value;\n };\n\n let columnHeaderLen =\n canvasContext && column\n ? canvasContext.measureText(String(column)).width\n : 50;\n /* padding 12, icon-width 15 */\n columnHeaderLen += 15 + 12;\n\n let width = columnHeaderLen;\n width =\n 16 +\n Math.ceil(\n canvasContext\n ? canvasContext.measureText(rows.reduce(dataWidthReducer, '')).width\n : 50\n );\n if (width < columnHeaderLen) {\n width = columnHeaderLen;\n }\n /* Gracefull */\n width += 8;\n return width;\n}\n","import { useEffect, useState } from 'react';\n\nexport default function useTextSizer() {\n const [ctx, setCtx] = useState<CanvasRenderingContext2D>();\n useEffect(() => {\n const canvas = document.createElement('canvas');\n const canvasContext = canvas.getContext('2d');\n if (canvasContext) {\n canvasContext.font = '18px Roboto';\n setCtx(canvasContext);\n }\n }, []);\n return ctx;\n}\n","import React from 'react';\nimport { useMutation } from '@tanstack/react-query';\nimport { UpdateProviderRequest, SSOProvider } from '@niledatabase/browser';\nimport Stack from '@mui/joy/Stack';\nimport Typography from '@mui/joy/Typography';\nimport Alert from '@mui/joy/Alert';\nimport CheckCircleOutlined from '@mui/icons-material/CheckCircleOutlined';\n\nimport SimpleForm from '../lib/SimpleForm';\nimport { useApi } from '../context';\nimport { Attribute, AttributeType } from '../lib/SimpleForm/types';\n\nimport { OktaProps } from './types';\n\ntype SSOFormRequest = Omit<UpdateProviderRequest, 'emailDomains'> & {\n emailDomains: string;\n};\nexport default function BaseSSOForm(\n props: Omit<OktaProps, 'callbackUrl' | 'providers'> & {\n providerName: string;\n configurationGuide?: JSX.Element;\n config?: SSOProvider;\n }\n) {\n const {\n config,\n providerName,\n onSuccess,\n onError,\n allowEdit = true,\n configurationGuide,\n } = props;\n\n const api = useApi();\n const [loading, setLoading] = React.useState(false);\n const [success, setSuccess] = React.useState(false);\n const [optimisticConfig, setConfig] = React.useState<SSOProvider | void>(\n config\n );\n const timer = React.useRef<NodeJS.Timeout>();\n const attributes = React.useMemo(() => {\n const attributes: Attribute[] = [\n {\n name: 'enabled',\n label: 'Allow Okta logins',\n type: AttributeType.Switch,\n defaultValue: optimisticConfig?.enabled === true,\n options: [\n {\n label: 'Enabled',\n },\n {\n label: 'Disabled',\n },\n ],\n disabled: !allowEdit,\n },\n {\n name: 'clientId',\n label: 'Client id',\n type: AttributeType.Text,\n defaultValue: optimisticConfig?.clientId ?? '',\n required: true,\n disabled: !allowEdit,\n },\n {\n name: 'configUrl',\n label: 'Config url',\n type: AttributeType.Text,\n defaultValue: optimisticConfig?.configUrl ?? '',\n helpText:\n 'The URL of the .well-known/openid-configuration for the identity provider',\n required: true,\n disabled: !allowEdit,\n },\n {\n name: 'emailDomains',\n label: 'Email domains',\n type: AttributeType.Text,\n defaultValue: optimisticConfig?.emailDomains?.join(', ') ?? '',\n required: true,\n helpText:\n 'A comma seperated list of email domains (yourDomain.com) to be used',\n disabled: !allowEdit,\n },\n ];\n if (!optimisticConfig?.clientId) {\n attributes.splice(2, 0, {\n name: 'clientSecret',\n label: 'Client secret',\n type: AttributeType.Password,\n defaultValue: '',\n required: true,\n disabled: !allowEdit,\n });\n }\n return attributes;\n }, [\n allowEdit,\n optimisticConfig?.clientId,\n optimisticConfig?.configUrl,\n optimisticConfig?.emailDomains,\n optimisticConfig?.enabled,\n ]);\n\n const handleTimer = () => {\n if (timer.current) {\n clearTimeout(timer.current);\n }\n\n timer.current = setTimeout(() => {\n setSuccess(false);\n }, 3000);\n };\n\n const mutation = useMutation(\n (ssoRequest: SSOFormRequest) => {\n setLoading(true);\n const payload = {\n providerName: providerName.toLowerCase(),\n updateProviderRequest: {\n ...ssoRequest,\n emailDomains: ssoRequest.emailDomains.split(','),\n },\n };\n if (optimisticConfig != null) {\n return api.auth.updateProvider(payload);\n } else {\n return api.auth.createProvider(payload);\n }\n },\n {\n onSuccess: (data, vars) => {\n setConfig(data);\n setSuccess(true);\n onSuccess && onSuccess(data, vars);\n },\n onError,\n onSettled: (data, error, vars) => {\n setLoading(false);\n handleTimer();\n if (!data) {\n if (!error || error?.message.includes('Unterminated string')) {\n // something unexpected happened on the BE, but it's non-fatal\n setConfig({\n enabled: vars.enabled,\n clientId: vars.clientId,\n configUrl: vars.configUrl,\n emailDomains: vars.emailDomains.split(', '),\n } as SSOProvider);\n }\n setSuccess(true);\n onSuccess && onSuccess(data, vars);\n }\n },\n }\n );\n\n React.useEffect(() => {\n () => {\n clearTimeout(timer.current);\n };\n });\n\n return (\n <Stack gap={2} position=\"relative\">\n <Typography level=\"h4\">Step 1</Typography>\n {configurationGuide}\n <Typography level=\"h4\">Step 2</Typography>\n <SimpleForm\n mutation={mutation}\n buttonText=\"Update\"\n attributes={attributes}\n loading={loading}\n successMessage={\n <Alert\n color=\"success\"\n sx={{\n opacity: success ? 1 : 0,\n transition: 'opacity 200ms',\n height: '0.9rem',\n }}\n startDecorator={<CheckCircleOutlined />}\n >\n <Typography textAlign=\"center\" fontSize=\"sm\">\n Provider updated\n </Typography>\n </Alert>\n }\n />\n </Stack>\n );\n}\n","import React from 'react';\nimport Stack from '@mui/joy/Stack';\nimport Typography from '@mui/joy/Typography';\nimport Box from '@mui/joy/Box';\nimport Input from '@mui/joy/Input';\nimport CopyAll from '@mui/icons-material/CopyAll';\nimport { Theme } from '@mui/joy/styles';\nimport Tooltip from '@mui/joy/Tooltip';\nimport CheckCircleOutlined from '@mui/icons-material/CheckCircleOutlined';\nimport { SSOProvider } from '@niledatabase/browser';\n\nimport BaseSSOForm from './BaseSSOForm';\nimport { OktaProps } from './types';\n\nfunction ConfigGuide({ callbackUrl }: { callbackUrl?: string }) {\n const [copied, setCopied] = React.useState(false);\n\n const timer = React.useRef<NodeJS.Timeout>();\n React.useEffect(() => {\n if (timer.current) {\n clearTimeout(timer.current);\n }\n timer.current = setTimeout(() => {\n setCopied(false);\n }, 3250);\n () => {\n clearTimeout(timer.current);\n };\n }, [copied]);\n return (\n <Stack gap={2}>\n <Typography>\n In order for Okta to redirect properly, provide the following URL as the{' '}\n <Box component=\"span\" sx={{ fontFamily: 'monospace' }}>\n Sign-in redirect URIs\n </Box>{' '}\n in the admin configuration of your application.\n </Typography>\n <Input\n onClick={async () => {\n if (callbackUrl) {\n await navigator.clipboard.writeText(callbackUrl);\n setCopied(true);\n }\n }}\n sx={(theme: Theme) => ({\n input: {\n cursor: 'pointer',\n },\n span: {\n cursor: 'pointer',\n },\n '&:hover svg': {\n '--Icon-color': theme.palette.primary[500],\n },\n })}\n value={callbackUrl}\n readOnly={true}\n endDecorator={\n <Tooltip title=\"Copy Okta redirect URL\">\n <Box\n position=\"relative\"\n width={copied ? '82px' : '24px'}\n height=\"24px\"\n >\n <Box\n position=\"absolute\"\n top=\"0\"\n left=\"0\"\n sx={{\n opacity: copied ? 0 : 1,\n transition: 'opacity 300ms',\n }}\n >\n <CopyAll />\n </Box>\n <Box\n position=\"absolute\"\n top=\"0\"\n left=\"0\"\n sx={{ opacity: !copied ? 0 : 1, transition: 'opacity 300ms' }}\n >\n <Stack direction=\"row\" gap={1}>\n <CheckCircleOutlined />\n <Typography color=\"primary\">Copied!</Typography>\n </Stack>\n </Box>\n </Box>\n </Tooltip>\n }\n />\n </Stack>\n );\n}\n\nexport default function Okta(props: OktaProps) {\n const { callbackUrl, providers, ...remaining } = props;\n if (!providers) {\n return null;\n }\n const config = providers?.find((provider) => provider.provider === 'okta');\n return (\n <BaseSSOForm\n {...remaining}\n config={config as SSOProvider}\n providerName=\"Okta\"\n configurationGuide={<ConfigGuide callbackUrl={callbackUrl} />}\n />\n );\n}\n","import React from 'react';\nimport Box from '@mui/joy/Box';\nimport Button from '@mui/joy/Button';\nimport Stack from '@mui/joy/Stack';\nimport Typography from '@mui/joy/Typography';\n\nimport { useNileConfig } from '../context';\n\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nimport GoogleLogo from './google.svg';\n\nconst LOGIN_PATH = 'users/oidc/google/login';\n\n/**\n * A component for a Google login button, according to their design language.\n * This works when an identity provider is configured in the admin dashboard.\n * @param props href: a string to override the URL provided by the context\n * @returns a JSX.Element to render\n */\nexport default function GoogleSSOButton(props: {\n href?: string;\n databaseId?: string;\n newTenantName?: string;\n}) {\n const { databaseId, newTenantName } = props;\n const { basePath } = useNileConfig();\n const encodedDatabase = encodeURIComponent(databaseId ?? '');\n const contextHref = `${basePath}/databases/${encodedDatabase}/${LOGIN_PATH}`;\n const query = newTenantName\n ? '?newTenant=' + encodeURIComponent(newTenantName)\n : '';\n const href = (props?.href ?? contextHref) + query;\n return (\n <Box\n component=\"a\"\n href={href}\n display=\"flex\"\n flex={1}\n sx={{ textDecoration: 'none' }}\n >\n <Box>\n <Button\n sx={{ padding: 0, textTransform: 'initial', flex: 1 }}\n aria-label=\"log in with google\"\n >\n <Stack\n direction=\"row\"\n alignItems=\"center\"\n p={0}\n flex={1}\n fontFamily=\"Roboto, sans-serif\"\n fontSize=\"14px\"\n display=\"inline-flex\"\n color=\"rgb(255 255, 255)\"\n boxShadow=\"rgb(0 0 0 / 24%) 0px 2px 2px 0px rgb(0 0 0 / 24%) 0px 0px 1px 0px\"\n borderRadius=\"4px\"\n border=\"1px solid transparent\"\n fontWeight=\"500\"\n sx={{\n backgroundColor: 'rgb(66 133, 244)',\n }}\n >\n <Box\n padding=\"11px\"\n display=\"flex\"\n border=\"1px solid rgb(66, 133, 244)\"\n borderRadius=\"4px\"\n sx={{\n background: 'rgb(255, 255, 255)',\n }}\n >\n <GoogleLogo aria-hidden=\"true\" />\n </Box>\n <Box padding=\"10px\" flex={1}>\n <Typography\n sx={{ color: 'white' }}\n fontWeight={700}\n fontFamily=\"Roboto, sans-serif\"\n fontSize=\"14px\"\n height=\"20px\"\n >\n Continue with Google\n </Typography>\n </Box>\n </Stack>\n </Button>\n </Box>\n </Box>\n );\n}\n","import React from 'react';\nimport { useMutation } from '@tanstack/react-query';\n\nimport { Attribute } from '../lib/SimpleForm/types';\nimport { useApi } from '../context';\nimport SimpleForm from '../lib/SimpleForm';\nimport { AttributeType } from '../lib/SimpleForm/types';\n\nimport { Props, LoginInfo } from './types';\n\nexport default function SingleSignOnForm(\n props: Props & {\n nextButtonText?: string;\n loginButtonText?: string;\n onSuccess: () => void;\n }\n) {\n const {\n attributes,\n onSuccess,\n onError,\n beforeMutate,\n nextButtonText = 'Next',\n loginButtonText = 'Log in',\n disableSSO = false,\n } = props;\n const api = useApi();\n const [buttonText, setButtonText] = React.useState(\n disableSSO ? loginButtonText : nextButtonText\n );\n\n const mutation = useMutation(\n async (_data: LoginInfo) => {\n const possibleData = beforeMutate && beforeMutate(_data);\n const data = possibleData ?? _data;\n return await api.auth.login({\n loginRequest: { email: data.email, password: data.password },\n sso: !disableSSO,\n });\n },\n {\n onSuccess: (token, data) => {\n if (token) {\n if (token?.redirectURI) {\n window.location.href = token.redirectURI;\n } else if (buttonText !== loginButtonText) {\n setButtonText(loginButtonText);\n } else {\n onSuccess && onSuccess(token, data);\n }\n }\n },\n onError: (error, data) => {\n // it is possible SSO failed, so only show errors on if the password is available\n if (buttonText === loginButtonText) {\n onError && onError(error as Error, data);\n } else {\n setButtonText(loginButtonText);\n }\n },\n }\n );\n\n const completeAttributes = React.useMemo(() => {\n const mainAttributes: Attribute[] = [\n {\n name: 'email',\n label: 'Email',\n type: AttributeType.Text,\n defaultValue: '',\n required: true,\n },\n ];\n if (buttonText === loginButtonText) {\n mainAttributes.push({\n name: 'password',\n label: 'Password',\n type: AttributeType.Password,\n defaultValue: '',\n required: true,\n });\n }\n if (attributes && attributes.length > 0) {\n return mainAttributes.concat(attributes);\n }\n return mainAttributes;\n }, [attributes, buttonText, loginButtonText]);\n\n return (\n <SimpleForm\n mutation={mutation}\n buttonText={buttonText}\n attributes={completeAttributes}\n />\n );\n}\n","import React from 'react';\nimport { useMutation } from '@tanstack/react-query';\nimport Alert from '@mui/joy/Alert';\nimport Stack from '@mui/joy/Stack';\n\nimport { Attribute } from '../lib/SimpleForm/types';\nimport { useApi } from '../context';\nimport SimpleForm from '../lib/SimpleForm';\nimport { AttributeType } from '../lib/SimpleForm/types';\n\nimport { Props, LoginInfo } from './types';\n\nexport default function LoginForm(props: Props) {\n const [error, setError] = React.useState<string | void>();\n const { attributes, onSuccess, onError, beforeMutate } = props;\n const api = useApi();\n\n const mutation = useMutation(\n async (_data: LoginInfo) => {\n setError(undefined);\n const possibleData = beforeMutate && beforeMutate(_data);\n const data = possibleData ?? _data;\n return await api.auth.login({\n loginRequest: data,\n });\n },\n {\n onSuccess,\n onError,\n }\n );\n\n const completeAttributes = React.useMemo(() => {\n const mainAttributes: Attribute[] = [\n {\n name: 'email',\n label: 'Email',\n type: AttributeType.Text,\n defaultValue: '',\n required: true,\n },\n {\n name: 'password',\n label: 'Password',\n type: AttributeType.Password,\n defaultValue: '',\n required: true,\n },\n ];\n if (attributes && attributes.length > 0) {\n return mainAttributes.concat(attributes);\n }\n return mainAttributes;\n }, [attributes]);\n\n return (\n <Stack gap={2}>\n {error ? <Alert color=\"danger\">{error}</Alert> : null}\n <SimpleForm\n mutation={mutation}\n buttonText=\"Log in\"\n attributes={completeAttributes}\n />\n </Stack>\n );\n}\n","import React from 'react';\nimport { useMutation } from '@tanstack/react-query';\nimport Stack from '@mui/joy/Stack';\nimport Alert from '@mui/joy/Alert';\n\nimport UserForm from '../lib/SimpleForm';\nimport { Attribute, AttributeType } from '../lib/SimpleForm/types';\nimport { useApi } from '../context';\n\nimport { Props, LoginInfo } from './types';\n\nexport default function SignUpForm(props: Props) {\n const [error, setError] = React.useState<string | void>();\n const {\n buttonText = 'Sign up',\n onSuccess,\n onError,\n attributes,\n beforeMutate,\n } = props;\n const api = useApi();\n const mutation = useMutation(\n async (_data: LoginInfo) => {\n setError(undefined);\n const possibleData = beforeMutate && beforeMutate(_data);\n const data = possibleData ?? _data;\n const { email, password, preferredName, newTenant, ...metadata } = data;\n if (Object.keys(metadata).length > 0) {\n // eslint-disable-next-line no-console\n console.warn('additional metadata not supported yet.');\n }\n return api.auth.signUp({\n signUpRequest: { email, password, preferredName, newTenant },\n });\n },\n {\n onSuccess,\n onError: (e: Error, vars) => {\n setError(e.message);\n onError && onError(e as Error, vars);\n },\n }\n );\n\n const completeAttributes = React.useMemo(() => {\n const mainAttributes: Attribute[] = [\n {\n name: 'email',\n label: 'Email',\n type: AttributeType.Text,\n defaultValue: '',\n required: true,\n },\n {\n name: 'password',\n label: 'Password',\n type: AttributeType.Password,\n defaultValue: '',\n required: true,\n },\n ];\n if (attributes && attributes.length > 0) {\n return mainAttributes.concat(attributes);\n }\n return mainAttributes;\n }, [attributes]);\n\n return (\n <Stack gap={2}>\n {error ? <Alert color=\"danger\">{error}</Alert> : null}\n <UserForm\n mutation={mutation}\n buttonText={buttonText}\n attributes={completeAttributes}\n />\n </Stack>\n );\n}\n","import { DataGrid } from '@mui/x-data-grid';\nimport React from 'react';\nimport Stack from '@mui/joy/Stack';\nimport { SxProps } from '@mui/system/styleFunctionSx/styleFunctionSx';\nimport { Theme } from '@mui/system/createTheme';\nimport { SignUp201Response, User } from '@niledatabase/browser';\n\nimport CreateUser from './CreateUser';\nimport useDataParser from './useDataParser';\n\ntype ColumnNames = string;\n\ntype Props = {\n data: void | User[];\n allowCreation?: boolean;\n buttonText?: string;\n onUserCreateSuccess?: (user: SignUp201Response) => void;\n slots?: {\n dataGrid?: SxProps<Theme>;\n };\n // white list of columns to show\n include?: ColumnNames[];\n};\n\nexport default function UserList(props: Props) {\n const {\n data,\n allowCreation = true,\n buttonText = 'Add a user',\n onUserCreateSuccess,\n slots,\n include = ['email', 'preferedName'],\n } = props;\n\n const dataGridSx = {\n width: '100%',\n height: '100%',\n ...(slots?.dataGrid ?? {}),\n };\n\n const [columns, rows] = useDataParser(data, include);\n return (\n <Stack flex={1}>\n <CreateUser\n allowCreation={allowCreation}\n buttonText={buttonText}\n onUserCreateSuccess={onUserCreateSuccess}\n />\n <DataGrid\n sx={dataGridSx}\n rows={rows}\n columns={columns}\n hideFooter={true}\n />\n </Stack>\n );\n}\n"],"names":["palette","primary","solidColor","softColor","solidDisabledBg","solidDisabledColor","plainHoverBg","outlinedHoverBg","neutral","softBg","purple","blue","divider","text","tertiary","background","surface","body","default","tableCell","border","unstable_sxConfig","muiSxConfig","muiTheme","extendMuiTheme","cssVarPrefix","colorSchemes","dark","main","joySxConfig","joyTheme","extendJoyTheme","components","JoyInput","styleOverrides","input","color","opacity","light","mergedTheme","deepmerge","typography","Themer","theme","children","React","createElement","JoyCssVarsProvider","defaultTheme","defaultMode","CssBaseline","enableColorScheme","generateCssVars","colorScheme","css","vars","queryClient","QueryClient","defaultContext","api","BrowserApi","basePath","credentials","context","createContext","Provider","BaseQueryProvider","QueryClientProvider","client","useNileContext","useContext","useNileConfig","tenantId","useMemo","useApi","_g","_extends","Object","assign","bind","target","i","arguments","length","source","key","prototype","hasOwnProperty","call","apply","this","SvgGoogle","props","xmlns","width","height","fillRule","fill","d","CheckGroup","options","attribute","display","helperText","watch","control","useFormContext","currentVals","name","checkProps","Controller","rules","required","Boolean","render","field","Stack","FormLabel","htmlFor","label","Box","role","sx","borderRadius","p","List","orientation","wrap","map","item","id","String","value","ListItem","Checkbox","overlay","checked","includes","disableIcon","variant","onChange","event","allowMultiple","concat","remaining","filter","val","Typography","level","AttributeType","FormAttributeType","getAttributeDefault","Array","isArray","defaultValue","Labler","error","attr","Tooltip","title","cursor","Error","ml","fontSize","SimpleForm","mutation","buttonText","attributes","cancelButton","loading","successMessage","defaultValues","reduce","accum","methods","useForm","register","handleSubmit","formState","errors","onSubmit","useCallback","data","mutate","FormProvider","component","spacing","fieldConfig","placeholder","disabled","helpText","type","Switch","FormControl","alignItems","FormHelperText","endDecorator","Select","_","newValue","option","Option","Password","Input","Number","Text","direction","Button","gap","AddUser","open","setOpen","refetch","errorText","setErrorText","useState","email","useEffect","useMutation","users","createTenantUser","signUpRequest","onSuccess","onError","e","message","handleUpdate","async","Modal","ModalDialog","Fragment","fullWidth","size","autoComplete","pt","onClick","CreateUser","allowCreation","onUserCreateSuccess","UserModal","startDecorator","Add","makeRenderable","vals","keys","cleaned","Set","from","join","parseResults","ctx","include","rows","fields","existentCols","cols","col","column","canvasContext","columnHeaderLen","measureText","Math","ceil","longest","nextRow","isNull","isUndefined","toString","getColumnSize","slice","padEnd","headerName","useDataParser","setCtx","document","getContext","font","useTextSizer","BaseSSOForm","config","providerName","allowEdit","configurationGuide","setLoading","success","setSuccess","optimisticConfig","setConfig","timer","useRef","enabled","clientId","configUrl","emailDomains","splice","ssoRequest","payload","toLowerCase","updateProviderRequest","split","auth","updateProvider","createProvider","onSettled","current","clearTimeout","setTimeout","position","Alert","transition","CheckCircleOutlined","textAlign","ConfigGuide","callbackUrl","copied","setCopied","fontFamily","navigator","clipboard","writeText","span","readOnly","top","left","CopyAll","databaseId","newTenantName","contextHref","encodeURIComponent","query","href","flex","textDecoration","padding","textTransform","boxShadow","fontWeight","backgroundColor","GoogleLogo","QueryProvider","values","ThemeProvider","providers","find","provider","beforeMutate","nextButtonText","loginButtonText","disableSSO","setButtonText","_data","login","loginRequest","password","sso","token","redirectURI","window","location","completeAttributes","mainAttributes","push","setError","undefined","preferredName","newTenant","metadata","console","warn","signUp","UserForm","slots","dataGridSx","dataGrid","columns","DataGrid","hideFooter"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"react.cjs.development.js","sources":["../src/context/config.ts","../src/context/theme.tsx","../src/context/index.tsx","../src/GoogleLoginButton/google.svg","../src/lib/SimpleForm/CheckGroup/index.tsx","../src/lib/SimpleForm/types.ts","../src/lib/SimpleForm/index.tsx","../src/UserTenantList/UserModal.tsx","../src/UserTenantList/CreateUser.tsx","../src/UserTenantList/useDataParser.ts","../src/utils/getColumnSize.ts","../src/hooks/useTextSizer.ts","../src/SSO/BaseSSOForm.tsx","../src/SSO/Okta.tsx","../src/GoogleLoginButton/GoogleLoginButton.tsx","../src/LoginForm/SingleSignOn.tsx","../src/LoginForm/LoginForm.tsx","../src/SignUpForm/SignUpForm.tsx","../src/UserTenantList/UserList.tsx"],"sourcesContent":["/* eslint-disable @typescript-eslint/ban-ts-comment */\nimport deepmerge from '@mui/utils/deepmerge';\nimport { extendTheme as extendJoyTheme } from '@mui/joy/styles';\nimport { experimental_extendTheme as extendMuiTheme } from '@mui/material/styles';\n\nconst palette = {\n primary: {\n '50': '#fff7ed',\n '100': '#FFEAD2',\n '200': '#FFDCB5',\n '300': '#FFCE97', //primary\n '400': '#FFC480',\n '500': '#FDC067',\n '600': '#FFB262',\n '700': '#FFAA57',\n '800': '#FFA24D',\n '900': '#FF933C',\n solidColor: 'rgba(var(--nile-palette-primary-contrastTextChannel) / 1)',\n softColor: 'rgba(var(--nile-palette-primary-contrastTextChannel) / .5)',\n solidDisabledBg: 'var(--nile-palette-grey-600)',\n solidDisabledColor: 'var(--nile-palette-grey-700)',\n plainHoverBg:\n 'rgba(var(--nile-palette-primary-mainChannel) / var(--nile-palette-action-hoverOpacity))',\n outlinedHoverBg:\n 'rgba(var(--nile-palette-primary-mainChannel) / var(--nile-palette-action-selectedOpacity))',\n },\n neutral: {\n outlinedHoverBg:\n 'rgba(var(--nile-palette-neutral-mainChannel) / var(--nile-palette-action-selectedOpacity))',\n softBg: 'rgba(45, 45, 51)',\n },\n // @ts-ignore\n purple: {\n '50': '#f0edff',\n '100': '#d8d3ff', // primary\n '200': '#beb6fe',\n '300': '#a298fb',\n '400': '#8a7ff7',\n '500': '#7269f3',\n '600': '#6663eb',\n '700': '#565ae1',\n '800': '#4754d8',\n '900': '#2d47c9',\n },\n blue: {\n '50': '#dff8ff',\n '100': '#adedff',\n '200': '#6fe2ff', // primary\n '300': '#12d6fb',\n '400': '#00ccf6',\n '500': '#00c2f0',\n '600': '#00b2dc',\n '700': '#009dc0',\n '800': '#008aa6',\n '900': '#006778',\n },\n divider: '#181818',\n text: {\n primary: '#fff7ed',\n tertiary: 'rgba(255 255 255 / 0.5)',\n },\n background: {\n surface: '#000',\n body: '#000',\n default: '#000',\n },\n tableCell: {\n border: 'none',\n },\n};\n\nconst { unstable_sxConfig: muiSxConfig, ...muiTheme } = extendMuiTheme({\n cssVarPrefix: 'nile',\n colorSchemes: {\n dark: {\n palette: {\n primary: {\n main: '#FFCE97',\n },\n },\n },\n },\n});\n\nconst { unstable_sxConfig: joySxConfig, ...joyTheme } = extendJoyTheme({\n cssVarPrefix: 'nile',\n components: {\n JoyInput: {\n styleOverrides: {\n input: {\n ':disabled': { color: 'var(--nile-palette-neutral-500)' },\n '::placeholder': {\n opacity: 0.6,\n },\n color: 'white',\n },\n },\n },\n },\n colorSchemes: {\n dark: { palette },\n light: { palette },\n },\n});\nconst mergedTheme = {\n ...muiTheme,\n ...joyTheme,\n colorSchemes: deepmerge(muiTheme.colorSchemes, joyTheme.colorSchemes),\n typography: {\n ...muiTheme.typography,\n ...joyTheme.typography,\n },\n} as unknown as ReturnType<typeof extendJoyTheme>;\n\nmergedTheme.generateCssVars = (colorScheme) => ({\n css: {\n ...muiTheme.generateCssVars(colorScheme).css,\n ...joyTheme.generateCssVars(colorScheme).css,\n },\n //@ts-expect-error - new dev\n vars: deepmerge(\n muiTheme.generateCssVars(colorScheme).vars,\n joyTheme.generateCssVars(colorScheme).vars\n ),\n});\n\nmergedTheme.unstable_sxConfig = {\n ...muiSxConfig,\n ...joySxConfig,\n};\nexport default mergedTheme;\n","// eslint-disable-next-line @typescript-eslint/ban-ts-comment\nimport React from 'react';\nimport CssBaseline from '@mui/material/CssBaseline';\nimport { Theme } from '@mui/joy/styles';\nimport { CssVarsProvider as JoyCssVarsProvider } from '@mui/joy/styles';\n\nimport defaultTheme from './config';\n\nexport default function Themer({\n theme,\n children,\n}: {\n theme?: Theme;\n children: JSX.Element;\n}) {\n return (\n <JoyCssVarsProvider theme={theme ?? defaultTheme} defaultMode=\"dark\">\n <CssBaseline enableColorScheme />\n {children}\n </JoyCssVarsProvider>\n );\n}\n","// eslint-disable-next-line @typescript-eslint/ban-ts-comment\nimport React, { useMemo, createContext, useContext } from 'react';\nimport Browser from '@niledatabase/browser';\nimport { QueryClientProvider, QueryClient } from '@tanstack/react-query';\n\nimport ThemeProvider from './theme';\nimport { NileContext, NileProviderProps, NileReactConfig } from './types';\n\nconst queryClient = new QueryClient();\n\nconst defaultContext: NileContext = {\n api: new Browser({\n basePath: 'https://api.thenile.dev',\n credentials: 'include',\n }),\n basePath: '',\n};\n\nconst context = createContext<NileContext>(defaultContext);\n\nconst { Provider } = context;\n\nexport const BaseQueryProvider = ({\n children,\n}: {\n children: JSX.Element;\n}): JSX.Element => {\n return (\n <QueryClientProvider client={queryClient}>{children}</QueryClientProvider>\n );\n};\n\nexport const NileProvider = (props: NileProviderProps) => {\n const {\n children,\n theme,\n tenantId,\n QueryProvider = BaseQueryProvider,\n basePath = 'https://api.thenile.dev',\n api,\n } = props;\n\n const values = useMemo<NileContext>((): NileContext => {\n return {\n api:\n api ??\n new Browser({\n basePath,\n credentials: 'include',\n }),\n tenantId: String(tenantId),\n basePath,\n };\n }, [api, basePath, tenantId]);\n\n return (\n <QueryProvider>\n <ThemeProvider theme={theme}>\n <Provider value={values}>{children}</Provider>\n </ThemeProvider>\n </QueryProvider>\n );\n};\n\nconst useNileContext = (): NileContext => {\n return useContext(context);\n};\n\nexport const useNileConfig = (): NileReactConfig => {\n const { basePath, tenantId } = useNileContext();\n return useMemo(\n () => ({\n tenantId,\n basePath,\n }),\n [basePath, tenantId]\n );\n};\n\nexport const useApi = (): Browser => {\n return useNileContext().api;\n};\n","<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"18\" height=\"18\">\n <g fill=\"#000\" fill-rule=\"evenodd\">\n <path d=\"M9 3.48c1.69 0 2.83.73 3.48 1.34l2.54-2.48C13.46.89 11.43 0 9 0 5.48 0 2.44 2.02.96 4.96l2.91 2.26C4.6 5.05 6.62 3.48 9 3.48z\" fill=\"#EA4335\" />\n <path d=\"M17.64 9.2c0-.74-.06-1.28-.19-1.84H9v3.34h4.96c-.1.83-.64 2.08-1.84 2.92l2.84 2.2c1.7-1.57 2.68-3.88 2.68-6.62z\" fill=\"#4285F4\" />\n <path d=\"M3.88 10.78A5.54 5.54 0 0 1 3.58 9c0-.62.11-1.22.29-1.78L.96 4.96A9.008 9.008 0 0 0 0 9c0 1.45.35 2.82.96 4.04l2.92-2.26z\" fill=\"#FBBC05\" />\n <path d=\"M9 18c2.43 0 4.47-.8 5.96-2.18l-2.84-2.2c-.76.53-1.78.9-3.12.9-2.38 0-4.4-1.57-5.12-3.74L.97 13.04C2.45 15.98 5.48 18 9 18z\" fill=\"#34A853\" />\n <path fill=\"none\" d=\"M0 0h18v18H0z\" />\n </g>\n</svg>","import * as React from 'react';\nimport Box from '@mui/joy/Box';\nimport Checkbox from '@mui/joy/Checkbox';\nimport List from '@mui/joy/List';\nimport { Controller, useFormContext } from 'react-hook-form';\nimport Stack from '@mui/joy/Stack';\nimport FormLabel from '@mui/joy/FormLabel';\nimport ListItem from '@mui/joy/ListItem';\nimport Typography from '@mui/joy/Typography';\n\nimport { Attribute, DisplayProps, Options } from '../types';\n\ntype Props = {\n attribute: Attribute;\n display: DisplayProps;\n options: Options;\n helperText: string;\n};\nexport default function CheckGroup(props: Props) {\n const { options, attribute, display, helperText } = props;\n const { watch, control } = useFormContext();\n const currentVals = watch(attribute.name);\n const checkProps: { color?: 'danger'; id?: string } = {};\n if (helperText) {\n checkProps.color = 'danger';\n }\n return (\n <Controller\n name={attribute.name}\n rules={{ required: Boolean(attribute.required) }}\n control={control}\n render={({ field }) => {\n return (\n <Stack>\n <FormLabel htmlFor={`${field.name}`}>{display.label}</FormLabel>\n <Box\n role=\"group\"\n aria-labelledby={attribute.name}\n sx={{\n borderRadius: 'var(--joy-radius-sm)',\n p: 0.5,\n border: helperText\n ? '1px solid var(--joy-palette-danger-outlinedBorder)'\n : 'none',\n }}\n >\n <List\n orientation=\"horizontal\"\n wrap\n sx={{\n '--List-gap': '8px',\n }}\n >\n {options.map((item) => {\n checkProps.id = String(item.value);\n return (\n <ListItem key={`${item.value}-${item.label}`}>\n <Checkbox\n overlay={options.length > 1}\n {...checkProps}\n checked={currentVals.includes(item.value)}\n disableIcon={options.length > 1}\n variant=\"soft\"\n label={item.label}\n onChange={(event) => {\n if (attribute.allowMultiple) {\n if (event.target.checked) {\n if (!currentVals) {\n field.onChange([item.value]);\n } else {\n field.onChange(currentVals.concat(item.value));\n }\n } else {\n const remaining = currentVals.filter(\n (val: string | number) => val !== item.value\n );\n if (remaining.length > 0) {\n field.onChange(remaining);\n } else {\n field.onChange('');\n }\n }\n } else {\n if (event.target.checked) {\n field.onChange(item.value);\n } else {\n field.onChange('');\n }\n }\n }}\n />\n </ListItem>\n );\n })}\n </List>\n </Box>\n <Typography\n sx={{ color: 'var(--joy-palette-danger-500)' }}\n level=\"body-sm\"\n >\n {helperText}\n </Typography>\n </Stack>\n );\n }}\n />\n );\n}\n","export enum AttributeType {\n Text = 'text',\n Password = 'password',\n Select = 'select',\n Number = 'number',\n Float = 'float',\n Checkbox = 'checkbox',\n Switch = 'switch',\n}\ntype SimplePrimitive = number | string | boolean;\n\n// possibly no value for `<Switch/>`\nexport type Options = { label: string; value?: SimplePrimitive }[];\nexport type Attribute = {\n name: string;\n type?: AttributeType;\n defaultValue?: SimplePrimitive;\n options?: Options;\n allowMultiple?: boolean;\n label?: string;\n required?: boolean;\n placeholder?: string;\n helpText?: string;\n disabled?: boolean;\n};\n\nexport type DisplayProps = {\n key: string;\n id: string;\n label: string;\n placeholder: string;\n error?: boolean;\n color?: 'danger';\n disabled?: boolean;\n};\n","import React from 'react';\nimport Button from '@mui/joy/Button';\nimport { Controller, FormProvider, useForm } from 'react-hook-form';\nimport Stack from '@mui/joy/Stack';\nimport Input from '@mui/joy/Input';\nimport FormControl from '@mui/joy/FormControl';\nimport FormHelperText from '@mui/joy/FormHelperText';\nimport Error from '@mui/icons-material/Error';\nimport FormLabel from '@mui/joy/FormLabel';\nimport Select from '@mui/joy/Select';\nimport Option from '@mui/joy/Option';\nimport Box from '@mui/joy/Box';\nimport Tooltip from '@mui/joy/Tooltip';\nimport { Switch } from '@mui/joy';\n\nimport CheckGroup from './CheckGroup';\nimport { Attribute, AttributeType, DisplayProps } from './types';\n\ntype AttrMap = {\n [key: string]: string | number | boolean | string[] | number[];\n};\n\ntype FieldConfig = {\n required?: boolean;\n};\n\nexport const getAttributeDefault = (\n attribute: Attribute\n): string | number | boolean | string[] | number[] => {\n // have to look to see if it is an enum\n if (attribute.allowMultiple === true) {\n if (!Array.isArray(attribute.defaultValue) && attribute.defaultValue) {\n if (typeof attribute.defaultValue === 'number') {\n return [attribute.defaultValue];\n }\n return [String(attribute.defaultValue)];\n }\n }\n return attribute.defaultValue ?? '';\n};\n\nfunction Labler(props: { error?: string; attr: Attribute }) {\n const { error, attr } = props;\n if (error) {\n return (\n <Tooltip title={error} color=\"danger\" sx={{ cursor: 'pointer' }}>\n <FormLabel>\n {attr.label ?? attr.name}\n <Error sx={{ ml: 0.5, '--Icon-color': '#c41c1c' }} fontSize=\"small\" />\n </FormLabel>\n </Tooltip>\n );\n }\n return <FormLabel>{attr.label ?? attr.name}</FormLabel>;\n}\nexport default function SimpleForm(props: {\n buttonText: string;\n cancelButton?: React.ReactNode;\n attributes: Attribute[];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n mutation: any;\n loading?: boolean;\n successMessage?: JSX.Element;\n}) {\n const {\n mutation,\n buttonText,\n attributes,\n cancelButton,\n loading,\n successMessage,\n } = props;\n\n const defaultValues = React.useMemo(\n () =>\n attributes.reduce((accum: AttrMap, attr: Attribute) => {\n accum[attr.name] = getAttributeDefault(attr);\n return accum;\n }, {}),\n [attributes]\n );\n\n const methods = useForm({\n defaultValues,\n });\n\n const {\n register,\n control,\n handleSubmit,\n formState: { errors },\n } = methods;\n const onSubmit = React.useCallback(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (data: any) => {\n mutation.mutate(data);\n },\n [mutation]\n );\n\n return (\n <FormProvider {...methods}>\n <Stack\n component=\"form\"\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n onSubmit={handleSubmit((data) => onSubmit(data as any))}\n spacing={2}\n >\n {attributes.map((attr: Attribute): React.ReactNode => {\n const fieldConfig: FieldConfig = {};\n const display: DisplayProps = {\n key: attr.name,\n label: attr.label ?? attr.name,\n id: attr.label ?? attr.name,\n placeholder: attr.placeholder ?? attr.label ?? attr.name,\n error: Boolean(errors[attr.name]),\n disabled: Boolean(attr.disabled),\n };\n const options = attr.options ?? [];\n const helperText = attr.helpText ?? '';\n let error = '';\n\n if (attr.required) {\n error = errors[attr.name]\n ? `${attr.label ?? attr.name} is required`\n : '';\n fieldConfig.required = true;\n }\n\n switch (attr.type) {\n case AttributeType.Switch:\n return (\n <FormControl\n key={display.key}\n id={display.id}\n orientation=\"horizontal\"\n sx={{ alignItems: 'center' }}\n >\n <Box>\n <Labler error={error} attr={attr} />\n <FormHelperText id={`${attr.name}-helper-text`}>\n {helperText}\n </FormHelperText>\n </Box>\n <Controller\n control={control}\n rules={{ required: Boolean(attr.required) }}\n name={attr.name}\n render={({ field }) => {\n const color: { color?: 'danger' } = {};\n if (errors[attr.name]) {\n color.color = 'danger';\n }\n return (\n <Switch\n id={`switch-field-${attr.name}`}\n {...color}\n {...field}\n checked={Boolean(field.value)}\n onChange={(event) => {\n field.onChange(event.target.checked);\n }}\n color={field.value ? 'success' : 'neutral'}\n endDecorator={\n field.value ? options[0].label : options[1].label\n }\n sx={{\n '--Switch-thumbSize': '28px',\n }}\n />\n );\n }}\n />\n </FormControl>\n );\n case AttributeType.Checkbox:\n return (\n <CheckGroup\n key={display.key}\n attribute={attr}\n display={display}\n options={options}\n helperText={helperText}\n />\n );\n case AttributeType.Select:\n return (\n <FormControl key={display.key} id={display.id}>\n <Labler error={error} attr={attr} />\n <Controller\n control={control}\n rules={{ required: Boolean(attr.required) }}\n name={attr.name}\n render={({ field }) => {\n const color: { color?: 'danger' } = {};\n if (errors[attr.name]) {\n color.color = 'danger';\n }\n const value = String(field.value);\n return (\n <Stack>\n <Select\n id={`select-field-${attr.name}`}\n placeholder={`${display.placeholder}...`}\n {...color}\n {...field}\n value={value}\n onChange={(_, newValue) => {\n field.onChange(newValue);\n }}\n >\n {options.map((option) => {\n return (\n <Option\n key={String(option.value ?? '')}\n value={option.value}\n >\n {option.label}\n </Option>\n );\n })}\n </Select>\n <FormHelperText id={`${attr.name}-helper-text`}>\n {helperText}\n </FormHelperText>\n </Stack>\n );\n }}\n />\n </FormControl>\n );\n case AttributeType.Password:\n return (\n <FormControl key={display.key} id={display.id}>\n <Labler error={error} attr={attr} />\n <Input\n {...display}\n {...register(attr.name, fieldConfig)}\n type={AttributeType.Password}\n />\n <FormHelperText id={`${attr.name}-helper-text`}>\n {helperText}\n </FormHelperText>\n </FormControl>\n );\n case AttributeType.Number:\n return (\n <FormControl key={display.key} id={display.id}>\n <Labler error={error} attr={attr} />\n <Input\n {...display}\n {...register(attr.name, fieldConfig)}\n type={AttributeType.Number}\n />\n <FormHelperText id={`${attr.name}-helper-text`}>\n {helperText}\n </FormHelperText>\n </FormControl>\n );\n\n case AttributeType.Text:\n default:\n return (\n <FormControl key={display.key} id={display.id}>\n <Labler error={error} attr={attr} />\n <Input {...display} {...register(attr.name, fieldConfig)} />\n <FormHelperText id={`${attr.name}-helper-text`}>\n {helperText}\n </FormHelperText>\n </FormControl>\n );\n }\n })}\n {cancelButton ? (\n <Stack spacing={2} direction=\"row\">\n {cancelButton}\n <Box>\n <Button type=\"submit\">{buttonText}</Button>\n </Box>\n </Stack>\n ) : (\n <Box>\n <Stack direction=\"row\" gap={2}>\n <Button type=\"submit\" loading={loading}>\n {buttonText}\n </Button>\n {successMessage}\n </Stack>\n </Box>\n )}\n </Stack>\n </FormProvider>\n );\n}\n","import React from 'react';\nimport {\n Button,\n Stack,\n Typography,\n FormControl,\n FormLabel,\n Input,\n Modal,\n ModalDialog,\n} from '@mui/joy';\nimport { useForm } from 'react-hook-form';\nimport { useMutation } from '@tanstack/react-query';\nimport { SignUp201Response, SignUpRequest } from '@niledatabase/browser';\n\nimport { useApi, useNileConfig } from '../context';\n\nexport type UserFormProps = {\n open: boolean;\n setOpen: (open: boolean) => void;\n refetch?: (user: SignUp201Response) => void;\n};\n\nexport default function AddUser(props: UserFormProps) {\n const { open, setOpen, refetch } = props;\n const { tenantId } = useNileConfig();\n const api = useApi();\n const [errorText, setErrorText] = React.useState<void | string>();\n const { watch, register, handleSubmit } = useForm<SignUpRequest>();\n const email = watch('email');\n\n React.useEffect(() => {\n if (errorText != null) {\n setErrorText();\n }\n // if email changes, no more error\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [email]);\n\n const mutation = useMutation(\n (data: SignUpRequest) =>\n api.users.createTenantUser({\n signUpRequest: data,\n tenantId: String(tenantId),\n }),\n {\n onSuccess(data) {\n refetch && refetch(data);\n setOpen(false);\n },\n onError(e) {\n if (e instanceof Error) {\n setErrorText(e.message);\n }\n },\n }\n );\n\n const handleUpdate = React.useCallback(\n async (data: SignUpRequest) => {\n setErrorText('');\n mutation.mutate(data);\n },\n [mutation]\n );\n\n return (\n <Modal open={open}>\n <ModalDialog>\n <Stack spacing={2}>\n <Typography level=\"h4\">Create user</Typography>\n <>\n {errorText && <Typography color=\"danger\">{errorText}</Typography>}\n </>\n <Stack\n component=\"form\"\n sx={{\n width: '40ch',\n }}\n spacing={1}\n onSubmit={handleSubmit((data) =>\n handleUpdate(data as SignUpRequest)\n )}\n >\n <FormControl\n sx={{\n '--FormHelperText-color': 'var(--joy-palette-danger-500)',\n }}\n >\n <FormLabel htmlFor=\"email\">Email</FormLabel>\n <Input\n {...register('email')}\n fullWidth\n size=\"lg\"\n id=\"email\"\n name=\"email\"\n autoComplete=\"current-email\"\n required\n error={Boolean(errorText)}\n />\n </FormControl>\n <FormControl\n sx={{\n '--FormHelperText-color': 'var(--joy-palette-danger-500)',\n }}\n >\n <FormLabel htmlFor=\"password\">Password</FormLabel>\n <Input\n {...register('password')}\n fullWidth\n size=\"lg\"\n id=\"password\"\n autoComplete=\"current-password\"\n type=\"password\"\n required\n />\n </FormControl>\n <Stack direction=\"row\" sx={{ pt: 2 }} spacing={2}>\n <Button onClick={() => setOpen(false)} variant=\"plain\">\n Cancel\n </Button>\n <Button type=\"submit\">Create</Button>\n </Stack>\n </Stack>\n </Stack>\n </ModalDialog>\n </Modal>\n );\n}\n","import React from 'react';\nimport Button from '@mui/joy/Button';\nimport Stack from '@mui/joy/Stack';\nimport { useState } from 'react';\nimport Add from '@mui/icons-material/Add';\nimport { SignUp201Response } from '@niledatabase/browser';\n\nimport UserModal from './UserModal';\n\ntype Props = {\n allowCreation: boolean;\n buttonText: string;\n onUserCreateSuccess?: (user: SignUp201Response) => void;\n};\nexport default function CreateUser(props: Props) {\n const { allowCreation, buttonText, onUserCreateSuccess } = props;\n const [open, setOpen] = useState(false);\n if (!allowCreation) {\n return null;\n }\n\n return (\n <Stack alignItems=\"flex-end\" gap={1}>\n <UserModal open={open} setOpen={setOpen} refetch={onUserCreateSuccess} />\n <Button startDecorator={<Add />} size=\"sm\" onClick={() => setOpen(true)}>\n {buttonText}\n </Button>\n </Stack>\n );\n}\n","import { useMemo } from 'react';\nimport { GridColDef, GridRowsProp } from '@mui/x-data-grid';\nimport { User } from '@niledatabase/browser';\n\nimport getColumnSize from '../utils/getColumnSize';\nimport useTextSizer from '../hooks/useTextSizer';\n\nexport const internalRowId = '_nile_data_grid_identifier';\n\ntype Cleaned = { [key: string]: string | Set<string> };\n\nconst makeRenderable = (vals: User) => {\n return Object.keys(vals).reduce((cleaned: Cleaned, key) => {\n const val = (vals as Cleaned)[key];\n if (val instanceof Set) {\n cleaned[key] = Array.from(val).join(', ');\n } else if (Array.isArray(val)) {\n cleaned[key] = val.join(', ');\n } else {\n cleaned[key] = val;\n }\n return cleaned;\n }, {});\n};\n\nconst parseResults = (\n data: void | User[],\n ctx: CanvasRenderingContext2D | void,\n include: string[]\n): [GridColDef[], GridRowsProp] => {\n if (!data) {\n return [[], []];\n }\n const rows = data.map(makeRenderable);\n const fields = Object.keys(rows[0]);\n\n const existentCols: { [key: string]: number } = {};\n\n const mapCols = (col: string): GridColDef | void => {\n const width = getColumnSize(col, rows, ctx);\n const name = col.slice();\n if (include.includes(name)) {\n // add spaces to the end of column names so they are not duplicated in the UI\n if (existentCols[name] == null) {\n existentCols[name] = name.length;\n } else {\n existentCols[name] += 1;\n }\n return {\n field: name.padEnd(existentCols[name]),\n headerName: name.padEnd(existentCols[name]),\n width,\n };\n }\n };\n const cols = fields?.map(mapCols).filter(Boolean) ?? [];\n\n return [cols as GridColDef[], rows];\n};\n\nexport default function useDataParser(\n data: void | User[],\n include: string[]\n): [GridColDef[], GridRowsProp] {\n const ctx = useTextSizer();\n const [cols, rows] = useMemo(\n () => parseResults(data, ctx, include),\n [data, ctx, include]\n );\n return [cols, rows];\n}\n","import { GridRowsProp } from '@mui/x-data-grid';\nimport isNull from 'lodash/isNull';\nimport isUndefined from 'lodash/isUndefined';\n\nexport default function getColumnSize(\n column: unknown,\n rows: GridRowsProp,\n canvasContext: void | CanvasRenderingContext2D\n) {\n const dataWidthReducer = (\n longest: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n nextRow: { [key: string]: any }\n ) => {\n let value = nextRow[String(column)];\n if (isNull(value) || isUndefined(value)) {\n value = '';\n }\n value = value?.toString();\n return longest.length > value.length ? longest : value;\n };\n\n let columnHeaderLen =\n canvasContext && column\n ? canvasContext.measureText(String(column)).width\n : 50;\n /* padding 12, icon-width 15 */\n columnHeaderLen += 15 + 12;\n\n let width = columnHeaderLen;\n width =\n 16 +\n Math.ceil(\n canvasContext\n ? canvasContext.measureText(rows.reduce(dataWidthReducer, '')).width\n : 50\n );\n if (width < columnHeaderLen) {\n width = columnHeaderLen;\n }\n /* Gracefull */\n width += 8;\n return width;\n}\n","import { useEffect, useState } from 'react';\n\nexport default function useTextSizer() {\n const [ctx, setCtx] = useState<CanvasRenderingContext2D>();\n useEffect(() => {\n const canvas = document.createElement('canvas');\n const canvasContext = canvas.getContext('2d');\n if (canvasContext) {\n canvasContext.font = '18px Roboto';\n setCtx(canvasContext);\n }\n }, []);\n return ctx;\n}\n","import React from 'react';\nimport { useMutation } from '@tanstack/react-query';\nimport { UpdateProviderRequest, SSOProvider } from '@niledatabase/browser';\nimport Stack from '@mui/joy/Stack';\nimport Typography from '@mui/joy/Typography';\nimport Alert from '@mui/joy/Alert';\nimport CheckCircleOutlined from '@mui/icons-material/CheckCircleOutlined';\n\nimport SimpleForm from '../lib/SimpleForm';\nimport { useApi } from '../context';\nimport { Attribute, AttributeType } from '../lib/SimpleForm/types';\n\nimport { OktaProps } from './types';\n\ntype SSOFormRequest = Omit<UpdateProviderRequest, 'emailDomains'> & {\n emailDomains: string;\n};\nexport default function BaseSSOForm(\n props: Omit<OktaProps, 'callbackUrl' | 'providers'> & {\n providerName: string;\n configurationGuide?: JSX.Element;\n config?: SSOProvider;\n }\n) {\n const {\n config,\n providerName,\n onSuccess,\n onError,\n allowEdit = true,\n configurationGuide,\n } = props;\n\n const api = useApi();\n const [loading, setLoading] = React.useState(false);\n const [success, setSuccess] = React.useState(false);\n const [optimisticConfig, setConfig] = React.useState<SSOProvider | void>(\n config\n );\n const timer = React.useRef<NodeJS.Timeout>();\n const attributes = React.useMemo(() => {\n const attributes: Attribute[] = [\n {\n name: 'enabled',\n label: 'Allow Okta logins',\n type: AttributeType.Switch,\n defaultValue: optimisticConfig?.enabled === true,\n options: [\n {\n label: 'Enabled',\n },\n {\n label: 'Disabled',\n },\n ],\n disabled: !allowEdit,\n },\n {\n name: 'clientId',\n label: 'Client id',\n type: AttributeType.Text,\n defaultValue: optimisticConfig?.clientId ?? '',\n required: true,\n disabled: !allowEdit,\n },\n {\n name: 'configUrl',\n label: 'Config url',\n type: AttributeType.Text,\n defaultValue: optimisticConfig?.configUrl ?? '',\n helpText:\n 'The URL of the .well-known/openid-configuration for the identity provider',\n required: true,\n disabled: !allowEdit,\n },\n {\n name: 'emailDomains',\n label: 'Email domains',\n type: AttributeType.Text,\n defaultValue: optimisticConfig?.emailDomains?.join(', ') ?? '',\n required: true,\n helpText:\n 'A comma seperated list of email domains (yourDomain.com) to be used',\n disabled: !allowEdit,\n },\n ];\n if (!optimisticConfig?.clientId) {\n attributes.splice(2, 0, {\n name: 'clientSecret',\n label: 'Client secret',\n type: AttributeType.Password,\n defaultValue: '',\n required: true,\n disabled: !allowEdit,\n });\n }\n return attributes;\n }, [\n allowEdit,\n optimisticConfig?.clientId,\n optimisticConfig?.configUrl,\n optimisticConfig?.emailDomains,\n optimisticConfig?.enabled,\n ]);\n\n const handleTimer = () => {\n if (timer.current) {\n clearTimeout(timer.current);\n }\n\n timer.current = setTimeout(() => {\n setSuccess(false);\n }, 3000);\n };\n\n const mutation = useMutation(\n (ssoRequest: SSOFormRequest) => {\n setLoading(true);\n const payload = {\n providerName: providerName.toLowerCase(),\n updateProviderRequest: {\n ...ssoRequest,\n emailDomains: ssoRequest.emailDomains.split(','),\n },\n };\n if (optimisticConfig != null) {\n return api.auth.updateProvider(payload);\n } else {\n return api.auth.createProvider(payload);\n }\n },\n {\n onSuccess: (data, vars) => {\n setConfig(data);\n setSuccess(true);\n onSuccess && onSuccess(data, vars);\n },\n onError,\n onSettled: (data, error, vars) => {\n setLoading(false);\n handleTimer();\n if (!data) {\n if (!error || error?.message.includes('Unterminated string')) {\n // something unexpected happened on the BE, but it's non-fatal\n setConfig({\n enabled: vars.enabled,\n clientId: vars.clientId,\n configUrl: vars.configUrl,\n emailDomains: vars.emailDomains.split(', '),\n } as SSOProvider);\n }\n setSuccess(true);\n onSuccess && onSuccess(data, vars);\n }\n },\n }\n );\n\n React.useEffect(() => {\n () => {\n clearTimeout(timer.current);\n };\n });\n\n return (\n <Stack gap={2} position=\"relative\">\n <Typography level=\"h4\">Step 1</Typography>\n {configurationGuide}\n <Typography level=\"h4\">Step 2</Typography>\n <SimpleForm\n mutation={mutation}\n buttonText=\"Update\"\n attributes={attributes}\n loading={loading}\n successMessage={\n <Alert\n color=\"success\"\n sx={{\n opacity: success ? 1 : 0,\n transition: 'opacity 200ms',\n height: '0.9rem',\n }}\n startDecorator={<CheckCircleOutlined />}\n >\n <Typography textAlign=\"center\" fontSize=\"sm\">\n Provider updated\n </Typography>\n </Alert>\n }\n />\n </Stack>\n );\n}\n","import React from 'react';\nimport Stack from '@mui/joy/Stack';\nimport Typography from '@mui/joy/Typography';\nimport Box from '@mui/joy/Box';\nimport Input from '@mui/joy/Input';\nimport CopyAll from '@mui/icons-material/CopyAll';\nimport { Theme } from '@mui/joy/styles';\nimport Tooltip from '@mui/joy/Tooltip';\nimport CheckCircleOutlined from '@mui/icons-material/CheckCircleOutlined';\nimport { SSOProvider } from '@niledatabase/browser';\n\nimport BaseSSOForm from './BaseSSOForm';\nimport { OktaProps } from './types';\n\nfunction ConfigGuide({ callbackUrl }: { callbackUrl?: string }) {\n const [copied, setCopied] = React.useState(false);\n\n const timer = React.useRef<NodeJS.Timeout>();\n React.useEffect(() => {\n if (timer.current) {\n clearTimeout(timer.current);\n }\n timer.current = setTimeout(() => {\n setCopied(false);\n }, 3250);\n () => {\n clearTimeout(timer.current);\n };\n }, [copied]);\n return (\n <Stack gap={2}>\n <Typography>\n In order for Okta to redirect properly, provide the following URL as the{' '}\n <Box component=\"span\" sx={{ fontFamily: 'monospace' }}>\n Sign-in redirect URIs\n </Box>{' '}\n in the admin configuration of your application.\n </Typography>\n <Input\n onClick={async () => {\n if (callbackUrl) {\n await navigator.clipboard.writeText(callbackUrl);\n setCopied(true);\n }\n }}\n sx={(theme: Theme) => ({\n input: {\n cursor: 'pointer',\n },\n span: {\n cursor: 'pointer',\n },\n '&:hover svg': {\n '--Icon-color': theme.palette.primary[500],\n },\n })}\n value={callbackUrl}\n readOnly={true}\n endDecorator={\n <Tooltip title=\"Copy Okta redirect URL\">\n <Box\n position=\"relative\"\n width={copied ? '82px' : '24px'}\n height=\"24px\"\n >\n <Box\n position=\"absolute\"\n top=\"0\"\n left=\"0\"\n sx={{\n opacity: copied ? 0 : 1,\n transition: 'opacity 300ms',\n }}\n >\n <CopyAll />\n </Box>\n <Box\n position=\"absolute\"\n top=\"0\"\n left=\"0\"\n sx={{ opacity: !copied ? 0 : 1, transition: 'opacity 300ms' }}\n >\n <Stack direction=\"row\" gap={1}>\n <CheckCircleOutlined />\n <Typography color=\"primary\">Copied!</Typography>\n </Stack>\n </Box>\n </Box>\n </Tooltip>\n }\n />\n </Stack>\n );\n}\n\nexport default function Okta(props: OktaProps) {\n const { callbackUrl, providers, ...remaining } = props;\n if (!providers) {\n return null;\n }\n const config = providers?.find((provider) => provider.provider === 'okta');\n return (\n <BaseSSOForm\n {...remaining}\n config={config as SSOProvider}\n providerName=\"Okta\"\n configurationGuide={<ConfigGuide callbackUrl={callbackUrl} />}\n />\n );\n}\n","import React from 'react';\nimport Box from '@mui/joy/Box';\nimport Button from '@mui/joy/Button';\nimport Stack from '@mui/joy/Stack';\nimport Typography from '@mui/joy/Typography';\n\nimport { useNileConfig } from '../context';\n\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nimport GoogleLogo from './google.svg';\n\nconst LOGIN_PATH = 'users/oidc/google/login';\n\n/**\n * A component for a Google login button, according to their design language.\n * This works when an identity provider is configured in the admin dashboard.\n * @param props href: a string to override the URL provided by the context\n * @returns a JSX.Element to render\n */\nexport default function GoogleSSOButton(props: {\n href?: string;\n databaseId?: string;\n newTenantName?: string;\n}) {\n const { databaseId, newTenantName } = props;\n const { basePath } = useNileConfig();\n const encodedDatabase = encodeURIComponent(databaseId ?? '');\n const contextHref = `${basePath}/databases/${encodedDatabase}/${LOGIN_PATH}`;\n const query = newTenantName\n ? '?newTenant=' + encodeURIComponent(newTenantName)\n : '';\n const href = (props?.href ?? contextHref) + query;\n return (\n <Box\n component=\"a\"\n href={href}\n display=\"flex\"\n flex={1}\n sx={{ textDecoration: 'none' }}\n >\n <Box>\n <Button\n sx={{ padding: 0, textTransform: 'initial', flex: 1 }}\n aria-label=\"log in with google\"\n >\n <Stack\n direction=\"row\"\n alignItems=\"center\"\n p={0}\n flex={1}\n fontFamily=\"Roboto, sans-serif\"\n fontSize=\"14px\"\n display=\"inline-flex\"\n color=\"rgb(255 255, 255)\"\n boxShadow=\"rgb(0 0 0 / 24%) 0px 2px 2px 0px rgb(0 0 0 / 24%) 0px 0px 1px 0px\"\n borderRadius=\"4px\"\n border=\"1px solid transparent\"\n fontWeight=\"500\"\n sx={{\n backgroundColor: 'rgb(66 133, 244)',\n }}\n >\n <Box\n padding=\"11px\"\n display=\"flex\"\n border=\"1px solid rgb(66, 133, 244)\"\n borderRadius=\"4px\"\n sx={{\n background: 'rgb(255, 255, 255)',\n }}\n >\n <GoogleLogo aria-hidden=\"true\" />\n </Box>\n <Box padding=\"10px\" flex={1}>\n <Typography\n sx={{ color: 'white' }}\n fontWeight={700}\n fontFamily=\"Roboto, sans-serif\"\n fontSize=\"14px\"\n height=\"20px\"\n >\n Continue with Google\n </Typography>\n </Box>\n </Stack>\n </Button>\n </Box>\n </Box>\n );\n}\n","import React from 'react';\nimport { useMutation } from '@tanstack/react-query';\n\nimport { Attribute } from '../lib/SimpleForm/types';\nimport { useApi } from '../context';\nimport SimpleForm from '../lib/SimpleForm';\nimport { AttributeType } from '../lib/SimpleForm/types';\n\nimport { Props, LoginInfo } from './types';\n\nexport default function SingleSignOnForm(\n props: Props & {\n nextButtonText?: string;\n loginButtonText?: string;\n onSuccess: () => void;\n }\n) {\n const {\n attributes,\n onSuccess,\n onError,\n beforeMutate,\n nextButtonText = 'Next',\n loginButtonText = 'Log in',\n disableSSO = false,\n } = props;\n const api = useApi();\n const [buttonText, setButtonText] = React.useState(\n disableSSO ? loginButtonText : nextButtonText\n );\n\n const mutation = useMutation(\n async (_data: LoginInfo) => {\n const possibleData = beforeMutate && beforeMutate(_data);\n const data = possibleData ?? _data;\n return await api.auth.login({\n loginRequest: { email: data.email, password: data.password },\n sso: !disableSSO,\n });\n },\n {\n onSuccess: (token, data) => {\n if (token) {\n if (token?.redirectURI) {\n window.location.href = token.redirectURI;\n } else if (buttonText !== loginButtonText) {\n setButtonText(loginButtonText);\n } else {\n onSuccess && onSuccess(token, data);\n }\n }\n },\n onError: (error, data) => {\n // it is possible SSO failed, so only show errors on if the password is available\n if (buttonText === loginButtonText) {\n onError && onError(error as Error, data);\n } else {\n setButtonText(loginButtonText);\n }\n },\n }\n );\n\n const completeAttributes = React.useMemo(() => {\n const mainAttributes: Attribute[] = [\n {\n name: 'email',\n label: 'Email',\n type: AttributeType.Text,\n defaultValue: '',\n required: true,\n },\n ];\n if (buttonText === loginButtonText) {\n mainAttributes.push({\n name: 'password',\n label: 'Password',\n type: AttributeType.Password,\n defaultValue: '',\n required: true,\n });\n }\n if (attributes && attributes.length > 0) {\n return mainAttributes.concat(attributes);\n }\n return mainAttributes;\n }, [attributes, buttonText, loginButtonText]);\n\n return (\n <SimpleForm\n mutation={mutation}\n buttonText={buttonText}\n attributes={completeAttributes}\n />\n );\n}\n","import React from 'react';\nimport { useMutation } from '@tanstack/react-query';\nimport Alert from '@mui/joy/Alert';\nimport Stack from '@mui/joy/Stack';\n\nimport { Attribute } from '../lib/SimpleForm/types';\nimport { useApi } from '../context';\nimport SimpleForm from '../lib/SimpleForm';\nimport { AttributeType } from '../lib/SimpleForm/types';\n\nimport { Props, LoginInfo } from './types';\n\nexport default function LoginForm(props: Props) {\n const [error, setError] = React.useState<string | void>();\n const { attributes, onSuccess, onError, beforeMutate } = props;\n const api = useApi();\n\n const mutation = useMutation(\n async (_data: LoginInfo) => {\n setError(undefined);\n const possibleData = beforeMutate && beforeMutate(_data);\n const data = possibleData ?? _data;\n return await api.auth.login({\n loginRequest: data,\n });\n },\n {\n onSuccess,\n onError,\n }\n );\n\n const completeAttributes = React.useMemo(() => {\n const mainAttributes: Attribute[] = [\n {\n name: 'email',\n label: 'Email',\n type: AttributeType.Text,\n defaultValue: '',\n required: true,\n },\n {\n name: 'password',\n label: 'Password',\n type: AttributeType.Password,\n defaultValue: '',\n required: true,\n },\n ];\n if (attributes && attributes.length > 0) {\n return mainAttributes.concat(attributes);\n }\n return mainAttributes;\n }, [attributes]);\n\n return (\n <Stack gap={2}>\n {error ? <Alert color=\"danger\">{error}</Alert> : null}\n <SimpleForm\n mutation={mutation}\n buttonText=\"Log in\"\n attributes={completeAttributes}\n />\n </Stack>\n );\n}\n","import React from 'react';\nimport { useMutation } from '@tanstack/react-query';\nimport Stack from '@mui/joy/Stack';\nimport Alert from '@mui/joy/Alert';\n\nimport UserForm from '../lib/SimpleForm';\nimport { Attribute, AttributeType } from '../lib/SimpleForm/types';\nimport { useApi } from '../context';\n\nimport { Props, LoginInfo } from './types';\n\nexport default function SignUpForm(props: Props) {\n const [error, setError] = React.useState<string | void>();\n const {\n buttonText = 'Sign up',\n onSuccess,\n onError,\n attributes,\n beforeMutate,\n } = props;\n const api = useApi();\n const mutation = useMutation(\n async (_data: LoginInfo) => {\n setError(undefined);\n const possibleData = beforeMutate && beforeMutate(_data);\n const data = possibleData ?? _data;\n const { email, password, preferredName, newTenant, ...metadata } = data;\n if (Object.keys(metadata).length > 0) {\n // eslint-disable-next-line no-console\n console.warn('additional metadata not supported yet.');\n }\n return api.auth.signUp({\n signUpRequest: { email, password, preferredName, newTenant },\n });\n },\n {\n onSuccess,\n onError: (e: Error, vars) => {\n setError(e.message);\n onError && onError(e as Error, vars);\n },\n }\n );\n\n const completeAttributes = React.useMemo(() => {\n const mainAttributes: Attribute[] = [\n {\n name: 'email',\n label: 'Email',\n type: AttributeType.Text,\n defaultValue: '',\n required: true,\n },\n {\n name: 'password',\n label: 'Password',\n type: AttributeType.Password,\n defaultValue: '',\n required: true,\n },\n ];\n if (attributes && attributes.length > 0) {\n return mainAttributes.concat(attributes);\n }\n return mainAttributes;\n }, [attributes]);\n\n return (\n <Stack gap={2}>\n {error ? <Alert color=\"danger\">{error}</Alert> : null}\n <UserForm\n mutation={mutation}\n buttonText={buttonText}\n attributes={completeAttributes}\n />\n </Stack>\n );\n}\n","import { DataGrid } from '@mui/x-data-grid';\nimport React from 'react';\nimport Stack from '@mui/joy/Stack';\nimport { SxProps } from '@mui/system/styleFunctionSx/styleFunctionSx';\nimport { Theme } from '@mui/system/createTheme';\nimport { SignUp201Response, User } from '@niledatabase/browser';\n\nimport CreateUser from './CreateUser';\nimport useDataParser from './useDataParser';\n\ntype ColumnNames = string;\n\ntype Props = {\n data: void | User[];\n allowCreation?: boolean;\n buttonText?: string;\n onUserCreateSuccess?: (user: SignUp201Response) => void;\n slots?: {\n dataGrid?: SxProps<Theme>;\n };\n // white list of columns to show\n include?: ColumnNames[];\n};\n\nexport default function UserList(props: Props) {\n const {\n data,\n allowCreation = true,\n buttonText = 'Add a user',\n onUserCreateSuccess,\n slots,\n include = ['email', 'preferedName'],\n } = props;\n\n const dataGridSx = {\n width: '100%',\n height: '100%',\n ...(slots?.dataGrid ?? {}),\n };\n\n const [columns, rows] = useDataParser(data, include);\n return (\n <Stack flex={1}>\n <CreateUser\n allowCreation={allowCreation}\n buttonText={buttonText}\n onUserCreateSuccess={onUserCreateSuccess}\n />\n <DataGrid\n sx={dataGridSx}\n rows={rows}\n columns={columns}\n hideFooter={true}\n />\n </Stack>\n );\n}\n"],"names":["palette","primary","solidColor","softColor","solidDisabledBg","solidDisabledColor","plainHoverBg","outlinedHoverBg","neutral","softBg","purple","blue","divider","text","tertiary","background","surface","body","default","tableCell","border","unstable_sxConfig","muiSxConfig","muiTheme","extendMuiTheme","cssVarPrefix","colorSchemes","dark","main","joySxConfig","joyTheme","extendJoyTheme","components","JoyInput","styleOverrides","input","color","opacity","light","mergedTheme","deepmerge","typography","Themer","theme","children","React","createElement","JoyCssVarsProvider","defaultTheme","defaultMode","CssBaseline","enableColorScheme","generateCssVars","colorScheme","css","vars","queryClient","QueryClient","defaultContext","api","Browser","basePath","credentials","context","createContext","Provider","BaseQueryProvider","QueryClientProvider","client","useNileContext","useContext","useNileConfig","tenantId","useMemo","useApi","_g","_extends","Object","assign","bind","target","i","arguments","length","source","key","prototype","hasOwnProperty","call","apply","this","SvgGoogle","props","xmlns","width","height","fillRule","fill","d","CheckGroup","options","attribute","display","helperText","watch","control","useFormContext","currentVals","name","checkProps","Controller","rules","required","Boolean","render","field","Stack","FormLabel","htmlFor","label","Box","role","sx","borderRadius","p","List","orientation","wrap","map","item","id","String","value","ListItem","Checkbox","overlay","checked","includes","disableIcon","variant","onChange","event","allowMultiple","concat","remaining","filter","val","Typography","level","AttributeType","FormAttributeType","getAttributeDefault","Array","isArray","defaultValue","Labler","error","attr","Tooltip","title","cursor","Error","ml","fontSize","SimpleForm","mutation","buttonText","attributes","cancelButton","loading","successMessage","defaultValues","reduce","accum","methods","useForm","register","handleSubmit","formState","errors","onSubmit","useCallback","data","mutate","FormProvider","component","spacing","fieldConfig","placeholder","disabled","helpText","type","Switch","FormControl","alignItems","FormHelperText","endDecorator","Select","_","newValue","option","Option","Password","Input","Number","Text","direction","Button","gap","AddUser","open","setOpen","refetch","errorText","setErrorText","useState","email","useEffect","useMutation","users","createTenantUser","signUpRequest","onSuccess","onError","e","message","handleUpdate","async","Modal","ModalDialog","Fragment","fullWidth","size","autoComplete","pt","onClick","CreateUser","allowCreation","onUserCreateSuccess","UserModal","startDecorator","Add","makeRenderable","vals","keys","cleaned","Set","from","join","parseResults","ctx","include","rows","fields","existentCols","cols","col","column","canvasContext","columnHeaderLen","measureText","Math","ceil","longest","nextRow","isNull","isUndefined","toString","getColumnSize","slice","padEnd","headerName","useDataParser","setCtx","document","getContext","font","useTextSizer","BaseSSOForm","config","providerName","allowEdit","configurationGuide","setLoading","success","setSuccess","optimisticConfig","setConfig","timer","useRef","enabled","clientId","configUrl","emailDomains","splice","ssoRequest","payload","toLowerCase","updateProviderRequest","split","auth","updateProvider","createProvider","onSettled","current","clearTimeout","setTimeout","position","Alert","transition","CheckCircleOutlined","textAlign","ConfigGuide","callbackUrl","copied","setCopied","fontFamily","navigator","clipboard","writeText","span","readOnly","top","left","CopyAll","databaseId","newTenantName","contextHref","encodeURIComponent","query","href","flex","textDecoration","padding","textTransform","boxShadow","fontWeight","backgroundColor","GoogleLogo","QueryProvider","values","ThemeProvider","providers","find","provider","beforeMutate","nextButtonText","loginButtonText","disableSSO","setButtonText","_data","login","loginRequest","password","sso","token","redirectURI","window","location","completeAttributes","mainAttributes","push","setError","undefined","preferredName","newTenant","metadata","console","warn","signUp","UserForm","slots","dataGridSx","dataGrid","columns","DataGrid","hideFooter"],"mappings":"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"}
|