codeapp-js 0.1.1 → 0.2.2

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 (121) hide show
  1. package/codeApp/dist/codeapp.js +552 -78
  2. package/codeApp/dist/power-apps-data.js +2531 -2531
  3. package/dev files/outlook.js +218 -9
  4. package/examples/combined demo/dist/codeapp.js +1098 -0
  5. package/examples/combined demo/dist/index.js +69 -114
  6. package/examples/combined demo/dist/power-apps-data.js +646 -170
  7. package/examples/combined demo/power.config.json +42 -42
  8. package/examples/dataverse Demo/dist/codeapp.js +1085 -0
  9. package/examples/dataverse Demo/dist/index.html +54 -54
  10. package/examples/dataverse Demo/dist/index.js +82 -70
  11. package/examples/dataverse Demo/dist/power-apps-data.js +551 -170
  12. package/examples/dataverse Demo/power.config.json +34 -34
  13. package/examples/dataverse Demo/readme.md +79 -79
  14. package/examples/groups Demo/dist/codeapp.js +1085 -0
  15. package/examples/groups Demo/dist/index.js +27 -27
  16. package/examples/groups Demo/dist/power-apps-data.js +551 -170
  17. package/examples/kanban/dist/dataverse.js +94 -94
  18. package/examples/kanban/dist/environmentVar.js +55 -55
  19. package/examples/kanban/dist/office365groups.js +97 -97
  20. package/examples/kanban/dist/office365users.js +169 -169
  21. package/examples/kanban/dist/outlook.js +162 -162
  22. package/examples/kanban/dist/power-apps-data.js +560 -138
  23. package/examples/kanban/dist/sharepoint.js +339 -339
  24. package/examples/myProfile/dist/index.html +184 -184
  25. package/examples/myProfile/dist/index.js +141 -141
  26. package/examples/myProfile/dist/office365users.js +169 -169
  27. package/examples/myProfile/dist/power-apps-data.js +560 -138
  28. package/examples/myProfile/power.config.json +22 -22
  29. package/examples/myProfile/readme.md +79 -79
  30. package/examples/outlook Demo/dist/codeapp.js +1085 -0
  31. package/examples/outlook Demo/dist/index.html +35 -35
  32. package/examples/outlook Demo/dist/index.js +170 -166
  33. package/examples/outlook Demo/dist/outlook.js +121 -121
  34. package/examples/outlook Demo/dist/power-apps-data.js +551 -170
  35. package/examples/outlook Demo/dist/styles.css +84 -84
  36. package/examples/outlook Demo/readme.md +82 -82
  37. package/examples/outlook Demo2/OutlookDemo_1_0_0_1.zip +0 -0
  38. package/examples/outlook Demo2/agent/decision-log.md +7 -0
  39. package/examples/outlook Demo2/dist/codeapp.js +1334 -0
  40. package/examples/outlook Demo2/dist/icon-512.png +0 -0
  41. package/examples/outlook Demo2/dist/index.html +98 -0
  42. package/examples/outlook Demo2/dist/index.js +346 -0
  43. package/examples/outlook Demo2/dist/power-apps-data.js +3007 -0
  44. package/examples/outlook Demo2/dist/styles.css +639 -0
  45. package/examples/outlook Demo2/power.config.json +23 -0
  46. package/examples/outlook Demo2/src/generated/index.ts +14 -0
  47. package/examples/outlook Demo2/src/generated/models/Office365GroupsModel.ts +363 -0
  48. package/examples/outlook Demo2/src/generated/models/Office365OutlookModel.ts +2046 -0
  49. package/examples/outlook Demo2/src/generated/models/Office365UsersModel.ts +254 -0
  50. package/examples/outlook Demo2/src/generated/services/Office365GroupsService.ts +326 -0
  51. package/examples/outlook Demo2/src/generated/services/Office365OutlookService.ts +2476 -0
  52. package/examples/outlook Demo2/src/generated/services/Office365UsersService.ts +358 -0
  53. package/examples/planning Poker/.vscode/settings.json +4 -4
  54. package/examples/planning Poker/additional files/customizations (tables).xml +6428 -6428
  55. package/examples/planning Poker/additional files/dataverse-tables.json +165 -165
  56. package/examples/planning Poker/additional files/readme.md +122 -122
  57. package/examples/planning Poker/dist/dataverse.js +78 -78
  58. package/examples/planning Poker/dist/index.html +198 -198
  59. package/examples/planning Poker/dist/index.js +954 -954
  60. package/examples/planning Poker/dist/power-apps-data.js +560 -138
  61. package/examples/planning Poker/dist/styles.css +815 -815
  62. package/examples/sharePoint Demo/agent/decision-log.md +5 -5
  63. package/examples/sharePoint Demo/dist/codeapp.js +1085 -0
  64. package/examples/sharePoint Demo/dist/index.js +44 -51
  65. package/examples/sharePoint Demo/dist/power-apps-data.js +551 -170
  66. package/examples/sharePoint Demo/power.config.json +22 -22
  67. package/examples/solution explorer/agent/decision-log.md +27 -0
  68. package/examples/solution explorer/agent/mockup-01-swiss-grid.html +452 -0
  69. package/examples/solution explorer/agent/mockup-02-dark-glass.html +496 -0
  70. package/examples/solution explorer/agent/mockup-03-paper-console.html +510 -0
  71. package/examples/solution explorer/agent/mockup-04-neon-noir.html +546 -0
  72. package/examples/solution explorer/agent/mockup-05-zen-garden.html +534 -0
  73. package/examples/solution explorer/dist/codeapp.js +1098 -0
  74. package/examples/solution explorer/dist/icon-512.png +0 -0
  75. package/examples/solution explorer/dist/index.html +80 -0
  76. package/examples/solution explorer/dist/index.js +735 -0
  77. package/examples/solution explorer/dist/power-apps-data.js +3007 -0
  78. package/examples/solution explorer/dist/styles.css +571 -0
  79. package/examples/solution explorer/power.config.json +151 -0
  80. package/examples/todo/dist/dataverse.js +64 -64
  81. package/examples/todo/dist/index.html +75 -75
  82. package/examples/todo/dist/index.js +8 -8
  83. package/examples/todo/dist/power-apps-data.js +560 -138
  84. package/examples/todo/dist/renderer.js +375 -375
  85. package/examples/todo/dist/styles.css +691 -691
  86. package/examples/todo/power.config.json +34 -34
  87. package/package.json +1 -8
  88. package/docs-mockups/atelier/index.html +0 -120
  89. package/docs-mockups/atelier/script.js +0 -23
  90. package/docs-mockups/atelier/styles.css +0 -361
  91. package/docs-mockups/field-guide/index.html +0 -112
  92. package/docs-mockups/field-guide/script.js +0 -20
  93. package/docs-mockups/field-guide/styles.css +0 -272
  94. package/docs-mockups/index.html +0 -80
  95. package/docs-mockups/maker-hub/index.html +0 -178
  96. package/docs-mockups/maker-hub/script.js +0 -20
  97. package/docs-mockups/maker-hub/styles.css +0 -404
  98. package/docs-mockups/script.js +0 -26
  99. package/docs-mockups/signal/index.html +0 -146
  100. package/docs-mockups/signal/script.js +0 -20
  101. package/docs-mockups/signal/styles.css +0 -314
  102. package/docs-mockups/styles.css +0 -287
  103. package/examples/combined demo/dist/dataverse.js +0 -86
  104. package/examples/combined demo/dist/environmentVar.js +0 -55
  105. package/examples/combined demo/dist/office365groups.js +0 -97
  106. package/examples/combined demo/dist/office365users.js +0 -169
  107. package/examples/combined demo/dist/outlook.js +0 -162
  108. package/examples/combined demo/dist/sharepoint.js +0 -339
  109. package/examples/dataverse Demo/dist/dataverse.js +0 -86
  110. package/examples/groups Demo/dist/dataverse.js +0 -86
  111. package/examples/groups Demo/dist/environmentVar.js +0 -55
  112. package/examples/groups Demo/dist/office365groups.js +0 -97
  113. package/examples/groups Demo/dist/office365users.js +0 -169
  114. package/examples/groups Demo/dist/outlook.js +0 -162
  115. package/examples/groups Demo/dist/sharepoint.js +0 -339
  116. package/examples/sharePoint Demo/dist/dataverse.js +0 -94
  117. package/examples/sharePoint Demo/dist/environmentVar.js +0 -55
  118. package/examples/sharePoint Demo/dist/office365groups.js +0 -97
  119. package/examples/sharePoint Demo/dist/office365users.js +0 -169
  120. package/examples/sharePoint Demo/dist/outlook.js +0 -162
  121. package/examples/sharePoint Demo/dist/sharepoint.js +0 -339
@@ -1,339 +1,339 @@
1
- import { getClient } from "@microsoft/power-apps/data";
2
-
3
- // ── Data source name (must match connectionReferences in power.config.json) ──
4
- const DATA_SOURCE = "sharepointonline";
5
-
6
- // ── Initialize SDK client for the SharePoint connector ─────────
7
- function initClient() {
8
- const dataSourcesInfo = {
9
- [DATA_SOURCE]: {
10
- tableId: "",
11
- version: "",
12
- primaryKey: "",
13
- dataSourceType: "Connector",
14
- apis: {
15
- GetItems: {
16
- path: "/{connectionId}/datasets/{siteUrl}/tables/{table}/items",
17
- method: "GET",
18
- parameters: [
19
- { name: "connectionId", in: "path", required: true },
20
- { name: "siteUrl", in: "path", required: true },
21
- { name: "table", in: "path", required: true },
22
- { name: "$filter", in: "query", required: false },
23
- { name: "$orderby", in: "query", required: false },
24
- { name: "$top", in: "query", required: false },
25
- { name: "$skip", in: "query", required: false },
26
- ],
27
- },
28
- GetItem: {
29
- path: "/{connectionId}/datasets/{siteUrl}/tables/{table}/items/{id}",
30
- method: "GET",
31
- parameters: [
32
- { name: "connectionId", in: "path", required: true },
33
- { name: "siteUrl", in: "path", required: true },
34
- { name: "table", in: "path", required: true },
35
- { name: "id", in: "path", required: true },
36
- ],
37
- },
38
- PostItem: {
39
- path: "/{connectionId}/datasets/{siteUrl}/tables/{table}/items",
40
- method: "POST",
41
- parameters: [
42
- { name: "connectionId", in: "path", required: true },
43
- { name: "siteUrl", in: "path", required: true },
44
- { name: "table", in: "path", required: true },
45
- { name: "item", in: "body", required: true },
46
- ],
47
- },
48
- PatchItem: {
49
- path: "/{connectionId}/datasets/{siteUrl}/tables/{table}/items/{id}",
50
- method: "PATCH",
51
- parameters: [
52
- { name: "connectionId", in: "path", required: true },
53
- { name: "siteUrl", in: "path", required: true },
54
- { name: "table", in: "path", required: true },
55
- { name: "id", in: "path", required: true },
56
- { name: "item", in: "body", required: true },
57
- ],
58
- },
59
- DeleteItem: {
60
- path: "/{connectionId}/datasets/{siteUrl}/tables/{table}/items/{id}",
61
- method: "DELETE",
62
- parameters: [
63
- { name: "connectionId", in: "path", required: true },
64
- { name: "siteUrl", in: "path", required: true },
65
- { name: "table", in: "path", required: true },
66
- { name: "id", in: "path", required: true },
67
- ],
68
- },
69
- GetTables: {
70
- path: "/{connectionId}/datasets/{siteUrl}/tables",
71
- method: "GET",
72
- parameters: [
73
- { name: "connectionId", in: "path", required: true },
74
- { name: "siteUrl", in: "path", required: true },
75
- ],
76
- },
77
- GetDataSetsMetadata: {
78
- path: "/{connectionId}/datasets/{siteUrl}",
79
- method: "GET",
80
- parameters: [
81
- { name: "connectionId", in: "path", required: true },
82
- { name: "siteUrl", in: "path", required: true },
83
- ],
84
- },
85
- CreateFile: {
86
- path: "/{connectionId}/datasets/{siteUrl}/files",
87
- method: "POST",
88
- parameters: [
89
- { name: "connectionId", in: "path", required: true },
90
- { name: "siteUrl", in: "path", required: true },
91
- { name: "folderPath", in: "query", required: true },
92
- { name: "name", in: "query", required: true },
93
- { name: "body", in: "body", required: true },
94
- ],
95
- },
96
- UpdateFile: {
97
- path: "/{connectionId}/datasets/{siteUrl}/files/{id}",
98
- method: "PUT",
99
- parameters: [
100
- { name: "connectionId", in: "path", required: true },
101
- { name: "siteUrl", in: "path", required: true },
102
- { name: "id", in: "path", required: true },
103
- { name: "body", in: "body", required: true },
104
- ],
105
- },
106
- DeleteFile: {
107
- path: "/{connectionId}/datasets/{siteUrl}/files/{id}",
108
- method: "DELETE",
109
- parameters: [
110
- { name: "connectionId", in: "path", required: true },
111
- { name: "siteUrl", in: "path", required: true },
112
- { name: "id", in: "path", required: true },
113
- ],
114
- },
115
- MoveFile: {
116
- path: "/{connectionId}/datasets/{siteUrl}/files/{id}/moveto",
117
- method: "POST",
118
- parameters: [
119
- { name: "connectionId", in: "path", required: true },
120
- { name: "siteUrl", in: "path", required: true },
121
- { name: "id", in: "path", required: true },
122
- { name: "destinationFolderPath", in: "query", required: true },
123
- { name: "newFileName", in: "query", required: false },
124
- ],
125
- },
126
- GetFileMetadata: {
127
- path: "/{connectionId}/datasets/{siteUrl}/files/{id}",
128
- method: "GET",
129
- parameters: [
130
- { name: "connectionId", in: "path", required: true },
131
- { name: "siteUrl", in: "path", required: true },
132
- { name: "id", in: "path", required: true },
133
- ],
134
- },
135
- HttpRequest: {
136
- path: "/{connectionId}/httprequest",
137
- method: "POST",
138
- parameters: [
139
- { name: "connectionId", in: "path", required: true },
140
- ],
141
- },
142
- },
143
- },
144
- };
145
- return getClient(dataSourcesInfo);
146
- }
147
-
148
- // ── Internal: execute a connector operation ────────────────────
149
- async function execOp(operationName, parameters) {
150
- const client = await initClient();
151
- const result = await client.executeAsync({
152
- connectorOperation: {
153
- tableName: DATA_SOURCE,
154
- operationName,
155
- parameters,
156
- },
157
- });
158
- if (!result.success) {
159
- throw new Error(result.error?.message || "Operation failed");
160
- }
161
- return result.data;
162
- }
163
-
164
- // ═══════════════════════════════════════════════════════════════
165
- // GENERIC
166
- // ═══════════════════════════════════════════════════════════════
167
-
168
- // ── Call any SharePoint connector operation by name ─────────────
169
- export async function callSharePointOperation(operationName, parameters = {}) {
170
- return execOp(operationName, parameters);
171
- }
172
-
173
- // ── Send HTTP Request (for list-name-based operations) ─────────
174
- export async function sendHttpRequest({ method = "GET", uri, headers, body }) {
175
- return execOp("HttpRequest", {
176
- method,
177
- uri,
178
- headers: headers || {},
179
- body: body || "",
180
- });
181
- }
182
-
183
- // ═══════════════════════════════════════════════════════════════
184
- // ITEMS (standard API — uses list ID)
185
- // ═══════════════════════════════════════════════════════════════
186
-
187
- // ── Get Items ──────────────────────────────────────────────────
188
- export async function getItems(sSiteUrl, sListId, { filter, orderBy, top, skip } = {}) {
189
- let params = { siteUrl: encodeURIComponent(sSiteUrl), table: sListId };
190
- if (filter) params.$filter = filter;
191
- if (orderBy) params.$orderby = orderBy;
192
- if (top != null) params.$top = top;
193
- if (skip != null) params.$skip = skip;
194
- return execOp("GetItems", params);
195
- }
196
-
197
- // ── Get Item ───────────────────────────────────────────────────
198
- export async function getItem(sSiteUrl, sListId, iItemId) {
199
- return execOp("GetItem", {
200
- siteUrl: encodeURIComponent(sSiteUrl),
201
- table: sListId,
202
- id: iItemId,
203
- });
204
- }
205
-
206
- // ── Create Item ────────────────────────────────────────────────
207
- export async function createItem(sSiteUrl, sListId, oFields) {
208
- return execOp("PostItem", {
209
- siteUrl: encodeURIComponent(sSiteUrl),
210
- table: sListId,
211
- item: oFields,
212
- });
213
- }
214
-
215
- // ── Update Item ────────────────────────────────────────────────
216
- export async function updateItem(sSiteUrl, sListId, iItemId, oChangedFields) {
217
- return execOp("PatchItem", {
218
- siteUrl: encodeURIComponent(sSiteUrl),
219
- table: sListId,
220
- id: iItemId,
221
- item: oChangedFields,
222
- });
223
- }
224
-
225
- // ── Delete Item ────────────────────────────────────────────────
226
- export async function deleteItem(sSiteUrl, sListId, iItemId) {
227
- return execOp("DeleteItem", {
228
- siteUrl: encodeURIComponent(sSiteUrl),
229
- table: sListId,
230
- id: iItemId,
231
- });
232
- }
233
-
234
- // ═══════════════════════════════════════════════════════════════
235
- // ITEMS (HTTP API — uses list name)
236
- // ═══════════════════════════════════════════════════════════════
237
-
238
- // ── Get Items by List Name ─────────────────────────────────────
239
- export async function getItemsByName(sSiteUrl, sListName, { filter, orderBy, top, skip } = {}) {
240
- let sUri = sSiteUrl + "/_api/web/lists/getbytitle('" + sListName + "')/items";
241
- let aQuery = [];
242
- if (filter) aQuery.push("$filter=" + filter);
243
- if (orderBy) aQuery.push("$orderby=" + orderBy);
244
- if (top != null) aQuery.push("$top=" + top);
245
- if (skip != null) aQuery.push("$skip=" + skip);
246
- if (aQuery.length > 0) sUri = sUri + "?" + aQuery.join("&");
247
- return sendHttpRequest({ method: "GET", uri: sUri, headers: { Accept: "application/json;odata=nometadata" } });
248
- }
249
-
250
- // ── Get Item by List Name ──────────────────────────────────────
251
- export async function getItemByName(sSiteUrl, sListName, iItemId) {
252
- let sUri = sSiteUrl + "/_api/web/lists/getbytitle('" + sListName + "')/items(" + iItemId + ")";
253
- return sendHttpRequest({ method: "GET", uri: sUri, headers: { Accept: "application/json;odata=nometadata" } });
254
- }
255
-
256
- // ── Create Item by List Name ───────────────────────────────────
257
- export async function createItemByName(sSiteUrl, sListName, oFields) {
258
- let sUri = sSiteUrl + "/_api/web/lists/getbytitle('" + sListName + "')/items";
259
- return sendHttpRequest({ method: "POST", uri: sUri, headers: { Accept: "application/json;odata=nometadata", "Content-Type": "application/json;odata=nometadata" }, body: JSON.stringify(oFields) });
260
- }
261
-
262
- // ── Update Item by List Name ───────────────────────────────────
263
- export async function updateItemByName(sSiteUrl, sListName, iItemId, oChangedFields) {
264
- let sUri = sSiteUrl + "/_api/web/lists/getbytitle('" + sListName + "')/items(" + iItemId + ")";
265
- return sendHttpRequest({ method: "PATCH", uri: sUri, headers: { Accept: "application/json;odata=nometadata", "Content-Type": "application/json;odata=nometadata", "If-Match": "*" }, body: JSON.stringify(oChangedFields) });
266
- }
267
-
268
- // ── Delete Item by List Name ───────────────────────────────────
269
- export async function deleteItemByName(sSiteUrl, sListName, iItemId) {
270
- let sUri = sSiteUrl + "/_api/web/lists/getbytitle('" + sListName + "')/items(" + iItemId + ")";
271
- return sendHttpRequest({ method: "DELETE", uri: sUri, headers: { Accept: "application/json;odata=nometadata", "If-Match": "*" } });
272
- }
273
-
274
- // ═══════════════════════════════════════════════════════════════
275
- // TABLES / LISTS
276
- // ═══════════════════════════════════════════════════════════════
277
-
278
- // ── List Tables (Lists) ────────────────────────────────────────
279
- export async function listTables(sSiteUrl) {
280
- return execOp("GetTables", {
281
- siteUrl: encodeURIComponent(sSiteUrl),
282
- });
283
- }
284
-
285
- // ── List Library (Document Libraries) ──────────────────────────
286
- export async function listLibrary(sSiteUrl) {
287
- return execOp("GetDataSetsMetadata", {
288
- siteUrl: encodeURIComponent(sSiteUrl),
289
- });
290
- }
291
-
292
- // ═══════════════════════════════════════════════════════════════
293
- // FILES
294
- // ═══════════════════════════════════════════════════════════════
295
-
296
- // ── Create File ────────────────────────────────────────────────
297
- export async function createFile(sSiteUrl, sLibraryName, sFileName, fileContent) {
298
- return execOp("CreateFile", {
299
- siteUrl: encodeURIComponent(sSiteUrl),
300
- folderPath: sLibraryName,
301
- name: sFileName,
302
- body: fileContent,
303
- });
304
- }
305
-
306
- // ── Update File ────────────────────────────────────────────────
307
- export async function updateFile(sSiteUrl, sFileId, fileContent) {
308
- return execOp("UpdateFile", {
309
- siteUrl: encodeURIComponent(sSiteUrl),
310
- id: sFileId,
311
- body: fileContent,
312
- });
313
- }
314
-
315
- // ── Delete File ────────────────────────────────────────────────
316
- export async function deleteFile(sSiteUrl, sFileId) {
317
- return execOp("DeleteFile", {
318
- siteUrl: encodeURIComponent(sSiteUrl),
319
- id: sFileId,
320
- });
321
- }
322
-
323
- // ── Move File ──────────────────────────────────────────────────
324
- export async function moveFile(sSiteUrl, sSourceFileId, sDestinationFolderPath, sNewFileName) {
325
- return execOp("MoveFile", {
326
- siteUrl: encodeURIComponent(sSiteUrl),
327
- id: sSourceFileId,
328
- destinationFolderPath: sDestinationFolderPath,
329
- newFileName: sNewFileName || "",
330
- });
331
- }
332
-
333
- // ── Get File Metadata ──────────────────────────────────────────
334
- export async function getFileMetadata(sSiteUrl, sFileId) {
335
- return execOp("GetFileMetadata", {
336
- siteUrl: encodeURIComponent(sSiteUrl),
337
- id: sFileId,
338
- });
339
- }
1
+ import { getClient } from "@microsoft/power-apps/data";
2
+
3
+ // ── Data source name (must match connectionReferences in power.config.json) ──
4
+ const DATA_SOURCE = "sharepointonline";
5
+
6
+ // ── Initialize SDK client for the SharePoint connector ─────────
7
+ function initClient() {
8
+ const dataSourcesInfo = {
9
+ [DATA_SOURCE]: {
10
+ tableId: "",
11
+ version: "",
12
+ primaryKey: "",
13
+ dataSourceType: "Connector",
14
+ apis: {
15
+ GetItems: {
16
+ path: "/{connectionId}/datasets/{siteUrl}/tables/{table}/items",
17
+ method: "GET",
18
+ parameters: [
19
+ { name: "connectionId", in: "path", required: true },
20
+ { name: "siteUrl", in: "path", required: true },
21
+ { name: "table", in: "path", required: true },
22
+ { name: "$filter", in: "query", required: false },
23
+ { name: "$orderby", in: "query", required: false },
24
+ { name: "$top", in: "query", required: false },
25
+ { name: "$skip", in: "query", required: false },
26
+ ],
27
+ },
28
+ GetItem: {
29
+ path: "/{connectionId}/datasets/{siteUrl}/tables/{table}/items/{id}",
30
+ method: "GET",
31
+ parameters: [
32
+ { name: "connectionId", in: "path", required: true },
33
+ { name: "siteUrl", in: "path", required: true },
34
+ { name: "table", in: "path", required: true },
35
+ { name: "id", in: "path", required: true },
36
+ ],
37
+ },
38
+ PostItem: {
39
+ path: "/{connectionId}/datasets/{siteUrl}/tables/{table}/items",
40
+ method: "POST",
41
+ parameters: [
42
+ { name: "connectionId", in: "path", required: true },
43
+ { name: "siteUrl", in: "path", required: true },
44
+ { name: "table", in: "path", required: true },
45
+ { name: "item", in: "body", required: true },
46
+ ],
47
+ },
48
+ PatchItem: {
49
+ path: "/{connectionId}/datasets/{siteUrl}/tables/{table}/items/{id}",
50
+ method: "PATCH",
51
+ parameters: [
52
+ { name: "connectionId", in: "path", required: true },
53
+ { name: "siteUrl", in: "path", required: true },
54
+ { name: "table", in: "path", required: true },
55
+ { name: "id", in: "path", required: true },
56
+ { name: "item", in: "body", required: true },
57
+ ],
58
+ },
59
+ DeleteItem: {
60
+ path: "/{connectionId}/datasets/{siteUrl}/tables/{table}/items/{id}",
61
+ method: "DELETE",
62
+ parameters: [
63
+ { name: "connectionId", in: "path", required: true },
64
+ { name: "siteUrl", in: "path", required: true },
65
+ { name: "table", in: "path", required: true },
66
+ { name: "id", in: "path", required: true },
67
+ ],
68
+ },
69
+ GetTables: {
70
+ path: "/{connectionId}/datasets/{siteUrl}/tables",
71
+ method: "GET",
72
+ parameters: [
73
+ { name: "connectionId", in: "path", required: true },
74
+ { name: "siteUrl", in: "path", required: true },
75
+ ],
76
+ },
77
+ GetDataSetsMetadata: {
78
+ path: "/{connectionId}/datasets/{siteUrl}",
79
+ method: "GET",
80
+ parameters: [
81
+ { name: "connectionId", in: "path", required: true },
82
+ { name: "siteUrl", in: "path", required: true },
83
+ ],
84
+ },
85
+ CreateFile: {
86
+ path: "/{connectionId}/datasets/{siteUrl}/files",
87
+ method: "POST",
88
+ parameters: [
89
+ { name: "connectionId", in: "path", required: true },
90
+ { name: "siteUrl", in: "path", required: true },
91
+ { name: "folderPath", in: "query", required: true },
92
+ { name: "name", in: "query", required: true },
93
+ { name: "body", in: "body", required: true },
94
+ ],
95
+ },
96
+ UpdateFile: {
97
+ path: "/{connectionId}/datasets/{siteUrl}/files/{id}",
98
+ method: "PUT",
99
+ parameters: [
100
+ { name: "connectionId", in: "path", required: true },
101
+ { name: "siteUrl", in: "path", required: true },
102
+ { name: "id", in: "path", required: true },
103
+ { name: "body", in: "body", required: true },
104
+ ],
105
+ },
106
+ DeleteFile: {
107
+ path: "/{connectionId}/datasets/{siteUrl}/files/{id}",
108
+ method: "DELETE",
109
+ parameters: [
110
+ { name: "connectionId", in: "path", required: true },
111
+ { name: "siteUrl", in: "path", required: true },
112
+ { name: "id", in: "path", required: true },
113
+ ],
114
+ },
115
+ MoveFile: {
116
+ path: "/{connectionId}/datasets/{siteUrl}/files/{id}/moveto",
117
+ method: "POST",
118
+ parameters: [
119
+ { name: "connectionId", in: "path", required: true },
120
+ { name: "siteUrl", in: "path", required: true },
121
+ { name: "id", in: "path", required: true },
122
+ { name: "destinationFolderPath", in: "query", required: true },
123
+ { name: "newFileName", in: "query", required: false },
124
+ ],
125
+ },
126
+ GetFileMetadata: {
127
+ path: "/{connectionId}/datasets/{siteUrl}/files/{id}",
128
+ method: "GET",
129
+ parameters: [
130
+ { name: "connectionId", in: "path", required: true },
131
+ { name: "siteUrl", in: "path", required: true },
132
+ { name: "id", in: "path", required: true },
133
+ ],
134
+ },
135
+ HttpRequest: {
136
+ path: "/{connectionId}/httprequest",
137
+ method: "POST",
138
+ parameters: [
139
+ { name: "connectionId", in: "path", required: true },
140
+ ],
141
+ },
142
+ },
143
+ },
144
+ };
145
+ return getClient(dataSourcesInfo);
146
+ }
147
+
148
+ // ── Internal: execute a connector operation ────────────────────
149
+ async function execOp(operationName, parameters) {
150
+ const client = await initClient();
151
+ const result = await client.executeAsync({
152
+ connectorOperation: {
153
+ tableName: DATA_SOURCE,
154
+ operationName,
155
+ parameters,
156
+ },
157
+ });
158
+ if (!result.success) {
159
+ throw new Error(result.error?.message || "Operation failed");
160
+ }
161
+ return result.data;
162
+ }
163
+
164
+ // ═══════════════════════════════════════════════════════════════
165
+ // GENERIC
166
+ // ═══════════════════════════════════════════════════════════════
167
+
168
+ // ── Call any SharePoint connector operation by name ─────────────
169
+ export async function callSharePointOperation(operationName, parameters = {}) {
170
+ return execOp(operationName, parameters);
171
+ }
172
+
173
+ // ── Send HTTP Request (for list-name-based operations) ─────────
174
+ export async function sendHttpRequest({ method = "GET", uri, headers, body }) {
175
+ return execOp("HttpRequest", {
176
+ method,
177
+ uri,
178
+ headers: headers || {},
179
+ body: body || "",
180
+ });
181
+ }
182
+
183
+ // ═══════════════════════════════════════════════════════════════
184
+ // ITEMS (standard API — uses list ID)
185
+ // ═══════════════════════════════════════════════════════════════
186
+
187
+ // ── Get Items ──────────────────────────────────────────────────
188
+ export async function getItems(sSiteUrl, sListId, { filter, orderBy, top, skip } = {}) {
189
+ let params = { siteUrl: encodeURIComponent(sSiteUrl), table: sListId };
190
+ if (filter) params.$filter = filter;
191
+ if (orderBy) params.$orderby = orderBy;
192
+ if (top != null) params.$top = top;
193
+ if (skip != null) params.$skip = skip;
194
+ return execOp("GetItems", params);
195
+ }
196
+
197
+ // ── Get Item ───────────────────────────────────────────────────
198
+ export async function getItem(sSiteUrl, sListId, iItemId) {
199
+ return execOp("GetItem", {
200
+ siteUrl: encodeURIComponent(sSiteUrl),
201
+ table: sListId,
202
+ id: iItemId,
203
+ });
204
+ }
205
+
206
+ // ── Create Item ────────────────────────────────────────────────
207
+ export async function createItem(sSiteUrl, sListId, oFields) {
208
+ return execOp("PostItem", {
209
+ siteUrl: encodeURIComponent(sSiteUrl),
210
+ table: sListId,
211
+ item: oFields,
212
+ });
213
+ }
214
+
215
+ // ── Update Item ────────────────────────────────────────────────
216
+ export async function updateItem(sSiteUrl, sListId, iItemId, oChangedFields) {
217
+ return execOp("PatchItem", {
218
+ siteUrl: encodeURIComponent(sSiteUrl),
219
+ table: sListId,
220
+ id: iItemId,
221
+ item: oChangedFields,
222
+ });
223
+ }
224
+
225
+ // ── Delete Item ────────────────────────────────────────────────
226
+ export async function deleteItem(sSiteUrl, sListId, iItemId) {
227
+ return execOp("DeleteItem", {
228
+ siteUrl: encodeURIComponent(sSiteUrl),
229
+ table: sListId,
230
+ id: iItemId,
231
+ });
232
+ }
233
+
234
+ // ═══════════════════════════════════════════════════════════════
235
+ // ITEMS (HTTP API — uses list name)
236
+ // ═══════════════════════════════════════════════════════════════
237
+
238
+ // ── Get Items by List Name ─────────────────────────────────────
239
+ export async function getItemsByName(sSiteUrl, sListName, { filter, orderBy, top, skip } = {}) {
240
+ let sUri = sSiteUrl + "/_api/web/lists/getbytitle('" + sListName + "')/items";
241
+ let aQuery = [];
242
+ if (filter) aQuery.push("$filter=" + filter);
243
+ if (orderBy) aQuery.push("$orderby=" + orderBy);
244
+ if (top != null) aQuery.push("$top=" + top);
245
+ if (skip != null) aQuery.push("$skip=" + skip);
246
+ if (aQuery.length > 0) sUri = sUri + "?" + aQuery.join("&");
247
+ return sendHttpRequest({ method: "GET", uri: sUri, headers: { Accept: "application/json;odata=nometadata" } });
248
+ }
249
+
250
+ // ── Get Item by List Name ──────────────────────────────────────
251
+ export async function getItemByName(sSiteUrl, sListName, iItemId) {
252
+ let sUri = sSiteUrl + "/_api/web/lists/getbytitle('" + sListName + "')/items(" + iItemId + ")";
253
+ return sendHttpRequest({ method: "GET", uri: sUri, headers: { Accept: "application/json;odata=nometadata" } });
254
+ }
255
+
256
+ // ── Create Item by List Name ───────────────────────────────────
257
+ export async function createItemByName(sSiteUrl, sListName, oFields) {
258
+ let sUri = sSiteUrl + "/_api/web/lists/getbytitle('" + sListName + "')/items";
259
+ return sendHttpRequest({ method: "POST", uri: sUri, headers: { Accept: "application/json;odata=nometadata", "Content-Type": "application/json;odata=nometadata" }, body: JSON.stringify(oFields) });
260
+ }
261
+
262
+ // ── Update Item by List Name ───────────────────────────────────
263
+ export async function updateItemByName(sSiteUrl, sListName, iItemId, oChangedFields) {
264
+ let sUri = sSiteUrl + "/_api/web/lists/getbytitle('" + sListName + "')/items(" + iItemId + ")";
265
+ return sendHttpRequest({ method: "PATCH", uri: sUri, headers: { Accept: "application/json;odata=nometadata", "Content-Type": "application/json;odata=nometadata", "If-Match": "*" }, body: JSON.stringify(oChangedFields) });
266
+ }
267
+
268
+ // ── Delete Item by List Name ───────────────────────────────────
269
+ export async function deleteItemByName(sSiteUrl, sListName, iItemId) {
270
+ let sUri = sSiteUrl + "/_api/web/lists/getbytitle('" + sListName + "')/items(" + iItemId + ")";
271
+ return sendHttpRequest({ method: "DELETE", uri: sUri, headers: { Accept: "application/json;odata=nometadata", "If-Match": "*" } });
272
+ }
273
+
274
+ // ═══════════════════════════════════════════════════════════════
275
+ // TABLES / LISTS
276
+ // ═══════════════════════════════════════════════════════════════
277
+
278
+ // ── List Tables (Lists) ────────────────────────────────────────
279
+ export async function listTables(sSiteUrl) {
280
+ return execOp("GetTables", {
281
+ siteUrl: encodeURIComponent(sSiteUrl),
282
+ });
283
+ }
284
+
285
+ // ── List Library (Document Libraries) ──────────────────────────
286
+ export async function listLibrary(sSiteUrl) {
287
+ return execOp("GetDataSetsMetadata", {
288
+ siteUrl: encodeURIComponent(sSiteUrl),
289
+ });
290
+ }
291
+
292
+ // ═══════════════════════════════════════════════════════════════
293
+ // FILES
294
+ // ═══════════════════════════════════════════════════════════════
295
+
296
+ // ── Create File ────────────────────────────────────────────────
297
+ export async function createFile(sSiteUrl, sLibraryName, sFileName, fileContent) {
298
+ return execOp("CreateFile", {
299
+ siteUrl: encodeURIComponent(sSiteUrl),
300
+ folderPath: sLibraryName,
301
+ name: sFileName,
302
+ body: fileContent,
303
+ });
304
+ }
305
+
306
+ // ── Update File ────────────────────────────────────────────────
307
+ export async function updateFile(sSiteUrl, sFileId, fileContent) {
308
+ return execOp("UpdateFile", {
309
+ siteUrl: encodeURIComponent(sSiteUrl),
310
+ id: sFileId,
311
+ body: fileContent,
312
+ });
313
+ }
314
+
315
+ // ── Delete File ────────────────────────────────────────────────
316
+ export async function deleteFile(sSiteUrl, sFileId) {
317
+ return execOp("DeleteFile", {
318
+ siteUrl: encodeURIComponent(sSiteUrl),
319
+ id: sFileId,
320
+ });
321
+ }
322
+
323
+ // ── Move File ──────────────────────────────────────────────────
324
+ export async function moveFile(sSiteUrl, sSourceFileId, sDestinationFolderPath, sNewFileName) {
325
+ return execOp("MoveFile", {
326
+ siteUrl: encodeURIComponent(sSiteUrl),
327
+ id: sSourceFileId,
328
+ destinationFolderPath: sDestinationFolderPath,
329
+ newFileName: sNewFileName || "",
330
+ });
331
+ }
332
+
333
+ // ── Get File Metadata ──────────────────────────────────────────
334
+ export async function getFileMetadata(sSiteUrl, sFileId) {
335
+ return execOp("GetFileMetadata", {
336
+ siteUrl: encodeURIComponent(sSiteUrl),
337
+ id: sFileId,
338
+ });
339
+ }