Skip to Content
Odoo Menu
  • Sign in
  • Try it free
  • Apps
    Finance
    • Accounting
    • Invoicing
    • Expenses
    • Spreadsheet (BI)
    • Documents
    • Sign
    Sales
    • CRM
    • Sales
    • POS Shop
    • POS Restaurant
    • Subscriptions
    • Rental
    Websites
    • Website Builder
    • eCommerce
    • Blog
    • Forum
    • Live Chat
    • eLearning
    Supply Chain
    • Inventory
    • Manufacturing
    • PLM
    • Purchase
    • Maintenance
    • Quality
    Human Resources
    • Employees
    • Recruitment
    • Time Off
    • Appraisals
    • Referrals
    • Fleet
    Marketing
    • Social Marketing
    • Email Marketing
    • SMS Marketing
    • Events
    • Marketing Automation
    • Surveys
    Services
    • Project
    • Timesheets
    • Field Service
    • Helpdesk
    • Planning
    • Appointments
    Productivity
    • Discuss
    • Approvals
    • IoT
    • VoIP
    • Knowledge
    • WhatsApp
    Third party apps Odoo Studio Odoo Cloud Platform
  • Industries
    Retail
    • Book Store
    • Clothing Store
    • Furniture Store
    • Grocery Store
    • Hardware Store
    • Toy Store
    Food & Hospitality
    • Bar and Pub
    • Restaurant
    • Fast Food
    • Guest House
    • Beverage Distributor
    • Hotel
    Real Estate
    • Real Estate Agency
    • Architecture Firm
    • Construction
    • Property Management
    • Gardening
    • Property Owner Association
    Consulting
    • Accounting Firm
    • Odoo Partner
    • Marketing Agency
    • Law firm
    • Talent Acquisition
    • Audit & Certification
    Manufacturing
    • Textile
    • Metal
    • Furnitures
    • Food
    • Brewery
    • Corporate Gifts
    Health & Fitness
    • Sports Club
    • Eyewear Store
    • Fitness Center
    • Wellness Practitioners
    • Pharmacy
    • Hair Salon
    Trades
    • Handyman
    • IT Hardware & Support
    • Solar Energy Systems
    • Shoe Maker
    • Cleaning Services
    • HVAC Services
    Others
    • Nonprofit Organization
    • Environmental Agency
    • Billboard Rental
    • Photography
    • Bike Leasing
    • Software Reseller
    Browse all Industries
  • Community
    Learn
    • Tutorials
    • Documentation
    • Certifications
    • Training
    • Blog
    • Podcast
    Empower Education
    • Education Program
    • Scale Up! Business Game
    • Visit Odoo
    Get the Software
    • Download
    • Compare Editions
    • Releases
    Collaborate
    • Github
    • Forum
    • Events
    • Translations
    • Become a Partner
    • Services for Partners
    • Register your Accounting Firm
    Get Services
    • Find a Partner
    • Find an Accountant
    • Meet an advisor
    • Implementation Services
    • Customer References
    • Support
    • Upgrades
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Get a demo
  • Pricing
  • Help
You need to be registered to interact with the community.
All Posts People Badges
Tags (View all)
odoo accounting v14 pos v15
About this forum
You need to be registered to interact with the community.
All Posts People Badges
Tags (View all)
odoo accounting v14 pos v15
About this forum
Help

How to create a calculated field from another field in another class.

Subscribe

Get notified when there's activity on this post

This question has been flagged
fields
2 Replies
16509 Views
Avatar
Reyes

Hello everyone,

I have two classes: "employees" and "contracts" that are related. There is an One2Many relation between "employee" and "contracts", so that one employee may have n contracts.

To create the “employees” module / class, I inherited from hr.employee and to create “contracts” I inherited from hr.contract.

Please, I need somebody explain me with an example under the new style of API v8 (took a few months learning and prefer to use from the start the new style of API v8) how to create a calculated date field in "employees" got the another value date field in "contracts". The date must take the date_start field in the last contract (remember that for every employee there n contracts).

I works perfectly the calculated field when the date grabs a date field in the same class (see example), but not how to do it when you take it from another class in another module and must also select an agreement among all to take the date.

Here I leave the example I've ever had and if I work:

# - * - Coding: utf-8 - * -

OpenERP from import fields, models, api

Employees class (models.Model):

_inherit = 'hr.employee'

date_last = fields.Date (compute = '_ calculate_birthday')

@ Api.depends ('birthday')

def _calculate_birthday (self):

for record in self:

record.date_last = record.birthday

Thank you all

0
Avatar
Discard
Avatar
Cyril Gaspard (GEM)
Best Answer

Hi,

I try to sort by line id, but this give the date start of the last line created like you want => the last contract (not last modification), see code not tested:

from openerp import fields, models, api


class HrEmployee(models.Model):

    _inherit = 'hr.employee'


    contract_ids = fields.One2many('hr.contract', 'employee_id', string="Contracts")

    date_start = fields.Date(compute='_ get_date_start', string="Date start")


    @api.multi

    @api.depends('contract_ids.date_start')

    def _get_date_start(self):

        for record in self:

            record.date_start = record.contract_ids.sorted(key=lambda r: r.id, inverse=True).mapped('date_start')[0]



class HrContract(models.Model):

    _inherit = 'hr.contract'


    employee_id = fields.Many2one('hr.employee', string="Employee")

    date_start = fields.Date(string="Date start")


bye

2
Avatar
Discard
Avatar
Diego Calzadilla
Best Answer

No entiendo muy bien tu necesidad, pero para obtener campos de otra tabla, y usarlos en la tabla donde quieres hacer tus calculos  puedes usar fields.related. También puedes hacer un trigger para que cuando los valores cambien en la tabla de origen, cambien automaticamente en la tabla donde haces los calculos:


class comun_denominador_producto(osv.osv):

_inherit = 'product.product'

_name='product.product'

def _get_comun_denominador_ids(self, cr, uid, ids, context=None):

comun_denominador_ids = self.pool.get('product.product').search(cr, uid, [('product_tmpl_id', 'in', ids)])

return list(set(comun_denominador_ids))

_columns = {

'cm_pt_id': fields.related('product_tmpl_id', 'cm_id', 'comun_denominador', string="Común denominador", type='char', store={

'product.template': (_get_comun_denominador_ids, ['cm_id'], 10),

'product.product': (lambda self, cr, uid, ids, c=None: ids, [], 10),

}, select=True)

}


el campo 'comun_denominador' es tipo char, quizá algo como esto te sea útil, pero con el campo tipo date.

Saludos!

1
Avatar
Discard
Enjoying the discussion? Don't just read, join in!

Create an account today to enjoy exclusive features and engage with our awesome community!

Sign up
Related Posts Replies Views Activity
I cannot see custom field in lead form
fields
Avatar
Avatar
Avatar
2
Dec 25
3887
trying to match fields for products
fields
Avatar
Avatar
Avatar
2
Dec 25
490
How to display a red * for required fields
fields
Avatar
Avatar
Avatar
Avatar
3
May 25
3969
How to display a red * for required fields
fields
Avatar
Avatar
1
Apr 25
2758
one2one relational field Solved
fields
Avatar
Avatar
Avatar
Avatar
3
Sep 24
16774
Community
  • Tutorials
  • Documentation
  • Forum
Open Source
  • Download
  • Github
  • Runbot
  • Translations
Services
  • Odoo.sh Hosting
  • Support
  • Upgrade
  • Custom Developments
  • Education
  • Find an Accountant
  • Find a Partner
  • Become a Partner
About us
  • Our company
  • Brand Assets
  • Contact us
  • Jobs
  • Events
  • Podcast
  • Blog
  • Customers
  • Legal • Privacy
  • Security
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español Svenska ภาษาไทย Türkçe українська Tiếng Việt

Odoo is a suite of open source business apps that cover all your company needs: CRM, eCommerce, accounting, inventory, point of sale, project management, etc.

Odoo's unique value proposition is to be at the same time very easy to use and fully integrated.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now