From 4fd99b44c5449cafd521b78c1e6e57aaefab232c Mon Sep 17 00:00:00 2001 From: Charles Zhao Date: Wed, 25 Oct 2023 20:30:35 +0800 Subject: [PATCH] feat(console,phrases): add organization creation guide (part 1) --- .../icons/organization-feature-dark.svg | 15 +++++ .../src/assets/icons/organization-feature.svg | 15 +++++ .../assets/icons/permission-feature-dark.svg | 44 ++++++++++++++ .../src/assets/icons/permission-feature.svg | 44 ++++++++++++++ .../src/assets/icons/rbac-feature-dark.svg | 26 ++++++++ .../console/src/assets/icons/rbac-feature.svg | 26 ++++++++ .../assets/images/organization-workflow.webp | Bin 0 -> 34090 bytes .../components/ActionBar/index.module.scss | 1 + .../src/containers/ConsoleContent/index.tsx | 2 + .../Guide/Step1/index.module.scss | 36 +++++++++++ .../pages/Organizations/Guide/Step1/index.tsx | 44 ++++++++++++++ .../Organizations/Guide/index.module.scss | 16 +++++ .../src/pages/Organizations/Guide/index.tsx | 57 ++++++++++++++++++ .../admin-console/organizations.ts | 45 ++++++++++++++ .../admin-console/organizations.ts | 25 ++++++++ .../admin-console/organizations.ts | 45 ++++++++++++++ .../admin-console/organizations.ts | 45 ++++++++++++++ .../admin-console/organizations.ts | 45 ++++++++++++++ .../admin-console/organizations.ts | 45 ++++++++++++++ .../admin-console/organizations.ts | 45 ++++++++++++++ .../admin-console/organizations.ts | 45 ++++++++++++++ .../admin-console/organizations.ts | 45 ++++++++++++++ .../admin-console/organizations.ts | 45 ++++++++++++++ .../admin-console/organizations.ts | 45 ++++++++++++++ .../admin-console/organizations.ts | 45 ++++++++++++++ .../admin-console/organizations.ts | 45 ++++++++++++++ .../admin-console/organizations.ts | 45 ++++++++++++++ .../admin-console/organizations.ts | 45 ++++++++++++++ 28 files changed, 981 insertions(+) create mode 100644 packages/console/src/assets/icons/organization-feature-dark.svg create mode 100644 packages/console/src/assets/icons/organization-feature.svg create mode 100644 packages/console/src/assets/icons/permission-feature-dark.svg create mode 100644 packages/console/src/assets/icons/permission-feature.svg create mode 100644 packages/console/src/assets/icons/rbac-feature-dark.svg create mode 100644 packages/console/src/assets/icons/rbac-feature.svg create mode 100644 packages/console/src/assets/images/organization-workflow.webp create mode 100644 packages/console/src/pages/Organizations/Guide/Step1/index.module.scss create mode 100644 packages/console/src/pages/Organizations/Guide/Step1/index.tsx create mode 100644 packages/console/src/pages/Organizations/Guide/index.module.scss create mode 100644 packages/console/src/pages/Organizations/Guide/index.tsx diff --git a/packages/console/src/assets/icons/organization-feature-dark.svg b/packages/console/src/assets/icons/organization-feature-dark.svg new file mode 100644 index 000000000..f3f1abbc2 --- /dev/null +++ b/packages/console/src/assets/icons/organization-feature-dark.svg @@ -0,0 +1,15 @@ + + + + + + + + + + + + + + + diff --git a/packages/console/src/assets/icons/organization-feature.svg b/packages/console/src/assets/icons/organization-feature.svg new file mode 100644 index 000000000..9fe3393c4 --- /dev/null +++ b/packages/console/src/assets/icons/organization-feature.svg @@ -0,0 +1,15 @@ + + + + + + + + + + + + + + + diff --git a/packages/console/src/assets/icons/permission-feature-dark.svg b/packages/console/src/assets/icons/permission-feature-dark.svg new file mode 100644 index 000000000..ff0005a13 --- /dev/null +++ b/packages/console/src/assets/icons/permission-feature-dark.svg @@ -0,0 +1,44 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/packages/console/src/assets/icons/permission-feature.svg b/packages/console/src/assets/icons/permission-feature.svg new file mode 100644 index 000000000..ab001c524 --- /dev/null +++ b/packages/console/src/assets/icons/permission-feature.svg @@ -0,0 +1,44 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/packages/console/src/assets/icons/rbac-feature-dark.svg b/packages/console/src/assets/icons/rbac-feature-dark.svg new file mode 100644 index 000000000..7e1f68e51 --- /dev/null +++ b/packages/console/src/assets/icons/rbac-feature-dark.svg @@ -0,0 +1,26 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/packages/console/src/assets/icons/rbac-feature.svg b/packages/console/src/assets/icons/rbac-feature.svg new file mode 100644 index 000000000..a32c0bb91 --- /dev/null +++ b/packages/console/src/assets/icons/rbac-feature.svg @@ -0,0 +1,26 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/packages/console/src/assets/images/organization-workflow.webp b/packages/console/src/assets/images/organization-workflow.webp new file mode 100644 index 0000000000000000000000000000000000000000..5ab89a1dd779c7029b7b17c24f6087e11eca7beb GIT binary patch literal 34090 zcmb@sV|ZrWvIQF3wr$%sJGRkL$F@2~$2L11+qR94Z9BQ?{&2p%&))akANPHdXRUWG zyftf9jWMd$Qj!!CBMJflP!knWP*vbihXMcqK=}B-1_f9J0T7f?kg)jp1_*zV{T>>s zUud1iMB!6Q%5dr=^3MFS&;R~7;q!K#_5T0I?)xRL9>9kU1aW}?0F&v!8Guwbplcv} zu@adwr1@mIIgDSECy^k{Y+fKS3m?|rc#_^H?<0WiEFeJNCXS~KGNa)cKgQu>T{28etyh9_@H{@ zv&(<}o_tIGNWTIT<8A^e*tW{#N!vzw^EbewB5sclh4%ChxiS zw$in7`F`|n!3W5n^=|jx^2Ytjf5tz9e*6CHv-IBjx_b})#QtRa+Hvd+)RF#f`|Gkg z`SYyzj}MYho4@n9`r0ven~_Vo&28k*s+M_n_x}I?hoscJx<0vBG8BP`Ibkpls2W&I zkjs`|eG*wRE}`_t2-zyfq}Zp!L$F^wI%uve(?) zij-C6U?hV?ruKaaPyCk|k4R3lL0fza%>v{mAU6hS10SR|wv>v}xg+H^0&Sd!>42@WC>cP%XKy>o(&b0+@TTYbjgt9-goktE&L> zqn9W8<+2cE31-r8=V<$qNUotGPX(0lLA7OP@W7wF#QCTy-YCEz_vjFXuj+6CKo%_& zC4%LPIZWnHI`C-o`3jd`09FE)M?~<^%JqkFU%w)PuR9$>dt&U)FHfsl z1}o>}Mv-0ZQTII@tPg|(<18n)0O&({0(I|{AS=hiqGfzG z+5wb6c*pW3_A>;{Ic2RJBZ#ehTi%*_?I(uRT$M$IagK{0bu?8DJ$cR^*||FPQV34X zXzU)o$FiPfOGTDj^?|+vI1QR?c&!L!)CT%o<1Qz+T_HGJu3}f|S@WewJd$ zDpH+Lh>-!@f$A9;Ij~%;L%(ZRf)*q!1r99jONnP}lV@Kr(p?k9N`B-RdTT?BnCIwG z0Wp&=?nW(KsK#gPHh<-6AZG!&LC7UQZej${$e&Y#U5EsXDb&5PMSNqXz@W5>f@MtE zDB*+wbLTyowC(#7f<^{@+$hG-NYH{Yq~V=Nqd?FT@a*C+Y!Rq1zi#t88GJKhkgI`e zzIYwOu6ZeZU;1NIO?7#)L5`Au+~~0F*NKJ^exK+sl40l(+ow`#-%R2tp%42-VEqtRbry^1Qx`UhCs)PZO;3+MhK z3s>7;oH0+c6?nv87FFIolOWt@96tY88|*ei zEcagG_=9Z(FxEfAgD(!j))uIwIz*{sitH*a!;o z(ib>xIr0kQ3QP9`(5w;+HE1Q7TmGS_-1%A{U7|vJI&mq~XV)O3m)!L5UGK(d zB~`s{n(v$*@_l@l`bNuHu*>AGeai!m<55U}e3O0#`FLDH2pUaQmC1ENW{tF=!`+gX zXVRuz6<8mr{dd@vL6Q$NB#^Pu(5aODV5zBlA%*q{NYv0S*f=4g_RTZUTC0<8OT8G$ z>9qvn6_p#%ZPz#VUp;NG55$1ibeL^VB-e5_=v;Q%@k0zvtA&)=jmk(8KJ!Fi?;2iF z=-THh^B?;%h%w{~jDte^dvO7g=32f-MGf9z8K9fikhxf

t86vW6Jkb73Uuy@ zz+?cwww2^IS41-zm2+w!Kk?D|?qa5D?JP6lA>V>5tLQJaTmQ;@X92PTjyG^Q;d1oq zVp#!aQ5WdA;sb|6=&kr7lo;fyTVVG|mi|`m4WO+b-I*!ubtgL0{z0r`^oh44)gv;i zrPX$Yw_SPUxO70AmJ~ZKLS{OEpCb_f7|QNmkXf0F9td!6UvqDhiALCO+jgi6y5x^0 zd|xVK?Xyuz`hbQ-JK#(L9|#gVIUZy^xezfd<0tQYjAA@ouI`a64%C!-S;A2^LdWyK zT>nV64`t+W{H679(RW1{P|!f&&V1t1TcjqpBAhzDHGC-$jEie*| zi@Uk{zG>^Cy-*s#dla=9iUv)F+Bz1x72W!oP|kkfS+~%|>QyY64~fpOe}pn3Be$QT z*mo`ut5_8{i-b9^1d1Fr3E&COr_rlv1>7ViI6v&3Zt}Na)7oVNWq&qM)`ri4_CfqD z($Ys>?XdG;XJU>{1r;~!X|$|=l3HW<(1Vl=E$NzsyDHniH@ZmlyB;-_->#TK@BWm! zMD`A^(co^~5Qa(G z@J%?V$fkK1Z9eM42MmL1zp&F%?f2zbP#C?g6~H$`v>c%r5wC5Ix_=5(!X~PDpm&= z>~A(xjJZhfBXPy4Y7=glA)Rfn%t#$g*dlxVNXhkY{C{xAhXVA?2xBBf2&UTzYoiu#9^9b6sg=A!v^!pAX}EMQfa)ngn& zN1x{9)LL>fB5sDRKq_qrkRbMyf$PoVxk4%ey1Z8!wQ_L6305(OZfRJ?{mtD3$hDlG z)t=n`h?gf`yFc;c4{|taWcW)t|4CnJyvOthta=}u#eFlGQZ}`INFICy>PpqTvEBO1 z&WkTU;dsKmYPpdlk+*UJ=aBw@ceW5iNg~f*8cU(kmhex_)(5F>>Zd1m%x)h!40W4cU%F6Fbs@*`%)6`m**ar9eRgme~tVs#W zV8Dem^teM&Tm;#+Kld zJUGaL?Icp8?Pl>=-Z@v-Q0I%ncZ;mw1niccqV!RN%o~5-k91Jr^1@_{Jp7A{zuIs= z8#Q=|{}TB~pHx(UXFlKPqwi{@;Y zUzOdre9~>2^v0gAI4e5>K*s6dBW$?4TIrnM&G;O1;c35~TxEa2LC_~m4dD%IoYcPGhfgcn1L|Y2;y>!12w{p@3)6?mZC34HeQMx5cH&Vo` z-15u~tPTd-ajc2C>jDc|(|VSo@Fs~!fQM|BJPkX`JPizVc&dz@$vL0T#w+XaHu3CQ z);DG%_0uTr#FDF@lS_IYv&yr6gxwyc*Q=r13RUhSu|24eyc4}g{3XVaGA9JOf+lLC zed1;UYR7l1=u|M@3z2$ZxVxR+9};2Xt8M|S-S-x|GXE$kKkCm-(?=KP#jE~D5Ba?p zV#r|b6?^e>`;%(WsLi2n0MtIZEk}ct1w(eRb<<=Rtv|1DtTQ1jdM^QU+Va5` z=tbaSXB?;nm7lOgAc@q^bZ15ULJAYV?`lUIXo>Bao7%a{VG2B+ zH6no#LC{`TIlh#93e?e~ku8om>sO)b9K=DGzs1>R<%1T`|5t-REtE)( zfgzUUPZ&vyEVd|&2)o>5;5TXClS9u^sI) zoDs0~CfEL#bjs|jcnbn*-rfB@K+Y81zhH>N4|zzd8WI#!3(pJZ@+TZ0e8?P*@<+an zx9e^_&%quWczFR+e_^RRZ(>b-4h&J*kNL+KJ*6_ejbld6Jw+Af7fd z(QkhGrS^@EU?8j*&>IG%nB<+_5861JqQhx?cA`9sHMM1v~wBlG+f^KYAe`^hE2HaQJGa>(@zw*(<_zlHr zVcS(-P8y0nYJflcK5luxR1&i+DZKQc&k;WA$iP1jwrkCt>vvBnbX$H^GZ12AfJFQo zmOpwErIUZK?5|n;iC!rkq^z4lQJ{c9NpC`3$9^3SHv-$tQeCjDzW==Tw_>q$qy zf4|B9FwI}TSODDy_45s7lCa!~pM9d2LK*Xatofg!@^1q_iknc*XQphurdELrgAgE4 zI-d(@E$T8!8tr(r}p$; zmEOP3?SGq9bs4(~8o`gh3L4(Y%5zd4E>S#r_3fSB4^c1^y|Q9E+LN6ft$08wtjbE{ zM$~1p7^P$6gytVa@V{^Q=WM*N;NX;vkUhvP{6l35jQn>OLT>=iv)lx}jtryd0!^+Ch(C^=8h7g(pFv2nyZ%-Nz}*F=azaxC83=FUXaCAR$gjDGRMN777jIDGWLezh5% z=*CQ?&hjnB-z9wqe>KbIjemEYn5yzCihlJ9{vzmqtczjDCU5mew{Dm$bb^ZWjs4;& zFLaL&Kaz&SCgKOXv7Eq(MuWDK4)%kW9A%5E*MD1+J_LRJcxDInm7@n8dB@orqPNZ_ zY-=&hd7@u6@!ulkpYAC|#fk1_nYPtXUpeG3QRxeP>b6hsIHA9*K#zit6A!3OT92Wn z;{V1Gsd@^)j~Myz69mjA=Y*WlCy6BhF~j;H>Son;xb z5E!TDh?H%Xr?~#($~?>a%ZDdQqQo5XhK7tX4 z$)QL$kTBj$P$0!6ZK4$s@jj`-KO^A5uFTN+yB+qwVc_4r8;5kd>&{tU@PD1pr83L6 zi`Xs4#;bLR5ry<6;YCT&o}$yyxw$|JpbOhCZ|%eVe;_FW}jSAdInNN`n!? ztEw#-;AS6tR!0x)ufRs2%z}clUMij(v1WoL`l?jp@wo2gZ$R5_(f=dISNpA?X@wjF zaWg~94Msi(^_z)~hmSeaU;^TQ%$jlziA?VwXNLdM1_CK2^ZxTG#9xH;yPMVEU=@h> zH%+FkItCvogkvR{VHfa0hG}NZpDGB0sWVdm-&he!v^DTGiQPBZ%hU~ z*~E=(EsV>@fb*)w|ARb85n)byj;qpLL5~wtZoR;}-OI-^LfGDO+AWokz%TKo3rYV$ zwmb&e(qTk$ZYX)QdjBVh_>aNyjl^AhQ~-D&cd-AyLPiIS^SVurL3BhYDRUc4N($$2 z4lZsHlfsn|i`U<#UK|Nt%%~p>vZK_QDh>Q&WCAj4J>3Q7M@Hq^Nj5tN2iPUKg~9(T zdNkV<`lZ~l8>`cYG`L#VJUpB|Co5b5lk?t@MU0i@vIp{ znBXGZr%`1-bKITr>j0CDx?J1i;n_;)-v^FLt3SE3IJr1oI*JiVju=4WT`pPh8?ll; z<&xMqKh+OGuQ#8Y2y=OAcVpIy_Q6-XIJc%vDoo>Cs**&D%;wYXgA09~)(rrf(^0rT zNDqIGCjwa{uy86-+IdNC-D^{2pF#(+d*u?z31JOX|8g>|WC>1p=nIGSo%etY93}_mVi02!Pz(Aee1-pjsZZ3+aVD zYtn||6OXCuWy+HK1@qWI3lZH{3Kk+NCzl`jbb=B~uP(#yJdIjHwnh;XxP+H=Qbrok za5z<{N@u}$*w*4Hh?u+MOWP4&)wKJ!4{8j)xbl^lf6?>6F+C{egk2%+pX2i=&_I?> zBPMzV7tt_bzNVKnwqoa!g}?1~5Ncap{CYY^y7mR_PC&c?GYQxbSv z^iwzM*)<}Wl2+}*rWuFAecAD}40bLX$JIZ-*6nvZ1q`;Y7tY#MvU-vq}Rx6U#qevQNx17v%sDcjud3t#Ih&#=1ah?Qg z`dX&<9X2!u`P7aRF`q*5rJ|ZmU>yq%6zHLiNs|Y>T+f}Q>&@{Qf7X!Ju|5eNhp+-{ zN>@%15mqu0j~TUBeUH2ScnJ0aQx~cZ5OnheKuiR5JR6gtu@C?V2Etp&Dp>`$QiA7o zOqD^#pFHC1nm3q@G+R#_B@ByP;)t!h3^a#SjyjDBof8iQX)T>&oYvTG5T@W(!uPIY zNdGXpqg(`2wW>%Qu(z_nsJsOo1&7k*ZVmW^4=w^A_tVf*jb@ju+;>uWCH4yoz<%49 zBu*N6+Il@}%*tSZZFxZA9q>u!Rm-aSWA!y z%WdIeEDg=XWz&QAKbL?Db8DQC;?yUJS8c=b=ey0&2-p9hmPE2r?ZA!?uJ(QTY$+Jv zlQ(|XwJN!ArdnMnybipYJblG8wuOp*$iw;#e8qk29c?g!0@x{84tK4`e^jQ;ERVzD zZ4$BMbuPPvxNTRcM*Y+pbe1-)ood{txZTlwDU>`5@>zQ46xpFLl7F9N&iZI(EGhCR ztrCr)o3xdon_(? zloh6S2 ziafoJfOe%ONw%U5%sWBR*W0iD$JQF3Gub9DO|(3Hl{07G#@(E`$Vqz!1Rsb%C15Nq zaQ&kNrHd~==h>>QvokI|dp?Uo?|>J1RP;>Fd5mnse1SLq^tCx6b`96Od7btq<@Ra+ z8Qi_#s9UBUuGSCn2LUi(U?%Wnk?*dOd<3qH;nr8W{l24D%ds39;E-LEl zMUi)o-LXEysJin@bV9>7FM?S4wSo;Lb8ahZ7WhL*k1frI7gbzmQ>eI5Y9ea&_wKwyG^l#AcAzT(LVcP7sWAnrcu}+X`il zBnln(`ij{1H-rn_=|w$yV(9Uz`!g3VKhSdA zV|k7FOd=gTMW4_{K>RGVa`07t>{b@Y0~WfdGwGr#!rVJ#`;{VVZCz=H!vrK5!RJCJ z7K6R?ydT3|wxH*p+i2p*j;TSH__a%)bb5e43q`^C0$cf6ykG~|Z}Gawc6d+T(l{_U zRf%ZQg^?Z5DA1pq%>Bodq=I{a|5@Cot@3C6TWdvlJE2O^YzHhH=vlcvB3IbG}8_P># z#Rz++tmqX_D`6z!9TLpg8j|Fm=&qEcM7NJ+dxr3NVgkwyEX@N9{3pWRQhiPZaqna0IHRn(a1Q0}6fJ^p3a% zu`Ck<5cgV7QtCYG{Oe~(dt4*}gq)R-unxW422@Wnn{FnFjE+sGeXk%7!H4rx0mN&` zkZ!8Y$uF*?NwZ1k*BHCUM6K+i^j_OjcinJ01`>9RByy(=C`G5xpIns9=}8yc=GWPm z+s7$I=3FUbcx#zj0az@9@x< z4ws(!ei7hs_*o8)IPlaUxN8B8DqZt_`@|n!5GdQFN_bjM)b&7D#Z2U#4d=L>B4uMC zM9){0K;+hRwEC);Xd%SOB_QZ7MRfhD0=A&Ld3~mwRb7YcYTNd4olh5bLaq{-fN2rX z3_cQ?YQhJ@`6iQD)b}E@ysk@Am$PHXLX9%u-nMm>Ms74*+M(7C>9d%yz@)z!c~Rom zAJJ85uEiwErqS$AaQTz4B!0&q zdr8XOaz|JQl(Z=6@cPX_y9F!gNyJUiVmyGWL550>hI8-W&@<|G#cCp(^FReqL`nr@ zt9vLkG&B|-zi323`GTdV`Q>a0B53IhK8VpvMg|Oym_P*xEZ!Ou^{b#9Y>Ev9S+nE) zGT#OPp@6h_$92Fb?-(3veA8=ji_fUAMDSu+bQ2x#E7Y~P8sPn5tWD#{4)N^8lDnpX zMHlC%!mdA-=;%-dE0+;mfw0tlM~Pt*B6~pUvFZuJ!;7ssl1$}XoJOjsyHwFAITIJ& zbH5;1do9Bp=#^wFp>%;gR4H|v;A;m=hoE|S!`bHA)psM=*V~-~Sp!5GKLMVN0zeLi zG8S{IaRnq1OSno6C#z^hd16Vh8A_Ciy%miRf-?DW6!gfaF`z^P+Mm4vWS_rj^>;qx z!JZib0N)X-+8os)q5Eu%*9u~qYW=8zOvcFAJVyEgP)9x?;~M1N3jD>E`zM7t6V&I3 zb&@S@h)(z}MVCU(f|#rut-|~ra(%MV`Mch*h}aAghS9_Gib!W7v6pK141CqlYzEQI z8%DA#mot!aI1BQ{)S8{4Hfj9Zvj%v_Ob~yqlx`+J$p?SCP`QCSkX4wP0KbwE7xOiCqf~QP(Dyy{nA3Gvky53w{9h+(YeU#x&bu9UBqlS znRym-{fojb{0aY1G57Al0Rg%Ie6yE+O9oHP>6|Fzkm?r1yNN=W)bZx{g^>o;a-zp% z;`lN11;uparjYH`#eOHN!Oj*x# zcZph+sHx)Tcy&`C%99Mqb5L{|y1EP^!+}*%n=FB>2n}t9wTGgzb_^6@Sbi#c!1qn7 z7-UZ*fO85ZC$ls=N=41<4D10|&7FYg;xRlfViEn|x0UG9#}LZf}b>qRtU zfZNDtS9)j5PSvi@VLY=}0|e`Z33XkMM9I9){Y*{I`hF|ov+P17;xQ$KSBV> z=sZxFGiM0^4UVP(2DQubqzRP3UUyETjp_Wwzq}5C=Rnv(P>|O@wGolD66qlaDr?*> zhP6l{E#%_@ROm!@@l9uRL~`ntBSAfDk9}eIu_;cf-Uj&)*YW1@)CytZo4Ir#3}t#h zd6`}UHl1<=J`&^Idwd z=T2ecXJ0gyKMTnG065TWtv#n1w6|XZ!kyF{Gqp z;&^Dt7Qcnl#cG6Sz1{qp9ilgmUnyl$uOfyEIwjY6&vdh<&ClsOZ?+ZdORx&r{KAWeAyah|kN9)x3%ob_;g zrI`o(D>q6tq1yorrW*U~a#&^Q1tcPIqC3HtDAa94q#Xn_ce9CJd#{Tr*xe3Zgq7VWPpHcq=@qaop@|U3i2PMu4XdO> z^2LqHOP<`zpI-q$)mNEE)0{XY@}bjr+&*F0rVzKiJ8~T6R8GN3b?&_`+uY;6_37MF zFhVAEp?#0%f}xMuk(rs9i!M?Z+x!b4fdjlOQ>WoVP5vSlTMSG)6`XBya_Tp|pDXcN z2X0|HdtNM&))sxOHi@HFvPg!kWD86&GCB_-2NXCf*Y_<=pBn3hG&tC=$(20TVOzz( z(QsinF@5B-ok$tiUbRaFW{_MLx8Oo(pK{Jb9ZjKT4)n=RvTEG(J~^Hiu&|P_r=?t* zzK5fyZ-|v~Hb^^tvb34@-fvhzr}Z*Y{^2NWM~(61cEq%$kXfH2DA3zlv1S6eJ#_mA<1S+%T%wRgnSvWX!o;A zsXUubQFKU=lah@V`9iCGhZJA6hd`lJqf{3%IThD*ta_cDzqlWQ0dH6&a0UA0B2L4( z(t4=eBUZ&3QEn&M$c{mEYJWbhwT-jWb{J)$gyG9pTHPb-yCu3%79N`PK1j-vt&KR{ zGG^5!M1Da9%hQO({?-qX(SH*Nu)+~n-XD`E%EaU%xk%8JfWKz{1Y49lEZ${^M8 z)o@4*kOWLNU>}<7(^APTI(}P4o0K7YRfx4p_{ZyrcW0_QLmNt#r>l>hfXD=mFgxN& zv+=T6gV}?_tUBaYF1`)5GUFvaQ}KAQ0RU~){w7q!HzL!Gk5lJaxDQ9f!;RmN4E1Z0 ze8KW8bai;nIFrGKq`Q1S{eUkw)RcX!0X9P$9s>Yi*@J25udLv7@*q;_>V!m~&LqSA zHpN@63q)C|HO{tWLHs0xZU6LO&72PGIUTR){N{O^ecqz@mH#og?s;LCN42D=$<>9! z>It~{MEMK&WEq)Fpu2-&;}=Y4=Kwrf+otPxFsr6d9{bgmfNf6QPHPv5u!tmm(M%7~ z>86^lHcZlp!@7r2Nip1*#Jz&L8b=zXoR{{ z!0f|LZq_(1YC!^NE5>|id=8`@MZ*GuJs@QQXb^PsnQ4&MB!KloJ`Rg#k&fls`M9DX z9*}S-zKtp#7~ezE2gxBi#9h0w`DWOO4NUC5c?%}yBtKGrd&HjBACa~h*JJ_1drjtu zd<8?MysjQl1<`5+0HDrWrxV1HiSkx#`o0xQitN>m0k{LwG{je*6j=#BW{J&F;a?d4 z&)pxeMB$8+Z=n=wpMwE?{RLvO0UA@o-jz>6ys+mRV~7Toh497a_5kU|C*qa($jgNDH>;xTdftfE<2l;X|g%*4;yaS!HWy5Z>OKO?$dnjUQz%|vi?!YUx*^onshwWNw{jdtf* zcFfIF^Ir}d4yVkLg#a_x=4+WncDU?KISykTe*5T#eJ)g3kjbe?5!PV}{?)|#Yq-ex zVEvjf3<{E1-#~U`r1ZHiHMba_P)R_WRxu`Y-cW=Vvkmr}%ZdSfPYyy=oe!$KYzB4x zGu)|J^hoW3bgkf9kxry7CDua4RXWp%Ne}95GBC7&gav#+zUtx1gA7W}K#$~0s}(e} zNbvZ5!p`7KrU%sAh&0`~!>(g6#7Czb&=yX$dWhe^PDl%VB;$IroBlc(DZWlr#dQxI ztkDwIF1>zCumUSUOE5*Ei#H5+k+c#v>jwYiq5Oz0T$Etrn*EW{j-f#7p^Gry{^(opO*W2 z+5lU#YB#F5tmF4Us;JaMEeI7{*69p=vT_)brf<0MJvaWaN>qzEKv!hpu}yRC+7;0S zqH(#6!X8(FQFJKG=geiLtBD#6q=_1ZdD~lz(=l#t09&fDbUhOM&v|0NR2-7PS!X5c z$8HZrT+1=Bc(Ucj$a&l}@PprMGDyoC2OE*Tf{t7OL$k>TA@VbdT=4cw^=q3EQCC<{ z1d6k_GR{M!eo=}FN}B=5dbwYP&;-t# zc$!W~+jU)iNwmi~tE_4I-pc!K;yYEzDKam|>8PXYaz|XDd%{Z50B0>n3v}7x&+#O} z`?B4&%38GZKn4cAW`RlviW6=C<{63d0H*eN0;cj>THyHtGp>11I?FD7yPG>mN`RQh zTJ{8k&tL*%H4B9nEUZ+6t;skJ0kj>|sjH8ffhMWnc;w7hQyyfk2tPS4NG%E#A66t( z1}VpTr8vz4ffP!2Y^<{*M~HBW5Ar1_0NjO z?iNs#1b392G_3lv4Ekr za%g}v+rCb(O8?WoDE`M|lhzRx0UZ=+X;Joy;RuIv`;5D7LdQgvF+jG9elMy9Uec5m z<}e+lH&ph1?-t$I#;pMr2BcY$WN_@)n*cu&z zu{R>r01k8W3Z}@ItXqUD#t{!+;v|u|_0%%2Cb;rvho) zSkLCFFv3YghYWhRO3Csd8PKG+Twa*SZKY%XS!pll&8hWsVnw>}xZx4%cuppua-b6b z-q_J2+UsZL(aE33s5Wt=QqZ_6e_ zfB-kEx2TjDabMT%+xc{}EmlnfF`7&CHll9*se z{Y34G8dy)zQJMhBT~9L&sXeP(&ieJ+bLkRsaWT*?iK&o!YhwQsmU)xWmGlw8#P?9)Pg(&0n8dY;Xh$yvgPyAtH;WIOB5(MaSQqs)t|+^ zEp)QXIpcUk+N4gJhulwoH@X}N&MvPY&gjSi>1!=4yweRbZGu^Fr%r%J=Zrha1018W zib)D`UH6jgGF|$lzsQ*mWK>!{-ItbKuD4vsR`~*E`)G5puK%$<_c}*MM2>>YF zydkN~JQ3xWbZo1T4k)cVoSXozQSvgE%g5r9lE#ptUg$Y!A<#?sl9%CZ&S@sXcl!74 z0r#E@UtN`6w9?JSs1o!w;LT+uyVF|-e0~)142I|xN~STo$3rINiQEfRa1s9;TPmP7 z<_CXQUu)SZd*chZpE9nqT&jr-pt}aV;Ym8v&AuJE<&rC5y&z?>>^9%T6(oh=63RdA zGV>BnuW^9O&WDZP1C;ec#eqlXe?4ch4*qV$!|idyM|x9GGuV~97iyTjo{tk;BL&`j zRO)kn+wI@D>)5vm`W1;Z4C*Q{PPERLFvH)h zWRXl{0vE>C$bJ_eQh|80F)6xK|A-}UTYi(~>7w!&4%3go7*&aH&A#|sxbE#ab zdk7}47i~kT+|-z`&ga}r!f5wgD}WKMMoy37>fCrWD2ZTpb{30E>cs^Cj%ng}qpj>5Bo1HStGSJZU%m z6!BisBRlY2ND`m~rubpmc2MefvTWK&0f@v>^OYy?yeH=wJ%HTETI!5=K!_0X`<`9`YTA(!&RN#c z`UgLPtrUDGe>zgN<%z`iw2_kaKS~x!;qR8%yh0z3gc7-CGF!f?A^dE~9^>pBni*`} z7OF?Nva6O!r0=|1)z143ueNwxueg1%eIGbc=fL1+Af7ejL~ zijKv&ELz+=#^NbxKvvD|+DO0m;xQ@Y0Vxh7k{-NXdivOZyX3;nlbUe^$FZ`B>-H}t z=wu_@yY8b(=>Th!SyhB?-Cbw``+UuUIf^#qU`*E|^Yd&3NC`m%GzxKqfI#2^k1%(= zzhDaJphZ>AkY5TBc;9lnr&(f;Stg`1>M9LN?JPEv^?s@b=4gZL**LRGd6@)B&JxZf zxRE;-ZiQXY$h-`C~eubk6LTNSsr#*(z06t&tAQ(0X}NvQ8WrKfprv_VG|bbi_tEIy0CMR@%L!04GAU ze{KB5`$PcR-QO~eDur{=Wtj?|+B|6J`_!&9-)iDKtgXY3@Ud@Cxp~_-bm1@epauL} zz;e*HS3j?m@mo{soT~~~)K)Ovd?>FAq!yOjT_1G`k(?9;c^@$wS;znjoL27MnKSGn zzRD?=x3V3uq98A9(kernuGsm+Dr<;SXa|p(@#+N{vxy{Zio?u#5?e?3FxCsuZ7v9Hy!Jlh&FdZUc{Bot=w#<8n@{QIVpVjBbo;aWDpp-SwhFXNCj z)k0Kz4ylsC&=gDVX zSfF;;#2Ky!HkIE;r|s6j6CYyyNuo!cm#1EjmopBub4k#Z_r%Q(F9+9X6>vcZY5aH4 z1f?v6rS+Z@GbGs1k7?m^7^GpXC5;74!fu2@FeDZmTRJK(KJgx)N^Z_7|2fedM7d$a`yG!OEw+CDVmrqP zQ4d*z(lI3vHIE0G6AQc2skgE5FoQMv<_^pwJtwq;^MZ)g=`=YM@q$-JPKjqp^K%6I z(_llvM!N_rm~Z-SHt`NQBhbvl$T#KFpE!_~qcOYz`MFX+i8`2oxk+t7C=Je(&2Gn9 zSY9~tyX_s{IFS}vhVKAwx;4*B(dtXCJCBmD8#d~3SSJj%lmvCVrXAe|9Fk?QNFwP8 ze*i5>uwt6wR*d;0?IlH&1I9I12U&mh=9FAVUcPf8P3|1xshp@6LF&y=@jukhg3zF9 zas{J(CCwt+&CW+C27wdAR2X=Z6`ZwCpiuIwd1OBR`t3#^H5BOPnooFLLcHTmKYgBz zO7Y{J)OUC)X}}VcYI7dWOITd2QC3p2v1tudnxlf40b4Wr&JoHa?Nd4+RfAMxdX`@+?C(IB=`+Z4 z6DE4Y+7Bfc2q1FqRQGe-NUMrhzq-Zyc%F0(MUcY?oUDDSphq)-$;hjmKM#<&^?1Ow z&KzQ=M3&?OwnOGLvy3iYKYF2wNk*?*V3Y5#u$ zI6cS0B3y8@?ACxsYAhtgB5jb^l8UkAx5x=vr6Y+eOi-eyqguwoyVJ{cuJ2}@XD06m ze8qHIsbaJ2FRO%3m@_mMGKg(oeJz)BYQ^tNXQu{7iJG0s7+}%WxV2cv zOEN~xoZBZh$;FugHgkKK<~)I(=zhSMz1ZwQiP-@Pbs*X{vnfpXz+i`p@;vfU)$oexunn>vxRu*j5!k!sP=$P9XTo6o(M1H)RZCyC{~HiS=Y2(I(j4Sk9N^g{l<`Fe|+ zkgr$Lw86*Q*H=+9nl$1d0DH0c;#UH(jSup_ z8I($gPb!1o%F!dE1I??C2KGV_yn6|kYjjt~^|IiR$CpL&R;4zRTa9&>hfdd??c${5 zgRMD_b(AGJ=V37oKwyL{j%Q=Zx5Tz5r`u718b#?k@Dt$*F-h3P!Kkg@I>td}lOlDo0OWi&3ZOJDUQtgX1!_ManS|h9?+S;`zUdR#ZN>PE zG%v92{0GRt^4TA~Iz`R{>u@ugZTD7yLgb|OlG+&IDfz@OT7L?XPhX*z^X&RjXP;sj zVHA+xnpi3ljG*45?Ovo9xcCC=W2nVWNP1vnT@TKl#3VtwrH* zhTtDFSHYH8jB~p!pn8nph^0GJ{c6t-gjA&KUt0CdS7I4h4JfAJ`x>&#adUpE z;YqeW2|4g2)ng%trtQGZ?`-HswKNnTo{uX&A%;mmB>#B!Z+M)?qYQ zyF(GqPOON29cJd<2$l7Z>^t(*Cqy%CZyz4|Zq`C?G?9hb1bTBgy5JT@*46c(yAPbot6`|Eli}4FIwBSXKM!97U0&zp`f>!`$b%6ON zMu)<`T9{C_M%R!vcm#V2bBgJ?iaD|{+suQ3Z#IBSE3ujC;A;%SklY3#?Ug_r>I68< zm_?iN685zNA9D>ca?^4b8*)Y6Yc=sxw;05=J*FLNHKNuQZ~$EB_L`|Z^4>QkjaIwt z(m$bDJZSU?5J57|K?8Bx^Y?;s%$m7hx>Bp?*8e1D~p4KH%( zU34Knla)ryzl9edUPb@{WfZw8JwZZoCR2R)BGQhxDU_V8x*hY_Yt&U~C zG2aB7w9e~IaB_eLQN04qFQ@smZ3F6))x7FF~|S}OM+L(nVrjIg0Vs6C%7RGj~Bs++6bKDG{-o_e5eF%bU~o} zG7zy-_b$nd1^$RclFiyG43}1NkG1vcdi;6RI}AJsSWfqo2vVJv#R2a;bS9 zDPH$5KoC{H1r*Y&l3}dVyH8lX z3x?$gIYg%UcJgR`x_oK{v(Qa2iB5NDplUT$vSht72mk;r(z-YR044O^0npA1Tc9#Q z30%d28h-V=2(mOO_$J>CEDOggC)>b%O zxHcrunPtiEQiGSnXNnS%qIfk5zamNd6M?b?XHrvHPXNCFp_Ta1j2ls36EfP0;ay{6 z$}BZqs~G)U*Lcd2b3wZoaQYu>Xzc!p+LJp`xe`Z-QG$^o>TPBq;o=oSzg^Hk@2aX( z;hmEVltvr|g$+=C(BBD3T5aMd=M6LT-KPDamDnlfHV4TwsyjL#%M12?R3*s40#Gc9 z;;qlz+kt^O9)!o~c+hdgH2?FC-G^E&$Er&7j*DWk9;&@Jzx!;(??q_K2^eGQ) zU&b)R(6xk)BBYD`(?>7J#Mk_t=uCvX0CLpK%=2?B!8qmCtT4U~35DTwDpQX$*d;?Z zBOC+T68m+26XO`?BwPeGueqa-!7*yv2S7|+t^lqdC9VQp;}RglAq{MU>`r=7lo`gD z^J@yDmHdlr8n~CYhq9w`ZmH%x8XuGFk4;2LwxKn4eBcSX+$ zbN%gutle}80T@7!rAi6|*wc!G3j2%m#WTp&me>Hqqkeajn$<~2nTLfhD;X|9#<`U> za`o@34Gl%T_?3WTY@yolA*26Vl};NSzBqIWnK5nQJQhBt$T9c`*`1-|Q8m~EFSTD) zR@)uY)|y7;P<1^qq2&D2w<_}dfq)*dGWWGO-En}0m=SPPS#Dx!L;PT4A>%B701fH4 zuDwc#eE;as*kdD1>e?os{V>8^i1guq0)PMj00000snpSA@Sh-`KeXQyBv!@2gR5olGf{-%w7$j?AvW9$`znIVhF*J(lxv*+ftGj2|?t znzqggh@wPyW*#?!Cu+uWPk2Z&c3NmQvi#?1`e(bzp_G8Nj4gb)n>UVA2pPfp^rEn@ zz^69x<`0=um-Ql)g1LHYQ8m~nccW@@Y}K%f^5qvLR44?`#%|k^suTie<2P-|RSEK$ z(0iMt2yhDnjJmK|!?QEp`w~NUKd(dDsBD4|%KP%dc z;G;Zc`9&62zWdPklioq!BLW;wEgO>t9cJ!zGYkJ^iE&Gk#QQY0YKq>dUuB|=64NY6yMZFF|N`3 zG%U7rEBQsL3{$1!}CAXJ-(NCq}!*)nFn6H7sLOb7B41C_f+xpvSg%y>v5HPx|Ym#>;2K%ilq zEAMLl*b?>g0-K|@N+|NE(6EKn z5)Ol_OMoJEi`{Cy8SI)bk;T0JVt)zW%su!h0_;wUQno<)!AfJFpl6PGdyPDE%iL+> zo?hcm9P;-Xc;}b6)5SF(e>L7xW-y&ZwAtv4ClLRv(>zY5;US=ZFkb~2B~2#!qYHQC zbD9vU2#q(qd_u%FtLfoCqvcS{qwd@Sne}TZ#%4=1KnmNR9{2Lcyv#|N8=;tz@9(|=dqA9q`T4r)Y+!;% zYfC^>0Pa1ZcTy$Hivs}&&+~~A3=D2QoZfX>xni))WI%r>!ghPbPgimu1!w#kAzAoo zdy(eDN~RIQx+QQVN`UEn@xTzQXdkE!iZc79gpCz+K6&(ev2PCt&KK(z*3taKQNKwI$WCT~@XTAuu6$Q{# z72!KS+UIq+(?W_ac;!VgFXs7Z0x)HK#_RPApJ% z?Qzl8yx;+nKZI`j6VCoeky87J?BKS5yc}a!_2!4@j`w+DwkPR?=c}aP z&S|l!HUPEAlt~P@`nx{%83X|9IfYujlXwvGh6Fs}fdP`DlwM|1EXAeLbLt(hO!wRE ze+NH>itAp_S+aooBRaTP{Zn3!HvR&~oI`I(B(YA_NQTf#nnx^-4tuSIcm0b%@{plKhXdqDl zFH_>7S8A?{m|qYlwNI3n`k-RGnVy#xXuS@@0T7Bb0pMT3v%Bt4v_kzmE0AVi=)-Bj z{E&8@Oq%bVrpLH~PM${1Na!Dhb8qP=&(|-b4_P21hFBX%8#iTOG<^_Y37fGa<#x_u znWwBL72-xW*b*Tl%SA42i7sN7LhAdtOlA!?)x!I|08|wrqSqj~`N(ZERa0gMnaL9I zHm4r4<0#f~o);+m5vL9YToH&z(CZp<)HpuuDK$YBjNuTAdF03=tAt8kB1h+AipoR& zS{zL3g~ftV4`XyYlE+NNjPJA^_T#qYi`=^y{{^YhDJaLq#Jzx9+Z;Zzn|IQ0{UB>K z55+|!lePzw!OAUKINspSDKwznpg99lgnQ)YP~QUv`4;zUCZA8Pk-c=3Vt_nrvMO&M zNtVE>mV73R!BlRb+>eU`DE5{m#+l8o%%Gl#kI+}DUR3wk!kw1j4LOTyQof^GRk#Rh3Ae^ypbl>1*IF*E(WorwJp{K9NDsH}R^GveM~A zrM;SHVoF_?lXXe`0Tm(pT6dA{WAqZa9Ht__EmguWRoYXYlsF=vwOapA=YarvPq2>a zuUQ@#2)9#->jHgJIT0hnG3^@3WEnH^XxK4+Ij!|m&(nwUYge45oDCv%3)h$5!f(Sx z)A$p+%d85?{vd@ScJJX0_oE^eDYvRp0!%$%|Ebdg1b#7nM>R$hop-o*gapdwi>?-Os>=p*l>=pq0~w z6iy%(l>x&3!2k?gFZ5B;k}UNcXES$hwt(b5TBX*nANLfk4qp)qnNVw-g#X-!zp?+k zz8vcl&yKsI1IP$oxS7%eoU6j96MxGjiM+12h&*wB_7Ccb1aM?#4oE@%)xaPFzJTH!k|PgL|dkTjFXupeV(0bDJ7N19*=K8Yz_{oG_5pqG``a%5eZz?or= z?}xzO>GbtS(uu@mT+eZ}LK^n`iuga&aCigQf8Bt;fv%v+a8ipy#+c)lC{AP4 z2xv8wOmw7_r;_P9QeEzIeh-@V}fAWrkOQ@qiPebVyj!a<7f|uiEAUmazlbFPC?H zJp6LAD-ifY?;Cu{OI|;#@b2m|g5tGMx>AcG;<=B9LL@$sW$;OB?g1t@43VdeY~G^* zimZ=XEaVIgGFPag!D)$gqQGu0zV=yIS+1ZlfTjhBmn-`x!$&3l_1p`WwK@2wfI8aO zr)Ww!LMb#*)@;C}PtsE;e8Gt|(6LuC4O}*Q)P`#zxFAPmWQ%tnRFjW+P^{1`W$(Dk zuAAPwS$;bh3X3fb;={vuJfA44@Sqcy_CVY-BD>(&6h3LAITVkqZ=C1~?pNQE@1DXT zWyD(ysAL)WSCf_G5f9KuZImyti8aUYWVMr~&pb8i7`y2Ps5~@*B?<-&Pisu~0p~(w z9UMH0knEr`{waau7#@iw(O%;S#x;=0ep*MQLTurOu2cH_8*o!tU8lb>k!% z-_X+m1cLJ#)M~Sa-F5brs;BLergm#~gTz@y1w0V~HaO`hWIVmk(rugQ8xhVdz|@Lc zi+2YzgTsr;rJ)>)a{%(L2IbOW$xfl_Z4bd82NJIbUpy`bE$O}W5|(_0wND@A{_iNE zoB`0d0$d2*bV;Ute#fjAs+G15_T=?|h*lmlhOT5QZIOdmba=fC^*J9QqU(YZ-YS~c z$h~YqK(&S&2kKaRbH!2!WE>SvnOLW%#AcL5*y$7D)Ta>C$jpw8picjH9iMUiruK2t|bA0K;=_|gVf7e0r@_D}7h zRQq{GWys_vY;E9@H=cv!i009*u5t_hY8Lca!gq3bO|%4Jx=AP;TA(Vyt4`XEL(#Q= z)5%aYH+l6@V=GXWrF~^!r&t!KCn?u8H3|aF5xox!7E;{T?gE}g46;Bb^Hv&d1o=nVPiABt8S}9P}sLO>vjpNHg6U6clC=%%h@zX`Xs@8 zRER==u;Pa$ZooFmyiIE2WbHL{^EK5z^OFnf<&4N*OMcBH?x3amSkTYiRtSqSo(4#Q zas@_N(~D=~YIsTB^OFqL1MUYI9#nl-nUSRS$2+FTViMhvdsVC?&Ju!7+7bnNXyzWS zhNvs5L3|>pFUICp*nI*?V1hqK17VG{% z`kmOtH~hg?1IqgVwj>$Kdih89xB=7Dg<>sdO|39i;SE_qU|U?J`zbD8*M^YzCq5^6#Qw^#;)SuPq5QNQQ@L+g>OaZb`7O);RkMPw6SU>nusE zPUsI1LRx-g+3z}I?W@0(L=g$-uX=9XpqJr^)f8CENb$)n;B}j$&B4(SorX5Pz{lY`oV64%C%_B+CjI;>7BfIXC z*$9lEio&!(e-a8X{_>+B+X;|m5rFJ#v`pak!d64+;Y>IBfm!663i=cqCUYfPG2Yr- z)ZRXSr4!OQJR#h)!IT5sl$+cP&$1RaC?FGrmWUi8zBw!Va*U36Xv)F#=49MlTI8>A zHqaXOa^E{3K6^pX>g(ZaGsc2Yw^JWvvamUje&Oxj`xlRE-bayYb6Fiku6bVsI4|<- zS9eAyfm*G(6H}8MI-Y>&RJUqRzU!ceGY?{D+BkeSTf#X`svHH}w_NA6SLFlfuiK{W z9nJ}Ke0TH6?%Y=6rn(>o5b4j>Zh)>^1`%zqjTk#FiiAZHA2E6|IIF$`<`2az_+v}0 zDsu@OLVrHsvj}hT1FS#1K{wG7lRe-x{k#$8g}dOvJEDK1o3N{^2S} z&KJ9RrxboPL(uIyG$%9afTa3*`_O4YqY81Xfs9k`>3l^dQ{KR!1j83SAkh@$(`ek2 z)-k`CDtJhRA`wa)CrFW#n^dP^w9w6qP-VB5p{blo0n@>u$x9ut{1CLDP+N3_X0I(l zHr!ews}AL|@fI)sW|vZ#aP*b{=3=Wn;!Cr+*prd(VRPp-y$lEbr5M=?hN)82vnLrI{Hww{mI zpS|ipU-501wB!zrsYROth+n_nU;EKn#tSe`IUtdb^orOlm2OQY)W(ExZ{^$;7fC`Q z)tw`1{}Q6jp@o`Of0+23C)~dtP>DJ{HF2{FC@PfJSrNn+=XGS5IYPSB*>Dh;slt_w7M(qxCp=FMk4lFubTk z?flzM{7D%MdY&N+o9WzHtj-GFY*tBBHx+4+4Z@0Ium%{lf`y_D8+hYb`Ub8*Sz84L z4sU;suqBW#Y!WpDeH>9lv2D$bs`J7{+LTQ+VpGsVSF#B6?SPV`oKQYS%@KVuWT#yet%HnMi|-4J*tU6Mz+oUjcb>!$bkoYgC9wW)RXW z4dfqBR!4#~8zCNTwaSbZ<;a^y3FnDN={!YIO<;CK@*B6yE3Myqs5*i%c@6SM4a{re zh;&IWl~em9S&O7Ak@ca{mq%Z^b4k1WE!_IQ=^2d^dOKj}vW3^`W=muUR zr z;hpJ#Cbf*-R}nw#8{402@5p`yV0v6d)O={2W=dMo=tq5a+=f+{o-78~P!AuO7BX9! zq)HMm14F-!M%2lVOQ|n!c{ObSL2x5taT9{oQ!$O?T{zeD?eaM=A|H)}qrtXA(b5`l ztOH>mzL=#LB)sTb?^*;IoZA};4Nc;#wS?Ocm#Lkc+EhF+eW+;$VwhUR3xRh35pYfJ zX@tO>nYeW&(A|_wfuy<1Sl&P>XA9_kmVGSe56@(^gA>2t1qtiB1)gglx^Zdoz2*FE)(`cYWrmk541zGC?VDhXscioZ?^R5TL*?1E2 z9R1|N4^Z~n8*OM6H&z1T4MmnqPg@0`JR!-k0tFJ27|h=ROq6{b=B5DS_*-gadiEd! zpcl67scL=1{ZjiNo{j(pS%3flD1`h704V`^tkj8s00HXAuZ%v=-^$}Kp- zypl{()5~B8*C-++7}rk{J@_D5om74K_4{b86TZV6gqwkYa`n+nU)-9~;>9X?fIlTR z00005@g<|3G$;T)Q8ZPi7`XzHW=79O=`(H)iQ7t0L0kdfROR=`sc(j8=R#znZZg!A(LIkj%vr6OhsmSO= zR*mGgr?+n<9aHEY1mR9u^JfaU&8VIj`n~_UE2@J$w?joQCMD})x7s525mBgnET7M^ z4ug7(ORfg)F{dEmX)#N=6Un%$t|WiC^I&r;I{~cioyWQ6y;?3=hVkY8hz2-!DZu`A ziliE2<)pf-hjge=WetoHe$RNGjJ5{8r0TtlGF9cdDYiLy!KR_S1Ct&Ahq*1f+p29G zs&XA_Vl92SQUnmP)jj4=P@YfJujY*xZK_Q3;?8HH$G0n80^l88&hoY&svVllg6>w~ z=3d16ZoUdSlK6A5ja2KnyHk9cw5)VQaV4ikI`OcX(Dlms4UMsud=6<2nh*GiD#pUE zrw+=SyP_1v&|kcU&LAOQ***_`L7XmVUvqueGx@4@d4o+GQIIEHi+@;#EIBVv&a z&ca2~+)vYe?mnuDo35-O%#@0^NpgfWEjlG{;<(%)w0JqW`&4-A>1$9B*@@JbGwiQSvjKs(iEHJ?x=AsxcE6?Vn#L zs-;ahG`mp`=B5^|Ol5~O5m$Q()X-9;;Xr8ShG$}G>%Xg9q`?466(LdaxTlZsWfj%y zf8{>ayk?==w+2~xlssn06xK_`%&5_rTxg-vhIIVaFUYOB5f+<#TkO>Db-b^mlJBzF zyYV4p5Gc3VO%b$k`q5(;JAPJE459?#$dKOgB|kqt7Yfus0000AjOzz;%X|)=7$ln| z)eGd~v3NMuUp#po{7WrcRmh5$M*Ub;siG2J9S-`1#v#0~TOH2mFhlI!U?)ruOtk1u zAH>WeUM3;*5rWGU_>5t_#bIp+Cy^miANF$6)Z{o*g#xXFVaM^K#KEIJfhJ^O1J_f1 zdbSv@xcrlv)Wk;2shjxI#cE4Dm8#|rAZfW;K^K>*%zb7=0~5~@3V_&~S_J?(gLj-e zE}L)=yDgQ1#VE6^5%M%ah2nB9oJEfQqs)Rf(LRa7tPz*YHyVFaw15ummNBCSu{z~#e9(yPahw%44J6bE;eJGO5Fh%s)DjHdM_ zjY#V2_;^=x9ovC^PSk~r`+3XZG!tuBv!6pTOQp!)l;;ic89dv0a$DkkJ>L`W0*S)m zc~!|qsG62$k9muKd542?H5|UA=ZaPi*zUljCbB%#a@vuzvnK<5>&});kpAf=;nDih z(2{9T6`CZL1w`zDIZAWycKG#79G3<_Y63yzl2R8?nu;wk>mwmYKwtm>001NE2%W=- zq$0?RloH6{7SuCMKzXN7rK$@}`t#WNZYzFd^!tDS4nSv*hiq)#>MRBDQjT|yhTq27 z_nd~~$fTFI50C|ns>dR!$5u_PGe0{;zJ@vGbKJvO&nEOoTVyJ_z6le^ISefWv)DfW zx^StW^cSLJ$ zR#GZ`c1aM0d^kE?fE!BTaA>Bl|2uyocPM9eAT%vOX|=<_Ck*FM8@U7!t!~hV-35B5 z$E`gz(yCwq<#?2O#3UIgIJFp;1#TW*PuRk}DDCB;FrzCLs*1@{JRCG(jg0UUDT9w& zkKJ?(;ZP#m;7fZ;(Up^mIsHNUmMe$%1hZO}`I#X_oJxsn)fuEfEd?^NzI_kIbdzyJUM009h9Vx)io0007# zJrRD&81MRrDb)?m%(&*oj8QL}+~KHkl`q?9kcHy1MCB018GRH#UT31U43Y-(^)T{`YdANQpOhd+7U?kp_i7uqgUL^-~GDX5yI_m$E zr%ak2rNrIz9kxzdg$@H;&gli~8%YVU`BP~8$|lSr{a6O5zWuicCX`ivfoR2$nz7=S zY|DkY2D>c5)77lB1lbRpMf3RKNIF|9+e9`PplWr`z-i(D3Q~<_!fh_thR@q(j9N1W4s#@j-f}L097{ zv66q0Y+sr)e!(f@8%T8 z@j`Q2o9ci`tEHASBCM;!_}djHJ4OuX(>A3aV`x*_)+6uDQrQ$s zWCm&nE~DLwo_f>h&;KfCh(US`mvyFnk9-;Vt9eW-ii+}+ddA#WJ*SmsWmp!?tAW>p zNicYGP~MBejfwREE!bMZim)CDc>0j$wg-O(uvTI!T7utdOO%&55|p>z2V&)?t6VE^ zQR*|z>@H^^Ci+hN5xJp^>0*E6-m{sAg9f7q686T$|E&$aYgen#y z4|`Q8*kZdNswql=?wyR$HU0k0S4NgL=~ZwEo(evL4)C!0c^D$pgbU0768Vf;;dp2f z7f6x;HA1Icsb5MJuYVk47jH~)|C#7**H5}W#X8E$cVhL9vFI9L8_{ANADu{i>|4yx zut)FHF8r5)?V{1>(UBN`(=YW`ntPibFOQaS(>k{PyE8*QZE3xrJ0?YrbvW%Fy>I4c zEz{VrS=tRB+2cMMF;#0#=e{Fl(74lwVp>)3?((?7u1aKlqa303b{otXp2tF)xDE;Z zhSqys_tMb}KXr3q7BH+d<^~z)J-OQ7zq$5|i2K+LzySbGz)^Y~uqNNu6`(07cf>)f@Oq3T;vCc93d0@<~`$xtvRidl-`<;VN*BJa~xrJTJWYUu+`*9WBOg_9q#zBuAH#1)P#S z+`~5WwDYbepk_-vQ%&@f^(Hu3bQ~MB*I^II0SUZZSmT-KUW<=#x$C! z9C{=%XfO0AxQqbaJo9*A(~#}9ulYP1k^5r7(0Ew1^{1)kkFt|!a*}K zio7W=Bd2n!>3}!8iKav%vM4YW-Lxm^4jt6dUn1TM2he8H@UzWkMa6Y8m-up_?1mSZ zoC>P>nKf46Fh+EciwCiV1)oLKp~hRS04~#%Yg*TQvK|*sw>s|78W1MnW&N(Q3ZB}g zy|U!TKzW0Sb0#?)ZsbpU(0btbT8RV1I=Rf*8|g)7RecqA^l;kqZ%u2+6A&b25Ep%! z4}*extt*k28#Vu8CK^egsI+>qxx+$JL!1=nEB%DFE#_b_9IO(IZh8>Q)5)$c_r~Ix zmukS)Tecbds8HOW>ZEI#?iWtohI9E%An2e2_@Y2>(RA9!frYIT>cyb%yHe}A6}-H6 zy|>{84!b&GGxC|J=_6dfqM0000000lPC004MluvsX10Dzq~pPjXRHAG;F0=!@V08IIm zISoMd8hT_EHZjtG02)FgP@0tgKApXlC2#-$03qD;@9;e&;RW>tN|gI~emvKD3u(qf zC{0B1RQWg^;5ho^Hvemmy@Gm$)hV6Mz5!00nPcR}Ru&6i7(`d|>`DppLig);+u` z8?a;G8yF`nqHW=9xYw-Q!_lpVYf~L%4{!Ox3DA5UyRj0yyMhcD!Y>8UF0s9LIn5j?Rp$XNL?0w60z&^KlJ-oP7H5<hT#mkRviFUJ?@b(cn`8s)bOJ%vV=qrzr zTIArrcpx`7r}A+l0V&ozaeMQW%|xfJ-}yM*j$LX78^CyXT-iKML#%S|d}$57YcrYH zpqTCaVXC4)$PB9XW@bKcHl*I@7#IIXo;3K#zc6G@r3&^;i?ZYT!vr82LvkrE6`ffF1lC zgT``|!(!%XRol>R76w_>vXWtmoaSh_?VCA#yy6%j7p8Cl(K?gt;$_1^pAjRj4%lgE zWh!w(#Q$W~lm%5glr@|Sb+b{J#w)x&dxPlpGkn&0Y}fQ=pZq`u~Q187Q3cI)5cz>% z00O-Uww;PD-mH@B-~a#sF<8b0I~kGfJ>mc%Af)%pTplH@5BGg(!55KCd&2Z(tOrlB&6jDi!Oo08q36#oS`vg&^UWQ0EF7(UyuMs zi?3&(000xIC8~9B%Vt+Bpl5*>@28}G2f0lS{Ub2f-dpH~iK`YTc5YNv7O=eP-MGot zIWAJbP*Zk*Ty7BNwG#=9tgw%JGBnY?+YGsT7pn2EJ$S2TA03WOc7tHI6)5=+xit}? zZJF2o5mG{d@D za4WNlP3skhpFfl(ucEw(KVM*78`J-q=3t|diY`D>0{_s`pl^&!aQ#)(SDpg_OcN5% zHr)ImnM6#!3IFiQfoJfa%G9@+W%u0^CED-KmaB50001GO7Z{# z-RN02z+!R;01ho-Z;HQUQUCw|4+%0{6H6~(zyE%aLHGiA0001oA&ir6w)QZzd_>SH zdV?k)0001PO_fVJ(n~{_8+y$aejWya<2~cMgBGd7f58-OuBaVqSM#yM76`Tm=S4!h zSFK00vwASj;#PmqO)a@5I>+rR#FI@=INEr_Gc~CH#Y^BK0ZU?}k9TYjKyD5XgVzB4 zyw;t!P0EUz!)uIo`m(?2(Xndpn(JvwSrK%T)vXq*jQm@5Y0> z?V?bzUNy$G0?L%UFQgHevELN*D+?tadbAN6p;dc`t>kf{gJyKmgpdLg9}v~otLg~U zhgla_8pZVtXQwq~yUcZ}$#ajhx?j3@VG4ycc-Gn^w)CkJ87O{mj0T@bZP>ktFcs;g zF!zUTK*P7TM-p>aZTL*Bn5>L#l5#b`*&~0E{k<-1mr1D|UK% zG&Vjfli$Br4n3{DPf=0$&g3+@un)F=Y6$G;91Dhv{oRVoYHe>uh%8F{fND@aU88%E zWg0=H7O(jQ&g`{&l;XS{6HrObG49Kxd@S!lF}7rCUui^ceBxo;)AA>~eia&p-^+qa zh3kdp{gQ%vPh4CwgQ)HvYn=orQg_(~dH4X1HHycv*j7~dx88CRiDH9xuC^c|fD)wY zP6)VnMApdH|*{uNx_1lH!ZA+B<(H8T1OY^PF*M zcdVOrkR@R%_}3n5D+DET4-eM$yVIqg4UQM%U4eN95EO$gjOz>tg8fXd@*S$rraxet z?x?rS{W9&$_Oih6&1%Yev6ASuU(J=XZCG7C=Z-1 zO3Z2nPYrzL<=w+5Xpwdc*h1*bTVE)3$uEQHOEqb!R{bMTso*nJ8~X6OjT7|e`|GzA zT)XJWdzeGvK+ZwCWy>>wa+7GlT*__+!yIa*+*YE@qq+%8^Odh7U^_)On6Q8d6jT@{ zZvs@1UP@IZQvE;)#=A6UZR0p|>C7jvBu}Mc%InZ9*xUoaGB?%5fRNSezb-tEs^T zp-SrZiLMjf{+6OUbNh>u$6=RpO2iwu0Tu(ye9w%{1K@Sajr)vAH#K%gQO|G=K_t06 zAzq0wZ6cX0ES%$5)g+rAN6>}-AQ&e&t4 z>IMJtVqNueBVjXjcL*h}8Em7JBG6%x?pqMAx@ccv3-JWZjmfWORuwk@006IDuQ&x9 zuprl{(WT6)D_U#`;G6NcewLG?4a^_;dRqL+J+uXB8ET=YT;Wr3r`6e+Odd$NRuu5e zy?iq!_bDk^VL}X!+aLO)ha!K9o_CKgcQe2Yn(`@L8N~l-a?x?=12KyqbyeZes$qzNI_Sau3yiS`PA-(M zUuy|PI!+-WZl@U%9?sGO;EYVAGB(+_?uVK`XIWY5wUA6`x_h|}RE@KlQktwIbX@b~ zcmTo1oX=BHF zFfipPVDF^!Wy~ei@0AYeVPP88=}mi>uuf~Vfiv^urY#dD=fH9+0mjeqD&JGT($EI$!KkQW#a;6}?M)B#MRU=A17#+b zT_(5x$qdk6DuCK8VTpyn-^U_H5W~!^-Q-MeVcv~!eETq&Tjmirp~D5A*Co3zLXXAh zt5|q41TttM#f9xqBKDhC+ihTrHtn`xa-} /> } /> } /> + } /> )} diff --git a/packages/console/src/pages/Organizations/Guide/Step1/index.module.scss b/packages/console/src/pages/Organizations/Guide/Step1/index.module.scss new file mode 100644 index 000000000..83634dc87 --- /dev/null +++ b/packages/console/src/pages/Organizations/Guide/Step1/index.module.scss @@ -0,0 +1,36 @@ +@use '@/scss/underscore' as _; +@use '@/scss/dimensions' as dim; + +.container { + display: flex; + flex-direction: column; + align-items: center; + gap: _.unit(6); + + .card { + display: flex; + flex-direction: column; + width: 100%; + max-width: dim.$guide-main-content-max-width; + padding: _.unit(12); + gap: _.unit(6); + + .image { + width: 100%; + } + + .icon { + width: 48px; + height: 48px; + flex-shrink: 0; + } + + .title { + font: var(--font-title-1); + } + + .subtitle { + font: var(--font-body-2); + } + } +} diff --git a/packages/console/src/pages/Organizations/Guide/Step1/index.tsx b/packages/console/src/pages/Organizations/Guide/Step1/index.tsx new file mode 100644 index 000000000..953f80d38 --- /dev/null +++ b/packages/console/src/pages/Organizations/Guide/Step1/index.tsx @@ -0,0 +1,44 @@ +import { Theme } from '@logto/schemas'; +import classNames from 'classnames'; +import { useTranslation } from 'react-i18next'; + +import OrganizationFeatureDark from '@/assets/icons/organization-feature-dark.svg'; +import OrganizationFeature from '@/assets/icons/organization-feature.svg'; +import PermissionFeatureDark from '@/assets/icons/permission-feature-dark.svg'; +import PermissionFeature from '@/assets/icons/permission-feature.svg'; +import workflowImage from '@/assets/images/organization-workflow.webp'; +import Card from '@/ds-components/Card'; +import useTheme from '@/hooks/use-theme'; + +import * as styles from './index.module.scss'; + +const icons = { + [Theme.Light]: { OrganizationIcon: OrganizationFeature, PermissionIcon: PermissionFeature }, + [Theme.Dark]: { + OrganizationIcon: OrganizationFeatureDark, + PermissionIcon: PermissionFeatureDark, + }, +}; + +function Step1() { + const { t } = useTranslation(undefined, { keyPrefix: 'admin_console.organizations.guide' }); + const theme = useTheme(); + const { OrganizationIcon, PermissionIcon } = icons[theme]; + + return ( +

+ + +
{t('brief_title')}
+ Organization workflow +
{t('brief_introduction')}
+
+ + +
{t('step_1')}
+
+
+ ); +} + +export default Step1; diff --git a/packages/console/src/pages/Organizations/Guide/index.module.scss b/packages/console/src/pages/Organizations/Guide/index.module.scss new file mode 100644 index 000000000..71998aae6 --- /dev/null +++ b/packages/console/src/pages/Organizations/Guide/index.module.scss @@ -0,0 +1,16 @@ +@use '@/scss/underscore' as _; + +.modalContainer { + height: 100vh; + width: 100vw; + display: flex; + flex-direction: column; + background: var(--color-base); + + .content { + flex: 1; + overflow: hidden; + width: 100%; + padding: _.unit(6); + } +} diff --git a/packages/console/src/pages/Organizations/Guide/index.tsx b/packages/console/src/pages/Organizations/Guide/index.tsx new file mode 100644 index 000000000..0b85dad4b --- /dev/null +++ b/packages/console/src/pages/Organizations/Guide/index.tsx @@ -0,0 +1,57 @@ +import { useCallback, useState } from 'react'; +import Modal from 'react-modal'; + +import ActionBar from '@/components/ActionBar'; +import Button from '@/ds-components/Button'; +import DsModalHeader from '@/ds-components/ModalHeader'; +import OverlayScrollbar from '@/ds-components/OverlayScrollbar'; +import useTenantPathname from '@/hooks/use-tenant-pathname'; +import * as modalStyles from '@/scss/modal.module.scss'; + +import Step1 from './Step1'; +import * as styles from './index.module.scss'; + +const totalSteps = 3; + +function Guide() { + const { navigate } = useTenantPathname(); + const [currentStep, setCurrentStep] = useState(1); + + const onClose = useCallback(() => { + navigate('/organizations'); + }, [navigate]); + + const onClickNext = useCallback(() => { + setCurrentStep(Math.min(currentStep + 1, totalSteps)); + }, [currentStep]); + + const onClickBack = useCallback(() => { + setCurrentStep(Math.max(1, currentStep - 1)); + }, [currentStep]); + + return ( + +
+ + + {currentStep === 1 && } + + + {currentStep === totalSteps && ( +
+
+ ); +} + +export default Guide; diff --git a/packages/phrases/src/locales/de/translation/admin-console/organizations.ts b/packages/phrases/src/locales/de/translation/admin-console/organizations.ts index bc7e18af1..63ccfc411 100644 --- a/packages/phrases/src/locales/de/translation/admin-console/organizations.ts +++ b/packages/phrases/src/locales/de/translation/admin-console/organizations.ts @@ -43,6 +43,51 @@ const organizations = { create_role_placeholder: 'Users with view-only permissions.', /** UNTRANSLATED */ search_permission_placeholder: 'Type to search for permissions', + guide: { + /** UNTRANSLATED */ + title: 'Start with guides', + /** UNTRANSLATED */ + subtitle: 'Jumpstart your app development process with our guides', + /** UNTRANSLATED */ + brief_title: "First, let's understand how organizations works in Logto", + /** UNTRANSLATED */ + brief_introduction: + "In a multi-tenant app, it's important to set clear authorization rules to keep each tenant's data separate. Think of each tenant of your product as its own Logto organization, and they should naturally share the same access control template by default. Learn more", + /** UNTRANSLATED */ + step_1: 'Step 1: Define organization permissions', + /** UNTRANSLATED */ + step_2: 'Step 2: Define organization roles', + /** UNTRANSLATED */ + step_2_description: + '"Organization roles" represent a set of roles given to each organization at the start. These roles are determined by the global permissions you have set in previous screen. Similar with org permission, once you finish this setting for the first time, you won’t need to do this every-time you create a new organization.', + /** UNTRANSLATED */ + step_3: 'Step 3: Create your first organization', + /** UNTRANSLATED */ + step_3_description: + "Let's create your first organization. It comes with a unique ID and serves as a container for handling various more business-toward identities, such as partners, customers, and their access control.", + /** UNTRANSLATED */ + more_next_steps: 'More next steps', + /** UNTRANSLATED */ + add_members: 'Add members to your organization', + /** UNTRANSLATED */ + add_members_action: 'Bulk add members and assign roles', + /** UNTRANSLATED */ + add_enterprise_connector: 'Add enterprise SSO', + /** UNTRANSLATED */ + add_enterprise_connector_action: 'Set up enterprise SSO', + /** UNTRANSLATED */ + organization_permissions: 'Organization permissions', + /** UNTRANSLATED */ + permission_name: 'Permission name', + /** UNTRANSLATED */ + permissions: 'Permissions', + /** UNTRANSLATED */ + organization_roles: 'Organization roles', + /** UNTRANSLATED */ + role_name: 'Role name', + /** UNTRANSLATED */ + organization_name: 'Organization name', + }, }; export default Object.freeze(organizations); diff --git a/packages/phrases/src/locales/en/translation/admin-console/organizations.ts b/packages/phrases/src/locales/en/translation/admin-console/organizations.ts index 21cb2142c..d74e5e8b5 100644 --- a/packages/phrases/src/locales/en/translation/admin-console/organizations.ts +++ b/packages/phrases/src/locales/en/translation/admin-console/organizations.ts @@ -23,6 +23,31 @@ const organization = { role: 'Role', create_role_placeholder: 'Users with view-only permissions.', search_permission_placeholder: 'Type to search for permissions', + guide: { + title: 'Start with guides', + subtitle: 'Jumpstart your app development process with our guides', + brief_title: "First, let's understand how organizations works in Logto", + brief_introduction: + "In a multi-tenant app, it's important to set clear authorization rules to keep each tenant's data separate. Think of each tenant of your product as its own Logto organization, and they should naturally share the same access control template by default. Learn more", + step_1: 'Step 1: Define organization permissions', + step_2: 'Step 2: Define organization roles', + step_2_description: + '"Organization roles" represent a set of roles given to each organization at the start. These roles are determined by the global permissions you have set in previous screen. Similar with org permission, once you finish this setting for the first time, you won’t need to do this every-time you create a new organization.', + step_3: 'Step 3: Create your first organization', + step_3_description: + "Let's create your first organization. It comes with a unique ID and serves as a container for handling various more business-toward identities, such as partners, customers, and their access control.", + more_next_steps: 'More next steps', + add_members: 'Add members to your organization', + add_members_action: 'Bulk add members and assign roles', + add_enterprise_connector: 'Add enterprise SSO', + add_enterprise_connector_action: 'Set up enterprise SSO', + organization_permissions: 'Organization permissions', + permission_name: 'Permission name', + permissions: 'Permissions', + organization_roles: 'Organization roles', + role_name: 'Role name', + organization_name: 'Organization name', + }, }; export default Object.freeze(organization); diff --git a/packages/phrases/src/locales/es/translation/admin-console/organizations.ts b/packages/phrases/src/locales/es/translation/admin-console/organizations.ts index bc7e18af1..63ccfc411 100644 --- a/packages/phrases/src/locales/es/translation/admin-console/organizations.ts +++ b/packages/phrases/src/locales/es/translation/admin-console/organizations.ts @@ -43,6 +43,51 @@ const organizations = { create_role_placeholder: 'Users with view-only permissions.', /** UNTRANSLATED */ search_permission_placeholder: 'Type to search for permissions', + guide: { + /** UNTRANSLATED */ + title: 'Start with guides', + /** UNTRANSLATED */ + subtitle: 'Jumpstart your app development process with our guides', + /** UNTRANSLATED */ + brief_title: "First, let's understand how organizations works in Logto", + /** UNTRANSLATED */ + brief_introduction: + "In a multi-tenant app, it's important to set clear authorization rules to keep each tenant's data separate. Think of each tenant of your product as its own Logto organization, and they should naturally share the same access control template by default. Learn more", + /** UNTRANSLATED */ + step_1: 'Step 1: Define organization permissions', + /** UNTRANSLATED */ + step_2: 'Step 2: Define organization roles', + /** UNTRANSLATED */ + step_2_description: + '"Organization roles" represent a set of roles given to each organization at the start. These roles are determined by the global permissions you have set in previous screen. Similar with org permission, once you finish this setting for the first time, you won’t need to do this every-time you create a new organization.', + /** UNTRANSLATED */ + step_3: 'Step 3: Create your first organization', + /** UNTRANSLATED */ + step_3_description: + "Let's create your first organization. It comes with a unique ID and serves as a container for handling various more business-toward identities, such as partners, customers, and their access control.", + /** UNTRANSLATED */ + more_next_steps: 'More next steps', + /** UNTRANSLATED */ + add_members: 'Add members to your organization', + /** UNTRANSLATED */ + add_members_action: 'Bulk add members and assign roles', + /** UNTRANSLATED */ + add_enterprise_connector: 'Add enterprise SSO', + /** UNTRANSLATED */ + add_enterprise_connector_action: 'Set up enterprise SSO', + /** UNTRANSLATED */ + organization_permissions: 'Organization permissions', + /** UNTRANSLATED */ + permission_name: 'Permission name', + /** UNTRANSLATED */ + permissions: 'Permissions', + /** UNTRANSLATED */ + organization_roles: 'Organization roles', + /** UNTRANSLATED */ + role_name: 'Role name', + /** UNTRANSLATED */ + organization_name: 'Organization name', + }, }; export default Object.freeze(organizations); diff --git a/packages/phrases/src/locales/fr/translation/admin-console/organizations.ts b/packages/phrases/src/locales/fr/translation/admin-console/organizations.ts index bc7e18af1..63ccfc411 100644 --- a/packages/phrases/src/locales/fr/translation/admin-console/organizations.ts +++ b/packages/phrases/src/locales/fr/translation/admin-console/organizations.ts @@ -43,6 +43,51 @@ const organizations = { create_role_placeholder: 'Users with view-only permissions.', /** UNTRANSLATED */ search_permission_placeholder: 'Type to search for permissions', + guide: { + /** UNTRANSLATED */ + title: 'Start with guides', + /** UNTRANSLATED */ + subtitle: 'Jumpstart your app development process with our guides', + /** UNTRANSLATED */ + brief_title: "First, let's understand how organizations works in Logto", + /** UNTRANSLATED */ + brief_introduction: + "In a multi-tenant app, it's important to set clear authorization rules to keep each tenant's data separate. Think of each tenant of your product as its own Logto organization, and they should naturally share the same access control template by default. Learn more", + /** UNTRANSLATED */ + step_1: 'Step 1: Define organization permissions', + /** UNTRANSLATED */ + step_2: 'Step 2: Define organization roles', + /** UNTRANSLATED */ + step_2_description: + '"Organization roles" represent a set of roles given to each organization at the start. These roles are determined by the global permissions you have set in previous screen. Similar with org permission, once you finish this setting for the first time, you won’t need to do this every-time you create a new organization.', + /** UNTRANSLATED */ + step_3: 'Step 3: Create your first organization', + /** UNTRANSLATED */ + step_3_description: + "Let's create your first organization. It comes with a unique ID and serves as a container for handling various more business-toward identities, such as partners, customers, and their access control.", + /** UNTRANSLATED */ + more_next_steps: 'More next steps', + /** UNTRANSLATED */ + add_members: 'Add members to your organization', + /** UNTRANSLATED */ + add_members_action: 'Bulk add members and assign roles', + /** UNTRANSLATED */ + add_enterprise_connector: 'Add enterprise SSO', + /** UNTRANSLATED */ + add_enterprise_connector_action: 'Set up enterprise SSO', + /** UNTRANSLATED */ + organization_permissions: 'Organization permissions', + /** UNTRANSLATED */ + permission_name: 'Permission name', + /** UNTRANSLATED */ + permissions: 'Permissions', + /** UNTRANSLATED */ + organization_roles: 'Organization roles', + /** UNTRANSLATED */ + role_name: 'Role name', + /** UNTRANSLATED */ + organization_name: 'Organization name', + }, }; export default Object.freeze(organizations); diff --git a/packages/phrases/src/locales/it/translation/admin-console/organizations.ts b/packages/phrases/src/locales/it/translation/admin-console/organizations.ts index bc7e18af1..63ccfc411 100644 --- a/packages/phrases/src/locales/it/translation/admin-console/organizations.ts +++ b/packages/phrases/src/locales/it/translation/admin-console/organizations.ts @@ -43,6 +43,51 @@ const organizations = { create_role_placeholder: 'Users with view-only permissions.', /** UNTRANSLATED */ search_permission_placeholder: 'Type to search for permissions', + guide: { + /** UNTRANSLATED */ + title: 'Start with guides', + /** UNTRANSLATED */ + subtitle: 'Jumpstart your app development process with our guides', + /** UNTRANSLATED */ + brief_title: "First, let's understand how organizations works in Logto", + /** UNTRANSLATED */ + brief_introduction: + "In a multi-tenant app, it's important to set clear authorization rules to keep each tenant's data separate. Think of each tenant of your product as its own Logto organization, and they should naturally share the same access control template by default. Learn more", + /** UNTRANSLATED */ + step_1: 'Step 1: Define organization permissions', + /** UNTRANSLATED */ + step_2: 'Step 2: Define organization roles', + /** UNTRANSLATED */ + step_2_description: + '"Organization roles" represent a set of roles given to each organization at the start. These roles are determined by the global permissions you have set in previous screen. Similar with org permission, once you finish this setting for the first time, you won’t need to do this every-time you create a new organization.', + /** UNTRANSLATED */ + step_3: 'Step 3: Create your first organization', + /** UNTRANSLATED */ + step_3_description: + "Let's create your first organization. It comes with a unique ID and serves as a container for handling various more business-toward identities, such as partners, customers, and their access control.", + /** UNTRANSLATED */ + more_next_steps: 'More next steps', + /** UNTRANSLATED */ + add_members: 'Add members to your organization', + /** UNTRANSLATED */ + add_members_action: 'Bulk add members and assign roles', + /** UNTRANSLATED */ + add_enterprise_connector: 'Add enterprise SSO', + /** UNTRANSLATED */ + add_enterprise_connector_action: 'Set up enterprise SSO', + /** UNTRANSLATED */ + organization_permissions: 'Organization permissions', + /** UNTRANSLATED */ + permission_name: 'Permission name', + /** UNTRANSLATED */ + permissions: 'Permissions', + /** UNTRANSLATED */ + organization_roles: 'Organization roles', + /** UNTRANSLATED */ + role_name: 'Role name', + /** UNTRANSLATED */ + organization_name: 'Organization name', + }, }; export default Object.freeze(organizations); diff --git a/packages/phrases/src/locales/ja/translation/admin-console/organizations.ts b/packages/phrases/src/locales/ja/translation/admin-console/organizations.ts index bc7e18af1..63ccfc411 100644 --- a/packages/phrases/src/locales/ja/translation/admin-console/organizations.ts +++ b/packages/phrases/src/locales/ja/translation/admin-console/organizations.ts @@ -43,6 +43,51 @@ const organizations = { create_role_placeholder: 'Users with view-only permissions.', /** UNTRANSLATED */ search_permission_placeholder: 'Type to search for permissions', + guide: { + /** UNTRANSLATED */ + title: 'Start with guides', + /** UNTRANSLATED */ + subtitle: 'Jumpstart your app development process with our guides', + /** UNTRANSLATED */ + brief_title: "First, let's understand how organizations works in Logto", + /** UNTRANSLATED */ + brief_introduction: + "In a multi-tenant app, it's important to set clear authorization rules to keep each tenant's data separate. Think of each tenant of your product as its own Logto organization, and they should naturally share the same access control template by default. Learn more", + /** UNTRANSLATED */ + step_1: 'Step 1: Define organization permissions', + /** UNTRANSLATED */ + step_2: 'Step 2: Define organization roles', + /** UNTRANSLATED */ + step_2_description: + '"Organization roles" represent a set of roles given to each organization at the start. These roles are determined by the global permissions you have set in previous screen. Similar with org permission, once you finish this setting for the first time, you won’t need to do this every-time you create a new organization.', + /** UNTRANSLATED */ + step_3: 'Step 3: Create your first organization', + /** UNTRANSLATED */ + step_3_description: + "Let's create your first organization. It comes with a unique ID and serves as a container for handling various more business-toward identities, such as partners, customers, and their access control.", + /** UNTRANSLATED */ + more_next_steps: 'More next steps', + /** UNTRANSLATED */ + add_members: 'Add members to your organization', + /** UNTRANSLATED */ + add_members_action: 'Bulk add members and assign roles', + /** UNTRANSLATED */ + add_enterprise_connector: 'Add enterprise SSO', + /** UNTRANSLATED */ + add_enterprise_connector_action: 'Set up enterprise SSO', + /** UNTRANSLATED */ + organization_permissions: 'Organization permissions', + /** UNTRANSLATED */ + permission_name: 'Permission name', + /** UNTRANSLATED */ + permissions: 'Permissions', + /** UNTRANSLATED */ + organization_roles: 'Organization roles', + /** UNTRANSLATED */ + role_name: 'Role name', + /** UNTRANSLATED */ + organization_name: 'Organization name', + }, }; export default Object.freeze(organizations); diff --git a/packages/phrases/src/locales/ko/translation/admin-console/organizations.ts b/packages/phrases/src/locales/ko/translation/admin-console/organizations.ts index bc7e18af1..63ccfc411 100644 --- a/packages/phrases/src/locales/ko/translation/admin-console/organizations.ts +++ b/packages/phrases/src/locales/ko/translation/admin-console/organizations.ts @@ -43,6 +43,51 @@ const organizations = { create_role_placeholder: 'Users with view-only permissions.', /** UNTRANSLATED */ search_permission_placeholder: 'Type to search for permissions', + guide: { + /** UNTRANSLATED */ + title: 'Start with guides', + /** UNTRANSLATED */ + subtitle: 'Jumpstart your app development process with our guides', + /** UNTRANSLATED */ + brief_title: "First, let's understand how organizations works in Logto", + /** UNTRANSLATED */ + brief_introduction: + "In a multi-tenant app, it's important to set clear authorization rules to keep each tenant's data separate. Think of each tenant of your product as its own Logto organization, and they should naturally share the same access control template by default. Learn more", + /** UNTRANSLATED */ + step_1: 'Step 1: Define organization permissions', + /** UNTRANSLATED */ + step_2: 'Step 2: Define organization roles', + /** UNTRANSLATED */ + step_2_description: + '"Organization roles" represent a set of roles given to each organization at the start. These roles are determined by the global permissions you have set in previous screen. Similar with org permission, once you finish this setting for the first time, you won’t need to do this every-time you create a new organization.', + /** UNTRANSLATED */ + step_3: 'Step 3: Create your first organization', + /** UNTRANSLATED */ + step_3_description: + "Let's create your first organization. It comes with a unique ID and serves as a container for handling various more business-toward identities, such as partners, customers, and their access control.", + /** UNTRANSLATED */ + more_next_steps: 'More next steps', + /** UNTRANSLATED */ + add_members: 'Add members to your organization', + /** UNTRANSLATED */ + add_members_action: 'Bulk add members and assign roles', + /** UNTRANSLATED */ + add_enterprise_connector: 'Add enterprise SSO', + /** UNTRANSLATED */ + add_enterprise_connector_action: 'Set up enterprise SSO', + /** UNTRANSLATED */ + organization_permissions: 'Organization permissions', + /** UNTRANSLATED */ + permission_name: 'Permission name', + /** UNTRANSLATED */ + permissions: 'Permissions', + /** UNTRANSLATED */ + organization_roles: 'Organization roles', + /** UNTRANSLATED */ + role_name: 'Role name', + /** UNTRANSLATED */ + organization_name: 'Organization name', + }, }; export default Object.freeze(organizations); diff --git a/packages/phrases/src/locales/pl-pl/translation/admin-console/organizations.ts b/packages/phrases/src/locales/pl-pl/translation/admin-console/organizations.ts index bc7e18af1..63ccfc411 100644 --- a/packages/phrases/src/locales/pl-pl/translation/admin-console/organizations.ts +++ b/packages/phrases/src/locales/pl-pl/translation/admin-console/organizations.ts @@ -43,6 +43,51 @@ const organizations = { create_role_placeholder: 'Users with view-only permissions.', /** UNTRANSLATED */ search_permission_placeholder: 'Type to search for permissions', + guide: { + /** UNTRANSLATED */ + title: 'Start with guides', + /** UNTRANSLATED */ + subtitle: 'Jumpstart your app development process with our guides', + /** UNTRANSLATED */ + brief_title: "First, let's understand how organizations works in Logto", + /** UNTRANSLATED */ + brief_introduction: + "In a multi-tenant app, it's important to set clear authorization rules to keep each tenant's data separate. Think of each tenant of your product as its own Logto organization, and they should naturally share the same access control template by default. Learn more", + /** UNTRANSLATED */ + step_1: 'Step 1: Define organization permissions', + /** UNTRANSLATED */ + step_2: 'Step 2: Define organization roles', + /** UNTRANSLATED */ + step_2_description: + '"Organization roles" represent a set of roles given to each organization at the start. These roles are determined by the global permissions you have set in previous screen. Similar with org permission, once you finish this setting for the first time, you won’t need to do this every-time you create a new organization.', + /** UNTRANSLATED */ + step_3: 'Step 3: Create your first organization', + /** UNTRANSLATED */ + step_3_description: + "Let's create your first organization. It comes with a unique ID and serves as a container for handling various more business-toward identities, such as partners, customers, and their access control.", + /** UNTRANSLATED */ + more_next_steps: 'More next steps', + /** UNTRANSLATED */ + add_members: 'Add members to your organization', + /** UNTRANSLATED */ + add_members_action: 'Bulk add members and assign roles', + /** UNTRANSLATED */ + add_enterprise_connector: 'Add enterprise SSO', + /** UNTRANSLATED */ + add_enterprise_connector_action: 'Set up enterprise SSO', + /** UNTRANSLATED */ + organization_permissions: 'Organization permissions', + /** UNTRANSLATED */ + permission_name: 'Permission name', + /** UNTRANSLATED */ + permissions: 'Permissions', + /** UNTRANSLATED */ + organization_roles: 'Organization roles', + /** UNTRANSLATED */ + role_name: 'Role name', + /** UNTRANSLATED */ + organization_name: 'Organization name', + }, }; export default Object.freeze(organizations); diff --git a/packages/phrases/src/locales/pt-br/translation/admin-console/organizations.ts b/packages/phrases/src/locales/pt-br/translation/admin-console/organizations.ts index bc7e18af1..63ccfc411 100644 --- a/packages/phrases/src/locales/pt-br/translation/admin-console/organizations.ts +++ b/packages/phrases/src/locales/pt-br/translation/admin-console/organizations.ts @@ -43,6 +43,51 @@ const organizations = { create_role_placeholder: 'Users with view-only permissions.', /** UNTRANSLATED */ search_permission_placeholder: 'Type to search for permissions', + guide: { + /** UNTRANSLATED */ + title: 'Start with guides', + /** UNTRANSLATED */ + subtitle: 'Jumpstart your app development process with our guides', + /** UNTRANSLATED */ + brief_title: "First, let's understand how organizations works in Logto", + /** UNTRANSLATED */ + brief_introduction: + "In a multi-tenant app, it's important to set clear authorization rules to keep each tenant's data separate. Think of each tenant of your product as its own Logto organization, and they should naturally share the same access control template by default. Learn more", + /** UNTRANSLATED */ + step_1: 'Step 1: Define organization permissions', + /** UNTRANSLATED */ + step_2: 'Step 2: Define organization roles', + /** UNTRANSLATED */ + step_2_description: + '"Organization roles" represent a set of roles given to each organization at the start. These roles are determined by the global permissions you have set in previous screen. Similar with org permission, once you finish this setting for the first time, you won’t need to do this every-time you create a new organization.', + /** UNTRANSLATED */ + step_3: 'Step 3: Create your first organization', + /** UNTRANSLATED */ + step_3_description: + "Let's create your first organization. It comes with a unique ID and serves as a container for handling various more business-toward identities, such as partners, customers, and their access control.", + /** UNTRANSLATED */ + more_next_steps: 'More next steps', + /** UNTRANSLATED */ + add_members: 'Add members to your organization', + /** UNTRANSLATED */ + add_members_action: 'Bulk add members and assign roles', + /** UNTRANSLATED */ + add_enterprise_connector: 'Add enterprise SSO', + /** UNTRANSLATED */ + add_enterprise_connector_action: 'Set up enterprise SSO', + /** UNTRANSLATED */ + organization_permissions: 'Organization permissions', + /** UNTRANSLATED */ + permission_name: 'Permission name', + /** UNTRANSLATED */ + permissions: 'Permissions', + /** UNTRANSLATED */ + organization_roles: 'Organization roles', + /** UNTRANSLATED */ + role_name: 'Role name', + /** UNTRANSLATED */ + organization_name: 'Organization name', + }, }; export default Object.freeze(organizations); diff --git a/packages/phrases/src/locales/pt-pt/translation/admin-console/organizations.ts b/packages/phrases/src/locales/pt-pt/translation/admin-console/organizations.ts index bc7e18af1..63ccfc411 100644 --- a/packages/phrases/src/locales/pt-pt/translation/admin-console/organizations.ts +++ b/packages/phrases/src/locales/pt-pt/translation/admin-console/organizations.ts @@ -43,6 +43,51 @@ const organizations = { create_role_placeholder: 'Users with view-only permissions.', /** UNTRANSLATED */ search_permission_placeholder: 'Type to search for permissions', + guide: { + /** UNTRANSLATED */ + title: 'Start with guides', + /** UNTRANSLATED */ + subtitle: 'Jumpstart your app development process with our guides', + /** UNTRANSLATED */ + brief_title: "First, let's understand how organizations works in Logto", + /** UNTRANSLATED */ + brief_introduction: + "In a multi-tenant app, it's important to set clear authorization rules to keep each tenant's data separate. Think of each tenant of your product as its own Logto organization, and they should naturally share the same access control template by default. Learn more", + /** UNTRANSLATED */ + step_1: 'Step 1: Define organization permissions', + /** UNTRANSLATED */ + step_2: 'Step 2: Define organization roles', + /** UNTRANSLATED */ + step_2_description: + '"Organization roles" represent a set of roles given to each organization at the start. These roles are determined by the global permissions you have set in previous screen. Similar with org permission, once you finish this setting for the first time, you won’t need to do this every-time you create a new organization.', + /** UNTRANSLATED */ + step_3: 'Step 3: Create your first organization', + /** UNTRANSLATED */ + step_3_description: + "Let's create your first organization. It comes with a unique ID and serves as a container for handling various more business-toward identities, such as partners, customers, and their access control.", + /** UNTRANSLATED */ + more_next_steps: 'More next steps', + /** UNTRANSLATED */ + add_members: 'Add members to your organization', + /** UNTRANSLATED */ + add_members_action: 'Bulk add members and assign roles', + /** UNTRANSLATED */ + add_enterprise_connector: 'Add enterprise SSO', + /** UNTRANSLATED */ + add_enterprise_connector_action: 'Set up enterprise SSO', + /** UNTRANSLATED */ + organization_permissions: 'Organization permissions', + /** UNTRANSLATED */ + permission_name: 'Permission name', + /** UNTRANSLATED */ + permissions: 'Permissions', + /** UNTRANSLATED */ + organization_roles: 'Organization roles', + /** UNTRANSLATED */ + role_name: 'Role name', + /** UNTRANSLATED */ + organization_name: 'Organization name', + }, }; export default Object.freeze(organizations); diff --git a/packages/phrases/src/locales/ru/translation/admin-console/organizations.ts b/packages/phrases/src/locales/ru/translation/admin-console/organizations.ts index bc7e18af1..63ccfc411 100644 --- a/packages/phrases/src/locales/ru/translation/admin-console/organizations.ts +++ b/packages/phrases/src/locales/ru/translation/admin-console/organizations.ts @@ -43,6 +43,51 @@ const organizations = { create_role_placeholder: 'Users with view-only permissions.', /** UNTRANSLATED */ search_permission_placeholder: 'Type to search for permissions', + guide: { + /** UNTRANSLATED */ + title: 'Start with guides', + /** UNTRANSLATED */ + subtitle: 'Jumpstart your app development process with our guides', + /** UNTRANSLATED */ + brief_title: "First, let's understand how organizations works in Logto", + /** UNTRANSLATED */ + brief_introduction: + "In a multi-tenant app, it's important to set clear authorization rules to keep each tenant's data separate. Think of each tenant of your product as its own Logto organization, and they should naturally share the same access control template by default. Learn more", + /** UNTRANSLATED */ + step_1: 'Step 1: Define organization permissions', + /** UNTRANSLATED */ + step_2: 'Step 2: Define organization roles', + /** UNTRANSLATED */ + step_2_description: + '"Organization roles" represent a set of roles given to each organization at the start. These roles are determined by the global permissions you have set in previous screen. Similar with org permission, once you finish this setting for the first time, you won’t need to do this every-time you create a new organization.', + /** UNTRANSLATED */ + step_3: 'Step 3: Create your first organization', + /** UNTRANSLATED */ + step_3_description: + "Let's create your first organization. It comes with a unique ID and serves as a container for handling various more business-toward identities, such as partners, customers, and their access control.", + /** UNTRANSLATED */ + more_next_steps: 'More next steps', + /** UNTRANSLATED */ + add_members: 'Add members to your organization', + /** UNTRANSLATED */ + add_members_action: 'Bulk add members and assign roles', + /** UNTRANSLATED */ + add_enterprise_connector: 'Add enterprise SSO', + /** UNTRANSLATED */ + add_enterprise_connector_action: 'Set up enterprise SSO', + /** UNTRANSLATED */ + organization_permissions: 'Organization permissions', + /** UNTRANSLATED */ + permission_name: 'Permission name', + /** UNTRANSLATED */ + permissions: 'Permissions', + /** UNTRANSLATED */ + organization_roles: 'Organization roles', + /** UNTRANSLATED */ + role_name: 'Role name', + /** UNTRANSLATED */ + organization_name: 'Organization name', + }, }; export default Object.freeze(organizations); diff --git a/packages/phrases/src/locales/tr-tr/translation/admin-console/organizations.ts b/packages/phrases/src/locales/tr-tr/translation/admin-console/organizations.ts index bc7e18af1..63ccfc411 100644 --- a/packages/phrases/src/locales/tr-tr/translation/admin-console/organizations.ts +++ b/packages/phrases/src/locales/tr-tr/translation/admin-console/organizations.ts @@ -43,6 +43,51 @@ const organizations = { create_role_placeholder: 'Users with view-only permissions.', /** UNTRANSLATED */ search_permission_placeholder: 'Type to search for permissions', + guide: { + /** UNTRANSLATED */ + title: 'Start with guides', + /** UNTRANSLATED */ + subtitle: 'Jumpstart your app development process with our guides', + /** UNTRANSLATED */ + brief_title: "First, let's understand how organizations works in Logto", + /** UNTRANSLATED */ + brief_introduction: + "In a multi-tenant app, it's important to set clear authorization rules to keep each tenant's data separate. Think of each tenant of your product as its own Logto organization, and they should naturally share the same access control template by default. Learn more", + /** UNTRANSLATED */ + step_1: 'Step 1: Define organization permissions', + /** UNTRANSLATED */ + step_2: 'Step 2: Define organization roles', + /** UNTRANSLATED */ + step_2_description: + '"Organization roles" represent a set of roles given to each organization at the start. These roles are determined by the global permissions you have set in previous screen. Similar with org permission, once you finish this setting for the first time, you won’t need to do this every-time you create a new organization.', + /** UNTRANSLATED */ + step_3: 'Step 3: Create your first organization', + /** UNTRANSLATED */ + step_3_description: + "Let's create your first organization. It comes with a unique ID and serves as a container for handling various more business-toward identities, such as partners, customers, and their access control.", + /** UNTRANSLATED */ + more_next_steps: 'More next steps', + /** UNTRANSLATED */ + add_members: 'Add members to your organization', + /** UNTRANSLATED */ + add_members_action: 'Bulk add members and assign roles', + /** UNTRANSLATED */ + add_enterprise_connector: 'Add enterprise SSO', + /** UNTRANSLATED */ + add_enterprise_connector_action: 'Set up enterprise SSO', + /** UNTRANSLATED */ + organization_permissions: 'Organization permissions', + /** UNTRANSLATED */ + permission_name: 'Permission name', + /** UNTRANSLATED */ + permissions: 'Permissions', + /** UNTRANSLATED */ + organization_roles: 'Organization roles', + /** UNTRANSLATED */ + role_name: 'Role name', + /** UNTRANSLATED */ + organization_name: 'Organization name', + }, }; export default Object.freeze(organizations); diff --git a/packages/phrases/src/locales/zh-cn/translation/admin-console/organizations.ts b/packages/phrases/src/locales/zh-cn/translation/admin-console/organizations.ts index bc7e18af1..63ccfc411 100644 --- a/packages/phrases/src/locales/zh-cn/translation/admin-console/organizations.ts +++ b/packages/phrases/src/locales/zh-cn/translation/admin-console/organizations.ts @@ -43,6 +43,51 @@ const organizations = { create_role_placeholder: 'Users with view-only permissions.', /** UNTRANSLATED */ search_permission_placeholder: 'Type to search for permissions', + guide: { + /** UNTRANSLATED */ + title: 'Start with guides', + /** UNTRANSLATED */ + subtitle: 'Jumpstart your app development process with our guides', + /** UNTRANSLATED */ + brief_title: "First, let's understand how organizations works in Logto", + /** UNTRANSLATED */ + brief_introduction: + "In a multi-tenant app, it's important to set clear authorization rules to keep each tenant's data separate. Think of each tenant of your product as its own Logto organization, and they should naturally share the same access control template by default. Learn more", + /** UNTRANSLATED */ + step_1: 'Step 1: Define organization permissions', + /** UNTRANSLATED */ + step_2: 'Step 2: Define organization roles', + /** UNTRANSLATED */ + step_2_description: + '"Organization roles" represent a set of roles given to each organization at the start. These roles are determined by the global permissions you have set in previous screen. Similar with org permission, once you finish this setting for the first time, you won’t need to do this every-time you create a new organization.', + /** UNTRANSLATED */ + step_3: 'Step 3: Create your first organization', + /** UNTRANSLATED */ + step_3_description: + "Let's create your first organization. It comes with a unique ID and serves as a container for handling various more business-toward identities, such as partners, customers, and their access control.", + /** UNTRANSLATED */ + more_next_steps: 'More next steps', + /** UNTRANSLATED */ + add_members: 'Add members to your organization', + /** UNTRANSLATED */ + add_members_action: 'Bulk add members and assign roles', + /** UNTRANSLATED */ + add_enterprise_connector: 'Add enterprise SSO', + /** UNTRANSLATED */ + add_enterprise_connector_action: 'Set up enterprise SSO', + /** UNTRANSLATED */ + organization_permissions: 'Organization permissions', + /** UNTRANSLATED */ + permission_name: 'Permission name', + /** UNTRANSLATED */ + permissions: 'Permissions', + /** UNTRANSLATED */ + organization_roles: 'Organization roles', + /** UNTRANSLATED */ + role_name: 'Role name', + /** UNTRANSLATED */ + organization_name: 'Organization name', + }, }; export default Object.freeze(organizations); diff --git a/packages/phrases/src/locales/zh-hk/translation/admin-console/organizations.ts b/packages/phrases/src/locales/zh-hk/translation/admin-console/organizations.ts index bc7e18af1..63ccfc411 100644 --- a/packages/phrases/src/locales/zh-hk/translation/admin-console/organizations.ts +++ b/packages/phrases/src/locales/zh-hk/translation/admin-console/organizations.ts @@ -43,6 +43,51 @@ const organizations = { create_role_placeholder: 'Users with view-only permissions.', /** UNTRANSLATED */ search_permission_placeholder: 'Type to search for permissions', + guide: { + /** UNTRANSLATED */ + title: 'Start with guides', + /** UNTRANSLATED */ + subtitle: 'Jumpstart your app development process with our guides', + /** UNTRANSLATED */ + brief_title: "First, let's understand how organizations works in Logto", + /** UNTRANSLATED */ + brief_introduction: + "In a multi-tenant app, it's important to set clear authorization rules to keep each tenant's data separate. Think of each tenant of your product as its own Logto organization, and they should naturally share the same access control template by default. Learn more", + /** UNTRANSLATED */ + step_1: 'Step 1: Define organization permissions', + /** UNTRANSLATED */ + step_2: 'Step 2: Define organization roles', + /** UNTRANSLATED */ + step_2_description: + '"Organization roles" represent a set of roles given to each organization at the start. These roles are determined by the global permissions you have set in previous screen. Similar with org permission, once you finish this setting for the first time, you won’t need to do this every-time you create a new organization.', + /** UNTRANSLATED */ + step_3: 'Step 3: Create your first organization', + /** UNTRANSLATED */ + step_3_description: + "Let's create your first organization. It comes with a unique ID and serves as a container for handling various more business-toward identities, such as partners, customers, and their access control.", + /** UNTRANSLATED */ + more_next_steps: 'More next steps', + /** UNTRANSLATED */ + add_members: 'Add members to your organization', + /** UNTRANSLATED */ + add_members_action: 'Bulk add members and assign roles', + /** UNTRANSLATED */ + add_enterprise_connector: 'Add enterprise SSO', + /** UNTRANSLATED */ + add_enterprise_connector_action: 'Set up enterprise SSO', + /** UNTRANSLATED */ + organization_permissions: 'Organization permissions', + /** UNTRANSLATED */ + permission_name: 'Permission name', + /** UNTRANSLATED */ + permissions: 'Permissions', + /** UNTRANSLATED */ + organization_roles: 'Organization roles', + /** UNTRANSLATED */ + role_name: 'Role name', + /** UNTRANSLATED */ + organization_name: 'Organization name', + }, }; export default Object.freeze(organizations); diff --git a/packages/phrases/src/locales/zh-tw/translation/admin-console/organizations.ts b/packages/phrases/src/locales/zh-tw/translation/admin-console/organizations.ts index bc7e18af1..63ccfc411 100644 --- a/packages/phrases/src/locales/zh-tw/translation/admin-console/organizations.ts +++ b/packages/phrases/src/locales/zh-tw/translation/admin-console/organizations.ts @@ -43,6 +43,51 @@ const organizations = { create_role_placeholder: 'Users with view-only permissions.', /** UNTRANSLATED */ search_permission_placeholder: 'Type to search for permissions', + guide: { + /** UNTRANSLATED */ + title: 'Start with guides', + /** UNTRANSLATED */ + subtitle: 'Jumpstart your app development process with our guides', + /** UNTRANSLATED */ + brief_title: "First, let's understand how organizations works in Logto", + /** UNTRANSLATED */ + brief_introduction: + "In a multi-tenant app, it's important to set clear authorization rules to keep each tenant's data separate. Think of each tenant of your product as its own Logto organization, and they should naturally share the same access control template by default. Learn more", + /** UNTRANSLATED */ + step_1: 'Step 1: Define organization permissions', + /** UNTRANSLATED */ + step_2: 'Step 2: Define organization roles', + /** UNTRANSLATED */ + step_2_description: + '"Organization roles" represent a set of roles given to each organization at the start. These roles are determined by the global permissions you have set in previous screen. Similar with org permission, once you finish this setting for the first time, you won’t need to do this every-time you create a new organization.', + /** UNTRANSLATED */ + step_3: 'Step 3: Create your first organization', + /** UNTRANSLATED */ + step_3_description: + "Let's create your first organization. It comes with a unique ID and serves as a container for handling various more business-toward identities, such as partners, customers, and their access control.", + /** UNTRANSLATED */ + more_next_steps: 'More next steps', + /** UNTRANSLATED */ + add_members: 'Add members to your organization', + /** UNTRANSLATED */ + add_members_action: 'Bulk add members and assign roles', + /** UNTRANSLATED */ + add_enterprise_connector: 'Add enterprise SSO', + /** UNTRANSLATED */ + add_enterprise_connector_action: 'Set up enterprise SSO', + /** UNTRANSLATED */ + organization_permissions: 'Organization permissions', + /** UNTRANSLATED */ + permission_name: 'Permission name', + /** UNTRANSLATED */ + permissions: 'Permissions', + /** UNTRANSLATED */ + organization_roles: 'Organization roles', + /** UNTRANSLATED */ + role_name: 'Role name', + /** UNTRANSLATED */ + organization_name: 'Organization name', + }, }; export default Object.freeze(organizations);