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.
@@ -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;
@@ -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
  })
@@ -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.14",
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.10.6",
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.6.1",
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",
@@ -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 },