- DEVELOPER AND CREATIVE DIRECTOR: Choose a framework version to develop your work on. This repo will create a child theme using Responsive Framework 2x, which is the stable version. The beta version is Responsive Framework 3x and can be started from responsive-child-starter-3x. If you choose the beta version, you will get the newest updates, but you will also run into bugs which need to be fixed. Please factor in project time to assist in fixing these bugs when choosing versions.
- DEVELOPER: Please set up CodeClimate and branch protections.
- DEVELOPER: Please review supported technologies and see if any immediate changes are needed for your project. Apply security updates on first install using
npm run fix
, if any, and ensure the theme still compiles by runninggrunt build
. - CREATIVE DIRECTOR AND DEVELOPER: Please review the Plugins section of Supported Technologies, and add or remove any plugins as needed for your theme.
- CREATIVE DIRECTOR: Please import our standard label set.
- CREATIVE DIRECTOR: Please provide a brief description of the purpose of the theme in the next section, then fill out the project information section. and set up a new Github Project.
- CREATIVE DIRECTOR: Please set up a documentation site.
- CREATIVE DIRECTOR: Please review project information and see if any immediate changes are needed for your project.
- DEVELOPER: Please review development workflow and see if any immediate changes are needed for your project.
- ENTIRE TEAM: Please review project information together and approve.
- ENTIRE TEAM: Please review development workflow together and approve.
You're ready for work! Go ahead and delete this section when all boxes are checked.
A starter template for child themes of Responsive Framework 2. For Responsive Framework 3, please see https://github.com/bu-ist/responsive-child-starter-3x/.
Contents:
- Set up a new custom theme
- Install your development dependencies, including nvm if you haven't already.
- Run
nvm use
to set the correct node version. - Run
npm install
, thengrunt
to begin watching changes. - Upload to your sandbox to see changes.
npm install
: Install your development dependenciesgrunt
: Watch your theme for changes and compile when a change is detected.grunt build
: Manually build all theme assets.grunt version
: Force CSS and JavaScript to refresh when you deploy changes.
- Webteam: LINK HERE
- ID Presents: LINK HERE
- Staging/Live: LINK HERE
- ActiveCollab: LINK HERE
- Smartsheet: LINK HERE
- Github Issues: LINK HERE
- Github Projects: LINK HERE
Information for collaborators
- This project uses [PLEASE CHOOSE: GITHUB PROJECTS OR GITHUB PROJECTS BETA]. See the project here: [PROJECT LINK HERE]
- Boards you'll find:
- [PLEASE LIST IMPORTANT BOARDS]
- [ADD RELEVANT INFORMATION SPECIFIC TO YOUR WORKFLOW HERE]
- Git-Flow will be the workflow.
- Pull requests should stay in
draft
status until they are actually ready for review. - [todo] Decide how to handle
code review
vsfunctionality review
.
main
&develop
will be used, but never directly committed to.- All changes should be in branches based off of
develop
and include the issue # when there is one. Examples:- branches/18-repo-setup
- branches/29-foundational-styles
- branches/feature/53-glossary
- branches/hotfix/99-branding-explosion
- Frontend vs Backend branches. Only when complex & necessary should we make seperate branches created for the same feature/issue.
- Code reviews are required to merge.
- CodeClimate is not required to merge. However, you should make your best effort to fix CodeClimate errors within reason.
- All active development will happen in team member sandboxes.
- All code ready for review will be uploaded to the shared
id-presents
sandbox before review with the client. - All code that is merged to
develop
is ready to deploy to staging at any time. - All code that is released to staging will be done via release numbers.
Please update this if you have a newer version of Node and can verify the theme compiles with it.
Please remove any plugins you do not plan to support in this theme.
- Responsive Framework 2x
- BU Navigation
- BU Banners
- BU Front End Library
- BU Profiles
- BU Landing Pages
- BU Program Pages
- BU Filtering
- BU Post Details
- BU Sharing
- BU Slideshow
- BU Text Widget
- Course Feeds
- cmb2
- Display Posts
- Gutenberg in the following areas:
- [PLEASE LIST PAGES, SECTIONS, POST TYPES, ETC]
- BU PrePress
- BU Blocks
Name | Version | Purpose |
---|---|---|
node.js | 12.19.0 LTS | Support for npm |
npm | X | Package management. See package.json for a full list of packages. |
Name | Version | Purpose |
---|---|---|
Responsive Foundation (Required) | 4.0.0 | Basic styles and utilities for all Boston University themes |
BU PrePress (Optional, delete if irrelevant to this project) | X | Editorial tools for Boston University schools and colleges which produce magazines or other news publications. |
BU Blocks (Optional, delete if irrelevant to this project) | X | Custom Gutenberg blocks for Boston University websites. Required by BU PrePress. |
Name | Version | Purpose |
---|---|---|
@babel/core | See package.json | Allows you to use newer JavaScript (ES6) syntax, such as import and arrow functions. |
@babel/preset-env | See package.json | Allows you to tell Babel which browsers to provide compatibility for. Settings are set according to our browser support standards. |
@wordpress/babel-preset-default | See package.json | Default Babel preset for WordPress development. |
@wordpress/eslint-plugin | See package.json | JavaScript linting, configurations and custom rules for WordPress development. |
autoprefixer | See package.json | Adds browser prefixes to CSS. Used with PostCSS. |
babelify | See package.json | Sends anything going through Browserify on to Babel. |
browserify-shim | See package.json | Allows jQuery and other non-Common JS libraries to go through Browserify. |
eslint | See package.json | Lints JavaScript, checks against coding standards and finds errors. |
Name | Version | Purpose |
---|---|---|
grunt | See package.json | Compiles the theme SCSS and runs commands like linting. We plan to replace this in the future. |
grunt-browserify | See package.json | Lets you require modules. In this theme, it handles the jQuery dependency. |
grunt-contrib-clean | See package.json | Small utility to clean out files and folders as part of compiling. |
grunt-contrib-concat | See package.json | Combines separate JavaScript files into one as part of compiling. |
grunt-contrib-copy | See package.json | Copies files and folders as part of compiling. |
grunt-contrib-uglify | See package.json | Minifies files as part of compiling. |
grunt-postcss | See package.json | Adds CSS browser prefixes as part of compiling. |
grunt-sass | See package.json | Settings to compile SCSS files as part of compiling process. |
grunt-version | See package.json | Looks for a version number in package.json and copies it to other files during the compiling process. |
grunt-wp-i18n | See package.json | Sets internationalization theme domain text throughout the theme as part of compiling. |
node-sass | See package.json | Compiles the SCSS according to grunt settings as part of compiling. We currently use the LibSass setting behind the scenes as compiling engine. Dart Sass is possible to use, but is much slower. |
You'll see these types of errors in the terminal, and this should be your first stop if anything isn't working as expected, including styles not showing up. Try running the following if your theme is not compiling successfully when you run grunt build
.
- If this theme successfully compiled before, check for a code error first. Look for red in the terminal, and see if you can trace it back to a file and line number. If the error is in your code, try to fix the error. If the error is in Responsive Foundation, continue with the following steps to see if it can be resolved. Both CSS and JavaScript errors can cause this behavior.
- Delete
package-lock.json
, then runnpm install
, even if you have already run it before. - Run
node -v
andnpm -v
to see your current node and npm versions. Do they match the versions in the supported technologies list? If not, use nvm to change the version by runningnvm use [VERSION NUMBER]
, where[VERSION NUMBER]
is replaced with the version from the list above. - Run
npm rebuild node-sass --force
, then rerunnpm install
. This one is helpful if you see a Node Sass OSX bindings error, or just switched npm/node versions for this theme.
Once you've confirmed your theme is compiling, the next step is to make sure your files are uploading correctly.
- If you are using monitoring or upload on save, check that the monitoring is actually enabled.
- Check the settings in your FTP tool of choice (usually SFTP for Sublime Text, Publishing settings in Coda, or SFTP for VSCode). Is your theme mapped to the correct sandbox, and uploading to the correct folder?
- Create a simple text file in your code editor, such as
text.txt
. Upload (don't monitor) the file using your code editor. Now, open a FTP program such as Transmit, Filezilla, or Cyberduck, and navigate to your theme folder in the server. Did the file upload? If so, your FTP is working correctly, and this is either a monitoring problem (go back to step 1) or a CSS problem (go to the next section).
If you've confirmed a file is uploading, but the CSS you expect to see still isn't showing up, it's probably your CSS selector. Here's how to test that.
- Choose a very broad text selector you can easily see, such as
body
orh1
. Set the color to red, and use the important flag, like so:h1 { color: red !important; }
Upload your file again. - If you see the change, the problem is with your selector and overriding. If you do not see the change, try one more time with a different selector.
- If you still do not see the change, clear your cache. Try a hard refresh first (shift+cmd+r). You can also try opening a private window.
- If you still do not see the change, wait five minutes, and try again. Rarely, the issue will be with caching on the server side. Grab a coffee, come back, and give it one more try.
- If you're still not seeing the change here, it's time to ask for help. See if a designer or developer has a few minutes to help you out in the #interactive-design channel.