src/js/widgets/playerWidget.js
author hamidouk
Fri, 04 Nov 2011 12:27:59 +0100
branchpopcorn-port
changeset 194 f5d86e5c4a56
parent 163 3ecb643627de
child 202 2e0205ee7ca9
permissions -rw-r--r--
some cleaning. Also added a progression indicator.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
109
be17a396d68b fix to the PlayerWidget constructor.
hamidouk
parents: 98
diff changeset
     1
IriSP.PlayerWidget = function(Popcorn, config, Serializer) {
be17a396d68b fix to the PlayerWidget constructor.
hamidouk
parents: 98
diff changeset
     2
  IriSP.Widget.call(this, Popcorn, config, Serializer);
145
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
     3
  
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
     4
  this._searchBlockOpen = false;
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
     5
  this._searchLastValue = "";
109
be17a396d68b fix to the PlayerWidget constructor.
hamidouk
parents: 98
diff changeset
     6
};
115
464e3e892915 forgot an inheritance line.
hamidouk
parents: 109
diff changeset
     7
464e3e892915 forgot an inheritance line.
hamidouk
parents: 109
diff changeset
     8
IriSP.PlayerWidget.prototype = new IriSP.Widget();
464e3e892915 forgot an inheritance line.
hamidouk
parents: 109
diff changeset
     9
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    10
IriSP.PlayerWidget.prototype.draw = function() {
153
43f6de365ed4 general code cleanup.
hamidouk
parents: 151
diff changeset
    11
  var self = this;
131
44c1170e0044 renames.
hamidouk
parents: 121
diff changeset
    12
  var width = this.width;
44c1170e0044 renames.
hamidouk
parents: 121
diff changeset
    13
	var height = this.height;
44c1170e0044 renames.
hamidouk
parents: 121
diff changeset
    14
	var heightS = this.height-20;
145
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
    15
	
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
    16
  var searchBox = Mustache.to_html(IriSP.search_template);
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
    17
  this.selector.append(searchBox);
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
    18
  
131
44c1170e0044 renames.
hamidouk
parents: 121
diff changeset
    19
	if (this._config.mode=="radio") {
121
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    20
		var radioPlayer = Mustache.to_html(IriSP.radio_template, {"share_template" : IriSP.share_template});
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    21
    this.selector.append(radioPlayer);		
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    22
    
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    23
		// special tricks for IE 7
121
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    24
		if (IriSP.jQuery.browser.msie == true && IriSP.jQuery.browser.version == "7.0"){
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    25
			//__IriSP.jQuery("#LdtPlayer").attr("margin-top","50px");
121
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    26
			this.selector.children("#Ldt-Root").css("padding-top","25px");			
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    27
		}
131
44c1170e0044 renames.
hamidouk
parents: 121
diff changeset
    28
	} else if (this._config.mode == "video") {
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    29
	
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    30
		var videoPlayer = Mustache.to_html(IriSP.video_template, {"share_template" : IriSP.share_template, "heightS" : heightS});
121
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    31
    this.selector.append(videoPlayer);		
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    32
	}
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    33
	
121
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    34
	this.selector.children("#Ldt-Annotations").width(width - (75 * 2));
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    35
	this.selector.children("#Ldt-Show-Arrow-container").width(width - (75 * 2));
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    36
	this.selector.children("#Ldt-ShowAnnotation-audio").width(width - 10);
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    37
	this.selector.children("#Ldt-ShowAnnotation-video").width(width - 10);
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    38
	this.selector.children("#Ldt-SaKeyword").width(width - 10);
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    39
	this.selector.children("#Ldt-controler").width(width - 10);
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    40
	this.selector.children("#Ldt-Control").attr("z-index", "100");
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    41
	this.selector.children("#Ldt-controler").hide();
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    42
	
121
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    43
  this.selector.children("#Ldt-ShowAnnotation-audio").append(IriSP.annotation_loading_template);	
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    44
131
44c1170e0044 renames.
hamidouk
parents: 121
diff changeset
    45
	if(this._config.mode=='radio'){
44c1170e0044 renames.
hamidouk
parents: 121
diff changeset
    46
		this.selector.children("#Ldt-load-container").attr("width",this.width);
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    47
	}
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    48
	  		
121
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    49
  this.selector.children("#Ldt-controler").show();
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    50
  //__IriSP.jQuery("#Ldt-Root").css('display','visible');
121
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    51
  this.selector.children("#Ldt-ShowAnnotation").click( function () { 
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    52
     //__IriSP.jQuery(this).slideUp(); 
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    53
  } );
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    54
121
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    55
  var LdtpPlayerY = this.selector.children("#Ldt-PlaceHolder").attr("top");
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    56
  var LdtpPlayerX = this.selector.children("#Ldt-PlaceHolder").attr("left");
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    57
  
121
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    58
  this.selector.find("#slider-range-min").slider( { //range: "min",
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    59
    value: 0,
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    60
    min: 1,
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    61
    max: this._serializer.currentMedia().meta["dc:duration"]/1000,//1:54:52.66 = 3600+3240+
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    62
    step: 0.1,
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    63
    slide: function(event, ui) {     
153
43f6de365ed4 general code cleanup.
hamidouk
parents: 151
diff changeset
    64
      self._Popcorn.currentTime(ui.value);
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    65
    },
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    66
    /* change event is similar to slide, but it happens when the slider position is 
153
43f6de365ed4 general code cleanup.
hamidouk
parents: 151
diff changeset
    67
       modified programatically. We use it for unit tests */       
43f6de365ed4 general code cleanup.
hamidouk
parents: 151
diff changeset
    68
    change: function(event, ui) {      
43f6de365ed4 general code cleanup.
hamidouk
parents: 151
diff changeset
    69
      self._Popcorn.trigger("test.fixture", ui.value);
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    70
    }
153
43f6de365ed4 general code cleanup.
hamidouk
parents: 151
diff changeset
    71
    
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    72
  } );
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    73
  
153
43f6de365ed4 general code cleanup.
hamidouk
parents: 151
diff changeset
    74
  this._Popcorn.listen("timeupdate", IriSP.wrap(this, this.sliderUpdater));
121
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    75
  this.selector.children("#amount").val(this.selector.children("#slider-range-min").slider("value")+" s");
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    76
  this.selector.children(".Ldt-Control1 button:first").button({
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    77
    icons: {
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    78
      primary: 'ui-icon-play'
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    79
    },
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    80
    text: false
153
43f6de365ed4 general code cleanup.
hamidouk
parents: 151
diff changeset
    81
  }).click(function() { self.playHandler.call(self); })
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    82
    .next().button({
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    83
    icons: {
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    84
      primary: 'ui-icon-seek-next'
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    85
    },
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    86
     text: false
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    87
  });
121
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
    88
  this.selector.children(".Ldt-Control2 button:first").button({
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    89
    icons: {
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    90
      primary: 'ui-icon-search'//,
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    91
      //secondary: 'ui-icon-volume-off'
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    92
    },
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    93
    text: false
153
43f6de365ed4 general code cleanup.
hamidouk
parents: 151
diff changeset
    94
  }).click(function() { self.searchButtonHandler.call(self); })
145
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
    95
    .next().button({
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    96
    icons: {
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    97
      primary: 'ui-icon-volume-on'
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    98
    },
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
    99
     text: false
153
43f6de365ed4 general code cleanup.
hamidouk
parents: 151
diff changeset
   100
  }).click(function() { self.muteHandler.call(self); } );
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   101
121
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
   102
  this.selector.children("#ldt-CtrlPlay").attr( "style", "background-color:#CD21C24;" );
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   103
  
121
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
   104
  this.selector.children("#Ldt-load-container").hide();
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   105
  
131
44c1170e0044 renames.
hamidouk
parents: 121
diff changeset
   106
  if( this._config.mode=="radio" & IriSP.jQuery.browser.msie != true ) {
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   107
    IriSP.jQuery( "#Ldtplayer1" ).attr( "height", "0" );
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   108
  }
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   109
153
43f6de365ed4 general code cleanup.
hamidouk
parents: 151
diff changeset
   110
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   111
};
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   112
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   113
IriSP.PlayerWidget.prototype.playHandler = function() {
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   114
  var status = this._Popcorn.media.paused;
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   115
  
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   116
  if ( status == true ){        
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   117
    this._Popcorn.play();
163
3ecb643627de some conversions to use this.selector.find instead of .children().
hamidouk
parents: 154
diff changeset
   118
    this.selector.find(".ui-icon-play").css( "background-position", "-16px -160px" );
3ecb643627de some conversions to use this.selector.find instead of .children().
hamidouk
parents: 154
diff changeset
   119
    this.selector.find("#ldt-CtrlPlay").attr("title", "Play");
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   120
  } else {
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   121
    this._Popcorn.pause();
163
3ecb643627de some conversions to use this.selector.find instead of .children().
hamidouk
parents: 154
diff changeset
   122
    this.selector.find(".ui-icon-play").css( "background-position","0px -160px" );
3ecb643627de some conversions to use this.selector.find instead of .children().
hamidouk
parents: 154
diff changeset
   123
    this.selector.find("#ldt-CtrlPlay").attr("title", "Pause");
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   124
  }  
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   125
};
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   126
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   127
IriSP.PlayerWidget.prototype.muteHandler = function() {
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   128
  if (!this._Popcorn.muted()) {    
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   129
      this._Popcorn.mute(true);
163
3ecb643627de some conversions to use this.selector.find instead of .children().
hamidouk
parents: 154
diff changeset
   130
      this.selector.find(" .ui-icon-volume-on ").css("background-position", "-130px -160px");    
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   131
    } else {
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   132
      this._Popcorn.mute(false);
163
3ecb643627de some conversions to use this.selector.find instead of .children().
hamidouk
parents: 154
diff changeset
   133
      this.selector.find( ".ui-icon-volume-on" ).css("background-position", "-144px -160px" );
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   134
    }
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   135
};
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   136
145
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   137
/* updates the slider as time passes */
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   138
IriSP.PlayerWidget.prototype.sliderUpdater = function() {  
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   139
  var currentPosition = this._Popcorn.currentTime();   
121
607f481ef4c3 some refactoring to use this.selector instead of directly using jquery.
hamidouk
parents: 115
diff changeset
   140
	this.selector.find( "#slider-range-min" ).slider( "value", currentPosition);		
98
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   141
};
ed4ac18baf07 broke the widgets.js in multiple files.
hamidouk
parents:
diff changeset
   142
145
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   143
IriSP.PlayerWidget.prototype.searchButtonHandler = function() {
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   144
    var self = this;
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   145
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   146
    /* show the search field if it is not shown */
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   147
  	if ( this._searchBlockOpen == false ) {
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   148
      this.selector.find( ".ui-icon-search" ).css( "background-position", "-144px -112px" );
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   149
      
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   150
      this.selector.find("#LdtSearch").show(100);
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   151
      
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   152
      this.selector.find("#LdtSearchInput").css('background-color','#fff');
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   153
      this.selector.find("#LdtSearchInput").focus();
151
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   154
      this.selector.find("#LdtSearchInput").attr('value', this._searchLastValue);      
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   155
      this._Popcorn.trigger("IriSP.search", this._searchLastValue); // trigger the search to make it more natural.
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   156
      
145
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   157
      this._searchBlockOpen = true;           
151
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   158
      this.selector.find("#LdtSearchInput").bind('keyup', null, function() { self.searchHandler.call(self); } );
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   159
      
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   160
      // tell the world the field is open
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   161
      this._Popcorn.trigger("IriSP.search.open");
145
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   162
      
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   163
	} else {
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   164
      this._searchLastValue = this.selector.find("#LdtSearchInput").attr('value');
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   165
      this.selector.find("#LdtSearchInput").attr('value','');
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   166
      this.selector.find(".ui-icon-search").css("background-position","-160px -112px");
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   167
      this.selector.find("#LdtSearch").hide(100);
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   168
      
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   169
      // unbind the watcher event.
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   170
      this.selector.find("#LdtSearchInput").unbind('keypress set');
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   171
      this._searchBlockOpen = false;
151
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   172
      
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   173
      this._Popcorn.trigger("IriSP.search.closed");
145
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   174
  }
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   175
};
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   176
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   177
/* this handler is called whenever the content of the search
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   178
   field changes */
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   179
IriSP.PlayerWidget.prototype.searchHandler = function() {
b477c9430d36 tests and implementation of the search button for the player.
hamidouk
parents: 131
diff changeset
   180
  this._searchLastValue = this.selector.find("#LdtSearchInput").attr('value');
154
6e115a094858 another tweak to the searchBox : the visualization is cleared when the searchbox
hamidouk
parents: 153
diff changeset
   181
  
6e115a094858 another tweak to the searchBox : the visualization is cleared when the searchbox
hamidouk
parents: 153
diff changeset
   182
  // do nothing if the search field is empty, instead of highlighting everything.
6e115a094858 another tweak to the searchBox : the visualization is cleared when the searchbox
hamidouk
parents: 153
diff changeset
   183
  if (this._searchLastValue == "") {
6e115a094858 another tweak to the searchBox : the visualization is cleared when the searchbox
hamidouk
parents: 153
diff changeset
   184
    this._Popcorn.trigger("IriSP.search.cleared");
6e115a094858 another tweak to the searchBox : the visualization is cleared when the searchbox
hamidouk
parents: 153
diff changeset
   185
  } else {
6e115a094858 another tweak to the searchBox : the visualization is cleared when the searchbox
hamidouk
parents: 153
diff changeset
   186
    this._Popcorn.trigger("IriSP.search", this._searchLastValue);
6e115a094858 another tweak to the searchBox : the visualization is cleared when the searchbox
hamidouk
parents: 153
diff changeset
   187
  }
151
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   188
};
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   189
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   190
/*
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   191
  handler for the IriSP.search.found message, which is sent by some views when they
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   192
  highlight a match.
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   193
*/
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   194
IriSP.PlayerWidget.prototype.searchMatch = function() {
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   195
  this.selector.find("#LdtSearchInput").css('background-color','#e1ffe1');
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   196
}
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   197
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   198
/* the same, except that no value could be found */
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   199
IriSP.PlayerWidget.prototype.searchNoMatch = function() {
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   200
  this.selector.find("#LdtSearchInput").css('background-color','#e1ffe1');
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   201
}
dc2ff4c87490 some tweaking to make the search function more user-friendly.
hamidouk
parents: 145
diff changeset
   202