2025-12-11 17:58:56 +05:30
|
|
|
from app import db
|
|
|
|
|
from datetime import datetime
|
|
|
|
|
|
|
|
|
|
class ManholeExcavation(db.Model):
|
|
|
|
|
__tablename__ = "manhole_excavation"
|
|
|
|
|
|
|
|
|
|
id = db.Column(db.Integer, primary_key=True)
|
|
|
|
|
# Foreign Key to Subcontractor table
|
|
|
|
|
subcontractor_id = db.Column(db.Integer, db.ForeignKey("subcontractors.id"), nullable=False)
|
|
|
|
|
# Relationship for easy access (subcontractor.subcontractor_name)
|
|
|
|
|
subcontractor = db.relationship("Subcontractor", backref="manhole_records")
|
|
|
|
|
|
|
|
|
|
# Basic Fields
|
2025-12-20 16:35:35 +05:30
|
|
|
Location = db.Column(db.String(500))
|
2025-12-11 17:58:56 +05:30
|
|
|
MH_NO = db.Column(db.String(100))
|
|
|
|
|
|
|
|
|
|
Upto_IL_Depth = db.Column(db.Float)
|
|
|
|
|
Cutting_Depth = db.Column(db.Float)
|
|
|
|
|
ID_of_MH_m = db.Column(db.Float)
|
|
|
|
|
Ex_Dia_of_Manhole = db.Column(db.Float)
|
|
|
|
|
Area_of_Manhole = db.Column(db.Float)
|
|
|
|
|
|
|
|
|
|
# Excavation categories
|
|
|
|
|
Soft_Murum_0_to_1_5 = db.Column(db.Float)
|
|
|
|
|
Soft_Murum_1_5_to_3_0 = db.Column(db.Float)
|
|
|
|
|
Soft_Murum_3_0_to_4_5 = db.Column(db.Float)
|
|
|
|
|
|
|
|
|
|
Hard_Murum_0_to_1_5 = db.Column(db.Float)
|
|
|
|
|
Hard_Murum_1_5_to_3_0 = db.Column(db.Float)
|
|
|
|
|
|
|
|
|
|
Soft_Rock_0_to_1_5 = db.Column(db.Float)
|
|
|
|
|
Soft_Rock_1_5_to_3_0 = db.Column(db.Float)
|
|
|
|
|
|
|
|
|
|
Hard_Rock_0_to_1_5 = db.Column(db.Float)
|
|
|
|
|
Hard_Rock_1_5_to_3_0 = db.Column(db.Float)
|
|
|
|
|
Hard_Rock_3_0_to_4_5 = db.Column(db.Float)
|
|
|
|
|
Hard_Rock_4_5_to_6_0 = db.Column(db.Float)
|
|
|
|
|
Hard_Rock_6_0_to_7_5 = db.Column(db.Float)
|
|
|
|
|
|
|
|
|
|
# Totals
|
|
|
|
|
Soft_Murum_0_to_1_5_total = db.Column(db.Float)
|
|
|
|
|
Soft_Murum_1_5_to_3_0_total = db.Column(db.Float)
|
|
|
|
|
Soft_Murum_3_0_to_4_5_total = db.Column(db.Float)
|
|
|
|
|
|
|
|
|
|
Hard_Murum_0_to_1_5_total = db.Column(db.Float)
|
|
|
|
|
Hard_Murum_1_5_and_above_total = db.Column(db.Float)
|
|
|
|
|
|
|
|
|
|
Soft_Rock_0_to_1_5_total = db.Column(db.Float)
|
|
|
|
|
Soft_Rock_1_5_and_above_total = db.Column(db.Float)
|
|
|
|
|
|
|
|
|
|
Hard_Rock_0_to_1_5_total = db.Column(db.Float)
|
2025-12-18 18:29:25 +05:30
|
|
|
Hard_Rock_1_5_to_3_0_total = db.Column(db.Float)
|
2025-12-11 17:58:56 +05:30
|
|
|
Hard_Rock_3_0_to_4_5_total = db.Column(db.Float)
|
|
|
|
|
Hard_Rock_4_5_to_6_0_total = db.Column(db.Float)
|
|
|
|
|
Hard_Rock_6_0_to_7_5_total = db.Column(db.Float)
|
|
|
|
|
|
|
|
|
|
Total = db.Column(db.Float)
|
2025-12-18 18:29:25 +05:30
|
|
|
Remarks = db.Column(db.String(500))
|
|
|
|
|
RA_Bill_No=db.Column(db.String(500))
|
2025-12-11 17:58:56 +05:30
|
|
|
|
2025-12-18 10:41:54 +05:30
|
|
|
created_at = db.Column(db.DateTime, default=datetime.today)
|
2025-12-11 17:58:56 +05:30
|
|
|
|
|
|
|
|
def __repr__(self):
|
|
|
|
|
return f"<HanholeExcavation {self.Location}>"
|
2026-01-09 15:22:32 +05:30
|
|
|
|
|
|
|
|
def serialize(self):
|
|
|
|
|
return {c.name: getattr(self, c.name) for c in self.__table__.columns}
|