Updated forms and search
This commit is contained in:
		| @@ -1,4 +1,4 @@ | |||||||
| from sqlalchemy import Column, Integer, String, Float, DateTime | from sqlalchemy import Column, Integer, String, Numeric, DateTime | ||||||
| from app import db | from app import db | ||||||
| import datetime | import datetime | ||||||
|  |  | ||||||
| @@ -7,8 +7,8 @@ class Transaction(db.Model): | |||||||
|     __tablename__ = "transactions" |     __tablename__ = "transactions" | ||||||
|  |  | ||||||
|     id = Column(Integer, primary_key=True, index=True) |     id = Column(Integer, primary_key=True, index=True) | ||||||
|     preauthorize_amount = Column(Float, nullable=True)  # Amount preauthorized (for auth transactions) |     preauthorize_amount = Column(Numeric(10, 2), nullable=True)  # Amount preauthorized (for auth transactions) | ||||||
|     charge_amount = Column(Float, nullable=True)  # Final charge amount (for charge/capture transactions) |     charge_amount = Column(Numeric(10, 2), nullable=True)  # Final charge amount (for charge/capture transactions) | ||||||
|     transaction_type = Column(Integer)  # 0 = charge, 1 = auth, 3 = capture |     transaction_type = Column(Integer)  # 0 = charge, 1 = auth, 3 = capture | ||||||
|     status = Column(Integer)  # 0 = approved, 1 = declined |     status = Column(Integer)  # 0 = approved, 1 = declined | ||||||
|     auth_net_transaction_id = Column(String, unique=True, index=True, nullable=True) |     auth_net_transaction_id = Column(String, unique=True, index=True, nullable=True) | ||||||
|   | |||||||
| @@ -365,7 +365,7 @@ def get_deliveries_finalized(page): | |||||||
|     deliveries = (db.session  |     deliveries = (db.session  | ||||||
|         .query(Delivery_Delivery)  |         .query(Delivery_Delivery)  | ||||||
|         .filter(Delivery_Delivery.delivery_status == 10)  |         .filter(Delivery_Delivery.delivery_status == 10)  | ||||||
|         .order_by(Delivery_Delivery.when_ordered.desc())  |         .order_by(Delivery_Delivery.id.desc())  | ||||||
|         .limit(per_page_amount).offset(offset_limit)) |         .limit(per_page_amount).offset(offset_limit)) | ||||||
|  |  | ||||||
|     customer_schema = Delivery_Delivery_schema(many=True) |     customer_schema = Delivery_Delivery_schema(many=True) | ||||||
|   | |||||||
| @@ -105,23 +105,12 @@ def office_finalize_delivery(delivery_id): | |||||||
|                  .filter(Stats_Employee_Oil.employee_id == get_delivery.driver_employee_id) |                  .filter(Stats_Employee_Oil.employee_id == get_delivery.driver_employee_id) | ||||||
|                  .first()) |                  .first()) | ||||||
|  |  | ||||||
|  |  | ||||||
|   |  | ||||||
|     customer_filled = request.json["customer_filled"] |  | ||||||
|     if customer_filled is True: |  | ||||||
|         customer_filled = 1 |  | ||||||
|     else: |  | ||||||
|         customer_filled = 0 |  | ||||||
|  |  | ||||||
|          |  | ||||||
|  |  | ||||||
|     if request.json["cash_recieved"]: |     if request.json["cash_recieved"]: | ||||||
|         cash_amount = request.json["cash_recieved"] |         cash_amount = request.json["cash_recieved"] | ||||||
|     else: |     else: | ||||||
|         cash_amount = None |         cash_amount = None | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     gallons_delivered = request.json["gallons_delivered"] |     gallons_delivered = request.json["gallons_delivered"] | ||||||
|     check_number = request.json["check_number"] |     check_number = request.json["check_number"] | ||||||
|     fill_location = request.json["fill_location"] |     fill_location = request.json["fill_location"] | ||||||
| @@ -171,5 +160,3 @@ def office_finalize_delivery(delivery_id): | |||||||
|             'id': get_delivery.id, |             'id': get_delivery.id, | ||||||
|         }, |         }, | ||||||
|     }), 200 |     }), 200 | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -11,13 +11,56 @@ from sqlalchemy import or_, and_ | |||||||
| def search_customers(): | def search_customers(): | ||||||
|     """ |     """ | ||||||
|     Searches for customers based on a keyword. |     Searches for customers based on a keyword. | ||||||
|     The new logic searches across multiple fields (name, address, town, phone, etc.) |     Supports special prefixes: @ for last name, ! for address, # for phone, $ for account. | ||||||
|     for each word provided in the search query. |     Otherwise searches across multiple fields for each word provided in the search query. | ||||||
|     """ |     """ | ||||||
|     keyword = request.args.get('q') |     keyword = request.args.get('q') | ||||||
|     if not keyword or len(keyword) < 2: |     if not keyword or len(keyword) < 2: | ||||||
|         return jsonify([]) |         return jsonify([]) | ||||||
|  |  | ||||||
|  |     # Check for special search prefixes | ||||||
|  |     search_type = None | ||||||
|  |     if keyword[0] in '!@#$': | ||||||
|  |         search_type = keyword[0] | ||||||
|  |         keyword = keyword[1:]  # remove the prefix for the search term | ||||||
|  |  | ||||||
|  |     if search_type: | ||||||
|  |         search_pattern = f"%{keyword}%" | ||||||
|  |         if search_type == '@': | ||||||
|  |             customer_list = (db.session | ||||||
|  |                              .query(Customer_Customer) | ||||||
|  |                              .filter(Customer_Customer.customer_last_name.ilike(search_pattern)) | ||||||
|  |                              .order_by(Customer_Customer.customer_last_name.asc()) | ||||||
|  |                              .limit(20) | ||||||
|  |                              .all()) | ||||||
|  |         elif search_type == '!': | ||||||
|  |             customer_list = (db.session | ||||||
|  |                              .query(Customer_Customer) | ||||||
|  |                              .filter(Customer_Customer.customer_address.ilike(search_pattern)) | ||||||
|  |                              .order_by(Customer_Customer.customer_last_name.asc()) | ||||||
|  |                              .limit(20) | ||||||
|  |                              .all()) | ||||||
|  |         elif search_type == '#': | ||||||
|  |             customer_list = (db.session | ||||||
|  |                              .query(Customer_Customer) | ||||||
|  |                              .filter(Customer_Customer.customer_phone_number.ilike(search_pattern)) | ||||||
|  |                              .order_by(Customer_Customer.customer_last_name.asc()) | ||||||
|  |                              .limit(20) | ||||||
|  |                              .all()) | ||||||
|  |         elif search_type == '$': | ||||||
|  |             customer_list = (db.session | ||||||
|  |                              .query(Customer_Customer) | ||||||
|  |                              .filter(Customer_Customer.account_number.ilike(search_pattern)) | ||||||
|  |                              .order_by(Customer_Customer.account_number.asc()) | ||||||
|  |                              .limit(20) | ||||||
|  |                              .all()) | ||||||
|  |         else: | ||||||
|  |             # fallback, though shouldn't happen | ||||||
|  |             return jsonify([]) | ||||||
|  |  | ||||||
|  |         customer_schema = Customer_Customer_schema(many=True) | ||||||
|  |         return jsonify(customer_schema.dump(customer_list)) | ||||||
|  |  | ||||||
|     # --- NEW SEARCH LOGIC --- |     # --- NEW SEARCH LOGIC --- | ||||||
|      |      | ||||||
|     # 1. Split the incoming search query into individual words. |     # 1. Split the incoming search query into individual words. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user