From 649e9fc65dac404548ad8358afbe643801c7079a Mon Sep 17 00:00:00 2001 From: Jake Laderman Date: Sun, 20 Oct 2024 20:31:21 -0400 Subject: [PATCH 1/8] add basic scaffolding for custom page --- pages/_app.tsx | 1 + pages/about/[keyword].tsx | 89 + pages/marketplace.tsx | 2 +- pages/pricing.tsx | 5 +- src/components/ArticleCard.tsx | 2 +- src/components/AspectRatio.tsx | 8 + src/components/PrimaryPage.tsx | 16 +- src/components/Typography.tsx | 64 +- src/components/custom-page/BlogCards.tsx | 5 + src/components/custom-page/CTA.tsx | 5 + src/components/custom-page/Cards.tsx | 5 + src/components/custom-page/CustomerQuote.tsx | 5 + src/components/custom-page/Hero.tsx | 73 + src/components/custom-page/LargeImage.tsx | 5 + src/components/custom-page/LogoStrip.tsx | 5 + .../custom-page/RichTextColumns.tsx | 5 + src/components/custom-page/SectionHeader.tsx | 5 + src/components/custom-page/common.tsx | 46 + .../HowPluralWorksMiniSection.tsx | 208 -- .../page-sections/HowPluralWorksSection.tsx | 198 -- src/generated/graphqlDirectus.ts | 2583 +++++++++++++++-- src/graph/directus/customPages.graphql | 81 + 22 files changed, 2809 insertions(+), 607 deletions(-) create mode 100644 pages/about/[keyword].tsx create mode 100644 src/components/custom-page/BlogCards.tsx create mode 100644 src/components/custom-page/CTA.tsx create mode 100644 src/components/custom-page/Cards.tsx create mode 100644 src/components/custom-page/CustomerQuote.tsx create mode 100644 src/components/custom-page/Hero.tsx create mode 100644 src/components/custom-page/LargeImage.tsx create mode 100644 src/components/custom-page/LogoStrip.tsx create mode 100644 src/components/custom-page/RichTextColumns.tsx create mode 100644 src/components/custom-page/SectionHeader.tsx create mode 100644 src/components/custom-page/common.tsx delete mode 100644 src/components/page-sections/HowPluralWorksMiniSection.tsx delete mode 100644 src/components/page-sections/HowPluralWorksSection.tsx create mode 100644 src/graph/directus/customPages.graphql diff --git a/pages/_app.tsx b/pages/_app.tsx index 5dc0f8fd..cc4440ea 100644 --- a/pages/_app.tsx +++ b/pages/_app.tsx @@ -36,6 +36,7 @@ export type GlobalPageProps = { metaDescription?: string footerVariant?: FooterVariant showHeaderBG?: boolean + hideHeader?: boolean } type MyAppProps = AppProps diff --git a/pages/about/[keyword].tsx b/pages/about/[keyword].tsx new file mode 100644 index 00000000..dac3d086 --- /dev/null +++ b/pages/about/[keyword].tsx @@ -0,0 +1,89 @@ +import { styledTheme } from '@pluralsh/design-system' +import { type GetStaticPaths, type InferGetStaticPropsType } from 'next' + +import { ThemeProvider } from 'styled-components' + +import { directusClient } from '@src/apollo-client' +import { renderComponent } from '@src/components/custom-page/common' +import { FooterVariant } from '@src/components/FooterFull' +import { + CustomPageDocument, + type CustomPageQuery, + type CustomPageQueryVariables, + CustomPageSlugsDocument, + type CustomPageSlugsQuery, + type CustomPageSlugsQueryVariables, +} from '@src/generated/graphqlDirectus' +import { propsWithGlobalSettings } from '@src/utils/getGlobalProps' + +export default function CustomPage({ + components, +}: InferGetStaticPropsType) { + return ( + // TODO: make theme adjustable + + {components.map((component) => renderComponent(component?.item))} + + ) +} + +export const getStaticPaths: GetStaticPaths = async () => { + const { data, error } = await directusClient.query< + CustomPageSlugsQuery, + CustomPageSlugsQueryVariables + >({ + query: CustomPageSlugsDocument, + }) + + if (error) { + console.error('GraphQL query error in static:', error) + } + + return { + paths: data.custom_pages.map((page) => ({ + params: { keyword: page.slug }, + })), + fallback: 'blocking', + } +} + +export const getStaticProps = async (context) => { + const slug = + typeof context?.params?.keyword === 'string' + ? context?.params?.keyword + : null + + if (!slug) { + return { notFound: true } + } + + const { data, error } = await directusClient.query< + CustomPageQuery, + CustomPageQueryVariables + >({ + query: CustomPageDocument, + variables: { slug }, + }) + + if (error) { + console.error('GraphQL query error in static: ', error) + } + const page = data.custom_pages?.[0] || null + + if (!page) { + return { notFound: true } + } + + return propsWithGlobalSettings( + { + metaTitle: 'Plural', + metaDescription: page.slug, + footerVariant: FooterVariant.none, + hideHeader: true, + components: page.components ?? [], + }, + { + revalidate: 20, + } + ) +} diff --git a/pages/marketplace.tsx b/pages/marketplace.tsx index 6a8ff4bc..4560f231 100644 --- a/pages/marketplace.tsx +++ b/pages/marketplace.tsx @@ -397,7 +397,7 @@ export default function Marketplace({ Discover over 90 incredible applications ready to deploy in your cloud in minutes using our guided deployment flow. With security, diff --git a/pages/pricing.tsx b/pages/pricing.tsx index 82dabc40..98a76546 100644 --- a/pages/pricing.tsx +++ b/pages/pricing.tsx @@ -82,7 +82,10 @@ export default function Pricing({ } /> -
+
diff --git a/src/components/ArticleCard.tsx b/src/components/ArticleCard.tsx index 6eb9a9a1..7499a05a 100644 --- a/src/components/ArticleCard.tsx +++ b/src/components/ArticleCard.tsx @@ -165,7 +165,7 @@ export function ArticleCard({ heading={heading} headingProps={{ textStyles: { '': 'mTitle1' } }} /> - {description && {description}} + {description && {description}} {ctas?.map((cta, i) => ( ( }) ) +export const ImageAspectRatio = styled(EmbedAspectRatio)<{ $url: string }>( + ({ $url }) => ({ + backgroundSize: 'cover', + backgroundPosition: 'center', + backgroundImage: `url(${$url})`, + }) +) + const ratioStyles = (ratio: string) => ({ position: 'relative', '&::before': { diff --git a/src/components/PrimaryPage.tsx b/src/components/PrimaryPage.tsx index 19006eac..f48b5588 100644 --- a/src/components/PrimaryPage.tsx +++ b/src/components/PrimaryPage.tsx @@ -65,13 +65,15 @@ export default function PrimaryPage({ - + {!pageProps.hideHeader && ( + + )} {children} diff --git a/src/components/Typography.tsx b/src/components/Typography.tsx index 72fc5fe4..5e399c97 100644 --- a/src/components/Typography.tsx +++ b/src/components/Typography.tsx @@ -1,4 +1,5 @@ import { + type CSSProperties, type ComponentProps, type HTMLAttributes, type ReactNode, @@ -7,6 +8,7 @@ import { import { ArrowRightIcon, + Markdown, type styledTheme, useNavigationContext, } from '@pluralsh/design-system' @@ -25,6 +27,8 @@ import { cn } from '@src/utils/cn' import { AttachLastWordToElt } from './AttachLastWordToElt' import { SingleAccordion } from './SingleAccordion' +type ColorKey = keyof DefaultTheme['colors'] + export const Heading1 = forwardRef< HTMLHeadingElement, AsChildProps> @@ -99,43 +103,44 @@ export const ResponsiveText = styled.h2.withConfig(textPropFilter)<{ } }) -export const Title2 = styled.h3(({ theme }) => ({ +export const Hero1 = styled.h1<{ $color?: ColorKey }>(({ theme, $color }) => ({ + ...theme.partials.marketingText.hero1, + color: $color && (theme.colors[$color] as string), +})) + +export const Hero2 = styled.h2<{ $color?: ColorKey }>(({ theme, $color }) => ({ + ...theme.partials.marketingText.hero2, + color: $color && (theme.colors[$color] as string), +})) + +export const Title2 = styled.h3<{ $color?: ColorKey }>(({ theme, $color }) => ({ ...theme.partials.marketingText.title2, + color: $color && (theme.colors[$color] as string), })) -export const Body1 = styled.p.withConfig(textPropFilter)( - ({ theme, color }) => ({ - ...theme.partials.marketingText.body1, - ...(color - ? { color: theme.colors[color] || theme.colors.text } - : { color: theme.colors.text }), - }) -) +export const Body1 = styled.p<{ $color?: ColorKey }>(({ theme, $color }) => ({ + ...theme.partials.marketingText.body1, + color: $color && (theme.colors[$color] as string), +})) -export const Body2 = styled.p.withConfig(textPropFilter)( - ({ theme, color }) => ({ +export const Body2 = styled.p<{ $color?: ColorKey }>( + ({ theme, $color = 'text-light' }) => ({ ...theme.partials.marketingText.body2, - ...(color - ? { color: theme.colors[color] || theme.colors['text-light'] } - : { color: theme.colors['text-light'] }), + color: theme.colors[$color] as string, }) ) -export const AppBody1 = styled.p.withConfig(textPropFilter)( - ({ theme, color }) => ({ +export const AppBody1 = styled.p<{ $color?: ColorKey }>( + ({ theme, $color = 'text-light' }) => ({ ...theme.partials.text.body1, - ...(color - ? { color: theme.colors[color] || theme.colors['text-light'] } - : { color: theme.colors['text-light'] }), + color: theme.colors[$color] as string, }) ) -export const AppBody2 = styled.p.withConfig(textPropFilter)( - ({ theme, color }) => ({ +export const AppBody2 = styled.p<{ $color?: ColorKey }>( + ({ theme, $color = 'text-light' }) => ({ ...theme.partials.text.body2, - ...(color - ? { color: theme.colors[color] || theme.colors['text-light'] } - : { color: theme.colors['text-light'] }), + color: theme.colors[$color] as string, }) ) @@ -322,3 +327,14 @@ export const BasicP = styled.p(({ theme }) => ({ marginTop: theme.spacing.medium, }, })) + +export function NoMarginMarkdown({ + extendedCss, + ...props +}: ComponentProps & { extendedCss?: CSSProperties }) { + return ( +
+ +
+ ) +} diff --git a/src/components/custom-page/BlogCards.tsx b/src/components/custom-page/BlogCards.tsx new file mode 100644 index 00000000..31017dd1 --- /dev/null +++ b/src/components/custom-page/BlogCards.tsx @@ -0,0 +1,5 @@ +import { type BlogCardsComponentFragment } from '@src/generated/graphqlDirectus' + +export function BlogCards({ spacing }: BlogCardsComponentFragment) { + return
BlogCards
+} diff --git a/src/components/custom-page/CTA.tsx b/src/components/custom-page/CTA.tsx new file mode 100644 index 00000000..2b5d45fb --- /dev/null +++ b/src/components/custom-page/CTA.tsx @@ -0,0 +1,5 @@ +import { type CtaComponentFragment } from '@src/generated/graphqlDirectus' + +export function CTA({ spacing }: CtaComponentFragment) { + return
CTA
+} diff --git a/src/components/custom-page/Cards.tsx b/src/components/custom-page/Cards.tsx new file mode 100644 index 00000000..8201e180 --- /dev/null +++ b/src/components/custom-page/Cards.tsx @@ -0,0 +1,5 @@ +import { type CardsComponentFragment } from '@src/generated/graphqlDirectus' + +export function Cards({ spacing }: CardsComponentFragment) { + return
Cards
+} diff --git a/src/components/custom-page/CustomerQuote.tsx b/src/components/custom-page/CustomerQuote.tsx new file mode 100644 index 00000000..fdf08b3c --- /dev/null +++ b/src/components/custom-page/CustomerQuote.tsx @@ -0,0 +1,5 @@ +import { type CustomerQuoteComponentFragment } from '@src/generated/graphqlDirectus' + +export function CustomerQuote({ spacing }: CustomerQuoteComponentFragment) { + return
CustomerQuote
+} diff --git a/src/components/custom-page/Hero.tsx b/src/components/custom-page/Hero.tsx new file mode 100644 index 00000000..8ea80c13 --- /dev/null +++ b/src/components/custom-page/Hero.tsx @@ -0,0 +1,73 @@ +import { Button, Code, Flex } from '@pluralsh/design-system' +import Link from 'next/link' + +import { getImageUrl } from '@src/consts/routes' +import { type HeroComponentFragment } from '@src/generated/graphqlDirectus' +import { cn } from '@src/utils/cn' + +import { ImageAspectRatio } from '../AspectRatio' +import Embed from '../Embed' +import { Body1, Hero1 } from '../Typography' + +import { spacingToClassName } from './common' + +export function Hero({ + spacing, + heading, + body_text: bodyText, + cta_text: ctaText, + cta_url: ctaUrl, + media_type: mediaType, + image, + video_url: videoUrl, + form, +}: HeroComponentFragment) { + const spacingClassName = spacingToClassName[spacing ?? 'normal'] ?? '' + const imageUrl = getImageUrl(image) + + return ( +
+ + + {heading} + {bodyText} + {ctaText && ( + + )} + +
+ {mediaType === 'image' ? ( + imageUrl && ( + + ) + ) : mediaType === 'video' ? ( + + ) : mediaType === 'form' ? ( + + {form ?? ''} + + ) : null} +
+
+
+ ) +} diff --git a/src/components/custom-page/LargeImage.tsx b/src/components/custom-page/LargeImage.tsx new file mode 100644 index 00000000..56956c7d --- /dev/null +++ b/src/components/custom-page/LargeImage.tsx @@ -0,0 +1,5 @@ +import { type LargeImageComponentFragment } from '@src/generated/graphqlDirectus' + +export function LargeImage({ spacing }: LargeImageComponentFragment) { + return
LargeImage
+} diff --git a/src/components/custom-page/LogoStrip.tsx b/src/components/custom-page/LogoStrip.tsx new file mode 100644 index 00000000..fca86593 --- /dev/null +++ b/src/components/custom-page/LogoStrip.tsx @@ -0,0 +1,5 @@ +import { type LogoStripComponentFragment } from '@src/generated/graphqlDirectus' + +export function LogoStrip({ spacing }: LogoStripComponentFragment) { + return
LogoStrip
+} diff --git a/src/components/custom-page/RichTextColumns.tsx b/src/components/custom-page/RichTextColumns.tsx new file mode 100644 index 00000000..59fe747d --- /dev/null +++ b/src/components/custom-page/RichTextColumns.tsx @@ -0,0 +1,5 @@ +import { type RichTextColumnsComponentFragment } from '@src/generated/graphqlDirectus' + +export function RichTextColumns({ spacing }: RichTextColumnsComponentFragment) { + return
RichTextColumns
+} diff --git a/src/components/custom-page/SectionHeader.tsx b/src/components/custom-page/SectionHeader.tsx new file mode 100644 index 00000000..2e7239a3 --- /dev/null +++ b/src/components/custom-page/SectionHeader.tsx @@ -0,0 +1,5 @@ +import { type SectionHeaderComponentFragment } from '@src/generated/graphqlDirectus' + +export function SectionHeader({ spacing }: SectionHeaderComponentFragment) { + return
SectionHeader
+} diff --git a/src/components/custom-page/common.tsx b/src/components/custom-page/common.tsx new file mode 100644 index 00000000..e3ceadc1 --- /dev/null +++ b/src/components/custom-page/common.tsx @@ -0,0 +1,46 @@ +import { type CustomPageFragment } from '@src/generated/graphqlDirectus' + +import { BlogCards } from './BlogCards' +import { Cards } from './Cards' +import { CTA } from './CTA' +import { CustomerQuote } from './CustomerQuote' +import { Hero } from './Hero' +import { LargeImage } from './LargeImage' +import { LogoStrip } from './LogoStrip' +import { RichTextColumns } from './RichTextColumns' +import { SectionHeader } from './SectionHeader' + +export const spacingToClassName = { + relaxed: 'my-[192px]', + normal: 'my-[96px]', + compact: 'my-[48px]', +} + +export function renderComponent( + component: NonNullable< + NonNullable[number] + >['item'] +) { + switch (component?.__typename) { + case 'hero': + return + case 'logo_strip': + return + case 'section_header': + return + case 'large_image': + return + case 'cards': + return + case 'blog_cards': + return + case 'rich_text_columns': + return + case 'customer_quote': + return + case 'cta': + return + default: + return null + } +} diff --git a/src/components/page-sections/HowPluralWorksMiniSection.tsx b/src/components/page-sections/HowPluralWorksMiniSection.tsx deleted file mode 100644 index 0cdb38a9..00000000 --- a/src/components/page-sections/HowPluralWorksMiniSection.tsx +++ /dev/null @@ -1,208 +0,0 @@ -import { - type ComponentProps, - type ReactElement, - type ReactNode, - cloneElement, -} from 'react' - -import { - ApiIcon, - BrowseAppsIcon, - CliIcon, - PadlockLockedIcon, -} from '@pluralsh/design-system' - -import styled from 'styled-components' -import { type Merge } from 'type-fest' - -import { mqs } from '@src/breakpoints' -import { cn as classNames } from '@src/utils/cn' - -import { Columns, EqualColumn } from '../layout/Columns' -import { StandardPageWidth } from '../layout/LayoutHelpers' -import { TextLimiter } from '../layout/TextLimiter' -import { SubsectionHead } from '../SectionHeads' -import { Body1, Body2, Cta, ResponsiveText } from '../Typography' -import { ValueCardIconSC } from '../ValueCard' - -const HowWorksInfoSC = styled.div(({ theme }) => ({ - rowGap: theme.spacing.medium, - textWrap: 'balance', - '&, .text': { - display: 'flex', - flexDirection: 'column', - }, - '.icon': { - display: 'flex', - }, - '.text': { - rowGap: theme.spacing.xsmall, - }, - [mqs.md]: { - maxWidth: 300, - }, -})) - -function HowWorksInfo({ - icon, - heading, - children, - ...props -}: Merge< - ComponentProps, - { - icon: ReactElement - heading: ReactNode - children: ReactNode - } ->) { - const iconClone = cloneElement(icon, { size: 22 }) - - return ( - -
- {iconClone} -
-
- - {heading} - - {children} -
-
- ) -} - -function HowPluralWorksMiniSection() { - return ( -
- - - - - - - We make it easy to securely deploy and manage open-source - applications in your cloud. - - -
- } - > - Get any stack you want running in minutes, and never think about - upgrades again. - - } - > - You control everything. No need to share your cloud account, - keys, or data. - - } - > - Built on Kubernetes and using standard infrastructure as code - with Terraform and Helm. - - } - > - Interactive runbooks, dashboards, and Kubernetes api visualizers - give an easy-to-use toolset to manage application operations.{' '} - -
- Learn more -
- -
-
- - Screenshot of app installation in Plural app - -
- ) -} - -const ImageAreaSC = styled.div(({ theme }) => ({ - paddingLeft: theme.spacing.large, - [mqs.columns]: { - position: 'absolute', - display: 'flex', - justifyContent: 'end', - alignItems: 'center', - width: '50%', - top: 0, - right: 0, - bottom: 0, - img: { - display: 'block', - width: '100%', - maxWidth: 1024, - }, - }, -})) - -const HPWMiniSectionSolutionsSC = styled.div(({ theme }) => ({ - backgroundColor: theme.colors['fill-zero'], - paddingTop: theme.spacing.xxxxlarge, - overflow: 'hidden', - [mqs.md]: { - paddingTop: theme.spacing.xxxxxlarge, - }, - [mqs.columns]: { - paddingBottom: theme.spacing.xxxxxlarge, - }, - [mqs.xxl]: { - paddingTop: theme.spacing.xxxxxxlarge, - paddingBottom: theme.spacing.xxxxxxlarge, - }, -})) - -export function HPWMiniSectionSolutions() { - return ( - - - - ) -} - -const HPWMiniSectionAppStacksSC = styled.div(({ theme }) => ({ - paddingTop: theme.spacing.xxlarge, - [mqs.md]: { - paddingTop: theme.spacing.xxxxlarge, - }, - [mqs.columns]: { - paddingBottom: theme.spacing.xxxxxlarge, - }, - [mqs.xxl]: { - paddingBottom: theme.spacing.xxxxxxlarge, - }, -})) - -export function HPWMiniSectionAppStacks() { - return ( - - - - ) -} diff --git a/src/components/page-sections/HowPluralWorksSection.tsx b/src/components/page-sections/HowPluralWorksSection.tsx deleted file mode 100644 index 6c7f79cd..00000000 --- a/src/components/page-sections/HowPluralWorksSection.tsx +++ /dev/null @@ -1,198 +0,0 @@ -import { - ConnectorLineH, - ConnectorLineV, - HowWorks, - HowWorksImage, - HowWorksImgCol, - HowWorksItemCol, - HowWorksSection, - HowWorksStepCol, - IMAGE_MARGIN, -} from '@src/components/HowPluralWorksComponents' -import { cn as classNames } from '@src/utils/cn' - -import { BasicUl } from '../Typography' - -export function HowPluralWorksSection() { - return ( - - - - -

Select open-source applications from the Plural Marketplace

- -
  • - Start or extend your infrastructure in minutes with our guided - deployment flow. -
  • -
  • - Choose from best in class applications for Data, DevOps, or - Security use cases. -
  • -
    -
    - - - -
    - - - -

    Your Cloud. Your Git Repository. No credentials shared.

    - -
  • - Plural leverages your cloud provider SDK and it's assigned IAM - role to orchestrate deployments. -
  • -
  • - All infrastructure-as-code is stored in your source code - repository. We support Github, GitLab, BitBucket, and more. We - don’t store any credentials. Apps are fully ejectable so you can - walk away from Plural at any time. -
  • -
  • - Customize every aspect of the apps for greater control of your - deployment. -
  • -
    -
    - - - - - - - - -
    - - - -

    Build & Deploy

    - -
  • - Plural provisions and secures infrastructure to best practices in - your cloud. -
  • -
  • Built-in secret management, image scans, and audit trails.
  • -
  • - Automatically configured user authentication with OpenID connect. -
  • -
    -
    - - - - - - - - -
    - - - -

    Maintain & Scale with Plural Console

    - -
  • - Console automatically deploys app updates making maintenance a - breeze. -
  • -
  • - Centralized monitoring and logs for each app reduces - troubleshooting time and accelerates product cycles. -
  • -
  • - Run scaling jobs through low-code runbooks in our console so you - can scale as usage grows. -
  • -
    -
    - - - -
    -
    - ) -} diff --git a/src/generated/graphqlDirectus.ts b/src/generated/graphqlDirectus.ts index dd9beca1..7043bae0 100644 --- a/src/generated/graphqlDirectus.ts +++ b/src/generated/graphqlDirectus.ts @@ -30,8 +30,12 @@ export type Mutation = { create_apps_items: Array; create_article_cards_item?: Maybe; create_article_cards_items: Array; + create_blog_cards_item?: Maybe; + create_blog_cards_items: Array; create_callouts_item?: Maybe; create_callouts_items: Array; + create_cards_item?: Maybe; + create_cards_items: Array; create_case_studies_item?: Maybe; create_case_studies_items: Array; create_collapsible_lists_item?: Maybe; @@ -46,14 +50,28 @@ export type Mutation = { create_company_logo_lists_items_items: Array; create_company_logos_item?: Maybe; create_company_logos_items: Array; + create_cta_item?: Maybe; + create_cta_items: Array; + create_custom_pages_components_item?: Maybe; + create_custom_pages_components_items: Array; + create_custom_pages_item?: Maybe; + create_custom_pages_items: Array; + create_customer_quote_item?: Maybe; + create_customer_quote_items: Array; create_events_item?: Maybe; create_events_items: Array; create_faqs_item?: Maybe; create_faqs_items: Array; create_featured_contributors_item?: Maybe; create_featured_contributors_items: Array; + create_hero_item?: Maybe; + create_hero_items: Array; create_job_listings_item?: Maybe; create_job_listings_items: Array; + create_large_image_item?: Maybe; + create_large_image_items: Array; + create_logo_strip_item?: Maybe; + create_logo_strip_items: Array; create_markdown_pages_item?: Maybe; create_markdown_pages_items: Array; create_nav_link_item?: Maybe; @@ -74,6 +92,10 @@ export type Mutation = { create_quote_lists_items_items: Array; create_quotes_item?: Maybe; create_quotes_items: Array; + create_rich_text_columns_item?: Maybe; + create_rich_text_columns_items: Array; + create_section_header_item?: Maybe; + create_section_header_items: Array; create_site_settings_nav_list_item?: Maybe; create_site_settings_nav_list_items: Array; create_solution_features_item?: Maybe; @@ -92,8 +114,12 @@ export type Mutation = { delete_apps_items?: Maybe; delete_article_cards_item?: Maybe; delete_article_cards_items?: Maybe; + delete_blog_cards_item?: Maybe; + delete_blog_cards_items?: Maybe; delete_callouts_item?: Maybe; delete_callouts_items?: Maybe; + delete_cards_item?: Maybe; + delete_cards_items?: Maybe; delete_case_studies_item?: Maybe; delete_case_studies_items?: Maybe; delete_collapsible_lists_item?: Maybe; @@ -108,14 +134,28 @@ export type Mutation = { delete_company_logo_lists_items_items?: Maybe; delete_company_logos_item?: Maybe; delete_company_logos_items?: Maybe; + delete_cta_item?: Maybe; + delete_cta_items?: Maybe; + delete_custom_pages_components_item?: Maybe; + delete_custom_pages_components_items?: Maybe; + delete_custom_pages_item?: Maybe; + delete_custom_pages_items?: Maybe; + delete_customer_quote_item?: Maybe; + delete_customer_quote_items?: Maybe; delete_events_item?: Maybe; delete_events_items?: Maybe; delete_faqs_item?: Maybe; delete_faqs_items?: Maybe; delete_featured_contributors_item?: Maybe; delete_featured_contributors_items?: Maybe; + delete_hero_item?: Maybe; + delete_hero_items?: Maybe; delete_job_listings_item?: Maybe; delete_job_listings_items?: Maybe; + delete_large_image_item?: Maybe; + delete_large_image_items?: Maybe; + delete_logo_strip_item?: Maybe; + delete_logo_strip_items?: Maybe; delete_markdown_pages_item?: Maybe; delete_markdown_pages_items?: Maybe; delete_nav_link_item?: Maybe; @@ -136,6 +176,10 @@ export type Mutation = { delete_quote_lists_items_items?: Maybe; delete_quotes_item?: Maybe; delete_quotes_items?: Maybe; + delete_rich_text_columns_item?: Maybe; + delete_rich_text_columns_items?: Maybe; + delete_section_header_item?: Maybe; + delete_section_header_items?: Maybe; delete_site_settings_nav_list_item?: Maybe; delete_site_settings_nav_list_items?: Maybe; delete_solution_features_item?: Maybe; @@ -157,9 +201,15 @@ export type Mutation = { update_article_cards_batch: Array; update_article_cards_item?: Maybe; update_article_cards_items: Array; + update_blog_cards_batch: Array; + update_blog_cards_item?: Maybe; + update_blog_cards_items: Array; update_callouts_batch: Array; update_callouts_item?: Maybe; update_callouts_items: Array; + update_cards_batch: Array; + update_cards_item?: Maybe; + update_cards_items: Array; update_case_studies_batch: Array; update_case_studies_item?: Maybe; update_case_studies_items: Array; @@ -181,6 +231,18 @@ export type Mutation = { update_company_logos_batch: Array; update_company_logos_item?: Maybe; update_company_logos_items: Array; + update_cta_batch: Array; + update_cta_item?: Maybe; + update_cta_items: Array; + update_custom_pages_batch: Array; + update_custom_pages_components_batch: Array; + update_custom_pages_components_item?: Maybe; + update_custom_pages_components_items: Array; + update_custom_pages_item?: Maybe; + update_custom_pages_items: Array; + update_customer_quote_batch: Array; + update_customer_quote_item?: Maybe; + update_customer_quote_items: Array; update_events_batch: Array; update_events_item?: Maybe; update_events_items: Array; @@ -190,9 +252,18 @@ export type Mutation = { update_featured_contributors_batch: Array; update_featured_contributors_item?: Maybe; update_featured_contributors_items: Array; + update_hero_batch: Array; + update_hero_item?: Maybe; + update_hero_items: Array; update_job_listings_batch: Array; update_job_listings_item?: Maybe; update_job_listings_items: Array; + update_large_image_batch: Array; + update_large_image_item?: Maybe; + update_large_image_items: Array; + update_logo_strip_batch: Array; + update_logo_strip_item?: Maybe; + update_logo_strip_items: Array; update_markdown_pages_batch: Array; update_markdown_pages_item?: Maybe; update_markdown_pages_items: Array; @@ -227,6 +298,12 @@ export type Mutation = { update_quotes_batch: Array; update_quotes_item?: Maybe; update_quotes_items: Array; + update_rich_text_columns_batch: Array; + update_rich_text_columns_item?: Maybe; + update_rich_text_columns_items: Array; + update_section_header_batch: Array; + update_section_header_item?: Maybe; + update_section_header_items: Array; update_site_settings?: Maybe; update_site_settings_nav_list_batch: Array; update_site_settings_nav_list_item?: Maybe; @@ -285,6 +362,22 @@ export type MutationCreate_Article_Cards_ItemsArgs = { }; +export type MutationCreate_Blog_Cards_ItemArgs = { + data: Create_Blog_Cards_Input; +}; + + +export type MutationCreate_Blog_Cards_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationCreate_Callouts_ItemArgs = { data: Create_Callouts_Input; }; @@ -301,6 +394,22 @@ export type MutationCreate_Callouts_ItemsArgs = { }; +export type MutationCreate_Cards_ItemArgs = { + data: Create_Cards_Input; +}; + + +export type MutationCreate_Cards_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationCreate_Case_Studies_ItemArgs = { data: Create_Case_Studies_Input; }; @@ -413,6 +522,70 @@ export type MutationCreate_Company_Logos_ItemsArgs = { }; +export type MutationCreate_Cta_ItemArgs = { + data: Create_Cta_Input; +}; + + +export type MutationCreate_Cta_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationCreate_Custom_Pages_Components_ItemArgs = { + data: Create_Custom_Pages_Components_Input; +}; + + +export type MutationCreate_Custom_Pages_Components_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationCreate_Custom_Pages_ItemArgs = { + data: Create_Custom_Pages_Input; +}; + + +export type MutationCreate_Custom_Pages_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationCreate_Customer_Quote_ItemArgs = { + data: Create_Customer_Quote_Input; +}; + + +export type MutationCreate_Customer_Quote_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationCreate_Events_ItemArgs = { data: Create_Events_Input; }; @@ -461,6 +634,22 @@ export type MutationCreate_Featured_Contributors_ItemsArgs = { }; +export type MutationCreate_Hero_ItemArgs = { + data: Create_Hero_Input; +}; + + +export type MutationCreate_Hero_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationCreate_Job_Listings_ItemArgs = { data: Create_Job_Listings_Input; }; @@ -477,6 +666,38 @@ export type MutationCreate_Job_Listings_ItemsArgs = { }; +export type MutationCreate_Large_Image_ItemArgs = { + data: Create_Large_Image_Input; +}; + + +export type MutationCreate_Large_Image_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationCreate_Logo_Strip_ItemArgs = { + data: Create_Logo_Strip_Input; +}; + + +export type MutationCreate_Logo_Strip_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationCreate_Markdown_Pages_ItemArgs = { data: Create_Markdown_Pages_Input; }; @@ -637,6 +858,38 @@ export type MutationCreate_Quotes_ItemsArgs = { }; +export type MutationCreate_Rich_Text_Columns_ItemArgs = { + data: Create_Rich_Text_Columns_Input; +}; + + +export type MutationCreate_Rich_Text_Columns_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationCreate_Section_Header_ItemArgs = { + data: Create_Section_Header_Input; +}; + + +export type MutationCreate_Section_Header_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationCreate_Site_Settings_Nav_List_ItemArgs = { data: Create_Site_Settings_Nav_List_Input; }; @@ -769,6 +1022,16 @@ export type MutationDelete_Article_Cards_ItemsArgs = { }; +export type MutationDelete_Blog_Cards_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Blog_Cards_ItemsArgs = { + ids: Array>; +}; + + export type MutationDelete_Callouts_ItemArgs = { id: Scalars['ID']['input']; }; @@ -779,6 +1042,16 @@ export type MutationDelete_Callouts_ItemsArgs = { }; +export type MutationDelete_Cards_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Cards_ItemsArgs = { + ids: Array>; +}; + + export type MutationDelete_Case_Studies_ItemArgs = { id: Scalars['ID']['input']; }; @@ -849,6 +1122,46 @@ export type MutationDelete_Company_Logos_ItemsArgs = { }; +export type MutationDelete_Cta_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Cta_ItemsArgs = { + ids: Array>; +}; + + +export type MutationDelete_Custom_Pages_Components_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Custom_Pages_Components_ItemsArgs = { + ids: Array>; +}; + + +export type MutationDelete_Custom_Pages_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Custom_Pages_ItemsArgs = { + ids: Array>; +}; + + +export type MutationDelete_Customer_Quote_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Customer_Quote_ItemsArgs = { + ids: Array>; +}; + + export type MutationDelete_Events_ItemArgs = { id: Scalars['ID']['input']; }; @@ -879,6 +1192,16 @@ export type MutationDelete_Featured_Contributors_ItemsArgs = { }; +export type MutationDelete_Hero_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Hero_ItemsArgs = { + ids: Array>; +}; + + export type MutationDelete_Job_Listings_ItemArgs = { id: Scalars['ID']['input']; }; @@ -889,6 +1212,26 @@ export type MutationDelete_Job_Listings_ItemsArgs = { }; +export type MutationDelete_Large_Image_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Large_Image_ItemsArgs = { + ids: Array>; +}; + + +export type MutationDelete_Logo_Strip_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Logo_Strip_ItemsArgs = { + ids: Array>; +}; + + export type MutationDelete_Markdown_Pages_ItemArgs = { id: Scalars['ID']['input']; }; @@ -989,6 +1332,26 @@ export type MutationDelete_Quotes_ItemsArgs = { }; +export type MutationDelete_Rich_Text_Columns_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Rich_Text_Columns_ItemsArgs = { + ids: Array>; +}; + + +export type MutationDelete_Section_Header_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Section_Header_ItemsArgs = { + ids: Array>; +}; + + export type MutationDelete_Site_Settings_Nav_List_ItemArgs = { id: Scalars['ID']['input']; }; @@ -1122,6 +1485,35 @@ export type MutationUpdate_Article_Cards_ItemsArgs = { }; +export type MutationUpdate_Blog_Cards_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Blog_Cards_ItemArgs = { + data: Update_Blog_Cards_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Blog_Cards_ItemsArgs = { + data: Update_Blog_Cards_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationUpdate_Callouts_BatchArgs = { data?: InputMaybe>; filter?: InputMaybe; @@ -1151,6 +1543,35 @@ export type MutationUpdate_Callouts_ItemsArgs = { }; +export type MutationUpdate_Cards_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Cards_ItemArgs = { + data: Update_Cards_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Cards_ItemsArgs = { + data: Update_Cards_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationUpdate_Case_Studies_BatchArgs = { data?: InputMaybe>; filter?: InputMaybe; @@ -1354,9 +1775,9 @@ export type MutationUpdate_Company_Logos_ItemsArgs = { }; -export type MutationUpdate_Events_BatchArgs = { - data?: InputMaybe>; - filter?: InputMaybe; +export type MutationUpdate_Cta_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; limit?: InputMaybe; offset?: InputMaybe; page?: InputMaybe; @@ -1365,8 +1786,124 @@ export type MutationUpdate_Events_BatchArgs = { }; -export type MutationUpdate_Events_ItemArgs = { - data: Update_Events_Input; +export type MutationUpdate_Cta_ItemArgs = { + data: Update_Cta_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Cta_ItemsArgs = { + data: Update_Cta_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Custom_Pages_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Custom_Pages_Components_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Custom_Pages_Components_ItemArgs = { + data: Update_Custom_Pages_Components_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Custom_Pages_Components_ItemsArgs = { + data: Update_Custom_Pages_Components_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Custom_Pages_ItemArgs = { + data: Update_Custom_Pages_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Custom_Pages_ItemsArgs = { + data: Update_Custom_Pages_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Customer_Quote_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Customer_Quote_ItemArgs = { + data: Update_Customer_Quote_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Customer_Quote_ItemsArgs = { + data: Update_Customer_Quote_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Events_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Events_ItemArgs = { + data: Update_Events_Input; id: Scalars['ID']['input']; }; @@ -1441,6 +1978,35 @@ export type MutationUpdate_Featured_Contributors_ItemsArgs = { }; +export type MutationUpdate_Hero_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Hero_ItemArgs = { + data: Update_Hero_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Hero_ItemsArgs = { + data: Update_Hero_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationUpdate_Job_Listings_BatchArgs = { data?: InputMaybe>; filter?: InputMaybe; @@ -1470,6 +2036,64 @@ export type MutationUpdate_Job_Listings_ItemsArgs = { }; +export type MutationUpdate_Large_Image_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Large_Image_ItemArgs = { + data: Update_Large_Image_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Large_Image_ItemsArgs = { + data: Update_Large_Image_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Logo_Strip_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Logo_Strip_ItemArgs = { + data: Update_Logo_Strip_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Logo_Strip_ItemsArgs = { + data: Update_Logo_Strip_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationUpdate_Markdown_Pages_BatchArgs = { data?: InputMaybe>; filter?: InputMaybe; @@ -1780,6 +2404,64 @@ export type MutationUpdate_Quotes_ItemsArgs = { }; +export type MutationUpdate_Rich_Text_Columns_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Rich_Text_Columns_ItemArgs = { + data: Update_Rich_Text_Columns_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Rich_Text_Columns_ItemsArgs = { + data: Update_Rich_Text_Columns_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Section_Header_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Section_Header_ItemArgs = { + data: Update_Section_Header_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Section_Header_ItemsArgs = { + data: Update_Section_Header_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationUpdate_Site_SettingsArgs = { data: Update_Site_Settings_Input; }; @@ -2001,9 +2683,15 @@ export type Query = { article_cards: Array; article_cards_aggregated: Array; article_cards_by_id?: Maybe; + blog_cards: Array; + blog_cards_aggregated: Array; + blog_cards_by_id?: Maybe; callouts: Array; callouts_aggregated: Array; callouts_by_id?: Maybe; + cards: Array; + cards_aggregated: Array; + cards_by_id?: Maybe; case_studies: Array; case_studies_aggregated: Array; case_studies_by_id?: Maybe; @@ -2025,6 +2713,18 @@ export type Query = { company_logos: Array; company_logos_aggregated: Array; company_logos_by_id?: Maybe; + cta: Array; + cta_aggregated: Array; + cta_by_id?: Maybe; + custom_pages: Array; + custom_pages_aggregated: Array; + custom_pages_by_id?: Maybe; + custom_pages_components: Array; + custom_pages_components_aggregated: Array; + custom_pages_components_by_id?: Maybe; + customer_quote: Array; + customer_quote_aggregated: Array; + customer_quote_by_id?: Maybe; events: Array; events_aggregated: Array; events_by_id?: Maybe; @@ -2034,9 +2734,18 @@ export type Query = { featured_contributors: Array; featured_contributors_aggregated: Array; featured_contributors_by_id?: Maybe; + hero: Array; + hero_aggregated: Array; + hero_by_id?: Maybe; job_listings: Array; job_listings_aggregated: Array; job_listings_by_id?: Maybe; + large_image: Array; + large_image_aggregated: Array; + large_image_by_id?: Maybe; + logo_strip: Array; + logo_strip_aggregated: Array; + logo_strip_by_id?: Maybe; markdown_pages: Array; markdown_pages_aggregated: Array; markdown_pages_by_id?: Maybe; @@ -2071,6 +2780,12 @@ export type Query = { quotes: Array; quotes_aggregated: Array; quotes_by_id?: Maybe; + rich_text_columns: Array; + rich_text_columns_aggregated: Array; + rich_text_columns_by_id?: Maybe; + section_header: Array; + section_header_aggregated: Array; + section_header_by_id?: Maybe; site_settings?: Maybe; site_settings_nav_list: Array; site_settings_nav_list_aggregated: Array; @@ -2149,6 +2864,32 @@ export type QueryArticle_Cards_By_IdArgs = { }; +export type QueryBlog_CardsArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryBlog_Cards_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryBlog_Cards_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + export type QueryCalloutsArgs = { filter?: InputMaybe; limit?: InputMaybe; @@ -2175,6 +2916,32 @@ export type QueryCallouts_By_IdArgs = { }; +export type QueryCardsArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryCards_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryCards_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + export type QueryCase_StudiesArgs = { filter?: InputMaybe; limit?: InputMaybe; @@ -2357,8 +3124,8 @@ export type QueryCompany_Logos_By_IdArgs = { }; -export type QueryEventsArgs = { - filter?: InputMaybe; +export type QueryCtaArgs = { + filter?: InputMaybe; limit?: InputMaybe; offset?: InputMaybe; page?: InputMaybe; @@ -2367,8 +3134,8 @@ export type QueryEventsArgs = { }; -export type QueryEvents_AggregatedArgs = { - filter?: InputMaybe; +export type QueryCta_AggregatedArgs = { + filter?: InputMaybe; groupBy?: InputMaybe>>; limit?: InputMaybe; offset?: InputMaybe; @@ -2378,13 +3145,13 @@ export type QueryEvents_AggregatedArgs = { }; -export type QueryEvents_By_IdArgs = { +export type QueryCta_By_IdArgs = { id: Scalars['ID']['input']; }; -export type QueryFaqsArgs = { - filter?: InputMaybe; +export type QueryCustom_PagesArgs = { + filter?: InputMaybe; limit?: InputMaybe; offset?: InputMaybe; page?: InputMaybe; @@ -2393,8 +3160,8 @@ export type QueryFaqsArgs = { }; -export type QueryFaqs_AggregatedArgs = { - filter?: InputMaybe; +export type QueryCustom_Pages_AggregatedArgs = { + filter?: InputMaybe; groupBy?: InputMaybe>>; limit?: InputMaybe; offset?: InputMaybe; @@ -2404,13 +3171,13 @@ export type QueryFaqs_AggregatedArgs = { }; -export type QueryFaqs_By_IdArgs = { +export type QueryCustom_Pages_By_IdArgs = { id: Scalars['ID']['input']; }; -export type QueryFeatured_ContributorsArgs = { - filter?: InputMaybe; +export type QueryCustom_Pages_ComponentsArgs = { + filter?: InputMaybe; limit?: InputMaybe; offset?: InputMaybe; page?: InputMaybe; @@ -2419,8 +3186,8 @@ export type QueryFeatured_ContributorsArgs = { }; -export type QueryFeatured_Contributors_AggregatedArgs = { - filter?: InputMaybe; +export type QueryCustom_Pages_Components_AggregatedArgs = { + filter?: InputMaybe; groupBy?: InputMaybe>>; limit?: InputMaybe; offset?: InputMaybe; @@ -2430,13 +3197,13 @@ export type QueryFeatured_Contributors_AggregatedArgs = { }; -export type QueryFeatured_Contributors_By_IdArgs = { +export type QueryCustom_Pages_Components_By_IdArgs = { id: Scalars['ID']['input']; }; -export type QueryJob_ListingsArgs = { - filter?: InputMaybe; +export type QueryCustomer_QuoteArgs = { + filter?: InputMaybe; limit?: InputMaybe; offset?: InputMaybe; page?: InputMaybe; @@ -2445,8 +3212,8 @@ export type QueryJob_ListingsArgs = { }; -export type QueryJob_Listings_AggregatedArgs = { - filter?: InputMaybe; +export type QueryCustomer_Quote_AggregatedArgs = { + filter?: InputMaybe; groupBy?: InputMaybe>>; limit?: InputMaybe; offset?: InputMaybe; @@ -2456,7 +3223,189 @@ export type QueryJob_Listings_AggregatedArgs = { }; -export type QueryJob_Listings_By_IdArgs = { +export type QueryCustomer_Quote_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + +export type QueryEventsArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryEvents_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryEvents_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + +export type QueryFaqsArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryFaqs_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryFaqs_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + +export type QueryFeatured_ContributorsArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryFeatured_Contributors_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryFeatured_Contributors_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + +export type QueryHeroArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryHero_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryHero_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + +export type QueryJob_ListingsArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryJob_Listings_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryJob_Listings_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + +export type QueryLarge_ImageArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryLarge_Image_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryLarge_Image_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + +export type QueryLogo_StripArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryLogo_Strip_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryLogo_Strip_By_IdArgs = { id: Scalars['ID']['input']; }; @@ -2721,6 +3670,58 @@ export type QueryQuotes_By_IdArgs = { }; +export type QueryRich_Text_ColumnsArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryRich_Text_Columns_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryRich_Text_Columns_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + +export type QuerySection_HeaderArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QuerySection_Header_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QuerySection_Header_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + export type QuerySite_Settings_Nav_ListArgs = { filter?: InputMaybe; limit?: InputMaybe; @@ -3164,44 +4165,20 @@ export type Article_Cards_Filter = { videoUrl?: InputMaybe; }; -export type Boolean_Filter_Operators = { - _eq?: InputMaybe; - _neq?: InputMaybe; - _nnull?: InputMaybe; - _null?: InputMaybe; -}; - -export type Callouts = { - __typename?: 'callouts'; - callout_id?: Maybe; - category?: Maybe; - content?: Maybe; - ctas?: Maybe; - ctas_func?: Maybe; +export type Blog_Cards = { + __typename?: 'blog_cards'; date_created?: Maybe; date_created_func?: Maybe; date_updated?: Maybe; date_updated_func?: Maybe; id: Scalars['ID']['output']; - sort?: Maybe; - status?: Maybe; - title?: Maybe; + spacing?: Maybe; user_created?: Maybe; user_updated?: Maybe; }; -export type CalloutsCallout_IdArgs = { - filter?: InputMaybe; - limit?: InputMaybe; - offset?: InputMaybe; - page?: InputMaybe; - search?: InputMaybe; - sort?: InputMaybe>>; -}; - - -export type CalloutsUser_CreatedArgs = { +export type Blog_CardsUser_CreatedArgs = { filter?: InputMaybe; limit?: InputMaybe; offset?: InputMaybe; @@ -3211,7 +4188,7 @@ export type CalloutsUser_CreatedArgs = { }; -export type CalloutsUser_UpdatedArgs = { +export type Blog_CardsUser_UpdatedArgs = { filter?: InputMaybe; limit?: InputMaybe; offset?: InputMaybe; @@ -3220,31 +4197,129 @@ export type CalloutsUser_UpdatedArgs = { sort?: InputMaybe>>; }; -export type Callouts_Aggregated = { - __typename?: 'callouts_aggregated'; - avg?: Maybe; - avgDistinct?: Maybe; - count?: Maybe; +export type Blog_Cards_Aggregated = { + __typename?: 'blog_cards_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; countAll?: Maybe; - countDistinct?: Maybe; + countDistinct?: Maybe; group?: Maybe; - max?: Maybe; - min?: Maybe; - sum?: Maybe; - sumDistinct?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; }; -export type Callouts_Aggregated_Count = { - __typename?: 'callouts_aggregated_count'; - callout_id?: Maybe; - category?: Maybe; - content?: Maybe; - ctas?: Maybe; +export type Blog_Cards_Aggregated_Count = { + __typename?: 'blog_cards_aggregated_count'; date_created?: Maybe; date_updated?: Maybe; id?: Maybe; - sort?: Maybe; - status?: Maybe; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + +export type Blog_Cards_Aggregated_Fields = { + __typename?: 'blog_cards_aggregated_fields'; + id?: Maybe; +}; + +export type Blog_Cards_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + date_created?: InputMaybe; + date_created_func?: InputMaybe; + date_updated?: InputMaybe; + date_updated_func?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Boolean_Filter_Operators = { + _eq?: InputMaybe; + _neq?: InputMaybe; + _nnull?: InputMaybe; + _null?: InputMaybe; +}; + +export type Callouts = { + __typename?: 'callouts'; + callout_id?: Maybe; + category?: Maybe; + content?: Maybe; + ctas?: Maybe; + ctas_func?: Maybe; + date_created?: Maybe; + date_created_func?: Maybe; + date_updated?: Maybe; + date_updated_func?: Maybe; + id: Scalars['ID']['output']; + sort?: Maybe; + status?: Maybe; + title?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + + +export type CalloutsCallout_IdArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type CalloutsUser_CreatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type CalloutsUser_UpdatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Callouts_Aggregated = { + __typename?: 'callouts_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Callouts_Aggregated_Count = { + __typename?: 'callouts_aggregated_count'; + callout_id?: Maybe; + category?: Maybe; + content?: Maybe; + ctas?: Maybe; + date_created?: Maybe; + date_updated?: Maybe; + id?: Maybe; + sort?: Maybe; + status?: Maybe; title?: Maybe; user_created?: Maybe; user_updated?: Maybe; @@ -3277,6 +4352,80 @@ export type Callouts_Filter = { user_updated?: InputMaybe; }; +export type Cards = { + __typename?: 'cards'; + date_created?: Maybe; + date_created_func?: Maybe; + date_updated?: Maybe; + date_updated_func?: Maybe; + id: Scalars['ID']['output']; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + + +export type CardsUser_CreatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type CardsUser_UpdatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Cards_Aggregated = { + __typename?: 'cards_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Cards_Aggregated_Count = { + __typename?: 'cards_aggregated_count'; + date_created?: Maybe; + date_updated?: Maybe; + id?: Maybe; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + +export type Cards_Aggregated_Fields = { + __typename?: 'cards_aggregated_fields'; + id?: Maybe; +}; + +export type Cards_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + date_created?: InputMaybe; + date_created_func?: InputMaybe; + date_updated?: InputMaybe; + date_updated_func?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + export type Case_Studies = { __typename?: 'case_studies'; case_study_id?: Maybe; @@ -3936,6 +5085,15 @@ export type Create_Article_Cards_Input = { videoUrl?: InputMaybe; }; +export type Create_Blog_Cards_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + export type Create_Callouts_Input = { callout_id?: InputMaybe; category?: InputMaybe; @@ -3951,6 +5109,15 @@ export type Create_Callouts_Input = { user_updated?: InputMaybe; }; +export type Create_Cards_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + export type Create_Case_Studies_Input = { case_study_id?: InputMaybe; content?: InputMaybe; @@ -4034,6 +5201,42 @@ export type Create_Company_Logos_Input = { width?: InputMaybe; }; +export type Create_Cta_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Create_Custom_Pages_Components_Input = { + collection?: InputMaybe; + custom_pages_id?: InputMaybe; + id?: InputMaybe; + item?: InputMaybe; +}; + +export type Create_Custom_Pages_Input = { + components?: InputMaybe>>; + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + slug: Scalars['String']['input']; + status?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Create_Customer_Quote_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + export type Create_Directus_Files_Input = { charset?: InputMaybe; description?: InputMaybe; @@ -4154,6 +5357,23 @@ export type Create_Featured_Contributors_Input = { user_updated?: InputMaybe; }; +export type Create_Hero_Input = { + body_text?: InputMaybe; + cta_text?: InputMaybe; + cta_url?: InputMaybe; + date_created?: InputMaybe; + date_updated?: InputMaybe; + form?: InputMaybe; + heading?: InputMaybe; + id?: InputMaybe; + image?: InputMaybe; + media_type?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; + video_url?: InputMaybe; +}; + export type Create_Job_Listings_Input = { content?: InputMaybe; date_created?: InputMaybe; @@ -4169,6 +5389,23 @@ export type Create_Job_Listings_Input = { user_updated?: InputMaybe; }; +export type Create_Large_Image_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Create_Logo_Strip_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; +}; + export type Create_Markdown_Pages_Input = { content?: InputMaybe; date_created?: InputMaybe; @@ -4307,6 +5544,24 @@ export type Create_Quotes_Input = { user_updated?: InputMaybe; }; +export type Create_Rich_Text_Columns_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Create_Section_Header_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + export type Create_Site_Settings_Input = { date_created?: InputMaybe; date_updated?: InputMaybe; @@ -4415,6 +5670,311 @@ export type Create_Team_Members_Input = { title?: InputMaybe; }; +export type Cta = { + __typename?: 'cta'; + date_created?: Maybe; + date_created_func?: Maybe; + date_updated?: Maybe; + date_updated_func?: Maybe; + id: Scalars['ID']['output']; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + + +export type CtaUser_CreatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type CtaUser_UpdatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Cta_Aggregated = { + __typename?: 'cta_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Cta_Aggregated_Count = { + __typename?: 'cta_aggregated_count'; + date_created?: Maybe; + date_updated?: Maybe; + id?: Maybe; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + +export type Cta_Aggregated_Fields = { + __typename?: 'cta_aggregated_fields'; + id?: Maybe; +}; + +export type Cta_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + date_created?: InputMaybe; + date_created_func?: InputMaybe; + date_updated?: InputMaybe; + date_updated_func?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Custom_Pages = { + __typename?: 'custom_pages'; + components?: Maybe>>; + components_func?: Maybe; + date_created?: Maybe; + date_created_func?: Maybe; + date_updated?: Maybe; + date_updated_func?: Maybe; + id: Scalars['ID']['output']; + slug: Scalars['String']['output']; + status?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + + +export type Custom_PagesComponentsArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type Custom_PagesUser_CreatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type Custom_PagesUser_UpdatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Custom_Pages_Aggregated = { + __typename?: 'custom_pages_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Custom_Pages_Aggregated_Count = { + __typename?: 'custom_pages_aggregated_count'; + components?: Maybe; + date_created?: Maybe; + date_updated?: Maybe; + id?: Maybe; + slug?: Maybe; + status?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + +export type Custom_Pages_Aggregated_Fields = { + __typename?: 'custom_pages_aggregated_fields'; + id?: Maybe; +}; + +export type Custom_Pages_Components = { + __typename?: 'custom_pages_components'; + collection?: Maybe; + custom_pages_id?: Maybe; + id: Scalars['ID']['output']; + item?: Maybe; +}; + + +export type Custom_Pages_ComponentsCustom_Pages_IdArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Custom_Pages_Components_Aggregated = { + __typename?: 'custom_pages_components_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Custom_Pages_Components_Aggregated_Count = { + __typename?: 'custom_pages_components_aggregated_count'; + collection?: Maybe; + custom_pages_id?: Maybe; + id?: Maybe; + item?: Maybe; +}; + +export type Custom_Pages_Components_Aggregated_Fields = { + __typename?: 'custom_pages_components_aggregated_fields'; + custom_pages_id?: Maybe; + id?: Maybe; +}; + +export type Custom_Pages_Components_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + collection?: InputMaybe; + custom_pages_id?: InputMaybe; + id?: InputMaybe; + item__blog_cards?: InputMaybe; + item__cards?: InputMaybe; + item__cta?: InputMaybe; + item__customer_quote?: InputMaybe; + item__hero?: InputMaybe; + item__large_image?: InputMaybe; + item__logo_strip?: InputMaybe; + item__rich_text_columns?: InputMaybe; + item__section_header?: InputMaybe; +}; + +export type Custom_Pages_Components_Item_Union = Blog_Cards | Cards | Cta | Customer_Quote | Hero | Large_Image | Logo_Strip | Rich_Text_Columns | Section_Header; + +export type Custom_Pages_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + components?: InputMaybe; + components_func?: InputMaybe; + date_created?: InputMaybe; + date_created_func?: InputMaybe; + date_updated?: InputMaybe; + date_updated_func?: InputMaybe; + id?: InputMaybe; + slug?: InputMaybe; + status?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Customer_Quote = { + __typename?: 'customer_quote'; + date_created?: Maybe; + date_created_func?: Maybe; + date_updated?: Maybe; + date_updated_func?: Maybe; + id: Scalars['ID']['output']; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + + +export type Customer_QuoteUser_CreatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type Customer_QuoteUser_UpdatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Customer_Quote_Aggregated = { + __typename?: 'customer_quote_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Customer_Quote_Aggregated_Count = { + __typename?: 'customer_quote_aggregated_count'; + date_created?: Maybe; + date_updated?: Maybe; + id?: Maybe; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + +export type Customer_Quote_Aggregated_Fields = { + __typename?: 'customer_quote_aggregated_fields'; + id?: Maybe; +}; + +export type Customer_Quote_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + date_created?: InputMaybe; + date_created_func?: InputMaybe; + date_updated?: InputMaybe; + date_updated_func?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + export type Date_Filter_Operators = { _between?: InputMaybe>>; _eq?: InputMaybe; @@ -4995,59 +6555,167 @@ export type Featured_Contributors_Aggregated = { sumDistinct?: Maybe; }; -export type Featured_Contributors_Aggregated_Count = { - __typename?: 'featured_contributors_aggregated_count'; - content?: Maybe; - ctas?: Maybe; +export type Featured_Contributors_Aggregated_Count = { + __typename?: 'featured_contributors_aggregated_count'; + content?: Maybe; + ctas?: Maybe; + date_created?: Maybe; + date_updated?: Maybe; + id?: Maybe; + name?: Maybe; + portrait?: Maybe; + social_github_url?: Maybe; + social_linkedin_url?: Maybe; + social_twitter_url?: Maybe; + sort?: Maybe; + status?: Maybe; + title?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + +export type Featured_Contributors_Aggregated_Fields = { + __typename?: 'featured_contributors_aggregated_fields'; + id?: Maybe; + sort?: Maybe; +}; + +export type Featured_Contributors_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + content?: InputMaybe; + ctas?: InputMaybe; + ctas_func?: InputMaybe; + date_created?: InputMaybe; + date_created_func?: InputMaybe; + date_updated?: InputMaybe; + date_updated_func?: InputMaybe; + id?: InputMaybe; + name?: InputMaybe; + portrait?: InputMaybe; + social_github_url?: InputMaybe; + social_linkedin_url?: InputMaybe; + social_twitter_url?: InputMaybe; + sort?: InputMaybe; + status?: InputMaybe; + title?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Hash_Filter_Operators = { + _empty?: InputMaybe; + _nempty?: InputMaybe; + _nnull?: InputMaybe; + _null?: InputMaybe; +}; + +export type Hero = { + __typename?: 'hero'; + body_text?: Maybe; + cta_text?: Maybe; + cta_url?: Maybe; + date_created?: Maybe; + date_created_func?: Maybe; + date_updated?: Maybe; + date_updated_func?: Maybe; + form?: Maybe; + heading?: Maybe; + id: Scalars['ID']['output']; + image?: Maybe; + media_type?: Maybe; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; + video_url?: Maybe; +}; + + +export type HeroImageArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type HeroUser_CreatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type HeroUser_UpdatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Hero_Aggregated = { + __typename?: 'hero_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Hero_Aggregated_Count = { + __typename?: 'hero_aggregated_count'; + body_text?: Maybe; + cta_text?: Maybe; + cta_url?: Maybe; date_created?: Maybe; date_updated?: Maybe; + form?: Maybe; + heading?: Maybe; id?: Maybe; - name?: Maybe; - portrait?: Maybe; - social_github_url?: Maybe; - social_linkedin_url?: Maybe; - social_twitter_url?: Maybe; - sort?: Maybe; - status?: Maybe; - title?: Maybe; + image?: Maybe; + media_type?: Maybe; + spacing?: Maybe; user_created?: Maybe; user_updated?: Maybe; + video_url?: Maybe; }; -export type Featured_Contributors_Aggregated_Fields = { - __typename?: 'featured_contributors_aggregated_fields'; +export type Hero_Aggregated_Fields = { + __typename?: 'hero_aggregated_fields'; id?: Maybe; - sort?: Maybe; }; -export type Featured_Contributors_Filter = { - _and?: InputMaybe>>; - _or?: InputMaybe>>; - content?: InputMaybe; - ctas?: InputMaybe; - ctas_func?: InputMaybe; +export type Hero_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + body_text?: InputMaybe; + cta_text?: InputMaybe; + cta_url?: InputMaybe; date_created?: InputMaybe; date_created_func?: InputMaybe; date_updated?: InputMaybe; date_updated_func?: InputMaybe; + form?: InputMaybe; + heading?: InputMaybe; id?: InputMaybe; - name?: InputMaybe; - portrait?: InputMaybe; - social_github_url?: InputMaybe; - social_linkedin_url?: InputMaybe; - social_twitter_url?: InputMaybe; - sort?: InputMaybe; - status?: InputMaybe; - title?: InputMaybe; + image?: InputMaybe; + media_type?: InputMaybe; + spacing?: InputMaybe; user_created?: InputMaybe; user_updated?: InputMaybe; -}; - -export type Hash_Filter_Operators = { - _empty?: InputMaybe; - _nempty?: InputMaybe; - _nnull?: InputMaybe; - _null?: InputMaybe; + video_url?: InputMaybe; }; export type Job_Listings = { @@ -5144,6 +6812,141 @@ export type Job_Listings_Filter = { user_updated?: InputMaybe; }; +export type Large_Image = { + __typename?: 'large_image'; + date_created?: Maybe; + date_created_func?: Maybe; + date_updated?: Maybe; + date_updated_func?: Maybe; + id: Scalars['ID']['output']; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + + +export type Large_ImageUser_CreatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type Large_ImageUser_UpdatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Large_Image_Aggregated = { + __typename?: 'large_image_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Large_Image_Aggregated_Count = { + __typename?: 'large_image_aggregated_count'; + date_created?: Maybe; + date_updated?: Maybe; + id?: Maybe; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + +export type Large_Image_Aggregated_Fields = { + __typename?: 'large_image_aggregated_fields'; + id?: Maybe; +}; + +export type Large_Image_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + date_created?: InputMaybe; + date_created_func?: InputMaybe; + date_updated?: InputMaybe; + date_updated_func?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Logo_Strip = { + __typename?: 'logo_strip'; + date_created?: Maybe; + date_created_func?: Maybe; + date_updated?: Maybe; + date_updated_func?: Maybe; + id: Scalars['ID']['output']; + spacing?: Maybe; + user_created?: Maybe; +}; + + +export type Logo_StripUser_CreatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Logo_Strip_Aggregated = { + __typename?: 'logo_strip_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Logo_Strip_Aggregated_Count = { + __typename?: 'logo_strip_aggregated_count'; + date_created?: Maybe; + date_updated?: Maybe; + id?: Maybe; + spacing?: Maybe; + user_created?: Maybe; +}; + +export type Logo_Strip_Aggregated_Fields = { + __typename?: 'logo_strip_aggregated_fields'; + id?: Maybe; +}; + +export type Logo_Strip_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + date_created?: InputMaybe; + date_created_func?: InputMaybe; + date_updated?: InputMaybe; + date_updated_func?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; +}; + export type Markdown_Pages = { __typename?: 'markdown_pages'; content?: Maybe; @@ -6073,29 +7876,149 @@ export type Quote_Lists_Items_Filter = { export type Quote_Lists_Items_Item_Union = Quotes; -export type Quotes = { - __typename?: 'quotes'; - author_text?: Maybe; - company?: Maybe; +export type Quotes = { + __typename?: 'quotes'; + author_text?: Maybe; + company?: Maybe; + date_created?: Maybe; + date_created_func?: Maybe; + date_updated?: Maybe; + date_updated_func?: Maybe; + id: Scalars['ID']['output']; + logo?: Maybe; + name?: Maybe; + portrait?: Maybe; + quote?: Maybe; + quote_id?: Maybe; + status?: Maybe; + title?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + + +export type QuotesLogoArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QuotesPortraitArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QuotesQuote_IdArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QuotesUser_CreatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QuotesUser_UpdatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Quotes_Aggregated = { + __typename?: 'quotes_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Quotes_Aggregated_Count = { + __typename?: 'quotes_aggregated_count'; + author_text?: Maybe; + company?: Maybe; + date_created?: Maybe; + date_updated?: Maybe; + id?: Maybe; + logo?: Maybe; + name?: Maybe; + portrait?: Maybe; + quote?: Maybe; + quote_id?: Maybe; + status?: Maybe; + title?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + +export type Quotes_Aggregated_Fields = { + __typename?: 'quotes_aggregated_fields'; + id?: Maybe; +}; + +export type Quotes_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + author_text?: InputMaybe; + company?: InputMaybe; + date_created?: InputMaybe; + date_created_func?: InputMaybe; + date_updated?: InputMaybe; + date_updated_func?: InputMaybe; + id?: InputMaybe; + logo?: InputMaybe; + name?: InputMaybe; + portrait?: InputMaybe; + quote?: InputMaybe; + quote_id?: InputMaybe; + status?: InputMaybe; + title?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Rich_Text_Columns = { + __typename?: 'rich_text_columns'; date_created?: Maybe; date_created_func?: Maybe; date_updated?: Maybe; date_updated_func?: Maybe; id: Scalars['ID']['output']; - logo?: Maybe; - name?: Maybe; - portrait?: Maybe; - quote?: Maybe; - quote_id?: Maybe; - status?: Maybe; - title?: Maybe; + spacing?: Maybe; user_created?: Maybe; user_updated?: Maybe; }; -export type QuotesLogoArgs = { - filter?: InputMaybe; +export type Rich_Text_ColumnsUser_CreatedArgs = { + filter?: InputMaybe; limit?: InputMaybe; offset?: InputMaybe; page?: InputMaybe; @@ -6104,8 +8027,8 @@ export type QuotesLogoArgs = { }; -export type QuotesPortraitArgs = { - filter?: InputMaybe; +export type Rich_Text_ColumnsUser_UpdatedArgs = { + filter?: InputMaybe; limit?: InputMaybe; offset?: InputMaybe; page?: InputMaybe; @@ -6113,18 +8036,62 @@ export type QuotesPortraitArgs = { sort?: InputMaybe>>; }; +export type Rich_Text_Columns_Aggregated = { + __typename?: 'rich_text_columns_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; -export type QuotesQuote_IdArgs = { - filter?: InputMaybe; - limit?: InputMaybe; - offset?: InputMaybe; - page?: InputMaybe; - search?: InputMaybe; - sort?: InputMaybe>>; +export type Rich_Text_Columns_Aggregated_Count = { + __typename?: 'rich_text_columns_aggregated_count'; + date_created?: Maybe; + date_updated?: Maybe; + id?: Maybe; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; }; +export type Rich_Text_Columns_Aggregated_Fields = { + __typename?: 'rich_text_columns_aggregated_fields'; + id?: Maybe; +}; -export type QuotesUser_CreatedArgs = { +export type Rich_Text_Columns_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + date_created?: InputMaybe; + date_created_func?: InputMaybe; + date_updated?: InputMaybe; + date_updated_func?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Section_Header = { + __typename?: 'section_header'; + date_created?: Maybe; + date_created_func?: Maybe; + date_updated?: Maybe; + date_updated_func?: Maybe; + id: Scalars['ID']['output']; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + + +export type Section_HeaderUser_CreatedArgs = { filter?: InputMaybe; limit?: InputMaybe; offset?: InputMaybe; @@ -6134,7 +8101,7 @@ export type QuotesUser_CreatedArgs = { }; -export type QuotesUser_UpdatedArgs = { +export type Section_HeaderUser_UpdatedArgs = { filter?: InputMaybe; limit?: InputMaybe; offset?: InputMaybe; @@ -6143,60 +8110,44 @@ export type QuotesUser_UpdatedArgs = { sort?: InputMaybe>>; }; -export type Quotes_Aggregated = { - __typename?: 'quotes_aggregated'; - avg?: Maybe; - avgDistinct?: Maybe; - count?: Maybe; +export type Section_Header_Aggregated = { + __typename?: 'section_header_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; countAll?: Maybe; - countDistinct?: Maybe; + countDistinct?: Maybe; group?: Maybe; - max?: Maybe; - min?: Maybe; - sum?: Maybe; - sumDistinct?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; }; -export type Quotes_Aggregated_Count = { - __typename?: 'quotes_aggregated_count'; - author_text?: Maybe; - company?: Maybe; +export type Section_Header_Aggregated_Count = { + __typename?: 'section_header_aggregated_count'; date_created?: Maybe; date_updated?: Maybe; id?: Maybe; - logo?: Maybe; - name?: Maybe; - portrait?: Maybe; - quote?: Maybe; - quote_id?: Maybe; - status?: Maybe; - title?: Maybe; + spacing?: Maybe; user_created?: Maybe; user_updated?: Maybe; }; -export type Quotes_Aggregated_Fields = { - __typename?: 'quotes_aggregated_fields'; +export type Section_Header_Aggregated_Fields = { + __typename?: 'section_header_aggregated_fields'; id?: Maybe; }; -export type Quotes_Filter = { - _and?: InputMaybe>>; - _or?: InputMaybe>>; - author_text?: InputMaybe; - company?: InputMaybe; +export type Section_Header_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; date_created?: InputMaybe; date_created_func?: InputMaybe; date_updated?: InputMaybe; date_updated_func?: InputMaybe; id?: InputMaybe; - logo?: InputMaybe; - name?: InputMaybe; - portrait?: InputMaybe; - quote?: InputMaybe; - quote_id?: InputMaybe; - status?: InputMaybe; - title?: InputMaybe; + spacing?: InputMaybe; user_created?: InputMaybe; user_updated?: InputMaybe; }; @@ -7072,6 +9023,15 @@ export type Update_Article_Cards_Input = { videoUrl?: InputMaybe; }; +export type Update_Blog_Cards_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + export type Update_Callouts_Input = { callout_id?: InputMaybe; category?: InputMaybe; @@ -7087,6 +9047,15 @@ export type Update_Callouts_Input = { user_updated?: InputMaybe; }; +export type Update_Cards_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + export type Update_Case_Studies_Input = { case_study_id?: InputMaybe; content?: InputMaybe; @@ -7170,6 +9139,42 @@ export type Update_Company_Logos_Input = { width?: InputMaybe; }; +export type Update_Cta_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Update_Custom_Pages_Components_Input = { + collection?: InputMaybe; + custom_pages_id?: InputMaybe; + id?: InputMaybe; + item?: InputMaybe; +}; + +export type Update_Custom_Pages_Input = { + components?: InputMaybe>>; + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + slug?: InputMaybe; + status?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Update_Customer_Quote_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + export type Update_Directus_Files_Input = { charset?: InputMaybe; description?: InputMaybe; @@ -7290,6 +9295,23 @@ export type Update_Featured_Contributors_Input = { user_updated?: InputMaybe; }; +export type Update_Hero_Input = { + body_text?: InputMaybe; + cta_text?: InputMaybe; + cta_url?: InputMaybe; + date_created?: InputMaybe; + date_updated?: InputMaybe; + form?: InputMaybe; + heading?: InputMaybe; + id?: InputMaybe; + image?: InputMaybe; + media_type?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; + video_url?: InputMaybe; +}; + export type Update_Job_Listings_Input = { content?: InputMaybe; date_created?: InputMaybe; @@ -7305,6 +9327,23 @@ export type Update_Job_Listings_Input = { user_updated?: InputMaybe; }; +export type Update_Large_Image_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Update_Logo_Strip_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; +}; + export type Update_Markdown_Pages_Input = { content?: InputMaybe; date_created?: InputMaybe; @@ -7453,6 +9492,24 @@ export type Update_Quotes_Input = { user_updated?: InputMaybe; }; +export type Update_Rich_Text_Columns_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Update_Section_Header_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + export type Update_Site_Settings_Input = { date_created?: InputMaybe; date_updated?: InputMaybe; @@ -7653,6 +9710,40 @@ export type SolutionsQueryVariables = Exact<{ export type SolutionsQuery = { __typename?: 'Query', solutions_pages: Array<{ __typename?: 'solutions_pages', id: string, slug: string, title?: string | null, description?: string | null, upper_features_title?: string | null, lower_features_title?: string | null, download_section_title?: string | null, download_section_description?: string | null, upper_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, lower_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, problems?: Array<{ __typename?: 'solution_problems', id: string, title?: string | null, subtitle?: string | null, problem?: string | null, solution?: string | null } | null> | null, featured_quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null }> }; +export type CustomPageFragment = { __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null } | { __typename?: 'logo_strip', spacing?: string | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null } | null } | null> | null }; + +export type CustomPageTinyFragment = { __typename?: 'custom_pages', id: string, slug: string }; + +export type CustomPageSlugsQueryVariables = Exact<{ [key: string]: never; }>; + + +export type CustomPageSlugsQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string }> }; + +export type CustomPageQueryVariables = Exact<{ + slug: Scalars['String']['input']; +}>; + + +export type CustomPageQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null } | { __typename?: 'logo_strip', spacing?: string | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null } | null } | null> | null }> }; + +export type HeroComponentFragment = { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null }; + +export type LogoStripComponentFragment = { __typename?: 'logo_strip', spacing?: string | null }; + +export type SectionHeaderComponentFragment = { __typename?: 'section_header', spacing?: string | null }; + +export type LargeImageComponentFragment = { __typename?: 'large_image', spacing?: string | null }; + +export type CardsComponentFragment = { __typename?: 'cards', spacing?: string | null }; + +export type BlogCardsComponentFragment = { __typename?: 'blog_cards', spacing?: string | null }; + +export type RichTextColumnsComponentFragment = { __typename?: 'rich_text_columns', spacing?: string | null }; + +export type CustomerQuoteComponentFragment = { __typename?: 'customer_quote', spacing?: string | null }; + +export type CtaComponentFragment = { __typename?: 'cta', spacing?: string | null }; + export type MinJobListingFragment = { __typename?: 'job_listings', id: string, slug: string, job_title?: string | null, department?: string | null, tags?: any | null, location?: string | null, status?: string | null }; export type FullJobListingFragment = { __typename?: 'job_listings', content?: string | null, id: string, slug: string, job_title?: string | null, department?: string | null, tags?: any | null, location?: string | null, status?: string | null }; @@ -7967,6 +10058,95 @@ export const SolutionFragmentDoc = gql` ${SolutionFeatureFragmentDoc} ${SolutionProblemFragmentDoc} ${QuoteFragmentDoc}`; +export const HeroComponentFragmentDoc = gql` + fragment HeroComponent on hero { + spacing + heading + body_text + media_type + image { + ...ImageFile + } + video_url + form + cta_text + cta_url +} + ${ImageFileFragmentDoc}`; +export const LogoStripComponentFragmentDoc = gql` + fragment LogoStripComponent on logo_strip { + spacing +} + `; +export const SectionHeaderComponentFragmentDoc = gql` + fragment SectionHeaderComponent on section_header { + spacing +} + `; +export const LargeImageComponentFragmentDoc = gql` + fragment LargeImageComponent on large_image { + spacing +} + `; +export const CardsComponentFragmentDoc = gql` + fragment CardsComponent on cards { + spacing +} + `; +export const BlogCardsComponentFragmentDoc = gql` + fragment BlogCardsComponent on blog_cards { + spacing +} + `; +export const RichTextColumnsComponentFragmentDoc = gql` + fragment RichTextColumnsComponent on rich_text_columns { + spacing +} + `; +export const CustomerQuoteComponentFragmentDoc = gql` + fragment CustomerQuoteComponent on customer_quote { + spacing +} + `; +export const CtaComponentFragmentDoc = gql` + fragment CTAComponent on cta { + spacing +} + `; +export const CustomPageFragmentDoc = gql` + fragment CustomPage on custom_pages { + id + slug + components { + collection + item { + ...HeroComponent + ...LogoStripComponent + ...SectionHeaderComponent + ...LargeImageComponent + ...CardsComponent + ...BlogCardsComponent + ...RichTextColumnsComponent + ...CustomerQuoteComponent + ...CTAComponent + } + } +} + ${HeroComponentFragmentDoc} +${LogoStripComponentFragmentDoc} +${SectionHeaderComponentFragmentDoc} +${LargeImageComponentFragmentDoc} +${CardsComponentFragmentDoc} +${BlogCardsComponentFragmentDoc} +${RichTextColumnsComponentFragmentDoc} +${CustomerQuoteComponentFragmentDoc} +${CtaComponentFragmentDoc}`; +export const CustomPageTinyFragmentDoc = gql` + fragment CustomPageTiny on custom_pages { + id + slug +} + `; export const MinJobListingFragmentDoc = gql` fragment MinJobListing on job_listings { id @@ -8396,6 +10576,75 @@ export function useSolutionsLazyQuery(baseOptions?: Apollo.LazyQueryHookOptions< export type SolutionsQueryHookResult = ReturnType; export type SolutionsLazyQueryHookResult = ReturnType; export type SolutionsQueryResult = Apollo.QueryResult; +export const CustomPageSlugsDocument = gql` + query CustomPageSlugs { + custom_pages(filter: {status: {_eq: "published"}}) { + ...CustomPageTiny + } +} + ${CustomPageTinyFragmentDoc}`; + +/** + * __useCustomPageSlugsQuery__ + * + * To run a query within a React component, call `useCustomPageSlugsQuery` and pass it any options that fit your needs. + * When your component renders, `useCustomPageSlugsQuery` returns an object from Apollo Client that contains loading, error, and data properties + * you can use to render your UI. + * + * @param baseOptions options that will be passed into the query, supported options are listed on: https://www.apollographql.com/docs/react/api/react-hooks/#options; + * + * @example + * const { data, loading, error } = useCustomPageSlugsQuery({ + * variables: { + * }, + * }); + */ +export function useCustomPageSlugsQuery(baseOptions?: Apollo.QueryHookOptions) { + const options = {...defaultOptions, ...baseOptions} + return Apollo.useQuery(CustomPageSlugsDocument, options); + } +export function useCustomPageSlugsLazyQuery(baseOptions?: Apollo.LazyQueryHookOptions) { + const options = {...defaultOptions, ...baseOptions} + return Apollo.useLazyQuery(CustomPageSlugsDocument, options); + } +export type CustomPageSlugsQueryHookResult = ReturnType; +export type CustomPageSlugsLazyQueryHookResult = ReturnType; +export type CustomPageSlugsQueryResult = Apollo.QueryResult; +export const CustomPageDocument = gql` + query CustomPage($slug: String!) { + custom_pages(filter: {slug: {_eq: $slug}, status: {_eq: "published"}}) { + ...CustomPage + } +} + ${CustomPageFragmentDoc}`; + +/** + * __useCustomPageQuery__ + * + * To run a query within a React component, call `useCustomPageQuery` and pass it any options that fit your needs. + * When your component renders, `useCustomPageQuery` returns an object from Apollo Client that contains loading, error, and data properties + * you can use to render your UI. + * + * @param baseOptions options that will be passed into the query, supported options are listed on: https://www.apollographql.com/docs/react/api/react-hooks/#options; + * + * @example + * const { data, loading, error } = useCustomPageQuery({ + * variables: { + * slug: // value for 'slug' + * }, + * }); + */ +export function useCustomPageQuery(baseOptions: Apollo.QueryHookOptions) { + const options = {...defaultOptions, ...baseOptions} + return Apollo.useQuery(CustomPageDocument, options); + } +export function useCustomPageLazyQuery(baseOptions?: Apollo.LazyQueryHookOptions) { + const options = {...defaultOptions, ...baseOptions} + return Apollo.useLazyQuery(CustomPageDocument, options); + } +export type CustomPageQueryHookResult = ReturnType; +export type CustomPageLazyQueryHookResult = ReturnType; +export type CustomPageQueryResult = Apollo.QueryResult; export const JobListingsDocument = gql` query JobListings { job_listings(filter: {status: {_neq: "archived"}}) { diff --git a/src/graph/directus/customPages.graphql b/src/graph/directus/customPages.graphql new file mode 100644 index 00000000..e0d9b371 --- /dev/null +++ b/src/graph/directus/customPages.graphql @@ -0,0 +1,81 @@ +fragment CustomPage on custom_pages { + id + slug + components { + collection + item { + ...HeroComponent + ...LogoStripComponent + ...SectionHeaderComponent + ...LargeImageComponent + ...CardsComponent + ...BlogCardsComponent + ...RichTextColumnsComponent + ...CustomerQuoteComponent + ...CTAComponent + } + } +} + +fragment CustomPageTiny on custom_pages { + id + slug +} + +query CustomPageSlugs { + custom_pages(filter: { status: { _eq: "published" } }) { + ...CustomPageTiny + } +} + +query CustomPage($slug: String!) { + custom_pages(filter: { slug: { _eq: $slug }, status: { _eq: "published" } }) { + ...CustomPage + } +} + +fragment HeroComponent on hero { + spacing + heading + body_text + media_type + image { + ...ImageFile + } + video_url + form + cta_text + cta_url +} + +fragment LogoStripComponent on logo_strip { + spacing +} + +fragment SectionHeaderComponent on section_header { + spacing +} + +fragment LargeImageComponent on large_image { + spacing +} + +fragment CardsComponent on cards { + spacing +} + +fragment BlogCardsComponent on blog_cards { + spacing +} + +fragment RichTextColumnsComponent on rich_text_columns { + spacing +} + +fragment CustomerQuoteComponent on customer_quote { + spacing +} + +fragment CTAComponent on cta { + spacing +} From 0e7a0cad9709669963d501afd352274e2fe32364 Mon Sep 17 00:00:00 2001 From: Jake Laderman Date: Mon, 21 Oct 2024 16:38:01 -0400 Subject: [PATCH 2/8] implement logo strip --- pages/about/[keyword].tsx | 9 +- src/components/CompanyLogos.tsx | 137 +++++------- src/components/custom-page/Hero.tsx | 5 +- src/components/custom-page/LogoStrip.tsx | 15 +- src/components/custom-page/common.tsx | 5 +- src/generated/graphqlDirectus.ts | 267 ++++++++++++++++++++--- src/graph/directus/cms.graphql | 11 +- src/graph/directus/customPages.graphql | 3 + 8 files changed, 323 insertions(+), 129 deletions(-) diff --git a/pages/about/[keyword].tsx b/pages/about/[keyword].tsx index dac3d086..04753084 100644 --- a/pages/about/[keyword].tsx +++ b/pages/about/[keyword].tsx @@ -22,7 +22,14 @@ export default function CustomPage({ return ( // TODO: make theme adjustable - {components.map((component) => renderComponent(component?.item))} + {components.map((component, index) => ( +
    + {renderComponent(component?.item)} +
    + ))}
    ) } diff --git a/src/components/CompanyLogos.tsx b/src/components/CompanyLogos.tsx index f4e98583..af37bc46 100644 --- a/src/components/CompanyLogos.tsx +++ b/src/components/CompanyLogos.tsx @@ -1,99 +1,76 @@ -import { type ComponentProps, type ReactNode } from 'react' - -import { WrapWithIf } from '@pluralsh/design-system' +import { type ComponentProps } from 'react' import styled, { useTheme } from 'styled-components' import { type Merge } from 'type-fest' -import { TextLabel } from '@src/components/Typography' -import { type PartnerLogos } from '@src/data/getSiteSettings' - -import { StandardPageWidth } from './layout/LayoutHelpers' - -const CompanyLogosSectionSC = styled.div(({ theme: _ }) => ({ - ul: {}, - img: { - width: 100, - }, -})) +import { getImageUrl } from '@src/consts/routes' +import { type LogoListFragment } from '@src/generated/graphqlDirectus' -// Using old inline-block layout technique so we can use 'text-wrap: balance' -// to keep things looking nice when it breaks to multiple lines -const LogosListSC = styled.ul(({ theme }) => ({ - textAlign: 'center', - textWrap: 'balance', - margin: -theme.spacing.xxlarge / 2, +const LogosListSC = styled.div(({ theme }) => ({ + display: 'flex', + justifyContent: 'center', + alignItems: 'center', + gap: theme.spacing.xxlarge, + paddingRight: theme.spacing.xxlarge, + paddingLeft: theme.spacing.xxlarge, })) -const LogoSC = styled.li(({ theme }) => ({ - display: 'inline-block', - padding: 0, - margin: theme.spacing.xxlarge / 2, - verticalAlign: 'middle', +const LogoSC = styled.a(({ theme }) => ({ + display: 'flex', + justifyContent: 'center', + padding: theme.spacing.medium, + width: 175, + height: 80, + borderRadius: theme.borderRadiuses.medium, + transition: 'background 0.2s ease-in-out', + '&:hover': { + background: theme.colors['fill-zero-hover'], + }, })) export function CompanyLogosSection({ logos, - heading, ...props }: Merge< - ComponentProps, - { - logos?: PartnerLogos['items'] - heading?: ReactNode - } + ComponentProps, + { logos?: LogoListFragment['logos'] } >) { const theme = useTheme() return ( - - - - {heading || 'Used by fast-moving teams at'} - - - {logos?.map((logo) => { - if (!logo?.item) { - return null - } - const { - slug, - logo_dark: logoDark, - logo_light: logoLight, - name, - url, - width, - } = logo.item - const imgUrl = theme.mode === 'light' ? logoLight : logoDark + + {logos?.map((logo) => { + if (!logo?.company_logos_id) { + return null + } + const { + slug, + logo_dark: logoDark, + logo_light: logoLight, + name, + url, + } = logo.company_logos_id + const imgUrl = getImageUrl( + theme.mode === 'light' ? logoLight : logoDark + ) - return ( - imgUrl && ( - - - } - > - {name} - - - ) - ) - })} - - - + return ( + imgUrl && ( + + {name} + + ) + ) + })} + ) } diff --git a/src/components/custom-page/Hero.tsx b/src/components/custom-page/Hero.tsx index 8ea80c13..ff64a14b 100644 --- a/src/components/custom-page/Hero.tsx +++ b/src/components/custom-page/Hero.tsx @@ -9,7 +9,7 @@ import { ImageAspectRatio } from '../AspectRatio' import Embed from '../Embed' import { Body1, Hero1 } from '../Typography' -import { spacingToClassName } from './common' +import { getSpacingClassName } from './common' export function Hero({ spacing, @@ -22,11 +22,10 @@ export function Hero({ video_url: videoUrl, form, }: HeroComponentFragment) { - const spacingClassName = spacingToClassName[spacing ?? 'normal'] ?? '' const imageUrl = getImageUrl(image) return ( -
    +
    LogoStrip
    +import { CompanyLogosSection } from '../CompanyLogos' + +import { getSpacingClassName } from './common' + +export function LogoStrip({ + spacing, + logo_list: logoList, +}: LogoStripComponentFragment) { + return ( +
    + +
    + ) } diff --git a/src/components/custom-page/common.tsx b/src/components/custom-page/common.tsx index e3ceadc1..ab393513 100644 --- a/src/components/custom-page/common.tsx +++ b/src/components/custom-page/common.tsx @@ -10,12 +10,15 @@ import { LogoStrip } from './LogoStrip' import { RichTextColumns } from './RichTextColumns' import { SectionHeader } from './SectionHeader' -export const spacingToClassName = { +const spacingToClassName = { relaxed: 'my-[192px]', normal: 'my-[96px]', compact: 'my-[48px]', } +export const getSpacingClassName = (spacing: Nullable) => + spacingToClassName[spacing ?? 'normal'] ?? '' + export function renderComponent( component: NonNullable< NonNullable[number] diff --git a/src/generated/graphqlDirectus.ts b/src/generated/graphqlDirectus.ts index 7043bae0..c1dec457 100644 --- a/src/generated/graphqlDirectus.ts +++ b/src/generated/graphqlDirectus.ts @@ -44,6 +44,8 @@ export type Mutation = { create_collapsible_lists_items_items: Array; create_collapsibles_item?: Maybe; create_collapsibles_items: Array; + create_company_logo_lists_company_logos_item?: Maybe; + create_company_logo_lists_company_logos_items: Array; create_company_logo_lists_item?: Maybe; create_company_logo_lists_items: Array; create_company_logo_lists_items_item?: Maybe; @@ -128,6 +130,8 @@ export type Mutation = { delete_collapsible_lists_items_items?: Maybe; delete_collapsibles_item?: Maybe; delete_collapsibles_items?: Maybe; + delete_company_logo_lists_company_logos_item?: Maybe; + delete_company_logo_lists_company_logos_items?: Maybe; delete_company_logo_lists_item?: Maybe; delete_company_logo_lists_items?: Maybe; delete_company_logo_lists_items_item?: Maybe; @@ -223,6 +227,9 @@ export type Mutation = { update_collapsibles_item?: Maybe; update_collapsibles_items: Array; update_company_logo_lists_batch: Array; + update_company_logo_lists_company_logos_batch: Array; + update_company_logo_lists_company_logos_item?: Maybe; + update_company_logo_lists_company_logos_items: Array; update_company_logo_lists_item?: Maybe; update_company_logo_lists_items: Array; update_company_logo_lists_items_batch: Array; @@ -474,6 +481,22 @@ export type MutationCreate_Collapsibles_ItemsArgs = { }; +export type MutationCreate_Company_Logo_Lists_Company_Logos_ItemArgs = { + data: Create_Company_Logo_Lists_Company_Logos_Input; +}; + + +export type MutationCreate_Company_Logo_Lists_Company_Logos_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationCreate_Company_Logo_Lists_ItemArgs = { data: Create_Company_Logo_Lists_Input; }; @@ -1092,6 +1115,16 @@ export type MutationDelete_Collapsibles_ItemsArgs = { }; +export type MutationDelete_Company_Logo_Lists_Company_Logos_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Company_Logo_Lists_Company_Logos_ItemsArgs = { + ids: Array>; +}; + + export type MutationDelete_Company_Logo_Lists_ItemArgs = { id: Scalars['ID']['input']; }; @@ -1699,6 +1732,35 @@ export type MutationUpdate_Company_Logo_Lists_BatchArgs = { }; +export type MutationUpdate_Company_Logo_Lists_Company_Logos_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Company_Logo_Lists_Company_Logos_ItemArgs = { + data: Update_Company_Logo_Lists_Company_Logos_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Company_Logo_Lists_Company_Logos_ItemsArgs = { + data: Update_Company_Logo_Lists_Company_Logos_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationUpdate_Company_Logo_Lists_ItemArgs = { data: Update_Company_Logo_Lists_Input; id: Scalars['ID']['input']; @@ -2707,6 +2769,9 @@ export type Query = { company_logo_lists: Array; company_logo_lists_aggregated: Array; company_logo_lists_by_id?: Maybe; + company_logo_lists_company_logos: Array; + company_logo_lists_company_logos_aggregated: Array; + company_logo_lists_company_logos_by_id?: Maybe; company_logo_lists_items: Array; company_logo_lists_items_aggregated: Array; company_logo_lists_items_by_id?: Maybe; @@ -3072,6 +3137,32 @@ export type QueryCompany_Logo_Lists_By_IdArgs = { }; +export type QueryCompany_Logo_Lists_Company_LogosArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryCompany_Logo_Lists_Company_Logos_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryCompany_Logo_Lists_Company_Logos_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + export type QueryCompany_Logo_Lists_ItemsArgs = { filter?: InputMaybe; limit?: InputMaybe; @@ -4813,7 +4904,8 @@ export type Company_Logo_Lists = { date_updated?: Maybe; date_updated_func?: Maybe; id: Scalars['ID']['output']; - ignore?: Maybe; + logos?: Maybe>>; + logos_func?: Maybe; partner_logos?: Maybe>>; slug?: Maybe; sort?: Maybe; @@ -4823,6 +4915,16 @@ export type Company_Logo_Lists = { }; +export type Company_Logo_ListsLogosArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type Company_Logo_ListsPartner_LogosArgs = { filter?: InputMaybe; limit?: InputMaybe; @@ -4871,7 +4973,7 @@ export type Company_Logo_Lists_Aggregated_Count = { date_created?: Maybe; date_updated?: Maybe; id?: Maybe; - ignore?: Maybe; + logos?: Maybe; slug?: Maybe; sort?: Maybe; status?: Maybe; @@ -4885,6 +4987,69 @@ export type Company_Logo_Lists_Aggregated_Fields = { sort?: Maybe; }; +export type Company_Logo_Lists_Company_Logos = { + __typename?: 'company_logo_lists_company_logos'; + company_logo_lists_id?: Maybe; + company_logos_id?: Maybe; + id: Scalars['ID']['output']; +}; + + +export type Company_Logo_Lists_Company_LogosCompany_Logo_Lists_IdArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type Company_Logo_Lists_Company_LogosCompany_Logos_IdArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Company_Logo_Lists_Company_Logos_Aggregated = { + __typename?: 'company_logo_lists_company_logos_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Company_Logo_Lists_Company_Logos_Aggregated_Count = { + __typename?: 'company_logo_lists_company_logos_aggregated_count'; + company_logo_lists_id?: Maybe; + company_logos_id?: Maybe; + id?: Maybe; +}; + +export type Company_Logo_Lists_Company_Logos_Aggregated_Fields = { + __typename?: 'company_logo_lists_company_logos_aggregated_fields'; + company_logo_lists_id?: Maybe; + company_logos_id?: Maybe; + id?: Maybe; +}; + +export type Company_Logo_Lists_Company_Logos_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + company_logo_lists_id?: InputMaybe; + company_logos_id?: InputMaybe; + id?: InputMaybe; +}; + export type Company_Logo_Lists_Filter = { _and?: InputMaybe>>; _or?: InputMaybe>>; @@ -4893,7 +5058,8 @@ export type Company_Logo_Lists_Filter = { date_updated?: InputMaybe; date_updated_func?: InputMaybe; id?: InputMaybe; - ignore?: InputMaybe; + logos?: InputMaybe; + logos_func?: InputMaybe; partner_logos?: InputMaybe; slug?: InputMaybe; sort?: InputMaybe; @@ -4973,7 +5139,6 @@ export type Company_Logos = { name: Scalars['String']['output']; slug?: Maybe; url?: Maybe; - width?: Maybe; }; @@ -5019,13 +5184,11 @@ export type Company_Logos_Aggregated_Count = { name?: Maybe; slug?: Maybe; url?: Maybe; - width?: Maybe; }; export type Company_Logos_Aggregated_Fields = { __typename?: 'company_logos_aggregated_fields'; id?: Maybe; - width?: Maybe; }; export type Company_Logos_Filter = { @@ -5039,7 +5202,6 @@ export type Company_Logos_Filter = { name?: InputMaybe; slug?: InputMaybe; url?: InputMaybe; - width?: InputMaybe; }; export type Count_Function_Filter_Operators = { @@ -5169,11 +5331,17 @@ export type Create_Collapsibles_Input = { user_updated?: InputMaybe; }; +export type Create_Company_Logo_Lists_Company_Logos_Input = { + company_logo_lists_id?: InputMaybe; + company_logos_id?: InputMaybe; + id?: InputMaybe; +}; + export type Create_Company_Logo_Lists_Input = { date_created?: InputMaybe; date_updated?: InputMaybe; id?: InputMaybe; - ignore?: InputMaybe; + logos?: InputMaybe>>; partner_logos?: InputMaybe>>; slug?: InputMaybe; sort?: InputMaybe; @@ -5198,7 +5366,6 @@ export type Create_Company_Logos_Input = { name: Scalars['String']['input']; slug?: InputMaybe; url?: InputMaybe; - width?: InputMaybe; }; export type Create_Cta_Input = { @@ -5402,6 +5569,7 @@ export type Create_Logo_Strip_Input = { date_created?: InputMaybe; date_updated?: InputMaybe; id?: InputMaybe; + logo_list?: InputMaybe; spacing?: InputMaybe; user_created?: InputMaybe; }; @@ -6893,11 +7061,22 @@ export type Logo_Strip = { date_updated?: Maybe; date_updated_func?: Maybe; id: Scalars['ID']['output']; + logo_list?: Maybe; spacing?: Maybe; user_created?: Maybe; }; +export type Logo_StripLogo_ListArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type Logo_StripUser_CreatedArgs = { filter?: InputMaybe; limit?: InputMaybe; @@ -6926,6 +7105,7 @@ export type Logo_Strip_Aggregated_Count = { date_created?: Maybe; date_updated?: Maybe; id?: Maybe; + logo_list?: Maybe; spacing?: Maybe; user_created?: Maybe; }; @@ -6933,6 +7113,7 @@ export type Logo_Strip_Aggregated_Count = { export type Logo_Strip_Aggregated_Fields = { __typename?: 'logo_strip_aggregated_fields'; id?: Maybe; + logo_list?: Maybe; }; export type Logo_Strip_Filter = { @@ -6943,6 +7124,7 @@ export type Logo_Strip_Filter = { date_updated?: InputMaybe; date_updated_func?: InputMaybe; id?: InputMaybe; + logo_list?: InputMaybe; spacing?: InputMaybe; user_created?: InputMaybe; }; @@ -9107,11 +9289,17 @@ export type Update_Collapsibles_Input = { user_updated?: InputMaybe; }; +export type Update_Company_Logo_Lists_Company_Logos_Input = { + company_logo_lists_id?: InputMaybe; + company_logos_id?: InputMaybe; + id?: InputMaybe; +}; + export type Update_Company_Logo_Lists_Input = { date_created?: InputMaybe; date_updated?: InputMaybe; id?: InputMaybe; - ignore?: InputMaybe; + logos?: InputMaybe>>; partner_logos?: InputMaybe>>; slug?: InputMaybe; sort?: InputMaybe; @@ -9136,7 +9324,6 @@ export type Update_Company_Logos_Input = { name?: InputMaybe; slug?: InputMaybe; url?: InputMaybe; - width?: InputMaybe; }; export type Update_Cta_Input = { @@ -9340,6 +9527,7 @@ export type Update_Logo_Strip_Input = { date_created?: InputMaybe; date_updated?: InputMaybe; id?: InputMaybe; + logo_list?: InputMaybe; spacing?: InputMaybe; user_created?: InputMaybe; }; @@ -9637,9 +9825,9 @@ export type LinkFragment = { __typename?: 'nav_link', id: string, title?: string export type NavListFragment = { __typename?: 'nav_list', id: string, flatten?: boolean | null, mobile_only?: boolean | null, link?: { __typename?: 'nav_link', id: string, title?: string | null, url?: string | null } | null }; -export type CompanyLogoFragment = { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, width?: number | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null }; +export type CompanyLogoFragment = { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null }; -export type LogoListFragment = { __typename?: 'company_logo_lists', slug?: string | null }; +export type LogoListFragment = { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null }; export type CaseStudyFragment = { __typename?: 'case_studies', id: string, slug?: string | null, label?: string | null, title?: string | null, content?: string | null, ctas?: any | null, stack_label?: string | null, stack_apps?: any | null, hero_image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null }; @@ -9710,7 +9898,7 @@ export type SolutionsQueryVariables = Exact<{ export type SolutionsQuery = { __typename?: 'Query', solutions_pages: Array<{ __typename?: 'solutions_pages', id: string, slug: string, title?: string | null, description?: string | null, upper_features_title?: string | null, lower_features_title?: string | null, download_section_title?: string | null, download_section_description?: string | null, upper_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, lower_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, problems?: Array<{ __typename?: 'solution_problems', id: string, title?: string | null, subtitle?: string | null, problem?: string | null, solution?: string | null } | null> | null, featured_quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null }> }; -export type CustomPageFragment = { __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null } | { __typename?: 'logo_strip', spacing?: string | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null } | null } | null> | null }; +export type CustomPageFragment = { __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null } | null } | null> | null }; export type CustomPageTinyFragment = { __typename?: 'custom_pages', id: string, slug: string }; @@ -9724,11 +9912,11 @@ export type CustomPageQueryVariables = Exact<{ }>; -export type CustomPageQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null } | { __typename?: 'logo_strip', spacing?: string | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null } | null } | null> | null }> }; +export type CustomPageQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null } | null } | null> | null }> }; export type HeroComponentFragment = { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null }; -export type LogoStripComponentFragment = { __typename?: 'logo_strip', spacing?: string | null }; +export type LogoStripComponentFragment = { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null }; export type SectionHeaderComponentFragment = { __typename?: 'section_header', spacing?: string | null }; @@ -9874,25 +10062,6 @@ export const ImageFileFragmentDoc = gql` filesize } `; -export const CompanyLogoFragmentDoc = gql` - fragment CompanyLogo on company_logos { - slug - name - logo_light { - ...ImageFile - } - logo_dark { - ...ImageFile - } - url - width -} - ${ImageFileFragmentDoc}`; -export const LogoListFragmentDoc = gql` - fragment LogoList on company_logo_lists { - slug -} - `; export const CaseStudyFragmentDoc = gql` fragment CaseStudy on case_studies { id @@ -10073,11 +10242,37 @@ export const HeroComponentFragmentDoc = gql` cta_url } ${ImageFileFragmentDoc}`; +export const CompanyLogoFragmentDoc = gql` + fragment CompanyLogo on company_logos { + slug + name + logo_light { + ...ImageFile + } + logo_dark { + ...ImageFile + } + url +} + ${ImageFileFragmentDoc}`; +export const LogoListFragmentDoc = gql` + fragment LogoList on company_logo_lists { + slug + logos { + company_logos_id { + ...CompanyLogo + } + } +} + ${CompanyLogoFragmentDoc}`; export const LogoStripComponentFragmentDoc = gql` fragment LogoStripComponent on logo_strip { spacing + logo_list { + ...LogoList + } } - `; + ${LogoListFragmentDoc}`; export const SectionHeaderComponentFragmentDoc = gql` fragment SectionHeaderComponent on section_header { spacing diff --git a/src/graph/directus/cms.graphql b/src/graph/directus/cms.graphql index faba6f7f..00da39d0 100644 --- a/src/graph/directus/cms.graphql +++ b/src/graph/directus/cms.graphql @@ -53,16 +53,15 @@ fragment CompanyLogo on company_logos { ...ImageFile } url - width } fragment LogoList on company_logo_lists { slug - # items { - # item { - # ...CompanyLogo - # } - # } + logos { + company_logos_id { + ...CompanyLogo + } + } } # fragment SiteSettings on site_settings { diff --git a/src/graph/directus/customPages.graphql b/src/graph/directus/customPages.graphql index e0d9b371..bc390b0f 100644 --- a/src/graph/directus/customPages.graphql +++ b/src/graph/directus/customPages.graphql @@ -50,6 +50,9 @@ fragment HeroComponent on hero { fragment LogoStripComponent on logo_strip { spacing + logo_list { + ...LogoList + } } fragment SectionHeaderComponent on section_header { From b42425242379791045601d9827ce600f220e62d1 Mon Sep 17 00:00:00 2001 From: Jake Laderman Date: Mon, 21 Oct 2024 16:58:36 -0400 Subject: [PATCH 3/8] add section header component --- src/components/Typography.tsx | 7 ++++++ src/components/custom-page/SectionHeader.tsx | 25 ++++++++++++++++++-- src/generated/graphqlDirectus.ts | 24 ++++++++++++++++--- src/graph/directus/customPages.graphql | 3 +++ 4 files changed, 54 insertions(+), 5 deletions(-) diff --git a/src/components/Typography.tsx b/src/components/Typography.tsx index 5e399c97..0bd4d9a7 100644 --- a/src/components/Typography.tsx +++ b/src/components/Typography.tsx @@ -130,6 +130,13 @@ export const Body2 = styled.p<{ $color?: ColorKey }>( }) ) +export const OverlineLabel = styled.span<{ $color?: ColorKey }>( + ({ theme, $color = 'text-light' }) => ({ + ...theme.partials.marketingText.label, + color: theme.colors[$color] as string, + }) +) + export const AppBody1 = styled.p<{ $color?: ColorKey }>( ({ theme, $color = 'text-light' }) => ({ ...theme.partials.text.body1, diff --git a/src/components/custom-page/SectionHeader.tsx b/src/components/custom-page/SectionHeader.tsx index 2e7239a3..b26f32d5 100644 --- a/src/components/custom-page/SectionHeader.tsx +++ b/src/components/custom-page/SectionHeader.tsx @@ -1,5 +1,26 @@ import { type SectionHeaderComponentFragment } from '@src/generated/graphqlDirectus' -export function SectionHeader({ spacing }: SectionHeaderComponentFragment) { - return
    SectionHeader
    +import { cn } from '../cn' +import { Body1, Hero2, OverlineLabel } from '../Typography' + +import { getSpacingClassName } from './common' + +export function SectionHeader({ + spacing, + overline, + title, + description, +}: SectionHeaderComponentFragment) { + return ( +
    + {overline && {overline}} + {title} + {description} +
    + ) } diff --git a/src/generated/graphqlDirectus.ts b/src/generated/graphqlDirectus.ts index c1dec457..029023f8 100644 --- a/src/generated/graphqlDirectus.ts +++ b/src/generated/graphqlDirectus.ts @@ -5724,8 +5724,11 @@ export type Create_Rich_Text_Columns_Input = { export type Create_Section_Header_Input = { date_created?: InputMaybe; date_updated?: InputMaybe; + description?: InputMaybe; id?: InputMaybe; + overline?: InputMaybe; spacing?: InputMaybe; + title?: InputMaybe; user_created?: InputMaybe; user_updated?: InputMaybe; }; @@ -8266,8 +8269,11 @@ export type Section_Header = { date_created_func?: Maybe; date_updated?: Maybe; date_updated_func?: Maybe; + description?: Maybe; id: Scalars['ID']['output']; + overline?: Maybe; spacing?: Maybe; + title?: Maybe; user_created?: Maybe; user_updated?: Maybe; }; @@ -8310,8 +8316,11 @@ export type Section_Header_Aggregated_Count = { __typename?: 'section_header_aggregated_count'; date_created?: Maybe; date_updated?: Maybe; + description?: Maybe; id?: Maybe; + overline?: Maybe; spacing?: Maybe; + title?: Maybe; user_created?: Maybe; user_updated?: Maybe; }; @@ -8328,8 +8337,11 @@ export type Section_Header_Filter = { date_created_func?: InputMaybe; date_updated?: InputMaybe; date_updated_func?: InputMaybe; + description?: InputMaybe; id?: InputMaybe; + overline?: InputMaybe; spacing?: InputMaybe; + title?: InputMaybe; user_created?: InputMaybe; user_updated?: InputMaybe; }; @@ -9692,8 +9704,11 @@ export type Update_Rich_Text_Columns_Input = { export type Update_Section_Header_Input = { date_created?: InputMaybe; date_updated?: InputMaybe; + description?: InputMaybe; id?: InputMaybe; + overline?: InputMaybe; spacing?: InputMaybe; + title?: InputMaybe; user_created?: InputMaybe; user_updated?: InputMaybe; }; @@ -9898,7 +9913,7 @@ export type SolutionsQueryVariables = Exact<{ export type SolutionsQuery = { __typename?: 'Query', solutions_pages: Array<{ __typename?: 'solutions_pages', id: string, slug: string, title?: string | null, description?: string | null, upper_features_title?: string | null, lower_features_title?: string | null, download_section_title?: string | null, download_section_description?: string | null, upper_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, lower_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, problems?: Array<{ __typename?: 'solution_problems', id: string, title?: string | null, subtitle?: string | null, problem?: string | null, solution?: string | null } | null> | null, featured_quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null }> }; -export type CustomPageFragment = { __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null } | null } | null> | null }; +export type CustomPageFragment = { __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }; export type CustomPageTinyFragment = { __typename?: 'custom_pages', id: string, slug: string }; @@ -9912,13 +9927,13 @@ export type CustomPageQueryVariables = Exact<{ }>; -export type CustomPageQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null } | null } | null> | null }> }; +export type CustomPageQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }> }; export type HeroComponentFragment = { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null }; export type LogoStripComponentFragment = { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null }; -export type SectionHeaderComponentFragment = { __typename?: 'section_header', spacing?: string | null }; +export type SectionHeaderComponentFragment = { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null }; export type LargeImageComponentFragment = { __typename?: 'large_image', spacing?: string | null }; @@ -10276,6 +10291,9 @@ export const LogoStripComponentFragmentDoc = gql` export const SectionHeaderComponentFragmentDoc = gql` fragment SectionHeaderComponent on section_header { spacing + overline + title + description } `; export const LargeImageComponentFragmentDoc = gql` diff --git a/src/graph/directus/customPages.graphql b/src/graph/directus/customPages.graphql index bc390b0f..a8321921 100644 --- a/src/graph/directus/customPages.graphql +++ b/src/graph/directus/customPages.graphql @@ -57,6 +57,9 @@ fragment LogoStripComponent on logo_strip { fragment SectionHeaderComponent on section_header { spacing + overline + title + description } fragment LargeImageComponent on large_image { From 9ad55e57d56574086b16031c08fed97803b590dc Mon Sep 17 00:00:00 2001 From: Jake Laderman Date: Mon, 21 Oct 2024 17:25:36 -0400 Subject: [PATCH 4/8] add large image component --- src/components/Typography.tsx | 7 ++- src/components/custom-page/Hero.tsx | 33 +++------- src/components/custom-page/LargeImage.tsx | 56 ++++++++++++++++- src/components/custom-page/Multimedia.tsx | 49 +++++++++++++++ src/generated/graphqlDirectus.ts | 74 +++++++++++++++++++++-- src/graph/directus/customPages.graphql | 11 ++++ 6 files changed, 198 insertions(+), 32 deletions(-) create mode 100644 src/components/custom-page/Multimedia.tsx diff --git a/src/components/Typography.tsx b/src/components/Typography.tsx index 0bd4d9a7..af25189b 100644 --- a/src/components/Typography.tsx +++ b/src/components/Typography.tsx @@ -113,7 +113,12 @@ export const Hero2 = styled.h2<{ $color?: ColorKey }>(({ theme, $color }) => ({ color: $color && (theme.colors[$color] as string), })) -export const Title2 = styled.h3<{ $color?: ColorKey }>(({ theme, $color }) => ({ +export const Title1 = styled.h3<{ $color?: ColorKey }>(({ theme, $color }) => ({ + ...theme.partials.marketingText.title1, + color: $color && (theme.colors[$color] as string), +})) + +export const Title2 = styled.h4<{ $color?: ColorKey }>(({ theme, $color }) => ({ ...theme.partials.marketingText.title2, color: $color && (theme.colors[$color] as string), })) diff --git a/src/components/custom-page/Hero.tsx b/src/components/custom-page/Hero.tsx index ff64a14b..4076e97e 100644 --- a/src/components/custom-page/Hero.tsx +++ b/src/components/custom-page/Hero.tsx @@ -1,15 +1,13 @@ -import { Button, Code, Flex } from '@pluralsh/design-system' +import { Button, Flex } from '@pluralsh/design-system' import Link from 'next/link' -import { getImageUrl } from '@src/consts/routes' import { type HeroComponentFragment } from '@src/generated/graphqlDirectus' import { cn } from '@src/utils/cn' -import { ImageAspectRatio } from '../AspectRatio' -import Embed from '../Embed' import { Body1, Hero1 } from '../Typography' import { getSpacingClassName } from './common' +import { Multimedia } from './Multimedia' export function Hero({ spacing, @@ -22,8 +20,6 @@ export function Hero({ video_url: videoUrl, form, }: HeroComponentFragment) { - const imageUrl = getImageUrl(image) - return (
    @@ -47,25 +43,12 @@ export function Hero({ )} -
    - {mediaType === 'image' ? ( - imageUrl && ( - - ) - ) : mediaType === 'video' ? ( - - ) : mediaType === 'form' ? ( - - {form ?? ''} - - ) : null} -
    +
    ) diff --git a/src/components/custom-page/LargeImage.tsx b/src/components/custom-page/LargeImage.tsx index 56956c7d..ceb0f5d6 100644 --- a/src/components/custom-page/LargeImage.tsx +++ b/src/components/custom-page/LargeImage.tsx @@ -1,5 +1,57 @@ +import { Button, Flex } from '@pluralsh/design-system' +import Link from 'next/link' + import { type LargeImageComponentFragment } from '@src/generated/graphqlDirectus' -export function LargeImage({ spacing }: LargeImageComponentFragment) { - return
    LargeImage
    +import { cn } from '../cn' +import { Body2, OverlineLabel, Title1 } from '../Typography' + +import { getSpacingClassName } from './common' +import { Multimedia } from './Multimedia' + +export function LargeImage({ + spacing, + overline, + heading, + body_text: bodyText, + cta_text: ctaText, + cta_url: ctaUrl, + media_type: mediaType, + image, + video_url: videoUrl, + form, +}: LargeImageComponentFragment) { + return ( +
    + + + + {overline && {overline}} + {heading} + {bodyText} + {ctaText && ( + + )} + + +
    + ) } diff --git a/src/components/custom-page/Multimedia.tsx b/src/components/custom-page/Multimedia.tsx new file mode 100644 index 00000000..ab69eedc --- /dev/null +++ b/src/components/custom-page/Multimedia.tsx @@ -0,0 +1,49 @@ +import { type ComponentProps } from 'react' + +import { Code } from '@pluralsh/design-system' + +import { getImageUrl } from '@src/consts/routes' +import { type ImageFileFragment } from '@src/generated/graphqlDirectus' + +import { ImageAspectRatio } from '../AspectRatio' +import Embed from '../Embed' + +export function Multimedia({ + mediaType, + image, + videoUrl, + form, + aspectRatio = '16 / 10', + ...props +}: { + mediaType: Nullable + image: Nullable + videoUrl: Nullable + form: Nullable + aspectRatio?: string +} & ComponentProps<'div'>) { + const imageUrl = getImageUrl(image) + + return ( +
    + {mediaType === 'image' ? ( + imageUrl && ( + + ) + ) : mediaType === 'video' ? ( + + ) : mediaType === 'form' ? ( + {form ?? ''} + ) : null} +
    + ) +} diff --git a/src/generated/graphqlDirectus.ts b/src/generated/graphqlDirectus.ts index 029023f8..db658c9e 100644 --- a/src/generated/graphqlDirectus.ts +++ b/src/generated/graphqlDirectus.ts @@ -5557,12 +5557,21 @@ export type Create_Job_Listings_Input = { }; export type Create_Large_Image_Input = { + body_text?: InputMaybe; + cta_text?: InputMaybe; + cta_url?: InputMaybe; date_created?: InputMaybe; date_updated?: InputMaybe; + form?: InputMaybe; + heading?: InputMaybe; id?: InputMaybe; + image?: InputMaybe; + media_type?: InputMaybe; + overline?: InputMaybe; spacing?: InputMaybe; user_created?: InputMaybe; user_updated?: InputMaybe; + video_url?: InputMaybe; }; export type Create_Logo_Strip_Input = { @@ -6985,14 +6994,33 @@ export type Job_Listings_Filter = { export type Large_Image = { __typename?: 'large_image'; + body_text?: Maybe; + cta_text?: Maybe; + cta_url?: Maybe; date_created?: Maybe; date_created_func?: Maybe; date_updated?: Maybe; date_updated_func?: Maybe; + form?: Maybe; + heading?: Maybe; id: Scalars['ID']['output']; + image?: Maybe; + media_type?: Maybe; + overline?: Maybe; spacing?: Maybe; user_created?: Maybe; user_updated?: Maybe; + video_url?: Maybe; +}; + + +export type Large_ImageImageArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; }; @@ -7031,12 +7059,21 @@ export type Large_Image_Aggregated = { export type Large_Image_Aggregated_Count = { __typename?: 'large_image_aggregated_count'; + body_text?: Maybe; + cta_text?: Maybe; + cta_url?: Maybe; date_created?: Maybe; date_updated?: Maybe; + form?: Maybe; + heading?: Maybe; id?: Maybe; + image?: Maybe; + media_type?: Maybe; + overline?: Maybe; spacing?: Maybe; user_created?: Maybe; user_updated?: Maybe; + video_url?: Maybe; }; export type Large_Image_Aggregated_Fields = { @@ -7047,14 +7084,23 @@ export type Large_Image_Aggregated_Fields = { export type Large_Image_Filter = { _and?: InputMaybe>>; _or?: InputMaybe>>; + body_text?: InputMaybe; + cta_text?: InputMaybe; + cta_url?: InputMaybe; date_created?: InputMaybe; date_created_func?: InputMaybe; date_updated?: InputMaybe; date_updated_func?: InputMaybe; + form?: InputMaybe; + heading?: InputMaybe; id?: InputMaybe; + image?: InputMaybe; + media_type?: InputMaybe; + overline?: InputMaybe; spacing?: InputMaybe; user_created?: InputMaybe; user_updated?: InputMaybe; + video_url?: InputMaybe; }; export type Logo_Strip = { @@ -9527,12 +9573,21 @@ export type Update_Job_Listings_Input = { }; export type Update_Large_Image_Input = { + body_text?: InputMaybe; + cta_text?: InputMaybe; + cta_url?: InputMaybe; date_created?: InputMaybe; date_updated?: InputMaybe; + form?: InputMaybe; + heading?: InputMaybe; id?: InputMaybe; + image?: InputMaybe; + media_type?: InputMaybe; + overline?: InputMaybe; spacing?: InputMaybe; user_created?: InputMaybe; user_updated?: InputMaybe; + video_url?: InputMaybe; }; export type Update_Logo_Strip_Input = { @@ -9913,7 +9968,7 @@ export type SolutionsQueryVariables = Exact<{ export type SolutionsQuery = { __typename?: 'Query', solutions_pages: Array<{ __typename?: 'solutions_pages', id: string, slug: string, title?: string | null, description?: string | null, upper_features_title?: string | null, lower_features_title?: string | null, download_section_title?: string | null, download_section_description?: string | null, upper_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, lower_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, problems?: Array<{ __typename?: 'solution_problems', id: string, title?: string | null, subtitle?: string | null, problem?: string | null, solution?: string | null } | null> | null, featured_quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null }> }; -export type CustomPageFragment = { __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }; +export type CustomPageFragment = { __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }; export type CustomPageTinyFragment = { __typename?: 'custom_pages', id: string, slug: string }; @@ -9927,7 +9982,7 @@ export type CustomPageQueryVariables = Exact<{ }>; -export type CustomPageQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }> }; +export type CustomPageQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }> }; export type HeroComponentFragment = { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null }; @@ -9935,7 +9990,7 @@ export type LogoStripComponentFragment = { __typename?: 'logo_strip', spacing?: export type SectionHeaderComponentFragment = { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null }; -export type LargeImageComponentFragment = { __typename?: 'large_image', spacing?: string | null }; +export type LargeImageComponentFragment = { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null }; export type CardsComponentFragment = { __typename?: 'cards', spacing?: string | null }; @@ -10299,8 +10354,19 @@ export const SectionHeaderComponentFragmentDoc = gql` export const LargeImageComponentFragmentDoc = gql` fragment LargeImageComponent on large_image { spacing + overline + heading + body_text + media_type + image { + ...ImageFile + } + video_url + form + cta_text + cta_url } - `; + ${ImageFileFragmentDoc}`; export const CardsComponentFragmentDoc = gql` fragment CardsComponent on cards { spacing diff --git a/src/graph/directus/customPages.graphql b/src/graph/directus/customPages.graphql index a8321921..dfa69a74 100644 --- a/src/graph/directus/customPages.graphql +++ b/src/graph/directus/customPages.graphql @@ -64,6 +64,17 @@ fragment SectionHeaderComponent on section_header { fragment LargeImageComponent on large_image { spacing + overline + heading + body_text + media_type + image { + ...ImageFile + } + video_url + form + cta_text + cta_url } fragment CardsComponent on cards { From 218554ffc887eb882eff358df2cf2378a5049f45 Mon Sep 17 00:00:00 2001 From: Jake Laderman Date: Mon, 21 Oct 2024 17:49:05 -0400 Subject: [PATCH 5/8] add cta --- src/components/custom-page/CTA.tsx | 5 --- src/components/custom-page/CallToAction.tsx | 38 ++++++++++++++++++++ src/components/custom-page/SectionHeader.tsx | 2 +- src/components/custom-page/common.tsx | 4 +-- src/generated/graphqlDirectus.ts | 30 ++++++++++++++-- src/graph/directus/customPages.graphql | 4 +++ 6 files changed, 72 insertions(+), 11 deletions(-) delete mode 100644 src/components/custom-page/CTA.tsx create mode 100644 src/components/custom-page/CallToAction.tsx diff --git a/src/components/custom-page/CTA.tsx b/src/components/custom-page/CTA.tsx deleted file mode 100644 index 2b5d45fb..00000000 --- a/src/components/custom-page/CTA.tsx +++ /dev/null @@ -1,5 +0,0 @@ -import { type CtaComponentFragment } from '@src/generated/graphqlDirectus' - -export function CTA({ spacing }: CtaComponentFragment) { - return
    CTA
    -} diff --git a/src/components/custom-page/CallToAction.tsx b/src/components/custom-page/CallToAction.tsx new file mode 100644 index 00000000..a3f64c8f --- /dev/null +++ b/src/components/custom-page/CallToAction.tsx @@ -0,0 +1,38 @@ +import { Button } from '@pluralsh/design-system' +import Link from 'next/link' + +import { type CtaComponentFragment } from '@src/generated/graphqlDirectus' + +import { cn } from '../cn' +import { Body1, Hero2 } from '../Typography' + +import { getSpacingClassName } from './common' + +export function CallToAction({ + spacing, + heading, + body_text: bodyText, + cta_text: ctaText, + cta_url: ctaUrl, +}: CtaComponentFragment) { + return ( +
    + {heading} + {bodyText} + +
    + ) +} diff --git a/src/components/custom-page/SectionHeader.tsx b/src/components/custom-page/SectionHeader.tsx index b26f32d5..0f0ace2b 100644 --- a/src/components/custom-page/SectionHeader.tsx +++ b/src/components/custom-page/SectionHeader.tsx @@ -15,7 +15,7 @@ export function SectionHeader({
    {overline && {overline}} diff --git a/src/components/custom-page/common.tsx b/src/components/custom-page/common.tsx index ab393513..8085ef81 100644 --- a/src/components/custom-page/common.tsx +++ b/src/components/custom-page/common.tsx @@ -1,8 +1,8 @@ import { type CustomPageFragment } from '@src/generated/graphqlDirectus' import { BlogCards } from './BlogCards' +import { CallToAction } from './CallToAction' import { Cards } from './Cards' -import { CTA } from './CTA' import { CustomerQuote } from './CustomerQuote' import { Hero } from './Hero' import { LargeImage } from './LargeImage' @@ -42,7 +42,7 @@ export function renderComponent( case 'customer_quote': return case 'cta': - return + return default: return null } diff --git a/src/generated/graphqlDirectus.ts b/src/generated/graphqlDirectus.ts index db658c9e..e28e1a6f 100644 --- a/src/generated/graphqlDirectus.ts +++ b/src/generated/graphqlDirectus.ts @@ -5369,8 +5369,12 @@ export type Create_Company_Logos_Input = { }; export type Create_Cta_Input = { + body_text?: InputMaybe; + cta_text?: InputMaybe; + cta_url?: InputMaybe; date_created?: InputMaybe; date_updated?: InputMaybe; + heading?: InputMaybe; id?: InputMaybe; spacing?: InputMaybe; user_created?: InputMaybe; @@ -5852,10 +5856,14 @@ export type Create_Team_Members_Input = { export type Cta = { __typename?: 'cta'; + body_text?: Maybe; + cta_text?: Maybe; + cta_url?: Maybe; date_created?: Maybe; date_created_func?: Maybe; date_updated?: Maybe; date_updated_func?: Maybe; + heading?: Maybe; id: Scalars['ID']['output']; spacing?: Maybe; user_created?: Maybe; @@ -5898,8 +5906,12 @@ export type Cta_Aggregated = { export type Cta_Aggregated_Count = { __typename?: 'cta_aggregated_count'; + body_text?: Maybe; + cta_text?: Maybe; + cta_url?: Maybe; date_created?: Maybe; date_updated?: Maybe; + heading?: Maybe; id?: Maybe; spacing?: Maybe; user_created?: Maybe; @@ -5914,10 +5926,14 @@ export type Cta_Aggregated_Fields = { export type Cta_Filter = { _and?: InputMaybe>>; _or?: InputMaybe>>; + body_text?: InputMaybe; + cta_text?: InputMaybe; + cta_url?: InputMaybe; date_created?: InputMaybe; date_created_func?: InputMaybe; date_updated?: InputMaybe; date_updated_func?: InputMaybe; + heading?: InputMaybe; id?: InputMaybe; spacing?: InputMaybe; user_created?: InputMaybe; @@ -9385,8 +9401,12 @@ export type Update_Company_Logos_Input = { }; export type Update_Cta_Input = { + body_text?: InputMaybe; + cta_text?: InputMaybe; + cta_url?: InputMaybe; date_created?: InputMaybe; date_updated?: InputMaybe; + heading?: InputMaybe; id?: InputMaybe; spacing?: InputMaybe; user_created?: InputMaybe; @@ -9968,7 +9988,7 @@ export type SolutionsQueryVariables = Exact<{ export type SolutionsQuery = { __typename?: 'Query', solutions_pages: Array<{ __typename?: 'solutions_pages', id: string, slug: string, title?: string | null, description?: string | null, upper_features_title?: string | null, lower_features_title?: string | null, download_section_title?: string | null, download_section_description?: string | null, upper_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, lower_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, problems?: Array<{ __typename?: 'solution_problems', id: string, title?: string | null, subtitle?: string | null, problem?: string | null, solution?: string | null } | null> | null, featured_quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null }> }; -export type CustomPageFragment = { __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }; +export type CustomPageFragment = { __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }; export type CustomPageTinyFragment = { __typename?: 'custom_pages', id: string, slug: string }; @@ -9982,7 +10002,7 @@ export type CustomPageQueryVariables = Exact<{ }>; -export type CustomPageQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }> }; +export type CustomPageQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }> }; export type HeroComponentFragment = { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null }; @@ -10000,7 +10020,7 @@ export type RichTextColumnsComponentFragment = { __typename?: 'rich_text_columns export type CustomerQuoteComponentFragment = { __typename?: 'customer_quote', spacing?: string | null }; -export type CtaComponentFragment = { __typename?: 'cta', spacing?: string | null }; +export type CtaComponentFragment = { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null }; export type MinJobListingFragment = { __typename?: 'job_listings', id: string, slug: string, job_title?: string | null, department?: string | null, tags?: any | null, location?: string | null, status?: string | null }; @@ -10390,6 +10410,10 @@ export const CustomerQuoteComponentFragmentDoc = gql` export const CtaComponentFragmentDoc = gql` fragment CTAComponent on cta { spacing + heading + body_text + cta_text + cta_url } `; export const CustomPageFragmentDoc = gql` diff --git a/src/graph/directus/customPages.graphql b/src/graph/directus/customPages.graphql index dfa69a74..7b019cde 100644 --- a/src/graph/directus/customPages.graphql +++ b/src/graph/directus/customPages.graphql @@ -95,4 +95,8 @@ fragment CustomerQuoteComponent on customer_quote { fragment CTAComponent on cta { spacing + heading + body_text + cta_text + cta_url } From 9934c2519a63aa80495b62831bcd9827f3091a73 Mon Sep 17 00:00:00 2001 From: Jake Laderman Date: Mon, 21 Oct 2024 21:56:18 -0400 Subject: [PATCH 6/8] add customer quote and rich text columns components --- src/components/Typography.tsx | 14 + src/components/custom-page/CustomerQuote.tsx | 26 +- .../custom-page/MultiColumnText.tsx | 50 ++ .../custom-page/RichTextColumns.tsx | 5 - src/components/custom-page/common.tsx | 6 +- src/generated/graphqlDirectus.ts | 447 +++++++++++++++++- src/graph/directus/customPages.graphql | 18 +- 7 files changed, 535 insertions(+), 31 deletions(-) create mode 100644 src/components/custom-page/MultiColumnText.tsx delete mode 100644 src/components/custom-page/RichTextColumns.tsx diff --git a/src/components/Typography.tsx b/src/components/Typography.tsx index af25189b..16dfab60 100644 --- a/src/components/Typography.tsx +++ b/src/components/Typography.tsx @@ -135,6 +135,20 @@ export const Body2 = styled.p<{ $color?: ColorKey }>( }) ) +export const Subtitle1 = styled.p<{ $color?: ColorKey }>( + ({ theme, $color }) => ({ + ...theme.partials.marketingText.subtitle1, + color: $color && (theme.colors[$color] as string), + }) +) + +export const Subtitle2 = styled.p<{ $color?: ColorKey }>( + ({ theme, $color }) => ({ + ...theme.partials.marketingText.subtitle2, + color: $color && (theme.colors[$color] as string), + }) +) + export const OverlineLabel = styled.span<{ $color?: ColorKey }>( ({ theme, $color = 'text-light' }) => ({ ...theme.partials.marketingText.label, diff --git a/src/components/custom-page/CustomerQuote.tsx b/src/components/custom-page/CustomerQuote.tsx index fdf08b3c..643fdf4b 100644 --- a/src/components/custom-page/CustomerQuote.tsx +++ b/src/components/custom-page/CustomerQuote.tsx @@ -1,5 +1,27 @@ +import { Flex } from '@pluralsh/design-system' + import { type CustomerQuoteComponentFragment } from '@src/generated/graphqlDirectus' -export function CustomerQuote({ spacing }: CustomerQuoteComponentFragment) { - return
    CustomerQuote
    +import { Body1, Subtitle2 } from '../Typography' + +import { getSpacingClassName } from './common' + +export function CustomerQuote({ + spacing, + quote, +}: CustomerQuoteComponentFragment) { + return ( +
    + + "{quote?.quote}" + - {quote?.author_text} + +
    + ) } diff --git a/src/components/custom-page/MultiColumnText.tsx b/src/components/custom-page/MultiColumnText.tsx new file mode 100644 index 00000000..c2a6239f --- /dev/null +++ b/src/components/custom-page/MultiColumnText.tsx @@ -0,0 +1,50 @@ +import { IconFrame } from '@pluralsh/design-system' + +import * as designSystemIcons from '@pluralsh/design-system/dist/icons' + +import * as productNavIcons from '@src/components/menu/ProductNavIcons' +import { type MultiColumnTextComponentFragment } from '@src/generated/graphqlDirectus' +import { cn } from '@src/utils/cn' + +import { Body1, Subtitle1 } from '../Typography' + +import { getSpacingClassName } from './common' + +const icons = { ...productNavIcons, ...designSystemIcons } + +export function MultiColumnText({ + spacing, + columns, +}: MultiColumnTextComponentFragment) { + return ( +
    + {columns?.map((c, index) => { + const Icon = + icons[`${c?.rich_text_columns_id?.icon ?? 'Kubernetes'}Icon`] ?? + icons.KubernetesIcon + const heading = c?.rich_text_columns_id?.heading + const bodyText = c?.rich_text_columns_id?.body_text + + return ( +
    + } + /> + {heading} + {bodyText} +
    + ) + })} +
    + ) +} diff --git a/src/components/custom-page/RichTextColumns.tsx b/src/components/custom-page/RichTextColumns.tsx deleted file mode 100644 index 59fe747d..00000000 --- a/src/components/custom-page/RichTextColumns.tsx +++ /dev/null @@ -1,5 +0,0 @@ -import { type RichTextColumnsComponentFragment } from '@src/generated/graphqlDirectus' - -export function RichTextColumns({ spacing }: RichTextColumnsComponentFragment) { - return
    RichTextColumns
    -} diff --git a/src/components/custom-page/common.tsx b/src/components/custom-page/common.tsx index 8085ef81..367fa851 100644 --- a/src/components/custom-page/common.tsx +++ b/src/components/custom-page/common.tsx @@ -7,7 +7,7 @@ import { CustomerQuote } from './CustomerQuote' import { Hero } from './Hero' import { LargeImage } from './LargeImage' import { LogoStrip } from './LogoStrip' -import { RichTextColumns } from './RichTextColumns' +import { MultiColumnText } from './MultiColumnText' import { SectionHeader } from './SectionHeader' const spacingToClassName = { @@ -37,8 +37,8 @@ export function renderComponent( return case 'blog_cards': return - case 'rich_text_columns': - return + case 'multi_column_text': + return case 'customer_quote': return case 'cta': diff --git a/src/generated/graphqlDirectus.ts b/src/generated/graphqlDirectus.ts index e28e1a6f..b81559c5 100644 --- a/src/generated/graphqlDirectus.ts +++ b/src/generated/graphqlDirectus.ts @@ -76,6 +76,10 @@ export type Mutation = { create_logo_strip_items: Array; create_markdown_pages_item?: Maybe; create_markdown_pages_items: Array; + create_multi_column_text_item?: Maybe; + create_multi_column_text_items: Array; + create_multi_column_text_rich_text_columns_item?: Maybe; + create_multi_column_text_rich_text_columns_items: Array; create_nav_link_item?: Maybe; create_nav_link_items: Array; create_nav_list_item?: Maybe; @@ -162,6 +166,10 @@ export type Mutation = { delete_logo_strip_items?: Maybe; delete_markdown_pages_item?: Maybe; delete_markdown_pages_items?: Maybe; + delete_multi_column_text_item?: Maybe; + delete_multi_column_text_items?: Maybe; + delete_multi_column_text_rich_text_columns_item?: Maybe; + delete_multi_column_text_rich_text_columns_items?: Maybe; delete_nav_link_item?: Maybe; delete_nav_link_items?: Maybe; delete_nav_list_item?: Maybe; @@ -274,6 +282,12 @@ export type Mutation = { update_markdown_pages_batch: Array; update_markdown_pages_item?: Maybe; update_markdown_pages_items: Array; + update_multi_column_text_batch: Array; + update_multi_column_text_item?: Maybe; + update_multi_column_text_items: Array; + update_multi_column_text_rich_text_columns_batch: Array; + update_multi_column_text_rich_text_columns_item?: Maybe; + update_multi_column_text_rich_text_columns_items: Array; update_nav_link_batch: Array; update_nav_link_item?: Maybe; update_nav_link_items: Array; @@ -737,6 +751,38 @@ export type MutationCreate_Markdown_Pages_ItemsArgs = { }; +export type MutationCreate_Multi_Column_Text_ItemArgs = { + data: Create_Multi_Column_Text_Input; +}; + + +export type MutationCreate_Multi_Column_Text_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationCreate_Multi_Column_Text_Rich_Text_Columns_ItemArgs = { + data: Create_Multi_Column_Text_Rich_Text_Columns_Input; +}; + + +export type MutationCreate_Multi_Column_Text_Rich_Text_Columns_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationCreate_Nav_Link_ItemArgs = { data: Create_Nav_Link_Input; }; @@ -1275,6 +1321,26 @@ export type MutationDelete_Markdown_Pages_ItemsArgs = { }; +export type MutationDelete_Multi_Column_Text_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Multi_Column_Text_ItemsArgs = { + ids: Array>; +}; + + +export type MutationDelete_Multi_Column_Text_Rich_Text_Columns_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Multi_Column_Text_Rich_Text_Columns_ItemsArgs = { + ids: Array>; +}; + + export type MutationDelete_Nav_Link_ItemArgs = { id: Scalars['ID']['input']; }; @@ -2185,6 +2251,64 @@ export type MutationUpdate_Markdown_Pages_ItemsArgs = { }; +export type MutationUpdate_Multi_Column_Text_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Multi_Column_Text_ItemArgs = { + data: Update_Multi_Column_Text_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Multi_Column_Text_ItemsArgs = { + data: Update_Multi_Column_Text_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Multi_Column_Text_Rich_Text_Columns_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Multi_Column_Text_Rich_Text_Columns_ItemArgs = { + data: Update_Multi_Column_Text_Rich_Text_Columns_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Multi_Column_Text_Rich_Text_Columns_ItemsArgs = { + data: Update_Multi_Column_Text_Rich_Text_Columns_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationUpdate_Nav_Link_BatchArgs = { data?: InputMaybe>; filter?: InputMaybe; @@ -2814,6 +2938,12 @@ export type Query = { markdown_pages: Array; markdown_pages_aggregated: Array; markdown_pages_by_id?: Maybe; + multi_column_text: Array; + multi_column_text_aggregated: Array; + multi_column_text_by_id?: Maybe; + multi_column_text_rich_text_columns: Array; + multi_column_text_rich_text_columns_aggregated: Array; + multi_column_text_rich_text_columns_by_id?: Maybe; nav_link: Array; nav_link_aggregated: Array; nav_link_by_id?: Maybe; @@ -3527,6 +3657,58 @@ export type QueryMarkdown_Pages_By_IdArgs = { }; +export type QueryMulti_Column_TextArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryMulti_Column_Text_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryMulti_Column_Text_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + +export type QueryMulti_Column_Text_Rich_Text_ColumnsArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryMulti_Column_Text_Rich_Text_Columns_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryMulti_Column_Text_Rich_Text_Columns_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + export type QueryNav_LinkArgs = { filter?: InputMaybe; limit?: InputMaybe; @@ -5403,6 +5585,7 @@ export type Create_Customer_Quote_Input = { date_created?: InputMaybe; date_updated?: InputMaybe; id?: InputMaybe; + quote?: InputMaybe; spacing?: InputMaybe; user_created?: InputMaybe; user_updated?: InputMaybe; @@ -5602,6 +5785,22 @@ export type Create_Markdown_Pages_Input = { user_updated?: InputMaybe; }; +export type Create_Multi_Column_Text_Input = { + columns?: InputMaybe>>; + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Create_Multi_Column_Text_Rich_Text_Columns_Input = { + id?: InputMaybe; + multi_column_text_id?: InputMaybe; + rich_text_columns_id?: InputMaybe; +}; + export type Create_Nav_Link_Input = { id?: InputMaybe; title?: InputMaybe; @@ -5726,10 +5925,12 @@ export type Create_Quotes_Input = { }; export type Create_Rich_Text_Columns_Input = { + body_text: Scalars['String']['input']; date_created?: InputMaybe; date_updated?: InputMaybe; + heading?: InputMaybe; + icon?: InputMaybe; id?: InputMaybe; - spacing?: InputMaybe; user_created?: InputMaybe; user_updated?: InputMaybe; }; @@ -6075,11 +6276,11 @@ export type Custom_Pages_Components_Filter = { item__hero?: InputMaybe; item__large_image?: InputMaybe; item__logo_strip?: InputMaybe; - item__rich_text_columns?: InputMaybe; + item__multi_column_text?: InputMaybe; item__section_header?: InputMaybe; }; -export type Custom_Pages_Components_Item_Union = Blog_Cards | Cards | Cta | Customer_Quote | Hero | Large_Image | Logo_Strip | Rich_Text_Columns | Section_Header; +export type Custom_Pages_Components_Item_Union = Blog_Cards | Cards | Cta | Customer_Quote | Hero | Large_Image | Logo_Strip | Multi_Column_Text | Section_Header; export type Custom_Pages_Filter = { _and?: InputMaybe>>; @@ -6104,12 +6305,23 @@ export type Customer_Quote = { date_updated?: Maybe; date_updated_func?: Maybe; id: Scalars['ID']['output']; + quote?: Maybe; spacing?: Maybe; user_created?: Maybe; user_updated?: Maybe; }; +export type Customer_QuoteQuoteArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type Customer_QuoteUser_CreatedArgs = { filter?: InputMaybe; limit?: InputMaybe; @@ -6148,6 +6360,7 @@ export type Customer_Quote_Aggregated_Count = { date_created?: Maybe; date_updated?: Maybe; id?: Maybe; + quote?: Maybe; spacing?: Maybe; user_created?: Maybe; user_updated?: Maybe; @@ -6156,6 +6369,7 @@ export type Customer_Quote_Aggregated_Count = { export type Customer_Quote_Aggregated_Fields = { __typename?: 'customer_quote_aggregated_fields'; id?: Maybe; + quote?: Maybe; }; export type Customer_Quote_Filter = { @@ -6166,6 +6380,7 @@ export type Customer_Quote_Filter = { date_updated?: InputMaybe; date_updated_func?: InputMaybe; id?: InputMaybe; + quote?: InputMaybe; spacing?: InputMaybe; user_created?: InputMaybe; user_updated?: InputMaybe; @@ -7298,6 +7513,158 @@ export type Markdown_Pages_Filter = { user_updated?: InputMaybe; }; +export type Multi_Column_Text = { + __typename?: 'multi_column_text'; + columns?: Maybe>>; + columns_func?: Maybe; + date_created?: Maybe; + date_created_func?: Maybe; + date_updated?: Maybe; + date_updated_func?: Maybe; + id: Scalars['ID']['output']; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + + +export type Multi_Column_TextColumnsArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type Multi_Column_TextUser_CreatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type Multi_Column_TextUser_UpdatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Multi_Column_Text_Aggregated = { + __typename?: 'multi_column_text_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Multi_Column_Text_Aggregated_Count = { + __typename?: 'multi_column_text_aggregated_count'; + columns?: Maybe; + date_created?: Maybe; + date_updated?: Maybe; + id?: Maybe; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + +export type Multi_Column_Text_Aggregated_Fields = { + __typename?: 'multi_column_text_aggregated_fields'; + id?: Maybe; +}; + +export type Multi_Column_Text_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + columns?: InputMaybe; + columns_func?: InputMaybe; + date_created?: InputMaybe; + date_created_func?: InputMaybe; + date_updated?: InputMaybe; + date_updated_func?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Multi_Column_Text_Rich_Text_Columns = { + __typename?: 'multi_column_text_rich_text_columns'; + id: Scalars['ID']['output']; + multi_column_text_id?: Maybe; + rich_text_columns_id?: Maybe; +}; + + +export type Multi_Column_Text_Rich_Text_ColumnsMulti_Column_Text_IdArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type Multi_Column_Text_Rich_Text_ColumnsRich_Text_Columns_IdArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Multi_Column_Text_Rich_Text_Columns_Aggregated = { + __typename?: 'multi_column_text_rich_text_columns_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Multi_Column_Text_Rich_Text_Columns_Aggregated_Count = { + __typename?: 'multi_column_text_rich_text_columns_aggregated_count'; + id?: Maybe; + multi_column_text_id?: Maybe; + rich_text_columns_id?: Maybe; +}; + +export type Multi_Column_Text_Rich_Text_Columns_Aggregated_Fields = { + __typename?: 'multi_column_text_rich_text_columns_aggregated_fields'; + id?: Maybe; + multi_column_text_id?: Maybe; + rich_text_columns_id?: Maybe; +}; + +export type Multi_Column_Text_Rich_Text_Columns_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + id?: InputMaybe; + multi_column_text_id?: InputMaybe; + rich_text_columns_id?: InputMaybe; +}; + export type Nav_Link = { __typename?: 'nav_link'; id: Scalars['ID']['output']; @@ -8253,12 +8620,14 @@ export type Quotes_Filter = { export type Rich_Text_Columns = { __typename?: 'rich_text_columns'; + body_text: Scalars['String']['output']; date_created?: Maybe; date_created_func?: Maybe; date_updated?: Maybe; date_updated_func?: Maybe; + heading?: Maybe; + icon?: Maybe; id: Scalars['ID']['output']; - spacing?: Maybe; user_created?: Maybe; user_updated?: Maybe; }; @@ -8299,10 +8668,12 @@ export type Rich_Text_Columns_Aggregated = { export type Rich_Text_Columns_Aggregated_Count = { __typename?: 'rich_text_columns_aggregated_count'; + body_text?: Maybe; date_created?: Maybe; date_updated?: Maybe; + heading?: Maybe; + icon?: Maybe; id?: Maybe; - spacing?: Maybe; user_created?: Maybe; user_updated?: Maybe; }; @@ -8315,12 +8686,14 @@ export type Rich_Text_Columns_Aggregated_Fields = { export type Rich_Text_Columns_Filter = { _and?: InputMaybe>>; _or?: InputMaybe>>; + body_text?: InputMaybe; date_created?: InputMaybe; date_created_func?: InputMaybe; date_updated?: InputMaybe; date_updated_func?: InputMaybe; + heading?: InputMaybe; + icon?: InputMaybe; id?: InputMaybe; - spacing?: InputMaybe; user_created?: InputMaybe; user_updated?: InputMaybe; }; @@ -9435,6 +9808,7 @@ export type Update_Customer_Quote_Input = { date_created?: InputMaybe; date_updated?: InputMaybe; id?: InputMaybe; + quote?: InputMaybe; spacing?: InputMaybe; user_created?: InputMaybe; user_updated?: InputMaybe; @@ -9634,6 +10008,22 @@ export type Update_Markdown_Pages_Input = { user_updated?: InputMaybe; }; +export type Update_Multi_Column_Text_Input = { + columns?: InputMaybe>>; + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Update_Multi_Column_Text_Rich_Text_Columns_Input = { + id?: InputMaybe; + multi_column_text_id?: InputMaybe; + rich_text_columns_id?: InputMaybe; +}; + export type Update_Nav_Link_Input = { id?: InputMaybe; title?: InputMaybe; @@ -9768,10 +10158,12 @@ export type Update_Quotes_Input = { }; export type Update_Rich_Text_Columns_Input = { + body_text?: InputMaybe; date_created?: InputMaybe; date_updated?: InputMaybe; + heading?: InputMaybe; + icon?: InputMaybe; id?: InputMaybe; - spacing?: InputMaybe; user_created?: InputMaybe; user_updated?: InputMaybe; }; @@ -9988,7 +10380,7 @@ export type SolutionsQueryVariables = Exact<{ export type SolutionsQuery = { __typename?: 'Query', solutions_pages: Array<{ __typename?: 'solutions_pages', id: string, slug: string, title?: string | null, description?: string | null, upper_features_title?: string | null, lower_features_title?: string | null, download_section_title?: string | null, download_section_description?: string | null, upper_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, lower_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, problems?: Array<{ __typename?: 'solution_problems', id: string, title?: string | null, subtitle?: string | null, problem?: string | null, solution?: string | null } | null> | null, featured_quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null }> }; -export type CustomPageFragment = { __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }; +export type CustomPageFragment = { __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null } | { __typename?: 'customer_quote', spacing?: string | null, quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'multi_column_text', spacing?: string | null, columns?: Array<{ __typename?: 'multi_column_text_rich_text_columns', rich_text_columns_id?: { __typename?: 'rich_text_columns', icon?: string | null, heading?: string | null, body_text: string } | null } | null> | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }; export type CustomPageTinyFragment = { __typename?: 'custom_pages', id: string, slug: string }; @@ -10002,7 +10394,7 @@ export type CustomPageQueryVariables = Exact<{ }>; -export type CustomPageQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null } | { __typename?: 'customer_quote', spacing?: string | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'rich_text_columns', spacing?: string | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }> }; +export type CustomPageQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null } | { __typename?: 'customer_quote', spacing?: string | null, quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'multi_column_text', spacing?: string | null, columns?: Array<{ __typename?: 'multi_column_text_rich_text_columns', rich_text_columns_id?: { __typename?: 'rich_text_columns', icon?: string | null, heading?: string | null, body_text: string } | null } | null> | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }> }; export type HeroComponentFragment = { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null }; @@ -10016,9 +10408,11 @@ export type CardsComponentFragment = { __typename?: 'cards', spacing?: string | export type BlogCardsComponentFragment = { __typename?: 'blog_cards', spacing?: string | null }; -export type RichTextColumnsComponentFragment = { __typename?: 'rich_text_columns', spacing?: string | null }; +export type RichTextColumnFragment = { __typename?: 'rich_text_columns', icon?: string | null, heading?: string | null, body_text: string }; -export type CustomerQuoteComponentFragment = { __typename?: 'customer_quote', spacing?: string | null }; +export type MultiColumnTextComponentFragment = { __typename?: 'multi_column_text', spacing?: string | null, columns?: Array<{ __typename?: 'multi_column_text_rich_text_columns', rich_text_columns_id?: { __typename?: 'rich_text_columns', icon?: string | null, heading?: string | null, body_text: string } | null } | null> | null }; + +export type CustomerQuoteComponentFragment = { __typename?: 'customer_quote', spacing?: string | null, quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null }; export type CtaComponentFragment = { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null }; @@ -10387,6 +10781,23 @@ export const LargeImageComponentFragmentDoc = gql` cta_url } ${ImageFileFragmentDoc}`; +export const RichTextColumnFragmentDoc = gql` + fragment RichTextColumn on rich_text_columns { + icon + heading + body_text +} + `; +export const MultiColumnTextComponentFragmentDoc = gql` + fragment MultiColumnTextComponent on multi_column_text { + spacing + columns { + rich_text_columns_id { + ...RichTextColumn + } + } +} + ${RichTextColumnFragmentDoc}`; export const CardsComponentFragmentDoc = gql` fragment CardsComponent on cards { spacing @@ -10397,16 +10808,14 @@ export const BlogCardsComponentFragmentDoc = gql` spacing } `; -export const RichTextColumnsComponentFragmentDoc = gql` - fragment RichTextColumnsComponent on rich_text_columns { - spacing -} - `; export const CustomerQuoteComponentFragmentDoc = gql` fragment CustomerQuoteComponent on customer_quote { spacing + quote { + ...Quote + } } - `; + ${QuoteFragmentDoc}`; export const CtaComponentFragmentDoc = gql` fragment CTAComponent on cta { spacing @@ -10427,9 +10836,9 @@ export const CustomPageFragmentDoc = gql` ...LogoStripComponent ...SectionHeaderComponent ...LargeImageComponent + ...MultiColumnTextComponent ...CardsComponent ...BlogCardsComponent - ...RichTextColumnsComponent ...CustomerQuoteComponent ...CTAComponent } @@ -10439,9 +10848,9 @@ export const CustomPageFragmentDoc = gql` ${LogoStripComponentFragmentDoc} ${SectionHeaderComponentFragmentDoc} ${LargeImageComponentFragmentDoc} +${MultiColumnTextComponentFragmentDoc} ${CardsComponentFragmentDoc} ${BlogCardsComponentFragmentDoc} -${RichTextColumnsComponentFragmentDoc} ${CustomerQuoteComponentFragmentDoc} ${CtaComponentFragmentDoc}`; export const CustomPageTinyFragmentDoc = gql` diff --git a/src/graph/directus/customPages.graphql b/src/graph/directus/customPages.graphql index 7b019cde..dd7f58a7 100644 --- a/src/graph/directus/customPages.graphql +++ b/src/graph/directus/customPages.graphql @@ -8,9 +8,9 @@ fragment CustomPage on custom_pages { ...LogoStripComponent ...SectionHeaderComponent ...LargeImageComponent + ...MultiColumnTextComponent ...CardsComponent ...BlogCardsComponent - ...RichTextColumnsComponent ...CustomerQuoteComponent ...CTAComponent } @@ -85,12 +85,26 @@ fragment BlogCardsComponent on blog_cards { spacing } -fragment RichTextColumnsComponent on rich_text_columns { +fragment RichTextColumn on rich_text_columns { + icon + heading + body_text +} + +fragment MultiColumnTextComponent on multi_column_text { spacing + columns { + rich_text_columns_id { + ...RichTextColumn + } + } } fragment CustomerQuoteComponent on customer_quote { spacing + quote { + ...Quote + } } fragment CTAComponent on cta { From 50a0e3a2963524d605651d0a078603158c28f965 Mon Sep 17 00:00:00 2001 From: Jake Laderman Date: Mon, 21 Oct 2024 22:38:12 -0400 Subject: [PATCH 7/8] add two column text --- src/components/custom-page/TwoColumnText.tsx | 29 +++ src/components/custom-page/common.tsx | 3 + src/generated/graphqlDirectus.ts | 211 ++++++++++++++++++- src/graph/directus/customPages.graphql | 7 + 4 files changed, 247 insertions(+), 3 deletions(-) create mode 100644 src/components/custom-page/TwoColumnText.tsx diff --git a/src/components/custom-page/TwoColumnText.tsx b/src/components/custom-page/TwoColumnText.tsx new file mode 100644 index 00000000..a1b6f4d2 --- /dev/null +++ b/src/components/custom-page/TwoColumnText.tsx @@ -0,0 +1,29 @@ +import { Markdown } from '@pluralsh/design-system' + +import { type TwoColumnTextComponentFragment } from '@src/generated/graphqlDirectus' + +import { cn } from '../cn' + +import { getSpacingClassName } from './common' + +export function TwoColumnText({ + spacing, + main_content: mainContent, + side_content: sideContent, +}: TwoColumnTextComponentFragment) { + return ( +
    +
    + +
    +
    + +
    +
    + ) +} diff --git a/src/components/custom-page/common.tsx b/src/components/custom-page/common.tsx index 367fa851..d5a82a13 100644 --- a/src/components/custom-page/common.tsx +++ b/src/components/custom-page/common.tsx @@ -9,6 +9,7 @@ import { LargeImage } from './LargeImage' import { LogoStrip } from './LogoStrip' import { MultiColumnText } from './MultiColumnText' import { SectionHeader } from './SectionHeader' +import { TwoColumnText } from './TwoColumnText' const spacingToClassName = { relaxed: 'my-[192px]', @@ -37,6 +38,8 @@ export function renderComponent( return case 'blog_cards': return + case 'two_column_text': + return case 'multi_column_text': return case 'customer_quote': diff --git a/src/generated/graphqlDirectus.ts b/src/generated/graphqlDirectus.ts index b81559c5..759990fc 100644 --- a/src/generated/graphqlDirectus.ts +++ b/src/generated/graphqlDirectus.ts @@ -116,6 +116,8 @@ export type Mutation = { create_stacks_items: Array; create_team_members_item?: Maybe; create_team_members_items: Array; + create_two_column_text_item?: Maybe; + create_two_column_text_items: Array; delete_apps_item?: Maybe; delete_apps_items?: Maybe; delete_article_cards_item?: Maybe; @@ -206,6 +208,8 @@ export type Mutation = { delete_stacks_items?: Maybe; delete_team_members_item?: Maybe; delete_team_members_items?: Maybe; + delete_two_column_text_item?: Maybe; + delete_two_column_text_items?: Maybe; update_app_defaults?: Maybe; update_apps_batch: Array; update_apps_item?: Maybe; @@ -348,6 +352,9 @@ export type Mutation = { update_team_members_batch: Array; update_team_members_item?: Maybe; update_team_members_items: Array; + update_two_column_text_batch: Array; + update_two_column_text_item?: Maybe; + update_two_column_text_items: Array; }; @@ -1071,6 +1078,22 @@ export type MutationCreate_Team_Members_ItemsArgs = { }; +export type MutationCreate_Two_Column_Text_ItemArgs = { + data: Create_Two_Column_Text_Input; +}; + + +export type MutationCreate_Two_Column_Text_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationDelete_Apps_ItemArgs = { id: Scalars['ID']['input']; }; @@ -1521,6 +1544,16 @@ export type MutationDelete_Team_Members_ItemsArgs = { }; +export type MutationDelete_Two_Column_Text_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Two_Column_Text_ItemsArgs = { + ids: Array>; +}; + + export type MutationUpdate_App_DefaultsArgs = { data: Update_App_Defaults_Input; }; @@ -2860,6 +2893,35 @@ export type MutationUpdate_Team_Members_ItemsArgs = { sort?: InputMaybe>>; }; + +export type MutationUpdate_Two_Column_Text_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Two_Column_Text_ItemArgs = { + data: Update_Two_Column_Text_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Two_Column_Text_ItemsArgs = { + data: Update_Two_Column_Text_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + export type Query = { __typename?: 'Query'; app_defaults?: Maybe; @@ -3004,6 +3066,9 @@ export type Query = { team_members: Array; team_members_aggregated: Array; team_members_by_id?: Maybe; + two_column_text: Array; + two_column_text_aggregated: Array; + two_column_text_by_id?: Maybe; }; @@ -4176,6 +4241,32 @@ export type QueryTeam_Members_By_IdArgs = { id: Scalars['ID']['input']; }; + +export type QueryTwo_Column_TextArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryTwo_Column_Text_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryTwo_Column_Text_By_IdArgs = { + id: Scalars['ID']['input']; +}; + export type App_Defaults = { __typename?: 'app_defaults'; case_study?: Maybe; @@ -6055,6 +6146,17 @@ export type Create_Team_Members_Input = { title?: InputMaybe; }; +export type Create_Two_Column_Text_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + main_content: Scalars['String']['input']; + side_content: Scalars['String']['input']; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + export type Cta = { __typename?: 'cta'; body_text?: Maybe; @@ -6278,9 +6380,10 @@ export type Custom_Pages_Components_Filter = { item__logo_strip?: InputMaybe; item__multi_column_text?: InputMaybe; item__section_header?: InputMaybe; + item__two_column_text?: InputMaybe; }; -export type Custom_Pages_Components_Item_Union = Blog_Cards | Cards | Cta | Customer_Quote | Hero | Large_Image | Logo_Strip | Multi_Column_Text | Section_Header; +export type Custom_Pages_Components_Item_Union = Blog_Cards | Cards | Cta | Customer_Quote | Hero | Large_Image | Logo_Strip | Multi_Column_Text | Section_Header | Two_Column_Text; export type Custom_Pages_Filter = { _and?: InputMaybe>>; @@ -9608,6 +9711,86 @@ export type Team_Members_Filter = { title?: InputMaybe; }; +export type Two_Column_Text = { + __typename?: 'two_column_text'; + date_created?: Maybe; + date_created_func?: Maybe; + date_updated?: Maybe; + date_updated_func?: Maybe; + id: Scalars['ID']['output']; + main_content: Scalars['String']['output']; + side_content: Scalars['String']['output']; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + + +export type Two_Column_TextUser_CreatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type Two_Column_TextUser_UpdatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Two_Column_Text_Aggregated = { + __typename?: 'two_column_text_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Two_Column_Text_Aggregated_Count = { + __typename?: 'two_column_text_aggregated_count'; + date_created?: Maybe; + date_updated?: Maybe; + id?: Maybe; + main_content?: Maybe; + side_content?: Maybe; + spacing?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + +export type Two_Column_Text_Aggregated_Fields = { + __typename?: 'two_column_text_aggregated_fields'; + id?: Maybe; +}; + +export type Two_Column_Text_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + date_created?: InputMaybe; + date_created_func?: InputMaybe; + date_updated?: InputMaybe; + date_updated_func?: InputMaybe; + id?: InputMaybe; + main_content?: InputMaybe; + side_content?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + export type Update_App_Defaults_Input = { case_study?: InputMaybe; date_updated?: InputMaybe; @@ -10296,6 +10479,17 @@ export type Update_Team_Members_Input = { title?: InputMaybe; }; +export type Update_Two_Column_Text_Input = { + date_created?: InputMaybe; + date_updated?: InputMaybe; + id?: InputMaybe; + main_content?: InputMaybe; + side_content?: InputMaybe; + spacing?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + export type EventFragment = { __typename?: 'events', id: string, name?: string | null, start_date?: any | null, end_date?: any | null, show_start_time: boolean, show_end_time?: boolean | null, timezone?: string | null, description?: string | null, fields?: any | null, ctas?: any | null }; export type EventsQueryVariables = Exact<{ [key: string]: never; }>; @@ -10380,7 +10574,7 @@ export type SolutionsQueryVariables = Exact<{ export type SolutionsQuery = { __typename?: 'Query', solutions_pages: Array<{ __typename?: 'solutions_pages', id: string, slug: string, title?: string | null, description?: string | null, upper_features_title?: string | null, lower_features_title?: string | null, download_section_title?: string | null, download_section_description?: string | null, upper_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, lower_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, problems?: Array<{ __typename?: 'solution_problems', id: string, title?: string | null, subtitle?: string | null, problem?: string | null, solution?: string | null } | null> | null, featured_quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null }> }; -export type CustomPageFragment = { __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null } | { __typename?: 'customer_quote', spacing?: string | null, quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'multi_column_text', spacing?: string | null, columns?: Array<{ __typename?: 'multi_column_text_rich_text_columns', rich_text_columns_id?: { __typename?: 'rich_text_columns', icon?: string | null, heading?: string | null, body_text: string } | null } | null> | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }; +export type CustomPageFragment = { __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null } | { __typename?: 'customer_quote', spacing?: string | null, quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'multi_column_text', spacing?: string | null, columns?: Array<{ __typename?: 'multi_column_text_rich_text_columns', rich_text_columns_id?: { __typename?: 'rich_text_columns', icon?: string | null, heading?: string | null, body_text: string } | null } | null> | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | { __typename?: 'two_column_text', spacing?: string | null, main_content: string, side_content: string } | null } | null> | null }; export type CustomPageTinyFragment = { __typename?: 'custom_pages', id: string, slug: string }; @@ -10394,7 +10588,7 @@ export type CustomPageQueryVariables = Exact<{ }>; -export type CustomPageQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null } | { __typename?: 'customer_quote', spacing?: string | null, quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'multi_column_text', spacing?: string | null, columns?: Array<{ __typename?: 'multi_column_text_rich_text_columns', rich_text_columns_id?: { __typename?: 'rich_text_columns', icon?: string | null, heading?: string | null, body_text: string } | null } | null> | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | null } | null> | null }> }; +export type CustomPageQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null } | { __typename?: 'customer_quote', spacing?: string | null, quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'multi_column_text', spacing?: string | null, columns?: Array<{ __typename?: 'multi_column_text_rich_text_columns', rich_text_columns_id?: { __typename?: 'rich_text_columns', icon?: string | null, heading?: string | null, body_text: string } | null } | null> | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | { __typename?: 'two_column_text', spacing?: string | null, main_content: string, side_content: string } | null } | null> | null }> }; export type HeroComponentFragment = { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null }; @@ -10410,6 +10604,8 @@ export type BlogCardsComponentFragment = { __typename?: 'blog_cards', spacing?: export type RichTextColumnFragment = { __typename?: 'rich_text_columns', icon?: string | null, heading?: string | null, body_text: string }; +export type TwoColumnTextComponentFragment = { __typename?: 'two_column_text', spacing?: string | null, main_content: string, side_content: string }; + export type MultiColumnTextComponentFragment = { __typename?: 'multi_column_text', spacing?: string | null, columns?: Array<{ __typename?: 'multi_column_text_rich_text_columns', rich_text_columns_id?: { __typename?: 'rich_text_columns', icon?: string | null, heading?: string | null, body_text: string } | null } | null> | null }; export type CustomerQuoteComponentFragment = { __typename?: 'customer_quote', spacing?: string | null, quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null }; @@ -10781,6 +10977,13 @@ export const LargeImageComponentFragmentDoc = gql` cta_url } ${ImageFileFragmentDoc}`; +export const TwoColumnTextComponentFragmentDoc = gql` + fragment TwoColumnTextComponent on two_column_text { + spacing + main_content + side_content +} + `; export const RichTextColumnFragmentDoc = gql` fragment RichTextColumn on rich_text_columns { icon @@ -10836,6 +11039,7 @@ export const CustomPageFragmentDoc = gql` ...LogoStripComponent ...SectionHeaderComponent ...LargeImageComponent + ...TwoColumnTextComponent ...MultiColumnTextComponent ...CardsComponent ...BlogCardsComponent @@ -10848,6 +11052,7 @@ export const CustomPageFragmentDoc = gql` ${LogoStripComponentFragmentDoc} ${SectionHeaderComponentFragmentDoc} ${LargeImageComponentFragmentDoc} +${TwoColumnTextComponentFragmentDoc} ${MultiColumnTextComponentFragmentDoc} ${CardsComponentFragmentDoc} ${BlogCardsComponentFragmentDoc} diff --git a/src/graph/directus/customPages.graphql b/src/graph/directus/customPages.graphql index dd7f58a7..95f0e874 100644 --- a/src/graph/directus/customPages.graphql +++ b/src/graph/directus/customPages.graphql @@ -8,6 +8,7 @@ fragment CustomPage on custom_pages { ...LogoStripComponent ...SectionHeaderComponent ...LargeImageComponent + ...TwoColumnTextComponent ...MultiColumnTextComponent ...CardsComponent ...BlogCardsComponent @@ -91,6 +92,12 @@ fragment RichTextColumn on rich_text_columns { body_text } +fragment TwoColumnTextComponent on two_column_text { + spacing + main_content + side_content +} + fragment MultiColumnTextComponent on multi_column_text { spacing columns { From 5d7d1de0381f5f8387fdc4667c08183e42b6affe Mon Sep 17 00:00:00 2001 From: Jake Laderman Date: Tue, 22 Oct 2024 00:04:45 -0400 Subject: [PATCH 8/8] add cards component --- src/components/AspectRatio.tsx | 4 +- src/components/custom-page/BlogCards.tsx | 5 +- src/components/custom-page/CallToAction.tsx | 2 +- src/components/custom-page/Cards.tsx | 75 +++- src/components/custom-page/SectionHeader.tsx | 2 +- src/generated/graphqlDirectus.ts | 416 ++++++++++++++++++- src/graph/directus/customPages.graphql | 14 + 7 files changed, 506 insertions(+), 12 deletions(-) diff --git a/src/components/AspectRatio.tsx b/src/components/AspectRatio.tsx index b0132417..57896dbc 100644 --- a/src/components/AspectRatio.tsx +++ b/src/components/AspectRatio.tsx @@ -38,7 +38,9 @@ export const EmbedAspectRatio = styled.div<{ $aspectRatio: string }>( ) export const ImageAspectRatio = styled(EmbedAspectRatio)<{ $url: string }>( - ({ $url }) => ({ + ({ theme, $url }) => ({ + borderRadius: theme.borderRadiuses.large, + border: theme.borders['fill-three'], backgroundSize: 'cover', backgroundPosition: 'center', backgroundImage: `url(${$url})`, diff --git a/src/components/custom-page/BlogCards.tsx b/src/components/custom-page/BlogCards.tsx index 31017dd1..a9f1633c 100644 --- a/src/components/custom-page/BlogCards.tsx +++ b/src/components/custom-page/BlogCards.tsx @@ -1,5 +1,6 @@ import { type BlogCardsComponentFragment } from '@src/generated/graphqlDirectus' -export function BlogCards({ spacing }: BlogCardsComponentFragment) { - return
    BlogCards
    +export function BlogCards({ spacing: _spacing }: BlogCardsComponentFragment) { + // TODO + return null } diff --git a/src/components/custom-page/CallToAction.tsx b/src/components/custom-page/CallToAction.tsx index a3f64c8f..23597193 100644 --- a/src/components/custom-page/CallToAction.tsx +++ b/src/components/custom-page/CallToAction.tsx @@ -19,7 +19,7 @@ export function CallToAction({
    {heading} diff --git a/src/components/custom-page/Cards.tsx b/src/components/custom-page/Cards.tsx index 8201e180..47ef4995 100644 --- a/src/components/custom-page/Cards.tsx +++ b/src/components/custom-page/Cards.tsx @@ -1,5 +1,74 @@ -import { type CardsComponentFragment } from '@src/generated/graphqlDirectus' +import { Card } from '@pluralsh/design-system' -export function Cards({ spacing }: CardsComponentFragment) { - return
    Cards
    +import styled from 'styled-components' + +import { getImageUrl } from '@src/consts/routes' +import { + type CardFragment, + type CardsComponentFragment, +} from '@src/generated/graphqlDirectus' +import { cn } from '@src/utils/cn' + +import { ImageAspectRatio } from '../AspectRatio' +import { Body2, OverlineLabel } from '../Typography' + +import { getSpacingClassName } from './common' + +export function Cards({ spacing, cards }: CardsComponentFragment) { + return ( +
    + {cards?.map((c) => c?.card_id && )} +
    + ) } + +export function CardComponent({ + image, + heading, + body_text: bodyText, + url, +}: CardFragment) { + return ( + + + {heading} + {bodyText} + + ) +} + +const CardComponentWrapperSC = styled(Card)<{ $clickable: boolean }>( + ({ theme, $clickable }) => ({ + display: 'flex', + flexDirection: 'column', + padding: theme.spacing.xlarge, + gap: theme.spacing.medium, + transition: 'border 0.16s ease-in-out', + ...($clickable + ? { + cursor: 'pointer', + '&:hover': { + border: theme.borders.selected, + }, + } + : {}), + }) +) diff --git a/src/components/custom-page/SectionHeader.tsx b/src/components/custom-page/SectionHeader.tsx index 0f0ace2b..a85a0b77 100644 --- a/src/components/custom-page/SectionHeader.tsx +++ b/src/components/custom-page/SectionHeader.tsx @@ -15,7 +15,7 @@ export function SectionHeader({
    {overline && {overline}} diff --git a/src/generated/graphqlDirectus.ts b/src/generated/graphqlDirectus.ts index 759990fc..bdf496e1 100644 --- a/src/generated/graphqlDirectus.ts +++ b/src/generated/graphqlDirectus.ts @@ -34,6 +34,10 @@ export type Mutation = { create_blog_cards_items: Array; create_callouts_item?: Maybe; create_callouts_items: Array; + create_card_item?: Maybe; + create_card_items: Array; + create_cards_card_item?: Maybe; + create_cards_card_items: Array; create_cards_item?: Maybe; create_cards_items: Array; create_case_studies_item?: Maybe; @@ -126,6 +130,10 @@ export type Mutation = { delete_blog_cards_items?: Maybe; delete_callouts_item?: Maybe; delete_callouts_items?: Maybe; + delete_card_item?: Maybe; + delete_card_items?: Maybe; + delete_cards_card_item?: Maybe; + delete_cards_card_items?: Maybe; delete_cards_item?: Maybe; delete_cards_items?: Maybe; delete_case_studies_item?: Maybe; @@ -223,7 +231,13 @@ export type Mutation = { update_callouts_batch: Array; update_callouts_item?: Maybe; update_callouts_items: Array; + update_card_batch: Array; + update_card_item?: Maybe; + update_card_items: Array; update_cards_batch: Array; + update_cards_card_batch: Array; + update_cards_card_item?: Maybe; + update_cards_card_items: Array; update_cards_item?: Maybe; update_cards_items: Array; update_case_studies_batch: Array; @@ -422,6 +436,38 @@ export type MutationCreate_Callouts_ItemsArgs = { }; +export type MutationCreate_Card_ItemArgs = { + data: Create_Card_Input; +}; + + +export type MutationCreate_Card_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationCreate_Cards_Card_ItemArgs = { + data: Create_Cards_Card_Input; +}; + + +export type MutationCreate_Cards_Card_ItemsArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationCreate_Cards_ItemArgs = { data: Create_Cards_Input; }; @@ -1134,6 +1180,26 @@ export type MutationDelete_Callouts_ItemsArgs = { }; +export type MutationDelete_Card_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Card_ItemsArgs = { + ids: Array>; +}; + + +export type MutationDelete_Cards_Card_ItemArgs = { + id: Scalars['ID']['input']; +}; + + +export type MutationDelete_Cards_Card_ItemsArgs = { + ids: Array>; +}; + + export type MutationDelete_Cards_ItemArgs = { id: Scalars['ID']['input']; }; @@ -1675,6 +1741,35 @@ export type MutationUpdate_Callouts_ItemsArgs = { }; +export type MutationUpdate_Card_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Card_ItemArgs = { + data: Update_Card_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Card_ItemsArgs = { + data: Update_Card_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationUpdate_Cards_BatchArgs = { data?: InputMaybe>; filter?: InputMaybe; @@ -1686,6 +1781,35 @@ export type MutationUpdate_Cards_BatchArgs = { }; +export type MutationUpdate_Cards_Card_BatchArgs = { + data?: InputMaybe>; + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type MutationUpdate_Cards_Card_ItemArgs = { + data: Update_Cards_Card_Input; + id: Scalars['ID']['input']; +}; + + +export type MutationUpdate_Cards_Card_ItemsArgs = { + data: Update_Cards_Card_Input; + filter?: InputMaybe; + ids: Array>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type MutationUpdate_Cards_ItemArgs = { data: Update_Cards_Input; id: Scalars['ID']['input']; @@ -2937,9 +3061,15 @@ export type Query = { callouts: Array; callouts_aggregated: Array; callouts_by_id?: Maybe; + card: Array; + card_aggregated: Array; + card_by_id?: Maybe; cards: Array; cards_aggregated: Array; cards_by_id?: Maybe; + cards_card: Array; + cards_card_aggregated: Array; + cards_card_by_id?: Maybe; case_studies: Array; case_studies_aggregated: Array; case_studies_by_id?: Maybe; @@ -3176,6 +3306,32 @@ export type QueryCallouts_By_IdArgs = { }; +export type QueryCardArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryCard_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryCard_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + export type QueryCardsArgs = { filter?: InputMaybe; limit?: InputMaybe; @@ -3202,6 +3358,32 @@ export type QueryCards_By_IdArgs = { }; +export type QueryCards_CardArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryCards_Card_AggregatedArgs = { + filter?: InputMaybe; + groupBy?: InputMaybe>>; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type QueryCards_Card_By_IdArgs = { + id: Scalars['ID']['input']; +}; + + export type QueryCase_StudiesArgs = { filter?: InputMaybe; limit?: InputMaybe; @@ -4716,8 +4898,103 @@ export type Callouts_Filter = { user_updated?: InputMaybe; }; +export type Card = { + __typename?: 'card'; + body_text: Scalars['String']['output']; + date_created?: Maybe; + date_created_func?: Maybe; + date_updated?: Maybe; + date_updated_func?: Maybe; + heading: Scalars['String']['output']; + id: Scalars['ID']['output']; + image?: Maybe; + url?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + + +export type CardImageArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type CardUser_CreatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type CardUser_UpdatedArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Card_Aggregated = { + __typename?: 'card_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Card_Aggregated_Count = { + __typename?: 'card_aggregated_count'; + body_text?: Maybe; + date_created?: Maybe; + date_updated?: Maybe; + heading?: Maybe; + id?: Maybe; + image?: Maybe; + url?: Maybe; + user_created?: Maybe; + user_updated?: Maybe; +}; + +export type Card_Aggregated_Fields = { + __typename?: 'card_aggregated_fields'; + id?: Maybe; +}; + +export type Card_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + body_text?: InputMaybe; + date_created?: InputMaybe; + date_created_func?: InputMaybe; + date_updated?: InputMaybe; + date_updated_func?: InputMaybe; + heading?: InputMaybe; + id?: InputMaybe; + image?: InputMaybe; + url?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + export type Cards = { __typename?: 'cards'; + cards?: Maybe>>; + cards_func?: Maybe; date_created?: Maybe; date_created_func?: Maybe; date_updated?: Maybe; @@ -4729,6 +5006,16 @@ export type Cards = { }; +export type CardsCardsArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + export type CardsUser_CreatedArgs = { filter?: InputMaybe; limit?: InputMaybe; @@ -4764,6 +5051,7 @@ export type Cards_Aggregated = { export type Cards_Aggregated_Count = { __typename?: 'cards_aggregated_count'; + cards?: Maybe; date_created?: Maybe; date_updated?: Maybe; id?: Maybe; @@ -4777,9 +5065,74 @@ export type Cards_Aggregated_Fields = { id?: Maybe; }; +export type Cards_Card = { + __typename?: 'cards_card'; + card_id?: Maybe; + cards_id?: Maybe; + id: Scalars['ID']['output']; +}; + + +export type Cards_CardCard_IdArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + + +export type Cards_CardCards_IdArgs = { + filter?: InputMaybe; + limit?: InputMaybe; + offset?: InputMaybe; + page?: InputMaybe; + search?: InputMaybe; + sort?: InputMaybe>>; +}; + +export type Cards_Card_Aggregated = { + __typename?: 'cards_card_aggregated'; + avg?: Maybe; + avgDistinct?: Maybe; + count?: Maybe; + countAll?: Maybe; + countDistinct?: Maybe; + group?: Maybe; + max?: Maybe; + min?: Maybe; + sum?: Maybe; + sumDistinct?: Maybe; +}; + +export type Cards_Card_Aggregated_Count = { + __typename?: 'cards_card_aggregated_count'; + card_id?: Maybe; + cards_id?: Maybe; + id?: Maybe; +}; + +export type Cards_Card_Aggregated_Fields = { + __typename?: 'cards_card_aggregated_fields'; + card_id?: Maybe; + cards_id?: Maybe; + id?: Maybe; +}; + +export type Cards_Card_Filter = { + _and?: InputMaybe>>; + _or?: InputMaybe>>; + card_id?: InputMaybe; + cards_id?: InputMaybe; + id?: InputMaybe; +}; + export type Cards_Filter = { _and?: InputMaybe>>; _or?: InputMaybe>>; + cards?: InputMaybe; + cards_func?: InputMaybe; date_created?: InputMaybe; date_created_func?: InputMaybe; date_updated?: InputMaybe; @@ -5544,7 +5897,26 @@ export type Create_Callouts_Input = { user_updated?: InputMaybe; }; +export type Create_Card_Input = { + body_text: Scalars['String']['input']; + date_created?: InputMaybe; + date_updated?: InputMaybe; + heading: Scalars['String']['input']; + id?: InputMaybe; + image?: InputMaybe; + url?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Create_Cards_Card_Input = { + card_id?: InputMaybe; + cards_id?: InputMaybe; + id?: InputMaybe; +}; + export type Create_Cards_Input = { + cards?: InputMaybe>>; date_created?: InputMaybe; date_updated?: InputMaybe; id?: InputMaybe; @@ -9859,7 +10231,26 @@ export type Update_Callouts_Input = { user_updated?: InputMaybe; }; +export type Update_Card_Input = { + body_text?: InputMaybe; + date_created?: InputMaybe; + date_updated?: InputMaybe; + heading?: InputMaybe; + id?: InputMaybe; + image?: InputMaybe; + url?: InputMaybe; + user_created?: InputMaybe; + user_updated?: InputMaybe; +}; + +export type Update_Cards_Card_Input = { + card_id?: InputMaybe; + cards_id?: InputMaybe; + id?: InputMaybe; +}; + export type Update_Cards_Input = { + cards?: InputMaybe>>; date_created?: InputMaybe; date_updated?: InputMaybe; id?: InputMaybe; @@ -10574,7 +10965,7 @@ export type SolutionsQueryVariables = Exact<{ export type SolutionsQuery = { __typename?: 'Query', solutions_pages: Array<{ __typename?: 'solutions_pages', id: string, slug: string, title?: string | null, description?: string | null, upper_features_title?: string | null, lower_features_title?: string | null, download_section_title?: string | null, download_section_description?: string | null, upper_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, lower_features?: Array<{ __typename?: 'solution_features', id: string, title?: string | null, description?: string | null, icon?: string | null, link_title?: string | null, link_url?: string | null } | null> | null, problems?: Array<{ __typename?: 'solution_problems', id: string, title?: string | null, subtitle?: string | null, problem?: string | null, solution?: string | null } | null> | null, featured_quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null }> }; -export type CustomPageFragment = { __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null } | { __typename?: 'customer_quote', spacing?: string | null, quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'multi_column_text', spacing?: string | null, columns?: Array<{ __typename?: 'multi_column_text_rich_text_columns', rich_text_columns_id?: { __typename?: 'rich_text_columns', icon?: string | null, heading?: string | null, body_text: string } | null } | null> | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | { __typename?: 'two_column_text', spacing?: string | null, main_content: string, side_content: string } | null } | null> | null }; +export type CustomPageFragment = { __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null, cards?: Array<{ __typename?: 'cards_card', card_id?: { __typename?: 'card', heading: string, body_text: string, url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null } | { __typename?: 'customer_quote', spacing?: string | null, quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'multi_column_text', spacing?: string | null, columns?: Array<{ __typename?: 'multi_column_text_rich_text_columns', rich_text_columns_id?: { __typename?: 'rich_text_columns', icon?: string | null, heading?: string | null, body_text: string } | null } | null> | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | { __typename?: 'two_column_text', spacing?: string | null, main_content: string, side_content: string } | null } | null> | null }; export type CustomPageTinyFragment = { __typename?: 'custom_pages', id: string, slug: string }; @@ -10588,7 +10979,7 @@ export type CustomPageQueryVariables = Exact<{ }>; -export type CustomPageQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null } | { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null } | { __typename?: 'customer_quote', spacing?: string | null, quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'multi_column_text', spacing?: string | null, columns?: Array<{ __typename?: 'multi_column_text_rich_text_columns', rich_text_columns_id?: { __typename?: 'rich_text_columns', icon?: string | null, heading?: string | null, body_text: string } | null } | null> | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | { __typename?: 'two_column_text', spacing?: string | null, main_content: string, side_content: string } | null } | null> | null }> }; +export type CustomPageQuery = { __typename?: 'Query', custom_pages: Array<{ __typename?: 'custom_pages', id: string, slug: string, components?: Array<{ __typename?: 'custom_pages_components', collection?: string | null, item?: { __typename?: 'blog_cards', spacing?: string | null } | { __typename?: 'cards', spacing?: string | null, cards?: Array<{ __typename?: 'cards_card', card_id?: { __typename?: 'card', heading: string, body_text: string, url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | { __typename?: 'cta', spacing?: string | null, heading?: string | null, body_text?: string | null, cta_text?: string | null, cta_url?: string | null } | { __typename?: 'customer_quote', spacing?: string | null, quote?: { __typename?: 'quotes', id: string, quote?: string | null, author_text?: string | null } | null } | { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | { __typename?: 'logo_strip', spacing?: string | null, logo_list?: { __typename?: 'company_logo_lists', slug?: string | null, logos?: Array<{ __typename?: 'company_logo_lists_company_logos', company_logos_id?: { __typename?: 'company_logos', slug?: string | null, name: string, url?: string | null, logo_light?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null, logo_dark?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null } | null } | { __typename?: 'multi_column_text', spacing?: string | null, columns?: Array<{ __typename?: 'multi_column_text_rich_text_columns', rich_text_columns_id?: { __typename?: 'rich_text_columns', icon?: string | null, heading?: string | null, body_text: string } | null } | null> | null } | { __typename?: 'section_header', spacing?: string | null, overline?: string | null, title?: string | null, description?: string | null } | { __typename?: 'two_column_text', spacing?: string | null, main_content: string, side_content: string } | null } | null> | null }> }; export type HeroComponentFragment = { __typename?: 'hero', spacing?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null }; @@ -10598,7 +10989,9 @@ export type SectionHeaderComponentFragment = { __typename?: 'section_header', sp export type LargeImageComponentFragment = { __typename?: 'large_image', spacing?: string | null, overline?: string | null, heading?: string | null, body_text?: string | null, media_type?: string | null, video_url?: string | null, form?: string | null, cta_text?: string | null, cta_url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null }; -export type CardsComponentFragment = { __typename?: 'cards', spacing?: string | null }; +export type CardFragment = { __typename?: 'card', heading: string, body_text: string, url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null }; + +export type CardsComponentFragment = { __typename?: 'cards', spacing?: string | null, cards?: Array<{ __typename?: 'cards_card', card_id?: { __typename?: 'card', heading: string, body_text: string, url?: string | null, image?: { __typename?: 'directus_files', id: string, title?: string | null, description?: string | null, tags?: any | null, filename_disk?: string | null, filename_download: string, metadata?: any | null, type?: string | null, filesize?: any | null } | null } | null } | null> | null }; export type BlogCardsComponentFragment = { __typename?: 'blog_cards', spacing?: string | null }; @@ -11001,11 +11394,26 @@ export const MultiColumnTextComponentFragmentDoc = gql` } } ${RichTextColumnFragmentDoc}`; +export const CardFragmentDoc = gql` + fragment Card on card { + image { + ...ImageFile + } + heading + body_text + url +} + ${ImageFileFragmentDoc}`; export const CardsComponentFragmentDoc = gql` fragment CardsComponent on cards { spacing + cards { + card_id { + ...Card + } + } } - `; + ${CardFragmentDoc}`; export const BlogCardsComponentFragmentDoc = gql` fragment BlogCardsComponent on blog_cards { spacing diff --git a/src/graph/directus/customPages.graphql b/src/graph/directus/customPages.graphql index 95f0e874..4e772a7e 100644 --- a/src/graph/directus/customPages.graphql +++ b/src/graph/directus/customPages.graphql @@ -78,8 +78,22 @@ fragment LargeImageComponent on large_image { cta_url } +fragment Card on card { + image { + ...ImageFile + } + heading + body_text + url +} + fragment CardsComponent on cards { spacing + cards { + card_id { + ...Card + } + } } fragment BlogCardsComponent on blog_cards {