Skip to main content

Genrate CRUD interface in TurboGears

Project description

tgcrud is an TurboGears command extension,
which could generate a sqlobject/sqlalchemy backend
editor/crud (create, read, update, delete) interface based
on your Model with kid template.
It could be plugged into any projects even if you don't use kid template.

The generated codes are fully customizable.
tgcrud heavily use form widgets and show you many
TG 1.0 features in it's controllers/templates.

Please refer to http://docs.turbogears.org/1.0/CRUDTemplate for detail

The command follow the TurboGears quickstart template style, you could easily add
identity, form validation, paginate in your crud interface.

If you are a TG beginer, tgcrud help you create a general
admin skeleton based on your model.

If you are an experienced TG developer, you could get it in minutes
since it just done the basic procedure that every time you write a
management interface of your model.

Features
----------------------

No Magic

* The generated codes are normal TG source.
* no extra magic encapsulation, thus you don't need to rewrite the
interface when you need extra flexibility (not the same as Rails'
scaffold)
* Separate Form definition from Model (not the same as Django admin)
* Use standard TurboGears syntax and code organization.
* It's a good crud implementation reference by TG.

TurboGears

* Provide the command line tool
* tgcrud kid interface works for you no matter whatever template
engine you currently choose for your project.
* You could customize the model relationship by widgets (document
shows how to customize 1-to-1, 1-to-many, many-to-many relationship with widgets.
Besides that, you could do it with HTML form in your way)
* Use widgets form heavily. you'd hardly need to modify the HTML. You
could add complex form validation via widgets, too.

Install
----------

The 'tgcrud' command extension is available in Python CheeseShop and
TurboGears svn.

You can use setuptools to install tgcrud with following command::


$ easy_install tgcrud

or download the source code and install tgcrud manually.

Screencast
--------------

Yes, there's a 'Make a Book Site with TurboGears' screencast with tgcrud.

If you are an experienced TG developer, you could skip to the third.

If you are new to TG, you may want to watch all of them to get familiar with TurboGears.

- Quickstart TurboGears project, 6.5MB

http://files.turbogears.org/video/openbook1.swf

- Design model with toolbox utilities, 7.7MB

http://files.turbogears.org/video/openbook2.swf

- tgcrud, the TG's scaffold, 5.2 MB

http://files.turbogears.org/video/openbook3.swf

With tgcrud you could easily generate a Rails scaffold
style CRUD interface. The difference is all code in tgcrud is
implicit, which leads to more easy customization.

Usage
----------

1. Define your model in model.py

2. After you've defined your model,
you could use "tg-admin crud" command to generate the crud pack.
The syntax is::

$ tg-admin crud [model class name] [package name]

e.x if the model name is BookMark,
the package name is BookMarkController, the command is::

$ tg-admin crud BookMark BookMarkController

Then the 'admin' package is generated.
You just need take several minutes to customize the formfield to
have a proper crud interface.

..note:: you could estimate the result by passing "--dry-run" to the command, such as::

$ tg-admin crud BookMark BookMarkController --dry-run

With this argument the command will not effect your physical directories.


3. Import the package to your controllers.py with a line:

from BookMarkController import BookMarkController

and add a branch on your Root()::

foo = BookMarkController()

4. Customize the form filed in admin/controllers.py

5. Open the http://localhost:8080/foo to use the customizable interface.

ChangeLog
-------------------------
1.0 Beta 3
* template refactory
* now 'edit' and 'new' actions share the same template

1.0 Beta 2
* remove db auto detection for flexibility

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tgcrud-1.0Beta3.win32.zip (22.6 kB view details)

Uploaded Source

Built Distributions

tgcrud-1.0Beta3-py2.5.egg (20.7 kB view details)

Uploaded Source

tgcrud-1.0Beta3-py2.4.egg (20.7 kB view details)

Uploaded Source

File details

Details for the file tgcrud-1.0Beta3.win32.zip.

File metadata

File hashes

Hashes for tgcrud-1.0Beta3.win32.zip
Algorithm Hash digest
SHA256 e182d10c26a5de772ebb73212b63824f296c522f1de9ad167091987ec1ad463c
MD5 2ced3bcc6c7e9e0eeac702c2aa092037
BLAKE2b-256 07f76233e34e6d5eef60422dd44c7ce162928799f7697ccb28542a06bfda1f4d

See more details on using hashes here.

File details

Details for the file tgcrud-1.0Beta3-py2.5.egg.

File metadata

File hashes

Hashes for tgcrud-1.0Beta3-py2.5.egg
Algorithm Hash digest
SHA256 69ca73c5c1e523564d3c310db126983effaff6ba989b0216c79babba2fe0d014
MD5 542b150f03a6c1235288ac76b4fb43be
BLAKE2b-256 738fe2bb79c93988582ef66579556845dddd535a0242925cc9c94076ef54c313

See more details on using hashes here.

File details

Details for the file tgcrud-1.0Beta3-py2.4.egg.

File metadata

File hashes

Hashes for tgcrud-1.0Beta3-py2.4.egg
Algorithm Hash digest
SHA256 9fd173fa5fd3a927bd8a49b3a085c8dff35e079a41c04b00a42c00118a7717ba
MD5 c6ca44d7c496cf6c1727cdd8c0c30c2e
BLAKE2b-256 6f61cde7c136a9a7c0f108606635ca68244f7902176a5acd41ab61f51ee356b7

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page