client/js/main.js
author veltr
Thu, 06 Sep 2012 17:21:11 +0200
changeset 37 db991a757015
parent 36 d249d36ecc37
child 41 9b9aabbb83bb
permissions -rw-r--r--
Added images
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
     1
/* 
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
     2
 *  Copyright 2012 Institut de recherche et d'innovation 
28
805d85b3f390 Publishing tests
veltr
parents: 26
diff changeset
     3
 *  contributor(s) : Yves-Marie Haussonne, Raphael Velt, Samuel Huron
1
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
     4
 *   
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
     5
 *  contact@iri.centrepompidou.fr
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
     6
 *  http://www.iri.centrepompidou.fr 
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
     7
 *   
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
     8
 *  This software is a computer program whose purpose is to show and add annotations on a video .
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
     9
 *  This software is governed by the CeCILL-C license under French law and
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    10
 *  abiding by the rules of distribution of free software. You can  use, 
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    11
 *  modify and/ or redistribute the software under the terms of the CeCILL-C
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    12
 *  license as circulated by CEA, CNRS and INRIA at the following URL
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    13
 *  "http://www.cecill.info". 
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    14
 *  
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    15
 *  The fact that you are presently reading this means that you have had
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    16
 *  knowledge of the CeCILL-C license and that you accept its terms.
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    17
*/
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    18
5
67085e6281e5 Added basic node/edge editing
veltr
parents: 4
diff changeset
    19
/* Declaring the Renkan Namespace Rkns and Default values */
1
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    20
28
805d85b3f390 Publishing tests
veltr
parents: 26
diff changeset
    21
if (typeof Rkns !== "object") {
805d85b3f390 Publishing tests
veltr
parents: 26
diff changeset
    22
    Rkns = {}
3
7722ec70c01b Scroll now depends on mouse position
veltr
parents: 2
diff changeset
    23
}
1
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    24
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    25
Rkns.$ = jQuery;
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    26
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    27
Rkns._ = _;
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    28
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    29
Rkns._BaseBin = function(_renkan, _opts) {
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    30
    if (typeof _renkan !== "undefined") {
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    31
        this.renkan = _renkan;
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    32
        this.renkan.$.find(".Rk-Bin-Main").hide();
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    33
        this.$ = Rkns.$('<li>')
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    34
            .addClass("Rk-Bin")
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    35
            .appendTo(_renkan.$.find(".Rk-Bin-List"));
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    36
        this.title_icon_$ = Rkns.$('<span>')
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    37
            .addClass("Rk-Bin-Title-Icon")
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    38
            .appendTo(this.$);
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    39
        var _this = this;
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    40
        Rkns.$('<span>')
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    41
            .addClass("Rk-Bin-Close")
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    42
            .html('&times;')
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    43
            .appendTo(this.$)
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    44
            .click(function() {
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    45
                _this.destroy();
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    46
            });
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    47
        this.title_$ = Rkns.$('<h2>')
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    48
            .addClass("Rk-Bin-Title")
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    49
            .appendTo(this.$);
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    50
        this.main_$ = Rkns.$('<div>')
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    51
            .addClass("Rk-Bin-Main")
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    52
            .appendTo(this.$);
26
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
    53
        this.title_$.html(_opts.title || '(new bin)');
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    54
        this.renkan.resizeBins();
20
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
    55
    }
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
    56
}
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    57
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    58
Rkns._BaseBin.prototype.destroy = function() {
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    59
    this.$.detach();
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    60
    this.renkan.resizeBins();
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    61
}
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    62
20
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
    63
/* Point of entry */
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
    64
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
    65
Rkns.Renkan = function(_opts) {
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    66
    if (typeof _opts.language !== "string" || typeof Rkns.i18n[_opts.language] == "undefined") {
5
67085e6281e5 Added basic node/edge editing
veltr
parents: 4
diff changeset
    67
        _opts.language = "en";
67085e6281e5 Added basic node/edge editing
veltr
parents: 4
diff changeset
    68
    }
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    69
    if (typeof _opts.container !== "string") {
20
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
    70
        _opts.container = "renkan";
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
    71
    }
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    72
    if (typeof _opts.search !== "object" || !_opts.search) {
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    73
        _opts.search = [];
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    74
    }
23
70c8af9b44ec Rebased Rendering on Backbone Model
veltr
parents: 21
diff changeset
    75
    this.project = new Rkns.Models.Project();
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    76
    this.language = _opts.language;
23
70c8af9b44ec Rebased Rendering on Backbone Model
veltr
parents: 21
diff changeset
    77
    this.l10n = Rkns.i18n[_opts.language];
70c8af9b44ec Rebased Rendering on Backbone Model
veltr
parents: 21
diff changeset
    78
    if (typeof _opts.user_id !== "undefined") {
70c8af9b44ec Rebased Rendering on Backbone Model
veltr
parents: 21
diff changeset
    79
        this.current_user = _opts.user_id;
4
f5297dde9053 Can now add nodes/edges
veltr
parents: 3
diff changeset
    80
    }
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    81
    this.$ = Rkns.$("#" + _opts.container);
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    82
    this.$
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    83
        .addClass("Rk-Main")
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    84
        .html(this.template());
23
70c8af9b44ec Rebased Rendering on Backbone Model
veltr
parents: 21
diff changeset
    85
    this.renderer = new Rkns.Renderer.Scene(this);
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    86
    this.tabs = [];
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    87
    this.search_engines = [];
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    88
    this.selected_bin_item = undefined;
1
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
    89
    var _this = this;
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    90
    this.$.mouseup(function() {
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    91
        _this.selected_bin_item = undefined;
26
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
    92
        _this.$.find(".Rk-Bin-Item.dragging").removeClass("dragging");
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    93
    });
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    94
    if (!_opts.search.length) {
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    95
        this.$.find(".Rk-Search-Form").detach();
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    96
    } else {
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    97
        var _tmpl = Rkns._.template('<li class="<%= className %>" data-key="<%= key %>"><%= title %></li>'),
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    98
            _select = this.$.find(".Rk-Search-List"),
24
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
    99
            _input = this.$.find(".Rk-Search-Input")
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   100
            _form = this.$.find(".Rk-Search-Form");
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   101
        Rkns._(_opts.search).each(function(_search, _key) {
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   102
            var _searchObj = new _search.type(_this, _search);
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   103
            _this.search_engines.push(_searchObj);
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   104
        });
24
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   105
        _select.html(
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   106
            Rkns._(this.search_engines).map(function(_search, _key) {
24
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   107
                return _tmpl({
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   108
                    key: _key,
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   109
                    title: _search.getSearchTitle(),
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   110
                    className: _search.getBgClass()
24
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   111
                });
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   112
            }).join("")
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   113
        );
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   114
        _select.find("li").click(function() {
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   115
            var _el = Rkns.$(this);
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   116
            _this.setSearchEngine(_el.attr("data-key"));
24
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   117
            _form.submit();
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   118
        });
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   119
        _form.submit(function() {
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   120
            if (_input.val()) {
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   121
                var _search = _this.search_engine;
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   122
                _search.search(_input.val());
24
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   123
            }
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   124
            return false;
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   125
        });
36
d249d36ecc37 Add Edge button, French translation and various bugfixes
veltr
parents: 34
diff changeset
   126
        this.$.find(".Rk-Search-Current").mouseenter(
d249d36ecc37 Add Edge button, French translation and various bugfixes
veltr
parents: 34
diff changeset
   127
            function() { _select.slideDown(); }
d249d36ecc37 Add Edge button, French translation and various bugfixes
veltr
parents: 34
diff changeset
   128
        );
d249d36ecc37 Add Edge button, French translation and various bugfixes
veltr
parents: 34
diff changeset
   129
        this.$.find(".Rk-Search-Select").mouseleave(
d249d36ecc37 Add Edge button, French translation and various bugfixes
veltr
parents: 34
diff changeset
   130
            function() { _select.slideUp(); }
d249d36ecc37 Add Edge button, French translation and various bugfixes
veltr
parents: 34
diff changeset
   131
        );
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   132
        this.setSearchEngine(0);
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   133
    }
26
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   134
    Rkns._(_opts.bins).each(function(_bin) {
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   135
        _this.tabs.push(new _bin.bin(_this, _bin));
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   136
    })
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   137
    
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   138
    /* The bins are not yet populated, but we want to bind dragging functions
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   139
     * here, as it will be easier than in the bins. Therefore, we bind to Rk-Bins
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   140
     * and look where the click was. */
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   141
    function findItem(_event) {
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   142
        var _t = Rkns.$(_event.target);
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   143
        while (!_t.is(".Rk-Bins,.Rk-Bin-Item")) {
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   144
            _t = _t.parent();
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   145
        }
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   146
        if (_t.is(".Rk-Bin-Item")) {
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   147
            return _t
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   148
        } else {
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   149
            return null;
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   150
        }
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   151
    }
24
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   152
    
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   153
    this.$.find(".Rk-Bins")
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   154
        .click(function(_e) {
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   155
            if (Rkns.$(_e.target).is(".Rk-Bin-Title,.Rk-Bin-Title-Icon")) {
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   156
                var _mainDiv = Rkns.$(_e.target).siblings(".Rk-Bin-Main");
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   157
                if (_mainDiv.is(":hidden")) {
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   158
                    _this.$.find(".Rk-Bin-Main").slideUp();
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   159
                    _mainDiv.slideDown();
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   160
                }
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   161
            }
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   162
        }).mousedown(function(_e) {
26
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   163
            var _t = findItem(_e);
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   164
            if (_t) {
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   165
                _t.addClass("dragging");
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   166
                _this.selected_bin_item = {
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   167
                    uri : $(_t).attr("data-uri"),
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   168
                    title : $(_t).attr("data-title"),
37
db991a757015 Added images
veltr
parents: 36
diff changeset
   169
                    description : $(_t).attr("data-description"),
db991a757015 Added images
veltr
parents: 36
diff changeset
   170
                    image: $(_t).attr("data-image")
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   171
                }
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   172
                return false;
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   173
            }
26
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   174
        }).mouseover(function(_e) {
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   175
            var _t = findItem(_e);
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   176
            if (_t && $(_t).attr("data-uri")) {
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   177
                var _models = _this.project.get("nodes").where({
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   178
                    uri: $(_t).attr("data-uri")
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   179
                });
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   180
                Rkns._(_models).each(function(_model) {
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   181
                    _this.renderer.highlightModel(_model);
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   182
                });
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   183
            }
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   184
        }).mouseout(function() {
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   185
            _this.renderer.unhighlightAll();
20
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
   186
        });
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   187
    Rkns.$(window).resize(function() {
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   188
        _this.resizeBins();
2
3360c3f7fb18 Added Edge management to the rendering engine
veltr
parents: 1
diff changeset
   189
    });
1
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   190
}
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   191
20
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
   192
Rkns.Renkan.prototype.template = Rkns._.template(
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   193
    '<div class="Rk-Title"><h1>Hyper Plateau</h1></div><div class="Rk-Bins">'
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   194
    + '<form class="Rk-Search-Form"><input class="Rk-Search-Input" type="text" placeholder="Search" />'
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   195
    + '<div class="Rk-Search-Select"><div class="Rk-Search-Current"></div><ul class="Rk-Search-List"></ul></div>'
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   196
    + '<input type="submit" value="" class="Rk-Search-Submit" /></form>'
28
805d85b3f390 Publishing tests
veltr
parents: 26
diff changeset
   197
    + '<ul class="Rk-Bin-List"></ul></div><div class="Rk-Render Rk-Render-Panel"></div>'
20
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
   198
);
18
4423bfcd8f9f UI improvements - Can now delete edges
veltr
parents: 15
diff changeset
   199
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   200
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   201
Rkns.Renkan.prototype.setSearchEngine = function(_key) {
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   202
    this.search_engine = this.search_engines[_key];
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   203
    this.$.find(".Rk-Search-Current").attr("class","Rk-Search-Current " + this.search_engine.getBgClass());
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   204
}
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   205
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   206
Rkns.Renkan.prototype.resizeBins = function() {
26
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   207
    var _d = + this.$.find(".Rk-Search-Form").outerHeight();
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   208
    this.$.find(".Rk-Bin-Title").each(function() {
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   209
        _d += Rkns.$(this).outerHeight();
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   210
    });
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   211
    this.$.find(".Rk-Bin-Main").css({
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   212
        height: this.$.find(".Rk-Bins").height() - _d
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   213
    });
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   214
}
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   215
1
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   216
/* Utility functions */
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   217
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   218
Rkns.Utils = {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   219
    _ID_AUTO_INCREMENT : 0,
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   220
    _ID_BASE : (function(_d) {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   221
        function pad(n){return n<10 ? '0'+n : n}
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   222
        function fillrand(n) {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   223
            var _res = ''
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   224
            for (var i=0; i<n; i++) {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   225
                _res += Math.floor(16*Math.random()).toString(16);
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   226
            }
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   227
            return _res;
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   228
        }
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   229
        return _d.getUTCFullYear() + '-'  
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   230
            + pad(_d.getUTCMonth()+1) + '-'  
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   231
            + pad(_d.getUTCDate()) + '-'
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   232
            + fillrand(16);
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   233
    })(new Date()),
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   234
    getUID : function(_base) {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   235
        var _n = (++this._ID_AUTO_INCREMENT).toString(16),
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   236
            _base = (typeof _base === "undefined" ? "" : _base + "-" );
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   237
        while (_n.length < 4) {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   238
            _n = '0' + _n
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   239
        }
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   240
        return _base + this._ID_BASE + '-' + _n;
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   241
    },
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   242
    inherit : function(_baseClass, _callbefore) {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   243
        var _class = function() {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   244
            if (typeof _callbefore === "function") {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   245
                _callbefore.apply(this, Array.prototype.slice.call(arguments, 0));
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   246
            }
28
805d85b3f390 Publishing tests
veltr
parents: 26
diff changeset
   247
            _baseClass.apply(this, Array.prototype.slice.call(arguments, 0));
805d85b3f390 Publishing tests
veltr
parents: 26
diff changeset
   248
            if (typeof this._init == "function") {
805d85b3f390 Publishing tests
veltr
parents: 26
diff changeset
   249
                this._init.apply(this, Array.prototype.slice.call(arguments, 0));
1
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   250
            }
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   251
        }
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   252
        _class.prototype = new _baseClass();
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   253
        return _class;
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   254
    }
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   255
}