mirror of
https://github.com/mountain-loop/yaak.git
synced 2026-03-18 07:24:07 +01:00
76 lines
2.2 KiB
TypeScript
76 lines
2.2 KiB
TypeScript
import React from 'react';
|
|
import init, { greet } from 'hello';
|
|
import ReactDOM from 'react-dom/client';
|
|
import App from './App';
|
|
import { HelmetProvider } from 'react-helmet-async';
|
|
import { MotionConfig } from 'framer-motion';
|
|
import { listen } from '@tauri-apps/api/event';
|
|
import { setTheme } from './lib/theme';
|
|
import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
|
|
import { createBrowserRouter, RouterProvider } from 'react-router-dom';
|
|
import { Layout } from './components/Layout';
|
|
import { Workspaces } from './pages/Workspaces';
|
|
import './main.css';
|
|
import { convertDates, HttpRequest } from './lib/models';
|
|
import { requestsQueryKey } from './hooks/useRequest';
|
|
|
|
setTheme();
|
|
|
|
// WASM stuff
|
|
await init();
|
|
greet();
|
|
|
|
const queryClient = new QueryClient();
|
|
|
|
await listen('updated_request', ({ payload: request }: { payload: HttpRequest }) => {
|
|
queryClient.setQueryData(requestsQueryKey(request.workspaceId), (requests: HttpRequest[] = []) =>
|
|
requests.map((r) => (r.id === request.id ? convertDates(request) : r)),
|
|
);
|
|
});
|
|
|
|
await listen('created_request', ({ payload: request }: { payload: HttpRequest }) => {
|
|
queryClient.setQueryData(
|
|
requestsQueryKey(request.workspaceId),
|
|
(requests: HttpRequest[] = []) => [...requests, convertDates(request)],
|
|
);
|
|
});
|
|
|
|
await listen('deleted_request', ({ payload: request }: { payload: HttpRequest }) => {
|
|
queryClient.setQueryData(requestsQueryKey(request.workspaceId), (requests: HttpRequest[] = []) =>
|
|
requests.filter((r) => r.id !== request.id),
|
|
);
|
|
});
|
|
|
|
const router = createBrowserRouter([
|
|
{
|
|
path: '/',
|
|
element: <Layout />,
|
|
children: [
|
|
{
|
|
path: '/',
|
|
element: <Workspaces />,
|
|
},
|
|
{
|
|
path: '/workspaces/:workspaceId',
|
|
element: <App />,
|
|
},
|
|
{
|
|
path: '/workspaces/:workspaceId/requests/:requestId',
|
|
element: <App />,
|
|
},
|
|
],
|
|
},
|
|
]);
|
|
|
|
ReactDOM.createRoot(document.getElementById('root') as HTMLElement).render(
|
|
<React.StrictMode>
|
|
<QueryClientProvider client={queryClient}>
|
|
<MotionConfig transition={{ duration: 0.15 }}>
|
|
<HelmetProvider>
|
|
<RouterProvider router={router} />
|
|
</HelmetProvider>
|
|
</MotionConfig>
|
|
</QueryClientProvider>
|
|
</React.StrictMode>,
|
|
);
|