Added a few attributes that are nice n easy to use for common cases
authordrewc <drewc@tech.coop>
Tue, 30 May 2006 01:16:19 +0000 (18:16 -0700)
committerdrewc <drewc@tech.coop>
Tue, 30 May 2006 01:16:19 +0000 (18:16 -0700)
darcs-hash:20060530011619-39164-7432985a0f0c1a5e8a30c1358d10e8b75c4a27b6.gz

src/attributes/standard-attributes.lisp

index 53022aa..dcd6196 100644 (file)
@@ -12,8 +12,7 @@
 
 (defdisplay
     :in-layer show-attribute-labels
 
 (defdisplay
     :in-layer show-attribute-labels
-    :around ((attribute standard-attribute) object)
-    
+    :around ((attribute standard-attribute) object)    
   (<:span
    :class "lol-label"
    (<:as-html (or (label attribute) (attribute.name attribute)) " "))
   (<:span
    :class "lol-label"
    (<:as-html (or (label attribute) (attribute.name attribute)) " "))
      (string-capitalize
       (substitute #\Space #\- label)))))
 
      (string-capitalize
       (substitute #\Space #\- label)))))
 
-(defattribute display ()
-  ()
+(deflayer inspect-attributes)
+
+(defdisplay :in-layer inspect-attributes
+           :around ((attribute standard-attribute) object)
+ (call-next-method)
+  (<ucw:a :action (ucw::call-inspector self attribute)
+         :title
+         (strcat "Inspect "
+                        (attribute.name attribute) ":"
+                        (description.type attribute) ":"
+                        (type-of attribute))
+         (<:as-html "(i)")))
+
+;;;; Functional attributes
+(defattribute display-attribute ()
+  ((display-arguments
+    :accessor display-arguments
+    :initarg :display
+    :special t
+    :initform nil))
+  (:type-name display)
   (:documentation "Apply the display function to this object"))
 
   (:documentation "Apply the display function to this object"))
 
-(defdisplay ((attribute display) object)
+(defdisplay ((attribute display-attribute) object)
   (apply #'display self (attribute-value object attribute)
   (apply #'display self (attribute-value object attribute)
-        (description.properties attribute)))
+        (display-arguments attribute)))
 
 
-;;;; * Base Types
+(defattribute function-attribute ()
+  ((function :accessor function-of
+            :initarg :function
+            :initform #'funcall
+            :special t))
+  (:type-name function)
+  (:documentation ""))
 
 
-(defattribute base-attribute ()
-  ())
+(defdisplay ((function function-attribute) object)
+  (funcall (function-of function)
+          (attribute-value object function)))
 
 
-(defdisplay ((base base-attribute) object)
- (<:as-html (attribute-value object base)))
 
 
-(defattribute base-attribute (ucw::string-field)
+;;;; Attribute Grouping
+(defattribute attribute-group ()
   ()
   ()
-  (:in-layer editor)
   (:default-properties
   (:default-properties
-      :callback nil))
-
-(defmethod ucw:client-value ((self base-attribute))
-  (attribute-value (object self) self))
+   :group nil)
+  (:type-name group))
 
 
-(defmethod (setf ucw:client-value) (value (attribute base-attribute))
-  (setf (attribute-value (object attribute) attribute) value))
+(defdisplay ((group attribute-group) object)
+  (apply #'display self object
+        :attributes (attributes group)
+        (group group)))
 
 
+;;;; * Base Types
 
 
-(defmethod render ((field base-attribute))
-  "this can only be used within a display-using-description call in the editor context, 
- it is a hack to integrate lol with ucw's new form stuff"
-  (call-next-method))
+(defattribute base-attribute ()
+  ()
+  (:default-properties
+      :default-value ""))
 
 
-  #+ (or)
-(LET ((value (attribute-value (object field) field)))
-  (<:as-html "asd" value)
-  (<:input
-   :NAME
-   (callback field)
-   :VALUE (escape-as-html value)
-   :TYPE
-   "text"
-   :ID
-   (DOM-ID FIELD)
-   :SIZE
-   (ucw::INPUT-SIZE FIELD)))
+(defdisplay ((base base-attribute) object)
+ (<:as-html (attribute-value object base)))
 
 
+(defattribute base-attribute (ucw::string-field)
+  ()
+  (:in-layer editor)
+  (:default-properties 
+    :callback nil
+    :default-value nil
+    :default-value-predicate #'null))
 
 
+(define-layered-function display-value (attribute value)
+  (:method (attribute value)
+    (if (funcall (default-value-predicate attribute) value)
+       (default-value attribute)
+       value)))
 
 (defdisplay
 
 (defdisplay
-    :in-layer editor  ((string base-attribute) object)
- (render string))
-
+  :in-layer editor ((field base-attribute) object)
+  (LET ((value (attribute-value (object field) field)))
+    (<:input
+     :NAME
+     (callback field)
+     :VALUE (escape-as-html (strcat (display-value field value)))
+     :TYPE
+     "text"
+     :ID
+     (DOM-ID FIELD)
+     :SIZE
+     (ucw::INPUT-SIZE FIELD))))
 
 (defdisplay
     :in-layer editor :around ((string base-attribute) object)
 
 (defdisplay
     :in-layer editor :around ((string base-attribute) object)
-    (dletf (((callback string) (ucw::make-new-callback
-                               #'(lambda (val)
-                                   (setf (attribute-value object string) val))))
+    (dletf (((callback string)
+            (or (callback string)
+                (ucw::make-new-callback
+                 #'(lambda (val)
+                     (setf (attribute-value object string) val)))))
            ((object string) object))
       (call-next-method)))
 
            ((object string) object))
       (call-next-method)))
 
   (:default-properties
       :escape-html-p t
     :size nil
   (:default-properties
       :escape-html-p t
     :size nil
-    :max-length nil))
+    :max-length nil
+    :default-value ""))
 
 (defdisplay :in-layer omit-nil-attributes
            :around ((attribute string-attribute) object)
 
 (defdisplay :in-layer omit-nil-attributes
            :around ((attribute string-attribute) object)
 
 (defdisplay :in-layer editor ((string text-attribute) object)
  (<:textarea
 
 (defdisplay :in-layer editor ((string text-attribute) object)
  (<:textarea
-  :id (id string)
+  :id (dom-id string)
   :name (callback string)
   (or (attribute-value object string) "")))
 
   :name (callback string)
   (or (attribute-value object string) "")))