Forum OpenACS Q&A: Re: User designed database package for dot?
Posted by
Vinod Kurup
on 06/26/06 11:17 PM
Hi Jose,
There is also a package in OpenACS called dynamic-types which provides a TCL API and a minimal UI to create acs-object-types. It also provides the ability to dynamically create forms to go along with those object types.
The version in OpenACS has been cleaned up and improved (I think by Lee Denison at xargs). I've been working with this version.
Here's how I would create a new type:
Create attributes:set otype institution # create a new dynamic object type dtype::create -name $otype \ -supertype acs_object \ -pretty_name "Institution" \ -pretty_plural "Institutions" \ -table_name institutions \ -id_column institution_id
Create a form with elements to match the attributes.# create attributes dtype::create_attribute -name institution_name \ -object_type $otype \ -datatype text \ -pretty_name "Institution Name" \ -pretty_plural "Institution Names" dtype::create_attribute -name state \ -object_type $otype \ -datatype text \ -pretty_name "State" \ -pretty_plural "States"
Notice in that last case that you can prepopulate the select list by setting the 'options' parameter. There are a bunch of other parameters that you can set/edit, all based on standard form builder functionality.# create form set form_id [dtype::form::create] dtype::form::map_type -form_id $form_id \ -form standard \ -object_type $otype # create elements set element_id [dtype::form::add_element -form_id $form_id \ -element institution_name \ -widget text] array set attr [dtype::get_attribute -object_type $otype -name institution_name] dtype::element::map_attribute -element_id $element_id \ -attribute_id $attr(attribute_id) set element_id [dtype::form::add_element -form_id $form_id \ -element state \ -widget select] array unset attr array set attr [dtype::get_attribute -object_type $otype -name state] dtype::element::map_attribute -element_id $element_id \ -attribute_id $attr(attribute_id) dtype::element::add_parameter -element_id $element_id \ -param options \ -value [db_list_of_lists get_states "select state_name, abbrev from us_states"]
Now here's the add.tcl page:
and the ADP filead_page_contract { @author Vinod Kurup @creation-date 2006-06-17 } { } set context [list "Add Institution"] dtype::form::generate \ -dtype_form standard \ -object_type institution \ -ats_form add if { [template::form::is_valid add] } { dtype::form::process -ats_form add ad_returnredirect ./ }
Again, all of this can be done in TCL (as above), or via a web UI. The part I haven't figured out is if it's possible to build up pages which query the system automatically, but it's easy enough to build those with the list-builder. Wiki page: https://openacs.org/xowiki/pages/en/dynamic-types<master> <property name="context">@context@</property> <formtemplate id="add"></formtemplate>