From 48fa33d8f7a91a08fb67ee5f31b5033ef282dba7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Sza=C5=82owski?= Date: Tue, 5 Mar 2024 16:47:41 +0100 Subject: [PATCH] [#379] create the propose a governance action card --- .../public/images/ProposeGovAction.png | Bin 0 -> 10302 bytes govtool/frontend/src/App.tsx | 16 ++--- .../src/components/atoms/ScrollToManage.tsx | 8 +-- .../molecules/GovernanceVotedOnCard.tsx | 2 +- .../components/organisms/DashboardCards.tsx | 29 ++++++++- .../DashboardGovernanceActionDetails.tsx | 6 +- .../organisms/GovernanceActionsToVote.tsx | 4 +- .../src/components/organisms/HomeCards.tsx | 57 ++++++++++++------ .../src/components/organisms/Slider.tsx | 15 ++--- govtool/frontend/src/consts/images.ts | 5 +- govtool/frontend/src/consts/navItems.ts | 4 +- govtool/frontend/src/consts/paths.ts | 16 ++--- .../src/hooks/forms/useVoteActionForm.tsx | 2 +- govtool/frontend/src/i18n/locales/en.ts | 47 ++++++++++----- govtool/frontend/src/pages/Dashboard.tsx | 4 +- .../DashboardGovernanceActionsCategory.tsx | 6 +- .../src/pages/GovernanceActionDetails.tsx | 6 +- .../frontend/src/pages/GovernanceActions.tsx | 2 +- .../src/pages/GovernanceActionsCategory.tsx | 6 +- 19 files changed, 149 insertions(+), 86 deletions(-) create mode 100644 govtool/frontend/public/images/ProposeGovAction.png diff --git a/govtool/frontend/public/images/ProposeGovAction.png b/govtool/frontend/public/images/ProposeGovAction.png new file mode 100644 index 0000000000000000000000000000000000000000..a355503a3a2813ba522dd44bcf3b64fea17ea3bb GIT binary patch literal 10302 zcmV-ED8bi>P)or){`Ygu$&CO(6F{^Hl&Ec`iWnnkt0@JCGOd-VLmh3krPC=oOqsURPO-p@ z#Y$%sOGiYMsUTP`BZP2~5EDX30+Rbl$hrLYeOZ_9^LgI)TYLWrCpqWja6&TUO4jUs z{=N6wYd!0|Jn!?q-xhg>Y~hO`FYkKfZPh&|H=AR-ZU z=Dy7kzBzfhJPo%*o&np&7w){Q+1-6hs2kC}swIeja|pr7(``aXG@ZBKhZH$QUIbDGiQl@b7?Cz7_qG&{Ztuau|R_Ou7oHIsjl_`2_a zV79g(+3HYSHxnZ2g1Z)OKai)<_Ou3+G1Arkx^!_Moo5}Eq~8^n;*=Y&fWq(pmaNOO z9{ah?&CS(jvwpkZtZ!^KtKX2PaLeQ=+z3!}=Uu;(EG+(v>-W9@blxFL!;b@jRq@GB z<1L?YtBW_Z@8A9KXMQ+aTfDq;#j{1GNJQ8j{tG--iRT^It*?Fv|GaJX9S`kZ9VY1q zCGm%ey36FH^?LcGY^C^Jc?!1ko+SZdDko3AQS!9YeDm0YQZ?_9EORc);ksS;NU|NO zDi7PEZj$HY(Cz+Oa^ZouIoRg-(>MQ4e%XbuOZxEY3NaKQGL8nuQaTs#be-b!?qKg4 zyx)fhcVE@i^}BuL*IbrKI_QX`j&J>xTgv_(-V@|JZ|4%oI7s+t(-N!eKN~N|Y3x;0C>4t6cBB*>v~wGU%-(%ZmUK?=35PZ;ibHuyxSS z_}V`R5PLZGY5;mkw~%bmm2{~uuAh<>j9d|3?)v#>-J*&n(D7TM`4 zm;&nP(oBKz<1sAHtjo{9{h=xsn3qUsGEx2hDeInQncMo-`fHJ(%x{zgH$zySOreJY%8LW)pO{W$j+BjNs z2f|HwG)Hxh<9JQz;{DIYU8|V* zZ@RyfR=fFxlylw=28niwD0}xlsYhke`WtjX|naJ~Spb28^jkD`|ACl>h$VHON zb8sB6km@csEdKIzc$_n!(|m9!PqM?b90%9)lidUf=OvP4FG-34t_O)GEpdivyg*zO z|6{D|^(0+g6W)k`_$d`)Xuqcc&n!5dyRi3WrJab7TBf&0zJ|~6xEc~f>~pQ9@^7qI zD+D3LUJVWXG{L+7rR@0E;7;sUwlS$+E8EkXe9`?W1gw|gxG$H+4fXqrw8Hj^JkLKN z=M&J5cZE;X-pqxAxo4P;;O3Ta^a7JK#!icW%=82T{7JF{hoxCxH+M$NOnM7=KP)n` z9Ke8zi62J{Ca4Gpp&rXjEFq|TZ%LW{c5!MG6qpQ>9HLm3a;$Ce9j?$x^ z#Z7ZSNr7AfdvbIB3B%AQ|lCC z2f!*Jm}yLKO_+srY>U!bd5Gw6j}GI#KXy7e&OIqT`-R7V)KNseAjx2j$XT{-Dl-CbN5}WoX1Oy^)rzyWur!xd0_l~zw#g;bbbHU31}e1; zAf0}N777SGfeDB4JaZO8qu0BfRaI(-V!oqgW)ZN=zDj}h5zN*yWBq~WyV)Q+ZDDZM zfR?xZ$-hnW&YKaFI&M;I)c4+Whp(!A8V`vJeLjJR(dkDka1k7@7HFDq1d^YD^(q*R zS-1kmkRcH$A7YYL6;O^#t2-J1rA??@JM zk)hMJ2_rxS0i10tMAPK)HYlU^ z7jrQ0bVH?QEHy=qW@>j^cx_XJ*DdLcj!W8Ip2bnS0%ut}X;0eE0X79*tz1}Hd8?Gv zbc)nSevz5=^859MHk#ygkNRkcU`pE%#ru7WPO$jfz;dY%B&lV6S4Lpl!b8bQJV!c4 z=HJ^)n;%PxRjIY(Zi-u6RKm}sV~2nRQhfr?G^!Ld*#*7X zX)HgJ$cB^14#eVW)DZ|M<7WnnmN4#i0rD2kVVW4AnSnU7QdPxJ1~l?|Uo`~t4QCB# zxc|mpdGh45WwH)oad@-Kdf)G3b;meF4O1O|Aq_>UM>k@ zsYbQP0#s$k#nPe!fzyj1c~2~H(e0O4Bw5~P?{ADM8EKy)t4}qKdc0pLEZ?IyAX953 zxIvR!1eA|_E#6qqn}9t-wdH7@ZR~A=MK!$_ZVu|6=Q!_|BW&a_jOvU44PW`tYd~rK zd9!}}`*FE>$%?~|rC7KC=T=y}qEV&1yX2a%2Ut?Wx*f68H;~=%?Mad&j&8{2{kO>S zg)dZVqs1t&jkzRmge#041SB$;yk_t8(#s)SEJz!F$s#D6sC%RO@$Ifchgqm(xRI&X z(v?b*TB`z?Dl2e^*P$)k0APyHK>?byDS#Q!O4SJpF|wb<$7txb>%W&}TbA&zi#)GL`pZ0y09n4$5vKEPaBGpnpx&f@0vJ41_axofQL8Pk0X6K%O#TgGQO%F;7v z?cRnGH5;5`qVC>oS>;sYW@%~Pmax*QV@`o|F)uovKI|q8{70Z#y$OGNFB^l852#B_ z3gU$`&cXW9#Dofn$5NlXA3d52l$t1b1hUaAB1Rhdg)H?zvTCNr+D@tmOD@skKu9n( z4#yLVyV6||w*XPO+c#67^|=V9UjH6;9sSSENTt=|q16t=6gMA%Q<<){+Ni_w+%q)r z!U$h=!V+7GWaQ!cNhg-7BC{+{3a27CBS;pF0j-nJ_wSLyy*jLipLHv4P&{r4YdgFE1e~ov0&bP@KW9jPjG!3a8l)bmWhO&OdPAy%1RRfE;3oX z5c}cS(h#eZG^?g_C8*8LvpvM`Os!?oeg_jvVk{zwsX4?%IJXzn?ueZ^cx?G~#C(>W z{Y0Co`hFfdi|j)$qs>s>_-$hxRYQl}+aHJf{|`L-C#MFqKKXgcRzD3t{lRD+?NzBo zI#{8vw(xztU4_-hJTgF63u9<2O?XsHtiDs}jg*SxHfm+Aal^PI`U?n ziM2_BCYN9r$z!uhB7sR83mM8D+JLu*?}R;<;jPzHJygo{kty^BcwpgF2ytz#;rBR* z$*{A}Dht!+@ka4-((oE|0p1HG>!U4CfT9@3jhM58)PzDKr>AfyP>o zv|XVCA#P?WUK6QgH*o$t%~9hp7|{yc4BO%baoH@C20s&=GFZYHX@ zy;o|(J}-k5z0pn7dD`tiHqdjA1d)mWuqci%;8Y}+)xL~GlR?5<|$nKQ|_ zWL9&xywl3dCYGrP{{2+|u_7~}l9-bgjS)_^(G}f+F0i{J!he(Cs|RG-xT6A3$xel6 z0Fp?@t*MI|2Kd&ybZUttJapDFM~( z`PaS6-}1qb6yd*1PNmqa)U*vB2{#Vf8R(?P9Jr`CN{oZtQe4d95Es8{l?=G7Km#DJ zB%x>ZBit=3m=J;_7RU?J%#0)33o7125)V)*(dpOFLt>Rgyghl4#@$49(*&TVJyTpB|~8rwA?3eqy$_l5$yK9PAT6@jma?kGOOr)Tj>%dnOm4lC}JuD5Xl?TwQloATaJv1N@ z8$ERcrrXifV(9{^E<_>$IZu2{eDP6YE)8`nh&U5KvSgO+i_1}X++Uk@%}atgF=z+$ zV!MU~Li?iXznsYui6VZk3{7+PUuxIJ~Mt2AT?-8bGwMU4jOE> zY4sq(KxWzBN*a^$k{)Rs<0cz{rZ$nrvh%6KWBBT37jby(tp(kx`6`gk!Q%}{qJC?y zoBUUSdO-r*Ldf}5cj0`Z@9_c6)6XH3Tw?-7B<6KFle^TlCJ;hUKDLUx#ZS6uqvM7e z%BEw4!d$79#KKWMEV0B9sCxnw=^!*LARckvb9)mS0*R4?2E zaNi1;6knK}$b|uBHf_v;nUv5n@uW`$`$)M8%k_38<;gO3MI(r6neD_%q*FN0CMGVk zE7bpNg{#0LZ|c3M_sPAmJwBipT=gsRz?c3uZqGGyIuzy)tsBRBza4bY9*!=3q4)r| zfb}NSD|~L(LPb*6OFw|Fwuj>ot`%n6e!d9ZY0*N+WwsR?Zg6^0SbfZ(Xm!LMyG;;te{e*N@ANPG1<`l8PnhM)hwrB^*5 z1e0SpB>xni8AGE^Y9+sQNm&4>niT9Ds3d7F4|__ZmW#%u)Is0BGh|4im51S30m?Q= z{qTK%G(CFvV!nF7F1V#S4Dd@wEXGCJV~eq3xtgW3!0uSNfG#!b5936Z!9%x{gC@+_ zbZ<>aU9;$_vgs3TXV|e=O@T96n*;ID^$;~zc!DDxjK~3Cy3dZI=g9YHiMnSLvJKoC zmCQ4W{qPE8`gEAt*iITLQhd(u4{ckjFiu-66%yqshJ_cM6`+3okvD+@UhZ*`jpBHY#_c>-OXQ=e@lmx#05*8; zP$u7)pk1QHTQFxNpP&NJ6oo*FGS@?tZbqCMOfNiRK*KE`cz#`$|Ckj7kUo#43A^bF&tYlXNx!5h4HpjcpWmMOhHgGN%BMNexx?x zq=?hhZP}U3b`G5&?1GiDA5s_aPi~4_I)Ws4UhV~MrlGjQsZOk$r&eB zQfj4B8?yG*h?>jSdUgQ2)B=!o!05v{z0tc zeG6iR5|P7XBg9X%PiUE&0eYbPJ!~0+`sj zR;hgG5x5fXdE03fb!RG21zRAgmaJhX*7MO) z)zxG4X+~bQk8aE8_?UC3$J0D{cXlXy>;50uzkSAlwp+O6cL(K8__3_W-&*zKu9}<@_ z$Qm8Rkxs|1KnKqZm=pk|osO2Dx&)jS+*s9>(Bg1ID9z#4+H8H45B;=KfNRcV)i$=s zwl}RcE#iP~3uK$18k>t!^+-o};_K8+V7=KOvmuB)a4F+8r-SPB6U<-z7#rySPN@ht zZ?0JM>54-nsF9YET39IWi_PrREXvL3_8veb4tOUxLuJ&rTNBfh`HYg4LRjWyPL!v*Or4W*09D(hLovJ*;djGtrVwV$uN zi+$j22`r?FZ;=MF**5&jJGx+v?S6$=(U`zAOO2!SBis| z#w?r|$&Y1)n@M0XS+#9g{dt>?DNPiZ86WGY_Q!s`0t9E7Dy~0Mb}GXa*K(Pew>u3LeI9jD)B9(->NQl4^y) zj>sl@RZ;L-|=TL5CUp|zXV}AhjllVO?eSY6AbZWN zfBa3TOc&}!^Fm>HiMN?d3L{?P3Sb{2c?4)~ok3qCZw$)wZ1zdw@U4j#?om~Yww0;8 zQ-B6-N@^cP>&*BlALDXIl6)RJ;lc;p;Dpo&Nwe53rCW4lu)1QSRs1!b%&Mmf$t&+7 z_Oh=Zbpz70jGcx!A+mFFTh}q=2XY0pL6~4w#ZCnB$k)cx$uFEWpxkix-+|2bU)0js zTM1@?L3?F5IJM1eAnif~n@tk2b?}zj{am{! z!Nqw}4J*+rl6WIok@3&4rUg_@848O6;`J0^qXH;C-n%Jcb2iEK24q<}(@a(O<+Xvr z<+w4E%?bNRV0Zqn@Zv`hSN{y)f8x-O9@>3UfNo89|7W-IuYyZl({No9vV29#f{Siq z^D5^wUCT9$Y#Ly`4LEUbsHIA=wK4k%44E^7FcYW4O!=RErkyTsm*mZUg2{9Q6T9HH zaO+)I*kENz!$$!wo1$SyKudNGa2*vMcSj?gf$F(|S!-c8nS+N#zjqvm{IiYS?ceH3 z_Y0`sPrGQg-A-G}hxffNU0>OJ2Q<;^(T`r^OuCQRJnt{d!RP;I+XyvRly*EP$h?8y zCaG4yjjFASptYh1r8;K#s($qEIwfYI?XnzcHOeJ~@?C)5=^BkH`kkA>JbwC;>n{0*Jc;d$#1U=}z3=V& zrJMd6-!!j=6I@78S1x*?3=e--1T;vy{LlEO%(Tb7-{jIgaWi&4H4^(MB2&rIl^(4^ z6vqDZn3%JIAI)hesM0&29hqBo%8s0~2cVKt@8acoGzBUD%d zw?$e)M!)vb@c^FMFyxHo~0Tvsd} zxD2tfu!86@_r^sfqUD}@-FGJG$fFk3wkw9!2Z<;j42)ude@F4Qw~HRXMFZtz|_l@C%KJp zzx|T#;^G%@p$9@dJ2zXPYF0X1bkd3?vtERoi^zMY-KflixKjrmL2-KcYj?^Nv2J?GVH5pOM z4bA4UjbE;tPyo=&;O2wDaN*%*G5O6a{^1q($~kOL8qje6{Vzal`#h`OF#EC87N{1` zFzf5c-k<$(mZ0Zrf`k5yTR zszGKW<&3vYtloGoZEGnmHN5A@4M*1HJZw+e<+*L%cH3&Fac@O`=oP+d&?RkrQoJA4`H-?AM& z**Yl+B)c4-l(6m+Noll$z7i6XTA-FU)(yxwzr@-7f|_PeM{%g;lW$U;uOe};IZu^m zpB(Q_K3**JJ~y8BKXug`uBzlI*uL#?gbPYXpZoM*)sxA^<#eJI6=P)qF!U!rrci^9 z-va<$9LM2eh>X_CF-Wcy;a9Ma&UNrO z7O?%ji(h^9>z;~Vw0-QB$a&a&IsK*SbbO2!r`-x?gxn-Jr*lX?uB71KRk()*Pe9ap z6Ic?Cox3ktT)Gd+(pKnnL+Ez5WO3m)vQBR&(|%Le`c4!?a?9enqK+ATkiY#q0VcQe zlIezj=Z9~7=)>>35{`Fu9o%A)HoI_3{t6jN_|Qe}dLHiN6<`M619Y$AdC+p{?h{UF zxa|E~dHwTuEOoZ7-rZfO%ibE=61ltK@_cRI_85A$+lfE^@D-Ek?l1VJzIr^FZcgj+1Je-RebpP@aLSms`~Djc4Bh9G z;X>k6a%=;JBoM$p7rPQ9o(LAfO1>=2jBPE z#{1tQ;h%L1oX#sfxNr4&x5#&Jdqx7vtrv>_*i6wSY=vwa_Wpf$m3vC~=HqS8SU~$f z`GWh)X?Z=mq7UeAF@>;`WbR$^H`}>w_rCXrE06xs%^y1c(YszEPlN5R0rSZV|M~R- Q9smFU07*qoM6N<$f`jN9wg3PC literal 0 HcmV?d00001 diff --git a/govtool/frontend/src/App.tsx b/govtool/frontend/src/App.tsx index 13bc34a7d..eb8ce5eb7 100644 --- a/govtool/frontend/src/App.tsx +++ b/govtool/frontend/src/App.tsx @@ -56,8 +56,8 @@ export default function App() { const checkTheWalletIsActive = useCallback(() => { const hrefCondition = window.location.pathname === PATHS.home || - window.location.pathname === PATHS.governance_actions || - window.location.pathname === PATHS.governance_actions_action; + window.location.pathname === PATHS.governanceActions || + window.location.pathname === PATHS.governanceActionsAction; const walletName = getItemFromLocalStorage(`${WALLET_LS_KEY}_name`); if (window.cardano) { @@ -89,29 +89,29 @@ export default function App() { } /> } > } /> } /> }> } /> } /> } /> } /> diff --git a/govtool/frontend/src/components/atoms/ScrollToManage.tsx b/govtool/frontend/src/components/atoms/ScrollToManage.tsx index 49046d36b..1b1ff7e1a 100644 --- a/govtool/frontend/src/components/atoms/ScrollToManage.tsx +++ b/govtool/frontend/src/components/atoms/ScrollToManage.tsx @@ -25,8 +25,8 @@ export const ScrollToManage = () => { window.scrollTo(0, pathMap.get(pathname)!); } else { if ( - pathname === PATHS.dashboard_governance_actions || - pathname === PATHS.governance_actions + pathname === PATHS.dashboardGovernanceActions || + pathname === PATHS.governanceActions ) { pathMap.set(pathname, 0); } @@ -37,8 +37,8 @@ export const ScrollToManage = () => { useEffect(() => { const fn = debounce(() => { if ( - pathname === PATHS.dashboard_governance_actions || - pathname === PATHS.governance_actions + pathname === PATHS.dashboardGovernanceActions || + pathname === PATHS.governanceActions ) { pathMap.set(pathname, window.scrollY); } diff --git a/govtool/frontend/src/components/molecules/GovernanceVotedOnCard.tsx b/govtool/frontend/src/components/molecules/GovernanceVotedOnCard.tsx index 58ff325a7..f5181769d 100644 --- a/govtool/frontend/src/components/molecules/GovernanceVotedOnCard.tsx +++ b/govtool/frontend/src/components/molecules/GovernanceVotedOnCard.tsx @@ -255,7 +255,7 @@ export const GovernanceVotedOnCard = ({ votedProposal, inProgress }: Props) => { )}-change-your-vote`} onClick={() => navigate( - PATHS.dashboard_governance_actions_action.replace( + PATHS.dashboardGovernanceActionsAction.replace( ":proposalId", getFullGovActionId(proposal.txHash, proposal.index) ), diff --git a/govtool/frontend/src/components/organisms/DashboardCards.tsx b/govtool/frontend/src/components/organisms/DashboardCards.tsx index 64075b3a8..f386c9782 100644 --- a/govtool/frontend/src/components/organisms/DashboardCards.tsx +++ b/govtool/frontend/src/components/organisms/DashboardCards.tsx @@ -503,7 +503,7 @@ export const DashboardCards = () => { "https://docs.sanchogov.tools/faqs/what-does-it-mean-to-register-as-a-drep" ) } - secondButtonVariant={"outlined"} + secondButtonVariant="outlined" imageURL={IMAGES.soleVoterImage} /> {/* REGISTARTION AS SOLE VOTER CARD END*/} @@ -511,7 +511,7 @@ export const DashboardCards = () => { navigate(PATHS.dashboard_governance_actions)} + firstButtonAction={() => navigate(PATHS.dashboardGovernanceActions)} firstButtonLabel={t( `dashboard.govActions.${ voter?.isRegisteredAsDRep ? "reviewAndVote" : "view" @@ -521,6 +521,31 @@ export const DashboardCards = () => { title={t("dashboard.govActions.title")} /> {/* GOV ACTIONS LIST CARD END*/} + {/* GOV ACTIONS LIST CARD */} + navigate(PATHS.governanceActionsPropose)} + firstButtonLabel={t( + `dashboard.proposeGovernanceAction.${ + // TODO: add isPendingGovernanceAction to the context + // isPendingGovernanceAction ? "propose" : "viewGovernanceActions" + `propose` + }` + )} + secondButtonLabel={t("learnMore")} + secondButtonAction={() => + openInNewTab( + "https://docs.sanchogov.tools/faqs/what-is-a-governance-action" + ) + } + secondButtonVariant="outlined" + imageURL={IMAGES.proposeGovActionImage} + title={t("dashboard.proposeGovernanceAction.title")} + /> + {/* GOV ACTIONS LIST CARD END*/} ); }; diff --git a/govtool/frontend/src/components/organisms/DashboardGovernanceActionDetails.tsx b/govtool/frontend/src/components/organisms/DashboardGovernanceActionDetails.tsx index 413f76818..815b1f37f 100644 --- a/govtool/frontend/src/components/organisms/DashboardGovernanceActionDetails.tsx +++ b/govtool/frontend/src/components/organisms/DashboardGovernanceActionDetails.tsx @@ -46,7 +46,7 @@ export const DashboardGovernanceActionDetails = () => { const breadcrumbs = [ @@ -87,10 +87,10 @@ export const DashboardGovernanceActionDetails = () => { onClick={() => navigate( state && state.openedFromCategoryPage - ? generatePath(PATHS.dashboard_governance_actions_category, { + ? generatePath(PATHS.dashboardGovernanceActionsCategory, { category: state.type, }) - : PATHS.dashboard_governance_actions, + : PATHS.dashboardGovernanceActions, { state: { isVotedListOnLoad: state && state.vote ? true : false, diff --git a/govtool/frontend/src/components/organisms/GovernanceActionsToVote.tsx b/govtool/frontend/src/components/organisms/GovernanceActionsToVote.tsx index 7058ce106..c457062c5 100644 --- a/govtool/frontend/src/components/organisms/GovernanceActionsToVote.tsx +++ b/govtool/frontend/src/components/organisms/GovernanceActionsToVote.tsx @@ -113,7 +113,7 @@ export const GovernanceActionsToVote = ({ : navigate( onDashboard ? generatePath( - PATHS.dashboard_governance_actions_action, + PATHS.dashboardGovernanceActionsAction, { proposalId: getFullGovActionId( item.txHash, @@ -121,7 +121,7 @@ export const GovernanceActionsToVote = ({ ), } ) - : PATHS.governance_actions_action.replace( + : PATHS.governanceActionsAction.replace( ":proposalId", getFullGovActionId( item.txHash, diff --git a/govtool/frontend/src/components/organisms/HomeCards.tsx b/govtool/frontend/src/components/organisms/HomeCards.tsx index c1ba526ba..4539587c1 100644 --- a/govtool/frontend/src/components/organisms/HomeCards.tsx +++ b/govtool/frontend/src/components/organisms/HomeCards.tsx @@ -35,12 +35,19 @@ export const HomeCards = () => { ); const onClickLearnMoreAboutSoleVoterRegistration = useCallback( - () => openInNewTab("https://www.google.com"), + // TODO: Update the link + () => openInNewTab("https://docs.sanchogov.tools/"), + [] + ); + + const onClickLearnMoreAboutProposingGovAction = useCallback( + // TODO: Update the link + () => openInNewTab("https://docs.sanchogov.tools/"), [] ); const navigateToGovActions = useCallback( - () => navigate(PATHS.governance_actions), + () => navigate(PATHS.governanceActions), [navigate] ); @@ -67,59 +74,75 @@ export const HomeCards = () => { {/* DELEGATE CARD END*/} {/* REGISTER AS DREP CARD */} {/* REGISTER AS DREP CARD END */} {/* REGISTER AS SOLE VOTER CARD */} {/* REGISTER AS SOLE VOTER CARD END */} {/* GOV ACTIONS CARD */} - {/* GOV ACTIONS CARD */} + {/* GOV ACTIONS CARD END*/} + {/* PROPOSE GOV ACTION CARD */} + + {/* PROPOSE GOV ACTION CARD END*/} ); }; diff --git a/govtool/frontend/src/components/organisms/Slider.tsx b/govtool/frontend/src/components/organisms/Slider.tsx index e6024a772..07bf2cd90 100644 --- a/govtool/frontend/src/components/organisms/Slider.tsx +++ b/govtool/frontend/src/components/organisms/Slider.tsx @@ -105,12 +105,12 @@ export const Slider = ({ onClick={() => onDashboard ? navigate( - generatePath(PATHS.dashboard_governance_actions_category, { + generatePath(PATHS.dashboardGovernanceActionsCategory, { category: navigateKey, }) ) : navigate( - generatePath(PATHS.governance_actions_category, { + generatePath(PATHS.governanceActionsCategory, { category: navigateKey, }) ) @@ -157,15 +157,12 @@ export const Slider = ({ onClick={() => onDashboard ? navigate( - generatePath( - PATHS.dashboard_governance_actions_category, - { - category: navigateKey, - } - ) + generatePath(PATHS.dashboardGovernanceActionsCategory, { + category: navigateKey, + }) ) : navigate( - generatePath(PATHS.governance_actions_category, { + generatePath(PATHS.governanceActionsCategory, { category: navigateKey, }) ) diff --git a/govtool/frontend/src/consts/images.ts b/govtool/frontend/src/consts/images.ts index 72f60559d..7f97c824a 100644 --- a/govtool/frontend/src/consts/images.ts +++ b/govtool/frontend/src/consts/images.ts @@ -4,12 +4,13 @@ export const IMAGES = { bgBlue: "/images/BGBlue.png", bgOrange: "/images/BGOrange.png", errorPageImage: "/images/ErrorPageImage.png", - heroImage: "/images/HeroImage.png", - soleVoterImage: "/images/GovActionsSoleVoter.png", govActionDefaultImage: "/images/GovActionDefault.png", govActionDelegateImage: "/images/GovActionDelegate.png", govActionListImage: "/images/GovActionList.png", govActionRegisterImage: "/images/GovActionRegister.png", + heroImage: "/images/HeroImage.png", + proposeGovActionImage: "/images/ProposeGovAction.png", + soleVoterImage: "/images/GovActionsSoleVoter.png", successImage: "/images/Success.png", warningImage: "/images/Warning.png", warningYellowImage: "/images/WarningYellow.png", diff --git a/govtool/frontend/src/consts/navItems.ts b/govtool/frontend/src/consts/navItems.ts index d46bbd6e1..1c3d0ec37 100644 --- a/govtool/frontend/src/consts/navItems.ts +++ b/govtool/frontend/src/consts/navItems.ts @@ -10,7 +10,7 @@ export const NAV_ITEMS = [ }, { dataTestId: "governance-actions-link", - navTo: PATHS.governance_actions, + navTo: PATHS.governanceActions, label: "Governance Actions", newTabLink: null, }, @@ -40,7 +40,7 @@ export const CONNECTED_NAV_ITEMS = [ { dataTestId: "governance-actions-link", label: "Governance Actions", - navTo: PATHS.dashboard_governance_actions, + navTo: PATHS.dashboardGovernanceActions, activeIcon: ICONS.governanceActionsActiveIcon, icon: ICONS.governanceActionsIcon, newTabLink: null, diff --git a/govtool/frontend/src/consts/paths.ts b/govtool/frontend/src/consts/paths.ts index 4ac0cbde2..1238e228c 100644 --- a/govtool/frontend/src/consts/paths.ts +++ b/govtool/frontend/src/consts/paths.ts @@ -1,18 +1,18 @@ export const PATHS = { - dashboard_governance_actions_action: - "/connected/governance_actions/:proposalId", - dashboard_governance_actions_category: + dashboardGovernanceActionsAction: "/connected/governance_actions/:proposalId", + dashboardGovernanceActionsCategory: "/connected/governance_actions/category/:category", - dashboard_governance_actions: "/connected/governance_actions", + dashboardGovernanceActions: "/connected/governance_actions", dashboard: "/dashboard", delegateTodRep: "/delegate", error: "/error", faqs: "/faqs", - governance_actions_action: "/governance_actions/:proposalId", - governance_actions_category_action: + governanceActions: "/governance_actions", + governanceActionsAction: "/governance_actions/:proposalId", + governanceActionsCategoryAction: "/governance_actions/category/:category/:proposalId", - governance_actions_category: "/governance_actions/category/:category", - governance_actions: "/governance_actions", + governanceActionsCategory: "/governance_actions/category/:category", + governanceActionsPropose: "/governance_actions/propose", guides: "/guides", home: "/", registerAsdRep: "/register", diff --git a/govtool/frontend/src/hooks/forms/useVoteActionForm.tsx b/govtool/frontend/src/hooks/forms/useVoteActionForm.tsx index cf1a0cbe0..30fd331aa 100644 --- a/govtool/frontend/src/hooks/forms/useVoteActionForm.tsx +++ b/govtool/frontend/src/hooks/forms/useVoteActionForm.tsx @@ -110,7 +110,7 @@ export const useVoteActionForm = () => { }); if (result) { addSuccessAlert("Vote submitted"); - navigate(PATHS.dashboard_governance_actions, { + navigate(PATHS.dashboardGovernanceActions, { state: { isVotedListOnLoad: state && state.vote ? true : false, }, diff --git a/govtool/frontend/src/i18n/locales/en.ts b/govtool/frontend/src/i18n/locales/en.ts index 3c9d6e006..b89bccc5e 100644 --- a/govtool/frontend/src/i18n/locales/en.ts +++ b/govtool/frontend/src/i18n/locales/en.ts @@ -80,6 +80,12 @@ export const en = { title: "Governance Actions", view: "View governance actions", }, + proposeGovernanceAction: { + title: "Propose a Governance Action", + description: "Submit your proposal for a Governance Action.", + propose: "Propose", + view: "View governance actions", + }, registration: { changeMetadata: "Change metadata", dRepRegistration: "DRep Registration", @@ -242,21 +248,32 @@ export const en = { }, home: { cards: { - delegateDescription: "Find a DRep to vote on your behalf.", - delegateFirstButtonLabel: "View DRep Direcotry", - delegateTitle: "Delegate your Voting Power", - governaneActionsDescription: - "See all the Governance Actions submitted on chain. ", - governanceActionsFirstButtonLabel: "View Governance Actions", - governaneActionsTitle: "View Governance Actions", - registerAsDRepDescription: - "Accept delegated voting power from other ADA holders, and combine it with your own voting power. Vote with the accumulated Power on Governance Actions.", - registerAsDRepFirstButtonLabel: "Connect to Register", - registerAsDRepTitle: "Become a DRep", - registerAsSoleVoterDescription: - "Vote on Governance Actions using your own voting power", - registerAsSoleVoterFirstButtonLabel: "Connect to Register", - registerAsSoleVoterTitle: "Become a Sole Voter", + delegate: { + description: "Find a DRep to vote on your behalf.", + firstButtonLabel: "View DRep Directory", + title: "Delegate your Voting Power", + }, + governanceActions: { + description: "See all the Governance Actions submitted on chain. ", + firstButtonLabel: "View Governance Actions", + title: "View Governance Actions", + }, + proposeAGovernanceAction: { + description: "Submit your proposal for a Governance Action.", + firstButtonLabel: "Connect to Submit", + title: "Propose a Governance Action", + }, + registerAsDRep: { + description: + "Accept delegated voting power from other ADA holders, and combine it with your own voting power. Vote with the accumulated Power on Governance Actions.", + firstButtonLabel: "Connect to Register", + title: "Become a DRep", + }, + registerAsSoleVoter: { + description: "Vote on Governance Actions using your own voting power", + firstButtonLabel: "Connect to Register", + title: "Become a Sole Voter", + }, }, }, menu: { diff --git a/govtool/frontend/src/pages/Dashboard.tsx b/govtool/frontend/src/pages/Dashboard.tsx index 992897916..cda265b50 100644 --- a/govtool/frontend/src/pages/Dashboard.tsx +++ b/govtool/frontend/src/pages/Dashboard.tsx @@ -20,7 +20,7 @@ export const Dashboard = () => { const getPageTitle = (pathname: string) => { if (pathname === PATHS.dashboard) { return t("dashboard.title"); - } else if (pathname.includes(PATHS.dashboard_governance_actions)) { + } else if (pathname.includes(PATHS.dashboardGovernanceActions)) { return t("dashboard.govActions.title"); } return ""; @@ -28,7 +28,7 @@ export const Dashboard = () => { useEffect(() => { if (divRef.current) { - pathname !== PATHS.dashboard_governance_actions && + pathname !== PATHS.dashboardGovernanceActions && divRef.current.scrollTo({ top: 0 }); } }, [pathname, divRef]); diff --git a/govtool/frontend/src/pages/DashboardGovernanceActionsCategory.tsx b/govtool/frontend/src/pages/DashboardGovernanceActionsCategory.tsx index 1fffa539d..15fd8ed44 100644 --- a/govtool/frontend/src/pages/DashboardGovernanceActionsCategory.tsx +++ b/govtool/frontend/src/pages/DashboardGovernanceActionsCategory.tsx @@ -69,7 +69,7 @@ export const DashboardGovernanceActionsCategory = () => { {t("govActions.title")} @@ -127,7 +127,7 @@ export const DashboardGovernanceActionsCategory = () => { textDecoration: "none", marginBottom: 3, }} - onClick={() => navigate(PATHS.dashboard_governance_actions)} + onClick={() => navigate(PATHS.dashboardGovernanceActions)} > { ) : navigate( generatePath( - PATHS.dashboard_governance_actions_action, + PATHS.dashboardGovernanceActionsAction, { proposalId: getFullGovActionId( item.txHash, diff --git a/govtool/frontend/src/pages/GovernanceActionDetails.tsx b/govtool/frontend/src/pages/GovernanceActionDetails.tsx index 76c26e93b..cabb8b1eb 100644 --- a/govtool/frontend/src/pages/GovernanceActionDetails.tsx +++ b/govtool/frontend/src/pages/GovernanceActionDetails.tsx @@ -51,7 +51,7 @@ export const GovernanceActionDetails = () => { const breadcrumbs = [ @@ -104,10 +104,10 @@ export const GovernanceActionDetails = () => { onClick={() => navigate( state && state.openedFromCategoryPage - ? generatePath(PATHS.governance_actions_category, { + ? generatePath(PATHS.governanceActionsCategory, { category: state.type, }) - : PATHS.governance_actions + : PATHS.governanceActions ) } > diff --git a/govtool/frontend/src/pages/GovernanceActions.tsx b/govtool/frontend/src/pages/GovernanceActions.tsx index ee4c2f561..2867a6ccf 100644 --- a/govtool/frontend/src/pages/GovernanceActions.tsx +++ b/govtool/frontend/src/pages/GovernanceActions.tsx @@ -23,7 +23,7 @@ export const GovernanceActions = () => { useEffect(() => { if (isEnabled && getItemFromLocalStorage(`${WALLET_LS_KEY}_stake_key`)) { - navigate(PATHS.dashboard_governance_actions); + navigate(PATHS.dashboardGovernanceActions); } }, [isEnabled]); diff --git a/govtool/frontend/src/pages/GovernanceActionsCategory.tsx b/govtool/frontend/src/pages/GovernanceActionsCategory.tsx index ef6c40a50..13b9b92e6 100644 --- a/govtool/frontend/src/pages/GovernanceActionsCategory.tsx +++ b/govtool/frontend/src/pages/GovernanceActionsCategory.tsx @@ -66,7 +66,7 @@ export const GovernanceActionsCategory = () => { const breadcrumbs = [ @@ -148,7 +148,7 @@ export const GovernanceActionsCategory = () => { textDecoration: "none", marginBottom: 4.25, }} - onClick={() => navigate(PATHS.dashboard_governance_actions)} + onClick={() => navigate(PATHS.dashboardGovernanceActions)} > { saveScrollPosition(); navigate( - PATHS.governance_actions_action.replace( + PATHS.governanceActionsAction.replace( ":proposalId", getFullGovActionId(item.txHash, item.index) ),