Giter Site home page Giter Site logo

adamghill / django-unicorn Goto Github PK

View Code? Open in Web Editor NEW
2.3K 25.0 114.0 3.83 MB

The magical reactive component framework for Django ✨

Home Page: https://www.django-unicorn.com

License: MIT License

Python 66.63% JavaScript 27.47% HTML 5.86% CSS 0.01% Shell 0.02%
django python javascript fullstack frontend-framework

django-unicorn's People

Contributors

adamghill avatar allcontributors[bot] avatar apoorvaeternity avatar bazubii avatar bloodywing avatar clangley avatar dancaron avatar edelvalle avatar felipmartins avatar franziskhan avatar frnidito avatar github-actions[bot] avatar hauntsaninja avatar hendi avatar imankulov avatar jacksund avatar joshiggins avatar lassebomh avatar martey avatar mihrab34 avatar nerdoc avatar pbadeer avatar regoawt avatar rhymiz avatar robwa avatar siliconcow avatar stat1c-void avatar zodman avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

django-unicorn's Issues

Looks promising

How can I help? I’m a web designer/developer (HTML + CSS) and haven’t taken the leap into the front-end frameworks.

I like the idea of components but all of the overhead in the front-end frameworks is overwhelmingly complex and changes far too often to keep up with a small team.

We have a couple of projects which use Django with templates.

This project looks like something we would be interested in.

How can we help?

Cast to a particular property type

Strings and booleans get cast as expected, but it'd be nice to have a mechanism to cast to a particular type inside the component. The canonical example would be a datetime coming from a HTML input and getting parsed to be a datetime` object inside the component.

Model bind to a nested property

Either a property array, dictionary or object. Probably should use dot notation to access.

e.g. <input type="text" unicorn:model="blog.author.name">

loading delay modifier

To prevent flicker only show/remove unicorn:loading when the action takes longer than 200ms.

Possible directory error in default examples

Hi. I've created an empty django project to test unicorn. But somehow the default instructions don't seem to work and cause a template not found error. Here's what I've done:

  1. Created a new django project in pycharm
  2. pip install django-unicorn
  3. Added "django_unicorn", to the INSTALLED_APPS
  4. Created an empty base.html file and made it viewable in the browser
  5. Added path("unicorn/", include("django_unicorn.urls"))
  6. Added {% load unicorn %} to the top of base.html
  7. Added {% unicorn_scripts %} right underneath in base.html
  8. Ran python manage.py startunicorn hello-world
  9. Added {% unicorn 'hello-world' %} at the bottom of base.html

After this last step 9 it starts to break and throws a TemplateDoesNotExist error:
django.template.loaders.filesystem.Loader: /home/user/uniplayground/templates/unicorn/hello-world.html (Source does not exist)

In my project folder the hello-world.html file generated by step 8 is located under:
/home/user/uniplayground/unicorn/templates/unicorn/hello-world.html

Am I doing something wrong or does the startunicorn command not generate the files into the right structure?

Edit: Moving the HTML file to the template folder that django is looking in seems to work. While leaving the python file in the generated folder structure.

Set property shortcut

Instead of having to create set_name() methods, support something like name='World'.

Updating class variables from outside

HI Adam!

It would be useful to be able to update the unicorn component class variables from another Django app.
You mentioned an API call or database hookup on the page refresh.
How would this be done?

Would this also be possible via AJAX or a Javascript hook?

Thanks!

Ashirvad

Django model on property doesn't reset as expected

When using a Django model as a property, if a field is updated as part of unicorn:model, the model will not get reset as expected.

class HelloWorldView(UnicornView):
    book = Book(title="The Sandman")
<input unicorn:model="book.title" type="text" id="bookId">

Reduce lag with keeping text input up to date

Example: django-unicorn-lag

Not sure if this is related to morphdom updating the DOM in a way not expected. Maybe need to prevent the current model name from being updated by morphdom? Or maybe just reduce the debounce timeout might make it work a little better?

Handle `lazy` modifier

Add support for unicorn:model.lazy to change the event listener to be blur instead of input.

$model special action variable

It would be useful to handle the special action argument $model being passed into an action. Probably only useful for db models since normal models can just do self.whatever in the component view code.

<div>
  {% for book in books %}
  <div u:db="book" u:pk="{{ book.id }}">
    <button u:click="delete($model)`>
    <!-- <button u:click="delete({{ book.id }})`> -->
  </div>
  {% endfor %}
</div>
from django_unicorn.components import UnicornView
from books.models import Book

class DbModelView(UnicornView):
    # magically instantiate the appropriate book instance object here based on model class and pk
    def delete(book):
         book.delete()

    # normal way call action with a model requires passing around an id/pk/slug and looking it up
    # def delete(book_id):
    #    book = Book.objects.get(id=book_id)
    #    book.delete()

    class Meta:
        db_models = [DbModel("book", Book)]

Passing arguments to the unicorn view

Being able to send arguments from the parent django template to the unicorn view.

To be able to do something like :

class TestView(UnicornView):
    name = "hello-world"
    def __init__(self, var):
         self.var = var
    def set_var(self, var):
         self.var = var
{% unicorn 'hello-world' with var=var %}      (django {% include %} like )

Or to be able to send arguments to Unicorn.call :

{% unicorn 'hello-world' %}

<button onclick="Unicorn.call('hello-world', 'set_var', 'var_value');">Set the name from outside the component</button>

Even if it's just sending a one-shot primitives it will be very helpful to give some context to the unicorn view.

When a model and action fire at the same time, the sync input can be lost

I was not seeing this on local dev with 0.6.0, but it happens when deployed. I am now able to replicate it on local by throttling network responses.

I think I need to merge the syncInput and callMethod actions that fire "at the same time" into the payload array so that the syncInput doesn't get lost.

Interaction glitch w/ BitWarden

hello Adam, long time no talk!

I was trying out the demo on the website and something BitWarden is doing to the input box, I think added it's own attribute to the html, causes the input to be redrawn empty but if you click the button add it will still load something but not everything.

Video:
django-unicorn-glitch.mov.zip

If I disable BitWarden and reload the page, the interaction works fine.

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.