@cj-tech-master/excelts 4.2.3 → 5.0.0-canary.20260123012457.1fdf506

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.
Files changed (84) hide show
  1. package/dist/browser/modules/csv/csv-core.d.ts +0 -9
  2. package/dist/browser/modules/csv/csv.browser.js +3 -3
  3. package/dist/browser/modules/excel/column.d.ts +5 -0
  4. package/dist/browser/modules/excel/column.js +10 -2
  5. package/dist/browser/modules/excel/row.d.ts +2 -0
  6. package/dist/browser/modules/excel/row.js +3 -1
  7. package/dist/browser/modules/excel/utils/parse-sax.d.ts +0 -3
  8. package/dist/browser/modules/excel/utils/parse-sax.js +13 -32
  9. package/dist/browser/modules/excel/utils/passthrough-manager.d.ts +77 -0
  10. package/dist/browser/modules/excel/utils/passthrough-manager.js +129 -0
  11. package/dist/browser/modules/excel/workbook.d.ts +12 -0
  12. package/dist/browser/modules/excel/workbook.js +12 -1
  13. package/dist/browser/modules/excel/worksheet.d.ts +4 -0
  14. package/dist/browser/modules/excel/worksheet.js +4 -1
  15. package/dist/browser/modules/excel/xlsx/xform/base-xform.js +68 -1
  16. package/dist/browser/modules/excel/xlsx/xform/core/content-types-xform.js +16 -10
  17. package/dist/browser/modules/excel/xlsx/xform/pivot-table/pivot-table-xform.d.ts +35 -11
  18. package/dist/browser/modules/excel/xlsx/xform/pivot-table/pivot-table-xform.js +271 -94
  19. package/dist/browser/modules/excel/xlsx/xform/sheet/row-xform.d.ts +1 -0
  20. package/dist/browser/modules/excel/xlsx/xform/sheet/row-xform.js +7 -1
  21. package/dist/browser/modules/excel/xlsx/xform/sheet/sheet-format-properties-xform.d.ts +1 -0
  22. package/dist/browser/modules/excel/xlsx/xform/sheet/sheet-format-properties-xform.js +9 -4
  23. package/dist/browser/modules/excel/xlsx/xform/sheet/sheet-view-xform.js +4 -2
  24. package/dist/browser/modules/excel/xlsx/xform/sheet/worksheet-xform.js +40 -12
  25. package/dist/browser/modules/excel/xlsx/xform/style/style-xform.d.ts +7 -0
  26. package/dist/browser/modules/excel/xlsx/xform/style/style-xform.js +26 -6
  27. package/dist/browser/modules/excel/xlsx/xform/style/styles-xform.d.ts +6 -0
  28. package/dist/browser/modules/excel/xlsx/xform/style/styles-xform.js +52 -4
  29. package/dist/browser/modules/excel/xlsx/xlsx.browser.d.ts +36 -1
  30. package/dist/browser/modules/excel/xlsx/xlsx.browser.js +220 -131
  31. package/dist/browser/modules/stream/streams.browser.js +0 -3
  32. package/dist/cjs/modules/csv/csv.browser.js +3 -3
  33. package/dist/cjs/modules/excel/column.js +10 -2
  34. package/dist/cjs/modules/excel/row.js +3 -1
  35. package/dist/cjs/modules/excel/utils/parse-sax.js +13 -32
  36. package/dist/cjs/modules/excel/utils/passthrough-manager.js +133 -0
  37. package/dist/cjs/modules/excel/workbook.js +12 -1
  38. package/dist/cjs/modules/excel/worksheet.js +4 -1
  39. package/dist/cjs/modules/excel/xlsx/xform/base-xform.js +68 -1
  40. package/dist/cjs/modules/excel/xlsx/xform/core/content-types-xform.js +16 -10
  41. package/dist/cjs/modules/excel/xlsx/xform/pivot-table/pivot-table-xform.js +271 -94
  42. package/dist/cjs/modules/excel/xlsx/xform/sheet/row-xform.js +7 -1
  43. package/dist/cjs/modules/excel/xlsx/xform/sheet/sheet-format-properties-xform.js +9 -4
  44. package/dist/cjs/modules/excel/xlsx/xform/sheet/sheet-view-xform.js +4 -2
  45. package/dist/cjs/modules/excel/xlsx/xform/sheet/worksheet-xform.js +40 -12
  46. package/dist/cjs/modules/excel/xlsx/xform/style/style-xform.js +26 -6
  47. package/dist/cjs/modules/excel/xlsx/xform/style/styles-xform.js +52 -4
  48. package/dist/cjs/modules/excel/xlsx/xlsx.browser.js +220 -131
  49. package/dist/cjs/modules/stream/streams.browser.js +0 -3
  50. package/dist/esm/modules/csv/csv.browser.js +3 -3
  51. package/dist/esm/modules/excel/column.js +10 -2
  52. package/dist/esm/modules/excel/row.js +3 -1
  53. package/dist/esm/modules/excel/utils/parse-sax.js +13 -32
  54. package/dist/esm/modules/excel/utils/passthrough-manager.js +129 -0
  55. package/dist/esm/modules/excel/workbook.js +12 -1
  56. package/dist/esm/modules/excel/worksheet.js +4 -1
  57. package/dist/esm/modules/excel/xlsx/xform/base-xform.js +68 -1
  58. package/dist/esm/modules/excel/xlsx/xform/core/content-types-xform.js +16 -10
  59. package/dist/esm/modules/excel/xlsx/xform/pivot-table/pivot-table-xform.js +271 -94
  60. package/dist/esm/modules/excel/xlsx/xform/sheet/row-xform.js +7 -1
  61. package/dist/esm/modules/excel/xlsx/xform/sheet/sheet-format-properties-xform.js +9 -4
  62. package/dist/esm/modules/excel/xlsx/xform/sheet/sheet-view-xform.js +4 -2
  63. package/dist/esm/modules/excel/xlsx/xform/sheet/worksheet-xform.js +40 -12
  64. package/dist/esm/modules/excel/xlsx/xform/style/style-xform.js +26 -6
  65. package/dist/esm/modules/excel/xlsx/xform/style/styles-xform.js +52 -4
  66. package/dist/esm/modules/excel/xlsx/xlsx.browser.js +220 -131
  67. package/dist/esm/modules/stream/streams.browser.js +0 -3
  68. package/dist/iife/excelts.iife.js +1009 -650
  69. package/dist/iife/excelts.iife.js.map +1 -1
  70. package/dist/iife/excelts.iife.min.js +25 -52
  71. package/dist/types/modules/csv/csv-core.d.ts +0 -9
  72. package/dist/types/modules/excel/column.d.ts +5 -0
  73. package/dist/types/modules/excel/row.d.ts +2 -0
  74. package/dist/types/modules/excel/utils/parse-sax.d.ts +0 -3
  75. package/dist/types/modules/excel/utils/passthrough-manager.d.ts +77 -0
  76. package/dist/types/modules/excel/workbook.d.ts +12 -0
  77. package/dist/types/modules/excel/worksheet.d.ts +4 -0
  78. package/dist/types/modules/excel/xlsx/xform/pivot-table/pivot-table-xform.d.ts +35 -11
  79. package/dist/types/modules/excel/xlsx/xform/sheet/row-xform.d.ts +1 -0
  80. package/dist/types/modules/excel/xlsx/xform/sheet/sheet-format-properties-xform.d.ts +1 -0
  81. package/dist/types/modules/excel/xlsx/xform/style/style-xform.d.ts +7 -0
  82. package/dist/types/modules/excel/xlsx/xform/style/styles-xform.d.ts +6 -0
  83. package/dist/types/modules/excel/xlsx/xlsx.browser.d.ts +36 -1
  84. package/package.json +15 -15
@@ -58,15 +58,6 @@ export interface CsvParseOptions {
58
58
  renameHeaders?: boolean;
59
59
  /** Comment character - lines starting with this are ignored */
60
60
  comment?: string;
61
- /**
62
- * Decimal separator used when parsing numbers from CSV (default: ".").
63
- *
64
- * Note: core CSV parsing returns strings; number conversion is handled by higher-level
65
- * consumers (e.g. the default value mapper in the CSV module).
66
- *
67
- * @deprecated Use CsvReadOptions.valueMapperOptions.decimalSeparator instead.
68
- */
69
- decimalSeparator?: "." | ",";
70
61
  /** Maximum number of data rows to parse (excluding header) */
71
62
  maxRows?: number;
72
63
  /** Number of lines to skip at the beginning (before header detection) */
@@ -11,6 +11,8 @@ export interface ColumnDefn {
11
11
  outlineLevel?: number;
12
12
  hidden?: boolean;
13
13
  style?: Partial<Style>;
14
+ /** Whether the column width is auto-fitted to content */
15
+ bestFit?: boolean;
14
16
  }
15
17
  export interface ColumnModel {
16
18
  min: number;
@@ -21,6 +23,7 @@ export interface ColumnModel {
21
23
  hidden?: boolean;
22
24
  outlineLevel?: number;
23
25
  collapsed?: boolean;
26
+ bestFit?: boolean;
24
27
  }
25
28
  /**
26
29
  * Column defines the column properties for 1 column.
@@ -36,6 +39,8 @@ declare class Column {
36
39
  width?: number;
37
40
  private _hidden;
38
41
  private _outlineLevel;
42
+ /** Whether the column width is auto-fitted to content */
43
+ bestFit?: boolean;
39
44
  /** Styles applied to the column */
40
45
  style: Partial<Style>;
41
46
  constructor(worksheet: Worksheet, number: number, defn?: ColumnDefn | false);
@@ -15,6 +15,7 @@ export interface RowModel {
15
15
  hidden: boolean;
16
16
  outlineLevel: number;
17
17
  collapsed: boolean;
18
+ dyDescent?: number;
18
19
  }
19
20
  declare class Row {
20
21
  private _worksheet;
@@ -24,6 +25,7 @@ declare class Row {
24
25
  private _hidden?;
25
26
  private _outlineLevel?;
26
27
  height?: number;
28
+ dyDescent?: number;
27
29
  constructor(worksheet: Worksheet, number: number);
28
30
  /**
29
31
  * The row number
@@ -54,7 +54,6 @@ export declare class SaxesParser {
54
54
  private positionAtNewLine;
55
55
  private chunkPosition;
56
56
  ENTITIES: Record<string, string>;
57
- private nsPrefix;
58
57
  private textHandler?;
59
58
  private openTagHandler?;
60
59
  private closeTagHandler?;
@@ -63,7 +62,6 @@ export declare class SaxesParser {
63
62
  get closed(): boolean;
64
63
  get position(): number;
65
64
  private _init;
66
- private stripNsPrefix;
67
65
  on(name: "text", handler: TextHandler): void;
68
66
  on(name: "opentag", handler: OpenTagHandler): void;
69
67
  on(name: "closetag", handler: CloseTagHandler): void;
@@ -108,7 +106,6 @@ export declare class SaxesParser {
108
106
  private skipSpaces;
109
107
  private openTag;
110
108
  private openSelfClosingTag;
111
- private processAttributes;
112
109
  private closeTag;
113
110
  private end;
114
111
  }
@@ -0,0 +1,77 @@
1
+ /**
2
+ * PassthroughManager - Manages passthrough files for round-trip preservation
3
+ *
4
+ * This module handles files that are not fully parsed by the library but need to be
5
+ * preserved during read/write cycles (e.g., charts, sparklines, slicers).
6
+ */
7
+ /**
8
+ * Content type entry for ZIP content types
9
+ */
10
+ export interface PassthroughContentType {
11
+ partName: string;
12
+ contentType: string;
13
+ }
14
+ /**
15
+ * ZIP writer interface for passthrough files
16
+ */
17
+ export interface IPassthroughZipWriter {
18
+ append(data: Uint8Array, options: {
19
+ name: string;
20
+ }): void;
21
+ }
22
+ /**
23
+ * PassthroughManager handles storage and retrieval of passthrough files
24
+ * that need to be preserved during Excel read/write cycles.
25
+ */
26
+ export declare class PassthroughManager {
27
+ private files;
28
+ /**
29
+ * Check if a path should be treated as passthrough
30
+ */
31
+ static isPassthroughPath(path: string): boolean;
32
+ /**
33
+ * Get the content type for a passthrough file path
34
+ * @returns Content type string or undefined if unknown
35
+ */
36
+ static getContentType(path: string): string | undefined;
37
+ /**
38
+ * Add a file to passthrough storage
39
+ */
40
+ add(path: string, data: Uint8Array): void;
41
+ /**
42
+ * Get a file from passthrough storage
43
+ */
44
+ get(path: string): Uint8Array | undefined;
45
+ /**
46
+ * Check if a file exists in passthrough storage
47
+ */
48
+ has(path: string): boolean;
49
+ /**
50
+ * Get all stored paths
51
+ */
52
+ getPaths(): string[];
53
+ /**
54
+ * Get all files as a record (for serialization)
55
+ */
56
+ toRecord(): Record<string, Uint8Array>;
57
+ /**
58
+ * Load files from a record (for deserialization)
59
+ */
60
+ fromRecord(record: Record<string, Uint8Array>): void;
61
+ /**
62
+ * Get content types for all stored files that have known types
63
+ */
64
+ getContentTypes(): PassthroughContentType[];
65
+ /**
66
+ * Write all passthrough files to a ZIP writer
67
+ */
68
+ writeToZip(zip: IPassthroughZipWriter): void;
69
+ /**
70
+ * Clear all stored files
71
+ */
72
+ clear(): void;
73
+ /**
74
+ * Get the number of stored files
75
+ */
76
+ get size(): number;
77
+ }
@@ -55,6 +55,12 @@ export interface WorkbookModel {
55
55
  /** Loaded pivot tables from file - used during reconciliation */
56
56
  loadedPivotTables?: any[];
57
57
  calcProperties: Partial<CalculationProperties>;
58
+ /** Passthrough files (charts, etc.) preserved for round-trip */
59
+ passthrough?: Record<string, Uint8Array>;
60
+ /** Raw drawing XML data for passthrough (when drawing contains chart references) */
61
+ rawDrawings?: Record<string, Uint8Array>;
62
+ /** Default font preserved from the original file for round-trip fidelity */
63
+ defaultFont?: any;
58
64
  }
59
65
  declare class Workbook {
60
66
  /**
@@ -94,6 +100,12 @@ declare class Workbook {
94
100
  private _worksheets;
95
101
  private _definedNames;
96
102
  private _themes?;
103
+ /** Passthrough files (charts, etc.) preserved for round-trip */
104
+ private _passthrough;
105
+ /** Raw drawing XML data for passthrough (when drawing contains chart references) */
106
+ private _rawDrawings;
107
+ /** Default font preserved from original file for round-trip fidelity */
108
+ private _defaultFont?;
97
109
  private _xlsx?;
98
110
  private _csv?;
99
111
  constructor();
@@ -111,6 +111,8 @@ interface WorksheetModel {
111
111
  dimensions?: Range;
112
112
  merges?: string[];
113
113
  mergeCells?: string[];
114
+ /** Loaded drawing data (for charts, etc.) - preserved for round-trip */
115
+ drawing?: any;
114
116
  }
115
117
  declare class Worksheet {
116
118
  private _workbook;
@@ -139,6 +141,8 @@ declare class Worksheet {
139
141
  conditionalFormattings: ConditionalFormattingOptions[];
140
142
  formControls: FormCheckbox[];
141
143
  private _headerRowCount?;
144
+ /** Loaded drawing data (for charts, etc.) - preserved for round-trip */
145
+ private _drawing;
142
146
  constructor(options: WorksheetOptions);
143
147
  get name(): string;
144
148
  set name(name: string | undefined);
@@ -67,26 +67,46 @@ interface ParsedPivotTableModel {
67
67
  compact?: boolean;
68
68
  compactData?: boolean;
69
69
  multipleFieldFilters?: boolean;
70
- rowItems?: any[];
71
- colItems?: any[];
70
+ outline?: boolean;
71
+ outlineData?: boolean;
72
+ chartFormat?: number;
73
+ rowItems?: RowColItem[];
74
+ colItems?: RowColItem[];
75
+ hasColFields?: boolean;
76
+ chartFormats?: ChartFormatItem[];
72
77
  isLoaded?: boolean;
73
78
  extensions?: any[];
74
79
  }
80
+ /**
81
+ * Row or column item in pivot table
82
+ */
83
+ interface RowColItem {
84
+ t?: string;
85
+ x: Array<{
86
+ v: number;
87
+ }>;
88
+ }
89
+ /**
90
+ * Chart format item for pivot charts
91
+ */
92
+ interface ChartFormatItem {
93
+ chart: number;
94
+ format: number;
95
+ series?: boolean;
96
+ pivotAreaXml?: string;
97
+ }
75
98
  declare class PivotTableXform extends BaseXform {
76
99
  map: {
77
100
  [key: string]: any;
78
101
  };
79
102
  model: ParsedPivotTableModel | null;
80
- private inPivotFields;
81
- private inRowFields;
82
- private inColFields;
83
- private inDataFields;
84
- private inRowItems;
85
- private inColItems;
86
- private inLocation;
103
+ private state;
87
104
  private currentPivotField;
88
- private inItems;
89
- private inPivotTableStyleInfo;
105
+ private currentRowItem;
106
+ private currentColItem;
107
+ private currentChartFormat;
108
+ private pivotAreaXmlBuffer;
109
+ private pivotAreaDepth;
90
110
  constructor();
91
111
  prepare(_model: any): void;
92
112
  get tag(): string;
@@ -104,6 +124,10 @@ declare class PivotTableXform extends BaseXform {
104
124
  * Render loaded pivot table (preserving original structure)
105
125
  */
106
126
  private renderLoaded;
127
+ /**
128
+ * Render a row or column item element
129
+ */
130
+ private renderRowColItem;
107
131
  /**
108
132
  * Render a loaded pivot field
109
133
  */
@@ -14,6 +14,7 @@ interface RowModel {
14
14
  outlineLevel?: number;
15
15
  collapsed?: boolean;
16
16
  style?: any;
17
+ dyDescent?: number;
17
18
  }
18
19
  declare class RowXform extends BaseXform {
19
20
  private maxItems?;
@@ -5,6 +5,7 @@ interface SheetFormatPropertiesModel {
5
5
  outlineLevelRow: number;
6
6
  outlineLevelCol: number;
7
7
  defaultColWidth?: number;
8
+ customHeight?: boolean;
8
9
  }
9
10
  declare class SheetFormatPropertiesXform extends BaseXform {
10
11
  get tag(): string;
@@ -11,6 +11,13 @@ interface StyleModel {
11
11
  protection?: any;
12
12
  checkbox?: boolean;
13
13
  xfComplementIndex?: number;
14
+ pivotButton?: boolean;
15
+ applyNumberFormat?: boolean;
16
+ applyFont?: boolean;
17
+ applyFill?: boolean;
18
+ applyBorder?: boolean;
19
+ applyAlignment?: boolean;
20
+ applyProtection?: boolean;
14
21
  }
15
22
  interface StyleOptions {
16
23
  xfId?: boolean;
@@ -12,11 +12,17 @@ declare class StylesXform extends BaseXform {
12
12
  private index?;
13
13
  private weakMap?;
14
14
  private _hasCheckboxes?;
15
+ defaultFont?: any;
15
16
  parser: any;
16
17
  static Mock: typeof StylesXform;
17
18
  constructor(initialise?: boolean);
18
19
  initIndex(): void;
19
20
  init(): void;
21
+ /**
22
+ * Set the default font to use when no font is explicitly specified.
23
+ * This preserves the original file's default font during round-trip.
24
+ */
25
+ setDefaultFont(font: any): void;
20
26
  render(xmlStream: any, model?: StylesModel): void;
21
27
  parseOpen(node: any): boolean;
22
28
  parseText(text: string): void;
@@ -144,6 +144,30 @@ declare class XLSX {
144
144
  * This is the foundation for TRUE streaming reads on platforms that have a
145
145
  * streaming ZIP parser (e.g. Node.js `modules/archive` Parse).
146
146
  */
147
+ /**
148
+ * Create an empty model for parsing XLSX files.
149
+ * Shared by loadFromZipEntries and loadFromFiles.
150
+ */
151
+ private createEmptyModel;
152
+ /**
153
+ * Collect all data from a stream into a single Uint8Array.
154
+ * Reusable helper for passthrough and drawing processing.
155
+ */
156
+ protected collectStreamData(stream: IParseStream): Promise<Uint8Array>;
157
+ /**
158
+ * Check if a drawing has chart references in its relationships
159
+ */
160
+ private drawingHasChartReference;
161
+ /**
162
+ * Check if a drawing rels list references charts.
163
+ * Used to decide whether we need to keep raw drawing XML for passthrough.
164
+ */
165
+ private drawingRelsHasChartReference;
166
+ /**
167
+ * Process a known OOXML entry (workbook, styles, shared strings, etc.)
168
+ * Returns true if handled, false if should be passed to _processDefaultEntry
169
+ */
170
+ protected _processKnownEntry(stream: IParseStream, model: any, entryName: string, options?: XlsxOptions): Promise<boolean>;
147
171
  protected loadFromZipEntries(entries: AsyncIterable<ZipEntryLike>, options?: XlsxOptions): Promise<any>;
148
172
  /**
149
173
  * Write workbook to buffer
@@ -189,8 +213,14 @@ declare class XLSX {
189
213
  loadFromFiles(zipData: Record<string, Uint8Array>, options?: any): Promise<any>;
190
214
  /**
191
215
  * Process default entries (drawings, comments, tables, etc.)
216
+ * @param rawData Optional raw entry data for passthrough preservation (used by loadFromFiles)
192
217
  */
193
- protected _processDefaultEntry(stream: IParseStream, model: any, entryName: string): Promise<boolean>;
218
+ protected _processDefaultEntry(stream: IParseStream, model: any, entryName: string, rawData?: Uint8Array): Promise<boolean>;
219
+ /**
220
+ * Store a passthrough file for preservation during read/write cycles.
221
+ * These files are not parsed but stored as raw bytes to be written back unchanged.
222
+ */
223
+ _processPassthroughEntry(stream: IParseStream, model: any, entryName: string): Promise<void>;
194
224
  addContentTypes(zip: IZipWriter, model: any): Promise<void>;
195
225
  addApp(zip: IZipWriter, model: any): Promise<void>;
196
226
  addCore(zip: IZipWriter, model: any): Promise<void>;
@@ -204,6 +234,11 @@ declare class XLSX {
204
234
  addWorksheets(zip: IZipWriter, model: any): Promise<void>;
205
235
  addDrawings(zip: IZipWriter, model: any): void;
206
236
  addTables(zip: IZipWriter, model: any): void;
237
+ /**
238
+ * Write passthrough files (charts, etc.) that were preserved during read.
239
+ * These files are written back unchanged to preserve unsupported features.
240
+ */
241
+ addPassthrough(zip: IZipWriter, model: any): void;
207
242
  addPivotTables(zip: IZipWriter, model: any): void;
208
243
  _finalize(zip: IZipWriter): Promise<this>;
209
244
  prepareModel(model: any, options: any): void;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cj-tech-master/excelts",
3
- "version": "4.2.3",
3
+ "version": "5.0.0-canary.20260123012457.1fdf506",
4
4
  "description": "TypeScript Excel Workbook Manager - Read and Write xlsx and csv Files.",
5
5
  "type": "module",
6
6
  "publishConfig": {
@@ -90,37 +90,37 @@
90
90
  ],
91
91
  "devDependencies": {
92
92
  "@eslint/js": "^9.39.2",
93
- "@types/node": "^25.0.6",
94
- "@typescript-eslint/eslint-plugin": "^8.52.0",
95
- "@typescript-eslint/parser": "^8.52.0",
96
- "@typescript/native-preview": "^7.0.0-dev.20260112.1",
97
- "@vitest/browser": "^4.0.17",
98
- "@vitest/browser-playwright": "^4.0.17",
99
- "@vitest/ui": "^4.0.17",
93
+ "@types/node": "^25.0.10",
94
+ "@typescript-eslint/eslint-plugin": "^8.53.1",
95
+ "@typescript-eslint/parser": "^8.53.1",
96
+ "@typescript/native-preview": "^7.0.0-dev.20260122.4",
97
+ "@vitest/browser": "^4.0.18",
98
+ "@vitest/browser-playwright": "^4.0.18",
99
+ "@vitest/ui": "^4.0.18",
100
100
  "concurrently": "^9.2.1",
101
101
  "cross-env": "^10.1.0",
102
102
  "eslint": "^9.39.2",
103
103
  "eslint-config-prettier": "^10.1.8",
104
104
  "eslint-import-resolver-typescript": "^4.4.4",
105
105
  "eslint-plugin-import-x": "^4.16.1",
106
- "eslint-plugin-oxlint": "^1.39.0",
106
+ "eslint-plugin-oxlint": "^1.41.0",
107
107
  "eslint-plugin-unused-imports": "^4.3.0",
108
108
  "husky": "^9.1.7",
109
- "oxlint": "^1.39.0",
109
+ "oxlint": "^1.41.0",
110
110
  "playwright": "^1.57.0",
111
- "prettier": "^3.7.4",
111
+ "prettier": "^3.8.1",
112
112
  "rimraf": "^6.1.2",
113
- "rolldown": "^1.0.0-beta.59",
113
+ "rolldown": "^1.0.0-rc.1",
114
114
  "rollup-plugin-visualizer": "^6.0.5",
115
115
  "typescript": "^5.9.3",
116
- "typescript-eslint": "^8.52.0",
116
+ "typescript-eslint": "^8.53.1",
117
117
  "vite-tsconfig-paths": "^6.0.4",
118
- "vitest": "^4.0.17"
118
+ "vitest": "^4.0.18"
119
119
  },
120
120
  "scripts": {
121
121
  "example": "node scripts/run-examples.ts",
122
122
  "check": "concurrently --raw \"npm run type\" \"npm run lint\"",
123
- "test": "vitest run && npm run test:browser",
123
+ "test": "vitest run && npm run test:browser --",
124
124
  "test:browser": "rimraf dist && npm run build:browser:bundle && vitest run --config vitest.browser.config.ts",
125
125
  "test:watch": "vitest",
126
126
  "build": "rimraf dist && concurrently \"npm run build:esm\" \"npm run build:cjs\" \"npm run build:browser\" \"npm run build:browser:bundle\" && npm run build:verify",