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.
- flock/__init__.py +12 -217
- flock/agent.py +678 -0
- flock/api/themes.py +71 -0
- flock/artifacts.py +79 -0
- flock/cli.py +75 -0
- flock/components.py +173 -0
- flock/dashboard/__init__.py +28 -0
- flock/dashboard/collector.py +283 -0
- flock/dashboard/events.py +182 -0
- flock/dashboard/launcher.py +230 -0
- flock/dashboard/service.py +537 -0
- flock/dashboard/websocket.py +235 -0
- flock/engines/__init__.py +6 -0
- flock/engines/dspy_engine.py +856 -0
- flock/examples.py +128 -0
- flock/{core/util → helper}/cli_helper.py +4 -3
- flock/{core/logging → logging}/__init__.py +2 -3
- flock/{core/logging → logging}/formatters/enum_builder.py +3 -4
- flock/{core/logging → logging}/formatters/theme_builder.py +19 -44
- flock/{core/logging → logging}/formatters/themed_formatter.py +69 -115
- flock/{core/logging → logging}/logging.py +77 -61
- flock/{core/logging → logging}/telemetry.py +20 -26
- flock/{core/logging → logging}/telemetry_exporter/base_exporter.py +2 -2
- flock/{core/logging → logging}/telemetry_exporter/file_exporter.py +6 -9
- flock/{core/logging → logging}/telemetry_exporter/sqlite_exporter.py +2 -3
- flock/{core/logging → logging}/trace_and_logged.py +20 -24
- flock/mcp/__init__.py +91 -0
- flock/{core/mcp/mcp_client.py → mcp/client.py} +103 -154
- flock/{core/mcp/mcp_config.py → mcp/config.py} +62 -117
- flock/mcp/manager.py +255 -0
- flock/mcp/servers/sse/__init__.py +1 -1
- flock/mcp/servers/sse/flock_sse_server.py +11 -53
- flock/mcp/servers/stdio/__init__.py +1 -1
- flock/mcp/servers/stdio/flock_stdio_server.py +8 -48
- flock/mcp/servers/streamable_http/flock_streamable_http_server.py +17 -62
- flock/mcp/servers/websockets/flock_websocket_server.py +7 -40
- flock/{core/mcp/flock_mcp_tool.py → mcp/tool.py} +16 -26
- flock/mcp/types/__init__.py +42 -0
- flock/{core/mcp → mcp}/types/callbacks.py +9 -15
- flock/{core/mcp → mcp}/types/factories.py +7 -6
- flock/{core/mcp → mcp}/types/handlers.py +13 -18
- flock/{core/mcp → mcp}/types/types.py +70 -74
- flock/{core/mcp → mcp}/util/helpers.py +1 -1
- flock/orchestrator.py +645 -0
- flock/registry.py +148 -0
- flock/runtime.py +262 -0
- flock/service.py +140 -0
- flock/store.py +69 -0
- flock/subscription.py +111 -0
- flock/themes/andromeda.toml +1 -1
- flock/themes/apple-system-colors.toml +1 -1
- flock/themes/arcoiris.toml +1 -1
- flock/themes/atomonelight.toml +1 -1
- flock/themes/ayu copy.toml +1 -1
- flock/themes/ayu-light.toml +1 -1
- flock/themes/belafonte-day.toml +1 -1
- flock/themes/belafonte-night.toml +1 -1
- flock/themes/blulocodark.toml +1 -1
- flock/themes/breeze.toml +1 -1
- flock/themes/broadcast.toml +1 -1
- flock/themes/brogrammer.toml +1 -1
- flock/themes/builtin-dark.toml +1 -1
- flock/themes/builtin-pastel-dark.toml +1 -1
- flock/themes/catppuccin-latte.toml +1 -1
- flock/themes/catppuccin-macchiato.toml +1 -1
- flock/themes/catppuccin-mocha.toml +1 -1
- flock/themes/cga.toml +1 -1
- flock/themes/chalk.toml +1 -1
- flock/themes/ciapre.toml +1 -1
- flock/themes/coffee-theme.toml +1 -1
- flock/themes/cyberpunkscarletprotocol.toml +1 -1
- flock/themes/dark+.toml +1 -1
- flock/themes/darkermatrix.toml +1 -1
- flock/themes/darkside.toml +1 -1
- flock/themes/desert.toml +1 -1
- flock/themes/django.toml +1 -1
- flock/themes/djangosmooth.toml +1 -1
- flock/themes/doomone.toml +1 -1
- flock/themes/dotgov.toml +1 -1
- flock/themes/dracula+.toml +1 -1
- flock/themes/duckbones.toml +1 -1
- flock/themes/encom.toml +1 -1
- flock/themes/espresso.toml +1 -1
- flock/themes/everblush.toml +1 -1
- flock/themes/fairyfloss.toml +1 -1
- flock/themes/fideloper.toml +1 -1
- flock/themes/fishtank.toml +1 -1
- flock/themes/flexoki-light.toml +1 -1
- flock/themes/floraverse.toml +1 -1
- flock/themes/framer.toml +1 -1
- flock/themes/galizur.toml +1 -1
- flock/themes/github.toml +1 -1
- flock/themes/grass.toml +1 -1
- flock/themes/grey-green.toml +1 -1
- flock/themes/gruvboxlight.toml +1 -1
- flock/themes/guezwhoz.toml +1 -1
- flock/themes/harper.toml +1 -1
- flock/themes/hax0r-blue.toml +1 -1
- flock/themes/hopscotch.256.toml +1 -1
- flock/themes/ic-green-ppl.toml +1 -1
- flock/themes/iceberg-dark.toml +1 -1
- flock/themes/japanesque.toml +1 -1
- flock/themes/jubi.toml +1 -1
- flock/themes/kibble.toml +1 -1
- flock/themes/kolorit.toml +1 -1
- flock/themes/kurokula.toml +1 -1
- flock/themes/materialdesigncolors.toml +1 -1
- flock/themes/matrix.toml +1 -1
- flock/themes/mellifluous.toml +1 -1
- flock/themes/midnight-in-mojave.toml +1 -1
- flock/themes/monokai-remastered.toml +1 -1
- flock/themes/monokai-soda.toml +1 -1
- flock/themes/neon.toml +1 -1
- flock/themes/neopolitan.toml +1 -1
- flock/themes/nord-light.toml +1 -1
- flock/themes/ocean.toml +1 -1
- flock/themes/onehalfdark.toml +1 -1
- flock/themes/onehalflight.toml +1 -1
- flock/themes/palenighthc.toml +1 -1
- flock/themes/paulmillr.toml +1 -1
- flock/themes/pencildark.toml +1 -1
- flock/themes/pnevma.toml +1 -1
- flock/themes/purple-rain.toml +1 -1
- flock/themes/purplepeter.toml +1 -1
- flock/themes/raycast-dark.toml +1 -1
- flock/themes/red-sands.toml +1 -1
- flock/themes/relaxed.toml +1 -1
- flock/themes/retro.toml +1 -1
- flock/themes/rose-pine.toml +1 -1
- flock/themes/royal.toml +1 -1
- flock/themes/ryuuko.toml +1 -1
- flock/themes/sakura.toml +1 -1
- flock/themes/scarlet-protocol.toml +1 -1
- flock/themes/seoulbones-dark.toml +1 -1
- flock/themes/shades-of-purple.toml +1 -1
- flock/themes/smyck.toml +1 -1
- flock/themes/softserver.toml +1 -1
- flock/themes/solarized-darcula.toml +1 -1
- flock/themes/square.toml +1 -1
- flock/themes/sugarplum.toml +1 -1
- flock/themes/thayer-bright.toml +1 -1
- flock/themes/tokyonight.toml +1 -1
- flock/themes/tomorrow.toml +1 -1
- flock/themes/ubuntu.toml +1 -1
- flock/themes/ultradark.toml +1 -1
- flock/themes/ultraviolent.toml +1 -1
- flock/themes/unikitty.toml +1 -1
- flock/themes/urple.toml +1 -1
- flock/themes/vesper.toml +1 -1
- flock/themes/vimbones.toml +1 -1
- flock/themes/wildcherry.toml +1 -1
- flock/themes/wilmersdorf.toml +1 -1
- flock/themes/wryan.toml +1 -1
- flock/themes/xcodedarkhc.toml +1 -1
- flock/themes/xcodelight.toml +1 -1
- flock/themes/zenbones-light.toml +1 -1
- flock/themes/zenwritten-dark.toml +1 -1
- flock/utilities.py +301 -0
- flock/{components/utility → utility}/output_utility_component.py +68 -53
- flock/visibility.py +107 -0
- flock_core-0.5.56b0.dist-info/METADATA +747 -0
- flock_core-0.5.56b0.dist-info/RECORD +398 -0
- flock_core-0.5.56b0.dist-info/entry_points.txt +2 -0
- {flock_core-0.5.0b28.dist-info → flock_core-0.5.56b0.dist-info}/licenses/LICENSE +1 -1
- flock/adapter/__init__.py +0 -14
- flock/adapter/azure_adapter.py +0 -68
- flock/adapter/chroma_adapter.py +0 -73
- flock/adapter/faiss_adapter.py +0 -97
- flock/adapter/pinecone_adapter.py +0 -51
- flock/adapter/vector_base.py +0 -47
- flock/cli/assets/release_notes.md +0 -140
- flock/cli/config.py +0 -8
- flock/cli/constants.py +0 -36
- flock/cli/create_agent.py +0 -1
- flock/cli/create_flock.py +0 -280
- flock/cli/execute_flock.py +0 -620
- flock/cli/load_agent.py +0 -1
- flock/cli/load_examples.py +0 -1
- flock/cli/load_flock.py +0 -192
- flock/cli/load_release_notes.py +0 -20
- flock/cli/loaded_flock_cli.py +0 -254
- flock/cli/manage_agents.py +0 -459
- flock/cli/registry_management.py +0 -889
- flock/cli/runner.py +0 -41
- flock/cli/settings.py +0 -857
- flock/cli/utils.py +0 -135
- flock/cli/view_results.py +0 -29
- flock/cli/yaml_editor.py +0 -396
- flock/components/__init__.py +0 -30
- flock/components/evaluation/__init__.py +0 -9
- flock/components/evaluation/declarative_evaluation_component.py +0 -606
- flock/components/routing/__init__.py +0 -15
- flock/components/routing/conditional_routing_component.py +0 -494
- flock/components/routing/default_routing_component.py +0 -103
- flock/components/routing/llm_routing_component.py +0 -206
- flock/components/utility/__init__.py +0 -22
- flock/components/utility/example_utility_component.py +0 -250
- flock/components/utility/feedback_utility_component.py +0 -206
- flock/components/utility/memory_utility_component.py +0 -550
- flock/components/utility/metrics_utility_component.py +0 -700
- flock/config.py +0 -61
- flock/core/__init__.py +0 -110
- flock/core/agent/__init__.py +0 -16
- flock/core/agent/default_agent.py +0 -216
- flock/core/agent/flock_agent_components.py +0 -104
- flock/core/agent/flock_agent_execution.py +0 -101
- flock/core/agent/flock_agent_integration.py +0 -260
- flock/core/agent/flock_agent_lifecycle.py +0 -186
- flock/core/agent/flock_agent_serialization.py +0 -381
- flock/core/api/__init__.py +0 -10
- flock/core/api/custom_endpoint.py +0 -45
- flock/core/api/endpoints.py +0 -254
- flock/core/api/main.py +0 -162
- flock/core/api/models.py +0 -97
- flock/core/api/run_store.py +0 -224
- flock/core/api/runner.py +0 -44
- flock/core/api/service.py +0 -214
- flock/core/component/__init__.py +0 -15
- flock/core/component/agent_component_base.py +0 -309
- flock/core/component/evaluation_component.py +0 -62
- flock/core/component/routing_component.py +0 -74
- flock/core/component/utility_component.py +0 -69
- flock/core/config/flock_agent_config.py +0 -58
- flock/core/config/scheduled_agent_config.py +0 -40
- flock/core/context/context.py +0 -213
- flock/core/context/context_manager.py +0 -37
- flock/core/context/context_vars.py +0 -10
- flock/core/evaluation/utils.py +0 -396
- flock/core/execution/batch_executor.py +0 -369
- flock/core/execution/evaluation_executor.py +0 -438
- flock/core/execution/local_executor.py +0 -31
- flock/core/execution/opik_executor.py +0 -103
- flock/core/execution/temporal_executor.py +0 -164
- flock/core/flock.py +0 -634
- flock/core/flock_agent.py +0 -336
- flock/core/flock_factory.py +0 -613
- flock/core/flock_scheduler.py +0 -166
- flock/core/flock_server_manager.py +0 -136
- flock/core/interpreter/python_interpreter.py +0 -689
- flock/core/mcp/__init__.py +0 -1
- flock/core/mcp/flock_mcp_server.py +0 -680
- flock/core/mcp/mcp_client_manager.py +0 -201
- flock/core/mcp/types/__init__.py +0 -1
- flock/core/mixin/dspy_integration.py +0 -403
- flock/core/mixin/prompt_parser.py +0 -125
- flock/core/orchestration/__init__.py +0 -15
- flock/core/orchestration/flock_batch_processor.py +0 -94
- flock/core/orchestration/flock_evaluator.py +0 -113
- flock/core/orchestration/flock_execution.py +0 -295
- flock/core/orchestration/flock_initialization.py +0 -149
- flock/core/orchestration/flock_server_manager.py +0 -67
- flock/core/orchestration/flock_web_server.py +0 -117
- flock/core/registry/__init__.py +0 -45
- flock/core/registry/agent_registry.py +0 -69
- flock/core/registry/callable_registry.py +0 -139
- flock/core/registry/component_discovery.py +0 -142
- flock/core/registry/component_registry.py +0 -64
- flock/core/registry/config_mapping.py +0 -64
- flock/core/registry/decorators.py +0 -137
- flock/core/registry/registry_hub.py +0 -205
- flock/core/registry/server_registry.py +0 -57
- flock/core/registry/type_registry.py +0 -86
- flock/core/serialization/__init__.py +0 -13
- flock/core/serialization/callable_registry.py +0 -52
- flock/core/serialization/flock_serializer.py +0 -832
- flock/core/serialization/json_encoder.py +0 -41
- flock/core/serialization/secure_serializer.py +0 -175
- flock/core/serialization/serializable.py +0 -342
- flock/core/serialization/serialization_utils.py +0 -412
- flock/core/util/file_path_utils.py +0 -223
- flock/core/util/hydrator.py +0 -309
- flock/core/util/input_resolver.py +0 -164
- flock/core/util/loader.py +0 -59
- flock/core/util/splitter.py +0 -219
- flock/di.py +0 -27
- flock/platform/docker_tools.py +0 -49
- flock/platform/jaeger_install.py +0 -86
- flock/webapp/__init__.py +0 -1
- flock/webapp/app/__init__.py +0 -0
- flock/webapp/app/api/__init__.py +0 -0
- flock/webapp/app/api/agent_management.py +0 -241
- flock/webapp/app/api/execution.py +0 -709
- flock/webapp/app/api/flock_management.py +0 -129
- flock/webapp/app/api/registry_viewer.py +0 -30
- flock/webapp/app/chat.py +0 -665
- flock/webapp/app/config.py +0 -104
- flock/webapp/app/dependencies.py +0 -117
- flock/webapp/app/main.py +0 -1070
- flock/webapp/app/middleware.py +0 -113
- flock/webapp/app/models_ui.py +0 -7
- flock/webapp/app/services/__init__.py +0 -0
- flock/webapp/app/services/feedback_file_service.py +0 -363
- flock/webapp/app/services/flock_service.py +0 -337
- flock/webapp/app/services/sharing_models.py +0 -81
- flock/webapp/app/services/sharing_store.py +0 -762
- flock/webapp/app/templates/theme_mapper.html +0 -326
- flock/webapp/app/theme_mapper.py +0 -812
- flock/webapp/app/utils.py +0 -85
- flock/webapp/run.py +0 -215
- flock/webapp/static/css/chat.css +0 -301
- flock/webapp/static/css/components.css +0 -167
- flock/webapp/static/css/header.css +0 -39
- flock/webapp/static/css/layout.css +0 -46
- flock/webapp/static/css/sidebar.css +0 -127
- flock/webapp/static/css/two-pane.css +0 -48
- flock/webapp/templates/base.html +0 -200
- flock/webapp/templates/chat.html +0 -152
- flock/webapp/templates/chat_settings.html +0 -19
- flock/webapp/templates/flock_editor.html +0 -16
- flock/webapp/templates/index.html +0 -12
- flock/webapp/templates/partials/_agent_detail_form.html +0 -93
- flock/webapp/templates/partials/_agent_list.html +0 -18
- flock/webapp/templates/partials/_agent_manager_view.html +0 -51
- flock/webapp/templates/partials/_agent_tools_checklist.html +0 -14
- flock/webapp/templates/partials/_chat_container.html +0 -15
- flock/webapp/templates/partials/_chat_messages.html +0 -57
- flock/webapp/templates/partials/_chat_settings_form.html +0 -85
- flock/webapp/templates/partials/_create_flock_form.html +0 -50
- flock/webapp/templates/partials/_dashboard_flock_detail.html +0 -17
- flock/webapp/templates/partials/_dashboard_flock_file_list.html +0 -16
- flock/webapp/templates/partials/_dashboard_flock_properties_preview.html +0 -28
- flock/webapp/templates/partials/_dashboard_upload_flock_form.html +0 -16
- flock/webapp/templates/partials/_dynamic_input_form_content.html +0 -22
- flock/webapp/templates/partials/_env_vars_table.html +0 -23
- flock/webapp/templates/partials/_execution_form.html +0 -118
- flock/webapp/templates/partials/_execution_view_container.html +0 -28
- flock/webapp/templates/partials/_flock_file_list.html +0 -23
- flock/webapp/templates/partials/_flock_properties_form.html +0 -52
- flock/webapp/templates/partials/_flock_upload_form.html +0 -16
- flock/webapp/templates/partials/_header_flock_status.html +0 -5
- flock/webapp/templates/partials/_load_manager_view.html +0 -49
- flock/webapp/templates/partials/_registry_table.html +0 -25
- flock/webapp/templates/partials/_registry_viewer_content.html +0 -70
- flock/webapp/templates/partials/_results_display.html +0 -78
- flock/webapp/templates/partials/_settings_env_content.html +0 -9
- flock/webapp/templates/partials/_settings_theme_content.html +0 -14
- flock/webapp/templates/partials/_settings_view.html +0 -36
- flock/webapp/templates/partials/_share_chat_link_snippet.html +0 -11
- flock/webapp/templates/partials/_share_link_snippet.html +0 -35
- flock/webapp/templates/partials/_sidebar.html +0 -74
- flock/webapp/templates/partials/_streaming_results_container.html +0 -195
- flock/webapp/templates/partials/_structured_data_view.html +0 -40
- flock/webapp/templates/partials/_theme_preview.html +0 -36
- flock/webapp/templates/registry_viewer.html +0 -84
- flock/webapp/templates/shared_run_page.html +0 -140
- flock/workflow/__init__.py +0 -0
- flock/workflow/activities.py +0 -196
- flock/workflow/agent_activities.py +0 -24
- flock/workflow/agent_execution_activity.py +0 -202
- flock/workflow/flock_workflow.py +0 -214
- flock/workflow/temporal_config.py +0 -96
- flock/workflow/temporal_setup.py +0 -68
- flock_core-0.5.0b28.dist-info/METADATA +0 -274
- flock_core-0.5.0b28.dist-info/RECORD +0 -561
- flock_core-0.5.0b28.dist-info/entry_points.txt +0 -2
- /flock/{core/logging → logging}/formatters/themes.py +0 -0
- /flock/{core/logging → logging}/span_middleware/baggage_span_processor.py +0 -0
- /flock/{core/mcp → mcp}/util/__init__.py +0 -0
- {flock_core-0.5.0b28.dist-info → flock_core-0.5.56b0.dist-info}/WHEEL +0 -0
flock/webapp/app/utils.py
DELETED
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
import inspect
|
|
2
|
-
import json
|
|
3
|
-
from typing import Any
|
|
4
|
-
|
|
5
|
-
def is_pydantic_model(obj: Any) -> bool:
|
|
6
|
-
"""
|
|
7
|
-
Check if an object is a Pydantic model instance.
|
|
8
|
-
More robust detection for both v1 and v2 Pydantic models.
|
|
9
|
-
"""
|
|
10
|
-
# Check for Pydantic v2 model
|
|
11
|
-
if hasattr(obj, "__class__") and hasattr(obj.__class__, "model_dump"):
|
|
12
|
-
return True
|
|
13
|
-
|
|
14
|
-
# Check for Pydantic v1 model
|
|
15
|
-
if hasattr(obj, "__class__") and hasattr(obj.__class__, "schema") and hasattr(obj, "dict"):
|
|
16
|
-
return True
|
|
17
|
-
|
|
18
|
-
# Check if it has a __pydantic_core__ attribute (v2 models)
|
|
19
|
-
if hasattr(obj, "__pydantic_core__"):
|
|
20
|
-
return True
|
|
21
|
-
|
|
22
|
-
# Final check: class name check and module check
|
|
23
|
-
if hasattr(obj, "__class__"):
|
|
24
|
-
cls = obj.__class__
|
|
25
|
-
cls_name = cls.__name__
|
|
26
|
-
module_name = getattr(cls, "__module__", "")
|
|
27
|
-
if "pydantic" in module_name.lower() or "basemodel" in cls_name.lower():
|
|
28
|
-
return True
|
|
29
|
-
|
|
30
|
-
return False
|
|
31
|
-
|
|
32
|
-
def is_json_serializable(obj: Any) -> bool:
|
|
33
|
-
"""Check if an object can be serialized to JSON."""
|
|
34
|
-
try:
|
|
35
|
-
json.dumps(obj)
|
|
36
|
-
return True
|
|
37
|
-
except (TypeError, ValueError):
|
|
38
|
-
return False
|
|
39
|
-
|
|
40
|
-
def pydantic_to_dict(obj: Any) -> Any:
|
|
41
|
-
"""
|
|
42
|
-
Recursively convert Pydantic models to dictionaries.
|
|
43
|
-
Works with nested models, lists, and dictionaries containing models.
|
|
44
|
-
Falls back to string representation if object can't be serialized.
|
|
45
|
-
"""
|
|
46
|
-
if obj is None:
|
|
47
|
-
return None
|
|
48
|
-
|
|
49
|
-
if is_pydantic_model(obj):
|
|
50
|
-
# Handle Pydantic v2 models
|
|
51
|
-
if hasattr(obj, "model_dump"):
|
|
52
|
-
return obj.model_dump()
|
|
53
|
-
# Handle Pydantic v1 models
|
|
54
|
-
elif hasattr(obj, "dict"):
|
|
55
|
-
return obj.dict()
|
|
56
|
-
# Last resort - try __dict__ if it exists
|
|
57
|
-
elif hasattr(obj, "__dict__"):
|
|
58
|
-
return {k: pydantic_to_dict(v) for k, v in obj.__dict__.items()
|
|
59
|
-
if not k.startswith("_")}
|
|
60
|
-
|
|
61
|
-
elif isinstance(obj, dict):
|
|
62
|
-
# Handle dictionaries that might contain Pydantic models
|
|
63
|
-
return {k: pydantic_to_dict(v) for k, v in obj.items()}
|
|
64
|
-
|
|
65
|
-
elif isinstance(obj, list):
|
|
66
|
-
# Handle lists that might contain Pydantic models
|
|
67
|
-
return [pydantic_to_dict(item) for item in obj]
|
|
68
|
-
|
|
69
|
-
elif isinstance(obj, tuple) and hasattr(obj, '_fields'):
|
|
70
|
-
# Handle namedtuples
|
|
71
|
-
return dict(zip(obj._fields, (pydantic_to_dict(item) for item in obj)))
|
|
72
|
-
|
|
73
|
-
elif isinstance(obj, (list, tuple)):
|
|
74
|
-
# Handle regular lists and tuples
|
|
75
|
-
return [pydantic_to_dict(item) for item in obj]
|
|
76
|
-
|
|
77
|
-
# Final check - if object is not JSON serializable, convert to string
|
|
78
|
-
if not is_json_serializable(obj):
|
|
79
|
-
try:
|
|
80
|
-
return str(obj)
|
|
81
|
-
except Exception:
|
|
82
|
-
return f"<Unserializable object of type {type(obj).__name__}>"
|
|
83
|
-
|
|
84
|
-
# Return other types unchanged - these should be JSON serializable by default
|
|
85
|
-
return obj
|
flock/webapp/run.py
DELETED
|
@@ -1,215 +0,0 @@
|
|
|
1
|
-
# src/flock/webapp/run.py
|
|
2
|
-
import sys
|
|
3
|
-
from collections.abc import Callable, Sequence
|
|
4
|
-
from pathlib import Path
|
|
5
|
-
from typing import TYPE_CHECKING, Any
|
|
6
|
-
|
|
7
|
-
import uvicorn
|
|
8
|
-
|
|
9
|
-
# Import core Flock components
|
|
10
|
-
if TYPE_CHECKING:
|
|
11
|
-
from flock.core.api.custom_endpoint import FlockEndpoint
|
|
12
|
-
from flock.core.flock import Flock
|
|
13
|
-
|
|
14
|
-
# --- Ensure src is in path for imports ---
|
|
15
|
-
current_file_path = Path(__file__).resolve()
|
|
16
|
-
flock_webapp_dir = current_file_path.parent
|
|
17
|
-
flock_dir = flock_webapp_dir.parent
|
|
18
|
-
src_dir = flock_dir.parent # Assuming `flock` is a package within `src`
|
|
19
|
-
|
|
20
|
-
if str(src_dir) not in sys.path:
|
|
21
|
-
sys.path.insert(0, str(src_dir))
|
|
22
|
-
|
|
23
|
-
# --- Main Server Startup Function ---
|
|
24
|
-
def start_unified_server(
|
|
25
|
-
flock_instance: "Flock",
|
|
26
|
-
host: str,
|
|
27
|
-
port: int,
|
|
28
|
-
server_title: str,
|
|
29
|
-
enable_ui_routes: bool,
|
|
30
|
-
enable_chat_routes: bool = False,
|
|
31
|
-
ui_theme: str | None = None,
|
|
32
|
-
custom_endpoints: Sequence["FlockEndpoint"] | dict[tuple[str, list[str] | None], Callable[..., Any]] | None = None,
|
|
33
|
-
):
|
|
34
|
-
"""Starts the unified FastAPI server for Flock.
|
|
35
|
-
- Initializes the web application (imported from webapp.app.main).
|
|
36
|
-
- Sets the provided Flock instance and a RunStore for dependency injection
|
|
37
|
-
and makes them available via app.state.
|
|
38
|
-
- Configures the UI theme.
|
|
39
|
-
- Stores custom API endpoints for registration during app lifespan startup.
|
|
40
|
-
- Optionally registers chat routes.
|
|
41
|
-
- Runs Uvicorn.
|
|
42
|
-
"""
|
|
43
|
-
print(f"Attempting to start unified server for Flock '{flock_instance.name}' on http://{host}:{port}")
|
|
44
|
-
print(f"UI Routes Enabled: {enable_ui_routes}, Theme: {ui_theme or 'Default'}")
|
|
45
|
-
|
|
46
|
-
try:
|
|
47
|
-
# Import necessary webapp components HERE, after path setup.
|
|
48
|
-
from flock.core.api.run_store import RunStore
|
|
49
|
-
from flock.core.logging.logging import get_logger # For logging
|
|
50
|
-
from flock.webapp.app.config import ( # For logging resolved theme
|
|
51
|
-
get_current_theme_name,
|
|
52
|
-
set_current_theme_name,
|
|
53
|
-
)
|
|
54
|
-
from flock.webapp.app.dependencies import (
|
|
55
|
-
add_pending_custom_endpoints,
|
|
56
|
-
set_global_flock_services,
|
|
57
|
-
)
|
|
58
|
-
from flock.webapp.app.main import (
|
|
59
|
-
app as fastapi_app, # The single FastAPI app instance
|
|
60
|
-
)
|
|
61
|
-
|
|
62
|
-
logger = get_logger("webapp.run") # Use a logger
|
|
63
|
-
|
|
64
|
-
# 1. Set UI Theme globally for the webapp
|
|
65
|
-
set_current_theme_name(ui_theme)
|
|
66
|
-
logger.info(f"Unified server configured to use theme: {get_current_theme_name()}")
|
|
67
|
-
|
|
68
|
-
# 2. Create RunStore & Set Global Services for Dependency Injection
|
|
69
|
-
run_store_instance = RunStore()
|
|
70
|
-
set_global_flock_services(flock_instance, run_store_instance)
|
|
71
|
-
logger.info("Global Flock instance and RunStore set for dependency injection.")
|
|
72
|
-
|
|
73
|
-
# 3. Make Flock instance and filename available on app.state
|
|
74
|
-
fastapi_app.state.flock_instance = flock_instance
|
|
75
|
-
source_file_attr = "_source_file_path" # Attribute where Flock might store its load path
|
|
76
|
-
fastapi_app.state.flock_filename = getattr(flock_instance, source_file_attr, None) or \
|
|
77
|
-
f"{flock_instance.name.replace(' ', '_').lower()}.flock.yaml"
|
|
78
|
-
fastapi_app.state.run_store = run_store_instance
|
|
79
|
-
fastapi_app.state.chat_enabled = enable_chat_routes
|
|
80
|
-
|
|
81
|
-
logger.info(f"Flock '{flock_instance.name}' (from '{fastapi_app.state.flock_filename}') made available via app.state.")
|
|
82
|
-
|
|
83
|
-
# 4. Store Custom Endpoints for registration by the lifespan manager in app.main
|
|
84
|
-
processed_custom_endpoints = []
|
|
85
|
-
if custom_endpoints:
|
|
86
|
-
from flock.core.api.custom_endpoint import (
|
|
87
|
-
FlockEndpoint, # Ensure it's imported
|
|
88
|
-
)
|
|
89
|
-
if isinstance(custom_endpoints, dict):
|
|
90
|
-
for (path_val, methods_val), cb_val in custom_endpoints.items():
|
|
91
|
-
processed_custom_endpoints.append(
|
|
92
|
-
FlockEndpoint(path=path_val, methods=list(methods_val) if methods_val else ["GET"], callback=cb_val)
|
|
93
|
-
)
|
|
94
|
-
else: # Assumed Sequence[FlockEndpoint]
|
|
95
|
-
processed_custom_endpoints.extend(list(custom_endpoints))
|
|
96
|
-
|
|
97
|
-
if processed_custom_endpoints:
|
|
98
|
-
add_pending_custom_endpoints(processed_custom_endpoints)
|
|
99
|
-
logger.info(f"{len(processed_custom_endpoints)} custom endpoints stored for registration by app lifespan.")
|
|
100
|
-
|
|
101
|
-
# 5. Update FastAPI app title (FastAPI app instance is now imported from main)
|
|
102
|
-
fastapi_app.title = server_title
|
|
103
|
-
|
|
104
|
-
# 5a. Optionally strip UI routes if UI is disabled
|
|
105
|
-
if not enable_ui_routes:
|
|
106
|
-
from fastapi.routing import APIRoute
|
|
107
|
-
|
|
108
|
-
allowed_tags = {"Flock API Core", "Flock API Custom Endpoints", "Chat"}
|
|
109
|
-
|
|
110
|
-
def _route_is_allowed(route: APIRoute) -> bool: # type: ignore
|
|
111
|
-
# Keep documentation and non-API utility routes (no tags)
|
|
112
|
-
if not hasattr(route, "tags") or not route.tags:
|
|
113
|
-
return True
|
|
114
|
-
# Keep if any tag is in the allowed list
|
|
115
|
-
return any(tag in allowed_tags for tag in route.tags) # type: ignore
|
|
116
|
-
|
|
117
|
-
original_count = len(fastapi_app.router.routes)
|
|
118
|
-
fastapi_app.router.routes = [r for r in fastapi_app.router.routes if _route_is_allowed(r)]
|
|
119
|
-
|
|
120
|
-
# Clear cached OpenAPI schema so FastAPI regenerates it with the reduced route set
|
|
121
|
-
if hasattr(fastapi_app, "openapi_schema"):
|
|
122
|
-
fastapi_app.openapi_schema = None # type: ignore
|
|
123
|
-
|
|
124
|
-
logger.info(
|
|
125
|
-
f"UI disabled: removed {original_count - len(fastapi_app.router.routes)} UI routes. Remaining routes: {len(fastapi_app.router.routes)}"
|
|
126
|
-
)
|
|
127
|
-
|
|
128
|
-
# 5b. Include Chat routes if requested
|
|
129
|
-
if enable_chat_routes:
|
|
130
|
-
try:
|
|
131
|
-
from flock.webapp.app.chat import (
|
|
132
|
-
router as chat_router, # type: ignore
|
|
133
|
-
)
|
|
134
|
-
fastapi_app.include_router(chat_router, tags=["Chat"])
|
|
135
|
-
logger.info("Chat routes enabled and registered.")
|
|
136
|
-
except Exception as e:
|
|
137
|
-
logger.error(f"Failed to include chat routes: {e}")
|
|
138
|
-
|
|
139
|
-
# 6. Run Uvicorn
|
|
140
|
-
logger.info(f"Running Uvicorn with application: flock.webapp.app.main:app")
|
|
141
|
-
uvicorn.run(
|
|
142
|
-
"flock.webapp.app.main:app",
|
|
143
|
-
host=host,
|
|
144
|
-
port=port,
|
|
145
|
-
reload=False, # Critical for programmatically set state like flock_instance
|
|
146
|
-
# root_path=os.getenv("FLOCK_ROOT_PATH", "")
|
|
147
|
-
)
|
|
148
|
-
|
|
149
|
-
except ImportError as e:
|
|
150
|
-
# More specific error logging
|
|
151
|
-
print(f"CRITICAL: Error importing components for unified server: {e}", file=sys.stderr)
|
|
152
|
-
print(f"Module not found: {e.name}", file=sys.stderr)
|
|
153
|
-
print("This usually means a problem with sys.path or missing dependencies.", file=sys.stderr)
|
|
154
|
-
print(f"Current sys.path: {sys.path}", file=sys.stderr)
|
|
155
|
-
sys.exit(1)
|
|
156
|
-
except Exception as e:
|
|
157
|
-
print(f"CRITICAL: Error starting unified server: {e}", file=sys.stderr)
|
|
158
|
-
# Consider logging the full traceback for easier debugging
|
|
159
|
-
import traceback
|
|
160
|
-
traceback.print_exc(file=sys.stderr)
|
|
161
|
-
sys.exit(1)
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
# --- Standalone Webapp Runner (for `flock --web` or direct execution `python -m flock.webapp.run`) ---
|
|
165
|
-
def main():
|
|
166
|
-
"""Runs the Flock web application in standalone mode.
|
|
167
|
-
In this mode, no specific Flock is pre-loaded by the startup script;
|
|
168
|
-
the user will load or create one via the UI.
|
|
169
|
-
The FastAPI app (`webapp.app.main:app`) will initialize with DI services
|
|
170
|
-
set to None for Flock, and a new RunStore.
|
|
171
|
-
"""
|
|
172
|
-
print("Starting Flock web application in standalone mode...")
|
|
173
|
-
|
|
174
|
-
from flock.core.api.run_store import RunStore
|
|
175
|
-
from flock.webapp.app.config import (
|
|
176
|
-
get_current_theme_name, # To log the theme being used
|
|
177
|
-
)
|
|
178
|
-
from flock.webapp.app.dependencies import set_global_flock_services
|
|
179
|
-
|
|
180
|
-
# No pre-loaded Flock instance; create a RunStore so API calls can still function
|
|
181
|
-
standalone_run_store = RunStore()
|
|
182
|
-
set_global_flock_services(None, standalone_run_store)
|
|
183
|
-
|
|
184
|
-
print(
|
|
185
|
-
f"Standalone mode: Initialized global services. Flock: None, RunStore: {type(standalone_run_store)}"
|
|
186
|
-
)
|
|
187
|
-
print(f"Standalone webapp using theme: {get_current_theme_name()}")
|
|
188
|
-
|
|
189
|
-
host = "127.0.0.1"
|
|
190
|
-
port = 8344
|
|
191
|
-
try:
|
|
192
|
-
import os
|
|
193
|
-
|
|
194
|
-
host = os.environ.get("FLOCK_WEB_HOST", host)
|
|
195
|
-
port = int(os.environ.get("FLOCK_WEB_PORT", port))
|
|
196
|
-
webapp_reload = os.environ.get("FLOCK_WEB_RELOAD", "true").lower() == "true"
|
|
197
|
-
except Exception:
|
|
198
|
-
webapp_reload = True
|
|
199
|
-
|
|
200
|
-
app_import_string = "flock.webapp.app.main:app"
|
|
201
|
-
print(
|
|
202
|
-
f"Running Uvicorn: app='{app_import_string}', host='{host}', port={port}, reload={webapp_reload}"
|
|
203
|
-
)
|
|
204
|
-
|
|
205
|
-
uvicorn.run(
|
|
206
|
-
app_import_string,
|
|
207
|
-
host=host,
|
|
208
|
-
port=port,
|
|
209
|
-
reload=webapp_reload,
|
|
210
|
-
# root_path=os.getenv("FLOCK_ROOT_PATH", "")
|
|
211
|
-
)
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
if __name__ == "__main__":
|
|
215
|
-
main()
|
flock/webapp/static/css/chat.css
DELETED
|
@@ -1,301 +0,0 @@
|
|
|
1
|
-
/* --- Enhanced Chat Styles --- */
|
|
2
|
-
body.chat-page {
|
|
3
|
-
display: block;
|
|
4
|
-
padding: 0;
|
|
5
|
-
margin: 0;
|
|
6
|
-
height: 100vh;
|
|
7
|
-
width: 100vw;
|
|
8
|
-
overflow: hidden;
|
|
9
|
-
background-color: var(--pico-background-color);
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
#chat-container {
|
|
13
|
-
/* Allow the chat container to grow to full width on small screens,
|
|
14
|
-
but cap it at 80% of the viewport on larger displays and
|
|
15
|
-
center it horizontally. */
|
|
16
|
-
width: 100%;
|
|
17
|
-
max-width: 80%;
|
|
18
|
-
margin: 0 auto;
|
|
19
|
-
display: flex;
|
|
20
|
-
flex-direction: column;
|
|
21
|
-
height: 100vh;
|
|
22
|
-
background-color: var(--pico-background-color);
|
|
23
|
-
overflow: hidden;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
#chat-log {
|
|
27
|
-
flex: 1;
|
|
28
|
-
overflow-y: auto;
|
|
29
|
-
padding: 1rem 1.5rem;
|
|
30
|
-
display: flex;
|
|
31
|
-
flex-direction: column;
|
|
32
|
-
min-height: 0;
|
|
33
|
-
gap: 1rem;
|
|
34
|
-
background-color: rgba(0, 0, 0, 0.05);
|
|
35
|
-
background-image:
|
|
36
|
-
radial-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px),
|
|
37
|
-
radial-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px);
|
|
38
|
-
background-size: 20px 20px;
|
|
39
|
-
background-position: 0 0, 10px 10px;
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
.bubble {
|
|
45
|
-
position: relative;
|
|
46
|
-
padding: 0.75rem 1rem;
|
|
47
|
-
border-radius: 1.2rem;
|
|
48
|
-
max-width: 80%;
|
|
49
|
-
margin: 0.25rem 0;
|
|
50
|
-
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
|
|
51
|
-
animation: fadeIn 0.3s ease-out;
|
|
52
|
-
word-break: break-word;
|
|
53
|
-
line-height: 1.4;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
@keyframes fadeIn {
|
|
57
|
-
from { opacity: 0; transform: translateY(10px); }
|
|
58
|
-
to { opacity: 1; transform: translateY(0); }
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
.bubble.user {
|
|
62
|
-
background: var(--pico-primary);
|
|
63
|
-
color: var(--pico-button-base-color);
|
|
64
|
-
margin-left: auto;
|
|
65
|
-
border-bottom-right-radius: 0.3rem;
|
|
66
|
-
text-align: right;
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
.bubble.user::after {
|
|
70
|
-
content: '';
|
|
71
|
-
position: absolute;
|
|
72
|
-
bottom: 0;
|
|
73
|
-
right: -0.5rem;
|
|
74
|
-
width: 1rem;
|
|
75
|
-
height: 1rem;
|
|
76
|
-
background: var(--pico-primary-hover, var(--pico-primary));
|
|
77
|
-
clip-path: polygon(0 0, 0% 100%, 100% 100%);
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
.bubble.bot {
|
|
81
|
-
background: var(--pico-code-background-color);
|
|
82
|
-
color: var(--pico-code-color);
|
|
83
|
-
margin-right: auto;
|
|
84
|
-
border-bottom-left-radius: 0.3rem;
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
.bubble.bot::after {
|
|
88
|
-
content: '';
|
|
89
|
-
position: absolute;
|
|
90
|
-
bottom: 0;
|
|
91
|
-
left: -0.5rem;
|
|
92
|
-
width: 1rem;
|
|
93
|
-
height: 1rem;
|
|
94
|
-
background: var(--pico-code-background-color);
|
|
95
|
-
clip-path: polygon(100% 0, 0% 100%, 100% 100%);
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
#chat-container form {
|
|
99
|
-
display: flex;
|
|
100
|
-
gap: 0.5rem;
|
|
101
|
-
margin: 0;
|
|
102
|
-
padding: 1rem;
|
|
103
|
-
background-color: var(--pico-card-background-color);
|
|
104
|
-
border-top: 1px solid var(--pico-muted-border-color);
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
#chat-container form input[type="text"] {
|
|
108
|
-
flex: 1;
|
|
109
|
-
border-radius: 2rem;
|
|
110
|
-
padding-left: 1.25rem;
|
|
111
|
-
background-color: var(--pico-background-color);
|
|
112
|
-
border: 1px solid var(--pico-muted-border-color);
|
|
113
|
-
transition: all 0.2s ease;
|
|
114
|
-
height: 3rem;
|
|
115
|
-
font-size: 1rem;
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
#chat-container form input[type="text"]:focus {
|
|
119
|
-
border-color: var(--pico-primary);
|
|
120
|
-
box-shadow: 0 0 0 2px rgba(var(--pico-primary-rgb, 0, 123, 255), 0.25);
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
#chat-container form button[type="submit"] {
|
|
124
|
-
flex: 0 0 auto;
|
|
125
|
-
min-width: auto;
|
|
126
|
-
width: 150px; /* Wider send button */
|
|
127
|
-
padding: 0 1rem;
|
|
128
|
-
border-radius: 2rem;
|
|
129
|
-
background: var(--pico-primary);
|
|
130
|
-
color: var(--pico-button-base-color);
|
|
131
|
-
font-weight: 600;
|
|
132
|
-
transition: all 0.2s ease;
|
|
133
|
-
margin-left: 0.5rem;
|
|
134
|
-
height: 3rem;
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
#chat-container form button[type="submit"]:hover {
|
|
138
|
-
background: var(--pico-primary-hover, var(--pico-primary));
|
|
139
|
-
transform: translateY(-2px);
|
|
140
|
-
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
.chat-header {
|
|
144
|
-
padding: 1rem 1.5rem;
|
|
145
|
-
background-color: var(--pico-card-background-color);
|
|
146
|
-
border-bottom: 1px solid var(--pico-muted-border-color);
|
|
147
|
-
display: flex;
|
|
148
|
-
align-items: center;
|
|
149
|
-
justify-content: space-between;
|
|
150
|
-
flex-shrink: 0;
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
.chat-header h2 {
|
|
154
|
-
margin: 0;
|
|
155
|
-
font-size: 1.5rem;
|
|
156
|
-
color: var(--pico-color);
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
.chat-header h3 {
|
|
160
|
-
margin: 0;
|
|
161
|
-
font-size: 0.9rem;
|
|
162
|
-
color: var(--pico-muted-color);
|
|
163
|
-
font-weight: normal;
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
.chat-timestamp {
|
|
167
|
-
display: block;
|
|
168
|
-
font-size: 0.7rem;
|
|
169
|
-
color: var(--pico-button-base-color);
|
|
170
|
-
margin-top: 0.25rem;
|
|
171
|
-
opacity: 0.8;
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
.chat-footer {
|
|
175
|
-
padding: 0.5rem 1rem;
|
|
176
|
-
text-align: center;
|
|
177
|
-
font-size: 0.8rem;
|
|
178
|
-
color: var(--pico-muted-color);
|
|
179
|
-
background-color: var(--pico-card-background-color);
|
|
180
|
-
border-top: 1px solid var(--pico-muted-border-color);
|
|
181
|
-
flex-shrink: 0;
|
|
182
|
-
}
|
|
183
|
-
/* --- End Enhanced Chat Styles --- */
|
|
184
|
-
|
|
185
|
-
/* -------------------------------------------------------------------------
|
|
186
|
-
Chat container tweaks when embedded in the main UI (non-standalone mode)
|
|
187
|
-
------------------------------------------------------------------------- */
|
|
188
|
-
body:not(.chat-page) #chat-container,
|
|
189
|
-
body:not(.chat-page) .chat-container {
|
|
190
|
-
height: 100%;
|
|
191
|
-
min-height: 100%;
|
|
192
|
-
/* allow full width inside the main content area */
|
|
193
|
-
width: 100%;
|
|
194
|
-
max-width: 100%;
|
|
195
|
-
margin: 0 auto;
|
|
196
|
-
}
|
|
197
|
-
|
|
198
|
-
/* Settings form inside chat container should stack vertically */
|
|
199
|
-
.chat-settings-form {
|
|
200
|
-
display: flex;
|
|
201
|
-
flex-direction: column;
|
|
202
|
-
min-height: 60vh;
|
|
203
|
-
min-width: 100%;
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
.chat-settings-form label,
|
|
207
|
-
.chat-settings-form input,
|
|
208
|
-
.chat-settings-form select {
|
|
209
|
-
display: block;
|
|
210
|
-
width: 100%;
|
|
211
|
-
margin-bottom: 0.75rem;
|
|
212
|
-
}
|
|
213
|
-
|
|
214
|
-
.chat-settings-form .grid {
|
|
215
|
-
display: flex;
|
|
216
|
-
gap: 0.5rem;
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
/* Button sizing for Save Settings */
|
|
220
|
-
.chat-settings-form .grid button:first-child {
|
|
221
|
-
flex: 1 1 auto; /* expand in standalone */
|
|
222
|
-
width: 50%;
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
/* In integrated UI (non chat-page) keep natural size */
|
|
226
|
-
body:not(.chat-page) .chat-settings-form .grid button:first-child {
|
|
227
|
-
flex: 0 0 auto;
|
|
228
|
-
width: auto;
|
|
229
|
-
}
|
|
230
|
-
|
|
231
|
-
/* -------------------------------------------------------------------------
|
|
232
|
-
Container flex area to ensure chat-log grows/shrinks as needed
|
|
233
|
-
------------------------------------------------------------------------- */
|
|
234
|
-
#chat-content-area {
|
|
235
|
-
display: flex;
|
|
236
|
-
flex-direction: column;
|
|
237
|
-
flex: 1 1 auto;
|
|
238
|
-
overflow: hidden;
|
|
239
|
-
}
|
|
240
|
-
|
|
241
|
-
/* Prevent double scrollbars when chat is embedded */
|
|
242
|
-
main.main-content:has(#chat-container) {
|
|
243
|
-
overflow: hidden;
|
|
244
|
-
}
|
|
245
|
-
|
|
246
|
-
/* Ensure all direct text and common markdown elements within bot bubbles use the bot's text color */
|
|
247
|
-
.bubble.bot,
|
|
248
|
-
.bubble.bot p,
|
|
249
|
-
.bubble.bot li,
|
|
250
|
-
.bubble.bot h1,
|
|
251
|
-
.bubble.bot h2,
|
|
252
|
-
.bubble.bot h3,
|
|
253
|
-
.bubble.bot h4,
|
|
254
|
-
.bubble.bot h5,
|
|
255
|
-
.bubble.bot h6,
|
|
256
|
-
.bubble.bot strong,
|
|
257
|
-
.bubble.bot em,
|
|
258
|
-
.bubble.bot table,
|
|
259
|
-
.bubble.bot th,
|
|
260
|
-
.bubble.bot td {
|
|
261
|
-
color: var(--pico-code-color);
|
|
262
|
-
}
|
|
263
|
-
|
|
264
|
-
/* For links specifically within bot messages, you might want them to also use the bot text color */
|
|
265
|
-
.bubble.bot a {
|
|
266
|
-
color: var(--pico-code-color);
|
|
267
|
-
text-decoration: underline; /* Or your preferred link style */
|
|
268
|
-
}
|
|
269
|
-
.bubble.bot a:hover {
|
|
270
|
-
color: var(--pico-primary-hover, var(--pico-primary));
|
|
271
|
-
text-decoration: underline;
|
|
272
|
-
}
|
|
273
|
-
|
|
274
|
-
/* Styling for code blocks generated by Markdown and highlighted by Prism.js */
|
|
275
|
-
/* The prism-okaidia theme will handle the internal colors of the code. */
|
|
276
|
-
/* This is more about the container of the code block. */
|
|
277
|
-
.bubble.bot pre[class*="language-"] {
|
|
278
|
-
background-color: var(--pico-card-background-color); /* Or a slightly different dark shade */
|
|
279
|
-
border: 1px solid var(--pico-muted-border-color);
|
|
280
|
-
border-radius: var(--pico-border-radius);
|
|
281
|
-
padding: 0.75em;
|
|
282
|
-
margin: 0.5em 0;
|
|
283
|
-
font-size: 0.875em; /* Adjust as needed */
|
|
284
|
-
overflow-x: auto; /* Allow horizontal scrolling for long code lines */
|
|
285
|
-
/* The text color *inside* the code block will be handled by the Prism theme (e.g., Okaidia) */
|
|
286
|
-
}
|
|
287
|
-
|
|
288
|
-
/* Ensure the code itself inside the pre block also resets its base color if needed,
|
|
289
|
-
though Prism themes usually take care of this. This is a fallback. */
|
|
290
|
-
.bubble.bot pre[class*="language-"] code {
|
|
291
|
-
/* color: inherit; */ /* This might not be necessary if Prism theme is comprehensive - try without first */
|
|
292
|
-
background: none;
|
|
293
|
-
padding: 0;
|
|
294
|
-
}
|
|
295
|
-
|
|
296
|
-
/* Styles for preformatted text wrapping */
|
|
297
|
-
.bubble pre {
|
|
298
|
-
white-space: pre-wrap; /* Allows wrapping and preserves sequences of white space and newlines */
|
|
299
|
-
word-wrap: break-word; /* Breaks long words/strings if they would overflow */
|
|
300
|
-
overflow-x: auto; /* Adds a scrollbar if content is still too wide */
|
|
301
|
-
}
|