FreeSewing 3.0 is er eindelijk.
FreeSewing is the leading open source platform for made-to-measure sewing patterns, loved by home sewers and fashion entrepreneurs alike.
The 3.0 release culminates more than a year of work, and comes just over four years after the v2.0 release. What I’m saying is: I don’t make announcements like this often, and it’s a big deal. Je zou opgewonden moeten raken.
Brekende veranderingen
Laten we beginnen met het voor de hand liggende: dit is een grote release, dus er zijn baanbrekende veranderingen. Ze allemaal opnoemen zou een hele uitdaging zijn, en waarschijnlijk niet zo nuttig. The first pre-release versions of FreeSewing 3 is almost a year old, and all of the people who contributed designs have either ported their designs, or I did it for them.
Still, I want to list three breaking changes that are super obviously going to break your stuff if you rely on FreeSewing code;
- FreeSewing 3 is ESM only: Migrating a large Javascript project to ESM modules is enough to make even the most seasoned developers break down and cry, but it’s done.
- FreeSewing 3 uses named exports: There are obviously some places where a default export is required (looking at you NextJS) but whereever we can, we now use named exports exclusively because we all know those are better.
- FreeSewing 3 vereist Node 18 of nieuwer: Ik raad lts/hydrogen aan.
Met dat uit de weg, laten we het hebben over wat er nieuw is. Er is veel werk gestoken in deze uitgave en ik kan onmogelijk alles behandelen. Maar sta me toe om een paar van de meer fundamentele veranderingen te noemen.
Ontwerpen zijn nu JBOP
A big driver for the decision to freeze the v2 branch and start working on v3 was to make it easier to mix-and-match parts from various designs.
Design inheritance was already possible in v2, but because the configuration was handled on the design level, it required careful re-configuration of (required) measurements, options, part dependencies, and so on. It was possible but came with a lot of friction.
In v3, all configuration is moved to the part level, and a design is now not much more than just a bunch of parts (JBOP). It is the parts themselves that configure what they need. This includes anything from the measurements they require, the options they provide, the plugins they use, their dependencies, and so on.
This way, re-use parts from various designs, and all of their configuration, dependencies, plugins, and so on will follow.
Minder boilerplate
Creating a design has also become a lot simpler, you essentially pass your list of parts to our Design
constructor and you’re done:
import { Design } from '@freesewing/core'
export const MyDesign = new Design({
parts: [ /* ... your parts here ... */ ]
})
Speaking of less boilerplate, in v2, the most common plugins were already bundled in the @freesewing/plugin-bundle
package, but you still had to include them in your design. In v3, those plugins have moved to the @freesewing/core-plugins
package, and will be loaded by FreeSewing’s core library by default (although you can opt out of that).
Plugins met meer bevoegdheden
In addition to providing macros, snippets, or tapping into FreeSewing’s lifecycle hooks, plugins can now also add methods to the store.
This is allows further extending FreeSewing with whatever exciting thing you can thing of. As an example, the way logging is handled in the core library was re-implemented based on this. Which means that if you would like a different logging solution, you can simple provide your own log handler in a plugin.
Nieuwe ontwikkelomgeving
With the version 3 release comes a new development environment that closely mimics what we will be providing at FreeSewing.org (more on that later).
The development environment ships with various templates that you can use to either start a design from scratch, or extend one of our blocks. You don’t have to choose one over the other either, you can use all of these at the same time, and if you want even add more.
Our new development environment now allows (optionally) integrates with the FreeSewing backend. You can authenticate with your FreeSewing account so you can (re)use your measurements while working on your designs.
Niet alles is in versie
There’s a lot more I could talk about, but I need to address the elephant in the room: So we have 3.0 now, when do non-developers get to use this?
Nou… Ik heb wat meer tijd nodig. Everything is sort of ready, but some things always a bit more time because you can’t really to them in advance. Things like translation, some more testing, not to mention migrating 50k users to a completely different infrastructure.
So as a regular user of FreeSewing.org who is not itching to spin up a development environment, you will need to hold on a little longer. But clearly, it’s going to be soon now. I’d say a matter of weeks, rather than months.
In the meanwhile, if you find a problem or bug, create an issue because FreeSewing 3 is now production-ready and fully supported.
joost