flock-core 0.5.0b28__py3-none-any.whl → 0.5.0b51__py3-none-any.whl

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.

Potentially problematic release.


This version of flock-core might be problematic. Click here for more details.

Files changed (469) hide show
  1. flock/__init__.py +12 -217
  2. flock/agent.py +678 -0
  3. flock/api/themes.py +71 -0
  4. flock/artifacts.py +79 -0
  5. flock/cli.py +75 -0
  6. flock/components.py +173 -0
  7. flock/dashboard/__init__.py +28 -0
  8. flock/dashboard/collector.py +283 -0
  9. flock/dashboard/events.py +182 -0
  10. flock/dashboard/launcher.py +230 -0
  11. flock/dashboard/service.py +537 -0
  12. flock/dashboard/websocket.py +235 -0
  13. flock/engines/__init__.py +6 -0
  14. flock/engines/dspy_engine.py +856 -0
  15. flock/examples.py +128 -0
  16. flock/frontend/README.md +678 -0
  17. flock/frontend/docs/DESIGN_SYSTEM.md +1980 -0
  18. flock/frontend/index.html +12 -0
  19. flock/frontend/package-lock.json +4347 -0
  20. flock/frontend/package.json +48 -0
  21. flock/frontend/src/App.tsx +79 -0
  22. flock/frontend/src/__tests__/e2e/critical-scenarios.test.tsx +587 -0
  23. flock/frontend/src/__tests__/integration/filtering-e2e.test.tsx +387 -0
  24. flock/frontend/src/__tests__/integration/graph-rendering.test.tsx +640 -0
  25. flock/frontend/src/__tests__/integration/indexeddb-persistence.test.tsx +699 -0
  26. flock/frontend/src/components/common/BuildInfo.tsx +39 -0
  27. flock/frontend/src/components/common/EmptyState.module.css +115 -0
  28. flock/frontend/src/components/common/EmptyState.tsx +128 -0
  29. flock/frontend/src/components/common/ErrorBoundary.module.css +169 -0
  30. flock/frontend/src/components/common/ErrorBoundary.tsx +118 -0
  31. flock/frontend/src/components/common/KeyboardShortcutsDialog.css +251 -0
  32. flock/frontend/src/components/common/KeyboardShortcutsDialog.tsx +151 -0
  33. flock/frontend/src/components/common/LoadingSpinner.module.css +97 -0
  34. flock/frontend/src/components/common/LoadingSpinner.tsx +29 -0
  35. flock/frontend/src/components/controls/PublishControl.css +547 -0
  36. flock/frontend/src/components/controls/PublishControl.test.tsx +543 -0
  37. flock/frontend/src/components/controls/PublishControl.tsx +432 -0
  38. flock/frontend/src/components/details/DetailWindowContainer.tsx +62 -0
  39. flock/frontend/src/components/details/LiveOutputTab.test.tsx +792 -0
  40. flock/frontend/src/components/details/LiveOutputTab.tsx +220 -0
  41. flock/frontend/src/components/details/MessageHistoryTab.tsx +299 -0
  42. flock/frontend/src/components/details/NodeDetailWindow.test.tsx +501 -0
  43. flock/frontend/src/components/details/NodeDetailWindow.tsx +218 -0
  44. flock/frontend/src/components/details/RunStatusTab.tsx +307 -0
  45. flock/frontend/src/components/details/tabs.test.tsx +1015 -0
  46. flock/frontend/src/components/filters/CorrelationIDFilter.module.css +102 -0
  47. flock/frontend/src/components/filters/CorrelationIDFilter.test.tsx +197 -0
  48. flock/frontend/src/components/filters/CorrelationIDFilter.tsx +121 -0
  49. flock/frontend/src/components/filters/FilterBar.module.css +29 -0
  50. flock/frontend/src/components/filters/FilterBar.test.tsx +133 -0
  51. flock/frontend/src/components/filters/FilterBar.tsx +33 -0
  52. flock/frontend/src/components/filters/FilterPills.module.css +79 -0
  53. flock/frontend/src/components/filters/FilterPills.test.tsx +173 -0
  54. flock/frontend/src/components/filters/FilterPills.tsx +67 -0
  55. flock/frontend/src/components/filters/TimeRangeFilter.module.css +91 -0
  56. flock/frontend/src/components/filters/TimeRangeFilter.test.tsx +154 -0
  57. flock/frontend/src/components/filters/TimeRangeFilter.tsx +105 -0
  58. flock/frontend/src/components/graph/AgentNode.test.tsx +75 -0
  59. flock/frontend/src/components/graph/AgentNode.tsx +322 -0
  60. flock/frontend/src/components/graph/GraphCanvas.tsx +406 -0
  61. flock/frontend/src/components/graph/MessageFlowEdge.tsx +128 -0
  62. flock/frontend/src/components/graph/MessageNode.test.tsx +62 -0
  63. flock/frontend/src/components/graph/MessageNode.tsx +116 -0
  64. flock/frontend/src/components/graph/MiniMap.tsx +47 -0
  65. flock/frontend/src/components/graph/TransformEdge.tsx +123 -0
  66. flock/frontend/src/components/layout/DashboardLayout.css +407 -0
  67. flock/frontend/src/components/layout/DashboardLayout.tsx +300 -0
  68. flock/frontend/src/components/layout/Header.module.css +88 -0
  69. flock/frontend/src/components/layout/Header.tsx +52 -0
  70. flock/frontend/src/components/modules/EventLogModule.test.tsx +401 -0
  71. flock/frontend/src/components/modules/EventLogModule.tsx +396 -0
  72. flock/frontend/src/components/modules/EventLogModuleWrapper.tsx +17 -0
  73. flock/frontend/src/components/modules/ModuleRegistry.test.ts +333 -0
  74. flock/frontend/src/components/modules/ModuleRegistry.ts +85 -0
  75. flock/frontend/src/components/modules/ModuleWindow.tsx +155 -0
  76. flock/frontend/src/components/modules/registerModules.ts +20 -0
  77. flock/frontend/src/components/settings/AdvancedSettings.tsx +175 -0
  78. flock/frontend/src/components/settings/AppearanceSettings.tsx +185 -0
  79. flock/frontend/src/components/settings/GraphSettings.tsx +110 -0
  80. flock/frontend/src/components/settings/SettingsPanel.css +327 -0
  81. flock/frontend/src/components/settings/SettingsPanel.tsx +131 -0
  82. flock/frontend/src/components/settings/ThemeSelector.tsx +298 -0
  83. flock/frontend/src/hooks/useKeyboardShortcuts.ts +148 -0
  84. flock/frontend/src/hooks/useModulePersistence.test.ts +442 -0
  85. flock/frontend/src/hooks/useModulePersistence.ts +154 -0
  86. flock/frontend/src/hooks/useModules.ts +139 -0
  87. flock/frontend/src/hooks/usePersistence.ts +139 -0
  88. flock/frontend/src/main.tsx +13 -0
  89. flock/frontend/src/services/api.ts +213 -0
  90. flock/frontend/src/services/indexeddb.test.ts +793 -0
  91. flock/frontend/src/services/indexeddb.ts +794 -0
  92. flock/frontend/src/services/layout.test.ts +437 -0
  93. flock/frontend/src/services/layout.ts +146 -0
  94. flock/frontend/src/services/themeApplicator.ts +140 -0
  95. flock/frontend/src/services/themeService.ts +77 -0
  96. flock/frontend/src/services/websocket.test.ts +595 -0
  97. flock/frontend/src/services/websocket.ts +685 -0
  98. flock/frontend/src/store/filterStore.test.ts +242 -0
  99. flock/frontend/src/store/filterStore.ts +103 -0
  100. flock/frontend/src/store/graphStore.test.ts +186 -0
  101. flock/frontend/src/store/graphStore.ts +414 -0
  102. flock/frontend/src/store/moduleStore.test.ts +253 -0
  103. flock/frontend/src/store/moduleStore.ts +57 -0
  104. flock/frontend/src/store/settingsStore.ts +188 -0
  105. flock/frontend/src/store/streamStore.ts +68 -0
  106. flock/frontend/src/store/uiStore.test.ts +54 -0
  107. flock/frontend/src/store/uiStore.ts +110 -0
  108. flock/frontend/src/store/wsStore.ts +34 -0
  109. flock/frontend/src/styles/index.css +15 -0
  110. flock/frontend/src/styles/scrollbar.css +47 -0
  111. flock/frontend/src/styles/variables.css +488 -0
  112. flock/frontend/src/test/setup.ts +1 -0
  113. flock/frontend/src/types/filters.ts +14 -0
  114. flock/frontend/src/types/graph.ts +55 -0
  115. flock/frontend/src/types/modules.ts +7 -0
  116. flock/frontend/src/types/theme.ts +55 -0
  117. flock/frontend/src/utils/mockData.ts +85 -0
  118. flock/frontend/src/utils/performance.ts +16 -0
  119. flock/frontend/src/utils/transforms.test.ts +860 -0
  120. flock/frontend/src/utils/transforms.ts +323 -0
  121. flock/frontend/src/vite-env.d.ts +17 -0
  122. flock/frontend/tsconfig.json +27 -0
  123. flock/frontend/tsconfig.node.json +11 -0
  124. flock/frontend/vite.config.ts +25 -0
  125. flock/frontend/vitest.config.ts +11 -0
  126. flock/{core/util → helper}/cli_helper.py +4 -3
  127. flock/{core/logging → logging}/__init__.py +2 -3
  128. flock/{core/logging → logging}/formatters/enum_builder.py +3 -4
  129. flock/{core/logging → logging}/formatters/theme_builder.py +19 -44
  130. flock/{core/logging → logging}/formatters/themed_formatter.py +69 -115
  131. flock/{core/logging → logging}/logging.py +77 -61
  132. flock/{core/logging → logging}/telemetry.py +20 -26
  133. flock/{core/logging → logging}/telemetry_exporter/base_exporter.py +2 -2
  134. flock/{core/logging → logging}/telemetry_exporter/file_exporter.py +6 -9
  135. flock/{core/logging → logging}/telemetry_exporter/sqlite_exporter.py +2 -3
  136. flock/{core/logging → logging}/trace_and_logged.py +20 -24
  137. flock/mcp/__init__.py +91 -0
  138. flock/{core/mcp/mcp_client.py → mcp/client.py} +103 -154
  139. flock/{core/mcp/mcp_config.py → mcp/config.py} +62 -117
  140. flock/mcp/manager.py +255 -0
  141. flock/mcp/servers/sse/__init__.py +1 -1
  142. flock/mcp/servers/sse/flock_sse_server.py +11 -53
  143. flock/mcp/servers/stdio/__init__.py +1 -1
  144. flock/mcp/servers/stdio/flock_stdio_server.py +8 -48
  145. flock/mcp/servers/streamable_http/flock_streamable_http_server.py +17 -62
  146. flock/mcp/servers/websockets/flock_websocket_server.py +7 -40
  147. flock/{core/mcp/flock_mcp_tool.py → mcp/tool.py} +16 -26
  148. flock/mcp/types/__init__.py +42 -0
  149. flock/{core/mcp → mcp}/types/callbacks.py +9 -15
  150. flock/{core/mcp → mcp}/types/factories.py +7 -6
  151. flock/{core/mcp → mcp}/types/handlers.py +13 -18
  152. flock/{core/mcp → mcp}/types/types.py +70 -74
  153. flock/{core/mcp → mcp}/util/helpers.py +1 -1
  154. flock/orchestrator.py +645 -0
  155. flock/registry.py +148 -0
  156. flock/runtime.py +262 -0
  157. flock/service.py +140 -0
  158. flock/store.py +69 -0
  159. flock/subscription.py +111 -0
  160. flock/themes/andromeda.toml +1 -1
  161. flock/themes/apple-system-colors.toml +1 -1
  162. flock/themes/arcoiris.toml +1 -1
  163. flock/themes/atomonelight.toml +1 -1
  164. flock/themes/ayu copy.toml +1 -1
  165. flock/themes/ayu-light.toml +1 -1
  166. flock/themes/belafonte-day.toml +1 -1
  167. flock/themes/belafonte-night.toml +1 -1
  168. flock/themes/blulocodark.toml +1 -1
  169. flock/themes/breeze.toml +1 -1
  170. flock/themes/broadcast.toml +1 -1
  171. flock/themes/brogrammer.toml +1 -1
  172. flock/themes/builtin-dark.toml +1 -1
  173. flock/themes/builtin-pastel-dark.toml +1 -1
  174. flock/themes/catppuccin-latte.toml +1 -1
  175. flock/themes/catppuccin-macchiato.toml +1 -1
  176. flock/themes/catppuccin-mocha.toml +1 -1
  177. flock/themes/cga.toml +1 -1
  178. flock/themes/chalk.toml +1 -1
  179. flock/themes/ciapre.toml +1 -1
  180. flock/themes/coffee-theme.toml +1 -1
  181. flock/themes/cyberpunkscarletprotocol.toml +1 -1
  182. flock/themes/dark+.toml +1 -1
  183. flock/themes/darkermatrix.toml +1 -1
  184. flock/themes/darkside.toml +1 -1
  185. flock/themes/desert.toml +1 -1
  186. flock/themes/django.toml +1 -1
  187. flock/themes/djangosmooth.toml +1 -1
  188. flock/themes/doomone.toml +1 -1
  189. flock/themes/dotgov.toml +1 -1
  190. flock/themes/dracula+.toml +1 -1
  191. flock/themes/duckbones.toml +1 -1
  192. flock/themes/encom.toml +1 -1
  193. flock/themes/espresso.toml +1 -1
  194. flock/themes/everblush.toml +1 -1
  195. flock/themes/fairyfloss.toml +1 -1
  196. flock/themes/fideloper.toml +1 -1
  197. flock/themes/fishtank.toml +1 -1
  198. flock/themes/flexoki-light.toml +1 -1
  199. flock/themes/floraverse.toml +1 -1
  200. flock/themes/framer.toml +1 -1
  201. flock/themes/galizur.toml +1 -1
  202. flock/themes/github.toml +1 -1
  203. flock/themes/grass.toml +1 -1
  204. flock/themes/grey-green.toml +1 -1
  205. flock/themes/gruvboxlight.toml +1 -1
  206. flock/themes/guezwhoz.toml +1 -1
  207. flock/themes/harper.toml +1 -1
  208. flock/themes/hax0r-blue.toml +1 -1
  209. flock/themes/hopscotch.256.toml +1 -1
  210. flock/themes/ic-green-ppl.toml +1 -1
  211. flock/themes/iceberg-dark.toml +1 -1
  212. flock/themes/japanesque.toml +1 -1
  213. flock/themes/jubi.toml +1 -1
  214. flock/themes/kibble.toml +1 -1
  215. flock/themes/kolorit.toml +1 -1
  216. flock/themes/kurokula.toml +1 -1
  217. flock/themes/materialdesigncolors.toml +1 -1
  218. flock/themes/matrix.toml +1 -1
  219. flock/themes/mellifluous.toml +1 -1
  220. flock/themes/midnight-in-mojave.toml +1 -1
  221. flock/themes/monokai-remastered.toml +1 -1
  222. flock/themes/monokai-soda.toml +1 -1
  223. flock/themes/neon.toml +1 -1
  224. flock/themes/neopolitan.toml +1 -1
  225. flock/themes/nord-light.toml +1 -1
  226. flock/themes/ocean.toml +1 -1
  227. flock/themes/onehalfdark.toml +1 -1
  228. flock/themes/onehalflight.toml +1 -1
  229. flock/themes/palenighthc.toml +1 -1
  230. flock/themes/paulmillr.toml +1 -1
  231. flock/themes/pencildark.toml +1 -1
  232. flock/themes/pnevma.toml +1 -1
  233. flock/themes/purple-rain.toml +1 -1
  234. flock/themes/purplepeter.toml +1 -1
  235. flock/themes/raycast-dark.toml +1 -1
  236. flock/themes/red-sands.toml +1 -1
  237. flock/themes/relaxed.toml +1 -1
  238. flock/themes/retro.toml +1 -1
  239. flock/themes/rose-pine.toml +1 -1
  240. flock/themes/royal.toml +1 -1
  241. flock/themes/ryuuko.toml +1 -1
  242. flock/themes/sakura.toml +1 -1
  243. flock/themes/scarlet-protocol.toml +1 -1
  244. flock/themes/seoulbones-dark.toml +1 -1
  245. flock/themes/shades-of-purple.toml +1 -1
  246. flock/themes/smyck.toml +1 -1
  247. flock/themes/softserver.toml +1 -1
  248. flock/themes/solarized-darcula.toml +1 -1
  249. flock/themes/square.toml +1 -1
  250. flock/themes/sugarplum.toml +1 -1
  251. flock/themes/thayer-bright.toml +1 -1
  252. flock/themes/tokyonight.toml +1 -1
  253. flock/themes/tomorrow.toml +1 -1
  254. flock/themes/ubuntu.toml +1 -1
  255. flock/themes/ultradark.toml +1 -1
  256. flock/themes/ultraviolent.toml +1 -1
  257. flock/themes/unikitty.toml +1 -1
  258. flock/themes/urple.toml +1 -1
  259. flock/themes/vesper.toml +1 -1
  260. flock/themes/vimbones.toml +1 -1
  261. flock/themes/wildcherry.toml +1 -1
  262. flock/themes/wilmersdorf.toml +1 -1
  263. flock/themes/wryan.toml +1 -1
  264. flock/themes/xcodedarkhc.toml +1 -1
  265. flock/themes/xcodelight.toml +1 -1
  266. flock/themes/zenbones-light.toml +1 -1
  267. flock/themes/zenwritten-dark.toml +1 -1
  268. flock/utilities.py +301 -0
  269. flock/{components/utility → utility}/output_utility_component.py +68 -53
  270. flock/visibility.py +107 -0
  271. flock_core-0.5.0b51.dist-info/METADATA +747 -0
  272. flock_core-0.5.0b51.dist-info/RECORD +508 -0
  273. flock_core-0.5.0b51.dist-info/entry_points.txt +2 -0
  274. {flock_core-0.5.0b28.dist-info → flock_core-0.5.0b51.dist-info}/licenses/LICENSE +1 -1
  275. flock/adapter/__init__.py +0 -14
  276. flock/adapter/azure_adapter.py +0 -68
  277. flock/adapter/chroma_adapter.py +0 -73
  278. flock/adapter/faiss_adapter.py +0 -97
  279. flock/adapter/pinecone_adapter.py +0 -51
  280. flock/adapter/vector_base.py +0 -47
  281. flock/cli/assets/release_notes.md +0 -140
  282. flock/cli/config.py +0 -8
  283. flock/cli/constants.py +0 -36
  284. flock/cli/create_agent.py +0 -1
  285. flock/cli/create_flock.py +0 -280
  286. flock/cli/execute_flock.py +0 -620
  287. flock/cli/load_agent.py +0 -1
  288. flock/cli/load_examples.py +0 -1
  289. flock/cli/load_flock.py +0 -192
  290. flock/cli/load_release_notes.py +0 -20
  291. flock/cli/loaded_flock_cli.py +0 -254
  292. flock/cli/manage_agents.py +0 -459
  293. flock/cli/registry_management.py +0 -889
  294. flock/cli/runner.py +0 -41
  295. flock/cli/settings.py +0 -857
  296. flock/cli/utils.py +0 -135
  297. flock/cli/view_results.py +0 -29
  298. flock/cli/yaml_editor.py +0 -396
  299. flock/components/__init__.py +0 -30
  300. flock/components/evaluation/__init__.py +0 -9
  301. flock/components/evaluation/declarative_evaluation_component.py +0 -606
  302. flock/components/routing/__init__.py +0 -15
  303. flock/components/routing/conditional_routing_component.py +0 -494
  304. flock/components/routing/default_routing_component.py +0 -103
  305. flock/components/routing/llm_routing_component.py +0 -206
  306. flock/components/utility/__init__.py +0 -22
  307. flock/components/utility/example_utility_component.py +0 -250
  308. flock/components/utility/feedback_utility_component.py +0 -206
  309. flock/components/utility/memory_utility_component.py +0 -550
  310. flock/components/utility/metrics_utility_component.py +0 -700
  311. flock/config.py +0 -61
  312. flock/core/__init__.py +0 -110
  313. flock/core/agent/__init__.py +0 -16
  314. flock/core/agent/default_agent.py +0 -216
  315. flock/core/agent/flock_agent_components.py +0 -104
  316. flock/core/agent/flock_agent_execution.py +0 -101
  317. flock/core/agent/flock_agent_integration.py +0 -260
  318. flock/core/agent/flock_agent_lifecycle.py +0 -186
  319. flock/core/agent/flock_agent_serialization.py +0 -381
  320. flock/core/api/__init__.py +0 -10
  321. flock/core/api/custom_endpoint.py +0 -45
  322. flock/core/api/endpoints.py +0 -254
  323. flock/core/api/main.py +0 -162
  324. flock/core/api/models.py +0 -97
  325. flock/core/api/run_store.py +0 -224
  326. flock/core/api/runner.py +0 -44
  327. flock/core/api/service.py +0 -214
  328. flock/core/component/__init__.py +0 -15
  329. flock/core/component/agent_component_base.py +0 -309
  330. flock/core/component/evaluation_component.py +0 -62
  331. flock/core/component/routing_component.py +0 -74
  332. flock/core/component/utility_component.py +0 -69
  333. flock/core/config/flock_agent_config.py +0 -58
  334. flock/core/config/scheduled_agent_config.py +0 -40
  335. flock/core/context/context.py +0 -213
  336. flock/core/context/context_manager.py +0 -37
  337. flock/core/context/context_vars.py +0 -10
  338. flock/core/evaluation/utils.py +0 -396
  339. flock/core/execution/batch_executor.py +0 -369
  340. flock/core/execution/evaluation_executor.py +0 -438
  341. flock/core/execution/local_executor.py +0 -31
  342. flock/core/execution/opik_executor.py +0 -103
  343. flock/core/execution/temporal_executor.py +0 -164
  344. flock/core/flock.py +0 -634
  345. flock/core/flock_agent.py +0 -336
  346. flock/core/flock_factory.py +0 -613
  347. flock/core/flock_scheduler.py +0 -166
  348. flock/core/flock_server_manager.py +0 -136
  349. flock/core/interpreter/python_interpreter.py +0 -689
  350. flock/core/mcp/__init__.py +0 -1
  351. flock/core/mcp/flock_mcp_server.py +0 -680
  352. flock/core/mcp/mcp_client_manager.py +0 -201
  353. flock/core/mcp/types/__init__.py +0 -1
  354. flock/core/mixin/dspy_integration.py +0 -403
  355. flock/core/mixin/prompt_parser.py +0 -125
  356. flock/core/orchestration/__init__.py +0 -15
  357. flock/core/orchestration/flock_batch_processor.py +0 -94
  358. flock/core/orchestration/flock_evaluator.py +0 -113
  359. flock/core/orchestration/flock_execution.py +0 -295
  360. flock/core/orchestration/flock_initialization.py +0 -149
  361. flock/core/orchestration/flock_server_manager.py +0 -67
  362. flock/core/orchestration/flock_web_server.py +0 -117
  363. flock/core/registry/__init__.py +0 -45
  364. flock/core/registry/agent_registry.py +0 -69
  365. flock/core/registry/callable_registry.py +0 -139
  366. flock/core/registry/component_discovery.py +0 -142
  367. flock/core/registry/component_registry.py +0 -64
  368. flock/core/registry/config_mapping.py +0 -64
  369. flock/core/registry/decorators.py +0 -137
  370. flock/core/registry/registry_hub.py +0 -205
  371. flock/core/registry/server_registry.py +0 -57
  372. flock/core/registry/type_registry.py +0 -86
  373. flock/core/serialization/__init__.py +0 -13
  374. flock/core/serialization/callable_registry.py +0 -52
  375. flock/core/serialization/flock_serializer.py +0 -832
  376. flock/core/serialization/json_encoder.py +0 -41
  377. flock/core/serialization/secure_serializer.py +0 -175
  378. flock/core/serialization/serializable.py +0 -342
  379. flock/core/serialization/serialization_utils.py +0 -412
  380. flock/core/util/file_path_utils.py +0 -223
  381. flock/core/util/hydrator.py +0 -309
  382. flock/core/util/input_resolver.py +0 -164
  383. flock/core/util/loader.py +0 -59
  384. flock/core/util/splitter.py +0 -219
  385. flock/di.py +0 -27
  386. flock/platform/docker_tools.py +0 -49
  387. flock/platform/jaeger_install.py +0 -86
  388. flock/webapp/__init__.py +0 -1
  389. flock/webapp/app/__init__.py +0 -0
  390. flock/webapp/app/api/__init__.py +0 -0
  391. flock/webapp/app/api/agent_management.py +0 -241
  392. flock/webapp/app/api/execution.py +0 -709
  393. flock/webapp/app/api/flock_management.py +0 -129
  394. flock/webapp/app/api/registry_viewer.py +0 -30
  395. flock/webapp/app/chat.py +0 -665
  396. flock/webapp/app/config.py +0 -104
  397. flock/webapp/app/dependencies.py +0 -117
  398. flock/webapp/app/main.py +0 -1070
  399. flock/webapp/app/middleware.py +0 -113
  400. flock/webapp/app/models_ui.py +0 -7
  401. flock/webapp/app/services/__init__.py +0 -0
  402. flock/webapp/app/services/feedback_file_service.py +0 -363
  403. flock/webapp/app/services/flock_service.py +0 -337
  404. flock/webapp/app/services/sharing_models.py +0 -81
  405. flock/webapp/app/services/sharing_store.py +0 -762
  406. flock/webapp/app/templates/theme_mapper.html +0 -326
  407. flock/webapp/app/theme_mapper.py +0 -812
  408. flock/webapp/app/utils.py +0 -85
  409. flock/webapp/run.py +0 -215
  410. flock/webapp/static/css/chat.css +0 -301
  411. flock/webapp/static/css/components.css +0 -167
  412. flock/webapp/static/css/header.css +0 -39
  413. flock/webapp/static/css/layout.css +0 -46
  414. flock/webapp/static/css/sidebar.css +0 -127
  415. flock/webapp/static/css/two-pane.css +0 -48
  416. flock/webapp/templates/base.html +0 -200
  417. flock/webapp/templates/chat.html +0 -152
  418. flock/webapp/templates/chat_settings.html +0 -19
  419. flock/webapp/templates/flock_editor.html +0 -16
  420. flock/webapp/templates/index.html +0 -12
  421. flock/webapp/templates/partials/_agent_detail_form.html +0 -93
  422. flock/webapp/templates/partials/_agent_list.html +0 -18
  423. flock/webapp/templates/partials/_agent_manager_view.html +0 -51
  424. flock/webapp/templates/partials/_agent_tools_checklist.html +0 -14
  425. flock/webapp/templates/partials/_chat_container.html +0 -15
  426. flock/webapp/templates/partials/_chat_messages.html +0 -57
  427. flock/webapp/templates/partials/_chat_settings_form.html +0 -85
  428. flock/webapp/templates/partials/_create_flock_form.html +0 -50
  429. flock/webapp/templates/partials/_dashboard_flock_detail.html +0 -17
  430. flock/webapp/templates/partials/_dashboard_flock_file_list.html +0 -16
  431. flock/webapp/templates/partials/_dashboard_flock_properties_preview.html +0 -28
  432. flock/webapp/templates/partials/_dashboard_upload_flock_form.html +0 -16
  433. flock/webapp/templates/partials/_dynamic_input_form_content.html +0 -22
  434. flock/webapp/templates/partials/_env_vars_table.html +0 -23
  435. flock/webapp/templates/partials/_execution_form.html +0 -118
  436. flock/webapp/templates/partials/_execution_view_container.html +0 -28
  437. flock/webapp/templates/partials/_flock_file_list.html +0 -23
  438. flock/webapp/templates/partials/_flock_properties_form.html +0 -52
  439. flock/webapp/templates/partials/_flock_upload_form.html +0 -16
  440. flock/webapp/templates/partials/_header_flock_status.html +0 -5
  441. flock/webapp/templates/partials/_load_manager_view.html +0 -49
  442. flock/webapp/templates/partials/_registry_table.html +0 -25
  443. flock/webapp/templates/partials/_registry_viewer_content.html +0 -70
  444. flock/webapp/templates/partials/_results_display.html +0 -78
  445. flock/webapp/templates/partials/_settings_env_content.html +0 -9
  446. flock/webapp/templates/partials/_settings_theme_content.html +0 -14
  447. flock/webapp/templates/partials/_settings_view.html +0 -36
  448. flock/webapp/templates/partials/_share_chat_link_snippet.html +0 -11
  449. flock/webapp/templates/partials/_share_link_snippet.html +0 -35
  450. flock/webapp/templates/partials/_sidebar.html +0 -74
  451. flock/webapp/templates/partials/_streaming_results_container.html +0 -195
  452. flock/webapp/templates/partials/_structured_data_view.html +0 -40
  453. flock/webapp/templates/partials/_theme_preview.html +0 -36
  454. flock/webapp/templates/registry_viewer.html +0 -84
  455. flock/webapp/templates/shared_run_page.html +0 -140
  456. flock/workflow/__init__.py +0 -0
  457. flock/workflow/activities.py +0 -196
  458. flock/workflow/agent_activities.py +0 -24
  459. flock/workflow/agent_execution_activity.py +0 -202
  460. flock/workflow/flock_workflow.py +0 -214
  461. flock/workflow/temporal_config.py +0 -96
  462. flock/workflow/temporal_setup.py +0 -68
  463. flock_core-0.5.0b28.dist-info/METADATA +0 -274
  464. flock_core-0.5.0b28.dist-info/RECORD +0 -561
  465. flock_core-0.5.0b28.dist-info/entry_points.txt +0 -2
  466. /flock/{core/logging → logging}/formatters/themes.py +0 -0
  467. /flock/{core/logging → logging}/span_middleware/baggage_span_processor.py +0 -0
  468. /flock/{core/mcp → mcp}/util/__init__.py +0 -0
  469. {flock_core-0.5.0b28.dist-info → flock_core-0.5.0b51.dist-info}/WHEEL +0 -0
@@ -0,0 +1,116 @@
1
+ import { memo } from 'react';
2
+ import { NodeProps, Handle, Position } from '@xyflow/react';
3
+ import JsonView from '@uiw/react-json-view';
4
+ import { MessageNodeData } from '../../types/graph';
5
+
6
+ const MessageNode = memo(({ data, selected }: NodeProps) => {
7
+ const nodeData = data as MessageNodeData;
8
+ const artifactType = nodeData.artifactType;
9
+ const payload = nodeData.payload;
10
+ const producedBy = nodeData.producedBy;
11
+ const timestamp = nodeData.timestamp;
12
+ const isStreaming = nodeData.isStreaming || false;
13
+ const streamingText = nodeData.streamingText || '';
14
+
15
+ return (
16
+ <div
17
+ className={`message-node ${selected ? 'selected' : ''}`}
18
+ style={{
19
+ padding: '12px',
20
+ border: `2px solid ${selected ? '#8b5cf6' : '#e2e8f0'}`,
21
+ borderRadius: '8px',
22
+ backgroundColor: '#fefce8',
23
+ minWidth: '300px',
24
+ maxWidth: '600px',
25
+ width: 'auto',
26
+ boxShadow: selected ? '0 4px 12px rgba(139,92,246,0.3)' : '0 2px 8px rgba(0,0,0,0.1)',
27
+ transition: 'all 0.2s ease',
28
+ }}
29
+ >
30
+ <Handle type="target" position={Position.Left} />
31
+ <Handle type="source" position={Position.Right} />
32
+
33
+ {/* Header */}
34
+ <div style={{
35
+ marginBottom: '10px',
36
+ paddingBottom: '8px',
37
+ borderBottom: '1px solid #e2e8f0'
38
+ }}>
39
+ <div style={{
40
+ fontWeight: 700,
41
+ fontSize: '14px',
42
+ marginBottom: '4px',
43
+ color: '#713f12',
44
+ fontFamily: 'monospace'
45
+ }}>
46
+ {artifactType}
47
+ </div>
48
+ <div style={{
49
+ fontSize: '11px',
50
+ color: '#a8a29e',
51
+ display: 'flex',
52
+ justifyContent: 'space-between',
53
+ alignItems: 'center'
54
+ }}>
55
+ <div>by: <span style={{ color: '#78716c', fontWeight: 600 }}>{producedBy}</span></div>
56
+ <div>{new Date(timestamp).toLocaleTimeString()}</div>
57
+ </div>
58
+ </div>
59
+
60
+ {/* Content: Streaming text or JSON Payload */}
61
+ <div style={{
62
+ fontSize: '12px',
63
+ maxHeight: '600px',
64
+ overflowY: 'auto',
65
+ overflowX: 'auto',
66
+ whiteSpace: 'pre-wrap',
67
+ wordBreak: 'break-word'
68
+ }}>
69
+ {isStreaming ? (
70
+ /* Streaming: Show raw text with cursor */
71
+ <div style={{
72
+ fontFamily: 'ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace',
73
+ color: '#78716c',
74
+ lineHeight: '1.5'
75
+ }}>
76
+ {streamingText}
77
+ <span style={{
78
+ display: 'inline-block',
79
+ width: '8px',
80
+ height: '14px',
81
+ backgroundColor: '#8b5cf6',
82
+ marginLeft: '2px',
83
+ animation: 'blink 1s step-end infinite'
84
+ }} />
85
+ <style>{`
86
+ @keyframes blink {
87
+ 0%, 50% { opacity: 1; }
88
+ 51%, 100% { opacity: 0; }
89
+ }
90
+ `}</style>
91
+ </div>
92
+ ) : (
93
+ /* Complete: Show beautiful JSON */
94
+ <JsonView
95
+ value={payload}
96
+ collapsed={false}
97
+ displayDataTypes={false}
98
+ shortenTextAfterLength={0}
99
+ style={{
100
+ backgroundColor: 'transparent',
101
+ fontSize: '12px',
102
+ fontFamily: 'ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace',
103
+ '--w-rjv-line-color': '#78716c',
104
+ '--w-rjv-key-string': '#713f12',
105
+ '--w-rjv-info-color': '#a8a29e',
106
+ } as React.CSSProperties}
107
+ />
108
+ )}
109
+ </div>
110
+ </div>
111
+ );
112
+ });
113
+
114
+ MessageNode.displayName = 'MessageNode';
115
+
116
+ export default MessageNode;
@@ -0,0 +1,47 @@
1
+ import React from 'react';
2
+ import { MiniMap as ReactFlowMiniMap } from '@xyflow/react';
3
+
4
+ /**
5
+ * Phase 4: Graph Visualization & Dual Views - MiniMap Component
6
+ *
7
+ * Wrapper around React Flow's MiniMap component for graph navigation.
8
+ * Features:
9
+ * - Positioned in bottom-right corner
10
+ * - Size: 150x100px
11
+ * - Color-coded nodes: agents (blue), messages (green)
12
+ *
13
+ * SPECIFICATION: docs/specs/003-real-time-dashboard/PLAN.md Phase 4
14
+ */
15
+
16
+ const MiniMap: React.FC = () => {
17
+ // Color function for nodes in minimap - using design system colors
18
+ const nodeColor = (node: any) => {
19
+ switch (node.type) {
20
+ case 'agent':
21
+ return '#3b82f6'; // Blue for agents (var(--color-node-agent-border))
22
+ case 'message':
23
+ return '#f59e0b'; // Amber for messages (var(--color-node-message-border))
24
+ default:
25
+ return '#64748b'; // Gray for other nodes (var(--color-idle))
26
+ }
27
+ };
28
+
29
+ return (
30
+ <ReactFlowMiniMap
31
+ nodeColor={nodeColor}
32
+ style={{
33
+ width: 150,
34
+ height: 100,
35
+ backgroundColor: 'var(--color-bg-surface)',
36
+ border: 'var(--border-default)',
37
+ borderRadius: 'var(--radius-lg)',
38
+ }}
39
+ maskColor="rgba(10, 10, 11, 0.7)"
40
+ position="bottom-right"
41
+ pannable
42
+ zoomable
43
+ />
44
+ );
45
+ };
46
+
47
+ export default MiniMap;
@@ -0,0 +1,123 @@
1
+ import React from 'react';
2
+ import {
3
+ BaseEdge,
4
+ EdgeProps,
5
+ getBezierPath,
6
+ getStraightPath,
7
+ getSmoothStepPath,
8
+ getSimpleBezierPath,
9
+ EdgeLabelRenderer
10
+ } from '@xyflow/react';
11
+ import { useSettingsStore } from '../../store/settingsStore';
12
+
13
+ /**
14
+ * Phase 4: Graph Visualization & Dual Views - TransformEdge Component
15
+ *
16
+ * Custom edge for Blackboard View showing transformation between artifacts.
17
+ * Features:
18
+ * - Dashed line style to indicate transformation
19
+ * - Label with agent name
20
+ * - Arrow marker at target
21
+ *
22
+ * SPECIFICATION: docs/specs/003-real-time-dashboard/PLAN.md Phase 4
23
+ */
24
+
25
+ export interface TransformEdgeData {
26
+ transformerAgent: string;
27
+ runId: string;
28
+ durationMs?: number;
29
+ labelOffset?: number; // Phase 11: Vertical offset to prevent label overlap
30
+ }
31
+
32
+ const TransformEdge: React.FC<EdgeProps> = ({
33
+ id,
34
+ sourceX,
35
+ sourceY,
36
+ targetX,
37
+ targetY,
38
+ sourcePosition,
39
+ targetPosition,
40
+ label,
41
+ style = {},
42
+ markerEnd,
43
+ data,
44
+ selected,
45
+ }) => {
46
+ // Get edge settings from settings store
47
+ const edgeType = useSettingsStore((state) => state.graph.edgeType);
48
+ const edgeStrokeWidth = useSettingsStore((state) => state.graph.edgeStrokeWidth);
49
+ const showEdgeLabels = useSettingsStore((state) => state.graph.showEdgeLabels);
50
+
51
+ // Use appropriate path function based on settings
52
+ const getPath = () => {
53
+ const params = { sourceX, sourceY, sourcePosition, targetX, targetY, targetPosition };
54
+ switch (edgeType) {
55
+ case 'straight':
56
+ return getStraightPath(params);
57
+ case 'smoothstep':
58
+ return getSmoothStepPath(params);
59
+ case 'simplebezier':
60
+ return getSimpleBezierPath(params);
61
+ case 'bezier':
62
+ default:
63
+ return getBezierPath(params);
64
+ }
65
+ };
66
+
67
+ const [edgePath, labelX, labelY] = getPath();
68
+
69
+ // Phase 11 Bug Fix: Apply label offset to prevent overlap when multiple edges exist
70
+ const edgeData = data as TransformEdgeData | undefined;
71
+ const labelOffset = edgeData?.labelOffset || 0;
72
+
73
+ const [isHovered, setIsHovered] = React.useState(false);
74
+
75
+ // Determine edge color based on state
76
+ const edgeColor = selected || isHovered ? 'var(--color-edge-active)' : 'var(--color-edge-default)';
77
+
78
+ return (
79
+ <>
80
+ <BaseEdge
81
+ id={id}
82
+ path={edgePath}
83
+ style={{
84
+ ...style,
85
+ stroke: edgeColor,
86
+ strokeWidth: isHovered || selected ? edgeStrokeWidth + 1 : edgeStrokeWidth,
87
+ strokeDasharray: '5,5',
88
+ transition: 'var(--transition-all)',
89
+ filter: isHovered || selected ? `drop-shadow(0 0 4px ${edgeColor})` : 'none',
90
+ }}
91
+ markerEnd={markerEnd}
92
+ />
93
+ {label && showEdgeLabels && (
94
+ <EdgeLabelRenderer>
95
+ <div
96
+ style={{
97
+ position: 'absolute',
98
+ transform: `translate(-50%, -50%) translate(${labelX}px,${labelY + labelOffset}px)`,
99
+ fontSize: 'var(--font-size-caption)',
100
+ fontWeight: 'var(--font-weight-medium)',
101
+ background: 'var(--color-edge-label-bg)',
102
+ color: 'var(--color-edge-label-text)',
103
+ padding: 'var(--spacing-1) var(--spacing-2)',
104
+ borderRadius: 'var(--radius-sm)',
105
+ border: `var(--border-width-1) solid ${edgeColor}`,
106
+ pointerEvents: 'all',
107
+ backdropFilter: 'blur(var(--blur-sm))',
108
+ boxShadow: 'var(--shadow-sm)',
109
+ transition: 'var(--transition-all)',
110
+ }}
111
+ className="nodrag nopan"
112
+ onMouseEnter={() => setIsHovered(true)}
113
+ onMouseLeave={() => setIsHovered(false)}
114
+ >
115
+ {label}
116
+ </div>
117
+ </EdgeLabelRenderer>
118
+ )}
119
+ </>
120
+ );
121
+ };
122
+
123
+ export default TransformEdge;
@@ -0,0 +1,407 @@
1
+ /* ========================================
2
+ Dashboard Layout - Premium Dark Theme
3
+ Uses design system from frontend/src/styles/variables.css
4
+ ======================================== */
5
+
6
+ /* Layout Container */
7
+ .dashboard-layout {
8
+ width: 100vw;
9
+ height: 100vh;
10
+ display: flex;
11
+ flex-direction: column;
12
+ background: var(--color-bg-base);
13
+ overflow: hidden;
14
+ }
15
+
16
+ /* ========================================
17
+ Header
18
+ ======================================== */
19
+
20
+ .dashboard-header {
21
+ display: flex;
22
+ justify-content: space-between;
23
+ align-items: center;
24
+ gap: var(--space-layout-md);
25
+ padding: var(--space-component-md) var(--space-layout-sm);
26
+ background: var(--color-bg-surface);
27
+ border-bottom: var(--border-subtle);
28
+ box-shadow: var(--shadow-sm);
29
+ z-index: 100;
30
+ }
31
+
32
+ .dashboard-title {
33
+ margin: 0;
34
+ font-size: var(--font-size-h3);
35
+ font-weight: var(--font-weight-semibold);
36
+ color: var(--color-text-primary);
37
+ letter-spacing: var(--letter-spacing-tight);
38
+ white-space: nowrap;
39
+ }
40
+
41
+ /* ========================================
42
+ View Toggle - Premium Pill Design
43
+ ======================================== */
44
+
45
+ .view-toggle-container {
46
+ display: flex;
47
+ align-items: center;
48
+ gap: var(--gap-md);
49
+ flex: 1;
50
+ justify-content: center;
51
+ }
52
+
53
+ .view-toggle-label {
54
+ font-size: var(--font-size-body-sm);
55
+ font-weight: var(--font-weight-medium);
56
+ color: var(--color-text-tertiary);
57
+ letter-spacing: var(--letter-spacing-wide);
58
+ text-transform: uppercase;
59
+ font-size: var(--font-size-caption);
60
+ }
61
+
62
+ .view-toggle-group {
63
+ display: inline-flex;
64
+ background: var(--color-bg-elevated);
65
+ padding: var(--spacing-1);
66
+ border-radius: var(--radius-full);
67
+ border: var(--border-subtle);
68
+ box-shadow: var(--shadow-inner);
69
+ gap: var(--gap-xs);
70
+ }
71
+
72
+ .view-toggle-button {
73
+ position: relative;
74
+ padding: var(--space-component-sm) var(--space-component-lg);
75
+ background: transparent;
76
+ color: var(--color-text-tertiary);
77
+ border: none;
78
+ border-radius: var(--radius-full);
79
+ font-family: var(--font-family-sans);
80
+ font-size: var(--font-size-body-sm);
81
+ font-weight: var(--font-weight-medium);
82
+ cursor: pointer;
83
+ transition: var(--transition-colors), var(--transition-transform);
84
+ white-space: nowrap;
85
+ }
86
+
87
+ .view-toggle-button:hover:not(.active) {
88
+ color: var(--color-text-secondary);
89
+ background: var(--color-bg-overlay);
90
+ }
91
+
92
+ .view-toggle-button.active {
93
+ background: var(--color-primary-500);
94
+ color: var(--color-text-on-primary);
95
+ box-shadow: var(--shadow-sm);
96
+ }
97
+
98
+ .view-toggle-button:active {
99
+ transform: scale(0.98);
100
+ }
101
+
102
+ .view-toggle-button:focus-visible {
103
+ outline: none;
104
+ box-shadow: var(--shadow-glow-primary);
105
+ }
106
+
107
+ /* ========================================
108
+ Dashboard Actions
109
+ ======================================== */
110
+
111
+ .dashboard-actions {
112
+ display: flex;
113
+ align-items: center;
114
+ gap: var(--gap-md);
115
+ }
116
+
117
+ /* Icon Button - Subtle, Icon-based Clear Button */
118
+ .icon-button {
119
+ display: inline-flex;
120
+ align-items: center;
121
+ justify-content: center;
122
+ width: 32px;
123
+ height: 32px;
124
+ padding: var(--spacing-2);
125
+ background: transparent;
126
+ color: var(--color-text-tertiary);
127
+ border: none;
128
+ border-radius: var(--radius-md);
129
+ cursor: pointer;
130
+ transition: var(--transition-colors), var(--transition-transform);
131
+ }
132
+
133
+ .icon-button:hover {
134
+ background: var(--color-bg-overlay);
135
+ color: var(--color-text-secondary);
136
+ }
137
+
138
+ .icon-button:active {
139
+ transform: scale(0.95);
140
+ }
141
+
142
+ .icon-button:focus-visible {
143
+ outline: none;
144
+ box-shadow: var(--shadow-glow-primary);
145
+ }
146
+
147
+ .help-button:hover {
148
+ color: var(--color-primary-500);
149
+ background: var(--color-primary-50);
150
+ }
151
+
152
+ .help-button:focus-visible {
153
+ box-shadow: var(--shadow-glow-primary);
154
+ }
155
+
156
+ .clear-button:hover {
157
+ color: var(--color-error);
158
+ background: var(--color-error-bg);
159
+ }
160
+
161
+ .clear-button:focus-visible {
162
+ box-shadow: var(--shadow-glow-error);
163
+ }
164
+
165
+ /* Controls Toggle - Elegant Premium Button */
166
+ .controls-toggle {
167
+ display: inline-flex;
168
+ align-items: center;
169
+ gap: var(--gap-sm);
170
+ padding: var(--space-component-sm) var(--space-component-md);
171
+ background: var(--color-bg-elevated);
172
+ color: var(--color-text-secondary);
173
+ border: var(--border-default);
174
+ border-radius: var(--radius-md);
175
+ font-family: var(--font-family-sans);
176
+ font-size: var(--font-size-body-sm);
177
+ font-weight: var(--font-weight-medium);
178
+ cursor: pointer;
179
+ transition: var(--transition-colors), var(--transition-shadow), var(--transition-transform);
180
+ white-space: nowrap;
181
+ }
182
+
183
+ /* Primary variant - for important actions like Publish */
184
+ .controls-toggle.primary {
185
+ background: var(--color-primary-500);
186
+ color: var(--color-text-on-primary);
187
+ border-color: var(--color-primary-500);
188
+ box-shadow: var(--shadow-md);
189
+ font-weight: var(--font-weight-semibold);
190
+ }
191
+
192
+ .controls-toggle.primary:hover {
193
+ background: var(--color-primary-600);
194
+ border-color: var(--color-primary-600);
195
+ box-shadow: var(--shadow-lg);
196
+ }
197
+
198
+ .controls-toggle.primary.active {
199
+ background: var(--color-primary-700);
200
+ border-color: var(--color-primary-700);
201
+ }
202
+
203
+ .controls-toggle:hover {
204
+ background: var(--color-bg-surface);
205
+ color: var(--color-text-primary);
206
+ border-color: var(--color-border-strong);
207
+ box-shadow: var(--shadow-sm);
208
+ }
209
+
210
+ .controls-toggle.active {
211
+ background: var(--color-success);
212
+ color: var(--color-text-on-primary);
213
+ border-color: var(--color-success);
214
+ box-shadow: var(--shadow-sm);
215
+ }
216
+
217
+ .controls-toggle.active:hover {
218
+ background: var(--color-success-dark);
219
+ border-color: var(--color-success-dark);
220
+ }
221
+
222
+ .controls-toggle:active {
223
+ transform: scale(0.98);
224
+ }
225
+
226
+ .controls-toggle:focus-visible {
227
+ outline: none;
228
+ box-shadow: var(--shadow-glow-primary);
229
+ }
230
+
231
+ .controls-toggle.active:focus-visible {
232
+ box-shadow: var(--shadow-glow-success);
233
+ }
234
+
235
+ .controls-toggle svg {
236
+ width: 16px;
237
+ height: 16px;
238
+ flex-shrink: 0;
239
+ transition: var(--transition-transform);
240
+ }
241
+
242
+ .controls-toggle.active svg {
243
+ transform: rotate(45deg);
244
+ }
245
+
246
+ /* ========================================
247
+ Main Content Area
248
+ ======================================== */
249
+
250
+ .dashboard-main {
251
+ flex: 1;
252
+ display: flex;
253
+ overflow: hidden;
254
+ position: relative;
255
+ }
256
+
257
+ .graph-container {
258
+ flex: 1;
259
+ overflow: hidden;
260
+ position: relative;
261
+ }
262
+
263
+ /* ========================================
264
+ Controls Sidebar - Premium Glassmorphism
265
+ ======================================== */
266
+
267
+ .controls-sidebar {
268
+ width: 400px;
269
+ background: var(--color-glass-bg);
270
+ backdrop-filter: blur(var(--blur-lg));
271
+ -webkit-backdrop-filter: blur(var(--blur-lg));
272
+ border-left: var(--border-subtle);
273
+ box-shadow: var(--shadow-lg);
274
+ overflow-y: auto;
275
+ animation: slideInRight var(--duration-slow) var(--ease-smooth);
276
+ }
277
+
278
+ @keyframes slideInRight {
279
+ from {
280
+ opacity: 0;
281
+ transform: translateX(20px);
282
+ }
283
+ to {
284
+ opacity: 1;
285
+ transform: translateX(0);
286
+ }
287
+ }
288
+
289
+ .controls-sidebar-inner {
290
+ padding: var(--space-layout-sm);
291
+ }
292
+
293
+ .controls-title {
294
+ margin: 0 0 var(--space-layout-sm) 0;
295
+ font-size: var(--font-size-h4);
296
+ font-weight: var(--font-weight-semibold);
297
+ color: var(--color-text-primary);
298
+ letter-spacing: var(--letter-spacing-tight);
299
+ }
300
+
301
+ .control-section {
302
+ margin-bottom: var(--space-layout-md);
303
+ }
304
+
305
+ .control-section-title {
306
+ margin: 0 0 var(--space-component-md) 0;
307
+ font-size: var(--font-size-h5);
308
+ font-weight: var(--font-weight-medium);
309
+ color: var(--color-text-secondary);
310
+ }
311
+
312
+ /* ========================================
313
+ Scrollbar Styling
314
+ ======================================== */
315
+
316
+ .controls-sidebar::-webkit-scrollbar {
317
+ width: 8px;
318
+ }
319
+
320
+ .controls-sidebar::-webkit-scrollbar-track {
321
+ background: var(--color-bg-elevated);
322
+ }
323
+
324
+ .controls-sidebar::-webkit-scrollbar-thumb {
325
+ background: var(--color-border-default);
326
+ border-radius: var(--radius-full);
327
+ transition: var(--transition-colors);
328
+ }
329
+
330
+ .controls-sidebar::-webkit-scrollbar-thumb:hover {
331
+ background: var(--color-border-strong);
332
+ }
333
+
334
+ /* ========================================
335
+ Responsive Design
336
+ ======================================== */
337
+
338
+ @media (max-width: 1024px) {
339
+ .dashboard-header {
340
+ flex-wrap: wrap;
341
+ gap: var(--gap-md);
342
+ }
343
+
344
+ .view-toggle-container {
345
+ order: 3;
346
+ width: 100%;
347
+ justify-content: center;
348
+ }
349
+
350
+ .controls-sidebar {
351
+ width: 320px;
352
+ }
353
+ }
354
+
355
+ @media (max-width: 768px) {
356
+ .dashboard-title {
357
+ font-size: var(--font-size-h4);
358
+ }
359
+
360
+ .view-toggle-button {
361
+ padding: var(--spacing-2) var(--spacing-4);
362
+ font-size: var(--font-size-caption);
363
+ }
364
+
365
+ .controls-toggle span {
366
+ display: none;
367
+ }
368
+
369
+ .controls-sidebar {
370
+ width: 280px;
371
+ }
372
+ }
373
+
374
+ /* ========================================
375
+ Accessibility - Reduced Motion
376
+ ======================================== */
377
+
378
+ @media (prefers-reduced-motion: reduce) {
379
+ .controls-sidebar {
380
+ animation: none;
381
+ }
382
+
383
+ .view-toggle-button,
384
+ .icon-button,
385
+ .controls-toggle {
386
+ transition: none;
387
+ }
388
+
389
+ .controls-toggle svg {
390
+ transition: none;
391
+ }
392
+ }
393
+
394
+ /* ========================================
395
+ Print Styles
396
+ ======================================== */
397
+
398
+ @media print {
399
+ .dashboard-header,
400
+ .controls-sidebar {
401
+ display: none;
402
+ }
403
+
404
+ .dashboard-main {
405
+ flex: 1;
406
+ }
407
+ }