NOTE: Related code is not quite stable yet, be aware that this document might be out of sync with the actual behavior. Current version of this instruction corresponds to the code commit ec6730c9fc02ee8a4bece061cae5a3eb9d2ce779
To add a new community with the name demo, we should follow the following protocol:
-
All community-specific assets should be added to the
/src/assets/themes/demo
folder. -
Community meta-data file should be created under the path
/src/server/tc-communities/demo/metadata.json
:{ "authorizedGroupIds": ["12345"], "challengeFilter": { "groupIds": ["12345"] }, "challengeListing": {}, "communityId": "demo", "communitySelector": [{ "label": "Demo Community", "value": "1" }, { "label": "Cognitive Community", "redirect": "http://cognitive.topcoder.com/", "value": "2" }, { "label": "iOS Community", "redirect": "https://ios.topcoder.com/", "value": "3" }], "groupIds": ["12345"], "leaderboardApiUrl": "https://api.topcoder.com/v4/looks/0/run/json/", "logos": [ "/themes/demo/logo_topcoder_with_name.svg" ], "additionalLogos": [ "/themes/demo/logo_topcoder_with_name.svg" ], "hideSearch": true, "chevronOverAvatar": true, "menuItems": [ { "title": "Home", "url": "." }, { "title": "Learn", "url": "learn" }, { "title": "Challenges", "url": "challenges" }, { "title": "Leaderboard", "url": "leaderboard" } ], "newsFeed": "http://www.topcoder.com/feed", "description": "A berief description which will be displayed in dashboard", "image": "1.jpg", "terms": [21153] }
Its fields serve the following purposes:
Note that we have three places where user groups can be mentioned in this config:
authorizedGroupIds
(Optional) controls authorizations necessary to access community;groupIds
controls who is considered to be a member of community; andgroupIds
(Optional) insidechallengeFilter
allows to filter challenges included into community by their user group affinity.Technically, when application server serves configuration object for a specified community, it extends each of these arrays by descendant groups (it helps to significantly simply a lot of related code).
authorizedGroupIds
- String Array - Optional. Array of group IDs. If specified, access to the community will be restricted only to authenticated visitors, included into any of these groups, or any of their descendant groups. If undefined, community will be accessible to any visitors (including non-authenticated ones).challengeFilter
- Object - Challenge filter matching challenges related to the community. This object can include any options known to the/src/utils/challenge-listing/filter.js
module, though in many cases you want to use just one of these:/* Matches challenges belonging to any of the groups listed by ID. */ { "groupIds": ["12345"] } /* Matches challenges tagged with at least one of the tags. */ { "tags": ["JavaScript"] } /* Matches challenges belonging to any of the groups AND tagged with * at least one of the tags. */ { "groupIds": ["12345"], "tags": ["JavaScript"] }
challengeListing
- Object - Optional. When provided, it holds configuration for the challenge listing shown inside the community. This config object may have the following fields:openChallengesInNewTabs
- Boolean - Optional. When set, challenge listing opens challenge details pages in new tabs. Defaults totrue
.prizeMode
- String - Optional. Modifies the way the prizes are shown in challenge cards. Valid values are:hidden
- Prize components are just hidden;money-eur
- Prizes are converted to EUR;money-inr
- Prizes are converted to INR;money-usd
- Prizes are shown in USD (no actual conversion needed);points
- Points are shown rather than the prizes. The points are taken fromdrPoints
field of challenge objects. There is no prizes tooltip in this case.
communityId
- String - Unique ID of this community.communitySelector
- Object Array - Specifies data for the community selection dropdown inside the community header. Each object MUST HAVElabel
andvalue
string fields, and MAY HAVEredirect
field. Ifredirect
field is specified, a click on that option in the dropdown will redirect user to the specified URL.groupIds
- String Array - Community user groups. All members of these groups, or their descendants, will be treated as members of the community. Join Community functionality, where available, adds user to the first group from this array. Most probably, this behavior will be updated soon.leaderboardApiUrl
- String - Endpoint from where the leaderboard data should be loaded.logos
- String Array | Object Array - Array of image URLs to insert as logos into the left corner of community's header, alternatively the array may contain JS objects of shapeFor such elements{ "img": "<SOME-IMAGE-URL>", "url": "https://www.topcoder.com" }
img
will be used as the image source, andurl
will be the redirection URL triggered by a click on the logo.additionalLogos
- String Array - Array of image URLs to insert as logos into the right corner of community's header.hideSearch
- Boolean - Hide/Show the search icon.chevronOverAvatar
- Boolean - Render a chevron-down instead of the user avatar.menuItems
- Object Array - Specifies options for the community navigation menu (both in the header and footer). Each object MUST HAVEtitle
andurl
fields. For now,url
field should be a relative link inside the community, within the same path segment.newsFeed
- String - Optional. URL of an XML blog feed to be used to render news section at a custom page. To actually render the news section, you should include it into the page code like (also see as example/src/shared/components/tc-communities/communities/wipro/Home/index.jsx
):The/* This goes inside the import section in the beginning of the file. */ import NewsSection from 'components/tc-communities/NewsSection'; /* This goes into appropriate place of the render function. */ <NewsSection news={props.news} />
<NewsSection />
component does not render anything, if itsnews
property is null or an empty array, thus it can be kept inside the page code even when there is no news feed configured for a community.description
: A berief description which will be displayed in dashboard.image
: A image that located at/assets/images/tc-communities/background
will be displayed in dashboardterms
- Array of Numbers - Optional. If provided, it should hold an array of Topcoder term of use IDs; agreement to all these terms will be necessary to self-join the community. Beside this, it has no other effects at the moment.
-
Custom pages of the community (anything beside
Challenges
andLeaderboard
) should be created inside/src/shared/components/tc-communities/communities/demo
. At the moment all communities have two custom pages:Home
andLearn
, you may just copy these from an existing community, and then customize to your particular needs. -
The routing inside community, and code splitting of the related code, should be set up inside
/src/shared/routes/Communities
:- Copy/paste one of the existing community folders and rename it into
/src/shared/routes/Communities/Demo
; - Inside
/src/shared/routes/Communities/Demo/index.jsx
you should change the name of code chunk in two places it is present (as value ofchunkName
prop, and insidewebpackChunkName
"magic comment"); - Inside
/src/shared/routes/Communities/Demo/Routes.jsx
you define necesary routing, as with usualreact-router
routing code; - Finally, you link this routing code into
/src/shared/routes/Communities/Routes.jsx
.
- Copy/paste one of the existing community folders and rename it into
-
At this point demo community is ready and accessible at the
/community/demo
route of the App (i.e., if we deploy dev version of the App tocommunity-west.topcoder-dev.com
, community will be accessible ascommunity-west.topcoder-dev.com/community/demo
).To make demo community accessible via a dedicated sub-domain, e.g. like
demo.topcoder-dev.com
, you should edit/src/shared/routes/subdomains.js
; adddemo: 'demo',
record (i.e. the format issubdomain: 'communityId'
) into theSUBDOMAIN_COMMUNITY
map. Beside it you should:- Ensure that the web-server where the App is deployed allows access to the subdomain
demo.topcoder-dev
, and redirects incoming requests to the App. - Ensure that Topcoder
accounts-app
allows to authenticate from the new subdomain address.
- Ensure that the web-server where the App is deployed allows access to the subdomain