Make Your Own Svelte Component Library

Поделиться
HTML-код
  • Опубликовано: 17 янв 2025

Комментарии • 53

  • @JoyofCodeDev
    @JoyofCodeDev  Год назад +1

    🔴 Patreon: www.patreon.com/joyofcode
    💬 Discord: joyofcode.xyz/invite

  • @mumk
    @mumk Год назад +8

    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.

  • @SarcevicAntonio
    @SarcevicAntonio Год назад +7

    Really awesome video as always!
    Remember, you can also have a default slot, so you don't have to wrap the content for example 😊👍

  • @henilmalaviya
    @henilmalaviya Год назад +1

    great timing man! Just 10 hours ago i was thinking to ask you about this on discord 😅

  • @pineappleseltzer9450
    @pineappleseltzer9450 Год назад +6

    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.

    • @JoyofCodeDev
      @JoyofCodeDev  Год назад +7

      That's a good point but this gives you more control.

  • @我的暱稱
    @我的暱稱 11 месяцев назад +3

    It could be nice to redo the same exercise with runes ^^

    • @mr_clean575
      @mr_clean575 8 месяцев назад

      Agreed, we definitely need this ❤

  • @rahulxcr
    @rahulxcr Год назад

    Thanks, this is really a great tutorial.

  • @leboyoyo
    @leboyoyo Год назад +2

    Once Again, Areally great tuto!
    Will make a video covering Unit test for this kind of component for exemple?

  •  Год назад

    Great content! Thank you!

  • @justingolden21
    @justingolden21 Год назад +3

    Maybe out of scope for this, but a follow up on publishing as a npm package would be awesome!

    • @JoyofCodeDev
      @JoyofCodeDev  Год назад +6

      I want to cover testing components and publishing in a future video.

    • @我的暱稱
      @我的暱稱 Год назад

      @@JoyofCodeDev this could be great 🥳

    • @O1O1OO1
      @O1O1OO1 Год назад +1

      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.

    • @jadelily18
      @jadelily18 Год назад

      would love to see this :D

  • @argonjs
    @argonjs Год назад

    Awesome 🔥

  • @justingolden21
    @justingolden21 Год назад

    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)

    • @JoyofCodeDev
      @JoyofCodeDev  Год назад

      I type fast and ligatures make it even worse to find the problem. 😂

  • @ScriptRaccoon
    @ScriptRaccoon Год назад

    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
      @JoyofCodeDev  Год назад

      That's what I also thought and I tried it before but it doesn't work.

    • @ScriptRaccoon
      @ScriptRaccoon Год назад

      ​@@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);
      }

    • @JoyofCodeDev
      @JoyofCodeDev  Год назад +1

      @Script Raccoon Thank you for pointing out my mistake! 😄

  • @TheMaxiviper117
    @TheMaxiviper117 Год назад

    @34:12 how do you get the variable autocomplete?

    • @JoyofCodeDev
      @JoyofCodeDev  Год назад

      I'm using the CSS Var Complete extension but I should make a video on it.

  • @HarrisonPage-wd3vz
    @HarrisonPage-wd3vz Год назад

    great work man

  • @tomich20
    @tomich20 Год назад +1

    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

    • @JoyofCodeDev
      @JoyofCodeDev  Год назад +1

      Using context is more suited for passing data between components while stores are great for managing global state.

  • @azag777
    @azag777 Год назад

    Great content!

  • @Hugos68
    @Hugos68 Год назад +3

    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.

  • @namthanhnguyen2554
    @namthanhnguyen2554 Год назад

    Thank youuuu

  • @我的暱稱
    @我的暱稱 Год назад

    34:40 you are ^^

  • @casper5314
    @casper5314 Год назад

    sickkkkk

  • @justingolden21
    @justingolden21 Год назад

    HOW IS HE STILL NOT AT 10K SUBS?
    (also sorry for comment spam lol)

  • @aer1al0
    @aer1al0 Год назад +1

    Next step: Exporting this as HTML Custom Web Elements to support framework agnostic components? 😅

    • @O1O1OO1
      @O1O1OO1 Год назад

      Yes please!!
      At lest vanilla JS components, since Custom Web Element support is currently a bit weak in Svelte

  • @lungarella-raffaele
    @lungarella-raffaele 6 месяцев назад

    Anyone gets 'Cannot find module $lib/components/accrdion or its corresponding type declarations.`

  • @werrutkyupnext
    @werrutkyupnext Год назад +1

    9:18 💀

  • @thederpykrafter
    @thederpykrafter 10 месяцев назад

    why does the console show true for colapse? isnt it set to false? mine shows false lol

  • @DeviantFox
    @DeviantFox 11 месяцев назад

    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.

  • @nzaeroax
    @nzaeroax Год назад

    where is the sample bro ?

    • @JoyofCodeDev
      @JoyofCodeDev  Год назад

      The post with the example is in the description.

  • @greendsnow
    @greendsnow Год назад

    No HeadlessUI support, no Svelte.
    Also Vue 3.2 is faster than Svelte...

    • @O1O1OO1
      @O1O1OO1 Год назад +1

      HeadlessUI for Svelte seems getting traction again.
      And hey, that's not the purpose of this video. It's about building your own components ; )

    • @Wurstfinger-rl1zi
      @Wurstfinger-rl1zi 7 месяцев назад

      skill issue