mirror of https://github.com/portainer/portainer
82 lines
2.2 KiB
TypeScript
82 lines
2.2 KiB
TypeScript
import { ArrowRight } from 'lucide-react';
|
|
import { useState } from 'react';
|
|
|
|
import { useAnalytics } from '@/angulartics.matomo/analytics-services';
|
|
import { useNodesCount } from '@/react/portainer/system/useNodesCount';
|
|
import {
|
|
ContainerPlatform,
|
|
useSystemInfo,
|
|
} from '@/react/portainer/system/useSystemInfo';
|
|
import { useUser } from '@/react/hooks/useUser';
|
|
import { withEdition } from '@/react/portainer/feature-flags/withEdition';
|
|
import { withHideOnExtension } from '@/react/hooks/withHideOnExtension';
|
|
|
|
import { useSidebarState } from '../useSidebarState';
|
|
|
|
import { UpgradeDialog } from './UpgradeDialog';
|
|
|
|
export const UpgradeBEBannerWrapper = withHideOnExtension(
|
|
withEdition(UpgradeBEBanner, 'CE')
|
|
);
|
|
|
|
const enabledPlatforms: Array<ContainerPlatform> = [
|
|
'Docker Standalone',
|
|
'Docker Swarm',
|
|
];
|
|
|
|
function UpgradeBEBanner() {
|
|
const { isAdmin } = useUser();
|
|
const { trackEvent } = useAnalytics();
|
|
const { isOpen: isSidebarOpen } = useSidebarState();
|
|
const nodesCountQuery = useNodesCount();
|
|
const systemInfoQuery = useSystemInfo();
|
|
|
|
const [isOpen, setIsOpen] = useState(false);
|
|
|
|
if (!nodesCountQuery.isSuccess || !systemInfoQuery.data) {
|
|
return null;
|
|
}
|
|
|
|
const nodesCount = nodesCountQuery.data;
|
|
const systemInfo = systemInfoQuery.data;
|
|
|
|
const metadata = {
|
|
upgrade: false,
|
|
nodeCount: nodesCount,
|
|
platform: systemInfo.platform,
|
|
edgeAgents: systemInfo.edgeAgents,
|
|
edgeDevices: systemInfo.edgeDevices,
|
|
agents: systemInfo.agents,
|
|
};
|
|
|
|
if (!enabledPlatforms.includes(systemInfo.platform)) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<>
|
|
<button
|
|
type="button"
|
|
className="border-0 bg-warning-5 text-warning-9 w-full py-2 font-semibold flex justify-center items-center gap-3"
|
|
onClick={handleClick}
|
|
>
|
|
{isSidebarOpen && <>Upgrade to Business Edition</>}
|
|
<ArrowRight className="text-lg lucide" />
|
|
</button>
|
|
|
|
{isOpen && <UpgradeDialog onDismiss={() => setIsOpen(false)} />}
|
|
</>
|
|
);
|
|
|
|
function handleClick() {
|
|
trackEvent(
|
|
isAdmin ? 'portainer-upgrade-admin' : 'portainer-upgrade-non-admin',
|
|
{
|
|
category: 'portainer',
|
|
metadata,
|
|
}
|
|
);
|
|
setIsOpen(true);
|
|
}
|
|
}
|