|
|
@ -1,6 +1,6 @@
|
|
|
|
import { route } from 'preact-router'
|
|
|
|
import { route } from 'preact-router'
|
|
|
|
import { useContext, useState } from 'preact/hooks'
|
|
|
|
import { useContext, useState } from 'preact/hooks'
|
|
|
|
import { isAdministrator, Solution as SolutionModel } from '../../shared/model'
|
|
|
|
import { isAdministrator, Problem as ProblemModel, Solution as SolutionModel } from '../../shared/model'
|
|
|
|
import { prependBaseUrl, server } from '../api'
|
|
|
|
import { prependBaseUrl, server } from '../api'
|
|
|
|
import { Header } from '../components/Header'
|
|
|
|
import { Header } from '../components/Header'
|
|
|
|
import { MarkdownEditor } from '../components/MarkdownEditor'
|
|
|
|
import { MarkdownEditor } from '../components/MarkdownEditor'
|
|
|
@ -21,15 +21,13 @@ export const ProblemPage = ({ id }: RouteProps) => {
|
|
|
|
|
|
|
|
|
|
|
|
const [source, setSource] = useState('')
|
|
|
|
const [source, setSource] = useState('')
|
|
|
|
|
|
|
|
|
|
|
|
const [{ content }] = useResource<{ content?: string }>(
|
|
|
|
const [problem] = useResource<ProblemModel | null>(`/api/problem/${id}`, null, problem => {
|
|
|
|
`/api/problem/${id}`,
|
|
|
|
if (problem === null) {
|
|
|
|
{
|
|
|
|
|
|
|
|
content: '',
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
() => {
|
|
|
|
|
|
|
|
route(prependBaseUrl('/'))
|
|
|
|
route(prependBaseUrl('/'))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
)
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const content = problem?.content ?? ''
|
|
|
|
|
|
|
|
|
|
|
|
const [solutions, refreshSolutions, setSolutionHeuristic] = useListResource<SolutionModel>(
|
|
|
|
const [solutions, refreshSolutions, setSolutionHeuristic] = useListResource<SolutionModel>(
|
|
|
|
`/api/solutions?problem=${id}`
|
|
|
|
`/api/solutions?problem=${id}`
|
|
|
|