From ae6bd5e406dfd8e4f95c76e4fd9e8c8094076bf4 Mon Sep 17 00:00:00 2001 From: Aamir Azad <82281117+aamirazad@users.noreply.github.com> Date: Tue, 25 Jun 2024 10:32:26 +0530 Subject: [PATCH] perf: speed up settings autofilling by only calling db calls once (#35) --- bun.lockb | Bin 223716 -> 223748 bytes package.json | 1 + src/app/settings/page.tsx | 94 +++++++++++++++++++------------------- 3 files changed, 48 insertions(+), 47 deletions(-) diff --git a/bun.lockb b/bun.lockb index 1a4a325f05432b246e7c0b5908a66a8c49614891..6ebb93f278a80db9f1f21c121179fdc931b218da 100755 GIT binary patch delta 23760 zcmeHvcYGDq*7nRKhh*r4NH~O&&`U^9PD087DWMp8JA@V>KqQSM(lrMV1rZTO-G(Bf zB1NTR;DQak3U;nu6_BgZtDq=FxhkUgKF{oZASn3a{eACWAM?vI&t7}4S$plZ%e0gE z_j|SOe81NHef831{koK`H#Dujrg`7jG_3|W%3sq$z^lNu!Q)Fxa!ST)T4Tu6D=I80 zMV_|Jp=q@s@AlKQ>fnOxg2LPhnzjB$QO}MduJ3E=adxYP0K0M z+6QV{GZch@X($Lx#mU(vh0_Z(Z33*ZqE`cCc~S1fnKZl|axn5gQwBc-vjJ}^&MoOU zDX(yxmV->%-H&|oamci{*_H=s-r}0l<8j5=<8w+h?JLMsjDi*&nG0r%o=^sSEnE(n z`T04;lX7A;%~$cAR;3=|>|RI4s~Q>)gWiE)WO+-idPcLdruC%lPr>-}W*5xN&n_K5 zx#YI-#n~k}nt@QWaYebs*`;tQe-@jpX_d%lBTFae6fh14mHa-KjXE17?b$7d{+63$ z^n)76;{qg?d8bd#9X}Zgxg|L>a=_&%pnG}fdm1XrE}h(QO3utDV1O0o=N9A^WtWu1 zHk6HCiF`Kx1Y{nU=9CRuuJS*C%x*sjroH`*r2d28>RK5LhRP_9Lk8n>5i-Z!_h44o zTJiD5(m-Mpseh%RKicsfU(i%KMed zR+39g@^Z(af}-|P{uudm=pSH?@(CTJd=N4nm-D-qTo$+*IqnwB3S4;%xJX?Rjj zZi(Gu)q)5xdpavpI=HfZ2`d3@2Nj-@k;a!NKu%b_}>G^YUThPE0q zN6J!g?NlV@G9eGhEhtUWPNM?KvtuQH0hukBUV@{sA=|ECyS3I4QkDw07_aepB{NtW z0vTh|>rRky`dQaB3@L98;!}Y3tZ``?Lg1YX#?bMOS9~^6c6?9B93~D)&;iL*&Z1ap!O8ypt>Z_%`t z;2*(Q0K5&s%s*-621b>|^^-L}-&fWVjnXibp1`090uSpiT|WeweTv?)`|`{HX>A*r zeZB$Z?CSu?95k7mkQ-=PnKxf1y!k_=`$ND~OjFzf<*c|Z zWRB_}a076}aOucGFddx^t_RM7KIKkeRm>RBz)K zeyvXT&E@DFdhH(#=e5+Lt$OuB3_Wp2`+8rR4eLA}SaP7O*}snu{QDcPb#GPNW6iNm zkA>|0X-C`8=m7n1mZ!N}|H>-Iez0}8x!df43nBE9x0;omoMd@gxXquC6HnKzwXI!d zghSIX+`Rr)b_(5)BmTp6n47|D(-pXa}fRt)W+2fKdXIr<~3{wXqC5fn@?e2(5SyfN6$fGg@!F9q7PMBbC*8bDsS&LcOg&4DZ8D^{9b7U zSZg7rp|9zI!#?^RNLYuxC~NJ~U$G8%aGPACm}l65=wx{!-1-And4$_MfD-!aU{j51 zb*x4m)Aiw&r=we6Y?WjGl6APF+Yy9u+u0h`GDXj}JdtjFy;Y9=m)2qIBP?f>+n7+# zIue;~uEI>CFLq6ivyggQP1>e7QZVz9tYgDdEl;#tZ(x;UKgl|b{c6h@<2Jv+_@y7Z zRT=3r6N5D^5fWnB-eu-Nl4ap-UFIf8j1?l+&ZU22d1Bpq533ye7p%jvZnFv20BZZQ zt!9>z0xZUDKcrZc$!m9^Rf#+(C*^_W&=2bcLbNbG#go{JY%Sv9LN z)@7z*1!YWRw@tG=DQ?3IvsR>}V@4cKaXa>h*<+#gNFRn21F5!^jix%< zXxgw#(#R{M9gv1xDhq5|RT>3p(514iS4e*CG!5r1Rl{INI6W)raY#H}*tP4YEN54@ zo?v;fpJSDGb(@>p%OJqlXcyLFXE%(w4zi0elrS%rLXxfFYV;PQ1fM;_h_D)UPdAez z}$p*IDJ*|7sn^KErZmxb+2=2m6<; z@(i~T7;PQNNH=>$%bA2(+0y0M3#m7k8qWt1@C--E^*V14^oNf;T?E=MrN zQM@&(MT(;*Qqk72^b~!D@x3y#LED?FU-#% zQByAH4KeIg-LTRh633yRJq76xhWVRxW7;kl0>~{`M~YG0QX5 zt$%Kn4|SVOaRf_DD?0;c4@d|x^s*ydyxmgFDdfww2Lk>We2ms;tK8!@i*VV(b_Lk$>dTPW zSy=9{e*XrEPRZ3g8Fm;|j88;vIwWe^E3m%9a%Q>B#u>8X4fc;Y0TMe`I`{x2sgF@< zzN;j-g@w1K1j2}Om}QUW+!&7c@imhhdk}H=p~iqQ1&PZQAT&H zgG5JV=X|atj7F4&_m)R(xEvp`%xZ#~YxnU@1YV@|h13n!F=jC= zmP4Xfc3t}GmS?QnvEUX>n`n(1o8oAYiC$sKD9*G-j7>LRL~cT8Ws(VLatTl`!YxzQ1BF?ISL8NoQJ5Z1I`_CP_b+(q@kBI zUxRe3PjUmW-aQ>9`XT1_jO@HzB~6BIlR_slPQU zCp8cWnvz}VHwvc(o**2BNcCU}i+_2Z+x%#>>~fgJxa=~fsyhoHNq4ZGm~TO%JD8Yo zE(R@PTrqcIU5+V~>{G}(q=s6f5>p%(kV>~k#ip3a*;QOLmqJ2Es%CwDMOiW;BOAlP zv<}kcK0OVon{_NQ#f%%TX*dgEzF^hU^DIx1+uVS>Slb`0WIGy8O?8z;X_`iGBkMpk z&;Y>5(+mL3v$v}3j~omH%@4p7u(!X$v^#(|>okOcXdA-#u(ztLTW{?Nv3}VT2yIP6 zkJ{VSn69Hk?IxfD?TyT;&@J{xri_4Unw7sXq>M*RpoHye>_C35T`HOSn0B_6JTT>a zfE$_C3jyXA0ok0AN1AttvC}cL6-^Zp911+^)uK z$P$2dmjc|DGVFfVl1(xW56E1tDpUO-m0y)vtpLamt8y~+S16fW4R{owyN?6Ze*)k} zX8w9S8=}mFy^*Q7LGeaASJTKm;AxfrjLIi7f2)%JjH$N+prgB#{w`jmbGw{zZJCZe z3y>?Mn$0x02Ve#J0Nr|SUmJUTy$FfhivYFu12+L50^I&zGVLF>t=cT(S|!7F;HXll z%5?i*0GsuRDkoF^RBZVgUR`Bj==ulV9LF)<0R-u;TlXg2B>l}lLHkGQu*NaJYHjl2_C5m z$V`q>GTE@++T6^J>R45ptxCysZ-UCtQTb$cX|Bq@RptLT%;x0jJk`jA?OwhzSd|%< z5|vLjtlM7(W%~Y*$|o}^bhVHnVQ*v_EC(~{tCai*xGv<)VEk!Yu%jb874HF4 ze;=5~Kd9Q74jfeS8%jQ;qtk1n;1gtUBh%1lioXEU;Bhc3{6^)UR{3Ya+{jFR zhaHdq5151QqLOtQ!A537>VX+SC*KIta8qy)I2w#UEmmfobST#r(wp z{{s#-M z!3_Cls+>&y&%re~{!SsmzWNc&mYQ&vA*w~Uufa4>Ta}ZUtcM-*gH%45$(xi+W_bg} zAz(*;WHeR^Rhe1MlwueaA-4i^6n6mQPm9DZ5WLET(lF6*-JeUXm2Bt#+uueUbwJ4@ub(PQG+EA{g%E`QrXsXIbg(-z_r9ft~ z6?R+<w_18>CJ;+M(Sb3E5Y2rWp=?Ms$eac&3O_`olV#=o?F2*umeno zb}6nT&Deu1W%U^bUgdMy5c%u9#D^&Rha201z(zjE*fB;_W*cYPk>uh zX5F^{982<^ewZ(DeN4l=U8kWN_x1<^BhPz!Ze#}N#=X6a%SHwT8<`{S#=SkGan)x6 z95z*M<>jheCBq(9RqyF(h%)1P9F)hveK&qKJp{ap1pI-YJ#G2Qep*M{|4+ zLX&);_qB)#h6xvv+OlSu z)zHyjRURMl^GO~zzIDN${nYcKI7AbCC~9xYQ9eoh6)mFkd?`cqVBj^?I78*}z4ICo zeiKYQs*3zo5uc>Z!*O)fq4F9cJzwQjLmm%t0=vXin#f=^*!Z@G$xz@PfX_vnsXX?Y zAH1c9VJfc)(g(#$G{F}?+?uN*c4(H$YoYSOkT*)@wN!cG$Qv!{HGqjlsG5$pRz)q4 z=5GDS)P8R9;7<*9twvsIR{xZVEBJZ@_mTe6Uv+;Hz}L z39qAzrVWke?F{7cso__^Hvk{{ZUeRheAC?k2mzcTx1kZLhl>Rbji|Cni4gw@tv)z%#&RU<<&vcJ}~_fqQ`^0RIOr4Zy#U*n^BC zha;sG!0v7bupilP9J7z>7?!+Cs|Q>_WxoKw0vCb(;*isDIS(PZ57-0j0=h!=G(vht zgf}v>%8nz+$+#1kh@wfrWPmTNO98%Mz60Rf^>F}SJWmH^0AqoXFgX(387Ke>fnwls z}pF92o&eC~5I zV9}-JDB!OqMgs*%=K-vYD)+KY{ijnJ}KBwGOG zzzSd~upF>}2LKa?RR?MSH37a93S$}43sLPNU@>qn@FViJg0}(Nf%(7!ARCwoi~wFl zjCk{T5Wq@WW-pywDn|o+xzAZB0D-`4pcl}aKgZ~U zL?+M|7>~-I2j&7fKsqWd1d4zXfUlHufm?x0$bEqosGMhq)c{xjHNbd)%e@Jk1As2j z>k4!Ooli8JRrE&juC%cL5im^b1f875)rd0Db{@Cg*$DVjMFO z=mmITV;;cM@kfv!0{DuL?{9g|^+Wn~*y1lCMgk8*ZxKUtuP%z48AB(&4F&!xi3gfU zzX_#6U^0*cj00H4^WNJ?^W^me@HDUy;E8K3@Gi=jN3fhfSm+;y9kvJJMP!K4T0ris zcdA$tW(=!-6T^{=iuubcf?bg;&bK#O)bnMtpE_is%MeRND@ zbR0%2M60)Fx3nK4^hACS7x4TXfr_=L!4`x>Jz4xKhQ!qMvO1^3y9CZRw}6>qtWI9#ji zNuV(zfiy+rCK;KbzJKAL-7w|n+`9))q+>~uaj39N97=*?_lc8KFBi>{A*~n5$wqhG zCCZYG5B23De6G>JA62XrQ#+yf39%Ryx)~wo1^vnVS5^)`KHv=)jhB(!Enc94?=uvk z8_Pb~e0&#{99tmGolNniy{jY$} zNOS~xPb{Tglz1l9aEkpYMk9TdIF_Q% zZx@xYpuZ|Eq#BtCzK?M{e(SW`W?szVz=(~Ei9?NHfwH0Vx8}UlKDpl>+fZ~Qu4&qf z+tX0*1hFm6$kcPhZ)vc1TsYGa^I{A`6Ac(L_M6{+zCZg1+a5!%eI@3m+YML=3iW++ zqkUA*Uw+C8{tkLBgb@ub74J~*PO)|n;vdJb`MFWuX5k`r7gOBuyR^0p)Zz&bY}X*)Vo~R7`He_u z+Na_y)n#{Gy?xP~4TprA{dq!oy1?vNv80QUX&Cjz$6btu`av=3W)!|JVxBgFt8vV0 zm7?9vnBVO&bvSixjSl7vOu|MGmy2aQV5L|#(rC~W>b~!EET}s&FYiu$m24I*Z4sY9 zHB^21!`uIkynP>U+wt_}hz5!JUExx>$moie`aS?s{i|V3+>hS-GxX5ijC`!v(iI;0 zTsR??t%eI}qRSAN_kHK%kxk1_Hn`~@3vd`FAQy-aL`*m6jT3!9p$p(WNAOQS&z`)0 z_yg+iZhW z2z}Mj9zU)rf*uwY_QUt09~2UNpC@^`FlJ}osqv3ML4`$r(M0n$XUgy?)Vd!_nMA|E4YjKD^j1wnGG5~tMXx0Nq`MzJ`c{Oq1*S*hw z1G5MxJ^x;8dE}CM=!;l<8J)_DZ*6WHU+ZD$aYDoMe~Ps*gcW2j?F|o;VIJFSe2wOd zh8(dQU`Nl^3uzLsMK+hAZ*Z}B_ZPOj$7R$N85<86wP|V*%__uyI}9{m*~3s z3^Ayuk%9@c6nY81kC+%wo_T%Z3PLg`RekyilqZw#RJi`*B9T&$~ zh3`8lam&ZgdTI5ew;THRsFb6qrl{8oZ3z<{K%u_xtb91H!8Y@~2!DS)hK4YsGsPGv zB=|nea`?iJuU7x|^97d`e4lRFQdV{%$UOb<<&uZQGqkNf_Tue%m)1LC{c!8D!a-5l z3jzPUwG7eo>vsIT=QBHd2D5YH(Z3i3QN6F(BOE40;&v!-74B_x&dOk(+45wEoSz?xo)Kxa0{d-#1zsqV!7D6kbPzMUny}7GLV0n+M%L)-9JQG!XFH%5_&p?lp zxO?}W_s$9SpB${Gr(sT_fBhpxQKr!_!5JwBf8ES6;_SdjQZ8GHR3(r7R1ocdpi%zi zlCI)87!UP*uBKNVZF&FJ+omex@V`Wyr4#px8hsJKFNC`x3ZWuXSaSehG z>)<|}4PJcYvmtN(9p?&r&4mxXPtiCJEHjTS*!q-R5<~Cyi+mg!>ib?!&K+M(FZNXO zERV_0S!-W7IQ2@g7kZ6-U-vn_dFHZVpH2PIHWW`o{w{H55QdoVvpw6L&HB7lzXdw} z(ghQ)b)0aoa^ca^ZGB%4L`i&PB3GZDB5g22IbOV!h10pcXwMZ>nYBhNCY=@Q24k8X z6Nd(4R@#y0X&;>R;cswQG&x)s;No>I+2H5OlOhEFEIJBQ4n1 z0e)%rb5^h8_=AZB4{xq%A7~Gv+QJ%&>%a}-!cb$SK1qmSI9_#niTDCi!u_4)oPH{N z_+vjW_^svTgIA-3mm%N$H161#`hoFwTWzx)MCNd`=!lp!9QFo^m6XnkQMfh`Zx1(u z(jL57Ub0-H&k!!(2Zru+zaQHB-2)jguBJr1XyU;P+A5}aV0DjJQ-w~8Js#9}UVMv8 z!^jYUBaB$RrbroqepTNP^6ofTw*2NvPq(sLVxJYESTq8cT&KmN5jcFQcnLEUEu$B;KK;cn7mUM6f%hPsoO^^j3;lA{>j_(-vna{Jg6#W_(6Xbw^zDbn-hFw> z*`vXk;roTdX{u3jp_ zM;e9bK3xAf^^?N=tl`YQcHO?O92pFHk5sfYnkE>WwOVG7_8YW^!8*}w@;-$&x*?<9J>vVKj3!&$s zt(}BE29zaYW}rXv2iU*T^gf-jv)hR_H4YfMx|`AFi+x(meN5zO`@Lkj#cd4klugDjaU&SE=MSMNR=<&a`U6r6mqG6%Qg zzYE!QcTj{_Gx4g|Pw8nfiIKQuO?^zP{8% zX<0uY3QPYOay1XGI?Po+s9`RhR-^s;hoo=9sRqdreH{bky1U>{oA;@B4voHYw*PK2 zU$vFz#YwIb*EhA}{_ElMyG~bYlUkH~-$L8h@%t``t6yHohY#|uM8(qXnClt%e<4J> z#IMtN;e(e6c!}e^^UJzn4+hjTE>F7uZpFmg;3C9REu1psM&M`>JrzrGebH;`b&c*) z@y1kGSuDPoib?1D7M$z3fQr41`@LqLocT;i+bZIUab2`mj43vp=HAir+j0%W++w4< z(Q=F!TZ~%wippY~f25L>!u4iiKnZGSE2flOGSI?jU@-19dG%s^IMpk<#Nsv)*KqdL zi|tXQ*ivkS{LbL@gkFZ!cXFvZ9{h!(3 zF}2!U=OELsx+-09^8MWyO7Wf8u5uDqr_?e$wB}u7=M9lDE6+X}jfW5Nk)Wv8->6?5 z4-xGfe?MKEnPtR^<+mF_V)INRP<%bpXk^IjhN9^#W0gKlq|L@z^Zi+u3T{z(m-LEe z8}t6~ydzkjH9_8RP7t-`7-Qt%bFvy!ES-Zzx=J;T#K&`tzWR}h4!0Zs@spQJae7e2 zkh#VHT@MoL=V1`9fjx4M|#<(C@ah4m4 z4ECmEudlkk&f8kkWtPJ&i=CGOZ+2{eM zPT>(uvbu*oDeCZ9-ZkyW>-j6n)#JZE9wI(kZG3=Rcs!(Kc5gi%%--$gJ6kyP+$t zqp#Eq{gW$XhFwKX8IJSaP0LGiUEYr3VSyN3fu$=-EO{1g*lom{@A5xxv7HgQyN&MkO0#qGrsoz+$jJIf>r)-JwdpNh z+HEw$!<pv;we%19&m-e*XT7)ywb!kN%U&s*GLTQ r=GR!<`){L;Skc6*FqGr0sVJ5MXbuNNAejVA$qXFRO3ik)B8O5l zEj80hG&8MxEvsAE*I=erUM=hEYS}Hd!TO$OuXPm5%I@!e|G9rW`&sW=?|Rq#u00&~ zymuR&c&E`lL-i5MhV`miZfIIFO{;!a)3gTQ2yaab1m6R049+Pp&n?fOBX9s32Q9qxq33av|w^2?LG!M0P*iDgRg_xfW3+f%46~h zOR}{rMAGhd#FGz0roA<`e4|!9xuL9ac9}aTw_MYXLZ)H_v{;d8V7BN%Wx&(I1&|qE zlv|dUo2Y4?f@fIA^uVBQO=N%l0EWTp{^$e*tMjdV^2e+?uz`FDY=yo$_&*-1;quW?(*{X zEoGyZBA$&u0-5;|f@FghsQA|)bJ%x-X>WV5)L#UyuT`PNA+nc8A%gw$4P?%{lVG+m zSn=Uj(m+(G)W6)&Z|!*UXSbFW^4K|oo?(UefdgT)`UEB&Dp&m~7-dxtX(KD}jPgI?a{kx^pVfe*+_AGY*0o?@~MmdTdTPnEk}% zlZUxKLB$v6&R}+JcY94kPgJj!TvdH10<7Lt#aUqVb#*VrQDF9002pIet%125zHKKf za#(Rid0{~|3YZin;}0O76?z%WS)Lg!<=v23ak;*$%C+oi<=G{bn&$2-Gv0_AbD;8a z3(D;ls}{5YbEJpG$_g%xk%o%nq~Q)IoCSUjnfXieVk#<2bIVu7%c(k}BDWZRLt6%! zGi5Hgad!l!F(5M(6j!8Z$58;~l0?aeAhQM2%aI!gqU{16vsOC-tKv~D_E%0}`3$Bu zfQ-3Wos=y5>9nqCm{Qfb=$~S=$8u^Kx}bU*7*nTuwBk>@%7O0=nbYL1ZkopF^Xmmr zd7Z4yq}=Rjd72ib6{%`PAR`B|Avh3x9tJs3?}7cm>6Y6ku)fhlO6R&;b9`c}R;0;J zn_TFwsK}k9?NiEmE?JwK%VTT@>n_VHb(fXrjzv5>cUe!#^T6!PuwHU73i66e%5pW0 ze!*Q>uDz+^bIVK1auMIZx72gzl#~^tGvew6RdwtmE7};$skt6?;1u4jxCYGeSPW*_ zvlVadCwt;iFlW>)i01?-1arKy6>9@zlM8ciL6Mqvw!ch2E;+dR6aq9bDL1z?rl4HQ zR2hd^$LfW(U2?rNJ6CaOOkqh5oF%xRsGvfdYqj+aOz1LLRua2O3_3IKI}AUkMc*Ns z776|m3s4u&vOyM z7EA)Oe@=~+EqE8q_+ctTBACl)*f`nJdgG4f|eyrC++vLao^w+`!}$TU68I)tb)E2y1I-(+RA zbD2kcG_4o1I4pOh(+tHm5pDZet0B1|VGUL{vD(7iTUJ(km)^swY438Z#WhxUYh`$< z{;?I*!DU8bnXwuM3pR5h!5^T8ZQD5=>mfn6eX4%k3hL-Gn_&%O*07Q&BL@;olnq!9 zDea>4sgiu`=0sRoom_g3Rny63K8&f+-L}Dceh!J{8FsCs8eU8bcj_fpO_a-g9C5On z+?|}}Nu^QGS`8@yqs|&Q?A*6Qf+wy@uH+ z|6+X|Y^m`>V=Fi&O&?-q#klk;s|M$1twS*`hYx0MPitIcsy@=nigoGBts0y^v<~6i z#tMpa8JSJ34`b8Jd$8767nGEr;tgSt71}Y?jKk7PL9~~3?4A@WE8eBow`y=6YaPOQ znH7}aGC#p2W>qjPVx4AGfTne|bGXw|d?CoBwjG`3DoE@tZ?<0l#L7x^>DO5`I6rM2 zN_3e`;RmSg&DNU3lvK}R&uxd4h%`CQpI?+X`GT?h;BYw#kcuF&6pm|(F9cbC7J1S- z)Wv1SwUlx7*mY(eq*SQaw~j?S%{7oX2&T0<#%X>DNg0lG8m=H~OhlSK*UIY3F0AS5 zGFxGHp}Ma<`#w>UJ%VOCtbNWDIisg2Nsje;NIj8;nTRek;T1+fk~47vB=&-@-I|q3 zLZ6@qKZm5|+sG6vsGG|y4fWKZZA6MMgzm_SmZ1YbQmJNG!y(+{r1v z5IFXly)M2{Nj}!GM5h@K7s?jeV`knAX^^eCdRU4cW<8XehIMf$)#cdU#-1|mQcZek zb{eKbqEjDk)pU26a}XD6$F+@jnolVSD?h^N_y|&8PBuN>s_EgL{l<0#XvJ*phySbqE@tAWqc}t0vgWa=FZrk+N|b*OhKrhg>elS;VDSN5fOi z*mj;&_UPS^5@55jiFG?95>PqV&jl7ul(`C}|j+%Dk#k5B+lg>fH-la+y z*h$l{MJq`_;+A2TuK&{t>f_QoSy?!jS~Y!K=9(zke$7I^!6ygx#hi~x@F1^yq!nxL}8Q?O0inBf(kY@IXmrDt&GScbT0%;JPjrl!7T&?zY z;D|;C_omNw6d}}?9@*T=5H##H>-Y{*S8FA5Mk5>J;d!xO_gF!LT)LN)g|o}58RRkx zF#$N<{#M&KCn^&(*k%5NxUPu9`sw6!B*NXsTPr)In%M|tA|Ab$;546OJS4kB{eP{j zAufG@RfF>q>k!VtR#3XjvBRlpWvq!KDh1}HHXD9!Hj2N6O` z*a7fu2b6?a5$|;PVh(k&#zmw$x+4^C9ZgHs3$3gh(MZUgVCYL(5e~bGX3EZnF3!n0NVy6P7pYk&Q4xxjCSEtp=Pwp?A}M} zp`6Z6M=7KfYh_fbxd9>eIL4~8(>xF9CP?;{>llH#*xw3`@9u2}&@JXC2;q<2ju{$h z)nvKMNw`>HgX-CvNG&7|6I?Ak%)cSALehiBz%{ZvF(=VwQy@{(_PqLfD`>3C^cx_D z+~B~NnUFZFvT_R{N&RDKPV?_dlAczxvTkyj*I~A>+im+s=|C$uJ5$}{;5aRTq#6k4{tu>E zp(xpapOb5VyKZktePIE!74u;MB-*pf(qFK$Cb}GzLo{u&HEv?6qkcL@gdt;cx;18E zn)wVO*xS-wX;zKfWnPb&$4P*_H_K_xf_U*sz-+ zvGQ{8H$WQCf=wUH4-6xFHN$C+g@oCtq!o}*SJVdH$4r2uzzn2+!q}HX;$*U&t@#!t zD02a#tT1dC7=D@N$b~e@S~;b=F9J7vqRoCIP=$-qT1cq9GUt!oXyQew3=%q9Rpa@K zlDlJy?iKQUi~#Oh#iqH^ufB2FHxpG2o)0wvq$)*v*>8rL<|@fAX8*0{t}Gsaz~ zisoEM7);fygO{bnpl4)bIH77FT^v`(aY%iwqp_)a2dk#kWtQZ~sf{Ux+O39!JqhdR z*exkf2Te_NR>f-el^4#Eb#NTe0>F&c3;?5QA9dLqF<6zF7l7GfAAf~u7jr#Pqan1^ zHiQ{uA9a}(!o1PQm=&64?cNz^GJuhXbYVka0@E;f_Ccm`44Hk9DNnQ|$+{KuTwoO= z&>{9wmmP@7SMg+8F92v|ijoV#JjjeM2B=p8@Tkkakf+i07iM_s1& z0{~e7Jjm3qp@4(z13V0{m^A?P*8)7qjDL&*jyf#+V?837VFOcfkeOj4!1zr74>IGo zP{8p=OucOYEBXw;A(#>ia91OgRAD9(_x4#@6l^0;_0dfYKTW=8_nyw6Dapo}tpo z3=UU(gNm=q^nYVjJek3plnf5Gt2P}xZ8%Zu zb|qIa5(k;HbRL*)`ff1wmZ)?xgG-fMms$7wRXmx&2b2u9w--Bt1|LKMC&h9w<&|JR z@MbXnv?p<5MV?l?15Ev0VCwHy@?Iss1ZD;HEBQ4g9{@K-{71Sh9|39TnBo&)8vG2* z0>4!8r&avdU>;-!&)~$0d<*8RyP#y-2xKxF;s<6Awgl5|D3`E50&!scX$gvxz*I;9 zV++#yfLnmGz})yIf;kT-fq9Twfjltt6@po@B9%_2{!|rT2F6oSt%?<(!3ALaX$x_x z555=7iaiRZp><&VY3q4X%=itEslN@(f@{IF_X3y|dJ#;$m%u!J#Z{L@(7-Dy<7+Ad znZbW3epB%QFb%)W#NT0d`7xDFrv5*{?9o$Tlk@K^0&J--s>?2F$ZG!%(?BDYPG-;# zC&o8b@ni-AluTxNbHy#dY-kA6dCg`A6f>^1QVdgykzmf^C@}uC7@T6kW5F~u5zGSI zinGD+V1Ey6%I4%LtwN?+oBtkY?;2B;ZW(oPkXgnI60>lJTM@npt74rT!x!AyD*C+6R# z;-69RwJLs>l3xHb{~j+4Il|gYDq)}E{fhZB5-!nqz%1xJFbg;YrhyL?9|q%3`$)+j zgQ<61$^4xQ<cVHf57IaR@WTu}7Gvm)-R>%j|sK-}EJjm2DReS>_ zH&p55rbrJ}>0v5;TpOi8W-t;bdc#C8$Jz5j*1P=n^PaBF8E096qcUZSVUy+;2 zjnHECMu54zCac`}if;zfRhEOPR{`cxml;0|@y);s!K}@FVD^+y{1BK2nei*VF~b;m z1QBe`Ixuw}$BF&91f*&L6FvE1E z1P?MNT^ztM?*}m70DwnbX4!)Q&ZVIM56Kfefj?#%#?8GwIj`N@YuE1Wuie{YHT);{ z{9H-b?(N~;;Jert{`6srDPOy{mu~&qz5TU&d+pl2{k41hE8XMMXI{IvM<-mnx4(98 zf2Di;YxnlJRljy`ukN}3oA>yC;od&{&+qM@KJ@A{Q^cpq`e5-vvffDa=&BFaQ^o9L zeRS=@u6o4~{h#8(96d*m7w)E&qD6?;dmzEJO@TN&ZrwLO>V z4Rw9LNWWJ<>{#0y4-B+!JwlL|$4P8o+`;%XqBSFMe6Hd+Vi9(XrhTE} z_#os#LFt_CzaF$@);Dvit=>|{_IyMd~C<#XBEdsoEOB~ zG{GmJ_Ms}u$A&+l_N=_F;sOwUSvAg3aeU>xO0;bb6A!B-ZIE81Qqas2r+1Rfn!TqMGt*DM`XTsy?o2sceU zL|q(FDyaj)%K@5-R&gB>UJ3B%j5z#hoq$zhD^2jF4G+HFVz)#CPXa83|DeUV&cG7@ zP4V>?<6?kEgdS)#)87=$1C4*T;1j$ifPrMb@@@=#?=4!lG{QU46@3nT3GnIeQ@~b$ zx4q2){>w;9AXpT%G(z-nF~6k|R~3htc!0l)Nd%IBE> ze6994@C2|C*aU0_o&**Gi-0?UyMViaRG>SM25{oF1vq;+GdKk}yqy4!CFk)P9dqhI zw2qGq_^X8C1Z0|GiVorI{^L=q&HMgqg%fM4v5fTV{8={#xB&bN`~rBvP51zOY0?Dn z1Ni#PA7};y0>MBCKsR$5c}Ajq{>04wHPUV1+W|yr)xd0^1SkdI*0pKCEkF)18JGav z1n>dyaDY#i`vLud9WcHVcn;VF{0(>+cmNQx;1EzB;LlL_ z)0Gc^_krhuX92#TzX!Mvcowbs7A@y58XiL$U;fVkdIG(Gdl9z`zz-(0aX=BmQ-Hn* z*YAfD{oQFVaeFJHMb#!4dlKjfbONG*&Oi(h3&a8OKmrgBJP6bPOMqp-y?_PyqCzH6 zA7}vZr4Zj=SqR^O!WRN}0(Svt5w`{W6gz(_0&{?Qz(imMkOk~PPw~z2et_PU-jv>R z9Ke0=7wG6<{zQQFh^vG=9wDLg;$j+tKsu0(!gmAJz$Bmt3M~do zfHHuul=FcCUR-16(8T< zavL@feigR(ONg<6fF3u?yVx~5yhU-CF)EwCN@7M|D8CM+VjvHg1h@gFaVvZSVeV&Z zfsMchfP2{^z*|UT9Km${U?HOoPB`xAB4PuL_5yOx+WXoVBkDI#MUni?)jA}ThXSeM zLX;8F)RRO%!ltH*glHq$q!x!OwKg}}h%?Q-U8M1eVr3VjL+$=9#tXW5q^r>)gd1Qh zjAzF2+8yz`o(nbf@d>fd z`@b77IQx}1p%5RNfIscDSPccef!IYo_K+X+ZW+ipQ2cT+wwuvUj~1)D83&UWV7Aa+g6q+Cx6N%Dj9f`Dhgx{P{xG9e!GU87 z$A5#A#8~tu)}+{c9U8C(S?eR~mqmYHo_TWk>rm(-JA0Ej1_gb)_>p>hq1OOG!!A;>TU#y6RAe9evkMi6^&jhlDZptx~x%%=UX1p@2xF+ zd&;((ScJ4-XH5$6d~0LfqDLa4hOSA20^5Wlo)e)xjC9>cOzDBDc)sB=_o>{sqPh*+ zX&Z`37+v%%(KZdWJ1kPuFoKhDf509eIq_e={BV!^EV3rr z19o1!0gx+2;t|x5xi|IX) z`F*hwkyoxXrh}$=KI}2+?(L%rj;uOuH^=TVHLO=`Z#>u9KHqo@QUMT5Pv89)h zZk+WOKld_P>bpf%ZzS#)38eSL;NI{At+6K2ebshibVMN*VlYI{w>b6&xAWOGVd5ut z9g?{0mx?!#J;d{IkNJK#6&B9ZSI94vAJl~2c`OmST<*;&A_S50^qC8LdP&oD@@`pnoIoqMrOVidG#Oek@|I8P3&1j{v>HVhNiiJM)PH*MIx)r-ptz)&b|t6{^=&dZkgKQGXO6J4JVkUX-%MSkg)H_9{ztOQQ!-I-LMYe^oRcU<7)_YbV4}WD6P6Mt1bX>vI}}FB-`f!_#v7ZOtIu zVMPys-D1&ifRXeY-|T1mX3iH^gk1AC9Di)eec4+^!4L*N3FALd9D@ZBJJ9eKr2`Ca z2VJ?04Dozo!C4a&d-d1b%zr1!Mdr^;blb zboBFkP-ucC?Ec5I{e5ftkG-Vu>kEVcJ*`K4EUysk#sys0g>&`<@^jtx>o@T3+XB4v zr51OM^GM-5ubyzz(t2wTv||b~;AkW^qUezDSgEk)d~v+@{@|iZMLWgEtefXcH`h1O z?#*bwb*i!r3wg*I1lxD++39!q$np71NwRHMi`d=#bL(3#UqJDu*0NnQJDhEcBL!m!5;$hB0=9%Z!f zM$IzCR7PZryFh>7u?oc=C?u=zO;u;yUikcxtxs>ldg9g$L%)CdbBkznBW%ycgA;CQ z%WEQENVnF1YiCVlR$Q?`L9Y>Gska__oGC&3mzhWBKeZ8h^hW6R?P4hul0Dzf$-VuH z>1A2RxV7_&4GVJyx{>Q-Pv_+yrjBem2q|=VDfrc=ILabE6;&&Z7Oi2+^VOautGA83 zFzc<6P*wiFp@<%VYIr{Lb8O+^imgLm^R*S=gYjHOOn^eN=YvA!&yU>rq|xMztzciK zc|JLGUBciI!LvVRC&8OCt0gugE2{Cz2qW6@HYye(&Qu%0-bk~@B*4eMjK537jYJ); zu-|fjz~z_RZ}mzsYb1s}U2Gj`yd_69$T-(stQdt&-Vo1@!ZqOv5jxsfu8$QvM?>|} z$mfZAnTVJtQZrH1vYv8u{&hb4=!9mzT`u)Um?(h)p4%;=dVjH-lHHL(;_FPq-(1vN zy07)3K^81E?jyx{u6IKQ9oRnrme4EQO*#r!78b#yVlnje&Emy6bX*+Hg85UT$rxOx zob4~7#u#{tC&od<@Py7;V{lnB zcaXdwk6WL%_p|xgaP7Q9q55Xw9t*u-F_Y9q+&|Vxs`7j>XxZWG^=)rYyaS5{S5{n@ zR~%`(+{huC)&?5It^d8}y$>S0UCQJ6=FH=vNB6(CtsgFbJ=Q!QsM#=t_4-)2w_~3De!V>3Ix>zdxb4A3NyV4Skn_9+=J^$Jivi=X z2W%4stAilJM;d?vm8*lmT2N{yXE(bA1rPhZ_L&|7h6ks z(U~E>9*_ALD27i$vtq^I0?;rqwGiYM%S%Di#ncI)#iEL7>qOIH&!g{ve04WfwFd^3N4jQ^Y2>(OI|4OENvV z+KD}AkciE`m{i}B@=4bW^b&P-a($Z@s zLeclX9tve&)?BxX2}<^SlIr<$>%Oo2Fl)1+)8}B-Xr7N&{j_7*& zIgV<*T>Yf>tWVV-xhAe+@m%#l{bBRo6(6I~zj6+jyMrsX@|0*)bk)uw=|7%izZ!Jq z%9IZqCVr&5QXOZH!qu#WztA6#i?A8k06pJMoA;StoBQiEH7+f{Kli2~o)56?_10hh zWZL8pE@f7JR`##)(>U?<47lrhV#?I3n#%d&)KoOTO4KXEhH{@sErax^7+Hp!iY;O` zBy-Dn`Bl04Vr`kx&uBS8bgw`WTg32kqpj#zVfZUe6&2EKqP&xAU327<8M~T)fyK&8 zD0rb(VsZIz4cm8$0phE2!yzjYE5gc+z{{{4 zCfDfvXS>%W*MH>+H&^J>FU_>8UZPhvraa2k&aEqY9yN8O=lSbXr(E1siHDduVsE99 z*c_iB=9fgZZf7eRHmJ0g89FZf#i>f8n~`Iyv=lvWHCE_1iwQHa)1JN62v!M+qVG)D zkqH--@11GP`OU3yfPU*Fc|Vvb;%+l0$Qc(Ty3aIx#Z$LkG-;O=EPlQX7i4eNrq43I z^TNeapV^q=KDE zX?!7{JJr2D*0tDf>05}mhWN~s%W zc`c4d{k#LkCnH65E&Nx6*s>iH;Ie|nhtFWK$JgS4xXg4>+a9zeRfmv2xT&bqfFv<= zhtb7+im#Ay91wTyF#0va3siSO;q-#yNdw0IPy5r+TRWtQV>{5VX+qy=geBzp%R8UL zBWFH3dSjcQGRVC3o*g){@h<^gKDr&UALM=ACfw+{<+_6jrtpW5i_Keg!7AGe9sJMsO$Z_}mqc`3>N&}TIM*?!NB z$~LS0ekVM2ZTv2yf40~X>J?P4XHH>m*_1f((J7;is6Ao$iGPQBbrRD;y}H%5YVFlw YaDxoKgv2qTz)Qph8sVa}!0W#M1G~67k^lez diff --git a/package.json b/package.json index 95f2f46..c782b3b 100644 --- a/package.json +++ b/package.json @@ -16,6 +16,7 @@ "dependencies": { "@clerk/nextjs": "^5.1.5", "@clerk/themes": "^2.1.9", + "@clerk/types": "^4.6.1", "@hookform/resolvers": "^3.6.0", "@radix-ui/react-alert-dialog": "^1.0.5", "@radix-ui/react-dropdown-menu": "^2.0.6", diff --git a/src/app/settings/page.tsx b/src/app/settings/page.tsx index 3dba67c..ace6ec4 100644 --- a/src/app/settings/page.tsx +++ b/src/app/settings/page.tsx @@ -28,27 +28,20 @@ import { QueryClient, } from "@tanstack/react-query"; import { EyeIcon, EyeOffIcon } from "lucide-react"; +import type { UsersTableType } from "@/server/db/schema"; const queryClient = new QueryClient(); -function PaperlessURL({ - setActiveTab, -}: { +interface FormProps { setActiveTab: Dispatch>; -}) { - const { user, isLoaded } = useUser(); - const pathname = usePathname(); + userData: UsersTableType; +} + +function PaperlessURL({ setActiveTab, userData }: FormProps) { const [isAutofilled, setIsAutofilled] = useState(false); const formSchema = z.object({ URL: z.string(), }); - const { data: userData, isLoading } = useQuery({ - queryKey: ["userData"], - queryFn: async () => { - const data = await getUserData(); - return data; - }, - }); const form = useForm>({ resolver: zodResolver(formSchema), @@ -57,17 +50,11 @@ function PaperlessURL({ }, }); - if (!isLoaded || isLoading || !userData) { - return Loading...; - } else if (userData.paperlessURL && !isAutofilled) { + if (userData.paperlessURL && !isAutofilled) { form.setValue("URL", userData.paperlessURL); setIsAutofilled(true); } - if (!user) { - return redirect("/sign-in?redirect=" + pathname); - } - async function onSubmit(values: z.infer) { if (values.URL == "") { setActiveTab((prevTab) => prevTab + 2); // Skip api key form @@ -114,25 +101,12 @@ function PaperlessURL({ ); } -function PaperlessToken({ - setActiveTab, -}: { - setActiveTab: Dispatch>; -}) { - const { user, isLoaded } = useUser(); - const pathname = usePathname(); +function PaperlessToken({ setActiveTab, userData }: FormProps) { const [isAutofilled, setIsAutofilled] = useState(false); const [isHidden, setIsHidden] = useState(false); const formSchema = z.object({ token: z.string(), }); - const { data: userData, isLoading } = useQuery({ - queryKey: ["userData"], - queryFn: async () => { - const data = await getUserData(); - return data; - }, - }); const form = useForm>({ resolver: zodResolver(formSchema), defaultValues: { @@ -140,17 +114,11 @@ function PaperlessToken({ }, }); - if (!isLoaded || isLoading || !userData) { - return Loading...; - } else if (userData.paperlessToken && !isAutofilled) { + if (userData.paperlessToken && !isAutofilled) { form.setValue("token", userData.paperlessToken); setIsAutofilled(true); } - if (!user) { - return redirect("/sign-in?redirect=" + pathname); - } - async function onSubmit(values: z.infer) { setActiveTab((prevTab) => prevTab + 1); // Increment activeTab @@ -229,23 +197,55 @@ const ProgressIndicator: React.FC = ({ ); }; -export default function SettingsPage() { +export function Forms() { const [activeTab, setActiveTab] = useState(0); + const { user: clerkUser, isLoaded } = useUser(); + const pathname = usePathname(); + + const { data: userData, isLoading } = useQuery({ + queryKey: ["userData"], + queryFn: async () => { + const data = await getUserData(); + return data; + }, + }); + + if (!userData || isLoading || !isLoaded) { + return Loading...; + } else if (!clerkUser) { + return redirect("/sign-in?redirect=" + pathname); + } const formElements = [ - , - , + , + , ]; return ( <> - - {formElements[activeTab]} - + {formElements[activeTab]} + + ); +} + +export default function SettingsPage() { + return ( + <> + + + );