Skip to content

bryntum/bryntum-scheduler-refine-nextjs-starter

 
 

Repository files navigation

Create a Bryntum Scheduler component in a Refine application using NextJS

This Refine project was generated using the Refine CLI-based Scaffolder. The following CLI options were selected:

  • Choose a project template: Next.js
  • Choose your backend service to connect: REST API - Installs the REST API data provider.
  • Do you want to use a UI Framework?: Headless - No UI framework.
  • Do you want to add example pages?: Yes
  • Do you need any Authentication logic?: None

The following code was added to the Next.js template for creating a SQLite database populated with Bryntum Scheduler data:

  • /src/config/database.ts: Sequelize, a Node.js ORM, SQLite database configuration.
  • /src/models:  Sequelize models for Bryntum Scheduler data.
  • /src/initialData: Example events, resources, and assignments JSON Bryntum Scheduler data.
  • /src/addExampleData.ts: Seed script to populate a local SQLite database with example JSON data.

The following npm packages were added:

  • sequelize
  • sqlite3

The following Next.js configuration was added to the next.config.mjs file:

const nextConfig = {
    experimental : {
        serverComponentsExternalPackages : ['sequelize']
    }
};

This removes the sequelize package from the Next.js server components bundling as bundling causes an import error when running the app.

Getting started

Install the dependencies by running the following command: 

npm install

Populate a local SQLite database with the example scheduler data in src/initialData:

npx tsx ./src/addExampleData.ts

Running the app

Run the local dev server using the following command:

npm run dev

You'll see the template Next.js CRUD app at http://localhost:3000/ with a blog posts and categories page:

Initial Refine app

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 94.6%
  • CSS 3.0%
  • Dockerfile 2.0%
  • JavaScript 0.4%