An open API service indexing awesome lists of open source software.

https://github.com/tryghost/koenig

Components of Ghost's Editor
https://github.com/tryghost/koenig

editor ghost javascript nodejs

Last synced: 7 months ago
JSON representation

Components of Ghost's Editor

Awesome Lists containing this project

README

          

# Koenig

Ghost editor, based on the Lexical framework.

## Get started

This is a mono repository, managed with [lerna](https://lerna.js.org/).

To get started in this repo:

1. `git clone` this repo & `cd` into it as usual
2. run `yarn setup` from the top-level:
- installs all external dependencies
- links all internal dependencies
- runs an initial build of all projects

To add a new package to the repo:
- install [Slimer](https://github.com/TryGhost/slimer)
- run `slimer new `

## Development

`yarn dev` runs the `koenig-lexical` package in development mode. Please refer to its [README](packages/koenig-lexical/README.md) for more information.

## Test

- `yarn lint` run just eslint
- `yarn test` run lint and tests

## Deployment

Ghost core team only.

### Prerequisites

Create an `.env` file in `packages/koenig-lexical`, with environment variables for Sentry, so that we can track errors in the editor. There is a copy of this file in [1password](https://start.1password.com/open/i?a=FTXJSFO4TFAIVNFNGLK6UWNFTQ&v=2zqurhc5fmj5thjoob4oxwfllq&i=gcx3n7g2y5dibdn6n4zsgtm64y&h=ghost.1password.com).

```
VITE_SENTRY_ORG=""
VITE_SENTRY_PROJECT=""
VITE_SENTRY_AUTH_TOKEN=""
```

### Deploy a new version

1. run `yarn ship` in the top-level Koenig directory to publish to npm
2. bump the Koenig dependencies in Ghost. Either:
- wait for Renovate to create a bump PR ([example](https://github.com/TryGhost/Ghost/pull/21606)) and merge it (recommended option)
- or, do it manually, by adding the new Koenig package versions to the `package.json` files in `Ghost/core` and `Ghost/admin`

# Copyright & License

Copyright (c) 2013-2025 Ghost Foundation - Released under the [MIT license](LICENSE).