-
Notifications
You must be signed in to change notification settings - Fork 15
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
feat!: new architecture, update to Svelte 5 and refactor core lib #1127
base: main
Are you sure you want to change the base?
Conversation
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.
@edodusi Thanks a bunch for the set of improvements implemented here, and keeping this library to the latests standards. I've added a few comments, let me know if you need any clarification
update-types: | ||
- patch | ||
ignore: | ||
- dependency-name: '*' |
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.
@edodusi wouldn't the ignore
statement prevent the releases from working properly? Because it'll ignore also the updates coming from @storyblok/js
.
If that's the case, can we set it to "ignore all dependencies except @storyblok/js
"? cc @alvarosabu
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.
@alexjoverm look at the line after, this is to tell dependabot to ignore all minor
and major
versions of all packages, and focus only on patch
.
This is just for security updates, I should include a new rule for storyblok packages
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.
@edodusi in the way is set up, on the lines above (the groups
statement) it where it groups the security updates. But the ignore
applies to all minors and majors, not only security ones. Correct?
If that's the case, if in @storyblok/js
we publish a new minor release, wouldn't that be ignored by this pkg? If the idea is to have a separate dependabot config for storyblok package, is it included in this PR?
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.
yes exactly, because the desired outcome would be that dependabot only opens auto-approved PR with grouped patches (we can decide to auto-merge them), and we control manually minors and majors because sometime there are changes that alter some stuff even in minor updates and it's better we do that manually
For storyblok packages we should have specific rules, because maybe we want patches and minors to be automatically merged
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.
"because maybe we want patches and minors to be automatically merged" -> Exactly, we need it as that's how the whole release system works currently. Can we add them?
About security updates, makes total sense 👍
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.
added
src/app.d.ts
Outdated
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.
@edodusi are the app.d.ts
, app.html
and routes/+page.svelte
necessary as part of the library source code? Aren't they more of a playground files?
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.
this is package structure as scaffolded by the Svelte CLI for a library
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.
What are they used for? It could happen the CLI creates them as a playground, but we have a separate one for that
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.
they are not a playground but part of a library that we don't use, I can remove them
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.
actually app.html
is required by svelte-package, so we need it
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.
What is it needed for exactly? I still don't see the use as src of the library
Maybe is taken as the entry point for bundling?
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.
It's the entrypoint for sveltekit apps and library also are treated as sveltekit apps, this is a behavior we can't avoid if we want to use svelte-package unless we want to remove it and use only Vite to build and bundle
src/lib/StoryblokComponent.svelte
Outdated
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.
Blocking:
@edodusi Is it necessary to have an extra directory called lib? I would rather suggest having one for components like the @storyblok-vue
one and the rest in the root of src.
I see we have also a different structure on @storyblok-react
. Would we nice if we standardized a little bit and avoided complex directory structures.
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.
@alvarosabu this is the required structure for a Svelte library that builds with svelte-package
, see https://svelte.dev/docs/kit/packaging
Running the svelte-package command from @sveltejs/package will take the contents of src/lib and generate a dist directory (which can be configured) containing the following:
All the files in src/lib. Svelte components will be preprocessed, TypeScript files will be transpiled to JavaScript.
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.
Fair enough. If it's possible to configure I will just set it to src
but I respect svelte packages' best practices
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.
can be configured -i / --input — the input directory which contains all the files of the package. Defaults to src/lib
but I would stick with Svelte best practice, what do you think
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.
My personal point of view, agree on embracing the Svelte best practice and defaults, where possible.
export default storyblokLintConfig( | ||
includeIgnoreFile(gitignorePath), | ||
{ | ||
ignores: ['playground', '**/node_modules/**', 'README.md', 'LICENSE'], |
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.
We should not ignore the playground for the linter, the indentation is even different there @edodusi
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.
yes this is temporary @alvarosabu because I just put the old playground here (previous version) and we should update it completely, we'll go back to this
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.
oh ok ok, its gonna be done in a separate PR then?
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.
no I will add them here after we discuss the possibility of changing the public API of the lib, ATM the DX is exactly the same but I'm brainstorming some possible updates that I will share privately
"require": "./dist/index.js" | ||
} | ||
}, | ||
"main": "./dist/index.js", |
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.
@edodusi @roberto-butti is the build filename configurable? Should be ./dist/storyblok-svelte.js
to keep it consistent with other SDKs
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.
I tried with some custom configs and got many errors, went through some discussions for reference: sveltejs/kit#11429
Do you think this is important? If it is I'm gonna need some time to investigate this.
[name: string]: typeof SvelteComponent<any>; | ||
} | ||
|
||
export interface SbSvelteSDKOptions extends SbSDKOptions { | ||
components?: SbSvelteComponentsMap | CallableFunction; | ||
} | ||
|
||
export { apiPlugin } from "@storyblok/js"; | ||
export { apiPlugin } from '@storyblok/js'; |
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.
@edodusi this is the only line that confuses me in the old repo. why is this needed in the types.
we export the apiPlugin already in the src/lib/index.ts. I guess you should reevaluate this.
Major Refactor: Svelte 5 Update & Architecture Improvements
This PR introduces significant improvements to the Storyblok Svelte library, modernizing its architecture and upgrading to Svelte 5.
Svelte 5 Migration: Updated core components to utilize Svelte 5's new features including:
$state
,$props
,$derived
)Architecture Refactoring:
Core Library Improvements:
StoryblokComponent
implementationPlease test it with the included
playground
or by integrating it in a custom project