Giter Site home page Giter Site logo

solarliner / django-crispy-bulma Goto Github PK

View Code? Open in Web Editor NEW

This project forked from python-discord/django-crispy-bulma

0.0 2.0 0.0 107 KB

Django application to add 'django-crispy-forms' layout objects for Bulma.io

License: MIT License

Python 29.37% HTML 70.63%

django-crispy-bulma's Introduction

django-crispy-bulma

This project is an early work in progress. You should not use this package yet, as it is poorly documented and is missing many important features. We'll remove this header when it's ready to use.

About

This is a Django application to add django-crispy-forms layout objects for Bulma. It is a fork of crispy-forms-bulma by Jure Hotujec, with the intention of adding support for Django 2.0+, as well as for components found in the bulma-extensions library.

Installation

You can install django-crispy-bulma from PyPI by running pip install django-crispy-bulma. Make sure you also have django-crispy-forms installed, as it will not work without it. In order to activate it, you'll need to modify your projects settings.py file.

First, add django-crispy-bulma to your INSTALLED_APPS:

INSTALLED_APPS = [
    'crispy_forms',
    'django_crispy_bulma',
    # ...
]

Next, add the following to the bottom of the file in order to configure crispy_forms to use the bulma template pack:

CRISPY_ALLOWED_TEMPLATE_PACKS = (
    "bootstrap",
    "uni_form",
    "bootstrap3",
    "bootstrap4",
    "bulma",
)

CRISPY_TEMPLATE_PACK = "bulma"

You may also need to use Layout objects or form objects from django_crispy_bulma in order to build certain objects, like the UploadField. See the documentation below for specifics on objects like these.

EmailField

The EmailField looks like this:

EmailField

An EmailField can be created simply, like any other field in your form. For example:

from django.forms import Form
from django_crispy_bulma.forms import EmailField

class MyForm(Form):
    my_email = EmailField(
        label="email",
        required=True
    )

IconField

If you'd like to render a field with an icon in it, you'll need to make use of the Crispy Forms layout object, and the IconField from our package. See below for an example:

IconField

from crispy_forms.helper import FormHelper
from crispy_forms.layout import Layout
from django.forms import Form, CharField

from django_crispy_bulma.layout import IconField

class SetupForm(Form):
    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)

        self.helper = FormHelper(self)

        self.helper.layout = Layout(
            IconField("username", icon_prepend="user"),
        )

    username = CharField(
        label="Username",
        required=True,
    )

Note that IconField also supports an icon_append keyword argument. This field only supports font-awesome icons.

UploadField

The UploadField looks like this:

UploadField

To create these with CrispyForms, you'll need both a form object and a layout object from our package. Here's an example of how to use them.

from crispy_forms.helper import FormHelper
from crispy_forms.layout import Layout
from django import forms
from django_crispy_bulma.layout import UploadField
from django_crispy_bulma.forms import ImageField, FileField

class MyForm(forms.Form):
    my_image = ImageField(
        label="Upload an image of your dog",
        required=False
    )
    my_file = FileField(
        label="Upload your actual dog in .dog format",
        required=True    
    )
    
    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        self.helper = FormHelper()
        
        self.helper.layout = Layout(
            UploadField("my_image"),
            UploadField("my_file"),
        )

A little bit of javascript is needed in order to get the filename to display after a file upload is successful.

Written in vanilla JS, this might look something like this:

window.onload = function() {
    // Apply this to all upload fields
    const upload_fields = document.querySelectorAll(".file");
    for (let i = 0; i < upload_fields.length; i++) {
        let input = upload_fields[i].querySelector(".file-input");
        let filename = upload_fields[i].querySelector(".file-name");

        input.onchange = function() {
            filename.textContent = input.files[0].name;
        }
    }
};

For your convenience, we provide a script that handles this in our companion package, django-simple-bulma. We highly recommend you use these two packages together.

django-crispy-bulma's People

Contributors

andrei-dracea avatar gdude2002 avatar ghostofgoes avatar hypercodex avatar jb3 avatar jchristgit avatar jhotujec avatar lemonsaurus avatar markkoz avatar pydis-bot avatar sco1 avatar scragly avatar solarliner avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.