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