sf-i-reporting 1.0.62 → 1.0.63

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/dev/index.html CHANGED
@@ -18,7 +18,7 @@
18
18
  import {LitElement, html, css} from 'https://esm.run/lit-element/lit-element.js';
19
19
  import {SfIElasticText} from 'https://esm.run/sf-i-elastic-text@1.0.17/sf-i-elastic-text.js';
20
20
  import {SfIForm} from 'https://esm.run/sf-i-form@1.0.183/sf-i-form.js';
21
- import {SfIBricks} from 'https://esm.run/sf-i-bricks@1.0.7/sf-i-bricks.js';
21
+ import {SfIBricks} from 'https://esm.run/sf-i-bricks@1.0.9/sf-i-bricks.js';
22
22
  import {SfIUploader} from 'https://esm.run/sf-i-uploader@1.0.103/sf-i-uploader.js';
23
23
  </script>
24
24
  <style>
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "sf-i-reporting",
3
3
  "private": false,
4
- "version": "1.0.62",
4
+ "version": "1.0.63",
5
5
  "description": "Superflows Reporting Component",
6
6
  "main": "sf-i-reporting.js",
7
7
  "module": "sf-i-reporting.js",
@@ -1 +1 @@
1
- {"version":3,"file":"sf-i-reporting.d.ts","sourceRoot":"","sources":["src/sf-i-reporting.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"sf-i-reporting.d.ts","sourceRoot":"","sources":["src/sf-i-reporting.ts"],"names":[],"mappings":"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"}
package/sf-i-reporting.js CHANGED
@@ -155,12 +155,18 @@ let SfIReporting = class SfIReporting extends LitElement {
155
155
  }
156
156
  else if (element.type == "sf-i-form-select") {
157
157
  valueObj[element.id] = element.value;
158
- for (let field of element.selectfields) {
159
- valueObj[field] = element.value[field];
158
+ if (element.savenameseparate == "yes") {
159
+ valueObj[element.id] = element.value;
160
+ }
161
+ else {
162
+ for (let field of element.selectfields) {
163
+ valueObj[field] = element.value[field];
164
+ }
160
165
  }
161
166
  }
162
167
  else if (element.type == "sf-i-bricks") {
163
168
  let bricks = this._SfReportingContainer.querySelector('#' + element.id);
169
+ console.log('sf-i-bricks id', element.id);
164
170
  if (element.savenameseparate == "yes") {
165
171
  valueObj[element.id + 'id'] = (_j = bricks.selectedValues()[0]) !== null && _j !== void 0 ? _j : "";
166
172
  valueObj[element.id + 'name'] = (_k = bricks.selectedTexts()[0]) !== null && _k !== void 0 ? _k : "";
@@ -558,7 +564,7 @@ let SfIReporting = class SfIReporting extends LitElement {
558
564
  <div part="date-container" class="d-flex flex-col flex-grow mt-20">
559
565
  <label id="${element.id}-label" part="date-label">${element.label}</label>
560
566
  <div part="td-body-2"><sf-i-elastic-text text="${element.hint}" minLength="50"></sf-i-elastic-text></div>
561
- <sf-i-form exportparts="td-action:form-td-action, td-body" id="${element.id}" class="reporting-sf-i-form" part="input-sf-i-form" name="${element.name}" label="" apiId="${element.apiid}" mode="${element.mode}" searchPhrase="${(element.mode == "multiselect-dropdown" ? (this.projectname + "&") : "") + element.searchstring}" selectProjection="${element.selectprojection}" ignoreProjections="${element.ignoredprojections}" ${parseInt(element.maxselect) == 0 ? "" : `maxselect="${element.maxselect}"`} ${element.mandatory != null ? "mandatory=\"\"" : ""}></sf-i-form>
567
+ <sf-i-form exportparts="td-action:form-td-action, td-body" id="${element.id}" class="reporting-sf-i-form" part="input-sf-i-form" name="${element.name}" label="" apiId="${element.apiid}" mode="${element.mode}" searchPhrase="${((element.mode == "multiselect-dropdown" || element.searchstring != "") ? (this.projectname + "&") : "") + element.searchstring}" selectProjection="${element.selectprojection}" ignoreProjections="${element.ignoredprojections}" ${parseInt(element.maxselect) == 0 ? "" : `maxselect="${element.maxselect}"`} ${element.mandatory != null ? "mandatory=\"\"" : ""}></sf-i-form>
562
568
  </div>
563
569
  `;
564
570
  let formContainer = this._SfReportingContainer.querySelector('#sf-i-form-container');
@@ -571,6 +577,10 @@ let SfIReporting = class SfIReporting extends LitElement {
571
577
  });
572
578
  let formSaveButton = this._SfReportingContainer.querySelector('#button-save-form');
573
579
  let formObj = formContainer.querySelector('#' + element.id);
580
+ console.log('formobj searchPhrase', formObj.searchPhrase);
581
+ // if(formObj.searchPhrase != ''){
582
+ // formObj.loadMode();
583
+ // }
574
584
  console.log('selectedsearchid', element.value);
575
585
  if (((_a = element.value.id) !== null && _a !== void 0 ? _a : '') != '') {
576
586
  formObj.selectedSearchId = element.value.id;
@@ -603,14 +613,22 @@ let SfIReporting = class SfIReporting extends LitElement {
603
613
  for (let [i, col] of cols.entries()) {
604
614
  valObj[col] = data[i];
605
615
  }
606
- dataElement.value = valObj;
616
+ if (dataElement.savenameseparate == "yes") {
617
+ console.log('populating dataelement', valObj);
618
+ dataElement.value = [valObj.name + ';' + valObj.id];
619
+ }
620
+ else {
621
+ dataElement.value = valObj;
622
+ }
607
623
  }
608
624
  }
609
625
  if (formContainer != null) {
610
626
  this.populateView(formContainer.scrollTop);
611
627
  }
612
628
  });
613
- this.updateShortlistedSearchPhrases(element.id);
629
+ if (element.dependencies != null && element.dependencies.length > 0) {
630
+ this.updateShortlistedSearchPhrases(element.id);
631
+ }
614
632
  });
615
633
  }
616
634
  }
@@ -707,7 +725,12 @@ let SfIReporting = class SfIReporting extends LitElement {
707
725
  this.dataModel[i].value = (_c = this.getPrepopulateJson()[element.id]) !== null && _c !== void 0 ? _c : '';
708
726
  }
709
727
  else if (element.type == "sf-i-form-select") {
728
+ // if(element.savenameseparate == "yes"){
729
+ // console.log('prepopulating sf-i-form-select', this.getPrepopulateJson()[element.id])
730
+ // this.dataModel[i].value = this.getPrepopulateJson()[element.id] ?? ''
731
+ // }else{
710
732
  this.dataModel[i].value = (_d = this.getPrepopulateJson()[element.id]) !== null && _d !== void 0 ? _d : '';
733
+ // }
711
734
  }
712
735
  else if (element.type == "sf-i-form") {
713
736
  if (element.savenameseparate == "yes") {
@@ -748,10 +771,7 @@ let SfIReporting = class SfIReporting extends LitElement {
748
771
  this.evalTimeout = setTimeout(() => {
749
772
  this.evalShowProgress();
750
773
  }, 2000);
751
- let formContainer = this._SfReportingContainer.querySelector('.form-container');
752
- if (formContainer != null) {
753
- this.populateView(formContainer.scrollTop);
754
- }
774
+ this.populateView();
755
775
  };
756
776
  this.evalShowProgress = () => {
757
777
  let total = 0;
@@ -853,7 +873,7 @@ let SfIReporting = class SfIReporting extends LitElement {
853
873
  if (this.editdisable == "true") {
854
874
  this._SfReportingContainer.querySelector('.progress-bar').style.display = 'none';
855
875
  }
856
- else {
876
+ else if (this._SfReportingContainer.querySelector('.progress-bar') != null) {
857
877
  this._SfReportingContainer.querySelector('.progress-bar').style.display = 'flex';
858
878
  let progress = Math.floor((filled / total) * 100);
859
879
  if (progress == 100) {
@@ -1275,7 +1295,7 @@ let SfIReporting = class SfIReporting extends LitElement {
1275
1295
  return elementHtml;
1276
1296
  };
1277
1297
  this.renderElement = (dataObj) => {
1278
- var _a, _b, _c, _d;
1298
+ var _a, _b;
1279
1299
  let elementHtml = "";
1280
1300
  console.log('rendering obj', dataObj.type);
1281
1301
  if (dataObj.type == "section") {
@@ -1318,6 +1338,18 @@ let SfIReporting = class SfIReporting extends LitElement {
1318
1338
  </div>`;
1319
1339
  }
1320
1340
  else if (dataObj.type == "sf-i-form-select") {
1341
+ let valToBeShown = "";
1342
+ if (dataObj.savenameseparate == "yes") {
1343
+ if (dataObj.value[0] != null && dataObj.value[0].split(';').length > 0) {
1344
+ valToBeShown = dataObj.value[0].split(';')[0];
1345
+ }
1346
+ }
1347
+ else if (dataObj.value.name != null) {
1348
+ valToBeShown = dataObj.value.name;
1349
+ }
1350
+ else {
1351
+ valToBeShown = dataObj.value.reference;
1352
+ }
1321
1353
  elementHtml += `<div part="date-container" class="d-flex flex-col flex-grow">
1322
1354
  <label id="${dataObj.id}-label" part="date-label">${dataObj.label}</label>
1323
1355
  <div part="td-body-2"><sf-i-elastic-text text="${dataObj.hint}" minLength="50"></sf-i-elastic-text></div>
@@ -1326,7 +1358,7 @@ let SfIReporting = class SfIReporting extends LitElement {
1326
1358
  ${((_b = Object.keys(dataObj.value)) !== null && _b !== void 0 ? _b : []).length > 0 ? (`
1327
1359
  <div class="selected-option d-flex justtify-center align-center" part="selected-option" id="selected-option-${dataObj.id}">
1328
1360
  ${this.flow == "details" ? '' : '<span class="material-icons selected-option-icon mr-10">cancel</span>'}
1329
- <label class="selected-option-label" part="selected-option-label">${(_c = dataObj.value.name) !== null && _c !== void 0 ? _c : ((_d = dataObj.value.reference) !== null && _d !== void 0 ? _d : "")}</label>
1361
+ <label class="selected-option-label" part="selected-option-label">${valToBeShown}</label>
1330
1362
  </div>`) : (`
1331
1363
  ${(this.flow == "details") ? '' :
1332
1364
  `<button id="button-edit-form-${dataObj.id}" part="button-icon" class="material-icons button-edit-form button-icon-click">edit</button>`}