timeline/js/timeline.js
author veltr
Fri, 25 May 2012 16:45:40 +0200
changeset 69 7bb5f89ad242
parent 68 4def147b1604
child 70 43012525c832
permissions -rw-r--r--
correction
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
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    60
/* Defaults */
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    61
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    62
Tlns.Defaults.Timeline = {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    63
    container : "timeline",
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    64
    width : 950,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    65
    height : 200,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    66
    url_univers : '',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    67
    min_width : 400,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    68
    min_height : 100,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    69
    main_width : 800,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    70
    timescales : [{
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    71
        label : "Mois",
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    72
        span : 32 * 86400 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    73
        grid_interval : 5 * 86400 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    74
        grid_date_format : '{{dayOfMonth}} {{shortMonthName}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    75
        start_date_format : '{{dayOfMonth}} {{shortMonthName}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    76
        end_date_format : '{{dayOfMonth}} {{shortMonthName}} {{year}}'
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    77
    }, {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    78
        label : "Semaine",
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    79
        span : 8 * 86400 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    80
        grid_interval : 86400 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    81
        grid_date_format : '{{shortDayOfWeek}} {{0dayOfMonth}}/{{0monthNumber}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    82
        start_date_format : '{{dayOfMonth}} {{shortMonthName}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    83
        end_date_format : '{{dayOfMonth}} {{shortMonthName}}'
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    84
    }, {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    85
        label : "2 jours",
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    86
        span : 2 * 86400 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    87
        grid_interval : 8 * 3600 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    88
        grid_date_format : '{{shortDayOfWeek}} {{0dayOfMonth}}/{{0monthNumber}} {{hours}}h',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    89
        start_date_format : '{{dayOfMonth}} {{shortMonthName}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    90
        end_date_format : '{{dayOfMonth}} {{shortMonthName}}'
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    91
    }, {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    92
        label : "Demi-Journée",
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    93
        span : 12 * 3600 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    94
        grid_interval : 2 * 3600 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    95
        grid_date_format : '{{hours}}h',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    96
        start_date_format : '{{dayOfMonth}} {{shortMonthName}} {{hours}}h',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    97
        end_date_format : '{{dayOfMonth}} {{shortMonthName}} {{hours}}h'
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    98
    }, {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
    99
        label : "3 Heures",
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   100
        span : 3 * 3600 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   101
        grid_interval : 30 * 60 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   102
        grid_date_format : '{{0hours}}:{{0minutes}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   103
        start_date_format : '{{dayOfMonth}} {{shortMonthName}} {{0hours}}:{{0minutes}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   104
        end_date_format : '{{0hours}}:{{0minutes}}'
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   105
    }, {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   106
        label : "1 Heure",
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   107
        span : 60 * 60 * 1000,
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   108
        grid_interval : 15 * 60 * 1000,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   109
        grid_date_format : '{{0hours}}:{{0minutes}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   110
        start_date_format : '{{dayOfMonth}} {{shortMonthName}} {{0hours}}:{{0minutes}}',
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   111
        end_date_format : '{{0hours}}:{{0minutes}}'
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   112
    }],
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   113
    level: 0,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   114
    central_time: 0,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   115
    sync_now: true,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   116
    url_occurrences: '',
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   117
    occurrences: [],
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   118
    cluster_spacing: 10
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   119
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   120
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   121
for (var _i = 0; _i < Tlns.Defaults.Timeline.timescales.length; _i++) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   122
    Tlns.Defaults.Timeline.timescales[_i].level = _i;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   123
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   124
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   125
/* Templates */
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   126
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   127
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
   128
    + '<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
   129
    + '<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
   130
    + '<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>'
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   131
    + '<div class="Tl-BottomPart"><ul class="Tl-UniversLabels"></ul><div class="Tl-MainPart"><div class="Tl-Layer Tl-Grid"></div><canvas class="Tl-Layer Tl-Canvas"></canvas><div class="Tl-Layer Tl-Occurrences"></div></div>'
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   132
    + '<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
   133
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   134
Tlns.Templates.Univers = '<span class="Tl-UniversText">{{title}}</span>';
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   135
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   136
Tlns.Templates.Occurrence = '{{#clusters}}<div class="Tl-Cluster Tl-Occ{{type}}" style="left: {{x}}px; top: {{y}}px;" cluster-contents="{{contents}}"><div class="Tl-ClusterCount">{{occurrences.length}}</div></div>{{/clusters}}{{#occurrences}}<div class="Tl-Occurrence Tl-OccOnGrid Tl-Occ{{type}}{{#editing}} Tl-Editing{{/editing}}" occurrence-type="{{type}}" occurrence-id="{{id}}" style="left: {{x}}px; top: {{y}}px;"></div>{{/occurrences}}{{#open_cluster}}<div class="Tl-ClusterOverlay" style="left: {{x}}px; top: {{y}}px;">{{#occurrences}}<div class="Tl-Occurrence Tl-OccInCluster Tl-Occ{{type}}{{#editing}} Tl-Editing{{/editing}}" occurrence-type="{{type}}" occurrence-id="{{id}}"></div>{{/occurrences}}</div>{{/open_cluster}}';
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   137
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   138
/* Classes */
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   139
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   140
Tlns.Classes.Timeline = function(_options) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   141
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   142
    /* Setting Defaults */
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   143
    Tlns.Utils.SetDefaults(this, Tlns.Defaults.Timeline, _options);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   144
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   145
    /* Setting container CSS */
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   146
    this.$ = $('#' + this.container);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   147
    this.$.addClass('Tl-Main');
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   148
    this.$.css({
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   149
        width : this.width + "px",
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   150
        height : this.height + "px"
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   151
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   152
    this.$.html(Mustache.to_html(Tlns.Templates.Timeline, this));
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   153
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   154
    this.main_height = this.height - this.$.find('.Tl-TopBar').outerHeight();
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   155
    this.$.find('.Tl-BottomPart').css("height", this.main_height + "px");
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   156
    this.$.find('.Tl-MainPart').css("width", this.main_width + "px");
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   157
    this.$.find('.Tl-Overlay-Container').css("left", (this.$.find('.Tl-BottomPart').outerWidth() - this.main_width) + "px");
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   158
    this.$.find('.Tl-Canvas').attr({
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   159
        width: this.main_width,
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   160
        height: this.main_height
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   161
    });
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   162
    var _o = this.$.find('.Tl-MainPart').offset();
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   163
    this.dragging_bounds = {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   164
        left: _o.left,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   165
        top: _o.top,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   166
        right: _o.left + this.$.find('.Tl-MainPart').outerWidth(),
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   167
        bottom: _o.top + this.$.find('.Tl-MainPart').outerHeight(),
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   168
    };
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   169
    
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   170
    var _this = this;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   171
    
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   172
    this.throttledDrawGrid = _.throttle(function() {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   173
        _this.drawGrid();
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   174
    }, 150);
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   175
    
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   176
    this.setLevel(this.level);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   177
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   178
    this.$.find('.Tl-TopBar-Timescales>div').click(function() {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   179
        _this.setLevel($(this).attr("data-level"));
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   180
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   181
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   182
    this.$.find('.Tl-TopBar-SyncButton').click(function() {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   183
        _this.sync_now = !_this.sync_now;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   184
        _this.drawGrid();
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   185
    })
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   186
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   187
    this.$.find('.Tl-TopBar-PreviousButton').click(function() {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   188
        _this.offsetTime(-_this.timescales[_this.level].span / 4);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   189
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   190
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   191
    this.$.find('.Tl-TopBar-NextButton').click(function() {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   192
        _this.offsetTime(_this.timescales[_this.level].span / 4);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   193
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   194
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   195
    this.$.find('.Tl-MainPart').mousedown(function(_event) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   196
        _this.onMouseDown(_event);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   197
        return false;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   198
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   199
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   200
    this.$.find('.Tl-MainPart').mousemove(function(_event) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   201
        _this.onMouseMove(_event);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   202
        return false;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   203
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   204
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   205
    this.$.find('.Tl-MainPart').mouseup(function(_event) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   206
        _this.onMouseUp(_event);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   207
        return false;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   208
    });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   209
    
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   210
    this.$.find('.Tl-MainPart').mousewheel(function(_event, _delta) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   211
        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
   212
        if (_newLevel != _this.level) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   213
            _this.hideTooltip();
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   214
            var _deltaX = _event.pageX - _this.dragging_bounds.left,
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   215
                _tAtMouse = _this.timeFromMouse(_event.pageX),
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   216
                _newScale = _this.main_width / (_this.timescales[_newLevel].span),
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   217
                _newStart = _tAtMouse - _deltaX / _newScale;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   218
            _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
   219
            _this.setLevel(_newLevel);
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   220
        }
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   221
        return false;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   222
    });
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   223
    
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   224
    this.$.find('.Tl-Overlay-Box').mouseover(function(_event) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   225
        $(this).show();
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   226
    }).mouseout(function(_event) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   227
        $(this).hide();
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   228
    });
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   229
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   230
    /* Loading Univers */
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   231
    $.getJSON(this.url_univers, function(_data) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   232
        _this.onUniversLoaded(_data);
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
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   236
Tlns.Classes.Timeline.prototype.onMouseDown = function(_event) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   237
    this.mouse_down = true;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   238
    this.is_dragging = false;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   239
    this.start_pos = {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   240
        x: _event.pageX,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   241
        y: _event.pageY
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   242
    };
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   243
    if (typeof this.dragging_type === "undefined") {
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   244
        this.time_at_start = this.central_time;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   245
        this.dragging_type = "timeline";
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   246
    }
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
Tlns.Classes.Timeline.prototype.onMouseUp = function(_event) {
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   250
    if (this.is_dragging) {
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   251
        switch (this.dragging_type) {
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   252
            case "occurrence":
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   253
                this.editing_occurrence.editing = false;
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   254
                this.throttledDrawGrid();
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   255
            break;
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   256
        }
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   257
    }
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   258
    this.mouse_down = false;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   259
    this.is_dragging = false;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   260
    this.dragging_type = undefined;
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   261
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   262
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   263
Tlns.Classes.Timeline.prototype.timeFromX = function(_x) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   264
    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
   265
}
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
Tlns.Classes.Timeline.prototype.timeFromMouse = function(_pageX) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   268
    return this.timeFromX(_pageX - this.dragging_bounds.left);
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   269
}
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   270
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   271
Tlns.Classes.Timeline.prototype.onMouseMove = function(_event) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   272
    if (this.mouse_down) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   273
        this.is_dragging = true;
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   274
        this.hideTooltip();
69
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   275
        switch (this.dragging_type) {
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   276
            case "occurrence":
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   277
                var _d = this.timeFromMouse(_event.pageX);
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   278
                this.editing_occurrence.date = _d;
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   279
                var _u = Math.max(0,Math.min(this.univers.length, Math.floor((_event.pageY - this.dragging_bounds.top) / this.univers_height)));
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   280
                this.editing_occurrence.univers = this.univers[_u];
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   281
                this.editing_occurrence.univers_id = this.univers[_u].id;
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   282
                this.throttledDrawGrid();
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   283
            break;
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   284
            case "timeline":
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   285
                this.setTime(this.time_at_start + Math.floor(( this.start_pos.x - _event.pageX ) / this.current_scale));
7bb5f89ad242 correction
veltr
parents: 68
diff changeset
   286
            break;
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   287
        }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   288
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   289
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   290
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   291
Tlns.Classes.Timeline.prototype.onUniversLoaded = function(_data) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   292
    this.univers = [];
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   293
    if(_data.length) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   294
        this.univers_height = Math.floor(this.main_height / _data.length);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   295
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   296
    for(var _i = 0; _i < _data.length; _i++) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   297
        this.univers.push(new Tlns.Classes.Univers(_data[_i], this, _i));
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   298
    }
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   299
    this.loadOccurrences();
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   300
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   301
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   302
Tlns.Classes.Timeline.prototype.offsetTime = function(_timeOffset) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   303
    this.setTime(this.central_time + _timeOffset);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   304
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   305
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   306
Tlns.Classes.Timeline.prototype.setTime = function(_centralTime) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   307
    this.sync_now = false;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   308
    this.central_time = _centralTime;
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   309
    this.throttledDrawGrid();
65
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
Tlns.Classes.Timeline.prototype.setLevel = function(_level) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   313
    if (_level >= 0 && _level < this.timescales.length) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   314
        this.$.find('.Tl-TopBar-Timescales>div').each(function() {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   315
            var _el = $(this);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   316
            if (_el.attr("data-level") == _level) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   317
                _el.addClass("active");
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   318
            } else {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   319
                _el.removeClass("active");
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   320
            }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   321
        });
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   322
        this.level = _level;
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   323
        this.throttledDrawGrid();
65
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
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   327
Tlns.Classes.Timeline.prototype.drawGrid = function() {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   328
    var _now = new Date().valueOf();
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   329
    if (this.sync_now) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   330
        this.central_time = _now;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   331
        this.$.find('.Tl-TopBar-SyncButton').addClass("active");
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   332
    } else {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   333
        this.$.find('.Tl-TopBar-SyncButton').removeClass("active");
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   334
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   335
    var _timescale = this.timescales[this.level],
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   336
        _offset = new Date().getTimezoneOffset() * 60000;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   337
    this.current_scale = this.main_width / (_timescale.span)
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   338
    this.start_time = this.central_time - (_timescale.span / 2);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   339
    this.end_time = this.central_time + (_timescale.span / 2);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   340
    var _grid_width = Math.floor(_timescale.grid_interval * this.current_scale),
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   341
        _roundstart = Math.floor((this.start_time - _offset) / _timescale.grid_interval) * _timescale.grid_interval + _offset,
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   342
        _html = '';
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   343
    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
   344
    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
   345
        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
   346
        if (_x > 0) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   347
            _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
   348
            + '<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
   349
        }
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   350
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   351
/*
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   352
 
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   353
    for (var _t = _roundstart; _t < _tmax; _t += _timescale.grid_interval) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   354
        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
   355
        _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
   356
        + ( _isMajor ? '<div class="Tl-Grid-Label">' + Tlns.Utils.dateFormat(_t, _timescale.date_format) + '</div>' : '' ) + '</div>';
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   357
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   358
*/
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   359
    if (this.start_time <= _now && this.end_time >= _now) {
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   360
        _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
   361
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   362
    this.$.find('.Tl-Grid').html(_html);
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   363
    this.drawOccurrences();
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   364
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   365
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   366
Tlns.Classes.Timeline.prototype.loadOccurrences = function() {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   367
    var _url = Mustache.to_html(this.url_occurrences, {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   368
            from_time: this.start_time,
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   369
            to_time: this.end_time
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   370
        }),
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   371
        _this = this;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   372
    $.getJSON(_url, function(_data) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   373
        _this.onOccurrencesLoaded(_data);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   374
    });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   375
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   376
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   377
Tlns.Classes.Timeline.prototype.onOccurrencesLoaded = function(_data) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   378
    if (typeof _data.occurrencesNarratives === "object" && _data.occurrencesNarratives !== null) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   379
        for (var _i = 0; _i < _data.occurrencesNarratives.length; _i++) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   380
            this.createOrUpdateOccurrence("narrative", _data.occurrencesNarratives[_i]);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   381
        }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   382
        for (var _i = 0; _i < _data.occurrencesProduction.length; _i++) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   383
            this.createOrUpdateOccurrence("production", _data.occurrencesProduction[_i]);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   384
        }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   385
    }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   386
    if (!this.mouse_down) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   387
        this.drawOccurrences();
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   388
    }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   389
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   390
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   391
Tlns.Classes.Timeline.prototype.getOccurrence = function(_type, _id) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   392
    return _(this.occurrences).find(function(_occ) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   393
        return (_occ.type == _type && _occ.id == _id);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   394
    });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   395
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   396
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   397
Tlns.Classes.Timeline.prototype.createOrUpdateOccurrence = function(_type, _data) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   398
    var _occurrence = this.getOccurrence(_type, _data.id);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   399
    if (typeof _occurrence === "undefined") {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   400
        _occurrence = new Tlns.Classes.Occurrence(this);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   401
        this.occurrences.push(_occurrence);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   402
    }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   403
    _occurrence.update(_type, _data);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   404
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   405
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   406
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
   407
    this.$.find('.Tl-Overlay-Box')
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   408
        .removeClass(_isUp ? 'Tl-Overlay-Down' : 'Tl-Overlay-Up')
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   409
        .addClass(_isUp ? 'Tl-Overlay-Up' : 'Tl-Overlay-Down')
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   410
        .show()
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   411
        .css({
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   412
            left: _x + "px",
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   413
            top: _y + "px"
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   414
        });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   415
    this.$.find('.Tl-Overlay-Main').html(_html);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   416
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   417
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   418
Tlns.Classes.Timeline.prototype.hideTooltip = function() {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   419
    this.$.find('.Tl-Overlay-Box').hide();
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   420
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   421
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   422
Tlns.Classes.Timeline.prototype.drawOccurrences = function() {
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   423
    var _this = this,
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   424
        _visible = _(this.occurrences).filter(function(_occ) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   425
        return (_occ.date >= _this.start_time && _occ.date <= _this.end_time && _occ.published);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   426
    });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   427
    _(_visible).each(function(_occ) {
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   428
        _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
   429
        _occ.y = _occ.univers.y;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   430
        _occ.in_cluster = false;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   431
    });
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   432
    
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   433
    var _moved = true;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   434
    while (_moved) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   435
        _moved = false;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   436
        for (var _i = 0; _i < _visible.length; _i++) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   437
            for (var _j = 0; _j < _i; _j++) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   438
                if (_visible[_j].univers_id == _visible[_i].univers_id
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   439
                    && _visible[_j].x != _visible[_i].x
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   440
                    && Math.abs(_visible[_j].x-_visible[_i].x) < this.cluster_spacing
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   441
                ) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   442
                    _moved = true;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   443
                    _visible[_i].x = this.cluster_spacing * Math.round(_visible[_i].x / this.cluster_spacing);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   444
                    _visible[_j].x = this.cluster_spacing * Math.round(_visible[_j].x / this.cluster_spacing);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   445
                }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   446
            }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   447
        }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   448
    }
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   449
    var _clusters = [],
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   450
        _openCluster = false;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   451
    for (var _i = 0; _i < _visible.length; _i++) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   452
        for (var _j = 0; _j < _i; _j++) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   453
            if (_visible[_j].univers_id == _visible[_i].univers_id && _visible[_j].x == _visible[_i].x) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   454
                _visible[_j].in_cluster = true;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   455
                _visible[_i].in_cluster = true;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   456
                var _x = _visible[_j].x,
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   457
                    _y = _visible[_j].y;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   458
                    _cluster = _(_clusters).find(function(_c) { return _c.x == _x && _c.y == _y });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   459
                if (typeof _cluster === "undefined") {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   460
                    _cluster = { x: _x, y: _y, occurrences: [] };
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   461
                    _clusters.push(_cluster);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   462
                }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   463
                if ("undefined" === typeof _(_cluster.occurrences).find(function(_o) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   464
                    return _o.type == _visible[_j].type && _o.id == _visible[_j].id;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   465
                })) {
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   466
                    _cluster.occurrences.push(_visible[_j]);
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   467
                }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   468
                if ("undefined" === typeof _(_cluster.occurrences).find(function(_o) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   469
                    return _o.type == _visible[_i].type && _o.id == _visible[_i].id;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   470
                })) {
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   471
                    _cluster.occurrences.push(_visible[_i]);
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   472
                }
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
    }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   476
    _(_clusters).each(function(_cluster) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   477
        _cluster.type = _cluster.occurrences[0].type;
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   478
        _cluster.contents = _cluster.occurrences.map(function(_o) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   479
            return _o.type + ":" + _o.id;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   480
        }).join("|");
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   481
        if (_cluster.contents == _this.open_cluster) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   482
            _openCluster = _cluster;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   483
        }
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   484
        for (var _i = 1; _i < _cluster.occurrences.length; _i++) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   485
            if (_cluster.occurrences[_i].type !== _cluster.type) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   486
                _cluster.type = "both";
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   487
                break;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   488
            }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   489
        }
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   490
    });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   491
    
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   492
    
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   493
    var _links = [];
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   494
    
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   495
    _(_visible).each(function(_occurrence) {
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   496
        _(_occurrence.dependsOn).each(function(_dependance) {
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   497
            var _parent = _(_visible).find(function(_o) {
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   498
                return _o.type == "narrative" && _o.id == _dependance;
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   499
            });
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   500
            if (typeof _parent !== "undefined") {
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   501
                _links.push({
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   502
                    from_x: _occurrence.x,
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   503
                    from_y: _occurrence.y + Math.floor(_this.univers_height / 2),
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   504
                    to_x: _parent.x,
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   505
                    to_y: _parent.y + Math.floor(_this.univers_height / 2)
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   506
                });
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   507
            }
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   508
        });
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   509
    });
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   510
    
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   511
    var _ctx = this.$.find('.Tl-Canvas')[0].getContext('2d');
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   512
    _ctx.clearRect(0,0,this.main_width, this.main_height);
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   513
    _(_links).each(function(_link) {
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   514
        _ctx.beginPath();
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   515
        _ctx.moveTo(_link.from_x,_link.from_y);
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   516
        _ctx.lineTo(_link.to_x,_link.to_y);
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   517
        _ctx.stroke();
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   518
    })
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   519
    
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   520
    console.log(_openCluster);
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   521
    
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   522
    var _html = Mustache.to_html(Tlns.Templates.Occurrence, {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   523
        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
   524
        clusters: _clusters,
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   525
        open_cluster: _openCluster
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   526
    });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   527
    this.$.find('.Tl-Occurrences').html(_html);
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   528
    
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   529
    
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   530
    if (_openCluster) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   531
        var _w = this.$.find('.Tl-Occurrence').width(),
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   532
            _ww = _w * _openCluster.occurrences.length;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   533
        this.$.find('.Tl-ClusterOverlay').css({
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   534
            "margin-left": - Math.floor(_ww/2) + "px",
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   535
            width: _ww
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   536
        });
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   537
        _(_openCluster.occurrences).each(function(_o, _i) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   538
            _o.y = _o.y - 20;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   539
            _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
   540
        });
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   541
    }
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   542
    
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   543
    this.$.find('.Tl-Occurrence').mousedown(function() {
67
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   544
        var _el = $(this);
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   545
        _this.editing_occurrence = _occurrence = _this.getOccurrence(_el.attr("occurrence-type"),_el.attr("occurrence-id"));
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   546
        if (typeof _this.editing_occurrence !== "undefined") {
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   547
            _this.dragging_type = "occurrence";
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   548
            _this.editing_occurrence.editing = true;
5d1ac260d3ee Added occurrence dragging and links drawing
veltr
parents: 66
diff changeset
   549
        }
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   550
    }).mouseover(function(_event) {
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   551
        var _el = $(this),
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   552
            _occurrence = _this.getOccurrence(_el.attr("occurrence-type"),_el.attr("occurrence-id"));
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   553
        _this.showTooltip(_occurrence.x, _occurrence.y, _occurrence.title, (_event.pageY - _this.dragging_bounds.top) > (_this.main_height / 2) );
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   554
    }).mouseout(function() {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   555
        _this.hideTooltip();
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   556
    });
68
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   557
    this.$.find('.Tl-Cluster').click(function() {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   558
        var _el = $(this),
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   559
            _contents = _el.attr("cluster-contents");
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   560
        if (_this.open_cluster == _contents) {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   561
            _this.open_cluster = false;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   562
        } else {
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   563
            _this.open_cluster = _contents;
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   564
        }
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   565
        console.log(_this.open_cluster);
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   566
        _this.throttledDrawGrid();
4def147b1604 Added a visualization of the contents of clusters + mousewheel support
veltr
parents: 67
diff changeset
   567
    })
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   568
}
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   569
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   570
Tlns.Classes.Timeline.prototype.getUnivers = function(_id) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   571
    return _(this.univers).find(function(_univ) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   572
        return (_univ.id == _id);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   573
    });
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   574
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   575
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   576
/*
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   577
 * Univers
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   578
 */
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   579
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   580
Tlns.Classes.Univers = function(_data, _timeline, _index) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   581
    this.id = _data.id;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   582
    this.index = _index;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   583
    this.title = _data.nom;
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   584
    this.mainCharacter = _data.personnage;
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   585
    this.y = (_timeline.univers_height * _index);
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   586
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   587
    this.$label = $('<li>').css({
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   588
        height : _timeline.univers_height + "px"
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   589
    }).html(Mustache.to_html(Tlns.Templates.Univers, this))
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   590
      .addClass((_index % 2) ? 'Tl-Line-Odd' : 'Tl-Line-Even');
65
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   591
    
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   592
    _timeline.$.find('.Tl-UniversLabels').append(this.$label);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   593
    var _txt = _data.nom,
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   594
        _span = this.$label.find('span');
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   595
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   596
    while (_span.outerWidth() > (_timeline.width - _timeline.main_width) && _txt) {
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   597
        _txt = _txt.substr(0, _txt.length - 1);
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   598
        _span.html(_txt + '&hellip;');
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   599
    }
03bbfd9cd3c6 First commit for Timeline
veltr
parents:
diff changeset
   600
}
66
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   601
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   602
/*
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   603
 * Occurrence
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   604
 */
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   605
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   606
Tlns.Classes.Occurrence = function(_timeline) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   607
    this.timeline = _timeline;
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
Tlns.Classes.Occurrence.prototype.update = function(_type, _data) {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   611
    this.type = _type;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   612
    this.id = _data.id || _.uniqueId();
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   613
    this.date = _data.date || _data.datePublication;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   614
    this.title = _data.titre || "<untitled>";
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   615
    this.univers_id = _data.univers;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   616
    this.univers = this.timeline.getUnivers(this.univers_id);
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   617
    this.status = _data.statut;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   618
    this.published = _data.publie || false;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   619
    this.locked = _data.verrouille || false;
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   620
    this.characters = _data.personnagesSecondaires || [];
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   621
    this.dependsOn = _data.dependDe || [];
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   622
}
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   623
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   624
Tlns.Classes.Occurrence.prototype.toString = function() {
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   625
    return "Occurrence " + this.type + ': "' + this.title + '"';
37492d1ce841 Added clustering
veltr
parents: 65
diff changeset
   626
}