Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: update Readme #22

Merged
merged 1 commit into from
Feb 8, 2024
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
214 changes: 6 additions & 208 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,57 +1,19 @@

# Next Airview

Create presentation decks using MDX, React, and [Next.js](https://nextjs.org/).

## Features

- 📝 Documentation as Code (via Github)
- ✍️ Collaborative editing (via Etherpad)
- 📽 React-based Slideshow
- ✍️ Write using Markdown, React components, even HTML!
- 🎨 Themeable with CSS
- 👉 Swipe to change slides
- ♻️ Sync slides between browser tabs
- 👨‍💻 Presentation Mode
- 📝 Speaker Notes
- ✍️ MDX mode for use within a website (Airview)

## Getting Started

1. Clone the project: `git clone https://github.com/AirWalk-Digital/airview-next`
2. Install dependencies: `yarn`
3. Run the dev server: `npm run dev` or `yarn dev`
4. Edit the first slide in `/markdwon/test.mdx` and save to [**see changes**](http://localhost:3000/files/ppt/test.mdx)!

*or*

1. Browse to Etherpad [here](https://pad.airview.airwalkconsulting.io)
2. Create a new pad
3. [**browse pads**](http://localhost:3000/

*or*

use the docker image with Etherpad:

```bash
source .env* && docker run -d --env ETHERPAD_API_KEY=$ETHERPAD_API_KEY --env ETHERPAD_BASE_URL=$ETHERPAD_BASE_URL -p 8080:3000 --name mdx-deck ghcr.io/airwalk-digital/airview-next:local
```

[**browse pads**](http://localhost:8080/


When you're done, run `npm run build && npm run export` or `yarn build && yarn export` will create a static app you can deploy anywhere (or use locally). See below for more details.

### Deploying

This project is easy to build locally or using a host with build services (like Netlify or Now).

1. ⚙️ Run the build process: `yarn export`
1. 🚀 Upload the static contents of `out` folder to host/CDN (or run the `out/index.html` locally)

## How to Use

### 💬 Changing the Title/Date/etc

The default theme includes a title, date, author (and link to the author's website) in of the `<Header>` component. You can edit this data inside the `site.config.js` file.
2. in VScode - "Open in Container" using remote containers.
3. Install dependencies: `npm i`
4. Run the dev server: `npm run dev`
5. Run storybook: `npm run storybook`

### ✍️ Writing JSX

Expand All @@ -64,71 +26,6 @@ You can use JSX in [a few ways](https://mdxjs.com/getting-started) in your MDX f

[Check out the MDX docs](https://mdxjs.com/getting-started) for more information on the syntax.

### 📃 Creating Slide Pages

You can create new slide pages by making new `.mdx` files inside the `/markdown/` directory. Each slide is separated by a markdown divider (`---`).

> **You have to wrap the contents of each `.mdx` file with a `<SlidePage>` component.** This is what breaks up each slide page into individual slides using the markdown dividers. [Note: this isn't required now]

### 🗺 Navigation

[Note: this isn't implemented yet] Slide pages represent real pages - so `page-2.mdx` == `your-site.com/page-2`. By using the `next` prop on the `<SlidePage>` component you can control the next page you navigate to (after you go through all the slides).

```js
// Navigates to your-site.com/your-custom-page after all slides complete
<SlidePage next="your-custom-page">
```

### 🎨 Theming the Slideshow

Theming is accomplished with **CSS custom properties** and/or **Styled Components**.

Design tokens are stored as CSS custom properties inside the SlidePage layout (`/layouts/SlidePage.jsx`), which are injected into the app using Styled Component's global styling utility. There you can change the color of text, background colors, fonts, etc.

The actual CSS styles of the Slideshow are also stored in the SlidePage layout. There you can change the padding of slides, alignment of quotes, etc.

When the Markdown is parsed into HTML, you can replace HTML with React components. These "swaps" are handled by the `<MDXProvider>` component. You can import custom components and swap elements (like a `<button>` with `<Button>`), or import components to use inside MDX (great for creating things like 2-col layouts with component). There you can change the syntax highlighting or find any custom MDX components. It's recommended to use Styled Components there to create custom components.

## Presentation Mode

[Note: this isn't implemented yet]

Presentation mode allows you to view the current slide alongside any **"speaker notes"** included inside the slide.

- Press `ALT/OPT + P` to toggle presentation mode on and off.
- You can also add the `mode` query parameter to the URL (e.g. `http://localhost:3000/slides/1?mode=presentation`).

The most common way to use presentation mode:

1. Open two browser tabs with any slide page.
2. Activate presentation mode in one tab.
3. Navigate through slides - they'll be synced in both tabs!

This way you can view your presentation on one monitor, while displaying the slides on another screen. Or if you're livestreaming, you can capture the slideshow window in software like OBS, and view the presentation window privately.

> Note that syncing between tabs is achieved using `localStorage`. If you want to use an "Incognito" browser, make sure both tabs are "incognito" or they won't sync.

### Speaker Notes

Speaker notes are only displayed during presentation mode. This allows you to write private notes to yourself that you can see in "presentation" mode, while the audience only sees the other slide content in "slideshow" mode.

Speaker notes can contain **Markdown**, **MDX/JSX**, and even **HTML** _(as JSX)_. The notes are displayed in a scrollable window to the side of slide content during "presenation" mode.

To create speaker notes, you use the `<SpeakerNotes>` component inside of your MDX files. No need to import it, it's [automatically imported into any MDX slide page](components/MDXProvider.jsx). You can also use it multiple times within the same slide, all the notes (per slide) will be combined.

Here's an example:

```mdx
Slide content would go here.

<SpeakerNotes>

Private notes here.

# Even Markdown!

</SpeakerNotes>
```

### Adding/replacing components in MDX

Expand All @@ -144,102 +41,3 @@ const mdComponents = {
CustomButton,
};
```

## Available Components

### Framer Motion

You can use any Framer Motion component:

```mdx
<motion.div
animate={{scale: 2}}
transition={{ duration: 0.5 }}
>

# Your animated header

</motion.div>
```

### Cover

Displays content centered and larger, commonly for the first slide in a deck.

```mdx
<Cover>

# NextJS MDX Deck

Create presentations using Next & React & MDX.

</Cover>
```

### Steps

![Steps component](./screenshots/next-mdx-deck-step-component.gif)

Reveals content step by step as the user does next/prev slide button.

```mdx
<Steps>
<Step>Something</Step>
<Step>happens</Step>
<Step>one</Step>
<Step>by</Step>
<Step>one</Step>
<Step>easy to add stuff</Step>
</Steps>
```

**Custom order**

You can also define the order explicitly:

```mdx
<Steps>
<Step order={3}>Third</Step>
<Step order={2}>Second</Step>
<Step order={1}>First</Step>
</Steps>
```

**Duration**

You can control the animation duration using the prop and providing an integer (representing seconds):

```mdx
<Steps>
{/** 3 seconds **/}
<Step duration={3}>Something</Step>
<Step>happens</Step>
</Steps>
```

## Learn More

### MDX

To learn more about **MDX**, take a look at the following resources:

- [MDX Documentation](https://mdxjs.com/)
- [Getting started with MDX](https://mdxjs.com/getting-started)
- [Using MDX with Next.js](https://mdxjs.com/getting-started/next)

### Next.js

To learn more about **Next.js**, take a look at the following resources:

- [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API.
- [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial.

### References

- [MDX Deck](https://github.com/jxnblk/mdx-deck/blob/master/packages/gatsby-theme/src/hooks/use-storage.js)
- [Gatsby Starter Deck](https://www.gatsbyjs.org/starters/fabe/gatsby-starter-deck/)
- [react-syntax-highlighter](https://github.com/conorhastings/react-syntax-highlighter)