From 8c49ccd07b365025399459278c499a78169952c7 Mon Sep 17 00:00:00 2001 From: "Sudarshan Maity (sumai)" Date: Tue, 10 Mar 2026 17:55:08 +0530 Subject: [PATCH 1/9] [ADD] Estate: Finished Chapters 2-3 Completed Initial Setup of Real Estate Module Created Basic Structure of Estate Module Created Estate Property Model Using ORM --- estate/__init__.py | 1 + estate/__manifest__.py | 5 +++++ estate/models/__init__.py | 1 + estate/models/estate_property.py | 38 ++++++++++++++++++++++++++++++++ 4 files changed, 45 insertions(+) create mode 100644 estate/__init__.py create mode 100644 estate/__manifest__.py create mode 100644 estate/models/__init__.py create mode 100644 estate/models/estate_property.py diff --git a/estate/__init__.py b/estate/__init__.py new file mode 100644 index 00000000000..9a7e03eded3 --- /dev/null +++ b/estate/__init__.py @@ -0,0 +1 @@ +from . import models \ No newline at end of file diff --git a/estate/__manifest__.py b/estate/__manifest__.py new file mode 100644 index 00000000000..001f9025b0f --- /dev/null +++ b/estate/__manifest__.py @@ -0,0 +1,5 @@ +{ + 'name': 'Real Estate', + 'depends': ['base'], + 'application': True, +} \ No newline at end of file diff --git a/estate/models/__init__.py b/estate/models/__init__.py new file mode 100644 index 00000000000..f4c8fd6db6d --- /dev/null +++ b/estate/models/__init__.py @@ -0,0 +1 @@ +from . import estate_property \ No newline at end of file diff --git a/estate/models/estate_property.py b/estate/models/estate_property.py new file mode 100644 index 00000000000..4e00e48f769 --- /dev/null +++ b/estate/models/estate_property.py @@ -0,0 +1,38 @@ +from odoo import models, fields + +class EstateProperty(models.Model): + _name = "estate.property" + _description = "Real Estate Property" + + name = fields.Char(string="Title", required=True) + description = fields.Text(string="Description") + postcode = fields.Char(string="Postcode") + date_availability = fields.Date(string="Available From") + expected_price = fields.Float(string="Expected Price", required=True) + selling_price = fields.Float(string="Selling Price") + bedrooms = fields.Integer(string="Bedrooms") + living_area = fields.Integer(string="Living Area (sqm)") + facades = fields.Integer(string="Facades") + garage = fields.Boolean(string="Garage") + garden = fields.Boolean(string="Garden") + garden_area = fields.Integer(string="Garden Area (sqm)") + garden_orientation = fields.Selection( + [ + ('north', 'North'), + ('south', 'South'), + ('east', 'East'), + ('west', 'West'), + ], + string="Garden Orientation" + ) + swimming_pool = fields.Boolean(string="Swimming Pool") #extra fields + property_type = fields.Selection( + [ + ('house', 'House'), + ('apartment', 'Apartment'), + ('villa', 'Villa'), + ('land', 'Land') + ], + string="Property Type" + ) + property_age = fields.Integer(string="Property Age") \ No newline at end of file From 97ba15a3df4b59aa8fb28a55268c3cc5474dac0e Mon Sep 17 00:00:00 2001 From: "Sudarshan Maity (sumai)" Date: Wed, 11 Mar 2026 17:13:22 +0530 Subject: [PATCH 2/9] [ADD] Estate: Finished Chapters 4 Solved Previous Issues Completed Chapter 4 Created Security File --- estate/__init__.py | 2 +- estate/__manifest__.py | 20 ++++++++++++++++++-- estate/models/__init__.py | 2 +- estate/models/estate_property.py | 5 +++-- estate/security/ir.model.access.csv | 2 ++ 5 files changed, 25 insertions(+), 6 deletions(-) create mode 100644 estate/security/ir.model.access.csv diff --git a/estate/__init__.py b/estate/__init__.py index 9a7e03eded3..0650744f6bc 100644 --- a/estate/__init__.py +++ b/estate/__init__.py @@ -1 +1 @@ -from . import models \ No newline at end of file +from . import models diff --git a/estate/__manifest__.py b/estate/__manifest__.py index 001f9025b0f..7ceef6ed6ea 100644 --- a/estate/__manifest__.py +++ b/estate/__manifest__.py @@ -1,5 +1,21 @@ { 'name': 'Real Estate', - 'depends': ['base'], + 'summary': 'Manage real estate properties and offers', + 'description': "This module allows managing property advertisements,including property details, offers, and related data.", + 'author': 'Sudarshan Maity (sumai)', + 'website': '', + 'category': 'Real Estate', + 'version': '1.0', + 'license': 'LGPL-3', + + 'depends': [ + 'base', + ], + + 'data': [ + 'security/ir.model.access.csv', + ], + + 'installable': True, 'application': True, -} \ No newline at end of file +} diff --git a/estate/models/__init__.py b/estate/models/__init__.py index f4c8fd6db6d..5e1963c9d2f 100644 --- a/estate/models/__init__.py +++ b/estate/models/__init__.py @@ -1 +1 @@ -from . import estate_property \ No newline at end of file +from . import estate_property diff --git a/estate/models/estate_property.py b/estate/models/estate_property.py index 4e00e48f769..1747557d1a5 100644 --- a/estate/models/estate_property.py +++ b/estate/models/estate_property.py @@ -1,5 +1,6 @@ from odoo import models, fields + class EstateProperty(models.Model): _name = "estate.property" _description = "Real Estate Property" @@ -25,7 +26,7 @@ class EstateProperty(models.Model): ], string="Garden Orientation" ) - swimming_pool = fields.Boolean(string="Swimming Pool") #extra fields + swimming_pool = fields.Boolean(string="Swimming Pool") # extra fields property_type = fields.Selection( [ ('house', 'House'), @@ -35,4 +36,4 @@ class EstateProperty(models.Model): ], string="Property Type" ) - property_age = fields.Integer(string="Property Age") \ No newline at end of file + property_age = fields.Integer(string="Property Age") diff --git a/estate/security/ir.model.access.csv b/estate/security/ir.model.access.csv new file mode 100644 index 00000000000..32389642d4f --- /dev/null +++ b/estate/security/ir.model.access.csv @@ -0,0 +1,2 @@ +id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink +access_estate_property,access_estate_property,model_estate_property,base.group_user,1,1,1,1 From 1fe4ef919deb1dde04653ab44065f346c84dedf9 Mon Sep 17 00:00:00 2001 From: "Sudarshan Maity (sumai)" Date: Thu, 12 Mar 2026 18:26:06 +0530 Subject: [PATCH 3/9] [IMP] Estate: Chapter 5 - Ongoing Solved Exercise 1 & 2 Created Views Folder Learnt about Menu, Submenu & Actions --- estate/__manifest__.py | 2 ++ estate/models/estate_property.py | 16 ++++++++-------- estate/views/estate_menus.xml | 24 ++++++++++++++++++++++++ estate/views/estate_property_views.xml | 9 +++++++++ 4 files changed, 43 insertions(+), 8 deletions(-) create mode 100644 estate/views/estate_menus.xml create mode 100644 estate/views/estate_property_views.xml diff --git a/estate/__manifest__.py b/estate/__manifest__.py index 7ceef6ed6ea..8384cb09833 100644 --- a/estate/__manifest__.py +++ b/estate/__manifest__.py @@ -14,6 +14,8 @@ 'data': [ 'security/ir.model.access.csv', + 'views/estate_property_views.xml', + 'views/estate_menus.xml', ], 'installable': True, diff --git a/estate/models/estate_property.py b/estate/models/estate_property.py index 1747557d1a5..8ac093a0e71 100644 --- a/estate/models/estate_property.py +++ b/estate/models/estate_property.py @@ -19,20 +19,20 @@ class EstateProperty(models.Model): garden_area = fields.Integer(string="Garden Area (sqm)") garden_orientation = fields.Selection( [ - ('north', 'North'), - ('south', 'South'), - ('east', 'East'), - ('west', 'West'), + ('north', "North"), + ('south', "South"), + ('east', "East"), + ('west', "West"), ], string="Garden Orientation" ) swimming_pool = fields.Boolean(string="Swimming Pool") # extra fields property_type = fields.Selection( [ - ('house', 'House'), - ('apartment', 'Apartment'), - ('villa', 'Villa'), - ('land', 'Land') + ('house', "House"), + ('apartment', "Apartment"), + ('villa', "Villa"), + ('land', "Land") ], string="Property Type" ) diff --git a/estate/views/estate_menus.xml b/estate/views/estate_menus.xml new file mode 100644 index 00000000000..731ecce79e6 --- /dev/null +++ b/estate/views/estate_menus.xml @@ -0,0 +1,24 @@ + + + + + + + + + + + + diff --git a/estate/views/estate_property_views.xml b/estate/views/estate_property_views.xml new file mode 100644 index 00000000000..d9db99a4f30 --- /dev/null +++ b/estate/views/estate_property_views.xml @@ -0,0 +1,9 @@ + + + + Properties + estate.property + list,form + + + From fe44d9a54afdd8fa46840a553307c70cd8399922 Mon Sep 17 00:00:00 2001 From: "Sudarshan Maity (sumai)" Date: Fri, 13 Mar 2026 18:54:54 +0530 Subject: [PATCH 4/9] [IMP] Estate: Chapter 5 - Completed Solved Remaining Exercise Added active field - added its default value Added State field and its required parameters --- estate/models/estate_property.py | 20 ++++++++++++++++---- estate/views/estate_property_views.xml | 2 +- 2 files changed, 17 insertions(+), 5 deletions(-) diff --git a/estate/models/estate_property.py b/estate/models/estate_property.py index 8ac093a0e71..617f116548a 100644 --- a/estate/models/estate_property.py +++ b/estate/models/estate_property.py @@ -1,3 +1,5 @@ +from datetime import timedelta + from odoo import models, fields @@ -8,10 +10,10 @@ class EstateProperty(models.Model): name = fields.Char(string="Title", required=True) description = fields.Text(string="Description") postcode = fields.Char(string="Postcode") - date_availability = fields.Date(string="Available From") + date_availability = fields.Date(string="Available From", copy=False, default=lambda self: fields.Date.today() + timedelta(days=90)) expected_price = fields.Float(string="Expected Price", required=True) - selling_price = fields.Float(string="Selling Price") - bedrooms = fields.Integer(string="Bedrooms") + selling_price = fields.Float(string="Selling Price", readonly=True, copy=False) + bedrooms = fields.Integer(string="Bedrooms", default=2) living_area = fields.Integer(string="Living Area (sqm)") facades = fields.Integer(string="Facades") garage = fields.Boolean(string="Garage") @@ -26,6 +28,16 @@ class EstateProperty(models.Model): ], string="Garden Orientation" ) + active = fields.Boolean(string="is Active", default=True) + state = fields.Selection( + [ + ('new', "New"), + ('offer_received', "Offer Received"), + ('offer_accepted', "Offer Accepted"), + ('sold', "Sold"), + ('cancelled', "Cancelled") + ], + string="Status", required=True, copy=False, default="new") swimming_pool = fields.Boolean(string="Swimming Pool") # extra fields property_type = fields.Selection( [ @@ -35,5 +47,5 @@ class EstateProperty(models.Model): ('land', "Land") ], string="Property Type" - ) + ) property_age = fields.Integer(string="Property Age") diff --git a/estate/views/estate_property_views.xml b/estate/views/estate_property_views.xml index d9db99a4f30..62bdc649135 100644 --- a/estate/views/estate_property_views.xml +++ b/estate/views/estate_property_views.xml @@ -3,7 +3,7 @@ Properties estate.property - list,form + kanban,list,form From 8ae1a0b51e771fd2fcef8d820d579a3a7e2f47af Mon Sep 17 00:00:00 2001 From: "Sudarshan Maity (sumai)" Date: Mon, 16 Mar 2026 18:49:02 +0530 Subject: [PATCH 5/9] [IMP] Estate: Chapter 6- Ongoing Solved Exercise 1 & 2 Created List view of Record Created Form View of Record --- estate/models/estate_property.py | 6 +-- estate/views/estate_property_views.xml | 74 ++++++++++++++++++++++++++ 2 files changed, 77 insertions(+), 3 deletions(-) diff --git a/estate/models/estate_property.py b/estate/models/estate_property.py index 617f116548a..5c8779e0a1d 100644 --- a/estate/models/estate_property.py +++ b/estate/models/estate_property.py @@ -4,8 +4,8 @@ class EstateProperty(models.Model): - _name = "estate.property" - _description = "Real Estate Property" + _name = 'estate.property' + _description = 'Real Estate Property' name = fields.Char(string="Title", required=True) description = fields.Text(string="Description") @@ -14,7 +14,7 @@ class EstateProperty(models.Model): expected_price = fields.Float(string="Expected Price", required=True) selling_price = fields.Float(string="Selling Price", readonly=True, copy=False) bedrooms = fields.Integer(string="Bedrooms", default=2) - living_area = fields.Integer(string="Living Area (sqm)") + living_area = fields.Integer(string="Living Area (sqm)", copy=False) facades = fields.Integer(string="Facades") garage = fields.Boolean(string="Garage") garden = fields.Boolean(string="Garden") diff --git a/estate/views/estate_property_views.xml b/estate/views/estate_property_views.xml index 62bdc649135..8127a886335 100644 --- a/estate/views/estate_property_views.xml +++ b/estate/views/estate_property_views.xml @@ -6,4 +6,78 @@ kanban,list,form + + estate.property.list + estate.property + + + + + + + + + + + + + + + + + + estate.property.form + estate.property + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+ From dcf4d0c9254b603acc238feddb80428301af4f93 Mon Sep 17 00:00:00 2001 From: "Sudarshan Maity (sumai)" Date: Tue, 17 Mar 2026 18:41:31 +0530 Subject: [PATCH 6/9] [IMP] Estate: Chapter 6- Completed Solved Remaing Exercise Created Search view of Record Added Domain Filter & Group by Filter --- estate/__manifest__.py | 1 - estate/models/estate_property.py | 12 +++--- estate/views/estate_property_views.xml | 51 ++++++++++++++++++++++++++ 3 files changed, 57 insertions(+), 7 deletions(-) diff --git a/estate/__manifest__.py b/estate/__manifest__.py index 8384cb09833..b3bd20826e4 100644 --- a/estate/__manifest__.py +++ b/estate/__manifest__.py @@ -7,7 +7,6 @@ 'category': 'Real Estate', 'version': '1.0', 'license': 'LGPL-3', - 'depends': [ 'base', ], diff --git a/estate/models/estate_property.py b/estate/models/estate_property.py index 5c8779e0a1d..73c47d61808 100644 --- a/estate/models/estate_property.py +++ b/estate/models/estate_property.py @@ -8,16 +8,16 @@ class EstateProperty(models.Model): _description = 'Real Estate Property' name = fields.Char(string="Title", required=True) - description = fields.Text(string="Description") - postcode = fields.Char(string="Postcode") + description = fields.Text() + postcode = fields.Char() date_availability = fields.Date(string="Available From", copy=False, default=lambda self: fields.Date.today() + timedelta(days=90)) expected_price = fields.Float(string="Expected Price", required=True) selling_price = fields.Float(string="Selling Price", readonly=True, copy=False) bedrooms = fields.Integer(string="Bedrooms", default=2) living_area = fields.Integer(string="Living Area (sqm)", copy=False) - facades = fields.Integer(string="Facades") - garage = fields.Boolean(string="Garage") - garden = fields.Boolean(string="Garden") + facades = fields.Integer() + garage = fields.Boolean() + garden = fields.Boolean() garden_area = fields.Integer(string="Garden Area (sqm)") garden_orientation = fields.Selection( [ @@ -47,5 +47,5 @@ class EstateProperty(models.Model): ('land', "Land") ], string="Property Type" - ) + ) property_age = fields.Integer(string="Property Age") diff --git a/estate/views/estate_property_views.xml b/estate/views/estate_property_views.xml index 8127a886335..2ba4098fcbb 100644 --- a/estate/views/estate_property_views.xml +++ b/estate/views/estate_property_views.xml @@ -80,4 +80,55 @@ + + estate.property.search + estate.property + + + + + + + + + + + + + + + + + + + + estate.property.kanban + estate.property + + + + +
+ + + +
+ Expected Price: + +
+
+ Bedrooms: + +
+
+ Status: + +
+
+
+
+
+
+
+ From 49cfdfc6777a477223c0fc82691141d448334bcb Mon Sep 17 00:00:00 2001 From: "Sudarshan Maity (sumai)" Date: Wed, 18 Mar 2026 18:41:08 +0530 Subject: [PATCH 7/9] [IMP] Estate: Chapter 7- Started Solved Exercise 1 & 2 Created New Model Estate Property Type Added New Fields in Models, Views, Menus --- estate/__manifest__.py | 1 + estate/models/__init__.py | 1 + estate/models/estate_property.py | 21 +++++++------ estate/models/estate_property_type.py | 8 +++++ estate/security/ir.model.access.csv | 1 + estate/views/estate_menus.xml | 16 +++++++++- estate/views/estate_property_type_views.xml | 33 +++++++++++++++++++++ estate/views/estate_property_views.xml | 18 +++++++++-- 8 files changed, 87 insertions(+), 12 deletions(-) create mode 100644 estate/models/estate_property_type.py create mode 100644 estate/views/estate_property_type_views.xml diff --git a/estate/__manifest__.py b/estate/__manifest__.py index b3bd20826e4..a986f36fa62 100644 --- a/estate/__manifest__.py +++ b/estate/__manifest__.py @@ -14,6 +14,7 @@ 'data': [ 'security/ir.model.access.csv', 'views/estate_property_views.xml', + 'views/estate_property_type_views.xml', 'views/estate_menus.xml', ], diff --git a/estate/models/__init__.py b/estate/models/__init__.py index 5e1963c9d2f..40092a2d810 100644 --- a/estate/models/__init__.py +++ b/estate/models/__init__.py @@ -1 +1,2 @@ from . import estate_property +from . import estate_property_type diff --git a/estate/models/estate_property.py b/estate/models/estate_property.py index 73c47d61808..58865311be4 100644 --- a/estate/models/estate_property.py +++ b/estate/models/estate_property.py @@ -39,13 +39,16 @@ class EstateProperty(models.Model): ], string="Status", required=True, copy=False, default="new") swimming_pool = fields.Boolean(string="Swimming Pool") # extra fields - property_type = fields.Selection( - [ - ('house', "House"), - ('apartment', "Apartment"), - ('villa', "Villa"), - ('land', "Land") - ], - string="Property Type" - ) + # property_type = fields.Selection( + # [ + # ('house', "House"), + # ('apartment', "Apartment"), + # ('villa', "Villa"), + # ('land', "Land") + # ], + # string="Property Type" + # ) property_age = fields.Integer(string="Property Age") + property_type_id = fields.Many2one("estate.property.type", string="Property Type") + buyer_id = fields.Many2one("res.partner", string="Buyer", copy=False) + salesperson_id = fields.Many2one("res.users", string="Salesperson", default=lambda self: self.env.user) diff --git a/estate/models/estate_property_type.py b/estate/models/estate_property_type.py new file mode 100644 index 00000000000..517b2987d9e --- /dev/null +++ b/estate/models/estate_property_type.py @@ -0,0 +1,8 @@ +from odoo import models, fields + + +class EstatePropertyType(models.Model): + _name = 'estate.property.type' + _description = 'Real Estate Property Types' + + name = fields.Char(string="Type Name", required=True) diff --git a/estate/security/ir.model.access.csv b/estate/security/ir.model.access.csv index 32389642d4f..11da225066f 100644 --- a/estate/security/ir.model.access.csv +++ b/estate/security/ir.model.access.csv @@ -1,2 +1,3 @@ id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink access_estate_property,access_estate_property,model_estate_property,base.group_user,1,1,1,1 +access_estate_property_type,access_estate_property_type,model_estate_property_type,base.group_user,1,1,1,1 diff --git a/estate/views/estate_menus.xml b/estate/views/estate_menus.xml index 731ecce79e6..d58dd7fdabe 100644 --- a/estate/views/estate_menus.xml +++ b/estate/views/estate_menus.xml @@ -6,7 +6,7 @@ name="Real Estate" sequence="1"/> - + + + + + + diff --git a/estate/views/estate_property_type_views.xml b/estate/views/estate_property_type_views.xml new file mode 100644 index 00000000000..f7543e0b966 --- /dev/null +++ b/estate/views/estate_property_type_views.xml @@ -0,0 +1,33 @@ + + + + Porperty Types + estate.property.type + list,form + + + + estate.property.type.list + estate.property.type + + + + + + + + + + estate.property.type.form + estate.property.type + +
+ + + + + +
+
+
+
diff --git a/estate/views/estate_property_views.xml b/estate/views/estate_property_views.xml index 2ba4098fcbb..8b0b910220f 100644 --- a/estate/views/estate_property_views.xml +++ b/estate/views/estate_property_views.xml @@ -19,7 +19,7 @@ - + @@ -38,6 +38,7 @@ + @@ -66,7 +67,6 @@ - @@ -74,6 +74,16 @@ + + + + + + + + + + @@ -124,6 +134,10 @@ Status: +
+ Property Type: + +
From 49c7c2d90d8dd220e2450104957bbf6fe8e48ec5 Mon Sep 17 00:00:00 2001 From: "Sudarshan Maity (sumai)" Date: Thu, 19 Mar 2026 18:00:19 +0530 Subject: [PATCH 8/9] [IMP] Estate: Chapter 7- Ongoing Solved Exercise 3 Created New Model Estate Property Tags Many2many Added New Fields in Models, Views, Menus in it --- estate/__manifest__.py | 1 + estate/models/__init__.py | 1 + estate/models/estate_property.py | 1 + estate/models/estate_property_tag.py | 8 +++++ estate/security/ir.model.access.csv | 1 + estate/views/estate_menus.xml | 7 +++++ estate/views/estate_property_tag_views.xml | 33 +++++++++++++++++++++ estate/views/estate_property_type_views.xml | 1 + estate/views/estate_property_views.xml | 1 + 9 files changed, 54 insertions(+) create mode 100644 estate/models/estate_property_tag.py create mode 100644 estate/views/estate_property_tag_views.xml diff --git a/estate/__manifest__.py b/estate/__manifest__.py index a986f36fa62..6d6645f148d 100644 --- a/estate/__manifest__.py +++ b/estate/__manifest__.py @@ -15,6 +15,7 @@ 'security/ir.model.access.csv', 'views/estate_property_views.xml', 'views/estate_property_type_views.xml', + 'views/estate_property_tag_views.xml', 'views/estate_menus.xml', ], diff --git a/estate/models/__init__.py b/estate/models/__init__.py index 40092a2d810..c620ac481a3 100644 --- a/estate/models/__init__.py +++ b/estate/models/__init__.py @@ -1,2 +1,3 @@ from . import estate_property from . import estate_property_type +from . import estate_property_tag diff --git a/estate/models/estate_property.py b/estate/models/estate_property.py index 58865311be4..1703803903b 100644 --- a/estate/models/estate_property.py +++ b/estate/models/estate_property.py @@ -52,3 +52,4 @@ class EstateProperty(models.Model): property_type_id = fields.Many2one("estate.property.type", string="Property Type") buyer_id = fields.Many2one("res.partner", string="Buyer", copy=False) salesperson_id = fields.Many2one("res.users", string="Salesperson", default=lambda self: self.env.user) + tags_ids = fields.Many2many("estate.property.tag", string="Property Tags") diff --git a/estate/models/estate_property_tag.py b/estate/models/estate_property_tag.py new file mode 100644 index 00000000000..7c89cb2c6c7 --- /dev/null +++ b/estate/models/estate_property_tag.py @@ -0,0 +1,8 @@ +from odoo import models, fields + + +class EstatePropertyTag(models.Model): + _name = 'estate.property.tag' + _description = 'Estate Property Tag' + + name = fields.Char(string="Tags Name", required=True) diff --git a/estate/security/ir.model.access.csv b/estate/security/ir.model.access.csv index 11da225066f..1493eab4011 100644 --- a/estate/security/ir.model.access.csv +++ b/estate/security/ir.model.access.csv @@ -1,3 +1,4 @@ id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink access_estate_property,access_estate_property,model_estate_property,base.group_user,1,1,1,1 access_estate_property_type,access_estate_property_type,model_estate_property_type,base.group_user,1,1,1,1 +access_estate_property_tag,access_estate_property_tag,model_estate_property_tag,base.group_user,1,1,1,1 diff --git a/estate/views/estate_menus.xml b/estate/views/estate_menus.xml index d58dd7fdabe..c8959b0b216 100644 --- a/estate/views/estate_menus.xml +++ b/estate/views/estate_menus.xml @@ -35,4 +35,11 @@ action="action_estate_property_type" sequence="1"/> + + diff --git a/estate/views/estate_property_tag_views.xml b/estate/views/estate_property_tag_views.xml new file mode 100644 index 00000000000..ee6152bc41c --- /dev/null +++ b/estate/views/estate_property_tag_views.xml @@ -0,0 +1,33 @@ + + + + Property Tags + estate.property.tag + list,form + + + + estate.property.tag.list + estate.property.tag + + + + + + + + + estate.property.tag.form + estate.property.tag + +
+ + + + + +
+
+
+ +
\ No newline at end of file diff --git a/estate/views/estate_property_type_views.xml b/estate/views/estate_property_type_views.xml index f7543e0b966..829ba0a6b69 100644 --- a/estate/views/estate_property_type_views.xml +++ b/estate/views/estate_property_type_views.xml @@ -30,4 +30,5 @@
+ diff --git a/estate/views/estate_property_views.xml b/estate/views/estate_property_views.xml index 8b0b910220f..866ca274f55 100644 --- a/estate/views/estate_property_views.xml +++ b/estate/views/estate_property_views.xml @@ -38,6 +38,7 @@ + From 9b534dde1b33ec0378d9a01e3e2ed64aa7b0a825 Mon Sep 17 00:00:00 2001 From: "Sudarshan Maity (sumai)" Date: Fri, 20 Mar 2026 18:35:24 +0530 Subject: [PATCH 9/9] [IMP] Estate: Chapter 7- Completed Solved All Remaining Exercise Created New Model Estate Property Offers with One2many Concept Added New Fields in Models, Views, in it --- estate/__manifest__.py | 1 + estate/models/__init__.py | 1 + estate/models/estate_property.py | 1 + estate/models/estate_property_offer.py | 16 ++++++++ estate/security/ir.model.access.csv | 1 + estate/views/estate_menus.xml | 8 +++- estate/views/estate_property_offer_views.xml | 39 ++++++++++++++++++++ estate/views/estate_property_views.xml | 3 ++ 8 files changed, 69 insertions(+), 1 deletion(-) create mode 100644 estate/models/estate_property_offer.py create mode 100644 estate/views/estate_property_offer_views.xml diff --git a/estate/__manifest__.py b/estate/__manifest__.py index 6d6645f148d..5a07b4071e0 100644 --- a/estate/__manifest__.py +++ b/estate/__manifest__.py @@ -16,6 +16,7 @@ 'views/estate_property_views.xml', 'views/estate_property_type_views.xml', 'views/estate_property_tag_views.xml', + 'views/estate_property_offer_views.xml', 'views/estate_menus.xml', ], diff --git a/estate/models/__init__.py b/estate/models/__init__.py index c620ac481a3..2f1821a39c1 100644 --- a/estate/models/__init__.py +++ b/estate/models/__init__.py @@ -1,3 +1,4 @@ from . import estate_property from . import estate_property_type from . import estate_property_tag +from . import estate_property_offer diff --git a/estate/models/estate_property.py b/estate/models/estate_property.py index 1703803903b..7c10d8fadc9 100644 --- a/estate/models/estate_property.py +++ b/estate/models/estate_property.py @@ -53,3 +53,4 @@ class EstateProperty(models.Model): buyer_id = fields.Many2one("res.partner", string="Buyer", copy=False) salesperson_id = fields.Many2one("res.users", string="Salesperson", default=lambda self: self.env.user) tags_ids = fields.Many2many("estate.property.tag", string="Property Tags") + offer_ids = fields.One2many("estate.property.offer", "property_id", string="Offers") diff --git a/estate/models/estate_property_offer.py b/estate/models/estate_property_offer.py new file mode 100644 index 00000000000..a0c2b7de44a --- /dev/null +++ b/estate/models/estate_property_offer.py @@ -0,0 +1,16 @@ +from odoo import models, fields + + +class EstatePropertyOffer(models.Model): + _name = "estate.property.offer" + _description = "Property Offer" + + price = fields.Float() + status = fields.Selection( + [ + ('accepted', "Accepted"), + ('refused', "Refused"), + ], + string="Current Status", copy=False) + partner_id = fields.Many2one("res.partner", string="Partner", required=True) + property_id = fields.Many2one("estate.property", string="Property", required=True) diff --git a/estate/security/ir.model.access.csv b/estate/security/ir.model.access.csv index 1493eab4011..89f97c50842 100644 --- a/estate/security/ir.model.access.csv +++ b/estate/security/ir.model.access.csv @@ -2,3 +2,4 @@ id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink access_estate_property,access_estate_property,model_estate_property,base.group_user,1,1,1,1 access_estate_property_type,access_estate_property_type,model_estate_property_type,base.group_user,1,1,1,1 access_estate_property_tag,access_estate_property_tag,model_estate_property_tag,base.group_user,1,1,1,1 +access_estate_property_offer,access_estate_property_offer,model_estate_property_offer,base.group_user,1,1,1,1 diff --git a/estate/views/estate_menus.xml b/estate/views/estate_menus.xml index c8959b0b216..d0852969293 100644 --- a/estate/views/estate_menus.xml +++ b/estate/views/estate_menus.xml @@ -24,7 +24,7 @@ @@ -41,5 +41,11 @@ parent="menu_real_estate_settings" action="action_estate_property_tag" sequence="2"/> + + diff --git a/estate/views/estate_property_offer_views.xml b/estate/views/estate_property_offer_views.xml new file mode 100644 index 00000000000..fab4f58e666 --- /dev/null +++ b/estate/views/estate_property_offer_views.xml @@ -0,0 +1,39 @@ + + + + + + estate.property.offer.list + estate.property.offer + + + + + + + + + + + + estate.property.offer.form + estate.property.offer + +
+ + + + + + + + +
+
+
+ +
diff --git a/estate/views/estate_property_views.xml b/estate/views/estate_property_views.xml index 866ca274f55..1a2bed99328 100644 --- a/estate/views/estate_property_views.xml +++ b/estate/views/estate_property_views.xml @@ -85,6 +85,9 @@
+ + +