@bsol-oss/react-datatable5 12.0.0-beta.79 → 12.0.0-beta.80

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.d.ts CHANGED
@@ -480,6 +480,29 @@ interface DefaultTableProps {
480
480
  }
481
481
  declare const DefaultTable: ({ showFooter, tableProps, tableHeaderProps, tableBodyProps, tableFooterProps, controlProps, variant, isLoading, }: DefaultTableProps) => react_jsx_runtime.JSX.Element;
482
482
 
483
+ interface DefaultTableServerProps extends DefaultTableProps {
484
+ /**
485
+ * Optional isLoading prop to override auto-detected loading state.
486
+ * If not provided, will automatically detect from DataTableServerContext.
487
+ */
488
+ isLoading?: boolean;
489
+ }
490
+ /**
491
+ * DefaultTableServer is a wrapper around DefaultTable that automatically
492
+ * detects server-side loading state from DataTableServerContext.
493
+ *
494
+ * Use this component when working with DataTableServer to automatically
495
+ * show skeleton loading state during data fetching.
496
+ *
497
+ * @example
498
+ * ```tsx
499
+ * <DataTableServer columns={columns} {...datatableServer}>
500
+ * <DefaultTableServer />
501
+ * </DataTableServer>
502
+ * ```
503
+ */
504
+ declare const DefaultTableServer: ({ isLoading: isLoadingOverride, ...props }: DefaultTableServerProps) => react_jsx_runtime.JSX.Element;
505
+
483
506
  interface ReloadButtonProps {
484
507
  variant?: string;
485
508
  }
@@ -1101,4 +1124,4 @@ declare module "@tanstack/react-table" {
1101
1124
  }
1102
1125
  }
1103
1126
 
1104
- export { type CalendarProps, CardHeader, type CardHeaderProps, type CustomJSONSchema7, type CustomJSONSchema7Definition, DataDisplay, type DataDisplayProps, type DataResponse, DataTable, type DataTableDefaultState, type DataTableProps, DataTableServer, type DataTableServerProps, type DatePickerLabels, type DatePickerProps, type DateTimePickerLabels, DefaultCardTitle, DefaultForm, type DefaultFormProps, DefaultTable, type DefaultTableProps, DensityToggleButton, type DensityToggleButtonProps, type EditFilterButtonProps, EditSortingButton, type EditSortingButtonProps, type EditViewButtonProps, EmptyState, type EmptyStateProps, type EnumPickerLabels, ErrorAlert, type ErrorAlertProps, type ErrorMessageConfig, type ErrorMessageResult, type FieldErrorConfig, type FilePickerLabels, type FilePickerMediaFile, type FilePickerProps, FilterDialog, FormBody, FormRoot, type FormRootProps, FormTitle, type GetColumnsConfigs, type GetDateColorProps, type GetMultiDatesProps, type GetRangeDatesProps, type GetStyleProps, type GetVariantProps, GlobalFilter, type IdPickerLabels, PageSizeControl, type PageSizeControlProps, Pagination, type QueryParams, type RangeCalendarProps, type RangeDatePickerProps, RecordDisplay, type RecordDisplayProps, ReloadButton, type ReloadButtonProps, ResetFilteringButton, ResetSelectionButton, ResetSortingButton, type Result, RowCountText, Table, TableBody, type TableBodyProps, TableCardContainer, type TableCardContainerProps, TableCards, type TableCardsProps, TableComponent, TableControls, type TableControlsProps, TableDataDisplay, type TableDataDisplayProps, TableFilter, TableFilterTags, TableFooter, type TableFooterProps, TableHeader, type TableHeaderProps, type TableHeaderTexts, TableLoadingComponent, type TableLoadingComponentProps, type TableProps, type TableRendererProps, type TableRowSelectorProps, TableSelector, TableSorter, TableViewer, type TagPickerProps, TextCell, type TextCellProps, type UseDataTableProps, type UseDataTableReturn, type UseDataTableServerProps, type UseDataTableServerReturn, type UseFormProps, type ValidationErrorType, ViewDialog, buildErrorMessages, buildFieldErrors, buildRequiredErrors, convertToAjvErrorsFormat, createErrorMessage, getColumns, getMultiDates, getRangeDates, idPickerSanityCheck, useDataTable, useDataTableContext, useDataTableServer, useForm, widthSanityCheck };
1127
+ export { type CalendarProps, CardHeader, type CardHeaderProps, type CustomJSONSchema7, type CustomJSONSchema7Definition, DataDisplay, type DataDisplayProps, type DataResponse, DataTable, type DataTableDefaultState, type DataTableProps, DataTableServer, type DataTableServerProps, type DatePickerLabels, type DatePickerProps, type DateTimePickerLabels, DefaultCardTitle, DefaultForm, type DefaultFormProps, DefaultTable, type DefaultTableProps, DefaultTableServer, type DefaultTableServerProps, DensityToggleButton, type DensityToggleButtonProps, type EditFilterButtonProps, EditSortingButton, type EditSortingButtonProps, type EditViewButtonProps, EmptyState, type EmptyStateProps, type EnumPickerLabels, ErrorAlert, type ErrorAlertProps, type ErrorMessageConfig, type ErrorMessageResult, type FieldErrorConfig, type FilePickerLabels, type FilePickerMediaFile, type FilePickerProps, FilterDialog, FormBody, FormRoot, type FormRootProps, FormTitle, type GetColumnsConfigs, type GetDateColorProps, type GetMultiDatesProps, type GetRangeDatesProps, type GetStyleProps, type GetVariantProps, GlobalFilter, type IdPickerLabels, PageSizeControl, type PageSizeControlProps, Pagination, type QueryParams, type RangeCalendarProps, type RangeDatePickerProps, RecordDisplay, type RecordDisplayProps, ReloadButton, type ReloadButtonProps, ResetFilteringButton, ResetSelectionButton, ResetSortingButton, type Result, RowCountText, Table, TableBody, type TableBodyProps, TableCardContainer, type TableCardContainerProps, TableCards, type TableCardsProps, TableComponent, TableControls, type TableControlsProps, TableDataDisplay, type TableDataDisplayProps, TableFilter, TableFilterTags, TableFooter, type TableFooterProps, TableHeader, type TableHeaderProps, type TableHeaderTexts, TableLoadingComponent, type TableLoadingComponentProps, type TableProps, type TableRendererProps, type TableRowSelectorProps, TableSelector, TableSorter, TableViewer, type TagPickerProps, TextCell, type TextCellProps, type UseDataTableProps, type UseDataTableReturn, type UseDataTableServerProps, type UseDataTableServerReturn, type UseFormProps, type ValidationErrorType, ViewDialog, buildErrorMessages, buildFieldErrors, buildRequiredErrors, convertToAjvErrorsFormat, createErrorMessage, getColumns, getMultiDates, getRangeDates, idPickerSanityCheck, useDataTable, useDataTableContext, useDataTableServer, useForm, widthSanityCheck };
package/dist/index.js CHANGED
@@ -3415,6 +3415,27 @@ const DefaultTable = ({ showFooter = false, tableProps = {}, tableHeaderProps =
3415
3415
  return (jsxRuntime.jsx(TableControls, { ...controlProps, children: jsxRuntime.jsxs(Table, { showLoading: isLoading, ...tableProps, children: [jsxRuntime.jsx(TableHeader, { ...tableHeaderProps }), bodyComponent, showFooter && jsxRuntime.jsx(TableFooter, { ...tableFooterProps })] }) }));
3416
3416
  };
3417
3417
 
3418
+ /**
3419
+ * DefaultTableServer is a wrapper around DefaultTable that automatically
3420
+ * detects server-side loading state from DataTableServerContext.
3421
+ *
3422
+ * Use this component when working with DataTableServer to automatically
3423
+ * show skeleton loading state during data fetching.
3424
+ *
3425
+ * @example
3426
+ * ```tsx
3427
+ * <DataTableServer columns={columns} {...datatableServer}>
3428
+ * <DefaultTableServer />
3429
+ * </DataTableServer>
3430
+ * ```
3431
+ */
3432
+ const DefaultTableServer = ({ isLoading: isLoadingOverride, ...props }) => {
3433
+ // Automatically detect loading state from server context
3434
+ const serverContext = useDataTableServerContext();
3435
+ const isLoading = isLoadingOverride ?? serverContext?.query?.isLoading ?? false;
3436
+ return jsxRuntime.jsx(DefaultTable, { ...props, isLoading: isLoading });
3437
+ };
3438
+
3418
3439
  const TableCardContainer = ({ children, variant = "", gap = "1rem", gridTemplateColumns = "repeat(auto-fit, minmax(20rem, 1fr))", direction = "row", ...props }) => {
3419
3440
  if (variant === "carousel") {
3420
3441
  return (jsxRuntime.jsx(react.Flex, { overflow: "auto", gap: gap, direction: direction, ...props, children: children }));
@@ -7200,6 +7221,7 @@ exports.DataTableServer = DataTableServer;
7200
7221
  exports.DefaultCardTitle = DefaultCardTitle;
7201
7222
  exports.DefaultForm = DefaultForm;
7202
7223
  exports.DefaultTable = DefaultTable;
7224
+ exports.DefaultTableServer = DefaultTableServer;
7203
7225
  exports.DensityToggleButton = DensityToggleButton;
7204
7226
  exports.EditSortingButton = EditSortingButton;
7205
7227
  exports.EmptyState = EmptyState$1;
package/dist/index.mjs CHANGED
@@ -3395,6 +3395,27 @@ const DefaultTable = ({ showFooter = false, tableProps = {}, tableHeaderProps =
3395
3395
  return (jsx(TableControls, { ...controlProps, children: jsxs(Table, { showLoading: isLoading, ...tableProps, children: [jsx(TableHeader, { ...tableHeaderProps }), bodyComponent, showFooter && jsx(TableFooter, { ...tableFooterProps })] }) }));
3396
3396
  };
3397
3397
 
3398
+ /**
3399
+ * DefaultTableServer is a wrapper around DefaultTable that automatically
3400
+ * detects server-side loading state from DataTableServerContext.
3401
+ *
3402
+ * Use this component when working with DataTableServer to automatically
3403
+ * show skeleton loading state during data fetching.
3404
+ *
3405
+ * @example
3406
+ * ```tsx
3407
+ * <DataTableServer columns={columns} {...datatableServer}>
3408
+ * <DefaultTableServer />
3409
+ * </DataTableServer>
3410
+ * ```
3411
+ */
3412
+ const DefaultTableServer = ({ isLoading: isLoadingOverride, ...props }) => {
3413
+ // Automatically detect loading state from server context
3414
+ const serverContext = useDataTableServerContext();
3415
+ const isLoading = isLoadingOverride ?? serverContext?.query?.isLoading ?? false;
3416
+ return jsx(DefaultTable, { ...props, isLoading: isLoading });
3417
+ };
3418
+
3398
3419
  const TableCardContainer = ({ children, variant = "", gap = "1rem", gridTemplateColumns = "repeat(auto-fit, minmax(20rem, 1fr))", direction = "row", ...props }) => {
3399
3420
  if (variant === "carousel") {
3400
3421
  return (jsx(Flex, { overflow: "auto", gap: gap, direction: direction, ...props, children: children }));
@@ -7173,4 +7194,4 @@ const getMultiDates = ({ selected, selectedDate, selectedDates, selectable, }) =
7173
7194
  }
7174
7195
  };
7175
7196
 
7176
- export { CardHeader, DataDisplay, DataTable, DataTableServer, DefaultCardTitle, DefaultForm, DefaultTable, DensityToggleButton, EditSortingButton, EmptyState$1 as EmptyState, ErrorAlert, FilterDialog, FormBody, FormRoot, FormTitle, GlobalFilter, PageSizeControl, Pagination, RecordDisplay, ReloadButton, ResetFilteringButton, ResetSelectionButton, ResetSortingButton, RowCountText, Table, TableBody, TableCardContainer, TableCards, TableComponent, TableControls, TableDataDisplay, TableFilter, TableFilterTags, TableFooter, TableHeader, TableLoadingComponent, TableSelector, TableSorter, TableViewer, TextCell, ViewDialog, buildErrorMessages, buildFieldErrors, buildRequiredErrors, convertToAjvErrorsFormat, createErrorMessage, getColumns, getMultiDates, getRangeDates, idPickerSanityCheck, useDataTable, useDataTableContext, useDataTableServer, useForm, widthSanityCheck };
7197
+ export { CardHeader, DataDisplay, DataTable, DataTableServer, DefaultCardTitle, DefaultForm, DefaultTable, DefaultTableServer, DensityToggleButton, EditSortingButton, EmptyState$1 as EmptyState, ErrorAlert, FilterDialog, FormBody, FormRoot, FormTitle, GlobalFilter, PageSizeControl, Pagination, RecordDisplay, ReloadButton, ResetFilteringButton, ResetSelectionButton, ResetSortingButton, RowCountText, Table, TableBody, TableCardContainer, TableCards, TableComponent, TableControls, TableDataDisplay, TableFilter, TableFilterTags, TableFooter, TableHeader, TableLoadingComponent, TableSelector, TableSorter, TableViewer, TextCell, ViewDialog, buildErrorMessages, buildFieldErrors, buildRequiredErrors, convertToAjvErrorsFormat, createErrorMessage, getColumns, getMultiDates, getRangeDates, idPickerSanityCheck, useDataTable, useDataTableContext, useDataTableServer, useForm, widthSanityCheck };
@@ -89,6 +89,7 @@ export * from "./components/DataTable/display/DataDisplay";
89
89
  export * from "./components/DataTable/DataTable";
90
90
  export * from "./components/DataTable/DataTableServer";
91
91
  export * from "./components/DataTable/DefaultTable";
92
+ export * from "./components/DataTable/DefaultTableServer";
92
93
  export * from "./components/DataTable/controls/ReloadButton";
93
94
  export * from "./components/DataTable/display/Table";
94
95
  export * from "./components/DataTable/display/TableBody";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bsol-oss/react-datatable5",
3
- "version": "12.0.0-beta.79",
3
+ "version": "12.0.0-beta.80",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.mjs",