Expand description; track individual earnings
This commit is contained in:
		
							parent
							
								
									e687907fdd
								
							
						
					
					
						commit
						9f9df5c4e9
					
				|  | @ -15,6 +15,7 @@ import { Grid, _ as r } from 'gridjs-react' | ||||||
| import 'gridjs/dist/theme/mermaid.css' | import 'gridjs/dist/theme/mermaid.css' | ||||||
| import { html } from 'gridjs' | import { html } from 'gridjs' | ||||||
| import dayjs from 'dayjs' | import dayjs from 'dayjs' | ||||||
|  | import { useUser } from '../hooks/use-user' | ||||||
| 
 | 
 | ||||||
| export const getStaticProps = fromPropz(getStaticPropz) | export const getStaticProps = fromPropz(getStaticPropz) | ||||||
| export async function getStaticPropz() { | export async function getStaticPropz() { | ||||||
|  | @ -96,6 +97,24 @@ function Explanation() { | ||||||
|           ! |           ! | ||||||
|         </em> |         </em> | ||||||
|       </p> |       </p> | ||||||
|  | 
 | ||||||
|  |       <h3 id="where-did-manafold-s-mana-go-"> | ||||||
|  |         Where did Manafold's mana go? | ||||||
|  |       </h3> | ||||||
|  |       <p> | ||||||
|  |         Honestly, we're as puzzled as you are. Leading theories include: | ||||||
|  |       </p> | ||||||
|  |       <ul> | ||||||
|  |         <li>Leaky abstractions in our manabase</li> | ||||||
|  |         <li>One too many floating-point rounding errors</li> | ||||||
|  |         <li> | ||||||
|  |           Our newest user <code>Robert');DROP TABLE Balances;--</code> | ||||||
|  |         </li> | ||||||
|  |       </ul> | ||||||
|  |       <p> | ||||||
|  |         We'd be happy to pay a bounty to anyone who can help us solve this | ||||||
|  |         riddle... oh wait. | ||||||
|  |       </p> | ||||||
|     </div> |     </div> | ||||||
|   ) |   ) | ||||||
| } | } | ||||||
|  | @ -114,6 +133,7 @@ export default function Manaboards(props: { | ||||||
|     topCreators: [], |     topCreators: [], | ||||||
|   } |   } | ||||||
|   const { topTraders, topCreators } = props |   const { topTraders, topCreators } = props | ||||||
|  |   const user = useUser() | ||||||
| 
 | 
 | ||||||
|   const values = Array.from(Array(topTraders.length).keys()) |   const values = Array.from(Array(topTraders.length).keys()) | ||||||
|     .map((i) => i + 1) |     .map((i) => i + 1) | ||||||
|  | @ -152,9 +172,11 @@ export default function Manaboards(props: { | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|  |   const MANIFOLD_ID = 'IPTOzEqrpkWmEzh6hwvAyY9PqFb2' | ||||||
|  | 
 | ||||||
|   return ( |   return ( | ||||||
|     <Page margin rightSidebar={<Explanation />}> |     <Page margin rightSidebar={<Explanation />}> | ||||||
|       <Title text={'🏅 Leaderboards'} /> |       <Title text={'🏅 Leaderboard slots, for sale!'} /> | ||||||
|       {/* <div className="absolute right-[700px] top-8"> |       {/* <div className="absolute right-[700px] top-8"> | ||||||
|         <img |         <img | ||||||
|           className="h-18 mx-auto w-24 object-cover transition hover:rotate-12" |           className="h-18 mx-auto w-24 object-cover transition hover:rotate-12" | ||||||
|  | @ -163,9 +185,9 @@ export default function Manaboards(props: { | ||||||
|       </div> */} |       </div> */} | ||||||
|       <div className="prose mb-8 text-gray-600"> |       <div className="prose mb-8 text-gray-600"> | ||||||
|         <p> |         <p> | ||||||
|           Manafold Markets is running low on mana, so we're selling our |           Manafold Markets is running out of mana... so we're selling our | ||||||
|           leaderboard slots to make up the deficit. Buy one now for ephemeral |           leaderboard slots to recoup our losses. Buy one now to earn fleeting | ||||||
|           glory, and help keep Manafold afloat! |           glory and keep Manafold afloat! | ||||||
|         </p> |         </p> | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|  | @ -179,7 +201,9 @@ export default function Manaboards(props: { | ||||||
|         {/* <Manaboard title="🏅 Top creators" users={topCreators} /> */} |         {/* <Manaboard title="🏅 Top creators" users={topCreators} /> */} | ||||||
| 
 | 
 | ||||||
|         <div className="text-sm"> |         <div className="text-sm"> | ||||||
|           <Title text={'Transaction log'} /> |           <Title text={'Transaction history'} /> | ||||||
|  |           {user && <p>Your balance: {userProfits(user.id, transactions)}</p>} | ||||||
|  |           <p>Manifold's earnings: {userProfits(MANIFOLD_ID, transactions)}</p> | ||||||
|           <TransactionsTable txns={_.reverse(sortedTxns)} /> |           <TransactionsTable txns={_.reverse(sortedTxns)} /> | ||||||
|         </div> |         </div> | ||||||
|       </Col> |       </Col> | ||||||
|  | @ -187,6 +211,14 @@ export default function Manaboards(props: { | ||||||
|   ) |   ) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | function userProfits(userId: string, txns: Transaction[]) { | ||||||
|  |   const losses = txns.filter((txn) => txn.fromId === userId) | ||||||
|  |   const loss = _.sumBy(losses, (txn) => txn.amount) | ||||||
|  |   const profits = txns.filter((txn) => txn.toId === userId) | ||||||
|  |   const profit = _.sumBy(profits, (txn) => txn.amount) | ||||||
|  |   return formatMoney(profit - loss) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| function TransactionsTable(props: { txns: Transaction[] }) { | function TransactionsTable(props: { txns: Transaction[] }) { | ||||||
|   const { txns } = props |   const { txns } = props | ||||||
|   return ( |   return ( | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user