added promo
This commit is contained in:
147
app/promo/views.py
Normal file
147
app/promo/views.py
Normal file
@@ -0,0 +1,147 @@
|
||||
from flask import request, jsonify
|
||||
import decimal
|
||||
from datetime import datetime
|
||||
from app.promo import promo
|
||||
from app import db
|
||||
from app.classes.promo import Promo_Promo, Promo_Promo_schema
|
||||
|
||||
|
||||
|
||||
@promo.route("/<int:promo_id>", methods=["GET"])
|
||||
def get_promo(promo_id):
|
||||
"""
|
||||
"""
|
||||
get_promo_data = (db.session
|
||||
.query(Promo_Promo)
|
||||
.filter(Promo_Promo.id == promo_id)
|
||||
.first())
|
||||
query_schema = Promo_Promo_schema(many=False)
|
||||
return jsonify(query_schema.dump(get_promo_data))
|
||||
|
||||
|
||||
@promo.route("/all", methods=["GET"])
|
||||
def get_all_promo():
|
||||
"""
|
||||
"""
|
||||
get_promo_data = (db.session
|
||||
.query(Promo_Promo)
|
||||
.all())
|
||||
query_schema = Promo_Promo_schema(many=True)
|
||||
return jsonify(query_schema.dump(get_promo_data))
|
||||
|
||||
|
||||
@promo.route("/delete/<int:promo_id>", methods=["DELETE"])
|
||||
def delete_a_promo(promo_id):
|
||||
"""
|
||||
"""
|
||||
get_promo_data = (db.session
|
||||
.query(Promo_Promo)
|
||||
.first(Promo_Promo.id == promo_id)
|
||||
.first())
|
||||
|
||||
db.session.delete(get_promo_data)
|
||||
db.session.commit()
|
||||
|
||||
|
||||
return jsonify({
|
||||
"ok": True,
|
||||
}), 200
|
||||
|
||||
@promo.route("/create", methods=["POST"])
|
||||
def create_promo():
|
||||
"""
|
||||
"""
|
||||
date_created = datetime.utcnow()
|
||||
name_of_promotion = request.json["name_of_promotion"]
|
||||
money_off_delivery = request.json["money_off_delivery"]
|
||||
description = request.json["description"]
|
||||
text_on_ticket = request.json["text_on_ticket"]
|
||||
# see if it exists
|
||||
|
||||
new_promo = Promo_Promo(
|
||||
name_of_promotion = name_of_promotion,
|
||||
money_off_delivery = float(money_off_delivery),
|
||||
description = description,
|
||||
date_created = date_created,
|
||||
text_on_ticket=text_on_ticket
|
||||
)
|
||||
db.session.add(new_promo)
|
||||
db.session.commit()
|
||||
|
||||
|
||||
return jsonify({
|
||||
"ok": True,
|
||||
'promo_id':new_promo.id,
|
||||
}), 200
|
||||
|
||||
|
||||
@promo.route("/edit/<int:promo_id>", methods=["PUT"])
|
||||
def edit_promo(promo_id):
|
||||
"""
|
||||
|
||||
"""
|
||||
get_promo_data = (db.session
|
||||
.query(Promo_Promo)
|
||||
.filter(Promo_Promo.id == promo_id)
|
||||
.first())
|
||||
text_on_ticket = request.json["text_on_ticket"]
|
||||
name_of_promotion = request.json["name_of_promotion"]
|
||||
money_off_delivery = request.json["money_off_delivery"]
|
||||
description = request.json["description"]
|
||||
|
||||
get_promo_data.text_on_ticket = text_on_ticket
|
||||
get_promo_data.description = description
|
||||
get_promo_data.name_of_promotion = name_of_promotion
|
||||
get_promo_data.money_off_delivery = float(money_off_delivery)
|
||||
|
||||
db.session.add(get_promo_data)
|
||||
db.session.commit()
|
||||
|
||||
return jsonify({
|
||||
"ok": True,
|
||||
'promo_id':get_promo_data.id,
|
||||
}), 200
|
||||
|
||||
|
||||
|
||||
@promo.route("/on/<int:promo_id>", methods=["PATCH"])
|
||||
def turn_on_promo(promo_id):
|
||||
"""
|
||||
|
||||
"""
|
||||
get_promo_data = (db.session
|
||||
.query(Promo_Promo)
|
||||
.filter(Promo_Promo.id == promo_id)
|
||||
.first())
|
||||
|
||||
get_promo_data.active = True
|
||||
|
||||
|
||||
db.session.add(get_promo_data)
|
||||
db.session.commit()
|
||||
|
||||
return jsonify({
|
||||
"ok": True,
|
||||
'promo_id':get_promo_data.id,
|
||||
}), 200
|
||||
|
||||
@promo.route("/off/<int:promo_id>", methods=["PATCH"])
|
||||
def turn_off_promo(promo_id):
|
||||
"""
|
||||
|
||||
"""
|
||||
get_promo_data = (db.session
|
||||
.query(Promo_Promo)
|
||||
.filter(Promo_Promo.id == promo_id)
|
||||
.first())
|
||||
|
||||
get_promo_data.active = False
|
||||
|
||||
|
||||
db.session.add(get_promo_data)
|
||||
db.session.commit()
|
||||
|
||||
return jsonify({
|
||||
"ok": True,
|
||||
'promo_id':get_promo_data.id,
|
||||
}), 200
|
||||
Reference in New Issue
Block a user