2010-01-07 20:21:07 +00:00
/ *
# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
ox . ui . js
requires
2010-01-25 11:42:28 +00:00
jquery - 1.4 . js
2010-01-07 20:21:07 +00:00
ox . js
# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
* /
// also see test.js, in demos ...
( function ( ) {
var oxui = {
defaultTheme : "classic" ,
elements : { } ,
getDimensions : function ( orientation ) {
return orientation == "horizontal" ?
[ "width" , "height" ] : [ "height" , "width" ] ;
} ,
getEdges : function ( orientation ) {
return orientation == "horizontal" ?
[ "left" , "right" , "top" , "bottom" ] :
[ "top" , "bottom" , "left" , "right" ] ;
} ,
getBarSize : function ( size ) {
var sizes = {
2010-02-20 03:58:46 +00:00
small : 20 ,
medium : 24 ,
large : 28 ,
2010-01-07 20:21:07 +00:00
} ;
return sizes [ size ] ;
} ,
2010-01-25 11:42:28 +00:00
jQueryFunctions : function ( ) {
2010-01-07 20:21:07 +00:00
var functions = [ ] ,
2010-01-25 11:42:28 +00:00
$element = $ ( "<div>" ) ;
//delete $element.length;
Ox . each ( $element , function ( k , v ) {
2010-01-07 20:21:07 +00:00
if ( typeof v == "function" ) {
functions . push ( k ) ;
}
} ) ;
return functions . sort ( ) ;
} ( ) ,
path : $ ( "script[src*=ox.ui.js]" ) . attr ( "src" )
. replace ( "js/ox.ui.js" , "" ) ,
2010-06-30 18:47:10 +00:00
scrollbarSize : $ . browser . mozilla ? 16 : 12 ,
2010-06-30 09:27:02 +00:00
symbols : {
2010-02-03 12:12:21 +00:00
alt : "\u2325" ,
apple : "\uF8FF" ,
arrow _down : "\u2193" ,
arrow _left : "\u2190" ,
2010-02-05 05:20:13 +00:00
arrow _right : "\u2192" ,
arrow _up : "\u2191" ,
backspace : "\u232B" ,
backup : "\u2707" ,
ballot : "\u2717" ,
black _star : "\u2605" ,
burn : "\u2622" ,
caps _lock : "\u21EA" ,
check : "\u2713" ,
2010-03-06 09:13:17 +00:00
//clear: "\u2327",
clear : "\u00D7" ,
2010-02-05 05:20:13 +00:00
click : "\uF803" ,
close : "\u2715" ,
command : "\u2318" ,
control : "\u2303" ,
cut : "\u2702" ,
"delete" : "\u2326" ,
diamond : "\u25C6" ,
edit : "\uF802" ,
eject : "\u23CF" ,
escape : "\u238B" ,
end : "\u2198" ,
enter : "\u2324" ,
fly : "\u2708" ,
gear : "\u2699" ,
home : "\u2196" ,
info : "\u24D8" ,
navigate : "\u2388" ,
option : "\u2387" ,
page _up : "\u21DE" ,
page _down : "\u21DF" ,
redo : "\u21BA" ,
"return" : "\u21A9" ,
2010-02-28 07:47:56 +00:00
//select: "\u21D5",
select : "\u25BE" ,
2010-02-05 05:20:13 +00:00
shift : "\u21E7" ,
sound : "\u266B" ,
space : "\u2423" ,
tab : "\u21E5" ,
trash : "\u267A" ,
triangle _down : "\u25BC" ,
triangle _left : "\u25C0" ,
2010-02-03 12:12:21 +00:00
triangle _right : "\u25BA" ,
2010-02-05 05:20:13 +00:00
triangle _up : "\u25B2" ,
undo : "\u21BB" ,
voltage : "\u26A1" ,
warning : "\u26A0" ,
white _star : "\u2606"
2010-02-03 12:12:21 +00:00
}
2010-01-07 20:21:07 +00:00
} ,
$window , $document , $body ;
$ ( function ( ) {
$window = $ ( window ) ,
$document = $ ( document ) ,
2010-06-30 09:27:02 +00:00
$body = $ ( "body" ) ,
$elements = { } ;
2010-01-07 20:21:07 +00:00
Ox . theme ( oxui . defaultTheme ) ;
2010-02-04 09:50:45 +00:00
} ) ;
2010-01-07 20:21:07 +00:00
/ *
=== === === === === === === === === === === === === === === === === === === === === === === === === =
Application
=== === === === === === === === === === === === === === === === === === === === === === === === === =
* /
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . App
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2010-01-27 12:30:00 +00:00
Ox . App = function ( ) {
/ *
options :
requestTimeout
requestType
requestURL
* /
return function ( options ) {
options = options || { } ;
var self = { } ,
that = this ;
self . options = $ . extend ( {
requestTimeout : oxui . requestTimeout ,
requestType : oxui . requestType ,
requestURL : oxui . requestURL
} , options ) ;
self . change = function ( ) {
} ;
that . launch = function ( ) {
$ . ajaxSetup ( {
timeout : self . options . requestTimeout ,
type : self . options . requestType ,
url : self . options . requestURL
} ) ;
} ;
that . options = function ( ) {
return Ox . getset ( self . options , Array . slice . call ( arguments ) , self . change , that ) ;
} ;
2010-01-31 08:03:22 +00:00
that . request = function ( action , data , callback ) {
if ( arguments . length == 2 ) {
2010-01-27 13:25:37 +00:00
callback = data ;
data = { } ;
}
return Ox . Request . send ( {
url : self . options . requestURL ,
data : {
2010-01-31 08:03:22 +00:00
action : action ,
2010-01-27 13:25:37 +00:00
data : JSON . stringify ( data )
} ,
callback : callback
} ) ;
} ;
2010-01-27 12:30:00 +00:00
return that ;
} ;
} ( ) ;
2010-01-07 20:21:07 +00:00
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . Event
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
2010-02-03 12:12:21 +00:00
2010-01-07 20:21:07 +00:00
naming convention for event / trigger
verb . id . namespace , i . e . verb . sourceId . targetId ( ? )
...
bind ( "keydown.shift+dot.numpad" , function ( ) {
// ...
} )
keyboard handler then would :
$ . each ( stack , function ( i , v ) {
elements [ v ] . trigger ( "keydown.shift+0.numpad" ) ;
} ) ;
and the element would implement
this . trigger ( event , data ) {
}
...
keyboard handler also triggers keydown . buffer
* /
// use dom elements / jquery instead
2010-02-03 12:12:21 +00:00
2010-01-07 20:21:07 +00:00
Ox . Event = function ( ) {
2010-02-05 09:13:03 +00:00
var keyboardEvents = { } ;
$eventHandler = $ ( "<div>" ) ;
function isKeyboardEvent ( event ) {
return event . substr ( 0 , 4 ) == "key_" ;
}
2010-02-04 08:02:23 +00:00
return {
2010-02-05 09:13:03 +00:00
bind : function ( id , event , callback ) {
if ( isKeyboardEvent ( event ) ) {
2010-02-05 09:34:07 +00:00
keyboardEvents [ id ] = keyboardEvents [ id ] || { } ;
keyboardEvents [ id ] [ event ] = callback ;
2010-02-05 09:13:03 +00:00
}
if ( ! isKeyboardEvent ( event ) || Ox . Focus . focused ( ) == id ) {
$eventHandler . bind ( event , callback ) ;
}
2010-02-04 08:02:23 +00:00
} ,
2010-02-05 09:13:03 +00:00
bindKeyboard : function ( id ) {
2010-02-05 09:34:07 +00:00
$ . each ( keyboardEvents [ id ] || [ ] , function ( event , callback ) {
Ox . Event . bind ( id , event , callback ) ;
2010-02-05 09:13:03 +00:00
} ) ;
2010-02-04 09:50:45 +00:00
} ,
2010-02-04 08:02:23 +00:00
trigger : function ( event , data ) {
2010-02-04 09:50:45 +00:00
Ox . print ( "trigger" , event , data || { } ) ;
$eventHandler . trigger ( event , data || { } ) ;
2010-02-04 08:02:23 +00:00
} ,
2010-02-05 09:13:03 +00:00
unbind : function ( id , event , callback ) {
if ( isKeyboardEvent ( event ) ) {
2010-02-05 09:34:07 +00:00
$ . each ( keyboardEvents [ id ] || [ ] , function ( e , callback ) {
if ( e == event ) {
delete keyboardEvents [ id ] [ e ] ;
2010-02-05 09:13:03 +00:00
return false ;
}
} ) ;
}
2010-02-04 08:02:23 +00:00
$eventHandler . unbind ( event , callback ) ;
2010-02-05 09:13:03 +00:00
} ,
unbindKeyboard : function ( id ) {
2010-02-05 09:34:07 +00:00
$ . each ( keyboardEvents [ id ] || [ ] , function ( event , callback ) {
$eventHandler . unbind ( event , callback ) ;
2010-02-05 09:13:03 +00:00
} ) ;
2010-02-04 08:02:23 +00:00
}
}
2010-02-04 09:50:45 +00:00
} ( ) ;
2010-02-04 08:02:23 +00:00
Ox . Event _ = function ( ) {
2010-01-07 20:21:07 +00:00
var events = { } ;
return {
// make these bind, trigger, unbind
publish : function ( event , data ) {
if ( events [ event ] ) {
$ . each ( events [ event ] , function ( i , v ) {
setTimeout ( function ( ) {
v ( data ) ;
} , 0 ) ;
} ) ;
}
} ,
subscribe : function ( event , callback ) {
if ( events [ event ] ) {
events [ event ] . push ( callback ) ;
} else {
events [ event ] = [ callback ] ;
}
} ,
unsubscribe : function ( event , callback ) {
$ . each ( events [ event ] , function ( i , v ) {
if ( Ox . startsWith ( callback . toString ( ) , v . toString ( ) ) ) {
events [ event ] . splice ( i , 1 ) ;
}
} ) ;
}
} ;
} ( ) ;
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . Focus
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
Ox . Focus = function ( ) {
var stack = [ ] ;
return {
2010-06-30 09:27:02 +00:00
blur : function ( id ) {
if ( stack . indexOf ( id ) > - 1 ) {
$elements [ Ox . Focus . focused ( ) ] . removeClass ( "OxFocus" ) ;
2010-06-30 18:47:10 +00:00
$ ( ".OxFocus" ) . removeClass ( "OxFocus" ) ; // fixme: the above is better, and should work
2010-06-30 09:27:02 +00:00
stack . splice ( stack . length - 2 , 0 , stack . pop ( ) ) ;
Ox . Event . unbindKeyboard ( id ) ;
Ox . Event . bindKeyboard ( stack [ stack . length - 1 ] ) ;
Ox . print ( "blur" , stack ) ;
}
} ,
2010-01-07 20:21:07 +00:00
focus : function ( id ) {
2010-02-07 15:01:22 +00:00
var index = stack . indexOf ( id ) ;
2010-02-05 09:13:03 +00:00
if ( stack . length ) {
2010-02-07 15:01:22 +00:00
Ox . Event . unbindKeyboard ( stack [ stack . length - 1 ] )
2010-02-05 09:13:03 +00:00
}
2010-01-07 20:21:07 +00:00
if ( index > - 1 ) {
2010-02-05 09:13:03 +00:00
stack . splice ( index , 1 ) ;
2010-01-07 20:21:07 +00:00
}
2010-02-05 09:13:03 +00:00
stack . push ( id ) ;
2010-06-30 09:27:02 +00:00
$elements [ Ox . Focus . focused ( ) ] . addClass ( "OxFocus" ) ;
2010-02-05 09:13:03 +00:00
Ox . Event . bindKeyboard ( id ) ;
2010-02-05 09:13:54 +00:00
Ox . print ( "focus" , stack ) ;
2010-02-05 09:13:03 +00:00
} ,
focused : function ( ) {
return stack [ stack . length - 1 ] ;
2010-01-07 20:21:07 +00:00
}
} ;
} ( ) ;
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . History
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . Keyboard
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
( function ( ) {
2010-01-25 11:42:28 +00:00
2010-01-07 20:21:07 +00:00
var buffer = "" ,
bufferTime = 0 ,
bufferTimeout = 1000 ,
keyNames = function ( ) {
return {
0 : "section" ,
8 : "backspace" ,
9 : "tab" ,
12 : "clear" ,
13 : "enter" ,
16 : "shift" ,
17 : "control" ,
18 : "alt" ,
20 : "capslock" ,
27 : "escape" ,
32 : "space" ,
33 : "pageup" ,
34 : "pagedown" ,
35 : "end" ,
36 : "home" ,
37 : "left" ,
38 : "up" ,
39 : "right" ,
40 : "down" ,
45 : "insert" ,
46 : "delete" ,
47 : "help" ,
48 : "0" ,
49 : "1" ,
50 : "2" ,
51 : "3" ,
52 : "4" ,
53 : "5" ,
54 : "6" ,
55 : "7" ,
56 : "8" ,
57 : "9" ,
2010-02-04 09:50:45 +00:00
65 : "a" ,
66 : "b" ,
67 : "c" ,
68 : "d" ,
69 : "e" ,
70 : "f" ,
71 : "g" ,
72 : "h" ,
73 : "i" ,
74 : "j" ,
75 : "k" ,
76 : "l" ,
77 : "m" ,
78 : "n" ,
79 : "o" ,
80 : "p" ,
81 : "q" ,
82 : "r" ,
83 : "s" ,
84 : "t" ,
85 : "u" ,
86 : "v" ,
87 : "w" ,
88 : "x" ,
89 : "y" ,
90 : "z" ,
2010-01-07 20:21:07 +00:00
91 : "meta.left" ,
92 : "meta.right" ,
93 : "select" ,
96 : "0.numpad" ,
97 : "1.numpad" ,
98 : "2.numpad" ,
99 : "3.numpad" ,
100 : "4.numpad" ,
101 : "5.numpad" ,
102 : "6.numpad" ,
103 : "7.numpad" ,
104 : "8.numpad" ,
105 : "9.numpad" ,
106 : "asterisk.numpad" ,
107 : "plus.numpad" ,
109 : "minus.numpad" ,
108 : "enter.numpad" ,
110 : "dot.numpad" ,
111 : "slash.numpad" ,
112 : "f1" ,
113 : "f2" ,
114 : "f3" ,
115 : "f4" ,
116 : "f5" ,
117 : "f6" ,
118 : "f7" ,
119 : "f8" ,
120 : "f9" ,
121 : "f10" ,
122 : "f11" ,
123 : "f12" ,
124 : "f13" ,
125 : "f14" ,
126 : "f15" ,
127 : "f16" ,
144 : "numlock" ,
145 : "scrolllock" ,
186 : "semicolon" ,
187 : "equal" ,
188 : "comma" ,
189 : "minus" ,
190 : "dot" ,
191 : "slash" ,
192 : "backtick" ,
219 : "openbracket" ,
220 : "backslash" ,
221 : "closebracket" ,
222 : "quote"
// see dojo, for ex.
} ;
} ( ) ,
modifierNames = {
altKey : "alt" , // mac: option
ctrlKey : "control" ,
2010-06-30 14:21:06 +00:00
// metaKey: "meta", // mac: command
2010-01-07 20:21:07 +00:00
shiftKey : "shift"
} ;
2010-02-05 15:42:52 +00:00
2010-02-04 09:50:45 +00:00
$ ( function ( ) {
2010-02-05 15:42:52 +00:00
// fixme: how to do this better?
2010-02-19 14:19:48 +00:00
// in firefox on mac, keypress doesn't fire for up/down
2010-02-19 11:47:13 +00:00
// if the cursor is at the start/end of an input element
2010-02-19 14:19:48 +00:00
// on linux, it doesn't seem to fire if the input element has focus
2010-02-19 11:47:13 +00:00
if ( $ . browser . mozilla ) {
2010-02-18 07:27:32 +00:00
$document . keypress ( keypress ) ;
2010-02-19 11:47:13 +00:00
$document . keydown ( function ( event ) {
var $element = $ ( "input:focus" ) ;
if ( $element . length ) {
if (
(
keyNames [ event . keyCode ] == "up" &&
$element [ 0 ] . selectionStart + $element [ 0 ] . selectionEnd == 0
) || (
keyNames [ event . keyCode ] == "down" &&
$element [ 0 ] . selectionStart == $element . val ( ) . length &&
$element [ 0 ] . selectionEnd == $element . val ( ) . length
)
) {
keypress ( event ) ;
}
}
} ) ;
} else {
$document . keydown ( keypress ) ;
2010-02-05 15:31:19 +00:00
}
2010-02-04 09:50:45 +00:00
} ) ;
2010-02-18 07:27:32 +00:00
function keypress ( event ) {
2010-02-04 09:50:45 +00:00
var key ,
keys = [ ] ,
2010-02-20 03:58:46 +00:00
//ret = true,
2010-02-04 09:50:45 +00:00
time ;
$ . each ( modifierNames , function ( k , v ) {
if ( event [ k ] ) {
keys . push ( v ) ;
2010-01-07 20:21:07 +00:00
}
2010-02-04 09:50:45 +00:00
} ) ;
// avoid pushing modifier twice
2010-06-30 14:21:06 +00:00
Ox . print ( "keys" , keys )
2010-02-04 09:50:45 +00:00
if ( keyNames [ event . keyCode ] && keys . indexOf ( keyNames [ event . keyCode ] ) == - 1 ) {
keys . push ( keyNames [ event . keyCode ] ) ;
}
2010-06-30 14:21:06 +00:00
key = keys . join ( "_" ) ;
2010-02-04 09:50:45 +00:00
if ( key . match ( /^[\w\d-]$|SPACE/ ) ) {
time = Ox . getTime ( ) ;
if ( time - bufferTime > bufferTimeout ) {
buffer = "" ;
2010-01-07 20:21:07 +00:00
}
2010-02-04 09:50:45 +00:00
buffer += key == "SPACE" ? " " : key ;
bufferTime = time ;
2010-01-07 20:21:07 +00:00
}
2010-02-05 09:13:03 +00:00
Ox . Event . trigger ( "key_" + key ) ;
2010-02-18 14:24:17 +00:00
//return false;
2010-02-04 09:50:45 +00:00
/ *
$ . each ( stack , function ( i , v ) {
// fixme: we dont get the return value!
ret = Ox . event . trigger ( keyboard + Ox . toCamelCase ( key ) + "." + v ) ;
return ret ;
} ) ;
* /
}
2010-01-07 20:21:07 +00:00
} ) ( ) ;
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . Mouse ( ? ? )
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2010-01-27 12:30:00 +00:00
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . Request
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
Ox . Request = function ( ) {
var cache = { } ,
pending = { } ,
requests = { } ,
self = {
options : {
timeout : 15000 ,
type : "POST" ,
url : "api"
}
} ;
return {
cancel : function ( ) {
var index ;
if ( arguments . length == 0 ) {
requests = { } ;
} else if ( Ox . isFunction ( arguments [ 0 ] ) ) {
// cancel with function
$ . each ( requests , function ( id , req ) {
if ( arguments [ 0 ] ( req ) ) {
delete requests [ id ] ;
}
} )
} else {
// cancel by id
delete requests [ arguments [ 0 ] ]
}
} ,
2010-01-27 12:34:27 +00:00
emptyCache : function ( ) {
cache = { } ;
2010-01-27 12:35:37 +00:00
} ,
2010-01-27 12:34:27 +00:00
2010-01-27 12:30:00 +00:00
options : function ( options ) {
2010-01-27 12:34:27 +00:00
return Ox . getset ( self . options , options , $ . noop ( ) , this ) ;
2010-01-27 12:30:00 +00:00
} ,
send : function ( options ) {
2010-07-01 23:51:08 +00:00
var options = $ . extend ( {
age : - 1 ,
callback : function ( ) { } ,
id : Ox . uid ( ) ,
timeout : self . options . timeout ,
type : self . options . type ,
url : self . options . url
} , options ) ,
req = JSON . stringify ( {
2010-01-27 12:30:00 +00:00
url : options . url ,
data : options . data
} ) ;
2010-01-31 10:06:52 +00:00
function callback ( data ) {
2010-01-27 12:30:00 +00:00
delete requests [ options . id ] ;
2010-07-01 23:51:08 +00:00
Ox . length ( requests ) == 0 && Ox . Event . trigger ( "requestStop" ) ;
2010-01-31 10:06:52 +00:00
options . callback ( data ) ;
2010-01-27 12:30:00 +00:00
}
2010-01-31 09:32:41 +00:00
function debug ( request ) {
var $iframe = $ ( "<iframe>" )
. css ( { // fixme: should go into a class
width : 768 ,
height : 384
} ) ,
$dialog = new Ox . Dialog ( {
title : "Application Error" ,
buttons : [
{
value : "Close" ,
click : function ( ) {
$dialog . close ( ) ;
}
}
] ,
width : 800 ,
height : 400
} )
. append ( $iframe )
. open ( ) ,
iframe = $iframe [ 0 ] . contentDocument || $iframe [ 0 ] . contentWindow . document ;
iframe . open ( ) ;
iframe . write ( request . responseText ) ;
iframe . close ( ) ;
}
2010-01-27 12:30:00 +00:00
function error ( request , status , error ) {
2010-01-31 10:06:52 +00:00
var data ;
2010-02-01 06:11:35 +00:00
if ( arguments . length == 1 ) {
data = arguments [ 0 ]
} else {
try {
data = JSON . parse ( request . responseText ) ;
} catch ( err ) {
data = {
status : {
code : request . status ,
text : request . statusText
}
} ;
}
2010-01-27 13:25:37 +00:00
}
2010-01-31 10:06:52 +00:00
if ( data . status . code < 500 ) {
callback ( data ) ;
} else {
2010-01-27 13:25:37 +00:00
var $dialog = new Ox . Dialog ( {
2010-01-31 09:32:41 +00:00
title : "Application Error" ,
buttons : [
{
value : "Details" ,
click : function ( ) {
$dialog . close ( function ( ) {
debug ( request ) ;
} ) ;
}
} ,
{
value : "Close" ,
click : function ( ) {
2010-01-31 10:06:52 +00:00
$dialog . close ( function ( ) {
callback ( data ) ;
} ) ;
2010-01-31 09:32:41 +00:00
}
}
] ,
width : 400 ,
2010-06-30 18:47:10 +00:00
height : 200
2010-01-31 09:32:41 +00:00
} )
2010-01-31 10:06:52 +00:00
. append ( "Sorry, we have encountered an application error while handling your request. To help us find out what went wrong, you may want to report this error to an administrator. Otherwise, please try again later." )
2010-01-31 09:32:41 +00:00
. open ( ) ;
2010-02-01 06:11:35 +00:00
// fixme: change this to Send / Don't Send
2010-01-27 13:25:37 +00:00
Ox . print ( {
request : request ,
status : status ,
error : error
} ) ;
}
2010-01-27 12:30:00 +00:00
pending [ options . id ] = false ;
}
function success ( data ) {
pending [ options . id ] = false ;
try {
data = JSON . parse ( data ) ;
2010-02-01 06:11:35 +00:00
} catch ( err ) {
error ( {
2010-01-31 09:32:41 +00:00
status : {
code : 500 ,
text : "Internal Server Error"
} ,
data : { }
2010-02-01 06:11:35 +00:00
} ) ;
return ;
2010-01-27 12:30:00 +00:00
}
cache [ req ] = {
data : data ,
time : Ox . getTime ( )
} ;
2010-01-31 10:06:52 +00:00
callback ( data ) ;
2010-01-27 12:30:00 +00:00
}
if ( pending [ options . id ] ) {
setTimeout ( function ( ) {
Ox . Request . send ( options ) ;
} , 0 ) ;
} else {
requests [ options . id ] = {
url : options . url ,
data : options . data
} ;
if ( cache [ req ] && ( options . age == - 1 || options . age > Ox . getTime ( ) - cache [ req ] . time ) ) {
setTimeout ( function ( ) {
2010-01-31 10:06:52 +00:00
callback ( cache [ req ] . data ) ;
2010-01-27 12:30:00 +00:00
} , 0 ) ;
} else {
pending [ options . id ] = true ;
$ . ajax ( {
data : options . data ,
error : error ,
success : success ,
timeout : options . timeout ,
type : options . type ,
url : options . url
} ) ;
2010-07-02 12:33:45 +00:00
Ox . print ( "request" , options . data ) ;
2010-07-01 23:51:08 +00:00
Ox . length ( requests ) == 1 && Ox . Event . trigger ( "requestStart" ) ;
2010-01-27 12:30:00 +00:00
}
}
2010-07-01 23:51:08 +00:00
2010-01-27 12:30:00 +00:00
return options . id ;
2010-07-01 23:51:08 +00:00
} ,
requests : function ( ) {
return Ox . length ( requests ) ;
2010-01-27 12:30:00 +00:00
}
} ;
} ( ) ;
2010-01-07 20:21:07 +00:00
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . URL
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
/ *
=== === === === === === === === === === === === === === === === === === === === === === === === === =
Core
=== === === === === === === === === === === === === === === === === === === === === === === === === =
* /
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . Container
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
// fixme: wouldn't it be better to let the elements be,
// rather then $element, $content, and potentially others,
// 0, 1, 2, etc, so that append would append 0, and appendTo
// would append (length - 1)?
2010-06-28 11:19:04 +00:00
Ox . Container = function ( options , self ) {
var that = new Ox . Element ( options , self )
2010-01-07 20:21:07 +00:00
. addClass ( "OxContainer" ) ;
2010-06-28 11:19:04 +00:00
that . $content = new Ox . Element ( options , self )
2010-01-07 20:21:07 +00:00
. addClass ( "OxContent" )
. appendTo ( that ) ;
return that ;
2010-02-07 15:01:22 +00:00
} ;
2010-01-07 20:21:07 +00:00
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . Element
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
// check out http://ejohn.org/apps/learn/#36 (-#38, making fns work w/o new)
Ox . Element = function ( ) {
2010-06-30 09:27:02 +00:00
var elements = { } ; // fixme: unused, we need this outside Element (for Focus)
2010-01-07 20:21:07 +00:00
return function ( options , self ) {
// construct
options = options || { } ;
self = self || { } ;
var that = this ;
// init
( function ( ) {
// allow for Ox.Widget("tagname", self)
if ( typeof options == "string" ) {
options = {
element : options
} ;
}
that . ox = Ox . version ;
that . id = Ox . uid ( ) ;
2010-01-25 11:42:28 +00:00
that . $element = $ ( "<" + ( options . element || "div" ) + "/>" , {
data : {
ox : that . id
}
} ) ;
2010-06-30 09:27:02 +00:00
$elements [ that . id ] = that ;
2010-01-07 20:21:07 +00:00
wrapjQuery ( ) ;
} ) ( ) ;
// private
function wrapjQuery ( ) {
2010-02-10 18:42:59 +00:00
$ . each ( oxui . jQueryFunctions , function ( i , fn ) {
2010-02-10 18:52:46 +00:00
that [ fn ] = function ( ) {
2010-01-07 20:21:07 +00:00
var args = arguments ,
length = args . length ,
2010-02-10 19:50:10 +00:00
id , ret ;
2010-02-10 18:42:59 +00:00
$ . each ( args , function ( i , arg ) {
2010-01-07 20:21:07 +00:00
// if an ox object was passed
// then pass its $element instead
// so we can do oxObj.jqFn(oxObj)
2010-02-10 19:59:10 +00:00
if ( arg . ox ) {
args [ i ] = arg . $element ;
}
2010-02-10 19:41:25 +00:00
/ *
2010-02-10 18:52:46 +00:00
if ( arg . ox ) { // fixme: or is this too much magic?
2010-02-10 18:42:59 +00:00
if ( fn == "appendTo" && arg . $content ) {
2010-02-10 18:52:46 +00:00
args [ i ] = arg . $content
2010-02-10 18:42:59 +00:00
} else {
2010-02-10 18:52:46 +00:00
args [ i ] = arg . $element ;
2010-02-10 18:42:59 +00:00
}
2010-01-07 20:21:07 +00:00
}
2010-02-10 19:41:25 +00:00
* /
2010-01-07 20:21:07 +00:00
} ) ;
2010-02-10 19:41:25 +00:00
/ *
2010-02-10 18:52:46 +00:00
if ( fn == "html" && that . $content ) { // fixme: or is this too much magic?
2010-02-10 18:42:59 +00:00
$element = that . $content ;
} else {
$element = that . $element ;
}
2010-02-10 19:41:25 +00:00
* /
2010-01-07 20:21:07 +00:00
// why does this not work?
// ret = that.$element[v].apply(this, arguments);
if ( length == 0 ) {
2010-02-10 19:50:10 +00:00
ret = that . $element [ fn ] ( ) ;
2010-01-07 20:21:07 +00:00
} else if ( length == 1 ) {
2010-02-10 19:50:10 +00:00
ret = that . $element [ fn ] ( args [ 0 ] ) ;
2010-01-07 20:21:07 +00:00
} else if ( length == 2 ) {
2010-02-10 19:50:10 +00:00
ret = that . $element [ fn ] ( args [ 0 ] , args [ 1 ] ) ;
2010-01-07 20:21:07 +00:00
} else if ( length == 3 ) {
2010-02-10 19:50:10 +00:00
ret = that . $element [ fn ] ( args [ 0 ] , args [ 1 ] , args [ 2 ] ) ;
2010-01-07 20:21:07 +00:00
} else if ( length == 4 ) {
2010-02-10 19:50:10 +00:00
ret = that . $element [ fn ] ( args [ 0 ] , args [ 1 ] , args [ 2 ] , args [ 3 ] ) ;
2010-01-07 20:21:07 +00:00
}
2010-02-10 18:42:59 +00:00
if ( fn == "data" ) {
2010-02-08 09:35:24 +00:00
// Ox.print("data ret", ret, $(ret))
2010-02-07 15:01:22 +00:00
}
2010-01-07 20:21:07 +00:00
// if the $element of an ox object was returned
// then return the ox object instead
// so we can do oxObj.jqFn().oxFn()
2010-06-30 09:27:02 +00:00
return ret . jquery && $elements [ id = ret . data ( "ox" ) ] ?
$elements [ id ] : ret ;
2010-01-07 20:21:07 +00:00
}
} ) ;
}
// shared
self . onChange = function ( ) {
2010-02-07 15:01:22 +00:00
// self.onChange(key, value)
2010-01-07 20:21:07 +00:00
// is called when an option changes
// (to be implemented by widget)
} ;
// public
2010-02-05 09:13:03 +00:00
that . bindEvent = function ( ) {
2010-02-06 10:29:27 +00:00
// fixme: shouldn't this work the other way around,
// and bind a function to an event triggered by this widget?
2010-02-05 09:13:03 +00:00
/ *
bindEvent ( event , fn ) or bindEvent ( { event0 : fn0 , event1 : fn1 , ... } )
* /
if ( arguments . length == 1 ) {
$ . each ( arguments [ 0 ] , function ( event , fn ) {
Ox . Event . bind ( that . id , event , fn ) ;
2010-02-10 16:37:26 +00:00
} ) ;
2010-02-05 09:13:03 +00:00
} else {
Ox . Event . bind ( that . id , arguments [ 0 ] , arguments [ 1 ] ) ;
}
2010-02-06 06:21:01 +00:00
return that ;
2010-02-05 09:13:03 +00:00
} ;
2010-01-07 20:21:07 +00:00
that . defaults = function ( defaults ) {
/ *
that . defaults ( { foo : x } ) sets self . defaults
* /
self . defaults = defaults ;
2010-02-20 10:01:32 +00:00
delete self . options ; // fixme: hackish fix for that = Ox.Foo({...}, self).defaults({...}).options({...})
2010-01-07 20:21:07 +00:00
return that ;
2010-02-05 09:13:03 +00:00
} ;
that . gainFocus = function ( ) {
Ox . Focus . focus ( that . id ) ;
2010-02-09 05:43:36 +00:00
return that ;
2010-02-05 09:13:03 +00:00
} ;
that . hasFocus = function ( ) {
return Ox . Focus . focused ( ) == that . id ;
} ;
that . loseFocus = function ( ) {
Ox . Focus . blur ( that . id ) ;
2010-02-09 05:43:36 +00:00
return that ;
2010-02-05 09:13:03 +00:00
} ;
that . options = function ( ) { // fixme: use Ox.getset
2010-01-07 20:21:07 +00:00
/ *
that . options ( ) returns self . options
that . options ( "foo" ) returns self . options . foo
that . options ( "foo" , x ) sets self . options . foo ,
returns that
that . options ( { foo : x , bar : y } ) sets self . options . foo
and self . options . bar ,
returns that
* /
var length = arguments . length ,
2010-02-06 08:23:42 +00:00
// args, options, ret;
2010-01-07 20:21:07 +00:00
args , ret ;
if ( length == 0 ) {
// options()
ret = self . options ;
} else if ( length == 1 && typeof arguments [ 0 ] == "string" ) {
// options(str)
ret = self . options [ arguments [ 0 ] ]
} else {
// options (str, val) or options({str: val, ...})
// translate (str, val) to ({str: val})
args = Ox . makeObject . apply ( that , arguments ) ;
2010-02-06 08:23:42 +00:00
/ *
options = self . options ;
* /
2010-02-20 09:56:33 +00:00
// if options have not been set, extend defaults,
// otherwise, extend options
2010-02-06 08:23:42 +00:00
self . options = $ . extend ( self . options || self . defaults , args ) ;
2010-02-06 06:21:01 +00:00
$ . each ( args , function ( key , value ) {
self . onChange ( key , value ) ;
2010-02-06 08:23:42 +00:00
/ *
fixme : why does this not work ?
Ox . print ( "options" , options , key , value )
//Ox.print(!options, !options || !options[key], !options || !options[key] || options[key] !== value)
if ( ! options || ! options [ key ] || options [ key ] !== value ) {
Ox . print ( "onChange..." )
self . onChange ( key , value ) ;
} else {
Ox . print ( "NO CHANGE" ) ;
}
* /
2010-01-07 20:21:07 +00:00
} ) ;
ret = that ;
}
return ret ;
2010-02-10 16:37:26 +00:00
} ;
2010-01-07 20:21:07 +00:00
that . remove = function ( ) {
that . $element . remove ( ) ;
2010-06-30 09:27:02 +00:00
delete $elements [ that . ox ] ;
2010-02-06 06:21:01 +00:00
return that ;
2010-02-10 16:37:26 +00:00
} ;
2010-02-06 08:23:42 +00:00
that . triggerEvent = function ( ) {
/ *
triggerEvent ( event , fn ) or triggerEvent ( { event0 : fn0 , event1 : fn1 , ... } )
* /
2010-02-08 09:35:24 +00:00
if ( Ox . isObject ( arguments [ 0 ] ) ) {
2010-02-06 08:23:42 +00:00
$ . each ( arguments [ 0 ] , function ( event , fn ) {
2010-02-08 14:42:00 +00:00
Ox . Event . trigger ( event + "_" + self . options . id , fn ) ;
2010-02-06 08:23:42 +00:00
} ) ;
} else {
2010-02-08 14:42:00 +00:00
Ox . Event . trigger ( arguments [ 0 ] + "_" + self . options . id , arguments [ 1 ] || { } ) ;
2010-02-06 08:23:42 +00:00
}
return that ;
2010-02-10 16:37:26 +00:00
} ;
2010-02-05 09:13:03 +00:00
that . unbindEvent = function ( ) {
/ *
unbindEvent ( event , fn ) or unbindEvent ( { event0 : fn0 , event1 : fn1 , ... } )
* /
if ( arguments . length == 1 ) {
$ . each ( arguments [ 0 ] , function ( event , fn ) {
Ox . Event . unbind ( that . id , event , fn ) ;
} )
} else {
Ox . Event . unbind ( that . id , arguments [ 0 ] , arguments [ 1 ] ) ;
}
2010-02-06 06:21:01 +00:00
return that ;
2010-02-10 16:37:26 +00:00
} ;
2010-01-07 20:21:07 +00:00
// return
return that ;
}
} ( ) ;
Ox . _Element = function ( element ) {
var that = this ;
that . def = { } ;
that . opt = { } ;
that . ox = Ox . version ;
that . id = Ox . uid ( ) ;
2010-02-06 10:29:27 +00:00
//Ox.print("that.id", that.id)
2010-01-07 20:21:07 +00:00
that . $element = $ ( "<" + ( element || "div" ) + "/>" )
//.addClass("OxElement")
. data ( "ox" , that . id ) ;
oxui . elements [ that . id ] = that ;
2010-02-06 10:29:27 +00:00
// Ox.print("oxui.elements", oxui.elements)
2010-01-07 20:21:07 +00:00
//function setOption() {};
that . setOption = function ( ) { } ;
/ *
* /
that . destroy = function ( ) {
that . $element . remove ( ) ;
delete oxui . elements [ that . ox ] ;
}
/ *
* /
that . disable = function ( ) {
}
/ *
* /
that . enable = function ( ) {
}
/ *
* /
///*
that . defaults = function ( ) {
var length = arguments . length ,
ret ;
if ( length == 0 ) {
ret = that . def
} else if ( length == 1 && typeof arguments [ 0 ] == "string" ) {
ret = that . def [ arguments [ 0 ] ] ;
} else {
// translate ("key", "value") to {"key": "value"}
that . def = $ . extend (
that . def , Ox . makeObject . apply ( that , arguments )
) ;
ret = that ;
}
return ret ;
}
//*/
/ *
Ox . Element . options ( )
get options
Ox . Element . options ( "foo" )
get options . foo
Ox . Element . options ( "foo" , 0 )
set options . foo
Ox . Element . options ( { foo : 0 , bar : 1 } )
set options . foo and options . bar
* /
///*
that . options = function ( ) {
var length = arguments . length ,
args , ret ;
if ( length == 0 ) {
2010-02-06 10:29:27 +00:00
//Ox.print("getting all options", options);
2010-01-07 20:21:07 +00:00
ret = that . opt ;
} else if ( length == 1 && typeof arguments [ 0 ] == "string" ) {
2010-02-06 10:29:27 +00:00
//Ox.print("getting one option", options, arguments[0], options[arguments[0]]);
2010-01-07 20:21:07 +00:00
ret = that . opt [ arguments [ 0 ] ] ;
} else {
// translate ("key", "value") to {"key": "value"}
args = Ox . makeObject . apply ( that , arguments ) ;
// if options have been set then extend options,
// otherwise extend defaults
that . opt = $ . extend ( Ox . length ( that . opt ) ?
that . opt : that . def , args ) ;
// that.trigger("OxElement" + that.id + "SetOptions", args);
$ . each ( args , function ( k , v ) {
that . setOption ( k , v ) ;
2010-02-06 10:29:27 +00:00
//Ox.print("triggering", "OxElement" + that.id + "SetOption", {k: v})
2010-01-07 20:21:07 +00:00
//that.trigger("OxElement" + that.id + "SetOption", {k: v});
} )
ret = that ;
}
return ret ;
}
// should become self.publish
that . publish = function ( event , data ) {
Ox . Event . publish ( event + that . id , data ) ;
return that ;
}
that . subscribe = function ( event , callback ) {
Ox . Event . subscribe ( event , callback ) ;
return that ;
}
//that.setOptions = function() {};
//*/
// wrap jquery functions
// so we can do oxObj.jqFn()
$ . each ( oxui . jqueryFunctions , function ( i , v ) {
that [ v ] = function ( ) {
var args = arguments ,
length = args . length ,
$element , id , ret ;
$ . each ( args , function ( i , v ) {
// if an oxui object was passed
// then pass its $element instead
// so we can do jqObj.append(oxObj)
if ( v . ox ) {
args [ i ] = v . $element ;
}
} ) ;
if ( v == "html" && that . $content ) {
$element = that . $content ;
} else {
$element = that . $element ;
}
// why does this not work?
// ret = that.$element[v].apply(this, arguments);
// maybe because we pass this, and not that.$element[v] ... ?
// ret = that.$element[v].apply(that.$element[v], arguments);
// doesn't work either ...
if ( length == 0 ) {
ret = $element [ v ] ( ) ;
} else if ( length == 1 ) {
ret = $element [ v ] ( args [ 0 ] ) ;
} else if ( length == 2 ) {
ret = $element [ v ] ( args [ 0 ] , args [ 1 ] ) ;
} else if ( length == 3 ) {
ret = $element [ v ] ( args [ 0 ] , args [ 1 ] , args [ 2 ] ) ;
} else if ( length == 4 ) {
ret = $element [ v ] ( args [ 0 ] , args [ 1 ] , args [ 2 ] , args [ 3 ] ) ;
}
// if the $element of an oxui object was returned
// then return the oxui object instead
// so we can do oxObj.jqFn().oxFn()
2010-02-06 10:29:27 +00:00
//Ox.print("v", v, "arguments", arguments)
2010-01-07 20:21:07 +00:00
if ( ret . jquery ) {
2010-02-06 10:29:27 +00:00
//Ox.print("ret", ret, "ret.data('id')", ret.data("ox"))
2010-01-07 20:21:07 +00:00
}
return ret . jquery && oxui . elements [ id = ret . data ( "ox" ) ] ?
oxui . elements [ id ] : ret ;
}
} ) ;
return that ;
} ;
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . theme ( )
get theme
Ox . theme ( "foo" )
set theme to "foo"
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
Ox . theme = function ( ) {
var length = arguments . length ,
classes = $body . attr ( "class" ) . split ( " " ) ,
arg , theme ;
$ . each ( classes , function ( i , v ) {
if ( Ox . startsWith ( v , "OxTheme" ) ) {
theme = v . replace ( "OxTheme" , "" ) . toLowerCase ( ) ;
if ( length == 1 ) {
$body . removeClass ( v ) ;
}
return false ;
}
} ) ;
if ( length == 1 ) {
arg = arguments [ 0 ]
$body . addClass ( "OxTheme" + Ox . toTitleCase ( arg ) ) ;
if ( theme ) {
$ ( "input[type=image]" ) . each ( function ( ) {
var $this = $ ( this ) ;
$this . attr ( {
src : $this . attr ( "src" ) . replace (
"/ox.ui." + theme + "/" , "/ox.ui." + arg + "/"
)
} ) ;
} ) ;
2010-02-20 10:34:50 +00:00
$ ( ".OxLoadingIcon" ) . each ( function ( ) {
var $this = $ ( this ) ;
$this . attr ( {
src : $this . attr ( "src" ) . replace (
"/ox.ui." + theme + "/" , "/ox.ui." + arg + "/"
)
} ) ;
} )
2010-01-07 20:21:07 +00:00
}
}
return theme ;
} ;
/ *
=== === === === === === === === === === === === === === === === === === === === === === === === === =
Bars
=== === === === === === === === === === === === === === === === === === === === === === === === === =
* /
Ox . Bar = function ( options , self ) {
var self = self || { } ,
that = new Ox . Element ( { } , self )
. defaults ( {
orientation : "horizontal" ,
2010-02-20 04:26:53 +00:00
size : "medium" // can be int
2010-01-07 20:21:07 +00:00
} )
2010-02-18 07:27:32 +00:00
. options ( options || { } )
. addClass ( "OxBar Ox" + Ox . toTitleCase ( self . options . orientation ) ) ,
2010-01-07 20:21:07 +00:00
dimensions = oxui . getDimensions ( self . options . orientation ) ;
2010-02-20 03:58:46 +00:00
self . options . size = Ox . isString ( self . options . size ) ?
oxui . getBarSize ( self . options . size ) : self . options . size ;
2010-02-18 07:27:32 +00:00
that . css ( dimensions [ 0 ] , "100%" )
2010-01-07 20:21:07 +00:00
. css ( dimensions [ 1 ] , self . options . size + "px" ) ;
return that ;
} ;
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . Tabbar
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
Ox . Tabbar = function ( options , self ) {
var self = self || { } ,
that = new Ox . Bar ( {
size : 20
} , self )
. defaults ( {
selected : 0 ,
2010-02-10 09:59:59 +00:00
tabs : [ ]
2010-01-07 20:21:07 +00:00
} )
. options ( options || { } )
. addClass ( "OxTabbar" ) ;
2010-02-08 09:35:24 +00:00
Ox . ButtonGroup ( {
2010-02-10 09:59:59 +00:00
buttons : self . options . tabs ,
2010-02-08 09:35:24 +00:00
group : true ,
selectable : true ,
selected : self . options . selected ,
size : "medium" ,
style : "tab" ,
} ) . appendTo ( that ) ;
2010-01-07 20:21:07 +00:00
return that ;
} ;
2010-02-20 03:58:46 +00:00
// fixme: no need for this
2010-01-07 20:21:07 +00:00
Ox . Toolbar = function ( options , self ) {
var self = self || { } ,
that = new Ox . Bar ( {
2010-02-07 15:01:22 +00:00
size : oxui . getBarSize ( options . size )
} , self ) ;
2010-01-07 20:21:07 +00:00
return that ;
} ;
2010-01-27 12:30:00 +00:00
/ *
=== === === === === === === === === === === === === === === === === === === === === === === === === =
2010-01-31 08:03:22 +00:00
Ox . Dialog
2010-01-27 12:30:00 +00:00
=== === === === === === === === === === === === === === === === === === === === === === === === === =
* /
Ox . Dialog = function ( options , self ) {
2010-02-20 07:46:31 +00:00
2010-02-18 07:27:32 +00:00
// fixme: dialog should be derived from a generic draggable
2010-01-27 12:30:00 +00:00
var self = self || { } ,
2010-02-20 03:42:03 +00:00
that = new Ox . Element ( "div" , self )
. defaults ( {
title : "" ,
buttons : [ ] ,
2010-02-21 06:47:18 +00:00
height : 216 ,
minHeight : 144 ,
2010-02-21 05:40:11 +00:00
minWidth : 256 ,
2010-02-21 05:20:39 +00:00
width : 384
2010-02-20 03:42:03 +00:00
} )
. options ( options || { } )
2010-02-21 06:47:18 +00:00
. addClass ( "OxDialog" ) ;
2010-02-20 07:46:31 +00:00
2010-02-21 05:20:39 +00:00
if ( ! Ox . isArray ( self . options . buttons [ 0 ] ) ) {
self . options . buttons = [ [ ] , self . options . buttons ] ;
}
2010-01-31 08:03:22 +00:00
that . $titlebar = new Ox . Bar ( {
size : "medium"
} )
2010-01-27 12:30:00 +00:00
. addClass ( "OxTitleBar" )
2010-02-20 03:42:03 +00:00
//.html(self.options.title)
2010-02-21 05:20:39 +00:00
. mousedown ( drag )
2010-02-21 06:23:37 +00:00
. dblclick ( center )
2010-01-27 12:30:00 +00:00
. appendTo ( that ) ;
2010-02-09 05:43:36 +00:00
that . $title = new Ox . Element ( )
. addClass ( "OxTitle" )
2010-02-20 03:42:03 +00:00
. html ( self . options . title )
2010-02-09 05:43:36 +00:00
. appendTo ( that . $titlebar ) ;
2010-01-27 12:30:00 +00:00
that . $content = new Ox . Container ( )
. addClass ( "OxContent" )
. appendTo ( that ) ;
2010-02-20 04:26:53 +00:00
that . $buttonsbar = new Ox . Bar ( { } )
2010-01-27 12:30:00 +00:00
. addClass ( "OxButtonsBar" )
. appendTo ( that ) ;
2010-01-31 09:32:41 +00:00
that . $buttons = [ ] ;
2010-02-21 05:20:39 +00:00
$ . each ( self . options . buttons [ 0 ] , function ( i , button ) {
2010-01-31 09:32:41 +00:00
that . $buttons [ i ] = new Ox . Button ( {
2010-02-21 05:20:39 +00:00
size : "medium" ,
value : button . value
} )
. addClass ( "OxLeft" )
. click ( button . click ) // fixme: rather use event?
. appendTo ( that . $buttonsbar ) ;
} ) ;
that . $resize = new Ox . Element ( )
. addClass ( "OxResize" )
. mousedown ( resize )
2010-02-21 06:47:18 +00:00
. dblclick ( reset )
2010-02-21 05:20:39 +00:00
. appendTo ( that . $buttonsbar ) ;
$ . each ( self . options . buttons [ 1 ] . reverse ( ) , function ( i , button ) {
that . $buttons [ that . $buttons . length ] = new Ox . Button ( {
size : "medium" ,
value : button . value
} )
. addClass ( "OxRight" )
. click ( button . click ) // fixme: rather use event?
. appendTo ( that . $buttonsbar ) ;
2010-01-27 12:30:00 +00:00
} ) ;
2010-01-31 09:32:41 +00:00
that . $buttons [ 0 ] . focus ( ) ;
2010-02-21 07:09:32 +00:00
that . $layer = new Ox . Element ( ) // fixme: Layer widget, that would handle click?
. addClass ( "OxLayer" )
. mousedown ( mousedownLayer )
. mouseup ( mouseupLayer ) ;
2010-02-20 07:46:31 +00:00
2010-02-21 06:23:37 +00:00
function center ( ) {
that . css ( {
left : 0 ,
2010-02-21 06:47:18 +00:00
top : parseInt ( - $document . height ( ) / 10 ) + "px" , // fixme: don't overlap menu
2010-02-21 06:23:37 +00:00
right : 0 ,
bottom : 0 ,
margin : "auto"
} ) ;
}
2010-02-21 05:20:39 +00:00
function drag ( event ) {
2010-03-06 12:59:13 +00:00
var bodyWidth = $body . width ( ) ,
bodyHeight = $document . height ( ) ,
2010-02-21 06:47:18 +00:00
elementWidth = that . width ( ) ,
2010-02-21 05:20:39 +00:00
offset = that . offset ( ) ,
x = event . clientX ,
y = event . clientY ;
$window . mousemove ( function ( event ) {
2010-03-06 12:59:13 +00:00
/ *
2010-02-21 05:20:39 +00:00
$ ( "*" ) . css ( {
WebkitUserSelect : "none"
} ) ;
2010-03-06 12:59:13 +00:00
* /
2010-02-21 06:02:56 +00:00
that . css ( {
margin : 0
} ) ;
2010-02-21 05:20:39 +00:00
var left = Ox . limit (
offset . left - x + event . clientX ,
2010-03-06 12:59:13 +00:00
24 - elementWidth , bodyWidth - 24
//0, documentWidth - elementWidth
2010-02-21 05:20:39 +00:00
) ,
top = Ox . limit (
offset . top - y + event . clientY ,
2010-03-06 12:59:13 +00:00
24 , bodyHeight - 24
//24, documentHeight - elementHeight
2010-02-21 05:20:39 +00:00
) ;
that . css ( {
left : left + "px" ,
top : top + "px"
} ) ;
} ) ;
$window . one ( "mouseup" , function ( ) {
$window . unbind ( "mousemove" ) ;
2010-03-06 12:59:13 +00:00
/ *
2010-02-21 05:20:39 +00:00
$ ( "*" ) . css ( {
WebkitUserSelect : "auto"
} ) ;
2010-03-06 12:59:13 +00:00
* /
} ) ;
2010-02-21 05:20:39 +00:00
}
2010-02-21 07:09:32 +00:00
function mousedownLayer ( ) {
that . $layer . stop ( ) . animate ( {
opacity : 0.5
2010-03-06 12:59:13 +00:00
} , 0 ) ;
2010-02-21 07:09:32 +00:00
}
function mouseupLayer ( ) {
that . $layer . stop ( ) . animate ( {
opacity : 0
2010-03-06 12:59:13 +00:00
} , 0 ) ;
2010-02-21 07:09:32 +00:00
}
2010-02-21 06:47:18 +00:00
function reset ( ) {
2010-02-21 08:58:41 +00:00
that . css ( {
left : Math . max ( that . offset ( ) . left , 24 - self . options . width )
} )
. width ( self . options . width )
. height ( self . options . height ) ;
2010-02-21 06:47:18 +00:00
that . $content . height ( self . options . height - 80 ) ;
}
2010-02-21 05:20:39 +00:00
function resize ( event ) {
var contentHeight = that . $content . height ( ) ,
documentWidth = $document . width ( ) ,
documentHeight = $document . height ( ) ,
elementWidth = that . width ( ) ,
elementHeight = that . height ( ) ,
2010-02-21 05:40:11 +00:00
offset = that . offset ( ) ,
2010-02-21 05:20:39 +00:00
x = event . clientX ,
y = event . clientY ;
$window . mousemove ( function ( event ) {
2010-03-06 12:59:13 +00:00
/ *
2010-02-21 06:02:56 +00:00
$ ( "*" ) . css ( {
WebkitUserSelect : "none"
} ) ;
2010-03-06 12:59:13 +00:00
* /
2010-02-21 05:34:17 +00:00
that . css ( {
2010-02-21 05:40:11 +00:00
left : offset . left ,
top : offset . top ,
2010-02-21 05:34:17 +00:00
margin : 0
} ) ;
2010-02-21 05:20:39 +00:00
var width = Ox . limit (
elementWidth - x + event . clientX ,
2010-02-21 06:47:18 +00:00
self . options . minWidth , Math . min ( documentWidth , documentWidth - offset . left )
2010-02-21 05:20:39 +00:00
) ,
height = Ox . limit (
elementHeight - y + event . clientY ,
2010-02-21 06:02:56 +00:00
self . options . minHeight , documentHeight - offset . top
2010-02-21 05:20:39 +00:00
) ;
that . width ( width ) ;
that . height ( height ) ;
that . $content . height ( height - 80 ) ;
} ) ;
$window . one ( "mouseup" , function ( ) {
$window . unbind ( "mousemove" ) ;
2010-03-06 12:59:13 +00:00
/ *
2010-02-21 06:02:56 +00:00
$ ( "*" ) . css ( {
WebkitUserSelect : "auto"
} ) ;
2010-03-06 12:59:13 +00:00
* /
2010-02-21 05:20:39 +00:00
} ) ;
}
2010-01-31 08:03:22 +00:00
self . onChange = function ( key , value ) {
if ( key == "title" ) {
that . $title . html ( value ) ;
}
}
2010-02-20 07:46:31 +00:00
2010-01-27 12:30:00 +00:00
that . append = function ( $element ) {
that . $content . append ( $element ) ;
return that ;
}
2010-02-20 07:46:31 +00:00
2010-01-31 09:32:41 +00:00
that . close = function ( callback ) {
callback = callback || function ( ) { } ;
2010-01-27 12:30:00 +00:00
that . animate ( {
opacity : 0
} , 200 , function ( ) {
that . remove ( ) ;
that . $layer . remove ( ) ;
2010-01-31 09:32:41 +00:00
callback ( ) ;
2010-02-20 09:56:33 +00:00
} ) ;
2010-03-06 12:59:13 +00:00
$window . unbind ( "mouseup" , mouseupLayer )
2010-02-20 09:56:33 +00:00
return that ;
2010-01-27 12:30:00 +00:00
}
2010-02-20 07:46:31 +00:00
that . disable = function ( ) {
2010-02-10 16:37:26 +00:00
// to be used on submit of form, like login
2010-02-20 07:46:31 +00:00
that . $layer . addClass ( "OxFront" ) ;
2010-02-10 16:37:26 +00:00
} ;
2010-02-20 07:46:31 +00:00
that . enable = function ( ) {
that . $layer . removeClass ( "OxFront" ) ;
}
2010-01-27 12:30:00 +00:00
that . open = function ( ) {
2010-02-20 07:46:31 +00:00
that . $layer . appendTo ( $body ) ;
2010-02-21 06:32:48 +00:00
center ( ) ;
2010-02-21 06:47:18 +00:00
reset ( ) ;
2010-01-27 12:30:00 +00:00
that . css ( {
opacity : 0
2010-05-05 18:27:09 +00:00
} ) . appendTo ( $body ) . animate ( {
2010-01-27 12:30:00 +00:00
opacity : 1
} , 200 ) ;
2010-03-06 12:59:13 +00:00
$window . bind ( "mouseup" , mouseupLayer )
2010-01-27 12:30:00 +00:00
return that ;
}
2010-02-20 07:46:31 +00:00
2010-01-27 12:30:00 +00:00
return that ;
2010-02-20 07:46:31 +00:00
2010-01-27 12:30:00 +00:00
}
2010-01-07 20:21:07 +00:00
/ *
=== === === === === === === === === === === === === === === === === === === === === === === === === =
Forms
=== === === === === === === === === === === === === === === === === === === === === === === === === =
* /
2010-02-10 16:37:26 +00:00
Ox . Form = function ( options , self ) {
var self = self || { } ,
that = new Ox . Element ( "div" , self )
2010-02-20 09:56:33 +00:00
. defaults ( {
items : [ ]
} )
. options ( options || { } ) ; // fixme: the || {} can be done once, in the options function
$ . each ( self . options . items , function ( i , item ) {
} ) ;
that . values = function ( ) {
var values = { } ;
if ( arguments . length == 0 ) {
$ . each ( self . options . items , function ( i , item ) {
values [ item . id ] = item . val ( ) ;
} ) ;
return values ;
} else {
$ . each ( arguments [ 0 ] , function ( key , value ) {
} ) ;
return that ;
}
} ;
return that ;
2010-02-10 16:37:26 +00:00
} ;
2010-02-20 09:56:33 +00:00
Ox . FormItem = function ( options , self ) {
var self = self || { } ,
that = new Ox . Element ( "" , self )
. defaults ( {
error : "" ,
regexp : / / ,
size : "medium" ,
type : "text"
} )
. options ( options || { } ) ;
that . $input = new OxInput ( ) ;
return that ;
}
2010-01-07 20:21:07 +00:00
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . Button
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
Ox . Button = function ( options , self ) {
2010-02-10 09:59:59 +00:00
/ *
events :
click non - selectable button was clicked
deselect selectable button was deselected
select selectable button was selected
* /
2010-01-07 20:21:07 +00:00
var self = self || { } ,
that = new Ox . Element ( "input" , self )
. defaults ( {
disabled : false ,
2010-02-10 09:59:59 +00:00
group : null ,
id : "" ,
2010-01-07 20:21:07 +00:00
selectable : false ,
selected : false ,
2010-02-06 06:21:01 +00:00
size : "medium" ,
2010-02-10 09:59:59 +00:00
style : "default" , // can be default, symbol or tab
2010-01-07 20:21:07 +00:00
type : "text" ,
value : "" ,
2010-07-01 15:06:04 +00:00
values : [ ] // fixme: shouldn't this go into self.values?
2010-01-07 20:21:07 +00:00
} )
. options ( $ . extend ( options , {
value : $ . isArray ( options . value ) ?
options . value [ 0 ] : options . value ,
values : $ . makeArray ( options . value )
2010-02-06 08:23:42 +00:00
} ) )
. attr ( {
2010-02-06 06:21:01 +00:00
disabled : self . options . disabled ? "disabled" : "" ,
type : self . options . type == "text" ? "button" : "image"
} )
. addClass ( "OxButton Ox" + Ox . toTitleCase ( self . options . size ) +
2010-03-06 09:54:30 +00:00
( self . options . style != "default" ? " Ox" + Ox . toTitleCase ( self . options . style ) : "" ) +
2010-02-06 06:21:01 +00:00
( self . options . disabled ? " OxDisabled" : "" ) +
( self . options . selected ? " OxSelected" : "" ) )
. mousedown ( mousedown )
. click ( click ) ;
2010-02-06 10:29:27 +00:00
//Ox.print(self.options.value, self.options.disabled)
2010-01-07 20:21:07 +00:00
/ *
that . bind ( "OxElement" + that . id + "SetOptions" , function ( e , data ) {
if ( typeof data . selected != "undefined" ) {
if ( data . selected != that . hasClass ( "OxSelected" ) ) {
that . toggleClass ( "OxSelected" ) ;
}
}
if ( typeof data . value != "undefined" ) {
if ( self . options . type == "image" ) {
that . attr ( {
src : oxui . path + "png/" + Ox . theme ( ) +
"/button" + Ox . toTitleCase ( options . value ) + ".png"
} ) ;
} else {
that . val ( self . options . value ) ;
}
}
} )
* /
function mousedown ( e ) {
if ( self . options . type == "image" && $ . browser . safari ) {
// keep image from being draggable
e . preventDefault ( ) ;
}
}
function click ( ) {
2010-02-10 09:59:59 +00:00
if ( ! self . options . selectable ) {
that . triggerEvent ( "click" ) ;
} else if ( ! self . options . group || ! self . options . selected ) {
if ( self . options . group ) {
that . triggerEvent ( "select" ) ;
} else {
that . toggleSelected ( ) ;
}
2010-01-07 20:21:07 +00:00
}
if ( self . options . values . length == 2 ) {
that . options ( {
value : self . options . value == self . options . values [ 0 ] ?
self . options . values [ 1 ] : self . options . values [ 0 ]
} ) ;
}
2010-02-06 06:21:01 +00:00
//self.options.click();
2010-01-07 20:21:07 +00:00
}
2010-02-06 06:21:01 +00:00
self . onChange = function ( key , value ) {
2010-02-06 10:29:27 +00:00
//Ox.print("setOption", option, value)
2010-02-06 06:21:01 +00:00
if ( key == "selected" ) {
2010-02-08 09:35:24 +00:00
if ( value != that . hasClass ( "OxSelected" ) ) { // fixme: neccessary?
2010-01-07 20:21:07 +00:00
that . toggleClass ( "OxSelected" ) ;
}
2010-02-10 09:59:59 +00:00
that . triggerEvent ( "change" ) ;
2010-02-06 06:21:01 +00:00
} else if ( key == "value" ) {
2010-01-07 20:21:07 +00:00
if ( self . options . type == "image" ) {
that . attr ( {
src : oxui . path + "png/ox.ui." + Ox . theme ( ) +
"/button" + Ox . toTitleCase ( value ) + ".png"
} ) ;
} else {
that . val ( value ) ;
}
}
}
2010-01-31 08:03:22 +00:00
that . toggleDisabled = function ( ) {
that . options ( {
enabled : ! self . options . disabled
} ) ;
}
2010-01-07 20:21:07 +00:00
that . toggleSelected = function ( ) {
that . options ( {
selected : ! self . options . selected
} ) ;
}
that . options ( "value" , self . options . value ) ;
return that ;
} ;
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . ButtonGroup
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
Ox . ButtonGroup = function ( options , self ) {
2010-02-08 09:35:24 +00:00
2010-02-10 09:59:59 +00:00
/ *
events :
change { id , value } selection within a group changed
* /
2010-01-07 20:21:07 +00:00
var self = self || { } ,
that = new Ox . Element ( { } , self )
. defaults ( {
2010-02-10 09:59:59 +00:00
buttons : [ ] ,
2010-02-08 09:35:24 +00:00
group : false ,
2010-01-07 20:21:07 +00:00
selectable : false ,
selected : - 1 ,
2010-02-06 06:21:01 +00:00
size : "medium" ,
2010-01-07 20:21:07 +00:00
style : "" ,
type : "text" ,
} )
. options ( options || { } )
. addClass ( "OxButtonGroup" ) ;
2010-02-08 09:35:24 +00:00
self . position = { } ;
that . $buttons = [ ] ;
2010-02-10 09:59:59 +00:00
$ . each ( self . options . buttons , function ( position , button ) {
2010-02-08 09:35:24 +00:00
that . $buttons [ position ] = Ox . Button ( {
2010-02-10 09:59:59 +00:00
disabled : button . disabled ,
group : self . options . group ? that : null ,
id : button . id ,
2010-02-08 09:35:24 +00:00
selectable : self . options . selectable ,
selected : position == self . options . selected ,
size : self . options . size ,
style : self . options . style ,
type : self . options . type ,
2010-02-10 09:59:59 +00:00
value : button . value
2010-02-08 09:35:24 +00:00
} ) . appendTo ( that ) ;
self . position [ that . $buttons . id ] = position ;
2010-02-10 09:59:59 +00:00
that . bindEvent ( "select_" + that . $buttons [ position ] . options ( "id" ) , function ( ) {
selectButton ( position ) ;
} ) ;
2010-02-08 09:35:24 +00:00
} ) ;
2010-02-10 09:59:59 +00:00
function onChange ( event , data ) {
2010-02-08 09:35:24 +00:00
console . log ( "event" , event , "data" , data )
var id = event . split ( "_" ) [ 1 ] ;
if ( self . options . selected > - 1 ) {
that . $buttons [ self . options . selected ] . toggleSelected ( ) ;
}
self . options . selected = self . position [ id ] ;
that . triggerEvent ( "change" , {
value : id
2010-01-07 20:21:07 +00:00
} ) ;
2010-02-08 09:35:24 +00:00
}
2010-02-10 09:59:59 +00:00
function selectButton ( position ) {
that . $buttons [ self . options . selected ] . toggleSelected ( ) ;
self . options . selected = position ;
that . $buttons [ self . options . selected ] . toggleSelected ( ) ;
} ;
2010-01-07 20:21:07 +00:00
return that ;
} ;
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . Input
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
Ox . Input = function ( options , self ) {
2010-02-19 10:24:02 +00:00
/ * o p t i o n s :
* autocomplete function , or array of values , or dict with array of values per label or placeholder
* clear boolean , clear button , or not
* highlight boolean , highlight value in autocomplete menu , or not
* id
* label string or array ( select ) -- label and placeholder are mutually exclusive
* labelWidth integer ( px )
* placeholder string or array ( select ) -- label and placeholder are mutually exclusive
* selected integer , selected label or placeholder
* size "large" , "medium" or "small"
* type "text" , "password" , "textarea" , etc .
* /
2010-01-07 20:21:07 +00:00
var self = self || { } ,
2010-02-19 10:24:02 +00:00
that = new Ox . Element ( "div" , self )
2010-01-07 20:21:07 +00:00
. defaults ( {
2010-02-18 07:27:32 +00:00
autocomplete : null ,
2010-02-19 10:24:02 +00:00
clear : false ,
highlight : false ,
2010-02-18 09:11:47 +00:00
id : "" ,
2010-02-19 10:24:02 +00:00
label : "" ,
2010-02-27 08:16:58 +00:00
labelWidth : 64 ,
2010-02-19 10:24:02 +00:00
placeholder : "" ,
selected : 0 ,
2010-02-06 06:21:01 +00:00
size : "medium" ,
2010-01-07 20:21:07 +00:00
type : "text"
} )
2010-02-18 07:27:32 +00:00
. options ( options || { } )
2010-02-19 10:24:02 +00:00
. addClass ( "OxInput Ox" + Ox . toTitleCase ( self . options . size ) ) ,
2010-07-02 12:33:45 +00:00
autocomplete ; // fixme: should be self.autocomplete
2010-02-19 10:24:02 +00:00
if ( self . options . label ) {
self . options . label = Ox . makeArray ( self . options . label ) ;
2010-07-02 12:33:45 +00:00
self . option = self . options . label [ self . options . selected ] ; // fixme: id or title? or not use this at all?
2010-02-20 07:46:31 +00:00
self . items = self . options . label ;
2010-02-19 10:24:02 +00:00
} else if ( self . options . placeholder ) {
self . options . placeholder = Ox . makeArray ( self . options . placeholder ) ;
2010-02-20 10:51:55 +00:00
self . option = self . options . placeholder [ self . options . selected ] ;
2010-02-20 07:46:31 +00:00
self . items = self . options . placeholder ;
2010-02-19 10:24:02 +00:00
}
if ( Ox . isArray ( self . options . autocomplete ) ) {
autocomplete = self . options . autocomplete ;
self . options . autocomplete = { } ;
self . options . autocomplete [ self . placeholder ] = autocomplete ;
}
if ( self . options . label ) {
2010-02-20 07:46:31 +00:00
that . $label = new Ox . Element ( )
2010-02-27 08:46:49 +00:00
. addClass ( "OxInputLabel" )
2010-02-20 07:46:31 +00:00
. width ( self . options . labelWidth )
2010-07-02 12:33:45 +00:00
. html ( self . options . label [ 0 ] . title )
2010-02-20 07:46:31 +00:00
. appendTo ( that ) ;
}
if ( self . options . label . length > 1 || self . options . placeholder . length > 1 ) {
that . $label && that . $label . click ( select ) ;
2010-02-19 10:24:02 +00:00
that . $select = new Ox . Button ( {
style : "symbol" ,
2010-03-06 09:54:30 +00:00
type : "image" ,
value : "select"
// value: oxui.symbols.select
2010-02-19 10:24:02 +00:00
} )
. click ( select )
. appendTo ( that ) ;
2010-02-20 07:46:31 +00:00
self . selectId = self . options . id + "_placeholder" ;
self . selectMenu = new Ox . Menu ( {
2010-02-19 10:24:02 +00:00
element : that ,
2010-02-20 07:46:31 +00:00
id : self . selectId ,
2010-07-02 12:33:45 +00:00
items : $ . map ( self . items , function ( item , position ) {
2010-02-19 10:24:02 +00:00
return {
checked : position == self . options . selected ,
2010-07-02 12:33:45 +00:00
id : item . id ,
2010-02-20 07:46:31 +00:00
group : self . selectId , // fixme: same id, works here, but should be different
2010-07-02 12:33:45 +00:00
title : item . title
2010-02-19 10:24:02 +00:00
} ;
2010-02-19 10:34:51 +00:00
} ) ,
offset : {
left : 4 ,
top : 0
}
2010-02-19 10:24:02 +00:00
} ) ;
2010-02-20 07:46:31 +00:00
that . bindEvent ( "change_" + self . selectId , change ) ;
2010-02-19 10:24:02 +00:00
}
that . $input = new Ox . Element (
self . options . type == "textarea" ? "textarea" : "input" , self
)
. attr ( {
2010-02-26 13:22:27 +00:00
type : self . options . type == "textarea" ? undefined : self . options . type // fixme: make conditional?
2010-02-19 10:24:02 +00:00
} )
. addClass (
"OxInput Ox" + Ox . toTitleCase ( self . options . size ) +
" OxPlaceholder"
)
. focus ( focus )
. blur ( blur )
. change ( change )
. appendTo ( that ) ;
2010-02-20 11:05:58 +00:00
self . options . placeholder && that . $input . val ( self . option ) ;
2010-02-19 10:24:02 +00:00
if ( self . options . clear ) {
that . $clear = new Ox . Button ( {
style : "symbol" ,
2010-03-06 09:54:30 +00:00
type : "image" ,
value : "clear"
//value: oxui.symbols.clear
2010-02-18 07:27:32 +00:00
} )
2010-02-19 10:24:02 +00:00
. click ( clear )
. appendTo ( that ) ;
}
2010-02-27 08:46:49 +00:00
if ( self . options . autocomplete ) {
2010-02-19 14:19:48 +00:00
that . $input . attr ( {
autocomplete : "off"
} ) ;
2010-02-19 10:24:02 +00:00
self . autocompleteId = self . options . id + "_menu" ; // fixme: we do this in other places ... are we doing it the same way? var name?
self . autocompleteMenu = new Ox . Menu ( {
2010-02-20 07:46:31 +00:00
element : that . $input ,
2010-02-19 10:24:02 +00:00
id : self . autocompleteId ,
2010-02-18 07:27:32 +00:00
offset : {
left : 4 ,
top : 0
} ,
size : self . options . size
} ) ;
2010-02-19 10:24:02 +00:00
that . bindEvent ( "click_" + self . autocompleteId , onClick ) ;
2010-02-18 07:27:32 +00:00
}
2010-02-19 10:24:02 +00:00
2010-02-26 13:46:14 +00:00
if ( self . options . type != "textarea" ) {
that . bindEvent ( {
key _enter : submit ,
} ) ;
}
2010-02-19 10:24:02 +00:00
that . bindEvent ( {
key _escape : cancel
} ) ;
function autocomplete ( value , callback ) {
2010-02-20 10:51:55 +00:00
var value = value . toLowerCase ( ) ,
items = [ ] ;
2010-02-19 10:24:02 +00:00
if ( value === "" ) {
2010-02-19 10:34:51 +00:00
// items = self.options.autocomplete[self.placeholder];
2010-02-19 10:24:02 +00:00
} else {
2010-02-20 10:51:55 +00:00
$ . each ( self . options . autocomplete [ self . option ] , function ( i , item ) {
2010-02-19 10:24:02 +00:00
if ( item . toLowerCase ( ) . indexOf ( value ) > - 1 ) {
items . push ( item ) ;
}
} ) ;
}
callback ( items ) ;
}
2010-02-20 11:05:58 +00:00
function blur ( ) {
that . loseFocus ( ) ;
if ( self . options . placeholder && that . $input . val ( ) === "" ) {
that . $input . addClass ( "OxPlaceholder" ) . val ( self . option ) ;
}
if ( self . options . autocomplete ) {
$document . unbind ( "keydown" , keypress ) ;
$document . unbind ( "keypress" , keypress ) ;
}
}
2010-02-19 10:24:02 +00:00
function call ( ) {
2010-02-20 10:51:55 +00:00
var value = that . $input . val ( ) ;
2010-07-02 12:33:45 +00:00
Ox . print ( "autocomplete call" , self . option , value )
2010-02-19 10:24:02 +00:00
if ( self . options . autocomplete ) {
2010-07-02 12:33:45 +00:00
if ( value !== "" ) {
Ox . isFunction ( self . options . autocomplete ) ? (
self . option ?
self . options . autocomplete ( self . option . id , value , callback ) :
self . options . autocomplete ( value , callback )
) : autocomplete ( value , callback ) ;
} else {
callback ( ) ;
}
2010-02-19 10:24:02 +00:00
}
2010-02-18 07:27:32 +00:00
}
2010-02-19 10:24:02 +00:00
function callback ( items ) {
2010-07-02 12:33:45 +00:00
Ox . print ( "autocomplete callback" , items )
var items = items || [ ] ,
selected = items . length == 1 ? 0 : - 1 ,
2010-02-20 10:43:45 +00:00
value = that . $input . val ( ) . toLowerCase ( ) ;
2010-02-18 07:56:37 +00:00
if ( items . length ) {
2010-02-18 15:11:14 +00:00
items = $ . map ( items , function ( title , position ) {
2010-02-20 10:51:55 +00:00
if ( value == Ox . stripTags ( title . toLowerCase ( ) ) ) {
2010-02-18 15:11:14 +00:00
selected = position ;
}
2010-02-18 07:56:37 +00:00
return {
id : title . toLowerCase ( ) , // fixme: need function to do lowercase, underscores etc?
2010-02-20 10:43:45 +00:00
title : self . options . highlight ? title . replace (
new RegExp ( "(" + value + ")" , "ig" ) ,
"<span class=\"OxHighlight\">$1</span>"
) : title
2010-02-18 09:11:47 +00:00
} ;
2010-02-18 07:56:37 +00:00
} ) ;
2010-02-20 07:46:31 +00:00
self . selectMenu . hideMenu ( ) ;
2010-02-19 10:24:02 +00:00
self . autocompleteMenu . options ( {
2010-02-18 15:11:14 +00:00
items : items ,
selected : selected
2010-02-18 07:56:37 +00:00
} ) . showMenu ( ) ;
} else {
2010-02-19 10:24:02 +00:00
self . autocompleteMenu . hideMenu ( ) ;
2010-02-18 07:56:37 +00:00
}
2010-02-10 15:49:33 +00:00
}
2010-02-19 10:24:02 +00:00
function cancel ( ) {
2010-02-19 10:34:51 +00:00
that . $input . blur ( ) ;
2010-02-19 10:24:02 +00:00
}
2010-02-20 07:46:31 +00:00
function change ( event , data ) {
2010-07-02 12:33:45 +00:00
Ox . print ( "input change" , event , data )
if ( data ) {
self . option = {
id : data . id ,
title : data . value // fixme: should be data.title
} ;
}
2010-02-20 07:46:31 +00:00
if ( self . options . label ) {
2010-07-02 12:33:45 +00:00
that . $label . html ( self . option . title ) ;
2010-02-19 10:34:51 +00:00
that . $input . focus ( ) ;
call ( ) ;
2010-02-20 07:46:31 +00:00
} else {
if ( that . $input . is ( ".OxPlaceholder" ) ) {
2010-02-20 11:05:58 +00:00
that . $input . val ( self . option ) ;
2010-02-20 07:46:31 +00:00
//that.$input.focus();
} else {
that . $input . focus ( ) ;
call ( ) ;
}
2010-02-19 10:24:02 +00:00
}
}
2010-02-20 11:05:58 +00:00
function clear ( ) {
that . $input . val ( "" ) . focus ( ) ;
//call();
2010-01-07 20:21:07 +00:00
}
2010-02-19 10:24:02 +00:00
2010-01-07 20:21:07 +00:00
function focus ( ) {
2010-07-02 12:33:45 +00:00
var value ;
2010-02-19 10:24:02 +00:00
that . gainFocus ( ) ;
if ( that . $input . is ( ".OxPlaceholder" ) ) {
that . $input . val ( "" ) . removeClass ( "OxPlaceholder" ) ;
2010-01-07 20:21:07 +00:00
}
2010-07-02 12:33:45 +00:00
value = that . $input . val ( ) ;
2010-02-18 07:27:32 +00:00
if ( self . options . autocomplete ) {
// fixme: different in webkit and firefox (?), see keyboard handler, need generic function
2010-02-18 14:24:17 +00:00
$document . bind ( "keydown" , keypress ) ;
2010-02-18 07:27:32 +00:00
$document . bind ( "keypress" , keypress ) ;
2010-07-02 12:33:45 +00:00
value !== "" && Ox . isFunction ( self . options . autocomplete ) ?
self . options . autocomplete ( self . option . id , value , callback ) :
autocomplete ( value , callback ) ;
2010-02-18 07:27:32 +00:00
}
2010-01-07 20:21:07 +00:00
}
2010-02-19 10:24:02 +00:00
2010-02-18 14:24:17 +00:00
function keypress ( event ) {
2010-02-18 15:15:23 +00:00
if ( event . keyCode != 13 ) {
setTimeout ( function ( ) {
2010-02-19 10:24:02 +00:00
var value = that . $input . val ( ) ;
if ( value != self . value ) {
2010-02-18 15:15:23 +00:00
self . value = value ;
2010-02-19 10:24:02 +00:00
call ( ) ;
2010-02-18 15:15:23 +00:00
}
2010-02-18 15:19:36 +00:00
} , 25 ) ;
2010-02-18 15:15:23 +00:00
}
2010-02-18 07:56:37 +00:00
}
2010-02-19 10:24:02 +00:00
2010-02-18 14:24:17 +00:00
function onClick ( event , data ) {
2010-07-02 13:06:13 +00:00
Ox . print ( "onClick" , data ) ;
2010-07-02 15:20:46 +00:00
that . $input . val ( Ox . stripTags ( data . title ) ) ;
2010-02-19 10:24:02 +00:00
self . autocompleteMenu . hideMenu ( ) ;
submit ( ) ;
2010-02-18 14:24:17 +00:00
}
2010-02-19 10:24:02 +00:00
function select ( ) {
2010-02-20 07:46:31 +00:00
self . selectMenu . showMenu ( ) ;
2010-02-19 10:24:02 +00:00
}
2010-02-18 14:24:17 +00:00
function selection ( ) {
2010-02-19 10:24:02 +00:00
// fixme: not used!
2010-02-18 14:24:17 +00:00
var start , end ;
if ( arguments . length == 0 ) {
return [ self . element . selectionStart , self . element . selectionEnd ] ;
} else {
start = arguments [ 0 ] ;
end = arguments [ 1 ] || start ;
2010-02-18 09:11:47 +00:00
self . element . setSelectionRange ( start , end ) ;
2010-01-07 20:21:07 +00:00
}
}
2010-02-19 10:24:02 +00:00
function submit ( ) {
2010-07-02 12:33:45 +00:00
Ox . print ( "input submit" , that . $input . val ( ) )
2010-02-19 10:24:02 +00:00
that . $input . trigger ( "blur" ) ;
2010-07-02 16:32:16 +00:00
that . triggerEvent ( "submit" , self . option ? {
key : self . option . id ,
value : that . $input . val ( )
} : that . $input . val ( ) ) ;
2010-02-19 10:24:02 +00:00
}
2010-02-26 13:22:27 +00:00
that . height = function ( value ) {
2010-02-27 08:16:58 +00:00
var stop = 8 / value ;
2010-02-26 13:22:27 +00:00
if ( self . options . type == "textarea" ) {
2010-02-27 08:16:58 +00:00
that . $element
. height ( value )
. css ( {
background : "-moz-linear-gradient(top, rgb(224, 224, 224), rgb(208, 208, 208) " + ( stop * 100 ) + "%, rgb(208, 208, 208) " + ( 100 - stop * 100 ) + "%, rgb(192, 192, 192))"
} )
. css ( {
background : "-webkit-gradient(linear, left top, left bottom, from(rgb(224, 224, 224)), color-stop(" + stop + ", rgb(208, 208, 208)), color-stop(" + ( 1 - stop ) + ", rgb(208, 208, 208)), to(rgb(192, 192, 192)))"
} ) ;
2010-02-26 13:42:21 +00:00
that . $input
. height ( value )
. css ( {
2010-02-27 08:16:58 +00:00
background : "-moz-linear-gradient(top, rgb(224, 224, 224), rgb(240, 240, 240) " + ( stop * 100 ) + "%, rgb(240, 240, 240) " + ( 100 - stop * 100 ) + "%, rgb(255, 255, 255))"
2010-02-26 13:42:21 +00:00
} )
. css ( {
2010-02-27 08:16:58 +00:00
background : "-webkit-gradient(linear, left top, left bottom, from(rgb(224, 224, 224)), color-stop(" + stop + ", rgb(240, 240, 240)), color-stop(" + ( 1 - stop ) + ", rgb(240, 240, 240)), to(rgb(255, 255, 255)))"
2010-02-26 13:42:21 +00:00
} ) ;
2010-02-26 13:22:27 +00:00
}
return that ;
}
2010-02-19 10:24:02 +00:00
that . width = function ( value ) {
that . $element . width ( value ) ;
2010-02-26 13:22:27 +00:00
that . $input . width ( value - ( self . options . type == "textarea" ? 0 : 2 ) -
2010-02-27 08:16:58 +00:00
( self . options . label ? self . options . labelWidth + 18 : 0 ) -
2010-02-20 07:46:31 +00:00
( self . options . placeholder . length > 1 ? 26 : 0 ) -
2010-02-27 07:54:45 +00:00
( self . options . clear ? 31 : 0 ) ) ;
2010-02-20 07:46:31 +00:00
// fixme: the values above are all weird guesswork
2010-02-19 10:24:02 +00:00
return that ;
}
2010-01-07 20:21:07 +00:00
return that ;
2010-02-19 10:24:02 +00:00
2010-01-07 20:21:07 +00:00
} ;
2010-02-27 08:46:49 +00:00
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . Label
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
Ox . Label = function ( options , self ) {
var self = self || { } ,
that = new Ox . Element ( { } , self )
. defaults ( {
id : "" ,
title : ""
} )
. options ( options )
. addClass ( "OxLabel" ) ;
that . html ( self . options . title ) ;
return that ;
} ;
2010-01-07 20:21:07 +00:00
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . Range
options :
2010-03-06 09:54:30 +00:00
animate boolean if true , animate thumb
arrows boolean if true , show arrows
arrowStep number step when clicking arrows
arrowSymbols array arrow symbols , like [ "minus" , "plus" ]
max number maximum value
min number minimum value
orientation string "horizontal" or "vertical"
step number step between values
size number width or height , in px
thumbSize number minimum width or height of thumb , in px
thumbValue boolean if true , display value on thumb
trackImages string or array one or multiple track background image URLs
trackStep number 0 ( scroll here ) or step when clicking track
value number initial value
2010-01-07 20:21:07 +00:00
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
Ox . Range = function ( options , self ) {
/ *
init
* /
var self = self || { } ,
that = new Ox . Element ( { } , self )
. defaults ( {
animate : false ,
arrows : false ,
arrowStep : 1 ,
2010-03-06 09:54:30 +00:00
arrowSymbols : [ "previous" , "next" ] ,
2010-01-07 20:21:07 +00:00
max : 100 ,
min : 0 ,
orientation : "horizontal" ,
step : 1 ,
size : 128 ,
thumbSize : 16 ,
thumbValue : false ,
trackImages : [ ] ,
trackStep : 0 ,
value : 0
} )
. options ( $ . extend ( options , {
arrowStep : options . arrowStep ?
options . arrowStep : options . step ,
trackImages : $ . makeArray ( options . trackImages || [ ] )
} ) )
. addClass ( "OxRange" ) ;
// fixme: self. ... ?
var trackImages = self . options . trackImages . length ,
values = ( self . options . max - self . options . min + self . options . step ) /
self . options . step ;
/ *
construct
* /
that . $element
. css ( {
width : self . options . size + "px"
} ) ;
if ( self . options . arrows ) {
var $arrowDec = Ox . Button ( {
style : "symbol" ,
type : "image" ,
2010-03-06 09:54:30 +00:00
value : self . options . arrowSymbols [ 0 ]
2010-01-07 20:21:07 +00:00
} )
. addClass ( "OxArrow" )
. mousedown ( mousedownArrow )
. click ( clickArrowDec )
. appendTo ( that . $element ) ;
}
var $track = new Ox . Element ( )
. addClass ( "OxTrack" )
. mousedown ( clickTrack )
. appendTo ( that . $element ) ; // fixme: make that work
if ( trackImages ) {
var width = parseFloat ( screen . width / trackImages ) ,
$image = $ ( "<canvas/>" )
. attr ( {
width : width * trackImages ,
height : 14
} )
. addClass ( "OxImage" )
. appendTo ( $track . $element ) , // fixme: make that work
c = $image [ 0 ] . getContext ( '2d' ) ;
2010-01-25 15:10:44 +00:00
c . mozImageSmoothingEnabled = false ; // we may want to remove this later
2010-01-07 20:21:07 +00:00
$ . each ( self . options . trackImages , function ( i , v ) {
$ ( "<img/>" )
. attr ( {
src : v
} )
. load ( function ( ) {
c . drawImage ( this , i * width , 0 , width , 14 ) ;
} ) ;
} ) ;
}
var $thumb = Ox . Button ( { } )
. addClass ( "OxThumb" )
. appendTo ( $track ) ;
if ( self . options . arrows ) {
var $arrowInc = Ox . Button ( {
style : "symbol" ,
type : "image" ,
2010-03-06 09:54:30 +00:00
value : self . options . arrowSymbols [ 1 ]
2010-01-07 20:21:07 +00:00
} )
. addClass ( "OxArrow" )
. mousedown ( mousedownArrow )
. click ( clickArrowInc )
. appendTo ( that . $element ) ;
}
var rangeWidth , trackWidth , imageWidth , thumbWidth ;
setWidth ( self . options . size ) ;
/ *
private functions
* /
function clickArrowDec ( ) {
that . removeClass ( "OxActive" ) ;
setValue ( self . options . value - self . options . arrowStep , 200 )
}
function clickArrowInc ( ) {
that . removeClass ( "OxActive" ) ;
setValue ( self . options . value + self . options . arrowStep , 200 ) ;
}
function clickTrack ( e ) {
Ox . Focus . focus ( ) ;
var left = $track . offset ( ) . left ,
offset = $ ( e . target ) . hasClass ( "OxThumb" ) ?
e . clientX - $thumb . offset ( ) . left - thumbWidth / 2 - 2 : 0 ;
function val ( e ) {
return getVal ( e . clientX - left - offset ) ;
}
setValue ( val ( e ) , 200 ) ;
$window . mousemove ( function ( e ) {
setValue ( val ( e ) ) ;
} ) ;
$window . one ( "mouseup" , function ( ) {
$window . unbind ( "mousemove" ) ;
} ) ;
}
function getPx ( val ) {
var pxPerVal = ( trackWidth - thumbWidth - 2 ) /
( self . options . max - self . options . min ) ;
return Math . ceil ( ( val - self . options . min ) * pxPerVal + 1 ) ;
}
function getVal ( px ) {
var px = trackWidth / values >= 16 ? px : px - 8 ,
valPerPx = ( self . options . max - self . options . min ) /
( trackWidth - thumbWidth ) ;
return Ox . limit ( self . options . min +
Math . floor ( px * valPerPx / self . options . step ) * self . options . step ,
self . options . min , self . options . max ) ;
}
function mousedownArrow ( ) {
that . addClass ( "OxActive" ) ;
}
function setThumb ( animate ) {
var animate = typeof animate != "undefined" ? animate : 0 ;
$thumb . animate ( {
marginLeft : ( getPx ( self . options . value ) - 2 ) + "px" ,
width : thumbWidth + "px"
} , self . options . animate ? animate : 0 , function ( ) {
if ( self . options . thumbValue ) {
$thumb . options ( {
value : self . options . value
} ) ;
}
} ) ;
}
function setValue ( val , animate ) {
val = Ox . limit ( val , self . options . min , self . options . max ) ;
if ( val != self . options . value ) {
that . options ( {
value : val
} ) ;
setThumb ( animate ) ;
2010-02-06 08:23:42 +00:00
that . triggerEvent ( "change" , { value : val } ) ;
2010-01-07 20:21:07 +00:00
}
}
function setWidth ( width ) {
trackWidth = width - self . options . arrows * 32 ;
thumbWidth = Math . max ( trackWidth / values - 2 , self . options . thumbSize - 2 ) ;
that . $element . css ( {
width : ( width - 2 ) + "px"
} ) ;
$track . css ( {
width : ( trackWidth - 2 ) + "px"
} ) ;
if ( trackImages ) {
$image . css ( {
width : ( trackWidth - 2 ) + "px"
} ) ;
}
$thumb . css ( {
width : ( thumbWidth - 2 ) + "px" ,
padding : 0
} ) ;
setThumb ( ) ;
}
/ *
shared functions
* /
self . onChange = function ( option , value ) {
}
return that ;
} ;
2010-02-05 05:20:13 +00:00
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . Select
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
Ox . Select = function ( options , self ) {
var self = self || { } ,
2010-02-19 10:24:02 +00:00
that = new Ox . Element ( "div" , self ) // fixme: do we use "div", or {}, or "", by default?
2010-02-05 05:20:13 +00:00
. defaults ( {
id : "" ,
2010-02-06 06:21:01 +00:00
items : [ ] ,
size : "medium"
2010-02-05 05:20:13 +00:00
} )
. options ( options )
2010-02-08 14:42:00 +00:00
. addClass ( "OxSelect Ox" + Ox . toTitleCase ( self . options . size ) ) ;
self . buttonId = self . options . id + "_button"
2010-02-09 12:25:42 +00:00
self . groupId = self . options . id + "_group"
2010-02-08 14:42:00 +00:00
self . menuId = self . options . id + "_menu" ,
2010-02-05 05:20:13 +00:00
$ . each ( self . options . items , function ( i , item ) {
2010-02-06 06:21:01 +00:00
self . options . items [ i ] = $ . extend ( self . options . items [ i ] , {
checked : item . checked || false ,
2010-02-09 12:25:42 +00:00
group : self . groupId
2010-02-06 06:21:01 +00:00
} ) ;
if ( item . checked ) {
2010-02-08 14:42:00 +00:00
self . selected = i ;
2010-02-06 06:21:01 +00:00
}
2010-02-07 15:01:22 +00:00
} ) ;
2010-02-05 05:20:13 +00:00
2010-02-06 06:21:01 +00:00
that . $button = new Ox . Button ( $ . extend ( self . options , {
2010-02-08 14:42:00 +00:00
id : self . buttonId ,
2010-02-06 06:21:01 +00:00
type : "text" , // fixme: this shouldn't be necessary
2010-07-02 12:33:45 +00:00
value : self . options . items [ self . selected ] . title // fixme: title instead of value?
2010-02-06 06:21:01 +00:00
} ) , { } )
. click ( clickButton )
. appendTo ( that ) ;
2010-03-06 09:54:30 +00:00
that . $symbol = new Ox . Button ( {
style : "symbol" ,
type : "image" ,
value : "select"
2010-02-06 06:21:01 +00:00
} )
2010-03-06 09:54:30 +00:00
. click ( clickButton )
. appendTo ( that ) ;
2010-02-06 06:21:01 +00:00
2010-02-05 05:20:13 +00:00
that . $menu = new Ox . Menu ( {
2010-02-06 06:21:01 +00:00
element : that . $button ,
2010-02-08 14:42:00 +00:00
id : self . menuId ,
2010-02-06 06:21:01 +00:00
items : self . options . items ,
2010-02-06 10:29:27 +00:00
offset : {
left : 8 ,
top : 0
} ,
2010-02-06 06:21:01 +00:00
side : "bottom" ,
size : self . options . size
} ) ;
2010-02-06 08:23:42 +00:00
2010-02-09 12:25:42 +00:00
that . bindEvent ( "change_" + self . groupId , clickMenu ) ;
2010-02-06 06:35:40 +00:00
2010-02-06 06:21:01 +00:00
function clickButton ( ) {
that . $menu . toggleMenu ( ) ;
}
function clickMenu ( event , data ) {
that . $button . options ( {
value : data . value
} ) ;
2010-02-09 11:50:29 +00:00
that . triggerEvent ( "change" , data . value ) ;
2010-02-05 05:20:13 +00:00
}
2010-02-06 06:21:01 +00:00
self . onChange = function ( key , value ) {
} ;
that . width = function ( val ) {
// fixme: silly hack, and won't work for css()
2010-02-19 10:24:02 +00:00
that . $element . width ( val + 16 ) ;
2010-02-06 06:21:01 +00:00
that . $button . width ( val ) ;
2010-03-06 09:54:30 +00:00
//that.$symbol.width(val);
2010-02-06 06:21:01 +00:00
return that ;
} ;
2010-02-05 05:20:13 +00:00
return that ;
}
2010-02-10 09:59:59 +00:00
/ *
=== === === === === === === === === === === === === === === === === === === === === === === === === =
Lists
=== === === === === === === === === === === === === === === === === === === === === === === === === =
* /
Ox . List = function ( options , self ) {
var self = self || { } ,
2010-06-25 15:55:25 +00:00
that = new Ox . Container ( { } , self )
. defaults ( {
2010-06-28 11:19:04 +00:00
construct : function ( ) { } ,
2010-06-25 15:55:25 +00:00
itemHeight : 16 ,
itemWidth : 16 ,
2010-06-28 09:16:36 +00:00
keys : [ ] ,
2010-06-25 15:55:25 +00:00
orientation : "vertical" ,
request : function ( ) { } , // {sort:, range:, callback:}, without parameter returns {items, size etc.}
rowLength : 1 ,
sort : [ ] ,
2010-06-30 18:47:10 +00:00
type : "text" ,
unique : ""
2010-06-25 15:55:25 +00:00
} )
2010-06-28 09:16:36 +00:00
. options ( options || { } )
2010-06-29 22:19:41 +00:00
. click ( click )
2010-06-28 09:16:36 +00:00
. scroll ( scroll ) ;
2010-06-25 15:55:25 +00:00
$ . extend ( self , {
$items : [ ] ,
$pages : [ ] ,
2010-06-30 10:39:49 +00:00
ids : { } ,
2010-06-30 14:21:06 +00:00
keyboardEvents : {
key _alt _control _a : invertSelection ,
key _control _a : selectAll ,
key _control _shift _a : selectNone ,
key _end : scrollToFirst ,
key _home : scrollToLast ,
key _pagedown : scrollPageDown ,
key _pageup : scrollPageUp
} ,
2010-06-25 15:55:25 +00:00
page : 0 ,
pageLength : 100 ,
2010-06-28 09:16:36 +00:00
requests : [ ] ,
2010-06-25 15:55:25 +00:00
selected : [ ]
} ) ;
2010-06-30 14:21:06 +00:00
self . keyboardEvents [ "key_" + ( self . options . orientation == "horizontal" ? "left" : "up" ) ] = selectPrevious ;
self . keyboardEvents [ "key_" + ( self . options . orientation == "horizontal" ? "right" : "down" ) ] = selectNext ;
self . keyboardEvents [ "key_" + ( self . options . orientation == "horizontal" ? "shift_left" : "shift_up" ) ] = addPreviousToSelection ;
self . keyboardEvents [ "key_" + ( self . options . orientation == "horizontal" ? "shift_right" : "shift_down" ) ] = addNextToSelection ;
2010-06-28 09:16:36 +00:00
2010-06-30 18:47:10 +00:00
updateQuery ( ) ;
that . bindEvent ( self . keyboardEvents ) ;
2010-06-25 15:55:25 +00:00
function addAllToSelection ( pos ) {
var arr ,
len = self . $items . length ;
if ( ! isSelected ( pos ) ) {
2010-06-30 09:02:13 +00:00
if ( self . selected . length == 0 ) {
2010-06-25 15:55:25 +00:00
addToSelection ( pos ) ;
} else {
2010-06-30 09:02:13 +00:00
if ( Ox . min ( self . selected ) < pos ) {
2010-06-25 15:55:25 +00:00
var arr = [ pos ] ;
for ( var i = pos - 1 ; i >= 0 ; i -- ) {
if ( isSelected ( i ) ) {
$ . each ( arr , function ( i , v ) {
addToSelection ( v ) ;
} ) ;
break ;
}
arr . push ( i ) ;
}
}
2010-06-30 09:02:13 +00:00
if ( Ox . max ( self . selected ) > pos ) {
2010-06-25 15:55:25 +00:00
var arr = [ pos ] ;
for ( var i = pos + 1 ; i < len ; i ++ ) {
if ( isSelected ( i ) ) {
$ . each ( arr , function ( i , v ) {
addToSelection ( v ) ;
} ) ;
break ;
}
arr . push ( i ) ;
}
}
}
}
}
2010-06-30 14:21:06 +00:00
function addNextToSelection ( ) {
var pos = getNext ( ) ;
if ( pos > - 1 ) {
addToSelection ( pos ) ;
scrollTo ( pos ) ;
}
}
function addPreviousToSelection ( ) {
var pos = getPrevious ( ) ;
if ( pos > - 1 ) {
addToSelection ( pos ) ;
scrollTo ( pos ) ;
}
}
2010-06-25 15:55:25 +00:00
function addToSelection ( pos ) {
if ( ! isSelected ( pos ) ) {
2010-06-30 09:02:13 +00:00
self . selected . push ( pos ) ;
2010-06-25 15:55:25 +00:00
if ( ! Ox . isUndefined ( self . $items [ pos ] ) ) {
self . $items [ pos ] . addClass ( "OxSelected" ) ;
}
2010-06-30 21:41:27 +00:00
that . triggerEvent ( "select" , {
2010-06-30 18:47:10 +00:00
ids : $ . map ( self . selected , function ( v , i ) {
return self . ids [ v ] ;
} )
2010-06-25 15:55:25 +00:00
} ) ;
}
}
2010-06-30 18:47:10 +00:00
function clear ( ) {
$ . each ( self . requests , function ( i , v ) {
2010-06-30 21:41:27 +00:00
Ox . print ( "Ox.Request.cancel" , v ) ;
2010-06-30 18:47:10 +00:00
Ox . Request . cancel ( v ) ;
} ) ;
$ . extend ( self , {
$items : [ ] ,
$pages : [ ] ,
page : 0 ,
requests : [ ]
} ) ;
}
2010-06-29 22:19:41 +00:00
function click ( e ) {
2010-06-30 09:02:13 +00:00
var $element = $ ( e . target ) , pos ;
2010-06-30 09:27:02 +00:00
that . gainFocus ( ) ;
2010-06-30 09:02:13 +00:00
while ( ! $element . hasClass ( "OxItem" ) && ! $element . hasClass ( "OxPage" ) ) {
$element = $element . parent ( ) ;
}
if ( $element . hasClass ( "OxItem" ) ) {
Ox . print ( $element . attr ( "id" ) , $element . data ( "position" ) ) ;
pos = $element . data ( "position" ) ;
if ( e . shiftKey ) {
addAllToSelection ( pos ) ;
} else if ( e . metaKey ) {
toggleSelection ( pos ) ;
} else {
select ( pos ) ;
}
} else {
selectNone ( ) ;
}
2010-06-29 22:19:41 +00:00
}
2010-06-25 15:55:25 +00:00
function deselect ( pos ) {
if ( isSelected ( pos ) ) {
2010-06-30 09:02:13 +00:00
self . selected . splice ( self . selected . indexOf ( pos ) , 1 ) ;
2010-06-25 15:55:25 +00:00
if ( ! Ox . isUndefined ( self . $items [ pos ] ) ) {
self . $items [ pos ] . removeClass ( "OxSelected" ) ;
}
2010-06-30 21:41:27 +00:00
that . triggerEvent ( "select" , {
2010-06-30 18:47:10 +00:00
ids : $ . map ( self . selected , function ( v , i ) {
return self . ids [ v ] ;
} )
2010-06-25 15:55:25 +00:00
} ) ;
}
}
2010-06-30 14:21:06 +00:00
function getHeight ( ) {
2010-06-30 18:47:10 +00:00
return that . height ( ) - ( that . $content . width ( ) > that . width ( ) ? oxui . scrollbarSize : 0 ) ;
2010-06-30 14:21:06 +00:00
}
2010-06-25 15:55:25 +00:00
function getNext ( ) {
var pos = - 1 ;
2010-06-30 09:02:13 +00:00
if ( self . selected . length ) {
2010-06-30 10:39:49 +00:00
pos = Ox . max ( self . selected ) + 1 ;
2010-06-25 15:55:25 +00:00
if ( pos == self . $items . length ) {
pos = - 1 ;
}
}
return pos ;
}
function getPage ( ) {
2010-06-30 21:41:27 +00:00
return self . options . orientation == "horizontal"
? Math . floor ( that . scrollLeft ( ) / self . pageWidth )
: Math . floor ( that . scrollTop ( ) / self . pageHeight ) ;
2010-06-25 15:55:25 +00:00
}
2010-06-30 18:47:10 +00:00
function getPositions ( ) {
Ox . print ( "getPositions" , $ . map ( self . selected , function ( v , i ) {
return self . ids [ v ] ;
} ) ) ;
// fixme: optimize: send non-selected ids if more than half of the items are selected
if ( self . selected . length /*&& self.selected.length < self.listLength*/ ) {
self . requests . push ( self . options . request ( {
callback : getPositionsCallback ,
ids : $ . map ( self . selected , function ( v , i ) {
return self . ids [ v ] ;
} ) ,
sort : self . options . sort
} ) ) ;
} else {
getPositionsCallback ( ) ;
}
}
function getPositionsCallback ( result ) {
Ox . print ( "getPositionsCallback" , result )
if ( result ) {
$ . extend ( self , {
ids : { } ,
selected : [ ]
} ) ;
$ . each ( result . data . positions , function ( id , pos ) {
Ox . print ( "id" , id , "pos" , pos )
self . selected . push ( pos ) ;
} ) ;
}
load ( ) ;
}
2010-06-25 15:55:25 +00:00
function getPrevious ( ) {
var pos = - 1 ;
2010-06-30 09:02:13 +00:00
if ( self . selected . length ) {
2010-06-30 10:39:49 +00:00
pos = Ox . min ( self . selected ) - 1 ;
2010-06-25 15:55:25 +00:00
}
return pos ;
}
2010-06-30 14:21:06 +00:00
function getWidth ( ) {
2010-06-30 18:47:10 +00:00
return that . width ( ) - ( that . $content . height ( ) > that . height ( ) ? oxui . scrollbarSize : 0 ) ;
2010-06-30 14:21:06 +00:00
}
2010-06-25 15:55:25 +00:00
function invertSelection ( ) {
2010-06-30 14:21:06 +00:00
$ . each ( Ox . range ( self . listLength ) , function ( i , v ) {
toggleSelection ( v ) ;
2010-06-25 15:55:25 +00:00
} ) ;
}
function isSelected ( pos ) {
2010-06-28 09:16:36 +00:00
return self . selected . indexOf ( pos ) > - 1 ;
2010-06-25 15:55:25 +00:00
}
2010-06-30 18:47:10 +00:00
function load ( ) {
that . scrollTop ( 0 ) ;
that . $content . empty ( ) ;
loadPages ( self . page ) ;
}
2010-06-25 15:55:25 +00:00
function loadPage ( page , callback ) {
2010-06-29 22:19:41 +00:00
Ox . print ( "loadPage" , page )
2010-06-30 18:47:10 +00:00
if ( page < 0 || page >= self . pages ) {
! Ox . isUndefined ( callback ) && callback ( ) ;
2010-06-25 15:55:25 +00:00
return ;
}
2010-06-30 09:02:13 +00:00
var keys = $ . inArray ( "id" , self . options . keys ) > - 1 ? self . options . keys :
$ . merge ( self . options . keys , [ "id" ] ) ,
offset = page * self . pageLength ,
2010-06-25 15:55:25 +00:00
range = [ offset , offset + ( page < self . pages - 1 ?
self . pageLength : self . listLength % self . pageLength ) ] ;
if ( Ox . isUndefined ( self . $pages [ page ] ) ) {
2010-06-28 09:16:36 +00:00
self . requests . push ( self . options . request ( {
2010-06-28 11:19:04 +00:00
callback : function ( result ) {
2010-06-25 15:55:25 +00:00
self . $pages [ page ] = new Ox . ListPage ( ) ;
if ( self . options . type == "text" ) {
self . $pages [ page ] . css ( {
top : ( page * self . pageHeight ) + "px"
} ) ;
} else {
self . $pages [ page ] . css ( {
} ) ;
}
2010-06-28 11:19:04 +00:00
$ . each ( result . data . items , function ( i , v ) {
2010-06-25 15:55:25 +00:00
var pos = offset + i ;
2010-06-28 11:19:04 +00:00
self . $items [ pos ] = new Ox . ListItem ( {
construct : self . options . construct ,
data : v ,
2010-06-30 18:47:10 +00:00
id : v [ self . options . unique ] ,
2010-06-30 09:02:13 +00:00
position : pos
2010-06-28 11:19:04 +00:00
} ) ;
2010-06-30 18:47:10 +00:00
self . ids [ pos ] = v [ self . options . unique ] ;
2010-06-25 15:55:25 +00:00
if ( isSelected ( pos ) ) {
self . $items [ pos ] . addClass ( "OxSelected" ) ;
}
2010-06-30 10:39:49 +00:00
self . $items [ pos ] . appendTo ( self . $pages [ page ] ) ;
2010-06-25 15:55:25 +00:00
} ) ;
2010-07-03 08:23:39 +00:00
if ( self . options . type == "text" && page == 0 ) {
var height = that . height ( ) ,
visibleItems = Math . ceil ( height / self . options . itemHeight ) ;
if ( result . data . items . length < visibleItems ) {
self . $pages [ page ] . height ( height ) . css ( {
overflow : "hidden"
} ) ;
$ . each ( Ox . range ( result . data . items . length , visibleItems ) , function ( i , v ) {
new Ox . ListItem ( {
construct : self . options . construct ,
data : { } ,
id : "" ,
position : v
} ) . appendTo ( self . $pages [ page ] ) ;
} ) ;
}
}
2010-06-28 09:16:36 +00:00
self . $pages [ page ] . appendTo ( that . $content ) ;
2010-06-30 18:47:10 +00:00
! Ox . isUndefined ( callback ) && callback ( ) ;
2010-06-25 15:55:25 +00:00
} ,
2010-06-30 09:02:13 +00:00
keys : keys ,
2010-06-25 15:55:25 +00:00
range : range ,
sort : self . options . sort
2010-06-28 09:16:36 +00:00
} ) ) ;
} else {
self . $pages [ page ] . appendTo ( that . $content ) ;
2010-06-25 15:55:25 +00:00
}
}
function loadPages ( page , callback ) {
var counter = 0 ,
fn = function ( ) {
counter ++ ;
counter == 2 && ! Ox . isUndefined ( callback ) && callback ( ) ;
} ;
loadPage ( page , function ( ) {
loadPage ( page - 1 , fn ) ;
loadPage ( page + 1 , fn ) ;
} ) ;
}
2010-06-28 09:16:36 +00:00
function scroll ( ) {
var page = self . page ;
self . page = getPage ( ) ;
if ( self . page == page - 1 ) {
unloadPage ( self . page + 2 ) ;
loadPage ( self . page - 1 ) ;
} else if ( self . page == page + 1 ) {
unloadPage ( self . page - 2 ) ;
loadPage ( self . page + 1 ) ;
} else if ( self . page == page - 2 ) {
unloadPage ( self . page + 3 ) ;
unloadPage ( self . page + 2 ) ;
loadPage ( self . page ) ;
loadPage ( self . page - 1 ) ;
} else if ( self . page == page + 2 ) {
unloadPage ( self . page - 3 ) ;
unloadPage ( self . page - 2 ) ;
loadPage ( self . page ) ;
loadPage ( self . page + 1 ) ;
} else if ( self . page != page ) {
unloadPages ( page ) ;
loadPages ( self . page ) ;
}
}
2010-06-30 14:21:06 +00:00
function scrollPageDown ( ) {
that . scrollBy ( getHeight ( ) ) ;
}
function scrollPageUp ( ) {
that . scrollBy ( - getHeight ( ) ) ;
}
function scrollTo ( pos ) {
var positions = [ ] , scroll , size ;
if ( self . options . orientation == "horizontal" ) {
} else if ( self . options . orientation == "vertical" ) {
positions [ 0 ] = self . options . itemHeight * pos ;
positions [ 1 ] = positions [ 0 ] + self . options . itemHeight ;
scroll = that . scrollTop ( ) ;
size = getHeight ( ) ;
if ( positions [ 0 ] < scroll ) {
that . animate ( {
scrollTop : positions [ 0 ] + "px"
} , 0 ) ;
} else if ( positions [ 1 ] > scroll + size ) {
that . animate ( {
scrollTop : ( positions [ 1 ] - size ) + "px"
} , 0 ) ;
}
} else {
}
}
function scrollToFirst ( ) {
that . scrollTop ( 0 ) ;
}
function scrollToLast ( ) {
2010-06-30 18:47:10 +00:00
that . scrollTop ( self . listHeight ) ;
2010-06-30 14:21:06 +00:00
}
2010-06-25 15:55:25 +00:00
function select ( pos ) {
2010-06-30 09:02:13 +00:00
if ( ! isSelected ( pos ) || self . selected . length > 1 ) {
2010-06-25 15:55:25 +00:00
selectNone ( ) ;
addToSelection ( pos ) ;
}
}
function selectAll ( ) {
2010-06-30 14:21:06 +00:00
$ . each ( Ox . range ( self . listLength ) , function ( i , v ) {
Ox . print ( "adding" , v ) ;
addToSelection ( v ) ;
2010-06-25 15:55:25 +00:00
} ) ;
}
function selectNext ( ) {
var pos = getNext ( ) ;
if ( pos > - 1 ) {
select ( pos ) ;
scrollTo ( pos ) ;
}
}
function selectNone ( ) {
$ . each ( self . $items , function ( i , v ) {
deselect ( i ) ;
} ) ;
}
function selectPrevious ( ) {
var pos = getPrevious ( ) ;
if ( pos > - 1 ) {
select ( pos ) ;
scrollTo ( pos ) ;
}
}
function selectQuery ( str ) {
$ . each ( self . $items , function ( i , v ) {
if ( Ox . toLatin ( v . title ) . toUpperCase ( ) . indexOf ( str ) == 0 ) {
select ( i ) ;
scrollTo ( i ) ;
return false ;
}
} ) ;
}
function toggleSelection ( pos ) {
if ( ! isSelected ( pos ) ) {
addToSelection ( pos ) ;
} else {
deselect ( pos ) ;
}
}
function unloadPage ( page ) {
2010-06-29 22:19:41 +00:00
if ( page < 0 || page >= self . pages ) {
return ;
}
Ox . print ( "unloadPage" , page )
Ox . print ( "self.$pages" , self . $pages )
Ox . print ( ! Ox . isUndefined ( self . $pages [ page ] ) )
2010-06-25 15:55:25 +00:00
! Ox . isUndefined ( self . $pages [ page ] ) && self . $pages [ page ] . remove ( ) ;
}
function unloadPages ( page ) {
unloadPage ( page ) ;
unloadPage ( page - 1 ) ;
unloadPage ( page + 1 )
}
2010-02-10 09:59:59 +00:00
2010-06-30 18:47:10 +00:00
function updateQuery ( ) {
clear ( ) ;
self . requests . push ( self . options . request ( {
callback : function ( result ) {
var keys = { } ;
2010-07-01 12:26:32 +00:00
that . triggerEvent ( "load" , result . data ) ;
2010-06-30 11:09:45 +00:00
$ . extend ( self , {
2010-06-30 18:47:10 +00:00
listHeight : result . data . items * self . options . itemHeight , // fixme: should be listSize
listLength : result . data . items ,
pages : Math . ceil ( result . data . items / self . pageLength ) ,
pageWidth : self . options . orientation == "horizontal" ?
self . pageLength * self . options . itemWidth : 0 ,
pageHeight : self . options . orientation == "horizontal" ? 0 :
self . pageLength * self . options . itemHeight / self . options . rowLength
2010-06-30 11:09:45 +00:00
} ) ;
2010-06-30 18:47:10 +00:00
that . $content . css ( {
height : self . listHeight + "px"
2010-06-30 11:09:45 +00:00
} ) ;
2010-06-30 18:47:10 +00:00
getPositions ( ) ;
2010-06-30 11:09:45 +00:00
}
2010-06-30 18:47:10 +00:00
} ) ) ;
}
2010-06-30 11:09:45 +00:00
2010-06-30 18:47:10 +00:00
function updateSort ( ) {
clear ( ) ;
getPositions ( ) ;
2010-06-28 09:16:36 +00:00
}
2010-06-30 18:47:10 +00:00
self . onChange = function ( key , value ) {
Ox . print ( "list onChange" , key , value ) ;
if ( key == "request" ) {
updateQuery ( ) ;
}
} ;
that . clearCache = function ( ) { // fixme: unused? make private?
self . $pages = [ ] ;
} ;
2010-06-28 09:16:36 +00:00
that . sort = function ( key , operator ) {
if ( key != self . options . sort [ 0 ] . key || operator != self . options . sort [ 0 ] . operator ) {
self . options . sort [ 0 ] = {
key : key ,
operator : operator
}
2010-06-30 21:41:27 +00:00
that . triggerEvent ( "sort" , self . options . sort [ 0 ] ) ;
2010-06-30 18:47:10 +00:00
updateSort ( ) ;
2010-06-28 09:16:36 +00:00
}
}
2010-02-10 09:59:59 +00:00
return that ;
} ;
Ox . ListItem = function ( options , self ) {
2010-06-28 11:19:04 +00:00
var self = self || { } ,
that = new Ox . Element ( { } , self )
. defaults ( {
construct : function ( ) { } ,
data : { } ,
2010-06-30 18:47:10 +00:00
id : "" ,
2010-06-30 09:02:13 +00:00
position : 0
2010-06-28 11:19:04 +00:00
} )
2010-06-29 14:00:18 +00:00
. options ( options || { } ) ;
2010-06-28 11:19:04 +00:00
$ . each ( self . options . data , function ( k , v ) {
self . options . data [ k ] = $ . isArray ( v ) ? v . join ( ", " ) : v ;
} ) ;
2010-06-30 09:02:13 +00:00
that . $element = self . options . construct ( self . options . data )
. attr ( {
2010-06-30 18:47:10 +00:00
id : self . options . id
2010-06-30 09:02:13 +00:00
} )
. data ( "position" , self . options . position ) ;
2010-06-28 11:19:04 +00:00
return that ;
2010-02-10 09:59:59 +00:00
} ;
2010-06-25 15:55:25 +00:00
Ox . ListPage = function ( options , self ) {
var self = self || { } ,
that = new Ox . Element ( { } , self )
2010-06-29 21:58:17 +00:00
. addClass ( "OxPage" ) ;
2010-06-25 15:55:25 +00:00
return that ;
} ;
Ox . TextList = function ( options , self ) {
var self = self || { } ,
that = new Ox . Element ( { } , self )
. defaults ( {
columns : [ ] ,
2010-06-29 21:24:07 +00:00
columnWidth : [ 40 , 800 ] ,
2010-06-30 09:27:02 +00:00
id : "" ,
2010-06-25 15:55:25 +00:00
request : function ( ) { } , // {sort, range, keys, callback}
2010-06-28 09:16:36 +00:00
sort : [ ]
2010-06-25 15:55:25 +00:00
} )
. options ( options || { } )
. addClass ( "OxTextList" ) ;
2010-06-30 18:47:10 +00:00
$ . each ( self . options . columns , function ( i , v ) { // fixme: can this go into a generic ox.js function?
if ( Ox . isUndefined ( v . unique ) ) {
v . unique = false ;
}
if ( Ox . isUndefined ( v . visible ) ) {
v . visible = false ;
}
if ( v . unique ) {
self . unique = v . id ;
}
} ) ;
2010-06-25 15:55:25 +00:00
$ . extend ( self , {
columnWidths : [ ] ,
itemHeight : 16 ,
page : 0 ,
pageLength : 100 ,
scrollLeft : 0 ,
2010-06-29 21:24:07 +00:00
selectedColumn : getColumnIndexById ( self . options . sort [ 0 ] . key ) ,
2010-06-28 09:16:36 +00:00
visibleColumns : $ . map ( self . options . columns , function ( v , i ) {
return v . visible ? v : null ;
} )
2010-06-25 15:55:25 +00:00
} ) ;
$ . extend ( self , {
pageHeight : self . pageLength * self . itemHeight
} ) ;
// Head
that . $bar = new Ox . Bar ( {
orientation : "horizontal" ,
size : 16
} ) . appendTo ( that ) ;
that . $head = new Ox . Container ( )
. addClass ( "OxHead" )
. appendTo ( that . $bar ) ;
that . $head . $content . addClass ( "OxTitles" ) ;
that . $titles = [ ] ;
2010-06-28 09:16:36 +00:00
$ . each ( self . visibleColumns , function ( i , v ) {
2010-06-25 15:55:25 +00:00
var $order , $resize , $left , $center , $right ;
self . columnWidths [ i ] = v . width ;
that . $titles [ i ] = $ ( "<div>" )
. addClass ( "OxTitle" )
. css ( {
width : ( v . width - 9 ) + "px" ,
textAlign : v . align
} )
. html ( v . title )
. click ( function ( ) {
2010-06-29 21:24:07 +00:00
clickColumn ( v . id )
2010-06-25 15:55:25 +00:00
} )
. appendTo ( that . $head . $content . $element ) ;
$order = $ ( "<div>" )
. addClass ( "OxOrder" )
. html ( oxui . symbols [ "triangle_" + (
2010-06-29 16:28:22 +00:00
v . operator == "+" ? "up" : "down"
2010-06-25 15:55:25 +00:00
) ] )
. click ( function ( ) {
$ ( this ) . prev ( ) . trigger ( "click" )
} )
. appendTo ( that . $head . $content . $element ) ;
$resize = $ ( "<div>" )
. addClass ( "OxResize" )
. mousedown ( function ( e ) {
var initialWidth = self . columnWidths [ i ] ,
initialX = e . clientX ;
$window . mousemove ( function ( e ) {
var x = e . clientX ,
2010-06-29 21:24:07 +00:00
width = Ox . limit (
initialWidth - initialX + x ,
self . options . columnWidth [ 0 ] ,
self . options . columnWidth [ 1 ]
) ;
resizeColumn ( v . id , width ) ;
2010-06-25 15:55:25 +00:00
} ) ;
$window . mouseup ( function ( ) {
$window . unbind ( "mousemove" ) ;
$window . unbind ( "mouseup" ) ;
} ) ;
} )
. dblclick ( function ( ) {
2010-06-29 21:24:07 +00:00
resizeColumn ( v . id , v . width ) ;
2010-06-25 15:55:25 +00:00
} )
. appendTo ( that . $head . $content . $element ) ;
$left = $ ( "<div>" ) . addClass ( "OxLeft" ) . appendTo ( $resize ) ;
$center = $ ( "<div>" ) . addClass ( "OxCenter" ) . appendTo ( $resize ) ;
$right = $ ( "<div>" ) . addClass ( "OxRight" ) . appendTo ( $resize ) ;
} ) ;
that . $head . $content . css ( {
2010-06-29 17:39:21 +00:00
width : ( Ox . sum ( self . columnWidths ) + 2 ) + "px"
2010-06-25 15:55:25 +00:00
} ) ;
2010-06-29 21:24:07 +00:00
toggleSelected ( self . options . columns [ self . selectedColumn ] . id ) ;
that . $titles [ getColumnPositionById ( self . options . columns [ self . selectedColumn ] . id ) ] . css ( {
2010-06-25 15:55:25 +00:00
width : ( self . options . columns [ self . selectedColumn ] . width - 25 ) + "px"
} ) ;
2010-06-30 15:49:49 +00:00
that . $select = new Ox . Button ( {
style : "symbol" ,
type : "image" ,
value : "select"
} ) . appendTo ( that . $bar . $element ) ;
2010-06-25 15:55:25 +00:00
// Body
2010-06-28 09:16:36 +00:00
that . $body = new Ox . List ( {
2010-06-28 11:19:04 +00:00
construct : constructItem ,
2010-06-30 09:27:02 +00:00
id : self . options . id ,
2010-06-28 09:16:36 +00:00
itemHeight : 16 ,
2010-06-30 09:02:13 +00:00
itemWidth : getItemWidth ( ) ,
2010-06-28 11:19:04 +00:00
keys : $ . map ( self . visibleColumns , function ( v , i ) {
return v . id ;
} ) ,
2010-06-28 09:16:36 +00:00
orientation : "vertical" ,
request : self . options . request ,
sort : self . options . sort ,
2010-06-30 18:47:10 +00:00
type : "text" ,
unique : self . unique
2010-06-28 11:19:04 +00:00
} )
2010-06-28 09:16:36 +00:00
. addClass ( "OxBody" )
. scroll ( function ( ) {
var scrollLeft = $ ( this ) . scrollLeft ( ) ;
if ( scrollLeft != self . scrollLeft ) {
self . scrollLeft = scrollLeft ;
that . $head . scrollLeft ( scrollLeft ) ;
}
} )
. appendTo ( that ) ;
that . $body . $content . css ( {
2010-06-30 09:02:13 +00:00
width : getItemWidth ( ) + "px"
2010-06-25 15:55:25 +00:00
} ) ;
2010-06-28 09:16:36 +00:00
function addColumn ( id ) {
}
2010-06-29 21:24:07 +00:00
function clickColumn ( id ) {
var i = getColumnIndexById ( id ) ,
isSelected = self . options . sort [ 0 ] . key == self . options . columns [ i ] . id ;
2010-06-29 16:28:22 +00:00
that . sort (
2010-06-29 21:24:07 +00:00
self . options . columns [ i ] . id , isSelected ?
( self . options . sort [ 0 ] . operator == "+" ? "-" : "+" ) :
self . options . columns [ i ] . operator
2010-06-29 16:28:22 +00:00
) ;
}
2010-06-30 09:02:13 +00:00
function constructItem ( data ) {
2010-06-28 11:19:04 +00:00
var $item = $ ( "<div>" )
2010-06-29 12:57:42 +00:00
. addClass ( "OxItem" )
2010-06-25 15:55:25 +00:00
. css ( {
2010-06-30 18:47:10 +00:00
width : Math . max ( Ox . sum ( self . columnWidths ) , that . $element . width ( ) - oxui . scrollbarSize ) + "px"
2010-06-30 09:02:13 +00:00
} ) ;
2010-06-28 11:19:04 +00:00
$ . each ( self . visibleColumns , function ( i , v ) {
2010-06-25 15:55:25 +00:00
var $cell = $ ( "<div>" )
. addClass ( "OxCell OxColumn" + Ox . toTitleCase ( v . id ) )
. css ( {
2010-06-28 11:19:04 +00:00
width : ( self . columnWidths [ i ] - 9 ) + "px" ,
2010-06-25 15:55:25 +00:00
textAlign : v . align
} )
2010-07-03 08:23:39 +00:00
. html ( ! $ . isEmptyObject ( data ) ? data [ v . id ] : "" )
. appendTo ( $item ) ;
2010-06-25 15:55:25 +00:00
} ) ;
return $item ;
}
2010-06-29 21:24:07 +00:00
function getColumnIndexById ( id ) {
2010-06-25 15:55:25 +00:00
var pos = - 1 ;
$ . each ( self . options . columns , function ( i , v ) {
if ( v . id == id ) {
pos = i ;
return false ;
}
} ) ;
return pos ;
}
2010-06-29 21:24:07 +00:00
function getColumnPositionById ( id ) {
var pos = - 1 ;
$ . each ( self . visibleColumns , function ( i , v ) {
if ( v . id == id ) {
pos = i ;
return false ;
}
} ) ;
return pos ;
}
2010-06-30 09:02:13 +00:00
function getItemWidth ( ) {
2010-06-30 18:47:10 +00:00
return Math . max ( Ox . sum ( self . columnWidths ) , that . $element . width ( ) - oxui . scrollbarSize ) ;
2010-06-30 09:02:13 +00:00
}
2010-06-28 09:16:36 +00:00
function moveColumn ( id ) {
}
function removeColumn ( id ) {
}
2010-06-29 22:19:41 +00:00
function resize ( ) {
}
2010-06-29 21:24:07 +00:00
function resizeColumn ( id , width ) {
var i = getColumnIndexById ( id ) ,
pos = getColumnPositionById ( id ) ;
2010-06-25 15:55:25 +00:00
self . columnWidths [ pos ] = width ;
that . $head . $content . css ( {
width : ( Ox . sum ( self . columnWidths ) + 2 ) + "px"
} ) ;
that . $titles [ pos ] . css ( {
2010-06-29 21:24:07 +00:00
width : ( width - 9 - ( i == self . selectedColumn ? 16 : 0 ) ) + "px"
2010-06-25 15:55:25 +00:00
} ) ;
that . $body . $content . find ( ".OxItem" ) . css ( { // fixme: can we avoid this lookup?
2010-06-30 09:02:13 +00:00
width : getItemWidth ( ) + "px"
2010-06-25 15:55:25 +00:00
} ) ;
that . $body . $content . css ( {
2010-06-30 09:02:13 +00:00
width : getItemWidth ( ) + "px" // fixme: check if scrollbar visible, and listen to resize/toggle event
2010-06-25 15:55:25 +00:00
} ) ;
2010-06-29 21:24:07 +00:00
$ ( ".OxColumn" + Ox . toTitleCase ( self . options . columns [ i ] . id ) ) . css ( {
2010-06-25 15:55:25 +00:00
width : ( width - 9 ) + "px"
} ) ;
that . $body . clearCache ( ) ;
}
2010-06-29 21:24:07 +00:00
function toggleSelected ( id ) {
var pos = getColumnPositionById ( id ) ;
updateOrder ( id ) ;
2010-06-29 17:39:21 +00:00
pos > 0 && that . $titles [ pos ] . prev ( ) . children ( ) . eq ( 2 ) . toggleClass ( "OxSelected" ) ;
2010-06-25 15:55:25 +00:00
that . $titles [ pos ] . toggleClass ( "OxSelected" ) ;
that . $titles [ pos ] . next ( ) . toggleClass ( "OxSelected" ) ;
that . $titles [ pos ] . next ( ) . next ( ) . children ( ) . eq ( 0 ) . toggleClass ( "OxSelected" ) ;
that . $titles [ pos ] . css ( {
width : (
2010-06-29 16:28:22 +00:00
that . $titles [ pos ] . width ( ) + ( that . $titles [ pos ] . hasClass ( "OxSelected" ) ? - 16 : 16 )
2010-06-25 15:55:25 +00:00
) + "px"
} ) ;
}
2010-06-29 21:24:07 +00:00
function updateOrder ( id ) {
var pos = getColumnPositionById ( id ) ;
Ox . print ( id , pos )
2010-06-29 17:39:21 +00:00
that . $titles [ pos ] . next ( ) . html ( oxui . symbols [
"triangle_" + ( self . options . sort [ 0 ] . operator == "+" ? "up" : "down" )
] ) ;
}
2010-06-30 18:47:10 +00:00
self . onChange = function ( key , value ) {
if ( key == "request" ) {
that . $body . options ( key , value ) ;
}
} ;
2010-06-25 15:55:25 +00:00
that . sort = function ( key , operator ) {
2010-06-29 16:28:22 +00:00
var isSelected = key == self . options . sort [ 0 ] . key ;
self . options . sort = [
{
key : key ,
operator : operator
}
] ;
if ( isSelected ) {
2010-06-29 21:24:07 +00:00
updateOrder ( self . options . columns [ self . selectedColumn ] . id ) ;
2010-06-29 16:28:22 +00:00
} else {
2010-06-29 21:24:07 +00:00
toggleSelected ( self . options . columns [ self . selectedColumn ] . id ) ;
self . selectedColumn = getColumnIndexById ( key ) ;
toggleSelected ( self . options . columns [ self . selectedColumn ] . id ) ;
2010-06-25 15:55:25 +00:00
}
2010-06-29 16:28:22 +00:00
that . $body . sort ( self . options . sort [ 0 ] . key , self . options . sort [ 0 ] . operator ) ;
2010-06-25 15:55:25 +00:00
} ;
return that ;
} ;
2010-01-07 20:21:07 +00:00
/ *
=== === === === === === === === === === === === === === === === === === === === === === === === === =
2010-02-02 16:03:11 +00:00
Menus
=== === === === === === === === === === === === === === === === === === === === === === === === === =
* /
Ox . MainMenu = function ( options , self ) {
2010-02-07 15:01:22 +00:00
2010-02-19 10:24:02 +00:00
/ * o p t i o n s :
* extras
* menus
* size
* /
2010-02-07 15:01:22 +00:00
var self = self || { } ,
that = new Ox . Bar ( { } , self )
2010-02-08 09:35:24 +00:00
. defaults ( {
2010-02-19 10:24:02 +00:00
extras : [ ] ,
2010-02-08 09:35:24 +00:00
menus : [ ] ,
size : "medium"
} )
. options ( options || { } )
2010-02-19 10:24:02 +00:00
. addClass ( "OxMainMenu Ox" + Ox . toTitleCase ( self . options . size ) ) // fixme: bar should accept small/medium/large ... like toolbar
2010-02-08 09:35:24 +00:00
. click ( click )
. mousemove ( mousemove ) ;
2010-02-07 15:01:22 +00:00
2010-02-08 09:35:24 +00:00
self . focused = false ;
self . selected = - 1 ;
that . menus = [ ] ;
2010-02-09 05:43:36 +00:00
that . titles = [ ] ;
that . layer = $ ( "<div>" ) . addClass ( "OxLayer" ) ;
2010-02-08 09:35:24 +00:00
2010-02-19 10:57:19 +00:00
$ . each ( self . options . menus , function ( position , menu ) {
2010-02-08 09:35:24 +00:00
that . titles [ position ] = $ ( "<div>" )
. addClass ( "OxTitle" )
. html ( menu . title )
. data ( "position" , position )
. appendTo ( that . $element ) ;
that . menus [ position ] = new Ox . Menu ( $ . extend ( menu , {
element : that . titles [ position ] ,
mainmenu : that ,
size : self . options . size
} ) ) ;
2010-02-09 05:43:36 +00:00
that . bindEvent ( "hide_" + that . menus [ position ] . options ( "id" ) , onHideMenu ) ;
2010-02-08 09:35:24 +00:00
} ) ;
2010-02-19 10:57:19 +00:00
if ( self . options . extras . length ) {
that . extras = $ ( "<div>" )
. addClass ( "OxExtras" )
. appendTo ( that . $element ) ;
$ . each ( self . options . extras , function ( position , extra ) {
2010-02-20 08:29:03 +00:00
extra . css ( {
float : "left" // fixme: need class!
} ) . appendTo ( that . extras ) ;
2010-02-19 10:57:19 +00:00
} ) ;
}
2010-02-08 09:35:24 +00:00
function click ( event ) {
var $target = $ ( event . target ) ,
2010-02-09 05:43:36 +00:00
position = typeof $target . data ( "position" ) != "undefined" ?
$target . data ( "position" ) : - 1 ;
clickTitle ( position ) ;
}
function clickTitle ( position ) {
var selected = self . selected ;
if ( self . selected > - 1 ) {
that . menus [ self . selected ] . hideMenu ( ) ;
}
if ( position > - 1 ) {
if ( position != selected ) {
self . focused = true ;
self . selected = position ;
that . titles [ self . selected ] . addClass ( "OxSelected" ) ;
that . menus [ self . selected ] . showMenu ( ) ;
}
2010-02-08 09:35:24 +00:00
}
}
function mousemove ( event ) {
var $target = $ ( event . target ) ,
2010-02-09 05:43:36 +00:00
focused ,
position = typeof $target . data ( "position" ) != "undefined" ?
$target . data ( "position" ) : - 1 ;
if ( self . focused && position != self . selected ) {
if ( position > - 1 ) {
clickTitle ( position ) ;
} else {
focused = self . focused ;
that . menus [ self . selected ] . hideMenu ( ) ;
self . focused = focused ;
2010-02-08 10:17:00 +00:00
}
2010-02-08 09:35:24 +00:00
}
}
2010-02-09 05:43:36 +00:00
function onHideMenu ( ) {
2010-02-09 12:20:23 +00:00
if ( self . selected > - 1 ) {
that . titles [ self . selected ] . removeClass ( "OxSelected" ) ;
self . selected = - 1 ;
}
2010-02-08 09:35:24 +00:00
self . focused = false ;
}
self . onChange = function ( key , value ) {
} ;
2010-02-19 10:24:02 +00:00
that . addMenuAfter = function ( id ) {
2010-02-08 10:17:00 +00:00
} ;
2010-02-19 10:24:02 +00:00
that . addMenuBefore = function ( id ) {
2010-02-08 10:17:00 +00:00
} ;
2010-02-10 16:37:26 +00:00
that . disableItem = function ( id ) {
} ;
that . enableItem = function ( id ) {
} ;
2010-02-19 16:13:22 +00:00
that . getItem = function ( id ) {
var item ;
$ . each ( that . menus , function ( i , menu ) {
item = menu . getItem ( id ) ;
return ! item ;
} ) ;
return item ;
} ;
2010-02-08 10:17:00 +00:00
that . removeMenu = function ( ) {
} ;
2010-02-08 09:35:24 +00:00
that . selectNextMenu = function ( ) {
if ( self . selected < self . options . menus . length - 1 ) {
clickTitle ( self . selected + 1 ) ;
}
} ;
that . selectPreviousMenu = function ( ) {
if ( self . selected ) {
clickTitle ( self . selected - 1 ) ;
}
} ;
return that ;
} ;
2010-02-02 16:03:11 +00:00
Ox . Menu = function ( options , self ) {
2010-02-09 12:58:47 +00:00
/ *
2010-02-10 15:49:57 +00:00
2010-02-09 12:58:47 +00:00
options :
element the element the menu is attached to
id the menu id
items array of menu items
mainmenu the main menu this menu is part of , if any
offset offset of the menu , in px
parent the supermenu , if any
selected the position of the selected item
2010-02-10 15:49:57 +00:00
side open to "bottom" or "right"
2010-02-09 12:58:47 +00:00
size "large" , "medium" or "small"
2010-02-10 15:49:57 +00:00
events :
2010-02-09 12:58:47 +00:00
change _groupId { id , value } checked item of a group has changed
click _itemId item not belonging to a group was clicked
2010-02-18 14:24:17 +00:00
click _menuId { id , value } item not belonging to a group was clicked
2010-02-18 15:23:43 +00:00
deselect _menuId { id , value } item was deselected not needed , not implemented
2010-02-09 12:58:47 +00:00
hide _menuId menu was hidden
2010-02-18 15:23:43 +00:00
select _menuId { id , value } item was selected not needed , not implemented
2010-02-10 15:49:57 +00:00
2010-02-09 12:58:47 +00:00
* /
2010-02-02 16:03:11 +00:00
var self = self || { } ,
that = new Ox . Element ( { } , self )
. defaults ( {
2010-02-04 08:02:23 +00:00
element : null ,
2010-02-02 16:03:11 +00:00
id : "" ,
items : [ ] ,
2010-02-08 09:35:24 +00:00
mainmenu : null ,
2010-02-02 16:03:11 +00:00
offset : {
left : 0 ,
top : 0
} ,
2010-02-05 09:13:03 +00:00
parent : null ,
2010-02-04 09:50:45 +00:00
selected : - 1 ,
2010-02-02 16:03:11 +00:00
side : "bottom" ,
2010-02-05 09:13:03 +00:00
size : "medium" ,
2010-02-02 16:03:11 +00:00
} )
2010-02-03 12:12:21 +00:00
. options ( options )
. addClass (
"OxMenu Ox" + Ox . toTitleCase ( self . options . side ) +
" Ox" + Ox . toTitleCase ( self . options . size )
2010-02-07 15:01:22 +00:00
)
. click ( click )
. mouseenter ( mouseenter )
. mouseleave ( mouseleave )
. mousemove ( mousemove ) ,
2010-02-05 14:59:24 +00:00
itemHeight = self . options . size == "small" ? 12 : ( self . options . size == "medium" ? 16 : 20 ) ,
2010-02-18 14:24:17 +00:00
// menuHeight,
2010-02-07 15:01:22 +00:00
scrollSpeed = 1 ,
2010-02-05 14:59:24 +00:00
$item ; // fixme: used?
2010-02-07 15:01:22 +00:00
// fixme: attach all private vars to self?
2010-02-02 16:03:11 +00:00
// construct
2010-02-04 08:02:23 +00:00
that . items = [ ] ;
that . submenus = { } ;
2010-02-02 16:03:11 +00:00
that . $scrollbars = [ ] ;
that . $top = $ ( "<div>" )
. addClass ( "OxTop" )
. appendTo ( that . $element ) ;
that . $scrollbars . up = constructScrollbar ( "up" )
. appendTo ( that . $element ) ;
that . $container = $ ( "<div>" )
. addClass ( "OxContainer" )
. appendTo ( that . $element ) ;
that . $content = $ ( "<table>" )
. addClass ( "OxContent" )
. appendTo ( that . $container ) ;
2010-02-18 07:27:32 +00:00
constructItems ( self . options . items ) ;
2010-02-02 16:03:11 +00:00
that . $scrollbars . down = constructScrollbar ( "down" )
. appendTo ( that . $element ) ;
that . $bottom = $ ( "<div>" )
. addClass ( "OxBottom" )
. appendTo ( that . $element ) ;
2010-02-09 05:43:36 +00:00
that . $layer = $ ( "<div>" )
. addClass ( self . options . mainmenu ? "OxMainMenuLayer" : "OxLayer" ) ;
2010-02-02 16:03:11 +00:00
2010-02-05 09:13:03 +00:00
function click ( event ) {
2010-02-07 15:01:22 +00:00
var item ,
2010-02-07 15:12:14 +00:00
position ,
2010-02-07 15:01:22 +00:00
$target = $ ( event . target ) ;
if ( $target . is ( ".OxCell" ) ) {
2010-02-07 15:12:14 +00:00
position = $target . parent ( ) . data ( "position" ) ;
item = that . items [ position ] ;
2010-02-07 15:01:22 +00:00
if ( ! item . options ( "disabled" ) ) {
2010-02-07 15:12:14 +00:00
clickItem ( position ) ;
2010-02-09 12:20:23 +00:00
} else {
that . hideMenu ( ) ;
2010-02-07 15:01:22 +00:00
}
2010-02-09 12:20:23 +00:00
} else {
that . hideMenu ( ) ;
2010-02-05 09:13:03 +00:00
}
}
2010-02-07 15:12:14 +00:00
function clickItem ( position ) {
var item = that . items [ position ] ;
if ( ! item . options ( "items" ) . length ) {
2010-02-08 09:35:24 +00:00
if ( that . options ( "parent" ) ) {
that . options ( "parent" ) . hideMenu ( ) . triggerEvent ( "click" ) ;
}
2010-02-07 15:12:14 +00:00
if ( item . options ( "checked" ) !== null && ( ! item . options ( "group" ) || ! item . options ( "checked" ) ) ) {
item . options ( {
checked : ! item . options ( "checked" )
} ) ;
2010-02-09 12:20:23 +00:00
Ox . Event . trigger ( "change_" + item . options ( "group" ) , {
2010-02-09 11:50:29 +00:00
id : item . options ( "id" ) ,
2010-02-07 15:12:14 +00:00
value : item . options ( "title" ) [ 0 ] // fixme: value or title?
} ) ;
2010-02-09 12:20:23 +00:00
} else {
2010-02-18 14:24:17 +00:00
Ox . Event . trigger ( "click_" + self . options . id , {
id : item . options ( "id" ) ,
title : item . options ( "title" ) [ 0 ]
} ) ;
2010-02-09 12:20:23 +00:00
Ox . Event . trigger ( "click_" + item . options ( "id" ) ) ;
2010-02-07 15:12:14 +00:00
}
if ( item . options ( "title" ) . length == 2 ) {
item . toggleTitle ( ) ;
}
}
2010-02-09 12:20:23 +00:00
that . hideMenu ( ) ;
2010-02-07 15:12:14 +00:00
}
function clickSelectedItem ( ) {
2010-02-09 05:43:36 +00:00
// called on key.enter
2010-02-04 09:50:45 +00:00
if ( self . options . selected > - 1 ) {
2010-02-07 15:12:14 +00:00
clickItem ( self . options . selected ) ;
2010-02-05 05:20:13 +00:00
} else {
that . hideMenu ( ) ;
2010-02-04 09:50:45 +00:00
}
}
2010-02-18 07:27:32 +00:00
function constructItems ( items ) {
that . items = [ ] ;
that . $content . empty ( ) ;
2010-02-18 14:24:17 +00:00
scrollMenuUp ( ) ;
2010-02-18 07:27:32 +00:00
$ . each ( items , function ( i , item ) {
var position ;
if ( item . id ) {
that . items . push ( new Ox . MenuItem ( $ . extend ( item , {
menu : that ,
position : position = that . items . length
} ) ) . data ( "position" , position ) . appendTo ( that . $content ) ) ; // fixme: jquery bug when passing {position: position}? does not return the object?;
if ( item . items ) {
that . submenus [ item . id ] = new Ox . Menu ( {
element : that . items [ position ] ,
id : Ox . toCamelCase ( self . options . id + "/" + item . id ) ,
items : item . items ,
mainmenu : self . options . mainmenu ,
offset : {
left : 0 ,
top : - 4
} ,
parent : that ,
side : "right" ,
size : self . options . size ,
} ) ;
}
} else {
that . $content . append ( constructSpace ( ) ) ;
that . $content . append ( constructLine ( ) ) ;
that . $content . append ( constructSpace ( ) ) ;
}
} ) ;
2010-02-18 14:24:17 +00:00
if ( ! that . is ( ":hidden" ) ) {
that . hideMenu ( ) ;
that . showMenu ( ) ;
}
2010-02-18 07:27:32 +00:00
}
2010-02-02 16:03:11 +00:00
function constructLine ( ) {
2010-02-03 12:12:21 +00:00
return $ ( "<tr>" ) . append (
2010-02-04 08:02:23 +00:00
$ ( "<td>" , {
"class" : "OxLine" ,
colspan : 5
2010-02-03 12:12:21 +00:00
} )
) ;
2010-02-02 16:03:11 +00:00
}
function constructScrollbar ( direction ) {
2010-02-05 14:59:24 +00:00
var interval ,
speed = direction == "up" ? - 1 : 1 ;
2010-02-03 12:12:21 +00:00
return $ ( "<div/>" , {
2010-02-05 05:20:13 +00:00
"class" : "OxScrollbar Ox" + Ox . toTitleCase ( direction ) ,
2010-02-03 12:12:21 +00:00
html : oxui . symbols [ "triangle_" + direction ] ,
click : function ( ) { // fixme: do we need to listen to click event?
return false ;
} ,
mousedown : function ( ) {
scrollSpeed = 2 ;
return false ;
} ,
mouseenter : function ( ) {
var $otherScrollbar = that . $scrollbars [ direction == "up" ? "down" : "up" ] ;
$ ( this ) . addClass ( "OxSelected" ) ;
if ( $otherScrollbar . is ( ":hidden" ) ) {
$otherScrollbar . show ( ) ;
that . $container . height ( that . $container . height ( ) - itemHeight ) ;
if ( direction == "down" ) {
that . $content . css ( {
top : - itemHeight + "px"
} ) ;
}
}
2010-02-05 14:59:24 +00:00
scrollMenu ( speed ) ;
2010-02-03 12:12:21 +00:00
interval = setInterval ( function ( ) {
2010-02-05 14:59:24 +00:00
scrollMenu ( speed ) ;
2010-02-03 12:12:21 +00:00
} , 100 ) ;
} ,
mouseleave : function ( ) {
$ ( this ) . removeClass ( "OxSelected" ) ;
clearInterval ( interval ) ;
} ,
mouseup : function ( ) {
scrollSpeed = 1 ;
return false ;
}
} ) ;
2010-02-02 16:03:11 +00:00
}
function constructSpace ( ) {
2010-02-03 12:12:21 +00:00
return $ ( "<tr>" ) . append (
2010-02-04 08:02:23 +00:00
$ ( "<td>" , {
"class" : "OxSpace" ,
colspan : 5
2010-02-03 12:12:21 +00:00
} )
) ;
2010-02-02 16:03:11 +00:00
}
function getElement ( id ) {
2010-02-05 09:13:03 +00:00
// fixme: needed?
2010-02-02 16:03:11 +00:00
return $ ( "#" + Ox . toCamelCase ( options . id + "/" + id ) ) ;
}
2010-02-05 05:20:13 +00:00
function isFirstEnabledItem ( ) {
var ret = true ;
$ . each ( that . items , function ( i , item ) {
if ( i < self . options . selected && ! item . options ( "disabled" ) ) {
return ret = false ;
}
} ) ;
return ret ;
}
function isLastEnabledItem ( ) {
var ret = true ;
$ . each ( that . items , function ( i , item ) {
if ( i > self . options . selected && ! item . options ( "disabled" ) ) {
return ret = false ;
}
} ) ;
return ret ;
}
2010-02-07 15:01:22 +00:00
function mouseenter ( ) {
that . gainFocus ( ) ;
}
function mouseleave ( ) {
if ( self . options . selected > - 1 && ! that . items [ self . options . selected ] . options ( "items" ) . length ) {
selectItem ( - 1 ) ;
}
}
function mousemove ( event ) {
var item ,
position ,
$target = $ ( event . target ) ;
if ( $target . is ( ".OxCell" ) ) {
position = $target . parent ( ) . data ( "position" ) ;
item = that . items [ position ] ;
if ( ! item . options ( "disabled" ) && position != self . options . selected ) {
selectItem ( position ) ;
}
} else {
mouseleave ( ) ;
}
}
2010-02-03 12:12:21 +00:00
function scrollMenu ( speed ) {
var containerHeight = that . $container . height ( ) ,
contentHeight = that . $content . height ( ) ,
top = parseInt ( that . $content . css ( "top" ) ) || 0 ,
min = containerHeight - contentHeight + itemHeight ,
max = 0 ;
top += speed * scrollSpeed * - itemHeight ;
if ( top <= min ) {
top = min ;
that . $scrollbars . down . hide ( ) . trigger ( "mouseleave" ) ;
2010-02-05 14:59:24 +00:00
that . $container . height ( containerHeight + itemHeight ) ;
that . items [ that . items . length - 1 ] . trigger ( "mouseover" ) ;
2010-02-03 12:12:21 +00:00
} else if ( top >= max - itemHeight ) {
top = max ;
that . $scrollbars . up . hide ( ) . trigger ( "mouseleave" ) ;
2010-02-05 14:59:24 +00:00
that . $container . height ( containerHeight + itemHeight ) ;
that . items [ 0 ] . trigger ( "mouseover" ) ;
2010-02-03 12:12:21 +00:00
}
that . $content . css ( {
top : top + "px"
} ) ;
2010-02-02 16:03:11 +00:00
}
2010-02-05 17:37:15 +00:00
function scrollMenuUp ( ) {
if ( that . $scrollbars . up . is ( ":visible" ) ) {
that . $content . css ( {
top : "0px"
} ) ;
that . $scrollbars . up . hide ( ) ;
if ( that . $scrollbars . down . is ( ":hidden" ) ) {
that . $scrollbars . down . show ( ) ;
} else {
that . $container . height ( that . $container . height ( ) + itemHeight ) ;
}
}
}
2010-02-07 15:01:22 +00:00
function selectItem ( position ) {
var item ;
if ( self . options . selected > - 1 ) {
2010-02-18 14:24:17 +00:00
item = that . items [ self . options . selected ]
item . removeClass ( "OxSelected" ) ;
2010-02-07 15:01:22 +00:00
}
if ( position > - 1 ) {
item = that . items [ position ] ;
$ . each ( that . submenus , function ( id , submenu ) {
if ( ! submenu . is ( ":hidden" ) ) {
submenu . hideMenu ( ) ;
return false ;
}
} ) ;
item . options ( "items" ) . length && that . submenus [ item . options ( "id" ) ] . showMenu ( ) ; // fixme: do we want to switch to this style?
item . addClass ( "OxSelected" ) ;
}
2010-02-18 09:11:47 +00:00
self . options . selected = position ;
2010-02-07 15:01:22 +00:00
}
2010-02-02 16:03:11 +00:00
function selectNextItem ( ) {
2010-02-05 15:26:23 +00:00
var offset ,
selected = self . options . selected ;
2010-02-05 05:20:13 +00:00
if ( ! isLastEnabledItem ( ) ) {
2010-02-05 17:37:15 +00:00
if ( selected == - 1 ) {
scrollMenuUp ( ) ;
} else {
2010-02-07 15:01:22 +00:00
that . items [ selected ] . removeClass ( "OxSelected" ) ;
2010-02-04 09:50:45 +00:00
}
2010-02-05 05:20:13 +00:00
do {
selected ++ ;
} while ( that . items [ selected ] . options ( "disabled" ) )
2010-02-07 15:01:22 +00:00
selectItem ( selected ) ;
2010-02-05 15:26:23 +00:00
offset = that . items [ selected ] . offset ( ) . top + itemHeight -
that . $container . offset ( ) . top - that . $container . height ( ) ;
if ( offset > 0 ) {
if ( that . $scrollbars . up . is ( ":hidden" ) ) {
that . $scrollbars . up . show ( ) ;
that . $container . height ( that . $container . height ( ) - itemHeight ) ;
offset += itemHeight ;
}
if ( selected == that . items . length - 1 ) {
that . $scrollbars . down . hide ( ) ;
that . $container . height ( that . $container . height ( ) + itemHeight ) ;
} else {
that . $content . css ( {
top : ( ( parseInt ( that . $content . css ( "top" ) ) || 0 ) - offset ) + "px"
} ) ;
}
}
2010-02-04 09:50:45 +00:00
}
2010-02-02 16:03:11 +00:00
}
function selectPreviousItem ( ) {
2010-02-05 15:26:23 +00:00
var offset ,
selected = self . options . selected ;
2010-02-05 17:37:15 +00:00
if ( selected > - 1 ) {
if ( ! isFirstEnabledItem ( ) ) {
2010-02-07 15:01:22 +00:00
that . items [ selected ] . removeClass ( "OxSelected" ) ;
2010-02-05 17:37:15 +00:00
do {
selected -- ;
} while ( that . items [ selected ] . options ( "disabled" ) )
2010-02-07 15:01:22 +00:00
selectItem ( selected ) ;
2010-02-05 15:26:23 +00:00
}
2010-02-05 17:37:15 +00:00
offset = that . items [ selected ] . offset ( ) . top - that . $container . offset ( ) . top ;
if ( offset < 0 ) {
if ( that . $scrollbars . down . is ( ":hidden" ) ) {
that . $scrollbars . down . show ( ) ;
that . $container . height ( that . $container . height ( ) - itemHeight ) ;
}
if ( selected == 0 ) {
that . $scrollbars . up . hide ( ) ;
that . $container . height ( that . $container . height ( ) + itemHeight ) ;
}
that . $content . css ( {
top : ( ( parseInt ( that . $content . css ( "top" ) ) || 0 ) - offset ) + "px"
} ) ;
2010-02-05 15:26:23 +00:00
}
}
2010-02-02 16:03:11 +00:00
}
2010-02-05 09:13:03 +00:00
function selectSubmenu ( ) {
2010-02-05 17:37:15 +00:00
if ( self . options . selected > - 1 ) {
var submenu = that . submenus [ that . items [ self . options . selected ] . options ( "id" ) ] ;
if ( submenu && submenu . hasEnabledItems ( ) ) {
submenu . gainFocus ( ) ;
submenu . selectFirstItem ( ) ;
2010-02-08 09:35:24 +00:00
} else if ( self . options . mainmenu ) {
self . options . mainmenu . selectNextMenu ( ) ;
}
} else if ( self . options . mainmenu ) {
self . options . mainmenu . selectNextMenu ( ) ;
2010-02-05 09:13:03 +00:00
}
}
function selectSupermenu ( ) {
if ( self . options . parent ) {
that . items [ self . options . selected ] . trigger ( "mouseleave" ) ;
self . options . parent . gainFocus ( ) ;
2010-02-08 09:35:24 +00:00
} else if ( self . options . mainmenu ) {
self . options . mainmenu . selectPreviousMenu ( ) ;
2010-02-05 09:13:03 +00:00
}
}
self . onChange = function ( key , value ) {
2010-02-18 07:27:32 +00:00
if ( key == "items" ) {
constructItems ( value ) ;
2010-02-18 09:11:47 +00:00
} else if ( key == "selected" ) {
selectItem ( value ) ;
2010-02-18 07:27:32 +00:00
}
2010-02-05 09:13:03 +00:00
}
2010-02-20 03:42:03 +00:00
that . addItem = function ( item , position ) {
} ;
2010-02-19 16:13:22 +00:00
that . addItemAfter = function ( item , id ) {
2010-02-08 10:17:00 +00:00
} ;
2010-02-19 16:13:22 +00:00
that . addItemBefore = function ( item , id ) {
2010-02-08 10:17:00 +00:00
} ;
2010-02-10 16:37:26 +00:00
that . getItem = function ( id ) {
2010-02-19 16:13:22 +00:00
var item ;
$ . each ( this . items , function ( i , v ) {
if ( v . options ( "id" ) == id ) {
item = v ;
2010-02-10 20:02:58 +00:00
return false ;
}
} ) ;
2010-02-19 16:13:22 +00:00
return item ;
2010-02-10 16:37:26 +00:00
} ;
2010-02-05 09:13:03 +00:00
that . hasEnabledItems = function ( ) {
var ret = false ;
$ . each ( that . items , function ( i , item ) {
if ( ! item . options ( "disabled" ) ) {
return ret = true ;
}
} ) ;
return ret ;
} ;
2010-02-02 16:03:11 +00:00
that . hideMenu = function ( ) {
2010-07-02 13:06:13 +00:00
if ( that . is ( ":hidden" ) ) {
return ;
}
2010-02-04 08:02:23 +00:00
$ . each ( that . submenus , function ( i , submenu ) {
2010-02-05 14:59:24 +00:00
if ( submenu . is ( ":visible" ) ) {
2010-02-04 08:02:23 +00:00
submenu . hideMenu ( ) ;
2010-02-03 12:12:21 +00:00
return false ;
}
} ) ;
2010-02-08 09:39:15 +00:00
selectItem ( - 1 ) ;
2010-02-05 17:37:15 +00:00
scrollMenuUp ( ) ;
2010-02-18 14:24:17 +00:00
that . $scrollbars . up . is ( ":visible" ) && that . $scrollbars . up . hide ( ) ;
that . $scrollbars . down . is ( ":visible" ) && that . $scrollbars . down . hide ( ) ;
//that.$scrollbars.down.hide();
2010-02-05 15:42:52 +00:00
if ( self . options . parent ) {
self . options . element . removeClass ( "OxSelected" ) ;
}
2010-02-09 05:43:36 +00:00
that . hide ( )
. loseFocus ( )
. unbindEvent ( {
key _up : selectPreviousItem ,
key _down : selectNextItem ,
key _left : selectSupermenu ,
key _right : selectSubmenu ,
key _escape : that . hideMenu ,
key _enter : clickItem
} )
. triggerEvent ( "hide" ) ;
that . $layer . hide ( ) ;
2010-02-05 09:13:03 +00:00
$document . unbind ( "click" , click ) ;
2010-02-08 09:35:24 +00:00
return that ;
//that.triggerEvent("hide");
2010-02-05 09:13:03 +00:00
} ;
2010-02-08 10:17:00 +00:00
that . removeItem = function ( ) {
} ;
2010-02-05 09:13:03 +00:00
that . selectFirstItem = function ( ) {
selectNextItem ( ) ;
2010-02-02 16:03:11 +00:00
} ;
that . showMenu = function ( ) {
2010-07-02 13:06:13 +00:00
if ( ! that . is ( ":hidden" ) ) {
return ;
}
2010-02-09 05:43:36 +00:00
if ( ! self . options . parent && ! that . $layer . parent ( ) . length ) {
that . $layer . appendTo ( $body ) ;
}
2010-02-04 08:02:23 +00:00
that . parent ( ) . length || that . appendTo ( $body ) ;
2010-02-18 14:42:53 +00:00
that . css ( {
left : "-1000px" ,
top : "-1000px" ,
} ) . show ( ) ;
2010-02-04 08:02:23 +00:00
var offset = self . options . element . offset ( ) ,
width = self . options . element . outerWidth ( ) ,
height = self . options . element . outerHeight ( ) ,
left = offset . left + self . options . offset . left + ( self . options . side == "bottom" ? 0 : width ) ,
top = offset . top + self . options . offset . top + ( self . options . side == "bottom" ? height : 0 ) ,
2010-02-18 14:42:53 +00:00
menuHeight = that . $content . outerHeight ( ) ; // fixme: why is outerHeight 0 when hidden?
2010-06-29 13:10:13 +00:00
menuMaxHeight = Math . floor ( $window . height ( ) - top - 16 ) ;
2010-02-05 17:37:15 +00:00
if ( self . options . parent ) {
2010-02-18 14:24:17 +00:00
if ( menuHeight > menuMaxHeight ) {
top = Ox . limit ( top - menuHeight + menuMaxHeight , self . options . parent . offset ( ) . top , top ) ;
menuMaxHeight = Math . floor ( $window . height ( ) - top - 16 ) ;
2010-02-05 17:37:15 +00:00
}
}
2010-02-18 14:42:53 +00:00
that . css ( {
left : left + "px" ,
top : top + "px"
} ) ;
2010-02-18 14:24:17 +00:00
if ( menuHeight > menuMaxHeight ) {
that . $container . height ( menuMaxHeight - itemHeight - 8 ) ; // margin
2010-02-03 12:12:21 +00:00
that . $scrollbars . down . show ( ) ;
2010-02-18 14:24:17 +00:00
} else {
that . $container . height ( menuHeight ) ;
2010-02-03 12:12:21 +00:00
}
2010-02-18 14:42:53 +00:00
! self . options . parent && that . gainFocus ( ) ;
2010-02-05 09:13:03 +00:00
that . bindEvent ( {
key _up : selectPreviousItem ,
key _down : selectNextItem ,
key _left : selectSupermenu ,
key _right : selectSubmenu ,
2010-02-09 05:43:36 +00:00
key _escape : that . hideMenu ,
2010-02-07 15:12:14 +00:00
key _enter : clickSelectedItem
2010-02-05 09:13:03 +00:00
} ) ;
2010-02-04 09:50:45 +00:00
setTimeout ( function ( ) {
2010-02-05 09:13:03 +00:00
$document . bind ( "click" , click ) ;
2010-02-04 09:50:45 +00:00
} , 100 ) ;
2010-02-08 09:35:24 +00:00
return that ;
//that.triggerEvent("show");
2010-02-02 16:03:11 +00:00
} ;
2010-02-03 12:12:21 +00:00
that . toggleMenu = function ( ) {
that . is ( ":hidden" ) ? that . showMenu ( ) : that . hideMenu ( ) ;
2010-02-02 16:03:11 +00:00
} ;
return that ;
2010-02-03 12:12:21 +00:00
} ;
2010-02-02 16:03:11 +00:00
Ox . MenuItem = function ( options , self ) {
var self = self || { } ,
2010-02-03 12:12:21 +00:00
that = new Ox . Element ( "tr" , self )
2010-02-02 16:03:11 +00:00
. defaults ( {
bind : [ ] ,
2010-02-04 08:02:23 +00:00
checked : null ,
2010-02-02 16:03:11 +00:00
disabled : false ,
group : "" ,
icon : "" ,
id : "" ,
2010-02-05 05:20:13 +00:00
items : [ ] ,
2010-02-03 12:12:21 +00:00
keyboard : "" ,
menu : null , // fixme: is passing the menu to 100s of menu items really memory-neutral?
2010-02-04 09:50:45 +00:00
position : 0 ,
2010-02-03 12:12:21 +00:00
title : [ ] ,
} )
. options ( $ . extend ( options , {
keyboard : parseKeyboard ( options . keyboard || self . defaults . keyboard ) ,
title : Ox . makeArray ( options . title || self . defaults . title )
} ) )
2010-02-04 08:02:23 +00:00
. addClass ( "OxItem" + ( self . options . disabled ? " OxDisabled" : "" ) )
2010-02-03 12:12:21 +00:00
. attr ( {
2010-02-07 15:01:22 +00:00
id : Ox . toCamelCase ( self . options . menu . options ( "id" ) + "/" + self . options . id )
2010-02-03 12:12:21 +00:00
} )
2010-02-07 15:01:22 +00:00
. data ( "group" , self . options . group ) ; // fixme: why?
2010-02-03 12:12:21 +00:00
// construct
that . append (
that . $status = $ ( "<td>" , {
2010-02-04 08:02:23 +00:00
"class" : "OxCell OxStatus" ,
2010-02-03 12:12:21 +00:00
html : self . options . checked ? oxui . symbols . check : ""
} )
)
. append (
that . $icon = $ ( "<td>" , {
2010-02-04 08:02:23 +00:00
"class" : "OxCell OxIcon"
2010-02-02 16:03:11 +00:00
} )
2010-02-03 12:12:21 +00:00
. append ( self . options . icon ?
$ ( "<img>" , {
2010-02-04 08:02:23 +00:00
src : self . options . icon
2010-02-03 12:12:21 +00:00
} ) : null
)
)
. append (
that . $title = $ ( "<td>" , {
2010-02-04 08:02:23 +00:00
"class" : "OxCell OxTitle" ,
2010-02-03 12:12:21 +00:00
html : self . options . title [ 0 ]
} )
)
. append (
$ ( "<td>" , {
2010-02-04 08:02:23 +00:00
"class" : "OxCell OxModifiers" ,
2010-02-03 12:12:21 +00:00
html : $ . map ( self . options . keyboard . modifiers , function ( modifier ) {
2010-02-08 09:45:48 +00:00
return oxui . symbols [ modifier ] ;
2010-02-03 12:12:21 +00:00
} ) . join ( "" )
} )
)
. append (
$ ( "<td>" , {
2010-02-05 05:20:13 +00:00
"class" : "OxCell Ox" + ( self . options . items . length ? "Submenu" : "Key" ) ,
html : self . options . items . length ? oxui . symbols . triangle _right :
2010-02-08 09:45:48 +00:00
oxui . symbols [ self . options . keyboard . key ] ||
self . options . keyboard . key . toUpperCase ( )
2010-02-03 12:12:21 +00:00
} )
2010-02-05 05:20:13 +00:00
) ;
2010-02-03 12:12:21 +00:00
function parseKeyboard ( str ) {
2010-02-18 14:24:17 +00:00
var modifiers = str . split ( " " ) ,
2010-02-03 12:12:21 +00:00
key = modifiers . pop ( ) ;
return {
modifiers : modifiers ,
key : key
}
}
self . onChange = function ( key , value ) {
if ( key == "checked" ) {
2010-02-04 08:02:23 +00:00
if ( value && self . options . group ) {
$ . each ( self . options . menu . items , function ( i , item ) {
if (
item . options ( "id" ) != self . options . id &&
item . options ( "group" ) == self . options . group &&
item . options ( "checked" )
) {
item . options ( {
checked : false
} ) ;
return false ;
}
} ) ;
}
that . $status . html ( value ? oxui . symbols . check : "" )
2010-02-03 12:12:21 +00:00
} else if ( key == "disabled" ) {
that . toggleClass ( "disabled" ) ; // fixme: this will only work if onChange is only invoked on actual change
2010-02-10 16:37:26 +00:00
} else if ( key == "title" ) {
2010-02-03 12:12:21 +00:00
}
}
2010-02-10 16:37:26 +00:00
that . toggle = function ( ) {
// toggle id and title
} ;
2010-02-03 12:12:21 +00:00
that . toggleChecked = function ( ) {
} ;
that . toggleDisabled = function ( ) {
} ;
that . toggleTitle = function ( ) {
that . options ( {
title : that . $title . html ( ) == self . options . title [ 0 ] ?
self . options . title [ 1 ] : self . options . title [ 0 ]
2010-02-10 16:37:26 +00:00
} ) ;
2010-02-03 12:12:21 +00:00
} ;
2010-02-02 16:03:11 +00:00
return that ;
2010-02-03 12:12:21 +00:00
} ;
2010-02-02 16:03:11 +00:00
/ *
=== === === === === === === === === === === === === === === === === === === === === === === === === =
2010-01-07 20:21:07 +00:00
Panels
=== === === === === === === === === === === === === === === === === === === === === === === === === =
* /
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . CollapsePanel
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
Ox . CollapsePanel = function ( options , self ) {
var self = self || { } ,
that = new Ox . Panel ( { } , self )
. defaults ( {
collapsed : false ,
size : 20 ,
title : ""
} )
. options ( options )
. addClass ( "OxCollapsePanel" ) ,
value = self . options . collapsed ?
[ "expand" , "collapsed" ] : [ "collapse" , "expand" ] ,
$titlebar = new Ox . Bar ( {
orientation : "horizontal" ,
size : self . options . size ,
} )
. dblclick ( dblclickTitlebar )
. appendTo ( that ) ,
$switch = new Ox . Button ( {
style : "symbol" ,
type : "image" ,
value : value ,
} )
. click ( toggleCollapsed )
. appendTo ( $titlebar ) ,
$title = new Ox . Element ( )
. addClass ( "OxTitle" )
. html ( self . options . title /*.toUpperCase()*/ )
. appendTo ( $titlebar ) ;
that . $content = new Ox . Element ( )
. addClass ( "OxContent" )
. appendTo ( that ) ;
// fixme: doesn't work, content still empty
// need to hide it if collapsed
if ( self . options . collapsed ) {
that . $content . css ( {
marginTop : - that . $content . height ( ) + "px"
} ) ;
}
function dblclickTitlebar ( e ) {
if ( ! $ ( e . target ) . hasClass ( "OxButton" ) ) {
toggleCollapsed ( ) ;
}
}
function toggleCollapsed ( ) {
that . options ( {
collapsed : ! self . options . collapsed
} ) ;
var top = self . options . collapsed ?
- that . $content . height ( ) : 0 ;
that . $content . animate ( {
marginTop : top + "px"
} , 200 ) ;
}
self . onChange = function ( option , value ) {
if ( option == "collapsed" ) {
$switch . options ( {
value : value ? "expand" : "collapse"
} ) ;
} else if ( option == "title" ) {
$title . html ( self . options . title ) ;
}
} ;
return that ;
} ;
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . Panel
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
Ox . Panel = function ( options , self ) {
var self = self || { } ,
that = new Ox . Element ( { } , self )
. addClass ( "OxPanel" ) ;
return that ;
} ;
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . SplitPanel
options :
orientation : "" "horizontal" or "vertical"
elements : [ {
element , Ox Element
size : 0 , size in px
resizable : false resizable or not
} ]
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
Ox . SplitPanel = function ( options , self ) {
var self = self || { } ,
that = new Ox . Element ( { } , self )
. defaults ( {
elements : [ ] ,
orientation : "horizontal"
} )
. options ( options || { } )
. addClass ( "OxSplitPanel" ) ,
length = self . options . elements . length ,
dimensions = oxui . getDimensions ( self . options . orientation ) ,
edges = oxui . getEdges ( self . options . orientation ) ;
$ . each ( self . options . elements , function ( i , v ) {
var element = v . element
. css ( {
position : "absolute" // fixme: this can go into a class
} )
. css ( edges [ 2 ] , 0 )
. css ( edges [ 3 ] , 0 ) ;
if ( v . size != undefined ) {
element . css ( dimensions [ 0 ] , v . size + "px" ) ;
}
if ( i == 0 ) {
element . css ( edges [ 0 ] , 0 ) ;
if ( v . size == undefined ) {
element . css (
edges [ 1 ] ,
( self . options . elements [ 1 ] . size + ( length == 3 ? self . options . elements [ 2 ] . size : 0 ) ) + "px"
) ;
}
} else if ( i == 1 ) {
if ( self . options . elements [ 0 ] . size != undefined ) {
element . css ( edges [ 0 ] , self . options . elements [ 0 ] . size + "px" ) ;
}
if ( self . options . elements [ 0 ] . size == undefined || v . size == undefined ) {
element . css (
edges [ 1 ] ,
( length == 3 ? self . options . elements [ 2 ] . size : 0 ) + "px"
) ;
}
} else {
element . css ( edges [ 1 ] , 0 ) ;
if ( v . size == undefined ) {
element . css (
edges [ 0 ] ,
( self . options . elements [ 0 ] . size + self . options . elements [ 1 ] . size ) + "px"
) ;
}
}
element . appendTo ( that ) ;
//that.append(element)
} ) ;
return that ;
} ;
2010-02-10 16:37:26 +00:00
Ox . TabPanel = function ( options , self ) {
} ;
2010-02-20 08:29:03 +00:00
/ *
=== === === === === === === === === === === === === === === === === === === === === === === === === =
Requests
=== === === === === === === === === === === === === === === === === === === === === === === === === =
* /
2010-01-27 12:30:00 +00:00
2010-02-20 08:29:03 +00:00
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . LoadingIcon
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2010-01-27 12:30:00 +00:00
2010-02-20 08:29:03 +00:00
Ox . LoadingIcon = function ( options , self ) {
var self = self || { } ,
that = new Ox . Element ( "img" , self )
. defaults ( {
size : "medium"
} )
. options ( options || { } )
. attr ( {
2010-02-20 10:34:50 +00:00
src : oxui . path + "/png/ox.ui." + Ox . theme ( ) + "/loading.png"
2010-02-20 08:29:03 +00:00
} )
. addClass (
"OxLoadingIcon Ox" + Ox . toTitleCase ( self . options . size )
) ;
self . deg = 0 ;
2010-07-01 23:51:08 +00:00
self . interval = 0 ;
self . isRunning = false ;
function clear ( ) {
clearInterval ( self . interval ) ;
self . deg = 0 ;
self . interval = 0 ;
update ( ) ;
}
2010-02-20 08:29:03 +00:00
function update ( ) {
that . css ( {
MozTransform : "rotate(" + self . deg + "deg)" ,
WebkitTransform : "rotate(" + self . deg + "deg)"
} ) ;
}
that . start = function ( ) {
2010-07-01 23:51:08 +00:00
self . isRunning = true ;
clear ( ) ;
that . animate ( {
opacity : 1
} , 250 ) ;
self . interval = setInterval ( function ( ) {
self . deg = ( self . deg + 30 ) % 360 ;
update ( ) ;
} , 83 ) ;
2010-02-20 08:29:03 +00:00
} ;
that . stop = function ( ) {
2010-07-01 23:51:08 +00:00
that . animate ( {
opacity : 0
} , 250 , function ( ) {
! self . isRunning && clear ( ) ;
self . isRunning = false ;
} ) ;
2010-02-20 08:29:03 +00:00
}
return that ;
}
/ *
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
Ox . Progressbar
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2010-01-27 12:30:00 +00:00
2010-05-05 12:21:18 +00:00
} ) ( ) ;