diff --git a/web/components/contract/contract-details.tsx b/web/components/contract/contract-details.tsx
index b4d67520..036311fe 100644
--- a/web/components/contract/contract-details.tsx
+++ b/web/components/contract/contract-details.tsx
@@ -11,6 +11,7 @@ import { UserLink } from '../user-page'
import {
Contract,
contractMetrics,
+ contractPath,
contractPool,
updateContract,
} from 'web/lib/firebase/contracts'
@@ -33,6 +34,7 @@ import { ShareIconButton } from 'web/components/share-icon-button'
import { useUser } from 'web/hooks/use-user'
import { Editor } from '@tiptap/react'
import { exhibitExts } from 'common/util/parse'
+import { ENV_CONFIG } from 'common/envs/constants'
export type ShowTime = 'resolve-date' | 'close-date'
@@ -222,9 +224,12 @@ export function ContractDetails(props: {
+
+
+
+ {maxUses != null
+ ? `${maxUses - uses}/${maxUses} uses left`
+ : `Unlimited use`}
+
+
+ {expiresTime != null
+ ? `Expires ${fromNow(expiresTime)}`
+ : 'Never expires'}
+
+
+
+
+
+
+
+ {formatMoney(amount)}
+
+ {message}
+
+
+
+
+ )
+}
+
+export function ManalinkCardFromView(props: {
+ className?: string
+ link: Manalink
+ highlightedSlug: string
+}) {
+ const { className, link, highlightedSlug } = props
+ const { message, amount, expiresTime, maxUses, claims } = link
+ const [details, setDetails] = useState(false)
+
+ return (
+
-
-
- {maxUses != null
- ? `${maxUses - uses}/${maxUses} uses left`
- : `Unlimited use`}
-
-
- {expiresTime != null
- ? `Expires ${fromNow(expiresTime)}`
- : 'Never expires'}
-
-
-
-
-
-
-
+
setDetails(!details)}
+ >
+ {details && (
+
+ )}
+
+
+ {maxUses != null
+ ? `${maxUses - claims.length}/${maxUses} uses left`
+ : `Unlimited use`}
+
+
+ {expiresTime != null
+ ? `Expires ${fromNow(expiresTime)}`
+ : 'Never expires'}
+
+
+
+
+
+
+
{formatMoney(amount)}
- {message}
-
-
-
-
-
-
-
+
+
+
+
{message || '\n\n'}
+
+
)
}
-export function ManalinkCardPreview(props: {
- className?: string
- info: ManalinkInfo
-}) {
- const { className, info } = props
- const { expiresTime, maxUses, uses, amount, message } = info
+function ClaimsList(props: { link: Manalink; className: string }) {
+ const { link, className } = props
return (
-
-
-
- {maxUses != null
- ? `${maxUses - uses}/${maxUses} uses left`
- : `Unlimited use`}
+ <>
+
+
+ Claimed by...
-
- {expiresTime != null
- ? `Expires ${fromNow(expiresTime)}`
- : 'Never expires'}
+
+ {link.claims.length > 0 ? (
+ <>
+ {link.claims.map((claim) => (
+
+
+
+ ))}
+ >
+ ) : (
+
+ No one has claimed this manalink yet! Share your manalink to start
+ spreading the wealth.
+
+ )}
-
-
-
-
- {formatMoney(amount)}
- {message}
-
-
-
+ >
)
}
+
+function Claim(props: { claim: Claim }) {
+ const { claim } = props
+ const who = useUserById(claim.toId)
+ return (
+
+ {who?.name || 'Loading...'}
+ {fromNow(claim.claimedTime)}
+
+ )
+}
+
+function getManalinkGradient(amount: number) {
+ if (amount < 20) {
+ return 'from-indigo-200 via-indigo-500 to-indigo-800'
+ } else if (amount >= 20 && amount < 50) {
+ return 'from-fuchsia-200 via-fuchsia-500 to-fuchsia-800'
+ } else if (amount >= 50 && amount < 100) {
+ return 'from-rose-100 via-rose-400 to-rose-700'
+ } else if (amount >= 100) {
+ return 'from-amber-200 via-amber-500 to-amber-700'
+ }
+}
+
+function getManalinkAmountColor(amount: number) {
+ if (amount < 20) {
+ return 'text-indigo-500'
+ } else if (amount >= 20 && amount < 50) {
+ return 'text-fuchsia-600'
+ } else if (amount >= 50 && amount < 100) {
+ return 'text-rose-600'
+ } else if (amount >= 100) {
+ return 'text-amber-600'
+ }
+}
diff --git a/web/components/manalinks/create-links-button.tsx b/web/components/manalinks/create-links-button.tsx
index 0d1d603e..25b51bb2 100644
--- a/web/components/manalinks/create-links-button.tsx
+++ b/web/components/manalinks/create-links-button.tsx
@@ -4,7 +4,7 @@ import { Col } from '../layout/col'
import { Row } from '../layout/row'
import { Title } from '../title'
import { User } from 'common/user'
-import { ManalinkCardPreview, ManalinkInfo } from 'web/components/manalink-card'
+import { ManalinkCard, ManalinkInfo } from 'web/components/manalink-card'
import { createManalink } from 'web/lib/firebase/manalinks'
import { Modal } from 'web/components/layout/modal'
import Textarea from 'react-expanding-textarea'
@@ -37,6 +37,7 @@ export function CreateLinksButton(props: {
message: newManalink.message,
})
setHighlightedSlug(slug || '')
+ setTimeout(() => setHighlightedSlug(''), 3700)
}}
/>
@@ -191,7 +192,7 @@ function CreateManalinkForm(props: {
{finishedCreating && (
<>
-
+
void
scrollToTop?: boolean
+ className?: string
nextTitle?: string
prevTitle?: string
}) {
@@ -15,13 +18,17 @@ export function Pagination(props: {
scrollToTop,
nextTitle,
prevTitle,
+ className,
} = props
const maxPage = Math.ceil(totalItems / itemsPerPage) - 1
return (