Skip to content

Latest commit

 

History

History
176 lines (110 loc) · 6.5 KB

File metadata and controls

176 lines (110 loc) · 6.5 KB

Vintage Vinyl

This repo contains a demo project that shows the use of Custom Post Types in a Frontity Project. This repo was created for the "Lunch & Learn 🍱 The React framework for WP - Frontity" organized by WebDevStudios

Workshop Agenda

1️⃣ Part 1: mars-theme

1. Create a frontity project from command line → mars-theme

2. Review mars-theme

3. frontity.settings.js & Namespaces

4. frontity global object → state

5. Styled Components

6. Packages & wp-source package

2️⃣ Part 2: mars-theme-vintage-vinyl

7. Using Custom Post Types in a Frontity Project

7.1 Verify Custom Post Type is properly available through the REST API
7.2 Define CPT in Frontity Project via frontity.settings.js

frontity.settings.js

{
  "name": "@frontity/wp-source",
  "state": {
    "source": {
      "api": "https://app-5efddb43c1ac181508283e93.closte.com/wp-json",
      "postTypes": [
        {
          type: "record",
          endpoint: "record",
          archive: "/record_cat"
        }
      ],
      taxonomies: [
        {
          taxonomy: "record_cat",
          endpoint: "record_cat",
          postTypeEndpoint: "record"
        }
      ]

    }
  }
},
7.3 Use frontity.actions.fetch to check CPT links

/record/1984/ /record_cat/rock/

7.3 Custom Post Type record will use the <Record> component to show details of each record (links like /record/nevermind/)

src/components/index.js

 <Record when={data.isRecord} />
  1. Custom Taxonomy record_cat will use the <ListRecords> component to show list of records (links like /record_cat/rock/)

src/components/index.js

<ListRecords when={data.isRecordCat || data.isRecordArchive} />

Launch a development server

npx frontity dev

Runs the app in development mode. Open http://localhost:3000 to view it in the browser.

The site will automatically reload if you make changes inside the packages folder. You will see the build errors in the console.

Have a look at our Quick Start Guide

Create your custom theme

npx frontity create-package your-custom-theme

Use the command npx frontity create-package to create a new package that can be set in your frontity.settings.js as your theme

Have a look at our blog post How to Create a React WordPress Theme in 30 Minutes

Create a production-ready build

npx frontity build

Builds the app for production to the build folder.

This will create a /build folder with a server.js (a serverless function) file and a /static folder with all your javascript files and other assets.

Your app is ready to be deployed.

Get more info about Frontity's architecture

Deploy

With the files generated in the build you can deploy your project

As a node app

Use npx frontity serve to run it like a normal Node app.

This command generates (and runs) a small web server that uses the generated server.js and /static to serve your content

As a serverless service

Upload your static folder to a CDN and your server.js file to a serverless service, like Now or Netlify.

Get more info about how to deploy a Frontity project


» Frontity Channels 🌎

We have different channels at your disposal where you can find information about the project, discuss about it and get involved:

  • 📖 Docs: this is the place to learn how to build amazing sites with Frontity.
  • 👨‍👩‍👧‍👦 Community: use our forum to ask any questions, feedback and meet great people. This is your place too to share what are you building with Frontity!
  • 🐞 GitHub: we use GitHub for bugs and pull requests. Questions are answered in the community forum!
  • 🗣 Social media: a more informal place to interact with Frontity users, reach out to us on Twitter.
  • 💌 Newsletter: do you want to receive the latest framework updates and news? Subscribe here

» Get involved 🤗

Got questions or feedback about Frontity? We'd love to hear from you. Use our community forum yo ! ❤️

Frontity also welcomes contributions. There are many ways to support the project! If you don't know where to start, this guide might help → How to contribute?