flock-core 0.5.0b28__py3-none-any.whl → 0.5.56b0__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 (359) 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/{core/util → helper}/cli_helper.py +4 -3
  17. flock/{core/logging → logging}/__init__.py +2 -3
  18. flock/{core/logging → logging}/formatters/enum_builder.py +3 -4
  19. flock/{core/logging → logging}/formatters/theme_builder.py +19 -44
  20. flock/{core/logging → logging}/formatters/themed_formatter.py +69 -115
  21. flock/{core/logging → logging}/logging.py +77 -61
  22. flock/{core/logging → logging}/telemetry.py +20 -26
  23. flock/{core/logging → logging}/telemetry_exporter/base_exporter.py +2 -2
  24. flock/{core/logging → logging}/telemetry_exporter/file_exporter.py +6 -9
  25. flock/{core/logging → logging}/telemetry_exporter/sqlite_exporter.py +2 -3
  26. flock/{core/logging → logging}/trace_and_logged.py +20 -24
  27. flock/mcp/__init__.py +91 -0
  28. flock/{core/mcp/mcp_client.py → mcp/client.py} +103 -154
  29. flock/{core/mcp/mcp_config.py → mcp/config.py} +62 -117
  30. flock/mcp/manager.py +255 -0
  31. flock/mcp/servers/sse/__init__.py +1 -1
  32. flock/mcp/servers/sse/flock_sse_server.py +11 -53
  33. flock/mcp/servers/stdio/__init__.py +1 -1
  34. flock/mcp/servers/stdio/flock_stdio_server.py +8 -48
  35. flock/mcp/servers/streamable_http/flock_streamable_http_server.py +17 -62
  36. flock/mcp/servers/websockets/flock_websocket_server.py +7 -40
  37. flock/{core/mcp/flock_mcp_tool.py → mcp/tool.py} +16 -26
  38. flock/mcp/types/__init__.py +42 -0
  39. flock/{core/mcp → mcp}/types/callbacks.py +9 -15
  40. flock/{core/mcp → mcp}/types/factories.py +7 -6
  41. flock/{core/mcp → mcp}/types/handlers.py +13 -18
  42. flock/{core/mcp → mcp}/types/types.py +70 -74
  43. flock/{core/mcp → mcp}/util/helpers.py +1 -1
  44. flock/orchestrator.py +645 -0
  45. flock/registry.py +148 -0
  46. flock/runtime.py +262 -0
  47. flock/service.py +140 -0
  48. flock/store.py +69 -0
  49. flock/subscription.py +111 -0
  50. flock/themes/andromeda.toml +1 -1
  51. flock/themes/apple-system-colors.toml +1 -1
  52. flock/themes/arcoiris.toml +1 -1
  53. flock/themes/atomonelight.toml +1 -1
  54. flock/themes/ayu copy.toml +1 -1
  55. flock/themes/ayu-light.toml +1 -1
  56. flock/themes/belafonte-day.toml +1 -1
  57. flock/themes/belafonte-night.toml +1 -1
  58. flock/themes/blulocodark.toml +1 -1
  59. flock/themes/breeze.toml +1 -1
  60. flock/themes/broadcast.toml +1 -1
  61. flock/themes/brogrammer.toml +1 -1
  62. flock/themes/builtin-dark.toml +1 -1
  63. flock/themes/builtin-pastel-dark.toml +1 -1
  64. flock/themes/catppuccin-latte.toml +1 -1
  65. flock/themes/catppuccin-macchiato.toml +1 -1
  66. flock/themes/catppuccin-mocha.toml +1 -1
  67. flock/themes/cga.toml +1 -1
  68. flock/themes/chalk.toml +1 -1
  69. flock/themes/ciapre.toml +1 -1
  70. flock/themes/coffee-theme.toml +1 -1
  71. flock/themes/cyberpunkscarletprotocol.toml +1 -1
  72. flock/themes/dark+.toml +1 -1
  73. flock/themes/darkermatrix.toml +1 -1
  74. flock/themes/darkside.toml +1 -1
  75. flock/themes/desert.toml +1 -1
  76. flock/themes/django.toml +1 -1
  77. flock/themes/djangosmooth.toml +1 -1
  78. flock/themes/doomone.toml +1 -1
  79. flock/themes/dotgov.toml +1 -1
  80. flock/themes/dracula+.toml +1 -1
  81. flock/themes/duckbones.toml +1 -1
  82. flock/themes/encom.toml +1 -1
  83. flock/themes/espresso.toml +1 -1
  84. flock/themes/everblush.toml +1 -1
  85. flock/themes/fairyfloss.toml +1 -1
  86. flock/themes/fideloper.toml +1 -1
  87. flock/themes/fishtank.toml +1 -1
  88. flock/themes/flexoki-light.toml +1 -1
  89. flock/themes/floraverse.toml +1 -1
  90. flock/themes/framer.toml +1 -1
  91. flock/themes/galizur.toml +1 -1
  92. flock/themes/github.toml +1 -1
  93. flock/themes/grass.toml +1 -1
  94. flock/themes/grey-green.toml +1 -1
  95. flock/themes/gruvboxlight.toml +1 -1
  96. flock/themes/guezwhoz.toml +1 -1
  97. flock/themes/harper.toml +1 -1
  98. flock/themes/hax0r-blue.toml +1 -1
  99. flock/themes/hopscotch.256.toml +1 -1
  100. flock/themes/ic-green-ppl.toml +1 -1
  101. flock/themes/iceberg-dark.toml +1 -1
  102. flock/themes/japanesque.toml +1 -1
  103. flock/themes/jubi.toml +1 -1
  104. flock/themes/kibble.toml +1 -1
  105. flock/themes/kolorit.toml +1 -1
  106. flock/themes/kurokula.toml +1 -1
  107. flock/themes/materialdesigncolors.toml +1 -1
  108. flock/themes/matrix.toml +1 -1
  109. flock/themes/mellifluous.toml +1 -1
  110. flock/themes/midnight-in-mojave.toml +1 -1
  111. flock/themes/monokai-remastered.toml +1 -1
  112. flock/themes/monokai-soda.toml +1 -1
  113. flock/themes/neon.toml +1 -1
  114. flock/themes/neopolitan.toml +1 -1
  115. flock/themes/nord-light.toml +1 -1
  116. flock/themes/ocean.toml +1 -1
  117. flock/themes/onehalfdark.toml +1 -1
  118. flock/themes/onehalflight.toml +1 -1
  119. flock/themes/palenighthc.toml +1 -1
  120. flock/themes/paulmillr.toml +1 -1
  121. flock/themes/pencildark.toml +1 -1
  122. flock/themes/pnevma.toml +1 -1
  123. flock/themes/purple-rain.toml +1 -1
  124. flock/themes/purplepeter.toml +1 -1
  125. flock/themes/raycast-dark.toml +1 -1
  126. flock/themes/red-sands.toml +1 -1
  127. flock/themes/relaxed.toml +1 -1
  128. flock/themes/retro.toml +1 -1
  129. flock/themes/rose-pine.toml +1 -1
  130. flock/themes/royal.toml +1 -1
  131. flock/themes/ryuuko.toml +1 -1
  132. flock/themes/sakura.toml +1 -1
  133. flock/themes/scarlet-protocol.toml +1 -1
  134. flock/themes/seoulbones-dark.toml +1 -1
  135. flock/themes/shades-of-purple.toml +1 -1
  136. flock/themes/smyck.toml +1 -1
  137. flock/themes/softserver.toml +1 -1
  138. flock/themes/solarized-darcula.toml +1 -1
  139. flock/themes/square.toml +1 -1
  140. flock/themes/sugarplum.toml +1 -1
  141. flock/themes/thayer-bright.toml +1 -1
  142. flock/themes/tokyonight.toml +1 -1
  143. flock/themes/tomorrow.toml +1 -1
  144. flock/themes/ubuntu.toml +1 -1
  145. flock/themes/ultradark.toml +1 -1
  146. flock/themes/ultraviolent.toml +1 -1
  147. flock/themes/unikitty.toml +1 -1
  148. flock/themes/urple.toml +1 -1
  149. flock/themes/vesper.toml +1 -1
  150. flock/themes/vimbones.toml +1 -1
  151. flock/themes/wildcherry.toml +1 -1
  152. flock/themes/wilmersdorf.toml +1 -1
  153. flock/themes/wryan.toml +1 -1
  154. flock/themes/xcodedarkhc.toml +1 -1
  155. flock/themes/xcodelight.toml +1 -1
  156. flock/themes/zenbones-light.toml +1 -1
  157. flock/themes/zenwritten-dark.toml +1 -1
  158. flock/utilities.py +301 -0
  159. flock/{components/utility → utility}/output_utility_component.py +68 -53
  160. flock/visibility.py +107 -0
  161. flock_core-0.5.56b0.dist-info/METADATA +747 -0
  162. flock_core-0.5.56b0.dist-info/RECORD +398 -0
  163. flock_core-0.5.56b0.dist-info/entry_points.txt +2 -0
  164. {flock_core-0.5.0b28.dist-info → flock_core-0.5.56b0.dist-info}/licenses/LICENSE +1 -1
  165. flock/adapter/__init__.py +0 -14
  166. flock/adapter/azure_adapter.py +0 -68
  167. flock/adapter/chroma_adapter.py +0 -73
  168. flock/adapter/faiss_adapter.py +0 -97
  169. flock/adapter/pinecone_adapter.py +0 -51
  170. flock/adapter/vector_base.py +0 -47
  171. flock/cli/assets/release_notes.md +0 -140
  172. flock/cli/config.py +0 -8
  173. flock/cli/constants.py +0 -36
  174. flock/cli/create_agent.py +0 -1
  175. flock/cli/create_flock.py +0 -280
  176. flock/cli/execute_flock.py +0 -620
  177. flock/cli/load_agent.py +0 -1
  178. flock/cli/load_examples.py +0 -1
  179. flock/cli/load_flock.py +0 -192
  180. flock/cli/load_release_notes.py +0 -20
  181. flock/cli/loaded_flock_cli.py +0 -254
  182. flock/cli/manage_agents.py +0 -459
  183. flock/cli/registry_management.py +0 -889
  184. flock/cli/runner.py +0 -41
  185. flock/cli/settings.py +0 -857
  186. flock/cli/utils.py +0 -135
  187. flock/cli/view_results.py +0 -29
  188. flock/cli/yaml_editor.py +0 -396
  189. flock/components/__init__.py +0 -30
  190. flock/components/evaluation/__init__.py +0 -9
  191. flock/components/evaluation/declarative_evaluation_component.py +0 -606
  192. flock/components/routing/__init__.py +0 -15
  193. flock/components/routing/conditional_routing_component.py +0 -494
  194. flock/components/routing/default_routing_component.py +0 -103
  195. flock/components/routing/llm_routing_component.py +0 -206
  196. flock/components/utility/__init__.py +0 -22
  197. flock/components/utility/example_utility_component.py +0 -250
  198. flock/components/utility/feedback_utility_component.py +0 -206
  199. flock/components/utility/memory_utility_component.py +0 -550
  200. flock/components/utility/metrics_utility_component.py +0 -700
  201. flock/config.py +0 -61
  202. flock/core/__init__.py +0 -110
  203. flock/core/agent/__init__.py +0 -16
  204. flock/core/agent/default_agent.py +0 -216
  205. flock/core/agent/flock_agent_components.py +0 -104
  206. flock/core/agent/flock_agent_execution.py +0 -101
  207. flock/core/agent/flock_agent_integration.py +0 -260
  208. flock/core/agent/flock_agent_lifecycle.py +0 -186
  209. flock/core/agent/flock_agent_serialization.py +0 -381
  210. flock/core/api/__init__.py +0 -10
  211. flock/core/api/custom_endpoint.py +0 -45
  212. flock/core/api/endpoints.py +0 -254
  213. flock/core/api/main.py +0 -162
  214. flock/core/api/models.py +0 -97
  215. flock/core/api/run_store.py +0 -224
  216. flock/core/api/runner.py +0 -44
  217. flock/core/api/service.py +0 -214
  218. flock/core/component/__init__.py +0 -15
  219. flock/core/component/agent_component_base.py +0 -309
  220. flock/core/component/evaluation_component.py +0 -62
  221. flock/core/component/routing_component.py +0 -74
  222. flock/core/component/utility_component.py +0 -69
  223. flock/core/config/flock_agent_config.py +0 -58
  224. flock/core/config/scheduled_agent_config.py +0 -40
  225. flock/core/context/context.py +0 -213
  226. flock/core/context/context_manager.py +0 -37
  227. flock/core/context/context_vars.py +0 -10
  228. flock/core/evaluation/utils.py +0 -396
  229. flock/core/execution/batch_executor.py +0 -369
  230. flock/core/execution/evaluation_executor.py +0 -438
  231. flock/core/execution/local_executor.py +0 -31
  232. flock/core/execution/opik_executor.py +0 -103
  233. flock/core/execution/temporal_executor.py +0 -164
  234. flock/core/flock.py +0 -634
  235. flock/core/flock_agent.py +0 -336
  236. flock/core/flock_factory.py +0 -613
  237. flock/core/flock_scheduler.py +0 -166
  238. flock/core/flock_server_manager.py +0 -136
  239. flock/core/interpreter/python_interpreter.py +0 -689
  240. flock/core/mcp/__init__.py +0 -1
  241. flock/core/mcp/flock_mcp_server.py +0 -680
  242. flock/core/mcp/mcp_client_manager.py +0 -201
  243. flock/core/mcp/types/__init__.py +0 -1
  244. flock/core/mixin/dspy_integration.py +0 -403
  245. flock/core/mixin/prompt_parser.py +0 -125
  246. flock/core/orchestration/__init__.py +0 -15
  247. flock/core/orchestration/flock_batch_processor.py +0 -94
  248. flock/core/orchestration/flock_evaluator.py +0 -113
  249. flock/core/orchestration/flock_execution.py +0 -295
  250. flock/core/orchestration/flock_initialization.py +0 -149
  251. flock/core/orchestration/flock_server_manager.py +0 -67
  252. flock/core/orchestration/flock_web_server.py +0 -117
  253. flock/core/registry/__init__.py +0 -45
  254. flock/core/registry/agent_registry.py +0 -69
  255. flock/core/registry/callable_registry.py +0 -139
  256. flock/core/registry/component_discovery.py +0 -142
  257. flock/core/registry/component_registry.py +0 -64
  258. flock/core/registry/config_mapping.py +0 -64
  259. flock/core/registry/decorators.py +0 -137
  260. flock/core/registry/registry_hub.py +0 -205
  261. flock/core/registry/server_registry.py +0 -57
  262. flock/core/registry/type_registry.py +0 -86
  263. flock/core/serialization/__init__.py +0 -13
  264. flock/core/serialization/callable_registry.py +0 -52
  265. flock/core/serialization/flock_serializer.py +0 -832
  266. flock/core/serialization/json_encoder.py +0 -41
  267. flock/core/serialization/secure_serializer.py +0 -175
  268. flock/core/serialization/serializable.py +0 -342
  269. flock/core/serialization/serialization_utils.py +0 -412
  270. flock/core/util/file_path_utils.py +0 -223
  271. flock/core/util/hydrator.py +0 -309
  272. flock/core/util/input_resolver.py +0 -164
  273. flock/core/util/loader.py +0 -59
  274. flock/core/util/splitter.py +0 -219
  275. flock/di.py +0 -27
  276. flock/platform/docker_tools.py +0 -49
  277. flock/platform/jaeger_install.py +0 -86
  278. flock/webapp/__init__.py +0 -1
  279. flock/webapp/app/__init__.py +0 -0
  280. flock/webapp/app/api/__init__.py +0 -0
  281. flock/webapp/app/api/agent_management.py +0 -241
  282. flock/webapp/app/api/execution.py +0 -709
  283. flock/webapp/app/api/flock_management.py +0 -129
  284. flock/webapp/app/api/registry_viewer.py +0 -30
  285. flock/webapp/app/chat.py +0 -665
  286. flock/webapp/app/config.py +0 -104
  287. flock/webapp/app/dependencies.py +0 -117
  288. flock/webapp/app/main.py +0 -1070
  289. flock/webapp/app/middleware.py +0 -113
  290. flock/webapp/app/models_ui.py +0 -7
  291. flock/webapp/app/services/__init__.py +0 -0
  292. flock/webapp/app/services/feedback_file_service.py +0 -363
  293. flock/webapp/app/services/flock_service.py +0 -337
  294. flock/webapp/app/services/sharing_models.py +0 -81
  295. flock/webapp/app/services/sharing_store.py +0 -762
  296. flock/webapp/app/templates/theme_mapper.html +0 -326
  297. flock/webapp/app/theme_mapper.py +0 -812
  298. flock/webapp/app/utils.py +0 -85
  299. flock/webapp/run.py +0 -215
  300. flock/webapp/static/css/chat.css +0 -301
  301. flock/webapp/static/css/components.css +0 -167
  302. flock/webapp/static/css/header.css +0 -39
  303. flock/webapp/static/css/layout.css +0 -46
  304. flock/webapp/static/css/sidebar.css +0 -127
  305. flock/webapp/static/css/two-pane.css +0 -48
  306. flock/webapp/templates/base.html +0 -200
  307. flock/webapp/templates/chat.html +0 -152
  308. flock/webapp/templates/chat_settings.html +0 -19
  309. flock/webapp/templates/flock_editor.html +0 -16
  310. flock/webapp/templates/index.html +0 -12
  311. flock/webapp/templates/partials/_agent_detail_form.html +0 -93
  312. flock/webapp/templates/partials/_agent_list.html +0 -18
  313. flock/webapp/templates/partials/_agent_manager_view.html +0 -51
  314. flock/webapp/templates/partials/_agent_tools_checklist.html +0 -14
  315. flock/webapp/templates/partials/_chat_container.html +0 -15
  316. flock/webapp/templates/partials/_chat_messages.html +0 -57
  317. flock/webapp/templates/partials/_chat_settings_form.html +0 -85
  318. flock/webapp/templates/partials/_create_flock_form.html +0 -50
  319. flock/webapp/templates/partials/_dashboard_flock_detail.html +0 -17
  320. flock/webapp/templates/partials/_dashboard_flock_file_list.html +0 -16
  321. flock/webapp/templates/partials/_dashboard_flock_properties_preview.html +0 -28
  322. flock/webapp/templates/partials/_dashboard_upload_flock_form.html +0 -16
  323. flock/webapp/templates/partials/_dynamic_input_form_content.html +0 -22
  324. flock/webapp/templates/partials/_env_vars_table.html +0 -23
  325. flock/webapp/templates/partials/_execution_form.html +0 -118
  326. flock/webapp/templates/partials/_execution_view_container.html +0 -28
  327. flock/webapp/templates/partials/_flock_file_list.html +0 -23
  328. flock/webapp/templates/partials/_flock_properties_form.html +0 -52
  329. flock/webapp/templates/partials/_flock_upload_form.html +0 -16
  330. flock/webapp/templates/partials/_header_flock_status.html +0 -5
  331. flock/webapp/templates/partials/_load_manager_view.html +0 -49
  332. flock/webapp/templates/partials/_registry_table.html +0 -25
  333. flock/webapp/templates/partials/_registry_viewer_content.html +0 -70
  334. flock/webapp/templates/partials/_results_display.html +0 -78
  335. flock/webapp/templates/partials/_settings_env_content.html +0 -9
  336. flock/webapp/templates/partials/_settings_theme_content.html +0 -14
  337. flock/webapp/templates/partials/_settings_view.html +0 -36
  338. flock/webapp/templates/partials/_share_chat_link_snippet.html +0 -11
  339. flock/webapp/templates/partials/_share_link_snippet.html +0 -35
  340. flock/webapp/templates/partials/_sidebar.html +0 -74
  341. flock/webapp/templates/partials/_streaming_results_container.html +0 -195
  342. flock/webapp/templates/partials/_structured_data_view.html +0 -40
  343. flock/webapp/templates/partials/_theme_preview.html +0 -36
  344. flock/webapp/templates/registry_viewer.html +0 -84
  345. flock/webapp/templates/shared_run_page.html +0 -140
  346. flock/workflow/__init__.py +0 -0
  347. flock/workflow/activities.py +0 -196
  348. flock/workflow/agent_activities.py +0 -24
  349. flock/workflow/agent_execution_activity.py +0 -202
  350. flock/workflow/flock_workflow.py +0 -214
  351. flock/workflow/temporal_config.py +0 -96
  352. flock/workflow/temporal_setup.py +0 -68
  353. flock_core-0.5.0b28.dist-info/METADATA +0 -274
  354. flock_core-0.5.0b28.dist-info/RECORD +0 -561
  355. flock_core-0.5.0b28.dist-info/entry_points.txt +0 -2
  356. /flock/{core/logging → logging}/formatters/themes.py +0 -0
  357. /flock/{core/logging → logging}/span_middleware/baggage_span_processor.py +0 -0
  358. /flock/{core/mcp → mcp}/util/__init__.py +0 -0
  359. {flock_core-0.5.0b28.dist-info → flock_core-0.5.56b0.dist-info}/WHEEL +0 -0
@@ -1,167 +0,0 @@
1
- /* ========================================================================
2
- components.css — Reusable component / utility styles
3
- ======================================================================== */
4
-
5
- /* ---------- Message container (toast notifications) ---------- */
6
- .message-container {
7
- position: fixed;
8
- bottom: 3rem;
9
- right: 1rem;
10
- z-index: 1002;
11
- max-width: 400px;
12
- }
13
-
14
- .message-container > div {
15
- margin-top: 0.5rem;
16
- box-shadow: var(--pico-card-box-shadow);
17
- display: flex;
18
- justify-content: space-between;
19
- align-items: center;
20
- padding: 0.75rem;
21
- border-radius: var(--pico-border-radius);
22
- font-weight: 500;
23
- }
24
-
25
- .message-container .success {
26
- background-color: var(--flock-success-color, var(--pico-ins-color));
27
- color: var(--pico-primary-inverse);
28
- border: 1px solid var(--flock-success-color, var(--pico-ins-color));
29
- }
30
-
31
- .message-container .error {
32
- background-color: var(--flock-error-color, var(--pico-del-color));
33
- color: var(--pico-primary-inverse);
34
- border: 1px solid var(--flock-error-color, var(--pico-del-color));
35
- }
36
-
37
- .message-container .close {
38
- background: none;
39
- border: none;
40
- color: inherit;
41
- font-size: 1.2rem;
42
- cursor: pointer;
43
- padding: 0 0.5rem;
44
- margin-left: 1rem;
45
- }
46
-
47
- /* ---------- HTMX loading indicator ---------- */
48
- .htmx-indicator { display: none; opacity: 0; transition: opacity 0.3s ease-in-out; }
49
- .htmx-request .htmx-indicator { display: inline-block; opacity: 1; margin-left: 0.5em; }
50
- .htmx-request.htmx-indicator { display: inline-block; opacity: 1; }
51
-
52
- /* ---------- Form & validation helpers ---------- */
53
- .field-error { color: var(--flock-error-color, var(--pico-del-color)); font-size: var(--pico-font-size-small); margin-top: -0.5rem; margin-bottom: 0.5rem; }
54
-
55
- /* ---------- Main content headings ---------- */
56
- main.main-content h1, main.main-content h2, main.main-content h3 {
57
- color: var(--pico-color);
58
- font-weight: 600;
59
- line-height: 1.2;
60
- margin-top: 0;
61
- }
62
- main.main-content h1 { font-size: 2rem; margin-bottom: 1.5rem; }
63
- main.main-content h2 { font-size: 1.75rem; margin-bottom: 1.25rem; }
64
- main.main-content h3 { font-size: 1.5rem; margin-bottom: 1rem; }
65
-
66
- .panel-title { margin-top: 0; margin-bottom: 1.25rem; }
67
-
68
- /* ---------- Two-pane flex container (Execution, Agents, etc.) ---------- */
69
- .two-pane-flex-container {
70
- display: flex;
71
- gap: 1.5rem;
72
- border: 1px solid var(--pico-muted-border-color);
73
- background-color: var(--pico-card-background-color);
74
- }
75
-
76
- .left-pane { flex: 1; min-width: 300px; display: flex; flex-direction: column; }
77
- .left-pane > .scrollable-content { flex-grow: 1; }
78
-
79
- .right-pane-framed { flex: 2; border-left: 1px solid var(--pico-muted-border-color); padding-left: 1.5rem; }
80
- .right-pane-framed > header { padding-bottom: 0.75rem; border-bottom: 1px solid var(--pico-muted-border-color); margin-bottom: 1rem; }
81
- .right-pane-framed > header > h5 { margin-bottom: 0; font-size: 1.1rem; }
82
-
83
- /* ---------- Item-list utility ---------- */
84
- .item-list-container { flex-grow: 1; }
85
- ul.item-list {
86
- list-style: none;
87
- padding: 0;
88
- margin: 0;
89
- }
90
-
91
- /* Guard against ::marker still appearing in some browsers */
92
- ul.item-list li::marker { content: none; }
93
-
94
- ul.item-list li { padding: 0.75rem 1rem; border-bottom: 1px solid var(--pico-muted-border-color); cursor: pointer; transition: background-color 0.15s ease-in-out, color 0.15s ease-in-out; }
95
- ul.item-list li:last-child { border-bottom: none; }
96
- ul.item-list li:hover, ul.item-list li.selected-item { background-color: var(--pico-primary-focus); color: var(--pico-primary-inverse); }
97
-
98
- /* ---------- Misc ---------- */
99
- progress { border-radius: 10px; height: 8px; }
100
- progress:indeterminate { background: rgba(var(--pico-primary-rgb, 0, 0, 0), 0.2); }
101
-
102
- /* ---------- Tool checklist (Agent form) ---------- */
103
- .tool-checklist {
104
- max-height: 150px;
105
- overflow-y: auto;
106
- border: 1px solid var(--pico-muted-border-color);
107
- padding: 0.5rem;
108
- margin-bottom: 0.75rem;
109
- border-radius: var(--pico-border-radius);
110
- background-color: var(--pico-form-element-background-color);
111
- }
112
-
113
- .tool-checklist label { display: block; margin-bottom: 0.25rem; font-weight: normal; }
114
- .tool-checklist input[type="checkbox"] { margin-right: 0.5rem; }
115
- .tool-checklist label small { color: var(--pico-muted-color); }
116
-
117
- /* ---------- Execution / Results display ---------- */
118
- #results-display {
119
- background-color: var(--pico-code-background-color);
120
- color: var(--pico-code-color);
121
- padding: 1rem;
122
- border-radius: var(--pico-border-radius);
123
- overflow-x: auto;
124
- margin-top: 1rem;
125
- min-height: 100px;
126
- border: 1px solid var(--pico-muted-border-color);
127
- }
128
-
129
- #results-display pre { margin: 0; white-space: pre-wrap; word-break: break-all; }
130
-
131
- #results-display .structured-table {
132
- border: 1px solid var(--pico-muted-border-color);
133
- font-size: 0.9em;
134
- width: 100%;
135
- margin-bottom: 0.75rem !important;
136
- border-collapse: collapse;
137
- }
138
- #results-display .structured-table td,
139
- #results-display .structured-table th {
140
- padding: 0.4em 0.6em !important;
141
- vertical-align: top;
142
- border-bottom: 1px solid var(--pico-muted-border-color);
143
- }
144
- #results-display .structured-table tr:last-child td { border-bottom: none; }
145
- #results-display .structured-table td[style*="font-weight: bold"] {
146
- color: var(--pico-secondary);
147
- min-width: 120px;
148
- max-width: 250px;
149
- word-break: break-word;
150
- border-right: 1px solid var(--pico-muted-border-color);
151
- }
152
- #results-display .structured-table ul { margin-left: 1em; padding-left: 1em; }
153
-
154
- /* ---------- Registry viewer tweaks ---------- */
155
- nav ul[role="group"] { margin-bottom: 1rem; }
156
- nav ul[role="group"] li button { width: 100%; }
157
- #registry-table-container table { margin-top: 1rem; }
158
-
159
- /* ---------- Progress elements ---------- */
160
- .sidebar progress { width: 80%; margin: 1rem auto; display: block; }
161
- progress { border-radius: 10px; height: 8px; }
162
- progress:indeterminate { background: rgba(var(--pico-primary-rgb, 0, 0, 0), 0.2); }
163
-
164
-
165
-
166
-
167
-
@@ -1,39 +0,0 @@
1
- /* ========================================================================
2
- header.css — Top header bar styles
3
- ======================================================================== */
4
-
5
- header.top-header {
6
- grid-area: header;
7
- border-bottom: 1px solid var(--pico-muted-border-color);
8
- padding: 0.7rem 1.5rem;
9
- background-color: var(--pico-card-sectioning-background-color);
10
- display: flex;
11
- justify-content: space-between;
12
- align-items: center;
13
- position: fixed;
14
- top: 0;
15
- left: 0;
16
- right: 0;
17
- z-index: 1001;
18
- box-shadow: var(--pico-card-box-shadow, 0 2px 10px rgba(0, 0, 0, 0.2));
19
- }
20
-
21
- header.top-header strong {
22
- color: var(--pico-color);
23
- font-weight: 600;
24
- font-size: 1.2rem;
25
- letter-spacing: 0.02em;
26
- }
27
-
28
- header.top-header small {
29
- color: var(--pico-muted-color);
30
- font-size: 0.85rem;
31
- }
32
-
33
- header.top-header code {
34
- background: var(--pico-code-background-color);
35
- color: var(--pico-code-color);
36
- padding: 0.2em 0.5em;
37
- border-radius: 4px;
38
- font-size: 0.85rem;
39
- }
@@ -1,46 +0,0 @@
1
- /* ========================================================================
2
- layout.css — Global layout & structure styles for Flock web UI
3
- (extracted from legacy custom.css)
4
- ======================================================================== */
5
-
6
- /* ---------- Global grid layout ---------- */
7
- body {
8
- font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
9
- display: grid;
10
- /* Sidebar column (300px) + main flexible column */
11
- grid-template-columns: 300px 1fr;
12
- /* Header (auto height) + main (flex) + footer (auto) rows */
13
- grid-template-rows: auto 1fr auto;
14
- grid-template-areas:
15
- "header header"
16
- "sidebar main"
17
- "footer footer";
18
- min-height: 100vh;
19
- margin: 0;
20
- background-color: var(--pico-background-color);
21
- }
22
-
23
- /* ---------- Main content area ---------- */
24
- main.main-content {
25
- grid-area: main;
26
- padding: 1.5rem;
27
- overflow-y: auto;
28
- /* account for fixed header height so content starts below */
29
- margin-top: 3.5rem;
30
- background-color: var(--pico-background-color);
31
- /* ensure footer does not overlap scrolling content */
32
- padding-bottom: 50px;
33
- }
34
-
35
- /* ---------- Footer ---------- */
36
- footer.main-footer {
37
- position: fixed;
38
- left: 0;
39
- bottom: 0;
40
- width: 100%;
41
- background-color: var(--pico-card-background-color);
42
- border-top: 1px solid var(--pico-muted-border-color);
43
- padding: 0.5rem 1rem;
44
- text-align: center;
45
- z-index: 1000;
46
- }
@@ -1,127 +0,0 @@
1
- /* ========================================================================
2
- sidebar.css — Left navigation sidebar styles
3
- ======================================================================== */
4
-
5
- aside.sidebar {
6
- grid-area: sidebar;
7
- background: var(--flock-sidebar-background, var(--pico-card-background-color));
8
- padding: 1.5rem 0;
9
- border-right: 1px solid var(--pico-muted-border-color);
10
- margin-top: 3.2rem; /* header height compensation */
11
- height: calc(100vh - 3.5rem - 2.1rem); /* header + footer */
12
- position: fixed;
13
- left: 0;
14
- bottom: 2.1rem; /* footer height */
15
- width: 300px;
16
- z-index: 1000;
17
- }
18
-
19
- .sidebar nav h5 {
20
- margin-bottom: 0.9rem;
21
- padding-left: 1.5rem;
22
- color: var(--pico-color);
23
- font-size: 0.85em;
24
- text-transform: uppercase;
25
- letter-spacing: 0.08em;
26
- font-weight: 600;
27
- }
28
-
29
- .sidebar nav h5:first-of-type {
30
- margin-top: 0;
31
- margin-bottom: 0.9rem;
32
- }
33
-
34
- .sidebar nav ul {
35
- padding-left: 0.5rem;
36
- padding-right: 0.5rem;
37
- list-style: none;
38
- margin-bottom: 1.5rem;
39
- }
40
-
41
- .sidebar nav li {
42
- margin-bottom: 0.2rem;
43
- }
44
-
45
- .sidebar hr {
46
- margin: 1.25rem 1.5rem;
47
- border-color: var(--pico-muted-border-color);
48
- opacity: 0.5;
49
- }
50
-
51
- /* Links & buttons */
52
- .sidebar nav a,
53
- .sidebar nav button {
54
- display: block;
55
- width: 100%;
56
- text-align: left;
57
- margin-bottom: 0;
58
- padding: 0.7rem 1rem;
59
- border: none;
60
- background-color: transparent;
61
- color: var(--pico-button-base-color);
62
- text-decoration: none;
63
- border-radius: 8px;
64
- font-size: 0.9em;
65
- cursor: pointer;
66
- transition: all 0.2s ease-in-out;
67
- font-weight: 500;
68
- white-space: nowrap;
69
- overflow: hidden;
70
- text-overflow: ellipsis;
71
- }
72
-
73
- .sidebar nav a i,
74
- .sidebar nav button i {
75
- width: 24px;
76
- margin-right: 8px;
77
- text-align: center;
78
- color: var(--pico-h2-color);
79
- transition: all 0.2s ease-in-out;
80
- flex-shrink: 0;
81
- }
82
-
83
- .sidebar nav a:hover i,
84
- .sidebar nav button:hover i,
85
- .sidebar nav a.active-nav i,
86
- .sidebar nav button.active-nav i {
87
- color: var(--pico-primary-inverse);
88
- transform: scale(1.1);
89
- }
90
-
91
- /* Button variations / states */
92
- .sidebar nav button.outline,
93
- .sidebar nav button.contrast {
94
- border: none;
95
- background-color: transparent;
96
- color: var(--pico-muted-color);
97
- box-shadow: none;
98
- }
99
-
100
- .sidebar nav button:focus {
101
- box-shadow: 0 0 0 3px var(--pico-primary-focus);
102
- }
103
-
104
- .sidebar nav a:hover,
105
- .sidebar nav button:hover {
106
- background-color: var(--pico-primary-hover-background, var(--pico-primary-focus));
107
- color: var(--pico-primary-inverse);
108
- transform: translateX(3px);
109
- }
110
-
111
- /* Active navigation */
112
- .sidebar nav a[aria-current="page"],
113
- .sidebar nav button[aria-current="page"],
114
- .sidebar nav a.active-nav,
115
- .sidebar nav button.active-nav {
116
- background-color: var(--pico-primary);
117
- color: var(--pico-primary-inverse);
118
- font-weight: 600;
119
- box-shadow: var(--pico-card-box-shadow);
120
- }
121
-
122
- /* Progress bar inside sidebar (used as loading indicator) */
123
- .sidebar progress {
124
- width: 80%;
125
- margin: 1rem auto;
126
- display: block;
127
- }
@@ -1,48 +0,0 @@
1
- /* ========================================================================
2
- two-pane.css — Styles for the two-pane layout used in execution view
3
- ======================================================================== */
4
-
5
- /* Two pane container */
6
- .two-pane-flex-container {
7
- display: flex;
8
- width: 100%;
9
- }
10
-
11
- /* Collapsed left pane */
12
- .left-pane-collapsed {
13
- width: 40px;
14
- display: flex;
15
- align-items: center;
16
- justify-content: center;
17
- background-color: var(--pico-muted-border-color);
18
- border-radius: 0 4px 4px 0;
19
- writing-mode: vertical-lr;
20
- transform: rotate(180deg);
21
- margin-right: 10px;
22
- transition: background-color 0.2s;
23
- }
24
-
25
- .left-pane-collapsed:hover {
26
- background-color: var(--pico-primary-hover);
27
- }
28
-
29
- /* Toggle links styling */
30
- .pane-toggle {
31
- text-decoration: none;
32
- color: var(--pico-primary);
33
- font-size: 0.875rem;
34
- font-weight: 500;
35
- padding: 5px 10px;
36
- border-radius: 4px;
37
- transition: all 0.2s;
38
- }
39
-
40
- .pane-toggle:hover {
41
- background-color: var(--pico-primary-hover);
42
- color: var(--pico-primary-inverse);
43
- }
44
-
45
- /* Ensure right pane takes full width when left is collapsed */
46
- #execution-right-pane {
47
- transition: flex 0.3s, padding-left 0.3s;
48
- }
@@ -1,200 +0,0 @@
1
- <!DOCTYPE html>
2
- <html lang="en" data-theme="dark">
3
-
4
- <head>
5
- <meta charset="UTF-8">
6
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
7
- <title>{% block title %}Flock UI{% endblock %}</title>
8
- <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@picocss/pico@2/css/pico.min.css" />
9
- <!-- Split modular CSS files -->
10
- <link rel="stylesheet"
11
- href="{{ url_for('static', path='css/layout.css') }}">
12
- <link rel="stylesheet"
13
- href="{{ url_for('static', path='css/header.css') }}">
14
- <link rel="stylesheet" href="{{ url_for('static', path='css/sidebar.css') }}">
15
- <link rel="stylesheet" href="{{ url_for('static', path='css/components.css') }}">
16
- <link rel="stylesheet" href="{{ url_for('static', path='css/chat.css') }}">
17
- <link rel="stylesheet" href="{{ url_for('static', path='css/two-pane.css') }}">
18
- <!-- Font Awesome for icons -->
19
- <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/css/all.min.css">
20
- <!-- Prism.js CSS for syntax highlighting (okaidia theme) -->
21
- <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism-okaidia.min.css" referrerpolicy="no-referrer" />
22
- {# Inject Theme CSS Variables #}
23
- {% if theme_css and theme_css.strip() %}
24
- <style>
25
- /* Start Theme CSS */
26
- {{ theme_css | safe }}
27
- /* End Theme CSS */
28
- </style>
29
- {% endif %}
30
- {# End Theme CSS Injection #}
31
- <script src="https://unpkg.com/htmx.org@1.9.10"
32
- integrity="sha384-D1Kt99CQMDuVetoL1lrYwg5t+9QdHe7NLX/SoJYkXDFfX37iInKRy5xLSi8nO7UC"
33
- crossorigin="anonymous"></script>
34
- <script defer src="https://cdn.jsdelivr.net/npm/alpinejs@3.x.x/dist/cdn.min.js"></script>
35
- <!-- Prism.js JS (core and autoloader) -->
36
- <script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/components/prism-core.min.js" referrerpolicy="no-referrer"></script>
37
- <script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/plugins/autoloader/prism-autoloader.min.js" referrerpolicy="no-referrer"></script>
38
- <!-- Removed inline styles as they're in custom.css -->
39
- </head>
40
-
41
- <body>
42
- <div id="global-toast-container" style="position: fixed; top: 1rem; right: 1rem; z-index: 9999; display: flex; flex-direction: column; gap: 0.5rem;">
43
- <!-- Toasts will be appended here -->
44
- </div>
45
-
46
- <header class="top-header">
47
- <span><strong>🐧 Flock Playground 🐤</strong></span> <span id="header-flock-status-container" hx-get="{{ url_for('htmx_get_header_flock_status') }}?ui_mode={{ ui_mode }}"
48
- hx-trigger="load, flockLoaded from:body, flockCleared from:body" hx-swap="innerHTML">
49
- <small>Loading status...</small> {# Placeholder while loading #}
50
- </span>
51
- </header> <aside class="sidebar" hx-get="{{ url_for('htmx_get_sidebar') }}?ui_mode={{ ui_mode }}"
52
- hx-trigger="load, flockLoaded from:body, flockListChanged from:body" hx-swap="innerHTML">
53
- <p>Loading navigation...</p><progress></progress>
54
- </aside>
55
-
56
- <main class="main-content" id="main-content-area">
57
- {# Initial content is now loaded via HTMX based on the route #}
58
- <div hx-get="{{ initial_content_url }}" hx-trigger="load" hx-swap="innerHTML">
59
- <p>Loading content...</p><progress></progress>
60
- </div>
61
- {# Render block content if navigating directly and template extends base #}
62
- {% block content %}{% endblock %}
63
- </main>
64
-
65
- <div class="message-container" x-data="messageHandler(
66
- {{ success_message | tojson | safe if success_message else 'null' }},
67
- {{ error_message | tojson | safe if error_message else 'null' }}
68
- )">
69
- <template x-if="showSuccess && successMsg">
70
- <div class="success" role="alert" @click="showSuccess = false" style="cursor: pointer;">
71
- <span x-text="successMsg"></span>
72
- <button type="button" class="close" aria-label="Dismiss">×</button>
73
- </div>
74
- </template>
75
- <template x-if="showError && errorMsg">
76
- <div class="error" role="alert" @click="showError = false" style="cursor: pointer;">
77
- <span x-text="errorMsg"></span>
78
- <button type="button" class="close" aria-label="Dismiss">×</button>
79
- </div>
80
- </template>
81
- </div>
82
-
83
- <footer class="main-footer">
84
- <small>Built with FastAPI, HTMX, Pico.CSS by 🤍 white duck 🦆 - Theme: {{ active_theme_name | default('default') }}</small>
85
- </footer>
86
-
87
- <script>
88
- function messageHandler(initialSuccessMsg, initialErrorMsg) {
89
- return {
90
- showSuccess: !!initialSuccessMsg,
91
- showError: !!initialErrorMsg,
92
- successMsg: initialSuccessMsg,
93
- errorMsg: initialErrorMsg,
94
- init() {
95
- if (this.successMsg) { setTimeout(() => this.showSuccess = false, 5000); }
96
- if (this.errorMsg) { setTimeout(() => this.showError = false, 7000); }
97
-
98
- window.addEventListener('notify', event => {
99
- if (event.detail.type === 'success') {
100
- this.successMsg = event.detail.message;
101
- this.showSuccess = true; this.showError = false;
102
- setTimeout(() => this.showSuccess = false, 5000);
103
- }
104
- if (event.detail.type === 'error') {
105
- this.errorMsg = event.detail.message;
106
- this.showError = true; this.showSuccess = false;
107
- setTimeout(() => this.showError = false, 7000);
108
- }
109
- });
110
- }
111
- };
112
- }
113
- function triggerEvent(eventName, detail = {}) {
114
- htmx.trigger(document.body, eventName, detail);
115
- }
116
-
117
- // Add HTMX event listener for Prism highlighting
118
- document.addEventListener('htmx:afterSwap', function(event) {
119
- // Check if the swapped element or its parent is the main content area or results display
120
- const mainContentArea = document.getElementById('main-content-area');
121
- const resultsDisplay = document.getElementById('results-display-content');
122
- let targetElement = event.detail.target;
123
-
124
- if (targetElement === mainContentArea || (resultsDisplay && resultsDisplay.contains(targetElement)) || (mainContentArea && mainContentArea.contains(targetElement))) {
125
- if (typeof Prism !== 'undefined') {
126
- // console.log('Prism highlighting triggered for swapped content in main area.');
127
- Prism.highlightAllUnder(mainContentArea || document.documentElement);
128
- }
129
- }
130
- });
131
-
132
- // Initial highlight on page load
133
- document.addEventListener('DOMContentLoaded', () => {
134
- if (typeof Prism !== 'undefined') {
135
- // console.log('Prism initial highlighting.');
136
- Prism.highlightAll();
137
- }
138
- });
139
- </script>
140
- {# Global Toast Handler - identical to the one in chat.html #}
141
- <script>
142
- document.body.addEventListener('showGlobalToast', function (event) {
143
- const detail = event.detail;
144
- const message = detail.message || 'Done!';
145
- const type = detail.type || 'info'; // success, error, warning, info
146
-
147
- const toastContainer = document.getElementById('global-toast-container');
148
- if (!toastContainer) return;
149
-
150
- const toast = document.createElement('article');
151
- toast.className = `toast-message ${type}`;
152
- toast.innerHTML = `<button class="close-toast" style="float: right; background: none; border: none; font-size: 1.2rem; line-height: 1; padding: 0.25rem 0.5rem; cursor: pointer;">&times;</button>${message}`;
153
-
154
- toast.style.padding = '0.75rem';
155
- toast.style.border = '1px solid';
156
- toast.style.borderRadius = 'var(--pico-border-radius, 4px)';
157
- toast.style.minWidth = '250px';
158
- toast.style.maxWidth = '400px';
159
- toast.style.opacity = '0';
160
- toast.style.transition = 'opacity 0.3s ease-in-out, transform 0.3s ease-in-out';
161
- toast.style.transform = 'translateX(100%)';
162
-
163
- if (type === 'success') {
164
- toast.style.borderColor = 'var(--pico-color-green-500, green)';
165
- toast.style.backgroundColor = 'var(--pico-color-green-150, #e6fffa)';
166
- toast.style.color = 'var(--pico-color-green-700, darkgreen)';
167
- } else if (type === 'error') {
168
- toast.style.borderColor = 'var(--pico-color-red-500, red)';
169
- toast.style.backgroundColor = 'var(--pico-color-red-150, #ffe6e6)';
170
- toast.style.color = 'var(--pico-color-red-700, darkred)';
171
- } else { // Default/info/warning
172
- toast.style.borderColor = 'var(--pico-color-blue-500, blue)';
173
- toast.style.backgroundColor = 'var(--pico-color-blue-150, #e6f7ff)';
174
- toast.style.color = 'var(--pico-color-blue-700, darkblue)';
175
- }
176
-
177
- toastContainer.appendChild(toast);
178
-
179
- setTimeout(() => {
180
- toast.style.opacity = '1';
181
- toast.style.transform = 'translateX(0)';
182
- }, 10);
183
-
184
- const closeButton = toast.querySelector('.close-toast');
185
- closeButton.onclick = () => {
186
- toast.style.opacity = '0';
187
- toast.style.transform = 'translateY(-20px)';
188
- setTimeout(() => toast.remove(), 300);
189
- };
190
-
191
- setTimeout(() => {
192
- toast.style.opacity = '0';
193
- toast.style.transform = 'translateY(-20px)';
194
- setTimeout(() => toast.remove(), 300);
195
- }, 5000);
196
- });
197
- </script>
198
- </body>
199
-
200
- </html>