ZCML Directive to Define Configuration Strings for Dropdown Lists
Project description
Tau SelectorStrings
Introduction
The purpose of this component distribution is two-fold; to provide a useful way of configuring clusters of strings to be presented in a dropdown list, and to teach others how to create new ZCML directives. The code has been carefully documented to make it clear how it works.
My need for selectorstrings comes from another component I’m designing for presenting collections of various files as a Zope folder. I wanted to allow the developer who adds an instance of this document folder, using the ZMI (Zope Management Interface), to pick from a list of directories. I did not want them to be able to enter arbitrary directories, partly as a security precaution and partly to prevent typing errors.
This resulted in the following ZCML directive:
<selectorstring cluster="sitedocs" label="Public Documents" value="/usr/share/public/" /> <selectorstring cluster="sitedocs" label="Family Photos" value="/home/jeff/photos/" />
And you can add more, using the same or difference cluster name and the strings will be available as a Zope vocabulary under that cluster name.
One drawback is that each such simple directive repeats the cluster name repeatedly. So next I created a complex (nested) directive to factor out the cluster name:
<selectorcluster name="sitedocs"> <selectorstring label="Public Documents" value="/usr/share/public/" /> <selectorstring label="Family Photos" value="/home/jeff/photos/" /> </selectorcluster>
Steps to Creating a New ZCML Directive
ZCML directives come in two flavors, simple and complex. A simple directive stands alone but a complex one supports grouping by containing one or more other ZCML directives.
A new ZCML directive, either simple or complex, is described by four pieces:
its name
the namespace it belongs to
the schema
its directive handler
The piece that ties these all together is the declaration of the (simple-kind of) directive in the meta.zcml file:
<meta:directive name="selectorstring" schema=".interfaces.ISelectorStringDirective" handler=".zcml_directives.selectorstring_SimpleDirectiveHandler" />
That takes care of declaring the name of the new directive and placing that name into the “zope” namespace. It could have placed it into the “browser” namespace or some other space that would make organizational sense.
To declare a complex-kind of directive:
<meta:complexDirective name="selectorcluster" schema=".interfaces.ISelectorClusterDirective" handler=".zcml_directives.selectorcluster_ComplexDirectiveHandler" > <meta:subdirective name="selectorstring" schema=".interfaces.ISelectorStringSubdirective" /> </meta:complexDirective>
Using Your ZCML Directive
Like any ZCML directive, you place it into a configure.zcml file or some other file included your the top-level site.zcml configuration file:
<configure xmlns="http://namespaces.zope.org/zope"> <selectorstring cluster="sitedocs" label="Public Documents" value="/usr/share/public/" /> </configure>
CHANGES
Version 0.1dev (2010-12-21)
Initial Release
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file tau.selectorstrings-0.1dev.tar.gz
.
File metadata
- Download URL: tau.selectorstrings-0.1dev.tar.gz
- Upload date:
- Size: 16.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 19ee7dd8cc271fe9c682583228dad1b1c24f668217f827c3814aef456b1c4a9e |
|
MD5 | 3d6d7cbbb9952c9c8cabc7ca7e780b82 |
|
BLAKE2b-256 | 65d67efcbc6e3b634fe169cad87026d6b7deebe38bad5c3d966c724a210e954d |
File details
Details for the file tau.selectorstrings-0.1dev-py2.6.egg
.
File metadata
- Download URL: tau.selectorstrings-0.1dev-py2.6.egg
- Upload date:
- Size: 15.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4a64b5a6d307ee1b1efcf547a14e3b39ac788d65e80610dcac0c56207e36ef5d |
|
MD5 | a6c7dda96460d02ad999b5a086ed9aca |
|
BLAKE2b-256 | e38b96453f368230b362eba16f5ba45275690344ba5b1e44fc61cddae8b743d2 |