Skip to content

Latest commit

 

History

History
148 lines (110 loc) · 5.11 KB

README.org

File metadata and controls

148 lines (110 loc) · 5.11 KB

Getting Started

In order to modify the IoT website you will need some software. We use “vagrant” to create a virtual machine to run this software to ensure that the correct versions are being used, regardless of platform and platform version.

You will need to install “VirtualBox” and “vagrant” [fn::If you are running under Linux, you can avoid using VirtualBox and can use “lxc” instead, which is much faster. See me for details.]

VirtualBox can be found at: https://www.virtualbox.org/wiki/Downloads

Vagrant can be found at: https://www.vagrantup.com/downloads.html

Download the appropriate installers and run them.

Assuming you have a “GitHub” account, you should clone the website source repository (assuming you are starting from your home directory)

Issue the following commands (The “#” and stuff after it is a comment, don’t type it in!):

git clone git@github.com:mit-cml/iot-website-source
cd iot-website-source
vagrant up  # <– This step will take a *long* time, particularly
            #    the first time you run it.

At this point vagrant is downloading a ubuntu (linux) VM, starting it up in VirtualBox and provisioning it, which means it is downloading the software needed to build the website. This takes quite awhile, but only the first time you do the “vagrant up” command.

Building the site from Source

Once the commands above are finished (successfully). You can now do:

vagrant ssh # <– This will connect you to the virtual machine
            #    your next command will be in the context of the
            #    virtual machine

# the next four lines might not be necessary, but Hal and Mark
# needed them. They are normally done by the provisioning of
# of the vagrant VM. But that can fail, so this ensures they
# really completed.
cd /vagrant
npm install
cd docs
npm install

# finally, do

cd /vagrant/docs
python makepages.py
npm run browser:development

This will compile the source of the website. It will be obvious if there are errors. If all goes well, you can go to “localhost:3000” on your host machine with a browser of your choice and see the site.

Building the site for public distribution

To build the site for upload to the distribution location you do:

cd /vagrant/docs
python makepages.py
npm run browser:build

If all goes well you can type “exit” (or control-D) to leave the virtual machine. You then do:

vagrant halt

This will shutdown the virtual machine. You can then to a “vagrant up” in the future to test/build the site again. It should be much faster then the initial time.

Updating the deployed site

At this point you are going to clone (or “pull” if you already have a copy) the production built website. You will then update the site from the files you built above and then you will push it out to production.

IMPORTANT: You will not be able to do this until you are authorized. Send your “ssh” public key (not private key) to jis@mit.edu and I can add you.

The details here are for the site as run from our own server at http://iot.appinventor.mit.edu. These details will change when we move to GitHub.

Assuming you do not have a copy of the site do (from your home directory):

git clone git@iot.appinventor.mit.edu iot-pages
cd iot-website-source/docs/build/
rsync -v -a * ../../../iot-pages/
cd ../src/www
rsync -v -a blocks ../../../../iot-pages/
cd ../../../../iot-pages
git add . --all
git commit # <– This will invoke an editor for you to put in the commit comment

The site should now be updated.

Where the pages are…

Adding pages is a bit complicated, but editing the content of existing pages should be pretty easy.

Page source (in Markdown) live in /vagrant/docs/src/app/pages. You can edit any of the pages in that directory and rebuild the site and you will see your changes.

Adding a new page

This is a little more complicated, but only a little.

Create your page in /vagrant/docs/src/app/pages. You then need to edit the makepages.py script to assign your page a path. Look at the lines that are there to see how to do it. You then need to edit /vagrant/docs/src/app/AppNavDrawer.js to add your page to the hierarchy of pages defined there. Again, look at the existing pages as a guide.

DO NOT EDIT /vagrant/docs/src/app/AppRoutes.js This file is automatically generated by the makepages.py script (which is why you edit the script to add a page).

So far we have two top-level drawers defined, “Teachers” and “Extensions”. You can add a new top-level draw. However to do so you also need to edit /vagrant/docs/src/app/Master.js. Look around line 160 where the existing top level drawers are mentioned. Add your draw there (using the code there as a guide).

When you are done, use the “npm run browser:development” (after running the makepages.py script) to test out your additions.