manifold/web/components/feed-create.tsx

153 lines
5.2 KiB
TypeScript
Raw Normal View History

2022-05-05 20:24:42 +00:00
import _ from 'lodash'
import { SparklesIcon, XIcon } from '@heroicons/react/solid'
2022-01-27 23:14:18 +00:00
import { Avatar } from './avatar'
import { useEffect, useRef, useState } from 'react'
import { Spacer } from './layout/spacer'
import { NewContract } from '../pages/create'
import { firebaseLogin, User } from '../lib/firebase/users'
import { ContractsGrid } from './contract/contracts-list'
import { Contract, MAX_QUESTION_LENGTH } from '../../common/contract'
2022-01-27 00:21:14 +00:00
import { Col } from './layout/col'
import clsx from 'clsx'
2022-03-03 08:56:03 +00:00
import { Row } from './layout/row'
import { ENV_CONFIG } from '../../common/envs/constants'
export function FeedPromo(props: { hotContracts: Contract[] }) {
const { hotContracts } = props
return (
<>
<Col className="my-6 rounded-xl bg-white py-12 text-center sm:m-12">
<h1 className="text-4xl sm:text-6xl xl:text-6xl">
2022-03-03 08:56:03 +00:00
<div className="font-semibold sm:mb-2">
A{' '}
<span className="bg-gradient-to-r from-teal-400 to-green-400 bg-clip-text font-bold text-transparent">
market{' '}
</span>
for
</div>
<div className="font-semibold">
every{' '}
<span className="bg-gradient-to-r from-teal-400 to-green-400 bg-clip-text font-bold text-transparent">
2022-04-04 06:07:58 +00:00
question
2022-03-03 08:56:03 +00:00
</span>
2022-01-27 00:21:14 +00:00
</div>
</h1>
<Spacer h={6} />
<div className="mb-4 text-gray-500">
2022-04-04 06:07:58 +00:00
Find markets on any topic imaginable. Or create your own!
<br />
2022-03-03 08:56:03 +00:00
Sign up to get M$ 1,000 and start trading.
<br />
</div>
2022-01-27 00:21:14 +00:00
<Spacer h={6} />
<button
2022-03-03 08:56:03 +00:00
className="btn btn-lg self-center border-none bg-gradient-to-r from-teal-500 to-green-500 normal-case hover:from-teal-600 hover:to-green-600"
2022-01-27 00:21:14 +00:00
onClick={firebaseLogin}
>
2022-03-03 08:56:03 +00:00
Sign up for free
2022-01-27 00:21:14 +00:00
</button>{' '}
</Col>
2022-01-22 20:52:49 +00:00
2022-03-03 08:56:03 +00:00
<Row className="m-4 mb-6 items-center gap-1 text-xl font-semibold text-gray-800">
<SparklesIcon className="inline h-5 w-5" aria-hidden="true" />
Trending today
</Row>
2022-01-27 00:21:14 +00:00
<ContractsGrid
contracts={hotContracts?.slice(0, 10) || []}
2022-05-05 20:24:42 +00:00
loadMore={() => {}}
hasMore={false}
2022-01-27 00:21:14 +00:00
/>
</>
)
}
export default function FeedCreate(props: {
user?: User
tag?: string
placeholder?: string
className?: string
}) {
const { user, tag, className } = props
const [question, setQuestion] = useState('')
const [isExpanded, setIsExpanded] = useState(false)
const inputRef = useRef<HTMLTextAreaElement | null>()
// Rotate through a new placeholder each day
// Easter egg idea: click your own name to shuffle the placeholder
// const daysSinceEpoch = Math.floor(Date.now() / 1000 / 60 / 60 / 24)
// Take care not to produce a different placeholder on the server and client
const [defaultPlaceholder, setDefaultPlaceholder] = useState('')
useEffect(() => {
setDefaultPlaceholder(
`e.g. ${_.sample(ENV_CONFIG.newQuestionPlaceholders)}`
)
}, [])
const placeholder = props.placeholder ?? defaultPlaceholder
return (
2022-01-27 21:08:18 +00:00
<div
className={clsx(
'w-full cursor-text rounded bg-white p-4 shadow-md',
isExpanded ? 'ring-2 ring-indigo-300' : '',
className
)}
onClick={() => {
!isExpanded && inputRef.current?.focus()
}}
2022-01-27 21:08:18 +00:00
>
<div className="relative flex items-start space-x-3">
2022-01-27 23:14:18 +00:00
<Avatar username={user?.username} avatarUrl={user?.avatarUrl} noLink />
2022-01-23 00:16:23 +00:00
<div className="min-w-0 flex-1">
<Row className="justify-between">
<p className="my-0.5 text-sm">Ask a question... </p>
{isExpanded && (
<button
className="btn btn-xs btn-circle btn-ghost rounded"
onClick={() => setIsExpanded(false)}
>
<XIcon
className="mx-auto h-6 w-6 text-gray-500"
aria-hidden="true"
/>
</button>
)}
</Row>
<textarea
ref={inputRef as any}
className={clsx(
'w-full resize-none appearance-none border-transparent bg-transparent p-0 text-indigo-700 placeholder:text-gray-400 focus:border-transparent focus:ring-transparent',
question && 'text-lg sm:text-xl',
!question && 'text-base sm:text-lg'
)}
placeholder={placeholder}
value={question}
rows={question.length > 68 ? 4 : 2}
maxLength={MAX_QUESTION_LENGTH}
onClick={(e) => e.stopPropagation()}
onChange={(e) => setQuestion(e.target.value.replace('\n', ''))}
onFocus={() => setIsExpanded(true)}
/>
</div>
</div>
2022-01-23 00:16:23 +00:00
{/* Hide component instead of deleting, so edits to NewContract don't get lost */}
<div className={isExpanded ? '' : 'hidden'}>
<NewContract question={question} tag={tag} />
</div>
2022-01-23 00:16:23 +00:00
{/* Show a fake "Create Market" button, which gets replaced with the NewContract one*/}
{!isExpanded && (
<div className="flex justify-end sm:-mt-4">
<button className="btn btn-sm capitalize" disabled>
Create Market
</button>
</div>
)}
</div>
)
}