-
-
Notifications
You must be signed in to change notification settings - Fork 130
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
Make the development process easier with Storybook #518
Conversation
Hello Adrien, |
Hi Alan, Happy return ;) Adrien works with the core team at Marmelab. We've discussed how to improve the API Platform admin developer experience, because we need a way to test various features in isolation. The current setup doesn't allow this. Using the demo (if you think about the e-commerce demo) won't do it either : the demo doesn't use guessers. And if you think about the current demo, it doesn't allow to test the connected setup. Storybook will let us test each guesser independently, with all their variants. It's the solution we use on react-admin. It's not heavy, it's super reactive, and it leads to a better design of each component as we have to think about their individual API. I really recommend going forward with this PR. |
Hello Alan, Thanks for your reply 🙂 As François said, I'm working with the React-Admin core team and while I was testing Api-Platform and the Api-Platform-Admin client, I was facing some issues. So why using Storybook?
|
84e6ca5
to
232df7b
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Otherwise it looks good 🙂
I still would like to test it locally though, so my review is WIP.
- by linking `@api-platform/admin` sources to an existing project; | ||
- by installing this project and running it through Storybook. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
These should link to their respective doc section (to act as a kind of TOC)
|
||
Create your client that will use `api-platform-admin` (replace `<yourproject>` by your project's name): | ||
> Prerequiste: running Api-Platform backend. See the [Getting Started guide](https://api-platform.com/docs/distribution/) to learn more. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this sill necessary? If I'm not mistaken you embedded a way to create one directly in this repo, didn't you?
|
||
Replace `src/App.js` by this one: | ||
Your client should already uses `@api-platform/admin` and its bootstrap file (usually: `src/App.tsx`) should at least contains: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Your client should already uses `@api-platform/admin` and its bootstrap file (usually: `src/App.tsx`) should at least contains: | |
Your client should already use `@api-platform/admin` and its bootstrap file (usually: `src/App.tsx`) should at least contains: |
|
||
#### Running Admin through Storybook | ||
|
||
If you don't have an existing API Platform application, you can use one of the bundled example APIs, and visualize the admin through [Storybook](https://storybook.js.org/). |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If you don't have an existing API Platform application, you can use one of the bundled example APIs, and visualize the admin through [Storybook](https://storybook.js.org/). | |
If you don't have an existing API Platform application, or don't want to use `yarn link`, you can use one of the bundled example APIs, and visualize the admin through [Storybook](https://storybook.js.org/). |
Get the source of `@api-platform/admin`: | ||
|
||
```shell | ||
cd .. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
cd ..
doesn't seem necessary to me since we won't need to move back and forth between two projects in this case, we only work with the admin
repo
start-simple: ## Start the simple Api-Platform backend and the Storybook frontend | ||
cd backend/simple && make build && make up HTTP_PORT=${SIMPLE_HTTP_PORT} HTTP3_PORT=${SIMPLE_HTTPS_PORT} HTTPS_PORT=${SIMPLE_HTTPS_PORT} && cd .. && yarn run storybook | ||
|
||
stop-simple: ## Stop and prune the simple Api-Platform backend | ||
cd backend/simple && make prune |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You should also provide targets to
- only start the embedded backend
- only start the storybook, without starting a backend (in case the user are providing their own backend)
I'm in favor of doing something like that instead of relying on the demo (which is a moving target, and sometimes not very stable). I just wonder if we couldn't find a way to not "pollute" this Git repository by scripting the installation of the distribution instead of bundling it. It will be hard to maintain otherwise. One last thing, I'm not a fan of Makefiles (except - maybe - in C/C++ projects, but even in these ecosystems we have better alternatives now, such as Bazel, or Makefiles generators such as CMake). Couldn't we just add some |
|
||
Create your client that will use `api-platform-admin` (replace `<yourproject>` by your project's name): | ||
> Prerequiste: running Api-Platform backend. See the [Getting Started guide](https://api-platform.com/docs/distribution/) to learn more. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
> Prerequiste: running Api-Platform backend. See the [Getting Started guide](https://api-platform.com/docs/distribution/) to learn more. | |
> Prerequiste: running API Platform backend. See the [Getting Started guide](https://api-platform.com/docs/distribution/) to learn more. |
I don't see this as a repo "pollution". It's required for a faster developer experience. It doesn't harm the users of the npm package, as it doesn't contain the examples. You'll have to help us find such a way, because I don't see how we can do it. The code in this repo must at least contain the schema of the entities. If you had a CLI tool that allows to generate an API platform app based on a schema, that would allow us to remove some of that code. That being said, we'll also have to include an example with authentication, and this one requires custom code, so I don't see how it can be generated.
Npm alone won't suffice: we must start both the frontend (a Vite app that can be launched with npm) and the backend (a docker compose with the API platform server and a Postgres BDD). We could script that with shell, but that'd be reinventing make IMHO. |
What I meant by using the demo, is cloning or downloading the API Platform Demo, not using it directly. Alright for using Storybook, to develop or test each guesser independently.
You could try to use https://github.com/api-platform/schema-generator. It would be great if we can avoid having the code of an API Platform application directly in this repo, we know from experience that having to maintain an app like this can be tiresome because we already do it for the distribution and the demo. |
We've tried that and it's not enough. We need to test how the admin app can adapt to non-basic APIs (with authentication, embedded relationships, custom getters, etc), and the generator can't allow for that.
We do keep the code of example applications in the react-admin repo and it's a great developer experience: it helps us detect regressions, write upgrade guides, simulate integrations with third-parties, and more generally keep everything in one place. Yes it can be tiresome to maintain, but not doing it means leaving undiscovered bugs, publishing breaking changes without noticing it, or publishing code samples in the doc that don't actually work with the last version of the library. Three problems that API Platform admin actually suffers from. It's because we want to fix these problems that we suggest a more secure approach ;). |
Sure I understand, I think custom code is needed too but only the necessary one.
You're completely right, the only difference is that API Platform Admin is not our main project, that's why we try to reduce the maintenance burden for it. We should strive to have the best equilibrium here. Obviously, I'm saying this only if another approach could work, maybe it's not the case and having a Symfony app is the only way. |
Our first attempt was to script the installation of API Platform via a # setup-api-platform.sh
# make commands come from the "Using a Makefile" section of Symfony Docker repository
git clone https://github.com/dunglas/symfony-docker.git api-platform
docker compose up -d
make composer c="req symfony/orm-pack"
docker compose up database -d
make composer c="req symfony/maker-bundle --dev"
make sf c="make:user --is-entity --identity-property-name=email --with-password -n -- User"
make sf c="make:migration -n"
make sf c="doctrine:migrations:migrate -n"
#... This works for a simple backend, but what about more complicated setups. For instance, to configure an API protected by JWT, we need to modify several files ( We therefore concluded that the best solution was to provide already configured backend according to the needs of the scenarios (simple, JWT protected, etc). This way we can keep the plug-n-play approach. |
The demo has all of this, and it is an open source project so adding new features to it is possible and encouraged. Cloning it or requiring it as a submodule is likely the best option. |
Hello @dunglas and @alanpoulain, The demo comes with many features and it seems very complete and useful. So I have some interrogations in my mind:
I would be really nice if we find a way to include Storybook 🙂 Thanks for reading! |
For Keycloak, maybe @vincentchalamon has some input on it? You're right, you will have less freedom to add different scenario if you use the demo. But it's not impossible to add them if they have value, and it will be beneficial in the long term. The demo should not be broken, if the tests break things in the demo, we will fix it 🙂 |
close as completed by #535 |
null
This PR attempts to help newcomers to develop easily the Admin client, without the need to link source and a dedicated project with
yarn link
. Instead, newcomers could develop directly by cloning this repository and by running amake
command.The idea:
In this logic, we could add as many backends as scenarios. For instance, we could add a story and a protected backend to test that React-admin's
authProvider
workflow works as expected.Branch:
TODO: