Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/vidundergunder/storyless

When Storybook is too much. UI DevTools and utilities for fast and enjoyable development.
https://github.com/vidundergunder/storyless

bun cli devtool devtools dx figma frontend nextjs open-source react storybook svg sync turborepo typescript ui

Last synced: 2 months ago
JSON representation

When Storybook is too much. UI DevTools and utilities for fast and enjoyable development.

Awesome Lists containing this project

README

        

# πŸ‰ Storyless

Storyless is a UI DevTool that lets you build and test components in isolation inside of your app.

For when design system powerhouses like [Storybook](https://storybook.com/) is just too much.

Direct interoperability with your app and main build tools means hard-to-integrate features like authentication, fetching, state management, themes, etc. will just work when you need them.

**[πŸ‘‰ LIVE DEMO](https://storyless.vercel.app/)**

![Storyless](packages/react-storyless/button.png)

## πŸš€ Get Started

### [πŸ“– Storyless (React)](https://github.com/VidunderGunder/storyless/tree/main/packages/react-storyless#readme)

Complimentary tools, on the house:

[🦩 Feasy – Feature Toogles](https://github.com/VidunderGunder/storyless/tree/main/apps/feasy#readme)
[🦘 JSON Switcheroo – CLI Tool](https://github.com/VidunderGunder/storyless/tree/main/packages/json-switcheroo#readme)
[πŸ₯· Figma to SVG – CLI Tool](https://github.com/VidunderGunder/storyless/tree/main/packages/figma-to-svg#readme)

## πŸš€ Get Started (for Contributors)

_Note that all installs may require restarting the terminal – and in some cases a complete reboot – to work properly_

Clone this repo to your development environment

Install [node](https://nodejs.org/en/) `>=20.0.0 <21.0.0`\*

> \*Alternatively, you can use [Node Version Manager](https://github.com/nvm-sh/nvm#installing-and-updating) with the included `.nvmrc` file
>
> ```sh
> nvm use
> ```

Install [bun](https://bun.sh/) `>=1.0.13`

Install dependencies:

```sh
bun i
```

Start developing:

```sh
bun dev
```

Unless you're a veteran, it is _highly recommended_ to read through the [**🀯 Problems During Development?**](https://github.com/VidunderGunder/storyless#-problems-during-development) section before starting development.

## What's inside?

This Turborepo includes the following packages & apps:

### Apps and Packages

- πŸ“‚ **apps**
- πŸ“– **docs** - _Storyless docs (Next.js)_
- 🦩 **feasy** - _Feasy Feature Toggling Service (Next.js)_
- ~~🦩 **feasy-api** - _Unused backend prototype for Feasy_~~
- β–² **nextjs-app-router** - _Next.js app (app router) for testing_
- β–² **nextjs-pages-router** - _Next.js app (pages router) for testing_
- πŸ“‚ **packages**
- πŸ“– **react-storyless** - _React (and Next.js) library for Storyless_
- 🦩 **feasy-drizzle** - _Library to do Feasy Database operations_
- πŸ₯· **figma-to-svg** - _CLI tool to convert Figma designs to SVGs_
- 🎨 **ui** - _Shared UI components for the monorepo_
- πŸ§™β€β™‚οΈ **scripts** - _Monorepo scripts_
- πŸ§™β€β™‚οΈ **tsconfig** - _Reusable TypeScript configurations_
- πŸ§™β€β™‚οΈ **eslint-config-storyless** - _Reusable ESLint configurations_

## πŸ“¦ Publish

_Note: You need to be a member of the `@storyless` npm organization to publish packages_

```bash
npm login
bun publish-packages
```

## Useful TurboRepo Links

Learn more about the power of Turborepo:

- [Tasks](https://turbo.build/repo/docs/core-concepts/monorepos/running-tasks)
- [Caching](https://turbo.build/repo/docs/core-concepts/caching)
- [Remote Caching](https://turbo.build/repo/docs/core-concepts/remote-caching)
- [Filtering](https://turbo.build/repo/docs/core-concepts/monorepos/filtering)
- [Configuration Options](https://turbo.build/repo/docs/reference/configuration)
- [CLI Usage](https://turbo.build/repo/docs/reference/command-line-reference)

## 🀯 Problems During Development?

Below are ways to solve them.

As of now we only support VSCode running on MacOS, Linux and WSL.

You are free to use anything else, but we can't guarantee that it will work.
Please document your findings if you try something else <3

### Generally

Restart your IDE (VSCode) and/or terminal

Restart your computer

### Permission errors when running commands (MacOS/Linux)

Prefix the command with `sudo`, e.g.:

```bash
sudo whatever you were trying to run
```

### Pulling changes from the repository

Always check for and install new dependecies when you pull changes from the repository:

```bash
bun i
```

### Wrong version of Node

- Check your version with
```bash
node -v
```
- Install the correct version according to `engines` in `package.json`

### Wrong version of bun

Check your version with

```bash
bun -v
```

Install the correct version according to `engines` in `package.json`

### Using 32-bit version of Node (Windows)

Getting `error Command failed with exit code 3221225477` or something similar?

Check if you're using 32-bit Node.js:

```bash
node -p "process.arch"
```

If so, ensure you're running on a 64-bit system, then install the 64-bit version instead.

### Divergent git branches

```bash
git config pull.rebase false
```

### Ports already in use

Kill the processes running on relevant ports:

```bash
bun run killports
```

### Weird TypeScript or ESLint errors

First, make sure you're running the workspace version of TypeScript and ESLint:

Open up any TypeScript file in the project and press...



  • ⌘ + Shift + P on Mac


  • Ctrl + Shift + P on Windows

Then ask VSCode to use the workspace TypeScript version:

```
> TypeScript: Select TypeScript Version
```

Then restart the TypeScript server:

```
> TypeScript: Restart TS server
```

Same for ESLint:

```
> ESLint: Restart ESLint server
```