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/templates/chat.html
DELETED
|
@@ -1,152 +0,0 @@
|
|
|
1
|
-
<!DOCTYPE html>
|
|
2
|
-
<html lang="en" data-theme="dark">
|
|
3
|
-
<head>
|
|
4
|
-
<meta charset="UTF-8">
|
|
5
|
-
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
6
|
-
<title>Flock Chat</title>
|
|
7
|
-
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@picocss/pico@2/css/pico.min.css" />
|
|
8
|
-
<link rel="stylesheet" href="{{ url_for('static', path='css/chat.css') }}">
|
|
9
|
-
{# Prism.js CSS for syntax highlighting (okaidia theme) #}
|
|
10
|
-
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism-okaidia.min.css" referrerpolicy="no-referrer" />
|
|
11
|
-
{# Inject active theme variables #}
|
|
12
|
-
{% if theme_css and theme_css.strip() %}
|
|
13
|
-
<style>
|
|
14
|
-
/* Start Theme CSS */
|
|
15
|
-
/* stylelint-disable */
|
|
16
|
-
{{ theme_css | safe }}
|
|
17
|
-
/* stylelint-enable */
|
|
18
|
-
/* End Theme CSS */
|
|
19
|
-
</style>
|
|
20
|
-
{% endif %}
|
|
21
|
-
<script src="https://unpkg.com/htmx.org@1.9.10" integrity="sha384-D1Kt99CQMDuVetoL1lrYwg5t+9QdHe7NLX/SoJYkXDFfX37iInKRy5xLSi8nO7UC" crossorigin="anonymous"></script>
|
|
22
|
-
<script defer src="https://cdn.jsdelivr.net/npm/alpinejs@3.x.x/dist/cdn.min.js"></script>
|
|
23
|
-
{# Prism.js JS (core and components for common languages) #}
|
|
24
|
-
<script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/components/prism-core.min.js" referrerpolicy="no-referrer"></script>
|
|
25
|
-
<script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/plugins/autoloader/prism-autoloader.min.js" referrerpolicy="no-referrer"></script>
|
|
26
|
-
</head>
|
|
27
|
-
<body class="chat-page">
|
|
28
|
-
<div id="global-toast-container" style="position: fixed; top: 1rem; right: 1rem; z-index: 9999; display: flex; flex-direction: column; gap: 0.5rem;">
|
|
29
|
-
<!-- Toasts will be appended here -->
|
|
30
|
-
</div>
|
|
31
|
-
|
|
32
|
-
<div id="chat-container">
|
|
33
|
-
<div class="chat-header" style="justify-content: space-between;">
|
|
34
|
-
<hgroup>
|
|
35
|
-
<h2>Flock Chat</h2>
|
|
36
|
-
<h3>{{ chat_subtitle }}</h3>
|
|
37
|
-
</hgroup> {% if not is_shared_chat %}
|
|
38
|
-
<button class="secondary outline" hx-get="{{ url_for('chat_settings_standalone') }}" hx-target="#chat-content-area" hx-swap="innerHTML" style="min-width:auto;">Settings</button>
|
|
39
|
-
{% else %}
|
|
40
|
-
{# Optionally, could show a disabled settings button or some other indicator #}
|
|
41
|
-
<span style="font-size: 0.8rem; color: var(--pico-muted-color);">Settings frozen for shared session.</span>
|
|
42
|
-
{% endif %}
|
|
43
|
-
</div>
|
|
44
|
-
|
|
45
|
-
<div id="chat-content-area"> <div id="chat-log"
|
|
46
|
-
hx-get="{% if is_shared_chat %}{{ url_for('chat_history_shared_partial', share_id=share_id) }}{% else %}{{ url_for('chat_history_partial') }}{% endif %}"
|
|
47
|
-
hx-trigger="load" {# Polling removed #}
|
|
48
|
-
hx-swap="innerHTML">
|
|
49
|
-
<p><em>Loading chat…</em></p>
|
|
50
|
-
</div>
|
|
51
|
-
<form id="chat-form-standalone"
|
|
52
|
-
hx-post="{% if is_shared_chat %}{{ url_for('chat_send_shared') }}{% else %}{{ url_for('chat_send') }}{% endif %}"
|
|
53
|
-
hx-target="#chat-log"
|
|
54
|
-
hx-swap="innerHTML"
|
|
55
|
-
hx-disabled-elt="input[name='message'], button[type='submit']"
|
|
56
|
-
hx-on::before-request="htmx.find('#chat-form-standalone button[type=\'submit\']').textContent = 'Sending...'"
|
|
57
|
-
hx-on::after-request="htmx.find('#chat-form-standalone button[type=\'submit\']').textContent = 'Send'; this.reset();">
|
|
58
|
-
|
|
59
|
-
{% if is_shared_chat %}
|
|
60
|
-
<input type="hidden" name="share_id" value="{{ share_id }}">
|
|
61
|
-
{% endif %}
|
|
62
|
-
<input type="text" name="message" placeholder="Type a message…" required autofocus>
|
|
63
|
-
<button type="submit">Send</button>
|
|
64
|
-
</form>
|
|
65
|
-
</div>
|
|
66
|
-
|
|
67
|
-
<div class="chat-footer">
|
|
68
|
-
<small>Built with FastAPI • HTMX • Pico.css – Theme: {{ active_theme_name | default('default') }}</small>
|
|
69
|
-
</div>
|
|
70
|
-
</div>
|
|
71
|
-
|
|
72
|
-
<script>
|
|
73
|
-
(function() {
|
|
74
|
-
const log = document.getElementById('chat-log');
|
|
75
|
-
function scrollBottom() {
|
|
76
|
-
log.scrollTop = log.scrollHeight;
|
|
77
|
-
}
|
|
78
|
-
document.addEventListener('htmx:afterSwap', e => {
|
|
79
|
-
if (e.detail.target.id === 'chat-log') {
|
|
80
|
-
scrollBottom();
|
|
81
|
-
// Re-run Prism highlighting after new content is swapped in
|
|
82
|
-
Prism.highlightAllUnder(log);
|
|
83
|
-
}
|
|
84
|
-
});
|
|
85
|
-
window.addEventListener('load', scrollBottom);
|
|
86
|
-
// Initial highlight on page load for any pre-existing content
|
|
87
|
-
document.addEventListener('DOMContentLoaded', () => {
|
|
88
|
-
Prism.highlightAll();
|
|
89
|
-
});
|
|
90
|
-
})();
|
|
91
|
-
|
|
92
|
-
// Global Toast Handler
|
|
93
|
-
document.body.addEventListener('showGlobalToast', function (event) {
|
|
94
|
-
const detail = event.detail;
|
|
95
|
-
const message = detail.message || 'Done!';
|
|
96
|
-
const type = detail.type || 'info'; // success, error, warning, info
|
|
97
|
-
|
|
98
|
-
const toastContainer = document.getElementById('global-toast-container');
|
|
99
|
-
if (!toastContainer) return;
|
|
100
|
-
|
|
101
|
-
const toast = document.createElement('article');
|
|
102
|
-
toast.className = `toast-message ${type}`;
|
|
103
|
-
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;">×</button>${message}`;
|
|
104
|
-
|
|
105
|
-
// Basic styling, can be enhanced in CSS file
|
|
106
|
-
toast.style.padding = '0.75rem';
|
|
107
|
-
toast.style.border = '1px solid';
|
|
108
|
-
toast.style.borderRadius = 'var(--pico-border-radius, 4px)';
|
|
109
|
-
toast.style.minWidth = '250px';
|
|
110
|
-
toast.style.maxWidth = '400px';
|
|
111
|
-
toast.style.opacity = '0'; // Start faded out
|
|
112
|
-
toast.style.transition = 'opacity 0.3s ease-in-out, transform 0.3s ease-in-out';
|
|
113
|
-
toast.style.transform = 'translateX(100%)'; // Start off-screen
|
|
114
|
-
|
|
115
|
-
if (type === 'success') {
|
|
116
|
-
toast.style.borderColor = 'var(--pico-color-green-500, green)';
|
|
117
|
-
toast.style.backgroundColor = 'var(--pico-color-green-150, #e6fffa)';
|
|
118
|
-
toast.style.color = 'var(--pico-color-green-700, darkgreen)';
|
|
119
|
-
} else if (type === 'error') {
|
|
120
|
-
toast.style.borderColor = 'var(--pico-color-red-500, red)';
|
|
121
|
-
toast.style.backgroundColor = 'var(--pico-color-red-150, #ffe6e6)';
|
|
122
|
-
toast.style.color = 'var(--pico-color-red-700, darkred)';
|
|
123
|
-
} else { // Default/info/warning
|
|
124
|
-
toast.style.borderColor = 'var(--pico-color-blue-500, blue)';
|
|
125
|
-
toast.style.backgroundColor = 'var(--pico-color-blue-150, #e6f7ff)';
|
|
126
|
-
toast.style.color = 'var(--pico-color-blue-700, darkblue)';
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
toastContainer.appendChild(toast);
|
|
130
|
-
|
|
131
|
-
// Animate in
|
|
132
|
-
setTimeout(() => {
|
|
133
|
-
toast.style.opacity = '1';
|
|
134
|
-
toast.style.transform = 'translateX(0)';
|
|
135
|
-
}, 10); // Small delay to allow CSS to apply initial state
|
|
136
|
-
|
|
137
|
-
const closeButton = toast.querySelector('.close-toast');
|
|
138
|
-
closeButton.onclick = () => {
|
|
139
|
-
toast.style.opacity = '0';
|
|
140
|
-
toast.style.transform = 'translateY(-20px)';
|
|
141
|
-
setTimeout(() => toast.remove(), 300);
|
|
142
|
-
};
|
|
143
|
-
|
|
144
|
-
setTimeout(() => {
|
|
145
|
-
toast.style.opacity = '0';
|
|
146
|
-
toast.style.transform = 'translateY(-20px)';
|
|
147
|
-
setTimeout(() => toast.remove(), 300);
|
|
148
|
-
}, 5000); // Auto-dismiss after 5 seconds
|
|
149
|
-
});
|
|
150
|
-
</script>
|
|
151
|
-
</body>
|
|
152
|
-
</html>
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
<!DOCTYPE html>
|
|
2
|
-
<html lang="en" data-theme="dark">
|
|
3
|
-
<head>
|
|
4
|
-
<meta charset="UTF-8">
|
|
5
|
-
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
6
|
-
<title>Chat Settings</title>
|
|
7
|
-
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@picocss/pico@2/css/pico.min.css" /> <link rel="stylesheet" href="{{ url_for('static', path='css/chat.css') }}">
|
|
8
|
-
<link rel="stylesheet" href="{{ url_for('static', path='css/header.css') }}">
|
|
9
|
-
{# Active theme CSS #}
|
|
10
|
-
{% if theme_css %}<style>{{ theme_css | safe }}</style>{% endif %}
|
|
11
|
-
<script src="https://unpkg.com/htmx.org@1.9.10" crossorigin="anonymous"></script>
|
|
12
|
-
</head>
|
|
13
|
-
<body class="chat-page">
|
|
14
|
-
<main style="max-width: 700px; margin: 2rem auto;">
|
|
15
|
-
{% include 'partials/_chat_settings_form.html' %}
|
|
16
|
-
<p style="text-align:center; margin-top: 1rem;"><a href="{{ url_for('chat_page') }}">← Back to Chat</a></p>
|
|
17
|
-
</main>
|
|
18
|
-
</body>
|
|
19
|
-
</html>
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
{% extends "base.html" %}
|
|
2
|
-
|
|
3
|
-
{% block title %}Flock Editor - {{ flock.name if flock else 'Loading...' }}{% endblock %}
|
|
4
|
-
|
|
5
|
-
{% block content %}
|
|
6
|
-
{# Main content area is now loaded dynamically based on sidebar clicks #}
|
|
7
|
-
{# We can load the properties form by default when this page is hit #}
|
|
8
|
-
<div id="editor-main-content" hx-get="{{ url_for('htmx_get_flock_properties_form') }}"
|
|
9
|
-
hx-trigger="load"
|
|
10
|
-
hx-swap="innerHTML">
|
|
11
|
-
<article>
|
|
12
|
-
<p>Loading editor content...</p>
|
|
13
|
-
<progress></progress>
|
|
14
|
-
</article>
|
|
15
|
-
</div>
|
|
16
|
-
{% endblock %}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
{% extends "base.html" %}
|
|
2
|
-
|
|
3
|
-
{% block title %}Flock UI - Dashboard{% endblock %}
|
|
4
|
-
|
|
5
|
-
{% block content %}
|
|
6
|
-
{# This content will be loaded dynamically via HTMX from the sidebar #}
|
|
7
|
-
{# We can load the 'load/manage' view by default #}
|
|
8
|
-
<div id="dashboard-content" hx-get="{{ url_for('htmx_get_load_flock_view') }}" hx-trigger="load" hx-swap="innerHTML">
|
|
9
|
-
<p>Loading dashboard content...</p>
|
|
10
|
-
<progress></progress>
|
|
11
|
-
</div>
|
|
12
|
-
{% endblock %}
|
|
@@ -1,93 +0,0 @@
|
|
|
1
|
-
<header>
|
|
2
|
-
<h5>{% if is_new %}Add New Agent{% else %}Edit Agent: {{ agent.name if agent else '' }}{% endif %}</h5>
|
|
3
|
-
</header>
|
|
4
|
-
<article id="agent-detail-form-content">
|
|
5
|
-
|
|
6
|
-
{% if form_message %}
|
|
7
|
-
<div class="form-message {{ 'success' if success else 'error' }}"
|
|
8
|
-
x-data="{ show: true }" x-show="show" x-init="setTimeout(() => show = false, 3000)"
|
|
9
|
-
x-transition:leave="transition ease-in duration-300"
|
|
10
|
-
x-transition:leave-start="opacity-100"
|
|
11
|
-
x-transition:leave-end="opacity-0">
|
|
12
|
-
{{ form_message }}
|
|
13
|
-
</div>
|
|
14
|
-
{% endif %} <form {% if is_new %} hx-post="{{ url_for('htmx_create_agent') }}"
|
|
15
|
-
{% else %}
|
|
16
|
-
hx-put="{{ url_for('htmx_update_agent', original_agent_name=agent.name if agent else '') }}"
|
|
17
|
-
{% endif %}
|
|
18
|
-
hx-target="#agent-detail-form-content"
|
|
19
|
-
hx-swap="innerHTML"
|
|
20
|
-
hx-indicator="#agent-detail-loading-indicator">
|
|
21
|
-
|
|
22
|
-
<fieldset>
|
|
23
|
-
<legend>Core Agent Configuration</legend>
|
|
24
|
-
<label for="agent_name_field">Agent Name *</label>
|
|
25
|
-
<input type="text" id="agent_name_field" name="agent_name" value="{{ agent.name if agent and not form_errors else (form_data.agent_name if form_data else '') }}" required placeholder="Unique name for the agent">
|
|
26
|
-
{% if form_errors and form_errors.agent_name %}<small class="field-error">{{ form_errors.agent_name }}</small>{% endif %}
|
|
27
|
-
|
|
28
|
-
<label for="agent_description_field">Description</label>
|
|
29
|
-
<textarea id="agent_description_field" name="agent_description" placeholder="Briefly describe what this agent does.">{{ agent.resolved_description if agent and not form_errors else (form_data.agent_description if form_data else '') }}</textarea>
|
|
30
|
-
|
|
31
|
-
<label for="agent_model_field">Model Override (Optional)</label>
|
|
32
|
-
<input type="text" id="agent_model_field" name="agent_model" value="{{ agent.model if agent and agent.model and not form_errors else (form_data.agent_model if form_data else '') }}" placeholder="e.g., openai/gpt-3.5-turbo (uses Flock default if blank)">
|
|
33
|
-
|
|
34
|
-
<label for="input_signature_field">Input Signature *</label>
|
|
35
|
-
<input type="text" id="input_signature_field" name="input_signature" value="{{ agent.input if agent and not form_errors else (form_data.input_signature if form_data else '') }}" required placeholder="e.g., query: str | The user's question, context: list[str]">
|
|
36
|
-
<small>Format: `name1: type1 | desc1, name2: type2 | desc2`</small>
|
|
37
|
-
{% if form_errors and form_errors.input_signature %}<small class="field-error">{{ form_errors.input_signature }}</small>{% endif %}
|
|
38
|
-
|
|
39
|
-
<label for="output_signature_field">Output Signature *</label>
|
|
40
|
-
<input type="text" id="output_signature_field" name="output_signature" value="{{ agent.output if agent and not form_errors else (form_data.output_signature if form_data else '') }}" required placeholder="e.g., answer: str | The final answer, sources: list[str]">
|
|
41
|
-
<small>Format: `name1: type1 | desc1, name2: type2 | desc2`</small>
|
|
42
|
-
{% if form_errors and form_errors.output_signature %}<small class="field-error">{{ form_errors.output_signature }}</small>{% endif %}
|
|
43
|
-
</fieldset>
|
|
44
|
-
|
|
45
|
-
<fieldset>
|
|
46
|
-
<legend>Tools (Optional)</legend>
|
|
47
|
-
<div class="tool-checklist">
|
|
48
|
-
{% if registered_tools %}
|
|
49
|
-
{% for tool in registered_tools %}
|
|
50
|
-
<label for="tool_{{ tool.name }}">
|
|
51
|
-
<input type="checkbox" id="tool_{{ tool.name }}" name="tools" value="{{ tool.name }}"
|
|
52
|
-
{% if tool.name in (current_tools if not form_errors else (form_data.getlist('tools') if form_data else [])) %}checked{% endif %}>
|
|
53
|
-
{{ tool.name }} <small>({{ tool.module }})</small>
|
|
54
|
-
</label>
|
|
55
|
-
{% endfor %}
|
|
56
|
-
{% else %}
|
|
57
|
-
<p>No tools registered. Add tools via the Registry page or ensure they are discovered by Flock.</p>
|
|
58
|
-
{% endif %}
|
|
59
|
-
</div>
|
|
60
|
-
</fieldset>
|
|
61
|
-
|
|
62
|
-
<fieldset>
|
|
63
|
-
<legend>Routing (Default Handoff)</legend>
|
|
64
|
-
<label for="default_router_handoff_field">Next Agent Name (Optional)</label>
|
|
65
|
-
<input type="text" id="default_router_handoff_field" name="default_router_handoff"
|
|
66
|
-
value="{{ agent.handoff_router.config.hand_off if agent and agent.handoff_router and agent.handoff_router.config and agent.handoff_router.config.hand_off is string and not form_errors else (form_data.default_router_handoff if form_data else '') }}"
|
|
67
|
-
placeholder="Enter name of next agent">
|
|
68
|
-
<small>If set, this agent will hand off to the specified agent by default.</small>
|
|
69
|
-
</fieldset>
|
|
70
|
-
|
|
71
|
-
<div class="grid">
|
|
72
|
-
<button type="submit">
|
|
73
|
-
{% if is_new %}Create Agent{% else %}Save Changes{% endif %}
|
|
74
|
-
</button>
|
|
75
|
-
{% if not is_new and agent %} <button type="button" role="button" class="secondary outline" hx-delete="{{ url_for('htmx_delete_agent', agent_name=agent.name) }}"
|
|
76
|
-
hx-target="#agent-detail-form-content"
|
|
77
|
-
hx-confirm="Are you sure you want to delete agent '{{ agent.name }}'?"
|
|
78
|
-
hx-indicator="#agent-detail-loading-indicator">
|
|
79
|
-
Delete Agent
|
|
80
|
-
</button>
|
|
81
|
-
{% endif %}
|
|
82
|
-
<button type="button" class="outline" hx-get="{{ url_for('htmx_get_new_agent_form') }}"
|
|
83
|
-
hx-target="#agent-detail-panel"
|
|
84
|
-
hx-swap="innerHTML"
|
|
85
|
-
hx-indicator="#agent-detail-loading-indicator">
|
|
86
|
-
Cancel / New Form
|
|
87
|
-
</button>
|
|
88
|
-
</div>
|
|
89
|
-
<div id="agent-detail-loading-indicator" class="htmx-indicator" style="margin-top: 0.5rem;">
|
|
90
|
-
<progress indeterminate></progress> Processing...
|
|
91
|
-
</div>
|
|
92
|
-
</form>
|
|
93
|
-
</article>
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
<article id="agent-list-content">
|
|
2
|
-
|
|
3
|
-
{% if message %}
|
|
4
|
-
<div class="form-message {{ 'success' if success else 'error' }}">{{ message }}</div>
|
|
5
|
-
{% endif %}
|
|
6
|
-
{% if flock.agents %}
|
|
7
|
-
<ul class="item-list">
|
|
8
|
-
{% for agent_name, agent in flock.agents.items() %} <li hx-get="{{ url_for('htmx_get_agent_details_form', agent_name=agent.name) }}" hx-target="#agent-detail-panel" hx-swap="innerHTML" hx-indicator="#agent-detail-loading-indicator" onclick="this.closest('ul').querySelectorAll('li').forEach(li => li.classList.remove('selected-item')); this.classList.add('selected-item');">
|
|
9
|
-
<strong>{{ agent.name }}</strong><br>
|
|
10
|
-
<small>{{ agent.resolved_description|truncate(80) if agent.resolved_description else 'No description' }}</small>
|
|
11
|
-
</li>
|
|
12
|
-
{% endfor %}
|
|
13
|
-
</ul>
|
|
14
|
-
{% else %}
|
|
15
|
-
<p>No agents defined in this Flock yet. Click "Add New Agent" to create one.</p>
|
|
16
|
-
{% endif %}
|
|
17
|
-
<div id="agent-list-loading" class="htmx-indicator">Loading agents... <progress></progress></div>
|
|
18
|
-
</article>
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
<!-- <article id="dashboard-flock-manager-content"> -->
|
|
2
|
-
<!-- {# This outer header is removed, title moves into the left-pane's new article structure #}
|
|
3
|
-
{# <header>
|
|
4
|
-
<h2>Manage & Load Flocks</h2> #}
|
|
5
|
-
</header> -->
|
|
6
|
-
|
|
7
|
-
{% if error_message %}
|
|
8
|
-
<div class="error DANGER" role="alert" x-data="{ show: true }" x-show="show" x-init="setTimeout(() => show = false, 5000)">
|
|
9
|
-
{{ error_message }} <button type="button" class="close" @click="show = false">×</button>
|
|
10
|
-
</div>
|
|
11
|
-
{% endif %}
|
|
12
|
-
{% if success_message %}
|
|
13
|
-
<div class="success SUCCESS" role="alert" x-data="{ show: true }" x-show="show" x-init="setTimeout(() => show = false, 5000)">
|
|
14
|
-
{{ success_message }} <button type="button" class="close" @click="show = false">×</button>
|
|
15
|
-
</div>
|
|
16
|
-
{% endif %}
|
|
17
|
-
|
|
18
|
-
<article class="two-pane-flex-container">
|
|
19
|
-
<article class="left-pane"> {# Changed section to article, or wrap section in article #}
|
|
20
|
-
<header class="grid">
|
|
21
|
-
<h2>Agents ({{ flock.agents|length }}) </h2>
|
|
22
|
-
<div style="text-align: right;">
|
|
23
|
-
<button role="button" class="outline" hx-get="{{ url_for('htmx_get_new_agent_form') }}" hx-target="#agent-detail-panel" hx-swap="innerHTML">Add New Agent</button>
|
|
24
|
-
</div>
|
|
25
|
-
|
|
26
|
-
</header>
|
|
27
|
-
|
|
28
|
-
{# Content of the left pane now goes into this article #}
|
|
29
|
-
<div style="padding: var(--pico-block-spacing-vertical) var(--pico-block-spacing-horizontal); flex-grow: 1; display: flex; flex-direction: column;"> <div hx-get="{{ url_for('htmx_get_agent_list') }}"
|
|
30
|
-
hx-trigger="load, agentListChanged from:body"
|
|
31
|
-
hx-swap="innerHTML"
|
|
32
|
-
id="agent-list-panel"
|
|
33
|
-
class="item-list-container" style="flex-grow: 1; overflow-y: auto;border: 1px solid var(--pico-border-color); border-radius: var(--pico-border-radius);">
|
|
34
|
-
<p style="padding:1rem;">Loading Agents...</p><progress indeterminate></progress>
|
|
35
|
-
</div>
|
|
36
|
-
</div>
|
|
37
|
-
</article>
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
<section id="agent-detail-panel" class="right-pane-framed"> {# Added right-pane-framed #}
|
|
42
|
-
<header>
|
|
43
|
-
<h5>Agent Details</h5> {# Changed to h5 for consistency #}
|
|
44
|
-
</header>
|
|
45
|
-
|
|
46
|
-
<p>Select an agent from the list to view/edit, or create a new one using the button above.</p>
|
|
47
|
-
</section>
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
</article>
|
|
51
|
-
<!-- </article> -->
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
<!-- This partial might be used if tool selection becomes more complex -->
|
|
2
|
-
<!-- For MVP, it's integrated into _agent_detail_form.html -->
|
|
3
|
-
<fieldset>
|
|
4
|
-
<legend>Select Tools</legend>
|
|
5
|
-
{% for tool in registered_tools %}
|
|
6
|
-
<label for="tool_{{ tool.name }}_{{ context_id }}"> <!-- context_id for uniqueness if form is loaded multiple times -->
|
|
7
|
-
<input type="checkbox" id="tool_{{ tool.name }}_{{ context_id }}" name="tools" value="{{ tool.name }}"
|
|
8
|
-
{% if tool.name in current_tools %}checked{% endif %}>
|
|
9
|
-
{{ tool.name }} <small>({{ tool.module }})</small>
|
|
10
|
-
</label>
|
|
11
|
-
{% else %}
|
|
12
|
-
<p>No tools available in registry.</p>
|
|
13
|
-
{% endfor %}
|
|
14
|
-
</fieldset>
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
<article id="chat-container" class="chat-container">
|
|
2
|
-
<div id="chat-log" hx-get="{{ url_for('chat_history_partial') }}" hx-trigger="load" hx-swap="innerHTML">
|
|
3
|
-
<p><em>Loading chat…</em></p>
|
|
4
|
-
</div>
|
|
5
|
-
<form id="chat-form-embedded" class="chat-form"
|
|
6
|
-
hx-post="{{ url_for('chat_send') }}"
|
|
7
|
-
hx-target="#chat-log"
|
|
8
|
-
hx-swap="innerHTML"
|
|
9
|
-
hx-disabled-elt="input[name='message'], button[type='submit']"
|
|
10
|
-
hx-on::before-request="htmx.find('#chat-form-embedded button[type=\'submit\']').textContent = 'Sending...'"
|
|
11
|
-
hx-on::after-request="htmx.find('#chat-form-embedded button[type=\'submit\']').textContent = 'Send'; this.reset();">
|
|
12
|
-
<input type="text" name="message" placeholder="Type a message…" required>
|
|
13
|
-
<button type="submit">Send</button>
|
|
14
|
-
</form>
|
|
15
|
-
</article>
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
{% for entry in history %}
|
|
2
|
-
{% if entry.role == 'user' %}
|
|
3
|
-
<div class="bubble user">
|
|
4
|
-
{{ entry.text }}
|
|
5
|
-
<span class="chat-timestamp">{{ entry.timestamp|default(now().strftime('%H:%M')) }}</span>
|
|
6
|
-
</div>
|
|
7
|
-
{% else %}
|
|
8
|
-
<div class="bubble bot" x-data="{showForm:false}">
|
|
9
|
-
<!-- Bubble content (visible when feedback form hidden) -->
|
|
10
|
-
<div x-show="!showForm">
|
|
11
|
-
<div>
|
|
12
|
-
{{ entry.text | safe }}
|
|
13
|
-
<span class="chat-timestamp">
|
|
14
|
-
{{ entry.timestamp|default(now().strftime('%H:%M')) }}{% if entry.agent %} - {{ entry.agent }}{% endif %}{% if entry.duration_ms is defined %} - {{ entry.duration_ms }}ms - {% endif %}
|
|
15
|
-
<!-- hidden meta form (used by thumbs links) -->
|
|
16
|
-
<form class="feedback-meta" style="display:none">
|
|
17
|
-
{% if share_id %}<input type="hidden" name="share_id" value="{{ share_id }}">{% endif %}
|
|
18
|
-
<input type="hidden" name="flock_definition" value="{{ entry.flock_yaml | replace('"', '"') }}">
|
|
19
|
-
<input type="hidden" name="agent_name" value="{{ entry.agent }}">
|
|
20
|
-
<input type="hidden" name="actual_response" value='{{ entry.raw_json | replace("'", "'") }}'>
|
|
21
|
-
<input type="hidden" name="reason" value="positive">
|
|
22
|
-
</form> <a href="#"
|
|
23
|
-
hx-post="{% if share_id %}{{ url_for('chat_feedback_shared') }}{% else %}{{ url_for('chat_feedback') }}{% endif %}"
|
|
24
|
-
hx-include="closest .feedback-meta"
|
|
25
|
-
hx-target="closest .bubble"
|
|
26
|
-
hx-swap="innerHTML"
|
|
27
|
-
title="Looks good!" class="feedback-link">👍</a>
|
|
28
|
-
-
|
|
29
|
-
<a href="#" @click.prevent="showForm=true" title="Submit detailed feedback" class="feedback-link">👎</a>
|
|
30
|
-
</span>
|
|
31
|
-
</div>
|
|
32
|
-
</div>
|
|
33
|
-
|
|
34
|
-
<!-- Feedback form (initially hidden, toggled by 👎 link) -->
|
|
35
|
-
<div x-show="showForm" style="width: 800px;"> <form
|
|
36
|
-
hx-post="{% if share_id %}{{ url_for('chat_feedback_shared') }}{% else %}{{ url_for('chat_feedback') }}{% endif %}"
|
|
37
|
-
hx-target="closest .bubble"
|
|
38
|
-
hx-swap="innerHTML"
|
|
39
|
-
x-on:htmx:afterRequest="showForm=false"
|
|
40
|
-
style="display:block; width:800px;">
|
|
41
|
-
{% if share_id %}<input type="hidden" name="share_id" value="{{ share_id }}">{% endif %}
|
|
42
|
-
<input type="hidden" name="flock_definition" value='{{ entry.flock_yaml | tojson | safe }}'>
|
|
43
|
-
<input type="hidden" name="agent_name" value='{{ entry.agent | tojson | safe }}'>
|
|
44
|
-
<input type="hidden" name="actual_response" value='{{ entry.raw_json | tojson | safe }}'>
|
|
45
|
-
<label>Reason</label>
|
|
46
|
-
<textarea name="reason" required style="min-height:5rem;width:100%; white-space:pre-wrap;"></textarea>
|
|
47
|
-
<label>Expected / Correct Response</label>
|
|
48
|
-
<textarea name="expected_response" style="min-height:12rem;width:100%; white-space:pre-wrap;font-family:monospace;">{{ entry.raw_json }}</textarea>
|
|
49
|
-
<div style="margin-top:0.4rem; display:flex; gap:0.5rem;">
|
|
50
|
-
<button type="submit" class="secondary">Send</button>
|
|
51
|
-
<button type="button" class="outline" @click="showForm=false">Back...</button>
|
|
52
|
-
</div>
|
|
53
|
-
</form>
|
|
54
|
-
</div>
|
|
55
|
-
</div>
|
|
56
|
-
{% endif %}
|
|
57
|
-
{% endfor %}
|
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
<form class="chat-settings-form" hx-post="{{ url_for('chat_settings_submit') }}" hx-target="this" hx-swap="outerHTML" hx-indicator="#chat-settings-saving" style="max-width: 500px; margin: 1rem auto;">
|
|
2
|
-
<hgroup style="margin-bottom: 1rem;">
|
|
3
|
-
<h3>Chat Settings</h3>
|
|
4
|
-
<h4>Select agent & field mappings</h4>
|
|
5
|
-
</hgroup>
|
|
6
|
-
|
|
7
|
-
<label for="agent_name_field">Chat Agent</label> <select id="agent_name_field" name="agent_name"
|
|
8
|
-
hx-get="{{ url_for('htmx_chat_settings_partial') }}"
|
|
9
|
-
hx-target="closest form"
|
|
10
|
-
hx-trigger="change"
|
|
11
|
-
hx-include="[name=agent_name]">
|
|
12
|
-
<option value="" {% if not chat_cfg.agent_name %}selected{% endif %}>-- Echo (no agent) --</option>
|
|
13
|
-
{% if current_flock and current_flock.agents %}
|
|
14
|
-
{% for agent_name in current_flock.agents.keys() %}
|
|
15
|
-
<option value="{{ agent_name }}" {% if chat_cfg.agent_name == agent_name %}selected{% endif %}>{{ agent_name }}</option>
|
|
16
|
-
{% endfor %}
|
|
17
|
-
{% else %}
|
|
18
|
-
<option disabled>(no agents loaded)</option>
|
|
19
|
-
{% endif %}
|
|
20
|
-
</select>
|
|
21
|
-
|
|
22
|
-
<label for="message_key_field">Message Key</label>
|
|
23
|
-
{% if input_fields %}
|
|
24
|
-
<select id="message_key_field" name="message_key">
|
|
25
|
-
<option value="" {% if not chat_cfg.message_key %}selected{% endif %}>-- None --</option>
|
|
26
|
-
{% for field in input_fields %}
|
|
27
|
-
<option value="{{ field }}" {% if chat_cfg.message_key == field %}selected{% endif %}>{{ field }}</option>
|
|
28
|
-
{% endfor %}
|
|
29
|
-
</select>
|
|
30
|
-
{% else %}
|
|
31
|
-
<input type="text" id="message_key_field" name="message_key" value="{{ chat_cfg.message_key }}" required>
|
|
32
|
-
{% endif %}
|
|
33
|
-
|
|
34
|
-
<label for="history_key_field">History Key</label>
|
|
35
|
-
{% if input_fields %}
|
|
36
|
-
<select id="history_key_field" name="history_key">
|
|
37
|
-
<option value="" {% if not chat_cfg.history_key %}selected{% endif %}>-- None --</option>
|
|
38
|
-
{% for field in input_fields %}
|
|
39
|
-
<option value="{{ field }}" {% if chat_cfg.history_key == field %}selected{% endif %}>{{ field }}</option>
|
|
40
|
-
{% endfor %}
|
|
41
|
-
</select>
|
|
42
|
-
{% else %}
|
|
43
|
-
<input type="text" id="history_key_field" name="history_key" value="{{ chat_cfg.history_key }}" required>
|
|
44
|
-
{% endif %}
|
|
45
|
-
|
|
46
|
-
<label for="response_key_field">Response Key</label>
|
|
47
|
-
{% if output_fields %}
|
|
48
|
-
<select id="response_key_field" name="response_key">
|
|
49
|
-
<option value="" {% if not chat_cfg.response_key %}selected{% endif %}>-- None --</option>
|
|
50
|
-
{% for field in output_fields %}
|
|
51
|
-
<option value="{{ field }}" {% if chat_cfg.response_key == field %}selected{% endif %}>{{ field }}</option>
|
|
52
|
-
{% endfor %}
|
|
53
|
-
</select>
|
|
54
|
-
{% else %}
|
|
55
|
-
<input type="text" id="response_key_field" name="response_key" value="{{ chat_cfg.response_key }}" required>
|
|
56
|
-
{% endif %}
|
|
57
|
-
|
|
58
|
-
<div class="grid" style="margin-top: 1rem;">
|
|
59
|
-
<button type="submit">Save Settings</button> <button type="reset" class="outline">Reset</button>
|
|
60
|
-
<button type="button" class="secondary outline" hx-get="{{ url_for('htmx_chat_view') }}" hx-target="#chat-content-area" hx-swap="innerHTML">Cancel</button>
|
|
61
|
-
</div>
|
|
62
|
-
<div id="chat-settings-saving" class="htmx-indicator" style="text-align:center; margin-top:0.5rem;"><progress indeterminate></progress></div>
|
|
63
|
-
|
|
64
|
-
{# Share Chat Link Section #}
|
|
65
|
-
<div style="margin-top: 1.5rem; padding-top: 1rem; border-top: 1px solid var(--pico-muted-border-color);">
|
|
66
|
-
<h5 style="margin-bottom: 0.5rem;">Share Chat Configuration</h5>
|
|
67
|
-
<p><small>Create a shareable link for this chat configuration. The current Flock and these chat settings will be frozen for the shared session.</small></p>
|
|
68
|
-
<a href="#"
|
|
69
|
-
id="shareChatHtmxLink"
|
|
70
|
-
hx-post="{{ url_for('htmx_generate_share_link') }}"
|
|
71
|
-
hx-target="#shareChatLinkDisplayArea"
|
|
72
|
-
hx-swap="innerHTML"
|
|
73
|
-
hx-indicator="#share-chat-loading-indicator"
|
|
74
|
-
hx-include="closest form" {# Includes all fields from the parent form #}
|
|
75
|
-
style="text-decoration: underline; cursor: pointer; color: var(--pico-primary);">
|
|
76
|
-
Create shareable chat link...
|
|
77
|
-
</a>
|
|
78
|
-
<span id="share-chat-loading-indicator" class="htmx-indicator" style="margin-left: 0.5rem;">
|
|
79
|
-
<progress indeterminate style="width: 100px;"></progress>
|
|
80
|
-
</span>
|
|
81
|
-
<div id="shareChatLinkDisplayArea" style="margin-top: 1rem;">
|
|
82
|
-
<!-- Shareable chat link will be loaded here by HTMX -->
|
|
83
|
-
</div>
|
|
84
|
-
</div>
|
|
85
|
-
</form>
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
<article id="create-flock-view-content">
|
|
2
|
-
<header>
|
|
3
|
-
<h2>Create or Upload Flock</h2>
|
|
4
|
-
</header>
|
|
5
|
-
|
|
6
|
-
{% if error_message %}
|
|
7
|
-
<div class="error DANGER" role="alert" x-data="{ show: true }" x-show="show" x-init="setTimeout(() => show = false, 5000)">
|
|
8
|
-
{{ error_message }} <button type="button" class="close" @click="show = false">×</button>
|
|
9
|
-
</div>
|
|
10
|
-
{% endif %}
|
|
11
|
-
{% if success_message %} {# For messages after an action within this view #}
|
|
12
|
-
<div class="success SUCCESS" role="alert" x-data="{ show: true }" x-show="show" x-init="setTimeout(() => show = false, 5000)">
|
|
13
|
-
{{ success_message }} <button type="button" class="close" @click="show = false">×</button>
|
|
14
|
-
</div>
|
|
15
|
-
{% endif %}
|
|
16
|
-
|
|
17
|
-
<section id="create-by-details-section">
|
|
18
|
-
<h4>Define New Flock Properties</h4> <form hx-post="{{ url_for('create_flock') }}"
|
|
19
|
-
hx-target="#main-content-area" {# On success, loads properties form into main area #}
|
|
20
|
-
hx-swap="innerHTML"
|
|
21
|
-
hx-indicator="#create-indicator-details">
|
|
22
|
-
<label for="flock_name_create_details">Flock Name *</label>
|
|
23
|
-
<input type="text" id="flock_name_create_details" name="flock_name" placeholder="My Awesome Flock" required>
|
|
24
|
-
|
|
25
|
-
<label for="default_model_create_details">Default Model (Optional)</label>
|
|
26
|
-
<input type="text" id="default_model_create_details" name="default_model" placeholder="openai/gpt-4o">
|
|
27
|
-
|
|
28
|
-
<label for="description_create_details">Description (Optional)</label>
|
|
29
|
-
<textarea id="description_create_details" name="description" placeholder="A brief description..."></textarea>
|
|
30
|
-
|
|
31
|
-
<button type="submit">Create and Edit Flock</button>
|
|
32
|
-
<span id="create-indicator-details" class="htmx-indicator"><progress indeterminate></progress> Creating...</span>
|
|
33
|
-
</form>
|
|
34
|
-
</section>
|
|
35
|
-
|
|
36
|
-
<hr>
|
|
37
|
-
|
|
38
|
-
<section id="create-by-upload-section">
|
|
39
|
-
<h4>Upload Existing Flock File</h4> <form hx-post="{{ url_for('load_flock_by_upload') }}"
|
|
40
|
-
hx-target="#main-content-area" {# On success, loads properties form into main area #}
|
|
41
|
-
hx-swap="innerHTML"
|
|
42
|
-
hx-encoding="multipart/form-data"
|
|
43
|
-
hx-indicator="#create-upload-loading-indicator">
|
|
44
|
-
<label for="flock_file_upload_create">Upload <code>.flock.yaml</code>, <code>.yaml</code>, or <code>.yml</code> file:</label>
|
|
45
|
-
<input type="file" id="flock_file_upload_create" name="flock_file_upload" accept=".yaml,.yml,.flock" required>
|
|
46
|
-
<button type="submit">Upload and Edit Flock</button>
|
|
47
|
-
<span id="create-upload-loading-indicator" class="htmx-indicator"><progress indeterminate></progress> Uploading...</span>
|
|
48
|
-
</form>
|
|
49
|
-
</section>
|
|
50
|
-
</article>
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
<article>
|
|
2
|
-
<header>
|
|
3
|
-
<h5>Flock File: <code>{{ selected_filename }}</code></h5>
|
|
4
|
-
</header>
|
|
5
|
-
<p>Details for this Flock file (e.g., size, last modified) could be shown here if fetched.</p> <form hx-post="{{ url_for('ui_load_flock_by_name_action') }}"
|
|
6
|
-
hx-target="#main-content-area" {# Target the main area to show editor on success #}
|
|
7
|
-
hx-swap="innerHTML"
|
|
8
|
-
hx-indicator="#dashboard-flock-detail-loading-indicator">
|
|
9
|
-
<input type="hidden" name="selected_flock_filename" value="{{ selected_filename }}">
|
|
10
|
-
<button type="submit">Load this Flock into Editor</button>
|
|
11
|
-
<span id="dashboard-flock-detail-loading-indicator" class="htmx-indicator"><progress indeterminate></progress></span>
|
|
12
|
-
</form>
|
|
13
|
-
<hr>
|
|
14
|
-
<p><small>Or, you can use the form below to upload a different Flock file.</small></p>
|
|
15
|
-
{# Include the upload form again or link back to it #}
|
|
16
|
-
<div hx-get="{{ url_for('htmx_get_dashboard_upload_flock_form') }}" hx-trigger="load" hx-swap="innerHTML"></div>
|
|
17
|
-
</article>
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
{% if flock_files %}
|
|
2
|
-
<ul class="item-list">
|
|
3
|
-
{% for file_name in flock_files %} <li hx-get="{{ url_for('htmx_get_dashboard_flock_properties_preview', filename=file_name) }}"
|
|
4
|
-
hx-target="#flock-properties-or-action-content" {# Target the right pane #}
|
|
5
|
-
hx-swap="innerHTML"
|
|
6
|
-
hx-indicator="#flock-properties-or-action-content progress"
|
|
7
|
-
{# Optional: Add hx-select-from-response or other advanced HTMX if needed to highlight this li #}
|
|
8
|
-
onclick="this.closest('ul').querySelectorAll('li').forEach(li => li.classList.remove('selected-item')); this.classList.add('selected-item');"
|
|
9
|
-
>
|
|
10
|
-
<strong>{{ file_name }}</strong>
|
|
11
|
-
</li>
|
|
12
|
-
{% endfor %}
|
|
13
|
-
</ul>
|
|
14
|
-
{% else %}
|
|
15
|
-
<p style="padding: 1rem;">No Flock files found in <code>./.flock_ui_projects/</code>.</p>
|
|
16
|
-
{% endif %}
|