annot-server/static/js/annotviz.js
author ymh <ymh.work@gmail.com>
Thu, 22 Jan 2015 08:07:09 +0100
changeset 109 8546e2181a73
parent 108 082b64a5c699
child 110 e4f0c105090d
permissions -rw-r--r--
correct color codes sent by client
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');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
var _ = require('lodash');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
module.exports = _({})
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
    .extend(doubleroll)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
    .extend(annotsroll)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
    .extend(annotstimeline)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
    .extend(annotsvizview)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
    .extend(stageview)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
    .extend(wswrapper)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
    .extend(logger)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
    .value();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
},{"./annotsroll":2,"./annotstimeline":3,"./annotsvizview":4,"./doubleroll":5,"./logger":6,"./stageview":8,"./wswrapper":10,"lodash":"lodash"}],2:[function(require,module,exports){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    32
* js/annotsRoll.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    33
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
* annotsRoll basic component
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
*
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
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
'use strict';
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
var PIXI = require('pixi');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
var _ = require('lodash');
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 DEFAULT_ANNOT_COLOR = '#bababa';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
var defaultAnnotStyles = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
    'label': { font: '16pt Arial Bold', fill: '#65A954', wordWrap: true},
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
    'text' : { font: '12pt Arial Regular', fill: '#444444', wordWrap: true},
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
    'user' : { font: '14pt Arial regular', fill: '#666666' },
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
var defaultOptions = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
    externalRefresh: false,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
    defaultColor: DEFAULT_ANNOT_COLOR,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
    annotStyles: defaultAnnotStyles
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
function AnnotsRoll(options) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
//parentContainer, xInit, yInit, width, height, widthRoll, pixelsPerSecond, annotColors
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
    var _this = this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
    var opts = _(options).defaults(defaultOptions).value();
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
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
    this.container = new PIXI.DisplayObjectContainer();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
    this.container.x = opts.xInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
    this.container.y = opts.yInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
    this.container.width = opts.width;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
    this.height = opts.height;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
    this.width = opts.width;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
    this.widthRoll = opts.widthRoll;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
    this.pixelsPerSecond = opts.pixelsPerSecond;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    73
    this.annotColors = opts.annotColors;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    74
    this.startTs = options.startTs || Date.now();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    75
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
    var yInit = opts.yInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
    var annotStyles = _(opts.annotStyles).defaults(defaultAnnotStyles).value();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    78
    for(var style in annotStyles) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    79
    	if (annotStyles[style].wordWrap === true){
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
    80
    		annotStyles[style].wordWrapWidth = this.widthRoll;
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    81
    	}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    82
    }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    83
    var started = false;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
    var ws = opts.ws;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
    var externalRefresh = opts.externalRefresh;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
    var stageView = opts.stageView;
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
    87
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
    stageView.registerComponent(this);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    89
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    90
    var isHidden = function(child) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    91
        // TODO: the origin point is an approximation. Should refine this
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
        var globalPos = child.toGlobal(new PIXI.Point(0,0));
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
        return ((globalPos.x + child.width) < 0) || ((globalPos.y + child.height) < 0) ;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
    this.addAnnots = function(data) {
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 title = data.content.category.label;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
        //var user = data.content.user;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
        //Test cat and color
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
        //var colorAnnot = 0x65A954;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
        var category = data.content.category.label,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
            text     = data.content.text,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
            user     = data.content.user,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
            ts       = Date.parse(data.ts),
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   106
            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
   107
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
        this.addAnnot(category, text, user, color, ts);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
    this.getColor = function(ts, code) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   112
        var colorsDef;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   113
        _(this.annotColors).eachRight(function(cdef) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   114
            console.log("cDef", cdef);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   115
            console.log("cDef ts", cdef.ts, ts);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   116
            if(cdef.ts < ts) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   117
                colorsDef = cdef.colors;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   118
                return false;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   119
            }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   120
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   121
        var resColor;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   122
        console.log("colorsDef", colorsDef);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   123
        if(colorsDef) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   124
            resColor = colorsDef[code];
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
        if(!resColor) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   127
            resColor = DEFAULT_ANNOT_COLOR;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   128
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   129
        return resColor;
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
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   132
    this.addAnnot = function(category, text, user, catColor, ts){
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
        var color = catColor ? catColor : DEFAULT_ANNOT_COLOR;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   135
        var x = 0;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   136
        var y = (ts-this.startTs) * this.pixelsPerSecond / 1000 + yInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   137
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   138
        var colorHex = parseInt(color.replace(/^#/, ''), 16);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   139
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   140
        var graphics = new PIXI.Graphics()
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   141
            .beginFill(colorHex)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   142
            .drawRect(x, y, 10, 3)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   143
            .endFill();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   144
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   145
        this.container.addChild(graphics);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   146
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   147
        var textHeight = 0;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   148
        var catLabel = new PIXI.Text(
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   149
            category,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   150
            _(annotStyles.label).extend({fill: color}).value()
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   151
        );
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   152
        catLabel.x = x + 20;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   153
        catLabel.y = y - 23;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   154
        this.container.addChild(catLabel);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   155
        textHeight += (catLabel.height - 23 + 2);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   156
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   157
        if(text) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   158
            var catText = new PIXI.Text(text, annotStyles.text);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   159
            catText.x = x + 20;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   160
            catText.y = y + 2;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   161
            this.container.addChild(catText);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   162
            textHeight += (catText.height + 2);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   163
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   164
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   165
        var catUser = new PIXI.Text(user, annotStyles.user);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   166
        catUser.x = x + 20;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   167
        catUser.y = y + 2 + textHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   168
        this.container.addChild(catUser);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   169
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   170
        this.addAnnotLine(colorHex, y);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   171
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   172
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   173
    this.addAnnotLine = function(color, y) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   174
        var x = this.widthRoll;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   175
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   176
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   177
        var graphics = new PIXI.Graphics()
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   178
            .beginFill(color)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   179
            .drawRect(x, y, this.width - x, 3)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   180
            .endFill();
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.container.addChild(graphics);
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.moveTo = function(diffTime){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   186
    	this.container.y = Math.floor(diffTime*this.pixelsPerSecond);
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
    this.move = this.refresh = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   190
        var diff = (this.startTs - Date.now())/1000;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   191
        this.moveTo(diff);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   192
    };
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.removePassedObjets = function(){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   195
        var childrenToRemove = [];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   196
        _(_this.container.children).forEach(function(child) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   197
            return typeof(child) === 'undefined' ||
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
                (isHidden(child) && childrenToRemove.push(child));
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
        childrenToRemove.forEach(function(child) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   201
            _this.container.removeChild(child);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   202
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   203
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   204
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   205
    this.init = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   206
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   207
        ws.message(function(data) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   208
            _this.addAnnots(data);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   209
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   210
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   211
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   212
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   213
    this.start = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   214
        if(!started) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   215
            this.startTs = Date.now();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   216
            started = true;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   217
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   218
        this.cleanInterval = setInterval(function () { _this.removePassedObjets(); }, 1000 * this.height / this.pixelsPerSecond );
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   219
        if(!externalRefresh) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   220
            this.refreshInterval = setInterval(function() {_this.move();}, 1000/this.framerate);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   221
        }
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
    this.stop = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   225
        clearInterval(this.cleanInterval);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   226
        if(!externalRefresh) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   227
            clearInterval(this.refreshInterval);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   228
        }
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
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   232
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   233
module.exports = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   234
    AnnotsRoll: AnnotsRoll,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   235
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   236
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   237
},{"lodash":"lodash","pixi":"pixi"}],3:[function(require,module,exports){
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
* js/annotstimeline
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   240
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   241
* annotstimeline basic component
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
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
var PIXI = require('pixi');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
var Utils = require('./utils.js');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
var _ = require('lodash');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   251
var defaultOptions = {
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
    logger: undefined,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
    intervalWidth: 10,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   254
    intervalHeight: 5,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   255
    maxCellHeight: 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   256
    radius: 300
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
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
function AnnotsTimeLine(options){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   261
    var _this = this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   262
    var opts = _(options).defaults(defaultOptions).value();
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   263
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   264
    this.container = new PIXI.DisplayObjectContainer();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   265
    this.container.x = opts.xInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   266
    this.container.y = opts.yInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   267
    this.container.width = opts.width;
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   268
    this.container.height = opts.height;
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   269
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   270
    this.timeBegin = opts.timeBegin;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   271
    this.timeEnd = opts.timeEnd;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   272
    this.duration = (this.timeEnd - this.timeBegin)/1000;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   273
    this.width = opts.width;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   274
    this.height = opts.height;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   275
    this.intervalHeight = opts.intervalHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   276
    this.intervalWidth = opts.intervalWidth;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   277
    this.maxCellHeight = opts.maxCellHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   278
    this.annotCategories = opts.annotCategories;
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   279
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   280
    this.circleX = opts.circleX || (this.width/2);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   281
    this.circleY = opts.circleY || (this.height/2);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   282
    this.radius = opts.radius;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   283
    this.perimeter = 2*Math.PI* this.radius;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   284
    this.intervalDuration = (this.intervalWidth * this.duration / this.perimeter);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   285
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   286
    var currentTime = this.timeBegin;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   287
    var totalIndex = Math.floor(this.perimeter/this.intervalWidth);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   288
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   289
    this.cells = []
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   290
    for (var i=0; i<(this.perimeter/this.intervalWidth) ; i++){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   291
    	this.cells[i] = [];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   292
    	this.cells[i].i = i;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   293
    	this.cells[i].totalAnnots = 0;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   294
    	this.cells[i].categories = {};
109
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
    	for (var category in this.annotCategories[0].colors){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   297
    		this.cells[i].categories[category] = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   298
				"count": 0,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   299
				"color": this.annotCategories[0].colors[category]
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   300
    		};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   301
    	}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   302
    }
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   303
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   304
    var ws = opts.ws;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   305
    var stageView = opts.stageView;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   306
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   307
    //draw the base - circle and line to locate the scene
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   308
    var graphics = new PIXI.Graphics();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   309
    graphics.lineStyle(2, 0x646464)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   310
    	.drawCircle(this.circleX, this.circleY, this.radius - 3)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   311
    	.lineStyle(1, 0xD7D7D7)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   312
    	.drawCircle(this.circleX, this.circleY, this.radius*2/3)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   313
    	.drawCircle(this.circleX, this.circleY, this.radius/3)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   314
    	.lineStyle(1, 0x646464)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   315
    	.moveTo(this.circleX, this.circleY - (this.radius/3)/2)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   316
    	.lineTo(this.circleX, this.circleY - this.radius - this.maxCellHeight - 10)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   317
    	.endFill()
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   318
    this.container.addChild(graphics);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   319
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   320
    //set time text
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   321
    //TODO : move this to annotsvizview
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   322
    var currentTimeText = new PIXI.Text("-- : -- : --", { font: '18pt Gothic Standard', fill: '#646464' });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   323
    currentTimeText.x = this.circleX - currentTimeText.width/2;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   324
    currentTimeText.y = this.circleY - currentTimeText.height/2;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   325
    this.container.addChild(currentTimeText);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   326
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   327
    stageView.registerComponent(this);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   328
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   329
    //Add Annotation to the TimeLine
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   330
    this.addAnnot = function(data){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   331
    	if (typeof(this.annotCategories[0].colors[data.content.category.code]) !== 'undefined'){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   332
    		var annotCode = data.content.category.code;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   333
    	} else {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   334
    		var annotCode = this.annotCategories[0].order[this.annotCategories[0].order.length -1];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   335
    	}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   336
    	var annotTime = Date.parse(data.ts);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   337
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   338
    	if (this.timeEnd > Date.parse(data.ts)){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   339
	    	var i = Math.floor((Date.parse(data.ts)-this.timeBegin)/(1000*this.intervalDuration));
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   340
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   341
			this.cells[i].categories[annotCode].count += 1;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   342
			this.cells[i].totalAnnots +=1;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   343
			this.redrawCell(this.cells[i], i);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   344
    	}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   345
    };
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   346
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   347
    this.initGraphics = function(cell){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   348
    	cell.graphics = new PIXI.Graphics();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   349
    	cell.graphics.position.x = this.circleX + this.radius * Math.sin(cell.i*(360/totalIndex)*(Math.PI/180));
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   350
    	cell.graphics.position.y = this.circleY - this.radius * Math.cos(cell.i*(360/totalIndex)*(Math.PI/180));
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   351
    	cell.graphics.rotation = (cell.i)*(360/totalIndex)*(Math.PI/180) + (360/(totalIndex*2))*(Math.PI/180);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   352
    	this.container.addChild(cell.graphics);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   353
    }
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   354
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   355
    this.initTimeTexts = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   356
	    var tBeg = new PIXI.Text(Utils.formatTime(this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   357
	    tBeg.x = this.circleX + 15;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   358
	    tBeg.y = this.circleY - this.radius - this.maxCellHeight - 10;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   359
	    this.container.addChild(tBeg);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   360
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   361
	    var tEnd = new PIXI.Text(Utils.formatTime(this.timeEnd), { font: '12pt Gothic Standard', fill: '#646464' });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   362
	    tEnd.x = this.circleX - 15 - tEnd.width;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   363
	    tEnd.y = this.circleY - this.radius - this.maxCellHeight - 10;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   364
	    this.container.addChild(tEnd);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   365
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   366
	    var t15 = new PIXI.Text(Utils.formatTime(((this.timeEnd - this.timeBegin)/4) + this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   367
	    t15.x = this.circleX + this.radius + this.maxCellHeight + 10 ;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   368
	    t15.y = this.circleY - t15.height;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   369
	    t15.rotation = Math.PI /2;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   370
	    this.container.addChild(t15);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   371
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   372
	    var t30 = new PIXI.Text(Utils.formatTime(((this.timeEnd - this.timeBegin)/2) + this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   373
	    t30.x = this.circleX - t30.width/2;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   374
	    t30.y = this.circleY + this.radius + this.maxCellHeight - 2;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   375
	    this.container.addChild(t30);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   376
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   377
	    var t45 = new PIXI.Text(Utils.formatTime(((this.timeEnd - this.timeBegin)*3/4) + this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   378
	    t45.x = this.circleX - this.radius - this.maxCellHeight - 10 ;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   379
	    t45.y = this.circleY + t15.height;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   380
	    t45.rotation = -Math.PI/2;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   381
	    this.container.addChild(t45);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   382
    }
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   383
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   384
    //Draw the cellule
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   385
    this.redrawCell = function(cell){
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   386
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   387
    	if (typeof(cell.graphics) === 'undefined'){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   388
    		this.initGraphics(cell);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   389
    	} else {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   390
    		cell.graphics.clear();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   391
    	}
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   392
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   393
    	var y = 0;
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   394
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   395
    	//Check if total height is higher than Max Cell Height
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   396
    	if ((cell.totalAnnots*this.intervalHeight) > this.maxCellHeight){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   397
    		var heightStep = this.maxCellHeight/cell.totalAnnots;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   398
    	} else {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   399
    		var heightStep = this.intervalHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   400
    	}
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   401
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   402
    	//Draw the rect depending on the height step calculated
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   403
    	for (var i=0; i< this.annotCategories[0].order.length; i++){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   404
    		var currentCode = this.annotCategories[0].order[i];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   405
			cell.graphics.beginFill(cell.categories[currentCode].color.replace("#", "0x"))
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   406
    			.drawRect(0, y, this.intervalWidth-1, -cell.categories[currentCode].count * heightStep)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   407
    			.endFill();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   408
    		y -= cell.categories[currentCode].count*heightStep;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   409
    	}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   410
    }
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   411
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   412
    this.init = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   413
    	ws.message(function(data) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   414
            _this.addAnnot(data);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   415
        });
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   416
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   417
    	this.initTimeTexts();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   418
    };
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   419
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   420
    this.updateTime = function(){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   421
    	currentTime += 1000;
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   422
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   423
        var nbSec = currentTime / 1000;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   424
        var hours = Math.floor( nbSec / 3600 ) % 24;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   425
        var minutes = Math.floor( nbSec / 60 ) % 60;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   426
        var seconds = Math.floor(nbSec % 60);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   427
        var timeStr = (hours < 10 ? '0' + hours : hours) + ':' + (minutes < 10 ? '0' + minutes : minutes) + ':' + (seconds  < 10 ? '0' + seconds : seconds);
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   428
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   429
        currentTimeText.setText(timeStr);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   430
    };
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   431
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   432
    var refreshTimeInterval;
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   433
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   434
    this.start = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   435
    	refreshTimeInterval = setInterval(function() {_this.updateTime();}, 1000);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   436
    };
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   437
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   438
    this.refresh = function() {
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   439
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   440
    };
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   441
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   442
    this.stop = function(){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   443
    	console.log(this.cells);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   444
    };
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
   445
108
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   446
    return this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   447
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   448
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   449
module.exports = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   450
	AnnotsTimeLine: AnnotsTimeLine
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   451
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   452
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   453
},{"./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
   454
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   455
* js/annotsvizview.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   456
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   457
* This is the starting point for your application.
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   458
* Take a look at http://browserify.org/ for more info
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   459
*/
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   460
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   461
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   462
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   463
var PIXI = require('pixi');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   464
var _ = require('lodash');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   465
var DoubleRoll = require('./doubleroll.js');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   466
var AnnotsTimeLine = require('./annotstimeline.js');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   467
var AnnotsRoll = require('./annotsroll.js');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   468
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   469
var defaultOptions = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   470
    xInit: 0,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   471
    yInit: 0,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   472
    width: 1024,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   473
    height: 768,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   474
    annotCategories: [{
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   475
        ts: 0,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   476
        colors: {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   477
            'ntm': '#CDC83F',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   478
            'iam': '#CDC83F',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   479
            'hip': '#CDC83F',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   480
            'hop': '#CDC83F',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   481
            'rock': '#DE8B53',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   482
            'rap': '#DE8B53',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   483
            'classic': '#DE8B53',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   484
            'drums': '#C5A3CA',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   485
            'guitar': '#C5A3CA',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   486
            'bass': '#79BB92',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   487
            'default': '#808080'
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   488
        },
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   489
        order: ['ntm', 'iam', 'hip', 'hop', 'rock', 'rap', 'classic', 'drums', 'guitar', 'bass', 'default']
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   490
    }]
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   491
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   492
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   493
function AnnotsVizView(options){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   494
	var _this = this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   495
    var opts = _(options).defaults(defaultOptions).value();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   496
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   497
    this.container = new PIXI.DisplayObjectContainer();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   498
    this.container.x = opts.xInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   499
    this.container.y = opts.yInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   500
	this.width = opts.width;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   501
	this.height= opts.height;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   502
    this.annotCategories = opts.annotCategories;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   503
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   504
	var wsPianoroll = opts.wsPianoroll;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   505
	var wsAnnot = opts.wsAnnot;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   506
	var stageView = opts.stageView;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   507
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   508
	stageView.registerComponent(this);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   509
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   510
	var timeLine = new AnnotsTimeLine.AnnotsTimeLine({
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   511
    	stageView : stageView,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   512
        logger: logger,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   513
        ws: new annotviz.WsWrapper(wsUriAnnotation, logger),
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   514
        xInit: 0,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   515
        yInit: 0,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   516
        width: 1024 - 200 - 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   517
        height: 768-200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   518
        timeBegin: Date.now(),
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   519
        timeEnd: Date.now() + 3000000,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   520
        intervalWidth: 6,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   521
        intervalHeight: 10,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   522
        maxCellHeight: 70,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   523
        radius: 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   524
        annotCategories: this.annotCategories
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   525
    });
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
	var doubleRollH = new DoubleRoll.DoubleRoll({
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   528
        stageView : stageView,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   529
    	logger: logger,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   530
        ws: wsPianoroll,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   531
        yInit: (this.height - 200),
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   532
        sceneHeight: 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   533
        pianorolls : [
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   534
            {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   535
                height: 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   536
                timeWidth: 10,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   537
                lineInterval: 5000,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   538
                noteHeight: 10
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   539
            },
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   540
        ]
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   541
    });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   542
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   543
	var doubleRollV = new DoubleRoll.DoubleRoll({
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   544
        stageView : stageView,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   545
    	logger: logger,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   546
        ws: wsPianoroll,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   547
        orientation: 'vertical',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   548
        sceneHeight: 768-200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   549
        pianorolls : [
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   550
            {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   551
                height: 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   552
                timeWidth: 60,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   553
                lineInterval: 5000,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   554
                noteHeight: 5,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   555
            },
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
    });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   558
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   559
	var annotsRoll = new AnnotsRoll.AnnotsRoll({
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   560
    	stageView : stageView,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   561
        logger: logger,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   562
        ws: wsAnnot,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   563
        parentContainer: doubleRollV.stage,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   564
        xInit: 1024 - 200 - 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   565
        yInit: 768-200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   566
        width: 200 + 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   567
        height: 768-200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   568
        widthRoll: 200,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   569
        framerate: doubleRollV.framerate,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   570
        pixelsPerSecond: Math.floor(1024 / 60),
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   571
        annotColors: this.annotCategories
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   572
    });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   573
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   574
	var limiters = new PIXI.Graphics()
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   575
		.lineStyle(1, 0x646464)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   576
		.moveTo(annotsRoll.container.x, annotsRoll.container.y)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   577
		.lineTo(annotsRoll.container.x, annotsRoll.container.y - annotsRoll.height)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   578
		.moveTo(annotsRoll.container.x + annotsRoll.widthRoll, annotsRoll.container.y)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   579
		.lineTo(annotsRoll.container.x + annotsRoll.widthRoll, annotsRoll.container.y - annotsRoll.height)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   580
		.moveTo(0, this.height - 200)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   581
		.lineTo(this.width, this.height - 200)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   582
		.drawRect(0, 0, this.width -1, this.height -1)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   583
		.beginFill(0xECECEC)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   584
		.drawRect(1024 - 200, 0, 200, 768-200)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   585
		.endFill();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   586
	this.container.addChild(limiters);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   587
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   588
//	var doubleRollV = new DoubleRoll.DoubleRoll({});
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   589
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   590
	this.init = function(){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   591
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   592
	}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   593
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   594
	this.start = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   595
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   596
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   597
    this.refresh = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   598
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   599
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   600
    this.stop = function(){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   601
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   602
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   603
    return this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   604
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   605
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   606
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   607
module.exports = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   608
	AnnotsVizView: AnnotsVizView
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   609
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   610
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   611
},{"./annotsroll.js":2,"./annotstimeline.js":3,"./doubleroll.js":5,"lodash":"lodash","pixi":"pixi"}],5:[function(require,module,exports){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   612
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   613
* scripts/doubleroll.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   614
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   615
* This is the starting point for your application.
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   616
* Take a look at http://browserify.org/ for more info
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   617
*/
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   618
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   619
/* global document: false */
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   620
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   621
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   622
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   623
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   624
var PIXI = require('pixi');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   625
var _ = require('lodash');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   626
var PianoRoll = require('./pianoroll.js');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   627
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   628
var defaultConfig = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   629
    orientation: 'horizontal',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   630
    logger: undefined,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   631
    sceneWidth: 1024,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   632
    pianorolls : [
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   633
      {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   634
        height: 435,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   635
        timeWidth: 10,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   636
        lineInterval: 5000,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   637
        noteHeight: undefined
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   638
      },
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   639
      {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   640
        height: 645,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   641
        timeWidth: 60,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   642
        lineInterval: 5000,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   643
        noteHeight: undefined
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   644
      },
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   645
    ],
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   646
    framerate: 25,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   647
    offsetMusic: false,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   648
    sceneBgColor: 0xFFFFFF,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   649
    lineColor: 0x444444,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   650
    lineFillColor: 0xFFFF00,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   651
    noteColors: [0xB90000, 0x4BDD71, 0xAF931E, 0x1C28BA, 0x536991],
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   652
    noteHeight: undefined,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   653
    zeroShift: 0.9,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   654
    timeWidth: 60,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   655
    lineInterval: 5000,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   656
//    wsUri: undefined,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   657
//    eventCode: undefined
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   658
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   659
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   660
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   661
function DoubleRoll(options) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   662
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   663
    var _this = this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   664
    var opts = _(options).defaults(defaultConfig).value();
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
    var orientation = opts.orientation;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   667
    var isHorizontal = (orientation !== 'vertical');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   668
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   669
    this.logger = opts.logger;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   670
    this.lineColor = opts.lineColor;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   671
    this.lineFillColor = opts.lineFillColor;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   672
    this.framerate = opts.framerate;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   673
    this.offsetMusic = opts.offsetMusic;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   674
    this.noteColors = opts.noteColors;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   675
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   676
    var noteHeight = opts.noteHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   677
    var sceneBgColor = opts.sceneBgColor;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   678
    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
   679
    var timeWidth = opts.timeWidth;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   680
    var lineInterval = opts.lineInterval;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   681
    var offsetMusic = opts.offsetMusic;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   682
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   683
    var sceneWidth = opts.sceneWidth;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   684
    var stageView = opts.stageView;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   685
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   686
    var zeroShift = opts.zeroShift;
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
    var ws = opts.ws;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   689
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   690
    var colorsReg = {};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   691
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   692
    this.container = new PIXI.DisplayObjectContainer();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   693
    this.container.x = Math.floor(sceneWidth*zeroShift);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   694
    this.container.y = 0;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   695
    
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   696
    stageView.registerComponent(this);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   697
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   698
    var pianorollList = [];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   699
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   700
    var pianorollOptions = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   701
        parentContainer: this.container,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   702
        orientation: orientation,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   703
        xInit: 0,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   704
        width: sceneWidth,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   705
        noteColors: this.noteColors,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   706
        colorsReg: colorsReg,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   707
        lineColor: this.lineColor,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   708
        lineInterval: lineInterval,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   709
        offsetMusic: offsetMusic,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   710
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   711
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   712
    var yInit = opts.yInit || 0;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   713
    var linesDown = true;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   714
    _(opts.pianorolls).forEach(function(prDef, i) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   715
        var prNoteHeight = noteHeight || prDef.noteHeight || prDef.height / 128;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   716
        var prTimeWidth = prDef.timeWidth || timeWidth;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   717
        pianorollList.push(new PianoRoll(_({
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   718
            yInit: yInit,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   719
            height: prDef.height,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   720
            linesDown: linesDown,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   721
            pixelsPerSecond: Math.floor(sceneWidth / prTimeWidth),
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   722
            noteHeight: prNoteHeight,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   723
            lineInterval: prDef.lineInterval
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   724
        }).defaults(pianorollOptions).value()));
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   725
        yInit += prDef.height;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   726
        linesDown = !linesDown;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   727
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   728
        if(i<(opts.pianorolls.length-1)) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   729
            var lineGraphics = new PIXI.Graphics()
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   730
                .beginFill(_this.lineFillColor)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   731
                .lineStyle(1, _this.lineColor)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   732
                .moveTo(Math.floor(sceneWidth*zeroShift), yInit)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   733
                .lineTo(-sceneWidth - Math.floor(sceneWidth*zeroShift), yInit)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   734
                .endFill();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   735
            _this.container.addChild(lineGraphics);
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
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   739
    if(!isHorizontal) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   740
        this.container.rotation = Math.PI/2;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   741
        this.container.y = sceneHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   742
        this.container.x = sceneWidth;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   743
    }
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
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   746
    this.init = function() {
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
    	ws.message(function(data) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   749
            _this.addNotes(data);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   750
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   751
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
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   755
    this.addNotes = function(data) {
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
        pianorollList.forEach(function(c) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   758
            c.addNoteRaw(data);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   759
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   760
    };
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
    this.refresh = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   763
        pianorollList.forEach(function(c) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   764
            c.move();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   765
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   766
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   767
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   768
    // Init page and intervals
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   769
    var startTs;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   770
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   771
    this.start = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   772
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   773
        startTs = Date.now();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   774
        pianorollList.forEach(function(c) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   775
            c.start();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   776
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   777
    };
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
    this.stop = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   780
    	
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   781
        pianorollList.forEach(function(c) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   782
            c.stop();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   783
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   784
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   785
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   786
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   787
    this.log = function(m) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   788
        if(this.logger) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   789
            this.logger.log(m);
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
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   792
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   793
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   794
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   795
    return this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   796
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   797
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   798
module.exports = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   799
    DoubleRoll: DoubleRoll
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   800
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   801
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   802
},{"./pianoroll.js":7,"lodash":"lodash","pixi":"pixi"}],6:[function(require,module,exports){
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
* js/wswrapper.js
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
* simple logger service
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
*/
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   809
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   810
/* global document: false */
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   811
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   812
'use strict';
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
function HtmlLogger(doLog, container) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   815
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   816
    var logContainer = container;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   817
    if(typeof(container) === 'string') {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   818
        logContainer = document.getElementById(container);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   819
    }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   820
    if(!doLog) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   821
        document.body.removeChild(logContainer);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   822
        logContainer = undefined;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   823
    }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   824
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   825
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   826
    this.log = function(msg) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   827
        if(doLog && logContainer) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   828
            logContainer.innerHTML += msg + '\n';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   829
            logContainer.scrollTop = logContainer.scrollHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   830
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   831
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   832
}
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
function ConsoleLogger(doLog) {
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
    this.log = function(msg) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   837
        if(doLog) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   838
            console.log(msg);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   839
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   840
    }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   841
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   842
}
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
module.exports = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   845
    HtmlLogger: HtmlLogger,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   846
    ConsoleLogger: ConsoleLogger
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   847
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   848
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   849
},{}],7:[function(require,module,exports){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   850
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   851
* js/pianoroll.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   852
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   853
* pianoroll basic component
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   854
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   855
*/
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
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   858
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   859
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   860
var PIXI = require('pixi');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   861
var randomColor = require('randomColor');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   862
var _ = require('lodash');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   863
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   864
var NTP_EPOCH_DELTA = 2208988800; //c.f. RFC 868
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   865
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   866
function PianoRoll(options) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   867
    var _this = this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   868
    this.container = new PIXI.DisplayObjectContainer();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   869
    this.container.x = options.xInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   870
    this.container.y = options.yInit;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   871
    options.parentContainer.addChild(this.container);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   872
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   873
    var orientation = options.orientation;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   874
    var isHorizontal = (orientation !== 'vertical');
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
    this.linesDown = options.linesDown;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   877
    this.height = options.height;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   878
    this.pixelsPerSecond = options.pixelsPerSecond;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   879
    this.width = options.width;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   880
    this.noteColors = options.noteColors;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   881
    this.colorsReg = options.colorsReg || {};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   882
    this.lineColor = options.lineColor;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   883
    this.lineInterval = options.lineInterval;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   884
    this.offsetMusic = options.offsetMusic || false;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   885
    this.noteHeight = options.noteHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   886
    this.noteDict = {};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   887
    this.startTs = options.startTs || Date.now();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   888
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   889
    var started = false;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   890
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   891
    var isHidden = function(child) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   892
        // TODO: the origin point is an approximation. Should refine this
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   893
        var globalPos = child.toGlobal(new PIXI.Point(0,0));
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   894
        return ((globalPos.x + child.width) < 0) || ((globalPos.y + child.height) < 0) ;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   895
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   896
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   897
    //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
   898
    this.getColor = function(canal) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   899
        var color = this.colorsReg[canal];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   900
        if(typeof(color) === 'undefined') {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   901
            var colorsRegSize = Object.keys(this.colorsReg).length;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   902
            if(colorsRegSize < this.noteColors.length) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   903
                color = this.colorsReg[canal] = this.noteColors[colorsRegSize];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   904
            }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   905
            else {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   906
                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
   907
            }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   908
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   909
        return color;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   910
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   911
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   912
    this.getNoteRect = function(x, y, color, alpha, width, height) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   913
        var graphics = new PIXI.Graphics();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   914
        graphics.beginFill(color, alpha);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   915
        graphics.drawRect(0, 0, width, height);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   916
        graphics.endFill();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   917
        graphics.x = x;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   918
        graphics.y = y;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   919
        graphics.width = width;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   920
        graphics.height = height;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   921
        return graphics;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   922
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   923
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   924
    this.addNoteRaw = function(data) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   925
    	console.log(data);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   926
        var note = data.content[3];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   927
        var velocity = data.content[4];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   928
        var ts = (data.content[0] - NTP_EPOCH_DELTA)*1000;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   929
        var channel = data.content[2];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   930
        var sessionTs = data.content[1];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   931
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   932
        this.addNote(note, ts, sessionTs, velocity, channel, 0);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   933
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   934
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   935
    this.addNote = function(note, startTime, sessionTs, velocity, channel, duration) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   936
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   937
        var ts = startTime;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   938
        if(this.offsetMusic) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   939
            ts = this.startTs + sessionTs;
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
        var noteDuration = duration;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   943
        var noteVelocity = velocity;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   944
        var graphics;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   945
        if(!duration) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   946
            if(typeof this.noteDict[channel]==='undefined'){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   947
                this.noteDict[channel] = {};
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
            if(velocity===0) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   950
                if(typeof this.noteDict[channel][note] !== 'undefined') {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   951
                    var noteDef = this.noteDict[channel][note];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   952
                    delete this.noteDict[channel][note];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   953
                    noteDuration = sessionTs - noteDef.sessionTs;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   954
                    graphics = noteDef.graphics;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   955
                    noteVelocity = noteDef.velocity;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   956
                    ts = noteDef.ts;
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
            }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   959
            else {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   960
                noteDuration = Date.now() - ts;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   961
                this.noteDict[channel][note] = { ts: ts, velocity: velocity, sessionTs: sessionTs};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   962
            }
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
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   965
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   966
        if(!this.offsetMusic || velocity===0) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   967
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   968
            var width = noteDuration * this.pixelsPerSecond / 1000;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   969
            if(!graphics) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   970
                var x = (ts-this.startTs) * this.pixelsPerSecond / 1000;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   971
                if((x+width) <  (Math.abs(this.container.x) - this.width)) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   972
                    // not visible. do nothing
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   973
                    return;
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
                var y = Math.floor((128-note+0.5) * this.height / 128 - (this.noteHeight/2));
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   976
                var color = this.getColor(channel);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   977
                var alpha = (noteVelocity / 128);
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
                graphics = this.getNoteRect(x, y, color, alpha, width, this.noteHeight);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   980
                this.container.addChild(graphics);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   981
            }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   982
            else {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   983
                graphics.width = width;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   984
            }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   985
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   986
            if(!duration && velocity) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   987
                this.noteDict[channel][note].graphics = graphics;
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
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   990
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   991
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   992
    this.addLine = function(ts){
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
        if(typeof(ts) === 'undefined') {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   995
            ts = new Date();
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
        var x = -this.container.x;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   998
        var y = this.linesDown ? this.height - 20 : 0;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
   999
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1000
        var graphics = new PIXI.Graphics()
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1001
            .beginFill(0xFFFF00)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1002
            .lineStyle(1, this.lineColor)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1003
            .moveTo(0, 0)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1004
            .lineTo(0, 20)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1005
            .endFill();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1006
        graphics.x = x;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1007
        graphics.y = y;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1008
        this.container.addChild(graphics);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1009
        // Add text
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1010
        //var totalSec = lineNb * this.lineInterval / 1000;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1011
        var hours = ts.getHours();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1012
        var minutes =ts.getMinutes();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1013
        var seconds = ts.getSeconds();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1014
        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
  1015
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1016
        var fontObj = { font: '10pt Arial', fill: '#444444' };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1017
        var t = new PIXI.Text(timeStr, fontObj);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1018
        if(isHorizontal) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1019
            t.x = x + 2;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1020
            t.y = this.linesDown ? this.height - 15 : 2;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1021
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1022
        else {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1023
            t.rotation = -Math.PI/2;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1024
            t.x = x ;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1025
            t.y = this.linesDown ? this.height - 2 : t.width + 2;
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
        this.container.addChild(t);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1028
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1029
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1030
    this.moveTo = function(diffTime){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1031
        var oldX = this.container.x;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1032
        this.container.x = Math.floor(diffTime*this.pixelsPerSecond);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1033
        var deltaX = Math.abs(oldX-this.container.x);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1034
        _.forOwn(this.noteDict, function(channelDict) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1035
            _.forOwn(channelDict, function(noteDef) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1036
                if(noteDef.graphics) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1037
                    noteDef.graphics.width = noteDef.graphics.width + deltaX;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1038
                }
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
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1041
    };
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.move = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1044
        var diff = (this.startTs - Date.now())/1000;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1045
        this.moveTo(diff);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1046
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1047
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1048
    this.removePassedObjets = function(){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1049
        var childrenToRemove = [];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1050
        _(_this.container.children).forEach(function(child) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1051
            return typeof(child) === 'undefined' ||
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1052
                (isHidden(child) && childrenToRemove.push(child));
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1053
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1054
        childrenToRemove.forEach(function(child) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1055
            _this.container.removeChild(child);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1056
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1057
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1058
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1059
    this.start = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1060
        if(!started) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1061
            this.startTs = Date.now();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1062
            this.addLine();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1063
            started = true;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1064
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1065
        this.verticalLinesInterval = setInterval(function() { _this.addLine(); }, this.lineInterval);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1066
        this.cleanInterval = setInterval(function () { _this.removePassedObjets(); }, 1000 * this.width / this.pixelsPerSecond );
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
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1069
    this.stop = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1070
        //window.clearInterval(this.moveInterval);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1071
        clearInterval(this.verticalLinesInterval);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1072
        clearInterval(this.cleanInterval);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1073
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1074
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
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1077
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1078
module.exports = PianoRoll;
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
},{"lodash":"lodash","pixi":"pixi","randomColor":"randomColor"}],8:[function(require,module,exports){
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
* scripts/stageview.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1083
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1084
* This is the starting point for your application.
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1085
* Take a look at http://browserify.org/ for more info
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1086
*/
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1087
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1088
/* global document: false */
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1089
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1090
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1091
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1092
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1093
var PIXI = require('pixi');
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1094
var _ = require('lodash');
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
var defaultConfig = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1097
    externalRefresh: false,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1098
    logger: undefined,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1099
    sceneWidth: 1024,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1100
    sceneHeight: 768,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1101
    framerate: 25,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1102
    sceneBgColor: 0xFFFFFF,
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1103
    canvasContainer: 'canvasContainer',
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1104
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1105
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1106
function StageView(options) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1107
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1108
    var _this = this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1109
    var opts = _(options).defaults(defaultConfig).value();
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
    var externalRefresh = opts.externalRefresh;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1112
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1113
    this.logger = opts.logger;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1114
    this.framerate = opts.framerate;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1115
    var sceneBgColor = opts.sceneBgColor;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1116
    var sceneWidth = opts.sceneWidth;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1117
    var sceneHeight = opts.sceneHeight;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1118
    var canvasContainer = opts.canvasContainer;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1119
    var timeContainer = [];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1120
    var components = []; 
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1121
    
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1122
    //create an new instance of a pixi stage
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1123
    this.stage = new PIXI.Stage(sceneBgColor);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1124
    //create a renderer instance.
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1125
    var renderer = PIXI.autoDetectRenderer(sceneWidth, sceneHeight);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1126
    	
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1127
    this.init = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1128
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1129
        if(typeof(canvasContainer) === 'string') {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1130
            canvasContainer = document.getElementById(canvasContainer);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1131
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1132
        if(typeof(timeContainer) === 'string') {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1133
            timeContainer = document.getElementById(timeContainer);
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
        canvasContainer.appendChild(renderer.view);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1137
        
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1138
        components.forEach(function(c){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1139
    		c.init();
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
    this.registerTimeContainer = function(container) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1144
    	timeContainer.push(container);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1145
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1146
    
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1147
    this.registerComponent = function(component) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1148
    	components.push(component);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1149
    	this.stage.addChild(component.container);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1150
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1151
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1152
    this.refresh = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1153
    	components.forEach(function(c){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1154
    		c.refresh();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1155
    	});
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1156
        renderer.render(this.stage);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1157
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1158
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1159
    // Init page and intervals
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1160
    var refreshInterval;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1161
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1162
    this.start = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1163
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1164
        if(!externalRefresh) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1165
            refreshInterval = setInterval(function() {_this.refresh();}, 1000/this.framerate);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1166
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1167
        
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1168
        components.forEach(function(c){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1169
    		c.start();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1170
    	});
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1171
    };
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
    this.stop = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1174
        if(!externalRefresh) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1175
            clearInterval(refreshInterval);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1176
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1177
        clearInterval(refreshTimeInterval);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1178
        
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1179
        components.forEach(function(c){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1180
    		c.stop();
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1181
    	});
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1182
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1183
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1184
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1185
    this.log = function(m) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1186
        if(this.logger) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1187
            this.logger.log(m);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1188
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1189
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1190
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1191
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1192
    return this;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1193
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1194
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1195
module.exports = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1196
    StageView: StageView
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1197
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1198
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1199
},{"lodash":"lodash","pixi":"pixi"}],9:[function(require,module,exports){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1200
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1201
* js/utils.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1202
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1203
* basic tools
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1204
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1205
*/
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
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1208
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1209
function formatTime (ts) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1210
	var hours = Math.floor( (ts/1000) / 3600 ) % 24;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1211
	var minutes = Math.floor( (ts/1000) / 60 ) % 60;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1212
	var seconds = Math.floor( (ts/1000) % 60);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1213
	return ((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
  1214
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1215
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1216
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1217
module.exports = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1218
	formatTime: formatTime
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1219
};
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1220
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1221
},{}],10:[function(require,module,exports){
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1222
/**
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1223
* js/wswrapper.js
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1224
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1225
* simple webservice wrapper to register callbacks on onmessage
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1226
*
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1227
*/
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1228
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1229
/* global WebSocket: false */
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1230
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1231
'use strict';
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1232
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1233
function WsWrapper(wsurl, logger) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1234
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1235
    var url = wsurl;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1236
    var sock = new WebSocket(url);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1237
    var loggerObj = logger;
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
    var log = function(msg) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1240
        if(loggerObj) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1241
            loggerObj.log(msg);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1242
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1243
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1244
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1245
    var handlers = [];
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1246
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1247
    sock.onopen = function() {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1248
        log('Connected to ' + url);
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
    sock.onclose = function(e) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1252
        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
  1253
        sock = null;
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1254
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1255
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1256
    sock.onmessage = function(e) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1257
        log('received ' + e.data);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1258
        var data = JSON.parse(e.data);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1259
        handlers.forEach(function(handler) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1260
            handler(data);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1261
        });
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1262
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1263
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1264
    this.message = function(handler) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1265
        if(handler) {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1266
            handlers.push(handler);
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1267
        }
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1268
    };
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1269
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1270
}
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1271
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1272
module.exports = {
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1273
    WsWrapper: WsWrapper
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1274
};
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
},{}]},{},[1])(1)
082b64a5c699 add vizualizations to server
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1277
});
109
8546e2181a73 correct color codes sent by client
ymh <ymh.work@gmail.com>
parents: 108
diff changeset
  1278
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9icm93c2VyaWZ5L25vZGVfbW9kdWxlcy9icm93c2VyLXBhY2svX3ByZWx1ZGUuanMiLCIuL2FwcC9qcy9tYWluLmpzIiwiL1VzZXJzL3ltaC9kZXYvcHJvamVjdHMvbW9ucy9kZXYvY2xpZW50L2Fubm90dml6L2FwcC9qcy9hbm5vdHNyb2xsLmpzIiwiL1VzZXJzL3ltaC9kZXYvcHJvamVjdHMvbW9ucy9kZXYvY2xpZW50L2Fubm90dml6L2FwcC9qcy9hbm5vdHN0aW1lbGluZS5qcyIsIi9Vc2Vycy95bWgvZGV2L3Byb2plY3RzL21vbnMvZGV2L2NsaWVudC9hbm5vdHZpei9hcHAvanMvYW5ub3Rzdml6dmlldy5qcyIsIi9Vc2Vycy95bWgvZGV2L3Byb2plY3RzL21vbnMvZGV2L2NsaWVudC9hbm5vdHZpei9hcHAvanMvZG91Ymxlcm9sbC5qcyIsIi9Vc2Vycy95bWgvZGV2L3Byb2plY3RzL21vbnMvZGV2L2NsaWVudC9hbm5vdHZpei9hcHAvanMvbG9nZ2VyLmpzIiwiL1VzZXJzL3ltaC9kZXYvcHJvamVjdHMvbW9ucy9kZXYvY2xpZW50L2Fubm90dml6L2FwcC9qcy9waWFub3JvbGwuanMiLCIvVXNlcnMveW1oL2Rldi9wcm9qZWN0cy9tb25zL2Rldi9jbGllbnQvYW5ub3R2aXovYXBwL2pzL3N0YWdldmlldy5qcyIsIi9Vc2Vycy95bWgvZGV2L3Byb2plY3RzL21vbnMvZGV2L2NsaWVudC9hbm5vdHZpei9hcHAvanMvdXRpbHMuanMiLCIvVXNlcnMveW1oL2Rldi9wcm9qZWN0cy9tb25zL2Rldi9jbGllbnQvYW5ub3R2aXovYXBwL2pzL3dzd3JhcHBlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTtBQ0FBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQzNCQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQzdNQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQ3ROQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUM1SkE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FDN0xBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQzdDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQ3JPQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUNySEE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQ3BCQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJmaWxlIjoiZ2VuZXJhdGVkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXNDb250ZW50IjpbIihmdW5jdGlvbiBlKHQsbixyKXtmdW5jdGlvbiBzKG8sdSl7aWYoIW5bb10pe2lmKCF0W29dKXt2YXIgYT10eXBlb2YgcmVxdWlyZT09XCJmdW5jdGlvblwiJiZyZXF1aXJlO2lmKCF1JiZhKXJldHVybiBhKG8sITApO2lmKGkpcmV0dXJuIGkobywhMCk7dmFyIGY9bmV3IEVycm9yKFwiQ2Fubm90IGZpbmQgbW9kdWxlICdcIitvK1wiJ1wiKTt0aHJvdyBmLmNvZGU9XCJNT0RVTEVfTk9UX0ZPVU5EXCIsZn12YXIgbD1uW29dPXtleHBvcnRzOnt9fTt0W29dWzBdLmNhbGwobC5leHBvcnRzLGZ1bmN0aW9uKGUpe3ZhciBuPXRbb11bMV1bZV07cmV0dXJuIHMobj9uOmUpfSxsLGwuZXhwb3J0cyxlLHQsbixyKX1yZXR1cm4gbltvXS5leHBvcnRzfXZhciBpPXR5cGVvZiByZXF1aXJlPT1cImZ1bmN0aW9uXCImJnJlcXVpcmU7Zm9yKHZhciBvPTA7bzxyLmxlbmd0aDtvKyspcyhyW29dKTtyZXR1cm4gc30pIiwiLyoqXG4gKiBzY3JpcHRzL21haW4uanNcbiAqXG4gKiBUaGlzIGlzIHRoZSBzdGFydGluZyBwb2ludCBmb3IgeW91ciBhcHBsaWNhdGlvbi5cbiAqIFRha2UgYSBsb29rIGF0IGh0dHA6Ly9icm93c2VyaWZ5Lm9yZy8gZm9yIG1vcmUgaW5mb1xuICovXG5cbid1c2Ugc3RyaWN0JztcblxudmFyIGRvdWJsZXJvbGwgPSByZXF1aXJlKCcuL2RvdWJsZXJvbGwnKTtcbnZhciBhbm5vdHNyb2xsID0gcmVxdWlyZSgnLi9hbm5vdHNyb2xsJyk7XG52YXIgYW5ub3RzdGltZWxpbmUgPSByZXF1aXJlKCcuL2Fubm90c3RpbWVsaW5lJyk7XG52YXIgYW5ub3Rzdml6dmlldyA9IHJlcXVpcmUoJy4vYW5ub3Rzdml6dmlldycpO1xudmFyIHN0YWdldmlldyA9IHJlcXVpcmUoJy4vc3RhZ2V2aWV3Jyk7XG52YXIgd3N3cmFwcGVyID0gcmVxdWlyZSgnLi93c3dyYXBwZXInKTtcbnZhciBsb2dnZXIgPSByZXF1aXJlKCcuL2xvZ2dlcicpO1xuXG52YXIgXyA9IHJlcXVpcmUoJ2xvZGFzaCcpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IF8oe30pXG4gICAgLmV4dGVuZChkb3VibGVyb2xsKVxuICAgIC5leHRlbmQoYW5ub3Rzcm9sbClcbiAgICAuZXh0ZW5kKGFubm90c3RpbWVsaW5lKVxuICAgIC5leHRlbmQoYW5ub3Rzdml6dmlldylcbiAgICAuZXh0ZW5kKHN0YWdldmlldylcbiAgICAuZXh0ZW5kKHdzd3JhcHBlcilcbiAgICAuZXh0ZW5kKGxvZ2dlcilcbiAgICAudmFsdWUoKTsiLCIvKipcbioganMvYW5ub3RzUm9sbC5qc1xuKlxuKiBhbm5vdHNSb2xsIGJhc2ljIGNvbXBvbmVudFxuKlxuKi9cblxuJ3VzZSBzdHJpY3QnO1xuXG52YXIgUElYSSA9IHJlcXVpcmUoJ3BpeGknKTtcbnZhciBfID0gcmVxdWlyZSgnbG9kYXNoJyk7XG5cbnZhciBERUZBVUxUX0FOTk9UX0NPTE9SID0gJyNiYWJhYmEnO1xuXG52YXIgZGVmYXVsdEFubm90U3R5bGVzID0ge1xuICAgICdsYWJlbCc6IHsgZm9udDogJzE2cHQgQXJpYWwgQm9sZCcsIGZpbGw6ICcjNjVBOTU0Jywgd29yZFdyYXA6IHRydWV9LFxuICAgICd0ZXh0JyA6IHsgZm9udDogJzEycHQgQXJpYWwgUmVndWxhcicsIGZpbGw6ICcjNDQ0NDQ0Jywgd29yZFdyYXA6IHRydWV9LFxuICAgICd1c2VyJyA6IHsgZm9udDogJzE0cHQgQXJpYWwgcmVndWxhcicsIGZpbGw6ICcjNjY2NjY2JyB9LFxufTtcblxudmFyIGRlZmF1bHRPcHRpb25zID0ge1xuICAgIGV4dGVybmFsUmVmcmVzaDogZmFsc2UsXG4gICAgZGVmYXVsdENvbG9yOiBERUZBVUxUX0FOTk9UX0NPTE9SLFxuICAgIGFubm90U3R5bGVzOiBkZWZhdWx0QW5ub3RTdHlsZXNcbn07XG5cbmZ1bmN0aW9uIEFubm90c1JvbGwob3B0aW9ucykge1xuXG4vL3BhcmVudENvbnRhaW5lciwgeEluaXQsIHlJbml0LCB3aWR0aCwgaGVpZ2h0LCB3aWR0aFJvbGwsIHBpeGVsc1BlclNlY29uZCwgYW5ub3RDb2xvcnNcbiAgICB2YXIgX3RoaXMgPSB0aGlzO1xuICAgIHZhciBvcHRzID0gXyhvcHRpb25zKS5kZWZhdWx0cyhkZWZhdWx0T3B0aW9ucykudmFsdWUoKTtcblxuXG4gICAgdGhpcy5jb250YWluZXIgPSBuZXcgUElYSS5EaXNwbGF5T2JqZWN0Q29udGFpbmVyKCk7XG4gICAgdGhpcy5jb250YWluZXIueCA9IG9wdHMueEluaXQ7XG4gICAgdGhpcy5jb250YWluZXIueSA9IG9wdHMueUluaXQ7XG4gICAgdGhpcy5jb250YWluZXIud2lkdGggPSBvcHRzLndpZHRoO1xuXG4gICAgdGhpcy5oZWlnaHQgPSBvcHRzLmhlaWdodDtcbiAgICB0aGlzLndpZHRoID0gb3B0cy53aWR0aDtcbiAgICB0aGlzLndpZHRoUm9sbCA9IG9wdHMud2lkdGhSb2xsO1xuICAgIHRoaXMucGl4ZWxzUGVyU2Vjb25kID0gb3B0cy5waXhlbHNQZXJTZWNvbmQ7XG4gICAgdGhpcy5hbm5vdENvbG9ycyA9IG9wdHMuYW5ub3RDb2xvcnM7XG4gICAgdGhpcy5zdGFydFRzID0gb3B0aW9ucy5zdGFydFRzIHx8IERhdGUubm93KCk7XG5cbiAgICB2YXIgeUluaXQgPSBvcHRzLnlJbml0O1xuICAgIHZhciBhbm5vdFN0eWxlcyA9IF8ob3B0cy5hbm5vdFN0eWxlcykuZGVmYXVsdHMoZGVmYXVsdEFubm90U3R5bGVzKS52YWx1ZSgpO1xuICAgIGZvcih2YXIgc3R5bGUgaW4gYW5ub3RTdHlsZXMpIHtcbiAgICBcdGlmIChhbm5vdFN0eWxlc1tzdHlsZV0ud29yZFdyYXAgPT09IHRydWUpe1xuICAgIFx0XHRhbm5vdFN0eWxlc1tzdHlsZV0ud29yZFdyYXBXaWR0aCA9IHRoaXMud2lkdGhSb2xsO1xuICAgIFx0fVxuICAgIH1cbiAgICB2YXIgc3RhcnRlZCA9IGZhbHNlO1xuICAgIHZhciB3cyA9IG9wdHMud3M7XG4gICAgdmFyIGV4dGVybmFsUmVmcmVzaCA9IG9wdHMuZXh0ZXJuYWxSZWZyZXNoO1xuICAgIHZhciBzdGFnZVZpZXcgPSBvcHRzLnN0YWdlVmlldztcblxuICAgIHN0YWdlVmlldy5yZWdpc3RlckNvbXBvbmVudCh0aGlzKTtcblxuICAgIHZhciBpc0hpZGRlbiA9IGZ1bmN0aW9uKGNoaWxkKSB7XG4gICAgICAgIC8vIFRPRE86IHRoZSBvcmlnaW4gcG9pbnQgaXMgYW4gYXBwcm94aW1hdGlvbi4gU2hvdWxkIHJlZmluZSB0aGlzXG4gICAgICAgIHZhciBnbG9iYWxQb3MgPSBjaGlsZC50b0dsb2JhbChuZXcgUElYSS5Qb2ludCgwLDApKTtcbiAgICAgICAgcmV0dXJuICgoZ2xvYmFsUG9zLnggKyBjaGlsZC53aWR0aCkgPCAwKSB8fCAoKGdsb2JhbFBvcy55ICsgY2hpbGQuaGVpZ2h0KSA8IDApIDtcbiAgICB9O1xuXG4gICAgdGhpcy5hZGRBbm5vdHMgPSBmdW5jdGlvbihkYXRhKSB7XG5cbiAgICAgICAgLy92YXIgdGl0bGUgPSBkYXRhLmNvbnRlbnQuY2F0ZWdvcnkubGFiZWw7XG4gICAgICAgIC8vdmFyIHVzZXIgPSBkYXRhLmNvbnRlbnQudXNlcjtcbiAgICAgICAgLy9UZXN0IGNhdCBhbmQgY29sb3JcbiAgICAgICAgLy92YXIgY29sb3JBbm5vdCA9IDB4NjVBOTU0O1xuICAgICAgICB2YXIgY2F0ZWdvcnkgPSBkYXRhLmNvbnRlbnQuY2F0ZWdvcnkubGFiZWwsXG4gICAgICAgICAgICB0ZXh0ICAgICA9IGRhdGEuY29udGVudC50ZXh0LFxuICAgICAgICAgICAgdXNlciAgICAgPSBkYXRhLmNvbnRlbnQudXNlcixcbiAgICAgICAgICAgIHRzICAgICAgID0gRGF0ZS5wYXJzZShkYXRhLnRzKSxcbiAgICAgICAgICAgIGNvbG9yICAgID0gZGF0YS5jb250ZW50LmNvbG9yIHx8IHRoaXMuZ2V0Q29sb3IodHMsIGRhdGEuY29udGVudC5jYXRlZ29yeS5jb2RlKTtcblxuICAgICAgICB0aGlzLmFkZEFubm90KGNhdGVnb3J5LCB0ZXh0LCB1c2VyLCBjb2xvciwgdHMpO1xuICAgIH07XG5cbiAgICB0aGlzLmdldENvbG9yID0gZnVuY3Rpb24odHMsIGNvZGUpIHtcbiAgICAgICAgdmFyIGNvbG9yc0RlZjtcbiAgICAgICAgXyh0aGlzLmFubm90Q29sb3JzKS5lYWNoUmlnaHQoZnVuY3Rpb24oY2RlZikge1xuICAgICAgICAgICAgY29uc29sZS5sb2coXCJjRGVmXCIsIGNkZWYpO1xuICAgICAgICAgICAgY29uc29sZS5sb2coXCJjRGVmIHRzXCIsIGNkZWYudHMsIHRzKTtcbiAgICAgICAgICAgIGlmKGNkZWYudHMgPCB0cykge1xuICAgICAgICAgICAgICAgIGNvbG9yc0RlZiA9IGNkZWYuY29sb3JzO1xuICAgICAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgICAgIHZhciByZXNDb2xvcjtcbiAgICAgICAgY29uc29sZS5sb2coXCJjb2xvcnNEZWZcIiwgY29sb3JzRGVmKTtcbiAgICAgICAgaWYoY29sb3JzRGVmKSB7XG4gICAgICAgICAgICByZXNDb2xvciA9IGNvbG9yc0RlZltjb2RlXTtcbiAgICAgICAgfVxuICAgICAgICBpZighcmVzQ29sb3IpIHtcbiAgICAgICAgICAgIHJlc0NvbG9yID0gREVGQVVMVF9BTk5PVF9DT0xPUjtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gcmVzQ29sb3I7XG4gICAgfVxuXG4gICAgdGhpcy5hZGRBbm5vdCA9IGZ1bmN0aW9uKGNhdGVnb3J5LCB0ZXh0LCB1c2VyLCBjYXRDb2xvciwgdHMpe1xuXG4gICAgICAgIHZhciBjb2xvciA9IGNhdENvbG9yID8gY2F0Q29sb3IgOiBERUZBVUxUX0FOTk9UX0NPTE9SO1xuICAgICAgICB2YXIgeCA9IDA7XG4gICAgICAgIHZhciB5ID0gKHRzLXRoaXMuc3RhcnRUcykgKiB0aGlzLnBpeGVsc1BlclNlY29uZCAvIDEwMDAgKyB5SW5pdDtcblxuICAgICAgICB2YXIgY29sb3JIZXggPSBwYXJzZUludChjb2xvci5yZXBsYWNlKC9eIy8sICcnKSwgMTYpO1xuXG4gICAgICAgIHZhciBncmFwaGljcyA9IG5ldyBQSVhJLkdyYXBoaWNzKClcbiAgICAgICAgICAgIC5iZWdpbkZpbGwoY29sb3JIZXgpXG4gICAgICAgICAgICAuZHJhd1JlY3QoeCwgeSwgMTAsIDMpXG4gICAgICAgICAgICAuZW5kRmlsbCgpO1xuXG4gICAgICAgIHRoaXMuY29udGFpbmVyLmFkZENoaWxkKGdyYXBoaWNzKTtcblxuICAgICAgICB2YXIgdGV4dEhlaWdodCA9IDA7XG4gICAgICAgIHZhciBjYXRMYWJlbCA9IG5ldyBQSVhJLlRleHQoXG4gICAgICAgICAgICBjYXRlZ29yeSxcbiAgICAgICAgICAgIF8oYW5ub3RTdHlsZXMubGFiZWwpLmV4dGVuZCh7ZmlsbDogY29sb3J9KS52YWx1ZSgpXG4gICAgICAgICk7XG4gICAgICAgIGNhdExhYmVsLnggPSB4ICsgMjA7XG4gICAgICAgIGNhdExhYmVsLnkgPSB5IC0gMjM7XG4gICAgICAgIHRoaXMuY29udGFpbmVyLmFkZENoaWxkKGNhdExhYmVsKTtcbiAgICAgICAgdGV4dEhlaWdodCArPSAoY2F0TGFiZWwuaGVpZ2h0IC0gMjMgKyAyKTtcblxuICAgICAgICBpZih0ZXh0KSB7XG4gICAgICAgICAgICB2YXIgY2F0VGV4dCA9IG5ldyBQSVhJLlRleHQodGV4dCwgYW5ub3RTdHlsZXMudGV4dCk7XG4gICAgICAgICAgICBjYXRUZXh0LnggPSB4ICsgMjA7XG4gICAgICAgICAgICBjYXRUZXh0LnkgPSB5ICsgMjtcbiAgICAgICAgICAgIHRoaXMuY29udGFpbmVyLmFkZENoaWxkKGNhdFRleHQpO1xuICAgICAgICAgICAgdGV4dEhlaWdodCArPSAoY2F0VGV4dC5oZWlnaHQgKyAyKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHZhciBjYXRVc2VyID0gbmV3IFBJWEkuVGV4dCh1c2VyLCBhbm5vdFN0eWxlcy51c2VyKTtcbiAgICAgICAgY2F0VXNlci54ID0geCArIDIwO1xuICAgICAgICBjYXRVc2VyLnkgPSB5ICsgMiArIHRleHRIZWlnaHQ7XG4gICAgICAgIHRoaXMuY29udGFpbmVyLmFkZENoaWxkKGNhdFVzZXIpO1xuXG4gICAgICAgIHRoaXMuYWRkQW5ub3RMaW5lKGNvbG9ySGV4LCB5KTtcbiAgICB9O1xuXG4gICAgdGhpcy5hZGRBbm5vdExpbmUgPSBmdW5jdGlvbihjb2xvciwgeSkge1xuICAgICAgICB2YXIgeCA9IHRoaXMud2lkdGhSb2xsO1xuXG5cbiAgICAgICAgdmFyIGdyYXBoaWNzID0gbmV3IFBJWEkuR3JhcGhpY3MoKVxuICAgICAgICAgICAgLmJlZ2luRmlsbChjb2xvcilcbiAgICAgICAgICAgIC5kcmF3UmVjdCh4LCB5LCB0aGlzLndpZHRoIC0geCwgMylcbiAgICAgICAgICAgIC5lbmRGaWxsKCk7XG5cbiAgICAgICAgdGhpcy5jb250YWluZXIuYWRkQ2hpbGQoZ3JhcGhpY3MpO1xuICAgIH07XG5cbiAgICB0aGlzLm1vdmVUbyA9IGZ1bmN0aW9uKGRpZmZUaW1lKXtcbiAgICBcdHRoaXMuY29udGFpbmVyLnkgPSBNYXRoLmZsb29yKGRpZmZUaW1lKnRoaXMucGl4ZWxzUGVyU2Vjb25kKTtcbiAgICB9O1xuXG4gICAgdGhpcy5tb3ZlID0gdGhpcy5yZWZyZXNoID0gZnVuY3Rpb24oKSB7XG4gICAgICAgIHZhciBkaWZmID0gKHRoaXMuc3RhcnRUcyAtIERhdGUubm93KCkpLzEwMDA7XG4gICAgICAgIHRoaXMubW92ZVRvKGRpZmYpO1xuICAgIH07XG5cbiAgICB0aGlzLnJlbW92ZVBhc3NlZE9iamV0cyA9IGZ1bmN0aW9uKCl7XG4gICAgICAgIHZhciBjaGlsZHJlblRvUmVtb3ZlID0gW107XG4gICAgICAgIF8oX3RoaXMuY29udGFpbmVyLmNoaWxkcmVuKS5mb3JFYWNoKGZ1bmN0aW9uKGNoaWxkKSB7XG4gICAgICAgICAgICByZXR1cm4gdHlwZW9mKGNoaWxkKSA9PT0gJ3VuZGVmaW5lZCcgfHxcbiAgICAgICAgICAgICAgICAoaXNIaWRkZW4oY2hpbGQpICYmIGNoaWxkcmVuVG9SZW1vdmUucHVzaChjaGlsZCkpO1xuICAgICAgICB9KTtcbiAgICAgICAgY2hpbGRyZW5Ub1JlbW92ZS5mb3JFYWNoKGZ1bmN0aW9uKGNoaWxkKSB7XG4gICAgICAgICAgICBfdGhpcy5jb250YWluZXIucmVtb3ZlQ2hpbGQoY2hpbGQpO1xuICAgICAgICB9KTtcbiAgICB9O1xuXG4gICAgdGhpcy5pbml0ID0gZnVuY3Rpb24oKSB7XG5cbiAgICAgICAgd3MubWVzc2FnZShmdW5jdGlvbihkYXRhKSB7XG4gICAgICAgICAgICBfdGhpcy5hZGRBbm5vdHMoZGF0YSk7XG4gICAgICAgIH0pO1xuXG4gICAgfTtcblxuICAgIHRoaXMuc3RhcnQgPSBmdW5jdGlvbigpIHtcbiAgICAgICAgaWYoIXN0YXJ0ZWQpIHtcbiAgICAgICAgICAgIHRoaXMuc3RhcnRUcyA9IERhdGUubm93KCk7XG4gICAgICAgICAgICBzdGFydGVkID0gdHJ1ZTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLmNsZWFuSW50ZXJ2YWwgPSBzZXRJbnRlcnZhbChmdW5jdGlvbiAoKSB7IF90aGlzLnJlbW92ZVBhc3NlZE9iamV0cygpOyB9LCAxMDAwICogdGhpcy5oZWlnaHQgLyB0aGlzLnBpeGVsc1BlclNlY29uZCApO1xuICAgICAgICBpZighZXh0ZXJuYWxSZWZyZXNoKSB7XG4gICAgICAgICAgICB0aGlzLnJlZnJlc2hJbnRlcnZhbCA9IHNldEludGVydmFsKGZ1bmN0aW9uKCkge190aGlzLm1vdmUoKTt9LCAxMDAwL3RoaXMuZnJhbWVyYXRlKTtcbiAgICAgICAgfVxuICAgIH07XG5cbiAgICB0aGlzLnN0b3AgPSBmdW5jdGlvbigpIHtcbiAgICAgICAgY2xlYXJJbnRlcnZhbCh0aGlzLmNsZWFuSW50ZXJ2YWwpO1xuICAgICAgICBpZighZXh0ZXJuYWxSZWZyZXNoKSB7XG4gICAgICAgICAgICBjbGVhckludGVydmFsKHRoaXMucmVmcmVzaEludGVydmFsKTtcbiAgICAgICAgfVxuICAgIH07XG5cbn1cblxubW9kdWxlLmV4cG9ydHMgPSB7XG4gICAgQW5ub3RzUm9sbDogQW5ub3RzUm9sbCxcbn07XG4iLCIvKipcbioganMvYW5ub3RzdGltZWxpbmVcbipcbiogYW5ub3RzdGltZWxpbmUgYmFzaWMgY29tcG9uZW50XG4qXG4qL1xuXG4ndXNlIHN0cmljdCc7XG5cbnZhciBQSVhJID0gcmVxdWlyZSgncGl4aScpO1xudmFyIFV0aWxzID0gcmVxdWlyZSgnLi91dGlscy5qcycpO1xudmFyIF8gPSByZXF1aXJlKCdsb2Rhc2gnKTtcblxudmFyIGRlZmF1bHRPcHRpb25zID0ge1xuICAgIGxvZ2dlcjogdW5kZWZpbmVkLFxuICAgIGludGVydmFsV2lkdGg6IDEwLFxuICAgIGludGVydmFsSGVpZ2h0OiA1LFxuICAgIG1heENlbGxIZWlnaHQ6IDIwMCxcbiAgICByYWRpdXM6IDMwMFxufTtcblxuXG5mdW5jdGlvbiBBbm5vdHNUaW1lTGluZShvcHRpb25zKXtcbiAgICB2YXIgX3RoaXMgPSB0aGlzO1xuICAgIHZhciBvcHRzID0gXyhvcHRpb25zKS5kZWZhdWx0cyhkZWZhdWx0T3B0aW9ucykudmFsdWUoKTtcblxuICAgIHRoaXMuY29udGFpbmVyID0gbmV3IFBJWEkuRGlzcGxheU9iamVjdENvbnRhaW5lcigpO1xuICAgIHRoaXMuY29udGFpbmVyLnggPSBvcHRzLnhJbml0O1xuICAgIHRoaXMuY29udGFpbmVyLnkgPSBvcHRzLnlJbml0O1xuICAgIHRoaXMuY29udGFpbmVyLndpZHRoID0gb3B0cy53aWR0aDtcbiAgICB0aGlzLmNvbnRhaW5lci5oZWlnaHQgPSBvcHRzLmhlaWdodDtcblxuICAgIHRoaXMudGltZUJlZ2luID0gb3B0cy50aW1lQmVnaW47XG4gICAgdGhpcy50aW1lRW5kID0gb3B0cy50aW1lRW5kO1xuICAgIHRoaXMuZHVyYXRpb24gPSAodGhpcy50aW1lRW5kIC0gdGhpcy50aW1lQmVnaW4pLzEwMDA7XG4gICAgdGhpcy53aWR0aCA9IG9wdHMud2lkdGg7XG4gICAgdGhpcy5oZWlnaHQgPSBvcHRzLmhlaWdodDtcbiAgICB0aGlzLmludGVydmFsSGVpZ2h0ID0gb3B0cy5pbnRlcnZhbEhlaWdodDtcbiAgICB0aGlzLmludGVydmFsV2lkdGggPSBvcHRzLmludGVydmFsV2lkdGg7XG4gICAgdGhpcy5tYXhDZWxsSGVpZ2h0ID0gb3B0cy5tYXhDZWxsSGVpZ2h0O1xuICAgIHRoaXMuYW5ub3RDYXRlZ29yaWVzID0gb3B0cy5hbm5vdENhdGVnb3JpZXM7XG5cbiAgICB0aGlzLmNpcmNsZVggPSBvcHRzLmNpcmNsZVggfHwgKHRoaXMud2lkdGgvMik7XG4gICAgdGhpcy5jaXJjbGVZID0gb3B0cy5jaXJjbGVZIHx8ICh0aGlzLmhlaWdodC8yKTtcbiAgICB0aGlzLnJhZGl1cyA9IG9wdHMucmFkaXVzO1xuICAgIHRoaXMucGVyaW1ldGVyID0gMipNYXRoLlBJKiB0aGlzLnJhZGl1cztcbiAgICB0aGlzLmludGVydmFsRHVyYXRpb24gPSAodGhpcy5pbnRlcnZhbFdpZHRoICogdGhpcy5kdXJhdGlvbiAvIHRoaXMucGVyaW1ldGVyKTtcblxuICAgIHZhciBjdXJyZW50VGltZSA9IHRoaXMudGltZUJlZ2luO1xuICAgIHZhciB0b3RhbEluZGV4ID0gTWF0aC5mbG9vcih0aGlzLnBlcmltZXRlci90aGlzLmludGVydmFsV2lkdGgpO1xuXG4gICAgdGhpcy5jZWxscyA9IFtdXG4gICAgZm9yICh2YXIgaT0wOyBpPCh0aGlzLnBlcmltZXRlci90aGlzLmludGVydmFsV2lkdGgpIDsgaSsrKXtcbiAgICBcdHRoaXMuY2VsbHNbaV0gPSBbXTtcbiAgICBcdHRoaXMuY2VsbHNbaV0uaSA9IGk7XG4gICAgXHR0aGlzLmNlbGxzW2ldLnRvdGFsQW5ub3RzID0gMDtcbiAgICBcdHRoaXMuY2VsbHNbaV0uY2F0ZWdvcmllcyA9IHt9O1xuXG4gICAgXHRmb3IgKHZhciBjYXRlZ29yeSBpbiB0aGlzLmFubm90Q2F0ZWdvcmllc1swXS5jb2xvcnMpe1xuICAgIFx0XHR0aGlzLmNlbGxzW2ldLmNhdGVnb3JpZXNbY2F0ZWdvcnldID0ge1xuXHRcdFx0XHRcImNvdW50XCI6IDAsXG5cdFx0XHRcdFwiY29sb3JcIjogdGhpcy5hbm5vdENhdGVnb3JpZXNbMF0uY29sb3JzW2NhdGVnb3J5XVxuICAgIFx0XHR9O1xuICAgIFx0fVxuICAgIH1cblxuICAgIHZhciB3cyA9IG9wdHMud3M7XG4gICAgdmFyIHN0YWdlVmlldyA9IG9wdHMuc3RhZ2VWaWV3O1xuXG4gICAgLy9kcmF3IHRoZSBiYXNlIC0gY2lyY2xlIGFuZCBsaW5lIHRvIGxvY2F0ZSB0aGUgc2NlbmVcbiAgICB2YXIgZ3JhcGhpY3MgPSBuZXcgUElYSS5HcmFwaGljcygpO1xuICAgIGdyYXBoaWNzLmxpbmVTdHlsZSgyLCAweDY0NjQ2NClcbiAgICBcdC5kcmF3Q2lyY2xlKHRoaXMuY2lyY2xlWCwgdGhpcy5jaXJjbGVZLCB0aGlzLnJhZGl1cyAtIDMpXG4gICAgXHQubGluZVN0eWxlKDEsIDB4RDdEN0Q3KVxuICAgIFx0LmRyYXdDaXJjbGUodGhpcy5jaXJjbGVYLCB0aGlzLmNpcmNsZVksIHRoaXMucmFkaXVzKjIvMylcbiAgICBcdC5kcmF3Q2lyY2xlKHRoaXMuY2lyY2xlWCwgdGhpcy5jaXJjbGVZLCB0aGlzLnJhZGl1cy8zKVxuICAgIFx0LmxpbmVTdHlsZSgxLCAweDY0NjQ2NClcbiAgICBcdC5tb3ZlVG8odGhpcy5jaXJjbGVYLCB0aGlzLmNpcmNsZVkgLSAodGhpcy5yYWRpdXMvMykvMilcbiAgICBcdC5saW5lVG8odGhpcy5jaXJjbGVYLCB0aGlzLmNpcmNsZVkgLSB0aGlzLnJhZGl1cyAtIHRoaXMubWF4Q2VsbEhlaWdodCAtIDEwKVxuICAgIFx0LmVuZEZpbGwoKVxuICAgIHRoaXMuY29udGFpbmVyLmFkZENoaWxkKGdyYXBoaWNzKTtcblxuICAgIC8vc2V0IHRpbWUgdGV4dFxuICAgIC8vVE9ETyA6IG1vdmUgdGhpcyB0byBhbm5vdHN2aXp2aWV3XG4gICAgdmFyIGN1cnJlbnRUaW1lVGV4dCA9IG5ldyBQSVhJLlRleHQoXCItLSA6IC0tIDogLS1cIiwgeyBmb250OiAnMThwdCBHb3RoaWMgU3RhbmRhcmQnLCBmaWxsOiAnIzY0NjQ2NCcgfSk7XG4gICAgY3VycmVudFRpbWVUZXh0LnggPSB0aGlzLmNpcmNsZVggLSBjdXJyZW50VGltZVRleHQud2lkdGgvMjtcbiAgICBjdXJyZW50VGltZVRleHQueSA9IHRoaXMuY2lyY2xlWSAtIGN1cnJlbnRUaW1lVGV4dC5oZWlnaHQvMjtcbiAgICB0aGlzLmNvbnRhaW5lci5hZGRDaGlsZChjdXJyZW50VGltZVRleHQpO1xuXG4gICAgc3RhZ2VWaWV3LnJlZ2lzdGVyQ29tcG9uZW50KHRoaXMpO1xuXG4gICAgLy9BZGQgQW5ub3RhdGlvbiB0byB0aGUgVGltZUxpbmVcbiAgICB0aGlzLmFkZEFubm90ID0gZnVuY3Rpb24oZGF0YSl7XG4gICAgXHRpZiAodHlwZW9mKHRoaXMuYW5ub3RDYXRlZ29yaWVzWzBdLmNvbG9yc1tkYXRhLmNvbnRlbnQuY2F0ZWdvcnkuY29kZV0pICE9PSAndW5kZWZpbmVkJyl7XG4gICAgXHRcdHZhciBhbm5vdENvZGUgPSBkYXRhLmNvbnRlbnQuY2F0ZWdvcnkuY29kZTtcbiAgICBcdH0gZWxzZSB7XG4gICAgXHRcdHZhciBhbm5vdENvZGUgPSB0aGlzLmFubm90Q2F0ZWdvcmllc1swXS5vcmRlclt0aGlzLmFubm90Q2F0ZWdvcmllc1swXS5vcmRlci5sZW5ndGggLTFdO1xuICAgIFx0fVxuICAgIFx0dmFyIGFubm90VGltZSA9IERhdGUucGFyc2UoZGF0YS50cyk7XG5cbiAgICBcdGlmICh0aGlzLnRpbWVFbmQgPiBEYXRlLnBhcnNlKGRhdGEudHMpKXtcblx0ICAgIFx0dmFyIGkgPSBNYXRoLmZsb29yKChEYXRlLnBhcnNlKGRhdGEudHMpLXRoaXMudGltZUJlZ2luKS8oMTAwMCp0aGlzLmludGVydmFsRHVyYXRpb24pKTtcblxuXHRcdFx0dGhpcy5jZWxsc1tpXS5jYXRlZ29yaWVzW2Fubm90Q29kZV0uY291bnQgKz0gMTtcblx0XHRcdHRoaXMuY2VsbHNbaV0udG90YWxBbm5vdHMgKz0xO1xuXHRcdFx0dGhpcy5yZWRyYXdDZWxsKHRoaXMuY2VsbHNbaV0sIGkpO1xuICAgIFx0fVxuICAgIH07XG5cbiAgICB0aGlzLmluaXRHcmFwaGljcyA9IGZ1bmN0aW9uKGNlbGwpe1xuICAgIFx0Y2VsbC5ncmFwaGljcyA9IG5ldyBQSVhJLkdyYXBoaWNzKCk7XG4gICAgXHRjZWxsLmdyYXBoaWNzLnBvc2l0aW9uLnggPSB0aGlzLmNpcmNsZVggKyB0aGlzLnJhZGl1cyAqIE1hdGguc2luKGNlbGwuaSooMzYwL3RvdGFsSW5kZXgpKihNYXRoLlBJLzE4MCkpO1xuICAgIFx0Y2VsbC5ncmFwaGljcy5wb3NpdGlvbi55ID0gdGhpcy5jaXJjbGVZIC0gdGhpcy5yYWRpdXMgKiBNYXRoLmNvcyhjZWxsLmkqKDM2MC90b3RhbEluZGV4KSooTWF0aC5QSS8xODApKTtcbiAgICBcdGNlbGwuZ3JhcGhpY3Mucm90YXRpb24gPSAoY2VsbC5pKSooMzYwL3RvdGFsSW5kZXgpKihNYXRoLlBJLzE4MCkgKyAoMzYwLyh0b3RhbEluZGV4KjIpKSooTWF0aC5QSS8xODApO1xuICAgIFx0dGhpcy5jb250YWluZXIuYWRkQ2hpbGQoY2VsbC5ncmFwaGljcyk7XG4gICAgfVxuXG4gICAgdGhpcy5pbml0VGltZVRleHRzID0gZnVuY3Rpb24oKSB7XG5cdCAgICB2YXIgdEJlZyA9IG5ldyBQSVhJLlRleHQoVXRpbHMuZm9ybWF0VGltZSh0aGlzLnRpbWVCZWdpbiksIHsgZm9udDogJzEycHQgR290aGljIFN0YW5kYXJkJywgZmlsbDogJyM2NDY0NjQnIH0pO1xuXHQgICAgdEJlZy54ID0gdGhpcy5jaXJjbGVYICsgMTU7XG5cdCAgICB0QmVnLnkgPSB0aGlzLmNpcmNsZVkgLSB0aGlzLnJhZGl1cyAtIHRoaXMubWF4Q2VsbEhlaWdodCAtIDEwO1xuXHQgICAgdGhpcy5jb250YWluZXIuYWRkQ2hpbGQodEJlZyk7XG5cblx0ICAgIHZhciB0RW5kID0gbmV3IFBJWEkuVGV4dChVdGlscy5mb3JtYXRUaW1lKHRoaXMudGltZUVuZCksIHsgZm9udDogJzEycHQgR290aGljIFN0YW5kYXJkJywgZmlsbDogJyM2NDY0NjQnIH0pO1xuXHQgICAgdEVuZC54ID0gdGhpcy5jaXJjbGVYIC0gMTUgLSB0RW5kLndpZHRoO1xuXHQgICAgdEVuZC55ID0gdGhpcy5jaXJjbGVZIC0gdGhpcy5yYWRpdXMgLSB0aGlzLm1heENlbGxIZWlnaHQgLSAxMDtcblx0ICAgIHRoaXMuY29udGFpbmVyLmFkZENoaWxkKHRFbmQpO1xuXG5cdCAgICB2YXIgdDE1ID0gbmV3IFBJWEkuVGV4dChVdGlscy5mb3JtYXRUaW1lKCgodGhpcy50aW1lRW5kIC0gdGhpcy50aW1lQmVnaW4pLzQpICsgdGhpcy50aW1lQmVnaW4pLCB7IGZvbnQ6ICcxMnB0IEdvdGhpYyBTdGFuZGFyZCcsIGZpbGw6ICcjNjQ2NDY0JyB9KTtcblx0ICAgIHQxNS54ID0gdGhpcy5jaXJjbGVYICsgdGhpcy5yYWRpdXMgKyB0aGlzLm1heENlbGxIZWlnaHQgKyAxMCA7XG5cdCAgICB0MTUueSA9IHRoaXMuY2lyY2xlWSAtIHQxNS5oZWlnaHQ7XG5cdCAgICB0MTUucm90YXRpb24gPSBNYXRoLlBJIC8yO1xuXHQgICAgdGhpcy5jb250YWluZXIuYWRkQ2hpbGQodDE1KTtcblxuXHQgICAgdmFyIHQzMCA9IG5ldyBQSVhJLlRleHQoVXRpbHMuZm9ybWF0VGltZSgoKHRoaXMudGltZUVuZCAtIHRoaXMudGltZUJlZ2luKS8yKSArIHRoaXMudGltZUJlZ2luKSwgeyBmb250OiAnMTJwdCBHb3RoaWMgU3RhbmRhcmQnLCBmaWxsOiAnIzY0NjQ2NCcgfSk7XG5cdCAgICB0MzAueCA9IHRoaXMuY2lyY2xlWCAtIHQzMC53aWR0aC8yO1xuXHQgICAgdDMwLnkgPSB0aGlzLmNpcmNsZVkgKyB0aGlzLnJhZGl1cyArIHRoaXMubWF4Q2VsbEhlaWdodCAtIDI7XG5cdCAgICB0aGlzLmNvbnRhaW5lci5hZGRDaGlsZCh0MzApO1xuXG5cdCAgICB2YXIgdDQ1ID0gbmV3IFBJWEkuVGV4dChVdGlscy5mb3JtYXRUaW1lKCgodGhpcy50aW1lRW5kIC0gdGhpcy50aW1lQmVnaW4pKjMvNCkgKyB0aGlzLnRpbWVCZWdpbiksIHsgZm9udDogJzEycHQgR290aGljIFN0YW5kYXJkJywgZmlsbDogJyM2NDY0NjQnIH0pO1xuXHQgICAgdDQ1LnggPSB0aGlzLmNpcmNsZVggLSB0aGlzLnJhZGl1cyAtIHRoaXMubWF4Q2VsbEhlaWdodCAtIDEwIDtcblx0ICAgIHQ0NS55ID0gdGhpcy5jaXJjbGVZICsgdDE1LmhlaWdodDtcblx0ICAgIHQ0NS5yb3RhdGlvbiA9IC1NYXRoLlBJLzI7XG5cdCAgICB0aGlzLmNvbnRhaW5lci5hZGRDaGlsZCh0NDUpO1xuICAgIH1cblxuICAgIC8vRHJhdyB0aGUgY2VsbHVsZVxuICAgIHRoaXMucmVkcmF3Q2VsbCA9IGZ1bmN0aW9uKGNlbGwpe1xuXG4gICAgXHRpZiAodHlwZW9mKGNlbGwuZ3JhcGhpY3MpID09PSAndW5kZWZpbmVkJyl7XG4gICAgXHRcdHRoaXMuaW5pdEdyYXBoaWNzKGNlbGwpO1xuICAgIFx0fSBlbHNlIHtcbiAgICBcdFx0Y2VsbC5ncmFwaGljcy5jbGVhcigpO1xuICAgIFx0fVxuXG4gICAgXHR2YXIgeSA9IDA7XG5cbiAgICBcdC8vQ2hlY2sgaWYgdG90YWwgaGVpZ2h0IGlzIGhpZ2hlciB0aGFuIE1heCBDZWxsIEhlaWdodFxuICAgIFx0aWYgKChjZWxsLnRvdGFsQW5ub3RzKnRoaXMuaW50ZXJ2YWxIZWlnaHQpID4gdGhpcy5tYXhDZWxsSGVpZ2h0KXtcbiAgICBcdFx0dmFyIGhlaWdodFN0ZXAgPSB0aGlzLm1heENlbGxIZWlnaHQvY2VsbC50b3RhbEFubm90cztcbiAgICBcdH0gZWxzZSB7XG4gICAgXHRcdHZhciBoZWlnaHRTdGVwID0gdGhpcy5pbnRlcnZhbEhlaWdodDtcbiAgICBcdH1cblxuICAgIFx0Ly9EcmF3IHRoZSByZWN0IGRlcGVuZGluZyBvbiB0aGUgaGVpZ2h0IHN0ZXAgY2FsY3VsYXRlZFxuICAgIFx0Zm9yICh2YXIgaT0wOyBpPCB0aGlzLmFubm90Q2F0ZWdvcmllc1swXS5vcmRlci5sZW5ndGg7IGkrKyl7XG4gICAgXHRcdHZhciBjdXJyZW50Q29kZSA9IHRoaXMuYW5ub3RDYXRlZ29yaWVzWzBdLm9yZGVyW2ldO1xuXHRcdFx0Y2VsbC5ncmFwaGljcy5iZWdpbkZpbGwoY2VsbC5jYXRlZ29yaWVzW2N1cnJlbnRDb2RlXS5jb2xvci5yZXBsYWNlKFwiI1wiLCBcIjB4XCIpKVxuICAgIFx0XHRcdC5kcmF3UmVjdCgwLCB5LCB0aGlzLmludGVydmFsV2lkdGgtMSwgLWNlbGwuY2F0ZWdvcmllc1tjdXJyZW50Q29kZV0uY291bnQgKiBoZWlnaHRTdGVwKVxuICAgIFx0XHRcdC5lbmRGaWxsKCk7XG4gICAgXHRcdHkgLT0gY2VsbC5jYXRlZ29yaWVzW2N1cnJlbnRDb2RlXS5jb3VudCpoZWlnaHRTdGVwO1xuICAgIFx0fVxuICAgIH1cblxuICAgIHRoaXMuaW5pdCA9IGZ1bmN0aW9uKCkge1xuICAgIFx0d3MubWVzc2FnZShmdW5jdGlvbihkYXRhKSB7XG4gICAgICAgICAgICBfdGhpcy5hZGRBbm5vdChkYXRhKTtcbiAgICAgICAgfSk7XG5cbiAgICBcdHRoaXMuaW5pdFRpbWVUZXh0cygpO1xuICAgIH07XG5cbiAgICB0aGlzLnVwZGF0ZVRpbWUgPSBmdW5jdGlvbigpe1xuICAgIFx0Y3VycmVudFRpbWUgKz0gMTAwMDtcblxuICAgICAgICB2YXIgbmJTZWMgPSBjdXJyZW50VGltZSAvIDEwMDA7XG4gICAgICAgIHZhciBob3VycyA9IE1hdGguZmxvb3IoIG5iU2VjIC8gMzYwMCApICUgMjQ7XG4gICAgICAgIHZhciBtaW51dGVzID0gTWF0aC5mbG9vciggbmJTZWMgLyA2MCApICUgNjA7XG4gICAgICAgIHZhciBzZWNvbmRzID0gTWF0aC5mbG9vcihuYlNlYyAlIDYwKTtcbiAgICAgICAgdmFyIHRpbWVTdHIgPSAoaG91cnMgPCAxMCA/ICcwJyArIGhvdXJzIDogaG91cnMpICsgJzonICsgKG1pbnV0ZXMgPCAxMCA/ICcwJyArIG1pbnV0ZXMgOiBtaW51dGVzKSArICc6JyArIChzZWNvbmRzICA8IDEwID8gJzAnICsgc2Vjb25kcyA6IHNlY29uZHMpO1xuXG4gICAgICAgIGN1cnJlbnRUaW1lVGV4dC5zZXRUZXh0KHRpbWVTdHIpO1xuICAgIH07XG5cbiAgICB2YXIgcmVmcmVzaFRpbWVJbnRlcnZhbDtcblxuICAgIHRoaXMuc3RhcnQgPSBmdW5jdGlvbigpIHtcbiAgICBcdHJlZnJlc2hUaW1lSW50ZXJ2YWwgPSBzZXRJbnRlcnZhbChmdW5jdGlvbigpIHtfdGhpcy51cGRhdGVUaW1lKCk7fSwgMTAwMCk7XG4gICAgfTtcblxuICAgIHRoaXMucmVmcmVzaCA9IGZ1bmN0aW9uKCkge1xuXG4gICAgfTtcblxuICAgIHRoaXMuc3RvcCA9IGZ1bmN0aW9uKCl7XG4gICAgXHRjb25zb2xlLmxvZyh0aGlzLmNlbGxzKTtcbiAgICB9O1xuXG4gICAgcmV0dXJuIHRoaXM7XG59XG5cbm1vZHVsZS5leHBvcnRzID0ge1xuXHRBbm5vdHNUaW1lTGluZTogQW5ub3RzVGltZUxpbmVcbn07XG4iLCIvKipcbioganMvYW5ub3Rzdml6dmlldy5qc1xuKlxuKiBUaGlzIGlzIHRoZSBzdGFydGluZyBwb2ludCBmb3IgeW91ciBhcHBsaWNhdGlvbi5cbiogVGFrZSBhIGxvb2sgYXQgaHR0cDovL2Jyb3dzZXJpZnkub3JnLyBmb3IgbW9yZSBpbmZvXG4qL1xuXG4ndXNlIHN0cmljdCc7XG5cbnZhciBQSVhJID0gcmVxdWlyZSgncGl4aScpO1xudmFyIF8gPSByZXF1aXJlKCdsb2Rhc2gnKTtcbnZhciBEb3VibGVSb2xsID0gcmVxdWlyZSgnLi9kb3VibGVyb2xsLmpzJyk7XG52YXIgQW5ub3RzVGltZUxpbmUgPSByZXF1aXJlKCcuL2Fubm90c3RpbWVsaW5lLmpzJyk7XG52YXIgQW5ub3RzUm9sbCA9IHJlcXVpcmUoJy4vYW5ub3Rzcm9sbC5qcycpO1xuXG52YXIgZGVmYXVsdE9wdGlvbnMgPSB7XG4gICAgeEluaXQ6IDAsXG4gICAgeUluaXQ6IDAsXG4gICAgd2lkdGg6IDEwMjQsXG4gICAgaGVpZ2h0OiA3NjgsXG4gICAgYW5ub3RDYXRlZ29yaWVzOiBbe1xuICAgICAgICB0czogMCxcbiAgICAgICAgY29sb3JzOiB7XG4gICAgICAgICAgICAnbnRtJzogJyNDREM4M0YnLFxuICAgICAgICAgICAgJ2lhbSc6ICcjQ0RDODNGJyxcbiAgICAgICAgICAgICdoaXAnOiAnI0NEQzgzRicsXG4gICAgICAgICAgICAnaG9wJzogJyNDREM4M0YnLFxuICAgICAgICAgICAgJ3JvY2snOiAnI0RFOEI1MycsXG4gICAgICAgICAgICAncmFwJzogJyNERThCNTMnLFxuICAgICAgICAgICAgJ2NsYXNzaWMnOiAnI0RFOEI1MycsXG4gICAgICAgICAgICAnZHJ1bXMnOiAnI0M1QTNDQScsXG4gICAgICAgICAgICAnZ3VpdGFyJzogJyNDNUEzQ0EnLFxuICAgICAgICAgICAgJ2Jhc3MnOiAnIzc5QkI5MicsXG4gICAgICAgICAgICAnZGVmYXVsdCc6ICcjODA4MDgwJ1xuICAgICAgICB9LFxuICAgICAgICBvcmRlcjogWydudG0nLCAnaWFtJywgJ2hpcCcsICdob3AnLCAncm9jaycsICdyYXAnLCAnY2xhc3NpYycsICdkcnVtcycsICdndWl0YXInLCAnYmFzcycsICdkZWZhdWx0J11cbiAgICB9XVxufTtcblxuZnVuY3Rpb24gQW5ub3RzVml6VmlldyhvcHRpb25zKXtcblx0dmFyIF90aGlzID0gdGhpcztcbiAgICB2YXIgb3B0cyA9IF8ob3B0aW9ucykuZGVmYXVsdHMoZGVmYXVsdE9wdGlvbnMpLnZhbHVlKCk7XG5cbiAgICB0aGlzLmNvbnRhaW5lciA9IG5ldyBQSVhJLkRpc3BsYXlPYmplY3RDb250YWluZXIoKTtcbiAgICB0aGlzLmNvbnRhaW5lci54ID0gb3B0cy54SW5pdDtcbiAgICB0aGlzLmNvbnRhaW5lci55ID0gb3B0cy55SW5pdDtcblx0dGhpcy53aWR0aCA9IG9wdHMud2lkdGg7XG5cdHRoaXMuaGVpZ2h0PSBvcHRzLmhlaWdodDtcbiAgICB0aGlzLmFubm90Q2F0ZWdvcmllcyA9IG9wdHMuYW5ub3RDYXRlZ29yaWVzO1xuXG5cdHZhciB3c1BpYW5vcm9sbCA9IG9wdHMud3NQaWFub3JvbGw7XG5cdHZhciB3c0Fubm90ID0gb3B0cy53c0Fubm90O1xuXHR2YXIgc3RhZ2VWaWV3ID0gb3B0cy5zdGFnZVZpZXc7XG5cblx0c3RhZ2VWaWV3LnJlZ2lzdGVyQ29tcG9uZW50KHRoaXMpO1xuXG5cdHZhciB0aW1lTGluZSA9IG5ldyBBbm5vdHNUaW1lTGluZS5Bbm5vdHNUaW1lTGluZSh7XG4gICAgXHRzdGFnZVZpZXcgOiBzdGFnZVZpZXcsXG4gICAgICAgIGxvZ2dlcjogbG9nZ2VyLFxuICAgICAgICB3czogbmV3IGFubm90dml6LldzV3JhcHBlcih3c1VyaUFubm90YXRpb24sIGxvZ2dlciksXG4gICAgICAgIHhJbml0OiAwLFxuICAgICAgICB5SW5pdDogMCxcbiAgICAgICAgd2lkdGg6IDEwMjQgLSAyMDAgLSAyMDAsXG4gICAgICAgIGhlaWdodDogNzY4LTIwMCxcbiAgICAgICAgdGltZUJlZ2luOiBEYXRlLm5vdygpLFxuICAgICAgICB0aW1lRW5kOiBEYXRlLm5vdygpICsgMzAwMDAwMCxcbiAgICAgICAgaW50ZXJ2YWxXaWR0aDogNixcbiAgICAgICAgaW50ZXJ2YWxIZWlnaHQ6IDEwLFxuICAgICAgICBtYXhDZWxsSGVpZ2h0OiA3MCxcbiAgICAgICAgcmFkaXVzOiAyMDAsXG4gICAgICAgIGFubm90Q2F0ZWdvcmllczogdGhpcy5hbm5vdENhdGVnb3JpZXNcbiAgICB9KTtcblxuXHR2YXIgZG91YmxlUm9sbEggPSBuZXcgRG91YmxlUm9sbC5Eb3VibGVSb2xsKHtcbiAgICAgICAgc3RhZ2VWaWV3IDogc3RhZ2VWaWV3LFxuICAgIFx0bG9nZ2VyOiBsb2dnZXIsXG4gICAgICAgIHdzOiB3c1BpYW5vcm9sbCxcbiAgICAgICAgeUluaXQ6ICh0aGlzLmhlaWdodCAtIDIwMCksXG4gICAgICAgIHNjZW5lSGVpZ2h0OiAyMDAsXG4gICAgICAgIHBpYW5vcm9sbHMgOiBbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgaGVpZ2h0OiAyMDAsXG4gICAgICAgICAgICAgICAgdGltZVdpZHRoOiAxMCxcbiAgICAgICAgICAgICAgICBsaW5lSW50ZXJ2YWw6IDUwMDAsXG4gICAgICAgICAgICAgICAgbm90ZUhlaWdodDogMTBcbiAgICAgICAgICAgIH0sXG4gICAgICAgIF1cbiAgICB9KTtcblxuXHR2YXIgZG91YmxlUm9sbFYgPSBuZXcgRG91YmxlUm9sbC5Eb3VibGVSb2xsKHtcbiAgICAgICAgc3RhZ2VWaWV3IDogc3RhZ2VWaWV3LFxuICAgIFx0bG9nZ2VyOiBsb2dnZXIsXG4gICAgICAgIHdzOiB3c1BpYW5vcm9sbCxcbiAgICAgICAgb3JpZW50YXRpb246ICd2ZXJ0aWNhbCcsXG4gICAgICAgIHNjZW5lSGVpZ2h0OiA3NjgtMjAwLFxuICAgICAgICBwaWFub3JvbGxzIDogW1xuICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIGhlaWdodDogMjAwLFxuICAgICAgICAgICAgICAgIHRpbWVXaWR0aDogNjAsXG4gICAgICAgICAgICAgICAgbGluZUludGVydmFsOiA1MDAwLFxuICAgICAgICAgICAgICAgIG5vdGVIZWlnaHQ6IDUsXG4gICAgICAgICAgICB9LFxuICAgICAgICBdXG4gICAgfSk7XG5cblx0dmFyIGFubm90c1JvbGwgPSBuZXcgQW5ub3RzUm9sbC5Bbm5vdHNSb2xsKHtcbiAgICBcdHN0YWdlVmlldyA6IHN0YWdlVmlldyxcbiAgICAgICAgbG9nZ2VyOiBsb2dnZXIsXG4gICAgICAgIHdzOiB3c0Fubm90LFxuICAgICAgICBwYXJlbnRDb250YWluZXI6IGRvdWJsZVJvbGxWLnN0YWdlLFxuICAgICAgICB4SW5pdDogMTAyNCAtIDIwMCAtIDIwMCxcbiAgICAgICAgeUluaXQ6IDc2OC0yMDAsXG4gICAgICAgIHdpZHRoOiAyMDAgKyAyMDAsXG4gICAgICAgIGhlaWdodDogNzY4LTIwMCxcbiAgICAgICAgd2lkdGhSb2xsOiAyMDAsXG4gICAgICAgIGZyYW1lcmF0ZTogZG91YmxlUm9sbFYuZnJhbWVyYXRlLFxuICAgICAgICBwaXhlbHNQZXJTZWNvbmQ6IE1hdGguZmxvb3IoMTAyNCAvIDYwKSxcbiAgICAgICAgYW5ub3RDb2xvcnM6IHRoaXMuYW5ub3RDYXRlZ29yaWVzXG4gICAgfSk7XG5cblx0dmFyIGxpbWl0ZXJzID0gbmV3IFBJWEkuR3JhcGhpY3MoKVxuXHRcdC5saW5lU3R5bGUoMSwgMHg2NDY0NjQpXG5cdFx0Lm1vdmVUbyhhbm5vdHNSb2xsLmNvbnRhaW5lci54LCBhbm5vdHNSb2xsLmNvbnRhaW5lci55KVxuXHRcdC5saW5lVG8oYW5ub3RzUm9sbC5jb250YWluZXIueCwgYW5ub3RzUm9sbC5jb250YWluZXIueSAtIGFubm90c1JvbGwuaGVpZ2h0KVxuXHRcdC5tb3ZlVG8oYW5ub3RzUm9sbC5jb250YWluZXIueCArIGFubm90c1JvbGwud2lkdGhSb2xsLCBhbm5vdHNSb2xsLmNvbnRhaW5lci55KVxuXHRcdC5saW5lVG8oYW5ub3RzUm9sbC5jb250YWluZXIueCArIGFubm90c1JvbGwud2lkdGhSb2xsLCBhbm5vdHNSb2xsLmNvbnRhaW5lci55IC0gYW5ub3RzUm9sbC5oZWlnaHQpXG5cdFx0Lm1vdmVUbygwLCB0aGlzLmhlaWdodCAtIDIwMClcblx0XHQubGluZVRvKHRoaXMud2lkdGgsIHRoaXMuaGVpZ2h0IC0gMjAwKVxuXHRcdC5kcmF3UmVjdCgwLCAwLCB0aGlzLndpZHRoIC0xLCB0aGlzLmhlaWdodCAtMSlcblx0XHQuYmVnaW5GaWxsKDB4RUNFQ0VDKVxuXHRcdC5kcmF3UmVjdCgxMDI0IC0gMjAwLCAwLCAyMDAsIDc2OC0yMDApXG5cdFx0LmVuZEZpbGwoKTtcblx0dGhpcy5jb250YWluZXIuYWRkQ2hpbGQobGltaXRlcnMpO1xuXG4vL1x0dmFyIGRvdWJsZVJvbGxWID0gbmV3IERvdWJsZVJvbGwuRG91YmxlUm9sbCh7fSk7XG5cblx0dGhpcy5pbml0ID0gZnVuY3Rpb24oKXtcblxuXHR9XG5cblx0dGhpcy5zdGFydCA9IGZ1bmN0aW9uKCkge1xuICAgIH07XG5cbiAgICB0aGlzLnJlZnJlc2ggPSBmdW5jdGlvbigpIHtcbiAgICB9O1xuXG4gICAgdGhpcy5zdG9wID0gZnVuY3Rpb24oKXtcbiAgICB9O1xuXG4gICAgcmV0dXJuIHRoaXM7XG5cbn1cblxubW9kdWxlLmV4cG9ydHMgPSB7XG5cdEFubm90c1ZpelZpZXc6IEFubm90c1ZpelZpZXdcbn07XG4iLCIvKipcbiogc2NyaXB0cy9kb3VibGVyb2xsLmpzXG4qXG4qIFRoaXMgaXMgdGhlIHN0YXJ0aW5nIHBvaW50IGZvciB5b3VyIGFwcGxpY2F0aW9uLlxuKiBUYWtlIGEgbG9vayBhdCBodHRwOi8vYnJvd3NlcmlmeS5vcmcvIGZvciBtb3JlIGluZm9cbiovXG5cbi8qIGdsb2JhbCBkb2N1bWVudDogZmFsc2UgKi9cblxuJ3VzZSBzdHJpY3QnO1xuXG5cbnZhciBQSVhJID0gcmVxdWlyZSgncGl4aScpO1xudmFyIF8gPSByZXF1aXJlKCdsb2Rhc2gnKTtcbnZhciBQaWFub1JvbGwgPSByZXF1aXJlKCcuL3BpYW5vcm9sbC5qcycpO1xuXG52YXIgZGVmYXVsdENvbmZpZyA9IHtcbiAgICBvcmllbnRhdGlvbjogJ2hvcml6b250YWwnLFxuICAgIGxvZ2dlcjogdW5kZWZpbmVkLFxuICAgIHNjZW5lV2lkdGg6IDEwMjQsXG4gICAgcGlhbm9yb2xscyA6IFtcbiAgICAgIHtcbiAgICAgICAgaGVpZ2h0OiA0MzUsXG4gICAgICAgIHRpbWVXaWR0aDogMTAsXG4gICAgICAgIGxpbmVJbnRlcnZhbDogNTAwMCxcbiAgICAgICAgbm90ZUhlaWdodDogdW5kZWZpbmVkXG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBoZWlnaHQ6IDY0NSxcbiAgICAgICAgdGltZVdpZHRoOiA2MCxcbiAgICAgICAgbGluZUludGVydmFsOiA1MDAwLFxuICAgICAgICBub3RlSGVpZ2h0OiB1bmRlZmluZWRcbiAgICAgIH0sXG4gICAgXSxcbiAgICBmcmFtZXJhdGU6IDI1LFxuICAgIG9mZnNldE11c2ljOiBmYWxzZSxcbiAgICBzY2VuZUJnQ29sb3I6IDB4RkZGRkZGLFxuICAgIGxpbmVDb2xvcjogMHg0NDQ0NDQsXG4gICAgbGluZUZpbGxDb2xvcjogMHhGRkZGMDAsXG4gICAgbm90ZUNvbG9yczogWzB4QjkwMDAwLCAweDRCREQ3MSwgMHhBRjkzMUUsIDB4MUMyOEJBLCAweDUzNjk5MV0sXG4gICAgbm90ZUhlaWdodDogdW5kZWZpbmVkLFxuICAgIHplcm9TaGlmdDogMC45LFxuICAgIHRpbWVXaWR0aDogNjAsXG4gICAgbGluZUludGVydmFsOiA1MDAwLFxuLy8gICAgd3NVcmk6IHVuZGVmaW5lZCxcbi8vICAgIGV2ZW50Q29kZTogdW5kZWZpbmVkXG5cbn07XG5cbmZ1bmN0aW9uIERvdWJsZVJvbGwob3B0aW9ucykge1xuXG4gICAgdmFyIF90aGlzID0gdGhpcztcbiAgICB2YXIgb3B0cyA9IF8ob3B0aW9ucykuZGVmYXVsdHMoZGVmYXVsdENvbmZpZykudmFsdWUoKTtcblxuICAgIHZhciBvcmllbnRhdGlvbiA9IG9wdHMub3JpZW50YXRpb247XG4gICAgdmFyIGlzSG9yaXpvbnRhbCA9IChvcmllbnRhdGlvbiAhPT0gJ3ZlcnRpY2FsJyk7XG5cbiAgICB0aGlzLmxvZ2dlciA9IG9wdHMubG9nZ2VyO1xuICAgIHRoaXMubGluZUNvbG9yID0gb3B0cy5saW5lQ29sb3I7XG4gICAgdGhpcy5saW5lRmlsbENvbG9yID0gb3B0cy5saW5lRmlsbENvbG9yO1xuICAgIHRoaXMuZnJhbWVyYXRlID0gb3B0cy5mcmFtZXJhdGU7XG4gICAgdGhpcy5vZmZzZXRNdXNpYyA9IG9wdHMub2Zmc2V0TXVzaWM7XG4gICAgdGhpcy5ub3RlQ29sb3JzID0gb3B0cy5ub3RlQ29sb3JzO1xuXG4gICAgdmFyIG5vdGVIZWlnaHQgPSBvcHRzLm5vdGVIZWlnaHQ7XG4gICAgdmFyIHNjZW5lQmdDb2xvciA9IG9wdHMuc2NlbmVCZ0NvbG9yO1xuICAgIHZhciBzY2VuZUhlaWdodCA9IG9wdHMuc2NlbmVIZWlnaHQgfHwgXyhvcHRzLnBpYW5vcm9sbHMpLnJlZHVjZShmdW5jdGlvbihzLHApIHsgcmV0dXJuIHMgKyBwLmhlaWdodDsgfSwgMCk7XG4gICAgdmFyIHRpbWVXaWR0aCA9IG9wdHMudGltZVdpZHRoO1xuICAgIHZhciBsaW5lSW50ZXJ2YWwgPSBvcHRzLmxpbmVJbnRlcnZhbDtcbiAgICB2YXIgb2Zmc2V0TXVzaWMgPSBvcHRzLm9mZnNldE11c2ljO1xuXG4gICAgdmFyIHNjZW5lV2lkdGggPSBvcHRzLnNjZW5lV2lkdGg7XG4gICAgdmFyIHN0YWdlVmlldyA9IG9wdHMuc3RhZ2VWaWV3O1xuXG4gICAgdmFyIHplcm9TaGlmdCA9IG9wdHMuemVyb1NoaWZ0O1xuXG4gICAgdmFyIHdzID0gb3B0cy53cztcblxuICAgIHZhciBjb2xvcnNSZWcgPSB7fTtcblxuICAgIHRoaXMuY29udGFpbmVyID0gbmV3IFBJWEkuRGlzcGxheU9iamVjdENvbnRhaW5lcigpO1xuICAgIHRoaXMuY29udGFpbmVyLnggPSBNYXRoLmZsb29yKHNjZW5lV2lkdGgqemVyb1NoaWZ0KTtcbiAgICB0aGlzLmNvbnRhaW5lci55ID0gMDtcbiAgICBcbiAgICBzdGFnZVZpZXcucmVnaXN0ZXJDb21wb25lbnQodGhpcyk7XG5cbiAgICB2YXIgcGlhbm9yb2xsTGlzdCA9IFtdO1xuXG4gICAgdmFyIHBpYW5vcm9sbE9wdGlvbnMgPSB7XG4gICAgICAgIHBhcmVudENvbnRhaW5lcjogdGhpcy5jb250YWluZXIsXG4gICAgICAgIG9yaWVudGF0aW9uOiBvcmllbnRhdGlvbixcbiAgICAgICAgeEluaXQ6IDAsXG4gICAgICAgIHdpZHRoOiBzY2VuZVdpZHRoLFxuICAgICAgICBub3RlQ29sb3JzOiB0aGlzLm5vdGVDb2xvcnMsXG4gICAgICAgIGNvbG9yc1JlZzogY29sb3JzUmVnLFxuICAgICAgICBsaW5lQ29sb3I6IHRoaXMubGluZUNvbG9yLFxuICAgICAgICBsaW5lSW50ZXJ2YWw6IGxpbmVJbnRlcnZhbCxcbiAgICAgICAgb2Zmc2V0TXVzaWM6IG9mZnNldE11c2ljLFxuICAgIH07XG5cbiAgICB2YXIgeUluaXQgPSBvcHRzLnlJbml0IHx8IDA7XG4gICAgdmFyIGxpbmVzRG93biA9IHRydWU7XG4gICAgXyhvcHRzLnBpYW5vcm9sbHMpLmZvckVhY2goZnVuY3Rpb24ocHJEZWYsIGkpIHtcbiAgICAgICAgdmFyIHByTm90ZUhlaWdodCA9IG5vdGVIZWlnaHQgfHwgcHJEZWYubm90ZUhlaWdodCB8fCBwckRlZi5oZWlnaHQgLyAxMjg7XG4gICAgICAgIHZhciBwclRpbWVXaWR0aCA9IHByRGVmLnRpbWVXaWR0aCB8fCB0aW1lV2lkdGg7XG4gICAgICAgIHBpYW5vcm9sbExpc3QucHVzaChuZXcgUGlhbm9Sb2xsKF8oe1xuICAgICAgICAgICAgeUluaXQ6IHlJbml0LFxuICAgICAgICAgICAgaGVpZ2h0OiBwckRlZi5oZWlnaHQsXG4gICAgICAgICAgICBsaW5lc0Rvd246IGxpbmVzRG93bixcbiAgICAgICAgICAgIHBpeGVsc1BlclNlY29uZDogTWF0aC5mbG9vcihzY2VuZVdpZHRoIC8gcHJUaW1lV2lkdGgpLFxuICAgICAgICAgICAgbm90ZUhlaWdodDogcHJOb3RlSGVpZ2h0LFxuICAgICAgICAgICAgbGluZUludGVydmFsOiBwckRlZi5saW5lSW50ZXJ2YWxcbiAgICAgICAgfSkuZGVmYXVsdHMocGlhbm9yb2xsT3B0aW9ucykudmFsdWUoKSkpO1xuICAgICAgICB5SW5pdCArPSBwckRlZi5oZWlnaHQ7XG4gICAgICAgIGxpbmVzRG93biA9ICFsaW5lc0Rvd247XG5cbiAgICAgICAgaWYoaTwob3B0cy5waWFub3JvbGxzLmxlbmd0aC0xKSkge1xuICAgICAgICAgICAgdmFyIGxpbmVHcmFwaGljcyA9IG5ldyBQSVhJLkdyYXBoaWNzKClcbiAgICAgICAgICAgICAgICAuYmVnaW5GaWxsKF90aGlzLmxpbmVGaWxsQ29sb3IpXG4gICAgICAgICAgICAgICAgLmxpbmVTdHlsZSgxLCBfdGhpcy5saW5lQ29sb3IpXG4gICAgICAgICAgICAgICAgLm1vdmVUbyhNYXRoLmZsb29yKHNjZW5lV2lkdGgqemVyb1NoaWZ0KSwgeUluaXQpXG4gICAgICAgICAgICAgICAgLmxpbmVUbygtc2NlbmVXaWR0aCAtIE1hdGguZmxvb3Ioc2NlbmVXaWR0aCp6ZXJvU2hpZnQpLCB5SW5pdClcbiAgICAgICAgICAgICAgICAuZW5kRmlsbCgpO1xuICAgICAgICAgICAgX3RoaXMuY29udGFpbmVyLmFkZENoaWxkKGxpbmVHcmFwaGljcyk7XG4gICAgICAgIH1cbiAgICB9KTtcblxuICAgIGlmKCFpc0hvcml6b250YWwpIHtcbiAgICAgICAgdGhpcy5jb250YWluZXIucm90YXRpb24gPSBNYXRoLlBJLzI7XG4gICAgICAgIHRoaXMuY29udGFpbmVyLnkgPSBzY2VuZUhlaWdodDtcbiAgICAgICAgdGhpcy5jb250YWluZXIueCA9IHNjZW5lV2lkdGg7XG4gICAgfVxuXG5cbiAgICB0aGlzLmluaXQgPSBmdW5jdGlvbigpIHtcblxuICAgIFx0d3MubWVzc2FnZShmdW5jdGlvbihkYXRhKSB7XG4gICAgICAgICAgICBfdGhpcy5hZGROb3RlcyhkYXRhKTtcbiAgICAgICAgfSk7XG5cbiAgICB9O1xuXG5cbiAgICB0aGlzLmFkZE5vdGVzID0gZnVuY3Rpb24oZGF0YSkge1xuXG4gICAgICAgIHBpYW5vcm9sbExpc3QuZm9yRWFjaChmdW5jdGlvbihjKSB7XG4gICAgICAgICAgICBjLmFkZE5vdGVSYXcoZGF0YSk7XG4gICAgICAgIH0pO1xuICAgIH07XG5cbiAgICB0aGlzLnJlZnJlc2ggPSBmdW5jdGlvbigpIHtcbiAgICAgICAgcGlhbm9yb2xsTGlzdC5mb3JFYWNoKGZ1bmN0aW9uKGMpIHtcbiAgICAgICAgICAgIGMubW92ZSgpO1xuICAgICAgICB9KTtcbiAgICB9O1xuXG4gICAgLy8gSW5pdCBwYWdlIGFuZCBpbnRlcnZhbHNcbiAgICB2YXIgc3RhcnRUcztcblxuICAgIHRoaXMuc3RhcnQgPSBmdW5jdGlvbigpIHtcblxuICAgICAgICBzdGFydFRzID0gRGF0ZS5ub3coKTtcbiAgICAgICAgcGlhbm9yb2xsTGlzdC5mb3JFYWNoKGZ1bmN0aW9uKGMpIHtcbiAgICAgICAgICAgIGMuc3RhcnQoKTtcbiAgICAgICAgfSk7XG4gICAgfTtcblxuICAgIHRoaXMuc3RvcCA9IGZ1bmN0aW9uKCkge1xuICAgIFx0XG4gICAgICAgIHBpYW5vcm9sbExpc3QuZm9yRWFjaChmdW5jdGlvbihjKSB7XG4gICAgICAgICAgICBjLnN0b3AoKTtcbiAgICAgICAgfSk7XG4gICAgfTtcblxuXG4gICAgdGhpcy5sb2cgPSBmdW5jdGlvbihtKSB7XG4gICAgICAgIGlmKHRoaXMubG9nZ2VyKSB7XG4gICAgICAgICAgICB0aGlzLmxvZ2dlci5sb2cobSk7XG4gICAgICAgIH1cbiAgICB9O1xuXG5cblxuICAgIHJldHVybiB0aGlzO1xufVxuXG5tb2R1bGUuZXhwb3J0cyA9IHtcbiAgICBEb3VibGVSb2xsOiBEb3VibGVSb2xsXG59O1xuIiwiLyoqXG4qIGpzL3dzd3JhcHBlci5qc1xuKlxuKiBzaW1wbGUgbG9nZ2VyIHNlcnZpY2VcbipcbiovXG5cbi8qIGdsb2JhbCBkb2N1bWVudDogZmFsc2UgKi9cblxuJ3VzZSBzdHJpY3QnO1xuXG5mdW5jdGlvbiBIdG1sTG9nZ2VyKGRvTG9nLCBjb250YWluZXIpIHtcblxuICAgIHZhciBsb2dDb250YWluZXIgPSBjb250YWluZXI7XG4gICAgaWYodHlwZW9mKGNvbnRhaW5lcikgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgIGxvZ0NvbnRhaW5lciA9IGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKGNvbnRhaW5lcik7XG4gICAgfVxuICAgIGlmKCFkb0xvZykge1xuICAgICAgICBkb2N1bWVudC5ib2R5LnJlbW92ZUNoaWxkKGxvZ0NvbnRhaW5lcik7XG4gICAgICAgIGxvZ0NvbnRhaW5lciA9IHVuZGVmaW5lZDtcbiAgICB9XG5cblxuICAgIHRoaXMubG9nID0gZnVuY3Rpb24obXNnKSB7XG4gICAgICAgIGlmKGRvTG9nICYmIGxvZ0NvbnRhaW5lcikge1xuICAgICAgICAgICAgbG9nQ29udGFpbmVyLmlubmVySFRNTCArPSBtc2cgKyAnXFxuJztcbiAgICAgICAgICAgIGxvZ0NvbnRhaW5lci5zY3JvbGxUb3AgPSBsb2dDb250YWluZXIuc2Nyb2xsSGVpZ2h0O1xuICAgICAgICB9XG4gICAgfTtcbn1cblxuZnVuY3Rpb24gQ29uc29sZUxvZ2dlcihkb0xvZykge1xuXG4gICAgdGhpcy5sb2cgPSBmdW5jdGlvbihtc2cpIHtcbiAgICAgICAgaWYoZG9Mb2cpIHtcbiAgICAgICAgICAgIGNvbnNvbGUubG9nKG1zZyk7XG4gICAgICAgIH1cbiAgICB9XG5cbn1cblxubW9kdWxlLmV4cG9ydHMgPSB7XG4gICAgSHRtbExvZ2dlcjogSHRtbExvZ2dlcixcbiAgICBDb25zb2xlTG9nZ2VyOiBDb25zb2xlTG9nZ2VyXG59O1xuIiwiLyoqXG4qIGpzL3BpYW5vcm9sbC5qc1xuKlxuKiBwaWFub3JvbGwgYmFzaWMgY29tcG9uZW50XG4qXG4qL1xuXG4ndXNlIHN0cmljdCc7XG5cblxudmFyIFBJWEkgPSByZXF1aXJlKCdwaXhpJyk7XG52YXIgcmFuZG9tQ29sb3IgPSByZXF1aXJlKCdyYW5kb21Db2xvcicpO1xudmFyIF8gPSByZXF1aXJlKCdsb2Rhc2gnKTtcblxudmFyIE5UUF9FUE9DSF9ERUxUQSA9IDIyMDg5ODg4MDA7IC8vYy5mLiBSRkMgODY4XG5cbmZ1bmN0aW9uIFBpYW5vUm9sbChvcHRpb25zKSB7XG4gICAgdmFyIF90aGlzID0gdGhpcztcbiAgICB0aGlzLmNvbnRhaW5lciA9IG5ldyBQSVhJLkRpc3BsYXlPYmplY3RDb250YWluZXIoKTtcbiAgICB0aGlzLmNvbnRhaW5lci54ID0gb3B0aW9ucy54SW5pdDtcbiAgICB0aGlzLmNvbnRhaW5lci55ID0gb3B0aW9ucy55SW5pdDtcbiAgICBvcHRpb25zLnBhcmVudENvbnRhaW5lci5hZGRDaGlsZCh0aGlzLmNvbnRhaW5lcik7XG5cbiAgICB2YXIgb3JpZW50YXRpb24gPSBvcHRpb25zLm9yaWVudGF0aW9uO1xuICAgIHZhciBpc0hvcml6b250YWwgPSAob3JpZW50YXRpb24gIT09ICd2ZXJ0aWNhbCcpO1xuXG4gICAgdGhpcy5saW5lc0Rvd24gPSBvcHRpb25zLmxpbmVzRG93bjtcbiAgICB0aGlzLmhlaWdodCA9IG9wdGlvbnMuaGVpZ2h0O1xuICAgIHRoaXMucGl4ZWxzUGVyU2Vjb25kID0gb3B0aW9ucy5waXhlbHNQZXJTZWNvbmQ7XG4gICAgdGhpcy53aWR0aCA9IG9wdGlvbnMud2lkdGg7XG4gICAgdGhpcy5ub3RlQ29sb3JzID0gb3B0aW9ucy5ub3RlQ29sb3JzO1xuICAgIHRoaXMuY29sb3JzUmVnID0gb3B0aW9ucy5jb2xvcnNSZWcgfHwge307XG4gICAgdGhpcy5saW5lQ29sb3IgPSBvcHRpb25zLmxpbmVDb2xvcjtcbiAgICB0aGlzLmxpbmVJbnRlcnZhbCA9IG9wdGlvbnMubGluZUludGVydmFsO1xuICAgIHRoaXMub2Zmc2V0TXVzaWMgPSBvcHRpb25zLm9mZnNldE11c2ljIHx8IGZhbHNlO1xuICAgIHRoaXMubm90ZUhlaWdodCA9IG9wdGlvbnMubm90ZUhlaWdodDtcbiAgICB0aGlzLm5vdGVEaWN0ID0ge307XG4gICAgdGhpcy5zdGFydFRzID0gb3B0aW9ucy5zdGFydFRzIHx8IERhdGUubm93KCk7XG5cbiAgICB2YXIgc3RhcnRlZCA9IGZhbHNlO1xuXG4gICAgdmFyIGlzSGlkZGVuID0gZnVuY3Rpb24oY2hpbGQpIHtcbiAgICAgICAgLy8gVE9ETzogdGhlIG9yaWdpbiBwb2ludCBpcyBhbiBhcHByb3hpbWF0aW9uLiBTaG91bGQgcmVmaW5lIHRoaXNcbiAgICAgICAgdmFyIGdsb2JhbFBvcyA9IGNoaWxkLnRvR2xvYmFsKG5ldyBQSVhJLlBvaW50KDAsMCkpO1xuICAgICAgICByZXR1cm4gKChnbG9iYWxQb3MueCArIGNoaWxkLndpZHRoKSA8IDApIHx8ICgoZ2xvYmFsUG9zLnkgKyBjaGlsZC5oZWlnaHQpIDwgMCkgO1xuICAgIH07XG5cbiAgICAvL1RPRE86IEkgZG8gbm90IGxpa2UgdGhlIFwicmVnQ29sb3JcIiBvYmplY3QuIFRoaXMgc2hvdWxkIG5vdCBiZSBnbG9iYWwsIGJ1dCBsb2NhbFxuICAgIHRoaXMuZ2V0Q29sb3IgPSBmdW5jdGlvbihjYW5hbCkge1xuICAgICAgICB2YXIgY29sb3IgPSB0aGlzLmNvbG9yc1JlZ1tjYW5hbF07XG4gICAgICAgIGlmKHR5cGVvZihjb2xvcikgPT09ICd1bmRlZmluZWQnKSB7XG4gICAgICAgICAgICB2YXIgY29sb3JzUmVnU2l6ZSA9IE9iamVjdC5rZXlzKHRoaXMuY29sb3JzUmVnKS5sZW5ndGg7XG4gICAgICAgICAgICBpZihjb2xvcnNSZWdTaXplIDwgdGhpcy5ub3RlQ29sb3JzLmxlbmd0aCkge1xuICAgICAgICAgICAgICAgIGNvbG9yID0gdGhpcy5jb2xvcnNSZWdbY2FuYWxdID0gdGhpcy5ub3RlQ29sb3JzW2NvbG9yc1JlZ1NpemVdO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgZWxzZSB7XG4gICAgICAgICAgICAgICAgY29sb3IgPSB0aGlzLmNvbG9yc1JlZ1tjYW5hbF0gPSBwYXJzZUludChyYW5kb21Db2xvcih7IGx1bWlub3NpdHk6ICdsaWdodCcsIGh1ZTogJ3JhbmRvbScsIGZvcm1hdDonaGV4J30pLnJlcGxhY2UoL14jLywgJycpLCAxNik7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGNvbG9yO1xuICAgIH07XG5cbiAgICB0aGlzLmdldE5vdGVSZWN0ID0gZnVuY3Rpb24oeCwgeSwgY29sb3IsIGFscGhhLCB3aWR0aCwgaGVpZ2h0KSB7XG4gICAgICAgIHZhciBncmFwaGljcyA9IG5ldyBQSVhJLkdyYXBoaWNzKCk7XG4gICAgICAgIGdyYXBoaWNzLmJlZ2luRmlsbChjb2xvciwgYWxwaGEpO1xuICAgICAgICBncmFwaGljcy5kcmF3UmVjdCgwLCAwLCB3aWR0aCwgaGVpZ2h0KTtcbiAgICAgICAgZ3JhcGhpY3MuZW5kRmlsbCgpO1xuICAgICAgICBncmFwaGljcy54ID0geDtcbiAgICAgICAgZ3JhcGhpY3MueSA9IHk7XG4gICAgICAgIGdyYXBoaWNzLndpZHRoID0gd2lkdGg7XG4gICAgICAgIGdyYXBoaWNzLmhlaWdodCA9IGhlaWdodDtcbiAgICAgICAgcmV0dXJuIGdyYXBoaWNzO1xuICAgIH07XG5cbiAgICB0aGlzLmFkZE5vdGVSYXcgPSBmdW5jdGlvbihkYXRhKSB7XG4gICAgXHRjb25zb2xlLmxvZyhkYXRhKTtcbiAgICAgICAgdmFyIG5vdGUgPSBkYXRhLmNvbnRlbnRbM107XG4gICAgICAgIHZhciB2ZWxvY2l0eSA9IGRhdGEuY29udGVudFs0XTtcbiAgICAgICAgdmFyIHRzID0gKGRhdGEuY29udGVudFswXSAtIE5UUF9FUE9DSF9ERUxUQSkqMTAwMDtcbiAgICAgICAgdmFyIGNoYW5uZWwgPSBkYXRhLmNvbnRlbnRbMl07XG4gICAgICAgIHZhciBzZXNzaW9uVHMgPSBkYXRhLmNvbnRlbnRbMV07XG5cbiAgICAgICAgdGhpcy5hZGROb3RlKG5vdGUsIHRzLCBzZXNzaW9uVHMsIHZlbG9jaXR5LCBjaGFubmVsLCAwKTtcbiAgICB9O1xuXG4gICAgdGhpcy5hZGROb3RlID0gZnVuY3Rpb24obm90ZSwgc3RhcnRUaW1lLCBzZXNzaW9uVHMsIHZlbG9jaXR5LCBjaGFubmVsLCBkdXJhdGlvbikge1xuXG4gICAgICAgIHZhciB0cyA9IHN0YXJ0VGltZTtcbiAgICAgICAgaWYodGhpcy5vZmZzZXRNdXNpYykge1xuICAgICAgICAgICAgdHMgPSB0aGlzLnN0YXJ0VHMgKyBzZXNzaW9uVHM7XG4gICAgICAgIH1cblxuICAgICAgICB2YXIgbm90ZUR1cmF0aW9uID0gZHVyYXRpb247XG4gICAgICAgIHZhciBub3RlVmVsb2NpdHkgPSB2ZWxvY2l0eTtcbiAgICAgICAgdmFyIGdyYXBoaWNzO1xuICAgICAgICBpZighZHVyYXRpb24pIHtcbiAgICAgICAgICAgIGlmKHR5cGVvZiB0aGlzLm5vdGVEaWN0W2NoYW5uZWxdPT09J3VuZGVmaW5lZCcpe1xuICAgICAgICAgICAgICAgIHRoaXMubm90ZURpY3RbY2hhbm5lbF0gPSB7fTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGlmKHZlbG9jaXR5PT09MCkge1xuICAgICAgICAgICAgICAgIGlmKHR5cGVvZiB0aGlzLm5vdGVEaWN0W2NoYW5uZWxdW25vdGVdICE9PSAndW5kZWZpbmVkJykge1xuICAgICAgICAgICAgICAgICAgICB2YXIgbm90ZURlZiA9IHRoaXMubm90ZURpY3RbY2hhbm5lbF1bbm90ZV07XG4gICAgICAgICAgICAgICAgICAgIGRlbGV0ZSB0aGlzLm5vdGVEaWN0W2NoYW5uZWxdW25vdGVdO1xuICAgICAgICAgICAgICAgICAgICBub3RlRHVyYXRpb24gPSBzZXNzaW9uVHMgLSBub3RlRGVmLnNlc3Npb25UcztcbiAgICAgICAgICAgICAgICAgICAgZ3JhcGhpY3MgPSBub3RlRGVmLmdyYXBoaWNzO1xuICAgICAgICAgICAgICAgICAgICBub3RlVmVsb2NpdHkgPSBub3RlRGVmLnZlbG9jaXR5O1xuICAgICAgICAgICAgICAgICAgICB0cyA9IG5vdGVEZWYudHM7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgZWxzZSB7XG4gICAgICAgICAgICAgICAgbm90ZUR1cmF0aW9uID0gRGF0ZS5ub3coKSAtIHRzO1xuICAgICAgICAgICAgICAgIHRoaXMubm90ZURpY3RbY2hhbm5lbF1bbm90ZV0gPSB7IHRzOiB0cywgdmVsb2NpdHk6IHZlbG9jaXR5LCBzZXNzaW9uVHM6IHNlc3Npb25Uc307XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cblxuXG4gICAgICAgIGlmKCF0aGlzLm9mZnNldE11c2ljIHx8IHZlbG9jaXR5PT09MCkge1xuXG4gICAgICAgICAgICB2YXIgd2lkdGggPSBub3RlRHVyYXRpb24gKiB0aGlzLnBpeGVsc1BlclNlY29uZCAvIDEwMDA7XG4gICAgICAgICAgICBpZighZ3JhcGhpY3MpIHtcbiAgICAgICAgICAgICAgICB2YXIgeCA9ICh0cy10aGlzLnN0YXJ0VHMpICogdGhpcy5waXhlbHNQZXJTZWNvbmQgLyAxMDAwO1xuICAgICAgICAgICAgICAgIGlmKCh4K3dpZHRoKSA8ICAoTWF0aC5hYnModGhpcy5jb250YWluZXIueCkgLSB0aGlzLndpZHRoKSkge1xuICAgICAgICAgICAgICAgICAgICAvLyBub3QgdmlzaWJsZS4gZG8gbm90aGluZ1xuICAgICAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIHZhciB5ID0gTWF0aC5mbG9vcigoMTI4LW5vdGUrMC41KSAqIHRoaXMuaGVpZ2h0IC8gMTI4IC0gKHRoaXMubm90ZUhlaWdodC8yKSk7XG4gICAgICAgICAgICAgICAgdmFyIGNvbG9yID0gdGhpcy5nZXRDb2xvcihjaGFubmVsKTtcbiAgICAgICAgICAgICAgICB2YXIgYWxwaGEgPSAobm90ZVZlbG9jaXR5IC8gMTI4KTtcblxuICAgICAgICAgICAgICAgIGdyYXBoaWNzID0gdGhpcy5nZXROb3RlUmVjdCh4LCB5LCBjb2xvciwgYWxwaGEsIHdpZHRoLCB0aGlzLm5vdGVIZWlnaHQpO1xuICAgICAgICAgICAgICAgIHRoaXMuY29udGFpbmVyLmFkZENoaWxkKGdyYXBoaWNzKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGVsc2Uge1xuICAgICAgICAgICAgICAgIGdyYXBoaWNzLndpZHRoID0gd2lkdGg7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGlmKCFkdXJhdGlvbiAmJiB2ZWxvY2l0eSkge1xuICAgICAgICAgICAgICAgIHRoaXMubm90ZURpY3RbY2hhbm5lbF1bbm90ZV0uZ3JhcGhpY3MgPSBncmFwaGljcztcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH07XG5cbiAgICB0aGlzLmFkZExpbmUgPSBmdW5jdGlvbih0cyl7XG5cbiAgICAgICAgaWYodHlwZW9mKHRzKSA9PT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgICAgICAgIHRzID0gbmV3IERhdGUoKTtcbiAgICAgICAgfVxuICAgICAgICB2YXIgeCA9IC10aGlzLmNvbnRhaW5lci54O1xuICAgICAgICB2YXIgeSA9IHRoaXMubGluZXNEb3duID8gdGhpcy5oZWlnaHQgLSAyMCA6IDA7XG5cbiAgICAgICAgdmFyIGdyYXBoaWNzID0gbmV3IFBJWEkuR3JhcGhpY3MoKVxuICAgICAgICAgICAgLmJlZ2luRmlsbCgweEZGRkYwMClcbiAgICAgICAgICAgIC5saW5lU3R5bGUoMSwgdGhpcy5saW5lQ29sb3IpXG4gICAgICAgICAgICAubW92ZVRvKDAsIDApXG4gICAgICAgICAgICAubGluZVRvKDAsIDIwKVxuICAgICAgICAgICAgLmVuZEZpbGwoKTtcbiAgICAgICAgZ3JhcGhpY3MueCA9IHg7XG4gICAgICAgIGdyYXBoaWNzLnkgPSB5O1xuICAgICAgICB0aGlzLmNvbnRhaW5lci5hZGRDaGlsZChncmFwaGljcyk7XG4gICAgICAgIC8vIEFkZCB0ZXh0XG4gICAgICAgIC8vdmFyIHRvdGFsU2VjID0gbGluZU5iICogdGhpcy5saW5lSW50ZXJ2YWwgLyAxMDAwO1xuICAgICAgICB2YXIgaG91cnMgPSB0cy5nZXRIb3VycygpO1xuICAgICAgICB2YXIgbWludXRlcyA9dHMuZ2V0TWludXRlcygpO1xuICAgICAgICB2YXIgc2Vjb25kcyA9IHRzLmdldFNlY29uZHMoKTtcbiAgICAgICAgdmFyIHRpbWVTdHIgPSAoaG91cnMgPCAxMCA/ICcwJyArIGhvdXJzIDogaG91cnMpICsgJzonICsgKG1pbnV0ZXMgPCAxMCA/ICcwJyArIG1pbnV0ZXMgOiBtaW51dGVzKSArICc6JyArIChzZWNvbmRzICA8IDEwID8gJzAnICsgc2Vjb25kcyA6IHNlY29uZHMpO1xuXG4gICAgICAgIHZhciBmb250T2JqID0geyBmb250OiAnMTBwdCBBcmlhbCcsIGZpbGw6ICcjNDQ0NDQ0JyB9O1xuICAgICAgICB2YXIgdCA9IG5ldyBQSVhJLlRleHQodGltZVN0ciwgZm9udE9iaik7XG4gICAgICAgIGlmKGlzSG9yaXpvbnRhbCkge1xuICAgICAgICAgICAgdC54ID0geCArIDI7XG4gICAgICAgICAgICB0LnkgPSB0aGlzLmxpbmVzRG93biA/IHRoaXMuaGVpZ2h0IC0gMTUgOiAyO1xuICAgICAgICB9XG4gICAgICAgIGVsc2Uge1xuICAgICAgICAgICAgdC5yb3RhdGlvbiA9IC1NYXRoLlBJLzI7XG4gICAgICAgICAgICB0LnggPSB4IDtcbiAgICAgICAgICAgIHQueSA9IHRoaXMubGluZXNEb3duID8gdGhpcy5oZWlnaHQgLSAyIDogdC53aWR0aCArIDI7XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5jb250YWluZXIuYWRkQ2hpbGQodCk7XG4gICAgfTtcblxuICAgIHRoaXMubW92ZVRvID0gZnVuY3Rpb24oZGlmZlRpbWUpe1xuICAgICAgICB2YXIgb2xkWCA9IHRoaXMuY29udGFpbmVyLng7XG4gICAgICAgIHRoaXMuY29udGFpbmVyLnggPSBNYXRoLmZsb29yKGRpZmZUaW1lKnRoaXMucGl4ZWxzUGVyU2Vjb25kKTtcbiAgICAgICAgdmFyIGRlbHRhWCA9IE1hdGguYWJzKG9sZFgtdGhpcy5jb250YWluZXIueCk7XG4gICAgICAgIF8uZm9yT3duKHRoaXMubm90ZURpY3QsIGZ1bmN0aW9uKGNoYW5uZWxEaWN0KSB7XG4gICAgICAgICAgICBfLmZvck93bihjaGFubmVsRGljdCwgZnVuY3Rpb24obm90ZURlZikge1xuICAgICAgICAgICAgICAgIGlmKG5vdGVEZWYuZ3JhcGhpY3MpIHtcbiAgICAgICAgICAgICAgICAgICAgbm90ZURlZi5ncmFwaGljcy53aWR0aCA9IG5vdGVEZWYuZ3JhcGhpY3Mud2lkdGggKyBkZWx0YVg7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfSk7XG4gICAgICAgIH0pO1xuICAgIH07XG5cbiAgICB0aGlzLm1vdmUgPSBmdW5jdGlvbigpIHtcbiAgICAgICAgdmFyIGRpZmYgPSAodGhpcy5zdGFydFRzIC0gRGF0ZS5ub3coKSkvMTAwMDtcbiAgICAgICAgdGhpcy5tb3ZlVG8oZGlmZik7XG4gICAgfTtcblxuICAgIHRoaXMucmVtb3ZlUGFzc2VkT2JqZXRzID0gZnVuY3Rpb24oKXtcbiAgICAgICAgdmFyIGNoaWxkcmVuVG9SZW1vdmUgPSBbXTtcbiAgICAgICAgXyhfdGhpcy5jb250YWluZXIuY2hpbGRyZW4pLmZvckVhY2goZnVuY3Rpb24oY2hpbGQpIHtcbiAgICAgICAgICAgIHJldHVybiB0eXBlb2YoY2hpbGQpID09PSAndW5kZWZpbmVkJyB8fFxuICAgICAgICAgICAgICAgIChpc0hpZGRlbihjaGlsZCkgJiYgY2hpbGRyZW5Ub1JlbW92ZS5wdXNoKGNoaWxkKSk7XG4gICAgICAgIH0pO1xuICAgICAgICBjaGlsZHJlblRvUmVtb3ZlLmZvckVhY2goZnVuY3Rpb24oY2hpbGQpIHtcbiAgICAgICAgICAgIF90aGlzLmNvbnRhaW5lci5yZW1vdmVDaGlsZChjaGlsZCk7XG4gICAgICAgIH0pO1xuICAgIH07XG5cbiAgICB0aGlzLnN0YXJ0ID0gZnVuY3Rpb24oKSB7XG4gICAgICAgIGlmKCFzdGFydGVkKSB7XG4gICAgICAgICAgICB0aGlzLnN0YXJ0VHMgPSBEYXRlLm5vdygpO1xuICAgICAgICAgICAgdGhpcy5hZGRMaW5lKCk7XG4gICAgICAgICAgICBzdGFydGVkID0gdHJ1ZTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLnZlcnRpY2FsTGluZXNJbnRlcnZhbCA9IHNldEludGVydmFsKGZ1bmN0aW9uKCkgeyBfdGhpcy5hZGRMaW5lKCk7IH0sIHRoaXMubGluZUludGVydmFsKTtcbiAgICAgICAgdGhpcy5jbGVhbkludGVydmFsID0gc2V0SW50ZXJ2YWwoZnVuY3Rpb24gKCkgeyBfdGhpcy5yZW1vdmVQYXNzZWRPYmpldHMoKTsgfSwgMTAwMCAqIHRoaXMud2lkdGggLyB0aGlzLnBpeGVsc1BlclNlY29uZCApO1xuICAgIH07XG5cbiAgICB0aGlzLnN0b3AgPSBmdW5jdGlvbigpIHtcbiAgICAgICAgLy93aW5kb3cuY2xlYXJJbnRlcnZhbCh0aGlzLm1vdmVJbnRlcnZhbCk7XG4gICAgICAgIGNsZWFySW50ZXJ2YWwodGhpcy52ZXJ0aWNhbExpbmVzSW50ZXJ2YWwpO1xuICAgICAgICBjbGVhckludGVydmFsKHRoaXMuY2xlYW5JbnRlcnZhbCk7XG4gICAgfTtcblxuXG59XG5cbm1vZHVsZS5leHBvcnRzID0gUGlhbm9Sb2xsO1xuIiwiLyoqXG4qIHNjcmlwdHMvc3RhZ2V2aWV3LmpzXG4qXG4qIFRoaXMgaXMgdGhlIHN0YXJ0aW5nIHBvaW50IGZvciB5b3VyIGFwcGxpY2F0aW9uLlxuKiBUYWtlIGEgbG9vayBhdCBodHRwOi8vYnJvd3NlcmlmeS5vcmcvIGZvciBtb3JlIGluZm9cbiovXG5cbi8qIGdsb2JhbCBkb2N1bWVudDogZmFsc2UgKi9cblxuJ3VzZSBzdHJpY3QnO1xuXG5cbnZhciBQSVhJID0gcmVxdWlyZSgncGl4aScpO1xudmFyIF8gPSByZXF1aXJlKCdsb2Rhc2gnKTtcblxudmFyIGRlZmF1bHRDb25maWcgPSB7XG4gICAgZXh0ZXJuYWxSZWZyZXNoOiBmYWxzZSxcbiAgICBsb2dnZXI6IHVuZGVmaW5lZCxcbiAgICBzY2VuZVdpZHRoOiAxMDI0LFxuICAgIHNjZW5lSGVpZ2h0OiA3NjgsXG4gICAgZnJhbWVyYXRlOiAyNSxcbiAgICBzY2VuZUJnQ29sb3I6IDB4RkZGRkZGLFxuICAgIGNhbnZhc0NvbnRhaW5lcjogJ2NhbnZhc0NvbnRhaW5lcicsXG59O1xuXG5mdW5jdGlvbiBTdGFnZVZpZXcob3B0aW9ucykge1xuXG4gICAgdmFyIF90aGlzID0gdGhpcztcbiAgICB2YXIgb3B0cyA9IF8ob3B0aW9ucykuZGVmYXVsdHMoZGVmYXVsdENvbmZpZykudmFsdWUoKTtcblxuICAgIHZhciBleHRlcm5hbFJlZnJlc2ggPSBvcHRzLmV4dGVybmFsUmVmcmVzaDtcblxuICAgIHRoaXMubG9nZ2VyID0gb3B0cy5sb2dnZXI7XG4gICAgdGhpcy5mcmFtZXJhdGUgPSBvcHRzLmZyYW1lcmF0ZTtcbiAgICB2YXIgc2NlbmVCZ0NvbG9yID0gb3B0cy5zY2VuZUJnQ29sb3I7XG4gICAgdmFyIHNjZW5lV2lkdGggPSBvcHRzLnNjZW5lV2lkdGg7XG4gICAgdmFyIHNjZW5lSGVpZ2h0ID0gb3B0cy5zY2VuZUhlaWdodDtcbiAgICB2YXIgY2FudmFzQ29udGFpbmVyID0gb3B0cy5jYW52YXNDb250YWluZXI7XG4gICAgdmFyIHRpbWVDb250YWluZXIgPSBbXTtcbiAgICB2YXIgY29tcG9uZW50cyA9IFtdOyBcbiAgICBcbiAgICAvL2NyZWF0ZSBhbiBuZXcgaW5zdGFuY2Ugb2YgYSBwaXhpIHN0YWdlXG4gICAgdGhpcy5zdGFnZSA9IG5ldyBQSVhJLlN0YWdlKHNjZW5lQmdDb2xvcik7XG4gICAgLy9jcmVhdGUgYSByZW5kZXJlciBpbnN0YW5jZS5cbiAgICB2YXIgcmVuZGVyZXIgPSBQSVhJLmF1dG9EZXRlY3RSZW5kZXJlcihzY2VuZVdpZHRoLCBzY2VuZUhlaWdodCk7XG4gICAgXHRcbiAgICB0aGlzLmluaXQgPSBmdW5jdGlvbigpIHtcblxuICAgICAgICBpZih0eXBlb2YoY2FudmFzQ29udGFpbmVyKSA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgICAgIGNhbnZhc0NvbnRhaW5lciA9IGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKGNhbnZhc0NvbnRhaW5lcik7XG4gICAgICAgIH1cbiAgICAgICAgaWYodHlwZW9mKHRpbWVDb250YWluZXIpID09PSAnc3RyaW5nJykge1xuICAgICAgICAgICAgdGltZUNvbnRhaW5lciA9IGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKHRpbWVDb250YWluZXIpO1xuICAgICAgICB9XG5cbiAgICAgICAgY2FudmFzQ29udGFpbmVyLmFwcGVuZENoaWxkKHJlbmRlcmVyLnZpZXcpO1xuICAgICAgICBcbiAgICAgICAgY29tcG9uZW50cy5mb3JFYWNoKGZ1bmN0aW9uKGMpe1xuICAgIFx0XHRjLmluaXQoKTtcbiAgICBcdH0pO1xuICAgIH07XG4gICAgXG4gICAgdGhpcy5yZWdpc3RlclRpbWVDb250YWluZXIgPSBmdW5jdGlvbihjb250YWluZXIpIHtcbiAgICBcdHRpbWVDb250YWluZXIucHVzaChjb250YWluZXIpO1xuICAgIH07XG4gICAgXG4gICAgdGhpcy5yZWdpc3RlckNvbXBvbmVudCA9IGZ1bmN0aW9uKGNvbXBvbmVudCkge1xuICAgIFx0Y29tcG9uZW50cy5wdXNoKGNvbXBvbmVudCk7XG4gICAgXHR0aGlzLnN0YWdlLmFkZENoaWxkKGNvbXBvbmVudC5jb250YWluZXIpO1xuICAgIH07XG5cbiAgICB0aGlzLnJlZnJlc2ggPSBmdW5jdGlvbigpIHtcbiAgICBcdGNvbXBvbmVudHMuZm9yRWFjaChmdW5jdGlvbihjKXtcbiAgICBcdFx0Yy5yZWZyZXNoKCk7XG4gICAgXHR9KTtcbiAgICAgICAgcmVuZGVyZXIucmVuZGVyKHRoaXMuc3RhZ2UpO1xuICAgIH07XG5cbiAgICAvLyBJbml0IHBhZ2UgYW5kIGludGVydmFsc1xuICAgIHZhciByZWZyZXNoSW50ZXJ2YWw7XG5cbiAgICB0aGlzLnN0YXJ0ID0gZnVuY3Rpb24oKSB7XG5cbiAgICAgICAgaWYoIWV4dGVybmFsUmVmcmVzaCkge1xuICAgICAgICAgICAgcmVmcmVzaEludGVydmFsID0gc2V0SW50ZXJ2YWwoZnVuY3Rpb24oKSB7X3RoaXMucmVmcmVzaCgpO30sIDEwMDAvdGhpcy5mcmFtZXJhdGUpO1xuICAgICAgICB9XG4gICAgICAgIFxuICAgICAgICBjb21wb25lbnRzLmZvckVhY2goZnVuY3Rpb24oYyl7XG4gICAgXHRcdGMuc3RhcnQoKTtcbiAgICBcdH0pO1xuICAgIH07XG5cbiAgICB0aGlzLnN0b3AgPSBmdW5jdGlvbigpIHtcbiAgICAgICAgaWYoIWV4dGVybmFsUmVmcmVzaCkge1xuICAgICAgICAgICAgY2xlYXJJbnRlcnZhbChyZWZyZXNoSW50ZXJ2YWwpO1xuICAgICAgICB9XG4gICAgICAgIGNsZWFySW50ZXJ2YWwocmVmcmVzaFRpbWVJbnRlcnZhbCk7XG4gICAgICAgIFxuICAgICAgICBjb21wb25lbnRzLmZvckVhY2goZnVuY3Rpb24oYyl7XG4gICAgXHRcdGMuc3RvcCgpO1xuICAgIFx0fSk7XG4gICAgfTtcblxuXG4gICAgdGhpcy5sb2cgPSBmdW5jdGlvbihtKSB7XG4gICAgICAgIGlmKHRoaXMubG9nZ2VyKSB7XG4gICAgICAgICAgICB0aGlzLmxvZ2dlci5sb2cobSk7XG4gICAgICAgIH1cbiAgICB9O1xuXG5cbiAgICByZXR1cm4gdGhpcztcbn1cblxubW9kdWxlLmV4cG9ydHMgPSB7XG4gICAgU3RhZ2VWaWV3OiBTdGFnZVZpZXdcbn07XG4iLCIvKipcbioganMvdXRpbHMuanNcbipcbiogYmFzaWMgdG9vbHNcbipcbiovXG5cbid1c2Ugc3RyaWN0JztcblxuZnVuY3Rpb24gZm9ybWF0VGltZSAodHMpIHtcblx0dmFyIGhvdXJzID0gTWF0aC5mbG9vciggKHRzLzEwMDApIC8gMzYwMCApICUgMjQ7XG5cdHZhciBtaW51dGVzID0gTWF0aC5mbG9vciggKHRzLzEwMDApIC8gNjAgKSAlIDYwO1xuXHR2YXIgc2Vjb25kcyA9IE1hdGguZmxvb3IoICh0cy8xMDAwKSAlIDYwKTtcblx0cmV0dXJuICgoaG91cnMgPCAxMCA/ICcwJyArIGhvdXJzIDogaG91cnMpICsgJzonICsgKG1pbnV0ZXMgPCAxMCA/ICcwJyArIG1pbnV0ZXMgOiBtaW51dGVzKSArICc6JyArIChzZWNvbmRzICA8IDEwID8gJzAnICsgc2Vjb25kcyA6IHNlY29uZHMpKTtcbn1cblxuXG5tb2R1bGUuZXhwb3J0cyA9IHtcblx0Zm9ybWF0VGltZTogZm9ybWF0VGltZVxufTtcbiIsIi8qKlxuKiBqcy93c3dyYXBwZXIuanNcbipcbiogc2ltcGxlIHdlYnNlcnZpY2Ugd3JhcHBlciB0byByZWdpc3RlciBjYWxsYmFja3Mgb24gb25tZXNzYWdlXG4qXG4qL1xuXG4vKiBnbG9iYWwgV2ViU29ja2V0OiBmYWxzZSAqL1xuXG4ndXNlIHN0cmljdCc7XG5cbmZ1bmN0aW9uIFdzV3JhcHBlcih3c3VybCwgbG9nZ2VyKSB7XG5cbiAgICB2YXIgdXJsID0gd3N1cmw7XG4gICAgdmFyIHNvY2sgPSBuZXcgV2ViU29ja2V0KHVybCk7XG4gICAgdmFyIGxvZ2dlck9iaiA9IGxvZ2dlcjtcblxuICAgIHZhciBsb2cgPSBmdW5jdGlvbihtc2cpIHtcbiAgICAgICAgaWYobG9nZ2VyT2JqKSB7XG4gICAgICAgICAgICBsb2dnZXJPYmoubG9nKG1zZyk7XG4gICAgICAgIH1cbiAgICB9O1xuXG4gICAgdmFyIGhhbmRsZXJzID0gW107XG5cbiAgICBzb2NrLm9ub3BlbiA9IGZ1bmN0aW9uKCkge1xuICAgICAgICBsb2coJ0Nvbm5lY3RlZCB0byAnICsgdXJsKTtcbiAgICB9O1xuXG4gICAgc29jay5vbmNsb3NlID0gZnVuY3Rpb24oZSkge1xuICAgICAgICBsb2coJ0Nvbm5lY3Rpb24gY2xvc2VkICh3YXNDbGVhbiA9ICcgKyBlLndhc0NsZWFuICsgJywgY29kZSA9ICcgKyBlLmNvZGUgKyAnLCByZWFzb24gPSBcXCcnICsgZS5yZWFzb24gKyAnXFwnKScpO1xuICAgICAgICBzb2NrID0gbnVsbDtcbiAgICB9O1xuXG4gICAgc29jay5vbm1lc3NhZ2UgPSBmdW5jdGlvbihlKSB7XG4gICAgICAgIGxvZygncmVjZWl2ZWQgJyArIGUuZGF0YSk7XG4gICAgICAgIHZhciBkYXRhID0gSlNPTi5wYXJzZShlLmRhdGEpO1xuICAgICAgICBoYW5kbGVycy5mb3JFYWNoKGZ1bmN0aW9uKGhhbmRsZXIpIHtcbiAgICAgICAgICAgIGhhbmRsZXIoZGF0YSk7XG4gICAgICAgIH0pO1xuICAgIH07XG5cbiAgICB0aGlzLm1lc3NhZ2UgPSBmdW5jdGlvbihoYW5kbGVyKSB7XG4gICAgICAgIGlmKGhhbmRsZXIpIHtcbiAgICAgICAgICAgIGhhbmRsZXJzLnB1c2goaGFuZGxlcik7XG4gICAgICAgIH1cbiAgICB9O1xuXG59XG5cbm1vZHVsZS5leHBvcnRzID0ge1xuICAgIFdzV3JhcHBlcjogV3NXcmFwcGVyXG59O1xuIl19