backend-plus 2.0.0-beta.14 → 2.0.0-beta.15
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/for-client/my-menu.js +3 -0
- package/for-client/my-tables.js +8 -3
- package/lib/procedures-table.js +34 -2
- package/package.json +3 -3
- package/unlogged/my-ajax.js +1 -0
package/for-client/my-menu.js
CHANGED
|
@@ -56,6 +56,9 @@ myOwn.wScreens.table = function(addrParams){
|
|
|
56
56
|
if(addrParams.detailing){
|
|
57
57
|
opts.detailing=addrParams.detailing;
|
|
58
58
|
}
|
|
59
|
+
if(addrParams.pick){
|
|
60
|
+
opts.pick=addrParams.pick;
|
|
61
|
+
}
|
|
59
62
|
opts.detailingForUrl=opts.detailing||{};
|
|
60
63
|
opts.detailingPath = [];
|
|
61
64
|
var pageTitle = addrParams.label || addrParams.name || addrParams.table || my.config.config.title;
|
package/for-client/my-tables.js
CHANGED
|
@@ -294,6 +294,7 @@ myOwn.TableConnector = function(context, opts){
|
|
|
294
294
|
connector.opts = opts||{};
|
|
295
295
|
connector.fixedFields = connector.opts.fixedFields || [];
|
|
296
296
|
connector.fixedField = {};
|
|
297
|
+
connector.pick = connector.opts.pick;
|
|
297
298
|
connector.hideBecauseRelated = {};
|
|
298
299
|
connector.fixedFields.forEach(function(pair){
|
|
299
300
|
if(!pair.range && pair.value != myOwn.skipInFixedFields){
|
|
@@ -360,7 +361,8 @@ myOwn.TableConnector.prototype.getData = function getData(){
|
|
|
360
361
|
return connector.my.ajax.table_data({
|
|
361
362
|
table:connector.tableName,
|
|
362
363
|
fixedFields:connector.fixedFields,
|
|
363
|
-
paramfun:connector.parameterFunctions||{}
|
|
364
|
+
paramfun:connector.parameterFunctions||{},
|
|
365
|
+
pick:connector.pick
|
|
364
366
|
}).then(function(rows){
|
|
365
367
|
return connector.whenStructureReady.then(function(){
|
|
366
368
|
if(connector.getElementToDisplayCount){
|
|
@@ -447,6 +449,7 @@ myOwn.TableConnectorLocal = function(context, opts){
|
|
|
447
449
|
connector.opts = opts||{};
|
|
448
450
|
connector.fixedFields = connector.opts.fixedFields || [];
|
|
449
451
|
connector.fixedField = {};
|
|
452
|
+
connector.pick = connector.opts.pick;
|
|
450
453
|
connector.hideBecauseRelated = {};
|
|
451
454
|
connector.fixedFields.forEach(function(pair){
|
|
452
455
|
if(!pair.range && pair.value != myOwn.skipInFixedFields){
|
|
@@ -615,7 +618,8 @@ myOwn.tableGrid = function tableGrid(tableName, mainElement, opts){
|
|
|
615
618
|
await grid.connector.my.ajax.table_data({
|
|
616
619
|
table:grid.connector.tableName,
|
|
617
620
|
fixedFields:grid.connector.fixedFields,
|
|
618
|
-
paramfun:grid.connector.parameterFunctions||{}
|
|
621
|
+
paramfun:grid.connector.parameterFunctions||{},
|
|
622
|
+
pick:grid.connector.pick
|
|
619
623
|
}).then(function(rows){
|
|
620
624
|
var primaryKey = grid.def.primaryKey;
|
|
621
625
|
var getPrimaryKeyValues=function getPrimaryKeyValues(primaryKey, row){
|
|
@@ -2379,7 +2383,8 @@ myOwn.TableGrid.prototype.displayGrid = function displayGrid(){
|
|
|
2379
2383
|
table:depot.def.name,
|
|
2380
2384
|
fixedFields:grid.def.primaryKey.map(function(fieldName, i){
|
|
2381
2385
|
return {fieldName:fieldName, value:depot.primaryKeyValues[i]};
|
|
2382
|
-
})
|
|
2386
|
+
}),
|
|
2387
|
+
pick:grid.def.pick
|
|
2383
2388
|
}).then(function(result){
|
|
2384
2389
|
grid.depotRefresh(depot,{updatedRow:result[0], sendedForUpdate:{}}, opts);
|
|
2385
2390
|
})
|
package/lib/procedures-table.js
CHANGED
|
@@ -76,13 +76,14 @@ ProcedureTables = [
|
|
|
76
76
|
parameters:[
|
|
77
77
|
{name: 'table', encoding:'plain'},
|
|
78
78
|
{name: 'fixedFields', defaultValue:[]},
|
|
79
|
-
{name: 'paramfun', defaultValue:[]}
|
|
79
|
+
{name: 'paramfun', defaultValue:[]},
|
|
80
|
+
{name: 'pick', defaultValue:'', encoding:'plain'}
|
|
80
81
|
],
|
|
81
82
|
coreFunction:
|
|
82
83
|
/**
|
|
83
84
|
*
|
|
84
85
|
* @param {*} context
|
|
85
|
-
* @param {{table:string, fixedFields:{fieldName:string, value:any, range:string}[], paramfun:string[]}} parameters
|
|
86
|
+
* @param {{table:string, fixedFields:{fieldName:string, value:any, range:string}[], paramfun:string[], pick:string}} parameters
|
|
86
87
|
*/
|
|
87
88
|
async function tableDatum(context, parameters){
|
|
88
89
|
var be=context.be;
|
|
@@ -155,6 +156,37 @@ ProcedureTables = [
|
|
|
155
156
|
return context.client.query(sql,
|
|
156
157
|
queryValues
|
|
157
158
|
).fetchAll().then(function(result){
|
|
159
|
+
if (parameters.pick) {
|
|
160
|
+
// /*
|
|
161
|
+
return result.rows.filter(row=>{
|
|
162
|
+
var line = likeAr(row).join(' ').trim().split(/\s+/);
|
|
163
|
+
return parameters.pick.split(' ').map(p=>p.toLocaleLowerCase()).every(palabraBuscada=>
|
|
164
|
+
line.map(p=>p.toLocaleLowerCase()).filter(palabra=>
|
|
165
|
+
palabraBuscada.length <= 3
|
|
166
|
+
? palabra == palabraBuscada.toLocaleLowerCase()
|
|
167
|
+
: palabra.includes(palabraBuscada.toLocaleLowerCase()
|
|
168
|
+
)).length
|
|
169
|
+
)
|
|
170
|
+
});
|
|
171
|
+
// */
|
|
172
|
+
/*
|
|
173
|
+
var filter = parameters.pick.split('|').map(andPart=>andPart.trim().split(/\s+/));
|
|
174
|
+
return result.rows.filter(row=>{
|
|
175
|
+
var line = likeAr(row).join(' ').trim().split(/\s+/);
|
|
176
|
+
for (var orPart of filter){
|
|
177
|
+
var allFound = true;
|
|
178
|
+
for (var andPart of orPart){
|
|
179
|
+
if (!line.includes(andPart)) {
|
|
180
|
+
allFound = false;
|
|
181
|
+
break;
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
if (allFound) return true;
|
|
185
|
+
}
|
|
186
|
+
return false;
|
|
187
|
+
})
|
|
188
|
+
*/
|
|
189
|
+
}
|
|
158
190
|
return result.rows;
|
|
159
191
|
}).catch(function(err){
|
|
160
192
|
throw err;
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "backend-plus",
|
|
3
3
|
"description": "Backend for the anti Pareto rule",
|
|
4
|
-
"version": "2.0.0-beta.
|
|
4
|
+
"version": "2.0.0-beta.15",
|
|
5
5
|
"author": "Codenautas <codenautas@googlegroups.com>",
|
|
6
6
|
"license": "MIT",
|
|
7
7
|
"repository": "codenautas/backend-plus",
|
|
@@ -81,7 +81,7 @@
|
|
|
81
81
|
"@types/js-yaml": "^4.0.9",
|
|
82
82
|
"@types/mocha": "^10.0.6",
|
|
83
83
|
"@types/multiparty": "~0.0.36",
|
|
84
|
-
"@types/node": "^20.
|
|
84
|
+
"@types/node": "^20.11.0",
|
|
85
85
|
"@types/nodemailer": "^6.4.14",
|
|
86
86
|
"@types/numeral": "~2.0.5",
|
|
87
87
|
"@types/session-file-store": "^1.2.5",
|
|
@@ -98,7 +98,7 @@
|
|
|
98
98
|
"kill-9": "~0.4.3",
|
|
99
99
|
"mocha": "^10.2.0",
|
|
100
100
|
"nyc": "^15.1.0",
|
|
101
|
-
"puppeteer": "^21.
|
|
101
|
+
"puppeteer": "^21.7.0",
|
|
102
102
|
"sinon": "^17.0.1",
|
|
103
103
|
"supertest": "^6.3.3",
|
|
104
104
|
"types.d.ts": "~0.6.21",
|
package/unlogged/my-ajax.js
CHANGED
|
@@ -593,6 +593,7 @@ myAjax.UriSearchToObjectParams={
|
|
|
593
593
|
td :{ encode:function(x){ return json4all.toUrl(x); }, decode:function(x){ return json4all.parse(x)} },
|
|
594
594
|
today :{ encode:function(x){ return JSON.stringify(x); }, decode:function(x){ return bestGlobals.date.iso((x+'').substr(0,10))} },
|
|
595
595
|
section :{ showInMenu:true , encode:noChange , decode:noChange },
|
|
596
|
+
pick :{ encode:noChange , decode:noChange },
|
|
596
597
|
directUrl :{ hide:true },
|
|
597
598
|
selectedByDefault:{ hide:true },
|
|
598
599
|
showParams :{ hide:true },
|