diff --git a/estate/__init__.py b/estate/__init__.py new file mode 100644 index 00000000000..0650744f6bc --- /dev/null +++ b/estate/__init__.py @@ -0,0 +1 @@ +from . import models diff --git a/estate/__manifest__.py b/estate/__manifest__.py new file mode 100644 index 00000000000..754f6ef50ec --- /dev/null +++ b/estate/__manifest__.py @@ -0,0 +1,20 @@ +{ + 'name': "Estate", + 'version': '0.1', + 'summary': "Real Estate Advertisement", + 'description': """ + This module allows you to manage real estate advertisements, including + properties, agents, and customer inquiries. + """, + 'author': "aykhu", + 'license': 'LGPL-3', + 'website': "https://www.odoo.com/app/estate", + 'category': 'Tutorials', + 'application': True, + 'depends': ['base'], + 'data': [ + 'security/ir.model.access.csv', + 'views/estate_property_views.xml', + 'views/estate_menus.xml', + ], +} diff --git a/estate/models/__init__.py b/estate/models/__init__.py new file mode 100644 index 00000000000..5e1963c9d2f --- /dev/null +++ b/estate/models/__init__.py @@ -0,0 +1 @@ +from . import estate_property diff --git a/estate/models/estate_property.py b/estate/models/estate_property.py new file mode 100644 index 00000000000..d9233c5ac08 --- /dev/null +++ b/estate/models/estate_property.py @@ -0,0 +1,40 @@ +from odoo import fields, models +from dateutil.relativedelta import relativedelta + + +class EstateProperty(models.Model): + _name = 'estate.property' + _description = 'Estate Property' + + name = fields.Char(string='Title', required=True, default='Unknown') + description = fields.Text(string='Description') + postcode = fields.Char(string='Postal Code') + last_seen = fields.Datetime(string="Last Seen", default=fields.Datetime.now) + date_availability = fields.Date( + string='Available From',copy=False, default=fields.Date.today() + relativedelta(months=+3) + ) + expected_price = fields.Float(string='Expected Price', required=True) + selling_price = fields.Float(string='Selling Price', readonly=True, copy=False) + living_area = fields.Float(string='Area (sq m)') + bedrooms = fields.Integer(string='Bedrooms', default=2) + facades = fields.Integer(string='Facades') + has_garage = fields.Boolean(string="Has Garage ?") + has_garden = fields.Boolean(string="Has Garden ?") + garden_area = fields.Integer(string="Garden Area (sq m)") + active = fields.Boolean(string="Is Active ?", default=True) + garden_orientation = fields.Selection( + string="Garden Orientation", + selection=[('north', 'North'), + ('south', 'South'), + ('east', 'East'), + ('west', 'West')], + ) + state = fields.Selection( + string="Status", + selection=[("New" , "New"), + ("Offer Received" , "Offer Received"), + ("Offer Accepted" , "Offer Accepted"), + ("Sold" , "Sold"), + ("Cancelled" , "Cancelled")], + required= True, default="New", copy=False + ) diff --git a/estate/security/ir.model.access.csv b/estate/security/ir.model.access.csv new file mode 100644 index 00000000000..ab63520e22b --- /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 +estate.access_estate_property,access_estate_property,estate.model_estate_property,base.group_user,1,1,1,1 \ No newline at end of file diff --git a/estate/views/estate_menus.xml b/estate/views/estate_menus.xml new file mode 100644 index 00000000000..600d4ae1a85 --- /dev/null +++ b/estate/views/estate_menus.xml @@ -0,0 +1,8 @@ + + + + + + + + \ No newline at end of file diff --git a/estate/views/estate_property_views.xml b/estate/views/estate_property_views.xml new file mode 100644 index 00000000000..fe6484667b3 --- /dev/null +++ b/estate/views/estate_property_views.xml @@ -0,0 +1,64 @@ + + + Test action + estate.property + list,form + + + + estate_property.list + estate.property + + + + + + + + + + + + + + + + estate_property.form + estate.property + +
+ +

+ +

+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+