This is the open source code for the NuPIC Website hosted at http://numenta.org
- Web Platform:
- HTML5 markup semantic page structure
- HTML pages are found in
./**/*.html
- These pages are wrapped in layout templates found in
./_layouts/
- These pages pull in partial include templates from
./_includes/
- Pages and Includes will load and render Markdown
.md
text content from the./_includes/content/
directory
- Pages and Includes will load and render Markdown
- These pages are wrapped in layout templates found in
- Final output is generated and served from the
./_site/
directory
- HTML pages are found in
- CSS3 styling with
SASS preprocessing
- Pages load CSS from the
./assets/css/
directory.- These files originate as
.scss
SASS files- The SASS files include template partials from the
./_sass/
directory
- The SASS files include template partials from the
- These files originate as
- Pages load CSS from the
- JS functionality
- HTML5 markup semantic page structure
- jQuery dom helper lib
- Bootstrap responsive frontend framework
- Git source control
- GitHub source git hosting
- GitHub Pages web hosting
- Source Repo: https://github.com/numenta/numenta.org
- GitHub source git hosting
- Ruby lang
- RubyGems packages
- bundler packager
- jekyll static site generator
- github-pages local devel
- RubyGems packages
- Node.js lang
- npm packages
- Gulp streaming build tooling
- KSS Living Styleguide generator
- SASS CSS pre-processor language
- Web Testing: Mocha, Casper + Phantom, Chai + Should
- npm packages
Example of a quick Mac OS X setup:
brew install git ruby node
git clone [email protected]:numenta/numenta.org.git
cd numenta.org
gem install bundler
bundle install
npm install
Build and Serve local dev site:
npm run dev
View local development site:
Test by starting up a dev webserver on default port (8008) and run webtests and linkchecks against local environment:
# use defaults
npm run test
# customize test target if needed (defaults listed)
TEST_HOST=http://localhost TEST_PORT=8008 TEST_PATH= npm run test
Build:
- Modify
_config.yml
and setbaseurl
to be/numenta.org
- Push changes to your own github
username/gh-pages
branch - Note: Living Styleguide doesn't work fully on Staging yet, it doesn't know
about the gh-pages Jekyll
baseurl
setting.
View: Your own staging site will build and be available:
http://username.github.io/numenta.org/
Test against your Staging:
TEST_HOST=http://username.github.io TEST_PORT=80 TEST_PATH=/numenta.org npm run test
Build:
- In
_config.yml
setbaseurl
to behttp://numenta.org
- Changes to the
gh-pages
branch of the numenta.org repo are automatically built and pushed to production by GitHub Pages - Changes, Pull Requests, and Issues are welcome and appreciated
- First, please make sure to sign the Contributor licenese
- Create a Pull Request
against
numenta/numenta.org:gh-pages
branch
- Continuous Integration builds on Travis-CI: https://travis-ci.org/numenta/numenta.org
View: Production build is available at the main URL:
http://numenta.org
Test against Production:
TEST_HOST=http://numenta.org TEST_PORT=80 TEST_PATH= npm run test
- Markdown Text Content:
- Main content text is stored as markdown here:
_includes/content/
- Quick snippet to load a Markdown text block:
{% include base/markdown.html file='text.md' %}
- Quick snippet to load a Markdown text block:
- Main content text is stored as markdown here:
- Links:
- Social Sharing link URLs do not have full hostnames when in Development or Staging, but they will be full in Production.
- DO NOT forget to include the
{{ site.baseurl }}
template variable on internal links.- If you forget to use it, you will break staging sites.
- Use
&
instead of&
within links.- (Local Jekyll may run fine, but GitHub Pages may die without warning.)
- Living Styleguide
- Clean, Simple, Modern, Intelligent style
- Mobile First
- Standards-compliant as possible
- Support a wide array of users with accessibility needs
- Retina images automatically loaded via
Retina.js - for
image.png
, expects a 2x resolution file named[email protected]
- Keep Standards-compliant as possible
- Main pages should pass as 100% fully valid HTML 5 (automate?)
- Browser and device support
- Support a wide array of users with accessibility needs
- Node Style: 2 space text file indentation, 80-width text files, etc.
- Clean simple file and directory names, no spaces (please use dash "-" instead) with lowercase and alphanumeric characters.
- Keep local dev Ruby gems updated:
bundle update
- Modules:
node_modules
meant for inclusion by the browser (jquery, bootstrap, etc) are stored in source control, and copied to_site/node_modules
on build, where the browser can get to them.node_modules
not meant for the frontend (devDependencies, etc) should be ignored in.gitignore
and_config.yml
.