client/js/main.js
author ymh <ymh.work@gmail.com>
Fri, 05 Apr 2013 13:56:22 +0200
changeset 139 9929b1447f69
parent 132 860340d4c645
child 155 7d5f722d76b2
child 168 f978d70a9e63
permissions -rw-r--r--
- Clean template code for list bin - set data-image to empty when there is no image for a resource - correct Rkns.Utils.getFullURL to handle case when the url is null or undefined - correct Rkns.Utils.getFullURL to avoid requesting the url when the url is already absolute
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
68
803dbeb7c919 Improved drag-and-drop. Added ontologies for edges
veltr
parents: 66
diff changeset
    29
Rkns.VERSION = '0.2';
803dbeb7c919 Improved drag-and-drop. Added ontologies for edges
veltr
parents: 66
diff changeset
    30
69
f0873867143a Added Drag-and-add bookmarklet
veltr
parents: 68
diff changeset
    31
Rkns.pickerColors = ["#8f1919", "#a80000", "#d82626", "#ff0000", "#e87c7c", "#ff6565", "#f7d3d3", "#fecccc",
f0873867143a Added Drag-and-add bookmarklet
veltr
parents: 68
diff changeset
    32
    "#8f5419", "#a85400", "#d87f26", "#ff7f00", "#e8b27c", "#ffb265", "#f7e5d3", "#fee5cc",
f0873867143a Added Drag-and-add bookmarklet
veltr
parents: 68
diff changeset
    33
    "#8f8f19", "#a8a800", "#d8d826", "#feff00", "#e8e87c", "#feff65", "#f7f7d3", "#fefecc",
f0873867143a Added Drag-and-add bookmarklet
veltr
parents: 68
diff changeset
    34
    "#198f19", "#00a800", "#26d826", "#00ff00", "#7ce87c", "#65ff65", "#d3f7d3", "#ccfecc",
f0873867143a Added Drag-and-add bookmarklet
veltr
parents: 68
diff changeset
    35
    "#198f8f", "#00a8a8", "#26d8d8", "#00feff", "#7ce8e8", "#65feff", "#d3f7f7", "#ccfefe",
f0873867143a Added Drag-and-add bookmarklet
veltr
parents: 68
diff changeset
    36
    "#19198f", "#0000a8", "#2626d8", "#0000ff", "#7c7ce8", "#6565ff", "#d3d3f7", "#ccccfe",
f0873867143a Added Drag-and-add bookmarklet
veltr
parents: 68
diff changeset
    37
    "#8f198f", "#a800a8", "#d826d8", "#ff00fe", "#e87ce8", "#ff65fe", "#f7d3f7", "#feccfe",
f0873867143a Added Drag-and-add bookmarklet
veltr
parents: 68
diff changeset
    38
    "#000000", "#242424", "#484848", "#6d6d6d", "#919191", "#b6b6b6", "#dadada", "#ffffff"];
52
e0f6f3c31150 Added colors !
veltr
parents: 44
diff changeset
    39
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    40
Rkns._BaseBin = function(_renkan, _opts) {
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    41
    if (typeof _renkan !== "undefined") {
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    42
        this.renkan = _renkan;
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    43
        this.renkan.$.find(".Rk-Bin-Main").hide();
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    44
        this.$ = Rkns.$('<li>')
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    45
            .addClass("Rk-Bin")
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    46
            .appendTo(_renkan.$.find(".Rk-Bin-List"));
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    47
        this.title_icon_$ = Rkns.$('<span>')
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    48
            .addClass("Rk-Bin-Title-Icon")
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    49
            .appendTo(this.$);
42
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    50
            
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    51
        var _this = this;
42
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    52
        
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    53
        Rkns.$('<a>')
119
0f7d2275a88f Added tooltips for bin refresh
veltr
parents: 114
diff changeset
    54
            .attr({
0f7d2275a88f Added tooltips for bin refresh
veltr
parents: 114
diff changeset
    55
            	href: "#",
0f7d2275a88f Added tooltips for bin refresh
veltr
parents: 114
diff changeset
    56
            	title: _renkan.translate("Close bin")
0f7d2275a88f Added tooltips for bin refresh
veltr
parents: 114
diff changeset
    57
        	})
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    58
            .addClass("Rk-Bin-Close")
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    59
            .html('&times;')
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    60
            .appendTo(this.$)
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    61
            .click(function() {
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    62
                _this.destroy();
119
0f7d2275a88f Added tooltips for bin refresh
veltr
parents: 114
diff changeset
    63
                if (!_renkan.$.find(".Rk-Bin-Main:visible").length) {
0f7d2275a88f Added tooltips for bin refresh
veltr
parents: 114
diff changeset
    64
                	_renkan.$.find(".Rk-Bin-Main:last").slideDown();
0f7d2275a88f Added tooltips for bin refresh
veltr
parents: 114
diff changeset
    65
                }
0f7d2275a88f Added tooltips for bin refresh
veltr
parents: 114
diff changeset
    66
                _renkan.resizeBins();
42
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    67
                return false;
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    68
            });
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    69
        Rkns.$('<a>')
119
0f7d2275a88f Added tooltips for bin refresh
veltr
parents: 114
diff changeset
    70
            .attr({
0f7d2275a88f Added tooltips for bin refresh
veltr
parents: 114
diff changeset
    71
            	href: "#",
0f7d2275a88f Added tooltips for bin refresh
veltr
parents: 114
diff changeset
    72
            	title: _renkan.translate("Refresh bin")
0f7d2275a88f Added tooltips for bin refresh
veltr
parents: 114
diff changeset
    73
        	})
42
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    74
            .addClass("Rk-Bin-Refresh")
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    75
            .appendTo(this.$)
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    76
            .click(function() {
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    77
                _this.refresh();
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    78
                return false;
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
    79
            });
44
869410bab434 Various changes
veltr
parents: 42
diff changeset
    80
        this.count_$ = Rkns.$('<div>')
869410bab434 Various changes
veltr
parents: 42
diff changeset
    81
            .addClass("Rk-Bin-Count")
869410bab434 Various changes
veltr
parents: 42
diff changeset
    82
            .appendTo(this.$);
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    83
        this.title_$ = Rkns.$('<h2>')
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    84
            .addClass("Rk-Bin-Title")
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    85
            .appendTo(this.$);
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    86
        this.main_$ = Rkns.$('<div>')
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    87
            .addClass("Rk-Bin-Main")
64
3a5a9421687b Added Ldt Search
veltr
parents: 62
diff changeset
    88
            .appendTo(this.$)
66
9b459e41e2df Added drag-and-drop and image from local drive
veltr
parents: 64
diff changeset
    89
            .html('<h4 class="Rk-Bin-Loading">' + _renkan.translate("Loading, please wait") + '</h4>');
26
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
    90
        this.title_$.html(_opts.title || '(new bin)');
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
    91
        this.renkan.resizeBins();
42
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    92
        
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    93
        if (_opts.auto_refresh) {
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    94
            window.setInterval(function() {
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    95
                _this.refresh();
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    96
            },_opts.auto_refresh)
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
    97
        }
20
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
    98
    }
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
    99
}
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   100
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   101
Rkns._BaseBin.prototype.destroy = function() {
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   102
    this.$.detach();
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   103
    this.renkan.resizeBins();
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   104
}
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   105
20
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
   106
/* Point of entry */
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
   107
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
   108
Rkns.Renkan = function(_opts) {
68
803dbeb7c919 Improved drag-and-drop. Added ontologies for edges
veltr
parents: 66
diff changeset
   109
    var _this = this;
803dbeb7c919 Improved drag-and-drop. Added ontologies for edges
veltr
parents: 66
diff changeset
   110
    
114
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   111
    this.options = _.defaults(_opts, Rkns.defaults);
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   112
        
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   113
	Rkns._(this.options.property_files).each(function(f) {
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   114
		Rkns.$.getJSON(f, function(data) {
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   115
			_this.options.properties = _this.options.properties.concat(data);
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   116
		});
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   117
	});
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   118
    
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   119
    this.read_only = this.options.read_only || !this.options.editor_mode;
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   120
23
70c8af9b44ec Rebased Rendering on Backbone Model
veltr
parents: 21
diff changeset
   121
    this.project = new Rkns.Models.Project();
69
f0873867143a Added Drag-and-add bookmarklet
veltr
parents: 68
diff changeset
   122
    
66
9b459e41e2df Added drag-and-drop and image from local drive
veltr
parents: 64
diff changeset
   123
    this.translate = function(_text) {
114
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   124
    	return (Rkns.i18n[_this.options.language] || Rkns.i18n[_this.options.language.substr(0,2)] || {})[_text] || _text;
66
9b459e41e2df Added drag-and-drop and image from local drive
veltr
parents: 64
diff changeset
   125
    }
114
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   126
    if (typeof this.options.user_id !== "undefined") {
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   127
        this.current_user = this.options.user_id;
4
f5297dde9053 Can now add nodes/edges
veltr
parents: 3
diff changeset
   128
    }
114
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   129
    this.$ = Rkns.$("#" + this.options.container);
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   130
    this.$
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   131
        .addClass("Rk-Main")
68
803dbeb7c919 Improved drag-and-drop. Added ontologies for edges
veltr
parents: 66
diff changeset
   132
        .html(this.template(this));
23
70c8af9b44ec Rebased Rendering on Backbone Model
veltr
parents: 21
diff changeset
   133
    this.renderer = new Rkns.Renderer.Scene(this);
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   134
    this.tabs = [];
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   135
    this.search_engines = [];
56
a9b9e6c7be63 Converging client and webapp
veltr
parents: 53
diff changeset
   136
a9b9e6c7be63 Converging client and webapp
veltr
parents: 53
diff changeset
   137
    this.current_user_list = new Rkns.Models.UsersList();
a9b9e6c7be63 Converging client and webapp
veltr
parents: 53
diff changeset
   138
    
114
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   139
    if (!this.options.search.length) {
44
869410bab434 Various changes
veltr
parents: 42
diff changeset
   140
        this.$.find(".Rk-Web-Search-Form").detach();
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   141
    } else {
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   142
        var _tmpl = Rkns._.template('<li class="<%= className %>" data-key="<%= key %>"><%= title %></li>'),
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   143
            _select = this.$.find(".Rk-Search-List"),
44
869410bab434 Various changes
veltr
parents: 42
diff changeset
   144
            _input = this.$.find(".Rk-Web-Search-Input")
869410bab434 Various changes
veltr
parents: 42
diff changeset
   145
            _form = this.$.find(".Rk-Web-Search-Form");
114
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   146
        Rkns._(this.options.search).each(function(_search, _key) {
78
af9e716b01bc Renkan bin configuration now with class names instead of classes themselves
veltr
parents: 75
diff changeset
   147
        	if (Rkns[_search.type] && Rkns[_search.type].Search) {
af9e716b01bc Renkan bin configuration now with class names instead of classes themselves
veltr
parents: 75
diff changeset
   148
        		_this.search_engines.push(new Rkns[_search.type].Search(_this, _search));
af9e716b01bc Renkan bin configuration now with class names instead of classes themselves
veltr
parents: 75
diff changeset
   149
        	}
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   150
        });
24
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   151
        _select.html(
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   152
            Rkns._(this.search_engines).map(function(_search, _key) {
24
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   153
                return _tmpl({
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   154
                    key: _key,
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   155
                    title: _search.getSearchTitle(),
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   156
                    className: _search.getBgClass()
24
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   157
                });
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   158
            }).join("")
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   159
        );
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   160
        _select.find("li").click(function() {
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   161
            var _el = Rkns.$(this);
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   162
            _this.setSearchEngine(_el.attr("data-key"));
24
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   163
            _form.submit();
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   164
        });
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   165
        _form.submit(function() {
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   166
            if (_input.val()) {
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   167
                var _search = _this.search_engine;
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   168
                _search.search(_input.val());
24
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   169
            }
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   170
            return false;
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   171
        });
36
d249d36ecc37 Add Edge button, French translation and various bugfixes
veltr
parents: 34
diff changeset
   172
        this.$.find(".Rk-Search-Current").mouseenter(
d249d36ecc37 Add Edge button, French translation and various bugfixes
veltr
parents: 34
diff changeset
   173
            function() { _select.slideDown(); }
d249d36ecc37 Add Edge button, French translation and various bugfixes
veltr
parents: 34
diff changeset
   174
        );
d249d36ecc37 Add Edge button, French translation and various bugfixes
veltr
parents: 34
diff changeset
   175
        this.$.find(".Rk-Search-Select").mouseleave(
70
47b3125130a2 bookmarklet evolution
veltr
parents: 69
diff changeset
   176
            function() { _select.hide(); }
36
d249d36ecc37 Add Edge button, French translation and various bugfixes
veltr
parents: 34
diff changeset
   177
        );
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   178
        this.setSearchEngine(0);
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   179
    }
114
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   180
    Rkns._(this.options.bins).each(function(_bin) {
78
af9e716b01bc Renkan bin configuration now with class names instead of classes themselves
veltr
parents: 75
diff changeset
   181
    	if (Rkns[_bin.type] && Rkns[_bin.type].Bin) {
af9e716b01bc Renkan bin configuration now with class names instead of classes themselves
veltr
parents: 75
diff changeset
   182
    		_this.tabs.push(new Rkns[_bin.type].Bin(_this, _bin));
af9e716b01bc Renkan bin configuration now with class names instead of classes themselves
veltr
parents: 75
diff changeset
   183
    	}
42
48d825187d67 Added Refresh button and Autorefresh
veltr
parents: 41
diff changeset
   184
    });
24
121a24be9da4 Added Wikipedia Search
veltr
parents: 23
diff changeset
   185
    
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   186
    this.$.find(".Rk-Bins")
41
9b9aabbb83bb Today, I learned about the delegate function in jQuery
veltr
parents: 37
diff changeset
   187
        .on("click",".Rk-Bin-Title,.Rk-Bin-Title-Icon", function() {
9b9aabbb83bb Today, I learned about the delegate function in jQuery
veltr
parents: 37
diff changeset
   188
            var _mainDiv = Rkns.$(this).siblings(".Rk-Bin-Main");
9b9aabbb83bb Today, I learned about the delegate function in jQuery
veltr
parents: 37
diff changeset
   189
            if (_mainDiv.is(":hidden")) {
9b9aabbb83bb Today, I learned about the delegate function in jQuery
veltr
parents: 37
diff changeset
   190
                _this.$.find(".Rk-Bin-Main").slideUp();
9b9aabbb83bb Today, I learned about the delegate function in jQuery
veltr
parents: 37
diff changeset
   191
                _mainDiv.slideDown();
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   192
            }
41
9b9aabbb83bb Today, I learned about the delegate function in jQuery
veltr
parents: 37
diff changeset
   193
        }).on("mouseover", ".Rk-Bin-Item", function(_e) {
9b9aabbb83bb Today, I learned about the delegate function in jQuery
veltr
parents: 37
diff changeset
   194
            var _t = Rkns.$(this);
26
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   195
            if (_t && $(_t).attr("data-uri")) {
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   196
                var _models = _this.project.get("nodes").where({
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   197
                    uri: $(_t).attr("data-uri")
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   198
                });
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   199
                Rkns._(_models).each(function(_model) {
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   200
                    _this.renderer.highlightModel(_model);
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   201
                });
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   202
            }
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   203
        }).mouseout(function() {
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   204
            _this.renderer.unhighlightAll();
113
fac7354c55d2 IE9 Compatibility
veltr
parents: 111
diff changeset
   205
        }).on("mousemove", ".Rk-Bin-Item", function(e) {
fac7354c55d2 IE9 Compatibility
veltr
parents: 111
diff changeset
   206
			try {
fac7354c55d2 IE9 Compatibility
veltr
parents: 111
diff changeset
   207
				this.dragDrop();
fac7354c55d2 IE9 Compatibility
veltr
parents: 111
diff changeset
   208
			}
fac7354c55d2 IE9 Compatibility
veltr
parents: 111
diff changeset
   209
			catch(err) {}
68
803dbeb7c919 Improved drag-and-drop. Added ontologies for edges
veltr
parents: 66
diff changeset
   210
        }).on("dragstart", ".Rk-Bin-Item", function(e) {
113
fac7354c55d2 IE9 Compatibility
veltr
parents: 111
diff changeset
   211
        	var div = document.createElement('div');
fac7354c55d2 IE9 Compatibility
veltr
parents: 111
diff changeset
   212
        	div.appendChild(this.cloneNode(true));
fac7354c55d2 IE9 Compatibility
veltr
parents: 111
diff changeset
   213
			try {
fac7354c55d2 IE9 Compatibility
veltr
parents: 111
diff changeset
   214
				e.originalEvent.dataTransfer.setData("text/html",div.innerHTML);
fac7354c55d2 IE9 Compatibility
veltr
parents: 111
diff changeset
   215
			}
fac7354c55d2 IE9 Compatibility
veltr
parents: 111
diff changeset
   216
			catch(err) {
fac7354c55d2 IE9 Compatibility
veltr
parents: 111
diff changeset
   217
				e.originalEvent.dataTransfer.setData("text",div.innerHTML);
fac7354c55d2 IE9 Compatibility
veltr
parents: 111
diff changeset
   218
			}
20
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
   219
        });
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   220
    Rkns.$(window).resize(function() {
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   221
        _this.resizeBins();
2
3360c3f7fb18 Added Edge management to the rendering engine
veltr
parents: 1
diff changeset
   222
    });
44
869410bab434 Various changes
veltr
parents: 42
diff changeset
   223
    
869410bab434 Various changes
veltr
parents: 42
diff changeset
   224
    this.$.find(".Rk-Bins-Search-Input").on("change keyup paste input", function() {
869410bab434 Various changes
veltr
parents: 42
diff changeset
   225
       var val = Rkns.$(this).val();
869410bab434 Various changes
veltr
parents: 42
diff changeset
   226
       Rkns._(_this.tabs).each(function(tab) {
869410bab434 Various changes
veltr
parents: 42
diff changeset
   227
           tab.render(val);
869410bab434 Various changes
veltr
parents: 42
diff changeset
   228
       });
869410bab434 Various changes
veltr
parents: 42
diff changeset
   229
    });
869410bab434 Various changes
veltr
parents: 42
diff changeset
   230
    this.$.find(".Rk-Bins-Search-Form").submit(function() {
869410bab434 Various changes
veltr
parents: 42
diff changeset
   231
        return false
869410bab434 Various changes
veltr
parents: 42
diff changeset
   232
    });
1
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   233
}
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   234
20
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
   235
Rkns.Renkan.prototype.template = Rkns._.template(
114
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   236
    '<% if (options.show_bins) { %><div class="Rk-Bins"><div class="Rk-Bins-Head"><h2 class="Rk-Bins-Title"><%- translate("Select contents:")%></h2>'
68
803dbeb7c919 Improved drag-and-drop. Added ontologies for edges
veltr
parents: 66
diff changeset
   237
    + '<form class="Rk-Web-Search-Form Rk-Search-Form"><input class="Rk-Web-Search-Input Rk-Search-Input" type="search" placeholder="<%- translate("Search the Web") %>" />'
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   238
    + '<div class="Rk-Search-Select"><div class="Rk-Search-Current"></div><ul class="Rk-Search-List"></ul></div>'
119
0f7d2275a88f Added tooltips for bin refresh
veltr
parents: 114
diff changeset
   239
    + '<input type="submit" value="" class="Rk-Web-Search-Submit Rk-Search-Submit" title="<%- translate("Search the Web") %>" /></form>'
68
803dbeb7c919 Improved drag-and-drop. Added ontologies for edges
veltr
parents: 66
diff changeset
   240
    + '<form class="Rk-Bins-Search-Form Rk-Search-Form"><input class="Rk-Bins-Search-Input Rk-Search-Input" type="search" placeholder="<%- translate("Search in Bins") %>" />'
119
0f7d2275a88f Added tooltips for bin refresh
veltr
parents: 114
diff changeset
   241
    + '<input type="submit" value="" class="Rk-Bins-Search-Submit Rk-Search-Submit" title="<%- translate("Search in Bins") %>" /></form></div>'
114
110f99eb417e moved options to defaults.js and improved read-only switching
veltr
parents: 113
diff changeset
   242
    + '<ul class="Rk-Bin-List"></ul></div><% } %><div class="Rk-Render Rk-Render-<% if (options.show_bins) { %>Panel<% } else { %>Full<% } %>"></div>'
20
bd58970ffd16 Refactoring to better fit the MVVM pattern
veltr
parents: 18
diff changeset
   243
);
18
4423bfcd8f9f UI improvements - Can now delete edges
veltr
parents: 15
diff changeset
   244
111
fbe12f54453a Added connection status
veltr
parents: 110
diff changeset
   245
Rkns.Renkan.prototype.onStatusChange = function() {
fbe12f54453a Added connection status
veltr
parents: 110
diff changeset
   246
	this.renderer.onStatusChange();
fbe12f54453a Added connection status
veltr
parents: 110
diff changeset
   247
}
fbe12f54453a Added connection status
veltr
parents: 110
diff changeset
   248
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   249
34
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   250
Rkns.Renkan.prototype.setSearchEngine = function(_key) {
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   251
    this.search_engine = this.search_engines[_key];
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   252
    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
   253
}
08a366a35143 First part of SH design integration
veltr
parents: 28
diff changeset
   254
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   255
Rkns.Renkan.prototype.resizeBins = function() {
75
7adef9ce92aa A few corrections for list bin
veltr
parents: 73
diff changeset
   256
    var _d = + this.$.find(".Rk-Bins-Head").outerHeight();
44
869410bab434 Various changes
veltr
parents: 42
diff changeset
   257
    this.$.find(".Rk-Bin-Title:visible").each(function() {
26
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   258
        _d += Rkns.$(this).outerHeight();
2fad193bae98 Added basic LDT project import
veltr
parents: 24
diff changeset
   259
    });
21
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   260
    this.$.find(".Rk-Bin-Main").css({
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   261
        height: this.$.find(".Rk-Bins").height() - _d
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   262
    });
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   263
}
b43dd87f7ffa Added Drag+Drop from a tweet list
veltr
parents: 20
diff changeset
   264
1
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   265
/* Utility functions */
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   266
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   267
Rkns.Utils = {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   268
    _ID_AUTO_INCREMENT : 0,
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   269
    _ID_BASE : (function(_d) {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   270
        function pad(n){return n<10 ? '0'+n : n}
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   271
        function fillrand(n) {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   272
            var _res = ''
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   273
            for (var i=0; i<n; i++) {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   274
                _res += Math.floor(16*Math.random()).toString(16);
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   275
            }
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   276
            return _res;
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   277
        }
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   278
        return _d.getUTCFullYear() + '-'  
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   279
            + pad(_d.getUTCMonth()+1) + '-'  
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   280
            + pad(_d.getUTCDate()) + '-'
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   281
            + fillrand(16);
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   282
    })(new Date()),
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   283
    getUID : function(_base) {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   284
        var _n = (++this._ID_AUTO_INCREMENT).toString(16),
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   285
            _base = (typeof _base === "undefined" ? "" : _base + "-" );
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   286
        while (_n.length < 4) {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   287
            _n = '0' + _n
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   288
        }
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   289
        return _base + this._ID_BASE + '-' + _n;
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   290
    },
132
860340d4c645 Improvements for CineCard
veltr
parents: 119
diff changeset
   291
    getFullURL : function(url) {
139
9929b1447f69 - Clean template code for list bin
ymh <ymh.work@gmail.com>
parents: 132
diff changeset
   292
    	
9929b1447f69 - Clean template code for list bin
ymh <ymh.work@gmail.com>
parents: 132
diff changeset
   293
    	if(typeof(url) == 'undefined' || url == null ) {
9929b1447f69 - Clean template code for list bin
ymh <ymh.work@gmail.com>
parents: 132
diff changeset
   294
    		return "";
9929b1447f69 - Clean template code for list bin
ymh <ymh.work@gmail.com>
parents: 132
diff changeset
   295
    	}
9929b1447f69 - Clean template code for list bin
ymh <ymh.work@gmail.com>
parents: 132
diff changeset
   296
    	if(url.indexOf("http://")==0) {
9929b1447f69 - Clean template code for list bin
ymh <ymh.work@gmail.com>
parents: 132
diff changeset
   297
    		return url;
9929b1447f69 - Clean template code for list bin
ymh <ymh.work@gmail.com>
parents: 132
diff changeset
   298
    	}
132
860340d4c645 Improvements for CineCard
veltr
parents: 119
diff changeset
   299
    	var img = new Image();
860340d4c645 Improvements for CineCard
veltr
parents: 119
diff changeset
   300
    	img.src = url;
860340d4c645 Improvements for CineCard
veltr
parents: 119
diff changeset
   301
    	var res = img.src;
860340d4c645 Improvements for CineCard
veltr
parents: 119
diff changeset
   302
    	img.src = null;
860340d4c645 Improvements for CineCard
veltr
parents: 119
diff changeset
   303
    	return res;
860340d4c645 Improvements for CineCard
veltr
parents: 119
diff changeset
   304
    },
1
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   305
    inherit : function(_baseClass, _callbefore) {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   306
        var _class = function() {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   307
            if (typeof _callbefore === "function") {
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   308
                _callbefore.apply(this, Array.prototype.slice.call(arguments, 0));
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   309
            }
28
805d85b3f390 Publishing tests
veltr
parents: 26
diff changeset
   310
            _baseClass.apply(this, Array.prototype.slice.call(arguments, 0));
805d85b3f390 Publishing tests
veltr
parents: 26
diff changeset
   311
            if (typeof this._init == "function") {
805d85b3f390 Publishing tests
veltr
parents: 26
diff changeset
   312
                this._init.apply(this, Array.prototype.slice.call(arguments, 0));
1
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   313
            }
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   314
        }
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   315
        _class.prototype = new _baseClass();
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   316
        return _class;
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   317
    }
45cca39b00ac First rendering tests
veltr
parents:
diff changeset
   318
}