Closes #5097 - Uses "nx affected" to detect what projects need to be checked in the current PR (for now, `ci-front` and `ci-server` workflows only). - Caches results of certain tasks (`lint`, `typecheck`, `test`, `storybook:build`) when a PR pipeline runs. The next runs of the same PR's pipeline will then be able to reuse the PR's task cache to execute tasks faster. - Caches Yarn's cache folder to install dependencies faster in CI jobs. - Rewrites the node modules cache/install steps as a custom, reusable Github action. - Distributes `ci-front` jobs with a "matrix" strategy. - Sets common tasks config at the root `nx.json`. For instance, to activate the `typecheck` task in a project, add `typecheck: {}` to its `project.json` and it'll use the default config set in `nx.json` for the `typecheck` task. Options can be overridden in each individual `project.json` if needed. - Adds "scope" tags to some projects: `scope:frontend`, `scope:backend`, `scope:shared`. An eslint rule ensures that `scope:frontend` only depends on `scope:frontent` or `scope:shared` projects, same for `scope:backend`. These tags are used by `nx affected` to filter projects by scope and generates different task cache keys according to the requested scope. - Enables checks for twenty-emails in the `ci-server` workflow.
49 lines
1.5 KiB
TypeScript
49 lines
1.5 KiB
TypeScript
import { BaseEmail } from 'src/components/BaseEmail';
|
|
import { CallToAction } from 'src/components/CallToAction';
|
|
import { HighlightedText } from 'src/components/HighlightedText';
|
|
import { MainText } from 'src/components/MainText';
|
|
import { Title } from 'src/components/Title';
|
|
|
|
type CleanInactiveWorkspaceEmailProps = {
|
|
daysLeft: number;
|
|
userName: string;
|
|
workspaceDisplayName: string;
|
|
};
|
|
|
|
export const CleanInactiveWorkspaceEmail = ({
|
|
daysLeft,
|
|
userName,
|
|
workspaceDisplayName,
|
|
}: CleanInactiveWorkspaceEmailProps) => {
|
|
const dayOrDays = daysLeft > 1 ? 'days' : 'day';
|
|
const remainingDays = daysLeft > 1 ? `${daysLeft} ` : '';
|
|
|
|
const helloString = userName?.length > 1 ? `Hello ${userName}` : 'Hello';
|
|
|
|
return (
|
|
<BaseEmail>
|
|
<Title value="Inactive Workspace 😴" />
|
|
<HighlightedText value={`${daysLeft} ${dayOrDays} left`} />
|
|
<MainText>
|
|
{helloString},
|
|
<br />
|
|
<br />
|
|
It appears that there has been a period of inactivity on your{' '}
|
|
<b>{workspaceDisplayName}</b> workspace.
|
|
<br />
|
|
<br />
|
|
Please note that the account is due for deactivation soon, and all
|
|
associated data within this workspace will be deleted.
|
|
<br />
|
|
<br />
|
|
No need for concern, though! Simply create or edit a record within the
|
|
next {remainingDays}
|
|
{dayOrDays} to retain access.
|
|
</MainText>
|
|
<CallToAction href="https://app.twenty.com" value="Connect to Twenty" />
|
|
</BaseEmail>
|
|
);
|
|
};
|
|
|
|
export default CleanInactiveWorkspaceEmail;
|