Skip to content

Latest commit

 

History

History
 
 

astro-example

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Astro Polar Demo

This directory contains a demo site to show off the @polar-sh/astro package for integrating Polar and Astro.

The site is based on the Astro blog template that ships with Astro:

pnpm create astro@latest -- --template blog

The only change is in the src/pages/blog/index.astro file, which contains an example of how to use the integration to upload posts to Polar.

Note: this code will fail unless you provide both a personal access token and an organization ID. The example is not intended to be run.

Example

The following code will upload all posts to Polar that have not been uploaded previously. It will also add the header image to the Polar post, if it exists, and will set the title of the post. By default, the title will be the filename.

import { getCollection } from 'astro:content'
import { Polar } from '@polar-sh/astro'

const posts = (await getCollection('blog')).sort(
  (a, b) => a.data.pubDate.valueOf() - b.data.pubDate.valueOf(),
)

if (!process.env.POLAR_ACCESS_TOKEN) {
  throw Error('POLAR_ACCESS_TOKEN is not set')
}

if (!process.env.POLAR_ORGANIZATION_ID) {
  throw Error('POLAR_ORGANIZATION_ID is not set')
}

/**
 * Upload all posts to Polar
 */
// Create a Polar client with your API key
const polar = new Polar({
  accessToken: process.env.POLAR_ACCESS_TOKEN,
})

// Upload all posts to Polar
const { error: postUploadError } = await polar
  .upload(posts, {
    organizationId: process.env.POLAR_ORGANIZATION_ID,
  })
  // Filter for only new posts
  .filter(({ exists }) => !exists)
  // Add the correct title to the post
  .transform(({ article, entry }) => {
    article.title = entry.data.title
    return article
  })
  // Add the header image and Polar metadata to the post
  .transform(({ article, entry }) => {
    if (entry.data.heroImage) {
      article.body = `![${entry.data.title}](${rootUrl}${entry.data.heroImage.src})\n\n${article.body}`
    }
    article = {
      ...article,
      ...entry.data.polar,
      published_at: entry.data.polar?.published_at?.toISOString(),
    }
    return article
  })

if (postUploadError) {
  console.error('Error uploading posts to Polar:', postUploadError)
}

The only other change has been to use an image in the collection config.

If you'd like to see more examples, check out @polar-sh/astro on NPM.