Skip to content

Commit 4a19773

Browse files
matthewlipskiYousefEDCTNicholas
authored
release: v0.12 - new website and major refactor (#609)
* first step * update examples * remove veaury * upgrade sandpack * example test * tests * misc * update vite configs * misc fixes * add docs * add comments * Added async slash menu items POC * Fixed vanilla example * Small test fix * Implemented PR feedback * Improved performance * Simplified how outdated queries are ignored/cancelled * small fixes * Added custom suggestion menus PoC * Updated custom mentions example * remove beta * fix settings * Added remaining examples * Build fixes and removed generated playground/docs files * Small fixes * fix build * re-add generated files * small fixes * wip: migrate to nextjs * update docs2 * fixes * fix * fix index * Converted more examples & small fixes * Added gen files for new examples * Small typing fixes * misc * fix build * disable examples * Converted remaining examples and small fixes * improve examples * react icon import only types * fix build speed * Fixed demo & examples styling * Small fix * basic auth working * remove old site * clean script + organize examples * Changed home page gradients and styling fixes * update examples, docs, scripts * fix playground * fix docs * fix playground * add strictmode again! * Revert "add strictmode again!" This reverts commit 692c5b3. * Revised features section and gradients * small fixes * small fixes * small fixes * try fix link clicks + speed * fix type issue * Revised styles, fixed dark mode, and small cleanup * Small fix * Improved dark mode selection * Refactor/cleanup mount system (#567) * cleanup mount system * demo * wip * fix build * fix * fix light / dark mode * clean examples * clean examples * docs * misc * refs * better errors * add default block / partialblock types * wip: examples * fix theme * update interop examples * Small fixes --------- Co-authored-by: Matthew Lipski <[email protected]> * refactor: Mentions & custom suggestion menus (#534) * fix: Docs home page demo styling fix (#507) * Fixed styling for code styles (#517) * Made suggestions plugin control multiple menus * Added hook to create suggestion menu * Fixed add block button behaviour on blocks with different content (#526) * Small CSS fix (#527) * fix: List item shortcuts (#528) * Fixed list item shortcuts * Updated test screenshots * Added code toggle formatting toolbar example (#531) * fix: Errors when hovering image block while editor is uneditable (#533) * Fixed errors when hovering image block while editor is uneditable * Small fix * fix: Formatting toolbar not hiding while dragging blocks (#529) * Fixed formatting toolbar not hiding while dragging blocks * Small fix * Updated Mantine (#535) * Updated `package-lock.json` (#536) * v0.11.1 * v0.6.2 * v0.8.1 * v0.8.2 * v0.8.3 * v0.8.4 * v0.8.5 * v0.9.0 * v0.9.1 * Revert "v0.9.1" This reverts commit 6e9d61f. * v0.9.1 * Revert "v0.9.1" This reverts commit ac7abee. * v0.9.2 * v0.9.3 * v0.9.4 * v0.9.5 * v0.9.6 * v0.10.0 * v0.10.1 * v0.11.0 * v0.11.1 * fix collaboration and editable: false bug (#538) * pair refactoring * wip * fix type annotations on some of the docs (#539) * Cleanup and continue refactor * docs: Dark mode styling fix (#548) * Fixed styles that were overwritten by Mantine globals * Removed old code * Implemented PR feedback * Add Liveblocks info and BlockNote download command (#540) * Update real-time-collaboration.md * feat: Example image * feat: Replace image with video * Fixed video --------- Co-authored-by: Matthew Lipski <[email protected]> * Implemented PR feedback * fix: Mantine styles (#553) * Updated Mantine and package-lock * Added Mantine global styles reset * Made Mantine global styles not get imported * Fixed CSS import order * Updated test & snapshots * Implemented PR feedback * Implemented PR feedback * Fixed paragraph shortcut (#556) * v0.11.2 * Fixed build issues * Fixed add block button behaviour * Small fix * Small fix * Fixed tests --------- Co-authored-by: Yousef <[email protected]> Co-authored-by: Chris Nicholas <[email protected]> * Refactored how remaining UI elements (except table handles) are created to match suggestions * remove file left after merge * Replaced `data`/`position` hooks with refactored general hooks * Fixed vanilla example * Lint fix * Minor fixes * Refactored table handles * clean getitems * misc * test * tests * small fixes * about page * Implemented PR feedback * Small naming fix * Added vanilla default slash menu items * address feedback * pair work * add footer * small fix * faq, sponsors * noteplan * readme todo * Cleaned up homepage * Addressed docs TODOs and cleanup * refactor: UI component types, names, and API (#584) * Cleaned up UI components and examples * Continued cleanup * Continued cleanup * Continued cleanup * Imlemented PR feedback * add default onItemClick * Implemented PR feedback * Small fix * fix build * remove file * Rename * fix image caption button * Moved components requiring Mantine to `/mantine` directories * Small fix * Updated formatting toolbar & side menu docs * suggestion (#588) * suggestion * Fixed block type dropdown API and small refactor --------- Co-authored-by: Matthew Lipski <[email protected]> * Added hyperlink toolbar docs and small changes * Updated slash menu docs & small fixes * Updated slash menu docs & small fixes * wip * update scripts * fix * fix * remove files * fix * update names * small fixes * docs * as discussed * address comments * Added initial content to UI component examples & small changes * Cleaned up UI component docs * custom schemas + custom blocks page * fix * update slash menu docs * move some examples * rename slash menu to suggestion menu * Added custom inline content page and other fixes * fix * theming todos * Made discussed changes to styling & theming docs * address feedback * Added custom styles docs * Fixed theming & styling demos * Updated advanced docs * docs: Proposal for editor basics docs changes (#594) * Added proposals for editor basics docs changes * Addressed editor basics TODOs * fix build * fix * Updated editor api links * generate + clean some comments * fix? * disable og * docs review (#596) * docs review * Fixed PR feedback --------- Co-authored-by: Matthew Lipski <[email protected]> --------- Co-authored-by: yousefed <[email protected]> --------- Co-authored-by: yousefed <[email protected]> * Fixed demo styles & windows scrollbars * fix build * fix og image? * Changed selections demo(s) & fixed various styles * fix lint * lint fix * Fixed demo input/output TODOs and removed hide last line hack * fix tests * try fix tests * Updated e2e test setup * Updated e2e test setup * Added docs pages redirects and misc changes * scripts * Updated screenshots * Fixed various docs TODOs * webpack stats / github ci * WIP: Fix/polish examples * ci update * Finished examples cleanup (expect collab) * Fixed toolbar button click behaviour for Safari * Fixed collaboration examples * Revert dependency changes * fix package json * separate inter font * fix xss #601 * Implemented PR feedback * small edits * small cleanup * fix bugs * features (wip) * fix * only apply fix to safari * comments * fix package lock * fix authors * fix bug * fix inline content api * Added insert inline content docs * update docs * small fixes * update readme * text * feat: Editor option to customize placeholders (#503) * Added option to customize placeholders * Slightly adjusted default placeholders * check emptyness with css * Added editor options to customize placeholders via CSS * Implemented PR feedback * small placeholder fixes --------- Co-authored-by: yousefed <[email protected]> * fix Incorrect blocknote styles affecting Mantine ToolTip component styles #566 * export * Cleaned up home page code * Added font import * update about * Implemented community/faq feedback * Updated test screenshots * Updated features gifs * Removed TODOs (added corresponding GH issues) * Fixed link --------- Co-authored-by: yousefed <[email protected]> Co-authored-by: Chris Nicholas <[email protected]>
1 parent f9278b8 commit 4a19773

File tree

817 files changed

+38621
-19146
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

817 files changed

+38621
-19146
lines changed

.github/workflows/build.yml

+7-7
Original file line numberDiff line numberDiff line change
@@ -11,14 +11,14 @@ jobs:
1111
name: Build
1212
runs-on: ubuntu-latest
1313
steps:
14-
- uses: actions/checkout@v3
14+
- uses: actions/checkout@v4
1515

16-
- uses: actions/setup-node@v3
16+
- uses: actions/setup-node@v4
1717
with:
18-
node-version: "18.x"
18+
node-version: "20.x"
1919

2020
- name: Cache node modules
21-
uses: actions/cache@v3
21+
uses: actions/cache@v4
2222
env:
2323
cache-name: cache-node-modules
2424
with:
@@ -32,7 +32,7 @@ jobs:
3232
3333
- name: cache playwright
3434
id: playwright-cache
35-
uses: actions/cache@v3
35+
uses: actions/cache@v4
3636
with:
3737
path: ~/.cache/ms-playwright
3838
key: pw-new-${{ runner.os }}-${{ hashFiles('**/package-lock.json') }}
@@ -70,7 +70,7 @@ jobs:
7070
working-directory: ./tests
7171
run: npx playwright test
7272

73-
- uses: actions/upload-artifact@v3
73+
- uses: actions/upload-artifact@v4
7474
if: always()
7575
with:
7676
name: playwright-report
@@ -80,5 +80,5 @@ jobs:
8080
- name: Upload webpack stats artifact (editor)
8181
uses: relative-ci/agent-upload-artifact-action@v1
8282
with:
83-
webpackStatsFile: ./examples/editor/dist/webpack-stats.json
83+
webpackStatsFile: ./playground/dist/webpack-stats.json
8484
artifactName: relative-ci-artifacts-editor

.nvmrc

+1-1
Original file line numberDiff line numberDiff line change
@@ -1 +1 @@
1-
v18.16.0
1+
v20.11.0

.vscode/settings.json

+3-1
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,9 @@
77
"editor.defaultFormatter": "esbenp.prettier-vscode"
88
},
99
"search.exclude": {
10-
"packages/editor/public/types": true
10+
"packages/editor/public/types": true,
11+
"packages/website/docs/.vitepress": false,
12+
"**/.*": false
1113
},
1214
"typescript.tsdk": "node_modules/typescript/lib"
1315
}

README.md

+13-17
Original file line numberDiff line numberDiff line change
@@ -1,49 +1,45 @@
11
<p align="center">
22
<a href="https://www.blocknotejs.org">
3-
<img alt="TypeCell" src="https://github.com/TypeCellOS/BlockNote/raw/main/packages/website/docs/public/img/logos/banner.svg?raw=true" width="300" />
3+
<img alt="TypeCell" src="https://github.com/TypeCellOS/BlockNote/raw/main/docs/public/img/logos/banner.svg?raw=true" width="300" />
44
</a>
55
</p>
66

77
<p align="center">
88
Welcome to BlockNote! The open source Block-Based
9-
rich text editor. Easily add a modern text editing experience to your app.
9+
React rich text editor. Easily add a modern text editing experience to your app.
1010
</p>
1111

1212
<p align="center">
13-
<a href="https://discord.gg/Qc2QTTH5dF"><img alt="Discord" src="https://img.shields.io/badge/Chat on discord%20-%237289DA.svg?&style=for-the-badge&logo=discord&logoColor=white"/></a> <a href="https://matrix.to/#/#typecell-space:matrix.org"><img alt="Matrix" src="https://img.shields.io/badge/Chat on matrix%20-%23000.svg?&style=for-the-badge&logo=matrix&logoColor=white"/></a>
13+
<a href="https://discord.gg/Qc2QTTH5dF"><img alt="Discord" src="https://img.shields.io/badge/Chat on discord%20-%237289DA.svg?&style=for-the-badge&logo=discord&logoColor=white"/></a>
1414
</p>
1515

1616
<p align="center">
1717
<a href="https://www.blocknotejs.org">
1818
Homepage
1919
</a> - <a href="https://www.blocknotejs.org/docs/introduction">
20-
Introduction
21-
</a> - <a href="https://www.blocknotejs.org/docs/quickstart">
2220
Documentation
21+
</a> - <a href="https://www.blocknotejs.org/docs/quickstart">
22+
Quickstart
23+
</a>- <a href="https://www.blocknotejs.org/docs/examples">
24+
Examples
2325
</a>
2426
</p>
2527

2628
# Live demo
2729

28-
Play with the editor @ [https://blocknote-main.vercel.app/](https://blocknote-main.vercel.app/).
29-
30-
(Source in [examples/editor](/examples/editor))
30+
See our homepage @ [https://www.blocknotejs.org](https://www.blocknotejs.org/) or browse the [examples](https://www.blocknotejs.org/examples).
3131

3232
# Example code (React)
3333

3434
[![npm version](https://badge.fury.io/js/%40blocknote%2Freact.svg)](https://badge.fury.io/js/%40blocknote%2Freact)
3535

3636
```typescript
37-
import { BlockNoteView, useBlockNote } from "@blocknote/react";
37+
import { BlockNoteView, useCreateBlockNote } from "@blocknote/react";
38+
import "@blocknote/core/fonts/inter.css";
3839
import "@blocknote/react/style.css";
3940

4041
function App() {
41-
const editor = useBlockNote({
42-
onEditorContentChange: (editor) => {
43-
// Log the document to console on every update
44-
console.log(editor.getJSON());
45-
},
46-
});
42+
const editor = useCreateBlockNote();
4743

4844
return <BlockNoteView editor={editor} />;
4945
}
@@ -99,8 +95,8 @@ Directory structure:
9995
blocknote
10096
├── packages/core - The core of the editor
10197
├── packages/react - The main library for use in React apps
102-
├── examples/editor - Example React app that embeds the editor
103-
├── examples/vanilla - An advanced example if you don't want to use React or want to build your own UI components
98+
├── examples - Example apps
99+
├── playground - App to browse the example apps (https://playground.blocknotejs.org)
104100
└── tests - Playwright end to end tests
105101
```
106102

docs/.env.local.example

+4
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
AUTH_SECRET= # Linux: `openssl rand -hex 32` or go to https://generate-secret.vercel.app/32
2+
3+
AUTH_GITHUB_ID=
4+
AUTH_GITHUB_SECRET=

docs/.eslintrc.json

+3
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
{
2+
"extends": "next/core-web-vitals"
3+
}

docs/.gitignore

+36
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,36 @@
1+
# See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
2+
3+
# dependencies
4+
/node_modules
5+
/.pnp
6+
.pnp.js
7+
.yarn/install-state.gz
8+
9+
# testing
10+
/coverage
11+
12+
# next.js
13+
/.next/
14+
/out/
15+
16+
# production
17+
/build
18+
19+
# misc
20+
.DS_Store
21+
*.pem
22+
23+
# debug
24+
npm-debug.log*
25+
yarn-debug.log*
26+
yarn-error.log*
27+
28+
# local env files
29+
.env*.local
30+
31+
# vercel
32+
.vercel
33+
34+
# typescript
35+
*.tsbuildinfo
36+
next-env.d.ts

docs/README.md

+36
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,36 @@
1+
This is a [Next.js](https://nextjs.org/) project bootstrapped with [`create-next-app`](https://github.com/vercel/next.js/tree/canary/packages/create-next-app).
2+
3+
## Getting Started
4+
5+
First, run the development server:
6+
7+
```bash
8+
npm run dev
9+
# or
10+
yarn dev
11+
# or
12+
pnpm dev
13+
# or
14+
bun dev
15+
```
16+
17+
Open [http://localhost:3000](http://localhost:3000) with your browser to see the result.
18+
19+
You can start editing the page by modifying `app/page.tsx`. The page auto-updates as you edit the file.
20+
21+
This project uses [`next/font`](https://nextjs.org/docs/basic-features/font-optimization) to automatically optimize and load Inter, a custom Google Font.
22+
23+
## Learn More
24+
25+
To learn more about Next.js, take a look at the following resources:
26+
27+
- [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API.
28+
- [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial.
29+
30+
You can check out [the Next.js GitHub repository](https://github.com/vercel/next.js/) - your feedback and contributions are welcome!
31+
32+
## Deploy on Vercel
33+
34+
The easiest way to deploy your Next.js app is to use the [Vercel Platform](https://vercel.com/new?utm_medium=default-template&filter=next.js&utm_source=create-next-app&utm_campaign=create-next-app-readme) from the creators of Next.js.
35+
36+
Check out our [Next.js deployment documentation](https://nextjs.org/docs/deployment) for more details.
+2
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
export { GET, POST } from "../../../../auth";
2+
export const runtime = "edge"; // optional

packages/website/api/og.tsx docs/app/api/og/route.tsx

+7-12
Original file line numberDiff line numberDiff line change
@@ -1,24 +1,19 @@
1-
import { ImageResponse } from "@vercel/og";
2-
import React from "react";
1+
import { ImageResponse } from "next/og";
32

4-
export const config = {
5-
runtime: "edge",
6-
};
3+
export const runtime = "edge";
74

8-
const font = fetch(
9-
new URL("../docs/public/fonts/Gilroy-Regular.ttf", import.meta.url)
10-
).then((res) => res.arrayBuffer());
11-
12-
export default async function handler(request) {
5+
export async function GET(request: Request) {
136
try {
7+
const fontData = await fetch(
8+
new URL("../../../assets/fonts/Gilroy-Regular.ttf", import.meta.url),
9+
).then((res) => res.arrayBuffer());
10+
1411
const { searchParams } = new URL(request.url);
1512
let title = searchParams.get("title");
1613
if (title && title.length > 100) {
1714
title = title.slice(0, 99) + "…";
1815
}
1916

20-
const fontData = await font;
21-
2217
const bannerSVG = (
2318
<svg
2419
width="938"

docs/app/favicon.ico

25.3 KB
Binary file not shown.

docs/app/globals.css

+33
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,33 @@
1+
@tailwind base;
2+
@tailwind components;
3+
@tailwind utilities;
4+
5+
:root {
6+
--foreground-rgb: 0, 0, 0;
7+
--background-start-rgb: 214, 219, 220;
8+
--background-end-rgb: 255, 255, 255;
9+
}
10+
11+
@media (prefers-color-scheme: dark) {
12+
:root {
13+
--foreground-rgb: 255, 255, 255;
14+
--background-start-rgb: 0, 0, 0;
15+
--background-end-rgb: 0, 0, 0;
16+
}
17+
}
18+
19+
body {
20+
color: rgb(var(--foreground-rgb));
21+
background: linear-gradient(
22+
to bottom,
23+
transparent,
24+
rgb(var(--background-end-rgb))
25+
)
26+
rgb(var(--background-start-rgb));
27+
}
28+
29+
@layer utilities {
30+
.text-balance {
31+
text-wrap: balance;
32+
}
33+
}

docs/app/layout.tsx

+22
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
import type { Metadata } from "next";
2+
import { Inter } from "next/font/google";
3+
import "./globals.css";
4+
5+
const inter = Inter({ subsets: ["latin"] });
6+
7+
export const metadata: Metadata = {
8+
title: "Create Next App",
9+
description: "Generated by create next app",
10+
};
11+
12+
export default function RootLayout({
13+
children,
14+
}: Readonly<{
15+
children: React.ReactNode;
16+
}>) {
17+
return (
18+
<html lang="en">
19+
<body className={inter.className}>{children}</body>
20+
</html>
21+
);
22+
}

0 commit comments

Comments
 (0)