openreplay/frontend/app/components/Onboarding/components/InstallOpenReplayTab/InstallOpenReplayTab.tsx
Delirium 8b52432a9a
fix(ui): onboarding design fixes (#1993)
* fix(ui): onboarding design fixes

* more stuff

* some assist details and options
2024-03-25 16:27:51 +01:00

89 lines
2.9 KiB
TypeScript

import React from 'react';
import OnboardingTabs from '../OnboardingTabs';
import MobileOnboardingTabs from '../OnboardingTabs/OnboardingMobileTabs';
import ProjectFormButton from '../ProjectFormButton';
import { Button, Icon } from 'UI';
import withOnboarding from '../withOnboarding';
import { WithOnboardingProps } from '../withOnboarding';
import { OB_TABS } from 'App/routes';
import withPageTitle from 'App/components/hocs/withPageTitle';
import { Segmented } from 'antd';
import { Button as AntButton } from 'antd'
interface Props extends WithOnboardingProps {
platforms: Array<{
label: string;
value: string;
}>;
platform: {
label: string;
value: string;
};
setPlatform: (val: { label: string; value: string }) => void;
platformMap: Record<string, any>
}
function InstallOpenReplayTab(props: Props) {
const { site, platforms, platform, setPlatform, platformMap } = props;
React.useEffect(() => {
if (site.platform)
setPlatform(platforms.find(({ value }) => value === platformMap[site.platform]) || platforms[0]);
}, [site]);
return (
<>
<h1 className="flex items-center px-4 py-3 border-b justify-between">
<div className="flex items-center text-2xl">
<span>👋</span>
<div className="ml-3 flex items-end">
<span>Hey there! Setup</span>
<ProjectFormButton />
</div>
</div>
<a href={"https://docs.openreplay.com/en/using-or/"} target="_blank">
<AntButton size={"small"} type={"text"} className="ml-2 flex items-center gap-2">
<Icon name={"question-circle"} />
<div className={"text-main"}>See Documentation</div>
</AntButton>
</a>
</h1>
<div className="p-4 flex gap-2 items-center">
<span className="font-medium">Project Type</span>
<Segmented
options={platforms}
value={platform.value}
onChange={(value) =>
setPlatform(platforms.find(({ value: v }) => v === value) || platforms[0])
}
/>
</div>
<div className="p-4">
{platform.value === 'web' ? <Snippet site={site} /> : <MobileOnboardingTabs site={site} />}
</div>
<div className="border-t px-4 py-3 flex justify-end">
<Button
variant="primary"
className=""
onClick={() => (props.navTo ? props.navTo(OB_TABS.IDENTIFY_USERS) : null)}
>
Identify Users
<Icon name="arrow-right-short" color="white" size={20} />
</Button>
</div>
</>
);
}
function Snippet({ site }: { site: Record<string, any> }) {
return (
<>
<div className="mb-6 text-lg font-medium">
Setup OpenReplay through NPM package <span className="text-sm">(recommended)</span> or
script.
</div>
<OnboardingTabs site={site} />
</>
);
}
export default withOnboarding(withPageTitle('Project Setup - OpenReplay')(InstallOpenReplayTab));