annot-server/static/js/annotviz.js
author ymh <ymh.work@gmail.com>
Fri, 17 Apr 2015 15:32:19 +0200
changeset 166 fa9e24e46968
parent 161 0b01cbd8ed9e
permissions -rw-r--r--
pianoroll use ts_server
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
!function(e){if("object"==typeof exports&&"undefined"!=typeof module)module.exports=e();else if("function"==typeof define&&define.amd)define([],e);else{var n;"undefined"!=typeof window?n=window:"undefined"!=typeof global?n=global:"undefined"!=typeof self&&(n=self),n.annotviz=e()}}(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
 * scripts/main.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
 *
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
 * This is the starting point for your application.
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
     6
 * Take a look at http://browserify.org/ for more info
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
 */
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
var doubleroll = require('./doubleroll');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
var annotsroll = require('./annotsroll');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
var annotstimeline = require('./annotstimeline');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
var annotsvizview = require('./annotsvizview');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
var stageview = require('./stageview');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
var wswrapper = require('./wswrapper');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
var logger = require('./logger');
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
    18
var utils = require('./utils');
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
var _ = require('lodash');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
module.exports = _({})
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
    .extend(doubleroll)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
    .extend(annotsroll)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
    .extend(annotstimeline)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
    .extend(annotsvizview)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
    .extend(stageview)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
    .extend(wswrapper)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
    .extend(logger)
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
    30
    .extend(utils)
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
    .value();
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
    32
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
    33
},{"./annotsroll":2,"./annotstimeline":3,"./annotsvizview":4,"./doubleroll":5,"./logger":6,"./stageview":8,"./utils":9,"./wswrapper":10,"lodash":"lodash"}],2:[function(require,module,exports){
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
* js/annotsRoll.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    36
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
* annotsRoll basic component
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
*/
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
var PIXI = require('pixi');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
var _ = require('lodash');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
var DEFAULT_ANNOT_COLOR = '#bababa';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
var defaultAnnotStyles = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
    'label': { font: '16pt Arial Bold', fill: '#65A954', wordWrap: true},
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
    'text' : { font: '12pt Arial Regular', fill: '#444444', wordWrap: true},
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
    'user' : { font: '14pt Arial regular', fill: '#666666' },
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
var defaultOptions = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
    externalRefresh: false,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
    defaultColor: DEFAULT_ANNOT_COLOR,
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
    57
    annotStyles: defaultAnnotStyles,
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
    58
    ignoreAnnots:false
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
function AnnotsRoll(options) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
//parentContainer, xInit, yInit, width, height, widthRoll, pixelsPerSecond, annotColors
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
    var _this = this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
    var opts = _(options).defaults(defaultOptions).value();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
    this.container = new PIXI.DisplayObjectContainer();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
    this.container.x = opts.xInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
    this.container.y = opts.yInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
    this.container.width = opts.width;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    73
    this.height = opts.height;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    74
    this.width = opts.width;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    75
    this.widthRoll = opts.widthRoll;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
    this.pixelsPerSecond = opts.pixelsPerSecond;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
    this.annotColors = opts.annotColors;
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
    78
    this.startTs = opts.startTs || Date.now();
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
    79
    this.ignoreAnnots = opts.ignoreAnnots;
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    80
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    81
    var yInit = opts.yInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    82
    var annotStyles = _(opts.annotStyles).defaults(defaultAnnotStyles).value();
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    83
    var marginX = 15;
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
    for(var style in annotStyles) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
    	if (annotStyles[style].wordWrap === true){
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
    86
    		annotStyles[style].wordWrapWidth = this.widthRoll - marginX;
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
    	}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
    }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    89
    var started = false;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    90
    var ws = opts.ws;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    91
    var externalRefresh = opts.externalRefresh;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
    var stageView = opts.stageView;
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
    93
    var waitInterval;
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
    94
    var wait = 0;
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
    95
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
    stageView.registerComponent(this);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    98
    var isHidden = function(child) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
        // TODO: the origin point is an approximation. Should refine this
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
        var globalPos = child.toGlobal(new PIXI.Point(0,0));
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
        return ((globalPos.x + child.width) < 0) || ((globalPos.y + child.height) < 0) ;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
    this.addAnnots = function(data) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   106
        //var title = data.content.category.label;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   107
        //var user = data.content.user;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
        //Test cat and color
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
        //var colorAnnot = 0x65A954;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
        var category = data.content.category.label,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
            text     = data.content.text,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   112
            user     = data.content.user,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   113
            ts       = Date.parse(data.ts),
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   114
            color    = data.content.color || this.getColor(ts, data.content.category.code);
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   115
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   116
        this.addAnnot(category, text, user, color, ts);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   117
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   118
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   119
    this.getColor = function(ts, code) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   120
        var colorsDef;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   121
        _(this.annotColors).eachRight(function(cdef) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   122
            if(cdef.ts < ts) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   123
                colorsDef = cdef.colors;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   124
                return false;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   125
            }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   126
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   127
        var resColor;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   128
        if(colorsDef) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   129
            resColor = colorsDef[code];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   130
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   131
        if(!resColor) {
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   132
            resColor = colorsDef.defaultColor || DEFAULT_ANNOT_COLOR;
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   133
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   134
        return resColor;
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   135
    };
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   136
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   137
    this.addAnnot = function(category, text, user, color, ts){
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   138
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   139
        var x = 0;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   140
        var y = (ts-this.startTs) * this.pixelsPerSecond / 1000 + yInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   141
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   142
        var colorHex = parseInt(color.replace(/^#/, ''), 16);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   143
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   144
        if (wait === 0){
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   145
	        var graphics = new PIXI.Graphics()
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   146
	            .beginFill(colorHex)
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   147
	            .drawRect(x, y, 10, 3)
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   148
	            .endFill();
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   149
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   150
	        this.container.addChild(graphics);
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   151
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   152
	        var textHeight = 0;
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   153
	        var catLabel = new PIXI.Text(
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   154
	            category,
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   155
	            _(annotStyles.label).extend({fill: color}).value()
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   156
	        );
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   157
	        catLabel.x = x + marginX;
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   158
	        catLabel.y = y - 23;
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   159
	        this.container.addChild(catLabel);
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   160
	        textHeight += (catLabel.height - 23 + 2);
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   161
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   162
	        if(text) {
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   163
	            var catText = new PIXI.Text(text, annotStyles.text);
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   164
	            catText.x = x + marginX;
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   165
	            catText.y = y + textHeight;
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   166
	            this.container.addChild(catText);
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   167
	            textHeight += (catText.height + 2);
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   168
	        }
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   169
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   170
	        var catUser = new PIXI.Text(user, annotStyles.user);
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   171
	        catUser.x = x + marginX;
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   172
	        catUser.y = y + textHeight;
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   173
	        this.container.addChild(catUser);
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   174
	        textHeight += (catUser.height + 8);
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   175
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   176
	        if (this.ignoreAnnots === true){
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   177
		        wait = textHeight / this.pixelsPerSecond;
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   178
		        waitInterval = setInterval(function() {_this.refreshWait();}, 1000);
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   179
	        }
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   180
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   181
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   182
        this.addAnnotLine(colorHex, y);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   183
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   184
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   185
    this.addAnnotLine = function(color, y) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   186
        var x = this.widthRoll;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   187
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   188
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   189
        var graphics = new PIXI.Graphics()
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   190
            .beginFill(color)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   191
            .drawRect(x, y, this.width - x, 3)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   192
            .endFill();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   193
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   194
        this.container.addChild(graphics);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   195
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   196
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   197
    this.moveTo = function(diffTime){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
    	this.container.y = Math.floor(diffTime*this.pixelsPerSecond);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   199
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   200
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   201
    this.move = this.refresh = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   202
        var diff = (this.startTs - Date.now())/1000;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   203
        this.moveTo(diff);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   204
    };
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   205
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   206
    this.refreshWait = function(){
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   207
    	wait -= 1;
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   208
    	if (wait < 0){
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   209
    		wait = 0;
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   210
    		clearInterval(waitInterval);
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   211
    	}
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   212
    };
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   213
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   214
    this.removePassedObjets = function(){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   215
        var childrenToRemove = [];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   216
        _(_this.container.children).forEach(function(child) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   217
            return typeof(child) === 'undefined' ||
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   218
                (isHidden(child) && childrenToRemove.push(child));
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   219
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   220
        childrenToRemove.forEach(function(child) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   221
            _this.container.removeChild(child);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   222
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   223
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   224
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   225
    this.init = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   226
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   227
        ws.message(function(data) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   228
            _this.addAnnots(data);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   229
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   230
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   231
    };
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   232
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   233
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   234
    this.start = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   235
        if(!started) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   236
            this.startTs = Date.now();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   237
            started = true;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   238
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   239
        this.cleanInterval = setInterval(function () { _this.removePassedObjets(); }, 1000 * this.height / this.pixelsPerSecond );
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   240
        if(!externalRefresh) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   241
            this.refreshInterval = setInterval(function() {_this.move();}, 1000/this.framerate);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   242
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   243
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   244
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   245
    this.stop = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
        clearInterval(this.cleanInterval);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
        if(!externalRefresh) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
            clearInterval(this.refreshInterval);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   251
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   254
module.exports = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   255
    AnnotsRoll: AnnotsRoll,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   256
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   257
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   258
},{"lodash":"lodash","pixi":"pixi"}],3:[function(require,module,exports){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   259
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   260
* js/annotstimeline
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   261
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   262
* annotstimeline basic component
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   263
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   264
*/
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   265
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   266
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   267
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   268
var PIXI = require('pixi');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   269
var Utils = require('./utils.js');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   270
var _ = require('lodash');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   271
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   272
var defaultOptions = {
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   273
    logger: undefined,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   274
    intervalWidth: 10,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   275
    intervalHeight: 5,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   276
    maxCellHeight: 200,
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   277
    radius: 300,
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   278
    serverUrl: 'http://127.0.0.1:8080',
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   279
    channel: 'ANNOT',
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   280
    maxPages: 1000,
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   281
    showClockGraphics: true,
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   282
    archive: false
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   283
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   284
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   285
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   286
function AnnotsTimeLine(options){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   287
    var _this = this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   288
    var opts = _(options).defaults(defaultOptions).value();
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   289
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   290
    this.container = new PIXI.DisplayObjectContainer();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   291
    this.container.x = opts.xInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   292
    this.container.y = opts.yInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   293
    this.container.width = opts.width;
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   294
    this.container.height = opts.height;
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   295
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   296
    this.timeBegin = opts.timeBegin;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   297
    this.timeEnd = opts.timeEnd;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   298
    this.duration = (this.timeEnd - this.timeBegin)/1000;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   299
    this.width = opts.width;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   300
    this.height = opts.height;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   301
    this.intervalHeight = opts.intervalHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   302
    this.intervalWidth = opts.intervalWidth;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   303
    this.maxCellHeight = opts.maxCellHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   304
    this.annotCategories = opts.annotCategories;
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   305
    this.startTs = options.startTs || Date.now();
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   306
    this.showClockGraphics = opts.showClockGraphics;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   307
    this.archive = opts.archive;
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   308
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   309
    this.circleX = opts.circleX || (this.width/2);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   310
    this.circleY = opts.circleY || (this.height/2);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   311
    this.radius = opts.radius;
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   312
    var perimeter = 2*Math.PI* this.radius;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   313
    this.intervalDuration = (this.intervalWidth * this.duration / perimeter);
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   314
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   315
    var channel = opts.channel;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   316
    var eventCode = opts.eventCode;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   317
    var serverUrl = opts.serverUrl;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   318
    var maxPages = opts.maxPages;
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   319
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   320
    var totalIndex = Math.floor( perimeter/this.intervalWidth);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   321
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   322
    this.cells = [];
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   323
    for (var i=0; i<(perimeter/this.intervalWidth) ; i++){
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   324
        this.cells[i] = [];
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   325
        this.cells[i].i = i;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   326
        this.cells[i].totalAnnots = 0;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   327
        this.cells[i].categories = {};
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   328
    }
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   329
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   330
    var ws = opts.ws;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   331
    var stageView = opts.stageView;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   332
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   333
    //draw the base - circle and line to locate the scene
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   334
    var graphics = new PIXI.Graphics();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   335
    graphics.lineStyle(2, 0x646464)
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   336
        .drawCircle(this.circleX, this.circleY, this.radius - 3)
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   337
        .endFill();
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   338
    this.container.addChild(graphics);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   339
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   340
    stageView.registerComponent(this);
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   341
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   342
    var loadArchives = function() {
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   343
        //start timeBegin end startTime
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   344
        //query -> need channel + eventCode
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   345
        //iterate over data fill cells
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   346
        var startTs = _this.timeBegin;
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   347
        var endTs = Math.min(_this.timeEnd,_this.startTs);
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   348
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   349
        var url = serverUrl + '/p/api/v1/annotation';
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   350
        var filters = [
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   351
            { name: 'ts', op: '>', val: new Date(startTs).toISOString()}, //start
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   352
            { name: 'ts', op: '<=', val: new Date(endTs).toISOString()}, //end
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   353
            { name: 'channel', op: '==', val: channel}, //channel
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   354
            { name: 'event_code', op: '==', val: eventCode} //eventcode
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   355
        ];
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   356
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   357
        url = url + '?q=' + JSON.stringify({filters:filters});
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   358
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   359
        var totalPage = 1;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   360
        var currentPage = 1;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   361
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   362
        var processResFunction = function(res) {
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   363
            //console.log("RES archive", res);
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   364
            if(res) {
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   365
                var data = res.target.json;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   366
                /*jshint -W069 */
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   367
                totalPage = Math.min(maxPages,parseInt(data['total_pages']));
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   368
                data.objects.forEach(function(annotation) {
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   369
                    _this.addAnnot(annotation);
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   370
                });
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   371
            }
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   372
            if(currentPage <= totalPage) {
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   373
                var jsonLoader = new PIXI.JsonLoader(url+'&page='+currentPage, true);
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   374
                jsonLoader.on('loaded', processResFunction);
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   375
                jsonLoader.load();
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   376
                currentPage++;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   377
            }
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   378
        };
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   379
        processResFunction();
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   380
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   381
    };
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   382
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   383
    //Add Annotation to the TimeLine
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   384
    this.addAnnot = function(data){
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   385
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   386
        var ts = Date.parse(data.ts);
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   387
        var colorsDef;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   388
        _(this.annotCategories).eachRight(function(cdef) {
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   389
            if(cdef.ts < ts) {
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   390
                colorsDef = cdef;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   391
                return false;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   392
            }
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   393
        });
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   394
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   395
        if(!colorsDef) {
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   396
            return;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   397
        }
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   398
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   399
        if (this.timeEnd > ts){
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   400
            var i = Math.floor((ts - this.timeBegin)/(1000*this.intervalDuration));
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   401
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   402
            if (typeof(this.cells[i].graphics) === 'undefined'){
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   403
                this.initCell(this.cells[i], colorsDef);
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   404
            }
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   405
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   406
            var annotCode;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   407
            if (typeof(colorsDef.colors[data.content.category.code]) !== 'undefined'){
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   408
                annotCode = data.content.category.code;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   409
            } else {
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   410
                annotCode = 'default';
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   411
            }
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   412
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   413
            this.cells[i].categories[annotCode].count += 1;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   414
            this.cells[i].totalAnnots +=1;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   415
            this.redrawCell(this.cells[i], colorsDef);
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   416
        }
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   417
    };
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   418
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   419
    this.initClockGraphics = function() {
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   420
        var tBeg = new PIXI.Text(Utils.formatTime(this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   421
        tBeg.x = this.circleX + 15;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   422
        tBeg.y = this.circleY - this.radius - this.maxCellHeight - 10;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   423
        this.container.addChild(tBeg);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   424
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   425
        var tEnd = new PIXI.Text(Utils.formatTime(this.timeEnd), { font: '12pt Gothic Standard', fill: '#646464' });
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   426
        tEnd.x = this.circleX - 15 - tEnd.width;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   427
        tEnd.y = this.circleY - this.radius - this.maxCellHeight - 10;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   428
        this.container.addChild(tEnd);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   429
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   430
        var t15 = new PIXI.Text(Utils.formatTime(((this.timeEnd - this.timeBegin)/4) + this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   431
        t15.x = this.circleX + this.radius + this.maxCellHeight + 10 ;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   432
        t15.y = this.circleY - t15.height;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   433
        t15.rotation = Math.PI /2;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   434
        this.container.addChild(t15);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   435
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   436
        var t30 = new PIXI.Text(Utils.formatTime(((this.timeEnd - this.timeBegin)/2) + this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   437
        t30.x = this.circleX - t30.width/2;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   438
        t30.y = this.circleY + this.radius + this.maxCellHeight - 2;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   439
        this.container.addChild(t30);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   440
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   441
        var t45 = new PIXI.Text(Utils.formatTime(((this.timeEnd - this.timeBegin)*3/4) + this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   442
        t45.x = this.circleX - this.radius - this.maxCellHeight - 10 ;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   443
        t45.y = this.circleY + t15.height;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   444
        t45.rotation = -Math.PI/2;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   445
        this.container.addChild(t45);
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   446
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   447
        var lineV = new PIXI.Graphics();
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   448
        lineV.lineStyle(1, 0x646464)
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   449
            .moveTo(this.circleX, this.circleY - (this.radius/3)/2)
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   450
            .lineTo(this.circleX, this.circleY - this.radius - this.maxCellHeight - 10)
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   451
            .endFill();
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   452
        this.container.addChild(lineV);
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   453
    };
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   454
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   455
    //Draw the cellule
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   456
    this.redrawCell = function(cell, colorsDef){
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   457
        var y = 0;
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   458
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   459
        //Check if total height is higher than Max Cell Height
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   460
        var heightStep;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   461
        if ((cell.totalAnnots*this.intervalHeight) > this.maxCellHeight){
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   462
            heightStep = this.maxCellHeight/cell.totalAnnots;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   463
        } else {
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   464
            heightStep = this.intervalHeight;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   465
        }
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   466
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   467
        //Draw the rect depending on the height step calculated
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   468
        for (var i=0; i< colorsDef.order.length; i++){
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   469
            var currentCode = colorsDef.order[i];
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   470
            cell.graphics.beginFill(cell.categories[currentCode].color.replace('#', '0x'))
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   471
                .drawRect(0, y, this.intervalWidth-1, -cell.categories[currentCode].count * heightStep)
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   472
                .endFill();
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   473
            y -= cell.categories[currentCode].count*heightStep;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   474
        }
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   475
    };
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   476
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   477
    this.initCell = function(cell, colorsDef){
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   478
        cell.graphics = new PIXI.Graphics();
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   479
        cell.graphics.position.x = this.circleX + this.radius * Math.sin(cell.i*(360/totalIndex)*(Math.PI/180));
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   480
        cell.graphics.position.y = this.circleY - this.radius * Math.cos(cell.i*(360/totalIndex)*(Math.PI/180));
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   481
        cell.graphics.rotation = (cell.i)*(360/totalIndex)*(Math.PI/180) + (360/(totalIndex*2))*(Math.PI/180);
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   482
        this.container.addChild(cell.graphics);
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   483
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   484
        for (var category in colorsDef.colors){
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   485
            cell.categories[category] = {
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   486
                'count': 0,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   487
                'color': colorsDef.colors[category]
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   488
            };
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   489
        }
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   490
        if (typeof(cell.categories['default']) === 'undefined'){
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   491
            cell.categories['default'] = {
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   492
                'count': 0,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   493
                'color': colorsDef.defaultColor
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   494
            };
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   495
        }
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   496
    };
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   497
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   498
    this.init = function() {
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   499
        if (!this.archive){
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   500
            ws.message(function(data) {
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   501
                _this.addAnnot(data);
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   502
            });
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   503
        }
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   504
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   505
        if (this.showClockGraphics){this.initClockGraphics();}
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   506
    };
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   507
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   508
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   509
    this.start = function() {
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   510
        this.startTs = Date.now();
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   511
        loadArchives();
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   512
    };
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   513
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   514
    this.refresh = function() {
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   515
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   516
    };
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   517
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   518
    this.stop = function(){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   519
    };
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   520
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   521
    return this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   522
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   523
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   524
module.exports = {
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   525
    AnnotsTimeLine: AnnotsTimeLine
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   526
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   527
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   528
},{"./utils.js":9,"lodash":"lodash","pixi":"pixi"}],4:[function(require,module,exports){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   529
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   530
* js/annotsvizview.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   531
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   532
* This is the starting point for your application.
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   533
* Take a look at http://browserify.org/ for more info
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   534
*
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   535
*/
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   536
/*jshint unused: false */
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   537
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   538
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   539
var PIXI = require('pixi');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   540
var _ = require('lodash');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   541
var DoubleRoll = require('./doubleroll.js');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   542
var AnnotsTimeLine = require('./annotstimeline.js');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   543
var AnnotsRoll = require('./annotsroll.js');
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   544
var Utils = require('./utils.js');
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   545
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   546
var defaultOptions = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   547
    xInit: 0,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   548
    yInit: 0,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   549
    width: 1024,
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   550
    height: 768
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   551
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   552
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   553
function AnnotsVizView(options){
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   554
    var _this = this;
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   555
    var opts = _(options).defaults(defaultOptions).value();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   556
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   557
    this.container = new PIXI.DisplayObjectContainer();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   558
    this.container.x = opts.xInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   559
    this.container.y = opts.yInit;
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   560
    this.width = opts.width;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   561
    this.height= opts.height;
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   562
    this.timeBegin = opts.timeBegin;
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   563
    this.timeEnd = opts.timeEnd;
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   564
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   565
    this.annotCategories = [];
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   566
    this.annotCategoriesDay2 = [];
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   567
    this.annotCategoriesDay1 = [];
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   568
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   569
    var wsPianoroll = opts.wsPianoroll;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   570
    var wsAnnot = opts.wsAnnot;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   571
    var stageView = opts.stageView;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   572
    var channel = opts.channel;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   573
    var serverUrl = opts.serverUrl;
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   574
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   575
    var eventCode = opts.eventCode;
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   576
    var eventCodeSessionDay2 = opts.eventCodeSessionDay2;
166
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
   577
    var eventCodeSessionDay1 = opts.eventCodeSessionDay1;
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   578
    var logger = opts.logger;
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   579
166
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
   580
    Utils.getAnnotCategories(opts.urlCategories + eventCode, this.annotCategories);
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   581
    Utils.getAnnotCategories(opts.urlCategories + eventCodeSessionDay2, this.annotCategoriesDay2);
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   582
    Utils.getAnnotCategories(opts.urlCategories + eventCodeSessionDay1, this.annotCategoriesDay1);
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   583
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   584
    stageView.registerComponent(this);
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   585
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   586
    var currentDay = new AnnotsTimeLine.AnnotsTimeLine({
166
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
   587
        stageView : stageView,
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   588
        logger: logger,
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   589
        ws: wsAnnot,
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   590
        xInit: 0,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   591
        yInit: 0,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   592
        width: 1024 - 200 - 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   593
        height: 768-200,
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   594
        timeBegin: this.timeBegin,
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
   595
        timeEnd: this.timeEnd,
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   596
        intervalWidth: 6,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   597
        intervalHeight: 10,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   598
        maxCellHeight: 70,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   599
        radius: 200,
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   600
        eventCode: eventCode,
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   601
        channel: channel,
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   602
        serverUrl: serverUrl,
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   603
        annotCategories: this.annotCategories
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   604
    });
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   605
166
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
   606
    //Archive day 2
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   607
    var timeLineDay2 = new AnnotsTimeLine.AnnotsTimeLine({
166
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
   608
        stageView : stageView,
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   609
        xInit: 0,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   610
        yInit: 0,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   611
        width: 1024 - 200 - 200,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   612
        height: 768-200,
161
0b01cbd8ed9e update annotvizview for 'atelier 3 jour 2'
rougeronj
parents: 153
diff changeset
   613
        timeBegin: Date.parse('2015-04-16T14:00:00+02:00'),
0b01cbd8ed9e update annotvizview for 'atelier 3 jour 2'
rougeronj
parents: 153
diff changeset
   614
        timeEnd: Date.parse('2015-04-16T21:00:00+02:00'),
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   615
        circleX: currentDay.circleX,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   616
        circleY: currentDay.circleY,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   617
        intervalWidth: (currentDay.radius*2/3)* currentDay.intervalWidth / currentDay.radius,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   618
        intervalHeight: (currentDay.intervalHeight * (currentDay.radius - currentDay.radius*2/3))/ currentDay.maxCellHeight,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   619
        maxCellHeight: (currentDay.radius - currentDay.radius*2/3)/2,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   620
        radius: currentDay.radius*2/3,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   621
        annotCategories: this.annotCategoriesDay2,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   622
        eventCode: eventCodeSessionDay2,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   623
        channel: channel,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   624
        serverUrl: serverUrl,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   625
        showClockGraphics:false,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   626
        archive: true
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   627
    });
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   628
166
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
   629
    //Archive day 1
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   630
    var timeLineDay1 = new AnnotsTimeLine.AnnotsTimeLine({
166
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
   631
        stageView : stageView,
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   632
        xInit: 0,
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   633
        yInit: 0,
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   634
        width: 1024 - 200 - 200,
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   635
        height: 768-200,
161
0b01cbd8ed9e update annotvizview for 'atelier 3 jour 2'
rougeronj
parents: 153
diff changeset
   636
        timeBegin: Date.parse('2015-04-16T14:00:00+02:00'),
0b01cbd8ed9e update annotvizview for 'atelier 3 jour 2'
rougeronj
parents: 153
diff changeset
   637
        timeEnd: Date.parse('2015-04-16T21:00:00+02:00'),
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   638
        circleX: currentDay.circleX,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   639
        circleY: currentDay.circleY,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   640
        intervalWidth: (currentDay.radius*2/3)* currentDay.intervalWidth / currentDay.radius,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   641
        intervalHeight: (currentDay.intervalHeight * (currentDay.radius - currentDay.radius/3))/ currentDay.maxCellHeight,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   642
        maxCellHeight: (currentDay.radius*2/3 - currentDay.radius/3)/4,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   643
        radius: currentDay.radius/3,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   644
        annotCategories: this.annotCategoriesDay1,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   645
        eventCode: eventCodeSessionDay1,
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   646
        channel: channel,
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   647
        serverUrl: serverUrl,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   648
        showClockGraphics:false,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   649
        archive: true,
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   650
    });
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   651
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   652
    var currentTimeText = new PIXI.Text('-- : -- : --', { font: '18pt Gothic Standard', fill: '#646464' });
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   653
    currentTimeText.x = timeLineDay2.circleX - currentTimeText.width/2;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   654
    currentTimeText.y = timeLineDay2.circleY - currentTimeText.height/2;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   655
    this.container.addChild(currentTimeText);
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   656
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   657
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   658
    var doubleRollH = new DoubleRoll.DoubleRoll({
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   659
        stageView : stageView,
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   660
        logger: logger,
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   661
        ws: wsPianoroll,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   662
        yInit: (this.height - 200),
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   663
        sceneHeight: 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   664
        pianorolls : [
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   665
            {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   666
                height: 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   667
                timeWidth: 10,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   668
                lineInterval: 5000,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   669
                noteHeight: 10
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   670
            },
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   671
        ]
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   672
    });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   673
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   674
    var doubleRollV = new DoubleRoll.DoubleRoll({
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   675
        stageView : stageView,
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   676
        logger: logger,
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   677
        ws: wsPianoroll,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   678
        orientation: 'vertical',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   679
        sceneHeight: 768-200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   680
        pianorolls : [
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   681
            {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   682
                height: 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   683
                timeWidth: 60,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   684
                lineInterval: 5000,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   685
                noteHeight: 5,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   686
            },
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   687
        ]
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   688
    });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   689
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   690
    var annotsRoll = new AnnotsRoll.AnnotsRoll({
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   691
        stageView : stageView,
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   692
        logger: logger,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   693
        ws: wsAnnot,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   694
        parentContainer: doubleRollV.stage,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   695
        xInit: 1024 - 200 - 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   696
        yInit: 768-200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   697
        width: 200 + 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   698
        height: 768-200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   699
        widthRoll: 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   700
        framerate: doubleRollV.framerate,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   701
        pixelsPerSecond: Math.floor(1024 / 60),
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   702
        annotColors: this.annotCategories
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   703
    });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   704
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   705
    var limiters = new PIXI.Graphics()
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   706
        .lineStyle(1, 0x646464)
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   707
        .moveTo(annotsRoll.container.x, annotsRoll.container.y)
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   708
        .lineTo(annotsRoll.container.x, annotsRoll.container.y - annotsRoll.height)
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   709
        .moveTo(annotsRoll.container.x + annotsRoll.widthRoll, annotsRoll.container.y)
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   710
        .lineTo(annotsRoll.container.x + annotsRoll.widthRoll, annotsRoll.container.y - annotsRoll.height)
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   711
        .moveTo(0, this.height - 200)
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   712
        .lineTo(this.width, this.height - 200)
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   713
        .drawRect(0, 0, this.width -1, this.height -1)
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   714
        .beginFill(0xECECEC)
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   715
        .drawRect(1024 - 200, 0, 200, 768-200)
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   716
        .endFill();
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   717
    this.container.addChild(limiters);
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   718
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   719
    this.init = function(){
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   720
    };
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   721
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   722
    this.updateTime = function(){
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   723
        currentTimeText.setText(Utils.formatTime(Date.now()));
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   724
    };
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   725
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   726
    var refreshTimeInterval;
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   727
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   728
    this.start = function() {
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   729
        refreshTimeInterval = setInterval(function() {_this.updateTime();}, 1000);
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   730
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   731
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   732
    this.refresh = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   733
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   734
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   735
    this.stop = function(){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   736
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   737
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   738
    return this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   739
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   740
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   741
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   742
module.exports = {
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   743
    AnnotsVizView: AnnotsVizView
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   744
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   745
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
   746
},{"./annotsroll.js":2,"./annotstimeline.js":3,"./doubleroll.js":5,"./utils.js":9,"lodash":"lodash","pixi":"pixi"}],5:[function(require,module,exports){
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   747
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   748
* scripts/doubleroll.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   749
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   750
* This is the starting point for your application.
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   751
* Take a look at http://browserify.org/ for more info
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   752
*/
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   753
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   754
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   755
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   756
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   757
var PIXI = require('pixi');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   758
var _ = require('lodash');
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   759
var PianoRoll = require('./pianoroll');
150
c8fe9606d967 add temporary timeCode on doubleroll and copy change to server
rougeronj
parents: 149
diff changeset
   760
var Utils = require('./utils.js');
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   761
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   762
var defaultConfig = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   763
    orientation: 'horizontal',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   764
    logger: undefined,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   765
    sceneWidth: 1024,
153
60bd2b36b9dc put showTime as an option and add it to static pianoroll template on server
rougeronj
parents: 150
diff changeset
   766
    showTimer: false,
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   767
    pianorolls : [
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   768
      {
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   769
        height: 384,
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   770
        timeWidth: 10,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   771
        lineInterval: 5000,
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   772
        noteHeight: undefined,
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   773
        range: {
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   774
    		bottom: 40,
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   775
    		top: 90,
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   776
        },
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   777
        dynamicRange: true,
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   778
      },
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   779
      {
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   780
        height: 384,
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   781
        timeWidth: 60,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   782
        lineInterval: 5000,
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   783
        noteHeight: undefined,
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   784
        range:{
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   785
    		bottom: 0,
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   786
    		top: 128,
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   787
        },
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   788
        dynamicRange: false,
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   789
      },
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   790
    ],
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   791
    framerate: 25,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   792
    offsetMusic: false,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   793
    sceneBgColor: 0xFFFFFF,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   794
    lineColor: 0x444444,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   795
    lineFillColor: 0xFFFF00,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   796
    noteColors: [0xB90000, 0x4BDD71, 0xAF931E, 0x1C28BA, 0x536991],
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   797
    noteHeight: undefined,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   798
    zeroShift: 0.9,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   799
    timeWidth: 60,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   800
    lineInterval: 5000,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   801
//    wsUri: undefined,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   802
//    eventCode: undefined
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   803
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   804
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   805
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   806
function DoubleRoll(options) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   807
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   808
    var _this = this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   809
    var opts = _(options).defaults(defaultConfig).value();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   810
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   811
    var orientation = opts.orientation;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   812
    var isHorizontal = (orientation !== 'vertical');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   813
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   814
    this.logger = opts.logger;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   815
    this.lineColor = opts.lineColor;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   816
    this.lineFillColor = opts.lineFillColor;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   817
    this.framerate = opts.framerate;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   818
    this.offsetMusic = opts.offsetMusic;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   819
    this.noteColors = opts.noteColors;
153
60bd2b36b9dc put showTime as an option and add it to static pianoroll template on server
rougeronj
parents: 150
diff changeset
   820
    this.showTimer = opts.showTimer;
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   821
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   822
    var noteHeight = opts.noteHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   823
    var sceneHeight = opts.sceneHeight || _(opts.pianorolls).reduce(function(s,p) { return s + p.height; }, 0);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   824
    var timeWidth = opts.timeWidth;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   825
    var lineInterval = opts.lineInterval;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   826
    var offsetMusic = opts.offsetMusic;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   827
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   828
    var sceneWidth = opts.sceneWidth;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   829
    var stageView = opts.stageView;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   830
153
60bd2b36b9dc put showTime as an option and add it to static pianoroll template on server
rougeronj
parents: 150
diff changeset
   831
    
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   832
    var zeroShift = opts.zeroShift;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   833
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   834
    var ws = opts.ws;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   835
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   836
    var colorsReg = {};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   837
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   838
    this.container = new PIXI.DisplayObjectContainer();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   839
    this.container.x = Math.floor(sceneWidth*zeroShift);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   840
    this.container.y = 0;
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   841
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   842
    stageView.registerComponent(this);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   843
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   844
    var pianorollList = [];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   845
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   846
    var pianorollOptions = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   847
        parentContainer: this.container,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   848
        orientation: orientation,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   849
        xInit: 0,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   850
        width: sceneWidth,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   851
        noteColors: this.noteColors,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   852
        colorsReg: colorsReg,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   853
        lineColor: this.lineColor,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   854
        lineInterval: lineInterval,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   855
        offsetMusic: offsetMusic,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   856
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   857
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   858
    var yInit = opts.yInit || 0;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   859
    var linesDown = true;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   860
    _(opts.pianorolls).forEach(function(prDef, i) {
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   861
        var prNoteHeight = noteHeight || prDef.noteHeight || prDef.height / (prDef.range.top - prDef.range.bottom + 1);
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   862
        var prTimeWidth = prDef.timeWidth || timeWidth;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   863
        pianorollList.push(new PianoRoll(_({
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   864
            yInit: yInit,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   865
            height: prDef.height,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   866
            linesDown: linesDown,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   867
            pixelsPerSecond: Math.floor(sceneWidth / prTimeWidth),
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   868
            noteHeight: prNoteHeight,
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   869
            lineInterval: prDef.lineInterval,
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   870
            range: prDef.range,
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
   871
            dynamicRange: prDef.dynamicRange,
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   872
        }).defaults(pianorollOptions).value()));
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   873
        yInit += prDef.height;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   874
        linesDown = !linesDown;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   875
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   876
        if(i<(opts.pianorolls.length-1)) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   877
            var lineGraphics = new PIXI.Graphics()
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   878
                .beginFill(_this.lineFillColor)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   879
                .lineStyle(1, _this.lineColor)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   880
                .moveTo(Math.floor(sceneWidth*zeroShift), yInit)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   881
                .lineTo(-sceneWidth - Math.floor(sceneWidth*zeroShift), yInit)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   882
                .endFill();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   883
            _this.container.addChild(lineGraphics);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   884
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   885
    });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   886
153
60bd2b36b9dc put showTime as an option and add it to static pianoroll template on server
rougeronj
parents: 150
diff changeset
   887
    if (this.showTimer){
60bd2b36b9dc put showTime as an option and add it to static pianoroll template on server
rougeronj
parents: 150
diff changeset
   888
	    var currentTimeText = new PIXI.Text('-- : -- : --', { font: '40pt Arial', fill: '#646464' });
60bd2b36b9dc put showTime as an option and add it to static pianoroll template on server
rougeronj
parents: 150
diff changeset
   889
	    currentTimeText.x = -currentTimeText.width - 60; 
60bd2b36b9dc put showTime as an option and add it to static pianoroll template on server
rougeronj
parents: 150
diff changeset
   890
	    currentTimeText.y = sceneHeight - currentTimeText.height - 30;
60bd2b36b9dc put showTime as an option and add it to static pianoroll template on server
rougeronj
parents: 150
diff changeset
   891
	    this.container.addChild(currentTimeText);
60bd2b36b9dc put showTime as an option and add it to static pianoroll template on server
rougeronj
parents: 150
diff changeset
   892
	}
150
c8fe9606d967 add temporary timeCode on doubleroll and copy change to server
rougeronj
parents: 149
diff changeset
   893
    
c8fe9606d967 add temporary timeCode on doubleroll and copy change to server
rougeronj
parents: 149
diff changeset
   894
    
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   895
    if(!isHorizontal) {
150
c8fe9606d967 add temporary timeCode on doubleroll and copy change to server
rougeronj
parents: 149
diff changeset
   896
        this.container.rotation = Math.PI/2; 
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   897
        this.container.y = sceneHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   898
        this.container.x = sceneWidth;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   899
    }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   900
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   901
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   902
    this.init = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   903
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   904
    	ws.message(function(data) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   905
            _this.addNotes(data);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   906
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   907
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   908
    };
150
c8fe9606d967 add temporary timeCode on doubleroll and copy change to server
rougeronj
parents: 149
diff changeset
   909
    
c8fe9606d967 add temporary timeCode on doubleroll and copy change to server
rougeronj
parents: 149
diff changeset
   910
    this.updateTime = function(){
c8fe9606d967 add temporary timeCode on doubleroll and copy change to server
rougeronj
parents: 149
diff changeset
   911
        currentTimeText.setText(Utils.formatTime(Date.now()));
c8fe9606d967 add temporary timeCode on doubleroll and copy change to server
rougeronj
parents: 149
diff changeset
   912
    };
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   913
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   914
    this.addNotes = function(data) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   915
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   916
        pianorollList.forEach(function(c) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   917
            c.addNoteRaw(data);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   918
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   919
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   920
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   921
    this.refresh = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   922
        pianorollList.forEach(function(c) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   923
            c.move();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   924
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   925
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   926
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   927
    // Init page and intervals
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   928
    var startTs;
150
c8fe9606d967 add temporary timeCode on doubleroll and copy change to server
rougeronj
parents: 149
diff changeset
   929
    var refreshTimeInterval;
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   930
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   931
    this.start = function() {
153
60bd2b36b9dc put showTime as an option and add it to static pianoroll template on server
rougeronj
parents: 150
diff changeset
   932
    	if (this.showTimer){
60bd2b36b9dc put showTime as an option and add it to static pianoroll template on server
rougeronj
parents: 150
diff changeset
   933
    		refreshTimeInterval = setInterval(function() {_this.updateTime();}, 1000);
60bd2b36b9dc put showTime as an option and add it to static pianoroll template on server
rougeronj
parents: 150
diff changeset
   934
    	}
150
c8fe9606d967 add temporary timeCode on doubleroll and copy change to server
rougeronj
parents: 149
diff changeset
   935
    	
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   936
        startTs = Date.now();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   937
        pianorollList.forEach(function(c) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   938
            c.start();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   939
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   940
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   941
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   942
    this.stop = function() {
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
   943
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   944
        pianorollList.forEach(function(c) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   945
            c.stop();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   946
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   947
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   948
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   949
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   950
    this.log = function(m) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   951
        if(this.logger) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   952
            this.logger.log(m);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   953
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   954
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   955
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   956
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   957
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   958
    return this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   959
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   960
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   961
module.exports = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   962
    DoubleRoll: DoubleRoll
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   963
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   964
150
c8fe9606d967 add temporary timeCode on doubleroll and copy change to server
rougeronj
parents: 149
diff changeset
   965
},{"./pianoroll":7,"./utils.js":9,"lodash":"lodash","pixi":"pixi"}],6:[function(require,module,exports){
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   966
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   967
* js/wswrapper.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   968
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   969
* simple logger service
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   970
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   971
*/
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   972
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   973
/* global document: false */
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   974
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   975
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   976
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   977
function HtmlLogger(doLog, container) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   978
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   979
    var logContainer = container;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   980
    if(typeof(container) === 'string') {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   981
        logContainer = document.getElementById(container);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   982
    }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   983
    if(!doLog) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   984
        document.body.removeChild(logContainer);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   985
        logContainer = undefined;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   986
    }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   987
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   988
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   989
    this.log = function(msg) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   990
        if(doLog && logContainer) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   991
            logContainer.innerHTML += msg + '\n';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   992
            logContainer.scrollTop = logContainer.scrollHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   993
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   994
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   995
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   996
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   997
function ConsoleLogger(doLog) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   998
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   999
    this.log = function(msg) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1000
        if(doLog) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1001
            console.log(msg);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1002
        }
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1003
    };
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1004
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1005
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1006
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1007
module.exports = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1008
    HtmlLogger: HtmlLogger,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1009
    ConsoleLogger: ConsoleLogger
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1010
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1011
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1012
},{}],7:[function(require,module,exports){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1013
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1014
* js/pianoroll.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1015
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1016
* pianoroll basic component
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1017
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1018
*/
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1019
166
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1020
//TODO: add delay to adjust the "zero". this could should be given as an option
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1021
//or if explicitely null automatically adjusted from the mean of difference
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1022
//between the note timestamp and the current timestamp.
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1023
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1024
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1025
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1026
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1027
var PIXI = require('pixi');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1028
var randomColor = require('randomColor');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1029
var _ = require('lodash');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1030
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1031
var NTP_EPOCH_DELTA = 2208988800; //c.f. RFC 868
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1032
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1033
function PianoRoll(options) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1034
    var _this = this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1035
    this.container = new PIXI.DisplayObjectContainer();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1036
    this.container.x = options.xInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1037
    this.container.y = options.yInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1038
    options.parentContainer.addChild(this.container);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1039
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1040
    var orientation = options.orientation;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1041
    var isHorizontal = (orientation !== 'vertical');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1042
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1043
    this.linesDown = options.linesDown;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1044
    this.height = options.height;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1045
    this.pixelsPerSecond = options.pixelsPerSecond;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1046
    this.width = options.width;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1047
    this.noteColors = options.noteColors;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1048
    this.colorsReg = options.colorsReg || {};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1049
    this.lineColor = options.lineColor;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1050
    this.lineInterval = options.lineInterval;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1051
    this.offsetMusic = options.offsetMusic || false;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1052
    this.noteHeight = options.noteHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1053
    this.noteDict = {};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1054
    this.startTs = options.startTs || Date.now();
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1055
    this.dynamicRange = options.dynamicRange;
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1056
    this.initRange = options.range;
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1057
    this.range = options.range;
166
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1058
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1059
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1060
    var started = false;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1061
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1062
    var isHidden = function(child) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1063
        // TODO: the origin point is an approximation. Should refine this
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1064
        var globalPos = child.toGlobal(new PIXI.Point(0,0));
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1065
        return ((globalPos.x + child.width) < 0) || ((globalPos.y + child.height) < 0) ;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1066
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1067
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1068
    //TODO: I do not like the "regColor" object. This should not be global, but local
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1069
    this.getColor = function(canal) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1070
        var color = this.colorsReg[canal];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1071
        if(typeof(color) === 'undefined') {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1072
            var colorsRegSize = Object.keys(this.colorsReg).length;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1073
            if(colorsRegSize < this.noteColors.length) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1074
                color = this.colorsReg[canal] = this.noteColors[colorsRegSize];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1075
            }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1076
            else {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1077
                color = this.colorsReg[canal] = parseInt(randomColor({ luminosity: 'light', hue: 'random', format:'hex'}).replace(/^#/, ''), 16);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1078
            }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1079
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1080
        return color;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1081
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1082
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1083
    this.getNoteRect = function(note, x, y, color, alpha, width, height) {
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1084
        var graphics = new PIXI.Graphics();
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1085
        graphics.note = note;
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1086
        graphics.beginFill(color, alpha);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1087
        graphics.drawRect(0, 0, width, height);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1088
        graphics.endFill();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1089
        graphics.x = x;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1090
        graphics.y = y;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1091
        graphics.width = width;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1092
        graphics.height = height;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1093
        return graphics;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1094
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1095
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1096
    this.addNoteRaw = function(data) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1097
        var note = data.content[3];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1098
        var velocity = data.content[4];
166
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1099
        //var ts = (data.content[0] - NTP_EPOCH_DELTA)*1000;
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1100
        var ts = Date.parse(data.ts_server);
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1101
        console.log(ts, data.content[0]);
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1102
        var channel = data.content[2];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1103
        var sessionTs = data.content[1];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1104
166
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1105
        if(velocity !== 0 && typeof(this.noteDict[channel]) !== 'undefined' && typeof(this.noteDict[channel][note] !== 'undefined')) {
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1106
            this.addNote(note, ts, sessionTs, 0, channel, 0);
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1107
        }
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1108
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1109
        this.addNote(note, ts, sessionTs, velocity, channel, 0);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1110
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1111
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1112
    this.addNote = function(note, startTime, sessionTs, velocity, channel, duration) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1113
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1114
        var ts = startTime;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1115
        if(this.offsetMusic) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1116
            ts = this.startTs + sessionTs;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1117
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1118
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1119
        var noteDuration = duration;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1120
        var noteVelocity = velocity;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1121
        var graphics;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1122
        if(!duration) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1123
            if(typeof this.noteDict[channel]==='undefined'){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1124
                this.noteDict[channel] = {};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1125
            }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1126
            if(velocity===0) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1127
                if(typeof this.noteDict[channel][note] !== 'undefined') {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1128
                    var noteDef = this.noteDict[channel][note];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1129
                    delete this.noteDict[channel][note];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1130
                    noteDuration = sessionTs - noteDef.sessionTs;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1131
                    graphics = noteDef.graphics;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1132
                    noteVelocity = noteDef.velocity;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1133
                    ts = noteDef.ts;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1134
                }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1135
            }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1136
            else {
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1137
                noteDuration = Math.abs(Date.now() - ts);
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1138
                this.noteDict[channel][note] = { ts: ts, velocity: velocity, sessionTs: sessionTs};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1139
            }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1140
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1141
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1142
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1143
        if(!this.offsetMusic || velocity===0) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1144
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1145
            var width = noteDuration * this.pixelsPerSecond / 1000;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1146
            if(!graphics) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1147
                var x = (ts-this.startTs) * this.pixelsPerSecond / 1000;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1148
                if((x+width) <  (Math.abs(this.container.x) - this.width)) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1149
                    // not visible. do nothing
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1150
                    return;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1151
                }
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1152
            	if (this.dynamicRange && (this.range.bottom > note || note > this.range.top)){
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1153
            		var newScale = {};
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1154
            		newScale['bottom'] = Math.min(note, this.range.bottom);
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1155
            		newScale['top'] = Math.max(note, this.range.top);
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1156
            		this.rescaleScene(newScale);
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1157
            	}
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1158
            	var y = Math.floor(((this.range.top-this.range.bottom)-(note-this.range.bottom)+0.5) * (this.noteHeight) - (this.noteHeight/2));
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1159
                var color = this.getColor(channel);
166
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1160
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1161
                var alpha = (noteVelocity / 128);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1162
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1163
                graphics = this.getNoteRect(note, x, y, color, alpha, width, this.noteHeight);
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1164
                this.container.addChild(graphics);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1165
            }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1166
            else {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1167
                graphics.width = width;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1168
            }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1169
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1170
            if(!duration && velocity) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1171
                this.noteDict[channel][note].graphics = graphics;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1172
            }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1173
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1174
    };
166
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1175
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1176
    //rescale scene in case a note out of range is added or a note out of the range is removed
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1177
    this.rescaleScene = function(newScale){
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1178
    	var _this = this;
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1179
    	var childrenToUpdate = [];
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1180
    	var top = this.initRange.top;
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1181
    	var bottom = this.initRange.bottom;
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1182
    	_(_this.container.children).forEach(function(child) {
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1183
    		if (typeof(child) !== 'undefined' && child.note && !isHidden(child)){
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1184
    			top = Math.max(child.note, top);
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1185
    			bottom = Math.min(child.note, bottom);
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1186
    			return childrenToUpdate.push(child);
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1187
    		}
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1188
        });
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1189
    	if (newScale){
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1190
    		this.range = newScale;
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1191
    	}else{
166
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1192
    		this.range.top = top;
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1193
    		this.range.bottom = bottom;
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1194
    	}
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1195
    	this.noteHeight = this.height / (this.range.top - this.range.bottom + 1);
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1196
    	childrenToUpdate.forEach(function(child) {
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1197
			child.y = Math.floor(((_this.range.top-_this.range.bottom)-(child.note-_this.range.bottom)+0.5) * (_this.noteHeight) - (_this.noteHeight/2));
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1198
			child.height = _this.noteHeight;
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1199
        });
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1200
    };
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1201
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1202
    this.addLine = function(ts){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1203
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1204
        if(typeof(ts) === 'undefined') {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1205
            ts = new Date();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1206
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1207
        var x = -this.container.x;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1208
        var y = this.linesDown ? this.height - 20 : 0;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1209
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1210
        var graphics = new PIXI.Graphics()
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1211
            .beginFill(0xFFFF00)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1212
            .lineStyle(1, this.lineColor)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1213
            .moveTo(0, 0)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1214
            .lineTo(0, 20)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1215
            .endFill();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1216
        graphics.x = x;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1217
        graphics.y = y;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1218
        this.container.addChild(graphics);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1219
        // Add text
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1220
        //var totalSec = lineNb * this.lineInterval / 1000;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1221
        var hours = ts.getHours();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1222
        var minutes =ts.getMinutes();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1223
        var seconds = ts.getSeconds();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1224
        var timeStr = (hours < 10 ? '0' + hours : hours) + ':' + (minutes < 10 ? '0' + minutes : minutes) + ':' + (seconds  < 10 ? '0' + seconds : seconds);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1225
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1226
        var fontObj = { font: '10pt Arial', fill: '#444444' };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1227
        var t = new PIXI.Text(timeStr, fontObj);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1228
        if(isHorizontal) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1229
            t.x = x + 2;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1230
            t.y = this.linesDown ? this.height - 15 : 2;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1231
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1232
        else {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1233
            t.rotation = -Math.PI/2;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1234
            t.x = x ;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1235
            t.y = this.linesDown ? this.height - 2 : t.width + 2;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1236
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1237
        this.container.addChild(t);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1238
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1239
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1240
    this.moveTo = function(diffTime){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1241
        var oldX = this.container.x;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1242
        this.container.x = Math.floor(diffTime*this.pixelsPerSecond);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1243
        var deltaX = Math.abs(oldX-this.container.x);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1244
        _.forOwn(this.noteDict, function(channelDict) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1245
            _.forOwn(channelDict, function(noteDef) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1246
                if(noteDef.graphics) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1247
                    noteDef.graphics.width = noteDef.graphics.width + deltaX;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1248
                }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1249
            });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1250
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1251
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1252
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1253
    this.move = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1254
        var diff = (this.startTs - Date.now())/1000;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1255
        this.moveTo(diff);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1256
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1257
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1258
    this.removePassedObjets = function(){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1259
        var childrenToRemove = [];
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1260
        var rescale = false;
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1261
        _(_this.container.children).forEach(function(child) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1262
            return typeof(child) === 'undefined' ||
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1263
                (isHidden(child) && childrenToRemove.push(child));
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1264
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1265
        childrenToRemove.forEach(function(child) {
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1266
        	if (_this.dynamicRange && (_this.range.bottom === child.note || child.note === _this.range.top)){
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1267
                rescale = true;
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1268
            }
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1269
            _this.container.removeChild(child);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1270
        });
148
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1271
        //externalize this test to avoid repeated call to the function rescaleScene in the previous loop
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1272
        if (rescale){
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1273
            _this.rescaleScene();
21634b2d7609 'gulp server' to copy the js to the server
rougeronj
parents: 142
diff changeset
  1274
        }
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1275
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1276
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1277
    this.start = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1278
        if(!started) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1279
            this.startTs = Date.now();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1280
            this.addLine();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1281
            started = true;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1282
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1283
        this.verticalLinesInterval = setInterval(function() { _this.addLine(); }, this.lineInterval);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1284
        this.cleanInterval = setInterval(function () { _this.removePassedObjets(); }, 1000 * this.width / this.pixelsPerSecond );
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1285
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1286
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1287
    this.stop = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1288
        clearInterval(this.verticalLinesInterval);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1289
        clearInterval(this.cleanInterval);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1290
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1291
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1292
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1293
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1294
module.exports = PianoRoll;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1295
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1296
},{"lodash":"lodash","pixi":"pixi","randomColor":"randomColor"}],8:[function(require,module,exports){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1297
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1298
* scripts/stageview.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1299
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1300
* This is the starting point for your application.
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1301
* Take a look at http://browserify.org/ for more info
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1302
*/
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1303
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1304
/* global document: false */
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1305
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1306
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1307
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1308
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1309
var PIXI = require('pixi');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1310
var _ = require('lodash');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1311
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1312
var defaultConfig = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1313
    externalRefresh: false,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1314
    logger: undefined,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1315
    sceneWidth: 1024,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1316
    sceneHeight: 768,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1317
    framerate: 25,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1318
    sceneBgColor: 0xFFFFFF,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1319
    canvasContainer: 'canvasContainer',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1320
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1321
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1322
function StageView(options) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1323
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1324
    var _this = this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1325
    var opts = _(options).defaults(defaultConfig).value();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1326
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1327
    var externalRefresh = opts.externalRefresh;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1328
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1329
    this.logger = opts.logger;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1330
    this.framerate = opts.framerate;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1331
    var sceneBgColor = opts.sceneBgColor;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1332
    var sceneWidth = opts.sceneWidth;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1333
    var sceneHeight = opts.sceneHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1334
    var canvasContainer = opts.canvasContainer;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1335
    var timeContainer = [];
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1336
    var components = [];
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1337
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1338
    //create an new instance of a pixi stage
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1339
    this.stage = new PIXI.Stage(sceneBgColor);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1340
    //create a renderer instance.
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1341
    var renderer = PIXI.autoDetectRenderer(sceneWidth, sceneHeight);
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1342
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1343
    this.init = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1344
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1345
        if(typeof(canvasContainer) === 'string') {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1346
            canvasContainer = document.getElementById(canvasContainer);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1347
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1348
        if(typeof(timeContainer) === 'string') {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1349
            timeContainer = document.getElementById(timeContainer);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1350
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1351
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1352
        canvasContainer.appendChild(renderer.view);
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1353
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1354
        components.forEach(function(c){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1355
    		c.init();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1356
    	});
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1357
    };
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1358
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1359
    this.registerTimeContainer = function(container) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1360
    	timeContainer.push(container);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1361
    };
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1362
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1363
    this.registerComponent = function(component) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1364
    	components.push(component);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1365
    	this.stage.addChild(component.container);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1366
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1367
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1368
    this.refresh = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1369
    	components.forEach(function(c){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1370
    		c.refresh();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1371
    	});
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1372
        renderer.render(this.stage);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1373
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1374
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1375
    // Init page and intervals
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1376
    var refreshInterval;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1377
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1378
    this.start = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1379
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1380
        if(!externalRefresh) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1381
            refreshInterval = setInterval(function() {_this.refresh();}, 1000/this.framerate);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1382
        }
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1383
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1384
        components.forEach(function(c){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1385
    		c.start();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1386
    	});
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1387
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1388
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1389
    this.stop = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1390
        if(!externalRefresh) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1391
            clearInterval(refreshInterval);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1392
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1393
        
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1394
        components.forEach(function(c){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1395
    		c.stop();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1396
    	});
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1397
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1398
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1399
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1400
    this.log = function(m) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1401
        if(this.logger) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1402
            this.logger.log(m);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1403
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1404
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1405
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1406
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1407
    return this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1408
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1409
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1410
module.exports = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1411
    StageView: StageView
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1412
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1413
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1414
},{"lodash":"lodash","pixi":"pixi"}],9:[function(require,module,exports){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1415
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1416
* js/utils.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1417
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1418
* basic tools
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1419
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1420
*/
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1421
/*jshint bitwise: false*/
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1422
/*jshint camelcase: false */
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1423
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1424
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1425
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1426
var PIXI = require('pixi');
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1427
var _ = require('lodash');
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1428
var moment = require('moment');
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1429
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1430
function formatTime (ts) {
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1431
    return moment(ts).format('HH:mm:ss');
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1432
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1433
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
  1434
function colorToHex(c) {
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1435
    var m = /rgba?\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)/.exec(c);
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1436
    return m ? '#' + (1 << 24 | m[1] << 16 | m[2] << 8 | m[3]).toString(16).substr(1) : c;
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
  1437
}
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
  1438
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1439
function getAnnotCategories(urlCategories, annotCategories) {
119
e6605fecb175 move colorToHex to utils
ymh <ymh.work@gmail.com>
parents: 110
diff changeset
  1440
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1441
    var jsonLoader = new PIXI.JsonLoader(urlCategories, true);
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1442
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1443
    jsonLoader.on('loaded', function(res) {
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1444
        var data = res.target.json;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1445
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1446
        while(annotCategories.length > 0) {
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1447
            annotCategories.pop();
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1448
        }
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1449
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1450
        data.sessions.forEach(function(session) {
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1451
            var annotCat = {
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1452
                ts: session.start_ts === null ? new Date(0) : Date.parse(session.start_ts),
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1453
                colors: {}
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1454
            };
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1455
            var categoriesJson = session.categories_json;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1456
            annotCat.order = categoriesJson.order;
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1457
            if (typeof(annotCat.order['default']) === 'undefined'){
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1458
                annotCat.order.push('default');
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1459
            }
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1460
            var catList = _.clone(categoriesJson.categories);
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1461
            while(catList.length > 0) {
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1462
                var cat = catList.pop();
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1463
                if(cat.code) {
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1464
                    annotCat.colors[cat.code] = colorToHex(cat.color);
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1465
                }
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1466
                if(cat.subcategories) {
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1467
                    catList = catList.concat(cat.subcategories);
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1468
                }
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1469
            }
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1470
            categoriesJson.categories.forEach(function(cat) {
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1471
                if(cat.code) {
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1472
                    annotCat.colors[cat.code] = colorToHex(cat.color);
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1473
                }
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1474
            });
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1475
            annotCat.defaultColor = categoriesJson.defaultColor || '#536991';
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1476
            annotCategories.push(annotCat);
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1477
        });
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1478
    });
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1479
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1480
    jsonLoader.load();
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1481
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1482
}
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1483
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1484
module.exports = {
142
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1485
    formatTime: formatTime,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1486
    getAnnotCategories: getAnnotCategories,
e424eed32f72 Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents: 130
diff changeset
  1487
    colorToHex: colorToHex
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1488
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1489
130
0a2b4991d48c publish new version to server
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
  1490
},{"lodash":"lodash","moment":"moment","pixi":"pixi"}],10:[function(require,module,exports){
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1491
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1492
* js/wswrapper.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1493
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1494
* simple webservice wrapper to register callbacks on onmessage
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1495
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1496
*/
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1497
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1498
/* global WebSocket: false */
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1499
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1500
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1501
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1502
function WsWrapper(wsurl, logger) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1503
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1504
    var url = wsurl;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1505
    var sock = new WebSocket(url);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1506
    var loggerObj = logger;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1507
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1508
    var log = function(msg) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1509
        if(loggerObj) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1510
            loggerObj.log(msg);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1511
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1512
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1513
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1514
    var handlers = [];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1515
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1516
    sock.onopen = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1517
        log('Connected to ' + url);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1518
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1519
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1520
    sock.onclose = function(e) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1521
        log('Connection closed (wasClean = ' + e.wasClean + ', code = ' + e.code + ', reason = \'' + e.reason + '\')');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1522
        sock = null;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1523
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1524
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1525
    sock.onmessage = function(e) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1526
        log('received ' + e.data);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1527
        var data = JSON.parse(e.data);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1528
        handlers.forEach(function(handler) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1529
            handler(data);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1530
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1531
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1532
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1533
    this.message = function(handler) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1534
        if(handler) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1535
            handlers.push(handler);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1536
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1537
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1538
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1539
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1540
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1541
module.exports = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1542
    WsWrapper: WsWrapper
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1543
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1544
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1545
},{}]},{},[1])(1)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1546
});
166
fa9e24e46968 pianoroll use ts_server
ymh <ymh.work@gmail.com>
parents: 161
diff changeset
  1547
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","./app/js/main.js","/Users/ymh/dev/projects/mons/dev/client/annotviz/app/js/annotsroll.js","/Users/ymh/dev/projects/mons/dev/client/annotviz/app/js/annotstimeline.js","/Users/ymh/dev/projects/mons/dev/client/annotviz/app/js/annotsvizview.js","/Users/ymh/dev/projects/mons/dev/client/annotviz/app/js/doubleroll.js","/Users/ymh/dev/projects/mons/dev/client/annotviz/app/js/logger.js","/Users/ymh/dev/projects/mons/dev/client/annotviz/app/js/pianoroll.js","/Users/ymh/dev/projects/mons/dev/client/annotviz/app/js/stageview.js","/Users/ymh/dev/projects/mons/dev/client/annotviz/app/js/utils.js","/Users/ymh/dev/projects/mons/dev/client/annotviz/app/js/wswrapper.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/NA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5QA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1RA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/**\n * scripts/main.js\n *\n * This is the starting point for your application.\n * Take a look at http://browserify.org/ for more info\n */\n\n'use strict';\n\nvar doubleroll = require('./doubleroll');\nvar annotsroll = require('./annotsroll');\nvar annotstimeline = require('./annotstimeline');\nvar annotsvizview = require('./annotsvizview');\nvar stageview = require('./stageview');\nvar wswrapper = require('./wswrapper');\nvar logger = require('./logger');\nvar utils = require('./utils');\n\nvar _ = require('lodash');\n\nmodule.exports = _({})\n    .extend(doubleroll)\n    .extend(annotsroll)\n    .extend(annotstimeline)\n    .extend(annotsvizview)\n    .extend(stageview)\n    .extend(wswrapper)\n    .extend(logger)\n    .extend(utils)\n    .value();\n","/**\n* js/annotsRoll.js\n*\n* annotsRoll basic component\n*\n*/\n\n'use strict';\n\nvar PIXI = require('pixi');\nvar _ = require('lodash');\n\nvar DEFAULT_ANNOT_COLOR = '#bababa';\n\nvar defaultAnnotStyles = {\n    'label': { font: '16pt Arial Bold', fill: '#65A954', wordWrap: true},\n    'text' : { font: '12pt Arial Regular', fill: '#444444', wordWrap: true},\n    'user' : { font: '14pt Arial regular', fill: '#666666' },\n};\n\nvar defaultOptions = {\n    externalRefresh: false,\n    defaultColor: DEFAULT_ANNOT_COLOR,\n    annotStyles: defaultAnnotStyles,\n    ignoreAnnots:false\n};\n\nfunction AnnotsRoll(options) {\n\n//parentContainer, xInit, yInit, width, height, widthRoll, pixelsPerSecond, annotColors\n    var _this = this;\n    var opts = _(options).defaults(defaultOptions).value();\n\n\n    this.container = new PIXI.DisplayObjectContainer();\n    this.container.x = opts.xInit;\n    this.container.y = opts.yInit;\n    this.container.width = opts.width;\n\n    this.height = opts.height;\n    this.width = opts.width;\n    this.widthRoll = opts.widthRoll;\n    this.pixelsPerSecond = opts.pixelsPerSecond;\n    this.annotColors = opts.annotColors;\n    this.startTs = opts.startTs || Date.now();\n    this.ignoreAnnots = opts.ignoreAnnots;\n\n    var yInit = opts.yInit;\n    var annotStyles = _(opts.annotStyles).defaults(defaultAnnotStyles).value();\n    var marginX = 15;\n    for(var style in annotStyles) {\n    \tif (annotStyles[style].wordWrap === true){\n    \t\tannotStyles[style].wordWrapWidth = this.widthRoll - marginX;\n    \t}\n    }\n    var started = false;\n    var ws = opts.ws;\n    var externalRefresh = opts.externalRefresh;\n    var stageView = opts.stageView;\n    var waitInterval;\n    var wait = 0;\n\n    stageView.registerComponent(this);\n\n    var isHidden = function(child) {\n        // TODO: the origin point is an approximation. Should refine this\n        var globalPos = child.toGlobal(new PIXI.Point(0,0));\n        return ((globalPos.x + child.width) < 0) || ((globalPos.y + child.height) < 0) ;\n    };\n\n    this.addAnnots = function(data) {\n\n        //var title = data.content.category.label;\n        //var user = data.content.user;\n        //Test cat and color\n        //var colorAnnot = 0x65A954;\n        var category = data.content.category.label,\n            text     = data.content.text,\n            user     = data.content.user,\n            ts       = Date.parse(data.ts),\n            color    = data.content.color || this.getColor(ts, data.content.category.code);\n\n        this.addAnnot(category, text, user, color, ts);\n    };\n\n    this.getColor = function(ts, code) {\n        var colorsDef;\n        _(this.annotColors).eachRight(function(cdef) {\n            if(cdef.ts < ts) {\n                colorsDef = cdef.colors;\n                return false;\n            }\n        });\n        var resColor;\n        if(colorsDef) {\n            resColor = colorsDef[code];\n        }\n        if(!resColor) {\n            resColor = colorsDef.defaultColor || DEFAULT_ANNOT_COLOR;\n        }\n        return resColor;\n    };\n\n    this.addAnnot = function(category, text, user, color, ts){\n\n        var x = 0;\n        var y = (ts-this.startTs) * this.pixelsPerSecond / 1000 + yInit;\n\n        var colorHex = parseInt(color.replace(/^#/, ''), 16);\n\n        if (wait === 0){\n\t        var graphics = new PIXI.Graphics()\n\t            .beginFill(colorHex)\n\t            .drawRect(x, y, 10, 3)\n\t            .endFill();\n\n\t        this.container.addChild(graphics);\n\n\t        var textHeight = 0;\n\t        var catLabel = new PIXI.Text(\n\t            category,\n\t            _(annotStyles.label).extend({fill: color}).value()\n\t        );\n\t        catLabel.x = x + marginX;\n\t        catLabel.y = y - 23;\n\t        this.container.addChild(catLabel);\n\t        textHeight += (catLabel.height - 23 + 2);\n\n\t        if(text) {\n\t            var catText = new PIXI.Text(text, annotStyles.text);\n\t            catText.x = x + marginX;\n\t            catText.y = y + textHeight;\n\t            this.container.addChild(catText);\n\t            textHeight += (catText.height + 2);\n\t        }\n\n\t        var catUser = new PIXI.Text(user, annotStyles.user);\n\t        catUser.x = x + marginX;\n\t        catUser.y = y + textHeight;\n\t        this.container.addChild(catUser);\n\t        textHeight += (catUser.height + 8);\n\n\t        if (this.ignoreAnnots === true){\n\t\t        wait = textHeight / this.pixelsPerSecond;\n\t\t        waitInterval = setInterval(function() {_this.refreshWait();}, 1000);\n\t        }\n        }\n\n        this.addAnnotLine(colorHex, y);\n    };\n\n    this.addAnnotLine = function(color, y) {\n        var x = this.widthRoll;\n\n\n        var graphics = new PIXI.Graphics()\n            .beginFill(color)\n            .drawRect(x, y, this.width - x, 3)\n            .endFill();\n\n        this.container.addChild(graphics);\n    };\n\n    this.moveTo = function(diffTime){\n    \tthis.container.y = Math.floor(diffTime*this.pixelsPerSecond);\n    };\n\n    this.move = this.refresh = function() {\n        var diff = (this.startTs - Date.now())/1000;\n        this.moveTo(diff);\n    };\n\n    this.refreshWait = function(){\n    \twait -= 1;\n    \tif (wait < 0){\n    \t\twait = 0;\n    \t\tclearInterval(waitInterval);\n    \t}\n    };\n\n    this.removePassedObjets = function(){\n        var childrenToRemove = [];\n        _(_this.container.children).forEach(function(child) {\n            return typeof(child) === 'undefined' ||\n                (isHidden(child) && childrenToRemove.push(child));\n        });\n        childrenToRemove.forEach(function(child) {\n            _this.container.removeChild(child);\n        });\n    };\n\n    this.init = function() {\n\n        ws.message(function(data) {\n            _this.addAnnots(data);\n        });\n\n    };\n\n\n    this.start = function() {\n        if(!started) {\n            this.startTs = Date.now();\n            started = true;\n        }\n        this.cleanInterval = setInterval(function () { _this.removePassedObjets(); }, 1000 * this.height / this.pixelsPerSecond );\n        if(!externalRefresh) {\n            this.refreshInterval = setInterval(function() {_this.move();}, 1000/this.framerate);\n        }\n    };\n\n    this.stop = function() {\n        clearInterval(this.cleanInterval);\n        if(!externalRefresh) {\n            clearInterval(this.refreshInterval);\n        }\n    };\n\n}\n\nmodule.exports = {\n    AnnotsRoll: AnnotsRoll,\n};\n","/**\n* js/annotstimeline\n*\n* annotstimeline basic component\n*\n*/\n\n'use strict';\n\nvar PIXI = require('pixi');\nvar Utils = require('./utils.js');\nvar _ = require('lodash');\n\nvar defaultOptions = {\n    logger: undefined,\n    intervalWidth: 10,\n    intervalHeight: 5,\n    maxCellHeight: 200,\n    radius: 300,\n    serverUrl: 'http://127.0.0.1:8080',\n    channel: 'ANNOT',\n    maxPages: 1000,\n    showClockGraphics: true,\n    archive: false\n};\n\n\nfunction AnnotsTimeLine(options){\n    var _this = this;\n    var opts = _(options).defaults(defaultOptions).value();\n\n    this.container = new PIXI.DisplayObjectContainer();\n    this.container.x = opts.xInit;\n    this.container.y = opts.yInit;\n    this.container.width = opts.width;\n    this.container.height = opts.height;\n\n    this.timeBegin = opts.timeBegin;\n    this.timeEnd = opts.timeEnd;\n    this.duration = (this.timeEnd - this.timeBegin)/1000;\n    this.width = opts.width;\n    this.height = opts.height;\n    this.intervalHeight = opts.intervalHeight;\n    this.intervalWidth = opts.intervalWidth;\n    this.maxCellHeight = opts.maxCellHeight;\n    this.annotCategories = opts.annotCategories;\n    this.startTs = options.startTs || Date.now();\n    this.showClockGraphics = opts.showClockGraphics;\n    this.archive = opts.archive;\n\n    this.circleX = opts.circleX || (this.width/2);\n    this.circleY = opts.circleY || (this.height/2);\n    this.radius = opts.radius;\n    var perimeter = 2*Math.PI* this.radius;\n    this.intervalDuration = (this.intervalWidth * this.duration / perimeter);\n\n    var channel = opts.channel;\n    var eventCode = opts.eventCode;\n    var serverUrl = opts.serverUrl;\n    var maxPages = opts.maxPages;\n\n    var totalIndex = Math.floor( perimeter/this.intervalWidth);\n\n    this.cells = [];\n    for (var i=0; i<(perimeter/this.intervalWidth) ; i++){\n        this.cells[i] = [];\n        this.cells[i].i = i;\n        this.cells[i].totalAnnots = 0;\n        this.cells[i].categories = {};\n    }\n\n    var ws = opts.ws;\n    var stageView = opts.stageView;\n\n    //draw the base - circle and line to locate the scene\n    var graphics = new PIXI.Graphics();\n    graphics.lineStyle(2, 0x646464)\n        .drawCircle(this.circleX, this.circleY, this.radius - 3)\n        .endFill();\n    this.container.addChild(graphics);\n\n    stageView.registerComponent(this);\n\n    var loadArchives = function() {\n        //start timeBegin end startTime\n        //query -> need channel + eventCode\n        //iterate over data fill cells\n        var startTs = _this.timeBegin;\n        var endTs = Math.min(_this.timeEnd,_this.startTs);\n\n        var url = serverUrl + '/p/api/v1/annotation';\n        var filters = [\n            { name: 'ts', op: '>', val: new Date(startTs).toISOString()}, //start\n            { name: 'ts', op: '<=', val: new Date(endTs).toISOString()}, //end\n            { name: 'channel', op: '==', val: channel}, //channel\n            { name: 'event_code', op: '==', val: eventCode} //eventcode\n        ];\n\n        url = url + '?q=' + JSON.stringify({filters:filters});\n\n        var totalPage = 1;\n        var currentPage = 1;\n\n        var processResFunction = function(res) {\n            //console.log(\"RES archive\", res);\n            if(res) {\n                var data = res.target.json;\n                /*jshint -W069 */\n                totalPage = Math.min(maxPages,parseInt(data['total_pages']));\n                data.objects.forEach(function(annotation) {\n                    _this.addAnnot(annotation);\n                });\n            }\n            if(currentPage <= totalPage) {\n                var jsonLoader = new PIXI.JsonLoader(url+'&page='+currentPage, true);\n                jsonLoader.on('loaded', processResFunction);\n                jsonLoader.load();\n                currentPage++;\n            }\n        };\n        processResFunction();\n\n    };\n\n    //Add Annotation to the TimeLine\n    this.addAnnot = function(data){\n\n        var ts = Date.parse(data.ts);\n        var colorsDef;\n        _(this.annotCategories).eachRight(function(cdef) {\n            if(cdef.ts < ts) {\n                colorsDef = cdef;\n                return false;\n            }\n        });\n\n        if(!colorsDef) {\n            return;\n        }\n\n        if (this.timeEnd > ts){\n            var i = Math.floor((ts - this.timeBegin)/(1000*this.intervalDuration));\n\n            if (typeof(this.cells[i].graphics) === 'undefined'){\n                this.initCell(this.cells[i], colorsDef);\n            }\n\n            var annotCode;\n            if (typeof(colorsDef.colors[data.content.category.code]) !== 'undefined'){\n                annotCode = data.content.category.code;\n            } else {\n                annotCode = 'default';\n            }\n\n            this.cells[i].categories[annotCode].count += 1;\n            this.cells[i].totalAnnots +=1;\n            this.redrawCell(this.cells[i], colorsDef);\n        }\n    };\n\n    this.initClockGraphics = function() {\n        var tBeg = new PIXI.Text(Utils.formatTime(this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });\n        tBeg.x = this.circleX + 15;\n        tBeg.y = this.circleY - this.radius - this.maxCellHeight - 10;\n        this.container.addChild(tBeg);\n\n        var tEnd = new PIXI.Text(Utils.formatTime(this.timeEnd), { font: '12pt Gothic Standard', fill: '#646464' });\n        tEnd.x = this.circleX - 15 - tEnd.width;\n        tEnd.y = this.circleY - this.radius - this.maxCellHeight - 10;\n        this.container.addChild(tEnd);\n\n        var t15 = new PIXI.Text(Utils.formatTime(((this.timeEnd - this.timeBegin)/4) + this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });\n        t15.x = this.circleX + this.radius + this.maxCellHeight + 10 ;\n        t15.y = this.circleY - t15.height;\n        t15.rotation = Math.PI /2;\n        this.container.addChild(t15);\n\n        var t30 = new PIXI.Text(Utils.formatTime(((this.timeEnd - this.timeBegin)/2) + this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });\n        t30.x = this.circleX - t30.width/2;\n        t30.y = this.circleY + this.radius + this.maxCellHeight - 2;\n        this.container.addChild(t30);\n\n        var t45 = new PIXI.Text(Utils.formatTime(((this.timeEnd - this.timeBegin)*3/4) + this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });\n        t45.x = this.circleX - this.radius - this.maxCellHeight - 10 ;\n        t45.y = this.circleY + t15.height;\n        t45.rotation = -Math.PI/2;\n        this.container.addChild(t45);\n\n        var lineV = new PIXI.Graphics();\n        lineV.lineStyle(1, 0x646464)\n            .moveTo(this.circleX, this.circleY - (this.radius/3)/2)\n            .lineTo(this.circleX, this.circleY - this.radius - this.maxCellHeight - 10)\n            .endFill();\n        this.container.addChild(lineV);\n    };\n\n    //Draw the cellule\n    this.redrawCell = function(cell, colorsDef){\n        var y = 0;\n\n        //Check if total height is higher than Max Cell Height\n        var heightStep;\n        if ((cell.totalAnnots*this.intervalHeight) > this.maxCellHeight){\n            heightStep = this.maxCellHeight/cell.totalAnnots;\n        } else {\n            heightStep = this.intervalHeight;\n        }\n\n        //Draw the rect depending on the height step calculated\n        for (var i=0; i< colorsDef.order.length; i++){\n            var currentCode = colorsDef.order[i];\n            cell.graphics.beginFill(cell.categories[currentCode].color.replace('#', '0x'))\n                .drawRect(0, y, this.intervalWidth-1, -cell.categories[currentCode].count * heightStep)\n                .endFill();\n            y -= cell.categories[currentCode].count*heightStep;\n        }\n    };\n\n    this.initCell = function(cell, colorsDef){\n        cell.graphics = new PIXI.Graphics();\n        cell.graphics.position.x = this.circleX + this.radius * Math.sin(cell.i*(360/totalIndex)*(Math.PI/180));\n        cell.graphics.position.y = this.circleY - this.radius * Math.cos(cell.i*(360/totalIndex)*(Math.PI/180));\n        cell.graphics.rotation = (cell.i)*(360/totalIndex)*(Math.PI/180) + (360/(totalIndex*2))*(Math.PI/180);\n        this.container.addChild(cell.graphics);\n\n        for (var category in colorsDef.colors){\n            cell.categories[category] = {\n                'count': 0,\n                'color': colorsDef.colors[category]\n            };\n        }\n        if (typeof(cell.categories['default']) === 'undefined'){\n            cell.categories['default'] = {\n                'count': 0,\n                'color': colorsDef.defaultColor\n            };\n        }\n    };\n\n    this.init = function() {\n        if (!this.archive){\n            ws.message(function(data) {\n                _this.addAnnot(data);\n            });\n        }\n\n        if (this.showClockGraphics){this.initClockGraphics();}\n    };\n\n\n    this.start = function() {\n        this.startTs = Date.now();\n        loadArchives();\n    };\n\n    this.refresh = function() {\n\n    };\n\n    this.stop = function(){\n    };\n\n    return this;\n}\n\nmodule.exports = {\n    AnnotsTimeLine: AnnotsTimeLine\n};\n","/**\n* js/annotsvizview.js\n*\n* This is the starting point for your application.\n* Take a look at http://browserify.org/ for more info\n*\n*/\n/*jshint unused: false */\n'use strict';\n\nvar PIXI = require('pixi');\nvar _ = require('lodash');\nvar DoubleRoll = require('./doubleroll.js');\nvar AnnotsTimeLine = require('./annotstimeline.js');\nvar AnnotsRoll = require('./annotsroll.js');\nvar Utils = require('./utils.js');\n\nvar defaultOptions = {\n    xInit: 0,\n    yInit: 0,\n    width: 1024,\n    height: 768\n};\n\nfunction AnnotsVizView(options){\n    var _this = this;\n    var opts = _(options).defaults(defaultOptions).value();\n\n    this.container = new PIXI.DisplayObjectContainer();\n    this.container.x = opts.xInit;\n    this.container.y = opts.yInit;\n    this.width = opts.width;\n    this.height= opts.height;\n    this.timeBegin = opts.timeBegin;\n    this.timeEnd = opts.timeEnd;\n\n    this.annotCategories = [];\n    this.annotCategoriesDay2 = [];\n    this.annotCategoriesDay1 = [];\n\n    var wsPianoroll = opts.wsPianoroll;\n    var wsAnnot = opts.wsAnnot;\n    var stageView = opts.stageView;\n    var channel = opts.channel;\n    var serverUrl = opts.serverUrl;\n\n    var eventCode = opts.eventCode;\n    var eventCodeSessionDay2 = opts.eventCodeSessionDay2;\n    var eventCodeSessionDay1 = opts.eventCodeSessionDay1;\n    var logger = opts.logger;\n\n    Utils.getAnnotCategories(opts.urlCategories + eventCode, this.annotCategories);\n    Utils.getAnnotCategories(opts.urlCategories + eventCodeSessionDay2, this.annotCategoriesDay2);\n    Utils.getAnnotCategories(opts.urlCategories + eventCodeSessionDay1, this.annotCategoriesDay1);\n\n    stageView.registerComponent(this);\n\n    var currentDay = new AnnotsTimeLine.AnnotsTimeLine({\n        stageView : stageView,\n        logger: logger,\n        ws: wsAnnot,\n        xInit: 0,\n        yInit: 0,\n        width: 1024 - 200 - 200,\n        height: 768-200,\n        timeBegin: this.timeBegin,\n        timeEnd: this.timeEnd,\n        intervalWidth: 6,\n        intervalHeight: 10,\n        maxCellHeight: 70,\n        radius: 200,\n        eventCode: eventCode,\n        channel: channel,\n        serverUrl: serverUrl,\n        annotCategories: this.annotCategories\n    });\n\n    //Archive day 2\n    var timeLineDay2 = new AnnotsTimeLine.AnnotsTimeLine({\n        stageView : stageView,\n        xInit: 0,\n        yInit: 0,\n        width: 1024 - 200 - 200,\n        height: 768-200,\n        timeBegin: Date.parse('2015-04-16T14:00:00+02:00'),\n        timeEnd: Date.parse('2015-04-16T21:00:00+02:00'),\n        circleX: currentDay.circleX,\n        circleY: currentDay.circleY,\n        intervalWidth: (currentDay.radius*2/3)* currentDay.intervalWidth / currentDay.radius,\n        intervalHeight: (currentDay.intervalHeight * (currentDay.radius - currentDay.radius*2/3))/ currentDay.maxCellHeight,\n        maxCellHeight: (currentDay.radius - currentDay.radius*2/3)/2,\n        radius: currentDay.radius*2/3,\n        annotCategories: this.annotCategoriesDay2,\n        eventCode: eventCodeSessionDay2,\n        channel: channel,\n        serverUrl: serverUrl,\n        showClockGraphics:false,\n        archive: true\n    });\n\n    //Archive day 1\n    var timeLineDay1 = new AnnotsTimeLine.AnnotsTimeLine({\n        stageView : stageView,\n        xInit: 0,\n        yInit: 0,\n        width: 1024 - 200 - 200,\n        height: 768-200,\n        timeBegin: Date.parse('2015-04-16T14:00:00+02:00'),\n        timeEnd: Date.parse('2015-04-16T21:00:00+02:00'),\n        circleX: currentDay.circleX,\n        circleY: currentDay.circleY,\n        intervalWidth: (currentDay.radius*2/3)* currentDay.intervalWidth / currentDay.radius,\n        intervalHeight: (currentDay.intervalHeight * (currentDay.radius - currentDay.radius/3))/ currentDay.maxCellHeight,\n        maxCellHeight: (currentDay.radius*2/3 - currentDay.radius/3)/4,\n        radius: currentDay.radius/3,\n        annotCategories: this.annotCategoriesDay1,\n        eventCode: eventCodeSessionDay1,\n        channel: channel,\n        serverUrl: serverUrl,\n        showClockGraphics:false,\n        archive: true,\n    });\n\n    var currentTimeText = new PIXI.Text('-- : -- : --', { font: '18pt Gothic Standard', fill: '#646464' });\n    currentTimeText.x = timeLineDay2.circleX - currentTimeText.width/2;\n    currentTimeText.y = timeLineDay2.circleY - currentTimeText.height/2;\n    this.container.addChild(currentTimeText);\n\n\n    var doubleRollH = new DoubleRoll.DoubleRoll({\n        stageView : stageView,\n        logger: logger,\n        ws: wsPianoroll,\n        yInit: (this.height - 200),\n        sceneHeight: 200,\n        pianorolls : [\n            {\n                height: 200,\n                timeWidth: 10,\n                lineInterval: 5000,\n                noteHeight: 10\n            },\n        ]\n    });\n\n    var doubleRollV = new DoubleRoll.DoubleRoll({\n        stageView : stageView,\n        logger: logger,\n        ws: wsPianoroll,\n        orientation: 'vertical',\n        sceneHeight: 768-200,\n        pianorolls : [\n            {\n                height: 200,\n                timeWidth: 60,\n                lineInterval: 5000,\n                noteHeight: 5,\n            },\n        ]\n    });\n\n    var annotsRoll = new AnnotsRoll.AnnotsRoll({\n        stageView : stageView,\n        logger: logger,\n        ws: wsAnnot,\n        parentContainer: doubleRollV.stage,\n        xInit: 1024 - 200 - 200,\n        yInit: 768-200,\n        width: 200 + 200,\n        height: 768-200,\n        widthRoll: 200,\n        framerate: doubleRollV.framerate,\n        pixelsPerSecond: Math.floor(1024 / 60),\n        annotColors: this.annotCategories\n    });\n\n    var limiters = new PIXI.Graphics()\n        .lineStyle(1, 0x646464)\n        .moveTo(annotsRoll.container.x, annotsRoll.container.y)\n        .lineTo(annotsRoll.container.x, annotsRoll.container.y - annotsRoll.height)\n        .moveTo(annotsRoll.container.x + annotsRoll.widthRoll, annotsRoll.container.y)\n        .lineTo(annotsRoll.container.x + annotsRoll.widthRoll, annotsRoll.container.y - annotsRoll.height)\n        .moveTo(0, this.height - 200)\n        .lineTo(this.width, this.height - 200)\n        .drawRect(0, 0, this.width -1, this.height -1)\n        .beginFill(0xECECEC)\n        .drawRect(1024 - 200, 0, 200, 768-200)\n        .endFill();\n    this.container.addChild(limiters);\n\n    this.init = function(){\n    };\n\n    this.updateTime = function(){\n        currentTimeText.setText(Utils.formatTime(Date.now()));\n    };\n\n    var refreshTimeInterval;\n\n    this.start = function() {\n        refreshTimeInterval = setInterval(function() {_this.updateTime();}, 1000);\n    };\n\n    this.refresh = function() {\n    };\n\n    this.stop = function(){\n    };\n\n    return this;\n\n}\n\nmodule.exports = {\n    AnnotsVizView: AnnotsVizView\n};\n","/**\n* scripts/doubleroll.js\n*\n* This is the starting point for your application.\n* Take a look at http://browserify.org/ for more info\n*/\n\n'use strict';\n\n\nvar PIXI = require('pixi');\nvar _ = require('lodash');\nvar PianoRoll = require('./pianoroll');\nvar Utils = require('./utils.js');\n\nvar defaultConfig = {\n    orientation: 'horizontal',\n    logger: undefined,\n    sceneWidth: 1024,\n    showTimer: false,\n    pianorolls : [\n      {\n        height: 384,\n        timeWidth: 10,\n        lineInterval: 5000,\n        noteHeight: undefined,\n        range: {\n    \t\tbottom: 40,\n    \t\ttop: 90,\n        },\n        dynamicRange: true,\n      },\n      {\n        height: 384,\n        timeWidth: 60,\n        lineInterval: 5000,\n        noteHeight: undefined,\n        range:{\n    \t\tbottom: 0,\n    \t\ttop: 128,\n        },\n        dynamicRange: false,\n      },\n    ],\n    framerate: 25,\n    offsetMusic: false,\n    sceneBgColor: 0xFFFFFF,\n    lineColor: 0x444444,\n    lineFillColor: 0xFFFF00,\n    noteColors: [0xB90000, 0x4BDD71, 0xAF931E, 0x1C28BA, 0x536991],\n    noteHeight: undefined,\n    zeroShift: 0.9,\n    timeWidth: 60,\n    lineInterval: 5000,\n//    wsUri: undefined,\n//    eventCode: undefined\n\n};\n\nfunction DoubleRoll(options) {\n\n    var _this = this;\n    var opts = _(options).defaults(defaultConfig).value();\n\n    var orientation = opts.orientation;\n    var isHorizontal = (orientation !== 'vertical');\n\n    this.logger = opts.logger;\n    this.lineColor = opts.lineColor;\n    this.lineFillColor = opts.lineFillColor;\n    this.framerate = opts.framerate;\n    this.offsetMusic = opts.offsetMusic;\n    this.noteColors = opts.noteColors;\n    this.showTimer = opts.showTimer;\n\n    var noteHeight = opts.noteHeight;\n    var sceneHeight = opts.sceneHeight || _(opts.pianorolls).reduce(function(s,p) { return s + p.height; }, 0);\n    var timeWidth = opts.timeWidth;\n    var lineInterval = opts.lineInterval;\n    var offsetMusic = opts.offsetMusic;\n\n    var sceneWidth = opts.sceneWidth;\n    var stageView = opts.stageView;\n\n    \n    var zeroShift = opts.zeroShift;\n\n    var ws = opts.ws;\n\n    var colorsReg = {};\n\n    this.container = new PIXI.DisplayObjectContainer();\n    this.container.x = Math.floor(sceneWidth*zeroShift);\n    this.container.y = 0;\n\n    stageView.registerComponent(this);\n\n    var pianorollList = [];\n\n    var pianorollOptions = {\n        parentContainer: this.container,\n        orientation: orientation,\n        xInit: 0,\n        width: sceneWidth,\n        noteColors: this.noteColors,\n        colorsReg: colorsReg,\n        lineColor: this.lineColor,\n        lineInterval: lineInterval,\n        offsetMusic: offsetMusic,\n    };\n\n    var yInit = opts.yInit || 0;\n    var linesDown = true;\n    _(opts.pianorolls).forEach(function(prDef, i) {\n        var prNoteHeight = noteHeight || prDef.noteHeight || prDef.height / (prDef.range.top - prDef.range.bottom + 1);\n        var prTimeWidth = prDef.timeWidth || timeWidth;\n        pianorollList.push(new PianoRoll(_({\n            yInit: yInit,\n            height: prDef.height,\n            linesDown: linesDown,\n            pixelsPerSecond: Math.floor(sceneWidth / prTimeWidth),\n            noteHeight: prNoteHeight,\n            lineInterval: prDef.lineInterval,\n            range: prDef.range,\n            dynamicRange: prDef.dynamicRange,\n        }).defaults(pianorollOptions).value()));\n        yInit += prDef.height;\n        linesDown = !linesDown;\n\n        if(i<(opts.pianorolls.length-1)) {\n            var lineGraphics = new PIXI.Graphics()\n                .beginFill(_this.lineFillColor)\n                .lineStyle(1, _this.lineColor)\n                .moveTo(Math.floor(sceneWidth*zeroShift), yInit)\n                .lineTo(-sceneWidth - Math.floor(sceneWidth*zeroShift), yInit)\n                .endFill();\n            _this.container.addChild(lineGraphics);\n        }\n    });\n\n    if (this.showTimer){\n\t    var currentTimeText = new PIXI.Text('-- : -- : --', { font: '40pt Arial', fill: '#646464' });\n\t    currentTimeText.x = -currentTimeText.width - 60; \n\t    currentTimeText.y = sceneHeight - currentTimeText.height - 30;\n\t    this.container.addChild(currentTimeText);\n\t}\n    \n    \n    if(!isHorizontal) {\n        this.container.rotation = Math.PI/2; \n        this.container.y = sceneHeight;\n        this.container.x = sceneWidth;\n    }\n\n\n    this.init = function() {\n\n    \tws.message(function(data) {\n            _this.addNotes(data);\n        });\n\n    };\n    \n    this.updateTime = function(){\n        currentTimeText.setText(Utils.formatTime(Date.now()));\n    };\n\n    this.addNotes = function(data) {\n\n        pianorollList.forEach(function(c) {\n            c.addNoteRaw(data);\n        });\n    };\n\n    this.refresh = function() {\n        pianorollList.forEach(function(c) {\n            c.move();\n        });\n    };\n\n    // Init page and intervals\n    var startTs;\n    var refreshTimeInterval;\n\n    this.start = function() {\n    \tif (this.showTimer){\n    \t\trefreshTimeInterval = setInterval(function() {_this.updateTime();}, 1000);\n    \t}\n    \t\n        startTs = Date.now();\n        pianorollList.forEach(function(c) {\n            c.start();\n        });\n    };\n\n    this.stop = function() {\n\n        pianorollList.forEach(function(c) {\n            c.stop();\n        });\n    };\n\n\n    this.log = function(m) {\n        if(this.logger) {\n            this.logger.log(m);\n        }\n    };\n\n\n\n    return this;\n}\n\nmodule.exports = {\n    DoubleRoll: DoubleRoll\n};\n","/**\n* js/wswrapper.js\n*\n* simple logger service\n*\n*/\n\n/* global document: false */\n\n'use strict';\n\nfunction HtmlLogger(doLog, container) {\n\n    var logContainer = container;\n    if(typeof(container) === 'string') {\n        logContainer = document.getElementById(container);\n    }\n    if(!doLog) {\n        document.body.removeChild(logContainer);\n        logContainer = undefined;\n    }\n\n\n    this.log = function(msg) {\n        if(doLog && logContainer) {\n            logContainer.innerHTML += msg + '\\n';\n            logContainer.scrollTop = logContainer.scrollHeight;\n        }\n    };\n}\n\nfunction ConsoleLogger(doLog) {\n\n    this.log = function(msg) {\n        if(doLog) {\n            console.log(msg);\n        }\n    };\n\n}\n\nmodule.exports = {\n    HtmlLogger: HtmlLogger,\n    ConsoleLogger: ConsoleLogger\n};\n","/**\n* js/pianoroll.js\n*\n* pianoroll basic component\n*\n*/\n\n//TODO: add delay to adjust the \"zero\". this could should be given as an option\n//or if explicitely null automatically adjusted from the mean of difference\n//between the note timestamp and the current timestamp.\n\n'use strict';\n\n\nvar PIXI = require('pixi');\nvar randomColor = require('randomColor');\nvar _ = require('lodash');\n\nvar NTP_EPOCH_DELTA = 2208988800; //c.f. RFC 868\n\nfunction PianoRoll(options) {\n    var _this = this;\n    this.container = new PIXI.DisplayObjectContainer();\n    this.container.x = options.xInit;\n    this.container.y = options.yInit;\n    options.parentContainer.addChild(this.container);\n\n    var orientation = options.orientation;\n    var isHorizontal = (orientation !== 'vertical');\n\n    this.linesDown = options.linesDown;\n    this.height = options.height;\n    this.pixelsPerSecond = options.pixelsPerSecond;\n    this.width = options.width;\n    this.noteColors = options.noteColors;\n    this.colorsReg = options.colorsReg || {};\n    this.lineColor = options.lineColor;\n    this.lineInterval = options.lineInterval;\n    this.offsetMusic = options.offsetMusic || false;\n    this.noteHeight = options.noteHeight;\n    this.noteDict = {};\n    this.startTs = options.startTs || Date.now();\n    this.dynamicRange = options.dynamicRange;\n    this.initRange = options.range;\n    this.range = options.range;\n\n\n    var started = false;\n\n    var isHidden = function(child) {\n        // TODO: the origin point is an approximation. Should refine this\n        var globalPos = child.toGlobal(new PIXI.Point(0,0));\n        return ((globalPos.x + child.width) < 0) || ((globalPos.y + child.height) < 0) ;\n    };\n\n    //TODO: I do not like the \"regColor\" object. This should not be global, but local\n    this.getColor = function(canal) {\n        var color = this.colorsReg[canal];\n        if(typeof(color) === 'undefined') {\n            var colorsRegSize = Object.keys(this.colorsReg).length;\n            if(colorsRegSize < this.noteColors.length) {\n                color = this.colorsReg[canal] = this.noteColors[colorsRegSize];\n            }\n            else {\n                color = this.colorsReg[canal] = parseInt(randomColor({ luminosity: 'light', hue: 'random', format:'hex'}).replace(/^#/, ''), 16);\n            }\n        }\n        return color;\n    };\n\n    this.getNoteRect = function(note, x, y, color, alpha, width, height) {\n        var graphics = new PIXI.Graphics();\n        graphics.note = note;\n        graphics.beginFill(color, alpha);\n        graphics.drawRect(0, 0, width, height);\n        graphics.endFill();\n        graphics.x = x;\n        graphics.y = y;\n        graphics.width = width;\n        graphics.height = height;\n        return graphics;\n    };\n\n    this.addNoteRaw = function(data) {\n        var note = data.content[3];\n        var velocity = data.content[4];\n        //var ts = (data.content[0] - NTP_EPOCH_DELTA)*1000;\n        var ts = Date.parse(data.ts_server);\n        console.log(ts, data.content[0]);\n        var channel = data.content[2];\n        var sessionTs = data.content[1];\n\n        if(velocity !== 0 && typeof(this.noteDict[channel]) !== 'undefined' && typeof(this.noteDict[channel][note] !== 'undefined')) {\n            this.addNote(note, ts, sessionTs, 0, channel, 0);\n        }\n\n        this.addNote(note, ts, sessionTs, velocity, channel, 0);\n    };\n\n    this.addNote = function(note, startTime, sessionTs, velocity, channel, duration) {\n\n        var ts = startTime;\n        if(this.offsetMusic) {\n            ts = this.startTs + sessionTs;\n        }\n\n        var noteDuration = duration;\n        var noteVelocity = velocity;\n        var graphics;\n        if(!duration) {\n            if(typeof this.noteDict[channel]==='undefined'){\n                this.noteDict[channel] = {};\n            }\n            if(velocity===0) {\n                if(typeof this.noteDict[channel][note] !== 'undefined') {\n                    var noteDef = this.noteDict[channel][note];\n                    delete this.noteDict[channel][note];\n                    noteDuration = sessionTs - noteDef.sessionTs;\n                    graphics = noteDef.graphics;\n                    noteVelocity = noteDef.velocity;\n                    ts = noteDef.ts;\n                }\n            }\n            else {\n                noteDuration = Math.abs(Date.now() - ts);\n                this.noteDict[channel][note] = { ts: ts, velocity: velocity, sessionTs: sessionTs};\n            }\n        }\n\n\n        if(!this.offsetMusic || velocity===0) {\n\n            var width = noteDuration * this.pixelsPerSecond / 1000;\n            if(!graphics) {\n                var x = (ts-this.startTs) * this.pixelsPerSecond / 1000;\n                if((x+width) <  (Math.abs(this.container.x) - this.width)) {\n                    // not visible. do nothing\n                    return;\n                }\n            \tif (this.dynamicRange && (this.range.bottom > note || note > this.range.top)){\n            \t\tvar newScale = {};\n            \t\tnewScale['bottom'] = Math.min(note, this.range.bottom);\n            \t\tnewScale['top'] = Math.max(note, this.range.top);\n            \t\tthis.rescaleScene(newScale);\n            \t}\n            \tvar y = Math.floor(((this.range.top-this.range.bottom)-(note-this.range.bottom)+0.5) * (this.noteHeight) - (this.noteHeight/2));\n                var color = this.getColor(channel);\n\n                var alpha = (noteVelocity / 128);\n\n                graphics = this.getNoteRect(note, x, y, color, alpha, width, this.noteHeight);\n                this.container.addChild(graphics);\n            }\n            else {\n                graphics.width = width;\n            }\n\n            if(!duration && velocity) {\n                this.noteDict[channel][note].graphics = graphics;\n            }\n        }\n    };\n\n    //rescale scene in case a note out of range is added or a note out of the range is removed\n    this.rescaleScene = function(newScale){\n    \tvar _this = this;\n    \tvar childrenToUpdate = [];\n    \tvar top = this.initRange.top;\n    \tvar bottom = this.initRange.bottom;\n    \t_(_this.container.children).forEach(function(child) {\n    \t\tif (typeof(child) !== 'undefined' && child.note && !isHidden(child)){\n    \t\t\ttop = Math.max(child.note, top);\n    \t\t\tbottom = Math.min(child.note, bottom);\n    \t\t\treturn childrenToUpdate.push(child);\n    \t\t}\n        });\n    \tif (newScale){\n    \t\tthis.range = newScale;\n    \t}else{\n    \t\tthis.range.top = top;\n    \t\tthis.range.bottom = bottom;\n    \t}\n    \tthis.noteHeight = this.height / (this.range.top - this.range.bottom + 1);\n    \tchildrenToUpdate.forEach(function(child) {\n\t\t\tchild.y = Math.floor(((_this.range.top-_this.range.bottom)-(child.note-_this.range.bottom)+0.5) * (_this.noteHeight) - (_this.noteHeight/2));\n\t\t\tchild.height = _this.noteHeight;\n        });\n    };\n\n    this.addLine = function(ts){\n\n        if(typeof(ts) === 'undefined') {\n            ts = new Date();\n        }\n        var x = -this.container.x;\n        var y = this.linesDown ? this.height - 20 : 0;\n\n        var graphics = new PIXI.Graphics()\n            .beginFill(0xFFFF00)\n            .lineStyle(1, this.lineColor)\n            .moveTo(0, 0)\n            .lineTo(0, 20)\n            .endFill();\n        graphics.x = x;\n        graphics.y = y;\n        this.container.addChild(graphics);\n        // Add text\n        //var totalSec = lineNb * this.lineInterval / 1000;\n        var hours = ts.getHours();\n        var minutes =ts.getMinutes();\n        var seconds = ts.getSeconds();\n        var timeStr = (hours < 10 ? '0' + hours : hours) + ':' + (minutes < 10 ? '0' + minutes : minutes) + ':' + (seconds  < 10 ? '0' + seconds : seconds);\n\n        var fontObj = { font: '10pt Arial', fill: '#444444' };\n        var t = new PIXI.Text(timeStr, fontObj);\n        if(isHorizontal) {\n            t.x = x + 2;\n            t.y = this.linesDown ? this.height - 15 : 2;\n        }\n        else {\n            t.rotation = -Math.PI/2;\n            t.x = x ;\n            t.y = this.linesDown ? this.height - 2 : t.width + 2;\n        }\n        this.container.addChild(t);\n    };\n\n    this.moveTo = function(diffTime){\n        var oldX = this.container.x;\n        this.container.x = Math.floor(diffTime*this.pixelsPerSecond);\n        var deltaX = Math.abs(oldX-this.container.x);\n        _.forOwn(this.noteDict, function(channelDict) {\n            _.forOwn(channelDict, function(noteDef) {\n                if(noteDef.graphics) {\n                    noteDef.graphics.width = noteDef.graphics.width + deltaX;\n                }\n            });\n        });\n    };\n\n    this.move = function() {\n        var diff = (this.startTs - Date.now())/1000;\n        this.moveTo(diff);\n    };\n\n    this.removePassedObjets = function(){\n        var childrenToRemove = [];\n        var rescale = false;\n        _(_this.container.children).forEach(function(child) {\n            return typeof(child) === 'undefined' ||\n                (isHidden(child) && childrenToRemove.push(child));\n        });\n        childrenToRemove.forEach(function(child) {\n        \tif (_this.dynamicRange && (_this.range.bottom === child.note || child.note === _this.range.top)){\n                rescale = true;\n            }\n            _this.container.removeChild(child);\n        });\n        //externalize this test to avoid repeated call to the function rescaleScene in the previous loop\n        if (rescale){\n            _this.rescaleScene();\n        }\n    };\n\n    this.start = function() {\n        if(!started) {\n            this.startTs = Date.now();\n            this.addLine();\n            started = true;\n        }\n        this.verticalLinesInterval = setInterval(function() { _this.addLine(); }, this.lineInterval);\n        this.cleanInterval = setInterval(function () { _this.removePassedObjets(); }, 1000 * this.width / this.pixelsPerSecond );\n    };\n\n    this.stop = function() {\n        clearInterval(this.verticalLinesInterval);\n        clearInterval(this.cleanInterval);\n    };\n\n}\n\nmodule.exports = PianoRoll;\n","/**\n* scripts/stageview.js\n*\n* This is the starting point for your application.\n* Take a look at http://browserify.org/ for more info\n*/\n\n/* global document: false */\n\n'use strict';\n\n\nvar PIXI = require('pixi');\nvar _ = require('lodash');\n\nvar defaultConfig = {\n    externalRefresh: false,\n    logger: undefined,\n    sceneWidth: 1024,\n    sceneHeight: 768,\n    framerate: 25,\n    sceneBgColor: 0xFFFFFF,\n    canvasContainer: 'canvasContainer',\n};\n\nfunction StageView(options) {\n\n    var _this = this;\n    var opts = _(options).defaults(defaultConfig).value();\n\n    var externalRefresh = opts.externalRefresh;\n\n    this.logger = opts.logger;\n    this.framerate = opts.framerate;\n    var sceneBgColor = opts.sceneBgColor;\n    var sceneWidth = opts.sceneWidth;\n    var sceneHeight = opts.sceneHeight;\n    var canvasContainer = opts.canvasContainer;\n    var timeContainer = [];\n    var components = [];\n\n    //create an new instance of a pixi stage\n    this.stage = new PIXI.Stage(sceneBgColor);\n    //create a renderer instance.\n    var renderer = PIXI.autoDetectRenderer(sceneWidth, sceneHeight);\n\n    this.init = function() {\n\n        if(typeof(canvasContainer) === 'string') {\n            canvasContainer = document.getElementById(canvasContainer);\n        }\n        if(typeof(timeContainer) === 'string') {\n            timeContainer = document.getElementById(timeContainer);\n        }\n\n        canvasContainer.appendChild(renderer.view);\n\n        components.forEach(function(c){\n    \t\tc.init();\n    \t});\n    };\n\n    this.registerTimeContainer = function(container) {\n    \ttimeContainer.push(container);\n    };\n\n    this.registerComponent = function(component) {\n    \tcomponents.push(component);\n    \tthis.stage.addChild(component.container);\n    };\n\n    this.refresh = function() {\n    \tcomponents.forEach(function(c){\n    \t\tc.refresh();\n    \t});\n        renderer.render(this.stage);\n    };\n\n    // Init page and intervals\n    var refreshInterval;\n\n    this.start = function() {\n\n        if(!externalRefresh) {\n            refreshInterval = setInterval(function() {_this.refresh();}, 1000/this.framerate);\n        }\n\n        components.forEach(function(c){\n    \t\tc.start();\n    \t});\n    };\n\n    this.stop = function() {\n        if(!externalRefresh) {\n            clearInterval(refreshInterval);\n        }\n        \n        components.forEach(function(c){\n    \t\tc.stop();\n    \t});\n    };\n\n\n    this.log = function(m) {\n        if(this.logger) {\n            this.logger.log(m);\n        }\n    };\n\n\n    return this;\n}\n\nmodule.exports = {\n    StageView: StageView\n};\n","/**\n* js/utils.js\n*\n* basic tools\n*\n*/\n/*jshint bitwise: false*/\n/*jshint camelcase: false */\n\n'use strict';\n\nvar PIXI = require('pixi');\nvar _ = require('lodash');\nvar moment = require('moment');\n\nfunction formatTime (ts) {\n    return moment(ts).format('HH:mm:ss');\n}\n\nfunction colorToHex(c) {\n    var m = /rgba?\\(\\s*(\\d+)\\s*,\\s*(\\d+)\\s*,\\s*(\\d+)/.exec(c);\n    return m ? '#' + (1 << 24 | m[1] << 16 | m[2] << 8 | m[3]).toString(16).substr(1) : c;\n}\n\nfunction getAnnotCategories(urlCategories, annotCategories) {\n\n    var jsonLoader = new PIXI.JsonLoader(urlCategories, true);\n\n    jsonLoader.on('loaded', function(res) {\n        var data = res.target.json;\n\n        while(annotCategories.length > 0) {\n            annotCategories.pop();\n        }\n\n        data.sessions.forEach(function(session) {\n            var annotCat = {\n                ts: session.start_ts === null ? new Date(0) : Date.parse(session.start_ts),\n                colors: {}\n            };\n            var categoriesJson = session.categories_json;\n            annotCat.order = categoriesJson.order;\n            if (typeof(annotCat.order['default']) === 'undefined'){\n                annotCat.order.push('default');\n            }\n            var catList = _.clone(categoriesJson.categories);\n            while(catList.length > 0) {\n                var cat = catList.pop();\n                if(cat.code) {\n                    annotCat.colors[cat.code] = colorToHex(cat.color);\n                }\n                if(cat.subcategories) {\n                    catList = catList.concat(cat.subcategories);\n                }\n            }\n            categoriesJson.categories.forEach(function(cat) {\n                if(cat.code) {\n                    annotCat.colors[cat.code] = colorToHex(cat.color);\n                }\n            });\n            annotCat.defaultColor = categoriesJson.defaultColor || '#536991';\n            annotCategories.push(annotCat);\n        });\n    });\n\n    jsonLoader.load();\n\n}\n\nmodule.exports = {\n    formatTime: formatTime,\n    getAnnotCategories: getAnnotCategories,\n    colorToHex: colorToHex\n};\n","/**\n* js/wswrapper.js\n*\n* simple webservice wrapper to register callbacks on onmessage\n*\n*/\n\n/* global WebSocket: false */\n\n'use strict';\n\nfunction WsWrapper(wsurl, logger) {\n\n    var url = wsurl;\n    var sock = new WebSocket(url);\n    var loggerObj = logger;\n\n    var log = function(msg) {\n        if(loggerObj) {\n            loggerObj.log(msg);\n        }\n    };\n\n    var handlers = [];\n\n    sock.onopen = function() {\n        log('Connected to ' + url);\n    };\n\n    sock.onclose = function(e) {\n        log('Connection closed (wasClean = ' + e.wasClean + ', code = ' + e.code + ', reason = \\'' + e.reason + '\\')');\n        sock = null;\n    };\n\n    sock.onmessage = function(e) {\n        log('received ' + e.data);\n        var data = JSON.parse(e.data);\n        handlers.forEach(function(handler) {\n            handler(data);\n        });\n    };\n\n    this.message = function(handler) {\n        if(handler) {\n            handlers.push(handler);\n        }\n    };\n\n}\n\nmodule.exports = {\n    WsWrapper: WsWrapper\n};\n"]}