- Intro to WordCamp Development
- How To Contribute With Git and Source Control
- How To Contribute With Sass and Gulp
- Setting Up A Local Development Environment
- Style Guide
- Helpful Resources for WordCamp Development
WordCamp sites are a different breed than regular WordPress sites - they are actually a multisite installation from WordCamp.org. This means that there are unique features and restrictions that help to standardize all WordCamp websites. For instance you gain access to a "Coming Soon" page, which gives you a quick placeholder while you develop the site. But you also can't add custom PHP or Javascript. You can read more details in the handbook.
The theme used for WordCamp Lehigh Valley's 2018 website is CampSite 2017 and is a lightweight theme based on the popular starter theme Underscores (often abbreviated "_s"). It is highly customizable with 23 widget areas, and it also features a Day of Event template, making it easier to highlight the most important info for attendees during the day.
WordCamps come with a really handy feature called Remote CSS. Found under Apperance > Remote CSS, you'll find you can add a git repository. We use a webhook in this repo to automatically sync a style.css
file with the live site. Everytime a commit is pushed, our styles will be downloaded, sanitized, minified, stored as a local copy, and finally enqueued as a stylesheet alongside the theme's default stylesheet. Pretty sweet! For this repository, the style.css
file is found in the root of the directory.
If this is your first time using git and source control, these instructions will provide a simplified workflow to easily collaborate with others and contribute to the project. This ensures that everyone working on the project is working on the latest version as well as providing a complete history of all changes made in case we ever need to revert back to a previous version.
If you'd like a great resource for learning more about git, then check out the free book Pro Git 📘 for further documentation and examples.
-
If you don't have one already, create a github profile. Message or email me your username so I can add you as a contributor to this project. (If you'd like, you can also star this repository 🌟)
-
In your terminal or command line program, move into the directory you'd like the project to reside.
cd ~/sites
- Clone the repository. This will create a folder called wclv2018 containing all of the content on the repo.
git clone https://github.com/koakekuna/wclv2018.git
-
Make changes to the repo with your text editor or IDE of choice. Remember only the root
style.css
file is synced with the WordCamp site. -
Add your changes. This will stage all of the changed files to be commited.
git add .
- Make a commit with a short message. It's recommended to use an action verb in the present tense for the first word (e.g. fix, update, remove, etc...).
git commit -m "add header styles"
- Push your changes to the repo. Congratulations – The WordCamp site should be updated with the changes that you made! 🎉 👍
git push
- Make sure you're in your local wclv2018 folder. Pull the most recent changes from the repository.
git pull
- Repeat steps 4-7 from the instructions for First Contribution.
We can use "build tools" to automate repetitive tasks such as preprocessing, minification, adding browser support, and much more! There are many options out there to accomplish this, but this tutorial will use Gulp.
The process is essentially to provide an input, watch Gulp do it's magic, and then we're given an output.
Our input will be a Sass file ./style.scss
. Sass is super handy and helps to keep our code DRY as well as provide neat features like variables, nesting, mixins, and much more.
The gulp magic (for now) simply converts our Sass into standard CSS that browsers can read. Eventually, I'll add support for linting, cross-browser compatibility, source maps, and minification.
Since we're using the Remote CSS feature, the final output will always be the ./style.css
file.
./style.css
, and you save changes to ./style.scss
, you'll overwrite the changes from the other person. Not to worry, with git we can always recover, but ideally all contributors should only work on ./style.scss
.
- In your terminal, change directories into wherever your local copy of this repository resides.
cd ~/sites/wclv2018
- Pull the most recent changes
git pull
- Install all the libraries and modules we'll need for development, as specified in
package.json
. This will create a node_modules folder and stash them inside here.
npm install
- Convert the sass found in
style.scss
to regular css instyle.css
gulp sass
- If you feel like you'll be making a lot of edits in a short amount of time, you can also "watch" for changes to
style.scss
. Anytime you save the file, it will automatically rungulp sass
to convert the file to css.
gulp sass:watch
-
Follow the steps outlined here. These instructions will take you through installing VVV, creating a file called
vvv-custom.yml
, and specifying options for the meta-environment. Since we only care about WordCamps, we can keep"wordcamp.test": true
, and set everything else tofalse
. -
Make sure you've reprovisioned. After that's complete start up VVV.
vagrant reload --provision
vagrant up
-
If you go to http://wp-meta.test, you should see links to all of the available sites. Log in to central.wordcamp.test with
admin
andpassword
. Go to the network admin dashboard and navigate to sites. You could add an entirely new site, but I ran into some issues, and it's easier to just alter the blank2014.new-site.wordcamp.test
. i. Go to Edit Site, change the Site Address on the Info tab, as well as Siteurl and Home in the Settings tab. I named ithttp://2018.lehighvalley.wordcamp.test
. ii. Invagrant-local/www/wordpress-meta-environment/wordcamp.test/provision/vvv-hosts
, you'll see a list of all the WordCamp URLs. Change2014.new-site.wordcamp.test
to2018.lehighvalley.wordcamp.test
. iii. In your terminal, we need to reload VVV -vagrant reload
-
The URL
2018.lehighvalley.wordcamp.test
should work now! To change themes to CampSite 2017, you'll need to enable it at the network level. If you need to copy the live site, sign into it and go to dashboard > Tools > export. This will export a.xml
file. Then in your local site, go to Dashboard > Tools > WordPress (Run Importer). You might still have to manually update somethings in the customizer.
$color-brand-primary: #990303;
$color-brand-secondary: #d39740;
$color-text: #252525;
$color-text-weak: #383838;
$color-text-strong: #000000;
$color-text-weak-invert: #dfdfdf;
$color-text-strong-invert: #ffffff;
Carrois Gothic is used for the headers Monteserrat is used for body text, buttons, forms, etc.
WordCamp Website Tips and Tricks
Setting up Your WordCamp Theme