Flotiq & Astro
هذا المحتوى غير متوفر بلغتك بعد.
Flotiq is a headless CMS designed for various frontends, such as static sites, mobile, and web applications. Developers and content creators manage and deliver content through REST and GraphQL-based APIs.
Integrating with Astro
Section titled Integrating with AstroThis guide will use the Flotiq headless CMS API with an Astro project to display content on your website.
Prerequisites
Section titled PrerequisitesTo get started, you will need:
- An Astro project - You can create a new project using the
npm create astro@latest
command. - A Flotiq account - If you don’t have an account, sign up for free.
- Flotiq read-only API key - Find out how to obtain your key.
Setting up the Environment variables
Section titled Setting up the Environment variablesAdd the read-only API key from your Flotiq account to the .env
file in the root of your Astro project:
Defining a Content Type in Flotiq
Section titled Defining a Content Type in FlotiqFirst, you need to define an example Content Type Definition in Flotiq to store data.
Log in to your Flotiq account and create a custom Content Type Definition with the following example Blog Post
configuration:
- Label: Blog Post
- API Name: blogpost
- Fields:
- Title: text, required
- Slug: text, required
- Content: rich text, required
Then, create one or more example Content Objects using this Blog Post
type.
Installing the Flotiq TypeScript SDK
Section titled Installing the Flotiq TypeScript SDKTo connect your project with Flotiq, install the Flotiq SDK using the package manager of your choice:
Next, configure the SDK using your credentials. Create a new file named flotiq.ts
inside the src/lib
directory of your project:
This configuration can now be used throughout your project.
Fetching and Displaying Data from Flotiq
Section titled Fetching and Displaying Data from Flotiq-
Fetch the
Blog Post
data on an Astro page using your content’s custom APIBlogpostAPI
: -
Display the content in your Astro template. You will have access to the
title
,slug
, andcontent
of your posts as well as otherinternal
post data: -
Start the dev server and visit your page preview at
http://localhost:4321
to see the list of your blog posts. Each post will link to a page that does not yet exist. These will be created in the next step.
Generating Individual Pages
Section titled Generating Individual PagesAstro supports both prerendering all your pages ahead of time, or creating routes on demand when they are requested. Follow the instructions for either static site generation or on-demand rendering to build the page routes for your blog posts.
Static Site Generation
Section titled Static Site GenerationIn static site generation (SSG) mode, use the getStaticPaths()
method to fetch all possible blog post paths from Flotiq.
-
Create a new file
[slug].astro
in the/src/pages/posts/
directory. Fetch all blog posts and return them within thegetStaticPaths()
method: -
Add the templating to display an individual post:
-
Visit
http://localhost:4321
and click on a linked blog post in your list. You will now be able to navigate to the individual post’s page.
On-demand Rendering
Section titled On-demand RenderingIf you are using SSR mode, you will need to fetch a single post based on its slug
.
-
Create a new file
[slug].astro
in the/src/pages/posts/
directory. Fetch the post by itsslug
field, including logic to display a 404 page when the route is not found: -
Add the templating to display an individual post:
-
Visit
http://localhost:4321
and click on a linked blog post in your list. You will now be able to navigate to the individual post’s page.
Refreshing the SDK After Content Type Changes
Section titled Refreshing the SDK After Content Type ChangesWhen using the Flotiq TypeScript SDK (flotiq-api-ts
), all your data types are accurately mapped into the Astro project.
If you make changes to the structure of your content types (such as adding a new field or modifying an existing one), you’ll need to refresh the SDK to ensure that your project reflects the latest model updates.
To do this, run the rebuild command for your package manager:
This will update the SDK, aligning object types, fields, and API methods with your current data model.
Publishing Your Site
Section titled Publishing Your SiteTo deploy your website, visit Astro’s deployment guides and follow the instructions for your preferred hosting provider.
Redeploy on Flotiq Changes
Section titled Redeploy on Flotiq ChangesTo update your published site, configure Flotiq to send a webhook your hosting provider to trigger a rebuild whenever your content changes.
In Flotiq, you can define which Content Type and events it should trigger on, and configure it accordingly. See the Flotiq Webhooks documentation for more details.