@elyx-code/editor-ui 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (452) hide show
  1. package/README.md +2 -0
  2. package/package.json +109 -0
  3. package/src/App.tsx +31 -0
  4. package/src/Router.tsx +115 -0
  5. package/src/__mocks__/defaultModuleMock.ts +1 -0
  6. package/src/__mocks__/fileMock.ts +1 -0
  7. package/src/__mocks__/styleMock.ts +1 -0
  8. package/src/assets/Clock-11.1s-18px.svg +16 -0
  9. package/src/assets/Clock-11.1s-28px.svg +16 -0
  10. package/src/assets/authentication.svg +1 -0
  11. package/src/assets/canvas-backdrop-0.png +0 -0
  12. package/src/assets/canvas-backdrop-1.png +0 -0
  13. package/src/assets/canvas-backdrop-2.png +0 -0
  14. package/src/assets/canvas-backdrop-3.png +0 -0
  15. package/src/assets/canvas-backdrop-4.png +0 -0
  16. package/src/assets/canvas-backdrop-5.png +0 -0
  17. package/src/assets/canvas-backdrop.png +0 -0
  18. package/src/assets/checkmark-animation.gif +0 -0
  19. package/src/assets/checkmark-animation.mp4 +0 -0
  20. package/src/assets/code-formatting/format-black.svg +6 -0
  21. package/src/assets/code-formatting/format-dark-grey.svg +6 -0
  22. package/src/assets/code-formatting/format-light-grey.svg +6 -0
  23. package/src/assets/code-formatting/format-white.svg +6 -0
  24. package/src/assets/code-formatting/inline-black.svg +5 -0
  25. package/src/assets/code-formatting/inline-dark-grey.svg +5 -0
  26. package/src/assets/code-formatting/inline-light-grey.svg +5 -0
  27. package/src/assets/code-formatting/inline-white.svg +5 -0
  28. package/src/assets/contained-logo-full-word.png +0 -0
  29. package/src/assets/cron-job-color.png +0 -0
  30. package/src/assets/cron-job.png +0 -0
  31. package/src/assets/database-table-color.png +0 -0
  32. package/src/assets/database-table.png +0 -0
  33. package/src/assets/datatype-icons/black/any.svg +1 -0
  34. package/src/assets/datatype-icons/black/binary.svg +1 -0
  35. package/src/assets/datatype-icons/black/boolean.svg +3 -0
  36. package/src/assets/datatype-icons/black/date-time.svg +3 -0
  37. package/src/assets/datatype-icons/black/definition-entity.svg +6 -0
  38. package/src/assets/datatype-icons/black/key-file.svg +1 -0
  39. package/src/assets/datatype-icons/black/list.svg +3 -0
  40. package/src/assets/datatype-icons/black/null.svg +3 -0
  41. package/src/assets/datatype-icons/black/number.svg +13 -0
  42. package/src/assets/datatype-icons/black/project.svg +12 -0
  43. package/src/assets/datatype-icons/black/sql-program.svg +2 -0
  44. package/src/assets/datatype-icons/black/text.svg +3 -0
  45. package/src/assets/datatype-icons/black/unknown.svg +3 -0
  46. package/src/assets/datatype-icons/black/uuid.svg +4 -0
  47. package/src/assets/datatype-icons/black/void.svg +1 -0
  48. package/src/assets/datatype-icons/dark-grey/any.svg +1 -0
  49. package/src/assets/datatype-icons/dark-grey/boolean.svg +3 -0
  50. package/src/assets/datatype-icons/dark-grey/date-time.svg +3 -0
  51. package/src/assets/datatype-icons/dark-grey/definition-entity.svg +6 -0
  52. package/src/assets/datatype-icons/dark-grey/list.svg +3 -0
  53. package/src/assets/datatype-icons/dark-grey/null.svg +3 -0
  54. package/src/assets/datatype-icons/dark-grey/number.svg +13 -0
  55. package/src/assets/datatype-icons/dark-grey/project.svg +12 -0
  56. package/src/assets/datatype-icons/dark-grey/sql-program.svg +2 -0
  57. package/src/assets/datatype-icons/dark-grey/text.svg +3 -0
  58. package/src/assets/datatype-icons/dark-grey/unknown.svg +3 -0
  59. package/src/assets/datatype-icons/dark-grey/uuid.svg +4 -0
  60. package/src/assets/datatype-icons/dark-grey/void.svg +1 -0
  61. package/src/assets/datatype-icons/light-grey/any.svg +1 -0
  62. package/src/assets/datatype-icons/light-grey/boolean.svg +3 -0
  63. package/src/assets/datatype-icons/light-grey/date-time.svg +3 -0
  64. package/src/assets/datatype-icons/light-grey/definition-entity.svg +6 -0
  65. package/src/assets/datatype-icons/light-grey/list.svg +3 -0
  66. package/src/assets/datatype-icons/light-grey/null.svg +3 -0
  67. package/src/assets/datatype-icons/light-grey/number.svg +13 -0
  68. package/src/assets/datatype-icons/light-grey/project.svg +12 -0
  69. package/src/assets/datatype-icons/light-grey/sql-program.svg +2 -0
  70. package/src/assets/datatype-icons/light-grey/text.svg +3 -0
  71. package/src/assets/datatype-icons/light-grey/unknown.svg +3 -0
  72. package/src/assets/datatype-icons/light-grey/uuid.svg +4 -0
  73. package/src/assets/datatype-icons/light-grey/void.svg +1 -0
  74. package/src/assets/edit.png +0 -0
  75. package/src/assets/execution.svg +13 -0
  76. package/src/assets/favicon.svg +14 -0
  77. package/src/assets/file-search.svg +1 -0
  78. package/src/assets/http-endpoint.png +0 -0
  79. package/src/assets/image-input-placeholder.png +0 -0
  80. package/src/assets/logo-full-word-white.png +0 -0
  81. package/src/assets/logo-full-word.png +0 -0
  82. package/src/assets/password.svg +85 -0
  83. package/src/assets/pencil.png +0 -0
  84. package/src/assets/publish-project-rich-icon-2.svg +1 -0
  85. package/src/assets/publish-project-rich-icon.svg +1 -0
  86. package/src/assets/relational-database.png +0 -0
  87. package/src/assets/resources.svg +3 -0
  88. package/src/assets/resume-icon-14px.png +0 -0
  89. package/src/assets/server.png +0 -0
  90. package/src/assets/small-status/checkmark.svg +4 -0
  91. package/src/assets/small-status/error.svg +4 -0
  92. package/src/assets/small-status/loading.svg +4 -0
  93. package/src/assets/small-status/skipped.svg +11 -0
  94. package/src/assets/sql-connection-config.svg +1 -0
  95. package/src/assets/sql-row-transformer.svg +1 -0
  96. package/src/assets/ssl-certificate-config.svg +1 -0
  97. package/src/assets/sync.svg +1 -0
  98. package/src/assets/testing-logic-icon.svg +1 -0
  99. package/src/assets/versions.svg +25 -0
  100. package/src/assets/visual-programming-icon.svg +1 -0
  101. package/src/assets/warning-sign-24px.png +0 -0
  102. package/src/auth/index.ts +318 -0
  103. package/src/components/DialogLoader.tsx +94 -0
  104. package/src/components/EntityDialogHeader.tsx +110 -0
  105. package/src/components/EntityDialogSectionHeader.tsx +214 -0
  106. package/src/components/GalleryAddExternalIntegrationInfoDialog.tsx +87 -0
  107. package/src/components/GenerateProjectStartingLogicPromptDialog.tsx +281 -0
  108. package/src/components/LegacyRouteRedirector.tsx +55 -0
  109. package/src/components/ProPlanChip.tsx +23 -0
  110. package/src/components/ReportBugDialog.tsx +412 -0
  111. package/src/components/RequestIntegrationAccessDialog.tsx +261 -0
  112. package/src/components/UseTemplateProjectDialog.tsx +193 -0
  113. package/src/components/WorkspaceLayout.tsx +152 -0
  114. package/src/components/animated-svg/AnimatedCheckmark.tsx +41 -0
  115. package/src/components/animated-svg/AnimatedCrossmark.tsx +51 -0
  116. package/src/components/animated-svg/AnimatedEmailSending.tsx +38 -0
  117. package/src/components/animated-svg/AnimatedLoading.tsx +72 -0
  118. package/src/components/animated-svg/animated-svg.css +239 -0
  119. package/src/components/canvas/Canvas.tsx +16 -0
  120. package/src/components/canvas/CreateEntityMenu.tsx +2020 -0
  121. package/src/components/canvas/canvas.css +10 -0
  122. package/src/components/canvas/create-entity-menu.css +579 -0
  123. package/src/components/canvas-search/CanvasSearch.tsx +501 -0
  124. package/src/components/canvas-search/canvas-search.css +126 -0
  125. package/src/components/canvas-settings-menu/CanvasSettingsMenuButton.tsx +515 -0
  126. package/src/components/canvas-settings-menu/canvas-settings-menu.css +96 -0
  127. package/src/components/circular-image-upload/CircularImageUpload.tsx +113 -0
  128. package/src/components/circular-image-upload/circular-image-upload.css +69 -0
  129. package/src/components/costs/CostsDialog.tsx +459 -0
  130. package/src/components/data-type/DataTypeBuilder.tsx +3127 -0
  131. package/src/components/data-type/data-type-builder.css +45 -0
  132. package/src/components/dialogs/BetaAcknowledgeDialog.tsx +43 -0
  133. package/src/components/dialogs/ComplexDataDialog.tsx +458 -0
  134. package/src/components/dialogs/CronBuilderDialog.tsx +2145 -0
  135. package/src/components/dialogs/ExternalIntegrationConnections.tsx +565 -0
  136. package/src/components/dialogs/JsonEditorDialog.tsx +1392 -0
  137. package/src/components/dialogs/StringEditorDialog.tsx +268 -0
  138. package/src/components/dialogs/argument-declaration/ArgumentDeclaration.tsx +1167 -0
  139. package/src/components/dialogs/argument-declaration/ArgumentDeclarationDialogContent.tsx +128 -0
  140. package/src/components/dialogs/beta-dialog.css +165 -0
  141. package/src/components/dialogs/condition/Condition.tsx +431 -0
  142. package/src/components/dialogs/condition/ConditionDialogContent.tsx +126 -0
  143. package/src/components/dialogs/definition-entity/DefinitionEntityDialogContent.tsx +973 -0
  144. package/src/components/dialogs/function-call/FunctionCall.tsx +442 -0
  145. package/src/components/dialogs/function-call/FunctionCallDialogContent.tsx +126 -0
  146. package/src/components/dialogs/function-declaration/FunctionDeclaration.tsx +926 -0
  147. package/src/components/dialogs/function-declaration/FunctionDeclarationDialogContent.tsx +124 -0
  148. package/src/components/dialogs/generating-project-starting-logic-overlay/GeneratingProjectStartingLogicOverlay.tsx +176 -0
  149. package/src/components/dialogs/generating-project-starting-logic-overlay/generating-project-starting-logic-overlay.css +13 -0
  150. package/src/components/dialogs/global-event/GlobalEvent.tsx +475 -0
  151. package/src/components/dialogs/global-event/GlobalEventDialogContent.tsx +126 -0
  152. package/src/components/dialogs/help/HelpDialog.tsx +217 -0
  153. package/src/components/dialogs/help/HelpDilalogHomeContent.tsx +178 -0
  154. package/src/components/dialogs/help/help-dialog.css +116 -0
  155. package/src/components/dialogs/help/help-icon/HelpIconButton.tsx +41 -0
  156. package/src/components/dialogs/help/help-icon/help-icon.css +9 -0
  157. package/src/components/dialogs/input-map/InputMap.tsx +635 -0
  158. package/src/components/dialogs/input-map/InputMapDialogContent.tsx +126 -0
  159. package/src/components/dialogs/json-editor-dialog.css +4 -0
  160. package/src/components/dialogs/loop/Loop.tsx +650 -0
  161. package/src/components/dialogs/loop/LoopDialogContent.tsx +122 -0
  162. package/src/components/dialogs/operation/Operation.tsx +440 -0
  163. package/src/components/dialogs/operation/OperationDialogContent.tsx +126 -0
  164. package/src/components/dialogs/output-map/OutputMap.tsx +536 -0
  165. package/src/components/dialogs/output-map/OutputMapDialogContent.tsx +126 -0
  166. package/src/components/dialogs/property/Property.tsx +1490 -0
  167. package/src/components/dialogs/property/PropertyDialogContent.tsx +106 -0
  168. package/src/components/dialogs/search-statement/ColumnSelector.tsx +334 -0
  169. package/src/components/dialogs/search-statement/ConditionBuilder.tsx +750 -0
  170. package/src/components/dialogs/search-statement/DataAggregationSection.tsx +621 -0
  171. package/src/components/dialogs/search-statement/DataSourceSelection.tsx +734 -0
  172. package/src/components/dialogs/search-statement/EntityMetadataSection.tsx +135 -0
  173. package/src/components/dialogs/search-statement/FilterConditionsSection.tsx +151 -0
  174. package/src/components/dialogs/search-statement/InlineInputMap.tsx +153 -0
  175. package/src/components/dialogs/search-statement/LiteralValue.tsx +616 -0
  176. package/src/components/dialogs/search-statement/MainSourceAndInputsSection.tsx +271 -0
  177. package/src/components/dialogs/search-statement/NestedSearchStatementBuilder.tsx +170 -0
  178. package/src/components/dialogs/search-statement/OutputFormatSection.tsx +1779 -0
  179. package/src/components/dialogs/search-statement/ResultsSection.tsx +344 -0
  180. package/src/components/dialogs/search-statement/SearchStatementBuilder.tsx +251 -0
  181. package/src/components/dialogs/search-statement/SearchStatementDialogContent.tsx +398 -0
  182. package/src/components/dialogs/search-statement/ValueSelector.tsx +766 -0
  183. package/src/components/dialogs/search-statement/search-statement-context.tsx +1630 -0
  184. package/src/components/dialogs/search-statement/search-statement-dialog.css +56 -0
  185. package/src/components/dialogs/search-statement/test.sql +111 -0
  186. package/src/components/dialogs/value-descriptor/ValueDescriptor.tsx +824 -0
  187. package/src/components/dialogs/value-descriptor/ValueDescriptorDialogContent.tsx +124 -0
  188. package/src/components/dialogs/variable-declaration/VariableDeclaration.tsx +836 -0
  189. package/src/components/dialogs/variable-declaration/VariableDeclarationDialogContent.tsx +106 -0
  190. package/src/components/dialogs/variable-instance/VariableInstance.tsx +443 -0
  191. package/src/components/dialogs/variable-instance/VariableInstanceDialogContent.tsx +124 -0
  192. package/src/components/draggable-entity-card/ArgumentDeclaration.tsx +736 -0
  193. package/src/components/draggable-entity-card/CollapseEntityButton.tsx +170 -0
  194. package/src/components/draggable-entity-card/ConditionCard.tsx +1062 -0
  195. package/src/components/draggable-entity-card/ConnectionDeleteButton.tsx +309 -0
  196. package/src/components/draggable-entity-card/DataTypeIcon.tsx +624 -0
  197. package/src/components/draggable-entity-card/DraggableEntityCard.tsx +617 -0
  198. package/src/components/draggable-entity-card/ErrorMapProperty.tsx +464 -0
  199. package/src/components/draggable-entity-card/EventCard.tsx +700 -0
  200. package/src/components/draggable-entity-card/ExecutionInProgressValue.tsx +327 -0
  201. package/src/components/draggable-entity-card/FunctionDeclarationCard.tsx +819 -0
  202. package/src/components/draggable-entity-card/InputMapProperty.tsx +1067 -0
  203. package/src/components/draggable-entity-card/InternalCall.tsx +978 -0
  204. package/src/components/draggable-entity-card/InternalCallExecutionNode.tsx +643 -0
  205. package/src/components/draggable-entity-card/LogicScopeCallerNode.tsx +262 -0
  206. package/src/components/draggable-entity-card/LoopCard.tsx +791 -0
  207. package/src/components/draggable-entity-card/MainValueInput.tsx +523 -0
  208. package/src/components/draggable-entity-card/MainValueOutput.tsx +458 -0
  209. package/src/components/draggable-entity-card/MethodDeclaration.tsx +1088 -0
  210. package/src/components/draggable-entity-card/NestedCondition.tsx +1025 -0
  211. package/src/components/draggable-entity-card/OutputMapProperty.tsx +843 -0
  212. package/src/components/draggable-entity-card/PassthroughEntityCard.tsx +1247 -0
  213. package/src/components/draggable-entity-card/ReturnedError.tsx +549 -0
  214. package/src/components/draggable-entity-card/SmallSuccessFailureNodes.tsx +523 -0
  215. package/src/components/draggable-entity-card/SuccessFailureNodes.tsx +509 -0
  216. package/src/components/draggable-entity-card/TestEntityButton.tsx +946 -0
  217. package/src/components/draggable-entity-card/TestMenu.tsx +523 -0
  218. package/src/components/draggable-entity-card/TestMenuValidationDropdown.tsx +84 -0
  219. package/src/components/draggable-entity-card/UnreachableMarker.tsx +114 -0
  220. package/src/components/draggable-entity-card/VariableCard.tsx +1577 -0
  221. package/src/components/draggable-entity-card/VariableScopeMarker.tsx +117 -0
  222. package/src/components/draggable-entity-card/collapse-entity-button.css +44 -0
  223. package/src/components/draggable-entity-card/definition-entity/DefinitionEntityCard.tsx +1181 -0
  224. package/src/components/draggable-entity-card/definition-entity/DefinitionEntityIcon.tsx +36 -0
  225. package/src/components/draggable-entity-card/definition-entity/DefinitionEntityProperty.tsx +478 -0
  226. package/src/components/draggable-entity-card/definition-entity/DynamicFooterActions.tsx +112 -0
  227. package/src/components/draggable-entity-card/definition-entity/actions/external-integration-connection/ExportCredentialsFooterAction.tsx +461 -0
  228. package/src/components/draggable-entity-card/definition-entity/actions/external-integration-connection/RestablishConnectionFooterAction.tsx +199 -0
  229. package/src/components/draggable-entity-card/definition-entity/actions/external-integration-connection/restablish-connection-footer-action.css +85 -0
  230. package/src/components/draggable-entity-card/definition-entity/actions/google-drive/GoogleDriveFilePickerAPIFooterAction.tsx +277 -0
  231. package/src/components/draggable-entity-card/definition-entity/actions/google-drive/google-drive-file-picker-api-footer-action.css +107 -0
  232. package/src/components/draggable-entity-card/definition-entity/actions/persisted-entity/DatabaseFooterAction.tsx +452 -0
  233. package/src/components/draggable-entity-card/definition-entity/actions/persisted-entity/database-footer-action.css +86 -0
  234. package/src/components/draggable-entity-card/definition-entity/definition-entity-card.css +17 -0
  235. package/src/components/draggable-entity-card/draggable-entity-card.css +1140 -0
  236. package/src/components/draggable-entity-card/entity-locked-icon/EntityLockedIcon.tsx +133 -0
  237. package/src/components/draggable-entity-card/entity-locked-icon/entity-locked.css +8 -0
  238. package/src/components/draggable-entity-card/expand-properties-icon-button/ExpandPropertiesIconButton.tsx +84 -0
  239. package/src/components/draggable-entity-card/expand-properties-icon-button/expand-properties-icon-button.css +21 -0
  240. package/src/components/draggable-entity-card/implement-entity-icon/ImplementEntityIcon.tsx +74 -0
  241. package/src/components/draggable-entity-card/implement-entity-icon/implement-entity-icon.css +13 -0
  242. package/src/components/draggable-entity-card/logic-error/LogicErrorIconMenu.tsx +424 -0
  243. package/src/components/draggable-entity-card/logic-error/logic-error.css +23 -0
  244. package/src/components/draggable-entity-card/new-card-input-button/NewCardInputButton.tsx +193 -0
  245. package/src/components/draggable-entity-card/new-card-input-button/NewDynamicInputButton.tsx +214 -0
  246. package/src/components/draggable-entity-card/new-card-input-button/new-card-input-button.css +71 -0
  247. package/src/components/draggable-entity-card/new-card-output-button/NewCardOutputButton.tsx +192 -0
  248. package/src/components/draggable-entity-card/new-card-output-button/new-card-output-button.css +71 -0
  249. package/src/components/draggable-entity-card/termination-statement/TerminationStatementCard.tsx +1543 -0
  250. package/src/components/draggable-entity-card/termination-statement/termination-statement-card.css +17 -0
  251. package/src/components/draggable-entity-card/test-entity-button.css +55 -0
  252. package/src/components/draggable-entity-card/test-menu.css +181 -0
  253. package/src/components/draggable-entity-card/unreachable-marker.css +43 -0
  254. package/src/components/draggable-entity-card/variable-scope-marker.css +22 -0
  255. package/src/components/dynamic-value/DynamicValue.tsx +2395 -0
  256. package/src/components/dynamic-value/DynamicValueEntry.tsx +1957 -0
  257. package/src/components/dynamic-value/dynamic-value.css +230 -0
  258. package/src/components/editor/ElyxMonacoEditor.tsx +38 -0
  259. package/src/components/entity-error/EntityErrorListItem.tsx +47 -0
  260. package/src/components/entity-error/entity-error.css +198 -0
  261. package/src/components/entity-icon/EntityIcon.tsx +292 -0
  262. package/src/components/entity-icon/entity-icon.css +39 -0
  263. package/src/components/gallery-card/CreateNewProject.tsx +222 -0
  264. package/src/components/gallery-card/GalleryCard.tsx +171 -0
  265. package/src/components/gallery-card/MarketplaceCard.tsx +87 -0
  266. package/src/components/gallery-card/ProjectDuplicationCard.tsx +575 -0
  267. package/src/components/gallery-card/gallery-card.css +25 -0
  268. package/src/components/notifications/NotificationsIconButton.tsx +124 -0
  269. package/src/components/notifications/NotificationsPanel.tsx +385 -0
  270. package/src/components/notifications/notifications.css +189 -0
  271. package/src/components/online-users/LocalOnlineUsers.tsx +175 -0
  272. package/src/components/online-users/PageOnlineUsers.tsx +297 -0
  273. package/src/components/online-users/online-users.css +72 -0
  274. package/src/components/page-backdrop/PageBackdrop.tsx +8 -0
  275. package/src/components/page-backdrop/page-backdrop.css +7 -0
  276. package/src/components/project-configuration/DeleteProjectConfirmationDialog.tsx +134 -0
  277. package/src/components/project-configuration/ProjectConfigurationDialog.tsx +972 -0
  278. package/src/components/project-configuration/ProjectDataForm.tsx +121 -0
  279. package/src/components/project-configuration/UnpublishProjectConfirmationDialog.tsx +162 -0
  280. package/src/components/project-configuration/project-configuration-content.css +209 -0
  281. package/src/components/project-name/ProjectName.tsx +2025 -0
  282. package/src/components/project-name/project-name.css +599 -0
  283. package/src/components/publishing/Publication.tsx +133 -0
  284. package/src/components/publishing/history/PublicationHistoryContent.tsx +414 -0
  285. package/src/components/publishing/history/PublicationHistoryDialog.tsx +234 -0
  286. package/src/components/publishing/preview/PublicationPreviewDialog.tsx +1158 -0
  287. package/src/components/publishing/preview/PublishingPriceForecast.tsx +160 -0
  288. package/src/components/publishing/preview/PublishingResourcesDetails.tsx +91 -0
  289. package/src/components/publishing/publication-sequence/PublishingSequenceContent.tsx +375 -0
  290. package/src/components/publishing/publication-sequence/PublishingSequenceDialog.tsx +344 -0
  291. package/src/components/publishing/publishing-dialog.css +142 -0
  292. package/src/components/publishing/utils.ts +227 -0
  293. package/src/components/resources/ResourcesDialog.tsx +591 -0
  294. package/src/components/resources/UpgradeBanner.tsx +102 -0
  295. package/src/components/resources/codebase/CodebaseDetails.tsx +156 -0
  296. package/src/components/resources/cron-job/CronJobsList.tsx +532 -0
  297. package/src/components/resources/functions/FunctionsList.tsx +454 -0
  298. package/src/components/resources/http-api/HttpAPI.tsx +566 -0
  299. package/src/components/resources/http-api/HttpAPIClientModule.tsx +37 -0
  300. package/src/components/resources/logs/LogsViewer.tsx +768 -0
  301. package/src/components/resources/query.ts +74 -0
  302. package/src/components/resources/relational-database/DatabaseTable.tsx +905 -0
  303. package/src/components/resources/relational-database/RelationalDatabase.tsx +83 -0
  304. package/src/components/resources/relational-database/RelationalDatabaseSecrets.tsx +361 -0
  305. package/src/components/resources/resources-dialog.css +74 -0
  306. package/src/components/test-relational-database/DatabaseTable.tsx +913 -0
  307. package/src/components/test-relational-database/TestDatabaseDialogContent.tsx +670 -0
  308. package/src/components/test-relational-database/query.ts +74 -0
  309. package/src/components/toolbar/ToolBar.tsx +236 -0
  310. package/src/components/toolbar/toolbar.css +78 -0
  311. package/src/components/transaction-history/TransactionHistoryDialog.tsx +268 -0
  312. package/src/components/user/CurrentUserAvatar.tsx +65 -0
  313. package/src/components/user/UserChip.tsx +62 -0
  314. package/src/components/user/user.css +39 -0
  315. package/src/components/user-profile/ChangePasswordForm.tsx +67 -0
  316. package/src/components/user-profile/OwnUserProfileContent.tsx +665 -0
  317. package/src/components/user-profile/PublicUserProfileContent.tsx +99 -0
  318. package/src/components/user-profile/UserDataForm.tsx +75 -0
  319. package/src/components/user-profile/UserProfileDialog.tsx +110 -0
  320. package/src/components/user-profile/user-profile-content.css +25 -0
  321. package/src/config.ts +130 -0
  322. package/src/globals.d.ts +13 -0
  323. package/src/index.html +27 -0
  324. package/src/index.tsx +23 -0
  325. package/src/lib/badge/Badge.tsx +35 -0
  326. package/src/lib/badge/badge.css +32 -0
  327. package/src/lib/button/Button.tsx +129 -0
  328. package/src/lib/button/button.css +145 -0
  329. package/src/lib/canvas/canvas-undo-redo.ts +263 -0
  330. package/src/lib/canvas/defs.ts +170 -0
  331. package/src/lib/canvas/index.test.ts +189 -0
  332. package/src/lib/canvas/index.ts +6999 -0
  333. package/src/lib/canvas/utils.ts +59 -0
  334. package/src/lib/card/Card.tsx +62 -0
  335. package/src/lib/card/LoadingCard.tsx +82 -0
  336. package/src/lib/card/card.css +259 -0
  337. package/src/lib/chip/Chip.tsx +79 -0
  338. package/src/lib/chip/chip.css +0 -0
  339. package/src/lib/dialog/Dialog.tsx +122 -0
  340. package/src/lib/dialog/SmallDialog.tsx +61 -0
  341. package/src/lib/dialog/dialog.css +40 -0
  342. package/src/lib/display-data-structure/index.tsx +21 -0
  343. package/src/lib/dropdown/CanvasDropdownMenuCard.tsx +68 -0
  344. package/src/lib/dropdown/CanvasDropdownMenuCardOption.tsx +136 -0
  345. package/src/lib/dropdown/DropdownButton.tsx +104 -0
  346. package/src/lib/dropdown/DropdownMenuCard.tsx +324 -0
  347. package/src/lib/dropdown/DropdownMenuPopup.tsx +27 -0
  348. package/src/lib/dropdown/dropdown-button.css +76 -0
  349. package/src/lib/dropdown/dropdown-menu.css +151 -0
  350. package/src/lib/json-editor/RawJsonEditor.tsx +137 -0
  351. package/src/lib/json-editor/json-editor.css +35 -0
  352. package/src/lib/loader/Loader.tsx +120 -0
  353. package/src/lib/loader/loader.css +38 -0
  354. package/src/lib/pagination/Pagination.tsx +64 -0
  355. package/src/lib/popup/CanvasPopupBaseComponent.tsx +103 -0
  356. package/src/lib/popup/Popup.tsx +243 -0
  357. package/src/lib/popup/popup.css +16 -0
  358. package/src/lib/table/RowForm.tsx +301 -0
  359. package/src/lib/table/Table.tsx +1069 -0
  360. package/src/lib/table/table.css +249 -0
  361. package/src/lib/table/types.ts +108 -0
  362. package/src/lib/text-area/TextArea.tsx +183 -0
  363. package/src/lib/text-area/text-area.css +156 -0
  364. package/src/lib/text-field/TextField.tsx +218 -0
  365. package/src/lib/text-field/index.ts +8 -0
  366. package/src/lib/text-field/text-field.css +201 -0
  367. package/src/lib/tooltip/Tooltip.tsx +24 -0
  368. package/src/lib/tooltip/tooltip.css +17 -0
  369. package/src/localization/index.ts +47 -0
  370. package/src/main.css +343 -0
  371. package/src/pages/Auth.tsx +848 -0
  372. package/src/pages/Editor.tsx +883 -0
  373. package/src/pages/ErrorPage.tsx +179 -0
  374. package/src/pages/Gallery.tsx +1693 -0
  375. package/src/pages/NewPaymentMethodCallback.tsx +53 -0
  376. package/src/pages/NotFoundPage.tsx +126 -0
  377. package/src/pages/PricingPlans.tsx +155 -0
  378. package/src/pages/auth.css +304 -0
  379. package/src/pages/gallery.css +421 -0
  380. package/src/payments/index.ts +187 -0
  381. package/src/popup-notification/index.ts +90 -0
  382. package/src/services/database/index.ts +1 -0
  383. package/src/services/database/utils.ts +1301 -0
  384. package/src/services/editor/CanvasElement.tsx +2934 -0
  385. package/src/services/editor/CanvasElementConnectionDeleteButton.ts +204 -0
  386. package/src/services/editor/CanvasPopup.tsx +749 -0
  387. package/src/services/editor/EditorService.ts +8157 -0
  388. package/src/services/editor/area.ts +1312 -0
  389. package/src/services/editor/connections.ts +1019 -0
  390. package/src/services/editor/create/condition.ts +25 -0
  391. package/src/services/editor/create/definition-entity.ts +29 -0
  392. package/src/services/editor/create/function-call.ts +25 -0
  393. package/src/services/editor/create/global-event.ts +33 -0
  394. package/src/services/editor/create/loop.ts +25 -0
  395. package/src/services/editor/create/operation.ts +30 -0
  396. package/src/services/editor/create/utils.ts +140 -0
  397. package/src/services/editor/create/variable-declaration.ts +135 -0
  398. package/src/services/editor/create/variable-instance.ts +100 -0
  399. package/src/services/editor/editor-ui-extensions-context.ts +43 -0
  400. package/src/services/editor/entities-metadata.json +9310 -0
  401. package/src/services/editor/icons.ts +1093 -0
  402. package/src/services/editor/index.ts +1 -0
  403. package/src/services/editor/layout.ts +102 -0
  404. package/src/services/editor/modules/built-in-function-implementations/base.ts +14 -0
  405. package/src/services/editor/modules/built-in-function-implementations/create-persisted-entity/index.ts +56 -0
  406. package/src/services/editor/modules/built-in-function-implementations/delete-persisted-entity/index.ts +55 -0
  407. package/src/services/editor/modules/built-in-function-implementations/index.ts +4 -0
  408. package/src/services/editor/modules/built-in-function-implementations/update-persisted-entity/index.ts +56 -0
  409. package/src/services/editor/modules/operations-implementations/external-integrations/google-drive/get-files.ts +183 -0
  410. package/src/services/editor/modules/operations-implementations/external-integrations/google-drive/list-drives.ts +124 -0
  411. package/src/services/editor/modules/operations-implementations/external-integrations/google-drive/list-root-folders.ts +125 -0
  412. package/src/services/editor/modules/operations-implementations/external-integrations/google-drive/smart-fetch-document.ts +702 -0
  413. package/src/services/editor/modules/operations-implementations/external-integrations/google-drive/upload-document.ts +535 -0
  414. package/src/services/editor/modules/operations-implementations/external-integrations/google-gemini/generate-content.ts +193 -0
  415. package/src/services/editor/modules/operations-implementations/external-integrations/google-mail/get-emails.ts +586 -0
  416. package/src/services/editor/modules/operations-implementations/external-integrations/google-mail/send-email.ts +386 -0
  417. package/src/services/editor/modules/operations-implementations/external-integrations/index.ts +12 -0
  418. package/src/services/editor/modules/operations-implementations/external-integrations/slack/channels.ts +240 -0
  419. package/src/services/editor/modules/operations-implementations/external-integrations/slack/messages.ts +210 -0
  420. package/src/services/editor/modules/operations-implementations/external-integrations/slack/replies.ts +200 -0
  421. package/src/services/editor/modules/operations-implementations/external-integrations/slack/send-message.ts +177 -0
  422. package/src/services/editor/modules/operations-implementations/index.ts +1 -0
  423. package/src/services/editor/modules/search-node-implementation/index.ts +42 -0
  424. package/src/services/editor/modules/sql-migrations-generation.tsx +1054 -0
  425. package/src/services/editor/publication/publication.ts +578 -0
  426. package/src/services/editor/ui.ts +1348 -0
  427. package/src/services/editor/utils.ts +5868 -0
  428. package/src/services/editor/value-store.ts +619 -0
  429. package/src/services/execution/built-in-function-implementations.ts +422 -0
  430. package/src/services/execution/index.ts +4747 -0
  431. package/src/services/execution/logic.ts +121 -0
  432. package/src/services/execution/test-instance.tsx +2296 -0
  433. package/src/services/execution/utils.ts +33 -0
  434. package/src/services/execution/value-resolution.test.ts +424 -0
  435. package/src/services/execution/value-resolution.ts +4087 -0
  436. package/src/services/integrations/ExternalIntegrationsService.ts +439 -0
  437. package/src/services/integrations/api.ts +175 -0
  438. package/src/services/local-relational-database/idb_helper.ts +66 -0
  439. package/src/services/local-relational-database/index.ts +3308 -0
  440. package/src/services/local-relational-database/utils.ts +403 -0
  441. package/src/services/notifications/index.ts +525 -0
  442. package/src/services/user/index.ts +144 -0
  443. package/src/setupTests.ts +1 -0
  444. package/src/socket/socket.ts +248 -0
  445. package/src/socket/utils.ts +10 -0
  446. package/src/store/workspace.ts +12 -0
  447. package/src/theme.ts +19 -0
  448. package/src/utils/DOM.ts +39 -0
  449. package/src/utils/date.ts +169 -0
  450. package/src/utils/index.ts +158 -0
  451. package/src/utils/react.tsx +679 -0
  452. package/src/utils/testing.ts +103 -0
@@ -0,0 +1,412 @@
1
+ import React, { useState, useRef, DragEvent } from 'react';
2
+ import axios from 'axios';
3
+ import { CircularProgress } from '@mui/material';
4
+ import { envConfig } from '../config';
5
+ import { getAccessToken } from '../auth';
6
+ import { popupNotification } from '../popup-notification';
7
+ import SmallDialog from '../lib/dialog/SmallDialog';
8
+ import { useWorkspaceStore } from '../store/workspace';
9
+ import Button from '../lib/button/Button';
10
+ import DropdownMenuPopup from '../lib/dropdown/DropdownMenuPopup';
11
+
12
+ interface ReportBugDialogProps {
13
+ projectId?: string;
14
+ onClose: () => void;
15
+ }
16
+
17
+ const SEVERITY_OPTIONS = [
18
+ { value: 'low', label: 'It is annoying but I can work around it' },
19
+ { value: 'medium', label: 'A feature is broken and I have no workaround' },
20
+ { value: 'high', label: 'Data loss or completely unable to work' },
21
+ ];
22
+
23
+ const ReportBugDialog: React.FC<ReportBugDialogProps> = ({ projectId, onClose }) => {
24
+ const activeWorkspace = useWorkspaceStore((state) => state.activeWorkspace);
25
+ const [subject, setSubject] = useState('');
26
+ const [body, setBody] = useState('');
27
+ const [severity, setSeverity] = useState('low');
28
+ const [isSeverityMenuOpen, setIsSeverityMenuOpen] = useState(false);
29
+ const [files, setFiles] = useState<File[]>([]);
30
+ const [isSubmitting, setIsSubmitting] = useState(false);
31
+ const [isDragging, setIsDragging] = useState(false);
32
+ const fileInputRef = useRef<HTMLInputElement>(null);
33
+
34
+ const handleFileChange = (e: React.ChangeEvent<HTMLInputElement>) => {
35
+ if (e.target.files) {
36
+ setFiles((prev) => [...prev, ...Array.from(e.target.files!)]);
37
+ }
38
+ };
39
+
40
+ const handleDragOver = (e: DragEvent<HTMLDivElement>) => {
41
+ e.preventDefault();
42
+ setIsDragging(true);
43
+ };
44
+
45
+ const handleDragLeave = (e: DragEvent<HTMLDivElement>) => {
46
+ e.preventDefault();
47
+ setIsDragging(false);
48
+ };
49
+
50
+ const handleDrop = (e: DragEvent<HTMLDivElement>) => {
51
+ e.preventDefault();
52
+ setIsDragging(false);
53
+ if (e.dataTransfer.files && e.dataTransfer.files.length > 0) {
54
+ setFiles((prev) => [...prev, ...Array.from(e.dataTransfer.files)]);
55
+ e.dataTransfer.clearData();
56
+ }
57
+ };
58
+
59
+ const removeFile = (index: number) => {
60
+ setFiles((prev) => prev.filter((_, i) => i !== index));
61
+ };
62
+
63
+ const uploadAttachment = async (file: File, caseId: string, token: string) => {
64
+ try {
65
+ // Get presigned URL
66
+ const res = await axios.post(
67
+ `${envConfig.API_BASE_URL}/support-service/v1/cases/attachments/presign`,
68
+ {
69
+ filename: file.name,
70
+ mimetype: file.type,
71
+ size: file.size,
72
+ caseId,
73
+ },
74
+ { headers: { Authorization: 'Bearer ' + token } }
75
+ );
76
+
77
+ const uploadUrl = res.data?.data?.uploadUrl;
78
+ if (uploadUrl) {
79
+ await axios.put(uploadUrl, file, {
80
+ headers: { 'Content-Type': file.type },
81
+ }).catch(e => console.warn("Mock PUT failed (expected in dev without real presigned URL):", e));
82
+ }
83
+ } catch (error) {
84
+ console.error("Attachment upload error", error);
85
+ }
86
+ };
87
+
88
+ const handleSubmit = async () => {
89
+ if (!subject.trim() || !body.trim()) {
90
+ popupNotification({ text: 'Please fill out subject and description', color: 'warning' });
91
+ return;
92
+ }
93
+
94
+ setIsSubmitting(true);
95
+ try {
96
+ const token = await getAccessToken();
97
+ const res = await axios.post(
98
+ `${envConfig.API_BASE_URL}/support-service/v1/cases`,
99
+ {
100
+ subject,
101
+ body,
102
+ type: 'bug-report',
103
+ severity,
104
+ workspaceId: activeWorkspace?.id,
105
+ metadata: {
106
+ project: projectId,
107
+ },
108
+ },
109
+ { headers: { Authorization: 'Bearer ' + token } }
110
+ );
111
+
112
+ const createdCase = res.data?.data;
113
+ if (createdCase?.id && files.length > 0) {
114
+ await Promise.all(files.map(file => uploadAttachment(file, createdCase.id, token)));
115
+ }
116
+
117
+ popupNotification({ text: 'Bug reported successfully! Thank you.', color: 'success' });
118
+ onClose();
119
+ } catch (error) {
120
+ console.error(error);
121
+ popupNotification({ text: 'Failed to submit bug report', color: 'error' });
122
+ setIsSubmitting(false);
123
+ }
124
+ };
125
+
126
+ return (
127
+ <SmallDialog
128
+ onClose={onClose}
129
+ style={{
130
+ width: '550px',
131
+ minHeight: 'auto',
132
+ display: 'flex',
133
+ flexDirection: 'column'
134
+ }}
135
+ >
136
+ <div
137
+ style={{
138
+ display: 'flex',
139
+ flexDirection: 'column',
140
+ flex: 1,
141
+ alignItems: 'center'
142
+ }}
143
+ >
144
+ <div style={{ display: 'flex', alignItems: 'center', gap: '12px', marginBottom: '16px' }}>
145
+ <i className="fa-solid fa-bug" style={{ fontSize: '24px', color: 'var(--color-main-error)' }} />
146
+ <h2
147
+ style={{
148
+ margin: 0,
149
+ fontWeight: 500,
150
+ color: 'rgb(0, 0, 0, 0.8)'
151
+ }}
152
+ >
153
+ Report a Bug
154
+ </h2>
155
+ </div>
156
+
157
+ <p
158
+ style={{
159
+ margin: '0 0 20px 0',
160
+ color: 'rgb(0, 0, 0, 0.6)',
161
+ fontSize: '14px',
162
+ lineHeight: '1.5',
163
+ textAlign: 'center'
164
+ }}
165
+ >
166
+ Found an issue? Let us know the details so we can fix it!
167
+ </p>
168
+
169
+ <div
170
+ style={{
171
+ display: 'flex',
172
+ flexDirection: 'column',
173
+ marginBottom: '16px',
174
+ width: '100%'
175
+ }}
176
+ >
177
+ <label
178
+ style={{
179
+ marginBottom: '8px',
180
+ fontSize: '13px',
181
+ fontWeight: 500,
182
+ color: 'rgb(0, 0, 0, 0.7)'
183
+ }}
184
+ >
185
+ Subject
186
+ </label>
187
+ <input
188
+ type='text'
189
+ value={subject}
190
+ onChange={(e) => setSubject(e.target.value)}
191
+ placeholder='e.g. Canvas goes blank when I drag a node'
192
+ disabled={isSubmitting}
193
+ style={{
194
+ width: '100%',
195
+ padding: '12px',
196
+ boxSizing: 'border-box',
197
+ borderRadius: '6px',
198
+ border: '1px solid #ccc',
199
+ fontFamily: 'inherit',
200
+ fontSize: '14px'
201
+ }}
202
+ />
203
+ </div>
204
+
205
+ <div
206
+ style={{
207
+ display: 'flex',
208
+ flexDirection: 'column',
209
+ marginBottom: '16px',
210
+ width: '100%'
211
+ }}
212
+ >
213
+ <label
214
+ style={{
215
+ marginBottom: '8px',
216
+ fontSize: '13px',
217
+ fontWeight: 500,
218
+ color: 'rgb(0, 0, 0, 0.7)'
219
+ }}
220
+ >
221
+ Description
222
+ </label>
223
+ <textarea
224
+ value={body}
225
+ onChange={(e) => setBody(e.target.value)}
226
+ placeholder='Steps to reproduce...'
227
+ disabled={isSubmitting}
228
+ rows={4}
229
+ style={{
230
+ resize: 'vertical',
231
+ width: '100%',
232
+ padding: '12px',
233
+ boxSizing: 'border-box',
234
+ borderRadius: '6px',
235
+ border: '1px solid #ccc',
236
+ fontFamily: 'inherit',
237
+ fontSize: '14px'
238
+ }}
239
+ />
240
+ </div>
241
+
242
+ <div
243
+ style={{
244
+ display: 'flex',
245
+ flexDirection: 'column',
246
+ marginBottom: '16px',
247
+ width: '100%'
248
+ }}
249
+ >
250
+ <label
251
+ style={{
252
+ marginBottom: '8px',
253
+ fontSize: '13px',
254
+ fontWeight: 500,
255
+ color: 'rgb(0, 0, 0, 0.7)'
256
+ }}
257
+ >
258
+ Severity
259
+ </label>
260
+ <div
261
+ id="severity-dropdown-anchor"
262
+ onClick={(e) => {
263
+ if (isSubmitting) return;
264
+ e.stopPropagation();
265
+ setIsSeverityMenuOpen(!isSeverityMenuOpen);
266
+ }}
267
+ style={{
268
+ width: '100%',
269
+ padding: '12px',
270
+ boxSizing: 'border-box',
271
+ borderRadius: '6px',
272
+ border: '1px solid #ccc',
273
+ fontFamily: 'inherit',
274
+ fontSize: '14px',
275
+ backgroundColor: isSubmitting ? '#f5f5f5' : '#fff',
276
+ cursor: isSubmitting ? 'not-allowed' : 'pointer',
277
+ display: 'flex',
278
+ justifyContent: 'space-between',
279
+ alignItems: 'center',
280
+ color: isSubmitting ? 'rgb(0,0,0,0.4)' : 'inherit'
281
+ }}
282
+ >
283
+ <span>{SEVERITY_OPTIONS.find(o => o.value === severity)?.label}</span>
284
+ <i className="fa-solid fa-chevron-down" style={{ color: '#888' }} />
285
+ </div>
286
+ <DropdownMenuPopup
287
+ popupOptions={{
288
+ id: 'severity-dropdown-popup',
289
+ anchorQuerySelector: '#severity-dropdown-anchor',
290
+ placement: 'bottom-start',
291
+ open: isSeverityMenuOpen,
292
+ onClickAway: () => setIsSeverityMenuOpen(false),
293
+ style: { width: '486px' }
294
+ }}
295
+ value={severity}
296
+ options={SEVERITY_OPTIONS.map(opt => ({
297
+ label: opt.label,
298
+ value: opt.value,
299
+ onClick: (_, e) => {
300
+ e.stopPropagation();
301
+ setSeverity(opt.value);
302
+ setIsSeverityMenuOpen(false);
303
+ }
304
+ }))}
305
+ />
306
+ </div>
307
+
308
+ <div
309
+ style={{
310
+ display: 'flex',
311
+ flexDirection: 'column',
312
+ marginBottom: '24px',
313
+ width: '100%'
314
+ }}
315
+ >
316
+ <label
317
+ style={{
318
+ marginBottom: '8px',
319
+ fontSize: '13px',
320
+ fontWeight: 500,
321
+ color: 'rgb(0, 0, 0, 0.7)'
322
+ }}
323
+ >
324
+ Attachments (Optional)
325
+ </label>
326
+
327
+ <div
328
+ onDragOver={handleDragOver}
329
+ onDragLeave={handleDragLeave}
330
+ onDrop={handleDrop}
331
+ onClick={() => fileInputRef.current?.click()}
332
+ style={{
333
+ border: `2px dashed ${isDragging ? 'var(--color-main-primary)' : '#ccc'}`,
334
+ borderRadius: '6px',
335
+ padding: '20px',
336
+ textAlign: 'center',
337
+ backgroundColor: isDragging ? 'rgba(var(--color-main-primary-rgb), 0.05)' : '#fafafa',
338
+ cursor: 'pointer',
339
+ transition: 'all 0.2s ease',
340
+ display: 'flex',
341
+ flexDirection: 'column',
342
+ alignItems: 'center',
343
+ gap: '8px'
344
+ }}
345
+ >
346
+ <i className="fa-solid fa-cloud-arrow-up" style={{ fontSize: '24px', color: 'var(--color-light-grey)' }} />
347
+ <span style={{ fontSize: '14px', color: 'rgb(0,0,0,0.6)' }}>
348
+ Click to upload or drag & drop files here
349
+ </span>
350
+ <input
351
+ type='file'
352
+ multiple
353
+ ref={fileInputRef}
354
+ onChange={handleFileChange}
355
+ disabled={isSubmitting}
356
+ style={{ display: 'none' }}
357
+ />
358
+ </div>
359
+
360
+ {files.length > 0 && (
361
+ <div style={{ marginTop: '12px', display: 'flex', flexDirection: 'column', gap: '6px' }}>
362
+ {files.map((f, idx) => (
363
+ <div key={idx} style={{ display: 'flex', alignItems: 'center', justifyContent: 'space-between', backgroundColor: '#f0f0f0', padding: '6px 10px', borderRadius: '4px' }}>
364
+ <span style={{ fontSize: '12px', color: '#333', overflow: 'hidden', textOverflow: 'ellipsis', whiteSpace: 'nowrap' }}>{f.name}</span>
365
+ <i
366
+ className="fa-solid fa-times"
367
+ style={{ cursor: 'pointer', color: 'var(--color-main-error)', fontSize: '14px' }}
368
+ onClick={(e) => {
369
+ e.stopPropagation();
370
+ removeFile(idx);
371
+ }}
372
+ />
373
+ </div>
374
+ ))}
375
+ </div>
376
+ )}
377
+ </div>
378
+
379
+ <div
380
+ style={{
381
+ display: 'flex',
382
+ justifyContent: 'flex-end',
383
+ gap: '12px',
384
+ width: '100%',
385
+ marginTop: 'auto'
386
+ }}
387
+ >
388
+ <Button
389
+ onClick={onClose}
390
+ disabled={isSubmitting}
391
+ style={{
392
+ background: 'transparent',
393
+ color: 'rgb(0,0,0,0.7)',
394
+ border: '1px solid #ccc'
395
+ }}
396
+ >
397
+ Cancel
398
+ </Button>
399
+ <Button
400
+ onClick={handleSubmit}
401
+ loading={isSubmitting}
402
+ color="error"
403
+ >
404
+ Report Bug
405
+ </Button>
406
+ </div>
407
+ </div>
408
+ </SmallDialog>
409
+ );
410
+ };
411
+
412
+ export default ReportBugDialog;
@@ -0,0 +1,261 @@
1
+ import React, { useState } from 'react';
2
+ import axios from 'axios';
3
+ import { CircularProgress } from '@mui/material';
4
+ import { envConfig } from '../config';
5
+ import { getAccessToken } from '../auth';
6
+ import { popupNotification } from '../popup-notification';
7
+ import SmallDialog from '../lib/dialog/SmallDialog';
8
+ import { useWorkspaceStore } from '../store/workspace';
9
+ import Button from '../lib/button/Button';
10
+
11
+ interface RequestIntegrationAccessDialogProps {
12
+ integrationKey: string;
13
+ integrationName: string;
14
+ isAlreadyRequested?: boolean;
15
+ onClose: (requested?: boolean) => void;
16
+ }
17
+
18
+ const RequestIntegrationAccessDialog: React.FC<
19
+ RequestIntegrationAccessDialogProps
20
+ > = ({ integrationKey, integrationName, isAlreadyRequested, onClose }) => {
21
+ const activeWorkspace = useWorkspaceStore((state) => state.activeWorkspace);
22
+ const [reason, setReason] = useState('');
23
+ const [isSubmitting, setIsSubmitting] = useState(false);
24
+
25
+ const handleSubmit = async () => {
26
+ if (!reason.trim()) {
27
+ popupNotification({
28
+ text: 'Please provide a reason',
29
+ color: 'warning'
30
+ });
31
+ return;
32
+ }
33
+
34
+ setIsSubmitting(true);
35
+ try {
36
+ const token = await getAccessToken();
37
+ await axios.post(
38
+ `${envConfig.API_BASE_URL}/support-service/v1/cases`,
39
+ {
40
+ subject: `Access request to: ${integrationName}`,
41
+ body: reason,
42
+ type: 'access-request',
43
+ severity: 'low',
44
+ workspaceId: activeWorkspace?.id,
45
+ metadata: {
46
+ integration: integrationKey
47
+ }
48
+ },
49
+ {
50
+ headers: {
51
+ Authorization: 'Bearer ' + token
52
+ }
53
+ }
54
+ );
55
+
56
+ popupNotification({
57
+ text: 'Request submitted successfully!',
58
+ color: 'success'
59
+ });
60
+ onClose(true);
61
+ } catch (error) {
62
+ console.error(error);
63
+ popupNotification({
64
+ text: 'Failed to submit request',
65
+ color: 'error'
66
+ });
67
+ setIsSubmitting(false);
68
+ }
69
+ };
70
+
71
+ return (
72
+ <SmallDialog
73
+ style={{
74
+ width: '500px',
75
+ minHeight: 'auto',
76
+ display: 'flex',
77
+ flexDirection: 'column'
78
+ }}
79
+ onClose={() => onClose()}
80
+ >
81
+ <div
82
+ style={{
83
+ display: 'flex',
84
+ flexDirection: 'column',
85
+ flex: 1,
86
+ alignItems: 'center'
87
+ }}
88
+ >
89
+ <div style={{ display: 'flex', alignItems: 'center', marginBottom: '20px' }}>
90
+ <img
91
+ src={`${envConfig.EXTERNAL_INTEGRATIONS_LOGOS_URL}/${integrationKey}.svg`}
92
+ alt={integrationName}
93
+ style={{ width: 60, height: 60, objectFit: 'contain' }}
94
+ />
95
+ </div>
96
+
97
+ {isAlreadyRequested ? (
98
+ <>
99
+ <div
100
+ style={{
101
+ background: 'rgba(76, 175, 80, 0.08)',
102
+ color: '#4caf50',
103
+ borderRadius: '20px',
104
+ padding: '6px 14px',
105
+ fontSize: '11px',
106
+ fontWeight: 700,
107
+ textTransform: 'uppercase',
108
+ letterSpacing: '1.5px',
109
+ marginBottom: '20px',
110
+ display: 'inline-flex',
111
+ alignItems: 'center',
112
+ gap: '6px',
113
+ border: '1px solid rgba(76, 175, 80, 0.15)'
114
+ }}
115
+ >
116
+ <span
117
+ style={{
118
+ width: '6px',
119
+ height: '6px',
120
+ backgroundColor: '#4caf50',
121
+ borderRadius: '50%',
122
+ display: 'inline-block'
123
+ }}
124
+ />
125
+ Requested
126
+ </div>
127
+
128
+ <h2
129
+ style={{
130
+ margin: '0 0 16px 0',
131
+ fontWeight: 500,
132
+ color: 'rgb(0, 0, 0, 0.8)'
133
+ }}
134
+ >
135
+ Request Received
136
+ </h2>
137
+
138
+ <p
139
+ style={{
140
+ margin: '0 0 24px 0',
141
+ color: 'rgb(0, 0, 0, 0.6)',
142
+ fontSize: '14px',
143
+ lineHeight: '1.5',
144
+ textAlign: 'center'
145
+ }}
146
+ >
147
+ You have already requested access to <strong>{integrationName}</strong>. Our team is reviewing your request.
148
+ </p>
149
+ <div
150
+ style={{
151
+ display: 'flex',
152
+ justifyContent: 'center',
153
+ width: '100%',
154
+ marginTop: 'auto'
155
+ }}
156
+ >
157
+ <Button onClick={() => onClose()}>
158
+ Close
159
+ </Button>
160
+ </div>
161
+ </>
162
+ ) : (
163
+ <>
164
+ <h2
165
+ style={{
166
+ margin: '0 0 16px 0',
167
+ fontWeight: 500,
168
+ color: 'rgb(0, 0, 0, 0.8)'
169
+ }}
170
+ >
171
+ Request Access
172
+ </h2>
173
+
174
+ <p
175
+ style={{
176
+ margin: '0 0 20px 0',
177
+ color: 'rgb(0, 0, 0, 0.6)',
178
+ fontSize: '14px',
179
+ lineHeight: '1.5',
180
+ textAlign: 'center'
181
+ }}
182
+ >
183
+ The <strong>{integrationName}</strong> integration is
184
+ currently restricted or in development. Please explain why
185
+ you need access to this integration, and our team will
186
+ review your request.
187
+ </p>
188
+ <div
189
+ style={{
190
+ display: 'flex',
191
+ flexDirection: 'column',
192
+ marginBottom: '24px',
193
+ width: '100%'
194
+ }}
195
+ >
196
+ <label
197
+ htmlFor="reason"
198
+ style={{
199
+ marginBottom: '8px',
200
+ fontSize: '13px',
201
+ fontWeight: 500,
202
+ color: 'rgb(0, 0, 0, 0.7)'
203
+ }}
204
+ >
205
+ Reason for access
206
+ </label>
207
+ <textarea
208
+ id="reason"
209
+ value={reason}
210
+ onChange={(e) => setReason(e.target.value)}
211
+ placeholder="I need this to sync user data..."
212
+ disabled={isSubmitting}
213
+ rows={4}
214
+ style={{
215
+ resize: 'vertical',
216
+ width: '100%',
217
+ padding: '12px',
218
+ boxSizing: 'border-box',
219
+ borderRadius: '6px',
220
+ border: '1px solid #ccc',
221
+ fontFamily: 'inherit',
222
+ fontSize: '14px'
223
+ }}
224
+ />
225
+ </div>
226
+ <div
227
+ style={{
228
+ display: 'flex',
229
+ justifyContent: 'flex-end',
230
+ gap: '12px',
231
+ width: '100%',
232
+ marginTop: 'auto'
233
+ }}
234
+ >
235
+ <Button
236
+ onClick={() => onClose()}
237
+ disabled={isSubmitting}
238
+ style={{
239
+ background: 'transparent',
240
+ color: 'rgb(0,0,0,0.7)',
241
+ border: '1px solid #ccc'
242
+ }}
243
+ >
244
+ Cancel
245
+ </Button>
246
+ <Button onClick={handleSubmit} disabled={isSubmitting}>
247
+ {isSubmitting ? (
248
+ <CircularProgress size={16} color="inherit" />
249
+ ) : (
250
+ 'Submit Request'
251
+ )}
252
+ </Button>
253
+ </div>
254
+ </>
255
+ )}
256
+ </div>
257
+ </SmallDialog>
258
+ );
259
+ };
260
+
261
+ export default RequestIntegrationAccessDialog;