@sisense/sdk-ui 2.2.0 → 2.3.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 (83) hide show
  1. package/dist/ai.cjs +39 -27
  2. package/dist/ai.js +1650 -1155
  3. package/dist/analytics-composer.cjs +24 -24
  4. package/dist/analytics-composer.js +131 -127
  5. package/dist/derive-chart-family-5O0nGmIH.cjs +669 -0
  6. package/dist/derive-chart-family-H5uuw6lv.js +90468 -0
  7. package/dist/{dimensions-mYUylB-h.cjs → dimensions-R6yuR7CB.cjs} +1 -1
  8. package/dist/{dimensions-HgrcPa-Q.js → dimensions-aqixuZxM.js} +13 -13
  9. package/dist/index.cjs +27 -27
  10. package/dist/index.js +12531 -12644
  11. package/dist/index.umd.js +1578 -0
  12. package/dist/packages/sdk-ui/src/ai/api/types.d.ts +2 -0
  13. package/dist/packages/sdk-ui/src/ai/common/icon-button.d.ts +1 -1
  14. package/dist/packages/sdk-ui/src/analytics-composer/index.d.ts +1 -0
  15. package/dist/packages/sdk-ui/src/analytics-composer/widget/chart-options/get-widget-options.d.ts +23 -7
  16. package/dist/packages/sdk-ui/src/app/client-application.d.ts +16 -0
  17. package/dist/packages/sdk-ui/src/chart/restructured-charts/chart-builder-factory.d.ts +3 -1
  18. package/dist/packages/sdk-ui/src/chart/restructured-charts/highchart-based-charts/cartesians/helpers/alerts.d.ts +3 -0
  19. package/dist/packages/sdk-ui/src/chart/restructured-charts/{helpers/cartesians → highchart-based-charts/cartesians/helpers}/data-options.d.ts +2 -2
  20. package/dist/packages/sdk-ui/src/chart/restructured-charts/highchart-based-charts/cartesians/helpers/data.d.ts +4 -0
  21. package/dist/packages/sdk-ui/src/chart/restructured-charts/highchart-based-charts/cartesians/helpers/get-legacy-cartesian-chart-options.d.ts +3 -0
  22. package/dist/packages/sdk-ui/src/chart/restructured-charts/highchart-based-charts/cartesians/stackable/bar-chart/bar-chart-builder.d.ts +2 -0
  23. package/dist/packages/sdk-ui/src/chart/restructured-charts/highchart-based-charts/cartesians/stackable/bar-chart/highcharts-options-builder.d.ts +2 -0
  24. package/dist/packages/sdk-ui/src/chart/restructured-charts/{column-chart → highchart-based-charts/cartesians/stackable/column-chart}/column-chart-builder.d.ts +1 -1
  25. package/dist/packages/sdk-ui/src/chart/restructured-charts/highchart-based-charts/cartesians/stackable/column-chart/highcharts-options-builder.d.ts +2 -0
  26. package/dist/packages/sdk-ui/src/chart/restructured-charts/{helpers/cartesians/stackable → highchart-based-charts/cartesians/stackable/helpers}/design-options.d.ts +3 -3
  27. package/dist/packages/sdk-ui/src/chart/restructured-charts/highchart-based-charts/cartesians/types.d.ts +1 -0
  28. package/dist/packages/sdk-ui/src/chart/restructured-charts/highchart-based-charts/highcharts-based-chart-renderer/build-highchart-options.d.ts +20 -0
  29. package/dist/packages/sdk-ui/src/chart/restructured-charts/highchart-based-charts/highcharts-based-chart-renderer/highcharts-based-chart-renderer.d.ts +39 -0
  30. package/dist/packages/sdk-ui/src/chart/restructured-charts/highchart-based-charts/highcharts-based-chart-renderer/utils.d.ts +2 -0
  31. package/dist/packages/sdk-ui/src/chart/restructured-charts/highchart-based-charts/types.d.ts +28 -0
  32. package/dist/packages/sdk-ui/src/chart/restructured-charts/types.d.ts +2 -2
  33. package/dist/packages/sdk-ui/src/chart/types.d.ts +0 -1
  34. package/dist/packages/sdk-ui/src/chart-options-processor/apply-event-handlers.d.ts +15 -0
  35. package/dist/packages/sdk-ui/src/chart-options-processor/common-highcharts-option-service.d.ts +9 -0
  36. package/dist/packages/sdk-ui/src/chart-options-processor/subtype-to-design-options.d.ts +2 -1
  37. package/dist/packages/sdk-ui/src/chart-options-processor/theme-option-service.d.ts +8 -0
  38. package/dist/packages/sdk-ui/src/chart-options-processor/translations/design-options.d.ts +4 -1
  39. package/dist/packages/sdk-ui/src/common/components/grouped-items-browser/group.d.ts +1 -0
  40. package/dist/packages/sdk-ui/src/common/components/grouped-items-browser/types.d.ts +3 -0
  41. package/dist/packages/sdk-ui/src/common/components/loading-overlay.d.ts +1 -3
  42. package/dist/packages/sdk-ui/src/common/components/menu/menu-ids.d.ts +10 -1
  43. package/dist/packages/sdk-ui/src/common/components/menu/types.d.ts +2 -0
  44. package/dist/packages/sdk-ui/src/common/components/modal/index.d.ts +2 -0
  45. package/dist/packages/sdk-ui/src/common/components/modal/modal-context.d.ts +39 -0
  46. package/dist/packages/sdk-ui/src/common/components/modal/modal-provider.d.ts +19 -0
  47. package/dist/packages/sdk-ui/src/common/components/popover.d.ts +10 -0
  48. package/dist/packages/sdk-ui/src/common/hooks/use-combined-menu.d.ts +4 -8
  49. package/dist/packages/sdk-ui/src/dashboard/components/jtd-dashboard.d.ts +15 -0
  50. package/dist/packages/sdk-ui/src/dashboard/hooks/use-jtd.d.ts +113 -0
  51. package/dist/packages/sdk-ui/src/dashboard/types.d.ts +9 -2
  52. package/dist/packages/sdk-ui/src/data-browser/data-schema-browser/data-schema-browser.d.ts +14 -0
  53. package/dist/packages/sdk-ui/src/data-browser/data-schema-browser/data-schema-browser.styles.d.ts +6 -0
  54. package/dist/packages/sdk-ui/src/data-browser/dimensions-browser/types.d.ts +5 -0
  55. package/dist/packages/sdk-ui/src/decorators/component-decorators/as-sisense-component.d.ts +2 -0
  56. package/dist/packages/sdk-ui/src/decorators/component-decorators/with-modal.d.ts +6 -0
  57. package/dist/packages/sdk-ui/src/index.d.ts +2 -1
  58. package/dist/packages/sdk-ui/src/models/dashboard/index.d.ts +1 -0
  59. package/dist/packages/sdk-ui/src/models/dashboard/types.d.ts +6 -0
  60. package/dist/packages/sdk-ui/src/models/dashboard/use-dashboard-model/use-dashboard-model.d.ts +18 -17
  61. package/dist/packages/sdk-ui/src/models/dashboard/use-dashboard-model/use-dashboard-persistence.d.ts +34 -0
  62. package/dist/packages/sdk-ui/src/pivot-table/hooks/use-render-pivot.d.ts +4 -4
  63. package/dist/packages/sdk-ui/src/plugins-provider/types.d.ts +2 -2
  64. package/dist/packages/sdk-ui/src/props.d.ts +3 -3
  65. package/dist/packages/sdk-ui/src/translation/resources/en.d.ts +7 -0
  66. package/dist/packages/sdk-ui/src/translation/resources/index.d.ts +14 -0
  67. package/dist/packages/sdk-ui/src/types.d.ts +26 -3
  68. package/dist/packages/sdk-ui/src/utils/filter-relations.d.ts +4 -4
  69. package/dist/packages/sdk-ui/src/widget-by-id/types.d.ts +72 -0
  70. package/dist/packages/sdk-ui/src/widgets/common/drilldown-breadcrumbs/styled-buttons.d.ts +2 -2
  71. package/dist/packages/sdk-ui/src/widgets/tabber-widget.d.ts +2 -1
  72. package/dist/use-common-filters-CN2YnxBs.cjs +350 -0
  73. package/dist/use-common-filters-CSwVz8Hy.js +32068 -0
  74. package/dist/{widget-composer-JVl8mNCt.cjs → widget-composer-BB1-bv-q.cjs} +7 -7
  75. package/dist/{widget-composer-CACtfvw6.js → widget-composer-BpeW0NNz.js} +83 -73
  76. package/package.json +23 -19
  77. package/dist/derive-chart-family-BsbFdcgd.cjs +0 -758
  78. package/dist/derive-chart-family-C9IDI6UV.js +0 -102051
  79. package/dist/packages/sdk-ui/src/chart/restructured-charts/bar-chart/bar-chart-builder.d.ts +0 -2
  80. package/dist/packages/sdk-ui/src/chart/restructured-charts/helpers/cartesians/data.d.ts +0 -4
  81. package/dist/packages/sdk-ui/src/widget-by-id/use-get-dashboard-model-and-widget-model.d.ts +0 -14
  82. package/dist/use-common-filters-BKYG6WGA.cjs +0 -271
  83. package/dist/use-common-filters-DkwU7HJ3.js +0 -28928
@@ -1,6 +1,6 @@
1
- "use strict";var G=Object.defineProperty,X=Object.defineProperties;var Z=Object.getOwnPropertyDescriptors;var j=Object.getOwnPropertySymbols;var tt=Object.prototype.hasOwnProperty,et=Object.prototype.propertyIsEnumerable;var L=(t,e,r)=>e in t?G(t,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):t[e]=r,l=(t,e)=>{for(var r in e||(e={}))tt.call(e,r)&&L(t,r,e[r]);if(j)for(var r of j(e))et.call(e,r)&&L(t,r,e[r]);return t},m=(t,e)=>X(t,Z(e));const n=require("./derive-chart-family-BsbFdcgd.cjs");class P extends n.DimensionalElement{constructor(e,r){var i;super((i=e.jaql.title)!==null&&i!==void 0?i:"",r),this.expression=e.jaql.dim||e.jaql.formula,this.metadataItem=e,e.jaql.agg?this.aggregation=e.jaql.agg:delete this.aggregation,e.jaql.formula?this.formula=e.jaql.formula:delete this.formula,e.jaql.sort?this.sortType=n.getSortType(e.jaql.sort):delete this.sortType,this.skipValidation=!0}get id(){return this.expression}jaql(e){return e===!0?this.metadataItem.jaql:this.metadataItem}serialize(){const e=super.serialize();return e.__serializable="JaqlElement",e.metadataItem=this.metadataItem,e.type=this.type,e}}const rt={text:n.MetadataTypes.TextAttribute,numeric:n.MetadataTypes.NumericAttribute,datetime:n.MetadataTypes.DateLevel};function it(t){var e;return new P(t,(e=rt[t.jaql.datatype])!==null&&e!==void 0?e:"numeric")}function B(t){const{jaql:e}=t;if(e.formula)return n.createCalculatedMeasureHelper(e);const r=n.DimensionalLevelAttribute.translateJaqlToGranularity(e);return"agg"in e&&e.dim&&e.datatype?n.createMeasureHelper({expression:e.dim,dataType:e.datatype,agg:e.agg||"",granularity:r,format:void 0,sort:e.sort,title:e.title,dataSource:e.datasource}):e.dim&&e.datatype?n.createAttributeHelper({expression:e.dim,dataType:e.datatype,granularity:r,sort:e.sort,title:e.title,panel:t.panel,dataSource:e.datasource}):it(t)}const at={jaql:{datasource:{title:"",type:"elasticube"},metadata:[]},queryTitle:"",chartRecommendations:{}},st={model:"",metadata:[],chart:{},queryTitle:""},nt=t=>"widgetProps"in t,k=t=>"dashboardOid"in t&&"widgetOid"in t,ot=t=>"dashboardProps"in t,lt=t=>"dashboardOid"in t;function dt(t){return t.replace(/\s+/g,"-").replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}function ut(t){return t.charAt(0).toUpperCase()+t.slice(1)}function ct(t){const e=/\[(.+?)\s\(Calendar\)\]/;return t.replace(e,"[$1]").trim()}function pt(t){if(t)if(t.metadata){if(!t.model)throw new n.TranslatableError("errors.missingModelTitle")}else throw new n.TranslatableError("errors.missingMetadata");else throw new n.TranslatableError("errors.emptyModel");return t}function mt(t){return!t||!t.jaql.datasource.title||!t.jaql.metadata.length}function _(t){if(![...n.ALL_CHART_TYPES,"pivot","pivot2"].includes(t))throw new n.TranslatableError("errors.chartTypeNotSupported",{chartType:t})}function gt(t){return"widgetType"in t&&t.widgetType==="pivot"}function h(t){var e;return"column"in t&&((e=t.column)==null?void 0:e.expression)&&/\(.*\)/.test(t.column.expression)}function w(t){const e="measures"in t&&c(t.measures)||"values"in t&&c(t.values);return gt(t)?"values"in t.dataOptions&&c(t.dataOptions.values):"chartType"in t?t.chartType==="indicator"?"value"in t.dataOptions&&c(t.dataOptions.value)||"secondary"in t.dataOptions&&c(t.dataOptions.secondary):t.chartType==="table"?!("columns"in t.dataOptions)||!c(t.dataOptions.columns)?!1:t.dataOptions.columns.some(i=>h(i)):t.chartType==="boxplot"?!1:t.chartType==="scatter"?"x"in t.dataOptions&&t.dataOptions.x!==void 0&&h(t.dataOptions.x)||"y"in t.dataOptions&&t.dataOptions.y!==void 0&&h(t.dataOptions.y)||"size"in t.dataOptions&&t.dataOptions.size!==void 0:t.chartType==="scattermap"?"colorBy"in t.dataOptions&&t.dataOptions.colorBy!==void 0&&h(t.dataOptions.colorBy)||"details"in t.dataOptions&&t.dataOptions.details!==void 0&&h(t.dataOptions.details)||"size"in t.dataOptions&&t.dataOptions.size!==void 0&&h(t.dataOptions.size):t.chartType==="areamap"?"geo"in t.dataOptions&&c(t.dataOptions.geo)&&"color"in t.dataOptions&&c(t.dataOptions.color):"value"in t.dataOptions&&c(t.dataOptions.value):e}function c(t){return Array.isArray(t)&&t.length>0}function yt(t){const e=t.split(`
1
+ "use strict";var tt=Object.defineProperty,et=Object.defineProperties;var rt=Object.getOwnPropertyDescriptors;var j=Object.getOwnPropertySymbols;var it=Object.prototype.hasOwnProperty,at=Object.prototype.propertyIsEnumerable;var $=(t,e,r)=>e in t?tt(t,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):t[e]=r,l=(t,e)=>{for(var r in e||(e={}))it.call(e,r)&&$(t,r,e[r]);if(j)for(var r of j(e))at.call(e,r)&&$(t,r,e[r]);return t},m=(t,e)=>et(t,rt(e));const n=require("./derive-chart-family-5O0nGmIH.cjs");class P extends n.DimensionalElement{constructor(e,r){var i;super((i=e.jaql.title)!==null&&i!==void 0?i:"",r),this.expression=e.jaql.dim||e.jaql.formula,this.metadataItem=e,e.jaql.agg?this.aggregation=e.jaql.agg:delete this.aggregation,e.jaql.formula?this.formula=e.jaql.formula:delete this.formula,e.jaql.sort?this.sortType=n.getSortType(e.jaql.sort):delete this.sortType,this.skipValidation=!0}get id(){return this.expression}jaql(e){return e===!0?this.metadataItem.jaql:this.metadataItem}serialize(){const e=super.serialize();return e.__serializable="JaqlElement",e.metadataItem=this.metadataItem,e.type=this.type,e}}const st={text:n.MetadataTypes.TextAttribute,numeric:n.MetadataTypes.NumericAttribute,datetime:n.MetadataTypes.DateLevel};function nt(t){var e;return new P(t,(e=st[t.jaql.datatype])!==null&&e!==void 0?e:"numeric")}function B(t){const{jaql:e}=t;if(e.formula)return n.createCalculatedMeasureHelper(e);const r=n.DimensionalLevelAttribute.translateJaqlToGranularity(e);return"agg"in e&&e.dim&&e.datatype?n.createMeasureHelper({expression:e.dim,dataType:e.datatype,agg:e.agg||"",granularity:r,format:void 0,sort:e.sort,title:e.title,dataSource:e.datasource}):e.dim&&e.datatype?n.createAttributeHelper({expression:e.dim,dataType:e.datatype,granularity:r,sort:e.sort,title:e.title,panel:t.panel,dataSource:e.datasource}):nt(t)}const ot={jaql:{datasource:{title:"",type:"elasticube"},metadata:[]},queryTitle:"",chartRecommendations:{}},lt={model:"",metadata:[],chart:{},queryTitle:""},dt=t=>"widgetProps"in t,R=t=>"dashboardOid"in t&&"widgetOid"in t,ct=t=>"dashboardProps"in t,ut=t=>"dashboardOid"in t;function pt(t){return t.replace(/\s+/g,"-").replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}function mt(t){return t.charAt(0).toUpperCase()+t.slice(1)}function gt(t){const e=/\[(.+?)\s\(Calendar\)\]/;return t.replace(e,"[$1]").trim()}function yt(t){if(t)if(t.metadata){if(!t.model)throw new n.TranslatableError("errors.missingModelTitle")}else throw new n.TranslatableError("errors.missingMetadata");else throw new n.TranslatableError("errors.emptyModel");return t}function ft(t){return!t||!t.jaql.datasource.title||!t.jaql.metadata.length}function k(t){if(![...n.ALL_CHART_TYPES,"pivot","pivot2"].includes(t))throw new n.TranslatableError("errors.chartTypeNotSupported",{chartType:t})}function ht(t){return"widgetType"in t&&t.widgetType==="pivot"}function S(t){var e;return"column"in t&&((e=t.column)==null?void 0:e.expression)&&/\(.*\)/.test(t.column.expression)}function w(t){const e="measures"in t&&u(t.measures)||"values"in t&&u(t.values);return ht(t)?"values"in t.dataOptions&&u(t.dataOptions.values):"chartType"in t?t.chartType==="indicator"?"value"in t.dataOptions&&u(t.dataOptions.value)||"secondary"in t.dataOptions&&u(t.dataOptions.secondary):t.chartType==="table"?!("columns"in t.dataOptions)||!u(t.dataOptions.columns)?!1:t.dataOptions.columns.some(i=>S(i)):t.chartType==="boxplot"?!1:t.chartType==="scatter"?"x"in t.dataOptions&&t.dataOptions.x!==void 0&&S(t.dataOptions.x)||"y"in t.dataOptions&&t.dataOptions.y!==void 0&&S(t.dataOptions.y)||"size"in t.dataOptions&&t.dataOptions.size!==void 0:t.chartType==="scattermap"?"colorBy"in t.dataOptions&&t.dataOptions.colorBy!==void 0&&S(t.dataOptions.colorBy)||"details"in t.dataOptions&&t.dataOptions.details!==void 0&&S(t.dataOptions.details)||"size"in t.dataOptions&&t.dataOptions.size!==void 0&&S(t.dataOptions.size):t.chartType==="areamap"?"geo"in t.dataOptions&&u(t.dataOptions.geo)&&"color"in t.dataOptions&&u(t.dataOptions.color):"value"in t.dataOptions&&u(t.dataOptions.value):e}function u(t){return Array.isArray(t)&&t.length>0}function St(t){const e=t.split(`
2
2
  `);for(let r=0;r<e.length-1;r++)if(e[r].trim()===""){const i=e[r+1].trim();if(i.startsWith("import *")||i.startsWith("import {")){e.splice(r,1);break}}return e.join(`
3
- `)}const ft={react:{baseChartTmpl:`import { {{componentString}} } from '@sisense/sdk-ui';
3
+ `)}const Ot={react:{baseChartTmpl:`import { {{componentString}} } from '@sisense/sdk-ui';
4
4
  {{extraImportsString}}
5
5
  import * as DM from './{{dataSourceString}}'; // generated with @sisense/sdk-cli
6
6
 
@@ -416,13 +416,13 @@ import { DashboardById } from '@sisense/sdk-ui-vue';
416
416
  <\/script>
417
417
  <template>
418
418
  <DashboardById :dashboardOid="'{{dashboardOid}}'" />
419
- </template>`,dashboardTmpl:"/** COMING SOON */"}},F=(t,e)=>ft[e][t].replace(/{{(.*?)Tmpl}}/g,(i,a)=>F(`${a}Tmpl`,e)),N=(t,e)=>t.replace(/{{(.*?)}}/g,(r,i)=>i in e?e[i]:(console.warn(`Placeholder ${i} not found in data`),r)),C=(t,e,r="react")=>{const i=F(t,r);return yt(N(i,e))},St=()=>Object.values(n.AggregationTypes).map(e=>n.DimensionalBaseMeasure.aggregationToJAQL(e)).join("|"),R=t=>{const{formula:e,context:r,filter:i}=t;if(!r||!e)return t;const a=Object.keys(r);if(a.length!==1)return t;const s=a[0];if(typeof s!="string")return t;const o=r[`${s}`],d=St(),g=new RegExp(`^\\s*(${d})\\(\\[\\w+\\]\\)$`),f=e.match(g);if(f&&e.includes(s)){const u=f[1];return l({dim:o.dim,table:o.table,column:o.column,datatype:o.datatype,agg:u,title:t.title},i?{filter:l({},i)}:{})}return t},D=t=>{let e=t;if("formula"in t&&(e=R(t)),"context"in e){const r=l({},e.context);Object.keys(r).forEach(i=>{r[`${i}`]=D(r[`${i}`])}),e.context=r}return e},ht=t=>{var i;const e=t;if(e.panel!=="scope")return e;const{jaql:r}=e;return(i=r.filter)!=null&&i.by&&(r.filter.by=R(r.filter.by)),m(l({},e),{jaql:r})},z=t=>{let e=t;e=ht(e);const{jaql:r,measure:i,by:a}=e;return l(l(m(l({},e),{jaql:D(r)}),a?{by:D(a)}:{}),i?{measure:D(i)}:{})},O=6,E=`
420
- `,M="UNKNOWN",Ot=(t,e)=>{let r="";return r+=`measureFactory.customFormula(
419
+ </template>`,dashboardTmpl:"/** COMING SOON */"}},F=(t,e)=>Ot[e][t].replace(/{{(.*?)Tmpl}}/g,(i,a)=>F(`${a}Tmpl`,e)),_=(t,e)=>t.replace(/{{(.*?)}}/g,(r,i)=>i in e?e[i]:(console.warn(`Placeholder ${i} not found in data`),r)),C=(t,e,r="react")=>{const i=F(t,r);return St(_(i,e))},Tt=()=>Object.values(n.AggregationTypes).map(e=>n.DimensionalBaseMeasure.aggregationToJAQL(e)).join("|"),N=t=>{const{formula:e,context:r,filter:i}=t;if(!r||!e)return t;const a=Object.keys(r);if(a.length!==1)return t;const s=a[0];if(typeof s!="string")return t;const o=r[`${s}`],g=Tt(),d=new RegExp(`^\\s*(${g})\\(\\[\\w+\\]\\)$`),f=e.match(d);if(f&&e.includes(s)){const c=f[1];return l({dim:o.dim,table:o.table,column:o.column,datatype:o.datatype,agg:c,title:t.title},i?{filter:l({},i)}:{})}return t},D=t=>{let e=t;if("formula"in t&&(e=N(t)),"context"in e){const r=l({},e.context);Object.keys(r).forEach(i=>{r[`${i}`]=D(r[`${i}`])}),e.context=r}return e},bt=t=>{var i;const e=t;if(e.panel!=="scope")return e;const{jaql:r}=e;return(i=r.filter)!=null&&i.by&&(r.filter.by=N(r.filter.by)),m(l({},e),{jaql:r})},z=t=>{let e=t;e=bt(e);const{jaql:r,measure:i,by:a}=e;return l(l(m(l({},e),{jaql:D(r)}),a?{by:D(a)}:{}),i?{measure:D(i)}:{})},O=6,x=`
420
+ `,M="UNKNOWN",vt=(t,e)=>{let r="";return r+=`measureFactory.customFormula(
421
421
  `,r+=" ".repeat(e),r+=` '${n.escapeSingleQuotes(t.title)}',
422
422
  `,r+=" ".repeat(e),r+=` '${t.formula}',
423
423
  `,r+=" ".repeat(e),r+=` {
424
424
  `,Object.entries(t.context).forEach(([i,a])=>{const s=n.normalizeAttributeName(a.table||M,a.column||M,void 0,"DM");r+=" ".repeat(e),r+=` '${i.slice(1,-1)}': ${s},
425
425
  `}),r+=" ".repeat(e),r+=` }
426
- `,r+=" ".repeat(e),r+=")",r},Tt=t=>{const{level:e,table:r,column:i,agg:a,title:s}=t;let o;return r&&i&&(o=n.normalizeAttributeName(r,i,e,"DM")),a&&r&&i&&s&&(o=`measureFactory.${n.DimensionalBaseMeasure.aggregationFromJAQL(a)}(${o}, '${n.escapeSingleQuotes(s)}')`),o||M},bt=(t,e)=>{const r=t.jaql(!1).jaql;return"formula"in r?Ot(r,e):Tt(r)},p=(t,e=0,r=!1)=>{if(!t)return"";if(typeof t=="string")return`'${n.escapeSingleQuotes(t)}'`;if(t instanceof P)return bt(t,e);if(t instanceof n.DimensionalElement)return t.composeCode||"";let i="";return Array.isArray(t)?i+=`[${t.map(a=>p(a,e+2))}${t.length?E+" ".repeat(e+2):""}]`:(i+=`{${E}`,Object.entries(t).forEach(([a,s])=>{r&&typeof a=="string"&&(a=`'${n.escapeSingleQuotes(a)}'`),i+=" ".repeat(e+2),Array.isArray(s)?i+=`${a}: [${s.map(o=>p(o,e+4,r))}${s.length?E+" ".repeat(e+2):""}]`:typeof s=="object"&&s!==null?i+=`${a}: ${p(s,e+2,r)}`:["number","boolean","undefined"].includes(typeof s)||s===null?i+=`${a}: ${s}`:typeof s=="string"?i+=`${a}: '${n.escapeSingleQuotes(s)}'`:i+=`${a}: ${s}`,i+=`,${E}`}),i+=" ".repeat(e),i+="}"),i};function vt(t){return p(t,O)}function I(t,e="data-source-placeholder"){if(!t)return e;const r=typeof t=="object"&&"title"in t?t.title:t;return dt(r)}function W(t,e=!0){const r=[];return e&&r.push("measureFactory"),c(t)&&r.push("filterFactory"),r.length>0?`import { ${r.join(", ")} } from '@sisense/sdk-data';`:""}const Q=`
427
- `,xt=(t,e)=>{if(t.composeCode)return`${Q}${" ".repeat(e)}${t.composeCode}`;const r=t.jaql().jaql;return`${Q}${" ".repeat(e)}filterFactory.customFilter(${p(r,e,!0)})`},Et=(t,e=0)=>{if(!t)return"";let r="";return r+=`[${t.map(i=>xt(i,e+2))}${t.length?`
428
- `+" ".repeat(e+2):""}]`,r},q=t=>t?Array.isArray(t)?Et(t,6):"/** Filter relations not supported yet */":"[]",Dt=["executeQueryByWidgetIdTmpl","widgetByIdTmpl"],Ct="chartWidgetTmpl",wt="pivotTableWidgetTmpl",Mt=t=>t,It=({dashboardOid:t,widgetOid:e,uiFramework:r="react",chartType:i="table",includeChart:a=!0})=>{_(i);const s={dashboardOid:t,widgetOid:e},o=Dt[Number(a)];return C(o,s,r)},Y=(t,e,r)=>{if(n.isChartWidgetProps(t)){_(t.chartType);const i=w(t),a={idString:t.id,widgetTypeString:"chart",titleString:t.title,dataSourceString:I(t.dataSource),chartTypeString:Mt(t.chartType),dataOptionsString:vt(t.dataOptions),filtersString:q(t.filters),componentString:"ChartWidget",extraImportsString:W(t.filters||[],i),styleOptionsString:p(t.styleOptions||{},O),drilldownOptionsString:p(t.drilldownOptions||{},O)};return C(r.chart,a,e)}if(n.isPivotTableWidgetProps(t)){const i=w(t),a={idString:t.id,widgetTypeString:"pivot",titleString:t.title,dataSourceString:I(t.dataSource),dataOptionsString:p(t.dataOptions),filtersString:q(t.filters),componentString:"PivotTableWidget",extraImportsString:W(t.filters||[],i),styleOptionsString:p(t.styleOptions||{},O)};return C(r.pivot,a,e)}if(n.isPluginWidgetProps(t))return"/** Plugin widget code not supported yet */";throw new n.TranslatableError("errors.otherWidgetTypesNotSupported")},Wt=({widgetProps:t,uiFramework:e="react"})=>Y(t,e,{chart:Ct,pivot:wt}),qt=t=>({dataOptions:{columns:t.map(B)}}),Pt=Object.freeze({convolution:{enabled:!0,selectedConvolutionType:"bySlicesCount",independentSlicesCount:7},lineWidth:{width:"bold"},markers:{enabled:!1},legend:{enabled:!1},yAxis:{gridLines:!1},xAxis:{gridLines:!1}}),$=Object.freeze({line:"line/spline",pie:"pie/donut",bar:"bar/stacked",column:"column/stackedcolumn"}),jt=(t,e,r)=>{const i=t.reduce((s,o)=>(s[o.jaql.title]=o,s),{}),a=Object.entries(r).reduce((s,o)=>{const[d,g]=o;return s[`${d}`]=Array.isArray(g)?g.map(f=>{var T,b;const u=n.normalizeAnyColumn(f);delete u.enabled;const y=i[u.column.name];if(!y)return{column:{type:"",name:u.column.name}};const S=B(y);if(y.panel==="measures")return m(l({},u),{column:S});if(n.isDatetime(S.type)){const v=(b=(T=y.format)==null?void 0:T.mask)==null?void 0:b[y.jaql.level];if(v)return m(l({},u),{column:S,dateFormat:v})}return m(l({},u),{column:S})}):g,s},{});switch(e){case"cartesian":return l({category:[],value:[],breakBy:[]},a);case"categorical":return l({category:[],value:[]},a);case"scatter":return Object.keys(a).forEach(s=>{a[`${s}`]=a[`${s}`][0]}),a;case"scattermap":return Object.keys(a).forEach(s=>{s!=="geo"&&(a[`${s}`]=a[`${s}`][0])}),a;case"table":return Object.keys(a).length===0?qt(t).dataOptions:a;case"boxplot":case"areamap":case"indicator":default:return a}},A=(t,e)=>{var r,i,a,s;return e==="x"?(i=(r=t.axesMapping.category)!=null?r:t.axesMapping.x)==null?void 0:i.map(o=>n.normalizeAnyColumn(o).column.name).join(", "):(s=(a=t.axesMapping.value)!=null?a:t.axesMapping.y)==null?void 0:s.map(o=>n.normalizeAnyColumn(o).column.name).join(", ")},Lt=(t,e,r=!0)=>{const{chartFamily:i,axesMapping:a={},styleOptions:s={}}=e,o=jt(t,i,a);let d;return r&&e.chartType in $?d=n.merge(n.merge(Pt,{subtype:$[e.chartType]}),{legend:{enabled:!0,position:"right"},yAxis:{title:{enabled:!0,text:A(e,"y")}},xAxis:{title:{enabled:!0,text:A(e,"x")}}},s):d=n.merge(n.getDefaultStyleOptions(),s),{dataOptions:o,chartStyleOptions:d}},Qt=t=>"chartType"in t?t:{chartType:"table",chartFamily:"table",axesMapping:{}},$t=t=>t.map(e=>n.createFilterFromJaql(e.jaql)),At=t=>t.reduce((e,r)=>{if((r.panel==="scope"||r.jaql.filter)&&e.metadataFilters.push(n.cloneDeep(r)),r.panel!=="scope"){const i=n.cloneDeep(r);delete i.jaql.filter,e.metadataColumns.push(i)}return e},{metadataColumns:[],metadataFilters:[]}),Bt=(t,e)=>{if(!mt(t))try{const{useCustomizedStyleOptions:r=!1}=e||{},{jaql:i,chartRecommendations:a,queryTitle:s}=t,{metadata:o,datasource:d}=i,g=m(l({},d),{type:d.type||"elasticube"}),f=n.convertJaqlDataSourceForDto(g),u=o.map(x=>z(x)).map(x=>m(l({},x),{jaql:m(l({},x.jaql),{datasource:f})})),y=Qt(a),S=y.chartType.toLowerCase(),T={cornerRadius:"Small",header:{renderToolbar:()=>null}},{metadataColumns:b,metadataFilters:v}=At(u),U=$t(v),{dataOptions:K,chartStyleOptions:V}=Lt(b,y,r),H=l(l({},V),T);return{widgetType:"chart",id:s,title:s,chartType:S,dataSource:g,dataOptions:K,filters:U,styleOptions:H}}catch(r){console.error(r);return}},J=(t,e)=>Bt(t,e),kt=t=>k(t)?It(t):Wt(t),_t=Object.freeze(Object.defineProperty({__proto__:null,toWidgetCode:kt,toWidgetProps:J},Symbol.toStringTag,{value:"Module"}));exports.CODE_TEMPLATES_INDENT=O;exports.EMPTY_EXPANDED_QUERY_MODEL=at;exports.EMPTY_SIMPLE_QUERY_MODEL=st;exports.JaqlElement=P;exports.capitalizeFirstLetter=ut;exports.checkIfMeasuresExist=w;exports.generateCode=C;exports.getWidgetCode=Y;exports.isByIdDashboardCodeParams=lt;exports.isByIdWidgetCodeParams=k;exports.isClientSideDashboardCodeParams=ot;exports.isClientSideWidgetCodeParams=nt;exports.populatePlaceholders=N;exports.sanitizeDimensionId=ct;exports.simplifyMetadataItem=z;exports.stringifyDataSource=I;exports.stringifyExtraImports=W;exports.stringifyFilters=q;exports.stringifyProps=p;exports.toWidgetProps=J;exports.validateQueryModel=pt;exports.widgetComposer=_t;
426
+ `,r+=" ".repeat(e),r+=")",r},Et=t=>{const{level:e,table:r,column:i,agg:a,title:s}=t;let o;return r&&i&&(o=n.normalizeAttributeName(r,i,e,"DM")),a&&r&&i&&s&&(o=`measureFactory.${n.DimensionalBaseMeasure.aggregationFromJAQL(a)}(${o}, '${n.escapeSingleQuotes(s)}')`),o||M},xt=(t,e)=>{const r=t.jaql(!1).jaql;return"formula"in r?vt(r,e):Et(r)},p=(t,e=0,r=!1)=>{if(!t)return"";if(typeof t=="string")return`'${n.escapeSingleQuotes(t)}'`;if(t instanceof P)return xt(t,e);if(t instanceof n.DimensionalElement)return t.composeCode||"";let i="";return Array.isArray(t)?i+=`[${t.map(a=>p(a,e+2))}${t.length?x+" ".repeat(e+2):""}]`:(i+=`{${x}`,Object.entries(t).forEach(([a,s])=>{r&&typeof a=="string"&&(a=`'${n.escapeSingleQuotes(a)}'`),i+=" ".repeat(e+2),Array.isArray(s)?i+=`${a}: [${s.map(o=>p(o,e+4,r))}${s.length?x+" ".repeat(e+2):""}]`:typeof s=="object"&&s!==null?i+=`${a}: ${p(s,e+2,r)}`:["number","boolean","undefined"].includes(typeof s)||s===null?i+=`${a}: ${s}`:typeof s=="string"?i+=`${a}: '${n.escapeSingleQuotes(s)}'`:i+=`${a}: ${s}`,i+=`,${x}`}),i+=" ".repeat(e),i+="}"),i};function Dt(t){return p(t,O)}function I(t,e="data-source-placeholder"){if(!t)return e;const r=typeof t=="object"&&"title"in t?t.title:t;return pt(r)}function W(t,e=!0){const r=[];return e&&r.push("measureFactory"),u(t)&&r.push("filterFactory"),r.length>0?`import { ${r.join(", ")} } from '@sisense/sdk-data';`:""}const L=`
427
+ `,Ct=(t,e)=>{if(t.composeCode)return`${L}${" ".repeat(e)}${t.composeCode}`;const r=t.jaql().jaql;return`${L}${" ".repeat(e)}filterFactory.customFilter(${p(r,e,!0)})`},wt=(t,e=0)=>{if(!t)return"";let r="";return r+=`[${t.map(i=>Ct(i,e+2))}${t.length?`
428
+ `+" ".repeat(e+2):""}]`,r},q=t=>t?Array.isArray(t)?wt(t,6):"/** Filter relations not supported yet */":"[]",Mt=["executeQueryByWidgetIdTmpl","widgetByIdTmpl"],It="chartWidgetTmpl",Wt="pivotTableWidgetTmpl",qt=t=>t,Pt=({dashboardOid:t,widgetOid:e,uiFramework:r="react",chartType:i="table",includeChart:a=!0})=>{k(i);const s={dashboardOid:t,widgetOid:e},o=Mt[Number(a)];return C(o,s,r)},Y=(t,e,r)=>{if(n.isChartWidgetProps(t)){k(t.chartType);const i=w(t),a={idString:t.id,widgetTypeString:"chart",titleString:t.title,dataSourceString:I(t.dataSource),chartTypeString:qt(t.chartType),dataOptionsString:Dt(t.dataOptions),filtersString:q(t.filters),componentString:"ChartWidget",extraImportsString:W(t.filters||[],i),styleOptionsString:p(t.styleOptions||{},O),drilldownOptionsString:p(t.drilldownOptions||{},O)};return C(r.chart,a,e)}if(n.isPivotTableWidgetProps(t)){const i=w(t),a={idString:t.id,widgetTypeString:"pivot",titleString:t.title,dataSourceString:I(t.dataSource),dataOptionsString:p(t.dataOptions),filtersString:q(t.filters),componentString:"PivotTableWidget",extraImportsString:W(t.filters||[],i),styleOptionsString:p(t.styleOptions||{},O)};return C(r.pivot,a,e)}if(n.isPluginWidgetProps(t))return"/** Plugin widget code not supported yet */";throw new n.TranslatableError("errors.otherWidgetTypesNotSupported")},jt=({widgetProps:t,uiFramework:e="react"})=>Y(t,e,{chart:It,pivot:Wt}),$t=t=>"chartType"in t.chartRecommendations?t.chartRecommendations:{chartType:"table",chartFamily:"table",axesMapping:{}},Lt=t=>({dataOptions:{columns:t.map(B)}}),Qt=Object.freeze({convolution:{enabled:!0,selectedConvolutionType:"bySlicesCount",independentSlicesCount:7},lineWidth:{width:"bold"},markers:{enabled:!1},legend:{enabled:!1},yAxis:{gridLines:!1},xAxis:{gridLines:!1}}),Q=Object.freeze({line:"line/spline",pie:"pie/donut",bar:"bar/stacked",column:"column/stackedcolumn"}),J=(t,e,r)=>{const i=t.reduce((s,o)=>(s[o.jaql.title]=o,s),{}),a=Object.entries(r).reduce((s,o)=>{const[g,d]=o;return s[`${g}`]=Array.isArray(d)?d.map(f=>{var T,b;const c=n.normalizeAnyColumn(f);delete c.enabled;const y=i[c.column.name];if(!y)return{column:{type:"",name:c.column.name}};const h=B(y);if(y.panel==="measures")return m(l({},c),{column:h});if(n.isDatetime(h.type)){const v=(b=(T=y.format)==null?void 0:T.mask)==null?void 0:b[y.jaql.level];if(v)return m(l({},c),{column:h,dateFormat:v})}return m(l({},c),{column:h})}):d,s},{});switch(e){case"cartesian":return l({category:[],value:[],breakBy:[]},a);case"categorical":return l({category:[],value:[]},a);case"scatter":return Object.keys(a).forEach(s=>{a[`${s}`]=a[`${s}`][0]}),a;case"scattermap":return Object.keys(a).forEach(s=>{s!=="geo"&&(a[`${s}`]=a[`${s}`][0])}),a;case"table":return Object.keys(a).length===0?Lt(t).dataOptions:a;case"boxplot":case"areamap":case"indicator":default:return a}},A=(t,e)=>{var r,i,a,s;return e==="x"?(i=(r=t.category)!=null?r:t.x)==null?void 0:i.map(o=>n.normalizeAnyColumn(o).column.name).join(", "):(s=(a=t.value)!=null?a:t.y)==null?void 0:s.map(o=>n.normalizeAnyColumn(o).column.name).join(", ")},U=(t,e,r,i)=>{let a;return i&&t in Q?a=n.merge(n.merge(Qt,{subtype:Q[`${t}`]}),{legend:{enabled:!0,position:"right"},yAxis:{title:{enabled:!0,text:A(e,"y")}},xAxis:{title:{enabled:!0,text:A(e,"x")}}},r):a=n.merge(n.getDefaultStyleOptions(),r),a},K=(t,e,r=!0)=>{const{chartFamily:i,chartType:a,axesMapping:s={},styleOptions:o={}}=e,g=J(t,i,s),d=U(a,s,o,r);return{dataOptions:g,chartStyleOptions:d}},At=t=>"chartType"in t?t:{chartType:"table",chartFamily:"table",axesMapping:{}},Bt=t=>t.map(e=>n.createFilterFromJaql(e.jaql)),Rt=t=>t.reduce((e,r)=>{if((r.panel==="scope"||r.jaql.filter)&&e.metadataFilters.push(n.cloneDeep(r)),r.panel!=="scope"){const i=n.cloneDeep(r);delete i.jaql.filter,e.metadataColumns.push(i)}return e},{metadataColumns:[],metadataFilters:[]}),kt=(t,e)=>{if(!ft(t))try{const{useCustomizedStyleOptions:r=!1}=e||{},{jaql:i,chartRecommendations:a,queryTitle:s}=t,{metadata:o,datasource:g}=i,d=m(l({},g),{type:g.type||"elasticube"}),f=n.convertJaqlDataSourceForDto(d),c=o.map(E=>z(E)).map(E=>m(l({},E),{jaql:m(l({},E.jaql),{datasource:f})})),y=At(a),h=y.chartType.toLowerCase(),T={cornerRadius:"Small",header:{renderToolbar:()=>null}},{metadataColumns:b,metadataFilters:v}=Rt(c),H=Bt(v),{dataOptions:G,chartStyleOptions:X}=K(b,y,r),Z=l(l({},X),T);return{widgetType:"chart",id:s,title:s,chartType:h,dataSource:d,dataOptions:G,filters:H,styleOptions:Z}}catch(r){console.error(r);return}},V=(t,e)=>kt(t,e),Ft=t=>R(t)?Pt(t):jt(t),_t=Object.freeze(Object.defineProperty({__proto__:null,toWidgetCode:Ft,toWidgetProps:V},Symbol.toStringTag,{value:"Module"}));exports.CODE_TEMPLATES_INDENT=O;exports.EMPTY_EXPANDED_QUERY_MODEL=ot;exports.EMPTY_SIMPLE_QUERY_MODEL=lt;exports.JaqlElement=P;exports.capitalizeFirstLetter=mt;exports.checkIfMeasuresExist=w;exports.generateCode=C;exports.getChartDataOptions=J;exports.getChartOptions=K;exports.getChartRecommendationsOrDefault=$t;exports.getChartStyleOptions=U;exports.getWidgetCode=Y;exports.isByIdDashboardCodeParams=ut;exports.isByIdWidgetCodeParams=R;exports.isClientSideDashboardCodeParams=ct;exports.isClientSideWidgetCodeParams=dt;exports.populatePlaceholders=_;exports.sanitizeDimensionId=gt;exports.simplifyMetadataItem=z;exports.stringifyDataSource=I;exports.stringifyExtraImports=W;exports.stringifyFilters=q;exports.stringifyProps=p;exports.toWidgetProps=V;exports.validateQueryModel=yt;exports.widgetComposer=_t;
@@ -9,9 +9,9 @@ var $ = (t, e, r) => e in t ? tt(t, e, { enumerable: !0, configurable: !0, writa
9
9
  for (var r of j(e))
10
10
  at.call(e, r) && $(t, r, e[r]);
11
11
  return t;
12
- }, c = (t, e) => et(t, rt(e));
13
- import { ek as _, a3 as st, eq as nt, aP as ot, er as lt, es as dt, M as C, T as S, et as ut, bd as R, e6 as ct, eu as O, em as z, aY as pt, bj as mt, bi as gt, m as M, ev as yt, b4 as I, aO as ft, ay as ht, c4 as P, ew as St } from "./derive-chart-family-C9IDI6UV.js";
14
- class J extends _ {
12
+ }, u = (t, e) => et(t, rt(e));
13
+ import { dW as N, w as st, e0 as nt, ap as ot, e1 as lt, e2 as dt, m as C, T as S, e3 as ct, aP as _, dI as ut, e4 as O, dY as z, ay as pt, aW as mt, aV as gt, aG as M, ao as yt, n as I, e5 as ft, a8 as ht, bG as P, e6 as St } from "./derive-chart-family-H5uuw6lv.js";
14
+ class J extends N {
15
15
  constructor(e, r) {
16
16
  var i;
17
17
  super((i = e.jaql.title) !== null && i !== void 0 ? i : "", r), this.expression = e.jaql.dim || e.jaql.formula, this.metadataItem = e, e.jaql.agg ? this.aggregation = e.jaql.agg : delete this.aggregation, e.jaql.formula ? this.formula = e.jaql.formula : delete this.formula, e.jaql.sort ? this.sortType = st(e.jaql.sort) : delete this.sortType, this.skipValidation = !0;
@@ -63,7 +63,7 @@ function Y(t) {
63
63
  dataSource: e.datasource
64
64
  }) : Tt(t);
65
65
  }
66
- const re = {
66
+ const ie = {
67
67
  jaql: {
68
68
  datasource: {
69
69
  title: "",
@@ -73,23 +73,23 @@ const re = {
73
73
  },
74
74
  queryTitle: "",
75
75
  chartRecommendations: {}
76
- }, ie = {
76
+ }, ae = {
77
77
  model: "",
78
78
  metadata: [],
79
79
  chart: {},
80
80
  queryTitle: ""
81
- }, ae = (t) => "widgetProps" in t, bt = (t) => "dashboardOid" in t && "widgetOid" in t, se = (t) => "dashboardProps" in t, ne = (t) => "dashboardOid" in t;
81
+ }, se = (t) => "widgetProps" in t, bt = (t) => "dashboardOid" in t && "widgetOid" in t, ne = (t) => "dashboardProps" in t, oe = (t) => "dashboardOid" in t;
82
82
  function vt(t) {
83
83
  return t.replace(/\s+/g, "-").replace(/([a-z])([A-Z])/g, "$1-$2").toLowerCase();
84
84
  }
85
- function oe(t) {
85
+ function le(t) {
86
86
  return t.charAt(0).toUpperCase() + t.slice(1);
87
87
  }
88
- function le(t) {
88
+ function de(t) {
89
89
  const e = /\[(.+?)\s\(Calendar\)\]/;
90
90
  return t.replace(e, "[$1]").trim();
91
91
  }
92
- function de(t) {
92
+ function ce(t) {
93
93
  if (t)
94
94
  if (t.metadata) {
95
95
  if (!t.model)
@@ -105,7 +105,7 @@ function xt(t) {
105
105
  }
106
106
  function U(t) {
107
107
  if (![
108
- ...ut,
108
+ ...ct,
109
109
  "pivot",
110
110
  "pivot2"
111
111
  ].includes(t))
@@ -121,10 +121,10 @@ function h(t) {
121
121
  return "column" in t && ((e = t.column) == null ? void 0 : e.expression) && /\(.*\)/.test(t.column.expression);
122
122
  }
123
123
  function L(t) {
124
- const e = "measures" in t && u(t.measures) || "values" in t && u(t.values);
125
- return Et(t) ? "values" in t.dataOptions && u(t.dataOptions.values) : "chartType" in t ? t.chartType === "indicator" ? "value" in t.dataOptions && u(t.dataOptions.value) || "secondary" in t.dataOptions && u(t.dataOptions.secondary) : t.chartType === "table" ? !("columns" in t.dataOptions) || !u(t.dataOptions.columns) ? !1 : t.dataOptions.columns.some((i) => h(i)) : t.chartType === "boxplot" ? !1 : t.chartType === "scatter" ? "x" in t.dataOptions && t.dataOptions.x !== void 0 && h(t.dataOptions.x) || "y" in t.dataOptions && t.dataOptions.y !== void 0 && h(t.dataOptions.y) || "size" in t.dataOptions && t.dataOptions.size !== void 0 : t.chartType === "scattermap" ? "colorBy" in t.dataOptions && t.dataOptions.colorBy !== void 0 && h(t.dataOptions.colorBy) || "details" in t.dataOptions && t.dataOptions.details !== void 0 && h(t.dataOptions.details) || "size" in t.dataOptions && t.dataOptions.size !== void 0 && h(t.dataOptions.size) : t.chartType === "areamap" ? "geo" in t.dataOptions && u(t.dataOptions.geo) && "color" in t.dataOptions && u(t.dataOptions.color) : "value" in t.dataOptions && u(t.dataOptions.value) : e;
124
+ const e = "measures" in t && c(t.measures) || "values" in t && c(t.values);
125
+ return Et(t) ? "values" in t.dataOptions && c(t.dataOptions.values) : "chartType" in t ? t.chartType === "indicator" ? "value" in t.dataOptions && c(t.dataOptions.value) || "secondary" in t.dataOptions && c(t.dataOptions.secondary) : t.chartType === "table" ? !("columns" in t.dataOptions) || !c(t.dataOptions.columns) ? !1 : t.dataOptions.columns.some((i) => h(i)) : t.chartType === "boxplot" ? !1 : t.chartType === "scatter" ? "x" in t.dataOptions && t.dataOptions.x !== void 0 && h(t.dataOptions.x) || "y" in t.dataOptions && t.dataOptions.y !== void 0 && h(t.dataOptions.y) || "size" in t.dataOptions && t.dataOptions.size !== void 0 : t.chartType === "scattermap" ? "colorBy" in t.dataOptions && t.dataOptions.colorBy !== void 0 && h(t.dataOptions.colorBy) || "details" in t.dataOptions && t.dataOptions.details !== void 0 && h(t.dataOptions.details) || "size" in t.dataOptions && t.dataOptions.size !== void 0 && h(t.dataOptions.size) : t.chartType === "areamap" ? "geo" in t.dataOptions && c(t.dataOptions.geo) && "color" in t.dataOptions && c(t.dataOptions.color) : "value" in t.dataOptions && c(t.dataOptions.value) : e;
126
126
  }
127
- function u(t) {
127
+ function c(t) {
128
128
  return Array.isArray(t) && t.length > 0;
129
129
  }
130
130
  function Dt(t) {
@@ -603,7 +603,7 @@ import { DashboardById } from '@sisense/sdk-ui-vue';
603
603
  }, K = (t, e) => wt[e][t].replace(/{{(.*?)Tmpl}}/g, (i, a) => K(`${a}Tmpl`, e)), Ct = (t, e) => t.replace(/{{(.*?)}}/g, (r, i) => i in e ? e[i] : (console.warn(`Placeholder ${i} not found in data`), r)), q = (t, e, r = "react") => {
604
604
  const i = K(t, r);
605
605
  return Dt(Ct(i, e));
606
- }, Mt = () => Object.values(ct).map((e) => R.aggregationToJAQL(e)).join("|"), V = (t) => {
606
+ }, It = () => Object.values(ut).map((e) => _.aggregationToJAQL(e)).join("|"), V = (t) => {
607
607
  const { formula: e, context: r, filter: i } = t;
608
608
  if (!r || !e)
609
609
  return t;
@@ -613,7 +613,7 @@ import { DashboardById } from '@sisense/sdk-ui-vue';
613
613
  const s = a[0];
614
614
  if (typeof s != "string")
615
615
  return t;
616
- const n = r[`${s}`], l = Mt(), m = new RegExp(`^\\s*(${l})\\(\\[\\w+\\]\\)$`), y = e.match(m);
616
+ const n = r[`${s}`], m = It(), l = new RegExp(`^\\s*(${m})\\(\\[\\w+\\]\\)$`), y = e.match(l);
617
617
  if (y && e.includes(s)) {
618
618
  const d = y[1];
619
619
  return o({
@@ -637,20 +637,20 @@ import { DashboardById } from '@sisense/sdk-ui-vue';
637
637
  }), e.context = r;
638
638
  }
639
639
  return e;
640
- }, It = (t) => {
640
+ }, Mt = (t) => {
641
641
  var i;
642
642
  const e = t;
643
643
  if (e.panel !== "scope")
644
644
  return e;
645
645
  const { jaql: r } = e;
646
- return (i = r.filter) != null && i.by && (r.filter.by = V(r.filter.by)), c(o({}, e), {
646
+ return (i = r.filter) != null && i.by && (r.filter.by = V(r.filter.by)), u(o({}, e), {
647
647
  jaql: r
648
648
  });
649
649
  }, qt = (t) => {
650
650
  let e = t;
651
- e = It(e);
651
+ e = Mt(e);
652
652
  const { jaql: r, measure: i, by: a } = e;
653
- return o(o(c(o({}, e), {
653
+ return o(o(u(o({}, e), {
654
654
  jaql: D(r)
655
655
  }), a ? {
656
656
  by: D(a)
@@ -673,7 +673,7 @@ import { DashboardById } from '@sisense/sdk-ui-vue';
673
673
  }, jt = (t) => {
674
674
  const { level: e, table: r, column: i, agg: a, title: s } = t;
675
675
  let n;
676
- return r && i && (n = z(r, i, e, "DM")), a && r && i && s && (n = `measureFactory.${R.aggregationFromJAQL(a)}(${n}, '${O(s)}')`), n || W;
676
+ return r && i && (n = z(r, i, e, "DM")), a && r && i && s && (n = `measureFactory.${_.aggregationFromJAQL(a)}(${n}, '${O(s)}')`), n || W;
677
677
  }, $t = (t, e) => {
678
678
  const r = t.jaql(!1).jaql;
679
679
  return "formula" in r ? Wt(r, e) : jt(r);
@@ -684,7 +684,7 @@ import { DashboardById } from '@sisense/sdk-ui-vue';
684
684
  return `'${O(t)}'`;
685
685
  if (t instanceof J)
686
686
  return $t(t, e);
687
- if (t instanceof _)
687
+ if (t instanceof N)
688
688
  return t.composeCode || "";
689
689
  let i = "";
690
690
  return Array.isArray(t) ? i += `[${t.map((a) => p(a, e + 2))}${t.length ? E + " ".repeat(e + 2) : ""}]` : (i += `{${E}`, Object.entries(t).forEach(([a, s]) => {
@@ -706,7 +706,7 @@ function Q(t, e = "data-source-placeholder") {
706
706
  }
707
707
  function A(t, e = !0) {
708
708
  const r = [];
709
- return e && r.push("measureFactory"), u(t) && r.push("filterFactory"), r.length > 0 ? `import { ${r.join(", ")} } from '@sisense/sdk-data';` : "";
709
+ return e && r.push("measureFactory"), c(t) && r.push("filterFactory"), r.length > 0 ? `import { ${r.join(", ")} } from '@sisense/sdk-data';` : "";
710
710
  }
711
711
  const k = `
712
712
  `, Lt = (t, e) => {
@@ -723,14 +723,14 @@ const k = `
723
723
  }, B = (t) => t ? Array.isArray(t) ? Qt(t, 6) : "/** Filter relations not supported yet */" : "[]", At = [
724
724
  "executeQueryByWidgetIdTmpl",
725
725
  "widgetByIdTmpl"
726
- ], kt = "chartWidgetTmpl", Bt = "pivotTableWidgetTmpl", Ft = (t) => t, Nt = ({ dashboardOid: t, widgetOid: e, uiFramework: r = "react", chartType: i = "table", includeChart: a = !0 }) => {
726
+ ], kt = "chartWidgetTmpl", Bt = "pivotTableWidgetTmpl", Rt = (t) => t, Ft = ({ dashboardOid: t, widgetOid: e, uiFramework: r = "react", chartType: i = "table", includeChart: a = !0 }) => {
727
727
  U(i);
728
728
  const s = {
729
729
  dashboardOid: t,
730
730
  widgetOid: e
731
731
  }, n = At[Number(a)];
732
732
  return q(n, s, r);
733
- }, _t = (t, e, r) => {
733
+ }, Nt = (t, e, r) => {
734
734
  if (pt(t)) {
735
735
  U(t.chartType);
736
736
  const i = L(t), a = {
@@ -738,7 +738,7 @@ const k = `
738
738
  widgetTypeString: "chart",
739
739
  titleString: t.title,
740
740
  dataSourceString: Q(t.dataSource),
741
- chartTypeString: Ft(t.chartType),
741
+ chartTypeString: Rt(t.chartType),
742
742
  dataOptionsString: Pt(t.dataOptions),
743
743
  filtersString: B(t.filters),
744
744
  componentString: "ChartWidget",
@@ -765,10 +765,14 @@ const k = `
765
765
  if (gt(t))
766
766
  return "/** Plugin widget code not supported yet */";
767
767
  throw new S("errors.otherWidgetTypesNotSupported");
768
- }, Rt = ({ widgetProps: t, uiFramework: e = "react" }) => _t(t, e, {
768
+ }, _t = ({ widgetProps: t, uiFramework: e = "react" }) => Nt(t, e, {
769
769
  chart: kt,
770
770
  pivot: Bt
771
- }), zt = (t) => ({
771
+ }), ue = (t) => "chartType" in t.chartRecommendations ? t.chartRecommendations : {
772
+ chartType: "table",
773
+ chartFamily: "table",
774
+ axesMapping: {}
775
+ }, zt = (t) => ({
772
776
  dataOptions: {
773
777
  columns: t.map(Y)
774
778
  }
@@ -793,17 +797,17 @@ const k = `
793
797
  xAxis: {
794
798
  gridLines: !1
795
799
  }
796
- }), F = Object.freeze({
800
+ }), R = Object.freeze({
797
801
  line: "line/spline",
798
802
  pie: "pie/donut",
799
803
  bar: "bar/stacked",
800
804
  column: "column/stackedcolumn"
801
805
  }), Yt = (t, e, r) => {
802
806
  const i = t.reduce((s, n) => (s[n.jaql.title] = n, s), {}), a = Object.entries(r).reduce((s, n) => {
803
- const [l, m] = n;
804
- return s[`${l}`] = Array.isArray(m) ? m.map((y) => {
807
+ const [m, l] = n;
808
+ return s[`${m}`] = Array.isArray(l) ? l.map((y) => {
805
809
  var T, b;
806
- const d = I(y);
810
+ const d = M(y);
807
811
  delete d.enabled;
808
812
  const g = i[d.column.name];
809
813
  if (!g)
@@ -815,21 +819,21 @@ const k = `
815
819
  };
816
820
  const f = Y(g);
817
821
  if (g.panel === "measures")
818
- return c(o({}, d), {
822
+ return u(o({}, d), {
819
823
  column: f
820
824
  });
821
- if (ft(f.type)) {
825
+ if (yt(f.type)) {
822
826
  const v = (b = (T = g.format) == null ? void 0 : T.mask) == null ? void 0 : b[g.jaql.level];
823
827
  if (v)
824
- return c(o({}, d), {
828
+ return u(o({}, d), {
825
829
  column: f,
826
830
  dateFormat: v
827
831
  });
828
832
  }
829
- return c(o({}, d), {
833
+ return u(o({}, d), {
830
834
  column: f
831
835
  });
832
- }) : m, s;
836
+ }) : l, s;
833
837
  }, {});
834
838
  switch (e) {
835
839
  case "cartesian":
@@ -859,14 +863,13 @@ const k = `
859
863
  default:
860
864
  return a;
861
865
  }
862
- }, N = (t, e) => {
866
+ }, F = (t, e) => {
863
867
  var r, i, a, s;
864
- return e === "x" ? (i = (r = t.axesMapping.category) != null ? r : t.axesMapping.x) == null ? void 0 : i.map((n) => I(n).column.name).join(", ") : (s = (a = t.axesMapping.value) != null ? a : t.axesMapping.y) == null ? void 0 : s.map((n) => I(n).column.name).join(", ");
865
- }, Ut = (t, e, r = !0) => {
866
- const { chartFamily: i, axesMapping: a = {}, styleOptions: s = {} } = e, n = Yt(t, i, a);
867
- let l;
868
- return r && e.chartType in F ? l = M(M(Jt, {
869
- subtype: F[e.chartType]
868
+ return e === "x" ? (i = (r = t.category) != null ? r : t.x) == null ? void 0 : i.map((n) => M(n).column.name).join(", ") : (s = (a = t.value) != null ? a : t.y) == null ? void 0 : s.map((n) => M(n).column.name).join(", ");
869
+ }, Ut = (t, e, r, i) => {
870
+ let a;
871
+ return i && t in R ? a = I(I(Jt, {
872
+ subtype: R[`${t}`]
870
873
  }), {
871
874
  legend: {
872
875
  enabled: !0,
@@ -875,24 +878,27 @@ const k = `
875
878
  yAxis: {
876
879
  title: {
877
880
  enabled: !0,
878
- text: N(e, "y")
881
+ text: F(e, "y")
879
882
  }
880
883
  },
881
884
  xAxis: {
882
885
  title: {
883
886
  enabled: !0,
884
- text: N(e, "x")
887
+ text: F(e, "x")
885
888
  }
886
889
  }
887
- }, s) : l = M(yt(), s), {
888
- dataOptions: n,
890
+ }, r) : a = I(ft(), r), a;
891
+ }, Kt = (t, e, r = !0) => {
892
+ const { chartFamily: i, chartType: a, axesMapping: s = {}, styleOptions: n = {} } = e, m = Yt(t, i, s), l = Ut(a, s, n, r);
893
+ return {
894
+ dataOptions: m,
889
895
  chartStyleOptions: l
890
896
  };
891
- }, Kt = (t) => "chartType" in t ? t : {
897
+ }, Vt = (t) => "chartType" in t ? t : {
892
898
  chartType: "table",
893
899
  chartFamily: "table",
894
900
  axesMapping: {}
895
- }, Vt = (t) => t.map((e) => ht(e.jaql)), Ht = (t) => t.reduce((e, r) => {
901
+ }, Gt = (t) => t.map((e) => ht(e.jaql)), Ht = (t) => t.reduce((e, r) => {
896
902
  if ((r.panel === "scope" || r.jaql.filter) && e.metadataFilters.push(P(r)), r.panel !== "scope") {
897
903
  const i = P(r);
898
904
  delete i.jaql.filter, e.metadataColumns.push(i);
@@ -901,62 +907,66 @@ const k = `
901
907
  }, {
902
908
  metadataColumns: [],
903
909
  metadataFilters: []
904
- }), Gt = (t, e) => {
910
+ }), Xt = (t, e) => {
905
911
  if (!xt(t))
906
912
  try {
907
- const { useCustomizedStyleOptions: r = !1 } = e || {}, { jaql: i, chartRecommendations: a, queryTitle: s } = t, { metadata: n, datasource: l } = i, m = c(o({}, l), {
908
- type: l.type || "elasticube"
909
- }), y = St(m), d = n.map((x) => qt(x)).map((x) => c(o({}, x), {
910
- jaql: c(o({}, x.jaql), {
913
+ const { useCustomizedStyleOptions: r = !1 } = e || {}, { jaql: i, chartRecommendations: a, queryTitle: s } = t, { metadata: n, datasource: m } = i, l = u(o({}, m), {
914
+ type: m.type || "elasticube"
915
+ }), y = St(l), d = n.map((x) => qt(x)).map((x) => u(o({}, x), {
916
+ jaql: u(o({}, x.jaql), {
911
917
  datasource: y
912
918
  })
913
- })), g = Kt(a), f = g.chartType.toLowerCase(), T = {
919
+ })), g = Vt(a), f = g.chartType.toLowerCase(), T = {
914
920
  cornerRadius: "Small",
915
921
  header: {
916
922
  // remove info button and render empty toolbar instead
917
923
  renderToolbar: () => null
918
924
  }
919
- }, { metadataColumns: b, metadataFilters: v } = Ht(d), H = Vt(v), { dataOptions: G, chartStyleOptions: X } = Ut(b, g, r), Z = o(o({}, X), T);
925
+ }, { metadataColumns: b, metadataFilters: v } = Ht(d), G = Gt(v), { dataOptions: H, chartStyleOptions: X } = Kt(b, g, r), Z = o(o({}, X), T);
920
926
  return {
921
927
  widgetType: "chart",
922
928
  id: s,
923
929
  title: s,
924
930
  chartType: f,
925
- dataSource: m,
926
- dataOptions: G,
927
- filters: H,
931
+ dataSource: l,
932
+ dataOptions: H,
933
+ filters: G,
928
934
  styleOptions: Z
929
935
  };
930
936
  } catch (r) {
931
937
  console.error(r);
932
938
  return;
933
939
  }
934
- }, Xt = (t, e) => Gt(t, e), Zt = (t) => bt(t) ? Nt(t) : Rt(t), ue = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
940
+ }, Zt = (t, e) => Xt(t, e), te = (t) => bt(t) ? Ft(t) : _t(t), pe = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
935
941
  __proto__: null,
936
- toWidgetCode: Zt,
937
- toWidgetProps: Xt
942
+ toWidgetCode: te,
943
+ toWidgetProps: Zt
938
944
  }, Symbol.toStringTag, { value: "Module" }));
939
945
  export {
940
946
  w as C,
941
- ie as E,
947
+ ae as E,
942
948
  J,
943
949
  q as a,
944
950
  L as b,
945
- oe as c,
951
+ le as c,
946
952
  Q as d,
947
953
  B as e,
948
954
  A as f,
949
- _t as g,
955
+ Nt as g,
950
956
  p as h,
951
- ne as i,
952
- re as j,
953
- ae as k,
957
+ oe as i,
958
+ ie as j,
959
+ se as k,
954
960
  bt as l,
955
- se as m,
961
+ ne as m,
956
962
  qt as n,
963
+ ue as o,
957
964
  Ct as p,
958
- le as s,
959
- Xt as t,
960
- de as v,
961
- ue as w
965
+ Yt as q,
966
+ Ut as r,
967
+ de as s,
968
+ Zt as t,
969
+ Kt as u,
970
+ ce as v,
971
+ pe as w
962
972
  };
package/package.json CHANGED
@@ -11,7 +11,7 @@
11
11
  "Sisense",
12
12
  "Compose SDK"
13
13
  ],
14
- "version": "2.2.0",
14
+ "version": "2.3.1",
15
15
  "type": "module",
16
16
  "exports": {
17
17
  ".": {
@@ -52,17 +52,17 @@
52
52
  "@dnd-kit/core": "^6.3.1",
53
53
  "@dnd-kit/modifiers": "^9.0.0",
54
54
  "@dnd-kit/utilities": "^3.2.2",
55
- "@emotion/cache": "^11.10.5",
56
- "@emotion/react": "^11.10.5",
57
- "@emotion/styled": "^11.10.5",
58
- "@mui/material": "^5.16.7",
59
- "@mui/system": "^5.16.7",
60
- "@sisense/sdk-common": "2.2.0",
61
- "@sisense/sdk-data": "2.2.0",
62
- "@sisense/sdk-pivot-client": "2.2.0",
63
- "@sisense/sdk-query-client": "2.2.0",
64
- "@sisense/sdk-rest-client": "2.2.0",
65
- "@sisense/sdk-tracking": "2.2.0",
55
+ "@emotion/cache": "^11.14.0",
56
+ "@emotion/react": "^11.14.0",
57
+ "@emotion/styled": "^11.14.0",
58
+ "@mui/material": "^6.4.11",
59
+ "@mui/system": "^6.4.11",
60
+ "@sisense/sdk-common": "2.3.1",
61
+ "@sisense/sdk-data": "2.3.1",
62
+ "@sisense/sdk-pivot-client": "2.3.1",
63
+ "@sisense/sdk-query-client": "2.3.1",
64
+ "@sisense/sdk-rest-client": "2.3.1",
65
+ "@sisense/sdk-tracking": "2.3.1",
66
66
  "@sisense/sisense-charts": "5.1.1",
67
67
  "@tanstack/react-query": "4.36.1",
68
68
  "classnames": "^2.3.2",
@@ -71,7 +71,7 @@
71
71
  "date-fns-tz": "^2.0.0",
72
72
  "dayjs": "^1.11.7",
73
73
  "dompurify": "^3.1.6",
74
- "fixed-data-table-2": "^1.2.18",
74
+ "fixed-data-table-2": "^2.0.21",
75
75
  "geojson": "^0.5.0",
76
76
  "guid-typescript": "^1.0.9",
77
77
  "highcharts-react-official": "^3.2.1",
@@ -79,9 +79,10 @@
79
79
  "immer": "^10.0.2",
80
80
  "leaflet": "^1.9.4",
81
81
  "lodash-es": "^4.17.21",
82
+ "markdown-to-jsx": "^7.7.6",
82
83
  "merge-deep": "^3.0.3",
83
84
  "proj4leaflet": "^1.0.2",
84
- "react-datepicker": "^7.3.0",
85
+ "react-datepicker": "^8.4.0",
85
86
  "react-error-boundary": "^4.0.11",
86
87
  "react-i18next": "^13.2.2",
87
88
  "react-number-format": "^5.1.0",
@@ -94,8 +95,10 @@
94
95
  "scripts": {
95
96
  "dev": "vite",
96
97
  "type-check": "tsc --noEmit",
97
- "build": "run type-check && vite build --mode development",
98
- "build:prod": "run type-check && vite build",
98
+ "build": "run type-check && vite build --mode development && run build:umd",
99
+ "build:prod": "run type-check && vite build && run build:umd:prod",
100
+ "build:umd": "tsx ./scripts/vite/vite.umd.build.ts --mode development",
101
+ "build:umd:prod": "tsx ./scripts/vite/vite.umd.build.ts --mode production",
99
102
  "clean": "rm -rf ./dist && rm -rf ./coverage && rm -rf tsconfig.tsbuildinfo && rm -rf node_modules/.vite/deps",
100
103
  "lint": "eslint . --quiet",
101
104
  "lint:fix": "run lint --fix",
@@ -138,7 +141,7 @@
138
141
  "@types/prismjs": "^1.26.5",
139
142
  "@types/proj4leaflet": "^1.0.10",
140
143
  "@types/react": "18.3.1",
141
- "@types/react-dom": "18.3.0",
144
+ "@types/react-dom": "18.3.1",
142
145
  "@types/react-grid-layout": "^1.3.5",
143
146
  "@types/react-plotly.js": "^2.6.0",
144
147
  "@vitejs/plugin-react-swc": "^3.8.0",
@@ -163,6 +166,7 @@
163
166
  "sass": "1.58.3",
164
167
  "storybook": "7.0.24",
165
168
  "tailwindcss": "^3.3.1",
169
+ "tsx": "^4.19.4",
166
170
  "typescript": "4.8.4",
167
171
  "vite": "5.2.10",
168
172
  "vite-plugin-checker": "^0.6.1",
@@ -171,8 +175,8 @@
171
175
  "vitest-canvas-mock": "^0.3.2"
172
176
  },
173
177
  "peerDependencies": {
174
- "react": "^17.0.0 || ^18.0.0",
175
- "react-dom": "^17.0.0 || ^18.0.0"
178
+ "react": "^17.0.0 || ^18.0.0 || ^19.0.0",
179
+ "react-dom": "^17.0.0 || ^18.0.0 || ^19.0.0"
176
180
  },
177
181
  "volta": {
178
182
  "extends": "../../package.json"