merge in connors css

This commit is contained in:
Shai Mor 2014-09-09 15:17:49 -04:00
commit d18806bb18
21 changed files with 629 additions and 552 deletions

3
CHANGELOG.md Normal file
View file

@ -0,0 +1,3 @@
## 2.5
- Initial release

92
CONTRIBUTING.md Normal file
View file

@ -0,0 +1,92 @@
# Contributing to Metamaps
Active involvement from the community is essential to help make Metamaps as beneficial for communities as it can be. You can help by reporting bugs, fixing bugs, adding features, contributing new modules and by providing feedback.
## Reporting bugs and other issues
If you think you've encountered a bug, do the following:
1. Make sure you are working with the latest version of the Metamaps `master` branch.
2. Browse through the [issues][metamaps-issues] to check if
anyone else has already reported. If someone has, feel free to add more
information to that issue to help us solve it.
3. If no one has yet submitted the issue you are encountering, add it in! Please be sure
to include as much information as possible, include errors, warnings,
screenshots, links to a video showing the problem or code that can reproduce
the issue.
## Contributing code
Metamaps is made possible by open source
contributors like you. We're very interested in getting help from the greater
community, but before you start it's important that you become acquainted with
our workflow. Following these guidelines below will make collaboration much
smoother and increase the chances that we will accept your pull request without
hiccups.
### Development Process
Our development process is very similar to the approach
described in the well-known article [A Successful Git Branching Model by Vincent
Driessen][git-branching-model]. Here's an overview:
* Our `master` branch is the branch upon which
Metamaps developers should be basing their work on. The `master` branch is not guaranteed to be stable.
* All commits intended for `master` should take place on your own personal
fork, and be submitted via pull request when ready.
* Only maintainers can accept pull requests from forks into the core Famo.us
repository.
* Please squash your commits into a single commit before making a pull request.
### Getting started
1. Make sure you have a [GitHub account](https://github.com/signup/free)
2. [Fork metamaps][fork-metamaps]
3. Keep your fork up to date. Metamaps is a fast moving project, and things are
changing all the time. It's important that any changes you make are based on
the most recent version of metamaps, since it's possible that something may
have changed that breaks your pull request or invalidates its need.
4. Make sure you have a [Contributor License Agreement][cla] on file.
5. Read on ...
### Contributor License Agreement
Before we can accept any contributions to Metamaps, we first require that all
individuals or companies agree to our Contributor License Agreement (CLA). The e-mail
address used in the pull request will be used to check if a CLA has already been
filed, so be sure to list all email addresses that you might use to submit your
pull requests when filling it out. Our CLA can be found [here][cla].
### Testing and Linting
TODO
### Branch grouping tokens
All pull requests submitted to Famo.us should occur on a new branch. For these
branches, we at metamaps use a short token indicating the nature of the branch in
question followed by a solidus (`/`) and a kebab-cased string describing the
branch. We are using the following tokens:
bug // bug fixes
wip // work in progress
feat // feature
Bug fixes follow a [slightly different format](#bug-fixes).
### Bug fixes
If you'd like to contribute a fix for a bug you've encountered, first read up on
[how to report a bug](#reporting-bugs-and-other-issues) and report it so we are
aware of the issue. By filing the issue first, we may be able to provide you
with some insight that guides you in the right direction.
[metamaps-issues]: https://github.com/Connoropolous/metamaps_gen002/issues
[git-branching-model]: http://nvie.com/posts/a-successful-git-branching-model/
[fork-metamaps]: https://github.com/Connoropolous/metamaps_gen002/fork
[cla]: http://metamaps.cc/cla

View file

@ -1,7 +1,7 @@
GNU AFFERO GENERAL PUBLIC LICENSE GNU AFFERO GENERAL PUBLIC LICENSE
Version 3, 19 November 2007 Version 3, 19 November 2007
Copyright (C) 2007 Free Software Foundation, Inc. [http://fsf.org/] Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
Everyone is permitted to copy and distribute verbatim copies Everyone is permitted to copy and distribute verbatim copies
of this license document, but changing it is not allowed. of this license document, but changing it is not allowed.
@ -618,3 +618,44 @@ copy of the Program in return for a fee.
END OF TERMS AND CONDITIONS END OF TERMS AND CONDITIONS
How to Apply These Terms to Your New Programs
If you develop a new program, and you want it to be of the greatest
possible use to the public, the best way to achieve this is to make it
free software which everyone can redistribute and change under these terms.
To do so, attach the following notices to the program. It is safest
to attach them to the start of each source file to most effectively
state the exclusion of warranty; and each file should have at least
the "copyright" line and a pointer to where the full notice is found.
<one line to give the program's name and a brief idea of what it does.>
Copyright (C) <year> <name of author>
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published
by the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
Also add information on how to contact you by electronic and paper mail.
If your software can interact with users remotely through a computer
network, you should also make sure that it provides a way for users to
get its source. For example, if your program is a web application, its
interface could display a "Source" link that leads users to an archive
of the code. There are many ways you could offer source, and different
solutions will be better for different programs; see section 13 for the
specific requirements.
You should also get your employer (if you work as a programmer) or school,
if any, to sign a "copyright disclaimer" for the program, if necessary.
For more information on this, and how to apply and follow the GNU AGPL, see
<http://www.gnu.org/licenses/>.

1
MacInstallation.md Normal file
View file

@ -0,0 +1 @@
TODO

55
README.md Normal file
View file

@ -0,0 +1,55 @@
Metamaps
=======
Welcome to the Metamaps GitHub repo.
## About
Metamaps is a free and AGPL open source technology for changemakers, innovators, educators and students. It enables individuals and communities to build and visualize their shared knowledge and unlock their collective intelligence. You can find out about more about the project at the [blog][site-blog].
You can find a version of this software running at [metamaps.cc][site-beta], where the technology is being tested in a private beta.
Metamaps is created and maintained by a distributed, nomadic community comprised of technologists, artists and storytellers. You can get in touch with us at team@metamaps.cc or @metamapps on twitter.
To get connected with the community interested in Metamaps, join our [Google+ community][community].
## Installation
Depending on which OS you are using, the instructions for getting set up with a local installation of the Metamaps software will vary. Because the software has both Node.js components, and RubyOnRails, getting set up with your local copy can take 1 to 2 hours.
- [For Windows][windows-installation]
- [For Ubuntu][ubuntu-installation]
- [For Mac][mac-installation]
## Contributing
Cloning this repository directly is primarily for those wishing to contribute to our codebase. Check out our [contributing instructions][contributing] to get involved.
## Documentation
- TODO
## Community
- If you would like to report a bug, please check the [issues][contributing-issues] section in our [contributing instructions][contributing].
- To participate in discussions and a public forum about Metamaps, join the [Google+ community][community]
- For contributors, read more instructions in [CONTRIBUTING.md][contributing].
## Licensing information
This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or(at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.
The license can be read [here][license].
Copyright (c) 2014 Connor Turland
[site-blog]: http://blog.metamaps.cc
[site-beta]: http://metamaps.cc
[community]: https://plus.google.com/u/0/communities/115060009262157699234
[license]: https://github.com/Connoropolous/metamaps_gen002/blob/master/LICENSE
[contributing]: https://github.com/Connoropolous/metamaps_gen002/blob/master/CONTRIBUTING.md
[contributing-issues]: https://github.com/Connoropolous/metamaps_gen002/blob/master/CONTRIBUTING.md#reporting-bugs-and-other-issues
[windows-installation]: https://github.com/Connoropolous/metamaps_gen002/blob/master/WindowsInstallation.md
[mac-installation]: https://github.com/Connoropolous/metamaps_gen002/blob/master/MacInstallation.md
[ubuntu-installation]: https://github.com/Connoropolous/metamaps_gen002/blob/master/UbuntuInstallation.md

View file

@ -1,89 +0,0 @@
== Metamaps
Metamaps is a free and open source technology for changemakers, innovators, educators and students. It enables individuals and communities to build and visualize their shared knowledge and unlock their collective intelligence. You can find out about more about the project at http://blog.metamaps.cc.
You can find a version of this software running at http://metamaps.cc, where the technology is being beta tested in a private beta, if you're not up to the task of running your own version.
Metamaps is created and maintained by a distributed, nomadic community comprised of technologists, artists and storytellers. You can get in touch with us at team@metamaps.cc or @metamapps on twitter.
To get connected with the community interested in Metamaps, join our G+ community. https://plus.google.com/u/0/communities/115060009262157699234
To contribute to Metamaps, fork this repository, and submit a pull request!
==Running Metamaps On Your Local Machine
First off, Metamaps runs on Ruby On Rails. Ruby 1.9.3 and Rails 3.2. You'll need to get Ruby and Rails installed on your computer if you don't already have it. We recommend using the Rails Installer, which you can download from Mac or Windows at http://railsinstaller.org/en (see the notes below about Ubuntu). This will get you set up perfectly with the right versions of Ruby, and Rails for running your local version of Metamaps.
It uses postgreSQL 9.2 as a database. You can install that for your computer from here: http://www.enterprisedb.com/products-services-training/pgdownload . During installation you can choose whatever database password you like. Make sure to note it down!
Once you install those, open a 'command prompt with ruby and rails'.
Navigate to the folder that you want to download the metamaps files to and run the following: (use your forked git repository address if it's different than this repo. You will also need to go to your Github account settings and add the SSH key that was placed in your clipboard earlier)
git clone git@github.com:Connoropolous/metamaps_gen002.git
cd metamaps_gen002
Now you're in the main directory.
Install all the gems needed for Metamaps by running
$ bundle install
Setting up the database:
1) Copy /config/database.yml.default and rename the copy to /config/database.yml then edit database.yml with your text editor and set the password to whatever you chose when you set up the PostGres database.
2) In a terminal:
$ rake db:create
$ rake db:schema:load
$ rake db:fixtures:load
Running the server:
$rails s #runs the server
Navigate your browser to localhost:3000 once you have the server running
Sign in with the default account
email: user@user.com
password: toolsplusconsciousness
OR create a new account at /users/sign_up, and use access code 'qwertyui'
Start mapping and programming!
==Installing on Ubuntu
There can be trouble installing on Ubuntu
Try installing postgresql and libpq-dev.
It's also recommended using Ruby Version Manager (rvm)
$rvm reinstall ruby-1.9.3-p125
execjs might complain there is no runtime, if so add gem 'therubyracer' to the Gemfile
== Finding Your Way Around The Code
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.
== Licensing Information
This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or(at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License along with this program. If not, see http://www.gnu.org/licenses.

View file

@ -1,101 +1,109 @@
Firstly this walkthrough is done with a 14.04 32bit install of Ubuntu. Firstly this walkthrough is done with a 14.04 32bit install of Ubuntu.
All Commands are quoted with "" which are not to be included in the command.
All commands that I could are terminal based. All commands that I could are terminal based.
Lets check if all updates for the system are installed first Lets check if all updates for the system are installed first
in terminal type in terminal type
"sudo apt-get update" sudo apt-get update
now we need to install git now we need to install git
"sudo apt-get install git" sudo apt-get install git
lets get our RVM installed (Ruby Version Manager) now this is fun because the package you will get from apt-get is outdated. lets get our RVM installed (Ruby Version Manager) now this is fun because the package you will get from apt-get is outdated.
so we are going to use CURL to get RVM so we are going to use CURL to get RVM
"sudo apt-get install curl" sudo apt-get install curl
then lets install RVM with curl like this then lets install RVM with curl like this
"curl -L get.rvm.io | bash -s stable" curl -L get.rvm.io | bash -s stable
"PATH=$PATH:$HOME/.rvm/bin # Add RVM to PATH for scripting" PATH=$PATH:$HOME/.rvm/bin # Add RVM to PATH for scripting
"[[ -s "$HOME/.profile" ]] && source "$HOME/.profile"" [[ -s "$HOME/.profile" ]] && source "$HOME/.profile"
"[[ -s "$HOME/.rvm/scripts/rvm" ]] && source "$HOME/.rvm/scripts/rvm"" [[ -s "$HOME/.rvm/scripts/rvm" ]] && source "$HOME/.rvm/scripts/rvm"
"source ~/.rvm/scripts/rvm" source ~/.rvm/scripts/rvm
now we can actually install RVM now we can actually install RVM
"rvm requirements" rvm requirements
running this will check your system for requirements as well so you will need to put your system password in. running this will check your system for requirements as well so you will need to put your system password in.
alright now we can download metamaps from the master using git alright now we can download metamaps from the master using git
"git clone https://github.com/Connoropolous/metamaps_gen002.git" git clone https://github.com/Connoropolous/metamaps_gen002.git
now there is a couple other things we are going to need which is nodejs, postgresql, libpq-dev and redis-server now there is a couple other things we are going to need which is nodejs, postgresql, libpq-dev and redis-server
"sudo apt-get install nodejs" sudo apt-get install nodejs
"sudo apt-get install postgresql" sudo apt-get install postgresql
"sudo apt-get install libpq-dev" sudo apt-get install libpq-dev
"sudo apt-get install redis-server" sudo apt-get install redis-server
Install the specific version of ruby needed this will take some time *Note you will get a warning about this being an outdated version* Install the specific version of ruby needed this will take some time *Note you will get a warning about this being an outdated version*
"rvm install ruby-1.9.3-p125" rvm install ruby-1.9.3-p125
Now we also need to rename your database file which is in ./config/database.default.yml to database.yml Now we also need to rename your database file which is in ./config/database.default.yml to database.yml
now run inside your metamaps_gen002 folder now run inside your metamaps_gen002 folder
"bundle install" bundle install
in your top lvl directory for metamaps this is a lengthy process so you might want to go and make a coffee or something :) in your top lvl directory for metamaps this is a lengthy process so you might want to go and make a coffee or something :)
alright now we need to make sure your postgres password is the same as it is listed in the DB file so we are going to set it by alright now we need to make sure your postgres password is the same as it is listed in the DB file so we are going to set it by
"sudo -u postgres psql" sudo -u postgres psql
Select postgres like this Select postgres like this
"\password postgres" \password postgres
set the password to 3112 set the password to 3112
Then to quit Then to quit
"\q" \q
now we can run the rake install and db creation now we can run the rake install and db creation
"rake db:create" rake db:create
"rake db:schema:load" rake db:schema:load
"rake db:fixtures:load" rake db:fixtures:load
Execute the server : "rails s" Execute the server:
rails s
and dont forget to run realtime too open a new terminal and dont forget to run realtime too open a new terminal
navigate to ./realtime and run navigate to ./realtime and run
"nodejs realtime-server.js" nodejs realtime-server.js
Now your all set enjoy your personal server of metamaps :) Now you're all set enjoy your personal server of metamaps :)
Navigate your browser to localhost:3000 once you have the server running
Sign in with the default account
email: user@user.com
password: toolsplusconsciousness
OR create a new account at /join, and use access code 'qwertyui'
Start mapping and programming!

42
WindowsInstallation.md Normal file
View file

@ -0,0 +1,42 @@
First off, Metamaps runs on Ruby On Rails. Ruby 1.9.3 and Rails 3.2. You'll need to get Ruby and Rails installed on your computer if you don't already have it. We recommend using the Rails Installer, which you can download from Mac or Windows at http://railsinstaller.org/en (see the notes below about Ubuntu). This will get you set up perfectly with the right versions of Ruby, and Rails for running your local version of Metamaps.
It uses postgreSQL 9.2 as a database. You can install that for your computer from here: http://www.enterprisedb.com/products-services-training/pgdownload . During installation you can choose whatever database password you like. Make sure to note it down!
Once you install those, open a 'command prompt with ruby and rails'.
Navigate to the folder that you want to download the metamaps files to and run the following: (use your forked git repository address if it's different than this repo. You will also need to go to your Github account settings and add the SSH key that was placed in your clipboard earlier)
git clone https://github.com/Connoropolous/metamaps_gen002.git
cd metamaps_gen002
Now you're in the main directory.
Install all the gems needed for Metamaps by running
bundle install
Setting up the database:
1) Copy /config/database.yml.default and rename the copy to /config/database.yml then edit database.yml with your text editor and set the password to whatever you chose when you set up the PostGres database.
2) In a terminal:
rake db:create
rake db:schema:load
rake db:fixtures:load
Running the server:
rails s
Navigate your browser to localhost:3000 once you have the server running
Sign in with the default account
email: user@user.com
password: toolsplusconsciousness
OR create a new account at /join, and use access code 'qwertyui'
Start mapping and programming!

View file

@ -1,262 +0,0 @@
/*
* textillate.js
* http://jschr.github.com/textillate
* MIT licensed
*
* Copyright (C) 2012-2013 Jordan Schroter
*/
(function ($) {
"use strict";
function isInEffect (effect) {
return /In/.test(effect) || $.inArray(effect, $.fn.textillate.defaults.inEffects) >= 0;
};
function isOutEffect (effect) {
return /Out/.test(effect) || $.inArray(effect, $.fn.textillate.defaults.outEffects) >= 0;
};
// custom get data api method
function getData (node) {
var attrs = node.attributes || []
, data = {};
if (!attrs.length) return data;
$.each(attrs, function (i, attr) {
if (/^data-in-*/.test(attr.nodeName)) {
data.in = data.in || {};
data.in[attr.nodeName.replace(/data-in-/, '')] = attr.nodeValue;
} else if (/^data-out-*/.test(attr.nodeName)) {
data.out = data.out || {};
data.out[attr.nodeName.replace(/data-out-/, '')] = attr.nodeValue;
} else if (/^data-*/.test(attr.nodeName)) {
data[attr.nodeName] = attr.nodeValue;
}
})
return data;
}
function shuffle (o) {
for (var j, x, i = o.length; i; j = parseInt(Math.random() * i), x = o[--i], o[i] = o[j], o[j] = x);
return o;
}
function animate ($c, effect, cb) {
$c.addClass('animated ' + effect)
.css('visibility', 'visible')
.show();
$c.one('animationend webkitAnimationEnd oAnimationEnd', function () {
$c.removeClass('animated ' + effect);
cb && cb();
});
}
function animateChars ($chars, options, cb) {
var that = this
, count = $chars.length;
if (!count) {
cb && cb();
return;
}
if (options.shuffle) $chars = shuffle($chars);
if (options.reverse) $chars = $chars.toArray().reverse();
$.each($chars, function (i, c) {
var $char = $(c);
function complete () {
if (isInEffect(options.effect)) {
$char.css('visibility', 'visible');
} else if (isOutEffect(options.effect)) {
$char.css('visibility', 'hidden');
}
count -= 1;
if (!count && cb) cb();
}
var delay = options.sync ? options.delay : options.delay * i * options.delayScale;
$char.text() ?
setTimeout(function () { animate($char, options.effect, complete) }, delay) :
complete();
});
};
var Textillate = function (element, options) {
var base = this
, $element = $(element);
base.init = function () {
base.$texts = $element.find(options.selector);
if (!base.$texts.length) {
base.$texts = $('<ul class="texts"><li>' + $element.html() + '</li></ul>');
$element.html(base.$texts);
}
base.$texts.hide();
base.$current = $('<span>')
.text(base.$texts.find(':first-child').html())
.prependTo($element);
if (isInEffect(options.effect)) {
base.$current.css('visibility', 'hidden');
} else if (isOutEffect(options.effect)) {
base.$current.css('visibility', 'visible');
}
base.setOptions(options);
setTimeout(function () {
base.options.autoStart && base.start();
}, base.options.initialDelay)
};
base.setOptions = function (options) {
base.options = options;
};
base.triggerEvent = function (name) {
var e = $.Event(name + '.tlt', { data: base });
$element.trigger(e);
return e;
};
base.in = function (index, cb) {
index = index || 0;
var $elem = base.$texts.find(':nth-child(' + (index + 1) + ')')
, options = $.extend({}, base.options, getData($elem))
, $chars;
base.triggerEvent('inAnimationBegin');
base.$current
.text($elem.html())
.lettering('words');
base.$current.find('[class^="word"]')
.css({
'display': 'inline-block',
// fix for poor ios performance
'-webkit-transform': 'translate3d(0,0,0)',
'-moz-transform': 'translate3d(0,0,0)',
'-o-transform': 'translate3d(0,0,0)',
'transform': 'translate3d(0,0,0)'
})
.each(function () { $(this).lettering() });
$chars = base.$current
.find('[class^="char"]')
.css('display', 'inline-block');
if (isInEffect(options.in.effect)) {
$chars.css('visibility', 'hidden');
} else if (isOutEffect(options.in.effect)) {
$chars.css('visibility', 'visible');
}
base.currentIndex = index;
animateChars($chars, options.in, function () {
base.triggerEvent('inAnimationEnd');
if (options.in.callback) options.in.callback();
if (cb) cb(base);
});
};
base.out = function (cb) {
var $elem = base.$texts.find(':nth-child(' + (base.currentIndex + 1) + ')')
, $chars = base.$current.find('[class^="char"]')
, options = $.extend({}, base.options, getData($elem));
base.triggerEvent('outAnimationBegin');
animateChars($chars, options.out, function () {
base.triggerEvent('outAnimationEnd');
if (options.out.callback) options.out.callback();
if (cb) cb(base);
});
};
base.start = function (index) {
base.triggerEvent('start');
(function run (index) {
base.in(index, function () {
var length = base.$texts.children().length;
index += 1;
if (!base.options.loop && index >= length) {
if (base.options.callback) base.options.callback();
base.triggerEvent('end');
} else {
index = index % length;
setTimeout(function () {
base.out(function () {
run(index)
});
}, base.options.minDisplayTime);
}
});
}(index || 0));
};
base.init();
}
$.fn.textillate = function (settings, args) {
return this.each(function () {
var $this = $(this)
, data = $this.data('textillate')
, options = $.extend(true, {}, $.fn.textillate.defaults, getData(this), typeof settings == 'object' && settings);
if (!data) {
$this.data('textillate', (data = new Textillate(this, options)));
} else if (typeof settings == 'string') {
data[settings].apply(data, [].concat(args));
} else {
data.setOptions.call(data, options);
}
})
};
$.fn.textillate.defaults = {
selector: '.texts',
loop: false,
minDisplayTime: 2000,
initialDelay: 0,
in: {
effect: 'fadeInLeftBig',
delayScale: 1.5,
delay: 50,
sync: false,
reverse: false,
shuffle: false,
callback: function () {}
},
out: {
effect: 'hinge',
delayScale: 1.5,
delay: 50,
sync: false,
reverse: false,
shuffle: false,
callback: function () {}
},
autoStart: true,
inEffects: [],
outEffects: [ 'hinge' ],
callback: function () {}
};
}(jQuery));

View file

@ -9,6 +9,10 @@ Metamaps.Backbone.Map = Backbone.Model.extend({
if (mapper && (this.get('permission') === "commons" || this.get('user_id') === mapper.get('id'))) return true; if (mapper && (this.get('permission') === "commons" || this.get('user_id') === mapper.get('id'))) return true;
else return false; else return false;
}, },
authorizePermissionChange: function (mapper) {
if (mapper && this.get('user_id') === mapper.get('id')) return true;
else return false;
},
getUser: function () { getUser: function () {
return Metamaps.Mapper.get(this.get('user_id')); return Metamaps.Mapper.get(this.get('user_id'));
}, },
@ -133,7 +137,7 @@ Metamaps.Backbone.Mapper = Backbone.Model.extend({
prepareLiForFilter: function () { prepareLiForFilter: function () {
var li = ''; var li = '';
li += '<li data-id="' + this.id.toString() + '">'; li += '<li data-id="' + this.id.toString() + '">';
li += '<img src="/assets/icons/person.png" data-id="' + this.id.toString() + '"'; li += '<img src="' + this.get("image") + '" data-id="' + this.id.toString() + '"';
li += ' alt="' + this.get('name') + '" />'; li += ' alt="' + this.get('name') + '" />';
li += '<p>' + this.get('name') + '</p></li>'; li += '<p>' + this.get('name') + '</p></li>';
return li; return li;

View file

@ -78,7 +78,6 @@ Metamaps.GlobalUI = {
// initialize global backbone models and collections // initialize global backbone models and collections
if (Metamaps.Active.Mapper) Metamaps.Active.Mapper = new Metamaps.Backbone.Mapper(Metamaps.Active.Mapper); if (Metamaps.Active.Mapper) Metamaps.Active.Mapper = new Metamaps.Backbone.Mapper(Metamaps.Active.Mapper);
Metamaps.Mappers = new Metamaps.Backbone.MapperCollection([Metamaps.Active.Mapper]);
var myCollection = Metamaps.Maps.Mine ? Metamaps.Maps.Mine : []; var myCollection = Metamaps.Maps.Mine ? Metamaps.Maps.Mine : [];
var featuredCollection = Metamaps.Maps.Featured ? Metamaps.Maps.Featured : []; var featuredCollection = Metamaps.Maps.Featured ? Metamaps.Maps.Featured : [];
@ -440,9 +439,9 @@ Metamaps.GlobalUI.Search = {
startTypeahead: function () { startTypeahead: function () {
var self = Metamaps.GlobalUI.Search; var self = Metamaps.GlobalUI.Search;
var mapheader = Metamaps.Active.Mapper ? '<h3 class="search-header">Maps</h3><input type="checkbox" class="limitToMe" id="limitMapsToMe"></input><label for="limitMapsToMe" class="limitToMeLabel">added by me</label><div class="minimizeResults minimizeMapResults"></div><div class="clearfloat"></div>' : '<h3 class="search-header">Maps</h3><div class="minimizeResults minimizeMapResults"></div><div class="clearfloat"></div>'; var mapheader = Metamaps.Active.Mapper ? '<div class="searchTopicsHeader searchHeader"><h3 class="search-heading">Maps</h3><input type="checkbox" class="limitToMe" id="limitMapsToMe"></input><label for="limitMapsToMe" class="limitToMeLabel">added by me</label><div class="minimizeResults minimizeMapResults"></div><div class="clearfloat"></div></div>' : '<div class="searchTopicsHeader searchHeader"><h3 class="search-heading">Maps</h3><div class="minimizeResults minimizeMapResults"></div><div class="clearfloat"></div></div>';
var topicheader = Metamaps.Active.Mapper ? '<h3 class="search-header">Topics</h3><input type="checkbox" class="limitToMe" id="limitTopicsToMe"></input><label for="limitTopicsToMe" class="limitToMeLabel">added by me</label><div class="minimizeResults minimizeTopicResults"></div><div class="clearfloat"></div>' : '<h3 class="search-header">Topics</h3><div class="minimizeResults minimizeTopicResults"></div><div class="clearfloat"></div>'; var topicheader = Metamaps.Active.Mapper ? '<div class="searchMapsHeader searchHeader"><h3 class="search-heading">Topics</h3><input type="checkbox" class="limitToMe" id="limitTopicsToMe"></input><label for="limitTopicsToMe" class="limitToMeLabel">added by me</label><div class="minimizeResults minimizeTopicResults"></div><div class="clearfloat"></div></div>' : '<div class="searchMapsHeader searchHeader"><h3 class="search-heading">Topics</h3><div class="minimizeResults minimizeTopicResults"></div><div class="clearfloat"></div></div>';
var mapperheader = '<h3 class="search-header">Mappers</h3><div class="minimizeResults minimizeMapperResults"></div><div class="clearfloat"></div>'; var mapperheader = '<div class="searchMappersHeader searchHeader"><h3 class="search-heading">Mappers</h3><div class="minimizeResults minimizeMapperResults"></div><div class="clearfloat"></div></div>';
var topics = { var topics = {
name: 'topics', name: 'topics',
@ -519,6 +518,7 @@ Metamaps.GlobalUI.Search = {
filter: function (dataset) { filter: function (dataset) {
if (dataset.length == 0) { if (dataset.length == 0) {
dataset.push({ dataset.push({
profile: "/assets/user.png",
value: "No results", value: "No results",
label: "No results", label: "No results",
rtype: "noresult" rtype: "noresult"

View file

@ -196,7 +196,7 @@ Metamaps.Backbone.init = function () {
prepareLiForFilter: function () { prepareLiForFilter: function () {
var li = ''; var li = '';
li += '<li data-id="' + this.get('desc') + '">'; li += '<li data-id="' + this.get('desc') + '">';
li += '<img src="/assets/synapsevisualize.png"'; li += '<img src="/assets/synapse16.png"';
li += ' alt="synapse icon" />'; li += ' alt="synapse icon" />';
li += '<p>' + this.get('desc') + '</p></li>'; li += '<p>' + this.get('desc') + '</p></li>';
return li; return li;
@ -306,31 +306,44 @@ Metamaps.Backbone.init = function () {
Metamaps.Metacodes = Metamaps.Metacodes ? new self.MetacodeCollection(Metamaps.Metacodes) : new self.MetacodeCollection(); Metamaps.Metacodes = Metamaps.Metacodes ? new self.MetacodeCollection(Metamaps.Metacodes) : new self.MetacodeCollection();
Metamaps.Topics = Metamaps.Topics ? new self.TopicCollection(Metamaps.Topics) : new self.TopicCollection(); Metamaps.Topics = Metamaps.Topics ? new self.TopicCollection(Metamaps.Topics) : new self.TopicCollection();
Metamaps.Topics.on("add remove", function(topic){
Metamaps.Filter.checkMetacodes();
Metamaps.Filter.checkMappers();
});
Metamaps.Synapses = Metamaps.Synapses ? new self.SynapseCollection(Metamaps.Synapses) : new self.SynapseCollection(); Metamaps.Synapses = Metamaps.Synapses ? new self.SynapseCollection(Metamaps.Synapses) : new self.SynapseCollection();
Metamaps.Synapses.on("add remove", function(synapse){
Metamaps.Filter.checkSynapses();
Metamaps.Filter.checkMappers();
});
Metamaps.Mappers = Metamaps.Mappers ? new self.MapperCollection(Metamaps.Mappers) : new self.MapperCollection(); Metamaps.Mappers = Metamaps.Mappers ? new self.MapperCollection(Metamaps.Mappers) : new self.MapperCollection();
if (Metamaps.Active.Map) { if (Metamaps.Active.Map) {
Metamaps.Mappings = Metamaps.Mappings ? new self.MappingCollection(Metamaps.Mappings) : new self.MappingCollection(); Metamaps.Mappings = Metamaps.Mappings ? new self.MappingCollection(Metamaps.Mappings) : new self.MappingCollection();
Metamaps.Mappings.on("add remove", function(synapse){
Metamaps.Filter.checkMetacodes();
Metamaps.Filter.checkMappers();
});
Metamaps.Active.Map = new self.Map(Metamaps.Active.Map); Metamaps.Active.Map = new self.Map(Metamaps.Active.Map);
} }
if (Metamaps.Active.Topic) Metamaps.Active.Topic = new self.Topic(Metamaps.Active.Topic); if (Metamaps.Active.Topic) Metamaps.Active.Topic = new self.Topic(Metamaps.Active.Topic);
//attach collection event listeners
self.attachCollectionEvents = function () {
Metamaps.Topics.on("add remove", function(topic){
Metamaps.Map.InfoBox.updateNumbers();
Metamaps.Filter.checkMetacodes();
Metamaps.Filter.checkMappers();
});
Metamaps.Synapses.on("add remove", function(synapse){
Metamaps.Map.InfoBox.updateNumbers();
Metamaps.Filter.checkSynapses();
Metamaps.Filter.checkMappers();
});
if (Metamaps.Active.Map) {
Metamaps.Mappings.on("add remove", function(mapping){
Metamaps.Map.InfoBox.updateNumbers();
Metamaps.Filter.checkSynapses();
Metamaps.Filter.checkMetacodes();
Metamaps.Filter.checkMappers();
});
}
}
self.attachCollectionEvents();
}; // end Metamaps.Backbone.init }; // end Metamaps.Backbone.init
@ -615,7 +628,6 @@ Metamaps.Create = {
Metamaps.TopicCard = { Metamaps.TopicCard = {
openTopicCard: null, //stores the JIT local ID of the topic with the topic card open openTopicCard: null, //stores the JIT local ID of the topic with the topic card open
linkActionsString: '<div class="linkActions"><div id="linkshare">share</div><div id="linkremove">remove</div> </div>', linkActionsString: '<div class="linkActions"><div id="linkshare">share</div><div id="linkremove">remove</div> </div>',
init: function () { init: function () {
// initialize best_in_place editing // initialize best_in_place editing
@ -1333,6 +1345,14 @@ Metamaps.Util = {
} }
return b + s; return b + s;
}, },
nowDateFormatted: function () {
var date = new Date(Date.now());
var month = (date.getMonth() + 1) < 10 ? '0' + (date.getMonth() + 1) : (date.getMonth() + 1);
var day = date.getDate() < 10 ? '0' + date.getDate() : date.getDate();
var year = date.getFullYear();
return month + '/' + day + '/' + year;
},
decodeEntities: function (desc) { decodeEntities: function (desc) {
var str, temp = document.createElement('p'); var str, temp = document.createElement('p');
temp.innerHTML = desc; //browser handles the topics temp.innerHTML = desc; //browser handles the topics
@ -1380,7 +1400,8 @@ Metamaps.Realtime = {
init: function () { init: function () {
var self = Metamaps.Realtime; var self = Metamaps.Realtime;
$(".realtimeOnOff").click(self.toggle); $(".rtOn").click(self.turnOn);
$(".rtOff").click(self.turnOff);
$('.sidebarCollaborateIcon').click(self.toggleBox); $('.sidebarCollaborateIcon').click(self.toggleBox);
$('.sidebarCollaborateBox').click(function(event){ $('.sidebarCollaborateBox').click(function(event){
@ -1431,20 +1452,25 @@ Metamaps.Realtime = {
}); });
} }
}, },
toggle: function () { turnOn: function () {
var self = Metamaps.Realtime; var self = Metamaps.Realtime;
if (!self.status) { if (!self.status) {
self.sendRealtimeOn(); self.sendRealtimeOn();
$(this).html('ON').removeClass('rtOff').addClass('rtOn');
$(".rtMapperSelf").removeClass('littleRtOff').addClass('littleRtOn'); $(".rtMapperSelf").removeClass('littleRtOff').addClass('littleRtOn');
} else { self.status = true;
self.sendRealtimeOff(); $(".sidebarCollaborateIcon").addClass("blue");
$(this).html('OFF').removeClass('rtOn').addClass('rtOff'); }
$(".rtMapperSelf").removeClass('littleRtOn').addClass('littleRtOff'); },
turnOff: function () {
var self = Metamaps.Realtime;
if (self.status) {
self.sendRealtimeOff();
$(".rtMapperSelf").removeClass('littleRtOn').addClass('littleRtOff');
self.status = false;
$(".sidebarCollaborateIcon").removeClass("blue");
} }
self.status = !self.status;
$(".sidebarCollaborateIcon").toggleClass("blue");
}, },
setupSocket: function () { setupSocket: function () {
var self = Metamaps.Realtime; var self = Metamaps.Realtime;
@ -1454,6 +1480,7 @@ Metamaps.Realtime = {
socket.emit('newMapperNotify', { socket.emit('newMapperNotify', {
userid: myId, userid: myId,
username: Metamaps.Active.Mapper.get("name"), username: Metamaps.Active.Mapper.get("name"),
userimage: Metamaps.Active.Mapper.get("image"),
mapid: Metamaps.Active.Map.id mapid: Metamaps.Active.Map.id
}); });
@ -1504,6 +1531,7 @@ Metamaps.Realtime = {
// data.userid // data.userid
// data.username // data.username
// data.userimage
// data.userrealtime // data.userrealtime
self.mappersOnMap[data.userid] = { self.mappersOnMap[data.userid] = {
@ -1516,7 +1544,11 @@ Metamaps.Realtime = {
mapperListItem += data.userid; mapperListItem += data.userid;
mapperListItem += '" class="rtMapper littleRt'; mapperListItem += '" class="rtMapper littleRt';
mapperListItem += onOff; mapperListItem += onOff;
mapperListItem += '">' + data.username + '</li>'; mapperListItem += '">';
mapperListItem += '<img src="' + data.userimage + '" width="24" height="24" class="rtUserImage" />';
mapperListItem += data.username;
mapperListItem += '<div class="littleJuntoIcon"></div>';
mapperListItem += '</li>';
$('#mapper' + data.userid).remove(); $('#mapper' + data.userid).remove();
$('.realtimeMapperList ul').append(mapperListItem); $('.realtimeMapperList ul').append(mapperListItem);
@ -1527,13 +1559,19 @@ Metamaps.Realtime = {
// data.userid // data.userid
// data.username // data.username
// data.userimage
self.mappersOnMap[data.userid] = { self.mappersOnMap[data.userid] = {
name: data.username, name: data.username,
realtime: true realtime: true
}; };
var mapperListItem = '<li id="mapper' + data.userid + '" class="rtMapper littleRtOn">' + data.username + '</li>'; var mapperListItem = '<li id="mapper' + data.userid + '" class="rtMapper littleRtOn">';
mapperListItem += '<img src="' + data.userimage + '" width="24" height="24" class="rtUserImage" />';
mapperListItem += data.username;
mapperListItem += '<div class="littleJuntoIcon"></div>';
mapperListItem += '</li>';
$('#mapper' + data.userid).remove(); $('#mapper' + data.userid).remove();
$('.realtimeMapperList ul').append(mapperListItem); $('.realtimeMapperList ul').append(mapperListItem);
@ -1543,6 +1581,7 @@ Metamaps.Realtime = {
var update = { var update = {
userToNotify: data.userid, userToNotify: data.userid,
username: Metamaps.Active.Mapper.get("name"), username: Metamaps.Active.Mapper.get("name"),
userimage: Metamaps.Active.Mapper.get("image"),
userid: Metamaps.Active.Mapper.id, userid: Metamaps.Active.Mapper.id,
userrealtime: self.status, userrealtime: self.status,
mapid: Metamaps.Active.Map.id mapid: Metamaps.Active.Map.id
@ -2070,7 +2109,8 @@ Metamaps.Filter = {
if (!self.isOpen && !self.changing) { if (!self.isOpen && !self.changing) {
self.changing = true; self.changing = true;
$('.sidebarFilterBox').fadeIn(200, function () { var height = $(document).height() - 108;
$('.sidebarFilterBox').css('max-height', height + 'px').fadeIn(200, function () {
self.changing = false; self.changing = false;
self.isOpen = true; self.isOpen = true;
}); });
@ -2177,6 +2217,8 @@ Metamaps.Filter = {
$('#filter_by_' + listToModify + ' li[data-id="' + identifier + '"]').fadeOut('fast',function(){ $('#filter_by_' + listToModify + ' li[data-id="' + identifier + '"]').fadeOut('fast',function(){
$(this).remove(); $(this).remove();
}); });
index = self.visible[filtersToUser].indexOf(identifier);
self.visible[filtersToUse].splice(index, 1);
}); });
var model, li, jQueryLi; var model, li, jQueryLi;
@ -2193,6 +2235,7 @@ Metamaps.Filter = {
jQueryLi = $(li).hide(); jQueryLi = $(li).hide();
$('li', '#filter_by_' + listToModify + ' ul').add(jQueryLi.fadeIn("fast")) $('li', '#filter_by_' + listToModify + ' ul').add(jQueryLi.fadeIn("fast"))
.sort(sortAlpha).appendTo('#filter_by_' + listToModify + ' ul'); .sort(sortAlpha).appendTo('#filter_by_' + listToModify + ' ul');
self.visible[filtersToUse].push(identifier);
}); });
// update the list of filters with the new list we just generated // update the list of filters with the new list we just generated
@ -2272,12 +2315,10 @@ Metamaps.Filter = {
}, },
toggleMapper: function () { toggleMapper: function () {
var self = Metamaps.Filter; var self = Metamaps.Filter;
self.toggleLi.call(this, 'mappers'); self.toggleLi.call(this, 'mappers');
}, },
toggleSynapse: function () { toggleSynapse: function () {
var self = Metamaps.Filter; var self = Metamaps.Filter;
self.toggleLi.call(this, 'synapses'); self.toggleLi.call(this, 'synapses');
}, },
passFilters: function () { passFilters: function () {
@ -2313,6 +2354,7 @@ Metamaps.Filter = {
} }
else { else {
if (n) { if (n) {
// TODO quick deselect node
n.setData('alpha', 0, 'end'); n.setData('alpha', 0, 'end');
} }
else console.log(topic); else console.log(topic);
@ -2334,12 +2376,13 @@ Metamaps.Filter = {
if (passesSynapse && passesMapper) { if (passesSynapse && passesMapper) {
if (e) { if (e) {
e.setData('alpha', 1, 'end'); e.setData('alpha', 0.4, 'end');
} }
else console.log(synapse); else console.log(synapse);
} }
else { else {
if (e) { if (e) {
// TODO quick deselect edge
e.setData('alpha', 0, 'end'); e.setData('alpha', 0, 'end');
} }
else console.log(synapse); else console.log(synapse);
@ -2350,7 +2393,7 @@ Metamaps.Filter = {
Metamaps.Visualize.mGraph.fx.animate({ Metamaps.Visualize.mGraph.fx.animate({
modes: ['node-property:alpha', modes: ['node-property:alpha',
'edge-property:alpha'], 'edge-property:alpha'],
duration: 500 duration: 200
}); });
} }
}; // end Metamaps.Filter }; // end Metamaps.Filter
@ -2553,6 +2596,7 @@ Metamaps.Topic = {
Metamaps.Active.Topic = new bb.Topic(data.topic); Metamaps.Active.Topic = new bb.Topic(data.topic);
Metamaps.Topics = new bb.TopicCollection([data.topic].concat(data.relatives)); Metamaps.Topics = new bb.TopicCollection([data.topic].concat(data.relatives));
Metamaps.Synapses = new bb.SynapseCollection(data.synapses); Metamaps.Synapses = new bb.SynapseCollection(data.synapses);
Metamaps.Backbone.attachCollectionEvents();
// build and render the visualization // build and render the visualization
Metamaps.Visualize.type = "RGraph"; Metamaps.Visualize.type = "RGraph";
@ -2884,6 +2928,7 @@ Metamaps.Map = {
Metamaps.Topics = new bb.TopicCollection(data.topics); Metamaps.Topics = new bb.TopicCollection(data.topics);
Metamaps.Synapses = new bb.SynapseCollection(data.synapses); Metamaps.Synapses = new bb.SynapseCollection(data.synapses);
Metamaps.Mappings = new bb.MappingCollection(data.mappings); Metamaps.Mappings = new bb.MappingCollection(data.mappings);
Metamaps.Backbone.attachCollectionEvents();
// build and render the visualization // build and render the visualization
Metamaps.Visualize.type = "ForceDirected"; Metamaps.Visualize.type = "ForceDirected";
@ -2893,6 +2938,9 @@ Metamaps.Map = {
Metamaps.Filter.reset(); Metamaps.Filter.reset();
Metamaps.Filter.initializeFilterData(); // this sets all the visible filters to true Metamaps.Filter.initializeFilterData(); // this sets all the visible filters to true
// set the proper mapinfobox content
Metamaps.Map.InfoBox.load();
// these three update the actual filter box with the right list items // these three update the actual filter box with the right list items
Metamaps.Filter.checkMetacodes(); Metamaps.Filter.checkMetacodes();
Metamaps.Filter.checkSynapses(); Metamaps.Filter.checkSynapses();
@ -2968,23 +3016,22 @@ Metamaps.Map.InfoBox = {
isOpen: false, isOpen: false,
changing: false, changing: false,
selectingPermission: false, selectingPermission: false,
changePermissionText: "<div class='tip'>As the creator, you can change the permission of this map, but the permissions of the topics and synapses on it must be changed independently.</div>",
nameHTML: '<span class="best_in_place best_in_place_name" id="best_in_place_map_{{id}}_name" data-url="/maps/{{id}}" data-object="map" data-attribute="name" data-type="input">{{name}}</span>',
descHTML: '<span class="best_in_place best_in_place_desc" id="best_in_place_map_{{id}}_desc" data-url="/maps/{{id}}" data-object="map" data-attribute="desc" data-nil="Click to add description." data-type="textarea">{{desc}}</span>',
deleteHTML: "<a href='/maps/{{id}}' class='delete' data-bypass='true' data-confirm='Delete this map (nodes and synapses will remain)?' data-method='delete' rel='nofollow'>Delete</a>",
init: function () { init: function () {
var self = Metamaps.Map.InfoBox; var self = Metamaps.Map.InfoBox;
// because anyone who can edit the map can change the map title
$('.mapInfoName .best_in_place_name').bind("ajax:success", function () {
var name = $(this).html();
$('.mapName').html(name);
Metamaps.Active.Map.set('name', name);
});
$('.yourMap .mapPermission').click(self.onPermissionClick);
$('.mapInfoIcon').click(self.toggleBox); $('.mapInfoIcon').click(self.toggleBox);
$('.mapInfoBox').click(function(event){ $('.mapInfoBox').click(function(event){
event.stopPropagation(); event.stopPropagation();
}); });
$('body').click(self.close); $('body').click(self.close);
self.attachEventListeners();
self.generateBoxHTML = Hogan.compile($('#mapInfoBoxTemplate').html());
}, },
toggleBox: function (event) { toggleBox: function (event) {
var self = Metamaps.Map.InfoBox; var self = Metamaps.Map.InfoBox;
@ -3016,6 +3063,66 @@ Metamaps.Map.InfoBox = {
}); });
} }
}, },
load: function () {
var self = Metamaps.Map.InfoBox;
var map = Metamaps.Active.Map;
var obj = map.pick("permission","contributor_count","topic_count","synapse_count","created_at","updated_at");
var isCreator = map.authorizePermissionChange(Metamaps.Active.Mapper);
var canEdit = map.authorizeToEdit(Metamaps.Active.Mapper);
obj["name"] = canEdit ? Hogan.compile(self.nameHTML).render({id: map.id, name: map.get("name")}) : map.get("name");
obj["desc"] = canEdit ? Hogan.compile(self.descHTML).render({id: map.id, desc: map.get("desc")}) : map.get("desc");
obj["map_creator_tip"] = isCreator ? self.changePermissionText : "";
obj["delete"] = isCreator ? Hogan.compile(self.deleteHTML).render({id: map.id}) : "";
obj["contributor_list"] = self.createContributorList();
obj["user_name"] = isCreator ? "you" : map.get("user_name");
var classes = isCreator ? "yourMap" : "";
classes += canEdit ? " canEdit" : "";
$(".mapInfoBox").removeClass("yourMap canEdit")
.addClass(classes)
.html(self.generateBoxHTML.render(obj));
self.attachEventListeners();
},
attachEventListeners: function () {
var self = Metamaps.Map.InfoBox;
$('.mapInfoBox .best_in_place').best_in_place();
// because anyone who can edit the map can change the map title
$('.mapInfoName .best_in_place_name').unbind("ajax:success").bind("ajax:success", function () {
var name = $(this).html();
$('.mapName').html(name);
Metamaps.Active.Map.set('name', name);
});
$('.yourMap .mapPermission').unbind().click(self.onPermissionClick);
},
createContributorList: function () {
var self = Metamaps.Map.InfoBox;
var mapperNames = Metamaps.Mappers.pluck("name");
return mapperNames.length > 0 ? mapperNames.join(", ") : "No one has added anything yet.";
},
updateNumbers: function () {
var self = Metamaps.Map.InfoBox;
var mapper = Metamaps.Active.Mapper;
if (mapper && Metamaps.Mappers.get(mapper.id) === undefined) {
Metamaps.Mappers.add(mapper);
}
$('.mapContributors').text(Metamaps.Mappers.length)
.append('<div class="tip">' + self.createContributorList() + '</div>');
$('.mapTopics').text(Metamaps.Topics.length);
$('.mapSynapses').text(Metamaps.Synapses.length);
$('.mapEditedAt').html('Last edited ' + Metamaps.Util.nowDateFormatted());
},
onPermissionClick: function () { onPermissionClick: function () {
var self = Metamaps.Map.InfoBox; var self = Metamaps.Map.InfoBox;

View file

@ -85,8 +85,6 @@ body {
font-family: 'din-medium', helvetica, sans-serif; font-family: 'din-medium', helvetica, sans-serif;
color: #424242; color: #424242;
} }
h1, h1,
h2, h2,
h3, h3,
@ -95,19 +93,6 @@ h5,
h6 { h6 {
font-weight: normal; font-weight: normal;
} }
h1 {
display: block;
text-align: left;
font-family: "vinyl", sans-serif;
}
h2 {
display: block;
text-align: center;
font-family: "katarine-web", sans-serif;
background: url('black_bg.png');
font-size: 24px;
line-height: 35px;
}
a { a {
color: #424242; color: #424242;
text-decoration: none; text-decoration: none;
@ -677,10 +662,8 @@ label[for="user_remember_me"] {
.sidebarFilterBox { .sidebarFilterBox {
display:none; display:none;
height: 400px; width: 304px;
width: 320px; padding: 16px 0;
padding: 10px;
text-align: center;
overflow-y: auto; overflow-y: auto;
} }
h3.filterBox { h3.filterBox {
@ -689,53 +672,78 @@ h3.filterBox {
} }
.sidebarFilterBox span { .sidebarFilterBox span {
float: right; float: right;
background: #15bad4;
padding: 1px 4px; padding: 1px 4px;
border-radius: 2px; border-radius: 2px;
margin-left: 5px; margin-right: 5px;
cursor: pointer; cursor: pointer;
font-size:12px;
}
.sidebarFilterBox span:hover {
color: #00BCD4;
} }
.sidebarFilterBox ul { .sidebarFilterBox ul {
list-style: none; list-style: none;
} }
.sidebarFilterBox li { .sidebarFilterBox li {
float: left; float: left;
width: 61px; width: 72px;
height: 70px; height: 72px;
cursor: pointer; cursor: pointer;
text-align: center;
} }
.sidebarFilterBox li:hover { .sidebarFilterBox li:hover {
background: #000;
} }
.sidebarFilterBox li img { #filter_by_mapper li img {
background-color: rgba(255, 255, 255, 0.1); width: 40px;
width: 45px; height: 40px;
height: 45px; border-radius: 20px;
margin: 0 auto; margin: 8px auto;
}
#filter_by_metacode li img {
width: 40px;
height: 40px;
margin: 8px auto;
}
#filter_by_synapse li img {
width: 16px;
height: 16px;
margin: 8px auto;
} }
.sidebarFilterBox li p { .sidebarFilterBox li p {
font-size: 11px; font-size: 11px;
line-height: 11px; line-height: 11px;
font-family: arial, sans-serif; font-family: 'din-regular', helvetica, sans-serif;
} }
.sidebarFilterBox li.toggledOff { .sidebarFilterBox li.toggledOff {
opacity: 0.4; opacity: 0.4;
} }
.sidebarFilterBox h2 {
font-size: 18px;
margin-left: 16px;
line-height: 18px;
}
.sidebarFilterBox h3 { .sidebarFilterBox h3 {
text-align: left; text-align: left;
text-transform: uppercase; text-transform: uppercase;
font-weight: bold; font-size:14px;
float:left;
}
.filterBySection {
margin-left:16px;
width: 288px;
border-top: 1px solid #BDBDBD;
padding-top:8px;
margin-top:8px;
} }
#filter_by_metacode { #filter_by_metacode {
border-bottom: 1px solid black;
margin: 5px;
} }
#filter_by_mapper { #filter_by_mapper {
margin: 5px auto;
} }
#filter_by_synapse { #filter_by_synapse {
margin: 5px auto;
border-bottom: 1px solid black;
} }
/* end filter by metacode */ /* end filter by metacode */
@ -748,52 +756,66 @@ h3.filterBox {
.sidebarCollaborateBox { .sidebarCollaborateBox {
display: none; display: none;
height: auto; height: auto;
width: auto; padding: 16px;
padding: 10px; width: 238px;
min-width: 180px;
} }
h3.realtimeBoxTitle { h3.realtimeBoxTitle {
margin-bottom: 10px; margin-bottom: 10px;
text-align: left; text-align: left;
float: left; float: left;
font-family: 'Lato', helvetica, sans-serif; font-size:18px;
line-height:18px;
} }
.sidebarCollaborateBox .realtimeOnOff { .sidebarCollaborateBox .realtimeOnOff {
float: left; float: right;
padding: 4px; padding: 4px;
border-radius: 2px; border-radius: 2px;
margin-left: 12px; margin-left: 12px;
cursor: pointer; cursor: pointer;
width: 31px;
text-align: center; text-align: center;
font-size:12px;
}
.sidebarCollaborateBox .realtimeOnOff:hover {
color: #00bcd4;
} }
.sidebarCollaborateBox .rtOff { .sidebarCollaborateBox .rtOff {
background: white;
color: black;
}
.sidebarCollaborateBox .rtOff:hover {
padding: 3px;
border: 1px solid #15bad4;
} }
.sidebarCollaborateBox .rtOn { .sidebarCollaborateBox .rtOn {
background: #15bad4;
color: white;
} }
.realtimeMapperList .rtMapper { .realtimeMapperList .rtMapper {
list-style-type: none; list-style-type: none;
white-space: nowrap; white-space: nowrap;
padding: 2px 5px 2px 30px; overflow: hidden;
text-overflow: ellipsis;
padding: 9px 32px;
display: block; display: block;
background-size: 26px 26px; height: 14px;
background-repeat: no-repeat; font-family: 'din-regular', helvetica, sans-serif;
background-position: 4px center; font-size: 14px;
margin-bottom: 5px; line-height: 14px;
position: relative;
} }
.realtimeMapperList .littleRtOff { .rtUserImage {
background-image: url('junto24.png'); position: absolute;
top: 4px;
left: 0;
border-radius: 12px;
} }
.realtimeMapperList .littleRtOn { .littleJuntoIcon {
background-image: url('junto24.png'); width: 24px;
height:24px;
position: absolute;
top: 4px;
right: 0;
background-image: url('junto24_sprite.png');
}
.realtimeMapperList .littleRtOff .littleJuntoIcon {
background-position: 0 0;
}
.realtimeMapperList .littleRtOn .littleJuntoIcon {
background-position: -24px 0;
} }
/* end collaborate */ /* end collaborate */
@ -1089,7 +1111,7 @@ float: left;
background-position: 13px center; background-position: 13px center;
} }
.mapSynapses { .mapSynapses {
background-image: url(synapse32tmcard.png); background-image: url(synapse32.png);
background-position: 13px center; background-position: 13px center;
} }
.mapInfoBox .mapPermission { .mapInfoBox .mapPermission {
@ -1099,14 +1121,26 @@ float: left;
padding: 0; padding: 0;
margin: 8px 30px 8px 10px; margin: 8px 30px 8px 10px;
position: relative; position: relative;
background-image: url(permissions32_sprite.png);
}
.mapInfoBox .mapPermission.commons {
background-position: 0 0;
}
.mapInfoBox .mapPermission.public {
background-position: -64px 0;
}
.mapInfoBox .mapPermission.private {
background-position: -32px 0;
} }
.yourMap .mapPermission:hover { .yourMap .mapPermission:hover {
background-image: url(arrowexpand.png); background-image: url(arrowdown_sprite.png);
cursor: pointer; cursor: pointer;
background-position: center -11px;
} }
.yourMap .mapPermission.minimize { .yourMap .mapPermission.minimize {
background-image: url(arrowcollapse.png) !important; background-image: url(arrowdown_sprite.png) !important;
cursor: pointer; cursor: pointer;
background-position: center -11px;
} }
.mapInfoBox .mapPermission .permissionSelect { .mapInfoBox .mapPermission .permissionSelect {
list-style: none; list-style: none;
@ -1119,7 +1153,25 @@ float: left;
width: 32px; width: 32px;
height: 32px; height: 32px;
background-repeat: no-repeat; background-repeat: no-repeat;
background-position: center center; background-image: url(permissions32_sprite.png);
}
.mapInfoBox .mapPermission .permissionSelect .commons {
background-position: 0 0;
}
.mapInfoBox .mapPermission .permissionSelect .public {
background-position: -64px 0;
}
.mapInfoBox .mapPermission .permissionSelect .private {
background-position: -32px 0;
}
.mapInfoBox .mapPermission .permissionSelect .commons:hover {
background-position: 0 -32px;
}
.mapInfoBox .mapPermission .permissionSelect .public:hover {
background-position: -64px -32px;
}
.mapInfoBox .mapPermission .permissionSelect .private:hover {
background-position: -32px -32px;
} }
.mapInfoBox .mapInfoDesc { .mapInfoBox .mapInfoDesc {
font-family: helvetica, sans-serif; font-family: helvetica, sans-serif;
@ -1128,6 +1180,7 @@ float: left;
height: 106px; height: 106px;
font-size: 14px; font-size: 14px;
line-height: 16px; line-height: 16px;
overflow-y: auto;
} }
.mapInfoBox .mapInfoMeta { .mapInfoBox .mapInfoMeta {
height: 35px; height: 35px;

View file

@ -202,19 +202,31 @@
font-family: 'din-medium', helvetica, sans-serif; font-family: 'din-medium', helvetica, sans-serif;
} }
.sidebarSearch .tt-dropdown-menu { .sidebarSearch .tt-dropdown-menu {
left: -35px !important; top: 40px !important;
background: #0F1519; background: #FFF;
min-width: 440px; width: 472px;
width: 440px; overflow-y: auto;
overflow-y: scroll;
overflow-x: hidden; overflow-x: hidden;
box-shadow: 0 1px 1.5px rgba(0,0,0,0.12), 0 1px 1px rgba(0,0,0,0.24);
}
.searchHeader {
height: 42px;
width: 100%;
}
.searchTopicsHeader {
background: #4fc4a8;
}
.searchMapsHeader {
background: #994fc0;
}
.searchMappersHeader {
background: #c04f4f;
} }
.sidebarSearch .tt-dropdown-menu h3 { .sidebarSearch .tt-dropdown-menu h3 {
font-family: 'vinyl', helvetica, sans-serif;
text-transform: uppercase; text-transform: uppercase;
font-style: italic; color: #F5F5F5;
font-size: 20px; font-size: 18px;
line-height: 20px; line-height: 18px;
margin: 10px 0 3px 10px; margin: 10px 0 3px 10px;
float: left; float: left;
} }
@ -246,15 +258,14 @@
cursor: pointer; cursor: pointer;
} }
.sidebarSearch .tt-suggestions { .sidebarSearch .tt-suggestions {
font-family: 'LatoLight', helvetica, sans-serif;
overflow: visible; overflow: visible;
} }
.sidebarSearch .tt-suggestion { .sidebarSearch .tt-suggestion {
background: #2A343C; background: #FFF;
} }
.sidebarSearch .tt-is-under-cursor, .sidebarSearch .tt-is-under-cursor,
.sidebarSearch .tt-is-under-mouse-cursor { .sidebarSearch .tt-is-under-mouse-cursor {
background: #0E161D; background: #E0E0E0;
} }
.sidebarSearch .tt-dataset-maps .tt-is-under-cursor .resultmap, .sidebarSearch .tt-dataset-maps .tt-is-under-cursor .resultmap,
.sidebarSearch .tt-dataset-maps .tt-is-under-mouse-cursor .resultmap, .sidebarSearch .tt-dataset-maps .tt-is-under-mouse-cursor .resultmap,
@ -264,9 +275,10 @@
} }
.sidebarSearch .tt-suggestion .icon { .sidebarSearch .tt-suggestion .icon {
float: left; float: left;
width: 36px; width: 32px;
height: 36px; height: 32px;
margin-right: 5px; margin-right: 5px;
border-radius:16px;
} }
.sidebarSearch .topicMetacode { .sidebarSearch .topicMetacode {
float: left; float: left;
@ -274,8 +286,8 @@
max-width: 70px; max-width: 70px;
} }
.sidebarSearch .tt-dataset-topics .topicIcon { .sidebarSearch .tt-dataset-topics .topicIcon {
width: 36px; width: 32px;
height: 36px; height: 32px;
} }
.sidebarSearch .tt-dataset-topics .tt-is-under-cursor .topicIcon, .sidebarSearch .tt-dataset-topics .tt-is-under-cursor .topicIcon,
.sidebarSearch .tt-dataset-topics .tt-is-under-mouse-cursor .topicIcon { .sidebarSearch .tt-dataset-topics .tt-is-under-mouse-cursor .topicIcon {
@ -296,9 +308,7 @@
text-align: center; text-align: center;
} }
.sidebarSearch .tt-dataset-mappers .tt-suggestion .icon { .sidebarSearch .tt-dataset-mappers .tt-suggestion .icon {
width: 28px; margin: 4px 9px 4px 4px;
height: 28px;
padding: 4px;
} }
.sidebarSearch .resultText { .sidebarSearch .resultText {
width: 225px; width: 225px;
@ -308,14 +318,12 @@
} }
.sidebarSearch .resultTitle { .sidebarSearch .resultTitle {
font-weight: normal; font-weight: normal;
font-family: 'LatoRegular';
font-size: 18px; font-size: 18px;
line-height: 22px; line-height: 22px;
width: 100%; width: 100%;
padding-top: 8px; padding-top: 8px;
} }
.sidebarSearch .resultDesc { .sidebarSearch .resultDesc {
font-family: 'LatoItalic';
font-size: 14px; font-size: 14px;
line-height: 16px; line-height: 16px;
width: 100%; width: 100%;
@ -481,7 +489,7 @@
position: fixed; position: fixed;
top: 10px; top: 10px;
right: 24px; right: 24px;
z-index:3; z-index:4;
} }
.upperRightUI .upperRightEl { .upperRightUI .upperRightEl {

View file

@ -8,6 +8,7 @@ module UsersHelper
user['id'] = u.id user['id'] = u.id
user['label'] = u.name user['label'] = u.name
user['value'] = u.name user['value'] = u.name
user['profile'] = u.image.url(:thumb)
user['mapCount'] = u.maps.count user['mapCount'] = u.maps.count
user['rtype'] = "mapper" user['rtype'] = "mapper"

View file

@ -23,7 +23,8 @@ class User < ActiveRecord::Base
:thumb => ['100x100>', :png], :thumb => ['100x100>', :png],
:square => ['200x200#', :png], :square => ['200x200#', :png],
:round => ['200x200#', :png] :round => ['200x200#', :png]
} },
:default_url => "/assets/user.png"
#, :convert_options => {:round => Proc.new{self.convert_options}} #, :convert_options => {:round => Proc.new{self.convert_options}}

View file

@ -6,7 +6,7 @@
<div class="templates"> <div class="templates">
<script type="text/template" id="mapInfoBoxTemplate"> <script type="text/template" id="mapInfoBoxTemplate">
<div class="mapInfoName">{{name}}</div> <div class="mapInfoName">{{{name}}}</div>
<div class="mapInfoStat"> <div class="mapInfoStat">
<div class="infoStatIcon mapContributors hoverForTip"> <div class="infoStatIcon mapContributors hoverForTip">
@ -20,21 +20,21 @@
{{synapse_count}} {{synapse_count}}
</div> </div>
<div class="infoStatIcon mapPermission {{permission}} hoverForTip"> <div class="infoStatIcon mapPermission {{permission}} hoverForTip">
{{map_creator_tip}} {{{map_creator_tip}}}
</div> </div>
<div class="clearfloat"></div> <div class="clearfloat"></div>
</div> </div>
<div class="mapInfoDesc"> <div class="mapInfoDesc">
{{desc}} {{{desc}}}
</div> </div>
<div class="mapInfoMeta"> <div class="mapInfoMeta">
<p>Created by {{user_name}} on {{created_at}}</p> <p class="mapCreatedAt">Created by {{user_name}} on {{created_at}}</p>
<p>Last edited {{updated_at}}</p> <p class="mapEditedAt">Last edited {{updated_at}}</p>
</div> </div>
<div class="mapInfoDelete"> <div class="mapInfoDelete">
{{delete}} {{{delete}}}
</div> </div>
</script> </script>
@ -43,14 +43,14 @@
<div class="permission {{editPermission}}"> <!-- must be canEdit or cannotEdit --> <div class="permission {{editPermission}}"> <!-- must be canEdit or cannotEdit -->
<div class="mapCard"> <div class="mapCard">
<span class="title"> <span class="title">
<span class="best_in_place best_in_place_name" id="best_in_place_map_{{id}}_name" data-url="/maps/{{id}}" data-object="map" data-attribute="name" data-type="textarea">{{name}}</span> {{name}}
</span> </span>
<div class="mapScreenshot"> <div class="mapScreenshot">
<img src="https://dl.dropboxusercontent.com/u/13307147/map%20screengrab%20blur-02.png"> <img src="https://dl.dropboxusercontent.com/u/13307147/map%20screengrab%20blur-02.png">
</div> </div>
<div class="scroll"> <div class="scroll">
<div class="desc"> <div class="desc">
<span class="best_in_place best_in_place_desc" id="best_in_place_map_{{id}}_desc" data-url="/maps/{{id}}" data-object="map" data-attribute="desc" data-nil="Click to add description." data-type="textarea">{{desc}}</span> {{desc}}
<div class="clearfloat"></div> <div class="clearfloat"></div>
</div> </div>
</div> </div>
@ -107,7 +107,7 @@
<script type="text/template" id="mapSearchTemplate"> <script type="text/template" id="mapSearchTemplate">
<div class="result{{rtype}}"> <div class="result{{rtype}}">
<img class="icon" src="/assets/map.png"> <img class="icon" src="/assets/metamap32c.png">
<div class="resultText"> <div class="resultText">
<p class="resultTitle">{{label}}</p> <p class="resultTitle">{{label}}</p>
<p class="resultDesc">{{description}}</p> <p class="resultDesc">{{description}}</p>
@ -138,7 +138,7 @@
<script type="text/template" id="mapperSearchTemplate"> <script type="text/template" id="mapperSearchTemplate">
<div class="result{{rtype}}"> <div class="result{{rtype}}">
<img class="icon" width="28" height="28" src="/assets/MMCCicon_mapper.png"> <img class="icon" width="32" height="32" src="{{profile}}">
<div class="resultText"> <div class="resultText">
<p class="resultTitle">{{label}}</p> <p class="resultTitle">{{label}}</p>
</div> </div>

View file

@ -23,13 +23,16 @@
<div class="sidebarCollaborate upperRightEl"> <div class="sidebarCollaborate upperRightEl">
<div class="sidebarCollaborateIcon upperRightIcon blue"></div> <div class="sidebarCollaborateIcon upperRightIcon blue"></div>
<div class="sidebarCollaborateBox upperRightBox"> <div class="sidebarCollaborateBox upperRightBox">
<h3 class="realtimeBoxTitle">Realtime: </h3> <h3 class="realtimeBoxTitle">REALTIME</h3>
<span class="realtimeOnOff rtOff">OFF</span>
<span class="realtimeOnOff rtOn">ON</span> <span class="realtimeOnOff rtOn">ON</span>
<div class="clearfloat"></div> <div class="clearfloat"></div>
<div class="realtimeMapperList"> <div class="realtimeMapperList">
<ul> <ul>
<li class="rtMapper littleRtOn rtMapperSelf"> <li class="rtMapper littleRtOn rtMapperSelf">
<%= image_tag user.image.url(:thumb), :size => "24x24", :class => "rtUserImage" %>
<%= user.name %> (me) <%= user.name %> (me)
<div class="littleJuntoIcon"></div>
</li> </li>
</ul> </ul>
</div> </div>

View file

@ -41,8 +41,8 @@
<% end %> <% end %>
<div class="mapInfoMeta"> <div class="mapInfoMeta">
<p>Created by <%= @map.user == user ? "you" : @map.user.name %> on <%= @map.created_at.strftime("%m/%d/%Y") %></p> <p class="mapCreatedAt">Created by <%= @map.user == user ? "you" : @map.user.name %> on <%= @map.created_at.strftime("%m/%d/%Y") %></p>
<p>Last edited <%= @map.updated_at.strftime("%m/%d/%Y") %></p> <p class="mapEditedAt">Last edited <%= @map.updated_at.strftime("%m/%d/%Y") %></p>
</div> </div>
<div class="mapInfoDelete"> <div class="mapInfoDelete">

View file

@ -44,43 +44,50 @@
end end
@synapses.each_with_index do |synapse, index| @synapses.each_with_index do |synapse, index|
@synapselist += '<li data-id="' + synapse.desc + '">' @synapselist += '<li data-id="' + synapse.desc + '">'
@synapselist += '<img src="/assets/synapsevisualize.png" alt="synapse icon" /><p>' + synapse.desc @synapselist += '<img src="/assets/synapse16.png" alt="synapse icon" /><p>' + synapse.desc
@synapselist += '</p></li>' @synapselist += '</p></li>'
end end
@mappers.each_with_index do |mapper, index| @mappers.each_with_index do |mapper, index|
@mapperlist += '<li data-id="' + mapper.id.to_s + '">' @mapperlist += '<li data-id="' + mapper.id.to_s + '">'
@mapperlist += '<img src="/assets/icons/person.png" data-id="' + mapper.id.to_s + '" alt="' + mapper.name + '" />' @mapperlist += '<img src="' + mapper.image.url(:thumb) + '" data-id="' + mapper.id.to_s + '" alt="' + mapper.name + '" />'
@mapperlist += '<p>' + mapper.name + '</p></li>' @mapperlist += '<p>' + mapper.name + '</p></li>'
end end
end end
%> %>
<div class="filterBox"> <div class="filterBox">
<h2>FILTER BY</h2>
<div class="clearfloat"></div> <div id="filter_by_mapper" class="filterBySection">
<div id="filter_by_metacode"> <h3>MAPPERS</h3>
<h3>metacodes</h3><span class="showAll showAllMetacodes">all</span> <span class="hideAll hideAllMetacodes">none</span> <span class="hideAll hideAllMappers">NONE</span>
<br> <span class="showAll showAllMappers">ALL</span>
<ul>
<%= @metacodelist.html_safe %>
</ul>
<div class="clearfloat"></div> <div class="clearfloat"></div>
</div>
<div id="filter_by_synapse">
<h3>synapses</h3> <span class="showAll showAllSynapses">all</span> <span class="hideAll hideAllSynapses">none</span>
<br>
<ul>
<%= @synapselist.html_safe %>
</ul>
<div class="clearfloat"></div>
</div>
<div id="filter_by_mapper">
<h3>mappers</h3><span class="showAll showAllMappers">all</span> <span class="hideAll hideAllMappers">none</span>
<br>
<ul> <ul>
<%= @mapperlist.html_safe %> <%= @mapperlist.html_safe %>
</ul> </ul>
<div class="clearfloat"></div> <div class="clearfloat"></div>
</div> </div>
<div id="filter_by_metacode" class="filterBySection">
<h3>METACODES</h3>
<span class="hideAll hideAllMetacodes">NONE</span>
<span class="showAll showAllMetacodes">ALL</span>
<div class="clearfloat"></div>
<ul>
<%= @metacodelist.html_safe %>
</ul>
<div class="clearfloat"></div>
</div>
<div id="filter_by_synapse" class="filterBySection">
<h3>SYNAPSES</h3>
<span class="hideAll hideAllSynapses">NONE</span>
<span class="showAll showAllSynapses">ALL</span>
<div class="clearfloat"></div>
<ul>
<%= @synapselist.html_safe %>
</ul>
<div class="clearfloat"></div>
</div>
</div> <!-- end .filterBox --> </div> <!-- end .filterBox -->

View file

@ -45,7 +45,8 @@ function start() {
var existingUser = { var existingUser = {
userid: data.userid, userid: data.userid,
username: data.username, username: data.username,
userrealtime: data.userrealtime userrealtime: data.userrealtime,
userimage: data.userimage
}; };
socket.broadcast.emit(data.userToNotify + '-' + data.mapid + '-UpdateMapperList', existingUser); socket.broadcast.emit(data.userToNotify + '-' + data.mapid + '-UpdateMapperList', existingUser);
}); });
@ -58,7 +59,8 @@ function start() {
var newUser = { var newUser = {
userid: data.userid, userid: data.userid,
username: data.username username: data.username,
userimage: data.userimage
}; };
socket.broadcast.emit('maps-' + data.mapid + '-newmapper', newUser); socket.broadcast.emit('maps-' + data.mapid + '-newmapper', newUser);