Allow user to cancel without saving
This commit is contained in:
parent
88853e352c
commit
dd93dd5aea
@ -21,7 +21,10 @@ def render_task_orders_edit(template, portfolio_id=None, task_order_id=None, for
|
|||||||
else:
|
else:
|
||||||
render_args["form"] = form or TaskOrderForm()
|
render_args["form"] = form or TaskOrderForm()
|
||||||
|
|
||||||
render_args["cancel_url"] = url_for(
|
render_args["cancel_save_url"] = url_for(
|
||||||
|
"task_orders.portfolio_funding", portfolio_id=portfolio_id, save=True
|
||||||
|
)
|
||||||
|
render_args["cancel_discard_url"] = url_for(
|
||||||
"task_orders.portfolio_funding", portfolio_id=portfolio_id
|
"task_orders.portfolio_funding", portfolio_id=portfolio_id
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -116,7 +119,7 @@ def submit_form_step_one_add_pdf(portfolio_id=None, task_order_id=None):
|
|||||||
|
|
||||||
|
|
||||||
@task_orders_bp.route("/task_orders/<task_order_id>/form/cancel", methods=["POST"])
|
@task_orders_bp.route("/task_orders/<task_order_id>/form/cancel", methods=["POST"])
|
||||||
@user_can(Permissions.CREATE_TASK_ORDER, message="view task order form")
|
@user_can(Permissions.CREATE_TASK_ORDER, message="cancel task order form")
|
||||||
def cancel_edit(task_order_id):
|
def cancel_edit(task_order_id):
|
||||||
save = http_request.args.get("save", False)
|
save = http_request.args.get("save", False)
|
||||||
if save:
|
if save:
|
||||||
@ -132,13 +135,14 @@ def cancel_edit(task_order_id):
|
|||||||
task_order = None
|
task_order = None
|
||||||
if task_order_id:
|
if task_order_id:
|
||||||
task_order = TaskOrders.update(task_order_id, **form.data)
|
task_order = TaskOrders.update(task_order_id, **form.data)
|
||||||
portfolio_id = task_order.portfolio_id
|
|
||||||
else:
|
else:
|
||||||
task_order = TaskOrders.create(
|
task_order = TaskOrders.create(
|
||||||
g.current_user, portfolio_id, **form.data
|
g.current_user, portfolio_id, **form.data
|
||||||
)
|
)
|
||||||
|
|
||||||
return redirect(url_for("task_orders.portfolio_funding", portfolio_id=portfolio_id))
|
return redirect(
|
||||||
|
url_for("task_orders.portfolio_funding", portfolio_id=g.portfolio.id)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
@task_orders_bp.route("/task_orders/<task_order_id>/form/step_2")
|
@task_orders_bp.route("/task_orders/<task_order_id>/form/step_2")
|
||||||
|
@ -37,8 +37,8 @@
|
|||||||
{% call Modal(name='cancel', dismissable=True) %}
|
{% call Modal(name='cancel', dismissable=True) %}
|
||||||
<div class="task-order__modal-cancel">
|
<div class="task-order__modal-cancel">
|
||||||
<h1>Do you want to save this draft?</h1>
|
<h1>Do you want to save this draft?</h1>
|
||||||
<a href="" class="action-group__action icon-link">No, delete it</a>
|
<a href="{{ cancel_discard_url }}" class="action-group__action icon-link">No, delete it</a>
|
||||||
<a href="" class="action-group__action icon-link">Yes, save for later</a>
|
<a href="{{ cancel_save_url }}" class="action-group__action icon-link">Yes, save for later</a>
|
||||||
</div>
|
</div>
|
||||||
{% endcall %}
|
{% endcall %}
|
||||||
|
|
||||||
|
@ -322,12 +322,40 @@ def test_can_cancel_edit_and_save_task_order(client, user_session, task_order, s
|
|||||||
user_session(task_order.portfolio.owner)
|
user_session(task_order.portfolio.owner)
|
||||||
response = client.post(
|
response = client.post(
|
||||||
url_for("task_orders.cancel_edit", task_order_id=task_order.id, save=True),
|
url_for("task_orders.cancel_edit", task_order_id=task_order.id, save=True),
|
||||||
data={"number": "0123456789012"},
|
data={"number": "7896564324567"},
|
||||||
)
|
)
|
||||||
assert response.status_code == 302
|
assert response.status_code == 302
|
||||||
|
|
||||||
updated_task_order = session.query(TaskOrder).get(task_order.id)
|
updated_task_order = session.query(TaskOrder).get(task_order.id)
|
||||||
assert updated_task_order.number == "0123456789012"
|
assert updated_task_order.number == "7896564324567"
|
||||||
|
|
||||||
|
|
||||||
|
def test_cancel_edit_does_not_save_invalid_form_input(client, user_session, session):
|
||||||
|
task_order = TaskOrderFactory.create()
|
||||||
|
user_session(task_order.portfolio.owner)
|
||||||
|
response = client.post(
|
||||||
|
url_for("task_orders.cancel_edit", task_order_id=task_order.id, save=True),
|
||||||
|
data={"clins": "not really clins"},
|
||||||
|
)
|
||||||
|
assert response.status_code == 302
|
||||||
|
|
||||||
|
# CLINs should be unchanged
|
||||||
|
updated_task_order = session.query(TaskOrder).get(task_order.id)
|
||||||
|
assert updated_task_order.clins == task_order.clins
|
||||||
|
|
||||||
|
|
||||||
|
def test_cancel_edit_without_saving(client, user_session, session):
|
||||||
|
task_order = TaskOrderFactory.create(number=None)
|
||||||
|
user_session(task_order.portfolio.owner)
|
||||||
|
response = client.post(
|
||||||
|
url_for("task_orders.cancel_edit", task_order_id=task_order.id),
|
||||||
|
data={"number": "7643906432984"},
|
||||||
|
)
|
||||||
|
assert response.status_code == 302
|
||||||
|
|
||||||
|
# TO number should be unchanged
|
||||||
|
updated_task_order = session.query(TaskOrder).get(task_order.id)
|
||||||
|
assert updated_task_order.number is None
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.skip(reason="Reevaluate how form handles invalid data")
|
@pytest.mark.skip(reason="Reevaluate how form handles invalid data")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user