Skip to content

jpslav/webview

 
 

Repository files navigation

Connexions Build Status dependency Status devDependency Status

Development and Building

Below are instructions for hosting and building the site and a layout of how the code is organized.

CNX webview is designed to be run as a frontend for cnx-archive.

Installing & Hosting

Installing

  1. If necessary, install Node.js and npm (included with Node.js).
  2. Run npm install -g grunt-cli bower in the command line to install grunt-cli and bower.
  3. From the root webview directory, run npm install in the command line to install test and build dependencies.
  • npm install runs bower install and grunt install, both of which can also be run independently
    • bower install downloads front-end dependencies
    • grunt install compiles the Aloha-Editor (which is downloaded by bower)
Testing

From the root webview directory, run npm test.

Building

From the root webview directory, run grunt dist.

The dist directory containing the built site will be added to the root webview directory.

Updating

From the root webview directory, run npm run-script upgrade, which executes the following commands:

  1. npm update
  2. bower update
  3. grunt install --verbose

Hosting

For Development
  1. Install nginx
  2. Run grunt nginx:start (uses nginx.development.conf)
  3. Point your browser to http://localhost:8000/test for mock data
  4. If you have https://github.com/Connexions/cnx-archive installed, you can point your browser to http://localhost:8000
Customization Notes
  1. Update settings in src/scripts/settings.coffee if necessary to, for example, include the correct Google Analytics ID, and to point to wherever cnxarchive is being hosted.

  2. Ensure resources are being served with the correct MIME type, including fonts.

  • Example nginx MIME types that may need to be added:
  types {
      image/svg+xml           svg svgz;
      font/truetype           ttf;
      font/opentype           otf;
      application/font-woff   woff;
  }
  1. Configure your server to point at dist/index.html (or src/index.html for development)
  • Unresolveable URIs should load dist/index.html or src/index.html
  • If not hosting the site from the domain root, update root in src/scripts/settings.coffee
  • scripts, styles, and images routes should be rewritten to the correct paths
  • Example nginx development config:
  server {
      listen 80;
      server_name $hostname;
      root /path/to/webview/src/;
      index index.html;
      try_files $uri $uri/ /index.html;

      location /resources/ {
          proxy_pass http://localhost:6543;
      }

      location ~ ^.*/bower_components/(.*)$ {
          alias /path/to/webview/bower_components/$1;
      }

      location ~ ^.*/(data|scripts|styles|images)/(.*) {
          try_files $uri $uri/ /$1/$2 /test/$1/$2;
      }

      location ~ ^.*/test/(.*)/(.*) {
          try_files $uri $uri/ /test/$1 /test/$2 /test/index.html;
      }

      location ~ ^.*/test/(.*) {
          try_files $uri $uri/ /test/$1 /test/index.html;
      }
  }
  • Example nginx production config:
  server {
      listen 80;
      server_name $hostname;
      root /path/to/webview/dist/;
      index index.html;
      try_files $uri $uri/ /index.html;

      location /resources/ {
          proxy_pass http://localhost:6543;
      }

      location ~ ^.*/(data|scripts|styles|images|fonts)/(.*) {
          try_files $uri $uri/ /$1/$2;
      }
  }

Test Site

When running the development version of the site with its corresponding config, you can access a test version of the site that simulates AJAX requests by appending /test to the root URI (for example: http://localhost/test).

Note: Mock test data is only available for the College Physics book.

Directory Layout

  • bower_components/ 3rd Party Libraries (added after install)
  • node_modules/ Node Modules (added after install)
  • dist/ Production version of the site (added after build)
  • src/ Development version of the site
  • src/data/ Hardcoded data
  • src/images/ Images used throughout the site
  • src/scripts/ Site scripts and 3rd party libraries
  • src/scripts/collections Backbone Collections
  • src/scripts/helpers Helpers for Handlebars, Backbone, and generic code
  • src/scripts/models Backbone Models
  • src/scripts/modules Self-contained, reusable Modules used to construct pages
  • src/scripts/pages Backbone Views representing an entire page (or the entire viewport)
  • src/scripts/config.js Require.js configuration
  • src/scripts/loader.coffee App loader, responsible for setting up global listeners
  • src/scripts/main.js Initial script called by Requirejs
  • src/scripts/router.coffee Backbone Router
  • src/scripts/session.coffee Session state singleton (Backbone Model)
  • src/scripts/settings.js Global application config settings (remains in place after build)
  • src/styles/ App-specific LESS variables and mixins
  • src/test/ Test site
  • src/index.html App's HTML Page
  • tests/ Unit tests

License

This software is subject to the provisions of the GNU Affero General Public License Version 3.0 (AGPL). See license.txt for details. Copyright (c) 2013 Rice University.

About

Connexions web site

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • CoffeeScript 65.7%
  • CSS 31.2%
  • JavaScript 3.1%