A monorepo containing shared UI libraries for the Perses project. All libraries are versioned together and published as independent npm packages under the @perses-dev org.
This monorepo manages the core UI libraries that power the Perses platform. Each workspace is published as a separate npm package, but they all share the same version number to ensure compatibility.
| Package | NPM | Description |
|---|---|---|
@perses-dev/components |
Common UI components used across Perses features | |
@perses-dev/dashboards |
The dashboards feature in Perses | |
@perses-dev/explore |
The explore feature in Perses | |
@perses-dev/plugin-system |
The plugin system for Perses |
- Node.js 22+
- npm 10+
Clone the repository and install dependencies:
git clone https://github.com/perses/shared.git
cd shared
npm installThis monorepo uses Turborepo for efficient task running and caching.
npm run buildnpm run testnpm run type-check# Check for linting issues
npm run lint
# Fix linting issues automatically
npm run lint:fixWatch for changes and rebuild automatically:
npm run start# Clean all build outputs
npm run clean
# Clean and reinstall all dependencies
npm run reinstall
# Clear Turborepo cache
npm run clear-turbo-cacheTo link these shared libraries with your local Perses UI development environment, use the provided script:
./scripts/link-with-perses/link-with-perses.shThe script will back up your current dependencies, build and link the shared libraries for local development. It will search for the Perses UI app as a sibling directory by default. See the script helper for more details:
./scripts/link-with-perses/link-with-perses.sh --helpWarning
As the shared dependencies are file references, you cannot build the Perses UI for production while linked to local shared libraries. Make sure to unlink the shared libraries before building for production.
- Clone the perses repo https://github.com/perses/perses
- From the perses
uifolder install the ui dependencies withnpm install. - From the perses root folder, start the Perses API in dev mode with
./scripts/api_backend_dev.sh. - Clone this shared repo and install dependencies with
npm install.⚠️ Do not rename the cloned repo, otherwise it breaks the paths resolution on the perses repo side. - From the shared root folder, run
./scripts/link-with-perses/link-with-perses.sh. If your perses repo is in a different location than a sibling directory, use the--pathoption to specify its location. - From the perses
uifolder, runnpm run start:sharedto start the Perses UI in dev mode using the linked shared libraries with hot module reloading. - Make changes to the shared libraries and see them reflected in your local Perses UI.
- When done, run
./scripts/link-with-perses/link-with-perses.sh unlinkto restore the original dependencies in the Perses UI.
Please read CONTRIBUTING.md for details on our development process and how to submit pull requests.
See RELEASE.md for information about the release process.
This project is licensed under the Apache License 2.0 - see the LICENSE file for details.