@almadar/ui 4.6.3 → 4.6.5

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.
@@ -19215,6 +19215,7 @@ var init_CardGrid = __esm({
19215
19215
  size: "sm",
19216
19216
  onClick: handleActionClick(action, itemData),
19217
19217
  "data-testid": action.event ? `action-${action.event}` : void 0,
19218
+ "data-row-id": String(itemData.id),
19218
19219
  className: "text-error hover:bg-error/10 px-2",
19219
19220
  children: action.label
19220
19221
  },
@@ -19245,6 +19246,7 @@ var init_CardGrid = __esm({
19245
19246
  size: "sm",
19246
19247
  onClick: handleActionClick(action, itemData),
19247
19248
  "data-testid": action.event ? `action-${action.event}` : void 0,
19249
+ "data-row-id": String(itemData.id),
19248
19250
  children: action.label
19249
19251
  },
19250
19252
  actionIdx
@@ -21989,6 +21991,7 @@ function DataGrid({
21989
21991
  size: "sm",
21990
21992
  onClick: handleActionClick(action, itemData),
21991
21993
  "data-testid": `action-${action.event}`,
21994
+ "data-row-id": String(itemData.id),
21992
21995
  className: "text-error hover:bg-error/10 px-2",
21993
21996
  children: [
21994
21997
  action.icon && /* @__PURE__ */ jsxRuntime.jsx(Icon, { name: action.icon, size: "xs" }),
@@ -22032,6 +22035,7 @@ function DataGrid({
22032
22035
  size: "sm",
22033
22036
  onClick: handleActionClick(action, itemData),
22034
22037
  "data-testid": `action-${action.event}`,
22038
+ "data-row-id": String(itemData.id),
22035
22039
  children: [
22036
22040
  action.icon && /* @__PURE__ */ jsxRuntime.jsx(Icon, { name: action.icon, size: "xs", className: "mr-1" }),
22037
22041
  action.label
@@ -22299,6 +22303,7 @@ function DataList({
22299
22303
  size: "sm",
22300
22304
  onClick: handleActionClick(action, itemData),
22301
22305
  "data-testid": `action-${action.event}`,
22306
+ "data-row-id": String(itemData.id),
22302
22307
  className: cn(
22303
22308
  action.variant === "danger" && "text-error hover:bg-error/10"
22304
22309
  ),
@@ -22388,6 +22393,7 @@ function DataList({
22388
22393
  size: "sm",
22389
22394
  onClick: handleActionClick(action, itemData),
22390
22395
  "data-testid": `action-${action.event}`,
22396
+ "data-row-id": String(itemData.id),
22391
22397
  className: cn(
22392
22398
  action.variant === "danger" && "text-error hover:bg-error/10"
22393
22399
  ),
@@ -30774,6 +30780,7 @@ var init_DetailPanel = __esm({
30774
30780
  actionPayload: { row: normalizedData },
30775
30781
  icon: action.icon,
30776
30782
  "data-testid": action.event ? `action-${action.event}` : void 0,
30783
+ "data-row-id": normalizedData?.id !== void 0 ? String(normalizedData.id) : void 0,
30777
30784
  children: action.label
30778
30785
  },
30779
30786
  idx
@@ -31753,6 +31760,16 @@ function evaluateFormExpression(expr, formCtx) {
31753
31760
  const ctx = toSharedContext2(formCtx);
31754
31761
  return evaluator.evaluate(expr, ctx);
31755
31762
  }
31763
+ function isOrbitalEntitySchema(value) {
31764
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
31765
+ const fields = value.fields;
31766
+ return Array.isArray(fields);
31767
+ }
31768
+ function isPlainEntityRow(value) {
31769
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
31770
+ const fields = value.fields;
31771
+ return !Array.isArray(fields);
31772
+ }
31756
31773
  function getEnumOptions(field) {
31757
31774
  if (field.options && field.options.length > 0) {
31758
31775
  return [...field.options];
@@ -31898,9 +31915,12 @@ var init_Form = __esm({
31898
31915
  const { t } = useTranslate();
31899
31916
  const resolvedSubmitLabel = submitLabel ?? t("common.save");
31900
31917
  const resolvedCancelLabel = cancelLabel ?? t("common.cancel");
31901
- const normalizedInitialData = initialData ?? {};
31902
- const resolvedEntity = entity && typeof entity === "object" && !Array.isArray(entity) ? entity : void 0;
31918
+ const isSchemaEntity = isOrbitalEntitySchema(entity);
31919
+ const resolvedEntity = isSchemaEntity ? entity : void 0;
31903
31920
  const entityName = typeof entity === "string" ? entity : resolvedEntity?.name;
31921
+ const entityRowAsInitial = isPlainEntityRow(entity) ? entity : void 0;
31922
+ const callerInitial = initialData !== null && typeof initialData === "object" && !Array.isArray(initialData) ? initialData : {};
31923
+ const normalizedInitialData = entityRowAsInitial !== void 0 ? { ...entityRowAsInitial, ...callerInitial } : callerInitial;
31904
31924
  const entityDerivedFields = React126__namespace.default.useMemo(() => {
31905
31925
  if (fields && fields.length > 0) return void 0;
31906
31926
  if (!resolvedEntity) return void 0;
@@ -31937,11 +31957,10 @@ var init_Form = __esm({
31937
31957
  [formData, externalContext]
31938
31958
  );
31939
31959
  React126__namespace.default.useEffect(() => {
31940
- const data = initialData;
31941
- if (data && Object.keys(data).length > 0) {
31942
- setFormData(data);
31960
+ if (Object.keys(normalizedInitialData).length > 0) {
31961
+ setFormData(normalizedInitialData);
31943
31962
  }
31944
- }, [initialData]);
31963
+ }, [normalizedInitialData]);
31945
31964
  const processCalculations = React126__namespace.default.useCallback(
31946
31965
  (changedFieldId, newFormData) => {
31947
31966
  if (!hiddenCalculations.length) return;
package/dist/avl/index.js CHANGED
@@ -19169,6 +19169,7 @@ var init_CardGrid = __esm({
19169
19169
  size: "sm",
19170
19170
  onClick: handleActionClick(action, itemData),
19171
19171
  "data-testid": action.event ? `action-${action.event}` : void 0,
19172
+ "data-row-id": String(itemData.id),
19172
19173
  className: "text-error hover:bg-error/10 px-2",
19173
19174
  children: action.label
19174
19175
  },
@@ -19199,6 +19200,7 @@ var init_CardGrid = __esm({
19199
19200
  size: "sm",
19200
19201
  onClick: handleActionClick(action, itemData),
19201
19202
  "data-testid": action.event ? `action-${action.event}` : void 0,
19203
+ "data-row-id": String(itemData.id),
19202
19204
  children: action.label
19203
19205
  },
19204
19206
  actionIdx
@@ -21943,6 +21945,7 @@ function DataGrid({
21943
21945
  size: "sm",
21944
21946
  onClick: handleActionClick(action, itemData),
21945
21947
  "data-testid": `action-${action.event}`,
21948
+ "data-row-id": String(itemData.id),
21946
21949
  className: "text-error hover:bg-error/10 px-2",
21947
21950
  children: [
21948
21951
  action.icon && /* @__PURE__ */ jsx(Icon, { name: action.icon, size: "xs" }),
@@ -21986,6 +21989,7 @@ function DataGrid({
21986
21989
  size: "sm",
21987
21990
  onClick: handleActionClick(action, itemData),
21988
21991
  "data-testid": `action-${action.event}`,
21992
+ "data-row-id": String(itemData.id),
21989
21993
  children: [
21990
21994
  action.icon && /* @__PURE__ */ jsx(Icon, { name: action.icon, size: "xs", className: "mr-1" }),
21991
21995
  action.label
@@ -22253,6 +22257,7 @@ function DataList({
22253
22257
  size: "sm",
22254
22258
  onClick: handleActionClick(action, itemData),
22255
22259
  "data-testid": `action-${action.event}`,
22260
+ "data-row-id": String(itemData.id),
22256
22261
  className: cn(
22257
22262
  action.variant === "danger" && "text-error hover:bg-error/10"
22258
22263
  ),
@@ -22342,6 +22347,7 @@ function DataList({
22342
22347
  size: "sm",
22343
22348
  onClick: handleActionClick(action, itemData),
22344
22349
  "data-testid": `action-${action.event}`,
22350
+ "data-row-id": String(itemData.id),
22345
22351
  className: cn(
22346
22352
  action.variant === "danger" && "text-error hover:bg-error/10"
22347
22353
  ),
@@ -30728,6 +30734,7 @@ var init_DetailPanel = __esm({
30728
30734
  actionPayload: { row: normalizedData },
30729
30735
  icon: action.icon,
30730
30736
  "data-testid": action.event ? `action-${action.event}` : void 0,
30737
+ "data-row-id": normalizedData?.id !== void 0 ? String(normalizedData.id) : void 0,
30731
30738
  children: action.label
30732
30739
  },
30733
30740
  idx
@@ -31707,6 +31714,16 @@ function evaluateFormExpression(expr, formCtx) {
31707
31714
  const ctx = toSharedContext2(formCtx);
31708
31715
  return evaluate(expr, ctx);
31709
31716
  }
31717
+ function isOrbitalEntitySchema(value) {
31718
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
31719
+ const fields = value.fields;
31720
+ return Array.isArray(fields);
31721
+ }
31722
+ function isPlainEntityRow(value) {
31723
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
31724
+ const fields = value.fields;
31725
+ return !Array.isArray(fields);
31726
+ }
31710
31727
  function getEnumOptions(field) {
31711
31728
  if (field.options && field.options.length > 0) {
31712
31729
  return [...field.options];
@@ -31852,9 +31869,12 @@ var init_Form = __esm({
31852
31869
  const { t } = useTranslate();
31853
31870
  const resolvedSubmitLabel = submitLabel ?? t("common.save");
31854
31871
  const resolvedCancelLabel = cancelLabel ?? t("common.cancel");
31855
- const normalizedInitialData = initialData ?? {};
31856
- const resolvedEntity = entity && typeof entity === "object" && !Array.isArray(entity) ? entity : void 0;
31872
+ const isSchemaEntity = isOrbitalEntitySchema(entity);
31873
+ const resolvedEntity = isSchemaEntity ? entity : void 0;
31857
31874
  const entityName = typeof entity === "string" ? entity : resolvedEntity?.name;
31875
+ const entityRowAsInitial = isPlainEntityRow(entity) ? entity : void 0;
31876
+ const callerInitial = initialData !== null && typeof initialData === "object" && !Array.isArray(initialData) ? initialData : {};
31877
+ const normalizedInitialData = entityRowAsInitial !== void 0 ? { ...entityRowAsInitial, ...callerInitial } : callerInitial;
31858
31878
  const entityDerivedFields = React126__default.useMemo(() => {
31859
31879
  if (fields && fields.length > 0) return void 0;
31860
31880
  if (!resolvedEntity) return void 0;
@@ -31891,11 +31911,10 @@ var init_Form = __esm({
31891
31911
  [formData, externalContext]
31892
31912
  );
31893
31913
  React126__default.useEffect(() => {
31894
- const data = initialData;
31895
- if (data && Object.keys(data).length > 0) {
31896
- setFormData(data);
31914
+ if (Object.keys(normalizedInitialData).length > 0) {
31915
+ setFormData(normalizedInitialData);
31897
31916
  }
31898
- }, [initialData]);
31917
+ }, [normalizedInitialData]);
31899
31918
  const processCalculations = React126__default.useCallback(
31900
31919
  (changedFieldId, newFormData) => {
31901
31920
  if (!hiddenCalculations.length) return;
@@ -14507,6 +14507,7 @@ var init_CardGrid = __esm({
14507
14507
  size: "sm",
14508
14508
  onClick: handleActionClick(action, itemData),
14509
14509
  "data-testid": action.event ? `action-${action.event}` : void 0,
14510
+ "data-row-id": String(itemData.id),
14510
14511
  className: "text-error hover:bg-error/10 px-2",
14511
14512
  children: action.label
14512
14513
  },
@@ -14537,6 +14538,7 @@ var init_CardGrid = __esm({
14537
14538
  size: "sm",
14538
14539
  onClick: handleActionClick(action, itemData),
14539
14540
  "data-testid": action.event ? `action-${action.event}` : void 0,
14541
+ "data-row-id": String(itemData.id),
14540
14542
  children: action.label
14541
14543
  },
14542
14544
  actionIdx
@@ -17512,6 +17514,7 @@ function DataGrid({
17512
17514
  size: "sm",
17513
17515
  onClick: handleActionClick(action, itemData),
17514
17516
  "data-testid": `action-${action.event}`,
17517
+ "data-row-id": String(itemData.id),
17515
17518
  className: "text-error hover:bg-error/10 px-2",
17516
17519
  children: [
17517
17520
  action.icon && /* @__PURE__ */ jsxRuntime.jsx(exports.Icon, { name: action.icon, size: "xs" }),
@@ -17555,6 +17558,7 @@ function DataGrid({
17555
17558
  size: "sm",
17556
17559
  onClick: handleActionClick(action, itemData),
17557
17560
  "data-testid": `action-${action.event}`,
17561
+ "data-row-id": String(itemData.id),
17558
17562
  children: [
17559
17563
  action.icon && /* @__PURE__ */ jsxRuntime.jsx(exports.Icon, { name: action.icon, size: "xs", className: "mr-1" }),
17560
17564
  action.label
@@ -17822,6 +17826,7 @@ function DataList({
17822
17826
  size: "sm",
17823
17827
  onClick: handleActionClick(action, itemData),
17824
17828
  "data-testid": `action-${action.event}`,
17829
+ "data-row-id": String(itemData.id),
17825
17830
  className: cn(
17826
17831
  action.variant === "danger" && "text-error hover:bg-error/10"
17827
17832
  ),
@@ -17911,6 +17916,7 @@ function DataList({
17911
17916
  size: "sm",
17912
17917
  onClick: handleActionClick(action, itemData),
17913
17918
  "data-testid": `action-${action.event}`,
17919
+ "data-row-id": String(itemData.id),
17914
17920
  className: cn(
17915
17921
  action.variant === "danger" && "text-error hover:bg-error/10"
17916
17922
  ),
@@ -26567,6 +26573,7 @@ var init_DetailPanel = __esm({
26567
26573
  actionPayload: { row: normalizedData },
26568
26574
  icon: action.icon,
26569
26575
  "data-testid": action.event ? `action-${action.event}` : void 0,
26576
+ "data-row-id": normalizedData?.id !== void 0 ? String(normalizedData.id) : void 0,
26570
26577
  children: action.label
26571
26578
  },
26572
26579
  idx
@@ -27641,6 +27648,16 @@ function evaluateFormExpression(expr, formCtx) {
27641
27648
  const ctx = toSharedContext2(formCtx);
27642
27649
  return evaluator.evaluate(expr, ctx);
27643
27650
  }
27651
+ function isOrbitalEntitySchema(value) {
27652
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
27653
+ const fields = value.fields;
27654
+ return Array.isArray(fields);
27655
+ }
27656
+ function isPlainEntityRow(value) {
27657
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
27658
+ const fields = value.fields;
27659
+ return !Array.isArray(fields);
27660
+ }
27644
27661
  function getEnumOptions(field) {
27645
27662
  if (field.options && field.options.length > 0) {
27646
27663
  return [...field.options];
@@ -27786,9 +27803,12 @@ var init_Form = __esm({
27786
27803
  const { t } = useTranslate();
27787
27804
  const resolvedSubmitLabel = submitLabel ?? t("common.save");
27788
27805
  const resolvedCancelLabel = cancelLabel ?? t("common.cancel");
27789
- const normalizedInitialData = initialData ?? {};
27790
- const resolvedEntity = entity && typeof entity === "object" && !Array.isArray(entity) ? entity : void 0;
27806
+ const isSchemaEntity = isOrbitalEntitySchema(entity);
27807
+ const resolvedEntity = isSchemaEntity ? entity : void 0;
27791
27808
  const entityName = typeof entity === "string" ? entity : resolvedEntity?.name;
27809
+ const entityRowAsInitial = isPlainEntityRow(entity) ? entity : void 0;
27810
+ const callerInitial = initialData !== null && typeof initialData === "object" && !Array.isArray(initialData) ? initialData : {};
27811
+ const normalizedInitialData = entityRowAsInitial !== void 0 ? { ...entityRowAsInitial, ...callerInitial } : callerInitial;
27792
27812
  const entityDerivedFields = React110__namespace.default.useMemo(() => {
27793
27813
  if (fields && fields.length > 0) return void 0;
27794
27814
  if (!resolvedEntity) return void 0;
@@ -27825,11 +27845,10 @@ var init_Form = __esm({
27825
27845
  [formData, externalContext]
27826
27846
  );
27827
27847
  React110__namespace.default.useEffect(() => {
27828
- const data = initialData;
27829
- if (data && Object.keys(data).length > 0) {
27830
- setFormData(data);
27848
+ if (Object.keys(normalizedInitialData).length > 0) {
27849
+ setFormData(normalizedInitialData);
27831
27850
  }
27832
- }, [initialData]);
27851
+ }, [normalizedInitialData]);
27833
27852
  const processCalculations = React110__namespace.default.useCallback(
27834
27853
  (changedFieldId, newFormData) => {
27835
27854
  if (!hiddenCalculations.length) return;
@@ -14462,6 +14462,7 @@ var init_CardGrid = __esm({
14462
14462
  size: "sm",
14463
14463
  onClick: handleActionClick(action, itemData),
14464
14464
  "data-testid": action.event ? `action-${action.event}` : void 0,
14465
+ "data-row-id": String(itemData.id),
14465
14466
  className: "text-error hover:bg-error/10 px-2",
14466
14467
  children: action.label
14467
14468
  },
@@ -14492,6 +14493,7 @@ var init_CardGrid = __esm({
14492
14493
  size: "sm",
14493
14494
  onClick: handleActionClick(action, itemData),
14494
14495
  "data-testid": action.event ? `action-${action.event}` : void 0,
14496
+ "data-row-id": String(itemData.id),
14495
14497
  children: action.label
14496
14498
  },
14497
14499
  actionIdx
@@ -17467,6 +17469,7 @@ function DataGrid({
17467
17469
  size: "sm",
17468
17470
  onClick: handleActionClick(action, itemData),
17469
17471
  "data-testid": `action-${action.event}`,
17472
+ "data-row-id": String(itemData.id),
17470
17473
  className: "text-error hover:bg-error/10 px-2",
17471
17474
  children: [
17472
17475
  action.icon && /* @__PURE__ */ jsx(Icon, { name: action.icon, size: "xs" }),
@@ -17510,6 +17513,7 @@ function DataGrid({
17510
17513
  size: "sm",
17511
17514
  onClick: handleActionClick(action, itemData),
17512
17515
  "data-testid": `action-${action.event}`,
17516
+ "data-row-id": String(itemData.id),
17513
17517
  children: [
17514
17518
  action.icon && /* @__PURE__ */ jsx(Icon, { name: action.icon, size: "xs", className: "mr-1" }),
17515
17519
  action.label
@@ -17777,6 +17781,7 @@ function DataList({
17777
17781
  size: "sm",
17778
17782
  onClick: handleActionClick(action, itemData),
17779
17783
  "data-testid": `action-${action.event}`,
17784
+ "data-row-id": String(itemData.id),
17780
17785
  className: cn(
17781
17786
  action.variant === "danger" && "text-error hover:bg-error/10"
17782
17787
  ),
@@ -17866,6 +17871,7 @@ function DataList({
17866
17871
  size: "sm",
17867
17872
  onClick: handleActionClick(action, itemData),
17868
17873
  "data-testid": `action-${action.event}`,
17874
+ "data-row-id": String(itemData.id),
17869
17875
  className: cn(
17870
17876
  action.variant === "danger" && "text-error hover:bg-error/10"
17871
17877
  ),
@@ -26522,6 +26528,7 @@ var init_DetailPanel = __esm({
26522
26528
  actionPayload: { row: normalizedData },
26523
26529
  icon: action.icon,
26524
26530
  "data-testid": action.event ? `action-${action.event}` : void 0,
26531
+ "data-row-id": normalizedData?.id !== void 0 ? String(normalizedData.id) : void 0,
26525
26532
  children: action.label
26526
26533
  },
26527
26534
  idx
@@ -27596,6 +27603,16 @@ function evaluateFormExpression(expr, formCtx) {
27596
27603
  const ctx = toSharedContext2(formCtx);
27597
27604
  return evaluate(expr, ctx);
27598
27605
  }
27606
+ function isOrbitalEntitySchema(value) {
27607
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
27608
+ const fields = value.fields;
27609
+ return Array.isArray(fields);
27610
+ }
27611
+ function isPlainEntityRow(value) {
27612
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
27613
+ const fields = value.fields;
27614
+ return !Array.isArray(fields);
27615
+ }
27599
27616
  function getEnumOptions(field) {
27600
27617
  if (field.options && field.options.length > 0) {
27601
27618
  return [...field.options];
@@ -27741,9 +27758,12 @@ var init_Form = __esm({
27741
27758
  const { t } = useTranslate();
27742
27759
  const resolvedSubmitLabel = submitLabel ?? t("common.save");
27743
27760
  const resolvedCancelLabel = cancelLabel ?? t("common.cancel");
27744
- const normalizedInitialData = initialData ?? {};
27745
- const resolvedEntity = entity && typeof entity === "object" && !Array.isArray(entity) ? entity : void 0;
27761
+ const isSchemaEntity = isOrbitalEntitySchema(entity);
27762
+ const resolvedEntity = isSchemaEntity ? entity : void 0;
27746
27763
  const entityName = typeof entity === "string" ? entity : resolvedEntity?.name;
27764
+ const entityRowAsInitial = isPlainEntityRow(entity) ? entity : void 0;
27765
+ const callerInitial = initialData !== null && typeof initialData === "object" && !Array.isArray(initialData) ? initialData : {};
27766
+ const normalizedInitialData = entityRowAsInitial !== void 0 ? { ...entityRowAsInitial, ...callerInitial } : callerInitial;
27747
27767
  const entityDerivedFields = React110__default.useMemo(() => {
27748
27768
  if (fields && fields.length > 0) return void 0;
27749
27769
  if (!resolvedEntity) return void 0;
@@ -27780,11 +27800,10 @@ var init_Form = __esm({
27780
27800
  [formData, externalContext]
27781
27801
  );
27782
27802
  React110__default.useEffect(() => {
27783
- const data = initialData;
27784
- if (data && Object.keys(data).length > 0) {
27785
- setFormData(data);
27803
+ if (Object.keys(normalizedInitialData).length > 0) {
27804
+ setFormData(normalizedInitialData);
27786
27805
  }
27787
- }, [initialData]);
27806
+ }, [normalizedInitialData]);
27788
27807
  const processCalculations = React110__default.useCallback(
27789
27808
  (changedFieldId, newFormData) => {
27790
27809
  if (!hiddenCalculations.length) return;
@@ -16050,6 +16050,7 @@ var init_CardGrid = __esm({
16050
16050
  size: "sm",
16051
16051
  onClick: handleActionClick(action, itemData),
16052
16052
  "data-testid": action.event ? `action-${action.event}` : void 0,
16053
+ "data-row-id": String(itemData.id),
16053
16054
  className: "text-error hover:bg-error/10 px-2",
16054
16055
  children: action.label
16055
16056
  },
@@ -16080,6 +16081,7 @@ var init_CardGrid = __esm({
16080
16081
  size: "sm",
16081
16082
  onClick: handleActionClick(action, itemData),
16082
16083
  "data-testid": action.event ? `action-${action.event}` : void 0,
16084
+ "data-row-id": String(itemData.id),
16083
16085
  children: action.label
16084
16086
  },
16085
16087
  actionIdx
@@ -18824,6 +18826,7 @@ function DataGrid({
18824
18826
  size: "sm",
18825
18827
  onClick: handleActionClick(action, itemData),
18826
18828
  "data-testid": `action-${action.event}`,
18829
+ "data-row-id": String(itemData.id),
18827
18830
  className: "text-error hover:bg-error/10 px-2",
18828
18831
  children: [
18829
18832
  action.icon && /* @__PURE__ */ jsxRuntime.jsx(Icon, { name: action.icon, size: "xs" }),
@@ -18867,6 +18870,7 @@ function DataGrid({
18867
18870
  size: "sm",
18868
18871
  onClick: handleActionClick(action, itemData),
18869
18872
  "data-testid": `action-${action.event}`,
18873
+ "data-row-id": String(itemData.id),
18870
18874
  children: [
18871
18875
  action.icon && /* @__PURE__ */ jsxRuntime.jsx(Icon, { name: action.icon, size: "xs", className: "mr-1" }),
18872
18876
  action.label
@@ -19134,6 +19138,7 @@ function DataList({
19134
19138
  size: "sm",
19135
19139
  onClick: handleActionClick(action, itemData),
19136
19140
  "data-testid": `action-${action.event}`,
19141
+ "data-row-id": String(itemData.id),
19137
19142
  className: cn(
19138
19143
  action.variant === "danger" && "text-error hover:bg-error/10"
19139
19144
  ),
@@ -19223,6 +19228,7 @@ function DataList({
19223
19228
  size: "sm",
19224
19229
  onClick: handleActionClick(action, itemData),
19225
19230
  "data-testid": `action-${action.event}`,
19231
+ "data-row-id": String(itemData.id),
19226
19232
  className: cn(
19227
19233
  action.variant === "danger" && "text-error hover:bg-error/10"
19228
19234
  ),
@@ -27609,6 +27615,7 @@ var init_DetailPanel = __esm({
27609
27615
  actionPayload: { row: normalizedData },
27610
27616
  icon: action.icon,
27611
27617
  "data-testid": action.event ? `action-${action.event}` : void 0,
27618
+ "data-row-id": normalizedData?.id !== void 0 ? String(normalizedData.id) : void 0,
27612
27619
  children: action.label
27613
27620
  },
27614
27621
  idx
@@ -28588,6 +28595,16 @@ function evaluateFormExpression(expr, formCtx) {
28588
28595
  const ctx = toSharedContext2(formCtx);
28589
28596
  return evaluator.evaluate(expr, ctx);
28590
28597
  }
28598
+ function isOrbitalEntitySchema(value) {
28599
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
28600
+ const fields = value.fields;
28601
+ return Array.isArray(fields);
28602
+ }
28603
+ function isPlainEntityRow(value) {
28604
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
28605
+ const fields = value.fields;
28606
+ return !Array.isArray(fields);
28607
+ }
28591
28608
  function getEnumOptions(field) {
28592
28609
  if (field.options && field.options.length > 0) {
28593
28610
  return [...field.options];
@@ -28733,9 +28750,12 @@ var init_Form = __esm({
28733
28750
  const { t } = useTranslate();
28734
28751
  const resolvedSubmitLabel = submitLabel ?? t("common.save");
28735
28752
  const resolvedCancelLabel = cancelLabel ?? t("common.cancel");
28736
- const normalizedInitialData = initialData ?? {};
28737
- const resolvedEntity = entity && typeof entity === "object" && !Array.isArray(entity) ? entity : void 0;
28753
+ const isSchemaEntity = isOrbitalEntitySchema(entity);
28754
+ const resolvedEntity = isSchemaEntity ? entity : void 0;
28738
28755
  const entityName = typeof entity === "string" ? entity : resolvedEntity?.name;
28756
+ const entityRowAsInitial = isPlainEntityRow(entity) ? entity : void 0;
28757
+ const callerInitial = initialData !== null && typeof initialData === "object" && !Array.isArray(initialData) ? initialData : {};
28758
+ const normalizedInitialData = entityRowAsInitial !== void 0 ? { ...entityRowAsInitial, ...callerInitial } : callerInitial;
28739
28759
  const entityDerivedFields = React115__namespace.default.useMemo(() => {
28740
28760
  if (fields && fields.length > 0) return void 0;
28741
28761
  if (!resolvedEntity) return void 0;
@@ -28772,11 +28792,10 @@ var init_Form = __esm({
28772
28792
  [formData, externalContext]
28773
28793
  );
28774
28794
  React115__namespace.default.useEffect(() => {
28775
- const data = initialData;
28776
- if (data && Object.keys(data).length > 0) {
28777
- setFormData(data);
28795
+ if (Object.keys(normalizedInitialData).length > 0) {
28796
+ setFormData(normalizedInitialData);
28778
28797
  }
28779
- }, [initialData]);
28798
+ }, [normalizedInitialData]);
28780
28799
  const processCalculations = React115__namespace.default.useCallback(
28781
28800
  (changedFieldId, newFormData) => {
28782
28801
  if (!hiddenCalculations.length) return;
@@ -16005,6 +16005,7 @@ var init_CardGrid = __esm({
16005
16005
  size: "sm",
16006
16006
  onClick: handleActionClick(action, itemData),
16007
16007
  "data-testid": action.event ? `action-${action.event}` : void 0,
16008
+ "data-row-id": String(itemData.id),
16008
16009
  className: "text-error hover:bg-error/10 px-2",
16009
16010
  children: action.label
16010
16011
  },
@@ -16035,6 +16036,7 @@ var init_CardGrid = __esm({
16035
16036
  size: "sm",
16036
16037
  onClick: handleActionClick(action, itemData),
16037
16038
  "data-testid": action.event ? `action-${action.event}` : void 0,
16039
+ "data-row-id": String(itemData.id),
16038
16040
  children: action.label
16039
16041
  },
16040
16042
  actionIdx
@@ -18779,6 +18781,7 @@ function DataGrid({
18779
18781
  size: "sm",
18780
18782
  onClick: handleActionClick(action, itemData),
18781
18783
  "data-testid": `action-${action.event}`,
18784
+ "data-row-id": String(itemData.id),
18782
18785
  className: "text-error hover:bg-error/10 px-2",
18783
18786
  children: [
18784
18787
  action.icon && /* @__PURE__ */ jsx(Icon, { name: action.icon, size: "xs" }),
@@ -18822,6 +18825,7 @@ function DataGrid({
18822
18825
  size: "sm",
18823
18826
  onClick: handleActionClick(action, itemData),
18824
18827
  "data-testid": `action-${action.event}`,
18828
+ "data-row-id": String(itemData.id),
18825
18829
  children: [
18826
18830
  action.icon && /* @__PURE__ */ jsx(Icon, { name: action.icon, size: "xs", className: "mr-1" }),
18827
18831
  action.label
@@ -19089,6 +19093,7 @@ function DataList({
19089
19093
  size: "sm",
19090
19094
  onClick: handleActionClick(action, itemData),
19091
19095
  "data-testid": `action-${action.event}`,
19096
+ "data-row-id": String(itemData.id),
19092
19097
  className: cn(
19093
19098
  action.variant === "danger" && "text-error hover:bg-error/10"
19094
19099
  ),
@@ -19178,6 +19183,7 @@ function DataList({
19178
19183
  size: "sm",
19179
19184
  onClick: handleActionClick(action, itemData),
19180
19185
  "data-testid": `action-${action.event}`,
19186
+ "data-row-id": String(itemData.id),
19181
19187
  className: cn(
19182
19188
  action.variant === "danger" && "text-error hover:bg-error/10"
19183
19189
  ),
@@ -27564,6 +27570,7 @@ var init_DetailPanel = __esm({
27564
27570
  actionPayload: { row: normalizedData },
27565
27571
  icon: action.icon,
27566
27572
  "data-testid": action.event ? `action-${action.event}` : void 0,
27573
+ "data-row-id": normalizedData?.id !== void 0 ? String(normalizedData.id) : void 0,
27567
27574
  children: action.label
27568
27575
  },
27569
27576
  idx
@@ -28543,6 +28550,16 @@ function evaluateFormExpression(expr, formCtx) {
28543
28550
  const ctx = toSharedContext2(formCtx);
28544
28551
  return evaluate(expr, ctx);
28545
28552
  }
28553
+ function isOrbitalEntitySchema(value) {
28554
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
28555
+ const fields = value.fields;
28556
+ return Array.isArray(fields);
28557
+ }
28558
+ function isPlainEntityRow(value) {
28559
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
28560
+ const fields = value.fields;
28561
+ return !Array.isArray(fields);
28562
+ }
28546
28563
  function getEnumOptions(field) {
28547
28564
  if (field.options && field.options.length > 0) {
28548
28565
  return [...field.options];
@@ -28688,9 +28705,12 @@ var init_Form = __esm({
28688
28705
  const { t } = useTranslate();
28689
28706
  const resolvedSubmitLabel = submitLabel ?? t("common.save");
28690
28707
  const resolvedCancelLabel = cancelLabel ?? t("common.cancel");
28691
- const normalizedInitialData = initialData ?? {};
28692
- const resolvedEntity = entity && typeof entity === "object" && !Array.isArray(entity) ? entity : void 0;
28708
+ const isSchemaEntity = isOrbitalEntitySchema(entity);
28709
+ const resolvedEntity = isSchemaEntity ? entity : void 0;
28693
28710
  const entityName = typeof entity === "string" ? entity : resolvedEntity?.name;
28711
+ const entityRowAsInitial = isPlainEntityRow(entity) ? entity : void 0;
28712
+ const callerInitial = initialData !== null && typeof initialData === "object" && !Array.isArray(initialData) ? initialData : {};
28713
+ const normalizedInitialData = entityRowAsInitial !== void 0 ? { ...entityRowAsInitial, ...callerInitial } : callerInitial;
28694
28714
  const entityDerivedFields = React115__default.useMemo(() => {
28695
28715
  if (fields && fields.length > 0) return void 0;
28696
28716
  if (!resolvedEntity) return void 0;
@@ -28727,11 +28747,10 @@ var init_Form = __esm({
28727
28747
  [formData, externalContext]
28728
28748
  );
28729
28749
  React115__default.useEffect(() => {
28730
- const data = initialData;
28731
- if (data && Object.keys(data).length > 0) {
28732
- setFormData(data);
28750
+ if (Object.keys(normalizedInitialData).length > 0) {
28751
+ setFormData(normalizedInitialData);
28733
28752
  }
28734
- }, [initialData]);
28753
+ }, [normalizedInitialData]);
28735
28754
  const processCalculations = React115__default.useCallback(
28736
28755
  (changedFieldId, newFormData) => {
28737
28756
  if (!hiddenCalculations.length) return;
@@ -15873,6 +15873,7 @@ var init_CardGrid = __esm({
15873
15873
  size: "sm",
15874
15874
  onClick: handleActionClick(action, itemData),
15875
15875
  "data-testid": action.event ? `action-${action.event}` : void 0,
15876
+ "data-row-id": String(itemData.id),
15876
15877
  className: "text-error hover:bg-error/10 px-2",
15877
15878
  children: action.label
15878
15879
  },
@@ -15903,6 +15904,7 @@ var init_CardGrid = __esm({
15903
15904
  size: "sm",
15904
15905
  onClick: handleActionClick(action, itemData),
15905
15906
  "data-testid": action.event ? `action-${action.event}` : void 0,
15907
+ "data-row-id": String(itemData.id),
15906
15908
  children: action.label
15907
15909
  },
15908
15910
  actionIdx
@@ -18633,6 +18635,7 @@ function DataGrid({
18633
18635
  size: "sm",
18634
18636
  onClick: handleActionClick(action, itemData),
18635
18637
  "data-testid": `action-${action.event}`,
18638
+ "data-row-id": String(itemData.id),
18636
18639
  className: "text-error hover:bg-error/10 px-2",
18637
18640
  children: [
18638
18641
  action.icon && /* @__PURE__ */ jsxRuntime.jsx(Icon, { name: action.icon, size: "xs" }),
@@ -18676,6 +18679,7 @@ function DataGrid({
18676
18679
  size: "sm",
18677
18680
  onClick: handleActionClick(action, itemData),
18678
18681
  "data-testid": `action-${action.event}`,
18682
+ "data-row-id": String(itemData.id),
18679
18683
  children: [
18680
18684
  action.icon && /* @__PURE__ */ jsxRuntime.jsx(Icon, { name: action.icon, size: "xs", className: "mr-1" }),
18681
18685
  action.label
@@ -18943,6 +18947,7 @@ function DataList({
18943
18947
  size: "sm",
18944
18948
  onClick: handleActionClick(action, itemData),
18945
18949
  "data-testid": `action-${action.event}`,
18950
+ "data-row-id": String(itemData.id),
18946
18951
  className: cn(
18947
18952
  action.variant === "danger" && "text-error hover:bg-error/10"
18948
18953
  ),
@@ -19032,6 +19037,7 @@ function DataList({
19032
19037
  size: "sm",
19033
19038
  onClick: handleActionClick(action, itemData),
19034
19039
  "data-testid": `action-${action.event}`,
19040
+ "data-row-id": String(itemData.id),
19035
19041
  className: cn(
19036
19042
  action.variant === "danger" && "text-error hover:bg-error/10"
19037
19043
  ),
@@ -27216,6 +27222,7 @@ var init_DetailPanel = __esm({
27216
27222
  actionPayload: { row: normalizedData },
27217
27223
  icon: action.icon,
27218
27224
  "data-testid": action.event ? `action-${action.event}` : void 0,
27225
+ "data-row-id": normalizedData?.id !== void 0 ? String(normalizedData.id) : void 0,
27219
27226
  children: action.label
27220
27227
  },
27221
27228
  idx
@@ -28195,6 +28202,16 @@ function evaluateFormExpression(expr, formCtx) {
28195
28202
  const ctx = toSharedContext2(formCtx);
28196
28203
  return evaluator.evaluate(expr, ctx);
28197
28204
  }
28205
+ function isOrbitalEntitySchema(value) {
28206
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
28207
+ const fields = value.fields;
28208
+ return Array.isArray(fields);
28209
+ }
28210
+ function isPlainEntityRow(value) {
28211
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
28212
+ const fields = value.fields;
28213
+ return !Array.isArray(fields);
28214
+ }
28198
28215
  function getEnumOptions(field) {
28199
28216
  if (field.options && field.options.length > 0) {
28200
28217
  return [...field.options];
@@ -28340,9 +28357,12 @@ var init_Form = __esm({
28340
28357
  const { t } = useTranslate();
28341
28358
  const resolvedSubmitLabel = submitLabel ?? t("common.save");
28342
28359
  const resolvedCancelLabel = cancelLabel ?? t("common.cancel");
28343
- const normalizedInitialData = initialData ?? {};
28344
- const resolvedEntity = entity && typeof entity === "object" && !Array.isArray(entity) ? entity : void 0;
28360
+ const isSchemaEntity = isOrbitalEntitySchema(entity);
28361
+ const resolvedEntity = isSchemaEntity ? entity : void 0;
28345
28362
  const entityName = typeof entity === "string" ? entity : resolvedEntity?.name;
28363
+ const entityRowAsInitial = isPlainEntityRow(entity) ? entity : void 0;
28364
+ const callerInitial = initialData !== null && typeof initialData === "object" && !Array.isArray(initialData) ? initialData : {};
28365
+ const normalizedInitialData = entityRowAsInitial !== void 0 ? { ...entityRowAsInitial, ...callerInitial } : callerInitial;
28346
28366
  const entityDerivedFields = React115__namespace.default.useMemo(() => {
28347
28367
  if (fields && fields.length > 0) return void 0;
28348
28368
  if (!resolvedEntity) return void 0;
@@ -28379,11 +28399,10 @@ var init_Form = __esm({
28379
28399
  [formData, externalContext]
28380
28400
  );
28381
28401
  React115__namespace.default.useEffect(() => {
28382
- const data = initialData;
28383
- if (data && Object.keys(data).length > 0) {
28384
- setFormData(data);
28402
+ if (Object.keys(normalizedInitialData).length > 0) {
28403
+ setFormData(normalizedInitialData);
28385
28404
  }
28386
- }, [initialData]);
28405
+ }, [normalizedInitialData]);
28387
28406
  const processCalculations = React115__namespace.default.useCallback(
28388
28407
  (changedFieldId, newFormData) => {
28389
28408
  if (!hiddenCalculations.length) return;
@@ -15828,6 +15828,7 @@ var init_CardGrid = __esm({
15828
15828
  size: "sm",
15829
15829
  onClick: handleActionClick(action, itemData),
15830
15830
  "data-testid": action.event ? `action-${action.event}` : void 0,
15831
+ "data-row-id": String(itemData.id),
15831
15832
  className: "text-error hover:bg-error/10 px-2",
15832
15833
  children: action.label
15833
15834
  },
@@ -15858,6 +15859,7 @@ var init_CardGrid = __esm({
15858
15859
  size: "sm",
15859
15860
  onClick: handleActionClick(action, itemData),
15860
15861
  "data-testid": action.event ? `action-${action.event}` : void 0,
15862
+ "data-row-id": String(itemData.id),
15861
15863
  children: action.label
15862
15864
  },
15863
15865
  actionIdx
@@ -18588,6 +18590,7 @@ function DataGrid({
18588
18590
  size: "sm",
18589
18591
  onClick: handleActionClick(action, itemData),
18590
18592
  "data-testid": `action-${action.event}`,
18593
+ "data-row-id": String(itemData.id),
18591
18594
  className: "text-error hover:bg-error/10 px-2",
18592
18595
  children: [
18593
18596
  action.icon && /* @__PURE__ */ jsx(Icon, { name: action.icon, size: "xs" }),
@@ -18631,6 +18634,7 @@ function DataGrid({
18631
18634
  size: "sm",
18632
18635
  onClick: handleActionClick(action, itemData),
18633
18636
  "data-testid": `action-${action.event}`,
18637
+ "data-row-id": String(itemData.id),
18634
18638
  children: [
18635
18639
  action.icon && /* @__PURE__ */ jsx(Icon, { name: action.icon, size: "xs", className: "mr-1" }),
18636
18640
  action.label
@@ -18898,6 +18902,7 @@ function DataList({
18898
18902
  size: "sm",
18899
18903
  onClick: handleActionClick(action, itemData),
18900
18904
  "data-testid": `action-${action.event}`,
18905
+ "data-row-id": String(itemData.id),
18901
18906
  className: cn(
18902
18907
  action.variant === "danger" && "text-error hover:bg-error/10"
18903
18908
  ),
@@ -18987,6 +18992,7 @@ function DataList({
18987
18992
  size: "sm",
18988
18993
  onClick: handleActionClick(action, itemData),
18989
18994
  "data-testid": `action-${action.event}`,
18995
+ "data-row-id": String(itemData.id),
18990
18996
  className: cn(
18991
18997
  action.variant === "danger" && "text-error hover:bg-error/10"
18992
18998
  ),
@@ -27171,6 +27177,7 @@ var init_DetailPanel = __esm({
27171
27177
  actionPayload: { row: normalizedData },
27172
27178
  icon: action.icon,
27173
27179
  "data-testid": action.event ? `action-${action.event}` : void 0,
27180
+ "data-row-id": normalizedData?.id !== void 0 ? String(normalizedData.id) : void 0,
27174
27181
  children: action.label
27175
27182
  },
27176
27183
  idx
@@ -28150,6 +28157,16 @@ function evaluateFormExpression(expr, formCtx) {
28150
28157
  const ctx = toSharedContext2(formCtx);
28151
28158
  return evaluate(expr, ctx);
28152
28159
  }
28160
+ function isOrbitalEntitySchema(value) {
28161
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
28162
+ const fields = value.fields;
28163
+ return Array.isArray(fields);
28164
+ }
28165
+ function isPlainEntityRow(value) {
28166
+ if (value === null || typeof value !== "object" || Array.isArray(value)) return false;
28167
+ const fields = value.fields;
28168
+ return !Array.isArray(fields);
28169
+ }
28153
28170
  function getEnumOptions(field) {
28154
28171
  if (field.options && field.options.length > 0) {
28155
28172
  return [...field.options];
@@ -28295,9 +28312,12 @@ var init_Form = __esm({
28295
28312
  const { t } = useTranslate();
28296
28313
  const resolvedSubmitLabel = submitLabel ?? t("common.save");
28297
28314
  const resolvedCancelLabel = cancelLabel ?? t("common.cancel");
28298
- const normalizedInitialData = initialData ?? {};
28299
- const resolvedEntity = entity && typeof entity === "object" && !Array.isArray(entity) ? entity : void 0;
28315
+ const isSchemaEntity = isOrbitalEntitySchema(entity);
28316
+ const resolvedEntity = isSchemaEntity ? entity : void 0;
28300
28317
  const entityName = typeof entity === "string" ? entity : resolvedEntity?.name;
28318
+ const entityRowAsInitial = isPlainEntityRow(entity) ? entity : void 0;
28319
+ const callerInitial = initialData !== null && typeof initialData === "object" && !Array.isArray(initialData) ? initialData : {};
28320
+ const normalizedInitialData = entityRowAsInitial !== void 0 ? { ...entityRowAsInitial, ...callerInitial } : callerInitial;
28301
28321
  const entityDerivedFields = React115__default.useMemo(() => {
28302
28322
  if (fields && fields.length > 0) return void 0;
28303
28323
  if (!resolvedEntity) return void 0;
@@ -28334,11 +28354,10 @@ var init_Form = __esm({
28334
28354
  [formData, externalContext]
28335
28355
  );
28336
28356
  React115__default.useEffect(() => {
28337
- const data = initialData;
28338
- if (data && Object.keys(data).length > 0) {
28339
- setFormData(data);
28357
+ if (Object.keys(normalizedInitialData).length > 0) {
28358
+ setFormData(normalizedInitialData);
28340
28359
  }
28341
- }, [initialData]);
28360
+ }, [normalizedInitialData]);
28342
28361
  const processCalculations = React115__default.useCallback(
28343
28362
  (changedFieldId, newFormData) => {
28344
28363
  if (!hiddenCalculations.length) return;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@almadar/ui",
3
- "version": "4.6.3",
3
+ "version": "4.6.5",
4
4
  "description": "React UI components, hooks, and providers for Almadar",
5
5
  "type": "module",
6
6
  "main": "./dist/components/index.js",