2010-01-20 14:00:14 +00:00
/ *
* autocomplete _options . js
* /
( function ( $ ) {
2010-03-11 03:28:00 +00:00
module ( "autocomplete: options" , {
teardown : function ( ) {
$ ( ":ui-autocomplete" ) . autocomplete ( "destroy" ) ;
}
} ) ;
2010-01-20 14:00:14 +00:00
/ * d i s a b l e d u n t i l a u t o c o m p l e t e a c t u a l l y h a s b u i l t - i n s u p p o r t f o r c a c h i n g
// returns at most 4 items
function source ( request ) {
ok ( true , "handling a request" ) ;
switch ( request . term ) {
case "cha" :
return [ "Common Pochard" , "Common Chiffchaff" , "Common Chaffinch" , "Iberian Chiffchaff" ]
case "chaf" :
case "chaff" :
return [ "Common Chiffchaff" , "Common Chaffinch" , "Iberian Chiffchaff" ]
case "chaffi" :
return [ "Common Chaffinch" ]
case "schi" :
return [ "schifpre" ]
}
}
function search ( input ) {
var autocomplete = input . data ( "autocomplete" ) ;
autocomplete . search ( "cha" ) ;
autocomplete . close ( ) ;
autocomplete . search ( "chaf" ) ;
autocomplete . close ( ) ;
autocomplete . search ( "chaff" ) ;
autocomplete . close ( ) ;
autocomplete . search ( "chaffi" ) ;
autocomplete . close ( ) ;
autocomplete . search ( "schi" ) ;
}
test ( "cache: default" , function ( ) {
expect ( 2 ) ;
search ( $ ( "#autocomplete" ) . autocomplete ( {
source : source
} ) ) ;
} ) ;
test ( "cache: {limit:4}" , function ( ) {
expect ( 3 ) ;
search ( $ ( "#autocomplete" ) . autocomplete ( {
cache : {
limit : 4
} ,
source : source
} ) ) ;
} ) ;
test ( "cache: false" , function ( ) {
expect ( 5 ) ;
search ( $ ( "#autocomplete" ) . autocomplete ( {
cache : false ,
source : source
} ) ) ;
} ) ;
* /
2010-03-20 14:37:18 +00:00
var data = [ "c++" , "java" , "php" , "coldfusion" , "javascript" , "asp" , "ruby" , "python" , "c" , "scala" , "groovy" , "haskell" , "perl" ] ;
2010-01-20 14:00:14 +00:00
2010-07-21 18:54:20 +00:00
test ( "appendTo" , function ( ) {
var ac = $ ( "#autocomplete" ) . autocomplete ( ) ;
same ( ac . autocomplete ( "widget" ) . parent ( ) [ 0 ] , document . body , "defaults to body" ) ;
ac . autocomplete ( "destroy" ) ;
ac . autocomplete ( {
appendTo : "#ac-wrap2"
} ) ;
same ( ac . autocomplete ( "widget" ) . parent ( ) [ 0 ] , $ ( "#ac-wrap2" ) [ 0 ] , "id" ) ;
ac . autocomplete ( "destroy" ) ;
ac . autocomplete ( {
appendTo : ".ac-wrap"
} ) ;
same ( ac . autocomplete ( "widget" ) . parent ( ) [ 0 ] , $ ( "#ac-wrap1" ) [ 0 ] , "class" ) ;
same ( $ ( "#ac-wrap2 .ui-autocomplete" ) . length , 0 , "class - only appends to one element" )
ac . autocomplete ( "destroy" ) ;
ac . autocomplete ( {
appendTo : null
} ) ;
same ( ac . autocomplete ( "widget" ) . parent ( ) [ 0 ] , document . body , "null" ) ;
ac . autocomplete ( "destroy" ) ;
ac . autocomplete ( ) . autocomplete ( "option" , "appendTo" , "#ac-wrap1" ) ;
same ( ac . autocomplete ( "widget" ) . parent ( ) [ 0 ] , $ ( "#ac-wrap1" ) [ 0 ] , "modified after init" ) ;
ac . autocomplete ( "destroy" ) ;
} ) ;
2011-03-15 13:36:36 +00:00
function autoFocusTest ( afValue , focusedLength ) {
2011-03-15 12:42:28 +00:00
var ac = $ ( "#autocomplete" ) . autocomplete ( {
2011-03-15 13:36:36 +00:00
autoFocus : afValue ,
2011-03-15 12:42:28 +00:00
delay : 0 ,
source : data ,
open : function ( event , ui ) {
2011-03-15 16:55:16 +00:00
equal ( ac . autocomplete ( "widget" ) . children ( ".ui-menu-item:first .ui-state-focus" ) . length , focusedLength , "first item is " + afValue ? "" : "not" + " auto focused" ) ;
2011-03-15 12:42:28 +00:00
start ( ) ;
}
} ) ;
ac . val ( "ja" ) . keydown ( ) ;
stop ( ) ;
2011-03-15 13:36:36 +00:00
}
test ( "autoFocus: false" , function ( ) {
autoFocusTest ( false , 0 ) ;
2011-03-15 12:42:28 +00:00
} ) ;
test ( "autoFocus: true" , function ( ) {
2011-03-15 13:36:36 +00:00
autoFocusTest ( true , 1 ) ;
2011-03-15 12:42:28 +00:00
} ) ;
2010-07-21 18:54:20 +00:00
2010-01-20 14:00:14 +00:00
test ( "delay" , function ( ) {
var ac = $ ( "#autocomplete" ) . autocomplete ( {
source : data ,
delay : 50
} ) ;
ac . val ( "ja" ) . keydown ( ) ;
2010-02-02 14:04:50 +00:00
same ( $ ( ".ui-menu:visible" ) . length , 0 ) ;
2010-01-20 14:00:14 +00:00
// wait half a second for the default delay to open the menu
stop ( ) ;
setTimeout ( function ( ) {
2010-02-02 14:04:50 +00:00
same ( $ ( ".ui-menu:visible" ) . length , 1 ) ;
2010-01-20 14:00:14 +00:00
ac . autocomplete ( "destroy" ) ;
start ( ) ;
} , 100 ) ;
} ) ;
2010-07-30 16:59:33 +00:00
test ( "disabled" , function ( ) {
var ac = $ ( "#autocomplete" ) . autocomplete ( {
source : data ,
delay : 0 ,
disabled : true
} ) ;
ac . val ( "ja" ) . keydown ( ) ;
same ( $ ( ".ui-menu:visible" ) . length , 0 ) ;
stop ( ) ;
setTimeout ( function ( ) {
same ( $ ( ".ui-menu:visible" ) . length , 0 ) ;
ac . autocomplete ( "destroy" ) ;
start ( ) ;
} , 50 ) ;
} ) ;
2010-01-20 14:00:14 +00:00
test ( "minLength" , function ( ) {
var ac = $ ( "#autocomplete" ) . autocomplete ( {
source : data
} ) ;
ac . autocomplete ( "search" , "" ) ;
2010-02-02 14:04:50 +00:00
same ( $ ( ".ui-menu:visible" ) . length , 0 , "blank not enough for minLength: 1" ) ;
2010-01-20 14:00:14 +00:00
ac . autocomplete ( "option" , "minLength" , 0 ) ;
ac . autocomplete ( "search" , "" ) ;
2010-02-02 14:04:50 +00:00
same ( $ ( ".ui-menu:visible" ) . length , 1 , "blank enough for minLength: 0" ) ;
2010-01-20 14:00:14 +00:00
ac . autocomplete ( "destroy" ) ;
} ) ;
test ( "source, local string array" , function ( ) {
var ac = $ ( "#autocomplete" ) . autocomplete ( {
source : data
} ) ;
ac . val ( "ja" ) . autocomplete ( "search" ) ;
same ( $ ( ".ui-menu .ui-menu-item" ) . text ( ) , "javajavascript" ) ;
ac . autocomplete ( "destroy" ) ;
} ) ;
function source _test ( source , async ) {
var ac = $ ( "#autocomplete" ) . autocomplete ( {
source : source
} ) ;
ac . val ( "ja" ) . autocomplete ( "search" ) ;
function result ( ) {
same ( $ ( ".ui-menu .ui-menu-item" ) . text ( ) , "javajavascript" ) ;
ac . autocomplete ( "destroy" ) ;
async && start ( ) ;
}
if ( async ) {
stop ( ) ;
2010-03-31 14:39:16 +00:00
$ ( document ) . one ( "ajaxStop" , result ) ;
2010-01-20 14:00:14 +00:00
} else {
result ( ) ;
}
}
test ( "source, local object array, only label property" , function ( ) {
source _test ( [
{ label : "java" } ,
{ label : "php" } ,
{ label : "coldfusion" } ,
{ label : "javascript" }
] ) ;
} ) ;
test ( "source, local object array, only value property" , function ( ) {
source _test ( [
{ value : "java" } ,
{ value : "php" } ,
{ value : "coldfusion" } ,
{ value : "javascript" }
] ) ;
} ) ;
test ( "source, url string with remote json string array" , function ( ) {
source _test ( "remote_string_array.txt" , true ) ;
} ) ;
test ( "source, url string with remote json object array, only value properties" , function ( ) {
source _test ( "remote_object_array_values.txt" , true ) ;
} ) ;
test ( "source, url string with remote json object array, only label properties" , function ( ) {
source _test ( "remote_object_array_labels.txt" , true ) ;
} ) ;
test ( "source, custom" , function ( ) {
source _test ( function ( request , response ) {
same ( request . term , "ja" ) ;
response ( [ "java" , "javascript" ] ) ;
} ) ;
} ) ;
test ( "source, update after init" , function ( ) {
var ac = $ ( "#autocomplete" ) . autocomplete ( {
source : [ "java" , "javascript" , "haskell" ]
} ) ;
ac . val ( "ja" ) . autocomplete ( "search" ) ;
same ( $ ( ".ui-menu .ui-menu-item" ) . text ( ) , "javajavascript" ) ;
ac . autocomplete ( "option" , "source" , [ "php" , "asp" ] ) ;
ac . val ( "ph" ) . autocomplete ( "search" ) ;
same ( $ ( ".ui-menu .ui-menu-item" ) . text ( ) , "php" ) ;
ac . autocomplete ( "destroy" ) ;
} ) ;
} ) ( jQuery ) ;