small fixes
This commit is contained in:
		| @@ -25,6 +25,8 @@ class Query_StateList(db.Model): | |||||||
|     text = db.Column(db.VARCHAR(140)) |     text = db.Column(db.VARCHAR(140)) | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class Query_StateList_Schema(ma.SQLAlchemyAutoSchema): | class Query_StateList_Schema(ma.SQLAlchemyAutoSchema): | ||||||
|     class Meta: |     class Meta: | ||||||
|         model = Query_StateList |         model = Query_StateList | ||||||
| @@ -33,6 +35,22 @@ class Query_StateList_Schema(ma.SQLAlchemyAutoSchema): | |||||||
|     value = ma.auto_field() |     value = ma.auto_field() | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class Query_TownList(db.Model): | ||||||
|  |     __tablename__ = 'query_town_list' | ||||||
|  |     __table_args__ = {"schema": "public"} | ||||||
|  |     id = db.Column(db.Integer, primary_key=True, autoincrement=True) | ||||||
|  |     value = db.Column(db.INTEGER) | ||||||
|  |     text = db.Column(db.VARCHAR(140)) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class Query_TownList_Schema(ma.SQLAlchemyAutoSchema): | ||||||
|  |     class Meta: | ||||||
|  |         model = Query_TownList | ||||||
|  |     id = ma.auto_field() | ||||||
|  |     text = ma.auto_field() | ||||||
|  |     value = ma.auto_field() | ||||||
|  |  | ||||||
|  |  | ||||||
| class Query_CustomerTypeList(db.Model): | class Query_CustomerTypeList(db.Model): | ||||||
|     __tablename__ = 'query_customer_type_list' |     __tablename__ = 'query_customer_type_list' | ||||||
|     __table_args__ = {"schema": "public"} |     __table_args__ = {"schema": "public"} | ||||||
|   | |||||||
| @@ -183,21 +183,57 @@ def create_customer(): | |||||||
|         the_state = 'MA' |         the_state = 'MA' | ||||||
|     elif response_customer_state == 1: |     elif response_customer_state == 1: | ||||||
|         the_state = 'RI' |         the_state = 'RI' | ||||||
|     elif response_customer_state == 1: |     elif response_customer_state == 2: | ||||||
|         the_state = 'NH' |         the_state = 'NH' | ||||||
|     else: |     else: | ||||||
|         the_state = 'MA' |         the_state = 'MA' | ||||||
|  |  | ||||||
|  |     if response_customer_town == 0: | ||||||
|  |         the_town = 'Auburn' | ||||||
|  |     elif response_customer_state == 1: | ||||||
|  |         the_town = 'Charlton' | ||||||
|  |     elif response_customer_state == 2: | ||||||
|  |         the_town = 'Cherry Valley' | ||||||
|  |     elif response_customer_state == 3: | ||||||
|  |         the_town = 'Dudley' | ||||||
|  |     elif response_customer_state == 4: | ||||||
|  |         the_town = 'Grafton' | ||||||
|  |     elif response_customer_state == 5: | ||||||
|  |         the_town = 'Leicester' | ||||||
|  |     elif response_customer_state == 6: | ||||||
|  |         the_town = 'Millbury' | ||||||
|  |     elif response_customer_state == 7: | ||||||
|  |         the_town = 'N Oxford' | ||||||
|  |     elif response_customer_state == 8: | ||||||
|  |         the_town = 'Oxford' | ||||||
|  |     elif response_customer_state == 9: | ||||||
|  |         the_town = 'Rochdale' | ||||||
|  |     elif response_customer_state == 10: | ||||||
|  |         the_town = 'Shrewsbury' | ||||||
|  |     elif response_customer_state == 11: | ||||||
|  |         the_town = 'Southbridge' | ||||||
|  |     elif response_customer_state == 12: | ||||||
|  |         the_town = 'Spencer' | ||||||
|  |     elif response_customer_state == 13: | ||||||
|  |         the_town = 'Sturbridge' | ||||||
|  |     elif response_customer_state == 14: | ||||||
|  |         the_town = 'Webster' | ||||||
|  |     elif response_customer_state == 15: | ||||||
|  |         the_town = 'Worcester' | ||||||
|  |     else: | ||||||
|  |         the_town = 'NA' | ||||||
|  |  | ||||||
|  |  | ||||||
|     geolocator = Nominatim(user_agent="auburnoil") |     geolocator = Nominatim(user_agent="auburnoil") | ||||||
|     address_string = customer_address + ' ' + response_customer_town + the_state + response_customer_zip |     address_string = customer_address + ' ' + response_customer_town+ ' ' + the_state | ||||||
|     try: |     try: | ||||||
|         location = geolocator.geocode(address_string) |         location = geolocator.geocode(address_string) | ||||||
|         user_lat =location.latitude  |         user_lat =location.latitude  | ||||||
|         user_long = location.longitude |         user_long = location.longitude | ||||||
|         cor_ad = True |         cor_ad = True | ||||||
|     except: |     except: | ||||||
|         user_lat =location.latitude  |         user_lat =None | ||||||
|         user_long = location.longitude |         user_long = None | ||||||
|         cor_ad = False |         cor_ad = False | ||||||
|          |          | ||||||
|     new_customer = Customer_Customer( |     new_customer = Customer_Customer( | ||||||
| @@ -437,7 +473,10 @@ def customer_automatic_assignment(customer_id): | |||||||
|                 .filter(Card_Card.main_card == True) |                 .filter(Card_Card.main_card == True) | ||||||
|                 .first()) |                 .first()) | ||||||
|  |  | ||||||
|  |     get_customer_tank = (db.session | ||||||
|  |                     .query(Customer_Tank_Inspection) | ||||||
|  |                     .filter(Customer_Tank_Inspection.customer_id == customer_id) | ||||||
|  |                     .first()) | ||||||
|     if get_customer.customer_automatic == 1: |     if get_customer.customer_automatic == 1: | ||||||
|         # customer becomes will call |         # customer becomes will call | ||||||
|         get_customer.customer_automatic = 0 |         get_customer.customer_automatic = 0 | ||||||
| @@ -458,7 +497,7 @@ def customer_automatic_assignment(customer_id): | |||||||
|      |      | ||||||
|         # customer becames an automatic    |         # customer becames an automatic    | ||||||
|         if get_auto is None: |         if get_auto is None: | ||||||
|             create_auto = Auto_Delivery(customer_id = customer_id, |             create_auto = Auto_Delivery(customer_id=customer_id, | ||||||
|                                         customer_full_name =get_customer.customer_first_name + ' ' + get_customer.customer_last_name, |                                         customer_full_name =get_customer.customer_first_name + ' ' + get_customer.customer_last_name, | ||||||
|                                         account_number=get_customer.account_number, |                                         account_number=get_customer.account_number, | ||||||
|                                         customer_town=get_customer.customer_town, |                                         customer_town=get_customer.customer_town, | ||||||
| @@ -470,13 +509,15 @@ def customer_automatic_assignment(customer_id): | |||||||
|                                         estimated_gallons_left = 0, |                                         estimated_gallons_left = 0, | ||||||
|                                         estimated_gallons_left_prev_day = 0, |                                         estimated_gallons_left_prev_day = 0, | ||||||
|                                         tank_height = 0, |                                         tank_height = 0, | ||||||
|                                         tank_size =275, |                                         tank_size = get_customer_tank.tank_size, | ||||||
|                                         house_factor = 1, |                                         house_factor = 1, | ||||||
|                                         auto_status=1, |                                         auto_status=1, | ||||||
|                                         days_since_last_fill=0 |                                         days_since_last_fill=0 | ||||||
|              |  | ||||||
|                                         ) |                                         ) | ||||||
|  |              | ||||||
|             db.session.add(create_auto) |             db.session.add(create_auto) | ||||||
|  |  | ||||||
|  |  | ||||||
|         get_customer.customer_automatic = 1 |         get_customer.customer_automatic = 1 | ||||||
|         db.session.add(get_customer) |         db.session.add(get_customer) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -489,8 +489,13 @@ def edit_a_delivery(delivery_id): | |||||||
|         .filter(Customer_Customer.id == get_delivery.customer_id) \ |         .filter(Customer_Customer.id == get_delivery.customer_id) \ | ||||||
|         .first() |         .first() | ||||||
|  |  | ||||||
|  |     get_today_price = db.session\ | ||||||
|  |         .query(Pricing_Oil_Oil)\ | ||||||
|  |         .order_by(Pricing_Oil_Oil.id.desc())\ | ||||||
|  |         .first()  | ||||||
|  |  | ||||||
|     if not get_delivery: |     if not get_delivery: | ||||||
|         return jsonify({"ok": False}), 200 |         return jsonify({"error": False}), 200 | ||||||
|     else: |     else: | ||||||
|         gallons_ordered = request.json["gallons_ordered"] |         gallons_ordered = request.json["gallons_ordered"] | ||||||
|         delivery_status = request.json["delivery_status"] |         delivery_status = request.json["delivery_status"] | ||||||
| @@ -499,6 +504,7 @@ def edit_a_delivery(delivery_id): | |||||||
|         customer_wants_fill = request.json["customer_asked_for_fill"] |         customer_wants_fill = request.json["customer_asked_for_fill"] | ||||||
|         card_payment = request.json["credit"] |         card_payment = request.json["credit"] | ||||||
|         cash_payment = request.json["cash"] |         cash_payment = request.json["cash"] | ||||||
|  |         emergency_info = request.json["emergency"] | ||||||
|         dispatcher_notes = request.json["dispatcher_notes_taken"] |         dispatcher_notes = request.json["dispatcher_notes_taken"] | ||||||
|  |  | ||||||
|         delivery_driver_id = request.json["driver_employee_id"] |         delivery_driver_id = request.json["driver_employee_id"] | ||||||
| @@ -561,6 +567,7 @@ def edit_a_delivery(delivery_id): | |||||||
|  |  | ||||||
|         if customer_wants_fill is True: |         if customer_wants_fill is True: | ||||||
|             customer_wants_fill = 1 |             customer_wants_fill = 1 | ||||||
|  |             gallons_ordered = 250 | ||||||
|         else: |         else: | ||||||
|             customer_wants_fill = 0 |             customer_wants_fill = 0 | ||||||
|  |  | ||||||
| @@ -570,13 +577,42 @@ def edit_a_delivery(delivery_id): | |||||||
|         else: |         else: | ||||||
|             same_day_info = 0 |             same_day_info = 0 | ||||||
|  |  | ||||||
|  |         if emergency_info is True: | ||||||
|  |             emergency_asked = 1 | ||||||
|  |         else: | ||||||
|  |             emergency_asked = 0 | ||||||
|  |  | ||||||
|         prime_info = request.json["prime"] |         prime_info = request.json["prime"] | ||||||
|         if prime_info is True: |         if prime_info is True: | ||||||
|             prime_info = 1 |             prime_info = 1 | ||||||
|         else: |         else: | ||||||
|             prime_info = 0 |             prime_info = 0 | ||||||
|  |  | ||||||
|         dispatcher_notes |         # Pricing | ||||||
|  |          | ||||||
|  |         if customer_wants_fill == 1: | ||||||
|  |             # Fill | ||||||
|  |             precharge_amount = (250 * get_today_price.price_for_customer) | ||||||
|  |         else: | ||||||
|  |             # Gallons | ||||||
|  |             precharge_amount = int(gallons_ordered) * get_today_price.price_for_customer | ||||||
|  |  | ||||||
|  |  | ||||||
|  |         # if prime/emergency/sameday | ||||||
|  |         if same_day_info == 1 and prime_info == 0: | ||||||
|  |             total_precharge_amount = precharge_amount + get_today_price.price_same_day | ||||||
|  |  | ||||||
|  |         elif prime_info == 1 and same_day_info == 0: | ||||||
|  |             total_precharge_amount = precharge_amount + get_today_price.price_prime | ||||||
|  |  | ||||||
|  |         elif emergency_asked == 1: | ||||||
|  |             total_precharge_amount = precharge_amount + get_today_price.price_emergency | ||||||
|  |  | ||||||
|  |         else: | ||||||
|  |             total_precharge_amount = precharge_amount + get_today_price.price_prime + get_today_price.price_same_day | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     | ||||||
|         get_delivery.dispatcher_notes = dispatcher_notes |         get_delivery.dispatcher_notes = dispatcher_notes | ||||||
|         get_delivery.delivery_status = delivery_status |         get_delivery.delivery_status = delivery_status | ||||||
|         get_delivery.gallons_ordered = gallons_ordered |         get_delivery.gallons_ordered = gallons_ordered | ||||||
| @@ -591,8 +627,11 @@ def edit_a_delivery(delivery_id): | |||||||
|         get_delivery.driver_last_name = get_driver.employee_last_name |         get_delivery.driver_last_name = get_driver.employee_last_name | ||||||
|         get_delivery.driver_first_name = get_driver.employee_first_name |         get_delivery.driver_first_name = get_driver.employee_first_name | ||||||
|         get_delivery.driver_employee_id = get_driver.id |         get_delivery.driver_employee_id = get_driver.id | ||||||
|         get_delivery.promo_id =promo_id_get_delivery |         get_delivery.promo_id = promo_id_get_delivery | ||||||
|         get_delivery.promo_money_discount = promo_money_discount_get_delivery |         get_delivery.promo_money_discount = promo_money_discount_get_delivery | ||||||
|  |  | ||||||
|  |         get_delivery.pre_charge_amount = total_precharge_amount | ||||||
|  |         get_delivery.total_price = precharge_amount | ||||||
|       |       | ||||||
|         db.session.add(get_delivery) |         db.session.add(get_delivery) | ||||||
|         db.session.commit() |         db.session.commit() | ||||||
| @@ -711,6 +750,7 @@ def create_a_delivery(user_id): | |||||||
|             gallons_ordered = 250 |             gallons_ordered = 250 | ||||||
|         else: |         else: | ||||||
|             customer_fill_up = 0 |             customer_fill_up = 0 | ||||||
|  |             gallons_ordered = request.json["gallons_ordered"] | ||||||
|  |  | ||||||
|         if emergency_info is True: |         if emergency_info is True: | ||||||
|             emergency_asked = 1 |             emergency_asked = 1 | ||||||
| @@ -731,6 +771,7 @@ def create_a_delivery(user_id): | |||||||
|         customer_filled_name = get_customer.customer_first_name + ' ' + get_customer.customer_last_name |         customer_filled_name = get_customer.customer_first_name + ' ' + get_customer.customer_last_name | ||||||
|         now = datetime.utcnow() |         now = datetime.utcnow() | ||||||
|          |          | ||||||
|  |  | ||||||
|         # Pricing |         # Pricing | ||||||
|          |          | ||||||
|         if customer_fill_up == 1: |         if customer_fill_up == 1: | ||||||
| @@ -788,9 +829,8 @@ def create_a_delivery(user_id): | |||||||
|             driver_last_name=driver_l_name, |             driver_last_name=driver_l_name, | ||||||
|             driver_first_name=driver_f_name, |             driver_first_name=driver_f_name, | ||||||
|             driver_employee_id=driver_emp_id, |             driver_employee_id=driver_emp_id, | ||||||
|  |             promo_id=promo_id_get_delivery, | ||||||
|             promo_id =promo_id_get_delivery, |             promo_money_discount=promo_money_discount_get_delivery | ||||||
|             promo_money_discount = promo_money_discount_get_delivery |  | ||||||
|  |  | ||||||
|         ) |         ) | ||||||
|          |          | ||||||
|   | |||||||
| @@ -3,9 +3,21 @@ import decimal | |||||||
| from datetime import datetime | from datetime import datetime | ||||||
| from app.promo import promo | from app.promo import promo | ||||||
| from app import db | from app import db | ||||||
| from app.classes.promo import Promo_Promo, Promo_Promo_schema | from app.classes.promo import ( | ||||||
|  |     Promo_Promo, | ||||||
|  |     Promo_Promo_schema) | ||||||
|  | from app.classes.delivery import (Delivery_Delivery, | ||||||
|  |                                   Delivery_Delivery_schema, | ||||||
|  |                                   Delivery_Notes_Driver, | ||||||
|  |                                   ) | ||||||
|  |  | ||||||
|  | def convert_to_decimal(text): | ||||||
|  |     try: | ||||||
|  |         number = float(text) | ||||||
|  |         return round(number, 2) | ||||||
|  |     except ValueError: | ||||||
|  |         return "0" | ||||||
|  |      | ||||||
|  |  | ||||||
| @promo.route("/<int:promo_id>", methods=["GET"]) | @promo.route("/<int:promo_id>", methods=["GET"]) | ||||||
| def get_promo(promo_id): | def get_promo(promo_id): | ||||||
| @@ -19,6 +31,24 @@ def get_promo(promo_id): | |||||||
|     return jsonify(query_schema.dump(get_promo_data)) |     return jsonify(query_schema.dump(get_promo_data)) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @promo.route("/promoprice/<int:delivery_id>", methods=["GET"]) | ||||||
|  | def get_promo_price(delivery_id): | ||||||
|  |     """ | ||||||
|  |     """ | ||||||
|  |     get_delivery = (db.session | ||||||
|  |         .query(Delivery_Delivery) | ||||||
|  |         .filter(Delivery_Delivery.id == delivery_id) | ||||||
|  |         .first()) | ||||||
|  |  | ||||||
|  |     price = get_delivery.customer_price - get_delivery.promo_money_discount | ||||||
|  |     price = convert_to_decimal(price) | ||||||
|  |     return jsonify({ | ||||||
|  |         "ok": True, | ||||||
|  |         "price": price, | ||||||
|  |     }), 200 | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @promo.route("/all", methods=["GET"]) | @promo.route("/all", methods=["GET"]) | ||||||
| def get_all_promo(): | def get_all_promo(): | ||||||
|     """ |     """ | ||||||
| @@ -58,9 +88,11 @@ def create_promo(): | |||||||
|     text_on_ticket = request.json["text_on_ticket"] |     text_on_ticket = request.json["text_on_ticket"] | ||||||
|     # see if it exists |     # see if it exists | ||||||
|  |  | ||||||
|  |     amount_off = convert_to_decimal(money_off_delivery) | ||||||
|  |  | ||||||
|     new_promo = Promo_Promo( |     new_promo = Promo_Promo( | ||||||
|         name_of_promotion = name_of_promotion, |         name_of_promotion = name_of_promotion, | ||||||
|         money_off_delivery = float(money_off_delivery), |         money_off_delivery = amount_off, | ||||||
|         description = description, |         description = description, | ||||||
|         date_created = date_created,  |         date_created = date_created,  | ||||||
|         text_on_ticket=text_on_ticket |         text_on_ticket=text_on_ticket | ||||||
| @@ -89,10 +121,13 @@ def edit_promo(promo_id): | |||||||
|     money_off_delivery = request.json["money_off_delivery"] |     money_off_delivery = request.json["money_off_delivery"] | ||||||
|     description = request.json["description"] |     description = request.json["description"] | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     amount_off = convert_to_decimal(money_off_delivery) | ||||||
|  |  | ||||||
|     get_promo_data.text_on_ticket = text_on_ticket |     get_promo_data.text_on_ticket = text_on_ticket | ||||||
|     get_promo_data.description = description |     get_promo_data.description = description | ||||||
|     get_promo_data.name_of_promotion = name_of_promotion |     get_promo_data.name_of_promotion = name_of_promotion | ||||||
|     get_promo_data.money_off_delivery = float(money_off_delivery) |     get_promo_data.money_off_delivery = amount_off | ||||||
|  |  | ||||||
|     db.session.add(get_promo_data) |     db.session.add(get_promo_data) | ||||||
|     db.session.commit() |     db.session.commit() | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user