codeapp-js 0.1.0 → 0.2.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.
- package/codeApp/dist/codeapp.js +326 -72
- package/codeApp/dist/icon-512.png +0 -0
- package/codeApp/dist/index.html +1 -0
- package/codeApp/dist/index.js +1 -1
- package/codeApp/dist/power-apps-data.js +2952 -2531
- package/codeApp/power.config.json +1 -1
- package/dev files/customConnector.js +98 -0
- package/dev files/dataverse.js +33 -7
- package/dev files/environmentVar.js +1 -1
- package/dev files/office365groups.js +1 -1
- package/dev files/office365users.js +1 -1
- package/dev files/outlook.js +1 -1
- package/dev files/power-apps-data.js +2952 -0
- package/dev files/sharepoint.js +1 -1
- package/examples/combined demo/dist/codeapp.js +1098 -0
- package/examples/combined demo/dist/index.js +470 -515
- package/examples/combined demo/dist/power-apps-data.js +3007 -2531
- package/examples/dataverse Demo/dist/codeapp.js +1085 -0
- package/examples/dataverse Demo/dist/index.js +38 -26
- package/examples/dataverse Demo/dist/power-apps-data.js +2912 -2531
- package/examples/groups Demo/dist/codeapp.js +1085 -0
- package/examples/groups Demo/dist/index.js +113 -113
- package/examples/groups Demo/dist/power-apps-data.js +2912 -2531
- package/examples/groups Demo/power.config.json +3 -2
- package/examples/kanban/dist/power-apps-data.js +2953 -2531
- package/examples/myProfile/dist/power-apps-data.js +2953 -2531
- package/examples/outlook Demo/dist/codeapp.js +1085 -0
- package/examples/outlook Demo/dist/index.js +39 -35
- package/examples/outlook Demo/dist/power-apps-data.js +2912 -2531
- package/examples/planning Poker/dist/power-apps-data.js +2953 -2531
- package/examples/sharePoint Demo/dist/codeapp.js +1085 -0
- package/examples/sharePoint Demo/dist/index.js +262 -269
- package/examples/sharePoint Demo/dist/power-apps-data.js +2912 -2531
- package/examples/solution explorer/agent/decision-log.md +27 -0
- package/examples/solution explorer/agent/mockup-01-swiss-grid.html +452 -0
- package/examples/solution explorer/agent/mockup-02-dark-glass.html +496 -0
- package/examples/solution explorer/agent/mockup-03-paper-console.html +510 -0
- package/examples/solution explorer/agent/mockup-04-neon-noir.html +546 -0
- package/examples/solution explorer/agent/mockup-05-zen-garden.html +534 -0
- package/examples/solution explorer/dist/codeapp.js +1098 -0
- package/examples/solution explorer/dist/icon-512.png +0 -0
- package/examples/solution explorer/dist/index.html +80 -0
- package/examples/solution explorer/dist/index.js +735 -0
- package/examples/solution explorer/dist/power-apps-data.js +3007 -0
- package/examples/solution explorer/dist/styles.css +571 -0
- package/examples/solution explorer/power.config.json +151 -0
- package/examples/todo/dist/power-apps-data.js +2953 -2531
- package/package.json +1 -8
- package/.github/instructions/wyattdave.instructions.md +0 -39
- package/examples/combined demo/dist/dataverse.js +0 -86
- package/examples/combined demo/dist/environmentVar.js +0 -55
- package/examples/combined demo/dist/office365groups.js +0 -97
- package/examples/combined demo/dist/office365users.js +0 -169
- package/examples/combined demo/dist/outlook.js +0 -162
- package/examples/combined demo/dist/sharepoint.js +0 -339
- package/examples/dataverse Demo/dist/dataverse.js +0 -86
- package/examples/groups Demo/dist/dataverse.js +0 -86
- package/examples/groups Demo/dist/environmentVar.js +0 -55
- package/examples/groups Demo/dist/office365groups.js +0 -97
- package/examples/groups Demo/dist/office365users.js +0 -169
- package/examples/groups Demo/dist/outlook.js +0 -162
- package/examples/groups Demo/dist/sharepoint.js +0 -339
- package/examples/sharePoint Demo/dist/dataverse.js +0 -94
- package/examples/sharePoint Demo/dist/environmentVar.js +0 -55
- package/examples/sharePoint Demo/dist/office365groups.js +0 -97
- package/examples/sharePoint Demo/dist/office365users.js +0 -169
- package/examples/sharePoint Demo/dist/outlook.js +0 -162
- package/examples/sharePoint Demo/dist/sharepoint.js +0 -339
- package/scripts/build-power-sdk.mjs +0 -69
|
@@ -1,339 +0,0 @@
|
|
|
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,69 +0,0 @@
|
|
|
1
|
-
import path from 'node:path';
|
|
2
|
-
import { access, readdir } from 'node:fs/promises';
|
|
3
|
-
import { build } from 'esbuild';
|
|
4
|
-
|
|
5
|
-
const sWorkspaceRoot = process.cwd();
|
|
6
|
-
const sSdkEntry = path.join(
|
|
7
|
-
sWorkspaceRoot,
|
|
8
|
-
'node_modules',
|
|
9
|
-
'@microsoft',
|
|
10
|
-
'power-apps',
|
|
11
|
-
'lib',
|
|
12
|
-
'data',
|
|
13
|
-
'index.js'
|
|
14
|
-
);
|
|
15
|
-
|
|
16
|
-
async function findSdkTargets(sDirPath) {
|
|
17
|
-
const aEntries = await readdir(sDirPath, { withFileTypes: true });
|
|
18
|
-
let aTargets = [];
|
|
19
|
-
|
|
20
|
-
for (const oEntry of aEntries) {
|
|
21
|
-
if (oEntry.name === 'node_modules' || oEntry.name === '.git') {
|
|
22
|
-
continue;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
const sEntryPath = path.join(sDirPath, oEntry.name);
|
|
26
|
-
|
|
27
|
-
if (oEntry.isDirectory()) {
|
|
28
|
-
const aChildTargets = await findSdkTargets(sEntryPath);
|
|
29
|
-
aTargets = aTargets.concat(aChildTargets);
|
|
30
|
-
continue;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
if (oEntry.isFile() && oEntry.name === 'power-apps-data.js') {
|
|
34
|
-
aTargets.push(sEntryPath);
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
return aTargets;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
async function bundleSdk() {
|
|
42
|
-
await access(sSdkEntry);
|
|
43
|
-
|
|
44
|
-
const aTargets = await findSdkTargets(sWorkspaceRoot);
|
|
45
|
-
|
|
46
|
-
if (aTargets.length === 0) {
|
|
47
|
-
throw new Error('No power-apps-data.js targets were found in the workspace.');
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
for (const sTargetPath of aTargets) {
|
|
51
|
-
await build({
|
|
52
|
-
entryPoints: [sSdkEntry],
|
|
53
|
-
outfile: sTargetPath,
|
|
54
|
-
bundle: true,
|
|
55
|
-
format: 'esm',
|
|
56
|
-
platform: 'browser',
|
|
57
|
-
target: ['es2020'],
|
|
58
|
-
legalComments: 'none',
|
|
59
|
-
logLevel: 'silent'
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
console.log('Bundled SDK to ' + path.relative(sWorkspaceRoot, sTargetPath));
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
bundleSdk().catch((oError) => {
|
|
67
|
-
console.error(oError.message);
|
|
68
|
-
process.exitCode = 1;
|
|
69
|
-
});
|