add visoes
This commit is contained in:
parent
8e34798496
commit
9300367948
11 changed files with 1079 additions and 1 deletions
71
dist-import/pilao-de-dados/visoes/index.js
Normal file
71
dist-import/pilao-de-dados/visoes/index.js
Normal file
|
|
@ -0,0 +1,71 @@
|
|||
import { z } from "zod";
|
||||
import { z_filtro } from "../_serie_consultar";
|
||||
// usar describe para definir o tipo de campo para render do componente
|
||||
const z_tipos_campos = z.enum([
|
||||
"tabela",
|
||||
"coluna",
|
||||
"texto",
|
||||
"lista_colunas",
|
||||
"lista_filtros",
|
||||
]);
|
||||
export const z_contagem_em_barra_vertical = z.object({
|
||||
tabela: z.string(),
|
||||
colanuEixoX: z.string(),
|
||||
colunaAgrupamento: z.string().array(),
|
||||
filtros: z_filtro.array(),
|
||||
descricao_pelo_usuario: z.string(),
|
||||
});
|
||||
export const z_contagem_em_pizza = z.object({
|
||||
tabela: z.string(),
|
||||
colanuEixoX: z.string(),
|
||||
filtros: z_filtro.array(),
|
||||
descricao_pelo_usuario: z.string(),
|
||||
});
|
||||
export const visoes = {
|
||||
z_contagem_em_barra_vertical,
|
||||
z_contagem_em_pizza,
|
||||
};
|
||||
/** Cria a estrutura de campos para insersão de dados */
|
||||
export const extruturas_de_campos = {
|
||||
z_contagem_em_barra_vertical: {
|
||||
visao: "z_contagem_em_barra_vertical",
|
||||
tabela: ({ tabela }) => tabela,
|
||||
descricao: ({ tabela, descricao_pelo_usuario, colanuEixoX, filtros, colunaAgrupamento, }) => {
|
||||
if (String(descricao_pelo_usuario || "").trim())
|
||||
return String(descricao_pelo_usuario || "").trim();
|
||||
return `Contagem de ${tabela} por ${colanuEixoX}${!filtros?.length
|
||||
? ""
|
||||
: `, quando ${filtros
|
||||
.map(({ coluna, operador, valor }) => `${coluna} ${operador} ${valor}`)
|
||||
.join(", ")}`}${!colunaAgrupamento?.length
|
||||
? ""
|
||||
: `, agrupado por ${colunaAgrupamento.join(", ")}`}.`;
|
||||
},
|
||||
campos: {
|
||||
colanuEixoX: { tipo_campo: "coluna" },
|
||||
tabela: { tipo_campo: "tabela" },
|
||||
colunaAgrupamento: { tipo_campo: "lista_colunas" },
|
||||
filtros: { tipo_campo: "lista_filtros" },
|
||||
descricao_pelo_usuario: { tipo_campo: "texto" },
|
||||
},
|
||||
},
|
||||
z_contagem_em_pizza: {
|
||||
visao: "z_contagem_em_pizza",
|
||||
tabela: ({ tabela }) => tabela,
|
||||
descricao: ({ tabela, descricao_pelo_usuario, colanuEixoX, filtros }) => {
|
||||
if (String(descricao_pelo_usuario || "").trim())
|
||||
return String(descricao_pelo_usuario || "").trim();
|
||||
return `Contagem de ${tabela} por ${colanuEixoX}${!filtros?.length
|
||||
? ""
|
||||
: `, quando ${filtros
|
||||
.map(({ coluna, operador, valor }) => `${coluna} ${operador} ${valor}`)
|
||||
.join(", ")}`}.`;
|
||||
},
|
||||
campos: {
|
||||
colanuEixoX: { tipo_campo: "coluna" },
|
||||
tabela: { tipo_campo: "tabela" },
|
||||
filtros: { tipo_campo: "lista_filtros" },
|
||||
descricao_pelo_usuario: { tipo_campo: "texto" },
|
||||
},
|
||||
},
|
||||
};
|
||||
Loading…
Add table
Add a link
Reference in a new issue