codeapp-js 0.2.1 → 0.3.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.
Files changed (100) hide show
  1. package/codeApp/.power/schemas/appschemas/dataSourcesInfo.ts +6275 -0
  2. package/codeApp/.power/schemas/jira/jira.Schema.json +6903 -0
  3. package/codeApp/.power/schemas/keyvault/keyvault.Schema.json +1600 -0
  4. package/codeApp/.power/schemas/teams/teams.Schema.json +11112 -0
  5. package/codeApp/dist/codeapp.js +992 -4
  6. package/codeApp/dist/power-apps-data.js +145 -31
  7. package/codeApp/src/generated/index.ts +12 -0
  8. package/codeApp/src/generated/models/AzureKeyVaultModel.ts +107 -0
  9. package/codeApp/src/generated/models/JiraModel.ts +501 -0
  10. package/codeApp/src/generated/models/Office365GroupsModel.ts +363 -0
  11. package/codeApp/src/generated/models/Office365OutlookModel.ts +2046 -0
  12. package/codeApp/src/generated/models/Office365UsersModel.ts +254 -0
  13. package/codeApp/src/generated/services/AzureKeyVaultService.ts +257 -0
  14. package/codeApp/src/generated/services/JiraService.ts +1124 -0
  15. package/codeApp/src/generated/services/Office365GroupsService.ts +326 -0
  16. package/codeApp/src/generated/services/Office365OutlookService.ts +2476 -0
  17. package/codeApp/src/generated/services/Office365UsersService.ts +358 -0
  18. package/dev files/outlook.js +218 -9
  19. package/examples/combined demo/dist/codeapp.js +1098 -1098
  20. package/examples/combined demo/dist/index.js +470 -470
  21. package/examples/combined demo/dist/power-apps-data.js +3006 -3006
  22. package/examples/combined demo/power.config.json +42 -42
  23. package/examples/dataverse Demo/dist/codeapp.js +1085 -1085
  24. package/examples/dataverse Demo/dist/index.html +54 -54
  25. package/examples/dataverse Demo/dist/index.js +82 -82
  26. package/examples/dataverse Demo/dist/power-apps-data.js +2911 -2911
  27. package/examples/dataverse Demo/power.config.json +34 -34
  28. package/examples/dataverse Demo/readme.md +79 -79
  29. package/examples/groups Demo/dist/codeapp.js +1085 -1085
  30. package/examples/groups Demo/dist/index.js +113 -113
  31. package/examples/groups Demo/dist/power-apps-data.js +2911 -2911
  32. package/examples/kanban/dist/dataverse.js +94 -94
  33. package/examples/kanban/dist/environmentVar.js +55 -55
  34. package/examples/kanban/dist/office365groups.js +97 -97
  35. package/examples/kanban/dist/office365users.js +169 -169
  36. package/examples/kanban/dist/outlook.js +162 -162
  37. package/examples/kanban/dist/power-apps-data.js +2953 -2953
  38. package/examples/kanban/dist/sharepoint.js +339 -339
  39. package/examples/myProfile/dist/index.html +184 -184
  40. package/examples/myProfile/dist/index.js +141 -141
  41. package/examples/myProfile/dist/office365users.js +169 -169
  42. package/examples/myProfile/dist/power-apps-data.js +2953 -2953
  43. package/examples/myProfile/power.config.json +22 -22
  44. package/examples/myProfile/readme.md +79 -79
  45. package/examples/outlook Demo/dist/codeapp.js +1085 -1085
  46. package/examples/outlook Demo/dist/index.html +35 -35
  47. package/examples/outlook Demo/dist/index.js +170 -170
  48. package/examples/outlook Demo/dist/outlook.js +121 -121
  49. package/examples/outlook Demo/dist/power-apps-data.js +2911 -2911
  50. package/examples/outlook Demo/dist/styles.css +84 -84
  51. package/examples/outlook Demo/readme.md +82 -82
  52. package/examples/outlook Demo2/OutlookDemo_1_0_0_1.zip +0 -0
  53. package/examples/outlook Demo2/agent/decision-log.md +7 -0
  54. package/examples/{solution explorer → outlook Demo2}/dist/codeapp.js +245 -9
  55. package/examples/outlook Demo2/dist/index.html +98 -0
  56. package/examples/outlook Demo2/dist/index.js +272 -0
  57. package/examples/outlook Demo2/dist/styles.css +639 -0
  58. package/examples/outlook Demo2/power.config.json +23 -0
  59. package/examples/outlook Demo2/src/generated/index.ts +14 -0
  60. package/examples/outlook Demo2/src/generated/models/Office365GroupsModel.ts +363 -0
  61. package/examples/outlook Demo2/src/generated/models/Office365OutlookModel.ts +2046 -0
  62. package/examples/outlook Demo2/src/generated/models/Office365UsersModel.ts +254 -0
  63. package/examples/outlook Demo2/src/generated/services/Office365GroupsService.ts +326 -0
  64. package/examples/outlook Demo2/src/generated/services/Office365OutlookService.ts +2476 -0
  65. package/examples/outlook Demo2/src/generated/services/Office365UsersService.ts +358 -0
  66. package/examples/planning Poker/.vscode/settings.json +4 -4
  67. package/examples/planning Poker/additional files/customizations (tables).xml +6428 -6428
  68. package/examples/planning Poker/additional files/dataverse-tables.json +165 -165
  69. package/examples/planning Poker/additional files/readme.md +122 -122
  70. package/examples/planning Poker/dist/dataverse.js +78 -78
  71. package/examples/planning Poker/dist/index.html +198 -198
  72. package/examples/planning Poker/dist/index.js +954 -954
  73. package/examples/planning Poker/dist/power-apps-data.js +2953 -2953
  74. package/examples/planning Poker/dist/styles.css +815 -815
  75. package/examples/sharePoint Demo/agent/decision-log.md +5 -5
  76. package/examples/sharePoint Demo/dist/codeapp.js +1085 -1085
  77. package/examples/sharePoint Demo/dist/index.js +262 -262
  78. package/examples/sharePoint Demo/dist/power-apps-data.js +2911 -2911
  79. package/examples/sharePoint Demo/power.config.json +22 -22
  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 +2953 -2953
  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 -1
  88. package/readme.md +33 -4
  89. package/examples/solution explorer/agent/decision-log.md +0 -27
  90. package/examples/solution explorer/agent/mockup-01-swiss-grid.html +0 -452
  91. package/examples/solution explorer/agent/mockup-02-dark-glass.html +0 -496
  92. package/examples/solution explorer/agent/mockup-03-paper-console.html +0 -510
  93. package/examples/solution explorer/agent/mockup-04-neon-noir.html +0 -546
  94. package/examples/solution explorer/agent/mockup-05-zen-garden.html +0 -534
  95. package/examples/solution explorer/dist/index.html +0 -80
  96. package/examples/solution explorer/dist/index.js +0 -735
  97. package/examples/solution explorer/dist/styles.css +0 -571
  98. package/examples/solution explorer/power.config.json +0 -151
  99. /package/examples/{solution explorer → outlook Demo2}/dist/icon-512.png +0 -0
  100. /package/examples/{solution explorer → outlook Demo2}/dist/power-apps-data.js +0 -0
@@ -1,35 +1,35 @@
1
- <!doctype html>
2
- <html lang="en">
3
- <head>
4
- <meta charset="UTF-8" />
5
- <meta name="viewport" content="width=device-width, initial-scale=1.0" />
6
- <title>Outlook Inbox</title>
7
- <script type="importmap">
8
- {
9
- "imports": {
10
- "@microsoft/power-apps/data": "./power-apps-data.js"
11
- }
12
- }
13
- </script>
14
- <link rel="stylesheet" href="styles.css" />
15
- </head>
16
- <body>
17
- <div id="root">
18
- <h1>My Inbox</h1>
19
- <div id="loading">Loading emails...</div>
20
- <table id="emailTable" style="display:none">
21
- <thead>
22
- <tr>
23
- <th>From</th>
24
- <th>Subject</th>
25
- <th>Received</th>
26
- <th>Read</th>
27
- </tr>
28
- </thead>
29
- <tbody id="emailBody"></tbody>
30
- </table>
31
- <div id="error" style="display:none"></div>
32
- </div>
33
- <script type="module" src="index.js"></script>
34
- </body>
35
- </html>
1
+ <!doctype html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8" />
5
+ <meta name="viewport" content="width=device-width, initial-scale=1.0" />
6
+ <title>Outlook Inbox</title>
7
+ <script type="importmap">
8
+ {
9
+ "imports": {
10
+ "@microsoft/power-apps/data": "./power-apps-data.js"
11
+ }
12
+ }
13
+ </script>
14
+ <link rel="stylesheet" href="styles.css" />
15
+ </head>
16
+ <body>
17
+ <div id="root">
18
+ <h1>My Inbox</h1>
19
+ <div id="loading">Loading emails...</div>
20
+ <table id="emailTable" style="display:none">
21
+ <thead>
22
+ <tr>
23
+ <th>From</th>
24
+ <th>Subject</th>
25
+ <th>Received</th>
26
+ <th>Read</th>
27
+ </tr>
28
+ </thead>
29
+ <tbody id="emailBody"></tbody>
30
+ </table>
31
+ <div id="error" style="display:none"></div>
32
+ </div>
33
+ <script type="module" src="index.js"></script>
34
+ </body>
35
+ </html>
@@ -1,170 +1,170 @@
1
- import { listEmails } from './codeapp.js';
2
-
3
- let eLoading = document.getElementById('loading');
4
- let eTable = document.getElementById('emailTable');
5
- let eBody = document.getElementById('emailBody');
6
- let eError = document.getElementById('error');
7
-
8
- function parseJsonIfNeeded(oValue) {
9
- if (typeof oValue !== 'string') return oValue;
10
-
11
- try {
12
- return JSON.parse(oValue);
13
- } catch {
14
- return oValue;
15
- }
16
- }
17
-
18
- function isPlainObject(oValue) {
19
- return oValue != null && typeof oValue === 'object' && Array.isArray(oValue) === false;
20
- }
21
-
22
- function looksLikeEmailRecord(oValue) {
23
- if (!isPlainObject(oValue)) return false;
24
-
25
- return Boolean(
26
- oValue.Subject ||
27
- oValue.subject ||
28
- oValue.From ||
29
- oValue.from ||
30
- oValue.DateTimeReceived ||
31
- oValue.receivedDateTime ||
32
- oValue.Id ||
33
- oValue.id
34
- );
35
- }
36
-
37
- function findEmailArray(oValue, oSeen = new Set(), iDepth = 0) {
38
- var oParsed = parseJsonIfNeeded(oValue);
39
-
40
- if (Array.isArray(oParsed)) {
41
- if (oParsed.length === 0 || looksLikeEmailRecord(oParsed[0])) return oParsed;
42
-
43
- for (var iArrayIndex = 0; iArrayIndex < oParsed.length; iArrayIndex += 1) {
44
- var aNested = findEmailArray(oParsed[iArrayIndex], oSeen, iDepth + 1);
45
- if (aNested.length > 0) return aNested;
46
- }
47
-
48
- return [];
49
- }
50
-
51
- if (!isPlainObject(oParsed) || oSeen.has(oParsed) || iDepth > 6) return [];
52
-
53
- oSeen.add(oParsed);
54
-
55
- var aKeys = Object.keys(oParsed);
56
- for (var iKeyIndex = 0; iKeyIndex < aKeys.length; iKeyIndex += 1) {
57
- var sKey = aKeys[iKeyIndex];
58
- var aNested = findEmailArray(oParsed[sKey], oSeen, iDepth + 1);
59
- if (aNested.length > 0) return aNested;
60
- }
61
-
62
- return [];
63
- }
64
-
65
- function extractEmails(oResult) {
66
- return findEmailArray(oResult);
67
- }
68
-
69
- function getSenderText(oEmail) {
70
- if (!oEmail) return '';
71
- if (typeof oEmail.From === 'string') return oEmail.From;
72
- if (oEmail.From && typeof oEmail.From === 'object') {
73
- return oEmail.From.Email || oEmail.From.Address || oEmail.From.Name || '';
74
- }
75
- return oEmail.from || '';
76
- }
77
-
78
- function getSubjectText(oEmail) {
79
- return oEmail.Subject || oEmail.subject || '(No Subject)';
80
- }
81
-
82
- function getReceivedDate(oEmail) {
83
- return oEmail.DateTimeReceived || oEmail.ReceivedTime || oEmail.receivedDateTime || '';
84
- }
85
-
86
- function isEmailRead(oEmail) {
87
- return oEmail.IsRead === true || oEmail.isRead === true;
88
- }
89
-
90
- function formatDiagnostic(oResult) {
91
- try {
92
- return JSON.stringify(oResult, null, 2).slice(0, 2000);
93
- } catch {
94
- return String(oResult);
95
- }
96
- }
97
-
98
- function formatDate(sDate) {
99
- if (!sDate) return '';
100
- var oDate = new Date(sDate);
101
- return oDate.toLocaleDateString() + ' ' + oDate.toLocaleTimeString();
102
- }
103
-
104
- function escapeHtml(sText) {
105
- if (!sText) return '';
106
- let sStr = String(sText);
107
- return sStr
108
- .replace(new RegExp('&', 'g'), '&amp;')
109
- .replace(new RegExp('<', 'g'), '&lt;')
110
- .replace(new RegExp('>', 'g'), '&gt;')
111
- .replace(new RegExp('"', 'g'), '&quot;')
112
- .replace(new RegExp("'", 'g'), '&#39;');
113
- }
114
-
115
- function renderEmails(aEmails) {
116
- eBody.innerHTML = '';
117
-
118
- if (aEmails.length === 0) {
119
- eBody.innerHTML = '<tr><td colspan="4">No emails found.</td></tr>';
120
- }
121
-
122
- aEmails.forEach((oEmail) => {
123
- var sFrom = escapeHtml(getSenderText(oEmail));
124
- var sSubject = escapeHtml(getSubjectText(oEmail));
125
- var sReceived = formatDate(getReceivedDate(oEmail));
126
- var bRead = isEmailRead(oEmail);
127
- var sRow = '<tr>' +
128
- '<td>' + sFrom + '</td>' +
129
- '<td>' + sSubject + '</td>' +
130
- '<td>' + sReceived + '</td>' +
131
- '<td>' + (bRead ? 'Yes' : 'No') + '</td>' +
132
- '</tr>';
133
- eBody.innerHTML += sRow;
134
- });
135
- eLoading.style.display = 'none';
136
- eTable.style.display = 'table';
137
- }
138
-
139
- function showError(sMessage) {
140
- eLoading.style.display = 'none';
141
- eError.style.display = 'block';
142
- eError.textContent = 'Error: ' + sMessage;
143
- }
144
-
145
- async function boot() {
146
- try {
147
- var oResult = await listEmails({ folderId: 'Inbox', top: 10 });
148
- var aEmails = extractEmails(oResult);
149
-
150
- if (aEmails.length === 0) {
151
- var oFallbackResult = await listEmails({ top: 10 });
152
- var aFallbackEmails = extractEmails(oFallbackResult);
153
-
154
- if (aFallbackEmails.length > 0) {
155
- renderEmails(aFallbackEmails);
156
- return;
157
- }
158
-
159
- showError('No emails extracted from Outlook response. Raw response: ' + formatDiagnostic(oResult));
160
- renderEmails([]);
161
- return;
162
- }
163
-
164
- renderEmails(aEmails);
165
- } catch (oErr) {
166
- showError('Outlook: ' + (oErr.message || oErr));
167
- }
168
- }
169
-
170
- boot();
1
+ import { listEmails } from './codeapp.js';
2
+
3
+ let eLoading = document.getElementById('loading');
4
+ let eTable = document.getElementById('emailTable');
5
+ let eBody = document.getElementById('emailBody');
6
+ let eError = document.getElementById('error');
7
+
8
+ function parseJsonIfNeeded(oValue) {
9
+ if (typeof oValue !== 'string') return oValue;
10
+
11
+ try {
12
+ return JSON.parse(oValue);
13
+ } catch {
14
+ return oValue;
15
+ }
16
+ }
17
+
18
+ function isPlainObject(oValue) {
19
+ return oValue != null && typeof oValue === 'object' && Array.isArray(oValue) === false;
20
+ }
21
+
22
+ function looksLikeEmailRecord(oValue) {
23
+ if (!isPlainObject(oValue)) return false;
24
+
25
+ return Boolean(
26
+ oValue.Subject ||
27
+ oValue.subject ||
28
+ oValue.From ||
29
+ oValue.from ||
30
+ oValue.DateTimeReceived ||
31
+ oValue.receivedDateTime ||
32
+ oValue.Id ||
33
+ oValue.id
34
+ );
35
+ }
36
+
37
+ function findEmailArray(oValue, oSeen = new Set(), iDepth = 0) {
38
+ var oParsed = parseJsonIfNeeded(oValue);
39
+
40
+ if (Array.isArray(oParsed)) {
41
+ if (oParsed.length === 0 || looksLikeEmailRecord(oParsed[0])) return oParsed;
42
+
43
+ for (var iArrayIndex = 0; iArrayIndex < oParsed.length; iArrayIndex += 1) {
44
+ var aNested = findEmailArray(oParsed[iArrayIndex], oSeen, iDepth + 1);
45
+ if (aNested.length > 0) return aNested;
46
+ }
47
+
48
+ return [];
49
+ }
50
+
51
+ if (!isPlainObject(oParsed) || oSeen.has(oParsed) || iDepth > 6) return [];
52
+
53
+ oSeen.add(oParsed);
54
+
55
+ var aKeys = Object.keys(oParsed);
56
+ for (var iKeyIndex = 0; iKeyIndex < aKeys.length; iKeyIndex += 1) {
57
+ var sKey = aKeys[iKeyIndex];
58
+ var aNested = findEmailArray(oParsed[sKey], oSeen, iDepth + 1);
59
+ if (aNested.length > 0) return aNested;
60
+ }
61
+
62
+ return [];
63
+ }
64
+
65
+ function extractEmails(oResult) {
66
+ return findEmailArray(oResult);
67
+ }
68
+
69
+ function getSenderText(oEmail) {
70
+ if (!oEmail) return '';
71
+ if (typeof oEmail.From === 'string') return oEmail.From;
72
+ if (oEmail.From && typeof oEmail.From === 'object') {
73
+ return oEmail.From.Email || oEmail.From.Address || oEmail.From.Name || '';
74
+ }
75
+ return oEmail.from || '';
76
+ }
77
+
78
+ function getSubjectText(oEmail) {
79
+ return oEmail.Subject || oEmail.subject || '(No Subject)';
80
+ }
81
+
82
+ function getReceivedDate(oEmail) {
83
+ return oEmail.DateTimeReceived || oEmail.ReceivedTime || oEmail.receivedDateTime || '';
84
+ }
85
+
86
+ function isEmailRead(oEmail) {
87
+ return oEmail.IsRead === true || oEmail.isRead === true;
88
+ }
89
+
90
+ function formatDiagnostic(oResult) {
91
+ try {
92
+ return JSON.stringify(oResult, null, 2).slice(0, 2000);
93
+ } catch {
94
+ return String(oResult);
95
+ }
96
+ }
97
+
98
+ function formatDate(sDate) {
99
+ if (!sDate) return '';
100
+ var oDate = new Date(sDate);
101
+ return oDate.toLocaleDateString() + ' ' + oDate.toLocaleTimeString();
102
+ }
103
+
104
+ function escapeHtml(sText) {
105
+ if (!sText) return '';
106
+ let sStr = String(sText);
107
+ return sStr
108
+ .replace(new RegExp('&', 'g'), '&amp;')
109
+ .replace(new RegExp('<', 'g'), '&lt;')
110
+ .replace(new RegExp('>', 'g'), '&gt;')
111
+ .replace(new RegExp('"', 'g'), '&quot;')
112
+ .replace(new RegExp("'", 'g'), '&#39;');
113
+ }
114
+
115
+ function renderEmails(aEmails) {
116
+ eBody.innerHTML = '';
117
+
118
+ if (aEmails.length === 0) {
119
+ eBody.innerHTML = '<tr><td colspan="4">No emails found.</td></tr>';
120
+ }
121
+
122
+ aEmails.forEach((oEmail) => {
123
+ var sFrom = escapeHtml(getSenderText(oEmail));
124
+ var sSubject = escapeHtml(getSubjectText(oEmail));
125
+ var sReceived = formatDate(getReceivedDate(oEmail));
126
+ var bRead = isEmailRead(oEmail);
127
+ var sRow = '<tr>' +
128
+ '<td>' + sFrom + '</td>' +
129
+ '<td>' + sSubject + '</td>' +
130
+ '<td>' + sReceived + '</td>' +
131
+ '<td>' + (bRead ? 'Yes' : 'No') + '</td>' +
132
+ '</tr>';
133
+ eBody.innerHTML += sRow;
134
+ });
135
+ eLoading.style.display = 'none';
136
+ eTable.style.display = 'table';
137
+ }
138
+
139
+ function showError(sMessage) {
140
+ eLoading.style.display = 'none';
141
+ eError.style.display = 'block';
142
+ eError.textContent = 'Error: ' + sMessage;
143
+ }
144
+
145
+ async function boot() {
146
+ try {
147
+ var oResult = await listEmails({ folderId: 'Inbox', top: 10 });
148
+ var aEmails = extractEmails(oResult);
149
+
150
+ if (aEmails.length === 0) {
151
+ var oFallbackResult = await listEmails({ top: 10 });
152
+ var aFallbackEmails = extractEmails(oFallbackResult);
153
+
154
+ if (aFallbackEmails.length > 0) {
155
+ renderEmails(aFallbackEmails);
156
+ return;
157
+ }
158
+
159
+ showError('No emails extracted from Outlook response. Raw response: ' + formatDiagnostic(oResult));
160
+ renderEmails([]);
161
+ return;
162
+ }
163
+
164
+ renderEmails(aEmails);
165
+ } catch (oErr) {
166
+ showError('Outlook: ' + (oErr.message || oErr));
167
+ }
168
+ }
169
+
170
+ boot();
@@ -1,121 +1,121 @@
1
- import { getClient } from "@microsoft/power-apps/data";
2
-
3
- // ── Data source name (must match connectionReferences in power.config.json) ──
4
- const DATA_SOURCE_CANDIDATES = ["office365outlook", "Office365Outlook", "office365"];
5
- const OUTLOOK_APIS = {
6
- GetEmailsV3: {
7
- path: "/{connectionId}/v3/Mail",
8
- method: "GET",
9
- parameters: [
10
- { name: "connectionId", in: "path", required: true },
11
- { name: "folderPath", in: "query", required: false },
12
- { name: "to", in: "query", required: false },
13
- { name: "cc", in: "query", required: false },
14
- { name: "toOrCc", in: "query", required: false },
15
- { name: "from", in: "query", required: false },
16
- { name: "importance", in: "query", required: false },
17
- { name: "fetchOnlyWithAttachment", in: "query", required: false },
18
- { name: "subjectFilter", in: "query", required: false },
19
- { name: "fetchOnlyUnread", in: "query", required: false },
20
- { name: "fetchOnlyFlagged", in: "query", required: false },
21
- { name: "mailboxAddress", in: "query", required: false },
22
- { name: "includeAttachments", in: "query", required: false },
23
- { name: "searchQuery", in: "query", required: false },
24
- { name: "top", in: "query", required: false },
25
- ],
26
- },
27
- };
28
-
29
- // ── Initialize SDK client for the Office 365 Outlook connector ──
30
- function initClient() {
31
- const dataSourcesInfo = {};
32
-
33
- DATA_SOURCE_CANDIDATES.forEach((sDataSourceName) => {
34
- dataSourcesInfo[sDataSourceName] = {
35
- tableId: "",
36
- version: "",
37
- primaryKey: "",
38
- dataSourceType: "Connector",
39
- apis: OUTLOOK_APIS,
40
- };
41
- });
42
-
43
- return getClient(dataSourcesInfo);
44
- }
45
-
46
- function stringifyErrorDetails(oError) {
47
- if (!oError) return "Operation failed";
48
- if (typeof oError === "string") return oError;
49
- if (oError instanceof Error) return oError.message || "Operation failed";
50
-
51
- var aPropertyNames = Object.getOwnPropertyNames(oError);
52
- var oSerializable = {};
53
- aPropertyNames.forEach((sName) => {
54
- oSerializable[sName] = oError[sName];
55
- });
56
-
57
- try {
58
- return JSON.stringify(oSerializable);
59
- } catch {
60
- return String(oError);
61
- }
62
- }
63
-
64
- function unwrapResult(oResult) {
65
- if (oResult && oResult.success === false) {
66
- var sMessage = stringifyErrorDetails(oResult.error);
67
- if (oResult.data !== undefined) {
68
- sMessage += " | data: " + stringifyErrorDetails(oResult.data);
69
- }
70
- throw new Error(sMessage);
71
- }
72
-
73
- if (oResult && Object.prototype.hasOwnProperty.call(oResult, "data")) {
74
- return oResult.data;
75
- }
76
-
77
- return oResult;
78
- }
79
-
80
- // ── Internal: execute a connector operation ────────────────────
81
- async function execOp(operationName, parameters) {
82
- const client = await initClient();
83
- const aErrors = [];
84
-
85
- for (let iIndex = 0; iIndex < DATA_SOURCE_CANDIDATES.length; iIndex += 1) {
86
- const sDataSourceName = DATA_SOURCE_CANDIDATES[iIndex];
87
-
88
- try {
89
- const result = await client.executeAsync({
90
- connectorOperation: {
91
- tableName: sDataSourceName,
92
- operationName,
93
- parameters,
94
- },
95
- });
96
-
97
- return unwrapResult(result);
98
- } catch (oErr) {
99
- const sMessage = stringifyErrorDetails(oErr);
100
- aErrors.push(sDataSourceName + ": " + sMessage);
101
-
102
- if (sMessage.indexOf("Connection reference not found") === -1) {
103
- throw oErr;
104
- }
105
- }
106
- }
107
-
108
- throw new Error("No Outlook connection reference matched. Tried: " + aErrors.join(" || "));
109
- }
110
-
111
- // ── List Emails ────────────────────────────────────────────────
112
- export async function listEmails({ folderId = "Inbox", fetchOnlyUnread, searchQuery, top, skip } = {}) {
113
- void skip;
114
-
115
- return execOp("GetEmailsV3", {
116
- folderPath: folderId,
117
- fetchOnlyUnread,
118
- searchQuery,
119
- top: top != null ? top : 10,
120
- });
121
- }
1
+ import { getClient } from "@microsoft/power-apps/data";
2
+
3
+ // ── Data source name (must match connectionReferences in power.config.json) ──
4
+ const DATA_SOURCE_CANDIDATES = ["office365outlook", "Office365Outlook", "office365"];
5
+ const OUTLOOK_APIS = {
6
+ GetEmailsV3: {
7
+ path: "/{connectionId}/v3/Mail",
8
+ method: "GET",
9
+ parameters: [
10
+ { name: "connectionId", in: "path", required: true },
11
+ { name: "folderPath", in: "query", required: false },
12
+ { name: "to", in: "query", required: false },
13
+ { name: "cc", in: "query", required: false },
14
+ { name: "toOrCc", in: "query", required: false },
15
+ { name: "from", in: "query", required: false },
16
+ { name: "importance", in: "query", required: false },
17
+ { name: "fetchOnlyWithAttachment", in: "query", required: false },
18
+ { name: "subjectFilter", in: "query", required: false },
19
+ { name: "fetchOnlyUnread", in: "query", required: false },
20
+ { name: "fetchOnlyFlagged", in: "query", required: false },
21
+ { name: "mailboxAddress", in: "query", required: false },
22
+ { name: "includeAttachments", in: "query", required: false },
23
+ { name: "searchQuery", in: "query", required: false },
24
+ { name: "top", in: "query", required: false },
25
+ ],
26
+ },
27
+ };
28
+
29
+ // ── Initialize SDK client for the Office 365 Outlook connector ──
30
+ function initClient() {
31
+ const dataSourcesInfo = {};
32
+
33
+ DATA_SOURCE_CANDIDATES.forEach((sDataSourceName) => {
34
+ dataSourcesInfo[sDataSourceName] = {
35
+ tableId: "",
36
+ version: "",
37
+ primaryKey: "",
38
+ dataSourceType: "Connector",
39
+ apis: OUTLOOK_APIS,
40
+ };
41
+ });
42
+
43
+ return getClient(dataSourcesInfo);
44
+ }
45
+
46
+ function stringifyErrorDetails(oError) {
47
+ if (!oError) return "Operation failed";
48
+ if (typeof oError === "string") return oError;
49
+ if (oError instanceof Error) return oError.message || "Operation failed";
50
+
51
+ var aPropertyNames = Object.getOwnPropertyNames(oError);
52
+ var oSerializable = {};
53
+ aPropertyNames.forEach((sName) => {
54
+ oSerializable[sName] = oError[sName];
55
+ });
56
+
57
+ try {
58
+ return JSON.stringify(oSerializable);
59
+ } catch {
60
+ return String(oError);
61
+ }
62
+ }
63
+
64
+ function unwrapResult(oResult) {
65
+ if (oResult && oResult.success === false) {
66
+ var sMessage = stringifyErrorDetails(oResult.error);
67
+ if (oResult.data !== undefined) {
68
+ sMessage += " | data: " + stringifyErrorDetails(oResult.data);
69
+ }
70
+ throw new Error(sMessage);
71
+ }
72
+
73
+ if (oResult && Object.prototype.hasOwnProperty.call(oResult, "data")) {
74
+ return oResult.data;
75
+ }
76
+
77
+ return oResult;
78
+ }
79
+
80
+ // ── Internal: execute a connector operation ────────────────────
81
+ async function execOp(operationName, parameters) {
82
+ const client = await initClient();
83
+ const aErrors = [];
84
+
85
+ for (let iIndex = 0; iIndex < DATA_SOURCE_CANDIDATES.length; iIndex += 1) {
86
+ const sDataSourceName = DATA_SOURCE_CANDIDATES[iIndex];
87
+
88
+ try {
89
+ const result = await client.executeAsync({
90
+ connectorOperation: {
91
+ tableName: sDataSourceName,
92
+ operationName,
93
+ parameters,
94
+ },
95
+ });
96
+
97
+ return unwrapResult(result);
98
+ } catch (oErr) {
99
+ const sMessage = stringifyErrorDetails(oErr);
100
+ aErrors.push(sDataSourceName + ": " + sMessage);
101
+
102
+ if (sMessage.indexOf("Connection reference not found") === -1) {
103
+ throw oErr;
104
+ }
105
+ }
106
+ }
107
+
108
+ throw new Error("No Outlook connection reference matched. Tried: " + aErrors.join(" || "));
109
+ }
110
+
111
+ // ── List Emails ────────────────────────────────────────────────
112
+ export async function listEmails({ folderId = "Inbox", fetchOnlyUnread, searchQuery, top, skip } = {}) {
113
+ void skip;
114
+
115
+ return execOp("GetEmailsV3", {
116
+ folderPath: folderId,
117
+ fetchOnlyUnread,
118
+ searchQuery,
119
+ top: top != null ? top : 10,
120
+ });
121
+ }