Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 5 additions & 2 deletions src/controllers/taxonomias-controller.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import limparEspacos from '@/helpers/limpa-espaco';

Check warning on line 1 in src/controllers/taxonomias-controller.js

View workflow job for this annotation

GitHub Actions / lint

There should be at least one empty line between import groups
import { atualizarNomeCientificoPorGenero, atualizarNomeCientificoPorEspecie } from '../utils/atualiza-nome-cientifico';

Check warning on line 2 in src/controllers/taxonomias-controller.js

View workflow job for this annotation

GitHub Actions / lint

There should be no empty line within import group

Check warning on line 2 in src/controllers/taxonomias-controller.js

View workflow job for this annotation

GitHub Actions / lint

`../utils/atualiza-nome-cientifico` import should occur after import of `../resources/sqls/lista-taxonomias`

import BadRequestExeption from '../errors/bad-request-exception';
import models from '../models';
Expand Down Expand Up @@ -604,7 +605,8 @@
id: generoId,
},
transaction,
}));
}))
.then(() => atualizarNomeCientificoPorGenero(generoId, transaction));
sequelize.transaction(callback)
.then(generoCriado => {
if (!generoCriado) {
Expand Down Expand Up @@ -837,7 +839,8 @@
id: especieId,
},
transaction,
}));
}))
.then(() => atualizarNomeCientificoPorEspecie(especieId, transaction));
sequelize.transaction(callback)
.then(especieCriado => {
if (!especieCriado) {
Expand Down

This file was deleted.

47 changes: 47 additions & 0 deletions src/utils/atualiza-nome-cientifico.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
import models from '../models';

const { sequelize } = models;

/**
* Atualiza o nome_cientifico de todos os tombos que possuem o genero_id informado.
* Deve ser chamado quando o nome de um gênero for alterado.
*/
export async function atualizarNomeCientificoPorGenero(generoId, transaction) {
// Tombos com genero e especie
await sequelize.query(`
UPDATE tombos t
SET nome_cientifico = CONCAT(g.nome, ' ', e.nome)
FROM generos g, especies e
WHERE t.genero_id = g.id
AND t.especie_id = e.id
AND t.genero_id = :generoId
AND t.nome_cientifico IS DISTINCT FROM CONCAT(g.nome, ' ', e.nome)
`, { replacements: { generoId }, transaction });

// Tombos com apenas genero (sem especie)
await sequelize.query(`
UPDATE tombos t
SET nome_cientifico = g.nome
FROM generos g
WHERE t.genero_id = g.id
AND t.especie_id IS NULL
AND t.genero_id = :generoId
AND t.nome_cientifico IS DISTINCT FROM g.nome
`, { replacements: { generoId }, transaction });
}

/**
* Atualiza o nome_cientifico de todos os tombos que possuem o especie_id informado.
* Deve ser chamado quando o nome de uma espécie for alterado.
*/
export async function atualizarNomeCientificoPorEspecie(especieId, transaction) {
await sequelize.query(`
UPDATE tombos t
SET nome_cientifico = CONCAT(g.nome, ' ', e.nome)
FROM generos g, especies e
WHERE t.genero_id = g.id
AND t.especie_id = e.id
AND t.especie_id = :especieId
AND t.nome_cientifico IS DISTINCT FROM CONCAT(g.nome, ' ', e.nome)
`, { replacements: { especieId }, transaction });
}
Loading