Although I might not have time for Svelte videos, I wanted to express how brilliant the thumbnail is. It's so vibrant, vivacious and surreal.. good job for those awesome thumbnails! I enamored it.
I get that the point is to teach us how to think about components (and it's awesome!), but in the case of accordions, you can also use the html tags details and summary, which builds in the open/close logic. I don't think you can animate the transition yet, though.
Awesome tutorial and it was neat to see those reference sites and learn about the context API in a very simple manner! It's "collapse" as someone pointed out lol, but it happens. I think to avoid the TS underlines, it might be best to not set the script type to TS until that part of the video. Also, you mentioned accidently typing single = instead of double/triple ===. When you read them outloud/think of them, read "=" as "is assigned to" and "==" as "is equal to" and "===" as "is strictly equal to" and then you'll never make the mistake ;) (I'm sure you know the difference, but it helps to change the voice inside your head as you read it lol)
Very cool idea to implement it like this. The API is very nice to use, all the logic about IDs and selecting them is "hidden". Just one small suggestion: you didn't need the close class for the arrow. When the open class is removed, the transition is automatically played backwards.
@@JoyofCodeDev It works when you put the transition property on the button, not just in the open class. Here is a REPL - I paste the code since links are not allowed. let rotated = false; rotated=!rotated} class:rotated> 🍓 button { transition: transform 100ms ease-in-out; border-radius: 50%; padding:0.5rem; } .rotated { transform: rotate(90deg); }
Thanks for the content . Question, I got lost at context stuff.. if you are using the store.. why not just send the data through it instead of all the context complex magic? Still don't understand it. Thanks again, and please teach us how to export the components so we can use it in plain html
I think you meant 'collapse' instead of 'colapse', still great video non the less, always wondered about svelte fragments, also never used the context api but defenitely will after this video.
🔴 Patreon: www.patreon.com/joyofcode
💬 Discord: joyofcode.xyz/invite
Although I might not have time for Svelte videos, I wanted to express how brilliant the thumbnail is. It's so vibrant, vivacious and surreal.. good job for those awesome thumbnails! I enamored it.
Thank you! 😄
Probably just using midjourney
Really awesome video as always!
Remember, you can also have a default slot, so you don't have to wrap the content for example 😊👍
great timing man! Just 10 hours ago i was thinking to ask you about this on discord 😅
I get that the point is to teach us how to think about components (and it's awesome!), but in the case of accordions, you can also use the html tags details and summary, which builds in the open/close logic. I don't think you can animate the transition yet, though.
That's a good point but this gives you more control.
It could be nice to redo the same exercise with runes ^^
Agreed, we definitely need this ❤
Thanks, this is really a great tutorial.
Once Again, Areally great tuto!
Will make a video covering Unit test for this kind of component for exemple?
Yeah! 😄
Great content! Thank you!
You're welcome! 😊
Maybe out of scope for this, but a follow up on publishing as a npm package would be awesome!
I want to cover testing components and publishing in a future video.
@@JoyofCodeDev this could be great 🥳
Yes that would be great, publishing and tips on all the stuff to consider when using these components in vanilla JS projects vs Svelte Projects.
would love to see this :D
Awesome 🔥
Awesome tutorial and it was neat to see those reference sites and learn about the context API in a very simple manner! It's "collapse" as someone pointed out lol, but it happens. I think to avoid the TS underlines, it might be best to not set the script type to TS until that part of the video. Also, you mentioned accidently typing single = instead of double/triple ===. When you read them outloud/think of them, read "=" as "is assigned to" and "==" as "is equal to" and "===" as "is strictly equal to" and then you'll never make the mistake ;) (I'm sure you know the difference, but it helps to change the voice inside your head as you read it lol)
I type fast and ligatures make it even worse to find the problem. 😂
Very cool idea to implement it like this. The API is very nice to use, all the logic about IDs and selecting them is "hidden".
Just one small suggestion: you didn't need the close class for the arrow. When the open class is removed, the transition is automatically played backwards.
That's what I also thought and I tried it before but it doesn't work.
@@JoyofCodeDev It works when you put the transition property on the button, not just in the open class. Here is a REPL - I paste the code since links are not allowed.
let rotated = false;
rotated=!rotated} class:rotated>
🍓
button {
transition: transform 100ms ease-in-out;
border-radius: 50%;
padding:0.5rem;
}
.rotated {
transform: rotate(90deg);
}
@Script Raccoon Thank you for pointing out my mistake! 😄
@34:12 how do you get the variable autocomplete?
I'm using the CSS Var Complete extension but I should make a video on it.
great work man
Thank you! 😄
Thanks for the content . Question, I got lost at context stuff.. if you are using the store.. why not just send the data through it instead of all the context complex magic? Still don't understand it.
Thanks again, and please teach us how to export the components so we can use it in plain html
Using context is more suited for passing data between components while stores are great for managing global state.
Great content!
I think you meant 'collapse' instead of 'colapse', still great video non the less, always wondered about svelte fragments, also never used the context api but defenitely will after this video.
Thank you! 😄
Thank youuuu
34:40 you are ^^
sickkkkk
HOW IS HE STILL NOT AT 10K SUBS?
(also sorry for comment spam lol)
It's close! 😄
@@JoyofCodeDev Now get to 30k 😎
Next step: Exporting this as HTML Custom Web Elements to support framework agnostic components? 😅
Yes please!!
At lest vanilla JS components, since Custom Web Element support is currently a bit weak in Svelte
Anyone gets 'Cannot find module $lib/components/accrdion or its corresponding type declarations.`
9:18 💀
why does the console show true for colapse? isnt it set to false? mine shows false lol
Man... watching this and knowing svelte 5 is coming, this is going ot be out of date... Hopefully you make a new one when it's time.
where is the sample bro ?
The post with the example is in the description.
No HeadlessUI support, no Svelte.
Also Vue 3.2 is faster than Svelte...
HeadlessUI for Svelte seems getting traction again.
And hey, that's not the purpose of this video. It's about building your own components ; )
skill issue