Skip to main content

Faster Development For Django 3 Projects

Project description

Django 3 Scaffold Package

Build Status Build Status Build Status Build Status Build Status

Overview

imagine that you need to build a customized admin panel from scratch or maybe you need a second panel just for your customers, regular users or something like that , then you need this package to do it very fast.

this package creates models and views and forms and URLs and tests and templates for crud in one single command!

for example, you just run a single command in your command-line like this :

python manage.py scaffold forum --model Forum char:name char:reads

and this package generates these files for you :

└── forum
   ├── __init__.py
   ├── admin.py
   ├── apps.py
   ├── forms.py
   ├── migrations
   │   └── __init__.py
   ├── models.py
   ├── templates
   │   ├── base.html
   │   └── forum
   │       ├── details.html
   │       └── list.html
   ├── tests.py
   ├── urls.py
   └── views.py

Installation

  • Install django3scaffold (ideally in your virtualenv!) using pip or simply getting a copy of the code and putting it in a directory in your codebase.

     pip install django3scaffold
    
  • Add django3scaffold to your Django settings INSTALLED_APPS\ :

    INSTALLED_APPS = [ # ... "django3scaffold", ]

  • Add the following to your settings.py with appropriate values:

    • IS_DEV

    • IS_PROD

    • DOMAIN_NAME

    • WWW_ROOT

      DOMAIN_NAME= 'localhost'
      WWW_ROOT = BASE_DIR
      IS_DEV = True
      IS_PROD = False
      
  • Add django3scaffold to your Django settings TEMPLATE_CONTEXT_PROCESSORS\ :

    'OPTIONS': {
         'context_processors': [
             ...
             'django3scaffold.context_processors.django3scaffold_settings',
             ...
    
         ],
    

usage

#. Run

To run scaffold type:

    python manage.py scaffold APPNAME --model MODELNAME [fields]

APPNAME is app name. If app does not exists it will be created. MODELNAME is model name. Just enter model name that you want to create (for example: Blog, Topic, Post etc). It must be alphanumerical. Only one model per run is allowed!

[fields] - list of the model fields.

#. Field types

Available fields:

    char - CharField
    text - TextField
    int - IntegerFIeld
    decimal -DecimalField
    datetime - DateTimeField
    foreign - ForeignKey

All fields requires name that is provided after : sign, for example:

char:title text:body int:posts datetime:create_date

Two fields foreign and decimal requires additional parameters:

  • "foreign" as third argument takes foreignkey model, example:

    foreign:blog:Blog, foreign:post:Post, foreign:added_by:User

NOTICE: All foreign key models must alread exist in project. User and Group model are imported automatically.

  • decimal field requires two more arguments max_digits and decimal_places\ , example:

    decimal:total_cost:10:2

NOTICE: To all models scaffold automatically adds two fields: update_date and create_date.

#. How it works?

Scaffold creates models, views (CRUD), forms, templates, admin, urls and basic tests (CRUD). Scaffold templates are using two blocks extending from base.html:

    {% extends "base.html" %}
    {% block page-title %} {% endblock %}
    {% block conent %} {% endblock %}

So be sure you have your base.html set up properly.

Scaffolding example usage

Let's create very simple forum app. We need Forum , Topic and Post model.

  • Forum model

Forum model needs just one field name :

    python manage.py scaffold forum --model Forum char:name
  • Topic model

Topics are created by site users so we need: created_by , title and Forum foreign key ( update_date and create_date are always added to models):

    python manage.py scaffold forum --model Topic foreign:created_by:User char:title foreign:forum:Forum
  • Post model

Last one are Posts. Posts are related to Topics. Here we need: title , body , created_by and foreign key to Topic\ :

    python manage.py scaffold forum --model Post char:title text:body foreign:created_by:User foreign:topic:Topic

All data should be in place!

Now you must add forum app to INSTALLED_APPS :

``
INSTALLED_APPS = [
    # ...
    "forum",
]
``

Now you must include app in urls.py file by adding into urlpatterns:

from django.conf.urls import url
from django.urls import include

   urlpatterns = patterns('',

       url(r'', include('forum.urls')),

   )

Now syncdb new app and you are ready to go:: add include and url and path ro url file add app name to settings fix from django.urls import reverse in views

  python manage.py migrate --run-syncdb
  python manage.py makemigrations
  python manage.py migrate

Run your server:

python manage.py runserver

And go to forum main page:

http://localhost:8000/forum/

All structure are in place. Now you can personalize models, templates and urls.

At the end you can test new app by runing test:

python manage.py test forum

Creating test database for alias 'default'... .......

Ran 7 tests in 0.884s

OK

Happy scaffolding!

This open-source app is brought to you by Tokyo Developers, Inc. ( http://tokyodevs.com/ )

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

django3scaffold-0.9.8.tar.gz (22.7 kB view details)

Uploaded Source

Built Distribution

django3scaffold-0.9.8-py3-none-any.whl (25.0 kB view details)

Uploaded Python 3

File details

Details for the file django3scaffold-0.9.8.tar.gz.

File metadata

  • Download URL: django3scaffold-0.9.8.tar.gz
  • Upload date:
  • Size: 22.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.8.1

File hashes

Hashes for django3scaffold-0.9.8.tar.gz
Algorithm Hash digest
SHA256 87a83cce428b53e47277fdd082491b95bd8a1071534baec81d0cdec627fa5c48
MD5 4a8e86b275afb38970ec5d2095c4e4b2
BLAKE2b-256 48b561a36724b0a8c931a6d4f3ee904a5f42e8386413fa77553bd9d95715bf0f

See more details on using hashes here.

File details

Details for the file django3scaffold-0.9.8-py3-none-any.whl.

File metadata

  • Download URL: django3scaffold-0.9.8-py3-none-any.whl
  • Upload date:
  • Size: 25.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.8.1

File hashes

Hashes for django3scaffold-0.9.8-py3-none-any.whl
Algorithm Hash digest
SHA256 ea19b2cb19a533086c09f7cb3728a87c8f726999ab51a70d06b0074cf82c1393
MD5 99926042b46a2e98c023beb6e8bac971
BLAKE2b-256 11f882ab7327b1134ce031f7fa8b523a29596f750d305485cf9b9a1221173b31

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