diff --git a/.project b/.project new file mode 100644 index 0000000..2f94689 --- /dev/null +++ b/.project @@ -0,0 +1,17 @@ + + + mvc + + + + + + jasko.tim.lisp.lispBuilder + + + + + + jasko.tim.lisp.lispNature + + diff --git a/src/controller.lisp b/src/controller.lisp new file mode 100644 index 0000000..9f04c34 --- /dev/null +++ b/src/controller.lisp @@ -0,0 +1,133 @@ +;;;; Created on 2011-04-09 15:41:36 +(in-package :mvc) +(defparameter *view-types* + (list (cons :html 'html-view) + (cons :partial 'template-view) + (cons :xml 'template-view) + (cons :json 'json-view))) +(defparameter *action* nil) +(defparameter *around-list* nil) +(defmacro defcontroller + (name &rest params + &key + options + view-type + view-layout + &allow-other-keys) + "Define packeage with given name. TODO define some variables" + (declare (ignore params)) + (let ((defpackage-options (remove-if #'(lambda (opt) + (member (car opt) + '(:export))) + (remove-if-not #'listp options)))) + `(eval-when (:compile-toplevel :load-toplevel :execute) + (let ((package (defpackage ,name ,@defpackage-options (:use :cl :mvc)))) + (push package (default-controllers)) + (defparameter-in-package *mapper* package (default-mapper)) + (defun-in-package index package ()) + (defparameter-in-package *default-action-name* package "index") + (defparameter-in-package *filters* package (list :before nil :after nil :around nil)) + (defparameter-in-package *view-type* package ,(if view-type `',(cdr (assoc view-type *view-types*)) `*default-view-type*)) + ;(defparameter-in-package *view-name* package ,@(if view-name view-type *default-view-name*)) + (defparameter-in-package *view-layout* package ,(if view-layout view-layout)) + package)))) +(defparameter *default-controller* (defcontroller "Index")) +(defun process-controller (controller action bindings) + (init-context controller action bindings) + (let ((*package* controller)) + (render-view (apply-with-filters action)))) +(defmacro make-view (&optional params &key name layout type) + (let* ((view-type (or (cdr (assoc type *view-types*)) + (cdr (assoc (get *action* :view-type) *view-types*)) + (find-symbol-value *view-type*))) + (view-name (or name + (get *action* :view-name) + (when (symbolp *action*) (symbol-name *action*)))) + (view-layout (if (or (not (eql 'html-view view-type)) (ajax-request-p)) + nil + (or layout + (get *action* :view-layout) + (find-symbol-value *view-layout*) + (package-name *package*))))) + `(make-instance ',view-type + ,@(if (and view-name (not (eql view-type 'json-view))) `(:name ,view-name)) + ,@(if (and view-layout (not (eql view-type 'json-view))) `(:layout ,view-layout)) + :params ,params))) +(defun init-context (controller action bindings) + (declare (ignore action)) + (defparameter-in-package *session* controller hunchentoot:*session*) + (defparameter-in-package *cookies-in* controller (hunchentoot:cookies-in*)) + (defparameter-in-package *cookies-out* controller (hunchentoot:cookies-out*)) + (defparameter-in-package *route-params* controller bindings)) +(defun apply-with-filters (action) + (let ((*action* action) + (around (get-filters *package* action :around)) + (before (get-filters *package* action :before)) + (after (get-filters *package* action :after))) + (flet ((apply-filters (filters) + (mapcar #'funcall filters))) + (apply-filters before) + (let ((res (apply-around around))) + (apply-filters after) + res)))) +(defmethod apply-around ((around list)) + (let ((*around-list* (rest around)) + (current (first around))) + (typecase current + (function (funcall current)) + (null (apply *action* (get-action-params))) + (t (call-next-filter))))) +(defun get-action-params () + (find-symbol-value *route-params*)) +(defun call-next-filter () + (apply-around *around-list*)) +(defun get-filters (controller action keyword &aux (action-filter (get action keyword))) + (flet ((is-for-action (filter action) + (if (find action (filter-actions filter)) + (not (slot-value filter 'inverse-actions)) + (slot-value filter 'inverse-actions)))) + (concatenate + 'list + (remove-if-not + #'functionp + (mapcar #'filter-func + (remove-if-not + (lambda (filter) + (is-for-action filter action)) + (getf (find-symbol-value *filters* controller) keyword)))) + (to-list action-filter)))) +(defclass filter () + ((function :initarg :function :accessor filter-func) + (actions :initform nil :accessor filter-actions) + (inverse-actions :initform t))) +(defmethod initialize-instance :after ((f filter) &key only except) + (if only + (let ((only (to-list only))) + (setf (slot-value f 'inverse-actions) nil) + (setf (filter-actions f) only)) + (when except + (let ((except (to-list except))) + (setf (filter-actions f) except))))) +(defun defilter (func keyword &key only except) + (push (make-instance 'filter :function func :only only :except except) + (getf (symbol-value (find-symbol "*FILTERS*")) keyword))) +(defmacro defaction (name (&rest variables) + (&key + (method :any) + before-filter + after-filter + around-filter + (view-type 'html-view) + view-name + view-layout) + &body body) + `(let ((action (defun ,name (,@(if variables `(&key ,@variables &allow-other-keys))) ,@body))) + (setf (symbol-plist action) + (list :before-filter ,before-filter + :after-filter ,after-filter + :around-filter ,around-filter + :view-type ',view-type + :view-name ,view-name + :method ,method + :view-layout ,view-layout)) + action)) diff --git a/src/core.lisp b/src/core.lisp new file mode 100644 index 0000000..5fab7e3 --- /dev/null +++ b/src/core.lisp @@ -0,0 +1,55 @@ +;;;; Created on 2011-04-12 14:55:49 +(defpackage :core + (:use :cl :routes :hunchentoot :cl-annot)) +(in-package :core) +(annot:enable-annot-syntax) +(defclass mvc-application () + ((mapper :initform (make-instance 'routes:mapper)) + (controllers :initform nil) + (routes :initform nil :accessor app-routes))) +@export +(defparameter *acceptors* nil) +(defparameter *DEFAULT-HOST-REDIRECT* nil) +@export +(defparameter *default-controller-name* "index") +@export +(defparameter *default-action-name* "index") +@export +(defparameter *default-view-type* 'html-view) +@export +(defparameter *mvc-application* (make-instance 'mvc-application)) +@export +(defmacro default-mapper () + `(slot-value *mvc-application* 'mapper)) +@export +(defmacro default-controllers () + `(slot-value *mvc-application* 'controllers)) +@export +(defmacro default-routes () + `(app-routes *mvc-application*)) +@export +(defun not-found-if-not (cond) + "Redirect to 404 page if cond" + (or cond + (progn + (setf (hunchentoot:return-code*) + hunchentoot:+HTTP-NOT-FOUND+) + (hunchentoot:abort-request-handler)))) +@export +(defun server-error (&optional err) + (setf (hunchentoot:return-code*) + hunchentoot:+http-internal-server-error+) + (hunchentoot:abort-request-handler)) +@export +(defun default-if (cond) + "Redirect to default page page if cond" + (when cond + (hunchentoot:redirect + (hunchentoot:request-uri*) + :host *default-host-redirect*))) +@export +(defun ajax-request-p () + (when (boundp 'hunchentoot:*request*) + (hunchentoot:header-in* "X-Requested-With"))) + + diff --git a/src/debug.lisp b/src/debug.lisp new file mode 100644 index 0000000..757cf46 --- /dev/null +++ b/src/debug.lisp @@ -0,0 +1,43 @@ +;;;; Created on 2011-05-26 21:56:39 +(in-package :mvc) + +(defun kill-all-debugging-threads () + "Used for destroy all debugging threads" + (bt:with-lock-held (*debugging-threads-lock*) + (dolist (thread *debugging-threads*) + (when (ignore-errors + (bt:destroy-thread thread) + t) + (setf *debugging-threads* + (remove thread *debugging-threads*)))))) + +(defun debug-mode-on () + "Enable debug mode" + (setf *catch-errors-p* nil)) + +(defun debug-mode-off (&optional (kill-debugging-threads t)) + "Turn off debug mode" + (setf *catch-errors-p* t) + (when kill-debugging-threads + (kill-all-debugging-threads))) + +(defun maybe-invoke-debugger (condition) + (cond + ((null *catch-errors-p*) + (when (< (length *debugging-threads*) *max-debugging-threads*) + (let ((thread (bt:current-thread))) + (bt:with-lock-held (*debugging-threads-lock*) + (push thread *debugging-threads*)) + (unwind-protect + (invoke-debugger condition) + (bt:with-lock-held (*debugging-threads-lock*) + (setf *debugging-threads* + (remove thread *debugging-threads*))))))) + (t (hunchentoot:maybe-invoke-debugger condition)))) + +(defun after-close-swank-connection (connection) + "Turns off debug mode and destroy debugging threads after closing the connection with the swank-server" + (declare (ignore connection)) + (debug-mode-off t)) + +#+swank (swank::add-hook swank::*connection-closed-hook* 'after-close-swank-connection) \ No newline at end of file diff --git a/src/defpackage.lisp b/src/defpackage.lisp new file mode 100644 index 0000000..ec7cb1e --- /dev/null +++ b/src/defpackage.lisp @@ -0,0 +1,28 @@ +;;;; 2011-04-05 20:32:08 +(in-package :common-lisp-user) +(defpackage :mvc + (:nicknames :mvc) + (:use :cl :iterate :orm :view :core :routing) + (:export + #:fname + #:start + #:stop + #:reset + #:defilter + #:defcontroller + #:defroute + #:defaction + #:make-view + #:render-template + :table + :deftable + :create-instance + :fetch + :record + :save + :save-slots + :destroy + :destroy-instance + :destroy-records + )) + diff --git a/src/dispatcher.lisp b/src/dispatcher.lisp new file mode 100644 index 0000000..5bbc92e --- /dev/null +++ b/src/dispatcher.lisp @@ -0,0 +1,68 @@ +;;;; Created on 2011-04-10 17:19:02 +(in-package :mvc) +(defclass mvc-generic-acceptor () ()) +(defclass mvc-acceptor (hunchentoot:acceptor mvc-generic-acceptor) ()) +(defclass mvc-ssl-acceptor (hunchentoot:ssl-acceptor mvc-generic-acceptor) ()) +(defun dispatch-request (acceptor request) + "Parse route and execute its processing" + (declare (ignore acceptor)) + (let ((mapper + (slot-value *mvc-application* 'core::mapper)) + (hunchentoot:*request* request)) + (not-found-if-not mapper) + (handler-case + (multiple-value-bind (route bindings) (routes:match mapper (hunchentoot:request-uri*)) + (not-found-if-not route) + (process-route route (alexandria:alist-plist bindings))) + (condition (err) (format nil "~a" err))))) +(defgeneric process-route (route bindings) + (:documentation "Select controller. Init controller context and call action")) +(defparameter *bindings* nil) +(defparameter *route* nil) +(defmethod process-route + ((route route) bindings &aux (bindings (apply-defaults bindings route))) + (let* ((controller + (not-found-if-not + (find-package (string-upcase + (or (getf bindings :controller) + (route-controller route)))))) + (action + (find-symbol (string-upcase + (or (nil-if-empty (getf bindings :action)) + (route-action route))) + controller)) + (*route* route)) + (not-found-if-not (fboundp action)) + (process-controller controller action bindings))) +(defun apply-defaults (bindings route) + (concatenate 'list bindings (route-defaults route))) +(defun start (&key + ssl-certificate-file + ssl-privatekey-file + ssl-privatekey-password + (port (if ssl-certificate-file 443 80))) + "Start mvc acceptor" + (unless (find port *acceptors* :key #'hunchentoot:acceptor-port) + (push (hunchentoot:start + (if ssl-certificate-file + (make-instance 'mvc-ssl-acceptor + :ssl-certificate-file ssl-certificate-file + :ssl-privatekey-file ssl-privatekey-file + :ssl-privatekey-password ssl-privatekey-password + :port port) + (make-instance 'mvc-acceptor + :port port))) + *acceptors*))) +(defun stop () + (mapcar #'hunchentoot:stop *acceptors*) + (setq *acceptors* nil)) +(defun reset () + (stop) + (setf (default-routes) nil) + (routes:reset-mapper (default-mapper))) +(setf hunchentoot:*hunchentoot-default-external-format* (flex:make-external-format :utf-8 :eol-style :lf)) +(defmethod hunchentoot:handle-request ((acceptor mvc-acceptor) request) + (setf (hunchentoot:reply-external-format*) (flex:make-external-format :utf-8 :eol-style :lf)) + (setf (hunchentoot:content-type*) "text/html; charset=utf-8") + (dispatch-request acceptor request)) + diff --git a/src/extensions.lisp b/src/extensions.lisp new file mode 100644 index 0000000..9d31a81 --- /dev/null +++ b/src/extensions.lisp @@ -0,0 +1,49 @@ +;;;; Created on 2011-04-09 21:43:20 +(in-package :mvc) +(defmacro defparameter-in-package + (name + package + &optional val + &aux + (n (typecase name + (string (string-upcase name)) + (symbol (symbol-name name)))) + (pcg (typecase package + (string (find-package package)) + (symbol package) + (package package)))) + "Define parameter for package." + `(let* ((s (intern ,n ,pcg))) + (setf (symbol-value s) ,val))) +(defmacro find-symbol-value (name + &optional package + &aux + (n (typecase name + (null *package*) + (string (string-upcase name)) + (symbol (symbol-name name))))) + `(let ((pcg ,package)) + (symbol-value (find-symbol ,n (typecase pcg + (string (find-package pcg)) + (symbol pcg) + (package pcg)))))) +(defmacro defun-in-package + (name + package + (&rest args) + &body body + &aux + (n (typecase name + (string (string-upcase name)) + (symbol (symbol-name name)))) + (pcg (typecase package + (string (find-package package)) + (symbol package) + (package package)))) + "Define function for package." + `(let* ((s (intern ,n ,pcg))) + (setf (symbol-function s) #'(lambda ,args ,@body)))) +(defun to-list (x) + (if (listp x) x (list x))) + + \ No newline at end of file diff --git a/src/mvc.asd b/src/mvc.asd new file mode 100644 index 0000000..fb5efcd --- /dev/null +++ b/src/mvc.asd @@ -0,0 +1,33 @@ +;;;; 2011-04-05 20:32:08 +;;;; +;;;; Think of this as your project file. +;;;; Keep it up to date, and you can reload your project easily +;;;; by right-clicking on it and selecting "Load Project" + +(defpackage #:mvc-asd + (:use :cl :asdf)) + +(in-package :mvc-asd) + +(defsystem mvc + :name "mvc" + :version "0.1" + :serial t + :components ((:module "orm" + :components ((:file "record") + (:file "table" :depends-on ("record")) + (:file "defpackage" :depends-on ("table")))) + (:file "core") + (:file "routing" :depends-on ("core")) + (:module "view" + :components ((:file "defpackage") + (:file "view" :depends-on ("defpackage")) + (:file "template" :depends-on ("defpackage")) + (:file "render" :depends-on ("defpackage" "view" "template"))) + :depends-on ("core" "routing")) + (:file "defpackage" :depends-on ("core" "routing")) + ;(:file "debug" :depends-on ("defpackage")) + (:file "extensions" :depends-on ("defpackage")) + (:file "controller" :depends-on ("defpackage" "core" "extensions" "view")) + (:file "dispatcher" :depends-on ("defpackage" "controller"))) + :depends-on ( #:hunchentoot #:routes #:yaclml #:cl-json #:clsql #:cl-annot)) diff --git a/src/orm/defpackage.lisp b/src/orm/defpackage.lisp new file mode 100644 index 0000000..81af864 --- /dev/null +++ b/src/orm/defpackage.lisp @@ -0,0 +1,30 @@ +;;;; 2011-05-28 20:35:00 +(in-package :common-lisp-user) +(defpackage :orm + (:use :cl) + (:import-from :orm-table + :table + :deftable + :create-instance + :fetch + :destroy-instance + :destroy-records + ) + (:import-from :orm-record + :record + :save + :save-slots + :destroy) + (:export + :table + :deftable + :create-instance + :fetch + :record + :save + :save-slots + :destroy + :destroy-instance + :destroy-records)) +(in-package :orm) + diff --git a/src/orm/orm.lisp b/src/orm/orm.lisp new file mode 100644 index 0000000..46594b8 --- /dev/null +++ b/src/orm/orm.lisp @@ -0,0 +1,33 @@ +;;;; 2011-05-28 20:35:00 + + +(in-package :common-lisp-user) + +(defpackage :orm + (:use :cl) + (:import-from :orm-table + :table + :deftable + :create-instance + :fetch + :destroy-instance + :destroy-records + ) + (:import-from :orm-record + :record + :save + :save-slots + :destroy) + (:export + :table + :deftable + :create-instance + :fetch + :record + :save + :save-slots + :destroy + :destroy-instance + :destroy-records)) +(in-package :orm) + diff --git a/src/orm/record.lisp b/src/orm/record.lisp new file mode 100644 index 0000000..4a88588 --- /dev/null +++ b/src/orm/record.lisp @@ -0,0 +1,37 @@ +;;;; Created on 2011-05-28 20:40:19 +(defpackage :orm-record + (:use :cl) + (:import-from :clsql + :update-records-from-instance + :update-record-from-slots + :delete-instance-records)) +(in-package :orm-record) +(cl-annot:enable-annot-syntax) +@export +(defclass record () () + (:documentation "Class for table instances, represents database record.")) +@export +(defmethod save ((rec record)) + "Save this instance and reflect slot values to database." + (update-records-from-instance rec) + rec) +@export +(defmethod save-slots ((rec record) slots) + "Save this instance and reflect slot values to database." + (update-record-from-slots rec slots) + rec) +@export +(defun pkey-name (view-class-name) + (clsql-sys::slot-definition-name (car (clsql-sys::keyslots-for-class (find-class view-class-name))))) +@export +(defmethod destroy ((rec record)) + "Delete this instance from the database. +I want to use `delete' for this name, but it is already used in very famous package :p." + (delete-instance-records rec)) +@export +(defmethod destroy ((nothing null)) + nothing) +@export +(defmethod attributes ((rec record)) + "Return a list of slot names." + (list-attributes rec)) \ No newline at end of file diff --git a/src/orm/table.lisp b/src/orm/table.lisp new file mode 100644 index 0000000..f0990e9 --- /dev/null +++ b/src/orm/table.lisp @@ -0,0 +1,176 @@ +;;;; Created on 2011-05-28 20:42:16 +(defpackage :orm-table + (:use :cl) + (:import-from :clsql + :enable-sql-reader-syntax + :create-view-from-class + :select + :sql-expression + :sql-operator + :table-exists-p + :sql-and + :sql-= + :sql-in + :sql-count) + (:import-from :clsql-sys :standard-db-class) + (:import-from :orm-record + :record + :save + :save-slots + :destroy + :pkey-name)) +(in-package :orm-table) +(cl-annot:enable-annot-syntax) +@export +(defclass table (clsql-sys::standard-db-class) () + (:documentation "Metaclass for database tables.")) +@export +(defmethod create-instance ((table symbol) &rest initargs) + (apply #'create-instance (find-class table) initargs)) +@export +(defmethod create-instance ((table table) &rest initargs) + "Same as `make-instance' except for calling `save' it then. +Example: + (create-instance 'person :name \"Eitarow Fukamachi\")" + (let ((new-instance (apply #'make-instance table initargs))) + (save new-instance) + new-instance)) +(defun remove-nil-from-plist (plist) + (loop for (k v) on plist by #'cddr + unless (eq v nil) + append (list k v))) +@export +(defmethod destroy-instance ((table symbol) id) + (destroy-instance (find-class table) id)) +@export +(defmethod destroy-instance ((table table) id) + (let ((instance (fetch table id))) + (destroy instance))) +@export +(defmethod fetch ((table symbol) ids-or-key + &key where conditions order-by offset limit group-by) + (fetch (find-class table) ids-or-key + :where where + :conditions conditions + :order-by order-by + :offset offset + :limit limit + :group-by group-by)) +@export +(defmethod destroy-records ((table symbol) &key where conditions) + (clsql:delete-records + :from (symbol-name table) + :where + (cond + ((and where conditions) + (sql-and where (normalize-conditions conditions))) + (where (sql-and where)) + (conditions (sql-and (normalize-conditions conditions))) + (t nil)))) +@export +(defmethod fetch ((table table) ids-or-key + &key where conditions order-by offset limit group-by) + "Find records from `table' and return it. +`ids-or-key' must be :first, :all, or a number, represents primary key, or the list. + +Example: + ;; Fetch a record, id=1. + (fetch person 1) + ;; Fetch records, country=jp + (fetch person :conditions '(:country \"jp\"))" + (setf table (class-name table)) + (etypecase + ids-or-key + (keyword (ecase ids-or-key + (:first + (car + (apply + #'select table :flatp t + (remove-nil-from-plist + `(:limit 1 + :refresh t + :offset ,offset + :order-by ,(normalize-order-by order-by) + :group-by ,group-by + :where ,(cond + ((and where conditions) + (sql-and where (normalize-conditions conditions))) + (where where) + (conditions (normalize-conditions conditions)))))))) + (:count + (car + (apply + #'select (sql-count (sql-expression :attribute "*")) :from table :flatp t + (remove-nil-from-plist + `(:offset ,offset + :order-by ,(normalize-order-by order-by) + :group-by ,group-by + :where ,(cond + ((and where conditions) + (sql-and where (normalize-conditions conditions))) + (where where) + (conditions (normalize-conditions conditions)))))))) + (:all + (apply + #'select table :flatp t + (remove-nil-from-plist + `(:limit ,limit + :refresh t + :offset ,offset + :order-by ,(normalize-order-by order-by) + :group-by ,group-by + :where ,(cond + ((and where conditions) + (sql-and where (normalize-conditions conditions))) + (where where) + (conditions (normalize-conditions conditions))))))))) + ((or number string) + (car + (apply + #'select table + :refresh t + :where + (cond + ((and where conditions) + (sql-and (sql-= (sql-expression :attribute (pkey-name table)) ids-or-key) where (normalize-conditions conditions))) + (where (sql-and (sql-= (sql-expression :attribute (pkey-name table)) ids-or-key) where)) + (conditions (sql-and (sql-= (sql-expression :attribute (pkey-name table)) ids-or-key) (normalize-conditions conditions))) + (t (sql-= (sql-expression :attribute (pkey-name table)) ids-or-key))) + :flatp t + (remove-nil-from-plist + `(:order-by ,(normalize-order-by order-by) :group-by ,group-by))))) + (cons + (apply + #'select table + :refresh t + :where + (if where + (sql-and (sql-in (sql-expression :attribute (pkey-name table)) ids-or-key) where) + (sql-in (sql-expression :attribute (pkey-name table)) ids-or-key)) + :flatp t + (remove-nil-from-plist + `(:limit ,limit + :offset ,offset + :order-by ,(normalize-order-by order-by) + :group-by ,group-by)))))) +@export +(defmacro deftable (class supers slots &optional cl-options) + "Define a table schema. This is just a wrapper of `clsql:def-view-class', +so, see CLSQL documentation to get more informations. +" + `(progn + (clsql:def-view-class ,class (record ,@supers) + ,slots + ,@(if (find :metaclass `,cl-options :key #'car) + `,cl-options + (cons '(:metaclass table) `,cl-options))) +; (unless (table-exists-p ',class) +; (create-view-from-class ',class)) + (defvar ,class (find-class ',class)))) +(defun normalize-conditions (conditions) + (apply #'sql-and + (loop for (k v) on conditions by #'cddr + collect (sql-= (sql-expression :attribute k) v)))) +(defun normalize-order-by (order-by) + (loop for (k v) on order-by by #'cddr + collect (list (sql-expression :attribute k) v))) \ No newline at end of file diff --git a/src/render.lisp b/src/render.lisp new file mode 100644 index 0000000..7d69eb7 --- /dev/null +++ b/src/render.lisp @@ -0,0 +1,47 @@ +;;;; Created on 2011-05-15 16:36:12 +(in-package :mvc) + +(defmethod render-view ((text string)) + text) + +(defmethod render-view ((view-func function)) + (funcall view-func)) + +(defmethod render-view :before ((code integer)) + (setf (hunchentoot:return-code*) code)) + +(defmethod render-view ((octets vector)) + octets) + +(defmethod render-view ((file pathname)) + (if (probe-file file) + (hunchentoot:handle-static-file file + (or (hunchentoot:mime-type file) + (hunchentoot:content-type hunchentoot:*reply*))) + (not-found-if-not nil))) + +(defmethod render-view ((object (eql nil))) + (render-view hunchentoot:+http-not-found+)) + +(defmethod render-view (object) + (error "Unknown as render ~A " object)) + +(defmethod render-view ((data list))) + +(defmethod render-view ((view template-view)) + (render-template (not-found-if-not (view-name view)) (view-params view))) + +(defmethod render-view ((view json-view)) + (json:encode-json-plist-to-string (view-params view))) + +(defmethod render-view :around ((view html-view)) + (if (ajax-request-p) + (progn + (hunchentoot:no-cache) + (call-next-method)) + (progn + (render-template (not-found-if-not (view-layout view)) (append (list :template (view-name view)) (view-params view))) + ))) + +(defmethod render-view ((view redirect-view)) + (hunchentoot:redirect (redirect-view-url view))) diff --git a/src/routing.lisp b/src/routing.lisp new file mode 100644 index 0000000..d072268 --- /dev/null +++ b/src/routing.lisp @@ -0,0 +1,77 @@ +;;;; Created on 2011-04-12 15:02:47 +(defpackage :routing + (:use :cl :core :cl-annot :iterate) + (:export + :route-action + :route-controller + :route-name + :route-defaults)) +(in-package :routing) +(annot:enable-annot-syntax) +@export +(defclass route (routes:route) + ((controller :initarg :controller :initform *default-controller-name* :accessor route-controller) + (action :initarg :action :initform *default-action-name* :accessor route-action) + (defaults :initarg :defaults :accessor route-defaults) + (name :initarg :name :accessor route-name) + (method :initarg :method) + (requirements :initarg :requirements))) +@export +(defun nil-if-empty (string) + (if (and (stringp string) (string= string "")) + nil + string)) +@export +(defun defroute (name + template + &key + action + controller + defaults + (method :any) + requirements + parse-vars) + (let ((route (make-instance 'route + :name name + :template (routes:parse-template template parse-vars) + :controller controller + :action (or action *default-action-name*) + :defaults defaults + :method method + :requirements requirements))) + (routes:connect (default-mapper) route) + (push route (default-routes)) + route)) +@export +(defun clear-routes () + (routes:reset-mapper (default-mapper)) + (setf (mvc::default-routes) nil) + ) +@export +(defun find-route (route-name) + (find-if (lambda (route) (string= (route-name route) route-name)) (default-routes))) +@export +(defun genurl-full (route &rest args) + (let ((uri (genurl/impl (route-template route) args))) + (setf (puri:uri-scheme uri) + :http) + (setf (puri:uri-host uri) + (if (boundp 'hunchentoot:*request*) + (hunchentoot:host) + "localhost")) + (puri:render-uri uri nil))) +@export +(defun genurl (route &rest args) + (puri:render-uri (genurl/impl (route-template route) args) nil)) +(defun route-template (route) + (routes:route-template route)) +(defun genurl/impl (tmpl args) + (let ((uri (make-instance 'puri:uri))) + (setf (puri:uri-parsed-path uri) + (cons :absolute + (routes::apply-bindings + tmpl + (iterate (for (key value) :on args :by #'cddr) + (collect (cons key (if (listp value) value (princ-to-string value)))))))) + uri)) + diff --git a/src/template.lisp b/src/template.lisp new file mode 100644 index 0000000..ad1d30d --- /dev/null +++ b/src/template.lisp @@ -0,0 +1,42 @@ +;;;; Created on 2011-05-22 21:25:05 + +(in-package :mvc) + +(defvar *view-dir* (merge-pathnames #p"views/")) + +(defvar *generator* + (make-instance 'yaclml:file-system-generator + :root-directories (list *view-dir*)) + "A filesystem-based TAL generator that looks for templates only in + current directory.") + +(defun plist-tal-env (pairs) + "Creates a fresh tal environment from the plist PAIRS." + (labels ((keyword-to-symbol (keyword) + (if (keywordp keyword) + (intern (symbol-name keyword)) + keyword)) + (list-tal-env (value) + (if (first value) + (if (keywordp (first value)) + (plist-tal-env value) + (mapcar (lambda (val) (if (listp val) (list-tal-env val) (list val))) value)) + nil))) + (list + (iterate (for (key value) :on pairs :by #'cddr) + (collect + (cons (keyword-to-symbol key) + (if (listp value) + (list-tal-env value) + value))))))) + +(defun render-template (name env) + (let ((template (yaclml:load-tal *generator* (concatenate 'string name ".tal")))) + (when template + (YACLML:WITH-YACLML-OUTPUT-TO-STRING (funcall template + (if (listp env) + (if (keywordp (first env)) + (plist-tal-env env) + env) + (list env)) + *generator*))))) diff --git a/src/testfile.lisp b/src/testfile.lisp new file mode 100644 index 0000000..3c02c0d --- /dev/null +++ b/src/testfile.lisp @@ -0,0 +1,40 @@ +;;;; Created on 2011-04-12 22:03:35 +; MAIN TODO: controller and action +; CURRENT TODO: action filter stack +(mvc::reset) +(mvc:defcontroller :init) +(in-package :init) +;(defun some-action (&key some variable) (write-to-string (list some variable))) +(defun http-hello-world-2(&rest args) + (declare (ignore args)) + + "Ïðèâåò ìèð!") + +(mvc:defaction some-action (some variable) () + (write-to-string *route-params*) + ;(hunchentoot:abort-request-handler) + (mvc:make-view (list :vars (list (list :id 1 :name "name"))) :name "template-name" :layout "some" :type :html)) + + +;(mvc:defilter (lambda () (setf (getf *route-params* :some) "value")) :before) +(mvc:defroute "some-route" "" :action "some-action" :controller "init") +(mvc:defroute "some-route1" ":some/:variable" :action "some-action" :controller "init") +(mvc:defroute "some-other-route" ":some/:variable/with-other" :defaults (list :other "value") :action "some-action" :controller "init") +(mvc:start) + + + + + + + +(let* ((package (symbol-package (type-of (first (get-tabs nil))))) + (func (find-symbol (string-upcase "sort-order") package))) + (when (fboundp func) "found") + ) + + + + + + diff --git a/src/view.lisp b/src/view.lisp new file mode 100644 index 0000000..c64c91c --- /dev/null +++ b/src/view.lisp @@ -0,0 +1,44 @@ +;;;; Created on 2011-04-10 00:58:59 + +(in-package :mvc) + +(defclass view-base () ()) +(defclass data-view (view-base) + ((params :initarg :params :initform nil :accessor view-params :type list))) + +;;; +; TEMPLATE views +;;; +(defclass template-view (data-view) + ((name :initarg :name :accessor view-name :type string))) +(defclass html-view (template-view) + ((layout :initarg :layout :accessor view-layout :type string))) +(defclass xml-view (template-view) ()) + +;;; +; Data views +;;; +;(defclass xml-plist-view (data-view) ()) +(defclass json-view (data-view) ()) + +;;; +; Advanced views +;;; +(defclass widget-view (view-base) ()) +(defclass javascript-view (view-base) ()) + +;;; +; Redirect views +;;; +(defclass redirect-view (view-base) + ((url :initarg :url :accessor redirect-view-url))) +(defclass referer-view (redirect-view) ()) + +(defmethod initialize-instance ((view redirect-view) &rest route-params &key route-name) + (when route-name + (setf (slot-value view 'url) (genurl (find-route route-name) (alexandria:remove-from-plist route-params :url :route-name))))) + +(defmethod initialize-instance ((view referer-view) &rest args) + (declare (ignore args)) + (setf (slot-value view 'url) (hunchentoot:referer))) + diff --git a/src/view/defpackage.lisp b/src/view/defpackage.lisp new file mode 100644 index 0000000..11df35e --- /dev/null +++ b/src/view/defpackage.lisp @@ -0,0 +1,20 @@ +;;;; Created on 2011-06-06 23:38:49 +(in-package :common-lisp-user) + +(defpackage :view + (:nicknames :view) + (:use :cl :json :iterate :core :routing) + (:export + #:render-template + #:render-view + #:view-params + #:view-name + #:view-layout + :html-view + :template-view + :xml-view + :json-view + :widget-view + :javascript-view + :redirect-view + :referer-view)) \ No newline at end of file diff --git a/src/view/render.lisp b/src/view/render.lisp new file mode 100644 index 0000000..9015d0e --- /dev/null +++ b/src/view/render.lisp @@ -0,0 +1,47 @@ +;;;; Created on 2011-05-15 16:36:12 +(in-package :view) + +(defmethod render-view ((text string)) + text) + +(defmethod render-view ((view-func function)) + (funcall view-func)) + +(defmethod render-view :before ((code integer)) + (setf (hunchentoot:return-code*) code)) + +(defmethod render-view ((octets vector)) + octets) + +(defmethod render-view ((file pathname)) + (if (probe-file file) + (hunchentoot:handle-static-file file + (or (hunchentoot:mime-type file) + (hunchentoot:content-type hunchentoot:*reply*))) + (not-found-if-not nil))) + +(defmethod render-view ((object (eql nil))) + (render-view hunchentoot:+http-not-found+)) + +(defmethod render-view (object) + (error "Unknown as render ~A " object)) + +(defmethod render-view ((data list))) + +(defmethod render-view ((view template-view)) + (render-template (not-found-if-not (view-name view)) (view-params view))) + +(defmethod render-view ((view json-view)) + (json:encode-json-plist-to-string (view-params view))) + +(defmethod render-view :around ((view html-view)) + (if (ajax-request-p) + (progn + (hunchentoot:no-cache) + (call-next-method)) + (progn + (render-template (not-found-if-not (view-layout view)) (append (list :template (view-name view)) (view-params view))) + ))) + +(defmethod render-view ((view redirect-view)) + (hunchentoot:redirect (redirect-view-url view))) diff --git a/src/view/template.lisp b/src/view/template.lisp new file mode 100644 index 0000000..7c31d6c --- /dev/null +++ b/src/view/template.lisp @@ -0,0 +1,42 @@ +;;;; Created on 2011-05-22 21:25:05 +(in-package :view) +(defvar *view-dir* (merge-pathnames #p"views/")) + +(defvar *generator* +(make-instance 'yaclml:file-system-generator + :root-directories (list *view-dir*)) + "A filesystem-based TAL generator that looks for templates only in + current directory.") + +(defun plist-tal-env (pairs) + "Creates a fresh tal environment from the plist PAIRS." + (labels ((keyword-to-symbol (keyword) + (if (keywordp keyword) + (intern (symbol-name keyword)) + keyword)) + (list-tal-env (value) + (if (first value) + (if (keywordp (first value)) + (plist-tal-env value) + (mapcar (lambda (val) (if (listp val) (list-tal-env val) (list val))) value)) + nil))) + (list + (iterate (for (key value) :on (if (and (listp pairs) (keywordp (first pairs))) pairs (list pairs)) :by #'cddr) + (collect + (cons (keyword-to-symbol key) + (if (listp value) + (list-tal-env value) + value))))))) +(defun render-template (name env &key template) + (let ((env-tal (if (listp env) + (if (keywordp (first env)) + (plist-tal-env env) + env) + (list env)))) + (if template + (yaclml:with-yaclml-output-to-string (funcall (yaclml:compile-tal-string template) env-tal nil)) + (let ((template (yaclml:load-tal *generator* (concatenate 'string name ".tal")))) + (when template + (YACLML:WITH-YACLML-OUTPUT-TO-STRING (funcall template + env-tal + *generator*))))))) \ No newline at end of file diff --git a/src/view/view.lisp b/src/view/view.lisp new file mode 100644 index 0000000..610b458 --- /dev/null +++ b/src/view/view.lisp @@ -0,0 +1,46 @@ +;;;; Created on 2011-04-10 00:58:59 + +(in-package :view) + +(defclass view-base () ()) +(defclass data-view (view-base) + ((params :initarg :params :initform nil :accessor view-params :type list))) + +;;; +; TEMPLATE views +;;; +(defclass template-view (data-view) + ((name :initarg :name :accessor view-name :type string))) +(defclass html-view (template-view) + ((layout :initarg :layout :accessor view-layout :type string))) +(defclass xml-view (template-view) ()) + +;;; +; Data views +;;; +;(defclass xml-plist-view (data-view) ()) +(defclass json-view (data-view) ()) + +;;; +; Advanced views +;;; +(defclass widget-view (view-base) ()) +(defclass javascript-view (view-base) ()) + +;;; +; Redirect views +;;; +(defclass redirect-view (view-base) + ((url :initarg :url :accessor redirect-view-url))) +(defclass referer-view (redirect-view) ()) + +(defmethod initialize-instance :after ((view redirect-view) &rest route-params &key route-name &allow-other-keys) + (when route-name + (let ((route (find-route route-name))) + (when route + (setf (slot-value view 'url) (apply #'genurl route (alexandria:remove-from-plist route-params :url :route-name))))))) + +(defmethod initialize-instance :after ((view referer-view) &rest args) + (declare (ignore args)) + (setf (slot-value view 'url) (hunchentoot:referer))) + diff --git a/test/authorization.lisp b/test/authorization.lisp new file mode 100644 index 0000000..6cb3bb2 --- /dev/null +++ b/test/authorization.lisp @@ -0,0 +1,40 @@ +;;;; Created on 2011-06-02 14:28:21 +(in-package :todotree) +(defparameter *user* nil) +(defun user-id () (if *user* (id *user*) 0)) +(defun utime+ (time amount unit &optional time-zone offset) + (let ((local (local-time:universal-to-timestamp time))) + (local-time:timestamp-to-universal (local-time:timestamp+ local amount unit time-zone offset)))) +(defun utime- (time amount unit &optional time-zone offset) + (let ((local (local-time:universal-to-timestamp time))) + (local-time:timestamp-to-universal (local-time:timestamp- local amount unit time-zone offset)))) +(defun load-user () + (setq *user* (or (hunchentoot:session-value :user) + (try-load-user-cookies)))) +(defun try-load-user-cookies () + (let ((email (hunchentoot:cookie-in "login-email")) + (key (hunchentoot:cookie-in "login-key"))) + (when email + (let ((user (get-user email))) + (if (and user + (string-equal key (get-user-hash email (user-password user) t))) + (setq *user* (setf (hunchentoot:session-value :user) user)) + (clear-user-cookies)))))) +(defun get-user-hash (email password &optional password-hashed) + (hash-password (concatenate 'string email (if password-hashed password (hash-password password))))) +(defun set-user-cookies (user) + (hunchentoot:set-cookie "login-email" :value (user-email user) :expires (utime+ (get-universal-time) 7 :day)) + (hunchentoot:set-cookie "login-key" :value (get-user-hash (user-email user) (user-password user) t) :expires (utime+ (get-universal-time) 7 :day)) + (setf (hunchentoot:session-value :user) user) + (setq *user* user)) +(defun clear-user-cookies () + (hunchentoot:set-cookie "login-email" :value nil :expires (utime- (get-universal-time) 1 :day)) + (hunchentoot:set-cookie "login-key" :value nil :expires (utime- (get-universal-time) 1 :day)) + (hunchentoot:delete-session-value :user) + (setq *user* nil)) +(defun authorize-user (email password &optional password-hashed) + (let ((user (get-user* email password password-hashed))) + (if user + (set-user-cookies user) + (clear-user-cookies)))) + diff --git a/test/dash.lisp b/test/dash.lisp new file mode 100644 index 0000000..b2bd09c --- /dev/null +++ b/test/dash.lisp @@ -0,0 +1,22 @@ +;;;; Created on 2011-06-02 14:06:06 +(in-package :todotree) +(defcontroller :index :options ((:use :todotree :todotree-model) (:import-from :todotree :user-id :*user*)) :view-type :html :view-layout "index") +(in-package :index) +(defilter #'todotree::load-user :before) +(defaction index () () + (let ((tabs (get-tabs (user-id)))) + (make-view (list :user todotree::*user* :tabs tabs) :name "index"))) +(defaction js (file-name) () + (make-pathname :directory "views/js/" :name file-name :type "js")) +(defun list-concat (list &optional delimiter) + (reduce (lambda (a b) + (concatenate 'string a delimiter b)) + (remove-if-not #'stringp list))) +(defaction style (file-name) () + (write-to-string file-name) + (concatenate 'string "views/css/" (list-concat file-name "/")) + (pathname (concatenate 'string "views/css/" (list-concat file-name "/")))) + + + + \ No newline at end of file diff --git a/test/defpackage.lisp b/test/defpackage.lisp new file mode 100644 index 0000000..f4ff4ac --- /dev/null +++ b/test/defpackage.lisp @@ -0,0 +1,7 @@ +;;;; 2011-05-29 15:16:59 +(in-package :common-lisp-user) +(defpackage :todotree + (:nicknames :todotree) + (:use :cl :mvc :todotree-model) + (:export :*user* :user-id)) + diff --git a/test/model/CRUD.lisp b/test/model/CRUD.lisp new file mode 100644 index 0000000..239e4b8 --- /dev/null +++ b/test/model/CRUD.lisp @@ -0,0 +1,122 @@ +;;;; Created on 2011-05-31 14:46:54 +(in-package :todotree-model) + +; +;Help functions +; + +(defun not-nil-keys (plist &optional result) + (flet ((keyword-to-symbol (keyword) + (if (keywordp keyword) + (intern (symbol-name keyword)) + keyword))) + (alexandria:doplist (key value plist result) + (when value + (push (keyword-to-symbol key) result))))) +(defun hash-password (password) + (ironclad:byte-array-to-hex-string + (ironclad:digest-sequence + :md5 + (ironclad:ascii-string-to-byte-array password)))) + +; +; Context +; +(defun add-context (name user-id &optional description) + (create-instance 'context :name name :user-id user-id :description description)) +(defun update-context (id &rest params &key name description) + (save-slots (make-instance 'context :id id :name name :description description) + (not-nil-keys params nil))) +(defun delete-context (id) + (destroy-instance 'context id)) +; +; Tag +; +(defun add-tag (name user-id &optional color picture tab-id) + (create-instance 'tag :name name :user-id user-id :color color :picture picture :tab-id tab-id)) +(defun update-tag (id &rest params &key name color picture tab-id) + (save-slots (make-instance 'tag :id id :name name :color color :picture picture :tab-id tab-id) + (not-nil-keys params nil))) +(defun delete-tag (id) + (destroy-instance 'tag id)) + +; +; Note +; +(defun add-note (text user-id &optional color task-id tab-id) + (create-instance 'note :text text :user-id user-id :color color :task-id task-id :tab-id tab-id)) +(defun update-note (id &rest params &key text color task-id tab-id) + (save-slots (make-instance 'note :id id :text text :color color :task-id task-id :tab-id tab-id) + (not-nil-keys params nil))) +(defun delete-note (id) + (destroy-instance 'note id)) + +; +; Task +; +(defun add-task (name user-id &optional priority description started active date-due parent-task-id tab-id color) + (create-instance 'task + :name name + :user-id user-id + :priority (or priority :normal) + :description (or description "") + :date-add (clsql:get-time) + :date-start (if started (clsql:get-time)) + :date-due date-due + :parent-task-id (or parent-task-id 0) + :tab-id tab-id + :color color + :active active)) +(defun update-task (id &rest params &key name priority description started active completed date-due parent-task-id tab-id color) + (save (update-slots (fetch 'task id) + params))) + +(defun update-slots (instance slots) + (alexandria:doplist (key val slots) + (let ((func (find-symbol (concatenate 'string (symbol-name (type-of instance)) "-" (symbol-name key))))) + (when (and func (fboundp func)) + (funcall (fdefinition (list 'setf func)) val instance)))) + instance) + +(defun delete-task (id) + (destroy-instance 'task id)) + +; +; User +; +(defun add-user (email password + &optional first-name last-name + &key password-hashed) + (create-instance 'user + :email email + :password (if password-hashed + password + (hash-password password)) + :first-name first-name + :last-name last-name)) +(defun update-user (id &rest params + &key email password first-name last-name) + (save-slots (update-slots (fetch 'user id) + params) + (not-nil-keys params nil))) +(defun delete-user (id) + (destroy-instance 'user id)) + +; +; Tab +; +(defun add-tab (name type user-id &key date sort-order) + (create-instance 'tab + :name (or name + (string-capitalize (symbol-name type))) + :type type + :date date + :sort-order (or sort-order 0) + :user-id user-id)) +(defun update-tab (id &rest args &key name type date sort-order) + (save-slots (update-slots (fetch 'tab id) + params) + (not-nil-keys params nil))) +(defun delete-tab (id) + (destroy-instance 'tab id)) + \ No newline at end of file diff --git a/test/model/database.lisp b/test/model/database.lisp new file mode 100644 index 0000000..0c73ae3 --- /dev/null +++ b/test/model/database.lisp @@ -0,0 +1,8 @@ +;;;; Created on 2011-05-30 14:33:29 +(in-package :todotree-model) + +(defvar *db* nil) +(setf *db* + (connect '("192.168.0.1" "todolisp" "postgres" "danniill") + :database-type :postgresql-socket + :if-exists :old)) diff --git a/test/model/defpackage.lisp b/test/model/defpackage.lisp new file mode 100644 index 0000000..9d39afc --- /dev/null +++ b/test/model/defpackage.lisp @@ -0,0 +1,27 @@ +;;;; Created on 2011-05-30 14:25:19 +(in-package :common-lisp-user) + +(defpackage :todotree-model + (:nicknames :todotree-model) + (:use :cl :mvc :clsql) + (:export + :id + :get-tabs + :user + :tab + :task + :task-completed + :get-user* + :get-user + :hash-password + :user-password + :user-email + :get-tab-tasks + :get-unsorted-tasks + :get-child-tasks + :create-tab + :tab-name + :delete-tab + :add-tab-task + :toggle-task + :add-child-task)) \ No newline at end of file diff --git a/test/model/send-mail.lisp b/test/model/send-mail.lisp new file mode 100644 index 0000000..6410db9 --- /dev/null +++ b/test/model/send-mail.lisp @@ -0,0 +1,27 @@ +;;;; Created on 2011-06-01 13:54:36 +(in-package :todotree-model) +(defparameter *new-user-format* "Ïðèâåò, âàø ïàðîëü: ~a Ìû ïðîñòî óâåðåíû, ÷òî Âàì îí ñîâñåì íå íðàâèòñÿ.Ïîýòîìó íå ñòåñíÿéòåñü ïîìåíÿòü åãî íà ëþáîé äðóãîé â ðàçäåëå «Íàñòðîéêè».---- Àäìèíèñòðàöèÿ") +(defgeneric send-mail (email object &key type)) +(defmethod send-mail (email (object null) &key type) + (declare (ignore email object type)) + "Error in send-mail! No object specified") +(defmethod send-mail (email (value string) &key type) + (case type + (:new-user + (bordeaux-threads:make-thread (lambda() (smtp-send email "New user registration" (format nil *new-user-format* value))))) + (otherwise "Error sending email! No such email type"))) +(defparameter *smtp-account* + (list :host "smtp.gmail.com" + :authentication (list "hairyhum@gmail.com" "danniill") + :from "noreply@gmail.com" + :ssl t)) +(defun smtp-send (to topic message) + (handler-case + (cl-smtp:send-email (getf *smtp-account* :host) + (getf *smtp-account* :from) + to + topic + message + :ssl (getf *smtp-account* :ssl) + :authentication (getf *smtp-account* :authentication)) + (error nil))) \ No newline at end of file diff --git a/test/model/tables.lisp b/test/model/tables.lisp new file mode 100644 index 0000000..726a171 --- /dev/null +++ b/test/model/tables.lisp @@ -0,0 +1,92 @@ +;;;; Created on 2011-05-30 14:34:58 +(in-package :todotree-model) + +(deftable user () + ((id + :type integer + :db-kind :key + :db-constraints (:not-null :auto-increment) + :accessor id + :initarg :id) + (email + :type string + :accessor user-email) + (password + :type string + :accessor user-password) + (first-name + :type string + :initform "" + :accessor user-first-name) + (last-name + :type string + :initform "" + :accessor user-last-name))) +(deftable task () + ((id + :type integer + :db-kind :key + :db-constraints (:not-null :auto-increment) + :initarg :id + :accessor id) + (name + :type string + :initarg :name + :accessor task-name) + (user-id + :type integer + :initarg :user-id + :accessor task-user-id) + (priority + :type keyword + :initarg :priority + :accessor task-priority) + (date-due + :type clsql:date + :initarg :date-due + :accessor task-date-due) + (completed + :type boolean + :initarg :completed + :accessor task-completed) + (tab-id + :type integer + :initform 0 + :initarg :tab-id + :accessor task-tab-id) + (parent-task-id + :type integer + :initform 0 + :initarg :parent-task-id + :accessor task-parent-task-id))) +(deftable tab () + ((id + :type integer + :db-kind :key + :db-constraints (:not-null :auto-increment) + :accessor id + :initarg :id) + (name + :type string + :initarg :name + :accessor tab-name) + (sort-order + :type integer + :initarg :sort-order + :accessor tab-sort-order) + (type + :type keyword + :initarg :type + :accessor tab-type) + (date + :type clsql:date + :initarg :date + :accessor tab-date) + (user-id + :type integer + :initarg :user-id + :accessor tab-user-id) + (tasks + :db-kind :virtual + :accessor tab-tasks + :initform nil))) diff --git a/test/model/tabs.lisp b/test/model/tabs.lisp new file mode 100644 index 0000000..62977bd --- /dev/null +++ b/test/model/tabs.lisp @@ -0,0 +1,32 @@ +;;;; Created on 2011-06-10 20:07:29 +(in-package :todotree-model) +(defmethod get-unsorted-tasks ((user-id integer)) + (fetch 'task :all :conditions (LIST :user-id user-id :tab-id 0 :parent-task-id 0))) +(defmethod get-unsorted-tasks ((nothing null)) + (fetch 'task :all :conditions (LIST :user-id 0 :tab-id 0 :parent-task-id 0))) +(defmethod get-tab-tasks ((tab tab)) + (let ((type (tab-type tab))) + (if (eql type :custom) + (filter-tasks* (tab-date tab) (tab-user-id tab) :tags nil :segment "day") + (filter-tasks type (tab-user-id tab))))) +(defmethod instance-refreshed ((tab tab)) + (setf (tab-tasks tab) (get-tab-tasks tab))) +(defmethod get-tabs ((nothing null)) + (fetch 'tab :all :conditions (list :user-id 0))) +(defmethod get-tabs ((user-id integer)) + (fetch 'tab :all :conditions (list :user-id user-id))) +(defun create-tab (name type user-id &optional date) + (let ((type (find-symbol (string-upcase type) :keyword))) + (if (eql :custom type) + (add-tab name type user-id :date (or date (clsql:get-date))) + (when (find type (list :today :tomorrow :week :next-week :month :next-month)) + (add-tab name type user-id :date (second (multiple-value-list (get-period-dates type)))))))) +(defmethod add-tab-task ((tab tab) name &key user-id priority description started active date-due color) + (add-task name (or user-id (tab-user-id tab)) priority description started active (or date-due (get-tab-date tab) (clsql:get-time)) nil (id tab) color)) +(defmethod add-tab-task ((tab-id integer) name &key user-id priority description started active date-due color) + (add-task name user-id priority description started active (or date-due (clsql:get-time)) nil tab-id color)) +(defmethod get-tab-date ((tab tab)) + (let ((type (tab-type tab))) + (if (eql type :custom) + (tab-date tab) + (second (multiple-value-list (get-period-dates type)))))) \ No newline at end of file diff --git a/test/model/tasks.lisp b/test/model/tasks.lisp new file mode 100644 index 0000000..bbe62e9 --- /dev/null +++ b/test/model/tasks.lisp @@ -0,0 +1,72 @@ +;;;; Created on 2011-05-31 22:20:59 +(in-package :todotree-model) +(defmethod task-has-children ((task task)) + (> (fetch 'task :count :conditions (list :parent-task-id (id task))) 0)) +(defmethod get-child-tasks ((parent-id integer) user-id) + (fetch 'task :all :conditions (list :parent-task-id parent-id :user-id user-id))) +(defmethod get-child-tasks ((task task) user-id) + (get-child-tasks (id task) user-id)) +(defmethod get-child-tasks ((nothing null) user-id) + (declare (ignore nothing user-id))) +(defun sql-date+ (date amount unit) + (when (eql unit :week) + (setq unit :day) + (setq amount (* amount 7))) + (clsql:date+ date (make-instance 'clsql:duration unit amount))) +(defun sql-date- (date amount unit) + (when (eql unit :week) + (setq unit :day) + (setq amount (* amount 7))) + (clsql:date- date (make-instance 'clsql:duration unit amount))) +(defun get-period-dates (period) + (case period + (:today + (values "day" (clsql:get-date))) + (:tomorrow + (values "day" (sql-date+ (clsql:get-date) 1 :day))) + (:week + (values "week" (sql-trunc-week (clsql:get-date)))) + (:next-week + (values "week" (sql-trunc-week (sql-date+ (clsql:get-date) 1 :week)))) + (:month + (values "month" (sql-trunc-month (clsql:get-date)))) + (:next-month + (values "month" (sql-trunc-month (sql-date+ (clsql:get-date) 1 :month)))) + (otherwise (values nil nil)))) +(defun sql-trunc-week (date) + (sql-date- date (- (clsql:date-dow date) 1) :day )) +(defun sql-trunc-month (date) + (sql-date- date (- (third (multiple-value-list (clsql:date-ymd date))) 1) :day)) +(defun filter-tasks* (date user-id &key segment) + (if segment + (fetch 'task :all :conditions (list :user-id user-id) :where (clsql:sql-= (clsql:sql-function "date_trunc" segment (clsql:sql-expression :attribute "date_due")) date)) + (fetch 'task :all :conditions (list :date date :user-id user-id)))) +(defmethod filter-tasks ((time clsql:wall-time) user-id &key segment) + (filter-tasks* time user-id :segment segment)) +(defmethod filter-tasks ((date clsql:date) user-id &key (segment "day")) + (filter-tasks* date user-id :segment segment)) +(defmethod filter-tasks ((period keyword) user-id &key segment) + (declare (ignore segment)) + (multiple-value-bind (segment date) (get-period-dates period) + (filter-tasks* date user-id :segment segment))) +(defmethod toggle-task ((task task) &optional checked) + (let ((completed (if checked (if (string-equal checked "true") "t" "f") "t"))) + (update-task (id task) :completed (string-equal completed "t")) + (clsql:update-records 'task :av-pairs (list (list 'completed completed)) :where (clsql:sql-= (clsql:sql-expression :attribute 'parent-task-id) (id task))))) +(defmethod toggle-task ((id integer) &optional checked) + (let ((task (fetch 'task id))) + (when task (toggle-task task checked)))) +(defmethod toggle-task ((id string) &optional checked) + (let ((task (fetch 'task id))) + (when task (toggle-task task checked)))) +(defmethod add-child-task ((task task) name &key priority description started active date-due color) + (add-task name (task-user-id task) priority description started active date-due (id task) nil color)) +(defmethod add-child-task ((task-id integer) name &key priority description started active date-due color) + (add-child-task (fetch 'task task-id) name :priority priority :description description :started started :active active :date-due date-due :color color)) +(defmethod add-child-task ((task-id string) name &key priority description started active date-due color) + (let ((priority (if (and priority (not (string-equal "" priority))) + (intern (string-upcase priority) :keyword) + :normal))) + (add-child-task (fetch 'task task-id) name :priority priority :description description :started started :active active :date-due date-due :color color))) + + diff --git a/test/model/user.lisp b/test/model/user.lisp new file mode 100644 index 0000000..8e1850d --- /dev/null +++ b/test/model/user.lisp @@ -0,0 +1,26 @@ +;;;; Created on 2011-06-02 14:08:22 +(in-package :todotree-model) +(defun generate-password (&optional length) + (map 'string + (lambda(arg) + (declare (ignore arg)) + (char "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz!@#$^*" (random 68))) + (make-list (or length 8)))) +(defun register-user (email) + (if (fetch 'user :first :conditions (list :email email)) + "Email already exist!" + (let ((password (generate-password))) + (add-user email password) + (send-mail email password :type :new-user)))) +(defmethod get-user ((nithing (eql nil))) + nil) +(defmethod get-user ((id integer)) + (fetch 'user id)) +(defmethod get-user ((email string)) + (fetch 'user :first :conditions (list :email email))) + +(defun get-user* (email password &optional password-hashed) + (fetch 'user + :first + :conditions (list :email email + :password (if password-hashed password (hash-password password))))) \ No newline at end of file diff --git a/test/routes.lisp b/test/routes.lisp new file mode 100644 index 0000000..f6867e1 --- /dev/null +++ b/test/routes.lisp @@ -0,0 +1,9 @@ +;;;; Created on 2011-06-10 20:14:51 +(defroute "tab-content" "/tabs/content/:id" :action "content" :controller "tabs") +(defroute "delete-tab" "/tabs/delete/:id" :action "delete-action" :controller "tabs") +(defroute "create-tab" "/tabs/create" :action "create" :controller "tabs") +(defroute "task-children" "/tasks/get-children" :action "get-children" :controller "tasks") +(defroute "delete-task" "/tasks/delete-completed/:tab-id" :action "delete-completed" :controller "tasks") +(defroute "add-task" "/tasks/add/:tab-id" :action "add" :controller "tasks") +(defroute "check-task" "/tasks/check/:id/:checked" :action "check" :controller "tasks") +(defroute "add-subtask" "/tasks/add-subtask/:parent-id" :action "add-subtask" :controller "tasks") \ No newline at end of file diff --git a/test/start.lisp b/test/start.lisp new file mode 100644 index 0000000..3b55e94 --- /dev/null +++ b/test/start.lisp @@ -0,0 +1,4 @@ +;;;; Created on 2011-06-03 21:12:14 +(in-package :todotree) +(setq *default-pathname-defaults* (pathname "d:/lisp/workspace/todotree/")) +(mvc:start) \ No newline at end of file diff --git a/test/tabs.lisp b/test/tabs.lisp new file mode 100644 index 0000000..7497389 --- /dev/null +++ b/test/tabs.lisp @@ -0,0 +1,29 @@ +;;;; Created on 2011-06-05 15:03:31 +(in-package :todotree) +(defcontroller :tabs + :options ((:use :todotree :todotree-model) + (:import-from :todotree :user-id :*user*)) + :view-type :json + :view-layout "index") +(in-package :tabs) +(defilter #'todotree::load-user :before) +(defaction content (id) () + (let ((tasks (if (string-equal "unsorted" id) + (get-unsorted-tasks (user-id)) + (get-tab-tasks (fetch 'tab id))))) + (make-view (list :user todotree::*user* + :tasks tasks) + :type :partial + :name "tab"))) +(defaction create () (:view-type :json) + (let ((tab (create-tab (hunchentoot:parameter "name") + (hunchentoot:parameter "type") + (user-id) + (clsql:parse-date-time (hunchentoot:parameter "date"))))) + (if tab + (make-view (list :id (id tab) + :name (tab-name tab))) + (make-view)))) +(defaction delete-action (id) (:view-type :json) + (todotree-model:delete-tab id) + (make-view (list :id id))) \ No newline at end of file diff --git a/test/tasks.lisp b/test/tasks.lisp new file mode 100644 index 0000000..6c37892 --- /dev/null +++ b/test/tasks.lisp @@ -0,0 +1,24 @@ +;;;; Created on 2011-06-02 14:00:48 +(in-package :todotree) +(defcontroller :tasks :options ((:use :todotree :todotree-model) (:import-from :todotree :user-id :*user*)) :view-type :html) +(in-package :tasks) +(defaction get-children ()() + (let ((tasks (get-child-tasks (parse-integer (hunchentoot:parameter "id") :junk-allowed t) (user-id)))) + (make-view (list :user todotree::*user* :tasks tasks) :name "tree" :type :partial))) +(defaction delete-completed (tab-id) (:view-type :json) + (destroy-records 'task :conditions (list :tab-id (if (string-equal tab-id "unsorted") 0 tab-id) :completed t)) + (make-view (list :tab-id tab-id) :type :json)) +(defaction add (tab-id) () + (let ((priority (intern (string-upcase (hunchentoot:parameter "priority")) :keyword))) + (if (string-equal tab-id "unsorted") + (add-tab-task 0 (hunchentoot:parameter "name") :priority priority :user-id (user-id)) + (add-tab-task (fetch 'tab tab-id) (hunchentoot:parameter "name") :priority priority))) + (make-view (list :tab-id tab-id) :type :json)) +(defaction check (id checked) () + (toggle-task id checked) + (make-view (list :completed (task-completed (fetch 'task id))) :type :json)) +(defaction add-subtask (parent-id) () + (add-child-task parent-id + (hunchentoot:parameter "name") + :priority (hunchentoot:parameter "priority")) + (make-view (list :id parent-id) :type :json)) \ No newline at end of file diff --git a/test/testfile.lisp b/test/testfile.lisp new file mode 100644 index 0000000..d7c926f --- /dev/null +++ b/test/testfile.lisp @@ -0,0 +1,69 @@ +;;;; Created on 2011-05-29 20:21:37 + +(defpackage :test (:use :cl + :clsql + :mvc)) +(in-package :test) +(defvar *db* nil) +(setf *db* + (clsql:connect '("localhost" "testbase" "postgres" "danniill") + :database-type :postgresql-socket + :if-exists :old)) +(deftable task () + ((id + :type integer + :db-kind :key + :db-constraints (:not-null :auto-increment) + :initarg :id) + (name + :type string + :initarg :name + :accessor task-name) + (date + :type clsql:wall-time + :initarg :date + :accessor task-description) + (user-id + :type integer) + (tags + :reader task-tags + :db-kind :join + :db-info ( + :join-class task-tag + :home-key id + :foreign-key task-id + :set t)))) + +(deftable tag () + ((id + :type integer + :db-kind :key + :db-constraints (:not-null :auto-increment) + :initarg :id) + (name + :type string))) +(deftable task-tag () + ((id :type integer + :db-kind :key + :db-constraints (:not-null :auto-increment) + :initarg :id) + (task-id + :type integer + :db-constraints :not-null + :initarg :task-id) + (tag-id + :type integer + :db-constraints :not-null + :initarg :tag-id))) + +(defun add-link (task tag) + (create-instance 'task-tag :task-id task :tag-id tag)) + + +(let ((me (make-instance 'task))) + (setf (task-name me) "çàäà÷à") + (setf (task-description me) (clsql:w)) + (save me)) + +(clsql:select 'task :where (clsql:sql-= (clsql:sql-function "date_trunc" "week" (clsql:sql-expression :attribute "date")) ) +(clsql:select 'task :where (clsql:sql-= (clsql:sql-function "date_trunc" "week" (clsql:get-date)) (clsql:sql-function "date_trunc" "week" (clsql:sql-expression :attribute "date")))) diff --git a/test/todotree.asd b/test/todotree.asd new file mode 100644 index 0000000..17c7e0b --- /dev/null +++ b/test/todotree.asd @@ -0,0 +1,33 @@ +;;;; 2011-05-29 15:16:59 +;;;; +;;;; Think of this as your project file. +;;;; Keep it up to date, and you can reload your project easily +;;;; by right-clicking on it and selecting "Load Project" + +(defpackage #:todotree-asd + (:use :cl :asdf)) + +(in-package :todotree-asd) + +(defsystem todotree + :name "todotree" + :version "0.1" + :serial t + :components ((:module "model" + :components ((:file "defpackage") + (:file "database" :depends-on ("defpackage")) + (:file "tables" :depends-on ("defpackage")) + (:file "CRUD" :depends-on ("defpackage" "tables")) + (:file "send-mail" :depends-on ("defpackage")) + (:file "user" :depends-on ("defpackage" "send-mail")) + (:file "tasks" :depends-on ("defpackage" "CRUD")) + (:file "tabs" :depends-on ("defpackage" "CRUD")) + )) + (:file "defpackage") + (:file "authorization" :depends-on ("defpackage")) + (:file "routes" :depends-on ("defpackage")) + (:file "dash" :depends-on ("defpackage" "authorization")) + (:file "tabs" :depends-on ("defpackage" "authorization")) + (:file "tasks" :depends-on ("defpackage" "authorization")) + (:file "start")) + :depends-on (#:mvc #:ironclad #:local-time #:cl-smtp)) diff --git a/test/views/css/cupertino/.svn/all-wcprops b/test/views/css/cupertino/.svn/all-wcprops new file mode 100644 index 0000000..e0d6a48 --- /dev/null +++ b/test/views/css/cupertino/.svn/all-wcprops @@ -0,0 +1,11 @@ +K 25 +svn:wc:ra_dav:version-url +V 63 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino +END +jquery-ui-1.8.13.custom.css +K 25 +svn:wc:ra_dav:version-url +V 91 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/jquery-ui-1.8.13.custom.css +END diff --git a/test/views/css/cupertino/.svn/entries b/test/views/css/cupertino/.svn/entries new file mode 100644 index 0000000..0f30b63 --- /dev/null +++ b/test/views/css/cupertino/.svn/entries @@ -0,0 +1,65 @@ +10 + +dir +2 +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework/todotree/views/css/cupertino +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework + + + +2011-06-10T16:28:28.115490Z +2 +hairyhum + + + + + + + + + + + + + + +ac95b44f-471c-48cd-8414-b967058da7d4 + +jquery-ui-1.8.13.custom.css +file + + + + +2011-06-01T07:59:44.000000Z +91a3df8885aad587eb667aadd6ca8f2f +2011-06-10T16:28:28.115490Z +2 +hairyhum + + + + + + + + + + + + + + + + + + + + + +34360 + +images +dir + diff --git a/test/views/css/cupertino/.svn/text-base/jquery-ui-1.8.13.custom.css.svn-base b/test/views/css/cupertino/.svn/text-base/jquery-ui-1.8.13.custom.css.svn-base new file mode 100644 index 0000000..ff54026 --- /dev/null +++ b/test/views/css/cupertino/.svn/text-base/jquery-ui-1.8.13.custom.css.svn-base @@ -0,0 +1,578 @@ +/* + * jQuery UI CSS Framework 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Theming/API + */ + +/* Layout helpers +----------------------------------*/ +.ui-helper-hidden { display: none; } +.ui-helper-hidden-accessible { position: absolute !important; clip: rect(1px 1px 1px 1px); clip: rect(1px,1px,1px,1px); } +.ui-helper-reset { margin: 0; padding: 0; border: 0; outline: 0; line-height: 1.3; text-decoration: none; font-size: 100%; list-style: none; } +.ui-helper-clearfix:after { content: "."; display: block; height: 0; clear: both; visibility: hidden; } +.ui-helper-clearfix { display: inline-block; } +/* required comment for clearfix to work in Opera \*/ +* html .ui-helper-clearfix { height:1%; } +.ui-helper-clearfix { display:block; } +/* end clearfix */ +.ui-helper-zfix { width: 100%; height: 100%; top: 0; left: 0; position: absolute; opacity: 0; filter:Alpha(Opacity=0); } + + +/* Interaction Cues +----------------------------------*/ +.ui-state-disabled { cursor: default !important; } + + +/* Icons +----------------------------------*/ + +/* states and images */ +.ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; } + + +/* Misc visuals +----------------------------------*/ + +/* Overlays */ +.ui-widget-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; } + + +/* + * jQuery UI CSS Framework 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Theming/API + * + * To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Lucida%20Grande,%20Lucida%20Sans,%20Arial,%20sans-serif&fwDefault=bold&fsDefault=1.1em&cornerRadius=6px&bgColorHeader=deedf7&bgTextureHeader=03_highlight_soft.png&bgImgOpacityHeader=100&borderColorHeader=aed0ea&fcHeader=222222&iconColorHeader=72a7cf&bgColorContent=f2f5f7&bgTextureContent=04_highlight_hard.png&bgImgOpacityContent=100&borderColorContent=dddddd&fcContent=362b36&iconColorContent=72a7cf&bgColorDefault=d7ebf9&bgTextureDefault=02_glass.png&bgImgOpacityDefault=80&borderColorDefault=aed0ea&fcDefault=2779aa&iconColorDefault=3d80b3&bgColorHover=e4f1fb&bgTextureHover=02_glass.png&bgImgOpacityHover=100&borderColorHover=74b2e2&fcHover=0070a3&iconColorHover=2694e8&bgColorActive=3baae3&bgTextureActive=02_glass.png&bgImgOpacityActive=50&borderColorActive=2694e8&fcActive=ffffff&iconColorActive=ffffff&bgColorHighlight=ffef8f&bgTextureHighlight=03_highlight_soft.png&bgImgOpacityHighlight=25&borderColorHighlight=f9dd34&fcHighlight=363636&iconColorHighlight=2e83ff&bgColorError=cd0a0a&bgTextureError=01_flat.png&bgImgOpacityError=15&borderColorError=cd0a0a&fcError=ffffff&iconColorError=ffffff&bgColorOverlay=eeeeee&bgTextureOverlay=08_diagonals_thick.png&bgImgOpacityOverlay=90&opacityOverlay=80&bgColorShadow=000000&bgTextureShadow=04_highlight_hard.png&bgImgOpacityShadow=70&opacityShadow=30&thicknessShadow=7px&offsetTopShadow=-7px&offsetLeftShadow=-7px&cornerRadiusShadow=8px + */ + + +/* Component containers +----------------------------------*/ +.ui-widget { font-family: Lucida Grande, Lucida Sans, Arial, sans-serif; font-size: 1.1em; } +.ui-widget .ui-widget { font-size: 1em; } +.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-family: Lucida Grande, Lucida Sans, Arial, sans-serif; font-size: 1em; } +.ui-widget-content { border: 1px solid #dddddd; background: #f2f5f7 url(images/ui-bg_highlight-hard_100_f2f5f7_1x100.png) 50% top repeat-x; color: #362b36; } +.ui-widget-content a { color: #362b36; } +.ui-widget-header { border: 1px solid #aed0ea; background: #deedf7 url(images/ui-bg_highlight-soft_100_deedf7_1x100.png) 50% 50% repeat-x; color: #222222; font-weight: bold; } +.ui-widget-header a { color: #222222; } + +/* Interaction states +----------------------------------*/ +.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #aed0ea; background: #d7ebf9 url(images/ui-bg_glass_80_d7ebf9_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #2779aa; } +.ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #2779aa; text-decoration: none; } +.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { border: 1px solid #74b2e2; background: #e4f1fb url(images/ui-bg_glass_100_e4f1fb_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #0070a3; } +.ui-state-hover a, .ui-state-hover a:hover { color: #0070a3; text-decoration: none; } +.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #2694e8; background: #3baae3 url(images/ui-bg_glass_50_3baae3_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #ffffff; } +.ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #ffffff; text-decoration: none; } +.ui-widget :active { outline: none; } + +/* Interaction Cues +----------------------------------*/ +.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {border: 1px solid #f9dd34; background: #ffef8f url(images/ui-bg_highlight-soft_25_ffef8f_1x100.png) 50% top repeat-x; color: #363636; } +.ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636; } +.ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid #cd0a0a; background: #cd0a0a url(images/ui-bg_flat_15_cd0a0a_40x100.png) 50% 50% repeat-x; color: #ffffff; } +.ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #ffffff; } +.ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #ffffff; } +.ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; } +.ui-priority-secondary, .ui-widget-content .ui-priority-secondary, .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; } +.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; } + +/* Icons +----------------------------------*/ + +/* states and images */ +.ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_72a7cf_256x240.png); } +.ui-widget-content .ui-icon {background-image: url(images/ui-icons_72a7cf_256x240.png); } +.ui-widget-header .ui-icon {background-image: url(images/ui-icons_72a7cf_256x240.png); } +.ui-state-default .ui-icon { background-image: url(images/ui-icons_3d80b3_256x240.png); } +.ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_2694e8_256x240.png); } +.ui-state-active .ui-icon {background-image: url(images/ui-icons_ffffff_256x240.png); } +.ui-state-highlight .ui-icon {background-image: url(images/ui-icons_2e83ff_256x240.png); } +.ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_ffffff_256x240.png); } + +/* positioning */ +.ui-icon-carat-1-n { background-position: 0 0; } +.ui-icon-carat-1-ne { background-position: -16px 0; } +.ui-icon-carat-1-e { background-position: -32px 0; } +.ui-icon-carat-1-se { background-position: -48px 0; } +.ui-icon-carat-1-s { background-position: -64px 0; } +.ui-icon-carat-1-sw { background-position: -80px 0; } +.ui-icon-carat-1-w { background-position: -96px 0; } +.ui-icon-carat-1-nw { background-position: -112px 0; } +.ui-icon-carat-2-n-s { background-position: -128px 0; } +.ui-icon-carat-2-e-w { background-position: -144px 0; } +.ui-icon-triangle-1-n { background-position: 0 -16px; } +.ui-icon-triangle-1-ne { background-position: -16px -16px; } +.ui-icon-triangle-1-e { background-position: -32px -16px; } +.ui-icon-triangle-1-se { background-position: -48px -16px; } +.ui-icon-triangle-1-s { background-position: -64px -16px; } +.ui-icon-triangle-1-sw { background-position: -80px -16px; } +.ui-icon-triangle-1-w { background-position: -96px -16px; } +.ui-icon-triangle-1-nw { background-position: -112px -16px; } +.ui-icon-triangle-2-n-s { background-position: -128px -16px; } +.ui-icon-triangle-2-e-w { background-position: -144px -16px; } +.ui-icon-arrow-1-n { background-position: 0 -32px; } +.ui-icon-arrow-1-ne { background-position: -16px -32px; } +.ui-icon-arrow-1-e { background-position: -32px -32px; } +.ui-icon-arrow-1-se { background-position: -48px -32px; } +.ui-icon-arrow-1-s { background-position: -64px -32px; } +.ui-icon-arrow-1-sw { background-position: -80px -32px; } +.ui-icon-arrow-1-w { background-position: -96px -32px; } +.ui-icon-arrow-1-nw { background-position: -112px -32px; } +.ui-icon-arrow-2-n-s { background-position: -128px -32px; } +.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; } +.ui-icon-arrow-2-e-w { background-position: -160px -32px; } +.ui-icon-arrow-2-se-nw { background-position: -176px -32px; } +.ui-icon-arrowstop-1-n { background-position: -192px -32px; } +.ui-icon-arrowstop-1-e { background-position: -208px -32px; } +.ui-icon-arrowstop-1-s { background-position: -224px -32px; } +.ui-icon-arrowstop-1-w { background-position: -240px -32px; } +.ui-icon-arrowthick-1-n { background-position: 0 -48px; } +.ui-icon-arrowthick-1-ne { background-position: -16px -48px; } +.ui-icon-arrowthick-1-e { background-position: -32px -48px; } +.ui-icon-arrowthick-1-se { background-position: -48px -48px; } +.ui-icon-arrowthick-1-s { background-position: -64px -48px; } +.ui-icon-arrowthick-1-sw { background-position: -80px -48px; } +.ui-icon-arrowthick-1-w { background-position: -96px -48px; } +.ui-icon-arrowthick-1-nw { background-position: -112px -48px; } +.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; } +.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; } +.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; } +.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; } +.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; } +.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; } +.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; } +.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; } +.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; } +.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; } +.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; } +.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; } +.ui-icon-arrowreturn-1-w { background-position: -64px -64px; } +.ui-icon-arrowreturn-1-n { background-position: -80px -64px; } +.ui-icon-arrowreturn-1-e { background-position: -96px -64px; } +.ui-icon-arrowreturn-1-s { background-position: -112px -64px; } +.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; } +.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; } +.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; } +.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; } +.ui-icon-arrow-4 { background-position: 0 -80px; } +.ui-icon-arrow-4-diag { background-position: -16px -80px; } +.ui-icon-extlink { background-position: -32px -80px; } +.ui-icon-newwin { background-position: -48px -80px; } +.ui-icon-refresh { background-position: -64px -80px; } +.ui-icon-shuffle { background-position: -80px -80px; } +.ui-icon-transfer-e-w { background-position: -96px -80px; } +.ui-icon-transferthick-e-w { background-position: -112px -80px; } +.ui-icon-folder-collapsed { background-position: 0 -96px; } +.ui-icon-folder-open { background-position: -16px -96px; } +.ui-icon-document { background-position: -32px -96px; } +.ui-icon-document-b { background-position: -48px -96px; } +.ui-icon-note { background-position: -64px -96px; } +.ui-icon-mail-closed { background-position: -80px -96px; } +.ui-icon-mail-open { background-position: -96px -96px; } +.ui-icon-suitcase { background-position: -112px -96px; } +.ui-icon-comment { background-position: -128px -96px; } +.ui-icon-person { background-position: -144px -96px; } +.ui-icon-print { background-position: -160px -96px; } +.ui-icon-trash { background-position: -176px -96px; } +.ui-icon-locked { background-position: -192px -96px; } +.ui-icon-unlocked { background-position: -208px -96px; } +.ui-icon-bookmark { background-position: -224px -96px; } +.ui-icon-tag { background-position: -240px -96px; } +.ui-icon-home { background-position: 0 -112px; } +.ui-icon-flag { background-position: -16px -112px; } +.ui-icon-calendar { background-position: -32px -112px; } +.ui-icon-cart { background-position: -48px -112px; } +.ui-icon-pencil { background-position: -64px -112px; } +.ui-icon-clock { background-position: -80px -112px; } +.ui-icon-disk { background-position: -96px -112px; } +.ui-icon-calculator { background-position: -112px -112px; } +.ui-icon-zoomin { background-position: -128px -112px; } +.ui-icon-zoomout { background-position: -144px -112px; } +.ui-icon-search { background-position: -160px -112px; } +.ui-icon-wrench { background-position: -176px -112px; } +.ui-icon-gear { background-position: -192px -112px; } +.ui-icon-heart { background-position: -208px -112px; } +.ui-icon-star { background-position: -224px -112px; } +.ui-icon-link { background-position: -240px -112px; } +.ui-icon-cancel { background-position: 0 -128px; } +.ui-icon-plus { background-position: -16px -128px; } +.ui-icon-plusthick { background-position: -32px -128px; } +.ui-icon-minus { background-position: -48px -128px; } +.ui-icon-minusthick { background-position: -64px -128px; } +.ui-icon-close { background-position: -80px -128px; } +.ui-icon-closethick { background-position: -96px -128px; } +.ui-icon-key { background-position: -112px -128px; } +.ui-icon-lightbulb { background-position: -128px -128px; } +.ui-icon-scissors { background-position: -144px -128px; } +.ui-icon-clipboard { background-position: -160px -128px; } +.ui-icon-copy { background-position: -176px -128px; } +.ui-icon-contact { background-position: -192px -128px; } +.ui-icon-image { background-position: -208px -128px; } +.ui-icon-video { background-position: -224px -128px; } +.ui-icon-script { background-position: -240px -128px; } +.ui-icon-alert { background-position: 0 -144px; } +.ui-icon-info { background-position: -16px -144px; } +.ui-icon-notice { background-position: -32px -144px; } +.ui-icon-help { background-position: -48px -144px; } +.ui-icon-check { background-position: -64px -144px; } +.ui-icon-bullet { background-position: -80px -144px; } +.ui-icon-radio-off { background-position: -96px -144px; } +.ui-icon-radio-on { background-position: -112px -144px; } +.ui-icon-pin-w { background-position: -128px -144px; } +.ui-icon-pin-s { background-position: -144px -144px; } +.ui-icon-play { background-position: 0 -160px; } +.ui-icon-pause { background-position: -16px -160px; } +.ui-icon-seek-next { background-position: -32px -160px; } +.ui-icon-seek-prev { background-position: -48px -160px; } +.ui-icon-seek-end { background-position: -64px -160px; } +.ui-icon-seek-start { background-position: -80px -160px; } +/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */ +.ui-icon-seek-first { background-position: -80px -160px; } +.ui-icon-stop { background-position: -96px -160px; } +.ui-icon-eject { background-position: -112px -160px; } +.ui-icon-volume-off { background-position: -128px -160px; } +.ui-icon-volume-on { background-position: -144px -160px; } +.ui-icon-power { background-position: 0 -176px; } +.ui-icon-signal-diag { background-position: -16px -176px; } +.ui-icon-signal { background-position: -32px -176px; } +.ui-icon-battery-0 { background-position: -48px -176px; } +.ui-icon-battery-1 { background-position: -64px -176px; } +.ui-icon-battery-2 { background-position: -80px -176px; } +.ui-icon-battery-3 { background-position: -96px -176px; } +.ui-icon-circle-plus { background-position: 0 -192px; } +.ui-icon-circle-minus { background-position: -16px -192px; } +.ui-icon-circle-close { background-position: -32px -192px; } +.ui-icon-circle-triangle-e { background-position: -48px -192px; } +.ui-icon-circle-triangle-s { background-position: -64px -192px; } +.ui-icon-circle-triangle-w { background-position: -80px -192px; } +.ui-icon-circle-triangle-n { background-position: -96px -192px; } +.ui-icon-circle-arrow-e { background-position: -112px -192px; } +.ui-icon-circle-arrow-s { background-position: -128px -192px; } +.ui-icon-circle-arrow-w { background-position: -144px -192px; } +.ui-icon-circle-arrow-n { background-position: -160px -192px; } +.ui-icon-circle-zoomin { background-position: -176px -192px; } +.ui-icon-circle-zoomout { background-position: -192px -192px; } +.ui-icon-circle-check { background-position: -208px -192px; } +.ui-icon-circlesmall-plus { background-position: 0 -208px; } +.ui-icon-circlesmall-minus { background-position: -16px -208px; } +.ui-icon-circlesmall-close { background-position: -32px -208px; } +.ui-icon-squaresmall-plus { background-position: -48px -208px; } +.ui-icon-squaresmall-minus { background-position: -64px -208px; } +.ui-icon-squaresmall-close { background-position: -80px -208px; } +.ui-icon-grip-dotted-vertical { background-position: 0 -224px; } +.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; } +.ui-icon-grip-solid-vertical { background-position: -32px -224px; } +.ui-icon-grip-solid-horizontal { background-position: -48px -224px; } +.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; } +.ui-icon-grip-diagonal-se { background-position: -80px -224px; } + + +/* Misc visuals +----------------------------------*/ + +/* Corner radius */ +.ui-corner-tl { -moz-border-radius-topleft: 6px; -webkit-border-top-left-radius: 6px; border-top-left-radius: 6px; } +.ui-corner-tr { -moz-border-radius-topright: 6px; -webkit-border-top-right-radius: 6px; border-top-right-radius: 6px; } +.ui-corner-bl { -moz-border-radius-bottomleft: 6px; -webkit-border-bottom-left-radius: 6px; border-bottom-left-radius: 6px; } +.ui-corner-br { -moz-border-radius-bottomright: 6px; -webkit-border-bottom-right-radius: 6px; border-bottom-right-radius: 6px; } +.ui-corner-top { -moz-border-radius-topleft: 6px; -webkit-border-top-left-radius: 6px; border-top-left-radius: 6px; -moz-border-radius-topright: 6px; -webkit-border-top-right-radius: 6px; border-top-right-radius: 6px; } +.ui-corner-bottom { -moz-border-radius-bottomleft: 6px; -webkit-border-bottom-left-radius: 6px; border-bottom-left-radius: 6px; -moz-border-radius-bottomright: 6px; -webkit-border-bottom-right-radius: 6px; border-bottom-right-radius: 6px; } +.ui-corner-right { -moz-border-radius-topright: 6px; -webkit-border-top-right-radius: 6px; border-top-right-radius: 6px; -moz-border-radius-bottomright: 6px; -webkit-border-bottom-right-radius: 6px; border-bottom-right-radius: 6px; } +.ui-corner-left { -moz-border-radius-topleft: 6px; -webkit-border-top-left-radius: 6px; border-top-left-radius: 6px; -moz-border-radius-bottomleft: 6px; -webkit-border-bottom-left-radius: 6px; border-bottom-left-radius: 6px; } +.ui-corner-all { -moz-border-radius: 6px; -webkit-border-radius: 6px; border-radius: 6px; } + +/* Overlays */ +.ui-widget-overlay { background: #eeeeee url(images/ui-bg_diagonals-thick_90_eeeeee_40x40.png) 50% 50% repeat; opacity: .80;filter:Alpha(Opacity=80); } +.ui-widget-shadow { margin: -7px 0 0 -7px; padding: 7px; background: #000000 url(images/ui-bg_highlight-hard_70_000000_1x100.png) 50% top repeat-x; opacity: .30;filter:Alpha(Opacity=30); -moz-border-radius: 8px; -webkit-border-radius: 8px; border-radius: 8px; }/* + * jQuery UI Resizable 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Resizable#theming + */ +.ui-resizable { position: relative;} +.ui-resizable-handle { position: absolute;font-size: 0.1px;z-index: 99999; display: block; + /* http://bugs.jqueryui.com/ticket/7233 + - Resizable: resizable handles fail to work in IE if transparent and content overlaps + */ + background-image:url(data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs=); +} +.ui-resizable-disabled .ui-resizable-handle, .ui-resizable-autohide .ui-resizable-handle { display: none; } +.ui-resizable-n { cursor: n-resize; height: 7px; width: 100%; top: -5px; left: 0; } +.ui-resizable-s { cursor: s-resize; height: 7px; width: 100%; bottom: -5px; left: 0; } +.ui-resizable-e { cursor: e-resize; width: 7px; right: -5px; top: 0; height: 100%; } +.ui-resizable-w { cursor: w-resize; width: 7px; left: -5px; top: 0; height: 100%; } +.ui-resizable-se { cursor: se-resize; width: 12px; height: 12px; right: 1px; bottom: 1px; } +.ui-resizable-sw { cursor: sw-resize; width: 9px; height: 9px; left: -5px; bottom: -5px; } +.ui-resizable-nw { cursor: nw-resize; width: 9px; height: 9px; left: -5px; top: -5px; } +.ui-resizable-ne { cursor: ne-resize; width: 9px; height: 9px; right: -5px; top: -5px;}/* + * jQuery UI Selectable 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Selectable#theming + */ +.ui-selectable-helper { position: absolute; z-index: 100; border:1px dotted black; } +/* + * jQuery UI Accordion 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Accordion#theming + */ +/* IE/Win - Fix animation bug - #4615 */ +.ui-accordion { width: 100%; } +.ui-accordion .ui-accordion-header { cursor: pointer; position: relative; margin-top: 1px; zoom: 1; } +.ui-accordion .ui-accordion-li-fix { display: inline; } +.ui-accordion .ui-accordion-header-active { border-bottom: 0 !important; } +.ui-accordion .ui-accordion-header a { display: block; font-size: 1em; padding: .5em .5em .5em .7em; } +.ui-accordion-icons .ui-accordion-header a { padding-left: 2.2em; } +.ui-accordion .ui-accordion-header .ui-icon { position: absolute; left: .5em; top: 50%; margin-top: -8px; } +.ui-accordion .ui-accordion-content { padding: 1em 2.2em; border-top: 0; margin-top: -2px; position: relative; top: 1px; margin-bottom: 2px; overflow: auto; display: none; zoom: 1; } +.ui-accordion .ui-accordion-content-active { display: block; } +/* + * jQuery UI Autocomplete 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Autocomplete#theming + */ +.ui-autocomplete { position: absolute; cursor: default; } + +/* workarounds */ +* html .ui-autocomplete { width:1px; } /* without this, the menu expands to 100% in IE6 */ + +/* + * jQuery UI Menu 1.8.13 + * + * Copyright 2010, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Menu#theming + */ +.ui-menu { + list-style:none; + padding: 2px; + margin: 0; + display:block; + float: left; +} +.ui-menu .ui-menu { + margin-top: -3px; +} +.ui-menu .ui-menu-item { + margin:0; + padding: 0; + zoom: 1; + float: left; + clear: left; + width: 100%; +} +.ui-menu .ui-menu-item a { + text-decoration:none; + display:block; + padding:.2em .4em; + line-height:1.5; + zoom:1; +} +.ui-menu .ui-menu-item a.ui-state-hover, +.ui-menu .ui-menu-item a.ui-state-active { + font-weight: normal; + margin: -1px; +} +/* + * jQuery UI Button 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Button#theming + */ +.ui-button { display: inline-block; position: relative; padding: 0; margin-right: .1em; text-decoration: none !important; cursor: pointer; text-align: center; zoom: 1; overflow: visible; } /* the overflow property removes extra width in IE */ +.ui-button-icon-only { width: 2.2em; } /* to make room for the icon, a width needs to be set here */ +button.ui-button-icon-only { width: 2.4em; } /* button elements seem to need a little more width */ +.ui-button-icons-only { width: 3.4em; } +button.ui-button-icons-only { width: 3.7em; } + +/*button text element */ +.ui-button .ui-button-text { display: block; line-height: 1.4; } +.ui-button-text-only .ui-button-text { padding: .4em 1em; } +.ui-button-icon-only .ui-button-text, .ui-button-icons-only .ui-button-text { padding: .4em; text-indent: -9999999px; } +.ui-button-text-icon-primary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 1em .4em 2.1em; } +.ui-button-text-icon-secondary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 2.1em .4em 1em; } +.ui-button-text-icons .ui-button-text { padding-left: 2.1em; padding-right: 2.1em; } +/* no icon support for input elements, provide padding by default */ +input.ui-button { padding: .4em 1em; } + +/*button icon element(s) */ +.ui-button-icon-only .ui-icon, .ui-button-text-icon-primary .ui-icon, .ui-button-text-icon-secondary .ui-icon, .ui-button-text-icons .ui-icon, .ui-button-icons-only .ui-icon { position: absolute; top: 50%; margin-top: -8px; } +.ui-button-icon-only .ui-icon { left: 50%; margin-left: -8px; } +.ui-button-text-icon-primary .ui-button-icon-primary, .ui-button-text-icons .ui-button-icon-primary, .ui-button-icons-only .ui-button-icon-primary { left: .5em; } +.ui-button-text-icon-secondary .ui-button-icon-secondary, .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } +.ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } + +/*button sets*/ +.ui-buttonset { margin-right: 7px; } +.ui-buttonset .ui-button { margin-left: 0; margin-right: -.3em; } + +/* workarounds */ +button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra padding in Firefox */ +/* + * jQuery UI Dialog 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Dialog#theming + */ +.ui-dialog { position: absolute; padding: .2em; width: 300px; overflow: hidden; } +.ui-dialog .ui-dialog-titlebar { padding: .4em 1em; position: relative; } +.ui-dialog .ui-dialog-title { float: left; margin: .1em 16px .1em 0; } +.ui-dialog .ui-dialog-titlebar-close { position: absolute; right: .3em; top: 50%; width: 19px; margin: -10px 0 0 0; padding: 1px; height: 18px; } +.ui-dialog .ui-dialog-titlebar-close span { display: block; margin: 1px; } +.ui-dialog .ui-dialog-titlebar-close:hover, .ui-dialog .ui-dialog-titlebar-close:focus { padding: 0; } +.ui-dialog .ui-dialog-content { position: relative; border: 0; padding: .5em 1em; background: none; overflow: auto; zoom: 1; } +.ui-dialog .ui-dialog-buttonpane { text-align: left; border-width: 1px 0 0 0; background-image: none; margin: .5em 0 0 0; padding: .3em 1em .5em .4em; } +.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset { float: right; } +.ui-dialog .ui-dialog-buttonpane button { margin: .5em .4em .5em 0; cursor: pointer; } +.ui-dialog .ui-resizable-se { width: 14px; height: 14px; right: 3px; bottom: 3px; } +.ui-draggable .ui-dialog-titlebar { cursor: move; } +/* + * jQuery UI Slider 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Slider#theming + */ +.ui-slider { position: relative; text-align: left; } +.ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 1.2em; height: 1.2em; cursor: default; } +.ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: .7em; display: block; border: 0; background-position: 0 0; } + +.ui-slider-horizontal { height: .8em; } +.ui-slider-horizontal .ui-slider-handle { top: -.3em; margin-left: -.6em; } +.ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; } +.ui-slider-horizontal .ui-slider-range-min { left: 0; } +.ui-slider-horizontal .ui-slider-range-max { right: 0; } + +.ui-slider-vertical { width: .8em; height: 100px; } +.ui-slider-vertical .ui-slider-handle { left: -.3em; margin-left: 0; margin-bottom: -.6em; } +.ui-slider-vertical .ui-slider-range { left: 0; width: 100%; } +.ui-slider-vertical .ui-slider-range-min { bottom: 0; } +.ui-slider-vertical .ui-slider-range-max { top: 0; }/* + * jQuery UI Tabs 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Tabs#theming + */ +.ui-tabs { position: relative; padding: .2em; zoom: 1; } /* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */ +.ui-tabs .ui-tabs-nav { margin: 0; padding: .2em .2em 0; } +.ui-tabs .ui-tabs-nav li { list-style: none; float: left; position: relative; top: 1px; margin: 0 .2em 1px 0; border-bottom: 0 !important; padding: 0; white-space: nowrap; } +.ui-tabs .ui-tabs-nav li a { float: left; padding: .5em 1em; text-decoration: none; } +.ui-tabs .ui-tabs-nav li.ui-tabs-selected { margin-bottom: 0; padding-bottom: 1px; } +.ui-tabs .ui-tabs-nav li.ui-tabs-selected a, .ui-tabs .ui-tabs-nav li.ui-state-disabled a, .ui-tabs .ui-tabs-nav li.ui-state-processing a { cursor: text; } +.ui-tabs .ui-tabs-nav li a, .ui-tabs.ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-selected a { cursor: pointer; } /* first selector in group seems obsolete, but required to overcome bug in Opera applying cursor: text overall if defined elsewhere... */ +.ui-tabs .ui-tabs-panel { display: block; border-width: 0; padding: 1em 1.4em; background: none; } +.ui-tabs .ui-tabs-hide { display: none !important; } +/* + * jQuery UI Datepicker 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Datepicker#theming + */ +.ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; } +.ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; } +.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; } +.ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; } +.ui-datepicker .ui-datepicker-prev { left:2px; } +.ui-datepicker .ui-datepicker-next { right:2px; } +.ui-datepicker .ui-datepicker-prev-hover { left:1px; } +.ui-datepicker .ui-datepicker-next-hover { right:1px; } +.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px; } +.ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; } +.ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; } +.ui-datepicker select.ui-datepicker-month-year {width: 100%;} +.ui-datepicker select.ui-datepicker-month, +.ui-datepicker select.ui-datepicker-year { width: 49%;} +.ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; } +.ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0; } +.ui-datepicker td { border: 0; padding: 1px; } +.ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; } +.ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; } +.ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; } +.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; } + +/* with multiple calendars */ +.ui-datepicker.ui-datepicker-multi { width:auto; } +.ui-datepicker-multi .ui-datepicker-group { float:left; } +.ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; } +.ui-datepicker-multi-2 .ui-datepicker-group { width:50%; } +.ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; } +.ui-datepicker-multi-4 .ui-datepicker-group { width:25%; } +.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; } +.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; } +.ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; } +.ui-datepicker-row-break { clear:both; width:100%; } + +/* RTL support */ +.ui-datepicker-rtl { direction: rtl; } +.ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; } +.ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; } +.ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; } +.ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; } +.ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; } +.ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; } +.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; } +.ui-datepicker-rtl .ui-datepicker-group { float:right; } +.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; } +.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; } + +/* IE6 IFRAME FIX (taken from datepicker 1.5.3 */ +.ui-datepicker-cover { + display: none; /*sorry for IE5*/ + display/**/: block; /*sorry for IE5*/ + position: absolute; /*must have*/ + z-index: -1; /*must have*/ + filter: mask(); /*must have*/ + top: -4px; /*must have*/ + left: -4px; /*must have*/ + width: 200px; /*must have*/ + height: 200px; /*must have*/ +}/* + * jQuery UI Progressbar 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Progressbar#theming + */ +.ui-progressbar { height:2em; text-align: left; } +.ui-progressbar .ui-progressbar-value {margin: -1px; height:100%; } \ No newline at end of file diff --git a/test/views/css/cupertino/images/.svn/all-wcprops b/test/views/css/cupertino/images/.svn/all-wcprops new file mode 100644 index 0000000..7e59512 --- /dev/null +++ b/test/views/css/cupertino/images/.svn/all-wcprops @@ -0,0 +1,89 @@ +K 25 +svn:wc:ra_dav:version-url +V 70 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/images +END +ui-icons_2e83ff_256x240.png +K 25 +svn:wc:ra_dav:version-url +V 98 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/images/ui-icons_2e83ff_256x240.png +END +ui-bg_highlight-hard_100_f2f5f7_1x100.png +K 25 +svn:wc:ra_dav:version-url +V 112 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/images/ui-bg_highlight-hard_100_f2f5f7_1x100.png +END +ui-bg_glass_100_e4f1fb_1x400.png +K 25 +svn:wc:ra_dav:version-url +V 103 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/images/ui-bg_glass_100_e4f1fb_1x400.png +END +ui-bg_glass_80_d7ebf9_1x400.png +K 25 +svn:wc:ra_dav:version-url +V 102 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/images/ui-bg_glass_80_d7ebf9_1x400.png +END +ui-icons_2694e8_256x240.png +K 25 +svn:wc:ra_dav:version-url +V 98 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/images/ui-icons_2694e8_256x240.png +END +ui-bg_flat_15_cd0a0a_40x100.png +K 25 +svn:wc:ra_dav:version-url +V 102 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/images/ui-bg_flat_15_cd0a0a_40x100.png +END +ui-icons_3d80b3_256x240.png +K 25 +svn:wc:ra_dav:version-url +V 98 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/images/ui-icons_3d80b3_256x240.png +END +ui-icons_ffffff_256x240.png +K 25 +svn:wc:ra_dav:version-url +V 98 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/images/ui-icons_ffffff_256x240.png +END +ui-bg_highlight-hard_70_000000_1x100.png +K 25 +svn:wc:ra_dav:version-url +V 111 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/images/ui-bg_highlight-hard_70_000000_1x100.png +END +ui-bg_highlight-soft_25_ffef8f_1x100.png +K 25 +svn:wc:ra_dav:version-url +V 111 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/images/ui-bg_highlight-soft_25_ffef8f_1x100.png +END +ui-bg_diagonals-thick_90_eeeeee_40x40.png +K 25 +svn:wc:ra_dav:version-url +V 112 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/images/ui-bg_diagonals-thick_90_eeeeee_40x40.png +END +ui-icons_72a7cf_256x240.png +K 25 +svn:wc:ra_dav:version-url +V 98 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/images/ui-icons_72a7cf_256x240.png +END +ui-bg_glass_50_3baae3_1x400.png +K 25 +svn:wc:ra_dav:version-url +V 102 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/images/ui-bg_glass_50_3baae3_1x400.png +END +ui-bg_highlight-soft_100_deedf7_1x100.png +K 25 +svn:wc:ra_dav:version-url +V 112 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/cupertino/images/ui-bg_highlight-soft_100_deedf7_1x100.png +END diff --git a/test/views/css/cupertino/images/.svn/entries b/test/views/css/cupertino/images/.svn/entries new file mode 100644 index 0000000..dba6e3b --- /dev/null +++ b/test/views/css/cupertino/images/.svn/entries @@ -0,0 +1,504 @@ +10 + +dir +2 +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework/todotree/views/css/cupertino/images +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework + + + +2011-06-10T16:28:28.115490Z +2 +hairyhum + + + + + + + + + + + + + + +ac95b44f-471c-48cd-8414-b967058da7d4 + +ui-icons_2e83ff_256x240.png +file + + + + +2011-06-01T07:59:44.000000Z +2b99a5e48d3c3957d03027d36a25e8bb +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +4369 + +ui-bg_highlight-hard_100_f2f5f7_1x100.png +file + + + + +2011-06-01T07:59:44.000000Z +8a3f00ec71e249407e06f9273bf6aa20 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +103 + +ui-bg_glass_100_e4f1fb_1x400.png +file + + + + +2011-06-01T07:59:44.000000Z +037d2fd1ee6fe1768020e5bf6c5768f1 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +119 + +ui-bg_glass_80_d7ebf9_1x400.png +file + + + + +2011-06-01T07:59:44.000000Z +0687b0cac1bf682ba9c66efca0c2e30e +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +124 + +ui-icons_2694e8_256x240.png +file + + + + +2011-06-01T07:59:44.000000Z +6df29a38ddb3190f593e02c6d670e526 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +4369 + +ui-bg_flat_15_cd0a0a_40x100.png +file + + + + +2011-06-01T07:59:44.000000Z +09157b3a07628d31140ca21018c799f7 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +181 + +ui-icons_3d80b3_256x240.png +file + + + + +2011-06-01T07:59:44.000000Z +205a7ce2e39007d40bdbf94825c724b0 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +4369 + +ui-icons_ffffff_256x240.png +file + + + + +2011-06-01T07:59:44.000000Z +342bc03f6264c75d3f1d7f99e34295b9 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +4369 + +ui-bg_highlight-hard_70_000000_1x100.png +file + + + + +2011-06-01T07:59:44.000000Z +485eaacf0adca5834aa66dcbcc0b69df +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +118 + +ui-bg_highlight-soft_25_ffef8f_1x100.png +file + + + + +2011-06-01T07:59:44.000000Z +d3cce7d7f63d015cdb0b56941d581060 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +119 + +ui-bg_diagonals-thick_90_eeeeee_40x40.png +file + + + + +2011-06-01T07:59:44.000000Z +d987b086c6e96fb45055361de17ac08e +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +251 + +ui-icons_72a7cf_256x240.png +file + + + + +2011-06-01T07:59:44.000000Z +26901adab4b9797711e41a6a64491449 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +4369 + +ui-bg_glass_50_3baae3_1x400.png +file + + + + +2011-06-01T07:59:44.000000Z +40dbd3438ae9348cff27c586eb6b142c +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +131 + +ui-bg_highlight-soft_100_deedf7_1x100.png +file + + + + +2011-06-01T07:59:44.000000Z +e1dfd54e95a50a152c448ce0f85496dd +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +104 + diff --git a/test/views/css/cupertino/images/.svn/prop-base/ui-bg_diagonals-thick_90_eeeeee_40x40.png.svn-base b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_diagonals-thick_90_eeeeee_40x40.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_diagonals-thick_90_eeeeee_40x40.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/cupertino/images/.svn/prop-base/ui-bg_flat_15_cd0a0a_40x100.png.svn-base b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_flat_15_cd0a0a_40x100.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_flat_15_cd0a0a_40x100.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/cupertino/images/.svn/prop-base/ui-bg_glass_100_e4f1fb_1x400.png.svn-base b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_glass_100_e4f1fb_1x400.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_glass_100_e4f1fb_1x400.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/cupertino/images/.svn/prop-base/ui-bg_glass_50_3baae3_1x400.png.svn-base b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_glass_50_3baae3_1x400.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_glass_50_3baae3_1x400.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/cupertino/images/.svn/prop-base/ui-bg_glass_80_d7ebf9_1x400.png.svn-base b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_glass_80_d7ebf9_1x400.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_glass_80_d7ebf9_1x400.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/cupertino/images/.svn/prop-base/ui-bg_highlight-hard_100_f2f5f7_1x100.png.svn-base b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_highlight-hard_100_f2f5f7_1x100.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_highlight-hard_100_f2f5f7_1x100.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/cupertino/images/.svn/prop-base/ui-bg_highlight-hard_70_000000_1x100.png.svn-base b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_highlight-hard_70_000000_1x100.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_highlight-hard_70_000000_1x100.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/cupertino/images/.svn/prop-base/ui-bg_highlight-soft_100_deedf7_1x100.png.svn-base b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_highlight-soft_100_deedf7_1x100.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_highlight-soft_100_deedf7_1x100.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/cupertino/images/.svn/prop-base/ui-bg_highlight-soft_25_ffef8f_1x100.png.svn-base b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_highlight-soft_25_ffef8f_1x100.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/cupertino/images/.svn/prop-base/ui-bg_highlight-soft_25_ffef8f_1x100.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/cupertino/images/.svn/prop-base/ui-icons_2694e8_256x240.png.svn-base b/test/views/css/cupertino/images/.svn/prop-base/ui-icons_2694e8_256x240.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/cupertino/images/.svn/prop-base/ui-icons_2694e8_256x240.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/cupertino/images/.svn/prop-base/ui-icons_2e83ff_256x240.png.svn-base b/test/views/css/cupertino/images/.svn/prop-base/ui-icons_2e83ff_256x240.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/cupertino/images/.svn/prop-base/ui-icons_2e83ff_256x240.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/cupertino/images/.svn/prop-base/ui-icons_3d80b3_256x240.png.svn-base b/test/views/css/cupertino/images/.svn/prop-base/ui-icons_3d80b3_256x240.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/cupertino/images/.svn/prop-base/ui-icons_3d80b3_256x240.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/cupertino/images/.svn/prop-base/ui-icons_72a7cf_256x240.png.svn-base b/test/views/css/cupertino/images/.svn/prop-base/ui-icons_72a7cf_256x240.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/cupertino/images/.svn/prop-base/ui-icons_72a7cf_256x240.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/cupertino/images/.svn/prop-base/ui-icons_ffffff_256x240.png.svn-base b/test/views/css/cupertino/images/.svn/prop-base/ui-icons_ffffff_256x240.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/cupertino/images/.svn/prop-base/ui-icons_ffffff_256x240.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/cupertino/images/.svn/text-base/ui-bg_diagonals-thick_90_eeeeee_40x40.png.svn-base b/test/views/css/cupertino/images/.svn/text-base/ui-bg_diagonals-thick_90_eeeeee_40x40.png.svn-base new file mode 100644 index 0000000..6348115 Binary files /dev/null and b/test/views/css/cupertino/images/.svn/text-base/ui-bg_diagonals-thick_90_eeeeee_40x40.png.svn-base differ diff --git a/test/views/css/cupertino/images/.svn/text-base/ui-bg_flat_15_cd0a0a_40x100.png.svn-base b/test/views/css/cupertino/images/.svn/text-base/ui-bg_flat_15_cd0a0a_40x100.png.svn-base new file mode 100644 index 0000000..7680b54 Binary files /dev/null and b/test/views/css/cupertino/images/.svn/text-base/ui-bg_flat_15_cd0a0a_40x100.png.svn-base differ diff --git a/test/views/css/cupertino/images/.svn/text-base/ui-bg_glass_100_e4f1fb_1x400.png.svn-base b/test/views/css/cupertino/images/.svn/text-base/ui-bg_glass_100_e4f1fb_1x400.png.svn-base new file mode 100644 index 0000000..705a32e Binary files /dev/null and b/test/views/css/cupertino/images/.svn/text-base/ui-bg_glass_100_e4f1fb_1x400.png.svn-base differ diff --git a/test/views/css/cupertino/images/.svn/text-base/ui-bg_glass_50_3baae3_1x400.png.svn-base b/test/views/css/cupertino/images/.svn/text-base/ui-bg_glass_50_3baae3_1x400.png.svn-base new file mode 100644 index 0000000..baabca6 Binary files /dev/null and b/test/views/css/cupertino/images/.svn/text-base/ui-bg_glass_50_3baae3_1x400.png.svn-base differ diff --git a/test/views/css/cupertino/images/.svn/text-base/ui-bg_glass_80_d7ebf9_1x400.png.svn-base b/test/views/css/cupertino/images/.svn/text-base/ui-bg_glass_80_d7ebf9_1x400.png.svn-base new file mode 100644 index 0000000..d9387e9 Binary files /dev/null and b/test/views/css/cupertino/images/.svn/text-base/ui-bg_glass_80_d7ebf9_1x400.png.svn-base differ diff --git a/test/views/css/cupertino/images/.svn/text-base/ui-bg_highlight-hard_100_f2f5f7_1x100.png.svn-base b/test/views/css/cupertino/images/.svn/text-base/ui-bg_highlight-hard_100_f2f5f7_1x100.png.svn-base new file mode 100644 index 0000000..28b566c Binary files /dev/null and b/test/views/css/cupertino/images/.svn/text-base/ui-bg_highlight-hard_100_f2f5f7_1x100.png.svn-base differ diff --git a/test/views/css/cupertino/images/.svn/text-base/ui-bg_highlight-hard_70_000000_1x100.png.svn-base b/test/views/css/cupertino/images/.svn/text-base/ui-bg_highlight-hard_70_000000_1x100.png.svn-base new file mode 100644 index 0000000..d588297 Binary files /dev/null and b/test/views/css/cupertino/images/.svn/text-base/ui-bg_highlight-hard_70_000000_1x100.png.svn-base differ diff --git a/test/views/css/cupertino/images/.svn/text-base/ui-bg_highlight-soft_100_deedf7_1x100.png.svn-base b/test/views/css/cupertino/images/.svn/text-base/ui-bg_highlight-soft_100_deedf7_1x100.png.svn-base new file mode 100644 index 0000000..2289d3c Binary files /dev/null and b/test/views/css/cupertino/images/.svn/text-base/ui-bg_highlight-soft_100_deedf7_1x100.png.svn-base differ diff --git a/test/views/css/cupertino/images/.svn/text-base/ui-bg_highlight-soft_25_ffef8f_1x100.png.svn-base b/test/views/css/cupertino/images/.svn/text-base/ui-bg_highlight-soft_25_ffef8f_1x100.png.svn-base new file mode 100644 index 0000000..0de3275 Binary files /dev/null and b/test/views/css/cupertino/images/.svn/text-base/ui-bg_highlight-soft_25_ffef8f_1x100.png.svn-base differ diff --git a/test/views/css/cupertino/images/.svn/text-base/ui-icons_2694e8_256x240.png.svn-base b/test/views/css/cupertino/images/.svn/text-base/ui-icons_2694e8_256x240.png.svn-base new file mode 100644 index 0000000..e62b8f7 Binary files /dev/null and b/test/views/css/cupertino/images/.svn/text-base/ui-icons_2694e8_256x240.png.svn-base differ diff --git a/test/views/css/cupertino/images/.svn/text-base/ui-icons_2e83ff_256x240.png.svn-base b/test/views/css/cupertino/images/.svn/text-base/ui-icons_2e83ff_256x240.png.svn-base new file mode 100644 index 0000000..09d1cdc Binary files /dev/null and b/test/views/css/cupertino/images/.svn/text-base/ui-icons_2e83ff_256x240.png.svn-base differ diff --git a/test/views/css/cupertino/images/.svn/text-base/ui-icons_3d80b3_256x240.png.svn-base b/test/views/css/cupertino/images/.svn/text-base/ui-icons_3d80b3_256x240.png.svn-base new file mode 100644 index 0000000..52c3cc6 Binary files /dev/null and b/test/views/css/cupertino/images/.svn/text-base/ui-icons_3d80b3_256x240.png.svn-base differ diff --git a/test/views/css/cupertino/images/.svn/text-base/ui-icons_72a7cf_256x240.png.svn-base b/test/views/css/cupertino/images/.svn/text-base/ui-icons_72a7cf_256x240.png.svn-base new file mode 100644 index 0000000..0d20b73 Binary files /dev/null and b/test/views/css/cupertino/images/.svn/text-base/ui-icons_72a7cf_256x240.png.svn-base differ diff --git a/test/views/css/cupertino/images/.svn/text-base/ui-icons_ffffff_256x240.png.svn-base b/test/views/css/cupertino/images/.svn/text-base/ui-icons_ffffff_256x240.png.svn-base new file mode 100644 index 0000000..42f8f99 Binary files /dev/null and b/test/views/css/cupertino/images/.svn/text-base/ui-icons_ffffff_256x240.png.svn-base differ diff --git a/test/views/css/cupertino/images/ui-bg_diagonals-thick_90_eeeeee_40x40.png b/test/views/css/cupertino/images/ui-bg_diagonals-thick_90_eeeeee_40x40.png new file mode 100644 index 0000000..6348115 Binary files /dev/null and b/test/views/css/cupertino/images/ui-bg_diagonals-thick_90_eeeeee_40x40.png differ diff --git a/test/views/css/cupertino/images/ui-bg_flat_15_cd0a0a_40x100.png b/test/views/css/cupertino/images/ui-bg_flat_15_cd0a0a_40x100.png new file mode 100644 index 0000000..7680b54 Binary files /dev/null and b/test/views/css/cupertino/images/ui-bg_flat_15_cd0a0a_40x100.png differ diff --git a/test/views/css/cupertino/images/ui-bg_glass_100_e4f1fb_1x400.png b/test/views/css/cupertino/images/ui-bg_glass_100_e4f1fb_1x400.png new file mode 100644 index 0000000..705a32e Binary files /dev/null and b/test/views/css/cupertino/images/ui-bg_glass_100_e4f1fb_1x400.png differ diff --git a/test/views/css/cupertino/images/ui-bg_glass_50_3baae3_1x400.png b/test/views/css/cupertino/images/ui-bg_glass_50_3baae3_1x400.png new file mode 100644 index 0000000..baabca6 Binary files /dev/null and b/test/views/css/cupertino/images/ui-bg_glass_50_3baae3_1x400.png differ diff --git a/test/views/css/cupertino/images/ui-bg_glass_80_d7ebf9_1x400.png b/test/views/css/cupertino/images/ui-bg_glass_80_d7ebf9_1x400.png new file mode 100644 index 0000000..d9387e9 Binary files /dev/null and b/test/views/css/cupertino/images/ui-bg_glass_80_d7ebf9_1x400.png differ diff --git a/test/views/css/cupertino/images/ui-bg_highlight-hard_100_f2f5f7_1x100.png b/test/views/css/cupertino/images/ui-bg_highlight-hard_100_f2f5f7_1x100.png new file mode 100644 index 0000000..28b566c Binary files /dev/null and b/test/views/css/cupertino/images/ui-bg_highlight-hard_100_f2f5f7_1x100.png differ diff --git a/test/views/css/cupertino/images/ui-bg_highlight-hard_70_000000_1x100.png b/test/views/css/cupertino/images/ui-bg_highlight-hard_70_000000_1x100.png new file mode 100644 index 0000000..d588297 Binary files /dev/null and b/test/views/css/cupertino/images/ui-bg_highlight-hard_70_000000_1x100.png differ diff --git a/test/views/css/cupertino/images/ui-bg_highlight-soft_100_deedf7_1x100.png b/test/views/css/cupertino/images/ui-bg_highlight-soft_100_deedf7_1x100.png new file mode 100644 index 0000000..2289d3c Binary files /dev/null and b/test/views/css/cupertino/images/ui-bg_highlight-soft_100_deedf7_1x100.png differ diff --git a/test/views/css/cupertino/images/ui-bg_highlight-soft_25_ffef8f_1x100.png b/test/views/css/cupertino/images/ui-bg_highlight-soft_25_ffef8f_1x100.png new file mode 100644 index 0000000..0de3275 Binary files /dev/null and b/test/views/css/cupertino/images/ui-bg_highlight-soft_25_ffef8f_1x100.png differ diff --git a/test/views/css/cupertino/images/ui-icons_2694e8_256x240.png b/test/views/css/cupertino/images/ui-icons_2694e8_256x240.png new file mode 100644 index 0000000..e62b8f7 Binary files /dev/null and b/test/views/css/cupertino/images/ui-icons_2694e8_256x240.png differ diff --git a/test/views/css/cupertino/images/ui-icons_2e83ff_256x240.png b/test/views/css/cupertino/images/ui-icons_2e83ff_256x240.png new file mode 100644 index 0000000..09d1cdc Binary files /dev/null and b/test/views/css/cupertino/images/ui-icons_2e83ff_256x240.png differ diff --git a/test/views/css/cupertino/images/ui-icons_3d80b3_256x240.png b/test/views/css/cupertino/images/ui-icons_3d80b3_256x240.png new file mode 100644 index 0000000..52c3cc6 Binary files /dev/null and b/test/views/css/cupertino/images/ui-icons_3d80b3_256x240.png differ diff --git a/test/views/css/cupertino/images/ui-icons_72a7cf_256x240.png b/test/views/css/cupertino/images/ui-icons_72a7cf_256x240.png new file mode 100644 index 0000000..0d20b73 Binary files /dev/null and b/test/views/css/cupertino/images/ui-icons_72a7cf_256x240.png differ diff --git a/test/views/css/cupertino/images/ui-icons_ffffff_256x240.png b/test/views/css/cupertino/images/ui-icons_ffffff_256x240.png new file mode 100644 index 0000000..42f8f99 Binary files /dev/null and b/test/views/css/cupertino/images/ui-icons_ffffff_256x240.png differ diff --git a/test/views/css/cupertino/jquery-ui-1.8.13.custom.css b/test/views/css/cupertino/jquery-ui-1.8.13.custom.css new file mode 100644 index 0000000..ff54026 --- /dev/null +++ b/test/views/css/cupertino/jquery-ui-1.8.13.custom.css @@ -0,0 +1,578 @@ +/* + * jQuery UI CSS Framework 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Theming/API + */ + +/* Layout helpers +----------------------------------*/ +.ui-helper-hidden { display: none; } +.ui-helper-hidden-accessible { position: absolute !important; clip: rect(1px 1px 1px 1px); clip: rect(1px,1px,1px,1px); } +.ui-helper-reset { margin: 0; padding: 0; border: 0; outline: 0; line-height: 1.3; text-decoration: none; font-size: 100%; list-style: none; } +.ui-helper-clearfix:after { content: "."; display: block; height: 0; clear: both; visibility: hidden; } +.ui-helper-clearfix { display: inline-block; } +/* required comment for clearfix to work in Opera \*/ +* html .ui-helper-clearfix { height:1%; } +.ui-helper-clearfix { display:block; } +/* end clearfix */ +.ui-helper-zfix { width: 100%; height: 100%; top: 0; left: 0; position: absolute; opacity: 0; filter:Alpha(Opacity=0); } + + +/* Interaction Cues +----------------------------------*/ +.ui-state-disabled { cursor: default !important; } + + +/* Icons +----------------------------------*/ + +/* states and images */ +.ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; } + + +/* Misc visuals +----------------------------------*/ + +/* Overlays */ +.ui-widget-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; } + + +/* + * jQuery UI CSS Framework 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Theming/API + * + * To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Lucida%20Grande,%20Lucida%20Sans,%20Arial,%20sans-serif&fwDefault=bold&fsDefault=1.1em&cornerRadius=6px&bgColorHeader=deedf7&bgTextureHeader=03_highlight_soft.png&bgImgOpacityHeader=100&borderColorHeader=aed0ea&fcHeader=222222&iconColorHeader=72a7cf&bgColorContent=f2f5f7&bgTextureContent=04_highlight_hard.png&bgImgOpacityContent=100&borderColorContent=dddddd&fcContent=362b36&iconColorContent=72a7cf&bgColorDefault=d7ebf9&bgTextureDefault=02_glass.png&bgImgOpacityDefault=80&borderColorDefault=aed0ea&fcDefault=2779aa&iconColorDefault=3d80b3&bgColorHover=e4f1fb&bgTextureHover=02_glass.png&bgImgOpacityHover=100&borderColorHover=74b2e2&fcHover=0070a3&iconColorHover=2694e8&bgColorActive=3baae3&bgTextureActive=02_glass.png&bgImgOpacityActive=50&borderColorActive=2694e8&fcActive=ffffff&iconColorActive=ffffff&bgColorHighlight=ffef8f&bgTextureHighlight=03_highlight_soft.png&bgImgOpacityHighlight=25&borderColorHighlight=f9dd34&fcHighlight=363636&iconColorHighlight=2e83ff&bgColorError=cd0a0a&bgTextureError=01_flat.png&bgImgOpacityError=15&borderColorError=cd0a0a&fcError=ffffff&iconColorError=ffffff&bgColorOverlay=eeeeee&bgTextureOverlay=08_diagonals_thick.png&bgImgOpacityOverlay=90&opacityOverlay=80&bgColorShadow=000000&bgTextureShadow=04_highlight_hard.png&bgImgOpacityShadow=70&opacityShadow=30&thicknessShadow=7px&offsetTopShadow=-7px&offsetLeftShadow=-7px&cornerRadiusShadow=8px + */ + + +/* Component containers +----------------------------------*/ +.ui-widget { font-family: Lucida Grande, Lucida Sans, Arial, sans-serif; font-size: 1.1em; } +.ui-widget .ui-widget { font-size: 1em; } +.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-family: Lucida Grande, Lucida Sans, Arial, sans-serif; font-size: 1em; } +.ui-widget-content { border: 1px solid #dddddd; background: #f2f5f7 url(images/ui-bg_highlight-hard_100_f2f5f7_1x100.png) 50% top repeat-x; color: #362b36; } +.ui-widget-content a { color: #362b36; } +.ui-widget-header { border: 1px solid #aed0ea; background: #deedf7 url(images/ui-bg_highlight-soft_100_deedf7_1x100.png) 50% 50% repeat-x; color: #222222; font-weight: bold; } +.ui-widget-header a { color: #222222; } + +/* Interaction states +----------------------------------*/ +.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #aed0ea; background: #d7ebf9 url(images/ui-bg_glass_80_d7ebf9_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #2779aa; } +.ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #2779aa; text-decoration: none; } +.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { border: 1px solid #74b2e2; background: #e4f1fb url(images/ui-bg_glass_100_e4f1fb_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #0070a3; } +.ui-state-hover a, .ui-state-hover a:hover { color: #0070a3; text-decoration: none; } +.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #2694e8; background: #3baae3 url(images/ui-bg_glass_50_3baae3_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #ffffff; } +.ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #ffffff; text-decoration: none; } +.ui-widget :active { outline: none; } + +/* Interaction Cues +----------------------------------*/ +.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {border: 1px solid #f9dd34; background: #ffef8f url(images/ui-bg_highlight-soft_25_ffef8f_1x100.png) 50% top repeat-x; color: #363636; } +.ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636; } +.ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid #cd0a0a; background: #cd0a0a url(images/ui-bg_flat_15_cd0a0a_40x100.png) 50% 50% repeat-x; color: #ffffff; } +.ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #ffffff; } +.ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #ffffff; } +.ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; } +.ui-priority-secondary, .ui-widget-content .ui-priority-secondary, .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; } +.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; } + +/* Icons +----------------------------------*/ + +/* states and images */ +.ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_72a7cf_256x240.png); } +.ui-widget-content .ui-icon {background-image: url(images/ui-icons_72a7cf_256x240.png); } +.ui-widget-header .ui-icon {background-image: url(images/ui-icons_72a7cf_256x240.png); } +.ui-state-default .ui-icon { background-image: url(images/ui-icons_3d80b3_256x240.png); } +.ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_2694e8_256x240.png); } +.ui-state-active .ui-icon {background-image: url(images/ui-icons_ffffff_256x240.png); } +.ui-state-highlight .ui-icon {background-image: url(images/ui-icons_2e83ff_256x240.png); } +.ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_ffffff_256x240.png); } + +/* positioning */ +.ui-icon-carat-1-n { background-position: 0 0; } +.ui-icon-carat-1-ne { background-position: -16px 0; } +.ui-icon-carat-1-e { background-position: -32px 0; } +.ui-icon-carat-1-se { background-position: -48px 0; } +.ui-icon-carat-1-s { background-position: -64px 0; } +.ui-icon-carat-1-sw { background-position: -80px 0; } +.ui-icon-carat-1-w { background-position: -96px 0; } +.ui-icon-carat-1-nw { background-position: -112px 0; } +.ui-icon-carat-2-n-s { background-position: -128px 0; } +.ui-icon-carat-2-e-w { background-position: -144px 0; } +.ui-icon-triangle-1-n { background-position: 0 -16px; } +.ui-icon-triangle-1-ne { background-position: -16px -16px; } +.ui-icon-triangle-1-e { background-position: -32px -16px; } +.ui-icon-triangle-1-se { background-position: -48px -16px; } +.ui-icon-triangle-1-s { background-position: -64px -16px; } +.ui-icon-triangle-1-sw { background-position: -80px -16px; } +.ui-icon-triangle-1-w { background-position: -96px -16px; } +.ui-icon-triangle-1-nw { background-position: -112px -16px; } +.ui-icon-triangle-2-n-s { background-position: -128px -16px; } +.ui-icon-triangle-2-e-w { background-position: -144px -16px; } +.ui-icon-arrow-1-n { background-position: 0 -32px; } +.ui-icon-arrow-1-ne { background-position: -16px -32px; } +.ui-icon-arrow-1-e { background-position: -32px -32px; } +.ui-icon-arrow-1-se { background-position: -48px -32px; } +.ui-icon-arrow-1-s { background-position: -64px -32px; } +.ui-icon-arrow-1-sw { background-position: -80px -32px; } +.ui-icon-arrow-1-w { background-position: -96px -32px; } +.ui-icon-arrow-1-nw { background-position: -112px -32px; } +.ui-icon-arrow-2-n-s { background-position: -128px -32px; } +.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; } +.ui-icon-arrow-2-e-w { background-position: -160px -32px; } +.ui-icon-arrow-2-se-nw { background-position: -176px -32px; } +.ui-icon-arrowstop-1-n { background-position: -192px -32px; } +.ui-icon-arrowstop-1-e { background-position: -208px -32px; } +.ui-icon-arrowstop-1-s { background-position: -224px -32px; } +.ui-icon-arrowstop-1-w { background-position: -240px -32px; } +.ui-icon-arrowthick-1-n { background-position: 0 -48px; } +.ui-icon-arrowthick-1-ne { background-position: -16px -48px; } +.ui-icon-arrowthick-1-e { background-position: -32px -48px; } +.ui-icon-arrowthick-1-se { background-position: -48px -48px; } +.ui-icon-arrowthick-1-s { background-position: -64px -48px; } +.ui-icon-arrowthick-1-sw { background-position: -80px -48px; } +.ui-icon-arrowthick-1-w { background-position: -96px -48px; } +.ui-icon-arrowthick-1-nw { background-position: -112px -48px; } +.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; } +.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; } +.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; } +.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; } +.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; } +.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; } +.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; } +.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; } +.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; } +.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; } +.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; } +.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; } +.ui-icon-arrowreturn-1-w { background-position: -64px -64px; } +.ui-icon-arrowreturn-1-n { background-position: -80px -64px; } +.ui-icon-arrowreturn-1-e { background-position: -96px -64px; } +.ui-icon-arrowreturn-1-s { background-position: -112px -64px; } +.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; } +.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; } +.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; } +.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; } +.ui-icon-arrow-4 { background-position: 0 -80px; } +.ui-icon-arrow-4-diag { background-position: -16px -80px; } +.ui-icon-extlink { background-position: -32px -80px; } +.ui-icon-newwin { background-position: -48px -80px; } +.ui-icon-refresh { background-position: -64px -80px; } +.ui-icon-shuffle { background-position: -80px -80px; } +.ui-icon-transfer-e-w { background-position: -96px -80px; } +.ui-icon-transferthick-e-w { background-position: -112px -80px; } +.ui-icon-folder-collapsed { background-position: 0 -96px; } +.ui-icon-folder-open { background-position: -16px -96px; } +.ui-icon-document { background-position: -32px -96px; } +.ui-icon-document-b { background-position: -48px -96px; } +.ui-icon-note { background-position: -64px -96px; } +.ui-icon-mail-closed { background-position: -80px -96px; } +.ui-icon-mail-open { background-position: -96px -96px; } +.ui-icon-suitcase { background-position: -112px -96px; } +.ui-icon-comment { background-position: -128px -96px; } +.ui-icon-person { background-position: -144px -96px; } +.ui-icon-print { background-position: -160px -96px; } +.ui-icon-trash { background-position: -176px -96px; } +.ui-icon-locked { background-position: -192px -96px; } +.ui-icon-unlocked { background-position: -208px -96px; } +.ui-icon-bookmark { background-position: -224px -96px; } +.ui-icon-tag { background-position: -240px -96px; } +.ui-icon-home { background-position: 0 -112px; } +.ui-icon-flag { background-position: -16px -112px; } +.ui-icon-calendar { background-position: -32px -112px; } +.ui-icon-cart { background-position: -48px -112px; } +.ui-icon-pencil { background-position: -64px -112px; } +.ui-icon-clock { background-position: -80px -112px; } +.ui-icon-disk { background-position: -96px -112px; } +.ui-icon-calculator { background-position: -112px -112px; } +.ui-icon-zoomin { background-position: -128px -112px; } +.ui-icon-zoomout { background-position: -144px -112px; } +.ui-icon-search { background-position: -160px -112px; } +.ui-icon-wrench { background-position: -176px -112px; } +.ui-icon-gear { background-position: -192px -112px; } +.ui-icon-heart { background-position: -208px -112px; } +.ui-icon-star { background-position: -224px -112px; } +.ui-icon-link { background-position: -240px -112px; } +.ui-icon-cancel { background-position: 0 -128px; } +.ui-icon-plus { background-position: -16px -128px; } +.ui-icon-plusthick { background-position: -32px -128px; } +.ui-icon-minus { background-position: -48px -128px; } +.ui-icon-minusthick { background-position: -64px -128px; } +.ui-icon-close { background-position: -80px -128px; } +.ui-icon-closethick { background-position: -96px -128px; } +.ui-icon-key { background-position: -112px -128px; } +.ui-icon-lightbulb { background-position: -128px -128px; } +.ui-icon-scissors { background-position: -144px -128px; } +.ui-icon-clipboard { background-position: -160px -128px; } +.ui-icon-copy { background-position: -176px -128px; } +.ui-icon-contact { background-position: -192px -128px; } +.ui-icon-image { background-position: -208px -128px; } +.ui-icon-video { background-position: -224px -128px; } +.ui-icon-script { background-position: -240px -128px; } +.ui-icon-alert { background-position: 0 -144px; } +.ui-icon-info { background-position: -16px -144px; } +.ui-icon-notice { background-position: -32px -144px; } +.ui-icon-help { background-position: -48px -144px; } +.ui-icon-check { background-position: -64px -144px; } +.ui-icon-bullet { background-position: -80px -144px; } +.ui-icon-radio-off { background-position: -96px -144px; } +.ui-icon-radio-on { background-position: -112px -144px; } +.ui-icon-pin-w { background-position: -128px -144px; } +.ui-icon-pin-s { background-position: -144px -144px; } +.ui-icon-play { background-position: 0 -160px; } +.ui-icon-pause { background-position: -16px -160px; } +.ui-icon-seek-next { background-position: -32px -160px; } +.ui-icon-seek-prev { background-position: -48px -160px; } +.ui-icon-seek-end { background-position: -64px -160px; } +.ui-icon-seek-start { background-position: -80px -160px; } +/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */ +.ui-icon-seek-first { background-position: -80px -160px; } +.ui-icon-stop { background-position: -96px -160px; } +.ui-icon-eject { background-position: -112px -160px; } +.ui-icon-volume-off { background-position: -128px -160px; } +.ui-icon-volume-on { background-position: -144px -160px; } +.ui-icon-power { background-position: 0 -176px; } +.ui-icon-signal-diag { background-position: -16px -176px; } +.ui-icon-signal { background-position: -32px -176px; } +.ui-icon-battery-0 { background-position: -48px -176px; } +.ui-icon-battery-1 { background-position: -64px -176px; } +.ui-icon-battery-2 { background-position: -80px -176px; } +.ui-icon-battery-3 { background-position: -96px -176px; } +.ui-icon-circle-plus { background-position: 0 -192px; } +.ui-icon-circle-minus { background-position: -16px -192px; } +.ui-icon-circle-close { background-position: -32px -192px; } +.ui-icon-circle-triangle-e { background-position: -48px -192px; } +.ui-icon-circle-triangle-s { background-position: -64px -192px; } +.ui-icon-circle-triangle-w { background-position: -80px -192px; } +.ui-icon-circle-triangle-n { background-position: -96px -192px; } +.ui-icon-circle-arrow-e { background-position: -112px -192px; } +.ui-icon-circle-arrow-s { background-position: -128px -192px; } +.ui-icon-circle-arrow-w { background-position: -144px -192px; } +.ui-icon-circle-arrow-n { background-position: -160px -192px; } +.ui-icon-circle-zoomin { background-position: -176px -192px; } +.ui-icon-circle-zoomout { background-position: -192px -192px; } +.ui-icon-circle-check { background-position: -208px -192px; } +.ui-icon-circlesmall-plus { background-position: 0 -208px; } +.ui-icon-circlesmall-minus { background-position: -16px -208px; } +.ui-icon-circlesmall-close { background-position: -32px -208px; } +.ui-icon-squaresmall-plus { background-position: -48px -208px; } +.ui-icon-squaresmall-minus { background-position: -64px -208px; } +.ui-icon-squaresmall-close { background-position: -80px -208px; } +.ui-icon-grip-dotted-vertical { background-position: 0 -224px; } +.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; } +.ui-icon-grip-solid-vertical { background-position: -32px -224px; } +.ui-icon-grip-solid-horizontal { background-position: -48px -224px; } +.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; } +.ui-icon-grip-diagonal-se { background-position: -80px -224px; } + + +/* Misc visuals +----------------------------------*/ + +/* Corner radius */ +.ui-corner-tl { -moz-border-radius-topleft: 6px; -webkit-border-top-left-radius: 6px; border-top-left-radius: 6px; } +.ui-corner-tr { -moz-border-radius-topright: 6px; -webkit-border-top-right-radius: 6px; border-top-right-radius: 6px; } +.ui-corner-bl { -moz-border-radius-bottomleft: 6px; -webkit-border-bottom-left-radius: 6px; border-bottom-left-radius: 6px; } +.ui-corner-br { -moz-border-radius-bottomright: 6px; -webkit-border-bottom-right-radius: 6px; border-bottom-right-radius: 6px; } +.ui-corner-top { -moz-border-radius-topleft: 6px; -webkit-border-top-left-radius: 6px; border-top-left-radius: 6px; -moz-border-radius-topright: 6px; -webkit-border-top-right-radius: 6px; border-top-right-radius: 6px; } +.ui-corner-bottom { -moz-border-radius-bottomleft: 6px; -webkit-border-bottom-left-radius: 6px; border-bottom-left-radius: 6px; -moz-border-radius-bottomright: 6px; -webkit-border-bottom-right-radius: 6px; border-bottom-right-radius: 6px; } +.ui-corner-right { -moz-border-radius-topright: 6px; -webkit-border-top-right-radius: 6px; border-top-right-radius: 6px; -moz-border-radius-bottomright: 6px; -webkit-border-bottom-right-radius: 6px; border-bottom-right-radius: 6px; } +.ui-corner-left { -moz-border-radius-topleft: 6px; -webkit-border-top-left-radius: 6px; border-top-left-radius: 6px; -moz-border-radius-bottomleft: 6px; -webkit-border-bottom-left-radius: 6px; border-bottom-left-radius: 6px; } +.ui-corner-all { -moz-border-radius: 6px; -webkit-border-radius: 6px; border-radius: 6px; } + +/* Overlays */ +.ui-widget-overlay { background: #eeeeee url(images/ui-bg_diagonals-thick_90_eeeeee_40x40.png) 50% 50% repeat; opacity: .80;filter:Alpha(Opacity=80); } +.ui-widget-shadow { margin: -7px 0 0 -7px; padding: 7px; background: #000000 url(images/ui-bg_highlight-hard_70_000000_1x100.png) 50% top repeat-x; opacity: .30;filter:Alpha(Opacity=30); -moz-border-radius: 8px; -webkit-border-radius: 8px; border-radius: 8px; }/* + * jQuery UI Resizable 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Resizable#theming + */ +.ui-resizable { position: relative;} +.ui-resizable-handle { position: absolute;font-size: 0.1px;z-index: 99999; display: block; + /* http://bugs.jqueryui.com/ticket/7233 + - Resizable: resizable handles fail to work in IE if transparent and content overlaps + */ + background-image:url(data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs=); +} +.ui-resizable-disabled .ui-resizable-handle, .ui-resizable-autohide .ui-resizable-handle { display: none; } +.ui-resizable-n { cursor: n-resize; height: 7px; width: 100%; top: -5px; left: 0; } +.ui-resizable-s { cursor: s-resize; height: 7px; width: 100%; bottom: -5px; left: 0; } +.ui-resizable-e { cursor: e-resize; width: 7px; right: -5px; top: 0; height: 100%; } +.ui-resizable-w { cursor: w-resize; width: 7px; left: -5px; top: 0; height: 100%; } +.ui-resizable-se { cursor: se-resize; width: 12px; height: 12px; right: 1px; bottom: 1px; } +.ui-resizable-sw { cursor: sw-resize; width: 9px; height: 9px; left: -5px; bottom: -5px; } +.ui-resizable-nw { cursor: nw-resize; width: 9px; height: 9px; left: -5px; top: -5px; } +.ui-resizable-ne { cursor: ne-resize; width: 9px; height: 9px; right: -5px; top: -5px;}/* + * jQuery UI Selectable 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Selectable#theming + */ +.ui-selectable-helper { position: absolute; z-index: 100; border:1px dotted black; } +/* + * jQuery UI Accordion 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Accordion#theming + */ +/* IE/Win - Fix animation bug - #4615 */ +.ui-accordion { width: 100%; } +.ui-accordion .ui-accordion-header { cursor: pointer; position: relative; margin-top: 1px; zoom: 1; } +.ui-accordion .ui-accordion-li-fix { display: inline; } +.ui-accordion .ui-accordion-header-active { border-bottom: 0 !important; } +.ui-accordion .ui-accordion-header a { display: block; font-size: 1em; padding: .5em .5em .5em .7em; } +.ui-accordion-icons .ui-accordion-header a { padding-left: 2.2em; } +.ui-accordion .ui-accordion-header .ui-icon { position: absolute; left: .5em; top: 50%; margin-top: -8px; } +.ui-accordion .ui-accordion-content { padding: 1em 2.2em; border-top: 0; margin-top: -2px; position: relative; top: 1px; margin-bottom: 2px; overflow: auto; display: none; zoom: 1; } +.ui-accordion .ui-accordion-content-active { display: block; } +/* + * jQuery UI Autocomplete 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Autocomplete#theming + */ +.ui-autocomplete { position: absolute; cursor: default; } + +/* workarounds */ +* html .ui-autocomplete { width:1px; } /* without this, the menu expands to 100% in IE6 */ + +/* + * jQuery UI Menu 1.8.13 + * + * Copyright 2010, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Menu#theming + */ +.ui-menu { + list-style:none; + padding: 2px; + margin: 0; + display:block; + float: left; +} +.ui-menu .ui-menu { + margin-top: -3px; +} +.ui-menu .ui-menu-item { + margin:0; + padding: 0; + zoom: 1; + float: left; + clear: left; + width: 100%; +} +.ui-menu .ui-menu-item a { + text-decoration:none; + display:block; + padding:.2em .4em; + line-height:1.5; + zoom:1; +} +.ui-menu .ui-menu-item a.ui-state-hover, +.ui-menu .ui-menu-item a.ui-state-active { + font-weight: normal; + margin: -1px; +} +/* + * jQuery UI Button 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Button#theming + */ +.ui-button { display: inline-block; position: relative; padding: 0; margin-right: .1em; text-decoration: none !important; cursor: pointer; text-align: center; zoom: 1; overflow: visible; } /* the overflow property removes extra width in IE */ +.ui-button-icon-only { width: 2.2em; } /* to make room for the icon, a width needs to be set here */ +button.ui-button-icon-only { width: 2.4em; } /* button elements seem to need a little more width */ +.ui-button-icons-only { width: 3.4em; } +button.ui-button-icons-only { width: 3.7em; } + +/*button text element */ +.ui-button .ui-button-text { display: block; line-height: 1.4; } +.ui-button-text-only .ui-button-text { padding: .4em 1em; } +.ui-button-icon-only .ui-button-text, .ui-button-icons-only .ui-button-text { padding: .4em; text-indent: -9999999px; } +.ui-button-text-icon-primary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 1em .4em 2.1em; } +.ui-button-text-icon-secondary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 2.1em .4em 1em; } +.ui-button-text-icons .ui-button-text { padding-left: 2.1em; padding-right: 2.1em; } +/* no icon support for input elements, provide padding by default */ +input.ui-button { padding: .4em 1em; } + +/*button icon element(s) */ +.ui-button-icon-only .ui-icon, .ui-button-text-icon-primary .ui-icon, .ui-button-text-icon-secondary .ui-icon, .ui-button-text-icons .ui-icon, .ui-button-icons-only .ui-icon { position: absolute; top: 50%; margin-top: -8px; } +.ui-button-icon-only .ui-icon { left: 50%; margin-left: -8px; } +.ui-button-text-icon-primary .ui-button-icon-primary, .ui-button-text-icons .ui-button-icon-primary, .ui-button-icons-only .ui-button-icon-primary { left: .5em; } +.ui-button-text-icon-secondary .ui-button-icon-secondary, .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } +.ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } + +/*button sets*/ +.ui-buttonset { margin-right: 7px; } +.ui-buttonset .ui-button { margin-left: 0; margin-right: -.3em; } + +/* workarounds */ +button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra padding in Firefox */ +/* + * jQuery UI Dialog 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Dialog#theming + */ +.ui-dialog { position: absolute; padding: .2em; width: 300px; overflow: hidden; } +.ui-dialog .ui-dialog-titlebar { padding: .4em 1em; position: relative; } +.ui-dialog .ui-dialog-title { float: left; margin: .1em 16px .1em 0; } +.ui-dialog .ui-dialog-titlebar-close { position: absolute; right: .3em; top: 50%; width: 19px; margin: -10px 0 0 0; padding: 1px; height: 18px; } +.ui-dialog .ui-dialog-titlebar-close span { display: block; margin: 1px; } +.ui-dialog .ui-dialog-titlebar-close:hover, .ui-dialog .ui-dialog-titlebar-close:focus { padding: 0; } +.ui-dialog .ui-dialog-content { position: relative; border: 0; padding: .5em 1em; background: none; overflow: auto; zoom: 1; } +.ui-dialog .ui-dialog-buttonpane { text-align: left; border-width: 1px 0 0 0; background-image: none; margin: .5em 0 0 0; padding: .3em 1em .5em .4em; } +.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset { float: right; } +.ui-dialog .ui-dialog-buttonpane button { margin: .5em .4em .5em 0; cursor: pointer; } +.ui-dialog .ui-resizable-se { width: 14px; height: 14px; right: 3px; bottom: 3px; } +.ui-draggable .ui-dialog-titlebar { cursor: move; } +/* + * jQuery UI Slider 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Slider#theming + */ +.ui-slider { position: relative; text-align: left; } +.ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 1.2em; height: 1.2em; cursor: default; } +.ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: .7em; display: block; border: 0; background-position: 0 0; } + +.ui-slider-horizontal { height: .8em; } +.ui-slider-horizontal .ui-slider-handle { top: -.3em; margin-left: -.6em; } +.ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; } +.ui-slider-horizontal .ui-slider-range-min { left: 0; } +.ui-slider-horizontal .ui-slider-range-max { right: 0; } + +.ui-slider-vertical { width: .8em; height: 100px; } +.ui-slider-vertical .ui-slider-handle { left: -.3em; margin-left: 0; margin-bottom: -.6em; } +.ui-slider-vertical .ui-slider-range { left: 0; width: 100%; } +.ui-slider-vertical .ui-slider-range-min { bottom: 0; } +.ui-slider-vertical .ui-slider-range-max { top: 0; }/* + * jQuery UI Tabs 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Tabs#theming + */ +.ui-tabs { position: relative; padding: .2em; zoom: 1; } /* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */ +.ui-tabs .ui-tabs-nav { margin: 0; padding: .2em .2em 0; } +.ui-tabs .ui-tabs-nav li { list-style: none; float: left; position: relative; top: 1px; margin: 0 .2em 1px 0; border-bottom: 0 !important; padding: 0; white-space: nowrap; } +.ui-tabs .ui-tabs-nav li a { float: left; padding: .5em 1em; text-decoration: none; } +.ui-tabs .ui-tabs-nav li.ui-tabs-selected { margin-bottom: 0; padding-bottom: 1px; } +.ui-tabs .ui-tabs-nav li.ui-tabs-selected a, .ui-tabs .ui-tabs-nav li.ui-state-disabled a, .ui-tabs .ui-tabs-nav li.ui-state-processing a { cursor: text; } +.ui-tabs .ui-tabs-nav li a, .ui-tabs.ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-selected a { cursor: pointer; } /* first selector in group seems obsolete, but required to overcome bug in Opera applying cursor: text overall if defined elsewhere... */ +.ui-tabs .ui-tabs-panel { display: block; border-width: 0; padding: 1em 1.4em; background: none; } +.ui-tabs .ui-tabs-hide { display: none !important; } +/* + * jQuery UI Datepicker 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Datepicker#theming + */ +.ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; } +.ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; } +.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; } +.ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; } +.ui-datepicker .ui-datepicker-prev { left:2px; } +.ui-datepicker .ui-datepicker-next { right:2px; } +.ui-datepicker .ui-datepicker-prev-hover { left:1px; } +.ui-datepicker .ui-datepicker-next-hover { right:1px; } +.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px; } +.ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; } +.ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; } +.ui-datepicker select.ui-datepicker-month-year {width: 100%;} +.ui-datepicker select.ui-datepicker-month, +.ui-datepicker select.ui-datepicker-year { width: 49%;} +.ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; } +.ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0; } +.ui-datepicker td { border: 0; padding: 1px; } +.ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; } +.ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; } +.ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; } +.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; } + +/* with multiple calendars */ +.ui-datepicker.ui-datepicker-multi { width:auto; } +.ui-datepicker-multi .ui-datepicker-group { float:left; } +.ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; } +.ui-datepicker-multi-2 .ui-datepicker-group { width:50%; } +.ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; } +.ui-datepicker-multi-4 .ui-datepicker-group { width:25%; } +.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; } +.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; } +.ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; } +.ui-datepicker-row-break { clear:both; width:100%; } + +/* RTL support */ +.ui-datepicker-rtl { direction: rtl; } +.ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; } +.ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; } +.ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; } +.ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; } +.ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; } +.ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; } +.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; } +.ui-datepicker-rtl .ui-datepicker-group { float:right; } +.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; } +.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; } + +/* IE6 IFRAME FIX (taken from datepicker 1.5.3 */ +.ui-datepicker-cover { + display: none; /*sorry for IE5*/ + display/**/: block; /*sorry for IE5*/ + position: absolute; /*must have*/ + z-index: -1; /*must have*/ + filter: mask(); /*must have*/ + top: -4px; /*must have*/ + left: -4px; /*must have*/ + width: 200px; /*must have*/ + height: 200px; /*must have*/ +}/* + * jQuery UI Progressbar 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Progressbar#theming + */ +.ui-progressbar { height:2em; text-align: left; } +.ui-progressbar .ui-progressbar-value {margin: -1px; height:100%; } \ No newline at end of file diff --git a/test/views/css/d.gif b/test/views/css/d.gif new file mode 100644 index 0000000..6eb0004 Binary files /dev/null and b/test/views/css/d.gif differ diff --git a/test/views/css/d.png b/test/views/css/d.png new file mode 100644 index 0000000..275daec Binary files /dev/null and b/test/views/css/d.png differ diff --git a/test/views/css/loading.gif b/test/views/css/loading.gif new file mode 100644 index 0000000..5b33f7e Binary files /dev/null and b/test/views/css/loading.gif differ diff --git a/test/views/css/style.css b/test/views/css/style.css new file mode 100644 index 0000000..5428494 --- /dev/null +++ b/test/views/css/style.css @@ -0,0 +1,200 @@ +div { + margin: 0; + padding: 0; +} + +#header, #footer, #content { + width: 100%; +} +#layout{ + width: 1100px; + margin-left: auto ; + margin-right: auto ; +} +#right { + /*height: 40px;*/ + /*width: 975px;*/ + padding: 5px; + background-repeat: no-repeat; + width: 310px; + float: left; + /*height: 98%;*/ +} + +#content { + float: left; + width: 750px; + /*height: 98%;*/ +} + +#tabs { + height: 100%; +} + +#tabs > div { + height: 100%; +} + +.portlet { + margin: 10px; /*width:150px;*/ +} + +.portlet-content { + padding: 3px; +} + +.portlet-header .ui-icon { + float: right; +} + +.portlet-header{ + padding-left: 3px; +} + +/* +* +* JSTREE CHECKBOXES +* +*/ + +.jstree-themeroller ins.jstree-checkbox { + background: url("d.gif"); +} + +.jstree-themeroller .jstree-no-icons .jstree-checkbox { + display: inline-block; +} + +.jstree-themeroller .jstree-no-checkboxes .jstree-checkbox { + display: none !important; +} + +.jstree-themeroller .jstree-checked > a > .jstree-checkbox { + background-position: -38px -19px; +} + +.jstree-themeroller .jstree-unchecked > a > .jstree-checkbox { + background-position: -2px -19px; +} + +.jstree-themeroller .jstree-undetermined > a > .jstree-checkbox { + background-position: -2px -19px; +} + +.jstree-themeroller .jstree-checked > a > .jstree-checkbox:hover { + background-position: -38px -37px; +} + +.jstree-themeroller .jstree-unchecked > a > .jstree-checkbox:hover { + background-position: -2px -37px; +} + +.jstree-themeroller .jstree-undetermined > a > .jstree-checkbox:hover { + background-position: -2px -37px; +} + +.jstree-themeroller .jstree-undetermined a .jstree-checkbox { + _background-position: -2px -19px; +} + +.jstree-themeroller .jstree-checked a .jstree-checkbox { + _background-position: -38px -19px; +} + +.jstree-themeroller .jstree-unchecked a .jstree-checkbox { + _background-position: -2px -19px; +} + +a.ui-state-default { + border: none !important; + background: none !important; +} + +#dialog label, #dialog input { + display: block; +} + +#dialog label { + margin-top: 0.5em; +} + +#dialog input, #dialog textarea { + width: 95%; +} + +#tabs li .ui-icon-close { + float: right; + margin: 0; + cursor: pointer; +} + +#add_tab { + cursor: pointer; +} + +.ui-tabs-vertical { + width: 730px; +} + +.ui-tabs-vertical .ui-tabs-nav { + padding: .2em .1em .2em .2em; + float: left; + width: 12em; + height: 98%; + background-repeat: no-repeat; +} + +.ui-tabs-vertical .ui-tabs-nav li { + clear: left; + width: 100%; + border-bottom-width: 1px !important; + border-right-width: 0 !important; + margin: 0 -1px .2em 0; +} + +.ui-tabs-vertical .ui-tabs-nav li a { + display: block; +} + +.ui-tabs-vertical .ui-tabs-nav li.ui-tabs-selected { + padding-bottom: 0; + margin-bottom: 3px; + padding-right: .1em; + border-right-width: 1px; + border-right-width: 1px; +} + +.ui-tabs-vertical .ui-tabs-panel { + padding: 1em; + float: right; + width: 450px; +} + +.ui-tabs-vertical .ui-state-default a { + width: 75%; +} + +.ui-sortable-placeholder { + border: 1px dotted black; + visibility: visible !important; +} + +.ui-sortable-placeholder * { + visibility: hidden; +} + + +.root_checkbox_unchecked{ + background: url("d.gif") repeat scroll 0 0 transparent; + background-position: -2px -19px; + height: 16px; + width: 16px; + display: inline-block; +} +.root_checkbox_checked{ + background: url("d.gif") repeat scroll 0 0 transparent; + background-position: -38px -19px; + height: 16px; + width: 16px; + display: inline-block; +} \ No newline at end of file diff --git a/test/views/css/tree-themes/.svn/all-wcprops b/test/views/css/tree-themes/.svn/all-wcprops new file mode 100644 index 0000000..0de99ee --- /dev/null +++ b/test/views/css/tree-themes/.svn/all-wcprops @@ -0,0 +1,5 @@ +K 25 +svn:wc:ra_dav:version-url +V 65 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes +END diff --git a/test/views/css/tree-themes/.svn/entries b/test/views/css/tree-themes/.svn/entries new file mode 100644 index 0000000..69c82b6 --- /dev/null +++ b/test/views/css/tree-themes/.svn/entries @@ -0,0 +1,40 @@ +10 + +dir +2 +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework/todotree/views/css/tree-themes +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework + + + +2011-06-10T16:28:28.115490Z +2 +hairyhum + + + + + + + + + + + + + + +ac95b44f-471c-48cd-8414-b967058da7d4 + +apple +dir + +classic +dir + +default-rtl +dir + +default +dir + diff --git a/test/views/css/tree-themes/apple/.svn/all-wcprops b/test/views/css/tree-themes/apple/.svn/all-wcprops new file mode 100644 index 0000000..a95a82c --- /dev/null +++ b/test/views/css/tree-themes/apple/.svn/all-wcprops @@ -0,0 +1,35 @@ +K 25 +svn:wc:ra_dav:version-url +V 71 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/apple +END +d.png +K 25 +svn:wc:ra_dav:version-url +V 77 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/apple/d.png +END +bg.jpg +K 25 +svn:wc:ra_dav:version-url +V 78 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/apple/bg.jpg +END +style.css +K 25 +svn:wc:ra_dav:version-url +V 81 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/apple/style.css +END +throbber.gif +K 25 +svn:wc:ra_dav:version-url +V 84 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/apple/throbber.gif +END +dot_for_ie.gif +K 25 +svn:wc:ra_dav:version-url +V 86 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/apple/dot_for_ie.gif +END diff --git a/test/views/css/tree-themes/apple/.svn/entries b/test/views/css/tree-themes/apple/.svn/entries new file mode 100644 index 0000000..fd42612 --- /dev/null +++ b/test/views/css/tree-themes/apple/.svn/entries @@ -0,0 +1,198 @@ +10 + +dir +2 +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework/todotree/views/css/tree-themes/apple +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework + + + +2011-06-10T16:28:28.115490Z +2 +hairyhum + + + + + + + + + + + + + + +ac95b44f-471c-48cd-8414-b967058da7d4 + +d.png +file + + + + +2010-06-03T11:41:42.000000Z +84c5c7217fd02dc781c5bffd619e6f2a +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +7765 + +bg.jpg +file + + + + +2010-06-03T11:41:42.000000Z +eb12f0d34682685e9c0765c86f849230 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +331 + +style.css +file + + + + +2010-09-18T19:30:12.000000Z +972faf8c700639be6acd867274f6a9bb +2011-06-10T16:28:28.115490Z +2 +hairyhum + + + + + + + + + + + + + + + + + + + + + +4047 + +throbber.gif +file + + + + +2010-06-03T11:41:42.000000Z +7b9776076d5fceef4993b55c9383dedd +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +1849 + +dot_for_ie.gif +file + + + + +2010-06-03T11:41:42.000000Z +8c304279c4e1d2ff621937a27c636f68 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +43 + diff --git a/test/views/css/tree-themes/apple/.svn/prop-base/bg.jpg.svn-base b/test/views/css/tree-themes/apple/.svn/prop-base/bg.jpg.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/tree-themes/apple/.svn/prop-base/bg.jpg.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/tree-themes/apple/.svn/prop-base/d.png.svn-base b/test/views/css/tree-themes/apple/.svn/prop-base/d.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/tree-themes/apple/.svn/prop-base/d.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/tree-themes/apple/.svn/prop-base/dot_for_ie.gif.svn-base b/test/views/css/tree-themes/apple/.svn/prop-base/dot_for_ie.gif.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/tree-themes/apple/.svn/prop-base/dot_for_ie.gif.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/tree-themes/apple/.svn/prop-base/throbber.gif.svn-base b/test/views/css/tree-themes/apple/.svn/prop-base/throbber.gif.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/tree-themes/apple/.svn/prop-base/throbber.gif.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/tree-themes/apple/.svn/text-base/bg.jpg.svn-base b/test/views/css/tree-themes/apple/.svn/text-base/bg.jpg.svn-base new file mode 100644 index 0000000..3aad05d Binary files /dev/null and b/test/views/css/tree-themes/apple/.svn/text-base/bg.jpg.svn-base differ diff --git a/test/views/css/tree-themes/apple/.svn/text-base/d.png.svn-base b/test/views/css/tree-themes/apple/.svn/text-base/d.png.svn-base new file mode 100644 index 0000000..2463ba6 Binary files /dev/null and b/test/views/css/tree-themes/apple/.svn/text-base/d.png.svn-base differ diff --git a/test/views/css/tree-themes/apple/.svn/text-base/dot_for_ie.gif.svn-base b/test/views/css/tree-themes/apple/.svn/text-base/dot_for_ie.gif.svn-base new file mode 100644 index 0000000..c0cc5fd Binary files /dev/null and b/test/views/css/tree-themes/apple/.svn/text-base/dot_for_ie.gif.svn-base differ diff --git a/test/views/css/tree-themes/apple/.svn/text-base/style.css.svn-base b/test/views/css/tree-themes/apple/.svn/text-base/style.css.svn-base new file mode 100644 index 0000000..d0c4163 --- /dev/null +++ b/test/views/css/tree-themes/apple/.svn/text-base/style.css.svn-base @@ -0,0 +1,61 @@ +/* + * jsTree apple theme 1.0 + * Supported features: dots/no-dots, icons/no-icons, focused, loading + * Supported plugins: ui (hovered, clicked), checkbox, contextmenu, search + */ + +.jstree-apple > ul { background:url("bg.jpg") left top repeat; } +.jstree-apple li, +.jstree-apple ins { background-image:url("d.png"); background-repeat:no-repeat; background-color:transparent; } +.jstree-apple li { background-position:-90px 0; background-repeat:repeat-y; } +.jstree-apple li.jstree-last { background:transparent; } +.jstree-apple .jstree-open > ins { background-position:-72px 0; } +.jstree-apple .jstree-closed > ins { background-position:-54px 0; } +.jstree-apple .jstree-leaf > ins { background-position:-36px 0; } + +.jstree-apple a { border-radius:4px; -moz-border-radius:4px; -webkit-border-radius:4px; text-shadow:1px 1px 1px white; } +.jstree-apple .jstree-hovered { background:#e7f4f9; border:1px solid #d8f0fa; padding:0 3px 0 1px; text-shadow:1px 1px 1px silver; } +.jstree-apple .jstree-clicked { background:#beebff; border:1px solid #99defd; padding:0 3px 0 1px; } +.jstree-apple a .jstree-icon { background-position:-56px -20px; } +.jstree-apple a.jstree-loading .jstree-icon { background:url("throbber.gif") center center no-repeat !important; } + +.jstree-apple.jstree-focused { background:white; } + +.jstree-apple .jstree-no-dots li, +.jstree-apple .jstree-no-dots .jstree-leaf > ins { background:transparent; } +.jstree-apple .jstree-no-dots .jstree-open > ins { background-position:-18px 0; } +.jstree-apple .jstree-no-dots .jstree-closed > ins { background-position:0 0; } + +.jstree-apple .jstree-no-icons a .jstree-icon { display:none; } + +.jstree-apple .jstree-search { font-style:italic; } + +.jstree-apple .jstree-no-icons .jstree-checkbox { display:inline-block; } +.jstree-apple .jstree-no-checkboxes .jstree-checkbox { display:none !important; } +.jstree-apple .jstree-checked > a > .jstree-checkbox { background-position:-38px -19px; } +.jstree-apple .jstree-unchecked > a > .jstree-checkbox { background-position:-2px -19px; } +.jstree-apple .jstree-undetermined > a > .jstree-checkbox { background-position:-20px -19px; } +.jstree-apple .jstree-checked > a > .checkbox:hover { background-position:-38px -37px; } +.jstree-apple .jstree-unchecked > a > .jstree-checkbox:hover { background-position:-2px -37px; } +.jstree-apple .jstree-undetermined > a > .jstree-checkbox:hover { background-position:-20px -37px; } + +#vakata-dragged.jstree-apple ins { background:transparent !important; } +#vakata-dragged.jstree-apple .jstree-ok { background:url("d.png") -2px -53px no-repeat !important; } +#vakata-dragged.jstree-apple .jstree-invalid { background:url("d.png") -18px -53px no-repeat !important; } +#jstree-marker.jstree-apple { background:url("d.png") -41px -57px no-repeat !important; text-indent:-100px; } + +.jstree-apple a.jstree-search { color:aqua; } +.jstree-apple .jstree-locked a { color:silver; cursor:default; } + +#vakata-contextmenu.jstree-apple-context, +#vakata-contextmenu.jstree-apple-context li ul { background:#f0f0f0; border:1px solid #979797; -moz-box-shadow: 1px 1px 2px #999; -webkit-box-shadow: 1px 1px 2px #999; box-shadow: 1px 1px 2px #999; } +#vakata-contextmenu.jstree-apple-context li { } +#vakata-contextmenu.jstree-apple-context a { color:black; } +#vakata-contextmenu.jstree-apple-context a:hover, +#vakata-contextmenu.jstree-apple-context .vakata-hover > a { padding:0 5px; background:#e8eff7; border:1px solid #aecff7; color:black; -moz-border-radius:2px; -webkit-border-radius:2px; border-radius:2px; } +#vakata-contextmenu.jstree-apple-context li.jstree-contextmenu-disabled a, +#vakata-contextmenu.jstree-apple-context li.jstree-contextmenu-disabled a:hover { color:silver; background:transparent; border:0; padding:1px 4px; } +#vakata-contextmenu.jstree-apple-context li.vakata-separator { background:white; border-top:1px solid #e0e0e0; margin:0; } +#vakata-contextmenu.jstree-apple-context li ul { margin-left:-4px; } + +/* TODO: IE6 support - the `>` selectors */ \ No newline at end of file diff --git a/test/views/css/tree-themes/apple/.svn/text-base/throbber.gif.svn-base b/test/views/css/tree-themes/apple/.svn/text-base/throbber.gif.svn-base new file mode 100644 index 0000000..5b33f7e Binary files /dev/null and b/test/views/css/tree-themes/apple/.svn/text-base/throbber.gif.svn-base differ diff --git a/test/views/css/tree-themes/apple/bg.jpg b/test/views/css/tree-themes/apple/bg.jpg new file mode 100644 index 0000000..3aad05d Binary files /dev/null and b/test/views/css/tree-themes/apple/bg.jpg differ diff --git a/test/views/css/tree-themes/apple/d.png b/test/views/css/tree-themes/apple/d.png new file mode 100644 index 0000000..2463ba6 Binary files /dev/null and b/test/views/css/tree-themes/apple/d.png differ diff --git a/test/views/css/tree-themes/apple/dot_for_ie.gif b/test/views/css/tree-themes/apple/dot_for_ie.gif new file mode 100644 index 0000000..c0cc5fd Binary files /dev/null and b/test/views/css/tree-themes/apple/dot_for_ie.gif differ diff --git a/test/views/css/tree-themes/apple/style.css b/test/views/css/tree-themes/apple/style.css new file mode 100644 index 0000000..d0c4163 --- /dev/null +++ b/test/views/css/tree-themes/apple/style.css @@ -0,0 +1,61 @@ +/* + * jsTree apple theme 1.0 + * Supported features: dots/no-dots, icons/no-icons, focused, loading + * Supported plugins: ui (hovered, clicked), checkbox, contextmenu, search + */ + +.jstree-apple > ul { background:url("bg.jpg") left top repeat; } +.jstree-apple li, +.jstree-apple ins { background-image:url("d.png"); background-repeat:no-repeat; background-color:transparent; } +.jstree-apple li { background-position:-90px 0; background-repeat:repeat-y; } +.jstree-apple li.jstree-last { background:transparent; } +.jstree-apple .jstree-open > ins { background-position:-72px 0; } +.jstree-apple .jstree-closed > ins { background-position:-54px 0; } +.jstree-apple .jstree-leaf > ins { background-position:-36px 0; } + +.jstree-apple a { border-radius:4px; -moz-border-radius:4px; -webkit-border-radius:4px; text-shadow:1px 1px 1px white; } +.jstree-apple .jstree-hovered { background:#e7f4f9; border:1px solid #d8f0fa; padding:0 3px 0 1px; text-shadow:1px 1px 1px silver; } +.jstree-apple .jstree-clicked { background:#beebff; border:1px solid #99defd; padding:0 3px 0 1px; } +.jstree-apple a .jstree-icon { background-position:-56px -20px; } +.jstree-apple a.jstree-loading .jstree-icon { background:url("throbber.gif") center center no-repeat !important; } + +.jstree-apple.jstree-focused { background:white; } + +.jstree-apple .jstree-no-dots li, +.jstree-apple .jstree-no-dots .jstree-leaf > ins { background:transparent; } +.jstree-apple .jstree-no-dots .jstree-open > ins { background-position:-18px 0; } +.jstree-apple .jstree-no-dots .jstree-closed > ins { background-position:0 0; } + +.jstree-apple .jstree-no-icons a .jstree-icon { display:none; } + +.jstree-apple .jstree-search { font-style:italic; } + +.jstree-apple .jstree-no-icons .jstree-checkbox { display:inline-block; } +.jstree-apple .jstree-no-checkboxes .jstree-checkbox { display:none !important; } +.jstree-apple .jstree-checked > a > .jstree-checkbox { background-position:-38px -19px; } +.jstree-apple .jstree-unchecked > a > .jstree-checkbox { background-position:-2px -19px; } +.jstree-apple .jstree-undetermined > a > .jstree-checkbox { background-position:-20px -19px; } +.jstree-apple .jstree-checked > a > .checkbox:hover { background-position:-38px -37px; } +.jstree-apple .jstree-unchecked > a > .jstree-checkbox:hover { background-position:-2px -37px; } +.jstree-apple .jstree-undetermined > a > .jstree-checkbox:hover { background-position:-20px -37px; } + +#vakata-dragged.jstree-apple ins { background:transparent !important; } +#vakata-dragged.jstree-apple .jstree-ok { background:url("d.png") -2px -53px no-repeat !important; } +#vakata-dragged.jstree-apple .jstree-invalid { background:url("d.png") -18px -53px no-repeat !important; } +#jstree-marker.jstree-apple { background:url("d.png") -41px -57px no-repeat !important; text-indent:-100px; } + +.jstree-apple a.jstree-search { color:aqua; } +.jstree-apple .jstree-locked a { color:silver; cursor:default; } + +#vakata-contextmenu.jstree-apple-context, +#vakata-contextmenu.jstree-apple-context li ul { background:#f0f0f0; border:1px solid #979797; -moz-box-shadow: 1px 1px 2px #999; -webkit-box-shadow: 1px 1px 2px #999; box-shadow: 1px 1px 2px #999; } +#vakata-contextmenu.jstree-apple-context li { } +#vakata-contextmenu.jstree-apple-context a { color:black; } +#vakata-contextmenu.jstree-apple-context a:hover, +#vakata-contextmenu.jstree-apple-context .vakata-hover > a { padding:0 5px; background:#e8eff7; border:1px solid #aecff7; color:black; -moz-border-radius:2px; -webkit-border-radius:2px; border-radius:2px; } +#vakata-contextmenu.jstree-apple-context li.jstree-contextmenu-disabled a, +#vakata-contextmenu.jstree-apple-context li.jstree-contextmenu-disabled a:hover { color:silver; background:transparent; border:0; padding:1px 4px; } +#vakata-contextmenu.jstree-apple-context li.vakata-separator { background:white; border-top:1px solid #e0e0e0; margin:0; } +#vakata-contextmenu.jstree-apple-context li ul { margin-left:-4px; } + +/* TODO: IE6 support - the `>` selectors */ \ No newline at end of file diff --git a/test/views/css/tree-themes/apple/throbber.gif b/test/views/css/tree-themes/apple/throbber.gif new file mode 100644 index 0000000..5b33f7e Binary files /dev/null and b/test/views/css/tree-themes/apple/throbber.gif differ diff --git a/test/views/css/tree-themes/classic/.svn/all-wcprops b/test/views/css/tree-themes/classic/.svn/all-wcprops new file mode 100644 index 0000000..7ab17d4 --- /dev/null +++ b/test/views/css/tree-themes/classic/.svn/all-wcprops @@ -0,0 +1,35 @@ +K 25 +svn:wc:ra_dav:version-url +V 73 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/classic +END +d.png +K 25 +svn:wc:ra_dav:version-url +V 79 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/classic/d.png +END +d.gif +K 25 +svn:wc:ra_dav:version-url +V 79 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/classic/d.gif +END +style.css +K 25 +svn:wc:ra_dav:version-url +V 83 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/classic/style.css +END +throbber.gif +K 25 +svn:wc:ra_dav:version-url +V 86 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/classic/throbber.gif +END +dot_for_ie.gif +K 25 +svn:wc:ra_dav:version-url +V 88 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/classic/dot_for_ie.gif +END diff --git a/test/views/css/tree-themes/classic/.svn/entries b/test/views/css/tree-themes/classic/.svn/entries new file mode 100644 index 0000000..104c766 --- /dev/null +++ b/test/views/css/tree-themes/classic/.svn/entries @@ -0,0 +1,198 @@ +10 + +dir +2 +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework/todotree/views/css/tree-themes/classic +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework + + + +2011-06-10T16:28:28.115490Z +2 +hairyhum + + + + + + + + + + + + + + +ac95b44f-471c-48cd-8414-b967058da7d4 + +d.png +file + + + + +2010-06-03T11:41:42.000000Z +651903f05f01694e55fc3b9218a56d89 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +7535 + +d.gif +file + + + + +2010-09-14T12:35:58.000000Z +e59bf915dbc3b54de68f97fcc385e9c6 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +3003 + +style.css +file + + + + +2010-09-18T19:29:52.000000Z +5a529a18800bfbdc6c1691b4ab4c76f7 +2011-06-10T16:28:28.115490Z +2 +hairyhum + + + + + + + + + + + + + + + + + + + + + +5073 + +throbber.gif +file + + + + +2010-06-03T11:41:42.000000Z +7b9776076d5fceef4993b55c9383dedd +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +1849 + +dot_for_ie.gif +file + + + + +2010-06-03T11:41:42.000000Z +8c304279c4e1d2ff621937a27c636f68 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +43 + diff --git a/test/views/css/tree-themes/classic/.svn/prop-base/d.gif.svn-base b/test/views/css/tree-themes/classic/.svn/prop-base/d.gif.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/tree-themes/classic/.svn/prop-base/d.gif.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/tree-themes/classic/.svn/prop-base/d.png.svn-base b/test/views/css/tree-themes/classic/.svn/prop-base/d.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/tree-themes/classic/.svn/prop-base/d.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/tree-themes/classic/.svn/prop-base/dot_for_ie.gif.svn-base b/test/views/css/tree-themes/classic/.svn/prop-base/dot_for_ie.gif.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/tree-themes/classic/.svn/prop-base/dot_for_ie.gif.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/tree-themes/classic/.svn/prop-base/throbber.gif.svn-base b/test/views/css/tree-themes/classic/.svn/prop-base/throbber.gif.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/tree-themes/classic/.svn/prop-base/throbber.gif.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/tree-themes/classic/.svn/text-base/d.gif.svn-base b/test/views/css/tree-themes/classic/.svn/text-base/d.gif.svn-base new file mode 100644 index 0000000..6eb0004 Binary files /dev/null and b/test/views/css/tree-themes/classic/.svn/text-base/d.gif.svn-base differ diff --git a/test/views/css/tree-themes/classic/.svn/text-base/d.png.svn-base b/test/views/css/tree-themes/classic/.svn/text-base/d.png.svn-base new file mode 100644 index 0000000..275daec Binary files /dev/null and b/test/views/css/tree-themes/classic/.svn/text-base/d.png.svn-base differ diff --git a/test/views/css/tree-themes/classic/.svn/text-base/dot_for_ie.gif.svn-base b/test/views/css/tree-themes/classic/.svn/text-base/dot_for_ie.gif.svn-base new file mode 100644 index 0000000..c0cc5fd Binary files /dev/null and b/test/views/css/tree-themes/classic/.svn/text-base/dot_for_ie.gif.svn-base differ diff --git a/test/views/css/tree-themes/classic/.svn/text-base/style.css.svn-base b/test/views/css/tree-themes/classic/.svn/text-base/style.css.svn-base new file mode 100644 index 0000000..0351b4c --- /dev/null +++ b/test/views/css/tree-themes/classic/.svn/text-base/style.css.svn-base @@ -0,0 +1,77 @@ +/* + * jsTree classic theme 1.0 + * Supported features: dots/no-dots, icons/no-icons, focused, loading + * Supported plugins: ui (hovered, clicked), checkbox, contextmenu, search + */ + +.jstree-classic li, +.jstree-classic ins { background-image:url("d.png"); background-repeat:no-repeat; background-color:transparent; } +.jstree-classic li { background-position:-90px 0; background-repeat:repeat-y; } +.jstree-classic li.jstree-last { background:transparent; } +.jstree-classic .jstree-open > ins { background-position:-72px 0; } +.jstree-classic .jstree-closed > ins { background-position:-54px 0; } +.jstree-classic .jstree-leaf > ins { background-position:-36px 0; } + +.jstree-classic .jstree-hovered { background:#e7f4f9; border:1px solid #e7f4f9; padding:0 2px 0 1px; } +.jstree-classic .jstree-clicked { background:navy; border:1px solid navy; padding:0 2px 0 1px; color:white; } +.jstree-classic a .jstree-icon { background-position:-56px -19px; } +.jstree-classic .jstree-open > a .jstree-icon { background-position:-56px -36px; } +.jstree-classic a.jstree-loading .jstree-icon { background:url("throbber.gif") center center no-repeat !important; } + +.jstree-classic.jstree-focused { background:white; } + +.jstree-classic .jstree-no-dots li, +.jstree-classic .jstree-no-dots .jstree-leaf > ins { background:transparent; } +.jstree-classic .jstree-no-dots .jstree-open > ins { background-position:-18px 0; } +.jstree-classic .jstree-no-dots .jstree-closed > ins { background-position:0 0; } + +.jstree-classic .jstree-no-icons a .jstree-icon { display:none; } + +.jstree-classic .jstree-search { font-style:italic; } + +.jstree-classic .jstree-no-icons .jstree-checkbox { display:inline-block; } +.jstree-classic .jstree-no-checkboxes .jstree-checkbox { display:none !important; } +.jstree-classic .jstree-checked > a > .jstree-checkbox { background-position:-38px -19px; } +.jstree-classic .jstree-unchecked > a > .jstree-checkbox { background-position:-2px -19px; } +.jstree-classic .jstree-undetermined > a > .jstree-checkbox { background-position:-20px -19px; } +.jstree-classic .jstree-checked > a > .jstree-checkbox:hover { background-position:-38px -37px; } +.jstree-classic .jstree-unchecked > a > .jstree-checkbox:hover { background-position:-2px -37px; } +.jstree-classic .jstree-undetermined > a > .jstree-checkbox:hover { background-position:-20px -37px; } + +#vakata-dragged.jstree-classic ins { background:transparent !important; } +#vakata-dragged.jstree-classic .jstree-ok { background:url("d.png") -2px -53px no-repeat !important; } +#vakata-dragged.jstree-classic .jstree-invalid { background:url("d.png") -18px -53px no-repeat !important; } +#jstree-marker.jstree-classic { background:url("d.png") -41px -57px no-repeat !important; text-indent:-100px; } + +.jstree-classic a.jstree-search { color:aqua; } +.jstree-classic .jstree-locked a { color:silver; cursor:default; } + +#vakata-contextmenu.jstree-classic-context, +#vakata-contextmenu.jstree-classic-context li ul { background:#f0f0f0; border:1px solid #979797; -moz-box-shadow: 1px 1px 2px #999; -webkit-box-shadow: 1px 1px 2px #999; box-shadow: 1px 1px 2px #999; } +#vakata-contextmenu.jstree-classic-context li { } +#vakata-contextmenu.jstree-classic-context a { color:black; } +#vakata-contextmenu.jstree-classic-context a:hover, +#vakata-contextmenu.jstree-classic-context .vakata-hover > a { padding:0 5px; background:#e8eff7; border:1px solid #aecff7; color:black; -moz-border-radius:2px; -webkit-border-radius:2px; border-radius:2px; } +#vakata-contextmenu.jstree-classic-context li.jstree-contextmenu-disabled a, +#vakata-contextmenu.jstree-classic-context li.jstree-contextmenu-disabled a:hover { color:silver; background:transparent; border:0; padding:1px 4px; } +#vakata-contextmenu.jstree-classic-context li.vakata-separator { background:white; border-top:1px solid #e0e0e0; margin:0; } +#vakata-contextmenu.jstree-classic-context li ul { margin-left:-4px; } + +/* IE6 BEGIN */ +.jstree-classic li, +.jstree-classic ins, +#vakata-dragged.jstree-classic .jstree-invalid, +#vakata-dragged.jstree-classic .jstree-ok, +#jstree-marker.jstree-classic { _background-image:url("d.gif"); } +.jstree-classic .jstree-open ins { _background-position:-72px 0; } +.jstree-classic .jstree-closed ins { _background-position:-54px 0; } +.jstree-classic .jstree-leaf ins { _background-position:-36px 0; } +.jstree-classic .jstree-open a ins.jstree-icon { _background-position:-56px -36px; } +.jstree-classic .jstree-closed a ins.jstree-icon { _background-position:-56px -19px; } +.jstree-classic .jstree-leaf a ins.jstree-icon { _background-position:-56px -19px; } +#vakata-contextmenu.jstree-classic-context ins { _display:none; } +#vakata-contextmenu.jstree-classic-context li { _zoom:1; } +.jstree-classic .jstree-undetermined a .jstree-checkbox { _background-position:-20px -19px; } +.jstree-classic .jstree-checked a .jstree-checkbox { _background-position:-38px -19px; } +.jstree-classic .jstree-unchecked a .jstree-checkbox { _background-position:-2px -19px; } +/* IE6 END */ \ No newline at end of file diff --git a/test/views/css/tree-themes/classic/.svn/text-base/throbber.gif.svn-base b/test/views/css/tree-themes/classic/.svn/text-base/throbber.gif.svn-base new file mode 100644 index 0000000..5b33f7e Binary files /dev/null and b/test/views/css/tree-themes/classic/.svn/text-base/throbber.gif.svn-base differ diff --git a/test/views/css/tree-themes/classic/d.gif b/test/views/css/tree-themes/classic/d.gif new file mode 100644 index 0000000..6eb0004 Binary files /dev/null and b/test/views/css/tree-themes/classic/d.gif differ diff --git a/test/views/css/tree-themes/classic/d.png b/test/views/css/tree-themes/classic/d.png new file mode 100644 index 0000000..275daec Binary files /dev/null and b/test/views/css/tree-themes/classic/d.png differ diff --git a/test/views/css/tree-themes/classic/dot_for_ie.gif b/test/views/css/tree-themes/classic/dot_for_ie.gif new file mode 100644 index 0000000..c0cc5fd Binary files /dev/null and b/test/views/css/tree-themes/classic/dot_for_ie.gif differ diff --git a/test/views/css/tree-themes/classic/style.css b/test/views/css/tree-themes/classic/style.css new file mode 100644 index 0000000..0351b4c --- /dev/null +++ b/test/views/css/tree-themes/classic/style.css @@ -0,0 +1,77 @@ +/* + * jsTree classic theme 1.0 + * Supported features: dots/no-dots, icons/no-icons, focused, loading + * Supported plugins: ui (hovered, clicked), checkbox, contextmenu, search + */ + +.jstree-classic li, +.jstree-classic ins { background-image:url("d.png"); background-repeat:no-repeat; background-color:transparent; } +.jstree-classic li { background-position:-90px 0; background-repeat:repeat-y; } +.jstree-classic li.jstree-last { background:transparent; } +.jstree-classic .jstree-open > ins { background-position:-72px 0; } +.jstree-classic .jstree-closed > ins { background-position:-54px 0; } +.jstree-classic .jstree-leaf > ins { background-position:-36px 0; } + +.jstree-classic .jstree-hovered { background:#e7f4f9; border:1px solid #e7f4f9; padding:0 2px 0 1px; } +.jstree-classic .jstree-clicked { background:navy; border:1px solid navy; padding:0 2px 0 1px; color:white; } +.jstree-classic a .jstree-icon { background-position:-56px -19px; } +.jstree-classic .jstree-open > a .jstree-icon { background-position:-56px -36px; } +.jstree-classic a.jstree-loading .jstree-icon { background:url("throbber.gif") center center no-repeat !important; } + +.jstree-classic.jstree-focused { background:white; } + +.jstree-classic .jstree-no-dots li, +.jstree-classic .jstree-no-dots .jstree-leaf > ins { background:transparent; } +.jstree-classic .jstree-no-dots .jstree-open > ins { background-position:-18px 0; } +.jstree-classic .jstree-no-dots .jstree-closed > ins { background-position:0 0; } + +.jstree-classic .jstree-no-icons a .jstree-icon { display:none; } + +.jstree-classic .jstree-search { font-style:italic; } + +.jstree-classic .jstree-no-icons .jstree-checkbox { display:inline-block; } +.jstree-classic .jstree-no-checkboxes .jstree-checkbox { display:none !important; } +.jstree-classic .jstree-checked > a > .jstree-checkbox { background-position:-38px -19px; } +.jstree-classic .jstree-unchecked > a > .jstree-checkbox { background-position:-2px -19px; } +.jstree-classic .jstree-undetermined > a > .jstree-checkbox { background-position:-20px -19px; } +.jstree-classic .jstree-checked > a > .jstree-checkbox:hover { background-position:-38px -37px; } +.jstree-classic .jstree-unchecked > a > .jstree-checkbox:hover { background-position:-2px -37px; } +.jstree-classic .jstree-undetermined > a > .jstree-checkbox:hover { background-position:-20px -37px; } + +#vakata-dragged.jstree-classic ins { background:transparent !important; } +#vakata-dragged.jstree-classic .jstree-ok { background:url("d.png") -2px -53px no-repeat !important; } +#vakata-dragged.jstree-classic .jstree-invalid { background:url("d.png") -18px -53px no-repeat !important; } +#jstree-marker.jstree-classic { background:url("d.png") -41px -57px no-repeat !important; text-indent:-100px; } + +.jstree-classic a.jstree-search { color:aqua; } +.jstree-classic .jstree-locked a { color:silver; cursor:default; } + +#vakata-contextmenu.jstree-classic-context, +#vakata-contextmenu.jstree-classic-context li ul { background:#f0f0f0; border:1px solid #979797; -moz-box-shadow: 1px 1px 2px #999; -webkit-box-shadow: 1px 1px 2px #999; box-shadow: 1px 1px 2px #999; } +#vakata-contextmenu.jstree-classic-context li { } +#vakata-contextmenu.jstree-classic-context a { color:black; } +#vakata-contextmenu.jstree-classic-context a:hover, +#vakata-contextmenu.jstree-classic-context .vakata-hover > a { padding:0 5px; background:#e8eff7; border:1px solid #aecff7; color:black; -moz-border-radius:2px; -webkit-border-radius:2px; border-radius:2px; } +#vakata-contextmenu.jstree-classic-context li.jstree-contextmenu-disabled a, +#vakata-contextmenu.jstree-classic-context li.jstree-contextmenu-disabled a:hover { color:silver; background:transparent; border:0; padding:1px 4px; } +#vakata-contextmenu.jstree-classic-context li.vakata-separator { background:white; border-top:1px solid #e0e0e0; margin:0; } +#vakata-contextmenu.jstree-classic-context li ul { margin-left:-4px; } + +/* IE6 BEGIN */ +.jstree-classic li, +.jstree-classic ins, +#vakata-dragged.jstree-classic .jstree-invalid, +#vakata-dragged.jstree-classic .jstree-ok, +#jstree-marker.jstree-classic { _background-image:url("d.gif"); } +.jstree-classic .jstree-open ins { _background-position:-72px 0; } +.jstree-classic .jstree-closed ins { _background-position:-54px 0; } +.jstree-classic .jstree-leaf ins { _background-position:-36px 0; } +.jstree-classic .jstree-open a ins.jstree-icon { _background-position:-56px -36px; } +.jstree-classic .jstree-closed a ins.jstree-icon { _background-position:-56px -19px; } +.jstree-classic .jstree-leaf a ins.jstree-icon { _background-position:-56px -19px; } +#vakata-contextmenu.jstree-classic-context ins { _display:none; } +#vakata-contextmenu.jstree-classic-context li { _zoom:1; } +.jstree-classic .jstree-undetermined a .jstree-checkbox { _background-position:-20px -19px; } +.jstree-classic .jstree-checked a .jstree-checkbox { _background-position:-38px -19px; } +.jstree-classic .jstree-unchecked a .jstree-checkbox { _background-position:-2px -19px; } +/* IE6 END */ \ No newline at end of file diff --git a/test/views/css/tree-themes/classic/throbber.gif b/test/views/css/tree-themes/classic/throbber.gif new file mode 100644 index 0000000..5b33f7e Binary files /dev/null and b/test/views/css/tree-themes/classic/throbber.gif differ diff --git a/test/views/css/tree-themes/default-rtl/.svn/all-wcprops b/test/views/css/tree-themes/default-rtl/.svn/all-wcprops new file mode 100644 index 0000000..e3b8f2c --- /dev/null +++ b/test/views/css/tree-themes/default-rtl/.svn/all-wcprops @@ -0,0 +1,35 @@ +K 25 +svn:wc:ra_dav:version-url +V 77 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/default-rtl +END +d.png +K 25 +svn:wc:ra_dav:version-url +V 83 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/default-rtl/d.png +END +d.gif +K 25 +svn:wc:ra_dav:version-url +V 83 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/default-rtl/d.gif +END +style.css +K 25 +svn:wc:ra_dav:version-url +V 87 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/default-rtl/style.css +END +throbber.gif +K 25 +svn:wc:ra_dav:version-url +V 90 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/default-rtl/throbber.gif +END +dots.gif +K 25 +svn:wc:ra_dav:version-url +V 86 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/default-rtl/dots.gif +END diff --git a/test/views/css/tree-themes/default-rtl/.svn/entries b/test/views/css/tree-themes/default-rtl/.svn/entries new file mode 100644 index 0000000..faf86e3 --- /dev/null +++ b/test/views/css/tree-themes/default-rtl/.svn/entries @@ -0,0 +1,198 @@ +10 + +dir +2 +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework/todotree/views/css/tree-themes/default-rtl +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework + + + +2011-06-10T16:28:28.115490Z +2 +hairyhum + + + + + + + + + + + + + + +ac95b44f-471c-48cd-8414-b967058da7d4 + +d.png +file + + + + +2010-06-14T17:08:50.000000Z +d6f62e7edafae482fc8abda429e692ce +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +7459 + +d.gif +file + + + + +2010-06-17T08:11:52.000000Z +e3fb5e0791a390693960697c569e5696 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +2872 + +style.css +file + + + + +2010-09-18T19:29:36.000000Z +d26c0f2c59237a6bdc1e9ca9a604075b +2011-06-10T16:28:28.115490Z +2 +hairyhum + + + + + + + + + + + + + + + + + + + + + +5894 + +throbber.gif +file + + + + +2010-06-11T07:22:56.000000Z +7b9776076d5fceef4993b55c9383dedd +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +1849 + +dots.gif +file + + + + +2010-06-16T11:44:18.000000Z +3ce3f8853ef2c56f6aec2bf8dc1e58fe +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +132 + diff --git a/test/views/css/tree-themes/default-rtl/.svn/prop-base/d.gif.svn-base b/test/views/css/tree-themes/default-rtl/.svn/prop-base/d.gif.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/tree-themes/default-rtl/.svn/prop-base/d.gif.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/tree-themes/default-rtl/.svn/prop-base/d.png.svn-base b/test/views/css/tree-themes/default-rtl/.svn/prop-base/d.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/tree-themes/default-rtl/.svn/prop-base/d.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/tree-themes/default-rtl/.svn/prop-base/dots.gif.svn-base b/test/views/css/tree-themes/default-rtl/.svn/prop-base/dots.gif.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/tree-themes/default-rtl/.svn/prop-base/dots.gif.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/tree-themes/default-rtl/.svn/prop-base/throbber.gif.svn-base b/test/views/css/tree-themes/default-rtl/.svn/prop-base/throbber.gif.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/tree-themes/default-rtl/.svn/prop-base/throbber.gif.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/tree-themes/default-rtl/.svn/text-base/d.gif.svn-base b/test/views/css/tree-themes/default-rtl/.svn/text-base/d.gif.svn-base new file mode 100644 index 0000000..d85aba0 Binary files /dev/null and b/test/views/css/tree-themes/default-rtl/.svn/text-base/d.gif.svn-base differ diff --git a/test/views/css/tree-themes/default-rtl/.svn/text-base/d.png.svn-base b/test/views/css/tree-themes/default-rtl/.svn/text-base/d.png.svn-base new file mode 100644 index 0000000..5179cf6 Binary files /dev/null and b/test/views/css/tree-themes/default-rtl/.svn/text-base/d.png.svn-base differ diff --git a/test/views/css/tree-themes/default-rtl/.svn/text-base/dots.gif.svn-base b/test/views/css/tree-themes/default-rtl/.svn/text-base/dots.gif.svn-base new file mode 100644 index 0000000..0043364 Binary files /dev/null and b/test/views/css/tree-themes/default-rtl/.svn/text-base/dots.gif.svn-base differ diff --git a/test/views/css/tree-themes/default-rtl/.svn/text-base/style.css.svn-base b/test/views/css/tree-themes/default-rtl/.svn/text-base/style.css.svn-base new file mode 100644 index 0000000..1343cf3 --- /dev/null +++ b/test/views/css/tree-themes/default-rtl/.svn/text-base/style.css.svn-base @@ -0,0 +1,84 @@ +/* + * jsTree default-rtl theme 1.0 + * Supported features: dots/no-dots, icons/no-icons, focused, loading + * Supported plugins: ui (hovered, clicked), checkbox, contextmenu, search + */ + +.jstree-default-rtl li, +.jstree-default-rtl ins { background-image:url("d.png"); background-repeat:no-repeat; background-color:transparent; } +.jstree-default-rtl li { background-position:-90px 0; background-repeat:repeat-y; } +.jstree-default-rtl li.jstree-last { background:transparent; } +.jstree-default-rtl .jstree-open > ins { background-position:-72px 0; } +.jstree-default-rtl .jstree-closed > ins { background-position:-54px 0; } +.jstree-default-rtl .jstree-leaf > ins { background-position:-36px 0; } + +.jstree-default-rtl .jstree-hovered { background:#e7f4f9; border:1px solid #d8f0fa; padding:0 2px 0 1px; } +.jstree-default-rtl .jstree-clicked { background:#beebff; border:1px solid #99defd; padding:0 2px 0 1px; } +.jstree-default-rtl a .jstree-icon { background-position:-56px -19px; } +.jstree-default-rtl a.jstree-loading .jstree-icon { background:url("throbber.gif") center center no-repeat !important; } + +.jstree-default-rtl.jstree-focused { background:#ffffee; } + +.jstree-default-rtl .jstree-no-dots li, +.jstree-default-rtl .jstree-no-dots .jstree-leaf > ins { background:transparent; } +.jstree-default-rtl .jstree-no-dots .jstree-open > ins { background-position:-18px 0; } +.jstree-default-rtl .jstree-no-dots .jstree-closed > ins { background-position:0 0; } + +.jstree-default-rtl .jstree-no-icons a .jstree-icon { display:none; } + +.jstree-default-rtl .jstree-search { font-style:italic; } + +.jstree-default-rtl .jstree-no-icons .jstree-checkbox { display:inline-block; } +.jstree-default-rtl .jstree-no-checkboxes .jstree-checkbox { display:none !important; } +.jstree-default-rtl .jstree-checked > a > .jstree-checkbox { background-position:-38px -19px; } +.jstree-default-rtl .jstree-unchecked > a > .jstree-checkbox { background-position:-2px -19px; } +.jstree-default-rtl .jstree-undetermined > a > .jstree-checkbox { background-position:-20px -19px; } +.jstree-default-rtl .jstree-checked > a > .jstree-checkbox:hover { background-position:-38px -37px; } +.jstree-default-rtl .jstree-unchecked > a > .jstree-checkbox:hover { background-position:-2px -37px; } +.jstree-default-rtl .jstree-undetermined > a > .jstree-checkbox:hover { background-position:-20px -37px; } + +#vakata-dragged.jstree-default-rtl ins { background:transparent !important; } +#vakata-dragged.jstree-default-rtl .jstree-ok { background:url("d.png") -2px -53px no-repeat !important; } +#vakata-dragged.jstree-default-rtl .jstree-invalid { background:url("d.png") -18px -53px no-repeat !important; } +#jstree-marker.jstree-default-rtl { background:url("d.png") -41px -57px no-repeat !important; text-indent:-100px; } + +.jstree-default-rtl a.jstree-search { color:aqua; } +.jstree-default-rtl .jstree-locked a { color:silver; cursor:default; } + +#vakata-contextmenu.jstree-default-rtl-context, +#vakata-contextmenu.jstree-default-rtl-context li ul { background:#f0f0f0; border:1px solid #979797; -moz-box-shadow: 1px 1px 2px #999; -webkit-box-shadow: 1px 1px 2px #999; box-shadow: 1px 1px 2px #999; } +#vakata-contextmenu.jstree-default-rtl-context li { } +#vakata-contextmenu.jstree-default-rtl-context a { color:black; } +#vakata-contextmenu.jstree-default-rtl-context a:hover, +#vakata-contextmenu.jstree-default-rtl-context .vakata-hover > a { padding:0 5px; background:#e8eff7; border:1px solid #aecff7; color:black; -moz-border-radius:2px; -webkit-border-radius:2px; border-radius:2px; } +#vakata-contextmenu.jstree-default-rtl-context li.jstree-contextmenu-disabled a, +#vakata-contextmenu.jstree-default-rtl-context li.jstree-contextmenu-disabled a:hover { color:silver; background:transparent; border:0; padding:1px 4px; } +#vakata-contextmenu.jstree-default-rtl-context li.vakata-separator { background:white; border-top:1px solid #e0e0e0; margin:0; } +#vakata-contextmenu.jstree-default-rtl-context li ul { margin-left:-4px; } + +/* IE6 BEGIN */ +.jstree-default-rtl li, +.jstree-default-rtl ins, +#vakata-dragged.jstree-default-rtl .jstree-invalid, +#vakata-dragged.jstree-default-rtl .jstree-ok, +#jstree-marker.jstree-default-rtl { _background-image:url("d.gif"); } +.jstree-default-rtl .jstree-open ins { _background-position:-72px 0; } +.jstree-default-rtl .jstree-closed ins { _background-position:-54px 0; } +.jstree-default-rtl .jstree-leaf ins { _background-position:-36px 0; } +.jstree-default-rtl a ins.jstree-icon { _background-position:-56px -19px; } +#vakata-contextmenu.jstree-default-rtl-context ins { _display:none; } +#vakata-contextmenu.jstree-default-rtl-context li { _zoom:1; } +.jstree-default-rtl .jstree-undetermined a .jstree-checkbox { _background-position:-18px -19px; } +.jstree-default-rtl .jstree-checked a .jstree-checkbox { _background-position:-36px -19px; } +.jstree-default-rtl .jstree-unchecked a .jstree-checkbox { _background-position:0px -19px; } +/* IE6 END */ + +/* RTL part */ +.jstree-default-rtl .jstree-hovered, .jstree-default-rtl .jstree-clicked { padding:0 1px 0 2px; } +.jstree-default-rtl li { background-image:url("dots.gif"); background-position: 100% 0px; } +.jstree-default-rtl .jstree-checked > a > .jstree-checkbox { background-position:-36px -19px; margin-left:2px; } +.jstree-default-rtl .jstree-unchecked > a > .jstree-checkbox { background-position:0px -19px; margin-left:2px; } +.jstree-default-rtl .jstree-undetermined > a > .jstree-checkbox { background-position:-18px -19px; margin-left:2px; } +.jstree-default-rtl .jstree-checked > a > .jstree-checkbox:hover { background-position:-36px -37px; } +.jstree-default-rtl .jstree-unchecked > a > .jstree-checkbox:hover { background-position:0px -37px; } +.jstree-default-rtl .jstree-undetermined > a > .jstree-checkbox:hover { background-position:-18px -37px; } \ No newline at end of file diff --git a/test/views/css/tree-themes/default-rtl/.svn/text-base/throbber.gif.svn-base b/test/views/css/tree-themes/default-rtl/.svn/text-base/throbber.gif.svn-base new file mode 100644 index 0000000..5b33f7e Binary files /dev/null and b/test/views/css/tree-themes/default-rtl/.svn/text-base/throbber.gif.svn-base differ diff --git a/test/views/css/tree-themes/default-rtl/d.gif b/test/views/css/tree-themes/default-rtl/d.gif new file mode 100644 index 0000000..d85aba0 Binary files /dev/null and b/test/views/css/tree-themes/default-rtl/d.gif differ diff --git a/test/views/css/tree-themes/default-rtl/d.png b/test/views/css/tree-themes/default-rtl/d.png new file mode 100644 index 0000000..5179cf6 Binary files /dev/null and b/test/views/css/tree-themes/default-rtl/d.png differ diff --git a/test/views/css/tree-themes/default-rtl/dots.gif b/test/views/css/tree-themes/default-rtl/dots.gif new file mode 100644 index 0000000..0043364 Binary files /dev/null and b/test/views/css/tree-themes/default-rtl/dots.gif differ diff --git a/test/views/css/tree-themes/default-rtl/style.css b/test/views/css/tree-themes/default-rtl/style.css new file mode 100644 index 0000000..1343cf3 --- /dev/null +++ b/test/views/css/tree-themes/default-rtl/style.css @@ -0,0 +1,84 @@ +/* + * jsTree default-rtl theme 1.0 + * Supported features: dots/no-dots, icons/no-icons, focused, loading + * Supported plugins: ui (hovered, clicked), checkbox, contextmenu, search + */ + +.jstree-default-rtl li, +.jstree-default-rtl ins { background-image:url("d.png"); background-repeat:no-repeat; background-color:transparent; } +.jstree-default-rtl li { background-position:-90px 0; background-repeat:repeat-y; } +.jstree-default-rtl li.jstree-last { background:transparent; } +.jstree-default-rtl .jstree-open > ins { background-position:-72px 0; } +.jstree-default-rtl .jstree-closed > ins { background-position:-54px 0; } +.jstree-default-rtl .jstree-leaf > ins { background-position:-36px 0; } + +.jstree-default-rtl .jstree-hovered { background:#e7f4f9; border:1px solid #d8f0fa; padding:0 2px 0 1px; } +.jstree-default-rtl .jstree-clicked { background:#beebff; border:1px solid #99defd; padding:0 2px 0 1px; } +.jstree-default-rtl a .jstree-icon { background-position:-56px -19px; } +.jstree-default-rtl a.jstree-loading .jstree-icon { background:url("throbber.gif") center center no-repeat !important; } + +.jstree-default-rtl.jstree-focused { background:#ffffee; } + +.jstree-default-rtl .jstree-no-dots li, +.jstree-default-rtl .jstree-no-dots .jstree-leaf > ins { background:transparent; } +.jstree-default-rtl .jstree-no-dots .jstree-open > ins { background-position:-18px 0; } +.jstree-default-rtl .jstree-no-dots .jstree-closed > ins { background-position:0 0; } + +.jstree-default-rtl .jstree-no-icons a .jstree-icon { display:none; } + +.jstree-default-rtl .jstree-search { font-style:italic; } + +.jstree-default-rtl .jstree-no-icons .jstree-checkbox { display:inline-block; } +.jstree-default-rtl .jstree-no-checkboxes .jstree-checkbox { display:none !important; } +.jstree-default-rtl .jstree-checked > a > .jstree-checkbox { background-position:-38px -19px; } +.jstree-default-rtl .jstree-unchecked > a > .jstree-checkbox { background-position:-2px -19px; } +.jstree-default-rtl .jstree-undetermined > a > .jstree-checkbox { background-position:-20px -19px; } +.jstree-default-rtl .jstree-checked > a > .jstree-checkbox:hover { background-position:-38px -37px; } +.jstree-default-rtl .jstree-unchecked > a > .jstree-checkbox:hover { background-position:-2px -37px; } +.jstree-default-rtl .jstree-undetermined > a > .jstree-checkbox:hover { background-position:-20px -37px; } + +#vakata-dragged.jstree-default-rtl ins { background:transparent !important; } +#vakata-dragged.jstree-default-rtl .jstree-ok { background:url("d.png") -2px -53px no-repeat !important; } +#vakata-dragged.jstree-default-rtl .jstree-invalid { background:url("d.png") -18px -53px no-repeat !important; } +#jstree-marker.jstree-default-rtl { background:url("d.png") -41px -57px no-repeat !important; text-indent:-100px; } + +.jstree-default-rtl a.jstree-search { color:aqua; } +.jstree-default-rtl .jstree-locked a { color:silver; cursor:default; } + +#vakata-contextmenu.jstree-default-rtl-context, +#vakata-contextmenu.jstree-default-rtl-context li ul { background:#f0f0f0; border:1px solid #979797; -moz-box-shadow: 1px 1px 2px #999; -webkit-box-shadow: 1px 1px 2px #999; box-shadow: 1px 1px 2px #999; } +#vakata-contextmenu.jstree-default-rtl-context li { } +#vakata-contextmenu.jstree-default-rtl-context a { color:black; } +#vakata-contextmenu.jstree-default-rtl-context a:hover, +#vakata-contextmenu.jstree-default-rtl-context .vakata-hover > a { padding:0 5px; background:#e8eff7; border:1px solid #aecff7; color:black; -moz-border-radius:2px; -webkit-border-radius:2px; border-radius:2px; } +#vakata-contextmenu.jstree-default-rtl-context li.jstree-contextmenu-disabled a, +#vakata-contextmenu.jstree-default-rtl-context li.jstree-contextmenu-disabled a:hover { color:silver; background:transparent; border:0; padding:1px 4px; } +#vakata-contextmenu.jstree-default-rtl-context li.vakata-separator { background:white; border-top:1px solid #e0e0e0; margin:0; } +#vakata-contextmenu.jstree-default-rtl-context li ul { margin-left:-4px; } + +/* IE6 BEGIN */ +.jstree-default-rtl li, +.jstree-default-rtl ins, +#vakata-dragged.jstree-default-rtl .jstree-invalid, +#vakata-dragged.jstree-default-rtl .jstree-ok, +#jstree-marker.jstree-default-rtl { _background-image:url("d.gif"); } +.jstree-default-rtl .jstree-open ins { _background-position:-72px 0; } +.jstree-default-rtl .jstree-closed ins { _background-position:-54px 0; } +.jstree-default-rtl .jstree-leaf ins { _background-position:-36px 0; } +.jstree-default-rtl a ins.jstree-icon { _background-position:-56px -19px; } +#vakata-contextmenu.jstree-default-rtl-context ins { _display:none; } +#vakata-contextmenu.jstree-default-rtl-context li { _zoom:1; } +.jstree-default-rtl .jstree-undetermined a .jstree-checkbox { _background-position:-18px -19px; } +.jstree-default-rtl .jstree-checked a .jstree-checkbox { _background-position:-36px -19px; } +.jstree-default-rtl .jstree-unchecked a .jstree-checkbox { _background-position:0px -19px; } +/* IE6 END */ + +/* RTL part */ +.jstree-default-rtl .jstree-hovered, .jstree-default-rtl .jstree-clicked { padding:0 1px 0 2px; } +.jstree-default-rtl li { background-image:url("dots.gif"); background-position: 100% 0px; } +.jstree-default-rtl .jstree-checked > a > .jstree-checkbox { background-position:-36px -19px; margin-left:2px; } +.jstree-default-rtl .jstree-unchecked > a > .jstree-checkbox { background-position:0px -19px; margin-left:2px; } +.jstree-default-rtl .jstree-undetermined > a > .jstree-checkbox { background-position:-18px -19px; margin-left:2px; } +.jstree-default-rtl .jstree-checked > a > .jstree-checkbox:hover { background-position:-36px -37px; } +.jstree-default-rtl .jstree-unchecked > a > .jstree-checkbox:hover { background-position:0px -37px; } +.jstree-default-rtl .jstree-undetermined > a > .jstree-checkbox:hover { background-position:-18px -37px; } \ No newline at end of file diff --git a/test/views/css/tree-themes/default-rtl/throbber.gif b/test/views/css/tree-themes/default-rtl/throbber.gif new file mode 100644 index 0000000..5b33f7e Binary files /dev/null and b/test/views/css/tree-themes/default-rtl/throbber.gif differ diff --git a/test/views/css/tree-themes/default/.svn/all-wcprops b/test/views/css/tree-themes/default/.svn/all-wcprops new file mode 100644 index 0000000..8effec7 --- /dev/null +++ b/test/views/css/tree-themes/default/.svn/all-wcprops @@ -0,0 +1,29 @@ +K 25 +svn:wc:ra_dav:version-url +V 73 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/default +END +d.png +K 25 +svn:wc:ra_dav:version-url +V 79 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/default/d.png +END +d.gif +K 25 +svn:wc:ra_dav:version-url +V 79 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/default/d.gif +END +style.css +K 25 +svn:wc:ra_dav:version-url +V 83 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/default/style.css +END +throbber.gif +K 25 +svn:wc:ra_dav:version-url +V 86 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/tree-themes/default/throbber.gif +END diff --git a/test/views/css/tree-themes/default/.svn/entries b/test/views/css/tree-themes/default/.svn/entries new file mode 100644 index 0000000..b043c3b --- /dev/null +++ b/test/views/css/tree-themes/default/.svn/entries @@ -0,0 +1,164 @@ +10 + +dir +2 +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework/todotree/views/css/tree-themes/default +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework + + + +2011-06-10T16:28:28.115490Z +2 +hairyhum + + + + + + + + + + + + + + +ac95b44f-471c-48cd-8414-b967058da7d4 + +d.png +file + + + + +2010-06-03T11:41:42.000000Z +0eb50798dca00f5cc8e153e6da9a87f9 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +7635 + +d.gif +file + + + + +2010-06-05T16:35:52.000000Z +25d6637406a2a3d42735b22d0f627639 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +2944 + +style.css +file + + + + +2010-09-18T19:29:40.000000Z +00575b10a2eb206a9838b5e592b0d2e2 +2011-06-10T16:28:28.115490Z +2 +hairyhum + + + + + + + + + + + + + + + + + + + + + +4796 + +throbber.gif +file + + + + +2010-06-03T11:41:42.000000Z +7b9776076d5fceef4993b55c9383dedd +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +1849 + diff --git a/test/views/css/tree-themes/default/.svn/prop-base/d.gif.svn-base b/test/views/css/tree-themes/default/.svn/prop-base/d.gif.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/tree-themes/default/.svn/prop-base/d.gif.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/tree-themes/default/.svn/prop-base/d.png.svn-base b/test/views/css/tree-themes/default/.svn/prop-base/d.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/tree-themes/default/.svn/prop-base/d.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/tree-themes/default/.svn/prop-base/throbber.gif.svn-base b/test/views/css/tree-themes/default/.svn/prop-base/throbber.gif.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/tree-themes/default/.svn/prop-base/throbber.gif.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/tree-themes/default/.svn/text-base/d.gif.svn-base b/test/views/css/tree-themes/default/.svn/text-base/d.gif.svn-base new file mode 100644 index 0000000..0e958d3 Binary files /dev/null and b/test/views/css/tree-themes/default/.svn/text-base/d.gif.svn-base differ diff --git a/test/views/css/tree-themes/default/.svn/text-base/d.png.svn-base b/test/views/css/tree-themes/default/.svn/text-base/d.png.svn-base new file mode 100644 index 0000000..8540175 Binary files /dev/null and b/test/views/css/tree-themes/default/.svn/text-base/d.png.svn-base differ diff --git a/test/views/css/tree-themes/default/.svn/text-base/style.css.svn-base b/test/views/css/tree-themes/default/.svn/text-base/style.css.svn-base new file mode 100644 index 0000000..7ef6a04 --- /dev/null +++ b/test/views/css/tree-themes/default/.svn/text-base/style.css.svn-base @@ -0,0 +1,74 @@ +/* + * jsTree default theme 1.0 + * Supported features: dots/no-dots, icons/no-icons, focused, loading + * Supported plugins: ui (hovered, clicked), checkbox, contextmenu, search + */ + +.jstree-default li, +.jstree-default ins { background-image:url("d.png"); background-repeat:no-repeat; background-color:transparent; } +.jstree-default li { background-position:-90px 0; background-repeat:repeat-y; } +.jstree-default li.jstree-last { background:transparent; } +.jstree-default .jstree-open > ins { background-position:-72px 0; } +.jstree-default .jstree-closed > ins { background-position:-54px 0; } +.jstree-default .jstree-leaf > ins { background-position:-36px 0; } + +.jstree-default .jstree-hovered { background:#e7f4f9; border:1px solid #d8f0fa; padding:0 2px 0 1px; } +.jstree-default .jstree-clicked { background:#beebff; border:1px solid #99defd; padding:0 2px 0 1px; } +.jstree-default a .jstree-icon { background-position:-56px -19px; } +.jstree-default a.jstree-loading .jstree-icon { background:url("throbber.gif") center center no-repeat !important; } + +.jstree-default.jstree-focused { background:#ffffee; } + +.jstree-default .jstree-no-dots li, +.jstree-default .jstree-no-dots .jstree-leaf > ins { background:transparent; } +.jstree-default .jstree-no-dots .jstree-open > ins { background-position:-18px 0; } +.jstree-default .jstree-no-dots .jstree-closed > ins { background-position:0 0; } + +.jstree-default .jstree-no-icons a .jstree-icon { display:none; } + +.jstree-default .jstree-search { font-style:italic; } + +.jstree-default .jstree-no-icons .jstree-checkbox { display:inline-block; } +.jstree-default .jstree-no-checkboxes .jstree-checkbox { display:none !important; } +.jstree-default .jstree-checked > a > .jstree-checkbox { background-position:-38px -19px; } +.jstree-default .jstree-unchecked > a > .jstree-checkbox { background-position:-2px -19px; } +.jstree-default .jstree-undetermined > a > .jstree-checkbox { background-position:-20px -19px; } +.jstree-default .jstree-checked > a > .jstree-checkbox:hover { background-position:-38px -37px; } +.jstree-default .jstree-unchecked > a > .jstree-checkbox:hover { background-position:-2px -37px; } +.jstree-default .jstree-undetermined > a > .jstree-checkbox:hover { background-position:-20px -37px; } + +#vakata-dragged.jstree-default ins { background:transparent !important; } +#vakata-dragged.jstree-default .jstree-ok { background:url("d.png") -2px -53px no-repeat !important; } +#vakata-dragged.jstree-default .jstree-invalid { background:url("d.png") -18px -53px no-repeat !important; } +#jstree-marker.jstree-default { background:url("d.png") -41px -57px no-repeat !important; text-indent:-100px; } + +.jstree-default a.jstree-search { color:aqua; } +.jstree-default .jstree-locked a { color:silver; cursor:default; } + +#vakata-contextmenu.jstree-default-context, +#vakata-contextmenu.jstree-default-context li ul { background:#f0f0f0; border:1px solid #979797; -moz-box-shadow: 1px 1px 2px #999; -webkit-box-shadow: 1px 1px 2px #999; box-shadow: 1px 1px 2px #999; } +#vakata-contextmenu.jstree-default-context li { } +#vakata-contextmenu.jstree-default-context a { color:black; } +#vakata-contextmenu.jstree-default-context a:hover, +#vakata-contextmenu.jstree-default-context .vakata-hover > a { padding:0 5px; background:#e8eff7; border:1px solid #aecff7; color:black; -moz-border-radius:2px; -webkit-border-radius:2px; border-radius:2px; } +#vakata-contextmenu.jstree-default-context li.jstree-contextmenu-disabled a, +#vakata-contextmenu.jstree-default-context li.jstree-contextmenu-disabled a:hover { color:silver; background:transparent; border:0; padding:1px 4px; } +#vakata-contextmenu.jstree-default-context li.vakata-separator { background:white; border-top:1px solid #e0e0e0; margin:0; } +#vakata-contextmenu.jstree-default-context li ul { margin-left:-4px; } + +/* IE6 BEGIN */ +.jstree-default li, +.jstree-default ins, +#vakata-dragged.jstree-default .jstree-invalid, +#vakata-dragged.jstree-default .jstree-ok, +#jstree-marker.jstree-default { _background-image:url("d.gif"); } +.jstree-default .jstree-open ins { _background-position:-72px 0; } +.jstree-default .jstree-closed ins { _background-position:-54px 0; } +.jstree-default .jstree-leaf ins { _background-position:-36px 0; } +.jstree-default a ins.jstree-icon { _background-position:-56px -19px; } +#vakata-contextmenu.jstree-default-context ins { _display:none; } +#vakata-contextmenu.jstree-default-context li { _zoom:1; } +.jstree-default .jstree-undetermined a .jstree-checkbox { _background-position:-20px -19px; } +.jstree-default .jstree-checked a .jstree-checkbox { _background-position:-38px -19px; } +.jstree-default .jstree-unchecked a .jstree-checkbox { _background-position:-2px -19px; } +/* IE6 END */ \ No newline at end of file diff --git a/test/views/css/tree-themes/default/.svn/text-base/throbber.gif.svn-base b/test/views/css/tree-themes/default/.svn/text-base/throbber.gif.svn-base new file mode 100644 index 0000000..5b33f7e Binary files /dev/null and b/test/views/css/tree-themes/default/.svn/text-base/throbber.gif.svn-base differ diff --git a/test/views/css/tree-themes/default/d.gif b/test/views/css/tree-themes/default/d.gif new file mode 100644 index 0000000..0e958d3 Binary files /dev/null and b/test/views/css/tree-themes/default/d.gif differ diff --git a/test/views/css/tree-themes/default/d.png b/test/views/css/tree-themes/default/d.png new file mode 100644 index 0000000..8540175 Binary files /dev/null and b/test/views/css/tree-themes/default/d.png differ diff --git a/test/views/css/tree-themes/default/style.css b/test/views/css/tree-themes/default/style.css new file mode 100644 index 0000000..7ef6a04 --- /dev/null +++ b/test/views/css/tree-themes/default/style.css @@ -0,0 +1,74 @@ +/* + * jsTree default theme 1.0 + * Supported features: dots/no-dots, icons/no-icons, focused, loading + * Supported plugins: ui (hovered, clicked), checkbox, contextmenu, search + */ + +.jstree-default li, +.jstree-default ins { background-image:url("d.png"); background-repeat:no-repeat; background-color:transparent; } +.jstree-default li { background-position:-90px 0; background-repeat:repeat-y; } +.jstree-default li.jstree-last { background:transparent; } +.jstree-default .jstree-open > ins { background-position:-72px 0; } +.jstree-default .jstree-closed > ins { background-position:-54px 0; } +.jstree-default .jstree-leaf > ins { background-position:-36px 0; } + +.jstree-default .jstree-hovered { background:#e7f4f9; border:1px solid #d8f0fa; padding:0 2px 0 1px; } +.jstree-default .jstree-clicked { background:#beebff; border:1px solid #99defd; padding:0 2px 0 1px; } +.jstree-default a .jstree-icon { background-position:-56px -19px; } +.jstree-default a.jstree-loading .jstree-icon { background:url("throbber.gif") center center no-repeat !important; } + +.jstree-default.jstree-focused { background:#ffffee; } + +.jstree-default .jstree-no-dots li, +.jstree-default .jstree-no-dots .jstree-leaf > ins { background:transparent; } +.jstree-default .jstree-no-dots .jstree-open > ins { background-position:-18px 0; } +.jstree-default .jstree-no-dots .jstree-closed > ins { background-position:0 0; } + +.jstree-default .jstree-no-icons a .jstree-icon { display:none; } + +.jstree-default .jstree-search { font-style:italic; } + +.jstree-default .jstree-no-icons .jstree-checkbox { display:inline-block; } +.jstree-default .jstree-no-checkboxes .jstree-checkbox { display:none !important; } +.jstree-default .jstree-checked > a > .jstree-checkbox { background-position:-38px -19px; } +.jstree-default .jstree-unchecked > a > .jstree-checkbox { background-position:-2px -19px; } +.jstree-default .jstree-undetermined > a > .jstree-checkbox { background-position:-20px -19px; } +.jstree-default .jstree-checked > a > .jstree-checkbox:hover { background-position:-38px -37px; } +.jstree-default .jstree-unchecked > a > .jstree-checkbox:hover { background-position:-2px -37px; } +.jstree-default .jstree-undetermined > a > .jstree-checkbox:hover { background-position:-20px -37px; } + +#vakata-dragged.jstree-default ins { background:transparent !important; } +#vakata-dragged.jstree-default .jstree-ok { background:url("d.png") -2px -53px no-repeat !important; } +#vakata-dragged.jstree-default .jstree-invalid { background:url("d.png") -18px -53px no-repeat !important; } +#jstree-marker.jstree-default { background:url("d.png") -41px -57px no-repeat !important; text-indent:-100px; } + +.jstree-default a.jstree-search { color:aqua; } +.jstree-default .jstree-locked a { color:silver; cursor:default; } + +#vakata-contextmenu.jstree-default-context, +#vakata-contextmenu.jstree-default-context li ul { background:#f0f0f0; border:1px solid #979797; -moz-box-shadow: 1px 1px 2px #999; -webkit-box-shadow: 1px 1px 2px #999; box-shadow: 1px 1px 2px #999; } +#vakata-contextmenu.jstree-default-context li { } +#vakata-contextmenu.jstree-default-context a { color:black; } +#vakata-contextmenu.jstree-default-context a:hover, +#vakata-contextmenu.jstree-default-context .vakata-hover > a { padding:0 5px; background:#e8eff7; border:1px solid #aecff7; color:black; -moz-border-radius:2px; -webkit-border-radius:2px; border-radius:2px; } +#vakata-contextmenu.jstree-default-context li.jstree-contextmenu-disabled a, +#vakata-contextmenu.jstree-default-context li.jstree-contextmenu-disabled a:hover { color:silver; background:transparent; border:0; padding:1px 4px; } +#vakata-contextmenu.jstree-default-context li.vakata-separator { background:white; border-top:1px solid #e0e0e0; margin:0; } +#vakata-contextmenu.jstree-default-context li ul { margin-left:-4px; } + +/* IE6 BEGIN */ +.jstree-default li, +.jstree-default ins, +#vakata-dragged.jstree-default .jstree-invalid, +#vakata-dragged.jstree-default .jstree-ok, +#jstree-marker.jstree-default { _background-image:url("d.gif"); } +.jstree-default .jstree-open ins { _background-position:-72px 0; } +.jstree-default .jstree-closed ins { _background-position:-54px 0; } +.jstree-default .jstree-leaf ins { _background-position:-36px 0; } +.jstree-default a ins.jstree-icon { _background-position:-56px -19px; } +#vakata-contextmenu.jstree-default-context ins { _display:none; } +#vakata-contextmenu.jstree-default-context li { _zoom:1; } +.jstree-default .jstree-undetermined a .jstree-checkbox { _background-position:-20px -19px; } +.jstree-default .jstree-checked a .jstree-checkbox { _background-position:-38px -19px; } +.jstree-default .jstree-unchecked a .jstree-checkbox { _background-position:-2px -19px; } +/* IE6 END */ \ No newline at end of file diff --git a/test/views/css/tree-themes/default/throbber.gif b/test/views/css/tree-themes/default/throbber.gif new file mode 100644 index 0000000..5b33f7e Binary files /dev/null and b/test/views/css/tree-themes/default/throbber.gif differ diff --git a/test/views/css/ui-lightness/.svn/all-wcprops b/test/views/css/ui-lightness/.svn/all-wcprops new file mode 100644 index 0000000..546e33e --- /dev/null +++ b/test/views/css/ui-lightness/.svn/all-wcprops @@ -0,0 +1,11 @@ +K 25 +svn:wc:ra_dav:version-url +V 66 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness +END +jquery-ui-1.8.13.custom.css +K 25 +svn:wc:ra_dav:version-url +V 94 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/jquery-ui-1.8.13.custom.css +END diff --git a/test/views/css/ui-lightness/.svn/entries b/test/views/css/ui-lightness/.svn/entries new file mode 100644 index 0000000..92b2703 --- /dev/null +++ b/test/views/css/ui-lightness/.svn/entries @@ -0,0 +1,65 @@ +10 + +dir +2 +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework/todotree/views/css/ui-lightness +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework + + + +2011-06-10T16:28:28.115490Z +2 +hairyhum + + + + + + + + + + + + + + +ac95b44f-471c-48cd-8414-b967058da7d4 + +jquery-ui-1.8.13.custom.css +file + + + + +2011-05-30T22:01:00.000000Z +8664bbee58dbc5453de100323cd1e8ee +2011-06-10T16:28:28.115490Z +2 +hairyhum + + + + + + + + + + + + + + + + + + + + + +34363 + +images +dir + diff --git a/test/views/css/ui-lightness/.svn/text-base/jquery-ui-1.8.13.custom.css.svn-base b/test/views/css/ui-lightness/.svn/text-base/jquery-ui-1.8.13.custom.css.svn-base new file mode 100644 index 0000000..4c33c4c --- /dev/null +++ b/test/views/css/ui-lightness/.svn/text-base/jquery-ui-1.8.13.custom.css.svn-base @@ -0,0 +1,578 @@ +/* + * jQuery UI CSS Framework 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Theming/API + */ + +/* Layout helpers +----------------------------------*/ +.ui-helper-hidden { display: none; } +.ui-helper-hidden-accessible { position: absolute !important; clip: rect(1px 1px 1px 1px); clip: rect(1px,1px,1px,1px); } +.ui-helper-reset { margin: 0; padding: 0; border: 0; outline: 0; line-height: 1.3; text-decoration: none; font-size: 100%; list-style: none; } +.ui-helper-clearfix:after { content: "."; display: block; height: 0; clear: both; visibility: hidden; } +.ui-helper-clearfix { display: inline-block; } +/* required comment for clearfix to work in Opera \*/ +* html .ui-helper-clearfix { height:1%; } +.ui-helper-clearfix { display:block; } +/* end clearfix */ +.ui-helper-zfix { width: 100%; height: 100%; top: 0; left: 0; position: absolute; opacity: 0; filter:Alpha(Opacity=0); } + + +/* Interaction Cues +----------------------------------*/ +.ui-state-disabled { cursor: default !important; } + + +/* Icons +----------------------------------*/ + +/* states and images */ +.ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; } + + +/* Misc visuals +----------------------------------*/ + +/* Overlays */ +.ui-widget-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; } + + +/* + * jQuery UI CSS Framework 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Theming/API + * + * To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Trebuchet%20MS,%20Tahoma,%20Verdana,%20Arial,%20sans-serif&fwDefault=bold&fsDefault=1.1em&cornerRadius=4px&bgColorHeader=f6a828&bgTextureHeader=12_gloss_wave.png&bgImgOpacityHeader=35&borderColorHeader=e78f08&fcHeader=ffffff&iconColorHeader=ffffff&bgColorContent=eeeeee&bgTextureContent=03_highlight_soft.png&bgImgOpacityContent=100&borderColorContent=dddddd&fcContent=333333&iconColorContent=222222&bgColorDefault=f6f6f6&bgTextureDefault=02_glass.png&bgImgOpacityDefault=100&borderColorDefault=cccccc&fcDefault=1c94c4&iconColorDefault=ef8c08&bgColorHover=fdf5ce&bgTextureHover=02_glass.png&bgImgOpacityHover=100&borderColorHover=fbcb09&fcHover=c77405&iconColorHover=ef8c08&bgColorActive=ffffff&bgTextureActive=02_glass.png&bgImgOpacityActive=65&borderColorActive=fbd850&fcActive=eb8f00&iconColorActive=ef8c08&bgColorHighlight=ffe45c&bgTextureHighlight=03_highlight_soft.png&bgImgOpacityHighlight=75&borderColorHighlight=fed22f&fcHighlight=363636&iconColorHighlight=228ef1&bgColorError=b81900&bgTextureError=08_diagonals_thick.png&bgImgOpacityError=18&borderColorError=cd0a0a&fcError=ffffff&iconColorError=ffd27a&bgColorOverlay=666666&bgTextureOverlay=08_diagonals_thick.png&bgImgOpacityOverlay=20&opacityOverlay=50&bgColorShadow=000000&bgTextureShadow=01_flat.png&bgImgOpacityShadow=10&opacityShadow=20&thicknessShadow=5px&offsetTopShadow=-5px&offsetLeftShadow=-5px&cornerRadiusShadow=5px + */ + + +/* Component containers +----------------------------------*/ +.ui-widget { font-family: Trebuchet MS, Tahoma, Verdana, Arial, sans-serif; font-size: 1.1em; } +.ui-widget .ui-widget { font-size: 1em; } +.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-family: Trebuchet MS, Tahoma, Verdana, Arial, sans-serif; font-size: 1em; } +.ui-widget-content { border: 1px solid #dddddd; background: #eeeeee url(images/ui-bg_highlight-soft_100_eeeeee_1x100.png) 50% top repeat-x; color: #333333; } +.ui-widget-content a { color: #333333; } +.ui-widget-header { border: 1px solid #e78f08; background: #f6a828 url(images/ui-bg_gloss-wave_35_f6a828_500x100.png) 50% 50% repeat-x; color: #ffffff; font-weight: bold; } +.ui-widget-header a { color: #ffffff; } + +/* Interaction states +----------------------------------*/ +.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #cccccc; background: #f6f6f6 url(images/ui-bg_glass_100_f6f6f6_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #1c94c4; } +.ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #1c94c4; text-decoration: none; } +.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { border: 1px solid #fbcb09; background: #fdf5ce url(images/ui-bg_glass_100_fdf5ce_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #c77405; } +.ui-state-hover a, .ui-state-hover a:hover { color: #c77405; text-decoration: none; } +.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #fbd850; background: #ffffff url(images/ui-bg_glass_65_ffffff_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #eb8f00; } +.ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #eb8f00; text-decoration: none; } +.ui-widget :active { outline: none; } + +/* Interaction Cues +----------------------------------*/ +.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {border: 1px solid #fed22f; background: #ffe45c url(images/ui-bg_highlight-soft_75_ffe45c_1x100.png) 50% top repeat-x; color: #363636; } +.ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636; } +.ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid #cd0a0a; background: #b81900 url(images/ui-bg_diagonals-thick_18_b81900_40x40.png) 50% 50% repeat; color: #ffffff; } +.ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #ffffff; } +.ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #ffffff; } +.ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; } +.ui-priority-secondary, .ui-widget-content .ui-priority-secondary, .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; } +.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; } + +/* Icons +----------------------------------*/ + +/* states and images */ +.ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_222222_256x240.png); } +.ui-widget-content .ui-icon {background-image: url(images/ui-icons_222222_256x240.png); } +.ui-widget-header .ui-icon {background-image: url(images/ui-icons_ffffff_256x240.png); } +.ui-state-default .ui-icon { background-image: url(images/ui-icons_ef8c08_256x240.png); } +.ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_ef8c08_256x240.png); } +.ui-state-active .ui-icon {background-image: url(images/ui-icons_ef8c08_256x240.png); } +.ui-state-highlight .ui-icon {background-image: url(images/ui-icons_228ef1_256x240.png); } +.ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_ffd27a_256x240.png); } + +/* positioning */ +.ui-icon-carat-1-n { background-position: 0 0; } +.ui-icon-carat-1-ne { background-position: -16px 0; } +.ui-icon-carat-1-e { background-position: -32px 0; } +.ui-icon-carat-1-se { background-position: -48px 0; } +.ui-icon-carat-1-s { background-position: -64px 0; } +.ui-icon-carat-1-sw { background-position: -80px 0; } +.ui-icon-carat-1-w { background-position: -96px 0; } +.ui-icon-carat-1-nw { background-position: -112px 0; } +.ui-icon-carat-2-n-s { background-position: -128px 0; } +.ui-icon-carat-2-e-w { background-position: -144px 0; } +.ui-icon-triangle-1-n { background-position: 0 -16px; } +.ui-icon-triangle-1-ne { background-position: -16px -16px; } +.ui-icon-triangle-1-e { background-position: -32px -16px; } +.ui-icon-triangle-1-se { background-position: -48px -16px; } +.ui-icon-triangle-1-s { background-position: -64px -16px; } +.ui-icon-triangle-1-sw { background-position: -80px -16px; } +.ui-icon-triangle-1-w { background-position: -96px -16px; } +.ui-icon-triangle-1-nw { background-position: -112px -16px; } +.ui-icon-triangle-2-n-s { background-position: -128px -16px; } +.ui-icon-triangle-2-e-w { background-position: -144px -16px; } +.ui-icon-arrow-1-n { background-position: 0 -32px; } +.ui-icon-arrow-1-ne { background-position: -16px -32px; } +.ui-icon-arrow-1-e { background-position: -32px -32px; } +.ui-icon-arrow-1-se { background-position: -48px -32px; } +.ui-icon-arrow-1-s { background-position: -64px -32px; } +.ui-icon-arrow-1-sw { background-position: -80px -32px; } +.ui-icon-arrow-1-w { background-position: -96px -32px; } +.ui-icon-arrow-1-nw { background-position: -112px -32px; } +.ui-icon-arrow-2-n-s { background-position: -128px -32px; } +.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; } +.ui-icon-arrow-2-e-w { background-position: -160px -32px; } +.ui-icon-arrow-2-se-nw { background-position: -176px -32px; } +.ui-icon-arrowstop-1-n { background-position: -192px -32px; } +.ui-icon-arrowstop-1-e { background-position: -208px -32px; } +.ui-icon-arrowstop-1-s { background-position: -224px -32px; } +.ui-icon-arrowstop-1-w { background-position: -240px -32px; } +.ui-icon-arrowthick-1-n { background-position: 0 -48px; } +.ui-icon-arrowthick-1-ne { background-position: -16px -48px; } +.ui-icon-arrowthick-1-e { background-position: -32px -48px; } +.ui-icon-arrowthick-1-se { background-position: -48px -48px; } +.ui-icon-arrowthick-1-s { background-position: -64px -48px; } +.ui-icon-arrowthick-1-sw { background-position: -80px -48px; } +.ui-icon-arrowthick-1-w { background-position: -96px -48px; } +.ui-icon-arrowthick-1-nw { background-position: -112px -48px; } +.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; } +.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; } +.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; } +.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; } +.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; } +.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; } +.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; } +.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; } +.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; } +.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; } +.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; } +.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; } +.ui-icon-arrowreturn-1-w { background-position: -64px -64px; } +.ui-icon-arrowreturn-1-n { background-position: -80px -64px; } +.ui-icon-arrowreturn-1-e { background-position: -96px -64px; } +.ui-icon-arrowreturn-1-s { background-position: -112px -64px; } +.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; } +.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; } +.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; } +.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; } +.ui-icon-arrow-4 { background-position: 0 -80px; } +.ui-icon-arrow-4-diag { background-position: -16px -80px; } +.ui-icon-extlink { background-position: -32px -80px; } +.ui-icon-newwin { background-position: -48px -80px; } +.ui-icon-refresh { background-position: -64px -80px; } +.ui-icon-shuffle { background-position: -80px -80px; } +.ui-icon-transfer-e-w { background-position: -96px -80px; } +.ui-icon-transferthick-e-w { background-position: -112px -80px; } +.ui-icon-folder-collapsed { background-position: 0 -96px; } +.ui-icon-folder-open { background-position: -16px -96px; } +.ui-icon-document { background-position: -32px -96px; } +.ui-icon-document-b { background-position: -48px -96px; } +.ui-icon-note { background-position: -64px -96px; } +.ui-icon-mail-closed { background-position: -80px -96px; } +.ui-icon-mail-open { background-position: -96px -96px; } +.ui-icon-suitcase { background-position: -112px -96px; } +.ui-icon-comment { background-position: -128px -96px; } +.ui-icon-person { background-position: -144px -96px; } +.ui-icon-print { background-position: -160px -96px; } +.ui-icon-trash { background-position: -176px -96px; } +.ui-icon-locked { background-position: -192px -96px; } +.ui-icon-unlocked { background-position: -208px -96px; } +.ui-icon-bookmark { background-position: -224px -96px; } +.ui-icon-tag { background-position: -240px -96px; } +.ui-icon-home { background-position: 0 -112px; } +.ui-icon-flag { background-position: -16px -112px; } +.ui-icon-calendar { background-position: -32px -112px; } +.ui-icon-cart { background-position: -48px -112px; } +.ui-icon-pencil { background-position: -64px -112px; } +.ui-icon-clock { background-position: -80px -112px; } +.ui-icon-disk { background-position: -96px -112px; } +.ui-icon-calculator { background-position: -112px -112px; } +.ui-icon-zoomin { background-position: -128px -112px; } +.ui-icon-zoomout { background-position: -144px -112px; } +.ui-icon-search { background-position: -160px -112px; } +.ui-icon-wrench { background-position: -176px -112px; } +.ui-icon-gear { background-position: -192px -112px; } +.ui-icon-heart { background-position: -208px -112px; } +.ui-icon-star { background-position: -224px -112px; } +.ui-icon-link { background-position: -240px -112px; } +.ui-icon-cancel { background-position: 0 -128px; } +.ui-icon-plus { background-position: -16px -128px; } +.ui-icon-plusthick { background-position: -32px -128px; } +.ui-icon-minus { background-position: -48px -128px; } +.ui-icon-minusthick { background-position: -64px -128px; } +.ui-icon-close { background-position: -80px -128px; } +.ui-icon-closethick { background-position: -96px -128px; } +.ui-icon-key { background-position: -112px -128px; } +.ui-icon-lightbulb { background-position: -128px -128px; } +.ui-icon-scissors { background-position: -144px -128px; } +.ui-icon-clipboard { background-position: -160px -128px; } +.ui-icon-copy { background-position: -176px -128px; } +.ui-icon-contact { background-position: -192px -128px; } +.ui-icon-image { background-position: -208px -128px; } +.ui-icon-video { background-position: -224px -128px; } +.ui-icon-script { background-position: -240px -128px; } +.ui-icon-alert { background-position: 0 -144px; } +.ui-icon-info { background-position: -16px -144px; } +.ui-icon-notice { background-position: -32px -144px; } +.ui-icon-help { background-position: -48px -144px; } +.ui-icon-check { background-position: -64px -144px; } +.ui-icon-bullet { background-position: -80px -144px; } +.ui-icon-radio-off { background-position: -96px -144px; } +.ui-icon-radio-on { background-position: -112px -144px; } +.ui-icon-pin-w { background-position: -128px -144px; } +.ui-icon-pin-s { background-position: -144px -144px; } +.ui-icon-play { background-position: 0 -160px; } +.ui-icon-pause { background-position: -16px -160px; } +.ui-icon-seek-next { background-position: -32px -160px; } +.ui-icon-seek-prev { background-position: -48px -160px; } +.ui-icon-seek-end { background-position: -64px -160px; } +.ui-icon-seek-start { background-position: -80px -160px; } +/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */ +.ui-icon-seek-first { background-position: -80px -160px; } +.ui-icon-stop { background-position: -96px -160px; } +.ui-icon-eject { background-position: -112px -160px; } +.ui-icon-volume-off { background-position: -128px -160px; } +.ui-icon-volume-on { background-position: -144px -160px; } +.ui-icon-power { background-position: 0 -176px; } +.ui-icon-signal-diag { background-position: -16px -176px; } +.ui-icon-signal { background-position: -32px -176px; } +.ui-icon-battery-0 { background-position: -48px -176px; } +.ui-icon-battery-1 { background-position: -64px -176px; } +.ui-icon-battery-2 { background-position: -80px -176px; } +.ui-icon-battery-3 { background-position: -96px -176px; } +.ui-icon-circle-plus { background-position: 0 -192px; } +.ui-icon-circle-minus { background-position: -16px -192px; } +.ui-icon-circle-close { background-position: -32px -192px; } +.ui-icon-circle-triangle-e { background-position: -48px -192px; } +.ui-icon-circle-triangle-s { background-position: -64px -192px; } +.ui-icon-circle-triangle-w { background-position: -80px -192px; } +.ui-icon-circle-triangle-n { background-position: -96px -192px; } +.ui-icon-circle-arrow-e { background-position: -112px -192px; } +.ui-icon-circle-arrow-s { background-position: -128px -192px; } +.ui-icon-circle-arrow-w { background-position: -144px -192px; } +.ui-icon-circle-arrow-n { background-position: -160px -192px; } +.ui-icon-circle-zoomin { background-position: -176px -192px; } +.ui-icon-circle-zoomout { background-position: -192px -192px; } +.ui-icon-circle-check { background-position: -208px -192px; } +.ui-icon-circlesmall-plus { background-position: 0 -208px; } +.ui-icon-circlesmall-minus { background-position: -16px -208px; } +.ui-icon-circlesmall-close { background-position: -32px -208px; } +.ui-icon-squaresmall-plus { background-position: -48px -208px; } +.ui-icon-squaresmall-minus { background-position: -64px -208px; } +.ui-icon-squaresmall-close { background-position: -80px -208px; } +.ui-icon-grip-dotted-vertical { background-position: 0 -224px; } +.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; } +.ui-icon-grip-solid-vertical { background-position: -32px -224px; } +.ui-icon-grip-solid-horizontal { background-position: -48px -224px; } +.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; } +.ui-icon-grip-diagonal-se { background-position: -80px -224px; } + + +/* Misc visuals +----------------------------------*/ + +/* Corner radius */ +.ui-corner-tl { -moz-border-radius-topleft: 4px; -webkit-border-top-left-radius: 4px; border-top-left-radius: 4px; } +.ui-corner-tr { -moz-border-radius-topright: 4px; -webkit-border-top-right-radius: 4px; border-top-right-radius: 4px; } +.ui-corner-bl { -moz-border-radius-bottomleft: 4px; -webkit-border-bottom-left-radius: 4px; border-bottom-left-radius: 4px; } +.ui-corner-br { -moz-border-radius-bottomright: 4px; -webkit-border-bottom-right-radius: 4px; border-bottom-right-radius: 4px; } +.ui-corner-top { -moz-border-radius-topleft: 4px; -webkit-border-top-left-radius: 4px; border-top-left-radius: 4px; -moz-border-radius-topright: 4px; -webkit-border-top-right-radius: 4px; border-top-right-radius: 4px; } +.ui-corner-bottom { -moz-border-radius-bottomleft: 4px; -webkit-border-bottom-left-radius: 4px; border-bottom-left-radius: 4px; -moz-border-radius-bottomright: 4px; -webkit-border-bottom-right-radius: 4px; border-bottom-right-radius: 4px; } +.ui-corner-right { -moz-border-radius-topright: 4px; -webkit-border-top-right-radius: 4px; border-top-right-radius: 4px; -moz-border-radius-bottomright: 4px; -webkit-border-bottom-right-radius: 4px; border-bottom-right-radius: 4px; } +.ui-corner-left { -moz-border-radius-topleft: 4px; -webkit-border-top-left-radius: 4px; border-top-left-radius: 4px; -moz-border-radius-bottomleft: 4px; -webkit-border-bottom-left-radius: 4px; border-bottom-left-radius: 4px; } +.ui-corner-all { -moz-border-radius: 4px; -webkit-border-radius: 4px; border-radius: 4px; } + +/* Overlays */ +.ui-widget-overlay { background: #666666 url(images/ui-bg_diagonals-thick_20_666666_40x40.png) 50% 50% repeat; opacity: .50;filter:Alpha(Opacity=50); } +.ui-widget-shadow { margin: -5px 0 0 -5px; padding: 5px; background: #000000 url(images/ui-bg_flat_10_000000_40x100.png) 50% 50% repeat-x; opacity: .20;filter:Alpha(Opacity=20); -moz-border-radius: 5px; -webkit-border-radius: 5px; border-radius: 5px; }/* + * jQuery UI Resizable 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Resizable#theming + */ +.ui-resizable { position: relative;} +.ui-resizable-handle { position: absolute;font-size: 0.1px;z-index: 99999; display: block; + /* http://bugs.jqueryui.com/ticket/7233 + - Resizable: resizable handles fail to work in IE if transparent and content overlaps + */ + background-image:url(data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs=); +} +.ui-resizable-disabled .ui-resizable-handle, .ui-resizable-autohide .ui-resizable-handle { display: none; } +.ui-resizable-n { cursor: n-resize; height: 7px; width: 100%; top: -5px; left: 0; } +.ui-resizable-s { cursor: s-resize; height: 7px; width: 100%; bottom: -5px; left: 0; } +.ui-resizable-e { cursor: e-resize; width: 7px; right: -5px; top: 0; height: 100%; } +.ui-resizable-w { cursor: w-resize; width: 7px; left: -5px; top: 0; height: 100%; } +.ui-resizable-se { cursor: se-resize; width: 12px; height: 12px; right: 1px; bottom: 1px; } +.ui-resizable-sw { cursor: sw-resize; width: 9px; height: 9px; left: -5px; bottom: -5px; } +.ui-resizable-nw { cursor: nw-resize; width: 9px; height: 9px; left: -5px; top: -5px; } +.ui-resizable-ne { cursor: ne-resize; width: 9px; height: 9px; right: -5px; top: -5px;}/* + * jQuery UI Selectable 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Selectable#theming + */ +.ui-selectable-helper { position: absolute; z-index: 100; border:1px dotted black; } +/* + * jQuery UI Accordion 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Accordion#theming + */ +/* IE/Win - Fix animation bug - #4615 */ +.ui-accordion { width: 100%; } +.ui-accordion .ui-accordion-header { cursor: pointer; position: relative; margin-top: 1px; zoom: 1; } +.ui-accordion .ui-accordion-li-fix { display: inline; } +.ui-accordion .ui-accordion-header-active { border-bottom: 0 !important; } +.ui-accordion .ui-accordion-header a { display: block; font-size: 1em; padding: .5em .5em .5em .7em; } +.ui-accordion-icons .ui-accordion-header a { padding-left: 2.2em; } +.ui-accordion .ui-accordion-header .ui-icon { position: absolute; left: .5em; top: 50%; margin-top: -8px; } +.ui-accordion .ui-accordion-content { padding: 1em 2.2em; border-top: 0; margin-top: -2px; position: relative; top: 1px; margin-bottom: 2px; overflow: auto; display: none; zoom: 1; } +.ui-accordion .ui-accordion-content-active { display: block; } +/* + * jQuery UI Autocomplete 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Autocomplete#theming + */ +.ui-autocomplete { position: absolute; cursor: default; } + +/* workarounds */ +* html .ui-autocomplete { width:1px; } /* without this, the menu expands to 100% in IE6 */ + +/* + * jQuery UI Menu 1.8.13 + * + * Copyright 2010, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Menu#theming + */ +.ui-menu { + list-style:none; + padding: 2px; + margin: 0; + display:block; + float: left; +} +.ui-menu .ui-menu { + margin-top: -3px; +} +.ui-menu .ui-menu-item { + margin:0; + padding: 0; + zoom: 1; + float: left; + clear: left; + width: 100%; +} +.ui-menu .ui-menu-item a { + text-decoration:none; + display:block; + padding:.2em .4em; + line-height:1.5; + zoom:1; +} +.ui-menu .ui-menu-item a.ui-state-hover, +.ui-menu .ui-menu-item a.ui-state-active { + font-weight: normal; + margin: -1px; +} +/* + * jQuery UI Button 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Button#theming + */ +.ui-button { display: inline-block; position: relative; padding: 0; margin-right: .1em; text-decoration: none !important; cursor: pointer; text-align: center; zoom: 1; overflow: visible; } /* the overflow property removes extra width in IE */ +.ui-button-icon-only { width: 2.2em; } /* to make room for the icon, a width needs to be set here */ +button.ui-button-icon-only { width: 2.4em; } /* button elements seem to need a little more width */ +.ui-button-icons-only { width: 3.4em; } +button.ui-button-icons-only { width: 3.7em; } + +/*button text element */ +.ui-button .ui-button-text { display: block; line-height: 1.4; } +.ui-button-text-only .ui-button-text { padding: .4em 1em; } +.ui-button-icon-only .ui-button-text, .ui-button-icons-only .ui-button-text { padding: .4em; text-indent: -9999999px; } +.ui-button-text-icon-primary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 1em .4em 2.1em; } +.ui-button-text-icon-secondary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 2.1em .4em 1em; } +.ui-button-text-icons .ui-button-text { padding-left: 2.1em; padding-right: 2.1em; } +/* no icon support for input elements, provide padding by default */ +input.ui-button { padding: .4em 1em; } + +/*button icon element(s) */ +.ui-button-icon-only .ui-icon, .ui-button-text-icon-primary .ui-icon, .ui-button-text-icon-secondary .ui-icon, .ui-button-text-icons .ui-icon, .ui-button-icons-only .ui-icon { position: absolute; top: 50%; margin-top: -8px; } +.ui-button-icon-only .ui-icon { left: 50%; margin-left: -8px; } +.ui-button-text-icon-primary .ui-button-icon-primary, .ui-button-text-icons .ui-button-icon-primary, .ui-button-icons-only .ui-button-icon-primary { left: .5em; } +.ui-button-text-icon-secondary .ui-button-icon-secondary, .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } +.ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } + +/*button sets*/ +.ui-buttonset { margin-right: 7px; } +.ui-buttonset .ui-button { margin-left: 0; margin-right: -.3em; } + +/* workarounds */ +button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra padding in Firefox */ +/* + * jQuery UI Dialog 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Dialog#theming + */ +.ui-dialog { position: absolute; padding: .2em; width: 300px; overflow: hidden; } +.ui-dialog .ui-dialog-titlebar { padding: .4em 1em; position: relative; } +.ui-dialog .ui-dialog-title { float: left; margin: .1em 16px .1em 0; } +.ui-dialog .ui-dialog-titlebar-close { position: absolute; right: .3em; top: 50%; width: 19px; margin: -10px 0 0 0; padding: 1px; height: 18px; } +.ui-dialog .ui-dialog-titlebar-close span { display: block; margin: 1px; } +.ui-dialog .ui-dialog-titlebar-close:hover, .ui-dialog .ui-dialog-titlebar-close:focus { padding: 0; } +.ui-dialog .ui-dialog-content { position: relative; border: 0; padding: .5em 1em; background: none; overflow: auto; zoom: 1; } +.ui-dialog .ui-dialog-buttonpane { text-align: left; border-width: 1px 0 0 0; background-image: none; margin: .5em 0 0 0; padding: .3em 1em .5em .4em; } +.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset { float: right; } +.ui-dialog .ui-dialog-buttonpane button { margin: .5em .4em .5em 0; cursor: pointer; } +.ui-dialog .ui-resizable-se { width: 14px; height: 14px; right: 3px; bottom: 3px; } +.ui-draggable .ui-dialog-titlebar { cursor: move; } +/* + * jQuery UI Slider 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Slider#theming + */ +.ui-slider { position: relative; text-align: left; } +.ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 1.2em; height: 1.2em; cursor: default; } +.ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: .7em; display: block; border: 0; background-position: 0 0; } + +.ui-slider-horizontal { height: .8em; } +.ui-slider-horizontal .ui-slider-handle { top: -.3em; margin-left: -.6em; } +.ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; } +.ui-slider-horizontal .ui-slider-range-min { left: 0; } +.ui-slider-horizontal .ui-slider-range-max { right: 0; } + +.ui-slider-vertical { width: .8em; height: 100px; } +.ui-slider-vertical .ui-slider-handle { left: -.3em; margin-left: 0; margin-bottom: -.6em; } +.ui-slider-vertical .ui-slider-range { left: 0; width: 100%; } +.ui-slider-vertical .ui-slider-range-min { bottom: 0; } +.ui-slider-vertical .ui-slider-range-max { top: 0; }/* + * jQuery UI Tabs 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Tabs#theming + */ +.ui-tabs { position: relative; padding: .2em; zoom: 1; } /* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */ +.ui-tabs .ui-tabs-nav { margin: 0; padding: .2em .2em 0; } +.ui-tabs .ui-tabs-nav li { list-style: none; float: left; position: relative; top: 1px; margin: 0 .2em 1px 0; border-bottom: 0 !important; padding: 0; white-space: nowrap; } +.ui-tabs .ui-tabs-nav li a { float: left; padding: .5em 1em; text-decoration: none; } +.ui-tabs .ui-tabs-nav li.ui-tabs-selected { margin-bottom: 0; padding-bottom: 1px; } +.ui-tabs .ui-tabs-nav li.ui-tabs-selected a, .ui-tabs .ui-tabs-nav li.ui-state-disabled a, .ui-tabs .ui-tabs-nav li.ui-state-processing a { cursor: text; } +.ui-tabs .ui-tabs-nav li a, .ui-tabs.ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-selected a { cursor: pointer; } /* first selector in group seems obsolete, but required to overcome bug in Opera applying cursor: text overall if defined elsewhere... */ +.ui-tabs .ui-tabs-panel { display: block; border-width: 0; padding: 1em 1.4em; background: none; } +.ui-tabs .ui-tabs-hide { display: none !important; } +/* + * jQuery UI Datepicker 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Datepicker#theming + */ +.ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; } +.ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; } +.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; } +.ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; } +.ui-datepicker .ui-datepicker-prev { left:2px; } +.ui-datepicker .ui-datepicker-next { right:2px; } +.ui-datepicker .ui-datepicker-prev-hover { left:1px; } +.ui-datepicker .ui-datepicker-next-hover { right:1px; } +.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px; } +.ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; } +.ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; } +.ui-datepicker select.ui-datepicker-month-year {width: 100%;} +.ui-datepicker select.ui-datepicker-month, +.ui-datepicker select.ui-datepicker-year { width: 49%;} +.ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; } +.ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0; } +.ui-datepicker td { border: 0; padding: 1px; } +.ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; } +.ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; } +.ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; } +.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; } + +/* with multiple calendars */ +.ui-datepicker.ui-datepicker-multi { width:auto; } +.ui-datepicker-multi .ui-datepicker-group { float:left; } +.ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; } +.ui-datepicker-multi-2 .ui-datepicker-group { width:50%; } +.ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; } +.ui-datepicker-multi-4 .ui-datepicker-group { width:25%; } +.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; } +.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; } +.ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; } +.ui-datepicker-row-break { clear:both; width:100%; } + +/* RTL support */ +.ui-datepicker-rtl { direction: rtl; } +.ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; } +.ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; } +.ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; } +.ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; } +.ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; } +.ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; } +.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; } +.ui-datepicker-rtl .ui-datepicker-group { float:right; } +.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; } +.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; } + +/* IE6 IFRAME FIX (taken from datepicker 1.5.3 */ +.ui-datepicker-cover { + display: none; /*sorry for IE5*/ + display/**/: block; /*sorry for IE5*/ + position: absolute; /*must have*/ + z-index: -1; /*must have*/ + filter: mask(); /*must have*/ + top: -4px; /*must have*/ + left: -4px; /*must have*/ + width: 200px; /*must have*/ + height: 200px; /*must have*/ +}/* + * jQuery UI Progressbar 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Progressbar#theming + */ +.ui-progressbar { height:2em; text-align: left; } +.ui-progressbar .ui-progressbar-value {margin: -1px; height:100%; } \ No newline at end of file diff --git a/test/views/css/ui-lightness/images/.svn/all-wcprops b/test/views/css/ui-lightness/images/.svn/all-wcprops new file mode 100644 index 0000000..00428c5 --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/all-wcprops @@ -0,0 +1,89 @@ +K 25 +svn:wc:ra_dav:version-url +V 73 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/images +END +ui-bg_gloss-wave_35_f6a828_500x100.png +K 25 +svn:wc:ra_dav:version-url +V 112 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/images/ui-bg_gloss-wave_35_f6a828_500x100.png +END +ui-icons_ef8c08_256x240.png +K 25 +svn:wc:ra_dav:version-url +V 101 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/images/ui-icons_ef8c08_256x240.png +END +ui-bg_diagonals-thick_18_b81900_40x40.png +K 25 +svn:wc:ra_dav:version-url +V 115 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/images/ui-bg_diagonals-thick_18_b81900_40x40.png +END +ui-bg_highlight-soft_75_ffe45c_1x100.png +K 25 +svn:wc:ra_dav:version-url +V 114 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/images/ui-bg_highlight-soft_75_ffe45c_1x100.png +END +ui-icons_ffffff_256x240.png +K 25 +svn:wc:ra_dav:version-url +V 101 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/images/ui-icons_ffffff_256x240.png +END +ui-bg_flat_10_000000_40x100.png +K 25 +svn:wc:ra_dav:version-url +V 105 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/images/ui-bg_flat_10_000000_40x100.png +END +ui-bg_glass_100_fdf5ce_1x400.png +K 25 +svn:wc:ra_dav:version-url +V 106 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/images/ui-bg_glass_100_fdf5ce_1x400.png +END +ui-bg_glass_65_ffffff_1x400.png +K 25 +svn:wc:ra_dav:version-url +V 105 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/images/ui-bg_glass_65_ffffff_1x400.png +END +ui-bg_diagonals-thick_20_666666_40x40.png +K 25 +svn:wc:ra_dav:version-url +V 115 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/images/ui-bg_diagonals-thick_20_666666_40x40.png +END +ui-icons_228ef1_256x240.png +K 25 +svn:wc:ra_dav:version-url +V 101 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/images/ui-icons_228ef1_256x240.png +END +ui-bg_highlight-soft_100_eeeeee_1x100.png +K 25 +svn:wc:ra_dav:version-url +V 115 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/images/ui-bg_highlight-soft_100_eeeeee_1x100.png +END +ui-icons_ffd27a_256x240.png +K 25 +svn:wc:ra_dav:version-url +V 101 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/images/ui-icons_ffd27a_256x240.png +END +ui-bg_glass_100_f6f6f6_1x400.png +K 25 +svn:wc:ra_dav:version-url +V 106 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/images/ui-bg_glass_100_f6f6f6_1x400.png +END +ui-icons_222222_256x240.png +K 25 +svn:wc:ra_dav:version-url +V 101 +/svn/lisp-mvc_framework/!svn/ver/2/todotree/views/css/ui-lightness/images/ui-icons_222222_256x240.png +END diff --git a/test/views/css/ui-lightness/images/.svn/entries b/test/views/css/ui-lightness/images/.svn/entries new file mode 100644 index 0000000..f8927a5 --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/entries @@ -0,0 +1,504 @@ +10 + +dir +2 +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework/todotree/views/css/ui-lightness/images +http://lisp-mvc.unfuddle.com/svn/lisp-mvc_framework + + + +2011-06-10T16:28:28.115490Z +2 +hairyhum + + + + + + + + + + + + + + +ac95b44f-471c-48cd-8414-b967058da7d4 + +ui-bg_gloss-wave_35_f6a828_500x100.png +file + + + + +2011-05-30T22:01:00.000000Z +58d2cd501e01573cf537089c694ba899 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +3762 + +ui-icons_ef8c08_256x240.png +file + + + + +2011-05-30T22:01:00.000000Z +ef9a6ccfe3b14041928ddc708665b226 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +4369 + +ui-bg_diagonals-thick_18_b81900_40x40.png +file + + + + +2011-05-30T22:01:00.000000Z +95f9cceeb9d742dd3e917ec16ed754f8 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +260 + +ui-bg_highlight-soft_75_ffe45c_1x100.png +file + + + + +2011-05-30T22:01:00.000000Z +b806658954cb4d16ade8977af737f486 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +129 + +ui-icons_ffffff_256x240.png +file + + + + +2011-05-30T22:01:00.000000Z +342bc03f6264c75d3f1d7f99e34295b9 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +4369 + +ui-bg_flat_10_000000_40x100.png +file + + + + +2011-05-30T22:01:00.000000Z +c18cd01623c7fed23c80d53e2f5e7c78 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +178 + +ui-bg_glass_100_fdf5ce_1x400.png +file + + + + +2011-05-30T22:01:00.000000Z +d26e8f463195a7b86f86b7d550cfc114 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +125 + +ui-bg_glass_65_ffffff_1x400.png +file + + + + +2011-05-30T22:01:00.000000Z +e5a8f32e28fd5c27bf0fed33c8a8b9b5 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +105 + +ui-bg_diagonals-thick_20_666666_40x40.png +file + + + + +2011-05-30T22:01:00.000000Z +f040b255ca13e693da34ab33c7d6b554 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +251 + +ui-icons_228ef1_256x240.png +file + + + + +2011-05-30T22:01:00.000000Z +79f41c0765e9ec18562b20b0801d748b +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +4369 + +ui-bg_highlight-soft_100_eeeeee_1x100.png +file + + + + +2011-05-30T22:01:00.000000Z +384c3f17709ba0f809b023b6e7b10b84 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +90 + +ui-icons_ffd27a_256x240.png +file + + + + +2011-05-30T22:01:00.000000Z +ab8c30acc0e3608fb79e01fccf832c70 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +4369 + +ui-bg_glass_100_f6f6f6_1x400.png +file + + + + +2011-05-30T22:01:00.000000Z +5f1847175ba18c41322cb9cb0581e0fb +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +104 + +ui-icons_222222_256x240.png +file + + + + +2011-05-30T22:01:00.000000Z +ebe6b6902a408fbf9cac6379a1477525 +2011-06-10T16:28:28.115490Z +2 +hairyhum +has-props + + + + + + + + + + + + + + + + + + + + +4369 + diff --git a/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_diagonals-thick_18_b81900_40x40.png.svn-base b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_diagonals-thick_18_b81900_40x40.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_diagonals-thick_18_b81900_40x40.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_diagonals-thick_20_666666_40x40.png.svn-base b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_diagonals-thick_20_666666_40x40.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_diagonals-thick_20_666666_40x40.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_flat_10_000000_40x100.png.svn-base b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_flat_10_000000_40x100.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_flat_10_000000_40x100.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_glass_100_f6f6f6_1x400.png.svn-base b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_glass_100_f6f6f6_1x400.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_glass_100_f6f6f6_1x400.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_glass_100_fdf5ce_1x400.png.svn-base b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_glass_100_fdf5ce_1x400.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_glass_100_fdf5ce_1x400.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_glass_65_ffffff_1x400.png.svn-base b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_glass_65_ffffff_1x400.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_glass_65_ffffff_1x400.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_gloss-wave_35_f6a828_500x100.png.svn-base b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_gloss-wave_35_f6a828_500x100.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_gloss-wave_35_f6a828_500x100.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_highlight-soft_100_eeeeee_1x100.png.svn-base b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_highlight-soft_100_eeeeee_1x100.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_highlight-soft_100_eeeeee_1x100.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_highlight-soft_75_ffe45c_1x100.png.svn-base b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_highlight-soft_75_ffe45c_1x100.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/prop-base/ui-bg_highlight-soft_75_ffe45c_1x100.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/ui-lightness/images/.svn/prop-base/ui-icons_222222_256x240.png.svn-base b/test/views/css/ui-lightness/images/.svn/prop-base/ui-icons_222222_256x240.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/prop-base/ui-icons_222222_256x240.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/ui-lightness/images/.svn/prop-base/ui-icons_228ef1_256x240.png.svn-base b/test/views/css/ui-lightness/images/.svn/prop-base/ui-icons_228ef1_256x240.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/prop-base/ui-icons_228ef1_256x240.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/ui-lightness/images/.svn/prop-base/ui-icons_ef8c08_256x240.png.svn-base b/test/views/css/ui-lightness/images/.svn/prop-base/ui-icons_ef8c08_256x240.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/prop-base/ui-icons_ef8c08_256x240.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/ui-lightness/images/.svn/prop-base/ui-icons_ffd27a_256x240.png.svn-base b/test/views/css/ui-lightness/images/.svn/prop-base/ui-icons_ffd27a_256x240.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/prop-base/ui-icons_ffd27a_256x240.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/ui-lightness/images/.svn/prop-base/ui-icons_ffffff_256x240.png.svn-base b/test/views/css/ui-lightness/images/.svn/prop-base/ui-icons_ffffff_256x240.png.svn-base new file mode 100644 index 0000000..5e9587e --- /dev/null +++ b/test/views/css/ui-lightness/images/.svn/prop-base/ui-icons_ffffff_256x240.png.svn-base @@ -0,0 +1,5 @@ +K 13 +svn:mime-type +V 24 +application/octet-stream +END diff --git a/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_diagonals-thick_18_b81900_40x40.png.svn-base b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_diagonals-thick_18_b81900_40x40.png.svn-base new file mode 100644 index 0000000..954e22d Binary files /dev/null and b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_diagonals-thick_18_b81900_40x40.png.svn-base differ diff --git a/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_diagonals-thick_20_666666_40x40.png.svn-base b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_diagonals-thick_20_666666_40x40.png.svn-base new file mode 100644 index 0000000..64ece57 Binary files /dev/null and b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_diagonals-thick_20_666666_40x40.png.svn-base differ diff --git a/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_flat_10_000000_40x100.png.svn-base b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_flat_10_000000_40x100.png.svn-base new file mode 100644 index 0000000..abdc010 Binary files /dev/null and b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_flat_10_000000_40x100.png.svn-base differ diff --git a/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_glass_100_f6f6f6_1x400.png.svn-base b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_glass_100_f6f6f6_1x400.png.svn-base new file mode 100644 index 0000000..9b383f4 Binary files /dev/null and b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_glass_100_f6f6f6_1x400.png.svn-base differ diff --git a/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_glass_100_fdf5ce_1x400.png.svn-base b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_glass_100_fdf5ce_1x400.png.svn-base new file mode 100644 index 0000000..a23baad Binary files /dev/null and b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_glass_100_fdf5ce_1x400.png.svn-base differ diff --git a/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_glass_65_ffffff_1x400.png.svn-base b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_glass_65_ffffff_1x400.png.svn-base new file mode 100644 index 0000000..42ccba2 Binary files /dev/null and b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_glass_65_ffffff_1x400.png.svn-base differ diff --git a/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_gloss-wave_35_f6a828_500x100.png.svn-base b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_gloss-wave_35_f6a828_500x100.png.svn-base new file mode 100644 index 0000000..39d5824 Binary files /dev/null and b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_gloss-wave_35_f6a828_500x100.png.svn-base differ diff --git a/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_highlight-soft_100_eeeeee_1x100.png.svn-base b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_highlight-soft_100_eeeeee_1x100.png.svn-base new file mode 100644 index 0000000..f127367 Binary files /dev/null and b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_highlight-soft_100_eeeeee_1x100.png.svn-base differ diff --git a/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_highlight-soft_75_ffe45c_1x100.png.svn-base b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_highlight-soft_75_ffe45c_1x100.png.svn-base new file mode 100644 index 0000000..359397a Binary files /dev/null and b/test/views/css/ui-lightness/images/.svn/text-base/ui-bg_highlight-soft_75_ffe45c_1x100.png.svn-base differ diff --git a/test/views/css/ui-lightness/images/.svn/text-base/ui-icons_222222_256x240.png.svn-base b/test/views/css/ui-lightness/images/.svn/text-base/ui-icons_222222_256x240.png.svn-base new file mode 100644 index 0000000..b273ff1 Binary files /dev/null and b/test/views/css/ui-lightness/images/.svn/text-base/ui-icons_222222_256x240.png.svn-base differ diff --git a/test/views/css/ui-lightness/images/.svn/text-base/ui-icons_228ef1_256x240.png.svn-base b/test/views/css/ui-lightness/images/.svn/text-base/ui-icons_228ef1_256x240.png.svn-base new file mode 100644 index 0000000..a641a37 Binary files /dev/null and b/test/views/css/ui-lightness/images/.svn/text-base/ui-icons_228ef1_256x240.png.svn-base differ diff --git a/test/views/css/ui-lightness/images/.svn/text-base/ui-icons_ef8c08_256x240.png.svn-base b/test/views/css/ui-lightness/images/.svn/text-base/ui-icons_ef8c08_256x240.png.svn-base new file mode 100644 index 0000000..85e63e9 Binary files /dev/null and b/test/views/css/ui-lightness/images/.svn/text-base/ui-icons_ef8c08_256x240.png.svn-base differ diff --git a/test/views/css/ui-lightness/images/.svn/text-base/ui-icons_ffd27a_256x240.png.svn-base b/test/views/css/ui-lightness/images/.svn/text-base/ui-icons_ffd27a_256x240.png.svn-base new file mode 100644 index 0000000..e117eff Binary files /dev/null and b/test/views/css/ui-lightness/images/.svn/text-base/ui-icons_ffd27a_256x240.png.svn-base differ diff --git a/test/views/css/ui-lightness/images/.svn/text-base/ui-icons_ffffff_256x240.png.svn-base b/test/views/css/ui-lightness/images/.svn/text-base/ui-icons_ffffff_256x240.png.svn-base new file mode 100644 index 0000000..42f8f99 Binary files /dev/null and b/test/views/css/ui-lightness/images/.svn/text-base/ui-icons_ffffff_256x240.png.svn-base differ diff --git a/test/views/css/ui-lightness/images/ui-bg_diagonals-thick_18_b81900_40x40.png b/test/views/css/ui-lightness/images/ui-bg_diagonals-thick_18_b81900_40x40.png new file mode 100644 index 0000000..954e22d Binary files /dev/null and b/test/views/css/ui-lightness/images/ui-bg_diagonals-thick_18_b81900_40x40.png differ diff --git a/test/views/css/ui-lightness/images/ui-bg_diagonals-thick_20_666666_40x40.png b/test/views/css/ui-lightness/images/ui-bg_diagonals-thick_20_666666_40x40.png new file mode 100644 index 0000000..64ece57 Binary files /dev/null and b/test/views/css/ui-lightness/images/ui-bg_diagonals-thick_20_666666_40x40.png differ diff --git a/test/views/css/ui-lightness/images/ui-bg_flat_10_000000_40x100.png b/test/views/css/ui-lightness/images/ui-bg_flat_10_000000_40x100.png new file mode 100644 index 0000000..abdc010 Binary files /dev/null and b/test/views/css/ui-lightness/images/ui-bg_flat_10_000000_40x100.png differ diff --git a/test/views/css/ui-lightness/images/ui-bg_glass_100_f6f6f6_1x400.png b/test/views/css/ui-lightness/images/ui-bg_glass_100_f6f6f6_1x400.png new file mode 100644 index 0000000..9b383f4 Binary files /dev/null and b/test/views/css/ui-lightness/images/ui-bg_glass_100_f6f6f6_1x400.png differ diff --git a/test/views/css/ui-lightness/images/ui-bg_glass_100_fdf5ce_1x400.png b/test/views/css/ui-lightness/images/ui-bg_glass_100_fdf5ce_1x400.png new file mode 100644 index 0000000..a23baad Binary files /dev/null and b/test/views/css/ui-lightness/images/ui-bg_glass_100_fdf5ce_1x400.png differ diff --git a/test/views/css/ui-lightness/images/ui-bg_glass_65_ffffff_1x400.png b/test/views/css/ui-lightness/images/ui-bg_glass_65_ffffff_1x400.png new file mode 100644 index 0000000..42ccba2 Binary files /dev/null and b/test/views/css/ui-lightness/images/ui-bg_glass_65_ffffff_1x400.png differ diff --git a/test/views/css/ui-lightness/images/ui-bg_gloss-wave_35_f6a828_500x100.png b/test/views/css/ui-lightness/images/ui-bg_gloss-wave_35_f6a828_500x100.png new file mode 100644 index 0000000..39d5824 Binary files /dev/null and b/test/views/css/ui-lightness/images/ui-bg_gloss-wave_35_f6a828_500x100.png differ diff --git a/test/views/css/ui-lightness/images/ui-bg_highlight-soft_100_eeeeee_1x100.png b/test/views/css/ui-lightness/images/ui-bg_highlight-soft_100_eeeeee_1x100.png new file mode 100644 index 0000000..f127367 Binary files /dev/null and b/test/views/css/ui-lightness/images/ui-bg_highlight-soft_100_eeeeee_1x100.png differ diff --git a/test/views/css/ui-lightness/images/ui-bg_highlight-soft_75_ffe45c_1x100.png b/test/views/css/ui-lightness/images/ui-bg_highlight-soft_75_ffe45c_1x100.png new file mode 100644 index 0000000..359397a Binary files /dev/null and b/test/views/css/ui-lightness/images/ui-bg_highlight-soft_75_ffe45c_1x100.png differ diff --git a/test/views/css/ui-lightness/images/ui-icons_222222_256x240.png b/test/views/css/ui-lightness/images/ui-icons_222222_256x240.png new file mode 100644 index 0000000..b273ff1 Binary files /dev/null and b/test/views/css/ui-lightness/images/ui-icons_222222_256x240.png differ diff --git a/test/views/css/ui-lightness/images/ui-icons_228ef1_256x240.png b/test/views/css/ui-lightness/images/ui-icons_228ef1_256x240.png new file mode 100644 index 0000000..a641a37 Binary files /dev/null and b/test/views/css/ui-lightness/images/ui-icons_228ef1_256x240.png differ diff --git a/test/views/css/ui-lightness/images/ui-icons_ef8c08_256x240.png b/test/views/css/ui-lightness/images/ui-icons_ef8c08_256x240.png new file mode 100644 index 0000000..85e63e9 Binary files /dev/null and b/test/views/css/ui-lightness/images/ui-icons_ef8c08_256x240.png differ diff --git a/test/views/css/ui-lightness/images/ui-icons_ffd27a_256x240.png b/test/views/css/ui-lightness/images/ui-icons_ffd27a_256x240.png new file mode 100644 index 0000000..e117eff Binary files /dev/null and b/test/views/css/ui-lightness/images/ui-icons_ffd27a_256x240.png differ diff --git a/test/views/css/ui-lightness/images/ui-icons_ffffff_256x240.png b/test/views/css/ui-lightness/images/ui-icons_ffffff_256x240.png new file mode 100644 index 0000000..42f8f99 Binary files /dev/null and b/test/views/css/ui-lightness/images/ui-icons_ffffff_256x240.png differ diff --git a/test/views/css/ui-lightness/jquery-ui-1.8.13.custom.css b/test/views/css/ui-lightness/jquery-ui-1.8.13.custom.css new file mode 100644 index 0000000..4c33c4c --- /dev/null +++ b/test/views/css/ui-lightness/jquery-ui-1.8.13.custom.css @@ -0,0 +1,578 @@ +/* + * jQuery UI CSS Framework 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Theming/API + */ + +/* Layout helpers +----------------------------------*/ +.ui-helper-hidden { display: none; } +.ui-helper-hidden-accessible { position: absolute !important; clip: rect(1px 1px 1px 1px); clip: rect(1px,1px,1px,1px); } +.ui-helper-reset { margin: 0; padding: 0; border: 0; outline: 0; line-height: 1.3; text-decoration: none; font-size: 100%; list-style: none; } +.ui-helper-clearfix:after { content: "."; display: block; height: 0; clear: both; visibility: hidden; } +.ui-helper-clearfix { display: inline-block; } +/* required comment for clearfix to work in Opera \*/ +* html .ui-helper-clearfix { height:1%; } +.ui-helper-clearfix { display:block; } +/* end clearfix */ +.ui-helper-zfix { width: 100%; height: 100%; top: 0; left: 0; position: absolute; opacity: 0; filter:Alpha(Opacity=0); } + + +/* Interaction Cues +----------------------------------*/ +.ui-state-disabled { cursor: default !important; } + + +/* Icons +----------------------------------*/ + +/* states and images */ +.ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; } + + +/* Misc visuals +----------------------------------*/ + +/* Overlays */ +.ui-widget-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; } + + +/* + * jQuery UI CSS Framework 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Theming/API + * + * To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Trebuchet%20MS,%20Tahoma,%20Verdana,%20Arial,%20sans-serif&fwDefault=bold&fsDefault=1.1em&cornerRadius=4px&bgColorHeader=f6a828&bgTextureHeader=12_gloss_wave.png&bgImgOpacityHeader=35&borderColorHeader=e78f08&fcHeader=ffffff&iconColorHeader=ffffff&bgColorContent=eeeeee&bgTextureContent=03_highlight_soft.png&bgImgOpacityContent=100&borderColorContent=dddddd&fcContent=333333&iconColorContent=222222&bgColorDefault=f6f6f6&bgTextureDefault=02_glass.png&bgImgOpacityDefault=100&borderColorDefault=cccccc&fcDefault=1c94c4&iconColorDefault=ef8c08&bgColorHover=fdf5ce&bgTextureHover=02_glass.png&bgImgOpacityHover=100&borderColorHover=fbcb09&fcHover=c77405&iconColorHover=ef8c08&bgColorActive=ffffff&bgTextureActive=02_glass.png&bgImgOpacityActive=65&borderColorActive=fbd850&fcActive=eb8f00&iconColorActive=ef8c08&bgColorHighlight=ffe45c&bgTextureHighlight=03_highlight_soft.png&bgImgOpacityHighlight=75&borderColorHighlight=fed22f&fcHighlight=363636&iconColorHighlight=228ef1&bgColorError=b81900&bgTextureError=08_diagonals_thick.png&bgImgOpacityError=18&borderColorError=cd0a0a&fcError=ffffff&iconColorError=ffd27a&bgColorOverlay=666666&bgTextureOverlay=08_diagonals_thick.png&bgImgOpacityOverlay=20&opacityOverlay=50&bgColorShadow=000000&bgTextureShadow=01_flat.png&bgImgOpacityShadow=10&opacityShadow=20&thicknessShadow=5px&offsetTopShadow=-5px&offsetLeftShadow=-5px&cornerRadiusShadow=5px + */ + + +/* Component containers +----------------------------------*/ +.ui-widget { font-family: Trebuchet MS, Tahoma, Verdana, Arial, sans-serif; font-size: 1.1em; } +.ui-widget .ui-widget { font-size: 1em; } +.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-family: Trebuchet MS, Tahoma, Verdana, Arial, sans-serif; font-size: 1em; } +.ui-widget-content { border: 1px solid #dddddd; background: #eeeeee url(images/ui-bg_highlight-soft_100_eeeeee_1x100.png) 50% top repeat-x; color: #333333; } +.ui-widget-content a { color: #333333; } +.ui-widget-header { border: 1px solid #e78f08; background: #f6a828 url(images/ui-bg_gloss-wave_35_f6a828_500x100.png) 50% 50% repeat-x; color: #ffffff; font-weight: bold; } +.ui-widget-header a { color: #ffffff; } + +/* Interaction states +----------------------------------*/ +.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #cccccc; background: #f6f6f6 url(images/ui-bg_glass_100_f6f6f6_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #1c94c4; } +.ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #1c94c4; text-decoration: none; } +.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { border: 1px solid #fbcb09; background: #fdf5ce url(images/ui-bg_glass_100_fdf5ce_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #c77405; } +.ui-state-hover a, .ui-state-hover a:hover { color: #c77405; text-decoration: none; } +.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #fbd850; background: #ffffff url(images/ui-bg_glass_65_ffffff_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #eb8f00; } +.ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #eb8f00; text-decoration: none; } +.ui-widget :active { outline: none; } + +/* Interaction Cues +----------------------------------*/ +.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {border: 1px solid #fed22f; background: #ffe45c url(images/ui-bg_highlight-soft_75_ffe45c_1x100.png) 50% top repeat-x; color: #363636; } +.ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636; } +.ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid #cd0a0a; background: #b81900 url(images/ui-bg_diagonals-thick_18_b81900_40x40.png) 50% 50% repeat; color: #ffffff; } +.ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #ffffff; } +.ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #ffffff; } +.ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; } +.ui-priority-secondary, .ui-widget-content .ui-priority-secondary, .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; } +.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; } + +/* Icons +----------------------------------*/ + +/* states and images */ +.ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_222222_256x240.png); } +.ui-widget-content .ui-icon {background-image: url(images/ui-icons_222222_256x240.png); } +.ui-widget-header .ui-icon {background-image: url(images/ui-icons_ffffff_256x240.png); } +.ui-state-default .ui-icon { background-image: url(images/ui-icons_ef8c08_256x240.png); } +.ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_ef8c08_256x240.png); } +.ui-state-active .ui-icon {background-image: url(images/ui-icons_ef8c08_256x240.png); } +.ui-state-highlight .ui-icon {background-image: url(images/ui-icons_228ef1_256x240.png); } +.ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_ffd27a_256x240.png); } + +/* positioning */ +.ui-icon-carat-1-n { background-position: 0 0; } +.ui-icon-carat-1-ne { background-position: -16px 0; } +.ui-icon-carat-1-e { background-position: -32px 0; } +.ui-icon-carat-1-se { background-position: -48px 0; } +.ui-icon-carat-1-s { background-position: -64px 0; } +.ui-icon-carat-1-sw { background-position: -80px 0; } +.ui-icon-carat-1-w { background-position: -96px 0; } +.ui-icon-carat-1-nw { background-position: -112px 0; } +.ui-icon-carat-2-n-s { background-position: -128px 0; } +.ui-icon-carat-2-e-w { background-position: -144px 0; } +.ui-icon-triangle-1-n { background-position: 0 -16px; } +.ui-icon-triangle-1-ne { background-position: -16px -16px; } +.ui-icon-triangle-1-e { background-position: -32px -16px; } +.ui-icon-triangle-1-se { background-position: -48px -16px; } +.ui-icon-triangle-1-s { background-position: -64px -16px; } +.ui-icon-triangle-1-sw { background-position: -80px -16px; } +.ui-icon-triangle-1-w { background-position: -96px -16px; } +.ui-icon-triangle-1-nw { background-position: -112px -16px; } +.ui-icon-triangle-2-n-s { background-position: -128px -16px; } +.ui-icon-triangle-2-e-w { background-position: -144px -16px; } +.ui-icon-arrow-1-n { background-position: 0 -32px; } +.ui-icon-arrow-1-ne { background-position: -16px -32px; } +.ui-icon-arrow-1-e { background-position: -32px -32px; } +.ui-icon-arrow-1-se { background-position: -48px -32px; } +.ui-icon-arrow-1-s { background-position: -64px -32px; } +.ui-icon-arrow-1-sw { background-position: -80px -32px; } +.ui-icon-arrow-1-w { background-position: -96px -32px; } +.ui-icon-arrow-1-nw { background-position: -112px -32px; } +.ui-icon-arrow-2-n-s { background-position: -128px -32px; } +.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; } +.ui-icon-arrow-2-e-w { background-position: -160px -32px; } +.ui-icon-arrow-2-se-nw { background-position: -176px -32px; } +.ui-icon-arrowstop-1-n { background-position: -192px -32px; } +.ui-icon-arrowstop-1-e { background-position: -208px -32px; } +.ui-icon-arrowstop-1-s { background-position: -224px -32px; } +.ui-icon-arrowstop-1-w { background-position: -240px -32px; } +.ui-icon-arrowthick-1-n { background-position: 0 -48px; } +.ui-icon-arrowthick-1-ne { background-position: -16px -48px; } +.ui-icon-arrowthick-1-e { background-position: -32px -48px; } +.ui-icon-arrowthick-1-se { background-position: -48px -48px; } +.ui-icon-arrowthick-1-s { background-position: -64px -48px; } +.ui-icon-arrowthick-1-sw { background-position: -80px -48px; } +.ui-icon-arrowthick-1-w { background-position: -96px -48px; } +.ui-icon-arrowthick-1-nw { background-position: -112px -48px; } +.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; } +.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; } +.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; } +.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; } +.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; } +.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; } +.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; } +.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; } +.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; } +.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; } +.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; } +.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; } +.ui-icon-arrowreturn-1-w { background-position: -64px -64px; } +.ui-icon-arrowreturn-1-n { background-position: -80px -64px; } +.ui-icon-arrowreturn-1-e { background-position: -96px -64px; } +.ui-icon-arrowreturn-1-s { background-position: -112px -64px; } +.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; } +.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; } +.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; } +.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; } +.ui-icon-arrow-4 { background-position: 0 -80px; } +.ui-icon-arrow-4-diag { background-position: -16px -80px; } +.ui-icon-extlink { background-position: -32px -80px; } +.ui-icon-newwin { background-position: -48px -80px; } +.ui-icon-refresh { background-position: -64px -80px; } +.ui-icon-shuffle { background-position: -80px -80px; } +.ui-icon-transfer-e-w { background-position: -96px -80px; } +.ui-icon-transferthick-e-w { background-position: -112px -80px; } +.ui-icon-folder-collapsed { background-position: 0 -96px; } +.ui-icon-folder-open { background-position: -16px -96px; } +.ui-icon-document { background-position: -32px -96px; } +.ui-icon-document-b { background-position: -48px -96px; } +.ui-icon-note { background-position: -64px -96px; } +.ui-icon-mail-closed { background-position: -80px -96px; } +.ui-icon-mail-open { background-position: -96px -96px; } +.ui-icon-suitcase { background-position: -112px -96px; } +.ui-icon-comment { background-position: -128px -96px; } +.ui-icon-person { background-position: -144px -96px; } +.ui-icon-print { background-position: -160px -96px; } +.ui-icon-trash { background-position: -176px -96px; } +.ui-icon-locked { background-position: -192px -96px; } +.ui-icon-unlocked { background-position: -208px -96px; } +.ui-icon-bookmark { background-position: -224px -96px; } +.ui-icon-tag { background-position: -240px -96px; } +.ui-icon-home { background-position: 0 -112px; } +.ui-icon-flag { background-position: -16px -112px; } +.ui-icon-calendar { background-position: -32px -112px; } +.ui-icon-cart { background-position: -48px -112px; } +.ui-icon-pencil { background-position: -64px -112px; } +.ui-icon-clock { background-position: -80px -112px; } +.ui-icon-disk { background-position: -96px -112px; } +.ui-icon-calculator { background-position: -112px -112px; } +.ui-icon-zoomin { background-position: -128px -112px; } +.ui-icon-zoomout { background-position: -144px -112px; } +.ui-icon-search { background-position: -160px -112px; } +.ui-icon-wrench { background-position: -176px -112px; } +.ui-icon-gear { background-position: -192px -112px; } +.ui-icon-heart { background-position: -208px -112px; } +.ui-icon-star { background-position: -224px -112px; } +.ui-icon-link { background-position: -240px -112px; } +.ui-icon-cancel { background-position: 0 -128px; } +.ui-icon-plus { background-position: -16px -128px; } +.ui-icon-plusthick { background-position: -32px -128px; } +.ui-icon-minus { background-position: -48px -128px; } +.ui-icon-minusthick { background-position: -64px -128px; } +.ui-icon-close { background-position: -80px -128px; } +.ui-icon-closethick { background-position: -96px -128px; } +.ui-icon-key { background-position: -112px -128px; } +.ui-icon-lightbulb { background-position: -128px -128px; } +.ui-icon-scissors { background-position: -144px -128px; } +.ui-icon-clipboard { background-position: -160px -128px; } +.ui-icon-copy { background-position: -176px -128px; } +.ui-icon-contact { background-position: -192px -128px; } +.ui-icon-image { background-position: -208px -128px; } +.ui-icon-video { background-position: -224px -128px; } +.ui-icon-script { background-position: -240px -128px; } +.ui-icon-alert { background-position: 0 -144px; } +.ui-icon-info { background-position: -16px -144px; } +.ui-icon-notice { background-position: -32px -144px; } +.ui-icon-help { background-position: -48px -144px; } +.ui-icon-check { background-position: -64px -144px; } +.ui-icon-bullet { background-position: -80px -144px; } +.ui-icon-radio-off { background-position: -96px -144px; } +.ui-icon-radio-on { background-position: -112px -144px; } +.ui-icon-pin-w { background-position: -128px -144px; } +.ui-icon-pin-s { background-position: -144px -144px; } +.ui-icon-play { background-position: 0 -160px; } +.ui-icon-pause { background-position: -16px -160px; } +.ui-icon-seek-next { background-position: -32px -160px; } +.ui-icon-seek-prev { background-position: -48px -160px; } +.ui-icon-seek-end { background-position: -64px -160px; } +.ui-icon-seek-start { background-position: -80px -160px; } +/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */ +.ui-icon-seek-first { background-position: -80px -160px; } +.ui-icon-stop { background-position: -96px -160px; } +.ui-icon-eject { background-position: -112px -160px; } +.ui-icon-volume-off { background-position: -128px -160px; } +.ui-icon-volume-on { background-position: -144px -160px; } +.ui-icon-power { background-position: 0 -176px; } +.ui-icon-signal-diag { background-position: -16px -176px; } +.ui-icon-signal { background-position: -32px -176px; } +.ui-icon-battery-0 { background-position: -48px -176px; } +.ui-icon-battery-1 { background-position: -64px -176px; } +.ui-icon-battery-2 { background-position: -80px -176px; } +.ui-icon-battery-3 { background-position: -96px -176px; } +.ui-icon-circle-plus { background-position: 0 -192px; } +.ui-icon-circle-minus { background-position: -16px -192px; } +.ui-icon-circle-close { background-position: -32px -192px; } +.ui-icon-circle-triangle-e { background-position: -48px -192px; } +.ui-icon-circle-triangle-s { background-position: -64px -192px; } +.ui-icon-circle-triangle-w { background-position: -80px -192px; } +.ui-icon-circle-triangle-n { background-position: -96px -192px; } +.ui-icon-circle-arrow-e { background-position: -112px -192px; } +.ui-icon-circle-arrow-s { background-position: -128px -192px; } +.ui-icon-circle-arrow-w { background-position: -144px -192px; } +.ui-icon-circle-arrow-n { background-position: -160px -192px; } +.ui-icon-circle-zoomin { background-position: -176px -192px; } +.ui-icon-circle-zoomout { background-position: -192px -192px; } +.ui-icon-circle-check { background-position: -208px -192px; } +.ui-icon-circlesmall-plus { background-position: 0 -208px; } +.ui-icon-circlesmall-minus { background-position: -16px -208px; } +.ui-icon-circlesmall-close { background-position: -32px -208px; } +.ui-icon-squaresmall-plus { background-position: -48px -208px; } +.ui-icon-squaresmall-minus { background-position: -64px -208px; } +.ui-icon-squaresmall-close { background-position: -80px -208px; } +.ui-icon-grip-dotted-vertical { background-position: 0 -224px; } +.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; } +.ui-icon-grip-solid-vertical { background-position: -32px -224px; } +.ui-icon-grip-solid-horizontal { background-position: -48px -224px; } +.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; } +.ui-icon-grip-diagonal-se { background-position: -80px -224px; } + + +/* Misc visuals +----------------------------------*/ + +/* Corner radius */ +.ui-corner-tl { -moz-border-radius-topleft: 4px; -webkit-border-top-left-radius: 4px; border-top-left-radius: 4px; } +.ui-corner-tr { -moz-border-radius-topright: 4px; -webkit-border-top-right-radius: 4px; border-top-right-radius: 4px; } +.ui-corner-bl { -moz-border-radius-bottomleft: 4px; -webkit-border-bottom-left-radius: 4px; border-bottom-left-radius: 4px; } +.ui-corner-br { -moz-border-radius-bottomright: 4px; -webkit-border-bottom-right-radius: 4px; border-bottom-right-radius: 4px; } +.ui-corner-top { -moz-border-radius-topleft: 4px; -webkit-border-top-left-radius: 4px; border-top-left-radius: 4px; -moz-border-radius-topright: 4px; -webkit-border-top-right-radius: 4px; border-top-right-radius: 4px; } +.ui-corner-bottom { -moz-border-radius-bottomleft: 4px; -webkit-border-bottom-left-radius: 4px; border-bottom-left-radius: 4px; -moz-border-radius-bottomright: 4px; -webkit-border-bottom-right-radius: 4px; border-bottom-right-radius: 4px; } +.ui-corner-right { -moz-border-radius-topright: 4px; -webkit-border-top-right-radius: 4px; border-top-right-radius: 4px; -moz-border-radius-bottomright: 4px; -webkit-border-bottom-right-radius: 4px; border-bottom-right-radius: 4px; } +.ui-corner-left { -moz-border-radius-topleft: 4px; -webkit-border-top-left-radius: 4px; border-top-left-radius: 4px; -moz-border-radius-bottomleft: 4px; -webkit-border-bottom-left-radius: 4px; border-bottom-left-radius: 4px; } +.ui-corner-all { -moz-border-radius: 4px; -webkit-border-radius: 4px; border-radius: 4px; } + +/* Overlays */ +.ui-widget-overlay { background: #666666 url(images/ui-bg_diagonals-thick_20_666666_40x40.png) 50% 50% repeat; opacity: .50;filter:Alpha(Opacity=50); } +.ui-widget-shadow { margin: -5px 0 0 -5px; padding: 5px; background: #000000 url(images/ui-bg_flat_10_000000_40x100.png) 50% 50% repeat-x; opacity: .20;filter:Alpha(Opacity=20); -moz-border-radius: 5px; -webkit-border-radius: 5px; border-radius: 5px; }/* + * jQuery UI Resizable 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Resizable#theming + */ +.ui-resizable { position: relative;} +.ui-resizable-handle { position: absolute;font-size: 0.1px;z-index: 99999; display: block; + /* http://bugs.jqueryui.com/ticket/7233 + - Resizable: resizable handles fail to work in IE if transparent and content overlaps + */ + background-image:url(data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs=); +} +.ui-resizable-disabled .ui-resizable-handle, .ui-resizable-autohide .ui-resizable-handle { display: none; } +.ui-resizable-n { cursor: n-resize; height: 7px; width: 100%; top: -5px; left: 0; } +.ui-resizable-s { cursor: s-resize; height: 7px; width: 100%; bottom: -5px; left: 0; } +.ui-resizable-e { cursor: e-resize; width: 7px; right: -5px; top: 0; height: 100%; } +.ui-resizable-w { cursor: w-resize; width: 7px; left: -5px; top: 0; height: 100%; } +.ui-resizable-se { cursor: se-resize; width: 12px; height: 12px; right: 1px; bottom: 1px; } +.ui-resizable-sw { cursor: sw-resize; width: 9px; height: 9px; left: -5px; bottom: -5px; } +.ui-resizable-nw { cursor: nw-resize; width: 9px; height: 9px; left: -5px; top: -5px; } +.ui-resizable-ne { cursor: ne-resize; width: 9px; height: 9px; right: -5px; top: -5px;}/* + * jQuery UI Selectable 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Selectable#theming + */ +.ui-selectable-helper { position: absolute; z-index: 100; border:1px dotted black; } +/* + * jQuery UI Accordion 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Accordion#theming + */ +/* IE/Win - Fix animation bug - #4615 */ +.ui-accordion { width: 100%; } +.ui-accordion .ui-accordion-header { cursor: pointer; position: relative; margin-top: 1px; zoom: 1; } +.ui-accordion .ui-accordion-li-fix { display: inline; } +.ui-accordion .ui-accordion-header-active { border-bottom: 0 !important; } +.ui-accordion .ui-accordion-header a { display: block; font-size: 1em; padding: .5em .5em .5em .7em; } +.ui-accordion-icons .ui-accordion-header a { padding-left: 2.2em; } +.ui-accordion .ui-accordion-header .ui-icon { position: absolute; left: .5em; top: 50%; margin-top: -8px; } +.ui-accordion .ui-accordion-content { padding: 1em 2.2em; border-top: 0; margin-top: -2px; position: relative; top: 1px; margin-bottom: 2px; overflow: auto; display: none; zoom: 1; } +.ui-accordion .ui-accordion-content-active { display: block; } +/* + * jQuery UI Autocomplete 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Autocomplete#theming + */ +.ui-autocomplete { position: absolute; cursor: default; } + +/* workarounds */ +* html .ui-autocomplete { width:1px; } /* without this, the menu expands to 100% in IE6 */ + +/* + * jQuery UI Menu 1.8.13 + * + * Copyright 2010, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Menu#theming + */ +.ui-menu { + list-style:none; + padding: 2px; + margin: 0; + display:block; + float: left; +} +.ui-menu .ui-menu { + margin-top: -3px; +} +.ui-menu .ui-menu-item { + margin:0; + padding: 0; + zoom: 1; + float: left; + clear: left; + width: 100%; +} +.ui-menu .ui-menu-item a { + text-decoration:none; + display:block; + padding:.2em .4em; + line-height:1.5; + zoom:1; +} +.ui-menu .ui-menu-item a.ui-state-hover, +.ui-menu .ui-menu-item a.ui-state-active { + font-weight: normal; + margin: -1px; +} +/* + * jQuery UI Button 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Button#theming + */ +.ui-button { display: inline-block; position: relative; padding: 0; margin-right: .1em; text-decoration: none !important; cursor: pointer; text-align: center; zoom: 1; overflow: visible; } /* the overflow property removes extra width in IE */ +.ui-button-icon-only { width: 2.2em; } /* to make room for the icon, a width needs to be set here */ +button.ui-button-icon-only { width: 2.4em; } /* button elements seem to need a little more width */ +.ui-button-icons-only { width: 3.4em; } +button.ui-button-icons-only { width: 3.7em; } + +/*button text element */ +.ui-button .ui-button-text { display: block; line-height: 1.4; } +.ui-button-text-only .ui-button-text { padding: .4em 1em; } +.ui-button-icon-only .ui-button-text, .ui-button-icons-only .ui-button-text { padding: .4em; text-indent: -9999999px; } +.ui-button-text-icon-primary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 1em .4em 2.1em; } +.ui-button-text-icon-secondary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 2.1em .4em 1em; } +.ui-button-text-icons .ui-button-text { padding-left: 2.1em; padding-right: 2.1em; } +/* no icon support for input elements, provide padding by default */ +input.ui-button { padding: .4em 1em; } + +/*button icon element(s) */ +.ui-button-icon-only .ui-icon, .ui-button-text-icon-primary .ui-icon, .ui-button-text-icon-secondary .ui-icon, .ui-button-text-icons .ui-icon, .ui-button-icons-only .ui-icon { position: absolute; top: 50%; margin-top: -8px; } +.ui-button-icon-only .ui-icon { left: 50%; margin-left: -8px; } +.ui-button-text-icon-primary .ui-button-icon-primary, .ui-button-text-icons .ui-button-icon-primary, .ui-button-icons-only .ui-button-icon-primary { left: .5em; } +.ui-button-text-icon-secondary .ui-button-icon-secondary, .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } +.ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } + +/*button sets*/ +.ui-buttonset { margin-right: 7px; } +.ui-buttonset .ui-button { margin-left: 0; margin-right: -.3em; } + +/* workarounds */ +button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra padding in Firefox */ +/* + * jQuery UI Dialog 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Dialog#theming + */ +.ui-dialog { position: absolute; padding: .2em; width: 300px; overflow: hidden; } +.ui-dialog .ui-dialog-titlebar { padding: .4em 1em; position: relative; } +.ui-dialog .ui-dialog-title { float: left; margin: .1em 16px .1em 0; } +.ui-dialog .ui-dialog-titlebar-close { position: absolute; right: .3em; top: 50%; width: 19px; margin: -10px 0 0 0; padding: 1px; height: 18px; } +.ui-dialog .ui-dialog-titlebar-close span { display: block; margin: 1px; } +.ui-dialog .ui-dialog-titlebar-close:hover, .ui-dialog .ui-dialog-titlebar-close:focus { padding: 0; } +.ui-dialog .ui-dialog-content { position: relative; border: 0; padding: .5em 1em; background: none; overflow: auto; zoom: 1; } +.ui-dialog .ui-dialog-buttonpane { text-align: left; border-width: 1px 0 0 0; background-image: none; margin: .5em 0 0 0; padding: .3em 1em .5em .4em; } +.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset { float: right; } +.ui-dialog .ui-dialog-buttonpane button { margin: .5em .4em .5em 0; cursor: pointer; } +.ui-dialog .ui-resizable-se { width: 14px; height: 14px; right: 3px; bottom: 3px; } +.ui-draggable .ui-dialog-titlebar { cursor: move; } +/* + * jQuery UI Slider 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Slider#theming + */ +.ui-slider { position: relative; text-align: left; } +.ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 1.2em; height: 1.2em; cursor: default; } +.ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: .7em; display: block; border: 0; background-position: 0 0; } + +.ui-slider-horizontal { height: .8em; } +.ui-slider-horizontal .ui-slider-handle { top: -.3em; margin-left: -.6em; } +.ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; } +.ui-slider-horizontal .ui-slider-range-min { left: 0; } +.ui-slider-horizontal .ui-slider-range-max { right: 0; } + +.ui-slider-vertical { width: .8em; height: 100px; } +.ui-slider-vertical .ui-slider-handle { left: -.3em; margin-left: 0; margin-bottom: -.6em; } +.ui-slider-vertical .ui-slider-range { left: 0; width: 100%; } +.ui-slider-vertical .ui-slider-range-min { bottom: 0; } +.ui-slider-vertical .ui-slider-range-max { top: 0; }/* + * jQuery UI Tabs 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Tabs#theming + */ +.ui-tabs { position: relative; padding: .2em; zoom: 1; } /* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */ +.ui-tabs .ui-tabs-nav { margin: 0; padding: .2em .2em 0; } +.ui-tabs .ui-tabs-nav li { list-style: none; float: left; position: relative; top: 1px; margin: 0 .2em 1px 0; border-bottom: 0 !important; padding: 0; white-space: nowrap; } +.ui-tabs .ui-tabs-nav li a { float: left; padding: .5em 1em; text-decoration: none; } +.ui-tabs .ui-tabs-nav li.ui-tabs-selected { margin-bottom: 0; padding-bottom: 1px; } +.ui-tabs .ui-tabs-nav li.ui-tabs-selected a, .ui-tabs .ui-tabs-nav li.ui-state-disabled a, .ui-tabs .ui-tabs-nav li.ui-state-processing a { cursor: text; } +.ui-tabs .ui-tabs-nav li a, .ui-tabs.ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-selected a { cursor: pointer; } /* first selector in group seems obsolete, but required to overcome bug in Opera applying cursor: text overall if defined elsewhere... */ +.ui-tabs .ui-tabs-panel { display: block; border-width: 0; padding: 1em 1.4em; background: none; } +.ui-tabs .ui-tabs-hide { display: none !important; } +/* + * jQuery UI Datepicker 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Datepicker#theming + */ +.ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; } +.ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; } +.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; } +.ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; } +.ui-datepicker .ui-datepicker-prev { left:2px; } +.ui-datepicker .ui-datepicker-next { right:2px; } +.ui-datepicker .ui-datepicker-prev-hover { left:1px; } +.ui-datepicker .ui-datepicker-next-hover { right:1px; } +.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px; } +.ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; } +.ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; } +.ui-datepicker select.ui-datepicker-month-year {width: 100%;} +.ui-datepicker select.ui-datepicker-month, +.ui-datepicker select.ui-datepicker-year { width: 49%;} +.ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; } +.ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0; } +.ui-datepicker td { border: 0; padding: 1px; } +.ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; } +.ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; } +.ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; } +.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; } + +/* with multiple calendars */ +.ui-datepicker.ui-datepicker-multi { width:auto; } +.ui-datepicker-multi .ui-datepicker-group { float:left; } +.ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; } +.ui-datepicker-multi-2 .ui-datepicker-group { width:50%; } +.ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; } +.ui-datepicker-multi-4 .ui-datepicker-group { width:25%; } +.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; } +.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; } +.ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; } +.ui-datepicker-row-break { clear:both; width:100%; } + +/* RTL support */ +.ui-datepicker-rtl { direction: rtl; } +.ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; } +.ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; } +.ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; } +.ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; } +.ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; } +.ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; } +.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; } +.ui-datepicker-rtl .ui-datepicker-group { float:right; } +.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; } +.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; } + +/* IE6 IFRAME FIX (taken from datepicker 1.5.3 */ +.ui-datepicker-cover { + display: none; /*sorry for IE5*/ + display/**/: block; /*sorry for IE5*/ + position: absolute; /*must have*/ + z-index: -1; /*must have*/ + filter: mask(); /*must have*/ + top: -4px; /*must have*/ + left: -4px; /*must have*/ + width: 200px; /*must have*/ + height: 200px; /*must have*/ +}/* + * jQuery UI Progressbar 1.8.13 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Progressbar#theming + */ +.ui-progressbar { height:2em; text-align: left; } +.ui-progressbar .ui-progressbar-value {margin: -1px; height:100%; } \ No newline at end of file diff --git a/test/views/index.tal b/test/views/index.tal new file mode 100644 index 0000000..1739f89 --- /dev/null +++ b/test/views/index.tal @@ -0,0 +1,172 @@ + + + + Task manager + + + + + + + + + + + + + + + + + + + Ðазвание + + + + Срок + + + УÑтановить дату + Ð¡ÐµÐ³Ð¾Ð´Ð½Ñ + Завтра + Ðа Ñтой неделе + Ðа Ñледующей неделе + Ð’ Ñтом меÑÑце + Ð’ Ñледующем меÑÑце + + + Дата + + + + + + + + + + Ðазвание + + + + + + Приоритет + + + + Срочный + Ð’Ñ‹Ñокий + Ðормальный + Ðизкий + + + + + + + + + + + + + + + Remove Tab + + + + ÐеÑортированные + + + + + Adding tab... + + + Добавить... + + + + + + + + + + Создать задачу: + + + + + Ðазвание: + + + + Закладка: + + + Выберите закладку... + + + + + + + + + Дополнительно + + + + + Приоритет: + + + Срочный + Ð’Ñ‹Ñокий + Ðормальный + Ðизкий + + + + Дата: + + + + + + + + + + + + + + + + + + + + diff --git a/test/views/index_main.tal b/test/views/index_main.tal new file mode 100644 index 0000000..2a620e0 --- /dev/null +++ b/test/views/index_main.tal @@ -0,0 +1,26 @@ + + + + Ð¡ÐµÐ³Ð¾Ð´Ð½Ñ + + + Remove Tab + + + + Завтра + + + Remove Tab + + + + Unsorted + + + + + Add tab... + + \ No newline at end of file diff --git a/test/views/js/jquery-1.5.1.min.js b/test/views/js/jquery-1.5.1.min.js new file mode 100644 index 0000000..6437874 --- /dev/null +++ b/test/views/js/jquery-1.5.1.min.js @@ -0,0 +1,16 @@ +/*! + * jQuery JavaScript Library v1.5.1 + * http://jquery.com/ + * + * Copyright 2011, John Resig + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * Includes Sizzle.js + * http://sizzlejs.com/ + * Copyright 2011, The Dojo Foundation + * Released under the MIT, BSD, and GPL Licenses. + * + * Date: Wed Feb 23 13:55:29 2011 -0500 + */ +(function(a,b){function cg(a){return d.isWindow(a)?a:a.nodeType===9?a.defaultView||a.parentWindow:!1}function cd(a){if(!bZ[a]){var b=d("<"+a+">").appendTo("body"),c=b.css("display");b.remove();if(c==="none"||c==="")c="block";bZ[a]=c}return bZ[a]}function cc(a,b){var c={};d.each(cb.concat.apply([],cb.slice(0,b)),function(){c[this]=a});return c}function bY(){try{return new a.ActiveXObject("Microsoft.XMLHTTP")}catch(b){}}function bX(){try{return new a.XMLHttpRequest}catch(b){}}function bW(){d(a).unload(function(){for(var a in bU)bU[a](0,1)})}function bQ(a,c){a.dataFilter&&(c=a.dataFilter(c,a.dataType));var e=a.dataTypes,f={},g,h,i=e.length,j,k=e[0],l,m,n,o,p;for(g=1;g=0===c})}function N(a){return!a||!a.parentNode||a.parentNode.nodeType===11}function F(a,b){return(a&&a!=="*"?a+".":"")+b.replace(r,"`").replace(s,"&")}function E(a){var b,c,e,f,g,h,i,j,k,l,m,n,o,q=[],r=[],s=d._data(this,"events");if(a.liveFired!==this&&s&&s.live&&!a.target.disabled&&(!a.button||a.type!=="click")){a.namespace&&(n=new RegExp("(^|\\.)"+a.namespace.split(".").join("\\.(?:.*\\.)?")+"(\\.|$)")),a.liveFired=this;var t=s.live.slice(0);for(i=0;ic)break;a.currentTarget=f.elem,a.data=f.handleObj.data,a.handleObj=f.handleObj,o=f.handleObj.origHandler.apply(f.elem,arguments);if(o===!1||a.isPropagationStopped()){c=f.level,o===!1&&(b=!1);if(a.isImmediatePropagationStopped())break}}return b}}function C(a,c,e){var f=d.extend({},e[0]);f.type=a,f.originalEvent={},f.liveFired=b,d.event.handle.call(c,f),f.isDefaultPrevented()&&e[0].preventDefault()}function w(){return!0}function v(){return!1}function g(a){for(var b in a)if(b!=="toJSON")return!1;return!0}function f(a,c,f){if(f===b&&a.nodeType===1){f=a.getAttribute("data-"+c);if(typeof f==="string"){try{f=f==="true"?!0:f==="false"?!1:f==="null"?null:d.isNaN(f)?e.test(f)?d.parseJSON(f):f:parseFloat(f)}catch(g){}d.data(a,c,f)}else f=b}return f}var c=a.document,d=function(){function I(){if(!d.isReady){try{c.documentElement.doScroll("left")}catch(a){setTimeout(I,1);return}d.ready()}}var d=function(a,b){return new d.fn.init(a,b,g)},e=a.jQuery,f=a.$,g,h=/^(?:[^<]*(<[\w\W]+>)[^>]*$|#([\w\-]+)$)/,i=/\S/,j=/^\s+/,k=/\s+$/,l=/\d/,m=/^<(\w+)\s*\/?>(?:<\/\1>)?$/,n=/^[\],:{}\s]*$/,o=/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g,p=/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,q=/(?:^|:|,)(?:\s*\[)+/g,r=/(webkit)[ \/]([\w.]+)/,s=/(opera)(?:.*version)?[ \/]([\w.]+)/,t=/(msie) ([\w.]+)/,u=/(mozilla)(?:.*? rv:([\w.]+))?/,v=navigator.userAgent,w,x=!1,y,z="then done fail isResolved isRejected promise".split(" "),A,B=Object.prototype.toString,C=Object.prototype.hasOwnProperty,D=Array.prototype.push,E=Array.prototype.slice,F=String.prototype.trim,G=Array.prototype.indexOf,H={};d.fn=d.prototype={constructor:d,init:function(a,e,f){var g,i,j,k;if(!a)return this;if(a.nodeType){this.context=this[0]=a,this.length=1;return this}if(a==="body"&&!e&&c.body){this.context=c,this[0]=c.body,this.selector="body",this.length=1;return this}if(typeof a==="string"){g=h.exec(a);if(!g||!g[1]&&e)return!e||e.jquery?(e||f).find(a):this.constructor(e).find(a);if(g[1]){e=e instanceof d?e[0]:e,k=e?e.ownerDocument||e:c,j=m.exec(a),j?d.isPlainObject(e)?(a=[c.createElement(j[1])],d.fn.attr.call(a,e,!0)):a=[k.createElement(j[1])]:(j=d.buildFragment([g[1]],[k]),a=(j.cacheable?d.clone(j.fragment):j.fragment).childNodes);return d.merge(this,a)}i=c.getElementById(g[2]);if(i&&i.parentNode){if(i.id!==g[2])return f.find(a);this.length=1,this[0]=i}this.context=c,this.selector=a;return this}if(d.isFunction(a))return f.ready(a);a.selector!==b&&(this.selector=a.selector,this.context=a.context);return d.makeArray(a,this)},selector:"",jquery:"1.5.1",length:0,size:function(){return this.length},toArray:function(){return E.call(this,0)},get:function(a){return a==null?this.toArray():a<0?this[this.length+a]:this[a]},pushStack:function(a,b,c){var e=this.constructor();d.isArray(a)?D.apply(e,a):d.merge(e,a),e.prevObject=this,e.context=this.context,b==="find"?e.selector=this.selector+(this.selector?" ":"")+c:b&&(e.selector=this.selector+"."+b+"("+c+")");return e},each:function(a,b){return d.each(this,a,b)},ready:function(a){d.bindReady(),y.done(a);return this},eq:function(a){return a===-1?this.slice(a):this.slice(a,+a+1)},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},slice:function(){return this.pushStack(E.apply(this,arguments),"slice",E.call(arguments).join(","))},map:function(a){return this.pushStack(d.map(this,function(b,c){return a.call(b,c,b)}))},end:function(){return this.prevObject||this.constructor(null)},push:D,sort:[].sort,splice:[].splice},d.fn.init.prototype=d.fn,d.extend=d.fn.extend=function(){var a,c,e,f,g,h,i=arguments[0]||{},j=1,k=arguments.length,l=!1;typeof i==="boolean"&&(l=i,i=arguments[1]||{},j=2),typeof i!=="object"&&!d.isFunction(i)&&(i={}),k===j&&(i=this,--j);for(;j0)return;y.resolveWith(c,[d]),d.fn.trigger&&d(c).trigger("ready").unbind("ready")}},bindReady:function(){if(!x){x=!0;if(c.readyState==="complete")return setTimeout(d.ready,1);if(c.addEventListener)c.addEventListener("DOMContentLoaded",A,!1),a.addEventListener("load",d.ready,!1);else if(c.attachEvent){c.attachEvent("onreadystatechange",A),a.attachEvent("onload",d.ready);var b=!1;try{b=a.frameElement==null}catch(e){}c.documentElement.doScroll&&b&&I()}}},isFunction:function(a){return d.type(a)==="function"},isArray:Array.isArray||function(a){return d.type(a)==="array"},isWindow:function(a){return a&&typeof a==="object"&&"setInterval"in a},isNaN:function(a){return a==null||!l.test(a)||isNaN(a)},type:function(a){return a==null?String(a):H[B.call(a)]||"object"},isPlainObject:function(a){if(!a||d.type(a)!=="object"||a.nodeType||d.isWindow(a))return!1;if(a.constructor&&!C.call(a,"constructor")&&!C.call(a.constructor.prototype,"isPrototypeOf"))return!1;var c;for(c in a){}return c===b||C.call(a,c)},isEmptyObject:function(a){for(var b in a)return!1;return!0},error:function(a){throw a},parseJSON:function(b){if(typeof b!=="string"||!b)return null;b=d.trim(b);if(n.test(b.replace(o,"@").replace(p,"]").replace(q,"")))return a.JSON&&a.JSON.parse?a.JSON.parse(b):(new Function("return "+b))();d.error("Invalid JSON: "+b)},parseXML:function(b,c,e){a.DOMParser?(e=new DOMParser,c=e.parseFromString(b,"text/xml")):(c=new ActiveXObject("Microsoft.XMLDOM"),c.async="false",c.loadXML(b)),e=c.documentElement,(!e||!e.nodeName||e.nodeName==="parsererror")&&d.error("Invalid XML: "+b);return c},noop:function(){},globalEval:function(a){if(a&&i.test(a)){var b=c.head||c.getElementsByTagName("head")[0]||c.documentElement,e=c.createElement("script");d.support.scriptEval()?e.appendChild(c.createTextNode(a)):e.text=a,b.insertBefore(e,b.firstChild),b.removeChild(e)}},nodeName:function(a,b){return a.nodeName&&a.nodeName.toUpperCase()===b.toUpperCase()},each:function(a,c,e){var f,g=0,h=a.length,i=h===b||d.isFunction(a);if(e){if(i){for(f in a)if(c.apply(a[f],e)===!1)break}else for(;g1){var f=E.call(arguments,0),g=b,h=function(a){return function(b){f[a]=arguments.length>1?E.call(arguments,0):b,--g||c.resolveWith(e,f)}};while(b--)a=f[b],a&&d.isFunction(a.promise)?a.promise().then(h(b),c.reject):--g;g||c.resolveWith(e,f)}else c!==a&&c.resolve(a);return e},uaMatch:function(a){a=a.toLowerCase();var b=r.exec(a)||s.exec(a)||t.exec(a)||a.indexOf("compatible")<0&&u.exec(a)||[];return{browser:b[1]||"",version:b[2]||"0"}},sub:function(){function a(b,c){return new a.fn.init(b,c)}d.extend(!0,a,this),a.superclass=this,a.fn=a.prototype=this(),a.fn.constructor=a,a.subclass=this.subclass,a.fn.init=function b(b,c){c&&c instanceof d&&!(c instanceof a)&&(c=a(c));return d.fn.init.call(this,b,c,e)},a.fn.init.prototype=a.fn;var e=a(c);return a},browser:{}}),y=d._Deferred(),d.each("Boolean Number String Function Array Date RegExp Object".split(" "),function(a,b){H["[object "+b+"]"]=b.toLowerCase()}),w=d.uaMatch(v),w.browser&&(d.browser[w.browser]=!0,d.browser.version=w.version),d.browser.webkit&&(d.browser.safari=!0),G&&(d.inArray=function(a,b){return G.call(b,a)}),i.test(" ")&&(j=/^[\s\xA0]+/,k=/[\s\xA0]+$/),g=d(c),c.addEventListener?A=function(){c.removeEventListener("DOMContentLoaded",A,!1),d.ready()}:c.attachEvent&&(A=function(){c.readyState==="complete"&&(c.detachEvent("onreadystatechange",A),d.ready())});return d}();(function(){d.support={};var b=c.createElement("div");b.style.display="none",b.innerHTML=" a";var e=b.getElementsByTagName("*"),f=b.getElementsByTagName("a")[0],g=c.createElement("select"),h=g.appendChild(c.createElement("option")),i=b.getElementsByTagName("input")[0];if(e&&e.length&&f){d.support={leadingWhitespace:b.firstChild.nodeType===3,tbody:!b.getElementsByTagName("tbody").length,htmlSerialize:!!b.getElementsByTagName("link").length,style:/red/.test(f.getAttribute("style")),hrefNormalized:f.getAttribute("href")==="/a",opacity:/^0.55$/.test(f.style.opacity),cssFloat:!!f.style.cssFloat,checkOn:i.value==="on",optSelected:h.selected,deleteExpando:!0,optDisabled:!1,checkClone:!1,noCloneEvent:!0,noCloneChecked:!0,boxModel:null,inlineBlockNeedsLayout:!1,shrinkWrapBlocks:!1,reliableHiddenOffsets:!0},i.checked=!0,d.support.noCloneChecked=i.cloneNode(!0).checked,g.disabled=!0,d.support.optDisabled=!h.disabled;var j=null;d.support.scriptEval=function(){if(j===null){var b=c.documentElement,e=c.createElement("script"),f="script"+d.now();try{e.appendChild(c.createTextNode("window."+f+"=1;"))}catch(g){}b.insertBefore(e,b.firstChild),a[f]?(j=!0,delete a[f]):j=!1,b.removeChild(e),b=e=f=null}return j};try{delete b.test}catch(k){d.support.deleteExpando=!1}!b.addEventListener&&b.attachEvent&&b.fireEvent&&(b.attachEvent("onclick",function l(){d.support.noCloneEvent=!1,b.detachEvent("onclick",l)}),b.cloneNode(!0).fireEvent("onclick")),b=c.createElement("div"),b.innerHTML="";var m=c.createDocumentFragment();m.appendChild(b.firstChild),d.support.checkClone=m.cloneNode(!0).cloneNode(!0).lastChild.checked,d(function(){var a=c.createElement("div"),b=c.getElementsByTagName("body")[0];if(b){a.style.width=a.style.paddingLeft="1px",b.appendChild(a),d.boxModel=d.support.boxModel=a.offsetWidth===2,"zoom"in a.style&&(a.style.display="inline",a.style.zoom=1,d.support.inlineBlockNeedsLayout=a.offsetWidth===2,a.style.display="",a.innerHTML="",d.support.shrinkWrapBlocks=a.offsetWidth!==2),a.innerHTML="t";var e=a.getElementsByTagName("td");d.support.reliableHiddenOffsets=e[0].offsetHeight===0,e[0].style.display="",e[1].style.display="none",d.support.reliableHiddenOffsets=d.support.reliableHiddenOffsets&&e[0].offsetHeight===0,a.innerHTML="",b.removeChild(a).style.display="none",a=e=null}});var n=function(a){var b=c.createElement("div");a="on"+a;if(!b.attachEvent)return!0;var d=a in b;d||(b.setAttribute(a,"return;"),d=typeof b[a]==="function"),b=null;return d};d.support.submitBubbles=n("submit"),d.support.changeBubbles=n("change"),b=e=f=null}})();var e=/^(?:\{.*\}|\[.*\])$/;d.extend({cache:{},uuid:0,expando:"jQuery"+(d.fn.jquery+Math.random()).replace(/\D/g,""),noData:{embed:!0,object:"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000",applet:!0},hasData:function(a){a=a.nodeType?d.cache[a[d.expando]]:a[d.expando];return!!a&&!g(a)},data:function(a,c,e,f){if(d.acceptData(a)){var g=d.expando,h=typeof c==="string",i,j=a.nodeType,k=j?d.cache:a,l=j?a[d.expando]:a[d.expando]&&d.expando;if((!l||f&&l&&!k[l][g])&&h&&e===b)return;l||(j?a[d.expando]=l=++d.uuid:l=d.expando),k[l]||(k[l]={},j||(k[l].toJSON=d.noop));if(typeof c==="object"||typeof c==="function")f?k[l][g]=d.extend(k[l][g],c):k[l]=d.extend(k[l],c);i=k[l],f&&(i[g]||(i[g]={}),i=i[g]),e!==b&&(i[c]=e);if(c==="events"&&!i[c])return i[g]&&i[g].events;return h?i[c]:i}},removeData:function(b,c,e){if(d.acceptData(b)){var f=d.expando,h=b.nodeType,i=h?d.cache:b,j=h?b[d.expando]:d.expando;if(!i[j])return;if(c){var k=e?i[j][f]:i[j];if(k){delete k[c];if(!g(k))return}}if(e){delete i[j][f];if(!g(i[j]))return}var l=i[j][f];d.support.deleteExpando||i!=a?delete i[j]:i[j]=null,l?(i[j]={},h||(i[j].toJSON=d.noop),i[j][f]=l):h&&(d.support.deleteExpando?delete b[d.expando]:b.removeAttribute?b.removeAttribute(d.expando):b[d.expando]=null)}},_data:function(a,b,c){return d.data(a,b,c,!0)},acceptData:function(a){if(a.nodeName){var b=d.noData[a.nodeName.toLowerCase()];if(b)return b!==!0&&a.getAttribute("classid")===b}return!0}}),d.fn.extend({data:function(a,c){var e=null;if(typeof a==="undefined"){if(this.length){e=d.data(this[0]);if(this[0].nodeType===1){var g=this[0].attributes,h;for(var i=0,j=g.length;i-1)return!0;return!1},val:function(a){if(!arguments.length){var c=this[0];if(c){if(d.nodeName(c,"option")){var e=c.attributes.value;return!e||e.specified?c.value:c.text}if(d.nodeName(c,"select")){var f=c.selectedIndex,g=[],h=c.options,i=c.type==="select-one";if(f<0)return null;for(var k=i?f:0,l=i?f+1:h.length;k=0;else if(d.nodeName(this,"select")){var f=d.makeArray(e);d("option",this).each(function(){this.selected=d.inArray(d(this).val(),f)>=0}),f.length||(this.selectedIndex=-1)}else this.value=e}})}}),d.extend({attrFn:{val:!0,css:!0,html:!0,text:!0,data:!0,width:!0,height:!0,offset:!0},attr:function(a,c,e,f){if(!a||a.nodeType===3||a.nodeType===8||a.nodeType===2)return b;if(f&&c in d.attrFn)return d(a)[c](e);var g=a.nodeType!==1||!d.isXMLDoc(a),h=e!==b;c=g&&d.props[c]||c;if(a.nodeType===1){var i=k.test(c);if(c==="selected"&&!d.support.optSelected){var j=a.parentNode;j&&(j.selectedIndex,j.parentNode&&j.parentNode.selectedIndex)}if((c in a||a[c]!==b)&&g&&!i){h&&(c==="type"&&l.test(a.nodeName)&&a.parentNode&&d.error("type property can't be changed"),e===null?a.nodeType===1&&a.removeAttribute(c):a[c]=e);if(d.nodeName(a,"form")&&a.getAttributeNode(c))return a.getAttributeNode(c).nodeValue;if(c==="tabIndex"){var o=a.getAttributeNode("tabIndex");return o&&o.specified?o.value:m.test(a.nodeName)||n.test(a.nodeName)&&a.href?0:b}return a[c]}if(!d.support.style&&g&&c==="style"){h&&(a.style.cssText=""+e);return a.style.cssText}h&&a.setAttribute(c,""+e);if(!a.attributes[c]&&(a.hasAttribute&&!a.hasAttribute(c)))return b;var p=!d.support.hrefNormalized&&g&&i?a.getAttribute(c,2):a.getAttribute(c);return p===null?b:p}h&&(a[c]=e);return a[c]}});var p=/\.(.*)$/,q=/^(?:textarea|input|select)$/i,r=/\./g,s=/ /g,t=/[^\w\s.|`]/g,u=function(a){return a.replace(t,"\\$&")};d.event={add:function(c,e,f,g){if(c.nodeType!==3&&c.nodeType!==8){try{d.isWindow(c)&&(c!==a&&!c.frameElement)&&(c=a)}catch(h){}if(f===!1)f=v;else if(!f)return;var i,j;f.handler&&(i=f,f=i.handler),f.guid||(f.guid=d.guid++);var k=d._data(c);if(!k)return;var l=k.events,m=k.handle;l||(k.events=l={}),m||(k.handle=m=function(){return typeof d!=="undefined"&&!d.event.triggered?d.event.handle.apply(m.elem,arguments):b}),m.elem=c,e=e.split(" ");var n,o=0,p;while(n=e[o++]){j=i?d.extend({},i):{handler:f,data:g},n.indexOf(".")>-1?(p=n.split("."),n=p.shift(),j.namespace=p.slice(0).sort().join(".")):(p=[],j.namespace=""),j.type=n,j.guid||(j.guid=f.guid);var q=l[n],r=d.event.special[n]||{};if(!q){q=l[n]=[];if(!r.setup||r.setup.call(c,g,p,m)===!1)c.addEventListener?c.addEventListener(n,m,!1):c.attachEvent&&c.attachEvent("on"+n,m)}r.add&&(r.add.call(c,j),j.handler.guid||(j.handler.guid=f.guid)),q.push(j),d.event.global[n]=!0}c=null}},global:{},remove:function(a,c,e,f){if(a.nodeType!==3&&a.nodeType!==8){e===!1&&(e=v);var g,h,i,j,k=0,l,m,n,o,p,q,r,s=d.hasData(a)&&d._data(a),t=s&&s.events;if(!s||!t)return;c&&c.type&&(e=c.handler,c=c.type);if(!c||typeof c==="string"&&c.charAt(0)==="."){c=c||"";for(h in t)d.event.remove(a,h+c);return}c=c.split(" ");while(h=c[k++]){r=h,q=null,l=h.indexOf(".")<0,m=[],l||(m=h.split("."),h=m.shift(),n=new RegExp("(^|\\.)"+d.map(m.slice(0).sort(),u).join("\\.(?:.*\\.)?")+"(\\.|$)")),p=t[h];if(!p)continue;if(!e){for(j=0;j=0&&(a.type=f=f.slice(0,-1),a.exclusive=!0),e||(a.stopPropagation(),d.event.global[f]&&d.each(d.cache,function(){var b=d.expando,e=this[b];e&&e.events&&e.events[f]&&d.event.trigger(a,c,e.handle.elem)}));if(!e||e.nodeType===3||e.nodeType===8)return b;a.result=b,a.target=e,c=d.makeArray(c),c.unshift(a)}a.currentTarget=e;var h=d._data(e,"handle");h&&h.apply(e,c);var i=e.parentNode||e.ownerDocument;try{e&&e.nodeName&&d.noData[e.nodeName.toLowerCase()]||e["on"+f]&&e["on"+f].apply(e,c)===!1&&(a.result=!1,a.preventDefault())}catch(j){}if(!a.isPropagationStopped()&&i)d.event.trigger(a,c,i,!0);else if(!a.isDefaultPrevented()){var k,l=a.target,m=f.replace(p,""),n=d.nodeName(l,"a")&&m==="click",o=d.event.special[m]||{};if((!o._default||o._default.call(e,a)===!1)&&!n&&!(l&&l.nodeName&&d.noData[l.nodeName.toLowerCase()])){try{l[m]&&(k=l["on"+m],k&&(l["on"+m]=null),d.event.triggered=!0,l[m]())}catch(q){}k&&(l["on"+m]=k),d.event.triggered=!1}}},handle:function(c){var e,f,g,h,i,j=[],k=d.makeArray(arguments);c=k[0]=d.event.fix(c||a.event),c.currentTarget=this,e=c.type.indexOf(".")<0&&!c.exclusive,e||(g=c.type.split("."),c.type=g.shift(),j=g.slice(0).sort(),h=new RegExp("(^|\\.)"+j.join("\\.(?:.*\\.)?")+"(\\.|$)")),c.namespace=c.namespace||j.join("."),i=d._data(this,"events"),f=(i||{})[c.type];if(i&&f){f=f.slice(0);for(var l=0,m=f.length;l-1?d.map(a.options,function(a){return a.selected}).join("-"):"":a.nodeName.toLowerCase()==="select"&&(c=a.selectedIndex);return c},B=function B(a){var c=a.target,e,f;if(q.test(c.nodeName)&&!c.readOnly){e=d._data(c,"_change_data"),f=A(c),(a.type!=="focusout"||c.type!=="radio")&&d._data(c,"_change_data",f);if(e===b||f===e)return;if(e!=null||f)a.type="change",a.liveFired=b,d.event.trigger(a,arguments[1],c)}};d.event.special.change={filters:{focusout:B,beforedeactivate:B,click:function(a){var b=a.target,c=b.type;(c==="radio"||c==="checkbox"||b.nodeName.toLowerCase()==="select")&&B.call(this,a)},keydown:function(a){var b=a.target,c=b.type;(a.keyCode===13&&b.nodeName.toLowerCase()!=="textarea"||a.keyCode===32&&(c==="checkbox"||c==="radio")||c==="select-multiple")&&B.call(this,a)},beforeactivate:function(a){var b=a.target;d._data(b,"_change_data",A(b))}},setup:function(a,b){if(this.type==="file")return!1;for(var c in z)d.event.add(this,c+".specialChange",z[c]);return q.test(this.nodeName)},teardown:function(a){d.event.remove(this,".specialChange");return q.test(this.nodeName)}},z=d.event.special.change.filters,z.focus=z.beforeactivate}c.addEventListener&&d.each({focus:"focusin",blur:"focusout"},function(a,b){function c(a){a=d.event.fix(a),a.type=b;return d.event.handle.call(this,a)}d.event.special[b]={setup:function(){this.addEventListener(a,c,!0)},teardown:function(){this.removeEventListener(a,c,!0)}}}),d.each(["bind","one"],function(a,c){d.fn[c]=function(a,e,f){if(typeof a==="object"){for(var g in a)this[c](g,e,a[g],f);return this}if(d.isFunction(e)||e===!1)f=e,e=b;var h=c==="one"?d.proxy(f,function(a){d(this).unbind(a,h);return f.apply(this,arguments)}):f;if(a==="unload"&&c!=="one")this.one(a,e,f);else for(var i=0,j=this.length;i0?this.bind(b,a,c):this.trigger(b)},d.attrFn&&(d.attrFn[b]=!0)}),function(){function u(a,b,c,d,e,f){for(var g=0,h=d.length;g0){j=i;break}}i=i[a]}d[g]=j}}}function t(a,b,c,d,e,f){for(var g=0,h=d.length;g+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g,e=0,f=Object.prototype.toString,g=!1,h=!0,i=/\\/g,j=/\W/;[0,0].sort(function(){h=!1;return 0});var k=function(b,d,e,g){e=e||[],d=d||c;var h=d;if(d.nodeType!==1&&d.nodeType!==9)return[];if(!b||typeof b!=="string")return e;var i,j,n,o,q,r,s,t,u=!0,w=k.isXML(d),x=[],y=b;do{a.exec(""),i=a.exec(y);if(i){y=i[3],x.push(i[1]);if(i[2]){o=i[3];break}}}while(i);if(x.length>1&&m.exec(b))if(x.length===2&&l.relative[x[0]])j=v(x[0]+x[1],d);else{j=l.relative[x[0]]?[d]:k(x.shift(),d);while(x.length)b=x.shift(),l.relative[b]&&(b+=x.shift()),j=v(b,j)}else{!g&&x.length>1&&d.nodeType===9&&!w&&l.match.ID.test(x[0])&&!l.match.ID.test(x[x.length-1])&&(q=k.find(x.shift(),d,w),d=q.expr?k.filter(q.expr,q.set)[0]:q.set[0]);if(d){q=g?{expr:x.pop(),set:p(g)}:k.find(x.pop(),x.length===1&&(x[0]==="~"||x[0]==="+")&&d.parentNode?d.parentNode:d,w),j=q.expr?k.filter(q.expr,q.set):q.set,x.length>0?n=p(j):u=!1;while(x.length)r=x.pop(),s=r,l.relative[r]?s=x.pop():r="",s==null&&(s=d),l.relative[r](n,s,w)}else n=x=[]}n||(n=j),n||k.error(r||b);if(f.call(n)==="[object Array]")if(u)if(d&&d.nodeType===1)for(t=0;n[t]!=null;t++)n[t]&&(n[t]===!0||n[t].nodeType===1&&k.contains(d,n[t]))&&e.push(j[t]);else for(t=0;n[t]!=null;t++)n[t]&&n[t].nodeType===1&&e.push(j[t]);else e.push.apply(e,n);else p(n,e);o&&(k(o,h,e,g),k.uniqueSort(e));return e};k.uniqueSort=function(a){if(r){g=h,a.sort(r);if(g)for(var b=1;b0},k.find=function(a,b,c){var d;if(!a)return[];for(var e=0,f=l.order.length;e":function(a,b){var c,d=typeof b==="string",e=0,f=a.length;if(d&&!j.test(b)){b=b.toLowerCase();for(;e=0)?c||d.push(h):c&&(b[g]=!1));return!1},ID:function(a){return a[1].replace(i,"")},TAG:function(a,b){return a[1].replace(i,"").toLowerCase()},CHILD:function(a){if(a[1]==="nth"){a[2]||k.error(a[0]),a[2]=a[2].replace(/^\+|\s*/g,"");var b=/(-?)(\d*)(?:n([+\-]?\d*))?/.exec(a[2]==="even"&&"2n"||a[2]==="odd"&&"2n+1"||!/\D/.test(a[2])&&"0n+"+a[2]||a[2]);a[2]=b[1]+(b[2]||1)-0,a[3]=b[3]-0}else a[2]&&k.error(a[0]);a[0]=e++;return a},ATTR:function(a,b,c,d,e,f){var g=a[1]=a[1].replace(i,"");!f&&l.attrMap[g]&&(a[1]=l.attrMap[g]),a[4]=(a[4]||a[5]||"").replace(i,""),a[2]==="~="&&(a[4]=" "+a[4]+" ");return a},PSEUDO:function(b,c,d,e,f){if(b[1]==="not")if((a.exec(b[3])||"").length>1||/^\w/.test(b[3]))b[3]=k(b[3],null,null,c);else{var g=k.filter(b[3],c,d,!0^f);d||e.push.apply(e,g);return!1}else if(l.match.POS.test(b[0])||l.match.CHILD.test(b[0]))return!0;return b},POS:function(a){a.unshift(!0);return a}},filters:{enabled:function(a){return a.disabled===!1&&a.type!=="hidden"},disabled:function(a){return a.disabled===!0},checked:function(a){return a.checked===!0},selected:function(a){a.parentNode&&a.parentNode.selectedIndex;return a.selected===!0},parent:function(a){return!!a.firstChild},empty:function(a){return!a.firstChild},has:function(a,b,c){return!!k(c[3],a).length},header:function(a){return/h\d/i.test(a.nodeName)},text:function(a){return"text"===a.getAttribute("type")},radio:function(a){return"radio"===a.type},checkbox:function(a){return"checkbox"===a.type},file:function(a){return"file"===a.type},password:function(a){return"password"===a.type},submit:function(a){return"submit"===a.type},image:function(a){return"image"===a.type},reset:function(a){return"reset"===a.type},button:function(a){return"button"===a.type||a.nodeName.toLowerCase()==="button"},input:function(a){return/input|select|textarea|button/i.test(a.nodeName)}},setFilters:{first:function(a,b){return b===0},last:function(a,b,c,d){return b===d.length-1},even:function(a,b){return b%2===0},odd:function(a,b){return b%2===1},lt:function(a,b,c){return bc[3]-0},nth:function(a,b,c){return c[3]-0===b},eq:function(a,b,c){return c[3]-0===b}},filter:{PSEUDO:function(a,b,c,d){var e=b[1],f=l.filters[e];if(f)return f(a,c,b,d);if(e==="contains")return(a.textContent||a.innerText||k.getText([a])||"").indexOf(b[3])>=0;if(e==="not"){var g=b[3];for(var h=0,i=g.length;h=0}},ID:function(a,b){return a.nodeType===1&&a.getAttribute("id")===b},TAG:function(a,b){return b==="*"&&a.nodeType===1||a.nodeName.toLowerCase()===b},CLASS:function(a,b){return(" "+(a.className||a.getAttribute("class"))+" ").indexOf(b)>-1},ATTR:function(a,b){var c=b[1],d=l.attrHandle[c]?l.attrHandle[c](a):a[c]!=null?a[c]:a.getAttribute(c),e=d+"",f=b[2],g=b[4];return d==null?f==="!=":f==="="?e===g:f==="*="?e.indexOf(g)>=0:f==="~="?(" "+e+" ").indexOf(g)>=0:g?f==="!="?e!==g:f==="^="?e.indexOf(g)===0:f==="$="?e.substr(e.length-g.length)===g:f==="|="?e===g||e.substr(0,g.length+1)===g+"-":!1:e&&d!==!1},POS:function(a,b,c,d){var e=b[2],f=l.setFilters[e];if(f)return f(a,c,b,d)}}},m=l.match.POS,n=function(a,b){return"\\"+(b-0+1)};for(var o in l.match)l.match[o]=new RegExp(l.match[o].source+/(?![^\[]*\])(?![^\(]*\))/.source),l.leftMatch[o]=new RegExp(/(^(?:.|\r|\n)*?)/.source+l.match[o].source.replace(/\\(\d+)/g,n));var p=function(a,b){a=Array.prototype.slice.call(a,0);if(b){b.push.apply(b,a);return b}return a};try{Array.prototype.slice.call(c.documentElement.childNodes,0)[0].nodeType}catch(q){p=function(a,b){var c=0,d=b||[];if(f.call(a)==="[object Array]")Array.prototype.push.apply(d,a);else if(typeof a.length==="number")for(var e=a.length;c",e.insertBefore(a,e.firstChild),c.getElementById(d)&&(l.find.ID=function(a,c,d){if(typeof c.getElementById!=="undefined"&&!d){var e=c.getElementById(a[1]);return e?e.id===a[1]||typeof e.getAttributeNode!=="undefined"&&e.getAttributeNode("id").nodeValue===a[1]?[e]:b:[]}},l.filter.ID=function(a,b){var c=typeof a.getAttributeNode!=="undefined"&&a.getAttributeNode("id");return a.nodeType===1&&c&&c.nodeValue===b}),e.removeChild(a),e=a=null}(),function(){var a=c.createElement("div");a.appendChild(c.createComment("")),a.getElementsByTagName("*").length>0&&(l.find.TAG=function(a,b){var c=b.getElementsByTagName(a[1]);if(a[1]==="*"){var d=[];for(var e=0;c[e];e++)c[e].nodeType===1&&d.push(c[e]);c=d}return c}),a.innerHTML="",a.firstChild&&typeof a.firstChild.getAttribute!=="undefined"&&a.firstChild.getAttribute("href")!=="#"&&(l.attrHandle.href=function(a){return a.getAttribute("href",2)}),a=null}(),c.querySelectorAll&&function(){var a=k,b=c.createElement("div"),d="__sizzle__";b.innerHTML="";if(!b.querySelectorAll||b.querySelectorAll(".TEST").length!==0){k=function(b,e,f,g){e=e||c;if(!g&&!k.isXML(e)){var h=/^(\w+$)|^\.([\w\-]+$)|^#([\w\-]+$)/.exec(b);if(h&&(e.nodeType===1||e.nodeType===9)){if(h[1])return p(e.getElementsByTagName(b),f);if(h[2]&&l.find.CLASS&&e.getElementsByClassName)return p(e.getElementsByClassName(h[2]),f)}if(e.nodeType===9){if(b==="body"&&e.body)return p([e.body],f);if(h&&h[3]){var i=e.getElementById(h[3]);if(!i||!i.parentNode)return p([],f);if(i.id===h[3])return p([i],f)}try{return p(e.querySelectorAll(b),f)}catch(j){}}else if(e.nodeType===1&&e.nodeName.toLowerCase()!=="object"){var m=e,n=e.getAttribute("id"),o=n||d,q=e.parentNode,r=/^\s*[+~]/.test(b);n?o=o.replace(/'/g,"\\$&"):e.setAttribute("id",o),r&&q&&(e=e.parentNode);try{if(!r||q)return p(e.querySelectorAll("[id='"+o+"'] "+b),f)}catch(s){}finally{n||m.removeAttribute("id")}}}return a(b,e,f,g)};for(var e in a)k[e]=a[e];b=null}}(),function(){var a=c.documentElement,b=a.matchesSelector||a.mozMatchesSelector||a.webkitMatchesSelector||a.msMatchesSelector,d=!1;try{b.call(c.documentElement,"[test!='']:sizzle")}catch(e){d=!0}b&&(k.matchesSelector=function(a,c){c=c.replace(/\=\s*([^'"\]]*)\s*\]/g,"='$1']");if(!k.isXML(a))try{if(d||!l.match.PSEUDO.test(c)&&!/!=/.test(c))return b.call(a,c)}catch(e){}return k(c,null,null,[a]).length>0})}(),function(){var a=c.createElement("div");a.innerHTML="";if(a.getElementsByClassName&&a.getElementsByClassName("e").length!==0){a.lastChild.className="e";if(a.getElementsByClassName("e").length===1)return;l.order.splice(1,0,"CLASS"),l.find.CLASS=function(a,b,c){if(typeof b.getElementsByClassName!=="undefined"&&!c)return b.getElementsByClassName(a[1])},a=null}}(),c.documentElement.contains?k.contains=function(a,b){return a!==b&&(a.contains?a.contains(b):!0)}:c.documentElement.compareDocumentPosition?k.contains=function(a,b){return!!(a.compareDocumentPosition(b)&16)}:k.contains=function(){return!1},k.isXML=function(a){var b=(a?a.ownerDocument||a:0).documentElement;return b?b.nodeName!=="HTML":!1};var v=function(a,b){var c,d=[],e="",f=b.nodeType?[b]:b;while(c=l.match.PSEUDO.exec(a))e+=c[0],a=a.replace(l.match.PSEUDO,"");a=l.relative[a]?a+"*":a;for(var g=0,h=f.length;g0)for(var g=c;g0},closest:function(a,b){var c=[],e,f,g=this[0];if(d.isArray(a)){var h,i,j={},k=1;if(g&&a.length){for(e=0,f=a.length;e-1:d(g).is(h))&&c.push({selector:i,elem:g,level:k});g=g.parentNode,k++}}return c}var l=L.test(a)?d(a,b||this.context):null;for(e=0,f=this.length;e-1:d.find.matchesSelector(g,a)){c.push(g);break}g=g.parentNode;if(!g||!g.ownerDocument||g===b)break}}c=c.length>1?d.unique(c):c;return this.pushStack(c,"closest",a)},index:function(a){if(!a||typeof a==="string")return d.inArray(this[0],a?d(a):this.parent().children());return d.inArray(a.jquery?a[0]:a,this)},add:function(a,b){var c=typeof a==="string"?d(a,b):d.makeArray(a),e=d.merge(this.get(),c);return this.pushStack(N(c[0])||N(e[0])?e:d.unique(e))},andSelf:function(){return this.add(this.prevObject)}}),d.each({parent:function(a){var b=a.parentNode;return b&&b.nodeType!==11?b:null},parents:function(a){return d.dir(a,"parentNode")},parentsUntil:function(a,b,c){return d.dir(a,"parentNode",c)},next:function(a){return d.nth(a,2,"nextSibling")},prev:function(a){return d.nth(a,2,"previousSibling")},nextAll:function(a){return d.dir(a,"nextSibling")},prevAll:function(a){return d.dir(a,"previousSibling")},nextUntil:function(a,b,c){return d.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return d.dir(a,"previousSibling",c)},siblings:function(a){return d.sibling(a.parentNode.firstChild,a)},children:function(a){return d.sibling(a.firstChild)},contents:function(a){return d.nodeName(a,"iframe")?a.contentDocument||a.contentWindow.document:d.makeArray(a.childNodes)}},function(a,b){d.fn[a]=function(c,e){var f=d.map(this,b,c),g=K.call(arguments);G.test(a)||(e=c),e&&typeof e==="string"&&(f=d.filter(e,f)),f=this.length>1&&!M[a]?d.unique(f):f,(this.length>1||I.test(e))&&H.test(a)&&(f=f.reverse());return this.pushStack(f,a,g.join(","))}}),d.extend({filter:function(a,b,c){c&&(a=":not("+a+")");return b.length===1?d.find.matchesSelector(b[0],a)?[b[0]]:[]:d.find.matches(a,b)},dir:function(a,c,e){var f=[],g=a[c];while(g&&g.nodeType!==9&&(e===b||g.nodeType!==1||!d(g).is(e)))g.nodeType===1&&f.push(g),g=g[c];return f},nth:function(a,b,c,d){b=b||1;var e=0;for(;a;a=a[c])if(a.nodeType===1&&++e===b)break;return a},sibling:function(a,b){var c=[];for(;a;a=a.nextSibling)a.nodeType===1&&a!==b&&c.push(a);return c}});var P=/ jQuery\d+="(?:\d+|null)"/g,Q=/^\s+/,R=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/ig,S=/<([\w:]+)/,T=/",""],legend:[1,"",""],thead:[1,"",""],tr:[2,"",""],td:[3,"",""],col:[2,"",""],area:[1,"",""],_default:[0,"",""]};X.optgroup=X.option,X.tbody=X.tfoot=X.colgroup=X.caption=X.thead,X.th=X.td,d.support.htmlSerialize||(X._default=[1,"div",""]),d.fn.extend({text:function(a){if(d.isFunction(a))return this.each(function(b){var c=d(this);c.text(a.call(this,b,c.text()))});if(typeof a!=="object"&&a!==b)return this.empty().append((this[0]&&this[0].ownerDocument||c).createTextNode(a));return d.text(this)},wrapAll:function(a){if(d.isFunction(a))return this.each(function(b){d(this).wrapAll(a.call(this,b))});if(this[0]){var b=d(a,this[0].ownerDocument).eq(0).clone(!0);this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;while(a.firstChild&&a.firstChild.nodeType===1)a=a.firstChild;return a}).append(this)}return this},wrapInner:function(a){if(d.isFunction(a))return this.each(function(b){d(this).wrapInner(a.call(this,b))});return this.each(function(){var b=d(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){return this.each(function(){d(this).wrapAll(a)})},unwrap:function(){return this.parent().each(function(){d.nodeName(this,"body")||d(this).replaceWith(this.childNodes)}).end()},append:function(){return this.domManip(arguments,!0,function(a){this.nodeType===1&&this.appendChild(a)})},prepend:function(){return this.domManip(arguments,!0,function(a){this.nodeType===1&&this.insertBefore(a,this.firstChild)})},before:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this)});if(arguments.length){var a=d(arguments[0]);a.push.apply(a,this.toArray());return this.pushStack(a,"before",arguments)}},after:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this.nextSibling)});if(arguments.length){var a=this.pushStack(this,"after",arguments);a.push.apply(a,d(arguments[0]).toArray());return a}},remove:function(a,b){for(var c=0,e;(e=this[c])!=null;c++)if(!a||d.filter(a,[e]).length)!b&&e.nodeType===1&&(d.cleanData(e.getElementsByTagName("*")),d.cleanData([e])),e.parentNode&&e.parentNode.removeChild(e);return this},empty:function(){for(var a=0,b;(b=this[a])!=null;a++){b.nodeType===1&&d.cleanData(b.getElementsByTagName("*"));while(b.firstChild)b.removeChild(b.firstChild)}return this},clone:function(a,b){a=a==null?!1:a,b=b==null?a:b;return this.map(function(){return d.clone(this,a,b)})},html:function(a){if(a===b)return this[0]&&this[0].nodeType===1?this[0].innerHTML.replace(P,""):null;if(typeof a!=="string"||V.test(a)||!d.support.leadingWhitespace&&Q.test(a)||X[(S.exec(a)||["",""])[1].toLowerCase()])d.isFunction(a)?this.each(function(b){var c=d(this);c.html(a.call(this,b,c.html()))}):this.empty().append(a);else{a=a.replace(R,"<$1>$2>");try{for(var c=0,e=this.length;c1&&l0?this.clone(!0):this).get();d(f[h])[b](j),e=e.concat(j)}return this.pushStack(e,a,f.selector)}}),d.extend({clone:function(a,b,c){var e=a.cloneNode(!0),f,g,h;if((!d.support.noCloneEvent||!d.support.noCloneChecked)&&(a.nodeType===1||a.nodeType===11)&&!d.isXMLDoc(a)){$(a,e),f=_(a),g=_(e);for(h=0;f[h];++h)$(f[h],g[h])}if(b){Z(a,e);if(c){f=_(a),g=_(e);for(h=0;f[h];++h)Z(f[h],g[h])}}return e},clean:function(a,b,e,f){b=b||c,typeof b.createElement==="undefined"&&(b=b.ownerDocument||b[0]&&b[0].ownerDocument||c);var g=[];for(var h=0,i;(i=a[h])!=null;h++){typeof i==="number"&&(i+="");if(!i)continue;if(typeof i!=="string"||U.test(i)){if(typeof i==="string"){i=i.replace(R,"<$1>$2>");var j=(S.exec(i)||["",""])[1].toLowerCase(),k=X[j]||X._default,l=k[0],m=b.createElement("div");m.innerHTML=k[1]+i+k[2];while(l--)m=m.lastChild;if(!d.support.tbody){var n=T.test(i),o=j==="table"&&!n?m.firstChild&&m.firstChild.childNodes:k[1]===""&&!n?m.childNodes:[];for(var p=o.length-1;p>=0;--p)d.nodeName(o[p],"tbody")&&!o[p].childNodes.length&&o[p].parentNode.removeChild(o[p])}!d.support.leadingWhitespace&&Q.test(i)&&m.insertBefore(b.createTextNode(Q.exec(i)[0]),m.firstChild),i=m.childNodes}}else i=b.createTextNode(i);i.nodeType?g.push(i):g=d.merge(g,i)}if(e)for(h=0;g[h];h++)!f||!d.nodeName(g[h],"script")||g[h].type&&g[h].type.toLowerCase()!=="text/javascript"?(g[h].nodeType===1&&g.splice.apply(g,[h+1,0].concat(d.makeArray(g[h].getElementsByTagName("script")))),e.appendChild(g[h])):f.push(g[h].parentNode?g[h].parentNode.removeChild(g[h]):g[h]);return g},cleanData:function(a){var b,c,e=d.cache,f=d.expando,g=d.event.special,h=d.support.deleteExpando;for(var i=0,j;(j=a[i])!=null;i++){if(j.nodeName&&d.noData[j.nodeName.toLowerCase()])continue;c=j[d.expando];if(c){b=e[c]&&e[c][f];if(b&&b.events){for(var k in b.events)g[k]?d.event.remove(j,k):d.removeEvent(j,k,b.handle);b.handle&&(b.handle.elem=null)}h?delete j[d.expando]:j.removeAttribute&&j.removeAttribute(d.expando),delete e[c]}}}});var bb=/alpha\([^)]*\)/i,bc=/opacity=([^)]*)/,bd=/-([a-z])/ig,be=/([A-Z])/g,bf=/^-?\d+(?:px)?$/i,bg=/^-?\d/,bh={position:"absolute",visibility:"hidden",display:"block"},bi=["Left","Right"],bj=["Top","Bottom"],bk,bl,bm,bn=function(a,b){return b.toUpperCase()};d.fn.css=function(a,c){if(arguments.length===2&&c===b)return this;return d.access(this,a,c,!0,function(a,c,e){return e!==b?d.style(a,c,e):d.css(a,c)})},d.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=bk(a,"opacity","opacity");return c===""?"1":c}return a.style.opacity}}},cssNumber:{zIndex:!0,fontWeight:!0,opacity:!0,zoom:!0,lineHeight:!0},cssProps:{"float":d.support.cssFloat?"cssFloat":"styleFloat"},style:function(a,c,e,f){if(a&&a.nodeType!==3&&a.nodeType!==8&&a.style){var g,h=d.camelCase(c),i=a.style,j=d.cssHooks[h];c=d.cssProps[h]||h;if(e===b){if(j&&"get"in j&&(g=j.get(a,!1,f))!==b)return g;return i[c]}if(typeof e==="number"&&isNaN(e)||e==null)return;typeof e==="number"&&!d.cssNumber[h]&&(e+="px");if(!j||!("set"in j)||(e=j.set(a,e))!==b)try{i[c]=e}catch(k){}}},css:function(a,c,e){var f,g=d.camelCase(c),h=d.cssHooks[g];c=d.cssProps[g]||g;if(h&&"get"in h&&(f=h.get(a,!0,e))!==b)return f;if(bk)return bk(a,c,g)},swap:function(a,b,c){var d={};for(var e in b)d[e]=a.style[e],a.style[e]=b[e];c.call(a);for(e in b)a.style[e]=d[e]},camelCase:function(a){return a.replace(bd,bn)}}),d.curCSS=d.css,d.each(["height","width"],function(a,b){d.cssHooks[b]={get:function(a,c,e){var f;if(c){a.offsetWidth!==0?f=bo(a,b,e):d.swap(a,bh,function(){f=bo(a,b,e)});if(f<=0){f=bk(a,b,b),f==="0px"&&bm&&(f=bm(a,b,b));if(f!=null)return f===""||f==="auto"?"0px":f}if(f<0||f==null){f=a.style[b];return f===""||f==="auto"?"0px":f}return typeof f==="string"?f:f+"px"}},set:function(a,b){if(!bf.test(b))return b;b=parseFloat(b);if(b>=0)return b+"px"}}}),d.support.opacity||(d.cssHooks.opacity={get:function(a,b){return bc.test((b&&a.currentStyle?a.currentStyle.filter:a.style.filter)||"")?parseFloat(RegExp.$1)/100+"":b?"1":""},set:function(a,b){var c=a.style;c.zoom=1;var e=d.isNaN(b)?"":"alpha(opacity="+b*100+")",f=c.filter||"";c.filter=bb.test(f)?f.replace(bb,e):c.filter+" "+e}}),c.defaultView&&c.defaultView.getComputedStyle&&(bl=function(a,c,e){var f,g,h;e=e.replace(be,"-$1").toLowerCase();if(!(g=a.ownerDocument.defaultView))return b;if(h=g.getComputedStyle(a,null))f=h.getPropertyValue(e),f===""&&!d.contains(a.ownerDocument.documentElement,a)&&(f=d.style(a,e));return f}),c.documentElement.currentStyle&&(bm=function(a,b){var c,d=a.currentStyle&&a.currentStyle[b],e=a.runtimeStyle&&a.runtimeStyle[b],f=a.style;!bf.test(d)&&bg.test(d)&&(c=f.left,e&&(a.runtimeStyle.left=a.currentStyle.left),f.left=b==="fontSize"?"1em":d||0,d=f.pixelLeft+"px",f.left=c,e&&(a.runtimeStyle.left=e));return d===""?"auto":d}),bk=bl||bm,d.expr&&d.expr.filters&&(d.expr.filters.hidden=function(a){var b=a.offsetWidth,c=a.offsetHeight;return b===0&&c===0||!d.support.reliableHiddenOffsets&&(a.style.display||d.css(a,"display"))==="none"},d.expr.filters.visible=function(a){return!d.expr.filters.hidden(a)});var bp=/%20/g,bq=/\[\]$/,br=/\r?\n/g,bs=/#.*$/,bt=/^(.*?):[ \t]*([^\r\n]*)\r?$/mg,bu=/^(?:color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week)$/i,bv=/(?:^file|^widget|\-extension):$/,bw=/^(?:GET|HEAD)$/,bx=/^\/\//,by=/\?/,bz=/
Ìû ïðîñòî óâåðåíû, ÷òî Âàì îí ñîâñåì íå íðàâèòñÿ.Ïîýòîìó íå ñòåñíÿéòåñü ïîìåíÿòü åãî íà ëþáîé äðóãîé â ðàçäåëå «Íàñòðîéêè».
---- Àäìèíèñòðàöèÿ