-
-
Notifications
You must be signed in to change notification settings - Fork 26
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Creating models based on the design developed last week on steps and flow #75
base: master
Are you sure you want to change the base?
Changes from 1 commit
a91919e
e2a62d4
105fd7c
f5ac818
c197403
674b59c
e144e3e
48d5ed1
3902e93
c71b62e
c50f10a
40c413c
9b16dbd
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
from django.urls import reverse | ||
|
||
from django.forms.widgets import Widget | ||
from django.utils.safestring import mark_safe | ||
|
||
class RedirectButtonWidget(Widget): | ||
def render(self, name, value, attrs=None, renderer=None): | ||
action_url = reverse('actions') | ||
button_html = f'<br> <a href="{action_url}" id="{name}_button" class="btn btn-primary hidden">Add Action</a>' | ||
return mark_safe(button_html) | ||
|
||
|
||
def save_steps(steps_data_json): | ||
from djgentelella.forms.forms import GTStepForm | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Esta importación del formulario GTStepForm no debe ir aquí. |
||
for step in steps_data_json: | ||
step_data = step['data'] | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Como aseguras que esa clave data exista? Desde el navegador podemos modificar la data que enviamos al post de la función create_flow haciendo que la función el sistema caiga con errores, debemos validar ese campo stepsData ya sea con un formulario o con un serializador porque ahorita mismo resulta fácil sabotear la data del post al no haber validación de ello. |
||
|
||
step_form_data = { | ||
'name': step_data.get('name'), | ||
'order': step_data.get('order'), | ||
'status_id': [], | ||
'form': [], | ||
'pre_action': [], | ||
'post_action': [], | ||
} | ||
|
||
form = GTStepForm(step_form_data) | ||
|
||
if form.is_valid(): | ||
step_instance = form.save() | ||
|
||
save_actions(step_data, step_instance) | ||
print('exito') | ||
else: | ||
print(form.errors) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Eliminar prints |
||
|
||
def save_actions(step_data, step_instance): | ||
from djgentelella.forms.forms import GTActionsStepForm | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Esta importación no debe ir acá. |
||
|
||
if 'preActions' in step_data and step_data['preActions']: | ||
for pre_action_data in step_data['preActions']: | ||
pre_action_form = GTActionsStepForm(pre_action_data) | ||
if pre_action_form.is_valid(): | ||
pre_action = pre_action_form.save() | ||
step_instance.pre_action.add(pre_action) | ||
else: | ||
print(pre_action_form.errors) | ||
|
||
|
||
if 'postActions' in step_data and step_data['postActions']: | ||
for post_action_data in step_data['postActions']: | ||
post_action_form = GTActionsStepForm(post_action_data) | ||
if post_action_form.is_valid(): | ||
post_action = post_action_form.save() | ||
step_instance.post_action.add(post_action) | ||
else: | ||
print(post_action_form.errors) |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
import json | ||
|
||
from django.shortcuts import render, redirect | ||
|
||
from demoapp.flow.utils import save_steps | ||
from djgentelella.forms.forms import GTStepForm, GTActionsStepForm, GTStatusForm, \ | ||
GTSkipConditionForm, GTFlowForm | ||
from djgentelella.models import GTStep | ||
|
||
|
||
def flow_index(request): | ||
return render(request, 'gentelella/flow/flow.html') | ||
|
||
def create_flow(request): | ||
|
||
form = GTFlowForm() | ||
|
||
if request.method == 'POST': | ||
form = GTFlowForm(request.POST) | ||
if form.is_valid(): | ||
form.save() | ||
steps_data = request.POST.get('stepsData') | ||
steps_data_json = json.loads(steps_data) | ||
save_steps(steps_data_json) | ||
return redirect('flow') | ||
|
||
return render(request, 'gentelella/flow/create_flow.html', {'form': form}) | ||
|
||
def step_index(request, id): | ||
|
||
step = GTStep() | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Estas creando la instancia de un paso(GTStep) pero no estas logrando hacer nada con ella, porque en el código JS modificas los valores de los campos con lo exista en la sesión. Sino vas a guardar la instancia o hacer algo con ella entonces es mejor no pasarla. |
||
|
||
form = GTStepForm(instance=step) | ||
return render(request, 'gentelella/flow/step.html', {'form': form, 'id': id}) | ||
|
||
def actions_index(request): | ||
if request.method == 'POST': | ||
form = GTActionsStepForm(request.POST) | ||
if form.is_valid(): | ||
form.save() | ||
return redirect('flow') | ||
else: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Este else no es tan necesario puedes declarar el formulario apenas inicias la función para que quede por defecto, lo mismo para status y condition. |
||
form = GTActionsStepForm() | ||
|
||
return render(request, 'gentelella/flow/actions.html', {'form': form}) | ||
|
||
|
||
def status_index(request): | ||
if request.method == 'POST': | ||
form = GTStatusForm(request.POST) | ||
if form.is_valid(): | ||
form.save() | ||
return redirect('status') | ||
else: | ||
form = GTStatusForm() | ||
|
||
return render(request, 'gentelella/flow/status.html', {'form': form}) | ||
|
||
def skip_condition_index(request): | ||
if request.method == 'POST': | ||
form = GTSkipConditionForm(request.POST) | ||
if form.is_valid(): | ||
form.save() | ||
return redirect('success_url') | ||
else: | ||
form = GTSkipConditionForm() | ||
|
||
return render(request, 'gentelella/flow/skip_conditions.html', {'form': form}) |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
{% extends 'gentelella/base.html' %} | ||
{% load gtsettings timejs %} | ||
|
||
{% block content %} | ||
<div class="card"> | ||
<div class="card-body"> | ||
<div class="card-title titles"> | ||
<h2>Actions</h2> | ||
</div> | ||
|
||
|
||
<form method="post"> | ||
{% csrf_token %} | ||
{{ form.as_p }} | ||
<button class="btn btn-primary text-end" type="submit">Submit</button> | ||
</form> | ||
|
||
</div> | ||
</div> | ||
</div> | ||
{% endblock %} | ||
|
||
{% block js %} | ||
|
||
<script></script> | ||
|
||
{% endblock js%} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
{% extends 'gentelella/base.html' %} | ||
{% load gtsettings timejs %} | ||
|
||
{% block content %} | ||
<div class="card"> | ||
<div class="card-body"> | ||
<div class="card-title titles"> | ||
<h2 id="step-title">Create Flow</h2> | ||
</div> | ||
|
||
<form method="post" id="flow_form" action="{% url 'create_flow' %}"> | ||
{% csrf_token %} | ||
{{ form.as_p }} | ||
<input type="hidden" id="stepsData" name="stepsData"> | ||
|
||
<button class="btn btn-primary" id="create_flow" type="submit">Submit</button> | ||
</form> | ||
</div> | ||
</div> | ||
</div> | ||
{% endblock %} | ||
|
||
{% block js %} | ||
|
||
<script> | ||
|
||
document.getElementById('create_flow').addEventListener('click', function() { | ||
event.preventDefault(); | ||
var stepsData = JSON.parse(sessionStorage.getItem('stepData')) || {}; | ||
console.log(stepsData); | ||
document.getElementById('stepsData').value = JSON.stringify(stepsData); | ||
document.getElementById('flow_form').submit(); | ||
sessionStorage.clear(); | ||
}); | ||
|
||
</script> | ||
|
||
{% endblock js%} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hay que mejorar la definción de esta url porque es demasiado general, recomiendo utilizar "flow_actions" o algo similar.
Todas las urls de flujo pueden partir de "flow" por ejemplo:
path("flow", ...., name="index_flow"),
path("flow/create", ...., name="create_flow")
path("flow/actions", ...., name="actions_flow")
De esta manera separamos todas las urls relacionadas a flow y no chocamos con otras urls a futuro, porque sino a futuro nos vemos obligados a actualizarlas y revisar donde son llamadas y por ende nos quitaría tiempo de algo que podemos mejorar ahorita mismo.