timeline/js/timeline.js
author veltr
Wed, 04 Jul 2012 16:13:49 +0200
changeset 73 642ef9139fad
parent 72 a000f6a29dfa
child 74 e107c77600e8
permissions -rw-r--r--
Replaced "Production" by "Publication". Added beautiful arrows
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
     1
/*
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
     2
 * Main Timeline code
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
     3
 */
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
     4
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
     5
window.Tlns = {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
     6
    Utils : {},
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
     7
    Defaults : {},
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
     8
    Templates : {},
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
     9
    Classes : {}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    10
};
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    11
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    12
/* Utility Functions */
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    13
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    14
Tlns.Utils.SetDefaults = function(_object, _defaults, _options) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    15
    var _options = _options || {};
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    16
    _(_defaults).each(function(_v, _k) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    17
        if(/^m(in|ax)_/.test(_k)) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    18
            var _tab = _k.split('_')
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    19
            if( typeof _object[_tab[1]] !== "undefined") {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    20
                var _fn = (_tab[0] === "min" ? Math.max : Math.min);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    21
                _object[_tab[1]] = _fn(_object[_tab[1]], _v);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    22
            }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    23
        } else {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    24
            if( typeof _options[_k] !== "undefined") {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    25
                _object[_k] = _options[_k];
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    26
            } else {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    27
                _object[_k] = _v;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    28
            }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    29
        }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    30
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    31
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    32
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    33
Tlns.Utils.dateFormat = function(_date, _template) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    34
    if (typeof _data !== "object") {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    35
        _date = new Date(_date);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    36
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    37
    function zeroPad(_n) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    38
        return (_n < 10 ? "0" : "") + _n
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    39
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    40
    var _params = {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    41
        hours: _date.getHours(),
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    42
        "0hours": zeroPad(_date.getHours()),
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    43
        minutes: _date.getMinutes(),
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    44
        "0minutes": zeroPad(_date.getMinutes()),
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    45
        seconds: _date.getSeconds(),
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    46
        "0seconds": zeroPad(_date.getSeconds()),
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    47
        dayOfWeek: ["dimanche","lundi","mardi","mercredi","jeudi","vendredi","samedi"][_date.getDay()],
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    48
        shortDayOfWeek: ["Dim","Lun","Mar","Mer","Jeu","Ven","Sam"][_date.getDay()],
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    49
        dayOfMonth: _date.getDate(),
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    50
        "0dayOfMonth": zeroPad(_date.getDate()),
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    51
        monthNumber: 1+_date.getMonth(),
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    52
        "0monthNumber": zeroPad(1+_date.getMonth()),
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    53
        monthName: ["janvier","février","mars","avril","mai","juin","juillet","août","septembre","octobre","novembre","décembre"][_date.getMonth()],
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    54
        shortMonthName: ["jan","fev","mar","avr","mai","jun","jul","aou","sep","oct","nov","dec"][_date.getMonth()],
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    55
        year: _date.getFullYear()
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    56
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    57
    return Mustache.to_html(_template, _params);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    58
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    59
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
    60
Tlns.Utils.guid = function() {
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
    61
    return 'xxxx-xxxx-xxxx-xxxx'.replace(/x/g,function() {
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
    62
        return Math.floor(Math.random()*16).toString(16);
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
    63
    });
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
    64
}
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
    65
73
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    66
Tlns.Utils.drawArrow = function(_ctx, _color, _x1, _y1, _x2, _y2) {
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    67
    _ctx.strokeStyle = _color;
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    68
    _ctx.fillStyle = _color;
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    69
    _ctx.beginPath();
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    70
    _ctx.moveTo(_x1,_y1);
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    71
    _ctx.lineTo(_x2,_y2);
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    72
    _ctx.stroke();
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    73
    var _mod = Math.sqrt(Math.pow(_x2 - _x1, 2) + Math.pow(_y2 - _y1, 2)),
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    74
        _xu = (_x2 - _x1) / _mod,
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    75
        _yu = (_y2 - _y1) / _mod,
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    76
        _xm = (_x1 + _x2) / 2,
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    77
        _ym = (_y1 + _y2) / 2,
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    78
        _arrowWidth = 4,
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    79
        _arrowLength = 8,
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    80
        _x3 = _xm - _arrowLength * _xu + _arrowWidth * _yu,
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    81
        _y3 = _ym - _arrowLength * _yu - _arrowWidth * _xu,
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    82
        _x4 = _xm - _arrowLength * _xu - _arrowWidth * _yu,
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    83
        _y4 = _ym - _arrowLength * _yu + _arrowWidth * _xu;
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    84
    _ctx.beginPath();
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    85
    _ctx.moveTo(_x3, _y3);
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    86
    _ctx.lineTo(_xm, _ym);
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    87
    _ctx.lineTo(_x4, _y4);
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    88
    _ctx.fill();
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    89
    _ctx.stroke();
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    90
}
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
    91
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    92
/* Defaults */
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    93
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    94
Tlns.Defaults.Timeline = {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    95
    container : "timeline",
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    96
    width : 950,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    97
    height : 200,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    98
    url_univers : '',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    99
    min_width : 400,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   100
    min_height : 100,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   101
    main_width : 800,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   102
    timescales : [{
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   103
        label : "Mois",
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   104
        span : 32 * 86400 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   105
        grid_interval : 5 * 86400 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   106
        grid_date_format : '{{dayOfMonth}} {{shortMonthName}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   107
        start_date_format : '{{dayOfMonth}} {{shortMonthName}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   108
        end_date_format : '{{dayOfMonth}} {{shortMonthName}} {{year}}'
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   109
    }, {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   110
        label : "Semaine",
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   111
        span : 8 * 86400 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   112
        grid_interval : 86400 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   113
        grid_date_format : '{{shortDayOfWeek}} {{0dayOfMonth}}/{{0monthNumber}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   114
        start_date_format : '{{dayOfMonth}} {{shortMonthName}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   115
        end_date_format : '{{dayOfMonth}} {{shortMonthName}}'
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   116
    }, {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   117
        label : "2 jours",
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   118
        span : 2 * 86400 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   119
        grid_interval : 8 * 3600 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   120
        grid_date_format : '{{shortDayOfWeek}} {{0dayOfMonth}}/{{0monthNumber}} {{hours}}h',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   121
        start_date_format : '{{dayOfMonth}} {{shortMonthName}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   122
        end_date_format : '{{dayOfMonth}} {{shortMonthName}}'
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   123
    }, {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   124
        label : "Demi-Journée",
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   125
        span : 12 * 3600 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   126
        grid_interval : 2 * 3600 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   127
        grid_date_format : '{{hours}}h',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   128
        start_date_format : '{{dayOfMonth}} {{shortMonthName}} {{hours}}h',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   129
        end_date_format : '{{dayOfMonth}} {{shortMonthName}} {{hours}}h'
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   130
    }, {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   131
        label : "3 Heures",
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   132
        span : 3 * 3600 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   133
        grid_interval : 30 * 60 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   134
        grid_date_format : '{{0hours}}:{{0minutes}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   135
        start_date_format : '{{dayOfMonth}} {{shortMonthName}} {{0hours}}:{{0minutes}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   136
        end_date_format : '{{0hours}}:{{0minutes}}'
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   137
    }, {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   138
        label : "1 Heure",
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   139
        span : 60 * 60 * 1000,
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   140
        grid_interval : 15 * 60 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   141
        grid_date_format : '{{0hours}}:{{0minutes}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   142
        start_date_format : '{{dayOfMonth}} {{shortMonthName}} {{0hours}}:{{0minutes}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   143
        end_date_format : '{{0hours}}:{{0minutes}}'
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   144
    }],
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   145
    level: 0,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   146
    central_time: 0,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   147
    sync_now: true,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   148
    url_occurrences: '',
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   149
    occurrences: [],
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   150
    cluster_spacing: 10,
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   151
    tooltip_date_format: '{{dayOfMonth}} {{shortMonthName}} {{year}} {{0hours}}:{{0minutes}}'
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   152
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   153
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   154
for (var _i = 0; _i < Tlns.Defaults.Timeline.timescales.length; _i++) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   155
    Tlns.Defaults.Timeline.timescales[_i].level = _i;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   156
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   157
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   158
/* Templates */
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   159
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   160
Tlns.Templates.Timeline = '<div class="Tl-TopBar"><div class="Tl-TopBar-Button Tl-Border-Right"><div class="Tl-TopBar-AddButton"></div></div><div class="Tl-TopBar-Spacer Tl-Border-Right"></div>'
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   161
    + '<div class="Tl-TopBar-Button Tl-Border-Right"><div class="Tl-TopBar-PreviousButton"></div></div><div class="Tl-TopBar-TimeSpan Tl-TopBar-TextBtn Tl-Border-Right">--/--</div>'
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   162
    + '<div class="Tl-TopBar-Button Tl-Border-Right"><div class="Tl-TopBar-SyncButton"></div></div><div class="Tl-TopBar-Button Tl-Border-Right"><div class="Tl-TopBar-NextButton"></div></div><div class="Tl-TopBar-Spacer Tl-Border-Right"></div>'
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   163
    + '<div class="Tl-TopBar-Timescales">{{#timescales}}<div class="Tl-TopBar-Button Tl-TopBar-TextBtn Tl-Border-Right" data-level="{{level}}">{{label}}</div>{{/timescales}}</div></div>'
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   164
    + '<div class="Tl-BottomPart"><ul class="Tl-UniversLabels"></ul>'
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   165
    + '<div class="Tl-MainPart"><div class="Tl-Layer Tl-Grid"></div><canvas class="Tl-Layer Tl-Canvas"></canvas><canvas class="Tl-Layer Tl-Linking-Canvas"></canvas><div class="Tl-Layer Tl-Occurrences"></div>'
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   166
    + '<ul class="Tl-Adding"><li class="Tl-AddingTitle">Ajout d\'une occurrence</li><li><span>Narrative</span><div class="Tl-AddOccurrence Tl-Occnarrative" occurrence-type="narrative" title="Glisser sur la frise chronologique pour ajouter"></div></li>'
73
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   167
    + '<li><span>De Publication</span><div class="Tl-AddOccurrence Tl-Occpublication" occurrence-type="publication" title="Glisser sur la frise chronologique pour ajouter"></div></li></ul></div>'
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   168
    + '<div class="Tl-Overlay-Container"><div class="Tl-Overlay-Box"><div class="Tl-Overlay"><div class="Tl-Overlay-Tip-Top"></div><div class="Tl-Overlay-Main"></div><div class="Tl-Overlay-Tip-Bottom"></div></div></div></div></div>';
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   169
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   170
Tlns.Templates.Univers = '<span class="Tl-UniversText">{{title}}</span>';
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   171
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   172
Tlns.Templates.Occurrence = '{{#clusters}}<div class="Tl-Cluster Tl-Occ{{type}}" style="left: {{x}}px; top: {{y}}px;" cluster-contents="{{contents}}">'
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   173
    + '<div class="Tl-ClusterCount">{{occurrences.length}}</div></div>{{/clusters}}'
72
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   174
    + '{{#occurrences}}<div class="Tl-Occurrence Tl-OccOnGrid Tl-Occ{{type}}{{#editing}} Tl-Editing{{/editing}}" occurrence-id="{{id}}" style="left: {{x}}px; top: {{y}}px;">'
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   175
    + '{{#locked}}<div class="Tl-Locked"></div>{{/locked}}<div class="Tl-Link"{{#editing}} style="display: block"{{/editing}}></div></div>{{/occurrences}}{{#open_cluster}}<div class="Tl-ClusterOverlay" style="left: {{x}}px; top: {{y}}px;">'
72
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   176
    + '{{#occurrences}}<div class="Tl-Occurrence Tl-OccInCluster Tl-Occ{{type}}{{#editing}} Tl-Editing{{/editing}}" occurrence-id="{{id}}">'
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   177
    + '{{#locked}}<div class="Tl-Locked"></div>{{/locked}}<div class="Tl-Link"{{#editing}} style="display: block"{{/editing}}></div></div>{{/occurrences}}</div>{{/open_cluster}}';
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   178
    
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   179
Tlns.Templates.OccurrenceTooltip = '<h3 class="Tl-Tooltip-Title">{{title}}</h3><p class="Tl-Tooltip-Date">{{formatted_date}}</p>'
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   180
    + '<p class="Tl-Tooltip-Description">{{description}}</p><p class="Tl-Tooltip-Characters">{{univers.mainCharacter}}{{#characters}}, {{.}}{{/characters}}</p>'
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   181
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   182
/* Classes */
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   183
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   184
Tlns.Classes.Timeline = function(_options) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   185
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   186
    /* Setting Defaults */
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   187
    Tlns.Utils.SetDefaults(this, Tlns.Defaults.Timeline, _options);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   188
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   189
    /* Setting container CSS */
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   190
    this.$ = $('#' + this.container);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   191
    this.$.addClass('Tl-Main');
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   192
    this.$.css({
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   193
        width : this.width + "px",
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   194
        height : this.height + "px"
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   195
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   196
    this.$.html(Mustache.to_html(Tlns.Templates.Timeline, this));
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   197
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   198
    this.main_height = this.height - this.$.find('.Tl-TopBar').outerHeight();
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   199
    this.$.find('.Tl-BottomPart').css("height", this.main_height + "px");
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   200
    this.$.find('.Tl-MainPart').css("width", this.main_width + "px");
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   201
    this.$.find('.Tl-Overlay-Container').css("left", (this.$.find('.Tl-BottomPart').outerWidth() - this.main_width) + "px");
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   202
    this.$.find('canvas.Tl-Layer').attr({
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   203
        width: this.main_width,
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   204
        height: this.main_height
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   205
    });
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   206
    var _o = this.$.find('.Tl-MainPart').offset();
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   207
    this.dragging_bounds = {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   208
        left: _o.left,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   209
        top: _o.top,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   210
        right: _o.left + this.$.find('.Tl-MainPart').outerWidth(),
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   211
        bottom: _o.top + this.$.find('.Tl-MainPart').outerHeight(),
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   212
    };
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   213
    
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   214
    var _this = this;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   215
    
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   216
    this.throttledDrawGrid = _.throttle(function() {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   217
        _this.drawGrid();
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   218
    }, 150);
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   219
    
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   220
    this.setLevel(this.level);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   221
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   222
    this.$.find('.Tl-TopBar-Timescales>div').click(function() {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   223
        _this.setLevel($(this).attr("data-level"));
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   224
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   225
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   226
    this.$.find('.Tl-TopBar-SyncButton').click(function() {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   227
        _this.sync_now = !_this.sync_now;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   228
        _this.drawGrid();
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   229
    })
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   230
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   231
    this.$.find('.Tl-TopBar-PreviousButton').click(function() {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   232
        _this.offsetTime(-_this.timescales[_this.level].span / 4);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   233
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   234
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   235
    this.$.find('.Tl-TopBar-NextButton').click(function() {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   236
        _this.offsetTime(_this.timescales[_this.level].span / 4);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   237
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   238
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   239
    this.$.find('.Tl-MainPart').mousedown(function(_event) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   240
        _this.onMouseDown(_event);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   241
        return false;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   242
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   243
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   244
    this.$.find('.Tl-MainPart').mousemove(function(_event) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   245
        _this.onMouseMove(_event);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   246
        return false;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   247
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   248
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   249
    this.$.find('.Tl-MainPart').mouseup(function(_event) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   250
        _this.onMouseUp(_event);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   251
        return false;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   252
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   253
    
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   254
    this.$.find('.Tl-MainPart').mousewheel(function(_event, _delta) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   255
        var _newLevel = Math.max(0,Math.min(_this.timescales.length-1, (_delta < 0 ? -1 : 1) + parseInt(_this.level)));
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   256
        if (_newLevel != _this.level) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   257
            _this.hideTooltip();
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   258
            var _deltaX = _event.pageX - _this.dragging_bounds.left,
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   259
                _tAtMouse = _this.timeFromMouse(_event.pageX),
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   260
                _newScale = _this.main_width / (_this.timescales[_newLevel].span),
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   261
                _newStart = _tAtMouse - _deltaX / _newScale;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   262
            _this.central_time = _newStart + _this.timescales[_newLevel].span / 2;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   263
            _this.setLevel(_newLevel);
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   264
        }
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   265
        return false;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   266
    });
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   267
    
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   268
    this.$.find('.Tl-Overlay-Box').mouseover(function(_event) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   269
        $(this).show();
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   270
    }).mouseout(function(_event) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   271
        $(this).hide();
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   272
    });
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   273
    
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   274
    this.$.find('.Tl-TopBar-AddButton').click(function() {
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   275
        $(this).toggleClass('active');
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   276
        _this.$.find('.Tl-Adding').toggle();
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   277
    });
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   278
    
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   279
    this.$.find('.Tl-AddOccurrence').mousedown(function(_event) {
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   280
        var _el = $(this),
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   281
            _type = _el.attr("occurrence-type"),
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   282
            _d = _this.timeFromMouse(_event.pageX),
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   283
            _u = _this.universFromMouse(_event.pageY),
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   284
            _occ = _this.createOrUpdateOccurrence(
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   285
                _type,
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   286
                {
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   287
                    date: _d,
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   288
                    titre: '<Nouvelle occurrence>',
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   289
                    univers: _this.univers[_u].id,
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   290
                    publie: true
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   291
                }
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   292
            );
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   293
        _occ.just_created = true;
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   294
        _occ.editing = true;
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   295
        _this.editing_occurrence = _occ;
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   296
        _this.dragging_type = "occurrence";
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   297
        window.setTimeout(function () {
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   298
            _this.$.find('.Tl-TopBar-AddButton').removeClass('active');
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   299
            _this.$.find('.Tl-Adding').hide();
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   300
        }, 200);
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   301
        _this.throttledDrawGrid();
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   302
    }).mouseup(function(_event) {
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   303
        _this.onMouseUp(_event);
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   304
        return false;
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   305
    });
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   306
    
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   307
    /* Loading Univers */
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   308
    $.getJSON(this.url_univers, function(_data) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   309
        _this.onUniversLoaded(_data);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   310
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   311
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   312
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   313
Tlns.Classes.Timeline.prototype.onMouseDown = function(_event) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   314
    this.mouse_down = true;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   315
    this.is_dragging = false;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   316
    this.start_pos = {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   317
        x: _event.pageX,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   318
        y: _event.pageY
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   319
    };
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   320
    if (typeof this.dragging_type === "undefined") {
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   321
        this.time_at_start = this.central_time;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   322
        this.dragging_type = "timeline";
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   323
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   324
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   325
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   326
Tlns.Classes.Timeline.prototype.onMouseUp = function(_event) {
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   327
    if (this.is_dragging) {
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   328
        switch (this.dragging_type) {
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   329
            case "occurrence":
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   330
                this.editing_occurrence.editing = false;
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   331
                this.editing_occurrence.just_created = false;
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   332
                this.throttledDrawGrid();
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   333
            break;
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   334
            case "link":
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   335
                this.editing_occurrence.editing = false;
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   336
                this.throttledDrawGrid();
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   337
                var _ctx = this.$.find('.Tl-Linking-Canvas')[0].getContext('2d');
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   338
                _ctx.clearRect(0,0,this.main_width, this.main_height);
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   339
            break;
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   340
        }
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   341
    } else {
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   342
        if (this.dragging_type == "occurrence" && this.editing_occurrence.just_created) {
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   343
            this.deleteOccurrence(this.editing_occurrence.type, this.editing_occurrence.id);
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   344
            this.throttledDrawGrid();
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   345
        }
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   346
    }
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   347
    this.mouse_down = false;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   348
    this.is_dragging = false;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   349
    this.dragging_type = undefined;
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   350
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   351
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   352
Tlns.Classes.Timeline.prototype.timeFromX = function(_x) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   353
    return Math.max(this.start_time,Math.min(this.end_time, this.start_time + _x / this.current_scale));
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   354
}
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   355
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   356
Tlns.Classes.Timeline.prototype.timeFromMouse = function(_pageX) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   357
    return this.timeFromX(_pageX - this.dragging_bounds.left);
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   358
}
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   359
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   360
Tlns.Classes.Timeline.prototype.universFromY = function(_y) {
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   361
    return Math.max(0,Math.min(this.univers.length, Math.floor(_y / this.univers_height)))
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   362
}
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   363
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   364
Tlns.Classes.Timeline.prototype.universFromMouse = function(_pageY) {
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   365
    return this.universFromY(_pageY - this.dragging_bounds.top);
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   366
}
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   367
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   368
Tlns.Classes.Timeline.prototype.onMouseMove = function(_event) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   369
    if (this.mouse_down) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   370
        this.is_dragging = true;
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   371
        this.hideTooltip();
69
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   372
        switch (this.dragging_type) {
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   373
            case "occurrence":
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   374
                var _d = this.timeFromMouse(_event.pageX);
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   375
                this.editing_occurrence.date = _d;
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   376
                var _u = this.universFromMouse(_event.pageY);
69
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   377
                this.editing_occurrence.univers = this.univers[_u];
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   378
                this.editing_occurrence.univers_id = this.univers[_u].id;
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   379
                this.throttledDrawGrid();
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   380
            break;
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   381
            case "timeline":
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   382
                this.setTime(this.time_at_start + Math.floor(( this.start_pos.x - _event.pageX ) / this.current_scale));
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   383
            break;
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   384
            case "link":
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   385
                var _ctx = this.$.find('.Tl-Linking-Canvas')[0].getContext('2d');
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   386
                _ctx.clearRect(0,0,this.main_width, this.main_height);
73
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   387
                Tlns.Utils.drawArrow(
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   388
                    _ctx,
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   389
                    '#800080',
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   390
                    this.editing_occurrence.x,
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   391
                    this.editing_occurrence.y + Math.floor(this.univers_height / 2),
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   392
                    _event.pageX - this.dragging_bounds.left,
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   393
                    _event.pageY - this.dragging_bounds.top
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   394
                );
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   395
            break;
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   396
        }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   397
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   398
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   399
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   400
Tlns.Classes.Timeline.prototype.onUniversLoaded = function(_data) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   401
    this.univers = [];
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   402
    if(_data.length) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   403
        this.univers_height = Math.floor(this.main_height / _data.length);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   404
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   405
    for(var _i = 0; _i < _data.length; _i++) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   406
        this.univers.push(new Tlns.Classes.Univers(_data[_i], this, _i));
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   407
    }
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   408
    this.loadOccurrences();
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   409
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   410
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   411
Tlns.Classes.Timeline.prototype.offsetTime = function(_timeOffset) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   412
    this.setTime(this.central_time + _timeOffset);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   413
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   414
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   415
Tlns.Classes.Timeline.prototype.setTime = function(_centralTime) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   416
    this.sync_now = false;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   417
    this.central_time = _centralTime;
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   418
    this.throttledDrawGrid();
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   419
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   420
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   421
Tlns.Classes.Timeline.prototype.setLevel = function(_level) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   422
    if (_level >= 0 && _level < this.timescales.length) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   423
        this.$.find('.Tl-TopBar-Timescales>div').each(function() {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   424
            var _el = $(this);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   425
            if (_el.attr("data-level") == _level) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   426
                _el.addClass("active");
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   427
            } else {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   428
                _el.removeClass("active");
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   429
            }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   430
        });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   431
        this.level = _level;
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   432
        this.throttledDrawGrid();
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   433
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   434
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   435
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   436
Tlns.Classes.Timeline.prototype.drawGrid = function() {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   437
    var _now = new Date().valueOf();
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   438
    if (this.sync_now) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   439
        this.central_time = _now;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   440
        this.$.find('.Tl-TopBar-SyncButton').addClass("active");
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   441
    } else {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   442
        this.$.find('.Tl-TopBar-SyncButton').removeClass("active");
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   443
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   444
    var _timescale = this.timescales[this.level],
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   445
        _offset = new Date().getTimezoneOffset() * 60000;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   446
    this.current_scale = this.main_width / (_timescale.span)
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   447
    this.start_time = this.central_time - (_timescale.span / 2);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   448
    this.end_time = this.central_time + (_timescale.span / 2);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   449
    var _grid_width = Math.floor(_timescale.grid_interval * this.current_scale),
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   450
        _roundstart = Math.floor((this.start_time - _offset) / _timescale.grid_interval) * _timescale.grid_interval + _offset,
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   451
        _html = '';
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   452
    this.$.find('.Tl-TopBar-TimeSpan').html(Tlns.Utils.dateFormat(this.start_time, _timescale.start_date_format) + ' - ' + Tlns.Utils.dateFormat(this.end_time, _timescale.end_date_format));
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   453
    for (var _t = _roundstart; _t < this.end_time; _t += _timescale.grid_interval) {
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   454
        var _x = this.current_scale * (_t - this.start_time);
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   455
        if (_x > 0) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   456
            _html += '<div class="Tl-Grid-Column" style="width:' + _grid_width + 'px; left: ' + _x + 'px">'
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   457
            + '<div class="Tl-Grid-Label">' + Tlns.Utils.dateFormat(_t, _timescale.grid_date_format) + '</div></div>';
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   458
        }
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   459
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   460
/*
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   461
 
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   462
    for (var _t = _roundstart; _t < _tmax; _t += _timescale.grid_interval) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   463
        var _isMajor = !(Math.floor((_t - _offset) / _timescale.grid_interval) % _timescale.major_interval);
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   464
        _html += '<div class="Tl-Grid-Column' + ( _isMajor ? ' Tl-Grid-Major' : '' ) + '" style="width:' + _grid_width + 'px; left: ' + _scale * (_t - this.start_time) + 'px">'
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   465
        + ( _isMajor ? '<div class="Tl-Grid-Label">' + Tlns.Utils.dateFormat(_t, _timescale.date_format) + '</div>' : '' ) + '</div>';
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   466
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   467
*/
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   468
    if (this.start_time <= _now && this.end_time >= _now) {
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   469
        _html += '<div class="Tl-Grid-Now" style="left: ' + this.current_scale * (_now - this.start_time) + 'px"></div>'
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   470
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   471
    this.$.find('.Tl-Grid').html(_html);
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   472
    this.drawOccurrences();
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   473
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   474
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   475
Tlns.Classes.Timeline.prototype.loadOccurrences = function() {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   476
    var _url = Mustache.to_html(this.url_occurrences, {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   477
            from_time: this.start_time,
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   478
            to_time: this.end_time
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   479
        }),
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   480
        _this = this;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   481
    $.getJSON(_url, function(_data) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   482
        _this.onOccurrencesLoaded(_data);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   483
    });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   484
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   485
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   486
Tlns.Classes.Timeline.prototype.onOccurrencesLoaded = function(_data) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   487
    if (typeof _data.occurrencesNarratives === "object" && _data.occurrencesNarratives !== null) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   488
        for (var _i = 0; _i < _data.occurrencesNarratives.length; _i++) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   489
            this.createOrUpdateOccurrence("narrative", _data.occurrencesNarratives[_i]);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   490
        }
73
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   491
        for (var _i = 0; _i < _data.occurrencesPublication.length; _i++) {
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   492
            this.createOrUpdateOccurrence("publication", _data.occurrencesPublication[_i]);
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   493
        }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   494
    }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   495
    if (!this.mouse_down) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   496
        this.drawOccurrences();
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   497
    }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   498
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   499
72
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   500
Tlns.Classes.Timeline.prototype.deleteOccurrence = function(_id) {
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   501
    this.occurrences = _(this.occurrences).reject(function(_occ) {
72
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   502
        return occ.id == _id;
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   503
    });
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   504
}
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   505
72
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   506
Tlns.Classes.Timeline.prototype.getOccurrence = function(_id) {
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   507
    return _(this.occurrences).find(function(_occ) {
72
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   508
        return _occ.id == _id;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   509
    });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   510
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   511
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   512
Tlns.Classes.Timeline.prototype.createOrUpdateOccurrence = function(_type, _data) {
72
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   513
    var _id = _type + "_" + _data.id,
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   514
        _occurrence = this.getOccurrence(_id);
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   515
    if (typeof _occurrence === "undefined") {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   516
        _occurrence = new Tlns.Classes.Occurrence(this);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   517
        this.occurrences.push(_occurrence);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   518
    }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   519
    _occurrence.update(_type, _data);
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   520
    return _occurrence;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   521
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   522
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   523
Tlns.Classes.Timeline.prototype.showTooltip = function(_x, _y, _html, _isUp) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   524
    this.$.find('.Tl-Overlay-Box')
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   525
        .removeClass(_isUp ? 'Tl-Overlay-Down' : 'Tl-Overlay-Up')
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   526
        .addClass(_isUp ? 'Tl-Overlay-Up' : 'Tl-Overlay-Down')
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   527
        .show()
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   528
        .css({
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   529
            left: _x + "px",
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   530
            top: _y + "px"
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   531
        });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   532
    this.$.find('.Tl-Overlay-Main').html(_html);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   533
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   534
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   535
Tlns.Classes.Timeline.prototype.hideTooltip = function() {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   536
    this.$.find('.Tl-Overlay-Box').hide();
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   537
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   538
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   539
Tlns.Classes.Timeline.prototype.drawOccurrences = function() {
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   540
    var _this = this,
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   541
        _visible = _(this.occurrences).filter(function(_occ) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   542
        return (_occ.date >= _this.start_time && _occ.date <= _this.end_time && _occ.published);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   543
    });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   544
    _(_visible).each(function(_occ) {
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   545
        _occ.x = _this.current_scale * (_occ.date - _this.start_time);
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   546
        _occ.y = _occ.univers.y;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   547
        _occ.in_cluster = false;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   548
    });
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   549
    
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   550
    var _moved = true;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   551
    while (_moved) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   552
        _moved = false;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   553
        for (var _i = 0; _i < _visible.length; _i++) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   554
            for (var _j = 0; _j < _i; _j++) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   555
                if (_visible[_j].univers_id == _visible[_i].univers_id
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   556
                    && _visible[_j].x != _visible[_i].x
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   557
                    && Math.abs(_visible[_j].x-_visible[_i].x) < this.cluster_spacing
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   558
                ) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   559
                    _moved = true;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   560
                    _visible[_i].x = this.cluster_spacing * Math.round(_visible[_i].x / this.cluster_spacing);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   561
                    _visible[_j].x = this.cluster_spacing * Math.round(_visible[_j].x / this.cluster_spacing);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   562
                }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   563
            }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   564
        }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   565
    }
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   566
    var _clusters = [],
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   567
        _openCluster = false;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   568
    for (var _i = 0; _i < _visible.length; _i++) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   569
        for (var _j = 0; _j < _i; _j++) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   570
            if (_visible[_j].univers_id == _visible[_i].univers_id && _visible[_j].x == _visible[_i].x) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   571
                _visible[_j].in_cluster = true;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   572
                _visible[_i].in_cluster = true;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   573
                var _x = _visible[_j].x,
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   574
                    _y = _visible[_j].y;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   575
                    _cluster = _(_clusters).find(function(_c) { return _c.x == _x && _c.y == _y });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   576
                if (typeof _cluster === "undefined") {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   577
                    _cluster = { x: _x, y: _y, occurrences: [] };
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   578
                    _clusters.push(_cluster);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   579
                }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   580
                if ("undefined" === typeof _(_cluster.occurrences).find(function(_o) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   581
                    return _o.type == _visible[_j].type && _o.id == _visible[_j].id;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   582
                })) {
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   583
                    _cluster.occurrences.push(_visible[_j]);
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   584
                }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   585
                if ("undefined" === typeof _(_cluster.occurrences).find(function(_o) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   586
                    return _o.type == _visible[_i].type && _o.id == _visible[_i].id;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   587
                })) {
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   588
                    _cluster.occurrences.push(_visible[_i]);
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   589
                }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   590
            }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   591
        }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   592
    }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   593
    _(_clusters).each(function(_cluster) {
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   594
        _cluster.occurrences = _(_cluster.occurrences).sortBy(function(_o) {
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   595
            return _o.date;
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   596
        });
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   597
        _cluster.type = _cluster.occurrences[0].type;
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   598
        _cluster.contents = _cluster.occurrences.map(function(_o) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   599
            return _o.type + ":" + _o.id;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   600
        }).join("|");
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   601
        if (_cluster.contents == _this.open_cluster) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   602
            _openCluster = _cluster;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   603
        }
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   604
        for (var _i = 1; _i < _cluster.occurrences.length; _i++) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   605
            if (_cluster.occurrences[_i].type !== _cluster.type) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   606
                _cluster.type = "both";
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   607
                break;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   608
            }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   609
        }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   610
    });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   611
    
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   612
    
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   613
    var _links = [];
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   614
    
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   615
    _(_visible).each(function(_occurrence) {
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   616
        _(_occurrence.dependsOn).each(function(_dependance) {
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   617
            var _parent = _(_visible).find(function(_o) {
72
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   618
                return _o.id == _dependance;
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   619
            });
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   620
            if (typeof _parent !== "undefined") {
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   621
                _links.push({
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   622
                    from_x: _occurrence.x,
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   623
                    from_y: _occurrence.y + Math.floor(_this.univers_height / 2),
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   624
                    to_x: _parent.x,
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   625
                    to_y: _parent.y + Math.floor(_this.univers_height / 2)
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   626
                });
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   627
            }
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   628
        });
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   629
    });
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   630
    
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   631
    var _ctx = this.$.find('.Tl-Canvas')[0].getContext('2d');
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   632
    _ctx.clearRect(0,0,this.main_width, this.main_height);
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   633
    _(_links).each(function(_link) {
73
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   634
        Tlns.Utils.drawArrow(_ctx, "#505050", _link.from_x,_link.from_y, _link.to_x,_link.to_y);
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   635
    });
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   636
    
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   637
    var _html = Mustache.to_html(Tlns.Templates.Occurrence, {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   638
        occurrences:_(_visible).reject(function(_o) {return _o.in_cluster}),
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   639
        clusters: _clusters,
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   640
        open_cluster: _openCluster
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   641
    });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   642
    this.$.find('.Tl-Occurrences').html(_html);
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   643
    
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   644
    
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   645
    if (_openCluster) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   646
        var _w = this.$.find('.Tl-Occurrence').width(),
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   647
            _ww = _w * _openCluster.occurrences.length;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   648
        this.$.find('.Tl-ClusterOverlay').css({
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   649
            "margin-left": - Math.floor(_ww/2) + "px",
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   650
            width: _ww
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   651
        });
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   652
        _(_openCluster.occurrences).each(function(_o, _i) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   653
            _o.y = _o.y - 20;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   654
            _o.x = _o.x - (_ww / 2) + ((_i + .5) * _w);
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   655
        });
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   656
    }
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   657
    
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   658
    this.$.find('.Tl-Occurrence').mousedown(function() {
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   659
        var _el = $(this),
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   660
            _id = _el.attr("occurrence-id");
72
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   661
        if (typeof _id !== "undefined") {
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   662
            _this.editing_occurrence = _this.getOccurrence(_id);
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   663
            if (typeof _this.dragging_type === "undefined" && typeof _this.editing_occurrence !== "undefined" && !_this.editing_occurrence.locked) {
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   664
                _this.dragging_type = "occurrence";
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   665
                _this.editing_occurrence.editing = true;
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   666
            }
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   667
        }
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   668
    }).mouseover(function(_event) {
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   669
        var _el = $(this),
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   670
            _id = _el.attr("occurrence-id");
72
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   671
        if (typeof _id !== "undefined") {
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   672
            var _occurrence = _this.getOccurrence(_id);
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   673
            if (!_occurrence.locked) {
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   674
                _el.find('.Tl-Link').show();
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   675
            }
73
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   676
            if (!_this.is_dragging) {
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   677
                _occurrence.formatted_date = Tlns.Utils.dateFormat(_occurrence.date,_this.tooltip_date_format);
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   678
                var _html = Mustache.to_html(Tlns.Templates.OccurrenceTooltip, _occurrence);
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   679
                _this.showTooltip(_occurrence.x, _occurrence.y, _html, (_event.pageY - _this.dragging_bounds.top) >= (.4 * _this.main_height) );
642ef9139fad Replaced "Production" by "Publication". Added beautiful arrows
veltr
parents: 72
diff changeset
   680
            }
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   681
        }
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   682
    }).mouseout(function() {
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   683
        var _el = $(this),
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   684
            _id = _el.attr("occurrence-id");
72
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   685
        if (typeof _id !== "undefined") {
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   686
            var _occurrence = _this.getOccurrence(_id);
71
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   687
            _this.hideTooltip();
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   688
            if (!_occurrence.editing) {
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   689
                $(this).find('.Tl-Link').hide();
fa03eb8a3fe5 Added "Add" functionality
veltr
parents: 70
diff changeset
   690
            }
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   691
        }
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   692
    }).mouseup(function() {
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   693
        var _el = $(this);
72
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   694
        if (_this.dragging_type == "link") {
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   695
            _this.editing_occurrence.addDependency(_el.attr("occurrence-id"));
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   696
        }
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   697
    });
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   698
    
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   699
    this.$.find('.Tl-Link').mousedown(function() {
72
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   700
        var _el = $(this).parent(),
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   701
            _id = _el.attr("occurrence-id");
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   702
        _this.editing_occurrence = _this.getOccurrence(_id);
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   703
        if (typeof _this.editing_occurrence !== "undefined" && !_this.editing_occurrence.locked) {
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   704
            _this.dragging_type = "link";
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   705
            _this.editing_occurrence.editing = true;
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   706
        }
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   707
    })
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   708
    
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   709
    this.$.find('.Tl-Cluster').click(function() {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   710
        var _el = $(this),
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   711
            _contents = _el.attr("cluster-contents");
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   712
        if (_this.open_cluster == _contents) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   713
            _this.open_cluster = false;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   714
        } else {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   715
            _this.open_cluster = _contents;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   716
        }
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   717
        _this.throttledDrawGrid();
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   718
    })
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   719
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   720
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   721
Tlns.Classes.Timeline.prototype.getUnivers = function(_id) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   722
    return _(this.univers).find(function(_univ) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   723
        return (_univ.id == _id);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   724
    });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   725
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   726
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   727
/*
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   728
 * Univers
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   729
 */
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   730
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   731
Tlns.Classes.Univers = function(_data, _timeline, _index) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   732
    this.id = _data.id;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   733
    this.index = _index;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   734
    this.title = _data.nom;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   735
    this.mainCharacter = _data.personnage;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   736
    this.y = (_timeline.univers_height * _index);
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   737
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   738
    this.$label = $('<li>').css({
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   739
        height : _timeline.univers_height + "px"
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   740
    }).html(Mustache.to_html(Tlns.Templates.Univers, this))
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   741
      .addClass((_index % 2) ? 'Tl-Line-Odd' : 'Tl-Line-Even');
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   742
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   743
    _timeline.$.find('.Tl-UniversLabels').append(this.$label);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   744
    var _txt = _data.nom,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   745
        _span = this.$label.find('span');
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   746
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   747
    while (_span.outerWidth() > (_timeline.width - _timeline.main_width) && _txt) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   748
        _txt = _txt.substr(0, _txt.length - 1);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   749
        _span.html(_txt + '&hellip;');
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   750
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   751
}
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   752
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   753
/*
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   754
 * Occurrence
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   755
 */
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   756
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   757
Tlns.Classes.Occurrence = function(_timeline) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   758
    this.timeline = _timeline;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   759
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   760
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   761
Tlns.Classes.Occurrence.prototype.update = function(_type, _data) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   762
    this.type = _type;
72
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   763
    this.original_id = _data.id || Tlns.Utils.guid();
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   764
    this.id = _type + "_" + this.original_id;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   765
    this.date = _data.date || _data.datePublication;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   766
    this.title = _data.titre || "<untitled>";
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   767
    this.univers_id = _data.univers;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   768
    this.univers = this.timeline.getUnivers(this.univers_id);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   769
    this.status = _data.statut;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   770
    this.published = _data.publie || false;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   771
    this.locked = _data.verrouille || false;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   772
    this.characters = _data.personnagesSecondaires || [];
72
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   773
    this.dependsOn = _(_data.dependDe || []).map(function(_id) {
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   774
        return "narrative_" + _id;
a000f6a29dfa Added production-production linking capabilities
veltr
parents: 71
diff changeset
   775
    });
70
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   776
    this.description = _data.description || "";
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   777
}
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   778
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   779
Tlns.Classes.Occurrence.prototype.addDependency = function(_id) {
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   780
    if (_(this.dependsOn).indexOf(_id) == -1) {
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   781
        this.dependsOn.push(_id);
43012525c832 Added linking and better Tooltip
veltr
parents: 69
diff changeset
   782
    }
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   783
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   784
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   785
Tlns.Classes.Occurrence.prototype.toString = function() {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   786
    return "Occurrence " + this.type + ': "' + this.title + '"';
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   787
}