front_idill/src/player/metadataplayer/Mediafragment.js
author bastiena
Thu, 24 May 2012 10:30:05 +0200
changeset 33 2d9b15f99b4e
parent 31 2c7fc855eba8
permissions -rw-r--r--
Front IDILL : search by curves added search by type added notifications added timeline improved
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
31
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
     1
IriSP.Widgets.Mediafragment = function(player, config) {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
     2
    IriSP.Widgets.Widget.call(this, player, config);
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
     3
    this.last_hash = "";
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
     4
    window.onhashchange = this.functionWrapper("goToHash");
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
     5
    if (typeof window.addEventListener !== "undefined") {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
     6
        window.addEventListener('message', function(_msg) {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
     7
            if (_msg.data.type === "hashchange") {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
     8
                document.location.hash = _msg.data.hash;
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
     9
            }
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    10
        })
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    11
    };
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    12
    this.bindPopcorn("pause","setHashToTime");
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    13
    this.bindPopcorn("seeked","setHashToTime");
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    14
    this.bindPopcorn("IriSP.Mediafragment.setHashToAnnotation","setHashToAnnotation");
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    15
    this.blocked = false;
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    16
}
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    17
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    18
IriSP.Widgets.Mediafragment.prototype = new IriSP.Widgets.Widget();
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    19
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    20
IriSP.Widgets.Mediafragment.prototype.draw = function() {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    21
    this.goToHash();
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    22
}
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    23
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    24
IriSP.Widgets.Mediafragment.prototype.goToHash = function() {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    25
    if (document.location.hash !== this.last_hash) {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    26
        this.last_hash = document.location.hash;
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    27
        var _tab = this.last_hash.split("=");
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    28
        if (_tab[0] === '#id') {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    29
            var _annotation = this.source.getElement(_tab[1]);
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    30
            if (typeof _annotation !== "undefined") {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    31
                this.player.popcorn.currentTime(_annotation.begin.getSeconds());
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    32
            }
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    33
        }
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    34
        if (_tab[0] === '#t') {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    35
            this.player.popcorn.currentTime(_tab[1]);
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    36
        }
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    37
    }
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    38
}
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    39
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    40
IriSP.Widgets.Mediafragment.prototype.setHashToAnnotation = function(_annotationId) {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    41
    this.setHash( '#id=' + this.source.unNamespace(_annotationId) );
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    42
}
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    43
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    44
IriSP.Widgets.Mediafragment.prototype.setHashToTime = function(_time) {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    45
    if (_time !== NaN) {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    46
        this.setHash( '#t=' + this.player.popcorn.currentTime() );
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    47
    }
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    48
}
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    49
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    50
IriSP.Widgets.Mediafragment.prototype.setHash = function(_hash) {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    51
    if (!this.blocked && this.last_hash !== _hash) {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    52
        this.last_hash = _hash;
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    53
        document.location.hash = _hash;
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    54
        if (window.parent !== window) {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    55
            window.parent.postMessage({
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    56
                type: "hashchange",
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    57
                hash: _hash
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    58
            })
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    59
        }
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    60
        this.block();
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    61
    }
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    62
}
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    63
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    64
IriSP.Widgets.Mediafragment.prototype.unblock = function() {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    65
    if (typeof this.blockTimeout !== "undefined") {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    66
        window.clearTimeout(this.blockTimeout);
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    67
    }
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    68
    this.blockTimeout = undefined;
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    69
    this.blocked = false;
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    70
}
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    71
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    72
IriSP.Widgets.Mediafragment.prototype.block = function() {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    73
    if (typeof this.blockTimeout !== "undefined") {
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    74
        window.clearTimeout(this.blockTimeout);
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    75
    }
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    76
    this.blocked = true;
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    77
    this.blockTimeout = window.setTimeout(this.functionWrapper("unblock"), 1000);
2c7fc855eba8 FRONT IDILL :
bastiena
parents:
diff changeset
    78
}