@updog/data-editor 0.1.3 → 0.1.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.
- package/README.md +281 -107
- package/index.css +1 -1
- package/index.d.ts +303 -53
- package/package.json +1 -1
package/index.d.ts
CHANGED
|
@@ -818,11 +818,40 @@ declare class ServerEditBuilder<TRow extends DataEditorRow = DataEditorRow> {
|
|
|
818
818
|
private viewContext;
|
|
819
819
|
}
|
|
820
820
|
|
|
821
|
+
/**
|
|
822
|
+
* Categories of internal errors surfaced through the `onError` callback.
|
|
823
|
+
*
|
|
824
|
+
* - `PARSE_ERROR` — file parsing failed (corrupt CSV, invalid XLSX, etc.).
|
|
825
|
+
* - `RENDER_ERROR` — component render failed (caught by error boundary).
|
|
826
|
+
* - `TRANSFORM_ERROR` — data transformation failed (column transform, value mapping).
|
|
827
|
+
* - `VALIDATION_ERROR` — validation execution failed (validator threw instead of returning).
|
|
828
|
+
* - `WORKER_ERROR` — Web Worker failed (filter worker, chat transform worker).
|
|
829
|
+
* - `COMMAND_ERROR` — undo/redo command failed.
|
|
830
|
+
* - `OPERATION_ERROR` — general operation failed (bulk mutations, imports).
|
|
831
|
+
*/
|
|
821
832
|
type UpdogErrorCode = "PARSE_ERROR" | "RENDER_ERROR" | "TRANSFORM_ERROR" | "VALIDATION_ERROR" | "WORKER_ERROR" | "COMMAND_ERROR" | "OPERATION_ERROR";
|
|
833
|
+
/**
|
|
834
|
+
* An internal error caught by the SDK and passed to `onError`. The SDK
|
|
835
|
+
* recovers gracefully where possible — `onError` is for your logging and
|
|
836
|
+
* monitoring (Sentry, Datadog, etc.).
|
|
837
|
+
*
|
|
838
|
+
* @example
|
|
839
|
+
* ```ts
|
|
840
|
+
* onError={(error) => {
|
|
841
|
+
* Sentry.captureException(error.originalError ?? error, {
|
|
842
|
+
* tags: { code: error.code, source: error.source },
|
|
843
|
+
* });
|
|
844
|
+
* }}
|
|
845
|
+
* ```
|
|
846
|
+
*/
|
|
822
847
|
type UpdogError = {
|
|
848
|
+
/** The error category. */
|
|
823
849
|
code: UpdogErrorCode;
|
|
850
|
+
/** Human-readable description. */
|
|
824
851
|
message: string;
|
|
852
|
+
/** Module or subsystem that raised the error. */
|
|
825
853
|
source: string;
|
|
854
|
+
/** The underlying thrown value, when available. */
|
|
826
855
|
originalError?: unknown;
|
|
827
856
|
};
|
|
828
857
|
|
|
@@ -1745,7 +1774,9 @@ type ColumnDelta = {
|
|
|
1745
1774
|
|
|
1746
1775
|
/**
|
|
1747
1776
|
* Base row shape. Each key is a column ID, each value is the cell data.
|
|
1748
|
-
* Extend this with your own type
|
|
1777
|
+
* Extend this with your own type via the `<DataEditor<TRow>>` generic for
|
|
1778
|
+
* type-safe column access. When the generic is omitted, rows are typed as
|
|
1779
|
+
* `Record<string, unknown>`.
|
|
1749
1780
|
*
|
|
1750
1781
|
* @example
|
|
1751
1782
|
* ```ts
|
|
@@ -1754,7 +1785,9 @@ type ColumnDelta = {
|
|
|
1754
1785
|
* ```
|
|
1755
1786
|
*/
|
|
1756
1787
|
type DataEditorRow = Record<string, unknown>;
|
|
1788
|
+
/** Sort direction. */
|
|
1757
1789
|
type SortDirection = "asc" | "desc";
|
|
1790
|
+
/** Current sort state. `null` means no active sort. */
|
|
1758
1791
|
type SortState = {
|
|
1759
1792
|
columnId: string;
|
|
1760
1793
|
direction: SortDirection;
|
|
@@ -1784,6 +1817,14 @@ type Filters = {
|
|
|
1784
1817
|
}>;
|
|
1785
1818
|
};
|
|
1786
1819
|
|
|
1820
|
+
/**
|
|
1821
|
+
* A single chunk in the stream returned from `DataEditorChat.onMessage`.
|
|
1822
|
+
*
|
|
1823
|
+
* - `status` — progress message shown while processing (e.g. "Analyzing 500 rows...").
|
|
1824
|
+
* - `message` — chat reply shown to the user.
|
|
1825
|
+
* - `rows` — updated rows to apply to the grid. Matched by `primaryKey`.
|
|
1826
|
+
* - `transform` — description of the transform applied.
|
|
1827
|
+
*/
|
|
1787
1828
|
type ChatResponseChunk<TRow extends DataEditorRow = DataEditorRow> = {
|
|
1788
1829
|
type: "status";
|
|
1789
1830
|
content: string;
|
|
@@ -1797,37 +1838,105 @@ type ChatResponseChunk<TRow extends DataEditorRow = DataEditorRow> = {
|
|
|
1797
1838
|
type: "transform";
|
|
1798
1839
|
content: string;
|
|
1799
1840
|
};
|
|
1841
|
+
/** Status of a row in the chat sample, relative to its origin snapshot. */
|
|
1800
1842
|
type ChatRowStatus = "new" | "edited" | "original";
|
|
1843
|
+
/** A sample row handed to the chat callback, with its current status and validation errors. */
|
|
1801
1844
|
type ChatRow<TRow extends DataEditorRow = DataEditorRow> = {
|
|
1845
|
+
/** Row data keyed by column ID. */
|
|
1802
1846
|
data: TRow;
|
|
1847
|
+
/** Whether the row was newly added, edited, or is unchanged. */
|
|
1803
1848
|
status: ChatRowStatus;
|
|
1849
|
+
/** Validation errors keyed by column ID. */
|
|
1804
1850
|
errors: Record<string, string[]>;
|
|
1851
|
+
/** The source this row belongs to. */
|
|
1805
1852
|
source: string;
|
|
1806
1853
|
};
|
|
1854
|
+
/** Aggregated error count across the current view, grouped by field and message. */
|
|
1807
1855
|
type ChatErrorSummary = {
|
|
1856
|
+
/** Column ID where the error occurred. */
|
|
1808
1857
|
field: string;
|
|
1858
|
+
/** The validation message. */
|
|
1809
1859
|
message: string;
|
|
1860
|
+
/** How many rows hit this error. */
|
|
1810
1861
|
count: number;
|
|
1862
|
+
/** A few example values that triggered the error. */
|
|
1811
1863
|
examples: string[];
|
|
1812
1864
|
};
|
|
1865
|
+
/**
|
|
1866
|
+
* Context about the current dataset, passed to `loadSuggestions` and extended
|
|
1867
|
+
* into `ChatContext` for `onMessage`.
|
|
1868
|
+
*/
|
|
1813
1869
|
type ChatDataContext<TRow extends DataEditorRow = DataEditorRow> = {
|
|
1870
|
+
/** Full column definitions. */
|
|
1814
1871
|
columns: DataEditorColumn[];
|
|
1872
|
+
/** Row identifier field. */
|
|
1815
1873
|
primaryKey: keyof TRow;
|
|
1874
|
+
/** Total rows in the dataset. */
|
|
1816
1875
|
totalRowCount: number;
|
|
1876
|
+
/** Rows in the current filtered view. */
|
|
1817
1877
|
filteredRowCount: number;
|
|
1878
|
+
/** Sample rows, with status and errors. Size controlled by `sampleSize`. */
|
|
1818
1879
|
sample: ChatRow<TRow>[];
|
|
1880
|
+
/** Aggregated error counts by field and message. */
|
|
1819
1881
|
errorSummary: ChatErrorSummary[];
|
|
1882
|
+
/** Access all rows. Use for full-dataset operations. */
|
|
1820
1883
|
getRows: () => ChatRow<TRow>[];
|
|
1821
1884
|
};
|
|
1885
|
+
/**
|
|
1886
|
+
* The full context passed to `DataEditorChat.onMessage` when the user sends
|
|
1887
|
+
* a prompt. Includes the prompt itself and all dataset context.
|
|
1888
|
+
*/
|
|
1822
1889
|
type ChatContext<TRow extends DataEditorRow = DataEditorRow> = ChatDataContext<TRow> & {
|
|
1890
|
+
/** The user's chat prompt. */
|
|
1823
1891
|
message: string;
|
|
1824
1892
|
};
|
|
1893
|
+
/**
|
|
1894
|
+
* Bring-your-own-AI chat configuration. When provided via the `chat` prop,
|
|
1895
|
+
* the editor shows a chat panel alongside the grid. You own the AI
|
|
1896
|
+
* integration; the SDK hands you dataset context and renders the streamed
|
|
1897
|
+
* response.
|
|
1898
|
+
*
|
|
1899
|
+
* @example
|
|
1900
|
+
* ```ts
|
|
1901
|
+
* chat={{
|
|
1902
|
+
* sampleSize: 50,
|
|
1903
|
+
* onMessage: async function* (context) {
|
|
1904
|
+
* yield { type: "status", content: "Thinking..." };
|
|
1905
|
+
* const res = await fetch("/api/ai", {
|
|
1906
|
+
* method: "POST",
|
|
1907
|
+
* body: JSON.stringify({
|
|
1908
|
+
* prompt: context.message,
|
|
1909
|
+
* columns: context.columns,
|
|
1910
|
+
* sample: context.sample.map(r => r.data),
|
|
1911
|
+
* errors: context.errorSummary,
|
|
1912
|
+
* }),
|
|
1913
|
+
* }).then(r => r.json());
|
|
1914
|
+
* yield { type: "rows", content: res.updatedRows };
|
|
1915
|
+
* yield { type: "transform", content: res.description };
|
|
1916
|
+
* yield { type: "message", content: res.reply };
|
|
1917
|
+
* },
|
|
1918
|
+
* }}
|
|
1919
|
+
* ```
|
|
1920
|
+
*/
|
|
1825
1921
|
type DataEditorChat<TRow extends DataEditorRow = DataEditorRow> = {
|
|
1922
|
+
/**
|
|
1923
|
+
* How many rows to include in the context sample. The SDK picks a
|
|
1924
|
+
* representative slice including rows with errors. When omitted, the SDK decides.
|
|
1925
|
+
*/
|
|
1826
1926
|
sampleSize?: number;
|
|
1927
|
+
/** Title shown above the suggestion list when the chat is empty. */
|
|
1827
1928
|
emptyTitle?: string;
|
|
1929
|
+
/** How many suggestions to request from `loadSuggestions`. */
|
|
1828
1930
|
suggestionsCount?: number;
|
|
1931
|
+
/** Optional prompt generator for the empty-state suggestion chips. */
|
|
1829
1932
|
loadSuggestions?: (context: ChatDataContext<TRow>) => Promise<string[]>;
|
|
1933
|
+
/**
|
|
1934
|
+
* Called when the user sends a message. Receives full dataset context.
|
|
1935
|
+
* Returns an async iterable of response chunks — the SDK streams them
|
|
1936
|
+
* into the UI.
|
|
1937
|
+
*/
|
|
1830
1938
|
onMessage: (context: ChatContext<TRow>) => AsyncIterable<ChatResponseChunk<TRow>>;
|
|
1939
|
+
/** Called when the user cancels a pending request. Use to abort your API call. */
|
|
1831
1940
|
onCancel?: () => void;
|
|
1832
1941
|
};
|
|
1833
1942
|
|
|
@@ -1847,8 +1956,13 @@ type ValidationResult = ValidationError[] | null;
|
|
|
1847
1956
|
* A function that validates a single cell value.
|
|
1848
1957
|
* Return a `ValidationError` to flag a problem, or `null` if the value is valid.
|
|
1849
1958
|
*
|
|
1959
|
+
* A `ValidationError` with `level: "error"` flags the cell in the grid but
|
|
1960
|
+
* does not block submission — invalid rows are delivered to `onComplete`
|
|
1961
|
+
* alongside valid ones, tagged via the `isValid` flag.
|
|
1962
|
+
*
|
|
1850
1963
|
* Built-in validator factories: `required(msg)`, `numeric(msg)`, `email(msg)`,
|
|
1851
|
-
* `date(msg)`, `endDateAfterStart(startField, msg)`.
|
|
1964
|
+
* `date(msg)`, `oneOf(values, msg)`, `endDateAfterStart(startField, msg)`.
|
|
1965
|
+
* Import them from the package root.
|
|
1852
1966
|
*
|
|
1853
1967
|
* @param value - The current cell value.
|
|
1854
1968
|
* @param row - The full row, useful for cross-field checks.
|
|
@@ -1932,41 +2046,62 @@ type ColumnLockMode = "all" | "default";
|
|
|
1932
2046
|
*
|
|
1933
2047
|
* @example
|
|
1934
2048
|
* ```ts
|
|
2049
|
+
* import { required, email, numeric } from "@updog/data-editor";
|
|
2050
|
+
*
|
|
1935
2051
|
* const columns: DataEditorColumn[] = [
|
|
1936
|
-
* { id: "name", title: "Full Name",
|
|
1937
|
-
* { id: "email", title: "Email",
|
|
1938
|
-
* { id: "role", title: "Role", editor: { type: "select", options:
|
|
1939
|
-
* { id: "salary", title: "Salary", validate: numeric, formatter: (v) => `$${v}` },
|
|
2052
|
+
* { id: "name", title: "Full Name", size: 200, validate: required("Name is required") },
|
|
2053
|
+
* { id: "email", title: "Email", size: 250, validate: [required("Email is required"), email("Invalid email")], unique: true },
|
|
2054
|
+
* { id: "role", title: "Role", editor: { type: "select", options: ["Admin", "Editor", "Viewer"] } },
|
|
2055
|
+
* { id: "salary", title: "Salary", validate: numeric("Must be a number"), formatter: (v) => v ? `$${v}` : "" },
|
|
1940
2056
|
* ];
|
|
1941
2057
|
* ```
|
|
1942
2058
|
*/
|
|
1943
2059
|
type DataEditorColumn = {
|
|
1944
2060
|
/** Unique column identifier. Must match the keys in your row data. */
|
|
1945
2061
|
id: string;
|
|
1946
|
-
/** Column header text. */
|
|
2062
|
+
/** Column header text shown to the user. */
|
|
1947
2063
|
title: string;
|
|
1948
|
-
/**
|
|
2064
|
+
/**
|
|
2065
|
+
* One or more validators run on every edit. Each receives the cell value and
|
|
2066
|
+
* the full row, and returns a `ValidationError` to flag a problem or `null`
|
|
2067
|
+
* if valid. Errors do not block submission — see `CellValidator`.
|
|
2068
|
+
*/
|
|
1949
2069
|
validate?: CellValidator | CellValidator[];
|
|
1950
|
-
/**
|
|
2070
|
+
/**
|
|
2071
|
+
* When `true`, the editor flags duplicate values in this column as errors.
|
|
2072
|
+
* The error message is localized via the `translations` prop
|
|
2073
|
+
* (`dataEditor.validation.valueMustBeUnique`).
|
|
2074
|
+
*/
|
|
1951
2075
|
unique?: boolean;
|
|
1952
|
-
/**
|
|
2076
|
+
/**
|
|
2077
|
+
* Column IDs to revalidate when this column changes. Use for cross-field
|
|
2078
|
+
* rules like "end date must be after start date".
|
|
2079
|
+
*/
|
|
1953
2080
|
dependentFields?: string[];
|
|
1954
2081
|
/** Format the display value without changing stored data. E.g. add `$` prefix. */
|
|
1955
2082
|
formatter?: (value: string) => string;
|
|
1956
|
-
/**
|
|
2083
|
+
/**
|
|
2084
|
+
* Transform a value before it enters the store. Runs when rows are uploaded
|
|
2085
|
+
* to the data editor.
|
|
2086
|
+
*/
|
|
1957
2087
|
transformer?: (value: unknown) => unknown;
|
|
1958
2088
|
/** How the cell is edited. Defaults to text input. */
|
|
1959
2089
|
editor?: CellEditor;
|
|
1960
2090
|
/** Adds a filter control for this column in the sidebar Filters panel. */
|
|
1961
2091
|
filter?: ColumnFilter;
|
|
1962
|
-
/**
|
|
2092
|
+
/**
|
|
2093
|
+
* Whether this column can be pinned to the left (right in RTL) via the
|
|
2094
|
+
* header context menu. @default true
|
|
2095
|
+
*/
|
|
1963
2096
|
pinnable?: boolean;
|
|
1964
2097
|
/** Column width in pixels. @default 150 */
|
|
1965
2098
|
size?: number;
|
|
1966
2099
|
/**
|
|
1967
|
-
* Controls whether cells in this column are locked.
|
|
1968
|
-
*
|
|
1969
|
-
* - `"
|
|
2100
|
+
* Controls whether cells in this column are locked. A column locked via
|
|
2101
|
+
* configuration cannot be unlocked from the UI.
|
|
2102
|
+
* - `true` | `"all"` — locked for every row.
|
|
2103
|
+
* - `"default"` — locked only for default-source rows; rows added manually,
|
|
2104
|
+
* duplicated, or imported remain editable.
|
|
1970
2105
|
* - `false` | `undefined` — not locked.
|
|
1971
2106
|
*/
|
|
1972
2107
|
locked?: boolean | ColumnLockMode;
|
|
@@ -2386,9 +2521,12 @@ type UndoRedoResult = {
|
|
|
2386
2521
|
success: boolean;
|
|
2387
2522
|
targetCell?: CellLocation;
|
|
2388
2523
|
};
|
|
2389
|
-
/**
|
|
2524
|
+
/**
|
|
2525
|
+
* Actions available inside the `onComplete` callback. Call `reset()` after a
|
|
2526
|
+
* successful save to clear the editor and re-fetch via `loadData`.
|
|
2527
|
+
*/
|
|
2390
2528
|
type DataEditorActions = {
|
|
2391
|
-
/** Discard all changes and reload the original data
|
|
2529
|
+
/** Discard all changes and reload the original data via `loadData`. */
|
|
2392
2530
|
reset: () => void;
|
|
2393
2531
|
};
|
|
2394
2532
|
/**
|
|
@@ -2448,14 +2586,24 @@ type DataEditorResult<TRow extends DataEditorRow = DataEditorRow> = {
|
|
|
2448
2586
|
invalid: number;
|
|
2449
2587
|
};
|
|
2450
2588
|
};
|
|
2589
|
+
/**
|
|
2590
|
+
* Options used to tag a chunk passed to `loadData`'s `onChunk` callback.
|
|
2591
|
+
* Sources are auto-registered on first encounter. Chunks without options go
|
|
2592
|
+
* to "Existing Data".
|
|
2593
|
+
*/
|
|
2451
2594
|
type ChunkSourceOptions = {
|
|
2452
|
-
/** Display name for this data source. */
|
|
2595
|
+
/** Display name for this data source. Required when tagging a source. */
|
|
2453
2596
|
source: string;
|
|
2454
|
-
/** Stable identifier. Defaults to `source` value when omitted. */
|
|
2597
|
+
/** Stable identifier. Defaults to the `source` value when omitted. */
|
|
2455
2598
|
id?: string;
|
|
2456
|
-
/**
|
|
2599
|
+
/** Whether the user can delete this source from the editor. @default false */
|
|
2457
2600
|
deletable?: boolean;
|
|
2458
|
-
/**
|
|
2601
|
+
/**
|
|
2602
|
+
* Marks this source as finished loading. Shows a completion state in the
|
|
2603
|
+
* UI. When the `loadData` promise resolves, any source still loading is
|
|
2604
|
+
* automatically finalized.
|
|
2605
|
+
* @default false
|
|
2606
|
+
*/
|
|
2459
2607
|
done?: boolean;
|
|
2460
2608
|
};
|
|
2461
2609
|
type DataSourceId = string;
|
|
@@ -2509,20 +2657,34 @@ type DataStoreSnapshot = {
|
|
|
2509
2657
|
/** True when the "show deleted rows" filter is active (bin mode). */
|
|
2510
2658
|
showOnlyDeletedRows: boolean;
|
|
2511
2659
|
};
|
|
2512
|
-
/**
|
|
2660
|
+
/**
|
|
2661
|
+
* Per-column input to `onValueMatch`: the unique imported values from the
|
|
2662
|
+
* file and the allowed select options defined on the column.
|
|
2663
|
+
*/
|
|
2513
2664
|
type ValueMatchInput = {
|
|
2665
|
+
/** Distinct values seen in the imported file for this column. */
|
|
2514
2666
|
importedValues: string[];
|
|
2667
|
+
/** Allowed options from the column's `select` editor. */
|
|
2515
2668
|
options: string[];
|
|
2516
2669
|
};
|
|
2517
|
-
/**
|
|
2670
|
+
/**
|
|
2671
|
+
* Per-column result from `onValueMatch`. Outer key = column ID, inner key =
|
|
2672
|
+
* imported value, inner value = chosen option, or `null` to skip
|
|
2673
|
+
* auto-matching for that value. Unmapped values fall back to built-in fuzzy
|
|
2674
|
+
* matching.
|
|
2675
|
+
*/
|
|
2518
2676
|
type ValueMatchOutput = Record<string, Record<string, string | null>>;
|
|
2519
|
-
/** File formats supported for import and export. */
|
|
2677
|
+
/** File formats supported for import and export. Shared by `importFormats` and `exportFormats`. */
|
|
2520
2678
|
type DataEditorFormat = "csv" | "tsv" | "xlsx" | "json" | "xml";
|
|
2521
2679
|
/**
|
|
2522
2680
|
* A client-defined remote data source (e.g. Google Sheets, S3, Dropbox).
|
|
2523
2681
|
*
|
|
2524
|
-
* The SDK renders a button per source and calls `fetch()`
|
|
2525
|
-
*
|
|
2682
|
+
* The SDK renders a button per source on the upload step and calls `fetch()`
|
|
2683
|
+
* when clicked. You own all integration complexity — auth, pickers,
|
|
2684
|
+
* downloads. The SDK just processes the result.
|
|
2685
|
+
*
|
|
2686
|
+
* Return a `File` to go through the standard parse pipeline
|
|
2687
|
+
* (CSV/XLSX/JSON/XML), or return structured records to skip parsing entirely.
|
|
2526
2688
|
*
|
|
2527
2689
|
* @example
|
|
2528
2690
|
* ```ts
|
|
@@ -2546,7 +2708,10 @@ type RemoteSource = {
|
|
|
2546
2708
|
icon: string;
|
|
2547
2709
|
/** Optional tooltip text. */
|
|
2548
2710
|
description?: string;
|
|
2549
|
-
/**
|
|
2711
|
+
/**
|
|
2712
|
+
* Returns a `File` (parsed via the CSV/XLSX/JSON/XML pipeline) or structured
|
|
2713
|
+
* records (used directly, skipping parse).
|
|
2714
|
+
*/
|
|
2550
2715
|
fetch: () => Promise<File | Record<string, unknown>[]>;
|
|
2551
2716
|
};
|
|
2552
2717
|
/**
|
|
@@ -2561,8 +2726,9 @@ type DataEditorBaseProps<TRow extends DataEditorRow = DataEditorRow> = {
|
|
|
2561
2726
|
/** Column definitions. Each entry describes one column in the grid. */
|
|
2562
2727
|
columns: DataEditorColumn[];
|
|
2563
2728
|
/**
|
|
2564
|
-
* The column ID used to uniquely identify each row (e.g. `"id"` or
|
|
2565
|
-
* Used to match imported rows
|
|
2729
|
+
* The column ID used to uniquely identify each row (e.g. `"id"` or
|
|
2730
|
+
* `"employeeId"`). Used to match imported rows against existing data and to
|
|
2731
|
+
* track edits.
|
|
2566
2732
|
*/
|
|
2567
2733
|
primaryKey: keyof TRow;
|
|
2568
2734
|
/**
|
|
@@ -2616,37 +2782,78 @@ type DataEditorBaseProps<TRow extends DataEditorRow = DataEditorRow> = {
|
|
|
2616
2782
|
* ```
|
|
2617
2783
|
*/
|
|
2618
2784
|
onComplete?: (result: DataEditorResult<TRow>, actions: DataEditorActions) => void;
|
|
2619
|
-
/**
|
|
2785
|
+
/**
|
|
2786
|
+
* Controls the initial view. `"editor"` opens directly to the spreadsheet
|
|
2787
|
+
* grid. `"uploader"` opens the file import wizard first — the user uploads
|
|
2788
|
+
* a file, maps columns, fixes errors, then continues to the grid.
|
|
2789
|
+
* @default "editor"
|
|
2790
|
+
*/
|
|
2620
2791
|
variant?: DataEditorVariant;
|
|
2621
|
-
/**
|
|
2792
|
+
/**
|
|
2793
|
+
* Override any UI string. Pass a partial object — only the keys you provide
|
|
2794
|
+
* are replaced. Every key lives under `dataEditor`.
|
|
2795
|
+
*/
|
|
2622
2796
|
translations?: DataEditorTranslations;
|
|
2623
|
-
/**
|
|
2797
|
+
/**
|
|
2798
|
+
* BCP 47 locale tag (e.g. `"en"`, `"fr"`, `"ar"`). Used for plural rules
|
|
2799
|
+
* and locale-aware features.
|
|
2800
|
+
* @default "en"
|
|
2801
|
+
*/
|
|
2624
2802
|
locale?: string;
|
|
2625
2803
|
/**
|
|
2626
2804
|
* Controls row deletion via the right-click context menu.
|
|
2627
|
-
* - `false` — deletion disabled
|
|
2805
|
+
* - `false` — deletion disabled.
|
|
2628
2806
|
* - `"new"` — only manually added or imported rows can be deleted.
|
|
2629
2807
|
* - `"all"` — any row can be deleted.
|
|
2630
2808
|
* @default false
|
|
2631
2809
|
*/
|
|
2632
2810
|
enableDeleteRow?: "all" | "new" | false;
|
|
2633
|
-
/**
|
|
2811
|
+
/**
|
|
2812
|
+
* Show the "Add row" button in the data sources panel. When `false`, users
|
|
2813
|
+
* can only edit existing rows or import data — they can't manually add
|
|
2814
|
+
* blank rows.
|
|
2815
|
+
* @default true
|
|
2816
|
+
*/
|
|
2634
2817
|
enableAddRow?: boolean;
|
|
2635
|
-
/**
|
|
2818
|
+
/**
|
|
2819
|
+
* Which file formats the user can import. `undefined` allows all formats,
|
|
2820
|
+
* `[]` disables import entirely.
|
|
2821
|
+
*/
|
|
2636
2822
|
importFormats?: DataEditorFormat[];
|
|
2637
|
-
/**
|
|
2823
|
+
/**
|
|
2824
|
+
* Client-defined remote data sources rendered as buttons on the upload
|
|
2825
|
+
* step. You own the integration; the SDK renders the button and processes
|
|
2826
|
+
* the result of `fetch()`.
|
|
2827
|
+
*/
|
|
2638
2828
|
remoteSources?: RemoteSource[];
|
|
2639
|
-
/**
|
|
2829
|
+
/**
|
|
2830
|
+
* Which file formats the user can export to. `undefined` allows all
|
|
2831
|
+
* formats, `[]` disables export entirely.
|
|
2832
|
+
*/
|
|
2640
2833
|
exportFormats?: DataEditorFormat[];
|
|
2641
2834
|
/** Row height in pixels. @default 34 */
|
|
2642
2835
|
rowHeight?: number;
|
|
2643
2836
|
/** Header row height in pixels. @default 36 */
|
|
2644
2837
|
headerHeight?: number;
|
|
2645
|
-
/**
|
|
2838
|
+
/**
|
|
2839
|
+
* When `true`, hides all editing UI (submit, add row, delete, import). The
|
|
2840
|
+
* grid becomes view-only.
|
|
2841
|
+
* @default false
|
|
2842
|
+
*/
|
|
2646
2843
|
readonly?: boolean;
|
|
2647
|
-
/**
|
|
2844
|
+
/**
|
|
2845
|
+
* Enable right-to-left layout. Set to `true` for Arabic, Hebrew, and other
|
|
2846
|
+
* RTL languages. Affects grid direction, text alignment, and scrollbar
|
|
2847
|
+
* position.
|
|
2848
|
+
* @default false
|
|
2849
|
+
*/
|
|
2648
2850
|
rtl?: boolean;
|
|
2649
|
-
/**
|
|
2851
|
+
/**
|
|
2852
|
+
* Allow creating new columns for unmatched CSV headers during import. When
|
|
2853
|
+
* enabled, users can keep data from columns that don't match your schema by
|
|
2854
|
+
* creating dynamic columns on the fly.
|
|
2855
|
+
* @default true
|
|
2856
|
+
*/
|
|
2650
2857
|
enableCreateColumn?: boolean;
|
|
2651
2858
|
/** Override column matching during import. Return a map of `{ csvHeader: columnId | null }`. Unmapped or `null` entries fall back to built-in matching. */
|
|
2652
2859
|
onColumnMatch?: (headers: string[], columns: DataEditorColumn[]) => Record<string, string | null> | Promise<Record<string, string | null>>;
|
|
@@ -2667,32 +2874,68 @@ type DataEditorBaseProps<TRow extends DataEditorRow = DataEditorRow> = {
|
|
|
2667
2874
|
* ```
|
|
2668
2875
|
*/
|
|
2669
2876
|
onValueMatch?: (valuesToMatch: Record<string, ValueMatchInput>) => ValueMatchOutput | Promise<ValueMatchOutput>;
|
|
2670
|
-
/**
|
|
2877
|
+
/**
|
|
2878
|
+
* Extra synonyms for column auto-matching. Keys are column IDs, values are
|
|
2879
|
+
* alternative names the matching engine should recognize.
|
|
2880
|
+
*
|
|
2881
|
+
* @example
|
|
2882
|
+
* ```ts
|
|
2883
|
+
* synonyms={{
|
|
2884
|
+
* productSku: ["sku", "article_no", "item_code"],
|
|
2885
|
+
* firstName: ["first", "given_name", "fname"],
|
|
2886
|
+
* }}
|
|
2887
|
+
* ```
|
|
2888
|
+
*/
|
|
2671
2889
|
synonyms?: Record<string, string[]>;
|
|
2672
|
-
/**
|
|
2890
|
+
/**
|
|
2891
|
+
* Sample rows included in the "Download Example" file. When the user clicks
|
|
2892
|
+
* "Download Example" in the import wizard, the SDK generates a template
|
|
2893
|
+
* file with column headers and these rows. When omitted, a generic example
|
|
2894
|
+
* row is auto-generated from column definitions.
|
|
2895
|
+
*/
|
|
2673
2896
|
sampleData?: Record<string, unknown>[];
|
|
2674
|
-
/**
|
|
2897
|
+
/**
|
|
2898
|
+
* Bring-your-own-AI chat. When provided, a chat panel is shown alongside
|
|
2899
|
+
* the grid. You own the AI integration; the SDK hands you dataset context
|
|
2900
|
+
* and renders the streamed response.
|
|
2901
|
+
*/
|
|
2675
2902
|
chat?: DataEditorChat<TRow>;
|
|
2676
2903
|
};
|
|
2677
2904
|
/**
|
|
2678
|
-
* Controls what the editor stores in `localStorage`.
|
|
2679
|
-
*
|
|
2905
|
+
* Controls what the editor stores in `localStorage`. Set to `false` to
|
|
2906
|
+
* disable all local storage usage.
|
|
2907
|
+
*
|
|
2908
|
+
* @default { licenseGrant: true }
|
|
2680
2909
|
*/
|
|
2681
2910
|
type DataEditorLocalStorage = false | {
|
|
2682
|
-
/**
|
|
2911
|
+
/**
|
|
2912
|
+
* Cache the license validation result to skip re-validation on reload.
|
|
2913
|
+
* @default true
|
|
2914
|
+
*/
|
|
2683
2915
|
licenseGrant?: boolean;
|
|
2684
2916
|
};
|
|
2685
|
-
/**
|
|
2917
|
+
/**
|
|
2918
|
+
* Rendering mode. `"modal"` wraps the editor in a full-screen dialog
|
|
2919
|
+
* overlay. `"inline"` renders it directly in the DOM.
|
|
2920
|
+
*/
|
|
2686
2921
|
type DataEditorMode = "modal" | "inline";
|
|
2687
2922
|
/** Shared props present in both modal and inline modes. */
|
|
2688
2923
|
type DataEditorCommonProps<TRow extends DataEditorRow = DataEditorRow> = DataEditorBaseProps<TRow> & {
|
|
2689
|
-
/** Your Updog license key.
|
|
2924
|
+
/** Your Updog license key. Validated on each open. */
|
|
2690
2925
|
apiKey: string;
|
|
2691
|
-
/**
|
|
2926
|
+
/**
|
|
2927
|
+
* Controls what the editor stores in `localStorage`. Set to `false` to
|
|
2928
|
+
* disable all local storage usage.
|
|
2929
|
+
* @default { licenseGrant: true }
|
|
2930
|
+
*/
|
|
2692
2931
|
localStorage?: DataEditorLocalStorage;
|
|
2693
|
-
/** CSS class added to the wrapper element. */
|
|
2932
|
+
/** CSS class added to the wrapper element. Use for scoped styling overrides. */
|
|
2694
2933
|
className?: string;
|
|
2695
|
-
/**
|
|
2934
|
+
/**
|
|
2935
|
+
* Called when the SDK catches an internal error. The SDK recovers
|
|
2936
|
+
* gracefully where possible — use this for your logging and monitoring
|
|
2937
|
+
* (Sentry, Datadog, etc.). Client mode only.
|
|
2938
|
+
*/
|
|
2696
2939
|
onError?: (error: UpdogError) => void;
|
|
2697
2940
|
};
|
|
2698
2941
|
/**
|
|
@@ -2702,9 +2945,16 @@ type DataEditorCommonProps<TRow extends DataEditorRow = DataEditorRow> = DataEdi
|
|
|
2702
2945
|
type DataEditorModalProps<TRow extends DataEditorRow = DataEditorRow> = DataEditorCommonProps<TRow> & {
|
|
2703
2946
|
/** Rendering mode. @default "modal" */
|
|
2704
2947
|
mode?: "modal";
|
|
2705
|
-
/**
|
|
2948
|
+
/**
|
|
2949
|
+
* Controls modal visibility. This is a controlled prop — you manage the
|
|
2950
|
+
* state. Required in modal mode.
|
|
2951
|
+
*/
|
|
2706
2952
|
open: boolean;
|
|
2707
|
-
/**
|
|
2953
|
+
/**
|
|
2954
|
+
* Called when the user closes the modal (X button or Escape key). If the
|
|
2955
|
+
* user has unsaved changes, the SDK shows a confirmation dialog before
|
|
2956
|
+
* calling `onClose`. Required in modal mode.
|
|
2957
|
+
*/
|
|
2708
2958
|
onClose: () => void;
|
|
2709
2959
|
};
|
|
2710
2960
|
/**
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@updog/data-editor",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.5",
|
|
4
4
|
"description": "Enterprise-grade spreadsheet editor SDK for React. Edit large datasets with validation, undo/redo, CSV/XLSX import, and multi-source merging.",
|
|
5
5
|
"author": "Mikhail Kutateladze <admin@updog.tech>",
|
|
6
6
|
"homepage": "https://updog.tech",
|