This is the repo for Brown CCV's static website built with Hugo.
To make contributions, first clone the repo and install the dependencies:
git clone https://github.com/brown-ccv/ccv-website.git
cd ccv-website
Create a .env
file with the contents of .env.example
in the root of your project.
- The .env file is included in .gitignore and should never be committed.
- You can obtain a Github Access Token by following these instructions. The Github Access Token only needs the
public_repo
scope.
First, install the dependencies:
npm install
To run it locally:
npm run serve
Go to localhost:1313/
To build the site into the public/
folder. This generates all the files needed to publish the site, but doesn't start the server.
npm run build
Open an issue using one of the provided templates. Follow the instructions and complete all items in the issue template. Consider assigning it to yourself and starting a pull request following the contribution guidelines below.
If you wish to contribute with content updates, style changes, new features, or bug fixes, read the full contributing guidelines below and follow the contribution workflow.
The main branches are:
master
(default): development/staging branch. Changes to this branch come from topic branches. Contributors should branch offmaster
to work on their changes. A PR should be submitted tomaster
, add the appropriate label to the changes being proposed. Reviews are required before merging. The topic branch will be deleted when merged.production
: this is the production branch. Changes to this branch come from PRs frommaster
. PRs need to be reviewed and approved (mostly check the staging website). Only members of website-admin team can approve and merge PRs to production.
Changes happen in topic branches. Topic branch names start with the type of the change <change_type>-*
(see types below). If multiple changes are expected in the same branch, name the branch updates-*
and add the labels corresponding to the change type in your PR. Topic branches are created off master
.
Once changes are done, a PR is submitted to master
with the corresponding labels, and a review is requested from up to 3 reviewers (depending on the type of change - content (sometimes) or technical (always)).
- Hotfix: bugs/mistakes that must be addressed in production. These changes happen in topic branches
hotfix-*
. - Data: changes to files in the data folder. Includes people and opportunities. Changes (add/remove/update) to items in those sections. These changes happen in topic branches
data-*
. - Content: changes to content (in content folder). These changes happen in topic branches
content-*
- What's New: this is a special case of content changes. All what's new items will be removed every month.
- Style: basic style changes. These changes happen in topic branches
style-*
- New Feature: major UI changes, new features, pages, new content, etc. These changes happen in topic branches
feature-*
. New features requests happen in issues with thesuggestion
label and are discussed during triage meetings.
When committing your changes, use npm run commit
instead of git commit -m
. Follow the instructions on the terminal to create your conventional commit message. Click here to learn more. This is required and the technical reviewer should make sure only changes with conventional commits are merged.
- https://ccv.brown.edu
- deployed from
production
branch. - will include all changes accepted into the
master
branch. - PRs from
master
. Only members ofwebsite-admin
team are able to approve/merge PRs toproduction
.
- https://datasci.brown.edu
- deployed from
master
branch. - for changes to make it into this branch they need to be reviewed and approved.
- no direct push allowed. All changes come from PRs from topic branches.
A Slack channel gh-ccv-website
is linked to this repository. Join that channel if you want to receive notifications when issues, PRs, and deployments are created.
Issues are welcome and are the recommended way to request or suggest changes. Use one of the templates provided and add labels as needed.
Issues labeled with suggestion
will be brought up for discussion during triage meetings. If a suggestion is approved, the issue will get the label next-up
or fast-track
depending on urgency and will be assigned to a member of website-dev
or website-content
. Priorities will also be discussed in the triage meetings and will be communicated to the assignee on the issue. If the suggestion is declined, a new label declined
will be added and the issue will be closed. Declined suggestions can be brought up for discussion in future meetings.n
Use the template provided and fill in all the information requested and assign the appropriate reviewers. Make sure to fill this out correctly and check the appropriate checkboxes. A checklist for the reviewers will be created based on this.
A version of the website will be deployed for review to Heroku and a link to the deployed website will be added to the PR comments section. To view the website, click on view deployment
. In addition, when the review site is deployed, the gh-ccv-website
will be notified.
For content changes:
- assign reviews to website-content and website-dev teams or to a specific person that you think should be the reviewer.
- 2 reviewers required (1 technical and 1 content), one of whom must not have been close to the development/design of the feature.
For new feature changes:
- assign reviews to website-content and website-dev teams.
- 3 reviewers required (1 technical and 2 content), one of whom must not have been close to the development/design of the feature.
For hotfix, data, and style changes:
- assign reviews to website-dev team for hotfix, data, and style changes.
When a PR is merged into master
, the topic branch that originates the PR is automatically deleted.
A checklist will be created in the comments section of the PR. Follow those instructions and use the checklist. And review the website deployed to Heroku.
The reviewer who merged the PR into master
is responsible for starting a PR to production
and assigning it to the website-admin
team once the waiting period (if applicable) is complete. Wait times are automatically tracked with the 1 day wait
and 2.5 day wait
labels and changed to ready
when 24 or 60 non-weekend hours have lapsed since the last commit. The wait times are as follows:
- content, other - 1 days
- new feature - 2.5 days
- data, hotfix, styles - No wait
The member from the website-admin
will announce on the slack channel gh-ccv-website
the waiting period for the PR to give everyone interested a chance to look at the staging site.
There are two types of reviewers. Reviewers are part of teams on GitHub and can find a checklist in the team discussion board.
- website-dev: will check if the code meets standards.
- website-content: will check the content, proof read, etc.
- website-admin: members who have permission to review and merge PRs from
master
toproduction
.
Sections:
- News (Blog) - https://www.medium.com/brown-ccv
- Showcase Projects
- Documentation - https://app.gitbook.com/@brown-cis/spaces
- Data folder: People & Opportunities
- Content folder: Home, Services, About
This is the blog section. It's now on Medium.
Project, labs, initiatives, groups, collaborations, or anything we want to showcase. Items under this section will show up on the home page's carousel.
---
title: "{{ replace .Name "-" " " | title }}"
date: {{.Date}}
draft: false
team: ""
text: ""
image: "/images/<image.png>"
href: ""
cfa: "Launch the App" # call for action button: Read More, Learn More, Launch the App, More on Github...
---
npm run new content/english/projects/project.md
Documentation is hosted on Gitbook. Check the docs here
For documentation related issues, open issues directly on the doc repo.
- Changes to the
data
folder go straight torelease
and don't have to wait until the next release cycle. Those changes are related to adding, updating or deleting items frompeople
andopportunities
.
data/people.yaml
- name: Ashley S. Lee
team: Advanced Research Computing
title: Data Scientist
github_username: alee35
brown_directory_uuid: 380094e2-6f9d-47cf-91ce-e636876a58cf
bio: "Ashley received training in Biology and Data Science at the University of Virginia
and dabbled in a variety of careers including Bus Driver, Bagel Slinger, and Chief
Fiduciary at Smoothie King. She enjoys food and beverage, bodies of water, jokes,
caring for her beloved dog and plants, and resenting her cat."
image: ashley.jpg
data/opportunities.yaml
- title: Research Services Support Specialist
team: CCV Operations
subteam: User Services
link: "https://brown.wd5.myworkdayjobs.com/en-US/staff-careers-brown/job/180-George-Street/Research-Services-Support-Specialist_REQ151702"
The majority of the website's content can be found under content/english/
in Markdown format.
- Home page:
content/english/_index.md
- About:
content/english/about/_index.md
- Services:
content/english/services/**/*
To create new files under services
use the command:
npm run new content/english/services/consulting/new_file.md
There are special shortcodes that can be used in the Markdown content files that generate styled html components that follow the website design. Find detailed information on how to write your markdown content and include shortcodes specific for CCV's website here.
It's possible to add content hosted in the Deskpro Knowledge Base. The content will be fetched at build time from the Deskpro RSS feed (https://ithelp.brown.edu/kb/ccv-website-articles.rss). For more information, reach out to CCV User Services team. If you are a content creator and are using Deskpro's Knowledge Base to serve content to the CCV Website, add the category Technical Services > CCV Website Articles
to your article. Only articles in that category will be fetched.
To add that content to a Markdown file, use the rss
shortcode with the article name as the only argument:
Note that the article name can be found in the article URL, for example, to add this article: https://ithelp.brown.edu/kb/articles/github-for-brown
, use:
{{< rss "github-for-brown" >}}
- Adding, updating, or deleting items from here do not require change to this repo. Fetching apps data requires a .env:
GITHUB_TOKEN=
GITHUB_USER=
ORGANIZATION=brown-ccv,compbiocore,dscov-tutorials
-
The .env file is included in .gitignore and should never be committed.
-
You can obtain a Github Access Token by following these instructions.
-
To add a new workshop/software to this list, add a file called
ready.yml
to your workshop/software repository (not this repo!), follow example below. -
If the repo is not part of one of these organizations: brown-ccv, compbiocore, dscov-tutorials, open an issue to let the admins know the new organization name.
repo: ccv-con
site_name: "CCV-Con Slide Archive"
authors:
- name: "Fernando Gelin"
github_user: fernandogelin
- name: "Mary McGrath"
github_user: mcmcgrath13
- name: "Paul Stey"
github_user: paulstey
repo_url: https://github.com/brown-ccv/ccv-con
site_description: "This repo houses links to the publically available slides from presentations at the CCV-Con Conference at Brown University."
docs_url:
type: workshop # required. choose one of [software, tutorial, workshop, documentation]
CCV's Calendar We also have an Events@brown calendar. https://event.brown.edu/ccv
To add events to the website, simply invite ccv-bot@brown.edu
to your event. Make sure to set a location, have a displayable name, and a nice typo-free, short description. The Bot needs to accept the invitation before it can be displayed on the website.
CCV's Google Calendar is connect to Events@Brown and will show events in both places