Skip to content

Commit

Permalink
[ADD] hr_applicant_duplicate: Onchange in phone and email to see if t…
Browse files Browse the repository at this point in the history
…he applicant is duplicated or discarded.
  • Loading branch information
Tu Nombre committed Jul 19, 2021
1 parent 48b855a commit bbf2a08
Show file tree
Hide file tree
Showing 10 changed files with 230 additions and 1 deletion.
2 changes: 1 addition & 1 deletion .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ sudo: false
cache: pip

python:
- "3.5"
- "3.6"

addons:
postgresql: "9.6"
Expand Down
28 changes: 28 additions & 0 deletions hr_applicant_duplicate/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
.. image:: https://img.shields.io/badge/licence-AGPL--3-blue.svg
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3

======================
Hr applicant duplicate
======================

* Onchange in phone and email to see if the applicant is duplicated or discarded.

Bug Tracker
===========

Bugs are tracked on `GitHub Issues
<https://github.com/avanzosc/hr-addons/issues>`_. In case of trouble,
please check there if your issue has already been reported. If you spotted
it first, help us smash it by providing detailed and welcomed feedback.

Do not contact contributors directly about support or help with technical issues.

Credits
=======

Contributors
------------

* Berezi Amubieta <[email protected]>
* Alfredo de la Fuente <[email protected]>
1 change: 1 addition & 0 deletions hr_applicant_duplicate/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import models
15 changes: 15 additions & 0 deletions hr_applicant_duplicate/__manifest__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
# Copyright 2021 Berezi - Iker - AvanzOSC
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html).
{
"name": "Hr Applicant Duplicate",
'version': '14.0.1.0.0',
"author": "Avanzosc",
"category": "Sales",
"depends": [
"hr_recruitment",
],
"data": [
],
"license": "AGPL-3",
'installable': True,
}
54 changes: 54 additions & 0 deletions hr_applicant_duplicate/i18n/es.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * hr_applicant_duplicate
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 14.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2021-07-19 07:57+0000\n"
"PO-Revision-Date: 2021-07-19 07:57+0000\n"
"Last-Translator: \n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"

#. module: hr_applicant_duplicate
#: model:ir.model,name:hr_applicant_duplicate.model_hr_applicant
msgid "Applicant"
msgstr "Candidato"

#. module: hr_applicant_duplicate
#: code:addons/hr_applicant_duplicate/models/hr_applicant.py:0
#, python-format
msgid "Applicant email is duplicated."
msgstr "El correo del candidato es duplicado."

#. module: hr_applicant_duplicate
#: code:addons/hr_applicant_duplicate/models/hr_applicant.py:0
#, python-format
msgid "Applicant mobile is duplicated."
msgstr "El móvil del cancidato es duplicado."

#. module: hr_applicant_duplicate
#: code:addons/hr_applicant_duplicate/models/hr_applicant.py:0
#, python-format
msgid "Applicant phone is duplicated."
msgstr "El teléfono del candidato es duplicado."

#. module: hr_applicant_duplicate
#: model:ir.model.fields,field_description:hr_applicant_duplicate.field_hr_applicant__display_name
msgid "Display Name"
msgstr "Nombre mostrado"

#. module: hr_applicant_duplicate
#: model:ir.model.fields,field_description:hr_applicant_duplicate.field_hr_applicant__id
msgid "ID"
msgstr ""

#. module: hr_applicant_duplicate
#: model:ir.model.fields,field_description:hr_applicant_duplicate.field_hr_applicant____last_update
msgid "Last Modified on"
msgstr "Última modificación el"
54 changes: 54 additions & 0 deletions hr_applicant_duplicate/i18n/hr_applicant_duplicate.pot
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * hr_applicant_duplicate
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 14.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2021-07-19 07:56+0000\n"
"PO-Revision-Date: 2021-07-19 07:56+0000\n"
"Last-Translator: \n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"

#. module: hr_applicant_duplicate
#: model:ir.model,name:hr_applicant_duplicate.model_hr_applicant
msgid "Applicant"
msgstr ""

#. module: hr_applicant_duplicate
#: code:addons/hr_applicant_duplicate/models/hr_applicant.py:0
#, python-format
msgid "Applicant email is duplicated."
msgstr ""

#. module: hr_applicant_duplicate
#: code:addons/hr_applicant_duplicate/models/hr_applicant.py:0
#, python-format
msgid "Applicant mobile is duplicated."
msgstr ""

#. module: hr_applicant_duplicate
#: code:addons/hr_applicant_duplicate/models/hr_applicant.py:0
#, python-format
msgid "Applicant phone is duplicated."
msgstr ""

#. module: hr_applicant_duplicate
#: model:ir.model.fields,field_description:hr_applicant_duplicate.field_hr_applicant__display_name
msgid "Display Name"
msgstr ""

#. module: hr_applicant_duplicate
#: model:ir.model.fields,field_description:hr_applicant_duplicate.field_hr_applicant__id
msgid "ID"
msgstr ""

#. module: hr_applicant_duplicate
#: model:ir.model.fields,field_description:hr_applicant_duplicate.field_hr_applicant____last_update
msgid "Last Modified on"
msgstr ""
1 change: 1 addition & 0 deletions hr_applicant_duplicate/models/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import hr_applicant
41 changes: 41 additions & 0 deletions hr_applicant_duplicate/models/hr_applicant.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
# Copyright 2021 Berezi - Iker - AvanzOSC
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html).
from odoo import models, api, _
from odoo.exceptions import ValidationError


class HrApplicant(models.Model):
_inherit = 'hr.applicant'

@api.onchange('partner_mobile', 'partner_phone', 'email_from')
def onchange_applicant_duplicate(self):
if self.partner_mobile:
cond1 = [('partner_mobile', '=', self.partner_mobile),
('active', '=', True)]
cond2 = [('partner_mobile', '=', self.partner_mobile),
('active', '=', False)]
employee1 = self.env['hr.applicant'].search(cond1, limit=1)
employee2 = self.env['hr.applicant'].search(cond2, limit=1)
if employee1 or employee2:
raise ValidationError(
_("Applicant mobile is duplicated."))
if self.partner_phone:
cond3 = [('partner_phone', '=', self.partner_phone),
('active', '=', True)]
cond4 = [('partner_phone', '=', self.partner_phone),
('active', '=', False)]
employee3 = self.env['hr.applicant'].search(cond3, limit=1)
employee4 = self.env['hr.applicant'].search(cond4, limit=1)
if employee3 or employee4:
raise ValidationError(
_("Applicant phone is duplicated."))
if self.email_from:
cond5 = [
('email_from', '=', self.email_from), ('active', '=', True)]
cond6 = [
('email_from', '=', self.email_from), ('active', '=', False)]
employee5 = self.env['hr.applicant'].search(cond5, limit=1)
employee6 = self.env['hr.applicant'].search(cond6, limit=1)
if employee5 or employee6:
raise ValidationError(
_("Applicant email is duplicated."))
1 change: 1 addition & 0 deletions hr_applicant_duplicate/tests/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import test_hr_applicant_duplicate
34 changes: 34 additions & 0 deletions hr_applicant_duplicate/tests/test_hr_applicant_duplicate.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
# Copyright (c) 2021 Berezi Amubieta - Avanzosc S.L.
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).

from odoo.tests import common
from odoo.exceptions import ValidationError


class TestHrApplicantDuplicate(common.SavepointCase):
@classmethod
def setUpClass(cls):
super(TestHrApplicantDuplicate, cls).setUpClass()
applicant_obj = cls.env['hr.applicant']
cls.applicant1 = applicant_obj.create({
'name': 'aaaa',
'partner_mobile': '11111',
'partner_phone': '22222',
'active': True,
})
cls.applicant2 = applicant_obj.create({
'name': 'bbbb',
'email_from': '[email protected]',
'active': False,
})

def test_sale_student_event(self):
self.applicant1.email_from = self.applicant2.email_from
with self.assertRaises(ValidationError):
self.applicant1.onchange_applicant_duplicate()
self.applicant2.partner_mobile = self.applicant1.partner_mobile
with self.assertRaises(ValidationError):
self.applicant2.onchange_applicant_duplicate()
self.applicant2.partner_phone = self.applicant1.partner_phone
with self.assertRaises(ValidationError):
self.applicant2.onchange_applicant_duplicate()

0 comments on commit bbf2a08

Please sign in to comment.