Skip to content
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

[Roadmap] Road to v1! #259

Closed
JamesLMilner opened this issue Jun 2, 2024 · 12 comments
Closed

[Roadmap] Road to v1! #259

JamesLMilner opened this issue Jun 2, 2024 · 12 comments
Labels
in progress Feature is currently being worked on

Comments

@JamesLMilner
Copy link
Owner

JamesLMilner commented Jun 2, 2024

Firstly, hello anyone reading or following the repository. It's come to my mind that Terra Draw will be two years old in July, and we are still tagged in Alpha. Although this a very deliberate decision, to allow quick iteration and avoidance of the limitations of attempting to adhere to semantic versioning, I am conscious that it is realistically going to be putting people off using the library.

As such I'd want to lay out a roadmap to what a v1 iteration would look like. For me there are three main issues:

  1. Allowing validations across both drawing and selecting modes (essentially feat: add validate to all built in modes #256 as we have validation in select mode already). I personally feel like the validations provide an open ended mechanism for people to allow or prevent drawing or editing of any shape in any way they see fit. We could also expose common validations that the community uses in the future.

  2. Providing at least the foundations of a standardised approach to how we handle Web Mercator vs Globe based drawing. I am still working out how might be best to approach this, either at a global level (i.e. you pass a flag to Terra Draw, and then all operations will be geodesic) or if it should be more granular (i.e. a flag we pass at the mode level). There are lots of things to consider here, as an example someone may want to draw on a Web Mercator map but draw a geodesic line (i.e. via TerraDrawGreatCircle mode). Another example of such trickiness would be what the default behaviour should be - in TerraDrawCircleMode geodesic and Web Mercator circles would result in very different looking geometries when projected back and forth, which is confusing to some users (i.e. at the moment we have a geodesic circle by default, but perhaps some users expect it to be a perfect Web Mercator circle?). This issue is mostly capture by Support geodesic drawing (i.e globes) #23 but it needs fleshing out a little bit to capture the full scope.

  3. Trying to bullet proofing what already exists. Essentially we want to make sure Terra Draw is as bug free and painless to use as possible. Of course, an incredibly tough endeavour, but with a combination of working on the unit and end-to-end testing and the user documentation, I am confident we can get to a good position.

  4. EDIT: Splitting out adapters into their own packages. This has many benefits, firstly resolving [Bug] Library not usable without skipLibCheck: true? #350 which is a pain. The other is that it allows a sensible versioning strategy for adapters. As mapping libraries change we want to keep up with them, but also allow ways to support multiple versions of a library. Having separate packages for the adapters allows for this, and also reduces the surface area of the actual core library. This will be quite a big change and will require some small adjustments by users, but I feel it is the best option for the long term of the library.

@JamesLMilner JamesLMilner pinned this issue Jun 2, 2024
@JamesLMilner JamesLMilner added the in progress Feature is currently being worked on label Jun 2, 2024
@vladimir-velinov
Copy link

@JamesLMilner thanks for the provided roadmap. Any idea about timeline?

@JamesLMilner
Copy link
Owner Author

JamesLMilner commented Nov 26, 2024

@vladimir-velinov thanks for posting - the main thing at the moment preventing release in my eyes is #350. I want to get to this soon, maybe around end of December during the holidays. Could be looking at a v1 release in Q1 of 2025.

What are you working on out of interest?

@vladimir-velinov
Copy link

vladimir-velinov commented Nov 27, 2024

@JamesLMilner Q1 2025 sounds good. We're making use of Maplibre to create reusable Web component for our apps. We already integrated TerraDraw and work really well, but we'll need it to be labeled as official release, not beta in order to go in production.

@JamesLMilner
Copy link
Owner Author

I've added point 4, which is to do with splitting out adapters into seprate packages. This resolves quite a few problems for Terra Draw, for example map library versioning, avoiding people having to install unnecessary devDependencies, and also helping resolve #350 .

@JamesLMilner
Copy link
Owner Author

Hey folks - just an update from me, this is now up for draft PR! #395

I'm aiming to have a v1 ready for use by end of day, complete with separated adapters for each mapping library, which should resolve #350

@realsketchmapper
Copy link

I picked the wrong day to begin working with Terra Draw maybe? Lol. Hope to try the new Maplibre version soon.

@NormandoHall
Copy link

NormandoHall commented Jan 13, 2025

Finally 1.0.0!!!! Congratulations and thanks!

EDIT: To fix documentation. Importing adapter like this:

import TerraDrawLeafletAdapter from 'terra-draw-leaflet-adapter';

get the error:

SyntaxError: [vite] The requested module 'terra-draw-leaflet-adapter' does not provide an export named 'default'

fixed with named import:

import { TerraDrawLeafletAdapter } from 'terra-draw-leaflet-adapter';

@vladimir-velinov
Copy link

That's great news. Thanks a lot @JamesLMilner

@carljohan
Copy link

Thanks for all your hard work on Terra Draw. Congrats on v1! 🎉

@alanOracle
Copy link

Congratulations on v1 @JamesLMilner ! Thanks for your work.

@JamesLMilner
Copy link
Owner Author

@NormandoHall @vladimir-velinov @carljohan @alanOracle thank you all! Appreciate all your support. Hope the upgrade path is smooth and straight forward for you all.

@JamesLMilner
Copy link
Owner Author

I'm going to mark this as closed 👍🏻 Thanks everyone!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
in progress Feature is currently being worked on
Projects
None yet
Development

No branches or pull requests

6 participants