@friggframework/devtools 2.0.0--canary.400.bed3308.0 → 2.0.0--canary.400.545e7a8.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 (167) hide show
  1. package/frigg-cli/build-command/index.js +2 -15
  2. package/frigg-cli/deploy-command/index.js +2 -15
  3. package/frigg-cli/index.js +4 -66
  4. package/frigg-cli/install-command/index.js +2 -15
  5. package/frigg-cli/start-command/index.js +2 -17
  6. package/infrastructure/AWS-IAM-CREDENTIAL-NEEDS.md +19 -43
  7. package/infrastructure/IAM-POLICY-TEMPLATES.md +1 -1
  8. package/infrastructure/frigg-deployment-iam-stack.yaml +2 -16
  9. package/infrastructure/iam-generator.js +6 -129
  10. package/infrastructure/iam-policy-basic.json +5 -29
  11. package/infrastructure/iam-policy-full.json +5 -28
  12. package/infrastructure/serverless-template.js +3 -190
  13. package/infrastructure/serverless-template.test.js +0 -12
  14. package/management-ui/dist/assets/index-CbM64Oba.js +1221 -0
  15. package/management-ui/dist/assets/index-CkvseXTC.css +1 -0
  16. package/management-ui/{index.html → dist/index.html} +2 -1
  17. package/package.json +5 -5
  18. package/frigg-cli/.eslintrc.js +0 -141
  19. package/frigg-cli/__tests__/jest.config.js +0 -102
  20. package/frigg-cli/__tests__/unit/commands/build.test.js +0 -483
  21. package/frigg-cli/__tests__/unit/commands/install.test.js +0 -418
  22. package/frigg-cli/__tests__/unit/commands/ui.test.js +0 -592
  23. package/frigg-cli/__tests__/utils/command-tester.js +0 -170
  24. package/frigg-cli/__tests__/utils/mock-factory.js +0 -270
  25. package/frigg-cli/__tests__/utils/test-fixtures.js +0 -463
  26. package/frigg-cli/__tests__/utils/test-setup.js +0 -286
  27. package/frigg-cli/generate-command/__tests__/generate-command.test.js +0 -312
  28. package/frigg-cli/generate-command/azure-generator.js +0 -43
  29. package/frigg-cli/generate-command/gcp-generator.js +0 -47
  30. package/frigg-cli/generate-command/index.js +0 -350
  31. package/frigg-cli/generate-command/terraform-generator.js +0 -555
  32. package/frigg-cli/package.json +0 -75
  33. package/frigg-cli/ui-command/index.js +0 -167
  34. package/frigg-cli/utils/app-resolver.js +0 -319
  35. package/frigg-cli/utils/backend-path.js +0 -38
  36. package/frigg-cli/utils/process-manager.js +0 -199
  37. package/frigg-cli/utils/repo-detection.js +0 -405
  38. package/management-ui/.eslintrc.js +0 -22
  39. package/management-ui/README.md +0 -203
  40. package/management-ui/components.json +0 -21
  41. package/management-ui/merge-conflict-cleaner.py +0 -371
  42. package/management-ui/package-lock.json +0 -10997
  43. package/management-ui/package.json +0 -76
  44. package/management-ui/postcss.config.js +0 -6
  45. package/management-ui/server/api/backend.js +0 -256
  46. package/management-ui/server/api/cli.js +0 -315
  47. package/management-ui/server/api/codegen.js +0 -663
  48. package/management-ui/server/api/connections.js +0 -857
  49. package/management-ui/server/api/discovery.js +0 -185
  50. package/management-ui/server/api/environment/index.js +0 -1
  51. package/management-ui/server/api/environment/router.js +0 -378
  52. package/management-ui/server/api/environment.js +0 -328
  53. package/management-ui/server/api/integrations.js +0 -479
  54. package/management-ui/server/api/logs.js +0 -248
  55. package/management-ui/server/api/monitoring.js +0 -282
  56. package/management-ui/server/api/open-ide.js +0 -31
  57. package/management-ui/server/api/project.js +0 -553
  58. package/management-ui/server/api/users/sessions.js +0 -371
  59. package/management-ui/server/api/users/simulation.js +0 -254
  60. package/management-ui/server/api/users.js +0 -362
  61. package/management-ui/server/api-contract.md +0 -275
  62. package/management-ui/server/index.js +0 -428
  63. package/management-ui/server/middleware/errorHandler.js +0 -70
  64. package/management-ui/server/middleware/security.js +0 -32
  65. package/management-ui/server/processManager.js +0 -296
  66. package/management-ui/server/server.js +0 -188
  67. package/management-ui/server/services/aws-monitor.js +0 -413
  68. package/management-ui/server/services/npm-registry.js +0 -347
  69. package/management-ui/server/services/template-engine.js +0 -538
  70. package/management-ui/server/utils/cliIntegration.js +0 -220
  71. package/management-ui/server/utils/environment/auditLogger.js +0 -471
  72. package/management-ui/server/utils/environment/awsParameterStore.js +0 -264
  73. package/management-ui/server/utils/environment/encryption.js +0 -278
  74. package/management-ui/server/utils/environment/envFileManager.js +0 -286
  75. package/management-ui/server/utils/import-commonjs.js +0 -28
  76. package/management-ui/server/utils/response.js +0 -83
  77. package/management-ui/server/websocket/handler.js +0 -325
  78. package/management-ui/src/App.jsx +0 -51
  79. package/management-ui/src/components/AppRouter.jsx +0 -65
  80. package/management-ui/src/components/Button.jsx +0 -2
  81. package/management-ui/src/components/Card.jsx +0 -9
  82. package/management-ui/src/components/EnvironmentCompare.jsx +0 -400
  83. package/management-ui/src/components/EnvironmentEditor.jsx +0 -372
  84. package/management-ui/src/components/EnvironmentImportExport.jsx +0 -469
  85. package/management-ui/src/components/EnvironmentSchema.jsx +0 -491
  86. package/management-ui/src/components/EnvironmentSecurity.jsx +0 -463
  87. package/management-ui/src/components/ErrorBoundary.jsx +0 -73
  88. package/management-ui/src/components/IntegrationCard.jsx +0 -199
  89. package/management-ui/src/components/IntegrationCardEnhanced.jsx +0 -490
  90. package/management-ui/src/components/IntegrationExplorer.jsx +0 -379
  91. package/management-ui/src/components/IntegrationStatus.jsx +0 -235
  92. package/management-ui/src/components/Layout.jsx +0 -250
  93. package/management-ui/src/components/LoadingSpinner.jsx +0 -45
  94. package/management-ui/src/components/RepositoryPicker.jsx +0 -248
  95. package/management-ui/src/components/SessionMonitor.jsx +0 -255
  96. package/management-ui/src/components/StatusBadge.jsx +0 -70
  97. package/management-ui/src/components/UserContextSwitcher.jsx +0 -154
  98. package/management-ui/src/components/UserSimulation.jsx +0 -299
  99. package/management-ui/src/components/Welcome.jsx +0 -434
  100. package/management-ui/src/components/codegen/APIEndpointGenerator.jsx +0 -637
  101. package/management-ui/src/components/codegen/APIModuleSelector.jsx +0 -227
  102. package/management-ui/src/components/codegen/CodeGenerationWizard.jsx +0 -247
  103. package/management-ui/src/components/codegen/CodePreviewEditor.jsx +0 -316
  104. package/management-ui/src/components/codegen/DynamicModuleForm.jsx +0 -271
  105. package/management-ui/src/components/codegen/FormBuilder.jsx +0 -737
  106. package/management-ui/src/components/codegen/IntegrationGenerator.jsx +0 -855
  107. package/management-ui/src/components/codegen/ProjectScaffoldWizard.jsx +0 -797
  108. package/management-ui/src/components/codegen/SchemaBuilder.jsx +0 -303
  109. package/management-ui/src/components/codegen/TemplateSelector.jsx +0 -586
  110. package/management-ui/src/components/codegen/index.js +0 -10
  111. package/management-ui/src/components/connections/ConnectionConfigForm.jsx +0 -362
  112. package/management-ui/src/components/connections/ConnectionHealthMonitor.jsx +0 -182
  113. package/management-ui/src/components/connections/ConnectionTester.jsx +0 -200
  114. package/management-ui/src/components/connections/EntityRelationshipMapper.jsx +0 -292
  115. package/management-ui/src/components/connections/OAuthFlow.jsx +0 -204
  116. package/management-ui/src/components/connections/index.js +0 -5
  117. package/management-ui/src/components/index.js +0 -21
  118. package/management-ui/src/components/monitoring/APIGatewayMetrics.jsx +0 -222
  119. package/management-ui/src/components/monitoring/LambdaMetrics.jsx +0 -169
  120. package/management-ui/src/components/monitoring/MetricsChart.jsx +0 -197
  121. package/management-ui/src/components/monitoring/MonitoringDashboard.jsx +0 -393
  122. package/management-ui/src/components/monitoring/SQSMetrics.jsx +0 -246
  123. package/management-ui/src/components/monitoring/index.js +0 -6
  124. package/management-ui/src/components/monitoring/monitoring.css +0 -218
  125. package/management-ui/src/components/theme-provider.jsx +0 -52
  126. package/management-ui/src/components/theme-toggle.jsx +0 -39
  127. package/management-ui/src/components/ui/badge.tsx +0 -36
  128. package/management-ui/src/components/ui/button.test.jsx +0 -56
  129. package/management-ui/src/components/ui/button.tsx +0 -57
  130. package/management-ui/src/components/ui/card.tsx +0 -76
  131. package/management-ui/src/components/ui/dropdown-menu.tsx +0 -199
  132. package/management-ui/src/components/ui/select.tsx +0 -157
  133. package/management-ui/src/components/ui/skeleton.jsx +0 -15
  134. package/management-ui/src/hooks/useFrigg.jsx +0 -387
  135. package/management-ui/src/hooks/useSocket.jsx +0 -58
  136. package/management-ui/src/index.css +0 -194
  137. package/management-ui/src/lib/utils.ts +0 -6
  138. package/management-ui/src/main.jsx +0 -10
  139. package/management-ui/src/pages/CodeGeneration.jsx +0 -14
  140. package/management-ui/src/pages/Connections.jsx +0 -252
  141. package/management-ui/src/pages/ConnectionsEnhanced.jsx +0 -427
  142. package/management-ui/src/pages/Dashboard.jsx +0 -311
  143. package/management-ui/src/pages/Environment.jsx +0 -314
  144. package/management-ui/src/pages/IntegrationConfigure.jsx +0 -544
  145. package/management-ui/src/pages/IntegrationDiscovery.jsx +0 -479
  146. package/management-ui/src/pages/IntegrationTest.jsx +0 -494
  147. package/management-ui/src/pages/Integrations.jsx +0 -254
  148. package/management-ui/src/pages/Monitoring.jsx +0 -17
  149. package/management-ui/src/pages/Simulation.jsx +0 -155
  150. package/management-ui/src/pages/Users.jsx +0 -492
  151. package/management-ui/src/services/api.js +0 -41
  152. package/management-ui/src/services/apiModuleService.js +0 -193
  153. package/management-ui/src/services/websocket-handlers.js +0 -120
  154. package/management-ui/src/test/api/project.test.js +0 -273
  155. package/management-ui/src/test/components/Welcome.test.jsx +0 -378
  156. package/management-ui/src/test/mocks/server.js +0 -178
  157. package/management-ui/src/test/setup.js +0 -61
  158. package/management-ui/src/test/utils/test-utils.jsx +0 -134
  159. package/management-ui/src/utils/repository.js +0 -98
  160. package/management-ui/src/utils/repository.test.js +0 -118
  161. package/management-ui/src/workflows/phase2-integration-workflows.js +0 -884
  162. package/management-ui/tailwind.config.js +0 -63
  163. package/management-ui/tsconfig.json +0 -37
  164. package/management-ui/tsconfig.node.json +0 -10
  165. package/management-ui/vite.config.js +0 -26
  166. package/management-ui/vitest.config.js +0 -38
  167. /package/management-ui/{src/assets/FriggLogo.svg → dist/assets/FriggLogo-B7Xx8ZW1.svg} +0 -0
@@ -1,254 +0,0 @@
1
- import React, { useState, useMemo } from 'react'
2
- import { Search, Filter, Grid3X3, List, Package } from 'lucide-react'
3
- import { useFrigg } from '../hooks/useFrigg'
4
- import IntegrationCard from '../components/IntegrationCard'
5
- import { Button } from '../components/Button'
6
- import { cn } from '../lib/utils'
7
-
8
- const Integrations = () => {
9
- const { integrations, installIntegration, uninstallIntegration } = useFrigg()
10
- const [searchQuery, setSearchQuery] = useState('')
11
- const [selectedCategory, setSelectedCategory] = useState('all')
12
- const [viewMode, setViewMode] = useState('grid') // 'grid' or 'list'
13
- const [installing, setInstalling] = useState(false)
14
- const [selectedIntegration, setSelectedIntegration] = useState(null)
15
-
16
- // Mock available integrations - in real app, this would come from API
17
- const availableIntegrations = [
18
- {
19
- name: 'slack',
20
- displayName: 'Slack',
21
- description: 'Team communication and collaboration platform',
22
- category: 'communication',
23
- tags: ['messaging', 'team', 'notifications'],
24
- version: '2.1.0',
25
- docsUrl: 'https://docs.frigg.dev/integrations/slack'
26
- },
27
- {
28
- name: 'salesforce',
29
- displayName: 'Salesforce',
30
- description: 'Customer relationship management and sales platform',
31
- category: 'crm',
32
- tags: ['sales', 'crm', 'leads'],
33
- version: '1.8.2',
34
- docsUrl: 'https://docs.frigg.dev/integrations/salesforce'
35
- },
36
- {
37
- name: 'hubspot',
38
- displayName: 'HubSpot',
39
- description: 'Inbound marketing, sales, and service software',
40
- category: 'marketing',
41
- tags: ['marketing', 'automation', 'analytics'],
42
- version: '3.0.1',
43
- docsUrl: 'https://docs.frigg.dev/integrations/hubspot'
44
- },
45
- {
46
- name: 'google-sheets',
47
- displayName: 'Google Sheets',
48
- description: 'Online spreadsheet collaboration and data management',
49
- category: 'productivity',
50
- tags: ['spreadsheet', 'data', 'collaboration'],
51
- version: '1.5.0',
52
- docsUrl: 'https://docs.frigg.dev/integrations/google-sheets'
53
- },
54
- {
55
- name: 'stripe',
56
- displayName: 'Stripe',
57
- description: 'Online payment processing and financial services',
58
- category: 'payments',
59
- tags: ['payments', 'ecommerce', 'billing'],
60
- version: '2.3.1',
61
- docsUrl: 'https://docs.frigg.dev/integrations/stripe'
62
- },
63
- {
64
- name: 'mailchimp',
65
- displayName: 'Mailchimp',
66
- description: 'Email marketing and automation platform',
67
- category: 'marketing',
68
- tags: ['email', 'marketing', 'campaigns'],
69
- version: '1.9.0',
70
- docsUrl: 'https://docs.frigg.dev/integrations/mailchimp'
71
- },
72
- ].map(integration => ({
73
- ...integration,
74
- installed: integrations.some(i => i.name === integration.name),
75
- connections: Math.floor(Math.random() * 10), // Mock data
76
- lastUpdated: new Date(Date.now() - Math.random() * 30 * 24 * 60 * 60 * 1000).toISOString()
77
- }))
78
-
79
- const categories = ['all', 'communication', 'crm', 'marketing', 'productivity', 'payments']
80
-
81
- const filteredIntegrations = useMemo(() => {
82
- return availableIntegrations.filter(integration => {
83
- const matchesSearch = integration.displayName.toLowerCase().includes(searchQuery.toLowerCase()) ||
84
- integration.description.toLowerCase().includes(searchQuery.toLowerCase()) ||
85
- integration.tags.some(tag => tag.toLowerCase().includes(searchQuery.toLowerCase()))
86
-
87
- const matchesCategory = selectedCategory === 'all' || integration.category === selectedCategory
88
-
89
- return matchesSearch && matchesCategory
90
- })
91
- }, [availableIntegrations, searchQuery, selectedCategory])
92
-
93
- const installedIntegrations = useMemo(() => {
94
- return availableIntegrations.filter(integration => integration.installed)
95
- }, [availableIntegrations])
96
-
97
- const availableForInstall = useMemo(() => {
98
- return filteredIntegrations.filter(integration => !integration.installed)
99
- }, [filteredIntegrations])
100
-
101
- const handleInstall = async (integrationName) => {
102
- setInstalling(true)
103
- setSelectedIntegration(integrationName)
104
- try {
105
- await installIntegration(integrationName)
106
- } catch (error) {
107
- console.error('Installation failed:', error)
108
- } finally {
109
- setInstalling(false)
110
- setSelectedIntegration(null)
111
- }
112
- }
113
-
114
- const handleUninstall = async (integrationName) => {
115
- try {
116
- if (uninstallIntegration) {
117
- await uninstallIntegration(integrationName)
118
- }
119
- } catch (error) {
120
- console.error('Uninstall failed:', error)
121
- }
122
- }
123
-
124
- const handleConfigure = (integrationName) => {
125
- // Navigate to configuration page or open modal
126
- console.log('Configure integration:', integrationName)
127
- }
128
-
129
- return (
130
- <div className="space-y-6">
131
- {/* Header */}
132
- <div>
133
- <h2 className="text-3xl font-bold text-gray-900">Integration Discovery</h2>
134
- <p className="mt-2 text-gray-600">Browse and manage Frigg integrations</p>
135
- </div>
136
-
137
- {/* Search and Filters */}
138
- <div className="flex flex-col sm:flex-row gap-4">
139
- <div className="relative flex-1">
140
- <Search size={20} className="absolute left-3 top-1/2 transform -translate-y-1/2 text-gray-400" />
141
- <input
142
- type="text"
143
- className="w-full pl-10 pr-4 py-2 border border-gray-300 rounded-lg focus:outline-none focus:ring-2 focus:ring-blue-500 focus:border-transparent"
144
- placeholder="Search integrations..."
145
- value={searchQuery}
146
- onChange={(e) => setSearchQuery(e.target.value)}
147
- />
148
- </div>
149
-
150
- <div className="flex items-center gap-2">
151
- <select
152
- value={selectedCategory}
153
- onChange={(e) => setSelectedCategory(e.target.value)}
154
- className="px-3 py-2 border border-gray-300 rounded-lg focus:outline-none focus:ring-2 focus:ring-blue-500"
155
- >
156
- {categories.map(category => (
157
- <option key={category} value={category}>
158
- {category.charAt(0).toUpperCase() + category.slice(1)}
159
- </option>
160
- ))}
161
- </select>
162
-
163
- <div className="flex border border-gray-300 rounded-lg">
164
- <Button
165
- variant={viewMode === 'grid' ? 'default' : 'ghost'}
166
- size="sm"
167
- onClick={() => setViewMode('grid')}
168
- className="rounded-r-none"
169
- >
170
- <Grid3X3 size={16} />
171
- </Button>
172
- <Button
173
- variant={viewMode === 'list' ? 'default' : 'ghost'}
174
- size="sm"
175
- onClick={() => setViewMode('list')}
176
- className="rounded-l-none border-l"
177
- >
178
- <List size={16} />
179
- </Button>
180
- </div>
181
- </div>
182
- </div>
183
-
184
- {/* Installed Integrations */}
185
- {installedIntegrations.length > 0 && (
186
- <div>
187
- <div className="flex items-center mb-4">
188
- <Package size={20} className="mr-2 text-green-600" />
189
- <h3 className="text-lg font-medium text-gray-900">
190
- Installed Integrations ({installedIntegrations.length})
191
- </h3>
192
- </div>
193
- <div className={cn(
194
- viewMode === 'grid'
195
- ? 'grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6'
196
- : 'space-y-4'
197
- )}>
198
- {installedIntegrations.map((integration) => (
199
- <IntegrationCard
200
- key={integration.name}
201
- integration={integration}
202
- onConfigure={handleConfigure}
203
- onUninstall={handleUninstall}
204
- className={viewMode === 'list' ? 'max-w-none' : ''}
205
- />
206
- ))}
207
- </div>
208
- </div>
209
- )}
210
-
211
- {/* Available Integrations */}
212
- <div>
213
- <h3 className="text-lg font-medium text-gray-900 mb-4">
214
- Available Integrations ({availableForInstall.length})
215
- </h3>
216
-
217
- {availableForInstall.length === 0 ? (
218
- <div className="text-center py-12">
219
- <Package size={48} className="mx-auto text-gray-300 mb-4" />
220
- <p className="text-gray-500">No integrations found matching your criteria</p>
221
- <Button
222
- variant="outline"
223
- onClick={() => {
224
- setSearchQuery('')
225
- setSelectedCategory('all')
226
- }}
227
- className="mt-4"
228
- >
229
- Clear Filters
230
- </Button>
231
- </div>
232
- ) : (
233
- <div className={cn(
234
- viewMode === 'grid'
235
- ? 'grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6'
236
- : 'space-y-4'
237
- )}>
238
- {availableForInstall.map((integration) => (
239
- <IntegrationCard
240
- key={integration.name}
241
- integration={integration}
242
- onInstall={handleInstall}
243
- installing={installing && selectedIntegration === integration.name}
244
- className={viewMode === 'list' ? 'max-w-none' : ''}
245
- />
246
- ))}
247
- </div>
248
- )}
249
- </div>
250
- </div>
251
- )
252
- }
253
-
254
- export default Integrations
@@ -1,17 +0,0 @@
1
- import React from 'react'
2
- import { Layout } from '../components/Layout'
3
- import { MonitoringDashboard } from '../components/monitoring'
4
-
5
- /**
6
- * Monitoring Page Component
7
- * Provides production monitoring and metrics visualization
8
- */
9
- function Monitoring() {
10
- return (
11
- <Layout>
12
- <MonitoringDashboard />
13
- </Layout>
14
- )
15
- }
16
-
17
- export default Monitoring
@@ -1,155 +0,0 @@
1
- import React, { useState } from 'react'
2
- import { useFrigg } from '../hooks/useFrigg'
3
- import UserSimulation from '../components/UserSimulation'
4
-
5
- const Simulation = () => {
6
- const { users, integrations, currentUser } = useFrigg()
7
- const [selectedUser, setSelectedUser] = useState(null)
8
- const [selectedIntegration, setSelectedIntegration] = useState(null)
9
-
10
- // Use current user context if available
11
- const simulationUser = selectedUser || currentUser
12
-
13
- return (
14
- <div>
15
- <div className="mb-8">
16
- <h2 className="text-3xl font-bold text-gray-900">Integration Testing Simulator</h2>
17
- <p className="mt-2 text-gray-600">Simulate user interactions with integrations for development testing</p>
18
- </div>
19
-
20
- {/* Selection Controls */}
21
- <div className="grid grid-cols-1 md:grid-cols-2 gap-6 mb-8">
22
- {/* User Selection */}
23
- <div className="bg-white shadow rounded-lg p-6">
24
- <h3 className="text-lg font-medium text-gray-900 mb-4">Select Test User</h3>
25
- {currentUser && (
26
- <div className="mb-4 p-3 bg-blue-50 border border-blue-200 rounded-md">
27
- <p className="text-sm text-blue-800">
28
- Using context user: <strong>{currentUser.firstName} {currentUser.lastName}</strong>
29
- </p>
30
- </div>
31
- )}
32
- <div className="space-y-2 max-h-64 overflow-y-auto">
33
- {users.length === 0 ? (
34
- <p className="text-sm text-gray-500 text-center py-4">
35
- No test users available. Create some users first.
36
- </p>
37
- ) : (
38
- users.map(user => (
39
- <label
40
- key={user.id}
41
- className={`flex items-center p-3 border rounded-md cursor-pointer transition-colors ${
42
- (simulationUser?.id === user.id)
43
- ? 'border-blue-500 bg-blue-50'
44
- : 'border-gray-200 hover:border-gray-300'
45
- }`}
46
- >
47
- <input
48
- type="radio"
49
- name="user"
50
- value={user.id}
51
- checked={simulationUser?.id === user.id}
52
- onChange={() => setSelectedUser(user)}
53
- className="mr-3"
54
- />
55
- <div className="flex-1">
56
- <p className="text-sm font-medium text-gray-900">
57
- {user.firstName} {user.lastName}
58
- </p>
59
- <p className="text-xs text-gray-500">{user.email}</p>
60
- <div className="flex items-center space-x-2 mt-1">
61
- <span className="text-xs bg-gray-100 text-gray-600 px-2 py-0.5 rounded">
62
- {user.role}
63
- </span>
64
- {user.appOrgId && (
65
- <span className="text-xs text-gray-500">
66
- Org: {user.appOrgId}
67
- </span>
68
- )}
69
- </div>
70
- </div>
71
- </label>
72
- ))
73
- )}
74
- </div>
75
- </div>
76
-
77
- {/* Integration Selection */}
78
- <div className="bg-white shadow rounded-lg p-6">
79
- <h3 className="text-lg font-medium text-gray-900 mb-4">Select Integration</h3>
80
- <div className="space-y-2 max-h-64 overflow-y-auto">
81
- {integrations.length === 0 ? (
82
- <p className="text-sm text-gray-500 text-center py-4">
83
- No integrations available. Install some integrations first.
84
- </p>
85
- ) : (
86
- integrations.map(integration => (
87
- <label
88
- key={integration.id}
89
- className={`flex items-center p-3 border rounded-md cursor-pointer transition-colors ${
90
- selectedIntegration?.id === integration.id
91
- ? 'border-blue-500 bg-blue-50'
92
- : 'border-gray-200 hover:border-gray-300'
93
- }`}
94
- >
95
- <input
96
- type="radio"
97
- name="integration"
98
- value={integration.id}
99
- checked={selectedIntegration?.id === integration.id}
100
- onChange={() => setSelectedIntegration(integration)}
101
- className="mr-3"
102
- />
103
- <div className="flex-1">
104
- <p className="text-sm font-medium text-gray-900">
105
- {integration.name}
106
- </p>
107
- <p className="text-xs text-gray-500">
108
- {integration.description || 'No description'}
109
- </p>
110
- <div className="flex items-center space-x-2 mt-1">
111
- <span className={`text-xs px-2 py-0.5 rounded ${
112
- integration.status === 'active'
113
- ? 'bg-green-100 text-green-700'
114
- : 'bg-gray-100 text-gray-600'
115
- }`}>
116
- {integration.status || 'inactive'}
117
- </span>
118
- <span className="text-xs text-gray-500">
119
- v{integration.version || '1.0.0'}
120
- </span>
121
- </div>
122
- </div>
123
- </label>
124
- ))
125
- )}
126
- </div>
127
- </div>
128
- </div>
129
-
130
- {/* Simulation Component */}
131
- <UserSimulation
132
- user={simulationUser}
133
- integration={selectedIntegration}
134
- />
135
-
136
- {/* Help Section */}
137
- <div className="mt-8 bg-yellow-50 border border-yellow-200 rounded-lg p-6">
138
- <h4 className="text-sm font-semibold text-yellow-900 mb-2">How to Use the Simulator</h4>
139
- <ol className="text-sm text-yellow-800 space-y-2 list-decimal list-inside">
140
- <li>Select a test user or use the current context user from the header</li>
141
- <li>Choose an integration to test</li>
142
- <li>Start a simulation session</li>
143
- <li>Execute actions and observe the responses</li>
144
- <li>Simulate webhook events to test integration reactions</li>
145
- <li>Monitor the activity log for debugging</li>
146
- </ol>
147
- <p className="text-xs text-yellow-700 mt-3">
148
- Note: All simulations are for local development only and do not affect real data.
149
- </p>
150
- </div>
151
- </div>
152
- )
153
- }
154
-
155
- export default Simulation