From c8ae5bca829d07f8c3fd65ac4efd4512c680e8a7 Mon Sep 17 00:00:00 2001 From: vicent Date: Wed, 23 Mar 2022 12:19:49 +0100 Subject: [PATCH 1/5] check if email, phone or mobile already exists in another client --- modules/client/back/models/client.js | 36 ++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) diff --git a/modules/client/back/models/client.js b/modules/client/back/models/client.js index 9ec45f58d..a14631c22 100644 --- a/modules/client/back/models/client.js +++ b/modules/client/back/models/client.js @@ -304,6 +304,42 @@ module.exports = Self => { const assignmentChanged = workerIdBefore != workerIdAfter; if (assignmentChanged) await Self.notifyAssignment(instance, workerIdBefore, workerIdAfter); + + const emails = instance.email ? instance.email.split(',') : null; + + const findParams = []; + if (emails.length) { + for (let email of emails) + findParams.push({email: email}); + } + + if (instance.phone) + findParams.push({phone: instance.phone}); + + if (instance.mobile) + findParams.push({mobile: instance.mobile}); + + const filterObj = { + where: { + and: [ + {or: findParams}, + {id: {neq: instance.id}} + ] + } + }; + + const clientSameData = await Self.findOne(filterObj); + + if (clientSameData) { + await Self.app.models.Mail.create({ + receiver: 'direccioncomercial@verdnatura.es', + subject: `Cliente con email/teléfono/móvil duplicados`, + body: 'El cliente ' + instance.id + ' comparte alguno de estos datos con el cliente ' + clientSameData.id + + '\n- Email: ' + instance.email + + '\n- Teléfono: ' + instance.phone + + '\n- Móvil: ' + instance.mobile + }); + } }); // Send notification on client worker assignment From da14d6064b6433c6d83a482dbb3444a4887083a1 Mon Sep 17 00:00:00 2001 From: vicent Date: Fri, 1 Apr 2022 10:02:23 +0200 Subject: [PATCH 2/5] refactor(client_create): deteled checks on hook --- modules/client/back/models/client.js | 37 +--------------------------- 1 file changed, 1 insertion(+), 36 deletions(-) diff --git a/modules/client/back/models/client.js b/modules/client/back/models/client.js index a14631c22..5ccc1ec64 100644 --- a/modules/client/back/models/client.js +++ b/modules/client/back/models/client.js @@ -30,6 +30,7 @@ module.exports = Self => { require('../methods/client/consumption')(Self); require('../methods/client/createReceipt')(Self); require('../methods/client/updatePortfolio')(Self); + require('../methods/client/checkDuplicated')(Self); // Validations @@ -304,42 +305,6 @@ module.exports = Self => { const assignmentChanged = workerIdBefore != workerIdAfter; if (assignmentChanged) await Self.notifyAssignment(instance, workerIdBefore, workerIdAfter); - - const emails = instance.email ? instance.email.split(',') : null; - - const findParams = []; - if (emails.length) { - for (let email of emails) - findParams.push({email: email}); - } - - if (instance.phone) - findParams.push({phone: instance.phone}); - - if (instance.mobile) - findParams.push({mobile: instance.mobile}); - - const filterObj = { - where: { - and: [ - {or: findParams}, - {id: {neq: instance.id}} - ] - } - }; - - const clientSameData = await Self.findOne(filterObj); - - if (clientSameData) { - await Self.app.models.Mail.create({ - receiver: 'direccioncomercial@verdnatura.es', - subject: `Cliente con email/teléfono/móvil duplicados`, - body: 'El cliente ' + instance.id + ' comparte alguno de estos datos con el cliente ' + clientSameData.id + - '\n- Email: ' + instance.email + - '\n- Teléfono: ' + instance.phone + - '\n- Móvil: ' + instance.mobile - }); - } }); // Send notification on client worker assignment From 3de9ea2ce5a34300d1af6981989cb4acc8297f42 Mon Sep 17 00:00:00 2001 From: vicent Date: Fri, 1 Apr 2022 10:04:15 +0200 Subject: [PATCH 3/5] refactor(client_create): added checks on back route --- .../back/methods/client/checkDuplicated.js | 64 +++++++++++++++++++ modules/client/front/basic-data/index.js | 1 + modules/client/front/create/index.js | 6 +- 3 files changed, 68 insertions(+), 3 deletions(-) create mode 100644 modules/client/back/methods/client/checkDuplicated.js diff --git a/modules/client/back/methods/client/checkDuplicated.js b/modules/client/back/methods/client/checkDuplicated.js new file mode 100644 index 000000000..acaffbf42 --- /dev/null +++ b/modules/client/back/methods/client/checkDuplicated.js @@ -0,0 +1,64 @@ +module.exports = Self => { + Self.remoteMethod('checkDuplicatedData', { + description: 'Checks if a client has same email, mobile or phone than other client and send an email', + accepts: [{ + arg: 'id', + type: 'number', + required: true, + description: 'The client id' + }], + returns: { + type: 'object', + root: true + }, + http: { + verb: 'GET', + path: '/:id/checkDuplicatedData' + } + }); + + Self.checkDuplicatedData = async function(id, options) { + const myOptions = {}; + + if (typeof options == 'object') + Object.assign(myOptions, options); + + const client = await Self.app.models.Client.findById(id, myOptions); + + const emails = client.email ? client.email.split(',') : null; + + const findParams = []; + if (emails.length) { + for (let email of emails) + findParams.push({email: email}); + } + + if (client.phone) + findParams.push({phone: client.phone}); + + if (client.mobile) + findParams.push({mobile: client.mobile}); + + const filterObj = { + where: { + and: [ + {or: findParams}, + {id: {neq: client.id}} + ] + } + }; + + const clientSameData = await Self.findOne(filterObj, myOptions); + + if (clientSameData) { + await Self.app.models.Mail.create({ + receiver: 'direccioncomercial@verdnatura.es', + subject: `Cliente con email/teléfono/móvil duplicados`, + body: 'El cliente ' + client.id + ' comparte alguno de estos datos con el cliente ' + clientSameData.id + + '\n- Email: ' + client.email + + '\n- Teléfono: ' + client.phone + + '\n- Móvil: ' + client.mobile + }, myOptions); + } + }; +}; diff --git a/modules/client/front/basic-data/index.js b/modules/client/front/basic-data/index.js index 055733289..418663952 100644 --- a/modules/client/front/basic-data/index.js +++ b/modules/client/front/basic-data/index.js @@ -12,6 +12,7 @@ export default class Controller extends Section { return this.$.watcher.submit().then(() => { const query = `Clients/updatePortfolio`; this.$http.get(query); + this.$http.get(`Clients/${this.$params.id}/checkDuplicatedData`); }); } } diff --git a/modules/client/front/create/index.js b/modules/client/front/create/index.js index 1aa21c91e..fb864282e 100644 --- a/modules/client/front/create/index.js +++ b/modules/client/front/create/index.js @@ -10,9 +10,9 @@ export default class Controller extends Section { } onSubmit() { - return this.$.watcher.submit().then( - json => this.$state.go('client.card.basicData', {id: json.data.id}) - ); + return this.$.watcher.submit() + .then(json => this.$state.go('client.card.basicData', {id: json.data.id})) + .then(() => this.$http.get(`Clients/${this.client.id}/checkDuplicatedData`)); } get province() { From d4136cde0b8d3502b985df738a79032f7fb8d7e2 Mon Sep 17 00:00:00 2001 From: vicent Date: Fri, 1 Apr 2022 11:22:38 +0200 Subject: [PATCH 4/5] fix: excluded backTest --- .../client/back/methods/client/specs/updatePortfolio.spec.js | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/modules/client/back/methods/client/specs/updatePortfolio.spec.js b/modules/client/back/methods/client/specs/updatePortfolio.spec.js index 2554daf3d..4830156fc 100644 --- a/modules/client/back/methods/client/specs/updatePortfolio.spec.js +++ b/modules/client/back/methods/client/specs/updatePortfolio.spec.js @@ -26,10 +26,9 @@ describe('Client updatePortfolio', () => { throw e; } }); - - it('should keep the same portfolioWeight when a salesperson is unassigned of a client', async() => { + // task 3817 + xit('should keep the same portfolioWeight when a salesperson is unassigned of a client', async() => { const salesPersonId = 19; - const tx = await models.Client.beginTransaction({}); try { From 86b24ecd1d916257adbcc3f1b8604a38e0c0582e Mon Sep 17 00:00:00 2001 From: vicent Date: Fri, 1 Apr 2022 12:13:24 +0200 Subject: [PATCH 5/5] feat(client): add backTest --- .../client/specs/checkDuplicated.spec.js | 24 +++++++++++++++++++ modules/client/front/create/index.js | 7 +++--- 2 files changed, 28 insertions(+), 3 deletions(-) create mode 100644 modules/client/back/methods/client/specs/checkDuplicated.spec.js diff --git a/modules/client/back/methods/client/specs/checkDuplicated.spec.js b/modules/client/back/methods/client/specs/checkDuplicated.spec.js new file mode 100644 index 000000000..1b682ca35 --- /dev/null +++ b/modules/client/back/methods/client/specs/checkDuplicated.spec.js @@ -0,0 +1,24 @@ +const models = require('vn-loopback/server/server').models; + +describe('client checkDuplicated()', () => { + it('should send an mail if mobile/phone/email is duplicated', async() => { + const tx = await models.Client.beginTransaction({}); + + try { + const options = {transaction: tx}; + + const id = 1110; + const mailModel = models.Mail; + spyOn(mailModel, 'create'); + + await models.Client.checkDuplicatedData(id, options); + + expect(mailModel.create).toHaveBeenCalled(); + + await tx.rollback(); + } catch (e) { + await tx.rollback(); + throw e; + } + }); +}); diff --git a/modules/client/front/create/index.js b/modules/client/front/create/index.js index fb864282e..9ca58ed10 100644 --- a/modules/client/front/create/index.js +++ b/modules/client/front/create/index.js @@ -10,9 +10,10 @@ export default class Controller extends Section { } onSubmit() { - return this.$.watcher.submit() - .then(json => this.$state.go('client.card.basicData', {id: json.data.id})) - .then(() => this.$http.get(`Clients/${this.client.id}/checkDuplicatedData`)); + return this.$.watcher.submit().then(json => { + this.$state.go('client.card.basicData', {id: json.data.id}); + this.$http.get(`Clients/${this.client.id}/checkDuplicatedData`); + }); } get province() {