Some checks failed
Branch Build CE / Build Setup (push) Has been cancelled
Branch Build CE / Build-Push Admin Docker Image (push) Has been cancelled
Branch Build CE / Build-Push Web Docker Image (push) Has been cancelled
Branch Build CE / Build-Push Space Docker Image (push) Has been cancelled
Branch Build CE / Build-Push Live Collaboration Docker Image (push) Has been cancelled
Branch Build CE / Build-Push API Server Docker Image (push) Has been cancelled
Branch Build CE / Build-Push Proxy Docker Image (push) Has been cancelled
Branch Build CE / Build-Push AIO Docker Image (push) Has been cancelled
Branch Build CE / Upload Build Assets (push) Has been cancelled
Branch Build CE / Build Release (push) Has been cancelled
CodeQL / Analyze (javascript) (push) Has been cancelled
CodeQL / Analyze (python) (push) Has been cancelled
Codespell / Check for spelling errors (push) Has been cancelled
Sync Repositories / sync_changes (push) Has been cancelled
Synced from upstream: 8853637e981ed7d8a6cff32bd98e7afe20f54362
92 lines
3.4 KiB
TypeScript
92 lines
3.4 KiB
TypeScript
"use client";
|
|
|
|
import { useMemo, useState } from "react";
|
|
import { observer } from "mobx-react";
|
|
import { useParams } from "next/navigation";
|
|
// hooks
|
|
import { useIssueDetail } from "@/hooks/store/use-issue-detail";
|
|
import { usePowerK } from "@/hooks/store/use-power-k";
|
|
import { useUser } from "@/hooks/store/user";
|
|
import { useAppRouter } from "@/hooks/use-app-router";
|
|
// plane web imports
|
|
import { ProjectLevelModals } from "@/plane-web/components/command-palette/modals/project-level";
|
|
import { WorkItemLevelModals } from "@/plane-web/components/command-palette/modals/work-item-level";
|
|
import { WorkspaceLevelModals } from "@/plane-web/components/command-palette/modals/workspace-level";
|
|
// local imports
|
|
import { useProjectsAppPowerKCommands } from "./config/commands";
|
|
import type { TPowerKCommandConfig, TPowerKContext } from "./core/types";
|
|
import { GlobalShortcutsProvider } from "./global-shortcuts";
|
|
import { ProjectsAppPowerKCommandsList } from "./ui/modal/commands-list";
|
|
import { ProjectsAppPowerKModalWrapper } from "./ui/modal/wrapper";
|
|
|
|
/**
|
|
* Projects App PowerK provider
|
|
*/
|
|
export const ProjectsAppPowerKProvider = observer(() => {
|
|
// router
|
|
const router = useAppRouter();
|
|
const params = useParams();
|
|
const { workspaceSlug, projectId: routerProjectId, workItem: workItemIdentifier } = params;
|
|
// states
|
|
const [activeCommand, setActiveCommand] = useState<TPowerKCommandConfig | null>(null);
|
|
const [shouldShowContextBasedActions, setShouldShowContextBasedActions] = useState(true);
|
|
// store hooks
|
|
const { activeContext, isPowerKModalOpen, togglePowerKModal, setActivePage } = usePowerK();
|
|
const { data: currentUser } = useUser();
|
|
// derived values
|
|
const {
|
|
issue: { getIssueById, getIssueIdByIdentifier },
|
|
} = useIssueDetail();
|
|
// derived values
|
|
const workItemId = workItemIdentifier ? getIssueIdByIdentifier(workItemIdentifier.toString()) : undefined;
|
|
const workItemDetails = workItemId ? getIssueById(workItemId) : undefined;
|
|
const projectId: string | string[] | undefined | null = routerProjectId ?? workItemDetails?.project_id;
|
|
const commands = useProjectsAppPowerKCommands();
|
|
// Build command context from props and store
|
|
const context: TPowerKContext = useMemo(
|
|
() => ({
|
|
currentUserId: currentUser?.id,
|
|
activeCommand,
|
|
activeContext,
|
|
shouldShowContextBasedActions,
|
|
setShouldShowContextBasedActions,
|
|
params: {
|
|
...params,
|
|
projectId,
|
|
},
|
|
router,
|
|
closePalette: () => togglePowerKModal(false),
|
|
setActiveCommand,
|
|
setActivePage,
|
|
}),
|
|
[
|
|
currentUser?.id,
|
|
activeCommand,
|
|
activeContext,
|
|
shouldShowContextBasedActions,
|
|
params,
|
|
projectId,
|
|
router,
|
|
togglePowerKModal,
|
|
setActivePage,
|
|
]
|
|
);
|
|
|
|
return (
|
|
<>
|
|
<GlobalShortcutsProvider context={context} commands={commands} />
|
|
{workspaceSlug && <WorkspaceLevelModals workspaceSlug={workspaceSlug.toString()} />}
|
|
{workspaceSlug && projectId && (
|
|
<ProjectLevelModals workspaceSlug={workspaceSlug.toString()} projectId={projectId.toString()} />
|
|
)}
|
|
<WorkItemLevelModals workItemIdentifier={workItemIdentifier?.toString()} />
|
|
<ProjectsAppPowerKModalWrapper
|
|
commandsListComponent={ProjectsAppPowerKCommandsList}
|
|
context={context}
|
|
isOpen={isPowerKModalOpen}
|
|
onClose={() => togglePowerKModal(false)}
|
|
/>
|
|
</>
|
|
);
|
|
});
|