Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mathison-ag/django-angular-dynamic-forms
Angular 6 reactive forms integrated with Django Rest Framework viewsets, rapid development of forms
https://github.com/mathison-ag/django-angular-dynamic-forms
angular2 angular5 django django-rest-framework forms ng-dynamic-forms reactive-forms
Last synced: 2 months ago
JSON representation
Angular 6 reactive forms integrated with Django Rest Framework viewsets, rapid development of forms
- Host: GitHub
- URL: https://github.com/mathison-ag/django-angular-dynamic-forms
- Owner: Mathison-AG
- License: mit
- Created: 2017-09-26T18:01:06.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-01-01T13:17:56.000Z (about 1 year ago)
- Last Synced: 2024-10-31T13:09:31.155Z (2 months ago)
- Topics: angular2, angular5, django, django-rest-framework, forms, ng-dynamic-forms, reactive-forms
- Language: TypeScript
- Homepage: https://mathison.ch
- Size: 1.8 MB
- Stars: 21
- Watchers: 7
- Forks: 9
- Open Issues: 29
-
Metadata Files:
- Readme: README.rst
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
Django Rest Framework meets Angular 6 dynamic forms
===================================================This repo provides Django mixins and Angular library for rapid
development of create/edit dialogs for django rest framework.
It depends on Django 2, Angular 6 and Material UI.Note: support for Angular 5 and Django<2 is not actively developed - use
release/angular5 branch or 1.1.* versions of packages if you need that.On django side, extend your ``Viewset`` to use ``AngularFormMixin``
and optionally configure the mixin by providing either layout
information or field defaults (such as css classes). See demos
for details... code-block:: python
class CityViewSet(AngularFormMixin, viewsets.ModelViewSet):
"""
API for cities
"""
queryset = City.objects.all()
serializer_class = CitySerializerOn angular side, use ``DjangoFormDialogService`` to display a dialog:
.. code-block:: typescript
constructor(private dialog: DjangoFormDialogService) {
}
createCity() {
this.dialog.open('/api/1.0/cities/').subscribe(result => {
console.log('City created, result from server is:', result);
});
}You can also display the form inside your own component via ```` tag.
.. code-block:: html
Demo and sample source files
----------------------------See demos at http://mesemus.no-ip.org:12569
.. image:: https://raw.githubusercontent.com/mesemus/django-angular-dynamic-forms/develop/docs/demo.png
With a bit of work on your side, foreign keys and many-to-many relationships are supported as well (see the demos for details)
.. image:: https://raw.githubusercontent.com/mesemus/django-angular-dynamic-forms/develop/docs/foreign_key.png
Installation
------------*Django side:*
.. code-block:: bash
pip install django-angular-dynamic-forms
*Angular side:*
.. code-block:: bash
npm install --save django-angular-dynamic-forms @ng-dynamic-forms/core @ng-dynamic-forms/ui-material
To render forms, this library uses https://github.com/udos86/ng-dynamic-forms - do not forget
to add it to your package.json.and add ``DjangoFormModule`` to imports. You will need to provide your own ErrorService for showing
communication errors back to the user. See the ``demo/angular/src/app/mat-error.service.ts`` for
an example implementation... code-block:: typescript
import {DjangoFormModule, ErrorService} from 'django-angular-dynamic-forms';
@NgModule({
declarations: [
...
],
imports: [
BrowserAnimationsModule,
DynamicFormsCoreModule.forRoot(),
DynamicFormsMaterialUIModule,
DjangoFormModule,
HttpClientModule,
...
],
providers: [
{
provide: ErrorService,
useClass: MatErrorService
},
],
bootstrap: [AppComponent]
})
export class AppModule {
}Configuration
-------------If your angular and django server are on the same host/port (see
https://github.com/angular/angular-cli/blob/master/docs/documentation/stories/proxy.md for development tips),
no configuration is necessary.If angular and django are on different hosts/ports, set django setting ``ANGULAR_FORM_ABSOLUTE_URLS=True`` (
thanks @sssolid for pointing this out).Sponsorship
-----------* `Mathison AG | Mobile & Web Development `_.
* `Stella Gastro | The best Restaurants, Bars and Cafés in Switzerland `_.
* `Lancer Express | The Swiss Army Knife for Freelancers `_.