Been wading through the docs for over an hour now. Don’t see any information on how to actually install and use this.
Been to Github and it say I need to install separate packages from npm, but doesn’t tell me what packages I need. Tells me to check out the website for more details.
As far as I can see the website doesn’t say anything about how to install this at all.
Seen a few examples that are barely even half-examples too. E.g. The example on Linting just demonstrates how to create the linting function, doesn’t demonstrate how you actually configure the editor to use it at all.
Don’t see a single example of setting anything up from scratch or any information on what packages I need anywhere.
You’re expected to know how to install NPM packages. As for which ones to use, you get to decide! As you say you’re unsure what to use, I’d recommend starting with the basic setup, just like the example above uses.
I found the instruction in the web docs to have a look at Rollup or Webpack, and I thought rather than spend my evening learning how to put that together from scratch I’ll see if there’s a Vite template that will do this.
It’s also taken a while to work out how to load content into the editor. There are a couple of places that demonstrate how to use a transaction to update a selection in the document, but nowhere is there any information on how to replace the content completely.
The documentation is quite painful. It’s more interested in telling me about the system architecture than how to install and use the editor, and more interested in telling me how to write a new language extension from scratch than on telling me what extensions already exist and how to install them.
Like the Linter example. It shows you how to write a linter function from scratch, but doesn’t show you how to install it!
CDN’s exist, and if you Google for editor solutions you’ll likely stumble across this through StackOverflow, but the CDN only exports fromTextArea and a couple of other types, which don’t appear to be documented, and nothing in the current documentation works from the CDN.
My ASP Core project has tooling to consume libraries from CDN, but not from npm. I’m loathe to add SPA style client build and bundle process to my basic multi-page web app just for this, as that’s going to polute and add complexity to my entire development, build and deployment tool pipeline.
So I guess I need some way to bundle this library that enables me to consume it from my simple web app without an SPA style build process, but at the same time that’s got to somehow handle the es6 style module references which aren’t going to work untransformed in the browser.
I’ve got Rollup working and integrated into my solution. But that was painful. I can’t say I understand why an editor whose primary use case is going to be in HTML is distributed in a manner that is so incompatible with that environment.
But of course step 6 is important: if you’re already using a bundler, (obviously?) don’t also separately use rollup.
That said, it would be nice if there was a “complete” example in the example section, because it does feel like that’s missing. The “bundling with rollup” and “configuration” kind of together cover what you “probably” need to do, but the first focuses on something most folks won’t need these days (given the proliferation of frameworks that already bundle) and so will ignore that, or they’re being presented an approach they won’t need until later (name, compartments) and so they might not recognize they can use the same code but without the extra wrapper.
So it feels like there’s first “basic code” example missing for showing the minimal ESM code that sets up an editor, like what’s listed above. And then the “if you need to manually bundle” and “extra config example” examples can be the second and third example.