@oliasoft-open-source/charts-library 3.5.2-beta-2 → 3.5.2-beta-4

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/dist/index.js CHANGED
@@ -13418,7 +13418,16 @@ const setDefaultTheme = () => {
13418
13418
  defaults$2.borderColor = BORDER_COLOR;
13419
13419
  };
13420
13420
  const isNilOrEmpty = (value) => {
13421
- return value === null || value === void 0 || value === "";
13421
+ if (value === null || value === void 0 || value === "") {
13422
+ return true;
13423
+ }
13424
+ if (Array.isArray(value) && value.length === 0) {
13425
+ return true;
13426
+ }
13427
+ if (typeof value === "object" && Object.keys(value).length === 0) {
13428
+ return true;
13429
+ }
13430
+ return false;
13422
13431
  };
13423
13432
  const chart$3 = "_chart_1v6ps_1";
13424
13433
  const styles$5 = {
@@ -23683,8 +23692,9 @@ const useChartFunctions = ({
23683
23692
  [axes]
23684
23693
  );
23685
23694
  const updateAxesRangesFromChart = useCallback(() => {
23695
+ var _a2;
23686
23696
  const { scales = {} } = (chartRef == null ? void 0 : chartRef.current) || {};
23687
- const axes2 = Object.entries(scales).map(
23697
+ const axes2 = (_a2 = Object.entries(scales)) == null ? void 0 : _a2.map(
23688
23698
  ([key, { min, max }]) => {
23689
23699
  return {
23690
23700
  id: key,
@@ -24540,7 +24550,7 @@ const defaultAdditionalAxesOptions$1 = (options) => ({
24540
24550
  stepSize: options == null ? void 0 : options.stepSize,
24541
24551
  suggestedMin: options == null ? void 0 : options.suggestedMin,
24542
24552
  suggestedMax: options == null ? void 0 : options.suggestedMax,
24543
- range: (options == null ? void 0 : options.range) || {},
24553
+ range: (options == null ? void 0 : options.range) || null,
24544
24554
  autoAxisPadding: (options == null ? void 0 : options.autoAxisPadding) ?? false
24545
24555
  });
24546
24556
  const defaultChartStyling$2 = (options) => ({
@@ -25427,23 +25437,27 @@ const useUpdateAxesRanges = (range, dispatch) => {
25427
25437
  prevAxes.current = axes;
25428
25438
  }
25429
25439
  };
25430
- const useSaveInitialAxesRanges = (chartRef, axes, dispatch) => {
25431
- const initialAxesRanges = chartRef ? getAxesRangesFromChart(chartRef, axes) : null;
25432
- const prevAxes = useRef(null);
25433
- useEffect(() => {
25434
- if (chartRef && !isEqual(initialAxesRanges, prevAxes.current)) {
25440
+ const useSaveInitialAxesRanges = (chartRef, axes, generatedDatasets, dispatch) => {
25441
+ const prevGeneratedDatasets = useRef();
25442
+ const saveInitialAxesRanges = useCallback(() => {
25443
+ if (chartRef && !isEqual(generatedDatasets, prevGeneratedDatasets.current)) {
25444
+ const initialAxesRanges = getAxesRangesFromChart(chartRef, axes);
25435
25445
  dispatch({
25436
25446
  type: SAVE_INITIAL_AXES_RANGES,
25437
25447
  payload: { initialAxesRanges }
25438
25448
  });
25439
- prevAxes.current = initialAxesRanges;
25449
+ prevGeneratedDatasets.current = generatedDatasets;
25440
25450
  }
25441
- }, [chartRef, initialAxesRanges, dispatch]);
25451
+ }, [chartRef, generatedDatasets]);
25452
+ useEffect(() => {
25453
+ saveInitialAxesRanges();
25454
+ }, [saveInitialAxesRanges, generatedDatasets]);
25442
25455
  };
25443
25456
  const useChartState = ({
25444
25457
  chartRef,
25445
25458
  options,
25446
25459
  state,
25460
+ generatedDatasets,
25447
25461
  dispatch,
25448
25462
  persistenceId
25449
25463
  }) => {
@@ -25456,7 +25470,7 @@ const useChartState = ({
25456
25470
  useStoreChartStateInStorage(memoState, persistenceId);
25457
25471
  useToggleCustomLegendVisibility(memoState, memoOptions);
25458
25472
  useUpdateAxesRanges(range, dispatch);
25459
- useSaveInitialAxesRanges(chartRef, axes, dispatch);
25473
+ useSaveInitialAxesRanges(chartRef, axes, generatedDatasets, dispatch);
25460
25474
  };
25461
25475
  const WORD_SEPARATOR = " ";
25462
25476
  const SEMI_TRANSPARENT = "rgba(0, 0, 0, 0.5)";
@@ -25684,6 +25698,7 @@ const LineChart = (props) => {
25684
25698
  },
25685
25699
  initialState
25686
25700
  );
25701
+ console.log(state);
25687
25702
  const generatedDatasets = useMemo(() => {
25688
25703
  return generateLineChartDatasets(datasets, state, options, translations);
25689
25704
  }, [state.lineEnabled, state.pointsEnabled, axes, annotations, graph]);
@@ -25691,6 +25706,7 @@ const LineChart = (props) => {
25691
25706
  chartRef,
25692
25707
  options,
25693
25708
  state,
25709
+ generatedDatasets,
25694
25710
  dispatch,
25695
25711
  persistenceId
25696
25712
  });
@@ -25709,7 +25725,6 @@ const LineChart = (props) => {
25709
25725
  generatedDatasets
25710
25726
  });
25711
25727
  const usePlugins = useChartPlugins({ options, resetZoom: resetZoom2 });
25712
- console.log(state);
25713
25728
  return /* @__PURE__ */ jsxs(
25714
25729
  "div",
25715
25730
  {
@@ -25766,8 +25781,7 @@ const LineChart = (props) => {
25766
25781
  state.enableDragPoints,
25767
25782
  state.zoomEnabled,
25768
25783
  state.panEnabled,
25769
- languageKey,
25770
- Math.random()
25784
+ languageKey
25771
25785
  ])
25772
25786
  );
25773
25787
  };