lucent-ui 0.5.0 → 0.6.0

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
@@ -301,7 +301,7 @@ export declare const darkTokens: LucentTokens;
301
301
 
302
302
  export declare const DATA_TABLE_MANIFEST: ComponentManifest;
303
303
 
304
- export declare function DataTable<T extends object>({ columns, rows, pageSize, page: controlledPage, onPageChange, emptyState, style, }: DataTableProps<T>): JSX_2.Element;
304
+ export declare function DataTable<T extends object>({ columns, rows, pageSize, page: controlledPage, onPageChange, onFilterChange, emptyState, style, }: DataTableProps<T>): JSX_2.Element;
305
305
 
306
306
  export declare interface DataTableColumn<T> {
307
307
  key: string;
@@ -309,6 +309,8 @@ export declare interface DataTableColumn<T> {
309
309
  /** Custom cell renderer — defaults to `String(row[key])` */
310
310
  render?: (row: T, index: number) => ReactNode;
311
311
  sortable?: boolean;
312
+ /** Adds a searchable, multi-select dropdown filter above the table for this column */
313
+ filterable?: boolean;
312
314
  width?: string;
313
315
  align?: 'left' | 'center' | 'right';
314
316
  }
@@ -321,6 +323,11 @@ export declare interface DataTableProps<T extends object> {
321
323
  /** Controlled current page (0-indexed) */
322
324
  page?: number;
323
325
  onPageChange?: (page: number) => void;
326
+ /**
327
+ * Called with the current filter map whenever any filter changes.
328
+ * Keys are column keys; values are arrays of selected filter strings (empty arrays are omitted).
329
+ */
330
+ onFilterChange?: (filters: Record<string, string[]>) => void;
324
331
  /** Empty state slot */
325
332
  emptyState?: ReactNode;
326
333
  style?: CSSProperties;