Fix response emit and sidebar flex

This commit is contained in:
Gregory Schier
2024-02-09 16:16:02 -08:00
parent cae9a4fd36
commit bbe62abd20
5 changed files with 27 additions and 24 deletions

View File

@@ -42,7 +42,7 @@ use window_ext::TrafficLightWindowExt;
use crate::analytics::{AnalyticsAction, AnalyticsResource}; use crate::analytics::{AnalyticsAction, AnalyticsResource};
use crate::http::send_http_request; use crate::http::send_http_request;
use crate::models::{ use crate::models::{
cancel_pending_grpc_connections, cancel_pending_responses, create_response, cancel_pending_grpc_connections, cancel_pending_responses, create_http_response,
delete_all_grpc_connections, delete_all_http_responses, delete_cookie_jar, delete_environment, delete_all_grpc_connections, delete_all_http_responses, delete_cookie_jar, delete_environment,
delete_folder, delete_grpc_connection, delete_grpc_request, delete_http_request, delete_folder, delete_grpc_connection, delete_grpc_request, delete_http_request,
delete_http_response, delete_workspace, duplicate_grpc_request, duplicate_http_request, delete_http_response, delete_workspace, duplicate_grpc_request, duplicate_http_request,
@@ -1001,7 +1001,7 @@ async fn cmd_export_data(
} }
#[tauri::command] #[tauri::command]
async fn cmd_send_request( async fn cmd_send_http_request(
w: Window, w: Window,
request_id: &str, request_id: &str,
environment_id: Option<&str>, environment_id: Option<&str>,
@@ -1030,7 +1030,7 @@ async fn cmd_send_request(
None => None, None => None,
}; };
let response = create_response( let response = create_http_response(
&w, &w,
&request.id, &request.id,
0, 0,
@@ -1654,7 +1654,7 @@ fn main() {
cmd_list_workspaces, cmd_list_workspaces,
cmd_new_window, cmd_new_window,
cmd_send_ephemeral_request, cmd_send_ephemeral_request,
cmd_send_request, cmd_send_http_request,
cmd_set_key_value, cmd_set_key_value,
cmd_set_update_mode, cmd_set_update_mode,
cmd_track_event, cmd_track_event,

View File

@@ -1147,7 +1147,7 @@ pub async fn delete_http_request(
} }
#[allow(clippy::too_many_arguments)] #[allow(clippy::too_many_arguments)]
pub async fn create_response( pub async fn create_http_response(
mgr: &impl Manager<Wry>, mgr: &impl Manager<Wry>,
request_id: &str, request_id: &str,
elapsed: i64, elapsed: i64,
@@ -1190,7 +1190,10 @@ pub async fn create_response(
.execute(&db) .execute(&db)
.await?; .await?;
get_http_response(mgr, &id).await match get_http_response(mgr, &id).await {
Ok(m) => Ok(emit_upserted_model(mgr, m)),
Err(e) => Err(e),
}
} }
pub async fn cancel_pending_grpc_connections(mgr: &impl Manager<Wry>) -> Result<(), sqlx::Error> { pub async fn cancel_pending_grpc_connections(mgr: &impl Manager<Wry>) -> Result<(), sqlx::Error> {

View File

@@ -92,7 +92,7 @@ export function GlobalHooks() {
}); });
}); });
useListenToTauriEvent<Model>('deleted_model', ({ payload, windowLabel }) => { useListenToTauriEvent<Model>('deleted_model', ({ payload }) => {
if (shouldIgnoreModel(payload)) return; if (shouldIgnoreModel(payload)) return;
if (payload.model === 'workspace') { if (payload.model === 'workspace') {

View File

@@ -743,7 +743,7 @@ const SidebarItem = forwardRef(function SidebarItem(
data-active={isActive} data-active={isActive}
data-selected={selected} data-selected={selected}
className={classNames( className={classNames(
'w-full flex gap-2 items-center text-sm h-xs pl-2 rounded-md transition-colors', 'w-full flex gap-2 items-center text-sm h-xs px-1.5 rounded-md transition-colors',
editing && 'ring-1 focus-within:ring-focus', editing && 'ring-1 focus-within:ring-focus',
isActive && 'bg-highlightSecondary text-gray-800', isActive && 'bg-highlightSecondary text-gray-800',
!isActive && !isActive &&
@@ -774,22 +774,22 @@ const SidebarItem = forwardRef(function SidebarItem(
) : ( ) : (
<span className="truncate">{itemName || itemFallbackName}</span> <span className="truncate">{itemName || itemFallbackName}</span>
)} )}
{latestGrpcConnection ? (
<div className="ml-auto">
{latestGrpcConnection.elapsed === 0 && (
<Icon spin size="sm" icon="update" className="text-gray-400" />
)}
</div>
) : latestHttpResponse ? (
<div className="ml-auto">
{isResponseLoading(latestHttpResponse) ? (
<Icon spin size="sm" icon="update" className="text-gray-400" />
) : (
<StatusTag className="text-2xs dark:opacity-80" response={latestHttpResponse} />
)}
</div>
) : null}
</div> </div>
{latestGrpcConnection ? (
<div className="ml-auto">
{latestGrpcConnection.elapsed === 0 && (
<Icon spin size="sm" icon="update" className="text-gray-400" />
)}
</div>
) : latestHttpResponse ? (
<div className="ml-auto">
{isResponseLoading(latestHttpResponse) ? (
<Icon spin size="sm" icon="update" className="text-gray-400" />
) : (
<StatusTag className="text-2xs dark:opacity-80" response={latestHttpResponse} />
)}
</div>
) : null}
</button> </button>
</div> </div>
{children} {children}

View File

@@ -31,7 +31,7 @@ export function useSendAnyRequest(options: { download?: boolean } = {}) {
} }
} }
return invoke('cmd_send_request', { return invoke('cmd_send_http_request', {
requestId: id, requestId: id,
environmentId, environmentId,
downloadDir: downloadDir, downloadDir: downloadDir,