Skip to main content

Provides Ruby on Rails-like command line functionalities, models and helper functions so you can focus on development and removes the pain of repeating frequent actions.

Project description

Django simplify provides Ruby on Rails-like command line functionalities, models and helper functions so you can focus on development and removes the pain of repeating frequent actions.

Requirements

  • Python 3.6 and above

  • Django (tested with 3.1, probably works with any version that supports

    Python 3)

Installation

django-simplify can be installed via pip.

$ pip install django-simplify

Then just add simplify to your INSTALLED_APPS.

Below are several example commands you can run.

$ python manage.py create_app <app_name>

Features

  • timestamp for every model

  • alphabetic filter for admin

  • model, view, template and url route generator

  • automatic import

Helper models

  • simplify.helpers.model_helper.TimeBasedModel
    • Provides the created_at and updated_at fields for timestamp

  • simplify.helpers.model_helper.NamedTimeBasedModel
    • Provides the name, created_at and updated_at fields.

  • simplify.helpers.admin_helper.AlphaNumericFilterAdmin
    • when subclassed, it allows the items to be filtered alphabetically by either A-Z or 0-9

    • Note: for this to work, you must specify values for alphanumeric_filter in the model admin.

Usage

# models.py
from simplify.helpers.model_helper import TimeBasedModel, NamedTimeBasedModel

class MyModel(TimeBasedModel):
    extra_fields = ....
# admin.py
from simplify.helpers.admin_helper import AlphaNumericFilterAdmin

class MemberAdmin(AlphaNumericFilterAdmin):
    alphanumeric_filter = ["first_name", "last_name", 'age'] # this part is important
    list_filter = ['age']
    list_display = ['first_name', 'last_name',]

Management commands

1. create_app

  • automatically adds a urls.py file after app is created.

  • adds newly created app in the settings.py file under INSTALLED_APPS

  • creates index, edit, create and detail view and respective templates

  • adds the app route to your project’s urls.py file

Usage

$ python manage.py create_app <app_name>

2. create_model

Creates a model and their respective fields. the following types maps to respective Django model fields

  • 121, o2o or set -> OneToOneField

  • bool -> BooleanField

  • date -> DateField

  • datetime or dt -> DateTimeField

  • dict or m2m -> ManyToManyField

  • email -> EmailField

  • file -> FileField

  • list or fk -> ForeignKey

  • float -> FloatField

  • dec -> DecimalField

  • img or image -> ImageField

  • int -> IntegerField

  • str or char -> CharField

  • txt or text -> TextField

Usage

$ python manage.py create_app <app_name> <model_name> field_name:type field_name:type ...

an example

$ python manage.py create_app member Member first_name:text last_name:text age:int

will generate the following code in the member/models.py file

class Member(TimeBasedModel):
    first_name = models.CharField(max_length=50)
    last_name = models.CharField(max_length=50)
    age = models.IntegerField(default=0)

    def __str__(self):
        return self.first_name

Specifying relationships

Specifying ForeignKey, OneToOneField or ManyToManyField is quite easy. just add an =<related_model>. See example

$ python manage.py create_app <app_name> <model_name> field_name:type=related_model

# an example
# if the related model is in the same models.py file, specify it as app_name.Model
$ python manage.py create_app author Author name:char books:fk=Book # or
$ python manage.py create_app author Author name:char books:fk=author.Book

# if in a different app. (say book model)
# obviously you should be able to substitute fk with m2m, o2o, 121
$ python manage.py create_app author Author name:char books:fk=book.Book

will create the following

class Author(TimeBasedModel):
    name = models.CharField(max_length=50)
    books = models.ForeignKey('book.Book', on_delete=models.CASCADE)

    def __str__(self):
        return self.name

Todo

  • add more helper functions

  • add documentation

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

django-simplify-0.1.1.tar.gz (8.4 kB view details)

Uploaded Source

File details

Details for the file django-simplify-0.1.1.tar.gz.

File metadata

  • Download URL: django-simplify-0.1.1.tar.gz
  • Upload date:
  • Size: 8.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.8.5

File hashes

Hashes for django-simplify-0.1.1.tar.gz
Algorithm Hash digest
SHA256 a3f45e3b69678fb3402a8ca1bab64e3dd561a10e7c1c03e6625511841d4ad695
MD5 3c94f198702795d64a2c4ffaee008aa2
BLAKE2b-256 0dc0d648a15f5706d2735320c2d919d0e975b206f1193a50d8701c3ce078df5e

See more details on using hashes here.

Supported by

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