示例#1
0
def sale(sale_id):
    sale = Sale.query.get(sale_id)
    
    sale_status_histories = SaleStatusHistory.query.filter_by(sale_id=sale_id).order_by(SaleStatusHistory.created.desc()).all()
    form = SaleForm(**sale.serialize())

    form.agent.query = Agent.query.order_by(Agent.first_name, Agent.last_name)

    if form.validate_on_submit():
        sale_status = form.sale_status.data
        if sale_status != sale.sale_status:
            ssh = SaleStatusHistory(sale=sale, status=sale_status)
            db_session.add(ssh)

        form.populate_obj(sale)
        if sale.annual_consumption == '':
            sale.annual_consumption = None
        if sale.commission_value == '':
            sale.commission_value = None
        if sale.clawback_value == '':
            sale.clawback_value = None

        db_session.commit()

        return redirect(url_for('sale', sale_id=sale_id))
        

    context = {'sale': sale,
               'form': form,
               'sale_status_histories': sale_status_histories}

    return render_template('sale.html', **context)