src/js/widgets-container/metadataplayer.js
author veltr
Tue, 01 Oct 2013 15:41:46 +0200
changeset 1013 392ddcd212d7
parent 1000 91023037f841
child 1043 967ac73327dc
permissions -rw-r--r--
Throwed in a bunch of semicolons
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
     1
/* widgets-container/metadataplayer.js - initialization and configuration of the widgets
9521347ede1d Refactoring
veltr
parents:
diff changeset
     2
*/
9521347ede1d Refactoring
veltr
parents:
diff changeset
     3
9521347ede1d Refactoring
veltr
parents:
diff changeset
     4
/* The Metadataplayer Object, single point of entry, replaces IriSP.init_player */
9521347ede1d Refactoring
veltr
parents:
diff changeset
     5
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
     6
(function(ns) {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
     7
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
     8
var formerJQuery, formerUnderscore, former$;
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
     9
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    10
var Metadataplayer = ns.Metadataplayer = function(config) {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    11
    ns.log("IriSP.Metadataplayer constructor");
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    12
    for (var key in ns.guiDefaults) {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    13
        if (ns.guiDefaults.hasOwnProperty(key) && !config.hasOwnProperty(key)) {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    14
            config[key] = ns.guiDefaults[key]
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
    15
        }
9521347ede1d Refactoring
veltr
parents:
diff changeset
    16
    }
9521347ede1d Refactoring
veltr
parents:
diff changeset
    17
    var _container = document.getElementById(config.container);
9521347ede1d Refactoring
veltr
parents:
diff changeset
    18
    _container.innerHTML = '<h3 class="Ldt-Loader">Loading... Chargement...</h3>';
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    19
    this.sourceManager = new ns.Model.Directory();
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
    20
    this.config = config;
9521347ede1d Refactoring
veltr
parents:
diff changeset
    21
    this.__events = {};
9521347ede1d Refactoring
veltr
parents:
diff changeset
    22
    this.loadLibs();
9521347ede1d Refactoring
veltr
parents:
diff changeset
    23
};
9521347ede1d Refactoring
veltr
parents:
diff changeset
    24
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    25
Metadataplayer.prototype.toString = function() {
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
    26
    return 'Metadataplayer in #' + this.config.container;
9521347ede1d Refactoring
veltr
parents:
diff changeset
    27
};
9521347ede1d Refactoring
veltr
parents:
diff changeset
    28
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    29
Metadataplayer.prototype.on = function(_event, _callback) {
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
    30
    if (typeof this.__events[_event] === "undefined") {
9521347ede1d Refactoring
veltr
parents:
diff changeset
    31
        this.__events[_event] = [];
9521347ede1d Refactoring
veltr
parents:
diff changeset
    32
    }
9521347ede1d Refactoring
veltr
parents:
diff changeset
    33
    this.__events[_event].push(_callback);
9521347ede1d Refactoring
veltr
parents:
diff changeset
    34
};
9521347ede1d Refactoring
veltr
parents:
diff changeset
    35
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    36
Metadataplayer.prototype.trigger = function(_event, _data) {
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
    37
    var _element = this;
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    38
    ns._(this.__events[_event]).each(function(_callback) {
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
    39
        _callback.call(_element, _data);
9521347ede1d Refactoring
veltr
parents:
diff changeset
    40
    });
9521347ede1d Refactoring
veltr
parents:
diff changeset
    41
};
9521347ede1d Refactoring
veltr
parents:
diff changeset
    42
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    43
Metadataplayer.prototype.loadLibs = function() {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    44
    ns.log("IriSP.Metadataplayer.prototype.loadLibs");
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
    45
    var $L = $LAB
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    46
        .script(ns.getLib("Mustache"));
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    47
    
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    48
    formerJQuery = !!window.jQuery;
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    49
    former$ = !!window.$;
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    50
    formerUnderscore = !!window._;
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
    51
    
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    52
    if (typeof ns.jQuery === "undefined") {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    53
        $L.script(ns.getLib("jQuery"));
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    54
    }
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    55
    
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    56
    if (typeof ns._ === "undefined") {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    57
        $L.script(ns.getLib("underscore"));
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    58
    }
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    59
    
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    60
    if (typeof window.JSON == "undefined") {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    61
        $L.script(ns.getLib("json"));
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
    62
    }
9521347ede1d Refactoring
veltr
parents:
diff changeset
    63
    
9521347ede1d Refactoring
veltr
parents:
diff changeset
    64
    $L.wait()
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    65
        .script(ns.getLib("jQueryUI"));
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
    66
9521347ede1d Refactoring
veltr
parents:
diff changeset
    67
    /* widget specific requirements */
9521347ede1d Refactoring
veltr
parents:
diff changeset
    68
    for(var _i = 0; _i < this.config.widgets.length; _i++) {
9521347ede1d Refactoring
veltr
parents:
diff changeset
    69
        var _t = this.config.widgets[_i].type;
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    70
        if (typeof ns.widgetsRequirements[_t] !== "undefined" && typeof ns.widgetsRequirements[_t].requires !== "undefined" ) {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    71
            for (var _j = 0; _j < ns.widgetsRequirements[_t].requires.length; _j++) {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    72
                $L.script(ns.getLib(ns.widgetsRequirements[_t].requires[_j]));
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
    73
            }
9521347ede1d Refactoring
veltr
parents:
diff changeset
    74
        }
9521347ede1d Refactoring
veltr
parents:
diff changeset
    75
    }
9521347ede1d Refactoring
veltr
parents:
diff changeset
    76
    
9521347ede1d Refactoring
veltr
parents:
diff changeset
    77
    var _this = this;
9521347ede1d Refactoring
veltr
parents:
diff changeset
    78
    
9521347ede1d Refactoring
veltr
parents:
diff changeset
    79
    $L.wait(function() {
9521347ede1d Refactoring
veltr
parents:
diff changeset
    80
        _this.onLibsLoaded();
9521347ede1d Refactoring
veltr
parents:
diff changeset
    81
    });
9521347ede1d Refactoring
veltr
parents:
diff changeset
    82
};
9521347ede1d Refactoring
veltr
parents:
diff changeset
    83
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    84
Metadataplayer.prototype.onLibsLoaded = function() {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    85
    ns.log("IriSP.Metadataplayer.prototype.onLibsLoaded");
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    86
    if (typeof ns.jQuery === "undefined" && typeof window.jQuery !== "undefined") {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    87
        ns.jQuery = window.jQuery;
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    88
        if (former$ || formerJQuery) {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    89
            window.jQuery.noConflict(formerJQuery);
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    90
        }
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
    91
    }
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    92
    if (typeof ns._ === "undefined" && typeof window._ !== "undefined") {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    93
        ns._ = window._;
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    94
        if (formerUnderscore) {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    95
            _.noConflict();
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    96
        }
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
    97
    }
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    98
    ns.loadCss(ns.getLib("cssjQueryUI"));
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
    99
    ns.loadCss(this.config.css);
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
   100
    
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   101
    this.$ = ns.jQuery('#' + this.config.container);
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
   102
    this.$.css({
9521347ede1d Refactoring
veltr
parents:
diff changeset
   103
        "width": this.config.width,
9521347ede1d Refactoring
veltr
parents:
diff changeset
   104
        "clear": "both"
9521347ede1d Refactoring
veltr
parents:
diff changeset
   105
    });
9521347ede1d Refactoring
veltr
parents:
diff changeset
   106
    if (typeof this.config.height !== "undefined") {
9521347ede1d Refactoring
veltr
parents:
diff changeset
   107
        this.$.css("height", this.config.height);
9521347ede1d Refactoring
veltr
parents:
diff changeset
   108
    }
9521347ede1d Refactoring
veltr
parents:
diff changeset
   109
      
9521347ede1d Refactoring
veltr
parents:
diff changeset
   110
    this.widgets = [];
9521347ede1d Refactoring
veltr
parents:
diff changeset
   111
    var _this = this;
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   112
    ns._(this.config.widgets).each(function(widgetconf, key) {
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
   113
        _this.widgets.push(null);
9521347ede1d Refactoring
veltr
parents:
diff changeset
   114
        _this.loadWidget(widgetconf, function(widget) {
9521347ede1d Refactoring
veltr
parents:
diff changeset
   115
            _this.widgets[key] = widget;
9521347ede1d Refactoring
veltr
parents:
diff changeset
   116
            if (widget.isLoaded()) {
9521347ede1d Refactoring
veltr
parents:
diff changeset
   117
                _this.trigger("widget-loaded");
9521347ede1d Refactoring
veltr
parents:
diff changeset
   118
            }
9521347ede1d Refactoring
veltr
parents:
diff changeset
   119
        });
9521347ede1d Refactoring
veltr
parents:
diff changeset
   120
    });
9521347ede1d Refactoring
veltr
parents:
diff changeset
   121
    this.$.find('.Ldt-Loader').detach();
9521347ede1d Refactoring
veltr
parents:
diff changeset
   122
    
9521347ede1d Refactoring
veltr
parents:
diff changeset
   123
    this.widgetsLoaded = false;
9521347ede1d Refactoring
veltr
parents:
diff changeset
   124
    
9521347ede1d Refactoring
veltr
parents:
diff changeset
   125
    this.on("widget-loaded", function() {
9521347ede1d Refactoring
veltr
parents:
diff changeset
   126
        if (_this.widgetsLoaded) {
9521347ede1d Refactoring
veltr
parents:
diff changeset
   127
            return;
9521347ede1d Refactoring
veltr
parents:
diff changeset
   128
        }
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   129
        var isloaded = !ns._(_this.widgets).any(function(w) {
1013
392ddcd212d7 Throwed in a bunch of semicolons
veltr
parents: 1000
diff changeset
   130
            return !(w && w.isLoaded());
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
   131
        });
9521347ede1d Refactoring
veltr
parents:
diff changeset
   132
        if (isloaded) {
9521347ede1d Refactoring
veltr
parents:
diff changeset
   133
            _this.widgetsLoaded = true;
9521347ede1d Refactoring
veltr
parents:
diff changeset
   134
            _this.trigger("widgets-loaded");
9521347ede1d Refactoring
veltr
parents:
diff changeset
   135
        }
9521347ede1d Refactoring
veltr
parents:
diff changeset
   136
    });   
9521347ede1d Refactoring
veltr
parents:
diff changeset
   137
};
9521347ede1d Refactoring
veltr
parents:
diff changeset
   138
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   139
Metadataplayer.prototype.loadMetadata = function(_metadataInfo) {
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
   140
    if (_metadataInfo.elementType === "source") {
9521347ede1d Refactoring
veltr
parents:
diff changeset
   141
        return _metadataInfo;
9521347ede1d Refactoring
veltr
parents:
diff changeset
   142
    }
9521347ede1d Refactoring
veltr
parents:
diff changeset
   143
    if (typeof _metadataInfo.serializer === "undefined" && typeof _metadataInfo.format !== "undefined") {
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   144
        _metadataInfo.serializer = ns.serializers[_metadataInfo.format];
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
   145
    }
9521347ede1d Refactoring
veltr
parents:
diff changeset
   146
    if (typeof _metadataInfo.url !== "undefined" && typeof _metadataInfo.serializer !== "undefined") {
9521347ede1d Refactoring
veltr
parents:
diff changeset
   147
        return this.sourceManager.remoteSource(_metadataInfo);
9521347ede1d Refactoring
veltr
parents:
diff changeset
   148
    } else {
9521347ede1d Refactoring
veltr
parents:
diff changeset
   149
        return this.sourceManager.newLocalSource(_metadataInfo);
9521347ede1d Refactoring
veltr
parents:
diff changeset
   150
    }
9521347ede1d Refactoring
veltr
parents:
diff changeset
   151
};
9521347ede1d Refactoring
veltr
parents:
diff changeset
   152
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   153
Metadataplayer.prototype.loadWidget = function(_widgetConfig, _callback) {
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
   154
    /* Creating containers if needed */
9521347ede1d Refactoring
veltr
parents:
diff changeset
   155
    if (typeof _widgetConfig.container === "undefined") {
9521347ede1d Refactoring
veltr
parents:
diff changeset
   156
        var _divs = this.layoutDivs(_widgetConfig.type);
9521347ede1d Refactoring
veltr
parents:
diff changeset
   157
        _widgetConfig.container = _divs[0];
9521347ede1d Refactoring
veltr
parents:
diff changeset
   158
    }
9521347ede1d Refactoring
veltr
parents:
diff changeset
   159
    
9521347ede1d Refactoring
veltr
parents:
diff changeset
   160
    var _this = this;
9521347ede1d Refactoring
veltr
parents:
diff changeset
   161
    
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   162
    if (typeof ns.Widgets[_widgetConfig.type] !== "undefined") {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   163
        ns._.defer(function() {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   164
            _callback(new ns.Widgets[_widgetConfig.type](_this, _widgetConfig));
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
   165
        });
9521347ede1d Refactoring
veltr
parents:
diff changeset
   166
    } else {
9521347ede1d Refactoring
veltr
parents:
diff changeset
   167
        /* Loading Widget CSS */
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   168
        if (typeof ns.widgetsRequirements[_widgetConfig.type] === "undefined" || typeof ns.widgetsRequirements[_widgetConfig.type].noCss === "undefined" || !ns.widgetsRequirements[_widgetConfig.type].noCss) {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   169
            ns.loadCss(ns.widgetsDir + '/' + _widgetConfig.type + '.css');
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
   170
        }
9521347ede1d Refactoring
veltr
parents:
diff changeset
   171
        /* Loading Widget JS    */
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   172
        $LAB.script(ns.widgetsDir + '/' + _widgetConfig.type + '.js').wait(function() {
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   173
            _callback(new ns.Widgets[_widgetConfig.type](_this, _widgetConfig));
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
   174
        });
9521347ede1d Refactoring
veltr
parents:
diff changeset
   175
    }
9521347ede1d Refactoring
veltr
parents:
diff changeset
   176
};
9521347ede1d Refactoring
veltr
parents:
diff changeset
   177
9521347ede1d Refactoring
veltr
parents:
diff changeset
   178
/** create a subdiv with an unique id, and a spacer div as well.
9521347ede1d Refactoring
veltr
parents:
diff changeset
   179
    @param widgetName the name of the widget.
9521347ede1d Refactoring
veltr
parents:
diff changeset
   180
    @return an array of the form [createdivId, spacerdivId].
9521347ede1d Refactoring
veltr
parents:
diff changeset
   181
*/
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   182
Metadataplayer.prototype.layoutDivs = function(_name, _height) {
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
   183
    if (typeof(_name) === "undefined") {
9521347ede1d Refactoring
veltr
parents:
diff changeset
   184
       _name = "";
9521347ede1d Refactoring
veltr
parents:
diff changeset
   185
    }
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   186
    var newDiv = ns._.uniqueId(this.config.container + "_widget_" + _name + "_"),
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   187
        spacerDiv = ns._.uniqueId("LdtPlayer_spacer_"),
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   188
        divHtml = ns.jQuery('<div>')
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
   189
            .attr("id",newDiv)
9521347ede1d Refactoring
veltr
parents:
diff changeset
   190
            .css({
9521347ede1d Refactoring
veltr
parents:
diff changeset
   191
                width: this.config.width + "px",
9521347ede1d Refactoring
veltr
parents:
diff changeset
   192
                position: "relative",
9521347ede1d Refactoring
veltr
parents:
diff changeset
   193
                clear: "both"
9521347ede1d Refactoring
veltr
parents:
diff changeset
   194
            }),
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   195
        spacerHtml = ns.jQuery('<div>')
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
   196
            .attr("id",spacerDiv)
9521347ede1d Refactoring
veltr
parents:
diff changeset
   197
            .css({
9521347ede1d Refactoring
veltr
parents:
diff changeset
   198
                width: this.config.width + "px",
9521347ede1d Refactoring
veltr
parents:
diff changeset
   199
                height: this.config.spacer_div_height + "px",
9521347ede1d Refactoring
veltr
parents:
diff changeset
   200
                position: "relative",
9521347ede1d Refactoring
veltr
parents:
diff changeset
   201
                clear: "both"
9521347ede1d Refactoring
veltr
parents:
diff changeset
   202
            });
9521347ede1d Refactoring
veltr
parents:
diff changeset
   203
    if (typeof _height !== "undefined") {
9521347ede1d Refactoring
veltr
parents:
diff changeset
   204
        divHtml.css("height", _height);
9521347ede1d Refactoring
veltr
parents:
diff changeset
   205
    }
9521347ede1d Refactoring
veltr
parents:
diff changeset
   206
            
9521347ede1d Refactoring
veltr
parents:
diff changeset
   207
    this.$.append(divHtml);
9521347ede1d Refactoring
veltr
parents:
diff changeset
   208
    this.$.append(spacerHtml);
9521347ede1d Refactoring
veltr
parents:
diff changeset
   209
9521347ede1d Refactoring
veltr
parents:
diff changeset
   210
    return [newDiv, spacerDiv];
9521347ede1d Refactoring
veltr
parents:
diff changeset
   211
};
9521347ede1d Refactoring
veltr
parents:
diff changeset
   212
1000
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   213
})(IriSP);
91023037f841 check jQuery and Underscore versions
veltr
parents: 998
diff changeset
   214
998
9521347ede1d Refactoring
veltr
parents:
diff changeset
   215
/* End of widgets-container/metadataplayer.js */