shortcutxl 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.
Files changed (423) hide show
  1. package/README.md +59 -0
  2. package/agent-docs/README.md +397 -0
  3. package/agent-docs/docs/compaction.md +390 -0
  4. package/agent-docs/docs/custom-provider.md +580 -0
  5. package/agent-docs/docs/development.md +69 -0
  6. package/agent-docs/docs/extensions.md +1971 -0
  7. package/agent-docs/docs/json.md +79 -0
  8. package/agent-docs/docs/keybindings.md +174 -0
  9. package/agent-docs/docs/models.md +293 -0
  10. package/agent-docs/docs/packages.md +209 -0
  11. package/agent-docs/docs/prompt-templates.md +67 -0
  12. package/agent-docs/docs/providers.md +186 -0
  13. package/agent-docs/docs/rpc.md +1317 -0
  14. package/agent-docs/docs/sdk.md +962 -0
  15. package/agent-docs/docs/session.md +412 -0
  16. package/agent-docs/docs/settings.md +223 -0
  17. package/agent-docs/docs/shell-aliases.md +13 -0
  18. package/agent-docs/docs/skills.md +231 -0
  19. package/agent-docs/docs/terminal-setup.md +70 -0
  20. package/agent-docs/docs/termux.md +127 -0
  21. package/agent-docs/docs/themes.md +295 -0
  22. package/agent-docs/docs/tree.md +219 -0
  23. package/agent-docs/docs/tui.md +887 -0
  24. package/agent-docs/docs/windows.md +17 -0
  25. package/agent-docs/examples/README.md +25 -0
  26. package/agent-docs/examples/extensions/README.md +205 -0
  27. package/agent-docs/examples/extensions/antigravity-image-gen.ts +447 -0
  28. package/agent-docs/examples/extensions/auto-commit-on-exit.ts +49 -0
  29. package/agent-docs/examples/extensions/bash-spawn-hook.ts +30 -0
  30. package/agent-docs/examples/extensions/bookmark.ts +50 -0
  31. package/agent-docs/examples/extensions/built-in-tool-renderer.ts +256 -0
  32. package/agent-docs/examples/extensions/claude-rules.ts +86 -0
  33. package/agent-docs/examples/extensions/commands.ts +75 -0
  34. package/agent-docs/examples/extensions/confirm-destructive.ts +59 -0
  35. package/agent-docs/examples/extensions/custom-compaction.ts +126 -0
  36. package/agent-docs/examples/extensions/custom-footer.ts +63 -0
  37. package/agent-docs/examples/extensions/custom-header.ts +73 -0
  38. package/agent-docs/examples/extensions/custom-provider-anthropic/index.ts +660 -0
  39. package/agent-docs/examples/extensions/custom-provider-anthropic/package-lock.json +24 -0
  40. package/agent-docs/examples/extensions/custom-provider-anthropic/package.json +19 -0
  41. package/agent-docs/examples/extensions/custom-provider-gitlab-duo/index.ts +362 -0
  42. package/agent-docs/examples/extensions/custom-provider-gitlab-duo/package.json +16 -0
  43. package/agent-docs/examples/extensions/custom-provider-gitlab-duo/test.ts +88 -0
  44. package/agent-docs/examples/extensions/custom-provider-qwen-cli/index.ts +349 -0
  45. package/agent-docs/examples/extensions/custom-provider-qwen-cli/package.json +16 -0
  46. package/agent-docs/examples/extensions/dirty-repo-guard.ts +56 -0
  47. package/agent-docs/examples/extensions/doom-overlay/README.md +46 -0
  48. package/agent-docs/examples/extensions/doom-overlay/doom/build.sh +152 -0
  49. package/agent-docs/examples/extensions/doom-overlay/doom/doomgeneric_pi.c +72 -0
  50. package/agent-docs/examples/extensions/doom-overlay/doom-component.ts +133 -0
  51. package/agent-docs/examples/extensions/doom-overlay/doom-engine.ts +186 -0
  52. package/agent-docs/examples/extensions/doom-overlay/doom-keys.ts +108 -0
  53. package/agent-docs/examples/extensions/doom-overlay/index.ts +74 -0
  54. package/agent-docs/examples/extensions/doom-overlay/wad-finder.ts +51 -0
  55. package/agent-docs/examples/extensions/dynamic-resources/SKILL.md +8 -0
  56. package/agent-docs/examples/extensions/dynamic-resources/dynamic.json +79 -0
  57. package/agent-docs/examples/extensions/dynamic-resources/dynamic.md +5 -0
  58. package/agent-docs/examples/extensions/dynamic-resources/index.ts +15 -0
  59. package/agent-docs/examples/extensions/dynamic-tools.ts +77 -0
  60. package/agent-docs/examples/extensions/event-bus.ts +43 -0
  61. package/agent-docs/examples/extensions/file-trigger.ts +41 -0
  62. package/agent-docs/examples/extensions/git-checkpoint.ts +53 -0
  63. package/agent-docs/examples/extensions/handoff.ts +155 -0
  64. package/agent-docs/examples/extensions/hello.ts +25 -0
  65. package/agent-docs/examples/extensions/inline-bash.ts +94 -0
  66. package/agent-docs/examples/extensions/input-transform.ts +43 -0
  67. package/agent-docs/examples/extensions/interactive-shell.ts +209 -0
  68. package/agent-docs/examples/extensions/mac-system-theme.ts +47 -0
  69. package/agent-docs/examples/extensions/message-renderer.ts +59 -0
  70. package/agent-docs/examples/extensions/minimal-mode.ts +430 -0
  71. package/agent-docs/examples/extensions/modal-editor.ts +90 -0
  72. package/agent-docs/examples/extensions/model-status.ts +31 -0
  73. package/agent-docs/examples/extensions/notify.ts +55 -0
  74. package/agent-docs/examples/extensions/overlay-qa-tests.ts +936 -0
  75. package/agent-docs/examples/extensions/overlay-test.ts +159 -0
  76. package/agent-docs/examples/extensions/permission-gate.ts +37 -0
  77. package/agent-docs/examples/extensions/pirate.ts +47 -0
  78. package/agent-docs/examples/extensions/plan-mode/README.md +65 -0
  79. package/agent-docs/examples/extensions/plan-mode/index.ts +363 -0
  80. package/agent-docs/examples/extensions/plan-mode/utils.ts +173 -0
  81. package/agent-docs/examples/extensions/preset.ts +418 -0
  82. package/agent-docs/examples/extensions/protected-paths.ts +30 -0
  83. package/agent-docs/examples/extensions/qna.ts +122 -0
  84. package/agent-docs/examples/extensions/question.ts +278 -0
  85. package/agent-docs/examples/extensions/questionnaire.ts +440 -0
  86. package/agent-docs/examples/extensions/rainbow-editor.ts +90 -0
  87. package/agent-docs/examples/extensions/reload-runtime.ts +37 -0
  88. package/agent-docs/examples/extensions/rpc-demo.ts +124 -0
  89. package/agent-docs/examples/extensions/sandbox/index.ts +324 -0
  90. package/agent-docs/examples/extensions/sandbox/package-lock.json +92 -0
  91. package/agent-docs/examples/extensions/sandbox/package.json +19 -0
  92. package/agent-docs/examples/extensions/send-user-message.ts +97 -0
  93. package/agent-docs/examples/extensions/session-name.ts +27 -0
  94. package/agent-docs/examples/extensions/shutdown-command.ts +69 -0
  95. package/agent-docs/examples/extensions/snake.ts +343 -0
  96. package/agent-docs/examples/extensions/space-invaders.ts +566 -0
  97. package/agent-docs/examples/extensions/ssh.ts +233 -0
  98. package/agent-docs/examples/extensions/status-line.ts +40 -0
  99. package/agent-docs/examples/extensions/subagent/README.md +172 -0
  100. package/agent-docs/examples/extensions/subagent/agents/planner.md +37 -0
  101. package/agent-docs/examples/extensions/subagent/agents/reviewer.md +35 -0
  102. package/agent-docs/examples/extensions/subagent/agents/scout.md +50 -0
  103. package/agent-docs/examples/extensions/subagent/agents/worker.md +24 -0
  104. package/agent-docs/examples/extensions/subagent/agents.ts +130 -0
  105. package/agent-docs/examples/extensions/subagent/index.ts +1068 -0
  106. package/agent-docs/examples/extensions/subagent/prompts/implement-and-review.md +10 -0
  107. package/agent-docs/examples/extensions/subagent/prompts/implement.md +10 -0
  108. package/agent-docs/examples/extensions/subagent/prompts/scout-and-plan.md +9 -0
  109. package/agent-docs/examples/extensions/summarize.ts +206 -0
  110. package/agent-docs/examples/extensions/system-prompt-header.ts +17 -0
  111. package/agent-docs/examples/extensions/timed-confirm.ts +72 -0
  112. package/agent-docs/examples/extensions/titlebar-spinner.ts +58 -0
  113. package/agent-docs/examples/extensions/todo.ts +314 -0
  114. package/agent-docs/examples/extensions/tool-override.ts +146 -0
  115. package/agent-docs/examples/extensions/tools.ts +145 -0
  116. package/agent-docs/examples/extensions/trigger-compact.ts +40 -0
  117. package/agent-docs/examples/extensions/truncated-tool.ts +194 -0
  118. package/agent-docs/examples/extensions/widget-placement.ts +17 -0
  119. package/agent-docs/examples/extensions/with-deps/index.ts +37 -0
  120. package/agent-docs/examples/extensions/with-deps/package-lock.json +31 -0
  121. package/agent-docs/examples/extensions/with-deps/package.json +22 -0
  122. package/agent-docs/examples/rpc-extension-ui.ts +654 -0
  123. package/agent-docs/examples/sdk/01-minimal.ts +22 -0
  124. package/agent-docs/examples/sdk/02-custom-model.ts +48 -0
  125. package/agent-docs/examples/sdk/03-custom-prompt.ts +55 -0
  126. package/agent-docs/examples/sdk/04-skills.ts +53 -0
  127. package/agent-docs/examples/sdk/05-tools.ts +56 -0
  128. package/agent-docs/examples/sdk/06-extensions.ts +88 -0
  129. package/agent-docs/examples/sdk/07-context-files.ts +40 -0
  130. package/agent-docs/examples/sdk/08-prompt-templates.ts +47 -0
  131. package/agent-docs/examples/sdk/09-api-keys-and-oauth.ts +48 -0
  132. package/agent-docs/examples/sdk/10-settings.ts +54 -0
  133. package/agent-docs/examples/sdk/11-sessions.ts +48 -0
  134. package/agent-docs/examples/sdk/12-full-control.ts +82 -0
  135. package/agent-docs/examples/sdk/README.md +144 -0
  136. package/agent-docs/xll-skill.md +61 -0
  137. package/agent-docs/xll-spec.md +110 -0
  138. package/dist/cli/args.js +290 -0
  139. package/dist/cli/config-selector.js +31 -0
  140. package/dist/cli/file-processor.js +79 -0
  141. package/dist/cli/list-models.js +92 -0
  142. package/dist/cli/package-commands.js +210 -0
  143. package/dist/cli/report-settings-errors.js +11 -0
  144. package/dist/cli/session-picker.js +34 -0
  145. package/dist/cli.js +19 -0
  146. package/dist/config.js +288 -0
  147. package/dist/core/abort.js +15 -0
  148. package/dist/core/agent-loop.js +352 -0
  149. package/dist/core/agent-session.js +2019 -0
  150. package/dist/core/agent.js +410 -0
  151. package/dist/core/auth-storage.js +456 -0
  152. package/dist/core/bash-executor.js +222 -0
  153. package/dist/core/compaction/branch-summarization.js +242 -0
  154. package/dist/core/compaction/compaction.js +610 -0
  155. package/dist/core/compaction/index.js +7 -0
  156. package/dist/core/compaction/utils.js +139 -0
  157. package/dist/core/defaults.js +6 -0
  158. package/dist/core/diagnostics.js +2 -0
  159. package/dist/core/event-bus.js +25 -0
  160. package/dist/core/exec.js +71 -0
  161. package/dist/core/export-html/ansi-to-html.js +256 -0
  162. package/dist/core/export-html/index.js +238 -0
  163. package/dist/core/export-html/session-view-model.js +342 -0
  164. package/dist/core/export-html/template.css +1110 -0
  165. package/dist/core/export-html/template.html +76 -0
  166. package/dist/core/export-html/template.js +1990 -0
  167. package/dist/core/export-html/tool-renderer.js +63 -0
  168. package/dist/core/export-html/vendor/highlight.min.js +7725 -0
  169. package/dist/core/export-html/vendor/marked.min.js +1803 -0
  170. package/dist/core/extensions/index.js +9 -0
  171. package/dist/core/extensions/loader.js +422 -0
  172. package/dist/core/extensions/runner.js +651 -0
  173. package/dist/core/extensions/types.js +35 -0
  174. package/dist/core/extensions/wrapper.js +102 -0
  175. package/dist/core/footer-data-provider.js +162 -0
  176. package/dist/core/index.js +9 -0
  177. package/dist/core/keybindings.js +153 -0
  178. package/dist/core/messages.js +133 -0
  179. package/dist/core/model-registry.js +539 -0
  180. package/dist/core/model-resolver.js +370 -0
  181. package/dist/core/package-manager.js +1485 -0
  182. package/dist/core/prompt-templates.js +253 -0
  183. package/dist/core/resolve-config-value.js +59 -0
  184. package/dist/core/resource-loader.js +700 -0
  185. package/dist/core/sdk.js +197 -0
  186. package/dist/core/session-bash.js +99 -0
  187. package/dist/core/session-compaction.js +165 -0
  188. package/dist/core/session-manager.js +1153 -0
  189. package/dist/core/session-models.js +99 -0
  190. package/dist/core/session-retry.js +155 -0
  191. package/dist/core/settings-manager.js +572 -0
  192. package/dist/core/skills.js +382 -0
  193. package/dist/core/slash-commands.js +31 -0
  194. package/dist/core/system-prompt.js +161 -0
  195. package/dist/core/theme.js +770 -0
  196. package/dist/core/timings.js +26 -0
  197. package/dist/core/tools/bash.js +258 -0
  198. package/dist/core/tools/edit-diff.js +245 -0
  199. package/dist/core/tools/edit.js +148 -0
  200. package/dist/core/tools/find.js +208 -0
  201. package/dist/core/tools/grep.js +246 -0
  202. package/dist/core/tools/index.js +67 -0
  203. package/dist/core/tools/ls.js +123 -0
  204. package/dist/core/tools/path-utils.js +81 -0
  205. package/dist/core/tools/read.js +160 -0
  206. package/dist/core/tools/truncate.js +70 -0
  207. package/dist/core/tools/write.js +82 -0
  208. package/dist/custom/agents/action.js +13 -0
  209. package/dist/custom/agents/document-reader.js +70 -0
  210. package/dist/custom/agents/general.js +26 -0
  211. package/dist/custom/agents/index.js +49 -0
  212. package/dist/custom/agents/installation.js +13 -0
  213. package/dist/custom/agents/types.js +7 -0
  214. package/dist/custom/auth/refresh-timer.js +33 -0
  215. package/dist/custom/auth/shortcut-oauth.js +145 -0
  216. package/dist/custom/constants.js +21 -0
  217. package/dist/custom/context/workbook-summary.js +73 -0
  218. package/dist/custom/credits/shortcut-credits.js +29 -0
  219. package/dist/custom/cron/cron-daemon-entry.js +18 -0
  220. package/dist/custom/cron/daemon-ipc.js +131 -0
  221. package/dist/custom/cron/daemon.js +224 -0
  222. package/dist/custom/cron/jobs.js +226 -0
  223. package/dist/custom/cron/run-log.js +51 -0
  224. package/dist/custom/cron/schedule.js +72 -0
  225. package/dist/custom/cron/status-line.js +98 -0
  226. package/dist/custom/cron/store.js +87 -0
  227. package/dist/custom/cron/types.js +8 -0
  228. package/dist/custom/dev/index.js +59 -0
  229. package/dist/custom/dev/trace-export.js +58 -0
  230. package/dist/custom/ensure-excel.js +63 -0
  231. package/dist/custom/excel-config.js +36 -0
  232. package/dist/custom/preflight.js +422 -0
  233. package/dist/custom/prompts/action.js +100 -0
  234. package/dist/custom/prompts/api.js +66 -0
  235. package/dist/custom/prompts/installation.js +124 -0
  236. package/dist/custom/prompts/shared.js +138 -0
  237. package/dist/custom/providers/llm-usage.js +42 -0
  238. package/dist/custom/providers/message-converter.js +74 -0
  239. package/dist/custom/providers/provider-ids.js +9 -0
  240. package/dist/custom/providers/register-openai-codex-provider.js +27 -0
  241. package/dist/custom/providers/register-shortcut-provider.js +52 -0
  242. package/dist/custom/providers/shortcut-invoke.js +117 -0
  243. package/dist/custom/providers/shortcut-stream.js +252 -0
  244. package/dist/custom/providers/sse-protocol.js +38 -0
  245. package/dist/custom/sync-xll.js +130 -0
  246. package/dist/custom/tools/cron.js +413 -0
  247. package/dist/custom/tools/excel-exec.js +167 -0
  248. package/dist/custom/tools/excel-range.js +50 -0
  249. package/dist/custom/tools/llm-analysis.js +265 -0
  250. package/dist/custom/tools/render-helpers.js +38 -0
  251. package/dist/custom/tools/switch-mode.js +94 -0
  252. package/dist/custom/tools/task/agents.js +6 -0
  253. package/dist/custom/tools/task/index.js +8 -0
  254. package/dist/custom/tools/task/render.js +348 -0
  255. package/dist/custom/tools/task/subprocess.js +320 -0
  256. package/dist/custom/tools/task/task.js +205 -0
  257. package/dist/custom/tools/todo-list.js +195 -0
  258. package/dist/custom/tracing/session-upload.js +93 -0
  259. package/dist/index.js +45 -0
  260. package/dist/main.js +613 -0
  261. package/dist/migrations.js +265 -0
  262. package/dist/modes/index.js +8 -0
  263. package/dist/modes/interactive/components/armin.js +337 -0
  264. package/dist/modes/interactive/components/assistant-message.js +94 -0
  265. package/dist/modes/interactive/components/bash-execution.js +171 -0
  266. package/dist/modes/interactive/components/bordered-loader.js +51 -0
  267. package/dist/modes/interactive/components/branch-summary-message.js +45 -0
  268. package/dist/modes/interactive/components/compaction-summary-message.js +46 -0
  269. package/dist/modes/interactive/components/config-selector.js +488 -0
  270. package/dist/modes/interactive/components/countdown-timer.js +33 -0
  271. package/dist/modes/interactive/components/custom-editor.js +93 -0
  272. package/dist/modes/interactive/components/custom-message.js +81 -0
  273. package/dist/modes/interactive/components/daxnuts.js +140 -0
  274. package/dist/modes/interactive/components/diff.js +133 -0
  275. package/dist/modes/interactive/components/dynamic-border.js +21 -0
  276. package/dist/modes/interactive/components/extension-editor.js +105 -0
  277. package/dist/modes/interactive/components/extension-input.js +61 -0
  278. package/dist/modes/interactive/components/extension-selector.js +78 -0
  279. package/dist/modes/interactive/components/footer.js +309 -0
  280. package/dist/modes/interactive/components/index.js +33 -0
  281. package/dist/modes/interactive/components/keybinding-hints.js +61 -0
  282. package/dist/modes/interactive/components/layout.js +64 -0
  283. package/dist/modes/interactive/components/login-dialog.js +148 -0
  284. package/dist/modes/interactive/components/model-selector.js +237 -0
  285. package/dist/modes/interactive/components/oauth-selector.js +111 -0
  286. package/dist/modes/interactive/components/session-selector-search.js +157 -0
  287. package/dist/modes/interactive/components/session-selector.js +860 -0
  288. package/dist/modes/interactive/components/settings-selector.js +123 -0
  289. package/dist/modes/interactive/components/show-images-selector.js +35 -0
  290. package/dist/modes/interactive/components/skill-invocation-message.js +48 -0
  291. package/dist/modes/interactive/components/theme-selector.js +47 -0
  292. package/dist/modes/interactive/components/thinking-selector.js +47 -0
  293. package/dist/modes/interactive/components/tool-execution.js +789 -0
  294. package/dist/modes/interactive/components/tool-group.js +106 -0
  295. package/dist/modes/interactive/components/tree-selector.js +962 -0
  296. package/dist/modes/interactive/components/user-message-selector.js +115 -0
  297. package/dist/modes/interactive/components/user-message.js +48 -0
  298. package/dist/modes/interactive/components/visual-truncate.js +33 -0
  299. package/dist/modes/interactive/file-attachments.js +135 -0
  300. package/dist/modes/interactive/interactive-mode.js +3775 -0
  301. package/dist/modes/interactive/theme/dark.json +85 -0
  302. package/dist/modes/interactive/theme/light.json +85 -0
  303. package/dist/modes/interactive/theme/theme-schema.json +335 -0
  304. package/dist/modes/interactive/theme/theme.js +177 -0
  305. package/dist/modes/print-mode.js +101 -0
  306. package/dist/modes/rpc/rpc-client.js +387 -0
  307. package/dist/modes/rpc/rpc-mode.js +509 -0
  308. package/dist/modes/rpc/rpc-types.js +8 -0
  309. package/dist/subagent-entry.js +145 -0
  310. package/dist/tool-names.js +34 -0
  311. package/dist/tui/autocomplete.js +596 -0
  312. package/dist/tui/components/box.js +104 -0
  313. package/dist/tui/components/cancellable-loader.js +35 -0
  314. package/dist/tui/components/editor.js +1679 -0
  315. package/dist/tui/components/image.js +69 -0
  316. package/dist/tui/components/input.js +433 -0
  317. package/dist/tui/components/loader.js +49 -0
  318. package/dist/tui/components/markdown.js +629 -0
  319. package/dist/tui/components/select-list.js +152 -0
  320. package/dist/tui/components/settings-list.js +185 -0
  321. package/dist/tui/components/spacer.js +23 -0
  322. package/dist/tui/components/text.js +89 -0
  323. package/dist/tui/components/truncated-text.js +51 -0
  324. package/dist/tui/editor-component.js +2 -0
  325. package/dist/tui/fuzzy.js +107 -0
  326. package/dist/tui/get-east-asian-width/index.js +32 -0
  327. package/dist/tui/get-east-asian-width/lookup.js +404 -0
  328. package/dist/tui/index.js +32 -0
  329. package/dist/tui/keybindings.js +114 -0
  330. package/dist/tui/keys.js +959 -0
  331. package/dist/tui/kill-ring.js +44 -0
  332. package/dist/tui/stdin-buffer.js +317 -0
  333. package/dist/tui/terminal-image.js +288 -0
  334. package/dist/tui/terminal.js +249 -0
  335. package/dist/tui/tui/autocomplete.js +596 -0
  336. package/dist/tui/tui/components/box.js +106 -0
  337. package/dist/tui/tui/components/cancellable-loader.js +35 -0
  338. package/dist/tui/tui/components/editor.js +1679 -0
  339. package/dist/tui/tui/components/image.js +69 -0
  340. package/dist/tui/tui/components/input.js +433 -0
  341. package/dist/tui/tui/components/loader.js +49 -0
  342. package/dist/tui/tui/components/markdown.js +629 -0
  343. package/dist/tui/tui/components/select-list.js +152 -0
  344. package/dist/tui/tui/components/settings-list.js +185 -0
  345. package/dist/tui/tui/components/spacer.js +23 -0
  346. package/dist/tui/tui/components/text.js +91 -0
  347. package/dist/tui/tui/components/truncated-text.js +51 -0
  348. package/dist/tui/tui/editor-component.js +2 -0
  349. package/dist/tui/tui/fuzzy.js +107 -0
  350. package/dist/tui/tui/get-east-asian-width/index.js +32 -0
  351. package/dist/tui/tui/get-east-asian-width/lookup.js +404 -0
  352. package/dist/tui/tui/index.js +32 -0
  353. package/dist/tui/tui/keybindings.js +114 -0
  354. package/dist/tui/tui/keys.js +959 -0
  355. package/dist/tui/tui/kill-ring.js +44 -0
  356. package/dist/tui/tui/stdin-buffer.js +317 -0
  357. package/dist/tui/tui/terminal-image.js +288 -0
  358. package/dist/tui/tui/terminal.js +249 -0
  359. package/dist/tui/tui/tui.js +955 -0
  360. package/dist/tui/tui/undo-stack.js +25 -0
  361. package/dist/tui/tui/utils.js +800 -0
  362. package/dist/tui/tui.js +955 -0
  363. package/dist/tui/undo-stack.js +25 -0
  364. package/dist/tui/utils.js +800 -0
  365. package/dist/utils/changelog.js +87 -0
  366. package/dist/utils/clipboard-image.js +164 -0
  367. package/dist/utils/clipboard-native.js +14 -0
  368. package/dist/utils/clipboard.js +67 -0
  369. package/dist/utils/frontmatter.js +26 -0
  370. package/dist/utils/git.js +166 -0
  371. package/dist/utils/image-convert.js +35 -0
  372. package/dist/utils/image-resize.js +183 -0
  373. package/dist/utils/mime.js +26 -0
  374. package/dist/utils/photon.js +121 -0
  375. package/dist/utils/shell.js +217 -0
  376. package/dist/utils/sleep.js +17 -0
  377. package/dist/utils/tools-manager.js +259 -0
  378. package/package.json +78 -0
  379. package/skills/excel-com-api/SKILL.md +74 -0
  380. package/skills/excel-com-api/excel-type-library.py +27767 -0
  381. package/skills/excel-com-api/office-type-library.py +10867 -0
  382. package/skills/integrations/SKILL.md +138 -0
  383. package/skills/integrations/alphasense.md +457 -0
  384. package/skills/integrations/bloomberg.md +803 -0
  385. package/skills/integrations/calcbench.md +315 -0
  386. package/skills/integrations/capiq.md +848 -0
  387. package/skills/integrations/dynamics-365-finance.md +354 -0
  388. package/skills/integrations/earnings_transcripts.md +387 -0
  389. package/skills/integrations/factset.md +758 -0
  390. package/skills/integrations/ice-fixed-income.md +344 -0
  391. package/skills/integrations/moodys-analytics.md +313 -0
  392. package/skills/integrations/morningstar.md +433 -0
  393. package/skills/integrations/nasdaq-data-link.md +249 -0
  394. package/skills/integrations/pitchbook.md +413 -0
  395. package/skills/integrations/preqin.md +422 -0
  396. package/skills/integrations/quickbooks.md +289 -0
  397. package/skills/integrations/quickfs.md +314 -0
  398. package/skills/integrations/refinitiv.md +473 -0
  399. package/skills/integrations/sage-intacct.md +401 -0
  400. package/skills/integrations/visible-alpha.md +320 -0
  401. package/skills/integrations/xero.md +393 -0
  402. package/skills/integrations/ycharts.md +306 -0
  403. package/skills/pdf-creation/SKILL.md +93 -0
  404. package/skills/pdf-extraction/SKILL.md +32 -0
  405. package/skills/powerpoint-creation/SKILL.md +110 -0
  406. package/skills/sec-edgar/SKILL.md +127 -0
  407. package/skills/sec-edgar/sec_to_pdf.py +109 -0
  408. package/xll/ShortcutXL.xll +0 -0
  409. package/xll/modules/debug_render.py +272 -0
  410. package/xll/modules/gameboy.py +241 -0
  411. package/xll/modules/pong.py +188 -0
  412. package/xll/modules/shortcut_xl/__init__.py +18 -0
  413. package/xll/modules/shortcut_xl/_categorize.py +200 -0
  414. package/xll/modules/shortcut_xl/_com.py +108 -0
  415. package/xll/modules/shortcut_xl/_format.py +252 -0
  416. package/xll/modules/shortcut_xl/_log.py +12 -0
  417. package/xll/modules/shortcut_xl/_managed.py +116 -0
  418. package/xll/modules/shortcut_xl/_registry.py +44 -0
  419. package/xll/modules/shortcut_xl/_threading.py +161 -0
  420. package/xll/modules/shortcut_xl/_tracking.py +283 -0
  421. package/xll/modules/stocks.py +100 -0
  422. package/xll/python3.dll +0 -0
  423. package/xll/python312.dll +0 -0
@@ -0,0 +1,354 @@
1
+ **Dynamics 365 Finance Excel Formula Guide**
2
+
3
+ **Intro**
4
+ You have full access to Microsoft Dynamics 365 Finance and Operations data through the CData Excel Add-in for Dynamics 365 Finance and Operations, but you should only pull D365 Finance data **when the user explicitly tells you to**. The CData connector enables SQL-style queries against D365 Finance OData entities including general ledger, accounts payable, accounts receivable, fixed assets, and budget data. You can retrieve any data point by writing CDATAQUERY formulas directly in Excel cells.
5
+
6
+ **IMPORTANT:** Before completing a task involving Dynamics 365 Finance, you must verify:
7
+ 1. Your CDATAQUERY formulas do not return errors.
8
+ 2. All values should seem reasonable and make intuitive sense based on your general knowledge of accounting.
9
+ 3. Use cell references for dynamic values when possible as opposed to hardcoded values.
10
+ 4. Be aware that D365 Finance uses legal entities (companies); include DataAreaId filters when needed.
11
+ 5. Date formats in queries should use ISO format (YYYY-MM-DD).
12
+ 6. Entity names are case-sensitive and use PascalCase.
13
+
14
+ You should essentially gut check every value that shows up. If there are any errors or the values seem wrong, you likely wrote the SQL syntax incorrectly or are referencing invalid entity/field names. Please correct the formula until it outputs the proper value.
15
+
16
+ ---
17
+
18
+ **CData Excel Functions Overview**
19
+
20
+ CData provides one main Excel function for Dynamics 365 Finance:
21
+
22
+ | Function | Purpose | Use Case |
23
+ |----------|---------|----------|
24
+ | CDATAQUERY | Execute SQL query | Retrieve any D365 Finance data via SQL SELECT statements |
25
+
26
+ ---
27
+
28
+ **1. CDATAQUERY - SQL Query Function**
29
+
30
+ Returns data from Dynamics 365 Finance using SQL syntax. Results spill into adjacent cells.
31
+
32
+ **Syntax:** =CDATAQUERY("SQL Query")
33
+
34
+ **Basic Examples:**
35
+ =CDATAQUERY("SELECT * FROM MainAccounts LIMIT 10")
36
+ -> First 10 main accounts from chart of accounts.
37
+
38
+ =CDATAQUERY("SELECT VendorAccountNumber, VendorOrganizationName FROM Vendors WHERE VendorGroupId = 'US_SI_VG'")
39
+ -> Vendors in a specific vendor group.
40
+
41
+ =CDATAQUERY("SELECT * FROM VendorInvoiceHeaders WHERE InvoiceStatus = 'Approved'")
42
+ -> Approved vendor invoices.
43
+
44
+ **Using Cell References:**
45
+ =CDATAQUERY("SELECT * FROM CustomerInvoiceHeaders WHERE InvoiceAccount = '" & A1 & "'")
46
+ -> Invoices for customer account in cell A1.
47
+
48
+ =CDATAQUERY("SELECT * FROM VendorTransactions WHERE AmountMST > " & B1)
49
+ -> Vendor transactions exceeding amount in cell B1.
50
+
51
+ ---
52
+
53
+ **2. Connection Setup**
54
+
55
+ Before using CDATAQUERY, the CData Excel Add-in must be configured:
56
+
57
+ 1. Install CData Excel Add-in for Dynamics 365 Finance and Operations (~$500-1000/year license)
58
+ 2. Open Excel and go to CData ribbon tab
59
+ 3. Click "Get Data" or "Connect"
60
+ 4. Select Dynamics 365 Finance and Operations as data source
61
+ 5. Enter connection details:
62
+ - Organization URL (required): Your D365 Finance environment URL
63
+ - OAuth Client Id (required): Azure AD App Registration Client ID
64
+ - OAuth Client Secret (required): Azure AD App Registration Secret
65
+ - Azure Tenant (required): Your Azure AD Tenant ID
66
+ 6. Authenticate via Azure AD OAuth2 flow
67
+ 7. Connection persists for session
68
+
69
+ **Connection Properties:**
70
+ | Property | Description |
71
+ |----------|-------------|
72
+ | OrganizationUrl | D365 Finance environment URL (e.g., https://yourorg.operations.dynamics.com) |
73
+ | OAuthClientId | Azure AD registered app Client ID |
74
+ | OAuthClientSecret | Azure AD app secret |
75
+ | AzureTenant | Azure AD Tenant ID or domain |
76
+ | Schema | Optional: OData schema version |
77
+
78
+ **Azure AD App Registration:**
79
+ 1. Register app in Azure Portal > Azure Active Directory > App Registrations
80
+ 2. Add API Permission: Dynamics ERP > Impersonate user
81
+ 3. Create Client Secret
82
+ 4. Note Client ID, Secret, and Tenant ID for connection
83
+
84
+ ---
85
+
86
+ **3. Dynamics 365 Finance Entities Reference**
87
+
88
+ **General Ledger:**
89
+ | Entity | Description | Key Fields |
90
+ |--------|-------------|------------|
91
+ | MainAccounts | Chart of accounts | MainAccountId, Name, MainAccountType, DebitCreditDefault |
92
+ | LedgerJournalHeaders | GL journal headers | JournalBatchNumber, JournalName, Description, Posted |
93
+ | LedgerJournalLines | GL journal lines | JournalBatchNumber, Voucher, AccountDisplayValue, Debit, Credit |
94
+ | GeneralJournalAccountEntries | Posted GL entries | LedgerAccount, AccountingDate, TransactionCurrencyAmount |
95
+ | TrialBalances | Trial balance view | MainAccountId, OpeningBalance, Debit, Credit, EndingBalance |
96
+ | DimensionCombinations | Financial dimensions | DisplayValue, MainAccount, Department, CostCenter |
97
+
98
+ **Accounts Payable:**
99
+ | Entity | Description | Key Fields |
100
+ |--------|-------------|------------|
101
+ | Vendors | Vendor master | VendorAccountNumber, VendorOrganizationName, VendorGroupId |
102
+ | VendorInvoiceHeaders | AP invoice headers | InvoiceId, VendorAccountNumber, InvoiceDate, InvoiceAmount |
103
+ | VendorInvoiceLines | AP invoice lines | InvoiceId, ItemNumber, Quantity, UnitPrice, LineAmount |
104
+ | VendorTransactions | Vendor transactions | VendorAccountNumber, Voucher, TransDate, AmountMST |
105
+ | VendorPaymentJournalHeaders | Payment journals | JournalBatchNumber, PaymMode, BankAccountId |
106
+ | VendorPaymentJournalLines | Payment lines | JournalBatchNumber, VendorAccountNumber, AmountCurDebit |
107
+
108
+ **Accounts Receivable:**
109
+ | Entity | Description | Key Fields |
110
+ |--------|-------------|------------|
111
+ | Customers | Customer master | CustomerAccount, CustomerName, CustomerGroupId, CreditLimit |
112
+ | CustomerInvoiceHeaders | AR invoice headers | InvoiceId, InvoiceAccount, InvoiceDate, InvoiceAmount |
113
+ | CustomerInvoiceLines | AR invoice lines | InvoiceId, ItemNumber, Quantity, UnitPrice, LineAmount |
114
+ | CustomerTransactions | Customer transactions | CustomerAccount, Voucher, TransDate, AmountMST |
115
+ | CustomerPaymentJournalHeaders | Receipt journals | JournalBatchNumber, BankAccountId |
116
+ | CustomerPaymentJournalLines | Receipt lines | JournalBatchNumber, CustomerAccount, AmountCurCredit |
117
+
118
+ **Fixed Assets:**
119
+ | Entity | Description | Key Fields |
120
+ |--------|-------------|------------|
121
+ | FixedAssets | Asset master | FixedAssetNumber, Name, FixedAssetGroupId, AcquisitionDate |
122
+ | FixedAssetBooks | Asset book values | FixedAssetNumber, BookId, AcquisitionPrice, NetBookValue |
123
+ | FixedAssetTransactions | Asset transactions | FixedAssetNumber, TransactionDate, TransactionType, Amount |
124
+ | FixedAssetDepreciationProfiles | Depreciation setup | DepreciationProfileId, Method, ServiceLife |
125
+
126
+ **Budget:**
127
+ | Entity | Description | Key Fields |
128
+ |--------|-------------|------------|
129
+ | BudgetTransactionHeaders | Budget entries | BudgetTransactionCode, BudgetModelId, Date |
130
+ | BudgetTransactionLines | Budget lines | MainAccount, BudgetType, TransactionCurrencyAmount |
131
+ | BudgetAccountEntries | Budget register | LedgerDimension, Date, TransactionCurrencyAmount |
132
+
133
+ **Dimensions:**
134
+ | Entity | Description | Key Fields |
135
+ |--------|-------------|------------|
136
+ | FinancialDimensions | Dimension definitions | DimensionName, DimensionDescription |
137
+ | FinancialDimensionValues | Dimension values | DimensionValue, Description, IsActive |
138
+ | LegalEntities | Companies | DataAreaId, Name, FullPrimaryAddress |
139
+ | OperatingUnits | Business units | OperatingUnitNumber, Name, OperatingUnitType |
140
+
141
+ ---
142
+
143
+ **4. Common Field Reference**
144
+
145
+ **MainAccounts Fields:**
146
+ | Field | Description |
147
+ |-------|-------------|
148
+ | MainAccountId | Account number |
149
+ | Name | Account name |
150
+ | MainAccountType | Asset, Liability, Equity, Revenue, Expense, BalanceSheet, ProfitAndLoss |
151
+ | DebitCreditDefault | Debit or Credit |
152
+ | PostingType | Posting behavior |
153
+ | CurrencyCode | Account currency |
154
+ | DoNotAllowManualEntry | Whether manual posting allowed |
155
+ | IsSuspended | Account suspended flag |
156
+
157
+ **Vendors Fields:**
158
+ | Field | Description |
159
+ |-------|-------------|
160
+ | VendorAccountNumber | Vendor ID |
161
+ | VendorOrganizationName | Vendor name |
162
+ | VendorGroupId | Vendor group |
163
+ | PaymentTermsName | Payment terms |
164
+ | DefaultPaymentMethod | Default payment method |
165
+ | TaxExemptNumber | Tax exempt ID |
166
+ | OnHoldStatus | Hold status (No, Invoice, All) |
167
+ | PrimaryContactEmail | Primary email |
168
+ | PrimaryContactPhone | Primary phone |
169
+
170
+ **Customers Fields:**
171
+ | Field | Description |
172
+ |-------|-------------|
173
+ | CustomerAccount | Customer ID |
174
+ | CustomerName | Customer name |
175
+ | CustomerGroupId | Customer group |
176
+ | PaymentTermsName | Payment terms |
177
+ | CreditLimit | Credit limit |
178
+ | Blocked | Block status |
179
+ | SalesCurrencyCode | Sales currency |
180
+ | PrimaryContactEmail | Primary email |
181
+ | PrimaryContactPhone | Primary phone |
182
+
183
+ **VendorInvoiceHeaders Fields:**
184
+ | Field | Description |
185
+ |-------|-------------|
186
+ | InvoiceId | Invoice number |
187
+ | VendorAccountNumber | Vendor ID |
188
+ | VendorName | Vendor name |
189
+ | InvoiceDate | Invoice date |
190
+ | DueDate | Payment due date |
191
+ | InvoiceAmount | Total amount |
192
+ | InvoiceStatus | Draft, Approved, Posted, Paid |
193
+ | CurrencyCode | Invoice currency |
194
+ | Description | Description |
195
+ | PurchaseOrder | Related PO number |
196
+ | DataAreaId | Legal entity |
197
+
198
+ ---
199
+
200
+ **5. Legal Entity / DataAreaId Filtering**
201
+
202
+ Dynamics 365 Finance is multi-company. Most entities include DataAreaId (legal entity/company code).
203
+
204
+ **Filter by Legal Entity:**
205
+ =CDATAQUERY("SELECT * FROM VendorInvoiceHeaders WHERE DataAreaId = 'USMF'")
206
+ -> Invoices for USMF company only.
207
+
208
+ **Cross-Company Query:**
209
+ =CDATAQUERY("SELECT DataAreaId, VendorAccountNumber, SUM(AmountMST) as Total FROM VendorTransactions GROUP BY DataAreaId, VendorAccountNumber")
210
+ -> Vendor balances across all companies.
211
+
212
+ ---
213
+
214
+ **6. SQL Syntax Reference**
215
+
216
+ **SELECT Statement:**
217
+ ```sql
218
+ SELECT column1, column2 FROM EntityName WHERE condition ORDER BY column LIMIT n
219
+ ```
220
+
221
+ **Operators:**
222
+ | Operator | Description | Example |
223
+ |----------|-------------|---------|
224
+ | = | Equals | `WHERE InvoiceStatus = 'Posted'` |
225
+ | <> | Not equals | `WHERE OnHoldStatus <> 'All'` |
226
+ | > | Greater than | `WHERE InvoiceAmount > 1000` |
227
+ | < | Less than | `WHERE NetBookValue < 500` |
228
+ | >= | Greater or equal | `WHERE InvoiceDate >= '2024-01-01'` |
229
+ | <= | Less or equal | `WHERE DueDate <= '2024-12-31'` |
230
+ | LIKE | Pattern match | `WHERE VendorOrganizationName LIKE 'Acme%'` |
231
+ | IN | In list | `WHERE MainAccountType IN ('Revenue','Expense')` |
232
+ | IS NULL | Null check | `WHERE PurchaseOrder IS NULL` |
233
+ | AND | Logical AND | `WHERE InvoiceAmount > 0 AND InvoiceStatus = 'Posted'` |
234
+ | OR | Logical OR | `WHERE MainAccountType = 'Asset' OR MainAccountType = 'Liability'` |
235
+
236
+ **Aggregate Functions:**
237
+ | Function | Description | Example |
238
+ |----------|-------------|---------|
239
+ | SUM() | Sum values | `SELECT SUM(InvoiceAmount) FROM VendorInvoiceHeaders` |
240
+ | COUNT() | Count rows | `SELECT COUNT(*) FROM Customers` |
241
+ | AVG() | Average | `SELECT AVG(CreditLimit) FROM Customers` |
242
+ | MIN() | Minimum | `SELECT MIN(InvoiceDate) FROM CustomerInvoiceHeaders` |
243
+ | MAX() | Maximum | `SELECT MAX(InvoiceAmount) FROM VendorInvoiceHeaders` |
244
+
245
+ **GROUP BY:**
246
+ ```sql
247
+ SELECT VendorAccountNumber, SUM(InvoiceAmount) as Total FROM VendorInvoiceHeaders GROUP BY VendorAccountNumber
248
+ ```
249
+
250
+ ---
251
+
252
+ **7. Example Formulas by Use Case**
253
+
254
+ **Chart of Accounts:**
255
+ =CDATAQUERY("SELECT MainAccountId, Name, MainAccountType FROM MainAccounts WHERE IsSuspended = 0 ORDER BY MainAccountId")
256
+ -> Active GL accounts.
257
+
258
+ =CDATAQUERY("SELECT MainAccountId, Name FROM MainAccounts WHERE MainAccountType IN ('Revenue','Expense')")
259
+ -> Income statement accounts.
260
+
261
+ **Trial Balance:**
262
+ =CDATAQUERY("SELECT MainAccountId, Name, OpeningBalance, Debit, Credit, EndingBalance FROM TrialBalances WHERE AccountingDate = '2024-12-31'")
263
+ -> Trial balance as of year end.
264
+
265
+ =CDATAQUERY("SELECT MainAccountId, SUM(TransactionCurrencyAmount) as Balance FROM GeneralJournalAccountEntries WHERE AccountingDate BETWEEN '2024-01-01' AND '2024-12-31' GROUP BY MainAccountId")
266
+ -> Account balances for the year.
267
+
268
+ **Accounts Payable:**
269
+ =CDATAQUERY("SELECT VendorAccountNumber, VendorOrganizationName, SUM(AmountMST) as Balance FROM VendorTransactions WHERE AmountMST <> 0 GROUP BY VendorAccountNumber, VendorOrganizationName ORDER BY Balance DESC")
270
+ -> AP balances by vendor.
271
+
272
+ =CDATAQUERY("SELECT InvoiceId, VendorName, DueDate, InvoiceAmount FROM VendorInvoiceHeaders WHERE InvoiceStatus = 'Posted' AND DueDate < '2024-02-01' ORDER BY DueDate")
273
+ -> Overdue AP invoices.
274
+
275
+ =CDATAQUERY("SELECT VendorAccountNumber, VendorOrganizationName, COUNT(*) as InvoiceCount, SUM(InvoiceAmount) as Total FROM VendorInvoiceHeaders WHERE InvoiceDate >= '2024-01-01' GROUP BY VendorAccountNumber, VendorOrganizationName ORDER BY Total DESC LIMIT 10")
276
+ -> Top 10 vendors by spend.
277
+
278
+ **Accounts Receivable:**
279
+ =CDATAQUERY("SELECT CustomerAccount, CustomerName, SUM(AmountMST) as Balance FROM CustomerTransactions WHERE AmountMST <> 0 GROUP BY CustomerAccount, CustomerName ORDER BY Balance DESC")
280
+ -> AR balances by customer.
281
+
282
+ =CDATAQUERY("SELECT InvoiceId, CustomerName, DueDate, InvoiceAmount FROM CustomerInvoiceHeaders WHERE InvoiceStatus = 'Posted' AND DueDate < '2024-02-01' ORDER BY DueDate")
283
+ -> Overdue AR invoices.
284
+
285
+ =CDATAQUERY("SELECT CustomerAccount, CustomerName, COUNT(*) as InvoiceCount, SUM(InvoiceAmount) as Total FROM CustomerInvoiceHeaders WHERE InvoiceDate >= '2024-01-01' GROUP BY CustomerAccount, CustomerName ORDER BY Total DESC LIMIT 10")
286
+ -> Top 10 customers by revenue.
287
+
288
+ **Fixed Assets:**
289
+ =CDATAQUERY("SELECT FixedAssetNumber, Name, AcquisitionDate, AcquisitionPrice, NetBookValue FROM FixedAssets fa JOIN FixedAssetBooks fab ON fa.FixedAssetNumber = fab.FixedAssetNumber WHERE fab.BookId = 'CORP'")
290
+ -> Fixed asset register with book values.
291
+
292
+ =CDATAQUERY("SELECT FixedAssetGroupId, COUNT(*) as AssetCount, SUM(NetBookValue) as TotalNBV FROM FixedAssetBooks GROUP BY FixedAssetGroupId")
293
+ -> Asset summary by group.
294
+
295
+ **Budget vs Actual:**
296
+ =CDATAQUERY("SELECT MainAccount, SUM(TransactionCurrencyAmount) as BudgetAmount FROM BudgetTransactionLines WHERE BudgetModelId = '2024' GROUP BY MainAccount")
297
+ -> Budget amounts by account.
298
+
299
+ **Journal Entries:**
300
+ =CDATAQUERY("SELECT JournalBatchNumber, Voucher, AccountDisplayValue, Debit, Credit, Description FROM LedgerJournalLines WHERE JournalBatchNumber = '" & A1 & "' ORDER BY Voucher")
301
+ -> Journal entry details for batch in A1.
302
+
303
+ **Vendor/Customer Lookup:**
304
+ =CDATAQUERY("SELECT VendorAccountNumber, VendorOrganizationName, PrimaryContactEmail, OnHoldStatus FROM Vendors WHERE VendorOrganizationName LIKE '%" & A1 & "%'")
305
+ -> Search vendors by name.
306
+
307
+ =CDATAQUERY("SELECT CustomerAccount, CustomerName, CreditLimit, PrimaryContactEmail FROM Customers WHERE CustomerName LIKE '%" & A1 & "%'")
308
+ -> Search customers by name.
309
+
310
+ ---
311
+
312
+ **8. Error Handling**
313
+
314
+ **Common Errors:**
315
+ | Error | Cause | Solution |
316
+ |-------|-------|----------|
317
+ | Connection failed | Invalid credentials | Verify OAuth Client ID, Secret, Tenant |
318
+ | Invalid entity | Entity name wrong | Check entity names in section 3 (case-sensitive) |
319
+ | Invalid field | Field doesn't exist | Verify field names for that entity |
320
+ | Syntax error | SQL syntax issue | Check quotes, operators, parentheses |
321
+ | No data returned | Query too restrictive | Broaden WHERE conditions, check DataAreaId |
322
+ | Permission denied | Insufficient access | Check Azure AD app permissions and D365 security roles |
323
+ | Rate limit | Too many requests | Add delays, use LIMIT clauses |
324
+ | 401 Unauthorized | Token expired | Re-authenticate via CData ribbon |
325
+
326
+ **Debugging Tips:**
327
+ 1. Start with simple query: `SELECT * FROM EntityName LIMIT 5`
328
+ 2. Add WHERE clauses incrementally
329
+ 3. Verify date format: use 'YYYY-MM-DD'
330
+ 4. String values need single quotes: `WHERE VendorAccountNumber = 'V001'`
331
+ 5. Entity names are PascalCase and case-sensitive
332
+ 6. Check DataAreaId (legal entity) filter if no data returns
333
+ 7. Verify Azure AD app has Dynamics ERP permissions
334
+
335
+ ---
336
+
337
+ **Final Checklist:**
338
+ - What D365 Finance data is needed? (GL? AP? AR? Fixed Assets? Budget?)
339
+ - What time frame is required? (Use InvoiceDate, TransDate, AccountingDate filters)
340
+ - What legal entity/company? (Use DataAreaId filter)
341
+ - What dimensions are needed? (Department, CostCenter, Project)
342
+ - Are entity and field names correct? (Case-sensitive, PascalCase)
343
+ - Are string values in single quotes?
344
+ - Are dates in YYYY-MM-DD format?
345
+ - Is LIMIT clause needed for large datasets?
346
+ - Is Azure AD authentication current?
347
+
348
+ ---
349
+
350
+ **Additional Resources:**
351
+ - CData D365 Finance Driver: https://www.cdata.com/drivers/d365finops/
352
+ - CData Excel Add-in Help: https://cdn.cdata.com/help/FFG/xls/
353
+ - D365 Finance OData Reference: https://learn.microsoft.com/en-us/dynamics365/fin-ops-core/dev-itpro/data-entities/odata
354
+ - D365 Finance Data Entities: https://learn.microsoft.com/en-us/dynamics365/fin-ops-core/dev-itpro/data-entities/data-entities