Skip to content

Instantly share code, notes, and snippets.

@gajus
Created February 18, 2023 23:33
Show Gist options
  • Save gajus/7daf8893ae91165246b5062b8fecff40 to your computer and use it in GitHub Desktop.
Save gajus/7daf8893ae91165246b5062b8fecff40 to your computer and use it in GitHub Desktop.
// @preserve name src/pages/_username/projects.page.client
// @preserve facadeModuleId /Users/gajus/Developer/contra/gaia-og2/apps/contra-web-app/src/pages/:username/projects.page.client.tsx
// @preserve module @/apps/contra-web-app/src/__generated__/components/Icons/BrownBriefcase.tsx
// @preserve module @/apps/contra-web-app/src/__generated__/components/Icons/ContraHandshake.tsx
// @preserve module @/apps/contra-web-app/src/__generated__/components/Icons/Contra.tsx
// @preserve module @/apps/contra-web-app/src/__generated__/projectsUsernamePageQuery.graphql.ts
// @preserve module @/apps/contra-web-app/src/__generated__/ProfileProjectsReorderMutation.graphql.ts
// @preserve module @/apps/contra-web-app/src/__generated__/ProfileProjects_userProfile.graphql.ts
// @preserve module @/apps/contra-web-app/src/__generated__/BlogCard_userProfile.graphql.ts
// @preserve module @/apps/contra-web-app/src/__generated__/BlogCard_portfolioProject.graphql.ts
// @preserve module @/apps/contra-web-app/src/features/profile/components/ProjectCard/ProjectCard.styles.ts
// @preserve module @/apps/contra-web-app/src/features/profile/components/BlogCard/BlogCard.tsx
// @preserve module @/apps/contra-web-app/src/__generated__/ProjectCard_userProfile.graphql.ts
// @preserve module @/apps/contra-web-app/src/__generated__/ProjectCard_portfolioProject.graphql.ts
// @preserve module @/apps/contra-web-app/src/__generated__/ProjectCardCollaborators_portfolioProject.graphql.ts
// @preserve module @/apps/contra-web-app/src/hooks/useIsExtraLargeScreen.ts
// @preserve module @/apps/contra-web-app/src/features/profile/components/ProjectCard/ProjectCardCollaborators.tsx
// @preserve module @/apps/contra-web-app/src/components/DraftResourceTag/ProjectDraftTag.tsx
// @preserve module @/apps/contra-web-app/src/features/profile/components/ProjectCard/ProjectCard.tsx
// @preserve module @/apps/contra-web-app/src/utilities/isBlogCategorySlug.ts
// @preserve module @/apps/contra-web-app/src/features/profile/components/ProfileProjects/ProfileProjects.tsx
// @preserve module @/apps/contra-web-app/src/features/project/components/CreateProject/actionTypes.ts
// @preserve module @/apps/contra-web-app/src/features/project/components/CreateProject/components/BlogProjectDetailsModal/BlogProjectDetailsModal.tsx
// @preserve module @/apps/contra-web-app/src/features/project/components/CreateProject/components/CreateProjectModal/CreateProjectModal.styles.tsx
// @preserve module @/apps/contra-web-app/src/features/project/components/CreateProject/components/CreateProjectModal/CreateProjectModal.tsx
// @preserve module @/apps/contra-web-app/src/features/project/components/CreateProject/components/LinkedProjectDetailsModal/LinkedProjectDetailsModal.tsx
// @preserve module @/apps/contra-web-app/src/features/project/components/CreateProject/components/ScratchProjectDetailsModal/ScratchProjectDetailsModal.tsx
// @preserve module @/apps/contra-web-app/src/__generated__/ProjectTemplatesModalQuery.graphql.ts
// @preserve module @/apps/contra-web-app/src/features/project/components/CreateProject/components/ProjectTemplatesModal/constants.ts
// @preserve module @/apps/contra-web-app/src/features/project/components/CreateProject/components/ProjectTemplatesModal/ProjectTemplatesModal.styles.tsx
// @preserve module @/apps/contra-web-app/src/features/project/components/CreateProject/components/ProjectTemplatesModal/utils.tsx
// @preserve module @/apps/contra-web-app/src/features/project/components/CreateProject/components/ProjectTemplatesModal/ProjectTemplatesModal.tsx
// @preserve module @/apps/contra-web-app/src/features/project/components/CreateProject/reducer.ts
// @preserve module @/apps/contra-web-app/src/features/project/components/CreateProject/CreateProject.tsx
// @preserve module @/apps/contra-web-app/src/features/project/components/CreateProject/CreateProjectWrapper.tsx
// @preserve module @/apps/contra-web-app/src/pages/:username/projects.page.client.tsx
import { a as jsx, j as jsxs, F as Fragment } from "../../../chunk-jsx-runtime.15e01768.js";
import { u as useProfileMagic } from "../../../chunk-useHasSidebarEnabled.874f345c.js";
import { F as Footer$1 } from "../../../chunk-Footer.fa5aeea4.js";
import { N as NotFound } from "../../../chunk-NotFound.a27f0d05.js";
import { P as PortfolioRedirect } from "../../../chunk-PortfolioRedirect.f9aae336.js";
import { R as Redirect } from "../../../chunk-Redirect-index.0440c4ea.js";
import { u as useOnboardingRedirection } from "../../../chunk-useOnboardingRedirection.2116273f.js";
import { B as BlankCardMessage } from "../../../chunk-BlankCardMessage.952c0ac2.js";
import { D as DeletePortfolioProjectModal, C as CATEGORY_SLUG_MAP, M as ModalClose, a as ModalBody$2, P as ProjectDetailsForm } from "../../../chunk-FullScreenProjectModal.9ede727b.js";
import { C as CircularIconButton, B as Button$1 } from "../../../chunk-CircularIconButton.0192d6bd.js";
import { r as reactExports } from "../../../chunk-react-index.ef789a88.js";
import { C as Card$1 } from "../../../chunk-Card.31d507db.js";
import { L as Link, u as useRouter } from "../../../chunk-Link-index.f428b207.js";
import { s as styled, C as Ce, T as Text, b as animated } from "../../../chunk-Text.79b8c338.js";
import { M as MOBILE_PROJECT_COVER_WIDTH, a as PROJECT_COVER_WIDTH, b as PROJECT_COVER_ASPECT_RATIO } from "../../../chunk-ProjectCoverWrapper_portfolioProjectCover.graphql.4db2ea39.js";
import { r as reactRelayExports } from "../../../chunk-react-relay-index.55977080.js";
import "../../../chunk-relay-runtime-index.e1d7d898.js";
import { I as IconSvg, d as dashedBorderBackground, g as gradientBorderBackground } from "../../../chunk-IconSvg.af64f841.js";
import { B as BlogCategoriesList } from "../../../chunk-BlogCategoriesList.22795462.js";
import { F as Flex } from "../../../chunk-Flex.27c91cf9.js";
import { M as Menu } from "../../../chunk-Menu.eb3f5c4c.js";
import { P as ProjectCoverWrapper } from "../../../chunk-ProjectCoverWrapper.3e30b074.js";
import { u as useAnalytics } from "../../../chunk-useAnalytics.4c9f2cf0.js";
import { u as useNavigation, r as routeHelpers, a as appendSearch } from "../../../chunk-routeHelpers.b8863483.js";
import { u as useOnElementViewed } from "../../../chunk-useOnElementViewed.b6930455.js";
import { M as MoveIcon } from "../../../chunk-MoveIcon.1d6cf192.js";
import { M as MoreIcon } from "../../../chunk-MoreIcon.0a6a05b3.js";
import { E as EditIcon } from "../../../chunk-EditIcon.d8c36f62.js";
import { C as CloseIcon } from "../../../chunk-CloseIcon.8cfb38e5.js";
import { C as CreateCard } from "../../../chunk-CreateCard.d7d73d39.js";
import { A as Avatar } from "../../../chunk-AvatarImageFragment.graphql.c4d3a365.js";
import { A as AvatarGroup } from "../../../chunk-AvatarGroup.a4ea97e2.js";
import { u as useHasOnboarded } from "../../../chunk-useHasOnboarded.c55111c3.js";
import { W as WindowDimensionsContext, u as useIsMobile } from "../../../chunk-useIsMobile.ef77db6e.js";
import "../../../chunk-constants.97b58b29.js";
import { C as Container$1, S as SuggestedTag, a as STAGGERED_CHILDREN_CONTAINER_VARIANTS, b as STAGGERED_CHILD_VARIANTS } from "../../../chunk-animationUtilities.17ecbc05.js";
import { T as Tooltip } from "../../../chunk-Tooltip.a177a0c3.js";
import { E as EyeOffIcon } from "../../../chunk-EyeOffIcon.5c2a623d.js";
import { g as getCategoryHref } from "../../../chunk-AuthorBlock.af1550b1.js";
import { u as useSortableListView, S as SortableListView } from "../../../chunk-SortableListView.46a5ec60.js";
import { S as SortableListItemWithClonedElement } from "../../../chunk-SortableListItemWithClonedElement.1ac9758c.js";
import { u as useRouteParameter } from "../../../chunk-useRouteParameter.089c2ca6.js";
import { u as useToggle } from "../../../chunk-useToggle.1f5c1cc2.js";
import { u as useUserTypeSelector } from "../../../chunk-useUserTypeSelector.fe6fbdd2.js";
import { f as formatName } from "../../../chunk-formatName.32c76990.js";
import { F as FilterIcon } from "../../../chunk-FilterIcon.37771ca5.js";
import { P as ProfileLayout } from "../../../chunk-ProfileLayout.93383303.js";
import { a as Modal } from "../../../chunk-useModal.46adce0d.js";
import "../../../chunk-preload-helper.781075f5.js";
import { T as TextField, F as FormField } from "../../../chunk-TextField.10f690b9.js";
import { g as getMaybeBrandDetailsFromLink } from "../../../chunk-utils.02ac7fc5.js";
import { S as ScrollingBrandStrip } from "../../../chunk-ScrollingBrandStrip.cb6b2531.js";
import { P as ProjectEditorContext, D as DEFAULT_TEXT_COVER, a as ProjectThumbnailContext, u as useLinkDetails, n as normalizeContraImageToUploadedImageInput, b as ProjectEditorContextProvider, c as ProjectThumbnailContextProvider } from "../../../chunk-useLinkDetails.7e215418.js";
import { u as useFeatureFlag } from "../../../chunk-useFeatureFlag.5b14fec0.js";
import { u as useLocation } from "../../../chunk-useLocation.4dfe13a8.js";
import { u as useSearchParameter } from "../../../chunk-useSearchParameter.11d71d73.js";
import { u as useTrackInput } from "../../../chunk-useTrackInput.30ec9175.js";
import { i as isValidPublicUrl } from "../../../chunk-isValidPublicUrl.61d4c8a5.js";
import { r as removeSearchParameter } from "../../../chunk-removeSearchParameter.f283d8a7.js";
import { U as UnidentifiedIcon } from "../../../chunk-Unidentified.be743308.js";
import { f as RocketEmoji } from "../../../chunk-Toaster.79f43b4e.js";
import { a as ErrorBoundary } from "../../../chunk-ErrorBoundary.556bdd2a.js";
import { f as formatUrl } from "../../../chunk-formatUrl.fc49aee9.js";
import { c as create, a as create$1 } from "../../../chunk-array.f2272c93.js";
import { u as useMount } from "../../../chunk-useMount.30a4ab15.js";
import { u as useRegisterAnalyticEvent } from "../../../chunk-useRegisterAnalyticEvent.fc6a490a.js";
import { u as useRoutes } from "../../../chunk-useRoutes.74f011be.js";
import { W } from "../../../chunk-index.module.a4920084.js";
import "../../../chunk-react-index.ef4c5b4f.js";
import "../../../chunk-SocialMediaIconBanner.2f246b0d.js";
import "../../../chunk-ProfileExternalLinkBrandIcon.397ffcd8.js";
import "../../../chunk-_commonjsHelpers.7066ccfc.js";
import "../../../chunk-ExternalLinkAltIcon.0364bc70.js";
import "../../../chunk-profile.9e45f3be.js";
import "../../../chunk-TooltipContainer.09a24ca6.js";
import "../../../chunk-TrashIcon.21cbddd7.js";
import "../../../chunk-isValidEmail.1be8a566.js";
import "../../../chunk-AnalyticsProvider.1a309899.js";
import "../../../chunk-logger.45534671.js";
import "../../../chunk-app.config.59c39c96.js";
import "../../../chunk-useCurrentUser.233240e0.js";
import "../../../chunk-usePageContext.8911b329.js";
import "../../../chunk-usePostHog.174fb2af.js";
import "../../../chunk-storage.ad3685da.js";
import "../../../chunk-serialize-error-index.1ff13d1c.js";
import "../../../chunk-fast-safe-stringify-index.a9ad69f2.js";
import "../../../chunk-Image.b3550815.js";
import "../../../chunk-TemplateWrapper.5837fa94.js";
import "../../../chunk-ArrowLeft.afd1c198.js";
import "../../../chunk-SlideUpDrawerV2.ee1bc62d.js";
import "../../../chunk-module.149f6a3d.js";
import "../../../chunk-module.c5792c6a.js";
import "../../../chunk-clsx.m.8ec312ad.js";
import "../../../chunk-module.9d10d042.js";
import "../../../chunk-react-dom-index.39306670.js";
import "../../../chunk-SparklesEmoji.95c84715.js";
import "../../../chunk-ChevronUpIcon.bf72c25f.js";
import "../../../chunk-ChevronDownIcon.ae4974c2.js";
import "../../../chunk-SparklesIcon.d7ed2c04.js";
import "../../../chunk-useOnboardingSuccessAddUIFlagMutation.graphql.13fb0ec7.js";
import "../../../chunk-Confetti.bb890761.js";
import "../../../chunk-useWindowSize.8e41c87d.js";
import "../../../chunk-useContraMutation.624ac50b.js";
import "../../../chunk-useHasUserInterfaceFlags.ad70ef3f.js";
import "../../../chunk-AddVerticalFades.4617da8a.js";
import "../../../chunk-MountedPortal.4b48b920.js";
import "../../../chunk-animation.51ef58d8.js";
import "../../../chunk-usePopper.b946d1be.js";
import "../../../chunk-prop-types-index.c4fc4f05.js";
import "../../../chunk-index.esm.6481cc33.js";
import "../../../chunk-index.esm.2400ceb4.js";
import "../../../chunk-yup.10c3ce19.js";
import "../../../chunk-PageLayout.121e8c64.js";
import "../../../chunk-EditSocialLinksModalContainer.ec2d4b3f.js";
import "../../../chunk-AddIcon.128f6e3b.js";
import "../../../chunk-SocialMediaLinkWithTooltip.8d1f8eb9.js";
import "../../../chunk-LinkIcon.b3be6f40.js";
import "../../../chunk-InlineFormElement.eabb911f.js";
import "../../../chunk-Plus.139a85b7.js";
import "../../../chunk-isTruthy.c705c4a7.js";
import "../../../chunk-LocationInput.9fd2787d.js";
import "../../../chunk-Loader.cdb365af.js";
import "../../../chunk-utils.fe9a8d17.js";
import "../../../chunk-downshift.esm.52bfcbdc.js";
import "../../../chunk-CheckIcon.a33f5aea.js";
import "../../../chunk-dist-index.1df99cb2.js";
import "../../../chunk-tslib.es6.0455069c.js";
import "../../../chunk-loadDynamicScript.750aa49f.js";
import "../../../chunk-LocationIcon.1ad2f20f.js";
import "../../../chunk-LocationText.8c663846.js";
import "../../../chunk-OrganizationLogoEmptyState.a7d5ef75.js";
import "../../../chunk-JobOutlineIcon.8b081bde.js";
import "../../../chunk-SkillInput.1172024b.js";
import "../../../chunk-useDebounceValue.3580389a.js";
import "../../../chunk-TagListMenu.df7438ff.js";
import "../../../chunk-OpportunityOutlineIcon.e696b805.js";
import "../../../chunk-useInteractionTimer.30024dd6.js";
import "../../../chunk-WorkPreferencesForm.styles.6c8fb082.js";
import "../../../chunk-dayjs.bec8af80.js";
import "../../../chunk-ChevronDown.e30331b9.js";
import "../../../chunk-ChevronUp.edf2930e.js";
import "../../../chunk-exports.5e239b61.js";
import "../../../chunk-CancelIcon.285a44d3.js";
import "../../../chunk-PreferenceIcon.4db8fef3.js";
import "../../../chunk-Radio.990b61a7.js";
import "../../../chunk-SolidCheck.da8599e4.js";
import "../../../chunk-SocialYoutubeIcon.d49383d3.js";
import "../../../chunk-ExternalTextLink.029e1a63.js";
import "../../../chunk-TextLink.styles.236b3fdb.js";
import "../../../chunk-MainLayout.1c5c6c51.js";
import "../../../chunk-NavbarV2.31cb12b9.js";
import "../../../chunk-legacy-popmotion-index.6e033319.js";
import "../../../chunk-useSafeState.3e1fefbd.js";
import "../../../chunk-useIsMounted.9a35f785.js";
import "../../../chunk-Logo.f6f41cbb.js";
import "../../../chunk-useIsMediumScreen.80372fe7.js";
import "../../../chunk-SearchIcon.2864a583.js";
import "../../../chunk-MenuContext.93540dcb.js";
import "../../../chunk-ContraLogoSuspenseLoader.3437f0e9.js";
import "../../../chunk-LastLocationContext.85bfe102.js";
import "../../../chunk-DeauthenticateUserMutation.graphql.9dda919a.js";
import "../../../chunk-useAuth.de37d73c.js";
import "../../../chunk-IndyPortfolioIconLink.styles.16ae7895.js";
import "../../../chunk-constants.cb364b01.js";
import "../../../chunk-extends.ab5e6725.js";
import "../../../chunk-ArrowRightIcon.bf030a71.js";
import "../../../chunk-ProjectOutlineIcon.c6742452.js";
import "../../../chunk-HeartOutlineIcon.76da948e.js";
import "../../../chunk-money.9614eb01.js";
import "../../../chunk-useIsSmallScreen.b8a39c2d.js";
import "../../../chunk-useLastLocation.535e1b05.js";
import "../../../chunk-getIndependentPortfolioUrl.926a6929.js";
import "../../../chunk-normalizeUsername.7f7862a8.js";
import "../../../chunk-getOnboardingFlowType.d73b9b13.js";
import "../../../chunk-shouldRedirectToOnboarding.ecf32a0d.js";
import "../../../chunk-AlertTriangleIcon.24aa3cb7.js";
import "../../../chunk-AvatarWithDetails.c73c7047.js";
import "../../../chunk-hasValidationError.96e2561c.js";
import "../../../chunk-OrganizationsInput.bf5e3e70.js";
import "../../../chunk-CharacterCounter.68587c5f.js";
import "../../../chunk-file.f50ddcea.js";
import "../../../chunk-UploadIcon.cdb97c36.js";
import "../../../chunk-getContraImageUrl.da8eb377.js";
import "../../../chunk-ChevronLeftIcon.0fe0ea5b.js";
import "../../../chunk-ImageIcon.066df029.js";
import "../../../chunk-RolesInput.cce62c5c.js";
import "../../../chunk-ToolsInput.75501cfa.js";
import "../../../chunk-SocialUnidentifiedToolIcon.88179d83.js";
import "../../../chunk-EditableHeadline.07f6af50.js";
import "../../../chunk-react-textarea-autosize.browser.esm.29ca9fd5.js";
import "../../../chunk-objectWithoutPropertiesLoose.74572fe5.js";
import "../../../chunk-browser.9123058c.js";
import "../../../chunk-prefetch.478528ed.js";
import "../../../chunk-assertRenderHook.c37a40c9.js";
import "../../../chunk-useIsElementVisible.8e80a0ee.js";
import "../../../chunk-LightbulbEmoji.e7bed4fe.js";
import "../../../chunk-AvatarWithPopover.809e43b5.js";
import "../../../chunk-useHasUserGroups.7e9998a1.js";
import "../../../chunk-TextLink.78899485.js";
import "../../../chunk-usePortfolioLink.133e180b.js";
import "../../../chunk-BarChartAnalytics.8ae10abe.js";
import "../../../chunk-LockSolidIcon.095d7a88.js";
import "../../../chunk-useExactMatch.ed35e1ce.js";
import "../../../chunk-useStartProjectCopy.44ba4019.js";
import "../../../chunk-useContraPayments.a9cb4efd.js";
import "../../../chunk-StripeContextProviderFragment.graphql.67ef9630.js";
import "../../../chunk-react-stripe.esm.5de9fbcf.js";
import "../../../chunk-useEnhancedReducer.60bccaf8.js";
import "../../../chunk-CreditCardOutlineIcon.862abd2d.js";
import "../../../chunk-getMutationResponsePayloadErrors.93dd8c9a.js";
import "../../../chunk-OnboardingTooltip.865f8422.js";
import "../../../chunk-ConfettiEmoji.f7895593.js";
import "../../../chunk-HeartSolidIcon.14a23f0e.js";
import "../../../chunk-useCopyToClipboard.e8810878.js";
import "../../../chunk-ShareAltIcon.7d8e0596.js";
import "../../../chunk-CopyIcon.dd191893.js";
import "../../../chunk-MailSendOutlineIcon.eacdda86.js";
import "../../../chunk-IndyPortfolioIconLink.be345e77.js";
import "../../../chunk-ServiceOutlineIcon.0b25a920.js";
import "../../../chunk-OpenOnboardingChecklistButton.1d6f00b6.js";
import "../../../chunk-RadialProgress.590669ec.js";
import "../../../chunk-module.1d2012e6.js";
import "../../../chunk-module.c67d479d.js";
import "../../../chunk-useHasCompletedProfile.e08382b0.js";
import "../../../chunk-ProfileImageCropperUploadInput.eac592e6.js";
import "../../../chunk-HoverCropperButton.d24bcd84.js";
import "../../../chunk-CameraIcon.018a5919.js";
import "../../../chunk-ContraPayments.9a652c6e.js";
import "../../../chunk-StripeElements.60b73d23.js";
import "../../../chunk-pure.0d31aa50.js";
import "../../../chunk-AdminSignInUrl.baee9666.js";
import "../../../chunk-Table.31bce020.js";
import "../../../chunk-index.es.fbfa066e.js";
import "../../../chunk-Tabs.0cbe576c.js";
import "../../../chunk-getDefaultFeatureFlags.bee9d147.js";
import "../../../chunk-isObject.4ea674ef.js";
import "../../../chunk-IndependentCategoryBadgeWrapper.44b1a177.js";
import "../../../chunk-EditableAvatar.f4557e08.js";
const BrownBriefcaseIcon = (props) => reactExports.createElement(
IconSvg,
{
...props,
viewBox: "0 0 24 24"
},
/* @__PURE__ */ jsx("path", { fill: "url(#brown-briefcase_svg__a)", d: "M0 0h24v24H0z" }),
/* @__PURE__ */ jsxs("defs", { children: [
/* @__PURE__ */ jsx(
"pattern",
{
id: "brown-briefcase_svg__a",
patternContentUnits: "objectBoundingBox",
width: 1,
height: 1,
children: /* @__PURE__ */ jsx("use", { xlinkHref: "#brown-briefcase_svg__b", transform: "scale(.00625)" })
}
),
/* @__PURE__ */ jsx(
"image",
{
id: "brown-briefcase_svg__b",
width: 160,
height: 160,
xlinkHref: ""
}
)
] })
);
const ContraHandshakeIcon = (props) => reactExports.createElement(
IconSvg,
{
...props,
viewBox: "0 0 24 24"
},
/* @__PURE__ */ jsx("path", { fill: "url(#contra-handshake_svg__a)", d: "M0 0h24v24H0z" }),
/* @__PURE__ */ jsxs("defs", { children: [
/* @__PURE__ */ jsx(
"pattern",
{
id: "contra-handshake_svg__a",
patternContentUnits: "objectBoundingBox",
width: 1,
height: 1,
children: /* @__PURE__ */ jsx("use", { xlinkHref: "#contra-handshake_svg__b", transform: "scale(.00625)" })
}
),
/* @__PURE__ */ jsx(
"image",
{
id: "contra-handshake_svg__b",
width: 160,
height: 160,
xlinkHref: ""
}
)
] })
);
const ContraIcon = (props) => reactExports.createElement(
IconSvg,
{
...props,
viewBox: "0 0 25 24"
},
/* @__PURE__ */ jsx(
"path",
{
fillRule: "evenodd",
clipRule: "evenodd",
d: "M12.888 11.35H23.79c.124 0 .224-.1.224-.224v-.334a.224.224 0 0 0-.168-.217A14.594 14.594 0 0 1 13.376.167.224.224 0 0 0 13.158 0h-.271c-.124 0-.224.1-.224.224v10.902c0 .123.1.224.224.224ZM12.888 24h.334a.223.223 0 0 0 .217-.168 14.595 14.595 0 0 1 10.408-10.47.224.224 0 0 0 .167-.217v-.271c0-.123-.1-.224-.224-.224H12.888c-.124 0-.224.1-.224.224v10.902c0 .124.1.224.224.224ZM10.854 24h.272c.123 0 .223-.1.223-.224V12.874c0-.123-.1-.224-.223-.224H.224c-.124 0-.224.1-.224.224v.334c0 .102.069.191.168.217a14.595 14.595 0 0 1 10.47 10.408.224.224 0 0 0 .216.167ZM.224 11.35h10.902c.123 0 .223-.1.223-.224V.224c0-.124-.1-.224-.223-.224h-.334a.224.224 0 0 0-.217.168A14.595 14.595 0 0 1 .167 10.638a.223.223 0 0 0-.167.217v.271c0 .123.1.224.224.224Z",
fill: "currentColor"
}
)
);
const node$8 = function() {
var v0 = [
{
"defaultValue": null,
"kind": "LocalArgument",
"name": "username"
}
], v1 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "id",
"storageKey": null
}, v2 = [
{
"kind": "Variable",
"name": "username",
"variableName": "username"
}
], v3 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "profileDisplayType",
"storageKey": null
}, v4 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "firstName",
"storageKey": null
}, v5 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "lastName",
"storageKey": null
}, v6 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "visitorCanEdit",
"storageKey": null
}, v7 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "displayUsername",
"storageKey": null
}, v8 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "hasCompletedClientOnboarding",
"storageKey": null
}, v9 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "hasCompletedIndyOnboarding",
"storageKey": null
}, v10 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "name",
"storageKey": null
}, v11 = [
v1,
v10
], v12 = {
"alias": null,
"args": null,
"concreteType": "BlogCategoryConnection",
"kind": "LinkedField",
"name": "blogCategories",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "BlogCategoryEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "BlogCategory",
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": v11,
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
}, v13 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "__typename",
"storageKey": null
}, v14 = [
v13,
v1,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "isSelected",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "suggestion",
"storageKey": null
}
], v15 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "title",
"storageKey": null
}, v16 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "count",
"storageKey": null
}, v17 = [
v16
], v18 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "analyticsId",
"storageKey": null
}, v19 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "slug",
"storageKey": null
}, v20 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "description",
"storageKey": null
}, v21 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "uid",
"storageKey": null
}, v22 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "height",
"storageKey": null
}, v23 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "originalFormat",
"storageKey": null
}, v24 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "sizeBytes",
"storageKey": null
}, v25 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "url",
"storageKey": null
}, v26 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "width",
"storageKey": null
}, v27 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "animated",
"storageKey": null
}, v28 = [
v1,
v21,
v25,
v22,
v23,
v24,
v26,
v27
], v29 = {
"alias": null,
"args": null,
"concreteType": "UserProfile",
"kind": "LinkedField",
"name": "userProfile",
"plural": false,
"selections": [
v1,
v7,
{
"alias": null,
"args": null,
"concreteType": "ContraImage",
"kind": "LinkedField",
"name": "avatarImage",
"plural": false,
"selections": v28,
"storageKey": null
}
],
"storageKey": null
};
return {
"fragment": {
"argumentDefinitions": v0,
"kind": "Fragment",
"metadata": null,
"name": "projectsUsernamePageQuery",
"selections": [
{
"alias": null,
"args": null,
"concreteType": "Visitor",
"kind": "LinkedField",
"name": "visitor",
"plural": false,
"selections": [
v1,
{
"alias": null,
"args": null,
"concreteType": "UserAccount",
"kind": "LinkedField",
"name": "userAccount",
"plural": false,
"selections": [
v1,
{
"args": null,
"kind": "FragmentSpread",
"name": "ProfileLayout_userAccount"
}
],
"storageKey": null
}
],
"storageKey": null
},
{
"alias": null,
"args": v2,
"concreteType": "UserProfile",
"kind": "LinkedField",
"name": "userProfileByUsername",
"plural": false,
"selections": [
v1,
v3,
v4,
v5,
v6,
v7,
v8,
v9,
{
"args": null,
"kind": "FragmentSpread",
"name": "ProfileLayout_userProfile"
},
{
"args": null,
"kind": "FragmentSpread",
"name": "ProfileProjects_userProfile"
}
],
"storageKey": null
},
v12
],
"type": "Query",
"abstractKey": null
},
"kind": "Request",
"operation": {
"argumentDefinitions": v0,
"kind": "Operation",
"name": "projectsUsernamePageQuery",
"selections": [
{
"alias": null,
"args": null,
"concreteType": "Visitor",
"kind": "LinkedField",
"name": "visitor",
"plural": false,
"selections": [
v1,
{
"alias": null,
"args": null,
"concreteType": "UserAccount",
"kind": "LinkedField",
"name": "userAccount",
"plural": false,
"selections": [
v1,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "userInterfaceFlags",
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "ContraMagicSuggestion",
"kind": "LinkedField",
"name": "contraMagicOneLinerSuggestions",
"plural": true,
"selections": v14,
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "ContraMagicSuggestion",
"kind": "LinkedField",
"name": "contraMagicBioSuggestions",
"plural": true,
"selections": v14,
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
},
{
"alias": null,
"args": v2,
"concreteType": "UserProfile",
"kind": "LinkedField",
"name": "userProfileByUsername",
"plural": false,
"selections": [
v1,
v3,
v4,
v5,
v6,
v7,
v8,
v9,
v15,
{
"alias": null,
"args": null,
"concreteType": "ReceivedTestimonialConnection",
"kind": "LinkedField",
"name": "receivedTestimonials",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "ReceivedTestimonialEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "Testimonial",
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "recommend",
"storageKey": null
},
v1
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "RecommendationRequestConnection",
"kind": "LinkedField",
"name": "recommendationRequests",
"plural": false,
"selections": v17,
"storageKey": null
},
v18,
{
"alias": null,
"args": [
{
"kind": "Literal",
"name": "type",
"value": "ALL"
}
],
"concreteType": "UserProfilePortfolioProjectConnection",
"kind": "LinkedField",
"name": "portfolioProjects",
"plural": false,
"selections": [
v16,
{
"alias": null,
"args": null,
"concreteType": "UserProfilePortfolioProjectEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "PortfolioProject",
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": [
v1,
{
"alias": null,
"args": null,
"concreteType": "UserProfile",
"kind": "LinkedField",
"name": "author",
"plural": false,
"selections": [
v1
],
"storageKey": null
},
v12,
v18,
v19,
v15,
v20,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "llmSuggestionId",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "publishedAt",
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": null,
"kind": "LinkedField",
"name": "cover",
"plural": false,
"selections": [
v13,
{
"kind": "TypeDiscriminator",
"abstractKey": "__isPortfolioProjectCover"
},
{
"kind": "InlineFragment",
"selections": [
{
"alias": null,
"args": null,
"concreteType": "ContraImage",
"kind": "LinkedField",
"name": "image",
"plural": false,
"selections": [
v21,
v1,
v22,
v23,
v24,
v25,
v26,
v27
],
"storageKey": null
}
],
"type": "PortfolioProjectImageCover",
"abstractKey": null
},
{
"kind": "InlineFragment",
"selections": [
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "style",
"storageKey": null
}
],
"type": "PortfolioProjectTextCover",
"abstractKey": null
}
],
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "PortfolioProjectCollaboratorConnection",
"kind": "LinkedField",
"name": "collaborators",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "PortfolioProjectCollaboratorEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": null,
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": [
v13,
v1,
{
"kind": "InlineFragment",
"selections": [
v29
],
"type": "ExistingUserCollaborator",
"abstractKey": null
}
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
},
v29,
{
"alias": null,
"args": null,
"concreteType": "PortfolioProjectContentImageConnection",
"kind": "LinkedField",
"name": "contentImages",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "PortfolioProjectContentImageEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "ContraImage",
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": [
v1,
v27,
v22,
v23,
v24,
v21,
v26,
v25
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": 'portfolioProjects(type:"ALL")'
},
{
"alias": null,
"args": null,
"concreteType": "UserProfileProductizedServiceConnection",
"kind": "LinkedField",
"name": "productizedServices",
"plural": false,
"selections": v17,
"storageKey": null
},
v13,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "showVerificationBadge",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "showWalletActiveBadge",
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "UserProfileExternalLinkConnection",
"kind": "LinkedField",
"name": "externalLinks",
"plural": false,
"selections": [
v16,
{
"alias": null,
"args": null,
"concreteType": "UserProfileExternalLinkEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "UserProfileExternalLink",
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": [
v1,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "label",
"storageKey": null
},
v25
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "Organization",
"kind": "LinkedField",
"name": "organization",
"plural": false,
"selections": [
v1,
v20,
{
"alias": null,
"args": null,
"concreteType": "ContraImage",
"kind": "LinkedField",
"name": "logoImage",
"plural": false,
"selections": v28,
"storageKey": null
},
v10,
v25,
v19,
v13
],
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "UserProfileRoleConnection",
"kind": "LinkedField",
"name": "roles",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "UserAccountRoleEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "Role",
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": v11,
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "calendarLink",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "generalInquiryCtaIsVisible",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "canReceiveInquiries",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "bio",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "location",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "locationGooglePlaceId",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "primaryJobPostingCategory",
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "UserListConnection",
"kind": "LinkedField",
"name": "belongsToContraLists",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "UserListUserProfileEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "UserList",
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "nid",
"storageKey": null
},
v1
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "ContraImage",
"kind": "LinkedField",
"name": "avatarImage",
"plural": false,
"selections": [
v1,
v25,
v21,
v22,
v23,
v24,
v26,
v27
],
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "onboardingType",
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "WorkPreferences",
"kind": "LinkedField",
"name": "workPreferences",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "isCurrentlyAvailable",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "availableUntil",
"storageKey": null
}
],
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "professionalTitle",
"storageKey": null
}
],
"storageKey": null
},
v12
]
},
"params": {
"cacheID": "cc895e14ba98638cbfd088fa2fe42d9a",
"id": null,
"metadata": {},
"name": "projectsUsernamePageQuery",
"operationKind": "query",
"text": "query projectsUsernamePageQuery(\n $username: String!\n) {\n visitor {\n id\n userAccount {\n id\n ...ProfileLayout_userAccount\n }\n }\n userProfileByUsername(username: $username) {\n id\n profileDisplayType\n firstName\n lastName\n visitorCanEdit\n displayUsername\n hasCompletedClientOnboarding\n hasCompletedIndyOnboarding\n ...ProfileLayout_userProfile\n ...ProfileProjects_userProfile\n }\n blogCategories {\n edges {\n node {\n id\n name\n }\n }\n }\n}\n\nfragment BioSuggestionsContainer_userAccount on UserAccount {\n ...BioSuggestions_userAccount\n}\n\nfragment BioSuggestions_userAccount on UserAccount {\n contraMagicBioSuggestions {\n id\n isSelected\n suggestion\n }\n}\n\nfragment Bio_bio on UserProfile {\n visitorCanEdit\n bio\n}\n\nfragment Bio_userAccount on UserAccount {\n contraMagicBioSuggestions {\n __typename\n id\n }\n ...BioSuggestionsContainer_userAccount\n}\n\nfragment BlogCard_portfolioProject on PortfolioProject {\n id\n analyticsId\n author {\n id\n }\n blogCategories {\n edges {\n node {\n id\n name\n }\n }\n }\n slug\n title\n description\n cover {\n __typename\n ...ProjectCoverWrapper_portfolioProjectCover\n ... on PortfolioProjectImageCover {\n __typename\n image {\n id\n animated\n height\n originalFormat\n sizeBytes\n uid\n width\n ...ContraImageFragment\n }\n }\n ... on PortfolioProjectTextCover {\n __typename\n style\n }\n }\n contentImages {\n edges {\n node {\n id\n animated\n height\n originalFormat\n sizeBytes\n uid\n width\n ...ContraImageFragment\n }\n }\n }\n}\n\nfragment BlogCard_userProfile on UserProfile {\n id\n analyticsId\n visitorCanEdit\n}\n\nfragment ContraImageFragment on ContraImage {\n id\n height\n originalFormat\n sizeBytes\n uid\n url\n width\n animated\n}\n\nfragment FullName_name on UserProfile {\n firstName\n lastName\n displayUsername\n visitorCanEdit\n}\n\nfragment HiringAsAnIndividual_userProfile on UserProfile {\n visitorCanEdit\n professionalTitle\n firstName\n organization {\n __typename\n id\n }\n}\n\nfragment InquireAndSave_userProfile on UserProfile {\n ...InquiryModal_profile\n ...WorkWithMe_userProfile\n}\n\nfragment InquiryForm_profile on UserProfile {\n id\n calendarLink\n firstName\n analyticsId\n}\n\nfragment InquiryModal_profile on UserProfile {\n id\n calendarLink\n firstName\n analyticsId\n ...InquiryForm_profile\n ...InquirySent_profile\n}\n\nfragment InquirySent_profile on UserProfile {\n firstName\n}\n\nfragment Links_userProfile on UserProfile {\n id\n visitorCanEdit\n externalLinks {\n edges {\n node {\n id\n label\n url\n }\n }\n }\n ...ProfileExternalLink_userProfile\n}\n\nfragment Location_userProfile on UserProfile {\n profileDisplayType\n location\n locationGooglePlaceId\n visitorCanEdit\n}\n\nfragment NewProfileSidebar_userAccount on UserAccount {\n ...Bio_userAccount\n}\n\nfragment NewProfileSidebar_userProfile on UserProfile {\n __typename\n id\n showVerificationBadge\n showWalletActiveBadge\n visitorCanEdit\n analyticsId\n hasCompletedClientOnboarding\n externalLinks {\n count\n }\n organization {\n id\n }\n roles {\n edges {\n node {\n id\n }\n }\n }\n ...FullName_name\n ...InquireAndSave_userProfile\n ...Bio_bio\n ...Location_userProfile\n ...Skills_roles\n ...ProfileSidebarAvatar_avatarImage\n ...ProfileSidebarWorkAvailability_userProfile\n ...Links_userProfile\n ...Organization_userProfile\n ...HiringAsAnIndividual_userProfile\n}\n\nfragment OneLinerSuggestionsContainer_userAccount on UserAccount {\n ...OneLinerSuggestions_userAccount\n}\n\nfragment OneLinerSuggestions_userAccount on UserAccount {\n contraMagicOneLinerSuggestions {\n id\n isSelected\n suggestion\n }\n}\n\nfragment OpportunitiesTab_userProfile on UserProfile {\n displayUsername\n}\n\nfragment Organization_userProfile on UserProfile {\n visitorCanEdit\n professionalTitle\n organization {\n description\n id\n logoImage {\n id\n uid\n url\n ...ContraImageFragment\n }\n name\n url\n slug\n }\n}\n\nfragment ProfileExternalLink_userProfile on UserProfile {\n analyticsId\n visitorCanEdit\n}\n\nfragment ProfileLayout_userAccount on UserAccount {\n ...useUserInterfaceFlags_fragment\n ...UncontrolledHeadlineEditor_userAccount\n ...NewProfileSidebar_userAccount\n}\n\nfragment ProfileLayout_userProfile on UserProfile {\n displayUsername\n visitorCanEdit\n title\n hasCompletedClientOnboarding\n hasCompletedIndyOnboarding\n profileDisplayType\n receivedTestimonials {\n edges {\n node {\n recommend\n id\n }\n }\n }\n recommendationRequests {\n count\n }\n ...WorkTab_userProfile\n ...ServicesTab_userProfile\n ...OpportunitiesTab_userProfile\n ...RecommendationsTab_userProfile\n ...UncontrolledHeadlineEditor_userProfile\n ...NewProfileSidebar_userProfile\n ...ProfileToothbrushButton_userProfile\n}\n\nfragment ProfileProjects_userProfile on UserProfile {\n id\n visitorCanEdit\n firstName\n profileDisplayType\n portfolioProjects(type: ALL) {\n edges {\n node {\n id\n author {\n id\n }\n blogCategories {\n edges {\n node {\n id\n }\n }\n }\n ...ProjectCard_portfolioProject\n ...BlogCard_portfolioProject\n }\n }\n }\n ...ProjectCard_userProfile\n ...BlogCard_userProfile\n}\n\nfragment ProfileSidebarAvatar_avatarImage on UserProfile {\n visitorCanEdit\n displayUsername\n firstName\n primaryJobPostingCategory\n belongsToContraLists {\n edges {\n node {\n nid\n id\n }\n }\n }\n avatarImage {\n id\n url\n uid\n ...ContraImageFragment\n }\n}\n\nfragment ProfileSidebarWorkAvailability_userProfile on UserProfile {\n onboardingType\n visitorCanEdit\n firstName\n workPreferences {\n isCurrentlyAvailable\n availableUntil\n }\n}\n\nfragment ProfileToothbrushButton_userProfile on UserProfile {\n visitorCanEdit\n hasCompletedIndyOnboarding\n ...VisitorCanEditProfileActions_userProfile\n ...PublicProfileActions_userProfile\n ...SocialShareLinksProvider_userProfile\n}\n\nfragment ProjectCardCollaborators_portfolioProject on PortfolioProject {\n id\n slug\n collaborators {\n edges {\n node {\n __typename\n id\n ... on ExistingUserCollaborator {\n userProfile {\n id\n displayUsername\n avatarImage {\n id\n uid\n url\n ...ContraImageFragment\n }\n }\n }\n }\n }\n }\n userProfile {\n id\n displayUsername\n avatarImage {\n id\n uid\n url\n ...ContraImageFragment\n }\n }\n}\n\nfragment ProjectCard_portfolioProject on PortfolioProject {\n id\n analyticsId\n slug\n title\n description\n llmSuggestionId\n publishedAt\n cover {\n __typename\n ...ProjectCoverWrapper_portfolioProjectCover\n }\n ...ProjectCardCollaborators_portfolioProject\n}\n\nfragment ProjectCard_userProfile on UserProfile {\n id\n analyticsId\n visitorCanEdit\n}\n\nfragment ProjectCoverWrapper_portfolioProjectCover on PortfolioProjectCover {\n __isPortfolioProjectCover: __typename\n ... on PortfolioProjectImageCover {\n __typename\n image {\n uid\n ...ContraImageFragment\n id\n }\n }\n ... on PortfolioProjectTextCover {\n __typename\n style\n }\n}\n\nfragment PublicProfileActions_userProfile on UserProfile {\n visitorCanEdit\n displayUsername\n ...SaveUserMenuButtonWrapper_userProfile\n ...ShareProfileMenuItem_userProfile\n}\n\nfragment RecommendationsTab_userProfile on UserProfile {\n analyticsId\n visitorCanEdit\n displayUsername\n receivedTestimonials {\n edges {\n node {\n recommend\n id\n }\n }\n }\n recommendationRequests {\n count\n }\n}\n\nfragment SaveUserMenuButtonWrapper_userProfile on UserProfile {\n analyticsId\n id\n firstName\n displayUsername\n}\n\nfragment ServicesTab_userProfile on UserProfile {\n displayUsername\n visitorCanEdit\n analyticsId\n productizedServices {\n count\n }\n}\n\nfragment ShareProfileMenuItem_userProfile on UserProfile {\n analyticsId\n visitorCanEdit\n}\n\nfragment Skills_roles on UserProfile {\n visitorCanEdit\n roles {\n edges {\n node {\n id\n name\n }\n }\n }\n}\n\nfragment SocialShareLinksProvider_userProfile on UserProfile {\n visitorCanEdit\n displayUsername\n firstName\n}\n\nfragment UncontrolledHeadlineEditor_userAccount on UserAccount {\n contraMagicOneLinerSuggestions {\n __typename\n id\n }\n ...OneLinerSuggestionsContainer_userAccount\n}\n\nfragment UncontrolledHeadlineEditor_userProfile on UserProfile {\n visitorCanEdit\n title\n}\n\nfragment VisitorCanEditProfileActions_userProfile on UserProfile {\n analyticsId\n visitorCanEdit\n ...ShareProfileMenuItem_userProfile\n}\n\nfragment WorkTab_userProfile on UserProfile {\n displayUsername\n profileDisplayType\n visitorCanEdit\n analyticsId\n portfolioProjects(type: ALL) {\n count\n }\n}\n\nfragment WorkWithMe_userProfile on UserProfile {\n id\n analyticsId\n displayUsername\n generalInquiryCtaIsVisible\n visitorCanEdit\n canReceiveInquiries\n}\n\nfragment useUserInterfaceFlags_fragment on UserAccount {\n userInterfaceFlags\n}\n"
}
};
}();
node$8.hash = "367e1ccce8ed755497fbbbb938e44cdb";
const node$7 = function() {
var v0 = [
{
"defaultValue": null,
"kind": "LocalArgument",
"name": "input"
}
], v1 = [
{
"kind": "Variable",
"name": "input",
"variableName": "input"
}
], v2 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "message",
"storageKey": null
}, v3 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "__typename",
"storageKey": null
}, v4 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "id",
"storageKey": null
}, v5 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "analyticsId",
"storageKey": null
}, v6 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "uid",
"storageKey": null
}, v7 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "height",
"storageKey": null
}, v8 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "originalFormat",
"storageKey": null
}, v9 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "sizeBytes",
"storageKey": null
}, v10 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "url",
"storageKey": null
}, v11 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "width",
"storageKey": null
}, v12 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "animated",
"storageKey": null
}, v13 = {
"alias": null,
"args": null,
"concreteType": "UserProfile",
"kind": "LinkedField",
"name": "userProfile",
"plural": false,
"selections": [
v4,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "displayUsername",
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "ContraImage",
"kind": "LinkedField",
"name": "avatarImage",
"plural": false,
"selections": [
v4,
v6,
v10,
v7,
v8,
v9,
v11,
v12
],
"storageKey": null
}
],
"storageKey": null
};
return {
"fragment": {
"argumentDefinitions": v0,
"kind": "Fragment",
"metadata": null,
"name": "ProfileProjectsReorderMutation",
"selections": [
{
"alias": null,
"args": v1,
"concreteType": "ReorderPortfolioProjectsPayload",
"kind": "LinkedField",
"name": "reorderPortfolioProjects",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": null,
"kind": "LinkedField",
"name": "errors",
"plural": true,
"selections": [
v2
],
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "UserProfile",
"kind": "LinkedField",
"name": "userProfile",
"plural": false,
"selections": [
{
"args": null,
"kind": "FragmentSpread",
"name": "ProfileProjects_userProfile"
}
],
"storageKey": null
}
],
"storageKey": null
}
],
"type": "Mutation",
"abstractKey": null
},
"kind": "Request",
"operation": {
"argumentDefinitions": v0,
"kind": "Operation",
"name": "ProfileProjectsReorderMutation",
"selections": [
{
"alias": null,
"args": v1,
"concreteType": "ReorderPortfolioProjectsPayload",
"kind": "LinkedField",
"name": "reorderPortfolioProjects",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": null,
"kind": "LinkedField",
"name": "errors",
"plural": true,
"selections": [
v3,
v2
],
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "UserProfile",
"kind": "LinkedField",
"name": "userProfile",
"plural": false,
"selections": [
v4,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "visitorCanEdit",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "firstName",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "profileDisplayType",
"storageKey": null
},
{
"alias": null,
"args": [
{
"kind": "Literal",
"name": "type",
"value": "ALL"
}
],
"concreteType": "UserProfilePortfolioProjectConnection",
"kind": "LinkedField",
"name": "portfolioProjects",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "UserProfilePortfolioProjectEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "PortfolioProject",
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": [
v4,
{
"alias": null,
"args": null,
"concreteType": "UserProfile",
"kind": "LinkedField",
"name": "author",
"plural": false,
"selections": [
v4
],
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "BlogCategoryConnection",
"kind": "LinkedField",
"name": "blogCategories",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "BlogCategoryEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "BlogCategory",
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": [
v4,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "name",
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
},
v5,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "slug",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "title",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "description",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "llmSuggestionId",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "publishedAt",
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": null,
"kind": "LinkedField",
"name": "cover",
"plural": false,
"selections": [
v3,
{
"kind": "TypeDiscriminator",
"abstractKey": "__isPortfolioProjectCover"
},
{
"kind": "InlineFragment",
"selections": [
{
"alias": null,
"args": null,
"concreteType": "ContraImage",
"kind": "LinkedField",
"name": "image",
"plural": false,
"selections": [
v6,
v4,
v7,
v8,
v9,
v10,
v11,
v12
],
"storageKey": null
}
],
"type": "PortfolioProjectImageCover",
"abstractKey": null
},
{
"kind": "InlineFragment",
"selections": [
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "style",
"storageKey": null
}
],
"type": "PortfolioProjectTextCover",
"abstractKey": null
}
],
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "PortfolioProjectCollaboratorConnection",
"kind": "LinkedField",
"name": "collaborators",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "PortfolioProjectCollaboratorEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": null,
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": [
v3,
v4,
{
"kind": "InlineFragment",
"selections": [
v13
],
"type": "ExistingUserCollaborator",
"abstractKey": null
}
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
},
v13,
{
"alias": null,
"args": null,
"concreteType": "PortfolioProjectContentImageConnection",
"kind": "LinkedField",
"name": "contentImages",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "PortfolioProjectContentImageEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "ContraImage",
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": [
v4,
v12,
v7,
v8,
v9,
v6,
v11,
v10
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": 'portfolioProjects(type:"ALL")'
},
v5
],
"storageKey": null
}
],
"storageKey": null
}
]
},
"params": {
"cacheID": "a30a90db89e6f6e245fe7639c8904ada",
"id": null,
"metadata": {},
"name": "ProfileProjectsReorderMutation",
"operationKind": "mutation",
"text": "mutation ProfileProjectsReorderMutation(\n $input: ReorderPortfolioProjectsInput!\n) {\n reorderPortfolioProjects(input: $input) {\n errors {\n __typename\n message\n }\n userProfile {\n ...ProfileProjects_userProfile\n id\n }\n }\n}\n\nfragment BlogCard_portfolioProject on PortfolioProject {\n id\n analyticsId\n author {\n id\n }\n blogCategories {\n edges {\n node {\n id\n name\n }\n }\n }\n slug\n title\n description\n cover {\n __typename\n ...ProjectCoverWrapper_portfolioProjectCover\n ... on PortfolioProjectImageCover {\n __typename\n image {\n id\n animated\n height\n originalFormat\n sizeBytes\n uid\n width\n ...ContraImageFragment\n }\n }\n ... on PortfolioProjectTextCover {\n __typename\n style\n }\n }\n contentImages {\n edges {\n node {\n id\n animated\n height\n originalFormat\n sizeBytes\n uid\n width\n ...ContraImageFragment\n }\n }\n }\n}\n\nfragment BlogCard_userProfile on UserProfile {\n id\n analyticsId\n visitorCanEdit\n}\n\nfragment ContraImageFragment on ContraImage {\n id\n height\n originalFormat\n sizeBytes\n uid\n url\n width\n animated\n}\n\nfragment ProfileProjects_userProfile on UserProfile {\n id\n visitorCanEdit\n firstName\n profileDisplayType\n portfolioProjects(type: ALL) {\n edges {\n node {\n id\n author {\n id\n }\n blogCategories {\n edges {\n node {\n id\n }\n }\n }\n ...ProjectCard_portfolioProject\n ...BlogCard_portfolioProject\n }\n }\n }\n ...ProjectCard_userProfile\n ...BlogCard_userProfile\n}\n\nfragment ProjectCardCollaborators_portfolioProject on PortfolioProject {\n id\n slug\n collaborators {\n edges {\n node {\n __typename\n id\n ... on ExistingUserCollaborator {\n userProfile {\n id\n displayUsername\n avatarImage {\n id\n uid\n url\n ...ContraImageFragment\n }\n }\n }\n }\n }\n }\n userProfile {\n id\n displayUsername\n avatarImage {\n id\n uid\n url\n ...ContraImageFragment\n }\n }\n}\n\nfragment ProjectCard_portfolioProject on PortfolioProject {\n id\n analyticsId\n slug\n title\n description\n llmSuggestionId\n publishedAt\n cover {\n __typename\n ...ProjectCoverWrapper_portfolioProjectCover\n }\n ...ProjectCardCollaborators_portfolioProject\n}\n\nfragment ProjectCard_userProfile on UserProfile {\n id\n analyticsId\n visitorCanEdit\n}\n\nfragment ProjectCoverWrapper_portfolioProjectCover on PortfolioProjectCover {\n __isPortfolioProjectCover: __typename\n ... on PortfolioProjectImageCover {\n __typename\n image {\n uid\n ...ContraImageFragment\n id\n }\n }\n ... on PortfolioProjectTextCover {\n __typename\n style\n }\n}\n"
}
};
}();
node$7.hash = "c38b17b902e1303ea2c9a27e9a95f36e";
const node$6 = function() {
var v0 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "id",
"storageKey": null
}, v1 = [
v0
];
return {
"argumentDefinitions": [],
"kind": "Fragment",
"metadata": null,
"name": "ProfileProjects_userProfile",
"selections": [
v0,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "visitorCanEdit",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "firstName",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "profileDisplayType",
"storageKey": null
},
{
"alias": null,
"args": [
{
"kind": "Literal",
"name": "type",
"value": "ALL"
}
],
"concreteType": "UserProfilePortfolioProjectConnection",
"kind": "LinkedField",
"name": "portfolioProjects",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "UserProfilePortfolioProjectEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "PortfolioProject",
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": [
v0,
{
"alias": null,
"args": null,
"concreteType": "UserProfile",
"kind": "LinkedField",
"name": "author",
"plural": false,
"selections": v1,
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "BlogCategoryConnection",
"kind": "LinkedField",
"name": "blogCategories",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "BlogCategoryEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "BlogCategory",
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": v1,
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
},
{
"args": null,
"kind": "FragmentSpread",
"name": "ProjectCard_portfolioProject"
},
{
"args": null,
"kind": "FragmentSpread",
"name": "BlogCard_portfolioProject"
}
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": 'portfolioProjects(type:"ALL")'
},
{
"args": null,
"kind": "FragmentSpread",
"name": "ProjectCard_userProfile"
},
{
"args": null,
"kind": "FragmentSpread",
"name": "BlogCard_userProfile"
}
],
"type": "UserProfile",
"abstractKey": null
};
}();
node$6.hash = "78f0785f2ebfbbd3d6e03f429b23cb61";
const node$5 = {
"argumentDefinitions": [],
"kind": "Fragment",
"metadata": null,
"name": "BlogCard_userProfile",
"selections": [
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "id",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "analyticsId",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "visitorCanEdit",
"storageKey": null
}
],
"type": "UserProfile",
"abstractKey": null
};
node$5.hash = "b67c56f2b0a9db1e280e568800d8471f";
const node$4 = function() {
var v0 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "id",
"storageKey": null
}, v1 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "__typename",
"storageKey": null
}, v2 = [
v0,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "animated",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "height",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "originalFormat",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "sizeBytes",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "uid",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "width",
"storageKey": null
},
{
"args": null,
"kind": "FragmentSpread",
"name": "ContraImageFragment"
}
];
return {
"argumentDefinitions": [],
"kind": "Fragment",
"metadata": null,
"name": "BlogCard_portfolioProject",
"selections": [
v0,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "analyticsId",
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "UserProfile",
"kind": "LinkedField",
"name": "author",
"plural": false,
"selections": [
v0
],
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "BlogCategoryConnection",
"kind": "LinkedField",
"name": "blogCategories",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "BlogCategoryEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "BlogCategory",
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": [
v0,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "name",
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "slug",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "title",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "description",
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": null,
"kind": "LinkedField",
"name": "cover",
"plural": false,
"selections": [
{
"args": null,
"kind": "FragmentSpread",
"name": "ProjectCoverWrapper_portfolioProjectCover"
},
{
"kind": "InlineFragment",
"selections": [
v1,
{
"alias": null,
"args": null,
"concreteType": "ContraImage",
"kind": "LinkedField",
"name": "image",
"plural": false,
"selections": v2,
"storageKey": null
}
],
"type": "PortfolioProjectImageCover",
"abstractKey": null
},
{
"kind": "InlineFragment",
"selections": [
v1,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "style",
"storageKey": null
}
],
"type": "PortfolioProjectTextCover",
"abstractKey": null
}
],
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "PortfolioProjectContentImageConnection",
"kind": "LinkedField",
"name": "contentImages",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "PortfolioProjectContentImageEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "ContraImage",
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": v2,
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
}
],
"type": "PortfolioProject",
"abstractKey": null
};
}();
node$4.hash = "871aef3b0d7622d26a2d10d0b576e3cd";
const BORDER_RADIUS = 20;
const MOBILE_PROJECT_CARD_PADDING = 16;
const Card = styled(Card$1).attrs({ removeBoxShadow: true })`
${({ theme, isDragging = false, empty = false, disabled = false }) => Ce`
height: auto;
width: 100%;
max-width: ${MOBILE_PROJECT_COVER_WIDTH + MOBILE_PROJECT_CARD_PADDING * 2}px;
border-radius: 20px;
padding: 16px;
margin: 0 auto;
position: relative;
${theme.mediaQueries.md} {
height: 100%;
}
${theme.mediaQueries.lg} {
height: auto;
}
${theme.mediaQueries.xl} {
padding: 30px;
margin: unset;
max-width: unset;
}
border: 1px solid ${theme.colorsV2.gray30};
${isDragging && Ce`
box-shadow: 0 0 20px rgba(0, 0, 0, 0.08);
`}
${disabled && Ce`
opacity: 0.3;
`}
${empty && Ce`
height: 244px;
${theme.mediaQueries.xl} {
height: 244px;
}
`}
`}
`;
const Body$1 = styled.div`
${({ theme }) => Ce`
display: flex;
flex-direction: column;
height: inherit;
${theme.mediaQueries.xl} {
flex-direction: row;
}
`}
`;
const Cover = styled(Link)`
${({ theme }) => Ce`
display: flex;
margin-bottom: 12px;
border-radius: 10px;
max-width: ${MOBILE_PROJECT_COVER_WIDTH}px;
width: 100%;
${theme.mediaQueries.xl} {
max-width: ${PROJECT_COVER_WIDTH}px;
margin-right: 20px;
margin-bottom: unset;
}
`}
`;
const Details = styled.div`
${({
addEditButtonPadding = false,
preview = false,
isGuideProject = false,
theme
}) => Ce`
display: flex;
flex-direction: column;
width: 100%;
height: inherit;
& > * + * {
margin-top: 16px;
}
${preview && Ce`
& > * + * {
margin-top: 8px;
}
`}
${isGuideProject && Ce`
& > * + * {
margin-top: 16px;
}
& > :nth-child(2) {
margin-top: 4px;
}
`}
${addEditButtonPadding && Ce`
${theme.mediaQueries.xl} {
padding-right: 32px;
}
`}
`}
`;
const Title$2 = styled(Text).attrs({
as: Link,
textStyle: "fifthLevelHeadline"
})`
display: -webkit-box;
-webkit-line-clamp: 3;
-webkit-box-orient: vertical;
overflow: hidden;
`;
const Description = styled(Text).attrs({
textStyle: "bodyRegular"
})`
${({ theme }) => Ce`
margin-top: 8px;
color: ${theme.colorsV2.gray70};
word-break: break-word;
`}
`;
const PreviewBody = styled.div`
margin-bottom: 24px;
`;
const Footer = styled.div`
${({ theme }) => Ce`
display: flex;
justify-content: space-between;
align-items: center;
margin-top: 16px;
${theme.mediaQueries.xl} {
margin-top: auto;
}
`}
`;
const Content = styled.div`
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
z-index: 0;
border-top-left-radius: inherit;
border-top-right-radius: inherit;
overflow: hidden;
`;
const CardSortHandle = styled.div`
${({ theme }) => Ce`
position: absolute;
top: 8px;
left: 8px;
padding: 8px 4px;
z-index: 1;
margin: 12px;
border-radius: 7px;
cursor: move;
touch-action: none;
background-color: rgba(19, 19, 19, 0.4);
color: ${theme.colorsV2.white};
${theme.mediaQueries.xl} {
top: -4px;
left: -8px;
background-color: transparent;
color: ${theme.colorsV2.black};
}
`}
`;
const Button = styled.div`
${({ theme }) => Ce`
position: absolute;
top: 20px;
right: 20px;
z-index: 1;
${theme.mediaQueries.xl} {
top: 12px;
right: 12px;
}
`}
`;
const MenuButton = styled(CircularIconButton)`
border: none;
`;
const NoProject = styled.div`
${({ theme }) => Ce`
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
height: 336px;
width: 100%;
padding: 36px;
${dashedBorderBackground({
radius: BORDER_RADIUS,
stroke: theme.colorsV2.black
})}
${theme.mediaQueries.md} {
align-items: start;
}
${theme.mediaQueries.xl} {
height: 440px;
}
`}
`;
const GuideTitle = styled(Text).attrs({ textStyles: "bodySmall" })`
${({ theme }) => Ce`
color: ${theme.colorsV2.gray60};
`}
`;
const GuideButton = styled.button`
${({ theme }) => Ce`
display: flex;
align-items: center;
flex-direction: row;
padding: 4px 12px;
background-color: ${theme.colorsV2.gray20};
color: ${theme.colorsV2.gray70};
font-weight: 600;
font-size: 0.8rem;
border-radius: 40px;
transition: background-color 0.2s ease-in-out;
${theme.mediaQueries.sm} {
font-size: 1rem;
padding: 6px 16px;
}
&:hover,
&:focus {
background-color: ${theme.colorsV2.gray30};
}
`}
`;
const GuideButtonIcon = styled.div`
display: flex;
margin-left: 4px;
`;
const FauxCover = styled.div`
position: relative;
padding-top: ${100 / PROJECT_COVER_ASPECT_RATIO}%;
`;
const ProjectPreview = Object.assign(
{},
{
Body: Body$1,
Button,
Card,
CardSortHandle,
Content,
Cover,
Description,
Details,
FauxCover,
Footer,
GuideButton,
GuideButtonIcon,
GuideTitle,
MenuButton,
NoProject,
PreviewBody,
Title: Title$2
}
);
const CategoriesDescriptionContainer = styled.div`
display: flex;
flex-direction: column;
gap: 8px;
`;
const CategoryRow = styled(Flex.Row)`
${({
theme
}) => Ce`
gap: 8px;
margin: 16px 0 0;
${theme.mediaQueries.lg} {
margin-top: auto;
}
`}
`;
const BlogCard = ({
canEdit,
isGuideProject,
portfolioProject,
sortableListeners,
isDragging,
disabled,
position,
userProfileRef
}) => {
var _a;
const data = reactRelayExports.useFragment(node$4, portfolioProject);
const user = reactRelayExports.useFragment(node$5, userProfileRef ?? null);
const blogCategories = ((_a = data.blogCategories) == null ? void 0 : _a.edges.map(({
node: {
id: categoryId,
name
}
}) => ({
id: categoryId,
name
}))) ?? [];
const [editMenuOpen, setEditMenuOpen] = reactExports.useState(false);
const [showDeleteProjectModal, setShowDeleteProjectModal] = reactExports.useState(false);
const toggleMenu = reactExports.useCallback(() => {
setEditMenuOpen((open) => !open);
}, [setEditMenuOpen]);
const toggleDeleteProjectModal = reactExports.useCallback(() => {
setShowDeleteProjectModal((open) => !open);
}, []);
const {
track
} = useAnalytics();
const navigation = useNavigation();
const onViewedRef = useOnElementViewed(() => {
if (data && user && typeof position === "number") {
track("portfolio_project_card", {
action: "viewed",
is_owner: user.visitorCanEdit,
owner_id: user.analyticsId,
portfolio_project_id: data.analyticsId,
position_index: position,
section: "profile"
});
}
});
if (!data) {
return null;
}
const {
id,
cover,
slug,
title,
description
} = data;
const shouldDisplaySortHandle = canEdit && sortableListeners;
return /* @__PURE__ */ jsxs(Fragment, {
children: [/* @__PURE__ */ jsxs(ProjectPreview.Card, {
disabled,
elementRef: onViewedRef,
isDragging,
children: [shouldDisplaySortHandle && /* @__PURE__ */ jsx(ProjectPreview.CardSortHandle, {
role: "button",
tabIndex: 0,
...sortableListeners,
children: /* @__PURE__ */ jsx(MoveIcon, {
size: 20
})
}), canEdit && /* @__PURE__ */ jsx(ProjectPreview.Button, {
children: /* @__PURE__ */ jsxs(Menu, {
isOpen: editMenuOpen,
placement: "bottom-end",
toggleMenu,
children: [/* @__PURE__ */ jsx(Menu.Reference, {
children: /* @__PURE__ */ jsx(ProjectPreview.MenuButton, {
"aria-label": "Open project menu",
icon: MoreIcon,
onClick: toggleMenu,
variant: "V2TertiaryOutline"
})
}), /* @__PURE__ */ jsxs(Menu.Panel, {
children: [/* @__PURE__ */ jsx(Menu.Item, {
icon: EditIcon,
onClick: () => {
navigation.push(routeHelpers.projectEdit({
slug
}));
},
children: "Edit Project"
}), /* @__PURE__ */ jsx(Menu.Item, {
icon: CloseIcon,
onClick: toggleDeleteProjectModal,
children: /* @__PURE__ */ jsx(Text, {
color: "alertError",
children: "Delete Project"
})
})]
})]
})
}), /* @__PURE__ */ jsxs(ProjectPreview.Body, {
children: [/* @__PURE__ */ jsx(ProjectPreview.Cover, {
onClick: () => {
if (position && user) {
track("portfolio_project_card", {
action: "tapped",
cta: "image",
is_owner: user.visitorCanEdit,
owner_id: user.analyticsId,
portfolio_project_id: data.analyticsId,
position_index: position,
section: "profile"
});
}
},
to: (routes) => routes.project({
slug
}),
children: /* @__PURE__ */ jsx(ProjectCoverWrapper, {
coverRef: cover
})
}), /* @__PURE__ */ jsxs(ProjectPreview.Details, {
addEditButtonPadding: canEdit,
children: [isGuideProject ? /* @__PURE__ */ jsx(ProjectPreview.GuideTitle, {
children: "Only you can see this"
}) : null, /* @__PURE__ */ jsx(ProjectPreview.Title, {
onClick: () => {
if (position && user) {
track("portfolio_project_card", {
action: "tapped",
cta: "title",
is_owner: user.visitorCanEdit,
owner_id: user.analyticsId,
portfolio_project_id: data.analyticsId,
position_index: position,
section: "profile"
});
}
},
to: (routes) => routes.project({
slug
}),
children: title
}), /* @__PURE__ */ jsxs(CategoriesDescriptionContainer, {
children: [description ? /* @__PURE__ */ jsx(ProjectPreview.Description, {
color: "uiBlackMediumEmphasis",
textStyle: "bodySmall",
children: description
}) : null, blogCategories.length ? /* @__PURE__ */ jsx(CategoryRow, {
children: /* @__PURE__ */ jsx(BlogCategoriesList, {
categories: blogCategories,
limit: 3,
size: "small"
})
}) : null]
})]
})]
})]
}), /* @__PURE__ */ jsx(DeletePortfolioProjectModal, {
isOpen: showDeleteProjectModal,
onCancel: toggleDeleteProjectModal,
projectId: id
})]
});
};
const node$3 = {
"argumentDefinitions": [],
"kind": "Fragment",
"metadata": null,
"name": "ProjectCard_userProfile",
"selections": [
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "id",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "analyticsId",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "visitorCanEdit",
"storageKey": null
}
],
"type": "UserProfile",
"abstractKey": null
};
node$3.hash = "96d84e478f5d1dc7f2f30bbf69e9b394";
const node$2 = {
"argumentDefinitions": [],
"kind": "Fragment",
"metadata": null,
"name": "ProjectCard_portfolioProject",
"selections": [
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "id",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "analyticsId",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "slug",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "title",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "description",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "llmSuggestionId",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "publishedAt",
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": null,
"kind": "LinkedField",
"name": "cover",
"plural": false,
"selections": [
{
"args": null,
"kind": "FragmentSpread",
"name": "ProjectCoverWrapper_portfolioProjectCover"
}
],
"storageKey": null
},
{
"args": null,
"kind": "FragmentSpread",
"name": "ProjectCardCollaborators_portfolioProject"
}
],
"type": "PortfolioProject",
"abstractKey": null
};
node$2.hash = "691d31ad06a21c8ed8ec6bfe98a90fa4";
const node$1 = function() {
var v0 = {
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "id",
"storageKey": null
}, v1 = {
"alias": null,
"args": null,
"concreteType": "UserProfile",
"kind": "LinkedField",
"name": "userProfile",
"plural": false,
"selections": [
v0,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "displayUsername",
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "ContraImage",
"kind": "LinkedField",
"name": "avatarImage",
"plural": false,
"selections": [
v0,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "uid",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "url",
"storageKey": null
},
{
"args": null,
"kind": "FragmentSpread",
"name": "ContraImageFragment"
}
],
"storageKey": null
}
],
"storageKey": null
};
return {
"argumentDefinitions": [],
"kind": "Fragment",
"metadata": null,
"name": "ProjectCardCollaborators_portfolioProject",
"selections": [
v0,
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "slug",
"storageKey": null
},
{
"alias": null,
"args": null,
"concreteType": "PortfolioProjectCollaboratorConnection",
"kind": "LinkedField",
"name": "collaborators",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "PortfolioProjectCollaboratorEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": null,
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "__typename",
"storageKey": null
},
v0,
{
"kind": "InlineFragment",
"selections": [
v1
],
"type": "ExistingUserCollaborator",
"abstractKey": null
}
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
},
v1
],
"type": "PortfolioProject",
"abstractKey": null
};
}();
node$1.hash = "fe19b97b06234542e398f96e1d21b261";
const useIsExtraLargeScreen = () => {
const { isBelowExtraLargeBreakpoint } = reactExports.useContext(WindowDimensionsContext);
return !isBelowExtraLargeBreakpoint;
};
const Container = styled.div`
display: flex;
align-items: center;
`;
const ProjectCardCollaborators = ({
canEdit,
node: nodeRef,
showOwnerOnly = false
}) => {
const data = reactRelayExports.useFragment(node$1, nodeRef);
const {
hasOnboardedAtAll
} = useHasOnboarded();
const isUserApproved = hasOnboardedAtAll;
const isExtraLargeScreen = useIsExtraLargeScreen();
const COLLABORATORS_SIZE = isExtraLargeScreen ? "sm" : "xs";
const {
collaborators,
userProfile
} = data;
const collaboratorsData = collaborators.edges.map(({
node: node2
}) => {
var _a, _b;
return {
avatarImage: (_a = node2.userProfile) == null ? void 0 : _a.avatarImage,
displayUsername: (_b = node2 == null ? void 0 : node2.userProfile) == null ? void 0 : _b.displayUsername,
key: node2.id
};
});
if (!data) {
return /* @__PURE__ */ jsx(Container, {
children: /* @__PURE__ */ jsx(Avatar, {
size: COLLABORATORS_SIZE
})
});
}
return /* @__PURE__ */ jsx(Container, {
children: canEdit && collaborators.edges.length === 0 || showOwnerOnly ? /* @__PURE__ */ jsx(Avatar, {
avatarImage: userProfile.avatarImage,
size: COLLABORATORS_SIZE
}) : /* @__PURE__ */ jsx(AvatarGroup, {
data: [{
avatarImage: userProfile.avatarImage,
displayUsername: userProfile.displayUsername,
key: userProfile.id
}, ...isUserApproved ? collaboratorsData : []],
maxCount: 3,
size: COLLABORATORS_SIZE
})
});
};
const ProjectDraftTag = () => {
const tooltipContent = "Only you can see this project";
return /* @__PURE__ */ jsx(
Tooltip,
{
content: tooltipContent,
placement: "top",
width: "270",
children: /* @__PURE__ */ jsxs(Container$1, { children: [
/* @__PURE__ */ jsx(EyeOffIcon, { size: 16 }),
/* @__PURE__ */ jsx(Text, { textStyle: "captionRegular", children: "Draft" })
] })
}
);
};
const ProjectCard = ({
canEdit,
isGuideProject,
portfolioProject,
sortableListeners,
isDragging,
disabled,
position,
userProfileRef,
onHideGuideProjectCard
}) => {
const data = reactRelayExports.useFragment(node$2, portfolioProject);
const user = reactRelayExports.useFragment(node$3, userProfileRef ?? null);
const isMobile = useIsMobile();
const [editMenuOpen, setEditMenuOpen] = reactExports.useState(false);
const [showDeleteProjectModal, setShowDeleteProjectModal] = reactExports.useState(false);
const toggleMenu = reactExports.useCallback(() => {
setEditMenuOpen((open) => !open);
}, [setEditMenuOpen]);
const toggleDeleteProjectModal = reactExports.useCallback(() => {
setShowDeleteProjectModal((open) => !open);
}, []);
const {
track
} = useAnalytics();
const navigation = useNavigation();
const onViewedRef = useOnElementViewed(() => {
if (data && user && typeof position === "number") {
track("portfolio_project_card", {
action: "viewed",
is_owner: user.visitorCanEdit,
owner_id: user.analyticsId,
portfolio_project_id: data.analyticsId,
position_index: position,
section: "profile"
});
}
});
if (!data) {
return null;
}
const {
id,
cover,
slug,
title,
description,
publishedAt,
llmSuggestionId
} = data;
const shouldDisplaySortHandle = canEdit && sortableListeners;
const isDraft = publishedAt === null;
const isProfileMagicSuggestion = isDraft && llmSuggestionId;
const suggestionTag = isProfileMagicSuggestion ? /* @__PURE__ */ jsx(SuggestedTag, {}) : null;
const draftTag = isDraft ? /* @__PURE__ */ jsx(ProjectDraftTag, {}) : null;
return /* @__PURE__ */ jsxs(Fragment, {
children: [/* @__PURE__ */ jsxs(ProjectPreview.Card, {
disabled,
elementRef: onViewedRef,
isDragging,
children: [shouldDisplaySortHandle && /* @__PURE__ */ jsx(ProjectPreview.CardSortHandle, {
role: "button",
tabIndex: 0,
...sortableListeners,
children: /* @__PURE__ */ jsx(MoveIcon, {
size: 20
})
}), canEdit && /* @__PURE__ */ jsx(ProjectPreview.Button, {
children: /* @__PURE__ */ jsxs(Menu, {
isOpen: editMenuOpen,
placement: "bottom-end",
toggleMenu,
children: [/* @__PURE__ */ jsx(Menu.Reference, {
children: /* @__PURE__ */ jsx(ProjectPreview.MenuButton, {
"aria-label": "Open project menu",
icon: MoreIcon,
onClick: toggleMenu,
variant: "V2Link"
})
}), /* @__PURE__ */ jsxs(Menu.Panel, {
children: [/* @__PURE__ */ jsx(Menu.Item, {
icon: EditIcon,
onClick: () => {
navigation.push(routeHelpers.projectEdit({
slug
}));
},
children: "Edit Project"
}), /* @__PURE__ */ jsx(Menu.Item, {
icon: CloseIcon,
onClick: toggleDeleteProjectModal,
children: /* @__PURE__ */ jsx(Text, {
color: "alertError",
children: "Delete Project"
})
})]
})]
})
}), /* @__PURE__ */ jsxs(ProjectPreview.Body, {
children: [/* @__PURE__ */ jsx(ProjectPreview.Cover, {
onClick: () => {
if (position && user) {
track("portfolio_project_card", {
action: "tapped",
cta: "image",
is_owner: user.visitorCanEdit,
owner_id: user.analyticsId,
portfolio_project_id: data.analyticsId,
position_index: position,
section: "profile"
});
}
},
to: (routes) => isDraft ? routes.projectEdit({
slug
}) : routes.project({
slug
}),
children: /* @__PURE__ */ jsx(ProjectCoverWrapper, {
coverRef: cover
})
}), /* @__PURE__ */ jsxs(ProjectPreview.Details, {
addEditButtonPadding: canEdit,
isGuideProject,
children: [isGuideProject ? /* @__PURE__ */ jsx(ProjectPreview.GuideTitle, {
children: "Only you can see this"
}) : null, isMobile || isProfileMagicSuggestion ? isProfileMagicSuggestion ? suggestionTag : draftTag : null, /* @__PURE__ */ jsx(ProjectPreview.Title, {
onClick: () => {
if (position && user) {
track("portfolio_project_card", {
action: "tapped",
cta: "title",
is_owner: user.visitorCanEdit,
owner_id: user.analyticsId,
portfolio_project_id: data.analyticsId,
position_index: position,
section: "profile"
});
}
},
to: (routes) => isDraft ? routes.projectEdit({
slug
}) : routes.project({
slug
}),
children: title
}), description ? /* @__PURE__ */ jsx(ProjectPreview.Description, {
children: description
}) : null, /* @__PURE__ */ jsxs(ProjectPreview.Footer, {
children: [isMobile || isProfileMagicSuggestion ? null : draftTag, description ? null : /* @__PURE__ */ jsx(ProjectCardCollaborators, {
canEdit,
node: data,
showOwnerOnly: isGuideProject
}), isGuideProject ? /* @__PURE__ */ jsxs(ProjectPreview.GuideButton, {
onClick: (event) => {
event == null ? void 0 : event.stopPropagation();
onHideGuideProjectCard == null ? void 0 : onHideGuideProjectCard();
},
children: ["Don’t Show This Again", /* @__PURE__ */ jsx(ProjectPreview.GuideButtonIcon, {
children: /* @__PURE__ */ jsx(CloseIcon, {
size: 24
})
})]
}) : null]
})]
})]
})]
}), /* @__PURE__ */ jsx(DeletePortfolioProjectModal, {
isOpen: showDeleteProjectModal,
onCancel: toggleDeleteProjectModal,
projectId: id
})]
});
};
const isBlogCategorySlug = (key) => {
return Object.prototype.hasOwnProperty.call(CATEGORY_SLUG_MAP, key);
};
const MOBILE_PROJECT_CARD_WIDTH = MOBILE_PROJECT_COVER_WIDTH + 16 * 2;
const flexColumnStyles = Ce`
display: flex;
flex-direction: column;
justify-content: center;
& > * + * {
margin-top: 16px;
}
`;
const MenuItem = styled.div`
display: flex;
flex-flow: row nowrap;
align-items: center;
padding: 8px 0;
& > *:not(:last-child) {
margin-right: 8px;
}
`;
const FilterPanelButton = styled.button`
${({
theme
}) => Ce`
width: 100%;
border: none;
padding: 32px 0 24px 0;
color: ${theme.colorsV2.gray70};
font-size: ${theme.textStyles.subtitleSmall.fontSize};
font-weight: 600;
display: flex;
flex-flow: row nowrap;
align-items: center;
& > svg {
margin-right: 4px;
}
`}
`;
const CategoryLabel = styled(Text).attrs({
textStyle: "subtitleRegular"
})`
margin-top: 8px;
`;
const FilterHeader = styled.div`
${({
theme
}) => Ce`
display: flex;
flex-flow: column nowrap;
margin-top: 24px;
margin-bottom: 32px;
${theme.mediaQueries.md} {
flex-flow: row nowrap;
& > *:not(:last-child) {
margin-right: 44px;
}
}
`}
`;
const CategoryTags = styled.div`
${({
theme
}) => Ce`
display: flex;
flex-flow: row wrap;
flex-grow: 1;
border-bottom: 1px solid ${theme.colorsV2.gray30};
justify-content: center;
padding-bottom: 8px;
& > * {
margin-top: 8px;
&:not(:last-child) {
margin-right: 8px;
}
}
${theme.mediaQueries.md} {
border: none;
justify-content: start;
}
`}
`;
const ProjectCards = styled(animated.div)`
${({
theme
}) => Ce`
position: relative;
margin-top: 24px;
${flexColumnStyles}
${theme.mediaQueries.md} {
display: grid;
grid-template-columns: ${MOBILE_PROJECT_CARD_WIDTH}px ${MOBILE_PROJECT_CARD_WIDTH}px;
grid-row-gap: 16px;
grid-column-gap: 16px;
& > * + * {
margin-top: unset;
}
}
${theme.mediaQueries.lg} {
grid-row-gap: unset;
${flexColumnStyles}
}
`}
`;
const ProfileProjects = ({
profileKey,
blogCategories,
showLinkedProjectsModal
}) => {
const profile = reactRelayExports.useFragment(node$6, profileKey);
const [updateProjectOrder] = reactRelayExports.useMutation(node$7);
const onProjectIdsSorted = reactExports.useCallback((ids) => {
updateProjectOrder({
variables: {
input: {
portfolioProjects: ids
}
}
});
}, [updateProjectOrder]);
const categorySlug = useRouteParameter("categorySlug");
const currentCategory = reactExports.useMemo(() => {
if (categorySlug && isBlogCategorySlug(categorySlug)) {
return CATEGORY_SLUG_MAP[categorySlug];
}
return null;
}, [categorySlug]);
const [isFiltersOpen, toggleFilters] = useToggle(false);
const {
selectedUserType
} = useUserTypeSelector();
const isMobile = useIsMobile();
const isBlogProfile = profile.profileDisplayType === "BLOG";
const projects = reactExports.useMemo(() => {
const filteredProjects = profile.portfolioProjects.edges.map((edge) => edge.node);
if (isBlogProfile && currentCategory) {
return currentCategory ? filteredProjects.filter(({
blogCategories: currentProjectCategories
}) => {
const categoryIds = (currentProjectCategories == null ? void 0 : currentProjectCategories.edges.map(({
node: {
id: projectCategoryId
}
}) => projectCategoryId)) ?? [];
return categoryIds.includes(currentCategory);
}) : filteredProjects;
}
return filteredProjects;
}, [profile.portfolioProjects.edges, isBlogProfile, currentCategory]);
const hasProjects = projects.length > 0;
const shouldDisableSorting = (
// use has edit permissions
!profile.visitorCanEdit || // we have less than 2 projects to disable
projects.length < 2
);
const sortState = useSortableListView({
data: projects,
disabled: shouldDisableSorting,
onDataIdsSorted: onProjectIdsSorted
});
const {
sortedNodeIds,
sortedData,
activeSortId,
disabled,
...sortListProps
} = sortState;
const handleCreateProjectClick = reactExports.useCallback((event) => {
showLinkedProjectsModal == null ? void 0 : showLinkedProjectsModal(event);
}, [showLinkedProjectsModal]);
if (!sortedData || !sortedNodeIds) {
return null;
}
const blogCategoriesWithAll = [{
id: "all",
name: "All"
}, ...blogCategories];
return /* @__PURE__ */ jsxs(Fragment, {
children: [isBlogProfile ? /* @__PURE__ */ jsx(Fragment, {
children: isMobile ? /* @__PURE__ */ jsxs(Menu, {
isOpen: isFiltersOpen,
toggleMenu: toggleFilters,
children: [/* @__PURE__ */ jsx(Menu.Reference, {
children: /* @__PURE__ */ jsxs(FilterPanelButton, {
"aria-label": "open filter panel",
onClick: () => toggleFilters(),
type: "button",
children: [/* @__PURE__ */ jsx(FilterIcon, {}), "Filters"]
})
}), /* @__PURE__ */ jsxs(Menu.Panel, {
children: [/* @__PURE__ */ jsx(CategoryLabel, {
children: "Category"
}), blogCategoriesWithAll.filter(({
name
}) => !["contra for independents", "contra for clients"].includes(name.trim().toLowerCase())).map(({
id: categoryKey,
name
}) => /* @__PURE__ */ jsx(MenuItem, {
onClick: () => toggleFilters(),
children: /* @__PURE__ */ jsx(Link, {
to: getCategoryHref({
id: categoryKey,
name
}),
children: /* @__PURE__ */ jsx(Text, {
as: "label",
color: "uiBlackHighEmphasis",
htmlFor: categoryKey,
textStyle: "bodyRegular",
children: name
})
})
}, categoryKey))]
})]
}) : /* @__PURE__ */ jsx(FilterHeader, {
children: /* @__PURE__ */ jsx(CategoryTags, {
children: /* @__PURE__ */ jsx(BlogCategoriesList, {
asLinks: true,
categories: blogCategoriesWithAll,
hideGroupingCategories: true,
selectedCategory: currentCategory
})
})
})
}) : null, !hasProjects && !profile.visitorCanEdit ? /* @__PURE__ */ jsx(BlankCardMessage, {
children: isBlogProfile ? /* @__PURE__ */ jsx(Fragment, {
children: "No posts found! "
}) : /* @__PURE__ */ jsxs(Fragment, {
children: [formatName({
firstName: profile.firstName
}, "firstName"), " hasn't added any work yet"]
})
}) : null, profile.visitorCanEdit ? /* @__PURE__ */ jsx(CreateCard, {
onCreateClick: handleCreateProjectClick,
variant: selectedUserType === "CLIENT" ? "client-work" : "project"
}) : null, /* @__PURE__ */ jsx(ProjectCards, {
animate: "show",
exit: "hidden",
initial: "hidden",
variants: STAGGERED_CHILDREN_CONTAINER_VARIANTS,
children: /* @__PURE__ */ jsx(SortableListView, {
sortedNodeIds,
...sortListProps,
children: sortedData.map((node2, index) => {
return /* @__PURE__ */ jsx(animated.div, {
variants: STAGGERED_CHILD_VARIANTS,
children: /* @__PURE__ */ jsx(SortableListItemWithClonedElement, {
activeSortId,
disabled,
sortId: node2.id,
children: node2.author ? /* @__PURE__ */ jsx(BlogCard, {
canEdit: profile.visitorCanEdit,
portfolioProject: node2,
position: index,
userProfileRef: profile
}, node2.id) : /* @__PURE__ */ jsx(ProjectCard, {
canEdit: profile.visitorCanEdit,
portfolioProject: node2,
position: index,
userProfileRef: profile
}, node2.id)
})
}, node2.id);
})
})
})]
});
};
const SET_HAS_PROCESS_STARTED = "SET_HAS_PROCESS_STARTED";
const SET_IS_LINKED_MODAL_OPEN = "SET_IS_LINKED_MODAL_OPEN";
const SET_IS_SCRATCH_MODAL_OPEN = "SET_IS_SCRATCH_MODAL_OPEN";
const SET_IS_BLOG_MODAL_OPEN = "SET_IS_BLOG_MODAL_OPEN";
const HANDOVER_TO_TEMPLATES_MODAL = "HANDOVER_TO_TEMPLATES_MODAL";
const SET_SELECTED_TEMPLATE = "SET_SELECTED_TEMPLATE";
const SET_LINK_DETAILS = "SET_LINK_DETAILS";
const SET_PROJECT_COVER = "SET_PROJECT_COVER";
const ON_CHANGE = "ON_CHANGE";
const SET_BRAND_ID = "SET_BRAND_ID";
const SET_VALIDATION_ERROR = "SET_VALIDATION_ERROR";
const RESET_STATE = "RESET_STATE";
const REPLACE_STATE = "REPLACE_STATE";
const BlogProjectDetailsModal = ({
isOpen,
onClose
}) => {
return /* @__PURE__ */ jsxs(
Modal,
{
isOpen,
modalName: "identity_blog_project_details_modal",
onClose,
size: "xxl",
children: [
/* @__PURE__ */ jsx(ModalClose, { onClose }),
/* @__PURE__ */ jsx(ModalBody$2, { children: /* @__PURE__ */ jsx(
ProjectDetailsForm,
{
isBlog: true,
onClose
}
) })
]
}
);
};
const ProjectLinkFormContainer = styled.div`
display: flex;
flex-direction: column;
align-items: center;
`;
const Header = styled.div`
width: 100%;
display: flex;
flex-direction: column;
align-items: center;
`;
const Title$1 = styled(Text).attrs({ textStyle: "fifthLevelHeadline" })`
text-align: center;
`;
const Body = styled(Text)`
${({ theme, isBrandSelected }) => Ce`
width: 100%;
text-align: center;
transition-property: opacity;
transition-duration: ${isBrandSelected ? 0.1 : 0.4}s;
transition-timing-function: ${isBrandSelected ? "ease-out" : "step-end"};
${theme.mediaQueries.sm} {
width: 312px;
}
`}
`;
const ScrollingBrandStripContainer = styled.div`
margin: 24px 0;
width: 100%;
`;
const Form = styled.form`
${({ theme }) => Ce`
margin-top: 16px;
width: 100%;
display: flex;
flex-direction: column;
align-items: center;
${theme.mediaQueries.sm} {
width: 488px;
}
`}
`;
const TextLabel = styled(TextField.Label)`
display: none;
`;
const ButtonsContainer$1 = styled.div`
${({ theme }) => Ce`
margin: 0 auto;
width: 100%;
& > button {
width: 100%;
}
${theme.mediaQueries.sm} {
width: 280px;
}
`}
`;
const FullWidthButton = styled(Button$1)`
width: 100%;
`;
const SeparatorContainer = styled.div`
display: flex;
justify-content: center;
align-items: center;
`;
const SeparatorText = styled(Text).attrs({ textStyle: "overline" })`
${({ theme }) => Ce`
text-transform: uppercase;
color: ${theme.colorsV2.gray60};
margin: 0 8px;
line-height: 1;
`}
`;
const HorizontalLine = styled.div`
${({ theme }) => Ce`
width: 32px;
height: 1px;
border-top: 1px solid ${theme.colorsV2.gray40};
`}
`;
const ModalBody$1 = styled(Modal.Body)`
${({ theme }) => Ce`
display: flex;
flex-direction: column;
align-items: center;
margin: 32px;
${theme.mediaQueries.lg} {
margin: 48px;
}
`}
`;
const BlogButton = styled(Button$1)`
margin-top: 24px;
& svg {
padding-top: 4px;
margin-left: 8px;
}
`;
const CreateProjectModal = ({
isOpen,
dispatch,
resetState,
state,
onLinkSubmit,
onClose,
isSubmitting
}) => {
const isMobile = useIsMobile();
const identityProjectBlogPosts = useFeatureFlag("identityProjectBlogPosts");
const { url, brandId, hasProcessStarted, errors } = state;
const validProjectUrl = url && isValidPublicUrl(url) ? url : void 0;
const location2 = useLocation();
const navigation = useNavigation();
const createNewProjectParameter = useSearchParameter(
"createNewProject",
"boolean"
);
const { track: trackInputs } = useTrackInput({ url }, "create_project_modal");
const { track } = useAnalytics();
const { dispatch: editorDispatch } = reactExports.useContext(ProjectEditorContext);
const onCreateLinkedProject = reactExports.useCallback(() => {
trackInputs();
onLinkSubmit();
}, [onLinkSubmit, trackInputs]);
const handleSubmitForm = reactExports.useCallback(
(event) => {
event.preventDefault();
onCreateLinkedProject();
},
[onCreateLinkedProject]
);
const onCreateBlogProject = reactExports.useCallback(() => {
track("modal", {
action: "tapped",
cta: "create_blog",
modal_name: "create_project_modal"
});
dispatch({
payload: true,
type: "SET_IS_BLOG_MODAL_OPEN"
});
editorDispatch({
type: "SET_IS_BLOG"
});
onClose();
}, [track, dispatch, editorDispatch, onClose]);
const onCreateScratchProject = reactExports.useCallback(() => {
track("modal", {
action: "tapped",
cta: "secondary",
modal_name: "create_project_modal"
});
dispatch({
payload: true,
type: "SET_IS_SCRATCH_MODAL_OPEN"
});
onClose();
}, [track, dispatch, onClose]);
const handleClose = reactExports.useCallback(() => {
track("modal", {
action: "tapped",
cta: "close",
modal_name: "create_project_modal"
});
resetState();
onClose();
if (createNewProjectParameter) {
navigation.replace(
removeSearchParameter(location2.path, "createNewProject")
);
}
}, [
createNewProjectParameter,
location2.path,
navigation,
onClose,
resetState,
track
]);
const onUrlChange = reactExports.useCallback(
(event) => {
dispatch({ payload: event.target, type: "ON_CHANGE" });
setTimeout(() => {
var _a;
const brandDetails = getMaybeBrandDetailsFromLink((_a = event.target) == null ? void 0 : _a.value);
dispatch({
payload: (brandDetails == null ? void 0 : brandDetails.id) ?? null,
type: "SET_BRAND_ID"
});
}, 0);
},
[dispatch]
);
const urlError = reactExports.useMemo(() => (errors == null ? void 0 : errors.path) === "url", [errors]);
return /* @__PURE__ */ jsxs(
Modal,
{
isKeyboardDismissDisabled: true,
isOpen,
modalName: "create_project_modal",
onClose: handleClose,
preventAutoFocus: isMobile,
children: [
/* @__PURE__ */ jsx(Modal.Close, { onClose: handleClose }),
/* @__PURE__ */ jsx(ModalBody$1, { children: /* @__PURE__ */ jsxs(ProjectLinkFormContainer, { children: [
/* @__PURE__ */ jsxs(Header, { children: [
brandId ? null : /* @__PURE__ */ jsx(Title$1, { children: "Paste in your project URL" }),
/* @__PURE__ */ jsx(ScrollingBrandStripContainer, { children: /* @__PURE__ */ jsx(ScrollingBrandStrip, { selectedBrandId: brandId ?? void 0 }) }),
/* @__PURE__ */ jsx(
Body,
{
isBrandSelected: brandId !== void 0,
textStyle: "bodyRegular",
children: "Any link, from any platform – share what best demonstrates your work."
}
)
] }),
/* @__PURE__ */ jsxs(Form, { onSubmit: handleSubmitForm, children: [
/* @__PURE__ */ jsxs(
FormField,
{
hasError: Boolean(urlError),
width: "100%",
children: [
/* @__PURE__ */ jsxs(TextField, { hasError: Boolean(urlError), children: [
/* @__PURE__ */ jsx(TextLabel, { htmlFor: "txtUrl", children: "URL" }),
/* @__PURE__ */ jsx(TextField.InputGroup, { children: /* @__PURE__ */ jsx(
TextField.Input,
{
"aria-label": "Project URL",
autoCapitalize: "off",
autoComplete: "url",
defaultValue: validProjectUrl,
disabled: isSubmitting,
inputMode: "url",
name: "url",
onInput: onUrlChange,
placeholder: "Paste in your project URL",
type: "text"
}
) })
] }),
/* @__PURE__ */ jsx(FormField.Error, { children: "This is not a valid URL" })
]
}
),
/* @__PURE__ */ jsxs(ButtonsContainer$1, { children: [
/* @__PURE__ */ jsx(
FullWidthButton,
{
isLoading: isSubmitting,
my: "16px",
onClick: onCreateLinkedProject,
type: "button",
children: "Link Your Project"
}
),
hasProcessStarted ? null : /* @__PURE__ */ jsxs(Fragment, { children: [
/* @__PURE__ */ jsxs(SeparatorContainer, { children: [
/* @__PURE__ */ jsx(HorizontalLine, {}),
/* @__PURE__ */ jsx(SeparatorText, { children: "Or" }),
/* @__PURE__ */ jsx(HorizontalLine, {})
] }),
/* @__PURE__ */ jsx(
Button$1,
{
block: true,
mt: "16px",
onClick: onCreateScratchProject,
type: "button",
variant: "V2TertiaryOutline",
children: "Create Project From Scratch"
}
),
identityProjectBlogPosts ? /* @__PURE__ */ jsxs(
BlogButton,
{
block: true,
onClick: onCreateBlogProject,
type: "button",
variant: "V2Link",
children: [
"Create A Blog Post",
/* @__PURE__ */ jsx(ContraIcon, { size: 18 })
]
}
) : null
] })
] })
] })
] }) })
]
}
);
};
const LinkedProjectDetailsModal = ({
isOpen,
onClose,
linkDetails,
linkImagesLoading,
handoverToTemplatesModal,
onBack = () => {
}
}) => {
return /* @__PURE__ */ jsxs(
Modal,
{
isOpen,
modalName: "linked_project_details_modal",
onClose,
size: "xxl",
children: [
/* @__PURE__ */ jsx(ModalClose, { onClose }),
/* @__PURE__ */ jsx(ModalBody$2, { children: /* @__PURE__ */ jsx(
ProjectDetailsForm,
{
handoverToTemplatesModal,
linkDetails,
linkImagesLoading,
onBack,
onClose
}
) })
]
}
);
};
const ScratchProjectDetailsModal = ({
isOpen,
onClose,
handoverToTemplatesModal
}) => {
return /* @__PURE__ */ jsxs(
Modal,
{
isOpen,
modalName: "scratch_project_details_modal",
onClose,
size: "xxl",
children: [
/* @__PURE__ */ jsx(ModalClose, { onClose }),
/* @__PURE__ */ jsx(ModalBody$2, { children: /* @__PURE__ */ jsx(
ProjectDetailsForm,
{
handoverToTemplatesModal,
onClose
}
) })
]
}
);
};
const node = function() {
var v0 = [
{
"alias": null,
"args": null,
"concreteType": "PortfolioProjectTemplateConnection",
"kind": "LinkedField",
"name": "portfolioProjectTemplates",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "PortfolioProjectTemplateEdge",
"kind": "LinkedField",
"name": "edges",
"plural": true,
"selections": [
{
"alias": null,
"args": null,
"concreteType": "PortfolioProjectTemplate",
"kind": "LinkedField",
"name": "node",
"plural": false,
"selections": [
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "id",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "title",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "description",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "icon",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "exampleUrl",
"storageKey": null
},
{
"alias": null,
"args": null,
"kind": "ScalarField",
"name": "slateContent",
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
}
],
"storageKey": null
}
];
return {
"fragment": {
"argumentDefinitions": [],
"kind": "Fragment",
"metadata": null,
"name": "ProjectTemplatesModalQuery",
"selections": v0,
"type": "Query",
"abstractKey": null
},
"kind": "Request",
"operation": {
"argumentDefinitions": [],
"kind": "Operation",
"name": "ProjectTemplatesModalQuery",
"selections": v0
},
"params": {
"cacheID": "9b7df854da2a98d186d061c8a33ecfa3",
"id": null,
"metadata": {},
"name": "ProjectTemplatesModalQuery",
"operationKind": "query",
"text": "query ProjectTemplatesModalQuery {\n portfolioProjectTemplates {\n edges {\n node {\n id\n title\n description\n icon\n exampleUrl\n slateContent\n }\n }\n }\n}\n"
}
};
}();
node.hash = "882dc4a36240a8294ec990ef184d4fc5";
const DEFAULT_COVER = {
id: DEFAULT_TEXT_COVER,
type: "text"
};
const ModalBody = styled(Modal.Body)`
display: flex;
flex-direction: column;
align-items: center;
text-align: center;
`;
const Title = styled(Text).attrs({ textStyle: "fourthLevelHeadline" })`
${({ theme }) => Ce`
font-size: 23px;
margin-bottom: 24px;
${theme.mediaQueries.md} {
font-size: 34px;
}
`}
`;
const SubTitle = styled(Text).attrs({ textStyle: "bodyRegular" })`
${({ theme }) => Ce`
font-size: 16px;
color: ${theme.colorsV2.gray70};
`}
`;
const SelectableCardsContainer = styled.div`
${({ theme }) => Ce`
display: flex;
flex-wrap: wrap;
margin: 30px 0px 60px 0px;
width: 100%;
justify-content: center;
gap: 16px;
${theme.mediaQueries.sm} {
gap: 16px;
}
${theme.mediaQueries.md} {
gap: 32px;
}
${theme.mediaQueries.lg} {
gap: 48px;
}
`}
`;
const SelectableCardOuterContainer = styled.div`
${({ theme }) => Ce`
display: flex;
flex-direction: column;
align-items: center;
width: 100%;
box-sizing: border-box;
max-width: 136px;
text-align: center;
flex-grow: 1;
${theme.mediaQueries.sm} {
max-width: 144px;
}
${theme.mediaQueries.md} {
max-width: 184px;
}
`}
`;
const SelectableCard = styled.button`
${({ theme, $isSelected = false, $dottedBorder = false }) => Ce`
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
border-radius: 10px;
height: 132px;
padding: 16px 8px;
border: ${$isSelected || $dottedBorder ? "none" : `2px solid ${theme.colorsV2.gray20}`};
width: 100%;
font-size: 12px;
transition: all 175ms ease;
&:hover {
cursor: pointer;
border: ${$isSelected || $dottedBorder ? "none" : "2px solid transparent"};
box-shadow: ${$isSelected ? "none" : theme.boxShadow.basic20};
/* ${$dottedBorder && !$isSelected && `background-image: none`}; */
}
${$isSelected && gradientBorderBackground({
colorStart: "#FF9E31",
colorStop: "#F2C94C",
radius: 10,
strokeWidth: 4
})}
${$dottedBorder && !$isSelected && dashedBorderBackground({
radius: 10,
stroke: theme.colorsV2.gray50
})}
svg {
margin-bottom: 12px;
flex-shrink: 0;
}
${theme.mediaQueries.md} {
padding: 16px;
height: unset;
}
${theme.mediaQueries.lg} {
height: 114px;
}
`}
`;
const SelectableCardTitle = styled(Text)`
${({ theme }) => Ce`
color: ${theme.colorsV2.black};
font-weight: ${theme.fontWeights.semiBold};
margin-bottom: 4px;
`}
`;
const SelectableCardSubTitle = styled(Text)`
${({ theme }) => Ce`
color: ${theme.colorsV2.gray70};
`}
`;
const ExampleLink = styled.a`
${({ theme }) => Ce`
color: ${theme.colorsV2.gray70};
font-weight: ${theme.fontWeights.semiBold};
font-size: 12px;
margin-top: 16px;
&:hover {
text-decoration: underline;
}
`}
`;
const ButtonsContainer = styled.div`
${({ theme }) => Ce`
display: flex;
flex-direction: column;
// margin-top: 40px;
gap: 16px;
width: 100%;
${theme.mediaQueries.sm} {
width: 152px;
}
`}
`;
const iconNameToIconComponentMap = {
briefcase: /* @__PURE__ */ jsx(BrownBriefcaseIcon, { size: 24 }),
custom: /* @__PURE__ */ jsx(EditIcon, { size: 24 }),
fallback: /* @__PURE__ */ jsx(UnidentifiedIcon, { size: 24 }),
handshake: /* @__PURE__ */ jsx(ContraHandshakeIcon, { size: 24 }),
rocket: /* @__PURE__ */ jsx(RocketEmoji, { size: 24 })
};
const getIconFromIconName = (iconName) => {
if (!iconName)
return iconNameToIconComponentMap["fallback"];
return iconNameToIconComponentMap[iconName] ?? iconNameToIconComponentMap["fallback"];
};
const getSelectedTemplateTitle = (portfolioProjectTemplates, selectedTemplateId) => {
var _a;
if (!selectedTemplateId)
return "custom";
const edge = portfolioProjectTemplates.edges.find(
({ node: node2 }) => node2.id === selectedTemplateId
);
return ((_a = edge == null ? void 0 : edge.node) == null ? void 0 : _a.title) ?? "custom";
};
const ProjectTemplatesModal = ({
isOpen,
dispatch,
selectedTemplate,
onCancel,
cover,
linkDetails
}) => {
const {
portfolioProjectTemplates
} = reactRelayExports.useLazyLoadQuery(node, {});
const isMobile = useIsMobile();
const {
track
} = useAnalytics();
const {
onCreateProject,
isPublishing
} = reactExports.useContext(ProjectEditorContext);
const coverToUse = cover ?? DEFAULT_COVER;
const linkDetailsToUse = linkDetails.url.trim() ? linkDetails : void 0;
const populatedTemplateId = (selectedTemplate == null ? void 0 : selectedTemplate.id) === "CUSTOM" ? void 0 : selectedTemplate == null ? void 0 : selectedTemplate.id;
return /* @__PURE__ */ jsx(Modal, {
"aria-label": "Choose a starting point for your project",
isKeyboardDismissDisabled: true,
isOpen,
modalName: "identity_project_templates_modal",
onClose: onCancel,
preventAutoFocus: isMobile,
size: "xl",
children: /* @__PURE__ */ jsxs(ModalBody, {
children: [/* @__PURE__ */ jsx(Title, {
children: "Choose a starting point for your project"
}), /* @__PURE__ */ jsx(SubTitle, {
children: "Select one of our templates or begin with a custom project"
}), /* @__PURE__ */ jsxs(SelectableCardsContainer, {
children: [portfolioProjectTemplates.edges.map(({
node: {
title,
description,
icon,
id,
exampleUrl
}
}) => {
var _a;
return /* @__PURE__ */ jsxs(SelectableCardOuterContainer, {
children: [/* @__PURE__ */ jsxs(SelectableCard, {
$isSelected: (selectedTemplate == null ? void 0 : selectedTemplate.id) === id,
onClick: () => {
const notYetSelected = (selectedTemplate == null ? void 0 : selectedTemplate.id) !== id;
if (notYetSelected) {
track("modal", {
action: "tapped",
modal_name: "identity_project_templates_modal",
selected_template: title
});
}
dispatch({
payload: {
id
},
type: SET_SELECTED_TEMPLATE
});
},
children: [getIconFromIconName(icon), /* @__PURE__ */ jsx(SelectableCardTitle, {
children: title
}), /* @__PURE__ */ jsx(SelectableCardSubTitle, {
children: description
})]
}), ((_a = exampleUrl == null ? void 0 : exampleUrl.trim) == null ? void 0 : _a.call(exampleUrl)) ? /* @__PURE__ */ jsx(ExampleLink, {
href: exampleUrl,
onClick: () => {
track("link", {
action: "tapped",
destination_route: "project",
destination_url: exampleUrl,
link_name: "identity_template_example"
});
},
target: "_blank",
children: "View Template Example"
}) : null]
}, id);
}), /* @__PURE__ */ jsx(SelectableCardOuterContainer, {
children: /* @__PURE__ */ jsxs(SelectableCard, {
$dottedBorder: true,
$isSelected: (selectedTemplate == null ? void 0 : selectedTemplate.id) === "CUSTOM",
onClick: () => {
const notYetSelected = (selectedTemplate == null ? void 0 : selectedTemplate.id) !== "CUSTOM";
if (notYetSelected) {
track("modal", {
action: "tapped",
modal_name: "identity_project_templates_modal",
selected_template: "custom"
});
}
dispatch({
payload: {
id: "CUSTOM"
},
type: SET_SELECTED_TEMPLATE
});
},
children: [getIconFromIconName("custom"), /* @__PURE__ */ jsx(SelectableCardTitle, {
children: "Custom Project"
}), /* @__PURE__ */ jsx(SelectableCardSubTitle, {
children: "Add your own content"
})]
})
})]
}), /* @__PURE__ */ jsxs(ButtonsContainer, {
children: [/* @__PURE__ */ jsx(Button$1, {
disabled: !selectedTemplate,
isLoading: isPublishing,
onClick: () => {
track("modal", {
action: "tapped",
cta: "primary",
modal_name: "identity_project_templates_modal",
selected_template: getSelectedTemplateTitle(portfolioProjectTemplates, selectedTemplate == null ? void 0 : selectedTemplate.id)
});
onCreateProject(coverToUse, linkDetailsToUse, populatedTemplateId);
},
children: "Continue"
}), /* @__PURE__ */ jsx(Button$1, {
onClick: onCancel,
variant: "V2TertiaryOutline",
children: "Back"
})]
})]
})
});
};
const defaultState = {
brandId: null,
cover: null,
errors: null,
hasProcessStarted: false,
isBlogModalOpen: false,
isLinkedModalOpen: false,
isScratchModalOpen: false,
isTemplatesModalOpen: false,
linkDetails: {
title: "",
url: ""
},
selectedTemplate: null,
url: null
};
const reducer = (state, action) => {
switch (action.type) {
case SET_LINK_DETAILS: {
return {
...state,
linkDetails: {
...state.linkDetails,
...action.payload
}
};
}
case SET_HAS_PROCESS_STARTED: {
return {
...state,
hasProcessStarted: action.payload
};
}
case SET_IS_LINKED_MODAL_OPEN: {
return {
...state,
isLinkedModalOpen: action.payload
};
}
case SET_IS_SCRATCH_MODAL_OPEN: {
return {
...state,
isScratchModalOpen: action.payload
};
}
case SET_IS_BLOG_MODAL_OPEN: {
return {
...state,
isBlogModalOpen: action.payload
};
}
case HANDOVER_TO_TEMPLATES_MODAL: {
return {
...state,
cover: action.payload,
isBlogModalOpen: false,
isLinkedModalOpen: false,
isScratchModalOpen: false,
isTemplatesModalOpen: true
};
}
case SET_SELECTED_TEMPLATE: {
return {
...state,
selectedTemplate: action.payload
};
}
case RESET_STATE: {
return {
...state,
...defaultState
};
}
case REPLACE_STATE: {
return { ...state, ...action.payload };
}
case ON_CHANGE: {
const { name, value } = action.payload;
return {
...state,
[name]: value
};
}
case SET_BRAND_ID: {
return {
...state,
brandId: action.payload
};
}
case SET_VALIDATION_ERROR: {
return {
...state,
errors: action.payload
};
}
case SET_PROJECT_COVER: {
return {
...state,
cover: action.payload
};
}
default: {
throw new Error("Unhandled create project reducer action");
}
}
};
const schema = create().shape({
url: create$1().test("url", "This is not a valid URL", isValidPublicUrl).required()
});
const CreateProject = ({
isOpen,
toggleCreateProjectModal
}) => {
const [prefetchProjectTemplates, setPrefetchProjectTemplates] = reactExports.useState(false);
reactExports.useEffect(() => {
if (isOpen && !prefetchProjectTemplates) {
setPrefetchProjectTemplates(true);
}
}, [isOpen, prefetchProjectTemplates]);
const {
dispatch: thumbnailPickerDispatch,
resetState: resetThumbnailPickerState
} = reactExports.useContext(ProjectThumbnailContext);
const { resetState: resetProjectEditorState } = reactExports.useContext(ProjectEditorContext);
const stateBeforeProjectsModal = reactExports.useRef();
const [state, dispatch] = reactExports.useReducer(reducer, {
...defaultState
});
const {
linkDetails,
hasProcessStarted,
isBlogModalOpen,
isScratchModalOpen,
isLinkedModalOpen,
isTemplatesModalOpen,
selectedTemplate,
cover,
url,
brandId
} = state;
const resetState = reactExports.useCallback(() => {
setTimeout(() => {
resetThumbnailPickerState();
resetProjectEditorState();
dispatch({ payload: {}, type: "RESET_STATE" });
}, 300);
}, [dispatch, resetThumbnailPickerState, resetProjectEditorState]);
const handoverToTemplatesModal = reactExports.useCallback(
(selectedCover) => {
stateBeforeProjectsModal.current = state;
dispatch({
payload: selectedCover,
type: HANDOVER_TO_TEMPLATES_MODAL
});
},
[state]
);
const onGoBackFromTemplatesModal = reactExports.useCallback(() => {
dispatch({
payload: (stateBeforeProjectsModal == null ? void 0 : stateBeforeProjectsModal.current) ?? {},
type: REPLACE_STATE
});
}, []);
const {
fetchLinkMetadata,
fetchLinkImages,
linkMetadataLoading,
linkImagesLoading
} = useLinkDetails({
onImagesSuccess: ({ images }) => {
if (images == null ? void 0 : images.length) {
const imagesArray = images.map(
(image) => normalizeContraImageToUploadedImageInput(image)
);
thumbnailPickerDispatch({
payload: "image",
type: "SET_COVER_TYPE"
});
thumbnailPickerDispatch({
payload: { imageCovers: imagesArray },
type: "ADD_IMAGE_COVERS"
});
dispatch({
payload: {
images: imagesArray
},
type: "SET_LINK_DETAILS"
});
}
},
onMetadataSuccess: (details) => {
if (details) {
dispatch({
payload: {
brandId: details.brandId ?? void 0,
description: details.description ?? void 0,
title: details.title,
url: details.url
},
type: "SET_LINK_DETAILS"
});
}
toggleCreateProjectModal();
dispatch({ payload: true, type: "SET_IS_LINKED_MODAL_OPEN" });
}
});
const onLinkSubmit = reactExports.useCallback(async () => {
schema.validate({ url }).then(async () => {
if (!hasProcessStarted) {
dispatch({ payload: true, type: "SET_HAS_PROCESS_STARTED" });
}
if (url) {
const formattedLink = formatUrl(url);
await fetchLinkMetadata(formattedLink, brandId);
fetchLinkImages(formattedLink);
}
}).catch((error) => {
dispatch({ payload: error, type: "SET_VALIDATION_ERROR" });
});
}, [hasProcessStarted, fetchLinkMetadata, fetchLinkImages, url, brandId]);
return /* @__PURE__ */ jsxs(Fragment, { children: [
/* @__PURE__ */ jsx(
CreateProjectModal,
{
dispatch,
isOpen,
isSubmitting: linkMetadataLoading,
onClose: toggleCreateProjectModal,
onLinkSubmit,
resetState,
state
}
),
/* @__PURE__ */ jsx(
ScratchProjectDetailsModal,
{
handoverToTemplatesModal,
isOpen: isScratchModalOpen,
onClose: () => resetState()
}
),
/* @__PURE__ */ jsx(
BlogProjectDetailsModal,
{
isOpen: isBlogModalOpen,
onClose: () => resetState()
}
),
/* @__PURE__ */ jsx(
LinkedProjectDetailsModal,
{
handoverToTemplatesModal,
isOpen: isLinkedModalOpen,
linkDetails,
linkImagesLoading,
onBack: () => {
dispatch({ payload: false, type: "SET_IS_LINKED_MODAL_OPEN" });
toggleCreateProjectModal();
},
onClose: resetState
}
),
prefetchProjectTemplates ? /* @__PURE__ */ jsx(ErrorBoundary, { renderError: () => null, children: /* @__PURE__ */ jsx(reactExports.Suspense, { fallback: null, children: /* @__PURE__ */ jsx(
ProjectTemplatesModal,
{
cover,
dispatch,
isOpen: isTemplatesModalOpen,
linkDetails,
onCancel: onGoBackFromTemplatesModal,
selectedTemplate
}
) }) }) : null
] });
};
const CreateProjectWrapper = ({
isOpen,
toggleCreateProjectModal
}) => {
return /* @__PURE__ */ jsx(
ProjectEditorContextProvider,
{
initialState: {
description: "",
organizations: [],
roles: [],
title: "",
tools: []
},
children: /* @__PURE__ */ jsx(
ProjectThumbnailContextProvider,
{
imageCovers: [],
initialImageCover: void 0,
isPublishing: false,
children: /* @__PURE__ */ jsx(
CreateProject,
{
isOpen,
toggleCreateProjectModal
}
)
}
)
}
);
};
const Page = ({
preloaded
}) => {
var _a;
const data = reactRelayExports.usePreloadedQuery(node$8, preloaded);
const {
visitor,
userProfileByUsername
} = data;
const router = useRouter();
const routes = useRoutes();
const createNewProject = useSearchParameter("createNewProject", "boolean");
const redirectToPortfolio = useSearchParameter("redirectToPortfolio", "boolean");
const isBlogProfile = (userProfileByUsername == null ? void 0 : userProfileByUsername.profileDisplayType) === "BLOG";
const [showCreateProjectModal, toggleCreateProjectModal] = useToggle(createNewProject);
const blogCategories = (_a = data.blogCategories) == null ? void 0 : _a.edges.map(({
node: {
id: categoryId,
name
}
}) => ({
id: categoryId,
name
}));
useRegisterAnalyticEvent(userProfileByUsername && !userProfileByUsername.visitorCanEdit ? {
eventType: "UserProfileView",
input: {
userProfileId: userProfileByUsername.id
}
} : void 0);
const {
LazyOnboardingRedirectionModal,
handleOnboardingRedirectionModalOpen,
shouldRedirectUser
} = useOnboardingRedirection({
redirectTo: appendSearch(userProfileByUsername ? routeHelpers.user({
username: userProfileByUsername.displayUsername
}) : routeHelpers.me())
});
const {
ProfileMagicInputModal,
setIsProfileMagicInputModalOpen,
isProfileMagicEnabled,
isOnboardingCompletedParameter,
hasUsedProfileMagic
} = useProfileMagic({
suggestionsToGenerate: "all"
});
useMount(() => {
if (shouldRedirectUser && (userProfileByUsername == null ? void 0 : userProfileByUsername.visitorCanEdit)) {
handleOnboardingRedirectionModalOpen();
} else if (isProfileMagicEnabled && isOnboardingCompletedParameter && (userProfileByUsername == null ? void 0 : userProfileByUsername.visitorCanEdit) && !hasUsedProfileMagic) {
setIsProfileMagicInputModalOpen(true);
}
});
reactExports.useEffect(() => {
if (createNewProject) {
toggleCreateProjectModal(true);
}
}, [createNewProject, toggleCreateProjectModal]);
if (!userProfileByUsername)
return /* @__PURE__ */ jsx(NotFound, {});
if (!isBlogProfile && preloaded.isFilteringRoute) {
return /* @__PURE__ */ jsx(Redirect, {
method: "replace",
to: (stubRoutes) => stubRoutes.user({
username: userProfileByUsername.displayUsername
})
});
}
if (redirectToPortfolio) {
return /* @__PURE__ */ jsx(PortfolioRedirect, {
displayUsername: userProfileByUsername.displayUsername,
route: router.isActive(routes.userProjects({
username: userProfileByUsername.displayUsername ?? ""
}), false) ? "userProjects" : "user"
});
}
if (userProfileByUsername.hasCompletedClientOnboarding && !userProfileByUsername.hasCompletedIndyOnboarding) {
return /* @__PURE__ */ jsx(Redirect, {
method: "replace",
to: routes.userOpportunities({
username: userProfileByUsername.displayUsername
})
});
}
if (location.pathname === "/blog/community") {
return /* @__PURE__ */ jsx(Redirect, {
method: "replace",
to: "/blog/success-stories"
});
}
return /* @__PURE__ */ jsxs(Fragment, {
children: [/* @__PURE__ */ jsx(W, {
children: /* @__PURE__ */ jsx("title", {
children: `${isBlogProfile ? "Articles" : "Projects created"} by ${userProfileByUsername.firstName} ${userProfileByUsername.lastName}`
})
}), /* @__PURE__ */ jsx(ProfileLayout, {
accountRef: visitor.userAccount,
userProfileRef: userProfileByUsername,
children: /* @__PURE__ */ jsx(ProfileProjects, {
blogCategories,
profileKey: userProfileByUsername
})
}), /* @__PURE__ */ jsx(Footer$1, {}), visitor.userAccount && /* @__PURE__ */ jsx(CreateProjectWrapper, {
isOpen: showCreateProjectModal,
toggleCreateProjectModal
}), /* @__PURE__ */ jsx(reactExports.Suspense, {
children: /* @__PURE__ */ jsx(LazyOnboardingRedirectionModal, {})
}), /* @__PURE__ */ jsx(ProfileMagicInputModal, {})]
});
};
export {
Page,
node$8 as pageConcreteRequest
};
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment