diff --git a/apps/portals/src/configurations/challengeportal/synapseConfigs/challenges.ts b/apps/portals/src/configurations/challengeportal/synapseConfigs/challenges.ts index 87c1614f95..6b96f1ab7e 100644 --- a/apps/portals/src/configurations/challengeportal/synapseConfigs/challenges.ts +++ b/apps/portals/src/configurations/challengeportal/synapseConfigs/challenges.ts @@ -16,7 +16,7 @@ export const challengesSchema: GenericCardSchema = { title: 'name', subTitle: 'Status', description: 'Abstract', - secondaryLabels: ['Difficulty', 'ChallengeType', 'DataType', 'Tags'], + secondaryLabels: ['ChallengeType', 'DataType', 'Tags'], } export const challengeTitleLinkConfig: CardLink = { isMarkdown: false, @@ -54,12 +54,6 @@ const taskTabConfigs = (taskID: string) => { title: 'Description', props: {}, }, - { - name: 'Markdown', - columnName: `${taskID}.Motivation`, - title: 'Motivation', - props: {}, - }, { name: 'Markdown', columnName: `${taskID}.DataWiki`, @@ -69,7 +63,7 @@ const taskTabConfigs = (taskID: string) => { { name: 'ChallengeDataDownload', columnName: `${taskID}.DataFolder`, - title: 'Training Data', + title: 'Data Files', props: { parentContainerId: '', // filled in dynamically by DetailsPage using value from `${taskID}.DataFolder` }, @@ -150,8 +144,14 @@ export const challengeDetailsPageConfig: DetailsPageProps = { props: {}, }, { - name: 'CardContainerLogic', + name: 'Markdown', + columnName: 'OrganizersDescription', + injectMarkdown: true, title: 'Organizers', + props: {}, + }, + { + name: 'CardContainerLogic', columnName: 'Organizers', overrideSqlSourceTable: true, // Instead, modify the sql (SELECT * FROM ) props: { @@ -161,8 +161,14 @@ export const challengeDetailsPageConfig: DetailsPageProps = { }, }, { - name: 'CardContainerLogic', + name: 'Markdown', + columnName: 'ContributorsDescription', + injectMarkdown: true, title: 'Contributors', + props: {}, + }, + { + name: 'CardContainerLogic', columnName: 'Contributors', overrideSqlSourceTable: true, props: { @@ -182,6 +188,17 @@ export const challengeDetailsPageConfig: DetailsPageProps = { type: SynapseConstants.MEDIUM_USER_CARD, }, }, + { + name: 'CardContainerLogic', + title: 'Support', + columnName: 'Support', + overrideSqlSourceTable: true, + props: { + sql: '', + limit: 6, + type: SynapseConstants.MEDIUM_USER_CARD, + }, + }, { name: 'ChallengeParticipantGoogleMap', title: 'Participants', @@ -218,6 +235,12 @@ export const challengeDetailsPageConfig: DetailsPageProps = { title: 'Conduct Rules', props: {}, }, + { + name: 'Markdown', + columnName: 'DataConditionsForUse', + title: 'Data Conditions For Use', + props: {}, + }, ], }, { diff --git a/apps/portals/src/portal-components/challengeportal/ChallengeDetailPageWrapper.tsx b/apps/portals/src/portal-components/challengeportal/ChallengeDetailPageWrapper.tsx index 51df9bd5f7..db51eb1a5d 100644 --- a/apps/portals/src/portal-components/challengeportal/ChallengeDetailPageWrapper.tsx +++ b/apps/portals/src/portal-components/challengeportal/ChallengeDetailPageWrapper.tsx @@ -1,6 +1,10 @@ import { Box } from '@mui/material' import * as React from 'react' -import { AppUtils, ChallengeDetailPage } from 'synapse-react-client' +import { + AppUtils, + ChallengeDetailPage, + SynapseQueries, +} from 'synapse-react-client' /** * This is the Challenge Registration button. This includes: @@ -11,7 +15,23 @@ import { AppUtils, ChallengeDetailPage } from 'synapse-react-client' */ const ChallengeDetailPageWrapper = () => { const projectId = AppUtils.useQuerySearchParam('id') - if (projectId) { + const { data, isLoading } = SynapseQueries.useGetEntityBundle( + projectId ?? '', //fallback for type safety, but should only be enabled when projectId is set + undefined, + { + includeAnnotations: true, + }, + { + enabled: !!projectId, + }, + ) + if (isLoading) { + return <> + } + if ( + !!projectId && + data?.annotations.annotations['Status']?.value[0] == 'Active' + ) { return (