metadataplayer/metadataplayer/Controller.js
author veltr
Thu, 27 Sep 2012 12:23:41 +0200
changeset 15 ed7ac7e94090
parent 3 4f1b7aa04ec7
permissions -rw-r--r--
Update Metadataplayer
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
     1
/* Displays Play and Pause buttons, Search Button and Form, Volume Control */
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
     2
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
     3
IriSP.Widgets.Controller = function(player, config) {
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
     4
    IriSP.Widgets.Widget.call(this, player, config);
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
     5
    this.lastSearchValue = "";
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
     6
};
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
     7
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
     8
IriSP.Widgets.Controller.prototype = new IriSP.Widgets.Widget();
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
     9
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    10
IriSP.Widgets.Controller.prototype.defaults = {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    11
    disable_annotate_btn: false,
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
    12
    disable_search_btn: false,
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
    13
    disable_ctrl_f: false
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    14
}
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    15
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    16
IriSP.Widgets.Controller.prototype.template =
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    17
    '<div class="Ldt-Ctrl">'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    18
    + '<div class="Ldt-Ctrl-Left">'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    19
    + '<div class="Ldt-Ctrl-button Ldt-Ctrl-Play Ldt-Ctrl-Play-PlayState Ldt-TraceMe" title="{{l10n.play_pause}}"></div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    20
    + '<div class="Ldt-Ctrl-spacer"></div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    21
    + '{{^disable_annotate_btn}}'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    22
    + '<div class="Ldt-Ctrl-button Ldt-Ctrl-Annotate Ldt-TraceMe" title="{{l10n.annotate}}"></div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    23
    + '<div class="Ldt-Ctrl-spacer"></div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    24
    + '{{/disable_annotate_btn}}'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    25
    + '{{^disable_search_btn}}'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    26
    + '<div class="Ldt-Ctrl-button Ldt-Ctrl-SearchBtn Ldt-TraceMe" title="{{l10n.search}}"></div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    27
    + '<div class="Ldt-Ctrl-spacer"></div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    28
    + '{{/disable_search_btn}}'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    29
    + '<div class="Ldt-Ctrl-Search">'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    30
    + '<input class="Ldt-Ctrl-SearchInput Ldt-TraceMe"></input>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    31
    + '</div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    32
    + '</div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    33
    + '<div class="Ldt-Ctrl-Right">'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    34
    + '<div class="Ldt-Ctrl-spacer"></div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    35
    + '<div class="Ldt-Ctrl-Time">'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    36
    + '<div class="Ldt-Ctrl-Time-Elapsed" title="{{l10n.elapsed_time}}">00:00</div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    37
    + '<div class="Ldt-Ctrl-Time-Separator">/</div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    38
    + '<div class="Ldt-Ctrl-Time-Total" title="{{l10n.total_time}}">00:00</div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    39
    + '</div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    40
    + '<div class="Ldt-Ctrl-spacer"></div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    41
    + '<div class="Ldt-Ctrl-button Ldt-Ctrl-Sound Ldt-Ctrl-Sound-Full Ldt-TraceMe" title="{{l10n.mute_unmute}}"></div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    42
    + '</div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    43
    + '<div class="Ldt-Ctrl-Volume-Control" title="{{l10n.volume_control}}">'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    44
    + '<div class="Ldt-Ctrl-Volume-Bar"></div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    45
    + '</div>'
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    46
    + '</div>';
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    47
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    48
IriSP.Widgets.Controller.prototype.messages = {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    49
    en: {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    50
        play_pause: "Play/Pause",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    51
        mute_unmute: "Mute/Unmute",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    52
        play: "Play",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    53
        pause: "Pause",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    54
        mute: "Mute",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    55
        unmute: "Unmute",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    56
        annotate: "Annotate",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    57
        search: "Search",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    58
        elapsed_time: "Elapsed time",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    59
        total_time: "Total time",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    60
        volume: "Volume",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    61
        volume_control: "Volume control"
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    62
    },
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    63
    fr: {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    64
        play_pause: "Lecture/Pause",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    65
        mute_unmute: "Couper/Activer le son",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    66
        play: "Lecture",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    67
        pause: "Pause",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    68
        mute: "Couper le son",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    69
        unmute: "Activer le son",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    70
        annotate: "Annoter",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    71
        search: "Rechercher",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    72
        elapsed_time: "Durée écoulée",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    73
        total_time: "Durée totale",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    74
        volume: "Niveau sonore",
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    75
        volume_control: "Réglage du niveau sonore"
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    76
    }
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    77
};
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    78
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    79
IriSP.Widgets.Controller.prototype.draw = function() {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    80
    var _this = this;
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    81
    this.renderTemplate();
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    82
    
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    83
    // Define blocks
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    84
    this.$playButton = this.$.find(".Ldt-Ctrl-Play");
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    85
    this.$searchBlock = this.$.find(".Ldt-Ctrl-Search");
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    86
    this.$searchInput = this.$.find(".Ldt-Ctrl-SearchInput");
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    87
    this.$volumeBar = this.$.find(".Ldt-Ctrl-Volume-Bar");
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    88
    
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    89
    // handle events
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
    90
    this.onMediaEvent("play","playButtonUpdater");
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
    91
    this.onMediaEvent("pause","playButtonUpdater");
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
    92
    this.onMediaEvent("volumechange","volumeUpdater");
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
    93
    this.onMediaEvent("timeupdate","timeDisplayUpdater");
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
    94
    this.onMediaEvent("loadedmetadata","volumeUpdater");
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
    95
    this.onMdpEvent("search.matchFound","searchMatch");
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
    96
    this.onMdpEvent("search.noMatchFound","searchNoMatch");
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
    97
    this.onMdpEvent("search.triggeredSearch","triggeredSearch");
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
    98
    this.onMdpEvent("search.cleared","hideSearchBlock");
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
    99
    
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   100
    // handle clicks
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   101
    this.$playButton.click(this.functionWrapper("playHandler"));
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   102
    
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   103
    this.$.find(".Ldt-Ctrl-Annotate").click(function() {
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   104
        _this.player.trigger("CreateAnnotation.toggle");
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   105
    });
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   106
    this.$.find(".Ldt-Ctrl-SearchBtn").click(this.functionWrapper("searchButtonHandler"));
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   107
    
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   108
    this.$searchInput.keyup(this.functionWrapper("searchHandler"));
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   109
  
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   110
	var _volctrl = this.$.find(".Ldt-Ctrl-Volume-Control");
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   111
    this.$.find('.Ldt-Ctrl-Sound')
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   112
        .click(this.functionWrapper("muteHandler"))
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   113
        .mouseover(function() {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   114
            _volctrl.show();
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   115
        })
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   116
        .mouseout(function() {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   117
            _volctrl.hide();
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   118
        });
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   119
    _volctrl.mouseover(function() {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   120
        _volctrl.show();
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   121
    }).mouseout(function() {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   122
        _volctrl.hide();
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   123
    });
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   124
    
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   125
    // Handle CTRL-F
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   126
    if (!this.disable_ctrl_f) {
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   127
        var _fKey = "F".charCodeAt(0),
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   128
            _lastCtrlFTime = 0;
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   129
        IriSP.jQuery(document).keydown(function(_event) {
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   130
            if (_event.keyCode === _fKey && (_event.ctrlKey || _event.metaKey)) {
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   131
                var _time = IriSP.jQuery.now();
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   132
                if (_time - _lastCtrlFTime > 2000) {
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   133
                    _this.searchButtonHandler();
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   134
                }
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   135
                _lastCtrlFTime = _time;
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   136
                return false;
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   137
            }
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   138
        });
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   139
    }
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   140
    
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   141
    // Allow Volume Cursor Dragging
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   142
    this.$volumeBar.slider({
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   143
        slide: function(event, ui) {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   144
            _this.$volumeBar.attr("title",_this.l10n.volume+': ' + ui.value + '%');
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   145
            _this.media.setVolume(ui.value / 100);
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   146
        },
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   147
        stop: this.functionWrapper("volumeUpdater")
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   148
    });
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   149
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   150
    // trigger an IriSP.Player.MouseOver to the widgets that are interested (i.e : sliderWidget)
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   151
    this.$.hover(
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   152
        function() {
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   153
            _this.player.trigger("Player.MouseOver");
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   154
        }, 
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   155
        function() {
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   156
            _this.player.trigger("Player.MouseOut");
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   157
        });
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   158
    
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   159
    this.timeDisplayUpdater(new IriSP.Model.Time(0));
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   160
    /* some players - including jwplayer - save the state of the mute button between sessions */
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   161
   //TODO: MOVE TO THE PLAYER/
3
4f1b7aa04ec7 Added HTML5 Mashup
veltr
parents: 0
diff changeset
   162
    window.setTimeout(this.functionWrapper("volumeUpdater"), 1000);
4f1b7aa04ec7 Added HTML5 Mashup
veltr
parents: 0
diff changeset
   163
   
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   164
};
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   165
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   166
/* Update the elasped time div */
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   167
IriSP.Widgets.Controller.prototype.timeDisplayUpdater = function(_time) {
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   168
  
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   169
    // we get it at each call because it may change.
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   170
    var _totalTime = this.media.duration;
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   171
    this.$.find(".Ldt-Ctrl-Time-Elapsed").html(_time.toString());
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   172
    this.$.find(".Ldt-Ctrl-Time-Total").html(_totalTime.toString());
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   173
};
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   174
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   175
/* update the icon of the button - separate function from playHandler
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   176
   because in some cases (for instance, when the user directly clicks on
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   177
   the jwplayer window) we have to change the icon without playing/pausing
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   178
*/
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   179
IriSP.Widgets.Controller.prototype.playButtonUpdater = function() {
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   180
    if (this.media.getPaused()) {
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   181
    /* the background sprite is changed by adding/removing the correct classes */
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   182
        this.$playButton
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   183
            .attr("title", this.l10n.play)
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   184
            .removeClass("Ldt-Ctrl-Play-PauseState")
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   185
            .addClass("Ldt-Ctrl-Play-PlayState");
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   186
    } else {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   187
        this.$playButton
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   188
            .attr("title", this.l10n.pause)
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   189
            .removeClass("Ldt-Ctrl-Play-PlayState")
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   190
            .addClass("Ldt-Ctrl-Play-PauseState");
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   191
    }
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   192
};
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   193
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   194
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   195
IriSP.Widgets.Controller.prototype.playHandler = function() {
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   196
    if (this.media.getPaused()) {        
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   197
        this.media.play();
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   198
    } else {
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   199
        this.media.pause();
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   200
    }  
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   201
};
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   202
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   203
IriSP.Widgets.Controller.prototype.muteHandler = function() {
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   204
    if (this.media.getMuted()) {
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   205
        this.media.unmute();
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   206
    } else {
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   207
        this.media.mute();
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   208
    }
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   209
};
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   210
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   211
IriSP.Widgets.Controller.prototype.volumeUpdater = function() {
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   212
    var _muted = this.media.getMuted(),
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   213
        _vol = this.media.getVolume();
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   214
    if (_vol === false) {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   215
        _vol = .5;
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   216
    }
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   217
    var _soundCtl = this.$.find(".Ldt-Ctrl-Sound");
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   218
    _soundCtl.removeClass("Ldt-Ctrl-Sound-Mute Ldt-Ctrl-Sound-Half Ldt-Ctrl-Sound-Full");
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   219
    if (_muted) {        
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   220
        _soundCtl.attr("title", this.l10n.unmute)
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   221
            .addClass("Ldt-Ctrl-Sound-Mute");    
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   222
    } else {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   223
        _soundCtl.attr("title", this.l10n.mute)
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   224
            .addClass(_vol < .5 ? "Ldt-Ctrl-Sound-Half" : "Ldt-Ctrl-Sound-Full" )
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   225
    }
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   226
    this.$volumeBar.slider("value", _muted ? 0 : 100 * _vol);
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   227
};
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   228
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   229
IriSP.Widgets.Controller.prototype.showSearchBlock = function() {
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   230
    this.$searchBlock.animate({ width:"160px" }, 200);
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   231
    this.$searchInput.css('background-color','#fff');
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   232
   
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   233
    this.$searchInput.focus();
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   234
    
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   235
    // we need this variable because some widgets can find a match in
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   236
    // their data while at the same time others don't. As we want the
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   237
    // search field to become green when there's a match, we need a 
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   238
    // variable to remember that we had one.
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   239
    this._positiveMatch = false;
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   240
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   241
    // tell the world the field is open
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   242
    this.player.trigger("search.open");
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   243
};
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   244
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   245
IriSP.Widgets.Controller.prototype.hideSearchBlock = function() {
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   246
    this.$searchBlock.animate( { width: 0 }, 200);
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   247
    this._positiveMatch = false;
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   248
    this.player.trigger("search.closed");
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   249
};
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   250
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   251
/** react to clicks on the search button */
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   252
IriSP.Widgets.Controller.prototype.searchButtonHandler = function() {
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   253
    if ( !this.$searchBlock.width() ) {
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   254
        this.showSearchBlock();
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   255
        var _val = this.$searchInput.val();
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   256
        if (_val) {
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   257
            this.player.trigger("search", _val); // trigger the search to make it more natural.
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   258
        }
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   259
	} else {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   260
        this.hideSearchBlock();
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   261
    }
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   262
};
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   263
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   264
/** this handler is called whenever the content of the search
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   265
   field changes */
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   266
IriSP.Widgets.Controller.prototype.searchHandler = function() {
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   267
    if ( !this.$searchBlock.width() ) {
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   268
        this.$searchBlock.css({ width:"160px" });
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   269
        this.$searchInput.css('background-color','#fff');
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   270
    }
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   271
    var _val = this.$searchInput.val();
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   272
    this._positiveMatch = false;
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   273
    
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   274
    // do nothing if the search field is empty, instead of highlighting everything.
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   275
    if (_val !== this.lastSearchValue) {
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   276
        if (_val) {
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   277
            this.player.trigger("search", _val);
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   278
        } else {
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   279
            this.player.trigger("search.cleared");
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   280
            this.$searchInput.css('background-color','');
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   281
        }
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   282
    }
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   283
    this.lastSearchValue = _val;
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   284
};
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   285
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   286
/**
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   287
  handler for the IriSP.search.found message, which is sent by some views when they
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   288
  highlight a match.
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   289
*/
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   290
IriSP.Widgets.Controller.prototype.searchMatch = function() {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   291
    this._positiveMatch = true;
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   292
    this.$searchInput.css('background-color','#e1ffe1');
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   293
};
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   294
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   295
/** the same, except that no value could be found */
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   296
IriSP.Widgets.Controller.prototype.searchNoMatch = function() {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   297
    if (this._positiveMatch !== true) {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   298
        this.$searchInput.css('background-color', "#d62e3a");
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   299
    }
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   300
};
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   301
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   302
/** react to an IriSP.Player.triggeredSearch - that is, when
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   303
    a widget ask the.Player to do a search on his behalf */
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   304
IriSP.Widgets.Controller.prototype.triggeredSearch = function(searchString) {
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   305
    this.showSearchBlock();
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   306
    this.$searchInput.attr('value', searchString);      
15
ed7ac7e94090 Update Metadataplayer
veltr
parents: 3
diff changeset
   307
    this.player.trigger("search", searchString); // trigger the search to make it more natural.
0
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   308
};
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   309
222f9654ed39 Added metadataplayer with examples and docs
veltr
parents:
diff changeset
   310