contable 0.0.6 → 0.0.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/client/client/client.js +240 -0
- package/dist/client/{menu.js → client/menu.js} +1 -1
- package/dist/client/client/redux-formulario.js +379 -0
- package/dist/client/client/render-components.js +750 -0
- package/dist/client/client/render-formulario.js +56 -0
- package/dist/client/client/render-general.js +197 -0
- package/dist/client/client/render-handlers.js +69 -0
- package/dist/client/client/tipos.js +13 -0
- package/dist/client/{tsconfig.json → client/tsconfig.json} +3 -4
- package/dist/{unlogged → client/unlogged}/tsconfig.json +1 -3
- package/dist/server/client/tipos.d.ts +119 -0
- package/dist/server/client/tipos.js +13 -0
- package/dist/server/{app-contable.d.ts → server/app-contable.d.ts} +63 -3
- package/dist/server/server/app-contable.js +192 -0
- package/dist/server/server/def-config.d.ts +1 -0
- package/dist/server/server/def-config.js +101 -0
- package/dist/server/server/procedures-contable.js +508 -0
- package/dist/server/{server-contable.js → server/server-contable.js} +1 -1
- package/dist/server/server/table-categorias_producto.js +29 -0
- package/dist/server/server/table-clientes.js +56 -0
- package/dist/server/server/table-condicion_iva.js +29 -0
- package/dist/server/server/table-estados_pedido.js +33 -0
- package/dist/server/server/table-estados_presupuesto.js +34 -0
- package/dist/server/server/table-insumos.js +44 -0
- package/dist/server/server/table-items_pedido.js +48 -0
- package/dist/server/server/table-items_presupuesto.js +48 -0
- package/dist/server/server/table-iva_productos.js +29 -0
- package/dist/server/server/table-parametros.js +38 -0
- package/dist/server/server/table-pedidos.js +48 -0
- package/dist/server/server/table-pedidos_pendientes.js +28 -0
- package/dist/server/server/table-pedidos_vencidos.js +28 -0
- package/dist/server/server/table-presupuestos.js +56 -0
- package/dist/server/server/table-productos.js +70 -0
- package/dist/server/server/table-productos_clientes.js +22 -0
- package/dist/server/server/table-productos_generales.js +22 -0
- package/dist/server/server/table-productos_insumos.js +47 -0
- package/dist/server/server/table-usuarios.js +44 -0
- package/dist/server/{types-contable.d.ts → server/types-contable.d.ts} +14 -3
- package/dist/server/server/types-contable.js +28 -0
- package/dist/unlogged/unlogged/adapt.js +8 -0
- package/dist/unlogged/unlogged/css/styles.styl +88 -0
- package/dist/unlogged/unlogged/img/login-logo-icon.png +0 -0
- package/dist/unlogged/unlogged/img/logo.png +0 -0
- package/dist/unlogged/unlogged/tsconfig.json +13 -0
- package/dist/unlogged/unlogged/unlogged.js +13 -0
- package/package.json +22 -5
- package/dist/client/client.js +0 -182
- package/dist/client/redux-formulario.js +0 -326
- package/dist/client/render-components.js +0 -617
- package/dist/client/render-formulario.js +0 -56
- package/dist/client/render-general.js +0 -172
- package/dist/client/render-handlers.js +0 -29
- package/dist/client/tipos.js +0 -13
- package/dist/server/app-contable.js +0 -192
- package/dist/server/def-config.d.ts +0 -1
- package/dist/server/def-config.js +0 -100
- package/dist/server/procedures-contable.js +0 -508
- package/dist/server/table-categorias_producto.js +0 -29
- package/dist/server/table-clientes.js +0 -56
- package/dist/server/table-condicion_iva.js +0 -29
- package/dist/server/table-estados_pedido.js +0 -33
- package/dist/server/table-estados_presupuesto.js +0 -34
- package/dist/server/table-insumos.js +0 -44
- package/dist/server/table-items_pedido.js +0 -48
- package/dist/server/table-items_presupuesto.js +0 -48
- package/dist/server/table-iva_productos.js +0 -29
- package/dist/server/table-parametros.js +0 -38
- package/dist/server/table-pedidos.js +0 -48
- package/dist/server/table-pedidos_pendientes.js +0 -28
- package/dist/server/table-pedidos_vencidos.js +0 -28
- package/dist/server/table-presupuestos.js +0 -56
- package/dist/server/table-productos.js +0 -70
- package/dist/server/table-productos_clientes.js +0 -22
- package/dist/server/table-productos_generales.js +0 -22
- package/dist/server/table-productos_insumos.js +0 -47
- package/dist/server/table-usuarios.js +0 -44
- package/dist/server/tsconfig.json +0 -10
- package/dist/server/types-contable.js +0 -28
- package/dist/unlogged/adapt.js +0 -8
- package/dist/unlogged/unlogged.js +0 -118
- /package/dist/client/{client.d.ts → client/client.d.ts} +0 -0
- /package/dist/client/{img → client/img}/bannersuperior.png +0 -0
- /package/dist/client/{menu.d.ts → client/menu.d.ts} +0 -0
- /package/dist/client/{redux-formulario.d.ts → client/redux-formulario.d.ts} +0 -0
- /package/dist/client/{render-components.d.ts → client/render-components.d.ts} +0 -0
- /package/dist/client/{render-components.tsx → client/render-components.tsx} +0 -0
- /package/dist/client/{render-formulario.d.ts → client/render-formulario.d.ts} +0 -0
- /package/dist/client/{render-formulario.tsx → client/render-formulario.tsx} +0 -0
- /package/dist/client/{render-general.d.ts → client/render-general.d.ts} +0 -0
- /package/dist/client/{render-general.tsx → client/render-general.tsx} +0 -0
- /package/dist/client/{render-handlers.d.ts → client/render-handlers.d.ts} +0 -0
- /package/dist/client/{tipos.d.ts → client/tipos.d.ts} +0 -0
- /package/dist/{unlogged → client/unlogged}/css/styles.styl +0 -0
- /package/dist/{unlogged/img/login-logo-icon.png.png → client/unlogged/img/login-logo-icon.png} +0 -0
- /package/dist/{unlogged → client/unlogged}/img/logo.png +0 -0
- /package/dist/server/{procedures-contable.d.ts → server/procedures-contable.d.ts} +0 -0
- /package/dist/server/{server-contable.d.ts → server/server-contable.d.ts} +0 -0
- /package/dist/server/{table-categorias_producto.d.ts → server/table-categorias_producto.d.ts} +0 -0
- /package/dist/server/{table-clientes.d.ts → server/table-clientes.d.ts} +0 -0
- /package/dist/server/{table-condicion_iva.d.ts → server/table-condicion_iva.d.ts} +0 -0
- /package/dist/server/{table-estados_pedido.d.ts → server/table-estados_pedido.d.ts} +0 -0
- /package/dist/server/{table-estados_presupuesto.d.ts → server/table-estados_presupuesto.d.ts} +0 -0
- /package/dist/server/{table-insumos.d.ts → server/table-insumos.d.ts} +0 -0
- /package/dist/server/{table-items_pedido.d.ts → server/table-items_pedido.d.ts} +0 -0
- /package/dist/server/{table-items_presupuesto.d.ts → server/table-items_presupuesto.d.ts} +0 -0
- /package/dist/server/{table-iva_productos.d.ts → server/table-iva_productos.d.ts} +0 -0
- /package/dist/server/{table-parametros.d.ts → server/table-parametros.d.ts} +0 -0
- /package/dist/server/{table-pedidos.d.ts → server/table-pedidos.d.ts} +0 -0
- /package/dist/server/{table-pedidos_pendientes.d.ts → server/table-pedidos_pendientes.d.ts} +0 -0
- /package/dist/server/{table-pedidos_vencidos.d.ts → server/table-pedidos_vencidos.d.ts} +0 -0
- /package/dist/server/{table-presupuestos.d.ts → server/table-presupuestos.d.ts} +0 -0
- /package/dist/server/{table-productos.d.ts → server/table-productos.d.ts} +0 -0
- /package/dist/server/{table-productos_clientes.d.ts → server/table-productos_clientes.d.ts} +0 -0
- /package/dist/server/{table-productos_generales.d.ts → server/table-productos_generales.d.ts} +0 -0
- /package/dist/server/{table-productos_insumos.d.ts → server/table-productos_insumos.d.ts} +0 -0
- /package/dist/server/{table-usuarios.d.ts → server/table-usuarios.d.ts} +0 -0
- /package/dist/unlogged/{adapt.d.ts → unlogged/adapt.d.ts} +0 -0
- /package/dist/unlogged/{unlogged.d.ts → unlogged/unlogged.d.ts} +0 -0
|
@@ -0,0 +1,508 @@
|
|
|
1
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
2
|
+
if (k2 === undefined) k2 = k;
|
|
3
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
4
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
5
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
6
|
+
}
|
|
7
|
+
Object.defineProperty(o, k2, desc);
|
|
8
|
+
}) : (function(o, m, k, k2) {
|
|
9
|
+
if (k2 === undefined) k2 = k;
|
|
10
|
+
o[k2] = m[k];
|
|
11
|
+
}));
|
|
12
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
13
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
14
|
+
};
|
|
15
|
+
(function (factory) {
|
|
16
|
+
if (typeof module === "object" && typeof module.exports === "object") {
|
|
17
|
+
var v = factory(require, exports);
|
|
18
|
+
if (v !== undefined) module.exports = v;
|
|
19
|
+
}
|
|
20
|
+
else if (typeof define === "function" && define.amd) {
|
|
21
|
+
define(["require", "exports", "./types-contable", "best-globals"], factory);
|
|
22
|
+
}
|
|
23
|
+
})(function (require, exports) {
|
|
24
|
+
"use strict";
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.ProceduresContable = void 0;
|
|
27
|
+
__exportStar(require("./types-contable"), exports);
|
|
28
|
+
const best_globals_1 = require("best-globals");
|
|
29
|
+
var path = require('path');
|
|
30
|
+
var sqlTools = require('sql-tools');
|
|
31
|
+
const ESTADO_ACEPTADO_PRESUPUESTO = 'aceptado';
|
|
32
|
+
const ESTADO_ANULADO_PRESUPUESTO = 'anulado';
|
|
33
|
+
const ESTADO_RECHAZADO_PRESUPUESTO = 'rechazado';
|
|
34
|
+
function json(sql, orderby) {
|
|
35
|
+
return `COALESCE((SELECT jsonb_agg(to_jsonb(j.*) ORDER BY ${orderby}) from (${sql}) as j),'[]'::jsonb)`;
|
|
36
|
+
}
|
|
37
|
+
function jsono(sql, indexedby) {
|
|
38
|
+
return `COALESCE((SELECT jsonb_object_agg(${indexedby},to_jsonb(j.*)) from (${sql}) as j),'{}'::jsonb)`;
|
|
39
|
+
}
|
|
40
|
+
var createStructure = function createStructure(context, tableName) {
|
|
41
|
+
var be = context.be;
|
|
42
|
+
var mainTableDef = be.tableStructures[tableName](context);
|
|
43
|
+
var getPkFromTableDef = function getPkFromTableDef(tableDef) {
|
|
44
|
+
return tableDef.primaryKey.map(function (pk) {
|
|
45
|
+
return { fieldName: pk };
|
|
46
|
+
});
|
|
47
|
+
};
|
|
48
|
+
var getFkFromTableDef = function getFkFromTableDef(tableDef) {
|
|
49
|
+
return tableDef.foreignKeys.map(function (fk) {
|
|
50
|
+
return fk.fields;
|
|
51
|
+
});
|
|
52
|
+
};
|
|
53
|
+
var struct = {
|
|
54
|
+
tableName: mainTableDef.name,
|
|
55
|
+
pkFields: getPkFromTableDef(mainTableDef),
|
|
56
|
+
};
|
|
57
|
+
struct.childTables = [];
|
|
58
|
+
if (mainTableDef.detailTables && mainTableDef.detailTables.length) {
|
|
59
|
+
mainTableDef.detailTables.forEach(function (detailTable) {
|
|
60
|
+
struct.childTables.push((0, best_globals_1.changing)(createStructure(context, detailTable.table), getFkFromTableDef(be.tableStructures[detailTable.table](context))));
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
return struct;
|
|
64
|
+
};
|
|
65
|
+
async function permiteEditarPresupuesto(nroPresup, client) {
|
|
66
|
+
if (!(await client.query(`
|
|
67
|
+
select *
|
|
68
|
+
from presupuestos inner join estados_presupuesto using (estado)
|
|
69
|
+
where presupuesto = $1
|
|
70
|
+
`, [nroPresup]).fetchOneRowIfExists()).row.permite_editar) {
|
|
71
|
+
//si el estado no permite editar tira error
|
|
72
|
+
throw Error('No se puede editar ya que su estado no lo permite.');
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
exports.ProceduresContable = [
|
|
76
|
+
{
|
|
77
|
+
action: 'estructura_crear',
|
|
78
|
+
parameters: [],
|
|
79
|
+
coreFunction: async function (context, _parameters) {
|
|
80
|
+
var client = context.client;
|
|
81
|
+
var query = `
|
|
82
|
+
SELECT
|
|
83
|
+
${jsono(`
|
|
84
|
+
SELECT *
|
|
85
|
+
FROM clientes
|
|
86
|
+
`, 'cliente')} as clientes,
|
|
87
|
+
${jsono(`
|
|
88
|
+
select p.*,
|
|
89
|
+
sum(i.costo_unitario*i.utilidad*pi.cantidad_insumo) as total_insumos,
|
|
90
|
+
precio_sin_insumos + coalesce(sum(i.costo_unitario*i.utilidad*pi.cantidad_insumo),0) as precio
|
|
91
|
+
from productos p
|
|
92
|
+
left join productos_insumos pi using (producto)
|
|
93
|
+
left join insumos i using (insumo)
|
|
94
|
+
where p.producto > 0
|
|
95
|
+
group by p.producto,
|
|
96
|
+
p.categoria,
|
|
97
|
+
p.nombre,
|
|
98
|
+
p.descripcion,
|
|
99
|
+
p.habilitado,
|
|
100
|
+
p.precio_sin_insumos,
|
|
101
|
+
p.stock,
|
|
102
|
+
p.stock_minimo,
|
|
103
|
+
p.stock_maximo,
|
|
104
|
+
p.iva
|
|
105
|
+
`, 'producto')} as productos,
|
|
106
|
+
${jsono(`
|
|
107
|
+
SELECT *
|
|
108
|
+
FROM condicion_iva
|
|
109
|
+
`, 'condicion')} as "condicionesIva",
|
|
110
|
+
${json(`
|
|
111
|
+
SELECT *
|
|
112
|
+
FROM estados_presupuesto
|
|
113
|
+
`, 'orden')} as "estadosPresupuesto",
|
|
114
|
+
${json(`
|
|
115
|
+
SELECT *
|
|
116
|
+
FROM estados_pedido
|
|
117
|
+
`, 'orden')} as "estadosPedido",
|
|
118
|
+
(SELECT to_jsonb(j.*)
|
|
119
|
+
from (select legales_pedido, legales_presupuesto from parametros) as j) as parametros
|
|
120
|
+
`;
|
|
121
|
+
try {
|
|
122
|
+
var result = await client.query(query).fetchUniqueRow();
|
|
123
|
+
return result.row;
|
|
124
|
+
}
|
|
125
|
+
catch (err) {
|
|
126
|
+
console.log('ERROR', err.message);
|
|
127
|
+
throw err;
|
|
128
|
+
}
|
|
129
|
+
;
|
|
130
|
+
}
|
|
131
|
+
},
|
|
132
|
+
{
|
|
133
|
+
action: 'presupuesto_cargar',
|
|
134
|
+
parameters: [
|
|
135
|
+
{ name: 'presupuesto', typeName: 'integer' },
|
|
136
|
+
],
|
|
137
|
+
coreFunction: async function (context, parameters) {
|
|
138
|
+
var client = context.client;
|
|
139
|
+
var query = `
|
|
140
|
+
SELECT
|
|
141
|
+
COALESCE(
|
|
142
|
+
(SELECT to_jsonb(j.*)
|
|
143
|
+
from (
|
|
144
|
+
SELECT *
|
|
145
|
+
from presupuestos
|
|
146
|
+
where presupuesto = $1
|
|
147
|
+
) as j
|
|
148
|
+
)
|
|
149
|
+
,'{}'::jsonb
|
|
150
|
+
) as presupuesto,
|
|
151
|
+
COALESCE(
|
|
152
|
+
(SELECT to_jsonb(j.*)
|
|
153
|
+
from (
|
|
154
|
+
SELECT *
|
|
155
|
+
FROM clientes
|
|
156
|
+
where cliente = (select cliente from presupuestos where presupuesto = $1)
|
|
157
|
+
) as j
|
|
158
|
+
),'{}'::jsonb
|
|
159
|
+
) as cliente,
|
|
160
|
+
${json(`
|
|
161
|
+
SELECT *
|
|
162
|
+
FROM items_presupuesto
|
|
163
|
+
where presupuesto = $1
|
|
164
|
+
`, 'numero_linea')} as "items"
|
|
165
|
+
`;
|
|
166
|
+
try {
|
|
167
|
+
var result = await client.query(query, [parameters.presupuesto]).fetchUniqueRow();
|
|
168
|
+
return result.row;
|
|
169
|
+
}
|
|
170
|
+
catch (err) {
|
|
171
|
+
console.log('ERROR', err.message);
|
|
172
|
+
throw err;
|
|
173
|
+
}
|
|
174
|
+
;
|
|
175
|
+
}
|
|
176
|
+
},
|
|
177
|
+
{
|
|
178
|
+
action: 'presupuesto_guardar',
|
|
179
|
+
parameters: [
|
|
180
|
+
{ name: 'presupuesto', typeName: 'jsonb' },
|
|
181
|
+
{ name: 'items', typeName: 'jsonb' },
|
|
182
|
+
{ name: 'cliente', typeName: 'jsonb' },
|
|
183
|
+
],
|
|
184
|
+
coreFunction: async function (context, parameters) {
|
|
185
|
+
var client = context.client;
|
|
186
|
+
var presup = parameters.presupuesto;
|
|
187
|
+
var cliente = parameters.cliente;
|
|
188
|
+
var numeroPresupuesto;
|
|
189
|
+
try {
|
|
190
|
+
var presupuestoFieldsSql = `(fecha, cliente, estado, valido_hasta, subtotal, descuento, total, con_opciones, con_descuento_en_items) `;
|
|
191
|
+
var presupuestoValuesSql = `($1,$2,$3,$4,$5,$6,$7,$8,$9) `;
|
|
192
|
+
var presupuestoValues = [
|
|
193
|
+
presup.fecha,
|
|
194
|
+
cliente.cliente,
|
|
195
|
+
presup.estado,
|
|
196
|
+
presup.valido_hasta,
|
|
197
|
+
presup.subtotal,
|
|
198
|
+
presup.descuento,
|
|
199
|
+
presup.total,
|
|
200
|
+
presup.con_opciones,
|
|
201
|
+
presup.con_descuento_en_items
|
|
202
|
+
];
|
|
203
|
+
if (presup.presupuesto) {
|
|
204
|
+
await permiteEditarPresupuesto(presup.presupuesto, client);
|
|
205
|
+
numeroPresupuesto = presup.presupuesto;
|
|
206
|
+
await client.query(`delete from items_presupuesto where presupuesto = $1`, [numeroPresupuesto]).execute();
|
|
207
|
+
await client.query(`
|
|
208
|
+
update presupuestos
|
|
209
|
+
set ${presupuestoFieldsSql} = ${presupuestoValuesSql}
|
|
210
|
+
where presupuesto = $10
|
|
211
|
+
returning *
|
|
212
|
+
`, presupuestoValues.concat(presup.presupuesto)).fetchUniqueRow();
|
|
213
|
+
}
|
|
214
|
+
else {
|
|
215
|
+
numeroPresupuesto = (await client.query(`
|
|
216
|
+
insert into
|
|
217
|
+
presupuestos ${presupuestoFieldsSql}
|
|
218
|
+
values ${presupuestoValuesSql}
|
|
219
|
+
returning *
|
|
220
|
+
`, presupuestoValues).fetchUniqueRow()).row.presupuesto;
|
|
221
|
+
}
|
|
222
|
+
for (let item of parameters.items) {
|
|
223
|
+
await client.query(`
|
|
224
|
+
insert
|
|
225
|
+
into items_presupuesto (presupuesto, cantidad, producto, nombre, descripcion, precio_unitario, porcentaje_descuento, descuento, total)
|
|
226
|
+
values ($1,$2,$3,$4,$5,$6,$7,$8,$9)
|
|
227
|
+
`, [numeroPresupuesto, item.cantidad, item.producto, item.nombre, item.descripcion, item.precio_unitario, item.porcentaje_descuento, item.descuento, item.total])
|
|
228
|
+
.execute();
|
|
229
|
+
}
|
|
230
|
+
return { estado: 'ok', presupuesto: numeroPresupuesto };
|
|
231
|
+
}
|
|
232
|
+
catch (err) {
|
|
233
|
+
console.log('ERROR', err.message);
|
|
234
|
+
throw err;
|
|
235
|
+
}
|
|
236
|
+
;
|
|
237
|
+
}
|
|
238
|
+
},
|
|
239
|
+
{
|
|
240
|
+
action: 'presupuesto_anular',
|
|
241
|
+
parameters: [
|
|
242
|
+
{ name: 'presupuesto', typeName: 'integer' },
|
|
243
|
+
],
|
|
244
|
+
coreFunction: async function (context, parameters) {
|
|
245
|
+
var client = context.client;
|
|
246
|
+
var db = context.be.db;
|
|
247
|
+
var nroPresup = parameters.presupuesto;
|
|
248
|
+
try {
|
|
249
|
+
await permiteEditarPresupuesto(nroPresup, client);
|
|
250
|
+
await client.query(`
|
|
251
|
+
update presupuestos
|
|
252
|
+
set estado = $2
|
|
253
|
+
where presupuesto = $1
|
|
254
|
+
returning *
|
|
255
|
+
`, [nroPresup, ESTADO_ANULADO_PRESUPUESTO]).fetchUniqueRow();
|
|
256
|
+
return { estado: 'ok' };
|
|
257
|
+
}
|
|
258
|
+
catch (err) {
|
|
259
|
+
console.log('ERROR', err.message);
|
|
260
|
+
throw err;
|
|
261
|
+
}
|
|
262
|
+
;
|
|
263
|
+
}
|
|
264
|
+
},
|
|
265
|
+
{
|
|
266
|
+
action: 'presupuesto_rechazar',
|
|
267
|
+
parameters: [
|
|
268
|
+
{ name: 'presupuesto', typeName: 'integer' },
|
|
269
|
+
],
|
|
270
|
+
coreFunction: async function (context, parameters) {
|
|
271
|
+
var client = context.client;
|
|
272
|
+
var db = context.be.db;
|
|
273
|
+
var nroPresup = parameters.presupuesto;
|
|
274
|
+
try {
|
|
275
|
+
await permiteEditarPresupuesto(nroPresup, client);
|
|
276
|
+
await client.query(`
|
|
277
|
+
update presupuestos
|
|
278
|
+
set estado = $2
|
|
279
|
+
where presupuesto = $1
|
|
280
|
+
returning *
|
|
281
|
+
`, [nroPresup, ESTADO_RECHAZADO_PRESUPUESTO]).fetchUniqueRow();
|
|
282
|
+
return { estado: 'ok' };
|
|
283
|
+
}
|
|
284
|
+
catch (err) {
|
|
285
|
+
console.log('ERROR', err.message);
|
|
286
|
+
throw err;
|
|
287
|
+
}
|
|
288
|
+
;
|
|
289
|
+
}
|
|
290
|
+
},
|
|
291
|
+
{
|
|
292
|
+
action: 'pedido_cargar',
|
|
293
|
+
parameters: [
|
|
294
|
+
{ name: 'pedido', typeName: 'integer' },
|
|
295
|
+
],
|
|
296
|
+
coreFunction: async function (context, parameters) {
|
|
297
|
+
var client = context.client;
|
|
298
|
+
var query = `
|
|
299
|
+
SELECT
|
|
300
|
+
COALESCE(
|
|
301
|
+
(SELECT to_jsonb(j.*)
|
|
302
|
+
from (
|
|
303
|
+
SELECT *
|
|
304
|
+
from pedidos
|
|
305
|
+
where pedido = $1
|
|
306
|
+
) as j
|
|
307
|
+
)
|
|
308
|
+
,'{}'::jsonb
|
|
309
|
+
) as pedido,
|
|
310
|
+
COALESCE(
|
|
311
|
+
(SELECT to_jsonb(j.*)
|
|
312
|
+
from (
|
|
313
|
+
SELECT *
|
|
314
|
+
FROM clientes
|
|
315
|
+
where cliente = (select cliente from pedidos where pedido = $1)
|
|
316
|
+
) as j
|
|
317
|
+
),'{}'::jsonb
|
|
318
|
+
) as cliente,
|
|
319
|
+
${json(`
|
|
320
|
+
SELECT *
|
|
321
|
+
FROM items_pedido
|
|
322
|
+
where pedido = $1
|
|
323
|
+
`, 'numero_linea')} as "items"
|
|
324
|
+
`;
|
|
325
|
+
try {
|
|
326
|
+
var result = await client.query(query, [parameters.pedido]).fetchUniqueRow();
|
|
327
|
+
return result.row;
|
|
328
|
+
}
|
|
329
|
+
catch (err) {
|
|
330
|
+
console.log('ERROR', err.message);
|
|
331
|
+
throw err;
|
|
332
|
+
}
|
|
333
|
+
;
|
|
334
|
+
}
|
|
335
|
+
},
|
|
336
|
+
{
|
|
337
|
+
// TODO -> stock (puede ir en trigger)
|
|
338
|
+
action: 'pedido_guardar',
|
|
339
|
+
parameters: [
|
|
340
|
+
{ name: 'pedido', typeName: 'jsonb' },
|
|
341
|
+
{ name: 'items', typeName: 'jsonb' },
|
|
342
|
+
{ name: 'cliente', typeName: 'jsonb' },
|
|
343
|
+
],
|
|
344
|
+
coreFunction: async function (context, parameters) {
|
|
345
|
+
var client = context.client;
|
|
346
|
+
var pedido = parameters.pedido;
|
|
347
|
+
var cliente = parameters.cliente;
|
|
348
|
+
var numeroPedido;
|
|
349
|
+
try {
|
|
350
|
+
var pedidoFieldsSql = `(presupuesto, fecha, cliente, estado, fecha_entrega, subtotal, descuento, total, observaciones) `;
|
|
351
|
+
var pedidoValuesSql = `($1,$2,$3,$4,$5,$6,$7,$8, $9) `;
|
|
352
|
+
var pedidoValues = [
|
|
353
|
+
pedido.presupuesto,
|
|
354
|
+
pedido.fecha,
|
|
355
|
+
cliente.cliente,
|
|
356
|
+
pedido.estado,
|
|
357
|
+
pedido.fecha_entrega,
|
|
358
|
+
pedido.subtotal,
|
|
359
|
+
pedido.descuento,
|
|
360
|
+
pedido.total,
|
|
361
|
+
pedido.observaciones
|
|
362
|
+
];
|
|
363
|
+
if (pedido.pedido) {
|
|
364
|
+
numeroPedido = pedido.pedido;
|
|
365
|
+
await client.query(`delete from items_pedido where pedido = $1`, [numeroPedido]).execute();
|
|
366
|
+
await client.query(`
|
|
367
|
+
update pedidos
|
|
368
|
+
set ${pedidoFieldsSql} = ${pedidoValuesSql}
|
|
369
|
+
where pedido = $10
|
|
370
|
+
returning *
|
|
371
|
+
`, pedidoValues.concat(pedido.pedido)).fetchUniqueRow();
|
|
372
|
+
}
|
|
373
|
+
else {
|
|
374
|
+
pedido.presupuesto ? await permiteEditarPresupuesto(pedido.presupuesto, client) : null;
|
|
375
|
+
numeroPedido = (await client.query(`
|
|
376
|
+
insert into
|
|
377
|
+
pedidos ${pedidoFieldsSql}
|
|
378
|
+
values ${pedidoValuesSql}
|
|
379
|
+
returning *
|
|
380
|
+
`, pedidoValues).fetchUniqueRow()).row.pedido;
|
|
381
|
+
}
|
|
382
|
+
for (let item of parameters.items) {
|
|
383
|
+
await client.query(`
|
|
384
|
+
insert
|
|
385
|
+
into items_pedido (pedido, cantidad, producto, nombre, descripcion, precio_unitario, porcentaje_descuento, descuento, total)
|
|
386
|
+
values ($1,$2,$3,$4,$5,$6,$7,$8,$9)
|
|
387
|
+
`, [numeroPedido, item.cantidad, item.producto, item.nombre, item.descripcion, item.precio_unitario, item.porcentaje_descuento, item.descuento, item.total])
|
|
388
|
+
.execute();
|
|
389
|
+
}
|
|
390
|
+
if (pedido.presupuesto) {
|
|
391
|
+
await client.query(`
|
|
392
|
+
update presupuestos
|
|
393
|
+
set estado = $1
|
|
394
|
+
where presupuesto = $2
|
|
395
|
+
returning *
|
|
396
|
+
`, [ESTADO_ACEPTADO_PRESUPUESTO, pedido.presupuesto]).fetchUniqueRow();
|
|
397
|
+
try {
|
|
398
|
+
await client.query(`
|
|
399
|
+
select presupuesto
|
|
400
|
+
from pedidos
|
|
401
|
+
where presupuesto = $1
|
|
402
|
+
`, [pedido.presupuesto]).fetchUniqueValue();
|
|
403
|
+
}
|
|
404
|
+
catch (err) {
|
|
405
|
+
throw Error(`El presupuesto ${pedido.presupuesto} ya tiene un pedido creado. ` + err.message);
|
|
406
|
+
}
|
|
407
|
+
}
|
|
408
|
+
return { estado: 'ok', pedido: numeroPedido };
|
|
409
|
+
}
|
|
410
|
+
catch (err) {
|
|
411
|
+
console.log('ERROR', err.message);
|
|
412
|
+
throw err;
|
|
413
|
+
}
|
|
414
|
+
;
|
|
415
|
+
}
|
|
416
|
+
},
|
|
417
|
+
{
|
|
418
|
+
action: 'producto_clonar',
|
|
419
|
+
parameters: [
|
|
420
|
+
{ name: 'producto', typeName: 'integer' },
|
|
421
|
+
],
|
|
422
|
+
coreFunction: async function (context, parameters) {
|
|
423
|
+
var client = context.client;
|
|
424
|
+
var be = context.be;
|
|
425
|
+
var producto = parameters.producto;
|
|
426
|
+
//clonacion producto
|
|
427
|
+
var productoAClonar = (await client.query(`select * from productos where producto = $1`, [producto]).fetchUniqueRow()).row;
|
|
428
|
+
delete (productoAClonar.producto);
|
|
429
|
+
delete (productoAClonar.stock);
|
|
430
|
+
delete (productoAClonar.stock_minimo);
|
|
431
|
+
delete (productoAClonar.stock_maximo);
|
|
432
|
+
var productoKeys = [];
|
|
433
|
+
var productoValues = [];
|
|
434
|
+
for (let key in productoAClonar) {
|
|
435
|
+
productoKeys.push(be.db.quoteIdent(key));
|
|
436
|
+
productoValues.push(be.db.quoteNullable(productoAClonar[key]));
|
|
437
|
+
}
|
|
438
|
+
var productoNuevo = (await client.query(`insert into productos (${productoKeys.join(',')}) values (${productoValues.join(',')}) returning *`, []).fetchUniqueRow()).row;
|
|
439
|
+
//clonacion insumos
|
|
440
|
+
var productosInsumosAClonar = (await client.query(`select * from productos_insumos where producto = $1`, [producto]).fetchAll()).rows;
|
|
441
|
+
var prodInsumosNuevos = [];
|
|
442
|
+
for (var prodInsumo of productosInsumosAClonar) {
|
|
443
|
+
prodInsumo.producto = productoNuevo.producto;
|
|
444
|
+
var prodInsumoKeys = [];
|
|
445
|
+
var prodInsumoValues = [];
|
|
446
|
+
for (let key in prodInsumo) {
|
|
447
|
+
prodInsumoKeys.push(be.db.quoteIdent(key));
|
|
448
|
+
prodInsumoValues.push(be.db.quoteNullable(prodInsumo[key]));
|
|
449
|
+
}
|
|
450
|
+
prodInsumosNuevos.push((await client.query(`
|
|
451
|
+
insert into
|
|
452
|
+
productos_insumos (${prodInsumoKeys.join(',')})
|
|
453
|
+
values (${prodInsumoValues.join(',')})
|
|
454
|
+
returning *`, []).fetchUniqueRow()).row);
|
|
455
|
+
}
|
|
456
|
+
return { estado: 'ok', productoNuevo, prodInsumosNuevos };
|
|
457
|
+
}
|
|
458
|
+
},
|
|
459
|
+
{
|
|
460
|
+
action: 'object_get',
|
|
461
|
+
parameters: [
|
|
462
|
+
{ name: 'tablename', typeName: 'text' },
|
|
463
|
+
{ name: 'pk_values', typeName: 'jsonb' },
|
|
464
|
+
],
|
|
465
|
+
coreFunction: async function (context, parameters) {
|
|
466
|
+
var client = context.client;
|
|
467
|
+
var query = sqlTools.structuredData.sqlRead(parameters.pk_values, createStructure(context, parameters.tablename));
|
|
468
|
+
try {
|
|
469
|
+
var result = await client.query(query).fetchUniqueValue();
|
|
470
|
+
return result.value;
|
|
471
|
+
}
|
|
472
|
+
catch (err) {
|
|
473
|
+
console.log('ERROR', err.message);
|
|
474
|
+
throw err;
|
|
475
|
+
}
|
|
476
|
+
;
|
|
477
|
+
}
|
|
478
|
+
},
|
|
479
|
+
{
|
|
480
|
+
action: 'object_save',
|
|
481
|
+
parameters: [
|
|
482
|
+
{ name: 'tablename', typeName: 'text' },
|
|
483
|
+
{ name: 'datos', typeName: 'jsonb' },
|
|
484
|
+
],
|
|
485
|
+
coreFunction: async function (context, parameters) {
|
|
486
|
+
var be = context.be;
|
|
487
|
+
var client = context.client;
|
|
488
|
+
var queries = sqlTools.structuredData.sqlWrite(parameters.datos, createStructure(context, parameters.tablename));
|
|
489
|
+
console.log("#############", queries);
|
|
490
|
+
return await queries.reduce(function (promise, query) {
|
|
491
|
+
return promise.then(function () {
|
|
492
|
+
return client.query(query).execute().then(function () {
|
|
493
|
+
return 'ok';
|
|
494
|
+
});
|
|
495
|
+
});
|
|
496
|
+
}, Promise.resolve()).then(async function () {
|
|
497
|
+
//TODO: traer json refrescado
|
|
498
|
+
//var result = await be.procedure.object_get.coreFunction(context, {tablename:parameters.tablename, });
|
|
499
|
+
return 'ok';
|
|
500
|
+
}).catch(function (err) {
|
|
501
|
+
console.log("ENTRA EN EL CATCH: ", err);
|
|
502
|
+
throw err;
|
|
503
|
+
});
|
|
504
|
+
}
|
|
505
|
+
},
|
|
506
|
+
];
|
|
507
|
+
});
|
|
508
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"procedures-contable.js","sourceRoot":"","sources":["../../../src/server/procedures-contable.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;IAAA,YAAY,CAAC;;;IAOb,mDAAiC;IAEjC,+CAAuD;IAIvD,IAAI,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAC3B,IAAI,QAAQ,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IAGpC,MAAM,2BAA2B,GAAI,UAAU,CAAC;IAChD,MAAM,0BAA0B,GAAK,SAAS,CAAC;IAC/C,MAAM,4BAA4B,GAAG,WAAW,CAAC;IAEjD,SAAS,IAAI,CAAC,GAAG,EAAE,OAAO;QACtB,OAAO,qDAAqD,OAAO,WAAW,GAAG,sBAAsB,CAAA;IAC3G,CAAC;IAED,SAAS,KAAK,CAAC,GAAG,EAAE,SAAS;QACzB,OAAO,qCAAqC,SAAS,yBAAyB,GAAG,sBAAsB,CAAA;IAC3G,CAAC;IAED,IAAI,eAAe,GAAG,SAAS,eAAe,CAAC,OAAe,EAAE,SAAgB;QAC5E,IAAI,EAAE,GAAG,OAAO,CAAC,EAAE,CAAC;QACpB,IAAI,YAAY,GAAmB,EAAE,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC;QAC1E,IAAI,iBAAiB,GAAG,SAAS,iBAAiB,CAAC,QAAwB;YACvE,OAAO,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,UAAS,EAAE;gBACtC,OAAO,EAAC,SAAS,EAAC,EAAE,EAAC,CAAC;YAC1B,CAAC,CAAC,CAAA;QACN,CAAC,CAAC;QACF,IAAI,iBAAiB,GAAG,SAAS,iBAAiB,CAAC,QAAwB;YACvE,OAAO,QAAQ,CAAC,WAAW,CAAC,GAAG,CAAC,UAAS,EAAE;gBACvC,OAAO,EAAE,CAAC,MAAM,CAAA;YACpB,CAAC,CAAC,CAAC;QACP,CAAC,CAAA;QACD,IAAI,MAAM,GAAC;YACP,SAAS,EAAC,YAAY,CAAC,IAAI;YAC3B,QAAQ,EAAC,iBAAiB,CAAC,YAAY,CAAC;SAC3C,CAAC;QACF,MAAM,CAAC,WAAW,GAAC,EAAE,CAAC;QACtB,IAAG,YAAY,CAAC,YAAY,IAAI,YAAY,CAAC,YAAY,CAAC,MAAM,EAAC,CAAC;YAC9D,YAAY,CAAC,YAAY,CAAC,OAAO,CAAC,UAAS,WAAW;gBAClD,MAAM,CAAC,WAAW,CAAC,IAAI,CACnB,IAAA,uBAAQ,EACJ,eAAe,CAAC,OAAO,EAAE,WAAW,CAAC,KAAK,CAAC,EAC3C,iBAAiB,CAAC,EAAE,CAAC,eAAe,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CACpE,CACJ,CAAC;YACN,CAAC,CAAC,CAAA;QACN,CAAC;QACD,OAAO,MAAM,CAAC;IAClB,CAAC,CAAA;IAED,KAAK,UAAU,wBAAwB,CAAC,SAAgB,EAAE,MAAa;QACnE,IAAG,CAAC,CAAC,MAAM,MAAM,CAAC,KAAK,CAAC;;;;KAIvB,EAAC,CAAC,SAAS,CAAC,CAAC,CAAC,mBAAmB,EAAE,CAAC,CAAC,GAAG,CAAC,cAAc,EAAC,CAAC;YACtD,2CAA2C;YAC3C,MAAM,KAAK,CAAE,oDAAoD,CAAC,CAAA;QACtE,CAAC;IACL,CAAC;IAEY,QAAA,kBAAkB,GAAoB;QAC/C;YACI,MAAM,EAAE,kBAAkB;YAC1B,UAAU,EAAE,EAAE;YACd,YAAY,EAAE,KAAK,WAAU,OAAwB,EAAE,WAAmC;gBACtF,IAAI,MAAM,GAAC,OAAO,CAAC,MAAM,CAAC;gBAC1B,IAAI,KAAK,GAAE;;sBAED,KAAK,CAAC;;;yBAGH,EACD,SAAS,CACZ;sBACC,KAAK,CAAC;;;;;;;;;;;;;;;;;;yBAkBH,EACD,UAAU,CACb;sBACC,KAAK,CAAC;;;yBAGH,EACD,WAAW,CACd;sBACC,IAAI,CAAC;;;yBAGF,EACD,OAAO,CACV;sBACC,IAAI,CAAC;;;yBAGF,EACD,OAAO,CACV;;;aAGR,CAAC;gBACF,IAAG,CAAC;oBACA,IAAI,MAAM,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,cAAc,EAAE,CAAC;oBACxD,OAAO,MAAM,CAAC,GAAG,CAAC;gBACtB,CAAC;gBAAA,OAAM,GAAG,EAAC,CAAC;oBACR,OAAO,CAAC,GAAG,CAAC,OAAO,EAAC,GAAG,CAAC,OAAO,CAAC,CAAC;oBACjC,MAAM,GAAG,CAAC;gBACd,CAAC;gBAAA,CAAC;YACN,CAAC;SACJ;QACD;YACI,MAAM,EAAE,oBAAoB;YAC5B,UAAU,EAAE;gBACR,EAAC,IAAI,EAAC,aAAa,EAAS,QAAQ,EAAC,SAAS,EAAC;aAClD;YACD,YAAY,EAAE,KAAK,WAAU,OAAwB,EAAE,UAAkC;gBACrF,IAAI,MAAM,GAAC,OAAO,CAAC,MAAM,CAAC;gBAC1B,IAAI,KAAK,GAAE;;;;;;;;;;;;;;;;;;;;;kBAqBL,IAAI,CAAC;;;;qBAIF,EACD,cAAc,CACjB;aACJ,CAAC;gBACF,IAAG,CAAC;oBACA,IAAI,MAAM,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC,KAAK,EAAC,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC;oBACjF,OAAO,MAAM,CAAC,GAAG,CAAC;gBACtB,CAAC;gBAAA,OAAM,GAAG,EAAC,CAAC;oBACR,OAAO,CAAC,GAAG,CAAC,OAAO,EAAC,GAAG,CAAC,OAAO,CAAC,CAAC;oBACjC,MAAM,GAAG,CAAC;gBACd,CAAC;gBAAA,CAAC;YACN,CAAC;SACJ;QACD;YACI,MAAM,EAAE,qBAAqB;YAC7B,UAAU,EAAC;gBACP,EAAC,IAAI,EAAC,aAAa,EAAS,QAAQ,EAAC,OAAO,EAAC;gBAC7C,EAAC,IAAI,EAAC,OAAO,EAAe,QAAQ,EAAC,OAAO,EAAC;gBAC7C,EAAC,IAAI,EAAC,SAAS,EAAa,QAAQ,EAAC,OAAO,EAAC;aAChD;YACD,YAAY,EAAE,KAAK,WAAU,OAAwB,EAAE,UAAkC;gBACrF,IAAI,MAAM,GAAC,OAAO,CAAC,MAAM,CAAC;gBAC1B,IAAI,MAAM,GAAG,UAAU,CAAC,WAAW,CAAC;gBACpC,IAAI,OAAO,GAAG,UAAU,CAAC,OAAO,CAAC;gBACjC,IAAI,iBAAiB,CAAC;gBACtB,IAAG,CAAC;oBACA,IAAI,oBAAoB,GAAG,2GAA2G,CAAC;oBACvI,IAAI,oBAAoB,GAAG,+BAA+B,CAAC;oBAC3D,IAAI,iBAAiB,GAAG;wBACpB,MAAM,CAAC,KAAK;wBACZ,OAAO,CAAC,OAAO;wBACf,MAAM,CAAC,MAAM;wBACb,MAAM,CAAC,YAAY;wBACnB,MAAM,CAAC,QAAQ;wBACf,MAAM,CAAC,SAAS;wBAChB,MAAM,CAAC,KAAK;wBACZ,MAAM,CAAC,YAAY;wBACnB,MAAM,CAAC,sBAAsB;qBAChC,CAAC;oBACF,IAAG,MAAM,CAAC,WAAW,EAAC,CAAC;wBACnB,MAAM,wBAAwB,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;wBAC3D,iBAAiB,GAAC,MAAM,CAAC,WAAW,CAAC;wBACrC,MAAM,MAAM,CAAC,KAAK,CAAC,sDAAsD,EAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;wBACzG,MAAM,MAAM,CAAC,KAAK,CAAC;;kCAEL,oBAAoB,MAAM,oBAAoB;;;qBAG3D,EAAC,iBAAiB,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC;oBACrE,CAAC;yBAAI,CAAC;wBACF,iBAAiB,GAAG,CAAC,MAAM,MAAM,CAAC,KAAK,CAAC;;2CAEjB,oBAAoB;qCAC1B,oBAAoB;;qBAEpC,EAAC,iBAAiB,CAAC,CAAC,cAAc,EAAE,CAAC,CAAC,GAAG,CAAC,WAAW,CAAA;oBAC1D,CAAC;oBACD,KAAI,IAAI,IAAI,IAAI,UAAU,CAAC,KAAK,EAAC,CAAC;wBAC9B,MAAM,MAAM,CAAC,KAAK,CAAC;;;;qBAIlB,EAAC,CAAC,iBAAiB,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,oBAAoB,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;6BAC/J,OAAO,EAAE,CAAC;oBACf,CAAC;oBACD,OAAO,EAAC,MAAM,EAAC,IAAI,EAAE,WAAW,EAAE,iBAAiB,EAAC,CAAC;gBACzD,CAAC;gBAAA,OAAM,GAAG,EAAC,CAAC;oBACR,OAAO,CAAC,GAAG,CAAC,OAAO,EAAC,GAAG,CAAC,OAAO,CAAC,CAAC;oBACjC,MAAM,GAAG,CAAC;gBACd,CAAC;gBAAA,CAAC;YACN,CAAC;SACJ;QACD;YACI,MAAM,EAAE,oBAAoB;YAC5B,UAAU,EAAC;gBACP,EAAC,IAAI,EAAC,aAAa,EAAS,QAAQ,EAAC,SAAS,EAAC;aAClD;YACD,YAAY,EAAE,KAAK,WAAU,OAAwB,EAAE,UAAkC;gBACrF,IAAI,MAAM,GAAC,OAAO,CAAC,MAAM,CAAC;gBAC1B,IAAI,EAAE,GAAI,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC;gBACxB,IAAI,SAAS,GAAG,UAAU,CAAC,WAAW,CAAC;gBACvC,IAAG,CAAC;oBACA,MAAM,wBAAwB,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;oBAClD,MAAM,MAAM,CAAC,KAAK,CAAC;;;;;iBAKlB,EAAC,CAAC,SAAS,EAAE,0BAA0B,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC;oBAC5D,OAAO,EAAC,MAAM,EAAC,IAAI,EAAC,CAAC;gBACzB,CAAC;gBAAA,OAAM,GAAG,EAAC,CAAC;oBACR,OAAO,CAAC,GAAG,CAAC,OAAO,EAAC,GAAG,CAAC,OAAO,CAAC,CAAC;oBACjC,MAAM,GAAG,CAAC;gBACd,CAAC;gBAAA,CAAC;YACN,CAAC;SACJ;QACD;YACI,MAAM,EAAE,sBAAsB;YAC9B,UAAU,EAAC;gBACP,EAAC,IAAI,EAAC,aAAa,EAAS,QAAQ,EAAC,SAAS,EAAC;aAClD;YACD,YAAY,EAAE,KAAK,WAAU,OAAwB,EAAE,UAAkC;gBACrF,IAAI,MAAM,GAAC,OAAO,CAAC,MAAM,CAAC;gBAC1B,IAAI,EAAE,GAAI,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC;gBACxB,IAAI,SAAS,GAAG,UAAU,CAAC,WAAW,CAAC;gBACvC,IAAG,CAAC;oBACA,MAAM,wBAAwB,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;oBAClD,MAAM,MAAM,CAAC,KAAK,CAAC;;;;;iBAKlB,EAAC,CAAC,SAAS,EAAE,4BAA4B,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC;oBAC9D,OAAO,EAAC,MAAM,EAAC,IAAI,EAAC,CAAC;gBACzB,CAAC;gBAAA,OAAM,GAAG,EAAC,CAAC;oBACR,OAAO,CAAC,GAAG,CAAC,OAAO,EAAC,GAAG,CAAC,OAAO,CAAC,CAAC;oBACjC,MAAM,GAAG,CAAC;gBACd,CAAC;gBAAA,CAAC;YACN,CAAC;SACJ;QACD;YACI,MAAM,EAAE,eAAe;YACvB,UAAU,EAAE;gBACR,EAAC,IAAI,EAAC,QAAQ,EAAS,QAAQ,EAAC,SAAS,EAAC;aAC7C;YACD,YAAY,EAAE,KAAK,WAAU,OAAwB,EAAE,UAAkC;gBACrF,IAAI,MAAM,GAAC,OAAO,CAAC,MAAM,CAAC;gBAC1B,IAAI,KAAK,GAAE;;;;;;;;;;;;;;;;;;;;;kBAqBL,IAAI,CAAC;;;;qBAIF,EACD,cAAc,CACjB;aACJ,CAAC;gBACF,IAAG,CAAC;oBACA,IAAI,MAAM,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC,KAAK,EAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC;oBAC5E,OAAO,MAAM,CAAC,GAAG,CAAC;gBACtB,CAAC;gBAAA,OAAM,GAAG,EAAC,CAAC;oBACR,OAAO,CAAC,GAAG,CAAC,OAAO,EAAC,GAAG,CAAC,OAAO,CAAC,CAAC;oBACjC,MAAM,GAAG,CAAC;gBACd,CAAC;gBAAA,CAAC;YACN,CAAC;SACJ;QACD;YACI,sCAAsC;YACtC,MAAM,EAAE,gBAAgB;YACxB,UAAU,EAAC;gBACP,EAAC,IAAI,EAAC,QAAQ,EAAc,QAAQ,EAAC,OAAO,EAAC;gBAC7C,EAAC,IAAI,EAAC,OAAO,EAAe,QAAQ,EAAC,OAAO,EAAC;gBAC7C,EAAC,IAAI,EAAC,SAAS,EAAa,QAAQ,EAAC,OAAO,EAAC;aAChD;YACD,YAAY,EAAE,KAAK,WAAU,OAAwB,EAAE,UAAkC;gBACrF,IAAI,MAAM,GAAC,OAAO,CAAC,MAAM,CAAC;gBAC1B,IAAI,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;gBAC/B,IAAI,OAAO,GAAG,UAAU,CAAC,OAAO,CAAC;gBACjC,IAAI,YAAY,CAAC;gBACjB,IAAG,CAAC;oBACA,IAAI,eAAe,GAAG,kGAAkG,CAAC;oBACzH,IAAI,eAAe,GAAG,gCAAgC,CAAC;oBACvD,IAAI,YAAY,GAAG;wBACf,MAAM,CAAC,WAAW;wBAClB,MAAM,CAAC,KAAK;wBACZ,OAAO,CAAC,OAAO;wBACf,MAAM,CAAC,MAAM;wBACb,MAAM,CAAC,aAAa;wBACpB,MAAM,CAAC,QAAQ;wBACf,MAAM,CAAC,SAAS;wBAChB,MAAM,CAAC,KAAK;wBACZ,MAAM,CAAC,aAAa;qBACvB,CAAC;oBACF,IAAG,MAAM,CAAC,MAAM,EAAC,CAAC;wBACd,YAAY,GAAC,MAAM,CAAC,MAAM,CAAC;wBAC3B,MAAM,MAAM,CAAC,KAAK,CAAC,4CAA4C,EAAC,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;wBAC1F,MAAM,MAAM,CAAC,KAAK,CAAC;;kCAEL,eAAe,MAAM,eAAe;;;qBAGjD,EAAC,YAAY,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC;oBAC3D,CAAC;yBAAI,CAAC;wBACF,MAAM,CAAC,WAAW,CAAA,CAAC,CAAA,MAAM,wBAAwB,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,CAAA,CAAC,CAAA,IAAI,CAAC;wBACnF,YAAY,GAAG,CAAC,MAAM,MAAM,CAAC,KAAK,CAAC;;sCAEjB,eAAe;qCAChB,eAAe;;qBAE/B,EAAC,YAAY,CAAC,CAAC,cAAc,EAAE,CAAC,CAAC,GAAG,CAAC,MAAM,CAAA;oBAChD,CAAC;oBACD,KAAI,IAAI,IAAI,IAAI,UAAU,CAAC,KAAK,EAAC,CAAC;wBAC9B,MAAM,MAAM,CAAC,KAAK,CAAC;;;;qBAIlB,EAAC,CAAC,YAAY,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,oBAAoB,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;6BAC1J,OAAO,EAAE,CAAC;oBACf,CAAC;oBACD,IAAG,MAAM,CAAC,WAAW,EAAC,CAAC;wBACnB,MAAM,MAAM,CAAC,KAAK,CAAC;;;;;qBAKlB,EAAC,CAAC,2BAA2B,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC;wBACtE,IAAG,CAAC;4BACA,MAAM,MAAM,CAAC,KAAK,CAAC;;;;yBAIlB,EAAC,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,gBAAgB,EAAE,CAAC;wBAC/C,CAAC;wBAAA,OAAM,GAAG,EAAC,CAAC;4BACR,MAAM,KAAK,CAAC,kBAAkB,MAAM,CAAC,WAAW,8BAA8B,GAAG,GAAG,CAAC,OAAO,CAAC,CAAA;wBACjG,CAAC;oBACL,CAAC;oBACD,OAAO,EAAC,MAAM,EAAC,IAAI,EAAE,MAAM,EAAE,YAAY,EAAC,CAAC;gBAC/C,CAAC;gBAAA,OAAM,GAAG,EAAC,CAAC;oBACR,OAAO,CAAC,GAAG,CAAC,OAAO,EAAC,GAAG,CAAC,OAAO,CAAC,CAAC;oBACjC,MAAM,GAAG,CAAC;gBACd,CAAC;gBAAA,CAAC;YACN,CAAC;SACJ;QACD;YACI,MAAM,EAAE,iBAAiB;YACzB,UAAU,EAAC;gBACP,EAAC,IAAI,EAAC,UAAU,EAAS,QAAQ,EAAC,SAAS,EAAC;aAC/C;YACD,YAAY,EAAE,KAAK,WAAU,OAAwB,EAAE,UAAkC;gBACrF,IAAI,MAAM,GAAC,OAAO,CAAC,MAAM,CAAC;gBAC1B,IAAI,EAAE,GAAG,OAAO,CAAC,EAAE,CAAC;gBACpB,IAAI,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAAC;gBAEnC,oBAAoB;gBACpB,IAAI,eAAe,GAAG,CAAC,MAAM,MAAM,CAAC,KAAK,CAAC,6CAA6C,EAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC,CAAC,GAAG,CAAC;gBAC1H,OAAM,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;gBACjC,OAAM,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;gBAC9B,OAAM,CAAC,eAAe,CAAC,YAAY,CAAC,CAAC;gBACrC,OAAM,CAAC,eAAe,CAAC,YAAY,CAAC,CAAC;gBACrC,IAAI,YAAY,GAAC,EAAE,CAAC;gBACpB,IAAI,cAAc,GAAC,EAAE,CAAC;gBACtB,KAAI,IAAI,GAAG,IAAI,eAAe,EAAC,CAAC;oBAC5B,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;oBACzC,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,aAAa,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBACnE,CAAC;gBACD,IAAI,aAAa,GAAG,CAAC,MAAM,MAAM,CAAC,KAAK,CAAC,0BAA0B,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,eAAe,EAAC,EAAE,CAAC,CAAC,cAAc,EAAE,CAAC,CAAC,GAAG,CAAA;gBACtK,mBAAmB;gBACnB,IAAI,uBAAuB,GAAG,CAAC,MAAM,MAAM,CAAC,KAAK,CAAC,qDAAqD,EAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC;gBACrI,IAAI,iBAAiB,GAAC,EAAE,CAAC;gBACzB,KAAI,IAAI,UAAU,IAAI,uBAAuB,EAAC,CAAC;oBAC3C,UAAU,CAAC,QAAQ,GAAC,aAAa,CAAC,QAAQ,CAAC;oBAC3C,IAAI,cAAc,GAAC,EAAE,CAAC;oBACtB,IAAI,gBAAgB,GAAC,EAAE,CAAC;oBACxB,KAAI,IAAI,GAAG,IAAI,UAAU,EAAC,CAAC;wBACvB,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;wBAC3C,gBAAgB,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,aAAa,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;oBAChE,CAAC;oBACD,iBAAiB,CAAC,IAAI,CAClB,CAAC,MAAM,MAAM,CAAC,KAAK,CAAC;;iDAES,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC;sCACnC,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC;wCACxB,EAAC,EAAE,CAAC,CAAC,cAAc,EAAE,CACxC,CAAC,GAAG,CACR,CAAA;gBACL,CAAC;gBACD,OAAO,EAAC,MAAM,EAAC,IAAI,EAAE,aAAa,EAAE,iBAAiB,EAAC,CAAC;YAC3D,CAAC;SACJ;QACD;YACI,MAAM,EAAE,YAAY;YACpB,UAAU,EAAE;gBACR,EAAC,IAAI,EAAC,WAAW,EAAO,QAAQ,EAAC,MAAM,EAAC;gBACxC,EAAC,IAAI,EAAC,WAAW,EAAS,QAAQ,EAAC,OAAO,EAAC;aAC9C;YACD,YAAY,EAAE,KAAK,WAAU,OAAwB,EAAE,UAAkC;gBACrF,IAAI,MAAM,GAAC,OAAO,CAAC,MAAM,CAAC;gBAC1B,IAAI,KAAK,GAAG,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,UAAU,CAAC,SAAS,EAAE,eAAe,CAAC,OAAO,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;gBAClH,IAAG,CAAC;oBACA,IAAI,MAAM,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,gBAAgB,EAAE,CAAC;oBAC1D,OAAO,MAAM,CAAC,KAAK,CAAC;gBACxB,CAAC;gBAAA,OAAM,GAAG,EAAC,CAAC;oBACR,OAAO,CAAC,GAAG,CAAC,OAAO,EAAC,GAAG,CAAC,OAAO,CAAC,CAAC;oBACjC,MAAM,GAAG,CAAC;gBACd,CAAC;gBAAA,CAAC;YACN,CAAC;SACJ;QACD;YACI,MAAM,EAAC,aAAa;YACpB,UAAU,EAAC;gBACP,EAAC,IAAI,EAAC,WAAW,EAAK,QAAQ,EAAC,MAAM,EAAC;gBACtC,EAAC,IAAI,EAAC,OAAO,EAAS,QAAQ,EAAC,OAAO,EAAC;aAC1C;YACD,YAAY,EAAC,KAAK,WAAU,OAAwB,EAAE,UAAiC;gBACnF,IAAI,EAAE,GAAC,OAAO,CAAC,EAAE,CAAC;gBAClB,IAAI,MAAM,GAAC,OAAO,CAAC,MAAM,CAAC;gBAC1B,IAAI,OAAO,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,UAAU,CAAC,KAAK,EAAE,eAAe,CAAC,OAAO,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;gBACjH,OAAO,CAAC,GAAG,CAAC,eAAe,EAAC,OAAO,CAAC,CAAA;gBACpC,OAAO,MAAM,OAAO,CAAC,MAAM,CAAC,UAAS,OAAoB,EAAE,KAAY;oBACnE,OAAO,OAAO,CAAC,IAAI,CAAC;wBAChB,OAAO,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC;4BACtC,OAAO,IAAI,CAAC;wBAChB,CAAC,CAAC,CAAC;oBACP,CAAC,CAAC,CAAC;gBACP,CAAC,EAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK;oBAC3B,6BAA6B;oBAC7B,uGAAuG;oBACvG,OAAO,IAAI,CAAC;gBAChB,CAAC,CAAC,CAAC,KAAK,CAAC,UAAS,GAAS;oBACvB,OAAO,CAAC,GAAG,CAAC,qBAAqB,EAAC,GAAG,CAAC,CAAA;oBACtC,MAAM,GAAG,CAAA;gBACb,CAAC,CAAC,CAAA;YACN,CAAC;SACJ;KACJ,CAAC","sourcesContent":["\"use strict\";\r\n\r\nimport { ProcedureDef, TableDefinition, Client } from \"./types-contable\";\r\nimport { ProcedureContext, CoreFunctionParameters, Context, ForeignKey, coreFunctionParameters } from \"backend-plus\";\r\nimport { Cliente } from \"../client/tipos\";\r\n\r\nimport * as likeAr from \"like-ar\";\r\nexport * from \"./types-contable\";\r\nimport {json, jsono} from \"pg-promise-strict\";\r\nimport {changing, datetime, date } from 'best-globals';\r\n\r\nimport {promises as  fs} from \"fs\";\r\nimport { create } from \"domain\";\r\nvar path = require('path');\r\nvar sqlTools = require('sql-tools');\r\ntype AnyObject = {[k:string]:any}\r\n\r\nconst ESTADO_ACEPTADO_PRESUPUESTO  = 'aceptado';\r\nconst ESTADO_ANULADO_PRESUPUESTO   = 'anulado';\r\nconst ESTADO_RECHAZADO_PRESUPUESTO = 'rechazado';\r\n\r\nfunction json(sql, orderby){\r\n    return `COALESCE((SELECT jsonb_agg(to_jsonb(j.*) ORDER BY ${orderby}) from (${sql}) as j),'[]'::jsonb)`\r\n}\r\n\r\nfunction jsono(sql, indexedby){\r\n    return `COALESCE((SELECT jsonb_object_agg(${indexedby},to_jsonb(j.*)) from (${sql}) as j),'{}'::jsonb)`\r\n}\r\n\r\nvar createStructure = function createStructure(context:Context, tableName:string){\r\n    var be = context.be;\r\n    var mainTableDef:TableDefinition = be.tableStructures[tableName](context);\r\n    var getPkFromTableDef = function getPkFromTableDef(tableDef:TableDefinition){\r\n        return tableDef.primaryKey.map(function(pk){\r\n            return {fieldName:pk};\r\n        })\r\n    };\r\n    var getFkFromTableDef = function getFkFromTableDef(tableDef:TableDefinition){\r\n        return tableDef.foreignKeys.map(function(fk){\r\n            return fk.fields\r\n        });\r\n    }\r\n    var struct={\r\n        tableName:mainTableDef.name,\r\n        pkFields:getPkFromTableDef(mainTableDef),\r\n    };\r\n    struct.childTables=[];\r\n    if(mainTableDef.detailTables && mainTableDef.detailTables.length){\r\n        mainTableDef.detailTables.forEach(function(detailTable){\r\n            struct.childTables.push(\r\n                changing(\r\n                    createStructure(context, detailTable.table),\r\n                    getFkFromTableDef(be.tableStructures[detailTable.table](context))\r\n                )\r\n            );\r\n        })\r\n    }\r\n    return struct;\r\n}\r\n\r\nasync function permiteEditarPresupuesto(nroPresup:number, client:Client){\r\n    if(!(await client.query(`\r\n        select * \r\n            from presupuestos inner join estados_presupuesto using (estado)\r\n            where presupuesto = $1\r\n    `,[nroPresup]).fetchOneRowIfExists()).row.permite_editar){\r\n        //si el estado no permite editar tira error\r\n        throw Error ('No se puede editar ya que su estado no lo permite.') \r\n    }\r\n}\r\n\r\nexport const ProceduresContable : ProcedureDef[] = [\r\n    {\r\n        action: 'estructura_crear',\r\n        parameters: [],\r\n        coreFunction: async function(context:ProcedureContext, _parameters: coreFunctionParameters){\r\n            var client=context.client;\r\n            var query =`\r\n                SELECT \r\n                    ${jsono(`\r\n                        SELECT *\r\n                            FROM clientes\r\n                        `,\r\n                        'cliente'\r\n                    )} as clientes,\r\n                    ${jsono(`\r\n                        select p.*, \r\n                                sum(i.costo_unitario*i.utilidad*pi.cantidad_insumo) as total_insumos, \r\n                                precio_sin_insumos + coalesce(sum(i.costo_unitario*i.utilidad*pi.cantidad_insumo),0) as precio\r\n                            from productos p \r\n                                left join productos_insumos pi using (producto) \r\n                                left join insumos i using (insumo)\r\n                            where p.producto > 0\r\n                            group by p.producto,\r\n                                    p.categoria,\r\n                                    p.nombre,\r\n                                    p.descripcion,\r\n                                    p.habilitado,\r\n                                    p.precio_sin_insumos,\r\n                                    p.stock,\r\n                                    p.stock_minimo,\r\n                                    p.stock_maximo,\r\n                                    p.iva\r\n                        `,\r\n                        'producto'\r\n                    )} as productos,\r\n                    ${jsono(`\r\n                        SELECT *\r\n                            FROM condicion_iva\r\n                        `,\r\n                        'condicion'\r\n                    )} as \"condicionesIva\",\r\n                    ${json(`\r\n                        SELECT *\r\n                            FROM estados_presupuesto\r\n                        `,\r\n                        'orden'\r\n                    )} as \"estadosPresupuesto\",\r\n                    ${json(`\r\n                        SELECT *\r\n                            FROM estados_pedido\r\n                        `,\r\n                        'orden'\r\n                    )} as \"estadosPedido\",\r\n                    (SELECT to_jsonb(j.*) \r\n                      from (select legales_pedido, legales_presupuesto from parametros) as j) as parametros\r\n            `;\r\n            try{\r\n                var result = await client.query(query).fetchUniqueRow();\r\n                return result.row;\r\n            }catch(err){\r\n                console.log('ERROR',err.message);\r\n                throw err;\r\n            };\r\n        }\r\n    },\r\n    {\r\n        action: 'presupuesto_cargar',\r\n        parameters: [\r\n            {name:'presupuesto'       , typeName:'integer'},\r\n        ],\r\n        coreFunction: async function(context:ProcedureContext, parameters: coreFunctionParameters){\r\n            var client=context.client;\r\n            var query =`\r\n                SELECT \r\n                    COALESCE(\r\n                        (SELECT to_jsonb(j.*) \r\n                            from (\r\n                                SELECT * \r\n                                    from presupuestos \r\n                                    where presupuesto = $1\r\n                            ) as j\r\n                        )\r\n                        ,'{}'::jsonb\r\n                    ) as presupuesto,\r\n                    COALESCE(\r\n                        (SELECT to_jsonb(j.*) \r\n                            from (\r\n                                SELECT *\r\n                                    FROM clientes \r\n                                    where cliente = (select cliente from presupuestos where presupuesto = $1)\r\n                            ) as j\r\n                        ),'{}'::jsonb\r\n                    ) as cliente,\r\n                ${json(`\r\n                    SELECT *\r\n                        FROM items_presupuesto\r\n                        where presupuesto = $1\r\n                    `,\r\n                    'numero_linea'\r\n                )} as \"items\"\r\n            `;\r\n            try{\r\n                var result = await client.query(query,[parameters.presupuesto]).fetchUniqueRow();\r\n                return result.row;\r\n            }catch(err){\r\n                console.log('ERROR',err.message);\r\n                throw err;\r\n            };\r\n        }\r\n    },\r\n    {\r\n        action: 'presupuesto_guardar',\r\n        parameters:[\r\n            {name:'presupuesto'       , typeName:'jsonb'},\r\n            {name:'items'             , typeName:'jsonb'},\r\n            {name:'cliente'           , typeName:'jsonb'},\r\n        ],\r\n        coreFunction: async function(context:ProcedureContext, parameters: coreFunctionParameters){\r\n            var client=context.client;\r\n            var presup = parameters.presupuesto;\r\n            var cliente = parameters.cliente;\r\n            var numeroPresupuesto;\r\n            try{\r\n                var presupuestoFieldsSql = `(fecha, cliente, estado, valido_hasta, subtotal, descuento, total, con_opciones, con_descuento_en_items) `;\r\n                var presupuestoValuesSql = `($1,$2,$3,$4,$5,$6,$7,$8,$9) `;\r\n                var presupuestoValues = [\r\n                    presup.fecha,\r\n                    cliente.cliente,\r\n                    presup.estado,\r\n                    presup.valido_hasta,\r\n                    presup.subtotal,\r\n                    presup.descuento,\r\n                    presup.total,\r\n                    presup.con_opciones,\r\n                    presup.con_descuento_en_items\r\n                ];\r\n                if(presup.presupuesto){\r\n                    await permiteEditarPresupuesto(presup.presupuesto, client);\r\n                    numeroPresupuesto=presup.presupuesto;\r\n                    await client.query(`delete from items_presupuesto where presupuesto = $1`,[numeroPresupuesto]).execute();\r\n                    await client.query(`\r\n                        update presupuestos \r\n                            set ${presupuestoFieldsSql} = ${presupuestoValuesSql}\r\n                            where presupuesto = $10\r\n                            returning *\r\n                    `,presupuestoValues.concat(presup.presupuesto)).fetchUniqueRow();\r\n                }else{\r\n                    numeroPresupuesto = (await client.query(`\r\n                        insert into \r\n                            presupuestos ${presupuestoFieldsSql}\r\n                            values ${presupuestoValuesSql}\r\n                            returning *\r\n                    `,presupuestoValues).fetchUniqueRow()).row.presupuesto\r\n                }\r\n                for(let item of parameters.items){\r\n                    await client.query(`\r\n                        insert \r\n                            into items_presupuesto (presupuesto, cantidad, producto, nombre, descripcion, precio_unitario, porcentaje_descuento, descuento, total) \r\n                            values ($1,$2,$3,$4,$5,$6,$7,$8,$9)\r\n                    `,[numeroPresupuesto, item.cantidad, item.producto, item.nombre, item.descripcion, item.precio_unitario, item.porcentaje_descuento, item.descuento, item.total])\r\n                    .execute();\r\n                }\r\n                return {estado:'ok', presupuesto: numeroPresupuesto};\r\n            }catch(err){\r\n                console.log('ERROR',err.message);\r\n                throw err;\r\n            };\r\n        }\r\n    },\r\n    {\r\n        action: 'presupuesto_anular',\r\n        parameters:[\r\n            {name:'presupuesto'       , typeName:'integer'},\r\n        ],\r\n        coreFunction: async function(context:ProcedureContext, parameters: coreFunctionParameters){\r\n            var client=context.client;\r\n            var db =  context.be.db;\r\n            var nroPresup = parameters.presupuesto;\r\n            try{\r\n                await permiteEditarPresupuesto(nroPresup, client);\r\n                await client.query(`\r\n                    update presupuestos \r\n                        set estado = $2\r\n                        where presupuesto = $1\r\n                        returning *\r\n                `,[nroPresup, ESTADO_ANULADO_PRESUPUESTO]).fetchUniqueRow();\r\n                return {estado:'ok'};\r\n            }catch(err){\r\n                console.log('ERROR',err.message);\r\n                throw err;\r\n            };\r\n        }\r\n    },\r\n    {\r\n        action: 'presupuesto_rechazar',\r\n        parameters:[\r\n            {name:'presupuesto'       , typeName:'integer'},\r\n        ],\r\n        coreFunction: async function(context:ProcedureContext, parameters: coreFunctionParameters){\r\n            var client=context.client;\r\n            var db =  context.be.db;\r\n            var nroPresup = parameters.presupuesto;\r\n            try{\r\n                await permiteEditarPresupuesto(nroPresup, client);\r\n                await client.query(`\r\n                    update presupuestos \r\n                    set estado = $2\r\n                        where presupuesto = $1\r\n                        returning *\r\n                `,[nroPresup, ESTADO_RECHAZADO_PRESUPUESTO]).fetchUniqueRow();\r\n                return {estado:'ok'};\r\n            }catch(err){\r\n                console.log('ERROR',err.message);\r\n                throw err;\r\n            };\r\n        }\r\n    },\r\n    {\r\n        action: 'pedido_cargar',\r\n        parameters: [\r\n            {name:'pedido'       , typeName:'integer'},\r\n        ],\r\n        coreFunction: async function(context:ProcedureContext, parameters: coreFunctionParameters){\r\n            var client=context.client;\r\n            var query =`\r\n                SELECT \r\n                    COALESCE(\r\n                        (SELECT to_jsonb(j.*) \r\n                            from (\r\n                                SELECT * \r\n                                    from pedidos \r\n                                    where pedido = $1\r\n                            ) as j\r\n                        )\r\n                        ,'{}'::jsonb\r\n                    ) as pedido,\r\n                    COALESCE(\r\n                        (SELECT to_jsonb(j.*) \r\n                            from (\r\n                                SELECT *\r\n                                    FROM clientes \r\n                                    where cliente = (select cliente from pedidos where pedido = $1)\r\n                            ) as j\r\n                        ),'{}'::jsonb\r\n                    ) as cliente,\r\n                ${json(`\r\n                    SELECT *\r\n                        FROM items_pedido\r\n                        where pedido = $1\r\n                    `,\r\n                    'numero_linea'\r\n                )} as \"items\"\r\n            `;\r\n            try{\r\n                var result = await client.query(query,[parameters.pedido]).fetchUniqueRow();\r\n                return result.row;\r\n            }catch(err){\r\n                console.log('ERROR',err.message);\r\n                throw err;\r\n            };\r\n        }\r\n    },\r\n    {\r\n        // TODO -> stock (puede ir en trigger)\r\n        action: 'pedido_guardar',\r\n        parameters:[\r\n            {name:'pedido'            , typeName:'jsonb'},\r\n            {name:'items'             , typeName:'jsonb'},\r\n            {name:'cliente'           , typeName:'jsonb'},\r\n        ],\r\n        coreFunction: async function(context:ProcedureContext, parameters: coreFunctionParameters){\r\n            var client=context.client;\r\n            var pedido = parameters.pedido;\r\n            var cliente = parameters.cliente;\r\n            var numeroPedido;\r\n            try{\r\n                var pedidoFieldsSql = `(presupuesto, fecha, cliente, estado, fecha_entrega, subtotal, descuento, total, observaciones) `;\r\n                var pedidoValuesSql = `($1,$2,$3,$4,$5,$6,$7,$8, $9) `;\r\n                var pedidoValues = [\r\n                    pedido.presupuesto,\r\n                    pedido.fecha,\r\n                    cliente.cliente,\r\n                    pedido.estado,\r\n                    pedido.fecha_entrega,\r\n                    pedido.subtotal,\r\n                    pedido.descuento,\r\n                    pedido.total,\r\n                    pedido.observaciones\r\n                ];\r\n                if(pedido.pedido){\r\n                    numeroPedido=pedido.pedido;\r\n                    await client.query(`delete from items_pedido where pedido = $1`,[numeroPedido]).execute();\r\n                    await client.query(`\r\n                        update pedidos \r\n                            set ${pedidoFieldsSql} = ${pedidoValuesSql}\r\n                            where pedido = $10\r\n                            returning *\r\n                    `,pedidoValues.concat(pedido.pedido)).fetchUniqueRow();\r\n                }else{\r\n                    pedido.presupuesto?await permiteEditarPresupuesto(pedido.presupuesto, client):null;\r\n                    numeroPedido = (await client.query(`\r\n                        insert into \r\n                            pedidos ${pedidoFieldsSql}\r\n                            values ${pedidoValuesSql}\r\n                            returning *\r\n                    `,pedidoValues).fetchUniqueRow()).row.pedido\r\n                }\r\n                for(let item of parameters.items){\r\n                    await client.query(`\r\n                        insert \r\n                            into items_pedido (pedido, cantidad, producto, nombre, descripcion, precio_unitario, porcentaje_descuento, descuento, total) \r\n                            values ($1,$2,$3,$4,$5,$6,$7,$8,$9)\r\n                    `,[numeroPedido, item.cantidad, item.producto, item.nombre, item.descripcion, item.precio_unitario, item.porcentaje_descuento, item.descuento, item.total])\r\n                    .execute();\r\n                }\r\n                if(pedido.presupuesto){\r\n                    await client.query(`\r\n                        update presupuestos \r\n                            set estado = $1\r\n                            where presupuesto = $2\r\n                            returning *\r\n                    `,[ESTADO_ACEPTADO_PRESUPUESTO, pedido.presupuesto]).fetchUniqueRow();\r\n                    try{\r\n                        await client.query(`\r\n                            select presupuesto\r\n                                from pedidos\r\n                                where presupuesto = $1\r\n                        `,[pedido.presupuesto]).fetchUniqueValue();\r\n                    }catch(err){\r\n                        throw Error(`El presupuesto ${pedido.presupuesto} ya tiene un pedido creado. ` + err.message)\r\n                    }\r\n                }\r\n                return {estado:'ok', pedido: numeroPedido};\r\n            }catch(err){\r\n                console.log('ERROR',err.message);\r\n                throw err;\r\n            };\r\n        }\r\n    },\r\n    {\r\n        action: 'producto_clonar',\r\n        parameters:[\r\n            {name:'producto'       , typeName:'integer'},\r\n        ],\r\n        coreFunction: async function(context:ProcedureContext, parameters: coreFunctionParameters){\r\n            var client=context.client;\r\n            var be = context.be;\r\n            var producto = parameters.producto;\r\n\r\n            //clonacion producto\r\n            var productoAClonar = (await client.query(`select * from productos where producto = $1`,[producto]).fetchUniqueRow()).row;\r\n            delete(productoAClonar.producto);\r\n            delete(productoAClonar.stock);\r\n            delete(productoAClonar.stock_minimo);\r\n            delete(productoAClonar.stock_maximo);\r\n            var productoKeys=[];\r\n            var productoValues=[];\r\n            for(let key in productoAClonar){\r\n                productoKeys.push(be.db.quoteIdent(key));\r\n                productoValues.push(be.db.quoteNullable(productoAClonar[key]));\r\n            }\r\n            var productoNuevo = (await client.query(`insert into productos (${productoKeys.join(',')}) values (${productoValues.join(',')}) returning *`,[]).fetchUniqueRow()).row\r\n            //clonacion insumos\r\n            var productosInsumosAClonar = (await client.query(`select * from productos_insumos where producto = $1`,[producto]).fetchAll()).rows;\r\n            var prodInsumosNuevos=[];\r\n            for(var prodInsumo of productosInsumosAClonar){\r\n                prodInsumo.producto=productoNuevo.producto;\r\n                var prodInsumoKeys=[];\r\n                var prodInsumoValues=[];\r\n                for(let key in prodInsumo){\r\n                    prodInsumoKeys.push(be.db.quoteIdent(key));\r\n                    prodInsumoValues.push(be.db.quoteNullable(prodInsumo[key]));\r\n                }\r\n                prodInsumosNuevos.push(\r\n                    (await client.query(`\r\n                        insert into \r\n                            productos_insumos (${prodInsumoKeys.join(',')}) \r\n                            values (${prodInsumoValues.join(',')}) \r\n                            returning *`,[]).fetchUniqueRow()\r\n                    ).row\r\n                )\r\n            }\r\n            return {estado:'ok', productoNuevo, prodInsumosNuevos};\r\n        }\r\n    },\r\n    {\r\n        action: 'object_get',\r\n        parameters: [\r\n            {name:'tablename'     , typeName:'text'},\r\n            {name:'pk_values'       , typeName:'jsonb'},\r\n        ],\r\n        coreFunction: async function(context:ProcedureContext, parameters: coreFunctionParameters){\r\n            var client=context.client;\r\n            var query = sqlTools.structuredData.sqlRead(parameters.pk_values, createStructure(context, parameters.tablename));\r\n            try{\r\n                var result = await client.query(query).fetchUniqueValue();\r\n                return result.value;\r\n            }catch(err){\r\n                console.log('ERROR',err.message);\r\n                throw err;\r\n            };\r\n        }\r\n    },\r\n    {\r\n        action:'object_save',\r\n        parameters:[\r\n            {name:'tablename'   , typeName:'text'},\r\n            {name:'datos'       , typeName:'jsonb'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, parameters:CoreFunctionParameters){\r\n            var be=context.be;\r\n            var client=context.client;\r\n            var queries = sqlTools.structuredData.sqlWrite(parameters.datos, createStructure(context, parameters.tablename));\r\n            console.log(\"#############\",queries)\r\n            return await queries.reduce(function(promise:Promise<any>, query:string){\r\n                return promise.then(function() {\r\n                    return client.query(query).execute().then(function(){\r\n                        return 'ok';\r\n                    });\r\n                });\r\n            },Promise.resolve()).then(async function(){\r\n                //TODO: traer json refrescado\r\n                //var result = await be.procedure.object_get.coreFunction(context, {tablename:parameters.tablename, });\r\n                return 'ok';\r\n            }).catch(function(err:Error){\r\n                console.log(\"ENTRA EN EL CATCH: \",err)\r\n                throw err\r\n            })\r\n        }\r\n    },\r\n];"]}
|
|
@@ -12,4 +12,4 @@
|
|
|
12
12
|
const app_contable_1 = require("./app-contable");
|
|
13
13
|
new app_contable_1.AppContable().start();
|
|
14
14
|
});
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmVyLWNvbnRhYmxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3NlcnZlci9zZXJ2ZXItY29udGFibGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0lBQUEsWUFBWSxDQUFDOztJQUViLGlEQUE0QztJQUU1QyxJQUFJLDBCQUFXLEVBQUUsQ0FBQyxLQUFLLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xyXG5cclxuaW1wb3J0IHsgQXBwQ29udGFibGV9IGZyb20gXCIuL2FwcC1jb250YWJsZVwiO1xyXG5cclxubmV3IEFwcENvbnRhYmxlKCkuc3RhcnQoKTtcclxuXHJcbiJdfQ==
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
(function (factory) {
|
|
2
|
+
if (typeof module === "object" && typeof module.exports === "object") {
|
|
3
|
+
var v = factory(require, exports);
|
|
4
|
+
if (v !== undefined) module.exports = v;
|
|
5
|
+
}
|
|
6
|
+
else if (typeof define === "function" && define.amd) {
|
|
7
|
+
define(["require", "exports"], factory);
|
|
8
|
+
}
|
|
9
|
+
})(function (require, exports) {
|
|
10
|
+
"use strict";
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.categorias_producto = categorias_producto;
|
|
13
|
+
function categorias_producto(context) {
|
|
14
|
+
var admin = context.user.rol === 'admin';
|
|
15
|
+
return {
|
|
16
|
+
name: 'categorias_producto',
|
|
17
|
+
allow: {
|
|
18
|
+
"vertical-edit": false,
|
|
19
|
+
},
|
|
20
|
+
editable: admin,
|
|
21
|
+
fields: [
|
|
22
|
+
{ name: 'categoria', typeName: 'text', nullable: false },
|
|
23
|
+
{ name: 'nombre', typeName: 'text', isName: true, nullable: false },
|
|
24
|
+
],
|
|
25
|
+
primaryKey: ['categoria']
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY2F0ZWdvcmlhc19wcm9kdWN0by5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zZXJ2ZXIvdGFibGUtY2F0ZWdvcmlhc19wcm9kdWN0by50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7SUFBQSxZQUFZLENBQUM7O0lBSWIsa0RBY0M7SUFkRCxTQUFnQixtQkFBbUIsQ0FBQyxPQUFvQjtRQUNwRCxJQUFJLEtBQUssR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBRyxPQUFPLENBQUM7UUFDdkMsT0FBTztZQUNILElBQUksRUFBQyxxQkFBcUI7WUFDMUIsS0FBSyxFQUFDO2dCQUNGLGVBQWUsRUFBQyxLQUFLO2FBQ3hCO1lBQ0QsUUFBUSxFQUFDLEtBQUs7WUFDZCxNQUFNLEVBQUM7Z0JBQ0gsRUFBQyxJQUFJLEVBQUMsV0FBVyxFQUFLLFFBQVEsRUFBQyxNQUFNLEVBQUcsUUFBUSxFQUFDLEtBQUssRUFBQztnQkFDdkQsRUFBQyxJQUFJLEVBQUMsUUFBUSxFQUFRLFFBQVEsRUFBQyxNQUFNLEVBQUcsTUFBTSxFQUFDLElBQUksRUFBRSxRQUFRLEVBQUMsS0FBSyxFQUFDO2FBQ3ZFO1lBQ0QsVUFBVSxFQUFDLENBQUMsV0FBVyxDQUFDO1NBQzNCLENBQUM7SUFDTixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCB7VGFibGVEZWZpbml0aW9uLCBUYWJsZUNvbnRleHR9IGZyb20gXCIuL3R5cGVzLWNvbnRhYmxlXCJcblxuZXhwb3J0IGZ1bmN0aW9uIGNhdGVnb3JpYXNfcHJvZHVjdG8oY29udGV4dDpUYWJsZUNvbnRleHQpOlRhYmxlRGVmaW5pdGlvbntcbiAgICB2YXIgYWRtaW4gPSBjb250ZXh0LnVzZXIucm9sPT09J2FkbWluJztcbiAgICByZXR1cm4ge1xuICAgICAgICBuYW1lOidjYXRlZ29yaWFzX3Byb2R1Y3RvJyxcbiAgICAgICAgYWxsb3c6e1xuICAgICAgICAgICAgXCJ2ZXJ0aWNhbC1lZGl0XCI6ZmFsc2UsXG4gICAgICAgIH0sXG4gICAgICAgIGVkaXRhYmxlOmFkbWluLFxuICAgICAgICBmaWVsZHM6W1xuICAgICAgICAgICAge25hbWU6J2NhdGVnb3JpYScgICAsIHR5cGVOYW1lOid0ZXh0JyAsIG51bGxhYmxlOmZhbHNlfSxcbiAgICAgICAgICAgIHtuYW1lOidub21icmUnICAgICAgLCB0eXBlTmFtZTondGV4dCcgLCBpc05hbWU6dHJ1ZSwgbnVsbGFibGU6ZmFsc2V9LFxuICAgICAgICBdLFxuICAgICAgICBwcmltYXJ5S2V5OlsnY2F0ZWdvcmlhJ11cbiAgICB9O1xufVxuIl19
|