diff --git a/apps/webservice/src/app/[workspaceSlug]/(job)/job-agents/JobAgentsGettingStarted.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(job)/job-agents/JobAgentsGettingStarted.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(job)/job-agents/JobAgentsGettingStarted.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(job)/job-agents/JobAgentsGettingStarted.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(job)/job-agents/JobAgentsTable.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(job)/job-agents/JobAgentsTable.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(job)/job-agents/JobAgentsTable.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(job)/job-agents/JobAgentsTable.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(job)/job-agents/integrations/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(job)/job-agents/integrations/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(job)/job-agents/integrations/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(job)/job-agents/integrations/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(job)/job-agents/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(job)/job-agents/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(job)/job-agents/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(job)/job-agents/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(job)/jobs/JobTable.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(job)/jobs/JobTable.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(job)/jobs/JobTable.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(job)/jobs/JobTable.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(job)/jobs/JobsGettingStarted.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(job)/jobs/JobsGettingStarted.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(job)/jobs/JobsGettingStarted.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(job)/jobs/JobsGettingStarted.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(job)/jobs/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(job)/jobs/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(job)/jobs/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(job)/jobs/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(job)/layout.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(job)/layout.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(job)/layout.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(job)/layout.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/layout.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/layout.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/layout.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/layout.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/CreateMetadataGroupDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/CreateMetadataGroupDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/CreateMetadataGroupDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/CreateMetadataGroupDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/DeleteMetadataGroupDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/DeleteMetadataGroupDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/DeleteMetadataGroupDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/DeleteMetadataGroupDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/EditMetadataGroupDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/EditMetadataGroupDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/EditMetadataGroupDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/EditMetadataGroupDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/MetadataFilterInput.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/MetadataFilterInput.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/MetadataFilterInput.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/MetadataFilterInput.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/TargetGroupTable.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/TargetGroupTable.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/TargetGroupTable.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/TargetGroupTable.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/TargetMetadataGroupsGettingStarted.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/TargetMetadataGroupsGettingStarted.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/TargetMetadataGroupsGettingStarted.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/TargetMetadataGroupsGettingStarted.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/[groupId]/CombincationsTable.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/[groupId]/CombincationsTable.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/[groupId]/CombincationsTable.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/[groupId]/CombincationsTable.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/[groupId]/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/[groupId]/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/[groupId]/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/[groupId]/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-metadata-groups/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-metadata-groups/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/ProviderActionsDropdown.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/ProviderActionsDropdown.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/ProviderActionsDropdown.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/ProviderActionsDropdown.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/TargetProvidersGettingStarted.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/TargetProvidersGettingStarted.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/TargetProvidersGettingStarted.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/TargetProvidersGettingStarted.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/add/GoogleScanerConfig.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/add/GoogleScanerConfig.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/add/GoogleScanerConfig.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/add/GoogleScanerConfig.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/add/TargetProviderSelectCard.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/add/TargetProviderSelectCard.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/add/TargetProviderSelectCard.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/add/TargetProviderSelectCard.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/add/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/add/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/add/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/add/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/integrations/GoogleActionButton.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/integrations/GoogleActionButton.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/integrations/GoogleActionButton.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/integrations/GoogleActionButton.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/integrations/google/GoogleDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/integrations/google/GoogleDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/integrations/google/GoogleDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/integrations/google/GoogleDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/integrations/google/UpdateGoogleProviderDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/integrations/google/UpdateGoogleProviderDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/integrations/google/UpdateGoogleProviderDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/integrations/google/UpdateGoogleProviderDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/integrations/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/integrations/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/integrations/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/integrations/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-providers/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-providers/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-views/TargetViewsTable.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-views/TargetViewsTable.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-views/TargetViewsTable.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-views/TargetViewsTable.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/target-views/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-views/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/target-views/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/target-views/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/TargetGettingStarted.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/TargetGettingStarted.tsx similarity index 96% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/TargetGettingStarted.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/TargetGettingStarted.tsx index 50f3f516b..f2b1fecbb 100644 --- a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/TargetGettingStarted.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/TargetGettingStarted.tsx @@ -4,7 +4,7 @@ import { IconTopologyComplex } from "@tabler/icons-react"; import { Button, buttonVariants } from "@ctrlplane/ui/button"; -import { CreateTargetDialog } from "../../_components/CreateTarget"; +import { CreateTargetDialog } from "../../../_components/CreateTarget"; export const TargetGettingStarted: React.FC<{ workspace: Workspace }> = ({ workspace, diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/TargetPageContent.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/TargetPageContent.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/TargetPageContent.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/TargetPageContent.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/TargetsTable.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/TargetsTable.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/TargetsTable.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/TargetsTable.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/ReleaseCell.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/ReleaseCell.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/ReleaseCell.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/ReleaseCell.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/layout.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/layout.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/layout.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/layout.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/variables/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/variables/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/variables/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/variables/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/DepEdge.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/DepEdge.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/DepEdge.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/DepEdge.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/ResourceVisualizationDiagram.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/ResourceVisualizationDiagram.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/ResourceVisualizationDiagram.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/ResourceVisualizationDiagram.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/edges.ts b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/edges.ts similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/edges.ts rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/edges.ts diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/nodes/DeploymentNode.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/nodes/DeploymentNode.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/nodes/DeploymentNode.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/nodes/DeploymentNode.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/nodes/EnvironmentNode.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/nodes/EnvironmentNode.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/nodes/EnvironmentNode.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/nodes/EnvironmentNode.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/nodes/ProviderNode.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/nodes/ProviderNode.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/nodes/ProviderNode.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/nodes/ProviderNode.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/nodes/ResourceNode.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/nodes/ResourceNode.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/nodes/ResourceNode.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/nodes/ResourceNode.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/nodes/SystemNode.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/nodes/SystemNode.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/nodes/SystemNode.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/nodes/SystemNode.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/[targetId]/visualize/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/[targetId]/visualize/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(targets)/targets/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/(targets)/targets/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/(targets)/targets/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebar.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebar.tsx new file mode 100644 index 000000000..c07931933 --- /dev/null +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebar.tsx @@ -0,0 +1,38 @@ +import type { Workspace } from "@ctrlplane/db/schema"; +import React from "react"; + +import { SidebarContent, SidebarHeader } from "@ctrlplane/ui/sidebar"; + +import { api } from "~/trpc/server"; +import { AppSidebarSystem, AppSidebarWorkspace } from "./AppSidebarContent"; +import { AppSidebarHeader } from "./AppSidebarHeader"; +import { AppSidebarPopover } from "./AppSidebarPopover"; +import { SidebarWithPopover } from "./AppSidebarPopoverContext"; + +export const AppSidebar: React.FC<{ workspace: Workspace }> = async ({ + workspace, +}) => { + const [workspaces, viewer, systems] = await Promise.all([ + api.workspace.list(), + api.user.viewer(), + api.system.list({ workspaceId: workspace.id }), + ]); + + return ( + + + + + + + + + + + ); +}; diff --git a/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebarContent.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebarContent.tsx new file mode 100644 index 000000000..7d802a76e --- /dev/null +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebarContent.tsx @@ -0,0 +1,111 @@ +"use client"; + +import type { System } from "@ctrlplane/db/schema"; +import { useMemo } from "react"; +import { + IconCategory, + IconObjectScan, + IconPlant, + IconRocket, + IconRun, + IconShip, + IconVariable, +} from "@tabler/icons-react"; + +import { SidebarNavMain } from "../SidebarNavMain"; + +const navMain = (prefix: string) => [ + { + title: "Systems", + icon: IconCategory, + isActive: true, + items: [ + { + title: "Dependencies", + url: `${prefix}/dependencies`, + isActive: true, + }, + ], + }, + { + title: "Resources", + popoverId: "targets", + icon: IconObjectScan, + isActive: true, + items: [ + { + title: "List", + url: `${prefix}/targets`, + }, + { + title: "Providers", + url: `${prefix}/target-providers`, + }, + { + title: "Groups", + url: `${prefix}/target-metadata-groups`, + }, + { + title: "Views", + url: `${prefix}/target-views`, + }, + ], + }, + { + title: "Jobs", + icon: IconRocket, + items: [ + { + title: "Agents", + url: "#", + }, + { + title: "Runs", + url: "#", + }, + ], + }, +]; + +export const AppSidebarWorkspace: React.FC<{ workspaceSlug: string }> = ({ + workspaceSlug, +}) => { + const items = useMemo(() => navMain(`/${workspaceSlug}`), [workspaceSlug]); + return ; +}; + +export const AppSidebarSystem: React.FC<{ + systems: System[]; +}> = ({ systems }) => { + const items = useMemo( + () => + systems.map((s) => ({ + title: s.name, + isActive: true, + items: [ + { + title: "Environments", + icon: IconPlant, + url: "#", + }, + { + title: "Deployements", + icon: IconShip, + url: "#", + }, + { + title: "Runbooks", + icon: IconRun, + url: "#", + }, + { + title: "Variable Sets", + icon: IconVariable, + url: "#", + }, + ], + })), + [systems], + ); + return ; +}; diff --git a/apps/webservice/src/app/[workspaceSlug]/SidebarCreateMenu.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebarCreateMenu.tsx similarity index 58% rename from apps/webservice/src/app/[workspaceSlug]/SidebarCreateMenu.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebarCreateMenu.tsx index 121f5683e..451d8a300 100644 --- a/apps/webservice/src/app/[workspaceSlug]/SidebarCreateMenu.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebarCreateMenu.tsx @@ -1,5 +1,8 @@ +"use client"; + import type { Workspace } from "@ctrlplane/db/schema"; import { useState } from "react"; +import { useParams } from "next/navigation"; import { IconPlus } from "@tabler/icons-react"; import { Button } from "@ctrlplane/ui/button"; @@ -12,17 +15,35 @@ import { DropdownMenuTrigger, } from "@ctrlplane/ui/dropdown-menu"; -import { CreateDeploymentDialog } from "./_components/CreateDeployment"; -import { CreateReleaseDialog } from "./_components/CreateRelease"; -import { CreateSystemDialog } from "./_components/CreateSystem"; -import { CreateTargetDialog } from "./_components/CreateTarget"; -import { CreateSessionDialog } from "./_components/terminal/CreateDialogSession"; +import { api } from "~/trpc/react"; +import { CreateDeploymentDialog } from "../_components/CreateDeployment"; +import { CreateReleaseDialog } from "../_components/CreateRelease"; +import { CreateSystemDialog } from "../_components/CreateSystem"; +import { CreateTargetDialog } from "../_components/CreateTarget"; +import { CreateSessionDialog } from "../_components/terminal/CreateDialogSession"; -export const SidebarCreateMenu: React.FC<{ +export const AppSidebarCreateMenu: React.FC<{ workspace: Workspace; - deploymentId?: string; - systemId?: string; -}> = (props) => { +}> = ({ workspace }) => { + const { deploymentSlug, workspaceSlug, systemSlug } = useParams<{ + workspaceSlug: string; + systemSlug?: string; + deploymentSlug?: string; + }>(); + + const system = api.system.bySlug.useQuery( + { workspaceSlug, systemSlug: systemSlug ?? "" }, + { enabled: systemSlug != null }, + ); + const deployment = api.deployment.bySlug.useQuery( + { + workspaceSlug, + systemSlug: systemSlug ?? "", + deploymentSlug: deploymentSlug ?? "", + }, + { enabled: deploymentSlug != null && systemSlug != null }, + ); + const [open, setOpen] = useState(false); return ( @@ -42,19 +63,26 @@ export const SidebarCreateMenu: React.FC<{ > setOpen(false)} > e.preventDefault()}> New System - setOpen(false)}> + setOpen(false)} + > e.preventDefault()}> New Deployment - setOpen(false)}> + setOpen(false)} + > e.preventDefault()}> New Release @@ -75,7 +103,10 @@ export const SidebarCreateMenu: React.FC<{ - setOpen(false)}> + setOpen(false)} + > e.preventDefault()}> Bootstrap Target diff --git a/apps/webservice/src/app/[workspaceSlug]/SidebarWorkspaceDropdown.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebarHeader.tsx similarity index 65% rename from apps/webservice/src/app/[workspaceSlug]/SidebarWorkspaceDropdown.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebarHeader.tsx index 600f09664..70f9c5843 100644 --- a/apps/webservice/src/app/[workspaceSlug]/SidebarWorkspaceDropdown.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebarHeader.tsx @@ -1,9 +1,9 @@ "use client"; -import type { Workspace } from "@ctrlplane/db/schema"; +import type { System, Workspace } from "@ctrlplane/db/schema"; import Link from "next/link"; -import { IconCheck, IconChevronDown } from "@tabler/icons-react"; -import { signOut, useSession } from "next-auth/react"; +import { IconCheck, IconChevronDown, IconSearch } from "@tabler/icons-react"; +import { signOut } from "next-auth/react"; import { Button } from "@ctrlplane/ui/button"; import { @@ -19,14 +19,17 @@ import { DropdownMenuSubTrigger, DropdownMenuTrigger, } from "@ctrlplane/ui/dropdown-menu"; +import { SidebarMenu, SidebarMenuItem } from "@ctrlplane/ui/sidebar"; import { api } from "~/trpc/react"; +import { SearchDialog } from "../_components/SearchDialog"; +import { AppSidebarCreateMenu } from "./AppSidebarCreateMenu"; -export const SidebarWorkspaceDropdown: React.FC<{ workspace: Workspace }> = ({ - workspace, -}) => { - const { data } = useSession(); - const workspaces = api.workspace.list.useQuery(); +const WorkspaceDropdown: React.FC<{ + workspace: Workspace; + workspaces: Workspace[]; + viewer: { email: string }; +}> = ({ workspace, workspaces, viewer }) => { const update = api.profile.update.useMutation(); return ( @@ -53,9 +56,9 @@ export const SidebarWorkspaceDropdown: React.FC<{ workspace: Workspace }> = ({ - {data?.user.email} + {viewer.email} - {workspaces.data?.map((ws) => ( + {workspaces.map((ws) => ( = ({ ); }; + +export const AppSidebarHeader: React.FC<{ + systems: System[]; + workspace: Workspace; + workspaces: Workspace[]; + viewer: { email: string }; +}> = ({ workspace, workspaces, viewer }) => { + return ( + + +
+ +
+ + + + +
+
+ ); +}; diff --git a/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebarPopover.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebarPopover.tsx new file mode 100644 index 000000000..adb987a02 --- /dev/null +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebarPopover.tsx @@ -0,0 +1,25 @@ +"use client"; + +import React from "react"; +import { useKey } from "react-use"; + +import { Popover, PopoverAnchor, PopoverContent } from "@ctrlplane/ui/popover"; + +import { useSidebarPopover } from "./AppSidebarPopoverContext"; + +export const AppSidebarPopover: React.FC = () => { + const { activeSidebarItem, setActiveSidebarItem } = useSidebarPopover(); + useKey("Escape", () => setActiveSidebarItem(null)); + return ( + + + + {activeSidebarItem} + + + ); +}; diff --git a/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebarPopoverContext.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebarPopoverContext.tsx new file mode 100644 index 000000000..e7367ff99 --- /dev/null +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/AppSidebarPopoverContext.tsx @@ -0,0 +1,85 @@ +"use client"; + +import { createContext, useContext, useState } from "react"; + +import { + Sidebar, + SidebarMenuItem, + SidebarMenuSubItem, +} from "@ctrlplane/ui/sidebar"; + +type AppSidebarPopoverContextType = { + activeSidebarItem: string | null; + setActiveSidebarItem: (item: string | null) => void; +}; + +const AppSidebarPopoverContext = createContext({ + activeSidebarItem: null, + setActiveSidebarItem: () => {}, +}); + +export const useSidebarPopover = () => useContext(AppSidebarPopoverContext); + +export const AppSidebarPopoverProvider: React.FC<{ + children: React.ReactNode; +}> = ({ children }) => { + const [activeSidebarItem, setActiveSidebarItem] = useState( + null, + ); + return ( + + {children} + + ); +}; + +export const SidebarWithPopover: React.FC<{ + children: React.ReactNode; +}> = ({ children }) => { + const { setActiveSidebarItem } = useSidebarPopover(); + return ( + setActiveSidebarItem(null)}> + {children} + + ); +}; + +export const SidebarMenuItemWithPopover: React.FC<{ + children: React.ReactNode; + popoverId?: string; +}> = ({ children, popoverId }) => { + const { setActiveSidebarItem } = useSidebarPopover(); + return ( + { + if (popoverId != null) { + setActiveSidebarItem(popoverId); + e.stopPropagation(); + } + }} + > + {children} + + ); +}; + +export const SidebarMenuSubItemWithPopover: React.FC<{ + children: React.ReactNode; + popoverId?: string; +}> = ({ children, popoverId }) => { + const { setActiveSidebarItem } = useSidebarPopover(); + return ( + { + if (popoverId != null) { + setActiveSidebarItem(popoverId); + e.stopPropagation(); + } + }} + > + {children} + + ); +}; diff --git a/apps/webservice/src/app/[workspaceSlug]/(app)/_SidebarPopoverSystem.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/_SidebarPopoverSystem.tsx new file mode 100644 index 000000000..5416b74e2 --- /dev/null +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/_SidebarPopoverSystem.tsx @@ -0,0 +1,51 @@ +// "use client"; + +// import type { Workspace } from "@ctrlplane/db/schema"; + +// import { api } from "~/trpc/react"; +// import { SidebarLink } from "./SidebarLink"; + +// export const SidebarPopoverSystem: React.FC<{ +// systemId: string; +// workspace: Workspace; +// }> = ({ workspace, systemId }) => { +// const system = api.system.byId.useQuery(systemId); +// const environments = api.environment.bySystemId.useQuery(systemId); +// const deployments = api.deployment.bySystemId.useQuery(systemId); +// return ( +//
+//
{system.data?.name}
+ +//
+//
+// Environments +//
+//
+// {environments.data?.map(({ name }) => ( +// +// {name} +// +// ))} +//
+//
+ +//
+//
+// Deployments +//
+//
+// {deployments.data?.map(({ id, name, slug }) => ( +// +// {name} +// +// ))} +//
+//
+//
+// ); +// }; diff --git a/apps/webservice/src/app/[workspaceSlug]/(app)/_SidebarSystems.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/_SidebarSystems.tsx new file mode 100644 index 000000000..ef7a0e142 --- /dev/null +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/_SidebarSystems.tsx @@ -0,0 +1,108 @@ +// "use client"; + +// import type { System, Workspace } from "@ctrlplane/db/schema"; +// import { useState } from "react"; +// import { useParams } from "next/navigation"; +// import { +// IconChevronRight, +// IconPlant, +// IconPlus, +// IconRun, +// IconShip, +// IconVariable, +// } from "@tabler/icons-react"; +// import _ from "lodash"; +// import { useLocalStorage } from "react-use"; + +// import { cn } from "@ctrlplane/ui"; +// import { Button } from "@ctrlplane/ui/button"; +// import { +// Collapsible, +// CollapsibleContent, +// CollapsibleTrigger, +// } from "@ctrlplane/ui/collapsible"; + +// import { CreateSystemDialog } from "./_components/CreateSystem"; +// import { useSidebar } from "./SidebarContext"; +// import { SidebarLink } from "./SidebarLink"; + +// const SystemCollapsible: React.FC<{ system: System }> = ({ system }) => { +// const { setActiveSidebarItem } = useSidebar(); +// const [open, setOpen] = useLocalStorage( +// `sidebar-systems-${system.id}`, +// "false", +// ); +// const { workspaceSlug } = useParams<{ workspaceSlug: string }>(); +// return ( +// setOpen(open === "true" ? "false" : "true")} +// className="space-y-1 text-sm" +// onMouseEnter={() => setActiveSidebarItem(`systems:${system.id}`)} +// > +// +// {system.name} +// +// +// +// +// Deployments +// +// +// Environments +// +// +// Runbooks +// +// +// Variable +// Sets +// +// +// +// ); +// }; + +// export const SidebarSystems: React.FC<{ +// workspace: Workspace; +// systems: System[]; +// }> = ({ workspace, systems }) => { +// const [open, setOpen] = useState(true); +// return ( +// +// +// Your systems +// +// +// +// {systems.length === 0 && ( +// +// +// +// )} +// {systems.map((system) => ( +// +// ))} +// +// +// ); +// }; diff --git a/apps/webservice/src/app/[workspaceSlug]/dashboard/TargetAnnotationPieChart.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dashboard/TargetAnnotationPieChart.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/dashboard/TargetAnnotationPieChart.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dashboard/TargetAnnotationPieChart.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/dashboard/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dashboard/page.tsx similarity index 95% rename from apps/webservice/src/app/[workspaceSlug]/dashboard/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dashboard/page.tsx index fdf6bf80c..4eb034341 100644 --- a/apps/webservice/src/app/[workspaceSlug]/dashboard/page.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/dashboard/page.tsx @@ -3,7 +3,7 @@ import { notFound } from "next/navigation"; import { Card } from "@ctrlplane/ui/card"; -import { api } from "../../../trpc/server"; +import { api } from "../../../../trpc/server"; import { JobHistoryChart } from "../systems/JobHistoryChart"; import { TargetAnnotationPieChart } from "./TargetAnnotationPieChart"; diff --git a/apps/webservice/src/app/[workspaceSlug]/dashboards/Dashboard.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/Dashboard.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/dashboards/Dashboard.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/Dashboard.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/dashboards/DashboardContext.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/DashboardContext.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/dashboards/DashboardContext.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/DashboardContext.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/dashboards/DashboardGrid.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/DashboardGrid.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/dashboards/DashboardGrid.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/DashboardGrid.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/dashboards/[dashboardId]/DashboardTitle.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/[dashboardId]/DashboardTitle.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/dashboards/[dashboardId]/DashboardTitle.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/[dashboardId]/DashboardTitle.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/dashboards/[dashboardId]/WidgetMenu.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/[dashboardId]/WidgetMenu.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/dashboards/[dashboardId]/WidgetMenu.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/[dashboardId]/WidgetMenu.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/dashboards/[dashboardId]/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/[dashboardId]/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/dashboards/[dashboardId]/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/[dashboardId]/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/dashboards/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/dashboards/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/dashboards/widgets/HelperButton.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/widgets/HelperButton.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/dashboards/widgets/HelperButton.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/widgets/HelperButton.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/dashboards/widgets/TargetWidgets.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/widgets/TargetWidgets.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/dashboards/widgets/TargetWidgets.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/widgets/TargetWidgets.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/dashboards/widgets/TextHeading.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/widgets/TextHeading.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/dashboards/widgets/TextHeading.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/widgets/TextHeading.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/dashboards/widgets/index.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/widgets/index.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/dashboards/widgets/index.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/widgets/index.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/dashboards/widgets/spec.ts b/apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/widgets/spec.ts similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/dashboards/widgets/spec.ts rename to apps/webservice/src/app/[workspaceSlug]/(app)/dashboards/widgets/spec.ts diff --git a/apps/webservice/src/app/[workspaceSlug]/dependencies/DependenciesGettingStarted.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dependencies/DependenciesGettingStarted.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/dependencies/DependenciesGettingStarted.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dependencies/DependenciesGettingStarted.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/dependencies/DependencyDiagram.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dependencies/DependencyDiagram.tsx similarity index 98% rename from apps/webservice/src/app/[workspaceSlug]/dependencies/DependencyDiagram.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dependencies/DependencyDiagram.tsx index 9f45d64be..ba84db0a4 100644 --- a/apps/webservice/src/app/[workspaceSlug]/dependencies/DependencyDiagram.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/dependencies/DependencyDiagram.tsx @@ -31,7 +31,7 @@ import { import { Popover, PopoverContent, PopoverTrigger } from "@ctrlplane/ui/popover"; import { api } from "~/trpc/react"; -import { getLayoutedElementsDagre } from "../_components/reactflow/layout"; +import { getLayoutedElementsDagre } from "../../_components/reactflow/layout"; const useOnLayout = () => { const { getNodes, fitView, setNodes, setEdges, getEdges } = useReactFlow(); diff --git a/apps/webservice/src/app/[workspaceSlug]/dependencies/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/dependencies/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/dependencies/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/dependencies/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(app)/layout.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/layout.tsx new file mode 100644 index 000000000..cb4fc3026 --- /dev/null +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/layout.tsx @@ -0,0 +1,54 @@ +import dynamic from "next/dynamic"; +import { notFound, redirect } from "next/navigation"; + +import { auth } from "@ctrlplane/auth"; +import { SidebarInset } from "@ctrlplane/ui/sidebar"; + +import { api } from "~/trpc/server"; +import { EnvironmentDrawer } from "../_components/environment-drawer/EnvironmentDrawer"; +import { EnvironmentPolicyDrawer } from "../_components/environment-policy-drawer/EnvironmentPolicyDrawer"; +import { JobDrawer } from "../_components/job-drawer/JobDrawer"; +import { ReleaseChannelDrawer } from "../_components/release-channel-drawer/ReleaseChannelDrawer"; +import { ReleaseDrawer } from "../_components/release-drawer/ReleaseDrawer"; +import { TargetDrawer } from "../_components/target-drawer/TargetDrawer"; +import { VariableSetDrawer } from "../_components/variable-set-drawer/VariableSetDrawer"; +import { AppSidebar } from "./AppSidebar"; +import { AppSidebarPopoverProvider } from "./AppSidebarPopoverContext"; + +const TerminalDrawer = dynamic( + () => import("../_components/terminal/TerminalSessionsDrawer"), + { ssr: false }, +); + +type Props = { + children: React.ReactNode; + params: { workspaceSlug: string }; +}; + +export default async function WorkspaceLayout({ + children, + params: { workspaceSlug }, +}: Props) { + const session = await auth(); + if (session == null) redirect("/login"); + + const workspace = await api.workspace.bySlug(workspaceSlug).catch(() => null); + if (workspace == null) notFound(); + + return ( + + + {children} + + + + + + + + + + + + ); +} diff --git a/apps/webservice/src/app/[workspaceSlug]/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/JobHistoryChart.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/JobHistoryChart.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/JobHistoryChart.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/JobHistoryChart.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/SystemActionsDropdown.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemActionsDropdown.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/SystemActionsDropdown.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemActionsDropdown.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemFilter.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemFilter.tsx new file mode 100644 index 000000000..07fc4f5af --- /dev/null +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemFilter.tsx @@ -0,0 +1,3 @@ +import type { Filter } from "../../_components/filter/Filter"; + +export type SystemFilter = Filter<"name" | "slug", string>; diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/SystemGettingStarted.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemGettingStarted.tsx similarity index 94% rename from apps/webservice/src/app/[workspaceSlug]/systems/SystemGettingStarted.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemGettingStarted.tsx index f3712804f..a77055fad 100644 --- a/apps/webservice/src/app/[workspaceSlug]/systems/SystemGettingStarted.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemGettingStarted.tsx @@ -3,7 +3,7 @@ import { IconTopologyComplex } from "@tabler/icons-react"; import { Button } from "@ctrlplane/ui/button"; -import { CreateSystemDialog } from "../_components/CreateSystem"; +import { CreateSystemDialog } from "../../_components/CreateSystem"; export const SystemGettingStarted: React.FC<{ workspace: Workspace; diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/SystemsBreadcrumb.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemsBreadcrumb.tsx similarity index 97% rename from apps/webservice/src/app/[workspaceSlug]/systems/SystemsBreadcrumb.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemsBreadcrumb.tsx index cb111d702..74da12297 100644 --- a/apps/webservice/src/app/[workspaceSlug]/systems/SystemsBreadcrumb.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemsBreadcrumb.tsx @@ -17,7 +17,7 @@ import { } from "@ctrlplane/ui/breadcrumb"; import { Button } from "@ctrlplane/ui/button"; -import { SystemActionsDropdown } from "~/app/[workspaceSlug]/systems/SystemActionsDropdown"; +import { SystemActionsDropdown } from "~/app/[workspaceSlug]/(app)/systems/SystemActionsDropdown"; import { api } from "~/trpc/server"; export const SystemBreadcrumbNavbar = async ({ diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/SystemsList.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemsList.tsx similarity index 93% rename from apps/webservice/src/app/[workspaceSlug]/systems/SystemsList.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemsList.tsx index 49b30d73b..4d3949412 100644 --- a/apps/webservice/src/app/[workspaceSlug]/systems/SystemsList.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemsList.tsx @@ -16,10 +16,10 @@ import { Skeleton } from "@ctrlplane/ui/skeleton"; import type { SystemFilter } from "./SystemFilter"; import { api } from "~/trpc/react"; -import { useFilters } from "../_components/filter/Filter"; -import { FilterDropdown } from "../_components/filter/FilterDropdown"; -import { ContentDialog } from "../_components/filter/FilterDropdownItems"; -import { NoFilterMatch } from "../_components/filter/NoFilterMatch"; +import { useFilters } from "../../_components/filter/Filter"; +import { FilterDropdown } from "../../_components/filter/FilterDropdown"; +import { ContentDialog } from "../../_components/filter/FilterDropdownItems"; +import { NoFilterMatch } from "../../_components/filter/NoFilterMatch"; import { SystemsTable } from "./SystemsTable"; export const SystemsList: React.FC<{ diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/SystemsTable.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemsTable.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/SystemsTable.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/SystemsTable.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/TopNav.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/TopNav.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/TopNav.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/TopNav.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/_components/DeleteSystemDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/_components/DeleteSystemDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/_components/DeleteSystemDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/_components/DeleteSystemDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/_components/EditAgentConfigDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/_components/EditAgentConfigDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/_components/EditAgentConfigDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/_components/EditAgentConfigDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/_components/EditSystemDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/_components/EditSystemDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/_components/EditSystemDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/_components/EditSystemDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/_components/variables/ConfigFields.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/_components/variables/ConfigFields.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/_components/variables/ConfigFields.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/_components/variables/ConfigFields.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/_components/variables/VariableInputs.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/_components/variables/VariableInputs.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/_components/variables/VariableInputs.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/_components/variables/VariableInputs.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/DeployButton.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/DeployButton.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/DeployButton.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/DeployButton.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/DeploymentBarChart.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/DeploymentBarChart.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/DeploymentBarChart.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/DeploymentBarChart.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/DeploymentGettingStarted.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/DeploymentGettingStarted.tsx similarity index 93% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/DeploymentGettingStarted.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/DeploymentGettingStarted.tsx index 9cfa183e9..90386f7a4 100644 --- a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/DeploymentGettingStarted.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/DeploymentGettingStarted.tsx @@ -2,7 +2,7 @@ import { IconShip } from "@tabler/icons-react"; import { Button } from "@ctrlplane/ui/button"; -import { CreateDeploymentDialog } from "../../../_components/CreateDeployment"; +import { CreateDeploymentDialog } from "../../../../_components/CreateDeployment"; export const DeploymentGettingStarted: React.FC<{ systemId: string }> = ({ systemId, diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/ReleaseDropdownMenu.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/ReleaseDropdownMenu.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/ReleaseDropdownMenu.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/ReleaseDropdownMenu.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/TableCells.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/TableCells.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/TableCells.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/TableCells.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/TableDeployments.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/TableDeployments.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/TableDeployments.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/TableDeployments.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/DeploymentNavBar.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/DeploymentNavBar.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/DeploymentNavBar.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/DeploymentNavBar.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/EditDeploymentSection.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/EditDeploymentSection.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/EditDeploymentSection.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/EditDeploymentSection.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/JobAgentSection.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/JobAgentSection.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/JobAgentSection.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/JobAgentSection.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/NavigationMenuAction.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/NavigationMenuAction.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/NavigationMenuAction.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/NavigationMenuAction.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/NavigationMenuTab.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/NavigationMenuTab.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/NavigationMenuTab.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/NavigationMenuTab.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/SettingsSidebar.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/SettingsSidebar.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/SettingsSidebar.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/SettingsSidebar.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/configure/job-agent/JobAgentConfigForm.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/configure/job-agent/JobAgentConfigForm.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/configure/job-agent/JobAgentConfigForm.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/configure/job-agent/JobAgentConfigForm.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/configure/job-agent/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/configure/job-agent/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/configure/job-agent/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/configure/job-agent/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/CreateHookDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/CreateHookDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/CreateHookDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/CreateHookDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/DeleteHookDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/DeleteHookDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/DeleteHookDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/DeleteHookDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/EditHookDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/EditHookDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/EditHookDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/EditHookDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/HookActionsDropdown.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/HookActionsDropdown.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/HookActionsDropdown.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/HookActionsDropdown.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/HooksTable.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/HooksTable.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/HooksTable.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/HooksTable.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/hooks/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/layout.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/layout.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/layout.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/layout.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/release-channels/CreateReleaseChannelDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/release-channels/CreateReleaseChannelDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/release-channels/CreateReleaseChannelDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/release-channels/CreateReleaseChannelDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/release-channels/ReleaseChannelsTable.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/release-channels/ReleaseChannelsTable.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/release-channels/ReleaseChannelsTable.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/release-channels/ReleaseChannelsTable.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/release-channels/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/release-channels/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/release-channels/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/release-channels/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/CreateVariableDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/CreateVariableDialog.tsx similarity index 98% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/CreateVariableDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/CreateVariableDialog.tsx index fd6d3d6ac..5e40557b4 100644 --- a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/CreateVariableDialog.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/CreateVariableDialog.tsx @@ -34,7 +34,7 @@ import { ConfigTypeSelector, NumberConfigFields, StringConfigFields, -} from "~/app/[workspaceSlug]/systems/[systemSlug]/_components/variables/ConfigFields"; +} from "~/app/[workspaceSlug]/(app)/systems/[systemSlug]/_components/variables/ConfigFields"; import { api } from "~/trpc/react"; const schema = z.object({ diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/DeploymentPageContent.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/DeploymentPageContent.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/DeploymentPageContent.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/DeploymentPageContent.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/ReleaseDistributionBarChart.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/ReleaseDistributionBarChart.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/ReleaseDistributionBarChart.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/ReleaseDistributionBarChart.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/ReleaseDistributionPopover.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/ReleaseDistributionPopover.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/ReleaseDistributionPopover.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/ReleaseDistributionPopover.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/FlowDiagram.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/FlowDiagram.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/FlowDiagram.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/FlowDiagram.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/FlowNode.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/FlowNode.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/FlowNode.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/FlowNode.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/FlowPolicyNode.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/FlowPolicyNode.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/FlowPolicyNode.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/FlowPolicyNode.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/JobDropdownMenu.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/JobDropdownMenu.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/JobDropdownMenu.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/JobDropdownMenu.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/JobsTable.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/JobsTable.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/JobsTable.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/JobsTable.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/PolicyApprovalRow.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/PolicyApprovalRow.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/PolicyApprovalRow.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/PolicyApprovalRow.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/ReleaseSequencingNode.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/ReleaseSequencingNode.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/ReleaseSequencingNode.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/ReleaseSequencingNode.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/TargetReleaseTable.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/TargetReleaseTable.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/TargetReleaseTable.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/TargetReleaseTable.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/TriggerNode.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/TriggerNode.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/TriggerNode.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/TriggerNode.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/useReleaseChannel.ts b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/useReleaseChannel.ts similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/useReleaseChannel.ts rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/useReleaseChannel.ts diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/targets/[targetId]/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/targets/[targetId]/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/targets/[targetId]/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/targets/[targetId]/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/targets/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/targets/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/targets/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/targets/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/AddVariableValueDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/AddVariableValueDialog.tsx similarity index 98% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/AddVariableValueDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/AddVariableValueDialog.tsx index 41ad1a441..3c84d5429 100644 --- a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/AddVariableValueDialog.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/AddVariableValueDialog.tsx @@ -36,7 +36,7 @@ import { VariableBooleanInput, VariableChoiceSelect, VariableStringInput, -} from "~/app/[workspaceSlug]/systems/[systemSlug]/_components/variables/VariableInputs"; +} from "~/app/[workspaceSlug]/(app)/systems/[systemSlug]/_components/variables/VariableInputs"; import { api } from "~/trpc/react"; const schema = z.object({ diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/EditVariableDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/EditVariableDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/EditVariableDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/EditVariableDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/VariableDropdown.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/VariableDropdown.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/VariableDropdown.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/VariableDropdown.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/VariableTable.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/VariableTable.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/VariableTable.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/VariableTable.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/VariableValueDropdown.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/VariableValueDropdown.tsx similarity index 98% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/VariableValueDropdown.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/VariableValueDropdown.tsx index 2e5aa0ef9..19592fc66 100644 --- a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/VariableValueDropdown.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/VariableValueDropdown.tsx @@ -53,7 +53,7 @@ import { VariableBooleanInput, VariableChoiceSelect, VariableStringInput, -} from "~/app/[workspaceSlug]/systems/[systemSlug]/_components/variables/VariableInputs"; +} from "~/app/[workspaceSlug]/(app)/systems/[systemSlug]/_components/variables/VariableInputs"; import { api } from "~/trpc/react"; const editVariableValueFormSchema = z.object({ diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/variable-data.ts b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/variable-data.ts similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/variables/variable-data.ts rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/variables/variable-data.ts diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/status-color.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/status-color.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/deployments/status-color.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/status-color.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/DeleteNodeDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/DeleteNodeDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/DeleteNodeDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/DeleteNodeDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/EnvFlowBuilder.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/EnvFlowBuilder.tsx similarity index 98% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/EnvFlowBuilder.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/EnvFlowBuilder.tsx index 2638f063b..d9524b4a1 100644 --- a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/EnvFlowBuilder.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/EnvFlowBuilder.tsx @@ -31,7 +31,7 @@ import { } from "~/app/[workspaceSlug]/_components/reactflow/edges"; import { getLayoutedElementsDagre } from "~/app/[workspaceSlug]/_components/reactflow/layout"; import { api } from "~/trpc/react"; -import { useEnvironmentPolicyDrawer } from "../../../_components/environment-policy-drawer/EnvironmentPolicyDrawer"; +import { useEnvironmentPolicyDrawer } from "../../../../_components/environment-policy-drawer/EnvironmentPolicyDrawer"; import { useDeleteNodeDialog } from "./DeleteNodeDialog"; import { useHandleEdgeDelete, useOnEdgeClick } from "./edges"; import { EnvFlowPanel } from "./EnvFlowPanel"; diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/EnvFlowPanel.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/EnvFlowPanel.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/EnvFlowPanel.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/EnvFlowPanel.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/FlowNodeTypes.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/FlowNodeTypes.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/FlowNodeTypes.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/FlowNodeTypes.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/SidepanelContext.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/SidepanelContext.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/SidepanelContext.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/SidepanelContext.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/TargetFilterUniquenessIndicator.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/TargetFilterUniquenessIndicator.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/TargetFilterUniquenessIndicator.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/TargetFilterUniquenessIndicator.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/[environmentId]/TargetCharts.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/[environmentId]/TargetCharts.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/[environmentId]/TargetCharts.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/[environmentId]/TargetCharts.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/[environmentId]/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/[environmentId]/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/[environmentId]/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/[environmentId]/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/edges.ts b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/edges.ts similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/edges.ts rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/edges.ts diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/layout.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/layout.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/layout.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/layout.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/useMatchSorter.ts b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/useMatchSorter.ts similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/environments/useMatchSorter.ts rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/environments/useMatchSorter.ts diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/EditRunbookDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/EditRunbookDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/EditRunbookDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/EditRunbookDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/RunbookGettingStarted.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/RunbookGettingStarted.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/RunbookGettingStarted.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/RunbookGettingStarted.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/RunbookRow.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/RunbookRow.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/RunbookRow.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/RunbookRow.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/TriggerRunbook.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/TriggerRunbook.tsx similarity index 97% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/TriggerRunbook.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/TriggerRunbook.tsx index e1718f7ac..e36770684 100644 --- a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/TriggerRunbook.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/TriggerRunbook.tsx @@ -24,7 +24,7 @@ import { VariableChoiceSelect, VariableStringInput, VariableTargetInput, -} from "~/app/[workspaceSlug]/systems/[systemSlug]/_components/variables/VariableInputs"; +} from "~/app/[workspaceSlug]/(app)/systems/[systemSlug]/_components/variables/VariableInputs"; import { api } from "~/trpc/react"; export type TriggerRunbookDialogProps = { diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/create/CreateRunbookForm.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/create/CreateRunbookForm.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/create/CreateRunbookForm.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/create/CreateRunbookForm.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/create/RunbookVariableEditor.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/create/RunbookVariableEditor.tsx similarity index 98% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/create/RunbookVariableEditor.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/create/RunbookVariableEditor.tsx index 5b2431109..53e95b38b 100644 --- a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/create/RunbookVariableEditor.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/create/RunbookVariableEditor.tsx @@ -30,7 +30,7 @@ import { RunbookConfigTypeSelector, StringConfigFields, TargetConfigFields, -} from "~/app/[workspaceSlug]/systems/[systemSlug]/_components/variables/ConfigFields"; +} from "~/app/[workspaceSlug]/(app)/systems/[systemSlug]/_components/variables/ConfigFields"; type RunbookVariableEditorProps = { value: InsertRunbookVariable; diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/create/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/create/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/create/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/create/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/runbooks/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/runbooks/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/variable-sets/CreateVariableSetDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/variable-sets/CreateVariableSetDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/variable-sets/CreateVariableSetDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/variable-sets/CreateVariableSetDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/variable-sets/GettingStartedVariableSets.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/variable-sets/GettingStartedVariableSets.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/variable-sets/GettingStartedVariableSets.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/variable-sets/GettingStartedVariableSets.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/variable-sets/VariableSetsTable.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/variable-sets/VariableSetsTable.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/variable-sets/VariableSetsTable.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/variable-sets/VariableSetsTable.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/variable-sets/[variableSetId]/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/variable-sets/[variableSetId]/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/variable-sets/[variableSetId]/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/variable-sets/[variableSetId]/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/variable-sets/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/variable-sets/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/[systemSlug]/variable-sets/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/[systemSlug]/variable-sets/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/systems/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/systems/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/systems/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/terminal/Terminal.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/terminal/Terminal.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/terminal/Terminal.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/terminal/Terminal.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/terminal/page.tsx b/apps/webservice/src/app/[workspaceSlug]/(app)/terminal/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/terminal/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/(app)/terminal/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/SidebarContext.tsx b/apps/webservice/src/app/[workspaceSlug]/SidebarContext.tsx deleted file mode 100644 index 24e43b52f..000000000 --- a/apps/webservice/src/app/[workspaceSlug]/SidebarContext.tsx +++ /dev/null @@ -1,15 +0,0 @@ -"use client"; - -import { createContext, useContext } from "react"; - -type SidebarContextType = { - activeSidebarItem: string | null; - setActiveSidebarItem: (item: string | null) => void; -}; - -export const SidebarContext = createContext({ - activeSidebarItem: null, - setActiveSidebarItem: () => {}, -}); - -export const useSidebar = () => useContext(SidebarContext); diff --git a/apps/webservice/src/app/[workspaceSlug]/SidebarLink.tsx b/apps/webservice/src/app/[workspaceSlug]/SidebarLink.tsx deleted file mode 100644 index c3db604cf..000000000 --- a/apps/webservice/src/app/[workspaceSlug]/SidebarLink.tsx +++ /dev/null @@ -1,40 +0,0 @@ -"use client"; - -import Link from "next/link"; -import { usePathname } from "next/navigation"; - -import { cn } from "@ctrlplane/ui"; - -import { useSidebar } from "./SidebarContext"; - -export const SidebarLink: React.FC<{ - href: string; - children: React.ReactNode; - exact?: boolean; - className?: string; - hideActiveEffect?: boolean; -}> = ({ href, exact, children, className, hideActiveEffect }) => { - const { setActiveSidebarItem } = useSidebar(); - const pathname = usePathname(); - const active = hideActiveEffect - ? false - : exact - ? pathname === href - : pathname.startsWith(href); - return ( - { - console.log("setting null"); - setActiveSidebarItem(null); - }} - className={cn( - className, - active ? "bg-neutral-800/70" : "hover:bg-neutral-800/50", - "flex items-center gap-2 rounded-md px-2 py-1", - )} - > - {children} - - ); -}; diff --git a/apps/webservice/src/app/[workspaceSlug]/SidebarMain.tsx b/apps/webservice/src/app/[workspaceSlug]/SidebarMain.tsx deleted file mode 100644 index d7ecbb2a1..000000000 --- a/apps/webservice/src/app/[workspaceSlug]/SidebarMain.tsx +++ /dev/null @@ -1,67 +0,0 @@ -"use client"; - -import type { System, Workspace } from "@ctrlplane/db/schema"; -import { useParams } from "next/navigation"; -import { IconSearch } from "@tabler/icons-react"; - -import { Button } from "@ctrlplane/ui/button"; - -import { api } from "~/trpc/react"; -import { SearchDialog } from "./Search"; -import { SidebarCreateMenu } from "./SidebarCreateMenu"; -import { SidebarSystems } from "./SidebarSystems"; -import { SidebarWorkspace } from "./SidebarWorkspace"; -import { SidebarWorkspaceDropdown } from "./SidebarWorkspaceDropdown"; - -export const SidebarMain: React.FC<{ - workspace: Workspace; - systems: System[]; -}> = ({ workspace, systems }) => { - const { deploymentSlug, workspaceSlug, systemSlug } = useParams<{ - workspaceSlug: string; - systemSlug?: string; - deploymentSlug?: string; - }>(); - - const system = systems.find((s) => s.slug === systemSlug); - const deployment = api.deployment.bySlug.useQuery( - { - workspaceSlug, - systemSlug: systemSlug ?? "", - deploymentSlug: deploymentSlug ?? "", - }, - { enabled: deploymentSlug != null && systemSlug != null }, - ); - - return ( -
-
-
-
- -
- - - - - - -
-
- - - - -
- ); -}; diff --git a/apps/webservice/src/app/[workspaceSlug]/SidebarNavMain.tsx b/apps/webservice/src/app/[workspaceSlug]/SidebarNavMain.tsx new file mode 100644 index 000000000..2f09a9fcd --- /dev/null +++ b/apps/webservice/src/app/[workspaceSlug]/SidebarNavMain.tsx @@ -0,0 +1,127 @@ +"use client"; + +import { useState } from "react"; +import Link from "next/link"; +import { usePathname } from "next/navigation"; +import { IconChevronRight } from "@tabler/icons-react"; + +import { + Collapsible, + CollapsibleContent, + CollapsibleTrigger, +} from "@ctrlplane/ui/collapsible"; +import { + SidebarGroup, + SidebarGroupLabel, + SidebarMenu, + SidebarMenuAction, + SidebarMenuButton, + SidebarMenuSub, + SidebarMenuSubButton, +} from "@ctrlplane/ui/sidebar"; + +import { + SidebarMenuItemWithPopover, + SidebarMenuSubItemWithPopover, + useSidebarPopover, +} from "./(app)/AppSidebarPopoverContext"; + +type SubItem = { + popoverId?: string; + icon?: any; + title: string; + url: string; + exact?: boolean; +}; + +type MainItem = { + popoverId?: string; + title: string; + url?: string; + icon?: any; + isOpen?: boolean; + items?: SubItem[]; +}; + +const SidebarSubItem: React.FC<{ item: SubItem }> = ({ item }) => { + const pathname = usePathname(); + const { setActiveSidebarItem } = useSidebarPopover(); + return ( + + + { + setActiveSidebarItem(null); + }} + > + {item.icon && } + {item.title} + + + + ); +}; + +const SidebarItem: React.FC<{ item: MainItem }> = ({ item }) => { + const [open, setOpen] = useState(item.isOpen); + return ( + + + {item.url ? ( + + + {item.icon && } + {item.title} + + + ) : ( + setOpen(!open)} + > +
+ {item.icon && } + {item.title} +
+
+ )} + {item.items?.length ? ( + <> + + + + Toggle + + + + + {item.items.map((subItem) => ( + + ))} + + + + ) : null} +
+
+ ); +}; + +export const SidebarNavMain: React.FC<{ + title: string; + items: MainItem[]; +}> = ({ title, items }) => { + return ( + + {title} + + {items.map((item) => ( + + ))} + + + ); +}; diff --git a/apps/webservice/src/app/[workspaceSlug]/SidebarPanels.tsx b/apps/webservice/src/app/[workspaceSlug]/SidebarPanels.tsx deleted file mode 100644 index 21c4ed41d..000000000 --- a/apps/webservice/src/app/[workspaceSlug]/SidebarPanels.tsx +++ /dev/null @@ -1,89 +0,0 @@ -"use client"; - -import type { System, Workspace } from "@ctrlplane/db/schema"; -import React, { useState } from "react"; -import { usePathname } from "next/navigation"; - -import { Popover, PopoverContent, PopoverTrigger } from "@ctrlplane/ui/popover"; -import { - ResizableHandle, - ResizablePanel, - ResizablePanelGroup, -} from "@ctrlplane/ui/resizable"; - -import { SidebarContext } from "./SidebarContext"; -import { SidebarMain } from "./SidebarMain"; -import { SidebarPopoverSystem } from "./SidebarPopoverSystem"; -import { SidebarPopoverTargets } from "./SidebarPopoverTargets"; -import { SidebarSettings } from "./SidebarSettings"; - -export const SidebarPanels: React.FC<{ - children: React.ReactNode; - workspace: Workspace; - systems: System[]; -}> = ({ children, systems, workspace }) => { - const pathname = usePathname(); - const isSettingsPage = pathname.includes("/settings"); - const [open, setOpen] = useState(false); - const [activeSidebarItem, setActiveSidebarItem] = useState( - null, - ); - - return ( - - - - e.preventDefault()} - className="focus-visible:outline-none" - > - setOpen(true)} - > -
- {isSettingsPage ? ( - - ) : ( - - )} -
-
-
- - {activeSidebarItem === "targets" && ( - - )} - {activeSidebarItem?.startsWith("systems:") && ( - - )} - -
- - - { - setOpen(false); - setActiveSidebarItem(null); - }} - > - {children} - -
{" "} -
- ); -}; diff --git a/apps/webservice/src/app/[workspaceSlug]/SidebarPopoverSystem.tsx b/apps/webservice/src/app/[workspaceSlug]/SidebarPopoverSystem.tsx deleted file mode 100644 index 804c0aad7..000000000 --- a/apps/webservice/src/app/[workspaceSlug]/SidebarPopoverSystem.tsx +++ /dev/null @@ -1,51 +0,0 @@ -"use client"; - -import type { Workspace } from "@ctrlplane/db/schema"; - -import { api } from "~/trpc/react"; -import { SidebarLink } from "./SidebarLink"; - -export const SidebarPopoverSystem: React.FC<{ - systemId: string; - workspace: Workspace; -}> = ({ workspace, systemId }) => { - const system = api.system.byId.useQuery(systemId); - const environments = api.environment.bySystemId.useQuery(systemId); - const deployments = api.deployment.bySystemId.useQuery(systemId); - return ( -
-
{system.data?.name}
- -
-
- Environments -
-
- {environments.data?.map(({ name }) => ( - - {name} - - ))} -
-
- -
-
- Deployments -
-
- {deployments.data?.map(({ id, name, slug }) => ( - - {name} - - ))} -
-
-
- ); -}; diff --git a/apps/webservice/src/app/[workspaceSlug]/SidebarPopoverTargets.tsx b/apps/webservice/src/app/[workspaceSlug]/SidebarPopoverTargets.tsx deleted file mode 100644 index 119631da4..000000000 --- a/apps/webservice/src/app/[workspaceSlug]/SidebarPopoverTargets.tsx +++ /dev/null @@ -1,125 +0,0 @@ -"use client"; - -import type { Workspace } from "@ctrlplane/db/schema"; -import { usePathname } from "next/navigation"; -import { IconBookmark } from "@tabler/icons-react"; -import LZString from "lz-string"; - -import { Badge } from "@ctrlplane/ui/badge"; -import { - ComparisonOperator, - FilterType, -} from "@ctrlplane/validators/conditions"; -import { ResourceFilterType } from "@ctrlplane/validators/resources"; - -import { api } from "~/trpc/react"; -import { TargetIcon } from "./_components/TargetIcon"; -import { SidebarLink } from "./SidebarLink"; - -export const SidebarPopoverTargets: React.FC<{ workspace: Workspace }> = ({ - workspace, -}) => { - const pathname = usePathname(); - const kinds = api.workspace.resourceKinds.useQuery(workspace.id); - - const views = api.resource.view.list.useQuery(workspace.id); - const viewsWithHash = views.data?.map((view) => ({ - ...view, - hash: LZString.compressToEncodedURIComponent(JSON.stringify(view.filter)), - })); - - const recentlyAdded = api.resource.byWorkspaceId.list.useQuery({ - workspaceId: workspace.id, - orderBy: [{ property: "createdAt", direction: "desc" }], - limit: 5, - }); - - const totalTargets = - (recentlyAdded.data?.total ?? 0) - (recentlyAdded.data?.items.length ?? 0); - - return ( -
-
Targets
- -
-
- Saved Views -
-
-
- No saved filters found. -
- {viewsWithHash != null && viewsWithHash.length > 0 && ( - <> - {viewsWithHash.map(({ id, name, hash }) => ( - - - {name} - - ))} - - )} -
-
- -
-
- Kinds -
-
- {kinds.data?.map(({ version, kind, count }) => ( - - - {kind} - - {count} - - - ))} -
-
- -
-
- Recently Added Targets -
-
- {recentlyAdded.data?.items.map((resource) => ( - - {resource.name} - - ))} - {totalTargets > 0 && ( -
- +{totalTargets} other targets -
- )} -
-
-
- ); -}; diff --git a/apps/webservice/src/app/[workspaceSlug]/SidebarSettings.tsx b/apps/webservice/src/app/[workspaceSlug]/SidebarSettings.tsx deleted file mode 100644 index 14fa4b3c8..000000000 --- a/apps/webservice/src/app/[workspaceSlug]/SidebarSettings.tsx +++ /dev/null @@ -1,75 +0,0 @@ -import Link from "next/link"; -import { IconBuilding, IconChevronLeft, IconUser } from "@tabler/icons-react"; - -import { SidebarLink } from "./SidebarLink"; - -const WorkspaceSettings: React.FC<{ workspaceSlug: string }> = ({ - workspaceSlug, -}) => { - return ( -
-
- Workspace -
- -
- - Overview - - - General - - - Members - - - Integrations - -
-
- ); -}; - -const AccountSettings: React.FC<{ workspaceSlug: string }> = ({ - workspaceSlug, -}) => { - return ( -
-
- My account -
- -
- - Profile - - - API - -
-
- ); -}; - -export const SidebarSettings: React.FC<{ workspaceSlug: string }> = ({ - workspaceSlug, -}) => { - return ( -
-
- -
- -
-
Settings
- -
- - - -
- ); -}; diff --git a/apps/webservice/src/app/[workspaceSlug]/SidebarSystems.tsx b/apps/webservice/src/app/[workspaceSlug]/SidebarSystems.tsx deleted file mode 100644 index 2e26ef95a..000000000 --- a/apps/webservice/src/app/[workspaceSlug]/SidebarSystems.tsx +++ /dev/null @@ -1,108 +0,0 @@ -"use client"; - -import type { System, Workspace } from "@ctrlplane/db/schema"; -import { useState } from "react"; -import { useParams } from "next/navigation"; -import { - IconChevronRight, - IconPlant, - IconPlus, - IconRun, - IconShip, - IconVariable, -} from "@tabler/icons-react"; -import _ from "lodash"; -import { useLocalStorage } from "react-use"; - -import { cn } from "@ctrlplane/ui"; -import { Button } from "@ctrlplane/ui/button"; -import { - Collapsible, - CollapsibleContent, - CollapsibleTrigger, -} from "@ctrlplane/ui/collapsible"; - -import { CreateSystemDialog } from "./_components/CreateSystem"; -import { useSidebar } from "./SidebarContext"; -import { SidebarLink } from "./SidebarLink"; - -const SystemCollapsible: React.FC<{ system: System }> = ({ system }) => { - const { setActiveSidebarItem } = useSidebar(); - const [open, setOpen] = useLocalStorage( - `sidebar-systems-${system.id}`, - "false", - ); - const { workspaceSlug } = useParams<{ workspaceSlug: string }>(); - return ( - setOpen(open === "true" ? "false" : "true")} - className="space-y-1 text-sm" - onMouseEnter={() => setActiveSidebarItem(`systems:${system.id}`)} - > - - {system.name} - - - - - Deployments - - - Environments - - - Runbooks - - - Variable - Sets - - - - ); -}; - -export const SidebarSystems: React.FC<{ - workspace: Workspace; - systems: System[]; -}> = ({ workspace, systems }) => { - const [open, setOpen] = useState(true); - return ( - - - Your systems - - - - {systems.length === 0 && ( - - - - )} - {systems.map((system) => ( - - ))} - - - ); -}; diff --git a/apps/webservice/src/app/[workspaceSlug]/SidebarWorkspace.tsx b/apps/webservice/src/app/[workspaceSlug]/SidebarWorkspace.tsx deleted file mode 100644 index a27c148f3..000000000 --- a/apps/webservice/src/app/[workspaceSlug]/SidebarWorkspace.tsx +++ /dev/null @@ -1,87 +0,0 @@ -"use client"; - -import { useState } from "react"; -import { useParams } from "next/navigation"; -import { - IconCategory, - IconChevronRight, - IconRocket, - IconTarget, -} from "@tabler/icons-react"; - -import { cn } from "@ctrlplane/ui"; -import { - Collapsible, - CollapsibleContent, - CollapsibleTrigger, -} from "@ctrlplane/ui/collapsible"; - -import { useSidebar } from "./SidebarContext"; -import { SidebarLink } from "./SidebarLink"; - -export const SidebarWorkspace: React.FC = () => { - const [open, setOpen] = useState(true); - const { workspaceSlug } = useParams<{ workspaceSlug: string }>(); - const { setActiveSidebarItem } = useSidebar(); - return ( - - - Workspace - - - - {/* - Dashboard - */} - - Systems - -
-
- - Dependencies - -
-
- -
setActiveSidebarItem("targets")}> - - Targets - -
-
- List - - Providers - - - Groups - - - Views - -
-
-
- -
- - Jobs - -
-
- - Agents - - - Triggered - -
-
-
-
-
- ); -}; diff --git a/apps/webservice/src/app/[workspaceSlug]/Search.tsx b/apps/webservice/src/app/[workspaceSlug]/_components/SearchDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/Search.tsx rename to apps/webservice/src/app/[workspaceSlug]/_components/SearchDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/_components/job-drawer/JobDrawer.tsx b/apps/webservice/src/app/[workspaceSlug]/_components/job-drawer/JobDrawer.tsx index bc694a9c8..5903915fa 100644 --- a/apps/webservice/src/app/[workspaceSlug]/_components/job-drawer/JobDrawer.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/_components/job-drawer/JobDrawer.tsx @@ -13,8 +13,8 @@ import { Button, buttonVariants } from "@ctrlplane/ui/button"; import { Drawer, DrawerContent, DrawerTitle } from "@ctrlplane/ui/drawer"; import { ReservedMetadataKey } from "@ctrlplane/validators/conditions"; -import { JobDropdownMenu } from "~/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/JobDropdownMenu"; -import { useReleaseChannel } from "~/app/[workspaceSlug]/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/useReleaseChannel"; +import { JobDropdownMenu } from "~/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/JobDropdownMenu"; +import { useReleaseChannel } from "~/app/[workspaceSlug]/(app)/systems/[systemSlug]/deployments/[deploymentSlug]/releases/[versionId]/useReleaseChannel"; import { api } from "~/trpc/react"; import { JobAgent } from "./JobAgent"; import { JobMetadata } from "./JobMetadata"; diff --git a/apps/webservice/src/app/[workspaceSlug]/layout.tsx b/apps/webservice/src/app/[workspaceSlug]/layout.tsx index bd579af9f..156ee8b96 100644 --- a/apps/webservice/src/app/[workspaceSlug]/layout.tsx +++ b/apps/webservice/src/app/[workspaceSlug]/layout.tsx @@ -1,56 +1,15 @@ -import dynamic from "next/dynamic"; -import { notFound, redirect } from "next/navigation"; +import { SidebarProvider } from "@ctrlplane/ui/sidebar"; -import { auth } from "@ctrlplane/auth"; - -import { api } from "~/trpc/server"; -import { EnvironmentDrawer } from "./_components/environment-drawer/EnvironmentDrawer"; -import { EnvironmentPolicyDrawer } from "./_components/environment-policy-drawer/EnvironmentPolicyDrawer"; -import { JobDrawer } from "./_components/job-drawer/JobDrawer"; -import { ReleaseChannelDrawer } from "./_components/release-channel-drawer/ReleaseChannelDrawer"; -import { ReleaseDrawer } from "./_components/release-drawer/ReleaseDrawer"; -import { TargetDrawer } from "./_components/target-drawer/TargetDrawer"; import { TerminalSessionsProvider } from "./_components/terminal/TerminalSessionsProvider"; -import { VariableSetDrawer } from "./_components/variable-set-drawer/VariableSetDrawer"; -import { SidebarPanels } from "./SidebarPanels"; - -const TerminalDrawer = dynamic( - () => import("./_components/terminal/TerminalSessionsDrawer"), - { ssr: false }, -); -export default async function WorkspaceLayout({ +export default function WorkspaceLayout({ children, - params, }: { children: React.ReactNode; - params: { workspaceSlug: string }; }) { - const session = await auth(); - if (session == null) redirect("/login"); - - const workspace = await api.workspace - .bySlug(params.workspaceSlug) - .catch(() => null); - - if (workspace == null) notFound(); - - const systems = await api.system.list({ workspaceId: workspace.id }); return ( - -
- - {children} - -
- - - - - - - - -
+ + {children} + ); } diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/layout.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/layout.tsx deleted file mode 100644 index dec54d55a..000000000 --- a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/layout.tsx +++ /dev/null @@ -1,7 +0,0 @@ -export default function AccountSettingsLayout({ - children, -}: { - children: React.ReactNode; -}) { - return
{children}
; -} diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/SettingsSidebar.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/SettingsSidebar.tsx new file mode 100644 index 000000000..9d9103304 --- /dev/null +++ b/apps/webservice/src/app/[workspaceSlug]/settings/SettingsSidebar.tsx @@ -0,0 +1,65 @@ +import type { Workspace } from "@ctrlplane/db/schema"; +import Link from "next/link"; +import { IconChevronLeft } from "@tabler/icons-react"; + +import { + Sidebar, + SidebarContent, + SidebarHeader, + SidebarMenuButton, +} from "@ctrlplane/ui/sidebar"; + +import { SidebarNavMain } from "../SidebarNavMain"; + +export const SettingsSidebar: React.FC<{ workspace: Workspace }> = ({ + workspace, +}) => { + return ( + + + + + + Settings + + + + + + + + + ); +}; diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/account/api/ApiSection.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/account/api/ApiSection.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/account/api/ApiSection.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/account/api/ApiSection.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/account/api/page.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/account/api/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/account/api/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/account/api/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/account/profile/GithubRedirectButton.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/account/profile/GithubRedirectButton.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/account/profile/GithubRedirectButton.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/account/profile/GithubRedirectButton.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/account/profile/page.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/account/profile/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/account/profile/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/account/profile/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/layout.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/layout.tsx new file mode 100644 index 000000000..aa81dfd6e --- /dev/null +++ b/apps/webservice/src/app/[workspaceSlug]/settings/layout.tsx @@ -0,0 +1,30 @@ +import { notFound, redirect } from "next/navigation"; + +import { auth } from "@ctrlplane/auth"; +import { SidebarInset } from "@ctrlplane/ui/sidebar"; + +import { api } from "~/trpc/server"; +import { SettingsSidebar } from "./SettingsSidebar"; + +type Props = { + children: React.ReactNode; + params: { workspaceSlug: string }; +}; + +export default async function AccountSettingsLayout({ + children, + params: { workspaceSlug }, +}: Props) { + const session = await auth(); + if (session == null) redirect("/login"); + + const workspace = await api.workspace.bySlug(workspaceSlug).catch(() => null); + if (workspace == null) notFound(); + + return ( + <> + + {children} + + ); +} diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/general/WorkspaceDeleteSection.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/general/WorkspaceDeleteSection.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/general/WorkspaceDeleteSection.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/general/WorkspaceDeleteSection.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/general/WorkspaceUpdateSection.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/general/WorkspaceUpdateSection.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/general/WorkspaceUpdateSection.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/general/WorkspaceUpdateSection.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/general/page.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/general/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/general/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/general/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/DeleteGithubUserButton.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/DeleteGithubUserButton.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/DeleteGithubUserButton.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/DeleteGithubUserButton.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/DisconnectDropdownActionButton.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/DisconnectDropdownActionButton.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/DisconnectDropdownActionButton.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/DisconnectDropdownActionButton.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/GithubAddOrgDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/GithubAddOrgDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/GithubAddOrgDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/GithubAddOrgDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/GithubConnectedOrgs.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/GithubConnectedOrgs.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/GithubConnectedOrgs.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/GithubConnectedOrgs.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/GithubRemoveOrgDialog.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/GithubRemoveOrgDialog.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/GithubRemoveOrgDialog.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/GithubRemoveOrgDialog.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/OrgActionDropdown.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/OrgActionDropdown.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/OrgActionDropdown.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/OrgActionDropdown.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/SelectPreconnectedOrgDialogContent.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/SelectPreconnectedOrgDialogContent.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/SelectPreconnectedOrgDialogContent.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/SelectPreconnectedOrgDialogContent.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/page.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/github/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/github/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/google/GoogleIntegration.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/google/GoogleIntegration.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/google/GoogleIntegration.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/google/GoogleIntegration.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/google/page.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/google/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/google/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/google/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/layout.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/layout.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/(integration)/layout.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/(integration)/layout.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/page.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/integrations/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/integrations/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/members/MembersExport.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/members/MembersExport.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/members/MembersExport.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/members/MembersExport.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/members/MembersTable.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/members/MembersTable.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/members/MembersTable.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/members/MembersTable.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/members/WorkspaceDomainMatching.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/members/WorkspaceDomainMatching.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/members/WorkspaceDomainMatching.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/members/WorkspaceDomainMatching.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/members/page.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/members/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/members/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/members/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/overview/page.tsx b/apps/webservice/src/app/[workspaceSlug]/settings/workspace/overview/page.tsx similarity index 100% rename from apps/webservice/src/app/[workspaceSlug]/settings/(settings)/workspace/overview/page.tsx rename to apps/webservice/src/app/[workspaceSlug]/settings/workspace/overview/page.tsx diff --git a/apps/webservice/src/app/[workspaceSlug]/systems/SystemFilter.tsx b/apps/webservice/src/app/[workspaceSlug]/systems/SystemFilter.tsx deleted file mode 100644 index 526d4ca08..000000000 --- a/apps/webservice/src/app/[workspaceSlug]/systems/SystemFilter.tsx +++ /dev/null @@ -1,3 +0,0 @@ -import type { Filter } from "../_components/filter/Filter"; - -export type SystemFilter = Filter<"name" | "slug", string>; diff --git a/apps/webservice/src/app/globals.css b/apps/webservice/src/app/globals.css index 068a498ef..84fce9a92 100644 --- a/apps/webservice/src/app/globals.css +++ b/apps/webservice/src/app/globals.css @@ -30,6 +30,15 @@ --chart-3: 197 37% 24%; --chart-4: 43 74% 66%; --chart-5: 27 87% 67%; + + --sidebar-background: 0 0% 98%; + --sidebar-foreground: 240 5.3% 26.1%; + --sidebar-primary: 240 5.9% 10%; + --sidebar-primary-foreground: 0 0% 98%; + --sidebar-accent: 240 4.8% 95.9%; + --sidebar-accent-foreground: 240 5.9% 10%; + --sidebar-border: 220 13% 91%; + --sidebar-ring: 217.2 91.2% 59.8%; } .dark { @@ -58,6 +67,15 @@ --chart-3: 30 80% 55%; --chart-4: 280 65% 60%; --chart-5: 340 75% 55%; + + --sidebar-background: 0 0% 0%; + --sidebar-foreground: 240 4.8% 95.9%; + --sidebar-primary: 224.3 76.3% 48%; + --sidebar-primary-foreground: 0 0% 100%; + --sidebar-accent: 240 3.7% 15.9%; + --sidebar-accent-foreground: 240 4.8% 95.9%; + --sidebar-border: 240 3.7% 15.9%; + --sidebar-ring: 217.2 91.2% 59.8%; } } @@ -72,3 +90,12 @@ scrollbar-width: none; /* Firefox */ } } + +@layer base { + * { + @apply border-border; + } + body { + @apply bg-background text-foreground; + } +} diff --git a/apps/webservice/tailwind.config.ts b/apps/webservice/tailwind.config.ts index 68bd41636..0a2ed5a00 100644 --- a/apps/webservice/tailwind.config.ts +++ b/apps/webservice/tailwind.config.ts @@ -14,6 +14,18 @@ export default { sans: ["var(--font-geist-sans)", ...fontFamily.sans], mono: ["var(--font-geist-mono)", ...fontFamily.mono], }, + colors: { + sidebar: { + DEFAULT: "hsl(var(--sidebar-background))", + foreground: "hsl(var(--sidebar-foreground))", + primary: "hsl(var(--sidebar-primary))", + "primary-foreground": "hsl(var(--sidebar-primary-foreground))", + accent: "hsl(var(--sidebar-accent))", + "accent-foreground": "hsl(var(--sidebar-accent-foreground))", + border: "hsl(var(--sidebar-border))", + ring: "hsl(var(--sidebar-ring))", + }, + }, }, }, plugins: [require("@tailwindcss/typography"), require("tailwind-scrollbar")], diff --git a/packages/job-dispatch/src/__test__/job-variables-deployment.test.ts b/packages/job-dispatch/src/__test__/job-variables-deployment.test.ts index 166b5f008..7d53cc443 100644 --- a/packages/job-dispatch/src/__test__/job-variables-deployment.test.ts +++ b/packages/job-dispatch/src/__test__/job-variables-deployment.test.ts @@ -62,6 +62,7 @@ const target: SCHEMA.Resource = { identifier: "test", providerId: "0", lockedAt: null, + createdAt: new Date(), }; const release: SCHEMA.Release = { diff --git a/packages/ui/package.json b/packages/ui/package.json index 580a90344..80c9dbebf 100644 --- a/packages/ui/package.json +++ b/packages/ui/package.json @@ -27,7 +27,7 @@ "@radix-ui/react-avatar": "^1.0.4", "@radix-ui/react-checkbox": "^1.0.4", "@radix-ui/react-collapsible": "^1.1.0", - "@radix-ui/react-dialog": "^1.0.5", + "@radix-ui/react-dialog": "^1.1.2", "@radix-ui/react-dropdown-menu": "^2.0.6", "@radix-ui/react-hover-card": "^1.0.7", "@radix-ui/react-icons": "^1.3.0", @@ -38,11 +38,11 @@ "@radix-ui/react-radio-group": "^1.1.3", "@radix-ui/react-scroll-area": "^1.0.5", "@radix-ui/react-select": "^2.0.0", - "@radix-ui/react-separator": "^1.0.3", + "@radix-ui/react-separator": "^1.1.0", "@radix-ui/react-slot": "^1.1.0", "@radix-ui/react-switch": "^1.1.0", "@radix-ui/react-tabs": "^1.1.0", - "@radix-ui/react-tooltip": "^1.1.1", + "@radix-ui/react-tooltip": "^1.1.3", "@tabler/icons-react": "^3.17.0", "class-variance-authority": "^0.7.0", "cmdk": "^1.0.0", @@ -55,6 +55,7 @@ "react-resizable-panels": "^2.0.20", "react-stately": "^3.31.1", "recharts": "^2.1.12", + "sidebar": "^1.0.2", "sonner": "^1.4.41", "tailwind-merge": "^2.3.0", "tailwindcss-animate": "^1.0.7", diff --git a/packages/ui/src/hooks/use-mobile.tsx b/packages/ui/src/hooks/use-mobile.tsx new file mode 100644 index 000000000..a93d58393 --- /dev/null +++ b/packages/ui/src/hooks/use-mobile.tsx @@ -0,0 +1,21 @@ +import * as React from "react"; + +const MOBILE_BREAKPOINT = 768; + +export function useIsMobile() { + const [isMobile, setIsMobile] = React.useState( + undefined, + ); + + React.useEffect(() => { + const mql = window.matchMedia(`(max-width: ${MOBILE_BREAKPOINT - 1}px)`); + const onChange = () => { + setIsMobile(window.innerWidth < MOBILE_BREAKPOINT); + }; + mql.addEventListener("change", onChange); + setIsMobile(window.innerWidth < MOBILE_BREAKPOINT); + return () => mql.removeEventListener("change", onChange); + }, []); + + return !!isMobile; +} diff --git a/packages/ui/src/sheet.tsx b/packages/ui/src/sheet.tsx new file mode 100644 index 000000000..dcac30a67 --- /dev/null +++ b/packages/ui/src/sheet.tsx @@ -0,0 +1,141 @@ +"use client"; + +import type { VariantProps } from "class-variance-authority"; +import * as React from "react"; +import * as SheetPrimitive from "@radix-ui/react-dialog"; +import { Cross2Icon } from "@radix-ui/react-icons"; +import { cva } from "class-variance-authority"; + +import { cn } from "./index"; + +const Sheet = SheetPrimitive.Root; + +const SheetTrigger = SheetPrimitive.Trigger; + +const SheetClose = SheetPrimitive.Close; + +const SheetPortal = SheetPrimitive.Portal; + +const SheetOverlay = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, ...props }, ref) => ( + +)); +SheetOverlay.displayName = SheetPrimitive.Overlay.displayName; + +const sheetVariants = cva( + "fixed z-50 gap-4 bg-background p-6 shadow-lg transition ease-in-out data-[state=closed]:duration-300 data-[state=open]:duration-500 data-[state=open]:animate-in data-[state=closed]:animate-out", + { + variants: { + side: { + top: "inset-x-0 top-0 border-b data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top", + bottom: + "inset-x-0 bottom-0 border-t data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom", + left: "inset-y-0 left-0 h-full w-3/4 border-r data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left sm:max-w-sm", + right: + "inset-y-0 right-0 h-full w-3/4 border-l data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right sm:max-w-sm", + }, + }, + defaultVariants: { + side: "right", + }, + }, +); + +interface SheetContentProps + extends React.ComponentPropsWithoutRef, + VariantProps {} + +const SheetContent = React.forwardRef< + React.ElementRef, + SheetContentProps +>(({ side = "right", className, children, ...props }, ref) => ( + + + + + + Close + + {children} + + +)); +SheetContent.displayName = SheetPrimitive.Content.displayName; + +const SheetHeader = ({ + className, + ...props +}: React.HTMLAttributes) => ( +
+); +SheetHeader.displayName = "SheetHeader"; + +const SheetFooter = ({ + className, + ...props +}: React.HTMLAttributes) => ( +
+); +SheetFooter.displayName = "SheetFooter"; + +const SheetTitle = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, ...props }, ref) => ( + +)); +SheetTitle.displayName = SheetPrimitive.Title.displayName; + +const SheetDescription = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, ...props }, ref) => ( + +)); +SheetDescription.displayName = SheetPrimitive.Description.displayName; + +export { + Sheet, + SheetPortal, + SheetOverlay, + SheetTrigger, + SheetClose, + SheetContent, + SheetHeader, + SheetFooter, + SheetTitle, + SheetDescription, +}; diff --git a/packages/ui/src/sidebar.tsx b/packages/ui/src/sidebar.tsx new file mode 100644 index 000000000..b9b7c0de3 --- /dev/null +++ b/packages/ui/src/sidebar.tsx @@ -0,0 +1,772 @@ +"use client"; + +import type { VariantProps } from "class-variance-authority"; +import * as React from "react"; +import { ViewVerticalIcon } from "@radix-ui/react-icons"; +import { Slot } from "@radix-ui/react-slot"; +import { cva } from "class-variance-authority"; + +import { Button } from "./button"; +import { useIsMobile } from "./hooks/use-mobile"; +import { cn } from "./index"; +import { Input } from "./input"; +import { Separator } from "./separator"; +import { Sheet, SheetContent } from "./sheet"; +import { Skeleton } from "./skeleton"; +import { + Tooltip, + TooltipContent, + TooltipProvider, + TooltipTrigger, +} from "./tooltip"; + +const SIDEBAR_COOKIE_NAME = "sidebar:state"; +const SIDEBAR_COOKIE_MAX_AGE = 60 * 60 * 24 * 7; +const SIDEBAR_WIDTH = "16rem"; +const SIDEBAR_WIDTH_MOBILE = "18rem"; +const SIDEBAR_WIDTH_ICON = "3rem"; +const SIDEBAR_KEYBOARD_SHORTCUT = "b"; + +type SidebarContext = { + state: "expanded" | "collapsed"; + open: boolean; + setOpen: (open: boolean) => void; + openMobile: boolean; + setOpenMobile: (open: boolean) => void; + isMobile: boolean; + toggleSidebar: () => void; +}; + +const SidebarContext = React.createContext(null); + +function useSidebar() { + const context = React.useContext(SidebarContext); + if (!context) { + throw new Error("useSidebar must be used within a SidebarProvider."); + } + + return context; +} + +const SidebarProvider = React.forwardRef< + HTMLDivElement, + React.ComponentProps<"div"> & { + defaultOpen?: boolean; + open?: boolean; + onOpenChange?: (open: boolean) => void; + } +>( + ( + { + defaultOpen = true, + open: openProp, + onOpenChange: setOpenProp, + className, + style, + children, + ...props + }, + ref, + ) => { + const isMobile = useIsMobile(); + const [openMobile, setOpenMobile] = React.useState(false); + + // This is the internal state of the sidebar. + // We use openProp and setOpenProp for control from outside the component. + const [_open, _setOpen] = React.useState(defaultOpen); + const open = openProp ?? _open; + const setOpen = React.useCallback( + (value: boolean | ((value: boolean) => boolean)) => { + const openState = typeof value === "function" ? value(open) : value; + if (setOpenProp) { + setOpenProp(openState); + } else { + _setOpen(openState); + } + + // This sets the cookie to keep the sidebar state. + document.cookie = `${SIDEBAR_COOKIE_NAME}=${openState}; path=/; max-age=${SIDEBAR_COOKIE_MAX_AGE}`; + }, + [setOpenProp, open], + ); + + // Helper to toggle the sidebar. + const toggleSidebar = React.useCallback(() => { + return isMobile + ? setOpenMobile((open) => !open) + : setOpen((open) => !open); + }, [isMobile, setOpen, setOpenMobile]); + + // Adds a keyboard shortcut to toggle the sidebar. + React.useEffect(() => { + const handleKeyDown = (event: KeyboardEvent) => { + if ( + event.key === SIDEBAR_KEYBOARD_SHORTCUT && + (event.metaKey || event.ctrlKey) + ) { + event.preventDefault(); + toggleSidebar(); + } + }; + + window.addEventListener("keydown", handleKeyDown); + return () => window.removeEventListener("keydown", handleKeyDown); + }, [toggleSidebar]); + + // We add a state so that we can do data-state="expanded" or "collapsed". + // This makes it easier to style the sidebar with Tailwind classes. + const state = open ? "expanded" : "collapsed"; + + const contextValue = React.useMemo( + () => ({ + state, + open, + setOpen, + isMobile, + openMobile, + setOpenMobile, + toggleSidebar, + }), + [ + state, + open, + setOpen, + isMobile, + openMobile, + setOpenMobile, + toggleSidebar, + ], + ); + + return ( + + +
+ {children} +
+
+
+ ); + }, +); +SidebarProvider.displayName = "SidebarProvider"; + +const Sidebar = React.forwardRef< + HTMLDivElement, + React.ComponentProps<"div"> & { + side?: "left" | "right"; + variant?: "sidebar" | "floating" | "inset"; + collapsible?: "offcanvas" | "icon" | "none"; + } +>( + ( + { + side = "left", + variant = "sidebar", + collapsible = "offcanvas", + className, + children, + ...props + }, + ref, + ) => { + const { isMobile, state, openMobile, setOpenMobile } = useSidebar(); + + if (collapsible === "none") { + return ( +
+ {children} +
+ ); + } + + if (isMobile) { + return ( + + +
{children}
+
+
+ ); + } + + return ( +
+ {/* This is what handles the sidebar gap on desktop */} +
+ +
+ ); + }, +); +Sidebar.displayName = "Sidebar"; + +const SidebarTrigger = React.forwardRef< + React.ElementRef, + React.ComponentProps +>(({ className, onClick, ...props }, ref) => { + const { toggleSidebar } = useSidebar(); + + return ( + + ); +}); +SidebarTrigger.displayName = "SidebarTrigger"; + +const SidebarRail = React.forwardRef< + HTMLButtonElement, + React.ComponentProps<"button"> +>(({ className, ...props }, ref) => { + const { toggleSidebar } = useSidebar(); + + return ( +