Skip to content

Commit

Permalink
feat: gatsby ssg works now
Browse files Browse the repository at this point in the history
  • Loading branch information
ryunsong-contentful committed Jan 9, 2025
1 parent 5b23aef commit c9e19be
Show file tree
Hide file tree
Showing 6 changed files with 104 additions and 94 deletions.
77 changes: 68 additions & 9 deletions examples/gatsby/gatsby-ssg/gatsby-node.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,68 @@
exports.onCreateWebpackConfig = ({ actions }) => {
actions.setWebpackConfig({
resolve: {
fallback: {
path: require.resolve("path-browserify"),
},
},
});
};
const path = require('path');

exports.createPages = async ({ graphql, actions, reporter }) => {
const { createPage } = actions;

// Dynamically import the ES Module
const { fetchById, detachExperienceStyles } = await import('@contentful/experiences-sdk-react');

const response = await graphql(`
query {
allContentfulExperience {
nodes {
contentful_id
slug
title
node_locale
sys {
contentType {
sys {
id
}
}
}
}
}
}
`);

if (response.errors) {
reporter.panicOnBuild('Error while querying Contentful data', response.errors);
return;
}

const { useContentfulClient } = require('./src/utils/useContentfulClient.ts');
const client = useContentfulClient();
const { nodes } = response.data.allContentfulExperience;

for (const node of nodes) {
const { slug, title, node_locale: localeCode, contentful_id, sys } = node;

try {
const experienceEntry = await fetchById({
client,
experienceTypeId: sys.contentType.sys.id,
localeCode,
id: contentful_id,
});

let experienceStyles = '';
if (experienceEntry) {
experienceStyles = detachExperienceStyles(experienceEntry) ?? '';
}

createPage({
path: `/experience/${slug}`,
component: path.resolve('src/templates/experiencePage.js'),
context: {
title,
experienceEntryJSON: JSON.stringify(experienceEntry),
locale: localeCode,
experienceStyles,
},
});
} catch (err) {
reporter.warn(`Error creating page for slug "${slug}": ${err.message}`);
}
}
};
32 changes: 9 additions & 23 deletions examples/gatsby/gatsby-ssg/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 2 additions & 1 deletion examples/gatsby/gatsby-ssg/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,9 @@
"typecheck": "tsc --noEmit"
},
"dependencies": {
"contentful": "^11.3.2",
"@contentful/experiences-sdk-react": "^1.27.1",
"@contentful/rich-text-react-renderer": "^16.0.1",
"contentful": "^11.3.2",
"gatsby": "^5.14.1",
"path-browserify": "^1.0.1",
"react": "^18.2.0",
Expand Down
74 changes: 19 additions & 55 deletions examples/gatsby/gatsby-ssg/src/pages/ExperienceSlugExample.tsx
Original file line number Diff line number Diff line change
@@ -1,61 +1,25 @@
import path from 'path';
import { fetchById, detachExperienceStyles } from '@contentful/experiences-sdk-react';
import React from 'react'
import { ExperienceRoot, useFetchBySlug } from '@contentful/experiences-sdk-react';
import { useContentfulClient } from '../utils/useContentfulClient';

exports.createPages = async ({ graphql, actions, reporter }: any) => {
const { client } = useContentfulClient();
const { createPage } = actions;

// Assume that your experience type id is "experience"
const response = await graphql(`
allContentfulExperience {
nodes {
contentful_id
slug
title
node_locale
sys {
contentType {
sys {
id
}
}
}
}
}
`);

if (response.errors) {
// handle errors
}
const slug = 'ExperienceSlugExample'
const localeCode = 'en-US';
const experienceTypeId = process.env.GATSBY_CTFL_EXPERIENCE_TYPE || '';

const { nodes } = response.data.allContentfulExperience;

for (const node of nodes) {
const { slug, title, node_locale: localeCode, contentful_id, sys } = node;

const experienceEntry = await fetchById({
client,
experienceTypeId: sys.contentType.sys.id,
localeCode,
id: contentful_id
});
export default function ExperienceSlugExample() {
const { client } = useContentfulClient();

let experienceStyles = '';
const { experience, error, isLoading } = useFetchBySlug({
slug,
localeCode,
client,
experienceTypeId,
});

if (experienceEntry) {
experienceStyles = detachExperienceStyles(experienceEntry) ?? '';
}
if (isLoading) return <div>Loading...</div>;
if (error) return <div>{error.message}</div>;

createPage({
path: `/experience/${slug}`,
component: path.resolve('src/templates/experiencePage.js'),
context: {
title,
experienceEntryJSON: JSON.stringify(experienceEntry),
locale: localeCode,
experienceStyles
}
});
}
};
return (
<ExperienceRoot experience={experience} locale={localeCode} />
)
}
10 changes: 5 additions & 5 deletions examples/gatsby/gatsby-ssg/src/utils/useContentfulClient.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,11 +7,11 @@ export const useContentfulClient = () => {

const client = useMemo(() => {
const clientConfig = {
space: process.env.GATSBY_CTFL_SPACE || 'son9ld5ewssk',
environment: process.env.GATSBY_CTFL_ENVIRONMENT || 'master',
host: isPreview ? `preview.${process.env.GATSBY_CTFL_DOMAIN}` || 'cdn.contentful.com' : `cdn.${process.env.GATSBY_CTFL_DOMAIN}` || 'cdn.contentful.com',
accessToken: isPreview ? process.env.GATSBY_CTFL_PREVIEW_ACCESS_TOKEN || 'kHi665AtkIuAWgln1xbsf_jvoMPva4AsK62hff0_lio': process.env.GATSBY_CTFL_ACCESS_TOKEN || 'jqD43tJfgQG9Djsrlp9IcpxJepE416qmOdaemfzoxnE',
experienceTypeId: process.env.GATSBY_CTFL_EXPERIENCE_TYPE || 'hostedLayout',
space: process.env.GATSBY_CTFL_SPACE || '',
environment: process.env.GATSBY_CTFL_ENVIRONMENT || '',
host: isPreview ? `preview.${process.env.GATSBY_CTFL_DOMAIN}` || 'preview.contentful.com' : `cdn.${process.env.GATSBY_CTFL_DOMAIN}` || 'cdn.contentful.com',
accessToken: isPreview ? process.env.GATSBY_CTFL_PREVIEW_ACCESS_TOKEN || '': process.env.GATSBY_CTFL_ACCESS_TOKEN || '',
experienceTypeId: process.env.GATSBY_CTFL_EXPERIENCE_TYPE || '',
};
return createClient(clientConfig);
}, []);
Expand Down
2 changes: 1 addition & 1 deletion examples/gatsby/gatsby-ssg/tsconfig.json
Original file line number Diff line number Diff line change
Expand Up @@ -98,5 +98,5 @@
// "skipDefaultLibCheck": true, /* Skip type checking .d.ts files that are included with TypeScript. */
"skipLibCheck": true /* Skip type checking all .d.ts files. */
},
"include": ["./src/**/*", "./gatsby-node.ts", "./gatsby-config.ts", "./plugins/**/*"]
"include": ["./src/**/*", "gatsby-node.js", "./gatsby-config.ts", "./plugins/**/*"]
}

0 comments on commit c9e19be

Please sign in to comment.