mirror of
https://github.com/twentyhq/twenty
synced 2026-04-21 13:37:22 +00:00
# Introduction closes https://github.com/twentyhq/core-team-issues/issues/591 Same than for `twenty-shared` made in https://github.com/twentyhq/twenty/pull/11083. ## TODO - [x] Manual migrate twenty-website twenty-ui imports ## What's next: - Generate barrel and migration script factorization within own package + tests - Refactoring using preconstruct ? TimeBox - Lint circular dependencies - Lint import from barrel and forbid them ### Preconstruct We need custom rollup plugins addition, but preconstruct does not expose its rollup configuration. It might be possible to handle this using the babel overrides. But was a big tunnel. We could give it a try afterwards ! ( allowing cjs interop and stuff like that ) Stuck to vite lib app Closed related PRs: - https://github.com/twentyhq/twenty/pull/11294 - https://github.com/twentyhq/twenty/pull/11203
47 lines
1.5 KiB
TypeScript
47 lines
1.5 KiB
TypeScript
import { useSSO } from '@/auth/sign-in-up/hooks/useSSO';
|
|
import {
|
|
SignInUpStep,
|
|
signInUpStepState,
|
|
} from '@/auth/states/signInUpStepState';
|
|
import { workspaceAuthProvidersState } from '@/workspace/states/workspaceAuthProvidersState';
|
|
import { useTheme } from '@emotion/react';
|
|
import { useLingui } from '@lingui/react/macro';
|
|
import { useRecoilValue, useSetRecoilState } from 'recoil';
|
|
import { isDefined } from 'twenty-shared/utils';
|
|
import { HorizontalSeparator, IconLock } from 'twenty-ui/display';
|
|
import { MainButton } from 'twenty-ui/input';
|
|
|
|
export const SignInUpWithSSO = () => {
|
|
const theme = useTheme();
|
|
const { t } = useLingui();
|
|
const setSignInUpStep = useSetRecoilState(signInUpStepState);
|
|
const workspaceAuthProviders = useRecoilValue(workspaceAuthProvidersState);
|
|
|
|
const signInUpStep = useRecoilValue(signInUpStepState);
|
|
|
|
const { redirectToSSOLoginPage } = useSSO();
|
|
|
|
const signInWithSSO = () => {
|
|
if (
|
|
isDefined(workspaceAuthProviders) &&
|
|
workspaceAuthProviders.sso.length === 1
|
|
) {
|
|
return redirectToSSOLoginPage(workspaceAuthProviders.sso[0].id);
|
|
}
|
|
|
|
setSignInUpStep(SignInUpStep.SSOIdentityProviderSelection);
|
|
};
|
|
|
|
return (
|
|
<>
|
|
<MainButton
|
|
Icon={() => <IconLock size={theme.icon.size.md} />}
|
|
title={t`Single sign-on (SSO)`}
|
|
onClick={signInWithSSO}
|
|
variant={signInUpStep === SignInUpStep.Init ? undefined : 'secondary'}
|
|
fullWidth
|
|
/>
|
|
<HorizontalSeparator visible={false} />
|
|
</>
|
|
);
|
|
};
|