contable 0.0.1

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.
Files changed (57) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +1 -0
  3. package/dist/client/client.js +259 -0
  4. package/dist/client/img/bannersuperior.png +0 -0
  5. package/dist/client/menu.js +3 -0
  6. package/dist/client/redux-formulario.js +379 -0
  7. package/dist/client/render-components.js +750 -0
  8. package/dist/client/render-components.tsx +1117 -0
  9. package/dist/client/render-formulario.js +56 -0
  10. package/dist/client/render-formulario.tsx +72 -0
  11. package/dist/client/render-general.js +197 -0
  12. package/dist/client/render-general.tsx +212 -0
  13. package/dist/client/render-handlers.js +69 -0
  14. package/dist/client/tipos.js +13 -0
  15. package/dist/client/tsconfig.json +12 -0
  16. package/dist/server/app-contable.js +174 -0
  17. package/dist/server/def-config.js +100 -0
  18. package/dist/server/procedures-contable.js +508 -0
  19. package/dist/server/server-contable.js +17 -0
  20. package/dist/server/table-categorias_producto.js +29 -0
  21. package/dist/server/table-clientes.js +56 -0
  22. package/dist/server/table-condicion_iva.js +29 -0
  23. package/dist/server/table-estados_pedido.js +33 -0
  24. package/dist/server/table-estados_presupuesto.js +34 -0
  25. package/dist/server/table-insumos.js +44 -0
  26. package/dist/server/table-items_pedido.js +48 -0
  27. package/dist/server/table-items_presupuesto.js +48 -0
  28. package/dist/server/table-iva_productos.js +29 -0
  29. package/dist/server/table-parametros.js +38 -0
  30. package/dist/server/table-pedidos.js +48 -0
  31. package/dist/server/table-pedidos_pendientes.js +28 -0
  32. package/dist/server/table-pedidos_vencidos.js +28 -0
  33. package/dist/server/table-presupuestos.js +56 -0
  34. package/dist/server/table-productos.js +70 -0
  35. package/dist/server/table-productos_clientes.js +22 -0
  36. package/dist/server/table-productos_generales.js +22 -0
  37. package/dist/server/table-productos_insumos.js +47 -0
  38. package/dist/server/table-usuarios.js +44 -0
  39. package/dist/server/tsconfig.json +10 -0
  40. package/dist/server/types-contable.js +28 -0
  41. package/dist/unlogged/adapt.js +8 -0
  42. package/dist/unlogged/css/styles.styl +88 -0
  43. package/dist/unlogged/img/login-logo-icon.png.png +0 -0
  44. package/dist/unlogged/img/logo.png +0 -0
  45. package/dist/unlogged/tsconfig.json +15 -0
  46. package/dist/unlogged/unlogged.js +205 -0
  47. package/install/categorias_producto.tab +2 -0
  48. package/install/condicion_iva.tab +3 -0
  49. package/install/estados_pedido.tab +5 -0
  50. package/install/estados_presupuesto.tab +5 -0
  51. package/install/iva_productos.tab +3 -0
  52. package/install/productos.tab +2 -0
  53. package/install/usuarios.tab +2 -0
  54. package/package.json +58 -0
  55. package/unlogged/img/main-loading.gif +0 -0
  56. package/unlogged/main-loading.gif +0 -0
  57. package/unlogged/my-skin.js +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":"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","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 * 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];"]}
@@ -0,0 +1,17 @@
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", "backend-plus", "./app-contable"], factory);
8
+ }
9
+ })(function (require, exports) {
10
+ "use strict";
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ const backend_plus_1 = require("backend-plus");
13
+ const app_contable_1 = require("./app-contable");
14
+ var AppContable = (0, app_contable_1.emergeAppContable)(backend_plus_1.AppBackend);
15
+ new AppContable().start();
16
+ });
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmVyLWNvbnRhYmxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NlcnZlci9zZXJ2ZXItY29udGFibGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0lBQUEsWUFBWSxDQUFDOztJQUViLCtDQUEwQztJQUMxQyxpREFBbUQ7SUFFbkQsSUFBSSxXQUFXLEdBQUcsSUFBQSxnQ0FBaUIsRUFBQyx5QkFBVSxDQUFDLENBQUM7SUFFaEQsSUFBSSxXQUFXLEVBQUUsQ0FBQyxLQUFLLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xyXG5cclxuaW1wb3J0IHsgQXBwQmFja2VuZCB9IGZyb20gXCJiYWNrZW5kLXBsdXNcIjtcclxuaW1wb3J0IHsgZW1lcmdlQXBwQ29udGFibGUgfSBmcm9tIFwiLi9hcHAtY29udGFibGVcIjtcclxuXHJcbnZhciBBcHBDb250YWJsZSA9IGVtZXJnZUFwcENvbnRhYmxlKEFwcEJhY2tlbmQpO1xyXG5cclxubmV3IEFwcENvbnRhYmxlKCkuc3RhcnQoKTtcclxuXHJcbiJdfQ==
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY2F0ZWdvcmlhc19wcm9kdWN0by5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zZXJ2ZXIvdGFibGUtY2F0ZWdvcmlhc19wcm9kdWN0by50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7SUFBQSxZQUFZLENBQUM7O0lBSWIsa0RBY0M7SUFkRCxTQUFnQixtQkFBbUIsQ0FBQyxPQUFvQjtRQUNwRCxJQUFJLEtBQUssR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBRyxPQUFPLENBQUM7UUFDdkMsT0FBTztZQUNILElBQUksRUFBQyxxQkFBcUI7WUFDMUIsS0FBSyxFQUFDO2dCQUNGLGVBQWUsRUFBQyxLQUFLO2FBQ3hCO1lBQ0QsUUFBUSxFQUFDLEtBQUs7WUFDZCxNQUFNLEVBQUM7Z0JBQ0gsRUFBQyxJQUFJLEVBQUMsV0FBVyxFQUFLLFFBQVEsRUFBQyxNQUFNLEVBQUcsUUFBUSxFQUFDLEtBQUssRUFBQztnQkFDdkQsRUFBQyxJQUFJLEVBQUMsUUFBUSxFQUFRLFFBQVEsRUFBQyxNQUFNLEVBQUcsTUFBTSxFQUFDLElBQUksRUFBRSxRQUFRLEVBQUMsS0FBSyxFQUFDO2FBQ3ZFO1lBQ0QsVUFBVSxFQUFDLENBQUMsV0FBVyxDQUFDO1NBQzNCLENBQUM7SUFDTixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCB7VGFibGVEZWZpbml0aW9uLCBUYWJsZUNvbnRleHR9IGZyb20gXCIuL3R5cGVzLWNvbnRhYmxlXCJcblxuZXhwb3J0IGZ1bmN0aW9uIGNhdGVnb3JpYXNfcHJvZHVjdG8oY29udGV4dDpUYWJsZUNvbnRleHQpOlRhYmxlRGVmaW5pdGlvbntcbiAgICB2YXIgYWRtaW4gPSBjb250ZXh0LnVzZXIucm9sPT09J2FkbWluJztcbiAgICByZXR1cm4ge1xuICAgICAgICBuYW1lOidjYXRlZ29yaWFzX3Byb2R1Y3RvJyxcbiAgICAgICAgYWxsb3c6e1xuICAgICAgICAgICAgXCJ2ZXJ0aWNhbC1lZGl0XCI6ZmFsc2UsXG4gICAgICAgIH0sXG4gICAgICAgIGVkaXRhYmxlOmFkbWluLFxuICAgICAgICBmaWVsZHM6W1xuICAgICAgICAgICAge25hbWU6J2NhdGVnb3JpYScgICAsIHR5cGVOYW1lOid0ZXh0JyAsIG51bGxhYmxlOmZhbHNlfSxcbiAgICAgICAgICAgIHtuYW1lOidub21icmUnICAgICAgLCB0eXBlTmFtZTondGV4dCcgLCBpc05hbWU6dHJ1ZSwgbnVsbGFibGU6ZmFsc2V9LFxuICAgICAgICBdLFxuICAgICAgICBwcmltYXJ5S2V5OlsnY2F0ZWdvcmlhJ11cbiAgICB9O1xufVxuIl19