cybertools/composer/schema
helmutm a4dfb9b209 extend composer.schema for usage for standard form rendering
git-svn-id: svn://svn.cy55.de/Zope3/src/cybertools/trunk@2060 fd906abe-77d9-0310-91a1-e0d9ade77398
2007-09-19 15:46:03 +00:00
..
browser extend composer.schema for usage for standard form rendering 2007-09-19 15:46:03 +00:00
__init__.py more on cybertools.reporter: control via the field's renderFactory 2007-05-21 17:28:16 +00:00
client.py work in progress: service managment with composer.schema for tumsm 2007-07-31 09:15:48 +00:00
configure.zcml refactoring field processing: class FieldInstance for processing and collecting state information 2007-08-30 07:53:09 +00:00
field.py extend composer.schema for usage for standard form rendering 2007-09-19 15:46:03 +00:00
instance.py minor changes to support wysiwyg schema editor 2007-09-06 16:05:18 +00:00
interfaces.py support for 'dropdown' field 2007-09-10 17:30:59 +00:00
README.txt more on cybertools.reporter: control via the field's renderFactory 2007-05-21 17:28:16 +00:00
schema.py rearrangement of schema_macros; added field instance class for number fields 2007-08-30 10:56:28 +00:00
tests.py removed Instance; added schema package 2007-05-15 09:36:02 +00:00
util.py more on schemas and fields: make it usable for interface-driven form generation; + minor bug fixes 2007-09-05 07:40:55 +00:00

===========================
Schema and Field Management
===========================

  ($Id$)

  >>> from cybertools.composer.schema import Schema
  >>> from cybertools.composer.schema import Field

We start with setting up a schema with fields.

  >>> serviceSchema = Schema(
  ...     Field(u'title', renderFactory=None),
  ...     Field(u'description'),
  ...     Field(u'start'),
  ...     Field(u'end'),
  ...     Field(u'capacity'),
  ... )

For using a schema we need some class that we can use for creating
objects.

  >>> class Service(object):
  ...     pass

The schema will be connected with an object via an instance adapter.

  >>> from cybertools.composer.schema.instance import Editor
  >>> from zope import component
  >>> component.provideAdapter(Editor, (Service,), name="service.edit")

  >>> srv = Service()
  >>> inst = component.getAdapter(srv, name='service.edit')
  >>> inst.template = serviceSchema
  >>> inst.applyTemplate()
  title -
  description -
  start -
  end -
  capacity -