Fix weird layout on refreshing create page

This commit is contained in:
James Grugett 2022-06-27 14:40:40 -05:00
parent 1e904f567a
commit 4107d5fedb

View File

@ -26,6 +26,7 @@ import { useWarnUnsavedChanges } from 'web/hooks/use-warn-unsaved-changes'
import { track } from 'web/lib/service/analytics' import { track } from 'web/lib/service/analytics'
import { GroupSelector } from 'web/components/groups/group-selector' import { GroupSelector } from 'web/components/groups/group-selector'
import { CATEGORIES } from 'common/categories' import { CATEGORIES } from 'common/categories'
import { User } from 'common/user'
export default function Create() { export default function Create() {
const [question, setQuestion] = useState('') const [question, setQuestion] = useState('')
@ -33,7 +34,13 @@ export default function Create() {
const router = useRouter() const router = useRouter()
const { groupId } = router.query as { groupId: string } const { groupId } = router.query as { groupId: string }
useTracking('view create page') useTracking('view create page')
if (!router.isReady) return <div /> const creator = useUser()
useEffect(() => {
if (creator === null) router.push('/')
}, [creator, router])
if (!router.isReady || !creator) return <div />
return ( return (
<Page> <Page>
@ -58,7 +65,11 @@ export default function Create() {
</div> </div>
</form> </form>
<Spacer h={6} /> <Spacer h={6} />
<NewContract question={question} groupId={groupId} /> <NewContract
question={question}
groupId={groupId}
creator={creator}
/>
</div> </div>
</div> </div>
</Page> </Page>
@ -66,14 +77,12 @@ export default function Create() {
} }
// Allow user to create a new contract // Allow user to create a new contract
export function NewContract(props: { question: string; groupId?: string }) { export function NewContract(props: {
const { question, groupId } = props creator: User
const creator = useUser() question: string
groupId?: string
useEffect(() => { }) {
if (creator === null) router.push('/') const { creator, question, groupId } = props
}, [creator])
const [outcomeType, setOutcomeType] = useState<outcomeType>('BINARY') const [outcomeType, setOutcomeType] = useState<outcomeType>('BINARY')
const [initialProb] = useState(50) const [initialProb] = useState(50)
const [minString, setMinString] = useState('') const [minString, setMinString] = useState('')