microsoft-graph 2.19.1 → 2.20.1

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 (37) hide show
  1. package/dist/cjs/services/batch.d.ts +8 -0
  2. package/dist/cjs/services/batch.d.ts.map +1 -0
  3. package/dist/cjs/services/batch.js +10 -0
  4. package/dist/cjs/services/cellText.d.ts +6 -0
  5. package/dist/cjs/services/cellText.d.ts.map +1 -0
  6. package/dist/cjs/services/cellText.js +9 -0
  7. package/dist/cjs/tasks/iterateWorkbookRange.d.ts +1 -0
  8. package/dist/cjs/tasks/iterateWorkbookRange.d.ts.map +1 -1
  9. package/dist/cjs/tasks/iterateWorkbookRange.js +3 -8
  10. package/dist/cjs/tasks/iterateWorkbookRangeValues.d.ts +1 -1
  11. package/dist/cjs/tasks/iterateWorkbookRangeValues.d.ts.map +1 -1
  12. package/dist/cjs/tasks/iterateWorkbookRangeValues.js +3 -9
  13. package/dist/cjs/tasks/readWorkbookRows.d.ts +11 -0
  14. package/dist/cjs/tasks/readWorkbookRows.d.ts.map +1 -0
  15. package/dist/cjs/tasks/readWorkbookRows.js +57 -0
  16. package/dist/cjs/tasks/writeWorkbookRows.d.ts +10 -0
  17. package/dist/cjs/tasks/writeWorkbookRows.d.ts.map +1 -0
  18. package/dist/cjs/tasks/writeWorkbookRows.js +59 -0
  19. package/dist/esm/services/batch.d.ts +8 -0
  20. package/dist/esm/services/batch.d.ts.map +1 -0
  21. package/dist/esm/services/batch.js +7 -0
  22. package/dist/esm/services/cellText.d.ts +6 -0
  23. package/dist/esm/services/cellText.d.ts.map +1 -0
  24. package/dist/esm/services/cellText.js +6 -0
  25. package/dist/esm/tasks/iterateWorkbookRange.d.ts +1 -0
  26. package/dist/esm/tasks/iterateWorkbookRange.d.ts.map +1 -1
  27. package/dist/esm/tasks/iterateWorkbookRange.js +2 -7
  28. package/dist/esm/tasks/iterateWorkbookRangeValues.d.ts +1 -1
  29. package/dist/esm/tasks/iterateWorkbookRangeValues.d.ts.map +1 -1
  30. package/dist/esm/tasks/iterateWorkbookRangeValues.js +2 -8
  31. package/dist/esm/tasks/readWorkbookRows.d.ts +11 -0
  32. package/dist/esm/tasks/readWorkbookRows.d.ts.map +1 -0
  33. package/dist/esm/tasks/readWorkbookRows.js +51 -0
  34. package/dist/esm/tasks/writeWorkbookRows.d.ts +10 -0
  35. package/dist/esm/tasks/writeWorkbookRows.d.ts.map +1 -0
  36. package/dist/esm/tasks/writeWorkbookRows.js +53 -0
  37. package/package.json +101 -1
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Maximum number of cells that can be retrieved in a single request, unless overwritten.
3
+ * @remarks The Microsoft Graph API documentation does not specify a fixed maximum number of cells that can be retrieved in a single request.
4
+ * However, it mentions that large ranges may result in errors due to resource constraints. Additionally, discussions in developer
5
+ * communities suggest that requests exceeding 10,000 cells may encounter issues.
6
+ */
7
+ export declare const maxCellsPerRequest = 10000;
8
+ //# sourceMappingURL=batch.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"batch.d.ts","sourceRoot":"","sources":["../../../src/services/batch.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,eAAO,MAAM,kBAAkB,QAAQ,CAAC"}
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.maxCellsPerRequest = void 0;
4
+ /**
5
+ * Maximum number of cells that can be retrieved in a single request, unless overwritten.
6
+ * @remarks The Microsoft Graph API documentation does not specify a fixed maximum number of cells that can be retrieved in a single request.
7
+ * However, it mentions that large ranges may result in errors due to resource constraints. Additionally, discussions in developer
8
+ * communities suggest that requests exceeding 10,000 cells may encounter issues.
9
+ */
10
+ exports.maxCellsPerRequest = 10000;
@@ -0,0 +1,6 @@
1
+ import type { CellText } from "../models/CellText.ts";
2
+ /**
3
+ * Casts a string to CellText.
4
+ */
5
+ export declare function asCellText(text: string): CellText;
6
+ //# sourceMappingURL=cellText.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cellText.d.ts","sourceRoot":"","sources":["../../../src/services/cellText.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAEtD;;GAEG;AACH,wBAAgB,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,QAAQ,CAEjD"}
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.asCellText = asCellText;
4
+ /**
5
+ * Casts a string to CellText.
6
+ */
7
+ function asCellText(text) {
8
+ return text;
9
+ }
@@ -7,6 +7,7 @@ import type { WorkbookRangeRef } from "../models/WorkbookRangeRef.ts";
7
7
  * @param rangeRef - A reference to the workbook range to iterate over.
8
8
  * @param overwriteRowsPerRequest - Optional. The number of rows to fetch per request. If omitted, it is automatically calculated.
9
9
  * @returns An async iterable that yields rows of range values.
10
+ * @deprecated Use `readWorkbookRows` instead.
10
11
  */
11
12
  export default function iterateWorkbookRange(rangeRef: WorkbookRangeRef, overwriteRowsPerRequest?: number | null): AsyncIterable<{
12
13
  rowOffset: RowOffset;
@@ -1 +1 @@
1
- {"version":3,"file":"iterateWorkbookRange.d.ts","sourceRoot":"","sources":["../../../src/tasks/iterateWorkbookRange.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AActE;;;;;;GAMG;AACH,wBAA+B,oBAAoB,CAAC,QAAQ,EAAE,gBAAgB,EAAE,uBAAuB,GAAE,MAAM,GAAG,IAAW,GAAG,aAAa,CAAC;IAAE,SAAS,EAAE,SAAS,CAAC;IAAC,GAAG,EAAE,GAAG,CAAA;CAAE,CAAC,CAsDhL"}
1
+ {"version":3,"file":"iterateWorkbookRange.d.ts","sourceRoot":"","sources":["../../../src/tasks/iterateWorkbookRange.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAOtE;;;;;;;GAOG;AACH,wBAA+B,oBAAoB,CAAC,QAAQ,EAAE,gBAAgB,EAAE,uBAAuB,GAAE,MAAM,GAAG,IAAW,GAAG,aAAa,CAAC;IAAE,SAAS,EAAE,SAAS,CAAC;IAAC,GAAG,EAAE,GAAG,CAAA;CAAE,CAAC,CAsDhL"}
@@ -8,20 +8,15 @@ const InvalidArgumentError_ts_1 = __importDefault(require("../errors/InvalidArgu
8
8
  const getWorkbookWorksheetRange_ts_1 = __importDefault(require("../operations/workbookRange/getWorkbookWorksheetRange.js"));
9
9
  const addressManipulation_ts_1 = require("../services/addressManipulation.js");
10
10
  const addressOffset_ts_1 = require("../services/addressOffset.js");
11
+ const batch_ts_1 = require("../services/batch.js");
11
12
  const workbookRange_ts_1 = require("../services/workbookRange.js");
12
- /**
13
- * Maximum number of cells that can be retrieved in a single request, unless overwritten.
14
- * @remarks The Microsoft Graph API documentation does not specify a fixed maximum number of cells that can be retrieved in a single request.
15
- * However, it mentions that large ranges may result in errors due to resource constraints. Additionally, discussions in developer
16
- * communities suggest that requests exceeding 10,000 cells may encounter issues.
17
- */
18
- const maxCellsPerRequest = 10_000;
19
13
  /**
20
14
  * Iterates over the values of a workbook range in chunks, fetching data in manageable sizes.
21
15
  *
22
16
  * @param rangeRef - A reference to the workbook range to iterate over.
23
17
  * @param overwriteRowsPerRequest - Optional. The number of rows to fetch per request. If omitted, it is automatically calculated.
24
18
  * @returns An async iterable that yields rows of range values.
19
+ * @deprecated Use `readWorkbookRows` instead.
25
20
  */
26
21
  async function* iterateWorkbookRange(rangeRef, overwriteRowsPerRequest = null) {
27
22
  const address = rangeRef.address;
@@ -31,7 +26,7 @@ async function* iterateWorkbookRange(rangeRef, overwriteRowsPerRequest = null) {
31
26
  throw new InvalidArgumentError_ts_1.default("overwriteRowsPerRequest must be greater than 0");
32
27
  }
33
28
  const columnCount = (0, addressManipulation_ts_1.countAddressColumns)(address);
34
- const rowsPerRequest = overwriteRowsPerRequest ?? Math.floor(maxCellsPerRequest / columnsPerRow);
29
+ const rowsPerRequest = overwriteRowsPerRequest ?? Math.floor(batch_ts_1.maxCellsPerRequest / columnsPerRow);
35
30
  const rangeStartRowOffset = (0, addressOffset_ts_1.rowAddressToOffset)(components.startRow);
36
31
  const rangeEndRowOffset = (0, addressOffset_ts_1.rowAddressToOffset)(components.endRow);
37
32
  let offset = 0;
@@ -6,7 +6,7 @@ import type { WorkbookRangeRef } from "../models/WorkbookRangeRef.ts";
6
6
  * @param rangeRef - A reference to the workbook range to iterate over.
7
7
  * @param overwriteRowsPerRequest - Optional. The number of rows to fetch per request. If omitted, it is automatically calculated.
8
8
  * @returns An async iterable that yields rows of range values.
9
- * @deprecated Use `iterateWorkbookRange` instead.
9
+ * @deprecated Use `readWorkbookRows` instead.
10
10
  */
11
11
  export default function iterateWorkbookRangeValues(rangeRef: WorkbookRangeRef, overwriteRowsPerRequest?: number | null): AsyncIterable<CellValue[]>;
12
12
  //# sourceMappingURL=iterateWorkbookRangeValues.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"iterateWorkbookRangeValues.d.ts","sourceRoot":"","sources":["../../../src/tasks/iterateWorkbookRangeValues.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAExD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AActE;;;;;;;GAOG;AACH,wBAA+B,0BAA0B,CAAC,QAAQ,EAAE,gBAAgB,EAAE,uBAAuB,GAAE,MAAM,GAAG,IAAW,GAAG,aAAa,CAAC,SAAS,EAAE,CAAC,CAoC/J"}
1
+ {"version":3,"file":"iterateWorkbookRangeValues.d.ts","sourceRoot":"","sources":["../../../src/tasks/iterateWorkbookRangeValues.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAExD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAOtE;;;;;;;GAOG;AACH,wBAA+B,0BAA0B,CAAC,QAAQ,EAAE,gBAAgB,EAAE,uBAAuB,GAAE,MAAM,GAAG,IAAW,GAAG,aAAa,CAAC,SAAS,EAAE,CAAC,CAoC/J"}
@@ -8,21 +8,15 @@ const InvalidArgumentError_ts_1 = __importDefault(require("../errors/InvalidArgu
8
8
  const getWorkbookWorksheetRange_ts_1 = __importDefault(require("../operations/workbookRange/getWorkbookWorksheetRange.js"));
9
9
  const addressManipulation_ts_1 = require("../services/addressManipulation.js");
10
10
  const addressOffset_ts_1 = require("../services/addressOffset.js");
11
+ const batch_ts_1 = require("../services/batch.js");
11
12
  const workbookRange_ts_1 = require("../services/workbookRange.js");
12
- /**
13
- * Maximum number of cells that can be retrieved in a single request, unless overwritten.
14
- * @remarks The Microsoft Graph API documentation does not specify a fixed maximum number of cells that can be retrieved in a single request.
15
- * However, it mentions that large ranges may result in errors due to resource constraints. Additionally, discussions in developer
16
- * communities suggest that requests exceeding 10,000 cells may encounter issues.
17
- */
18
- const maxCellsPerRequest = 10_000;
19
13
  /**
20
14
  * Iterates over the values of a workbook range in chunks, fetching data in manageable sizes.
21
15
  *
22
16
  * @param rangeRef - A reference to the workbook range to iterate over.
23
17
  * @param overwriteRowsPerRequest - Optional. The number of rows to fetch per request. If omitted, it is automatically calculated.
24
18
  * @returns An async iterable that yields rows of range values.
25
- * @deprecated Use `iterateWorkbookRange` instead.
19
+ * @deprecated Use `readWorkbookRows` instead.
26
20
  */
27
21
  async function* iterateWorkbookRangeValues(rangeRef, overwriteRowsPerRequest = null) {
28
22
  const address = rangeRef.address;
@@ -31,7 +25,7 @@ async function* iterateWorkbookRangeValues(rangeRef, overwriteRowsPerRequest = n
31
25
  if (overwriteRowsPerRequest !== null && overwriteRowsPerRequest < 1) {
32
26
  throw new InvalidArgumentError_ts_1.default("overwriteRowsPerRequest must be greater than 0");
33
27
  }
34
- const rowsPerRequest = overwriteRowsPerRequest ?? Math.floor(maxCellsPerRequest / columnsPerRow);
28
+ const rowsPerRequest = overwriteRowsPerRequest ?? Math.floor(batch_ts_1.maxCellsPerRequest / columnsPerRow);
35
29
  const rangeStartRowOffset = (0, addressOffset_ts_1.rowAddressToOffset)(components.startRow);
36
30
  const rangeEndRowOffset = (0, addressOffset_ts_1.rowAddressToOffset)(components.endRow);
37
31
  for (let chunkRowOffset = rangeStartRowOffset; chunkRowOffset <= rangeEndRowOffset; chunkRowOffset = (chunkRowOffset + rowsPerRequest)) {
@@ -0,0 +1,11 @@
1
+ import type { Row } from "../models/Row.ts";
2
+ import type { WorkbookRangeRef } from "../models/WorkbookRangeRef.ts";
3
+ /**
4
+ * Iterates over the values of a workbook range in chunks, fetching data in manageable sizes.
5
+ *
6
+ * @param rangeRef - A reference to the workbook range to iterate over.
7
+ * @param overwriteMaxRowsPerChunk - Optional. The number of rows to fetch per request. If omitted, it is automatically calculated.
8
+ * @returns An async iterable that yields rows of range values.
9
+ */
10
+ export default function readWorkbookRows(rangeRef: WorkbookRangeRef, overwriteMaxRowsPerChunk?: number | null): AsyncIterable<Row>;
11
+ //# sourceMappingURL=readWorkbookRows.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"readWorkbookRows.d.ts","sourceRoot":"","sources":["../../../src/tasks/readWorkbookRows.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAC;AAE5C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAOtE;;;;;;GAMG;AACH,wBAA+B,gBAAgB,CAAC,QAAQ,EAAE,gBAAgB,EAAE,wBAAwB,GAAE,MAAM,GAAG,IAAW,GAAG,aAAa,CAAC,GAAG,CAAC,CA+C9I"}
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.default = readWorkbookRows;
7
+ const InvalidArgumentError_ts_1 = __importDefault(require("../errors/InvalidArgumentError.js"));
8
+ const getWorkbookWorksheetRange_ts_1 = __importDefault(require("../operations/workbookRange/getWorkbookWorksheetRange.js"));
9
+ const addressManipulation_ts_1 = require("../services/addressManipulation.js");
10
+ const addressOffset_ts_1 = require("../services/addressOffset.js");
11
+ const workbookRange_ts_1 = require("../services/workbookRange.js");
12
+ const batch_ts_1 = require("../services/batch.js");
13
+ /**
14
+ * Iterates over the values of a workbook range in chunks, fetching data in manageable sizes.
15
+ *
16
+ * @param rangeRef - A reference to the workbook range to iterate over.
17
+ * @param overwriteMaxRowsPerChunk - Optional. The number of rows to fetch per request. If omitted, it is automatically calculated.
18
+ * @returns An async iterable that yields rows of range values.
19
+ */
20
+ async function* readWorkbookRows(rangeRef, overwriteMaxRowsPerChunk = null) {
21
+ const address = rangeRef.address;
22
+ const components = (0, addressManipulation_ts_1.decomposeAddress)(address);
23
+ const columnsPerRow = (0, addressOffset_ts_1.columnAddressToOffset)(components.endColumn) - (0, addressOffset_ts_1.columnAddressToOffset)(components.startColumn) + 1;
24
+ if (overwriteMaxRowsPerChunk !== null && overwriteMaxRowsPerChunk < 1) {
25
+ throw new InvalidArgumentError_ts_1.default("overwriteRowsPerRequest must be greater than 0");
26
+ }
27
+ const columnCount = (0, addressManipulation_ts_1.countAddressColumns)(address);
28
+ const rowsPerRequest = overwriteMaxRowsPerChunk ?? Math.floor(batch_ts_1.maxCellsPerRequest / columnsPerRow);
29
+ const rangeStartRowOffset = (0, addressOffset_ts_1.rowAddressToOffset)(components.startRow);
30
+ const rangeEndRowOffset = (0, addressOffset_ts_1.rowAddressToOffset)(components.endRow);
31
+ for (let chunkRowOffset = rangeStartRowOffset; chunkRowOffset <= rangeEndRowOffset; chunkRowOffset = (chunkRowOffset + rowsPerRequest)) {
32
+ const requestStartRowOffset = chunkRowOffset;
33
+ const requestEndRowOffset = Math.min(chunkRowOffset + rowsPerRequest - 1, rangeEndRowOffset);
34
+ const chunkStartRow = (0, addressOffset_ts_1.rowOffsetToAddress)(requestStartRowOffset);
35
+ const chunkEndRow = (0, addressOffset_ts_1.rowOffsetToAddress)(requestEndRowOffset);
36
+ const requestAddress = (0, addressManipulation_ts_1.composeAddress)({
37
+ startRow: chunkStartRow,
38
+ endRow: chunkEndRow,
39
+ startColumn: components.startColumn,
40
+ endColumn: components.endColumn,
41
+ });
42
+ const requestRef = (0, workbookRange_ts_1.createWorkbookRangeRef)(rangeRef, requestAddress);
43
+ const range = await (0, getWorkbookWorksheetRange_ts_1.default)(requestRef);
44
+ const values = range.values;
45
+ const text = range.text;
46
+ const numberFormat = range.numberFormat;
47
+ const rowCount = values.length;
48
+ for (let r = 0; r < rowCount; r++) {
49
+ const row = Array.from({ length: columnCount }, (_, c) => ({
50
+ text: text[r]?.[c] ?? "",
51
+ value: values[r]?.[c] ?? "",
52
+ numberFormat: numberFormat?.[r]?.[c] ?? "",
53
+ }));
54
+ yield row;
55
+ }
56
+ }
57
+ }
@@ -0,0 +1,10 @@
1
+ import type { Cell } from "../models/Cell.ts";
2
+ import type { WorkbookRangeRef } from "../models/WorkbookRangeRef.ts";
3
+ /**
4
+ * Write rows to a workbook range. Uses batching to handle large datasets efficiently.
5
+ * @param originRef The reference to the workbook range where rows will be written. Only the upper-left is used as an origin point.
6
+ * @param rows An iterable or async iterable of rows to write. Each row is an array of cells.
7
+ * @param overrideMaxRowsPerUnderlyingRead Optional maximum number of rows to write in a single underlying read. If not provided, it will be automatically calculated based on a safe value.
8
+ */
9
+ export default function writeWorkbookRows(originRef: WorkbookRangeRef, rows: Iterable<Partial<Cell>[]> | AsyncIterable<Partial<Cell>[]>, overrideMaxRowsPerUnderlyingRead?: number | null): Promise<void>;
10
+ //# sourceMappingURL=writeWorkbookRows.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"writeWorkbookRows.d.ts","sourceRoot":"","sources":["../../../src/tasks/writeWorkbookRows.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAC;AAE9C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAMtE;;;;;GAKG;AACH,wBAA8B,iBAAiB,CAAC,SAAS,EAAE,gBAAgB,EAAE,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,gCAAgC,GAAE,MAAM,GAAG,IAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAuBpN"}
@@ -0,0 +1,59 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.default = writeWorkbookRows;
7
+ const InvalidArgumentError_ts_1 = __importDefault(require("../errors/InvalidArgumentError.js"));
8
+ const updateWorkbookRange_ts_1 = __importDefault(require("../operations/workbookRange/updateWorkbookRange.js"));
9
+ const batch_ts_1 = require("../services/batch.js");
10
+ const cartesianAddress_ts_1 = require("../services/cartesianAddress.js");
11
+ const workbookRange_ts_1 = require("../services/workbookRange.js");
12
+ /**
13
+ * Write rows to a workbook range. Uses batching to handle large datasets efficiently.
14
+ * @param originRef The reference to the workbook range where rows will be written. Only the upper-left is used as an origin point.
15
+ * @param rows An iterable or async iterable of rows to write. Each row is an array of cells.
16
+ * @param overrideMaxRowsPerUnderlyingRead Optional maximum number of rows to write in a single underlying read. If not provided, it will be automatically calculated based on a safe value.
17
+ */
18
+ async function writeWorkbookRows(originRef, rows, overrideMaxRowsPerUnderlyingRead = null) {
19
+ let maxRowsPerUnderlyingRead = overrideMaxRowsPerUnderlyingRead;
20
+ let cellsPerRow = null;
21
+ let rowsCompleted = 0;
22
+ const batch = [];
23
+ for await (const row of rows) {
24
+ if (cellsPerRow === null) {
25
+ cellsPerRow = row.length;
26
+ }
27
+ else if (cellsPerRow !== row.length) {
28
+ throw new InvalidArgumentError_ts_1.default("Not all rows have the same number of cells. Ensure all rows are consistent in length.");
29
+ }
30
+ if (maxRowsPerUnderlyingRead === null) {
31
+ maxRowsPerUnderlyingRead = Math.max(1, Math.floor(batch_ts_1.maxCellsPerRequest / cellsPerRow)); // Excel supports up to 16k columns, which exceeds the assumed 10k cell limit per write. This might not be a problem, but not worth spending time checking this currently either.
32
+ }
33
+ if (batch.push(row) >= maxRowsPerUnderlyingRead) {
34
+ rowsCompleted += await flushBatch(batch, originRef, rowsCompleted);
35
+ }
36
+ }
37
+ await flushBatch(batch, originRef, rowsCompleted);
38
+ }
39
+ async function flushBatch(batch, originRef, rowsCompleted) {
40
+ if (batch.length === 0) {
41
+ return 0;
42
+ }
43
+ const { ay, ax, bx } = (0, cartesianAddress_ts_1.addressToCartesian)(originRef.address);
44
+ const count = batch.length;
45
+ const address = (0, cartesianAddress_ts_1.cartesianToAddress)({
46
+ ay: (rowsCompleted + ay),
47
+ by: (rowsCompleted + ay + count - 1),
48
+ ax,
49
+ bx,
50
+ });
51
+ const rangeRef = (0, workbookRange_ts_1.createWorkbookRangeRef)(originRef, address);
52
+ await (0, updateWorkbookRange_ts_1.default)(rangeRef, {
53
+ values: batch.map((r) => r.map((c) => c.value)),
54
+ text: batch.map((r) => r.map((c) => c.text)),
55
+ numberFormat: batch.map((r) => r.map((c) => c.numberFormat)),
56
+ });
57
+ batch.length = 0;
58
+ return count;
59
+ }
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Maximum number of cells that can be retrieved in a single request, unless overwritten.
3
+ * @remarks The Microsoft Graph API documentation does not specify a fixed maximum number of cells that can be retrieved in a single request.
4
+ * However, it mentions that large ranges may result in errors due to resource constraints. Additionally, discussions in developer
5
+ * communities suggest that requests exceeding 10,000 cells may encounter issues.
6
+ */
7
+ export declare const maxCellsPerRequest = 10000;
8
+ //# sourceMappingURL=batch.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"batch.d.ts","sourceRoot":"","sources":["../../../src/services/batch.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,eAAO,MAAM,kBAAkB,QAAQ,CAAC"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Maximum number of cells that can be retrieved in a single request, unless overwritten.
3
+ * @remarks The Microsoft Graph API documentation does not specify a fixed maximum number of cells that can be retrieved in a single request.
4
+ * However, it mentions that large ranges may result in errors due to resource constraints. Additionally, discussions in developer
5
+ * communities suggest that requests exceeding 10,000 cells may encounter issues.
6
+ */
7
+ export const maxCellsPerRequest = 10000;
@@ -0,0 +1,6 @@
1
+ import type { CellText } from "../models/CellText.ts";
2
+ /**
3
+ * Casts a string to CellText.
4
+ */
5
+ export declare function asCellText(text: string): CellText;
6
+ //# sourceMappingURL=cellText.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cellText.d.ts","sourceRoot":"","sources":["../../../src/services/cellText.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAEtD;;GAEG;AACH,wBAAgB,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,QAAQ,CAEjD"}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Casts a string to CellText.
3
+ */
4
+ export function asCellText(text) {
5
+ return text;
6
+ }
@@ -7,6 +7,7 @@ import type { WorkbookRangeRef } from "../models/WorkbookRangeRef.ts";
7
7
  * @param rangeRef - A reference to the workbook range to iterate over.
8
8
  * @param overwriteRowsPerRequest - Optional. The number of rows to fetch per request. If omitted, it is automatically calculated.
9
9
  * @returns An async iterable that yields rows of range values.
10
+ * @deprecated Use `readWorkbookRows` instead.
10
11
  */
11
12
  export default function iterateWorkbookRange(rangeRef: WorkbookRangeRef, overwriteRowsPerRequest?: number | null): AsyncIterable<{
12
13
  rowOffset: RowOffset;
@@ -1 +1 @@
1
- {"version":3,"file":"iterateWorkbookRange.d.ts","sourceRoot":"","sources":["../../../src/tasks/iterateWorkbookRange.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AActE;;;;;;GAMG;AACH,wBAA+B,oBAAoB,CAAC,QAAQ,EAAE,gBAAgB,EAAE,uBAAuB,GAAE,MAAM,GAAG,IAAW,GAAG,aAAa,CAAC;IAAE,SAAS,EAAE,SAAS,CAAC;IAAC,GAAG,EAAE,GAAG,CAAA;CAAE,CAAC,CAsDhL"}
1
+ {"version":3,"file":"iterateWorkbookRange.d.ts","sourceRoot":"","sources":["../../../src/tasks/iterateWorkbookRange.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAOtE;;;;;;;GAOG;AACH,wBAA+B,oBAAoB,CAAC,QAAQ,EAAE,gBAAgB,EAAE,uBAAuB,GAAE,MAAM,GAAG,IAAW,GAAG,aAAa,CAAC;IAAE,SAAS,EAAE,SAAS,CAAC;IAAC,GAAG,EAAE,GAAG,CAAA;CAAE,CAAC,CAsDhL"}
@@ -2,20 +2,15 @@ import InvalidArgumentError from "../errors/InvalidArgumentError.js";
2
2
  import getWorkbookWorksheetRange from "../operations/workbookRange/getWorkbookWorksheetRange.js";
3
3
  import { composeAddress, countAddressColumns, decomposeAddress } from "../services/addressManipulation.js";
4
4
  import { columnAddressToOffset, rowAddressToOffset, rowOffsetToAddress } from "../services/addressOffset.js";
5
+ import { maxCellsPerRequest } from "../services/batch.js";
5
6
  import { createWorkbookRangeRef } from "../services/workbookRange.js";
6
- /**
7
- * Maximum number of cells that can be retrieved in a single request, unless overwritten.
8
- * @remarks The Microsoft Graph API documentation does not specify a fixed maximum number of cells that can be retrieved in a single request.
9
- * However, it mentions that large ranges may result in errors due to resource constraints. Additionally, discussions in developer
10
- * communities suggest that requests exceeding 10,000 cells may encounter issues.
11
- */
12
- const maxCellsPerRequest = 10_000;
13
7
  /**
14
8
  * Iterates over the values of a workbook range in chunks, fetching data in manageable sizes.
15
9
  *
16
10
  * @param rangeRef - A reference to the workbook range to iterate over.
17
11
  * @param overwriteRowsPerRequest - Optional. The number of rows to fetch per request. If omitted, it is automatically calculated.
18
12
  * @returns An async iterable that yields rows of range values.
13
+ * @deprecated Use `readWorkbookRows` instead.
19
14
  */
20
15
  export default async function* iterateWorkbookRange(rangeRef, overwriteRowsPerRequest = null) {
21
16
  const address = rangeRef.address;
@@ -6,7 +6,7 @@ import type { WorkbookRangeRef } from "../models/WorkbookRangeRef.ts";
6
6
  * @param rangeRef - A reference to the workbook range to iterate over.
7
7
  * @param overwriteRowsPerRequest - Optional. The number of rows to fetch per request. If omitted, it is automatically calculated.
8
8
  * @returns An async iterable that yields rows of range values.
9
- * @deprecated Use `iterateWorkbookRange` instead.
9
+ * @deprecated Use `readWorkbookRows` instead.
10
10
  */
11
11
  export default function iterateWorkbookRangeValues(rangeRef: WorkbookRangeRef, overwriteRowsPerRequest?: number | null): AsyncIterable<CellValue[]>;
12
12
  //# sourceMappingURL=iterateWorkbookRangeValues.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"iterateWorkbookRangeValues.d.ts","sourceRoot":"","sources":["../../../src/tasks/iterateWorkbookRangeValues.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAExD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AActE;;;;;;;GAOG;AACH,wBAA+B,0BAA0B,CAAC,QAAQ,EAAE,gBAAgB,EAAE,uBAAuB,GAAE,MAAM,GAAG,IAAW,GAAG,aAAa,CAAC,SAAS,EAAE,CAAC,CAoC/J"}
1
+ {"version":3,"file":"iterateWorkbookRangeValues.d.ts","sourceRoot":"","sources":["../../../src/tasks/iterateWorkbookRangeValues.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAExD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAOtE;;;;;;;GAOG;AACH,wBAA+B,0BAA0B,CAAC,QAAQ,EAAE,gBAAgB,EAAE,uBAAuB,GAAE,MAAM,GAAG,IAAW,GAAG,aAAa,CAAC,SAAS,EAAE,CAAC,CAoC/J"}
@@ -2,21 +2,15 @@ import InvalidArgumentError from "../errors/InvalidArgumentError.js";
2
2
  import getWorkbookWorksheetRange from "../operations/workbookRange/getWorkbookWorksheetRange.js";
3
3
  import { composeAddress, decomposeAddress } from "../services/addressManipulation.js";
4
4
  import { columnAddressToOffset, rowAddressToOffset, rowOffsetToAddress } from "../services/addressOffset.js";
5
+ import { maxCellsPerRequest } from "../services/batch.js";
5
6
  import { createWorkbookRangeRef } from "../services/workbookRange.js";
6
- /**
7
- * Maximum number of cells that can be retrieved in a single request, unless overwritten.
8
- * @remarks The Microsoft Graph API documentation does not specify a fixed maximum number of cells that can be retrieved in a single request.
9
- * However, it mentions that large ranges may result in errors due to resource constraints. Additionally, discussions in developer
10
- * communities suggest that requests exceeding 10,000 cells may encounter issues.
11
- */
12
- const maxCellsPerRequest = 10_000;
13
7
  /**
14
8
  * Iterates over the values of a workbook range in chunks, fetching data in manageable sizes.
15
9
  *
16
10
  * @param rangeRef - A reference to the workbook range to iterate over.
17
11
  * @param overwriteRowsPerRequest - Optional. The number of rows to fetch per request. If omitted, it is automatically calculated.
18
12
  * @returns An async iterable that yields rows of range values.
19
- * @deprecated Use `iterateWorkbookRange` instead.
13
+ * @deprecated Use `readWorkbookRows` instead.
20
14
  */
21
15
  export default async function* iterateWorkbookRangeValues(rangeRef, overwriteRowsPerRequest = null) {
22
16
  const address = rangeRef.address;
@@ -0,0 +1,11 @@
1
+ import type { Row } from "../models/Row.ts";
2
+ import type { WorkbookRangeRef } from "../models/WorkbookRangeRef.ts";
3
+ /**
4
+ * Iterates over the values of a workbook range in chunks, fetching data in manageable sizes.
5
+ *
6
+ * @param rangeRef - A reference to the workbook range to iterate over.
7
+ * @param overwriteMaxRowsPerChunk - Optional. The number of rows to fetch per request. If omitted, it is automatically calculated.
8
+ * @returns An async iterable that yields rows of range values.
9
+ */
10
+ export default function readWorkbookRows(rangeRef: WorkbookRangeRef, overwriteMaxRowsPerChunk?: number | null): AsyncIterable<Row>;
11
+ //# sourceMappingURL=readWorkbookRows.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"readWorkbookRows.d.ts","sourceRoot":"","sources":["../../../src/tasks/readWorkbookRows.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAC;AAE5C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAOtE;;;;;;GAMG;AACH,wBAA+B,gBAAgB,CAAC,QAAQ,EAAE,gBAAgB,EAAE,wBAAwB,GAAE,MAAM,GAAG,IAAW,GAAG,aAAa,CAAC,GAAG,CAAC,CA+C9I"}
@@ -0,0 +1,51 @@
1
+ import InvalidArgumentError from "../errors/InvalidArgumentError.js";
2
+ import getWorkbookWorksheetRange from "../operations/workbookRange/getWorkbookWorksheetRange.js";
3
+ import { composeAddress, countAddressColumns, decomposeAddress } from "../services/addressManipulation.js";
4
+ import { columnAddressToOffset, rowAddressToOffset, rowOffsetToAddress } from "../services/addressOffset.js";
5
+ import { createWorkbookRangeRef } from "../services/workbookRange.js";
6
+ import { maxCellsPerRequest } from "../services/batch.js";
7
+ /**
8
+ * Iterates over the values of a workbook range in chunks, fetching data in manageable sizes.
9
+ *
10
+ * @param rangeRef - A reference to the workbook range to iterate over.
11
+ * @param overwriteMaxRowsPerChunk - Optional. The number of rows to fetch per request. If omitted, it is automatically calculated.
12
+ * @returns An async iterable that yields rows of range values.
13
+ */
14
+ export default async function* readWorkbookRows(rangeRef, overwriteMaxRowsPerChunk = null) {
15
+ const address = rangeRef.address;
16
+ const components = decomposeAddress(address);
17
+ const columnsPerRow = columnAddressToOffset(components.endColumn) - columnAddressToOffset(components.startColumn) + 1;
18
+ if (overwriteMaxRowsPerChunk !== null && overwriteMaxRowsPerChunk < 1) {
19
+ throw new InvalidArgumentError("overwriteRowsPerRequest must be greater than 0");
20
+ }
21
+ const columnCount = countAddressColumns(address);
22
+ const rowsPerRequest = overwriteMaxRowsPerChunk ?? Math.floor(maxCellsPerRequest / columnsPerRow);
23
+ const rangeStartRowOffset = rowAddressToOffset(components.startRow);
24
+ const rangeEndRowOffset = rowAddressToOffset(components.endRow);
25
+ for (let chunkRowOffset = rangeStartRowOffset; chunkRowOffset <= rangeEndRowOffset; chunkRowOffset = (chunkRowOffset + rowsPerRequest)) {
26
+ const requestStartRowOffset = chunkRowOffset;
27
+ const requestEndRowOffset = Math.min(chunkRowOffset + rowsPerRequest - 1, rangeEndRowOffset);
28
+ const chunkStartRow = rowOffsetToAddress(requestStartRowOffset);
29
+ const chunkEndRow = rowOffsetToAddress(requestEndRowOffset);
30
+ const requestAddress = composeAddress({
31
+ startRow: chunkStartRow,
32
+ endRow: chunkEndRow,
33
+ startColumn: components.startColumn,
34
+ endColumn: components.endColumn,
35
+ });
36
+ const requestRef = createWorkbookRangeRef(rangeRef, requestAddress);
37
+ const range = await getWorkbookWorksheetRange(requestRef);
38
+ const values = range.values;
39
+ const text = range.text;
40
+ const numberFormat = range.numberFormat;
41
+ const rowCount = values.length;
42
+ for (let r = 0; r < rowCount; r++) {
43
+ const row = Array.from({ length: columnCount }, (_, c) => ({
44
+ text: text[r]?.[c] ?? "",
45
+ value: values[r]?.[c] ?? "",
46
+ numberFormat: numberFormat?.[r]?.[c] ?? "",
47
+ }));
48
+ yield row;
49
+ }
50
+ }
51
+ }
@@ -0,0 +1,10 @@
1
+ import type { Cell } from "../models/Cell.ts";
2
+ import type { WorkbookRangeRef } from "../models/WorkbookRangeRef.ts";
3
+ /**
4
+ * Write rows to a workbook range. Uses batching to handle large datasets efficiently.
5
+ * @param originRef The reference to the workbook range where rows will be written. Only the upper-left is used as an origin point.
6
+ * @param rows An iterable or async iterable of rows to write. Each row is an array of cells.
7
+ * @param overrideMaxRowsPerUnderlyingRead Optional maximum number of rows to write in a single underlying read. If not provided, it will be automatically calculated based on a safe value.
8
+ */
9
+ export default function writeWorkbookRows(originRef: WorkbookRangeRef, rows: Iterable<Partial<Cell>[]> | AsyncIterable<Partial<Cell>[]>, overrideMaxRowsPerUnderlyingRead?: number | null): Promise<void>;
10
+ //# sourceMappingURL=writeWorkbookRows.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"writeWorkbookRows.d.ts","sourceRoot":"","sources":["../../../src/tasks/writeWorkbookRows.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAC;AAE9C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAMtE;;;;;GAKG;AACH,wBAA8B,iBAAiB,CAAC,SAAS,EAAE,gBAAgB,EAAE,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,gCAAgC,GAAE,MAAM,GAAG,IAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAuBpN"}
@@ -0,0 +1,53 @@
1
+ import InvalidArgumentError from "../errors/InvalidArgumentError.js";
2
+ import updateWorkbookRange from "../operations/workbookRange/updateWorkbookRange.js";
3
+ import { maxCellsPerRequest } from "../services/batch.js";
4
+ import { addressToCartesian, cartesianToAddress } from "../services/cartesianAddress.js";
5
+ import { createWorkbookRangeRef } from "../services/workbookRange.js";
6
+ /**
7
+ * Write rows to a workbook range. Uses batching to handle large datasets efficiently.
8
+ * @param originRef The reference to the workbook range where rows will be written. Only the upper-left is used as an origin point.
9
+ * @param rows An iterable or async iterable of rows to write. Each row is an array of cells.
10
+ * @param overrideMaxRowsPerUnderlyingRead Optional maximum number of rows to write in a single underlying read. If not provided, it will be automatically calculated based on a safe value.
11
+ */
12
+ export default async function writeWorkbookRows(originRef, rows, overrideMaxRowsPerUnderlyingRead = null) {
13
+ let maxRowsPerUnderlyingRead = overrideMaxRowsPerUnderlyingRead;
14
+ let cellsPerRow = null;
15
+ let rowsCompleted = 0;
16
+ const batch = [];
17
+ for await (const row of rows) {
18
+ if (cellsPerRow === null) {
19
+ cellsPerRow = row.length;
20
+ }
21
+ else if (cellsPerRow !== row.length) {
22
+ throw new InvalidArgumentError("Not all rows have the same number of cells. Ensure all rows are consistent in length.");
23
+ }
24
+ if (maxRowsPerUnderlyingRead === null) {
25
+ maxRowsPerUnderlyingRead = Math.max(1, Math.floor(maxCellsPerRequest / cellsPerRow)); // Excel supports up to 16k columns, which exceeds the assumed 10k cell limit per write. This might not be a problem, but not worth spending time checking this currently either.
26
+ }
27
+ if (batch.push(row) >= maxRowsPerUnderlyingRead) {
28
+ rowsCompleted += await flushBatch(batch, originRef, rowsCompleted);
29
+ }
30
+ }
31
+ await flushBatch(batch, originRef, rowsCompleted);
32
+ }
33
+ async function flushBatch(batch, originRef, rowsCompleted) {
34
+ if (batch.length === 0) {
35
+ return 0;
36
+ }
37
+ const { ay, ax, bx } = addressToCartesian(originRef.address);
38
+ const count = batch.length;
39
+ const address = cartesianToAddress({
40
+ ay: (rowsCompleted + ay),
41
+ by: (rowsCompleted + ay + count - 1),
42
+ ax,
43
+ bx,
44
+ });
45
+ const rangeRef = createWorkbookRangeRef(originRef, address);
46
+ await updateWorkbookRange(rangeRef, {
47
+ values: batch.map((r) => r.map((c) => c.value)),
48
+ text: batch.map((r) => r.map((c) => c.text)),
49
+ numberFormat: batch.map((r) => r.map((c) => c.numberFormat)),
50
+ });
51
+ batch.length = 0;
52
+ return count;
53
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "microsoft-graph",
3
- "version": "2.19.1",
3
+ "version": "2.20.1",
4
4
  "description": "Microsoft GraphAPI SDK for NodeJS",
5
5
  "main": "./dist/cjs/index.js",
6
6
  "module": "./dist/esm/index.js",
@@ -3119,6 +3119,31 @@
3119
3119
  "require": "./dist/cjs/services/addressOffset.js",
3120
3120
  "types": "./dist/esm/services/addressOffset.d.ts"
3121
3121
  },
3122
+ "./batch": {
3123
+ "import": "./dist/esm/services/batch.js",
3124
+ "require": "./dist/cjs/services/batch.js",
3125
+ "types": "./dist/esm/services/batch.d.ts"
3126
+ },
3127
+ "./dist/cjs/services/batch.js": {
3128
+ "import": "./dist/esm/services/batch.js",
3129
+ "require": "./dist/cjs/services/batch.js",
3130
+ "types": "./dist/esm/services/batch.d.ts"
3131
+ },
3132
+ "./dist/cjs/services/batch": {
3133
+ "import": "./dist/esm/services/batch.js",
3134
+ "require": "./dist/cjs/services/batch.js",
3135
+ "types": "./dist/esm/services/batch.d.ts"
3136
+ },
3137
+ "./services/batch": {
3138
+ "import": "./dist/esm/services/batch.js",
3139
+ "require": "./dist/cjs/services/batch.js",
3140
+ "types": "./dist/esm/services/batch.d.ts"
3141
+ },
3142
+ "./services/batch.js": {
3143
+ "import": "./dist/esm/services/batch.js",
3144
+ "require": "./dist/cjs/services/batch.js",
3145
+ "types": "./dist/esm/services/batch.d.ts"
3146
+ },
3122
3147
  "./cartesianAddress": {
3123
3148
  "import": "./dist/esm/services/cartesianAddress.js",
3124
3149
  "require": "./dist/cjs/services/cartesianAddress.js",
@@ -3144,6 +3169,31 @@
3144
3169
  "require": "./dist/cjs/services/cartesianAddress.js",
3145
3170
  "types": "./dist/esm/services/cartesianAddress.d.ts"
3146
3171
  },
3172
+ "./cellText": {
3173
+ "import": "./dist/esm/services/cellText.js",
3174
+ "require": "./dist/cjs/services/cellText.js",
3175
+ "types": "./dist/esm/services/cellText.d.ts"
3176
+ },
3177
+ "./dist/cjs/services/cellText.js": {
3178
+ "import": "./dist/esm/services/cellText.js",
3179
+ "require": "./dist/cjs/services/cellText.js",
3180
+ "types": "./dist/esm/services/cellText.d.ts"
3181
+ },
3182
+ "./dist/cjs/services/cellText": {
3183
+ "import": "./dist/esm/services/cellText.js",
3184
+ "require": "./dist/cjs/services/cellText.js",
3185
+ "types": "./dist/esm/services/cellText.d.ts"
3186
+ },
3187
+ "./services/cellText": {
3188
+ "import": "./dist/esm/services/cellText.js",
3189
+ "require": "./dist/cjs/services/cellText.js",
3190
+ "types": "./dist/esm/services/cellText.d.ts"
3191
+ },
3192
+ "./services/cellText.js": {
3193
+ "import": "./dist/esm/services/cellText.js",
3194
+ "require": "./dist/cjs/services/cellText.js",
3195
+ "types": "./dist/esm/services/cellText.d.ts"
3196
+ },
3147
3197
  "./context": {
3148
3198
  "import": "./dist/esm/services/context.js",
3149
3199
  "require": "./dist/cjs/services/context.js",
@@ -3919,6 +3969,31 @@
3919
3969
  "require": "./dist/cjs/tasks/listDriveItems.js",
3920
3970
  "types": "./dist/esm/tasks/listDriveItems.d.ts"
3921
3971
  },
3972
+ "./readWorkbookRows": {
3973
+ "import": "./dist/esm/tasks/readWorkbookRows.js",
3974
+ "require": "./dist/cjs/tasks/readWorkbookRows.js",
3975
+ "types": "./dist/esm/tasks/readWorkbookRows.d.ts"
3976
+ },
3977
+ "./dist/cjs/tasks/readWorkbookRows.js": {
3978
+ "import": "./dist/esm/tasks/readWorkbookRows.js",
3979
+ "require": "./dist/cjs/tasks/readWorkbookRows.js",
3980
+ "types": "./dist/esm/tasks/readWorkbookRows.d.ts"
3981
+ },
3982
+ "./dist/cjs/tasks/readWorkbookRows": {
3983
+ "import": "./dist/esm/tasks/readWorkbookRows.js",
3984
+ "require": "./dist/cjs/tasks/readWorkbookRows.js",
3985
+ "types": "./dist/esm/tasks/readWorkbookRows.d.ts"
3986
+ },
3987
+ "./tasks/readWorkbookRows": {
3988
+ "import": "./dist/esm/tasks/readWorkbookRows.js",
3989
+ "require": "./dist/cjs/tasks/readWorkbookRows.js",
3990
+ "types": "./dist/esm/tasks/readWorkbookRows.d.ts"
3991
+ },
3992
+ "./tasks/readWorkbookRows.js": {
3993
+ "import": "./dist/esm/tasks/readWorkbookRows.js",
3994
+ "require": "./dist/cjs/tasks/readWorkbookRows.js",
3995
+ "types": "./dist/esm/tasks/readWorkbookRows.d.ts"
3996
+ },
3922
3997
  "./safeDeleteWorkbook": {
3923
3998
  "import": "./dist/esm/tasks/safeDeleteWorkbook.js",
3924
3999
  "require": "./dist/cjs/tasks/safeDeleteWorkbook.js",
@@ -4093,6 +4168,31 @@
4093
4168
  "import": "./dist/esm/tasks/tryDeleteDriveItem.js",
4094
4169
  "require": "./dist/cjs/tasks/tryDeleteDriveItem.js",
4095
4170
  "types": "./dist/esm/tasks/tryDeleteDriveItem.d.ts"
4171
+ },
4172
+ "./writeWorkbookRows": {
4173
+ "import": "./dist/esm/tasks/writeWorkbookRows.js",
4174
+ "require": "./dist/cjs/tasks/writeWorkbookRows.js",
4175
+ "types": "./dist/esm/tasks/writeWorkbookRows.d.ts"
4176
+ },
4177
+ "./dist/cjs/tasks/writeWorkbookRows.js": {
4178
+ "import": "./dist/esm/tasks/writeWorkbookRows.js",
4179
+ "require": "./dist/cjs/tasks/writeWorkbookRows.js",
4180
+ "types": "./dist/esm/tasks/writeWorkbookRows.d.ts"
4181
+ },
4182
+ "./dist/cjs/tasks/writeWorkbookRows": {
4183
+ "import": "./dist/esm/tasks/writeWorkbookRows.js",
4184
+ "require": "./dist/cjs/tasks/writeWorkbookRows.js",
4185
+ "types": "./dist/esm/tasks/writeWorkbookRows.d.ts"
4186
+ },
4187
+ "./tasks/writeWorkbookRows": {
4188
+ "import": "./dist/esm/tasks/writeWorkbookRows.js",
4189
+ "require": "./dist/cjs/tasks/writeWorkbookRows.js",
4190
+ "types": "./dist/esm/tasks/writeWorkbookRows.d.ts"
4191
+ },
4192
+ "./tasks/writeWorkbookRows.js": {
4193
+ "import": "./dist/esm/tasks/writeWorkbookRows.js",
4194
+ "require": "./dist/cjs/tasks/writeWorkbookRows.js",
4195
+ "types": "./dist/esm/tasks/writeWorkbookRows.d.ts"
4096
4196
  }
4097
4197
  }
4098
4198
  }