36 lines
1.9 KiB
Text
36 lines
1.9 KiB
Text
==How to code in Metamaps
|
|
|
|
Here are the important folders/files:
|
|
|
|
config/database.yml: This file is your database configuration. If it doesn't exist, copy it from config/database.yml.default and then get it set up. config/database.yml is in .gitignore
|
|
|
|
app/assets/javascripts/application.js: Global Javascript
|
|
|
|
app/assets/javascripts/Jit/*: These files handle all code that uses the Javascript Infovis Toolkit, so realistically, most code for laying stuff out is in here.
|
|
|
|
app/assets/controllers/*: These files define actions you can do on the different database objects. So for instance, what happens when you edit a Synapse? Check in app/assets/controllers/synapse_controller.rb, in the edit block
|
|
|
|
app/assets/views/*.html.erb: Files in here define either html that is displayed when a certain action is called (like edit, or create) on a thing. E.G. app/assets/views/topic/new.html.erb would have a form for creating a new topic. We don't use that way very much anymore though. "Partial" views can be called elsewhere in ruby code and are prefixed with an underscore. So we focus more on the files starting with an underscore. Read through the comments at the top of each file to understand what they all do.
|
|
|
|
app/assets/views/*.js.erb: Javascript that is called in response to, e.g., editing or creating a topic, synapse, etc.
|
|
|
|
Setting up the database:
|
|
|
|
1) Copy database.yml.default to database.yml
|
|
- Then you'll need to figure out how to configure it to work with Postgresql (which you need to install - try Herokuapp's exe or app)
|
|
2) In a terminal:
|
|
$ rake db:create
|
|
$ rake db:migrate
|
|
$ rake db:fixtures:load
|
|
|
|
Running the server:
|
|
|
|
$rails s #runs the server
|
|
$
|
|
$rails c #gives you an interactive console
|
|
|
|
==Installing on Ubuntu
|
|
|
|
I had a lot of trouble installing on Ubuntu
|
|
I had to install postgresql and libpq-dev. I had to do $rvm reinstall ruby-1.9.3-p125
|
|
execjs complained there was no runtime, so I added gem 'therubyracer' to the Gemfile
|