129 lines
4.9 KiB
TypeScript
129 lines
4.9 KiB
TypeScript
"use client";
|
|
|
|
import { useEffect, useRef } from "react";
|
|
import { useRouter } from "next/navigation";
|
|
import Rule from "../../../../components/cards/Rule";
|
|
import { useTranslation } from "../../../../contexts/MessagesContext";
|
|
import { CreateFlowHeaderLockup } from "../../components/CreateFlowHeaderLockup";
|
|
import { useCreateFlow } from "../../context/CreateFlowContext";
|
|
import { useCreateFlowLgUp } from "../../hooks/useCreateFlowLgUp";
|
|
import { CreateFlowStepShell } from "../../components/CreateFlowStepShell";
|
|
import {
|
|
CREATE_FLOW_MD_UP_GRID_CELL_CLASS,
|
|
CREATE_FLOW_TWO_COLUMN_MAX_WIDTH_CLASS,
|
|
} from "../../components/createFlowLayoutTokens";
|
|
import {
|
|
getAssetPath,
|
|
vectorMarkPath,
|
|
} from "../../../../../lib/assetUtils";
|
|
import { methodSectionsPinsForHydratedSelections } from "../../../../../lib/create/publishedDocumentToCreateFlowState";
|
|
import { createFlowStepPath } from "../../utils/createFlowPaths";
|
|
|
|
/** Create Community review — Figma `19706:12135` (`/create/review`; two columns from `lg:`; column caps in `createFlowLayoutTokens`). */
|
|
export function CommunityReviewScreen() {
|
|
const router = useRouter();
|
|
const lgUp = useCreateFlowLgUp();
|
|
const t = useTranslation("create.community.review");
|
|
const { state, updateState } = useCreateFlow();
|
|
|
|
/**
|
|
* If the user picked "Customize" or "Use without changes" from a template
|
|
* before entering community stage, we pinned `pendingTemplateAction` so
|
|
* this screen can skip itself — they already expressed their intent, no
|
|
* reason to make them re-pick from the review footer. We `replace` (not
|
|
* `push`) so Back from the destination goes to `community-save` instead of
|
|
* bouncing through here again. The action is cleared synchronously via
|
|
* `updateState` to guarantee the redirect only fires once: later visits to
|
|
* `/create/review` (e.g. navigating here directly) render normally.
|
|
*
|
|
* Ref guard covers React 18 StrictMode's double-mount in dev so we don't
|
|
* fire `router.replace` twice on the same transition.
|
|
*/
|
|
const firedRedirectRef = useRef(false);
|
|
useEffect(() => {
|
|
if (firedRedirectRef.current) return;
|
|
const pending = state.pendingTemplateAction;
|
|
if (!pending) return;
|
|
const target =
|
|
pending.mode === "customize"
|
|
? createFlowStepPath("core-values")
|
|
: createFlowStepPath("confirm-stakeholders");
|
|
firedRedirectRef.current = true;
|
|
const pinMerge =
|
|
pending.mode === "customize"
|
|
? {
|
|
methodSectionsPinCommitted: {
|
|
...state.methodSectionsPinCommitted,
|
|
...methodSectionsPinsForHydratedSelections(state),
|
|
},
|
|
}
|
|
: {};
|
|
updateState({ pendingTemplateAction: undefined, ...pinMerge });
|
|
router.replace(target);
|
|
}, [
|
|
router,
|
|
state.pendingTemplateAction,
|
|
state.methodSectionsPinCommitted,
|
|
state.selectedCommunicationMethodIds,
|
|
state.selectedMembershipMethodIds,
|
|
state.selectedDecisionApproachIds,
|
|
state.selectedConflictManagementIds,
|
|
updateState,
|
|
]);
|
|
|
|
const cardTitle =
|
|
typeof state.title === "string" && state.title.trim().length > 0
|
|
? state.title.trim()
|
|
: t("ruleCard.title");
|
|
/**
|
|
* No placeholder fallback: if the user skipped `community-context`, leave
|
|
* the card description off rather than render the old "Mutual Aid Monday
|
|
* is a grassroots community…" sample, which read as real user copy.
|
|
*/
|
|
const cardDescription =
|
|
typeof state.communityContext === "string" &&
|
|
state.communityContext.trim().length > 0
|
|
? state.communityContext.trim()
|
|
: undefined;
|
|
|
|
const avatarUrl =
|
|
typeof state.communityAvatarUrl === "string" &&
|
|
state.communityAvatarUrl.trim().length > 0
|
|
? state.communityAvatarUrl.trim()
|
|
: null;
|
|
|
|
return (
|
|
<CreateFlowStepShell
|
|
variant="wideGridLoosePadding"
|
|
contentTopBelowMd="space-1400"
|
|
>
|
|
<div
|
|
className={`flex w-full min-w-0 flex-col items-center gap-6 lg:mx-auto lg:w-full lg:grid lg:grid-cols-2 lg:items-center lg:justify-items-center lg:gap-x-[var(--measures-spacing-1200,48px)] lg:gap-y-6 ${CREATE_FLOW_TWO_COLUMN_MAX_WIDTH_CLASS}`}
|
|
>
|
|
<div
|
|
className={`flex flex-col justify-center lg:min-h-[212px] ${CREATE_FLOW_MD_UP_GRID_CELL_CLASS}`}
|
|
>
|
|
<CreateFlowHeaderLockup
|
|
title={t("header.title")}
|
|
description={t("header.description")}
|
|
/>
|
|
</div>
|
|
<div className={CREATE_FLOW_MD_UP_GRID_CELL_CLASS}>
|
|
<Rule
|
|
title={cardTitle}
|
|
description={cardDescription}
|
|
size={lgUp ? "L" : "M"}
|
|
expanded={false}
|
|
backgroundColor="bg-[var(--color-teal-teal50,#c9fef9)]"
|
|
logoUrl={
|
|
avatarUrl ?? getAssetPath(vectorMarkPath("mutual-aid"))
|
|
}
|
|
logoAlt={cardTitle}
|
|
className="rounded-[24px]"
|
|
/>
|
|
</div>
|
|
</div>
|
|
</CreateFlowStepShell>
|
|
);
|
|
}
|