Skip to content

Instantly share code, notes, and snippets.

@walterdavis
Created April 3, 2012 14:24
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save walterdavis/2292393 to your computer and use it in GitHub Desktop.
Save walterdavis/2292393 to your computer and use it in GitHub Desktop.
Safari-style search field polyfill; requires Prototype.js, no other dependencies
//naturally, requires Prototype.js be already loaded
document.observe('dom:loaded',function(){
var q = $('q'); //your search element, must be an <input type="search" />
Element.addMethods({
addResetButton: function(element){
var element = $(element);
if(! element.next('.search-reset') && ( ! Prototype.Browser.WebKit ) ){
var wrapper = ( !!element.up('.search-reset-wrapper') ) ? element.up('.search-reset-wrapper') : element.wrap('span',{style:'position:relative; overflow:hidden;', 'class': 'search-reset-wrapper'});
var reset = new Element('span',{'class': 'search-reset'});
reset.insert('x');
reset.setStyle('-moz-border-radius: 11px; border-radius: 9px; background-color: #cecece; color: #fff; position: absolute; right: 4px; top: 4px; padding: 0 4px 3px; cursor: pointer; font: bold 11px/11px "Lucida Grande", Lucida, Verdana, sans-serif; ');
wrapper.insert(reset);
reset.observe('click',function(evt){
this.stopObserving().remove();
element.clear().focus();
});
var inputColor = new Element('input',{type:'text'}).getStyle('color');
element.setStyle('color: ' + inputColor);
element.focus();
}
return element;
},
removeResetButton: function(element){
var element = $(element);
if( element.next('.search-reset') ) element.next('.search-reset').stopObserving().remove();
return element;
}
});
if(( q.type != 'search' ) || ( ! Prototype.Browser.WebKit )){
var inputColor = new Element('input',{type:'text'}).getStyle('color');
var placeholder = q.readAttribute('placeholder');
var w = q.getWidth();
q.setStyle('background: #fff url() no-repeat left center; padding-left: 18px; padding-right: 18px; -moz-border-radius: 11px; border-radius: 11px; width: ' + (w - 38) + 'px');
if(q.getValue() != placeholder && q.getValue() != ''){
q.addResetButton();
}else{
q.setValue(placeholder).setStyle('color: gray');
}
q.observe('focus',function(evt){
if($F(q) == placeholder){
q.clear().setStyle('color: ' + inputColor);
}
});
q.observe('blur',function(evt){
if($F(q) == ''){
q.setValue(placeholder).setStyle('color: gray').removeResetButton();
}
});
q.observe('keyup', function(evt){
if(($F(this) != '') && ($F(this) != placeholder)){
this.addResetButton();
}
});
}
});
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment