UI for Topcoder Event Leaderboards
Nodejs (version 8+) Contentful API
You need to provide configuration values for the following:
PORT // The port on which the server will run. The default port is 3000.
CONTENTFUL_SPACE_ID // Contentful Space ID
CONTENTFUL_ACCESS_TOKEN // Contentful Delivery API access token
CONTENTFUL_HOME_ENTRY_ID // Entry id for the content relevant for the home page
CONTENTFUL_MESSAGE_ENTRY_ID // Entry id for the content relevant for the message page
CONTENTFUL_COUNTDOWN_ENTRY_ID // Entry id for the content relevant for the countdown timer page
HOST // URL address where the app is hosted, without any trailing slash "/". Example: http://localhost:3000
NODE_ENV // self explanatory
Install the dependencies
npm install
The app has been developed using Next.js
To make changes to the app and test locally, set the environment variables and execute the following command
npm run build
npm start
If you have set PORT=3001
in your environment variable, then you can access the app at http://localhost:3001
.
The app has already been configured for deployment on heroku. No additional changes needed.
There are 3 pages currently. Each page has its own content model and content that needs to be set up as described below. In order to get the data for each page, you need to make an api call to the server at route /content/:pageName
where pageName
is the environment variable key of the relevant page that has the contentful entry id of the data as its value. Example
This page would be the first page to show when a round is about to begin. It displays the Topcoder Open logo and the sponsors. It does not reveal much about the round, other than the track and the round number.
The content model for this page is as described below:
logo: // The logo that is shown in the header as well as at the center of the page
primaryColor: // The color theme to use for the header background and the track name. Value provided here should be same as the value used in a css style (example: #333333)
track: // The name of the track
round: // The round. Example "round 1"
eventStartDateTime: // The date and time when the event will start
mainSponsor: // The image for the main sponsor
otherSponsors: // Images for other sponsors
This page is useful to show an informative message to the user. Besides the messages in the ticker, this page also contains a primary message that can be shown to the user.
The content model for this page is as described below:
logo: // The logo that is shown in the header as well as at the center of the page
primaryColor: // The color theme to use for the header background and the track name. Value provided here should be same as the value used in a css style (example: "#333333")
track: // The name of the track
round: // The round. Example "round 1"
eventStartDateTime: // The date and time when the event will start
message: // The primary message to show the user. Example: We will be back soon
tickerMessages: // List of Short Text. Messages to show to the user at the bottom ticker
tickerType: // Media. Used to display the type of messages that will be shown in the ticker
tickerSeparator: // Media. Separator that is shown in between messages in the ticker
mainSponsor: // The image for the main sponsor
otherSponsors: // Images for other sponsors
This page is used to show a countdown timer that counts down until the track / round starts.
The content model for this page is as described below:
logo: // The logo that is shown in the header as well as at the center of the page
primaryColor: // The color theme to use for the header background and the track name. Value provided here should be same as the value used in a css style (example: "#333333")
track: // The name of the track
round: // The round. Example "round 1"
eventStartDateTime: // The date and time when the event will start
tickerMessages: // List of Short Text. Messages to show to the user at the bottom ticker
tickerType: // Media. Used to display the type of messages that will be shown in the ticker
tickerSeparator: // Media. Separator that is shown in between messages in the ticker
mainSponsor: // The image for the main sponsor
otherSponsors: // Images for other sponsors
This page lists all the finalists for a track
The content model for this page is as described below:
logo: // The logo that is shown in the header as well as at the center of the page
primaryColor: // The color theme to use for the header background and the track name. Value provided here should be same as the value used in a css style (example: "#333333")
track: // The name of the track
round: // The round. Example "round 1"
eventStartDateTime: // The date and time when the event will start
tickerMessages: // List of Short Text. Messages to show to the user at the bottom ticker
tickerType: // Media. Used to display the type of messages that will be shown in the ticker
tickerSeparator: // Media. Separator that is shown in between messages in the ticker
mainSponsor: // The image for the main sponsor
otherSponsors: // Images for other sponsors,
finalists: // JSON array of objects, where each object has the following structure:
handle: // member handle
country: // member country
profilePic: // url for the member\'s profile pic
countryFlag: // url for the member\'s country\'s flag
This page lists all the finalists for a track as well as the details of 1 finalist
The content model for this page is as described below:
logo: // The logo that is shown in the header as well as at the center of the page
primaryColor: // The color theme to use for the header background and the track name. Value provided here should be same as the value used in a css style (example: "#333333")
track: // The name of the track
round: // The round. Example "round 1"
eventStartDateTime: // The date and time when the event will start
tickerMessages: // List of Short Text. Messages to show to the user at the bottom ticker
tickerType: // Media. Used to display the type of messages that will be shown in the ticker
tickerSeparator: // Media. Separator that is shown in between messages in the ticker
mainSponsor: // The image for the main sponsor
otherSponsors: // Images for other sponsors,
finalists: // JSON array of objects, where each object has the following structure:
handle: // member handle
country: // member country
profilePic: // url for the member\'s profile pic
countryFlag: // url for the member\'s country\'s flag
isActive: // boolean. Indicates which members details are being shown. Can be set on only one member at any time
finalistDetails: // JSON Object with the following structure:
profilePic: // url of the members profile pic, in a specific pose
fullName: // full name of the member
countryFlag: // url of the member\'s country\'s flag
stats: // object containing the member\'s stats such as
rating:
competitions:
rank:
wins:
},
badges: // array of url strings that contain the images for the badges earned by the member
This page lists the winners for a track
The content model for this page is as described below:
logo: // The logo that is shown in the header as well as at the center of the page
primaryColor: // The color theme to use for the header background and the track name. Value provided here should be same as the value used in a css style (example: "#333333")
track: // The name of the track
round: // The round. Example "round 1"
eventStartDateTime: // The date and time when the event will start
tickerMessages: // List of Short Text. Messages to show to the user at the bottom ticker
tickerType: // Media. Used to display the type of messages that will be shown in the ticker
tickerSeparator: // Media. Separator that is shown in between messages in the ticker
mainSponsor: // The image for the main sponsor
otherSponsors: // Images for other sponsors,
finalists: // JSON array of objects, where each object has the following structure:
handle: // member handle
country: // member country
profilePic: // url for the member\'s profile pic
countryFlag: // url for the member\'s country\'s flag
winnersImages: // Images for the winners, arranged in the order in which they won
prizes: // List of Short Text. Prizes for the winners, arranged in order