@lab1095/n8n-nodes-sharepoint-excel 0.1.1 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/credentials/MicrosoftGraphOAuth2Api.credentials.d.ts +3 -2
- package/dist/credentials/MicrosoftGraphOAuth2Api.credentials.js +9 -33
- package/dist/credentials/MicrosoftGraphOAuth2Api.credentials.js.map +1 -1
- package/dist/nodes/SharePointExcel/SharePointExcel.node.d.ts +4 -0
- package/dist/nodes/SharePointExcel/SharePointExcel.node.js +4 -0
- package/dist/nodes/SharePointExcel/SharePointExcel.node.js.map +1 -1
- package/dist/nodes/SharePointExcel/actions/router.js +12 -5
- package/dist/nodes/SharePointExcel/actions/router.js.map +1 -1
- package/dist/nodes/SharePointExcel/actions/sheet/appendRows.js +52 -29
- package/dist/nodes/SharePointExcel/actions/sheet/appendRows.js.map +1 -1
- package/dist/nodes/SharePointExcel/actions/sheet/appendRows.test.d.ts +1 -0
- package/dist/nodes/SharePointExcel/actions/sheet/appendRows.test.js +437 -0
- package/dist/nodes/SharePointExcel/actions/sheet/appendRows.test.js.map +1 -0
- package/dist/nodes/SharePointExcel/actions/sheet/clearSheet.js +2 -2
- package/dist/nodes/SharePointExcel/actions/sheet/clearSheet.js.map +1 -1
- package/dist/nodes/SharePointExcel/actions/sheet/clearSheet.test.d.ts +1 -0
- package/dist/nodes/SharePointExcel/actions/sheet/clearSheet.test.js +182 -0
- package/dist/nodes/SharePointExcel/actions/sheet/clearSheet.test.js.map +1 -0
- package/dist/nodes/SharePointExcel/actions/sheet/readRows.js +75 -20
- package/dist/nodes/SharePointExcel/actions/sheet/readRows.js.map +1 -1
- package/dist/nodes/SharePointExcel/actions/sheet/readRows.test.d.ts +1 -0
- package/dist/nodes/SharePointExcel/actions/sheet/readRows.test.js +251 -0
- package/dist/nodes/SharePointExcel/actions/sheet/readRows.test.js.map +1 -0
- package/dist/nodes/SharePointExcel/actions/sheet/upsertRows.js +100 -55
- package/dist/nodes/SharePointExcel/actions/sheet/upsertRows.js.map +1 -1
- package/dist/nodes/SharePointExcel/actions/table/getRows.js +69 -13
- package/dist/nodes/SharePointExcel/actions/table/getRows.js.map +1 -1
- package/dist/nodes/SharePointExcel/actions/table/getRows.test.d.ts +1 -0
- package/dist/nodes/SharePointExcel/actions/table/getRows.test.js +228 -0
- package/dist/nodes/SharePointExcel/actions/table/getRows.test.js.map +1 -0
- package/dist/nodes/SharePointExcel/actions/workbook/getWorkbooks.test.d.ts +1 -0
- package/dist/nodes/SharePointExcel/actions/workbook/getWorkbooks.test.js +151 -0
- package/dist/nodes/SharePointExcel/actions/workbook/getWorkbooks.test.js.map +1 -0
- package/dist/nodes/SharePointExcel/descriptions.d.ts +7 -0
- package/dist/nodes/SharePointExcel/descriptions.js +198 -13
- package/dist/nodes/SharePointExcel/descriptions.js.map +1 -1
- package/dist/nodes/SharePointExcel/listSearch.js +20 -5
- package/dist/nodes/SharePointExcel/listSearch.js.map +1 -1
- package/dist/nodes/SharePointExcel/listSearch.test.d.ts +1 -0
- package/dist/nodes/SharePointExcel/listSearch.test.js +302 -0
- package/dist/nodes/SharePointExcel/listSearch.test.js.map +1 -0
- package/dist/nodes/SharePointExcel/resourceMapping.d.ts +2 -0
- package/dist/nodes/SharePointExcel/resourceMapping.js +118 -0
- package/dist/nodes/SharePointExcel/resourceMapping.js.map +1 -0
- package/dist/nodes/SharePointExcel/test-utils/mocks.d.ts +114 -0
- package/dist/nodes/SharePointExcel/test-utils/mocks.js +116 -0
- package/dist/nodes/SharePointExcel/test-utils/mocks.js.map +1 -0
- package/dist/nodes/SharePointExcel/types.d.ts +25 -2
- package/dist/package.json +7 -3
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +7 -3
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import type { ICredentialType, INodeProperties } from 'n8n-workflow';
|
|
1
|
+
import type { ICredentialTestRequest, ICredentialType, INodeProperties, Icon } from 'n8n-workflow';
|
|
2
2
|
export declare class MicrosoftGraphOAuth2Api implements ICredentialType {
|
|
3
3
|
name: string;
|
|
4
4
|
extends: string[];
|
|
5
5
|
displayName: string;
|
|
6
6
|
documentationUrl: string;
|
|
7
|
-
icon:
|
|
7
|
+
icon: Icon;
|
|
8
8
|
properties: INodeProperties[];
|
|
9
|
+
test: ICredentialTestRequest;
|
|
9
10
|
}
|
|
@@ -4,48 +4,24 @@ exports.MicrosoftGraphOAuth2Api = void 0;
|
|
|
4
4
|
class MicrosoftGraphOAuth2Api {
|
|
5
5
|
constructor() {
|
|
6
6
|
this.name = 'microsoftGraphOAuth2Api';
|
|
7
|
-
this.extends = ['
|
|
7
|
+
this.extends = ['microsoftOAuth2Api'];
|
|
8
8
|
this.displayName = 'Microsoft Graph OAuth2 API';
|
|
9
|
-
this.documentationUrl = 'https://
|
|
9
|
+
this.documentationUrl = 'https://learn.microsoft.com/en-us/graph/auth-v2-user';
|
|
10
10
|
this.icon = 'file:icons/Microsoft.svg';
|
|
11
11
|
this.properties = [
|
|
12
|
-
{
|
|
13
|
-
displayName: 'Grant Type',
|
|
14
|
-
name: 'grantType',
|
|
15
|
-
type: 'hidden',
|
|
16
|
-
default: 'authorizationCode',
|
|
17
|
-
},
|
|
18
|
-
{
|
|
19
|
-
displayName: 'Authorization URL',
|
|
20
|
-
name: 'authUrl',
|
|
21
|
-
type: 'hidden',
|
|
22
|
-
default: 'https://login.microsoftonline.com/common/oauth2/v2.0/authorize',
|
|
23
|
-
},
|
|
24
|
-
{
|
|
25
|
-
displayName: 'Access Token URL',
|
|
26
|
-
name: 'accessTokenUrl',
|
|
27
|
-
type: 'hidden',
|
|
28
|
-
default: 'https://login.microsoftonline.com/common/oauth2/v2.0/token',
|
|
29
|
-
},
|
|
30
12
|
{
|
|
31
13
|
displayName: 'Scope',
|
|
32
14
|
name: 'scope',
|
|
33
15
|
type: 'hidden',
|
|
34
|
-
default: 'openid offline_access Sites.ReadWrite.All Files.ReadWrite.All',
|
|
35
|
-
},
|
|
36
|
-
{
|
|
37
|
-
displayName: 'Auth URI Query Parameters',
|
|
38
|
-
name: 'authQueryParameters',
|
|
39
|
-
type: 'hidden',
|
|
40
|
-
default: 'response_mode=query',
|
|
41
|
-
},
|
|
42
|
-
{
|
|
43
|
-
displayName: 'Authentication',
|
|
44
|
-
name: 'authentication',
|
|
45
|
-
type: 'hidden',
|
|
46
|
-
default: 'body',
|
|
16
|
+
default: 'openid offline_access Sites.Read.All Sites.ReadWrite.All Files.Read.All Files.ReadWrite.All',
|
|
47
17
|
},
|
|
48
18
|
];
|
|
19
|
+
this.test = {
|
|
20
|
+
request: {
|
|
21
|
+
baseURL: 'https://graph.microsoft.com/v1.0',
|
|
22
|
+
url: '/sites?search=*&$top=1',
|
|
23
|
+
},
|
|
24
|
+
};
|
|
49
25
|
}
|
|
50
26
|
}
|
|
51
27
|
exports.MicrosoftGraphOAuth2Api = MicrosoftGraphOAuth2Api;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MicrosoftGraphOAuth2Api.credentials.js","sourceRoot":"","sources":["../../credentials/MicrosoftGraphOAuth2Api.credentials.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"MicrosoftGraphOAuth2Api.credentials.js","sourceRoot":"","sources":["../../credentials/MicrosoftGraphOAuth2Api.credentials.ts"],"names":[],"mappings":";;;AAOA,MAAa,uBAAuB;IAApC;QACC,SAAI,GAAG,yBAAyB,CAAC;QAEjC,YAAO,GAAG,CAAC,oBAAoB,CAAC,CAAC;QAEjC,gBAAW,GAAG,4BAA4B,CAAC;QAE3C,qBAAgB,GACf,sDAAsD,CAAC;QAExD,SAAI,GAAS,0BAA0B,CAAC;QAExC,eAAU,GAAsB;YAC/B;gBACC,WAAW,EAAE,OAAO;gBACpB,IAAI,EAAE,OAAO;gBACb,IAAI,EAAE,QAAQ;gBACd,OAAO,EACN,6FAA6F;aAC9F;SACD,CAAC;QAEF,SAAI,GAA2B;YAC9B,OAAO,EAAE;gBACR,OAAO,EAAE,kCAAkC;gBAC3C,GAAG,EAAE,wBAAwB;aAC7B;SACD,CAAC;IACH,CAAC;CAAA;AA5BD,0DA4BC"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import type { IExecuteFunctions, INodeExecutionData, INodeType, INodeTypeDescription } from 'n8n-workflow';
|
|
2
2
|
import { searchSites, getDrives, getFiles, getSheets, getTables } from './listSearch';
|
|
3
|
+
import { getMappingColumns } from './resourceMapping';
|
|
3
4
|
export declare class SharePointExcel implements INodeType {
|
|
4
5
|
description: INodeTypeDescription;
|
|
5
6
|
methods: {
|
|
@@ -10,6 +11,9 @@ export declare class SharePointExcel implements INodeType {
|
|
|
10
11
|
getSheets: typeof getSheets;
|
|
11
12
|
getTables: typeof getTables;
|
|
12
13
|
};
|
|
14
|
+
resourceMapping: {
|
|
15
|
+
getMappingColumns: typeof getMappingColumns;
|
|
16
|
+
};
|
|
13
17
|
};
|
|
14
18
|
execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]>;
|
|
15
19
|
}
|
|
@@ -5,6 +5,7 @@ const n8n_workflow_1 = require("n8n-workflow");
|
|
|
5
5
|
const router_1 = require("./actions/router");
|
|
6
6
|
const descriptions_1 = require("./descriptions");
|
|
7
7
|
const listSearch_1 = require("./listSearch");
|
|
8
|
+
const resourceMapping_1 = require("./resourceMapping");
|
|
8
9
|
class SharePointExcel {
|
|
9
10
|
constructor() {
|
|
10
11
|
this.description = {
|
|
@@ -37,6 +38,9 @@ class SharePointExcel {
|
|
|
37
38
|
getSheets: listSearch_1.getSheets,
|
|
38
39
|
getTables: listSearch_1.getTables,
|
|
39
40
|
},
|
|
41
|
+
resourceMapping: {
|
|
42
|
+
getMappingColumns: resourceMapping_1.getMappingColumns,
|
|
43
|
+
},
|
|
40
44
|
};
|
|
41
45
|
}
|
|
42
46
|
async execute() {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SharePointExcel.node.js","sourceRoot":"","sources":["../../../nodes/SharePointExcel/SharePointExcel.node.ts"],"names":[],"mappings":";;;AAMA,+CAAuE;AACvE,6CAA0C;AAC1C,iDAA4C;AAC5C,6CAMsB;
|
|
1
|
+
{"version":3,"file":"SharePointExcel.node.js","sourceRoot":"","sources":["../../../nodes/SharePointExcel/SharePointExcel.node.ts"],"names":[],"mappings":";;;AAMA,+CAAuE;AACvE,6CAA0C;AAC1C,iDAA4C;AAC5C,6CAMsB;AACtB,uDAAsD;AAEtD,MAAa,eAAe;IAA5B;QACC,gBAAW,GAAyB;YACnC,WAAW,EAAE,4BAA4B;YACzC,IAAI,EAAE,iBAAiB;YACvB,IAAI,EAAE,gBAAgB;YACtB,KAAK,EAAE,CAAC,WAAW,CAAC;YACpB,OAAO,EAAE,CAAC;YACV,QAAQ,EAAE,8DAA8D;YACxE,WAAW,EACV,uEAAuE;YACxE,QAAQ,EAAE;gBACT,IAAI,EAAE,4BAA4B;aAClC;YACD,MAAM,EAAE,CAAC,kCAAmB,CAAC,IAAI,CAAC;YAClC,OAAO,EAAE,CAAC,kCAAmB,CAAC,IAAI,CAAC;YACnC,YAAY,EAAE,IAAI;YAClB,WAAW,EAAE;gBACZ;oBACC,IAAI,EAAE,yBAAyB;oBAC/B,QAAQ,EAAE,IAAI;iBACd;aACD;YACD,UAAU,EAAV,yBAAU;SACV,CAAC;QAEF,YAAO,GAAG;YACT,UAAU,EAAE;gBACX,WAAW,EAAX,wBAAW;gBACX,SAAS,EAAT,sBAAS;gBACT,QAAQ,EAAR,qBAAQ;gBACR,SAAS,EAAT,sBAAS;gBACT,SAAS,EAAT,sBAAS;aACT;YACD,eAAe,EAAE;gBAChB,iBAAiB,EAAjB,mCAAiB;aACjB;SACD,CAAC;IAkCH,CAAC;IAhCA,KAAK,CAAC,OAAO;QACZ,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAClC,IAAI,UAAU,GAAyB,EAAE,CAAC;QAE1C,IAAI,CAAC;YACJ,UAAU,GAAG,MAAM,eAAM,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAC7C,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YAEd,IAAI,GAAG,YAAY,iCAAkB,EAAE,CAAC;gBACvC,IAAI,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;oBAC3B,UAAU,CAAC,IAAI,CAAC;wBACf,IAAI,EAAE,EAAE,KAAK,EAAE,GAAG,CAAC,OAAO,EAAE;wBAC5B,UAAU,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE;qBACvB,CAAC,CAAC;gBACJ,CAAC;qBAAM,CAAC;oBACP,MAAM,GAAG,CAAC;gBACX,CAAC;YACF,CAAC;iBAAM,CAAC;gBACP,MAAM,KAAK,GAAG,GAAY,CAAC;gBAC3B,IAAI,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;oBAC3B,UAAU,CAAC,IAAI,CAAC;wBACf,IAAI,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,OAAO,EAAE;wBAC9B,UAAU,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE;qBACvB,CAAC,CAAC;gBACJ,CAAC;qBAAM,CAAC;oBACP,MAAM,IAAI,iCAAkB,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;gBAC7D,CAAC;YACF,CAAC;QACF,CAAC;QAED,OAAO,CAAC,UAAU,CAAC,CAAC;IACrB,CAAC;CACD;AAtED,0CAsEC"}
|
|
@@ -45,11 +45,18 @@ function buildContext(executeFunctions) {
|
|
|
45
45
|
const operation = executeFunctions.getNodeParameter('operation', 0);
|
|
46
46
|
const driveIdParam = executeFunctions.getNodeParameter('driveId', 0);
|
|
47
47
|
const driveId = typeof driveIdParam === 'object' ? driveIdParam.value : driveIdParam;
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
48
|
+
let fileId;
|
|
49
|
+
if (operation !== 'getWorkbooks') {
|
|
50
|
+
const fileIdParam = executeFunctions.getNodeParameter('fileId', 0);
|
|
51
|
+
fileId = typeof fileIdParam === 'object' ? fileIdParam.value : fileIdParam;
|
|
52
|
+
}
|
|
53
|
+
let siteId;
|
|
54
|
+
let basePath = '';
|
|
55
|
+
if (operation !== 'getWorkbooks') {
|
|
56
|
+
const siteIdParam = executeFunctions.getNodeParameter('siteId', 0);
|
|
57
|
+
siteId = typeof siteIdParam === 'object' ? siteIdParam.value : siteIdParam;
|
|
58
|
+
basePath = `/sites/${siteId}/drives/${driveId}/items/${fileId}`;
|
|
59
|
+
}
|
|
53
60
|
return {
|
|
54
61
|
source,
|
|
55
62
|
resource,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"router.js","sourceRoot":"","sources":["../../../../nodes/SharePointExcel/actions/router.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUA,
|
|
1
|
+
{"version":3,"file":"router.js","sourceRoot":"","sources":["../../../../nodes/SharePointExcel/actions/router.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,39 +3,61 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.execute = execute;
|
|
4
4
|
const n8n_workflow_1 = require("n8n-workflow");
|
|
5
5
|
const api_1 = require("../../api");
|
|
6
|
+
function getRowData(context, itemIndex, item, dataMode) {
|
|
7
|
+
switch (dataMode) {
|
|
8
|
+
case 'autoMap': {
|
|
9
|
+
return [item.json];
|
|
10
|
+
}
|
|
11
|
+
case 'manual': {
|
|
12
|
+
const columns = context.getNodeParameter('columns', itemIndex);
|
|
13
|
+
if (!columns.value || Object.keys(columns.value).length === 0) {
|
|
14
|
+
throw new n8n_workflow_1.NodeOperationError(context.getNode(), 'No column values provided in manual mapping mode', { itemIndex });
|
|
15
|
+
}
|
|
16
|
+
return [columns.value];
|
|
17
|
+
}
|
|
18
|
+
case 'raw': {
|
|
19
|
+
const rowDataParam = context.getNodeParameter('rowData', itemIndex);
|
|
20
|
+
try {
|
|
21
|
+
const parsed = JSON.parse(rowDataParam);
|
|
22
|
+
return Array.isArray(parsed) ? parsed : [parsed];
|
|
23
|
+
}
|
|
24
|
+
catch (err) {
|
|
25
|
+
throw new n8n_workflow_1.NodeOperationError(context.getNode(), `Invalid JSON in Row Data: ${err.message}`, { itemIndex });
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
default:
|
|
29
|
+
throw new n8n_workflow_1.NodeOperationError(context.getNode(), `Unknown data mode: ${dataMode}`, { itemIndex });
|
|
30
|
+
}
|
|
31
|
+
}
|
|
6
32
|
async function execute(items, context) {
|
|
7
33
|
const returnData = [];
|
|
8
34
|
const sheetNameParam = this.getNodeParameter('sheetName', 0);
|
|
9
35
|
const sheetName = typeof sheetNameParam === 'object' ? sheetNameParam.value : sheetNameParam;
|
|
36
|
+
const dataMode = this.getNodeParameter('dataMode', 0, 'autoMap');
|
|
37
|
+
const options = this.getNodeParameter('options', 0, {});
|
|
38
|
+
const headerRow = options.headerRow || 1;
|
|
39
|
+
const workbook = await api_1.loadWorkbook.call(this, context.basePath);
|
|
40
|
+
const worksheet = (0, api_1.getWorksheet)(workbook, sheetName, this, 0);
|
|
41
|
+
const headers = [];
|
|
42
|
+
const headerRowData = worksheet.getRow(headerRow);
|
|
43
|
+
headerRowData.eachCell({ includeEmpty: false }, (cell, colNumber) => {
|
|
44
|
+
headers[colNumber] = String(cell.value);
|
|
45
|
+
});
|
|
46
|
+
const hasHeaders = headers.some((h) => h && h.trim() !== '');
|
|
47
|
+
const headerMap = {};
|
|
48
|
+
let totalRowsAdded = 0;
|
|
10
49
|
for (let i = 0; i < items.length; i++) {
|
|
11
|
-
const
|
|
12
|
-
|
|
13
|
-
try {
|
|
14
|
-
const parsed = JSON.parse(rowDataParam);
|
|
15
|
-
rowsToAdd = Array.isArray(parsed) ? parsed : [parsed];
|
|
16
|
-
}
|
|
17
|
-
catch (err) {
|
|
18
|
-
throw new n8n_workflow_1.NodeOperationError(this.getNode(), `Invalid JSON in Row Data: ${err.message}`, { itemIndex: i });
|
|
19
|
-
}
|
|
20
|
-
const workbook = await api_1.loadWorkbook.call(this, context.basePath);
|
|
21
|
-
const worksheet = (0, api_1.getWorksheet)(workbook, sheetName, this, i);
|
|
22
|
-
const headers = [];
|
|
23
|
-
const headerRow = worksheet.getRow(1);
|
|
24
|
-
headerRow.eachCell({ includeEmpty: false }, (cell, colNumber) => {
|
|
25
|
-
headers[colNumber] = String(cell.value);
|
|
26
|
-
});
|
|
27
|
-
const hasHeaders = headers.some((h) => h && h.trim() !== '');
|
|
28
|
-
const headerMap = {};
|
|
29
|
-
if (!hasHeaders && rowsToAdd.length > 0) {
|
|
50
|
+
const rowsToAdd = getRowData(this, i, items[i], dataMode);
|
|
51
|
+
if (!hasHeaders && i === 0 && rowsToAdd.length > 0) {
|
|
30
52
|
const keys = Object.keys(rowsToAdd[0]);
|
|
31
53
|
keys.forEach((key, idx) => {
|
|
32
54
|
const colNumber = idx + 1;
|
|
33
|
-
|
|
55
|
+
headerRowData.getCell(colNumber).value = key;
|
|
34
56
|
headers[colNumber] = key;
|
|
35
57
|
headerMap[key] = colNumber;
|
|
36
58
|
});
|
|
37
59
|
}
|
|
38
|
-
else {
|
|
60
|
+
else if (i === 0) {
|
|
39
61
|
headers.forEach((h, idx) => {
|
|
40
62
|
if (h)
|
|
41
63
|
headerMap[h] = idx;
|
|
@@ -50,16 +72,17 @@ async function execute(items, context) {
|
|
|
50
72
|
}
|
|
51
73
|
}
|
|
52
74
|
worksheet.addRow(newRow);
|
|
75
|
+
totalRowsAdded++;
|
|
53
76
|
}
|
|
54
|
-
await api_1.saveWorkbook.call(this, context.basePath, workbook);
|
|
55
|
-
returnData.push({
|
|
56
|
-
json: {
|
|
57
|
-
success: true,
|
|
58
|
-
rowsAdded: rowsToAdd.length,
|
|
59
|
-
sheet: sheetName,
|
|
60
|
-
},
|
|
61
|
-
});
|
|
62
77
|
}
|
|
78
|
+
await api_1.saveWorkbook.call(this, context.basePath, workbook);
|
|
79
|
+
returnData.push({
|
|
80
|
+
json: {
|
|
81
|
+
success: true,
|
|
82
|
+
rowsAdded: totalRowsAdded,
|
|
83
|
+
sheet: sheetName,
|
|
84
|
+
},
|
|
85
|
+
});
|
|
63
86
|
return returnData;
|
|
64
87
|
}
|
|
65
88
|
//# sourceMappingURL=appendRows.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"appendRows.js","sourceRoot":"","sources":["../../../../../nodes/SharePointExcel/actions/sheet/appendRows.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"appendRows.js","sourceRoot":"","sources":["../../../../../nodes/SharePointExcel/actions/sheet/appendRows.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|